Blame SOURCES/dconf-override.patch
|
 |
42593f |
diff --git a/engine/dconf-engine-source-user.c b/engine/dconf-engine-source-user.c
|
|
 |
42593f |
index 1657875..e4f8786 100644
|
|
 |
42593f |
--- a/engine/dconf-engine-source-user.c
|
|
 |
42593f |
+++ b/engine/dconf-engine-source-user.c
|
|
 |
42593f |
@@ -39,11 +39,17 @@ dconf_engine_source_user_open_gvdb (const gchar *name)
|
|
 |
42593f |
{
|
|
 |
42593f |
GvdbTable *table;
|
|
 |
42593f |
gchar *filename;
|
|
 |
42593f |
+ const gchar *override;
|
|
 |
42593f |
+
|
|
 |
42593f |
+ override = g_getenv ("DCONF_USER_CONFIG_DIR");
|
|
 |
42593f |
+ if (override == NULL)
|
|
 |
42593f |
+ filename = g_build_filename (g_get_user_config_dir (), "dconf", name, NULL);
|
|
 |
42593f |
+ else
|
|
 |
42593f |
+ filename = g_build_filename (g_get_home_dir (), override, name, NULL);
|
|
 |
42593f |
|
|
 |
42593f |
/* This can fail in the normal case of the user not having any
|
|
 |
42593f |
* settings. That's OK and it shouldn't be considered as an error.
|
|
 |
42593f |
*/
|
|
 |
42593f |
- filename = g_build_filename (g_get_user_config_dir (), "dconf", name, NULL);
|
|
 |
42593f |
table = gvdb_table_new (filename, FALSE, NULL);
|
|
 |
42593f |
g_free (filename);
|
|
 |
42593f |
|