From db5cd70f04824216506d0e6a04dcd927bd7e5421 Mon Sep 17 00:00:00 2001 From: cheapie Date: Thu, 25 Apr 2024 14:14:39 -0500 Subject: Require sneak to be held to remove controllers/dispatchers These nodes are a huge pain to set back up if one is accidentally removed. This makes that less likely. --- controller.lua | 12 ++++++++++++ dispatcher.lua | 12 ++++++++++++ 2 files changed, 24 insertions(+) diff --git a/controller.lua b/controller.lua index 7001a91..184da36 100644 --- a/controller.lua +++ b/controller.lua @@ -116,6 +116,16 @@ local function controllerleds(pos,running) end end +local function candig(_,player) + local controls = player:get_player_control() + if controls.sneak then + return true + else + minetest.chat_send_player(player:get_player_name(),"Hold the sneak button while digging to remove.") + return false + end +end + minetest.register_node("celevator:controller",{ description = "Elevator Controller", groups = { @@ -148,6 +158,7 @@ minetest.register_node("celevator:controller",{ on_destruct = ondestruct, on_rotate = onrotate, on_receive_fields = handlefields, + can_dig = candig, on_construct = function(pos) local meta = minetest.get_meta(pos) meta:set_string("mem",minetest.serialize({})) @@ -226,6 +237,7 @@ minetest.register_node("celevator:controller_open",{ on_destruct = ondestruct, on_rotate = onrotate, on_receive_fields = handlefields, + can_dig = candig, on_punch = function(pos,node,puncher) if not puncher:is_player() then return diff --git a/dispatcher.lua b/dispatcher.lua index 6a8a77a..b58c6eb 100644 --- a/dispatcher.lua +++ b/dispatcher.lua @@ -89,6 +89,16 @@ local function handlefields(pos,_,fields,sender) celevator.dispatcher.run(pos,event) end +local function candig(_,player) + local controls = player:get_player_control() + if controls.sneak then + return true + else + minetest.chat_send_player(player:get_player_name(),"Hold the sneak button while digging to remove.") + return false + end +end + minetest.register_node("celevator:dispatcher",{ description = "Elevator Dispatcher", groups = { @@ -121,6 +131,7 @@ minetest.register_node("celevator:dispatcher",{ on_destruct = ondestruct, on_rotate = onrotate, on_receive_fields = handlefields, + can_dig = candig, on_construct = function(pos) local meta = minetest.get_meta(pos) meta:set_string("mem",minetest.serialize({})) @@ -198,6 +209,7 @@ minetest.register_node("celevator:dispatcher_open",{ on_destruct = ondestruct, on_rotate = onrotate, on_receive_fields = handlefields, + can_dig = candig, on_punch = function(pos,node,puncher) if not puncher:is_player() then return -- cgit v1.2.3