#include <stdlib.h>
#include <ctype.h>
-#include "lib/mem.h"
-#include "lib/str.h"
-#include "lib/intl.h"
+#include <lib-lib/mem.h>
+#include <lib-lib/str.h>
+#include <lib-lib/ascii.h>
+#include <lib-lib/macros.h>
+
#include "lib/debug.h"
#include "mutt.h"
+#include "enter.h"
#include "imap_private.h"
/* -- forward declarations -- */
short showparents = 0;
int noselect;
int noinferiors;
+ int save_lsub;
IMAP_MBOX mx;
if (imap_parse_path (path, &mx)) {
return -1;
}
- strfcpy (list_cmd, option (OPTIMAPLSUB) ? "LSUB" : "LIST",
- sizeof (list_cmd));
+ save_lsub = option (OPTIMAPCHECKSUBSCRIBED);
+ unset_option (OPTIMAPCHECKSUBSCRIBED);
+ m_strcpy(list_cmd, sizeof(list_cmd),
+ option(OPTIMAPLSUB) ? "LSUB" : "LIST");
if (!(idata = imap_conn_find (&(mx.account), 0)))
goto fail;
if (!mx.mbox) {
home_namespace = 1;
mbox[0] = '\0'; /* Do not replace "" with "INBOX" here */
- mx.mbox = str_dup (ImapHomeNamespace);
+ mx.mbox = m_strdup(ImapHomeNamespace);
if (mutt_bit_isset (idata->capabilities, NAMESPACE)) {
mutt_message _("Getting namespaces...");
imap_fix_path (idata, mx.mbox, mbox, sizeof (mbox));
imap_munge_mbox_name (buf, sizeof (buf), mbox);
imap_unquote_string (buf); /* As kludgy as it gets */
- mbox[sizeof (mbox) - 1] = '\0';
- strncpy (mbox, buf, sizeof (mbox) - 1);
- n = str_len (mbox);
+ m_strcpy(mbox, sizeof(mbox), buf);
+ n = m_strlen(mbox);
debug_print (3, ("mbox: %s\n", mbox));
imap_unmunge_mbox_name (cur_folder);
if (!noinferiors && cur_folder[0] &&
- (n = str_len (mbox)) < LONG_STRING - 1) {
+ (n = m_strlen(mbox)) < LONG_STRING - 1) {
mbox[n++] = idata->delim;
mbox[n] = '\0';
}
if (!home_namespace)
showparents = 1;
imap_qualify_path (buf, sizeof (buf), &mx, mbox);
- state->folder = str_dup (buf);
+ state->folder = m_strdup(buf);
n--;
}
ctmp = mbox[n];
mbox[n] = '\0';
imap_qualify_path (buf, sizeof (buf), &mx, mbox);
- state->folder = str_dup (buf);
+ state->folder = m_strdup(buf);
}
mbox[n] = ctmp;
}
imap_add_folder (idata->delim, relpath, 1, 0, state, 1);
if (!state->folder) {
imap_qualify_path (buf, sizeof (buf), &mx, relpath);
- state->folder = str_dup (buf);
+ state->folder = m_strdup(buf);
}
}
}
/* no namespace, no folder: set folder to host only */
if (!state->folder) {
imap_qualify_path (buf, sizeof (buf), &mx, NULL);
- state->folder = str_dup (buf);
+ state->folder = m_strdup(buf);
}
if (home_namespace && mbox[0] != '\0') {
}
}
- mem_free (&mx.mbox);
+ if (save_lsub)
+ set_option (OPTIMAPCHECKSUBSCRIBED);
+
+ p_delete(&mx.mbox);
return 0;
fail:
- mem_free (&mx.mbox);
+ if (save_lsub)
+ set_option (OPTIMAPCHECKSUBSCRIBED);
+ p_delete(&mx.mbox);
return -1;
}
goto fail;
}
- strfcpy (buf, NONULL (mx.mbox), sizeof (buf));
+ m_strcpy(buf, sizeof(buf), NONULL(mx.mbox));
/* append a delimiter if necessary */
- n = str_len (buf);
+ n = m_strlen(buf);
if (n && (n < sizeof (buf) - 1) && (buf[n - 1] != idata->delim)) {
buf[n++] = idata->delim;
buf[n] = '\0';
if (mutt_get_field (_("Create mailbox: "), buf, sizeof (buf), M_FILE) < 0)
goto fail;
- if (!str_len (buf)) {
+ if (!m_strlen(buf)) {
mutt_error (_("Mailbox must have a name."));
mutt_sleep (1);
goto fail;
mutt_sleep (0);
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return 0;
fail:
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return -1;
}
if (mutt_get_field (buf, newname, sizeof (newname), M_FILE) < 0)
goto fail;
- if (!str_len (newname)) {
+ if (!m_strlen(newname)) {
mutt_error (_("Mailbox must have a name."));
mutt_sleep (1);
goto fail;
mutt_message (_("Mailbox renamed."));
mutt_sleep (0);
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return 0;
fail:
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return -1;
}
do {
if (imap_parse_list_response (idata, &name, &noselect, &noinferiors,
&idata->delim) != 0) {
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return -1;
}
if (isparent)
noselect = 1;
/* prune current folder from output */
- if (isparent || str_ncmp (name, mx.mbox, str_len (name)))
+ if (isparent || m_strncmp(name, mx.mbox, m_strlen(name)))
imap_add_folder (idata->delim, name, noselect, noinferiors, state,
isparent);
}
}
while ((ascii_strncmp (idata->cmd.buf, idata->cmd.seq, SEQLEN) != 0));
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return 0;
}
imap_unmunge_mbox_name (folder);
if (state->entrylen + 1 == state->entrymax) {
- mem_realloc (&state->entry,
- sizeof (struct folder_file) * (state->entrymax += 256));
- memset (state->entry + state->entrylen, 0,
- (sizeof (struct folder_file) *
- (state->entrymax - state->entrylen)));
+ p_realloc(&state->entry, state->entrymax += 256);
+ p_clear(state->entry + state->entrylen,
+ state->entrymax - state->entrylen);
}
/* render superiors as unix-standard ".." */
if (isparent)
- strfcpy (relpath, "../", sizeof (relpath));
+ m_strcpy(relpath, sizeof(relpath), "../");
/* strip current folder from target, to render a relative path */
- else if (!str_ncmp (mx.mbox, folder, str_len (mx.mbox)))
- strfcpy (relpath, folder + str_len (mx.mbox), sizeof (relpath));
+ else if (!m_strncmp(mx.mbox, folder, m_strlen(mx.mbox)))
+ m_strcpy(relpath, sizeof(relpath), folder + m_strlen(mx.mbox));
else
- strfcpy (relpath, folder, sizeof (relpath));
+ m_strcpy(relpath, sizeof(relpath), folder);
/* apply filemask filter. This should really be done at menu setup rather
* than at scan, since it's so expensive to scan. But that's big changes
* to browser.c */
if (!((regexec (Mask.rx, relpath, 0, NULL, 0) == 0) ^ Mask.not)) {
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
return;
}
imap_qualify_path (tmp, sizeof (tmp), &mx, folder);
- (state->entry)[state->entrylen].name = str_dup (tmp);
+ (state->entry)[state->entrylen].name = m_strdup(tmp);
/* mark desc with delim in browser if it can have subfolders */
- if (!isparent && !noinferiors && str_len (relpath) < sizeof (relpath) - 1) {
- relpath[str_len (relpath) + 1] = '\0';
- relpath[str_len (relpath)] = delim;
+ if (!isparent && !noinferiors && m_strlen(relpath) < sizeof (relpath) - 1) {
+ relpath[m_strlen(relpath) + 1] = '\0';
+ relpath[m_strlen(relpath)] = delim;
}
- (state->entry)[state->entrylen].desc = str_dup (relpath);
+ (state->entry)[state->entrylen].desc = m_strdup(relpath);
(state->entry)[state->entrylen].imap = 1;
/* delimiter at the root is useless. */
(state->entry)[state->entrylen].inferiors = !noinferiors;
(state->entrylen)++;
- mem_free (&mx.mbox);
+ p_delete(&mx.mbox);
}
static int compare_names (struct folder_file *a, struct folder_file *b)
{
- return str_cmp (a->name, b->name);
+ return m_strcmp(a->name, b->name);
}
static int browse_get_namespace (IMAP_DATA * idata, char *nsbuf, int nsblen,