aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/compress.js9
-rw-r--r--test/compress/evaluate.js23
2 files changed, 31 insertions, 1 deletions
diff --git a/lib/compress.js b/lib/compress.js
index d99310ed..7c1c3b42 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -595,7 +595,14 @@ merge(Compressor.prototype, {
var expr = node.expression;
if (!(expr instanceof AST_SymbolRef)) return;
var def = expr.definition();
- if (is_arguments(def) && node.property instanceof AST_Number) def.reassigned = true;
+ if (!is_arguments(def)) return;
+ var key = node.property;
+ if (key.is_constant()) key = key.value;
+ if (!(key instanceof AST_Node) && !/^[1-9]*[0-9]$/.test(key)) return;
+ def.reassigned = true;
+ (key instanceof AST_Node ? def.scope.argnames : [ def.scope.argnames[key] ]).forEach(function(argname) {
+ if (argname instanceof AST_SymbolFunarg) argname.definition().fixed = false;
+ });
}
function scan_declaration(tw, lhs, fixed, visit) {
diff --git a/test/compress/evaluate.js b/test/compress/evaluate.js
index 8ef1a466..7466d63b 100644
--- a/test/compress/evaluate.js
+++ b/test/compress/evaluate.js
@@ -3094,3 +3094,26 @@ issue_4393: {
}
expect_stdout: "PASS"
}
+
+issue_4422: {
+ options = {
+ evaluate: true,
+ reduce_vars: true,
+ unused: true,
+ }
+ input: {
+ console.log(function f(a) {
+ a = "FAIL 1";
+ arguments[0] = "PASS";
+ return a;
+ }("FAIL 2"));
+ }
+ expect: {
+ console.log(function(a) {
+ a = "FAIL 1";
+ arguments[0] = "PASS";
+ return a;
+ }("FAIL 2"));
+ }
+ expect_stdout: "PASS"
+}