Mercurial > dovecot > original-hg > dovecot-1.2
view src/lib-index/mbox/mbox-sync.c @ 160:ff05b320482c HEAD
Bigger changes.. full_virtual_size was removed from index record and
MessagePart caching is now forced. Also added per-message flags, including
binary flags which can be used to check if CRs need to be inserted into
message data.
Added mbox-rewrite support which can be used to write out mbox file with
updated flags. This still has the problem of being able to read changed
custom flags, that'll require another bigger change.
There's also several other mostly mbox related fixes.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Fri, 06 Sep 2002 16:43:58 +0300 |
parents | a6d7ed739926 |
children | ed0d5b17c7a4 |
line wrap: on
line source
/* Copyright (C) 2002 Timo Sirainen */ #include "lib.h" #include "iobuffer.h" #include "mbox-index.h" #include "mail-index-util.h" #include <stdlib.h> #include <unistd.h> #include <fcntl.h> #include <sys/stat.h> static uoff_t get_indexed_mbox_size(MailIndex *index) { MailIndexRecord *rec, *prev; uoff_t offset; if (index->lock_type == MAIL_LOCK_UNLOCK) { if (!mail_index_set_lock(index, MAIL_LOCK_SHARED)) return 0; } /* get the last record */ rec = index->header->messages_count == 0 ? NULL : index->lookup(index, index->header->messages_count); if (rec == NULL) { rec = prev = index->lookup(index, 1); while (rec != NULL) { prev = rec; rec = index->next(index, rec); } rec = prev; } offset = 0; if (rec != NULL) { /* get the offset + size of last message, which tells the last known mbox file size */ if (mbox_mail_get_start_offset(index, rec, &offset)) offset += rec->header_size + rec->body_size; } if (index->lock_type == MAIL_LOCK_SHARED) (void)mail_index_set_lock(index, MAIL_LOCK_UNLOCK); if (offset > OFF_T_MAX) { /* too large to fit in off_t */ return 0; } return offset; } int mbox_index_sync(MailIndex *index) { struct stat st; uoff_t filesize; i_assert(index->lock_type != MAIL_LOCK_SHARED); if (stat(index->mbox_path, &st) == -1) { index_set_error(index, "stat() failed with mbox file %s: %m", index->mbox_path); return FALSE; } filesize = st.st_size; if (index->file_sync_stamp == st.st_mtime && (index->mbox_size == filesize || index->mbox_size == filesize-1 || index->mbox_size == filesize-2)) return TRUE; /* problem .. index->mbox_size points to data after the last message. that should be \n, \r\n, or end of file. modify filesize accordingly to allow any of the extra 0-2 bytes. Don't actually bother to open the file and verify it, it'd just slow things.. */ index->mbox_size = get_indexed_mbox_size(index); if (filesize == index->mbox_size+1 || filesize == index->mbox_size+2) filesize = index->mbox_size; if (index->file_sync_stamp == 0 && index->mbox_size == filesize) { /* just opened the mailbox, and the file size is same as we expected. don't bother checking it any further. */ index->file_sync_stamp = st.st_mtime; return TRUE; } index->file_sync_stamp = st.st_mtime; /* file has changed, scan through the whole mbox */ return mbox_index_fsck(index); }