mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-24 20:08:10 +01:00
CLI/config: switch "notmuch config list" to merged config
Use the database opened at the top level rather than opening another notmuch_database_t. Test output changes because keys are now listed in alphabetical order, and because a missing database is no longer an error.
This commit is contained in:
parent
34f734e26b
commit
3787fe6c84
2 changed files with 24 additions and 74 deletions
|
@ -972,67 +972,20 @@ _notmuch_config_list_built_with ()
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
_list_db_config (notmuch_config_t *config)
|
notmuch_config_command_list (notmuch_database_t *notmuch)
|
||||||
{
|
{
|
||||||
notmuch_database_t *notmuch;
|
notmuch_config_pairs_t *list;
|
||||||
notmuch_config_list_t *list;
|
|
||||||
|
|
||||||
if (notmuch_database_open (notmuch_config_get_database_path (config),
|
|
||||||
NOTMUCH_DATABASE_MODE_READ_ONLY, ¬much))
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
|
|
||||||
/* XXX Handle UUID mismatch? */
|
|
||||||
|
|
||||||
|
|
||||||
if (print_status_database ("notmuch config", notmuch,
|
|
||||||
notmuch_database_get_config_list (notmuch, "", &list)))
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
|
|
||||||
for (; notmuch_config_list_valid (list); notmuch_config_list_move_to_next (list)) {
|
|
||||||
printf ("%s=%s\n", notmuch_config_list_key (list), notmuch_config_list_value (list));
|
|
||||||
}
|
|
||||||
notmuch_config_list_destroy (list);
|
|
||||||
|
|
||||||
return EXIT_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
notmuch_config_command_list (notmuch_config_t *config)
|
|
||||||
{
|
|
||||||
char **groups;
|
|
||||||
size_t g, groups_length;
|
|
||||||
|
|
||||||
groups = g_key_file_get_groups (config->key_file, &groups_length);
|
|
||||||
if (groups == NULL)
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
for (g = 0; g < groups_length; g++) {
|
|
||||||
char **keys;
|
|
||||||
size_t k, keys_length;
|
|
||||||
|
|
||||||
keys = g_key_file_get_keys (config->key_file,
|
|
||||||
groups[g], &keys_length, NULL);
|
|
||||||
if (keys == NULL)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
for (k = 0; k < keys_length; k++) {
|
|
||||||
char *value;
|
|
||||||
|
|
||||||
value = g_key_file_get_string (config->key_file,
|
|
||||||
groups[g], keys[k], NULL);
|
|
||||||
if (value != NULL) {
|
|
||||||
printf ("%s.%s=%s\n", groups[g], keys[k], value);
|
|
||||||
free (value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
g_strfreev (keys);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_strfreev (groups);
|
|
||||||
|
|
||||||
_notmuch_config_list_built_with ();
|
_notmuch_config_list_built_with ();
|
||||||
return _list_db_config (config);
|
for (list = notmuch_config_get_pairs (notmuch, "");
|
||||||
|
notmuch_config_pairs_valid (list);
|
||||||
|
notmuch_config_pairs_move_to_next (list)) {
|
||||||
|
const char *value = notmuch_config_pairs_value (list);
|
||||||
|
if (value)
|
||||||
|
printf ("%s=%s\n", notmuch_config_pairs_key (list), value);
|
||||||
|
}
|
||||||
|
notmuch_config_pairs_destroy (list);
|
||||||
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -1074,7 +1027,7 @@ notmuch_config_command (notmuch_config_t *config, notmuch_database_t *notmuch,
|
||||||
}
|
}
|
||||||
ret = notmuch_config_command_set (config, argv[1], argc - 2, argv + 2);
|
ret = notmuch_config_command_set (config, argv[1], argc - 2, argv + 2);
|
||||||
} else if (strcmp (argv[0], "list") == 0) {
|
} else if (strcmp (argv[0], "list") == 0) {
|
||||||
ret = notmuch_config_command_list (config);
|
ret = notmuch_config_command_list (notmuch);
|
||||||
} else {
|
} else {
|
||||||
fprintf (stderr, "Unrecognized argument for notmuch config: %s\n",
|
fprintf (stderr, "Unrecognized argument for notmuch config: %s\n",
|
||||||
argv[0]);
|
argv[0]);
|
||||||
|
|
|
@ -46,25 +46,22 @@ notmuch config set foo.nonexistent
|
||||||
test_expect_equal "$(notmuch config get foo.nonexistent)" ""
|
test_expect_equal "$(notmuch config get foo.nonexistent)" ""
|
||||||
|
|
||||||
test_begin_subtest "List all items"
|
test_begin_subtest "List all items"
|
||||||
notmuch config list > STDOUT 2> STDERR
|
notmuch config list 2>&1 | notmuch_config_sanitize > OUTPUT
|
||||||
printf "%s\n====\n%s\n" "$(< STDOUT)" "$(< STDERR)" | notmuch_config_sanitize > OUTPUT
|
|
||||||
|
|
||||||
cat <<EOF > EXPECTED
|
cat <<EOF > EXPECTED
|
||||||
database.path=MAIL_DIR
|
|
||||||
user.name=Notmuch Test Suite
|
|
||||||
user.primary_email=test_suite@notmuchmail.org
|
|
||||||
user.other_email=test_suite_other@notmuchmail.org;test_suite@otherdomain.org
|
|
||||||
new.tags=unread;inbox;
|
|
||||||
new.ignore=
|
|
||||||
search.exclude_tags=
|
|
||||||
maildir.synchronize_flags=true
|
|
||||||
foo.string=this is another string value
|
|
||||||
foo.list=this;is another;list value;
|
|
||||||
built_with.compact=something
|
built_with.compact=something
|
||||||
built_with.field_processor=something
|
built_with.field_processor=something
|
||||||
built_with.retry_lock=something
|
built_with.retry_lock=something
|
||||||
====
|
database.mail_root=MAIL_DIR
|
||||||
Error: Cannot open database at MAIL_DIR/.notmuch: No such file or directory.
|
database.path=MAIL_DIR
|
||||||
|
foo.list=this;is another;list value;
|
||||||
|
foo.string=this is another string value
|
||||||
|
maildir.synchronize_flags=true
|
||||||
|
new.ignore=
|
||||||
|
new.tags=unread;inbox;
|
||||||
|
search.exclude_tags=
|
||||||
|
user.name=Notmuch Test Suite
|
||||||
|
user.other_email=test_suite_other@notmuchmail.org;test_suite@otherdomain.org
|
||||||
|
user.primary_email=test_suite@notmuchmail.org
|
||||||
EOF
|
EOF
|
||||||
test_expect_equal_file EXPECTED OUTPUT
|
test_expect_equal_file EXPECTED OUTPUT
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue