diff options
| author | Daniel Schadt <kingdread@gmx.de> | 2020-07-23 17:40:42 +0200 | 
|---|---|---|
| committer | Daniel Schadt <kingdread@gmx.de> | 2020-07-23 17:40:42 +0200 | 
| commit | d2a3a49dc4759ede6cc9f553955eb289477a9d74 (patch) | |
| tree | ac060c0f88904aea67bd0a005affab51d01e2d82 /src/analyzers | |
| parent | d64ead757122e713d2cbb133d5fe683537cfcf6c (diff) | |
| download | evtclib-d2a3a49dc4759ede6cc9f553955eb289477a9d74.tar.gz evtclib-d2a3a49dc4759ede6cc9f553955eb289477a9d74.tar.bz2 evtclib-d2a3a49dc4759ede6cc9f553955eb289477a9d74.zip | |
implement strike Analyzers
Diffstat (limited to 'src/analyzers')
| -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)) +    } +} | 
