Fix data converter

I used a old factions version and created two teams with land claims and ranks. It converted fine. Make sure you pick the same parcel size as the old save file because if they are not they don't show up in the same spot or not at all.
This commit is contained in:
Coder12a 2018-10-28 22:03:55 -05:00
parent c069828a28
commit bc54df4925

View File

@ -127,8 +127,7 @@ end
function factions.start_diplomacy(name,faction) function factions.start_diplomacy(name,faction)
for i in pairs(factions.factions) do for i in pairs(factions.factions) do
if i ~= name and not (faction.neutral[i] or faction.allies[i] or faction.enemies[i]) then if i ~= name and not (faction.neutral[i] or faction.allies[i] or faction.enemies[i]) then
faction:new_enemy(factions.factions[i].name) faction:new_enemy(i)
factions.factions[i]:new_enemy(faction.name)
end end
end end
end end
@ -841,14 +840,16 @@ function factions.load()
local current_version = misc_mod_data.data.factions_version local current_version = misc_mod_data.data.factions_version
misc_mod_data.load() misc_mod_data.load()
local old_version = misc_mod_data.data.factions_version local old_version = misc_mod_data.data.factions_version
factions.factions = minetest.deserialize(raw_data) local tabledata = minetest.deserialize(raw_data)
if current_version ~= old_version or factions.is_old_file(factions.factions) then file:close()
if tabledata then
factions.factions = tabledata
if current_version ~= old_version or factions.is_old_file(tabledata) then
if factions.convert(filename) then if factions.convert(filename) then
minetest.after(5, minetest.after(5,
function() function()
minetest.chat_send_all("Factions successfully converted.") minetest.chat_send_all("Factions successfully converted.")
end) end)
factions.save()
end end
end end
for facname, faction in pairs(factions.factions) do for facname, faction in pairs(factions.factions) do
@ -882,14 +883,27 @@ function factions.load()
if faction.no_parcel ~= -1 then if faction.no_parcel ~= -1 then
faction.no_parcel = os.time() faction.no_parcel = os.time()
end end
if faction:count_land() > 0 then
faction.no_parcel = -1
end
if faction.onlineplayers and faction.offlineplayers then
for i, _ in pairs(faction.onlineplayers) do for i, _ in pairs(faction.onlineplayers) do
faction.offlineplayers[i] = _ faction.offlineplayers[i] = _
end end
else
faction.offlineplayers = {}
end
faction.onlineplayers = {} faction.onlineplayers = {}
end end
file:close()
misc_mod_data.data.factions_version = current_version misc_mod_data.data.factions_version = current_version
misc_mod_data.save() misc_mod_data.save()
factions.save()
else
minetest.after(5,
function()
minetest.chat_send_all("Failed to deserialize saved file.")
end)
end
end end
factions_ip.load() factions_ip.load()
end end
@ -931,23 +945,40 @@ function factions.convert(filename)
return false return false
end end
local raw_data = file:read("*a") local raw_data = file:read("*a")
file:close()
local data = minetest.deserialize(raw_data) local data = minetest.deserialize(raw_data)
for facname,faction in pairs(data) do for facname,faction in pairs(data) do
local newfac = factions.new_faction(facname) local newfac = factions.new_faction(facname,true)
for oi, ol in pairs(faction) do for oi, ol in pairs(faction) do
if newfac[oi] then if newfac[oi] then
newfac[oi] = ol newfac[oi] = ol
end end
end end
for player, unused in pairs(newfac.players) do if faction.players then
factions.players[player] = newfac.name newfac.players = faction.players
end end
for land, unused in pairs(newfac.land) do if faction.land then
factions.parcels[land] = newfac.name newfac.land = faction.land
end
if faction.ranks then
newfac.ranks = faction.ranks
end end
factions.start_diplomacy(facname,newfac) factions.start_diplomacy(facname,newfac)
newfac:check_power() newfac:check_power()
end end
-- Create runtime data.
for facname,faction in pairs(factions.factions) do
if faction.players then
for player, unused in pairs(faction.players) do
factions.players[player] = faction.name
end
end
if faction.land then
for l, unused in pairs(faction.land) do
factions.parcels[l] = facname
end
end
end
return true return true
end end
@ -1001,7 +1032,7 @@ function(player)
if faction:has_permission(name, "diplomacy") then if faction:has_permission(name, "diplomacy") then
for _ in pairs(faction.request_inbox) do minetest.chat_send_player(name,"You have diplomatic requests in the inbox.") break end for _ in pairs(faction.request_inbox) do minetest.chat_send_player(name,"You have diplomatic requests in the inbox.") break end
end end
if faction.message_of_the_day ~= "" or faction.message_of_the_day ~= " " then if faction.message_of_the_day and (faction.message_of_the_day ~= "" or faction.message_of_the_day ~= " ") then
minetest.chat_send_player(name,faction.message_of_the_day) minetest.chat_send_player(name,faction.message_of_the_day)
end end
end end