fixed round termination when one zombie and fixed reserve ammo
This commit is contained in:
parent
552a81ac14
commit
c907d9e99f
@ -171,7 +171,7 @@ public Action Timer_CheckIfRestartNeeded(Handle timer, any userid)
|
|||||||
if (activePlayers == 1)
|
if (activePlayers == 1)
|
||||||
{
|
{
|
||||||
PrintToChatAll("First Player joining. Restarting the round...");
|
PrintToChatAll("First Player joining. Restarting the round...");
|
||||||
CS_TerminateRound(4.0, CSRoundEnd_Draw, false);
|
CS_TerminateRound(4.0, CSRoundEnd_Draw, true);
|
||||||
}
|
}
|
||||||
return Plugin_Handled;
|
return Plugin_Handled;
|
||||||
}
|
}
|
||||||
@ -268,7 +268,7 @@ public Action Cmd_ChangeWave(int client, int args)
|
|||||||
{
|
{
|
||||||
g_iWave = l_iWave;
|
g_iWave = l_iWave;
|
||||||
PrintToChatAll("Admin %N Changing to Day %i: %s", client, g_iWave, g_cDaysTitles[g_iWave - 1]);
|
PrintToChatAll("Admin %N Changing to Day %i: %s", client, g_iWave, g_cDaysTitles[g_iWave - 1]);
|
||||||
CS_TerminateRound(4.0, CSRoundEnd_Draw, false);
|
CS_TerminateRound(4.0, CSRoundEnd_Draw, true);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -471,7 +471,7 @@ public void ZmarketGetWeapon(int client, int index)
|
|||||||
l_iEntity = CreateEntityByName(g_cWeaponEntity[index][g_iLength]);
|
l_iEntity = CreateEntityByName(g_cWeaponEntity[index][g_iLength]);
|
||||||
if (l_iEntity == -1)
|
if (l_iEntity == -1)
|
||||||
{
|
{
|
||||||
ReplyToCommand(client, "Error occured");
|
ReplyToCommand(client, "Error occured. cry to jenz");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
GetClientAbsOrigin(client, l_fClientPos);
|
GetClientAbsOrigin(client, l_fClientPos);
|
||||||
@ -485,6 +485,7 @@ public void ZmarketGetWeapon(int client, int index)
|
|||||||
CS_DropWeapon(client, l_iWeapon, false, true);
|
CS_DropWeapon(client, l_iWeapon, false, true);
|
||||||
AcceptEntityInput(l_iWeapon, "Kill");
|
AcceptEntityInput(l_iWeapon, "Kill");
|
||||||
}
|
}
|
||||||
|
DispatchKeyValueInt(l_iEntity, "ammo", 4500);
|
||||||
TeleportEntity(l_iEntity, l_fClientPos, NULL_VECTOR, NULL_VECTOR);
|
TeleportEntity(l_iEntity, l_fClientPos, NULL_VECTOR, NULL_VECTOR);
|
||||||
DispatchSpawn(l_iEntity);
|
DispatchSpawn(l_iEntity);
|
||||||
SetEntProp(client, Prop_Send, "m_iAccount", l_iClientCash - g_iWeaponPrice[index]);
|
SetEntProp(client, Prop_Send, "m_iAccount", l_iClientCash - g_iWeaponPrice[index]);
|
||||||
@ -1152,7 +1153,7 @@ public void LoadWave(int wave)
|
|||||||
{
|
{
|
||||||
g_iWave = 1;
|
g_iWave = 1;
|
||||||
PrintToChatAll("Finished last Day! Restarting...");
|
PrintToChatAll("Finished last Day! Restarting...");
|
||||||
CS_TerminateRound(5.0, CSRoundEnd_Draw, false);
|
CS_TerminateRound(5.0, CSRoundEnd_Draw, true);
|
||||||
}
|
}
|
||||||
delete kv;
|
delete kv;
|
||||||
delete l_hFile;
|
delete l_hFile;
|
||||||
@ -1778,7 +1779,7 @@ public Action UpdateWaveCount(int client)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
PrintToChatAll("All Humans died!");
|
PrintToChatAll("All Humans died!");
|
||||||
CS_TerminateRound(4.0, CSRoundEnd_TerroristWin, false);
|
CS_TerminateRound(4.0, CSRoundEnd_TerroristWin, true);
|
||||||
return Plugin_Handled;
|
return Plugin_Handled;
|
||||||
}
|
}
|
||||||
else if (GetClientTeam(client) == CS_TEAM_T)
|
else if (GetClientTeam(client) == CS_TEAM_T)
|
||||||
@ -1789,12 +1790,30 @@ public Action UpdateWaveCount(int client)
|
|||||||
if (g_iZMCount == 0 && g_bRoundInProgress)
|
if (g_iZMCount == 0 && g_bRoundInProgress)
|
||||||
{
|
{
|
||||||
PrintToChatAll("Won Round!");
|
PrintToChatAll("Won Round!");
|
||||||
CS_TerminateRound(4.0, CSRoundEnd_CTWin, false);
|
CS_TerminateRound(4.0, CSRoundEnd_CTWin, true);
|
||||||
g_iWave++;
|
g_iWave++;
|
||||||
g_bRoundInProgress = false;
|
g_bRoundInProgress = false;
|
||||||
}
|
}
|
||||||
return Plugin_Continue;
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Action CS_OnTerminateRound(float& delay, CSRoundEndReason& reason)
|
||||||
|
{
|
||||||
|
//generally we only want to block round termination when all (or the only) zombies are dead but the count requires that there
|
||||||
|
//are more left to kill. we wait for the zombie to respawn so we can kill him again until g_iZMCount reaches 0.
|
||||||
|
if (g_iZMCount > 0)
|
||||||
|
{
|
||||||
|
for (int i = 1; i <= MaxClients; i++)
|
||||||
|
{
|
||||||
|
if (IsValidClient(i) && IsPlayerAlive(i) && GetClientTeam(i) == CS_TEAM_CT)
|
||||||
|
{
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Plugin_Changed;
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
|
Loading…
Reference in New Issue
Block a user