mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 06:00:56 -05:00
Remove breakpoint support again in PaperScript as this code is better placed in sketch.
This commit is contained in:
parent
5e6d0377f4
commit
e96ec6a2f1
1 changed files with 5 additions and 48 deletions
|
@ -119,6 +119,7 @@ Base.exports.PaperScript = (function() {
|
||||||
*/
|
*/
|
||||||
function compile(code, url, options) {
|
function compile(code, url, options) {
|
||||||
options = options || {};
|
options = options || {};
|
||||||
|
url = url || '';
|
||||||
// Use Acorn or Esprima to translate the code into an AST structure
|
// Use Acorn or Esprima to translate the code into an AST structure
|
||||||
// which is then walked and parsed for operators to overload. Instead of
|
// which is then walked and parsed for operators to overload. Instead of
|
||||||
// modifying the AST and translating it back to code, we directly change
|
// modifying the AST and translating it back to code, we directly change
|
||||||
|
@ -166,21 +167,10 @@ Base.exports.PaperScript = (function() {
|
||||||
code = code.substring(0, start) + str + code.substring(end);
|
code = code.substring(0, start) + str + code.substring(end);
|
||||||
}
|
}
|
||||||
|
|
||||||
var breakpoints = (options.breakpoints || []).slice();
|
|
||||||
|
|
||||||
// Recursively walks the AST and replaces the code of certain nodes
|
// Recursively walks the AST and replaces the code of certain nodes
|
||||||
function walkAST(node, parent) {
|
function walkAST(node, parent) {
|
||||||
if (!node)
|
if (!node)
|
||||||
return;
|
return;
|
||||||
var type = node.type,
|
|
||||||
loc = node.loc;
|
|
||||||
// if (node.range) {
|
|
||||||
// var part = getCode(node);
|
|
||||||
// if (part && part.length > 20)
|
|
||||||
// part = part.substr(0, 10) + '...' + part.substr(-10);
|
|
||||||
// console.log(type, part);
|
|
||||||
// }
|
|
||||||
|
|
||||||
// The easiest way to walk through the whole AST is to simply loop
|
// The easiest way to walk through the whole AST is to simply loop
|
||||||
// over each property of the node and filter out fields we don't
|
// over each property of the node and filter out fields we don't
|
||||||
// need to consider...
|
// need to consider...
|
||||||
|
@ -197,25 +187,7 @@ Base.exports.PaperScript = (function() {
|
||||||
walkAST(value, node);
|
walkAST(value, node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// See if a breakpoint is to be placed in the range of this
|
switch (node.type) {
|
||||||
// node, and if the node type supports it.
|
|
||||||
if (breakpoints.length > 0 && loc
|
|
||||||
// Filter the type of nodes that support setting breakpoints.
|
|
||||||
&& /^(ForStatement|VariableDeclaration|ExpressionStatement|ReturnStatement)$/.test(type)
|
|
||||||
// Filter out variable definitions inside ForStatement.
|
|
||||||
&& parent.type !== 'ForStatement') {
|
|
||||||
var start = loc.start.line - 1,
|
|
||||||
end = loc.end.line - 1;
|
|
||||||
for (var i = 0, l = breakpoints.length; i < l; i++) {
|
|
||||||
var line = breakpoints[i];
|
|
||||||
if (line >= start && line <= end) {
|
|
||||||
replaceCode(node, 'debugger; ' + getCode(node));
|
|
||||||
breakpoints.splice(i, 1);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
switch (type) {
|
|
||||||
case 'UnaryExpression': // -a
|
case 'UnaryExpression': // -a
|
||||||
if (node.operator in unaryOperators
|
if (node.operator in unaryOperators
|
||||||
&& node.argument.type !== 'Literal') {
|
&& node.argument.type !== 'Literal') {
|
||||||
|
@ -249,7 +221,7 @@ Base.exports.PaperScript = (function() {
|
||||||
// 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 (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 + ', "'
|
||||||
|
@ -321,20 +293,6 @@ Base.exports.PaperScript = (function() {
|
||||||
walkAST(scope.esprima.parse(code, { range: true, loc: true }));
|
walkAST(scope.esprima.parse(code, { range: true, loc: true }));
|
||||||
/*#*/ }
|
/*#*/ }
|
||||||
|
|
||||||
if (breakpoints.length > 0) {
|
|
||||||
// Process the breakpoints left which were not set on statements
|
|
||||||
// represented by the AST, e.g. on empty lines.
|
|
||||||
var lines = code.split(lineBreaks);
|
|
||||||
for (var i = 0; i < breakpoints.length; i++) {
|
|
||||||
var line = breakpoints[i],
|
|
||||||
str = lines[line];
|
|
||||||
// Make sure we're not adding it twice to the same line.
|
|
||||||
if (!/\bdebugger;\b/.test(str))
|
|
||||||
lines[line] = 'debugger; ' + str;
|
|
||||||
}
|
|
||||||
code = lines.join('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
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.
|
||||||
|
@ -342,7 +300,7 @@ Base.exports.PaperScript = (function() {
|
||||||
+ "\n//# sourceMappingURL=data:application/json;base64,"
|
+ "\n//# sourceMappingURL=data:application/json;base64,"
|
||||||
+ (btoa(unescape(encodeURIComponent(
|
+ (btoa(unescape(encodeURIComponent(
|
||||||
JSON.stringify(sourceMap)))))
|
JSON.stringify(sourceMap)))))
|
||||||
+ "\n//# sourceURL=" + url;
|
+ "\n//# sourceURL=" + (url || 'paperscript');
|
||||||
}
|
}
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
@ -511,8 +469,7 @@ Base.exports.PaperScript = (function() {
|
||||||
return {
|
return {
|
||||||
compile: compile,
|
compile: compile,
|
||||||
execute: execute,
|
execute: execute,
|
||||||
load: load,
|
load: load
|
||||||
lineNumberBase: 0
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*#*/ } else { // !__options.environment == 'browser'
|
/*#*/ } else { // !__options.environment == 'browser'
|
||||||
|
|
Loading…
Reference in a new issue