mods - toolranks : added reduced version that used sounds from default

* add also support for hoes into farming mod (cos we used older non redo)
* autodetection if extra toolranks mod its already doing that
This commit is contained in:
mckaygerhard 2023-06-11 20:12:09 -04:00
parent 9f62ed07c7
commit a182b7dd6a
15 changed files with 395 additions and 40 deletions

View File

@ -36,6 +36,7 @@ To download you can play this game with the following minetest engines:
* minetest default and extras
* integrated the killme/game_commands were simplified into default mod, and provide CC-BY-SA-NC license
* farming is default older but has build in toolranks support
* xdecor as `xdecor` [mods/xdecor](mods/xdecor) a super reduced version of homedecor pack, for performance
* sorceredkid auth mod
* minetest Auth Redux as `auth_rx` [mods/auth_rx](mods/auth_rx) from https://codeberg.org/minenux/minetest-mod-auth_rx
@ -46,6 +47,7 @@ To download you can play this game with the following minetest engines:
* simple_skins as `skins` [mods/skins](mods/skins) from https://codeberg.org/minenux/minetest-mod-simple_skins
* regrow as `regrow` [mods/regrow](mods/regrow) from https://codeberg.org/minenux/minetest-mod-regrow
* ethereal as `ethereal` [mods/ethereal](mods/ethereal) from https://codeberg.org/minenux/minetest-mod-ethereal
* toolranks as `toolranks` [mods/toolranks](mods/toolranks) from https://codeberg.org/minenux/minetest-mod-toolranks
* armors and stuff mods
* 3d_armor and shields [mods/3d_armor](mods/3d_armor) https://codeberg.org/minenux/minetest-mod-3d_armor
* player stuffs:

View File

