don't check for sticky blocks in locations that are already being pushed
This commit is contained in:
parent
00359e7ae8
commit
ba9b2509a0
|
@ -95,16 +95,19 @@ function mesecon.mvps_get_stack(pos, dir, maximum, all_pull_sticky)
|
||||||
-- position
|
-- position
|
||||||
for _, r in ipairs(mesecon.rules.alldirs) do
|
for _, r in ipairs(mesecon.rules.alldirs) do
|
||||||
local adjpos = vector.add(np, r)
|
local adjpos = vector.add(np, r)
|
||||||
local adjnode = minetest.get_node(adjpos)
|
-- optimization: don't check blocks that are already part of the stack
|
||||||
if minetest.registered_nodes[adjnode.name]
|
if not pos_set[minetest.hash_node_position(adjpos)] then
|
||||||
and minetest.registered_nodes[adjnode.name].mvps_sticky then
|
local adjnode = minetest.get_node(adjpos)
|
||||||
local sticksto = minetest.registered_nodes[adjnode.name]
|
if minetest.registered_nodes[adjnode.name]
|
||||||
.mvps_sticky(adjpos, adjnode)
|
and minetest.registered_nodes[adjnode.name].mvps_sticky then
|
||||||
|
local sticksto = minetest.registered_nodes[adjnode.name]
|
||||||
-- connects to this position?
|
.mvps_sticky(adjpos, adjnode)
|
||||||
for _, link in ipairs(sticksto) do
|
|
||||||
if vector.equals(link, np) then
|
-- connects to this position?
|
||||||
frontiers:add(adjpos)
|
for _, link in ipairs(sticksto) do
|
||||||
|
if vector.equals(link, np) then
|
||||||
|
frontiers:add(adjpos)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue