#ifndef IMAP_MATCH_H
#define IMAP_MATCH_H
enum imap_match_result {
IMAP_MATCH_NO = 0x00, /* definite non-match */
IMAP_MATCH_YES = 0x01, /* match */
/* YES and NO are returned alone, but CHILDREN and PARENT may be
returned both (eg. "foo*bar" vs. "foobar/baz") */
/* non-match, but its children could match (eg. "box" vs "box/%") */
IMAP_MATCH_CHILDREN = 0x02,
/* non-match, but one of its parents does match. This should often be
handled with YES matches, because when listing for "%" and "box/foo"
exists but "box" doesn't, you should still list "box" as
(Nonexistent HasChildren) mailbox. */
IMAP_MATCH_PARENT = 0x04
};
struct imap_match_glob;
/* If inboxcase is TRUE, the "INBOX" string at the beginning of line is
compared case-insensitively */
struct imap_match_glob *
imap_match_init(pool_t pool, const char *pattern,
bool inboxcase, char separator);
struct imap_match_glob *
imap_match_init_multiple(pool_t pool, const char *const *patterns,
bool inboxcase, char separator);
void imap_match_deinit(struct imap_match_glob **glob);
struct imap_match_glob *
imap_match_dup(pool_t pool, const struct imap_match_glob *glob);
/* Returns TRUE if two globs were created with same init() parameters
(but inboxcase is ignored if no patterns can match INBOX) */
bool imap_match_globs_equal(const struct imap_match_glob *glob1,
const struct imap_match_glob *glob2);
enum imap_match_result
imap_match(struct imap_match_glob *glob, const char *data);
#endif