From a0e9b32bebe33e33e34f7f51952c4d7b5406782e Mon Sep 17 00:00:00 2001 From: Mikko Tiusanen Date: Thu, 16 Oct 2014 23:17:29 +0300 Subject: Changed score_info to use namelog, new option for score penalty on early quit. --- src/game/g_admin.c | 47 +++++++++++++++++++++++++++-------------------- src/game/g_admin.h | 6 +++--- src/game/g_team.c | 2 ++ 3 files changed, 32 insertions(+), 23 deletions(-) (limited to 'src') diff --git a/src/game/g_admin.c b/src/game/g_admin.c index 2ffb647..d1ff924 100644 --- a/src/game/g_admin.c +++ b/src/game/g_admin.c @@ -3414,32 +3414,35 @@ qboolean G_admin_namelog( gentity_t *ent ) qboolean G_admin_score_info( gentity_t *ent ) { - char reason[ 64 ]; int pid; - char name[ MAX_NAME_LENGTH ], err[ MAX_STRING_CHARS ]; - gentity_t *vic; + char name[ MAX_NAME_LENGTH ]; + g_admin_admin_t *target; + namelog_t *match; if( trap_Argc() < 2 ) { ADMP( va( "^3score: ^7usage: score [name|slot#]\n" ) ); return qfalse; } + trap_Argv( 1, name, sizeof( name ) ); - if( ( pid = G_ClientNumberFromString( name, err, sizeof( err ) ) ) == -1 ) + + if( !( match = G_NamelogFromString( ent, name ) ) ) { - ADMP( va( "^3score: ^7%s\n", err ) ); + ADMP( va( "^3score: ^7no namelog match for %s\n", name ) ); return qfalse; } - vic = &g_entities[ pid ]; - if( vic->client->pers.admin ) - { - ADMP( va( "score: ^7%s^7 level: %d score: %d\n\"", - vic->client->pers.netname, - vic->client->pers.admin->level, - vic->client->pers.admin->score ) ); - } else { - ADMP( va( "score: ^7%s^7 does not have an admin record.\n" ) ); + + target = G_admin_admin( match->guid ); + if( target == NULL ) { + ADMP( va( "^3score: ^7no admin record found for %s\n", name ) ); + return qfalse; } + + ADMP( va( "score: ^7%s^7 level: %d score: %d\n", + match->name[match->nameOffset], + target->level, + target->score ) ); return qtrue; } @@ -3839,9 +3842,9 @@ void G_admin_add_score( gentity_t *ent, int score ) { a = ent->client->pers.admin; a->level = n->level; admin_log( va( "^7%d (%s^7) \"%s" S_COLOR_WHITE "\"", a->level, a->guid, a->name ) ); - AP( va("print \"^3setlevel: ^7%s^7 was given level %d admin rights (^7%s^7) through score gained\n\"", + AP( va("print \"^3setlevel: ^7%s^7 was given level %d admin rights (^7%s^7) through score gained\\\n\"", a->name, a->level, n->name ) ); - admin_writeconfig(); + // admin_writeconfig(); } } } @@ -3853,19 +3856,23 @@ void G_admin_reset_score( gentity_t *ent ) { if( ent->client->pers.admin && level.numAlienClients >= g_AutoLevelMinTeamSize.integer && level.numHumanClients >= g_AutoLevelMinTeamSize.integer ) { a = ent->client->pers.admin; l = G_admin_find_level_for_score( a->score ); - if( g_RageQuitScorePenalty.integer < 0 ) { + admin_log( va( "score reset: %d (%s) \"%s" S_COLOR_WHITE "\"", a->level, a->guid, a->name ) ); + if( g_RageQuitScorePenalty.integer == -1 ) { a->score = l->score; - admin_log( va( "score reset: %d (%s) \"%s" S_COLOR_WHITE "\"", a->level, a->guid, a->name ) ); AP( va("print \"^3score: ^7%s^7 score advance towards next level reset due to rage quit.\n\"", a->name ) ); + } else if( g_RageQuitScorePenalty.integer == -2 ) { + a->score -= ent->client->ps.persistant[ PERS_SCORE ]; + if( a->score < l->score ) a->score = l->score; + AP( va("print \"^3score: ^7%s^7 score earned during this game has been lost.\n\"", + a->name ) ); } else { a->score -= g_RageQuitScorePenalty.integer; if( a->score < l->score ) a->score = l->score; - admin_log( va( "score penalty: %d (%s) \"%s" S_COLOR_WHITE "\"", a->level, a->guid, a->name ) ); AP( va("print \"^3score: ^7%s^7 score penalty of %d total score due to rage quit.\n\"", a->name, g_RageQuitScorePenalty.integer ) ); } - admin_writeconfig(); + // admin_writeconfig(); } } diff --git a/src/game/g_admin.h b/src/game/g_admin.h index ccdb01e..4953cfe 100644 --- a/src/game/g_admin.h +++ b/src/game/g_admin.h @@ -192,9 +192,6 @@ qboolean G_admin_admintest( gentity_t *ent ); qboolean G_admin_allready( gentity_t *ent ); qboolean G_admin_endvote( gentity_t *ent ); qboolean G_admin_spawn( gentity_t *ent ); -g_admin_level_t *G_admin_find_level_for_score( int score ); -void G_admin_add_score( gentity_t *ent, int score ); -void G_admin_reset_score( gentity_t *ent ); qboolean G_admin_spec999( gentity_t *ent ); qboolean G_admin_rename( gentity_t *ent ); qboolean G_admin_restart( gentity_t *ent ); @@ -210,6 +207,9 @@ qboolean G_admin_flaglist( gentity_t *ent ); qboolean G_admin_flag( gentity_t *ent ); qboolean G_admin_slap( gentity_t *ent ); +g_admin_level_t *G_admin_find_level_for_score( int score ); +void G_admin_add_score( gentity_t *ent, int score ); +void G_admin_reset_score( gentity_t *ent ); g_admin_level_t *G_admin_level( const int l ); g_admin_level_t *G_admin_level_next( g_admin_level_t *level ); diff --git a/src/game/g_team.c b/src/game/g_team.c index 6ffac38..a89d043 100644 --- a/src/game/g_team.c +++ b/src/game/g_team.c @@ -225,6 +225,8 @@ void G_LeaveTeam( gentity_t *self ) G_namelog_update_score( self->client ); ent->client->pers.newTeam = TEAM_NONE; + + admin_writeconfig(); } /* -- cgit