1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
use core::ops::ControlFlow;

use crate::{
    hkt::hkt,
    nameable,
    protocol::{any_t, walker::HintMeta, Yield, Effect, SyncEffect, Visitor},
};

pub trait Sequence<'ctx, E: Effect<'ctx, ControlFlow<(), ()>>> {
    fn visit<'a>(
        &'a mut self,
        scope: &'a mut dyn SequenceScope<'ctx, E>,
    ) -> Yield<'a, 'ctx, ControlFlow<(), ()>, E>
    where
        'ctx: 'a;
}

nameable! {
    pub struct Name['a, 'ctx, E];

    impl [E] for dyn Sequence<'ctx, E> + 'a where {
        E: Effect<'ctx, ControlFlow<(), ()>> + Effect<'ctx, ControlFlow<(), Status>>,
        'ctx: 'a
    }

    impl [E] where dyn Sequence<'ctx, E> + 'a {
        E: Effect<'ctx, ControlFlow<(), ()>> + Effect<'ctx, ControlFlow<(), Status>>,
        'ctx: 'a
    }
}

pub trait SequenceScope<'ctx, E>
where
    E: Effect<'ctx, ControlFlow<(), Status>>,
{
    fn next<'a>(&'a mut self, visitor: Visitor<'a, 'ctx, E>) -> Yield<'a, 'ctx, ControlFlow<(), Status>, E>
    where
        'ctx: 'a;
}

#[derive(PartialEq, Eq, PartialOrd, Ord, Copy, Clone, Debug)]
pub enum Status {
    Done,
    Continue,
}

hkt!((any_t): for<'a, 'ctx> pub KnownHkt => Known);

#[derive(Default)]
pub struct Known {
    pub len: (usize, Option<usize>),
}

pub struct Hint {
    pub len: (usize, Option<usize>),
}

impl<'a, 'ctx: 'a, E: Effect<'ctx, ControlFlow<(), ()>>> HintMeta<'ctx> for dyn Sequence<'ctx, E> + '_ {
    type Known = KnownHkt<'ctx>;

    type Hint = Hint;
}