From: Steve Holme Date: Sat, 29 Dec 2012 23:06:25 +0000 (+0000) Subject: smtp_doing: don't call smtp_dophase_done() if already failed X-Git-Tag: curl-7_29_0~158 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=36837c10b275829d70a5e3d6d1f3dd8b9a68f43d;p=thirdparty%2Fcurl.git smtp_doing: don't call smtp_dophase_done() if already failed Applied the POP3 fix from commit 2897ce7dc2e1 so smtp_dophase_done() isn't called if smtp_multi_statemach() fails. --- diff --git a/lib/smtp.c b/lib/smtp.c index b8ab8976cb..7295e3efae 100644 --- a/lib/smtp.c +++ b/lib/smtp.c @@ -1591,11 +1591,13 @@ static CURLcode smtp_doing(struct connectdata *conn, bool *dophase_done) if(result) DEBUGF(infof(conn->data, "DO phase failed\n")); - else - DEBUGF(infof(conn->data, "DO phase is complete\n")); + else { + if(*dophase_done) { + result = smtp_dophase_done(conn, FALSE /* not connected */); - if(*dophase_done) - smtp_dophase_done(conn, FALSE /* not connected */); + DEBUGF(infof(conn->data, "DO phase is complete\n")); + } + } return result; }