diff options
author | Diego MartÃnez <kaeza@users.sf.net> | 2013-06-21 00:20:20 -0300 |
---|---|---|
committer | Diego MartÃnez <kaeza@users.sf.net> | 2013-06-21 00:20:20 -0300 |
commit | 0039f38b9497e9c8be830c05b5dd59a7e1633b83 (patch) | |
tree | 3c566e9e07a974c2243d630e2f01d1a76529b154 | |
parent | a1da74209b75c5543bd6f2e1cc8b1643adf13ffa (diff) |
Deployers and constructors now able to "place" craftitems.
-rw-r--r-- | technic/constructor.lua | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/technic/constructor.lua b/technic/constructor.lua index 58d2dad..2b031e5 100644 --- a/technic/constructor.lua +++ b/technic/constructor.lua @@ -283,6 +283,22 @@ deploy_node =function (inv, slot_name, pos1, node1, node) stack1[1]:take_item() inv:set_stack(slot_name, 1, stack1[1]) elseif def.type == "craft" then + if def.on_place then + -- print("deploy_node: item has on_place. trying...") + local ok, stk = pcall(def.on_place, stack1[1], nil, { + -- Fake pointed_thing + type = "node", + above = pos1, + under = { x=pos1.x, y=pos1.y-1, z=pos1.z }, + }) + if ok then + -- print("deploy_node: on_place succeeded!") + inv:set_stack(slot_name, 1, stk or stack1[1]) + return + -- else + -- print("deploy_node: WARNING: error while running on_place: "..tostring(stk)) + end + end minetest.item_place_object(stack1[1], nil, { -- Fake pointed_thing type = "node", |