cli: add --exclude=all option to notmuch-search.c

Add a --exclude=all option to notmuch search.
This commit is contained in:
Mark Walters 2013-05-11 20:50:03 +01:00 committed by David Bremner
parent 38698d8659
commit e691783b3b

View file

@ -287,6 +287,7 @@ enum {
EXCLUDE_TRUE, EXCLUDE_TRUE,
EXCLUDE_FALSE, EXCLUDE_FALSE,
EXCLUDE_FLAG, EXCLUDE_FLAG,
EXCLUDE_ALL
}; };
int int
@ -334,6 +335,7 @@ notmuch_search_command (notmuch_config_t *config, int argc, char *argv[])
(notmuch_keyword_t []){ { "true", EXCLUDE_TRUE }, (notmuch_keyword_t []){ { "true", EXCLUDE_TRUE },
{ "false", EXCLUDE_FALSE }, { "false", EXCLUDE_FALSE },
{ "flag", EXCLUDE_FLAG }, { "flag", EXCLUDE_FLAG },
{ "all", EXCLUDE_ALL },
{ 0, 0 } } }, { 0, 0 } } },
{ NOTMUCH_OPT_INT, &offset, "offset", 'O', 0 }, { NOTMUCH_OPT_INT, &offset, "offset", 'O', 0 },
{ NOTMUCH_OPT_INT, &limit, "limit", 'L', 0 }, { NOTMUCH_OPT_INT, &limit, "limit", 'L', 0 },
@ -400,7 +402,7 @@ notmuch_search_command (notmuch_config_t *config, int argc, char *argv[])
exclude = EXCLUDE_FALSE; exclude = EXCLUDE_FALSE;
} }
if (exclude == EXCLUDE_TRUE || exclude == EXCLUDE_FLAG) { if (exclude != EXCLUDE_FALSE) {
const char **search_exclude_tags; const char **search_exclude_tags;
size_t search_exclude_tags_length; size_t search_exclude_tags_length;
@ -409,7 +411,9 @@ notmuch_search_command (notmuch_config_t *config, int argc, char *argv[])
for (i = 0; i < search_exclude_tags_length; i++) for (i = 0; i < search_exclude_tags_length; i++)
notmuch_query_add_tag_exclude (query, search_exclude_tags[i]); notmuch_query_add_tag_exclude (query, search_exclude_tags[i]);
if (exclude == EXCLUDE_FLAG) if (exclude == EXCLUDE_FLAG)
notmuch_query_set_omit_excluded (query, FALSE); notmuch_query_set_omit_excluded (query, NOTMUCH_EXCLUDE_FALSE);
if (exclude == EXCLUDE_ALL)
notmuch_query_set_omit_excluded (query, NOTMUCH_EXCLUDE_ALL);
} }
switch (output) { switch (output) {