toml_edit/
array_of_tables.rs1use std::iter::FromIterator;
2
3use crate::{Array, Item, Table};
4
5#[derive(Clone, Debug, Default)]
7pub struct ArrayOfTables {
8 pub(crate) span: Option<std::ops::Range<usize>>,
10 pub(crate) values: Vec<Item>,
11}
12
13impl ArrayOfTables {
17 pub fn new() -> Self {
19 Default::default()
20 }
21}
22
23impl ArrayOfTables {
25 pub fn into_array(mut self) -> Array {
27 for value in self.values.iter_mut() {
28 value.make_value();
29 }
30 let mut a = Array::with_vec(self.values);
31 a.fmt();
32 a
33 }
34
35 pub fn span(&self) -> Option<std::ops::Range<usize>> {
39 self.span.clone()
40 }
41
42 pub(crate) fn despan(&mut self, input: &str) {
43 self.span = None;
44 for value in &mut self.values {
45 value.despan(input);
46 }
47 }
48}
49
50impl ArrayOfTables {
51 pub fn iter(&self) -> ArrayOfTablesIter<'_> {
53 Box::new(self.values.iter().filter_map(Item::as_table))
54 }
55
56 pub fn iter_mut(&mut self) -> ArrayOfTablesIterMut<'_> {
58 Box::new(self.values.iter_mut().filter_map(Item::as_table_mut))
59 }
60
61 pub fn len(&self) -> usize {
64 self.values.len()
65 }
66
67 pub fn is_empty(&self) -> bool {
69 self.len() == 0
70 }
71
72 pub fn clear(&mut self) {
74 self.values.clear();
75 }
76
77 pub fn get(&self, index: usize) -> Option<&Table> {
79 self.values.get(index).and_then(Item::as_table)
80 }
81
82 pub fn get_mut(&mut self, index: usize) -> Option<&mut Table> {
84 self.values.get_mut(index).and_then(Item::as_table_mut)
85 }
86
87 pub fn push(&mut self, table: Table) {
89 self.values.push(Item::Table(table));
90 }
91
92 pub fn insert(&mut self, index: usize, table: Table) {
99 self.values.insert(index, Item::Table(table));
100 }
101
102 pub fn replace(&mut self, index: usize, table: Table) -> Table {
119 match std::mem::replace(&mut self.values[index], Item::Table(table)) {
120 Item::Table(old) => old,
121 x => panic!("non-table item {x:?} in an array of tables"),
122 }
123 }
124
125 pub fn remove(&mut self, index: usize) -> Table {
127 self.values
128 .remove(index)
129 .into_table()
130 .expect("cannot have any other item in an array-of-tables")
131 }
132
133 pub fn retain<F>(&mut self, mut keep: F)
140 where
141 F: FnMut(&Table) -> bool,
142 {
143 self.values
144 .retain(|item| item.as_table().map(&mut keep).unwrap_or(false));
145 }
146}
147
148pub type ArrayOfTablesIter<'a> = Box<dyn Iterator<Item = &'a Table> + 'a>;
150pub type ArrayOfTablesIterMut<'a> = Box<dyn Iterator<Item = &'a mut Table> + 'a>;
152pub type ArrayOfTablesIntoIter = Box<dyn Iterator<Item = Table>>;
154
155impl Extend<Table> for ArrayOfTables {
156 fn extend<T: IntoIterator<Item = Table>>(&mut self, iter: T) {
157 for value in iter {
158 self.push(value);
159 }
160 }
161}
162
163impl FromIterator<Table> for ArrayOfTables {
164 fn from_iter<I>(iter: I) -> Self
165 where
166 I: IntoIterator<Item = Table>,
167 {
168 let v = iter.into_iter().map(Item::Table);
169 Self {
170 values: v.collect(),
171 span: None,
172 }
173 }
174}
175
176impl IntoIterator for ArrayOfTables {
177 type Item = Table;
178 type IntoIter = ArrayOfTablesIntoIter;
179
180 fn into_iter(self) -> Self::IntoIter {
181 Box::new(
182 self.values
183 .into_iter()
184 .filter(|v| v.is_table())
185 .map(|v| v.into_table().unwrap()),
186 )
187 }
188}
189
190impl<'s> IntoIterator for &'s ArrayOfTables {
191 type Item = &'s Table;
192 type IntoIter = ArrayOfTablesIter<'s>;
193
194 fn into_iter(self) -> Self::IntoIter {
195 self.iter()
196 }
197}
198
199#[cfg(feature = "display")]
200impl std::fmt::Display for ArrayOfTables {
201 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
202 self.clone().into_array().fmt(f)
204 }
205}