diff options
Diffstat (limited to 'composer/e-msg-composer.c')
-rw-r--r-- | composer/e-msg-composer.c | 32 |
1 files changed, 22 insertions, 10 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c index 4996b9fa3c..e5d710ceaa 100644 --- a/composer/e-msg-composer.c +++ b/composer/e-msg-composer.c @@ -1023,13 +1023,14 @@ struct _AutosaveManager { static AutosaveManager *am = NULL; -static void +static gboolean autosave_save_draft (EMsgComposer *composer) { CamelMimeMessage *msg; CamelStream *stream; char *file; gint fd; + gboolean success = TRUE; fd = composer->autosave_fd; file = composer->autosave_file; @@ -1037,7 +1038,7 @@ autosave_save_draft (EMsgComposer *composer) if (fd == -1) { e_notice (GTK_WINDOW (composer), GNOME_MESSAGE_BOX_ERROR, _("Error accessing file: %s"), file); - return; + return FALSE; } msg = e_msg_composer_get_message_draft (composer); @@ -1045,19 +1046,19 @@ autosave_save_draft (EMsgComposer *composer) if (msg == NULL) { e_notice (GTK_WINDOW (composer), GNOME_MESSAGE_BOX_ERROR, _("Unable to retrieve message from editor")); - return; + return FALSE; } if (lseek (fd, (off_t)0, SEEK_SET) == -1) { e_notice (GTK_WINDOW (composer), GNOME_MESSAGE_BOX_ERROR, _("Unable to seek on file: %s\n%s"), file, strerror(errno)); - return; + return FALSE; } if (ftruncate (fd, (off_t)0) == -1) { e_notice (GTK_WINDOW (composer), GNOME_MESSAGE_BOX_ERROR, _("Unable to truncate file: %s\n%s"), file, strerror(errno)); - return; + return FALSE; } /* this does an lseek so we don't have to */ @@ -1066,11 +1067,14 @@ autosave_save_draft (EMsgComposer *composer) || camel_stream_flush((CamelStream *)stream) == -1) { e_notice (GTK_WINDOW (composer), GNOME_MESSAGE_BOX_ERROR, _("Error autosaving message: %s\n %s"), file, strerror(errno)); - + + success = FALSE; } /* set the fd to -1 in the stream so camel doesn't close it we want to keep it open */ CAMEL_STREAM_FS (stream)->fd = -1; camel_object_unref((CamelObject *)stream); + + return success; } static EMsgComposer * @@ -1205,8 +1209,10 @@ autosave_manager_start (AutosaveManager *am) static void autosave_manager_stop (AutosaveManager *am) { - if (am->id) + if (am->id) { gtk_timeout_remove (am->id); + am->id = 0; + } } AutosaveManager * @@ -1233,8 +1239,10 @@ autosave_manager_register (AutosaveManager *am, EMsgComposer *composer) key = g_basename (composer->autosave_file); g_hash_table_insert (am->table, key, composer); if (am->ask) { + /* keep recursion out of our bedrooms. */ am->ask = FALSE; autosave_manager_query_load_orphans (am, composer); + am->ask = TRUE; } } @@ -1246,8 +1254,12 @@ autosave_manager_unregister (AutosaveManager *am, EMsgComposer *composer) { g_hash_table_remove (am->table, g_basename (composer->autosave_file)); + /* only remove the file if we can successfully save it */ + /* FIXME this test could probably be more efficient */ + if (autosave_save_draft (composer)) { + unlink (composer->autosave_file); + } close (composer->autosave_fd); - unlink (composer->autosave_file); g_free (composer->autosave_file); if (g_hash_table_size (am->table) == 0) @@ -1859,6 +1871,8 @@ destroy (GtkObject *object) composer = E_MSG_COMPOSER (object); + autosave_manager_unregister (am, composer); + CORBA_exception_init (&ev); if (composer->config_db) { @@ -1895,8 +1909,6 @@ destroy (GtkObject *object) g_free (composer->charset); - autosave_manager_unregister (am, composer); - CORBA_exception_init (&ev); if (composer->persist_stream_interface != CORBA_OBJECT_NIL) { |