From 4c6c506713eab84d1a03238be079f9e808523b6c Mon Sep 17 00:00:00 2001 From: teknomunk Date: Thu, 28 Mar 2024 06:18:50 +0000 Subject: [PATCH] Implement minecart with command block --- mods/ENTITIES/mcl_minecarts/init.lua | 52 ++++++++++++++----- .../REDSTONE/mesecons_commandblock/api.lua | 1 + 2 files changed, 39 insertions(+), 14 deletions(-) diff --git a/mods/ENTITIES/mcl_minecarts/init.lua b/mods/ENTITIES/mcl_minecarts/init.lua index f6d2fac02..bec5c565a 100644 --- a/mods/ENTITIES/mcl_minecarts/init.lua +++ b/mods/ENTITIES/mcl_minecarts/init.lua @@ -698,7 +698,7 @@ local function register_entity(entity_id, def) for d=1, #drop do minetest.add_item(self.object:get_pos(), drop[d]) end - elseif puncher and killer:is_player() then + elseif killer and killer:is_player() then local inv = killer:get_inventory() for d=1, #drop do if not inv:contains_item("main", drop[d]) then @@ -841,17 +841,18 @@ function mcl_minecarts.place_minecart(itemstack, pointed_thing, placer) local cart_dir = mcl_minecarts:get_rail_direction(railpos, vector.new(1,0,0), nil, nil, railtype) cart:set_yaw(minetest.dir_to_yaw(cart_dir)) - -- Call placer - if cart._mcl_minecarts_on_place then - cart._mcl_minecarts_on_place(self, placer) - end - -- Update static data local le = cart:get_luaentity() if le then le._staticdata = make_staticdata( railtype, railpos, cart_dir ) end + -- Call placer + if le._mcl_minecarts_on_place then + print("Calling on_place") + le._mcl_minecarts_on_place(le, placer) + end + handle_cart_enter(le, railpos) local pname = "" @@ -1118,6 +1119,20 @@ register_minecart({ end end }) +function table_metadata(table) + return { + table = table, + set_string = function(self, key, value) + print("set_string("..tostring(key)..", "..tostring(value)..")") + self.table[key] = tostring(value) + end, + get_string = function(self, key) + if self.table[key] then + return tostring(self.table[key]) + end + end + } +end -- Minecart with Command Block register_minecart({ @@ -1139,18 +1154,27 @@ register_minecart({ }, icon = "mcl_minecarts_minecart_command_block.png", drop = {"mcl_minecarts:minecart"}, - on_rightclick = nil, + on_rightclick = function(self, clicker) + self._staticdata.meta = self._staticdata.meta or {} + local meta = table_metadata(self._staticdata.meta) + + mesecon.commandblock.handle_rightclick(meta, clicker) + end, _mcl_minecarts_on_place = function(self, placer) - if mesecon and mesecon.command_block then - mesecons.command_block.configure_entity(self, placer) - end + -- Create a fake metadata object that stores into the cart's staticdata + self._staticdata.meta = self._staticdata.meta or {} + local meta = table_metadata(self._staticdata.meta) + + mesecon.commandblock.initialize(meta) + mesecon.commandblock.place(meta, placer) end, on_activate_by_rail = function(self, timer) - if mesecon and mesecond.command_block then - mesecons.command_block.resolve_command_entity(self) - end + self._staticdata.meta = self._staticdata.meta or {} + local meta = table_metadata(self._staticdata.meta) + + mesecon.commandblock.action_on(meta, self.object:get_pos()) end, - creative = false + creative = true }) -- Minecart with Hopper diff --git a/mods/ITEMS/REDSTONE/mesecons_commandblock/api.lua b/mods/ITEMS/REDSTONE/mesecons_commandblock/api.lua index 50127a2d2..7edcc9083 100644 --- a/mods/ITEMS/REDSTONE/mesecons_commandblock/api.lua +++ b/mods/ITEMS/REDSTONE/mesecons_commandblock/api.lua @@ -211,6 +211,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields) return end local meta = formspec_metas[fs_id] + formspec_metas[fs_id] = nil -- Verify the command local check, error_message = check_commands(fields.commands, player:get_player_name())