diff --git a/lib/ftp.c b/lib/ftp.c index c6f8b6191fea52bf55f93f0d00a712ad1cdb1bb4..6ec17c11a4037a2f78d634d4622f54268ff42a2e 100644 --- a/lib/ftp.c +++ b/lib/ftp.c @@ -545,9 +545,6 @@ CURLcode Curl_ftp_done(struct connectdata *conn) } } - free(ftp); - data->proto.ftp=NULL; /* it is gone */ - return CURLE_OK; } diff --git a/lib/http.c b/lib/http.c index 54623ec6bc3619b327a97d42e96fa0f2b181d194..93ae049b14416cb904db8f3d729a9e694b3b698c 100644 --- a/lib/http.c +++ b/lib/http.c @@ -375,9 +375,6 @@ CURLcode Curl_http_done(struct connectdata *conn) *bytecount = http->readbytecount + http->writebytecount; } - free(http); - data->proto.http=NULL; /* it is gone */ - return CURLE_OK; } diff --git a/lib/url.c b/lib/url.c index 2348ac2d6223262f3d6b42e0997fb58a6f07d5fa..7fe2fc1e9066136df78d85715c2d93f014dab603 100644 --- a/lib/url.c +++ b/lib/url.c @@ -561,6 +561,10 @@ CURLcode curl_disconnect(CURLconnect *c_connect) struct UrlData *data = conn->data; + if(data->proto.generic) + free(data->proto.generic); + data->proto.generic=NULL; /* it is gone */ + #ifdef ENABLE_IPV6 if(conn->res) /* host name info */ freeaddrinfo(conn->res); @@ -1644,7 +1648,13 @@ CURLcode curl_do(CURLconnect *in_conn) if(!conn || (conn->handle!= STRUCT_CONNECT)) { return CURLE_BAD_FUNCTION_ARGUMENT; } - if(conn->state != CONN_INIT) { + switch(conn->state) { + case CONN_INIT: + case CONN_DONE: + /* these two states are OK */ + break; + default: + /* anything else is bad */ return CURLE_BAD_CALLING_ORDER; }