mirror of
https://github.com/curl/curl.git
synced 2025-01-24 14:15:18 +08:00
When setting *_URL or *_PROXY in *_setopt(), it is important that we check
and possibly free the existing pointer first, and then clear the "allocated" bit. We previously mistakenly could free the new pointer passed to us by the friendly user...!
This commit is contained in:
parent
c9c2115088
commit
12acab9b86
17
lib/url.c
17
lib/url.c
@ -483,9 +483,8 @@ CURLcode Curl_setopt(struct UrlData *data, CURLoption option, ...)
|
|||||||
* Set cookie file to read and parse.
|
* Set cookie file to read and parse.
|
||||||
*/
|
*/
|
||||||
cookiefile = (char *)va_arg(param, void *);
|
cookiefile = (char *)va_arg(param, void *);
|
||||||
if(cookiefile) {
|
if(cookiefile)
|
||||||
data->cookies = Curl_cookie_init(cookiefile);
|
data->cookies = Curl_cookie_init(cookiefile, data->cookies);
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case CURLOPT_WRITEHEADER:
|
case CURLOPT_WRITEHEADER:
|
||||||
/*
|
/*
|
||||||
@ -582,6 +581,11 @@ CURLcode Curl_setopt(struct UrlData *data, CURLoption option, ...)
|
|||||||
/*
|
/*
|
||||||
* The URL to fetch.
|
* The URL to fetch.
|
||||||
*/
|
*/
|
||||||
|
if(data->bits.urlstringalloc) {
|
||||||
|
/* the already set URL is allocated, free it first! */
|
||||||
|
free(data->url);
|
||||||
|
data->bits.urlstringalloc=FALSE;
|
||||||
|
}
|
||||||
data->url = va_arg(param, char *);
|
data->url = va_arg(param, char *);
|
||||||
break;
|
break;
|
||||||
case CURLOPT_PORT:
|
case CURLOPT_PORT:
|
||||||
@ -628,6 +632,13 @@ CURLcode Curl_setopt(struct UrlData *data, CURLoption option, ...)
|
|||||||
/*
|
/*
|
||||||
* Set proxy server:port to use as HTTP proxy
|
* Set proxy server:port to use as HTTP proxy
|
||||||
*/
|
*/
|
||||||
|
if(data->bits.proxystringalloc) {
|
||||||
|
/*
|
||||||
|
* The already set string is allocated, free that first
|
||||||
|
*/
|
||||||
|
data->bits.proxystringalloc=FALSE;;
|
||||||
|
free(data->proxy);
|
||||||
|
}
|
||||||
data->proxy = va_arg(param, char *);
|
data->proxy = va_arg(param, char *);
|
||||||
data->bits.httpproxy = data->proxy?1:0;
|
data->bits.httpproxy = data->proxy?1:0;
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user