};
rx_t *SpamList = NULL, *NoSpamList = NULL;
+string_list_t *AutoViewList, *AlternativeOrderList, *MimeLookupList;
+string_list_t *Ignore, *UnIgnore, *HeaderOrderList;
-@package Mime {
+static char *mailcap_init(void)
+{
+ /* Default search path from RFC1524 */
+ const char *path = "~/.mailcap:" PKGDATADIR "/mailcap:"
+ SYSCONFDIR "/mailcap:/etc/mailcap:"
+ "/usr/etc/mailcap:/usr/local/etc/mailcap";
+ return m_strdup(getenv("MAILCAPS") ?: path);
+}
+
+@package mod_mime {
/*
** .pp
** ``$spam_separator'' controls what happens when multiple spam headers
*/
string_t spam_separator = m_strdup(",");
+ /*
+ ** .pp
+ ** This variable specifies which files to consult when attempting to
+ ** display MIME bodies not directly supported by Madmutt.
+ */
+ string_t mailcap_path = mailcap_init();
+
+ /*
+ ** .pp
+ ** If \fIset\fP, Madmutt will restrict possible characters in mailcap \fT%\fP expandos
+ ** to a well-defined set of safe characters. This is the safe setting,
+ ** but we are not sure it doesn't break some more advanced MIME stuff.
+ ** .pp
+ ** \fBDON'T CHANGE THIS SETTING UNLESS YOU ARE REALLY SURE WHAT YOU ARE
+ ** DOING!\fP
+ */
+ bool mailcap_sanitize = 1;
+
void spam(rx_t rx, const string_t tpl) {
rx_set_template(rx, tpl);
- rx_list_append(&SpamList, rx);
+ rx_list_remove(&NoSpamList, rx);
+ rx_list_add2(&SpamList, &rx);
RETURN();
};
rx_list_wipe(&NoSpamList);
rx_delete(&rx);
} else {
- rx_list_append(&NoSpamList, rx);
+ rx_list_remove(&SpamList, rx);
+ rx_list_add2(&NoSpamList, &rx);
}
RETURN();
};
-};
-/****************************************************************************/
-/* rfc822 header parameters */
-/****************************************************************************/
-
-char *parameter_getval(parameter_t *parm, const char *s)
-{
- while (parm) {
- if (!ascii_strcasecmp(parm->attribute, s))
- return parm->value;
- parm = parm->next;
- }
- return NULL;
-}
-
-void parameter_setval(parameter_t **p, const char *attribute, const char *value)
-{
- while (*p) {
- if (!ascii_strcasecmp(attribute, (*p)->attribute)) {
- if (value) {
- m_strreplace(&(*p)->value, value);
- } else {
- parameter_t *q = parameter_list_pop(p);
- parameter_delete(&q);
- }
- return;
+ void auto_view(string_t s) {
+ string_list_add(&AutoViewList, s);
+ RETURN();
+ };
+ void unauto_view(string_t s) {
+ if (m_strcmp(s, "*")) {
+ string_list_remove(&AutoViewList, s);
+ } else {
+ string_list_wipe(&AutoViewList);
}
- p = &(*p)->next;
- }
-
- if (value) {
- (*p) = parameter_new();
- (*p)->attribute = m_strdup(attribute);
- (*p)->value = m_strdup(value);
- }
-}
+ RETURN();
+ };
-void parameter_delval(parameter_t **p, const char *attribute)
-{
- while (*p) {
- if (!ascii_strcasecmp(attribute, (*p)->attribute)) {
- parameter_t *q = parameter_list_pop(p);
- parameter_delete(&q);
- return;
+ void alternative_order(string_t s) {
+ string_list_add(&AlternativeOrderList, s);
+ RETURN();
+ };
+ void unalternative_order(string_t s) {
+ if (m_strcmp(s, "*")) {
+ string_list_remove(&AlternativeOrderList, s);
+ } else {
+ string_list_wipe(&AlternativeOrderList);
}
+ RETURN();
+ };
- p = &(*p)->next;
- }
-}
-
-int parameter_equal(const parameter_t *p1, const parameter_t *p2)
-{
- while (p1 && p2) {
- if (m_strcmp(p1->attribute, p2->attribute)
- || m_strcmp(p1->value, p2->value))
- return 0;
-
- p1 = p1->next;
- p2 = p2->next;
- }
-
- if (p1 || p2)
- return 0;
-
- return 1;
-}
-
-void parameter_set_boundary(parameter_t **parm)
-{
- char rs[BOUNDARYLEN + 1];
- int i;
-
- for (i = 0; i < BOUNDARYLEN; i++) {
- rs[i] = __m_b64chars[lrand48() % sizeof(__m_b64chars)];
- }
- rs[BOUNDARYLEN] = '\0';
+ void lookup(string_t s) {
+ string_list_add(&MimeLookupList, s);
+ RETURN();
+ };
+ void unlookup(string_t s) {
+ if (m_strcmp(s, "*")) {
+ string_list_remove(&MimeLookupList, s);
+ } else {
+ string_list_wipe(&MimeLookupList);
+ }
+ RETURN();
+ };
- parameter_setval(parm, "boundary", rs);
-}
+ void hdr_order(string_t s) {
+ string_list_add(&HeaderOrderList, s);
+ RETURN();
+ };
+ void unhdr_order(string_t s) {
+ if (m_strcmp(s, "*")) {
+ string_list_remove(&HeaderOrderList, s);
+ } else {
+ string_list_wipe(&HeaderOrderList);
+ }
+ RETURN();
+ };
+ void ignore(string_t s) {
+ if (m_strcmp(s, "*")) {
+ string_list_remove(&UnIgnore, s);
+ } else {
+ string_list_wipe(&UnIgnore);
+ }
+ string_list_add(&Ignore, s);
+ RETURN();
+ };
+ void unignore(string_t s) {
+ if (m_strcmp(s, "*")) {
+ string_list_add(&UnIgnore, s);
+ string_list_remove(&Ignore, s);
+ } else {
+ string_list_wipe(&Ignore);
+ }
+ RETURN();
+ };
+};
/****************************************************************************/
/* XXX */
p_delete(&p->date);
p_delete(&p->x_label);
p_delete(&p->organization);
-#ifdef USE_NNTP
- p_delete(&p->newsgroups);
- p_delete(&p->xref);
- p_delete(&p->followup_to);
- p_delete(&p->x_comment_to);
-#endif
mutt_buffer_free (&p->spam);
string_list_wipe(&p->references);
void body_wipe(BODY *b)
{
- if (b->parameter)
- parameter_list_wipe(&b->parameter);
-
+ b->parameter = NULL;
if (b->unlink && b->filename) {
unlink (b->filename);
}
p_delete(&h->maildir_flags);
p_delete(&h->tree);
p_delete(&h->path);
- string_list_wipe(&h->chain);
p_delete(&h->data);
}