Compare commits

..

5 Commits

Author SHA1 Message Date
Not
bc002667c8 v1.2.7 2022-03-28 13:11:21 +02:00
Not
b0d5b5abeb v1.2.6 2022-03-28 13:11:00 +02:00
Not
18a81fab6d v1.2.5 2022-03-28 13:10:43 +02:00
Not
9a1fb0677a v1.2.4 2022-03-28 13:10:13 +02:00
Not
321ff7737c v1.2.3 2022-03-28 13:09:52 +02:00

View File

@ -7,6 +7,7 @@ local disable = true
local prevLap = 0
local splits = {}
local PATCH = nil
local help = true
local Flags = 0
@ -91,42 +92,90 @@ else
print("Failed to open file: ", FILENAME)
end
local function initLeaderboard(player)
local ingame = 0
local function ingame()
local n = 0
for p in players.iterate do
if p.valid and not p.spectator then
ingame = ingame + 1
n = $ + 1
end
end
disable = ingame > 1
return n
end
if disable then
--print("To many players in game, leaderboard has been disabled")
return
end
local function initLeaderboard(player)
disable = ingame() > 1
end
addHook("PlayerSpawn", initLeaderboard)
local function retry(player, ...)
local function doyoudare(player)
if disable or player.spectator then
CONS_Printf(player, "How dare you")
return
return false
end
return true
end
COM_BufInsertText(server, "map " + G_BuildMapName(gamemap))
local function retry(player, ...)
if doyoudare(player) then
COM_BufInsertText(server, "map " + G_BuildMapName(gamemap))
end
end
COM_AddCommand("retry", retry)
local function exitlevel(player, ...)
if disable or player.spectator then
CONS_Printf(player, "How dare you")
return
if doyoudare(player) then
G_ExitLevel()
end
G_ExitLevel()
end
COM_AddCommand("exit", exitlevel)
local function mapNotExists(player, map)
CONS_Printf(player, string.format("Map doesn't exist: %s", map:upper()))
end
local ALPH = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
local function changelevel(player, ...)
if not doyoudare(player) then
return
end
local map = ...
if map == nil then
CONS_Printf(player, "Usage: changelevel MAPXX")
return
end
local p, q = map:upper():match("MAP(%w)(%w)$", 1)
if not (p and q) then
CONS_Printf(player, string.format("Invalid map name: %s", map))
return
end
local mapnum = 0
if tonumber(p) != nil then
-- Non extended map numbers
if tonumber(q) == nil then
mapNotExists(player, map)
return
end
mapnum = tonumber(p) * 10 + tonumber(q)
else
--Extended map numbers
p = ALPH:find(p) - 1
q = (tonumber(q) or ALPH:find(q) + 9)
mapnum = 36 * p + q + 100
end
if mapheaderinfo[mapnum] == nil then
mapNotExists(player, map)
return
end
COM_BufInsertText(server, "map " + (G_BuildMapName(mapnum)))
end
COM_AddCommand("changelevel", changelevel)
local function clearcheats(player)
if not player.spectator then
clearcheats = true
@ -186,6 +235,17 @@ local function drawitem(v, x, y, scale, itempatch, vflags)
)
end
local function marquee(text, maxwidth)
if #text <= maxwidth then
return text
end
local shift = 16
local pos = ((leveltime / 16) % (#text - maxwidth + shift * 2)) + 1 - shift
pos = min(max(pos, 1), #text - maxwidth + 1)
return text:sub(pos, pos + maxwidth - 1)
end
local bodium = {V_YELLOWMAP, V_GRAYMAP, V_BROWNMAP, 0}
local splitColor = {[true]=V_SKYMAP, [false]=V_REDMAP}
local splitSymbol = {[true]="-", [false]="+"}
@ -273,7 +333,7 @@ local function drawScoreboard(v, player)
stralign = "small"
py = 2
if v.stringWidth(name, 0, "small") > MAXWIDTH then
name = name:sub(0, 15) + "..."
name = marquee(name, 15)
end
end
end
@ -410,6 +470,7 @@ end
local function think()
if disable then
help = true
return
end
if showSplit > 0 then
@ -417,6 +478,18 @@ local function think()
end
if leveltime < startTime then
-- Help message
if leveltime == startTime - TICRATE * 3 then
if ingame() == 1 then
if help then
help = false
chatprint("\x89Leaderboard Commands:\nretry exit findmap changelevel spba_clearcheats", true)
end
else
help = true
end
end
Flags = $ & !(F_SPBATK | F_SPBEXP | F_SPBBIG | F_SPBJUS)
if leveltime > startTime - (3 * TICRATE) / 2 and server.SPBArunning then
Flags = $ | F_SPBATK