diff options
author | Alex Lam S.L <alexlamsl@gmail.com> | 2018-03-06 00:45:58 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-03-06 00:45:58 +0800 |
commit | fe51a91395f3b0a6ab812f3f42746d39efd9e80c (patch) | |
tree | d8b2c380890eeb04d9acb1dbb5ffce863e701c7d | |
parent | 951d87ca9471b2cbbd6b96200484beb421d1a335 (diff) | |
download | tracifyjs-fe51a91395f3b0a6ab812f3f42746d39efd9e80c.tar.gz tracifyjs-fe51a91395f3b0a6ab812f3f42746d39efd9e80c.zip |
handle negated constants correctly in `collapse_vars` (#2975)
fixes #2974
-rw-r--r-- | lib/compress.js | 3 | ||||
-rw-r--r-- | test/compress/collapse_vars.js | 36 |
2 files changed, 37 insertions, 2 deletions
diff --git a/lib/compress.js b/lib/compress.js index a63a5c66..2f109a17 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -778,8 +778,7 @@ merge(Compressor.prototype, { lhs = lhs.fixed_value(); } if (!lhs) return true; - if (lhs instanceof AST_RegExp) return false; - if (lhs instanceof AST_Constant) return true; + if (lhs.is_constant()) return true; return is_lhs_read_only(lhs); } return false; diff --git a/test/compress/collapse_vars.js b/test/compress/collapse_vars.js index 97efc21b..8b0f033a 100644 --- a/test/compress/collapse_vars.js +++ b/test/compress/collapse_vars.js @@ -5207,3 +5207,39 @@ collapse_rhs_undefined: { } expect_stdout: "true true true" } + +issue_2974: { + options = { + booleans: true, + collapse_vars: true, + evaluate: true, + loops: true, + passes: 2, + pure_getters: "strict", + reduce_vars: true, + sequences: true, + side_effects: true, + unused: true, + } + input: { + var c = 0; + (function f(b) { + var a = 2; + do { + b && b[b]; + b && (b.null = -4); + c++; + } while (b.null && --a > 0); + })(true); + console.log(c); + } + expect: { + var c = 0; + (function(b) { + var a = 2; + for (; b.null = -4, c++, b.null && --a > 0;); + })(!0), + console.log(c); + } + expect_stdout: "1" +} |