mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-20 22:39:50 -05:00
Filter out loop statements in operator overloading code, to optimize loop execution speed.
This commit is contained in:
parent
6ad2105110
commit
cd7604952c
1 changed files with 24 additions and 16 deletions
|
@ -168,7 +168,17 @@ var PaperScript = Base.exports.PaperScript = (function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
switch (node && node.type) {
|
switch (node && node.type) {
|
||||||
|
case 'UnaryExpression':
|
||||||
|
// -a
|
||||||
|
if (node.operator in unaryOperators
|
||||||
|
&& node.argument.type !== 'Literal') {
|
||||||
|
var arg = getCode(node.argument);
|
||||||
|
replaceCode(node, '$_("' + node.operator + '", '
|
||||||
|
+ arg + ')');
|
||||||
|
}
|
||||||
|
break;
|
||||||
case 'BinaryExpression':
|
case 'BinaryExpression':
|
||||||
|
// a + b, a - b, a / b, a * b, a == b, a % b, ...
|
||||||
if (node.operator in binaryOperators
|
if (node.operator in binaryOperators
|
||||||
&& node.left.type !== 'Literal') {
|
&& node.left.type !== 'Literal') {
|
||||||
var left = getCode(node.left),
|
var left = getCode(node.left),
|
||||||
|
@ -177,22 +187,17 @@ var PaperScript = Base.exports.PaperScript = (function() {
|
||||||
+ '", ' + right + ')');
|
+ '", ' + right + ')');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'AssignmentExpression':
|
|
||||||
if (/^.=$/.test(node.operator)
|
|
||||||
&& node.left.type !== 'Literal') {
|
|
||||||
var left = getCode(node.left),
|
|
||||||
right = getCode(node.right);
|
|
||||||
replaceCode(node, left + ' = _$_(' + left + ', "'
|
|
||||||
+ node.operator[0] + '", ' + right + ')');
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 'UpdateExpression':
|
case 'UpdateExpression':
|
||||||
|
// a++, a--
|
||||||
if (!node.prefix && !(parent && (
|
if (!node.prefix && !(parent && (
|
||||||
|
// Filter out for statements to allow loop increments
|
||||||
|
// to perform well
|
||||||
|
parent.type === 'ForStatement'
|
||||||
// We need to filter out parents that are comparison
|
// We need to filter out parents that are comparison
|
||||||
// operators, e.g. for situations like if (++i < 1),
|
// operators, e.g. for situations like if (++i < 1),
|
||||||
// as we can't replace that with if (_$_(i, "+", 1) < 1)
|
// as we can't replace that with if (_$_(i, "+", 1) < 1)
|
||||||
// Match any operator beginning with =, !, < and >.
|
// Match any operator beginning with =, !, < and >.
|
||||||
parent.type === 'BinaryExpression'
|
|| parent.type === 'BinaryExpression'
|
||||||
&& /^[=!<>]/.test(parent.operator)
|
&& /^[=!<>]/.test(parent.operator)
|
||||||
// array[i++] is a MemberExpression with computed = true
|
// array[i++] is a MemberExpression with computed = true
|
||||||
// We can't replace that with array[_$_(i, "+", 1)].
|
// We can't replace that with array[_$_(i, "+", 1)].
|
||||||
|
@ -203,12 +208,15 @@ var PaperScript = Base.exports.PaperScript = (function() {
|
||||||
+ node.operator[0] + '", 1)');
|
+ node.operator[0] + '", 1)');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'UnaryExpression':
|
case 'AssignmentExpression':
|
||||||
if (node.operator in unaryOperators
|
/// a += b, a -= b
|
||||||
&& node.argument.type !== 'Literal') {
|
if (/^.=$/.test(node.operator)
|
||||||
var arg = getCode(node.argument);
|
&& node.left.type !== 'Literal'
|
||||||
replaceCode(node, '$_("' + node.operator + '", '
|
&& !(parent && parent.type === 'ForStatement')) {
|
||||||
+ arg + ')');
|
var left = getCode(node.left),
|
||||||
|
right = getCode(node.right);
|
||||||
|
replaceCode(node, left + ' = _$_(' + left + ', "'
|
||||||
|
+ node.operator[0] + '", ' + right + ')');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue