18 #ifndef KVIKIO_LIBCURL_FOUND
20 "cannot include the remote IO API, please build KvikIO with libcurl (-DKvikIO_REMOTE_SUPPORT=ON)"
29 #include <curl/curl.h>
53 using UniqueHandlePtr = std::unique_ptr<CURL, std::function<decltype(curl_easy_cleanup)>>;
58 std::vector<UniqueHandlePtr> _free_curl_handles{};
90 char _errbuf[CURL_ERROR_SIZE];
91 LibCurl::UniqueHandlePtr _handle;
92 std::string _source_file;
93 std::string _source_line;
105 CurlHandle(LibCurl::UniqueHandlePtr
handle, std::string source_file, std::string source_line);
129 template <typename VAL>
130 void setopt(CURLoption option, VAL value)
132 CURLcode err = curl_easy_setopt(
handle(), option, value);
133 if (err != CURLE_OK) {
134 std::stringstream ss;
135 ss <<
"curl_easy_setopt() error near " << _source_file <<
":" << _source_line;
136 ss <<
"(" << curl_easy_strerror(err) <<
")";
137 throw std::runtime_error(ss.str());
156 template <
typename OUTPUT>
159 CURLcode err = curl_easy_getinfo(
handle(), info, output);
160 if (err != CURLE_OK) {
161 std::stringstream ss;
162 ss <<
"curl_easy_getinfo() error near " << _source_file <<
":" << _source_line;
163 ss <<
"(" << curl_easy_strerror(err) <<
")";
164 throw std::runtime_error(ss.str());
184 __attribute__((noinline))
inline std::string fix_conda_file_path_hack(std::string filename)
186 if (filename.data() !=
nullptr) {
return std::string{filename.data()}; }
187 return std::string{};
196 #define create_curl_handle() \
197 kvikio::CurlHandle(kvikio::LibCurl::instance().get_handle(), \
198 kvikio::detail::fix_conda_file_path_hack(__FILE__), \
199 KVIKIO_STRINGIFY(__LINE__))
Representation of a curl easy handle pointer and its operations.
void setopt(CURLoption option, VAL value)
Set option for the curl handle.
CurlHandle(LibCurl::UniqueHandlePtr handle, std::string source_file, std::string source_line)
Construct a new curl handle.
void getinfo(CURLINFO info, OUTPUT *output)
Extract information from a curl handle.
void perform()
Perform a blocking network transfer using previously set options.
CURL * handle() noexcept
Get the underlying curl easy handle pointer.
Singleton class to initialize and cleanup the global state of libcurl.
UniqueHandlePtr get_free_handle()
Returns a free curl handle if available.
void retain_handle(UniqueHandlePtr handle)
Retain a curl handle for later use.
UniqueHandlePtr get_handle()
Returns a curl handle, create a new handle if none is available.