2020-12-16 16:33:41 +01:00
|
|
|
-- serialize_lib
|
|
|
|
--[[
|
|
|
|
Copyright (C) 2020 Moritz Blei (orwell96) and contributors
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as
|
|
|
|
published by the Free Software Foundation, either version 3 of the
|
|
|
|
License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
]]--
|
|
|
|
|
|
|
|
serialize_lib = {}
|
|
|
|
|
|
|
|
--[[ Configuration table
|
|
|
|
Whenever asked for a "config", the following table structure is expected:
|
|
|
|
config = {
|
|
|
|
skip_empty_tables = false -- if true, does not store empty tables
|
|
|
|
-- On next read, keys that mapped to empty tables resolve to nil
|
|
|
|
-- Used by: write_table_to_file
|
|
|
|
}
|
|
|
|
Not all functions use all of the parameters, so you can simplify your config sometimes
|
|
|
|
]]
|
|
|
|
|
|
|
|
-- log utils
|
|
|
|
-- =========
|
|
|
|
|
|
|
|
|
|
|
|
function serialize_lib.log_error(text)
|
2020-12-21 20:03:49 +01:00
|
|
|
minetest.log("error", "[serialize_lib] ("..(minetest.get_current_modname() or "?").."): "..(text or "<nil>"))
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
|
|
|
function serialize_lib.log_warn(text)
|
2020-12-21 20:03:49 +01:00
|
|
|
minetest.log("warning", "[serialize_lib] ("..(minetest.get_current_modname() or "?").."): "..(text or "<nil>"))
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
|
|
|
function serialize_lib.log_info(text)
|
2020-12-21 20:03:49 +01:00
|
|
|
minetest.log("action", "[serialize_lib] ("..(minetest.get_current_modname() or "?").."): "..(text or "<nil>"))
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
|
|
|
function serialize_lib.log_debug(text)
|
2020-12-21 20:03:49 +01:00
|
|
|
minetest.log("action", "[serialize_lib] ("..(minetest.get_current_modname() or "?")..") DEBUG: "..(text or "<nil>"))
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
-- basic serialization/deserialization
|
|
|
|
-- ===================================
|
|
|
|
|
2020-12-21 20:03:49 +01:00
|
|
|
local mp = minetest.get_modpath(minetest.get_current_modname())
|
|
|
|
serialize_lib.serialize = dofile(mp.."/serialize.lua")
|
|
|
|
dofile(mp.."/atomic.lua")
|
|
|
|
|
|
|
|
local ser = serialize_lib.serialize
|
2020-12-16 16:33:41 +01:00
|
|
|
|
|
|
|
-- Opens the passed filename, and returns deserialized table
|
|
|
|
-- When an error occurs, logs an error and returns false
|
|
|
|
function serialize_lib.read_table_from_file(filename)
|
2020-12-21 20:03:49 +01:00
|
|
|
local succ, ret = pcall(ser.read_from_file, filename)
|
2020-12-16 16:33:41 +01:00
|
|
|
if not succ then
|
2020-12-21 20:03:49 +01:00
|
|
|
serialize_lib.log_error(ret)
|
2021-03-22 12:13:19 +01:00
|
|
|
return false,ret
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
2020-12-21 20:03:49 +01:00
|
|
|
return ret
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
-- Writes table into file
|
|
|
|
-- When an error occurs, logs an error and returns false
|
2020-12-21 20:03:49 +01:00
|
|
|
function serialize_lib.write_table_to_file(root_table, filename)
|
|
|
|
local succ, ret = pcall(ser.write_to_file, root_table, filename)
|
2020-12-16 16:33:41 +01:00
|
|
|
if not succ then
|
2020-12-21 20:03:49 +01:00
|
|
|
serialize_lib.log_error(ret)
|
2021-03-22 12:13:19 +01:00
|
|
|
return false,ret
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
2021-03-22 12:13:19 +01:00
|
|
|
return true
|
2020-12-16 16:33:41 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
|