char *literal;
} exprunion;
-typedef struct searchASTCache {
- searchASTExpr *tree;
- searchASTExpr *cache[AST_RECENT];
- int nextpos;
-} searchASTCache;
-
/* comares either a string and a string or an expression and an expression */
static searchASTExpr *compareloc(searchASTExpr *expr, exprunion *loc) {
if(expr->type == AST_NODE_LITERAL) {
memset(&cache, 0, sizeof(cache));
cache.tree = tree;
- newsearch_ctxinit(&ctx, search_astparse, reply, wall, &cache, reg_nicksearch, sender);
+ newsearch_ctxinit(&ctx, search_astparse, reply, wall, &cache, reg_nicksearch, sender, display, limit);
buf[0] = '\0';
reply(sender, "Parsing: %s", ast_printtree(buf, sizeof(buf), tree, reg_nicksearch));
reply(sender, "Executing...");
if(header)
header(sender, headerarg);
- nicksearch_exe(search, &ctx, sender, display, limit);
+ nicksearch_exe(search, &ctx);
(search->free)(&ctx, search);
searchNode *search;
char buf[1024];
- newsearch_ctxinit(&ctx, search_astparse, reply, wall, &cache, reg_chansearch, sender);
+ newsearch_ctxinit(&ctx, search_astparse, reply, wall, &cache, reg_chansearch, sender, display, limit);
memset(&cache, 0, sizeof(cache));
cache.tree = tree;
reply(sender, "Executing...");
if(header)
header(sender, headerarg);
- chansearch_exe(search, &ctx, sender, display, limit);
+ chansearch_exe(search, &ctx);
(search->free)(&ctx, search);
memset(&cache, 0, sizeof(cache));
cache.tree = tree;
- newsearch_ctxinit(&ctx, search_astparse, reply, wall, &cache, reg_usersearch, sender);
+ newsearch_ctxinit(&ctx, search_astparse, reply, wall, &cache, reg_usersearch, sender, display, limit);
buf[0] = '\0';
reply(sender, "Parsing: %s", ast_printtree(buf, sizeof(buf), tree, reg_usersearch));
reply(sender, "Executing...");
if(header)
header(sender, headerarg);
- usersearch_exe(search, &ctx, sender, display, limit);
+ usersearch_exe(search, &ctx);
(search->free)(&ctx, search);
sbaddchar(buf, ')');
} else if(expr->type == AST_NODE_LITERAL) {
- int quotesrequired, escrequired;
char *p;
- for(quotesrequired=escrequired=0,p=expr->u.literal;*p;p++) {
- if(*p == '(' || *p == ')' || *p == ' ')
- quotesrequired = 1;
- if(*p == '\\' || *p == '"') {
- escrequired = 1;
- if(quotesrequired)
- break;
- }
- }
- if(quotesrequired)
- sbaddchar(buf, '"');
-
- if(escrequired) {
- for(p=expr->u.literal;*p;p++) {
- if(*p == '\\' || *p == '"')
- sbaddchar(buf, '\\');
- sbaddchar(buf, *p);
- }
- } else {
- sbaddstr(buf, expr->u.literal);
+
+ sbaddchar(buf, '"');
+
+ for(p=expr->u.literal;*p;p++) {
+ if(*p == '\\' || *p == '"')
+ sbaddchar(buf, '\\');
+ sbaddchar(buf, *p);
}
- if(quotesrequired)
- sbaddchar(buf, '"');
+ sbaddchar(buf, '"');
} else {
sbaddstr(buf, "???");
}