Improve rightclick handler of doors
This commit is contained in:
parent
5bc7589042
commit
7862875f85
@ -41,15 +41,21 @@ function door.register_door(name, def)
|
|||||||
groups = def.groups,
|
groups = def.groups,
|
||||||
|
|
||||||
on_place = function(itemstack, placer, pointed_thing)
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
if not pointed_thing.type == "node" then
|
-- Handle pointed node handlers first
|
||||||
return itemstack
|
local handled, handled_itemstack = util.on_place_pointed_node_handler(itemstack, placer, pointed_thing)
|
||||||
|
if handled then
|
||||||
|
return handled_itemstack
|
||||||
end
|
end
|
||||||
|
|
||||||
local ptu = pointed_thing.under
|
-- Check protection
|
||||||
local nu = minetest.get_node(ptu)
|
local pos_protected = minetest.get_pointed_thing_position(pointed_thing, true)
|
||||||
if minetest.registered_nodes[nu.name].on_rightclick then
|
for i=0, 1 do
|
||||||
return minetest.registered_nodes[nu.name].on_rightclick(
|
local protpos = vector.add(pos_protected, vector.new(0, i, 0))
|
||||||
ptu, nu, placer, itemstack)
|
if minetest.is_protected(protpos, placer:get_player_name()) and
|
||||||
|
not minetest.check_player_privs(placer, "protection_bypass") then
|
||||||
|
minetest.record_protection_violation(protpos, placer:get_player_name())
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local pt = pointed_thing.above
|
local pt = pointed_thing.above
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
name = rp_door
|
name = rp_door
|
||||||
depends = rp_sounds, rp_crafting, rp_achievements
|
depends = rp_util, rp_sounds, rp_crafting, rp_achievements
|
||||||
|
@ -264,7 +264,7 @@ end
|
|||||||
-- on_place handler
|
-- on_place handler
|
||||||
-- Recommended usage is by putting this boilerplate code at the beginning of your function:
|
-- Recommended usage is by putting this boilerplate code at the beginning of your function:
|
||||||
--[[
|
--[[
|
||||||
local handled, handled_itemstack = on_place_pointed_node_handler(itemstack, placer, pointed_thing)
|
local handled, handled_itemstack = util.on_place_pointed_node_handler(itemstack, placer, pointed_thing)
|
||||||
if handled then
|
if handled then
|
||||||
return handled_itemstack
|
return handled_itemstack
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user