Compare commits
	
		
			15 Commits
		
	
	
		
			curl-7_47_
			...
			http2-push
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | f87a3d736f | ||
|   | bf5218c85e | ||
|   | c2cc3a5e97 | ||
|   | aa4e3c6438 | ||
|   | d712e22b56 | ||
|   | f649411a1c | ||
|   | cb5d4b1389 | ||
|   | 3174c940b5 | ||
|   | 2b3860d1d6 | ||
|   | 0a9f285140 | ||
|   | af3d76ccf9 | ||
|   | 952b745c98 | ||
|   | 21784936e1 | ||
|   | 352fbceef3 | ||
|   | 19d5bcd66a | 
| @@ -1,10 +0,0 @@ | |||||||
| ;;; Directory Local Variables |  | ||||||
| ;;; See Info node `(emacs) Directory Variables' for more information. |  | ||||||
|  |  | ||||||
| ((nil . ((indent-tabs-mode . nil) |  | ||||||
|          (show-trailing-whitespace . t))) |  | ||||||
|  (c-mode . ((c-basic-offset . 2) |  | ||||||
|             )) |  | ||||||
|  (c++-mode . ((c-basic-offset . 2) |  | ||||||
|               )) |  | ||||||
|  ) |  | ||||||
							
								
								
									
										59
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										59
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,52 +1,51 @@ | |||||||
| *.asc | .deps | ||||||
|  | .libs | ||||||
|  | *.lib | ||||||
|  | *.pdb | ||||||
| *.dll | *.dll | ||||||
| *.exe | *.exe | ||||||
| *.exp |  | ||||||
| *.la |  | ||||||
| *.lib |  | ||||||
| *.lo |  | ||||||
| *.o |  | ||||||
| *.obj | *.obj | ||||||
| *.pdb | *.asc | ||||||
| *~ |  | ||||||
| .*.swp | .*.swp | ||||||
| .cproject |  | ||||||
| .deps |  | ||||||
| .dirstamp |  | ||||||
| .libs |  | ||||||
| .project |  | ||||||
| .settings |  | ||||||
| /build/ |  | ||||||
| /builds/ |  | ||||||
| CHANGES.dist |  | ||||||
| Debug | Debug | ||||||
| INSTALL | Release | ||||||
|  | *.exp | ||||||
| Makefile | Makefile | ||||||
| Makefile.in | Makefile.in | ||||||
| Release |  | ||||||
| TAGS |  | ||||||
| aclocal.m4 | aclocal.m4 | ||||||
| aclocal.m4.bak |  | ||||||
| autom4te.cache | autom4te.cache | ||||||
| compile |  | ||||||
| config.cache | config.cache | ||||||
| config.guess | config.guess | ||||||
| config.log | config.log | ||||||
| config.status | config.status | ||||||
| config.sub | config.sub | ||||||
| configure | configure | ||||||
| curl-*.tar.bz2 |  | ||||||
| curl-*.tar.gz |  | ||||||
| curl-*.tar.lzma |  | ||||||
| curl-*.zip |  | ||||||
| curl-config |  | ||||||
| depcomp | depcomp | ||||||
| install-sh |  | ||||||
| libcurl.pc |  | ||||||
| libtool | libtool | ||||||
| ltmain.sh | ltmain.sh | ||||||
|  | compile | ||||||
|  | curl-config | ||||||
|  | libcurl.pc | ||||||
| missing | missing | ||||||
|  | curl-*.tar.gz | ||||||
|  | curl-*.tar.bz2 | ||||||
|  | curl-*.tar.lzma | ||||||
|  | curl-*.zip | ||||||
|  | INSTALL | ||||||
|  | install-sh | ||||||
|  | *.o | ||||||
|  | *.lo | ||||||
|  | *.la | ||||||
| mkinstalldirs | mkinstalldirs | ||||||
| tags | tags | ||||||
|  | TAGS | ||||||
|  | *~ | ||||||
|  | aclocal.m4.bak | ||||||
|  | CHANGES.dist | ||||||
|  | .project | ||||||
|  | .cproject | ||||||
|  | .settings | ||||||
|  | .dirstamp | ||||||
| test-driver | test-driver | ||||||
| scripts/_curl | /build/ | ||||||
|  | /builds/ | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								.travis.yml
									
									
									
									
									
								
							| @@ -1,15 +1,5 @@ | |||||||
| os: |  | ||||||
|   - linux |  | ||||||
|   - osx |  | ||||||
|  |  | ||||||
| sudo: false |  | ||||||
|  |  | ||||||
| language: c | language: c | ||||||
|  |  | ||||||
| install: |  | ||||||
|   - if [ "$TRAVIS_OS_NAME" == "osx" ]; then brew update > /dev/null; fi |  | ||||||
|   - if [ "$TRAVIS_OS_NAME" == "osx" ]; then brew install openssl libidn rtmpdump libssh2 c-ares libmetalink libressl nghttp2; fi |  | ||||||
|  |  | ||||||
| before_script: | before_script: | ||||||
|   - ./buildconf |   - ./buildconf | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								CHANGES
									
									
									
									
									
								
							| @@ -1,7 +1,15 @@ | |||||||
| See https://curl.haxx.se/changes.html for the edited and human readable online |                                   _   _ ____  _ | ||||||
| version of what has changed over the years in different curl releases. |                               ___| | | |  _ \| | | ||||||
|  |                              / __| | | | |_) | | | ||||||
|  |                             | (__| |_| |  _ <| |___ | ||||||
|  |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
| Generate a CHANGES file like the one present in evey release like this: |                                   Changelog | ||||||
|  |  | ||||||
|  | This file no longer holds the changelog. Now you can generate it yourself | ||||||
|  | like this: | ||||||
|  |  | ||||||
| $ git log --pretty=fuller --no-color --date=short --decorate=full | \ | $ git log --pretty=fuller --no-color --date=short --decorate=full | \ | ||||||
|   ./log2changes.pl |   ./log2changes.pl | ||||||
|  |  | ||||||
|  | The older, manually edited, changelog is found in git named CHANGES.0 | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -139,7 +139,7 @@ int main(void) | |||||||
|   rc = gethostbyname_r(address, &h, &hdata); |   rc = gethostbyname_r(address, &h, &hdata); | ||||||
| #elif defined(HAVE_GETHOSTBYNAME_R_5) || \ | #elif defined(HAVE_GETHOSTBYNAME_R_5) || \ | ||||||
|       defined(HAVE_GETHOSTBYNAME_R_5_REENTRANT) |       defined(HAVE_GETHOSTBYNAME_R_5_REENTRANT) | ||||||
|   rc = gethostbyname_r(address, &h, buffer, 8192, &h_errnop); |   rc = gethostbyname_r(address, &h, buffer, 8192, 0, &h_errnop); | ||||||
|   (void)hp; /* not used for test */ |   (void)hp; /* not used for test */ | ||||||
| #elif defined(HAVE_GETHOSTBYNAME_R_6) || \ | #elif defined(HAVE_GETHOSTBYNAME_R_6) || \ | ||||||
|       defined(HAVE_GETHOSTBYNAME_R_6_REENTRANT) |       defined(HAVE_GETHOSTBYNAME_R_6_REENTRANT) | ||||||
|   | |||||||
| @@ -10,8 +10,8 @@ endmacro(add_header_include) | |||||||
|  |  | ||||||
| set(signature_call_conv) | set(signature_call_conv) | ||||||
| if(HAVE_WINDOWS_H) | if(HAVE_WINDOWS_H) | ||||||
|   add_header_include(HAVE_WINSOCK2_H "winsock2.h") |  | ||||||
|   add_header_include(HAVE_WINDOWS_H "windows.h") |   add_header_include(HAVE_WINDOWS_H "windows.h") | ||||||
|  |   add_header_include(HAVE_WINSOCK2_H "winsock2.h") | ||||||
|   add_header_include(HAVE_WINSOCK_H "winsock.h") |   add_header_include(HAVE_WINSOCK_H "winsock.h") | ||||||
|   set(_source_epilogue |   set(_source_epilogue | ||||||
|       "${_source_epilogue}\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif") |       "${_source_epilogue}\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif") | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -64,7 +64,7 @@ message(STATUS "curl version=[${CURL_VERSION}]") | |||||||
| # SET(PACKAGE_NAME "curl") | # SET(PACKAGE_NAME "curl") | ||||||
| # SET(PACKAGE_VERSION "-") | # SET(PACKAGE_VERSION "-") | ||||||
| # SET(PACKAGE_STRING "curl-") | # SET(PACKAGE_STRING "curl-") | ||||||
| # SET(PACKAGE_BUGREPORT "a suitable curl mailing list => https://curl.haxx.se/mail/") | # SET(PACKAGE_BUGREPORT "a suitable curl mailing list => http://curl.haxx.se/mail/") | ||||||
| set(OPERATING_SYSTEM "${CMAKE_SYSTEM_NAME}") | set(OPERATING_SYSTEM "${CMAKE_SYSTEM_NAME}") | ||||||
| set(OS "\"${CMAKE_SYSTEM_NAME}\"") | set(OS "\"${CMAKE_SYSTEM_NAME}\"") | ||||||
|  |  | ||||||
| @@ -122,6 +122,11 @@ endif() | |||||||
| option(CURL_HIDDEN_SYMBOLS "Set to ON to hide libcurl internal symbols (=hide all symbols that aren't officially external)." ON) | option(CURL_HIDDEN_SYMBOLS "Set to ON to hide libcurl internal symbols (=hide all symbols that aren't officially external)." ON) | ||||||
| mark_as_advanced(CURL_HIDDEN_SYMBOLS) | mark_as_advanced(CURL_HIDDEN_SYMBOLS) | ||||||
|  |  | ||||||
|  | # IF(WIN32) | ||||||
|  | # OPTION(CURL_WINDOWS_SSPI "Use windows libraries to allow NTLM authentication without openssl" ON) | ||||||
|  | # MARK_AS_ADVANCED(CURL_WINDOWS_SSPI) | ||||||
|  | # ENDIF() | ||||||
|  |  | ||||||
| option(HTTP_ONLY "disables all protocols except HTTP (This overrides all CURL_DISABLE_* options)" OFF) | option(HTTP_ONLY "disables all protocols except HTTP (This overrides all CURL_DISABLE_* options)" OFF) | ||||||
| mark_as_advanced(HTTP_ONLY) | mark_as_advanced(HTTP_ONLY) | ||||||
| option(CURL_DISABLE_FTP "disables FTP" OFF) | option(CURL_DISABLE_FTP "disables FTP" OFF) | ||||||
| @@ -181,7 +186,7 @@ option(DISABLED_THREADSAFE "Set to explicitly specify we don't want to use threa | |||||||
| mark_as_advanced(DISABLED_THREADSAFE) | mark_as_advanced(DISABLED_THREADSAFE) | ||||||
| option(ENABLE_IPV6 "Define if you want to enable IPv6 support" ON) | option(ENABLE_IPV6 "Define if you want to enable IPv6 support" ON) | ||||||
| mark_as_advanced(ENABLE_IPV6) | mark_as_advanced(ENABLE_IPV6) | ||||||
| if(ENABLE_IPV6 AND NOT WIN32) | if(ENABLE_IPV6) | ||||||
|   include(CheckStructHasMember) |   include(CheckStructHasMember) | ||||||
|   check_struct_has_member("struct sockaddr_in6" sin6_addr "netinet/in.h" |   check_struct_has_member("struct sockaddr_in6" sin6_addr "netinet/in.h" | ||||||
|                           HAVE_SOCKADDR_IN6_SIN6_ADDR) |                           HAVE_SOCKADDR_IN6_SIN6_ADDR) | ||||||
| @@ -248,7 +253,6 @@ include (CheckLibraryExists) | |||||||
| include (CheckSymbolExists) | include (CheckSymbolExists) | ||||||
| include (CheckTypeSize) | include (CheckTypeSize) | ||||||
| include (CheckCSourceCompiles) | include (CheckCSourceCompiles) | ||||||
| include (CMakeDependentOption) |  | ||||||
|  |  | ||||||
| # On windows preload settings | # On windows preload settings | ||||||
| if(WIN32) | if(WIN32) | ||||||
| @@ -286,22 +290,14 @@ endif(NOT NOT_NEED_LIBNSL) | |||||||
|  |  | ||||||
| check_function_exists(gethostname HAVE_GETHOSTNAME) | check_function_exists(gethostname HAVE_GETHOSTNAME) | ||||||
|  |  | ||||||
| set(OPENSSL_DEFAULT ON) |  | ||||||
| if(WIN32) | if(WIN32) | ||||||
|   set(OPENSSL_DEFAULT OFF) |  | ||||||
|   check_library_exists_concat("ws2_32" getch        HAVE_LIBWS2_32) |   check_library_exists_concat("ws2_32" getch        HAVE_LIBWS2_32) | ||||||
|   check_library_exists_concat("winmm"  getch        HAVE_LIBWINMM) |   check_library_exists_concat("winmm"  getch        HAVE_LIBWINMM) | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
| option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ${OPENSSL_DEFAULT}) | option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON) | ||||||
| mark_as_advanced(CMAKE_USE_OPENSSL) | mark_as_advanced(CMAKE_USE_OPENSSL) | ||||||
|  |  | ||||||
| if(WIN32) |  | ||||||
|   CMAKE_DEPENDENT_OPTION(CURL_WINDOWS_SSPI "Use windows libraries to allow NTLM authentication without openssl" ON |  | ||||||
|     "NOT CMAKE_USE_OPENSSL" OFF) |  | ||||||
|   mark_as_advanced(CURL_WINDOWS_SSPI) |  | ||||||
| endif() |  | ||||||
|  |  | ||||||
| set(USE_OPENSSL OFF) | set(USE_OPENSSL OFF) | ||||||
| set(HAVE_LIBCRYPTO OFF) | set(HAVE_LIBCRYPTO OFF) | ||||||
| set(HAVE_LIBSSL OFF) | set(HAVE_LIBSSL OFF) | ||||||
| @@ -324,8 +320,6 @@ if(CMAKE_USE_OPENSSL) | |||||||
|     check_include_file("openssl/ssl.h"    HAVE_OPENSSL_SSL_H) |     check_include_file("openssl/ssl.h"    HAVE_OPENSSL_SSL_H) | ||||||
|     check_include_file("openssl/x509.h"   HAVE_OPENSSL_X509_H) |     check_include_file("openssl/x509.h"   HAVE_OPENSSL_X509_H) | ||||||
|     check_include_file("openssl/rand.h"   HAVE_OPENSSL_RAND_H) |     check_include_file("openssl/rand.h"   HAVE_OPENSSL_RAND_H) | ||||||
|   elseif(WIN32) |  | ||||||
|     set(CURL_WINDOWS_SSPI ON) |  | ||||||
|   endif() |   endif() | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
| @@ -361,10 +355,9 @@ if(NOT CURL_DISABLE_LDAP) | |||||||
|     check_include_file_concat("winber.h"  HAVE_WINBER_H) |     check_include_file_concat("winber.h"  HAVE_WINBER_H) | ||||||
|   endif() |   endif() | ||||||
|    |    | ||||||
|   set(CMAKE_REQUIRED_INCLUDES_BAK ${CMAKE_REQUIRED_INCLUDES}) |  | ||||||
|   set(CMAKE_LDAP_INCLUDE_DIR "" CACHE STRING "Path to LDAP include directory") |   set(CMAKE_LDAP_INCLUDE_DIR "" CACHE STRING "Path to LDAP include directory") | ||||||
|   if(CMAKE_LDAP_INCLUDE_DIR) |   if(CMAKE_LDAP_INCLUDE_DIR) | ||||||
|     list(APPEND CMAKE_REQUIRED_INCLUDES ${CMAKE_LDAP_INCLUDE_DIR}) |     set(CMAKE_REQUIRED_INCLUDES ${CMAKE_LDAP_INCLUDE_DIR}) | ||||||
|   endif() |   endif() | ||||||
|   check_include_file_concat("ldap.h"           HAVE_LDAP_H) |   check_include_file_concat("ldap.h"           HAVE_LDAP_H) | ||||||
|   check_include_file_concat("lber.h"           HAVE_LBER_H) |   check_include_file_concat("lber.h"           HAVE_LBER_H) | ||||||
| @@ -372,11 +365,9 @@ if(NOT CURL_DISABLE_LDAP) | |||||||
|   if(NOT HAVE_LDAP_H) |   if(NOT HAVE_LDAP_H) | ||||||
|     message(STATUS "LDAP_H not found CURL_DISABLE_LDAP set ON") |     message(STATUS "LDAP_H not found CURL_DISABLE_LDAP set ON") | ||||||
|     set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) |     set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) | ||||||
|     set(CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES_BAK}) #LDAP includes won't be used |  | ||||||
|   elseif(NOT HAVE_LIBLDAP) |   elseif(NOT HAVE_LIBLDAP) | ||||||
|     message(STATUS "LDAP library '${CMAKE_LDAP_LIB}' not found CURL_DISABLE_LDAP set ON") |     message(STATUS "LDAP library '${CMAKE_LDAP_LIB}' not found CURL_DISABLE_LDAP set ON") | ||||||
|     set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) |     set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) | ||||||
|     set(CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES_BAK}) #LDAP includes won't be used |  | ||||||
|   else() |   else() | ||||||
|     if(CMAKE_USE_OPENLDAP) |     if(CMAKE_USE_OPENLDAP) | ||||||
|       set(USE_OPENLDAP ON) |       set(USE_OPENLDAP ON) | ||||||
| @@ -457,7 +448,6 @@ if(CURL_ZLIB) | |||||||
|     set(HAVE_LIBZ ON) |     set(HAVE_LIBZ ON) | ||||||
|     list(APPEND CURL_LIBS ${ZLIB_LIBRARIES}) |     list(APPEND CURL_LIBS ${ZLIB_LIBRARIES}) | ||||||
|     include_directories(${ZLIB_INCLUDE_DIRS}) |     include_directories(${ZLIB_INCLUDE_DIRS}) | ||||||
|     list(APPEND CMAKE_REQUIRED_INCLUDES ${ZLIB_INCLUDE_DIRS}) |  | ||||||
|   endif() |   endif() | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
| @@ -473,7 +463,7 @@ if(CMAKE_USE_LIBSSH2) | |||||||
|   if(LIBSSH2_FOUND) |   if(LIBSSH2_FOUND) | ||||||
|     list(APPEND CURL_LIBS ${LIBSSH2_LIBRARY}) |     list(APPEND CURL_LIBS ${LIBSSH2_LIBRARY}) | ||||||
|     set(CMAKE_REQUIRED_LIBRARIES ${LIBSSH2_LIBRARY}) |     set(CMAKE_REQUIRED_LIBRARIES ${LIBSSH2_LIBRARY}) | ||||||
|     list(APPEND CMAKE_REQUIRED_INCLUDES "${LIBSSH2_INCLUDE_DIR}") |     set(CMAKE_REQUIRED_INCLUDES "${LIBSSH2_INCLUDE_DIR}") | ||||||
|     include_directories("${LIBSSH2_INCLUDE_DIR}") |     include_directories("${LIBSSH2_INCLUDE_DIR}") | ||||||
|     set(HAVE_LIBSSH2 ON) |     set(HAVE_LIBSSH2 ON) | ||||||
|     set(USE_LIBSSH2 ON) |     set(USE_LIBSSH2 ON) | ||||||
| @@ -501,12 +491,12 @@ mark_as_advanced(CMAKE_USE_GSSAPI) | |||||||
| if(CMAKE_USE_GSSAPI) | if(CMAKE_USE_GSSAPI) | ||||||
|   find_package(GSS) |   find_package(GSS) | ||||||
|  |  | ||||||
|   set(HAVE_GSSAPI ${GSS_FOUND}) |   set(HAVE_GSS_API ${GSS_FOUND}) | ||||||
|   if(GSS_FOUND) |   if(GSS_FOUND) | ||||||
|  |  | ||||||
|     message(STATUS "Found ${GSS_FLAVOUR} GSSAPI version: \"${GSS_VERSION}\"") |     message(STATUS "Found ${GSS_FLAVOUR} GSSAPI version: \"${GSS_VERSION}\"") | ||||||
|  |  | ||||||
|     list(APPEND CMAKE_REQUIRED_INCLUDES ${GSS_INCLUDE_DIRECTORIES}) |     set(CMAKE_REQUIRED_INCLUDES ${GSS_INCLUDE_DIR}) | ||||||
|     check_include_file_concat("gssapi/gssapi.h"  HAVE_GSSAPI_GSSAPI_H) |     check_include_file_concat("gssapi/gssapi.h"  HAVE_GSSAPI_GSSAPI_H) | ||||||
|     check_include_file_concat("gssapi/gssapi_generic.h" HAVE_GSSAPI_GSSAPI_GENERIC_H) |     check_include_file_concat("gssapi/gssapi_generic.h" HAVE_GSSAPI_GSSAPI_GENERIC_H) | ||||||
|     check_include_file_concat("gssapi/gssapi_krb5.h" HAVE_GSSAPI_GSSAPI_KRB5_H) |     check_include_file_concat("gssapi/gssapi_krb5.h" HAVE_GSSAPI_GSSAPI_KRB5_H) | ||||||
| @@ -542,7 +532,7 @@ if(CMAKE_USE_GSSAPI) | |||||||
|  |  | ||||||
|     endif() |     endif() | ||||||
|  |  | ||||||
|     include_directories(${GSS_INCLUDE_DIRECTORIES}) |     include_directories(${GSS_INCLUDE_DIR}) | ||||||
|     link_directories(${GSS_LINK_DIRECTORIES}) |     link_directories(${GSS_LINK_DIRECTORIES}) | ||||||
|     set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${GSS_COMPILER_FLAGS}") |     set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${GSS_COMPILER_FLAGS}") | ||||||
|     set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${GSS_LINKER_FLAGS}") |     set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${GSS_LINKER_FLAGS}") | ||||||
| @@ -562,25 +552,12 @@ else() | |||||||
|   unset(USE_UNIX_SOCKETS CACHE) |   unset(USE_UNIX_SOCKETS CACHE) | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
|  |  | ||||||
| # Check for header files | # Check for header files | ||||||
| if(NOT UNIX) | if(NOT UNIX) | ||||||
|   check_include_file_concat("windows.h"      HAVE_WINDOWS_H) |   check_include_file_concat("windows.h"      HAVE_WINDOWS_H) | ||||||
|   check_include_file_concat("winsock.h"      HAVE_WINSOCK_H) |   check_include_file_concat("winsock.h"      HAVE_WINSOCK_H) | ||||||
|   check_include_file_concat("ws2tcpip.h"     HAVE_WS2TCPIP_H) |   check_include_file_concat("ws2tcpip.h"     HAVE_WS2TCPIP_H) | ||||||
|   check_include_file_concat("winsock2.h"     HAVE_WINSOCK2_H) |   check_include_file_concat("winsock2.h"     HAVE_WINSOCK2_H) | ||||||
|   if(CURL_WINDOWS_SSPI) |  | ||||||
|     set(CMAKE_REQUIRED_DEFINITIONS "${CMAKE_REQUIRED_DEFINITIONS} -DSECURITY_WIN32") |  | ||||||
|     check_include_file_concat("sspi.h"       HAVE_SSPI_H) |  | ||||||
|     if(HAVE_SSPI_H) |  | ||||||
|       check_include_file_concat("schannel.h" HAVE_SCHANNEL_H) |  | ||||||
|       set(USE_WINDOWS_SSPI ON) |  | ||||||
|       if(HAVE_SCHANNEL_H) |  | ||||||
|         set(USE_SCHANNEL ON) |  | ||||||
|         set(SSL_ENABLED ON) |  | ||||||
|       endif() |  | ||||||
|     endif() |  | ||||||
|   endif() |  | ||||||
| endif(NOT UNIX) | endif(NOT UNIX) | ||||||
|  |  | ||||||
| check_include_file_concat("stdio.h"          HAVE_STDIO_H) | check_include_file_concat("stdio.h"          HAVE_STDIO_H) | ||||||
| @@ -1061,8 +1038,7 @@ endfunction() | |||||||
|  |  | ||||||
| # Clear list and try to detect available features | # Clear list and try to detect available features | ||||||
| set(_items) | set(_items) | ||||||
| _add_if("WinSSL"        SSL_ENABLED AND USE_WINDOWS_SSPI) | _add_if("SSL"           SSL_ENABLED) | ||||||
| _add_if("OpenSSL"       SSL_ENABLED AND USE_OPENSSL) |  | ||||||
| _add_if("IPv6"          ENABLE_IPV6) | _add_if("IPv6"          ENABLE_IPV6) | ||||||
| _add_if("unix-sockets"  USE_UNIX_SOCKETS) | _add_if("unix-sockets"  USE_UNIX_SOCKETS) | ||||||
| _add_if("libz"          HAVE_LIBZ) | _add_if("libz"          HAVE_LIBZ) | ||||||
| @@ -1070,12 +1046,12 @@ _add_if("AsynchDNS"     USE_ARES OR USE_THREADS_POSIX) | |||||||
| _add_if("IDN"           HAVE_LIBIDN) | _add_if("IDN"           HAVE_LIBIDN) | ||||||
| # TODO SSP1 (WinSSL) check is missing | # TODO SSP1 (WinSSL) check is missing | ||||||
| _add_if("SSPI"          USE_WINDOWS_SSPI) | _add_if("SSPI"          USE_WINDOWS_SSPI) | ||||||
| _add_if("GSS-API"       HAVE_GSSAPI) | _add_if("GSS-API"       HAVE_GSS_API) | ||||||
| # TODO SSP1 missing for SPNEGO | # TODO SSP1 missing for SPNEGO | ||||||
| _add_if("SPNEGO"        NOT CURL_DISABLE_CRYPTO_AUTH AND | _add_if("SPNEGO"        NOT CURL_DISABLE_CRYPTO_AUTH AND | ||||||
|                         (HAVE_GSSAPI OR USE_WINDOWS_SSPI)) |                         (HAVE_GSS_API OR USE_WINDOWS_SSPI)) | ||||||
| _add_if("Kerberos"      NOT CURL_DISABLE_CRYPTO_AUTH AND | _add_if("Kerberos"      NOT CURL_DISABLE_CRYPTO_AUTH AND | ||||||
|                         (HAVE_GSSAPI OR USE_WINDOWS_SSPI)) |                         (HAVE_GSS_API OR USE_WINDOWS_SSPI)) | ||||||
| # NTLM support requires crypto function adaptions from various SSL libs | # NTLM support requires crypto function adaptions from various SSL libs | ||||||
| # TODO alternative SSL libs tests for SSP1, GNUTLS, NSS, DARWINSSL | # TODO alternative SSL libs tests for SSP1, GNUTLS, NSS, DARWINSSL | ||||||
| if(NOT CURL_DISABLE_CRYPTO_AUTH AND (USE_OPENSSL OR | if(NOT CURL_DISABLE_CRYPTO_AUTH AND (USE_OPENSSL OR | ||||||
| @@ -1160,7 +1136,7 @@ set(VERSIONNUM              "${CURL_VERSION_NUM}") | |||||||
| # Finally generate a "curl-config" matching this config | # Finally generate a "curl-config" matching this config | ||||||
| configure_file("${CURL_SOURCE_DIR}/curl-config.in" | configure_file("${CURL_SOURCE_DIR}/curl-config.in" | ||||||
|                "${CURL_BINARY_DIR}/curl-config" @ONLY) |                "${CURL_BINARY_DIR}/curl-config" @ONLY) | ||||||
| install(FILES "${CURL_BINARY_DIR}/curl-config" | install(FILES "${CMAKE_BINARY_DIR}/curl-config" | ||||||
|         DESTINATION bin |         DESTINATION bin | ||||||
|         PERMISSIONS |         PERMISSIONS | ||||||
|           OWNER_READ OWNER_WRITE OWNER_EXECUTE |           OWNER_READ OWNER_WRITE OWNER_EXECUTE | ||||||
| @@ -1170,7 +1146,7 @@ install(FILES "${CURL_BINARY_DIR}/curl-config" | |||||||
| # Finally generate a pkg-config file matching this config | # Finally generate a pkg-config file matching this config | ||||||
| configure_file("${CURL_SOURCE_DIR}/libcurl.pc.in" | configure_file("${CURL_SOURCE_DIR}/libcurl.pc.in" | ||||||
|                "${CURL_BINARY_DIR}/libcurl.pc" @ONLY) |                "${CURL_BINARY_DIR}/libcurl.pc" @ONLY) | ||||||
| install(FILES "${CURL_BINARY_DIR}/libcurl.pc" | install(FILES "${CMAKE_BINARY_DIR}/libcurl.pc" | ||||||
|         DESTINATION lib/pkgconfig) |         DESTINATION lib/pkgconfig) | ||||||
|  |  | ||||||
| # This needs to be run very last so other parts of the scripts can take advantage of this. | # This needs to be run very last so other parts of the scripts can take advantage of this. | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ Join the community | |||||||
|  |  | ||||||
|  1. Click 'watch' on the github repo |  1. Click 'watch' on the github repo | ||||||
|  |  | ||||||
|  2. Subscribe to the suitable [mailing lists](https://curl.haxx.se/mail/) |  2. Subscribe to the suitable [mailing lists](http://curl.haxx.se/mail/) | ||||||
|  |  | ||||||
| Read [docs/CONTRIBUTE](docs/CONTRIBUTE) | Read [docs/CONTRIBUTE](docs/CONTRIBUTE) | ||||||
| --------------------------------------- | --------------------------------------- | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								COPYING
									
									
									
									
									
								
							| @@ -1,7 +1,6 @@ | |||||||
| COPYRIGHT AND PERMISSION NOTICE | COPYRIGHT AND PERMISSION NOTICE | ||||||
|  |  | ||||||
| Copyright (c) 1996 - 2016, Daniel Stenberg, <daniel@haxx.se>, and many | Copyright (c) 1996 - 2015, Daniel Stenberg, <daniel@haxx.se>. | ||||||
| contributors, see the THANKS file. |  | ||||||
|  |  | ||||||
| All rights reserved. | All rights reserved. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -65,7 +65,7 @@ else | |||||||
|  ARCHES64='-arch x86_64' |  ARCHES64='-arch x86_64' | ||||||
|  #We "know" that 10.4 and earlier do not support 64bit |  #We "know" that 10.4 and earlier do not support 64bit | ||||||
|  OLD_SDK64=`ls  $SDK_PATH|egrep -v "10.[0-4]"|head -1` |  OLD_SDK64=`ls  $SDK_PATH|egrep -v "10.[0-4]"|head -1` | ||||||
|  NEW_SDK64=`ls -r $SDK_PATH|egrep -v "10.[0-4][^0-9]" | head -1` |  NEW_SDK64=`ls -r $SDK_PATH|egrep -v "10.[0-4]"|head -1` | ||||||
|  if test $USE_OLD -gt 0 |  if test $USE_OLD -gt 0 | ||||||
|   then |   then | ||||||
|    SDK64=$OLD_SDK64 |    SDK64=$OLD_SDK64 | ||||||
|   | |||||||
							
								
								
									
										92
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										92
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -9,7 +9,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -32,97 +32,86 @@ CMAKE_DIST = CMakeLists.txt CMake/CMakeConfigurableFile.in	\ | |||||||
| VC6_LIBTMPL = projects/Windows/VC6/lib/libcurl.tmpl | VC6_LIBTMPL = projects/Windows/VC6/lib/libcurl.tmpl | ||||||
| VC6_LIBDSP = projects/Windows/VC6/lib/libcurl.dsp.dist | VC6_LIBDSP = projects/Windows/VC6/lib/libcurl.dsp.dist | ||||||
| VC6_LIBDSP_DEPS = $(VC6_LIBTMPL) Makefile.am lib/Makefile.inc | VC6_LIBDSP_DEPS = $(VC6_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC6_SRCTMPL = projects/Windows/VC6/src/curl.tmpl | VC6_SRCTMPL = projects/Windows/VC6/src/curlsrc.tmpl | ||||||
| VC6_SRCDSP = projects/Windows/VC6/src/curl.dsp.dist | VC6_SRCDSP = projects/Windows/VC6/src/curlsrc.dsp.dist | ||||||
| VC6_SRCDSP_DEPS = $(VC6_SRCTMPL) Makefile.am src/Makefile.inc | VC6_SRCDSP_DEPS = $(VC6_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC7_LIBTMPL = projects/Windows/VC7/lib/libcurl.tmpl | VC7_LIBTMPL = projects/Windows/VC7/lib/libcurl.tmpl | ||||||
| VC7_LIBVCPROJ = projects/Windows/VC7/lib/libcurl.vcproj.dist | VC7_LIBVCPROJ = projects/Windows/VC7/lib/libcurl.vcproj.dist | ||||||
| VC7_LIBVCPROJ_DEPS = $(VC7_LIBTMPL) Makefile.am lib/Makefile.inc | VC7_LIBVCPROJ_DEPS = $(VC7_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC7_SRCTMPL = projects/Windows/VC7/src/curl.tmpl | VC7_SRCTMPL = projects/Windows/VC7/src/curlsrc.tmpl | ||||||
| VC7_SRCVCPROJ = projects/Windows/VC7/src/curl.vcproj.dist | VC7_SRCVCPROJ = projects/Windows/VC7/src/curlsrc.vcproj.dist | ||||||
| VC7_SRCVCPROJ_DEPS = $(VC7_SRCTMPL) Makefile.am src/Makefile.inc | VC7_SRCVCPROJ_DEPS = $(VC7_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC71_LIBTMPL = projects/Windows/VC7.1/lib/libcurl.tmpl | VC71_LIBTMPL = projects/Windows/VC7.1/lib/libcurl.tmpl | ||||||
| VC71_LIBVCPROJ = projects/Windows/VC7.1/lib/libcurl.vcproj.dist | VC71_LIBVCPROJ = projects/Windows/VC7.1/lib/libcurl.vcproj.dist | ||||||
| VC71_LIBVCPROJ_DEPS = $(VC71_LIBTMPL) Makefile.am lib/Makefile.inc | VC71_LIBVCPROJ_DEPS = $(VC71_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC71_SRCTMPL = projects/Windows/VC7.1/src/curl.tmpl | VC71_SRCTMPL = projects/Windows/VC7.1/src/curlsrc.tmpl | ||||||
| VC71_SRCVCPROJ = projects/Windows/VC7.1/src/curl.vcproj.dist | VC71_SRCVCPROJ = projects/Windows/VC7.1/src/curlsrc.vcproj.dist | ||||||
| VC71_SRCVCPROJ_DEPS = $(VC71_SRCTMPL) Makefile.am src/Makefile.inc | VC71_SRCVCPROJ_DEPS = $(VC71_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC8_LIBTMPL = projects/Windows/VC8/lib/libcurl.tmpl | VC8_LIBTMPL = projects/Windows/VC8/lib/libcurl.tmpl | ||||||
| VC8_LIBVCPROJ = projects/Windows/VC8/lib/libcurl.vcproj.dist | VC8_LIBVCPROJ = projects/Windows/VC8/lib/libcurl.vcproj.dist | ||||||
| VC8_LIBVCPROJ_DEPS = $(VC8_LIBTMPL) Makefile.am lib/Makefile.inc | VC8_LIBVCPROJ_DEPS = $(VC8_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC8_SRCTMPL = projects/Windows/VC8/src/curl.tmpl | VC8_SRCTMPL = projects/Windows/VC8/src/curlsrc.tmpl | ||||||
| VC8_SRCVCPROJ = projects/Windows/VC8/src/curl.vcproj.dist | VC8_SRCVCPROJ = projects/Windows/VC8/src/curlsrc.vcproj.dist | ||||||
| VC8_SRCVCPROJ_DEPS = $(VC8_SRCTMPL) Makefile.am src/Makefile.inc | VC8_SRCVCPROJ_DEPS = $(VC8_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC9_LIBTMPL = projects/Windows/VC9/lib/libcurl.tmpl | VC9_LIBTMPL = projects/Windows/VC9/lib/libcurl.tmpl | ||||||
| VC9_LIBVCPROJ = projects/Windows/VC9/lib/libcurl.vcproj.dist | VC9_LIBVCPROJ = projects/Windows/VC9/lib/libcurl.vcproj.dist | ||||||
| VC9_LIBVCPROJ_DEPS = $(VC9_LIBTMPL) Makefile.am lib/Makefile.inc | VC9_LIBVCPROJ_DEPS = $(VC9_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC9_SRCTMPL = projects/Windows/VC9/src/curl.tmpl | VC9_SRCTMPL = projects/Windows/VC9/src/curlsrc.tmpl | ||||||
| VC9_SRCVCPROJ = projects/Windows/VC9/src/curl.vcproj.dist | VC9_SRCVCPROJ = projects/Windows/VC9/src/curlsrc.vcproj.dist | ||||||
| VC9_SRCVCPROJ_DEPS = $(VC9_SRCTMPL) Makefile.am src/Makefile.inc | VC9_SRCVCPROJ_DEPS = $(VC9_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC10_LIBTMPL = projects/Windows/VC10/lib/libcurl.tmpl | VC10_LIBTMPL = projects/Windows/VC10/lib/libcurl.tmpl | ||||||
| VC10_LIBVCXPROJ = projects/Windows/VC10/lib/libcurl.vcxproj.dist | VC10_LIBVCXPROJ = projects/Windows/VC10/lib/libcurl.vcxproj.dist | ||||||
| VC10_LIBVCXPROJ_DEPS = $(VC10_LIBTMPL) Makefile.am lib/Makefile.inc | VC10_LIBVCXPROJ_DEPS = $(VC10_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC10_SRCTMPL = projects/Windows/VC10/src/curl.tmpl | VC10_SRCTMPL = projects/Windows/VC10/src/curlsrc.tmpl | ||||||
| VC10_SRCVCXPROJ = projects/Windows/VC10/src/curl.vcxproj.dist | VC10_SRCVCXPROJ = projects/Windows/VC10/src/curlsrc.vcxproj.dist | ||||||
| VC10_SRCVCXPROJ_DEPS = $(VC10_SRCTMPL) Makefile.am src/Makefile.inc | VC10_SRCVCXPROJ_DEPS = $(VC10_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC11_LIBTMPL = projects/Windows/VC11/lib/libcurl.tmpl | VC11_LIBTMPL = projects/Windows/VC11/lib/libcurl.tmpl | ||||||
| VC11_LIBVCXPROJ = projects/Windows/VC11/lib/libcurl.vcxproj.dist | VC11_LIBVCXPROJ = projects/Windows/VC11/lib/libcurl.vcxproj.dist | ||||||
| VC11_LIBVCXPROJ_DEPS = $(VC11_LIBTMPL) Makefile.am lib/Makefile.inc | VC11_LIBVCXPROJ_DEPS = $(VC11_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC11_SRCTMPL = projects/Windows/VC11/src/curl.tmpl | VC11_SRCTMPL = projects/Windows/VC11/src/curlsrc.tmpl | ||||||
| VC11_SRCVCXPROJ = projects/Windows/VC11/src/curl.vcxproj.dist | VC11_SRCVCXPROJ = projects/Windows/VC11/src/curlsrc.vcxproj.dist | ||||||
| VC11_SRCVCXPROJ_DEPS = $(VC11_SRCTMPL) Makefile.am src/Makefile.inc | VC11_SRCVCXPROJ_DEPS = $(VC11_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC12_LIBTMPL = projects/Windows/VC12/lib/libcurl.tmpl | VC12_LIBTMPL = projects/Windows/VC12/lib/libcurl.tmpl | ||||||
| VC12_LIBVCXPROJ = projects/Windows/VC12/lib/libcurl.vcxproj.dist | VC12_LIBVCXPROJ = projects/Windows/VC12/lib/libcurl.vcxproj.dist | ||||||
| VC12_LIBVCXPROJ_DEPS = $(VC12_LIBTMPL) Makefile.am lib/Makefile.inc | VC12_LIBVCXPROJ_DEPS = $(VC12_LIBTMPL) Makefile.am lib/Makefile.inc | ||||||
| VC12_SRCTMPL = projects/Windows/VC12/src/curl.tmpl | VC12_SRCTMPL = projects/Windows/VC12/src/curlsrc.tmpl | ||||||
| VC12_SRCVCXPROJ = projects/Windows/VC12/src/curl.vcxproj.dist | VC12_SRCVCXPROJ = projects/Windows/VC12/src/curlsrc.vcxproj.dist | ||||||
| VC12_SRCVCXPROJ_DEPS = $(VC12_SRCTMPL) Makefile.am src/Makefile.inc | VC12_SRCVCXPROJ_DEPS = $(VC12_SRCTMPL) Makefile.am src/Makefile.inc | ||||||
|  |  | ||||||
| VC14_LIBTMPL = projects/Windows/VC14/lib/libcurl.tmpl |  | ||||||
| VC14_LIBVCXPROJ = projects/Windows/VC14/lib/libcurl.vcxproj.dist |  | ||||||
| VC14_LIBVCXPROJ_DEPS = $(VC14_LIBTMPL) Makefile.am lib/Makefile.inc |  | ||||||
| VC14_SRCTMPL = projects/Windows/VC14/src/curl.tmpl |  | ||||||
| VC14_SRCVCXPROJ = projects/Windows/VC14/src/curl.vcxproj.dist |  | ||||||
| VC14_SRCVCXPROJ_DEPS = $(VC14_SRCTMPL) Makefile.am src/Makefile.inc |  | ||||||
|  |  | ||||||
| VC_DIST = projects/README	\ | VC_DIST = projects/README	\ | ||||||
|  projects/build-openssl.bat	\ |  projects/build-openssl.bat	\ | ||||||
|  projects/build-wolfssl.bat	\ |  | ||||||
|  projects/checksrc.bat	\ |  projects/checksrc.bat	\ | ||||||
|  projects/Windows/VC6/curl-all.dsw	\ |  projects/Windows/VC6/curl-all.dsw	\ | ||||||
|  projects/Windows/VC6/lib/libcurl.dsw \ |  projects/Windows/VC6/lib/libcurl.dsw \ | ||||||
|  projects/Windows/VC6/src/curl.dsw \ |  projects/Windows/VC6/src/curlsrc.dsw \ | ||||||
|  projects/Windows/VC7/curl-all.sln	\ |  projects/Windows/VC7/curl-all.sln	\ | ||||||
|  projects/Windows/VC7/lib/libcurl.sln 	\ |  projects/Windows/VC7/lib/libcurl.sln 	\ | ||||||
|  projects/Windows/VC7/src/curl.sln 	\ |  projects/Windows/VC7/src/curlsrc.sln 	\ | ||||||
|  projects/Windows/VC7.1/curl-all.sln	\ |  projects/Windows/VC7.1/curl-all.sln	\ | ||||||
|  projects/Windows/VC7.1/lib/libcurl.sln \ |  projects/Windows/VC7.1/lib/libcurl.sln \ | ||||||
|  projects/Windows/VC7.1/src/curl.sln \ |  projects/Windows/VC7.1/src/curlsrc.sln \ | ||||||
|  projects/Windows/VC8/curl-all.sln	\ |  projects/Windows/VC8/curl-all.sln	\ | ||||||
|  projects/Windows/VC8/lib/libcurl.sln 	\ |  projects/Windows/VC8/lib/libcurl.sln 	\ | ||||||
|  projects/Windows/VC8/src/curl.sln 	\ |  projects/Windows/VC8/src/curlsrc.sln 	\ | ||||||
|  projects/Windows/VC9/curl-all.sln	\ |  projects/Windows/VC9/curl-all.sln	\ | ||||||
|  projects/Windows/VC9/lib/libcurl.sln 	\ |  projects/Windows/VC9/lib/libcurl.sln 	\ | ||||||
|  projects/Windows/VC9/src/curl.sln 	\ |  projects/Windows/VC9/src/curlsrc.sln 	\ | ||||||
|  projects/Windows/VC10/curl-all.sln	\ |  projects/Windows/VC10/curl-all.sln	\ | ||||||
|  projects/Windows/VC10/lib/libcurl.sln 	\ |  projects/Windows/VC10/lib/libcurl.sln 	\ | ||||||
|  projects/Windows/VC10/src/curl.sln  \ |  projects/Windows/VC10/src/curlsrc.sln  \ | ||||||
|  projects/Windows/VC11/curl-all.sln	\ |  projects/Windows/VC11/curl-all.sln	\ | ||||||
|  projects/Windows/VC11/lib/libcurl.sln 	\ |  projects/Windows/VC11/lib/libcurl.sln 	\ | ||||||
|  projects/Windows/VC11/src/curl.sln 	\ |  projects/Windows/VC11/src/curlsrc.sln 	\ | ||||||
|  projects/Windows/VC12/curl-all.sln	\ |  projects/Windows/VC12/curl-all.sln	\ | ||||||
|  projects/Windows/VC12/lib/libcurl.sln 	\ |  projects/Windows/VC12/lib/libcurl.sln 	\ | ||||||
|  projects/Windows/VC12/src/curl.sln	\ |  projects/Windows/VC12/src/curlsrc.sln | ||||||
|  projects/Windows/VC14/curl-all.sln	\ |  | ||||||
|  projects/Windows/VC14/lib/libcurl.sln 	\ |  | ||||||
|  projects/Windows/VC14/src/curl.sln |  | ||||||
|  |  | ||||||
| WINBUILD_DIST = winbuild/BUILD.WINDOWS.txt winbuild/gen_resp_file.bat	\ | WINBUILD_DIST = winbuild/BUILD.WINDOWS.txt winbuild/gen_resp_file.bat	\ | ||||||
|  winbuild/MakefileBuild.vc winbuild/Makefile.vc				\ |  winbuild/MakefileBuild.vc winbuild/Makefile.vc				\ | ||||||
| @@ -135,12 +124,11 @@ EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | |||||||
| CLEANFILES = $(VC6_LIBDSP) $(VC6_SRCDSP) $(VC7_LIBVCPROJ) $(VC7_SRCVCPROJ)	\ | CLEANFILES = $(VC6_LIBDSP) $(VC6_SRCDSP) $(VC7_LIBVCPROJ) $(VC7_SRCVCPROJ)	\ | ||||||
|  $(VC71_LIBVCPROJ) $(VC71_SRCVCPROJ) $(VC8_LIBVCPROJ) $(VC8_SRCVCPROJ)	\ |  $(VC71_LIBVCPROJ) $(VC71_SRCVCPROJ) $(VC8_LIBVCPROJ) $(VC8_SRCVCPROJ)	\ | ||||||
|  $(VC9_LIBVCPROJ) $(VC9_SRCVCPROJ) $(VC10_LIBVCXPROJ) $(VC10_SRCVCXPROJ)	\ |  $(VC9_LIBVCPROJ) $(VC9_SRCVCPROJ) $(VC10_LIBVCXPROJ) $(VC10_SRCVCXPROJ)	\ | ||||||
|  $(VC11_LIBVCXPROJ) $(VC11_SRCVCXPROJ) $(VC12_LIBVCXPROJ) $(VC12_SRCVCXPROJ)	\ |  $(VC11_LIBVCXPROJ) $(VC11_SRCVCXPROJ) $(VC12_LIBVCXPROJ) $(VC12_SRCVCXPROJ) | ||||||
|  $(VC14_LIBVCXPROJ) $(VC14_SRCVCXPROJ) |  | ||||||
|  |  | ||||||
| bin_SCRIPTS = curl-config | bin_SCRIPTS = curl-config | ||||||
|  |  | ||||||
| SUBDIRS = lib src include scripts | SUBDIRS = lib src include | ||||||
| DIST_SUBDIRS = $(SUBDIRS) tests packages docs | DIST_SUBDIRS = $(SUBDIRS) tests packages docs | ||||||
|  |  | ||||||
| pkgconfigdir = $(libdir)/pkgconfig | pkgconfigdir = $(libdir)/pkgconfig | ||||||
| @@ -160,10 +148,10 @@ dist-hook: | |||||||
| 	done) | 	done) | ||||||
|  |  | ||||||
| html: | html: | ||||||
| 	cd docs && make html | 	cd docs; make html | ||||||
|  |  | ||||||
| pdf: | pdf: | ||||||
| 	cd docs && make pdf | 	cd docs; make pdf | ||||||
|  |  | ||||||
| check: test examples check-docs | check: test examples check-docs | ||||||
|  |  | ||||||
| @@ -281,7 +269,7 @@ vc-ide: $(VC6_LIBDSP_DEPS) $(VC6_SRCDSP_DEPS) $(VC7_LIBVCPROJ_DEPS)	\ | |||||||
|  $(VC8_LIBVCPROJ_DEPS) $(VC8_SRCVCPROJ_DEPS) $(VC9_LIBVCPROJ_DEPS)	\ |  $(VC8_LIBVCPROJ_DEPS) $(VC8_SRCVCPROJ_DEPS) $(VC9_LIBVCPROJ_DEPS)	\ | ||||||
|  $(VC9_SRCVCPROJ_DEPS) $(VC10_LIBVCXPROJ_DEPS) $(VC10_SRCVCXPROJ_DEPS)	\ |  $(VC9_SRCVCPROJ_DEPS) $(VC10_LIBVCXPROJ_DEPS) $(VC10_SRCVCXPROJ_DEPS)	\ | ||||||
|  $(VC11_LIBVCXPROJ_DEPS) $(VC11_SRCVCXPROJ_DEPS) $(VC12_LIBVCXPROJ_DEPS)	\ |  $(VC11_LIBVCXPROJ_DEPS) $(VC11_SRCVCXPROJ_DEPS) $(VC12_LIBVCXPROJ_DEPS)	\ | ||||||
|  $(VC12_SRCVCXPROJ_DEPS) $(VC14_LIBVCXPROJ_DEPS) $(VC14_SRCVCXPROJ_DEPS) |  $(VC12_SRCVCXPROJ_DEPS) | ||||||
| 	@(win32_lib_srcs='$(LIB_CFILES)'; \ | 	@(win32_lib_srcs='$(LIB_CFILES)'; \ | ||||||
| 	win32_lib_hdrs='$(LIB_HFILES) config-win32.h'; \ | 	win32_lib_hdrs='$(LIB_HFILES) config-win32.h'; \ | ||||||
| 	win32_lib_rc='$(LIB_RCFILES)'; \ | 	win32_lib_rc='$(LIB_RCFILES)'; \ | ||||||
| @@ -542,22 +530,4 @@ function gen_element(type, dir, file)\ | |||||||
| 		-v src_rc="$$win32_src_rc" \ | 		-v src_rc="$$win32_src_rc" \ | ||||||
| 		-v src_x_srcs="$$sorted_src_x_srcs" \ | 		-v src_x_srcs="$$sorted_src_x_srcs" \ | ||||||
| 		-v src_x_hdrs="$$sorted_src_x_hdrs" \ | 		-v src_x_hdrs="$$sorted_src_x_hdrs" \ | ||||||
| 		"$$awk_code" $(srcdir)/$(VC12_SRCTMPL) > $(VC12_SRCVCXPROJ) || { exit 1; }; \ | 		"$$awk_code" $(srcdir)/$(VC12_SRCTMPL) > $(VC12_SRCVCXPROJ) || { exit 1; };) | ||||||
| 	\ |  | ||||||
| 	echo "generating '$(VC14_LIBVCXPROJ)'"; \ |  | ||||||
| 	awk -v proj_type=vcxproj \ |  | ||||||
| 		-v lib_srcs="$$sorted_lib_srcs" \ |  | ||||||
| 		-v lib_hdrs="$$sorted_lib_hdrs" \ |  | ||||||
| 		-v lib_rc="$$win32_lib_rc" \ |  | ||||||
| 		-v lib_vtls_srcs="$$sorted_lib_vtls_srcs" \ |  | ||||||
| 		-v lib_vtls_hdrs="$$sorted_lib_vtls_hdrs" \ |  | ||||||
| 		"$$awk_code" $(srcdir)/$(VC14_LIBTMPL) > $(VC14_LIBVCXPROJ) || { exit 1; }; \ |  | ||||||
| 	\ |  | ||||||
| 	echo "generating '$(VC14_SRCVCXPROJ)'"; \ |  | ||||||
| 	awk -v proj_type=vcxproj \ |  | ||||||
| 		-v src_srcs="$$sorted_src_srcs" \ |  | ||||||
| 		-v src_hdrs="$$sorted_src_hdrs" \ |  | ||||||
| 		-v src_rc="$$win32_src_rc" \ |  | ||||||
| 		-v src_x_srcs="$$sorted_src_x_srcs" \ |  | ||||||
| 		-v src_x_hdrs="$$sorted_src_x_hdrs" \ |  | ||||||
| 		"$$awk_code" $(srcdir)/$(VC14_SRCTMPL) > $(VC14_SRCVCXPROJ) || { exit 1; };) |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -566,17 +566,6 @@ src/Makefile.vc12: src/Makefile.vc6 | |||||||
| 	@echo "generate $@" | 	@echo "generate $@" | ||||||
| 	@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc12/g" -e "s/VC6/VC12/g" src/Makefile.vc6 > src/Makefile.vc12 | 	@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc12/g" -e "s/VC6/VC12/g" src/Makefile.vc6 > src/Makefile.vc12 | ||||||
|  |  | ||||||
| # VC14 makefiles are for use with VS2015 |  | ||||||
| vc14: lib/Makefile.vc14 src/Makefile.vc14 |  | ||||||
|  |  | ||||||
| lib/Makefile.vc14: lib/Makefile.vc6 |  | ||||||
| 	@echo "generate $@" |  | ||||||
| 	@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc14/g" -e "s/VC6/VC14/g" lib/Makefile.vc6 > lib/Makefile.vc14 |  | ||||||
|  |  | ||||||
| src/Makefile.vc14: src/Makefile.vc6 |  | ||||||
| 	@echo "generate $@" |  | ||||||
| 	@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc14/g" -e "s/VC6/VC14/g" src/Makefile.vc6 > src/Makefile.vc14 |  | ||||||
|  |  | ||||||
| ca-bundle: lib/mk-ca-bundle.pl | ca-bundle: lib/mk-ca-bundle.pl | ||||||
| 	@echo "generate a fresh ca-bundle.crt" | 	@echo "generate a fresh ca-bundle.crt" | ||||||
| 	@perl $< -b -l -u lib/ca-bundle.crt | 	@perl $< -b -l -u lib/ca-bundle.crt | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								README
									
									
									
									
									
								
							| @@ -24,7 +24,7 @@ README | |||||||
| CONTACT | CONTACT | ||||||
|  |  | ||||||
|   If you have problems, questions, ideas or suggestions, please contact us |   If you have problems, questions, ideas or suggestions, please contact us | ||||||
|   by posting to a suitable mailing list. See https://curl.haxx.se/mail/ |   by posting to a suitable mailing list. See http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
|   All contributors to the project are listed in the THANKS document. |   All contributors to the project are listed in the THANKS document. | ||||||
|  |  | ||||||
| @@ -32,13 +32,13 @@ WEB SITE | |||||||
|  |  | ||||||
|   Visit the curl web site for the latest news and downloads: |   Visit the curl web site for the latest news and downloads: | ||||||
|  |  | ||||||
|         https://curl.haxx.se/ |         http://curl.haxx.se/ | ||||||
|  |  | ||||||
| GIT | GIT | ||||||
|  |  | ||||||
|   To download the very latest source off the GIT server do this: |   To download the very latest source off the GIT server do this: | ||||||
|  |  | ||||||
|     git clone https://github.com/curl/curl.git |     git clone https://github.com/bagder/curl.git | ||||||
|  |  | ||||||
|   (you'll get a directory named curl created, filled with the source code) |   (you'll get a directory named curl created, filled with the source code) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,48 +1,31 @@ | |||||||
| Curl and libcurl 7.47.1 | Curl and libcurl 7.44.0 | ||||||
|  |  | ||||||
|  |  Public curl releases:         148 | ||||||
|  |  Command line options:         176 | ||||||
|  |  curl_easy_setopt() options:   219 | ||||||
|  |  Public functions in libcurl:  58 | ||||||
|  |  Contributors:                 1291 | ||||||
|  |  | ||||||
|  | This release includes the following changes: | ||||||
|  |  | ||||||
|  |  o | ||||||
|  |  | ||||||
|  Public curl releases:         152 |  | ||||||
|  Command line options:         179 |  | ||||||
|  curl_easy_setopt() options:   221 |  | ||||||
|  Public functions in libcurl:  61 |  | ||||||
|  Contributors:                 1346 |  | ||||||
|  |  | ||||||
| This release includes the following bugfixes: | This release includes the following bugfixes: | ||||||
|  |  | ||||||
|  o getredirect.c: fix variable name |  o | ||||||
|  o tool_doswin: silence unused function warning [1] |  | ||||||
|  o cmake: fixed when OpenSSL enabled on Windows and schannel detected [2] |  | ||||||
|  o curl.1: Explain remote-name behavior if file already exists |  | ||||||
|  o tool_operate: Don't sanitize --output path (Windows) [3] |  | ||||||
|  o URLs: change all http:// URLs to https:// in documentation & comments |  | ||||||
|  o sasl_sspi: Fix memory leak in domain populate [4] |  | ||||||
|  o COPYING: clarify that Daniel is not the sole author |  | ||||||
|  o examples/htmltitle: Use _stricmp on Windows [5] |  | ||||||
|  o examples/asiohiper: Avoid function name collision on Windows [6] |  | ||||||
|  o idn_win32: Better error checking [7] |  | ||||||
|  o openssl: Fix signed/unsigned mismatch warning in X509V3_ext [8] |  | ||||||
|  o curl save files: check for backslashes on cygwin [9] |  | ||||||
|  |  | ||||||
| This release includes the following known bugs: | This release includes the following known bugs: | ||||||
|  |  | ||||||
|  o see docs/KNOWN_BUGS (https://curl.haxx.se/docs/knownbugs.html) |  o see docs/KNOWN_BUGS (http://curl.haxx.se/docs/knownbugs.html) | ||||||
|  |  | ||||||
| This release would not have looked like this without help, code, reports and | This release would not have looked like this without help, code, reports and | ||||||
| advice from friends like these: | advice from friends like these: | ||||||
|  |  | ||||||
|   Bernard Spil, Dan Fandrich, Daniel Stenberg, Gisle Vanem, Michael Kaufmann, |  | ||||||
|   Octavio Schroeder, Ray Satiro, Sergei Nikulov, Viktor Szakáts, |  | ||||||
|   (9 contributors) |  | ||||||
|  |  | ||||||
|         Thanks! (and sorry if I forgot to mention someone) |         Thanks! (and sorry if I forgot to mention someone) | ||||||
|  |  | ||||||
| References to bug reports and discussions on issues: | References to bug reports and discussions on issues: | ||||||
|  |  | ||||||
|  [1] = https://github.com/curl/curl/pull/616 |  [1] = | ||||||
|  [2] = https://curl.haxx.se/bug/?i=617 |  | ||||||
|  [3] = https://curl.haxx.se/bug/?i=624 |  | ||||||
|  [4] = https://github.com/curl/curl/issues/635 |  | ||||||
|  [5] = https://curl.haxx.se/mail/lib-2016-02/0017.html |  | ||||||
|  [6] = https://curl.haxx.se/mail/lib-2016-02/0016.html |  | ||||||
|  [7] = https://github.com/curl/curl/pull/637 |  | ||||||
|  [8] = https://github.com/curl/curl/commit/dd1b44c#commitcomment-15913896 |  | ||||||
|  [9] = https://curl.haxx.se/docs/adv_20160127B.html |  | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -5,11 +5,11 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -1851,10 +1851,8 @@ AC_DEFUN([CURL_CHECK_FUNC_CLOCK_GETTIME_MONOTONIC], [ | |||||||
|   AC_REQUIRE([AC_HEADER_TIME])dnl |   AC_REQUIRE([AC_HEADER_TIME])dnl | ||||||
|   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h) |   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h) | ||||||
|   AC_MSG_CHECKING([for monotonic clock_gettime]) |   AC_MSG_CHECKING([for monotonic clock_gettime]) | ||||||
|   # |   AC_COMPILE_IFELSE([ | ||||||
|   if test "x$dontwant_rt" == "xno" ; then |     AC_LANG_PROGRAM([[ | ||||||
|     AC_COMPILE_IFELSE([ |  | ||||||
|       AC_LANG_PROGRAM([[ |  | ||||||
| #ifdef HAVE_SYS_TYPES_H | #ifdef HAVE_SYS_TYPES_H | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #endif | #endif | ||||||
| @@ -1868,18 +1866,17 @@ AC_DEFUN([CURL_CHECK_FUNC_CLOCK_GETTIME_MONOTONIC], [ | |||||||
| #include <time.h> | #include <time.h> | ||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
|       ]],[[ |     ]],[[ | ||||||
|         struct timespec ts; |       struct timespec ts; | ||||||
|         (void)clock_gettime(CLOCK_MONOTONIC, &ts); |       (void)clock_gettime(CLOCK_MONOTONIC, &ts); | ||||||
|       ]]) |     ]]) | ||||||
|     ],[ |   ],[ | ||||||
|       AC_MSG_RESULT([yes]) |     AC_MSG_RESULT([yes]) | ||||||
|       ac_cv_func_clock_gettime="yes" |     ac_cv_func_clock_gettime="yes" | ||||||
|     ],[ |   ],[ | ||||||
|       AC_MSG_RESULT([no]) |     AC_MSG_RESULT([no]) | ||||||
|       ac_cv_func_clock_gettime="no" |     ac_cv_func_clock_gettime="no" | ||||||
|     ]) |   ]) | ||||||
|   fi |  | ||||||
|   dnl Definition of HAVE_CLOCK_GETTIME_MONOTONIC is intentionally postponed |   dnl Definition of HAVE_CLOCK_GETTIME_MONOTONIC is intentionally postponed | ||||||
|   dnl until library linking and run-time checks for clock_gettime succeed. |   dnl until library linking and run-time checks for clock_gettime succeed. | ||||||
| ]) | ]) | ||||||
| @@ -2837,6 +2834,7 @@ AC_DEFUN([CURL_CONFIGURE_CURL_OFF_T], [ | |||||||
|   # |   # | ||||||
|   x_LP64_long="" |   x_LP64_long="" | ||||||
|   x_LP32_long="" |   x_LP32_long="" | ||||||
|  |   x_LP16_long="" | ||||||
|   # |   # | ||||||
|   if test "$ac_cv_sizeof_long" -eq "8" && |   if test "$ac_cv_sizeof_long" -eq "8" && | ||||||
|      test "$ac_cv_sizeof_voidp" -ge "8"; then |      test "$ac_cv_sizeof_voidp" -ge "8"; then | ||||||
| @@ -2844,6 +2842,9 @@ AC_DEFUN([CURL_CONFIGURE_CURL_OFF_T], [ | |||||||
|   elif test "$ac_cv_sizeof_long" -eq "4" && |   elif test "$ac_cv_sizeof_long" -eq "4" && | ||||||
|        test "$ac_cv_sizeof_voidp" -ge "4"; then |        test "$ac_cv_sizeof_voidp" -ge "4"; then | ||||||
|     x_LP32_long="long" |     x_LP32_long="long" | ||||||
|  |   elif test "$ac_cv_sizeof_long" -eq "2" && | ||||||
|  |        test "$ac_cv_sizeof_voidp" -ge "2"; then | ||||||
|  |     x_LP16_long="long" | ||||||
|   fi |   fi | ||||||
|   # |   # | ||||||
|   dnl DO_CURL_OFF_T_CHECK results are stored in next 3 vars |   dnl DO_CURL_OFF_T_CHECK results are stored in next 3 vars | ||||||
| @@ -2877,6 +2878,17 @@ AC_DEFUN([CURL_CONFIGURE_CURL_OFF_T], [ | |||||||
|     done |     done | ||||||
|     AC_MSG_RESULT([$curl_typeof_curl_off_t]) |     AC_MSG_RESULT([$curl_typeof_curl_off_t]) | ||||||
|   fi |   fi | ||||||
|  |   if test "$curl_typeof_curl_off_t" = "unknown"; then | ||||||
|  |     AC_MSG_CHECKING([for 16-bit curl_off_t data type]) | ||||||
|  |     for t2 in          \ | ||||||
|  |       "$x_LP16_long"   \ | ||||||
|  |       'int16_t'        \ | ||||||
|  |       '__int16'        \ | ||||||
|  |       'int'            ; do | ||||||
|  |       DO_CURL_OFF_T_CHECK([$t2], [2]) | ||||||
|  |     done | ||||||
|  |     AC_MSG_RESULT([$curl_typeof_curl_off_t]) | ||||||
|  |   fi | ||||||
|   if test "$curl_typeof_curl_off_t" = "unknown"; then |   if test "$curl_typeof_curl_off_t" = "unknown"; then | ||||||
|     AC_MSG_ERROR([cannot find data type for curl_off_t.]) |     AC_MSG_ERROR([cannot find data type for curl_off_t.]) | ||||||
|   fi |   fi | ||||||
| @@ -3037,14 +3049,12 @@ dnl Optionally PKG_CONFIG_LIBDIR may be given as $pcdir. | |||||||
| dnl | dnl | ||||||
|  |  | ||||||
| AC_DEFUN([CURL_CHECK_PKGCONFIG], [ | AC_DEFUN([CURL_CHECK_PKGCONFIG], [ | ||||||
|     if test -n "$PKG_CONFIG"; then |  | ||||||
|       PKGCONFIG="$PKG_CONFIG" |  | ||||||
|     else |  | ||||||
|       AC_PATH_TOOL([PKGCONFIG], [pkg-config], [no], |  | ||||||
|         [$PATH:/usr/bin:/usr/local/bin]) |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|     if test "x$PKGCONFIG" != "xno"; then |     PKGCONFIG="no" | ||||||
|  |  | ||||||
|  |     AC_PATH_TOOL( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin) | ||||||
|  |  | ||||||
|  |     if test x$PKGCONFIG != xno; then | ||||||
|       AC_MSG_CHECKING([for $1 options with pkg-config]) |       AC_MSG_CHECKING([for $1 options with pkg-config]) | ||||||
|       dnl ask pkg-config about $1 |       dnl ask pkg-config about $1 | ||||||
|       itexists=`CURL_EXPORT_PCDIR([$2]) dnl |       itexists=`CURL_EXPORT_PCDIR([$2]) dnl | ||||||
|   | |||||||
							
								
								
									
										35
									
								
								appveyor.yml
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								appveyor.yml
									
									
									
									
									
								
							| @@ -1,35 +0,0 @@ | |||||||
| version: 7.47.0.{build} |  | ||||||
|  |  | ||||||
| environment: |  | ||||||
|     matrix: |  | ||||||
|       - PRJ_GEN: "Visual Studio 11 2012 Win64" |  | ||||||
|         BDIR: msvc2012 |  | ||||||
|         PRJ_CFG: Release |  | ||||||
|         OPENSSL: OFF |  | ||||||
|       - PRJ_GEN: "Visual Studio 12 2013 Win64" |  | ||||||
|         BDIR: msvc2013 |  | ||||||
|         PRJ_CFG: Release |  | ||||||
|         OPENSSL: OFF |  | ||||||
|       - PRJ_GEN: "Visual Studio 14 2015 Win64" |  | ||||||
|         BDIR: msvc2015 |  | ||||||
|         PRJ_CFG: Release |  | ||||||
|         OPENSSL: OFF |  | ||||||
|       - PRJ_GEN: "Visual Studio 11 2012 Win64" |  | ||||||
|         BDIR: msvc2012 |  | ||||||
|         PRJ_CFG: Release |  | ||||||
|         OPENSSL: ON |  | ||||||
|       - PRJ_GEN: "Visual Studio 12 2013 Win64" |  | ||||||
|         BDIR: msvc2013 |  | ||||||
|         PRJ_CFG: Release |  | ||||||
|         OPENSSL: ON |  | ||||||
|       - PRJ_GEN: "Visual Studio 14 2015 Win64" |  | ||||||
|         BDIR: msvc2015 |  | ||||||
|         PRJ_CFG: Release |  | ||||||
|         OPENSSL: ON |  | ||||||
|  |  | ||||||
|  |  | ||||||
| build_script: |  | ||||||
|     - mkdir build.%BDIR% |  | ||||||
|     - cd build.%BDIR% |  | ||||||
|     - cmake .. -G"%PRJ_GEN%" -DCMAKE_USE_OPENSSL=%OPENSSL% |  | ||||||
|     - cmake --build . --config %PRJ_CFG% --clean-first |  | ||||||
| @@ -10,7 +10,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
							
								
								
									
										374
									
								
								buildconf.bat
									
									
									
									
									
								
							
							
						
						
									
										374
									
								
								buildconf.bat
									
									
									
									
									
								
							| @@ -1,352 +1,38 @@ | |||||||
| @echo off | @echo off | ||||||
| rem *************************************************************************** | REM | ||||||
| rem *                                  _   _ ____  _ | REM | ||||||
| rem *  Project                     ___| | | |  _ \| | | REM This batch file must be used to set up a git tree to build on | ||||||
| rem *                             / __| | | | |_) | | | REM systems where there is no autotools support (i.e. Microsoft). | ||||||
| rem *                            | (__| |_| |  _ <| |___ | REM | ||||||
| rem *                             \___|\___/|_| \_\_____| | REM This file is not included nor needed for curl's release | ||||||
| rem * | REM archives, neither for curl's daily snapshot archives. | ||||||
| rem * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  | ||||||
| rem * |  | ||||||
| rem * This software is licensed as described in the file COPYING, which |  | ||||||
| rem * you should have received as part of this distribution. The terms |  | ||||||
| rem * are also available at https://curl.haxx.se/docs/copyright.html. |  | ||||||
| rem * |  | ||||||
| rem * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  | ||||||
| rem * copies of the Software, and permit persons to whom the Software is |  | ||||||
| rem * furnished to do so, under the terms of the COPYING file. |  | ||||||
| rem * |  | ||||||
| rem * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |  | ||||||
| rem * KIND, either express or implied. |  | ||||||
| rem * |  | ||||||
| rem *************************************************************************** |  | ||||||
|  |  | ||||||
| rem NOTES | if exist GIT-INFO goto start_doing | ||||||
| rem | ECHO ERROR: This file shall only be used with a curl git tree checkout. | ||||||
| rem This batch file must be used to set up a git tree to build on systems where | goto end_all | ||||||
| rem there is no autotools support (i.e. DOS and Windows). | :start_doing | ||||||
| rem |  | ||||||
| rem This file is not included or required for curl's release archives or daily  |  | ||||||
| rem snapshot archives. |  | ||||||
|  |  | ||||||
| :begin | REM create tool_hugehelp.c | ||||||
|   rem Set our variables | if not exist src\tool_hugehelp.c.cvs goto end_hugehelp_c | ||||||
|   if "%OS%" == "Windows_NT" setlocal | copy /Y src\tool_hugehelp.c.cvs src\tool_hugehelp.c | ||||||
|   set MODE=GENERATE | :end_hugehelp_c | ||||||
|  |  | ||||||
|   rem Switch to this batch file's directory | REM create Makefile | ||||||
|   cd /d "%~0\.." 1>NUL 2>&1 | if not exist Makefile.dist goto end_makefile | ||||||
|  | copy /Y Makefile.dist Makefile | ||||||
|  | :end_makefile | ||||||
|  |  | ||||||
|   rem Check we are running from a curl git repository | REM create curlbuild.h | ||||||
|   if not exist GIT-INFO goto norepo | if not exist include\curl\curlbuild.h.dist goto end_curlbuild_h | ||||||
|  | copy /Y include\curl\curlbuild.h.dist include\curl\curlbuild.h | ||||||
|  | :end_curlbuild_h | ||||||
|  |  | ||||||
|   rem Detect programs. HAVE_<PROGNAME> | REM setup c-ares git tree | ||||||
|   rem When not found the variable is set undefined. The undefined pattern | if not exist ares\buildconf.bat goto end_c_ares | ||||||
|   rem allows for statements like "if not defined HAVE_PERL (command)" | cd ares | ||||||
|   groff --version <NUL 1>NUL 2>&1 | call buildconf.bat | ||||||
|   if errorlevel 1 (set HAVE_GROFF=) else (set HAVE_GROFF=Y) | cd .. | ||||||
|   nroff --version <NUL 1>NUL 2>&1 | :end_c_ares | ||||||
|   if errorlevel 1 (set HAVE_NROFF=) else (set HAVE_NROFF=Y) |  | ||||||
|   perl --version <NUL 1>NUL 2>&1 |  | ||||||
|   if errorlevel 1 (set HAVE_PERL=) else (set HAVE_PERL=Y) |  | ||||||
|   gzip --version <NUL 1>NUL 2>&1 |  | ||||||
|   if errorlevel 1 (set HAVE_GZIP=) else (set HAVE_GZIP=Y) |  | ||||||
|  |  | ||||||
| :parseArgs | :end_all | ||||||
|   if "%~1" == "" goto start |  | ||||||
|  |  | ||||||
|   if /i "%~1" == "-clean" ( |  | ||||||
|     set MODE=CLEAN |  | ||||||
|   ) else if /i "%~1" == "-?" ( |  | ||||||
|     goto syntax |  | ||||||
|   ) else if /i "%~1" == "-h" ( |  | ||||||
|     goto syntax |  | ||||||
|   ) else if /i "%~1" == "-help" ( |  | ||||||
|     goto syntax |  | ||||||
|   ) else ( |  | ||||||
|     goto unknown |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   shift & goto parseArgs |  | ||||||
|  |  | ||||||
| :start |  | ||||||
|   if "%MODE%" == "GENERATE" ( |  | ||||||
|     echo. |  | ||||||
|     echo Generating prerequisite files |  | ||||||
|  |  | ||||||
|     call :generate |  | ||||||
|     if errorlevel 4 goto nogencurlbuild |  | ||||||
|     if errorlevel 3 goto nogenhugehelp |  | ||||||
|     if errorlevel 2 goto nogenmakefile |  | ||||||
|     if errorlevel 1 goto warning |  | ||||||
|  |  | ||||||
|   ) else ( |  | ||||||
|     echo. |  | ||||||
|     echo Removing prerequisite files |  | ||||||
|  |  | ||||||
|     call :clean |  | ||||||
|     if errorlevel 3 goto nocleancurlbuild |  | ||||||
|     if errorlevel 2 goto nocleanhugehelp |  | ||||||
|     if errorlevel 1 goto nocleanmakefile |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   goto success |  | ||||||
|  |  | ||||||
| rem Main generate function. |  | ||||||
| rem |  | ||||||
| rem Returns: |  | ||||||
| rem |  | ||||||
| rem 0 - success |  | ||||||
| rem 1 - success with simplified tool_hugehelp.c  |  | ||||||
| rem 2 - failed to generate Makefile |  | ||||||
| rem 3 - failed to generate tool_hugehelp.c |  | ||||||
| rem 4 - failed to generate curlbuild.h |  | ||||||
| rem |  | ||||||
| :generate |  | ||||||
|   if "%OS%" == "Windows_NT" setlocal |  | ||||||
|   set BASIC_HUGEHELP=0 |  | ||||||
|  |  | ||||||
|   rem Create Makefile |  | ||||||
|   echo * %CD%\Makefile |  | ||||||
|   if exist Makefile.dist ( |  | ||||||
|     copy /Y Makefile.dist Makefile 1>NUL 2>&1 |  | ||||||
|     if errorlevel 1 ( |  | ||||||
|       if "%OS%" == "Windows_NT" endlocal |  | ||||||
|       exit /B 2 |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   rem Create tool_hugehelp.c |  | ||||||
|   echo * %CD%\src\tool_hugehelp.c |  | ||||||
|   call :genHugeHelp |  | ||||||
|   if errorlevel 2 ( |  | ||||||
|     if "%OS%" == "Windows_NT" endlocal |  | ||||||
|     exit /B 3 |  | ||||||
|   ) |  | ||||||
|   if errorlevel 1 ( |  | ||||||
|     set BASIC_HUGEHELP=1 |  | ||||||
|   ) |  | ||||||
|   cmd /c exit 0 |  | ||||||
|  |  | ||||||
|   rem Create curlbuild.h |  | ||||||
|   echo * %CD%\include\curl\curlbuild.h |  | ||||||
|   if exist include\curl\curlbuild.h.dist ( |  | ||||||
|     copy /Y include\curl\curlbuild.h.dist include\curl\curlbuild.h 1>NUL 2>&1 |  | ||||||
|     if errorlevel 1 ( |  | ||||||
|       if "%OS%" == "Windows_NT" endlocal |  | ||||||
|       exit /B 4 |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   rem Setup c-ares git tree |  | ||||||
|   if exist ares\buildconf.bat ( |  | ||||||
|     echo. |  | ||||||
|     echo Configuring c-ares build environment |  | ||||||
|     cd ares |  | ||||||
|     call buildconf.bat |  | ||||||
|     cd .. |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   if "%BASIC_HUGEHELP%" == "1" ( |  | ||||||
|     if "%OS%" == "Windows_NT" endlocal |  | ||||||
|     exit /B 1 |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   if "%OS%" == "Windows_NT" endlocal |  | ||||||
|   exit /B 0 |  | ||||||
|  |  | ||||||
| rem Main clean function. |  | ||||||
| rem |  | ||||||
| rem Returns: |  | ||||||
| rem |  | ||||||
| rem 0 - success |  | ||||||
| rem 1 - failed to clean Makefile |  | ||||||
| rem 2 - failed to clean tool_hugehelp.c |  | ||||||
| rem 3 - failed to clean curlbuild.h |  | ||||||
| rem |  | ||||||
| :clean |  | ||||||
|   rem Remove Makefile |  | ||||||
|   echo * %CD%\Makefile |  | ||||||
|   if exist Makefile ( |  | ||||||
|     del Makefile 2>NUL |  | ||||||
|     if exist Makefile ( |  | ||||||
|       exit /B 1 |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   rem Remove tool_hugehelp.c |  | ||||||
|   echo * %CD%\src\tool_hugehelp.c |  | ||||||
|   if exist src\tool_hugehelp.c ( |  | ||||||
|     del src\tool_hugehelp.c 2>NUL |  | ||||||
|     if exist src\tool_hugehelp.c ( |  | ||||||
|       exit /B 2 |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   rem Remove curlbuild.h |  | ||||||
|   echo * %CD%\include\curl\curlbuild.h |  | ||||||
|   if exist include\curl\curlbuild.h ( |  | ||||||
|     del include\curl\curlbuild.h 2>NUL |  | ||||||
|     if exist include\curl\curlbuild.h ( |  | ||||||
|       exit /B 3 |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   exit /B |  | ||||||
|  |  | ||||||
| rem Function to generate src\tool_hugehelp.c |  | ||||||
| rem |  | ||||||
| rem Returns: |  | ||||||
| rem |  | ||||||
| rem 0 - full tool_hugehelp.c generated |  | ||||||
| rem 1 - simplified tool_hugehelp.c |  | ||||||
| rem 2 - failure |  | ||||||
| rem |  | ||||||
| :genHugeHelp |  | ||||||
|   if "%OS%" == "Windows_NT" setlocal |  | ||||||
|   set LC_ALL=C |  | ||||||
|   set ROFFCMD= |  | ||||||
|   set BASIC=1 |  | ||||||
|  |  | ||||||
|   if defined HAVE_PERL ( |  | ||||||
|     if defined HAVE_GROFF ( |  | ||||||
|       set ROFFCMD=groff -mtty-char -Tascii -P-c -man |  | ||||||
|     ) else if defined HAVE_NROFF ( |  | ||||||
|       set ROFFCMD=nroff -c -Tascii -man |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   if defined ROFFCMD ( |  | ||||||
|     echo #include "tool_setup.h"> src\tool_hugehelp.c |  | ||||||
|     echo #include "tool_hugehelp.h">> src\tool_hugehelp.c  |  | ||||||
|  |  | ||||||
|     if defined HAVE_GZIP ( |  | ||||||
|       echo #ifndef HAVE_LIBZ>> src\tool_hugehelp.c |  | ||||||
|     ) |  | ||||||
|  |  | ||||||
|     %ROFFCMD% docs\curl.1 2>NUL | perl src\mkhelp.pl docs\MANUAL >> src\tool_hugehelp.c |  | ||||||
|     if defined HAVE_GZIP ( |  | ||||||
|       echo #else>> src\tool_hugehelp.c |  | ||||||
|       %ROFFCMD% docs\curl.1 2>NUL | perl src\mkhelp.pl -c docs\MANUAL >> src\tool_hugehelp.c |  | ||||||
|       echo #endif /^* HAVE_LIBZ ^*/>> src\tool_hugehelp.c |  | ||||||
|     ) |  | ||||||
|  |  | ||||||
|     set BASIC=0 |  | ||||||
|   ) else ( |  | ||||||
|     if exist src\tool_hugehelp.c.cvs ( |  | ||||||
|       copy /Y src\tool_hugehelp.c.cvs src\tool_hugehelp.c 1>NUL 2>&1 |  | ||||||
|     ) else ( |  | ||||||
|       echo #include "tool_setup.h"> src\tool_hugehelp.c |  | ||||||
|       echo #include "tool_hugehelp.hd">> src\tool_hugehelp.c |  | ||||||
|       echo.>> src\tool_hugehelp.c |  | ||||||
|       echo void hugehelp(void^)>> src\tool_hugehelp.c |  | ||||||
|       echo {>> src\tool_hugehelp.c |  | ||||||
|       echo #ifdef USE_MANUAL>> src\tool_hugehelp.c |  | ||||||
|       echo   fputs("Built-in manual not included\n", stdout^);>> src\tool_hugehelp.c |  | ||||||
|       echo #endif>> src\tool_hugehelp.c |  | ||||||
|       echo }>> src\tool_hugehelp.c |  | ||||||
|     ) |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   findstr "/C:void hugehelp(void)" src\tool_hugehelp.c 1>NUL 2>&1 |  | ||||||
|   if errorlevel 1 ( |  | ||||||
|     if "%OS%" == "Windows_NT" endlocal |  | ||||||
|     exit /B 2 |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   if "%BASIC%" == "1" ( |  | ||||||
|     if "%OS%" == "Windows_NT" endlocal |  | ||||||
|     exit /B 1 |  | ||||||
|   ) |  | ||||||
|  |  | ||||||
|   if "%OS%" == "Windows_NT" endlocal |  | ||||||
|   exit /B 0 |  | ||||||
|  |  | ||||||
| rem Function to clean-up local variables under DOS, Windows 3.x and |  | ||||||
| rem Windows 9x as setlocal isn't available until Windows NT |  | ||||||
| rem |  | ||||||
| :dosCleanup |  | ||||||
|   set MODE= |  | ||||||
|   set HAVE_GROFF= |  | ||||||
|   set HAVE_NROFF= |  | ||||||
|   set HAVE_PERL= |  | ||||||
|   set HAVE_GZIP= |  | ||||||
|   set BASIC_HUGEHELP= |  | ||||||
|   set LC_ALL |  | ||||||
|   set ROFFCMD= |  | ||||||
|   set BASIC= |  | ||||||
|  |  | ||||||
|   exit /B |  | ||||||
|  |  | ||||||
| :syntax |  | ||||||
|   rem Display the help |  | ||||||
|   echo. |  | ||||||
|   echo Usage: buildconf [-clean] |  | ||||||
|   echo. |  | ||||||
|   echo -clean    - Removes the files |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :unknown |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unknown argument '%1' |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :norepo |  | ||||||
|   echo. |  | ||||||
|   echo Error: This batch file should only be used with a curl git repository |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :nogenmakefile |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unable to generate Makefile |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :nogenhugehelp |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unable to generate src\tool_hugehelp.c |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :nogencurlbuild |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unable to generate include\curl\curlbuild.h |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :nocleanmakefile |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unable to clean Makefile |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :nocleanhugehelp |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unable to clean src\tool_hugehelp.c |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :nocleancurlbuild |  | ||||||
|   echo. |  | ||||||
|   echo Error: Unable to clean include\curl\curlbuild.h |  | ||||||
|   goto error |  | ||||||
|  |  | ||||||
| :warning |  | ||||||
|   echo. |  | ||||||
|   echo Warning: The curl manual could not be integrated in the source. This means when |  | ||||||
|   echo you build curl the manual will not be available (curl --man^). Integration of |  | ||||||
|   echo the manual is not required and a summary of the options will still be available |  | ||||||
|   echo (curl --help^). To integrate the manual your PATH is required to have |  | ||||||
|   echo groff/nroff, perl and optionally gzip for compression. |  | ||||||
|   goto success |  | ||||||
|  |  | ||||||
| :error |  | ||||||
|   if "%OS%" == "Windows_NT" ( |  | ||||||
|     endlocal |  | ||||||
|   ) else ( |  | ||||||
|     call :dosCleanup |  | ||||||
|   ) |  | ||||||
|   exit /B 1 |  | ||||||
|  |  | ||||||
| :success |  | ||||||
|   if "%OS%" == "Windows_NT" ( |  | ||||||
|     endlocal |  | ||||||
|   ) else ( |  | ||||||
|     call :dosCleanup |  | ||||||
|   ) |  | ||||||
|   exit /B 0 |  | ||||||
|   | |||||||
							
								
								
									
										295
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										295
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -5,11 +5,11 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -24,14 +24,14 @@ dnl Process this file with autoconf to produce a configure script. | |||||||
| AC_PREREQ(2.57) | AC_PREREQ(2.57) | ||||||
|  |  | ||||||
| dnl We don't know the version number "statically" so we use a dash here | dnl We don't know the version number "statically" so we use a dash here | ||||||
| AC_INIT([curl], [-], [a suitable curl mailing list: https://curl.haxx.se/mail/]) | AC_INIT([curl], [-], [a suitable curl mailing list: http://curl.haxx.se/mail/]) | ||||||
|  |  | ||||||
| XC_OVR_ZZ50 | XC_OVR_ZZ50 | ||||||
| XC_OVR_ZZ60 | XC_OVR_ZZ60 | ||||||
| CURL_OVERRIDE_AUTOCONF | CURL_OVERRIDE_AUTOCONF | ||||||
|  |  | ||||||
| dnl configure script copyright | dnl configure script copyright | ||||||
| AC_COPYRIGHT([Copyright (c) 1998 - 2016 Daniel Stenberg, <daniel@haxx.se> | AC_COPYRIGHT([Copyright (c) 1998 - 2014 Daniel Stenberg, <daniel@haxx.se> | ||||||
| This configure script may be copied, distributed and modified under the | This configure script may be copied, distributed and modified under the | ||||||
| terms of the curl license; see COPYING for more details]) | terms of the curl license; see COPYING for more details]) | ||||||
|  |  | ||||||
| @@ -39,7 +39,6 @@ AC_CONFIG_SRCDIR([lib/urldata.h]) | |||||||
| AC_CONFIG_HEADERS(lib/curl_config.h include/curl/curlbuild.h) | AC_CONFIG_HEADERS(lib/curl_config.h include/curl/curlbuild.h) | ||||||
| AC_CONFIG_MACRO_DIR([m4]) | AC_CONFIG_MACRO_DIR([m4]) | ||||||
| AM_MAINTAINER_MODE | AM_MAINTAINER_MODE | ||||||
| m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])]) |  | ||||||
|  |  | ||||||
| CURL_CHECK_OPTION_DEBUG | CURL_CHECK_OPTION_DEBUG | ||||||
| CURL_CHECK_OPTION_OPTIMIZE | CURL_CHECK_OPTION_OPTIMIZE | ||||||
| @@ -48,7 +47,6 @@ CURL_CHECK_OPTION_WERROR | |||||||
| CURL_CHECK_OPTION_CURLDEBUG | CURL_CHECK_OPTION_CURLDEBUG | ||||||
| CURL_CHECK_OPTION_SYMBOL_HIDING | CURL_CHECK_OPTION_SYMBOL_HIDING | ||||||
| CURL_CHECK_OPTION_ARES | CURL_CHECK_OPTION_ARES | ||||||
| CURL_CHECK_OPTION_RT |  | ||||||
|  |  | ||||||
| XC_CHECK_PATH_SEPARATOR | XC_CHECK_PATH_SEPARATOR | ||||||
|  |  | ||||||
| @@ -149,7 +147,7 @@ AC_SUBST(PKGADD_VENDOR) | |||||||
|  |  | ||||||
| dnl | dnl | ||||||
| dnl initialize all the info variables | dnl initialize all the info variables | ||||||
|     curl_ssl_msg="no      (--with-{ssl,gnutls,nss,polarssl,mbedtls,cyassl,axtls,winssl,darwinssl} )" |     curl_ssl_msg="no      (--with-{ssl,gnutls,nss,polarssl,cyassl,axtls,winssl,darwinssl} )" | ||||||
|     curl_ssh_msg="no      (--with-libssh2)" |     curl_ssh_msg="no      (--with-libssh2)" | ||||||
|    curl_zlib_msg="no      (--with-zlib)" |    curl_zlib_msg="no      (--with-zlib)" | ||||||
|     curl_gss_msg="no      (--with-gssapi)" |     curl_gss_msg="no      (--with-gssapi)" | ||||||
| @@ -167,7 +165,6 @@ curl_verbose_msg="enabled (--disable-verbose)" | |||||||
|    curl_rtsp_msg="no      (--enable-rtsp)" |    curl_rtsp_msg="no      (--enable-rtsp)" | ||||||
|    curl_rtmp_msg="no      (--with-librtmp)" |    curl_rtmp_msg="no      (--with-librtmp)" | ||||||
|   curl_mtlnk_msg="no      (--with-libmetalink)" |   curl_mtlnk_msg="no      (--with-libmetalink)" | ||||||
|     curl_psl_msg="no      (--with-libpsl)" |  | ||||||
|  |  | ||||||
|     init_ssl_msg=${curl_ssl_msg} |     init_ssl_msg=${curl_ssl_msg} | ||||||
|  |  | ||||||
| @@ -1083,11 +1080,7 @@ AC_HELP_STRING([--disable-ipv6],[Disable IPv6 support]), | |||||||
|  |  | ||||||
|   AC_TRY_RUN([ /* is AF_INET6 available? */ |   AC_TRY_RUN([ /* is AF_INET6 available? */ | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #ifdef HAVE_WINSOCK2_H |  | ||||||
| #include <winsock2.h> |  | ||||||
| #else |  | ||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif |  | ||||||
| #include <stdlib.h> /* for exit() */ | #include <stdlib.h> /* for exit() */ | ||||||
| main() | main() | ||||||
| { | { | ||||||
| @@ -1101,8 +1094,8 @@ main() | |||||||
|   ipv6=yes, |   ipv6=yes, | ||||||
|   AC_MSG_RESULT(no) |   AC_MSG_RESULT(no) | ||||||
|   ipv6=no, |   ipv6=no, | ||||||
|   AC_MSG_RESULT(yes) |   AC_MSG_RESULT(no) | ||||||
|   ipv6=yes |   ipv6=no | ||||||
| )) | )) | ||||||
|  |  | ||||||
| if test "$ipv6" = "yes"; then | if test "$ipv6" = "yes"; then | ||||||
| @@ -1114,12 +1107,7 @@ if test "$ipv6" = yes; then | |||||||
|   AC_MSG_CHECKING([if struct sockaddr_in6 has sin6_scope_id member]) |   AC_MSG_CHECKING([if struct sockaddr_in6 has sin6_scope_id member]) | ||||||
|   AC_TRY_COMPILE([ |   AC_TRY_COMPILE([ | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #ifdef HAVE_WINSOCK2_H | #include <netinet/in.h>] , | ||||||
| #include <winsock2.h> |  | ||||||
| #include <ws2tcpip.h> |  | ||||||
| #else |  | ||||||
| #include <netinet/in.h> |  | ||||||
| #endif] , |  | ||||||
|   struct sockaddr_in6 s; s.sin6_scope_id = 0; , have_sin6_scope_id=yes) |   struct sockaddr_in6 s; s.sin6_scope_id = 0; , have_sin6_scope_id=yes) | ||||||
|   if test "$have_sin6_scope_id" = yes; then |   if test "$have_sin6_scope_id" = yes; then | ||||||
|     AC_MSG_RESULT([yes]) |     AC_MSG_RESULT([yes]) | ||||||
| @@ -1408,24 +1396,6 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then | |||||||
|   CLEANCPPFLAGS="$CPPFLAGS" |   CLEANCPPFLAGS="$CPPFLAGS" | ||||||
|   CLEANLIBS="$LIBS" |   CLEANLIBS="$LIBS" | ||||||
|  |  | ||||||
|   dnl This is for Msys/Mingw |  | ||||||
|   case $host in |  | ||||||
|     *-*-msys* | *-*-mingw*) |  | ||||||
|       AC_MSG_CHECKING([for gdi32]) |  | ||||||
|       my_ac_save_LIBS=$LIBS |  | ||||||
|       LIBS="-lgdi32 $LIBS" |  | ||||||
|       AC_TRY_LINK([#include <windef.h> |  | ||||||
|                    #include <wingdi.h>], |  | ||||||
|                    [GdiFlush();], |  | ||||||
|                    [ dnl worked! |  | ||||||
|                    AC_MSG_RESULT([yes])], |  | ||||||
|                    [ dnl failed, restore LIBS |  | ||||||
|                    LIBS=$my_ac_save_LIBS |  | ||||||
|                    AC_MSG_RESULT(no)] |  | ||||||
|                   ) |  | ||||||
|       ;; |  | ||||||
|   esac |  | ||||||
|  |  | ||||||
|   case "$OPT_SSL" in |   case "$OPT_SSL" in | ||||||
|   yes) |   yes) | ||||||
|     dnl --with-ssl (without path) used |     dnl --with-ssl (without path) used | ||||||
| @@ -1504,13 +1474,31 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then | |||||||
|   CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS" |   CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS" | ||||||
|   LDFLAGS="$LDFLAGS $SSL_LDFLAGS" |   LDFLAGS="$LDFLAGS $SSL_LDFLAGS" | ||||||
|  |  | ||||||
|   AC_CHECK_LIB(crypto, HMAC_Update,[ |   dnl This is for Msys/Mingw | ||||||
|  |   case $host in | ||||||
|  |     *-*-msys* | *-*-mingw*) | ||||||
|  |       AC_MSG_CHECKING([for gdi32]) | ||||||
|  |       my_ac_save_LIBS=$LIBS | ||||||
|  |       LIBS="-lgdi32 $LIBS" | ||||||
|  |       AC_TRY_LINK([#include <windef.h> | ||||||
|  |                    #include <wingdi.h>], | ||||||
|  |                    [GdiFlush();], | ||||||
|  |                    [ dnl worked! | ||||||
|  |                    AC_MSG_RESULT([yes])], | ||||||
|  |                    [ dnl failed, restore LIBS | ||||||
|  |                    LIBS=$my_ac_save_LIBS | ||||||
|  |                    AC_MSG_RESULT(no)] | ||||||
|  |                   ) | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  |  | ||||||
|  |   AC_CHECK_LIB(crypto, CRYPTO_lock,[ | ||||||
|      HAVECRYPTO="yes" |      HAVECRYPTO="yes" | ||||||
|      LIBS="-lcrypto $LIBS" |      LIBS="-lcrypto $LIBS" | ||||||
|      ],[ |      ],[ | ||||||
|      LDFLAGS="$CLEANLDFLAGS -L$LIB_OPENSSL" |      LDFLAGS="$CLEANLDFLAGS -L$LIB_OPENSSL" | ||||||
|      CPPFLAGS="$CLEANCPPFLAGS -I$PREFIX_OPENSSL/include/openssl -I$PREFIX_OPENSSL/include" |      CPPFLAGS="$CLEANCPPFLAGS -I$PREFIX_OPENSSL/include/openssl -I$PREFIX_OPENSSL/include" | ||||||
|      AC_CHECK_LIB(crypto, HMAC_Init_ex,[ |      AC_CHECK_LIB(crypto, CRYPTO_add_lock,[ | ||||||
|        HAVECRYPTO="yes" |        HAVECRYPTO="yes" | ||||||
|        LIBS="-lcrypto $LIBS"], [ |        LIBS="-lcrypto $LIBS"], [ | ||||||
|        LDFLAGS="$CLEANLDFLAGS" |        LDFLAGS="$CLEANLDFLAGS" | ||||||
| @@ -1520,46 +1508,6 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then | |||||||
|     ]) |     ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|   if test X"$HAVECRYPTO" = X"yes"; then |  | ||||||
|      AC_MSG_CHECKING([OpenSSL linking without -ldl]) |  | ||||||
|      saved_libs=$LIBS |  | ||||||
|      AC_TRY_LINK( |  | ||||||
|         [ |  | ||||||
|           #include <openssl/evp.h> |  | ||||||
|         ], |  | ||||||
|         [ |  | ||||||
|           SSLeay_add_all_algorithms(); |  | ||||||
|         ], |  | ||||||
|         [ |  | ||||||
|           AC_MSG_RESULT(yes) |  | ||||||
|           LIBS="$saved_libs" |  | ||||||
|         ], |  | ||||||
|         [ |  | ||||||
|           AC_MSG_RESULT(no) |  | ||||||
|           AC_MSG_CHECKING([OpenSSL linking with -ldl]) |  | ||||||
|           LIBS="-ldl $LIBS" |  | ||||||
|           AC_TRY_LINK( |  | ||||||
|           [ |  | ||||||
|             #include <openssl/evp.h> |  | ||||||
|           ], |  | ||||||
|           [ |  | ||||||
|             SSLeay_add_all_algorithms(); |  | ||||||
|           ], |  | ||||||
|           [ |  | ||||||
|             AC_MSG_RESULT(yes) |  | ||||||
|             LIBS="$saved_libs -ldl" |  | ||||||
|           ], |  | ||||||
|           [ |  | ||||||
|             AC_MSG_RESULT(no) |  | ||||||
|             LIBS="$saved_libs" |  | ||||||
|           ] |  | ||||||
|           ) |  | ||||||
|  |  | ||||||
|         ] |  | ||||||
|      ) |  | ||||||
|  |  | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   if test X"$HAVECRYPTO" = X"yes"; then |   if test X"$HAVECRYPTO" = X"yes"; then | ||||||
|     dnl This is only reasonable to do if crypto actually is there: check for |     dnl This is only reasonable to do if crypto actually is there: check for | ||||||
|     dnl SSL libs NOTE: it is important to do this AFTER the crypto lib |     dnl SSL libs NOTE: it is important to do this AFTER the crypto lib | ||||||
| @@ -1631,8 +1579,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then | |||||||
|     dnl Older versions of Cyassl (some time before 2.9.4) don't have |     dnl Older versions of Cyassl (some time before 2.9.4) don't have | ||||||
|     dnl SSL_get_shutdown (but this check won't actually detect it there |     dnl SSL_get_shutdown (but this check won't actually detect it there | ||||||
|     dnl as it's a macro that needs the header files be included) |     dnl as it's a macro that needs the header files be included) | ||||||
|     dnl BoringSSL didn't have DES_set_odd_parity for a while but now it is |     dnl BoringSSL doesn't have DES_set_odd_parity | ||||||
|     dnl back again. |  | ||||||
|  |  | ||||||
|     AC_CHECK_FUNCS( RAND_status \ |     AC_CHECK_FUNCS( RAND_status \ | ||||||
|                     RAND_screen \ |                     RAND_screen \ | ||||||
| @@ -1644,22 +1591,14 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then | |||||||
|                     DES_set_odd_parity ) |                     DES_set_odd_parity ) | ||||||
|  |  | ||||||
|     AC_MSG_CHECKING([for BoringSSL]) |     AC_MSG_CHECKING([for BoringSSL]) | ||||||
|     AC_COMPILE_IFELSE([ |     if test "x$ac_cv_func_DES_set_odd_parity" != "xyes"; then | ||||||
|         AC_LANG_PROGRAM([[ |       curl_ssl_msg="enabled (BoringSSL)" | ||||||
|                 #include <openssl/base.h> |       AC_DEFINE_UNQUOTED(HAVE_BORINGSSL, 1, | ||||||
|                 ]],[[ |         [Define to 1 if using BoringSSL.]) | ||||||
|                 #ifndef OPENSSL_IS_BORINGSSL |       AC_MSG_RESULT([yes]) | ||||||
|                 #error not boringssl |     else | ||||||
|                 #endif |       AC_MSG_RESULT([no]) | ||||||
|        ]]) |     fi | ||||||
|     ],[ |  | ||||||
|         AC_MSG_RESULT([yes]) |  | ||||||
|         AC_DEFINE_UNQUOTED(HAVE_BORINGSSL, 1, |  | ||||||
|                            [Define to 1 if using BoringSSL.]) |  | ||||||
|     ],[ |  | ||||||
|         AC_MSG_RESULT([no]) |  | ||||||
|     ]) |  | ||||||
|  |  | ||||||
|     AC_MSG_CHECKING([for libressl]) |     AC_MSG_CHECKING([for libressl]) | ||||||
|     AC_COMPILE_IFELSE([ |     AC_COMPILE_IFELSE([ | ||||||
|       AC_LANG_PROGRAM([[ |       AC_LANG_PROGRAM([[ | ||||||
| @@ -1847,7 +1786,6 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then | |||||||
|             AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH]) |             AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH]) | ||||||
|           fi |           fi | ||||||
|         fi |         fi | ||||||
|         AC_CHECK_FUNCS(gnutls_certificate_set_x509_key_file2) |  | ||||||
|       fi |       fi | ||||||
|  |  | ||||||
|     fi |     fi | ||||||
| @@ -1985,93 +1923,6 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then | |||||||
|  |  | ||||||
| fi | fi | ||||||
|  |  | ||||||
| dnl ---------------------------------------------------- |  | ||||||
| dnl check for mbedTLS |  | ||||||
| dnl ---------------------------------------------------- |  | ||||||
|  |  | ||||||
| OPT_MBEDTLS=no |  | ||||||
|  |  | ||||||
| _cppflags=$CPPFLAGS |  | ||||||
| _ldflags=$LDFLAGS |  | ||||||
| AC_ARG_WITH(mbedtls,dnl |  | ||||||
| AC_HELP_STRING([--with-mbedtls=PATH],[where to look for mbedTLS, PATH points to the installation root]) |  | ||||||
| AC_HELP_STRING([--without-mbedtls], [disable mbedTLS detection]), |  | ||||||
|   OPT_MBEDTLS=$withval) |  | ||||||
|  |  | ||||||
| if test "$curl_ssl_msg" = "$init_ssl_msg"; then |  | ||||||
|  |  | ||||||
|   if test X"$OPT_MBEDTLS" != Xno; then |  | ||||||
|  |  | ||||||
|     if test "$OPT_MBEDTLS" = "yes"; then |  | ||||||
|       OPT_MBEDTLS="" |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|     if test -z "$OPT_MBEDTLS" ; then |  | ||||||
|       dnl check for lib first without setting any new path |  | ||||||
|  |  | ||||||
|       AC_CHECK_LIB(mbedtls, mbedtls_havege_init, |  | ||||||
|       dnl libmbedtls found, set the variable |  | ||||||
|        [ |  | ||||||
|          AC_DEFINE(USE_MBEDTLS, 1, [if mbedTLS is enabled]) |  | ||||||
|          AC_SUBST(USE_MBEDTLS, [1]) |  | ||||||
|          MBEDTLS_ENABLED=1 |  | ||||||
|          USE_MBEDTLS="yes" |  | ||||||
|          curl_ssl_msg="enabled (mbedTLS)" |  | ||||||
|         ], [], -lmbedx509 -lmbedcrypto) |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|     addld="" |  | ||||||
|     addlib="" |  | ||||||
|     addcflags="" |  | ||||||
|     mbedtlslib="" |  | ||||||
|  |  | ||||||
|     if test "x$USE_MBEDTLS" != "xyes"; then |  | ||||||
|       dnl add the path and test again |  | ||||||
|       addld=-L$OPT_MBEDTLS/lib$libsuff |  | ||||||
|       addcflags=-I$OPT_MBEDTLS/include |  | ||||||
|       mbedtlslib=$OPT_MBEDTLS/lib$libsuff |  | ||||||
|  |  | ||||||
|       LDFLAGS="$LDFLAGS $addld" |  | ||||||
|       if test "$addcflags" != "-I/usr/include"; then |  | ||||||
|          CPPFLAGS="$CPPFLAGS $addcflags" |  | ||||||
|       fi |  | ||||||
|  |  | ||||||
|       AC_CHECK_LIB(mbedtls, mbedtls_ssl_init, |  | ||||||
|        [ |  | ||||||
|        AC_DEFINE(USE_MBEDTLS, 1, [if mbedTLS is enabled]) |  | ||||||
|        AC_SUBST(USE_MBEDTLS, [1]) |  | ||||||
|        MBEDTLS_ENABLED=1 |  | ||||||
|        USE_MBEDTLS="yes" |  | ||||||
|        curl_ssl_msg="enabled (mbedTLS)" |  | ||||||
|        ], |  | ||||||
|        [ |  | ||||||
|          CPPFLAGS=$_cppflags |  | ||||||
|          LDFLAGS=$_ldflags |  | ||||||
|        ], -lmbedx509 -lmbedcrypto) |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|     if test "x$USE_MBEDTLS" = "xyes"; then |  | ||||||
|       AC_MSG_NOTICE([detected mbedTLS]) |  | ||||||
|  |  | ||||||
|       LIBS="-lmbedtls -lmbedx509 -lmbedcrypto $LIBS" |  | ||||||
|  |  | ||||||
|       if test -n "$mbedtlslib"; then |  | ||||||
|         dnl when shared libs were found in a path that the run-time |  | ||||||
|         dnl linker doesn't search through, we need to add it to |  | ||||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail |  | ||||||
|         dnl due to this |  | ||||||
|         if test "x$cross_compiling" != "xyes"; then |  | ||||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$mbedtlslib" |  | ||||||
|           export LD_LIBRARY_PATH |  | ||||||
|           AC_MSG_NOTICE([Added $mbedtlslib to LD_LIBRARY_PATH]) |  | ||||||
|         fi |  | ||||||
|       fi |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|   fi dnl mbedTLS not disabled |  | ||||||
|  |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl ---------------------------------------------------- | dnl ---------------------------------------------------- | ||||||
| dnl check for CyaSSL | dnl check for CyaSSL | ||||||
| dnl ---------------------------------------------------- | dnl ---------------------------------------------------- | ||||||
| @@ -2175,11 +2026,11 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then | |||||||
| 	]]) | 	]]) | ||||||
|       ],[ |       ],[ | ||||||
|          AC_MSG_RESULT(yes) |          AC_MSG_RESULT(yes) | ||||||
|          AC_DEFINE(USE_CYASSL, 1, [if CyaSSL/WolfSSL is enabled]) |          AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) | ||||||
|          AC_SUBST(USE_CYASSL, [1]) |          AC_SUBST(USE_CYASSL, [1]) | ||||||
|          CYASSL_ENABLED=1 |          CYASSL_ENABLED=1 | ||||||
|          USE_CYASSL="yes" |          USE_CYASSL="yes" | ||||||
|          curl_ssl_msg="enabled (WolfSSL)" |          curl_ssl_msg="enabled (CyaSSL)" | ||||||
|        ], |        ], | ||||||
|        [ |        [ | ||||||
|          AC_MSG_RESULT(no) |          AC_MSG_RESULT(no) | ||||||
| @@ -2191,7 +2042,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then | |||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if test "x$USE_CYASSL" = "xyes"; then |     if test "x$USE_CYASSL" = "xyes"; then | ||||||
|       AC_MSG_NOTICE([detected $cyassllibname]) |       AC_MSG_NOTICE([detected CyaSSL]) | ||||||
|  |  | ||||||
|       dnl cyassl/ctaocrypt/types.h needs SIZEOF_LONG_LONG defined! |       dnl cyassl/ctaocrypt/types.h needs SIZEOF_LONG_LONG defined! | ||||||
|       AC_CHECK_SIZEOF(long long) |       AC_CHECK_SIZEOF(long long) | ||||||
| @@ -2204,16 +2055,6 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then | |||||||
|  |  | ||||||
|       LIBS="-l$cyassllibname -lm $LIBS" |       LIBS="-l$cyassllibname -lm $LIBS" | ||||||
|  |  | ||||||
|       if test "x$cyassllibname" = "xwolfssl"; then |  | ||||||
|         dnl Recent WolfSSL versions build without SSLv3 by default |  | ||||||
|         dnl WolfSSL needs configure --enable-opensslextra to have *get_peer* |  | ||||||
|         AC_CHECK_FUNCS(wolfSSLv3_client_method \ |  | ||||||
|                        wolfSSL_get_peer_certificate) |  | ||||||
|       else |  | ||||||
|         dnl Cyassl needs configure --enable-opensslextra to have *get_peer* |  | ||||||
|         AC_CHECK_FUNCS(CyaSSL_get_peer_certificate) |  | ||||||
|       fi |  | ||||||
|  |  | ||||||
|       if test -n "$cyassllib"; then |       if test -n "$cyassllib"; then | ||||||
|         dnl when shared libs were found in a path that the run-time |         dnl when shared libs were found in a path that the run-time | ||||||
|         dnl linker doesn't search through, we need to add it to |         dnl linker doesn't search through, we need to add it to | ||||||
| @@ -2406,7 +2247,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then | |||||||
|   fi |   fi | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if test "x$OPENSSL_ENABLED$GNUTLS_ENABLED$NSS_ENABLED$POLARSSL_ENABLED$MBEDTLS_ENABLED$AXTLS_ENABLED$CYASSL_ENABLED$WINSSL_ENABLED$DARWINSSL_ENABLED" = "x"; then | if test "x$OPENSSL_ENABLED$GNUTLS_ENABLED$NSS_ENABLED$POLARSSL_ENABLED$AXTLS_ENABLED$CYASSL_ENABLED$WINSSL_ENABLED$DARWINSSL_ENABLED" = "x"; then | ||||||
|   AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.]) |   AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.]) | ||||||
|   AC_MSG_WARN([Use --with-ssl, --with-gnutls, --with-polarssl, --with-cyassl, --with-nss, --with-axtls, --with-winssl, or --with-darwinssl to address this.]) |   AC_MSG_WARN([Use --with-ssl, --with-gnutls, --with-polarssl, --with-cyassl, --with-nss, --with-axtls, --with-winssl, or --with-darwinssl to address this.]) | ||||||
| else | else | ||||||
| @@ -2421,27 +2262,6 @@ dnl ********************************************************************** | |||||||
|  |  | ||||||
| CURL_CHECK_CA_BUNDLE | CURL_CHECK_CA_BUNDLE | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for libpsl |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| AC_ARG_WITH(libpsl, |  | ||||||
|            AS_HELP_STRING([--without-libpsl], |  | ||||||
|            [disable support for libpsl cookie checking]), |  | ||||||
|            with_libpsl=$withval, |  | ||||||
|            with_libpsl=yes) |  | ||||||
| if test $with_libpsl != "no"; then |  | ||||||
|   AC_SEARCH_LIBS(psl_builtin, psl, |  | ||||||
|     [curl_psl_msg="yes"; |  | ||||||
|      AC_DEFINE([USE_LIBPSL], [1], [PSL support enabled]) |  | ||||||
|      ], |  | ||||||
|     [curl_psl_msg="no      (libpsl not found)"; |  | ||||||
|      AC_MSG_WARN([libpsl was not found]) |  | ||||||
|      ] |  | ||||||
|   ) |  | ||||||
| fi |  | ||||||
| AM_CONDITIONAL([USE_LIBPSL], [test "$curl_psl_msg" = "yes"]) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Check for libmetalink | dnl Check for libmetalink | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -3049,31 +2869,6 @@ if test X"$want_h2" != Xno; then | |||||||
|  |  | ||||||
| fi | fi | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for zsh completion path |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| OPT_ZSH_FPATH=default |  | ||||||
| AC_ARG_WITH(zsh-functions-dir, |  | ||||||
| AC_HELP_STRING([--with-zsh-functions-dir=PATH],[Install zsh completions to PATH]) |  | ||||||
| AC_HELP_STRING([--without-zsh-functions-dir],[Do not install zsh completions]), |  | ||||||
|   [OPT_ZSH_FPATH=$withval]) |  | ||||||
| case "$OPT_ZSH_FPATH" in |  | ||||||
|   no) |  | ||||||
|     dnl --without-zsh-functions-dir option used |  | ||||||
|     ;; |  | ||||||
|   default|yes) |  | ||||||
|     dnl --with-zsh-functions-dir option used without path |  | ||||||
|     ZSH_FUNCTIONS_DIR="$datarootdir/zsh/site-functions" |  | ||||||
|     AC_SUBST(ZSH_FUNCTIONS_DIR) |  | ||||||
|     ;; |  | ||||||
|   *) |  | ||||||
|     dnl --with-zsh-functions-dir option used with path |  | ||||||
|     ZSH_FUNCTIONS_DIR="$withval" |  | ||||||
|     AC_SUBST(ZSH_FUNCTIONS_DIR) |  | ||||||
|     ;; |  | ||||||
| esac |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Back to "normal" configuring | dnl Back to "normal" configuring | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -3422,7 +3217,7 @@ if test "x$want_thres" = xyes && test "x$want_ares" = xyes; then | |||||||
| [Options --enable-threaded-resolver and --enable-ares are mutually exclusive]) | [Options --enable-threaded-resolver and --enable-ares are mutually exclusive]) | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if test "$want_thres" = "yes" && test "$dontwant_rt" = "no"; then | if test "$want_thres" = "yes"; then | ||||||
|   AC_CHECK_HEADER(pthread.h, |   AC_CHECK_HEADER(pthread.h, | ||||||
|     [ AC_DEFINE(HAVE_PTHREAD_H, 1, [if you have <pthread.h>]) |     [ AC_DEFINE(HAVE_PTHREAD_H, 1, [if you have <pthread.h>]) | ||||||
|       save_CFLAGS="$CFLAGS" |       save_CFLAGS="$CFLAGS" | ||||||
| @@ -3690,10 +3485,6 @@ if test "x$HAVE_GSSAPI" = "x1"; then | |||||||
|   SUPPORT_FEATURES="$SUPPORT_FEATURES GSS-API" |   SUPPORT_FEATURES="$SUPPORT_FEATURES GSS-API" | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if test "x$curl_psl_msg" = "xyes"; then |  | ||||||
|   SUPPORT_FEATURES="$SUPPORT_FEATURES PSL" |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| if test "x$CURL_DISABLE_CRYPTO_AUTH" != "x1" -a \ | if test "x$CURL_DISABLE_CRYPTO_AUTH" != "x1" -a \ | ||||||
|     \( "x$HAVE_GSSAPI" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \); then |     \( "x$HAVE_GSSAPI" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \); then | ||||||
|   SUPPORT_FEATURES="$SUPPORT_FEATURES SPNEGO" |   SUPPORT_FEATURES="$SUPPORT_FEATURES SPNEGO" | ||||||
| @@ -3841,7 +3632,6 @@ AC_CONFIG_FILES([Makefile \ | |||||||
|            include/curl/Makefile \ |            include/curl/Makefile \ | ||||||
|            src/Makefile \ |            src/Makefile \ | ||||||
|            lib/Makefile \ |            lib/Makefile \ | ||||||
|            scripts/Makefile \ |  | ||||||
|            lib/libcurl.vers \ |            lib/libcurl.vers \ | ||||||
|            tests/Makefile \ |            tests/Makefile \ | ||||||
|            tests/certs/Makefile \ |            tests/certs/Makefile \ | ||||||
| @@ -3900,7 +3690,6 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | |||||||
|   RTSP support:     ${curl_rtsp_msg} |   RTSP support:     ${curl_rtsp_msg} | ||||||
|   RTMP support:     ${curl_rtmp_msg} |   RTMP support:     ${curl_rtmp_msg} | ||||||
|   metalink support: ${curl_mtlnk_msg} |   metalink support: ${curl_mtlnk_msg} | ||||||
|   PSL support:      ${curl_psl_msg} |  | ||||||
|   HTTP2 support:    ${curl_h2_msg} |   HTTP2 support:    ${curl_h2_msg} | ||||||
|   Protocols:        ${SUPPORT_PROTOCOLS} |   Protocols:        ${SUPPORT_PROTOCOLS} | ||||||
| ]) | ]) | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ Basic | |||||||
|  |  | ||||||
| C | C | ||||||
|   libcurl is a C library in itself! |   libcurl is a C library in itself! | ||||||
|   https://curl.haxx.se/libcurl/ |   http://curl.haxx.se/libcurl/ | ||||||
|  |  | ||||||
| C++ | C++ | ||||||
|  |  | ||||||
| @@ -184,7 +184,7 @@ Rexx | |||||||
| RPG | RPG | ||||||
|  |  | ||||||
|   Support for ILE/RPG on OS/400 is included in source distribution |   Support for ILE/RPG on OS/400 is included in source distribution | ||||||
|   https://curl.haxx.se/libcurl/ |   http://curl.haxx.se/libcurl/ | ||||||
|   See packages/OS400/README.OS400 and packages/OS400/curl.inc.in |   See packages/OS400/README.OS400 and packages/OS400/curl.inc.in | ||||||
|  |  | ||||||
| Ruby | Ruby | ||||||
|   | |||||||
| @@ -35,12 +35,12 @@ BUGS | |||||||
|   have a go at a solution. You can optionally also post your bug/problem at |   have a go at a solution. You can optionally also post your bug/problem at | ||||||
|   curl's bug tracking system over at |   curl's bug tracking system over at | ||||||
|  |  | ||||||
|         https://github.com/curl/curl/issues |         https://github.com/bagder/curl/issues | ||||||
|  |  | ||||||
|   Please read the rest of this document below first before doing that! |   Please read the rest of this document below first before doing that! | ||||||
|  |  | ||||||
|   If you feel you need to ask around first, find a suitable mailing list and |   If you feel you need to ask around first, find a suitable mailing list and | ||||||
|   post there. The lists are available on https://curl.haxx.se/mail/ |   post there. The lists are available on http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
| 1.3 What to report | 1.3 What to report | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,32 +0,0 @@ | |||||||
| Contributor Code of Conduct |  | ||||||
| =========================== |  | ||||||
|  |  | ||||||
| As contributors and maintainers of this project, we pledge to respect all |  | ||||||
| people who contribute through reporting issues, posting feature requests, |  | ||||||
| updating documentation, submitting pull requests or patches, and other |  | ||||||
| activities. |  | ||||||
|  |  | ||||||
| We are committed to making participation in this project a harassment-free |  | ||||||
| experience for everyone, regardless of level of experience, gender, gender |  | ||||||
| identity and expression, sexual orientation, disability, personal appearance, |  | ||||||
| body size, race, ethnicity, age, or religion. |  | ||||||
|  |  | ||||||
| Examples of unacceptable behavior by participants include the use of sexual |  | ||||||
| language or imagery, derogatory comments or personal attacks, trolling, public |  | ||||||
| or private harassment, insults, or other unprofessional conduct. |  | ||||||
|  |  | ||||||
| Project maintainers have the right and responsibility to remove, edit, or |  | ||||||
| reject comments, commits, code, wiki edits, issues, and other contributions |  | ||||||
| that are not aligned to this Code of Conduct. Project maintainers who do not |  | ||||||
| follow the Code of Conduct may be removed from the project team. |  | ||||||
|  |  | ||||||
| This code of conduct applies both within project spaces and in public spaces |  | ||||||
| when an individual is representing the project or its community. |  | ||||||
|  |  | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be |  | ||||||
| reported by opening an issue or contacting one or more of the project |  | ||||||
| maintainers. |  | ||||||
|  |  | ||||||
| This Code of Conduct is adapted from the [Contributor |  | ||||||
| Covenant](http://contributor-covenant.org), version 1.1.0, available at |  | ||||||
| [http://contributor-covenant.org/version/1/1/0/](http://contributor-covenant.org/version/1/1/0/) |  | ||||||
| @@ -42,13 +42,13 @@ | |||||||
|  |  | ||||||
| 1.1 Join the Community | 1.1 Join the Community | ||||||
|  |  | ||||||
|  Skip over to https://curl.haxx.se/mail/ and join the appropriate mailing |  Skip over to http://curl.haxx.se/mail/ and join the appropriate mailing | ||||||
|  list(s).  Read up on details before you post questions. Read this file before |  list(s).  Read up on details before you post questions. Read this file before | ||||||
|  you start sending patches! We prefer patches and discussions being held on |  you start sending patches! We prefer patches and discussions being held on | ||||||
|  the mailing list(s), not sent to individuals. |  the mailing list(s), not sent to individuals. | ||||||
|  |  | ||||||
|  Before posting to one of the curl mailing lists, please read up on the mailing |  Before posting to one of the curl mailing lists, please read up on the mailing | ||||||
|  list etiquette: https://curl.haxx.se/mail/etiquette.html |  list etiquette: http://curl.haxx.se/mail/etiquette.html | ||||||
|  |  | ||||||
|  We also hang out on IRC in #curl on irc.freenode.net |  We also hang out on IRC in #curl on irc.freenode.net | ||||||
|  |  | ||||||
| @@ -203,7 +203,7 @@ | |||||||
|  |  | ||||||
|  You need to first checkout the repository: |  You need to first checkout the repository: | ||||||
|  |  | ||||||
|      git clone https://github.com/curl/curl.git |      git clone https://github.com/bagder/curl.git | ||||||
|  |  | ||||||
|  You then proceed and edit all the files you like and you commit them to your |  You then proceed and edit all the files you like and you commit them to your | ||||||
|  local repository: |  local repository: | ||||||
|   | |||||||
							
								
								
									
										176
									
								
								docs/DISTRO-DILEMMA
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								docs/DISTRO-DILEMMA
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,176 @@ | |||||||
|  |   Date: February 11, 2007 | ||||||
|  |   Author: Daniel Stenberg <daniel@haxx.se> | ||||||
|  |   URL: http://curl.haxx.se/legal/distro-dilemma.html | ||||||
|  |  | ||||||
|  | Condition | ||||||
|  |  | ||||||
|  |  This document is written to describe the situation as it is right now. | ||||||
|  |  libcurl 7.16.1 is currently the latest version available. Things may of | ||||||
|  |  course change in the future. | ||||||
|  |  | ||||||
|  |  This document reflects my view and understanding of these things. Please tell | ||||||
|  |  me where and how you think I'm wrong, and I'll try to correct my mistakes. | ||||||
|  |  | ||||||
|  | Background | ||||||
|  |  | ||||||
|  |  The Free Software Foundation has deemed the Original BSD license[1] to be | ||||||
|  |  "incompatible"[2] with GPL[3]. I'd rather say it is the other way around, but | ||||||
|  |  the point is the same: if you distribute a binary version of a GPL program, | ||||||
|  |  it MUST NOT be linked with any Original BSD-licensed parts or libraries. | ||||||
|  |  Doing so will violate the GPL license. For a long time, very many GPL | ||||||
|  |  licensed programs have avoided this license mess by adding an exception[8] to | ||||||
|  |  their license. And many others have just closed their eyes for this problem. | ||||||
|  |  | ||||||
|  |  libcurl is MIT-style[4] licensed - how on earth did this dilemma fall onto | ||||||
|  |  our plates? | ||||||
|  |  | ||||||
|  |  libcurl is only a little library. libcurl can be built to use OpenSSL for its | ||||||
|  |  SSL/TLS capabilities. OpenSSL is basically Original BSD licensed[5]. | ||||||
|  |  | ||||||
|  |  If libcurl built to use OpenSSL is used by a GPL-licensed application and you | ||||||
|  |  decide to distribute a binary version of it (Linux distros - for example - | ||||||
|  |  tend to), you have a clash. GPL vs Original BSD. | ||||||
|  |  | ||||||
|  |  This dilemma is not libcurl-specific nor is it specific to any particular | ||||||
|  |  Linux distro. (This article mentions and refers to Debian several times, but | ||||||
|  |  only because Debian seems to be the only Linux distro to have faced this | ||||||
|  |  issue yet since no other distro is shipping libcurl built with two SSL | ||||||
|  |  libraries.) | ||||||
|  |  | ||||||
|  | Part of the Operating System | ||||||
|  |  | ||||||
|  |  This would not be a problem if the used lib would be considered part of the | ||||||
|  |  underlying operating system, as then the GPL license has an exception | ||||||
|  |  clause[6] that allows applications to use such libs without having to be | ||||||
|  |  allowed to distribute it or its sources. Possibly some distros will claim | ||||||
|  |  that OpenSSL is part of their operating system. | ||||||
|  |  | ||||||
|  |  Debian does however not take this stance and has officially(?) claimed that | ||||||
|  |  OpenSSL is not a required part of the Debian operating system | ||||||
|  |  | ||||||
|  |  Some people claim that this paragraph cannot be exploited this way by a Linux | ||||||
|  |  distro, but I am not a lawyer and that is a discussion left outside of this | ||||||
|  |  document. | ||||||
|  |  | ||||||
|  | GnuTLS | ||||||
|  |  | ||||||
|  |  Since May 2005 libcurl can get built to use GnuTLS instead of OpenSSL. GnuTLS | ||||||
|  |  is an LGPL[7] licensed library that offers a matching set of features as | ||||||
|  |  OpenSSL does. Now, you can build and distribute an TLS/SSL capable libcurl | ||||||
|  |  without including any Original BSD licensed code. | ||||||
|  |  | ||||||
|  |  I believe Debian is the first (only?) distro that provides libcurl/GnuTLS | ||||||
|  |  packages. | ||||||
|  |  | ||||||
|  | yassl | ||||||
|  |  | ||||||
|  |  libcurl can get also get built to use yassl for the TLS/SSL layer. yassl is a | ||||||
|  |  GPL[3] licensed library. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | GnuTLS vs OpenSSL vs yassl | ||||||
|  |  | ||||||
|  |  While these three libraries offer similar features, they are not equal. | ||||||
|  |  libcurl does not (yet) offer a standardized stable ABI if you decide to | ||||||
|  |  switch from using libcurl-openssl to libcurl-gnutls or vice-versa. The GnuTLS | ||||||
|  |  and yassl support is very recent in libcurl and it has not been tested nor | ||||||
|  |  used very extensively, while the OpenSSL equivalent code has been used and | ||||||
|  |  thus matured since 1999. | ||||||
|  |  | ||||||
|  |  GnuTLS | ||||||
|  |    - LGPL licensed | ||||||
|  |    - supports SRP | ||||||
|  |    - lacks SSLv2 support | ||||||
|  |    - lacks MD2 support (used by at least some CA certs) | ||||||
|  |    - lacks the crypto functions libcurl uses for NTLM | ||||||
|  |  | ||||||
|  |  OpenSSL | ||||||
|  |    - Original BSD licensed | ||||||
|  |    - lacks SRP | ||||||
|  |    - supports SSLv2 | ||||||
|  |    - older and more widely used | ||||||
|  |    - provides crypto functions libcurl uses for NTLM | ||||||
|  |    - libcurl can do non-blocking connects with it in 7.15.4 and later | ||||||
|  |  | ||||||
|  |  yassl | ||||||
|  |    - GPL licensed | ||||||
|  |    - much untested and unproven in the real work by (lib)curl users so we don't | ||||||
|  |      know a lot about restrictions or benefits from using this | ||||||
|  |  | ||||||
|  | The Better License, Original BSD, GPL or LGPL? | ||||||
|  |  | ||||||
|  |  It isn't obvious or without debate to any objective interested party that | ||||||
|  |  either of these licenses are the "better" or even the "preferred" one in a | ||||||
|  |  generic situation. | ||||||
|  |  | ||||||
|  |  Instead, I think we should accept the fact that the SSL/TLS libraries and | ||||||
|  |  their different licenses will fit different applications and their authors | ||||||
|  |  differently depending on the applications' licenses and their general usage | ||||||
|  |  pattern (considering how GPL and LGPL libraries for example can be burdensome | ||||||
|  |  for embedded systems usage). | ||||||
|  |  | ||||||
|  |  In Debian land, there seems to be a common opinion that LGPL is "maximally | ||||||
|  |  compatible" with apps while Original BSD is not. Like this: | ||||||
|  |  | ||||||
|  |         https://lists.debian.org/debian-devel/2005/09/msg01417.html | ||||||
|  |  | ||||||
|  | More SSL Libraries | ||||||
|  |  | ||||||
|  |  In libcurl, there's no stopping us here. There are more Open Source/Free | ||||||
|  |  SSL/TLS libraries out there and we would very much like to support them as | ||||||
|  |  well, to offer application authors an even wider scope of choice. | ||||||
|  |  | ||||||
|  | Application Angle of this Problem | ||||||
|  |  | ||||||
|  |  libcurl is built to use one SSL/TLS library. It uses a single fixed name (by | ||||||
|  |  default) on the built/created lib file, and applications are built/linked to | ||||||
|  |  use that single lib. Replacing one libcurl instance with another one that | ||||||
|  |  uses the other SSL/TLS library might break one or more applications (due to | ||||||
|  |  ABI differences and/or different feature set). You want your application to | ||||||
|  |  use the libcurl it was built for. | ||||||
|  |  | ||||||
|  | Project cURL Angle of this Problem | ||||||
|  |  | ||||||
|  |  We distribute libcurl and everyone may build libcurl with either library at | ||||||
|  |  their choice. This problem is not directly a problem of ours. It merely | ||||||
|  |  affects users - GPL application authors only - of our lib as it comes | ||||||
|  |  included and delivered on some distros. | ||||||
|  |  | ||||||
|  |  libcurl has different ABI when built with different SSL/TLS libraries due to | ||||||
|  |  these reasons: | ||||||
|  |  | ||||||
|  |  1. No one has worked on fixing this. The mutex/lock callbacks should be set | ||||||
|  |     with a generic libcurl function that should use the proper underlying | ||||||
|  |     functions. | ||||||
|  |  | ||||||
|  |  2. The CURLOPT_SSL_CTX_FUNCTION option is not possible to "emulate" on GnuTLS | ||||||
|  |     but simply requires OpenSSL. | ||||||
|  |  | ||||||
|  |  3. There might be some other subtle differences just because nobody has yet | ||||||
|  |     tried to make a fixed ABI like this. | ||||||
|  |  | ||||||
|  | Distro Angle of this Problem | ||||||
|  |  | ||||||
|  |  To my knowledge there is only one distro that ships libcurl built with either | ||||||
|  |  OpenSSL or GnuTLS. | ||||||
|  |  | ||||||
|  |  Debian Linux is now (since mid September 2005) providing two different | ||||||
|  |  libcurl packages, one for libcurl built with OpenSSL and one built with | ||||||
|  |  GnuTLS. They use different .so names and can this both be installed in a | ||||||
|  |  single system simultaneously. This has been said to be a transitional system | ||||||
|  |  not desired to keep in the long run. | ||||||
|  |  | ||||||
|  | Footnotes | ||||||
|  |  | ||||||
|  |  [1] = http://www.xfree86.org/3.3.6/COPYRIGHT2.html#6 | ||||||
|  |  [2] = https://www.gnu.org/philosophy/bsd.html | ||||||
|  |  [3] = https://www.gnu.org/licenses/gpl.html | ||||||
|  |  [4] = http://curl.haxx.se/docs/copyright.html | ||||||
|  |  [5] = https://www.openssl.org/source/license.html | ||||||
|  |  [6] = https://www.gnu.org/licenses/gpl.html end of section 3 | ||||||
|  |  [7] = https://www.gnu.org/licenses/lgpl.html | ||||||
|  |  [8] = https://en.wikipedia.org/wiki/OpenSSL_exception | ||||||
|  |  | ||||||
|  | Feedback/Updates provided by | ||||||
|  |  | ||||||
|  |  Eric Cooper | ||||||
							
								
								
									
										55
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										55
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -225,9 +225,7 @@ FAQ | |||||||
|   implement it for you, that is not a very friendly attitude. We spend a |   implement it for you, that is not a very friendly attitude. We spend a | ||||||
|   considerable time already on maintaining and developing curl. In order to |   considerable time already on maintaining and developing curl. In order to | ||||||
|   get more out of us, you should consider trading in some of your time and |   get more out of us, you should consider trading in some of your time and | ||||||
|   efforts in return. Simply go to the GitHub repo which resides at |   efforts in return. | ||||||
|   https://github.com/curl/curl, fork the project, and create pull requests |  | ||||||
|   with your proposed changes. |  | ||||||
|  |  | ||||||
|   If you write the code, chances are bigger that it will get into curl faster. |   If you write the code, chances are bigger that it will get into curl faster. | ||||||
|  |  | ||||||
| @@ -253,10 +251,9 @@ FAQ | |||||||
|  |  | ||||||
|   We still get help from companies. Haxx provides web site, bandwidth, mailing |   We still get help from companies. Haxx provides web site, bandwidth, mailing | ||||||
|   lists etc, sourceforge.net hosts project services we take advantage from, |   lists etc, sourceforge.net hosts project services we take advantage from, | ||||||
|   like the bug tracker, and GitHub hosts the primary git repository at |   like the bug tracker and github hosts the primary git repository. Also | ||||||
|   https://github.com/curl/curl. Also again, some companies have sponsored |   again, some companies have sponsored certain parts of the development in the | ||||||
|   certain parts of the development in the past and I hope some will continue to |   past and I hope some will continue to do so in the future. | ||||||
|   do so in the future. |  | ||||||
|  |  | ||||||
|   If you want to support our project, consider a donation or a banner-program |   If you want to support our project, consider a donation or a banner-program | ||||||
|   or even better: by helping us coding, documenting, testing etc. |   or even better: by helping us coding, documenting, testing etc. | ||||||
| @@ -281,7 +278,7 @@ FAQ | |||||||
|   Please do not mail any single individual unless you really need to. Keep |   Please do not mail any single individual unless you really need to. Keep | ||||||
|   curl-related questions on a suitable mailing list. All available mailing |   curl-related questions on a suitable mailing list. All available mailing | ||||||
|   lists are listed in the MANUAL document and online at |   lists are listed in the MANUAL document and online at | ||||||
|   https://curl.haxx.se/mail/ |   http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
|   Keeping curl-related questions and discussions on mailing lists allows |   Keeping curl-related questions and discussions on mailing lists allows | ||||||
|   others to join in and help, to share their ideas, contribute their |   others to join in and help, to share their ideas, contribute their | ||||||
| @@ -302,7 +299,7 @@ FAQ | |||||||
|   your curl-related problems. |   your curl-related problems. | ||||||
|  |  | ||||||
|   We list available alternatives on the curl web site: |   We list available alternatives on the curl web site: | ||||||
|   https://curl.haxx.se/support.html |   http://curl.haxx.se/support.html | ||||||
|  |  | ||||||
|   1.10 How many are using curl? |   1.10 How many are using curl? | ||||||
|  |  | ||||||
| @@ -319,7 +316,7 @@ FAQ | |||||||
|   In May 2012 Daniel did a counting game and came up with a number that may |   In May 2012 Daniel did a counting game and came up with a number that may | ||||||
|   be completely wrong or somewhat accurate. Over 500 million! |   be completely wrong or somewhat accurate. Over 500 million! | ||||||
|  |  | ||||||
|   See https://daniel.haxx.se/blog/2012/05/16/300m-users/ |   See http://daniel.haxx.se/blog/2012/05/16/300m-users/ | ||||||
|  |  | ||||||
|   1.11 Why don't you update ca-bundle.crt |   1.11 Why don't you update ca-bundle.crt | ||||||
|  |  | ||||||
| @@ -341,7 +338,7 @@ FAQ | |||||||
|   If you want the most recent collection of ca certs that Mozilla Firefox |   If you want the most recent collection of ca certs that Mozilla Firefox | ||||||
|   uses, we recommend that you extract the collection yourself from Mozilla |   uses, we recommend that you extract the collection yourself from Mozilla | ||||||
|   Firefox (by running 'make ca-bundle), or by using our online service setup |   Firefox (by running 'make ca-bundle), or by using our online service setup | ||||||
|   for this purpose: https://curl.haxx.se/docs/caextract.html |   for this purpose: http://curl.haxx.se/docs/caextract.html | ||||||
|  |  | ||||||
|   1.12 I have a problem who can I chat with? |   1.12 I have a problem who can I chat with? | ||||||
|  |  | ||||||
| @@ -355,15 +352,13 @@ FAQ | |||||||
|   cryptography. When doing so, the Export Control Classification Number (ECCN) |   cryptography. When doing so, the Export Control Classification Number (ECCN) | ||||||
|   is used to identify the level of export control etc. |   is used to identify the level of export control etc. | ||||||
|  |  | ||||||
|   Apache Software Foundation gives a good explanation of ECCNs at |   ASF gives a good explanation at https://www.apache.org/dev/crypto.html | ||||||
|   https://www.apache.org/dev/crypto.html |  | ||||||
|  |  | ||||||
|   We believe curl's number might be ECCN 5D002, another possibility is |   We believe curl's number might be ECCN 5D002, another possibility is | ||||||
|   5D992. It seems necessary to write them (the authority that administers ECCN |   5D992. It seems necessary to write them, asking to confirm. | ||||||
|   numbers), asking to confirm. |  | ||||||
|  |  | ||||||
|   Comprehensible explanations of the meaning of such numbers and how to obtain |   Comprehensible explanations of the meaning of such numbers and how to | ||||||
|   them (resp.) are here |   obtain them (resp.) are here | ||||||
|  |  | ||||||
|   http://www.bis.doc.gov/licensing/exportingbasics.htm |   http://www.bis.doc.gov/licensing/exportingbasics.htm | ||||||
|   http://www.bis.doc.gov/licensing/do_i_needaneccn.html |   http://www.bis.doc.gov/licensing/do_i_needaneccn.html | ||||||
| @@ -449,7 +444,7 @@ FAQ | |||||||
|   GnuTLS, yassl, NSS, PolarSSL, axTLS, Secure Transport (native iOS/OS X), |   GnuTLS, yassl, NSS, PolarSSL, axTLS, Secure Transport (native iOS/OS X), | ||||||
|   WinSSL (native Windows) or GSKit (native IBM i). They all have their pros |   WinSSL (native Windows) or GSKit (native IBM i). They all have their pros | ||||||
|   and cons, and we try to maintain a comparison of them here: |   and cons, and we try to maintain a comparison of them here: | ||||||
|   https://curl.haxx.se/docs/ssl-compared.html |   http://curl.haxx.se/docs/ssl-compared.html | ||||||
|  |  | ||||||
|   2.3 Where can I find a copy of LIBEAY32.DLL? |   2.3 Where can I find a copy of LIBEAY32.DLL? | ||||||
|  |  | ||||||
| @@ -561,7 +556,7 @@ FAQ | |||||||
|  |  | ||||||
|   Find out more about which languages that support curl directly, and how to |   Find out more about which languages that support curl directly, and how to | ||||||
|   install and use them, in the libcurl section of the curl web site: |   install and use them, in the libcurl section of the curl web site: | ||||||
|   https://curl.haxx.se/libcurl/ |   http://curl.haxx.se/libcurl/ | ||||||
|  |  | ||||||
|   All the various bindings to libcurl are made by other projects and people, |   All the various bindings to libcurl are made by other projects and people, | ||||||
|   outside of the cURL project. The cURL project itself only produces libcurl |   outside of the cURL project. The cURL project itself only produces libcurl | ||||||
| @@ -694,7 +689,7 @@ FAQ | |||||||
|   certificate. Server certificate verification is enabled by default in curl |   certificate. Server certificate verification is enabled by default in curl | ||||||
|   and libcurl and is often the reason for problems as explained in FAQ entry |   and libcurl and is often the reason for problems as explained in FAQ entry | ||||||
|   4.12 and the SSLCERTS document |   4.12 and the SSLCERTS document | ||||||
|   (https://curl.haxx.se/docs/sslcerts.html). Server certificates that are |   (http://curl.haxx.se/docs/sslcerts.html). Server certificates that are | ||||||
|   "self-signed" or otherwise signed by a CA that you do not have a CA cert |   "self-signed" or otherwise signed by a CA that you do not have a CA cert | ||||||
|   for, cannot be verified. If the verification during a connect fails, you are |   for, cannot be verified. If the verification during a connect fails, you are | ||||||
|   refused access. You then need to explicitly disable the verification to |   refused access. You then need to explicitly disable the verification to | ||||||
| @@ -985,7 +980,7 @@ FAQ | |||||||
|   this check. |   this check. | ||||||
|  |  | ||||||
|   Details are also in the SSLCERTS file in the release archives, found online |   Details are also in the SSLCERTS file in the release archives, found online | ||||||
|   here: https://curl.haxx.se/docs/sslcerts.html |   here: http://curl.haxx.se/docs/sslcerts.html | ||||||
|  |  | ||||||
|   4.13 Why is curl -R on Windows one hour off? |   4.13 Why is curl -R on Windows one hour off? | ||||||
|  |  | ||||||
| @@ -1092,7 +1087,7 @@ FAQ | |||||||
|  |  | ||||||
|   In such cases, the TCP/IP stack is responsible for detecting when the |   In such cases, the TCP/IP stack is responsible for detecting when the | ||||||
|   network connection is irrevocably lost. Since with some protocols it is |   network connection is irrevocably lost. Since with some protocols it is | ||||||
|   perfectly legal for the client to wait indefinitely for data, the stack may |   perfectly legal for the client wait indefinitely for data, the stack may | ||||||
|   never report a problem, and even when it does, it can take up to 20 minutes |   never report a problem, and even when it does, it can take up to 20 minutes | ||||||
|   for it to detect an issue.  The curl option --keepalive-time enables |   for it to detect an issue.  The curl option --keepalive-time enables | ||||||
|   keep-alive support in the TCP/IP stack which makes it periodically probe the |   keep-alive support in the TCP/IP stack which makes it periodically probe the | ||||||
| @@ -1402,7 +1397,7 @@ FAQ | |||||||
|   to do "LIST -a" or similar to see them. |   to do "LIST -a" or similar to see them. | ||||||
|  |  | ||||||
|   The application thus needs to parse the LIST output. One such existing |   The application thus needs to parse the LIST output. One such existing | ||||||
|   list parser is available at https://cr.yp.to/ftpparse.html  Versions of |   list parser is available at http://cr.yp.to/ftpparse.html  Versions of | ||||||
|   libcurl since 7.21.0 also provide the ability to specify a wildcard to |   libcurl since 7.21.0 also provide the ability to specify a wildcard to | ||||||
|   download multiple files from one FTP directory. |   download multiple files from one FTP directory. | ||||||
|  |  | ||||||
| @@ -1521,7 +1516,7 @@ FAQ | |||||||
|   notice" somewhere. Most probably like in the documentation or in the section |   notice" somewhere. Most probably like in the documentation or in the section | ||||||
|   where other third party dependencies already are mentioned and acknowledged. |   where other third party dependencies already are mentioned and acknowledged. | ||||||
|  |  | ||||||
|   As can be seen here: https://curl.haxx.se/docs/companies.html and elsewhere, |   As can be seen here: http://curl.haxx.se/docs/companies.html and elsewhere, | ||||||
|   more and more companies are discovering the power of libcurl and take |   more and more companies are discovering the power of libcurl and take | ||||||
|   advantage of it even in commercial environments. |   advantage of it even in commercial environments. | ||||||
|  |  | ||||||
| @@ -1541,7 +1536,9 @@ FAQ | |||||||
|  |  | ||||||
|   7.2 Who wrote PHP/CURL? |   7.2 Who wrote PHP/CURL? | ||||||
|  |  | ||||||
|   PHP/CURL was initially written by Sterling Hughes. |   PHP/CURL is a module that comes with the regular PHP package. It depends and | ||||||
|  |   uses libcurl, so you need to have libcurl installed properly first before | ||||||
|  |   PHP/CURL can be used. PHP/CURL was initially written by Sterling Hughes. | ||||||
|  |  | ||||||
|   7.3 Can I perform multiple requests using the same handle? |   7.3 Can I perform multiple requests using the same handle? | ||||||
|  |  | ||||||
| @@ -1550,10 +1547,4 @@ FAQ | |||||||
|   unknown to me). |   unknown to me). | ||||||
|  |  | ||||||
|   After a transfer, you just set new options in the handle and make another |   After a transfer, you just set new options in the handle and make another | ||||||
|   transfer. This will make libcurl re-use the same connection if it can. |   transfer. This will make libcurl to re-use the same connection if it can. | ||||||
|  |  | ||||||
|   7.4 Does PHP/CURL have dependencies? |  | ||||||
|  |  | ||||||
|   PHP/CURL is a module that comes with the regular PHP package. It depends on |  | ||||||
|   and uses libcurl, so you need to have libcurl installed properly before |  | ||||||
|   PHP/CURL can be used. |  | ||||||
|   | |||||||
| @@ -65,7 +65,7 @@ OpenSSL took over where SSLeay was abandoned. | |||||||
| May, first Debian package. | May, first Debian package. | ||||||
|  |  | ||||||
| August, LDAP:// and FILE:// support added. The curl web site gets 1300 visits | August, LDAP:// and FILE:// support added. The curl web site gets 1300 visits | ||||||
| weekly. Moved site to curl.haxx.nu. | weekly. | ||||||
|  |  | ||||||
| Released curl 6.0 in September. 15000 lines of code. | Released curl 6.0 in September. 15000 lines of code. | ||||||
|  |  | ||||||
| @@ -81,8 +81,6 @@ the easy interface and turned out to be the beginning of actually getting | |||||||
| other software and programs to get based on and powered by libcurl. Almost | other software and programs to get based on and powered by libcurl. Almost | ||||||
| 20000 lines of code. | 20000 lines of code. | ||||||
|  |  | ||||||
| June 2000: the curl site moves to "curl.haxx.se" |  | ||||||
|  |  | ||||||
| August, the curl web site gets 4000 visits weekly. | August, the curl web site gets 4000 visits weekly. | ||||||
|  |  | ||||||
| The PHP guys adopted libcurl already the same month, when the first ever third | The PHP guys adopted libcurl already the same month, when the first ever third | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| Updated: July 3, 2012 (https://curl.haxx.se/docs/http-cookies.html) | Updated: July 3, 2012 (http://curl.haxx.se/docs/http-cookies.html) | ||||||
|                                   _   _ ____  _ |                                   _   _ ____  _ | ||||||
|                               ___| | | |  _ \| | |                               ___| | | |  _ \| | | ||||||
|                              / __| | | | |_) | | |                              / __| | | | |_) | | | ||||||
| @@ -34,7 +34,7 @@ HTTP Cookies | |||||||
|   servers with the Cookie: header. |   servers with the Cookie: header. | ||||||
|  |  | ||||||
|   For a very long time, the only spec explaining how to use cookies was the |   For a very long time, the only spec explaining how to use cookies was the | ||||||
|   original Netscape spec from 1994: https://curl.haxx.se/rfc/cookie_spec.html |   original Netscape spec from 1994: http://curl.haxx.se/rfc/cookie_spec.html | ||||||
|  |  | ||||||
|   In 2011, RFC6265 (https://www.ietf.org/rfc/rfc6265.txt) was finally published |   In 2011, RFC6265 (https://www.ietf.org/rfc/rfc6265.txt) was finally published | ||||||
|   and details how cookies work within HTTP. |   and details how cookies work within HTTP. | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ HTTP/2 with curl | |||||||
| ================ | ================ | ||||||
|  |  | ||||||
| [HTTP/2 Spec](https://www.rfc-editor.org/rfc/rfc7540.txt) | [HTTP/2 Spec](https://www.rfc-editor.org/rfc/rfc7540.txt) | ||||||
| [http2 explained](https://daniel.haxx.se/http2/) | [http2 explained](http://daniel.haxx.se/http2/) | ||||||
|  |  | ||||||
| Build prerequisites | Build prerequisites | ||||||
| ------------------- | ------------------- | ||||||
| @@ -100,5 +100,8 @@ automatically. [Spec](https://tools.ietf.org/html/draft-ietf-httpbis-alt-svc-05) | |||||||
| TODO | TODO | ||||||
| ---- | ---- | ||||||
|  |  | ||||||
|   - Implement "prior-knowledge" HTTP/2 connections over clear text so that |   - Provide API to set priorities / dependencies of individual streams | ||||||
|  |  | ||||||
|  |   - Implement "prior-knowledge" HTTP/2 connecitons over clear text so that | ||||||
|     curl can connect with HTTP/2 at once without 1.1+Upgrade. |     curl can connect with HTTP/2 at once without 1.1+Upgrade. | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -473,12 +473,12 @@ Win32 | |||||||
|  |  | ||||||
|    Legacy Windows and SSL |    Legacy Windows and SSL | ||||||
|    ---------------------- |    ---------------------- | ||||||
|  |    WinSSL (Windows SSPI, more specifically Schannel), is the native SSL library | ||||||
|    WinSSL (specifically SChannel from Windows SSPI), is the native SSL library |    that comes with the Windows OS. WinSSL in Windows <= XP is not able to | ||||||
|    in Windows. However, WinSSL in Windows <= XP is unable to connect to servers |    connect to servers that no longer support the legacy handshakes and | ||||||
|    that no longer support the legacy handshakes and algorithms used by those |    algorithms used by those versions. If you will be using curl in one of those | ||||||
|    versions. If you will be using curl in one of those earlier versions of |    earlier versions of Windows you should choose another SSL backend like | ||||||
|    Windows you should choose another SSL backend such as OpenSSL. |    OpenSSL. | ||||||
|  |  | ||||||
| Apple iOS and Mac OS X | Apple iOS and Mac OS X | ||||||
| ====================== | ====================== | ||||||
| @@ -706,7 +706,7 @@ NetWare | |||||||
|    Builds automatically created 8 times a day from current git are here: |    Builds automatically created 8 times a day from current git are here: | ||||||
|    http://www.gknw.net/mirror/curl/autobuilds/ |    http://www.gknw.net/mirror/curl/autobuilds/ | ||||||
|    the status of these builds can be viewed at the autobuild table: |    the status of these builds can be viewed at the autobuild table: | ||||||
|    https://curl.haxx.se/dev/builds.html |    http://curl.haxx.se/dev/builds.html | ||||||
|  |  | ||||||
| eCos | eCos | ||||||
| ==== | ==== | ||||||
| @@ -950,10 +950,9 @@ REDUCING SIZE | |||||||
|    important factor.  First, be sure to set the CFLAGS variable when |    important factor.  First, be sure to set the CFLAGS variable when | ||||||
|    configuring with any relevant compiler optimization flags to reduce the |    configuring with any relevant compiler optimization flags to reduce the | ||||||
|    size of the binary.  For gcc, this would mean at minimum the -Os option, |    size of the binary.  For gcc, this would mean at minimum the -Os option, | ||||||
|    and potentially the -march=X, -mdynamic-no-pic and -flto options as well, |    and potentially the -march=X and -mdynamic-no-pic options as well, e.g. | ||||||
|    e.g. |  | ||||||
|  |  | ||||||
|       ./configure CFLAGS='-Os' LDFLAGS='-Wl,-Bsymbolic'... |       ./configure CFLAGS='-Os' ... | ||||||
|  |  | ||||||
|    Note that newer compilers often produce smaller code than older versions |    Note that newer compilers often produce smaller code than older versions | ||||||
|    due to improved optimization. |    due to improved optimization. | ||||||
| @@ -971,9 +970,7 @@ REDUCING SIZE | |||||||
|      --disable-ipv6 (disables support for IPv6) |      --disable-ipv6 (disables support for IPv6) | ||||||
|      --disable-manual (disables support for the built-in documentation) |      --disable-manual (disables support for the built-in documentation) | ||||||
|      --disable-proxy (disables support for HTTP and SOCKS proxies) |      --disable-proxy (disables support for HTTP and SOCKS proxies) | ||||||
|      --disable-unix-sockets (disables support for UNIX sockets) |  | ||||||
|      --disable-verbose (eliminates debugging strings and error code strings) |      --disable-verbose (eliminates debugging strings and error code strings) | ||||||
|      --disable-versioned-symbols (disables support for versioned symbols) |  | ||||||
|      --enable-hidden-symbols (eliminates unneeded symbols in the shared library) |      --enable-hidden-symbols (eliminates unneeded symbols in the shared library) | ||||||
|      --without-libidn (disables support for the libidn DNS library) |      --without-libidn (disables support for the libidn DNS library) | ||||||
|      --without-librtmp (disables support for RTMP) |      --without-librtmp (disables support for RTMP) | ||||||
| @@ -986,7 +983,7 @@ REDUCING SIZE | |||||||
|    configure command-line, e.g. |    configure command-line, e.g. | ||||||
|  |  | ||||||
|      CFLAGS="-Os -ffunction-sections -fdata-sections \ |      CFLAGS="-Os -ffunction-sections -fdata-sections \ | ||||||
|              -fno-unwind-tables -fno-asynchronous-unwind-tables -flto" \ |              -fno-unwind-tables -fno-asynchronous-unwind-tables" \ | ||||||
|      LDFLAGS="-Wl,-s -Wl,-Bsymbolic -Wl,--gc-sections" |      LDFLAGS="-Wl,-s -Wl,-Bsymbolic -Wl,--gc-sections" | ||||||
|  |  | ||||||
|    Be sure also to strip debugging symbols from your binaries after |    Be sure also to strip debugging symbols from your binaries after | ||||||
| @@ -996,9 +993,9 @@ REDUCING SIZE | |||||||
|    .comment section). |    .comment section). | ||||||
|  |  | ||||||
|    Using these techniques it is possible to create a basic HTTP-only shared |    Using these techniques it is possible to create a basic HTTP-only shared | ||||||
|    libcurl library for i386 Linux platforms that is only 109 KiB in size, and |    libcurl library for i386 Linux platforms that is only 114 KiB in size, and | ||||||
|    an FTP-only library that is 109 KiB in size (as of libcurl version 7.45.0, |    an FTP-only library that is 115 KiB in size (as of libcurl version 7.35.0, | ||||||
|    using gcc 4.9.2). |    using gcc 4.8.2). | ||||||
|  |  | ||||||
|    You may find that statically linking libcurl to your application will |    You may find that statically linking libcurl to your application will | ||||||
|    result in a lower total size than dynamically linking. |    result in a lower total size than dynamically linking. | ||||||
|   | |||||||
| @@ -248,7 +248,7 @@ SSL Files | |||||||
| openssl-0.9.7e-win32-bin.zip for the minimalist package of the openssl-0.9.7e | openssl-0.9.7e-win32-bin.zip for the minimalist package of the openssl-0.9.7e | ||||||
| binaries ported to MS Windows 95/98/NT/XP using the MingW32/GCC-3.1 | binaries ported to MS Windows 95/98/NT/XP using the MingW32/GCC-3.1 | ||||||
| development environment. The file may be downloaded at | development environment. The file may be downloaded at | ||||||
| https://curl.haxx.se/download/. | http://curl.haxx.se/download/. | ||||||
|  |  | ||||||
| 2- Open the above zip file. You will find two files - SDL.dll, | 2- Open the above zip file. You will find two files - SDL.dll, | ||||||
| SDL_mixer.dll. Install them in the directory C:\WINDOWS\SYSTEM32 for Win 9x | SDL_mixer.dll. Install them in the directory C:\WINDOWS\SYSTEM32 for Win 9x | ||||||
|   | |||||||
| @@ -1079,17 +1079,17 @@ for older and later versions as things don't change drastically that often. | |||||||
|   the share API. |   the share API. | ||||||
|  |  | ||||||
|  |  | ||||||
| [1]: https://curl.haxx.se/libcurl/c/curl_easy_setopt.html | [1]: http://curl.haxx.se/libcurl/c/curl_easy_setopt.html | ||||||
| [2]: https://curl.haxx.se/libcurl/c/curl_easy_init.html | [2]: http://curl.haxx.se/libcurl/c/curl_easy_init.html | ||||||
| [3]: http://c-ares.haxx.se/ | [3]: http://c-ares.haxx.se/ | ||||||
| [4]: https://tools.ietf.org/html/rfc7230 "RFC 7230" | [4]: https://tools.ietf.org/html/rfc7230 "RFC 7230" | ||||||
| [5]: https://curl.haxx.se/libcurl/c/CURLOPT_ACCEPT_ENCODING.html | [5]: http://curl.haxx.se/libcurl/c/CURLOPT_ACCEPT_ENCODING.html | ||||||
| [6]: https://curl.haxx.se/docs/manpage.html#--compressed | [6]: http://curl.haxx.se/docs/manpage.html#--compressed | ||||||
| [7]: https://curl.haxx.se/libcurl/c/curl_multi_socket_action.html | [7]: http://curl.haxx.se/libcurl/c/curl_multi_socket_action.html | ||||||
| [8]: https://curl.haxx.se/libcurl/c/curl_multi_timeout.html | [8]: http://curl.haxx.se/libcurl/c/curl_multi_timeout.html | ||||||
| [9]: https://curl.haxx.se/libcurl/c/curl_multi_setopt.html | [9]: http://curl.haxx.se/libcurl/c/curl_multi_setopt.html | ||||||
| [10]: https://curl.haxx.se/libcurl/c/CURLMOPT_TIMERFUNCTION.html | [10]: http://curl.haxx.se/libcurl/c/CURLMOPT_TIMERFUNCTION.html | ||||||
| [11]: https://curl.haxx.se/libcurl/c/curl_multi_perform.html | [11]: http://curl.haxx.se/libcurl/c/curl_multi_perform.html | ||||||
| [12]: https://curl.haxx.se/libcurl/c/curl_multi_fdset.html | [12]: http://curl.haxx.se/libcurl/c/curl_multi_fdset.html | ||||||
| [13]: https://curl.haxx.se/libcurl/c/curl_multi_add_handle.html | [13]: http://curl.haxx.se/libcurl/c/curl_multi_add_handle.html | ||||||
| [14]: https://curl.haxx.se/libcurl/c/curl_multi_info_read.html | [14]: http://curl.haxx.se/libcurl/c/curl_multi_info_read.html | ||||||
|   | |||||||
| @@ -3,17 +3,14 @@ join in and help us correct one or more of these! Also be sure to check the | |||||||
| changelog of the current development status, as one or more of these problems | changelog of the current development status, as one or more of these problems | ||||||
| may have been fixed since this was written! | may have been fixed since this was written! | ||||||
|  |  | ||||||
| 91. "curl_easy_perform hangs with imap and PolarSSL" |  | ||||||
|   https://github.com/curl/curl/issues/334 |  | ||||||
|  |  | ||||||
| 90. IMAP "SEARCH ALL" truncates output on large boxes. "A quick search of the | 90. IMAP "SEARCH ALL" truncates output on large boxes. "A quick search of the | ||||||
|   code reveals that pingpong.c contains some truncation code, at line 408, |   code reveals that pingpong.c contains some truncation code, at line 408, | ||||||
|   when it deems the server response to be too large truncating it to 40 |   when it deems the server response to be too large truncating it to 40 | ||||||
|   characters" |   characters" | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1366 |   http://curl.haxx.se/bug/view.cgi?id=1366 | ||||||
|  |  | ||||||
| 89. Disabling HTTP Pipelining when there are ongoing transfers can lead to | 89. Disabling HTTP Pipelining when there are ongoing transfers can lead to | ||||||
|   heap corruption and crash. https://curl.haxx.se/bug/view.cgi?id=1411 |   heap corruption and crash. http://curl.haxx.se/bug/view.cgi?id=1411 | ||||||
|  |  | ||||||
| 88. libcurl doesn't support CURLINFO_FILETIME for SFTP transfers and thus | 88. libcurl doesn't support CURLINFO_FILETIME for SFTP transfers and thus | ||||||
|   curl's -R option also doesn't work then. |   curl's -R option also doesn't work then. | ||||||
| @@ -24,7 +21,7 @@ may have been fixed since this was written! | |||||||
|   mention that decoding also means that we need to check for nastiness that is |   mention that decoding also means that we need to check for nastiness that is | ||||||
|   attempted, like "../" sequences and the like. Probably everything to the left |   attempted, like "../" sequences and the like. Probably everything to the left | ||||||
|   of any embedded slashes should be cut off. |   of any embedded slashes should be cut off. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1294 |   http://curl.haxx.se/bug/view.cgi?id=1294 | ||||||
|  |  | ||||||
| 86. The disconnect commands (LOGOUT and QUIT) may not be sent by IMAP, POP3 | 86. The disconnect commands (LOGOUT and QUIT) may not be sent by IMAP, POP3 | ||||||
|   and SMTP if a failure occurs during the authentication phase of a |   and SMTP if a failure occurs during the authentication phase of a | ||||||
| @@ -35,8 +32,7 @@ may have been fixed since this was written! | |||||||
|   CURLINFO_STARTTRANSFER_TIME is wrong. While using POST |   CURLINFO_STARTTRANSFER_TIME is wrong. While using POST | ||||||
|   CURLINFO_STARTTRANSFER_TIME minus CURLINFO_PRETRANSFER_TIME is near to zero |   CURLINFO_STARTTRANSFER_TIME minus CURLINFO_PRETRANSFER_TIME is near to zero | ||||||
|   every time. |   every time. | ||||||
|   https://github.com/curl/curl/issues/218 |   http://curl.haxx.se/bug/view.cgi?id=1213 | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1213 |  | ||||||
|  |  | ||||||
| 84. CURLINFO_SSL_VERIFYRESULT is only implemented for the OpenSSL and NSS | 84. CURLINFO_SSL_VERIFYRESULT is only implemented for the OpenSSL and NSS | ||||||
|   backends, so relying on this information in a generic app is flaky. |   backends, so relying on this information in a generic app is flaky. | ||||||
| @@ -44,48 +40,58 @@ may have been fixed since this was written! | |||||||
| 82. When building with the Windows Borland compiler, it fails because the | 82. When building with the Windows Borland compiler, it fails because the | ||||||
|   "tlib" tool doesn't support hyphens (minus signs) in file names and we have |   "tlib" tool doesn't support hyphens (minus signs) in file names and we have | ||||||
|   such in the build. |   such in the build. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1222 |   http://curl.haxx.se/bug/view.cgi?id=1222 | ||||||
|  |  | ||||||
| 81. When using -J (with -O), automatically resumed downloading together with | 81. When using -J (with -O), automatically resumed downloading together with | ||||||
|   "-C -" fails. Without -J the same command line works! This happens because |   "-C -" fails. Without -J the same command line works! This happens because | ||||||
|   the resume logic is worked out before the target file name (and thus its |   the resume logic is worked out before the target file name (and thus its | ||||||
|   pre-transfer size) has been figured out! |   pre-transfer size) has been figured out! | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1169 |   http://curl.haxx.se/bug/view.cgi?id=1169 | ||||||
|  |  | ||||||
| 80. Curl doesn't recognize certificates in DER format in keychain, but it | 80. Curl doesn't recognize certificates in DER format in keychain, but it | ||||||
|   works with PEM. |   works with PEM. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1065 |   http://curl.haxx.se/bug/view.cgi?id=1065 | ||||||
|  |  | ||||||
| 79. SMTP. When sending data to multiple recipients, curl will abort and return | 79. SMTP. When sending data to multiple recipients, curl will abort and return | ||||||
|   failure if one of the recipients indicate failure (on the "RCPT TO" |   failure if one of the recipients indicate failure (on the "RCPT TO" | ||||||
|   command). Ordinary mail programs would proceed and still send to the ones |   command). Ordinary mail programs would proceed and still send to the ones | ||||||
|   that can receive data. This is subject for change in the future. |   that can receive data. This is subject for change in the future. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=1116 |   http://curl.haxx.se/bug/view.cgi?id=1116 | ||||||
|  |  | ||||||
|  | 78. curl and libcurl don't always signal the client properly when "sending" | ||||||
|  |   zero bytes files - it makes for example the command line client not creating | ||||||
|  |   any file at all. Like when using FTP. | ||||||
|  |   http://curl.haxx.se/bug/view.cgi?id=1063 | ||||||
|  |  | ||||||
|  | 76. The SOCKET type in Win64 is 64 bits large (and thus so is curl_socket_t on | ||||||
|  |   that platform), and long is only 32 bits. It makes it impossible for | ||||||
|  |   curl_easy_getinfo() to return a socket properly with the CURLINFO_LASTSOCKET | ||||||
|  |   option as for all other operating systems. | ||||||
|  |  | ||||||
| 75. NTLM authentication involving unicode user name or password only works | 75. NTLM authentication involving unicode user name or password only works | ||||||
|   properly if built with UNICODE defined together with the WinSSL/schannel |   properly if built with UNICODE defined together with the WinSSL/schannel | ||||||
|   backend. The original problem was mentioned in: |   backend. The original problem was mentioned in: | ||||||
|   https://curl.haxx.se/mail/lib-2009-10/0024.html |   http://curl.haxx.se/mail/lib-2009-10/0024.html | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=896 |   http://curl.haxx.se/bug/view.cgi?id=896 | ||||||
|  |  | ||||||
|   The WinSSL/schannel version verified to work as mentioned in |   The WinSSL/schannel version verified to work as mentioned in | ||||||
|   https://curl.haxx.se/mail/lib-2012-07/0073.html |   http://curl.haxx.se/mail/lib-2012-07/0073.html | ||||||
|  |  | ||||||
| 73. if a connection is made to a FTP server but the server then just never | 73. if a connection is made to a FTP server but the server then just never | ||||||
|   sends the 220 response or otherwise is dead slow, libcurl will not |   sends the 220 response or otherwise is dead slow, libcurl will not | ||||||
|   acknowledge the connection timeout during that phase but only the "real" |   acknowledge the connection timeout during that phase but only the "real" | ||||||
|   timeout - which may surprise users as it is probably considered to be the |   timeout - which may surprise users as it is probably considered to be the | ||||||
|   connect phase to most people. Brought up (and is being misunderstood) in: |   connect phase to most people. Brought up (and is being misunderstood) in: | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=856 |   http://curl.haxx.se/bug/view.cgi?id=856 | ||||||
|  |  | ||||||
| 72. "Pausing pipeline problems." | 72. "Pausing pipeline problems." | ||||||
|   https://curl.haxx.se/mail/lib-2009-07/0214.html |   http://curl.haxx.se/mail/lib-2009-07/0214.html | ||||||
|  |  | ||||||
| 70. Problem re-using easy handle after call to curl_multi_remove_handle | 70. Problem re-using easy handle after call to curl_multi_remove_handle | ||||||
|   https://curl.haxx.se/mail/lib-2009-07/0249.html |   http://curl.haxx.se/mail/lib-2009-07/0249.html | ||||||
|  |  | ||||||
| 68. "More questions about ares behavior". | 68. "More questions about ares behavior". | ||||||
|   https://curl.haxx.se/mail/lib-2009-08/0012.html |   http://curl.haxx.se/mail/lib-2009-08/0012.html | ||||||
|  |  | ||||||
| 67. When creating multipart formposts. The file name part can be encoded with | 67. When creating multipart formposts. The file name part can be encoded with | ||||||
|   something beyond ascii but currently libcurl will only pass in the verbatim |   something beyond ascii but currently libcurl will only pass in the verbatim | ||||||
| @@ -94,7 +100,7 @@ may have been fixed since this was written! | |||||||
|   https://tools.ietf.org/html/draft-reschke-rfc2231-in-http-02 |   https://tools.ietf.org/html/draft-reschke-rfc2231-in-http-02 | ||||||
|  |  | ||||||
| 66. When using telnet, the time limitation options don't work. | 66. When using telnet, the time limitation options don't work. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=846 |   http://curl.haxx.se/bug/view.cgi?id=846 | ||||||
|  |  | ||||||
| 65. When doing FTP over a socks proxy or CONNECT through HTTP proxy and the | 65. When doing FTP over a socks proxy or CONNECT through HTTP proxy and the | ||||||
|   multi interface is used, libcurl will fail if the (passive) TCP connection |   multi interface is used, libcurl will fail if the (passive) TCP connection | ||||||
| @@ -105,27 +111,27 @@ may have been fixed since this was written! | |||||||
| 63. When CURLOPT_CONNECT_ONLY is used, the handle cannot reliably be re-used | 63. When CURLOPT_CONNECT_ONLY is used, the handle cannot reliably be re-used | ||||||
|   for any further requests or transfers. The work-around is then to close that |   for any further requests or transfers. The work-around is then to close that | ||||||
|   handle with curl_easy_cleanup() and create a new. Some more details: |   handle with curl_easy_cleanup() and create a new. Some more details: | ||||||
|   https://curl.haxx.se/mail/lib-2009-04/0300.html |   http://curl.haxx.se/mail/lib-2009-04/0300.html | ||||||
|  |  | ||||||
| 61. If an upload using Expect: 100-continue receives an HTTP 417 response, | 61. If an upload using Expect: 100-continue receives an HTTP 417 response, | ||||||
|   it ought to be automatically resent without the Expect:.  A workaround is |   it ought to be automatically resent without the Expect:.  A workaround is | ||||||
|   for the client application to redo the transfer after disabling Expect:. |   for the client application to redo the transfer after disabling Expect:. | ||||||
|   https://curl.haxx.se/mail/archive-2008-02/0043.html |   http://curl.haxx.se/mail/archive-2008-02/0043.html | ||||||
|  |  | ||||||
| 60. libcurl closes the connection if an HTTP 401 reply is received while it | 60. libcurl closes the connection if an HTTP 401 reply is received while it | ||||||
|   is waiting for the the 100-continue response. |   is waiting for the the 100-continue response. | ||||||
|   https://curl.haxx.se/mail/lib-2008-08/0462.html |   http://curl.haxx.se/mail/lib-2008-08/0462.html | ||||||
|  |  | ||||||
| 58. It seems sensible to be able to use CURLOPT_NOBODY and | 58. It seems sensible to be able to use CURLOPT_NOBODY and | ||||||
|   CURLOPT_FAILONERROR with FTP to detect if a file exists or not, but it is |   CURLOPT_FAILONERROR with FTP to detect if a file exists or not, but it is | ||||||
|   not working: https://curl.haxx.se/mail/lib-2008-07/0295.html |   not working: http://curl.haxx.se/mail/lib-2008-07/0295.html | ||||||
|  |  | ||||||
| 56. When libcurl sends CURLOPT_POSTQUOTE commands when connected to a SFTP | 56. When libcurl sends CURLOPT_POSTQUOTE commands when connected to a SFTP | ||||||
|   server using the multi interface, the commands are not being sent correctly |   server using the multi interface, the commands are not being sent correctly | ||||||
|   and instead the connection is "cancelled" (the operation is considered done) |   and instead the connection is "cancelled" (the operation is considered done) | ||||||
|   prematurely. There is a half-baked (busy-looping) patch provided in the bug |   prematurely. There is a half-baked (busy-looping) patch provided in the bug | ||||||
|   report but it cannot be accepted as-is. See |   report but it cannot be accepted as-is. See | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=748 |   http://curl.haxx.se/bug/view.cgi?id=748 | ||||||
|  |  | ||||||
| 55. libcurl fails to build with MIT Kerberos for Windows (KfW) due to KfW's | 55. libcurl fails to build with MIT Kerberos for Windows (KfW) due to KfW's | ||||||
|   library header files exporting symbols/macros that should be kept private |   library header files exporting symbols/macros that should be kept private | ||||||
| @@ -134,13 +140,13 @@ may have been fixed since this was written! | |||||||
| 52. Gautam Kachroo's issue that identifies a problem with the multi interface | 52. Gautam Kachroo's issue that identifies a problem with the multi interface | ||||||
|   where a connection can be re-used without actually being properly |   where a connection can be re-used without actually being properly | ||||||
|   SSL-negotiated: |   SSL-negotiated: | ||||||
|   https://curl.haxx.se/mail/lib-2008-01/0277.html |   http://curl.haxx.se/mail/lib-2008-01/0277.html | ||||||
|  |  | ||||||
| 49. If using --retry and the transfer timeouts (possibly due to using -m or | 49. If using --retry and the transfer timeouts (possibly due to using -m or | ||||||
|   -y/-Y) the next attempt doesn't resume the transfer properly from what was |   -y/-Y) the next attempt doesn't resume the transfer properly from what was | ||||||
|   downloaded in the previous attempt but will truncate and restart at the |   downloaded in the previous attempt but will truncate and restart at the | ||||||
|   original position where it was at before the previous failed attempt. See |   original position where it was at before the previous failed attempt. See | ||||||
|   https://curl.haxx.se/mail/lib-2008-01/0080.html and Mandriva bug report |   http://curl.haxx.se/mail/lib-2008-01/0080.html and Mandriva bug report | ||||||
|   https://qa.mandriva.com/show_bug.cgi?id=22565 |   https://qa.mandriva.com/show_bug.cgi?id=22565 | ||||||
|  |  | ||||||
| 48. If a CONNECT response-headers are larger than BUFSIZE (16KB) when the | 48. If a CONNECT response-headers are larger than BUFSIZE (16KB) when the | ||||||
| @@ -149,25 +155,25 @@ may have been fixed since this was written! | |||||||
|   protocol code. This should be very rare. |   protocol code. This should be very rare. | ||||||
|  |  | ||||||
| 43. There seems to be a problem when connecting to the Microsoft telnet server. | 43. There seems to be a problem when connecting to the Microsoft telnet server. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=649 |   http://curl.haxx.se/bug/view.cgi?id=649 | ||||||
|  |  | ||||||
| 41. When doing an operation over FTP that requires the ACCT command (but not | 41. When doing an operation over FTP that requires the ACCT command (but not | ||||||
|   when logging in), the operation will fail since libcurl doesn't detect this |   when logging in), the operation will fail since libcurl doesn't detect this | ||||||
|   and thus fails to issue the correct command: |   and thus fails to issue the correct command: | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=635 |   http://curl.haxx.se/bug/view.cgi?id=635 | ||||||
|  |  | ||||||
| 39. Steffen Rumler's Race Condition in Curl_proxyCONNECT: | 39. Steffen Rumler's Race Condition in Curl_proxyCONNECT: | ||||||
|   https://curl.haxx.se/mail/lib-2007-01/0045.html |   http://curl.haxx.se/mail/lib-2007-01/0045.html | ||||||
|  |  | ||||||
| 38. Kumar Swamy Bhatt's problem in ftp/ssl "LIST" operation: | 38. Kumar Swamy Bhatt's problem in ftp/ssl "LIST" operation: | ||||||
|   https://curl.haxx.se/mail/lib-2007-01/0103.html |   http://curl.haxx.se/mail/lib-2007-01/0103.html | ||||||
|  |  | ||||||
| 35. Both SOCKS5 and SOCKS4 proxy connections are done blocking, which is very | 35. Both SOCKS5 and SOCKS4 proxy connections are done blocking, which is very | ||||||
|   bad when used with the multi interface. |   bad when used with the multi interface. | ||||||
|  |  | ||||||
| 34. The SOCKS4 connection codes don't properly acknowledge (connect) timeouts. | 34. The SOCKS4 connection codes don't properly acknowledge (connect) timeouts. | ||||||
|   Also see #12. According to bug #1556528, even the SOCKS5 connect code does |   Also see #12. According to bug #1556528, even the SOCKS5 connect code does | ||||||
|   not do it right: https://curl.haxx.se/bug/view.cgi?id=604 |   not do it right: http://curl.haxx.se/bug/view.cgi?id=604 | ||||||
|  |  | ||||||
| 31. "curl-config --libs" will include details set in LDFLAGS when configure is | 31. "curl-config --libs" will include details set in LDFLAGS when configure is | ||||||
|   run that might be needed only for building libcurl. Further, curl-config |   run that might be needed only for building libcurl. Further, curl-config | ||||||
| @@ -175,7 +181,7 @@ may have been fixed since this was written! | |||||||
|  |  | ||||||
| 26. NTLM authentication using SSPI (on Windows) when (lib)curl is running in | 26. NTLM authentication using SSPI (on Windows) when (lib)curl is running in | ||||||
|   "system context" will make it use wrong(?) user name - at least when compared |   "system context" will make it use wrong(?) user name - at least when compared | ||||||
|   to what winhttp does. See https://curl.haxx.se/bug/view.cgi?id=535 |   to what winhttp does. See http://curl.haxx.se/bug/view.cgi?id=535 | ||||||
|  |  | ||||||
| 23. SOCKS-related problems: | 23. SOCKS-related problems: | ||||||
|   B) libcurl doesn't support FTPS over a SOCKS proxy. |   B) libcurl doesn't support FTPS over a SOCKS proxy. | ||||||
| @@ -221,8 +227,8 @@ may have been fixed since this was written! | |||||||
| 10. To get HTTP Negotiate (SPNEGO) authentication to work fine, you need to | 10. To get HTTP Negotiate (SPNEGO) authentication to work fine, you need to | ||||||
|   provide a (fake) user name (this concerns both curl and the lib) because the |   provide a (fake) user name (this concerns both curl and the lib) because the | ||||||
|   code wrongly only considers authentication if there's a user name provided. |   code wrongly only considers authentication if there's a user name provided. | ||||||
|   https://curl.haxx.se/bug/view.cgi?id=440 How? |   http://curl.haxx.se/bug/view.cgi?id=440 How? | ||||||
|   https://curl.haxx.se/mail/lib-2004-08/0182.html |   http://curl.haxx.se/mail/lib-2004-08/0182.html | ||||||
|  |  | ||||||
| 8. Doing resumed upload over HTTP does not work with '-C -', because curl | 8. Doing resumed upload over HTTP does not work with '-C -', because curl | ||||||
|   doesn't do a HEAD first to get the initial size. This needs to be done |   doesn't do a HEAD first to get the initial size. This needs to be done | ||||||
| @@ -238,4 +244,14 @@ may have been fixed since this was written! | |||||||
| 5. libcurl doesn't treat the content-length of compressed data properly, as | 5. libcurl doesn't treat the content-length of compressed data properly, as | ||||||
|   it seems HTTP servers send the *uncompressed* length in that header and |   it seems HTTP servers send the *uncompressed* length in that header and | ||||||
|   libcurl thinks of it as the *compressed* length. Some explanations are here: |   libcurl thinks of it as the *compressed* length. Some explanations are here: | ||||||
|   https://curl.haxx.se/mail/lib-2003-06/0146.html |   http://curl.haxx.se/mail/lib-2003-06/0146.html | ||||||
|  |  | ||||||
|  | 2. If a HTTP server responds to a HEAD request and includes a body (thus | ||||||
|  |   violating the RFC2616), curl won't wait to read the response but just stop | ||||||
|  |   reading and return back. If a second request (let's assume a GET) is then | ||||||
|  |   immediately made to the same server again, the connection will be re-used | ||||||
|  |   fine of course, and the second request will be sent off but when the | ||||||
|  |   response is to get read, the previous response-body is what curl will read | ||||||
|  |   and havoc is what happens. | ||||||
|  |   More details on this is found in this libcurl mailing list thread: | ||||||
|  |   http://curl.haxx.se/mail/lib-2002-08/0000.html | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ accompany your license with an exception[2]. This particular problem was | |||||||
| addressed when the Modified BSD license was created, which does not have the | addressed when the Modified BSD license was created, which does not have the | ||||||
| announcement clause that collides with GPL. | announcement clause that collides with GPL. | ||||||
|  |  | ||||||
| libcurl https://curl.haxx.se/docs/copyright.html | libcurl http://curl.haxx.se/docs/copyright.html | ||||||
|  |  | ||||||
|         Uses an MIT (or Modified BSD)-style license that is as liberal as |         Uses an MIT (or Modified BSD)-style license that is as liberal as | ||||||
|         possible. |         possible. | ||||||
| @@ -73,7 +73,7 @@ libressl http://www.libressl.org/ | |||||||
|         (May be used for SSL/TLS support) As an OpenSSL fork, it has the same |         (May be used for SSL/TLS support) As an OpenSSL fork, it has the same | ||||||
|         license as that. |         license as that. | ||||||
|  |  | ||||||
| c-ares  https://daniel.haxx.se/projects/c-ares/license.html | c-ares  http://daniel.haxx.se/projects/c-ares/license.html | ||||||
|  |  | ||||||
|         (Used for asynchronous name resolves) Uses an MIT license that is very |         (Used for asynchronous name resolves) Uses an MIT license that is very | ||||||
|         liberal and imposes no restrictions on any other library or part you |         liberal and imposes no restrictions on any other library or part you | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ MAIL ETIQUETTE | |||||||
|   1.1 Mailing Lists |   1.1 Mailing Lists | ||||||
|  |  | ||||||
|   The mailing lists we have are all listed and described at |   The mailing lists we have are all listed and described at | ||||||
|   https://curl.haxx.se/mail/ |   http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
|   Each mailing list is targeted to a specific set of users and subjects, |   Each mailing list is targeted to a specific set of users and subjects, | ||||||
|   please use the one or the ones that suit you the most. |   please use the one or the ones that suit you the most. | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ LATEST VERSION | |||||||
|   You always find news about what's going on as well as the latest versions |   You always find news about what's going on as well as the latest versions | ||||||
|   from the curl web pages, located at: |   from the curl web pages, located at: | ||||||
|  |  | ||||||
|         https://curl.haxx.se |         http://curl.haxx.se | ||||||
|  |  | ||||||
| SIMPLE USAGE | SIMPLE USAGE | ||||||
|  |  | ||||||
| @@ -824,7 +824,7 @@ LDAP | |||||||
|   Working with LDAP URLs": |   Working with LDAP URLs": | ||||||
|   http://developer.netscape.com/docs/manuals/dirsdk/csdk30/url.htm |   http://developer.netscape.com/docs/manuals/dirsdk/csdk30/url.htm | ||||||
|  |  | ||||||
|   RFC 2255, "The LDAP URL Format" https://curl.haxx.se/rfc/rfc2255.txt |   RFC 2255, "The LDAP URL Format" http://curl.haxx.se/rfc/rfc2255.txt | ||||||
|  |  | ||||||
|   To show you an example, this is how I can get all people from my local LDAP |   To show you an example, this is how I can get all people from my local LDAP | ||||||
|   server that has a certain sub-domain in their email address: |   server that has a certain sub-domain in their email address: | ||||||
| @@ -1011,7 +1011,7 @@ MAILING LISTS | |||||||
|  |  | ||||||
|   For your convenience, we have several open mailing lists to discuss curl, |   For your convenience, we have several open mailing lists to discuss curl, | ||||||
|   its development and things relevant to this. Get all info at |   its development and things relevant to this. Get all info at | ||||||
|   https://curl.haxx.se/mail/. Some of the lists available are: |   http://curl.haxx.se/mail/. Some of the lists available are: | ||||||
|  |  | ||||||
|   curl-users |   curl-users | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -33,22 +33,22 @@ SUBDIRS = examples libcurl | |||||||
|  |  | ||||||
| CLEANFILES = $(GENHTMLPAGES) $(PDFPAGES) | CLEANFILES = $(GENHTMLPAGES) $(PDFPAGES) | ||||||
|  |  | ||||||
| EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS	\ | EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS	 \ | ||||||
|  README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS	\ |  README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS	 \ | ||||||
|  KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL		\ |  KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL		 \ | ||||||
|  $(PDFPAGES) LICENSE-MIXING README.netware INSTALL.devcpp		\ |  $(PDFPAGES) LICENSE-MIXING README.netware DISTRO-DILEMMA INSTALL.devcpp \ | ||||||
|  MAIL-ETIQUETTE HTTP-COOKIES SECURITY RELEASE-PROCEDURE SSL-PROBLEMS	\ |  MAIL-ETIQUETTE HTTP-COOKIES SECURITY RELEASE-PROCEDURE  \ | ||||||
|  HTTP2.md ROADMAP.md CODE_OF_CONDUCT.md |  SSL-PROBLEMS HTTP2.md ROADMAP.md | ||||||
|  |  | ||||||
| MAN2HTML= roffit < $< >$@ | MAN2HTML= roffit < $< >$@ | ||||||
|  |  | ||||||
| SUFFIXES = .1 .html .pdf | SUFFIXES = .1 .html .pdf | ||||||
|  |  | ||||||
| html: $(HTMLPAGES) | html: $(HTMLPAGES) | ||||||
| 	cd libcurl && make html | 	cd libcurl; make html | ||||||
|  |  | ||||||
| pdf: $(PDFPAGES) | pdf: $(PDFPAGES) | ||||||
| 	cd libcurl && make pdf | 	cd libcurl; make pdf | ||||||
|  |  | ||||||
| .1.html: | .1.html: | ||||||
| 	$(MAN2HTML) | 	$(MAN2HTML) | ||||||
|   | |||||||
| @@ -24,8 +24,6 @@ in the source code repo | |||||||
|  |  | ||||||
| - upload the 8 resulting files to the primary download directory | - upload the 8 resulting files to the primary download directory | ||||||
|  |  | ||||||
| - upload the 4 tarballs to github for the HTTPS download |  | ||||||
|  |  | ||||||
| in the curl-www repo | in the curl-www repo | ||||||
| -------------------- | -------------------- | ||||||
|  |  | ||||||
| @@ -80,7 +78,9 @@ Coming dates | |||||||
| Based on the description above, here are some planned release dates (at the | Based on the description above, here are some planned release dates (at the | ||||||
| time of this writing): | time of this writing): | ||||||
|  |  | ||||||
| - October 7, 2015 (version 7.45.0) | - June 17, 2015 (version 7.43.0) | ||||||
|  | - August 12, 2015 | ||||||
|  | - October 7, 2015 | ||||||
| - December 2, 2015 | - December 2, 2015 | ||||||
| - January 27, 2016 | - January 27, 2016 | ||||||
| - March 23, 2016 | - March 23, 2016 | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ This document lists documents and standards used by curl. | |||||||
|  |  | ||||||
|   RFC 2109 - HTTP State Management Mechanism (cookie stuff) |   RFC 2109 - HTTP State Management Mechanism (cookie stuff) | ||||||
|            - Also, read Netscape's specification at |            - Also, read Netscape's specification at | ||||||
|              https://curl.haxx.se/rfc/cookie_spec.html |              http://curl.haxx.se/rfc/cookie_spec.html | ||||||
|  |  | ||||||
|   RFC 2183 - The Content-Disposition Header Field |   RFC 2183 - The Content-Disposition Header Field | ||||||
|  |  | ||||||
|   | |||||||
| @@ -18,11 +18,32 @@ HTTP/2 | |||||||
|    To decide: if we need to bundle parts of the nghttp2 stuff that probably |    To decide: if we need to bundle parts of the nghttp2 stuff that probably | ||||||
|    won't be shipped by many distros. |    won't be shipped by many distros. | ||||||
|  |  | ||||||
|  | - stream properties API | ||||||
|  |  | ||||||
|  |    Provide options for setting priorities and dependencies among the streams | ||||||
|  |    (easy handles). They are mostly information set for the stream and sent to | ||||||
|  |    the server so we don't have to add much logic for this. | ||||||
|  |  | ||||||
|  | - server push | ||||||
|  |  | ||||||
|  |    Not exactly clear exactly how to support this API-wise, but by adding | ||||||
|  |    handles without asking for a resource it could be a way to be prepared to | ||||||
|  |    receive pushes in case such are sent. We probably need it to still specify | ||||||
|  |    a URL with host name, port etc but we probably need a special option to | ||||||
|  |    tell libcurl it is for server push purposes. | ||||||
|  |  | ||||||
| - provide option for HTTP/2 "prior knowledge" over clear text | - provide option for HTTP/2 "prior knowledge" over clear text | ||||||
|  |  | ||||||
|    As it would avoid the roundtrip-heavy Upgrade: procedures when you _know_ |    As it would avoid the roundtrip-heavy Upgrade: procedures when you _know_ | ||||||
|    it speaks HTTP/2. |    it speaks HTTP/2. | ||||||
|  |  | ||||||
|  | - provide option to allow curl to default to HTTP/2 only when using HTTPS | ||||||
|  |  | ||||||
|  |    We could switch on HTTP/2 by-default for HTTPS quite easily and it | ||||||
|  |    shouldn't hurt anyone, while HTTP/2 for HTTP by default could introduce | ||||||
|  |    lots of Upgrade: roundtrips that users won't like. So a separated option | ||||||
|  |    alternative makes sense. | ||||||
|  |  | ||||||
| SRV records | SRV records | ||||||
| ----------- | ----------- | ||||||
|  |  | ||||||
| @@ -96,7 +117,7 @@ Improve | |||||||
|  |  | ||||||
| 2. curl -h output (considered overwhelming to users) | 2. curl -h output (considered overwhelming to users) | ||||||
|  |  | ||||||
| 3. we have > 170 command line options, is there a way to redo things to | 3. we have > 160 command line options, is there a way to redo things to | ||||||
|    simplify or improve the situation as we are likely to keep adding |    simplify or improve the situation as we are likely to keep adding | ||||||
|    features/options in the future too |    features/options in the future too | ||||||
|  |  | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ Publishing Information | |||||||
| ---------------------- | ---------------------- | ||||||
|  |  | ||||||
| All known and public curl or libcurl related vulnerabilities are listed on | All known and public curl or libcurl related vulnerabilities are listed on | ||||||
| [the curl web site security page](https://curl.haxx.se/docs/security.html). | [the curl web site security page](http://curl.haxx.se/docs/security.html). | ||||||
|  |  | ||||||
| Security vulnerabilities should not be entered in the project's public bug | Security vulnerabilities should not be entered in the project's public bug | ||||||
| tracker unless the necessary configuration is in place to limit access to the | tracker unless the necessary configuration is in place to limit access to the | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ CA bundle missing intermediate certificates | |||||||
|   problems if your CA cert does not have the certificates for the |   problems if your CA cert does not have the certificates for the | ||||||
|   intermediates in the whole trust chain. |   intermediates in the whole trust chain. | ||||||
|  |  | ||||||
| Protocol version | SSL version | ||||||
|  |  | ||||||
|   Some broken servers fail to support the protocol negotiation properly that |   Some broken servers fail to support the protocol negotiation properly that | ||||||
|   SSL servers are supposed to handle. This may cause the connection to fail |   SSL servers are supposed to handle. This may cause the connection to fail | ||||||
| @@ -36,9 +36,7 @@ Protocol version | |||||||
|   An additional complication can be that modern SSL libraries sometimes are |   An additional complication can be that modern SSL libraries sometimes are | ||||||
|   built with support for older SSL and TLS versions disabled! |   built with support for older SSL and TLS versions disabled! | ||||||
|  |  | ||||||
|   All versions of SSL are considered insecure and should be avoided. Use TLS. | SSL ciphers | ||||||
|  |  | ||||||
| Ciphers |  | ||||||
|  |  | ||||||
|   Clients give servers a list of ciphers to select from. If the list doesn't |   Clients give servers a list of ciphers to select from. If the list doesn't | ||||||
|   include any ciphers the server wants/can use, the connection handshake |   include any ciphers the server wants/can use, the connection handshake | ||||||
| @@ -53,10 +51,6 @@ Ciphers | |||||||
|   Note that these weak ciphers are identified as flawed. For example, this |   Note that these weak ciphers are identified as flawed. For example, this | ||||||
|   includes symmetric ciphers with less than 128 bit keys and RC4. |   includes symmetric ciphers with less than 128 bit keys and RC4. | ||||||
|  |  | ||||||
|   WinSSL in Windows XP is not able to connect to servers that no longer |  | ||||||
|   support the legacy handshakes and algorithms used by those versions, so we |  | ||||||
|   advice against building curl to use WinSSL on really old Windows versions. |  | ||||||
|  |  | ||||||
|   References: |   References: | ||||||
|  |  | ||||||
|   https://tools.ietf.org/html/draft-popov-tls-prohibiting-rc4-01 |   https://tools.ietf.org/html/draft-popov-tls-prohibiting-rc4-01 | ||||||
| @@ -71,17 +65,3 @@ Allow BEAST | |||||||
|   introduced. Exactly as it sounds, it re-introduces the BEAST vulnerability |   introduced. Exactly as it sounds, it re-introduces the BEAST vulnerability | ||||||
|   but on the other hand it allows curl to connect to that kind of strange |   but on the other hand it allows curl to connect to that kind of strange | ||||||
|   servers. |   servers. | ||||||
|  |  | ||||||
| Disabling certificate revocation checks |  | ||||||
|  |  | ||||||
|   Some SSL backends may do certificate revocation checks (CRL, OCSP, etc) |  | ||||||
|   depending on the OS or build configuration. The --ssl-no-revoke option was |  | ||||||
|   introduced in 7.44.0 to disable revocation checking but currently is only |  | ||||||
|   supported for WinSSL (the native Windows SSL library), with an exception in |  | ||||||
|   the case of Windows' Untrusted Publishers blacklist which it seems can't be |  | ||||||
|   bypassed. This option may have broader support to accommodate other SSL |  | ||||||
|   backends in the future. |  | ||||||
|  |  | ||||||
|   References: |  | ||||||
|  |  | ||||||
|   https://curl.haxx.se/docs/ssl-compared.html |  | ||||||
|   | |||||||
| @@ -109,7 +109,7 @@ server, do one of the following: | |||||||
|  5. Get a better/different/newer CA cert bundle! One option is to extract the |  5. Get a better/different/newer CA cert bundle! One option is to extract the | ||||||
|     one a recent Firefox browser uses by running 'make ca-bundle' in the curl |     one a recent Firefox browser uses by running 'make ca-bundle' in the curl | ||||||
|     build tree root, or possibly download a version that was generated this |     build tree root, or possibly download a version that was generated this | ||||||
|     way for you: [CA Extract](https://curl.haxx.se/docs/caextract.html) |     way for you: [CA Extract](http://curl.haxx.se/docs/caextract.html) | ||||||
|  |  | ||||||
| Neglecting to use one of the above methods when dealing with a server using a | Neglecting to use one of the above methods when dealing with a server using a | ||||||
| certificate that isn't signed by one of the certificates in the installed CA | certificate that isn't signed by one of the certificates in the installed CA | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										59
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -131,14 +131,12 @@ Benbuck Nason | |||||||
| Benjamin Gerard | Benjamin Gerard | ||||||
| Benjamin Gilbert | Benjamin Gilbert | ||||||
| Benjamin Johnson | Benjamin Johnson | ||||||
| Benjamin Kircher |  | ||||||
| Benoit Neil | Benoit Neil | ||||||
| Benoit Sigoure | Benoit Sigoure | ||||||
| Bernard Leak | Bernard Leak | ||||||
| Bernhard Reutner-Fischer | Bernhard Reutner-Fischer | ||||||
| Bert Huijben | Bert Huijben | ||||||
| Bertrand Demiddelaer | Bertrand Demiddelaer | ||||||
| Bertrand Simonnet |  | ||||||
| Bill Doyle | Bill Doyle | ||||||
| Bill Egert | Bill Egert | ||||||
| Bill Hoffman | Bill Hoffman | ||||||
| @@ -207,7 +205,6 @@ Christian Krause | |||||||
| Christian Kurz | Christian Kurz | ||||||
| Christian Robottom Reis | Christian Robottom Reis | ||||||
| Christian Schmitz | Christian Schmitz | ||||||
| Christian Stewart |  | ||||||
| Christian Vogt | Christian Vogt | ||||||
| Christian Weisgerber | Christian Weisgerber | ||||||
| Christophe Demory | Christophe Demory | ||||||
| @@ -237,7 +234,6 @@ Cris Bailiff | |||||||
| Cristian Rodríguez | Cristian Rodríguez | ||||||
| Curt Bogmine | Curt Bogmine | ||||||
| Cyrill Osterwalder | Cyrill Osterwalder | ||||||
| Cédric Connes |  | ||||||
| Cédric Deltheil | Cédric Deltheil | ||||||
| D. Flinkmann | D. Flinkmann | ||||||
| Da-Yoon Chung | Da-Yoon Chung | ||||||
| @@ -256,15 +252,9 @@ Dan Zitter | |||||||
| Daniel Black | Daniel Black | ||||||
| Daniel Cater | Daniel Cater | ||||||
| Daniel Egger | Daniel Egger | ||||||
| Daniel Hwang |  | ||||||
| Daniel Johnson | Daniel Johnson | ||||||
| Daniel Kahn Gillmor |  | ||||||
| Daniel Lee Hwang |  | ||||||
| Daniel Melani | Daniel Melani | ||||||
| Daniel Mentz | Daniel Mentz | ||||||
| Daniel Schauenberg |  | ||||||
| Daniel Seither |  | ||||||
| Daniel Shahaf |  | ||||||
| Daniel Steinberg | Daniel Steinberg | ||||||
| Daniel Stenberg | Daniel Stenberg | ||||||
| Daniel Theron | Daniel Theron | ||||||
| @@ -278,7 +268,6 @@ Dave May | |||||||
| Dave Reisner | Dave Reisner | ||||||
| Dave Thompson | Dave Thompson | ||||||
| Dave Vasilevsky | Dave Vasilevsky | ||||||
| Davey Shafik |  | ||||||
| David Bau | David Bau | ||||||
| David Binderman | David Binderman | ||||||
| David Blaikie | David Blaikie | ||||||
| @@ -308,7 +297,6 @@ David Woodhouse | |||||||
| David Wright | David Wright | ||||||
| David Yan | David Yan | ||||||
| Dengminwen | Dengminwen | ||||||
| Denis Feklushkin |  | ||||||
| Dennis Clarke | Dennis Clarke | ||||||
| Derek Higgins | Derek Higgins | ||||||
| Detlef Schmier | Detlef Schmier | ||||||
| @@ -332,14 +320,12 @@ Dmitry Falko | |||||||
| Dmitry Kurochkin | Dmitry Kurochkin | ||||||
| Dmitry Popov | Dmitry Popov | ||||||
| Dmitry Rechkin | Dmitry Rechkin | ||||||
| Dmitry S. Baikov |  | ||||||
| Dolbneff A.V | Dolbneff A.V | ||||||
| Domenico Andreoli | Domenico Andreoli | ||||||
| Dominick Meglio | Dominick Meglio | ||||||
| Dominique Leuenberger | Dominique Leuenberger | ||||||
| Doug Kaufman | Doug Kaufman | ||||||
| Doug Porter | Doug Porter | ||||||
| Douglas Creager |  | ||||||
| Douglas E. Wegscheid | Douglas E. Wegscheid | ||||||
| Douglas Kilpatrick | Douglas Kilpatrick | ||||||
| Douglas R. Horner | Douglas R. Horner | ||||||
| @@ -378,14 +364,12 @@ Eric Lubin | |||||||
| Eric Melville | Eric Melville | ||||||
| Eric Mertens | Eric Mertens | ||||||
| Eric Rautman | Eric Rautman | ||||||
| Eric Ridge |  | ||||||
| Eric S. Raymond | Eric S. Raymond | ||||||
| Eric Thelin | Eric Thelin | ||||||
| Eric Vergnaud | Eric Vergnaud | ||||||
| Eric Wong | Eric Wong | ||||||
| Eric Young | Eric Young | ||||||
| Erick Nuwendam | Erick Nuwendam | ||||||
| Erik Janssen |  | ||||||
| Erik Johansson | Erik Johansson | ||||||
| Ernest Beinrohr | Ernest Beinrohr | ||||||
| Erwan Legrand | Erwan Legrand | ||||||
| @@ -400,15 +384,12 @@ Fabian Hiernaux | |||||||
| Fabian Keil | Fabian Keil | ||||||
| Fabrizio Ammollo | Fabrizio Ammollo | ||||||
| Fedor Karpelevitch | Fedor Karpelevitch | ||||||
| Feist Josselin |  | ||||||
| Felix Yan | Felix Yan | ||||||
| Felix von Leitner | Felix von Leitner | ||||||
| Feng Tu | Feng Tu | ||||||
| Flavio Medeiros |  | ||||||
| Florian Schoppmann | Florian Schoppmann | ||||||
| Florian Weimer | Florian Weimer | ||||||
| Forrest Cahoon | Forrest Cahoon | ||||||
| Francisco Moraes |  | ||||||
| Frank Gevaerts | Frank Gevaerts | ||||||
| Frank Hempel | Frank Hempel | ||||||
| Frank Keeney | Frank Keeney | ||||||
| @@ -472,7 +453,6 @@ Guido Berhoerster | |||||||
| Guillaume Arluison | Guillaume Arluison | ||||||
| Gunter Knauf | Gunter Knauf | ||||||
| Gustaf Hui | Gustaf Hui | ||||||
| Gustavo Grieco |  | ||||||
| Gwenole Beauchesne | Gwenole Beauchesne | ||||||
| Gökhan Şengün | Gökhan Şengün | ||||||
| Götz Babin-Ebell | Götz Babin-Ebell | ||||||
| @@ -517,7 +497,6 @@ Iida Yosiaki | |||||||
| Ilguiz Latypov | Ilguiz Latypov | ||||||
| Ilja van Sprundel | Ilja van Sprundel | ||||||
| Immanuel Gregoire | Immanuel Gregoire | ||||||
| Inca R |  | ||||||
| Ingmar Runge | Ingmar Runge | ||||||
| Ingo Ralf Blum | Ingo Ralf Blum | ||||||
| Ingo Wilken | Ingo Wilken | ||||||
| @@ -528,7 +507,6 @@ Jack Zhang | |||||||
| Jacky Lam | Jacky Lam | ||||||
| Jacob Meuser | Jacob Meuser | ||||||
| Jacob Moshenko | Jacob Moshenko | ||||||
| Jactry Zeng |  | ||||||
| Jad Chamcham | Jad Chamcham | ||||||
| Jakub Zakrzewski | Jakub Zakrzewski | ||||||
| James Bursa | James Bursa | ||||||
| @@ -557,7 +535,6 @@ Jason Liu | |||||||
| Jason McDonald | Jason McDonald | ||||||
| Jason S. Priebe | Jason S. Priebe | ||||||
| Javier Barroso | Javier Barroso | ||||||
| Javier G. Sogo |  | ||||||
| Jay Austin | Jay Austin | ||||||
| Jayesh A Shah | Jayesh A Shah | ||||||
| Jaz Fresh | Jaz Fresh | ||||||
| @@ -613,7 +590,6 @@ Johan Nilsson | |||||||
| Johan van Selst | Johan van Selst | ||||||
| Johannes Bauer | Johannes Bauer | ||||||
| Johannes Ernst | Johannes Ernst | ||||||
| Johannes Schindelin |  | ||||||
| John Bradshaw | John Bradshaw | ||||||
| John Coffey | John Coffey | ||||||
| John Crow | John Crow | ||||||
| @@ -624,9 +600,7 @@ John Gardiner Myers | |||||||
| John Janssen | John Janssen | ||||||
| John Joseph Bachir | John Joseph Bachir | ||||||
| John Kelly | John Kelly | ||||||
| John Kohl |  | ||||||
| John Lask | John Lask | ||||||
| John Levon |  | ||||||
| John Lightsey | John Lightsey | ||||||
| John Marino | John Marino | ||||||
| John Marshall | John Marshall | ||||||
| @@ -645,7 +619,6 @@ Jon Torrey | |||||||
| Jon Travis | Jon Travis | ||||||
| Jon Turner | Jon Turner | ||||||
| Jonas Forsman | Jonas Forsman | ||||||
| Jonas Minnberg |  | ||||||
| Jonas Schnelli | Jonas Schnelli | ||||||
| Jonatan Lander | Jonatan Lander | ||||||
| Jonatan Vela | Jonatan Vela | ||||||
| @@ -674,7 +647,6 @@ Julien Nabet | |||||||
| Julien Royer | Julien Royer | ||||||
| Jun-ichiro itojun Hagino | Jun-ichiro itojun Hagino | ||||||
| Jurij Smakov | Jurij Smakov | ||||||
| Justin Ehlert |  | ||||||
| Justin Fletcher | Justin Fletcher | ||||||
| Justin Karneges | Justin Karneges | ||||||
| Justin Maggard | Justin Maggard | ||||||
| @@ -686,7 +658,6 @@ Kai Sommerfeld | |||||||
| Kai-Uwe Rommel | Kai-Uwe Rommel | ||||||
| Kalle Vahlman | Kalle Vahlman | ||||||
| Kamil Dudka | Kamil Dudka | ||||||
| Kang Lin |  | ||||||
| Kang-Jin Lee | Kang-Jin Lee | ||||||
| Karl Moerder | Karl Moerder | ||||||
| Karol Pietrzak | Karol Pietrzak | ||||||
| @@ -718,7 +689,6 @@ Krishnendu Majumdar | |||||||
| Krister Johansen | Krister Johansen | ||||||
| Kristian Gunstone | Kristian Gunstone | ||||||
| Kristian Köhntopp | Kristian Köhntopp | ||||||
| Kurt Fankhauser |  | ||||||
| Kyle J. McKay | Kyle J. McKay | ||||||
| Kyle L. Huff | Kyle L. Huff | ||||||
| Kyle Sallee | Kyle Sallee | ||||||
| @@ -735,7 +705,6 @@ Lars Nilsson | |||||||
| Lars Torben Wilson | Lars Torben Wilson | ||||||
| Lau Hang Kin | Lau Hang Kin | ||||||
| Laurent Rabret | Laurent Rabret | ||||||
| Lauri Kasanen |  | ||||||
| Legoff Vincent | Legoff Vincent | ||||||
| Lehel Bernadt | Lehel Bernadt | ||||||
| Leif W | Leif W | ||||||
| @@ -751,7 +720,6 @@ Linas Vepstas | |||||||
| Lindley French | Lindley French | ||||||
| Ling Thio | Ling Thio | ||||||
| Linus Nielsen Feltzing | Linus Nielsen Feltzing | ||||||
| Lior Kaplan |  | ||||||
| Lisa Xu | Lisa Xu | ||||||
| Liviu Chircu | Liviu Chircu | ||||||
| Liza Alenchery | Liza Alenchery | ||||||
| @@ -764,7 +732,6 @@ Lucas Adamski | |||||||
| Lucas Pardue | Lucas Pardue | ||||||
| Ludek Finstrle | Ludek Finstrle | ||||||
| Ludovico Cavedon | Ludovico Cavedon | ||||||
| Lukas Ruzicka |  | ||||||
| Lukasz Czekierda | Lukasz Czekierda | ||||||
| Luke Amery | Luke Amery | ||||||
| Luke Call | Luke Call | ||||||
| @@ -775,7 +742,6 @@ Maciej Karpiuk | |||||||
| Maciej Puzio | Maciej Puzio | ||||||
| Maciej W. Rozycki | Maciej W. Rozycki | ||||||
| Maks Naumov | Maks Naumov | ||||||
| Maksim Stsepanenka |  | ||||||
| Mamoru Tasaka | Mamoru Tasaka | ||||||
| Mandy Wu | Mandy Wu | ||||||
| Manfred Schwarb | Manfred Schwarb | ||||||
| @@ -859,7 +825,6 @@ Michael Day | |||||||
| Michael Goffioul | Michael Goffioul | ||||||
| Michael Jahn | Michael Jahn | ||||||
| Michael Jerris | Michael Jerris | ||||||
| Michael Kalinin |  | ||||||
| Michael Kaufmann | Michael Kaufmann | ||||||
| Michael Mealling | Michael Mealling | ||||||
| Michael Mueller | Michael Mueller | ||||||
| @@ -870,10 +835,8 @@ Michael Stillwell | |||||||
| Michael Wallner | Michael Wallner | ||||||
| Michal Bonino | Michal Bonino | ||||||
| Michal Marek | Michal Marek | ||||||
| Michał Fita |  | ||||||
| Michał Górny | Michał Górny | ||||||
| Michał Kowalczyk | Michał Kowalczyk | ||||||
| Michał Piechowski |  | ||||||
| Michel Promonet | Michel Promonet | ||||||
| Michele Bini | Michele Bini | ||||||
| Miguel Angel | Miguel Angel | ||||||
| @@ -905,7 +868,6 @@ Nagai H | |||||||
| Nathan Coulter | Nathan Coulter | ||||||
| Nathan O'Sullivan | Nathan O'Sullivan | ||||||
| Nathanael Nerode | Nathanael Nerode | ||||||
| Nathaniel Waisbrot |  | ||||||
| Naveen Chandran | Naveen Chandran | ||||||
| Naveen Noel | Naveen Noel | ||||||
| Neil Bowers | Neil Bowers | ||||||
| @@ -932,7 +894,6 @@ Nis Jorgensen | |||||||
| Nobuhiro Ban | Nobuhiro Ban | ||||||
| Nodak Sodak | Nodak Sodak | ||||||
| Norbert Frese | Norbert Frese | ||||||
| Norbert Kett |  | ||||||
| Norbert Novotny | Norbert Novotny | ||||||
| Ofer | Ofer | ||||||
| Ola Mork | Ola Mork | ||||||
| @@ -942,7 +903,6 @@ Oliver Gondža | |||||||
| Oliver Kuckertz | Oliver Kuckertz | ||||||
| Oliver Schindler | Oliver Schindler | ||||||
| Olivier Berger | Olivier Berger | ||||||
| Orange Tsai |  | ||||||
| Oren Souroujon | Oren Souroujon | ||||||
| Oren Tirosh | Oren Tirosh | ||||||
| Orgad Shaneh | Orgad Shaneh | ||||||
| @@ -1038,7 +998,6 @@ Rainer Canavan | |||||||
| Rainer Jung | Rainer Jung | ||||||
| Rainer Koenig | Rainer Koenig | ||||||
| Rajesh Naganathan | Rajesh Naganathan | ||||||
| Rajkumar Mandal |  | ||||||
| Ralf S. Engelschall | Ralf S. Engelschall | ||||||
| Ralph Beckmann | Ralph Beckmann | ||||||
| Ralph Mitchell | Ralph Mitchell | ||||||
| @@ -1048,7 +1007,6 @@ Ravi Pratap | |||||||
| Ray Dassen | Ray Dassen | ||||||
| Ray Pekowski | Ray Pekowski | ||||||
| Ray Satiro | Ray Satiro | ||||||
| Razvan Cojocaru |  | ||||||
| Reinout van Schouwen | Reinout van Schouwen | ||||||
| Remi Gacogne | Remi Gacogne | ||||||
| Renato Botelho | Renato Botelho | ||||||
| @@ -1069,12 +1027,10 @@ Richard Bramante | |||||||
| Richard Clayton | Richard Clayton | ||||||
| Richard Cooper | Richard Cooper | ||||||
| Richard Gorton | Richard Gorton | ||||||
| Richard Hosking |  | ||||||
| Richard Michael | Richard Michael | ||||||
| Richard Moore | Richard Moore | ||||||
| Richard Prescott | Richard Prescott | ||||||
| Richard Silverman | Richard Silverman | ||||||
| Richard van den Berg |  | ||||||
| Rick Jones | Rick Jones | ||||||
| Rick Richardson | Rick Richardson | ||||||
| Rob Crittenden | Rob Crittenden | ||||||
| @@ -1098,7 +1054,6 @@ Robson Braga Araujo | |||||||
| Rodney Simmons | Rodney Simmons | ||||||
| Rodric Glaser | Rodric Glaser | ||||||
| Rodrigo Silva | Rodrigo Silva | ||||||
| Roger Leigh |  | ||||||
| Roland Blom | Roland Blom | ||||||
| Roland Krikava | Roland Krikava | ||||||
| Roland Zimmermann | Roland Zimmermann | ||||||
| @@ -1123,7 +1078,6 @@ Salvador Dávila | |||||||
| Salvatore Sorrentino | Salvatore Sorrentino | ||||||
| Sam Deane | Sam Deane | ||||||
| Sam Hurst | Sam Hurst | ||||||
| Sam Roth |  | ||||||
| Sam Schanken | Sam Schanken | ||||||
| Sampo Kellomaki | Sampo Kellomaki | ||||||
| Samuel Díaz García | Samuel Díaz García | ||||||
| @@ -1143,7 +1097,6 @@ Scott Cantor | |||||||
| Scott Davis | Scott Davis | ||||||
| Scott McCreary | Scott McCreary | ||||||
| Sean Boudreau | Sean Boudreau | ||||||
| Sebastian Pohlschmidt |  | ||||||
| Sebastian Rasmussen | Sebastian Rasmussen | ||||||
| Senthil Raja Velu | Senthil Raja Velu | ||||||
| Sergei Nikulov | Sergei Nikulov | ||||||
| @@ -1204,20 +1157,16 @@ Sune Ahlgren | |||||||
| Sven Anders | Sven Anders | ||||||
| Sven Neuhaus | Sven Neuhaus | ||||||
| Sven Wegener | Sven Wegener | ||||||
| Svyatoslav Mishyn |  | ||||||
| Symeon Paraschoudis | Symeon Paraschoudis | ||||||
| Sébastien Willemijns | Sébastien Willemijns | ||||||
| T. Bharath | T. Bharath | ||||||
| T. Yamada | T. Yamada | ||||||
| TJ Saunders |  | ||||||
| Tae Hyoung Ahn | Tae Hyoung Ahn | ||||||
| Taneli Vahakangas | Taneli Vahakangas | ||||||
| Tanguy Fautre | Tanguy Fautre | ||||||
| Tatsuhiro Tsujikawa | Tatsuhiro Tsujikawa | ||||||
| Temprimus | Temprimus | ||||||
| Terri Oda |  | ||||||
| Thomas Braun | Thomas Braun | ||||||
| Thomas Glanzmann |  | ||||||
| Thomas J. Moore | Thomas J. Moore | ||||||
| Thomas Klausner | Thomas Klausner | ||||||
| Thomas L. Shinnick | Thomas L. Shinnick | ||||||
| @@ -1225,7 +1174,6 @@ Thomas Lopatic | |||||||
| Thomas Ruecker | Thomas Ruecker | ||||||
| Thomas Schwinge | Thomas Schwinge | ||||||
| Thomas Tonino | Thomas Tonino | ||||||
| Thorsten Schöning |  | ||||||
| Tiit Pikma | Tiit Pikma | ||||||
| Till Maas | Till Maas | ||||||
| Tim Ansell | Tim Ansell | ||||||
| @@ -1236,9 +1184,8 @@ Tim Costello | |||||||
| Tim Harder | Tim Harder | ||||||
| Tim Heckman | Tim Heckman | ||||||
| Tim Newsome | Tim Newsome | ||||||
| Tim Rühsen | Tim Ruehsen | ||||||
| Tim Sneddon | Tim Sneddon | ||||||
| Tim Stack |  | ||||||
| Tim Starling | Tim Starling | ||||||
| Timo Sirainen | Timo Sirainen | ||||||
| Tinus van den Berg | Tinus van den Berg | ||||||
| @@ -1248,6 +1195,7 @@ Tobias Stoeckmann | |||||||
| Toby Peterson | Toby Peterson | ||||||
| Todd A Ouska | Todd A Ouska | ||||||
| Todd Kulesza | Todd Kulesza | ||||||
|  | Todd Ouska | ||||||
| Todd Vierling | Todd Vierling | ||||||
| Tom Benoist | Tom Benoist | ||||||
| Tom Donovan | Tom Donovan | ||||||
| @@ -1307,7 +1255,6 @@ Vojtech Janota | |||||||
| Vojtech Minarik | Vojtech Minarik | ||||||
| Vojtěch Král | Vojtěch Král | ||||||
| Vsevolod Novikov | Vsevolod Novikov | ||||||
| W. Mark Kubacki |  | ||||||
| Waldek Kozba | Waldek Kozba | ||||||
| Walter J. Mack | Walter J. Mack | ||||||
| Ward Willats | Ward Willats | ||||||
| @@ -1325,7 +1272,6 @@ Wojciech Zwiefka | |||||||
| Wouter Van Rooy | Wouter Van Rooy | ||||||
| Wu Yongzheng | Wu Yongzheng | ||||||
| Xavier Bouchoux | Xavier Bouchoux | ||||||
| Xiangbin Li |  | ||||||
| Yaakov Selkowitz | Yaakov Selkowitz | ||||||
| Yamada Yasuharu | Yamada Yasuharu | ||||||
| Yang Tse | Yang Tse | ||||||
| @@ -1348,5 +1294,4 @@ Zvi Har'El | |||||||
| nk | nk | ||||||
| swalkaus at yahoo.com | swalkaus at yahoo.com | ||||||
| tommink[at]post.pl | tommink[at]post.pl | ||||||
| Štefan Kremeň |  | ||||||
| Никита Дорохин | Никита Дорохин | ||||||
|   | |||||||
| @@ -50,5 +50,3 @@ s/Jiří Hruška/Jiri Hruska/ | |||||||
| s/Viktor Szakats/Viktor Szakáts/ | s/Viktor Szakats/Viktor Szakáts/ | ||||||
| s/Jonathan Cardoso/Jonathan Cardoso Machado/ | s/Jonathan Cardoso/Jonathan Cardoso Machado/ | ||||||
| s/Linus Nielsen/Linus Nielsen Feltzing/ | s/Linus Nielsen/Linus Nielsen Feltzing/ | ||||||
| s/Todd Ouska$/Todd A Ouska/ |  | ||||||
| s/Tim Ruehsen/Tim Rühsen/ |  | ||||||
|   | |||||||
							
								
								
									
										195
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										195
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -26,18 +26,11 @@ | |||||||
|  1.8 Allow SSL (HTTPS) to proxy |  1.8 Allow SSL (HTTPS) to proxy | ||||||
|  1.9 Cache negative name resolves |  1.9 Cache negative name resolves | ||||||
|  1.10 Support IDNA2008 |  1.10 Support IDNA2008 | ||||||
|  1.11 minimize dependencies with dynamicly loaded modules |  | ||||||
|  1.12 have form functions use CURL handle argument |  | ||||||
|  1.13 Add CURLOPT_MAIL_CLIENT option |  | ||||||
|  1.14 Typesafe curl_easy_setopt() |  | ||||||
|  1.15 TCP Fast Open |  | ||||||
|  1.16 Try to URL encode given URL |  | ||||||
|  |  | ||||||
|  2. libcurl - multi interface |  2. libcurl - multi interface | ||||||
|  2.1 More non-blocking |  2.1 More non-blocking | ||||||
|  2.2 Better support for same name resolves |  2.2 Fix HTTP Pipelining for PUT | ||||||
|  2.3 Non-blocking curl_multi_remove_handle() |  2.3 Better support for same name resolves | ||||||
|  2.4 Split connect and authentication process |  | ||||||
|  |  | ||||||
|  3. Documentation |  3. Documentation | ||||||
|  3.1 Update date and version in man pages |  3.1 Update date and version in man pages | ||||||
| @@ -58,7 +51,6 @@ | |||||||
|  5.4 SPDY |  5.4 SPDY | ||||||
|  5.5 auth= in URLs |  5.5 auth= in URLs | ||||||
|  5.6 Refuse "downgrade" redirects |  5.6 Refuse "downgrade" redirects | ||||||
|  5.7 More compressions |  | ||||||
|  |  | ||||||
|  6. TELNET |  6. TELNET | ||||||
|  6.1 ditch stdin |  6.1 ditch stdin | ||||||
| @@ -84,7 +76,6 @@ | |||||||
|  11.1 File listing support |  11.1 File listing support | ||||||
|  11.2 Honor file timestamps |  11.2 Honor file timestamps | ||||||
|  11.3 Use NTLMv2 |  11.3 Use NTLMv2 | ||||||
|  11.4 Create remote directories |  | ||||||
|   |   | ||||||
|  12. New protocols |  12. New protocols | ||||||
|  12.1 RSYNC |  12.1 RSYNC | ||||||
| @@ -122,8 +113,6 @@ | |||||||
|  17.7 warning when sending binary output to terminal |  17.7 warning when sending binary output to terminal | ||||||
|  17.8 offer color-coded HTTP header output |  17.8 offer color-coded HTTP header output | ||||||
|  17.9 Choose the name of file in braces for complex URLs |  17.9 Choose the name of file in braces for complex URLs | ||||||
|  17.10 improve how curl works in a windows console window |  | ||||||
|  17.11 -w output to stderr |  | ||||||
|  |  | ||||||
|  18. Build |  18. Build | ||||||
|  18.1 roffit |  18.1 roffit | ||||||
| @@ -149,6 +138,8 @@ | |||||||
|  21.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE |  21.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE | ||||||
|  21.7 remove progress meter from libcurl |  21.7 remove progress meter from libcurl | ||||||
|  21.8 remove 'curl_httppost' from public |  21.8 remove 'curl_httppost' from public | ||||||
|  |  21.9 have form functions use CURL handle argument | ||||||
|  |  21.10 Add CURLOPT_MAIL_CLIENT option | ||||||
|  |  | ||||||
| ============================================================================== | ============================================================================== | ||||||
|  |  | ||||||
| @@ -173,7 +164,7 @@ | |||||||
|  signal handler back into the library with a sigsetjmp, which effectively |  signal handler back into the library with a sigsetjmp, which effectively | ||||||
|  causes libcurl to continue running within the signal handler. This is |  causes libcurl to continue running within the signal handler. This is | ||||||
|  non-portable and could cause problems on some platforms. A discussion on the |  non-portable and could cause problems on some platforms. A discussion on the | ||||||
|  problem is available at https://curl.haxx.se/mail/lib-2008-09/0197.html |  problem is available at http://curl.haxx.se/mail/lib-2008-09/0197.html | ||||||
|  |  | ||||||
|  Also, alarm() provides timeout resolution only to the nearest second. alarm |  Also, alarm() provides timeout resolution only to the nearest second. alarm | ||||||
|  ought to be replaced by setitimer on systems that support it. |  ought to be replaced by setitimer on systems that support it. | ||||||
| @@ -234,66 +225,6 @@ | |||||||
|  by libidn. libidn implements IDNA2003 which has been superseded by IDNA2008. |  by libidn. libidn implements IDNA2003 which has been superseded by IDNA2008. | ||||||
|  libidn2 is an existing library offering support for IDNA2008. |  libidn2 is an existing library offering support for IDNA2008. | ||||||
|  |  | ||||||
| 1.11 minimize dependencies with dynamicly loaded modules |  | ||||||
|  |  | ||||||
|  We can create a system with loadable modules/plug-ins, where these modules |  | ||||||
|  would be the ones that link to 3rd party libs. That would allow us to avoid |  | ||||||
|  having to load ALL dependencies since only the necessary ones for this |  | ||||||
|  app/invoke/used protocols would be necessary to load.  See |  | ||||||
|  https://github.com/curl/curl/issues/349 |  | ||||||
|  |  | ||||||
| 1.12 have form functions use CURL handle argument |  | ||||||
|  |  | ||||||
|  curl_formadd() and curl_formget() both currently have no CURL handle |  | ||||||
|  argument, but both can use a callback that is set in the easy handle, and |  | ||||||
|  thus curl_formget() with callback cannot function without first having |  | ||||||
|  curl_easy_perform() (or similar) called - which is hard to grasp and a design |  | ||||||
|  mistake. |  | ||||||
|  |  | ||||||
|  The curl_formadd() design can probably also be reconsidered to make it easier |  | ||||||
|  to use and less error-prone. Probably easiest by splitting it into several |  | ||||||
|  function calls. |  | ||||||
|  |  | ||||||
| 1.13 Add CURLOPT_MAIL_CLIENT option |  | ||||||
|  |  | ||||||
|  Rather than use the URL to specify the mail client string to present in the |  | ||||||
|  HELO and EHLO commands, libcurl should support a new CURLOPT specifically for |  | ||||||
|  specifying this data as the URL is non-standard and to be honest a bit of a |  | ||||||
|  hack ;-) |  | ||||||
|  |  | ||||||
|  Please see the following thread for more information: |  | ||||||
|  https://curl.haxx.se/mail/lib-2012-05/0178.html |  | ||||||
|  |  | ||||||
| 1.14 Typesafe curl_easy_setopt() |  | ||||||
|  |  | ||||||
|  One of the most common problems in libcurl using applications is the lack of |  | ||||||
|  type checks for curl_easy_setopt() which happens because it accepts varargs |  | ||||||
|  and thus can take any type. |  | ||||||
|  |  | ||||||
|  One possible solution to this is to introduce a few different versions of the |  | ||||||
|  setopt version for the different kinds of data you can set. |  | ||||||
|  |  | ||||||
|   curl_easy_set_num() - sets a long value |  | ||||||
|  |  | ||||||
|   curl_easy_set_large() - sets a curl_off_t value |  | ||||||
|  |  | ||||||
|   curl_easy_set_ptr() - sets a pointer |  | ||||||
|  |  | ||||||
|   curl_easy_set_cb() - sets a callback PLUS its callback data |  | ||||||
|  |  | ||||||
| 1.15 TCP Fast Open |  | ||||||
|  |  | ||||||
|  RFC 7413 defines how to include data already in the TCP SYN handshake to |  | ||||||
|  reduce latency. |  | ||||||
|  |  | ||||||
| 1.16 Try to URL encode given URL |  | ||||||
|  |  | ||||||
|  Given a URL that for example contains spaces, libcurl could have an option |  | ||||||
|  that would try somewhat harder than it does now and convert spaces to %20 and |  | ||||||
|  perhaps URL encoded byte values over 128 etc (basically do what the redirect |  | ||||||
|  following code already does). |  | ||||||
|  |  | ||||||
|  https://github.com/curl/curl/issues/514 |  | ||||||
|  |  | ||||||
| 2. libcurl - multi interface | 2. libcurl - multi interface | ||||||
|  |  | ||||||
| @@ -311,7 +242,13 @@ | |||||||
|  - The "DONE" operation (post transfer protocol-specific actions) for the |  - The "DONE" operation (post transfer protocol-specific actions) for the | ||||||
|    protocols SFTP, SMTP, FTP. Fixing Curl_done() for this is a worthy task. |    protocols SFTP, SMTP, FTP. Fixing Curl_done() for this is a worthy task. | ||||||
|  |  | ||||||
| 2.2 Better support for same name resolves | 2.2 Fix HTTP Pipelining for PUT | ||||||
|  |  | ||||||
|  |  HTTP Pipelining can be a way to greatly enhance performance for multiple | ||||||
|  |  serial requests and currently libcurl only supports that for HEAD and GET | ||||||
|  |  requests but it should also be possible for PUT. | ||||||
|  |  | ||||||
|  | 2.3 Better support for same name resolves | ||||||
|  |  | ||||||
|  If a name resolve has been initiated for name NN and a second easy handle |  If a name resolve has been initiated for name NN and a second easy handle | ||||||
|  wants to resolve that name as well, make it wait for the first resolve to end |  wants to resolve that name as well, make it wait for the first resolve to end | ||||||
| @@ -319,20 +256,6 @@ | |||||||
|  especially needed when adding many simultaneous handles using the same host |  especially needed when adding many simultaneous handles using the same host | ||||||
|  name when the DNS resolver can get flooded. |  name when the DNS resolver can get flooded. | ||||||
|  |  | ||||||
| 2.3 Non-blocking curl_multi_remove_handle() |  | ||||||
|  |  | ||||||
|  The multi interface has a few API calls that assume a blocking behavior, like |  | ||||||
|  add_handle() and remove_handle() which limits what we can do internally. The |  | ||||||
|  multi API need to be moved even more into a single function that "drives" |  | ||||||
|  everything in a non-blocking manner and signals when something is done. A |  | ||||||
|  remove or add would then only ask for the action to get started and then |  | ||||||
|  multi_perform() etc still be called until the add/remove is completed. |  | ||||||
|  |  | ||||||
| 2.4 Split connect and authentication process |  | ||||||
|  |  | ||||||
|  The multi interface treats the authentication process as part of the connect |  | ||||||
|  phase. As such any failures during authentication won't trigger the relevant |  | ||||||
|  QUIT or LOGOFF for protocols such as IMAP, POP3 and SMTP. |  | ||||||
|  |  | ||||||
| 3. Documentation | 3. Documentation | ||||||
|  |  | ||||||
| @@ -356,7 +279,7 @@ | |||||||
|  When trying to connect passively to a server which only supports active |  When trying to connect passively to a server which only supports active | ||||||
|  connections, libcurl returns CURLE_FTP_WEIRD_PASV_REPLY and closes the |  connections, libcurl returns CURLE_FTP_WEIRD_PASV_REPLY and closes the | ||||||
|  connection. There could be a way to fallback to an active connection (and |  connection. There could be a way to fallback to an active connection (and | ||||||
|  vice versa). https://curl.haxx.se/bug/feature.cgi?id=1754793 |  vice versa). http://curl.haxx.se/bug/feature.cgi?id=1754793 | ||||||
|  |  | ||||||
| 4.3 Earlier bad letter detection | 4.3 Earlier bad letter detection | ||||||
|  |  | ||||||
| @@ -393,13 +316,13 @@ This is not detailed in any FTP specification. | |||||||
| 5.1 Better persistency for HTTP 1.0 | 5.1 Better persistency for HTTP 1.0 | ||||||
|  |  | ||||||
|  "Better" support for persistent connections over HTTP 1.0 |  "Better" support for persistent connections over HTTP 1.0 | ||||||
|  https://curl.haxx.se/bug/feature.cgi?id=1089001 |  http://curl.haxx.se/bug/feature.cgi?id=1089001 | ||||||
|  |  | ||||||
| 5.2 support FF3 sqlite cookie files | 5.2 support FF3 sqlite cookie files | ||||||
|  |  | ||||||
|  Firefox 3 is changing from its former format to a a sqlite database instead. |  Firefox 3 is changing from its former format to a a sqlite database instead. | ||||||
|  We should consider how (lib)curl can/should support this. |  We should consider how (lib)curl can/should support this. | ||||||
|  https://curl.haxx.se/bug/feature.cgi?id=1871388 |  http://curl.haxx.se/bug/feature.cgi?id=1871388 | ||||||
|  |  | ||||||
| 5.3 Rearrange request header order | 5.3 Rearrange request header order | ||||||
|  |  | ||||||
| @@ -435,19 +358,11 @@ This is not detailed in any FTP specification. | |||||||
|  |  | ||||||
| 5.6 Refuse "downgrade" redirects | 5.6 Refuse "downgrade" redirects | ||||||
|  |  | ||||||
|  See https://github.com/curl/curl/issues/226 |  See https://github.com/bagder/curl/issues/226 | ||||||
|  |  | ||||||
|  Consider a way to tell curl to refuse to "downgrade" protocol with a redirect |  Consider a way to tell curl to refuse to "downgrade" protocol with a redirect | ||||||
|  and/or possibly a bit that refuses redirect to change protocol completely. |  and/or possibly a bit that refuses redirect to change protocol completely. | ||||||
|  |  | ||||||
| 5.7 More compressions |  | ||||||
|  |  | ||||||
|  Compression algorithms that perform better than gzip are being considered for |  | ||||||
|  use and inclusion in existing browsers. For example 'brotli'. If servers |  | ||||||
|  follow along it is a good reason for us to also allow users to take advantage |  | ||||||
|  of this. The algorithm: https://github.com/google/brotli The Firefox bug: |  | ||||||
|  https://bugzilla.mozilla.org/show_bug.cgi?id=366559 |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 6. TELNET | 6. TELNET | ||||||
|  |  | ||||||
| @@ -527,11 +442,6 @@ The timestamp of the transferred file should reflect that of the original file. | |||||||
|  |  | ||||||
| Currently the SMB authentication uses NTLMv1. | Currently the SMB authentication uses NTLMv1. | ||||||
|  |  | ||||||
| 11.4 Create remote directories |  | ||||||
|  |  | ||||||
| Support for creating remote directories when uploading a file to a directory |  | ||||||
| that doesn't exist on the server, just like --ftp-create-dirs. |  | ||||||
|  |  | ||||||
| 12. New protocols | 12. New protocols | ||||||
|  |  | ||||||
| 12.1 RSYNC | 12.1 RSYNC | ||||||
| @@ -544,7 +454,7 @@ that doesn't exist on the server, just like --ftp-create-dirs. | |||||||
| 13.1 Disable specific versions | 13.1 Disable specific versions | ||||||
|  |  | ||||||
|  Provide an option that allows for disabling specific SSL versions, such as |  Provide an option that allows for disabling specific SSL versions, such as | ||||||
|  SSLv2 https://curl.haxx.se/bug/feature.cgi?id=1767276 |  SSLv2 http://curl.haxx.se/bug/feature.cgi?id=1767276 | ||||||
|  |  | ||||||
| 13.2 Provide mutex locking API | 13.2 Provide mutex locking API | ||||||
|  |  | ||||||
| @@ -555,7 +465,7 @@ that doesn't exist on the server, just like --ftp-create-dirs. | |||||||
| 13.3 Evaluate SSL patches | 13.3 Evaluate SSL patches | ||||||
|  |  | ||||||
|  Evaluate/apply Gertjan van Wingerde's SSL patches: |  Evaluate/apply Gertjan van Wingerde's SSL patches: | ||||||
|  https://curl.haxx.se/mail/lib-2004-03/0087.html |  http://curl.haxx.se/mail/lib-2004-03/0087.html | ||||||
|  |  | ||||||
| 13.4 Cache OpenSSL contexts | 13.4 Cache OpenSSL contexts | ||||||
|  |  | ||||||
| @@ -593,9 +503,9 @@ that doesn't exist on the server, just like --ftp-create-dirs. | |||||||
|  https://www.rfc-editor.org/rfc/rfc6698.txt |  https://www.rfc-editor.org/rfc/rfc6698.txt | ||||||
|  |  | ||||||
|  An initial patch was posted by Suresh Krishnaswamy on March 7th 2013 |  An initial patch was posted by Suresh Krishnaswamy on March 7th 2013 | ||||||
|  (https://curl.haxx.se/mail/lib-2013-03/0075.html) but it was a too simple |  (http://curl.haxx.se/mail/lib-2013-03/0075.html) but it was a too simple | ||||||
|  approach. See Daniel's comments: |  approach. See Daniel's comments: | ||||||
|  https://curl.haxx.se/mail/lib-2013-03/0103.html . libunbound may be the |  http://curl.haxx.se/mail/lib-2013-03/0103.html . libunbound may be the | ||||||
|  correct library to base this development on. |  correct library to base this development on. | ||||||
|  |  | ||||||
| 14. GnuTLS | 14. GnuTLS | ||||||
| @@ -687,7 +597,7 @@ that doesn't exist on the server, just like --ftp-create-dirs. | |||||||
|  The client could be told to use maximum N simultaneous parallel transfers and |  The client could be told to use maximum N simultaneous parallel transfers and | ||||||
|  then just make sure that happens. It should of course not make more than one |  then just make sure that happens. It should of course not make more than one | ||||||
|  connection to the same remote host. This would require the client to use the |  connection to the same remote host. This would require the client to use the | ||||||
|  multi interface. https://curl.haxx.se/bug/feature.cgi?id=1558595 |  multi interface. http://curl.haxx.se/bug/feature.cgi?id=1558595 | ||||||
|  |  | ||||||
| 17.5 provide formpost headers | 17.5 provide formpost headers | ||||||
|  |  | ||||||
| @@ -705,46 +615,32 @@ that doesn't exist on the server, just like --ftp-create-dirs. | |||||||
|  |  | ||||||
| 17.6 warning when setting an option | 17.6 warning when setting an option | ||||||
|  |  | ||||||
|  Display a warning when libcurl returns an error when setting an option. |   Display a warning when libcurl returns an error when setting an option. | ||||||
|  This can be useful to tell when support for a particular feature hasn't been |   This can be useful to tell when support for a particular feature hasn't been | ||||||
|  compiled into the library. |   compiled into the library. | ||||||
|  |  | ||||||
| 17.7 warning when sending binary output to terminal | 17.7 warning when sending binary output to terminal | ||||||
|  |  | ||||||
|  Provide a way that prompts the user for confirmation before binary data is |   Provide a way that prompts the user for confirmation before binary data is | ||||||
|  sent to the terminal, much in the style 'less' does it. |   sent to the terminal, much in the style 'less' does it. | ||||||
|  |  | ||||||
| 17.8 offer color-coded HTTP header output | 17.8 offer color-coded HTTP header output | ||||||
|  |  | ||||||
|  By offering different color output on the header name and the header |   By offering different color output on the header name and the header | ||||||
|  contents, they could be made more readable and thus help users working on |   contents, they could be made more readable and thus help users working on | ||||||
|  HTTP services. |   HTTP services. | ||||||
|  |  | ||||||
| 17.9 Choose the name of file in braces for complex URLs | 17.9 Choose the name of file in braces for complex URLs | ||||||
|  |  | ||||||
|  When using braces to download a list of URLs and you use complicated names |   When using braces to download a list of URLs and you use complicated names | ||||||
|  in the list of alternatives, it could be handy to allow curl to use other |   in the list of alternatives, it could be handy to allow curl to use other | ||||||
|  names when saving. |   names when saving. | ||||||
|  |  | ||||||
|  Consider a way to offer that. Possibly like |   Consider a way to offer that. Possibly like | ||||||
|  {partURL1:name1,partURL2:name2,partURL3:name3} where the name following the |   {partURL1:name1,partURL2:name2,partURL3:name3} where the name following the | ||||||
|  colon is the output name. |   colon is the output name. | ||||||
|  |  | ||||||
|  See https://github.com/curl/curl/issues/221 |   See https://github.com/bagder/curl/issues/221 | ||||||
|  |  | ||||||
| 17.10 improve how curl works in a windows console window |  | ||||||
|  |  | ||||||
|  If you pull the scrollbar when transferring with curl in a Windows console |  | ||||||
|  window, the transfer is interrupted and can get disconnected. This can |  | ||||||
|  probably be improved. See https://github.com/curl/curl/issues/322 |  | ||||||
|  |  | ||||||
| 17.11 -w output to stderr |  | ||||||
|  |  | ||||||
|  -w is quite useful, but not to those of us who use curl without -o or -O |  | ||||||
|  (such as for scripting through a higher level language). It would be nice to |  | ||||||
|  have an option that is exactly like -w but sends it to stderr |  | ||||||
|  instead. Proposed name: --write-stderr. See |  | ||||||
|  https://github.com/curl/curl/issues/613 |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 18. Build | 18. Build | ||||||
| @@ -895,3 +791,22 @@ that doesn't exist on the server, just like --ftp-create-dirs. | |||||||
|  |  | ||||||
|  Changing them to return a private handle will benefit the implementation and |  Changing them to return a private handle will benefit the implementation and | ||||||
|  allow us much greater freedoms while still maintaining a solid API and ABI. |  allow us much greater freedoms while still maintaining a solid API and ABI. | ||||||
|  |  | ||||||
|  | 21.9 have form functions use CURL handle argument | ||||||
|  |  | ||||||
|  |  curl_formadd() and curl_formget() both currently have no CURL handle | ||||||
|  |  argument, but both can use a callback that is set in the easy handle, and | ||||||
|  |  thus curl_formget() with callback cannot function without first having | ||||||
|  |  curl_easy_perform() (or similar) called - which is hard to grasp and a design | ||||||
|  |  mistake. | ||||||
|  |  | ||||||
|  | 21.10 Add CURLOPT_MAIL_CLIENT option | ||||||
|  |  | ||||||
|  |  Rather than use the URL to specify the mail client string to present in the | ||||||
|  |  HELO and EHLO commands, libcurl should support a new CURLOPT specifically for | ||||||
|  |  specifying this data as the URL is non-standard and to be honest a bit of a | ||||||
|  |  hack ;-) | ||||||
|  |  | ||||||
|  |  Please see the following thread for more information: | ||||||
|  |  http://curl.haxx.se/mail/lib-2012-05/0178.html | ||||||
|  |   | ||||||
|   | |||||||
| @@ -136,7 +136,7 @@ The Art Of Scripting HTTP Requests Using Curl | |||||||
|  |  | ||||||
|  The Uniform Resource Locator format is how you specify the address of a |  The Uniform Resource Locator format is how you specify the address of a | ||||||
|  particular resource on the Internet. You know these, you've seen URLs like |  particular resource on the Internet. You know these, you've seen URLs like | ||||||
|  https://curl.haxx.se or https://yourbank.com a million times. RFC 3986 is the |  http://curl.haxx.se or https://yourbank.com a million times. RFC 3986 is the | ||||||
|  canonical spec. And yeah, the formal name is not URL, it is URI. |  canonical spec. And yeah, the formal name is not URL, it is URI. | ||||||
|  |  | ||||||
|  2.2 Host |  2.2 Host | ||||||
| @@ -203,7 +203,7 @@ The Art Of Scripting HTTP Requests Using Curl | |||||||
|  issues a GET request to the server and receives the document it asked for. |  issues a GET request to the server and receives the document it asked for. | ||||||
|  If you issue the command line |  If you issue the command line | ||||||
|  |  | ||||||
|         curl https://curl.haxx.se |         curl http://curl.haxx.se | ||||||
|  |  | ||||||
|  you get a web page returned in your terminal window. The entire HTML document |  you get a web page returned in your terminal window. The entire HTML document | ||||||
|  that that URL holds. |  that that URL holds. | ||||||
| @@ -628,7 +628,7 @@ The Art Of Scripting HTTP Requests Using Curl | |||||||
|   More about server certificate verification and ca cert bundles can be read |   More about server certificate verification and ca cert bundles can be read | ||||||
|   in the SSLCERTS document, available online here: |   in the SSLCERTS document, available online here: | ||||||
|  |  | ||||||
|         https://curl.haxx.se/docs/sslcerts.html |         http://curl.haxx.se/docs/sslcerts.html | ||||||
|  |  | ||||||
|   At times you may end up with your own CA cert store and then you can tell |   At times you may end up with your own CA cert store and then you can tell | ||||||
|   curl to use that to verify the server's certificate: |   curl to use that to verify the server's certificate: | ||||||
| @@ -755,4 +755,4 @@ The Art Of Scripting HTTP Requests Using Curl | |||||||
|  |  | ||||||
|  14.2 Sites |  14.2 Sites | ||||||
|  |  | ||||||
|  https://curl.haxx.se is the home of the cURL project |  http://curl.haxx.se is the home of the cURL project | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| .\" * | .\" * | ||||||
| .\" * This software is licensed as described in the file COPYING, which | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * you should have received as part of this distribution. The terms | ||||||
| .\" * are also available at https://curl.haxx.se/docs/copyright.html. | .\" * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| .\" * | .\" * | ||||||
| .\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell | .\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| .\" * copies of the Software, and permit persons to whom the Software is | .\" * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
							
								
								
									
										149
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										149
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -5,11 +5,11 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is licensed as described in the file COPYING, which | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * you should have received as part of this distribution. The terms | ||||||
| .\" * are also available at https://curl.haxx.se/docs/copyright.html. | .\" * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| .\" * | .\" * | ||||||
| .\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell | .\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| .\" * copies of the Software, and permit persons to whom the Software is | .\" * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -171,11 +171,10 @@ a level of control). | |||||||
| .IP "-2, --sslv2" | .IP "-2, --sslv2" | ||||||
| (SSL) Forces curl to use SSL version 2 when negotiating with a remote SSL | (SSL) Forces curl to use SSL version 2 when negotiating with a remote SSL | ||||||
| server. Sometimes curl is built without SSLv2 support. SSLv2 is widely | server. Sometimes curl is built without SSLv2 support. SSLv2 is widely | ||||||
| considered insecure (see RFC 6176). | considered insecure. | ||||||
| .IP "-3, --sslv3" | .IP "-3, --sslv3" | ||||||
| (SSL) Forces curl to use SSL version 3 when negotiating with a remote SSL | (SSL) Forces curl to use SSL version 3 when negotiating with a remote SSL | ||||||
| server. Sometimes curl is built without SSLv3 support. SSLv3 is widely | server. Sometimes curl is built without SSLv3 support. | ||||||
| considered insecure (see RFC 7568). |  | ||||||
| .IP "-4, --ipv4" | .IP "-4, --ipv4" | ||||||
| This option tells curl to resolve names to IPv4 addresses only, and not for | This option tells curl to resolve names to IPv4 addresses only, and not for | ||||||
| example try IPv6. | example try IPv6. | ||||||
| @@ -213,7 +212,7 @@ be in the format "NAME1=VALUE1; NAME2=VALUE2". | |||||||
|  |  | ||||||
| If no '=' symbol is used in the line, it is treated as a filename to use to | If no '=' symbol is used in the line, it is treated as a filename to use to | ||||||
| read previously stored cookie lines from, which should be used in this session | read previously stored cookie lines from, which should be used in this session | ||||||
| if they match. Using this method also activates the cookie engine which will | if they match. Using this method also activates the "cookie parser" which will | ||||||
| make curl record incoming cookies too, which may be handy if you're using this | make curl record incoming cookies too, which may be handy if you're using this | ||||||
| in combination with the \fI-L, --location\fP option. The file format of the | in combination with the \fI-L, --location\fP option. The file format of the | ||||||
| file to read cookies from should be plain HTTP headers or the Netscape/Mozilla | file to read cookies from should be plain HTTP headers or the Netscape/Mozilla | ||||||
| @@ -223,15 +222,6 @@ The file specified with \fI-b, --cookie\fP is only used as input. No cookies | |||||||
| will be written to the file. To store cookies, use the \fI-c, --cookie-jar\fP | will be written to the file. To store cookies, use the \fI-c, --cookie-jar\fP | ||||||
| option. | option. | ||||||
|  |  | ||||||
| Exercise caution if you are using this option and multiple transfers may occur. |  | ||||||
| If you use the NAME1=VALUE1; format, or in a file use the Set-Cookie format and |  | ||||||
| don't specify a domain, then the cookie is sent for any domain (even after |  | ||||||
| redirects are followed) and cannot be modified by a server-set cookie. If the |  | ||||||
| cookie engine is enabled and a server sets a cookie of the same name then both |  | ||||||
| will be sent on a future transfer to that server, likely not what you intended. |  | ||||||
| To address these issues set a domain in Set-Cookie (doing that will include |  | ||||||
| sub-domains) or use the Netscape format. |  | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "-B, --use-ascii" | .IP "-B, --use-ascii" | ||||||
| (FTP/LDAP) Enable ASCII transfer. For FTP, this can also be enforced by using | (FTP/LDAP) Enable ASCII transfer. For FTP, this can also be enforced by using | ||||||
| @@ -263,9 +253,6 @@ won't fail or even report an error clearly. Using -v will get a warning | |||||||
| displayed, but that is the only visible feedback you get about this possibly | displayed, but that is the only visible feedback you get about this possibly | ||||||
| lethal situation. | lethal situation. | ||||||
|  |  | ||||||
| Since 7.43.0 cookies that were imported in the Set-Cookie format without a |  | ||||||
| domain name are not exported by this option. |  | ||||||
|  |  | ||||||
| If this option is used several times, the last specified file name will be | If this option is used several times, the last specified file name will be | ||||||
| used. | used. | ||||||
| .IP "-C, --continue-at <offset>" | .IP "-C, --continue-at <offset>" | ||||||
| @@ -488,10 +475,10 @@ If this option is used several times, the last one will be used. | |||||||
| (SSL) Tells curl to use the specified client certificate file when getting a | (SSL) Tells curl to use the specified client certificate file when getting a | ||||||
| file with HTTPS, FTPS or another SSL-based protocol. The certificate must be | file with HTTPS, FTPS or another SSL-based protocol. The certificate must be | ||||||
| in PKCS#12 format if using Secure Transport, or PEM format if using any other | in PKCS#12 format if using Secure Transport, or PEM format if using any other | ||||||
| engine.  If the optional password isn't specified, it will be queried for on | engine.  If the optional password isn't specified, it will be queried | ||||||
| the terminal. Note that this option assumes a \&"certificate" file that is the | for on the terminal. Note that this option assumes a \&"certificate" file that | ||||||
| private key and the client certificate concatenated! See \fI--cert\fP and | is the private key and the private certificate concatenated! See \fI--cert\fP | ||||||
| \fI--key\fP to specify them independently. | and \fI--key\fP to specify them independently. | ||||||
|  |  | ||||||
| If curl is built against the NSS SSL library then this option can tell | If curl is built against the NSS SSL library then this option can tell | ||||||
| curl the nickname of the certificate to use within the NSS database defined | curl the nickname of the certificate to use within the NSS database defined | ||||||
| @@ -523,13 +510,6 @@ after having run curl. | |||||||
| (SSL) Specify the path name to the Entropy Gathering Daemon socket. The socket | (SSL) Specify the path name to the Entropy Gathering Daemon socket. The socket | ||||||
| is used to seed the random engine for SSL connections. See also the | is used to seed the random engine for SSL connections. See also the | ||||||
| \fI--random-file\fP option. | \fI--random-file\fP option. | ||||||
| .IP "--expect100-timeout <seconds>" |  | ||||||
| (HTTP) Maximum time in seconds that you allow curl to wait for a 100-continue |  | ||||||
| response when curl emits an Expects: 100-continue header in its request. By |  | ||||||
| default curl will wait one second. This option accepts decimal values! When |  | ||||||
| curl stops waiting, it will continue as if the response has been received. |  | ||||||
|  |  | ||||||
| (Added in 7.47.0) |  | ||||||
| .IP "--cert-type <type>" | .IP "--cert-type <type>" | ||||||
| (SSL) Tells curl what certificate type the provided certificate is in. PEM, | (SSL) Tells curl what certificate type the provided certificate is in. PEM, | ||||||
| DER and ENG are recognized types.  If not specified, PEM is assumed. | DER and ENG are recognized types.  If not specified, PEM is assumed. | ||||||
| @@ -564,11 +544,9 @@ OpenSSL-powered curl to make SSL-connections much more efficiently than using | |||||||
|  |  | ||||||
| If this option is set, the default capath value will be ignored, and if it is | If this option is set, the default capath value will be ignored, and if it is | ||||||
| used several times, the last one will be used. | used several times, the last one will be used. | ||||||
| .IP "--pinnedpubkey <pinned public key (hashes)>" | .IP "--pinnedpubkey <pinned public key>" | ||||||
| (SSL) Tells curl to use the specified public key file (or hashes) to verify the | (SSL) Tells curl to use the specified public key file to verify the peer. The | ||||||
| peer. This can be a path to a file which contains a single public key in PEM or | file must contain a single public key in PEM or DER format. | ||||||
| DER format, or any number of base64 encoded sha256 hashes preceded by |  | ||||||
| \'sha256//\' and separated by \';\' |  | ||||||
|  |  | ||||||
| When negotiating a TLS or SSL connection, the server sends a certificate | When negotiating a TLS or SSL connection, the server sends a certificate | ||||||
| indicating its identity. A public key is extracted from this certificate and | indicating its identity. A public key is extracted from this certificate and | ||||||
| @@ -576,8 +554,7 @@ if it does not exactly match the public key provided to this option, curl will | |||||||
| abort the connection before sending or receiving any data. | abort the connection before sending or receiving any data. | ||||||
|  |  | ||||||
| Added in 7.39.0 for OpenSSL, GnuTLS and GSKit. Added in 7.43.0 for NSS and | Added in 7.39.0 for OpenSSL, GnuTLS and GSKit. Added in 7.43.0 for NSS and | ||||||
| wolfSSL/CyaSSL. sha256 support added in 7.44.0 for OpenSSL, | wolfSSL/CyaSSL. Other SSL backends not supported. | ||||||
| GnuTLS, NSS and wolfSSL/CyaSSL. Other SSL backends not supported. |  | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--cert-status" | .IP "--cert-status" | ||||||
| @@ -627,9 +604,7 @@ input: | |||||||
| \fBcurl\fP -F password=@/etc/passwd www.mypasswords.com | \fBcurl\fP -F password=@/etc/passwd www.mypasswords.com | ||||||
|  |  | ||||||
| To read content from stdin instead of a file, use - as the filename. This goes | To read content from stdin instead of a file, use - as the filename. This goes | ||||||
| for both @ and < constructs. Unfortunately it does not support reading the | for both @ and < constructs. | ||||||
| file from a named pipe or similar, as it needs the full size before the |  | ||||||
| transfer starts. |  | ||||||
|  |  | ||||||
| You can also tell curl what Content-Type to use by using 'type=', in a manner | You can also tell curl what Content-Type to use by using 'type=', in a manner | ||||||
| similar to: | similar to: | ||||||
| @@ -796,12 +771,10 @@ This option can be used multiple times to add/replace/remove multiple headers. | |||||||
| be the 128 bit MD5 checksum of the remote host's public key, curl will refuse | be the 128 bit MD5 checksum of the remote host's public key, curl will refuse | ||||||
| the connection with the host unless the md5sums match. (Added in 7.17.1) | the connection with the host unless the md5sums match. (Added in 7.17.1) | ||||||
| .IP "--ignore-content-length" | .IP "--ignore-content-length" | ||||||
| For HTTP, Ignore the Content-Length header. This is particularly useful for | (HTTP) | ||||||
| servers running Apache 1.x, which will report incorrect Content-Length for | Ignore the Content-Length header. This is particularly useful for servers | ||||||
| files larger than 2 gigabytes. | running Apache 1.x, which will report incorrect Content-Length for files | ||||||
|  | larger than 2 gigabytes. | ||||||
| For FTP (since 7.46.0), skip the RETR command to figure out the size before |  | ||||||
| downloading a file. |  | ||||||
| .IP "-i, --include" | .IP "-i, --include" | ||||||
| (HTTP) Include the HTTP-header in the output. The HTTP-header includes things | (HTTP) Include the HTTP-header in the output. The HTTP-header includes things | ||||||
| like server-name, date of the document, HTTP-version and more... | like server-name, date of the document, HTTP-version and more... | ||||||
| @@ -828,17 +801,8 @@ cookies when they're closed down. | |||||||
| server-specified Content-Disposition filename instead of extracting a filename | server-specified Content-Disposition filename instead of extracting a filename | ||||||
| from the URL. | from the URL. | ||||||
|  |  | ||||||
| If the server specifies a file name and a file with that name already exists |  | ||||||
| in the current working directory it will not be overwritten and an error will |  | ||||||
| occur. If the server doesn't specify a file name then this option has no |  | ||||||
| effect. |  | ||||||
|  |  | ||||||
| There's no attempt to decode %-sequences (yet) in the provided file name, so | There's no attempt to decode %-sequences (yet) in the provided file name, so | ||||||
| this option may provide you with rather unexpected file names. | this option may provide you with rather unexpected file names. | ||||||
|  |  | ||||||
| \fBWARNING\fP: Exercise judicious use of this option, especially on Windows. A |  | ||||||
| rogue server could send you the name of a DLL or other file that could possibly |  | ||||||
| be loaded automatically by Windows or some third party software. |  | ||||||
| .IP "-k, --insecure" | .IP "-k, --insecure" | ||||||
| (SSL) This option explicitly allows curl to perform "insecure" SSL connections | (SSL) This option explicitly allows curl to perform "insecure" SSL connections | ||||||
| and transfers. All SSL connections are attempted to be made secure by using | and transfers. All SSL connections are attempted to be made secure by using | ||||||
| @@ -846,7 +810,7 @@ the CA certificate bundle installed by default. This makes all connections | |||||||
| considered "insecure" fail unless \fI-k, --insecure\fP is used. | considered "insecure" fail unless \fI-k, --insecure\fP is used. | ||||||
|  |  | ||||||
| See this online resource for further details: | See this online resource for further details: | ||||||
| \fBhttps://curl.haxx.se/docs/sslcerts.html\fP | \fBhttp://curl.haxx.se/docs/sslcerts.html\fP | ||||||
| .IP "-K, --config <config file>" | .IP "-K, --config <config file>" | ||||||
| Specify which config file to read curl arguments from. The config file is a | Specify which config file to read curl arguments from. The config file is a | ||||||
| text file in which command line arguments can be written which then will be | text file in which command line arguments can be written which then will be | ||||||
| @@ -873,7 +837,7 @@ Note that to be able to specify a URL in the config file, you need to specify | |||||||
| it using the \fI--url\fP option, and not by simply writing the URL on its own | it using the \fI--url\fP option, and not by simply writing the URL on its own | ||||||
| line. So, it could look similar to this: | line. So, it could look similar to this: | ||||||
|  |  | ||||||
| url = "https://curl.haxx.se/docs/" | url = "http://curl.haxx.se/docs/" | ||||||
|  |  | ||||||
| When curl is invoked, it always (unless \fI-q\fP is used) checks for a default | When curl is invoked, it always (unless \fI-q\fP is used) checks for a default | ||||||
| config file and uses it if found. The default config file is checked for in | config file and uses it if found. The default config file is checked for in | ||||||
| @@ -1199,15 +1163,12 @@ output to be done to stdout. | |||||||
| Write output to a local file named like the remote file we get. (Only the file | Write output to a local file named like the remote file we get. (Only the file | ||||||
| part of the remote file is used, the path is cut off.) | part of the remote file is used, the path is cut off.) | ||||||
|  |  | ||||||
| The file will be saved in the current working directory. If you want the file | The remote file name to use for saving is extracted from the given URL, | ||||||
| saved in a different directory, make sure you change the current working | nothing else. | ||||||
| directory before invoking curl with this option. |  | ||||||
|  |  | ||||||
| The remote file name to use for saving is extracted from the given URL, nothing | Consequentially, the file will be saved in the current working directory. If | ||||||
| else, and if it already exists it will be overwritten. If you want the server | you want the file saved in a different directory, make sure you change current | ||||||
| to be able to choose the file name refer to \fI-J, --remote-header-name\fP | working directory before you invoke curl with the \fB-O, --remote-name\fP flag! | ||||||
| which can be used in addition to this option. If the server chooses a file name |  | ||||||
| and that name already exists it will not be overwritten. |  | ||||||
|  |  | ||||||
| There is no URL decoding done on the file name. If it has %20 or other URL | There is no URL decoding done on the file name. If it has %20 or other URL | ||||||
| encoded parts of the name, they will end up as-is as file name. | encoded parts of the name, they will end up as-is as file name. | ||||||
| @@ -1284,21 +1245,21 @@ this option set you tell it not to do that. | |||||||
|  |  | ||||||
| (Added in 7.42.0) | (Added in 7.42.0) | ||||||
| .IP "--post301" | .IP "--post301" | ||||||
| (HTTP) Tells curl to respect RFC 7230/6.4.2 and not convert POST requests | (HTTP) Tells curl to respect RFC 2616/10.3.2 and not convert POST requests | ||||||
| into GET requests when following a 301 redirection. The non-RFC behaviour is | into GET requests when following a 301 redirection. The non-RFC behaviour is | ||||||
| ubiquitous in web browsers, so curl does the conversion by default to maintain | ubiquitous in web browsers, so curl does the conversion by default to maintain | ||||||
| consistency. However, a server may require a POST to remain a POST after such | consistency. However, a server may require a POST to remain a POST after such | ||||||
| a redirection. This option is meaningful only when using \fI-L, --location\fP | a redirection. This option is meaningful only when using \fI-L, --location\fP | ||||||
| (Added in 7.17.1) | (Added in 7.17.1) | ||||||
| .IP "--post302" | .IP "--post302" | ||||||
| (HTTP) Tells curl to respect RFC 7230/6.4.3 and not convert POST requests | (HTTP) Tells curl to respect RFC 2616/10.3.2 and not convert POST requests | ||||||
| into GET requests when following a 302 redirection. The non-RFC behaviour is | into GET requests when following a 302 redirection. The non-RFC behaviour is | ||||||
| ubiquitous in web browsers, so curl does the conversion by default to maintain | ubiquitous in web browsers, so curl does the conversion by default to maintain | ||||||
| consistency. However, a server may require a POST to remain a POST after such | consistency. However, a server may require a POST to remain a POST after such | ||||||
| a redirection. This option is meaningful only when using \fI-L, --location\fP | a redirection. This option is meaningful only when using \fI-L, --location\fP | ||||||
| (Added in 7.19.1) | (Added in 7.19.1) | ||||||
| .IP "--post303" | .IP "--post303" | ||||||
| (HTTP) Tells curl to respect RFC 7230/6.4.4 and not convert POST requests | (HTTP) Tells curl to respect RFC 2616/10.3.2 and not convert POST requests | ||||||
| into GET requests when following a 303 redirection. The non-RFC behaviour is | into GET requests when following a 303 redirection. The non-RFC behaviour is | ||||||
| ubiquitous in web browsers, so curl does the conversion by default to maintain | ubiquitous in web browsers, so curl does the conversion by default to maintain | ||||||
| consistency. However, a server may require a POST to remain a POST after such | consistency. However, a server may require a POST to remain a POST after such | ||||||
| @@ -1345,40 +1306,9 @@ This option can be used multiple times, in which case the effect is the same | |||||||
| as concatenating the protocols into one instance of the option. | as concatenating the protocols into one instance of the option. | ||||||
|  |  | ||||||
| (Added in 7.20.2) | (Added in 7.20.2) | ||||||
| .IP "--proto-default <protocol>" |  | ||||||
| Tells curl to use \fIprotocol\fP for any URL missing a scheme name. |  | ||||||
|  |  | ||||||
| Example: |  | ||||||
|  |  | ||||||
| .RS |  | ||||||
| .IP "--proto-default https ftp.mozilla.org" |  | ||||||
| https://ftp.mozilla.org |  | ||||||
| .RE |  | ||||||
|  |  | ||||||
| An unknown or unsupported protocol causes error |  | ||||||
| \fICURLE_UNSUPPORTED_PROTOCOL\fP. |  | ||||||
|  |  | ||||||
| This option does not change the default proxy protocol (http). |  | ||||||
|  |  | ||||||
| Without this option curl would make a guess based on the host, see \fI--url\fP |  | ||||||
| for details. |  | ||||||
|  |  | ||||||
| (Added in 7.45.0) |  | ||||||
| .IP "--proto-redir <protocols>" | .IP "--proto-redir <protocols>" | ||||||
| Tells curl to use the listed protocols on redirect. See --proto for how | Tells curl to use the listed protocols after a redirect. See --proto for | ||||||
| protocols are represented. | how protocols are represented. | ||||||
|  |  | ||||||
| Example: |  | ||||||
|  |  | ||||||
| .RS |  | ||||||
| .IP "--proto-redir -all,http,https" |  | ||||||
| Allow only HTTP and HTTPS on redirect. |  | ||||||
| .RE |  | ||||||
|  |  | ||||||
| By default curl will allow all protocols on redirect except several disabled |  | ||||||
| for security reasons: Since 7.19.4 FILE and SCP are disabled, and since 7.40.0 |  | ||||||
| SMB and SMBS are also disabled. Specifying \fIall\fP or \fI+all\fP enables all |  | ||||||
| protocols on redirect, including those disabled for security. |  | ||||||
|  |  | ||||||
| (Added in 7.20.2) | (Added in 7.20.2) | ||||||
| .IP "--proxy-anyauth" | .IP "--proxy-anyauth" | ||||||
| @@ -1493,10 +1423,13 @@ specifies the last 500 bytes | |||||||
| specifies the bytes from offset 9500 and forward | specifies the bytes from offset 9500 and forward | ||||||
| .TP | .TP | ||||||
| .B 0-0,-1 | .B 0-0,-1 | ||||||
| specifies the first and last byte only(*)(HTTP) | specifies the first and last byte only(*)(H) | ||||||
|  | .TP | ||||||
|  | .B 500-700,600-799 | ||||||
|  | specifies 300 bytes from offset 500(H) | ||||||
| .TP | .TP | ||||||
| .B 100-199,500-599 | .B 100-199,500-599 | ||||||
| specifies two separate 100-byte ranges(*) (HTTP) | specifies two separate 100-byte ranges(*)(H) | ||||||
| .RE | .RE | ||||||
| .IP | .IP | ||||||
| (*) = NOTE that this will cause the server to reply with a multipart | (*) = NOTE that this will cause the server to reply with a multipart | ||||||
| @@ -1609,10 +1542,6 @@ and TLS1.0 protocols known as BEAST.  If this option isn't used, the SSL layer | |||||||
| may use workarounds known to cause interoperability problems with some older | may use workarounds known to cause interoperability problems with some older | ||||||
| SSL implementations. WARNING: this option loosens the SSL security, and by | SSL implementations. WARNING: this option loosens the SSL security, and by | ||||||
| using this flag you ask for exactly that.  (Added in 7.25.0) | using this flag you ask for exactly that.  (Added in 7.25.0) | ||||||
| .IP "--ssl-no-revoke" |  | ||||||
| (WinSSL) This option tells curl to disable certificate revocation checks. |  | ||||||
| WARNING: this option loosens the SSL security, and by using this flag you ask |  | ||||||
| for exactly that.  (Added in 7.44.0) |  | ||||||
| .IP "--socks4 <host[:port]>" | .IP "--socks4 <host[:port]>" | ||||||
| Use the specified SOCKS4 proxy. If the port number is not specified, it is | Use the specified SOCKS4 proxy. If the port number is not specified, it is | ||||||
| assumed at port 1080. (Added in 7.15.2) | assumed at port 1080. (Added in 7.15.2) | ||||||
| @@ -1822,12 +1751,6 @@ If this option is used several times, the last one will be used. | |||||||
| Specify a URL to fetch. This option is mostly handy when you want to specify | Specify a URL to fetch. This option is mostly handy when you want to specify | ||||||
| URL(s) in a config file. | URL(s) in a config file. | ||||||
|  |  | ||||||
| If the given URL is missing a scheme name (such as "http://" or "ftp://" etc) |  | ||||||
| then curl will make a guess based on the host. If the outermost sub-domain name |  | ||||||
| matches DICT, FTP, IMAP, LDAP, POP3 or SMTP then that protocol will be used, |  | ||||||
| otherwise HTTP will be used. Since 7.45.0 guessing can be disabled by setting a |  | ||||||
| default protocol, see \fI--proto-default\fP for details. |  | ||||||
|  |  | ||||||
| This option may be used any number of times. To control where this URL is | This option may be used any number of times. To control where this URL is | ||||||
| written, use the \fI-o, --output\fP or the \fI-O, --remote-name\fP options. | written, use the \fI-o, --output\fP or the \fI-O, --remote-name\fP options. | ||||||
| .IP "-v, --verbose" | .IP "-v, --verbose" | ||||||
| @@ -2347,7 +2270,7 @@ are meant to never change. | |||||||
| Daniel Stenberg is the main author, but the whole list of contributors is | Daniel Stenberg is the main author, but the whole list of contributors is | ||||||
| found in the separate THANKS file. | found in the separate THANKS file. | ||||||
| .SH WWW | .SH WWW | ||||||
| https://curl.haxx.se | http://curl.haxx.se | ||||||
| .SH FTP | .SH FTP | ||||||
| ftp://ftp.sunet.se/pub/www/utilities/curl/ | ftp://ftp.sunet.se/pub/www/utilities/curl/ | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -73,7 +73,3 @@ smtp-vrfy | |||||||
| url2file | url2file | ||||||
| usercertinmem | usercertinmem | ||||||
| xmlstream | xmlstream | ||||||
| http2-download |  | ||||||
| http2-serverpush |  | ||||||
| http2-upload |  | ||||||
| imap-lsub |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -32,7 +32,7 @@ check_PROGRAMS = 10-at-a-time anyauthput cookie_interface debug fileupload \ | |||||||
|   imap-list imap-lsub imap-fetch imap-store imap-append imap-examine       \ |   imap-list imap-lsub imap-fetch imap-store imap-append imap-examine       \ | ||||||
|   imap-search imap-create imap-delete imap-copy imap-noop imap-ssl         \ |   imap-search imap-create imap-delete imap-copy imap-noop imap-ssl         \ | ||||||
|   imap-tls imap-multi url2file sftpget ftpsget postinmemory http2-download \ |   imap-tls imap-multi url2file sftpget ftpsget postinmemory http2-download \ | ||||||
|   http2-upload http2-serverpush getredirect |   http2-upload http2-serverpush | ||||||
|  |  | ||||||
| # These examples require external dependencies that may not be commonly | # These examples require external dependencies that may not be commonly | ||||||
| # available on POSIX systems, so don't bother attempting to compile them here. | # available on POSIX systems, so don't bother attempting to compile them here. | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| # are also available at https://curl.haxx.se/docs/copyright.html. | # are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
| # | # | ||||||
| # You may opt to use, copy, modify, merge, publish, distribute and/or sell | # You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
| # copies of the Software, and permit persons to whom the Software is | # copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -50,7 +50,7 @@ LIBRTMP_PATH = ../../../librtmp-2.4 | |||||||
| endif | endif | ||||||
| # Edit the path below to point to the base of your libidn package. | # Edit the path below to point to the base of your libidn package. | ||||||
| ifndef LIBIDN_PATH | ifndef LIBIDN_PATH | ||||||
| LIBIDN_PATH = ../../../libidn-1.32 | LIBIDN_PATH = ../../../libidn-1.30 | ||||||
| endif | endif | ||||||
| # Edit the path below to point to the base of your MS IDN package. | # Edit the path below to point to the base of your MS IDN package. | ||||||
| # Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1 | # Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1 | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ endif | |||||||
|  |  | ||||||
| # Edit the path below to point to the base of your libidn package. | # Edit the path below to point to the base of your libidn package. | ||||||
| ifndef LIBIDN_PATH | ifndef LIBIDN_PATH | ||||||
| LIBIDN_PATH = ../../../libidn-1.32 | LIBIDN_PATH = ../../../libidn-1.30 | ||||||
| endif | endif | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your librtmp package. | # Edit the path below to point to the base of your librtmp package. | ||||||
|   | |||||||
| @@ -32,7 +32,51 @@ actually torture our web site with your tests!  Thanks. | |||||||
|  |  | ||||||
| EXAMPLES | EXAMPLES | ||||||
|  |  | ||||||
| Each example source code file is designed to be and work stand-alone and | anyauthput.c   - HTTP PUT using "any" authentication method | ||||||
| rather self-explanatory. The examples may at times lack the level of error | cacertinmem.c  - Use a built-in PEM certificate to retrieve a https page | ||||||
| checks you need in a real world, but that is then only for the sake of | cookie_interface.c - shows usage of simple cookie interface | ||||||
| readability: to make the code smaller and easier to follow. | curlgtk.c      - download using a GTK progress bar | ||||||
|  | curlx.c        - getting file info from the remote cert data | ||||||
|  | debug.c        - showing how to use the debug callback | ||||||
|  | fileupload.c   - uploading to a file:// URL | ||||||
|  | fopen.c        - fopen() layer that supports opening URLs and files | ||||||
|  | ftpget.c       - simple getting a file from FTP | ||||||
|  | ftpgetresp.c   - get the response strings from the FTP server | ||||||
|  | ftpupload.c    - upload a file to an FTP server | ||||||
|  | ftpuploadresume.c - resume an upload to an FTP server | ||||||
|  | getinfo.c      - get the Content-Type from the recent transfer | ||||||
|  | getinmemory.c  - download a file to memory only | ||||||
|  | ghiper.c       - curl_multi_socket() using code with glib-2 | ||||||
|  | hiperfifo.c    - downloads all URLs written to the fifo, using | ||||||
|  |                  curl_multi_socket() and libevent | ||||||
|  | htmltidy.c     - download a document and use libtidy to parse the HTML | ||||||
|  | htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML | ||||||
|  |                  page using libxml | ||||||
|  | http-post.c    - HTTP POST | ||||||
|  | httpput.c      - HTTP PUT a local file | ||||||
|  | https.c        - simple HTTPS transfer | ||||||
|  | imap.c         - simple IMAP transfer | ||||||
|  | multi-app.c    - a multi-interface app | ||||||
|  | multi-debugcallback.c - a multi-interface app using the debug callback | ||||||
|  | multi-double.c - a multi-interface app doing two simultaneous transfers | ||||||
|  | multi-post.c   - a multi-interface app doing a multipart formpost | ||||||
|  | multi-single.c - a multi-interface app getting a single file | ||||||
|  | multi-uv.c     - a multi-interface app using libuv | ||||||
|  | multithread.c  - an example using multi-treading transferring multiple files | ||||||
|  | opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded | ||||||
|  | persistant.c   - request two URLs with a persistent connection | ||||||
|  | pop3s.c        - POP3S transfer | ||||||
|  | pop3slist.c    - POP3S LIST | ||||||
|  | post-callback.c - send a HTTP POST using a callback | ||||||
|  | postit2.c      - send a HTTP multipart formpost | ||||||
|  | sampleconv.c   - showing how a program on a non-ASCII platform would invoke | ||||||
|  |                  callbacks to do its own codeset conversions instead of using | ||||||
|  |                  the built-in iconv functions in libcurl | ||||||
|  | sepheaders.c   - download headers to a separate file | ||||||
|  | simple.c       - the most simple download a URL source | ||||||
|  | simplepost.c   - HTTP POST | ||||||
|  | simplessl.c    - HTTPS example with certificates many options set | ||||||
|  | synctime.c     - Sync local time by extracting date from remote HTTP servers | ||||||
|  | url2file.c     - download a document and store it in a file | ||||||
|  | xmlstream.c    - Stream-parse a document using the streaming Expat parser | ||||||
|  | 10-at-a-time.c - Download many files simultaneously, 10 at a time. | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
|  |  | ||||||
| # pass files as argument(s) | # pass files as argument(s) | ||||||
|  |  | ||||||
| my $docroot="https://curl.haxx.se/libcurl/c"; | my $docroot="http://curl.haxx.se/libcurl/c"; | ||||||
|  |  | ||||||
| for $f (@ARGV) { | for $f (@ARGV) { | ||||||
|     open(NEW, ">$f.new"); |     open(NEW, ">$f.new"); | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -48,7 +48,6 @@ | |||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
| #include <boost/asio.hpp> | #include <boost/asio.hpp> | ||||||
| #include <boost/bind.hpp> | #include <boost/bind.hpp> | ||||||
| #include <iostream> |  | ||||||
|  |  | ||||||
| #define MSG_OUT stdout /* Send info to stdout, change to stderr if you want */ | #define MSG_OUT stdout /* Send info to stdout, change to stderr if you want */ | ||||||
|  |  | ||||||
| @@ -379,9 +378,9 @@ static curl_socket_t opensocket(void *clientp, curlsocktype purpose, | |||||||
| } | } | ||||||
|  |  | ||||||
| /* CURLOPT_CLOSESOCKETFUNCTION */ | /* CURLOPT_CLOSESOCKETFUNCTION */ | ||||||
| static int close_socket(void *clientp, curl_socket_t item) | static int closesocket(void *clientp, curl_socket_t item) | ||||||
| { | { | ||||||
|   fprintf(MSG_OUT, "\nclose_socket : %d", item); |   fprintf(MSG_OUT, "\nclosesocket : %d", item); | ||||||
|  |  | ||||||
|   std::map<curl_socket_t, boost::asio::ip::tcp::socket *>::iterator it = socket_map.find(item); |   std::map<curl_socket_t, boost::asio::ip::tcp::socket *>::iterator it = socket_map.find(item); | ||||||
|  |  | ||||||
| @@ -428,7 +427,7 @@ static void new_conn(char *url, GlobalInfo *g) | |||||||
|   curl_easy_setopt(conn->easy, CURLOPT_OPENSOCKETFUNCTION, opensocket); |   curl_easy_setopt(conn->easy, CURLOPT_OPENSOCKETFUNCTION, opensocket); | ||||||
|  |  | ||||||
|   /* call this function to close a socket */ |   /* call this function to close a socket */ | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_CLOSESOCKETFUNCTION, close_socket); |   curl_easy_setopt(conn->easy, CURLOPT_CLOSESOCKETFUNCTION, closesocket); | ||||||
|  |  | ||||||
|   fprintf(MSG_OUT, |   fprintf(MSG_OUT, | ||||||
|           "\nAdding easy %p to multi %p (%s)", conn->easy, g->multi, url); |           "\nAdding easy %p to multi %p (%s)", conn->easy, g->multi, url); | ||||||
| @@ -442,6 +441,7 @@ static void new_conn(char *url, GlobalInfo *g) | |||||||
| int main(int argc, char **argv) | int main(int argc, char **argv) | ||||||
| { | { | ||||||
|   GlobalInfo g; |   GlobalInfo g; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|   (void)argc; |   (void)argc; | ||||||
|   (void)argv; |   (void)argv; | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ | |||||||
|  *    "This product includes software developed by the Openevidence Project |  *    "This product includes software developed by the Openevidence Project | ||||||
|  *    for use in the OpenEvidence Toolkit. (http://www.openevidence.org/)" |  *    for use in the OpenEvidence Toolkit. (http://www.openevidence.org/)" | ||||||
|  *    This product includes software developed by the OpenSSL Project |  *    This product includes software developed by the OpenSSL Project | ||||||
|  *    for use in the OpenSSL Toolkit (https://www.openssl.org/)" |  *    for use in the OpenSSL Toolkit (http://www.openssl.org/)" | ||||||
|  *    This product includes cryptographic software written by Eric Young |  *    This product includes cryptographic software written by Eric Young | ||||||
|  *    (eay@cryptsoft.com).  This product includes software written by Tim |  *    (eay@cryptsoft.com).  This product includes software written by Tim | ||||||
|  *    Hudson (tjh@cryptsoft.com)." |  *    Hudson (tjh@cryptsoft.com)." | ||||||
| @@ -55,7 +55,7 @@ | |||||||
|  *    "This product includes software developed by the OpenEvidence Project |  *    "This product includes software developed by the OpenEvidence Project | ||||||
|  *    for use in the OpenEvidence Toolkit (http://www.openevidence.org/) |  *    for use in the OpenEvidence Toolkit (http://www.openevidence.org/) | ||||||
|  *    This product includes software developed by the OpenSSL Project |  *    This product includes software developed by the OpenSSL Project | ||||||
|  *    for use in the OpenSSL Toolkit (https://www.openssl.org/)" |  *    for use in the OpenSSL Toolkit (http://www.openssl.org/)" | ||||||
|  *    This product includes cryptographic software written by Eric Young |  *    This product includes cryptographic software written by Eric Young | ||||||
|  *    (eay@cryptsoft.com).  This product includes software written by Tim |  *    (eay@cryptsoft.com).  This product includes software written by Tim | ||||||
|  *    Hudson (tjh@cryptsoft.com)." |  *    Hudson (tjh@cryptsoft.com)." | ||||||
| @@ -75,7 +75,7 @@ | |||||||
|  * ==================================================================== |  * ==================================================================== | ||||||
|  * |  * | ||||||
|  * This product includes software developed by the OpenSSL Project |  * This product includes software developed by the OpenSSL Project | ||||||
|  * for use in the OpenSSL Toolkit (https://www.openssl.org/) |  * for use in the OpenSSL Toolkit (http://www.openssl.org/) | ||||||
|  * This product includes cryptographic software written by Eric Young |  * This product includes cryptographic software written by Eric Young | ||||||
|  * (eay@cryptsoft.com).  This product includes software written by Tim |  * (eay@cryptsoft.com).  This product includes software written by Tim | ||||||
|  * Hudson (tjh@cryptsoft.com). |  * Hudson (tjh@cryptsoft.com). | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -65,7 +65,7 @@ int main(void) | |||||||
|     res = curl_easy_perform(curl); |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|     if(CURLE_OK == res) { |     if(CURLE_OK == res) { | ||||||
|       /* https://curl.haxx.se/libcurl/c/curl_easy_getinfo.html */ |       /* http://curl.haxx.se/libcurl/c/curl_easy_getinfo.html */ | ||||||
|       res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime); |       res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime); | ||||||
|       if((CURLE_OK == res) && (filetime >= 0)) { |       if((CURLE_OK == res) && (filetime >= 0)) { | ||||||
|         time_t file_time = (time_t)filetime; |         time_t file_time = (time_t)filetime; | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -1,70 +0,0 @@ | |||||||
| /*************************************************************************** |  | ||||||
|  *                                  _   _ ____  _ |  | ||||||
|  *  Project                     ___| | | |  _ \| | |  | ||||||
|  *                             / __| | | | |_) | | |  | ||||||
|  *                            | (__| |_| |  _ <| |___ |  | ||||||
|  *                             \___|\___/|_| \_\_____| |  | ||||||
|  * |  | ||||||
|  * Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel@haxx.se>, et al. |  | ||||||
|  * |  | ||||||
|  * This software is licensed as described in the file COPYING, which |  | ||||||
|  * you should have received as part of this distribution. The terms |  | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  | ||||||
|  * |  | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  | ||||||
|  * furnished to do so, under the terms of the COPYING file. |  | ||||||
|  * |  | ||||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |  | ||||||
|  * KIND, either express or implied. |  | ||||||
|  * |  | ||||||
|  ***************************************************************************/ |  | ||||||
| /* <DESC> |  | ||||||
|  * Show how to extract Location: header and URL to redirect to. |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> |  | ||||||
| #include <curl/curl.h> |  | ||||||
|  |  | ||||||
| int main(void) |  | ||||||
| { |  | ||||||
|   CURL *curl; |  | ||||||
|   CURLcode res; |  | ||||||
|   char *location; |  | ||||||
|   long response_code; |  | ||||||
|  |  | ||||||
|   curl = curl_easy_init(); |  | ||||||
|   if(curl) { |  | ||||||
|     curl_easy_setopt(curl, CURLOPT_URL, "http://example.com"); |  | ||||||
|  |  | ||||||
|     /* example.com is redirected, figure out the redirection! */ |  | ||||||
|  |  | ||||||
|     /* Perform the request, res will get the return code */ |  | ||||||
|     res = curl_easy_perform(curl); |  | ||||||
|     /* Check for errors */ |  | ||||||
|     if(res != CURLE_OK) |  | ||||||
|       fprintf(stderr, "curl_easy_perform() failed: %s\n", |  | ||||||
|               curl_easy_strerror(res)); |  | ||||||
|     else { |  | ||||||
|       res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &response_code); |  | ||||||
|       if((res == CURLE_OK) && |  | ||||||
|          ((response_code / 100) != 3)) { |  | ||||||
|         /* a redirect implies a 3xx response code */ |  | ||||||
|         fprintf(stderr, "Not a redirect.\n"); |  | ||||||
|       } |  | ||||||
|       else { |  | ||||||
|         res = curl_easy_getinfo(curl, CURLINFO_REDIRECT_URL, &location); |  | ||||||
|  |  | ||||||
|         if((res == CURLE_OK) && location) { |  | ||||||
|           /* This is the new absolute URL that you could redirect to, even if |  | ||||||
|            * the Location: response header may have been a relative URL. */ |  | ||||||
|           printf("Redirected to: %s\n", location); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /* always cleanup */ |  | ||||||
|     curl_easy_cleanup(curl); |  | ||||||
|   } |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -330,7 +330,7 @@ static void new_conn(char *url, GlobalInfo *g ) | |||||||
|   conn->url = strdup(url); |   conn->url = strdup(url); | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url); |   curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url); | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb); |   curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb); | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, conn); |   curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, &conn); | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, 1L); |   curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, 1L); | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error); |   curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error); | ||||||
|   curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn); |   curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn); | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,10 +19,8 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> | // Get a web page, parse it with libxml. | ||||||
|  * Get a web page, extract the title with libxml. | // | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| // Written by Lars Nilsson | // Written by Lars Nilsson | ||||||
| // | // | ||||||
| // GNU C++ compile command line suggestion (edit paths accordingly): | // GNU C++ compile command line suggestion (edit paths accordingly): | ||||||
| @@ -42,7 +40,7 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #ifdef _MSC_VER | #ifdef _MSC_VER | ||||||
| #define COMPARE(a, b) (!_stricmp((a), (b))) | #define COMPARE(a, b) (!stricmp((a), (b))) | ||||||
| #else | #else | ||||||
| #define COMPARE(a, b) (!strcasecmp((a), (b))) | #define COMPARE(a, b) (!strcasecmp((a), (b))) | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,10 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * simple HTTP POST using the easy interface |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,13 +19,8 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * Multiplexed HTTP/2 downloads over a single connection |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <string.h> |  | ||||||
|  |  | ||||||
| /* somewhat unix-specific */ | /* somewhat unix-specific */ | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,13 +19,8 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * HTTP/2 server push |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <string.h> |  | ||||||
|  |  | ||||||
| /* somewhat unix-specific */ | /* somewhat unix-specific */ | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,13 +19,8 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * Multiplexed HTTP/2 uploads over a single connection |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <string.h> |  | ||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #include <sys/stat.h> | #include <sys/stat.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,10 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * HTTP request with custom modified, removed and added headers |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,10 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * HTTP PUT with easy interface and read callback |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #include <sys/stat.h> | #include <sys/stat.h> | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,10 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| /* <DESC> |  | ||||||
|  * Simple HTTPS GET |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example showing how to send e-mails |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example showing how to copy an e-mail from one folder to another |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example showing how to create a new folder |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example showing how to delete a folder |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example showing how to obtain information about a folder |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example showing how to retreieve e-mails |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example to list the folders within a mailbox |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,11 +5,11 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2015, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
|  * are also available at https://curl.haxx.se/docs/copyright.html. |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  * |  * | ||||||
|  * You may opt to use, copy, modify, merge, publish, distribute and/or sell |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  * copies of the Software, and permit persons to whom the Software is |  * copies of the Software, and permit persons to whom the Software is | ||||||
| @@ -19,12 +19,6 @@ | |||||||
|  * KIND, either express or implied. |  * KIND, either express or implied. | ||||||
|  * |  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| /* <DESC> |  | ||||||
|  * IMAP example to list the subscribed folders |  | ||||||
|  * </DESC> |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user