Skip to content

Commit

Permalink
Make TableCollections iterable
Browse files Browse the repository at this point in the history
  • Loading branch information
hyanwong committed Jun 21, 2019
1 parent 57ff0ab commit f492ef1
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 0 deletions.
11 changes: 11 additions & 0 deletions python/tests/test_tables.py
Original file line number Diff line number Diff line change
Expand Up @@ -1497,6 +1497,17 @@ def test_asdict(self):
self.assertEqual(set(d1.keys()), set(d2.keys()))
# TODO test the fromdict constructor

def test_iter(self):
def test_iter(table_collection):
table_names = [
attr_name for attr_name in sorted(dir(table_collection))
if isinstance(getattr(table_collection, attr_name), tskit.BaseTable)]
for n in table_names:
yield n, getattr(table_collection, n)
ts = msprime.simulate(10, mutation_rate=1, random_seed=1)
for t1, t2 in zip(test_iter(ts.tables), ts.tables):
self.assertEquals(t1, t2)

def test_equals_empty(self):
self.assertEqual(tskit.TableCollection(), tskit.TableCollection())

Expand Down
15 changes: 15 additions & 0 deletions python/tskit/tables.py
Original file line number Diff line number Diff line change
Expand Up @@ -1505,6 +1505,21 @@ def __banner(self, title):
title_line += "#"
return line + "\n" + title_line + "\n" + line + "\n"

def __iter__(self):
"""
Iterate over the tables in this TableCollection, ordered by table name
(i.e. deterministically), returning a tuple of (table_name, table_object)
"""
# For speed we simply list these by hand. They are tested against an
# automatically generated version in the unit tests
yield 'edges', self.edges
yield 'individuals', self.individuals
yield 'migrations', self.migrations
yield 'mutations', self.mutations
yield 'nodes', self.nodes
yield 'populations', self.populations
yield 'provenances', self.provenances

def __str__(self):
s = self.__banner("Individuals")
s += str(self.individuals) + "\n"
Expand Down

0 comments on commit f492ef1

Please sign in to comment.