struct searchNode *modes_parse(searchCtx *ctx, int argc, char **argv) {
struct modes_localdata *localdata;
- struct searchNode *thenode;
+ struct searchNode *thenode, *modestring;
const flag *flaglist;
-
+ char *p;
+
if (argc!=1) {
parseError="modes: usage: modes (mode string)";
return NULL;
if (ctx->searchcmd == reg_chansearch) {
flaglist=cmodeflags;
- } else if (ctx->searchcmd == reg_nicksearch) {
+ } else if (ctx->searchcmd == reg_nicksearch || ctx->searchcmd == reg_whowassearch) {
flaglist=umodeflags;
} else {
parseError="modes: unsupported search type";
localdata->setmodes=0;
localdata->clearmodes = ~0;
- setflags(&(localdata->setmodes), 0xFFFF, argv[0], flaglist, REJECT_NONE);
- setflags(&(localdata->clearmodes), 0xFFFF, argv[0], flaglist, REJECT_NONE);
-
+ if (!(modestring=argtoconststr("modes", ctx, argv[0], &p))) {
+ free(localdata);
+ return NULL;
+ }
+
+ setflags(&(localdata->setmodes), 0xFFFF, p, flaglist, REJECT_NONE);
+ setflags(&(localdata->clearmodes), 0xFFFF, p, flaglist, REJECT_NONE);
+ (modestring->free)(ctx, modestring);
+
localdata->clearmodes = ~(localdata->clearmodes);
if (!(thenode=(struct searchNode *)malloc(sizeof(struct searchNode)))) {
if (!cip->channel)
return NULL;
flags=cip->channel->flags;
- } else if (ctx->searchcmd == reg_nicksearch) {
+ } else if (ctx->searchcmd == reg_nicksearch || ctx->searchcmd == reg_whowassearch) {
np=(nick *)value;
flags=np->umodes;
} else {