Skip to content

Commit 70d72ad

Browse files
authoredMar 2, 2017
properly cover all cases of for-in loop variables (#1536)
1 parent fe9227a commit 70d72ad

File tree

2 files changed

+22
-7
lines changed

2 files changed

+22
-7
lines changed
 

‎lib/compress.js

+6-6
Original file line numberDiff line numberDiff line change
@@ -243,13 +243,13 @@ merge(Compressor.prototype, {
243243
return true;
244244
}
245245
if (node instanceof AST_ForIn) {
246-
if (node.init instanceof AST_SymbolRef) {
247-
var d = node.init.definition();
248-
d.references.push(node.init);
249-
d.fixed = false;
250-
} else {
251-
node.init.walk(tw);
246+
var sym = node.init;
247+
if (sym instanceof AST_Var) {
248+
sym = sym.definitions[0].name;
252249
}
250+
var d = sym.definition();
251+
d.references.push(sym);
252+
d.fixed = false;
253253
node.object.walk(tw);
254254
push();
255255
node.body.walk(tw);

‎test/compress/reduce_vars.js

+16-1
Original file line numberDiff line numberDiff line change
@@ -563,7 +563,7 @@ inner_var_for: {
563563
}
564564
}
565565

566-
inner_var_for_in: {
566+
inner_var_for_in_1: {
567567
options = {
568568
evaluate: true,
569569
reduce_vars: true,
@@ -590,6 +590,21 @@ inner_var_for_in: {
590590
}
591591
}
592592

593+
inner_var_for_in_2: {
594+
options = {
595+
evaluate: true,
596+
reduce_vars: true,
597+
}
598+
input: {
599+
for (var long_name in {})
600+
console.log(long_name);
601+
}
602+
expect: {
603+
for (var long_name in {})
604+
console.log(long_name);
605+
}
606+
}
607+
593608
issue_1533_1: {
594609
options = {
595610
collapse_vars: true,

0 commit comments

Comments
 (0)
Please sign in to comment.