X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=notmuch-setup.c;h=c3ea9371c13cbc4058922fbdc920a5755e4084f0;hp=622bbaa68343c7633ade295d794e86e66c64d137;hb=ebe733632dbd048dae7cabb3b40e9f4d8326a8c9;hpb=e72a6176e3fc3fcf4b1696e3f0ee9cf66509fb4d diff --git a/notmuch-setup.c b/notmuch-setup.c index 622bbaa6..c3ea9371 100644 --- a/notmuch-setup.c +++ b/notmuch-setup.c @@ -92,13 +92,15 @@ notmuch_setup_command (unused (void *ctx), unused (int argc), unused (char *argv[])) { char *response = NULL; - size_t response_size; + size_t response_size = 0; notmuch_config_t *config; - char **old_other_emails; + const char **old_other_emails; size_t old_other_emails_len; GPtrArray *other_emails; unsigned int i; int is_new; + const char **new_tags; + size_t new_tags_len; #define prompt(format, ...) \ do { \ @@ -159,6 +161,40 @@ notmuch_setup_command (unused (void *ctx), notmuch_config_set_database_path (config, absolute_path); } + new_tags = notmuch_config_get_new_tags (config, &new_tags_len); + + printf ("Tags to apply to all new messages (separated by spaces) ["); + + for (i = 0; i < new_tags_len; i++) { + if (i != 0) + printf (" "); + printf ("%s", new_tags[i]); + } + + prompt ("]: "); + + if (strlen (response)) { + GPtrArray *tags = g_ptr_array_new (); + char *tag = response; + char *space; + + while (tag && *tag) { + space = strchr (tag, ' '); + if (space) + g_ptr_array_add (tags, talloc_strndup (ctx, tag, space - tag)); + else + g_ptr_array_add (tags, talloc_strdup (ctx, tag)); + tag = space; + while (tag && *tag == ' ') + tag++; + } + + notmuch_config_set_new_tags (config, (const char **) tags->pdata, + tags->len); + + g_ptr_array_free (tags, TRUE); + } + if (! notmuch_config_save (config)) { if (is_new) welcome_message_post_setup ();