diff options
author | Alex Lam S.L <alexlamsl@gmail.com> | 2019-05-11 18:55:45 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-05-11 18:55:45 +0800 |
commit | 9fc8cd40763467d8b256be00380965268b7afcfd (patch) | |
tree | a96536e67f89b94a660e20b7bebabed39b0421e8 | |
parent | 5476cb8f05d0e7d402d583ef726e743451555c10 (diff) | |
download | tracifyjs-9fc8cd40763467d8b256be00380965268b7afcfd.tar.gz tracifyjs-9fc8cd40763467d8b256be00380965268b7afcfd.zip |
fix corner case in `functions` (#3403)
fixes #3402
-rw-r--r-- | lib/compress.js | 8 | ||||
-rw-r--r-- | test/compress/assignment.js | 36 | ||||
-rw-r--r-- | test/compress/functions.js | 35 |
3 files changed, 79 insertions, 0 deletions
diff --git a/lib/compress.js b/lib/compress.js index 418b1d54..b63c0512 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -3682,6 +3682,7 @@ merge(Compressor.prototype, { } else if (compressor.option("functions") && def.value === def.name.fixed_value() && def.value instanceof AST_Function + && !(def.value.name && def.value.name.definition().assignments) && can_rename(def.value, def.name.name) && (!compressor.has_directive("use strict") || parent instanceof AST_Scope)) { AST_Node.warn("Declaring {name} as function [{file}:{line},{col}]", template(def.name)); @@ -6301,6 +6302,13 @@ merge(Compressor.prototype, { expression: self.left }); } + if (!compressor.option("ie8") && self.left instanceof AST_Symbol && self.left.is_immutable()) { + return (self.operator == "=" ? self.right : make_node(AST_Binary, self, { + operator: self.operator.slice(0, -1), + left: self.left, + right: self.right + })).optimize(compressor); + } return self; function in_try(level, node) { diff --git a/test/compress/assignment.js b/test/compress/assignment.js index ece0185d..191b892e 100644 --- a/test/compress/assignment.js +++ b/test/compress/assignment.js @@ -311,3 +311,39 @@ issue_3375: { } expect_stdout: "string" } + +issue_3402: { + options = { + assignments: true, + evaluate: true, + functions: true, + passes: 2, + reduce_vars: true, + side_effects: true, + toplevel: true, + typeofs: true, + unused: true, + } + input: { + var f = function f() { + f = 42; + console.log(typeof f); + }; + "function" == typeof f && f(); + "function" == typeof f && f(); + console.log(typeof f); + } + expect: { + function f() { + console.log(typeof f); + } + f(); + f(); + console.log(typeof f); + } + expect_stdout: [ + "function", + "function", + "function", + ] +} diff --git a/test/compress/functions.js b/test/compress/functions.js index 21146457..82295383 100644 --- a/test/compress/functions.js +++ b/test/compress/functions.js @@ -3113,3 +3113,38 @@ issue_3400: { "42", ] } + +issue_3402: { + options = { + evaluate: true, + functions: true, + reduce_vars: true, + side_effects: true, + toplevel: true, + typeofs: true, + unused: true, + } + input: { + var f = function f() { + f = 42; + console.log(typeof f); + }; + "function" == typeof f && f(); + "function" == typeof f && f(); + console.log(typeof f); + } + expect: { + var f = function f() { + f = 42; + console.log(typeof f); + }; + f(); + f(); + console.log(typeof f); + } + expect_stdout: [ + "function", + "function", + "function", + ] +} |