File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / curl / docs / libcurl / libcurl-easy.3
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Wed Jun 3 10:01:15 2020 UTC (4 years, 10 months ago) by misho
Branches: curl, MAIN
CVS tags: v7_70_0p4, HEAD
curl

    1: .\" **************************************************************************
    2: .\" *                                  _   _ ____  _
    3: .\" *  Project                     ___| | | |  _ \| |
    4: .\" *                             / __| | | | |_) | |
    5: .\" *                            | (__| |_| |  _ <| |___
    6: .\" *                             \___|\___/|_| \_\_____|
    7: .\" *
    8: .\" * Copyright (C) 1998 - 2020, Daniel Stenberg, <daniel@haxx.se>, et al.
    9: .\" *
   10: .\" * This software is licensed as described in the file COPYING, which
   11: .\" * you should have received as part of this distribution. The terms
   12: .\" * are also available at https://curl.haxx.se/docs/copyright.html.
   13: .\" *
   14: .\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell
   15: .\" * copies of the Software, and permit persons to whom the Software is
   16: .\" * furnished to do so, under the terms of the COPYING file.
   17: .\" *
   18: .\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
   19: .\" * KIND, either express or implied.
   20: .\" *
   21: .\" **************************************************************************
   22: .TH libcurl 3 "March 23, 2020" "libcurl 7.70.0" "libcurl easy interface"
   23: 
   24: .SH NAME
   25: libcurl-easy \- easy interface overview
   26: .SH DESCRIPTION
   27: When using libcurl's "easy" interface you init your session and get a handle
   28: (often referred to as an "easy handle"), which you use as input to the easy
   29: interface functions you use. Use \fIcurl_easy_init(3)\fP to get the handle.
   30: 
   31: You continue by setting all the options you want in the upcoming transfer, the
   32: most important among them is the URL itself (you can't transfer anything
   33: without a specified URL as you may have figured out yourself). You might want
   34: to set some callbacks as well that will be called from the library when data
   35: is available etc. \fIcurl_easy_setopt(3)\fP is used for all this.
   36: 
   37: \fICURLOPT_URL(3)\fP is only option you really must set, as otherwise there
   38: can be no transfer. Another commonly used option is \fICURLOPT_VERBOSE(3)\fP
   39: that will help you see what libcurl is doing under the hood, very useful when
   40: debugging for example. The \fIcurl_easy_setopt(3)\fP man page has a full index
   41: of the over 200 available options.
   42: 
   43: If you at any point would like to blank all previously set options for a
   44: single easy handle, you can call \fIcurl_easy_reset(3)\fP and you can also
   45: make a clone of an easy handle (with all its set options) using
   46: \fIcurl_easy_duphandle(3)\fP.
   47: 
   48: When all is setup, you tell libcurl to perform the transfer using
   49: \fIcurl_easy_perform(3)\fP.  It will then do the entire operation and won't
   50: return until it is done (successfully or not).
   51: 
   52: After the transfer has been made, you can set new options and make another
   53: transfer, or if you're done, cleanup the session by calling
   54: \fIcurl_easy_cleanup(3)\fP. If you want persistent connections, you don't
   55: cleanup immediately, but instead run ahead and perform other transfers using
   56: the same easy handle.
   57: .SH "SEE ALSO"
   58: .BR curl_easy_init "(3)," curl_easy_cleanup "(3)," curl_easy_setopt "(3), "
   59: .BR libcurl-errors "(3), " libcurl-multi "(3), " libcurl "(3) "

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>