2012-11-12 21:54:16 -04:00
|
|
|
#ifndef _TAG_UTIL_H
|
|
|
|
#define _TAG_UTIL_H
|
|
|
|
|
|
|
|
#include "notmuch-client.h"
|
|
|
|
|
|
|
|
typedef struct _tag_operation_t tag_operation_t;
|
|
|
|
typedef struct _tag_op_list_t tag_op_list_t;
|
|
|
|
|
|
|
|
/* Use powers of 2 */
|
|
|
|
typedef enum {
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_FLAG_NONE = 0,
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/* Operations are synced to maildir, if possible.
|
|
|
|
*/
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_FLAG_MAILDIR_SYNC = (1 << 0),
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/* Remove all tags from message before applying list.
|
|
|
|
*/
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_FLAG_REMOVE_ALL = (1 << 1),
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/* Don't try to avoid database operations. Useful when we
|
|
|
|
* know that message passed needs these operations.
|
|
|
|
*/
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_FLAG_PRE_OPTIMIZED = (1 << 2),
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/* Accept strange tags that might be user error;
|
|
|
|
* intended for use by notmuch-restore.
|
|
|
|
*/
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_FLAG_BE_GENEROUS = (1 << 3)
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
} tag_op_flag_t;
|
|
|
|
|
|
|
|
/* These should obey the convention that fatal errors are negative,
|
|
|
|
* skipped lines are positive.
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_PARSE_OUT_OF_MEMORY = -1,
|
2012-11-12 21:54:16 -04:00
|
|
|
|
2018-01-02 10:32:38 -05:00
|
|
|
/* Line parsed successfully. */
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_PARSE_SUCCESS = 0,
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/* Line has a syntax error */
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_PARSE_INVALID = 1,
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/* Line was blank or a comment */
|
2019-06-13 07:31:01 -03:00
|
|
|
TAG_PARSE_SKIPPED = 2
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
} tag_parse_status_t;
|
|
|
|
|
|
|
|
/* Parse a string of the following format:
|
|
|
|
*
|
|
|
|
* +<tag>|-<tag> [...] [--] <search-terms>
|
|
|
|
*
|
|
|
|
* Each line is interpreted similarly to "notmuch tag" command line
|
|
|
|
* arguments. The delimiter is one or more spaces ' '. Any characters
|
|
|
|
* in <tag> and <search-terms> MAY be hex encoded with %NN where NN is
|
|
|
|
* the hexadecimal value of the character. Any ' ' and '%' characters
|
|
|
|
* in <tag> and <search-terms> MUST be hex encoded (using %20 and %25,
|
|
|
|
* respectively). Any characters that are not part of <tag> or
|
|
|
|
* <search-terms> MUST NOT be hex encoded.
|
|
|
|
*
|
|
|
|
* Leading and trailing space ' ' is ignored. Empty lines and lines
|
|
|
|
* beginning with '#' are ignored.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Output Parameters:
|
|
|
|
* ops contains a list of tag operations
|
|
|
|
* query_str the search terms.
|
|
|
|
*/
|
|
|
|
tag_parse_status_t
|
|
|
|
parse_tag_line (void *ctx, char *line,
|
|
|
|
tag_op_flag_t flags,
|
|
|
|
char **query_str, tag_op_list_t *ops);
|
|
|
|
|
2012-12-25 15:42:39 -04:00
|
|
|
|
|
|
|
|
|
|
|
/* Parse a command line of the following format:
|
|
|
|
*
|
|
|
|
* +<tag>|-<tag> [...] [--] <search-terms>
|
|
|
|
*
|
|
|
|
* Output Parameters:
|
|
|
|
* ops contains a list of tag operations
|
|
|
|
* query_str the search terms.
|
2013-06-23 14:23:55 +10:00
|
|
|
*
|
|
|
|
* The ops argument is not cleared.
|
2012-12-25 15:42:39 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
tag_parse_status_t
|
|
|
|
parse_tag_command_line (void *ctx, int argc, char **argv,
|
|
|
|
char **query_str, tag_op_list_t *ops);
|
|
|
|
|
2014-02-23 18:55:21 +02:00
|
|
|
/*
|
|
|
|
* Test tags for some forbidden cases.
|
|
|
|
*
|
|
|
|
* Relax the checks if 'remove' is true to allow removal of previously
|
|
|
|
* added forbidden tags.
|
|
|
|
*
|
|
|
|
* return: NULL if OK,
|
|
|
|
* explanatory message otherwise.
|
|
|
|
*/
|
|
|
|
const char *
|
2017-10-07 11:44:04 +03:00
|
|
|
illegal_tag (const char *tag, bool remove);
|
2014-02-23 18:55:21 +02:00
|
|
|
|
2012-11-12 21:54:16 -04:00
|
|
|
/*
|
|
|
|
* Create an empty list of tag operations
|
|
|
|
*
|
|
|
|
* ctx is passed to talloc
|
|
|
|
*/
|
|
|
|
|
|
|
|
tag_op_list_t *
|
|
|
|
tag_op_list_create (void *ctx);
|
|
|
|
|
|
|
|
/*
|
2017-10-07 11:44:04 +03:00
|
|
|
* Add a tag operation (delete iff remove == true) to a list.
|
2012-11-12 21:54:16 -04:00
|
|
|
* The list is expanded as necessary.
|
|
|
|
*/
|
|
|
|
|
|
|
|
int
|
2012-12-16 15:58:15 -04:00
|
|
|
tag_op_list_append (tag_op_list_t *list,
|
2012-11-12 21:54:16 -04:00
|
|
|
const char *tag,
|
2017-10-07 11:44:04 +03:00
|
|
|
bool remove);
|
2012-11-12 21:54:16 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Apply a list of tag operations, in order, to a given message.
|
|
|
|
*
|
|
|
|
* Flags can be bitwise ORed; see enum above for possibilies.
|
|
|
|
*/
|
|
|
|
|
|
|
|
notmuch_status_t
|
|
|
|
tag_op_list_apply (notmuch_message_t *message,
|
|
|
|
tag_op_list_t *tag_ops,
|
|
|
|
tag_op_flag_t flags);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return the number of operations in a list
|
|
|
|
*/
|
|
|
|
|
|
|
|
size_t
|
|
|
|
tag_op_list_size (const tag_op_list_t *list);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Reset a list to contain no operations
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
tag_op_list_reset (tag_op_list_t *list);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* return the i'th tag in the list
|
|
|
|
*/
|
|
|
|
|
|
|
|
const char *
|
|
|
|
tag_op_list_tag (const tag_op_list_t *list, size_t i);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Is the i'th tag operation a remove?
|
|
|
|
*/
|
|
|
|
|
2017-10-07 11:44:04 +03:00
|
|
|
bool
|
2012-11-12 21:54:16 -04:00
|
|
|
tag_op_list_isremove (const tag_op_list_t *list, size_t i);
|
|
|
|
|
|
|
|
#endif
|