[tracker/gsettings-keyfile-bridge: 1/2] libtracker-common: Add a way to test things with old .cfg files



commit d9b6ef2407d259bced0e91baa018cd6cd84db634
Author: Carlos Garnacho <carlos lanedo com>
Date:   Mon Nov 21 15:30:26 2011 +0100

    libtracker-common: Add a way to test things with old .cfg files
    
    The TRACKER_USE_CONFIG_FILES envvar now triggers a mode where .cfg
    files are dumped into GSettings, but not deleted. The changes done
    to GSettings are also dumped to the .cfg file after any
    g_settings_apply() call with unapplied data.

 src/libtracker-common/tracker-config-file.c |  128 ++++++++++++++++++++++++---
 1 files changed, 117 insertions(+), 11 deletions(-)
---
diff --git a/src/libtracker-common/tracker-config-file.c b/src/libtracker-common/tracker-config-file.c
index 7982ef6..8a22f24 100644
--- a/src/libtracker-common/tracker-config-file.c
+++ b/src/libtracker-common/tracker-config-file.c
@@ -413,19 +413,13 @@ tracker_config_file_new (void)
 			     NULL);
 }
 
-gboolean
-tracker_config_file_migrate (TrackerConfigFile           *file,
-			     GSettings                   *settings,
-			     TrackerConfigMigrationEntry *entries)
+static gboolean
+migrate_keyfile_to_settings (TrackerConfigMigrationEntry *entries,
+                             TrackerConfigFile           *file,
+                             GSettings                   *settings)
 {
 	gint i;
 
-	g_return_val_if_fail (TRACKER_IS_CONFIG_FILE (file), FALSE);
-
-	if (!file->key_file || !file->file_exists) {
-		return TRUE;
-	}
-
 	g_message ("Migrating configuration to GSettings...");
 
 	for (i = 0; entries[i].type != G_TYPE_INVALID; i++) {
@@ -433,6 +427,7 @@ tracker_config_file_migrate (TrackerConfigFile           *file,
 		                         entries[i].file_section,
 		                         entries[i].file_key,
 		                         NULL)) {
+			g_settings_reset (settings, entries[i].settings_key);
 			continue;
 		}
 
@@ -487,9 +482,120 @@ tracker_config_file_migrate (TrackerConfigFile           *file,
 		}
 	}
 
-	g_file_delete (file->file, NULL, NULL);
 	g_message ("Finished migration to GSettings.");
 
 	return TRUE;
 }
 
+static void
+migrate_settings_to_keyfile (TrackerConfigMigrationEntry *entries,
+                             GSettings                   *settings,
+                             TrackerConfigFile           *file)
+{
+	gint i;
+
+	g_message ("Storing configuration to Keyfile...");
+
+	for (i = 0; entries[i].type != G_TYPE_INVALID; i++) {
+		switch (entries[i].type) {
+		case G_TYPE_INT:
+		case G_TYPE_ENUM: {
+			gint val;
+
+			if (entries[i].type == G_TYPE_INT) {
+				val = g_settings_get_int (settings, entries[i].settings_key);
+			} else {
+				val = g_settings_get_enum (settings, entries[i].settings_key);
+			}
+
+			g_key_file_set_integer (file->key_file,
+			                        entries[i].file_section,
+			                        entries[i].file_key,
+			                        val);
+			break;
+		}
+		case G_TYPE_BOOLEAN: {
+			gboolean val;
+
+			val = g_settings_get_boolean (settings, entries[i].settings_key);
+			g_key_file_set_boolean (file->key_file,
+			                        entries[i].file_section,
+			                        entries[i].file_key,
+			                        val);
+			break;
+		}
+		case G_TYPE_POINTER: {
+			gchar **vals;
+
+			vals = g_settings_get_strv (settings, entries[i].settings_key);
+
+			if (vals) {
+				g_key_file_set_string_list (file->key_file,
+				                            entries[i].file_section,
+				                            entries[i].file_key,
+				                            (const gchar * const *)vals,
+				                            g_strv_length (vals));
+				g_strfreev (vals);
+			}
+
+			break;
+		}
+		default:
+			g_assert_not_reached ();
+			break;
+		}
+	}
+}
+
+typedef struct {
+	TrackerConfigFile *file;
+	TrackerConfigMigrationEntry *entries;
+} UnappliedNotifyData;
+
+static void
+settings_has_unapplied_notify (GObject    *object,
+                               GParamSpec *pspec,
+                               gpointer    user_data)
+{
+	UnappliedNotifyData *data = user_data;
+
+	if (!g_settings_get_has_unapplied (G_SETTINGS (object))) {
+		/* Dump to config file too */
+		migrate_settings_to_keyfile (data->entries,
+		                             G_SETTINGS (object),
+		                             data->file);
+		tracker_config_file_save (data->file);
+	}
+}
+
+gboolean
+tracker_config_file_migrate (TrackerConfigFile           *file,
+                             GSettings                   *settings,
+                             TrackerConfigMigrationEntry *entries)
+{
+	g_return_val_if_fail (TRACKER_IS_CONFIG_FILE (file), FALSE);
+
+	if (file->key_file && file->file_exists) {
+		migrate_keyfile_to_settings (entries, file, settings);
+	}
+
+	if (g_getenv ("TRACKER_USE_CONFIG_FILES")) {
+		UnappliedNotifyData *data;
+
+		/* Keep the file around, and connect to notify::has-unapplied so
+		 * we write back to it when g_settings_apply() is called
+		 */
+		data = g_new (UnappliedNotifyData, 1);
+		data->file = g_object_ref (file);
+		data->entries = entries;
+
+		g_signal_connect (settings, "notify::has-unapplied",
+		                  G_CALLBACK (settings_has_unapplied_notify),
+		                  data);
+	} else {
+		/* The config file has been migrated to GSettings, delete it */
+		g_file_delete (file->file, NULL, NULL);
+	}
+
+	return TRUE;
+}



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]