From 325ae5e97701651f0701d2018a7e6c2b27c6debc Mon Sep 17 00:00:00 2001 From: Nicholas Hastings Date: Tue, 11 Oct 2011 19:47:20 -0400 Subject: [PATCH] Added better Nuclear Dawn compatibility to base plugins (bug 5117, r=fyren). --- plugins/basetriggers.sp | 10 +++++++++- plugins/funcommands.sp | 18 +++++++++++++++++- plugins/mapchooser.sp | 32 +++++++++++++++++++++++++++----- 3 files changed, 53 insertions(+), 7 deletions(-) diff --git a/plugins/basetriggers.sp b/plugins/basetriggers.sp index f4d94670..732dc66b 100644 --- a/plugins/basetriggers.sp +++ b/plugins/basetriggers.sp @@ -97,7 +97,15 @@ public OnPluginStart() HookEvent("game_start", Event_GameStart); } - HookEvent("round_end", Event_RoundEnd); + if (strcmp(folder, "nucleardawn") == 0) + { + HookEvent("round_win", Event_RoundEnd); + } + else + { + HookEvent("round_end", Event_RoundEnd); + } + HookEventEx("teamplay_win_panel", Event_TeamPlayWinPanel); HookEventEx("teamplay_restart_round", Event_TFRestartRound); HookEventEx("arena_win_panel", Event_TeamPlayWinPanel); diff --git a/plugins/funcommands.sp b/plugins/funcommands.sp index c525c2bb..5fe1be5c 100644 --- a/plugins/funcommands.sp +++ b/plugins/funcommands.sp @@ -158,7 +158,23 @@ RegisterCmds( ) HookEvents( ) { - HookEvent("round_end", Event_RoundEnd, EventHookMode_PostNoCopy); + decl String:folder[64]; + GetGameFolderName(folder, sizeof(folder)); + + if (strcmp(folder, "tf") == 0) + { + HookEvent("teamplay_win_panel", Event_RoundEnd, EventHookMode_PostNoCopy); + HookEvent("teamplay_restart_round", Event_RoundEnd, EventHookMode_PostNoCopy); + HookEvent("arena_win_panel", Event_RoundEnd, EventHookMode_PostNoCopy); + } + else if (strcmp(folder, "nucleardawn") == 0) + { + HookEvent("round_win", Event_RoundEnd, EventHookMode_PostNoCopy); + } + else + { + HookEvent("round_end", Event_RoundEnd, EventHookMode_PostNoCopy); + } } public OnMapStart() diff --git a/plugins/mapchooser.sp b/plugins/mapchooser.sp index e074dce8..7ad497a2 100644 --- a/plugins/mapchooser.sp +++ b/plugins/mapchooser.sp @@ -137,10 +137,23 @@ public OnPluginStart() if (g_Cvar_Winlimit != INVALID_HANDLE || g_Cvar_Maxrounds != INVALID_HANDLE) { - HookEvent("round_end", Event_RoundEnd); - HookEventEx("teamplay_win_panel", Event_TeamPlayWinPanel); - HookEventEx("teamplay_restart_round", Event_TFRestartRound); - HookEventEx("arena_win_panel", Event_TeamPlayWinPanel); + decl String:folder[64]; + GetGameFolderName(folder, sizeof(folder)); + + if (strcmp(folder, "tf") == 0) + { + HookEvent("teamplay_win_panel", Event_TeamPlayWinPanel); + HookEvent("teamplay_restart_round", Event_TFRestartRound); + HookEvent("arena_win_panel", Event_TeamPlayWinPanel); + } + else if (strcmp(folder, "nucleardawn") == 0) + { + HookEvent("round_win", Event_RoundEnd); + } + else + { + HookEvent("round_end", Event_RoundEnd); + } } if (g_Cvar_Fraglimit != INVALID_HANDLE) @@ -407,7 +420,16 @@ public Event_RoundEnd(Handle:event, const String:name[], bool:dontBroadcast) g_ChangeMapInProgress = true; } - new winner = GetEventInt(event, "winner"); + new winner; + if (strcmp(name, "round_win") == 0) + { + // Nuclear Dawn + winner = GetEventInt(event, "team"); + } + else + { + winner = GetEventInt(event, "winner"); + } if (winner == 0 || winner == 1 || !GetConVarBool(g_Cvar_EndOfMapVote)) {