From cd072317d08cc0d1a97f8bd295ee1138d608ae84 Mon Sep 17 00:00:00 2001 From: "Alex Lam S.L" Date: Fri, 18 Oct 2019 17:09:43 +0800 Subject: fix corner case in `unused` (#3496) fixes #3495 --- lib/compress.js | 6 +++++- test/compress/drop-unused.js | 19 +++++++++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/lib/compress.js b/lib/compress.js index 4b0ceee4..33b62daa 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -3629,6 +3629,7 @@ merge(Compressor.prototype, { return !(def.id in in_use_ids) || def.orig.length > 1; }; // pass 3: we should drop declarations not in_use + var unused_fn_names = []; var tt = new TreeTransformer(function(node, descend, in_list) { var parent = tt.parent(); if (drop_vars) { @@ -3656,7 +3657,7 @@ merge(Compressor.prototype, { } if (scope !== self) return; if (node instanceof AST_Function && node.name && drop_fn_name(node.name.definition())) { - node.name = null; + unused_fn_names.push(node); } if (node instanceof AST_Lambda && !(node instanceof AST_Accessor)) { var trim = compressor.drop_fargs(node, parent); @@ -3853,6 +3854,9 @@ merge(Compressor.prototype, { }); tt.push(compressor.parent()); self.transform(tt); + unused_fn_names.forEach(function(fn) { + fn.name = null; + }); function verify_safe_usage(def, read, modified) { if (def.id in in_use_ids) return; diff --git a/test/compress/drop-unused.js b/test/compress/drop-unused.js index 6ed193e9..ea7ee02f 100644 --- a/test/compress/drop-unused.js +++ b/test/compress/drop-unused.js @@ -2062,3 +2062,22 @@ issue_3427_2: { } expect_stdout: "PASS" } + +issue_3495: { + options = { + dead_code: true, + pure_getters: "strict", + side_effects: true, + unused: true, + } + input: { + console.log(function f() { + f = 0; + var a = f.p; + }()); + } + expect: { + console.log(void 0); + } + expect_stdout: "undefined" +} -- cgit v1.2.3