Skip to main content

subtr_actor/stats/analysis_graph/nodes/
half_flip.rs

1use super::*;
2use crate::stats::calculators::*;
3use crate::*;
4
5/// Detects half-flips from player frame state during live play.
6pub struct HalfFlipNode {
7    calculator: HalfFlipCalculator,
8}
9
10impl HalfFlipNode {
11    pub fn new() -> Self {
12        Self {
13            calculator: HalfFlipCalculator::new(),
14        }
15    }
16}
17
18impl Default for HalfFlipNode {
19    fn default() -> Self {
20        Self::new()
21    }
22}
23
24impl AnalysisNode for HalfFlipNode {
25    type State = HalfFlipCalculator;
26
27    fn name(&self) -> &'static str {
28        "half_flip"
29    }
30
31    fn emitted_events(&self) -> &'static [crate::stats::calculators::EmittedEvent] {
32        crate::stats::calculators::HALF_FLIP_EMITTED_EVENTS
33    }
34
35    fn dependencies(&self) -> NodeDependencies {
36        vec![
37            frame_info_dependency(),
38            player_frame_state_dependency(),
39            live_play_dependency(),
40        ]
41    }
42
43    fn evaluate(&mut self, ctx: &AnalysisStateContext<'_>) -> SubtrActorResult<()> {
44        self.calculator.update(
45            ctx.get::<FrameInfo>()?,
46            ctx.get::<PlayerFrameState>()?,
47            ctx.get::<LivePlayState>()?,
48        )
49    }
50
51    fn finish(&mut self, ctx: &AnalysisStateContext<'_>) -> SubtrActorResult<()> {
52        self.calculator.finalize(ctx.get::<FrameInfo>()?);
53        Ok(())
54    }
55
56    fn state(&self) -> &Self::State {
57        &self.calculator
58    }
59}
60
61pub(crate) fn boxed_default() -> Box<dyn AnalysisNodeDyn> {
62    Box::new(HalfFlipNode::new())
63}