Mac Developer Library Developer


This manual page is part of Xcode Tools version 5.0

To obtain these tools:

If you are running a version of Xcode Tools other than 5.0, view the documentation locally:

  • In Xcode

  • In Terminal, using the man(1) command

Reading manual pages

Manual pages are intended as a quick reference for people who already understand a technology.

  • To learn how the manual is organized or to learn about command syntax, read the manual page for manpages(5).

  • For more information about this technology, look for other documentation in the Apple Developer Library.

  • For general information about writing shell scripts, read Shell Scripting Primer.

libcurl-share(3)                           libcurl share interface                          libcurl-share(3)

       libcurl-share - how to use the share interface

       This  is an overview on how to use the libcurl share interface in your C programs. There are specific
       man pages for each function mentioned in here.

       All functions in the share interface are prefixed with curl_share.

       The share interface was added to enable sharing of data between curl "handles".

       You can have multiple easy handles share data between them. Have them update and use the same  cookie
       database  or  DNS cache! This way, each single transfer will take advantage from data updates made by
       the other transfer(s).

       You create a shared object with curl_share_init(3). It returns a handle for a newly created one.

       You tell the shared object what data you want it to share by using curl_share_setopt(3).

       Since you can use this share from multiple threads, and libcurl has no internal  thread  synchroniza-tion, synchronization,
       tion,  you  must provide mutex callbacks if you're using this multi-threaded. You set lock and unlock
       functions with curl_share_setopt(3) too.

       Then,  you  make  an  easy  handle  to  use  this  share,  you  set  the  CURLOPT_SHARE  option  with
       curl_easy_setopt(3), and pass in share handle. You can make any number of easy handles share the same
       share handle.

       To make an easy handle stop using that particular share, you set CURLOPT_SHARE to NULL for that  easy
       handle. To make a handle stop sharing a particular data, you can CURLSHOPT_UNSHARE it.

       When  you're  done  using  the  share,  make  sure  that  no  easy handle is still using it, and call
       curl_share_cleanup(3) on the handle.

       curl_share_init(3), curl_share_setopt(3), curl_share_cleanup(3)

libcurl 7.10.7                                   8 Aug 2003                                 libcurl-share(3)

Reporting Problems

The way to report a problem with this manual page depends on the type of problem:

Content errors
Report errors in the content of this documentation with the feedback links below.
Bug reports
Report bugs in the functionality of the described tool or API through Bug Reporter.
Formatting problems
Report formatting mistakes in the online version of these pages with the feedback links below.