aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/analyzers/mod.rs7
-rw-r--r--src/analyzers/strikes.rs30
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))
+ }
+}