diff options
-rw-r--r-- | filter/ChangeLog | 10 | ||||
-rw-r--r-- | filter/filter-driver.c | 15 |
2 files changed, 21 insertions, 4 deletions
diff --git a/filter/ChangeLog b/filter/ChangeLog index 8ddc892746..832da213e6 100644 --- a/filter/ChangeLog +++ b/filter/ChangeLog @@ -1,7 +1,17 @@ 2000-11-15 Jeffrey Stedfast <fejj@helixcode.com> + * filter-driver.c (filter_driver_filter_folder): Sync here + instead. + (filter_driver_filter_mbox): And here too. + (filter_driver_finalise): Don't sync here afterall - it's more + preferable to sync right after processing. + +2000-11-15 Jeffrey Stedfast <fejj@helixcode.com> + * filter-driver.c (filter_driver_finalise): Sync the defaultfolder. + (filter_driver_filter_folder): Sync here instead. + (filter_driver_filter_mbox): And here too. 2000-11-13 Jeffrey Stedfast <fejj@helixcode.com> diff --git a/filter/filter-driver.c b/filter/filter-driver.c index 9385e6f098..fca858d187 100644 --- a/filter/filter-driver.c +++ b/filter/filter-driver.c @@ -206,11 +206,9 @@ filter_driver_finalise (GtkObject *obj) g_hash_table_destroy (p->globals); gtk_object_unref (GTK_OBJECT (p->eval)); - - if (p->defaultfolder) { - camel_folder_sync (p->defaultfolder, FALSE, NULL); + + if (p->defaultfolder) camel_object_unref (CAMEL_OBJECT (p->defaultfolder)); - } g_free (p); @@ -602,6 +600,7 @@ filter_driver_log (FilterDriver *driver, enum filter_log_t status, const char *d void filter_driver_filter_mbox (FilterDriver *driver, const char *mbox, const char *source, CamelException *ex) { + struct _FilterDriverPrivate *p = _PRIVATE (driver); CamelMimeParser *mp = NULL; char *source_url = NULL; int fd = -1; @@ -656,6 +655,10 @@ filter_driver_filter_mbox (FilterDriver *driver, const char *mbox, const char *s /* skip over the FROM_END state */ camel_mime_parser_step (mp, 0, 0); } + + if (p->defaultfolder) + camel_folder_sync (p->defaultfolder, FALSE, ex); + fail: g_free (source_url); if (fd != -1) @@ -669,6 +672,7 @@ void filter_driver_filter_folder (FilterDriver *driver, CamelFolder *folder, const char *source, GPtrArray *uids, gboolean remove, CamelException *ex) { + struct _FilterDriverPrivate *p = _PRIVATE (driver); int i; int freeuids = FALSE; CamelMimeMessage *message; @@ -714,6 +718,9 @@ filter_driver_filter_folder (FilterDriver *driver, CamelFolder *folder, const ch if (freeuids) camel_folder_free_uids (folder, uids); + if (p->defaultfolder) + camel_folder_sync (p->defaultfolder, FALSE, ex); + g_free (source_url); } |