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