object_rainbow/impls/
vec.rs

1use std::collections::VecDeque;
2
3use crate::*;
4
5impl<T: InlineOutput> ToOutput for Vec<T> {
6    fn to_output(&self, output: &mut dyn Output) {
7        T::slice_to_output(self, output);
8    }
9}
10
11impl<T: ListHashes> ListHashes for Vec<T> {
12    fn list_hashes(&self, f: &mut impl FnMut(Hash)) {
13        self.iter_list_hashes(f);
14    }
15}
16
17impl<T: Topological> Topological for Vec<T> {
18    fn traverse(&self, visitor: &mut impl PointVisitor) {
19        self.iter_traverse(visitor);
20    }
21}
22
23impl<T: ParseInline<I>, I: ParseInput> Parse<I> for Vec<T> {
24    fn parse(input: I) -> crate::Result<Self> {
25        input.parse_vec()
26    }
27}
28
29impl<T: Tagged> Tagged for Vec<T> {
30    const TAGS: Tags = T::TAGS;
31}
32
33impl<T: InlineOutput> ToOutput for VecDeque<T> {
34    fn to_output(&self, output: &mut dyn Output) {
35        let (l, r) = self.as_slices();
36        T::slice_to_output(l, output);
37        T::slice_to_output(r, output);
38    }
39}
40
41impl<T: ListHashes> ListHashes for VecDeque<T> {
42    fn list_hashes(&self, f: &mut impl FnMut(Hash)) {
43        self.iter_list_hashes(f);
44    }
45}
46
47impl<T: Topological> Topological for VecDeque<T> {
48    fn traverse(&self, visitor: &mut impl PointVisitor) {
49        self.iter_traverse(visitor);
50    }
51}
52
53impl<T: ParseInline<I>, I: ParseInput> Parse<I> for VecDeque<T> {
54    fn parse(input: I) -> crate::Result<Self> {
55        input.parse_vec().map(From::from)
56    }
57}
58
59impl<T: Tagged> Tagged for VecDeque<T> {
60    const TAGS: Tags = T::TAGS;
61}