]> git.lizzy.rs Git - rust.git/blob - src/librustdoc/fold.rs
Rollup merge of #84048 - konan8205:master, r=jsha
[rust.git] / src / librustdoc / fold.rs
1 use crate::clean::*;
2
3 crate fn strip_item(mut item: Item) -> Item {
4     if !matches!(*item.kind, StrippedItem(..)) {
5         item.kind = box StrippedItem(item.kind);
6     }
7     item
8 }
9
10 crate trait DocFolder: Sized {
11     fn fold_item(&mut self, item: Item) -> Option<Item> {
12         Some(self.fold_item_recur(item))
13     }
14
15     /// don't override!
16     fn fold_inner_recur(&mut self, kind: ItemKind) -> ItemKind {
17         match kind {
18             StrippedItem(..) => unreachable!(),
19             ModuleItem(i) => ModuleItem(self.fold_mod(i)),
20             StructItem(mut i) => {
21                 let num_fields = i.fields.len();
22                 i.fields = i.fields.into_iter().filter_map(|x| self.fold_item(x)).collect();
23                 i.fields_stripped |=
24                     num_fields != i.fields.len() || i.fields.iter().any(|f| f.is_stripped());
25                 StructItem(i)
26             }
27             UnionItem(mut i) => {
28                 let num_fields = i.fields.len();
29                 i.fields = i.fields.into_iter().filter_map(|x| self.fold_item(x)).collect();
30                 i.fields_stripped |=
31                     num_fields != i.fields.len() || i.fields.iter().any(|f| f.is_stripped());
32                 UnionItem(i)
33             }
34             EnumItem(mut i) => {
35                 let num_variants = i.variants.len();
36                 i.variants = i.variants.into_iter().filter_map(|x| self.fold_item(x)).collect();
37                 i.variants_stripped |=
38                     num_variants != i.variants.len() || i.variants.iter().any(|f| f.is_stripped());
39                 EnumItem(i)
40             }
41             TraitItem(mut i) => {
42                 i.items = i.items.into_iter().filter_map(|x| self.fold_item(x)).collect();
43                 TraitItem(i)
44             }
45             ImplItem(mut i) => {
46                 i.items = i.items.into_iter().filter_map(|x| self.fold_item(x)).collect();
47                 ImplItem(i)
48             }
49             VariantItem(i) => {
50                 let i2 = i.clone(); // this clone is small
51                 match i {
52                     Variant::Struct(mut j) => {
53                         let num_fields = j.fields.len();
54                         j.fields = j.fields.into_iter().filter_map(|x| self.fold_item(x)).collect();
55                         j.fields_stripped |= num_fields != j.fields.len()
56                             || j.fields.iter().any(|f| f.is_stripped());
57                         VariantItem(Variant::Struct(j))
58                     }
59                     _ => VariantItem(i2),
60                 }
61             }
62             x => x,
63         }
64     }
65
66     /// don't override!
67     fn fold_item_recur(&mut self, mut item: Item) -> Item {
68         item.kind = box match *item.kind {
69             StrippedItem(box i) => StrippedItem(box self.fold_inner_recur(i)),
70             _ => self.fold_inner_recur(*item.kind),
71         };
72         item
73     }
74
75     fn fold_mod(&mut self, m: Module) -> Module {
76         Module {
77             span: m.span,
78             items: m.items.into_iter().filter_map(|i| self.fold_item(i)).collect(),
79         }
80     }
81
82     fn fold_crate(&mut self, mut c: Crate) -> Crate {
83         c.module = self.fold_item(c.module).unwrap();
84
85         {
86             let external_traits = { std::mem::take(&mut *c.external_traits.borrow_mut()) };
87             for (k, mut v) in external_traits {
88                 v.trait_.items =
89                     v.trait_.items.into_iter().filter_map(|i| self.fold_item(i)).collect();
90                 c.external_traits.borrow_mut().insert(k, v);
91             }
92         }
93         c
94     }
95 }