|
1 | 1 | //! Traits related to user-facing types |
2 | 2 |
|
3 | | -use crate::edge_table::EdgeTableIterator; |
4 | | -use crate::individual_table::IndividualTableIterator; |
5 | | -use crate::migration_table::MigrationTableIterator; |
6 | | -use crate::mutation_table::MutationTableIterator; |
7 | | -use crate::node_table::NodeTableIterator; |
8 | | -use crate::population_table::PopulationTableIterator; |
9 | | -use crate::site_table::SiteTableIterator; |
10 | 3 | use crate::table_iterator::make_table_iterator; |
11 | 4 | use crate::EdgeTable; |
12 | 5 | use crate::IndividualTable; |
@@ -60,63 +53,64 @@ pub trait TableAccess { |
60 | 53 | fn edges(&self) -> EdgeTable; |
61 | 54 |
|
62 | 55 | /// Return an iterator over the edges. |
63 | | - /// See [`EdgeTable::iter`] for details. |
64 | | - fn edges_iter(&self) -> EdgeTableIterator { |
65 | | - make_table_iterator::<EdgeTable>(self.edges()) |
| 56 | + fn edges_iter(&self) -> Box<dyn Iterator<Item = crate::edge_table::EdgeTableRow> + '_> { |
| 57 | + Box::new(make_table_iterator::<EdgeTable>(self.edges())) |
66 | 58 | } |
67 | 59 |
|
68 | 60 | /// Get reference to the [``NodeTable``](crate::NodeTable). |
69 | 61 | fn nodes(&self) -> NodeTable; |
70 | 62 |
|
71 | 63 | /// Return an iterator over the nodes. |
72 | | - /// See [`NodeTable::iter`] for details. |
73 | | - fn nodes_iter(&self) -> NodeTableIterator { |
74 | | - make_table_iterator::<NodeTable>(self.nodes()) |
| 64 | + fn nodes_iter(&self) -> Box<dyn Iterator<Item = crate::node_table::NodeTableRow> + '_> { |
| 65 | + Box::new(make_table_iterator::<NodeTable>(self.nodes())) |
75 | 66 | } |
76 | 67 |
|
77 | 68 | /// Get reference to the [``MutationTable``](crate::MutationTable). |
78 | 69 | fn mutations(&self) -> MutationTable; |
79 | 70 |
|
80 | 71 | /// Return an iterator over the mutations. |
81 | | - /// See [`MutationTable::iter`] for details. |
82 | | - fn mutations_iter(&self) -> MutationTableIterator { |
83 | | - make_table_iterator::<MutationTable>(self.mutations()) |
| 72 | + fn mutations_iter( |
| 73 | + &self, |
| 74 | + ) -> Box<dyn Iterator<Item = crate::mutation_table::MutationTableRow> + '_> { |
| 75 | + Box::new(make_table_iterator::<MutationTable>(self.mutations())) |
84 | 76 | } |
85 | 77 |
|
86 | 78 | /// Get reference to the [``SiteTable``](crate::SiteTable). |
87 | 79 | fn sites(&self) -> SiteTable; |
88 | 80 |
|
89 | 81 | /// Return an iterator over the sites. |
90 | | - /// See [`SiteTable::iter`] for details. |
91 | | - fn sites_iter(&self) -> SiteTableIterator { |
92 | | - make_table_iterator::<SiteTable>(self.sites()) |
| 82 | + fn sites_iter(&self) -> Box<dyn Iterator<Item = crate::site_table::SiteTableRow> + '_> { |
| 83 | + Box::new(make_table_iterator::<SiteTable>(self.sites())) |
93 | 84 | } |
94 | 85 |
|
95 | 86 | /// Get reference to the [``PopulationTable``](crate::PopulationTable). |
96 | 87 | fn populations(&self) -> PopulationTable; |
97 | 88 |
|
98 | 89 | /// Return an iterator over the populations. |
99 | | - /// See [`PopulationTable::iter`] for details. |
100 | | - fn populations_iter(&self) -> PopulationTableIterator { |
101 | | - make_table_iterator::<PopulationTable>(self.populations()) |
| 90 | + fn populations_iter( |
| 91 | + &self, |
| 92 | + ) -> Box<dyn Iterator<Item = crate::population_table::PopulationTableRow> + '_> { |
| 93 | + Box::new(make_table_iterator::<PopulationTable>(self.populations())) |
102 | 94 | } |
103 | 95 |
|
104 | 96 | /// Get reference to the [``MigrationTable``](crate::MigrationTable). |
105 | 97 | fn migrations(&self) -> MigrationTable; |
106 | 98 |
|
107 | 99 | /// Return an iterator over the migration events. |
108 | | - /// See [`MigrationTable::iter`] for details. |
109 | | - fn migrations_iter(&self) -> MigrationTableIterator { |
110 | | - make_table_iterator::<MigrationTable>(self.migrations()) |
| 100 | + fn migrations_iter( |
| 101 | + &self, |
| 102 | + ) -> Box<dyn Iterator<Item = crate::migration_table::MigrationTableRow> + '_> { |
| 103 | + Box::new(make_table_iterator::<MigrationTable>(self.migrations())) |
111 | 104 | } |
112 | 105 |
|
113 | 106 | /// Get reference to the [``IndividualTable``](crate::IndividualTable). |
114 | 107 | fn individuals(&self) -> IndividualTable; |
115 | 108 |
|
116 | 109 | /// Return an iterator over the individuals. |
117 | | - /// See [`IndividualTable::iter`] for details. |
118 | | - fn individuals_iter(&self) -> IndividualTableIterator { |
119 | | - make_table_iterator::<IndividualTable>(self.individuals()) |
| 110 | + fn individuals_iter( |
| 111 | + &self, |
| 112 | + ) -> Box<dyn Iterator<Item = crate::individual_table::IndividualTableRow> + '_> { |
| 113 | + Box::new(make_table_iterator::<IndividualTable>(self.individuals())) |
120 | 114 | } |
121 | 115 | } |
122 | 116 |
|
|
0 commit comments