[evolution/wip/camel-more-gobject: 75/75] Bug 764065 (part 1) - [Camel] Port more classes to GObject



commit 4f3feffe52c11f76c23a004cc8a4c21914bd13ab
Author: Milan Crha <mcrha redhat com>
Date:   Tue Oct 11 21:55:50 2016 +0200

    Bug 764065 (part 1) - [Camel] Port more classes to GObject

 src/libemail-engine/e-mail-folder-utils.c  |   37 +++-----
 src/libemail-engine/e-mail-session-utils.c |   32 ++-----
 src/libemail-engine/e-mail-session.c       |    2 +-
 src/libemail-engine/e-mail-utils.c         |    6 +-
 src/libemail-engine/mail-folder-cache.c    |   35 ++++---
 src/libemail-engine/mail-ops.c             |   11 +--
 src/mail/e-mail-browser.c                  |    5 +-
 src/mail/e-mail-display.c                  |    2 +-
 src/mail/e-mail-folder-pane.c              |    2 +-
 src/mail/e-mail-notes.c                    |    8 +-
 src/mail/e-mail-reader-utils.c             |   72 +++++++++------
 src/mail/e-mail-reader.c                   |    7 +-
 src/mail/e-mail-tag-editor.c               |  139 +++++++++++----------------
 src/mail/e-mail-tag-editor.h               |   10 +--
 src/mail/em-composer-utils.c               |    4 +-
 src/mail/em-utils.c                        |   54 +++++++-----
 src/mail/importers/mail-importer.c         |    4 +-
 src/mail/message-list.c                    |   43 ++++++---
 src/modules/mdn/evolution-mdn.c            |   19 +---
 src/plugins/dbx-import/dbx-importer.c      |    2 +-
 src/plugins/pst-import/pst-importer.c      |    2 +-
 src/plugins/templates/e-templates-store.c  |    4 +-
 src/plugins/templates/templates.c          |    2 +-
 23 files changed, 244 insertions(+), 258 deletions(-)
