mirror of
https://bitbucket.org/Infinatum/scaffolding.git
synced 2025-01-24 23:30:20 +01:00
New Branch
Adding New auto build system
This commit is contained in:
parent
5649827170
commit
a00e2ff125
92
init.lua
92
init.lua
@ -1,3 +1,5 @@
|
|||||||
|
|
||||||
|
|
||||||
print("scaffolding: Loading 'functions.lua'")
|
print("scaffolding: Loading 'functions.lua'")
|
||||||
dofile(minetest.get_modpath("scaffolding").."/functions.lua")
|
dofile(minetest.get_modpath("scaffolding").."/functions.lua")
|
||||||
|
|
||||||
@ -26,21 +28,40 @@ minetest.register_node("scaffolding:scaffolding", {
|
|||||||
puncher:get_inventory():add_item("main", ItemStack("scaffolding:scaffolding"))
|
puncher:get_inventory():add_item("main", ItemStack("scaffolding:scaffolding"))
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
--[[on_rightclick = function(pos, node, player, itemstack, pointed_thing)
|
on_rightclick = function(pos, node, player, itemstack, pointed_thing)
|
||||||
if itemstack:get_name() == "scaffolding:scaffolding_wrench" then
|
if itemstack:get_name() == "scaffolding:scaffolding" then
|
||||||
node.name = "scaffolding:reinforced_scaffolding"
|
|
||||||
minetest.env:set_node(pos, node)
|
-- many thanks to addi for improveing (rewriteing) my crappy code --
|
||||||
|
local name = minetest.get_node(pos).name -- get loacation of node
|
||||||
|
height = 0; -- set hite of scaffolding (not set)
|
||||||
|
|
||||||
|
--[[ debug stuff ]]
|
||||||
|
minetest.chat_send_all(string.format("node: %s",name))
|
||||||
|
|
||||||
|
minetest.chat_send_all(string.format("node: %s %s %s ",pos.x, pos.y, pos.z ))
|
||||||
|
|
||||||
|
repeat
|
||||||
|
pos.y = pos.y + 1; --every run get one node up
|
||||||
|
height = height + 1
|
||||||
|
local current_node = minetest.get_node(pos); --get the node of the new position
|
||||||
|
minetest.chat_send_all(string.format("found %q at location: %s",
|
||||||
|
current_node.name,
|
||||||
|
minetest.pos_to_string(pos)
|
||||||
|
))
|
||||||
|
|
||||||
|
if current_node.name == "air" then
|
||||||
|
minetest.set_node(pos, {name = "scaffolding:scaffolding"} )
|
||||||
|
itemstack:take_item(1); --//and remove one if its the correct one
|
||||||
|
player:set_wielded_item(itemstack);--//update inventory of the player
|
||||||
|
end
|
||||||
|
until current_node.name ~= "scaffolding:scaffolding" or height >= 64 --we repeat until we find something else then "scaffolding:scaffolding"
|
||||||
|
--maybe there should be also another limit, because its currently possible to build infinite towers
|
||||||
|
minetest.chat_send_all(string.format("exit loop"))
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end,
|
end,
|
||||||
on_punch = function(pos, node, puncher)
|
|
||||||
local tool = puncher:get_wielded_item():get_name()
|
|
||||||
if tool and tool == "scaffolding:scaffolding_wrench" then
|
|
||||||
node.name = "air"
|
|
||||||
minetest.env:set_node(pos, node)
|
|
||||||
puncher:get_inventory():add_item("main", ItemStack("scaffolding:scaffolding"))
|
|
||||||
end
|
|
||||||
end,]]
|
|
||||||
node_box = {
|
node_box = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {
|
fixed = {
|
||||||
@ -211,22 +232,39 @@ minetest.register_node("scaffolding:reinforced_scaffolding", {
|
|||||||
puncher:get_inventory():add_item("main", ItemStack("scaffolding:scaffolding"))
|
puncher:get_inventory():add_item("main", ItemStack("scaffolding:scaffolding"))
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
--[[on_rightclick = function(pos, node, puncher)
|
on_rightclick = function(pos, node, player, itemstack, pointed_thing)
|
||||||
local tool = puncher:get_wielded_item():get_name()
|
if itemstack:get_name() == "scaffolding:iron_scaffolding" then
|
||||||
if tool and tool == "scaffolding:scaffolding_wrench" then
|
|
||||||
node.name = "scaffolding:reinforced_iron_scaffolding"
|
-- many thanks to addi for improveing (rewriteing) my crappy code --
|
||||||
minetest.env:set_node(pos, node)
|
local name = minetest.get_node(pos).name -- get loacation of node
|
||||||
|
height = 0; -- set hite of scaffolding (not set)
|
||||||
|
|
||||||
|
--[[ debug stuff ]]
|
||||||
|
minetest.chat_send_all(string.format("node: %s",name))
|
||||||
|
|
||||||
|
minetest.chat_send_all(string.format("node: %s %s %s ",pos.x, pos.y, pos.z ))
|
||||||
|
|
||||||
|
repeat
|
||||||
|
pos.y = pos.y + 1; --every run get one node up
|
||||||
|
height = height + 1
|
||||||
|
local current_node = minetest.get_node(pos); --get the node of the new position
|
||||||
|
minetest.chat_send_all(string.format("found %q at location: %s",
|
||||||
|
current_node.name,
|
||||||
|
minetest.pos_to_string(pos)
|
||||||
|
))
|
||||||
|
|
||||||
|
if current_node.name == "air" then
|
||||||
|
minetest.set_node(pos, {name = "scaffolding:iron_scaffolding"} )
|
||||||
|
itemstack:take_item(1); --//and remove one if its the correct one
|
||||||
|
player:set_wielded_item(itemstack);--//update inventory of the player
|
||||||
end
|
end
|
||||||
|
until current_node.name ~= "scaffolding:iron_scaffolding" or height >= 64 --we repeat until we find something else then "scaffolding:scaffolding"
|
||||||
|
--maybe there should be also another limit, because its currently possible to build infinite towers
|
||||||
|
minetest.chat_send_all(string.format("exit loop"))
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
end,
|
end,
|
||||||
on_punch = function(pos, node, puncher)
|
|
||||||
local tool = puncher:get_wielded_item():get_name()
|
|
||||||
if tool and tool == "scaffolding:scaffolding_wrench" then
|
|
||||||
node.name = "air"
|
|
||||||
minetest.env:set_node(pos, node)
|
|
||||||
--puncher:get_inventory():remove_item("main", ItemStack("beer_test:tankard"))
|
|
||||||
puncher:get_inventory():add_item("main", ItemStack("scaffolding:scaffolding"))
|
|
||||||
end
|
|
||||||
end,]]
|
|
||||||
after_dig_node = function(pos, node, metadata, digger)
|
after_dig_node = function(pos, node, metadata, digger)
|
||||||
default.dig_up(pos, node, digger)
|
default.dig_up(pos, node, digger)
|
||||||
end,
|
end,
|
||||||
@ -481,5 +519,3 @@ minetest.register_craft({
|
|||||||
{'default:steel_ingot', '', ''},
|
{'default:steel_ingot', '', ''},
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user