close iterators on abrupt completion - google/traceur-compiler#1773 #838

This commit is contained in:
Sebastian McKenzie
2015-02-27 11:44:13 +11:00
parent 5d90c442cb
commit a9db70b60d
20 changed files with 604 additions and 118 deletions

View File

@@ -1,3 +1,21 @@
for (var ITERATOR_KEY = OBJECT[Symbol.iterator](), STEP_KEY; !(STEP_KEY = ITERATOR_KEY.next()).done; ) {
var ITERATOR_COMPLETION = true;
var ITERATOR_HAD_ERROR_KEY = false;
var ITERATOR_ERROR_KEY = undefined;
try {
for (var ITERATOR_KEY = OBJECT[Symbol.iterator](), STEP_KEY; !(ITERATOR_COMPLETION = (STEP_KEY = ITERATOR_KEY.next()).done); ITERATOR_COMPLETION = true) {
}
} catch (err) {
ITERATOR_HAD_ERROR_KEY = true;
ITERATOR_ERROR_KEY = err;
} finally {
try {
if (!ITERATOR_COMPLETION && ITERATOR_KEY.return) {
ITERATOR_KEY.return();
}
} finally {
if (ITERATOR_HAD_ERROR_KEY) {
throw ITERATOR_ERROR_KEY;
}
}
}

View File

@@ -32,7 +32,7 @@ exports.ForOfStatement = function (node, parent, scope, file) {
// todo: find out why this is necessary? #538
loop._scopeInfo = node._scopeInfo;
return loop;
return build.node;
};
var breakVisitor = {
@@ -113,6 +113,7 @@ var loose = function (node, parent, scope, file) {
return {
declar: declar,
node: loop,
loop: loop
};
};
@@ -140,12 +141,18 @@ var spec = function (node, parent, scope, file) {
var iteratorKey = scope.generateUidIdentifier("iterator");
var loop = util.template("for-of", {
ITERATOR_KEY: iteratorKey,
STEP_KEY: stepKey,
OBJECT: node.right
var node = util.template("for-of", {
ITERATOR_HAD_ERROR_KEY: scope.generateUidIdentifier("didIteratorError"),
ITERATOR_COMPLETION: scope.generateUidIdentifier("iteratorNormalCompletion"),
ITERATOR_ERROR_KEY: scope.generateUidIdentifier("iteratorError"),
ITERATOR_KEY: iteratorKey,
STEP_KEY: stepKey,
OBJECT: node.right,
BODY: null
});
var loop = node[3].block.body[0];
//
scope.traverse(node, breakVisitor, {
@@ -160,6 +167,7 @@ var spec = function (node, parent, scope, file) {
return {
declar: declar,
loop: loop
loop: loop,
node: node
};
};