cli: config: keep track of whether the config is newly created
authorJani Nikula <jani@nikula.org>
Sun, 3 Mar 2013 21:55:07 +0000 (23:55 +0200)
committerDavid Bremner <bremner@debian.org>
Thu, 7 Mar 2013 13:39:05 +0000 (09:39 -0400)
Keep track of whether the config is newly created, and add
notmuch_config_is_new() accessor function to query this.

This is to support anyone with a config handle to check this, instead
of just whoever called notmuch_config_open().

notmuch-client.h
notmuch-config.c

index 5f2883681c1ee127332108ba7872146a04eb3e6f..07367e014ccacda58d9cf88ae69ac611d7dc8973 100644 (file)
@@ -256,6 +256,9 @@ notmuch_config_close (notmuch_config_t *config);
 int
 notmuch_config_save (notmuch_config_t *config);
 
 int
 notmuch_config_save (notmuch_config_t *config);
 
+notmuch_bool_t
+notmuch_config_is_new (notmuch_config_t *config);
+
 const char *
 notmuch_config_get_database_path (notmuch_config_t *config);
 
 const char *
 notmuch_config_get_database_path (notmuch_config_t *config);
 
index b5c2066e345678fa36f189116c2d6b243eccf60e..e733e92976ade780c9694d2dc088a84f5b464976 100644 (file)
@@ -104,6 +104,7 @@ static const char search_config_comment[] =
 struct _notmuch_config {
     char *filename;
     GKeyFile *key_file;
 struct _notmuch_config {
     char *filename;
     GKeyFile *key_file;
+    notmuch_bool_t is_new;
 
     char *database_path;
     char *user_name;
 
     char *database_path;
     char *user_name;
@@ -266,6 +267,7 @@ notmuch_config_open (void *ctx,
 
     config->key_file = g_key_file_new ();
 
 
     config->key_file = g_key_file_new ();
 
+    config->is_new = FALSE;
     config->database_path = NULL;
     config->user_name = NULL;
     config->user_primary_email = NULL;
     config->database_path = NULL;
     config->user_name = NULL;
     config->user_primary_email = NULL;
@@ -435,6 +437,8 @@ notmuch_config_open (void *ctx,
     if (is_new_ret)
        *is_new_ret = is_new;
 
     if (is_new_ret)
        *is_new_ret = is_new;
 
+    config->is_new = is_new;
+
     return config;
 }
 
     return config;
 }
 
@@ -482,6 +486,13 @@ notmuch_config_save (notmuch_config_t *config)
     return 0;
 }
 
     return 0;
 }
 
+notmuch_bool_t
+notmuch_config_is_new (notmuch_config_t *config)
+{
+    return config->is_new;
+}
+
+
 static const char **
 _config_get_list (notmuch_config_t *config,
                  const char *section, const char *key,
 static const char **
 _config_get_list (notmuch_config_t *config,
                  const char *section, const char *key,