summaryrefslogtreecommitdiff
path: root/src/game/g_admin.c
diff options
context:
space:
mode:
authorIronClawTrem <louie.nutman@gmail.com>2020-02-20 19:46:51 +0000
committerIronClawTrem <louie.nutman@gmail.com>2020-02-20 19:46:51 +0000
commit47b7ec756a81b3fecd67ae0ebb52921f2debfcd5 (patch)
treefe498589ccf81884f3fa75209048097e7c10a00c /src/game/g_admin.c
parentf77fa03797d80118c65bd7e82a344d9934d7bde1 (diff)
add !switch command
Diffstat (limited to 'src/game/g_admin.c')
-rw-r--r--src/game/g_admin.c68
1 files changed, 68 insertions, 0 deletions
diff --git a/src/game/g_admin.c b/src/game/g_admin.c
index f3fc247..6280ada 100644
--- a/src/game/g_admin.c
+++ b/src/game/g_admin.c
@@ -426,6 +426,11 @@ g_admin_cmd_t g_admin_cmds[ ] =
{"print",G_admin_print2, "print",
"prints text",
"[text to print]"
+ },
+
+ {"switch", G_admin_switch, "switch",
+ "switch places with somenone",
+ "[^3name|slot#^7]"
}
};
@@ -8198,3 +8203,66 @@ qboolean G_admin_print2(gentity_t *ent, int skiparg )
AP( va( "print \"%s\n\"", text ));
return qtrue;
}
+
+qboolean G_admin_switch( gentity_t *ent, int skiparg )
+{
+ int pids[ MAX_CLIENTS ];
+ char name[ MAX_NAME_LENGTH ], err[ MAX_STRING_CHARS ];
+ int minargc;
+ gentity_t *vic;
+
+ if( !ent )
+ {
+ ADMP( "^3!switch: ^7console cannot use this command\n" );
+ return qfalse;
+ }
+
+ minargc = 2 + skiparg;
+
+ if( G_SayArgc() < minargc )
+ {
+ ADMP( "^3!switch: ^7usage: !switch [name|slot#]\n" );
+ return qfalse;
+ }
+
+ G_SayArgv( 1 + skiparg, name, sizeof( name ) );
+
+ if( G_ClientNumbersFromString( name, pids ) != 1 )
+ {
+ G_MatchOnePlayer( pids, err, sizeof( err ) );
+ ADMP( va( "^3!switch: ^7%s\n", err ) );
+ return qfalse;
+ }
+
+ vic = &g_entities[ pids[ 0 ] ];
+
+ //put them on noclip
+ vic->client->noclip = qtrue;
+ ent->client->noclip = qtrue;
+
+ //switch places
+ trap_UnlinkEntity( ent );
+ VectorCopy( vic->s.origin, ent->client->ps.origin );
+
+ //switch places
+ trap_UnlinkEntity( vic );
+ VectorCopy( ent->s.origin, vic->client->ps.origin );
+
+ //spectator fix
+ if( ent->client->sess.spectatorState == SPECTATOR_NOT )
+ trap_LinkEntity (ent);
+
+ if( vic->client->sess.spectatorState == SPECTATOR_NOT )
+ trap_LinkEntity (vic);
+
+
+ //take them off noclip
+ vic->client->noclip = qfalse;
+ ent->client->noclip = qfalse;
+
+ trap_SendServerCommand( vic-g_entities, va( "print \"^7%s^7 switched with you\n\"", ent->client->pers.netname ) );
+ trap_SendServerCommand( ent-g_entities, va( "print \"^7you switched with ^7%s^7\n\"", vic->client->pers.netname ) );
+
+ return qtrue;
+
+}