X-Git-Url: http://git.madism.org/?a=blobdiff_plain;ds=sidebyside;f=imap%2Fmx_imap.c;h=b44f9e1d83cdbc40e239524a13aaae9bec268090;hb=3648b4eb2926b930816326ba2874a0648dcd81e7;hp=f0aee599d99453eaabe43c5210b14ccf729212c4;hpb=b2a6a9673e124c222f921650a6f0025b64ab2145;p=apps%2Fmadmutt.git diff --git a/imap/mx_imap.c b/imap/mx_imap.c index f0aee59..b44f9e1 100644 --- a/imap/mx_imap.c +++ b/imap/mx_imap.c @@ -35,6 +35,23 @@ static int acl_check_imap (CONTEXT* ctx, int bit) { mutt_bit_isset (((IMAP_DATA*) ctx->data)->rights, bit)); } +static int imap_open_new_message (MESSAGE * msg, CONTEXT * dest, HEADER * hdr) +{ + char tmp[_POSIX_PATH_MAX]; + + mutt_mktemp (tmp); + if ((msg->fp = safe_fopen (tmp, "w")) == NULL) + return (-1); + msg->path = safe_strdup (tmp); + return 0; +} + +/* this ugly kludge is required since the last int to + * imap_check_mailbox() doesn't mean 'lock' but 'force'... */ +static int _imap_check_mailbox (CONTEXT* ctx, int* index_hint, int lock) { + return (imap_check_mailbox (ctx, index_hint, 0)); +} + mx_t* imap_reg_mx (void) { mx_t* fmt = safe_calloc (1, sizeof (mx_t)); @@ -43,6 +60,10 @@ mx_t* imap_reg_mx (void) { fmt->mx_is_magic = imap_is_magic; fmt->mx_access = imap_access; fmt->mx_open_mailbox = imap_open_mailbox; + fmt->mx_open_new_message = imap_open_new_message; fmt->mx_acl_check = acl_check_imap; + fmt->mx_fastclose_mailbox = imap_close_mailbox; + fmt->mx_sync_mailbox = imap_sync_mailbox; + fmt->mx_check_mailbox = _imap_check_mailbox; return (fmt); }