Actually fix facedir-rotated nodes placed using minetest.env:place_node()
This commit is contained in:
parent
a2738dec59
commit
0b61253931
@ -148,11 +148,13 @@ function minetest.item_place_node(itemstack, placer, pointed_thing)
|
|||||||
local dir = {x = under.x - above.x, y = under.y - above.y, z = under.z - above.z}
|
local dir = {x = under.x - above.x, y = under.y - above.y, z = under.z - above.z}
|
||||||
newnode.param2 = minetest.dir_to_wallmounted(dir)
|
newnode.param2 = minetest.dir_to_wallmounted(dir)
|
||||||
-- Calculate the direction for furnaces and chests and stuff
|
-- Calculate the direction for furnaces and chests and stuff
|
||||||
elseif def.paramtype2 == 'facedir' and placer then
|
elseif def.paramtype2 == 'facedir' then
|
||||||
local playerpos = placer:getpos()
|
local placer_pos = placer:getpos()
|
||||||
local dir = {x = pos.x - playerpos.x, y = pos.y - playerpos.y, z = pos.z - playerpos.z}
|
if placer_pos then
|
||||||
newnode.param2 = minetest.dir_to_facedir(dir)
|
local dir = {x = pos.x - placer_pos.x, y = pos.y - placer_pos.y, z = pos.z - placer_pos.z}
|
||||||
minetest.log("action", "facedir: " .. newnode.param2)
|
newnode.param2 = minetest.dir_to_facedir(dir)
|
||||||
|
minetest.log("action", "facedir: " .. newnode.param2)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Add node and update
|
-- Add node and update
|
||||||
|
@ -447,6 +447,9 @@ minetest.register_node("experimental:tester_node_1", {
|
|||||||
tile_images = {"wieldhand.png"},
|
tile_images = {"wieldhand.png"},
|
||||||
groups = {oddly_breakable_by_hand=2},
|
groups = {oddly_breakable_by_hand=2},
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
-- This was known to cause a bug in minetest.item_place_node() when used
|
||||||
|
-- via minetest.env:place_node(), causing a placer with no position
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
experimental.print_to_everything("experimental:tester_node_1:on_construct("..minetest.pos_to_string(pos)..")")
|
experimental.print_to_everything("experimental:tester_node_1:on_construct("..minetest.pos_to_string(pos)..")")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user