summaryrefslogtreecommitdiff
path: root/util_movement.lua
diff options
context:
space:
mode:
authorFaceDeer <derksenmobile@gmail.com>2017-01-08 01:23:10 -0700
committerFaceDeer <derksenmobile@gmail.com>2017-01-08 01:23:10 -0700
commitd7e5309833bc7044447982424dc8431d84d7a1a0 (patch)
treedb1081d61fd650db0593ef190b0bb32f93a19b3a /util_movement.lua
parente704249735372a3232883cc8b7f25679f4949a8d (diff)
Added a rotation controller
Well that was a lot of work. Also, switched the "waiting" timer management to the actual on_timer system - I noticed that minetest.after wasn't persisting through server shutdown and restart, that could put a controller in a "broken" state.
Diffstat (limited to 'util_movement.lua')
-rw-r--r--util_movement.lua6
1 files changed, 4 insertions, 2 deletions
diff --git a/util_movement.lua b/util_movement.lua
index 218ba48..f7c36dd 100644
--- a/util_movement.lua
+++ b/util_movement.lua
@@ -6,8 +6,10 @@ digtron.move_node = function(pos, newpos, player_name)
minetest.log("action", string.format("%s moves %s from (%d, %d, %d) to (%d, %d, %d), displacing %s", player_name, node.name, pos.x, pos.y, pos.z, newpos.x, newpos.y, newpos.z, oldnode.name))
minetest.add_node(newpos, { name=node.name, param1=node.param1, param2=node.param2 })
-- copy the metadata
- local oldmeta = minetest.get_meta(pos):to_table()
- minetest.get_meta(newpos):from_table(oldmeta)
+ local oldmeta_table = minetest.get_meta(pos):to_table()
+ local meta = minetest.get_meta(newpos)
+ meta:from_table(oldmeta_table)
+ meta:set_string("waiting", nil) -- If a controller moves another controller that's in the waiting state, clear the waiting state otherwise it might get stuck like that (we've moved it away from the target of the pending 'clear the waiting state' delegate call). That means you can run a digtron as fast as you want by rapidly clicking between two different controllers, but shhh - don't tell the player that.
-- Move the little floaty entity inside the builders
if minetest.get_item_group(node.name, "digtron") == 4 then