mail-transaction-log-view.c revision 44ff75ca53188056ff5a3e50428e3f2078800b3c
/* Copyright (C) 2003-2004 Timo Sirainen */
#include "lib.h"
#include "buffer.h"
#include "mail-index-private.h"
#include "mail-transaction-log-private.h"
#include "mail-transaction-util.h"
struct mail_transaction_log_view {
struct mail_transaction_log *log;
struct mail_transaction_log_view *next;
struct mail_transaction_header tmp_hdr;
unsigned int broken:1;
};
struct mail_transaction_log_view *
{
struct mail_transaction_log_view *view;
return view;
}
{
struct mail_transaction_log_view **p;
struct mail_transaction_log_file *file;
if (*p == view) {
break;
}
}
}
{
struct mail_transaction_log_view *view;
}
int
{
/* FIXME: error handling for "not found" case is bad.. should the
caller after all check it and handle as it sees best..? */
int ret;
return -1;
/* we can skip this */
min_file_offset = sizeof(struct mail_transaction_log_header);
if (min_file_seq > max_file_seq) {
/* empty view */
}
}
if (ret <= 0) {
if (ret == 0) {
"Lost transaction log file %s seq %u",
}
return -1;
}
/* check these later than others as index file may have corrupted
log_file_offset. we should have recreated the log file and
skipped min_file_seq file above.. max_file_offset can be broken
only if min_file_seq = max_file_seq. */
if (ret <= 0) {
if (ret == 0) {
"Lost transaction log file %s seq %u",
}
return -1;
}
"Lost transaction log file %s seq %u",
return -1;
}
sizeof(struct mail_transaction_log_header),
if (ret == 0) {
"Lost transaction log file %s seq %u",
}
if (ret <= 0)
return -1;
}
/* we have all of them. update refcounts. */
/* unref old files */
} else {
/* going backwards, reference them */
}
/* reference all new files */
view->prev_file_seq = 0;
view->prev_file_offset = 0;
return 0;
}
void
{
}
void
const char *fmt, ...)
{
t_push();
t_pop();
}
int
{
}
const struct mail_transaction_header **hdr_r,
const void **data_r)
{
const struct mail_transaction_header *hdr;
struct mail_transaction_log_file *file;
const struct mail_transaction_type_map *type_rec;
const void *data;
unsigned int record_size;
for (;;) {
return 0;
break;
}
return 0;
"offset points outside file "
return -1;
}
"record size too large (type=0x%x, offset=%"PRIuUOFF_T
return -1;
}
"record size too small (type=0x%x, size=%u)",
return -1;
}
else {
"unknown record type 0x%x",
return -1;
}
"found expunge without protection mask");
return -1;
}
"extra bits in header type: 0x%x",
return -1;
"extra record update out of range (%u > %u)",
return -1;
}
}
"record size wrong (type 0x%x, %u %% %u != 0)",
return -1;
}
return 1;
}
const struct mail_transaction_header **hdr_r,
{
const struct mail_transaction_header *hdr;
const void *data;
int ret = 0;
return -1;
break;
/* we don't want this record */
append isn't in mask */
}
if (ret <= 0)
return ret;
/* hide expunge protection */
}
return 1;
}