Mercurial > dovecot > core-2.2
view src/lib-storage/index/index-save.c @ 29:e9375147c0cb HEAD
Added write_full() which is a simple wrapper around write() meant for
writing into files.
When there's too much deleted data in index files, they're now compressed
when the index is being opened.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Mon, 26 Aug 2002 02:46:59 +0300 |
parents | 1b34ec11fff8 |
children | d493b9cc265e |
line wrap: on
line source
/* Copyright (C) 2002 Timo Sirainen */ #include "lib.h" #include "iobuffer.h" #include "write-full.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) { unsigned int i, cr; cr = *last_cr ? -1 : -2; for (i = 0; i < size; i++) { if (data[i] == '\r') cr = i; else if (data[i] == '\n' && cr != i-1) { /* missing CR */ if (write_full(fd, data, i) < 0) return FALSE; if (write_full(fd, "\r", 1) < 0) 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_full(fd, data, size) < 0; } 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; }