/*
* Copyright notice from original mutt:
* Copyright (C) 1996-2002 Michael R. Elkins <me@mutt.org>
* Copyright (C) 1999-2002 Thomas Roessler <roessler@does-not-exist.org>
*
* This file is part of mutt-ng, see http://www.muttng.org/.
* It's licensed under the GNU General Public License,
* please see the file GPL in the top level source directory.
*/
/*
* mailbox abstraction
* when adding code dealing with folders or whatever,
* please use these only
*/
#ifndef _MX_H
#define _MX_H
#include <sys/stat.h>
#include <utime.h>
/*
* supported mailbox formats
* in mx_init() the registration order must be exactly as given here!!!1!
*/
enum {
M_MBOX = 1,
M_MMDF,
M_MH,
M_MAILDIR
#ifdef USE_IMAP
, M_IMAP
#endif
#ifdef USE_POP
, M_POP
#endif
#ifdef USE_NNTP
, M_NNTP
#endif
#ifdef USE_COMPRESSED
, M_COMPRESSED
#endif
};
enum {
ACL_LOOKUP = 0,
ACL_READ,
ACL_SEEN,
ACL_WRITE,
ACL_INSERT,
ACL_POST,
ACL_CREATE,
ACL_DELETE,
ACL_ADMIN,
RIGHTSMAX
};
/* ugly hack to define macro once (for pager+index) */
#define CHECK_MX_ACL(c,f,s) if(!mx_acl_check(c,f)) \
{\
mutt_flushinp (); \
mutt_error(_("%s not permitted by ACL."), s); \
break; \
}
typedef struct {
FILE *fp; /* pointer to the message data */
char *path; /* path to temp file */
short magic; /* type of mailbox this message belongs to */
short write; /* nonzero if message is open for writing */
struct {
unsigned read:1;
unsigned flagged:1;
unsigned replied:1;
} flags;
time_t received; /* the time at which this message was received */
} MESSAGE;
typedef struct {
/* folder magic */
int type;
/* may we stat() it? */
unsigned int local : 1;
/* tests if given path is of its magic */
int (*mx_is_magic) (const char*, struct stat*);
/* tests if folder is empty */
int (*mx_check_empty) (const char*);
/* test for access */
int (*mx_access) (const char*, int);
/* read mailbox into ctx structure */
int (*mx_open_mailbox) (CONTEXT*);
/* open new message */
int (*mx_open_new_message) (MESSAGE*, CONTEXT*, HEADER*);
/* check ACL flags; if not implemented, always assume granted
* permissions */
int (*mx_acl_check) (CONTEXT*, int);
/* check for new mail; see mx_check_mailbox() below for return vals */
int (*mx_check_mailbox) (CONTEXT*, int*, int);
/* fast closing */
void (*mx_fastclose_mailbox) (CONTEXT*);
/* write out changes */
int (*mx_sync_mailbox) (CONTEXT*, int, int*);
/* commit a message to a folder */
int (*mx_commit_message) (MESSAGE*, CONTEXT*);
} mx_t;
/* called from main: init all folder types */
void mx_init (void);
/* flags for mx_open_mailbox() */
#define M_NOSORT (1<<0) /* do not sort the mailbox after opening it */
#define M_APPEND (1<<1) /* open mailbox for appending messages */
#define M_READONLY (1<<2) /* open in read-only mode */
#define M_QUIET (1<<3) /* do not print any messages */
#define M_NEWFOLDER (1<<4) /* create a new folder - same as M_APPEND, but uses
* safe_fopen() for mbox-style folders. */
#define M_COUNT (1<<5) /* just do counting? needed to do speed optimizations
for sidebar */
/* mx_open_new_message() */
#define M_ADD_FROM 1 /* add a From_ line */
#define MAXLOCKATTEMPT 5
WHERE short DefaultMagic INITVAL (M_MBOX);
/*
* please use the following _ONLY_ when doing "something"
* with folders
*/
CONTEXT *mx_open_mailbox (const char *, int, CONTEXT *);
MESSAGE *mx_open_message (CONTEXT *, int);
MESSAGE *mx_open_new_message (CONTEXT *, HEADER *, int);
void mx_fastclose_mailbox (CONTEXT *);
int mx_close_mailbox (CONTEXT *, int *);
int mx_sync_mailbox (CONTEXT *, int *);
int mx_commit_message (MESSAGE *, CONTEXT *);
int mx_close_message (MESSAGE **);
/* determines magic for given folder */
int mx_get_magic (const char*);
/* sets/parses DefaultMagic */
int mx_set_magic (const char *);
/* tests whether given folder magic is (valid and) local */
int mx_is_local (int);
/* return values from mx_check_mailbox() */
enum {
M_NEW_MAIL = 1, /* new mail received in mailbox */
M_LOCKED, /* couldn't lock the mailbox */
M_REOPENED, /* mailbox was reopened */
M_FLAGS /* nondestructive flags change (IMAP) */
};
int mx_check_mailbox (CONTEXT *, int *, int);
int mx_access (const char *, int);
int mx_check_empty (const char *);
int mx_acl_check (CONTEXT*, int);
void mx_alloc_memory (CONTEXT *);
void mx_update_context (CONTEXT *, int);
void mx_update_tables (CONTEXT *, int);
int mx_lock_file (const char *, int, int, int, int);
int mx_unlock_file (const char *path, int fd, int dot);
int mx_rebuild_cache (void);
#endif /* !_MX_H */
syntax highlighted by Code2HTML, v. 0.9.1