changeset 10650:e9f4efacf692 HEAD

mdbox saving: Fallback to using non-exact mail size if exact isn't available. The size is used only to check if it would make mdbox file become too large.
author Timo Sirainen <tss@iki.fi>
date Sat, 06 Feb 2010 23:22:04 +0200
parents cfe7d639fa03
children b1597605c3ef
files src/lib-storage/index/dbox-multi/mdbox-save.c
diffstat 1 files changed, 10 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/src/lib-storage/index/dbox-multi/mdbox-save.c	Sat Feb 06 21:07:44 2010 +0200
+++ b/src/lib-storage/index/dbox-multi/mdbox-save.c	Sat Feb 06 23:22:04 2010 +0200
@@ -98,8 +98,16 @@
 	uoff_t mail_size, append_offset;
 
 	/* get the size of the mail to be saved, if possible */
-	if (i_stream_get_size(input, TRUE, &mail_size) <= 0)
-		mail_size = 0;
+	if (i_stream_get_size(input, TRUE, &mail_size) <= 0) {
+		const struct stat *st;
+
+		/* we couldn't find out the exact size. fallback to non-exact,
+		   maybe it'll give something useful. the mail size is used
+		   only to figure out if it's causing mdbox file to grow
+		   too large. */
+		st = i_stream_stat(input, FALSE);
+		mail_size = st->st_size > 0 ? st->st_size : 0;
+	}
 	if (dbox_map_append_next(ctx->append_ctx, mail_size,
 				 &ctx->cur_file_append,
 				 &ctx->ctx.cur_output) < 0) {