diff options
author | Alon Zakai <alonzakai@gmail.com> | 2013-03-01 19:49:48 -0500 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2013-03-01 19:49:48 -0500 |
commit | 37106eebf48382d77ac886ea897ca196db22f6f5 (patch) | |
tree | 588ebcd0be3ffee61c70a39808ca9f3bbb2bce2c /src | |
parent | dbac2b2beee684a56642608f8e93f9eabf765bcf (diff) |
do not emit code in a label after a returnfail
Diffstat (limited to 'src')
-rw-r--r-- | src/analyzer.js | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/analyzer.js b/src/analyzer.js index c930231f..f9b0c5af 100644 --- a/src/analyzer.js +++ b/src/analyzer.js @@ -18,6 +18,7 @@ function recomputeLines(func) { // Handy sets var BRANCH_INVOKE = set('branch', 'invoke'); +var LABEL_ENDERS = set('branch', 'return'); var SIDE_EFFECT_CAUSERS = set('call', 'invoke', 'atomic'); var UNUNFOLDABLE = set('value', 'structvalue', 'type', 'phiparam'); @@ -88,7 +89,7 @@ function analyzer(data, sidePass) { // Internal line if (!currLabelFinished) { item.functions.slice(-1)[0].labels.slice(-1)[0].lines.push(subItem); // If this line fails, perhaps missing a label? - if (subItem.intertype === 'branch') { + if (subItem.intertype in LABEL_ENDERS) { currLabelFinished = true; } } else { |