mirror of
https://github.com/SmallJoker/exchange_shop.git
synced 2025-01-24 17:00:29 +01:00
Better migrate options, fix 'default' dependency
This commit is contained in:
parent
89d08b907b
commit
130389705b
@ -41,7 +41,7 @@ local function list_add_list(inv, list_name, list)
|
|||||||
return leftover_list
|
return leftover_list
|
||||||
end
|
end
|
||||||
|
|
||||||
local function migrate_shop_node(pos, node)
|
function exchange_shop.migrate_shop_node(pos, node)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local owner = meta:get_string("owner")
|
local owner = meta:get_string("owner")
|
||||||
local title = meta:get_string("infotext")
|
local title = meta:get_string("infotext")
|
||||||
@ -76,12 +76,13 @@ local function migrate_shop_node(pos, node)
|
|||||||
minetest.swap_node(pos, node)
|
minetest.swap_node(pos, node)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if exchange_shop.migrate.use_lbm then
|
||||||
minetest.register_lbm({
|
minetest.register_lbm({
|
||||||
label = "currency shop to exchange shop migration",
|
label = "currency shop to exchange shop migration",
|
||||||
name = "exchange_shop:currency_migrate",
|
name = "exchange_shop:currency_migrate",
|
||||||
nodenames = { "currency:shop" },
|
nodenames = { "currency:shop" },
|
||||||
run_at_every_load = true, -- TODO this for testing only
|
run_at_every_load = false,
|
||||||
action = migrate_shop_node
|
action = exchange_shop.migrate_shop_node
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Clean up garbage
|
-- Clean up garbage
|
||||||
@ -95,3 +96,4 @@ minetest.register_on_joinplayer(function(player)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
end
|
||||||
|
@ -1,8 +1,5 @@
|
|||||||
local def = table.copy(minetest.registered_nodes["currency:shop"])
|
|
||||||
def.groups.not_in_creative_inventory = 1
|
|
||||||
|
|
||||||
minetest.override_item("currency:shop", {
|
minetest.override_item("currency:shop", {
|
||||||
groups = def.groups,
|
|
||||||
on_construct = function() end,
|
on_construct = function() end,
|
||||||
after_place_node = function(pos, ...)
|
after_place_node = function(pos, ...)
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
@ -14,6 +11,10 @@ minetest.override_item("currency:shop", {
|
|||||||
new_def.on_construct(pos)
|
new_def.on_construct(pos)
|
||||||
end
|
end
|
||||||
new_def.after_place_node(pos, unpack({...}))
|
new_def.after_place_node(pos, unpack({...}))
|
||||||
|
end,
|
||||||
|
on_rightclick = function(pos, node, ...)
|
||||||
|
exchange_shop.migrate_shop_node(pos, node)
|
||||||
|
local new_def = minetest.registered_nodes[exchange_shop.shopname]
|
||||||
|
new_def.on_rightclick(pos, node, unpack({...}))
|
||||||
end
|
end
|
||||||
})
|
})
|
@ -1,3 +1,4 @@
|
|||||||
|
default
|
||||||
currency?
|
currency?
|
||||||
bitchange?
|
bitchange?
|
||||||
wrench?
|
wrench?
|
21
init.lua
21
init.lua
@ -5,23 +5,34 @@ exchange_shop.shopname = "exchange_shop:shop"
|
|||||||
local modpath = minetest.get_modpath("exchange_shop")
|
local modpath = minetest.get_modpath("exchange_shop")
|
||||||
local has_currency = minetest.get_modpath("currency")
|
local has_currency = minetest.get_modpath("currency")
|
||||||
local has_bitchange = minetest.get_modpath("bitchange")
|
local has_bitchange = minetest.get_modpath("bitchange")
|
||||||
local migrate_currency = true -- TODO testing!
|
|
||||||
local slow_migrate_currency = false
|
-- Currency migrate options
|
||||||
|
exchange_shop.migrate = {
|
||||||
|
use_lbm = false,
|
||||||
|
-- ^ Runs once on each unique loaded mapblock
|
||||||
|
on_interact = true
|
||||||
|
-- ^ Converts shop nodes "on the fly"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if has_bitchange then
|
if has_bitchange then
|
||||||
minetest.register_alias("exchange_shop:shop", "bitchange:shop")
|
minetest.register_alias("exchange_shop:shop", "bitchange:shop")
|
||||||
exchange_shop.shopname = "bitchange:shop"
|
exchange_shop.shopname = "bitchange:shop"
|
||||||
else
|
else
|
||||||
|
minetest.register_alias("bitchange:shop", "exchange_shop:shop")
|
||||||
dofile(modpath .. "/shop_functions.lua")
|
dofile(modpath .. "/shop_functions.lua")
|
||||||
dofile(modpath .. "/shop.lua")
|
dofile(modpath .. "/shop.lua")
|
||||||
end
|
end
|
||||||
|
|
||||||
if has_currency then
|
if has_currency then
|
||||||
if migrate_currency then
|
local new_groups = table.copy(minetest.registered_nodes["currency:shop"].groups)
|
||||||
|
new_groups.not_in_creative_inventory = 1
|
||||||
|
minetest.override_item("currency:shop", {
|
||||||
|
groups = new_groups
|
||||||
|
})
|
||||||
|
|
||||||
dofile(modpath .. "/currency_migrate.lua")
|
dofile(modpath .. "/currency_migrate.lua")
|
||||||
end
|
if exchange_shop.migrate.on_interact then
|
||||||
if slow_migrate_currency then
|
|
||||||
dofile(modpath .. "/currency_override.lua")
|
dofile(modpath .. "/currency_override.lua")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user