diff options
author | Not Zed <NotZed@Ximian.com> | 2005-01-19 16:38:55 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2005-01-19 16:38:55 +0800 |
commit | a3af35f7b66f27331c9f20d80d12a1173760313c (patch) | |
tree | dcfbd2b7aef7589220d5725bf9d936e4e50ab659 /mail/em-composer-utils.c | |
parent | c1cb4235dbac007329e627a7d5132fe0d4188934 (diff) | |
download | gsoc2013-evolution-a3af35f7b66f27331c9f20d80d12a1173760313c.tar.gz gsoc2013-evolution-a3af35f7b66f27331c9f20d80d12a1173760313c.tar.zst gsoc2013-evolution-a3af35f7b66f27331c9f20d80d12a1173760313c.zip |
** See bug #66943.
2005-01-19 Not Zed <NotZed@Ximian.com>
** See bug #66943.
* em-composer-utils.c (save_draft_done): check if the
editor_engine is still there before trying to invoke a method on
it.
(em_utils_composer_save_draft_cb): grab resources before getting
the folder, so the composer doesn't go away.
svn path=/trunk/; revision=28445
Diffstat (limited to 'mail/em-composer-utils.c')
-rw-r--r-- | mail/em-composer-utils.c | 47 |
1 files changed, 30 insertions, 17 deletions
diff --git a/mail/em-composer-utils.c b/mail/em-composer-utils.c index 5653107082..e7b0a7aa35 100644 --- a/mail/em-composer-utils.c +++ b/mail/em-composer-utils.c @@ -468,6 +468,7 @@ em_utils_composer_send_cb (EMsgComposer *composer, gpointer user_data) struct _save_draft_info { struct emcs_t *emcs; EMsgComposer *composer; + CamelMessageInfo *info; int quit; }; @@ -481,10 +482,12 @@ save_draft_done (CamelFolder *folder, CamelMimeMessage *msg, CamelMessageInfo *i if (!ok) goto done; - - CORBA_exception_init (&ev); - GNOME_GtkHTML_Editor_Engine_runCommand (sdi->composer->editor_engine, "saved", &ev); - CORBA_exception_free (&ev); + + if (sdi->composer->editor_engine) { + CORBA_exception_init (&ev); + GNOME_GtkHTML_Editor_Engine_runCommand (sdi->composer->editor_engine, "saved", &ev); + CORBA_exception_free (&ev); + } if ((emcs = sdi->emcs) == NULL) { emcs = emcs_new (); @@ -555,8 +558,22 @@ em_utils_composer_save_draft_cb (EMsgComposer *composer, int quit, gpointer user CamelMimeMessage *msg; CamelMessageInfo *info; EAccount *account; - + + /* need to get stuff from the composer here, since it could + * get destroyed while we're in mail_msg_wait() a little lower + * down, waiting for the folder to open */ + + g_object_ref(composer); + msg = e_msg_composer_get_message_draft (composer); account = e_msg_composer_get_preferred_account (composer); + + sdi = g_malloc(sizeof(struct _save_draft_info)); + sdi->composer = composer; + sdi->emcs = user_data; + if (sdi->emcs) + emcs_ref(sdi->emcs); + sdi->quit = quit; + if (account && account->drafts_folder_uri && strcmp (account->drafts_folder_uri, default_drafts_folder_uri) != 0) { int id; @@ -565,8 +582,14 @@ em_utils_composer_save_draft_cb (EMsgComposer *composer, int quit, gpointer user mail_msg_wait (id); if (!folder) { - if (e_error_run((GtkWindow *)composer, "mail:ask-default-drafts", NULL) != GTK_RESPONSE_YES) + if (e_error_run((GtkWindow *)composer, "mail:ask-default-drafts", NULL) != GTK_RESPONSE_YES) { + g_object_unref(composer); + camel_object_unref(msg); + if (sdi->emcs) + emcs_unref(sdi->emcs); + g_free(sdi); return; + } folder = drafts_folder; camel_object_ref (drafts_folder); @@ -576,19 +599,9 @@ em_utils_composer_save_draft_cb (EMsgComposer *composer, int quit, gpointer user camel_object_ref (folder); } - msg = e_msg_composer_get_message_draft (composer); - info = camel_message_info_new(NULL); camel_message_info_set_flags(info, CAMEL_MESSAGE_DRAFT | CAMEL_MESSAGE_SEEN, ~0); - - sdi = g_malloc (sizeof (struct _save_draft_info)); - sdi->composer = composer; - g_object_ref (composer); - sdi->emcs = user_data; - if (sdi->emcs) - emcs_ref (sdi->emcs); - sdi->quit = quit; - + mail_append_mail (folder, msg, info, save_draft_done, sdi); camel_object_unref (folder); camel_object_unref (msg); |