---
diff --git a/src/libemail-engine/e-mail-folder-utils.c b/src/libemail-engine/e-mail-folder-utils.c
index 0667962..e1ca6d8 100644
--- a/src/libemail-engine/e-mail-folder-utils.c
+++ b/src/libemail-engine/e-mail-folder-utils.c
@@ -47,23 +47,16 @@ struct _AsyncContext {
 static void
 async_context_free (AsyncContext *context)
 {
-       if (context->message != NULL)
-               g_object_unref (context->message);
-
-       if (context->info != NULL)
-               camel_message_info_unref (context->info);
-
-       if (context->part != NULL)
-               g_object_unref (context->part);
-
        if (context->hash_table != NULL)
                g_hash_table_unref (context->hash_table);
 
        if (context->ptr_array != NULL)
                g_ptr_array_unref (context->ptr_array);
 
-       if (context->destination != NULL)
-               g_object_unref (context->destination);
+       g_clear_object (&context->message);
+       g_clear_object (&context->info);
+       g_clear_object (&context->part);
+       g_clear_object (&context->destination);
 
        g_free (context->fwd_subject);
        g_free (context->message_uid);
@@ -146,7 +139,7 @@ e_mail_folder_append_message (CamelFolder *folder,
        context->message = g_object_ref (message);
 
        if (info != NULL)
-               context->info = camel_message_info_ref (info);
+               context->info = g_object_ref (info);
 
        simple = g_simple_async_result_new (
                G_OBJECT (folder), callback, user_data,
@@ -249,7 +242,7 @@ mail_folder_expunge_pop3_stores (CamelFolder *folder,
 
                if (info != NULL) {
                        flags = camel_message_info_get_flags (info);
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                }
 
                /* Only interested in deleted messages. */
@@ -792,7 +785,7 @@ e_mail_folder_find_duplicate_messages_sync (CamelFolder *folder,
        g_hash_table_iter_init (&iter, hash_table);
 
        while (g_hash_table_iter_next (&iter, &key, &value)) {
-               const CamelSummaryMessageID *message_id;
+               CamelSummaryMessageID message_id;
                CamelMessageFlags flags;
                CamelMessageInfo *info;
                gboolean duplicate;
@@ -802,13 +795,13 @@ e_mail_folder_find_duplicate_messages_sync (CamelFolder *folder,
                if (!info)
                        continue;
 
-               message_id = camel_message_info_get_message_id (info);
+               message_id.id.id = camel_message_info_get_message_id (info);
                flags = camel_message_info_get_flags (info);
 
                /* Skip messages marked for deletion. */
                if (flags & CAMEL_MESSAGE_DELETED) {
                        g_queue_push_tail (&trash, key);
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                        continue;
                }
 
@@ -816,13 +809,13 @@ e_mail_folder_find_duplicate_messages_sync (CamelFolder *folder,
 
                if (digest == NULL) {
                        g_queue_push_tail (&trash, key);
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                        continue;
                }
 
                /* Determine if the message a duplicate. */
 
-               value = g_hash_table_lookup (unique_ids, &message_id->id.id);
+               value = g_hash_table_lookup (unique_ids, &message_id.id.id);
                duplicate = (value != NULL) && g_str_equal (digest, value);
 
                if (!duplicate) {
@@ -832,13 +825,13 @@ e_mail_folder_find_duplicate_messages_sync (CamelFolder *folder,
                         *     of 64-bit integers and have the hash
                         *     table keys point to array elements. */
                        v_int64 = g_new0 (gint64, 1);
-                       *v_int64 = (gint64) message_id->id.id;
+                       *v_int64 = (gint64) message_id.id.id;
 
                        g_hash_table_insert (unique_ids, v_int64, g_strdup (digest));
                        g_queue_push_tail (&trash, key);
                }
 
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        /* Delete all non-duplicate messages from the hash table. */
@@ -1395,8 +1388,8 @@ mail_folder_strip_message (CamelFolder *folder,
                                CAMEL_MESSAGE_DELETED,
                                CAMEL_MESSAGE_DELETED);
 
-               camel_message_info_unref (orig_info);
-               camel_message_info_unref (copy_info);
+               g_clear_object (&orig_info);
+               g_clear_object (&copy_info);
        }
 
        return success;
diff --git a/src/libemail-engine/e-mail-session-utils.c b/src/libemail-engine/e-mail-session-utils.c
index 20ba4aa..5dadf09 100644
--- a/src/libemail-engine/e-mail-session-utils.c
+++ b/src/libemail-engine/e-mail-session-utils.c
@@ -64,26 +64,13 @@ struct _AsyncContext {
 static void
 async_context_free (AsyncContext *context)
 {
-       if (context->folder != NULL)
-               g_object_unref (context->folder);
-
-       if (context->message != NULL)
-               g_object_unref (context->message);
-
-       if (context->info != NULL)
-               camel_message_info_unref (context->info);
-
-       if (context->from != NULL)
-               g_object_unref (context->from);
-
-       if (context->recipients != NULL)
-               g_object_unref (context->recipients);
-
-       if (context->driver != NULL)
-               g_object_unref (context->driver);
-
-       if (context->transport != NULL)
-               g_object_unref (context->transport);
+       g_clear_object (&context->folder);
+       g_clear_object (&context->message);
+       g_clear_object (&context->info);
+       g_clear_object (&context->from);
+       g_clear_object (&context->recipients);
+       g_clear_object (&context->driver);
+       g_clear_object (&context->transport);
 
        if (context->cancellable != NULL) {
                camel_operation_pop_message (context->cancellable);
@@ -192,7 +179,7 @@ e_mail_session_append_to_local_folder (EMailSession *session,
        context->message = g_object_ref (message);
 
        if (info != NULL)
-               context->info = camel_message_info_ref (info);
+               context->info = g_object_ref (info);
 
        simple = g_simple_async_result_new (
                G_OBJECT (session), callback, user_data,
@@ -911,8 +898,7 @@ e_mail_session_send_to (EMailSession *session,
 
        info = camel_message_info_new_from_header (
                NULL, CAMEL_MIME_PART (message)->headers);
-       ((CamelMessageInfoBase *) info)->size =
-               get_message_size (message, cancellable);
+       camel_message_info_set_size (info, get_message_size (message, cancellable));
        camel_message_info_set_flags (info, CAMEL_MESSAGE_SEEN |
                (camel_mime_message_has_attachment (message) ? CAMEL_MESSAGE_ATTACHMENTS : 0), ~0);
 
diff --git a/src/libemail-engine/e-mail-session.c b/src/libemail-engine/e-mail-session.c
index fc612bc..5cb61cc 100644
--- a/src/libemail-engine/e-mail-session.c
+++ b/src/libemail-engine/e-mail-session.c
@@ -1515,7 +1515,7 @@ mail_session_forward_to_sync (CamelSession *session,
                g_mutex_unlock (&priv->preparing_flush_lock);
        }
 
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 
        g_object_unref (source);
 
diff --git a/src/libemail-engine/e-mail-utils.c b/src/libemail-engine/e-mail-utils.c
index 862ec00..64ae039 100644
--- a/src/libemail-engine/e-mail-utils.c
+++ b/src/libemail-engine/e-mail-utils.c
@@ -306,7 +306,7 @@ guess_mail_account_from_folder (ESourceRegistry *registry,
                        location = camel_vee_folder_get_location (CAMEL_VEE_FOLDER (folder), 
(CamelVeeMessageInfo *) mi, NULL);
                        if (location)
                                store = camel_folder_get_parent_store (location);
-                       camel_message_info_unref (mi);
+                       g_clear_object (&mi);
                }
        }
 
@@ -795,7 +795,7 @@ em_utils_get_real_folder_and_message_uid (CamelFolder *folder,
                                else
                                        g_free (real_uid);
 
-                               camel_message_info_unref (mi);
+                               g_clear_object (&mi);
 
                                if (out_real_folder)
                                        *out_real_folder = g_object_ref (real_folder);
@@ -803,7 +803,7 @@ em_utils_get_real_folder_and_message_uid (CamelFolder *folder,
                                return;
                        }
 
-                       camel_message_info_unref (mi);
+                       g_clear_object (&mi);
                }
        }
 
diff --git a/src/libemail-engine/mail-folder-cache.c b/src/libemail-engine/mail-folder-cache.c
index 8c8b380..b18d9bb 100644
--- a/src/libemail-engine/mail-folder-cache.c
+++ b/src/libemail-engine/mail-folder-cache.c
@@ -859,31 +859,37 @@ folder_cache_check_ignore_thread (CamelFolder *folder,
                                  GCancellable *cancellable,
                                  GError **error)
 {
-       const CamelSummaryReferences *references;
+       GArray *references;
        gboolean has_ignore_thread = FALSE, first_ignore_thread = FALSE, found_first_msgid = FALSE;
        guint64 first_msgid;
        GString *expr = NULL;
-       gint ii;
+       guint ii;
 
        g_return_val_if_fail (CAMEL_IS_FOLDER (folder), FALSE);
        g_return_val_if_fail (info != NULL, FALSE);
 
-       references = camel_message_info_get_references (info);
-       if (!references || references->size <= 0)
+       references = camel_message_info_dup_references (info);
+       if (!references || references->len <= 0) {
+               if (references)
+                       g_array_unref (references);
                return FALSE;
+       }
+
+       first_msgid = g_array_index (references, guint64, 0);
 
-       first_msgid = references->references[0].id.id;
+       for (ii = 0; ii < references->len; ii++) {
+               CamelSummaryMessageID msgid;
 
-       for (ii = 0; ii < references->size; ii++) {
-               if (references->references[ii].id.id == 0)
+               msgid.id.id = g_array_index (references, guint64, ii);
+               if (!msgid.id.id)
                        continue;
 
                if (!expr)
                        expr = g_string_new ("(match-all (or ");
 
                g_string_append_printf (expr, "(= \"msgid\" \"%lu %lu\")",
-                       (gulong) references->references[ii].id.part.hi,
-                       (gulong) references->references[ii].id.part.lo);
+                       (gulong) msgid.id.part.hi,
+                       (gulong) msgid.id.part.lo);
        }
 
        if (expr) {
@@ -901,19 +907,18 @@ folder_cache_check_ignore_thread (CamelFolder *folder,
                                if (!refrinfo)
                                        continue;
 
-                               if (first_msgid && camel_message_info_get_message_id (refrinfo) &&
-                                   camel_message_info_get_message_id (refrinfo)->id.id == first_msgid) {
+                               if (first_msgid && camel_message_info_get_message_id (refrinfo) == 
first_msgid) {
                                        /* The first msgid in the references is In-ReplyTo, which is the 
master;
                                           the rest is just a guess. */
                                        found_first_msgid = TRUE;
                                        first_ignore_thread = camel_message_info_get_user_flag (refrinfo, 
"ignore-thread");
-                                       camel_message_info_unref (refrinfo);
+                                       g_clear_object (&refrinfo);
                                        break;
                                }
 
                                has_ignore_thread = has_ignore_thread || camel_message_info_get_user_flag 
(refrinfo, "ignore-thread");
 
-                               camel_message_info_unref (refrinfo);
+                               g_clear_object (&refrinfo);
                        }
 
                        camel_folder_search_free (folder, uids);
@@ -922,6 +927,8 @@ folder_cache_check_ignore_thread (CamelFolder *folder,
                g_string_free (expr, TRUE);
        }
 
+       g_array_unref (references);
+
        return (found_first_msgid && first_ignore_thread) || (!found_first_msgid && has_ignore_thread);
 }
 
@@ -1019,7 +1026,7 @@ folder_cache_process_folder_changes_thread (CamelFolder *folder,
                                        }
                                }
 
-                               camel_message_info_unref (info);
+                               g_clear_object (&info);
 
                                if (local_error) {
                                        g_propagate_error (error, local_error);
diff --git a/src/libemail-engine/mail-ops.c b/src/libemail-engine/mail-ops.c
index 7790e3a..ef1bd11 100644
--- a/src/libemail-engine/mail-ops.c
+++ b/src/libemail-engine/mail-ops.c
@@ -701,7 +701,7 @@ mail_send_message (struct _send_queue_msg *m,
 
        /* Now check for posting, failures are ignored */
        info = camel_message_info_new (NULL);
-       ((CamelMessageInfoBase *) info)->size = get_message_size (message, cancellable);
+       camel_message_info_set_size (info, get_message_size (message, cancellable));
        camel_message_info_set_flags (info, CAMEL_MESSAGE_SEEN |
                (camel_mime_message_has_attachment (message) ? CAMEL_MESSAGE_ATTACHMENTS : 0), ~0);
 
@@ -902,11 +902,8 @@ exit:
                g_object_unref (folder);
        }
 
-       if (info != NULL)
-               camel_message_info_unref (info);
-
-       if (service != NULL)
-               g_object_unref (service);
+       g_clear_object (&info);
+       g_clear_object (&service);
 
        g_object_unref (recipients);
        g_object_unref (from);
@@ -978,7 +975,7 @@ send_queue_exec (struct _send_queue_msg *m,
                        if ((camel_message_info_get_flags (info) & CAMEL_MESSAGE_DELETED) == 0 &&
                            (!delay_send || camel_message_info_get_date_sent (info) <= delay_send))
                                send_uids->pdata[j++] = uids->pdata[i];
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                }
        }
 
diff --git a/src/mail/e-mail-browser.c b/src/mail/e-mail-browser.c
index 5809256..989a8df 100644
--- a/src/mail/e-mail-browser.c
+++ b/src/mail/e-mail-browser.c
@@ -293,8 +293,7 @@ mail_browser_message_selected_cb (EMailBrowser *browser,
                if (g_settings_get_boolean (settings, "mark-seen"))
                        camel_message_info_set_flags (info, CAMEL_MESSAGE_SEEN, CAMEL_MESSAGE_SEEN);
                g_clear_object (&settings);
-
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        g_clear_object (&folder);
@@ -912,7 +911,7 @@ mail_browser_set_message (EMailReader *reader,
                gtk_window_set_title (
                        GTK_WINDOW (reader),
                        camel_message_info_get_subject (info));
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        g_clear_object (&folder);
diff --git a/src/mail/e-mail-display.c b/src/mail/e-mail-display.c
index f26a188..9ee3767 100644
--- a/src/mail/e-mail-display.c
+++ b/src/mail/e-mail-display.c
@@ -2080,7 +2080,7 @@ e_mail_display_claim_attachment (EMailFormatter *formatter,
                                if (info) {
                                        if (!camel_message_info_get_user_flag (info, E_MAIL_NOTES_USER_FLAG))
                                                camel_message_info_set_user_flag (info, 
E_MAIL_NOTES_USER_FLAG, TRUE);
-                                       camel_message_info_unref (info);
+                                       g_clear_object (&info);
                                }
                        }
                }
diff --git a/src/mail/e-mail-folder-pane.c b/src/mail/e-mail-folder-pane.c
index 1c689a7..ad6f1b3 100644
--- a/src/mail/e-mail-folder-pane.c
+++ b/src/mail/e-mail-folder-pane.c
@@ -139,7 +139,7 @@ mail_paned_view_open_selected_mail (EMailPanedView *view)
                        g_ptr_array_add (views, g_strdup (uid));
                }
 
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        n_views = views->len;
diff --git a/src/mail/e-mail-notes.c b/src/mail/e-mail-notes.c
index a917360..54aa982 100644
--- a/src/mail/e-mail-notes.c
+++ b/src/mail/e-mail-notes.c
@@ -621,7 +621,9 @@ e_mail_notes_replace_message_in_folder_sync (CamelFolder *folder,
                CamelMessageInfo *clone;
                gchar *appended_uid = NULL;
 
-               clone = camel_message_info_clone (mi);
+               clone = camel_message_info_clone (mi, NULL);
+               camel_message_info_set_abort_notifications (clone, TRUE);
+
                camel_message_info_set_user_flag (clone, E_MAIL_NOTES_USER_FLAG, has_note);
 
                success = camel_folder_append_message_sync (folder, message, clone,
@@ -630,8 +632,8 @@ e_mail_notes_replace_message_in_folder_sync (CamelFolder *folder,
                if (success)
                        camel_message_info_set_flags (mi, CAMEL_MESSAGE_DELETED, CAMEL_MESSAGE_DELETED);
 
-               camel_message_info_unref (clone);
-               camel_message_info_unref (mi);
+               g_clear_object (&clone);
+               g_clear_object (&mi);
                g_free (appended_uid);
        } else {
                g_set_error_literal (error, CAMEL_ERROR, CAMEL_ERROR_GENERIC, _("Cannot find message in its 
folder summary"));
diff --git a/src/mail/e-mail-reader-utils.c b/src/mail/e-mail-reader-utils.c
index 8221cc4..891d728 100644
--- a/src/mail/e-mail-reader-utils.c
+++ b/src/mail/e-mail-reader-utils.c
@@ -934,15 +934,15 @@ mark_ignore_thread_data_free (gpointer ptr)
 
 static void
 insert_to_checked_msgids (GHashTable *checked_msgids,
-                         const CamelSummaryMessageID *msgid)
+                         const CamelSummaryMessageID msgid)
 {
        CamelSummaryMessageID *msgid_copy;
 
-       if (!msgid)
+       if (!msgid.id.id)
                return;
 
        msgid_copy = g_new0 (CamelSummaryMessageID, 1);
-       memcpy (msgid_copy, msgid, sizeof (CamelSummaryMessageID));
+       msgid_copy->id.id = msgid.id.id;
 
        g_hash_table_insert (checked_msgids, msgid_copy, GINT_TO_POINTER (1));
 }
@@ -959,7 +959,7 @@ mark_ignore_thread_traverse_uids (CamelFolder *folder,
 {
        GSList *to_check;
        GPtrArray *uids;
-       gint ii;
+       guint ii;
        gboolean success;
 
        success = !g_cancellable_set_error_if_cancelled (cancellable, error);
@@ -973,8 +973,7 @@ mark_ignore_thread_traverse_uids (CamelFolder *folder,
 
        while (to_check != NULL && !g_cancellable_set_error_if_cancelled (cancellable, error)) {
                CamelMessageInfo *mi;
-               const CamelSummaryMessageID *msgid;
-               const CamelSummaryReferences *references;
+               CamelSummaryMessageID msgid;
                const gchar *uid = to_check->data;
                gchar *sexp;
                GError *local_error = NULL;
@@ -990,36 +989,40 @@ mark_ignore_thread_traverse_uids (CamelFolder *folder,
 
                mi = camel_folder_get_message_info (folder, uid);
                if (!mi || !camel_message_info_get_message_id (mi)) {
-                       if (mi)
-                               camel_message_info_unref (mi);
+                       g_clear_object (&mi);
                        camel_pstring_free (uid);
                        continue;
                }
 
                camel_message_info_set_user_flag (mi, "ignore-thread", ignore_thread);
 
-               msgid = camel_message_info_get_message_id (mi);
+               msgid.id.id = camel_message_info_get_message_id (mi);
                insert_to_checked_msgids (checked_msgids, msgid);
 
                if (whole_thread) {
+                       GArray *references;
+
                        /* Search for parents */
-                       references = camel_message_info_get_references (mi);
+                       references = camel_message_info_dup_references (mi);
                        if (references) {
                                GString *expr = NULL;
 
-                               for (ii = 0; ii < references->size; ii++) {
-                                       if (references->references[ii].id.id == 0 ||
-                                           g_hash_table_contains (checked_msgids, 
&references->references[ii]))
+                               for (ii = 0; ii < references->len; ii++) {
+                                       CamelSummaryMessageID ref_msgid;
+
+                                       ref_msgid.id.id = g_array_index (references, guint64, ii);
+                                       if (!ref_msgid.id.id ||
+                                           g_hash_table_contains (checked_msgids, &ref_msgid))
                                                continue;
 
-                                       insert_to_checked_msgids (checked_msgids, 
&references->references[ii]);
+                                       insert_to_checked_msgids (checked_msgids, ref_msgid);
 
                                        if (!expr)
                                                expr = g_string_new ("(match-all (or ");
 
                                        g_string_append_printf (expr, "(= \"msgid\" \"%lu %lu\")",
-                                               (gulong) references->references[ii].id.part.hi,
-                                               (gulong) references->references[ii].id.part.lo);
+                                               (gulong) ref_msgid.id.part.hi,
+                                               (gulong) ref_msgid.id.part.lo);
                                }
 
                                if (expr) {
@@ -1041,17 +1044,19 @@ mark_ignore_thread_traverse_uids (CamelFolder *folder,
 
                                        if (local_error) {
                                                g_propagate_error (error, local_error);
-                                               camel_message_info_unref (mi);
+                                               g_clear_object (&mi);
                                                camel_pstring_free (uid);
                                                success = FALSE;
                                                break;
                                        }
                                }
+
+                               g_array_unref (references);
                        }
                }
 
                /* Search for children */
-               sexp = g_strdup_printf ("(match-all (= \"references\" \"%lu %lu\"))", (gulong) 
msgid->id.part.hi, (gulong) msgid->id.part.lo);
+               sexp = g_strdup_printf ("(match-all (= \"references\" \"%lu %lu\"))", (gulong) 
msgid.id.part.hi, (gulong) msgid.id.part.lo);
                uids = camel_folder_search_by_expression (folder, sexp, cancellable, &local_error);
                if (uids) {
                        for (ii = 0; ii < uids->len; ii++) {
@@ -1059,25 +1064,34 @@ mark_ignore_thread_traverse_uids (CamelFolder *folder,
 
                                if (refruid && !g_hash_table_contains (checked_uids, refruid)) {
                                        CamelMessageInfo *refrmi = camel_folder_get_message_info (folder, 
refruid);
+                                       guint64 msg_id = 0;
+
+                                       if (refrmi)
+                                               msg_id = camel_message_info_get_message_id (refrmi);
+
+                                       if (refrmi && msg_id && !g_hash_table_contains (checked_msgids, 
&msg_id)) {
+                                               GArray *references;
 
-                                       if (refrmi && camel_message_info_get_message_id (refrmi) &&
-                                           !g_hash_table_contains (checked_msgids, 
camel_message_info_get_message_id (refrmi))) {
                                                /* The 'references' filter search can return false positives 
*/
-                                               references = camel_message_info_get_references (refrmi);
+                                               references = camel_message_info_dup_references (refrmi);
                                                if (references) {
-                                                       gint jj;
+                                                       guint jj;
+
+                                                       for (jj = 0; jj < references->len; jj++) {
+                                                               guint64 ref_msgid;
 
-                                                       for (jj = 0; jj < references->size; jj++) {
-                                                               if (references->references[jj].id.id == 
msgid->id.id) {
+                                                               ref_msgid = g_array_index (references, 
guint64, jj);
+                                                               if (ref_msgid == msgid.id.id) {
                                                                        to_check = g_slist_prepend (to_check, 
(gpointer) camel_pstring_strdup (refruid));
                                                                        break;
                                                                }
                                                        }
+
+                                                       g_array_unref (references);
                                                }
                                        }
 
-                                       if (refrmi)
-                                               camel_message_info_unref (refrmi);
+                                       g_clear_object (&refrmi);
                                }
                        }
 
@@ -1085,7 +1099,7 @@ mark_ignore_thread_traverse_uids (CamelFolder *folder,
                }
                g_free (sexp);
 
-               camel_message_info_unref (mi);
+               g_clear_object (&mi);
                camel_pstring_free (uid);
 
                if (local_error) {
@@ -1298,7 +1312,7 @@ e_mail_reader_open_selected (EMailReader *reader)
                        g_ptr_array_add (views, g_strdup (uid));
                }
 
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        for (ii = 0; ii < views->len; ii++) {
@@ -2669,7 +2683,7 @@ e_mail_reader_save_messages (EMailReader *reader)
                subject = camel_message_info_get_subject (info);
                if (subject != NULL)
                        suggestion = g_strconcat (subject, ".mbox", NULL);
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        if (suggestion == NULL) {
diff --git a/src/mail/e-mail-reader.c b/src/mail/e-mail-reader.c
index be23984..a186f99 100644
--- a/src/mail/e-mail-reader.c
+++ b/src/mail/e-mail-reader.c
@@ -206,8 +206,7 @@ action_mail_add_sender_cb (GtkAction *action,
        g_object_unref (cia);
 
 exit:
-       if (info != NULL)
-               camel_message_info_unref (info);
+       g_clear_object (&info);
        g_ptr_array_unref (uids);
 
        g_clear_object (&folder);
@@ -3052,7 +3051,7 @@ mail_reader_manage_followup_flag (EMailReader *reader,
                g_object_unref (alert);
        }
 
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 
        if (!alert_added)
                mail_reader_remove_followup_alert (reader);
@@ -4642,7 +4641,7 @@ e_mail_reader_check_state (EMailReader *reader)
                has_notignore_thread = has_notignore_thread ||
                        !camel_message_info_get_user_flag (info, "ignore-thread");
 
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        have_enabled_account =
diff --git a/src/mail/e-mail-tag-editor.c b/src/mail/e-mail-tag-editor.c
index 2602241..da38b3f 100644
--- a/src/mail/e-mail-tag-editor.c
+++ b/src/mail/e-mail-tag-editor.c
@@ -117,75 +117,6 @@ mail_tag_editor_realize (GtkWidget *widget)
        gtk_container_set_border_width (GTK_CONTAINER (action_area), 12);
 }
 
-static CamelTag *
-mail_tag_editor_get_tag_list (EMailTagEditor *editor)
-{
-       CamelTag *tag_list = NULL;
-       time_t date;
-       gchar *text = NULL;
-       GtkWidget *entry;
-
-       entry = gtk_bin_get_child (GTK_BIN (editor->priv->combo_entry));
-       if (entry)
-               text = g_strdup (gtk_entry_get_text (GTK_ENTRY (entry)));
-       camel_tag_set (&tag_list, "follow-up", text);
-       g_free (text);
-
-       date = e_date_edit_get_time (editor->priv->target_date);
-       if (date != (time_t) -1) {
-               text = camel_header_format_date (date, 0);
-               camel_tag_set (&tag_list, "due-by", text);
-               g_free (text);
-       } else
-               camel_tag_set (&tag_list, "due-by", "");
-
-       if (e_mail_tag_editor_get_completed (editor)) {
-               text = camel_header_format_date (
-                       editor->priv->completed_date, 0);
-               camel_tag_set (&tag_list, "completed-on", text);
-               g_free (text);
-       } else
-               camel_tag_set (&tag_list, "completed-on", "");
-
-       return tag_list;
-}
-
-static void
-mail_tag_editor_set_tag_list (EMailTagEditor *editor,
-                              CamelTag *tag_list)
-{
-       GtkWidget *child;
-       const gchar *text;
-       time_t date;
-
-       /* Extract the GtkEntry from the GtkComboBoxEntry. */
-       child = gtk_bin_get_child (GTK_BIN (editor->priv->combo_entry));
-
-       /* XXX This is kind of cheating.  Since we only store the
-        *     translated tag there's no sure-fire way to determine
-        *     the corresponding combo box index (e.g. the tag may
-        *     have been set while running in a different locale). */
-       text = camel_tag_get (&tag_list, "follow-up");
-       if (text != NULL)
-               gtk_entry_set_text (GTK_ENTRY (child), text);
-
-       text = camel_tag_get (&tag_list, "due-by");
-       if (text != NULL && *text != '\0') {
-               date = camel_header_decode_date (text, NULL);
-               e_date_edit_set_time (editor->priv->target_date, date);
-       } else
-               e_date_edit_set_time (editor->priv->target_date, (time_t) -1);
-
-       text = camel_tag_get (&tag_list, "completed-on");
-       if (text != NULL && *text != '\0') {
-               date = camel_header_decode_date (text, NULL);
-               if (date != (time_t) 0) {
-                       e_mail_tag_editor_set_completed (editor, TRUE);
-                       editor->priv->completed_date = date;
-               }
-       }
-}
-
 static void
 e_mail_tag_editor_class_init (EMailTagEditorClass *class)
 {
@@ -201,9 +132,6 @@ e_mail_tag_editor_class_init (EMailTagEditorClass *class)
        widget_class = GTK_WIDGET_CLASS (class);
        widget_class->realize = mail_tag_editor_realize;
 
-       class->get_tag_list = mail_tag_editor_get_tag_list;
-       class->set_tag_list = mail_tag_editor_set_tag_list;
-
        g_object_class_install_property (
                object_class,
                PROP_COMPLETED,
@@ -331,32 +259,79 @@ e_mail_tag_editor_set_completed (EMailTagEditor *editor,
        g_object_notify (G_OBJECT (editor), "completed");
 }
 
-CamelTag *
+CamelNameValueArray *
 e_mail_tag_editor_get_tag_list (EMailTagEditor *editor)
 {
-       EMailTagEditorClass *class;
+       CamelNameValueArray *tag_list;
+       time_t date;
+       gchar *text = NULL;
+       GtkWidget *entry;
 
        g_return_val_if_fail (E_IS_MAIL_TAG_EDITOR (editor), NULL);
 
-       class = E_MAIL_TAG_EDITOR_GET_CLASS (editor);
-       g_return_val_if_fail (class->get_tag_list != NULL, NULL);
+       tag_list = camel_name_value_array_new ();
+
+       entry = gtk_bin_get_child (GTK_BIN (editor->priv->combo_entry));
+       if (entry)
+               text = g_strdup (gtk_entry_get_text (GTK_ENTRY (entry)));
+       camel_name_value_array_set_named (tag_list, TRUE, "follow-up", text);
+       g_free (text);
 
-       return class->get_tag_list (editor);
+       date = e_date_edit_get_time (editor->priv->target_date);
+       if (date != (time_t) -1) {
+               text = camel_header_format_date (date, 0);
+               camel_name_value_array_set_named (tag_list, TRUE, "due-by", text);
+               g_free (text);
+       } else
+               camel_name_value_array_set_named (tag_list, TRUE, "due-by", "");
+
+       if (e_mail_tag_editor_get_completed (editor)) {
+               text = camel_header_format_date (editor->priv->completed_date, 0);
+               camel_name_value_array_set_named (tag_list, TRUE, "completed-on", text);
+               g_free (text);
+       } else
+               camel_name_value_array_set_named (tag_list, TRUE, "completed-on", "");
+
+       return tag_list;
 }
 
 void
 e_mail_tag_editor_set_tag_list (EMailTagEditor *editor,
-                                CamelTag *tag_list)
+                               const CamelNameValueArray *tag_list)
 {
-       EMailTagEditorClass *class;
+       GtkWidget *child;
+       const gchar *text;
+       time_t date;
 
        g_return_if_fail (E_IS_MAIL_TAG_EDITOR (editor));
        g_return_if_fail (tag_list != NULL);
 
-       class = E_MAIL_TAG_EDITOR_GET_CLASS (editor);
-       g_return_if_fail (class->set_tag_list != NULL);
+       /* Extract the GtkEntry from the GtkComboBoxEntry. */
+       child = gtk_bin_get_child (GTK_BIN (editor->priv->combo_entry));
+
+       /* XXX This is kind of cheating.  Since we only store the
+        *     translated tag there's no sure-fire way to determine
+        *     the corresponding combo box index (e.g. the tag may
+        *     have been set while running in a different locale). */
+       text = camel_name_value_array_get_named (tag_list, TRUE, "follow-up");
+       if (text != NULL)
+               gtk_entry_set_text (GTK_ENTRY (child), text);
+
+       text = camel_name_value_array_get_named (tag_list, TRUE, "due-by");
+       if (text != NULL && *text != '\0') {
+               date = camel_header_decode_date (text, NULL);
+               e_date_edit_set_time (editor->priv->target_date, date);
+       } else
+               e_date_edit_set_time (editor->priv->target_date, (time_t) -1);
 
-       class->set_tag_list (editor, tag_list);
+       text = camel_name_value_array_get_named (tag_list, TRUE, "completed-on");
+       if (text != NULL && *text != '\0') {
+               date = camel_header_decode_date (text, NULL);
+               if (date != (time_t) 0) {
+                       e_mail_tag_editor_set_completed (editor, TRUE);
+                       editor->priv->completed_date = date;
+               }
+       }
 }
 
 void
diff --git a/src/mail/e-mail-tag-editor.h b/src/mail/e-mail-tag-editor.h
index b5c7af2..324c435 100644
--- a/src/mail/e-mail-tag-editor.h
+++ b/src/mail/e-mail-tag-editor.h
@@ -58,11 +58,6 @@ struct _EMailTagEditor {
 
 struct _EMailTagEditorClass {
        GtkDialogClass parent_class;
-
-       /* virtual methods */
-       CamelTag *      (*get_tag_list)         (EMailTagEditor *editor);
-       void            (*set_tag_list)         (EMailTagEditor *editor,
-                                                CamelTag *tags);
 };
 
 GType          e_mail_tag_editor_get_type      (void);
@@ -70,9 +65,10 @@ GtkWidget *  e_mail_tag_editor_new           (void);
 gboolean       e_mail_tag_editor_get_completed (EMailTagEditor *editor);
 void           e_mail_tag_editor_set_completed (EMailTagEditor *editor,
                                                 gboolean completed);
-CamelTag *     e_mail_tag_editor_get_tag_list  (EMailTagEditor *editor);
+CamelNameValueArray *
+               e_mail_tag_editor_get_tag_list  (EMailTagEditor *editor);
 void           e_mail_tag_editor_set_tag_list  (EMailTagEditor *editor,
-                                                CamelTag *tag_list);
+                                                const CamelNameValueArray *tag_list);
 void           e_mail_tag_editor_add_message   (EMailTagEditor *editor,
                                                 const gchar *from,
                                                 const gchar *subject);
diff --git a/src/mail/em-composer-utils.c b/src/mail/em-composer-utils.c
index 8b9334a..ee00595 100644
--- a/src/mail/em-composer-utils.c
+++ b/src/mail/em-composer-utils.c
@@ -1008,7 +1008,7 @@ composer_save_to_drafts_append_mail (AsyncContext *async_context,
                composer_save_to_drafts_cleanup,
                async_context);
 
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 
        g_object_unref (drafts_folder);
 }
@@ -1223,7 +1223,7 @@ em_utils_composer_save_to_outbox_cb (EMsgComposer *composer,
                composer_save_to_outbox_completed,
                async_context);
 
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 }
 
 typedef struct _PrintAsyncContext {
diff --git a/src/mail/em-utils.c b/src/mail/em-utils.c
index 1b55f48..6d4c762 100644
--- a/src/mail/em-utils.c
+++ b/src/mail/em-utils.c
@@ -239,8 +239,8 @@ em_utils_flag_for_followup (EMailReader *reader,
        EMailDisplay *display;
        GtkWidget *editor;
        GtkWindow *window;
-       CamelTag *tags;
-       gint i;
+       CamelNameValueArray *tags;
+       guint ii, tags_len;
 
        g_return_if_fail (E_IS_MAIL_READER (reader));
        g_return_if_fail (CAMEL_IS_FOLDER (folder));
@@ -251,10 +251,10 @@ em_utils_flag_for_followup (EMailReader *reader,
        editor = e_mail_tag_editor_new ();
        gtk_window_set_transient_for (GTK_WINDOW (editor), window);
 
-       for (i = 0; i < uids->len; i++) {
+       for (ii = 0; ii < uids->len; ii++) {
                CamelMessageInfo *info;
 
-               info = camel_folder_get_message_info (folder, uids->pdata[i]);
+               info = camel_folder_get_message_info (folder, uids->pdata[ii]);
 
                if (info == NULL)
                        continue;
@@ -264,7 +264,7 @@ em_utils_flag_for_followup (EMailReader *reader,
                        camel_message_info_get_from (info),
                        camel_message_info_get_subject (info));
 
-               camel_message_info_unref (info);
+               g_clear_object (&info);
        }
 
        /* special-case... */
@@ -275,12 +275,13 @@ em_utils_flag_for_followup (EMailReader *reader,
                message_uid = g_ptr_array_index (uids, 0);
                info = camel_folder_get_message_info (folder, message_uid);
                if (info) {
-                       tags = (CamelTag *) camel_message_info_get_user_tags (info);
+                       tags = camel_message_info_dup_user_tags (info);
 
                        if (tags)
-                               e_mail_tag_editor_set_tag_list (
-                                       E_MAIL_TAG_EDITOR (editor), tags);
-                       camel_message_info_unref (info);
+                               e_mail_tag_editor_set_tag_list (E_MAIL_TAG_EDITOR (editor), tags);
+
+                       camel_name_value_array_free (tags);
+                       g_clear_object (&info);
                }
        }
 
@@ -291,25 +292,35 @@ em_utils_flag_for_followup (EMailReader *reader,
        if (tags == NULL)
                goto exit;
 
+       tags_len = camel_name_value_array_get_length (tags);
+
        camel_folder_freeze (folder);
-       for (i = 0; i < uids->len; i++) {
+       for (ii = 0; ii < uids->len; ii++) {
                CamelMessageInfo *info;
-               CamelTag *iter;
+               guint jj;
 
-               info = camel_folder_get_message_info (folder, uids->pdata[i]);
+               info = camel_folder_get_message_info (folder, uids->pdata[ii]);
 
                if (info == NULL)
                        continue;
 
-               for (iter = tags; iter != NULL; iter = iter->next)
-                       camel_message_info_set_user_tag (
-                               info, iter->name, iter->value);
+               camel_message_info_freeze_notifications (info);
+
+               for (jj = 0; jj < tags_len; jj++) {
+                       const gchar *name = NULL, *value = NULL;
+
+                       if (!camel_name_value_array_get (tags, jj, &name, &value))
+                               continue;
+
+                       camel_message_info_set_user_tag (info, name, value);
+               }
 
-               camel_message_info_unref (info);
+               camel_message_info_thaw_notifications (info);
+               g_clear_object (&info);
        }
 
        camel_folder_thaw (folder);
-       camel_tag_list_free (&tags);
+       camel_name_value_array_free (tags);
 
        display = e_mail_reader_get_mail_display (reader);
        e_mail_display_reload (display);
@@ -346,7 +357,7 @@ em_utils_flag_for_followup_clear (GtkWindow *parent,
                        camel_message_info_set_user_tag (mi, "follow-up", NULL);
                        camel_message_info_set_user_tag (mi, "due-by", NULL);
                        camel_message_info_set_user_tag (mi, "completed-on", NULL);
-                       camel_message_info_unref (mi);
+                       g_clear_object (&mi);
                }
        }
 
@@ -386,7 +397,7 @@ em_utils_flag_for_followup_completed (GtkWindow *parent,
                        tag = camel_message_info_get_user_tag (mi, "follow-up");
                        if (tag && tag[0])
                                camel_message_info_set_user_tag (mi, "completed-on", now);
-                       camel_message_info_unref (mi);
+                       g_clear_object (&mi);
                }
        }
 
@@ -711,7 +722,7 @@ em_utils_selection_set_uidlist (GtkSelectionData *selection_data,
                                g_free (folder_uri);
                        }
 
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                }
        } else {
                folder_uri = e_mail_folder_uri_from_folder (folder);
@@ -882,8 +893,7 @@ em_utils_build_export_basename (CamelFolder *folder,
 
        basename = g_strdup_printf ("%s_%s%s", datetmp, subject, extension);
 
-       if (info != NULL)
-               camel_message_info_unref (info);
+       g_clear_object (&info);
 
        return basename;
 }
diff --git a/src/mail/importers/mail-importer.c b/src/mail/importers/mail-importer.c
index 0c02121..55a8873 100644
--- a/src/mail/importers/mail-importer.c
+++ b/src/mail/importers/mail-importer.c
@@ -134,7 +134,7 @@ import_mbox_add_message (CamelFolder *folder,
        camel_folder_append_message_sync (
                folder, msg, info, NULL,
                cancellable, error);
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 }
 
 static void
@@ -357,7 +357,7 @@ import_kmail_folder (struct _import_mbox_msg *m,
                                camel_folder_append_message_sync (
                                        folder, msg, info, NULL,
                                        cancellable, error);
-                               camel_message_info_unref (info);
+                               g_clear_object (&info);
                                g_object_unref (msg);
                                g_object_unref (mp);
                        } else {
diff --git a/src/mail/message-list.c b/src/mail/message-list.c
index 58890b5..8e88dc2 100644
--- a/src/mail/message-list.c
+++ b/src/mail/message-list.c
@@ -520,8 +520,7 @@ regen_data_unref (RegenData *regen_data)
                        length = regen_data->summary->len;
 
                        for (ii = 0; ii < length; ii++)
-                               camel_message_info_unref (
-                                       regen_data->summary->pdata[ii]);
+                               g_clear_object (&regen_data->summary->pdata[ii]);
 
                        g_ptr_array_free (regen_data->summary, TRUE);
                }
@@ -1664,7 +1663,8 @@ add_all_labels_foreach (ETreeModel *etm,
        CamelMessageInfo *msg_info;
        const gchar *old_label;
        gchar *new_label;
-       const CamelFlag *flag;
+       const CamelNamedFlags *flags;
+       guint ii, len;
 
        if (!etm)
                msg_info = (CamelMessageInfo *) path;
@@ -1672,8 +1672,12 @@ add_all_labels_foreach (ETreeModel *etm,
                msg_info = ((GNode *) path)->data;
        g_return_val_if_fail (msg_info != NULL, FALSE);
 
-       for (flag = camel_message_info_get_user_flags (msg_info); flag; flag = flag->next)
-               add_label_if_known (ld, flag->name);
+       camel_message_info_property_lock (msg_info);
+       flags = camel_message_info_get_user_flags (msg_info);
+       len = camel_named_flags_get_length (flags);
+
+       for (ii = 0; ii < len; ii++)
+               add_label_if_known (ld, camel_named_flags_get (flags, ii));
 
        old_label = camel_message_info_get_user_tag (msg_info, "label");
        if (old_label != NULL) {
@@ -1684,6 +1688,8 @@ add_all_labels_foreach (ETreeModel *etm,
                add_label_if_known (ld, new_label);
        }
 
+       camel_message_info_property_unlock (msg_info);
+
        return FALSE;
 }
 
@@ -3170,6 +3176,7 @@ message_list_value_at (ETreeModel *tree_model,
 {
        MessageList *message_list;
        CamelMessageInfo *msg_info;
+       gpointer result;
 
        message_list = MESSAGE_LIST (tree_model);
 
@@ -3180,7 +3187,11 @@ message_list_value_at (ETreeModel *tree_model,
        msg_info = ((GNode *) path)->data;
        g_return_val_if_fail (msg_info != NULL, NULL);
 
-       return ml_tree_value_at_ex (tree_model, path, col, msg_info, message_list);
+       camel_message_info_property_lock (msg_info);
+       result = ml_tree_value_at_ex (tree_model, path, col, msg_info, message_list);
+       camel_message_info_property_unlock (msg_info);
+
+       return result;
 }
 
 static gpointer
@@ -3786,8 +3797,7 @@ clear_info (gchar *key,
             GNode *node,
             MessageList *message_list)
 {
-       camel_message_info_unref (node->data);
-       node->data = NULL;
+       g_clear_object (&node->data);
 }
 
 static void
@@ -4105,7 +4115,7 @@ ml_uid_nodemap_insert (MessageList *message_list,
        flags = camel_message_info_get_flags (info);
        date = camel_message_info_get_date_received (info);
 
-       camel_message_info_ref (info);
+       g_object_ref (info);
        g_hash_table_insert (message_list->uid_nodemap, (gpointer) uid, node);
 
        /* Track the latest seen and unseen messages shown, used in
@@ -4153,7 +4163,7 @@ ml_uid_nodemap_remove (MessageList *message_list,
        }
 
        g_hash_table_remove (message_list->uid_nodemap, uid);
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 
        g_object_unref (folder);
 }
@@ -4551,8 +4561,8 @@ mail_folder_hide_by_flag (CamelFolder *folder,
                else
                        camel_folder_change_info_change_uid (
                                newchanges, changes->uid_changed->pdata[i]);
-               if (info)
-                       camel_message_info_unref (info);
+
+               g_clear_object (&info);
        }
 
        if (newchanges->uid_added->len > 0 || newchanges->uid_removed->len > 0) {
@@ -5487,20 +5497,25 @@ cmp_array_uids (gconstpointer a,
                struct sort_column_data *scol = g_ptr_array_index (sort_data->sort_columns, i);
 
                if (md1->values->len <= i) {
+                       camel_message_info_property_lock (md1->mi);
                        v1 = ml_tree_value_at_ex (
                                NULL, NULL,
                                scol->col->spec->compare_col,
                                md1->mi, sort_data->message_list);
+                       camel_message_info_property_unlock (md1->mi);
                        g_ptr_array_add (md1->values, v1);
                } else {
                        v1 = g_ptr_array_index (md1->values, i);
                }
 
                if (md2->values->len <= i) {
+                       camel_message_info_property_lock (md2->mi);
                        v2 = ml_tree_value_at_ex (
                                NULL, NULL,
                                scol->col->spec->compare_col,
                                md2->mi, sort_data->message_list);
+                       camel_message_info_property_unlock (md2->mi);
+
                        g_ptr_array_add (md2->values, v2);
                } else {
                        v2 = g_ptr_array_index (md2->values, i);
@@ -5541,7 +5556,7 @@ free_message_info_data (gpointer uid,
                g_ptr_array_free (data->values, TRUE);
        }
 
-       camel_message_info_unref (data->mi);
+       g_clear_object (&data->mi);
        g_free (data);
 }
 
@@ -5717,7 +5732,7 @@ message_list_regen_tweak_search_results (MessageList *message_list,
                        search_results,
                        (gpointer) camel_pstring_strdup (uid));
 
-       camel_message_info_unref (info);
+       g_clear_object (&info);
 }
 
 static void
diff --git a/src/modules/mdn/evolution-mdn.c b/src/modules/mdn/evolution-mdn.c
index 1a8cbad..d5e01b3 100644
--- a/src/modules/mdn/evolution-mdn.c
+++ b/src/modules/mdn/evolution-mdn.c
@@ -79,9 +79,7 @@ G_DEFINE_DYNAMIC_TYPE (EMdn, e_mdn, E_TYPE_EXTENSION)
 static void
 mdn_context_free (MdnContext *context)
 {
-       if (context->info != NULL)
-               camel_message_info_unref (context->info);
-
+       g_clear_object (&context->info);
        g_object_unref (context->source);
        g_object_unref (context->reader);
        g_object_unref (context->folder);
@@ -416,7 +414,7 @@ mdn_notify_sender (ESource *identity_source,
                NULL, (GAsyncReadyCallback) mdn_receipt_done,
                g_object_ref (session));
 
-       camel_message_info_unref (receipt_info);
+       g_clear_object (&receipt_info);
 
        g_free (message_date);
        g_free (message_id);
@@ -437,8 +435,7 @@ mdn_notify_action_cb (GtkAction *action,
                MDN_SENDING_MODE_MANUAL);
 
        /* Make sure the newly-added user flag gets saved. */
-       camel_message_info_unref (context->info);
-       context->info = NULL;
+       g_clear_object (&context->info);
 }
 
 static void
@@ -526,7 +523,7 @@ mdn_message_loaded_cb (EMailReader *reader,
                context->reader = g_object_ref (reader);
                context->folder = g_object_ref (folder);
                context->message = g_object_ref (message);
-               context->info = camel_message_info_ref (info);
+               context->info = g_object_ref (info);
 
                context->notify_to = notify_to;
                notify_to = NULL;
@@ -559,9 +556,7 @@ mdn_message_loaded_cb (EMailReader *reader,
        g_object_unref (source);
 
 exit:
-       if (info != NULL)
-               camel_message_info_unref (info);
-
+       g_clear_object (&info);
        g_clear_object (&folder);
        g_free (notify_to);
 }
@@ -619,9 +614,7 @@ mdn_message_seen_cb (EMailReader *reader,
        g_object_unref (source);
 
 exit:
-       if (info != NULL)
-               camel_message_info_unref (info);
-
+       g_clear_object (&info);
        g_clear_object (&folder);
        g_free (notify_to);
 }
diff --git a/src/plugins/dbx-import/dbx-importer.c b/src/plugins/dbx-import/dbx-importer.c
index 0fe66dc..2c747b8 100644
--- a/src/plugins/dbx-import/dbx-importer.c
+++ b/src/plugins/dbx-import/dbx-importer.c
@@ -681,7 +681,7 @@ dbx_import_file (DbxImporter *m)
                success = camel_folder_append_message_sync (
                        folder, msg, info, NULL,
                        cancellable, &m->base.error);
-               camel_message_info_unref (info);
+               g_clear_object (&info);
                g_object_unref (msg);
 
                if (!success) {
diff --git a/src/plugins/pst-import/pst-importer.c b/src/plugins/pst-import/pst-importer.c
index fed8493..00d7376 100644
--- a/src/plugins/pst-import/pst-importer.c
+++ b/src/plugins/pst-import/pst-importer.c
@@ -1397,7 +1397,7 @@ pst_process_email (PstImporter *m,
        /* FIXME Not passing a GCancellable or GError here. */
        success = camel_folder_append_message_sync (
                m->folder, msg, info, NULL, NULL, NULL);
-       camel_message_info_unref (info);
+       g_clear_object (&info);
        g_object_unref (msg);
 
        /* FIXME Not passing a GCancellable or GError here. */
diff --git a/src/plugins/templates/e-templates-store.c b/src/plugins/templates/e-templates-store.c
index 40b092f..b8668ee 100644
--- a/src/plugins/templates/e-templates-store.c
+++ b/src/plugins/templates/e-templates-store.c
@@ -467,7 +467,7 @@ tmpl_folder_data_update_sync (TmplFolderData *tfd,
                                changed = tmpl_folder_data_remove_message (tfd, camel_message_info_get_uid 
(info)) || changed;
                        }
 
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                }
        }
 
@@ -477,7 +477,7 @@ tmpl_folder_data_update_sync (TmplFolderData *tfd,
                info = camel_folder_summary_get (tfd->folder->summary, uid);
                if (info) {
                        changed = tmpl_folder_data_change_message (tfd, info) || changed;
-                       camel_message_info_unref (info);
+                       g_clear_object (&info);
                }
        }
 
diff --git a/src/plugins/templates/templates.c b/src/plugins/templates/templates.c
index cdd6319..4a20077 100644
--- a/src/plugins/templates/templates.c
+++ b/src/plugins/templates/templates.c
@@ -1183,7 +1183,7 @@ save_template_async_data_free (gpointer ptr)
                g_clear_object (&sta->composer);
                g_clear_object (&sta->session);
                g_clear_object (&sta->message);
-               camel_message_info_unref (sta->info);
+               g_clear_object (&sta->info);
                g_free (sta->templates_folder_uri);
                g_free (sta);
        }



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