dry up array comprehension for single block

This commit is contained in:
Sebastian McKenzie
2014-09-29 16:27:35 +10:00
parent 74a661bf44
commit 908beea515
12 changed files with 75 additions and 34 deletions

View File

@@ -1,3 +1,3 @@
OBJECT.forEach(function (KEY) {
ARRAY.forEach(function (KEY) {
});

View File

@@ -0,0 +1,5 @@
ARRAY.filter(function (KEY) {
return FILTER;
}).map(function (KEY) {
return STATEMENT;
});

View File

@@ -0,0 +1,3 @@
ARRAY.map(function (KEY) {
return STATEMENT;
});

View File

@@ -1,6 +1,29 @@
var util = require("../util");
var _ = require("lodash");
exports.ComprehensionExpression = function (node, parent, opts, generateUid) {
var blocks = node.blocks;
_.each(blocks, function (block) {
if (!block.of) {
throw util.errorWithNode(block, "for-in array comprehension is not supported");
}
});
if (blocks.length === 1) {
var block = blocks[0];
var templateName = "array-comprehension-map";
if (node.filter) templateName += "-filter";
return util.template(templateName, {
ARRAY: block.right,
KEY: block.left,
FILTER: node.filter,
STATEMENT: node.body
});
}
var uid = generateUid("arr");
var container = util.template("array-comprehension-container", {
@@ -13,13 +36,9 @@ exports.ComprehensionExpression = function (node, parent, opts, generateUid) {
var returnStatement = body.pop();
var build = function () {
var self = node.blocks.shift();
var self = blocks.shift();
if (!self) return;
if (!self.of) {
throw util.errorWithNode(self, "for-in array comprehension is not supported");
}
var child = build();
if (!child) {
// last item
@@ -29,6 +48,7 @@ exports.ComprehensionExpression = function (node, parent, opts, generateUid) {
STATEMENT: node.body
}, true);
// add a filter as this is our final stop
if (node.filter) {
var filter = util.template("if", {
STATEMENT: node.filter
@@ -39,12 +59,10 @@ exports.ComprehensionExpression = function (node, parent, opts, generateUid) {
}
var container2 = util.template("array-comprehension-for-each", {
OBJECT: self.right,
KEY: self.left,
ARRAY: self.right,
KEY: self.left
}, true);
container2.expression.arguments[0].body.body = [child];
return container2;
};

View File

@@ -37,7 +37,7 @@ exports.parse = function (code, opts) {
};
exports.errorWithNode = function (node, msg) {
var err = new Error(msg);
var err = new SyntaxError(msg);
err.lineNumber = node.loc.start.line;
err.column = node.loc.start.column;
return err;