Use Box<dyn Iterator> as return type of functions
This commit is contained in:
parent
3a81585d51
commit
33b5975f93
@ -1,6 +1,5 @@
|
|||||||
use crate::color::Rgb;
|
use crate::color::Rgb;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::collections::vec_deque;
|
|
||||||
|
|
||||||
pub mod collide;
|
pub mod collide;
|
||||||
pub mod fade;
|
pub mod fade;
|
||||||
@ -17,6 +16,8 @@ pub use moving_rainbow::{MovingRainbow, MovingRainbowParams};
|
|||||||
pub use orb::{Orb, OrbParams};
|
pub use orb::{Orb, OrbParams};
|
||||||
pub use solid::{Solid, SolidParams};
|
pub use solid::{Solid, SolidParams};
|
||||||
|
|
||||||
|
pub type ColorIterator<'a> = Box<dyn Iterator<Item = &'a Rgb> + 'a>;
|
||||||
|
|
||||||
pub trait FormRender {
|
pub trait FormRender {
|
||||||
fn render(&self) -> String;
|
fn render(&self) -> String;
|
||||||
}
|
}
|
||||||
@ -193,7 +194,7 @@ impl Parameters {
|
|||||||
pub trait Pattern: std::fmt::Debug + Send + Sync {
|
pub trait Pattern: std::fmt::Debug + Send + Sync {
|
||||||
fn init(&mut self, num_lights: u16) -> Result<(), ()>;
|
fn init(&mut self, num_lights: u16) -> Result<(), ()>;
|
||||||
fn step(&mut self) -> Result<bool, ()>;
|
fn step(&mut self) -> Result<bool, ()>;
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb>;
|
fn get_strip<'a>(&'a self) -> ColorIterator;
|
||||||
}
|
}
|
||||||
|
|
||||||
// #[cfg(test)]
|
// #[cfg(test)]
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, Rgb};
|
use crate::color::{self, Rgb};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::collections::{vec_deque, VecDeque};
|
use std::collections::VecDeque;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct CollideParams {
|
pub struct CollideParams {
|
||||||
@ -183,7 +183,7 @@ impl Pattern for Collide {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb> {
|
fn get_strip<'a>(&'a self) -> ColorIterator<'a> {
|
||||||
self.lights_buf.iter()
|
Box::new(self.lights_buf.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, merge_colors_u8, Rgb};
|
use crate::color::{self, merge_colors_u8, Rgb};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::{
|
use std::{collections::VecDeque, iter};
|
||||||
collections::{vec_deque, VecDeque},
|
|
||||||
iter,
|
|
||||||
};
|
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct FadeParams {
|
pub struct FadeParams {
|
||||||
@ -78,7 +75,7 @@ impl Pattern for Fade {
|
|||||||
self.lights_buf = VecDeque::from(vec![color::BLACK; self.num_lights.into()]);
|
self.lights_buf = VecDeque::from(vec![color::BLACK; self.num_lights.into()]);
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb> {
|
fn get_strip<'a>(&'a self) -> ColorIterator {
|
||||||
self.lights_buf.iter()
|
Box::new(self.lights_buf.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, Rgb};
|
use crate::color::{self, Rgb};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::{
|
use std::{collections::VecDeque, iter};
|
||||||
collections::{vec_deque, VecDeque},
|
|
||||||
iter,
|
|
||||||
};
|
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct FlashingParams {
|
pub struct FlashingParams {
|
||||||
@ -90,7 +87,7 @@ impl Pattern for Flashing {
|
|||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb> {
|
fn get_strip<'a>(&'a self) -> ColorIterator {
|
||||||
self.lights_buf.iter()
|
Box::new(self.lights_buf.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, Rgb};
|
use crate::color::{self, Rgb};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::collections::{vec_deque, VecDeque};
|
use std::collections::VecDeque;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct MovingPixelParams {
|
pub struct MovingPixelParams {
|
||||||
@ -68,7 +68,7 @@ impl Pattern for MovingPixel {
|
|||||||
*self.lights_buf.get_mut(0).ok_or(())? = self.color;
|
*self.lights_buf.get_mut(0).ok_or(())? = self.color;
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb> {
|
fn get_strip<'a>(&'a self) -> ColorIterator {
|
||||||
self.lights_buf.iter()
|
Box::new(self.lights_buf.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, Rgb, RAINBOW};
|
use crate::color::{self, Rgb, RAINBOW};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::{
|
use std::{collections::VecDeque, convert::TryFrom, iter};
|
||||||
collections::{vec_deque, VecDeque},
|
|
||||||
convert::TryFrom,
|
|
||||||
iter,
|
|
||||||
};
|
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct MovingRainbowParams {
|
pub struct MovingRainbowParams {
|
||||||
|
@ -1,10 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, Rgb};
|
use crate::color::{self, Rgb};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::{
|
use std::{collections::VecDeque, iter};
|
||||||
collections::{vec_deque, VecDeque},
|
|
||||||
iter,
|
|
||||||
};
|
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct OrbParams {
|
pub struct OrbParams {
|
||||||
@ -127,7 +124,7 @@ impl Pattern for Orb {
|
|||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb> {
|
fn get_strip<'a>(&'a self) -> ColorIterator {
|
||||||
self.lights_buf.iter()
|
Box::new(self.lights_buf.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use super::{FormRender, InputRender, Pattern};
|
use super::{ColorIterator, FormRender, InputRender, Pattern};
|
||||||
use crate::color::{self, Rgb};
|
use crate::color::{self, Rgb};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::collections::{vec_deque, VecDeque};
|
use std::collections::VecDeque;
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||||
pub struct SolidParams {
|
pub struct SolidParams {
|
||||||
@ -57,7 +57,7 @@ impl Pattern for Solid {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_strip(&self) -> vec_deque::Iter<Rgb> {
|
fn get_strip<'a>(&'a self) -> ColorIterator {
|
||||||
self.lights_buf.iter()
|
Box::new(self.lights_buf.iter())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user