CLI: load merged config at top level

This paves the way for the conversion of the remaining subcommands to
the new configuration framework.
This commit is contained in:
David Bremner 2021-02-09 20:26:40 -04:00
parent b25e57e6cb
commit d9bc5c8528
2 changed files with 27 additions and 3 deletions

View 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 *

View file

@ -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;