Some refactoring of enchanting code
This commit is contained in:
parent
8f8ba904c1
commit
e9cff1f8d3
@ -13,26 +13,27 @@ enchanting.speed = 0.2
|
|||||||
enchanting.jump = 0.2
|
enchanting.jump = 0.2
|
||||||
|
|
||||||
-- Enchanted tools registration.
|
-- Enchanted tools registration.
|
||||||
|
-- Available enchantments: durable, fast, sharp, strong, speed.
|
||||||
enchanting.tools = {
|
enchanting.tools = {
|
||||||
--[[ Registration format:
|
--[[ Registration format:
|
||||||
[Mod name] = {
|
[Mod name] = {
|
||||||
materials,
|
materials,
|
||||||
{tool name, tool group, enchantments}
|
{tool name, enchantments}
|
||||||
}
|
}
|
||||||
--]]
|
]]
|
||||||
["default"] = {
|
["default"] = {
|
||||||
"steel bronze mese diamond",
|
"steel, bronze, mese, diamond",
|
||||||
{"axe", "choppy", "durable, fast"},
|
{"axe", "durable, fast"},
|
||||||
{"pick", "cracky", "durable, fast"},
|
{"pick", "durable, fast"},
|
||||||
{"shovel", "crumbly", "durable, fast"},
|
{"shovel", "durable, fast"},
|
||||||
{"sword", "fleshy", "sharp"}
|
{"sword", "sharp"}
|
||||||
},
|
},
|
||||||
["3d_armor"] = {
|
["3d_armor"] = {
|
||||||
"steel bronze gold diamond",
|
"steel, bronze, gold, diamond",
|
||||||
{"boots", nil, "strong, speed"},
|
{"boots", "strong, speed"},
|
||||||
{"chestplate", nil, "strong"},
|
{"chestplate", "strong"},
|
||||||
{"helmet", nil, "strong"},
|
{"helmet", "strong"},
|
||||||
{"leggings", nil, "strong"}
|
{"leggings", "strong"}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,18 +156,19 @@ local function cap(S) return S:gsub("^%l", string.upper) end
|
|||||||
for mod, defs in pairs(enchanting.tools) do
|
for mod, defs in pairs(enchanting.tools) do
|
||||||
for material in defs[1]:gmatch("[%w_]+") do
|
for material in defs[1]:gmatch("[%w_]+") do
|
||||||
for _, tooldef in next, defs, 1 do
|
for _, tooldef in next, defs, 1 do
|
||||||
for enchant in tooldef[3]:gmatch("[%w_]+") do
|
for enchant in tooldef[2]:gmatch("[%w_]+") do
|
||||||
local tool, group = tooldef[1], tooldef[2]
|
local tool, group = tooldef[1], ""
|
||||||
local original_tool = minetest.registered_tools[mod..":"..tool.."_"..material]
|
local original_tool = minetest.registered_tools[mod..":"..tool.."_"..material]
|
||||||
|
|
||||||
if original_tool then
|
if original_tool then
|
||||||
if mod == "default" then
|
if original_tool.tool_capabilities then
|
||||||
local original_damage_groups = original_tool.tool_capabilities.damage_groups
|
local original_damage_groups = original_tool.tool_capabilities.damage_groups
|
||||||
local original_groupcaps = original_tool.tool_capabilities.groupcaps
|
local original_groupcaps = original_tool.tool_capabilities.groupcaps
|
||||||
local groupcaps = table.copy(original_groupcaps)
|
local groupcaps = table.copy(original_groupcaps)
|
||||||
local fleshy = original_damage_groups.fleshy
|
local fleshy = original_damage_groups.fleshy
|
||||||
local full_punch_interval = original_tool.tool_capabilities.full_punch_interval
|
local full_punch_interval = original_tool.tool_capabilities.full_punch_interval
|
||||||
local max_drop_level = original_tool.tool_capabilities.max_drop_level
|
local max_drop_level = original_tool.tool_capabilities.max_drop_level
|
||||||
|
group = tostring(next(original_groupcaps))
|
||||||
|
|
||||||
if enchant == "durable" then
|
if enchant == "durable" then
|
||||||
groupcaps[group].uses = math.ceil(original_groupcaps[group].uses * enchanting.uses)
|
groupcaps[group].uses = math.ceil(original_groupcaps[group].uses * enchanting.uses)
|
||||||
@ -192,7 +194,6 @@ for enchant in tooldef[3]:gmatch("[%w_]+") do
|
|||||||
|
|
||||||
if mod == "3d_armor" then
|
if mod == "3d_armor" then
|
||||||
local original_armor_groups = original_tool.groups
|
local original_armor_groups = original_tool.groups
|
||||||
local armorcaps = table.copy(original_armor_groups)
|
|
||||||
local armorcaps = {}
|
local armorcaps = {}
|
||||||
armorcaps.not_in_creative_inventory = 1
|
armorcaps.not_in_creative_inventory = 1
|
||||||
|
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
local worktable = {}
|
local worktable = {}
|
||||||
screwdriver = screwdriver or {}
|
screwdriver = screwdriver or {}
|
||||||
|
|
||||||
-- Nodes allowed to be cut. Registration format: [mod name] = [[ node names ]].
|
-- Nodes allowed to be cut.
|
||||||
|
-- Registration format: [mod name] = [[ node names ]].
|
||||||
worktable.nodes = {
|
worktable.nodes = {
|
||||||
["default"] = [[
|
["default"] = [[
|
||||||
wood tree cobble desert_stone
|
wood tree cobble desert_stone
|
||||||
|
Loading…
Reference in New Issue
Block a user