mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2024-11-23 04:42:32 +00:00
- add a match command, which prints out who would be matched with a
ban/cuff/mute/kick command, but without actually doing them :) - fix 'leet nick matching of eet in 37337, and a segfault, as well as simplifying the code :)
This commit is contained in:
parent
4bc167c5aa
commit
bdfa1830fe
1 changed files with 33 additions and 13 deletions
|
@ -82,6 +82,10 @@ match_char (char a, char b)
|
|||
return false;
|
||||
}
|
||||
|
||||
/*
|
||||
FIXME: this function and it's callers are getting progressively
|
||||
uglier as more features are added :)
|
||||
*/
|
||||
qboolean
|
||||
SV_Match_User (const char *substr, int *uidp)
|
||||
{
|
||||
|
@ -91,9 +95,11 @@ SV_Match_User (const char *substr, int *uidp)
|
|||
client_t *cl;
|
||||
|
||||
if (!substr[0]) {
|
||||
if (uidp) {
|
||||
*uidp = 0;
|
||||
SV_Printf ("Too many matches, ignoring command!\n");
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
for (i = 0, cl = svs.clients; i < MAX_CLIENTS; i++, cl++) {
|
||||
if (!cl->state)
|
||||
|
@ -105,23 +111,22 @@ SV_Match_User (const char *substr, int *uidp)
|
|||
if (!match_char (substr[j], str[j]))
|
||||
break;
|
||||
if (!substr[j]) { // found a match;
|
||||
if (uidp)
|
||||
*uidp = cl->userid;
|
||||
count++;
|
||||
SV_Printf ("User %04d matches with name: %s\n",
|
||||
*uidp, cl->name);
|
||||
str = 0;
|
||||
} else {
|
||||
str = strchr (str + 1, substr[0]);
|
||||
for (str = str + 1;
|
||||
*str && !match_char (*str, substr[0]); str++)
|
||||
;
|
||||
cl->userid, cl->name);
|
||||
break;
|
||||
}
|
||||
str++;
|
||||
}
|
||||
}
|
||||
if (count > 1) {
|
||||
if (uidp) {
|
||||
*uidp = 0;
|
||||
SV_Printf ("Too many matches, ignoring command!\n");
|
||||
}
|
||||
}
|
||||
if (count)
|
||||
return true;
|
||||
return false;
|
||||
|
@ -746,6 +751,19 @@ SV_Ban_f (void)
|
|||
Con_Printf ("Couldn't find user %s\n", Cmd_Argv(1));
|
||||
}
|
||||
|
||||
void
|
||||
SV_Match_f (void)
|
||||
{
|
||||
if (Cmd_Argc() != 2) {
|
||||
SV_Printf ("usage: match <name/userid>\n");
|
||||
return;
|
||||
}
|
||||
|
||||
if (!SV_Match_User (Cmd_Argv(1), NULL))
|
||||
SV_Printf ("No usernames matched, would treat as number\n");
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
SV_ConSay (const char *prefix)
|
||||
{
|
||||
|
@ -1196,6 +1214,8 @@ SV_InitOperatorCommands (void)
|
|||
"specified time");
|
||||
Cmd_AddCommand ("mute", SV_Mute_f, "silience a player for a specified "
|
||||
"time");
|
||||
Cmd_AddCommand ("match", SV_Match_f, "matches nicks as ban/cuff/mute "
|
||||
"commands do, so you can check safely");
|
||||
|
||||
cl_warncmd = Cvar_Get ("cl_warncmd", "1", CVAR_NONE, NULL, "Toggles the "
|
||||
"display of error messages for unknown commands");
|
||||
|
|
Loading…
Reference in a new issue