forked from VoxeLibre/VoxeLibre
Fix door dropping when pushed by pistons
This commit is contained in:
parent
2dd774475f
commit
302f66977a
|
@ -141,13 +141,6 @@ function mcl_doors:register_door(name, def)
|
||||||
local tt = def.tiles_top
|
local tt = def.tiles_top
|
||||||
local tb = def.tiles_bottom
|
local tb = def.tiles_bottom
|
||||||
|
|
||||||
local function after_dig_node(pos, name, digger)
|
|
||||||
local node = minetest.get_node(pos)
|
|
||||||
if node.name == name then
|
|
||||||
minetest.node_dig(pos, node, digger)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local function on_open_close(pos, dir, check_name, replace, replace_dir, params)
|
local function on_open_close(pos, dir, check_name, replace, replace_dir, params)
|
||||||
local meta1 = minetest.get_meta(pos)
|
local meta1 = minetest.get_meta(pos)
|
||||||
pos.y = pos.y+dir
|
pos.y = pos.y+dir
|
||||||
|
@ -227,9 +220,11 @@ function mcl_doors:register_door(name, def)
|
||||||
_mcl_hardness = def._mcl_hardness,
|
_mcl_hardness = def._mcl_hardness,
|
||||||
sounds = def.sounds,
|
sounds = def.sounds,
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
after_destruct = function(bottom, oldnode)
|
||||||
pos.y = pos.y+1
|
local top = { x = bottom.x, y = bottom.y + 1, z = bottom.z }
|
||||||
after_dig_node(pos, name.."_t_1", digger)
|
if minetest.get_node(bottom).name == "air" and minetest.get_node(top).name == name.."_t_1" then
|
||||||
|
minetest.remove_node(top)
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
|
|
||||||
on_rightclick = on_rightclick,
|
on_rightclick = on_rightclick,
|
||||||
|
@ -271,9 +266,11 @@ function mcl_doors:register_door(name, def)
|
||||||
_mcl_hardness = def._mcl_hardness,
|
_mcl_hardness = def._mcl_hardness,
|
||||||
sounds = def.sounds,
|
sounds = def.sounds,
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
after_destruct = function(top, oldnode)
|
||||||
pos.y = pos.y-1
|
local bottom = { x = top.x, y = top.y - 1, z = top.z }
|
||||||
after_dig_node(pos, name.."_b_1", digger)
|
if minetest.get_node(top).name == "air" and minetest.get_node(bottom).name == name.."_b_1" and oldnode.name == name.."_t_1" then
|
||||||
|
minetest.dig_node(bottom)
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
|
|
||||||
on_rightclick = on_rightclick,
|
on_rightclick = on_rightclick,
|
||||||
|
@ -311,9 +308,11 @@ function mcl_doors:register_door(name, def)
|
||||||
_mcl_hardness = def._mcl_hardness,
|
_mcl_hardness = def._mcl_hardness,
|
||||||
sounds = def.sounds,
|
sounds = def.sounds,
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
after_destruct = function(bottom, oldnode)
|
||||||
pos.y = pos.y+1
|
local top = { x = bottom.x, y = bottom.y + 1, z = bottom.z }
|
||||||
after_dig_node(pos, name.."_t_2", digger)
|
if minetest.get_node(bottom).name == "air" and minetest.get_node(top).name == name.."_t_2" then
|
||||||
|
minetest.remove_node(top)
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
|
|
||||||
on_rightclick = on_rightclick,
|
on_rightclick = on_rightclick,
|
||||||
|
@ -355,9 +354,11 @@ function mcl_doors:register_door(name, def)
|
||||||
_mcl_hardness = def._mcl_hardness,
|
_mcl_hardness = def._mcl_hardness,
|
||||||
sounds = def.sounds,
|
sounds = def.sounds,
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
after_destruct = function(top, oldnode)
|
||||||
pos.y = pos.y-1
|
local bottom = { x = top.x, y = top.y - 1, z = top.z }
|
||||||
after_dig_node(pos, name.."_b_2", digger)
|
if minetest.get_node(top).name == "air" and minetest.get_node(bottom).name == name.."_b_2" and oldnode.name == name.."_t_2" then
|
||||||
|
minetest.dig_node(bottom)
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
|
|
||||||
on_rightclick = on_rightclick,
|
on_rightclick = on_rightclick,
|
||||||
|
|
Loading…
Reference in New Issue