Subversion Repository Public Repository

Nextrek

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
{
    "uid": "1BEF7399KDF43A4E3ASA1A1E6EA70E833770",
    "isLoaded": true,
    "lastModificationTime": 1428415344176,
    "items": {
        "name": "VariableStore",
        "type": "game_script",
        "order": 6,
        "content": "# ===================================================================\n#\n#   Script: VariableStore\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass VariableStore\n    @objectCodecBlackList = [\"persistentNumbers\", \"persistentStrings\", \"persistentBooleans\", \"persistentLists\"]\n    \n    ###*\n    * <p>A storage for different kind of game variables. The following scopes\n    * for variables exist:</p>\n    * \n    * - Local Variables -> Only valid for the current scene.\n    * - Global Variables -> Valid for the whole game but bound to a single save-game.\n    * - Persistent Variables -> Valid for the whole game indepentent from the save-games.\n    * \n    * <p>The following data-types exist:</p>\n    * - Strings -> Variables storing text data.\n    * - Numbers -> Variables storing integer number values.\n    * - Booleans -> Variables storing boolean values. (Called \"Switches\" for easier understanding)\n    * - Lists -> Variables storing multiple other variables. Lists can also contain Lists.\n    * <p>\n    * Local variables are stored by scene UID. For each scene UID a list of local variables is stored.</p>\n    * \n    * <p>Global and persistent variables are stored and a specific domain. A domain is just a unique name such\n    * as <i>com.example.game</i> for example. The default domain is an empty string. Domains are useful to avoid\n    * overlapping of variable numbers when sharing content with other users. </p>\n    *\n    * @module gs\n    * @class VariableStore\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: () ->\n        ###*\n        * Current local variable context\n        * @property context\n        * @type Object\n        ###\n        @context = null\n        \n        ###*\n        * Current domain for global and persistent variables. Each domain has its own\n        * variables. Please use <b>changeDomain</b> method to change the domain.\n        * @property domain\n        * @type Object\n        * @readOnly\n        ###\n        @domain = \"\"\n        \n        ###*\n        * List of available domains for global and persistent variables.\n        * @property domains\n        * @type string[]\n        ###\n        @domains = [\"\"]\n        \n        ###*\n        * The global number variables of the current domain.\n        * @property numbers\n        * @type number[]\n        ###\n        @numbers = null\n        ###*\n        * The global boolean variables of the current domain.\n        * @property booleans\n        * @type boolean[]\n        ###\n        @booleans = null\n        ###*\n        * The global string variables of the current domain.\n        * @property strings\n        * @type string[]\n        ###\n        @strings = null\n        ###*\n        * The global list variables of the current domain.\n        * @property lists\n        * @type Object[][]\n        ###\n        @lists = null\n        \n        ###*\n        * The storage of all global variables by domain.\n        * @property globalVariablesByDomain\n        * @type Object[][]\n        ###\n        @globalVariablesByDomain = {}\n        \n        ###*\n        * The storage of all persistent variables by domain.\n        * @property persistentVariablesByDomain\n        * @type Object[][]\n        ###\n        @persistentVariablesByDomain = {}\n        \n        ###*\n        * The persistent number variables of the current domain.\n        * @property persistentNumbers\n        * @type number[]\n        ###\n        @persistentNumbers = []\n        ###*\n        * The persistent string variables of the current domain.\n        * @property persistentStrings\n        * @type string[]\n        ###\n        @persistentStrings = []\n        ###*\n        * The persistent boolean variables of the current domain.\n        * @property persistentBooleans\n        * @type boolean[]\n        ###\n        @persistentBooleans = []\n        ###*\n        * The persistent list variables of the current domain.\n        * @property persistentLists\n        * @type Object[][]\n        ###\n        @persistentLists = []\n        ###*\n        * The local number variables.\n        * @property localNumbers\n        * @type Object\n        ###\n        @localNumbers = {}\n        ###*\n        * The local string variables.\n        * @property localStrings\n        * @type Object\n        ###\n        @localStrings = {}\n        ###*\n        * The local boolean variables.\n        * @property localBooleans\n        * @type Object\n        ###\n        @localBooleans = {}\n        ###*\n        * The local list variables.\n        * @property localLists\n        * @type Object\n        ###\n        @localLists = {}\n        ###*\n        * @property tempNumbers\n        * @type number[]\n        ###\n        @tempNumbers = null\n        ###*\n        * @property tempStrings\n        * @type string[]\n        ###\n        @tempStrings = null\n        ###*\n        * @property localBooleans\n        * @type number[]\n        ###\n        @tempBooleans = null\n        ###*\n        * @property localLists\n        * @type Object[][]\n        ###\n        @tempLists = null\n        \n    ###*\n    * Called if this object instance is restored from a data-bundle. It can be used\n    * re-assign event-handler, anonymous functions, etc.\n    * \n    * @method onDataBundleRestore.\n    * @param Object data - The data-bundle\n    * @param gs.ObjectCodecContext context - The codec-context.\n    ###\n    onDataBundleRestore: (data, context) ->\n        domains = DataManager.getDocumentsByType(\"global_variables\").select (d) -> d.items.domain\n        \n        for domain, i in domains\n            @numbersByDomain[domain] = @numbersByDomain[i]\n            @stringsByDomain[domain] = @stringsByDomain[i]\n            @booleansByDomain[domain] = @booleansByDomain[i]\n            @listsByDomain[domain] = @listsByDomain[i]\n                \n        return null\n     \n    setupGlobalDomains: () ->\n        @numbersByDomain = []\n        @stringsByDomain = []\n        @booleansByDomain = []\n        @listsByDomain = []\n        \n        for domain, i in @domains\n            @numbersByDomain[i] = new Array(1000)\n            @numbersByDomain[domain] = @numbersByDomain[i]\n            @stringsByDomain[i] = new Array(1000)\n            @stringsByDomain[domain] = @stringsByDomain[i]\n            @booleansByDomain[i] = new Array(1000)\n            @booleansByDomain[domain] = @booleansByDomain[i]\n            @listsByDomain[i] = new Array(1000)\n            @listsByDomain[domain] = @listsByDomain[i]\n            \n        @numbers = @numbersByDomain[0]\n        @strings = @stringsByDomain[0]\n        @booleans = @booleansByDomain[0]\n        @lists = @numbersByDomain[0]\n        \n    setupPersistentDomains: (domains) ->\n        for domain, i in @domains\n            @persistentNumbers[i] = new Array(10)\n            @persistentNumbers[domain] = @persistentNumbers[i]\n            @persistentStrings[i] = new Array(10)\n            @persistentStrings[domain] = @persistentStrings[i]\n            @persistentBooleans[i] = new Array(10)\n            @persistentBooleans[domain] = @persistentBooleans[i]\n            @persistentLists[i] = new Array(10)\n            @persistentLists[domain] = @persistentLists[i]\n            \n    setupDomains: (domains) ->\n        @domains = domains\n        @setupGlobalDomains()\n        @setupPersistentDomains()\n        \n            \n    ###*\n    * Changes the current domain.\n    *\n    * @deprecated\n    * @method changeDomain\n    * @param {string} domain - The domain to change to.\n    ### \n    changeDomain: (domain) ->\n        @domain = domain\n        globalVariables = @globalVariablesByDomain[domain]\n        persistentVariables = @persistentVariablesByDomain[domain]\n        \n        if !globalVariables\n            globalVariables = @globalVariablesByDomain[domain] = { numbers: new Array(500), strings: new Array(500), booleans: new Array(500), lists: new Array(500) }\n        if !persistentVariables\n            persistentVariables = @persistentVariablesByDomain[domain] = { numbers: new Array(500), strings: new Array(500), booleans: new Array(500), lists: new Array(500) }    \n        \n        @numbers = globalVariables.numbers\n        @strings = globalVariables.strings\n        @booleans = globalVariables.booleans\n        @lists = globalVariables.lists\n        @persistentNumbers = persistentVariables.numbers\n        @persistentBooleans = persistentVariables.booleans\n        @persistentStrings = persistentVariables.strings\n        @persistentLists = persistentVariables.lists\n        \n    ###*\n    * Clears all global variables\n    *\n    * @method clearGlobalVariables\n    ### \n    clearAllGlobalVariables: ->\n        @setupGlobalDomains()\n        return\n        \n        globalVariables = @globalVariablesByDomain[@domain]\n        @numbersByDomain = new Array(1000)\n        globalVariables.booleans = new Array(1000)\n        globalVariables.strings = new Array(1000)\n    \n        @numbers = globalVariables.numbers\n        @strings = globalVariables.strings\n        @booleans = globalVariables.booleans\n    \n    ###*\n    * Clears all local variables for all contexts/scenes/common-events.\n    *\n    * @method clearAllLocalVariables\n    ### \n    clearAllLocalVariables: ->\n        @localNumbers = {}\n        @localStrings = {}\n        @localBooleans = {}\n        @localLists = {}\n     \n    ###*\n    * Clears specified variables.\n    *\n    * @method clearVariables\n    * @param {number[]} numbers - The number variables to clear.\n    * @param {string[]} strings - The string variables to clear.\n    * @param {boolean[]} booleans - The boolean variables to clear.\n    * @param {Array[]} lists - The list variables to clear.\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all specified variables are cleared.\n    ###  \n    clearVariables: (numbers, strings, booleans, lists, type, range) ->\n        switch type\n            when 0 # All\n                numbers?.fill(0, range.start, range.end)\n                strings?.fill(\"\", range.start, range.end)\n                booleans?.fill(false, range.start, range.end)\n                lists?.fill([], range.start, range.end)\n            when 1 # Switch\n                booleans?.fill(false, range.start, range.end)\n            when 2 # Number\n                numbers?.fill(0, range.start, range.end)\n            when 3 # Text\n                strings?.fill(\"\", range.start, range.end)\n            when 4 # List\n                lists?.fill([], range.start, range.end)\n                \n    ###*\n    * Clears all local variables for a specified context. If the context is not specified, all\n    * local variables for all contexts/scenes/common-events are cleared.\n    *\n    * @method clearLocalVariables\n    * @param {Object} context - The context to clear the local variables for. If <b>null</b>, all\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n    ###  \n    clearLocalVariables: (context, type, range) ->\n        if context?\n            ids = [context.id]\n        else\n            ids = Object.keys(@localNumbers)\n            \n        if range?\n            range = start: range.start, end: range.end + 1\n        else\n            range = start: 0, end: null\n            \n        for id in ids\n            @clearVariables(@localNumbers[id], @localStrings[id], @localBooleans[id], @localLists[id], type, range)\n \n    ###*\n    * Clears global variables.\n    *\n    * @method clearGlobalVariables\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n    ### \n    clearGlobalVariables: (type, range) ->\n        if range?\n            range = start: range.start, end: range.end + 1\n        else\n            range = start: 0, end: null\n            \n        @clearVariables(@numbers, @strings, @booleans, @lists, type, range)\n        \n    ###*\n    * Clears persistent variables.\n    *\n    * @method clearPersistentVariables\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n    ### \n    clearPersistentVariables: (type, range) ->\n        if range?\n            range = start: range.start, end: range.end + 1\n        else\n            range = start: 0, end: null\n            \n        @clearVariables(@persistentNumbers, @persistentstrings, @persistentBooleans, @persistentLists, type, range)\n        \n    ###*\n    * Initializes the variables. Should be called whenever the context changes. (Like after a scene change)\n    *\n    * @method setup\n    * @param {Object} context - The context(current scene) needed for local variables. Needs have at least an id-property.\n    ###     \n    setup: (context) ->\n        @setupLocalVariables(context)\n        @setupTempVariables(context)\n    \n    \n    ###*\n    * Initializes the local variables for the specified context. Should be called on first time use.\n    *\n    * @method setupLocalVariables\n    * @param {Object} context - The context(current scene). Needs have at least an id-property.\n    ###\n    setupLocalVariables: (context) ->\n        @setupVariables(context, \"localNumbers\", 0)\n        @setupVariables(context, \"localStrings\", \"\")\n        @setupVariables(context, \"localBooleans\", no)\n        @setupVariables(context, \"localLists\", [])\n        \n    ###*\n    * Initializes the specified kind of variables.\n    *\n    * @method setupVariables                                       \n    * @param {Object} context - The context(current scene). Needs have at least an id-property.\n    * @param {string} property - The kind of variables (property-name).\n    * @param {Object} defaultValue - The default value for each variable.\n    ###  \n    setupVariables: (context, property, defaultValue) ->\n        if not this[property][context.id]?\n            this[property][context.id] = []\n    \n    \n    ###*\n    * Initializes the current temp variables for the specified context. Should be called whenever the context changed.\n    *\n    * @method setupTempVariables\n    * @param {Object} context - The context(current scene). Needs have at least an id-property.\n    ###    \n    setupTempVariables: (context) ->\n        @context = context\n        if !@localNumbers[context.id]\n            @setupLocalVariables(context)\n            \n        @tempNumbers = @localNumbers[context.id]\n        @tempStrings = @localStrings[context.id]\n        @tempBooleans = @localBooleans[context.id]\n        @tempLists = @localLists[context.id]\n        \n    clearTempVariables: (context) ->\n        \n    \n    ###*\n    * Gets the index for the variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    * @param {number} scope - The variable scope: 0 = local, 1 = global, 2 = persistent.\n    * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n    ###  \n    indexOfVariable: (name, type, scope, domain) ->\n        result = 0\n        \n        switch scope\n            when 0 # Local\n                result = @indexOfTempVariable(name, type)\n            when 1 # Global\n                result = @indexOfGlobalVariable(name, type, domain)\n            when 2 # Persistent\n                result = @indexOfPersistentVariable(name, type, domain)\n            \n        return result\n        \n    ###*\n    * Gets the index for the local variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    ###  \n    indexOfTempVariable: (name, type) ->\n        result = 0\n        \n        if @context?.owner\n            if @context.owner.sceneDocument\n                variable = @context.owner.sceneDocument.items[type + \"Variables\"].first (v) -> v.name == name\n                result = variable.index if variable?\n            else if @context.owner[type + \"Variables\"]\n                variable = @context.owner[type + \"Variables\"].first (v) -> v.name == name\n                \n                if variable?\n                    result = variable.index\n                else\n                    console.warn(\"Variable referenced by name not found: \" + name +\"(local, \"+type+\")\")\n                    \n        return result\n        \n    ###*\n    * Gets the index for the global variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n    ###  \n    indexOfGlobalVariable: (name, type, domain) ->\n        result = 0\n        variables = DataManager.getDocumentsByType(\"global_variables\")\n        variablesDocument = variables.first (v) -> v.items.domain == domain\n        variablesDocument ?= variables[0]\n        \n        if variablesDocument\n            variable = variablesDocument.items[type + \"s\"].first (v) -> v.name == name\n            if variable\n                result = variable.index \n            else\n                console.warn(\"Variable referenced by name not found: #{name} (persistent, #{type})\")\n        \n        return result\n    \n    ###*\n    * Gets the index for the persistent variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n    ###      \n    indexOfPersistentVariable: (name, type, domain) ->\n        result = 0\n        variables = DataManager.getDocumentsByType(\"persistent_variables\")\n        variablesDocument = variables.first (v) -> v.items.domain == domain\n        variablesDocument ?= variables[0]\n        \n        if variablesDocument\n            variable = variablesDocument.items[type + \"s\"].first (v) -> v.name == name\n            if variable?\n                result = variable.index \n            else\n                console.warn(\"Variable referenced by name not found: #{name} (persistent, #{type})\")\n        \n        return result    \n        \n    ###*\n    * Sets the value of the number variable at the specified index.\n    *\n    * @method setNumberValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} type - The variable's index.\n    * @param {number} value - The value to set.\n    ###     \n    setNumberValueAtIndex: (scope, index, value, domain) ->\n        if scope == 2\n            @persistentNumbers[domain][index] = value\n        else if scope == 1\n            @numbersByDomain[domain||0][index] = value\n        else\n            @tempNumbers[index] = value\n\n    ###*\n    * Sets the value of a specified number variable.\n    *\n    * @method setNumberValueAtIndex\n    * @param {number} variable - The variable to set. \n    * @param {number} value - The value to set.\n    ###     \n    setNumberValueTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentNumbers[variable.domain||0][variable.index] = value\n        else if variable.scope == 1\n            @numbersByDomain[variable.domain||0][variable.index] = value\n        else\n            @tempNumbers[variable.index] = value\n\n    ###*\n    * Sets the value of a specified list variable.\n    *\n    * @method setListObjectTo\n    * @param {Object} variable - The variable to set. \n    * @param {Object} value - The value to set.\n    ###             \n    setListObjectTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentLists[variable.domain||0][variable.index] = value\n        else if variable.scope == 1\n            @listsByDomain[variable.domain||0][variable.index] = value\n        else\n            @tempLists[variable.index] = value\n\n    \n    ###*\n    * Sets the value of a specified boolean variable.\n    *\n    * @method setBooleanValueTo\n    * @param {Object} variable - The variable to set. \n    * @param {boolean} value - The value to set.\n    ###               \n    setBooleanValueTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentBooleans[variable.domain][variable.index] = value\n        else if variable.scope == 1\n            @booleansByDomain[variable.domain][variable.index] = value\n        else\n            @tempBooleans[variable.index] = value\n            \n    ###*\n    * Sets the value of the boolean variable at the specified index.\n    *\n    * @method setBooleanValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @param {boolean} value - The value to set.\n    ###     \n    setBooleanValueAtIndex: (scope, index, value, domain) ->\n        if scope == 2\n            @persistentBooleans[domain][index] = value\n        else if scope == 1\n            @booleansByDomain[domain][index] = value\n        else\n            @tempBooleans[index] = value\n\n    ###*\n    * Sets the value of a specified string variable.\n    *\n    * @method setStringValueTo\n    * @param {Object} variable - The variable to set. \n    * @param {string} value - The value to set.\n    ###   \n    setStringValueTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentStrings[variable.domain][variable.index] = value\n        else if variable.scope == 1\n            @stringsByDomain[variable.domain][variable.index] = value\n        else\n            @tempStrings[variable.index] = value\n            \n    ###*\n    * Sets the value of the string variable at the specified index.\n    *\n    * @method setStringValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @param {string} value - The value to set.\n    ###     \n    setStringValueAtIndex: (scope, index, value, domain) ->\n        if scope == 2\n            @persistentStrings[domain][index] = value\n        else if scope == 1\n            @stringsByDomain[domain][index] = value\n        else\n            @tempStrings[index] = value\n\n    ###*\n    * Gets the value of a specified list variable.\n    *\n    * @method listObjectOf\n    * @param {Object} object - The list-variable/object to get the value from.\n    * @return {Object} The list-object.\n    ###   \n    listObjectOf: (object) ->\n        result = 0\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentLists[object.domain][object.index]\n            else if object.scope == 1\n                result = @listsByDomain[object.domain][object.index]\n            else\n                result = @tempLists[object.index]\n        else\n            result = object\n            \n        return result || []\n    \n    ###*\n    * Gets the value of a number variable at the specified index.\n    *\n    * @method numberValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @return {Object} The number value of the variable.\n    ###      \n    numberValueAtIndex: (scope, index, domain) ->\n        result = 0\n        \n        if scope == 2\n            result = @persistentNumbers[domain][index]\n        else if scope == 1\n            result = @numbersByDomain[domain][index]\n        else\n            result = @tempNumbers[index]\n\n        return result\n    \n    ###*\n    * Gets the value of a specified number variable.\n    *\n    * @method numberValueOf\n    * @param {Object} object - The variable to get the value from.\n    * @return {Object} The number value of the variable.\n    ###     \n    numberValueOf: (object) ->\n        result = 0\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentNumbers[object.domain][object.index]\n            else if object.scope == 1\n                result = @numbersByDomain[object.domain][object.index]\n            else\n                result = @tempNumbers[object.index]\n\n        else\n            result = object\n            \n        return result || 0\n    \n    ###*\n    * Gets the value of a specified string variable.\n    *\n    * @method stringValueOf\n    * @param {Object} object - The variable to get the value from.\n    * @return {string} The string value of the variable.\n    ###        \n    stringValueOf: (object) ->\n        result = \"\"\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentStrings[object.domain][object.index]\n            else if object.scope == 1\n                result = @stringsByDomain[object.domain][object.index]\n            else\n                result = @tempStrings[object.index]\n        else\n            result = object\n            \n        return result || \"\"\n     \n    ###*\n    * Gets the value of a string variable at the specified index.\n    *\n    * @method stringValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @return {string} The string value of the variable.\n    ###        \n    stringValueAtIndex: (scope, index, domain) ->\n        result = \"\"\n        \n        if scope == 2\n            result = @persistentStrings[domain][index]\n        else if scope == 1\n            result = @stringsByDomain[domain][index]\n        else\n            result = @tempStrings[index]\n\n        return result || \"\"\n    \n    ###*\n    * Gets the value of a specified boolean variable.\n    *\n    * @method booleanValueOf\n    * @param {Object} object - The variable to get the value from.\n    * @return {Object} The boolean value of the variable.\n    ###       \n    booleanValueOf: (object) ->\n        result = no\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentBooleans[object.domain][object.index] || no\n            else if object.scope == 1\n                result = @booleansByDomain[object.domain][object.index] || no\n            else\n                result = @tempBooleans[object.index] || no\n\n        else\n            result = if object then true else false\n            \n        return result\n        \n    ###*\n    * Gets the value of a boolean variable at the specified index.\n    *\n    * @method booleanValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @return {boolean} The boolean value of the variable.\n    ###        \n    booleanValueAtIndex: (scope, index, domain) ->\n        result = no\n        \n        if scope == 2\n            result = @persistenBooleans[domain][index] || no\n        else if scope == 1\n            result = @booleansByDomain[domain][index] || no\n        else\n            result = @tempBooleans[index] || no\n\n        return result\n        \ngs.VariableStore = VariableStore",
        "compiledContent": "var VariableStore;\n\nVariableStore = (function() {\n  VariableStore.objectCodecBlackList = [\"persistentNumbers\", \"persistentStrings\", \"persistentBooleans\", \"persistentLists\"];\n\n\n  /**\n  * <p>A storage for different kind of game variables. The following scopes\n  * for variables exist:</p>\n  * \n  * - Local Variables -> Only valid for the current scene.\n  * - Global Variables -> Valid for the whole game but bound to a single save-game.\n  * - Persistent Variables -> Valid for the whole game indepentent from the save-games.\n  * \n  * <p>The following data-types exist:</p>\n  * - Strings -> Variables storing text data.\n  * - Numbers -> Variables storing integer number values.\n  * - Booleans -> Variables storing boolean values. (Called \"Switches\" for easier understanding)\n  * - Lists -> Variables storing multiple other variables. Lists can also contain Lists.\n  * <p>\n  * Local variables are stored by scene UID. For each scene UID a list of local variables is stored.</p>\n  * \n  * <p>Global and persistent variables are stored and a specific domain. A domain is just a unique name such\n  * as <i>com.example.game</i> for example. The default domain is an empty string. Domains are useful to avoid\n  * overlapping of variable numbers when sharing content with other users. </p>\n  *\n  * @module gs\n  * @class VariableStore\n  * @memberof gs\n  * @constructor\n   */\n\n  function VariableStore() {\n\n    /**\n    * Current local variable context\n    * @property context\n    * @type Object\n     */\n    this.context = null;\n\n    /**\n    * Current domain for global and persistent variables. Each domain has its own\n    * variables. Please use <b>changeDomain</b> method to change the domain.\n    * @property domain\n    * @type Object\n    * @readOnly\n     */\n    this.domain = \"\";\n\n    /**\n    * List of available domains for global and persistent variables.\n    * @property domains\n    * @type string[]\n     */\n    this.domains = [\"\"];\n\n    /**\n    * The global number variables of the current domain.\n    * @property numbers\n    * @type number[]\n     */\n    this.numbers = null;\n\n    /**\n    * The global boolean variables of the current domain.\n    * @property booleans\n    * @type boolean[]\n     */\n    this.booleans = null;\n\n    /**\n    * The global string variables of the current domain.\n    * @property strings\n    * @type string[]\n     */\n    this.strings = null;\n\n    /**\n    * The global list variables of the current domain.\n    * @property lists\n    * @type Object[][]\n     */\n    this.lists = null;\n\n    /**\n    * The storage of all global variables by domain.\n    * @property globalVariablesByDomain\n    * @type Object[][]\n     */\n    this.globalVariablesByDomain = {};\n\n    /**\n    * The storage of all persistent variables by domain.\n    * @property persistentVariablesByDomain\n    * @type Object[][]\n     */\n    this.persistentVariablesByDomain = {};\n\n    /**\n    * The persistent number variables of the current domain.\n    * @property persistentNumbers\n    * @type number[]\n     */\n    this.persistentNumbers = [];\n\n    /**\n    * The persistent string variables of the current domain.\n    * @property persistentStrings\n    * @type string[]\n     */\n    this.persistentStrings = [];\n\n    /**\n    * The persistent boolean variables of the current domain.\n    * @property persistentBooleans\n    * @type boolean[]\n     */\n    this.persistentBooleans = [];\n\n    /**\n    * The persistent list variables of the current domain.\n    * @property persistentLists\n    * @type Object[][]\n     */\n    this.persistentLists = [];\n\n    /**\n    * The local number variables.\n    * @property localNumbers\n    * @type Object\n     */\n    this.localNumbers = {};\n\n    /**\n    * The local string variables.\n    * @property localStrings\n    * @type Object\n     */\n    this.localStrings = {};\n\n    /**\n    * The local boolean variables.\n    * @property localBooleans\n    * @type Object\n     */\n    this.localBooleans = {};\n\n    /**\n    * The local list variables.\n    * @property localLists\n    * @type Object\n     */\n    this.localLists = {};\n\n    /**\n    * @property tempNumbers\n    * @type number[]\n     */\n    this.tempNumbers = null;\n\n    /**\n    * @property tempStrings\n    * @type string[]\n     */\n    this.tempStrings = null;\n\n    /**\n    * @property localBooleans\n    * @type number[]\n     */\n    this.tempBooleans = null;\n\n    /**\n    * @property localLists\n    * @type Object[][]\n     */\n    this.tempLists = null;\n  }\n\n\n  /**\n  * Called if this object instance is restored from a data-bundle. It can be used\n  * re-assign event-handler, anonymous functions, etc.\n  * \n  * @method onDataBundleRestore.\n  * @param Object data - The data-bundle\n  * @param gs.ObjectCodecContext context - The codec-context.\n   */\n\n  VariableStore.prototype.onDataBundleRestore = function(data, context) {\n    var domain, domains, i, j, len;\n    domains = DataManager.getDocumentsByType(\"global_variables\").select(function(d) {\n      return d.items.domain;\n    });\n    for (i = j = 0, len = domains.length; j < len; i = ++j) {\n      domain = domains[i];\n      this.numbersByDomain[domain] = this.numbersByDomain[i];\n      this.stringsByDomain[domain] = this.stringsByDomain[i];\n      this.booleansByDomain[domain] = this.booleansByDomain[i];\n      this.listsByDomain[domain] = this.listsByDomain[i];\n    }\n    return null;\n  };\n\n  VariableStore.prototype.setupGlobalDomains = function() {\n    var domain, i, j, len, ref;\n    this.numbersByDomain = [];\n    this.stringsByDomain = [];\n    this.booleansByDomain = [];\n    this.listsByDomain = [];\n    ref = this.domains;\n    for (i = j = 0, len = ref.length; j < len; i = ++j) {\n      domain = ref[i];\n      this.numbersByDomain[i] = new Array(1000);\n      this.numbersByDomain[domain] = this.numbersByDomain[i];\n      this.stringsByDomain[i] = new Array(1000);\n      this.stringsByDomain[domain] = this.stringsByDomain[i];\n      this.booleansByDomain[i] = new Array(1000);\n      this.booleansByDomain[domain] = this.booleansByDomain[i];\n      this.listsByDomain[i] = new Array(1000);\n      this.listsByDomain[domain] = this.listsByDomain[i];\n    }\n    this.numbers = this.numbersByDomain[0];\n    this.strings = this.stringsByDomain[0];\n    this.booleans = this.booleansByDomain[0];\n    return this.lists = this.numbersByDomain[0];\n  };\n\n  VariableStore.prototype.setupPersistentDomains = function(domains) {\n    var domain, i, j, len, ref, results;\n    ref = this.domains;\n    results = [];\n    for (i = j = 0, len = ref.length; j < len; i = ++j) {\n      domain = ref[i];\n      this.persistentNumbers[i] = new Array(10);\n      this.persistentNumbers[domain] = this.persistentNumbers[i];\n      this.persistentStrings[i] = new Array(10);\n      this.persistentStrings[domain] = this.persistentStrings[i];\n      this.persistentBooleans[i] = new Array(10);\n      this.persistentBooleans[domain] = this.persistentBooleans[i];\n      this.persistentLists[i] = new Array(10);\n      results.push(this.persistentLists[domain] = this.persistentLists[i]);\n    }\n    return results;\n  };\n\n  VariableStore.prototype.setupDomains = function(domains) {\n    this.domains = domains;\n    this.setupGlobalDomains();\n    return this.setupPersistentDomains();\n  };\n\n\n  /**\n  * Changes the current domain.\n  *\n  * @deprecated\n  * @method changeDomain\n  * @param {string} domain - The domain to change to.\n   */\n\n  VariableStore.prototype.changeDomain = function(domain) {\n    var globalVariables, persistentVariables;\n    this.domain = domain;\n    globalVariables = this.globalVariablesByDomain[domain];\n    persistentVariables = this.persistentVariablesByDomain[domain];\n    if (!globalVariables) {\n      globalVariables = this.globalVariablesByDomain[domain] = {\n        numbers: new Array(500),\n        strings: new Array(500),\n        booleans: new Array(500),\n        lists: new Array(500)\n      };\n    }\n    if (!persistentVariables) {\n      persistentVariables = this.persistentVariablesByDomain[domain] = {\n        numbers: new Array(500),\n        strings: new Array(500),\n        booleans: new Array(500),\n        lists: new Array(500)\n      };\n    }\n    this.numbers = globalVariables.numbers;\n    this.strings = globalVariables.strings;\n    this.booleans = globalVariables.booleans;\n    this.lists = globalVariables.lists;\n    this.persistentNumbers = persistentVariables.numbers;\n    this.persistentBooleans = persistentVariables.booleans;\n    this.persistentStrings = persistentVariables.strings;\n    return this.persistentLists = persistentVariables.lists;\n  };\n\n\n  /**\n  * Clears all global variables\n  *\n  * @method clearGlobalVariables\n   */\n\n  VariableStore.prototype.clearAllGlobalVariables = function() {\n    var globalVariables;\n    this.setupGlobalDomains();\n    return;\n    globalVariables = this.globalVariablesByDomain[this.domain];\n    this.numbersByDomain = new Array(1000);\n    globalVariables.booleans = new Array(1000);\n    globalVariables.strings = new Array(1000);\n    this.numbers = globalVariables.numbers;\n    this.strings = globalVariables.strings;\n    return this.booleans = globalVariables.booleans;\n  };\n\n\n  /**\n  * Clears all local variables for all contexts/scenes/common-events.\n  *\n  * @method clearAllLocalVariables\n   */\n\n  VariableStore.prototype.clearAllLocalVariables = function() {\n    this.localNumbers = {};\n    this.localStrings = {};\n    this.localBooleans = {};\n    return this.localLists = {};\n  };\n\n\n  /**\n  * Clears specified variables.\n  *\n  * @method clearVariables\n  * @param {number[]} numbers - The number variables to clear.\n  * @param {string[]} strings - The string variables to clear.\n  * @param {boolean[]} booleans - The boolean variables to clear.\n  * @param {Array[]} lists - The list variables to clear.\n  * @param {number} type - Determines what kind of variables should be cleared.\n  * <ul>\n  * <li>0 = All</li>\n  * <li>1 = Switches / Booleans</li>\n  * <li>2 = Numbers</li>\n  * <li>3 = Texts</li>\n  * <li>4 = Lists</li>\n  * </ul>\n  * @param {Object} range - The variable id-range to clear. If <b>null</b> all specified variables are cleared.\n   */\n\n  VariableStore.prototype.clearVariables = function(numbers, strings, booleans, lists, type, range) {\n    switch (type) {\n      case 0:\n        if (numbers != null) {\n          numbers.fill(0, range.start, range.end);\n        }\n        if (strings != null) {\n          strings.fill(\"\", range.start, range.end);\n        }\n        if (booleans != null) {\n          booleans.fill(false, range.start, range.end);\n        }\n        return lists != null ? lists.fill([], range.start, range.end) : void 0;\n      case 1:\n        return booleans != null ? booleans.fill(false, range.start, range.end) : void 0;\n      case 2:\n        return numbers != null ? numbers.fill(0, range.start, range.end) : void 0;\n      case 3:\n        return strings != null ? strings.fill(\"\", range.start, range.end) : void 0;\n      case 4:\n        return lists != null ? lists.fill([], range.start, range.end) : void 0;\n    }\n  };\n\n\n  /**\n  * Clears all local variables for a specified context. If the context is not specified, all\n  * local variables for all contexts/scenes/common-events are cleared.\n  *\n  * @method clearLocalVariables\n  * @param {Object} context - The context to clear the local variables for. If <b>null</b>, all\n  * @param {number} type - Determines what kind of variables should be cleared.\n  * <ul>\n  * <li>0 = All</li>\n  * <li>1 = Switches / Booleans</li>\n  * <li>2 = Numbers</li>\n  * <li>3 = Texts</li>\n  * <li>4 = Lists</li>\n  * </ul>\n  * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n   */\n\n  VariableStore.prototype.clearLocalVariables = function(context, type, range) {\n    var id, ids, j, len, results;\n    if (context != null) {\n      ids = [context.id];\n    } else {\n      ids = Object.keys(this.localNumbers);\n    }\n    if (range != null) {\n      range = {\n        start: range.start,\n        end: range.end + 1\n      };\n    } else {\n      range = {\n        start: 0,\n        end: null\n      };\n    }\n    results = [];\n    for (j = 0, len = ids.length; j < len; j++) {\n      id = ids[j];\n      results.push(this.clearVariables(this.localNumbers[id], this.localStrings[id], this.localBooleans[id], this.localLists[id], type, range));\n    }\n    return results;\n  };\n\n\n  /**\n  * Clears global variables.\n  *\n  * @method clearGlobalVariables\n  * @param {number} type - Determines what kind of variables should be cleared.\n  * <ul>\n  * <li>0 = All</li>\n  * <li>1 = Switches / Booleans</li>\n  * <li>2 = Numbers</li>\n  * <li>3 = Texts</li>\n  * <li>4 = Lists</li>\n  * </ul>\n  * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n   */\n\n  VariableStore.prototype.clearGlobalVariables = function(type, range) {\n    if (range != null) {\n      range = {\n        start: range.start,\n        end: range.end + 1\n      };\n    } else {\n      range = {\n        start: 0,\n        end: null\n      };\n    }\n    return this.clearVariables(this.numbers, this.strings, this.booleans, this.lists, type, range);\n  };\n\n\n  /**\n  * Clears persistent variables.\n  *\n  * @method clearPersistentVariables\n  * @param {number} type - Determines what kind of variables should be cleared.\n  * <ul>\n  * <li>0 = All</li>\n  * <li>1 = Switches / Booleans</li>\n  * <li>2 = Numbers</li>\n  * <li>3 = Texts</li>\n  * <li>4 = Lists</li>\n  * </ul>\n  * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n   */\n\n  VariableStore.prototype.clearPersistentVariables = function(type, range) {\n    if (range != null) {\n      range = {\n        start: range.start,\n        end: range.end + 1\n      };\n    } else {\n      range = {\n        start: 0,\n        end: null\n      };\n    }\n    return this.clearVariables(this.persistentNumbers, this.persistentstrings, this.persistentBooleans, this.persistentLists, type, range);\n  };\n\n\n  /**\n  * Initializes the variables. Should be called whenever the context changes. (Like after a scene change)\n  *\n  * @method setup\n  * @param {Object} context - The context(current scene) needed for local variables. Needs have at least an id-property.\n   */\n\n  VariableStore.prototype.setup = function(context) {\n    this.setupLocalVariables(context);\n    return this.setupTempVariables(context);\n  };\n\n\n  /**\n  * Initializes the local variables for the specified context. Should be called on first time use.\n  *\n  * @method setupLocalVariables\n  * @param {Object} context - The context(current scene). Needs have at least an id-property.\n   */\n\n  VariableStore.prototype.setupLocalVariables = function(context) {\n    this.setupVariables(context, \"localNumbers\", 0);\n    this.setupVariables(context, \"localStrings\", \"\");\n    this.setupVariables(context, \"localBooleans\", false);\n    return this.setupVariables(context, \"localLists\", []);\n  };\n\n\n  /**\n  * Initializes the specified kind of variables.\n  *\n  * @method setupVariables                                       \n  * @param {Object} context - The context(current scene). Needs have at least an id-property.\n  * @param {string} property - The kind of variables (property-name).\n  * @param {Object} defaultValue - The default value for each variable.\n   */\n\n  VariableStore.prototype.setupVariables = function(context, property, defaultValue) {\n    if (this[property][context.id] == null) {\n      return this[property][context.id] = [];\n    }\n  };\n\n\n  /**\n  * Initializes the current temp variables for the specified context. Should be called whenever the context changed.\n  *\n  * @method setupTempVariables\n  * @param {Object} context - The context(current scene). Needs have at least an id-property.\n   */\n\n  VariableStore.prototype.setupTempVariables = function(context) {\n    this.context = context;\n    if (!this.localNumbers[context.id]) {\n      this.setupLocalVariables(context);\n    }\n    this.tempNumbers = this.localNumbers[context.id];\n    this.tempStrings = this.localStrings[context.id];\n    this.tempBooleans = this.localBooleans[context.id];\n    return this.tempLists = this.localLists[context.id];\n  };\n\n  VariableStore.prototype.clearTempVariables = function(context) {};\n\n\n  /**\n  * Gets the index for the variable with the specified name. If a variable with that\n  * name cannot be found, the index will be 0.\n  *\n  * @method indexOfTempVariable\n  * @param {string} name - The name of the variable to get the index for.\n  * @param {string} type - The type name: number, string, boolean or list.\n  * @param {number} scope - The variable scope: 0 = local, 1 = global, 2 = persistent.\n  * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n   */\n\n  VariableStore.prototype.indexOfVariable = function(name, type, scope, domain) {\n    var result;\n    result = 0;\n    switch (scope) {\n      case 0:\n        result = this.indexOfTempVariable(name, type);\n        break;\n      case 1:\n        result = this.indexOfGlobalVariable(name, type, domain);\n        break;\n      case 2:\n        result = this.indexOfPersistentVariable(name, type, domain);\n    }\n    return result;\n  };\n\n\n  /**\n  * Gets the index for the local variable with the specified name. If a variable with that\n  * name cannot be found, the index will be 0.\n  *\n  * @method indexOfTempVariable\n  * @param {string} name - The name of the variable to get the index for.\n  * @param {string} type - The type name: number, string, boolean or list.\n   */\n\n  VariableStore.prototype.indexOfTempVariable = function(name, type) {\n    var ref, result, variable;\n    result = 0;\n    if ((ref = this.context) != null ? ref.owner : void 0) {\n      if (this.context.owner.sceneDocument) {\n        variable = this.context.owner.sceneDocument.items[type + \"Variables\"].first(function(v) {\n          return v.name === name;\n        });\n        if (variable != null) {\n          result = variable.index;\n        }\n      } else if (this.context.owner[type + \"Variables\"]) {\n        variable = this.context.owner[type + \"Variables\"].first(function(v) {\n          return v.name === name;\n        });\n        if (variable != null) {\n          result = variable.index;\n        } else {\n          console.warn(\"Variable referenced by name not found: \" + name(+\"(local, \" + type + \")\"));\n        }\n      }\n    }\n    return result;\n  };\n\n\n  /**\n  * Gets the index for the global variable with the specified name. If a variable with that\n  * name cannot be found, the index will be 0.\n  *\n  * @method indexOfTempVariable\n  * @param {string} name - The name of the variable to get the index for.\n  * @param {string} type - The type name: number, string, boolean or list.\n  * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n   */\n\n  VariableStore.prototype.indexOfGlobalVariable = function(name, type, domain) {\n    var result, variable, variables, variablesDocument;\n    result = 0;\n    variables = DataManager.getDocumentsByType(\"global_variables\");\n    variablesDocument = variables.first(function(v) {\n      return v.items.domain === domain;\n    });\n    if (variablesDocument == null) {\n      variablesDocument = variables[0];\n    }\n    if (variablesDocument) {\n      variable = variablesDocument.items[type + \"s\"].first(function(v) {\n        return v.name === name;\n      });\n      if (variable) {\n        result = variable.index;\n      } else {\n        console.warn(\"Variable referenced by name not found: \" + name + \" (persistent, \" + type + \")\");\n      }\n    }\n    return result;\n  };\n\n\n  /**\n  * Gets the index for the persistent variable with the specified name. If a variable with that\n  * name cannot be found, the index will be 0.\n  *\n  * @method indexOfTempVariable\n  * @param {string} name - The name of the variable to get the index for.\n  * @param {string} type - The type name: number, string, boolean or list.\n  * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n   */\n\n  VariableStore.prototype.indexOfPersistentVariable = function(name, type, domain) {\n    var result, variable, variables, variablesDocument;\n    result = 0;\n    variables = DataManager.getDocumentsByType(\"persistent_variables\");\n    variablesDocument = variables.first(function(v) {\n      return v.items.domain === domain;\n    });\n    if (variablesDocument == null) {\n      variablesDocument = variables[0];\n    }\n    if (variablesDocument) {\n      variable = variablesDocument.items[type + \"s\"].first(function(v) {\n        return v.name === name;\n      });\n      if (variable != null) {\n        result = variable.index;\n      } else {\n        console.warn(\"Variable referenced by name not found: \" + name + \" (persistent, \" + type + \")\");\n      }\n    }\n    return result;\n  };\n\n\n  /**\n  * Sets the value of the number variable at the specified index.\n  *\n  * @method setNumberValueAtIndex\n  * @param {number} scope - The variable scope.\n  * @param {number} type - The variable's index.\n  * @param {number} value - The value to set.\n   */\n\n  VariableStore.prototype.setNumberValueAtIndex = function(scope, index, value, domain) {\n    if (scope === 2) {\n      return this.persistentNumbers[domain][index] = value;\n    } else if (scope === 1) {\n      return this.numbersByDomain[domain || 0][index] = value;\n    } else {\n      return this.tempNumbers[index] = value;\n    }\n  };\n\n\n  /**\n  * Sets the value of a specified number variable.\n  *\n  * @method setNumberValueAtIndex\n  * @param {number} variable - The variable to set. \n  * @param {number} value - The value to set.\n   */\n\n  VariableStore.prototype.setNumberValueTo = function(variable, value) {\n    if (variable.scope === 2) {\n      return this.persistentNumbers[variable.domain || 0][variable.index] = value;\n    } else if (variable.scope === 1) {\n      return this.numbersByDomain[variable.domain || 0][variable.index] = value;\n    } else {\n      return this.tempNumbers[variable.index] = value;\n    }\n  };\n\n\n  /**\n  * Sets the value of a specified list variable.\n  *\n  * @method setListObjectTo\n  * @param {Object} variable - The variable to set. \n  * @param {Object} value - The value to set.\n   */\n\n  VariableStore.prototype.setListObjectTo = function(variable, value) {\n    if (variable.scope === 2) {\n      return this.persistentLists[variable.domain || 0][variable.index] = value;\n    } else if (variable.scope === 1) {\n      return this.listsByDomain[variable.domain || 0][variable.index] = value;\n    } else {\n      return this.tempLists[variable.index] = value;\n    }\n  };\n\n\n  /**\n  * Sets the value of a specified boolean variable.\n  *\n  * @method setBooleanValueTo\n  * @param {Object} variable - The variable to set. \n  * @param {boolean} value - The value to set.\n   */\n\n  VariableStore.prototype.setBooleanValueTo = function(variable, value) {\n    if (variable.scope === 2) {\n      return this.persistentBooleans[variable.domain][variable.index] = value;\n    } else if (variable.scope === 1) {\n      return this.booleansByDomain[variable.domain][variable.index] = value;\n    } else {\n      return this.tempBooleans[variable.index] = value;\n    }\n  };\n\n\n  /**\n  * Sets the value of the boolean variable at the specified index.\n  *\n  * @method setBooleanValueAtIndex\n  * @param {number} scope - The variable scope.\n  * @param {number} index - The variable's index.\n  * @param {boolean} value - The value to set.\n   */\n\n  VariableStore.prototype.setBooleanValueAtIndex = function(scope, index, value, domain) {\n    if (scope === 2) {\n      return this.persistentBooleans[domain][index] = value;\n    } else if (scope === 1) {\n      return this.booleansByDomain[domain][index] = value;\n    } else {\n      return this.tempBooleans[index] = value;\n    }\n  };\n\n\n  /**\n  * Sets the value of a specified string variable.\n  *\n  * @method setStringValueTo\n  * @param {Object} variable - The variable to set. \n  * @param {string} value - The value to set.\n   */\n\n  VariableStore.prototype.setStringValueTo = function(variable, value) {\n    if (variable.scope === 2) {\n      return this.persistentStrings[variable.domain][variable.index] = value;\n    } else if (variable.scope === 1) {\n      return this.stringsByDomain[variable.domain][variable.index] = value;\n    } else {\n      return this.tempStrings[variable.index] = value;\n    }\n  };\n\n\n  /**\n  * Sets the value of the string variable at the specified index.\n  *\n  * @method setStringValueAtIndex\n  * @param {number} scope - The variable scope.\n  * @param {number} index - The variable's index.\n  * @param {string} value - The value to set.\n   */\n\n  VariableStore.prototype.setStringValueAtIndex = function(scope, index, value, domain) {\n    if (scope === 2) {\n      return this.persistentStrings[domain][index] = value;\n    } else if (scope === 1) {\n      return this.stringsByDomain[domain][index] = value;\n    } else {\n      return this.tempStrings[index] = value;\n    }\n  };\n\n\n  /**\n  * Gets the value of a specified list variable.\n  *\n  * @method listObjectOf\n  * @param {Object} object - The list-variable/object to get the value from.\n  * @return {Object} The list-object.\n   */\n\n  VariableStore.prototype.listObjectOf = function(object) {\n    var result;\n    result = 0;\n    if ((object != null) && (object.index != null)) {\n      if (object.scope === 2) {\n        result = this.persistentLists[object.domain][object.index];\n      } else if (object.scope === 1) {\n        result = this.listsByDomain[object.domain][object.index];\n      } else {\n        result = this.tempLists[object.index];\n      }\n    } else {\n      result = object;\n    }\n    return result || [];\n  };\n\n\n  /**\n  * Gets the value of a number variable at the specified index.\n  *\n  * @method numberValueAtIndex\n  * @param {number} scope - The variable scope.\n  * @param {number} index - The variable's index.\n  * @return {Object} The number value of the variable.\n   */\n\n  VariableStore.prototype.numberValueAtIndex = function(scope, index, domain) {\n    var result;\n    result = 0;\n    if (scope === 2) {\n      result = this.persistentNumbers[domain][index];\n    } else if (scope === 1) {\n      result = this.numbersByDomain[domain][index];\n    } else {\n      result = this.tempNumbers[index];\n    }\n    return result;\n  };\n\n\n  /**\n  * Gets the value of a specified number variable.\n  *\n  * @method numberValueOf\n  * @param {Object} object - The variable to get the value from.\n  * @return {Object} The number value of the variable.\n   */\n\n  VariableStore.prototype.numberValueOf = function(object) {\n    var result;\n    result = 0;\n    if ((object != null) && (object.index != null)) {\n      if (object.scope === 2) {\n        result = this.persistentNumbers[object.domain][object.index];\n      } else if (object.scope === 1) {\n        result = this.numbersByDomain[object.domain][object.index];\n      } else {\n        result = this.tempNumbers[object.index];\n      }\n    } else {\n      result = object;\n    }\n    return result || 0;\n  };\n\n\n  /**\n  * Gets the value of a specified string variable.\n  *\n  * @method stringValueOf\n  * @param {Object} object - The variable to get the value from.\n  * @return {string} The string value of the variable.\n   */\n\n  VariableStore.prototype.stringValueOf = function(object) {\n    var result;\n    result = \"\";\n    if ((object != null) && (object.index != null)) {\n      if (object.scope === 2) {\n        result = this.persistentStrings[object.domain][object.index];\n      } else if (object.scope === 1) {\n        result = this.stringsByDomain[object.domain][object.index];\n      } else {\n        result = this.tempStrings[object.index];\n      }\n    } else {\n      result = object;\n    }\n    return result || \"\";\n  };\n\n\n  /**\n  * Gets the value of a string variable at the specified index.\n  *\n  * @method stringValueAtIndex\n  * @param {number} scope - The variable scope.\n  * @param {number} index - The variable's index.\n  * @return {string} The string value of the variable.\n   */\n\n  VariableStore.prototype.stringValueAtIndex = function(scope, index, domain) {\n    var result;\n    result = \"\";\n    if (scope === 2) {\n      result = this.persistentStrings[domain][index];\n    } else if (scope === 1) {\n      result = this.stringsByDomain[domain][index];\n    } else {\n      result = this.tempStrings[index];\n    }\n    return result || \"\";\n  };\n\n\n  /**\n  * Gets the value of a specified boolean variable.\n  *\n  * @method booleanValueOf\n  * @param {Object} object - The variable to get the value from.\n  * @return {Object} The boolean value of the variable.\n   */\n\n  VariableStore.prototype.booleanValueOf = function(object) {\n    var result;\n    result = false;\n    if ((object != null) && (object.index != null)) {\n      if (object.scope === 2) {\n        result = this.persistentBooleans[object.domain][object.index] || false;\n      } else if (object.scope === 1) {\n        result = this.booleansByDomain[object.domain][object.index] || false;\n      } else {\n        result = this.tempBooleans[object.index] || false;\n      }\n    } else {\n      result = object ? true : false;\n    }\n    return result;\n  };\n\n\n  /**\n  * Gets the value of a boolean variable at the specified index.\n  *\n  * @method booleanValueAtIndex\n  * @param {number} scope - The variable scope.\n  * @param {number} index - The variable's index.\n  * @return {boolean} The boolean value of the variable.\n   */\n\n  VariableStore.prototype.booleanValueAtIndex = function(scope, index, domain) {\n    var result;\n    result = false;\n    if (scope === 2) {\n      result = this.persistenBooleans[domain][index] || false;\n    } else if (scope === 1) {\n      result = this.booleansByDomain[domain][index] || false;\n    } else {\n      result = this.tempBooleans[index] || false;\n    }\n    return result;\n  };\n\n  return VariableStore;\n\n})();\n\ngs.VariableStore = VariableStore;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"AAOA,IAAA;;AAAM;EACF,aAAC,CAAA,oBAAD,GAAwB,CAAC,mBAAD,EAAsB,mBAAtB,EAA2C,oBAA3C,EAAiE,iBAAjE;;;AAExB;;;;;;;;;;;;;;;;;;;;;;;;;;EAyBa,uBAAA;;AACT;;;;;IAKA,IAAC,CAAA,OAAD,GAAW;;AAEX;;;;;;;IAOA,IAAC,CAAA,MAAD,GAAU;;AAEV;;;;;IAKA,IAAC,CAAA,OAAD,GAAW,CAAC,EAAD;;AAEX;;;;;IAKA,IAAC,CAAA,OAAD,GAAW;;AACX;;;;;IAKA,IAAC,CAAA,QAAD,GAAY;;AACZ;;;;;IAKA,IAAC,CAAA,OAAD,GAAW;;AACX;;;;;IAKA,IAAC,CAAA,KAAD,GAAS;;AAET;;;;;IAKA,IAAC,CAAA,uBAAD,GAA2B;;AAE3B;;;;;IAKA,IAAC,CAAA,2BAAD,GAA+B;;AAE/B;;;;;IAKA,IAAC,CAAA,iBAAD,GAAqB;;AACrB;;;;;IAKA,IAAC,CAAA,iBAAD,GAAqB;;AACrB;;;;;IAKA,IAAC,CAAA,kBAAD,GAAsB;;AACtB;;;;;IAKA,IAAC,CAAA,eAAD,GAAmB;;AACnB;;;;;IAKA,IAAC,CAAA,YAAD,GAAgB;;AAChB;;;;;IAKA,IAAC,CAAA,YAAD,GAAgB;;AAChB;;;;;IAKA,IAAC,CAAA,aAAD,GAAiB;;AACjB;;;;;IAKA,IAAC,CAAA,UAAD,GAAc;;AACd;;;;IAIA,IAAC,CAAA,WAAD,GAAe;;AACf;;;;IAIA,IAAC,CAAA,WAAD,GAAe;;AACf;;;;IAIA,IAAC,CAAA,YAAD,GAAgB;;AAChB;;;;IAIA,IAAC,CAAA,SAAD,GAAa;EAlIJ;;;AAoIb;;;;;;;;;0BAQA,mBAAA,GAAqB,SAAC,IAAD,EAAO,OAAP;AACjB,QAAA;IAAA,OAAA,GAAU,WAAW,CAAC,kBAAZ,CAA+B,kBAA/B,CAAkD,CAAC,MAAnD,CAA0D,SAAC,CAAD;aAAO,CAAC,CAAC,KAAK,CAAC;IAAf,CAA1D;AAEV,SAAA,iDAAA;;MACI,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAjB,GAA2B,IAAC,CAAA,eAAgB,CAAA,CAAA;MAC5C,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAjB,GAA2B,IAAC,CAAA,eAAgB,CAAA,CAAA;MAC5C,IAAC,CAAA,gBAAiB,CAAA,MAAA,CAAlB,GAA4B,IAAC,CAAA,gBAAiB,CAAA,CAAA;MAC9C,IAAC,CAAA,aAAc,CAAA,MAAA,CAAf,GAAyB,IAAC,CAAA,aAAc,CAAA,CAAA;AAJ5C;AAMA,WAAO;EATU;;0BAWrB,kBAAA,GAAoB,SAAA;AAChB,QAAA;IAAA,IAAC,CAAA,eAAD,GAAmB;IACnB,IAAC,CAAA,eAAD,GAAmB;IACnB,IAAC,CAAA,gBAAD,GAAoB;IACpB,IAAC,CAAA,aAAD,GAAiB;AAEjB;AAAA,SAAA,6CAAA;;MACI,IAAC,CAAA,eAAgB,CAAA,CAAA,CAAjB,GAA0B,IAAA,KAAA,CAAM,IAAN;MAC1B,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAjB,GAA2B,IAAC,CAAA,eAAgB,CAAA,CAAA;MAC5C,IAAC,CAAA,eAAgB,CAAA,CAAA,CAAjB,GAA0B,IAAA,KAAA,CAAM,IAAN;MAC1B,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAjB,GAA2B,IAAC,CAAA,eAAgB,CAAA,CAAA;MAC5C,IAAC,CAAA,gBAAiB,CAAA,CAAA,CAAlB,GAA2B,IAAA,KAAA,CAAM,IAAN;MAC3B,IAAC,CAAA,gBAAiB,CAAA,MAAA,CAAlB,GAA4B,IAAC,CAAA,gBAAiB,CAAA,CAAA;MAC9C,IAAC,CAAA,aAAc,CAAA,CAAA,CAAf,GAAwB,IAAA,KAAA,CAAM,IAAN;MACxB,IAAC,CAAA,aAAc,CAAA,MAAA,CAAf,GAAyB,IAAC,CAAA,aAAc,CAAA,CAAA;AAR5C;IAUA,IAAC,CAAA,OAAD,GAAW,IAAC,CAAA,eAAgB,CAAA,CAAA;IAC5B,IAAC,CAAA,OAAD,GAAW,IAAC,CAAA,eAAgB,CAAA,CAAA;IAC5B,IAAC,CAAA,QAAD,GAAY,IAAC,CAAA,gBAAiB,CAAA,CAAA;WAC9B,IAAC,CAAA,KAAD,GAAS,IAAC,CAAA,eAAgB,CAAA,CAAA;EAnBV;;0BAqBpB,sBAAA,GAAwB,SAAC,OAAD;AACpB,QAAA;AAAA;AAAA;SAAA,6CAAA;;MACI,IAAC,CAAA,iBAAkB,CAAA,CAAA,CAAnB,GAA4B,IAAA,KAAA,CAAM,EAAN;MAC5B,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAnB,GAA6B,IAAC,CAAA,iBAAkB,CAAA,CAAA;MAChD,IAAC,CAAA,iBAAkB,CAAA,CAAA,CAAnB,GAA4B,IAAA,KAAA,CAAM,EAAN;MAC5B,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAnB,GAA6B,IAAC,CAAA,iBAAkB,CAAA,CAAA;MAChD,IAAC,CAAA,kBAAmB,CAAA,CAAA,CAApB,GAA6B,IAAA,KAAA,CAAM,EAAN;MAC7B,IAAC,CAAA,kBAAmB,CAAA,MAAA,CAApB,GAA8B,IAAC,CAAA,kBAAmB,CAAA,CAAA;MAClD,IAAC,CAAA,eAAgB,CAAA,CAAA,CAAjB,GAA0B,IAAA,KAAA,CAAM,EAAN;mBAC1B,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAjB,GAA2B,IAAC,CAAA,eAAgB,CAAA,CAAA;AARhD;;EADoB;;0BAWxB,YAAA,GAAc,SAAC,OAAD;IACV,IAAC,CAAA,OAAD,GAAW;IACX,IAAC,CAAA,kBAAD,CAAA;WACA,IAAC,CAAA,sBAAD,CAAA;EAHU;;;AAMd;;;;;;;;0BAOA,YAAA,GAAc,SAAC,MAAD;AACV,QAAA;IAAA,IAAC,CAAA,MAAD,GAAU;IACV,eAAA,GAAkB,IAAC,CAAA,uBAAwB,CAAA,MAAA;IAC3C,mBAAA,GAAsB,IAAC,CAAA,2BAA4B,CAAA,MAAA;IAEnD,IAAG,CAAC,eAAJ;MACI,eAAA,GAAkB,IAAC,CAAA,uBAAwB,CAAA,MAAA,CAAzB,GAAmC;QAAE,OAAA,EAAa,IAAA,KAAA,CAAM,GAAN,CAAf;QAA2B,OAAA,EAAa,IAAA,KAAA,CAAM,GAAN,CAAxC;QAAoD,QAAA,EAAc,IAAA,KAAA,CAAM,GAAN,CAAlE;QAA8E,KAAA,EAAW,IAAA,KAAA,CAAM,GAAN,CAAzF;QADzD;;IAEA,IAAG,CAAC,mBAAJ;MACI,mBAAA,GAAsB,IAAC,CAAA,2BAA4B,CAAA,MAAA,CAA7B,GAAuC;QAAE,OAAA,EAAa,IAAA,KAAA,CAAM,GAAN,CAAf;QAA2B,OAAA,EAAa,IAAA,KAAA,CAAM,GAAN,CAAxC;QAAoD,QAAA,EAAc,IAAA,KAAA,CAAM,GAAN,CAAlE;QAA8E,KAAA,EAAW,IAAA,KAAA,CAAM,GAAN,CAAzF;QADjE;;IAGA,IAAC,CAAA,OAAD,GAAW,eAAe,CAAC;IAC3B,IAAC,CAAA,OAAD,GAAW,eAAe,CAAC;IAC3B,IAAC,CAAA,QAAD,GAAY,eAAe,CAAC;IAC5B,IAAC,CAAA,KAAD,GAAS,eAAe,CAAC;IACzB,IAAC,CAAA,iBAAD,GAAqB,mBAAmB,CAAC;IACzC,IAAC,CAAA,kBAAD,GAAsB,mBAAmB,CAAC;IAC1C,IAAC,CAAA,iBAAD,GAAqB,mBAAmB,CAAC;WACzC,IAAC,CAAA,eAAD,GAAmB,mBAAmB,CAAC;EAjB7B;;;AAmBd;;;;;;0BAKA,uBAAA,GAAyB,SAAA;AACrB,QAAA;IAAA,IAAC,CAAA,kBAAD,CAAA;AACA;IAEA,eAAA,GAAkB,IAAC,CAAA,uBAAwB,CAAA,IAAC,CAAA,MAAD;IAC3C,IAAC,CAAA,eAAD,GAAuB,IAAA,KAAA,CAAM,IAAN;IACvB,eAAe,CAAC,QAAhB,GAA+B,IAAA,KAAA,CAAM,IAAN;IAC/B,eAAe,CAAC,OAAhB,GAA8B,IAAA,KAAA,CAAM,IAAN;IAE9B,IAAC,CAAA,OAAD,GAAW,eAAe,CAAC;IAC3B,IAAC,CAAA,OAAD,GAAW,eAAe,CAAC;WAC3B,IAAC,CAAA,QAAD,GAAY,eAAe,CAAC;EAXP;;;AAazB;;;;;;0BAKA,sBAAA,GAAwB,SAAA;IACpB,IAAC,CAAA,YAAD,GAAgB;IAChB,IAAC,CAAA,YAAD,GAAgB;IAChB,IAAC,CAAA,aAAD,GAAiB;WACjB,IAAC,CAAA,UAAD,GAAc;EAJM;;;AAMxB;;;;;;;;;;;;;;;;;;;0BAkBA,cAAA,GAAgB,SAAC,OAAD,EAAU,OAAV,EAAmB,QAAnB,EAA6B,KAA7B,EAAoC,IAApC,EAA0C,KAA1C;AACZ,YAAO,IAAP;AAAA,WACS,CADT;;UAEQ,OAAO,CAAE,IAAT,CAAc,CAAd,EAAiB,KAAK,CAAC,KAAvB,EAA8B,KAAK,CAAC,GAApC;;;UACA,OAAO,CAAE,IAAT,CAAc,EAAd,EAAkB,KAAK,CAAC,KAAxB,EAA+B,KAAK,CAAC,GAArC;;;UACA,QAAQ,CAAE,IAAV,CAAe,KAAf,EAAsB,KAAK,CAAC,KAA5B,EAAmC,KAAK,CAAC,GAAzC;;+BACA,KAAK,CAAE,IAAP,CAAY,EAAZ,EAAgB,KAAK,CAAC,KAAtB,EAA6B,KAAK,CAAC,GAAnC;AALR,WAMS,CANT;kCAOQ,QAAQ,CAAE,IAAV,CAAe,KAAf,EAAsB,KAAK,CAAC,KAA5B,EAAmC,KAAK,CAAC,GAAzC;AAPR,WAQS,CART;iCASQ,OAAO,CAAE,IAAT,CAAc,CAAd,EAAiB,KAAK,CAAC,KAAvB,EAA8B,KAAK,CAAC,GAApC;AATR,WAUS,CAVT;iCAWQ,OAAO,CAAE,IAAT,CAAc,EAAd,EAAkB,KAAK,CAAC,KAAxB,EAA+B,KAAK,CAAC,GAArC;AAXR,WAYS,CAZT;+BAaQ,KAAK,CAAE,IAAP,CAAY,EAAZ,EAAgB,KAAK,CAAC,KAAtB,EAA6B,KAAK,CAAC,GAAnC;AAbR;EADY;;;AAgBhB;;;;;;;;;;;;;;;;;0BAgBA,mBAAA,GAAqB,SAAC,OAAD,EAAU,IAAV,EAAgB,KAAhB;AACjB,QAAA;IAAA,IAAG,eAAH;MACI,GAAA,GAAM,CAAC,OAAO,CAAC,EAAT,EADV;KAAA,MAAA;MAGI,GAAA,GAAM,MAAM,CAAC,IAAP,CAAY,IAAC,CAAA,YAAb,EAHV;;IAKA,IAAG,aAAH;MACI,KAAA,GAAQ;QAAA,KAAA,EAAO,KAAK,CAAC,KAAb;QAAoB,GAAA,EAAK,KAAK,CAAC,GAAN,GAAY,CAArC;QADZ;KAAA,MAAA;MAGI,KAAA,GAAQ;QAAA,KAAA,EAAO,CAAP;QAAU,GAAA,EAAK,IAAf;QAHZ;;AAKA;SAAA,qCAAA;;mBACI,IAAC,CAAA,cAAD,CAAgB,IAAC,CAAA,YAAa,CAAA,EAAA,CAA9B,EAAmC,IAAC,CAAA,YAAa,CAAA,EAAA,CAAjD,EAAsD,IAAC,CAAA,aAAc,CAAA,EAAA,CAArE,EAA0E,IAAC,CAAA,UAAW,CAAA,EAAA,CAAtF,EAA2F,IAA3F,EAAiG,KAAjG;AADJ;;EAXiB;;;AAcrB;;;;;;;;;;;;;;;0BAcA,oBAAA,GAAsB,SAAC,IAAD,EAAO,KAAP;IAClB,IAAG,aAAH;MACI,KAAA,GAAQ;QAAA,KAAA,EAAO,KAAK,CAAC,KAAb;QAAoB,GAAA,EAAK,KAAK,CAAC,GAAN,GAAY,CAArC;QADZ;KAAA,MAAA;MAGI,KAAA,GAAQ;QAAA,KAAA,EAAO,CAAP;QAAU,GAAA,EAAK,IAAf;QAHZ;;WAKA,IAAC,CAAA,cAAD,CAAgB,IAAC,CAAA,OAAjB,EAA0B,IAAC,CAAA,OAA3B,EAAoC,IAAC,CAAA,QAArC,EAA+C,IAAC,CAAA,KAAhD,EAAuD,IAAvD,EAA6D,KAA7D;EANkB;;;AAQtB;;;;;;;;;;;;;;;0BAcA,wBAAA,GAA0B,SAAC,IAAD,EAAO,KAAP;IACtB,IAAG,aAAH;MACI,KAAA,GAAQ;QAAA,KAAA,EAAO,KAAK,CAAC,KAAb;QAAoB,GAAA,EAAK,KAAK,CAAC,GAAN,GAAY,CAArC;QADZ;KAAA,MAAA;MAGI,KAAA,GAAQ;QAAA,KAAA,EAAO,CAAP;QAAU,GAAA,EAAK,IAAf;QAHZ;;WAKA,IAAC,CAAA,cAAD,CAAgB,IAAC,CAAA,iBAAjB,EAAoC,IAAC,CAAA,iBAArC,EAAwD,IAAC,CAAA,kBAAzD,EAA6E,IAAC,CAAA,eAA9E,EAA+F,IAA/F,EAAqG,KAArG;EANsB;;;AAQ1B;;;;;;;0BAMA,KAAA,GAAO,SAAC,OAAD;IACH,IAAC,CAAA,mBAAD,CAAqB,OAArB;WACA,IAAC,CAAA,kBAAD,CAAoB,OAApB;EAFG;;;AAKP;;;;;;;0BAMA,mBAAA,GAAqB,SAAC,OAAD;IACjB,IAAC,CAAA,cAAD,CAAgB,OAAhB,EAAyB,cAAzB,EAAyC,CAAzC;IACA,IAAC,CAAA,cAAD,CAAgB,OAAhB,EAAyB,cAAzB,EAAyC,EAAzC;IACA,IAAC,CAAA,cAAD,CAAgB,OAAhB,EAAyB,eAAzB,EAA0C,KAA1C;WACA,IAAC,CAAA,cAAD,CAAgB,OAAhB,EAAyB,YAAzB,EAAuC,EAAvC;EAJiB;;;AAMrB;;;;;;;;;0BAQA,cAAA,GAAgB,SAAC,OAAD,EAAU,QAAV,EAAoB,YAApB;IACZ,IAAO,kCAAP;aACI,IAAK,CAAA,QAAA,CAAU,CAAA,OAAO,CAAC,EAAR,CAAf,GAA6B,GADjC;;EADY;;;AAKhB;;;;;;;0BAMA,kBAAA,GAAoB,SAAC,OAAD;IAChB,IAAC,CAAA,OAAD,GAAW;IACX,IAAG,CAAC,IAAC,CAAA,YAAa,CAAA,OAAO,CAAC,EAAR,CAAlB;MACI,IAAC,CAAA,mBAAD,CAAqB,OAArB,EADJ;;IAGA,IAAC,CAAA,WAAD,GAAe,IAAC,CAAA,YAAa,CAAA,OAAO,CAAC,EAAR;IAC7B,IAAC,CAAA,WAAD,GAAe,IAAC,CAAA,YAAa,CAAA,OAAO,CAAC,EAAR;IAC7B,IAAC,CAAA,YAAD,GAAgB,IAAC,CAAA,aAAc,CAAA,OAAO,CAAC,EAAR;WAC/B,IAAC,CAAA,SAAD,GAAa,IAAC,CAAA,UAAW,CAAA,OAAO,CAAC,EAAR;EART;;0BAUpB,kBAAA,GAAoB,SAAC,OAAD,GAAA;;;AAGpB;;;;;;;;;;;0BAUA,eAAA,GAAiB,SAAC,IAAD,EAAO,IAAP,EAAa,KAAb,EAAoB,MAApB;AACb,QAAA;IAAA,MAAA,GAAS;AAET,YAAO,KAAP;AAAA,WACS,CADT;QAEQ,MAAA,GAAS,IAAC,CAAA,mBAAD,CAAqB,IAArB,EAA2B,IAA3B;AADR;AADT,WAGS,CAHT;QAIQ,MAAA,GAAS,IAAC,CAAA,qBAAD,CAAuB,IAAvB,EAA6B,IAA7B,EAAmC,MAAnC;AADR;AAHT,WAKS,CALT;QAMQ,MAAA,GAAS,IAAC,CAAA,yBAAD,CAA2B,IAA3B,EAAiC,IAAjC,EAAuC,MAAvC;AANjB;AAQA,WAAO;EAXM;;;AAajB;;;;;;;;;0BAQA,mBAAA,GAAqB,SAAC,IAAD,EAAO,IAAP;AACjB,QAAA;IAAA,MAAA,GAAS;IAET,sCAAW,CAAE,cAAb;MACI,IAAG,IAAC,CAAA,OAAO,CAAC,KAAK,CAAC,aAAlB;QACI,QAAA,GAAW,IAAC,CAAA,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,KAAM,CAAA,IAAA,GAAO,WAAP,CAAmB,CAAC,KAAvD,CAA6D,SAAC,CAAD;iBAAO,CAAC,CAAC,IAAF,KAAU;QAAjB,CAA7D;QACX,IAA2B,gBAA3B;UAAA,MAAA,GAAS,QAAQ,CAAC,MAAlB;SAFJ;OAAA,MAGK,IAAG,IAAC,CAAA,OAAO,CAAC,KAAM,CAAA,IAAA,GAAO,WAAP,CAAlB;QACD,QAAA,GAAW,IAAC,CAAA,OAAO,CAAC,KAAM,CAAA,IAAA,GAAO,WAAP,CAAmB,CAAC,KAAnC,CAAyC,SAAC,CAAD;iBAAO,CAAC,CAAC,IAAF,KAAU;QAAjB,CAAzC;QAEX,IAAG,gBAAH;UACI,MAAA,GAAS,QAAQ,CAAC,MADtB;SAAA,MAAA;UAGI,OAAO,CAAC,IAAR,CAAa,yCAAA,GAA4C,IAAA,CAAK,CAAC,UAAD,GAAY,IAAZ,GAAiB,GAAtB,CAAzD,EAHJ;SAHC;OAJT;;AAYA,WAAO;EAfU;;;AAiBrB;;;;;;;;;;0BASA,qBAAA,GAAuB,SAAC,IAAD,EAAO,IAAP,EAAa,MAAb;AACnB,QAAA;IAAA,MAAA,GAAS;IACT,SAAA,GAAY,WAAW,CAAC,kBAAZ,CAA+B,kBAA/B;IACZ,iBAAA,GAAoB,SAAS,CAAC,KAAV,CAAgB,SAAC,CAAD;aAAO,CAAC,CAAC,KAAK,CAAC,MAAR,KAAkB;IAAzB,CAAhB;;MACpB,oBAAqB,SAAU,CAAA,CAAA;;IAE/B,IAAG,iBAAH;MACI,QAAA,GAAW,iBAAiB,CAAC,KAAM,CAAA,IAAA,GAAO,GAAP,CAAW,CAAC,KAApC,CAA0C,SAAC,CAAD;eAAO,CAAC,CAAC,IAAF,KAAU;MAAjB,CAA1C;MACX,IAAG,QAAH;QACI,MAAA,GAAS,QAAQ,CAAC,MADtB;OAAA,MAAA;QAGI,OAAO,CAAC,IAAR,CAAa,yCAAA,GAA0C,IAA1C,GAA+C,gBAA/C,GAA+D,IAA/D,GAAoE,GAAjF,EAHJ;OAFJ;;AAOA,WAAO;EAbY;;;AAevB;;;;;;;;;;0BASA,yBAAA,GAA2B,SAAC,IAAD,EAAO,IAAP,EAAa,MAAb;AACvB,QAAA;IAAA,MAAA,GAAS;IACT,SAAA,GAAY,WAAW,CAAC,kBAAZ,CAA+B,sBAA/B;IACZ,iBAAA,GAAoB,SAAS,CAAC,KAAV,CAAgB,SAAC,CAAD;aAAO,CAAC,CAAC,KAAK,CAAC,MAAR,KAAkB;IAAzB,CAAhB;;MACpB,oBAAqB,SAAU,CAAA,CAAA;;IAE/B,IAAG,iBAAH;MACI,QAAA,GAAW,iBAAiB,CAAC,KAAM,CAAA,IAAA,GAAO,GAAP,CAAW,CAAC,KAApC,CAA0C,SAAC,CAAD;eAAO,CAAC,CAAC,IAAF,KAAU;MAAjB,CAA1C;MACX,IAAG,gBAAH;QACI,MAAA,GAAS,QAAQ,CAAC,MADtB;OAAA,MAAA;QAGI,OAAO,CAAC,IAAR,CAAa,yCAAA,GAA0C,IAA1C,GAA+C,gBAA/C,GAA+D,IAA/D,GAAoE,GAAjF,EAHJ;OAFJ;;AAOA,WAAO;EAbgB;;;AAe3B;;;;;;;;;0BAQA,qBAAA,GAAuB,SAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,MAAtB;IACnB,IAAG,KAAA,KAAS,CAAZ;aACI,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAA3B,GAAoC,MADxC;KAAA,MAEK,IAAG,KAAA,KAAS,CAAZ;aACD,IAAC,CAAA,eAAgB,CAAA,MAAA,IAAQ,CAAR,CAAW,CAAA,KAAA,CAA5B,GAAqC,MADpC;KAAA,MAAA;aAGD,IAAC,CAAA,WAAY,CAAA,KAAA,CAAb,GAAsB,MAHrB;;EAHc;;;AAQvB;;;;;;;;0BAOA,gBAAA,GAAkB,SAAC,QAAD,EAAW,KAAX;IACd,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACI,IAAC,CAAA,iBAAkB,CAAA,QAAQ,CAAC,MAAT,IAAiB,CAAjB,CAAoB,CAAA,QAAQ,CAAC,KAAT,CAAvC,GAAyD,MAD7D;KAAA,MAEK,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACD,IAAC,CAAA,eAAgB,CAAA,QAAQ,CAAC,MAAT,IAAiB,CAAjB,CAAoB,CAAA,QAAQ,CAAC,KAAT,CAArC,GAAuD,MADtD;KAAA,MAAA;aAGD,IAAC,CAAA,WAAY,CAAA,QAAQ,CAAC,KAAT,CAAb,GAA+B,MAH9B;;EAHS;;;AAQlB;;;;;;;;0BAOA,eAAA,GAAiB,SAAC,QAAD,EAAW,KAAX;IACb,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACI,IAAC,CAAA,eAAgB,CAAA,QAAQ,CAAC,MAAT,IAAiB,CAAjB,CAAoB,CAAA,QAAQ,CAAC,KAAT,CAArC,GAAuD,MAD3D;KAAA,MAEK,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACD,IAAC,CAAA,aAAc,CAAA,QAAQ,CAAC,MAAT,IAAiB,CAAjB,CAAoB,CAAA,QAAQ,CAAC,KAAT,CAAnC,GAAqD,MADpD;KAAA,MAAA;aAGD,IAAC,CAAA,SAAU,CAAA,QAAQ,CAAC,KAAT,CAAX,GAA6B,MAH5B;;EAHQ;;;AASjB;;;;;;;;0BAOA,iBAAA,GAAmB,SAAC,QAAD,EAAW,KAAX;IACf,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACI,IAAC,CAAA,kBAAmB,CAAA,QAAQ,CAAC,MAAT,CAAiB,CAAA,QAAQ,CAAC,KAAT,CAArC,GAAuD,MAD3D;KAAA,MAEK,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACD,IAAC,CAAA,gBAAiB,CAAA,QAAQ,CAAC,MAAT,CAAiB,CAAA,QAAQ,CAAC,KAAT,CAAnC,GAAqD,MADpD;KAAA,MAAA;aAGD,IAAC,CAAA,YAAa,CAAA,QAAQ,CAAC,KAAT,CAAd,GAAgC,MAH/B;;EAHU;;;AAQnB;;;;;;;;;0BAQA,sBAAA,GAAwB,SAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,MAAtB;IACpB,IAAG,KAAA,KAAS,CAAZ;aACI,IAAC,CAAA,kBAAmB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAA5B,GAAqC,MADzC;KAAA,MAEK,IAAG,KAAA,KAAS,CAAZ;aACD,IAAC,CAAA,gBAAiB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAA1B,GAAmC,MADlC;KAAA,MAAA;aAGD,IAAC,CAAA,YAAa,CAAA,KAAA,CAAd,GAAuB,MAHtB;;EAHe;;;AAQxB;;;;;;;;0BAOA,gBAAA,GAAkB,SAAC,QAAD,EAAW,KAAX;IACd,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACI,IAAC,CAAA,iBAAkB,CAAA,QAAQ,CAAC,MAAT,CAAiB,CAAA,QAAQ,CAAC,KAAT,CAApC,GAAsD,MAD1D;KAAA,MAEK,IAAG,QAAQ,CAAC,KAAT,KAAkB,CAArB;aACD,IAAC,CAAA,eAAgB,CAAA,QAAQ,CAAC,MAAT,CAAiB,CAAA,QAAQ,CAAC,KAAT,CAAlC,GAAoD,MADnD;KAAA,MAAA;aAGD,IAAC,CAAA,WAAY,CAAA,QAAQ,CAAC,KAAT,CAAb,GAA+B,MAH9B;;EAHS;;;AAQlB;;;;;;;;;0BAQA,qBAAA,GAAuB,SAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,MAAtB;IACnB,IAAG,KAAA,KAAS,CAAZ;aACI,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAA3B,GAAoC,MADxC;KAAA,MAEK,IAAG,KAAA,KAAS,CAAZ;aACD,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAAzB,GAAkC,MADjC;KAAA,MAAA;aAGD,IAAC,CAAA,WAAY,CAAA,KAAA,CAAb,GAAsB,MAHrB;;EAHc;;;AAQvB;;;;;;;;0BAOA,YAAA,GAAc,SAAC,MAAD;AACV,QAAA;IAAA,MAAA,GAAS;IACT,IAAG,gBAAA,IAAY,sBAAf;MACI,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACI,MAAA,GAAS,IAAC,CAAA,eAAgB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,EAD7C;OAAA,MAEK,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACD,MAAA,GAAS,IAAC,CAAA,aAAc,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,EADtC;OAAA,MAAA;QAGD,MAAA,GAAS,IAAC,CAAA,SAAU,CAAA,MAAM,CAAC,KAAP,EAHnB;OAHT;KAAA,MAAA;MAQI,MAAA,GAAS,OARb;;AAUA,WAAO,MAAA,IAAU;EAZP;;;AAcd;;;;;;;;;0BAQA,kBAAA,GAAoB,SAAC,KAAD,EAAQ,KAAR,EAAe,MAAf;AAChB,QAAA;IAAA,MAAA,GAAS;IAET,IAAG,KAAA,KAAS,CAAZ;MACI,MAAA,GAAS,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAQ,CAAA,KAAA,EADxC;KAAA,MAEK,IAAG,KAAA,KAAS,CAAZ;MACD,MAAA,GAAS,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAQ,CAAA,KAAA,EADjC;KAAA,MAAA;MAGD,MAAA,GAAS,IAAC,CAAA,WAAY,CAAA,KAAA,EAHrB;;AAKL,WAAO;EAVS;;;AAYpB;;;;;;;;0BAOA,aAAA,GAAe,SAAC,MAAD;AACX,QAAA;IAAA,MAAA,GAAS;IACT,IAAG,gBAAA,IAAY,sBAAf;MACI,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACI,MAAA,GAAS,IAAC,CAAA,iBAAkB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,EAD/C;OAAA,MAEK,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACD,MAAA,GAAS,IAAC,CAAA,eAAgB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,EADxC;OAAA,MAAA;QAGD,MAAA,GAAS,IAAC,CAAA,WAAY,CAAA,MAAM,CAAC,KAAP,EAHrB;OAHT;KAAA,MAAA;MASI,MAAA,GAAS,OATb;;AAWA,WAAO,MAAA,IAAU;EAbN;;;AAef;;;;;;;;0BAOA,aAAA,GAAe,SAAC,MAAD;AACX,QAAA;IAAA,MAAA,GAAS;IACT,IAAG,gBAAA,IAAY,sBAAf;MACI,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACI,MAAA,GAAS,IAAC,CAAA,iBAAkB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,EAD/C;OAAA,MAEK,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACD,MAAA,GAAS,IAAC,CAAA,eAAgB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,EADxC;OAAA,MAAA;QAGD,MAAA,GAAS,IAAC,CAAA,WAAY,CAAA,MAAM,CAAC,KAAP,EAHrB;OAHT;KAAA,MAAA;MAQI,MAAA,GAAS,OARb;;AAUA,WAAO,MAAA,IAAU;EAZN;;;AAcf;;;;;;;;;0BAQA,kBAAA,GAAoB,SAAC,KAAD,EAAQ,KAAR,EAAe,MAAf;AAChB,QAAA;IAAA,MAAA,GAAS;IAET,IAAG,KAAA,KAAS,CAAZ;MACI,MAAA,GAAS,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAQ,CAAA,KAAA,EADxC;KAAA,MAEK,IAAG,KAAA,KAAS,CAAZ;MACD,MAAA,GAAS,IAAC,CAAA,eAAgB,CAAA,MAAA,CAAQ,CAAA,KAAA,EADjC;KAAA,MAAA;MAGD,MAAA,GAAS,IAAC,CAAA,WAAY,CAAA,KAAA,EAHrB;;AAKL,WAAO,MAAA,IAAU;EAVD;;;AAYpB;;;;;;;;0BAOA,cAAA,GAAgB,SAAC,MAAD;AACZ,QAAA;IAAA,MAAA,GAAS;IACT,IAAG,gBAAA,IAAY,sBAAf;MACI,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACI,MAAA,GAAS,IAAC,CAAA,kBAAmB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,CAAnC,IAAoD,MADjE;OAAA,MAEK,IAAG,MAAM,CAAC,KAAP,KAAgB,CAAnB;QACD,MAAA,GAAS,IAAC,CAAA,gBAAiB,CAAA,MAAM,CAAC,MAAP,CAAe,CAAA,MAAM,CAAC,KAAP,CAAjC,IAAkD,MAD1D;OAAA,MAAA;QAGD,MAAA,GAAS,IAAC,CAAA,YAAa,CAAA,MAAM,CAAC,KAAP,CAAd,IAA+B,MAHvC;OAHT;KAAA,MAAA;MASI,MAAA,GAAY,MAAH,GAAe,IAAf,GAAyB,MATtC;;AAWA,WAAO;EAbK;;;AAehB;;;;;;;;;0BAQA,mBAAA,GAAqB,SAAC,KAAD,EAAQ,KAAR,EAAe,MAAf;AACjB,QAAA;IAAA,MAAA,GAAS;IAET,IAAG,KAAA,KAAS,CAAZ;MACI,MAAA,GAAS,IAAC,CAAA,iBAAkB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAA3B,IAAqC,MADlD;KAAA,MAEK,IAAG,KAAA,KAAS,CAAZ;MACD,MAAA,GAAS,IAAC,CAAA,gBAAiB,CAAA,MAAA,CAAQ,CAAA,KAAA,CAA1B,IAAoC,MAD5C;KAAA,MAAA;MAGD,MAAA,GAAS,IAAC,CAAA,YAAa,CAAA,KAAA,CAAd,IAAwB,MAHhC;;AAKL,WAAO;EAVU;;;;;;AAYzB,EAAE,CAAC,aAAH,GAAmB","sourcesContent":["# ===================================================================\n#\n#   Script: VariableStore\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass VariableStore\n    @objectCodecBlackList = [\"persistentNumbers\", \"persistentStrings\", \"persistentBooleans\", \"persistentLists\"]\n    \n    ###*\n    * <p>A storage for different kind of game variables. The following scopes\n    * for variables exist:</p>\n    * \n    * - Local Variables -> Only valid for the current scene.\n    * - Global Variables -> Valid for the whole game but bound to a single save-game.\n    * - Persistent Variables -> Valid for the whole game indepentent from the save-games.\n    * \n    * <p>The following data-types exist:</p>\n    * - Strings -> Variables storing text data.\n    * - Numbers -> Variables storing integer number values.\n    * - Booleans -> Variables storing boolean values. (Called \"Switches\" for easier understanding)\n    * - Lists -> Variables storing multiple other variables. Lists can also contain Lists.\n    * <p>\n    * Local variables are stored by scene UID. For each scene UID a list of local variables is stored.</p>\n    * \n    * <p>Global and persistent variables are stored and a specific domain. A domain is just a unique name such\n    * as <i>com.example.game</i> for example. The default domain is an empty string. Domains are useful to avoid\n    * overlapping of variable numbers when sharing content with other users. </p>\n    *\n    * @module gs\n    * @class VariableStore\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: () ->\n        ###*\n        * Current local variable context\n        * @property context\n        * @type Object\n        ###\n        @context = null\n        \n        ###*\n        * Current domain for global and persistent variables. Each domain has its own\n        * variables. Please use <b>changeDomain</b> method to change the domain.\n        * @property domain\n        * @type Object\n        * @readOnly\n        ###\n        @domain = \"\"\n        \n        ###*\n        * List of available domains for global and persistent variables.\n        * @property domains\n        * @type string[]\n        ###\n        @domains = [\"\"]\n        \n        ###*\n        * The global number variables of the current domain.\n        * @property numbers\n        * @type number[]\n        ###\n        @numbers = null\n        ###*\n        * The global boolean variables of the current domain.\n        * @property booleans\n        * @type boolean[]\n        ###\n        @booleans = null\n        ###*\n        * The global string variables of the current domain.\n        * @property strings\n        * @type string[]\n        ###\n        @strings = null\n        ###*\n        * The global list variables of the current domain.\n        * @property lists\n        * @type Object[][]\n        ###\n        @lists = null\n        \n        ###*\n        * The storage of all global variables by domain.\n        * @property globalVariablesByDomain\n        * @type Object[][]\n        ###\n        @globalVariablesByDomain = {}\n        \n        ###*\n        * The storage of all persistent variables by domain.\n        * @property persistentVariablesByDomain\n        * @type Object[][]\n        ###\n        @persistentVariablesByDomain = {}\n        \n        ###*\n        * The persistent number variables of the current domain.\n        * @property persistentNumbers\n        * @type number[]\n        ###\n        @persistentNumbers = []\n        ###*\n        * The persistent string variables of the current domain.\n        * @property persistentStrings\n        * @type string[]\n        ###\n        @persistentStrings = []\n        ###*\n        * The persistent boolean variables of the current domain.\n        * @property persistentBooleans\n        * @type boolean[]\n        ###\n        @persistentBooleans = []\n        ###*\n        * The persistent list variables of the current domain.\n        * @property persistentLists\n        * @type Object[][]\n        ###\n        @persistentLists = []\n        ###*\n        * The local number variables.\n        * @property localNumbers\n        * @type Object\n        ###\n        @localNumbers = {}\n        ###*\n        * The local string variables.\n        * @property localStrings\n        * @type Object\n        ###\n        @localStrings = {}\n        ###*\n        * The local boolean variables.\n        * @property localBooleans\n        * @type Object\n        ###\n        @localBooleans = {}\n        ###*\n        * The local list variables.\n        * @property localLists\n        * @type Object\n        ###\n        @localLists = {}\n        ###*\n        * @property tempNumbers\n        * @type number[]\n        ###\n        @tempNumbers = null\n        ###*\n        * @property tempStrings\n        * @type string[]\n        ###\n        @tempStrings = null\n        ###*\n        * @property localBooleans\n        * @type number[]\n        ###\n        @tempBooleans = null\n        ###*\n        * @property localLists\n        * @type Object[][]\n        ###\n        @tempLists = null\n        \n    ###*\n    * Called if this object instance is restored from a data-bundle. It can be used\n    * re-assign event-handler, anonymous functions, etc.\n    * \n    * @method onDataBundleRestore.\n    * @param Object data - The data-bundle\n    * @param gs.ObjectCodecContext context - The codec-context.\n    ###\n    onDataBundleRestore: (data, context) ->\n        domains = DataManager.getDocumentsByType(\"global_variables\").select (d) -> d.items.domain\n        \n        for domain, i in domains\n            @numbersByDomain[domain] = @numbersByDomain[i]\n            @stringsByDomain[domain] = @stringsByDomain[i]\n            @booleansByDomain[domain] = @booleansByDomain[i]\n            @listsByDomain[domain] = @listsByDomain[i]\n                \n        return null\n     \n    setupGlobalDomains: () ->\n        @numbersByDomain = []\n        @stringsByDomain = []\n        @booleansByDomain = []\n        @listsByDomain = []\n        \n        for domain, i in @domains\n            @numbersByDomain[i] = new Array(1000)\n            @numbersByDomain[domain] = @numbersByDomain[i]\n            @stringsByDomain[i] = new Array(1000)\n            @stringsByDomain[domain] = @stringsByDomain[i]\n            @booleansByDomain[i] = new Array(1000)\n            @booleansByDomain[domain] = @booleansByDomain[i]\n            @listsByDomain[i] = new Array(1000)\n            @listsByDomain[domain] = @listsByDomain[i]\n            \n        @numbers = @numbersByDomain[0]\n        @strings = @stringsByDomain[0]\n        @booleans = @booleansByDomain[0]\n        @lists = @numbersByDomain[0]\n        \n    setupPersistentDomains: (domains) ->\n        for domain, i in @domains\n            @persistentNumbers[i] = new Array(10)\n            @persistentNumbers[domain] = @persistentNumbers[i]\n            @persistentStrings[i] = new Array(10)\n            @persistentStrings[domain] = @persistentStrings[i]\n            @persistentBooleans[i] = new Array(10)\n            @persistentBooleans[domain] = @persistentBooleans[i]\n            @persistentLists[i] = new Array(10)\n            @persistentLists[domain] = @persistentLists[i]\n            \n    setupDomains: (domains) ->\n        @domains = domains\n        @setupGlobalDomains()\n        @setupPersistentDomains()\n        \n            \n    ###*\n    * Changes the current domain.\n    *\n    * @deprecated\n    * @method changeDomain\n    * @param {string} domain - The domain to change to.\n    ### \n    changeDomain: (domain) ->\n        @domain = domain\n        globalVariables = @globalVariablesByDomain[domain]\n        persistentVariables = @persistentVariablesByDomain[domain]\n        \n        if !globalVariables\n            globalVariables = @globalVariablesByDomain[domain] = { numbers: new Array(500), strings: new Array(500), booleans: new Array(500), lists: new Array(500) }\n        if !persistentVariables\n            persistentVariables = @persistentVariablesByDomain[domain] = { numbers: new Array(500), strings: new Array(500), booleans: new Array(500), lists: new Array(500) }    \n        \n        @numbers = globalVariables.numbers\n        @strings = globalVariables.strings\n        @booleans = globalVariables.booleans\n        @lists = globalVariables.lists\n        @persistentNumbers = persistentVariables.numbers\n        @persistentBooleans = persistentVariables.booleans\n        @persistentStrings = persistentVariables.strings\n        @persistentLists = persistentVariables.lists\n        \n    ###*\n    * Clears all global variables\n    *\n    * @method clearGlobalVariables\n    ### \n    clearAllGlobalVariables: ->\n        @setupGlobalDomains()\n        return\n        \n        globalVariables = @globalVariablesByDomain[@domain]\n        @numbersByDomain = new Array(1000)\n        globalVariables.booleans = new Array(1000)\n        globalVariables.strings = new Array(1000)\n    \n        @numbers = globalVariables.numbers\n        @strings = globalVariables.strings\n        @booleans = globalVariables.booleans\n    \n    ###*\n    * Clears all local variables for all contexts/scenes/common-events.\n    *\n    * @method clearAllLocalVariables\n    ### \n    clearAllLocalVariables: ->\n        @localNumbers = {}\n        @localStrings = {}\n        @localBooleans = {}\n        @localLists = {}\n     \n    ###*\n    * Clears specified variables.\n    *\n    * @method clearVariables\n    * @param {number[]} numbers - The number variables to clear.\n    * @param {string[]} strings - The string variables to clear.\n    * @param {boolean[]} booleans - The boolean variables to clear.\n    * @param {Array[]} lists - The list variables to clear.\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all specified variables are cleared.\n    ###  \n    clearVariables: (numbers, strings, booleans, lists, type, range) ->\n        switch type\n            when 0 # All\n                numbers?.fill(0, range.start, range.end)\n                strings?.fill(\"\", range.start, range.end)\n                booleans?.fill(false, range.start, range.end)\n                lists?.fill([], range.start, range.end)\n            when 1 # Switch\n                booleans?.fill(false, range.start, range.end)\n            when 2 # Number\n                numbers?.fill(0, range.start, range.end)\n            when 3 # Text\n                strings?.fill(\"\", range.start, range.end)\n            when 4 # List\n                lists?.fill([], range.start, range.end)\n                \n    ###*\n    * Clears all local variables for a specified context. If the context is not specified, all\n    * local variables for all contexts/scenes/common-events are cleared.\n    *\n    * @method clearLocalVariables\n    * @param {Object} context - The context to clear the local variables for. If <b>null</b>, all\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n    ###  \n    clearLocalVariables: (context, type, range) ->\n        if context?\n            ids = [context.id]\n        else\n            ids = Object.keys(@localNumbers)\n            \n        if range?\n            range = start: range.start, end: range.end + 1\n        else\n            range = start: 0, end: null\n            \n        for id in ids\n            @clearVariables(@localNumbers[id], @localStrings[id], @localBooleans[id], @localLists[id], type, range)\n \n    ###*\n    * Clears global variables.\n    *\n    * @method clearGlobalVariables\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n    ### \n    clearGlobalVariables: (type, range) ->\n        if range?\n            range = start: range.start, end: range.end + 1\n        else\n            range = start: 0, end: null\n            \n        @clearVariables(@numbers, @strings, @booleans, @lists, type, range)\n        \n    ###*\n    * Clears persistent variables.\n    *\n    * @method clearPersistentVariables\n    * @param {number} type - Determines what kind of variables should be cleared.\n    * <ul>\n    * <li>0 = All</li>\n    * <li>1 = Switches / Booleans</li>\n    * <li>2 = Numbers</li>\n    * <li>3 = Texts</li>\n    * <li>4 = Lists</li>\n    * </ul>\n    * @param {Object} range - The variable id-range to clear. If <b>null</b> all variables are cleared.\n    ### \n    clearPersistentVariables: (type, range) ->\n        if range?\n            range = start: range.start, end: range.end + 1\n        else\n            range = start: 0, end: null\n            \n        @clearVariables(@persistentNumbers, @persistentstrings, @persistentBooleans, @persistentLists, type, range)\n        \n    ###*\n    * Initializes the variables. Should be called whenever the context changes. (Like after a scene change)\n    *\n    * @method setup\n    * @param {Object} context - The context(current scene) needed for local variables. Needs have at least an id-property.\n    ###     \n    setup: (context) ->\n        @setupLocalVariables(context)\n        @setupTempVariables(context)\n    \n    \n    ###*\n    * Initializes the local variables for the specified context. Should be called on first time use.\n    *\n    * @method setupLocalVariables\n    * @param {Object} context - The context(current scene). Needs have at least an id-property.\n    ###\n    setupLocalVariables: (context) ->\n        @setupVariables(context, \"localNumbers\", 0)\n        @setupVariables(context, \"localStrings\", \"\")\n        @setupVariables(context, \"localBooleans\", no)\n        @setupVariables(context, \"localLists\", [])\n        \n    ###*\n    * Initializes the specified kind of variables.\n    *\n    * @method setupVariables                                       \n    * @param {Object} context - The context(current scene). Needs have at least an id-property.\n    * @param {string} property - The kind of variables (property-name).\n    * @param {Object} defaultValue - The default value for each variable.\n    ###  \n    setupVariables: (context, property, defaultValue) ->\n        if not this[property][context.id]?\n            this[property][context.id] = []\n    \n    \n    ###*\n    * Initializes the current temp variables for the specified context. Should be called whenever the context changed.\n    *\n    * @method setupTempVariables\n    * @param {Object} context - The context(current scene). Needs have at least an id-property.\n    ###    \n    setupTempVariables: (context) ->\n        @context = context\n        if !@localNumbers[context.id]\n            @setupLocalVariables(context)\n            \n        @tempNumbers = @localNumbers[context.id]\n        @tempStrings = @localStrings[context.id]\n        @tempBooleans = @localBooleans[context.id]\n        @tempLists = @localLists[context.id]\n        \n    clearTempVariables: (context) ->\n        \n    \n    ###*\n    * Gets the index for the variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    * @param {number} scope - The variable scope: 0 = local, 1 = global, 2 = persistent.\n    * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n    ###  \n    indexOfVariable: (name, type, scope, domain) ->\n        result = 0\n        \n        switch scope\n            when 0 # Local\n                result = @indexOfTempVariable(name, type)\n            when 1 # Global\n                result = @indexOfGlobalVariable(name, type, domain)\n            when 2 # Persistent\n                result = @indexOfPersistentVariable(name, type, domain)\n            \n        return result\n        \n    ###*\n    * Gets the index for the local variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    ###  \n    indexOfTempVariable: (name, type) ->\n        result = 0\n        \n        if @context?.owner\n            if @context.owner.sceneDocument\n                variable = @context.owner.sceneDocument.items[type + \"Variables\"].first (v) -> v.name == name\n                result = variable.index if variable?\n            else if @context.owner[type + \"Variables\"]\n                variable = @context.owner[type + \"Variables\"].first (v) -> v.name == name\n                \n                if variable?\n                    result = variable.index\n                else\n                    console.warn(\"Variable referenced by name not found: \" + name +\"(local, \"+type+\")\")\n                    \n        return result\n        \n    ###*\n    * Gets the index for the global variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n    ###  \n    indexOfGlobalVariable: (name, type, domain) ->\n        result = 0\n        variables = DataManager.getDocumentsByType(\"global_variables\")\n        variablesDocument = variables.first (v) -> v.items.domain == domain\n        variablesDocument ?= variables[0]\n        \n        if variablesDocument\n            variable = variablesDocument.items[type + \"s\"].first (v) -> v.name == name\n            if variable\n                result = variable.index \n            else\n                console.warn(\"Variable referenced by name not found: #{name} (persistent, #{type})\")\n        \n        return result\n    \n    ###*\n    * Gets the index for the persistent variable with the specified name. If a variable with that\n    * name cannot be found, the index will be 0.\n    *\n    * @method indexOfTempVariable\n    * @param {string} name - The name of the variable to get the index for.\n    * @param {string} type - The type name: number, string, boolean or list.\n    * @param {string} domain - The variable domain to search in. If not specified, the default domain will be used.\n    ###      \n    indexOfPersistentVariable: (name, type, domain) ->\n        result = 0\n        variables = DataManager.getDocumentsByType(\"persistent_variables\")\n        variablesDocument = variables.first (v) -> v.items.domain == domain\n        variablesDocument ?= variables[0]\n        \n        if variablesDocument\n            variable = variablesDocument.items[type + \"s\"].first (v) -> v.name == name\n            if variable?\n                result = variable.index \n            else\n                console.warn(\"Variable referenced by name not found: #{name} (persistent, #{type})\")\n        \n        return result    \n        \n    ###*\n    * Sets the value of the number variable at the specified index.\n    *\n    * @method setNumberValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} type - The variable's index.\n    * @param {number} value - The value to set.\n    ###     \n    setNumberValueAtIndex: (scope, index, value, domain) ->\n        if scope == 2\n            @persistentNumbers[domain][index] = value\n        else if scope == 1\n            @numbersByDomain[domain||0][index] = value\n        else\n            @tempNumbers[index] = value\n\n    ###*\n    * Sets the value of a specified number variable.\n    *\n    * @method setNumberValueAtIndex\n    * @param {number} variable - The variable to set. \n    * @param {number} value - The value to set.\n    ###     \n    setNumberValueTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentNumbers[variable.domain||0][variable.index] = value\n        else if variable.scope == 1\n            @numbersByDomain[variable.domain||0][variable.index] = value\n        else\n            @tempNumbers[variable.index] = value\n\n    ###*\n    * Sets the value of a specified list variable.\n    *\n    * @method setListObjectTo\n    * @param {Object} variable - The variable to set. \n    * @param {Object} value - The value to set.\n    ###             \n    setListObjectTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentLists[variable.domain||0][variable.index] = value\n        else if variable.scope == 1\n            @listsByDomain[variable.domain||0][variable.index] = value\n        else\n            @tempLists[variable.index] = value\n\n    \n    ###*\n    * Sets the value of a specified boolean variable.\n    *\n    * @method setBooleanValueTo\n    * @param {Object} variable - The variable to set. \n    * @param {boolean} value - The value to set.\n    ###               \n    setBooleanValueTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentBooleans[variable.domain][variable.index] = value\n        else if variable.scope == 1\n            @booleansByDomain[variable.domain][variable.index] = value\n        else\n            @tempBooleans[variable.index] = value\n            \n    ###*\n    * Sets the value of the boolean variable at the specified index.\n    *\n    * @method setBooleanValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @param {boolean} value - The value to set.\n    ###     \n    setBooleanValueAtIndex: (scope, index, value, domain) ->\n        if scope == 2\n            @persistentBooleans[domain][index] = value\n        else if scope == 1\n            @booleansByDomain[domain][index] = value\n        else\n            @tempBooleans[index] = value\n\n    ###*\n    * Sets the value of a specified string variable.\n    *\n    * @method setStringValueTo\n    * @param {Object} variable - The variable to set. \n    * @param {string} value - The value to set.\n    ###   \n    setStringValueTo: (variable, value) ->\n        if variable.scope == 2\n            @persistentStrings[variable.domain][variable.index] = value\n        else if variable.scope == 1\n            @stringsByDomain[variable.domain][variable.index] = value\n        else\n            @tempStrings[variable.index] = value\n            \n    ###*\n    * Sets the value of the string variable at the specified index.\n    *\n    * @method setStringValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @param {string} value - The value to set.\n    ###     \n    setStringValueAtIndex: (scope, index, value, domain) ->\n        if scope == 2\n            @persistentStrings[domain][index] = value\n        else if scope == 1\n            @stringsByDomain[domain][index] = value\n        else\n            @tempStrings[index] = value\n\n    ###*\n    * Gets the value of a specified list variable.\n    *\n    * @method listObjectOf\n    * @param {Object} object - The list-variable/object to get the value from.\n    * @return {Object} The list-object.\n    ###   \n    listObjectOf: (object) ->\n        result = 0\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentLists[object.domain][object.index]\n            else if object.scope == 1\n                result = @listsByDomain[object.domain][object.index]\n            else\n                result = @tempLists[object.index]\n        else\n            result = object\n            \n        return result || []\n    \n    ###*\n    * Gets the value of a number variable at the specified index.\n    *\n    * @method numberValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @return {Object} The number value of the variable.\n    ###      \n    numberValueAtIndex: (scope, index, domain) ->\n        result = 0\n        \n        if scope == 2\n            result = @persistentNumbers[domain][index]\n        else if scope == 1\n            result = @numbersByDomain[domain][index]\n        else\n            result = @tempNumbers[index]\n\n        return result\n    \n    ###*\n    * Gets the value of a specified number variable.\n    *\n    * @method numberValueOf\n    * @param {Object} object - The variable to get the value from.\n    * @return {Object} The number value of the variable.\n    ###     \n    numberValueOf: (object) ->\n        result = 0\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentNumbers[object.domain][object.index]\n            else if object.scope == 1\n                result = @numbersByDomain[object.domain][object.index]\n            else\n                result = @tempNumbers[object.index]\n\n        else\n            result = object\n            \n        return result || 0\n    \n    ###*\n    * Gets the value of a specified string variable.\n    *\n    * @method stringValueOf\n    * @param {Object} object - The variable to get the value from.\n    * @return {string} The string value of the variable.\n    ###        \n    stringValueOf: (object) ->\n        result = \"\"\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentStrings[object.domain][object.index]\n            else if object.scope == 1\n                result = @stringsByDomain[object.domain][object.index]\n            else\n                result = @tempStrings[object.index]\n        else\n            result = object\n            \n        return result || \"\"\n     \n    ###*\n    * Gets the value of a string variable at the specified index.\n    *\n    * @method stringValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @return {string} The string value of the variable.\n    ###        \n    stringValueAtIndex: (scope, index, domain) ->\n        result = \"\"\n        \n        if scope == 2\n            result = @persistentStrings[domain][index]\n        else if scope == 1\n            result = @stringsByDomain[domain][index]\n        else\n            result = @tempStrings[index]\n\n        return result || \"\"\n    \n    ###*\n    * Gets the value of a specified boolean variable.\n    *\n    * @method booleanValueOf\n    * @param {Object} object - The variable to get the value from.\n    * @return {Object} The boolean value of the variable.\n    ###       \n    booleanValueOf: (object) ->\n        result = no\n        if object? and object.index?\n            if object.scope == 2\n                result = @persistentBooleans[object.domain][object.index] || no\n            else if object.scope == 1\n                result = @booleansByDomain[object.domain][object.index] || no\n            else\n                result = @tempBooleans[object.index] || no\n\n        else\n            result = if object then true else false\n            \n        return result\n        \n    ###*\n    * Gets the value of a boolean variable at the specified index.\n    *\n    * @method booleanValueAtIndex\n    * @param {number} scope - The variable scope.\n    * @param {number} index - The variable's index.\n    * @return {boolean} The boolean value of the variable.\n    ###        \n    booleanValueAtIndex: (scope, index, domain) ->\n        result = no\n        \n        if scope == 2\n            result = @persistenBooleans[domain][index] || no\n        else if scope == 1\n            result = @booleansByDomain[domain][index] || no\n        else\n            result = @tempBooleans[index] || no\n\n        return result\n        \ngs.VariableStore = VariableStore"]}\n//# sourceURL=VariableStore_82.js",
        "parentId": "2EC9F946K6417A4973S8308E368608E89B8B"
    },
    "summary": [
        "name",
        "type",
        "order"
    ]
}

Commits for Nextrek/s2s/data/1BEF7399KDF43A4E3ASA1A1E6EA70E833770.json

Diff revisions: vs.
Revision Author Commited Message
1084 MOliva picture MOliva Fri 11 May, 2018 12:41:55 +0000