Subversion Repository Public Repository

Nextrek

Diff Revisions 1085 vs 1086 for /s2s/data/19D5B266K1082A4D01S85D0E17BE2BBA69F8.json

Diff revisions: vs.
  @@ -6,10 +6,10 @@
6 6 "name": "Object_Base",
7 7 "type": "game_script",
8 8 "order": 0,
9 - "content": "# ===================================================================\n#\n# Script: Object_Base\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Object_Base\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 if @id\n window[\"$\"+@id] = this\n \n \n #\n # Gets or sets the group the object belongs to.\n #\n # @property group\n # @type string\n #\n @accessors \"group\", \n set: (g) -> \n @group_ = g\n gs.ObjectManager.current?.addToGroup(this, g)\n \n get: -> @group_\n \n #\n # Gets or sets the order-index of the object. The lower the index, the\n # earlier the object will be updated in a list of sub-objects.\n #\n # @property order\n # @type number\n #\n @accessors \"order\",\n set: (o) ->\n if o != @order_\n @order_ = o\n @parent?.needsSort = true\n get: -> @order_\n \n #\n # Gets or sets if an objects needs an update. If true, the parent will update\n # the object in the next update and resets the needsUpdate property back\n # to false.\n #\n # @property needsUpdate\n # @type boolean\n #\n @accessors \"needsUpdate\", \n set: (v) ->\n @needsUpdate_ = v\n \n parent = @parent\n while parent\n parent.needsUpdate_ = yes\n parent = parent.parent\n \n #if v\n # @parent?.needsUpdate = yes\n #if v\n # for object in @subObjects\n # object.needsUpdate_ = v\n if v\n @requestSubUpdate()\n get: -> return @needsUpdate_ || SceneManager.scene.preparing\n \n requestSubUpdate: ->\n for object in @subObjects\n if object\n object.needsUpdate_ = yes\n object.requestSubUpdate()\n \n return null\n #\n # Gets or sets if an object needs a full update. A full update triggers\n # an update for all sub-objects recursively. \n #\n # @property needsFullUpdate\n # @type boolean\n #\n @accessors \"needsFullUpdate\", \n set: (v) ->\n @needsUpdate = v\n if v\n for object in @subObjects\n object.needsFullUpdate = v\n get: -> @needsUpdate_\n \n ###*\n * The base class for all game objects. A game object itself doesn't implement\n * any game logic but uses components and sub-objects for that.\n *\n * @module gs\n * @class Object_Base\n * @memberof gs\n * @constructor\n ###\n constructor: () ->\n ###*\n * @property subObjects\n * @type gs.Object_Base[]\n * @default []\n * A list of game-objects grouped under this game object.\n ###\n @subObjects = []\n \n ###*\n * @property components\n * @type gs.Component[]\n * @default []\n * A list of components defining the logic/behavior and appearance of the game object.\n ###\n @components = []\n \n ###*\n * @property componentsById\n * @type Object\n * @default []\n * All associated components by their ID.\n ###\n @componentsById = {}\n \n ###*\n * @property disposed\n * @type boolean\n * @default false\n * Indicates if the game object id disposed. A disposed game object cannot be used anymore.\n ###\n @disposed = no\n \n ###*\n * @property active\n * @default true\n * Indicates if the game object is active. An inactive game object will not be updated.\n ###\n @active = yes\n \n @input = no\n \n ###*\n * @property id\n * @type string\n * @default null\n * The game object's UID (Unique ID)\n ###\n @id = null \n \n ###*\n * @property group\n * @default null\n * @type string\n * The game object's group. To get all object's of a specific group the gs.ObjectManager.objectsByGroup property can be used.\n ###\n @group = null \n \n ###*\n * @property parent\n * @type gs.Object_Base\n * @default null\n * The parent object if the game object is a sub-object of another game object.\n ###\n @parent = null\n \n ###*\n * @property order\n * @type number\n * @default 0\n * Controls the update-order. The smaller the value the earlier the game object is updated before other game objects are updated.\n ###\n @order = 0\n \n ###*\n * @property rIndex\n * @type number\n * @default 0\n * Holds the render-index if the game object has a graphical representation on screen. The render-index is the\n * index of the game object's graphic-object(gs.GraphicObject) in the current list of graphic-objects. The render-index\n * is read-only. Setting the render-index to a certain value has no effect.\n ###\n @rIndex = 0\n \n ###*\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the list of sub-objects needs to be sorted by order because of a change.\n ###\n @needsSort = yes\n \n ###*\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the UI object needs to be updated.\n ###\n @needsUpdate = yes\n \n ###*\n * @property initialized\n * @type boolean\n * @default true\n * Indicates if the game object and its components have been initialized.\n ###\n @initialized = no\n \n ###*\n * @property customData\n * @type Object\n * @default {}\n * A custom data object which can be used to add any custom data/fields to the game\n * object. It is an empty object by default.\n ###\n @customData = {}\n \n \n gs.ObjectManager.current?.registerObject(this)\n \n ###*\n * Disposes the object with all its components and sub-objects. A disposed object will be\n * removed from the parent automatically.\n *\n * @method dispose\n ###\n dispose: ->\n if not @disposed\n @disposed = yes\n @disposeComponents()\n @disposeObjects()\n \n gs.ObjectManager.current?.unregisterObject(this)\n \n return null\n \n ###*\n * Disposes all sub-objects.\n *\n * @method disposeObjects\n * @protected\n ###\n disposeObjects: ->\n for subObject in @subObjects\n subObject?.dispose?()\n \n ###*\n * Disposes all components\n *\n * @method disposeComponents\n * @protected\n ###\n disposeComponents: ->\n for component in @components\n component?.dispose?()\n \n ###*\n * Calls setup-routine on all components.\n *\n * @method setup\n ###\n setup: ->\n for component in @components\n component.setup() if not component?.isSetup\n \n @initialized = yes\n return null\n \n ###*\n * Deserializes components from a data-bundle object.\n * \n * @method componentsFromDataBundle\n * @param {Object} data The data-bundle object.\n ###\n componentsFromDataBundle: (data) ->\n if data?.components\n for component in data.components\n componentObject = new gs[component.className](component)\n @addComponent(componentObject)\n delete data.components\n \n return null\n \n ###*\n * Serializes components of a specified type to a data-bundle. A component\n * needs to implement the toDataBundle method for correct serialization.\n *\n * @method componentsToDataBundle\n * @param {String} type - A component class name.\n * @return A data bundle.\n ###\n componentsToDataBundle: (type) ->\n components = []\n for component in @components\n if component instanceof type\n continue unless component.toDataBundle?\n bundle = component.toDataBundle()\n bundle.className = component.constructor.name\n components.push(bundle)\n return components\n \n ###*\n * Starts a full-refresh on all sub-objects\n *\n * @method fullRefresh\n ###\n fullRefresh: ->\n for object in @subObjects\n if object\n object.needsUpdate = yes\n object.fullRefresh()\n \n return null\n \n ###*\n * Updates the object with all parent- and sub-objects. \n *\n * @method fullUpdate\n ###\n fullUpdate: ->\n parent = this\n while parent != null\n parent.update()\n parent = parent.parent\n \n for object in @subObjects\n object?.update()\n \n ###*\n * Updates the object and all its components. This method is\n * called automatically by the parent or ObjectManager so in regular it is \n * not necessary to call it manually.\n *\n * @method update\n ###\n update: ->\n return if !@active\n i = 0\n while i < @components.length\n component = @components[i]\n if not component.disposed\n component.update()\n i++\n else\n @components.splice(i, 1)\n\n\n if @input then Input.clear()\n @input = no\n \n return null\n \n ###*\n * Searches for the first component with the specified class name.\n *\n * @method findComponent\n * @param {String} name The class name of the component.\n * @return {Component} The component or null if a component with the specified class name cannot be found.\n ###\n findComponent: (name) -> @components.first (v) -> v.constructor.name == name\n \n ###*\n * Searches for all components with the specified class name.\n *\n * @method findComponents\n * @param {String} name The class name of the components.\n * @return {Array} The components or null if no component with the specified class name has been found.\n ###\n findComponents: (name) -> @components.where (v) -> v.constructor.name == name\n \n ###*\n * Searches for the component with the specified ID.\n *\n * @method findComponentById\n * @param {String} id The unique identifier of the component.\n * @return {Component} The component or null if a component with the specified ID cannot be found.\n ###\n findComponentById: (id) -> @componentsById[id]\n \n ###*\n * Adds an object to the list of sub-objects.\n *\n * @method addObject\n * @param {Object_Base} object The object which should be added.\n ###\n addObject: (object) ->\n gs.ObjectManager.current?.remove(object)\n object.parent?.removeObject(object)\n object.parent = this\n @subObjects.push(object)\n @needsSort = yes\n @needsUpdate = yes\n \n if object.id?\n gs.ObjectManager.current.setObjectById(object, object.id)\n \n ###*\n * Inserts an object into the list of sub-objects at the specified index.\n *\n * @method insertObject\n * @param {Object_Base} object The object which should be inserted.\n * @param {Number} index The index.\n ###\n insertObject:(object, index) ->\n gs.ObjectManager.current.remove(object)\n object.parent?.removeObject(object)\n object.parent = this\n @subObjects.splice(index, 0, object)\n \n if object.id?\n gs.ObjectManager.current.setObjectById(object, object.id)\n \n ###*\n * Sets sub-object at the specified index.\n *\n * @method setObject\n * @param {Object_Base} object The object.\n * @param {Number} index The index.\n ###\n setObject: (object, index) ->\n if object\n gs.ObjectManager.current.remove(object)\n object.parent?.removeObject(object)\n object.parent = this\n \n @subObjects[index] = object\n \n if object?.id?\n gs.ObjectManager.current.setObjectById(object, object.id)\n \n ###*\n * Removes the specified object from the list of sub-objects.\n *\n * @method removeObject\n * @param {Object_Base} object The object which should be removed.\n ###\n removeObject: (object) ->\n @subObjects.remove(object)\n object.parent = null\n @needsUpdate = yes\n \n ###*\n * Erases the object at the specified index. The list size\n * will not be changed but the the value at the index will be set to null.\n *\n * @method eraseObject\n * @param {Number} object The object which should be erased.\n ###\n eraseObject: (index) ->\n object = @subObjects[index]\n object?.parent = null\n @subObjects[index] = null\n \n ###*\n * Adds the specified component to the object.\n *\n * @method addComponent\n * @param {Component} component The component\n * @param {String} id An optional unique identifier for the component.\n ###\n addComponent: (component, id) ->\n if not @components.contains(component)\n component.object = this\n @components.push(component)\n if id?\n @componentsById[id] = component\n ###*\n * Inserts a component at the specified index.\n *\n * @method insertComponent\n * @param {Component} component The component.\n * @param {Number} index The index.\n * @param {String} id An optional unique identifier for the component.\n ### \n insertComponent: (component, index, id) ->\n @components.remove(component)\n component.object = this\n @components.splice(index, 0, component)\n if id?\n @componentsById[id] = component\n \n ###*\n * Removes a component from the object.\n *\n * @method removeComponent\n * @param {Component} component The component to remove.\n ### \n removeComponent: (component) -> \n @components.remove(component)\n if id?\n delete @componentsById[id]\n\ngs.Object_Base = Object_Base",
9 + "content": "# ===================================================================\n#\n# Script: Object_Base\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass Object_Base\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 if @id\n window[\"$\"+@id] = this\n \n \n #\n # Gets or sets the group the object belongs to.\n #\n # @property group\n # @type string\n #\n @accessors \"group\", \n set: (g) -> \n @group_ = g\n gs.ObjectManager.current?.addToGroup(this, g)\n \n get: -> @group_\n \n #\n # Gets or sets the order-index of the object. The lower the index, the\n # earlier the object will be updated in a list of sub-objects.\n #\n # @property order\n # @type number\n #\n @accessors \"order\",\n set: (o) ->\n if o != @order_\n @order_ = o\n @parent?.needsSort = true\n get: -> @order_\n \n #\n # Gets or sets if an objects needs an update. If true, the parent will update\n # the object in the next update and resets the needsUpdate property back\n # to false.\n #\n # @property needsUpdate\n # @type boolean\n #\n @accessors \"needsUpdate\", \n set: (v) ->\n @needsUpdate_ = v\n \n parent = @parent\n while parent\n parent.needsUpdate_ = yes\n parent = parent.parent\n \n #if v\n # @parent?.needsUpdate = yes\n #if v\n # for object in @subObjects\n # object.needsUpdate_ = v\n if v\n @requestSubUpdate()\n get: -> return @needsUpdate_ || SceneManager.scene.preparing\n \n requestSubUpdate: ->\n for object in @subObjects\n if object\n object.needsUpdate_ = yes\n object.requestSubUpdate()\n \n return null\n #\n # Gets or sets if an object needs a full update. A full update triggers\n # an update for all sub-objects recursively. \n #\n # @property needsFullUpdate\n # @type boolean\n #\n @accessors \"needsFullUpdate\", \n set: (v) ->\n @needsUpdate = v\n if v\n for object in @subObjects\n object.needsFullUpdate = v\n get: -> @needsUpdate_\n \n ###*\n * The base class for all game objects. A game object itself doesn't implement\n * any game logic but uses components and sub-objects for that.\n *\n * @module gs\n * @class Object_Base\n * @memberof gs\n * @constructor\n ###\n constructor: () ->\n ###*\n * @property subObjects\n * @type gs.Object_Base[]\n * @default []\n * A list of game-objects grouped under this game object.\n ###\n @subObjects = []\n \n ###*\n * @property components\n * @type gs.Component[]\n * @default []\n * A list of components defining the logic/behavior and appearance of the game object.\n ###\n @components = []\n \n ###*\n * @property componentsById\n * @type Object\n * @default []\n * All associated components by their ID.\n ###\n @componentsById = {}\n \n ###*\n * @property disposed\n * @type boolean\n * @default false\n * Indicates if the game object id disposed. A disposed game object cannot be used anymore.\n ###\n @disposed = no\n \n ###*\n * @property active\n * @default true\n * Indicates if the game object is active. An inactive game object will not be updated.\n ###\n @active = yes\n \n @input = no\n \n ###*\n * @property id\n * @type string\n * @default null\n * The game object's UID (Unique ID)\n ###\n @id = null \n \n ###*\n * @property group\n * @default null\n * @type string\n * The game object's group. To get all object's of a specific group the gs.ObjectManager.objectsByGroup property can be used.\n ###\n @group = null \n \n ###*\n * @property parent\n * @type gs.Object_Base\n * @default null\n * The parent object if the game object is a sub-object of another game object.\n ###\n @parent = null\n \n ###*\n * @property order\n * @type number\n * @default 0\n * Controls the update-order. The smaller the value the earlier the game object is updated before other game objects are updated.\n ###\n @order = 0\n \n ###*\n * @property rIndex\n * @type number\n * @default 0\n * Holds the render-index if the game object has a graphical representation on screen. The render-index is the\n * index of the game object's graphic-object(gs.GraphicObject) in the current list of graphic-objects. The render-index\n * is read-only. Setting the render-index to a certain value has no effect.\n ###\n @rIndex = 0\n \n ###*\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the list of sub-objects needs to be sorted by order because of a change.\n ###\n @needsSort = yes\n \n ###*\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the UI object needs to be updated.\n ###\n @needsUpdate = yes\n \n ###*\n * @property initialized\n * @type boolean\n * @default true\n * Indicates if the game object and its components have been initialized.\n ###\n @initialized = no\n \n ###*\n * @property customData\n * @type Object\n * @default {}\n * A custom data object which can be used to add any custom data/fields to the game\n * object. It is an empty object by default.\n ###\n @customData = {}\n \n \n gs.ObjectManager.current?.registerObject(this)\n \n ###*\n * Disposes the object with all its components and sub-objects. A disposed object will be\n * removed from the parent automatically.\n *\n * @method dispose\n ###\n dispose: ->\n if not @disposed\n @disposed = yes\n @disposeComponents()\n @disposeObjects()\n \n gs.ObjectManager.current?.unregisterObject(this)\n \n return null\n \n ###*\n * Disposes all sub-objects.\n *\n * @method disposeObjects\n * @protected\n ###\n disposeObjects: ->\n for subObject in @subObjects\n subObject?.dispose?()\n \n ###*\n * Disposes all components\n *\n * @method disposeComponents\n * @protected\n ###\n disposeComponents: ->\n for component in @components\n component?.dispose?()\n \n ###*\n * Calls setup-routine on all components.\n *\n * @method setup\n ###\n setup: ->\n for component in @components\n component.setup() if not component?.isSetup\n \n @initialized = yes\n return null\n \n ###*\n * Deserializes components from a data-bundle object.\n * \n * @method componentsFromDataBundle\n * @param {Object} data The data-bundle object.\n ###\n componentsFromDataBundle: (data) ->\n if data?.components\n for component in data.components\n componentObject = new gs[component.className](component)\n @addComponent(componentObject)\n delete data.components\n \n return null\n \n ###*\n * Serializes components of a specified type to a data-bundle. A component\n * needs to implement the toDataBundle method for correct serialization.\n *\n * @method componentsToDataBundle\n * @param {String} type - A component class name.\n * @return A data bundle.\n ###\n componentsToDataBundle: (type) ->\n components = []\n for component in @components\n if component instanceof type\n continue unless component.toDataBundle?\n bundle = component.toDataBundle()\n bundle.className = component.constructor.name\n components.push(bundle)\n return components\n \n ###*\n * Starts a full-refresh on all sub-objects\n *\n * @method fullRefresh\n ###\n fullRefresh: ->\n for object in @subObjects\n if object\n object.needsUpdate = yes\n object.fullRefresh()\n \n return null\n \n ###*\n * Updates the object with all parent- and sub-objects. \n *\n * @method fullUpdate\n ###\n fullUpdate: ->\n parent = this\n while parent != null\n parent.update()\n parent = parent.parent\n \n for object in @subObjects\n object?.update()\n \n ###*\n * Updates the object and all its components. This method is\n * called automatically by the parent or ObjectManager so in regular it is \n * not necessary to call it manually.\n *\n * @method update\n ###\n update: ->\n return if !@active\n i = 0\n while i < @components.length\n component = @components[i]\n if not component.disposed\n component.update()\n i++\n else\n @components.splice(i, 1)\n\n\n if @input then Input.clear()\n @input = no\n \n return null\n \n ###*\n * Searches for the first component with the specified class name.\n *\n * @method findComponent\n * @param {String} name The class name of the component.\n * @return {Component} The component or null if a component with the specified class name cannot be found.\n ###\n findComponent: (name) -> @components.first (v) -> v.constructor.name == name\n \n ###*\n * Searches for all components with the specified class name.\n *\n * @method findComponents\n * @param {String} name The class name of the components.\n * @return {Array} The components or null if no component with the specified class name has been found.\n ###\n findComponents: (name) -> @components.where (v) -> v.constructor.name == name\n \n ###*\n * Searches for the component with the specified ID.\n *\n * @method findComponentById\n * @param {String} id The unique identifier of the component.\n * @return {Component} The component or null if a component with the specified ID cannot be found.\n ###\n findComponentById: (id) -> @componentsById[id]\n \n ###*\n * Searches for the component with the specified name. If multiple components have the\n * same name, it will return the first match.\n *\n * @method findComponentByName\n * @param {String} name The name of the component to find.\n * @return {Component} The component or null if a component with the specified name cannot be found.\n ###\n findComponentByName: (name) -> @components.first (v) -> v.name == name\n \n ###*\n * Searches for components with the specified name.\n *\n * @method findComponentsByName\n * @param {String} name The name of the components to find.\n * @return {Component[]} An array of components matching the specified name or null if no components with the specified name exist.\n ###\n findComponentsByName: (name) -> @components.where (v) -> v.name == name\n \n ###*\n * Adds an object to the list of sub-objects.\n *\n * @method addObject\n * @param {Object_Base} object The object which should be added.\n ###\n addObject: (object) ->\n gs.ObjectManager.current?.remove(object)\n object.parent?.removeObject(object)\n object.parent = this\n @subObjects.push(object)\n @needsSort = yes\n @needsUpdate = yes\n \n if object.id?\n gs.ObjectManager.current.setObjectById(object, object.id)\n \n ###*\n * Inserts an object into the list of sub-objects at the specified index.\n *\n * @method insertObject\n * @param {Object_Base} object The object which should be inserted.\n * @param {Number} index The index.\n ###\n insertObject:(object, index) ->\n gs.ObjectManager.current.remove(object)\n object.parent?.removeObject(object)\n object.parent = this\n @subObjects.splice(index, 0, object)\n \n if object.id?\n gs.ObjectManager.current.setObjectById(object, object.id)\n \n ###*\n * Sets sub-object at the specified index.\n *\n * @method setObject\n * @param {Object_Base} object The object.\n * @param {Number} index The index.\n ###\n setObject: (object, index) ->\n if object\n gs.ObjectManager.current.remove(object)\n object.parent?.removeObject(object)\n object.parent = this\n \n @subObjects[index] = object\n \n if object?.id?\n gs.ObjectManager.current.setObjectById(object, object.id)\n \n ###*\n * Removes the specified object from the list of sub-objects.\n *\n * @method removeObject\n * @param {Object_Base} object The object which should be removed.\n ###\n removeObject: (object) ->\n @subObjects.remove(object)\n object.parent = null\n @needsUpdate = yes\n \n ###*\n * Removes the object at the specified index from the list of sub-objects.\n *\n * @method removeObjectAt\n * @param {number} index The index of the objec to remove.\n ### \n removeObjectAt: (index) ->\n object = @subObjects[index]\n @subObjects.splice(index, 1)\n object.parent = null\n @needsUpdate = yes\n \n ###*\n * Removes all sub-objects.\n *\n * @method removeAllObjects\n ### \n removeAllObjects: ->\n while @subObjects.length > 0\n @removeObjectAt(0)\n \n ###*\n * Erases the object at the specified index. The list size\n * will not be changed but the the value at the index will be set to null.\n *\n * @method eraseObject\n * @param {Number} object The object which should be erased.\n ###\n eraseObject: (index) ->\n object = @subObjects[index]\n object?.parent = null\n @subObjects[index] = null\n \n ###*\n * Adds the specified component to the object.\n *\n * @method addComponent\n * @param {Component} component The component\n * @param {String} id An optional unique identifier for the component.\n ###\n addComponent: (component, id) ->\n if not @components.contains(component)\n component.object = this\n @components.push(component)\n if id?\n @componentsById[id] = component\n ###*\n * Inserts a component at the specified index.\n *\n * @method insertComponent\n * @param {Component} component The component.\n * @param {Number} index The index.\n * @param {String} id An optional unique identifier for the component.\n ### \n insertComponent: (component, index, id) ->\n @components.remove(component)\n component.object = this\n @components.splice(index, 0, component)\n if id?\n @componentsById[id] = component\n \n ###*\n * Removes a component from the object.\n *\n * @method removeComponent\n * @param {Component} component The component to remove.\n ### \n removeComponent: (component) -> \n @components.remove(component)\n if id?\n delete @componentsById[id]\n\ngs.Object_Base = Object_Base",
10 10 "parentId": "A05E7029K45DBA459BSADF4EEC07A526241A",
11 11 "folder": false,
12 - "compiledContent": "var Object_Base;\n\nObject_Base = (function() {\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 Object_Base.prototype.onDataBundleRestore = function(data, context) {\n if (this.id) {\n return window[\"$\" + this.id] = this;\n }\n };\n\n Object_Base.accessors(\"group\", {\n set: function(g) {\n var ref;\n this.group_ = g;\n return (ref = gs.ObjectManager.current) != null ? ref.addToGroup(this, g) : void 0;\n },\n get: function() {\n return this.group_;\n }\n });\n\n Object_Base.accessors(\"order\", {\n set: function(o) {\n var ref;\n if (o !== this.order_) {\n this.order_ = o;\n return (ref = this.parent) != null ? ref.needsSort = true : void 0;\n }\n },\n get: function() {\n return this.order_;\n }\n });\n\n Object_Base.accessors(\"needsUpdate\", {\n set: function(v) {\n var parent;\n this.needsUpdate_ = v;\n parent = this.parent;\n while (parent) {\n parent.needsUpdate_ = true;\n parent = parent.parent;\n }\n if (v) {\n return this.requestSubUpdate();\n }\n },\n get: function() {\n return this.needsUpdate_ || SceneManager.scene.preparing;\n }\n });\n\n Object_Base.prototype.requestSubUpdate = function() {\n var j, len, object, ref;\n ref = this.subObjects;\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n if (object) {\n object.needsUpdate_ = true;\n object.requestSubUpdate();\n }\n }\n return null;\n };\n\n Object_Base.accessors(\"needsFullUpdate\", {\n set: function(v) {\n var j, len, object, ref, results;\n this.needsUpdate = v;\n if (v) {\n ref = this.subObjects;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n results.push(object.needsFullUpdate = v);\n }\n return results;\n }\n },\n get: function() {\n return this.needsUpdate_;\n }\n });\n\n\n /**\n * The base class for all game objects. A game object itself doesn't implement\n * any game logic but uses components and sub-objects for that.\n *\n * @module gs\n * @class Object_Base\n * @memberof gs\n * @constructor\n */\n\n function Object_Base() {\n\n /**\n * @property subObjects\n * @type gs.Object_Base[]\n * @default []\n * A list of game-objects grouped under this game object.\n */\n var ref;\n this.subObjects = [];\n\n /**\n * @property components\n * @type gs.Component[]\n * @default []\n * A list of components defining the logic/behavior and appearance of the game object.\n */\n this.components = [];\n\n /**\n * @property componentsById\n * @type Object\n * @default []\n * All associated components by their ID.\n */\n this.componentsById = {};\n\n /**\n * @property disposed\n * @type boolean\n * @default false\n * Indicates if the game object id disposed. A disposed game object cannot be used anymore.\n */\n this.disposed = false;\n\n /**\n * @property active\n * @default true\n * Indicates if the game object is active. An inactive game object will not be updated.\n */\n this.active = true;\n this.input = false;\n\n /**\n * @property id\n * @type string\n * @default null\n * The game object's UID (Unique ID)\n */\n this.id = null;\n\n /**\n * @property group\n * @default null\n * @type string\n * The game object's group. To get all object's of a specific group the gs.ObjectManager.objectsByGroup property can be used.\n */\n this.group = null;\n\n /**\n * @property parent\n * @type gs.Object_Base\n * @default null\n * The parent object if the game object is a sub-object of another game object.\n */\n this.parent = null;\n\n /**\n * @property order\n * @type number\n * @default 0\n * Controls the update-order. The smaller the value the earlier the game object is updated before other game objects are updated.\n */\n this.order = 0;\n\n /**\n * @property rIndex\n * @type number\n * @default 0\n * Holds the render-index if the game object has a graphical representation on screen. The render-index is the\n * index of the game object's graphic-object(gs.GraphicObject) in the current list of graphic-objects. The render-index\n * is read-only. Setting the render-index to a certain value has no effect.\n */\n this.rIndex = 0;\n\n /**\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the list of sub-objects needs to be sorted by order because of a change.\n */\n this.needsSort = true;\n\n /**\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the UI object needs to be updated.\n */\n this.needsUpdate = true;\n\n /**\n * @property initialized\n * @type boolean\n * @default true\n * Indicates if the game object and its components have been initialized.\n */\n this.initialized = false;\n\n /**\n * @property customData\n * @type Object\n * @default {}\n * A custom data object which can be used to add any custom data/fields to the game\n * object. It is an empty object by default.\n */\n this.customData = {};\n if ((ref = gs.ObjectManager.current) != null) {\n ref.registerObject(this);\n }\n }\n\n\n /**\n * Disposes the object with all its components and sub-objects. A disposed object will be\n * removed from the parent automatically.\n *\n * @method dispose\n */\n\n Object_Base.prototype.dispose = function() {\n var ref;\n if (!this.disposed) {\n this.disposed = true;\n this.disposeComponents();\n this.disposeObjects();\n if ((ref = gs.ObjectManager.current) != null) {\n ref.unregisterObject(this);\n }\n }\n return null;\n };\n\n\n /**\n * Disposes all sub-objects.\n *\n * @method disposeObjects\n * @protected\n */\n\n Object_Base.prototype.disposeObjects = function() {\n var j, len, ref, results, subObject;\n ref = this.subObjects;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n subObject = ref[j];\n results.push(subObject != null ? typeof subObject.dispose === \"function\" ? subObject.dispose() : void 0 : void 0);\n }\n return results;\n };\n\n\n /**\n * Disposes all components\n *\n * @method disposeComponents\n * @protected\n */\n\n Object_Base.prototype.disposeComponents = function() {\n var component, j, len, ref, results;\n ref = this.components;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n results.push(component != null ? typeof component.dispose === \"function\" ? component.dispose() : void 0 : void 0);\n }\n return results;\n };\n\n\n /**\n * Calls setup-routine on all components.\n *\n * @method setup\n */\n\n Object_Base.prototype.setup = function() {\n var component, j, len, ref;\n ref = this.components;\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n if (!(component != null ? component.isSetup : void 0)) {\n component.setup();\n }\n }\n this.initialized = true;\n return null;\n };\n\n\n /**\n * Deserializes components from a data-bundle object.\n * \n * @method componentsFromDataBundle\n * @param {Object} data The data-bundle object.\n */\n\n Object_Base.prototype.componentsFromDataBundle = function(data) {\n var component, componentObject, j, len, ref;\n if (data != null ? data.components : void 0) {\n ref = data.components;\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n componentObject = new gs[component.className](component);\n this.addComponent(componentObject);\n }\n delete data.components;\n }\n return null;\n };\n\n\n /**\n * Serializes components of a specified type to a data-bundle. A component\n * needs to implement the toDataBundle method for correct serialization.\n *\n * @method componentsToDataBundle\n * @param {String} type - A component class name.\n * @return A data bundle.\n */\n\n Object_Base.prototype.componentsToDataBundle = function(type) {\n var bundle, component, components, j, len, ref;\n components = [];\n ref = this.components;\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n if (component instanceof type) {\n if (component.toDataBundle == null) {\n continue;\n }\n bundle = component.toDataBundle();\n bundle.className = component.constructor.name;\n components.push(bundle);\n }\n }\n return components;\n };\n\n\n /**\n * Starts a full-refresh on all sub-objects\n *\n * @method fullRefresh\n */\n\n Object_Base.prototype.fullRefresh = function() {\n var j, len, object, ref;\n ref = this.subObjects;\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n if (object) {\n object.needsUpdate = true;\n object.fullRefresh();\n }\n }\n return null;\n };\n\n\n /**\n * Updates the object with all parent- and sub-objects. \n *\n * @method fullUpdate\n */\n\n Object_Base.prototype.fullUpdate = function() {\n var j, len, object, parent, ref, results;\n parent = this;\n while (parent !== null) {\n parent.update();\n parent = parent.parent;\n }\n ref = this.subObjects;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n results.push(object != null ? object.update() : void 0);\n }\n return results;\n };\n\n\n /**\n * Updates the object and all its components. This method is\n * called automatically by the parent or ObjectManager so in regular it is \n * not necessary to call it manually.\n *\n * @method update\n */\n\n Object_Base.prototype.update = function() {\n var component, i;\n if (!this.active) {\n return;\n }\n i = 0;\n while (i < this.components.length) {\n component = this.components[i];\n if (!component.disposed) {\n component.update();\n i++;\n } else {\n this.components.splice(i, 1);\n }\n }\n if (this.input) {\n Input.clear();\n }\n this.input = false;\n return null;\n };\n\n\n /**\n * Searches for the first component with the specified class name.\n *\n * @method findComponent\n * @param {String} name The class name of the component.\n * @return {Component} The component or null if a component with the specified class name cannot be found.\n */\n\n Object_Base.prototype.findComponent = function(name) {\n return this.components.first(function(v) {\n return v.constructor.name === name;\n });\n };\n\n\n /**\n * Searches for all components with the specified class name.\n *\n * @method findComponents\n * @param {String} name The class name of the components.\n * @return {Array} The components or null if no component with the specified class name has been found.\n */\n\n Object_Base.prototype.findComponents = function(name) {\n return this.components.where(function(v) {\n return v.constructor.name === name;\n });\n };\n\n\n /**\n * Searches for the component with the specified ID.\n *\n * @method findComponentById\n * @param {String} id The unique identifier of the component.\n * @return {Component} The component or null if a component with the specified ID cannot be found.\n */\n\n Object_Base.prototype.findComponentById = function(id) {\n return this.componentsById[id];\n };\n\n\n /**\n * Adds an object to the list of sub-objects.\n *\n * @method addObject\n * @param {Object_Base} object The object which should be added.\n */\n\n Object_Base.prototype.addObject = function(object) {\n var ref, ref1;\n if ((ref = gs.ObjectManager.current) != null) {\n ref.remove(object);\n }\n if ((ref1 = object.parent) != null) {\n ref1.removeObject(object);\n }\n object.parent = this;\n this.subObjects.push(object);\n this.needsSort = true;\n this.needsUpdate = true;\n if (object.id != null) {\n return gs.ObjectManager.current.setObjectById(object, object.id);\n }\n };\n\n\n /**\n * Inserts an object into the list of sub-objects at the specified index.\n *\n * @method insertObject\n * @param {Object_Base} object The object which should be inserted.\n * @param {Number} index The index.\n */\n\n Object_Base.prototype.insertObject = function(object, index) {\n var ref;\n gs.ObjectManager.current.remove(object);\n if ((ref = object.parent) != null) {\n ref.removeObject(object);\n }\n object.parent = this;\n this.subObjects.splice(index, 0, object);\n if (object.id != null) {\n return gs.ObjectManager.current.setObjectById(object, object.id);\n }\n };\n\n\n /**\n * Sets sub-object at the specified index.\n *\n * @method setObject\n * @param {Object_Base} object The object.\n * @param {Number} index The index.\n */\n\n Object_Base.prototype.setObject = function(object, index) {\n var ref;\n if (object) {\n gs.ObjectManager.current.remove(object);\n if ((ref = object.parent) != null) {\n ref.removeObject(object);\n }\n object.parent = this;\n }\n this.subObjects[index] = object;\n if ((object != null ? object.id : void 0) != null) {\n return gs.ObjectManager.current.setObjectById(object, object.id);\n }\n };\n\n\n /**\n * Removes the specified object from the list of sub-objects.\n *\n * @method removeObject\n * @param {Object_Base} object The object which should be removed.\n */\n\n Object_Base.prototype.removeObject = function(object) {\n this.subObjects.remove(object);\n object.parent = null;\n return this.needsUpdate = true;\n };\n\n\n /**\n * Erases the object at the specified index. The list size\n * will not be changed but the the value at the index will be set to null.\n *\n * @method eraseObject\n * @param {Number} object The object which should be erased.\n */\n\n Object_Base.prototype.eraseObject = function(index) {\n var object;\n object = this.subObjects[index];\n if (object != null) {\n object.parent = null;\n }\n return this.subObjects[index] = null;\n };\n\n\n /**\n * Adds the specified component to the object.\n *\n * @method addComponent\n * @param {Component} component The component\n * @param {String} id An optional unique identifier for the component.\n */\n\n Object_Base.prototype.addComponent = function(component, id) {\n if (!this.components.contains(component)) {\n component.object = this;\n this.components.push(component);\n if (id != null) {\n return this.componentsById[id] = component;\n }\n }\n };\n\n\n /**\n * Inserts a component at the specified index.\n *\n * @method insertComponent\n * @param {Component} component The component.\n * @param {Number} index The index.\n * @param {String} id An optional unique identifier for the component.\n */\n\n Object_Base.prototype.insertComponent = function(component, index, id) {\n this.components.remove(component);\n component.object = this;\n this.components.splice(index, 0, component);\n if (id != null) {\n return this.componentsById[id] = component;\n }\n };\n\n\n /**\n * Removes a component from the object.\n *\n * @method removeComponent\n * @param {Component} component The component to remove.\n */\n\n Object_Base.prototype.removeComponent = function(component) {\n this.components.remove(component);\n if (typeof id !== \"undefined\" && id !== null) {\n return delete this.componentsById[id];\n }\n };\n\n return Object_Base;\n\n})();\n\ngs.Object_Base = Object_Base;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Object_Base\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Object_Base\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        if @id\n            window[\"$\"+@id] = this\n            \n    \n    #\n    # Gets or sets the group the object belongs to.\n    #\n    # @property group\n    # @type string\n    #\n    @accessors \"group\", \n        set: (g) -> \n            @group_ = g\n            gs.ObjectManager.current?.addToGroup(this, g)\n            \n        get: -> @group_\n        \n    #\n    # Gets or sets the order-index of the object. The lower the index, the\n    # earlier the object will be updated in a list of sub-objects.\n    #\n    # @property order\n    # @type number\n    #\n    @accessors \"order\",\n        set: (o) ->\n            if o != @order_\n                @order_ = o\n                @parent?.needsSort = true\n        get: -> @order_\n        \n    #\n    # Gets or sets if an objects needs an update. If true, the parent will update\n    # the object in the next update and resets the needsUpdate property back\n    # to false.\n    #\n    # @property needsUpdate\n    # @type boolean\n    #\n    @accessors \"needsUpdate\", \n        set: (v) ->\n            @needsUpdate_ = v\n            \n            parent = @parent\n            while parent\n                parent.needsUpdate_ = yes\n                parent = parent.parent\n                \n            #if v\n            #    @parent?.needsUpdate = yes\n            #if v\n            #    for object in @subObjects\n            #        object.needsUpdate_ = v\n            if v\n                @requestSubUpdate()\n        get: -> return @needsUpdate_ || SceneManager.scene.preparing\n        \n    requestSubUpdate: ->\n        for object in @subObjects\n            if object\n                object.needsUpdate_ = yes\n                object.requestSubUpdate()\n                \n        return null\n    #\n    # Gets or sets if an object needs a full update. A full update triggers\n    # an update for all sub-objects recursively. \n    #\n    # @property needsFullUpdate\n    # @type boolean\n    #\n    @accessors \"needsFullUpdate\", \n        set: (v) ->\n            @needsUpdate = v\n            if v\n                for object in @subObjects\n                    object.needsFullUpdate = v\n        get: -> @needsUpdate_\n            \n    ###*\n    * The base class for all game objects. A game object itself doesn't implement\n    * any game logic but uses components and sub-objects for that.\n    *\n    * @module gs\n    * @class Object_Base\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: () ->\n        ###*\n        * @property subObjects\n        * @type gs.Object_Base[]\n        * @default []\n        * A list of game-objects grouped under this game object.\n        ###\n        @subObjects = []\n        \n        ###*\n        * @property components\n        * @type gs.Component[]\n        * @default []\n        * A list of components defining the logic/behavior and appearance of the game object.\n        ###\n        @components = []\n        \n        ###*\n        * @property componentsById\n        * @type Object\n        * @default []\n        * All associated components by their ID.\n        ###\n        @componentsById = {}\n        \n        ###*\n        * @property disposed\n        * @type boolean\n        * @default false\n        * Indicates if the game object id disposed. A disposed game object cannot be used anymore.\n        ###\n        @disposed = no\n        \n        ###*\n        * @property active\n        * @default true\n        * Indicates if the game object is active. An inactive game object will not be updated.\n        ###\n        @active = yes\n        \n        @input = no\n        \n        ###*\n        * @property id\n        * @type string\n        * @default null\n        * The game object's UID (Unique ID)\n        ###\n        @id = null \n        \n        ###*\n        * @property group\n        * @default null\n        * @type string\n        * The game object's group. To get all object's of a specific group the gs.ObjectManager.objectsByGroup property can be used.\n        ###\n        @group = null \n        \n        ###*\n        * @property parent\n        * @type gs.Object_Base\n        * @default null\n        * The parent object if the game object is a sub-object of another game object.\n        ###\n        @parent = null\n        \n        ###*\n        * @property order\n        * @type number\n        * @default 0\n        * Controls the update-order. The smaller the value the earlier the game object is updated before other game objects are updated.\n        ###\n        @order = 0\n        \n        ###*\n        * @property rIndex\n        * @type number\n        * @default 0\n        * Holds the render-index if the game object has a graphical representation on screen. The render-index is the\n        * index of the game object's graphic-object(gs.GraphicObject) in the current list of graphic-objects. The render-index\n        * is read-only. Setting the render-index to a certain value has no effect.\n        ###\n        @rIndex = 0\n        \n        ###*\n        * @property needsSort\n        * @type boolean\n        * @default true\n        * Indicates if the list of sub-objects needs to be sorted by order because of a change.\n        ###\n        @needsSort = yes\n        \n        ###*\n        * @property needsSort\n        * @type boolean\n        * @default true\n        * Indicates if the UI object needs to be updated.\n        ###\n        @needsUpdate = yes\n        \n        ###*\n        * @property initialized\n        * @type boolean\n        * @default true\n        * Indicates if the game object and its components have been initialized.\n        ###\n        @initialized = no\n        \n        ###*\n        * @property customData\n        * @type Object\n        * @default {}\n        * A custom data object which can be used to add any custom data/fields to the game\n        * object. It is an empty object by default.\n        ###\n        @customData = {}\n        \n        \n        gs.ObjectManager.current?.registerObject(this)\n        \n    ###*\n    * Disposes the object with all its components and sub-objects. A disposed object will be\n    * removed from the parent automatically.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        if not @disposed\n            @disposed = yes\n            @disposeComponents()\n            @disposeObjects()\n                \n            gs.ObjectManager.current?.unregisterObject(this)\n        \n        return null\n        \n    ###*\n    * Disposes all sub-objects.\n    *\n    * @method disposeObjects\n    * @protected\n    ###\n    disposeObjects: ->\n        for subObject in @subObjects\n            subObject?.dispose?()\n            \n    ###*\n    * Disposes all components\n    *\n    * @method disposeComponents\n    * @protected\n    ###\n    disposeComponents: ->\n        for component in @components\n            component?.dispose?()\n       \n    ###*\n    * Calls setup-routine on all components.\n    *\n    * @method setup\n    ###\n    setup: ->\n        for component in @components\n            component.setup() if not component?.isSetup\n            \n        @initialized = yes\n        return null\n        \n    ###*\n    * Deserializes components from a data-bundle object.\n    * \n    * @method componentsFromDataBundle\n    * @param {Object} data The data-bundle object.\n    ###\n    componentsFromDataBundle: (data) ->\n        if data?.components\n            for component in data.components\n                componentObject = new gs[component.className](component)\n                @addComponent(componentObject)\n            delete data.components\n                \n        return null\n           \n    ###*\n    * Serializes components of a specified type to a data-bundle. A component\n    * needs to implement the toDataBundle method for correct serialization.\n    *\n    * @method componentsToDataBundle\n    * @param {String} type - A component class name.\n    * @return A data bundle.\n    ###\n    componentsToDataBundle: (type) ->\n        components = []\n        for component in @components\n            if component instanceof type\n                continue unless component.toDataBundle?\n                bundle = component.toDataBundle()\n                bundle.className = component.constructor.name\n                components.push(bundle)\n        return components\n        \n    ###*\n    * Starts a full-refresh on all sub-objects\n    *\n    * @method fullRefresh\n    ###\n    fullRefresh: ->\n        for object in @subObjects\n            if object\n                object.needsUpdate = yes\n                object.fullRefresh()\n            \n        return null\n    \n    ###*\n    * Updates the object with all parent- and sub-objects. \n    *\n    * @method fullUpdate\n    ###\n    fullUpdate: ->\n        parent = this\n        while parent != null\n            parent.update()\n            parent = parent.parent\n            \n        for object in @subObjects\n            object?.update()\n        \n    ###*\n    * Updates the object and all its components. This method is\n    * called automatically by the parent or ObjectManager so in regular it is \n    * not necessary to call it manually.\n    *\n    * @method update\n    ###\n    update: ->\n        return if !@active\n        i = 0\n        while i < @components.length\n            component = @components[i]\n            if not component.disposed\n                component.update()\n                i++\n            else\n                @components.splice(i, 1)\n\n\n        if @input then Input.clear()\n        @input = no\n        \n        return null\n            \n    ###*\n    * Searches for the first component with the specified class name.\n    *\n    * @method findComponent\n    * @param {String} name The class name of the component.\n    * @return {Component} The component or null if a component with the specified class name cannot be found.\n    ###\n    findComponent: (name) -> @components.first (v) -> v.constructor.name == name\n    \n    ###*\n    * Searches for all components with the specified class name.\n    *\n    * @method findComponents\n    * @param {String} name The class name of the components.\n    * @return {Array} The components or null if no component with the specified class name has been found.\n    ###\n    findComponents: (name) -> @components.where (v) -> v.constructor.name == name\n    \n    ###*\n    * Searches for the component with the specified ID.\n    *\n    * @method findComponentById\n    * @param {String} id The unique identifier of the component.\n    * @return {Component} The component or null if a component with the specified ID cannot be found.\n    ###\n    findComponentById: (id) -> @componentsById[id]\n    \n    ###*\n    * Adds an object to the list of sub-objects.\n    *\n    * @method addObject\n    * @param {Object_Base} object The object which should be added.\n    ###\n    addObject: (object) ->\n        gs.ObjectManager.current?.remove(object)\n        object.parent?.removeObject(object)\n        object.parent = this\n        @subObjects.push(object)\n        @needsSort = yes\n        @needsUpdate = yes\n    \n        if object.id?\n            gs.ObjectManager.current.setObjectById(object, object.id)\n        \n    ###*\n    * Inserts an object into the list of sub-objects at the specified index.\n    *\n    * @method insertObject\n    * @param {Object_Base} object The object which should be inserted.\n    * @param {Number} index The index.\n    ###\n    insertObject:(object, index) ->\n        gs.ObjectManager.current.remove(object)\n        object.parent?.removeObject(object)\n        object.parent = this\n        @subObjects.splice(index, 0, object)\n      \n        if object.id?\n            gs.ObjectManager.current.setObjectById(object, object.id)\n            \n    ###*\n    * Sets sub-object at the specified index.\n    *\n    * @method setObject\n    * @param {Object_Base} object The object.\n    * @param {Number} index The index.\n    ###\n    setObject: (object, index) ->\n        if object\n            gs.ObjectManager.current.remove(object)\n            object.parent?.removeObject(object)\n            object.parent = this\n            \n        @subObjects[index] = object\n      \n        if object?.id?\n            gs.ObjectManager.current.setObjectById(object, object.id)\n    \n    ###*\n    * Removes the specified object from the list of sub-objects.\n    *\n    * @method removeObject\n    * @param {Object_Base} object The object which should be removed.\n    ###\n    removeObject: (object) ->\n        @subObjects.remove(object)\n        object.parent = null\n        @needsUpdate = yes\n    \n    ###*\n    * Erases the object at the specified index. The list size\n    * will not be changed but the the value at the index will be set to null.\n    *\n    * @method eraseObject\n    * @param {Number} object The object which should be erased.\n    ###\n    eraseObject: (index) ->\n        object = @subObjects[index]\n        object?.parent = null\n        @subObjects[index] = null\n    \n    ###*\n    * Adds the specified component to the object.\n    *\n    * @method addComponent\n    * @param {Component} component The component\n    * @param {String} id An optional unique identifier for the component.\n    ###\n    addComponent: (component, id) ->\n        if not @components.contains(component)\n            component.object = this\n            @components.push(component)\n            if id?\n                @componentsById[id] = component\n    ###*\n    * Inserts a component at the specified index.\n    *\n    * @method insertComponent\n    * @param {Component} component The component.\n    * @param {Number} index The index.\n    * @param {String} id An optional unique identifier for the component.\n    ###    \n    insertComponent: (component, index, id) ->\n        @components.remove(component)\n        component.object = this\n        @components.splice(index, 0, component)\n        if id?\n            @componentsById[id] = component\n    \n    ###*\n    * Removes a component from the object.\n    *\n    * @method removeComponent\n    * @param {Component} component The component to remove.\n    ###  \n    removeComponent: (component) -> \n        @components.remove(component)\n        if id?\n            delete @componentsById[id]\n\ngs.Object_Base = Object_Base"]}\n//# sourceURL=Object_Base_5.js"
12 + "compiledContent": "var Object_Base;\n\nObject_Base = (function() {\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 Object_Base.prototype.onDataBundleRestore = function(data, context) {\n if (this.id) {\n return window[\"$\" + this.id] = this;\n }\n };\n\n Object_Base.accessors(\"group\", {\n set: function(g) {\n var ref;\n this.group_ = g;\n return (ref = gs.ObjectManager.current) != null ? ref.addToGroup(this, g) : void 0;\n },\n get: function() {\n return this.group_;\n }\n });\n\n Object_Base.accessors(\"order\", {\n set: function(o) {\n var ref;\n if (o !== this.order_) {\n this.order_ = o;\n return (ref = this.parent) != null ? ref.needsSort = true : void 0;\n }\n },\n get: function() {\n return this.order_;\n }\n });\n\n Object_Base.accessors(\"needsUpdate\", {\n set: function(v) {\n var parent;\n this.needsUpdate_ = v;\n parent = this.parent;\n while (parent) {\n parent.needsUpdate_ = true;\n parent = parent.parent;\n }\n if (v) {\n return this.requestSubUpdate();\n }\n },\n get: function() {\n return this.needsUpdate_ || SceneManager.scene.preparing;\n }\n });\n\n Object_Base.prototype.requestSubUpdate = function() {\n var j, len, object, ref;\n ref = this.subObjects;\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n if (object) {\n object.needsUpdate_ = true;\n object.requestSubUpdate();\n }\n }\n return null;\n };\n\n Object_Base.accessors(\"needsFullUpdate\", {\n set: function(v) {\n var j, len, object, ref, results;\n this.needsUpdate = v;\n if (v) {\n ref = this.subObjects;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n results.push(object.needsFullUpdate = v);\n }\n return results;\n }\n },\n get: function() {\n return this.needsUpdate_;\n }\n });\n\n\n /**\n * The base class for all game objects. A game object itself doesn't implement\n * any game logic but uses components and sub-objects for that.\n *\n * @module gs\n * @class Object_Base\n * @memberof gs\n * @constructor\n */\n\n function Object_Base() {\n\n /**\n * @property subObjects\n * @type gs.Object_Base[]\n * @default []\n * A list of game-objects grouped under this game object.\n */\n var ref;\n this.subObjects = [];\n\n /**\n * @property components\n * @type gs.Component[]\n * @default []\n * A list of components defining the logic/behavior and appearance of the game object.\n */\n this.components = [];\n\n /**\n * @property componentsById\n * @type Object\n * @default []\n * All associated components by their ID.\n */\n this.componentsById = {};\n\n /**\n * @property disposed\n * @type boolean\n * @default false\n * Indicates if the game object id disposed. A disposed game object cannot be used anymore.\n */\n this.disposed = false;\n\n /**\n * @property active\n * @default true\n * Indicates if the game object is active. An inactive game object will not be updated.\n */\n this.active = true;\n this.input = false;\n\n /**\n * @property id\n * @type string\n * @default null\n * The game object's UID (Unique ID)\n */\n this.id = null;\n\n /**\n * @property group\n * @default null\n * @type string\n * The game object's group. To get all object's of a specific group the gs.ObjectManager.objectsByGroup property can be used.\n */\n this.group = null;\n\n /**\n * @property parent\n * @type gs.Object_Base\n * @default null\n * The parent object if the game object is a sub-object of another game object.\n */\n this.parent = null;\n\n /**\n * @property order\n * @type number\n * @default 0\n * Controls the update-order. The smaller the value the earlier the game object is updated before other game objects are updated.\n */\n this.order = 0;\n\n /**\n * @property rIndex\n * @type number\n * @default 0\n * Holds the render-index if the game object has a graphical representation on screen. The render-index is the\n * index of the game object's graphic-object(gs.GraphicObject) in the current list of graphic-objects. The render-index\n * is read-only. Setting the render-index to a certain value has no effect.\n */\n this.rIndex = 0;\n\n /**\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the list of sub-objects needs to be sorted by order because of a change.\n */\n this.needsSort = true;\n\n /**\n * @property needsSort\n * @type boolean\n * @default true\n * Indicates if the UI object needs to be updated.\n */\n this.needsUpdate = true;\n\n /**\n * @property initialized\n * @type boolean\n * @default true\n * Indicates if the game object and its components have been initialized.\n */\n this.initialized = false;\n\n /**\n * @property customData\n * @type Object\n * @default {}\n * A custom data object which can be used to add any custom data/fields to the game\n * object. It is an empty object by default.\n */\n this.customData = {};\n if ((ref = gs.ObjectManager.current) != null) {\n ref.registerObject(this);\n }\n }\n\n\n /**\n * Disposes the object with all its components and sub-objects. A disposed object will be\n * removed from the parent automatically.\n *\n * @method dispose\n */\n\n Object_Base.prototype.dispose = function() {\n var ref;\n if (!this.disposed) {\n this.disposed = true;\n this.disposeComponents();\n this.disposeObjects();\n if ((ref = gs.ObjectManager.current) != null) {\n ref.unregisterObject(this);\n }\n }\n return null;\n };\n\n\n /**\n * Disposes all sub-objects.\n *\n * @method disposeObjects\n * @protected\n */\n\n Object_Base.prototype.disposeObjects = function() {\n var j, len, ref, results, subObject;\n ref = this.subObjects;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n subObject = ref[j];\n results.push(subObject != null ? typeof subObject.dispose === \"function\" ? subObject.dispose() : void 0 : void 0);\n }\n return results;\n };\n\n\n /**\n * Disposes all components\n *\n * @method disposeComponents\n * @protected\n */\n\n Object_Base.prototype.disposeComponents = function() {\n var component, j, len, ref, results;\n ref = this.components;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n results.push(component != null ? typeof component.dispose === \"function\" ? component.dispose() : void 0 : void 0);\n }\n return results;\n };\n\n\n /**\n * Calls setup-routine on all components.\n *\n * @method setup\n */\n\n Object_Base.prototype.setup = function() {\n var component, j, len, ref;\n ref = this.components;\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n if (!(component != null ? component.isSetup : void 0)) {\n component.setup();\n }\n }\n this.initialized = true;\n return null;\n };\n\n\n /**\n * Deserializes components from a data-bundle object.\n * \n * @method componentsFromDataBundle\n * @param {Object} data The data-bundle object.\n */\n\n Object_Base.prototype.componentsFromDataBundle = function(data) {\n var component, componentObject, j, len, ref;\n if (data != null ? data.components : void 0) {\n ref = data.components;\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n componentObject = new gs[component.className](component);\n this.addComponent(componentObject);\n }\n delete data.components;\n }\n return null;\n };\n\n\n /**\n * Serializes components of a specified type to a data-bundle. A component\n * needs to implement the toDataBundle method for correct serialization.\n *\n * @method componentsToDataBundle\n * @param {String} type - A component class name.\n * @return A data bundle.\n */\n\n Object_Base.prototype.componentsToDataBundle = function(type) {\n var bundle, component, components, j, len, ref;\n components = [];\n ref = this.components;\n for (j = 0, len = ref.length; j < len; j++) {\n component = ref[j];\n if (component instanceof type) {\n if (component.toDataBundle == null) {\n continue;\n }\n bundle = component.toDataBundle();\n bundle.className = component.constructor.name;\n components.push(bundle);\n }\n }\n return components;\n };\n\n\n /**\n * Starts a full-refresh on all sub-objects\n *\n * @method fullRefresh\n */\n\n Object_Base.prototype.fullRefresh = function() {\n var j, len, object, ref;\n ref = this.subObjects;\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n if (object) {\n object.needsUpdate = true;\n object.fullRefresh();\n }\n }\n return null;\n };\n\n\n /**\n * Updates the object with all parent- and sub-objects. \n *\n * @method fullUpdate\n */\n\n Object_Base.prototype.fullUpdate = function() {\n var j, len, object, parent, ref, results;\n parent = this;\n while (parent !== null) {\n parent.update();\n parent = parent.parent;\n }\n ref = this.subObjects;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n object = ref[j];\n results.push(object != null ? object.update() : void 0);\n }\n return results;\n };\n\n\n /**\n * Updates the object and all its components. This method is\n * called automatically by the parent or ObjectManager so in regular it is \n * not necessary to call it manually.\n *\n * @method update\n */\n\n Object_Base.prototype.update = function() {\n var component, i;\n if (!this.active) {\n return;\n }\n i = 0;\n while (i < this.components.length) {\n component = this.components[i];\n if (!component.disposed) {\n component.update();\n i++;\n } else {\n this.components.splice(i, 1);\n }\n }\n if (this.input) {\n Input.clear();\n }\n this.input = false;\n return null;\n };\n\n\n /**\n * Searches for the first component with the specified class name.\n *\n * @method findComponent\n * @param {String} name The class name of the component.\n * @return {Component} The component or null if a component with the specified class name cannot be found.\n */\n\n Object_Base.prototype.findComponent = function(name) {\n return this.components.first(function(v) {\n return v.constructor.name === name;\n });\n };\n\n\n /**\n * Searches for all components with the specified class name.\n *\n * @method findComponents\n * @param {String} name The class name of the components.\n * @return {Array} The components or null if no component with the specified class name has been found.\n */\n\n Object_Base.prototype.findComponents = function(name) {\n return this.components.where(function(v) {\n return v.constructor.name === name;\n });\n };\n\n\n /**\n * Searches for the component with the specified ID.\n *\n * @method findComponentById\n * @param {String} id The unique identifier of the component.\n * @return {Component} The component or null if a component with the specified ID cannot be found.\n */\n\n Object_Base.prototype.findComponentById = function(id) {\n return this.componentsById[id];\n };\n\n\n /**\n * Searches for the component with the specified name. If multiple components have the\n * same name, it will return the first match.\n *\n * @method findComponentByName\n * @param {String} name The name of the component to find.\n * @return {Component} The component or null if a component with the specified name cannot be found.\n */\n\n Object_Base.prototype.findComponentByName = function(name) {\n return this.components.first(function(v) {\n return v.name === name;\n });\n };\n\n\n /**\n * Searches for components with the specified name.\n *\n * @method findComponentsByName\n * @param {String} name The name of the components to find.\n * @return {Component[]} An array of components matching the specified name or null if no components with the specified name exist.\n */\n\n Object_Base.prototype.findComponentsByName = function(name) {\n return this.components.where(function(v) {\n return v.name === name;\n });\n };\n\n\n /**\n * Adds an object to the list of sub-objects.\n *\n * @method addObject\n * @param {Object_Base} object The object which should be added.\n */\n\n Object_Base.prototype.addObject = function(object) {\n var ref, ref1;\n if ((ref = gs.ObjectManager.current) != null) {\n ref.remove(object);\n }\n if ((ref1 = object.parent) != null) {\n ref1.removeObject(object);\n }\n object.parent = this;\n this.subObjects.push(object);\n this.needsSort = true;\n this.needsUpdate = true;\n if (object.id != null) {\n return gs.ObjectManager.current.setObjectById(object, object.id);\n }\n };\n\n\n /**\n * Inserts an object into the list of sub-objects at the specified index.\n *\n * @method insertObject\n * @param {Object_Base} object The object which should be inserted.\n * @param {Number} index The index.\n */\n\n Object_Base.prototype.insertObject = function(object, index) {\n var ref;\n gs.ObjectManager.current.remove(object);\n if ((ref = object.parent) != null) {\n ref.removeObject(object);\n }\n object.parent = this;\n this.subObjects.splice(index, 0, object);\n if (object.id != null) {\n return gs.ObjectManager.current.setObjectById(object, object.id);\n }\n };\n\n\n /**\n * Sets sub-object at the specified index.\n *\n * @method setObject\n * @param {Object_Base} object The object.\n * @param {Number} index The index.\n */\n\n Object_Base.prototype.setObject = function(object, index) {\n var ref;\n if (object) {\n gs.ObjectManager.current.remove(object);\n if ((ref = object.parent) != null) {\n ref.removeObject(object);\n }\n object.parent = this;\n }\n this.subObjects[index] = object;\n if ((object != null ? object.id : void 0) != null) {\n return gs.ObjectManager.current.setObjectById(object, object.id);\n }\n };\n\n\n /**\n * Removes the specified object from the list of sub-objects.\n *\n * @method removeObject\n * @param {Object_Base} object The object which should be removed.\n */\n\n Object_Base.prototype.removeObject = function(object) {\n this.subObjects.remove(object);\n object.parent = null;\n return this.needsUpdate = true;\n };\n\n\n /**\n * Removes the object at the specified index from the list of sub-objects.\n *\n * @method removeObjectAt\n * @param {number} index The index of the objec to remove.\n */\n\n Object_Base.prototype.removeObjectAt = function(index) {\n var object;\n object = this.subObjects[index];\n this.subObjects.splice(index, 1);\n object.parent = null;\n return this.needsUpdate = true;\n };\n\n\n /**\n * Removes all sub-objects.\n *\n * @method removeAllObjects\n */\n\n Object_Base.prototype.removeAllObjects = function() {\n var results;\n results = [];\n while (this.subObjects.length > 0) {\n results.push(this.removeObjectAt(0));\n }\n return results;\n };\n\n\n /**\n * Erases the object at the specified index. The list size\n * will not be changed but the the value at the index will be set to null.\n *\n * @method eraseObject\n * @param {Number} object The object which should be erased.\n */\n\n Object_Base.prototype.eraseObject = function(index) {\n var object;\n object = this.subObjects[index];\n if (object != null) {\n object.parent = null;\n }\n return this.subObjects[index] = null;\n };\n\n\n /**\n * Adds the specified component to the object.\n *\n * @method addComponent\n * @param {Component} component The component\n * @param {String} id An optional unique identifier for the component.\n */\n\n Object_Base.prototype.addComponent = function(component, id) {\n if (!this.components.contains(component)) {\n component.object = this;\n this.components.push(component);\n if (id != null) {\n return this.componentsById[id] = component;\n }\n }\n };\n\n\n /**\n * Inserts a component at the specified index.\n *\n * @method insertComponent\n * @param {Component} component The component.\n * @param {Number} index The index.\n * @param {String} id An optional unique identifier for the component.\n */\n\n Object_Base.prototype.insertComponent = function(component, index, id) {\n this.components.remove(component);\n component.object = this;\n this.components.splice(index, 0, component);\n if (id != null) {\n return this.componentsById[id] = component;\n }\n };\n\n\n /**\n * Removes a component from the object.\n *\n * @method removeComponent\n * @param {Component} component The component to remove.\n */\n\n Object_Base.prototype.removeComponent = function(component) {\n this.components.remove(component);\n if (typeof id !== \"undefined\" && id !== null) {\n return delete this.componentsById[id];\n }\n };\n\n return Object_Base;\n\n})();\n\ngs.Object_Base = Object_Base;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Object_Base\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Object_Base\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        if @id\n            window[\"$\"+@id] = this\n            \n    \n    #\n    # Gets or sets the group the object belongs to.\n    #\n    # @property group\n    # @type string\n    #\n    @accessors \"group\", \n        set: (g) -> \n            @group_ = g\n            gs.ObjectManager.current?.addToGroup(this, g)\n            \n        get: -> @group_\n        \n    #\n    # Gets or sets the order-index of the object. The lower the index, the\n    # earlier the object will be updated in a list of sub-objects.\n    #\n    # @property order\n    # @type number\n    #\n    @accessors \"order\",\n        set: (o) ->\n            if o != @order_\n                @order_ = o\n                @parent?.needsSort = true\n        get: -> @order_\n        \n    #\n    # Gets or sets if an objects needs an update. If true, the parent will update\n    # the object in the next update and resets the needsUpdate property back\n    # to false.\n    #\n    # @property needsUpdate\n    # @type boolean\n    #\n    @accessors \"needsUpdate\", \n        set: (v) ->\n            @needsUpdate_ = v\n            \n            parent = @parent\n            while parent\n                parent.needsUpdate_ = yes\n                parent = parent.parent\n                \n            #if v\n            #    @parent?.needsUpdate = yes\n            #if v\n            #    for object in @subObjects\n            #        object.needsUpdate_ = v\n            if v\n                @requestSubUpdate()\n        get: -> return @needsUpdate_ || SceneManager.scene.preparing\n        \n    requestSubUpdate: ->\n        for object in @subObjects\n            if object\n                object.needsUpdate_ = yes\n                object.requestSubUpdate()\n                \n        return null\n    #\n    # Gets or sets if an object needs a full update. A full update triggers\n    # an update for all sub-objects recursively. \n    #\n    # @property needsFullUpdate\n    # @type boolean\n    #\n    @accessors \"needsFullUpdate\", \n        set: (v) ->\n            @needsUpdate = v\n            if v\n                for object in @subObjects\n                    object.needsFullUpdate = v\n        get: -> @needsUpdate_\n            \n    ###*\n    * The base class for all game objects. A game object itself doesn't implement\n    * any game logic but uses components and sub-objects for that.\n    *\n    * @module gs\n    * @class Object_Base\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: () ->\n        ###*\n        * @property subObjects\n        * @type gs.Object_Base[]\n        * @default []\n        * A list of game-objects grouped under this game object.\n        ###\n        @subObjects = []\n        \n        ###*\n        * @property components\n        * @type gs.Component[]\n        * @default []\n        * A list of components defining the logic/behavior and appearance of the game object.\n        ###\n        @components = []\n        \n        ###*\n        * @property componentsById\n        * @type Object\n        * @default []\n        * All associated components by their ID.\n        ###\n        @componentsById = {}\n        \n        ###*\n        * @property disposed\n        * @type boolean\n        * @default false\n        * Indicates if the game object id disposed. A disposed game object cannot be used anymore.\n        ###\n        @disposed = no\n        \n        ###*\n        * @property active\n        * @default true\n        * Indicates if the game object is active. An inactive game object will not be updated.\n        ###\n        @active = yes\n        \n        @input = no\n        \n        ###*\n        * @property id\n        * @type string\n        * @default null\n        * The game object's UID (Unique ID)\n        ###\n        @id = null \n        \n        ###*\n        * @property group\n        * @default null\n        * @type string\n        * The game object's group. To get all object's of a specific group the gs.ObjectManager.objectsByGroup property can be used.\n        ###\n        @group = null \n        \n        ###*\n        * @property parent\n        * @type gs.Object_Base\n        * @default null\n        * The parent object if the game object is a sub-object of another game object.\n        ###\n        @parent = null\n        \n        ###*\n        * @property order\n        * @type number\n        * @default 0\n        * Controls the update-order. The smaller the value the earlier the game object is updated before other game objects are updated.\n        ###\n        @order = 0\n        \n        ###*\n        * @property rIndex\n        * @type number\n        * @default 0\n        * Holds the render-index if the game object has a graphical representation on screen. The render-index is the\n        * index of the game object's graphic-object(gs.GraphicObject) in the current list of graphic-objects. The render-index\n        * is read-only. Setting the render-index to a certain value has no effect.\n        ###\n        @rIndex = 0\n        \n        ###*\n        * @property needsSort\n        * @type boolean\n        * @default true\n        * Indicates if the list of sub-objects needs to be sorted by order because of a change.\n        ###\n        @needsSort = yes\n        \n        ###*\n        * @property needsSort\n        * @type boolean\n        * @default true\n        * Indicates if the UI object needs to be updated.\n        ###\n        @needsUpdate = yes\n        \n        ###*\n        * @property initialized\n        * @type boolean\n        * @default true\n        * Indicates if the game object and its components have been initialized.\n        ###\n        @initialized = no\n        \n        ###*\n        * @property customData\n        * @type Object\n        * @default {}\n        * A custom data object which can be used to add any custom data/fields to the game\n        * object. It is an empty object by default.\n        ###\n        @customData = {}\n        \n        \n        gs.ObjectManager.current?.registerObject(this)\n        \n    ###*\n    * Disposes the object with all its components and sub-objects. A disposed object will be\n    * removed from the parent automatically.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        if not @disposed\n            @disposed = yes\n            @disposeComponents()\n            @disposeObjects()\n                \n            gs.ObjectManager.current?.unregisterObject(this)\n        \n        return null\n        \n    ###*\n    * Disposes all sub-objects.\n    *\n    * @method disposeObjects\n    * @protected\n    ###\n    disposeObjects: ->\n        for subObject in @subObjects\n            subObject?.dispose?()\n            \n    ###*\n    * Disposes all components\n    *\n    * @method disposeComponents\n    * @protected\n    ###\n    disposeComponents: ->\n        for component in @components\n            component?.dispose?()\n       \n    ###*\n    * Calls setup-routine on all components.\n    *\n    * @method setup\n    ###\n    setup: ->\n        for component in @components\n            component.setup() if not component?.isSetup\n            \n        @initialized = yes\n        return null\n        \n    ###*\n    * Deserializes components from a data-bundle object.\n    * \n    * @method componentsFromDataBundle\n    * @param {Object} data The data-bundle object.\n    ###\n    componentsFromDataBundle: (data) ->\n        if data?.components\n            for component in data.components\n                componentObject = new gs[component.className](component)\n                @addComponent(componentObject)\n            delete data.components\n                \n        return null\n           \n    ###*\n    * Serializes components of a specified type to a data-bundle. A component\n    * needs to implement the toDataBundle method for correct serialization.\n    *\n    * @method componentsToDataBundle\n    * @param {String} type - A component class name.\n    * @return A data bundle.\n    ###\n    componentsToDataBundle: (type) ->\n        components = []\n        for component in @components\n            if component instanceof type\n                continue unless component.toDataBundle?\n                bundle = component.toDataBundle()\n                bundle.className = component.constructor.name\n                components.push(bundle)\n        return components\n        \n    ###*\n    * Starts a full-refresh on all sub-objects\n    *\n    * @method fullRefresh\n    ###\n    fullRefresh: ->\n        for object in @subObjects\n            if object\n                object.needsUpdate = yes\n                object.fullRefresh()\n            \n        return null\n    \n    ###*\n    * Updates the object with all parent- and sub-objects. \n    *\n    * @method fullUpdate\n    ###\n    fullUpdate: ->\n        parent = this\n        while parent != null\n            parent.update()\n            parent = parent.parent\n            \n        for object in @subObjects\n            object?.update()\n        \n    ###*\n    * Updates the object and all its components. This method is\n    * called automatically by the parent or ObjectManager so in regular it is \n    * not necessary to call it manually.\n    *\n    * @method update\n    ###\n    update: ->\n        return if !@active\n        i = 0\n        while i < @components.length\n            component = @components[i]\n            if not component.disposed\n                component.update()\n                i++\n            else\n                @components.splice(i, 1)\n\n\n        if @input then Input.clear()\n        @input = no\n        \n        return null\n            \n    ###*\n    * Searches for the first component with the specified class name.\n    *\n    * @method findComponent\n    * @param {String} name The class name of the component.\n    * @return {Component} The component or null if a component with the specified class name cannot be found.\n    ###\n    findComponent: (name) -> @components.first (v) -> v.constructor.name == name\n    \n    ###*\n    * Searches for all components with the specified class name.\n    *\n    * @method findComponents\n    * @param {String} name The class name of the components.\n    * @return {Array} The components or null if no component with the specified class name has been found.\n    ###\n    findComponents: (name) -> @components.where (v) -> v.constructor.name == name\n    \n    ###*\n    * Searches for the component with the specified ID.\n    *\n    * @method findComponentById\n    * @param {String} id The unique identifier of the component.\n    * @return {Component} The component or null if a component with the specified ID cannot be found.\n    ###\n    findComponentById: (id) -> @componentsById[id]\n    \n    ###*\n    * Searches for the component with the specified name. If multiple components have the\n    * same name, it will return the first match.\n    *\n    * @method findComponentByName\n    * @param {String} name The name of the component to find.\n    * @return {Component} The component or null if a component with the specified name cannot be found.\n    ###\n    findComponentByName: (name) -> @components.first (v) -> v.name == name\n    \n    ###*\n    * Searches for components with the specified name.\n    *\n    * @method findComponentsByName\n    * @param {String} name The name of the components to find.\n    * @return {Component[]} An array of components matching the specified name or null if no components with the specified name exist.\n    ###\n    findComponentsByName: (name) -> @components.where (v) -> v.name == name\n    \n    ###*\n    * Adds an object to the list of sub-objects.\n    *\n    * @method addObject\n    * @param {Object_Base} object The object which should be added.\n    ###\n    addObject: (object) ->\n        gs.ObjectManager.current?.remove(object)\n        object.parent?.removeObject(object)\n        object.parent = this\n        @subObjects.push(object)\n        @needsSort = yes\n        @needsUpdate = yes\n    \n        if object.id?\n            gs.ObjectManager.current.setObjectById(object, object.id)\n        \n    ###*\n    * Inserts an object into the list of sub-objects at the specified index.\n    *\n    * @method insertObject\n    * @param {Object_Base} object The object which should be inserted.\n    * @param {Number} index The index.\n    ###\n    insertObject:(object, index) ->\n        gs.ObjectManager.current.remove(object)\n        object.parent?.removeObject(object)\n        object.parent = this\n        @subObjects.splice(index, 0, object)\n      \n        if object.id?\n            gs.ObjectManager.current.setObjectById(object, object.id)\n            \n    ###*\n    * Sets sub-object at the specified index.\n    *\n    * @method setObject\n    * @param {Object_Base} object The object.\n    * @param {Number} index The index.\n    ###\n    setObject: (object, index) ->\n        if object\n            gs.ObjectManager.current.remove(object)\n            object.parent?.removeObject(object)\n            object.parent = this\n            \n        @subObjects[index] = object\n      \n        if object?.id?\n            gs.ObjectManager.current.setObjectById(object, object.id)\n    \n    ###*\n    * Removes the specified object from the list of sub-objects.\n    *\n    * @method removeObject\n    * @param {Object_Base} object The object which should be removed.\n    ###\n    removeObject: (object) ->\n        @subObjects.remove(object)\n        object.parent = null\n        @needsUpdate = yes\n     \n    ###*\n    * Removes the object at the specified index from the list of sub-objects.\n    *\n    * @method removeObjectAt\n    * @param {number} index The index of the objec to remove.\n    ###   \n    removeObjectAt: (index) ->\n        object = @subObjects[index]\n        @subObjects.splice(index, 1)\n        object.parent = null\n        @needsUpdate = yes\n    \n    ###*\n    * Removes all sub-objects.\n    *\n    * @method removeAllObjects\n    ###     \n    removeAllObjects: ->\n        while @subObjects.length > 0\n            @removeObjectAt(0)\n    \n    ###*\n    * Erases the object at the specified index. The list size\n    * will not be changed but the the value at the index will be set to null.\n    *\n    * @method eraseObject\n    * @param {Number} object The object which should be erased.\n    ###\n    eraseObject: (index) ->\n        object = @subObjects[index]\n        object?.parent = null\n        @subObjects[index] = null\n    \n    ###*\n    * Adds the specified component to the object.\n    *\n    * @method addComponent\n    * @param {Component} component The component\n    * @param {String} id An optional unique identifier for the component.\n    ###\n    addComponent: (component, id) ->\n        if not @components.contains(component)\n            component.object = this\n            @components.push(component)\n            if id?\n                @componentsById[id] = component\n    ###*\n    * Inserts a component at the specified index.\n    *\n    * @method insertComponent\n    * @param {Component} component The component.\n    * @param {Number} index The index.\n    * @param {String} id An optional unique identifier for the component.\n    ###    \n    insertComponent: (component, index, id) ->\n        @components.remove(component)\n        component.object = this\n        @components.splice(index, 0, component)\n        if id?\n            @componentsById[id] = component\n    \n    ###*\n    * Removes a component from the object.\n    *\n    * @method removeComponent\n    * @param {Component} component The component to remove.\n    ###  \n    removeComponent: (component) -> \n        @components.remove(component)\n        if id?\n            delete @componentsById[id]\n\ngs.Object_Base = Object_Base"]}\n//# sourceURL=Object_Base_5.js"
13 13 },
14 14 "summary": [
15 15 "name",