projects
/
apps
/
madmutt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Rocco Rutte:
[apps/madmutt.git]
/
imap
/
mx_imap.c
diff --git
a/imap/mx_imap.c
b/imap/mx_imap.c
index
eb402db
..
cd6d71b
100644
(file)
--- a/
imap/mx_imap.c
+++ b/
imap/mx_imap.c
@@
-7,6
+7,8
@@
#include "config.h"
#endif
#include "config.h"
#endif
+#include <sys/stat.h>
+
#include "mutt.h"
#include "imap_private.h"
#include "mutt.h"
#include "imap_private.h"
@@
-18,7
+20,7
@@
#include "url.h"
#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);
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));
}
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));
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_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_acl_check = acl_check_imap;
+ fmt->mx_fastclose_mailbox = imap_close_mailbox;
+ fmt->mx_sync_mailbox = imap_sync_mailbox;
return (fmt);
}
return (fmt);
}