-mx_t* imap_reg_mx (void) {
- mx_t* fmt = safe_calloc (1, sizeof (mx_t));
-
- /* make up mx_t record... */
- fmt->type = M_IMAP;
- 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);
+/* 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 __attribute__ ((unused))) {
+ return (imap_check_mailbox (ctx, index_hint, 0));
+}
+
+static int imap_commit_message (MESSAGE* msg, CONTEXT* ctx) {
+ int r = 0;
+
+ if ((r = safe_fclose (&msg->fp)) == 0)
+ r = imap_append_message (ctx, msg);
+ return (r);