scratch-vm/src/engine/variable.js

71 lines
1.8 KiB
JavaScript
Raw Normal View History

/**
* @fileoverview
* Object representing a Scratch variable.
*/
const uid = require('../util/uid');
2019-01-24 20:31:33 -05:00
const xmlEscape = require('../util/xml-escape');
2017-04-17 19:42:48 -04:00
class Variable {
/**
* @param {string} id Id of the variable.
* @param {string} name Name of the variable.
2017-11-13 16:55:57 -05:00
* @param {string} type Type of the variable, one of '' or 'list'
2017-04-17 19:42:48 -04:00
* @param {boolean} isCloud Whether the variable is stored in the cloud.
* @constructor
*/
constructor (id, name, type, isCloud) {
this.id = id || uid();
2017-04-17 19:42:48 -04:00
this.name = name;
this.type = type;
2017-04-17 19:42:48 -04:00
this.isCloud = isCloud;
switch (this.type) {
case Variable.SCALAR_TYPE:
this.value = 0;
break;
case Variable.LIST_TYPE:
this.value = [];
break;
case Variable.BROADCAST_MESSAGE_TYPE:
this.value = this.name;
break;
default:
throw new Error(`Invalid variable type: ${this.type}`);
}
2017-04-17 19:42:48 -04:00
}
toXML (isLocal) {
isLocal = (isLocal === true);
return `<variable type="${this.type}" id="${this.id}" islocal="${isLocal
2019-01-24 20:31:33 -05:00
}" iscloud="${this.isCloud}">${xmlEscape(this.name)}</variable>`;
}
/**
* Type representation for scalar variables.
2017-11-15 09:17:20 -05:00
* This is currently represented as ''
* for compatibility with blockly.
* @const {string}
*/
static get SCALAR_TYPE () {
return '';
}
/**
* Type representation for list variables.
* @const {string}
*/
static get LIST_TYPE () {
return 'list';
}
/**
* Type representation for list variables.
* @const {string}
*/
static get BROADCAST_MESSAGE_TYPE () {
return 'broadcast_msg';
}
2017-04-17 19:42:48 -04:00
}
module.exports = Variable;