summaryrefslogtreecommitdiff
path: root/src/game
diff options
context:
space:
mode:
authorkai <kai@zittrig.eu>2020-04-30 20:22:17 +0100
committerkai <kai@zittrig.eu>2020-04-30 20:22:17 +0100
commitb8afc34152545616674d51c2e37570c7980f69ea (patch)
treed429c4b7686beab57b93a65027bed2c5d0daf2ce /src/game
parentfcc97a2517aadd2a91601a1e3a5fd0a62ab73636 (diff)
show turnout when voting
Diffstat (limited to 'src/game')
-rw-r--r--src/game/g_main.c50
1 files changed, 37 insertions, 13 deletions
diff --git a/src/game/g_main.c b/src/game/g_main.c
index 9535288..942643f 100644
--- a/src/game/g_main.c
+++ b/src/game/g_main.c
@@ -2525,7 +2525,8 @@ CheckVote
void CheckVote( void )
{
int votePassThreshold=level.votePassThreshold;
- int voteYesPercent;
+ int voteYesPercent, turnout;
+ char *turnoutCol;
if( level.voteExecuteTime && level.voteExecuteTime < level.time )
{
@@ -2569,23 +2570,46 @@ void CheckVote( void )
else
voteYesPercent = 0;
+ turnout = 100 * ( level.voteYes + level.voteNo ) / level.numConnectedClients;
+
+ if( turnout <= 10)
+ {
+ turnoutCol = "^1";
+ }
+ else if( turnout > 10 && turnout <= 33)
+ {
+ turnoutCol = "^A";
+ }
+ else if( turnout > 33 && turnout <= 66)
+ {
+ turnoutCol = "^C";
+ }
+ else if( turnout > 66 && turnout <= 90)
+ {
+ turnoutCol = "^Z";
+ }
+ else
+ {
+ turnoutCol = "^2";
+ }
+
if( ( level.time - level.voteTime >= VOTE_TIME ) ||
( level.voteYes + level.voteNo == level.numConnectedClients ) )
{
if( voteYesPercent> votePassThreshold || level.voteNo == 0 )
{
// execute the command, then remove the vote
- trap_SendServerCommand( -1, va("print \"Vote ^Zpassed ^7(^ZYes: ^7%d | ^ANo: ^7%d)\n\"",
- level.voteYes, level.voteNo ) );
- G_LogPrintf( "Vote: Vote passed (%d-%d)\n", level.voteYes, level.voteNo );
+ trap_SendServerCommand( -1, va("print \"Vote ^Zpassed ^7(^ZYes^7: %d | ^ANo^7: %d | ^dTurnout^7: %s%i%%^7)\n\"",
+ level.voteYes, level.voteNo, turnoutCol, turnout ) );
+ G_LogPrintf( "Vote: Vote passed (%d - %d), turnout: %i%%\n", level.voteYes, level.voteNo, turnout );
level.voteExecuteTime = level.time + 3000;
}
else
{
// same behavior as a timeout
- trap_SendServerCommand( -1, va("print \"Vote ^Afailed ^7(^ZYes: ^7%d | ^ANo: ^7%d)\n\"",
- level.voteYes, level.voteNo ) );
- G_LogPrintf( "Vote: Vote failed (%d - %d)\n", level.voteYes, level.voteNo );
+ trap_SendServerCommand( -1, va("print \"Vote ^Afailed ^7(^ZYes^7: %d | ^ANo^7: %d | ^dTurnout^7: %s%i%%^7)\n\"",
+ level.voteYes, level.voteNo, turnoutCol, turnout ) );
+ G_LogPrintf( "Vote: Vote failed (%d - %d), turnout: %i%%\n", level.voteYes, level.voteNo, turnout );
}
}
else
@@ -2594,18 +2618,18 @@ void CheckVote( void )
( (double) votePassThreshold/100.0 ) ) )
{
// execute the command, then remove the vote
- trap_SendServerCommand( -1, va("print \"Vote ^Zpassed ^7(^ZYes: ^7%d | ^ANo: ^7%d)\n\"",
- level.voteYes, level.voteNo ) );
- G_LogPrintf( "Vote: Vote passed (%d - %d)\n", level.voteYes, level.voteNo );
+ trap_SendServerCommand( -1, va("print \"Vote ^Afailed ^7(^ZYes^7: %d | ^ANo^7: %d | ^dTurnout^7: %s%i%%^7)\n\"",
+ level.voteYes, level.voteNo, turnoutCol, turnout ) );
+ G_LogPrintf( "Vote: Vote passed (%d - %d), turnout: %i%%\n", level.voteYes, level.voteNo, turnout );
level.voteExecuteTime = level.time + 3000;
}
else if( level.voteNo > (int)( (double) level.numConnectedClients *
( (double) ( 100.0-votePassThreshold )/ 100.0 ) ) )
{
// same behavior as a timeout
- trap_SendServerCommand( -1, va("print \"Vote ^Afailed ^7(^ZYes: ^7%d | ^ANo: ^7%d)\n\"",
- level.voteYes, level.voteNo ) );
- G_LogPrintf("Vote failed\n");
+ trap_SendServerCommand( -1, va("print \"Vote ^Afailed ^7(^ZYes^7: %d | ^ANo^7: %d | ^dTurnout^7: %s%i%%^7)\n\"",
+ level.voteYes, level.voteNo, turnoutCol, turnout ) );
+ G_LogPrintf( "Vote: Vote failed (%d - %d), turnout: %i%%\n", level.voteYes, level.voteNo, turnout );
}
else
{