Fix shadow variables reassignment for block scoping in loops. (#6814)

This commit is contained in:
Artem Yavorsky 2017-11-14 01:06:32 +02:00 committed by Mateusz Burzyński
parent 84fe8e4181
commit 056a995dd8
4 changed files with 48 additions and 0 deletions

View File

@ -247,6 +247,8 @@ const continuationVisitor = {
}
state.reassignments[name] = true;
}
} else if (path.isReturnStatement()) {
state.returnStatements.push(path);
}
},
};
@ -585,6 +587,7 @@ class BlockScoping {
addContinuations(fn) {
const state = {
reassignments: {},
returnStatements: [],
outsideReferences: this.outsideLetReferences,
};
@ -599,6 +602,12 @@ class BlockScoping {
this.scope.rename(param.name, newParam.name, fn);
state.returnStatements.forEach(returnStatement => {
returnStatement.insertBefore(
t.expressionStatement(t.assignmentExpression("=", param, newParam)),
);
});
// assign outer reference as it's been modified internally and needs to be retained
fn.body.body.push(
t.expressionStatement(t.assignmentExpression("=", param, newParam)),

View File

@ -0,0 +1,13 @@
let data = [true, false, false, true, false];
for (let index = 0; index < data.length; index++) {
let item = data[index];
if (!item) {
data.splice(index, 1);
index--;
continue;
}
let fn = function () {item;};
}
assert(data.every(item => item));

View File

@ -0,0 +1,7 @@
for (let index = 0; index < 10; index++) {
if (index % 2) {
index+=3;
continue;
}
let fn = function () {index;};
}

View File

@ -0,0 +1,19 @@
var _loop = function (_index) {
if (_index % 2) {
_index += 3;
index = _index;
return "continue";
}
var fn = function () {
_index;
};
index = _index;
};
for (var index = 0; index < 10; index++) {
var _ret = _loop(index);
if (_ret === "continue") continue;
}