From: Daniel Stenberg Date: Wed, 5 Sep 2001 07:24:01 +0000 (+0000) Subject: first shaky and stumbling attempts at a *_duphandle() function X-Git-Tag: curl-7_9~77 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=610ec27d933843a0d5f954383f599aa33002e0e5;p=thirdparty%2Fcurl.git first shaky and stumbling attempts at a *_duphandle() function --- diff --git a/lib/easy.c b/lib/easy.c index 38ae32082d..f9cb6d8607 100644 --- a/lib/easy.c +++ b/lib/easy.c @@ -250,3 +250,30 @@ CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...) return Curl_getinfo(data, info, paramp); } + +CURL *curl_easy_duphandle(CURL *incurl) +{ + struct SessionHandle *data=(struct SessionHandle *)incurl; + + struct SessionHandle *outcurl = malloc(sizeof(struct SessionHandle)); + + if(NULL == outcurl) + return NULL; /* failure */ + + /* start with clearing the entire new struct */ + memset(outcurl, 0, sizeof(struct SessionHandle)); + + /* copy all userdefined values */ + outcurl->set = data->set; + + /* duplicate all values in 'change' */ + outcurl->change.url = strdup(data->change.url); + outcurl->change.proxy = strdup(data->change.proxy); + outcurl->change.referer = strdup(data->change.referer); + /* set all the alloc-bits */ + outcurl->change.url_alloc = + outcurl->change.proxy_alloc = + outcurl->change.referer_alloc = TRUE; + + return outcurl; +}