diff options
-rw-r--r-- | src/analyzers/mod.rs | 7 | ||||
-rw-r--r-- | src/analyzers/strikes.rs | 30 |
2 files changed, 36 insertions, 1 deletions
diff --git a/src/analyzers/mod.rs b/src/analyzers/mod.rs index c440136..f2cd2c7 100644 --- a/src/analyzers/mod.rs +++ b/src/analyzers/mod.rs @@ -22,6 +22,7 @@ use crate::{Boss, Log}; pub mod fractals; pub mod helpers; pub mod raids; +pub mod strikes; /// The outcome of a fight. #[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)] @@ -104,6 +105,10 @@ pub fn for_log<'l>(log: &'l Log) -> Option<Box<dyn Analyzer + 'l>> { Some(Box::new(fractals::GenericFractal::new(log))) } - _ => None, + Boss::IcebroodConstruct + | Boss::VoiceOfTheFallen + | Boss::FraenirOfJormag + | Boss::Boneskinner + | Boss::WhisperOfJormag => Some(Box::new(strikes::GenericStrike::new(log))), } } diff --git a/src/analyzers/strikes.rs b/src/analyzers/strikes.rs new file mode 100644 index 0000000..82fcd79 --- /dev/null +++ b/src/analyzers/strikes.rs @@ -0,0 +1,30 @@ +//! Analyzers for Strike Mission logs. +use crate::{ + analyzers::{helpers, Analyzer, Outcome}, + Log, +}; + +#[derive(Debug, Clone, Copy)] +pub struct GenericStrike<'log> { + log: &'log Log, +} + +impl<'log> GenericStrike<'log> { + pub fn new(log: &'log Log) -> Self { + GenericStrike { log } + } +} + +impl<'log> Analyzer for GenericStrike<'log> { + fn log(&self) -> &Log { + self.log + } + + fn is_cm(&self) -> bool { + false + } + + fn outcome(&self) -> Option<Outcome> { + Outcome::from_bool(helpers::boss_is_dead(self.log)) + } +} |