From: Alex Lam S.L Date: Sun, 20 Dec 2020 14:54:27 +0000 (+0000) Subject: fix corner case in `collapse_vars` (#4431) X-Git-Url: https://git.ndcode.org/public/gitweb.cgi?a=commitdiff_plain;h=47b63ed1a09caf5e15a51276adad83a94c89abac;p=UglifyJS.git fix corner case in `collapse_vars` (#4431) fixes #4430 --- diff --git a/lib/compress.js b/lib/compress.js index 7c1c3b42..d532300c 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -1743,7 +1743,11 @@ merge(Compressor.prototype, { if (node instanceof AST_LoopControl) return true; if (node instanceof AST_SymbolRef) { if (node.is_declared(compressor)) { - if (node.fixed_value() || can_drop_symbol(node)) return false; + if (node.fixed_value()) return false; + if (can_drop_symbol(node)) { + return !(parent instanceof AST_PropAccess && parent.expression === node) + && is_arguments(node.definition()); + } } else if (parent instanceof AST_Assign && parent.operator == "=" && parent.left === node) { return false; } @@ -1812,7 +1816,9 @@ merge(Compressor.prototype, { return compressor.option("ie8") && node.name && lvalues.has(node.name.name); } if (node instanceof AST_PropAccess) { - return side_effects || !value_def && node.expression.may_throw_on_access(compressor); + var exp = node.expression; + return side_effects || !value_def && exp.may_throw_on_access(compressor) + || exp instanceof AST_SymbolRef && is_arguments(exp.definition()); } if (node instanceof AST_Spread) return true; if (node instanceof AST_SymbolRef) { diff --git a/test/compress/collapse_vars.js b/test/compress/collapse_vars.js index edf4795a..17ee8d10 100644 --- a/test/compress/collapse_vars.js +++ b/test/compress/collapse_vars.js @@ -8602,3 +8602,63 @@ issue_4248: { } expect_stdout: "1" } + +issue_4430_1: { + options = { + collapse_vars: true, + pure_getters: "strict", + } + input: { + function f(a) { + switch (a = 1, arguments[0]) { + case 1: + return "PASS"; + case 2: + return "FAIL"; + } + } + console.log(f(2)); + } + expect: { + function f(a) { + switch (a = 1, arguments[0]) { + case 1: + return "PASS"; + case 2: + return "FAIL"; + } + } + console.log(f(2)); + } + expect_stdout: "PASS" +} + +issue_4430_2: { + options = { + collapse_vars: true, + pure_getters: "strict", + } + input: { + function f(a) { + switch (a = 0, arguments[0]) { + case 0: + return "PASS"; + case 1: + return "FAIL"; + } + } + console.log(f(1)); + } + expect: { + function f(a) { + switch (arguments[a = 0]) { + case 0: + return "PASS"; + case 1: + return "FAIL"; + } + } + console.log(f(1)); + } + expect_stdout: "PASS" +}