summaryrefslogtreecommitdiff
path: root/anvil
diff options
context:
space:
mode:
Diffstat (limited to 'anvil')
-rw-r--r--anvil/init.lua152
1 files changed, 81 insertions, 71 deletions
diff --git a/anvil/init.lua b/anvil/init.lua
index e4bc8bd..fa554cd 100644
--- a/anvil/init.lua
+++ b/anvil/init.lua
@@ -6,9 +6,9 @@
---------------------------------------------------------------------------------------
anvil = {
- setting = {
- item_displacement = 7/16,
- }
+ setting = {
+ item_displacement = 7/16,
+ }
}
minetest.register_alias("castle:anvil", "anvil:anvil")
@@ -24,7 +24,7 @@ minetest.register_tool("anvil:hammer", {
_doc_items_usagehelp = S("Use this hammer to strike blows upon an anvil bearing a damaged tool and you can repair it. It can also be used for smashing stone, but it is not well suited to this task."),
image = "anvil_tool_steelhammer.png",
inventory_image = "anvil_tool_steelhammer.png",
-
+
tool_capabilities = {
full_punch_interval = 0.8,
max_drop_level=1,
@@ -133,27 +133,29 @@ minetest.register_node("anvil:anvil", {
{-0.35,-0.1,-0.2,0.35,0.1,0.2},
}
},
+
on_construct = function(pos)
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
inv:set_size("input", 1)
end,
-
+
after_place_node = function(pos, placer)
local meta = minetest.get_meta(pos)
meta:set_string("owner", placer:get_player_name() or "")
+ meta:set_string("infotext",placer:get_player_name().."'s anvil")
end,
-
+
can_dig = function(pos,player)
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
-
+
if not inv:is_empty("input") then
return false
end
return true
end,
-
+
allow_metadata_inventory_put = function(pos, listname, index, stack, player)
local meta = minetest.get_meta(pos)
if listname~="input" then
@@ -162,30 +164,33 @@ minetest.register_node("anvil:anvil", {
if (listname=='input'
and(stack:get_wear() == 0
or minetest.get_item_group(stack:get_name(), "not_repaired_by_anvil") ~= 0
- or stack:get_name() == "technic:water_can"
+ or stack:get_name() == "technic:water_can"
or stack:get_name() == "technic:lava_can" )) then
-
+
minetest.chat_send_player( player:get_player_name(), S('This anvil is for damaged tools only.'))
return 0
end
-
+
if meta:get_inventory():room_for_item("input", stack) then
return stack:get_count()
end
return 0
end,
-
+
allow_metadata_inventory_take = function(pos, listname, index, stack, player)
if listname~="input" then
return 0
end
return stack:get_count()
end,
-
+
on_rightclick = function(pos, node, clicker, itemstack)
+ local meta = minetest.get_meta(pos)
+ local name = clicker:get_player_name()
+
+ if name ~= meta:get_string("owner") then return itemstack end
if itemstack:get_count() == 0 then
- local meta = minetest.get_meta(pos)
- local inv = meta:get_inventory()
+ local inv = meta:get_inventory()
if not inv:is_empty("input") then
local return_stack = inv:get_stack("input", 1)
inv:set_stack("input", 1, nil)
@@ -193,7 +198,7 @@ minetest.register_node("anvil:anvil", {
clicker:get_inventory():set_stack("main", wield_index, return_stack)
remove_item(pos, node)
return return_stack
- end
+ end
end
local this_def = minetest.registered_nodes[node.name]
if this_def.allow_metadata_inventory_put(pos, "input", 1, itemstack:peek_item(), clicker) > 0 then
@@ -203,9 +208,10 @@ minetest.register_node("anvil:anvil", {
inv:add_item("input", s)
update_item(pos,node)
end
+
return itemstack
end,
-
+
on_punch = function(pos, node, puncher)
if( not( pos ) or not( node ) or not( puncher )) then
return
@@ -214,7 +220,10 @@ minetest.register_node("anvil:anvil", {
local wielded = puncher:get_wielded_item()
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
-
+ if meta:get_string("owner") ~= puncher:get_player_name() then
+ return
+ end
+
if wielded:get_count() == 0 then
if not inv:is_empty("input") then
local return_stack = inv:get_stack("input", 1)
@@ -222,60 +231,59 @@ minetest.register_node("anvil:anvil", {
local wield_index = puncher:get_wield_index()
puncher:get_inventory():set_stack("main", wield_index, return_stack)
remove_item(pos, node)
- end
+ end
end
-
+
-- only punching with the hammer is supposed to work
if wielded:get_name() ~= 'anvil:hammer' then
return
end
-
local input = inv:get_stack('input',1)
-
+
-- only tools can be repaired
- if( not( input )
- or input:is_empty()
- or input:get_name() == "technic:water_can"
- or input:get_name() == "technic:lava_can" ) then
+ if( not( input )
+ or input:is_empty()
+ or input:get_name() == "technic:water_can"
+ or input:get_name() == "technic:lava_can" ) then
return
end
-
+
-- 65535 is max damage
local damage_state = 40-math.floor(input:get_wear()/1638)
-
+
local tool_name = input:get_name()
local hud2 = nil
local hud3 = nil
if( input:get_wear()>0 ) then
hud2 = puncher:hud_add({
- hud_elem_type = "statbar",
- text = "default_cloud.png^[colorize:#ff0000:256",
- number = 40,
- direction = 0, -- left to right
- position = {x=0.5, y=0.65},
- alignment = {x = 0, y = 0},
- offset = {x = -320, y = 0},
- size = {x=32, y=32},
+ hud_elem_type = "statbar",
+ text = "default_cloud.png^[colorize:#ff0000:256",
+ number = 40,
+ direction = 0, -- left to right
+ position = {x=0.5, y=0.65},
+ alignment = {x = 0, y = 0},
+ offset = {x = -320, y = 0},
+ size = {x=32, y=32},
})
hud3 = puncher:hud_add({
- hud_elem_type = "statbar",
- text = "default_cloud.png^[colorize:#00ff00:256",
- number = damage_state,
- direction = 0, -- left to right
- position = {x=0.5, y=0.65},
- alignment = {x = 0, y = 0},
- offset = {x = -320, y = 0},
- size = {x=32, y=32},
+ hud_elem_type = "statbar",
+ text = "default_cloud.png^[colorize:#00ff00:256",
+ number = damage_state,
+ direction = 0, -- left to right
+ position = {x=0.5, y=0.65},
+ alignment = {x = 0, y = 0},
+ offset = {x = -320, y = 0},
+ size = {x=32, y=32},
})
end
minetest.after(2, function()
- if( puncher ) then
- puncher:hud_remove(hud2)
- puncher:hud_remove(hud3)
+ if( puncher ) then
+ puncher:hud_remove(hud2)
+ puncher:hud_remove(hud3)
end
end)
-
+
-- tell the player when the job is done
if( input:get_wear() == 0 ) then
local tool_desc
@@ -290,28 +298,28 @@ minetest.register_node("anvil:anvil", {
pos.y = pos.y + anvil.setting.item_displacement
minetest.sound_play({name="anvil_clang"}, {pos=pos})
minetest.add_particlespawner({
- amount = 10,
- time = 0.1,
- minpos = pos,
- maxpos = pos,
- minvel = {x=2, y=3, z=2},
- maxvel = {x=-2, y=1, z=-2},
- minacc = {x=0, y= -10, z=0},
- maxacc = {x=0, y= -10, z=0},
- minexptime = 0.5,
- maxexptime = 1,
- minsize = 1,
- maxsize = 1,
- collisiondetection = true,
- vertical = false,
- texture = "anvil_spark.png",
+ amount = 10,
+ time = 0.1,
+ minpos = pos,
+ maxpos = pos,
+ minvel = {x=2, y=3, z=2},
+ maxvel = {x=-2, y=1, z=-2},
+ minacc = {x=0, y= -10, z=0},
+ maxacc = {x=0, y= -10, z=0},
+ minexptime = 0.5,
+ maxexptime = 1,
+ minsize = 1,
+ maxsize = 1,
+ collisiondetection = true,
+ vertical = false,
+ texture = "anvil_spark.png",
})
end
-
+
-- do the actual repair
input:add_wear( -5000 ) -- equals to what technic toolshop does in 5 seconds
inv:set_stack("input", 1, input)
-
+
-- damage the hammer slightly
wielded:add_wear( 100 )
puncher:set_wielded_item( wielded )
@@ -358,16 +366,18 @@ minetest.register_lbm({
minetest.register_craft({
output = "anvil:anvil",
recipe = {
- {"default:steel_ingot","default:steel_ingot","default:steel_ingot"},
- {'', "default:steel_ingot",'' },
- {"default:steel_ingot","default:steel_ingot","default:steel_ingot"} },
+ {"default:steel_ingot","default:steel_ingot","default:steel_ingot"},
+ {'', "default:steel_ingot",'' },
+ {"default:steel_ingot","default:steel_ingot","default:steel_ingot"}
+ }
})
minetest.register_craft({
output = "anvil:hammer",
recipe = {
- {"default:steel_ingot","default:steel_ingot","default:steel_ingot"},
- {"default:steel_ingot","default:steel_ingot","default:steel_ingot"},
- {"group:stick", '', ''} },
+ {"default:steel_ingot","default:steel_ingot","default:steel_ingot"},
+ {"default:steel_ingot","default:steel_ingot","default:steel_ingot"},
+ {"group:stick","",""}
+ }
})