mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-11 10:39:56 -05:00
Merge pull request #1786 from picklesrus/test-log
VM changes for the sensing_of block.
This commit is contained in:
commit
e0550db404
5 changed files with 61 additions and 5 deletions
|
@ -313,12 +313,11 @@ class Scratch3SensingBlocks {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Variables
|
// Target variables.
|
||||||
const varName = args.PROPERTY;
|
const varName = args.PROPERTY;
|
||||||
for (const id in attrTarget.variables) {
|
const variable = attrTarget.lookupVariableByNameAndType(varName, '', true);
|
||||||
if (attrTarget.variables[id].name === varName) {
|
if (variable) {
|
||||||
return attrTarget.variables[id].value;
|
return variable.value;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise, 0
|
// Otherwise, 0
|
||||||
|
|
|
@ -567,6 +567,17 @@ class Blocks {
|
||||||
if (!optRuntime){
|
if (!optRuntime){
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
// The selected item in the sensing of block menu needs to change based on the
|
||||||
|
// selected target. Set it to the first item in the menu list.
|
||||||
|
// TODO: (#1787)
|
||||||
|
if (block.opcode === 'sensing_of_object_menu') {
|
||||||
|
if (block.fields.OBJECT.value === '_stage_') {
|
||||||
|
this._blocks[block.parent].fields.PROPERTY.value = 'backdrop #';
|
||||||
|
} else {
|
||||||
|
this._blocks[block.parent].fields.PROPERTY.value = 'x position';
|
||||||
|
}
|
||||||
|
optRuntime.requestBlocksUpdate();
|
||||||
|
}
|
||||||
|
|
||||||
const flyoutBlock = block.shadow && block.parent ? this._blocks[block.parent] : block;
|
const flyoutBlock = block.shadow && block.parent ? this._blocks[block.parent] : block;
|
||||||
if (flyoutBlock.isMonitored) {
|
if (flyoutBlock.isMonitored) {
|
||||||
|
|
|
@ -613,6 +613,14 @@ class Runtime extends EventEmitter {
|
||||||
return 'RUNTIME_STARTED';
|
return 'RUNTIME_STARTED';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Event name for reporting that a block was updated and needs to be rerendered.
|
||||||
|
* @const {string}
|
||||||
|
*/
|
||||||
|
static get BLOCKS_NEED_UPDATE () {
|
||||||
|
return 'BLOCKS_NEED_UPDATE';
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* How rapidly we try to step threads by default, in ms.
|
* How rapidly we try to step threads by default, in ms.
|
||||||
*/
|
*/
|
||||||
|
@ -2169,6 +2177,13 @@ class Runtime extends EventEmitter {
|
||||||
this._refreshTargets = true;
|
this._refreshTargets = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Emit an event that indicate that the blocks on the workspace need updating.
|
||||||
|
*/
|
||||||
|
requestBlocksUpdate () {
|
||||||
|
this.emit(Runtime.BLOCKS_NEED_UPDATE);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set up timers to repeatedly step in a browser.
|
* Set up timers to repeatedly step in a browser.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -108,6 +108,9 @@ class VirtualMachine extends EventEmitter {
|
||||||
this.runtime.on(Runtime.BLOCKSINFO_UPDATE, blocksInfo => {
|
this.runtime.on(Runtime.BLOCKSINFO_UPDATE, blocksInfo => {
|
||||||
this.emit(Runtime.BLOCKSINFO_UPDATE, blocksInfo);
|
this.emit(Runtime.BLOCKSINFO_UPDATE, blocksInfo);
|
||||||
});
|
});
|
||||||
|
this.runtime.on(Runtime.BLOCKS_NEED_UPDATE, () => {
|
||||||
|
this.emitWorkspaceUpdate();
|
||||||
|
});
|
||||||
this.runtime.on(Runtime.PERIPHERAL_LIST_UPDATE, info => {
|
this.runtime.on(Runtime.PERIPHERAL_LIST_UPDATE, info => {
|
||||||
this.emit(Runtime.PERIPHERAL_LIST_UPDATE, info);
|
this.emit(Runtime.PERIPHERAL_LIST_UPDATE, info);
|
||||||
});
|
});
|
||||||
|
|
|
@ -229,6 +229,34 @@ test('loud? boolean', t => {
|
||||||
t.end();
|
t.end();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('get attribute of sprite variable', t => {
|
||||||
|
const rt = new Runtime();
|
||||||
|
const sensing = new Sensing(rt);
|
||||||
|
const s = new Sprite();
|
||||||
|
const target = new RenderedTarget(s, rt);
|
||||||
|
const variable = {
|
||||||
|
name: 'cars',
|
||||||
|
value: 'trucks',
|
||||||
|
type: ''
|
||||||
|
};
|
||||||
|
// Add variable to set the map (it should be empty before this).
|
||||||
|
target.variables.anId = variable;
|
||||||
|
rt.getSpriteTargetByName = () => target;
|
||||||
|
t.equal(sensing.getAttributeOf({PROPERTY: 'cars'}), 'trucks');
|
||||||
|
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
test('get attribute of variable that does not exist', t => {
|
||||||
|
const rt = new Runtime();
|
||||||
|
const sensing = new Sensing(rt);
|
||||||
|
const s = new Sprite();
|
||||||
|
const target = new RenderedTarget(s, rt);
|
||||||
|
rt.getTargetForStage = () => target;
|
||||||
|
t.equal(sensing.getAttributeOf({PROPERTY: 'variableThatDoesNotExist'}), 0);
|
||||||
|
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
|
||||||
test('username block', t => {
|
test('username block', t => {
|
||||||
const rt = new Runtime();
|
const rt = new Runtime();
|
||||||
const sensing = new Sensing(rt);
|
const sensing = new Sensing(rt);
|
||||||
|
|
Loading…
Reference in a new issue