mirror of
https://github.com/moparisthebest/curl
synced 2025-01-11 22:18:00 -05:00
curl: improved skip-setopt-options when built with disabled features
Reduces #ifdefs in src/tool_operate.c
Follow-up from 4e86f2fc4e
Closes #3936
This commit is contained in:
parent
6c2f9bea70
commit
b9e0c6d28c
@ -825,9 +825,8 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
|
|
||||||
/* where to store */
|
/* where to store */
|
||||||
my_setopt(curl, CURLOPT_WRITEDATA, &outs);
|
my_setopt(curl, CURLOPT_WRITEDATA, &outs);
|
||||||
#ifndef CURL_DISABLE_RTSP
|
|
||||||
my_setopt(curl, CURLOPT_INTERLEAVEDATA, &outs);
|
my_setopt(curl, CURLOPT_INTERLEAVEDATA, &outs);
|
||||||
#endif
|
|
||||||
if(metalink || !config->use_metalink)
|
if(metalink || !config->use_metalink)
|
||||||
/* what call to write */
|
/* what call to write */
|
||||||
my_setopt(curl, CURLOPT_WRITEFUNCTION, tool_write_cb);
|
my_setopt(curl, CURLOPT_WRITEFUNCTION, tool_write_cb);
|
||||||
@ -875,7 +874,6 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
if(config->oauth_bearer)
|
if(config->oauth_bearer)
|
||||||
my_setopt_str(curl, CURLOPT_XOAUTH2_BEARER, config->oauth_bearer);
|
my_setopt_str(curl, CURLOPT_XOAUTH2_BEARER, config->oauth_bearer);
|
||||||
|
|
||||||
#if !defined(CURL_DISABLE_PROXY)
|
|
||||||
{
|
{
|
||||||
my_setopt_str(curl, CURLOPT_PROXY, config->proxy);
|
my_setopt_str(curl, CURLOPT_PROXY, config->proxy);
|
||||||
/* new in libcurl 7.5 */
|
/* new in libcurl 7.5 */
|
||||||
@ -914,7 +912,6 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
my_setopt(curl, CURLOPT_SUPPRESS_CONNECT_HEADERS,
|
my_setopt(curl, CURLOPT_SUPPRESS_CONNECT_HEADERS,
|
||||||
config->suppress_connect_headers?1L:0L);
|
config->suppress_connect_headers?1L:0L);
|
||||||
}
|
}
|
||||||
#endif /* !CURL_DISABLE_PROXY */
|
|
||||||
|
|
||||||
my_setopt(curl, CURLOPT_FAILONERROR, config->failonerror?1L:0L);
|
my_setopt(curl, CURLOPT_FAILONERROR, config->failonerror?1L:0L);
|
||||||
my_setopt(curl, CURLOPT_REQUEST_TARGET, config->request_target);
|
my_setopt(curl, CURLOPT_REQUEST_TARGET, config->request_target);
|
||||||
@ -1017,9 +1014,7 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
|
|
||||||
} /* (built_in_protos & CURLPROTO_HTTP) */
|
} /* (built_in_protos & CURLPROTO_HTTP) */
|
||||||
|
|
||||||
#ifndef CURL_DISABLE_FTP
|
|
||||||
my_setopt_str(curl, CURLOPT_FTPPORT, config->ftpport);
|
my_setopt_str(curl, CURLOPT_FTPPORT, config->ftpport);
|
||||||
#endif
|
|
||||||
my_setopt(curl, CURLOPT_LOW_SPEED_LIMIT,
|
my_setopt(curl, CURLOPT_LOW_SPEED_LIMIT,
|
||||||
config->low_speed_limit);
|
config->low_speed_limit);
|
||||||
my_setopt(curl, CURLOPT_LOW_SPEED_TIME, config->low_speed_time);
|
my_setopt(curl, CURLOPT_LOW_SPEED_TIME, config->low_speed_time);
|
||||||
@ -1034,9 +1029,8 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
my_setopt(curl, CURLOPT_RESUME_FROM_LARGE, CURL_OFF_T_C(0));
|
my_setopt(curl, CURLOPT_RESUME_FROM_LARGE, CURL_OFF_T_C(0));
|
||||||
|
|
||||||
my_setopt_str(curl, CURLOPT_KEYPASSWD, config->key_passwd);
|
my_setopt_str(curl, CURLOPT_KEYPASSWD, config->key_passwd);
|
||||||
#ifndef CURL_DISABLE_PROXY
|
|
||||||
my_setopt_str(curl, CURLOPT_PROXY_KEYPASSWD, config->proxy_key_passwd);
|
my_setopt_str(curl, CURLOPT_PROXY_KEYPASSWD, config->proxy_key_passwd);
|
||||||
#endif
|
|
||||||
if(built_in_protos & (CURLPROTO_SCP|CURLPROTO_SFTP)) {
|
if(built_in_protos & (CURLPROTO_SCP|CURLPROTO_SFTP)) {
|
||||||
|
|
||||||
/* SSH and SSL private key uses same command-line option */
|
/* SSH and SSL private key uses same command-line option */
|
||||||
@ -1213,7 +1207,6 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
my_setopt_slist(curl, CURLOPT_POSTQUOTE, config->postquote);
|
my_setopt_slist(curl, CURLOPT_POSTQUOTE, config->postquote);
|
||||||
my_setopt_slist(curl, CURLOPT_PREQUOTE, config->prequote);
|
my_setopt_slist(curl, CURLOPT_PREQUOTE, config->prequote);
|
||||||
|
|
||||||
#if !defined(CURL_DISABLE_HTTP) && !defined(CURL_DISABLE_COOKIES)
|
|
||||||
if(config->cookie)
|
if(config->cookie)
|
||||||
my_setopt_str(curl, CURLOPT_COOKIE, config->cookie);
|
my_setopt_str(curl, CURLOPT_COOKIE, config->cookie);
|
||||||
|
|
||||||
@ -1226,13 +1219,6 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
|
|
||||||
/* new in libcurl 7.9.7 */
|
/* new in libcurl 7.9.7 */
|
||||||
my_setopt(curl, CURLOPT_COOKIESESSION, config->cookiesession?1L:0L);
|
my_setopt(curl, CURLOPT_COOKIESESSION, config->cookiesession?1L:0L);
|
||||||
#else
|
|
||||||
if(config->cookie || config->cookiefile || config->cookiejar) {
|
|
||||||
warnf(config->global, "cookie option(s) used even though cookie "
|
|
||||||
"support is disabled!\n");
|
|
||||||
return CURLE_NOT_BUILT_IN;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
my_setopt_enum(curl, CURLOPT_TIMECONDITION, (long)config->timecond);
|
my_setopt_enum(curl, CURLOPT_TIMECONDITION, (long)config->timecond);
|
||||||
my_setopt(curl, CURLOPT_TIMEVALUE_LARGE, config->condtime);
|
my_setopt(curl, CURLOPT_TIMEVALUE_LARGE, config->condtime);
|
||||||
@ -1242,9 +1228,8 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
|
|
||||||
/* three new ones in libcurl 7.3: */
|
/* three new ones in libcurl 7.3: */
|
||||||
my_setopt_str(curl, CURLOPT_INTERFACE, config->iface);
|
my_setopt_str(curl, CURLOPT_INTERFACE, config->iface);
|
||||||
#ifndef CURL_DISABLE_FTP
|
|
||||||
my_setopt_str(curl, CURLOPT_KRBLEVEL, config->krblevel);
|
my_setopt_str(curl, CURLOPT_KRBLEVEL, config->krblevel);
|
||||||
#endif
|
|
||||||
progressbarinit(&progressbar, config);
|
progressbarinit(&progressbar, config);
|
||||||
if((global->progressmode == CURL_PROGRESS_BAR) &&
|
if((global->progressmode == CURL_PROGRESS_BAR) &&
|
||||||
!global->noprogress && !global->mute) {
|
!global->noprogress && !global->mute) {
|
||||||
@ -1266,10 +1251,9 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
if(config->dns_ipv6_addr)
|
if(config->dns_ipv6_addr)
|
||||||
my_setopt_str(curl, CURLOPT_DNS_LOCAL_IP6, config->dns_ipv6_addr);
|
my_setopt_str(curl, CURLOPT_DNS_LOCAL_IP6, config->dns_ipv6_addr);
|
||||||
|
|
||||||
#ifndef CURL_DISABLE_TELNET
|
|
||||||
/* new in libcurl 7.6.2: */
|
/* new in libcurl 7.6.2: */
|
||||||
my_setopt_slist(curl, CURLOPT_TELNETOPTIONS, config->telnet_options);
|
my_setopt_slist(curl, CURLOPT_TELNETOPTIONS, config->telnet_options);
|
||||||
#endif
|
|
||||||
/* new in libcurl 7.7: */
|
/* new in libcurl 7.7: */
|
||||||
my_setopt_str(curl, CURLOPT_RANDOM_FILE, config->random_file);
|
my_setopt_str(curl, CURLOPT_RANDOM_FILE, config->random_file);
|
||||||
my_setopt_str(curl, CURLOPT_EGDSOCKET, config->egd_file);
|
my_setopt_str(curl, CURLOPT_EGDSOCKET, config->egd_file);
|
||||||
@ -1372,30 +1356,26 @@ static CURLcode operate_do(struct GlobalConfig *global,
|
|||||||
my_setopt_str(curl, CURLOPT_SERVICE_NAME,
|
my_setopt_str(curl, CURLOPT_SERVICE_NAME,
|
||||||
config->service_name);
|
config->service_name);
|
||||||
|
|
||||||
#ifndef CURL_DISABLE_FTP
|
|
||||||
/* curl 7.13.0 */
|
/* curl 7.13.0 */
|
||||||
my_setopt_str(curl, CURLOPT_FTP_ACCOUNT, config->ftp_account);
|
my_setopt_str(curl, CURLOPT_FTP_ACCOUNT, config->ftp_account);
|
||||||
#endif
|
|
||||||
my_setopt(curl, CURLOPT_IGNORE_CONTENT_LENGTH, config->ignorecl?1L:0L);
|
my_setopt(curl, CURLOPT_IGNORE_CONTENT_LENGTH, config->ignorecl?1L:0L);
|
||||||
|
|
||||||
#ifndef CURL_DISABLE_FTP
|
|
||||||
/* curl 7.14.2 */
|
/* curl 7.14.2 */
|
||||||
my_setopt(curl, CURLOPT_FTP_SKIP_PASV_IP, config->ftp_skip_ip?1L:0L);
|
my_setopt(curl, CURLOPT_FTP_SKIP_PASV_IP, config->ftp_skip_ip?1L:0L);
|
||||||
|
|
||||||
/* curl 7.15.1 */
|
/* curl 7.15.1 */
|
||||||
my_setopt(curl, CURLOPT_FTP_FILEMETHOD, (long)config->ftp_filemethod);
|
my_setopt(curl, CURLOPT_FTP_FILEMETHOD, (long)config->ftp_filemethod);
|
||||||
#endif
|
|
||||||
/* curl 7.15.2 */
|
/* curl 7.15.2 */
|
||||||
if(config->localport) {
|
if(config->localport) {
|
||||||
my_setopt(curl, CURLOPT_LOCALPORT, config->localport);
|
my_setopt(curl, CURLOPT_LOCALPORT, config->localport);
|
||||||
my_setopt_str(curl, CURLOPT_LOCALPORTRANGE, config->localportrange);
|
my_setopt_str(curl, CURLOPT_LOCALPORTRANGE, config->localportrange);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef CURL_DISABLE_FTP
|
|
||||||
/* curl 7.15.5 */
|
/* curl 7.15.5 */
|
||||||
my_setopt_str(curl, CURLOPT_FTP_ALTERNATIVE_TO_USER,
|
my_setopt_str(curl, CURLOPT_FTP_ALTERNATIVE_TO_USER,
|
||||||
config->ftp_alternative_to_user);
|
config->ftp_alternative_to_user);
|
||||||
#endif
|
|
||||||
/* curl 7.16.0 */
|
/* curl 7.16.0 */
|
||||||
if(config->disable_sessionid)
|
if(config->disable_sessionid)
|
||||||
/* disable it */
|
/* disable it */
|
||||||
|
@ -720,9 +720,14 @@ CURLcode tool_setopt(CURL *curl, bool str, struct GlobalConfig *config,
|
|||||||
|
|
||||||
#endif /* CURL_DISABLE_LIBCURL_OPTION */
|
#endif /* CURL_DISABLE_LIBCURL_OPTION */
|
||||||
|
|
||||||
CURLcode tool_real_error(CURLcode result, CURLoption tag)
|
/*
|
||||||
|
* tool_setopt_skip() allows the curl tool code to avoid setopt options that
|
||||||
|
* are explicitly disabled in the build.
|
||||||
|
*/
|
||||||
|
bool tool_setopt_skip(CURLoption tag)
|
||||||
{
|
{
|
||||||
#ifdef CURL_DISABLE_PROXY
|
#ifdef CURL_DISABLE_PROXY
|
||||||
|
#define USED_TAG
|
||||||
switch(tag) {
|
switch(tag) {
|
||||||
case CURLOPT_HAPROXYPROTOCOL:
|
case CURLOPT_HAPROXYPROTOCOL:
|
||||||
case CURLOPT_HTTPPROXYTUNNEL:
|
case CURLOPT_HTTPPROXYTUNNEL:
|
||||||
@ -756,13 +761,71 @@ CURLcode tool_real_error(CURLcode result, CURLoption tag)
|
|||||||
case CURLOPT_PROXYTYPE:
|
case CURLOPT_PROXYTYPE:
|
||||||
case CURLOPT_PROXYUSERNAME:
|
case CURLOPT_PROXYUSERNAME:
|
||||||
case CURLOPT_PROXYUSERPWD:
|
case CURLOPT_PROXYUSERPWD:
|
||||||
return CURLE_OK; /* pretend it worked */
|
return TRUE;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#else
|
#endif
|
||||||
|
#ifdef CURL_DISABLE_FTP
|
||||||
|
#define USED_TAG
|
||||||
|
switch(tag) {
|
||||||
|
case CURLOPT_FTPPORT:
|
||||||
|
case CURLOPT_FTP_ACCOUNT:
|
||||||
|
case CURLOPT_FTP_ALTERNATIVE_TO_USER:
|
||||||
|
case CURLOPT_FTP_FILEMETHOD:
|
||||||
|
case CURLOPT_FTP_SKIP_PASV_IP:
|
||||||
|
case CURLOPT_FTP_USE_EPRT:
|
||||||
|
case CURLOPT_FTP_USE_EPSV:
|
||||||
|
case CURLOPT_FTP_USE_PRET:
|
||||||
|
case CURLOPT_KRBLEVEL:
|
||||||
|
return TRUE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef CURL_DISABLE_RTSP
|
||||||
|
#define USED_TAG
|
||||||
|
switch(tag) {
|
||||||
|
case CURLOPT_INTERLEAVEDATA:
|
||||||
|
return TRUE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if defined(CURL_DISABLE_HTTP) || defined(CURL_DISABLE_COOKIES)
|
||||||
|
#define USED_TAG
|
||||||
|
switch(tag) {
|
||||||
|
case CURLOPT_COOKIE:
|
||||||
|
case CURLOPT_COOKIEFILE:
|
||||||
|
case CURLOPT_COOKIEJAR:
|
||||||
|
case CURLOPT_COOKIESESSION:
|
||||||
|
return TRUE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if defined(CURL_DISABLE_TELNET)
|
||||||
|
#define USED_TAG
|
||||||
|
switch(tag) {
|
||||||
|
case CURLOPT_TELNETOPTIONS:
|
||||||
|
return TRUE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef CURL_DISABLE_TFTP
|
||||||
|
#define USED_TAG
|
||||||
|
switch(tag) {
|
||||||
|
case CURLOPT_TFTP_BLKSIZE:
|
||||||
|
case CURLOPT_TFTP_NO_OPTIONS:
|
||||||
|
return TRUE;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef USED_TAG
|
||||||
(void)tag;
|
(void)tag;
|
||||||
#endif
|
#endif
|
||||||
return result;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,13 +30,15 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#define SETOPT_CHECK(v,opt) do { \
|
#define SETOPT_CHECK(v,opt) do { \
|
||||||
result = tool_real_error((v), opt); \
|
if(!tool_setopt_skip(opt)) { \
|
||||||
if(result) \
|
result = (v); \
|
||||||
goto show_error; \
|
if(result) \
|
||||||
|
goto show_error; \
|
||||||
|
} \
|
||||||
} WHILE_FALSE
|
} WHILE_FALSE
|
||||||
|
|
||||||
/* allow removed features to simulate success: */
|
/* allow removed features to simulate success: */
|
||||||
CURLcode tool_real_error(CURLcode result, CURLoption tag);
|
bool tool_setopt_skip(CURLoption tag);
|
||||||
|
|
||||||
#ifndef CURL_DISABLE_LIBCURL_OPTION
|
#ifndef CURL_DISABLE_LIBCURL_OPTION
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user