Cleans up a common pattern somewhat. Implemented as a macro.
Closes #19834
```
Returns the stored length of the referenced buffer.
+
+## `dup`
+
+```c
+char *Curl_bufref_dup(const struct bufref *br);
+```
+
+Returns a strdup() version of the buffer. Note that this assumes that the
+bufref is null terminated.
CURLcode Curl_bufref_memdup0(struct bufref *br, const void *ptr, size_t len);
void Curl_bufref_free(struct bufref *br);
+/* return a strdup() version of the buffer */
+#define Curl_bufref_dup(x) curlx_strdup(Curl_bufref_ptr(x))
+
#endif
if(Curl_bufref_ptr(&data->state.url)) {
Curl_bufref_set(&outcurl->state.url,
- curlx_strdup(Curl_bufref_ptr(&data->state.url)), 0,
+ Curl_bufref_dup(&data->state.url), 0,
curl_free);
if(!Curl_bufref_ptr(&outcurl->state.url))
goto fail;
}
if(Curl_bufref_ptr(&data->state.referer)) {
Curl_bufref_set(&outcurl->state.referer,
- curlx_strdup(Curl_bufref_ptr(&data->state.referer)), 0,
+ Curl_bufref_dup(&data->state.referer), 0,
curl_free);
if(!Curl_bufref_ptr(&outcurl->state.referer))
goto fail;
out in bug #2284386 */
curlx_free(data->req.newurl);
/* clone URL */
- data->req.newurl = curlx_strdup(Curl_bufref_ptr(&data->state.url));
+ data->req.newurl = Curl_bufref_dup(&data->state.url);
if(!data->req.newurl)
return CURLE_OUT_OF_MEMORY;
}
if((data->state.httpreq != HTTPREQ_GET) &&
(data->state.httpreq != HTTPREQ_HEAD)) {
/* clone URL */
- data->req.newurl = curlx_strdup(Curl_bufref_ptr(&data->state.url));
+ data->req.newurl = Curl_bufref_dup(&data->state.url);
if(!data->req.newurl)
return CURLE_OUT_OF_MEMORY;
data->state.authhost.done = TRUE;
&conn->http_negotiate_state;
if(!result) {
curlx_free(data->req.newurl);
- data->req.newurl = curlx_strdup(Curl_bufref_ptr(&data->state.url));
+ data->req.newurl = Curl_bufref_dup(&data->state.url);
if(!data->req.newurl)
return CURLE_OUT_OF_MEMORY;
data->state.authproblem = FALSE;
data->state.disableexpect = TRUE;
Curl_req_abort_sending(data);
DEBUGASSERT(!data->req.newurl);
- data->req.newurl = curlx_strdup(Curl_bufref_ptr(&data->state.url));
+ data->req.newurl = Curl_bufref_dup(&data->state.url);
if(!data->req.newurl) {
result = CURLE_OUT_OF_MEMORY;
goto out;
data->state.errorbuf = FALSE;
if(!newurl)
/* typically for HTTP_1_1_REQUIRED error on first flight */
- newurl = curlx_strdup(Curl_bufref_ptr(&data->state.url));
+ newurl = Curl_bufref_dup(&data->state.url);
if(!newurl) {
result = CURLE_OUT_OF_MEMORY;
}
}
infof(data, "Connection died, retrying a fresh connect (retry count: %d)",
data->state.retrycount);
- *url = curlx_strdup(Curl_bufref_ptr(&data->state.url));
+ *url = Curl_bufref_dup(&data->state.url);
if(!*url)
return CURLE_OUT_OF_MEMORY;