@ -1,3 +1,8 @@
local use_toolranks = minetest.get_modpath("toolranks") or false
local use_extratoolranks = minetest.get_modpath("toolranks_extra") or false
local use_tr = (use_toolranks and (not use_extratoolranks)) or false
farming.register_hoe(":farming:hoe_wood", {
description = "Wooden Hoe",
inventory_image = "farming_tool_woodhoe.png",
@ -5,6 +10,7 @@ farming.register_hoe(":farming:hoe_wood", {
material = "group:wood",
groups = {flammable = 2},
})
if use_tr then farming.add_hoe("farming:hoe_wood") end
farming.register_hoe(":farming:hoe_stone", {
description = "Stone Hoe",
@ -12,6 +18,7 @@ farming.register_hoe(":farming:hoe_stone", {
max_uses = 90,
material = "group:stone"
})
if use_tr then farming.add_hoe("farming:hoe_stone") end
farming.register_hoe(":farming:hoe_steel", {
description = "Steel Hoe",
@ -19,6 +26,7 @@ farming.register_hoe(":farming:hoe_steel", {
max_uses = 200,
material = "default:steel_ingot"
})
if use_tr then farming.add_hoe("farming:hoe_steel") end
farming.register_hoe(":farming:hoe_bronze", {
description = "Bronze Hoe",
@ -26,6 +34,7 @@ farming.register_hoe(":farming:hoe_bronze", {
max_uses = 220,
material = "default:bronze_ingot"
})
if use_tr then farming.add_hoe("farming:hoe_bronze") end
farming.register_hoe(":farming:hoe_mese", {
description = "Mese Hoe",
@ -33,6 +42,7 @@ farming.register_hoe(":farming:hoe_mese", {
max_uses = 350,
material = "default:mese_crystal"
})
if use_tr then farming.add_hoe("farming:hoe_mese") end
farming.register_hoe(":farming:hoe_diamond", {
description = "Diamond Hoe",
@ -40,3 +50,4 @@ farming.register_hoe(":farming:hoe_diamond", {
max_uses = 500,
material = "default:diamond"
})
if use_tr then farming.add_hoe("farming:hoe_diamond") end

View File

@ -4,13 +4,53 @@ farming = {}
farming.path = minetest.get_modpath("farming")
-- toolranks support
if minetest.get_modpath("toolranks") then
function farming.add_hoe(material)
-- registering as tool
local name = material
toolranks.add_tool(material)
-- getting after_use
local def = minetest.registered_items[name]
local hoe_on_use = def.on_use
local hoe_after_use = def.after_use
if (hoe_on_use == nil) or (hoe_after_use == nil) then
return
end
minetest.override_item(name, {
-- we also want hoes to increase dugnodes when farming soil
on_use = function(itemstack, user, pointed_thing, uses)
-- if no node is pointed, the hoe cannot be used
if pointed_thing.under == nil then
return nil
end
local under = minetest.get_node(pointed_thing.under)
-- get origin wear
local wear = itemstack:get_wear()
-- apply previous on_use
local ret_itemstack = hoe_on_use(itemstack, user, pointed_thing, uses)
if ret_itemstack == nil then
return nil
end
-- compute wear diff
local hoe_uses = ret_itemstack:get_wear() - wear
-- set wear back because it is up to hoe_after_use to add wear
ret_itemstack:set_wear(wear)
-- apply afteruse
return hoe_after_use(ret_itemstack, user, under, {wear = hoe_uses})
end
})
end
end
-- Load files
dofile(farming.path .. "/api.lua")
dofile(farming.path .. "/nodes.lua")
dofile(farming.path .. "/hoes.lua")
-- WHEAT
farming.register_plant("farming:wheat", {
@ -137,42 +177,3 @@ minetest.register_craft({
recipe = "farming:hoe_wood",
burntime = 5,
})
local box = {
type = "fixed",
fixed = {
{-0.1875, -0.4375, -0.1875, 0.1875, 0.0625, 0.1875}, -- Bottom
{-0.25, -0.375, -0.25, 0.25, 0, 0.25}, -- Middle
-- {-0.1875, 0.0625, -0.1875, 0.1875, 0, 0.1875}, -- Top
{-0.0625, 0.0625, -0.0625, 0, 0.125, 0}, -- NodeBox4
{0.0625, 0.0625, 0.0625, 0, 0.125, 0}, -- NodeBox5
{0.0625, 0.125, -0.0625, 0, 0.1875, 0}, -- NodeBox4
{-0.0625, 0.125, 0.0625, 0, 0.1875, 0}, -- NodeBox5
}
}
minetest.override_item("default:apple",{
drawtype = "nodebox",
paramtype = "light",
tiles = { -- +Y, -Y, +X, -X, +Z, -Z
"apple_bottom.png^apple_top_overlay.png",
"apple_bottom.png",
"apple_side.png",
"apple_side.png",
"apple_side.png",
"apple_side.png",
},
node_box = box,
inventory_image = "default_apple.png",
sunlight_propagates = true,
walkable = false,
is_ground_content = false,
selection_box = box,
groups = {fleshy = 3, dig_immediate = 3, flammable = 2, leafdecay = 3, leafdecay_drop = 1},
on_use = minetest.item_eat(2),
sounds = default.node_sound_leaves_defaults(),
after_place_node = function(pos, placer, itemstack)
minetest.set_node(pos, {name = "default:apple", param2 = 1})
end,
})

81
mods/toolranks/README.md Normal file
View File

@ -0,0 +1,81 @@
# Minetest tool ranks mod
Tool gains levels for digging nodes. Higher level take longer to wear out.
Information
------------
It adds improved information on the description label of the tools,
like how much was used the tool and how much is improved,
and also provides improved xperience over the tool as much you use it..
![](screenshot.png)
# Technical information
---------------------
This mod is named `toolranks`
This ranktool is the tenplus1's version, featured custom values throught
configuration interface for dig speed, mutiplier and durability.
Shows information about the counts the nodes that spend the tool
Also provide interface to add toolrank support on other mods.
#### Dependencies
* default (now optional)
#### configuration
| Config item | type | def | values | Description |
| -------------------------- | ----- | ---- | ----------- | ----------------------------- |
| toolranks_levels | int | 8 | any int | Level (Number of tool levels) |
| toolranks_level_digs | int | 1000 | any int | Number of nodes that need to be dug to reach the next tool level |
| toolranks_speed_multiplier | float | 1.1 | 1.0 to 10.0 | Dig speed multiplier (at maximum tool level, 1.0 to disable) |
| toolranks_use_multiplier | float | 1.1 | 1.0 to 10.0 | Durability multiplier (at maximum tool level,1.0 to disable) |
#### mods toolrank support
The default mod of minetest game has default support in this mod,
but not farming hoes, many other mods already integrates toolrank support,
by example all the tenplus1's "redo"s mod already has support, others will need
extra mods like toolranks_extra due rejection from mod authors.
#### how to add support in mods
If so, to support this mod, add this code to your mod, after your tool's code:
```lua
if minetest.get_modpath("toolranks") then
toolranks.add_tool("mymod:mytool")
end
```
Where `mymod` is the technical/namespace name of the mod and `mytool` the item name.
That function provides all that can be do by custom way also as:
```lua
if minetest.get_modpath("toolranks") then
minetest.override_item("mymod:mytool", {
original_description = "My Tool",
description = toolranks.create_description("My Tool"),
after_use = toolranks.new_afteruse
})
end
end
```
## LICENSE
(c) 2017 lisacvuk
(c) 2017 tenplus1
(c) 2023 mckaygerhard
Code is LGPL v2.1
media is CC-BY
check [license.txt](license.txt)

View File

@ -0,0 +1 @@
default?

View File

@ -0,0 +1 @@
TOOL gains levels for digging nodes. Higher level take longer to wear out

211
mods/toolranks/init.lua Normal file
View File

@ -0,0 +1,211 @@
local S
if minetest.get_translator ~= nil then
S = minetest.get_translator("toolranks") -- 5.x translation function
else
if minetest.get_modpath("intllib") then
dofile(minetest.get_modpath("intllib") .. "/init.lua")
if intllib.make_gettext_pair then
gettext, ngettext = intllib.make_gettext_pair() -- new gettext method
else
gettext = intllib.Getter() -- old text file method
end
S = gettext
else -- boilerplate function
S = function(str, ...)
local args = {...}
return str:gsub("@%d+", function(match)
return args[tonumber(match:sub(2))]
end)
end
end
end
toolranks = {
colors = {
grey = minetest.get_color_escape_sequence("#9d9d9d"),
green = minetest.get_color_escape_sequence("#1eff00"),
gold = minetest.get_color_escape_sequence("#ffdf00"),
white = minetest.get_color_escape_sequence("#ffffff")
}
}
local max_speed = tonumber(minetest.settings:get("toolranks_speed_multiplier")) or 1.1--2.0
local max_use = tonumber(minetest.settings:get("toolranks_use_multiplier")) or 1.1
local max_level = tonumber(minetest.settings:get("toolranks_levels")) or 8
local level_digs = tonumber(minetest.settings:get("toolranks_level_digs")) or 1000
local level_multiplier = 1 / max_level
function toolranks.get_level(uses)
if type(uses) == "number" and uses > 0 then
return math.min(max_level, math.floor(uses / level_digs))
end
return 0
end
function toolranks.create_description(name, uses)
local description = name
local newdesc = S(
"@1@2\n@3Level @4 @5\n@6@Node dug: @7",
toolranks.colors.green,
description,
toolranks.colors.gold,
toolranks.get_level(uses),
"", -- was tooltype
toolranks.colors.grey,
(type(uses) == "number" and uses or 0)
)
return newdesc
end
function toolranks.new_afteruse(itemstack, user, node, digparams)
local pname = user:get_player_name()
if not pname then return itemstack end -- player nil check
local itemmeta = itemstack:get_meta()
local dugnodes = tonumber(itemmeta:get_string("dug")) or 0
if digparams.wear > 0 then -- Only count nodes that spend the tool
dugnodes = dugnodes + 1
itemmeta:set_string("dug", dugnodes)
end
if itemstack:get_wear() > 60135 then
minetest.chat_send_player(pname,
toolranks.colors.gold .. S("Your tool is about to break!"))
minetest.sound_play("default_tool_breaks", {
to_player = pname,
gain = 2.0,
}, true)
end
local itemdef = itemstack:get_definition()
local itemdesc = itemdef.original_description or ""
local lastlevel = tonumber(itemmeta:get_string("lastlevel")) or 0
local level = toolranks.get_level(dugnodes)
if lastlevel < level then
local levelup_text = S(
"Your @1@2@3 just leveled up!",
toolranks.colors.green,
itemdesc,
toolranks.colors.white
)
minetest.chat_send_player(pname, levelup_text .. " "..lastlevel.." -> "..level)
minetest.sound_play("toolranks_levelup", {
to_player = pname,
gain = 2.0,
}, true)
-- 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)
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
end
end
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(wear)
return itemstack
end
-- Helper function
function toolranks.add_tool(name)
local desc = ItemStack(name):get_definition().description
minetest.override_item(name, {
original_description = desc,
description = toolranks.create_description(desc),
after_use = toolranks.new_afteruse
})
end
local defaultmod = minetest.get_modpath("default")
if defaultmod then
-- Sword
toolranks.add_tool("default:sword_wood")
toolranks.add_tool("default:sword_stone")
toolranks.add_tool("default:sword_steel")
toolranks.add_tool("default:sword_bronze")
toolranks.add_tool("default:sword_mese")
toolranks.add_tool("default:sword_diamond")
-- Pickaxe
toolranks.add_tool("default:pick_wood")
toolranks.add_tool("default:pick_stone")
toolranks.add_tool("default:pick_steel")
toolranks.add_tool("default:pick_bronze")
toolranks.add_tool("default:pick_mese")
toolranks.add_tool("default:pick_diamond")
-- Axe
toolranks.add_tool("default:axe_wood")
toolranks.add_tool("default:axe_stone")
toolranks.add_tool("default:axe_steel")
toolranks.add_tool("default:axe_bronze")
toolranks.add_tool("default:axe_mese")
toolranks.add_tool("default:axe_diamond")
-- Shovel
toolranks.add_tool("default:shovel_wood")
toolranks.add_tool("default:shovel_stone")
toolranks.add_tool("default:shovel_steel")
toolranks.add_tool("default:shovel_bronze")
toolranks.add_tool("default:shovel_mese")
toolranks.add_tool("default:shovel_diamond")
end
print("[MOD] Tool Ranks loaded")

View File

@ -0,0 +1,2 @@
Code: LGPLv2.1+
Sounds: CC BY 3.0

View File

@ -0,0 +1,11 @@
# textdomain: toolranks
@1@2@n@3Level @4 @5@n@6Node dug: @7=@1@2@n@3Level @4 @5@n@6Node dug: @7
pickaxe=pickaxe
axe=axe
shovel=shovel
hoe=hoe
sword=sword
tool=tool
Most used tool is now a @1@2@3 owned by @4 with @5 uses.=Most used tool is now a @1@2@3 owned by @4 with @5 uses.
Your tool is about to break!=Your tool is about to break!
Your @1@2@3 just leveled up!=Your @1@2@3 just leveled up!

View File

@ -0,0 +1,11 @@
# textdomain: toolranks
@1@2@n@3Level @4 @5@n@6Node dug: @7=@1@2@n@3Nivel @4 @5@n@6Nodos picado: @7
pickaxe=pickaxe
axe=axe
shovel=shovel
hoe=hoe
sword=sword
tool=tool
Most used tool is now a @1@2@3 owned by @4 with @5 uses.=La herramienta mas usada es @1@2@3 pertenece a @4 con @5 veces.
Your tool is about to break!=Tu herramienta esta a punto de romperse!
Your @1@2@3 just leveled up!=Tu @1@2@3 acaba de subir nivel!

View File

@ -0,0 +1,11 @@
# textdomain: toolranks
@1@2@n@3Level @4 @5@n@6Node dug: @7=@1@2@n@3@5 niveau @4@n@6Blocks minés : @7
pickaxe=pioche
axe=hache
shovel=pelle
hoe=houe
sword=épée
tool=outil
Most used tool is now a @1@2@3 owned by @4 with @5 uses.=Loutil le plus utilisé est désormais @1@2@3 appartenant à @4 avec @5 utilisations.
Your tool is about to break!=Votre outil va se casser !
Your @1@2@3 just leveled up!=Votre @1@2@3 a gagné un niveau !

4
mods/toolranks/mod.conf Normal file
View File

@ -0,0 +1,4 @@
name = toolranks
depends =
optional_depens = default
description = TOOL gains levels for digging nodes. Higher level take longer to wear out

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

View File

@ -0,0 +1,8 @@
# Number of tool levels
toolranks_levels (Levels) int 8
# Number of nodes that need to be dug to reach the next tool level
toolranks_level_digs (Digs per level) int 1000
# Dig speed multiplier at maximum tool level (1.0 to disable)
toolranks_speed_multiplier (Dig speed multiplier) float 1.1 1.0 10.0
# Durability multiplier at maximum tool level (1.0 to disable)
toolranks_use_multiplier (Durability multiplier) float 1.1 1.0 10.0

Binary file not shown.