cvar_set("g_maplist", shufflewords(autocvar_g_maplist));
}
-float leaderscore;
-float secondscore;
int fragsleft_last;
float WinningCondition_Scores(float limit, float leadlimit)
{
limit = -limit;
}
- if(WinningConditionHelper_zeroisworst
- || (!autocvar_leadlimit_and_fraglimit && limit && leadlimit >= fabs(limit)))
+ if(WinningConditionHelper_zeroisworst)
leadlimit = 0; // not supported in this mode
if(MUTATOR_CALLHOOK(Scores_CountFragsRemaining))
- // these modes always score in increments of 1, thus this makes sense
{
- if (leaderscore != WinningConditionHelper_topscore ||
- secondscore != WinningConditionHelper_secondscore)
- {
- int fragsleft = 0;
-
- leaderscore = WinningConditionHelper_topscore;
- secondscore = WinningConditionHelper_secondscore;
+ float fragsleft = FLOAT_MAX, leadingfragsleft = FLOAT_MAX;
+ if (limit)
+ fragsleft = limit - WinningConditionHelper_topscore;
+ if (leadlimit)
+ leadingfragsleft = WinningConditionHelper_secondscore + leadlimit - WinningConditionHelper_topscore;
- if (limit)
- {
- if (leaderscore == limit - 1)
- fragsleft |= BIT(1);
- else if (leaderscore == limit - 2)
- fragsleft |= BIT(2);
- else if (leaderscore == limit - 3)
- fragsleft |= BIT(3);
- }
- if (leadlimit)
- {
- if (leaderscore == leadlimit + secondscore - 1)
- fragsleft |= BIT(1);
- else if (leaderscore == leadlimit + secondscore - 2)
- fragsleft |= BIT(2);
- else if (leaderscore == leadlimit + secondscore - 3)
- fragsleft |= BIT(3);
- }
-
- fragsleft = fragsleft & -fragsleft; // least significant bit where 1 is set
+ if (limit && leadlimit && autocvar_leadlimit_and_fraglimit)
+ fragsleft = max(fragsleft, leadingfragsleft);
+ else
+ fragsleft = min(fragsleft, leadingfragsleft);
- if (fragsleft_last != fragsleft) // do not announce same remaining frags multiple times
- {
- if (fragsleft & BIT(1))
- Send_Notification(NOTIF_ALL, NULL, MSG_ANNCE, ANNCE_REMAINING_FRAG_1);
- else if (fragsleft & BIT(2))
- Send_Notification(NOTIF_ALL, NULL, MSG_ANNCE, ANNCE_REMAINING_FRAG_2);
- else if (fragsleft & BIT(3))
- Send_Notification(NOTIF_ALL, NULL, MSG_ANNCE, ANNCE_REMAINING_FRAG_3);
-
- fragsleft_last = fragsleft;
- }
+ if (fragsleft_last != fragsleft) // do not announce same remaining frags multiple times
+ {
+ if (fragsleft == 1)
+ Send_Notification(NOTIF_ALL, NULL, MSG_ANNCE, ANNCE_REMAINING_FRAG_1);
+ else if (fragsleft == 2)
+ Send_Notification(NOTIF_ALL, NULL, MSG_ANNCE, ANNCE_REMAINING_FRAG_2);
+ else if (fragsleft == 3)
+ Send_Notification(NOTIF_ALL, NULL, MSG_ANNCE, ANNCE_REMAINING_FRAG_3);
+
+ fragsleft_last = fragsleft;
}
}
bool fraglimit_reached = (limit && WinningConditionHelper_topscore >= limit);
- bool leadlimit_reached = (WinningConditionHelper_topscore - WinningConditionHelper_secondscore >= leadlimit);
+ bool leadlimit_reached = (leadlimit && WinningConditionHelper_topscore - WinningConditionHelper_secondscore >= leadlimit);
bool limit_reached;
- if(autocvar_leadlimit_and_fraglimit)
+ // only respect leadlimit_and_fraglimit when both limits are set or the game will never end
+ if (limit && leadlimit && autocvar_leadlimit_and_fraglimit)
limit_reached = (fraglimit_reached && leadlimit_reached);
else
limit_reached = (fraglimit_reached || leadlimit_reached);