1
0
mirror of https://github.com/lisacvuk/minetest-toolranks.git synced 2025-07-12 21:10:27 +02:00

8 Commits

Author SHA1 Message Date
aac3cded36 Merge remote-tracking branch 'upstream/master' 2020-11-25 21:56:20 +01:00
8010feb5bf Add nil check afteruse
Add player nil check to toolranks.new_afteruse() to fix error.
2020-11-22 14:32:59 +00:00
12af618f9b Add check for tool_capabilities and fallback if not defined (#15)
* add check for `tool_capabilities` and fallback if not defined

* fix whitespace
2020-06-30 18:30:12 +02:00
8b466b199f Merge remote-tracking branch 'upstream/master' into nalc-1.2-dev 2020-06-20 16:07:16 +02:00
0d7bf5a5d6 Merge remote-tracking branch 'upstream/master' into nalc-1.2-dev 2020-02-29 18:36:06 +01:00
1a9996b76c Merge branch 'master' of yunohost.local:mtcontrib/minetest-toolranks into nalc-1.2-dev 2019-12-22 15:18:48 +01:00
2ce4efa2cd Ajoute plus de niveaux. 10 niveaux au total. 2019-03-06 21:38:19 +01:00
95f0fba777 Ajoute message de chargement du mod dans le journal "action" 2019-01-19 19:23:59 +01:00

View File

@ -63,11 +63,13 @@ end
function toolranks.new_afteruse(itemstack, user, node, digparams)
local itemmeta = itemstack:get_meta()
local itemdef = itemstack:get_definition()
local itemdesc = itemdef.original_description
local itemdesc = itemdef.original_description or ""
local dugnodes = tonumber(itemmeta:get_string("dug")) 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_user = mod_storage:get_string("most_digs_user") or 0
local pname = user:get_player_name()
if not pname then return itemstack end -- player nil check
if digparams.wear > 0 then -- Only count nodes that spend the tool
dugnodes = dugnodes + 1
@ -75,24 +77,24 @@ function toolranks.new_afteruse(itemstack, user, node, digparams)
end
if dugnodes > most_digs then
if most_digs_user ~= user:get_player_name() then -- Avoid spam.
if most_digs_user ~= pname then -- Avoid spam.
minetest.chat_send_all(S(
"Most used tool is now a @1@2@3 owned by @4 with @5 uses.",
toolranks.colors.green,
itemdesc,
toolranks.colors.white,
user:get_player_name(),
pname,
dugnodes
))
end
mod_storage:set_int("most_digs", dugnodes)
mod_storage:set_string("most_digs_user", user:get_player_name())
mod_storage:set_string("most_digs_user", pname)
end
if itemstack:get_wear() > 60135 then
minetest.chat_send_player(user:get_player_name(), S("Your tool is about to break!"))
minetest.sound_play("default_tool_breaks", {
to_player = user:get_player_name(),
to_player = pname,
gain = 2.0,
})
end
@ -107,29 +109,38 @@ function toolranks.new_afteruse(itemstack, user, node, digparams)
)
minetest.chat_send_player(user:get_player_name(), levelup_text)
minetest.sound_play("toolranks_levelup", {
to_player = user:get_player_name(),
to_player = pname,
gain = 2.0,
})
-- Make tool better by modifying tool_capabilities (if defined)
if itemdef.tool_capabilities then
local speed_multiplier = 1 + (level * level_multiplier * (max_speed - 1))
local use_multiplier = 1 + (level * level_multiplier * (max_use - 1))
local caps = table.copy(itemdef.tool_capabilities)
local speed_multiplier = 1 + (level * level_multiplier * (max_speed - 1))
local use_multiplier = 1 + (level * level_multiplier * (max_use - 1))
local caps = table.copy(itemdef.tool_capabilities)
caps.full_punch_interval = caps.full_punch_interval and (caps.full_punch_interval / speed_multiplier)
caps.punch_attack_uses = caps.punch_attack_uses and (caps.punch_attack_uses * use_multiplier)
caps.full_punch_interval = caps.full_punch_interval and (caps.full_punch_interval / speed_multiplier)
caps.punch_attack_uses = caps.punch_attack_uses and (caps.punch_attack_uses * use_multiplier)
for _,c in pairs(caps.groupcaps) do
c.uses = c.uses * use_multiplier
for i,t in ipairs(c.times) do
c.times[i] = t / speed_multiplier
for _,c in pairs(caps.groupcaps) do
c.uses = c.uses * use_multiplier
for i,t in ipairs(c.times) do
c.times[i] = t / speed_multiplier
end
end
end
itemmeta:set_tool_capabilities(caps)
itemmeta:set_tool_capabilities(caps)
end
end
-- Old method for compatibility with tools without tool_capabilities defined
local wear = digparams.wear
if level > 0 and not itemdef.tool_capabilities then
local use_multiplier = 1 + (level * level_multiplier * (max_use - 1))
wear = wear / use_multiplier
end
itemmeta:set_string("lastlevel", level)
itemmeta:set_string("description", toolranks.create_description(itemdesc, dugnodes))
itemstack:add_wear(digparams.wear)
itemstack:add_wear(wear)
return itemstack
end
@ -174,3 +185,5 @@ toolranks.add_tool("default:shovel_steel")
toolranks.add_tool("default:shovel_bronze")
toolranks.add_tool("default:shovel_mese")
toolranks.add_tool("default:shovel_diamond")
minetest.log("action", "[toolranks] loaded.")