diff options
Diffstat (limited to 'mailbox')
-rw-r--r-- | mailbox/attachment.c | 3 | ||||
-rw-r--r-- | mailbox/filter.c | 16 | ||||
-rw-r--r-- | mailbox/filter_iconv.c | 1 | ||||
-rw-r--r-- | mailbox/mutil.c | 4 |
4 files changed, 15 insertions, 9 deletions
diff --git a/mailbox/attachment.c b/mailbox/attachment.c index 26430fc93..8f02b4fbd 100644 --- a/mailbox/attachment.c +++ b/mailbox/attachment.c @@ -313,7 +313,8 @@ mu_message_save_attachment (mu_message_t msg, const char *filename, content_encoding = "7bit"; ret = mu_filter_create (&info->stream, istream, content_encoding, - MU_FILTER_DECODE, MU_STREAM_READ); + MU_FILTER_DECODE, + MU_STREAM_READ | MU_STREAM_NO_CLOSE); free (content_encoding_mem); } } diff --git a/mailbox/filter.c b/mailbox/filter.c index 6a2e4d11d..e7ad3d20b 100644 --- a/mailbox/filter.c +++ b/mailbox/filter.c @@ -46,6 +46,8 @@ static void filter_destroy (mu_stream_t stream) { mu_filter_t filter = mu_stream_get_owner (stream); + if (!(stream->flags & MU_STREAM_NO_CLOSE)) + mu_stream_destroy (&filter->stream, mu_stream_get_owner (filter->stream)); if (filter->_destroy) filter->_destroy (filter); if (filter->property) @@ -165,7 +167,7 @@ mu_filter_get_list (mu_list_t *plist) int mu_filter_create (mu_stream_t *pstream, mu_stream_t stream, const char *name, - int type, int direction) + int type, int flags) { mu_iterator_t iterator = NULL; mu_filter_record_t filter_record = NULL; @@ -204,14 +206,12 @@ mu_filter_create (mu_stream_t *pstream, mu_stream_t stream, const char *name, if (found) { - int flags = 0; mu_filter_t filter; filter = calloc (1, sizeof (*filter)); if (filter == NULL) return ENOMEM; - mu_stream_get_flags (stream, &flags); status = mu_stream_create (pstream, flags | MU_STREAM_NO_CHECK, filter); if (status != 0) { @@ -221,7 +221,11 @@ mu_filter_create (mu_stream_t *pstream, mu_stream_t stream, const char *name, filter->stream = stream; filter->filter_stream = *pstream; - filter->direction = (direction == 0) ? MU_STREAM_READ : direction; + filter->direction = (flags == 0) ? MU_STREAM_READ + : (flags + & (MU_STREAM_READ | + MU_STREAM_WRITE | + MU_STREAM_RDWR)); filter->type = type; status = mu_property_create (&(filter->property), filter); @@ -249,8 +253,8 @@ mu_filter_create (mu_stream_t *pstream, mu_stream_t stream, const char *name, } } - mu_stream_set_open (*pstream, filter_open, filter ); - mu_stream_set_close (*pstream, filter_close, filter ); + mu_stream_set_open (*pstream, filter_open, filter); + mu_stream_set_close (*pstream, filter_close, filter); mu_stream_set_read (*pstream, filter_read, filter); mu_stream_set_readline (*pstream, filter_readline, filter); mu_stream_set_write (*pstream, filter_write, filter); diff --git a/mailbox/filter_iconv.c b/mailbox/filter_iconv.c index c09d4631b..e47c5db25 100644 --- a/mailbox/filter_iconv.c +++ b/mailbox/filter_iconv.c @@ -114,6 +114,7 @@ _icvt_destroy (mu_stream_t stream) s->buf = NULL; if (s->cd != (iconv_t) -1) iconv_close (s->cd); + free (s); } static int _icvt_read (mu_stream_t stream, char *optr, size_t osize, diff --git a/mailbox/mutil.c b/mailbox/mutil.c index 19dbcc1c8..70bce589e 100644 --- a/mailbox/mutil.c +++ b/mailbox/mutil.c @@ -1329,8 +1329,8 @@ mu_decode_filter (mu_stream_t *pfilter, mu_stream_t input, { mu_stream_t cvt; status = mu_filter_iconv_create (&cvt, filter, fromcode, tocode, - MU_STREAM_NO_CLOSE, - mu_default_fallback_mode); + MU_STREAM_NO_CLOSE, + mu_default_fallback_mode); if (status == 0) { if (mu_stream_open (cvt)) |