diff options
author | Not Zed <NotZed@Ximian.com> | 2004-07-29 11:00:42 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2004-07-29 11:00:42 +0800 |
commit | f000b8fa4fda0208ea241179451d62c27c4b3ffd (patch) | |
tree | 8dae82030012f9c1bc48e3c009c19385a3f92e8b | |
parent | a46a470a9d5be9d8b9699738b774d14acedce052 (diff) | |
download | gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.tar gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.tar.gz gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.tar.bz2 gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.tar.lz gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.tar.xz gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.tar.zst gsoc2013-evolution-f000b8fa4fda0208ea241179451d62c27c4b3ffd.zip |
** See #61958.
2004-07-28 Not Zed <NotZed@Ximian.com>
** See #61958.
* mail-folder-cache.c (real_flush_updates): remove the soreinfo
lookup, it isn't used anywhere anymore.
(mail_note_folder): hook onto the events outside of the lock, and
don't pass the mfi pointer anymore.
(mail_note_store): hook onto the events outside of the lock.
(folder_changed, folder_finalised, folder_renamed): lookup the mfi
if needed, it is no longer passed to the callback.
(unset_folder_info): change unhook calls for new parameters.
svn path=/trunk/; revision=26764
-rw-r--r-- | mail/ChangeLog | 13 | ||||
-rw-r--r-- | mail/mail-folder-cache.c | 69 |
2 files changed, 55 insertions, 27 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 7b2da9976e..27a25c0041 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,5 +1,18 @@ 2004-07-28 Not Zed <NotZed@Ximian.com> + ** See #61958. + + * mail-folder-cache.c (real_flush_updates): remove the soreinfo + lookup, it isn't used anywhere anymore. + (mail_note_folder): hook onto the events outside of the lock, and + don't pass the mfi pointer anymore. + (mail_note_store): hook onto the events outside of the lock. + (folder_changed, folder_finalised, folder_renamed): lookup the mfi + if needed, it is no longer passed to the callback. + (unset_folder_info): change unhook calls for new parameters. + +2004-07-28 Not Zed <NotZed@Ximian.com> + ** See #61940. * em-composer-utils.c (composer_set_body): add emformat source arg. diff --git a/mail/mail-folder-cache.c b/mail/mail-folder-cache.c index 25c962472c..52765b4ffd 100644 --- a/mail/mail-folder-cache.c +++ b/mail/mail-folder-cache.c @@ -56,6 +56,8 @@ #define w(x) #define d(x) +/* This code is a mess, there is no reason it should be so complicated. */ + /* note that many things are effectively serialised by having them run in the main loop thread which they need to do because of corba/gtk calls */ #define LOCK(x) pthread_mutex_lock(&x) @@ -185,7 +187,6 @@ real_flush_updates(void *o, void *event_data, void *data) struct _MailComponent *component; struct _EMFolderTreeModel *model; struct _folder_update *up; - struct _store_info *si; time_t now; component = mail_component_peek (); @@ -193,8 +194,6 @@ real_flush_updates(void *o, void *event_data, void *data) LOCK(info_lock); while ((up = (struct _folder_update *)e_dlist_remhead(&updates))) { - si = g_hash_table_lookup(stores, up->store); - UNLOCK(info_lock); if (up->remove) { @@ -264,9 +263,9 @@ unset_folder_info(struct _folder_info *mfi, int delete, int unsub) if (mfi->folder) { CamelFolder *folder = mfi->folder; - camel_object_unhook_event(folder, "folder_changed", folder_changed, mfi); - camel_object_unhook_event(folder, "renamed", folder_renamed, mfi); - camel_object_unhook_event(folder, "finalize", folder_finalised, mfi); + camel_object_unhook_event(folder, "folder_changed", folder_changed, NULL); + camel_object_unhook_event(folder, "renamed", folder_renamed, NULL); + camel_object_unhook_event(folder, "finalize", folder_finalised, NULL); } if ((mfi->flags & CAMEL_FOLDER_NOSELECT) == 0) { @@ -417,13 +416,12 @@ static void folder_changed (CamelObject *o, gpointer event_data, gpointer user_data) { CamelFolderChangeInfo *changes = event_data; - CamelFolder *folder = (CamelFolder *) o; - struct _folder_info *mfi = user_data; + CamelFolder *folder = (CamelFolder *)o; + CamelStore *store = folder->parent_store; + struct _store_info *si; + struct _folder_info *mfi; int new = 0; - if (mfi->folder != folder) - return; - d(printf("folder '%s' changed\n", folder->full_name)); if (!CAMEL_IS_VEE_FOLDER(folder) @@ -434,31 +432,42 @@ folder_changed (CamelObject *o, gpointer event_data, gpointer user_data) new = changes->uid_added->len; LOCK(info_lock); - update_1folder(mfi, new, NULL); + if (stores != NULL + && (si = g_hash_table_lookup(stores, store)) != NULL + && (mfi = g_hash_table_lookup(si->folders, folder->full_name)) != NULL + && mfi->folder == folder) { + update_1folder(mfi, new, NULL); + } UNLOCK(info_lock); } static void folder_finalised(CamelObject *o, gpointer event_data, gpointer user_data) { - struct _folder_info *mfi = user_data; + CamelFolder *folder = (CamelFolder *)o; + CamelStore *store = folder->parent_store; + struct _store_info *si; + struct _folder_info *mfi; d(printf("Folder finalised '%s'!\n", ((CamelFolder *)o)->full_name)); LOCK(info_lock); - mfi->folder = NULL; + if (stores != NULL + && (si = g_hash_table_lookup(stores, store)) != NULL + && (mfi = g_hash_table_lookup(si->folders, folder->full_name)) != NULL + && mfi->folder == folder) { + mfi->folder = NULL; + } UNLOCK(info_lock); } static void folder_renamed(CamelObject *o, gpointer event_data, gpointer user_data) { - struct _folder_info *mfi = user_data; CamelFolder *folder = (CamelFolder *)o; char *old = event_data; d(printf("Folder renamed from '%s' to '%s'\n", old, folder->full_name)); - mfi = mfi; old = old; folder = folder; /* Dont do anything, do it from the store rename event? */ @@ -489,13 +498,13 @@ void mail_note_folder(CamelFolder *folder) mfi->folder = folder; - camel_object_hook_event(folder, "folder_changed", folder_changed, mfi); - camel_object_hook_event(folder, "renamed", folder_renamed, mfi); - camel_object_hook_event(folder, "finalize", folder_finalised, mfi); - update_1folder(mfi, 0, NULL); UNLOCK(info_lock); + + camel_object_hook_event(folder, "folder_changed", folder_changed, NULL); + camel_object_hook_event(folder, "renamed", folder_renamed, NULL); + camel_object_hook_event(folder, "finalize", folder_finalised, NULL); } static void @@ -740,6 +749,7 @@ mail_note_store_remove(CamelStore *store) g_hash_table_destroy(si->folders_uri); g_free(si); } + UNLOCK(info_lock); } @@ -867,6 +877,7 @@ mail_note_store(CamelStore *store, CamelOperation *op, struct _update_data *ud; const char *buf; guint timeout; + int hook = 0; g_assert(CAMEL_IS_STORE(store)); g_assert(pthread_self() == mail_gui_thread); @@ -894,13 +905,7 @@ mail_note_store(CamelStore *store, CamelOperation *op, camel_object_ref((CamelObject *)store); g_hash_table_insert(stores, store, si); e_dlist_init(&si->folderinfo_updates); - - camel_object_hook_event(store, "folder_opened", store_folder_opened, NULL); - camel_object_hook_event(store, "folder_created", store_folder_created, NULL); - camel_object_hook_event(store, "folder_deleted", store_folder_deleted, NULL); - camel_object_hook_event(store, "folder_renamed", store_folder_renamed, NULL); - camel_object_hook_event(store, "folder_subscribed", store_folder_subscribed, NULL); - camel_object_hook_event(store, "folder_unsubscribed", store_folder_unsubscribed, NULL); + hook = TRUE; } /* We might get a race when setting up a store, such that it is still left in offline mode, @@ -929,6 +934,16 @@ mail_note_store(CamelStore *store, CamelOperation *op, } UNLOCK(info_lock); + + /* there is potential for race here, but it is safe as we check for the store anyway */ + if (hook) { + camel_object_hook_event(store, "folder_opened", store_folder_opened, NULL); + camel_object_hook_event(store, "folder_created", store_folder_created, NULL); + camel_object_hook_event(store, "folder_deleted", store_folder_deleted, NULL); + camel_object_hook_event(store, "folder_renamed", store_folder_renamed, NULL); + camel_object_hook_event(store, "folder_subscribed", store_folder_subscribed, NULL); + camel_object_hook_event(store, "folder_unsubscribed", store_folder_unsubscribed, NULL); + } } struct _find_info { |