PkmnLib_rs/src/static_data/moves/secondary_effect.rs

64 lines
1.5 KiB
Rust
Raw Normal View History

#[derive(PartialEq, Debug)]
pub enum EffectParameter {
Bool(bool),
Int(i64),
Float(f32),
String(String),
}
#[derive(PartialEq, Debug)]
pub struct SecondaryEffect {
chance: f32,
effect_name: String,
parameters: Vec<EffectParameter>,
}
impl SecondaryEffect {
pub fn empty() -> SecondaryEffect {
SecondaryEffect {
chance: 0.0,
effect_name: "".to_string(),
parameters: vec![],
}
}
pub fn new(
chance: f32,
effect_name: String,
parameters: Vec<EffectParameter>,
) -> SecondaryEffect {
SecondaryEffect {
chance,
effect_name,
parameters,
}
}
pub fn chance(&self) -> f32 {
self.chance
}
pub fn effect_name(&self) -> &str {
&self.effect_name
}
pub fn parameters(&self) -> &Vec<EffectParameter> {
&self.parameters
}
}
#[cfg(test)]
mod tests {
use crate::static_data::moves::secondary_effect::SecondaryEffect;
use assert_approx_eq::assert_approx_eq;
#[test]
fn create_secondary_effect() {
let empty = SecondaryEffect::empty();
2022-06-11 18:51:37 +00:00
assert_approx_eq!(empty.chance(), 0.0);
assert_eq!(empty.effect_name(), "");
assert_eq!(empty.parameters().len(), 0);
let set = SecondaryEffect::new(50.0, "foo".to_string(), Vec::new());
2022-06-11 18:51:37 +00:00
assert_approx_eq!(set.chance(), 50.0);
assert_eq!(set.effect_name(), "foo");
assert_eq!(set.parameters().len(), 0);
}
}