From 902997b73dd0a6f3a8ada67f5e8bbfed000f5282 Mon Sep 17 00:00:00 2001 From: "Alex Lam S.L" Date: Fri, 16 Jul 2021 15:13:33 +0100 Subject: [PATCH] fix corner case in `inline` (#5083) fixes #5082 --- lib/compress.js | 8 +++--- test/compress/classes.js | 58 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+), 5 deletions(-) diff --git a/lib/compress.js b/lib/compress.js index 84392f7c5e6..fa684339ed5 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -9522,11 +9522,9 @@ merge(Compressor.prototype, { refs.forEach(function(ref) { ref.scope = exp === fn ? fn.parent_scope : exp.scope; ref.reference(); - if (replacing) { - ref.definition().replaced++; - } else { - ref.definition().single_use = false; - } + var def = ref.definition(); + if (replacing) def.replaced++; + def.single_use = false; }); return node; } else if (!node.has_side_effects(compressor)) { diff --git a/test/compress/classes.js b/test/compress/classes.js index d4047a8a8c8..f604810acbd 100644 --- a/test/compress/classes.js +++ b/test/compress/classes.js @@ -2008,3 +2008,61 @@ issue_5053_4: { expect_stdout: "PASS" node_version: ">=4" } + +issue_5082_1: { + options = { + inline: true, + reduce_vars: true, + unused: true, + } + input: { + (function() { + class A { + p = console.log("PASS"); + q() {} + } + class B { + static P = new A(); + } + })(); + } + expect: { + (function() { + class A { + p = console.log("PASS"); + q() {} + } + new A(); + })(); + } + expect_stdout: "PASS" + node_version: ">=12" +} + +issue_5082_2: { + options = { + inline: true, + passes: 2, + reduce_vars: true, + unused: true, + } + input: { + (function() { + class A { + p = console.log("PASS"); + q() {} + } + class B { + static P = new A(); + } + })(); + } + expect: { + void new class { + p = console.log("PASS"); + q() {} + }(); + } + expect_stdout: "PASS" + node_version: ">=12" +}