X-Git-Url: https://jfr.im/git/irc/quakenet/newserv.git/blobdiff_plain/fa434c76bed715e8646e50c089bae5c4b7005354..8855bb48b449ed06cfd3ce528b3c0a77c37cb24b:/newsearch/newsearch.h diff --git a/newsearch/newsearch.h b/newsearch/newsearch.h index f8508fdb..a4414b30 100644 --- a/newsearch/newsearch.h +++ b/newsearch/newsearch.h @@ -11,7 +11,6 @@ #define NSMAX_KILL_LIMIT 500 #define NSMAX_GLINE_LIMIT 500 -#define NSMAX_GLINE_CLONES 5 /* gline duration, in seconds */ #define NSGLINE_DURATION 3600 @@ -126,6 +125,7 @@ struct searchNode *modes_parse(searchCtx *ctx, int argc, char **argv); /* Nick functions (various types) */ struct searchNode *hostmask_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *realname_parse(searchCtx *ctx, int argc, char **argv); +struct searchNode *away_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *authname_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *authts_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *ident_parse(searchCtx *ctx, int argc, char **argv); @@ -138,6 +138,7 @@ struct searchNode *channels_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *server_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *authid_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *cidr_parse(searchCtx *ctx, int argc, char **argv); +struct searchNode *ipv6_parse(searchCtx *ctx, int argc, char **argv); /* Channel functions (various types) */ struct searchNode *exists_parse(searchCtx *ctx, int argc, char **argv); @@ -146,13 +147,12 @@ struct searchNode *size_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *name_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *topic_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *oppct_parse(searchCtx *ctx, int argc, char **argv); +struct searchNode *cumodecount_parse(searchCtx *ctx, int argc, char **argv); +struct searchNode *cumodepct_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *hostpct_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *authedpct_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *kick_parse(searchCtx *ctx, int argc, char **argv); -/* Interpret a string to give a node */ -struct searchNode *search_parse(searchCtx *ctx, char *input); - /* Iteration functions */ struct searchNode *any_parse(searchCtx *ctx, int argc, char **argv); struct searchNode *all_parse(searchCtx *ctx, int argc, char **argv); @@ -183,6 +183,10 @@ void unregdisp( searchCmd *cmd, const char *name, void *handler); /* Special nick* printf */ void nssnprintf(char *, size_t, const char *, nick *); +#ifdef NEWSEARCH_NEWPARSER +void displaystrerror(replyFunc reply, nick *np, const char *input); +#endif + extern const char *parseError; extern nick *senderNSExtern; @@ -234,6 +238,12 @@ typedef struct searchASTExpr { } u; } searchASTExpr; +typedef struct searchASTCache { + searchASTExpr *tree; + searchASTExpr *cache[AST_RECENT]; + int nextpos; +} searchASTCache; + #define __NSASTSizeOfArray(x) (sizeof(x) / sizeof(x[0])) #define __NSASTExpr(x, y, ...) (searchASTExpr){.type = x, .u.y = __VA_ARGS__} @@ -271,4 +281,6 @@ extern UserDisplayFunc defaultuserfn; extern NickDisplayFunc defaultnickfn; extern ChanDisplayFunc defaultchanfn; +struct searchNode *argtoconststr(char *command, searchCtx *ctx, char *arg, char **p); + #endif