fix corner case in `unused` (#4405)
authorAlex Lam S.L <alexlamsl@gmail.com>
Fri, 18 Dec 2020 15:45:41 +0000 (15:45 +0000)
committerGitHub <noreply@github.com>
Fri, 18 Dec 2020 15:45:41 +0000 (23:45 +0800)
fixes #4404

lib/compress.js
test/compress/drop-unused.js

index a3842be..1249e62 100644 (file)
@@ -5860,7 +5860,15 @@ merge(Compressor.prototype, {
                 if (def.scope === self) assignments.add(def.id, node);
             }
             var node_def, props = [], sym = assign_as_unused(node, props);
-            if (sym && self.variables.get(sym.name) === (node_def = sym.definition())) {
+            if (sym && self.variables.get(sym.name) === (node_def = sym.definition())
+                && !(is_arguments(node_def) && !all(self.argnames, function(argname) {
+                    return !argname.match_symbol(function(node) {
+                        if (node instanceof AST_SymbolFunarg) {
+                            var def = node.definition();
+                            return def.references.length > def.replaced;
+                        }
+                    }, true);
+                }))) {
                 props.forEach(function(prop) {
                     prop.walk(tw);
                 });
index 4448bdd..1c9ab61 100644 (file)
@@ -3112,3 +3112,25 @@ issue_4235: {
     }
     expect_stdout: "undefined"
 }
+
+issue_4404: {
+    options = {
+        pure_getters: "strict",
+        unused: true,
+    }
+    input: {
+        function f(a) {
+            arguments[0] = "PASS";
+            console.log(a);
+        }
+        f("FAIL");
+    }
+    expect: {
+        function f(a) {
+            arguments[0] = "PASS";
+            console.log(a);
+        }
+        f("FAIL");
+    }
+    expect_stdout: "PASS"
+}