Drop: support for colddb

This commit is contained in:
Coder12a 2019-12-31 19:28:24 -06:00
parent e16e72956f
commit 01a13d6b8f
3 changed files with 31 additions and 42 deletions

View File

@ -9,21 +9,12 @@ factions.parcels = {}
factions.players = {} factions.players = {}
factions.player_ips = {} factions.player_ips = {}
if factions_config.database == "colddb" then
-- Create cold databases.
factions.root = colddb.Colddb(minetest.get_worldpath() .. "/factions")
factions.factions = factions.root.sub_database("factions")
factions.parcels = factions.root.sub_database("parcels")
factions.players = factions.root.sub_database("players")
factions.player_ips = factions.root.sub_database("ips")
elseif factions_config.database == "mod_storage" then
dofile (minetest.get_modpath("fac_database") .. "/storagedb.lua") dofile (minetest.get_modpath("fac_database") .. "/storagedb.lua")
factions.root = storagedb.Storagedb("factions") factions.root = storagedb.Storagedb("factions")
factions.factions = factions.root.sub_database("factions") factions.factions = factions.root.sub_database("factions")
factions.parcels = factions.root.sub_database("parcels") factions.parcels = factions.root.sub_database("parcels")
factions.players = factions.root.sub_database("players") factions.players = factions.root.sub_database("players")
factions.player_ips = factions.root.sub_database("ips") factions.player_ips = factions.root.sub_database("ips")
end
-- Memory only storage. -- Memory only storage.
factions.onlineplayers = {} factions.onlineplayers = {}

View File

@ -1,3 +1,2 @@
name = fac_database name = fac_database
depends = fac_config depends = fac_config
optional_depends = colddb

View File

@ -16,51 +16,31 @@ function storagedb.Storagedb(dir)
setmetatable(mem_pool_del, {__mode = "kv"}) setmetatable(mem_pool_del, {__mode = "kv"})
local function storekey(key) local function storekey(key)
local list = minetest.deserialize(storage:get_string(directory)) local list = deserializer(storage:get_string(directory))
if not list then if not list then
list = {} list = {}
list[key] = key list[key] = key
else else
list[key] = key list[key] = key
end end
storage:set_string(directory, minetest.serialize(list)) storage:set_string(directory, serializer(list))
end end
local function removekey(key) local function removekey(key)
local list = minetest.deserialize(storage:get_string(directory)) local list = deserializer(storage:get_string(directory))
if not list then if not list then
list = {} list = {}
else else
list[key] = nil list[key] = nil
end end
storage:set_string(directory, minetest.serialize(list)) storage:set_string(directory, serializer(list))
end end
local function getkeys() local function getkeys()
local list = minetest.deserialize(storage:get_string(directory)) local list = deserializer(storage:get_string(directory))
if not list then if not list then
list = {} list = {}
end end
return list return list
end end
self.get_memory_pool = function()
return mem_pool
end
self.set_memory_pool = function(pool)
mem_pool = pool
end
self.add_to_memory_pool = function(value)
if value then
add_to_mem_pool = value
end
return add_to_mem_pool
end
self.get_serializer = function()
return serializer, deserializer
end
self.set_serializer = function(coder, decoder)
serializer = coder
deserializer = decoder
end
local function load_into_mem(name, _table) local function load_into_mem(name, _table)
if add_to_mem_pool then if add_to_mem_pool then
mem_pool[name] = {mem = _table} mem_pool[name] = {mem = _table}
@ -79,7 +59,7 @@ function storagedb.Storagedb(dir)
return false return false
end end
storekey(name) storekey(name)
storage:set_string(string.format("%s/%s", directory, name), minetest.serialize(_table)) storage:set_string(string.format("%s/%s", directory, name), serializer(_table))
end end
local function save_key(name) local function save_key(name)
storage:set_string(string.format("%s/%s", directory, name), "") storage:set_string(string.format("%s/%s", directory, name), "")
@ -91,6 +71,25 @@ function storagedb.Storagedb(dir)
end end
return false return false
end end
self.get_memory_pool = function()
return mem_pool
end
self.set_memory_pool = function(pool)
mem_pool = pool
end
self.add_to_memory_pool = function(value)
if value then
add_to_mem_pool = value
end
return add_to_mem_pool
end
self.get_serializer = function()
return serializer, deserializer
end
self.set_serializer = function(coder, decoder)
serializer = coder
deserializer = decoder
end
self.set_mem = function(name, _table) self.set_mem = function(name, _table)
load_into_mem(name, _table) load_into_mem(name, _table)
mem_pool_del[name] = nil mem_pool_del[name] = nil