From: Alex Lam S.L Date: Fri, 18 Oct 2019 09:09:43 +0000 (+0800) Subject: fix corner case in `unused` (#3496) X-Git-Url: https://git.ndcode.org/public/gitweb.cgi?a=commitdiff_plain;h=cd072317d08cc0d1a97f8bd295ee1138d608ae84;p=UglifyJS.git fix corner case in `unused` (#3496) fixes #3495 --- 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" +}