diff options
author | Christopher James Lahey <clahey@helixcode.com> | 2000-06-03 00:12:26 +0800 |
---|---|---|
committer | Chris Lahey <clahey@src.gnome.org> | 2000-06-03 00:12:26 +0800 |
commit | 8d6afbe9102a979e28c861e3e4d34900cadd2eae (patch) | |
tree | 03d3c424f0cce1a7a965d05e707af6b773cc2c18 /camel/camel-store.c | |
parent | ac5683a1daaec4bf129ba1f59d80d8ea496efaab (diff) | |
download | gsoc2013-evolution-8d6afbe9102a979e28c861e3e4d34900cadd2eae.tar.gz gsoc2013-evolution-8d6afbe9102a979e28c861e3e4d34900cadd2eae.tar.zst gsoc2013-evolution-8d6afbe9102a979e28c861e3e4d34900cadd2eae.zip |
Ref and unref objects in the service cache properly.
2000-06-02 Christopher James Lahey <clahey@helixcode.com>
* camel-session.c: Ref and unref objects in the service cache
properly.
* camel-store.c: Ref the folder when returning it using
lookup_folder. Used the folder's full name for the key for the
folder cache since that's used to uncache it.
svn path=/trunk/; revision=3388
Diffstat (limited to 'camel/camel-store.c')
-rw-r--r-- | camel/camel-store.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/camel/camel-store.c b/camel/camel-store.c index b4eae9975e..ab0c4241f7 100644 --- a/camel/camel-store.c +++ b/camel/camel-store.c @@ -151,8 +151,12 @@ get_default_folder_name (CamelStore *store, CamelException *ex) static CamelFolder * lookup_folder (CamelStore *store, const char *folder_name) { - if (store->folders) - return g_hash_table_lookup (store->folders, folder_name); + if (store->folders) { + CamelFolder *folder = g_hash_table_lookup (store->folders, folder_name); + if (folder) + gtk_object_ref(GTK_OBJECT(folder)); + return folder; + } return NULL; } @@ -166,7 +170,7 @@ cache_folder (CamelStore *store, const char *folder_name, CamelFolder *folder) g_warning ("Caching folder %s that already exists.", folder_name); } - g_hash_table_insert (store->folders, (gpointer)g_strdup(folder_name), folder); + g_hash_table_insert (store->folders, camel_folder_get_full_name (folder), folder); gtk_signal_connect_object (GTK_OBJECT (folder), "destroy", GTK_SIGNAL_FUNC (CS_CLASS (store)->uncache_folder), GTK_OBJECT (store)); |