Legacy potions converter
This commit is contained in:
parent
d306260c7e
commit
dbea863553
|
@ -1,6 +1,8 @@
|
||||||
local S = minetest.get_translator(minetest.get_current_modname())
|
local S = minetest.get_translator(minetest.get_current_modname())
|
||||||
|
|
||||||
mcl_potions.registered_potions = {}
|
mcl_potions.registered_potions = {}
|
||||||
|
-- shorthand
|
||||||
|
local registered_potions = mcl_potions.registered_potions
|
||||||
|
|
||||||
local function potion_image(colorstring, opacity)
|
local function potion_image(colorstring, opacity)
|
||||||
if not opacity then
|
if not opacity then
|
||||||
|
@ -810,3 +812,50 @@ mcl_potions.register_potion({
|
||||||
has_lingering = false,
|
has_lingering = false,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-- COMPAT CODE
|
||||||
|
local function replace_legacy_potion(itemstack)
|
||||||
|
local name = itemstack:get_name()
|
||||||
|
local new_name = name:match("^(.+)_plus$")
|
||||||
|
local new_stack
|
||||||
|
if new_name then
|
||||||
|
new_stack = ItemStack(new_name)
|
||||||
|
new_stack:get_meta():set_int("mcl_potions:potion_plus",
|
||||||
|
registered_potions[new_name]._default_extend_level)
|
||||||
|
tt.reload_itemstack_description(new_stack)
|
||||||
|
end
|
||||||
|
new_name = name:match("^(.+)_2$")
|
||||||
|
if new_name then
|
||||||
|
new_stack = ItemStack(new_name)
|
||||||
|
new_stack:get_meta():set_int("mcl_potions:potion_potent",
|
||||||
|
registered_potions[new_name]._default_potent_level-1)
|
||||||
|
tt.reload_itemstack_description(new_stack)
|
||||||
|
end
|
||||||
|
return new_stack
|
||||||
|
end
|
||||||
|
local compat = "mcl_potions:compat_potion"
|
||||||
|
minetest.register_craftitem(compat, {
|
||||||
|
description = S("Unknown Potion"),
|
||||||
|
_tt_help = S("Right-click to identify"),
|
||||||
|
image = "mcl_potions_dragon_breath.png",
|
||||||
|
on_secondary_use = replace_legacy_potion,
|
||||||
|
on_place = replace_legacy_potion,
|
||||||
|
})
|
||||||
|
|
||||||
|
local old_potions_plus = {
|
||||||
|
"fire_resistance", "water_breathing", "invisibility", "regeneration", "poison",
|
||||||
|
"withering", "leaping", "slowness", "swiftness", "night_vision"
|
||||||
|
}
|
||||||
|
local old_potions_2 = {
|
||||||
|
"healing", "harming", "swiftness", "slowness", "leaping",
|
||||||
|
"withering", "poison", "regeneration"
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, name in pairs(old_potions_2) do
|
||||||
|
minetest.register_alias("mcl_potions:" .. name .. "_2", compat)
|
||||||
|
end
|
||||||
|
for _, name in pairs(old_potions_plus) do
|
||||||
|
minetest.register_alias("mcl_potions:" .. name .. "_plus", compat)
|
||||||
|
end
|
||||||
|
|
Loading…
Reference in New Issue