aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorGisle Vanem <gvanem@broadpark.no>2006-11-14 20:26:13 +0000
committerGisle Vanem <gvanem@broadpark.no>2006-11-14 20:26:13 +0000
commit438312f00e3813efe576a2d5d78844b5451b1f69 (patch)
tree9bc50630df9febbfa4de1ec9ce865b28551f6ccd /lib
parent381ccaa3916eb6b71a9c45065de52dda70d755a7 (diff)
Free 'scp->path' in case of libssh2 setup failure.
Diffstat (limited to 'lib')
-rw-r--r--lib/ssh.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/lib/ssh.c b/lib/ssh.c
index f3cd99b33..9b56ebc7b 100644
--- a/lib/ssh.c
+++ b/lib/ssh.c
@@ -294,6 +294,7 @@ CURLcode Curl_scp_connect(struct connectdata *conn, bool *done)
libssh2_realloc, NULL);
if (scp->scpSession == NULL) {
failf(data, "Failure initialising ssh session\n");
+ Curl_safefree(scp->path);
return CURLE_FAILED_INIT;
}
#ifdef CURL_LIBSSH2_DEBUG
@@ -302,6 +303,7 @@ CURLcode Curl_scp_connect(struct connectdata *conn, bool *done)
if (libssh2_session_startup(scp->scpSession, sock)) {
failf(data, "Failure establishing ssh session\n");
+ Curl_safefree(scp->path);
return CURLE_FAILED_INIT;
}
@@ -393,6 +395,7 @@ CURLcode Curl_scp_connect(struct connectdata *conn, bool *done)
if (!authed) {
failf(data, "Authentication failure\n");
+ Curl_safefree(scp->path);
return CURLE_FAILED_INIT;
}