curl / libcurl / API / curl_multi_setopt / CURLMOPT_NETWORK_CHANGED

CURLMOPT_NETWORK_CHANGED explained

Name

CURLMOPT_NETWORK_CHANGED - signal network changed

Synopsis

#include <curl/curl.h>
 
CURLMcode curl_multi_setopt(CURLM *handle, CURLMOPT_NETWORK_CHANGED,
                            long value);

Description

Pass a long with a bitmask to tell libcurl how the multi handle should react. The following values in the mask are defined. All bits not mentioned are reserved for future extensions.

This option can be set at any time and repeatedly. Each call only affects the currently cached connections and DNS information. Any connection created or DNS information added afterwards is cached the usual way again. Phrasing it another way: the option is not persisted but setting it serves as a "trigger" to clear the caches.

The call affects only the connection and DNS cache of the multi handle itself and not the ones owned by SHARE handles.

CURLMNWC_CLEAR_CONNS

No longer reuse any existing connection in the multi handle's connection cache. This closes all connections that are not in use. Ongoing transfers continue on the connections they operate on.

CURLMNWC_CLEAR_DNS

Clear the multi handle's DNS cache.

Default

0, which has no effect.

Protocols

This functionality affects all supported protocols

Example

int main(void)
{
  CURLM *m = curl_multi_init();
  /* do transfers on the multi handle */
  /* do not reuse existing connections */
  curl_multi_setopt(m, CURLMOPT_NETWORK_CHANGED, CURLMNWC_CLEAR_CONNS);
}

Availability

Added in curl 8.16.0

Return value

curl_multi_setopt returns a CURLMcode indicating success or error.

CURLM_OK (0) means everything was OK, non-zero means an error occurred, see libcurl-errors.

See also

CURLOPT_FORBID_REUSE(3), CURLOPT_FRESH_CONNECT(3)

This HTML page was made with roffit.