mirror of
https://github.com/minetest/minetest.git
synced 2024-12-24 15:12:23 +01:00
Add tool callback
This commit is contained in:
parent
4e5760a541
commit
34e0a0ca0f
@ -383,14 +383,19 @@ function minetest.node_dig(pos, node, digger)
|
|||||||
|
|
||||||
local wielded = digger:get_wielded_item()
|
local wielded = digger:get_wielded_item()
|
||||||
local drops = minetest.get_node_drops(node.name, wielded:get_name())
|
local drops = minetest.get_node_drops(node.name, wielded:get_name())
|
||||||
|
|
||||||
-- Wear out tool
|
local wdef = wielded:get_definition()
|
||||||
if not minetest.setting_getbool("creative_mode") then
|
local tp = wielded:get_tool_capabilities()
|
||||||
local tp = wielded:get_tool_capabilities()
|
local dp = minetest.get_dig_params(def.groups, tp)
|
||||||
local dp = minetest.get_dig_params(def.groups, tp)
|
if wdef and wdef.after_use then
|
||||||
wielded:add_wear(dp.wear)
|
wielded = wdef.after_use(wielded, digger, node, dp) or wielded
|
||||||
digger:set_wielded_item(wielded)
|
else
|
||||||
|
-- Wear out tool
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
wielded:add_wear(dp.wear)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
digger:set_wielded_item(wielded)
|
||||||
|
|
||||||
-- Handle drops
|
-- Handle drops
|
||||||
minetest.handle_node_drops(pos, drops, digger)
|
minetest.handle_node_drops(pos, drops, digger)
|
||||||
|
@ -1980,6 +1980,15 @@ Item definition (register_node, register_craftitem, register_tool)
|
|||||||
eg. itemstack:take_item(); return itemstack
|
eg. itemstack:take_item(); return itemstack
|
||||||
^ Otherwise, the function is free to do what it wants.
|
^ Otherwise, the function is free to do what it wants.
|
||||||
^ The default functions handle regular use cases.
|
^ The default functions handle regular use cases.
|
||||||
|
after_use = func(itemstack, user, node, digparams),
|
||||||
|
^ default: nil
|
||||||
|
^ If defined, should return an itemstack and will be called instead of
|
||||||
|
wearing out the tool. If returns nil, does nothing.
|
||||||
|
If after_use doesn't exist, it is the same as:
|
||||||
|
function(itemstack, user, node, digparams)
|
||||||
|
itemstack:add_wear(digparams.wear)
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
Tile definition:
|
Tile definition:
|
||||||
|
Loading…
Reference in New Issue
Block a user