void CC_svcvar(void) { char cvarName[MAX_CVAR_VALUE_STRING]; char mode[16]; char cvarValue1[MAX_CVAR_VALUE_STRING]; char cvarValue2[MAX_CVAR_VALUE_STRING]; int i; int index = level.svCvarsCount; if (trap_Argc() <= 3) { G_Printf("usage: sv_cvar <cvar name> <mode> <value1> <value2>\n"); return; } trap_Argv(1, cvarName, sizeof(cvarName)); trap_Argv(2, mode, sizeof(mode)); trap_Argv(3, cvarValue1, sizeof(cvarValue1)); if (trap_Argc() == 5) { trap_Argv(4, cvarValue2, sizeof(cvarValue2)); } // is this cvar already in the array?.. (maybe they have a double entry) for (i = 0; i < level.svCvarsCount; i++) { if (!Q_stricmp(cvarName, level.svCvars[i].cvarName)) { index = i; } } if (index >= MAX_SVCVARS) { G_Printf("sv_cvar: MAX_SVCVARS hit\n"); return; } if (!Q_stricmp(mode, "EQ") || !Q_stricmp(mode, "EQUAL")) { level.svCvars[index].mode = SVC_EQUAL; } else if (!Q_stricmp(mode, "G") || !Q_stricmp(mode, "GREATER")) { level.svCvars[index].mode = SVC_GREATER; } else if (!Q_stricmp(mode, "GE") || !Q_stricmp(mode, "GREATEREQUAL")) { level.svCvars[index].mode = SVC_GREATEREQUAL; } else if (!Q_stricmp(mode, "L") || !Q_stricmp(mode, "LOWER")) { level.svCvars[index].mode = SVC_LOWER; } else if (!Q_stricmp(mode, "LE") || !Q_stricmp(mode, "LOWEREQUAL")) { level.svCvars[index].mode = SVC_LOWEREQUAL; } else if (!Q_stricmp(mode, "IN") || !Q_stricmp(mode, "INSIDE")) { level.svCvars[index].mode = SVC_INSIDE; } else if (!Q_stricmp(mode, "OUT") || !Q_stricmp(mode, "OUTSIDE")) { level.svCvars[index].mode = SVC_OUTSIDE; } else if (!Q_stricmp(mode, "INC") || !Q_stricmp(mode, "INCLUDE")) { level.svCvars[index].mode = SVC_INCLUDE; } else if (!Q_stricmp(mode, "EXC") || !Q_stricmp(mode, "EXCLUDE")) { level.svCvars[index].mode = SVC_EXCLUDE; } else { G_Printf("sv_cvar: invalid mode\n"); return; } if (trap_Argc() == 5) { Q_strncpyz(level.svCvars[index].Val2, cvarValue2, sizeof(level.svCvars[0].Val2)); } else { Q_strncpyz(level.svCvars[index].Val2, "", sizeof(level.svCvars[0].Val2)); } Q_strncpyz(level.svCvars[index].cvarName, cvarName, sizeof(level.svCvars[0].cvarName)); Q_strncpyz(level.svCvars[index].Val1, cvarValue1, sizeof(level.svCvars[0].Val1)); // cvar wasn't yet in the array? if (index >= level.svCvarsCount) { level.svCvarsCount++; } G_UpdateSvCvars(); }
/* ================= ConsoleCommand ================= */ qboolean ConsoleCommand(void) { char cmd[MAX_TOKEN_CHARS]; trap_Argv(0, cmd, sizeof(cmd)); #ifdef FEATURE_LUA if (!Q_stricmp(cmd, "lua_status")) { G_LuaStatus(NULL); return qtrue; } // *LUA* API callbacks if (G_LuaHook_ConsoleCommand(cmd)) { return qtrue; } #endif if (Q_stricmp(cmd, "entitylist") == 0) { Svcmd_EntityList_f(); return qtrue; } if (Q_stricmp(cmd, "forceteam") == 0) { Svcmd_ForceTeam_f(); return qtrue; } if (Q_stricmp(cmd, "game_memory") == 0) { Svcmd_GameMem_f(); return qtrue; } if (Q_stricmp(cmd, "addip") == 0) { Svcmd_AddIP_f(); return qtrue; } if (Q_stricmp(cmd, "removeip") == 0) { Svcmd_RemoveIP_f(); return qtrue; } if (Q_stricmp(cmd, "listip") == 0) { trap_SendConsoleCommand(EXEC_INSERT, "g_banIPs\n"); return qtrue; } if (Q_stricmp(cmd, "listmaxlivesip") == 0) { PrintMaxLivesGUID(); return qtrue; } if (Q_stricmp(cmd, "start_match") == 0) { Svcmd_StartMatch_f(); return qtrue; } if (Q_stricmp(cmd, "reset_match") == 0) { Svcmd_ResetMatch_f(qtrue, qtrue); return qtrue; } if (Q_stricmp(cmd, "swap_teams") == 0) { Svcmd_SwapTeams_f(); return qtrue; } if (Q_stricmp(cmd, "shuffle_teams") == 0) { Svcmd_ShuffleTeams_f(); return qtrue; } if (Q_stricmp(cmd, "makeReferee") == 0) { G_MakeReferee(); return qtrue; } if (Q_stricmp(cmd, "removeReferee") == 0) { G_RemoveReferee(); return qtrue; } /*if (Q_stricmp (cmd, "mute") == 0) { G_MuteClient(); return qtrue; } if (Q_stricmp (cmd, "unmute") == 0) { G_UnMuteClient(); return qtrue; }*/ if (Q_stricmp(cmd, "ban") == 0) { G_PlayerBan(); return qtrue; } if (Q_stricmp(cmd, "campaign") == 0) { Svcmd_Campaign_f(); return qtrue; } if (Q_stricmp(cmd, "listcampaigns") == 0) { Svcmd_ListCampaigns_f(); return qtrue; } if (Q_stricmp(cmd, "revive") == 0) { trap_Argv(1, cmd, sizeof(cmd)); Svcmd_RevivePlayer(cmd); return qtrue; } // fretn - moved from engine if (!Q_stricmp(cmd, "kick")) { Svcmd_Kick_f(); return qtrue; } if (!Q_stricmp(cmd, "clientkick")) { Svcmd_KickNum_f(); return qtrue; } #ifdef FEATURE_OMNIBOT if (!Q_stricmp(cmd, "bot")) { Bot_Interface_ConsoleCommand(); return qtrue; } #endif if (!Q_stricmp(cmd, "sv_cvarempty")) { memset(level.svCvars, 0, sizeof(level.svCvars)); level.svCvarsCount = 0; G_UpdateSvCvars(); return qtrue; } if (!Q_stricmp(cmd, "sv_cvar")) { CC_svcvar(); return qtrue; } if (!Q_stricmp(cmd, "playsound") || !Q_stricmp(cmd, "playsound_env")) { G_PlaySound_Cmd(); return qtrue; } if (g_dedicated.integer) { if (!Q_stricmp(cmd, "say")) { trap_SendServerCommand(-1, va("cpm \"server: %s\n\"", ConcatArgs(1))); return qtrue; } // OSP - console also gets ref commands if (!level.fLocalHost && Q_stricmp(cmd, "ref") == 0) { // G_refCommandCheck expects the next argument (warn, pause, lock,..) trap_Argv(1, cmd, sizeof(cmd)); if (!G_refCommandCheck(NULL, cmd)) { G_refHelp_cmd(NULL); } return qtrue; } // everything else will also be printed as a say command // trap_SendServerCommand( -1, va("cpm \"server: %s\n\"", ConcatArgs(0) ) ); // prints to the console instead now return qfalse; } return qfalse; }
qboolean ConsoleCommand(void) { char cmd[MAX_TOKEN_CHARS]; trap_Argv(0, cmd, sizeof(cmd)); #ifdef FEATURE_LUA if (!Q_stricmp(cmd, "lua_status")) { G_LuaStatus(NULL); return qtrue; } if (Q_stricmp(cmd, "lua_api") == 0) { G_LuaStackDump(); return qtrue; } // *LUA* API callbacks if (G_LuaHook_ConsoleCommand(cmd)) { return qtrue; } #endif if (Q_stricmp(cmd, "entitylist") == 0) { Svcmd_EntityList_f(); return qtrue; } if (Q_stricmp(cmd, "csinfo") == 0) { Svcmd_CSInfo_f(); return qtrue; } if (Q_stricmp(cmd, "forceteam") == 0) { Svcmd_ForceTeam_f(); return qtrue; } if (Q_stricmp(cmd, "game_memory") == 0) { Svcmd_GameMem_f(); return qtrue; } if (Q_stricmp(cmd, "addip") == 0) { Svcmd_AddIP_f(); return qtrue; } if (Q_stricmp(cmd, "removeip") == 0) { Svcmd_RemoveIP_f(); return qtrue; } if (Q_stricmp(cmd, "listip") == 0) { trap_SendConsoleCommand(EXEC_INSERT, "g_banIPs\n"); return qtrue; } if (Q_stricmp(cmd, "listmaxlivesip") == 0) { PrintMaxLivesGUID(); return qtrue; } if (Q_stricmp(cmd, "start_match") == 0) { Svcmd_StartMatch_f(); return qtrue; } if (Q_stricmp(cmd, "reset_match") == 0) { Svcmd_ResetMatch_f(qtrue, qtrue); return qtrue; } if (Q_stricmp(cmd, "swap_teams") == 0) { Svcmd_SwapTeams_f(); return qtrue; } if (Q_stricmp(cmd, "shuffle_teams") == 0) { Svcmd_ShuffleTeams_f(qtrue); return qtrue; } if (Q_stricmp(cmd, "shuffle_teams_norestart") == 0) { Svcmd_ShuffleTeams_f(qfalse); return qtrue; } if (Q_stricmp(cmd, "makeReferee") == 0) { G_MakeReferee(); return qtrue; } if (Q_stricmp(cmd, "removeReferee") == 0) { G_RemoveReferee(); return qtrue; } if (Q_stricmp(cmd, "mute") == 0) { G_MuteClient(); return qtrue; } if (Q_stricmp(cmd, "unmute") == 0) { G_UnMuteClient(); return qtrue; } if (Q_stricmp(cmd, "ban") == 0) { G_PlayerBan(); return qtrue; } if (Q_stricmp(cmd, "campaign") == 0) { Svcmd_Campaign_f(); return qtrue; } if (Q_stricmp(cmd, "listcampaigns") == 0) { Svcmd_ListCampaigns_f(); return qtrue; } if (Q_stricmp(cmd, "revive") == 0) { trap_Argv(1, cmd, sizeof(cmd)); Svcmd_RevivePlayer(cmd); return qtrue; } // moved from engine if (!Q_stricmp(cmd, "kick")) { Svcmd_Kick_f(); return qtrue; } if (!Q_stricmp(cmd, "clientkick")) { Svcmd_KickNum_f(); return qtrue; } #ifdef FEATURE_OMNIBOT if (!Q_stricmp(cmd, "bot")) { Bot_Interface_ConsoleCommand(); return qtrue; } #endif if (!Q_stricmp(cmd, "cp")) { trap_SendServerCommand(-1, va("cp \"%s\"", Q_AddCR(ConcatArgs(1)))); return qtrue; } if (!Q_stricmp(cmd, "reloadConfig")) { trap_SetConfigstring(CS_CONFIGNAME, ""); memset(&level.config, 0, sizeof(config_t)); G_configSet(g_customConfig.string); return qtrue; } if (!Q_stricmp(cmd, "loadConfig")) { CC_loadconfig(); return qtrue; } if (!Q_stricmp(cmd, "sv_cvarempty")) { memset(level.svCvars, 0, sizeof(level.svCvars)); level.svCvarsCount = 0; G_UpdateSvCvars(); return qtrue; } if (!Q_stricmp(cmd, "sv_cvar")) { CC_svcvar(); return qtrue; } if (!Q_stricmp(cmd, "playsound") || !Q_stricmp(cmd, "playsound_env")) { G_PlaySound_Cmd(); return qtrue; } //if (g_cheats.integer) //{ if (!Q_stricmp(cmd, "gib")) { Svcmd_Gib(); return qtrue; } if (!Q_stricmp(cmd, "die")) { Svcmd_Die(); return qtrue; } if (!Q_stricmp(cmd, "freeze")) { Svcmd_Freeze(); return qtrue; } if (!Q_stricmp(cmd, "unfreeze")) { Svcmd_Unfreeze(); return qtrue; } if (!Q_stricmp(cmd, "burn")) { Svcmd_Burn(); return qtrue; } if (!Q_stricmp(cmd, "pip")) { Svcmd_Pip(); return qtrue; } if (!Q_stricmp(cmd, "throw")) { Svcmd_Fling(1); return qtrue; } //} if (g_dedicated.integer) { // FIXME // this 'say' condition is never reached?! if (!Q_stricmp(cmd, "say")) { trap_SendServerCommand(-1, va("cpm \"server: %s\n\"", Q_AddCR(ConcatArgs(1)))); return qtrue; } // added for rcon/Lua chat if (!Q_stricmp(cmd, "chat")) { trap_SendServerCommand(-1, va("chat \"console: %s\"", Q_AddCR(ConcatArgs(1)))); return qtrue; } // console also gets ref commands if (!level.fLocalHost && Q_stricmp(cmd, "ref") == 0) { //G_refCommandCheck expects the next argument (warn, pause, lock,..) trap_Argv(1, cmd, sizeof(cmd)); if (!G_refCommandCheck(NULL, cmd)) { G_refHelp_cmd(NULL); } return qtrue; } // everything else will also be printed as a say command //trap_SendServerCommand( -1, va("cpm \"server: %s\n\"", ConcatArgs(0) ) ); // prints to the console instead now return qfalse; } return qfalse; }