c{0: 0 (((1 string-address)) <- ((new)) a/b) -- nil c{0: 1 (((2 string-address-array-address)) <- ((split)) ((1 string-address)) ((/ literal))) -- nil c{1: 0 ✓ (((1 string-address)) <- ((new)) a/b) c{1: 1 ✓ (((2 string-address-array-address)) <- ((split)) ((1 string-address)) ((/ literal))) cn0: convert-names in main cn0: (((1 string-address)) <- ((new)) a/b) nil nil cn0: checking arg a/b cn0: checking oarg ((1 string-address)) maybe-add: ((1 string-address)) cn0: (((2 string-address-array-address)) <- ((split)) ((1 string-address)) ((/ literal))) nil nil cn0: checking arg ((1 string-address)) maybe-add: ((1 string-address)) cn0: checking arg ((/ literal)) cn0: checking oarg ((2 string-address-array-address)) maybe-add: ((2 string-address-array-address)) cn1: (((1 string-address)) <- ((new)) a/b) cn1: (((2 string-address-array-address)) <- ((split)) ((1 string-address)) ((/ literal))) schedule: main run: main 0: (((1 string-address)) <- ((new)) a/b) run: main 0: 1000 => ((1 string-address)) mem: ((1 string-address)): 1 <= 1000 run: main 1: (((2 string-address-array-address)) <- ((split)) ((1 string-address)) ((/ literal))) mem: ((1 string-address)) => 1000 run: split/main 0: (((default-space space-address)) <- ((new)) ((space literal)) ((30 literal))) run: split/main 0: 1004 => ((default-space space-address)) run: split/main 1: (((1 string-address)) <- ((next-input))) arg: nil 0 (1000 #\/) run: split/main 1: 1000 => ((1 string-address)) mem: ((1 string-address)): 1006 <= 1000 run: split/main 2: (((2 character)) <- ((next-input))) arg: nil 1 (1000 #\/) run: split/main 2: #\/ => ((2 character)) mem: ((2 character)): 1007 <= #\/ run: split/main 3: (((3 integer)) <- ((length)) ((1 string-address) (deref))) array-len: ((1 string-address) (deref)) mem: ((1000 integer) (raw)) => 3 run: split/main 3: 3 => ((3 integer)) mem: ((3 integer)): 1008 <= 3 run: split/main 4: (((4 boolean)) <- ((equal)) ((3 integer)) ((0 literal))) mem: ((3 integer)) => 3 run: split/main 4: nil => ((4 boolean)) mem: ((4 boolean)): 1009 <= nil run: split/main 5: (((jump-unless)) ((4 boolean)) ((2 offset))) mem: ((4 boolean)) => nil run: split/main 8: (((6 integer)) <- ((copy)) ((1 literal))) run: split/main 8: 1 => ((6 integer)) mem: ((6 integer)): 1011 <= 1 run: split/main 9: (((7 integer)) <- ((copy)) ((0 literal))) run: split/main 9: 0 => ((7 integer)) mem: ((7 integer)): 1012 <= 0 run: split/main 10: (((7 integer)) <- ((find-next)) ((1 string-address)) ((2 character)) ((7 integer))) mem: ((1 string-address)) => 1000 mem: ((2 character)) => / mem: ((7 integer)) => 0 run: find-next/split/main 0: (((default-space space-address)) <- ((new)) ((space literal)) ((30 literal))) run: find-next/split/main 0: 1035 => ((default-space space-address)) run: find-next/split/main 1: (((1 string-address)) <- ((next-input))) arg: nil 0 (1000 #\/ 0) run: find-next/split/main 1: 1000 => ((1 string-address)) mem: ((1 string-address)): 1037 <= 1000 run: find-next/split/main 2: (((2 character)) <- ((next-input))) arg: nil 1 (1000 #\/ 0) run: find-next/split/main 2: #\/ => ((2 character)) mem: ((2 character)): 1038 <= #\/ run: find-next/split/main 3: (((3 integer)) <- ((next-input))) arg: nil 2 (1000 #\/ 0) run: find-next/split/main 3: 0 => ((3 integer)) mem: ((3 integer)): 1039 <= 0 run: find-next/split/main 4: (((4 integer)) <- ((length)) ((1 string-address) (deref))) array-len: ((1 string-address) (deref)) mem: ((1000 integer) (raw)) => 3 run: find-next/split/main 4: 3 => ((4 integer)) mem: ((4 integer)): 1040 <= 3 run: find-next/split/main 5: (((5 boolean)) <- ((greater-or-equal)) ((3 integer)) ((4 integer))) mem: ((3 integer)) => 0 mem: ((4 integer)) => 3 run: find-next/split/main 5: nil => ((5 boolean)) mem: ((5 boolean)): 1041 <= nil run: find-next/split/main 6: (((jump-if)) ((5 boolean)) ((5 offset))) mem: ((5 boolean)) => nil run: find-next/split/main 7: (((6 byte)) <- ((index)) ((1 string-address) (deref)) ((3 integer))) mem: ((3 integ
# To check our support for consoles in scenarios, rewrite tests from
# scenario_console.mu
# Tests for console interface.
scenario read-key-in-mu [
assume-console [
type [abc]
]
run [
1:char, 2:bool <- read-key console
3:char, 4:bool <- read-key console
5:char, 6:bool <- read-key console
7:char, 8:bool <- read-key console
]
memory-should-contain [
1 <- 97 # 'a'
2 <- 1
3 <- 98 # 'b'
4 <- 1
5 <- 99 # 'c'
6 <- 1
7 <- 0 # eof
8 <- 1
]
]