[evolution-data-server] Test for parent_store availability around camel_folder_changed()



commit ec7da5027346412df5f03f50012e4644eac59a92
Author: Milan Crha <mcrha redhat com>
Date:   Wed Dec 7 21:59:36 2016 +0100

    Test for parent_store availability around camel_folder_changed()
    
    This could happen after the changes for the bug 772292.

 src/camel/camel-folder.c |   32 ++++++++++++++++++--------------
 1 files changed, 18 insertions(+), 14 deletions(-)
---
diff --git a/src/camel/camel-folder.c b/src/camel/camel-folder.c
index 7e68e70..82ed860 100644
--- a/src/camel/camel-folder.c
+++ b/src/camel/camel-folder.c
@@ -1095,6 +1095,9 @@ folder_changed (CamelFolder *folder,
        g_mutex_unlock (&folder->priv->change_lock);
 
        parent_store = camel_folder_get_parent_store (folder);
+       if (!parent_store)
+               return;
+
        session = camel_service_ref_session (CAMEL_SERVICE (parent_store));
        if (!session)
                return;
@@ -2485,24 +2488,25 @@ camel_folder_changed (CamelFolder *folder,
                SignalClosure *signal_closure;
 
                parent_store = camel_folder_get_parent_store (folder);
+               if (parent_store) {
+                       service = CAMEL_SERVICE (parent_store);
+                       session = camel_service_ref_session (service);
 
-               service = CAMEL_SERVICE (parent_store);
-               session = camel_service_ref_session (service);
+                       if (session) {
+                               pending_changes = camel_folder_change_info_new ();
+                               folder->priv->pending_changes = pending_changes;
 
-               if (session) {
-                       pending_changes = camel_folder_change_info_new ();
-                       folder->priv->pending_changes = pending_changes;
+                               signal_closure = g_slice_new0 (SignalClosure);
+                               signal_closure->folder = g_object_ref (folder);
 
-                       signal_closure = g_slice_new0 (SignalClosure);
-                       signal_closure->folder = g_object_ref (folder);
+                               camel_session_idle_add (
+                                       session, G_PRIORITY_LOW,
+                                       folder_emit_changed_cb,
+                                       signal_closure,
+                                       (GDestroyNotify) signal_closure_free);
 
-                       camel_session_idle_add (
-                               session, G_PRIORITY_LOW,
-                               folder_emit_changed_cb,
-                               signal_closure,
-                               (GDestroyNotify) signal_closure_free);
-
-                       g_object_unref (session);
+                               g_object_unref (session);
+                       }
                }
        }
 


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