aboutsummaryrefslogtreecommitdiff
path: root/sys/libbio/phylo.c
diff options
context:
space:
mode:
authorNicholas Noll <nbnoll@eml.cc>2020-04-22 18:15:17 -0700
committerNicholas Noll <nbnoll@eml.cc>2020-04-22 18:15:17 -0700
commitfb4c4ceba416376751196cdbbdb5f7240e08a405 (patch)
treebb874085d6d7715c24da544e9f71ef05e6a2a80a /sys/libbio/phylo.c
parent583656a3537bc43a28c58111520143df04bf27f2 (diff)
fix: bug squashing with newick parser
Diffstat (limited to 'sys/libbio/phylo.c')
-rw-r--r--sys/libbio/phylo.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/sys/libbio/phylo.c b/sys/libbio/phylo.c
index 8033e35..374cd08 100644
--- a/sys/libbio/phylo.c
+++ b/sys/libbio/phylo.c
@@ -6,9 +6,15 @@ error
phylo·addchild(bio·Node* parent, bio·Node* child)
{
bio·Node *it, *sibling;
- if (parent->nchild < 2) {
+ switch (parent->nchild) {
+ case 1:
+ parent->child[0]->sibling = child;
+ case 0:
parent->child[parent->nchild++] = child;
- } else {
+ break;
+
+ default:
+ sibling = parent->child[1];
for (it = parent->child[1]->sibling; it != nil; it = it->sibling) {
sibling = it;
}
@@ -16,5 +22,6 @@ phylo·addchild(bio·Node* parent, bio·Node* child)
parent->nchild++;
}
+ child->parent = parent;
return 0;
}