X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;f=lib%2Fconfig.cc;h=483a02efac8c3287df6fae66f83211e92da7bb9a;hb=6251e2bb9ee023d25b58384c8a49576086fdaba3;hp=b2957f0c97c9a4fd0f9ca67d19b37ea204a40ffa;hpb=d071828bd5f8aee0437aeb4993ffeeaa803c367b;p=notmuch diff --git a/lib/config.cc b/lib/config.cc index b2957f0c..483a02ef 100644 --- a/lib/config.cc +++ b/lib/config.cc @@ -38,7 +38,7 @@ struct _notmuch_config_values { void *children; /* talloc_context */ }; -static const char * _notmuch_config_key_to_string (notmuch_config_key_t key); +static const char *_notmuch_config_key_to_string (notmuch_config_key_t key); static int _notmuch_config_list_destroy (notmuch_config_list_t *list) @@ -104,7 +104,7 @@ notmuch_database_get_config (notmuch_database_t *notmuch, const char *key, char **value) { - const char* stored_val; + const char *stored_val; notmuch_status_t status; if (! notmuch->config) { @@ -119,7 +119,7 @@ notmuch_database_get_config (notmuch_database_t *notmuch, if (! stored_val) { /* XXX in principle this API should be fixed so empty string * is distinguished from not found */ - *value = strdup(""); + *value = strdup (""); } else { *value = strdup (stored_val); } @@ -152,7 +152,8 @@ notmuch_database_get_config_list (notmuch_database_t *notmuch, talloc_set_destructor (list, _notmuch_config_list_destroy); } catch (const Xapian::Error &error) { - _notmuch_database_log (notmuch, "A Xapian exception occurred getting metadata iterator: %s.\n", + _notmuch_database_log (notmuch, + "A Xapian exception occurred getting metadata iterator: %s.\n", error.get_msg ().c_str ()); notmuch->exception_reported = true; status = NOTMUCH_STATUS_XAPIAN_EXCEPTION; @@ -167,7 +168,7 @@ notmuch_database_get_config_list (notmuch_database_t *notmuch, if (status != NOTMUCH_STATUS_XAPIAN_EXCEPTION) _notmuch_config_list_destroy (list); } - } else { + } else { talloc_set_destructor (list, _notmuch_config_list_destroy); } @@ -183,7 +184,9 @@ notmuch_config_list_valid (notmuch_config_list_t *metadata) return true; } -static inline char * _key_from_iterator (notmuch_config_list_t *list) { +static inline char * +_key_from_iterator (notmuch_config_list_t *list) +{ return talloc_strdup (list, (*list->iterator).c_str () + CONFIG_PREFIX.length ()); } @@ -239,7 +242,7 @@ _notmuch_config_load_from_database (notmuch_database_t *notmuch) if (notmuch->config == NULL) notmuch->config = _notmuch_string_map_create (notmuch); - if (unlikely(notmuch->config == NULL)) + if (unlikely (notmuch->config == NULL)) return NOTMUCH_STATUS_OUT_OF_MEMORY; status = notmuch_database_get_config_list (notmuch, "", &list); @@ -267,7 +270,7 @@ notmuch_config_get_values (notmuch_database_t *notmuch, notmuch_config_key_t key goto DONE; values = talloc (notmuch, notmuch_config_values_t); - if (unlikely(! values)) + if (unlikely (! values)) goto DONE; values->children = talloc_new (values); @@ -279,17 +282,18 @@ notmuch_config_get_values (notmuch_database_t *notmuch, notmuch_config_key_t key values->iterator = strsplit_len (values->string, ';', &(values->tok_len)); ok = true; - DONE: - if (!ok) { + DONE: + if (! ok) { if (values) - talloc_free(values); + talloc_free (values); return NULL; } return values; } notmuch_bool_t -notmuch_config_values_valid (notmuch_config_values_t *values) { +notmuch_config_values_valid (notmuch_config_values_t *values) +{ if (! values) return false; @@ -297,12 +301,14 @@ notmuch_config_values_valid (notmuch_config_values_t *values) { } const char * -notmuch_config_values_get (notmuch_config_values_t *values) { +notmuch_config_values_get (notmuch_config_values_t *values) +{ return talloc_strndup (values, values->iterator, values->tok_len); } void -notmuch_config_values_start (notmuch_config_values_t *values) { +notmuch_config_values_start (notmuch_config_values_t *values) +{ if (values == NULL) return; if (values->children) { @@ -315,13 +321,15 @@ notmuch_config_values_start (notmuch_config_values_t *values) { } void -notmuch_config_values_move_to_next (notmuch_config_values_t *values) { +notmuch_config_values_move_to_next (notmuch_config_values_t *values) +{ values->iterator += values->tok_len; values->iterator = strsplit_len (values->iterator, ';', &(values->tok_len)); } void -notmuch_config_values_destroy (notmuch_config_values_t *values) { +notmuch_config_values_destroy (notmuch_config_values_t *values) +{ talloc_free (values); } @@ -330,44 +338,82 @@ _notmuch_config_load_from_file (notmuch_database_t *notmuch, GKeyFile *file) { notmuch_status_t status = NOTMUCH_STATUS_SUCCESS; - gchar **groups, **keys, *val; + gchar **groups = NULL, **keys, *val; if (notmuch->config == NULL) notmuch->config = _notmuch_string_map_create (notmuch); - if (unlikely(notmuch->config == NULL)) { + if (unlikely (notmuch->config == NULL)) { status = NOTMUCH_STATUS_OUT_OF_MEMORY; goto DONE; } - for (groups = g_key_file_get_groups (file, NULL); *groups; groups++) { - for (keys = g_key_file_get_keys (file, *groups, NULL, NULL); *keys; keys++) { - char *absolute_key = talloc_asprintf(notmuch, "%s.%s", *groups, *keys); - val = g_key_file_get_value (file, *groups, *keys, NULL); + groups = g_key_file_get_groups (file, NULL); + for (gchar **grp = groups; *grp; grp++) { + keys = g_key_file_get_keys (file, *grp, NULL, NULL); + for (gchar **keys_p = keys; *keys_p; keys_p++) { + char *absolute_key = talloc_asprintf (notmuch, "%s.%s", *grp, *keys_p); + val = g_key_file_get_value (file, *grp, *keys_p, NULL); if (! val) { status = NOTMUCH_STATUS_FILE_ERROR; goto DONE; } _notmuch_string_map_set (notmuch->config, absolute_key, val); + g_free (val); talloc_free (absolute_key); if (status) goto DONE; } + g_strfreev (keys); } - DONE: + DONE: + if (groups) + g_strfreev (groups); + return status; } +notmuch_status_t +notmuch_config_get_bool (notmuch_database_t *notmuch, notmuch_config_key_t key, notmuch_bool_t *val) +{ + const char *key_string, *val_string; + + key_string = _notmuch_config_key_to_string (key); + if (! key_string) { + return NOTMUCH_STATUS_ILLEGAL_ARGUMENT; + } + + val_string = _notmuch_string_map_get (notmuch->config, key_string); + if (! val_string) { + *val = FALSE; + return NOTMUCH_STATUS_SUCCESS; + } + + if (strcase_equal (val_string, "false") || strcase_equal (val_string, "no")) + *val = FALSE; + else if (strcase_equal (val_string, "true") || strcase_equal (val_string, "yes")) + *val = TRUE; + else + return NOTMUCH_STATUS_ILLEGAL_ARGUMENT; + + return NOTMUCH_STATUS_SUCCESS; +} + static const char * -_notmuch_config_key_to_string (notmuch_config_key_t key) { +_notmuch_config_key_to_string (notmuch_config_key_t key) +{ switch (key) { case NOTMUCH_CONFIG_DATABASE_PATH: return "database.path"; + case NOTMUCH_CONFIG_HOOK_DIR: + return "database.hook_dir"; case NOTMUCH_CONFIG_EXCLUDE_TAGS: return "search.exclude_tags"; case NOTMUCH_CONFIG_NEW_TAGS: return "new.tags"; + case NOTMUCH_CONFIG_NEW_IGNORE: + return "new.ignore"; case NOTMUCH_CONFIG_SYNC_MAILDIR_FLAGS: return "maildir.synchronize_flags"; case NOTMUCH_CONFIG_PRIMARY_EMAIL: @@ -382,7 +428,8 @@ _notmuch_config_key_to_string (notmuch_config_key_t key) { } static const char * -_notmuch_config_default (void *ctx, notmuch_config_key_t key) { +_notmuch_config_default (void *ctx, notmuch_config_key_t key) +{ char *path; switch (key) { @@ -400,6 +447,8 @@ _notmuch_config_default (void *ctx, notmuch_config_key_t key) { return "inbox;unread"; case NOTMUCH_CONFIG_SYNC_MAILDIR_FLAGS: return "true"; + case NOTMUCH_CONFIG_HOOK_DIR: + case NOTMUCH_CONFIG_NEW_IGNORE: case NOTMUCH_CONFIG_USER_NAME: case NOTMUCH_CONFIG_PRIMARY_EMAIL: case NOTMUCH_CONFIG_OTHER_EMAIL: @@ -407,34 +456,48 @@ _notmuch_config_default (void *ctx, notmuch_config_key_t key) { default: case NOTMUCH_CONFIG_LAST: INTERNAL_ERROR ("illegal key enum %d", key); - } + } } notmuch_status_t -_notmuch_config_load_defaults (notmuch_database_t *notmuch) { +_notmuch_config_load_defaults (notmuch_database_t *notmuch) +{ notmuch_config_key_t key; + for (key = NOTMUCH_CONFIG_FIRST; key < NOTMUCH_CONFIG_LAST; - key = notmuch_config_key_t(key + 1)) { + key = notmuch_config_key_t (key + 1)) { const char *val = notmuch_config_get (notmuch, key); const char *key_string = _notmuch_config_key_to_string (key); val = _notmuch_string_map_get (notmuch->config, key_string); if (! val) { - _notmuch_string_map_set (notmuch->config, key_string, _notmuch_config_default (notmuch, key)); + _notmuch_string_map_set (notmuch->config, key_string, _notmuch_config_default (notmuch, + key)); } } return NOTMUCH_STATUS_SUCCESS; } const char * -notmuch_config_get (notmuch_database_t *notmuch, notmuch_config_key_t key) { +notmuch_config_get (notmuch_database_t *notmuch, notmuch_config_key_t key) +{ return _notmuch_string_map_get (notmuch->config, _notmuch_config_key_to_string (key)); } notmuch_status_t -notmuch_config_set (notmuch_database_t *notmuch, notmuch_config_key_t key, const char *val) { +notmuch_config_set (notmuch_database_t *notmuch, notmuch_config_key_t key, const char *val) +{ return notmuch_database_set_config (notmuch, _notmuch_config_key_to_string (key), val); } + +void +_notmuch_config_cache (notmuch_database_t *notmuch, notmuch_config_key_t key, const char *val) +{ + if (notmuch->config == NULL) + notmuch->config = _notmuch_string_map_create (notmuch); + + _notmuch_string_map_set (notmuch->config, _notmuch_config_key_to_string (key), val); +}