Mercurial > dovecot > original-hg > dovecot-1.2
view src/lib-storage/index/index-save.c @ 5:1b34ec11fff8 HEAD
Message data is parsed in blocks (no longer entirely mmap()ed). Several
IOBuffer changes. All mixed signed/unsigned comparisions were fixed so code
can now be compiled with gcc's -W flag. mbox support is broken currently,
and there's most likely several other problems too.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Thu, 22 Aug 2002 01:10:20 +0300 |
parents | 3b1985cbc908 |
children | e9375147c0cb |
line wrap: on
line source
/* Copyright (C) 2002 Timo Sirainen */ #include "lib.h" #include "iobuffer.h" #include "index-storage.h" #include <stdlib.h> #include <unistd.h> static int write_with_crlf(int fd, const unsigned char *data, unsigned int size, unsigned int *last_cr) { int i, cr; i_assert(size < INT_MAX); cr = *last_cr ? -1 : -2; for (i = 0; i < (int)size; i++) { if (data[i] == '\r') cr = i; else if (data[i] == '\n' && cr != i-1) { /* missing CR */ if (write(fd, data, (size_t) i) != i) return FALSE; if (write(fd, "\r", 1) != 1) return FALSE; /* skip the data so far. \n is left into buffer and we'll continue from the next character. */ data += i; size -= i; i = 0; cr = -2; } } return write(fd, data, size) == i; } int index_storage_save_into_fd(MailStorage *storage, int fd, const char *path, IOBuffer *buf, size_t data_size) { unsigned char *data; unsigned int size, last_cr; int ret; last_cr = FALSE; while ((ret = io_buffer_read(buf)) != 0) { if (ret == -1) { mail_storage_set_critical(storage, "Error reading mail: %m"); return FALSE; } /* -2 = buffer full, ignore it since we're just emptying it.. */ data = io_buffer_get_data(buf, &size); if (size == 0) continue; if (size > data_size) size = data_size; data_size -= size; if (write_with_crlf(fd, data, size, &last_cr)) { mail_storage_set_critical(storage, "write() failed " "for file %s: %m", path); return FALSE; } io_buffer_skip(buf, size); } return TRUE; }