- 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:
Adam Olsen 2001-09-11 07:10:45 +00:00
parent 4bc167c5aa
commit bdfa1830fe

View file

@ -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");