Skip to content

Commit

Permalink
fix corner case in collapse_vars (#5018)
Browse files Browse the repository at this point in the history
fixes #5017
  • Loading branch information
alexlamsl committed Jun 21, 2021
1 parent e368d39 commit 111366f
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 10 deletions.
7 changes: 3 additions & 4 deletions lib/compress.js
Original file line number Diff line number Diff line change
Expand Up @@ -1820,7 +1820,7 @@ merge(Compressor.prototype, {
if (is_lhs(node, parent)) {
if (value_def && !hit_rhs) {
assign_used = true;
replaced++;
if (node.definition().last_ref === node) replaced++;
}
return node;
} else if (value_def) {
Expand Down Expand Up @@ -1946,10 +1946,9 @@ merge(Compressor.prototype, {
}
}
// Replace variable when found
if (node instanceof AST_SymbolRef
&& node.name == def.name) {
if (!--replaced) abort = true;
if (node instanceof AST_SymbolRef && node.definition() === def) {
if (is_lhs(node, multi_replacer.parent())) return node;
if (!--replaced) abort = true;
var ref = rvalue.clone();
ref.scope = node.scope;
ref.reference();
Expand Down
5 changes: 3 additions & 2 deletions test/compress/collapse_vars.js
Original file line number Diff line number Diff line change
Expand Up @@ -4658,6 +4658,7 @@ replace_all_var_scope: {
rename = true
options = {
collapse_vars: true,
reduce_vars: true,
unused: true,
}
mangle = {}
Expand All @@ -4676,7 +4677,7 @@ replace_all_var_scope: {
(function(c, o) {
switch (~a) {
case (b += a):
case o++:
case +o:
}
})(--b, a);
console.log(a, b);
Expand Down Expand Up @@ -4728,7 +4729,7 @@ cascade_statement: {
}
function f3(a, b) {
for (; a < b; a++)
if (c = a, a && b)
if ((c = a) && b)
var c = c = b(a);
}
}
Expand Down
22 changes: 22 additions & 0 deletions test/compress/destructured.js
Original file line number Diff line number Diff line change
Expand Up @@ -2625,3 +2625,25 @@ issue_4994: {
expect_stdout: "PASS"
node_version: ">=6"
}

issue_5017: {
options = {
collapse_vars: true,
reduce_vars: true,
toplevel: true,
}
input: {
var a = function() {};
var b = c = a;
var c = [ c ] = [ c ];
console.log(c[0] === a ? "PASS" : "FAIL");
}
expect: {
var a = function() {};
var b = a;
var c = [ c ] = [ c = a ];
console.log(c[0] === a ? "PASS" : "FAIL");
}
expect_stdout: "PASS"
node_version: ">=6"
}
9 changes: 5 additions & 4 deletions test/compress/keep_fargs.js
Original file line number Diff line number Diff line change
Expand Up @@ -1151,15 +1151,16 @@ replace_all_var_scope: {
options = {
collapse_vars: true,
keep_fargs: false,
reduce_vars: true,
unused: true,
}
mangle = {}
input: {
var a = 100, b = 10;
(function(r, a) {
switch (~a) {
case (b += a):
case a++:
case (b += a):
case a++:
}
})(--b, a);
console.log(a, b);
Expand All @@ -1168,8 +1169,8 @@ replace_all_var_scope: {
var a = 100, b = 10;
(function(c) {
switch (~a) {
case (b += a):
case c++:
case (b += a):
case +c:
}
})((--b, a));
console.log(a, b);
Expand Down

0 comments on commit 111366f

Please sign in to comment.