//-- this file is generated! don't try editing it. import "luxe: io" for IO import "luxe: bytes" for Byter, Bytes import "luxe: world" for Block //`modifiers/field/field > runtime` types class ModifierRuntime { construct new() { } //new } //ModifierRuntime //`modifiers/field/field > runtime` compilers class ModifierRuntimeCompiler { construct new() { } bytes_count(instance) { var size = 4 //version size = size + 0 return size } //bytes_count validate(from_source_id, elements) { var fields = { "type": false, //:luxe:internal "uuid": false, //:luxe:internal "luxe.self.modifier": false, //:luxe:internal } for(element in elements) { var instance = element.value for(field in instance) { if(fields[field.key] == null) { Fiber.abort("node `%(element.key)` in `%(from_source_id)` has extra field `%(field.key)`") } //if not found } //each field for(field in fields) { var required = field.value if(required && instance[field.key] == null) { Fiber.abort("node `%(element.key)` in `%(from_source_id)` is missing a required field `%(field.key)` (and the field has no default value)") } } //each field } //each element } //validate write(compiler, instance, out) { //version out.write_int32(0) return out } //write bytes_count_block() { return 8 } //bytes_count_block write_block(compiler, out) { //source id out.write_uint32(compiler.string.hash("modifiers/field/field > runtime")) //fields count out.write_int32(0) } //write_block write(instance) { var size = bytes_count(instance) var out = Byter.new(size+8) out.write_string("LUXEMRTM") write(instance, out) return out } //write } //ModifierRuntimeCompiler //`modifiers/field/field > runtime` block types class BlockModifierRuntime { field { "field" } source { "modifiers/field/field > runtime" } construct new(block) { _block = block _inst_type = instance_type _inst = _inst_type.new(_block, 0) } construct new() { _block = Block.create() _inst_type = instance_type _inst = _inst_type.new(_block, 0) Block.set_type(_block, "modifiers/field/field > runtime") } //new instance_type { class BlockInstModifierRuntime { slot { _slot } entity { Block.get_handle(_block, _slot) } block_set_slot(value) { _slot=value return this } construct new(block, slot) { _block = block _slot = slot } //new block { _block } } //BlockInstModifierRuntime return BlockInstModifierRuntime } //instance_type block { _block } count { Block.get_count(_block) } add() { Block.add(_block) } append(other_block) { Block.append(_block, other_block) } each(c, fn) { for(i in 0 ... c) { fn.call(0, _inst.block_set_slot(i)) } } //each [slot, inst] { _inst.block_set_slot(slot) } [slot] { _inst_type.new(_block, slot) } } //BlockModifierRuntime //`modifiers/field/field > data` types class ModifierData { construct new() { _slot_scale = 1 _slot_distance = 50 } //new slot_scale { _slot_scale } slot_scale=(vvv) { _slot_scale = vvv } slot_distance { _slot_distance } slot_distance=(vvv) { _slot_distance = vvv } } //ModifierData //`modifiers/field/field > data` compilers class ModifierDataCompiler { construct new() { } bytes_count(instance) { var size = 4 //version size = size + 8 // slot_scale size = size + 8 // slot_distance size = size + 0 return size } //bytes_count validate(from_source_id, elements) { var fields = { "type": false, //:luxe:internal "uuid": false, //:luxe:internal "luxe.self.modifier": false, //:luxe:internal "slot_scale": false, "slot_distance": false, } for(element in elements) { var instance = element.value for(field in instance) { if(fields[field.key] == null) { Fiber.abort("node `%(element.key)` in `%(from_source_id)` has extra field `%(field.key)`") } //if not found } //each field for(field in fields) { var required = field.value if(required && instance[field.key] == null) { Fiber.abort("node `%(element.key)` in `%(from_source_id)` is missing a required field `%(field.key)` (and the field has no default value)") } } //each field } //each element } //validate write(compiler, instance, out) { //version out.write_int32(0) var slot_scale = instance["slot_scale"] if(slot_scale == null) slot_scale = 1 out.write_float64(slot_scale) var slot_distance = instance["slot_distance"] if(slot_distance == null) slot_distance = 50 out.write_float64(slot_distance) return out } //write bytes_count_block() { return 40 } //bytes_count_block write_block(compiler, out) { //source id out.write_uint32(compiler.string.hash("modifiers/field/field > data")) //fields count out.write_int32(2) // slot_scale out.write_uint32(compiler.string.hash("slot_scale")) out.write_uint32(467038368) //type number var slot_scale_default = 1 out.write_float64(slot_scale_default) // slot_distance out.write_uint32(compiler.string.hash("slot_distance")) out.write_uint32(467038368) //type number var slot_distance_default = 50 out.write_float64(slot_distance_default) } //write_block write(instance) { var size = bytes_count(instance) var out = Byter.new(size+8) out.write_string("LUXEMDTA") write(instance, out) return out } //write } //ModifierDataCompiler //`modifiers/field/field > data` block types class BlockModifierData { field { "field" } source { "modifiers/field/field > data" } construct new(block) { _block = block _inst_type = instance_type _inst = _inst_type.new(_block, 0) } construct new() { _block = Block.create() _inst_type = instance_type _inst = _inst_type.new(_block, 0) Block.add(_block, "slot_scale", "number", 1) Block.add(_block, "slot_distance", "number", 50) Block.set_type(_block, "modifiers/field/field > data") } //new instance_type { class BlockInstModifierData { slot_scale { Block.get(_block, "slot_scale", _slot) } slot_scale=(v) { Block.set(_block, "slot_scale", _slot, v) } slot_distance { Block.get(_block, "slot_distance", _slot) } slot_distance=(v) { Block.set(_block, "slot_distance", _slot, v) } slot { _slot } entity { Block.get_handle(_block, _slot) } block_set_slot(value) { _slot=value return this } construct new(block, slot) { _block = block _slot = slot } //new block { _block } } //BlockInstModifierData return BlockInstModifierData } //instance_type block { _block } count { Block.get_count(_block) } add() { Block.add(_block) } append(other_block) { Block.append(_block, other_block) } each(c, fn) { for(i in 0 ... c) { fn.call(0, _inst.block_set_slot(i)) } } //each [slot, inst] { _inst.block_set_slot(slot) } [slot] { _inst_type.new(_block, slot) } } //BlockModifierData //`modifiers/field/field > world` types class ModifierWorld { construct new() { } //new } //ModifierWorld //`modifiers/field/field > world` compilers class ModifierWorldCompiler { construct new() { } bytes_count(instance) { var size = 4 //version size = size + 0 return size } //bytes_count validate(from_source_id, elements) { var fields = { "type": false, //:luxe:internal "uuid": false, //:luxe:internal "luxe.self.modifier": false, //:luxe:internal } for(element in elements) { var instance = element.value for(field in instance) { if(fields[field.key] == null) { Fiber.abort("node `%(element.key)` in `%(from_source_id)` has extra field `%(field.key)`") } //if not found } //each field for(field in fields) { var required = field.value if(required && instance[field.key] == null) { Fiber.abort("node `%(element.key)` in `%(from_source_id)` is missing a required field `%(field.key)` (and the field has no default value)") } } //each field } //each element } //validate write(compiler, instance, out) { //version out.write_int32(0) return out } //write bytes_count_block() { return 8 } //bytes_count_block write_block(compiler, out) { //source id out.write_uint32(compiler.string.hash("modifiers/field/field > world")) //fields count out.write_int32(0) } //write_block write(instance) { var size = bytes_count(instance) var out = Byter.new(size+8) out.write_string("LUXEMWLD") write(instance, out) return out } //write } //ModifierWorldCompiler //`modifiers/field/field > world` block types class BlockModifierWorld { field { "field" } source { "modifiers/field/field > world" } construct new(block) { _block = block _inst_type = instance_type _inst = _inst_type.new(_block, 0) } construct new() { _block = Block.create() _inst_type = instance_type _inst = _inst_type.new(_block, 0) Block.set_type(_block, "modifiers/field/field > world") } //new instance_type { class BlockInstModifierWorld { slot { _slot } entity { Block.get_handle(_block, _slot) } block_set_slot(value) { _slot=value return this } construct new(block, slot) { _block = block _slot = slot } //new block { _block } } //BlockInstModifierWorld return BlockInstModifierWorld } //instance_type block { _block } count { Block.get_count(_block) } add() { Block.add(_block) } append(other_block) { Block.append(_block, other_block) } each(c, fn) { for(i in 0 ... c) { fn.call(0, _inst.block_set_slot(i)) } } //each [slot, inst] { _inst.block_set_slot(slot) } [slot] { _inst_type.new(_block, slot) } } //BlockModifierWorld