Merge remote-tracking branch 'refs/remotes/LLK/develop' into bug/WhiteSpaceEqualsZero

This commit is contained in:
griffpatch 2017-02-10 08:02:43 +00:00
commit 246ff28363
7 changed files with 59 additions and 25 deletions

View file

@ -45,6 +45,6 @@
"tap": "10.1.0", "tap": "10.1.0",
"travis-after-all": "1.4.4", "travis-after-all": "1.4.4",
"webpack": "2.2.1", "webpack": "2.2.1",
"webpack-dev-server": "1.16.3" "webpack-dev-server": "2.3.0"
} }
} }

View file

@ -110,7 +110,7 @@ Scratch3ControlBlocks.prototype.stop = function (args, util) {
option === 'other scripts in stage') { option === 'other scripts in stage') {
util.stopOtherTargetThreads(); util.stopOtherTargetThreads();
} else if (option === 'this script') { } else if (option === 'this script') {
util.stopThread(); util.stopThisScript();
} }
}; };

View file

@ -147,6 +147,7 @@ Scratch3PenBlocks.prototype._updatePenColor = function (penState) {
penState.penAttributes.color4f[0] = rgb.r / 255.0; penState.penAttributes.color4f[0] = rgb.r / 255.0;
penState.penAttributes.color4f[1] = rgb.g / 255.0; penState.penAttributes.color4f[1] = rgb.g / 255.0;
penState.penAttributes.color4f[2] = rgb.b / 255.0; penState.penAttributes.color4f[2] = rgb.b / 255.0;
penState.penAttributes.color4f[3] = 1;
}; };
/** /**
@ -260,6 +261,8 @@ Scratch3PenBlocks.prototype.setPenColorToColor = function (args, util) {
penState.penAttributes.color4f[2] = rgb.b / 255.0; penState.penAttributes.color4f[2] = rgb.b / 255.0;
if (rgb.hasOwnProperty('a')) { // Will there always be an 'a'? if (rgb.hasOwnProperty('a')) { // Will there always be an 'a'?
penState.penAttributes.color4f[3] = rgb.a / 255.0; penState.penAttributes.color4f[3] = rgb.a / 255.0;
} else {
penState.penAttributes.color4f[3] = 1;
} }
}; };

View file

@ -183,8 +183,8 @@ var execute = function (sequencer, thread) {
stopOtherTargetThreads: function () { stopOtherTargetThreads: function () {
runtime.stopForTarget(target, thread); runtime.stopForTarget(target, thread);
}, },
stopThread: function () { stopThisScript: function () {
sequencer.retireThread(thread); thread.stopThisScript();
}, },
startProcedure: function (procedureCode) { startProcedure: function (procedureCode) {
sequencer.stepToProcedure(thread, procedureCode); sequencer.stepToProcedure(thread, procedureCode);

View file

@ -140,6 +140,27 @@ Thread.prototype.popStack = function () {
return this.stack.pop(); return this.stack.pop();
}; };
/**
* Pop back down the stack frame until we hit a procedure call or the stack frame is emptied
*/
Thread.prototype.stopThisScript = function () {
var blockID = this.peekStack();
while (blockID !== null) {
var block = this.target.blocks.getBlock(blockID);
if (typeof block !== 'undefined' && block.opcode === 'procedures_callnoreturn') {
break;
}
this.popStack();
blockID = this.peekStack();
}
if (this.stack.length === 0) {
// Clean up!
this.requestScriptGlowInFrame = false;
this.status = Thread.STATUS_DONE;
}
};
/** /**
* Get top stack item. * Get top stack item.
* @return {?string} Block ID on top of stack. * @return {?string} Block ID on top of stack.

View file

@ -23,16 +23,35 @@ var Timer = function () {};
*/ */
Timer.prototype.startTime = 0; Timer.prototype.startTime = 0;
/**
* Disable use of self.performance for now as it results in lower performance
* However, instancing it like below (caching the self.performance to a local variable) negates most of the issues.
* @type {boolean}
*/
var USE_PERFORMANCE = false;
/**
* Legacy object to allow for us to call now to get the old style date time (for backwards compatibility)
* @deprecated This is only called via the nowObj.now() if no other means is possible...
*/
var legacyDateCode = {
now: function () {
return new Date().getTime();
}
};
/**
* Use this object to route all time functions through single access points.
*/
var nowObj = (USE_PERFORMANCE && typeof self !== 'undefined' && self.performance && 'now' in self.performance) ?
self.performance : Date.now ? Date : legacyDateCode;
/** /**
* Return the currently known absolute time, in ms precision. * Return the currently known absolute time, in ms precision.
* @returns {number} ms elapsed since 1 January 1970 00:00:00 UTC. * @returns {number} ms elapsed since 1 January 1970 00:00:00 UTC.
*/ */
Timer.prototype.time = function () { Timer.prototype.time = function () {
if (Date.now) { return nowObj.now();
return Date.now();
} else {
return new Date().getTime();
}
}; };
/** /**
@ -43,12 +62,7 @@ Timer.prototype.time = function () {
* @returns {number} ms-scale accurate time relative to other relative times. * @returns {number} ms-scale accurate time relative to other relative times.
*/ */
Timer.prototype.relativeTime = function () { Timer.prototype.relativeTime = function () {
if (typeof self !== 'undefined' && return nowObj.now();
self.performance && 'now' in self.performance) {
return self.performance.now();
} else {
return this.time();
}
}; };
/** /**
@ -56,15 +70,11 @@ Timer.prototype.relativeTime = function () {
* at the most accurate precision possible. * at the most accurate precision possible.
*/ */
Timer.prototype.start = function () { Timer.prototype.start = function () {
this.startTime = this.relativeTime(); this.startTime = nowObj.now();
}; };
/**
* Check time elapsed since `timer.start` was called.
* @returns {number} Time elapsed, in ms (possibly sub-ms precision).
*/
Timer.prototype.timeElapsed = function () { Timer.prototype.timeElapsed = function () {
return this.relativeTime() - this.startTime; return nowObj.now() - this.startTime;
}; };
module.exports = Timer; module.exports = Timer;

View file

@ -104,7 +104,7 @@ test('stop', function (t) {
var state = { var state = {
stopAll: 0, stopAll: 0,
stopOtherTargetThreads: 0, stopOtherTargetThreads: 0,
stopThread: 0 stopThisScript: 0
}; };
var util = { var util = {
stopAll: function () { stopAll: function () {
@ -113,8 +113,8 @@ test('stop', function (t) {
stopOtherTargetThreads: function () { stopOtherTargetThreads: function () {
state.stopOtherTargetThreads++; state.stopOtherTargetThreads++;
}, },
stopThread: function () { stopThisScript: function () {
state.stopThread++; state.stopThisScript++;
} }
}; };
@ -125,6 +125,6 @@ test('stop', function (t) {
c.stop({STOP_OPTION: 'this script'}, util); c.stop({STOP_OPTION: 'this script'}, util);
t.strictEqual(state.stopAll, 1); t.strictEqual(state.stopAll, 1);
t.strictEqual(state.stopOtherTargetThreads, 2); t.strictEqual(state.stopOtherTargetThreads, 2);
t.strictEqual(state.stopThread, 1); t.strictEqual(state.stopThisScript, 1);
t.end(); t.end();
}); });