diff options
author | Alex Lam S.L <alexlamsl@gmail.com> | 2020-09-26 08:31:33 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-26 15:31:33 +0800 |
commit | b4ff6d0f2da3f094cf1bb4897a2dc67ad4f3efa5 (patch) | |
tree | a4ac8b3aed1a702275516c41e93aae1fb5969e8b | |
parent | 9882a9f4af95af4b0cba0a4a60a695ba2f6de04d (diff) | |
download | tracifyjs-b4ff6d0f2da3f094cf1bb4897a2dc67ad4f3efa5.tar.gz tracifyjs-b4ff6d0f2da3f094cf1bb4897a2dc67ad4f3efa5.zip |
fix corner cases in `functions` & `merge_vars` (#4156)
fixes #4155
-rw-r--r-- | lib/compress.js | 8 | ||||
-rw-r--r-- | test/compress/functions.js | 31 | ||||
-rw-r--r-- | test/compress/merge_vars.js | 38 |
3 files changed, 75 insertions, 2 deletions
diff --git a/lib/compress.js b/lib/compress.js index 3f7eee68..25a993f6 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -4449,7 +4449,9 @@ merge(Compressor.prototype, { segment.block = node; walk_body(node, tw); if (node.bcatch) { - references[node.bcatch.argname.definition().id] = false; + var def = node.bcatch.argname.definition(); + references[def.id] = false; + if (def = def.redefined()) references[def.id] = false; pop(); push(); walk_body(node.bcatch, tw); @@ -4843,8 +4845,10 @@ merge(Compressor.prototype, { && !compressor.option("ie8") && var_defs.length == 1 && sym.assignments == 0 - && def.value === def.name.fixed_value() && def.value instanceof AST_Function + && (sym.references.length ? all(sym.references, function(ref) { + return def.value === ref.fixed_value(); + }) : def.value === def.name.fixed_value()) && (!def.value.name || (old_def = def.value.name.definition()).assignments == 0 && (old_def.name == def.name.name || all(old_def.references, function(ref) { return ref.scope.find_variable(def.name) === def.name.definition(); diff --git a/test/compress/functions.js b/test/compress/functions.js index 3027d59e..1be01167 100644 --- a/test/compress/functions.js +++ b/test/compress/functions.js @@ -4777,3 +4777,34 @@ issue_4006: { } expect_stdout: "-1" } + +issue_4155: { + options = { + functions: true, + inline: true, + merge_vars: true, + reduce_vars: true, + unused: true, + } + input: { + (function() { + var a; + (function() { + console.log(a); + })(a); + var b = function() {}; + b && console.log(typeof b); + })(); + } + expect: { + (function() { + void console.log(b); + var b = function() {}; + b && console.log(typeof b); + })(); + } + expect_stdout: [ + "undefined", + "function", + ] +} diff --git a/test/compress/merge_vars.js b/test/compress/merge_vars.js index b86b0e99..7eb3f13c 100644 --- a/test/compress/merge_vars.js +++ b/test/compress/merge_vars.js @@ -2822,3 +2822,41 @@ conditional_write: { } expect_stdout: "PASS,42" } + +issue_4155: { + options = { + inline: true, + merge_vars: true, + } + input: { + (function() { + try { + throw "PASS"; + } catch (e) { + var a; + (function() { + console.log(e, a); + })(a = NaN); + } + var e = function() {}; + e && console.log(typeof e); + })(); + } + expect: { + (function() { + try { + throw "PASS"; + } catch (e) { + var a; + a = NaN, + void console.log(e, a); + } + var e = function() {}; + e && console.log(typeof e); + })(); + } + expect_stdout: [ + "PASS NaN", + "function", + ] +} |