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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
use std::iter::{once, Once};

use super::Tree;

pub enum IntoIter<T> {
    Unique(Once<T>),
    Multiple(NoneIntoIter<T>),
}

impl<T> From<Tree<T>> for IntoIter<T> {
    fn from(value: Tree<T>) -> Self {
        match value {
            Tree::Leaf(value) => Self::Unique(once(value)),
            Tree::Node(multiple) => Self::Multiple(NoneIntoIter {
                state: NodeIterState::Normal,
                iter: multiple.into_iter(),
            }),
        }
    }
}

impl<T> Iterator for IntoIter<T> {
    type Item = T;

    fn next(&mut self) -> Option<Self::Item> {
        match self {
            Self::Unique(once) => once.next(),
            Self::Multiple(multiple) => multiple.next(),
        }
    }
}

pub enum NodeIterState<T> {
    Normal,
    Recursion(Box<NoneIntoIter<T>>),
}

pub struct NoneIntoIter<T> {
    state: NodeIterState<T>,
    iter: std::vec::IntoIter<Tree<T>>,
}

impl<T> Iterator for NoneIntoIter<T> {
    type Item = T;

    fn next(&mut self) -> Option<Self::Item> {
        match &mut self.state {
            NodeIterState::Normal => {
                let next = self.iter.next()?;

                match next {
                    Tree::Leaf(value) => Some(value),
                    Tree::Node(trees) => {
                        self.state = NodeIterState::Recursion(Box::new(Self {
                            state: NodeIterState::Normal,
                            iter: trees.into_iter(),
                        }));
                        self.next()
                    }
                }
            }
            NodeIterState::Recursion(rec) => {
                let next = rec.next();

                match next {
                    None => {
                        self.state = NodeIterState::Normal;
                        self.next()
                    }
                    value => value,
                }
            }
        }
    }
}

impl<Item> IntoIterator for Tree<Item> {
    type Item = Item;

    type IntoIter = IntoIter<Item>;

    fn into_iter(self) -> Self::IntoIter {
        self.into()
    }
}