Merge pull request 'Only save/load files for the server' (#6) from Lonsfor/srb2k-leaderboard:lonsfor-patch-3 into master

Reviewed-on: #6
This commit is contained in:
Not 2022-11-14 14:22:43 +01:00
commit 1d4eb423d6

View File

@ -272,60 +272,62 @@ local function stat_str(stat)
end end
-- Read the leaderboard -- Read the leaderboard
local f = io.open(FILENAME, "r") if isserver then
if f then local f = io.open(FILENAME, "r")
for l in f:lines() do if f then
-- Leaderboard is stored in the following tab separated format for l in f:lines() do
-- mapnum, name, skin, color, time, splits, flags, stat -- Leaderboard is stored in the following tab separated format
local t = {} -- mapnum, name, skin, color, time, splits, flags, stat
for word in (l+"\t"):gmatch("(.-)\t") do local t = {}
table.insert(t, word) for word in (l+"\t"):gmatch("(.-)\t") do
end table.insert(t, word)
local flags = 0
if t[7] != nil then
flags = tonumber(t[7])
end
scoreTable = getScoreTable(tonumber(t[1]), flags) or {}
local spl = {}
if t[6] != nil then
for str in t[6]:gmatch("([^ ]+)") do
table.insert(spl, tonumber(str))
end end
end
local stats = nil local flags = 0
if t[8] != nil then if t[7] != nil then
if #t[8] >= 2 then flags = tonumber(t[7])
local speed = tonumber(string.sub(t[8], 1, 1))
local weight = tonumber(string.sub(t[8], 2, 2))
stats = stat_t(speed, weight)
end end
end
table.insert( scoreTable = getScoreTable(tonumber(t[1]), flags) or {}
scoreTable,
score_t( local spl = {}
tonumber(t[1]), if t[6] != nil then
t[2], for str in t[6]:gmatch("([^ ]+)") do
t[3], table.insert(spl, tonumber(str))
t[4], end
tonumber(t[5]), end
spl,
flags, local stats = nil
stats if t[8] != nil then
if #t[8] >= 2 then
local speed = tonumber(string.sub(t[8], 1, 1))
local weight = tonumber(string.sub(t[8], 2, 2))
stats = stat_t(speed, weight)
end
end
table.insert(
scoreTable,
score_t(
tonumber(t[1]),
t[2],
t[3],
t[4],
tonumber(t[5]),
spl,
flags,
stats
)
) )
)
setScoreTable(tonumber(t[1]), flags, scoreTable) setScoreTable(tonumber(t[1]), flags, scoreTable)
end
sortScores()
f:close()
else
print("Failed to open file: ", FILENAME)
end end
sortScores()
f:close()
else
print("Failed to open file: ", FILENAME)
end end
function allowJoin(v) function allowJoin(v)
@ -1315,30 +1317,32 @@ local function saveTime(player)
StatTrack = true StatTrack = true
end end
local f = assert(io.open(FILENAME, "w")) if isserver then
if f == nil then local f = assert(io.open(FILENAME, "w"))
print("Failed to open file for writing: " + FILENAME) if f == nil then
return print("Failed to open file for writing: " + FILENAME)
end return
end
for _, tbl in pairs(lb) do for _, tbl in pairs(lb) do
for _, scoreTable in pairs(tbl) do for _, scoreTable in pairs(tbl) do
for _, score in ipairs(scoreTable) do for _, score in ipairs(scoreTable) do
f:write( f:write(
score["map"], "\t", score["map"], "\t",
score["name"], "\t", score["name"], "\t",
score["skin"], "\t", score["skin"], "\t",
score["color"], "\t", score["color"], "\t",
score["time"], "\t", score["time"], "\t",
table.concat(score["splits"], " "), "\t", table.concat(score["splits"], " "), "\t",
score["flags"], "\t", score["flags"], "\t",
stat_str(score["stat"]), "\n" stat_str(score["stat"]), "\n"
) )
end
end end
end end
end
f:close() f:close()
end
end end
-- DEBUGGING -- DEBUGGING