mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Make PaperScript math operator methods 'hidden' and use aliases to visible methods.
Avoids Path#add() being misinterpreted as an operator, and console.log(path + ' hi'); causing weird issues.
This commit is contained in:
parent
5e7209a7bb
commit
5b574877e9
2 changed files with 21 additions and 8 deletions
|
@ -19,7 +19,7 @@
|
||||||
"test"
|
"test"
|
||||||
],
|
],
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"straps": "~1.1.2",
|
"straps": "~1.1.3",
|
||||||
"acorn": "~0.3.1",
|
"acorn": "~0.3.1",
|
||||||
"esprima": "~1.0.3",
|
"esprima": "~1.0.3",
|
||||||
"stats.js": "r11"
|
"stats.js": "r11"
|
||||||
|
|
|
@ -31,20 +31,34 @@ paper.PaperScope.prototype.PaperScript = new function() {
|
||||||
// Operators to overload
|
// Operators to overload
|
||||||
|
|
||||||
var binaryOperators = {
|
var binaryOperators = {
|
||||||
'+': 'add',
|
// The hidden math functions are to be injected specifically, see below.
|
||||||
'-': 'subtract',
|
'+': '_add',
|
||||||
'*': 'multiply',
|
'-': '_subtract',
|
||||||
'/': 'divide',
|
'*': '_multiply',
|
||||||
'%': 'modulo',
|
'/': '_divide',
|
||||||
|
'%': '_modulo',
|
||||||
|
// Use the real equals.
|
||||||
'==': 'equals',
|
'==': 'equals',
|
||||||
'!=': 'equals'
|
'!=': 'equals'
|
||||||
};
|
};
|
||||||
|
|
||||||
var unaryOperators = {
|
var unaryOperators = {
|
||||||
'-': 'negate',
|
'-': '_negate',
|
||||||
'+': null
|
'+': null
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Add hidden math functions to Point, Size and Color
|
||||||
|
var fields = Base.each(
|
||||||
|
'add,subtract,multiply,divide,modulo,negate'.split(','),
|
||||||
|
function(name) {
|
||||||
|
this['_' + name] = '#' + name;
|
||||||
|
},
|
||||||
|
{}
|
||||||
|
);
|
||||||
|
paper.Point.inject(fields);
|
||||||
|
paper.Size.inject(fields);
|
||||||
|
paper.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.
|
||||||
|
@ -80,7 +94,6 @@ paper.PaperScope.prototype.PaperScript = new function() {
|
||||||
|
|
||||||
// AST Helpers
|
// AST Helpers
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Compiles PaperScript code into JavaScript code.
|
* Compiles PaperScript code into JavaScript code.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue