mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2024-12-24 15:02:52 -05:00
export deserializeBlocks method
This commit is contained in:
parent
e6a7188613
commit
fe46a81cc9
1 changed files with 31 additions and 20 deletions
|
@ -741,6 +741,34 @@ const deserializeFields = function (fields) {
|
||||||
return obj;
|
return obj;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Covnert serialized INPUT and FIELD primitives back to hydrated block templates.
|
||||||
|
*
|
||||||
|
* @param {object} blocks Serialized SB3 "blocks" property of a target. Will be mutated.
|
||||||
|
* @return {object} input is modified and returned
|
||||||
|
*/
|
||||||
|
const deserializeBlocks = function (blocks) {
|
||||||
|
for (const blockId in blocks) {
|
||||||
|
if (!blocks.hasOwnProperty(blockId)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
const block = blocks[blockId];
|
||||||
|
if (Array.isArray(block)) {
|
||||||
|
// this is one of the primitives
|
||||||
|
// delete the old entry in object.blocks and replace it w/the
|
||||||
|
// deserialized object
|
||||||
|
delete block[blockId];
|
||||||
|
deserializeInputDesc(block, null, false, blocks);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
block.id = blockId; // add id back to block since it wasn't serialized
|
||||||
|
block.inputs = deserializeInputs(block.inputs, blockId, blocks);
|
||||||
|
block.fields = deserializeFields(block.fields);
|
||||||
|
}
|
||||||
|
return blocks;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parse a single "Scratch object" and create all its in-memory VM objects.
|
* Parse a single "Scratch object" and create all its in-memory VM objects.
|
||||||
* @param {!object} object From-JSON "Scratch object:" sprite, stage, watcher.
|
* @param {!object} object From-JSON "Scratch object:" sprite, stage, watcher.
|
||||||
|
@ -766,25 +794,7 @@ const parseScratchObject = function (object, runtime, extensions, zip) {
|
||||||
sprite.name = object.name;
|
sprite.name = object.name;
|
||||||
}
|
}
|
||||||
if (object.hasOwnProperty('blocks')) {
|
if (object.hasOwnProperty('blocks')) {
|
||||||
for (const blockId in object.blocks) {
|
deserializeBlocks(object.blocks);
|
||||||
if (!object.blocks.hasOwnProperty(blockId)) continue;
|
|
||||||
const blockJSON = object.blocks[blockId];
|
|
||||||
if (Array.isArray(blockJSON)) {
|
|
||||||
// this is one of the primitives
|
|
||||||
// delete the old entry in object.blocks and replace it w/the
|
|
||||||
// deserialized object
|
|
||||||
delete object.blocks[blockId];
|
|
||||||
deserializeInputDesc(blockJSON, null, false, object.blocks);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
blockJSON.id = blockId; // add id back to block since it wasn't serialized
|
|
||||||
const serializedInputs = blockJSON.inputs;
|
|
||||||
const deserializedInputs = deserializeInputs(serializedInputs, blockId, object.blocks);
|
|
||||||
blockJSON.inputs = deserializedInputs;
|
|
||||||
const serializedFields = blockJSON.fields;
|
|
||||||
const deserializedFields = deserializeFields(serializedFields);
|
|
||||||
blockJSON.fields = deserializedFields;
|
|
||||||
}
|
|
||||||
// Take a second pass to create objects and add extensions
|
// Take a second pass to create objects and add extensions
|
||||||
for (const blockId in object.blocks) {
|
for (const blockId in object.blocks) {
|
||||||
if (!object.blocks.hasOwnProperty(blockId)) continue;
|
if (!object.blocks.hasOwnProperty(blockId)) continue;
|
||||||
|
@ -1008,5 +1018,6 @@ const deserialize = function (json, runtime, zip, isSingleSprite) {
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
serialize: serialize,
|
serialize: serialize,
|
||||||
deserialize: deserialize
|
deserialize: deserialize,
|
||||||
|
deserializeBlocks: deserializeBlocks
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue