1
0
mirror of https://github.com/moparisthebest/curl synced 2025-01-06 03:18:04 -05:00
curl/docs/examples
Yang Tse 5a053ffe80 build: fix circular header inclusion with other packages
This commit renames lib/setup.h to lib/curl_setup.h and
renames lib/setup_once.h to lib/curl_setup_once.h.

Removes the need and usage of a header inclusion guard foreign
to libcurl. [1]

Removes the need and presence of an alarming notice we carried
in old setup_once.h [2]

----------------------------------------

1 - lib/setup_once.h used __SETUP_ONCE_H macro as header inclusion guard
    up to commit ec691ca3 which changed this to HEADER_CURL_SETUP_ONCE_H,
    this single inclusion guard is enough to ensure that inclusion of
    lib/setup_once.h done from lib/setup.h is only done once.

    Additionally lib/setup.h has always used __SETUP_ONCE_H macro to
    protect inclusion of setup_once.h even after commit ec691ca3, this
    was to avoid a circular header inclusion triggered when building a
    c-ares enabled version with c-ares sources available which also has
    a setup_once.h header. Commit ec691ca3 exposes the real nature of
    __SETUP_ONCE_H usage in lib/setup.h, it is a header inclusion guard
    foreign to libcurl belonging to c-ares's setup_once.h

    The renaming this commit does, fixes the circular header inclusion,
    and as such removes the need and usage of a header inclusion guard
    foreign to libcurl. Macro __SETUP_ONCE_H no longer used in libcurl.

2 - Due to the circular interdependency of old lib/setup_once.h and the
    c-ares setup_once.h header, old file lib/setup_once.h has carried
    back from 2006 up to now days an alarming and prominent notice about
    the need of keeping libcurl's and c-ares's setup_once.h in sync.

    Given that this commit fixes the circular interdependency, the need
    and presence of mentioned notice is removed.

    All mentioned interdependencies come back from now old days when
    the c-ares project lived inside a curl subdirectory. This commit
    removes last traces of such fact.
2013-01-09 00:49:50 +01:00
..
.gitignore ftpsget: simple example showing a FTPS fetch 2012-08-27 14:50:09 +02:00
10-at-a-time.c sources: update source headers 2011-03-10 12:04:33 +01:00
adddocsref.pl add URLs in comments for all libcurl function calls 2004-11-22 13:39:23 +00:00
anyauthput.c examples/anyauthput.c: fix Tru64 compilation issue 2012-12-10 15:42:12 +01:00
asiohiper.cpp examples: Updated asiohiper.cpp to remove connect from opensocket 2012-11-25 18:37:07 +01:00
cacertinmem.c sources: update source headers 2011-03-10 12:04:33 +01:00
certinfo.c examples/certinfo.c: fix compiler warning 2012-12-29 22:17:06 +01:00
chkspeed.c examples: cleanup curl includes 2011-06-28 19:08:51 +02:00
cookie_interface.c examples: fix compilation issues - commit 7332a7cafb follow-up 2012-12-05 12:59:14 +01:00
curlgtk.c examples: cleanup curl includes 2011-06-28 19:08:51 +02:00
curlx.c OpenSSL: remove reference to openssl internal struct 2012-01-04 23:02:36 +01:00
debug.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
evhiperfifo.c evhiperfifo: fix the pointer passed to WRITEDATA 2012-11-01 14:20:58 +01:00
externalsocket.c examples/externalsocket.c: fix SunPro compilation issue 2012-12-10 18:06:35 +01:00
fileupload.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
fopen.c example: fix compiler warnings in fopen.c 2010-12-17 00:09:48 +01:00
ftp-wildcard.c examples: fix compiler warnings 2012-04-13 17:59:49 +02:00
ftpget.c examples: cleanup curl includes 2011-06-28 19:08:51 +02:00
ftpgetinfo.c examples: fix compilation issues - commit 23f8dca6fb follow-up 2012-12-05 11:43:40 +01:00
ftpgetresp.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
ftpsget.c ftpsget: simple example showing a FTPS fetch 2012-08-27 14:50:09 +02:00
ftpupload.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
ftpuploadresume.c MinGW64 has this prototype already. 2011-09-23 03:56:34 +02:00
getinfo.c sources: update source headers 2011-03-10 12:04:33 +01:00
getinmemory.c getinmemory.c: use better argument names for write callback 2011-09-07 22:43:28 +02:00
ghiper.c sources: update source headers 2011-03-10 12:04:33 +01:00
hiperfifo.c sources: update source headers 2011-03-10 12:04:33 +01:00
href_extractor.c href_extractor.c: fix the URL 2012-10-18 19:42:31 +02:00
htmltidy.c sources: update source headers 2011-03-10 12:04:33 +01:00
htmltitle.cpp htmltitle: use .cpp extension for C++ examples 2012-11-21 18:26:42 +01:00
http-post.c Added curl_global_* functions. 2012-07-12 02:02:57 +02:00
httpcustomheader.c httpcustomheader.c: free the headers after use 2012-11-06 11:51:19 +01:00
httpput.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
https.c https.c example: remember to call curl_global_init() 2012-10-01 11:23:51 +02:00
imap.c examples: fix compiler warnings 2012-04-13 17:59:49 +02:00
Makefile.am build: fix circular header inclusion with other packages 2013-01-09 00:49:50 +01:00
makefile.dj examples/makefile.dj: update email 2011-04-07 15:16:38 +02:00
Makefile.example source header: added to more files 2011-03-12 00:14:32 +01:00
Makefile.inc htmltitle: use .cpp extension for C++ examples 2012-11-21 18:26:42 +01:00
Makefile.m32 MinGW makefile tweaks for running from sh. 2012-07-03 12:56:41 +02:00
Makefile.netware Updated dependency libary versions. 2012-05-22 04:15:37 +02:00
multi-app.c examples: use do/while loop for multi examples 2012-08-27 15:10:13 +02:00
multi-debugcallback.c examples: use do/while loop for multi examples 2012-08-27 15:10:13 +02:00
multi-double.c examples: use do/while loop for multi examples 2012-08-27 15:10:13 +02:00
multi-post.c examples: use do/while loop for multi examples 2012-08-27 15:10:13 +02:00
multi-single.c examples: use do/while loop for multi examples 2012-08-27 15:10:13 +02:00
multithread.c sources: update source headers 2011-03-10 12:04:33 +01:00
opensslthreadlock.c sources: update source headers 2011-03-10 12:04:33 +01:00
persistant.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
pop3s.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
pop3slist.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
post-callback.c examples: fix compilation issues - commit 23f8dca6fb follow-up 2012-12-05 11:43:40 +01:00
postit2.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
progressfunc.c examples: fix compilation issues 2012-12-05 00:37:57 +01:00
README examples: updated README with two new example programs 2012-01-20 22:44:59 -08:00
resolve.c resolve.c: new example showing off CURLOPT_RESOLVE 2011-08-23 16:31:10 +02:00
rtsp.c examples: fix compilation issues - commit 7332a7cafb follow-up 2012-12-05 12:59:14 +01:00
sampleconv.c sources: update source headers 2011-03-10 12:04:33 +01:00
sendrecv.c examples: fix compiler warnings 2012-04-13 17:59:49 +02:00
sepheaders.c examples: cleanup curl includes 2011-06-28 19:08:51 +02:00
sftpget.c sftpget: SFTP is not "SSH FTP" 2012-08-27 14:42:56 +02:00
simple.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
simplepost.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
simplesmtp.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
simplessl.c examples/simplessl.c: fix compiler warning 2012-12-11 15:03:17 +01:00
smooth-gtk-thread.c examples: cleanup curl includes 2011-06-28 19:08:51 +02:00
smtp-multi.c Removed non-used variable. 2012-07-04 22:14:18 +02:00
smtp-tls.c Added error checking for samples. 2012-07-04 17:03:52 +02:00
synctime.c Fixed scanf format for WORD = unsigned short. 2011-09-23 03:21:50 +02:00
threaded-ssl.c sources: update source headers 2011-03-10 12:04:33 +01:00
url2file.c url2file: new simple example 2012-01-16 14:47:00 +01:00
version-check.pl removed trailing whitespace 2011-12-30 03:36:18 +01:00

                                  _   _ ____  _
                              ___| | | |  _ \| |
                             / __| | | | |_) | |
                            | (__| |_| |  _ <| |___
                             \___|\___/|_| \_\_____|

This directory is for libcurl programming examples. They are meant to show
some simple steps on how you can build your own application to take full
advantage of libcurl.

If you end up with other small but still useful example sources, please mail
them for submission in future packages and on the web site.

BUILDING

The Makefile.example is an example makefile that could be used to build these
examples. Just edit the file according to your system and requirements first.

Most examples should build fine using a command line like this:

  $ `curl-config --cc --cflags --libs` -o example example.c

Some compilers don't like having the arguments in this order but instead
want you do reorganize them like:

  $ `curl-config --cc` -o example example.c `curl-config --cflags --libs`

*PLEASE* do not use the curl.haxx.se site as a test target for your libcurl
applications/experiments. Even if some of the examples use that site as a URL
at some places, it doesn't mean that the URLs work or that we expect you to
actually torture our web site with your tests!  Thanks.

EXAMPLES

anyauthput.c   - HTTP PUT using "any" authentication method
cacertinmem.c  - Use a built-in PEM certificate to retrieve a https page
cookie_interface.c - shows usage of simple cookie interface
curlgtk.c      - download using a GTK progress bar
curlx.c        - getting file info from the remote cert data
debug.c        - showing how to use the debug callback
fileupload.c   - uploading to a file:// URL
fopen.c        - fopen() layer that supports opening URLs and files
ftpget.c       - simple getting a file from FTP
ftpgetresp.c   - get the response strings from the FTP server
ftpupload.c    - upload a file to an FTP server
ftpuploadresume.c - resume an upload to an FTP server
getinfo.c      - get the Content-Type from the recent transfer
getinmemory.c  - download a file to memory only
ghiper.c       - curl_multi_socket() using code with glib-2
hiperfifo.c    - downloads all URLs written to the fifo, using
                 curl_multi_socket() and libevent
htmltidy.c     - download a document and use libtidy to parse the HTML
htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML
                 page using libxml
http-post.c    - HTTP POST
httpput.c      - HTTP PUT a local file
https.c        - simple HTTPS transfer
imap.c         - simple IMAP transfer
multi-app.c    - a multi-interface app
multi-debugcallback.c - a multi-interface app using the debug callback
multi-double.c - a multi-interface app doing two simultaneous transfers
multi-post.c   - a multi-interface app doing a multipart formpost
multi-single.c - a multi-interface app getting a single file
multithread.c  - an example using multi-treading transferring multiple files
opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded
persistant.c   - request two URLs with a persistent connection
pop3s.c        - POP3S transfer
pop3slist.c    - POP3S LIST
post-callback.c - send a HTTP POST using a callback
postit2.c      - send a HTTP multipart formpost
sampleconv.c   - showing how a program on a non-ASCII platform would invoke
                 callbacks to do its own codeset conversions instead of using
                 the built-in iconv functions in libcurl
sepheaders.c   - download headers to a separate file
simple.c       - the most simple download a URL source
simplepost.c   - HTTP POST
simplessl.c    - HTTPS example with certificates many options set
synctime.c     - Sync local time by extracting date from remote HTTP servers
url2file.c     - download a document and store it in a file
10-at-a-time.c - Download many files simultaneously, 10 at a time.