]> git.notmuchmail.org Git - notmuch/commitdiff
CLI: load merged config at top level
authorDavid Bremner <david@tethera.net>
Wed, 10 Feb 2021 00:26:40 +0000 (20:26 -0400)
committerDavid Bremner <david@tethera.net>
Sat, 27 Mar 2021 12:26:14 +0000 (09:26 -0300)
This paves the way for the conversion of the remaining subcommands to
the new configuration framework.

notmuch-client.h
notmuch.c

index 704586294c17fe8ed4cf3fb0151f62599b7e342b..b560e3ed65a085f3a18a88a01362fdbf341f7f4a 100644 (file)
@@ -272,6 +272,7 @@ typedef enum {
     NOTMUCH_COMMAND_DATABASE_EARLY     = 1 << 2,
     NOTMUCH_COMMAND_DATABASE_WRITE     = 1 << 3,
     NOTMUCH_COMMAND_DATABASE_CREATE    = 1 << 4,
+    NOTMUCH_COMMAND_CONFIG_LOAD                = 1 << 5,
 } notmuch_command_mode_t;
 
 notmuch_config_t *
index f2bf9c24a11fe03a5e6b02f62fa650f628d7d8b7..742544c291472a3e3c59a615c290d73b913c31e2 100644 (file)
--- a/notmuch.c
+++ b/notmuch.c
@@ -175,7 +175,7 @@ static command_t commands[] = {
     { "reindex", notmuch_reindex_command, NOTMUCH_COMMAND_DATABASE_EARLY |
       NOTMUCH_COMMAND_DATABASE_WRITE,
       "Re-index all messages matching the search terms." },
-    { "config", notmuch_config_command, NOTMUCH_COMMAND_CONFIG_OPEN,
+    { "config", notmuch_config_command, NOTMUCH_COMMAND_CONFIG_OPEN | NOTMUCH_COMMAND_CONFIG_LOAD,
       "Get or set settings in the notmuch configuration file." },
 #if WITH_EMACS
     { "emacs-mua", NULL, 0,
@@ -471,7 +471,7 @@ main (int argc, char *argv[])
     notmuch_config_t *config = NULL;
     notmuch_database_t *notmuch = NULL;
     int opt_index;
-    int ret;
+    int ret = EXIT_SUCCESS;
 
     notmuch_opt_desc_t options[] = {
        { .opt_string = &config_file_name, .name = "config" },
@@ -559,7 +559,30 @@ main (int argc, char *argv[])
                return EXIT_FAILURE;
            }
        }
-    } else {
+    }
+
+    if (command->mode & NOTMUCH_COMMAND_CONFIG_LOAD) {
+       char *status_string = NULL;
+       notmuch_status_t status;
+       status = notmuch_database_load_config (NULL,
+                                              config_file_name,
+                                              NULL,
+                                              &notmuch,
+                                              &status_string);
+       if (status) {
+           if (status_string) {
+               fputs (status_string, stderr);
+               free (status_string);
+           }
+
+           if (status == NOTMUCH_STATUS_NO_CONFIG)
+               fputs ("Try running 'notmuch setup' to create a configuration.", stderr);
+           goto DONE;
+       }
+
+    }
+
+    if (command->mode & NOTMUCH_COMMAND_CONFIG_OPEN) {
        config = notmuch_config_open (local, config_file_name, command->mode);
        if (! config) {
            ret = EXIT_FAILURE;