2013-09-02 19:16:14 -04:00
|
|
|
-- This file contains functions to convert from
|
|
|
|
-- the old areas format and other compatability code.
|
|
|
|
|
|
|
|
minetest.register_chatcommand("legacy_load_areas", {
|
2013-09-17 12:46:00 -04:00
|
|
|
params = "<version>",
|
2013-09-03 01:33:08 -04:00
|
|
|
description = "Loads, converts, and saves the areas from"
|
2013-09-17 12:46:00 -04:00
|
|
|
.." a legacy save file.",
|
2014-07-12 19:10:26 -04:00
|
|
|
privs = {areas=true, server=true},
|
2013-09-02 19:16:14 -04:00
|
|
|
func = function(name, param)
|
|
|
|
minetest.chat_send_player(name, "Converting areas...")
|
2013-09-17 12:46:00 -04:00
|
|
|
local version = tonumber(param)
|
|
|
|
if version == 0 then
|
|
|
|
err = areas:node_ownership_load()
|
|
|
|
if err then
|
|
|
|
minetest.chat_send_player(name, "Error loading legacy file: "..err)
|
|
|
|
return
|
|
|
|
end
|
|
|
|
else
|
|
|
|
minetest.chat_send_player(name, "Invalid version number. (0 allowed)")
|
2013-09-02 19:16:14 -04:00
|
|
|
return
|
|
|
|
end
|
|
|
|
minetest.chat_send_player(name, "Legacy file loaded.")
|
|
|
|
|
|
|
|
for k, area in pairs(areas.areas) do
|
2013-11-18 21:01:24 -05:00
|
|
|
-- New position format
|
|
|
|
area.pos1 = {x=area.x1, y=area.y1, z=area.z1}
|
|
|
|
area.pos2 = {x=area.x2, y=area.y2, z=area.z2}
|
2013-09-02 19:16:14 -04:00
|
|
|
|
2013-11-18 21:01:24 -05:00
|
|
|
area.x1, area.y1, area.z1,
|
|
|
|
area.x2, area.y2, area.z2 =
|
2013-09-02 19:16:14 -04:00
|
|
|
nil, nil, nil, nil, nil, nil
|
|
|
|
|
2013-11-18 21:01:24 -05:00
|
|
|
-- Area positions sorting
|
2014-07-12 16:37:54 -04:00
|
|
|
areas:sortPos(area.pos1, area.pos2)
|
2013-09-02 19:16:14 -04:00
|
|
|
|
2013-11-18 21:01:24 -05:00
|
|
|
-- Add name
|
|
|
|
area.name = "unnamed"
|
|
|
|
|
|
|
|
-- Remove ID
|
|
|
|
area.id = nil
|
2013-09-02 19:16:14 -04:00
|
|
|
end
|
|
|
|
minetest.chat_send_player(name, "Table format updated.")
|
|
|
|
|
|
|
|
areas:save()
|
2013-09-03 01:33:08 -04:00
|
|
|
minetest.chat_send_player(name, "Converted areas saved. Done.")
|
2014-07-12 16:37:54 -04:00
|
|
|
end
|
|
|
|
})
|
2013-09-02 19:16:14 -04:00
|
|
|
|
2013-09-17 12:38:29 -04:00
|
|
|
function areas:node_ownership_load()
|
2013-09-02 19:16:14 -04:00
|
|
|
local filename = minetest.get_worldpath().."/owners.tbl"
|
|
|
|
tables, err = loadfile(filename)
|
|
|
|
if err then
|
|
|
|
return err
|
|
|
|
end
|
|
|
|
|
|
|
|
tables = tables()
|
|
|
|
for idx = 1, #tables do
|
|
|
|
local tolinkv, tolinki = {}, {}
|
|
|
|
for i, v in pairs(tables[idx]) do
|
|
|
|
if type(v) == "table" and tables[v[1]] then
|
|
|
|
table.insert(tolinkv, {i, tables[v[1]]})
|
|
|
|
end
|
|
|
|
if type(i) == "table" and tables[i[1]] then
|
|
|
|
table.insert(tolinki, {i, tables[i[1]]})
|
|
|
|
end
|
|
|
|
end
|
|
|
|
-- link values, first due to possible changes of indices
|
|
|
|
for _, v in ipairs(tolinkv) do
|
|
|
|
tables[idx][v[1]] = v[2]
|
|
|
|
end
|
|
|
|
-- link indices
|
|
|
|
for _, v in ipairs(tolinki) do
|
|
|
|
tables[idx][v[2]], tables[idx][v[1]] = tables[idx][v[1]], nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
self.areas = tables[1]
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Returns the name of the first player that owns an area
|
|
|
|
function areas.getNodeOwnerName(pos)
|
2014-01-15 20:10:24 -05:00
|
|
|
for id, area in pairs(areas:getAreasAtPos(pos)) do
|
|
|
|
return area.owner
|
2013-09-02 19:16:14 -04:00
|
|
|
end
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Checks if a node is owned by you
|
|
|
|
function areas.isNodeOwner(pos, name)
|
2014-07-12 19:10:26 -04:00
|
|
|
if minetest.check_player_privs(name, areas.adminPrivs) then
|
2013-09-02 19:16:14 -04:00
|
|
|
return true
|
|
|
|
end
|
2014-01-15 20:10:24 -05:00
|
|
|
for id, area in pairs(areas:getAreasAtPos(pos)) do
|
|
|
|
if name == area.owner then
|
|
|
|
return true
|
2013-09-02 19:16:14 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
|
2013-11-14 18:26:57 -05:00
|
|
|
-- Checks if an area has an owner
|
|
|
|
function areas.hasOwner(pos)
|
2014-01-15 20:10:24 -05:00
|
|
|
for id, area in pairs(areas:getAreasAtPos(pos)) do
|
|
|
|
return true
|
2013-11-14 18:26:57 -05:00
|
|
|
end
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
|
2013-09-02 19:16:14 -04:00
|
|
|
IsPlayerNodeOwner = areas.isNodeOwner
|
|
|
|
GetNodeOwnerName = areas.getNodeOwnerName
|
|
|
|
HasOwner = areas.hasOwner
|
|
|
|
|
2013-09-17 12:38:29 -04:00
|
|
|
-- This is entirely untested and may break in strange and new ways.
|
2013-09-02 19:16:14 -04:00
|
|
|
if areas.legacy_table then
|
2014-07-12 19:18:31 -04:00
|
|
|
owner_defs = setmetatable({}, {
|
2013-09-02 19:16:14 -04:00
|
|
|
__index = function(table, key)
|
|
|
|
local a = rawget(areas.areas, key)
|
2014-07-12 19:18:31 -04:00
|
|
|
if not a then return a end
|
|
|
|
local b = {}
|
|
|
|
for k, v in pairs(a) do b[k] = v end
|
|
|
|
b.x1, b.y1, b.z1 = b.pos1.x, b.pos1.y, b.pos1.z
|
|
|
|
b.x2, b.y1, b.z2 = b.pos2.x, b.pos2.y, b.pos2.z
|
|
|
|
b.pos1, b.pos2 = nil, nil
|
|
|
|
b.id = key
|
|
|
|
return b
|
2013-09-02 19:16:14 -04:00
|
|
|
end,
|
|
|
|
__newindex = function(table, key, value)
|
2013-12-16 17:18:15 -05:00
|
|
|
local a = value
|
2014-07-12 19:18:31 -04:00
|
|
|
a.pos1, a.pos2 = {x=a.x1, y=a.y1, z=a.z1},
|
|
|
|
{x=a.x2, y=a.y2, z=a.z2}
|
2013-12-16 17:18:15 -05:00
|
|
|
a.x1, a.y1, a.z1, a.x2, a.y2, a.z2 =
|
|
|
|
nil, nil, nil, nil, nil, nil
|
|
|
|
a.name = a.name or "unnamed"
|
|
|
|
a.id = nil
|
|
|
|
return rawset(areas.areas, key, a)
|
2013-09-02 19:16:14 -04:00
|
|
|
end
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|