[gconf/port-to-dbus: 23/23] gconf-client: Use the cache for keys we know we don't have locally
- From: Ross Burton <rburton src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gconf/port-to-dbus: 23/23] gconf-client: Use the cache for keys we know we don't have locally
- Date: Tue, 28 Jun 2011 14:29:29 +0000 (UTC)
commit 8a4e5e35e947ad62fff2d88bd43330746b69f007
Author: Zhenqiang Chen <zhenqiang chen intel com>
Date: Thu Aug 27 22:52:11 2009 -0400
gconf-client: Use the cache for keys we know we don't have locally
Say the application recursively preloads /foo which contains /foo/a/a and
/foo/b/b, which are fetched and cached. The application then asks for /foo/c/c.
Because we recursively preloaded we should know that this key doesn't exist, but
because it isn't stored in the caches we have to make a DBus call.
This change lets the caching layer know that we recursively loaded /foo and
therefore if the key isn't in the cache, it doesn't exist.
gconf/gconf-client.c | 48 +++++++++++++++++++++++++++++++++++++-----------
gconf/gconf-client.h | 2 +-
2 files changed, 38 insertions(+), 12 deletions(-)
---
diff --git a/gconf/gconf-client.c b/gconf/gconf-client.c
index 796c548..16be032 100644
--- a/gconf/gconf-client.c
+++ b/gconf/gconf-client.c
@@ -239,6 +239,8 @@ gconf_client_init (GConfClient *client)
client->cache_hash = g_hash_table_new (g_str_hash, g_str_equal);
client->cache_dirs = g_hash_table_new_full (g_str_hash, g_str_equal,
g_free, NULL);
+ client->cache_recursive_dirs = g_hash_table_new_full (g_str_hash, g_str_equal,
+ g_free, NULL);
/* We create the listeners only if they're actually used */
client->listeners = NULL;
client->notify_list = NULL;
@@ -316,6 +318,9 @@ gconf_client_finalize (GObject* object)
g_hash_table_destroy (client->cache_hash);
client->cache_hash = NULL;
+ g_hash_table_destroy (client->cache_recursive_dirs);
+ client->cache_recursive_dirs = NULL;
+
g_hash_table_destroy (client->cache_dirs);
client->cache_dirs = NULL;
@@ -871,7 +876,7 @@ gconf_client_clear_cache(GConfClient* client)
}
static void
-cache_pairs_in_dir(GConfClient* client, const gchar* path);
+cache_pairs_in_dir(GConfClient* client, const gchar* path, gboolean recursive);
static void
recurse_subdir_list(GConfClient* client, GSList* subdirs)
@@ -884,7 +889,7 @@ recurse_subdir_list(GConfClient* client, GSList* subdirs)
{
gchar* s = tmp->data;
- cache_pairs_in_dir(client, s);
+ cache_pairs_in_dir(client, s, TRUE);
trace ("REMOTE: All dirs at '%s'", s);
PUSH_USE_ENGINE (client);
@@ -955,7 +960,7 @@ cache_entry_list_destructively (GConfClient *client,
}
static void
-cache_pairs_in_dir(GConfClient* client, const gchar* dir)
+cache_pairs_in_dir(GConfClient* client, const gchar* dir, gboolean recursive)
{
GSList* pairs;
GError* error = NULL;
@@ -977,6 +982,9 @@ cache_pairs_in_dir(GConfClient* client, const gchar* dir)
cache_entry_list_destructively (client, pairs);
trace ("Mark '%s' as fully cached", dir);
g_hash_table_insert (client->cache_dirs, g_strdup (dir), GINT_TO_POINTER (1));
+
+ if (recursive)
+ g_hash_table_insert (client->cache_recursive_dirs, g_strdup (dir), GINT_TO_POINTER (1));
}
void
@@ -1009,7 +1017,7 @@ gconf_client_preload (GConfClient* client,
{
trace ("Onelevel preload of '%s'", dirname);
- cache_pairs_in_dir (client, dirname);
+ cache_pairs_in_dir (client, dirname, FALSE);
}
break;
@@ -1024,7 +1032,7 @@ gconf_client_preload (GConfClient* client,
subdirs = gconf_engine_all_dirs(client->engine, dirname, NULL);
POP_USE_ENGINE (client);
- cache_pairs_in_dir(client, dirname);
+ cache_pairs_in_dir(client, dirname, TRUE);
recurse_subdir_list(client, subdirs);
}
@@ -2362,12 +2370,30 @@ gconf_client_lookup (GConfClient *client,
*last_slash = 0;
if (g_hash_table_lookup (client->cache_dirs, dir))
- {
- g_free (dir);
- trace ("Negative cache hit on %s", key);
- return TRUE;
- }
-
+ {
+ g_free (dir);
+ trace ("Negative cache hit on %s", key);
+ return TRUE;
+ }
+ else
+ {
+ gboolean not_cached = FALSE;
+ while(not_cached || (!g_hash_table_lookup (client->cache_recursive_dirs, dir)))
+ {
+ last_slash = strrchr (dir, '/');
+ if (last_slash == NULL)
+ break;
+ else
+ *last_slash = 0;
+ if (g_hash_table_lookup (client->cache_recursive_dirs, dir))
+ {
+ g_free (dir);
+ trace ("Non-existing dir for %s", key);
+ return TRUE;
+ }
+ not_cached = TRUE;
+ }
+ }
g_free (dir);
}
diff --git a/gconf/gconf-client.h b/gconf/gconf-client.h
index e142b0c..bc5eaf3 100644
--- a/gconf/gconf-client.h
+++ b/gconf/gconf-client.h
@@ -101,7 +101,7 @@ struct _GConfClient
guint notify_handler;
int pending_notify_count;
GHashTable *cache_dirs;
- int pad2;
+ GHashTable *cache_recursive_dirs;
};
struct _GConfClientClass
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]