From 23ffa4d5863192a0a687ec2db5766ce97bc04b3b Mon Sep 17 00:00:00 2001 From: Erik Minekus Date: Mon, 19 Oct 2020 13:24:29 +0200 Subject: [PATCH] Add {nextmap} variable with MapChooser support --- addons/sourcemod/configs/advertisements.txt | 2 +- addons/sourcemod/scripting/advertisements.sp | 23 ++++++++++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/addons/sourcemod/configs/advertisements.txt b/addons/sourcemod/configs/advertisements.txt index 8c8e9ad..5fd4286 100644 --- a/addons/sourcemod/configs/advertisements.txt +++ b/addons/sourcemod/configs/advertisements.txt @@ -28,7 +28,7 @@ } "3" { - "menu" "Next map is {sm_nextmap} in {timeleft} minutes." + "menu" "Next map is {nextmap} in {timeleft} minutes." "flags" "cft" } "4" diff --git a/addons/sourcemod/scripting/advertisements.sp b/addons/sourcemod/scripting/advertisements.sp index 9083e4c..71e5f28 100644 --- a/addons/sourcemod/scripting/advertisements.sp +++ b/addons/sourcemod/scripting/advertisements.sp @@ -1,5 +1,6 @@ #include #undef REQUIRE_PLUGIN +#include #include #include "advertisements/chatcolors.sp" #include "advertisements/topcolors.sp" @@ -36,6 +37,7 @@ enum struct Advertisement /** * Globals */ +bool g_bMapChooser; bool g_bSayText2; int g_iCurrentAd; ArrayList g_hAdvertisements; @@ -60,6 +62,7 @@ public void OnPluginStart() g_hFile.AddChangeHook(ConVarChange_File); g_hInterval.AddChangeHook(ConVarChange_Interval); + g_bMapChooser = LibraryExists("mapchooser"); g_bSayText2 = GetUserMessageId("SayText2") != INVALID_MESSAGE_ID; g_hAdvertisements = new ArrayList(sizeof(Advertisement)); @@ -81,11 +84,21 @@ public void OnConfigsExecuted() public void OnLibraryAdded(const char[] name) { + if (StrEqual(name, "mapchooser")) { + g_bMapChooser = true; + } if (StrEqual(name, "updater")) { Updater_AddPlugin(UPDATE_URL); } } +public void OnLibraryRemoved(const char[] name) +{ + if (StrEqual(name, "mapchooser")) { + g_bMapChooser = false; + } +} + public void ConVarChange_File(ConVar convar, const char[] oldValue, const char[] newValue) { ParseAds(); @@ -303,8 +316,18 @@ void ProcessVariables(const char[] message, char[] buffer, int maxlength) if (StrEqual(name, "currentmap", false)) { GetCurrentMap(value, sizeof(value)); + GetMapDisplayName(value, value, sizeof(value)); buf_idx += strcopy(buffer[buf_idx], maxlength - buf_idx, value); } + else if (StrEqual(name, "nextmap", false)) { + if (g_bMapChooser && EndOfMapVoteEnabled() && !HasEndOfMapVoteFinished()) { + buf_idx += strcopy(buffer[buf_idx], maxlength - buf_idx, "Pending Vote"); + } else { + GetNextMap(value, sizeof(value)); + GetMapDisplayName(value, value, sizeof(value)); + buf_idx += strcopy(buffer[buf_idx], maxlength - buf_idx, value); + } + } else if (StrEqual(name, "date", false)) { FormatTime(value, sizeof(value), "%m/%d/%Y"); buf_idx += strcopy(buffer[buf_idx], maxlength - buf_idx, value);