X-Git-Url: http://git.madism.org/?a=blobdiff_plain;f=imap%2Fmx_imap.c;h=cd6d71b76a43e20b5809b4f07c70ca8b43ea9ee8;hb=2f0ad939a786df928a8b5d489692fbe11cf8c9d3;hp=eb402db269b87dbdacbb6ded6ffe4d068e64128b;hpb=8e6b42b9b28f646a6764936d80bda04647d5b45f;p=apps%2Fmadmutt.git diff --git a/imap/mx_imap.c b/imap/mx_imap.c index eb402db..cd6d71b 100644 --- a/imap/mx_imap.c +++ b/imap/mx_imap.c @@ -7,6 +7,8 @@ #include "config.h" #endif +#include + #include "mutt.h" #include "imap_private.h" @@ -18,7 +20,7 @@ #include "url.h" -static int imap_is_magic (const char* path) { +int imap_is_magic (const char* path, struct stat* st) { url_scheme_t s; if (!path || !*path) return (-1); @@ -33,6 +35,17 @@ 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; +} + mx_t* imap_reg_mx (void) { mx_t* fmt = safe_calloc (1, sizeof (mx_t)); @@ -41,6 +54,9 @@ 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; return (fmt); }