X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=rfc1524.c;h=882f583a71772230b0d65dd4a4d38f4b1224e27d;hp=86ffc062f5c0372f9aa6f8512db75b50d3ad3a8b;hb=1c16e9623a9fb6a15bb284a6f7322b583ebc06a7;hpb=bbc4fd52516a8afefbd14c77e34f8389d6f0a6ed diff --git a/rfc1524.c b/rfc1524.c index 86ffc06..882f583 100644 --- a/rfc1524.c +++ b/rfc1524.c @@ -21,14 +21,16 @@ # include "config.h" #endif +#include +#include +#include +#include +#include + #include "mutt.h" -#include "ascii.h" #include "rfc1524.h" #include "attach.h" -#include "lib/mem.h" -#include "lib/intl.h" -#include "lib/str.h" #include "lib/debug.h" #include @@ -196,14 +198,14 @@ static int rfc1524_mailcap_parse (BODY * a, /* check type */ ch = get_field (buf); if (ascii_strcasecmp (buf, type) && (ascii_strncasecmp (buf, type, btlen) || (buf[btlen] != 0 && /* implicit wild */ - str_cmp (buf + btlen, "/*")))) /* wildsubtype */ + m_strcmp(buf + btlen, "/*")))) /* wildsubtype */ continue; /* next field is the viewcommand */ field = ch; ch = get_field (ch); if (entry) - entry->command = str_dup (field); + entry->command = m_strdup(field); /* parse the optional fields */ found = TRUE; @@ -267,14 +269,14 @@ static int rfc1524_mailcap_parse (BODY * a, if (get_field_text (field + 4, &test_command, type, filename, line) && test_command) { - len = str_len (test_command) + STRING; - mem_realloc (&test_command, len); + len = m_strlen(test_command) + STRING; + p_realloc(&test_command, len); rfc1524_expand_command (a, a->filename, type, test_command, len); if (mutt_system (test_command)) { /* a non-zero exit code means test failed */ found = FALSE; } - mem_free (&test_command); + p_delete(&test_command); } } } /* while (ch) */ @@ -299,13 +301,13 @@ static int rfc1524_mailcap_parse (BODY * a, if (!found) { /* reset */ if (entry) { - mem_free (&entry->command); - mem_free (&entry->composecommand); - mem_free (&entry->composetypecommand); - mem_free (&entry->editcommand); - mem_free (&entry->printcommand); - mem_free (&entry->nametemplate); - mem_free (&entry->convert); + p_delete(&entry->command); + p_delete(&entry->composecommand); + p_delete(&entry->composetypecommand); + p_delete(&entry->editcommand); + p_delete(&entry->printcommand); + p_delete(&entry->nametemplate); + p_delete(&entry->convert); entry->needsterminal = 0; entry->copiousoutput = 0; } @@ -313,27 +315,27 @@ static int rfc1524_mailcap_parse (BODY * a, } /* while (!found && (buf = mutt_read_line ())) */ fclose (fp); } /* if ((fp = fopen ())) */ - mem_free (&buf); + p_delete(&buf); return found; } rfc1524_entry *rfc1524_new_entry (void) { - return (rfc1524_entry *) mem_calloc (1, sizeof (rfc1524_entry)); + return p_new(rfc1524_entry, 1); } void rfc1524_free_entry (rfc1524_entry ** entry) { rfc1524_entry *p = *entry; - mem_free (&p->command); - mem_free (&p->testcommand); - mem_free (&p->composecommand); - mem_free (&p->composetypecommand); - mem_free (&p->editcommand); - mem_free (&p->printcommand); - mem_free (&p->nametemplate); - mem_free (entry); + p_delete(&p->command); + p_delete(&p->testcommand); + p_delete(&p->composecommand); + p_delete(&p->composetypecommand); + p_delete(&p->editcommand); + p_delete(&p->printcommand); + p_delete(&p->nametemplate); + p_delete(entry); } /* @@ -475,8 +477,8 @@ int rfc1524_expand_filename (char *nametemplate, rmatch = 1; - for (r = 0, j = str_len (oldfile) - 1, k = - str_len (nametemplate) - 1; + for (r = 0, j = m_strlen(oldfile) - 1, k = + m_strlen(nametemplate) - 1; j >= (lmatch ? i : 0) && k >= i + 2; j--, k--) { if (nametemplate[k] != oldfile[j]) { rmatch = 0; @@ -507,7 +509,7 @@ int rfc1524_expand_filename (char *nametemplate, } } - mutt_adv_mktemp (newfile, nflen); + mutt_adv_mktemp (NULL, newfile, nflen); if (rmatch && lmatch) return 0;