Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Kitware
GitHub Repository: Kitware/CMake
Path: blob/master/Utilities/cmcurl/include/curl/easy.h
5020 views
1
#ifndef CURLINC_EASY_H
2
#define CURLINC_EASY_H
3
/***************************************************************************
4
* _ _ ____ _
5
* Project ___| | | | _ \| |
6
* / __| | | | |_) | |
7
* | (__| |_| | _ <| |___
8
* \___|\___/|_| \_\_____|
9
*
10
* Copyright (C) Daniel Stenberg, <[email protected]>, et al.
11
*
12
* This software is licensed as described in the file COPYING, which
13
* you should have received as part of this distribution. The terms
14
* are also available at https://curl.se/docs/copyright.html.
15
*
16
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
17
* copies of the Software, and permit persons to whom the Software is
18
* furnished to do so, under the terms of the COPYING file.
19
*
20
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
21
* KIND, either express or implied.
22
*
23
* SPDX-License-Identifier: curl
24
*
25
***************************************************************************/
26
#ifdef __cplusplus
27
extern "C" {
28
#endif
29
30
/* Flag bits in the curl_blob struct: */
31
#define CURL_BLOB_COPY 1 /* tell libcurl to copy the data */
32
#define CURL_BLOB_NOCOPY 0 /* tell libcurl to NOT copy the data */
33
34
struct curl_blob {
35
void *data;
36
size_t len;
37
unsigned int flags; /* bit 0 is defined, the rest are reserved and should be
38
left zeroes */
39
};
40
41
CURL_EXTERN CURL *curl_easy_init(void);
42
CURL_EXTERN CURLcode curl_easy_setopt(CURL *curl, CURLoption option, ...);
43
CURL_EXTERN CURLcode curl_easy_perform(CURL *curl);
44
CURL_EXTERN void curl_easy_cleanup(CURL *curl);
45
46
/*
47
* NAME curl_easy_getinfo()
48
*
49
* DESCRIPTION
50
*
51
* Request internal information from the curl session with this function.
52
* The third argument MUST be pointing to the specific type of the used option
53
* which is documented in each man page of the option. The data pointed to
54
* will be filled in accordingly and can be relied upon only if the function
55
* returns CURLE_OK. This function is intended to get used *AFTER* a performed
56
* transfer, all results from this function are undefined until the transfer
57
* is completed.
58
*/
59
CURL_EXTERN CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...);
60
61
/*
62
* NAME curl_easy_duphandle()
63
*
64
* DESCRIPTION
65
*
66
* Creates a new curl session handle with the same options set for the handle
67
* passed in. Duplicating a handle could only be a matter of cloning data and
68
* options, internal state info and things like persistent connections cannot
69
* be transferred. It is useful in multi-threaded applications when you can run
70
* curl_easy_duphandle() for each new thread to avoid a series of identical
71
* curl_easy_setopt() invokes in every thread.
72
*/
73
CURL_EXTERN CURL *curl_easy_duphandle(CURL *curl);
74
75
/*
76
* NAME curl_easy_reset()
77
*
78
* DESCRIPTION
79
*
80
* Re-initializes a curl handle to the default values. This puts back the
81
* handle to the same state as it was in when it was just created.
82
*
83
* It does keep: live connections, the Session ID cache, the DNS cache and the
84
* cookies.
85
*/
86
CURL_EXTERN void curl_easy_reset(CURL *curl);
87
88
/*
89
* NAME curl_easy_recv()
90
*
91
* DESCRIPTION
92
*
93
* Receives data from the connected socket. Use after successful
94
* curl_easy_perform() with CURLOPT_CONNECT_ONLY option.
95
*/
96
CURL_EXTERN CURLcode curl_easy_recv(CURL *curl, void *buffer, size_t buflen,
97
size_t *n);
98
99
/*
100
* NAME curl_easy_send()
101
*
102
* DESCRIPTION
103
*
104
* Sends data over the connected socket. Use after successful
105
* curl_easy_perform() with CURLOPT_CONNECT_ONLY option.
106
*/
107
CURL_EXTERN CURLcode curl_easy_send(CURL *curl, const void *buffer,
108
size_t buflen, size_t *n);
109
110
/*
111
* NAME curl_easy_upkeep()
112
*
113
* DESCRIPTION
114
*
115
* Performs connection upkeep for the given session handle.
116
*/
117
CURL_EXTERN CURLcode curl_easy_upkeep(CURL *curl);
118
119
#ifdef __cplusplus
120
} /* end of extern "C" */
121
#endif
122
123
#endif
124
125