Skip to content

Commit

Permalink
fix corner case in collapse_vars (#3334)
Browse files Browse the repository at this point in the history
fixes #3274
  • Loading branch information
alexlamsl authored Mar 14, 2019
1 parent d074aa6 commit ebd82b3
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 6 deletions.
18 changes: 12 additions & 6 deletions lib/compress.js
Original file line number Diff line number Diff line change
Expand Up @@ -1585,13 +1585,19 @@ merge(Compressor.prototype, {
var found = false;
return statements[stat_index].transform(new TreeTransformer(function(node, descend, in_list) {
if (found) return node;
if (node === expr || node.body === expr) {
if (node !== expr && node.body !== expr) return;
if (node instanceof AST_VarDef) {
found = true;
if (node instanceof AST_VarDef) {
node.value = null;
return node;
}
return in_list ? MAP.skip : null;
node.value = null;
return node;
}
if (in_list) {
found = true;
return MAP.skip;
}
if (!this.parent()) {
found = true;
return null;
}
}, function(node) {
if (node instanceof AST_Sequence) switch (node.expressions.length) {
Expand Down
30 changes: 30 additions & 0 deletions test/compress/functions.js
Original file line number Diff line number Diff line change
Expand Up @@ -2315,3 +2315,33 @@ issue_3125: {
}
expect_stdout: "PASS"
}

issue_3274: {
options = {
collapse_vars: true,
inline: true,
join_vars: true,
loops: true,
reduce_vars: true,
unused: true,
}
input: {
(function() {
var g = function(a) {
var c = a.p, b = c;
return b != c;
};
while (g(1))
console.log("FAIL");
console.log("PASS");
})();
}
expect: {
(function() {
for (var c; void 0, (c = 1..p) != c;)
console.log("FAIL");
console.log("PASS");
})();
}
expect_stdout: "PASS"
}

0 comments on commit ebd82b3

Please sign in to comment.