From 1b1ed4d290ac15c9116354f0f2b42ebd3a81abaa Mon Sep 17 00:00:00 2001 From: alexlamsl Date: Thu, 1 Aug 2024 01:59:29 +0300 Subject: [PATCH] fix corner case in `collapse_vars` fixes #5899 --- lib/compress.js | 12 ++++++++- test/compress/destructured.js | 48 +++++++++++++++++++++++++++++++++++ 2 files changed, 59 insertions(+), 1 deletion(-) diff --git a/lib/compress.js b/lib/compress.js index ce8e23283e4..5fd29464e2d 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -3285,7 +3285,16 @@ Compressor.prototype.compress = function(node) { if (expr instanceof AST_Assign && expr.right.single_use) return; var lhs_ids = Object.create(null); var marker = new TreeWalker(function(node) { - if (node instanceof AST_SymbolRef) lhs_ids[node.definition().id] = true; + if (!(node instanceof AST_SymbolRef)) return; + for (var level = 0, parent, child = node; parent = marker.parent(level++); child = parent) { + if (is_direct_assignment(child, parent)) { + if (parent instanceof AST_DestructuredKeyVal) parent = marker.parent(level++); + continue; + } + lhs_ids[node.definition().id] = true; + return; + } + lhs_ids[node.definition().id] = "a"; }); while (expr instanceof AST_Assign && expr.operator == "=") { expr.left.walk(marker); @@ -3293,6 +3302,7 @@ Compressor.prototype.compress = function(node) { } if (expr instanceof AST_ObjectIdentity) return rhs_exact_match; if (expr instanceof AST_SymbolRef) { + if (lhs_ids[expr.definition().id] === "a") return; var value = expr.evaluate(compressor); if (value === expr) return rhs_exact_match; return rhs_fuzzy_match(value, rhs_exact_match); diff --git a/test/compress/destructured.js b/test/compress/destructured.js index a283c3ac0ea..83e7392e002 100644 --- a/test/compress/destructured.js +++ b/test/compress/destructured.js @@ -4241,3 +4241,51 @@ issue_5866_12: { expect_stdout: "PASS" node_version: ">=6" } + +issue_5899_1: { + options = { + collapse_vars: true, + } + input: { + var log = console.log, a, b; + a = "foo"; + log(a && a); + b = { p: a } = a; + log(a); + } + expect: { + var log = console.log, a, b; + log((a = "foo") && a); + b = { p: a } = a; + log(a); + } + expect_stdout: [ + "foo", + "undefined", + ] + node_version: ">=6" +} + +issue_5899_2: { + options = { + collapse_vars: true, + } + input: { + var log = console.log, a, b; + a = "foo"; + log(a && a); + b = [ a ] = a; + log(a); + } + expect: { + var log = console.log, a, b; + log((a = "foo") && a); + b = [ a ] = a; + log(a); + } + expect_stdout: [ + "foo", + "f", + ] + node_version: ">=6" +}