c{0: 0 (((1 string-address)) <- ((new)) abc) -- nil c{0: 1 (((2 string-address)) <- ((new)) bd) -- nil c{0: 2 (((3 integer)) <- ((find-substring)) ((1 string-address)) ((2 string-address)) ((0 literal))) -- nil c{1: 0 ✓ (((1 string-address)) <- ((new)) abc) c{1: 1 ✓ (((2 string-address)) <- ((new)) bd) c{1: 2 ✓ (((3 integer)) <- ((find-substring)) ((1 string-address)) ((2 string-address)) ((0 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)) bd) nil nil cn0: checking arg bd cn0: checking oarg ((2 string-address)) maybe-add: ((2 string-address)) cn0: (((3 integer)) <- ((find-substring)) ((1 string-address)) ((2 string-address)) ((0 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 ((0 literal)) cn0: checking oarg ((3 integer)) maybe-add: ((3 integer)) cn1: (((1 string-address)) <- ((new)) abc) cn1: (((2 string-address)) <- ((new)) bd) cn1: (((3 integer)) <- ((find-substring)) ((1 string-address)) ((2 string-address)) ((0 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)) bd) run: main 1: 1004 => ((2 string-address)) mem: ((2 string-address)): 2 <= 1004 run: main 2: (((3 integer)) <- ((find-substring)) ((1 string-address)) ((2 string-address)) ((0 literal))) mem: ((1 string-address)) => 1000 mem: ((2 string-address)) => 1004 run: find-substring/main 0: (((default-space space-address)) <- ((new)) ((space literal)) ((30 literal))) run: find-substring/main 0: 1007 => ((default-space space-address)) run: find-substring/main 1: (((1 string-address)) <- ((next-input))) arg: nil 0 (1000 1004 0) run: find-substring/main 1: 1000 => ((1 string-address)) mem: ((1 string-address)): 1009 <= 1000 run: find-substring/main 2: (((2 string-address)) <- ((next-input))) arg: nil 1 (1000 1004 0) run: find-substring/main 2: 1004 => ((2 string-address)) mem: ((2 string-address)): 1010 <= 1004 run: find-substring/main 3: (((3 integer)) <- ((next-input))) arg: nil 2 (1000 1004 0) run: find-substring/main 3: 0 => ((3 integer)) mem: ((3 integer)): 1011 <= 0 run: find-substring/main 4: (((4 character)) <- ((index)) ((2 string-address) (deref)) ((0 literal))) array-len: ((1004 string) (raw)) mem: ((1004 integer) (raw)) => 2 mem: ((1005 byte) (raw)) => b run: find-substring/main 4: #\b => ((4 character)) mem: ((4 character)): 1012 <= #\b run: find-substring/main 5: (((5 integer)) <- ((length)) ((1 string-address) (deref))) array-len: ((1 string-address) (deref)) mem: ((1000 integer) (raw)) => 3 run: find-substring/main 5: 3 => ((5 integer)) mem: ((5 integer)): 1013 <= 3 run: find-substring/main 6: (((6 boolean)) <- ((greater-or-equal)) ((3 integer)) ((5 integer))) mem: ((3 integer)) => 0 mem: ((5 integer)) => 3 run: find-substring/main 6: nil => ((6 boolean)) mem: ((6 boolean)): 1014 <= nil run: find-substring/main 7: (((jump-if)) ((6 boolean)) ((5 offset))) mem: ((6 boolean)) => nil run: find-substring/main 8: (((7 boolean)) <- ((match-at)) ((1 string-address)) ((2 string-address)) ((3 integer))) mem: ((1 string-address)) => 1000 mem: ((2 string-address)) => 1004 mem: ((3 integer)) => 0 run: match-at/find-substring/main 0: (((default-space space-address)) <- ((new)) ((space literal)) ((30 literal))) run: match-at/find-substring/main 0: 1038 => ((default-space space-address)) run: match-at/find-substring/main 1: (((1 string-address)) <- ((next-input))) arg: nil 0 (1000 1004 0) run: match-at/find-substring/main 1: 1000 => ((1 string-address)) mem: ((1 string-address)): 1040 <= 1000 run: match-at/find-substring/main 2: (((2 string-address)) <- ((next-input))) arg: nil 1 (1000 1004 0) run: match-at/find-substring/main 2: 1004 => ((2 string-address)) mem: ((2 string-address)): 1041 <= 1004 run: match-at/find-substring/main 3: (((3 integer)) <- ((next-input))) arg: nil 2 (1000 1004 0) run: match-at/find-substring/main 3: 0 => ((3 integer)) mem: ((3 integer)): 1042 <= 0 run: match-at/find-substring/main 4: (((4 integer)) <- ((length)) ((2 string-address) (deref))) array-len: ((2 string-address) (deref)) mem: ((1004 integer) (raw)) => 2 run: match-at/find-substring/main 4: 2 => ((4 integer)) mem: ((4 integer)): 1043 <= 2 run: mat
c{0: 0 (((1 integer)) <- ((copy)) ((0 literal))) -- nil
c{0: 1 (((2 integer)) <- ((copy)) ((0 literal))) -- nil
c{0: 2 (((3 integer)) <- ((copy)) ((0 literal))) -- nil
c{0: 3 (((break))) -- ((open 3))
c{0: 4 (((reply))) -- ((close 4) (open 3))
c{1: 0 ✓ (((1 integer)) <- ((copy)) ((0 literal)))
c{1: 1 ✓ (((2 integer)) <- ((copy)) ((0 literal)))
c{1: 2 ✓ (((3 integer)) <- ((copy)) ((0 literal)))
c{1: 3 X (((break))) => (((jump)) ((0 offset)))
c{1: 4 ✓ (((reply)))