c{0: 0 (((1 string-address)) <- ((new)) abc) -- nil c{0: 1 (((2 string-address)) <- ((new)) a) -- nil c{0: 2 (((3 boolean)) <- ((match-at)) ((1 string-address)) ((2 string-address)) ((4 literal))) -- nil c{1: 0 ✓ (((1 string-address)) <- ((new)) abc) c{1: 1 ✓ (((2 string-address)) <- ((new)) a) c{1: 2 ✓ (((3 boolean)) <- ((match-at)) ((1 string-address)) ((2 string-address)) ((4 literal))) cn0: convert-names in main cn0: (((1 string-address)) <- ((new)) abc) nil nil cn0: checking arg abc cn0: checking oarg ((1 string-address)) maybe-add: ((1 string-address)) cn0: (((2 string-address)) <- ((new)) a) nil nil cn0: checking arg a cn0: checking oarg ((2 string-address)) maybe-add: ((2 string-address)) cn0: (((3 boolean)) <- ((match-at)) ((1 string-address)) ((2 string-address)) ((4 literal))) nil nil cn0: checking arg ((1 string-address)) maybe-add: ((1 string-address)) cn0: checking arg ((2 string-address)) maybe-add: ((2 string-address)) cn0: checking arg ((4 literal)) cn0: checking oarg ((3 boolean)) maybe-add: ((3 boolean)) cn1: (((1 string-address)) <- ((new)) abc) cn1: (((2 string-address)) <- ((new)) a) cn1: (((3 boolean)) <- ((match-at)) ((1 string-address)) ((2 string-address)) ((4 literal))) schedule: main run: main 0: (((1 string-address)) <- ((new)) abc) run: main 0: 1000 => ((1 string-address)) mem: ((1 string-address)): 1 <= 1000 run: main 1: (((2 string-address)) <- ((new)) a) run: main 1: 1004 => ((2 string-address)) mem: ((2 string-address)): 2 <= 1004 run: main 2: (((3 boolean)) <- ((match-at)) ((1 string-address)) ((2 string-address)) ((4 literal))) mem: ((1 string-address)) => 1000 mem: ((2 string-address)) => 1004 run: match-at/main 0: (((default-space space-address)) <- ((new)) ((space literal)) ((30 literal))) run: match-at/main 0: 1006 => ((default-space space-address)) run: match-at/main 1: (((1 string-address)) <- ((next-input))) arg: nil 0 (1000 1004 4) run: match-at/main 1: 1000 => ((1 string-address)) mem: ((1 string-address)): 1008 <= 1000 run: match-at/main 2: (((2 string-address)) <- ((next-input))) arg: nil 1 (1000 1004 4) run: match-at/main 2: 1004 => ((2 string-address)) mem: ((2 string-address)): 1009 <= 1004 run: match-at/main 3: (((3 integer)) <- ((next-input))) arg: nil 2 (1000 1004 4) run: match-at/main 3: 4 => ((3 integer)) mem: ((3 integer)): 1010 <= 4 run: match-at/main 4: (((4 integer)) <- ((length)) ((2 string-address) (deref))) array-len: ((2 string-address) (deref)) mem: ((1004 integer) (raw)) => 1 run: match-at/main 4: 1 => ((4 integer)) mem: ((4 integer)): 1011 <= 1 run: match-at/main 5: (((5 integer)) <- ((length)) ((1 string-address) (deref))) array-len: ((1 string-address) (deref)) mem: ((1000 integer) (raw)) => 3 run: match-at/main 5: 3 => ((5 integer)) mem: ((5 integer)): 1012 <= 3 run: match-at/main 6: (((5 integer)) <- ((subtract)) ((5 integer)) ((4 integer))) mem: ((5 integer)) => 3 mem: ((4 integer)) => 1 run: match-at/main 6: 2 => ((5 integer)) mem: ((5 integer)): 1012 <= 2 run: match-at/main 7: (((6 boolean)) <- ((lesser-or-equal)) ((3 integer)) ((5 integer))) mem: ((3 integer)) => 4 mem: ((5 integer)) => 2 run: match-at/main 7: nil => ((6 boolean)) mem: ((6 boolean)): 1013 <= nil run: match-at/main 8: (((jump-if)) ((6 boolean)) ((1 offset))) mem: ((6 boolean)) => nil run: match-at/main 9: (((reply)) ((nil literal))) run: main 2: nil => ((3 boolean)) mem: ((3 boolean)): 3 <= nil schedule: done with routine nil