forked from mtcontrib/minetest-toolranks
Compare commits
2 Commits
nalc-1.2.0
...
v1.2
Author | SHA1 | Date | |
---|---|---|---|
d000b4b20f | |||
17994ed8db |
13
.github/workflows/build.yml
vendored
Normal file
13
.github/workflows/build.yml
vendored
Normal file
@ -0,0 +1,13 @@
|
||||
name: Build
|
||||
on: [push, pull_request]
|
||||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v1
|
||||
- name: apt
|
||||
run: sudo apt-get install -y luarocks
|
||||
- name: luacheck install
|
||||
run: luarocks install --local luacheck
|
||||
- name: luacheck run
|
||||
run: $HOME/.luarocks/bin/luacheck ./
|
18
.luacheckrc
Normal file
18
.luacheckrc
Normal file
@ -0,0 +1,18 @@
|
||||
unused_args = false
|
||||
allow_defined_top = true
|
||||
|
||||
globals = {
|
||||
"minetest",
|
||||
}
|
||||
|
||||
read_globals = {
|
||||
string = {fields = {"split"}},
|
||||
table = {fields = {"copy", "getn"}},
|
||||
|
||||
-- Builtin
|
||||
"vector", "ItemStack",
|
||||
"dump", "DIR_DELIM", "VoxelArea", "Settings",
|
||||
|
||||
-- MTG
|
||||
"default", "sfinv", "creative",
|
||||
}
|
@ -13,7 +13,7 @@ If so, to support this mod, add this code to your mod, after your tool's code:
|
||||
if minetest.get_modpath("toolranks") then
|
||||
minetest.override_item("mymod:mytool", {
|
||||
original_description = "My Tool",
|
||||
description = toolranks.create_description("My Tool", 0, 1),
|
||||
description = toolranks.create_description("My Tool"),
|
||||
after_use = toolranks.new_afteruse
|
||||
})
|
||||
end
|
||||
|
23
init.lua
23
init.lua
@ -37,7 +37,14 @@ function toolranks.get_tool_type(description)
|
||||
end
|
||||
end
|
||||
|
||||
function toolranks.create_description(name, uses, 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 tooltype = toolranks.get_tool_type(description)
|
||||
local newdesc = S(
|
||||
@ -45,18 +52,14 @@ function toolranks.create_description(name, uses, level)
|
||||
toolranks.colors.green,
|
||||
description,
|
||||
toolranks.colors.gold,
|
||||
(level or 1),
|
||||
toolranks.get_level(uses),
|
||||
S(tooltype),
|
||||
toolranks.colors.grey,
|
||||
(uses or 0)
|
||||
(type(uses) == "number" and uses or 0)
|
||||
)
|
||||
return newdesc
|
||||
end
|
||||
|
||||
function toolranks.get_level(uses)
|
||||
return math.min(max_level, math.floor(uses / level_digs))
|
||||
end
|
||||
|
||||
function toolranks.new_afteruse(itemstack, user, node, digparams)
|
||||
local itemmeta = itemstack:get_meta()
|
||||
local itemdef = itemstack:get_definition()
|
||||
@ -107,7 +110,6 @@ function toolranks.new_afteruse(itemstack, user, node, digparams)
|
||||
to_player = user:get_player_name(),
|
||||
gain = 2.0,
|
||||
})
|
||||
itemmeta:set_string("lastlevel", level)
|
||||
|
||||
local speed_multiplier = 1 + (level * level_multiplier * (max_speed - 1))
|
||||
local use_multiplier = 1 + (level * level_multiplier * (max_use - 1))
|
||||
@ -125,7 +127,8 @@ function toolranks.new_afteruse(itemstack, user, node, digparams)
|
||||
itemmeta:set_tool_capabilities(caps)
|
||||
end
|
||||
|
||||
itemmeta:set_string("description", toolranks.create_description(itemdesc, dugnodes, level))
|
||||
itemmeta:set_string("lastlevel", level)
|
||||
itemmeta:set_string("description", toolranks.create_description(itemdesc, dugnodes))
|
||||
itemstack:add_wear(digparams.wear)
|
||||
return itemstack
|
||||
end
|
||||
@ -135,7 +138,7 @@ function toolranks.add_tool(name)
|
||||
local desc = ItemStack(name):get_definition().description
|
||||
minetest.override_item(name, {
|
||||
original_description = desc,
|
||||
description = toolranks.create_description(desc, 0, 1),
|
||||
description = toolranks.create_description(desc),
|
||||
after_use = toolranks.new_afteruse
|
||||
})
|
||||
end
|
||||
|
Reference in New Issue
Block a user