summaryrefslogtreecommitdiff
path: root/ftp/curl
diff options
context:
space:
mode:
authorSunpoet Po-Chuan Hsieh <sunpoet@FreeBSD.org>2019-05-30 21:55:31 +0000
committerSunpoet Po-Chuan Hsieh <sunpoet@FreeBSD.org>2019-05-30 21:55:31 +0000
commit947208117320d528b728607aac3702b26431fbab (patch)
tree59eae68eb8dd30ae720b436f930a5dd437d8e47d /ftp/curl
parentwww/node10: Update 10.15.3_1 -> 10.16.0 (diff)
Fix runtime with PROXY disabled
- Bump PORTREVISION for package change Obtained from: https://github.com/curl/curl/commit/f4f485c17b9a8b41c23ad1fa9fbcfc1973172ead
Notes
Notes: svn path=/head/; revision=503090
Diffstat (limited to 'ftp/curl')
-rw-r--r--ftp/curl/Makefile2
-rw-r--r--ftp/curl/files/patch-src-tool_setopt.c61
-rw-r--r--ftp/curl/files/patch-src-tool_setopt.h90
3 files changed, 152 insertions, 1 deletions
diff --git a/ftp/curl/Makefile b/ftp/curl/Makefile
index cdf82c51ab55..bc325fe114d5 100644
--- a/ftp/curl/Makefile
+++ b/ftp/curl/Makefile
@@ -3,7 +3,7 @@
PORTNAME= curl
PORTVERSION= 7.65.0
-PORTREVISION= 1
+PORTREVISION= 2
CATEGORIES= ftp net www
MASTER_SITES= https://curl.haxx.se/download/ \
LOCAL/sunpoet
diff --git a/ftp/curl/files/patch-src-tool_setopt.c b/ftp/curl/files/patch-src-tool_setopt.c
new file mode 100644
index 000000000000..fc1f2a7a391b
--- /dev/null
+++ b/ftp/curl/files/patch-src-tool_setopt.c
@@ -0,0 +1,61 @@
+Obtained from: https://github.com/curl/curl/commit/f4f485c17b9a8b41c23ad1fa9fbcfc1973172ead
+
+--- src/tool_setopt.c.orig 2019-05-16 20:54:53 UTC
++++ src/tool_setopt.c
+@@ -713,4 +713,56 @@ CURLcode tool_setopt(CURL *curl, bool st
+ return ret;
+ }
+
++#else /* CURL_DISABLE_LIBCURL_OPTION */
++
++#include "tool_cfgable.h"
++#include "tool_setopt.h"
++
+ #endif /* CURL_DISABLE_LIBCURL_OPTION */
++
++CURLcode tool_real_error(CURLcode result, CURLoption tag)
++{
++#ifdef CURL_DISABLE_PROXY
++ switch(tag) {
++ case CURLOPT_HAPROXYPROTOCOL:
++ case CURLOPT_HTTPPROXYTUNNEL:
++ case CURLOPT_NOPROXY:
++ case CURLOPT_PRE_PROXY:
++ case CURLOPT_PROXY:
++ case CURLOPT_PROXYAUTH:
++ case CURLOPT_PROXY_CAINFO:
++ case CURLOPT_PROXY_CAPATH:
++ case CURLOPT_PROXY_CRLFILE:
++ case CURLOPT_PROXYHEADER:
++ case CURLOPT_PROXY_KEYPASSWD:
++ case CURLOPT_PROXYPASSWORD:
++ case CURLOPT_PROXY_PINNEDPUBLICKEY:
++ case CURLOPT_PROXYPORT:
++ case CURLOPT_PROXY_SERVICE_NAME:
++ case CURLOPT_PROXY_SSLCERT:
++ case CURLOPT_PROXY_SSLCERTTYPE:
++ case CURLOPT_PROXY_SSL_CIPHER_LIST:
++ case CURLOPT_PROXY_SSLKEY:
++ case CURLOPT_PROXY_SSLKEYTYPE:
++ case CURLOPT_PROXY_SSL_OPTIONS:
++ case CURLOPT_PROXY_SSL_VERIFYHOST:
++ case CURLOPT_PROXY_SSL_VERIFYPEER:
++ case CURLOPT_PROXY_SSLVERSION:
++ case CURLOPT_PROXY_TLS13_CIPHERS:
++ case CURLOPT_PROXY_TLSAUTH_PASSWORD:
++ case CURLOPT_PROXY_TLSAUTH_TYPE:
++ case CURLOPT_PROXY_TLSAUTH_USERNAME:
++ case CURLOPT_PROXY_TRANSFER_MODE:
++ case CURLOPT_PROXYTYPE:
++ case CURLOPT_PROXYUSERNAME:
++ case CURLOPT_PROXYUSERPWD:
++ return CURLE_OK; /* pretend it worked */
++ default:
++ break;
++ }
++#else
++ (void)tag;
++#endif
++ return result;
++}
++
diff --git a/ftp/curl/files/patch-src-tool_setopt.h b/ftp/curl/files/patch-src-tool_setopt.h
new file mode 100644
index 000000000000..80c75ad18226
--- /dev/null
+++ b/ftp/curl/files/patch-src-tool_setopt.h
@@ -0,0 +1,90 @@
+Obtained from: https://github.com/curl/curl/commit/f4f485c17b9a8b41c23ad1fa9fbcfc1973172ead
+
+--- src/tool_setopt.h.orig 2019-04-15 07:05:14 UTC
++++ src/tool_setopt.h
+@@ -29,11 +29,14 @@
+ * Macros used in operate()
+ */
+
+-#define SETOPT_CHECK(v) do { \
+- result = (v); \
+- if(result) \
+- goto show_error; \
+-} WHILE_FALSE
++#define SETOPT_CHECK(v,opt) do { \
++ result = tool_real_error((v), opt); \
++ if(result) \
++ goto show_error; \
++ } WHILE_FALSE
++
++/* allow removed features to simulate success: */
++CURLcode tool_real_error(CURLcode result, CURLoption tag);
+
+ #ifndef CURL_DISABLE_LIBCURL_OPTION
+
+@@ -97,25 +100,25 @@ CURLcode tool_setopt(CURL *curl, bool st
+ const char *name, CURLoption tag, ...);
+
+ #define my_setopt(x,y,z) \
+- SETOPT_CHECK(tool_setopt(x, FALSE, global, #y, y, z))
++ SETOPT_CHECK(tool_setopt(x, FALSE, global, #y, y, z), y)
+
+ #define my_setopt_str(x,y,z) \
+- SETOPT_CHECK(tool_setopt(x, TRUE, global, #y, y, z))
++ SETOPT_CHECK(tool_setopt(x, TRUE, global, #y, y, z), y)
+
+ #define my_setopt_enum(x,y,z) \
+- SETOPT_CHECK(tool_setopt_enum(x, global, #y, y, setopt_nv_ ## y, z))
++ SETOPT_CHECK(tool_setopt_enum(x, global, #y, y, setopt_nv_ ## y, z), y)
+
+ #define my_setopt_flags(x,y,z) \
+- SETOPT_CHECK(tool_setopt_flags(x, global, #y, y, setopt_nv_ ## y, z))
++ SETOPT_CHECK(tool_setopt_flags(x, global, #y, y, setopt_nv_ ## y, z), y)
+
+ #define my_setopt_bitmask(x,y,z) \
+- SETOPT_CHECK(tool_setopt_bitmask(x, global, #y, y, setopt_nv_ ## y, z))
++ SETOPT_CHECK(tool_setopt_bitmask(x, global, #y, y, setopt_nv_ ## y, z), y)
+
+ #define my_setopt_mimepost(x,y,z) \
+- SETOPT_CHECK(tool_setopt_mimepost(x, global, #y, y, z))
++ SETOPT_CHECK(tool_setopt_mimepost(x, global, #y, y, z), y)
+
+ #define my_setopt_slist(x,y,z) \
+- SETOPT_CHECK(tool_setopt_slist(x, global, #y, y, z))
++ SETOPT_CHECK(tool_setopt_slist(x, global, #y, y, z), y)
+
+ #define res_setopt(x,y,z) tool_setopt(x, FALSE, global, #y, y, z)
+
+@@ -126,25 +129,25 @@ CURLcode tool_setopt(CURL *curl, bool st
+ /* No --libcurl, so pass options directly to library */
+
+ #define my_setopt(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define my_setopt_str(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define my_setopt_enum(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define my_setopt_flags(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define my_setopt_bitmask(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define my_setopt_mimepost(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define my_setopt_slist(x,y,z) \
+- SETOPT_CHECK(curl_easy_setopt(x, y, z))
++ SETOPT_CHECK(curl_easy_setopt(x, y, z), y)
+
+ #define res_setopt(x,y,z) curl_easy_setopt(x,y,z)
+