notmuch setup: Prompt for tags to set on new messages.
authorCarl Worth <cworth@cworth.org>
Fri, 23 Apr 2010 17:30:40 +0000 (10:30 -0700)
committerCarl Worth <cworth@cworth.org>
Fri, 23 Apr 2010 17:30:40 +0000 (10:30 -0700)
Our "notmuch setup" command is only really helpful if it guides the
user through all the possible options. So add this one.

notmuch-setup.c

index 622bbaa68343c7633ade295d794e86e66c64d137..955deb7e51330c633d1a1017de47e35742cc8d4c 100644 (file)
@@ -99,6 +99,8 @@ notmuch_setup_command (unused (void *ctx),
     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 ();