-rw-r--r-- | lib/curl.cc | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/curl.cc b/lib/curl.cc index 3e69b47..6172828 100644 --- a/lib/curl.cc +++ b/lib/curl.cc @@ -1,54 +1,79 @@ #include <opkele/curl.h> #include "config.h" namespace opkele { namespace util { curl_t::~curl_t() throw() { if(_c) curl_easy_cleanup(_c); } curl_t& curl_t::operator=(CURL *c) { if(_c) curl_easy_cleanup(_c); _c = c; return *this; } CURLcode curl_t::misc_sets() { assert(_c); CURLcode r; (r=easy_setopt(CURLOPT_FOLLOWLOCATION,1)) || (r=easy_setopt(CURLOPT_MAXREDIRS,5)) || (r=easy_setopt(CURLOPT_DNS_CACHE_TIMEOUT,120)) || (r=easy_setopt(CURLOPT_DNS_USE_GLOBAL_CACHE,1)) || (r=easy_setopt(CURLOPT_USERAGENT,PACKAGE_NAME"/"PACKAGE_SRC_VERSION)) || (r=easy_setopt(CURLOPT_TIMEOUT,20)) #ifdef DISABLE_CURL_SSL_VERIFYHOST || (r=easy_setopt(CURLOPT_SSL_VERIFYHOST,0)) #endif #ifdef DISABLE_CURL_SSL_VERIFYPEER || (r=easy_setopt(CURLOPT_SSL_VERIFYPEER,0)) #endif ; return r; } static size_t _write(void *p,size_t s,size_t nm,void *stream) { return ((curl_t*)stream)->write(p,s,nm); } CURLcode curl_t::set_write() { assert(_c); CURLcode r; (r = easy_setopt(CURLOPT_WRITEDATA,this)) || (r = easy_setopt(CURLOPT_WRITEFUNCTION,_write)); return r; } + static int _progress(void *cp,double dlt,double dln,double ult,double uln) { + return ((curl_t*)cp)->progress(dlt,dln,ult,uln); + } + + CURLcode curl_t::set_progress() { + assert(_c); + CURLcode r; + (r = easy_setopt(CURLOPT_PROGRESSDATA,this)) + || (r = easy_setopt(CURLOPT_PROGRESSFUNCTION,_progress)) + || (r = easy_setopt(CURLOPT_NOPROGRESS,0)); + return r; + } + + static size_t _header(void *p,size_t s,size_t nm,void *stream) { + return ((curl_t*)stream)->header(p,s,nm); + } + + CURLcode curl_t::set_header() { + assert(_c); + CURLcode r; + (r = easy_setopt(CURLOPT_HEADERDATA,this)) + || (r=easy_setopt(CURLOPT_HEADERFUNCTION,_header)); + return r; + } + } } |