mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Use names less likely to be used in code for Operator Overloading handlers.
This commit is contained in:
parent
12254f5fe8
commit
6e6df750f0
1 changed files with 16 additions and 14 deletions
|
@ -71,12 +71,12 @@ Base.exports.PaperScript = (function() {
|
||||||
Size.inject(fields);
|
Size.inject(fields);
|
||||||
Color.inject(fields);
|
Color.inject(fields);
|
||||||
|
|
||||||
// Use very short name for the binary operator (_$_) as well as the
|
// Use very short name for the binary operator (__$__) as well as the
|
||||||
// unary operator ($_), as operations will be replaced with then.
|
// unary operator ($__), as operations will be replaced with then.
|
||||||
// The underscores stands for the values, and the $ for the operators.
|
// The underscores stands for the values, and the $ for the operators.
|
||||||
|
|
||||||
// Binary Operator Handler
|
// Binary Operator Handler
|
||||||
function _$_(left, operator, right) {
|
function __$__(left, operator, right) {
|
||||||
var handler = binaryOperators[operator];
|
var handler = binaryOperators[operator];
|
||||||
if (left && left[handler]) {
|
if (left && left[handler]) {
|
||||||
var res = left[handler](right);
|
var res = left[handler](right);
|
||||||
|
@ -94,7 +94,7 @@ Base.exports.PaperScript = (function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unary Operator Handler
|
// Unary Operator Handler
|
||||||
function $_(operator, value) {
|
function $__(operator, value) {
|
||||||
var handler = unaryOperators[operator];
|
var handler = unaryOperators[operator];
|
||||||
if (handler && value && value[handler])
|
if (handler && value && value[handler])
|
||||||
return value[handler]();
|
return value[handler]();
|
||||||
|
@ -196,7 +196,7 @@ Base.exports.PaperScript = (function() {
|
||||||
if (node.operator in unaryOperators
|
if (node.operator in unaryOperators
|
||||||
&& node.argument.type !== 'Literal') {
|
&& node.argument.type !== 'Literal') {
|
||||||
var arg = getCode(node.argument);
|
var arg = getCode(node.argument);
|
||||||
replaceCode(node, '$_("' + node.operator + '", '
|
replaceCode(node, '$__("' + node.operator + '", '
|
||||||
+ arg + ')');
|
+ arg + ')');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -205,7 +205,7 @@ Base.exports.PaperScript = (function() {
|
||||||
&& node.left.type !== 'Literal') {
|
&& node.left.type !== 'Literal') {
|
||||||
var left = getCode(node.left),
|
var left = getCode(node.left),
|
||||||
right = getCode(node.right);
|
right = getCode(node.right);
|
||||||
replaceCode(node, '_$_(' + left + ', "' + node.operator
|
replaceCode(node, '__$__(' + left + ', "' + node.operator
|
||||||
+ '", ' + right + ')');
|
+ '", ' + right + ')');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -216,19 +216,20 @@ Base.exports.PaperScript = (function() {
|
||||||
// to perform well
|
// to perform well
|
||||||
parent.type === 'ForStatement'
|
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)].
|
||||||
|| parent.type === 'MemberExpression'
|
|| parent.type === 'MemberExpression'
|
||||||
&& parent.computed))) {
|
&& parent.computed))) {
|
||||||
if (node.type === 'UpdateExpression') {
|
if (node.type === 'UpdateExpression') {
|
||||||
if (!node.prefix) {
|
if (!node.prefix) {
|
||||||
var arg = getCode(node.argument);
|
var arg = getCode(node.argument);
|
||||||
replaceCode(node, arg + ' = _$_(' + arg + ', "'
|
replaceCode(node, arg + ' = __$__(' + arg + ', "'
|
||||||
+ node.operator[0] + '", 1)');
|
+ node.operator[0] + '", 1)');
|
||||||
}
|
}
|
||||||
} else { // AssignmentExpression
|
} else { // AssignmentExpression
|
||||||
|
@ -236,7 +237,7 @@ Base.exports.PaperScript = (function() {
|
||||||
&& node.left.type !== 'Literal') {
|
&& node.left.type !== 'Literal') {
|
||||||
var left = getCode(node.left),
|
var left = getCode(node.left),
|
||||||
right = getCode(node.right);
|
right = getCode(node.right);
|
||||||
replaceCode(node, left + ' = _$_(' + left + ', "'
|
replaceCode(node, left + ' = __$__(' + left + ', "'
|
||||||
+ node.operator[0] + '", ' + right + ')');
|
+ node.operator[0] + '", ' + right + ')');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -294,7 +295,7 @@ Base.exports.PaperScript = (function() {
|
||||||
}
|
}
|
||||||
// Now do the parsing magic
|
// Now do the parsing magic
|
||||||
walkAST(parse(code, { ranges: true }));
|
walkAST(parse(code, { ranges: true }));
|
||||||
|
console.log(code);
|
||||||
if (sourceMap) {
|
if (sourceMap) {
|
||||||
// Adjust the line offset of the resulting code if required.
|
// Adjust the line offset of the resulting code if required.
|
||||||
// This is part of a browser hack, see above.
|
// This is part of a browser hack, see above.
|
||||||
|
@ -352,7 +353,7 @@ Base.exports.PaperScript = (function() {
|
||||||
// these too as pseudo-globals, but only if they seem to be in use.
|
// these too as pseudo-globals, but only if they seem to be in use.
|
||||||
for (var key in scope) {
|
for (var key in scope) {
|
||||||
// Next to \b well also need to match \s and \W in the beginning
|
// Next to \b well also need to match \s and \W in the beginning
|
||||||
// of $_, since $ is not part of \w.
|
// of $__, since $ is not part of \w.
|
||||||
if ((hidden || !/^_/.test(key)) && new RegExp('[\\b\\s\\W]'
|
if ((hidden || !/^_/.test(key)) && new RegExp('[\\b\\s\\W]'
|
||||||
+ key.replace(/\$/g, '\\$') + '\\b').test(code)) {
|
+ key.replace(/\$/g, '\\$') + '\\b').test(code)) {
|
||||||
params.push(key);
|
params.push(key);
|
||||||
|
@ -360,7 +361,8 @@ Base.exports.PaperScript = (function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
expose({ _$_: _$_, $_: $_, paper: scope, view: view, tool: tool }, true);
|
expose({ __$__: __$__, $__: $__, paper: scope, view: view, tool: tool },
|
||||||
|
true);
|
||||||
expose(scope);
|
expose(scope);
|
||||||
// Finally define the handler variable names as parameters and compose
|
// Finally define the handler variable names as parameters and compose
|
||||||
// the string describing the properties for the returned object at the
|
// the string describing the properties for the returned object at the
|
||||||
|
|
Loading…
Reference in a new issue