summaryrefslogtreecommitdiff
path: root/src/game
diff options
context:
space:
mode:
authorMikko Tiusanen <ams@daug.net>2014-07-03 23:35:50 +0300
committerMikko Tiusanen <ams@daug.net>2014-07-03 23:36:57 +0300
commit7cca5892b8abdbafeccf5407ee83cfe3906fcaae (patch)
tree8e18b2dc4ac25b49e3a92d61e5e0019b6350aaff /src/game
parent6c8c4388491928043fb6e2175616656db12fa754 (diff)
Incognito admins are now listed as having player level 2.
Added broadcast command and support for colors and formatting in cpa.
Diffstat (limited to 'src/game')
-rw-r--r--src/game/g_admin.c67
-rw-r--r--src/game/g_admin.h1
2 files changed, 48 insertions, 20 deletions
diff --git a/src/game/g_admin.c b/src/game/g_admin.c
index c134351..d3908ad 100644
--- a/src/game/g_admin.c
+++ b/src/game/g_admin.c
@@ -79,6 +79,11 @@ g_admin_cmd_t g_admin_cmds[ ] =
"[^5name|slot#|IP(/mask)^5] (^5duration^5) (^5reason^5)"
},
+ {"broadcast", G_admin_broadcast, qfalse, "broadcast",
+ "display a console message to all users, optionally specifying team(s) to send to",
+ "(^5-A|H|S^5) [^5message^5]"
+ },
+
{"builder", G_admin_builder, qtrue, "builder",
"show who built a structure",
""
@@ -2343,9 +2348,8 @@ qboolean G_admin_changemap( gentity_t *ent )
return qtrue;
}
-qboolean G_admin_cp( gentity_t *ent )
-{
- char message[ 64 ];
+qboolean cp_broadcast( gentity_t *ent, qboolean cp ) {
+ char *message;
char arg[ 8 ];
int team = -1;
int i;
@@ -2353,7 +2357,7 @@ qboolean G_admin_cp( gentity_t *ent )
if( trap_Argc( ) < 2 )
{
- ADMP( "^5cpa: ^5usage: cpa (-AHS) [message]\n" );
+ ADMP( "^5broadcast: ^5usage: broadcast (-AHS) [message]\n" );
return qfalse;
}
trap_Argv( 1, arg, sizeof( arg ) );
@@ -2371,18 +2375,21 @@ qboolean G_admin_cp( gentity_t *ent )
team = TEAM_NONE;
break;
default:
- ADMP( "^5cpa: ^5team not recognized as -a -h or -s\n" );
+ ADMP( "^5broadcast: ^5team not recognized as -a -h or -s\n" );
return qfalse;
}
if( trap_Argc( ) < 2 )
{
- ADMP( "^5cpa: ^5no message\n" );
+ ADMP( "^5broadcast: ^5no message\n" );
return qfalse;
}
- G_DecolorString( ConcatArgs( 2 ), message, sizeof( message ) );
+
+ message = ConcatArgs( 2 );
}
else
- G_DecolorString( ConcatArgs( 1 ), message, sizeof( message ) );
+ {
+ message = ConcatArgs( 1 );
+ }
for( i = 0; i < level.maxclients; i++ )
{
@@ -2393,24 +2400,40 @@ qboolean G_admin_cp( gentity_t *ent )
if( team < 0 || level.clients[ i ].pers.teamSelection == team ||
( admin = G_admin_permission( &g_entities[ i ], ADMF_ADMINCHAT ) ) )
{
- if( !admin )
- trap_SendServerCommand( i, va( "cp \"^%s%s\"",
- ( team < 0 ) ? "2" : "5", message ) );
- trap_SendServerCommand( i, va( "print \"%s^5CPA: ^5%s%s^5%s%s%s: %c%s\n\"",
- ( admin ) ? "[ADMIN] " : "",
- ( team >= 0 ) ? "(" : "",
- admin_name( ent ),
- ( team >= 0 ) ? ")" : "",
- ( admin ) ? " to " : "",
- ( admin ) ? BG_TeamName( team ) : "",
- INDENT_MARKER,
- message ) );
+ if( cp ) {
+ if( !admin )
+ trap_SendServerCommand( i, va( "cp \"^%s%s\"",
+ ( team < 0 ) ? "2" : "5", message ) );
+ trap_SendServerCommand( i, va( "print \"%s^5CPA: ^5%s%s^5%s%s%s: %c%s\n\"",
+ ( admin ) ? "[ADMIN] " : "",
+ ( team >= 0 ) ? "(" : "",
+ admin_name( ent ),
+ ( team >= 0 ) ? ")" : "",
+ ( admin ) ? " to " : "",
+ ( admin ) ? BG_TeamName( team ) : "",
+ INDENT_MARKER,
+ message ) );
+ }
+ else if( !admin )
+ {
+ trap_SendServerCommand( i, va( "print \"^5%s\n\"", message ) );
+ }
}
}
return qtrue;
}
+qboolean G_admin_broadcast( gentity_t *ent )
+{
+ return cp_broadcast( ent, qfalse );
+}
+
+qboolean G_admin_cp( gentity_t *ent )
+{
+ return cp_broadcast( ent, qtrue );
+}
+
qboolean G_admin_warn( gentity_t *ent )
{
char reason[ 64 ];
@@ -2699,6 +2722,10 @@ qboolean G_admin_listplayers( gentity_t *ent )
if( Q_stricmp( namecleaned, name2cleaned ) )
registeredname = p->pers.admin->name;
}
+ else
+ {
+ l = G_admin_level( 2 ); // Display 'Verified Player' level
+ }
}
if( l )
diff --git a/src/game/g_admin.h b/src/game/g_admin.h
index 38b3e3e..e94b33d 100644
--- a/src/game/g_admin.h
+++ b/src/game/g_admin.h
@@ -179,6 +179,7 @@ qboolean G_admin_listlayouts( gentity_t *ent );
qboolean G_admin_listplayers( gentity_t *ent );
qboolean G_admin_changemap( gentity_t *ent );
qboolean G_admin_cp( gentity_t *ent );
+qboolean G_admin_broadcast( gentity_t *ent );
qboolean G_admin_warn( gentity_t *ent );
qboolean G_admin_mute( gentity_t *ent );
qboolean G_admin_denybuild( gentity_t *ent );