1
0
mirror of https://github.com/lisacvuk/minetest-toolranks.git synced 2025-01-25 06:50:21 +01:00

Use original after_use instead of directly calling add_wear

Respect description updates caused by this call
This commit is contained in:
Vftdan 2023-11-18 09:34:21 +03:00
parent 05eea5177e
commit ed9257cd06

View File

@ -60,10 +60,20 @@ function toolranks.create_description(name, uses)
return newdesc return newdesc
end end
-- Implicit Minetest behavior when after_use = nil
local function default_afteruse(itemstack, user, node, digparams)
itemstack:add_wear(digparams.wear)
return itemstack
end
function toolranks.new_afteruse(itemstack, user, node, digparams) function toolranks.new_afteruse(itemstack, user, node, digparams)
local itemmeta = itemstack:get_meta() local itemmeta = itemstack:get_meta()
local itemdef = itemstack:get_definition() local itemdef = itemstack:get_definition()
local itemdesc = itemdef.original_description or "" local itemdesc = itemmeta:get_string("toolranks_original_description")
if itemdesc == "" or itemdesc == nil then
itemdesc = itemmeta:get_string("description")
end
itemdesc = itemdesc or itemdef.original_description or ""
local dugnodes = tonumber(itemmeta:get_string("dug")) or 0 local dugnodes = tonumber(itemmeta:get_string("dug")) or 0
local lastlevel = tonumber(itemmeta:get_string("lastlevel")) or 0 local lastlevel = tonumber(itemmeta:get_string("lastlevel")) or 0
local most_digs = mod_storage:get_int("most_digs") or 0 local most_digs = mod_storage:get_int("most_digs") or 0
@ -138,18 +148,31 @@ function toolranks.new_afteruse(itemstack, user, node, digparams)
wear = wear / use_multiplier wear = wear / use_multiplier
end end
local modified_digparams = table.copy(digparams)
modified_digparams.wear = wear
itemmeta:set_string("description", itemdesc) -- For the original mod
itemmeta:set_string("lastlevel", level) itemmeta:set_string("lastlevel", level)
itemstack = (itemdef._toolranks_original_after_use or default_afteruse)(itemstack, user, node, modified_digparams) or itemstack
itemmeta = itemstack:get_meta()
itemdesc = itemmeta:get_string("description")
itemmeta:set_string("description", toolranks.create_description(itemdesc, dugnodes)) itemmeta:set_string("description", toolranks.create_description(itemdesc, dugnodes))
itemstack:add_wear(wear) itemmeta:set_string("toolranks_original_description", itemdesc)
-- TODO somehow handle description updates that happen outside of after_use event?
return itemstack return itemstack
end end
-- Helper function -- Helper function
function toolranks.add_tool(name) function toolranks.add_tool(name)
local desc = ItemStack(name):get_definition().description local original_definition = ItemStack(name):get_definition()
local desc = original_definition.description
local original_after_use = original_definition.after_use
if original_after_use == nil or original_after_use == toolranks.new_afteruse then
original_after_use = default_afteruse
end
minetest.override_item(name, { minetest.override_item(name, {
original_description = desc, original_description = desc,
description = toolranks.create_description(desc), description = toolranks.create_description(desc),
_toolranks_original_after_use = original_after_use,
after_use = toolranks.new_afteruse after_use = toolranks.new_afteruse
}) })
end end