mail-index.c revision 4a09c57f1c66b4a8880bcc12b567bb42c3549f52
/* Copyright (c) 2003-2009 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "ioloop.h"
#include "array.h"
#include "buffer.h"
#include "eacces-error.h"
#include "hash.h"
#include "str-sanitize.h"
#include "mmap-util.h"
#include "nfs-workarounds.h"
#include "read-full.h"
#include "write-full.h"
#include "mail-index-private.h"
#include "mail-index-view-private.h"
#include "mail-index-sync-private.h"
#include "mail-index-modseq.h"
#include "mail-transaction-log.h"
#include "mail-cache.h"
#include <stdio.h>
#include <stddef.h>
#include <time.h>
struct mail_index_module_register mail_index_module_register = { 0 };
{
struct mail_index *index;
128, 2, 1);
return index;
}
{
}
{
}
{
}
{
struct mail_index_registered_ext rext;
if (default_record_size != 0 && default_record_align == 0) {
i_panic("mail_index_ext_register(%s): "
"Invalid record alignment", name);
}
return ext_id;
}
{
const struct mail_index_registered_ext *extensions;
unsigned int i, count;
for (i = 0; i < count; i++) {
*ext_id_r = i;
return TRUE;
}
}
return FALSE;
}
void *context)
{
struct mail_index_registered_ext *rext;
}
{
struct mail_index_registered_ext *rext;
}
{
struct mail_index_registered_ext *rext;
}
{
struct mail_index_registered_ext *rext;
}
{
}
{
mail_index_sync_lost_handler_t *const *handlers;
unsigned int i, count;
for (i = 0; i < count; i++) {
break;
}
}
}
{
void *value;
/* keywords_hash keeps a name => index mapping of keywords.
Keywords are never removed from it, so the index values are valid
for the lifetime of the mail_index. */
return TRUE;
}
*idx_r = (unsigned int)-1;
return FALSE;
}
const char *keyword,
unsigned int *idx_r)
{
char *keyword_dup;
return;
}
{
}
struct mail_keywords *
const char *const keywords[])
{
struct mail_keywords *k;
if (count == 0) {
k->refcount = 1;
return k;
}
/* @UNSAFE */
k = i_malloc(sizeof(struct mail_keywords) +
k->refcount = 1;
/* look up the keywords from index. they're never removed from there
so we can permanently store indexes to them. */
/* ignore if this is a duplicate */
for (i = 0; i < src; i++) {
break;
}
if (i == src)
dest++;
}
return k;
}
struct mail_keywords *
const ARRAY_TYPE(keyword_indexes)
{
struct mail_keywords *k;
const unsigned int *indexes;
if (count == 0) {
k->refcount = 1;
return k;
}
/* @UNSAFE */
k = i_malloc(sizeof(struct mail_keywords) +
k->refcount = 1;
/* copy but skip duplicates */
for (i = 0; i < src; i++) {
break;
}
if (i == src)
}
return k;
}
{
}
{
}
{
/* Note that our caller must close index->fd by itself. */
else {
}
}
/* have to create it */
return 0;
}
return 1;
}
static int
{
int ret;
if (MAIL_INDEX_IS_IN_MEMORY(index))
return 0;
if (ret == 0) {
/* it's corrupted - recreate it */
}
}
return ret;
}
{
const char *path;
int fd;
if (fd == -1)
return fd;
}
enum mail_index_open_flags flags)
{
int ret;
if (ret == 0) {
if ((flags & MAIL_INDEX_OPEN_FLAG_CREATE) == 0)
return 0;
/* if dovecot.index exists, read it first so that we can get
the correct indexid and log sequence */
(void)mail_index_try_open(index);
/* Create a new indexid for us. If we're opening index
into memory, index->map doesn't exist yet. */
}
}
if (ret >= 0) {
if (ret == 0) {
/* corrupted */
if (ret == 0) {
}
}
}
if (ret < 0) {
if ((flags & MAIL_INDEX_OPEN_FLAG_CREATE) == 0)
return -1;
if (mail_index_move_to_memory(index) < 0)
return -1;
}
return 1;
}
enum file_lock_method lock_method)
{
int ret;
MAIL_INDEX_HDR_FLAG_CORRUPTED) != 0) {
/* corrupted, reopen files */
} else {
return 1;
}
}
i_strdup("(in-memory index)") :
index->shared_lock_count = 0;
index->excl_lock_count = 0;
(flags & MAIL_INDEX_OPEN_FLAG_DOTLOCK_USE_EXCL) != 0;
(flags & MAIL_INDEX_OPEN_FLAG_FSYNC_DISABLE) != 0;
(flags & MAIL_INDEX_OPEN_FLAG_NEVER_IN_MEMORY) != 0;
i_fatal("nfs flush requires fsync_disable=no");
i_fatal("nfs flush requires mmap_disable=yes");
/* doesn't exist and create flag not used */
return ret;
}
return 1;
}
enum mail_index_open_flags flags,
enum file_lock_method lock_method)
{
int ret;
return ret < 0 ? -1 : 0;
}
{
}
index->shared_lock_count = 0;
index->excl_lock_count = 0;
}
{
}
{
const char *path;
int last_errno = 0;
if (MAIL_INDEX_IS_IN_MEMORY(index))
return 0;
/* main index */
last_errno = errno;
/* logs */
last_errno = errno;
last_errno = errno;
/* cache */
last_errno = errno;
if (last_errno == 0)
return 0;
else {
errno = last_errno;
return -1;
}
}
{
if (MAIL_INDEX_IS_IN_MEMORY(index))
return 0;
return mail_index_try_open_only(index);
return 0;
}
/* the same file */
return 1;
}
/* new file, new locks. the old fd can keep its locks, they don't
matter anymore as no-one's going to modify the file. */
return mail_index_try_open_only(index);
}
{
int ret;
return ret <= 0 ? -1 : 0;
}
{
}
{
else {
}
return -1;
}
{
return MAIL_INDEX_IS_IN_MEMORY(index);
}
{
struct mail_index_map *map;
if (MAIL_INDEX_IS_IN_MEMORY(index))
if (index->never_in_memory)
return -1;
/* set the index as being into memory */
/* index was never even opened. just mark it as being in
memory and let the caller re-open the index. */
return -1;
}
/* move index map to memory */
}
/* move transaction log to memory */
}
}
return 0;
}
{
}
{
/* no gid changing */
return;
/* success */
return;
/* group and world permissions are the same, so group doesn't
really matter. ignore silently. */
return;
}
else {
index->gid_origin));
}
/* continue, but change permissions so that only the common
subset of group and world is used. this makes sure no one
gets any extra permissions. */
}
const char *function)
{
if (!index->never_in_memory)
return -1;
}
}
const char *filepath,
const char *function)
{
if (!index->never_in_memory)
return -1;
}
} else {
}
}
{
}
{
}
}