diff options
author | Alon Zakai <alonzakai@gmail.com> | 2016-03-22 10:13:08 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2016-03-22 10:13:08 -0700 |
commit | 996416ccefc4f079b14495bcb4ac66e7aa705f4f (patch) | |
tree | d3ecc3db30c81896b1678f5d6fed8bbd6f429d35 /test/unit.asm.js | |
parent | 12a5d972ec7c5144cd54afe7bdee7351219aaca0 (diff) | |
download | binaryen-996416ccefc4f079b14495bcb4ac66e7aa705f4f.tar.gz binaryen-996416ccefc4f079b14495bcb4ac66e7aa705f4f.tar.bz2 binaryen-996416ccefc4f079b14495bcb4ac66e7aa705f4f.zip |
only reuse nameless blocks in blockify in asm2wasm - if they are named, they can be broken out of, which is bad for our loop constructs
Diffstat (limited to 'test/unit.asm.js')
-rw-r--r-- | test/unit.asm.js | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/test/unit.asm.js b/test/unit.asm.js index c600f714d..5bb84bdcd 100644 --- a/test/unit.asm.js +++ b/test/unit.asm.js @@ -55,6 +55,7 @@ function asm() { } function switcher(x) { x = x | 0; + var waka = 0; switch (x | 0) { case 1: return 1; case 2: return 2; @@ -79,6 +80,32 @@ function asm() { break; } } + + L1 : while (1) { + L3 : while (1) switch (x) { + case -1: + { + break L1; + break; + } + case 116: + { + waka = 1; + break; + } + case 110: + { + break L3; + break; + } + default: + { + break L1; + } + } + h(120); + } + return 0; } function blocker() { |