mirror of
https://github.com/minetest-mods/mesecons.git
synced 2025-01-11 17:40:20 +01:00
Doors: Use new mesh door API if available
I've implemented a new door API in minetest_game that performs all the needed things to assure doors are properly openend and closed, without mods needing to know the inner details of what needs to be done. Mesecons can just fetch a reference to the door object and call the appropriate open or close method, which simplifies this code a lot. For compatibility, this code retains the old code path and tests whether the new API is available, so this code remains functional if the new API is not available. Since the metal trapdoor was only recently added, I added it to the new API codepath only, it's unlikely to be present on older versions of minetest_game anyway. As a benefit from the new door API, there is now absolutely no more accidental switching closed trapdoors to open on power off, which could happen with the old method - since that was just a simple toggle.
This commit is contained in:
parent
f56c4ce35c
commit
fb4c440265
@ -20,31 +20,53 @@ local function on_rightclick(pos, dir, check_name, replace, replace_dir, params)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function meseconify_door(name)
|
local function meseconify_door(name)
|
||||||
if not minetest.registered_items[name] then return end
|
if minetest.registered_items[name .. "_b_1"] then
|
||||||
|
-- old style double-node doors
|
||||||
|
local function toggle_state1 (pos, node)
|
||||||
|
on_rightclick(pos, 1, name.."_t_1", name.."_b_2", name.."_t_2", {1,2,3,0})
|
||||||
|
end
|
||||||
|
|
||||||
local function toggle_state1 (pos, node)
|
local function toggle_state2 (pos, node)
|
||||||
on_rightclick(pos, 1, name.."_t_1", name.."_b_2", name.."_t_2", {1,2,3,0})
|
on_rightclick(pos, 1, name.."_t_2", name.."_b_1", name.."_t_1", {3,0,1,2})
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.override_item(name.."_b_1", {
|
||||||
|
mesecons = {effector = {
|
||||||
|
action_on = toggle_state1,
|
||||||
|
action_off = toggle_state1,
|
||||||
|
rules = mesecon.rules.pplate
|
||||||
|
}}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.override_item(name.."_b_2", {
|
||||||
|
mesecons = {effector = {
|
||||||
|
action_on = toggle_state2,
|
||||||
|
action_off = toggle_state2,
|
||||||
|
rules = mesecon.rules.pplate
|
||||||
|
}}
|
||||||
|
})
|
||||||
|
elseif minetest.registered_items[name .. "_a"] then
|
||||||
|
-- new style mesh node based doors
|
||||||
|
local override = {
|
||||||
|
mesecons = {effector = {
|
||||||
|
action_on = function(pos, node)
|
||||||
|
local door = doors.get(pos)
|
||||||
|
if door then
|
||||||
|
door:open()
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
action_off = function(pos, node)
|
||||||
|
local door = doors.get(pos)
|
||||||
|
if door then
|
||||||
|
door:close()
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
rules = mesecon.rules.pplate
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
minetest.override_item(name .. "_a", override)
|
||||||
|
minetest.override_item(name .. "_b", override)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function toggle_state2 (pos, node)
|
|
||||||
on_rightclick(pos, 1, name.."_t_2", name.."_b_1", name.."_t_1", {3,0,1,2})
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.override_item(name.."_b_1", {
|
|
||||||
mesecons = {effector = {
|
|
||||||
action_on = toggle_state1,
|
|
||||||
action_off = toggle_state1,
|
|
||||||
rules = mesecon.rules.pplate
|
|
||||||
}},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.override_item(name.."_b_2", {
|
|
||||||
mesecons = {effector = {
|
|
||||||
action_on = toggle_state2,
|
|
||||||
action_off = toggle_state2,
|
|
||||||
rules = mesecon.rules.pplate
|
|
||||||
}},
|
|
||||||
})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
meseconify_door("doors:door_wood")
|
meseconify_door("doors:door_wood")
|
||||||
@ -67,18 +89,41 @@ local function trapdoor_switch(pos, node)
|
|||||||
minetest.get_meta(pos):set_int("state", state == 1 and 0 or 1)
|
minetest.get_meta(pos):set_int("state", state == 1 and 0 or 1)
|
||||||
end
|
end
|
||||||
|
|
||||||
if minetest.registered_nodes["doors:trapdoor"] then
|
if doors and doors.get then
|
||||||
minetest.override_item("doors:trapdoor", {
|
local override = {
|
||||||
mesecons = {effector = {
|
mesecons = {effector = {
|
||||||
action_on = trapdoor_switch,
|
action_on = function(pos, node)
|
||||||
action_off = trapdoor_switch
|
local door = doors.get(pos)
|
||||||
|
if door then
|
||||||
|
door:open()
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
action_off = function(pos, node)
|
||||||
|
local door = doors.get(pos)
|
||||||
|
if door then
|
||||||
|
door:close()
|
||||||
|
end
|
||||||
|
end,
|
||||||
}},
|
}},
|
||||||
})
|
}
|
||||||
|
minetest.override_item("doors:trapdoor", override)
|
||||||
|
minetest.override_item("doors:trapdoor_open", override)
|
||||||
|
minetest.override_item("doors:trapdoor_steel", override)
|
||||||
|
minetest.override_item("doors:trapdoor_steel_open", override)
|
||||||
|
else
|
||||||
|
if minetest.registered_nodes["doors:trapdoor"] then
|
||||||
|
minetest.override_item("doors:trapdoor", {
|
||||||
|
mesecons = {effector = {
|
||||||
|
action_on = trapdoor_switch,
|
||||||
|
action_off = trapdoor_switch
|
||||||
|
}},
|
||||||
|
})
|
||||||
|
|
||||||
minetest.override_item("doors:trapdoor_open", {
|
minetest.override_item("doors:trapdoor_open", {
|
||||||
mesecons = {effector = {
|
mesecons = {effector = {
|
||||||
action_on = trapdoor_switch,
|
action_on = trapdoor_switch,
|
||||||
action_off = trapdoor_switch
|
action_off = trapdoor_switch
|
||||||
}},
|
}},
|
||||||
})
|
})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user