X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=send.c;h=a6da714e8efa4de91ad361cb1e4e6ae652eb811a;hp=fd4bf7756a3c6121a907eec010f4f34fc57200c9;hb=1601b25fd310dd65a6b6d1b49f2e16f55560ac9d;hpb=a8477ebaa09990b3688164cbe5cf661c4189541d diff --git a/send.c b/send.c index fd4bf77..a6da714 100644 --- a/send.c +++ b/send.c @@ -12,6 +12,8 @@ #endif #include "mutt.h" +#include "enter.h" +#include "ascii.h" #include "mutt_curses.h" #include "rfc2047.h" #include "keymap.h" @@ -21,6 +23,7 @@ #include "mutt_crypt.h" #include "mutt_idna.h" #include "url.h" +#include "attach.h" #include "lib/mem.h" #include "lib/intl.h" @@ -53,15 +56,9 @@ static void append_signature (FILE * f) FILE *tmpfp; pid_t thepid; - if (SignOffString) { - fprintf (f, "\n%s", SignOffString); - } - if (Signature && (tmpfp = mutt_open_read (Signature, &thepid))) { if (option (OPTSIGDASHES)) fputs ("\n-- \n", f); - else if (SignOffString) - fputs ("\n", f); mutt_copy_stream (tmpfp, f); fclose (tmpfp); if (thepid != -1) @@ -192,7 +189,7 @@ static int edit_address (ADDRESS ** a, /* const */ char *field) mutt_error (_("Error: '%s' is a bad IDN."), err); mutt_refresh (); mutt_sleep (2); - FREE (&err); + mem_free (&err); } } while (idna_ok != 0); @@ -213,7 +210,7 @@ static int edit_envelope (ENVELOPE * en, int flags) buf[0] = 0; if (mutt_get_field ("Newsgroups: ", buf, sizeof (buf), 0) != 0) return (-1); - FREE (&en->newsgroups); + mem_free (&en->newsgroups); en->newsgroups = str_dup (buf); if (en->followup_to) @@ -223,7 +220,7 @@ static int edit_envelope (ENVELOPE * en, int flags) if (option (OPTASKFOLLOWUP) && mutt_get_field ("Followup-To: ", buf, sizeof (buf), 0) != 0) return (-1); - FREE (&en->followup_to); + mem_free (&en->followup_to); en->followup_to = str_dup (buf); if (en->x_comment_to) @@ -233,7 +230,7 @@ static int edit_envelope (ENVELOPE * en, int flags) if (option (OPTXCOMMENTTO) && option (OPTASKXCOMMENTTO) && mutt_get_field ("X-Comment-To: ", buf, sizeof (buf), 0) != 0) return (-1); - FREE (&en->x_comment_to); + mem_free (&en->x_comment_to); en->x_comment_to = str_dup (buf); } else @@ -368,24 +365,6 @@ static void process_user_header (ENVELOPE * env) } } -LIST *mutt_copy_list (LIST * p) -{ - LIST *t, *r = NULL, *l = NULL; - - for (; p; p = p->next) { - t = (LIST *) safe_malloc (sizeof (LIST)); - t->data = str_dup (p->data); - t->next = NULL; - if (l) { - r->next = t; - r = r->next; - } - else - l = r = t; - } - return (l); -} - void mutt_forward_intro (FILE * fp, HEADER * cur) { char buffer[STRING]; @@ -450,7 +429,6 @@ void mutt_make_post_indent (CONTEXT * ctx, HEADER * cur, FILE * out) if (PostIndentString) { mutt_make_string (buffer, sizeof (buffer), PostIndentString, ctx, cur); fputs (buffer, out); - fputc ('\n', out); } } @@ -659,8 +637,8 @@ void mutt_make_misc_reply_headers (ENVELOPE * env, CONTEXT * ctx, * been taken from a List-Post header. Is that correct? */ if (curenv->real_subj) { - FREE (&env->subject); - env->subject = safe_malloc (str_len (curenv->real_subj) + 5); + mem_free (&env->subject); + env->subject = mem_malloc (str_len (curenv->real_subj) + 5); sprintf (env->subject, "Re: %s", curenv->real_subj); /* __SPRINTF_CHECKED__ */ } else if (!env->subject) @@ -974,7 +952,7 @@ static ADDRESS *set_reverse_name (ENVELOPE * env) if (tmp) { tmp = rfc822_cpy_adr_real (tmp); if (!option (OPTREVREAL)) - FREE (&tmp->personal); + mem_free (&tmp->personal); if (!tmp->personal) tmp->personal = str_dup (Realname); } @@ -996,7 +974,7 @@ ADDRESS *mutt_default_from (void) else if (option (OPTUSEDOMAIN)) { adr = rfc822_new_address (); adr->mailbox = - safe_malloc (str_len (Username) + str_len (fqdn) + 2); + mem_malloc (str_len (Username) + str_len (fqdn) + 2); sprintf (adr->mailbox, "%s@%s", NONULL (Username), NONULL (fqdn)); /* __SPRINTF_CHECKED__ */ } else { @@ -1110,6 +1088,7 @@ int ci_send_message (int flags, /* send mode */ /* save current value of "pgp_sign_as" */ char *signas = NULL; char *tag = NULL, *err = NULL; + char *ctype; int rv = -1; @@ -1190,7 +1169,10 @@ int ci_send_message (int flags, /* send mode */ pbody->next = msg->content; /* don't kill command-line attachments */ msg->content = pbody; - mutt_parse_content_type (ContentType, msg->content); + ctype = str_dup (ContentType); + mutt_parse_content_type (ctype, msg->content); + mem_free (&ctype); + msg->content->unlink = 1; msg->content->use_disp = 0; msg->content->disposition = DISPINLINE; @@ -1556,7 +1538,7 @@ int ci_send_message (int flags, /* send mode */ if (mutt_env_to_idna (msg->env, &tag, &err)) { mutt_error (_("Bad IDN in \"%s\": '%s'"), tag, err); - FREE (&err); + mem_free (&err); if (!(flags & SENDBATCH)) goto main_loop; else @@ -1617,7 +1599,7 @@ int ci_send_message (int flags, /* send mode */ mutt_protect (msg, pgpkeylist) == -1) { msg->content = mutt_remove_multipart (msg->content); - FREE (&pgpkeylist); + mem_free (&pgpkeylist); decode_descriptions (msg->content); goto main_loop; @@ -1781,7 +1763,7 @@ int ci_send_message (int flags, /* send mode */ #endif if (WithCrypto && (msg->security & ENCRYPT)) - FREE (&pgpkeylist); + mem_free (&pgpkeylist); if (WithCrypto && free_clear_content) mutt_free_body (&clear_content); @@ -1803,7 +1785,7 @@ cleanup: if ((WithCrypto & APPLICATION_PGP) && (flags & SENDPOSTPONED)) { if (signas) { - FREE (&PgpSignAs); + mem_free (&PgpSignAs); PgpSignAs = signas; } }