From f19ba003245e8230cd33ba878a542f6afea787a1 Mon Sep 17 00:00:00 2001 From: Zeno Rogue Date: Sun, 15 Aug 2021 21:01:47 +0200 Subject: [PATCH] rulegen:: fixed for the case of a single live branch at root. TBH more hack than a proper fix --- rulegen.cpp | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/rulegen.cpp b/rulegen.cpp index 998ad13b..c53ebd32 100644 --- a/rulegen.cpp +++ b/rulegen.cpp @@ -1124,14 +1124,22 @@ void advance(vector& bdata, branchdata at, int dir, bool start_forwa } } +bool dubious_lr; + void verify_lr(branchdata bd, int dir) { if(dir) { bd.spin_full(dir); if(bd.dir == 0) bd.dir = bd.at.at->type; } auto& r = treestates[bd.id].rules; for(int i=0; i bdata; int dist_at = rg.at->dist; - while(left != right) { + dubious_lr = left == right; + do { /* can be false in case of multi-edges */ if(treestates[id].rules[left] >= 0) { @@ -1161,14 +1170,20 @@ void examine_branch(int id, int left, int right) { advance(bdata, br, +1, true, false, dist_at+5); } } + while(left != right); int steps = 0; while(true) { steps++; - if(steps == max_examine_branch) + + if(steps == max_examine_branch) { + debuglist = { rg }; throw rulegen_failure("max_examine_branch exceeded"); + } - if(isize(bdata) > max_bdata) + if(isize(bdata) > max_bdata) { + debuglist = { rg }; throw rulegen_failure("max_bdata exceeded"); + } /* advance both */ vector bdata2;