Some refactoring of enchanting code

This commit is contained in:
kilbith 2016-01-27 22:19:54 +01:00
parent 8f8ba904c1
commit e9cff1f8d3
2 changed files with 19 additions and 17 deletions

View File

@ -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

View File

@ -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