summaryrefslogtreecommitdiffstats
path: root/src/lib-storage/mail-search-parser.h
blob: 0535587c4cc5b01d16ef972fbd0421cb14e9a8ac (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#ifndef MAIL_SEARCH_PARSER_H
#define MAIL_SEARCH_PARSER_H

#define MAIL_SEARCH_PARSER_KEY_LIST "("

struct imap_arg;

/* Build a parser parsing the given imap args. NOTE: args must not be freed
   until this parser is destroyed. */
struct mail_search_parser *
mail_search_parser_init_imap(const struct imap_arg *args);
/* Build a parser parsing the given command line args. */
struct mail_search_parser *
mail_search_parser_init_cmdline(const char *const args[]);

void mail_search_parser_deinit(struct mail_search_parser **parser);

/* Key is set to the next search key, or MAIL_SEARCH_PARSER_KEY_LIST for
   beginning of a list. Returns 1 if ok, 0 if no more keys in this
   list/query, -1 if parsing error. */
int mail_search_parse_key(struct mail_search_parser *parser,
			  const char **key_r);
/* Get the next string. Returns 0 if ok, -1 if parsing error. */
int mail_search_parse_string(struct mail_search_parser *parser,
			     const char **value_r);
/* If next parameter equals to the given string case-insensitively, skip over
   it and return TRUE. Otherwise do nothing and return FALSE. */
bool mail_search_parse_skip_next(struct mail_search_parser *parser,
				 const char *str);

/* Returns the reason string for parsing error. */
const char *mail_search_parser_get_error(struct mail_search_parser *parser);

#endif