Fix shadow variables reassignment for block scoping in loops. (#6814)
This commit is contained in:
parent
84fe8e4181
commit
056a995dd8
@ -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)),
|
||||||
|
|||||||
@ -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));
|
||||||
@ -0,0 +1,7 @@
|
|||||||
|
for (let index = 0; index < 10; index++) {
|
||||||
|
if (index % 2) {
|
||||||
|
index+=3;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
let fn = function () {index;};
|
||||||
|
}
|
||||||
@ -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;
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user