view src/lib-storage/mail-search-parser.h @ 19604:c996bc091c6b

master: Do not close stdout if going foreground This lets one to use /dev/stdout for logging. Mainly useful for testing purposes where we can generate log output to stdout and use tee to write it to a file for later examination.
author Aki Tuomi <aki.tuomi@dovecot.fi>
date Mon, 18 Jan 2016 15:50:23 +0200
parents 4a98f01eaaac
children
line wrap: on
line source

#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