From: Steve Holme Date: Sun, 9 Feb 2020 15:50:57 +0000 (+0000) Subject: smtp: Simplify the MAIL command and avoid a duplication of send strings X-Git-Tag: curl-7_69_0~126 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=0b8651d48bb70605ef2b0b6563e5becd09104ea6;p=thirdparty%2Fcurl.git smtp: Simplify the MAIL command and avoid a duplication of send strings This avoids the duplication of strings when the optional AUTH and SIZE parameters are required. It also assists with the modifications that are part of #4892. Closes #4903 --- diff --git a/lib/smtp.c b/lib/smtp.c index 764a1b75ea..7bcff0ce7b 100644 --- a/lib/smtp.c +++ b/lib/smtp.c @@ -584,18 +584,13 @@ static CURLcode smtp_perform_mail(struct connectdata *conn) } /* Send the MAIL command */ - if(!auth && !size) - result = Curl_pp_sendf(&conn->proto.smtpc.pp, - "MAIL FROM:%s", from); - else if(auth && !size) - result = Curl_pp_sendf(&conn->proto.smtpc.pp, - "MAIL FROM:%s AUTH=%s", from, auth); - else if(auth && size) - result = Curl_pp_sendf(&conn->proto.smtpc.pp, - "MAIL FROM:%s AUTH=%s SIZE=%s", from, auth, size); - else - result = Curl_pp_sendf(&conn->proto.smtpc.pp, - "MAIL FROM:%s SIZE=%s", from, size); + result = Curl_pp_sendf(&conn->proto.smtpc.pp, + "MAIL FROM:%s%s%s%s%s", + from, /* Mandatory */ + auth ? " AUTH=" : "", /* Optional (on AUTH support) */ + auth ? auth : "", + size ? " SIZE=" : "", /* Optional (on SIZE support) */ + size ? size : ""); free(from); free(auth);