Compare commits
	
		
			259 Commits
		
	
	
		
			curl-7_19_
			...
			curl-7_19_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 6247b6d468 | ||
|   | 966cb698e6 | ||
|   | 4b44638f4d | ||
|   | 13afff5752 | ||
|   | e73fe837a8 | ||
|   | a9caeb1064 | ||
|   | 171eef68c3 | ||
|   | 33368ebd02 | ||
|   | 501f9f8309 | ||
|   | 9fe787fc1f | ||
|   | 0dec3e5e6a | ||
|   | 66f5baa16e | ||
|   | 1cb921b7f3 | ||
|   | 0cf6721898 | ||
|   | 97c8bc9757 | ||
|   | 2cad095425 | ||
|   | 37d509f04f | ||
|   | 35eb9fc6ad | ||
|   | df09088a96 | ||
|   | 1a14966577 | ||
|   | 0606b792f0 | ||
|   | a53525e930 | ||
|   | 3a9c03bef3 | ||
|   | f0dbdcff9d | ||
|   | 9d03dd7fb8 | ||
|   | 781b82baf5 | ||
|   | 2838362a7b | ||
|   | 0b66efac9c | ||
|   | 47a9660ec1 | ||
|   | aabf62e7d2 | ||
|   | 6d891d2a3b | ||
|   | c0e8bed5bf | ||
|   | 0dce2ff8a0 | ||
|   | 2642638fca | ||
|   | 8b0fc9819f | ||
|   | bf5f91244b | ||
|   | e8e84cf1da | ||
|   | 0179dbe1c2 | ||
|   | 8978b87728 | ||
|   | 0684128209 | ||
|   | 9b5c00a664 | ||
|   | b347a7a96e | ||
|   | 240bfaa69e | ||
|   | 7dc48e57a6 | ||
|   | 8570883412 | ||
|   | 1d5627b181 | ||
|   | 038fff6c9f | ||
|   | 21dd9a8021 | ||
|   | 59934c1176 | ||
|   | 2f6ff57d96 | ||
|   | 77eba8727d | ||
|   | 47c392e135 | ||
|   | 9cff716925 | ||
|   | 4c207a004c | ||
|   | 650543a042 | ||
|   | 5f0cae8037 | ||
|   | 95c2ab77e7 | ||
|   | d7f33b7e4e | ||
|   | 56e6441ceb | ||
|   | b74b5e0602 | ||
|   | b4dcbbfabd | ||
|   | 6dd0277c22 | ||
|   | fb08218a04 | ||
|   | 08d95bff5e | ||
|   | b476530755 | ||
|   | a8ea1e9ef4 | ||
|   | 6dade671ad | ||
|   | 38b88b5892 | ||
|   | 340e3b952f | ||
|   | 35c91f6ea9 | ||
|   | f5f9354093 | ||
|   | 600460ffc6 | ||
|   | 18b3833f90 | ||
|   | f671d0513c | ||
|   | 100f6b7703 | ||
|   | 4e75c70874 | ||
|   | bdbfe1f8a9 | ||
|   | bea9d2cafd | ||
|   | d709cb2ae3 | ||
|   | 444bb03fab | ||
|   | 966cc10fcc | ||
|   | 0c7087c41f | ||
|   | c42a06bc1f | ||
|   | b4c00a8fb0 | ||
|   | f3403d4c5b | ||
|   | 5cf78472e1 | ||
|   | 2aaff16a87 | ||
|   | 6236198d43 | ||
|   | 83fb285d40 | ||
|   | 3050f10676 | ||
|   | 175fc5096d | ||
|   | 18f238dd53 | ||
|   | 4f551259dd | ||
|   | 9cb68c6e32 | ||
|   | a9a89c604a | ||
|   | e96a9190a3 | ||
|   | 1ff4e9008b | ||
|   | 2d716517a8 | ||
|   | 22226a8aec | ||
|   | 9b8e56c97c | ||
|   | ad1bfc5468 | ||
|   | 2c0c05e96d | ||
|   | d6d63147b6 | ||
|   | 98f7771d74 | ||
|   | 37eba37019 | ||
|   | 40b2f2553b | ||
|   | d3e35d49ae | ||
|   | a0474685c1 | ||
|   | 0b317b72ae | ||
|   | afe06d1563 | ||
|   | c40365e9b6 | ||
|   | 4b6d3a2bfd | ||
|   | 7ae624e700 | ||
|   | c32cf33a16 | ||
|   | 7eb59de7df | ||
|   | 5931cf77f4 | ||
|   | 989aace192 | ||
|   | 65cf30e441 | ||
|   | d4480c979d | ||
|   | 169e94d68b | ||
|   | 0cc8184057 | ||
|   | a7c75142fa | ||
|   | 02d3c452e4 | ||
|   | 1c148575ea | ||
|   | d1a1865650 | ||
|   | 067544abc5 | ||
|   | 77da57057f | ||
|   | aa1da57c37 | ||
|   | c2ce2aa4de | ||
|   | 90c9fd55fc | ||
|   | 47e403640b | ||
|   | 4ea513cc38 | ||
|   | 3ca0b9bb47 | ||
|   | e592da5a59 | ||
|   | 2c93f889fd | ||
|   | 6173ce6463 | ||
|   | 065a51d2e1 | ||
|   | 7edcc22136 | ||
|   | 352177090f | ||
|   | 9d18c0b156 | ||
|   | ec65a9a364 | ||
|   | 5c4b6a8ef0 | ||
|   | 5d502eb90c | ||
|   | d6662d8442 | ||
|   | 1d97f13462 | ||
|   | 2c16681225 | ||
|   | 065047dc62 | ||
|   | eba8d6d5f5 | ||
|   | 744dceaffe | ||
|   | 8740d147c9 | ||
|   | 16ae283fb4 | ||
|   | 312600fe9c | ||
|   | 3e0c067e43 | ||
|   | f90551ff41 | ||
|   | 9442fc0b52 | ||
|   | dbb93a2718 | ||
|   | 242cf423f8 | ||
|   | 217faf778b | ||
|   | 01b74950b7 | ||
|   | 420bfbcf40 | ||
|   | 89f6567fda | ||
|   | efec05d581 | ||
|   | 47198dce5d | ||
|   | f45500c612 | ||
|   | 6f3e817372 | ||
|   | cfda5df020 | ||
|   | 2b4f41603d | ||
|   | 448f448d14 | ||
|   | ee6a618116 | ||
|   | e08f81c891 | ||
|   | 9324f1c29f | ||
|   | d71c1514f2 | ||
|   | 2df75e84e7 | ||
|   | 9ab89734de | ||
|   | 960c0319c4 | ||
|   | 439891cb9f | ||
|   | bdfb3ef11c | ||
|   | 8d581f7fe4 | ||
|   | 262907d0a3 | ||
|   | 15be673054 | ||
|   | 16a5649670 | ||
|   | 6582895b51 | ||
|   | e3d65389d7 | ||
|   | 027cb376f3 | ||
|   | f1261bcdd7 | ||
|   | 2e7b36d04f | ||
|   | ce1a58414a | ||
|   | 1012c5705a | ||
|   | 1c2947581b | ||
|   | 00883822be | ||
|   | 13fdb9d8a5 | ||
|   | 52b2bc4109 | ||
|   | b59b3a5152 | ||
|   | fe6c03370e | ||
|   | e3f128875c | ||
|   | 7bf82a814b | ||
|   | e1270928a3 | ||
|   | 6fce5b54a8 | ||
|   | 3c38eafd75 | ||
|   | 9dcc1b3370 | ||
|   | e3c37aac28 | ||
|   | 61a967095d | ||
|   | c0e004ec1c | ||
|   | 0a1b7296b9 | ||
|   | cd5e6743f7 | ||
|   | 2091fe530f | ||
|   | cda8d63d43 | ||
|   | bef1b140e9 | ||
|   | c9188e2260 | ||
|   | 15eaf27bc7 | ||
|   | bf2277e263 | ||
|   | 348ffbc47e | ||
|   | f13cbcf175 | ||
|   | 9418c56fd3 | ||
|   | 7dbd502931 | ||
|   | 0bf9c1e881 | ||
|   | bf07d37737 | ||
|   | eecb713616 | ||
|   | bf085e2c4b | ||
|   | ce1a97d6c8 | ||
|   | 34c9ec4e1a | ||
|   | e73fb6808a | ||
|   | 1c93d9dcfe | ||
|   | 675d6ec5e6 | ||
|   | 1ad43c54c0 | ||
|   | 1cf6c15ab4 | ||
|   | 8fc17ed764 | ||
|   | 26028068e8 | ||
|   | 8519682564 | ||
|   | 5ca0c73e98 | ||
|   | 4c979aa44f | ||
|   | 274dc3ecac | ||
|   | 5e2b5edde5 | ||
|   | b8b6521659 | ||
|   | e37b1b0623 | ||
|   | 4a79462c3e | ||
|   | c328cc9608 | ||
|   | cf2d39220a | ||
|   | 7dbd649f60 | ||
|   | 4282199bb4 | ||
|   | 7071dd0162 | ||
|   | e61a687eda | ||
|   | 7e85d2fbd4 | ||
|   | 969ab28261 | ||
|   | 90d36cc630 | ||
|   | 1bb68cbcfa | ||
|   | de7a14003c | ||
|   | e3ead9f585 | ||
|   | a461b0ae44 | ||
|   | 1b28f9fa89 | ||
|   | dff8076022 | ||
|   | dd3c187484 | ||
|   | 4677778f85 | ||
|   | f96204dbe0 | ||
|   | 0427b783e2 | ||
|   | 4650732f4a | ||
|   | 1e138c1401 | ||
|   | 89fb7c85bf | ||
|   | 0e51fc90e3 | 
| @@ -5,7 +5,7 @@ aclocal.m4.bak | |||||||
| autom4te.cache | autom4te.cache | ||||||
| compile | compile | ||||||
| config.guess | config.guess | ||||||
| config.h | curl_config.h | ||||||
| config.log | config.log | ||||||
| config.lt | config.lt | ||||||
| config.status | config.status | ||||||
|   | |||||||
							
								
								
									
										65
									
								
								Android.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								Android.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | # Google Android makefile for curl and libcurl | ||||||
|  | # Place the curl source (including this makefile) into external/curl/ in the | ||||||
|  | # Android source tree.  Then build them with 'make curl' or just 'make libcurl' | ||||||
|  | # from the Android root. | ||||||
|  | # | ||||||
|  | # Note: you must first create a curl_config.h file by running configure in the | ||||||
|  | # Android environment. I haven't found an easy way to do this yet. If there is | ||||||
|  | # no easy way, a static config-android.h may need to be created and checked in | ||||||
|  | # to the libcurl source tree. | ||||||
|  | # | ||||||
|  | # Dan Fandrich | ||||||
|  | # July 2009 | ||||||
|  |  | ||||||
|  | LOCAL_PATH:= $(call my-dir) | ||||||
|  |  | ||||||
|  | common_CFLAGS := -Wpointer-arith -Wwrite-strings -Wunused -Winline -Wnested-externs -Wmissing-declarations -Wmissing-prototypes -Wno-long-long -Wfloat-equal -Wno-multichar -Wsign-compare -Wno-format-nonliteral -Wendif-labels -Wstrict-prototypes -Wdeclaration-after-statement -Wno-system-headers -DHAVE_CONFIG_H | ||||||
|  |  | ||||||
|  | ######################### | ||||||
|  | # Build the libcurl library | ||||||
|  |  | ||||||
|  | include $(CLEAR_VARS) | ||||||
|  | include $(LOCAL_PATH)/lib/Makefile.inc | ||||||
|  | CURL_HEADERS := \ | ||||||
|  | 	curlbuild.h \ | ||||||
|  | 	curl.h \ | ||||||
|  | 	curlrules.h \ | ||||||
|  | 	curlver.h \ | ||||||
|  | 	easy.h \ | ||||||
|  | 	mprintf.h \ | ||||||
|  | 	multi.h \ | ||||||
|  | 	stdcheaders.h \ | ||||||
|  | 	typecheck-gcc.h \ | ||||||
|  | 	types.h | ||||||
|  |  | ||||||
|  | LOCAL_SRC_FILES := $(addprefix lib/,$(CSOURCES)) | ||||||
|  | LOCAL_C_INCLUDES += $(LOCAL_PATH)/include/ | ||||||
|  | LOCAL_CFLAGS += $(common_CFLAGS) | ||||||
|  |  | ||||||
|  | LOCAL_COPY_HEADERS_TO := libcurl/curl | ||||||
|  | LOCAL_COPY_HEADERS := $(addprefix include/curl/,$(CURL_HEADERS)) | ||||||
|  |  | ||||||
|  | LOCAL_MODULE:= libcurl | ||||||
|  |  | ||||||
|  | include $(BUILD_STATIC_LIBRARY) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ######################### | ||||||
|  | # Build the curl binary | ||||||
|  |  | ||||||
|  | include $(CLEAR_VARS) | ||||||
|  | include $(LOCAL_PATH)/src/Makefile.inc | ||||||
|  | LOCAL_SRC_FILES := $(addprefix src/,$(CURL_SOURCES)) | ||||||
|  |  | ||||||
|  | LOCAL_MODULE := curl | ||||||
|  | LOCAL_STATIC_LIBRARIES := libcurl | ||||||
|  | LOCAL_SYSTEM_SHARED_LIBRARIES := libc | ||||||
|  |  | ||||||
|  | LOCAL_C_INCLUDES += $(LOCAL_PATH)/include $(LOCAL_PATH)/lib | ||||||
|  |  | ||||||
|  | # This will also need to include $(CURLX_ONES) in order to correctly build | ||||||
|  | # a dynamic library | ||||||
|  | LOCAL_CFLAGS += $(common_CFLAGS) | ||||||
|  |  | ||||||
|  | include $(BUILD_EXECUTABLE) | ||||||
|  |  | ||||||
							
								
								
									
										316
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										316
									
								
								CHANGES
									
									
									
									
									
								
							| @@ -6,6 +6,322 @@ | |||||||
|  |  | ||||||
|                                   Changelog |                                   Changelog | ||||||
|  |  | ||||||
|  | Version 7.19.6 (12 August 2009) | ||||||
|  |  | ||||||
|  | Daniel Stenberg (12 Aug 2009) | ||||||
|  | - Carsten Lange reported a bug and provided a patch for TFTP upload and the | ||||||
|  |   sending of the TSIZE option. I don't like fixing bugs just hours before | ||||||
|  |   a release, but since it was broken and the patch fixes this for him I decided | ||||||
|  |   to get it in anyway. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (11 Aug 2009) | ||||||
|  | - Peter Sylvester made the HTTPS test server use specific certificates for | ||||||
|  |   each test, so that the test suite can now be used to actually test the | ||||||
|  |   verification of cert names etc. This made an error show up in the OpenSSL- | ||||||
|  |   specific code where it would attempt to match the CN field even if a | ||||||
|  |   subjectAltName exists that doesn't match. This is now fixed and verified | ||||||
|  |   in test 311. | ||||||
|  |  | ||||||
|  | - Benbuck Nason posted the bug report #2835196 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=2835196), fixing a few compiler | ||||||
|  |   warnings when mixing ints and bools. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (10 Aug 2009) | ||||||
|  | - Fixed a memory leak in the FTP code and an off-by-one heap buffer overflow. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (9 Aug 2009) | ||||||
|  | - Fixed some memory leaks in the command-line tool that caused most of the | ||||||
|  |   torture tests to fail. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (2 Aug 2009) | ||||||
|  | - Curt Bogmine reported a problem with SNI enabled on a particular server. We | ||||||
|  |   should introduce an option to disable SNI, but as we're in feature freeze | ||||||
|  |   now I've addressed the obvious bug here (pointed out by Peter Sylvester): we | ||||||
|  |   shouldn't try to enable SNI when SSLv2 or SSLv3 is explicitly selected. | ||||||
|  |   Code for OpenSSL and GnuTLS was fixed. NSS doesn't seem to have a particular | ||||||
|  |   option for SNI, or are we simply not using it? | ||||||
|  |  | ||||||
|  | Daniel Stenberg (1 Aug 2009) | ||||||
|  | - Scott Cantor posted the bug report #2829955 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=2829955) mentioning the recent SSL cert | ||||||
|  |   verification flaw found and exploited by Moxie Marlinspike. The presentation | ||||||
|  |   he did at Black Hat is available here: | ||||||
|  |   https://www.blackhat.com/html/bh-usa-09/bh-usa-09-archives.html#Marlinspike | ||||||
|  |  | ||||||
|  |   Apparently at least one CA allowed a subjectAltName or CN that contain a | ||||||
|  |   zero byte, and thus clients that assumed they would never have zero bytes | ||||||
|  |   were exploited to OK a certificate that didn't actually match the site. Like | ||||||
|  |   if the name in the cert was "example.com\0theatualsite.com", libcurl would | ||||||
|  |   happily verify that cert for example.com. | ||||||
|  |  | ||||||
|  |   libcurl now better uses the length of the extracted name, not using the zero | ||||||
|  |   termination for getting the string length. | ||||||
|  |  | ||||||
|  |   This fixing only made and needed in OpenSSL interfacing code. | ||||||
|  |  | ||||||
|  | - Tanguy Fautre pointed out that OpenSSL's function RAND_screen() (present | ||||||
|  |   only in some OpenSSL installs - like on Windows) isn't thread-safe and we | ||||||
|  |   agreed that moving it to the global_init() function is a decent way to deal | ||||||
|  |   with this situation. | ||||||
|  |  | ||||||
|  | - Alexander Beedie provided the patch for a noproxy problem: If I have set | ||||||
|  |   CURLOPT_NOPROXY to "*", or to a host that should not use a proxy, I actually | ||||||
|  |   could still end up using a proxy if a proxy environment variable was set. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (27 Jul 2009) | ||||||
|  | - All the quote options (CURLOPT_QUOTE, CURLOPT_POSTQUOTE and | ||||||
|  |   CURLOPT_PREQUOTE) now accept a preceeding asterisk before the command to | ||||||
|  |   send when using FTP, as a sign that libcurl shall simply ignore the response | ||||||
|  |   from the server instead of treating it as an error. Not treating a 400+ FTP | ||||||
|  |   response code as an error means that failed commands will not abort the | ||||||
|  |   chain of commands, nor will they cause the connection to get disconnected. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (26 Jul 2009) | ||||||
|  | - Johan van Selst posted bug report #2825989 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=2825989) pointing out that | ||||||
|  |   OpenSSL-powered libcurl didn't support the SHA-2 digest algorithm, and | ||||||
|  |   provided the solution too: to use OpenSSL_add_all_algorithms() in addition | ||||||
|  |   to the older SSLeay_* alternative. OpenSSL_add_all_algorithms was added in | ||||||
|  |   OpenSSL 0.9.5 | ||||||
|  |  | ||||||
|  | Daniel Stenberg (23 Jul 2009) | ||||||
|  | - Added CURLOPT_SSH_KNOWNHOSTS, CURLOPT_SSH_KEYFUNCTION, CURLOPT_SSH_KEYDATA. | ||||||
|  |   They introduce known_host support for SSH keys to libcurl. See docs for | ||||||
|  |   details. Note that this feature depends on a new enough libssh2 version, to | ||||||
|  |   be supported in libssh2 1.2 and later (or current git repo at this time). | ||||||
|  |  | ||||||
|  | Michal Marek (22 Jul 2009) | ||||||
|  | - David Binderman found a memory and fd leak in lib/gtls.c:load_file() | ||||||
|  |   (https://bugzilla.novell.com/523919). When looking at the code, I found that | ||||||
|  |   also the ptr pointer can leak. | ||||||
|  |  | ||||||
|  | Kamil Dudka (20 Jul 2009) | ||||||
|  | - Claes Jakobsson improved the support for client certificates handling in | ||||||
|  |   NSS-powered libcurl. Now the client certificates can be selected | ||||||
|  |   automatically by a NSS built-in hook. Additionally pre-login to all PKCS11 | ||||||
|  |   slots is no more performed. It used to cause problems with HW tokens. | ||||||
|  |  | ||||||
|  | - Fixed reference counting for NSS client certificates. Now the PEM reader | ||||||
|  |   module should be always properly unloaded on Curl_nss_cleanup(). If the | ||||||
|  |   unload fails though, libcurl will try to reuse the already loaded instance. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (15 Jul 2009) | ||||||
|  | - Added nonblock.c to the non-automake makefiles (note that the dependencies | ||||||
|  |   in the Watcom makefiles aren't quite correct). | ||||||
|  |  | ||||||
|  | Michal Marek (15 Jul 2009) | ||||||
|  | - Changed the description of CURLINFO_OS_ERRNO to make it clear that the | ||||||
|  |   errno is not reset on success. | ||||||
|  |  | ||||||
|  | Guenter Knauf (14 Jul 2009) | ||||||
|  | - renamed generated config.h to curl_config.h to avoid any future clashes | ||||||
|  |   with config.h from other projects. | ||||||
|  |    | ||||||
|  | Daniel Stenberg (9 Jul 2009) | ||||||
|  | - Eric Wong introduced curlx_nonblock() that the curl tool now (re-)uses for | ||||||
|  |   setting a file descriptor non-blocking. Used by the functionality Eric | ||||||
|  |   himself brough on June 15th. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (8 Jul 2009) | ||||||
|  | - Constantine Sapuntzakis posted bug report #2813123 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=2813123) and an a patch that fixes the | ||||||
|  |   problem: | ||||||
|  |  | ||||||
|  |   Url A is accessed using auth. Url A redirects to Url B (on a different | ||||||
|  |   server0. Url B reuses a persistent connection. Url B has auth, even though | ||||||
|  |   it's on a different server. | ||||||
|  |  | ||||||
|  |   Note: if Url B does not reuse a persistent connection, auth is not sent. | ||||||
|  |  | ||||||
|  |   reason: | ||||||
|  |  | ||||||
|  |   data->state.first_host is not initialized becuase Curl_http_connect is not | ||||||
|  |   called when a connection is reused. | ||||||
|  |  | ||||||
|  |   Solution: | ||||||
|  |  | ||||||
|  |   move initialization of data->state.first_host to Curl_http. No code before | ||||||
|  |   Curl_http uses data->state.first_host anyway. | ||||||
|  |  | ||||||
|  | Guenter Knauf (4 Jul 2009) | ||||||
|  | - Markus Koetter provided a patch to avoid getnameinfo() usage which broke a | ||||||
|  |   couple of both IPv4 and IPv6 autobuilds. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (29 Jun 2009) | ||||||
|  | - Markus Koetter made CURLOPT_FTPPORT (and curl's -P/--ftpport) support a port | ||||||
|  |   range if given colon-separated after the host name/address part. Like | ||||||
|  |   "192.168.0.1:2000-10000" | ||||||
|  |  | ||||||
|  | - Modified the separators used for CURLOPT_CERTINFO in multi-part outputs. I | ||||||
|  |   don't know how they got wrong in the first place, but using this output | ||||||
|  |   format makes it possible to quite easily separate the string into an array | ||||||
|  |   of multiple items. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (16 June 2009) | ||||||
|  | - Added a few more compiler warning options for gcc. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (16 Jun 2009) | ||||||
|  | - Reuven Wachtfogel made curl -o - properly produce a binary output on windows | ||||||
|  |   (no newline translations). Use -B/--use-ascii if you rather get the ascii | ||||||
|  |   approach. | ||||||
|  |  | ||||||
|  | Michal Marek (16 Jun 2009) | ||||||
|  | - When doing non-anonymous ftp via http proxies and the password is not | ||||||
|  |   provided in the url, add it there (squid needs this). | ||||||
|  |  | ||||||
|  | Daniel Stenberg (15 Jun 2009) | ||||||
|  | - Eric Wong's patch: | ||||||
|  |  | ||||||
|  |   This allows curl(1) to be used as a client-side tunnel for arbitrary stream | ||||||
|  |   protocols by abusing chunked transfer encoding in both the HTTP request and | ||||||
|  |   HTTP response.  This requires server support for sending a response while a | ||||||
|  |   request is still being read, of course. | ||||||
|  |  | ||||||
|  |   If attempting to read from stdin returns EAGAIN, then we pause our sender. | ||||||
|  |   This leaves curl to attempt to read from the socket while reading from stdin | ||||||
|  |   (and thus sending) is paused. | ||||||
|  |  | ||||||
|  |   This change was needed to allow successfully tunneling the git protocol over | ||||||
|  |   HTTP (--no-buffer is needed, as well). | ||||||
|  |  | ||||||
|  | Patrick Monnerat (15 Jun 2009) | ||||||
|  | - Replaced use of standard C library rand()/srand() by our own pseudo-random | ||||||
|  |   number generator. | ||||||
|  |  | ||||||
|  | Yang Tse (11 Jun 2009) | ||||||
|  | - I adapted testcurl script to allow building test harness programs when | ||||||
|  |   cross-compiling for a *-*-mingw* host. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (10 Jun 2009) | ||||||
|  | - Fabian Keil ran clang on the (lib)curl code, found a bunch of warnings and | ||||||
|  |   contributed a range of patches to fix them. | ||||||
|  |  | ||||||
|  | Yang Tse (10 Jun 2009) | ||||||
|  | - I introduced configure script option --enable-curldebug which now allows | ||||||
|  |   the decoupled enabling or disabling of the curl debug memory tracking | ||||||
|  |   feature from the --enable-debug option which no longer controls this. | ||||||
|  |  | ||||||
|  |   curl --version will list 'Debug' feature for debug enabled builds, and | ||||||
|  |   will list 'TrackMemory' feature for curl debug memory tracking capable | ||||||
|  |   builds. These features are independent and can be controlled when running | ||||||
|  |   the configure script. When --enable-debug is given both features will be | ||||||
|  |   enabled, unless some restriction prevents memory tracking from being used. | ||||||
|  |  | ||||||
|  |   Internally, definition of preprocessor symbol DEBUGBUILD restricts code | ||||||
|  |   which is only compiled for debug enabled builds. And symbol CURLDEBUG is | ||||||
|  |   used to differentiate code which is _only_ used for memory tracking. | ||||||
|  |  | ||||||
|  | Yang Tse (9 Jun 2009) | ||||||
|  | - Daniel Steinberg pointed out that Curl_FormInit() in formdata.c was not | ||||||
|  |   initializing the fread callback pointer and this triggered a compiler | ||||||
|  |   warning, also provided a friendly suggestion on how to fix it. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (8 Jun 2009) | ||||||
|  | - Claes Jakobsson provided a patch for libcurl-NSS that fixed a bad refcount | ||||||
|  |   issue with client certs that caused issues like segfaults. | ||||||
|  |   http://curl.haxx.se/mail/lib-2009-05/0316.html | ||||||
|  |  | ||||||
|  | - Triggered by bug report #2798852 and the patch in there, I fixed configure | ||||||
|  |   to detect gnutls build options with pkg-config only and not libgnutls-config | ||||||
|  |   anymore since GnuTLS has stopped distributing that tool. If an explicit path | ||||||
|  |   is given to configure, we will instead guess on how to link and use that | ||||||
|  |   lib. I did not use the patch from the bug report. | ||||||
|  |  | ||||||
|  | Yang Tse (8 Jun 2009) | ||||||
|  | - Igor Novoseltsev adjusted Makefile.vxworks to get sources and headers | ||||||
|  |   included from Makefile.inc, and provided docs\INSTALL VxWorks section. | ||||||
|  |  | ||||||
|  | - I removed buildconf.bat from release and daily snapshot archives. This | ||||||
|  |   file is only for CVS tree checkout builds. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (8 Jun 2009) | ||||||
|  | - Eric Wong fixed --no-buffer to actually switch off output buffering. Been | ||||||
|  |   broken since 7.19.0 | ||||||
|  |  | ||||||
|  | Bill Hoffman (6 Jun 2009) | ||||||
|  | - Added some cmake docs and fixed socklen_t in the build. | ||||||
|  |  | ||||||
|  | Yang Tse (5 Jun 2009) | ||||||
|  | - John E. Malmberg provided VMS specific patch: "This fixes an existing bug | ||||||
|  |   in urlglob.c where it was not converting the Curl Unix exit code to a VMS | ||||||
|  |   DCL compatible exit code.  This fix required the enhancement described next. | ||||||
|  |   This also adds an enhancement to main.c so that when curl is run under a | ||||||
|  |   Unix shell like Bash on VMS, it will return the standard Unix exit codes | ||||||
|  |   and messages." And another patch for docs/examples. | ||||||
|  |  | ||||||
|  |   I introduced os-specific.c and os-specific.h for use in curl tool code | ||||||
|  |   and adjusted John E. Malmberg's patch placement to use these new files | ||||||
|  |   as an effort to prevent main.c from growing ad infinitum. Code already | ||||||
|  |   existing in main.c which is OS specific should be moved into these files. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (4 June 2009) | ||||||
|  | - Setting the Content-Length: header from your app when you do a POST or PUT | ||||||
|  |   is almost always a VERY BAD IDEA. Yet there are still apps out there doing | ||||||
|  |   this, and now recently it triggered a bug/side-effect in libcurl as when | ||||||
|  |   libcurl sends a POST or PUT with NTLM, it sends an empty post first when it | ||||||
|  |   knows it will just get a 401/407 back. If the app then replaced the | ||||||
|  |   Content-Length header, it caused the server to wait for input that libcurl | ||||||
|  |   wouldn't send. Aaron Oneal reported this problem in bug report #2799008 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=2799008) and helped us verify the fix. | ||||||
|  |  | ||||||
|  | Yang Tse (4 Jun 2009) | ||||||
|  | - Igor Novoseltsev provided patches and information, that after some | ||||||
|  |   adjustments to better fit curl's way of doing things, have resulted | ||||||
|  |   in the posibility of building libcurl for VxWorks. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (2 June 2009) | ||||||
|  | - Checked in a Google Android make file. To use it, you must first | ||||||
|  |   create a config.h file by running configure in the Android environment, | ||||||
|  |   which doesn't seem to be easy to do. If no easy way can be found, a | ||||||
|  |   static config-android.h may need to be created and checked in to the | ||||||
|  |   libcurl source tree. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (1 June 2009) | ||||||
|  | - Claes Jakobsson fixed the configure script to better find and use NSS | ||||||
|  |   without pkg-config. | ||||||
|  |  | ||||||
|  | Yang Tse (1 Jun 2009) | ||||||
|  | - John E. Malmberg provided a VMS specific clean-up for curl.h, and pointed | ||||||
|  |   out that the configure script was failing to detect the timeval struct on | ||||||
|  |   VMS when building with _XOPEN_SOURCE_EXTENDED undefined due to definition | ||||||
|  |   taking place in socket.h instead of time.h.  I have adjusted configure | ||||||
|  |   script to also include this header when checking struct timeval. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (27 May 2009) | ||||||
|  | - Frank McGeough provided a small OpenSSL #include fix to make libcurl compile | ||||||
|  |   fine with Nokia 5th edition 1.0 SDK for Symbian. | ||||||
|  |  | ||||||
|  | - Andre Guibert de Bruet found a call to a OpenSSL function that didn't check | ||||||
|  |   for a failure properly. | ||||||
|  |  | ||||||
|  | - Mike Crowe pointed out that setting CURLOPT_USERPWD to NULL used to clear | ||||||
|  |   the auth credentials back in 7.19.0 and earlier while now you have to set "" | ||||||
|  |   to get the same effect. His patch brings back the ability to use NULL. | ||||||
|  |  | ||||||
|  | - Claes Jakobsson fixed libcurl-NSS to build fine even without the | ||||||
|  |   PK11_CreateGenericObject() function. | ||||||
|  |  | ||||||
|  | Daniel Stenberg (25 May 2009) | ||||||
|  | - bug report #2796358 (http://curl.haxx.se/bug/view.cgi?id=2796358) pointed | ||||||
|  |   out that the cookie parser would leak memory when it parses cookies that are | ||||||
|  |   received with domain, path etc set multiple times in the same header. While | ||||||
|  |   such a cookie is questionable, they occur in the wild and libcurl no longer | ||||||
|  |   leaks memory for them. I added such a header to test case 8. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (22 May 2009) | ||||||
|  | - Removed some obsolete digest code that caused a valgrind error in test 551. | ||||||
|  |  | ||||||
|  | Daniel Fandrich (20 May 2009) | ||||||
|  | - Added "non-existing host" test keywords to make it easy to skip those | ||||||
|  |   tests on machines that have broken DNS configurations (such as | ||||||
|  |   those configured to use OpenDNS). | ||||||
|  |  | ||||||
|  | Daniel Stenberg (19 May 2009) | ||||||
|  | - Kamil Dudka brought the patch from the Redhat bug entry | ||||||
|  |   https://bugzilla.redhat.com/show_bug.cgi?id=427966 which was libcurl closing | ||||||
|  |   a bad file descriptor when closing down the FTP data connection.  Caolan | ||||||
|  |   McNamara seems to be the original author of it. | ||||||
|  |  | ||||||
| Version 7.19.5 (18 May 2009) | Version 7.19.5 (18 May 2009) | ||||||
|  |  | ||||||
| Daniel Stenberg (17 May 2009) | Daniel Stenberg (17 May 2009) | ||||||
|   | |||||||
| @@ -6,6 +6,13 @@ | |||||||
| #  include <sys/types.h> | #  include <sys/types.h> | ||||||
| #endif /* HAVE_SYS_TYPES_H */ | #endif /* HAVE_SYS_TYPES_H */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #ifdef _WIN32 | ||||||
|  | #  include <winsock2.h> | ||||||
|  | #  include <ws2tcpip.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef HAVE_STDINT_H | #ifdef HAVE_STDINT_H | ||||||
| #  include <stdint.h> | #  include <stdint.h> | ||||||
| #endif /* HAVE_STDINT_H */ | #endif /* HAVE_STDINT_H */ | ||||||
|   | |||||||
| @@ -6,51 +6,51 @@ | |||||||
| #  VARIABLE - variable to store size if the type exists. | #  VARIABLE - variable to store size if the type exists. | ||||||
| #  HAVE_${VARIABLE} - does the variable exists or not | #  HAVE_${VARIABLE} - does the variable exists or not | ||||||
|  |  | ||||||
| MACRO(CHECK_TYPE_SIZE TYPE VARIABLE) | macro(CHECK_TYPE_SIZE TYPE VARIABLE) | ||||||
|   SET(CMAKE_ALLOW_UNKNOWN_VARIABLE_READ_ACCESS 1) |   set(CMAKE_ALLOW_UNKNOWN_VARIABLE_READ_ACCESS 1) | ||||||
|   IF(NOT DEFINED ${VARIABLE}) |   if(NOT DEFINED ${VARIABLE}) | ||||||
|   IF("HAVE_${VARIABLE}" MATCHES "^HAVE_${VARIABLE}$") |     if("HAVE_${VARIABLE}" MATCHES "^HAVE_${VARIABLE}$") | ||||||
|     SET(CHECK_TYPE_SIZE_TYPE "${TYPE}") |       set(CHECK_TYPE_SIZE_TYPE "${TYPE}") | ||||||
|     SET(MACRO_CHECK_TYPE_SIZE_FLAGS  |       set(MACRO_CHECK_TYPE_SIZE_FLAGS  | ||||||
|       "${CMAKE_REQUIRED_FLAGS}") |         "${CMAKE_REQUIRED_FLAGS}") | ||||||
|     FOREACH(def HAVE_SYS_TYPES_H HAVE_STDINT_H HAVE_STDDEF_H) |       foreach(def HAVE_SYS_TYPES_H HAVE_STDINT_H HAVE_STDDEF_H) | ||||||
|       IF("${def}") |         if("${def}") | ||||||
|         SET(MACRO_CHECK_TYPE_SIZE_FLAGS  |           set(MACRO_CHECK_TYPE_SIZE_FLAGS  | ||||||
|           "${MACRO_CHECK_TYPE_SIZE_FLAGS} -D${def}") |             "${MACRO_CHECK_TYPE_SIZE_FLAGS} -D${def}") | ||||||
|       ENDIF("${def}") |         endif("${def}") | ||||||
|     ENDFOREACH(def) |       endforeach(def) | ||||||
|     SET(CHECK_TYPE_SIZE_PREMAIN) |       set(CHECK_TYPE_SIZE_PREMAIN) | ||||||
|     FOREACH(def ${CMAKE_EXTRA_INCLUDE_FILES}) |       foreach(def ${CMAKE_EXTRA_INCLUDE_FILES}) | ||||||
|       SET(CHECK_TYPE_SIZE_PREMAIN "${CHECK_TYPE_SIZE_PREMAIN}#include \"${def}\"\n") |         set(CHECK_TYPE_SIZE_PREMAIN "${CHECK_TYPE_SIZE_PREMAIN}#include \"${def}\"\n") | ||||||
|     ENDFOREACH(def) |       endforeach(def) | ||||||
|     CONFIGURE_FILE( |       configure_file( | ||||||
|       "${CMAKE_CURRENT_SOURCE_DIR}/CMake/CheckTypeSize.c.in" |         "${CMAKE_CURRENT_SOURCE_DIR}/CMake/CheckTypeSize.c.in" | ||||||
|       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckTypeSize.c"  |         "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckTypeSize.c"  | ||||||
|       IMMEDIATE @ONLY) |         IMMEDIATE @ONLY) | ||||||
|     FILE(READ  |       file(READ  | ||||||
|       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckTypeSize.c" |         "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckTypeSize.c" | ||||||
|       CHECK_TYPE_SIZE_FILE_CONTENT) |         CHECK_TYPE_SIZE_FILE_CONTENT) | ||||||
|     MESSAGE(STATUS "Check size of ${TYPE}") |       message(STATUS "Check size of ${TYPE}") | ||||||
|     IF(CMAKE_REQUIRED_LIBRARIES) |       if(CMAKE_REQUIRED_LIBRARIES) | ||||||
|       SET(CHECK_TYPE_SIZE_ADD_LIBRARIES  |         set(CHECK_TYPE_SIZE_ADD_LIBRARIES  | ||||||
|         "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") |           "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") | ||||||
|     ENDIF(CMAKE_REQUIRED_LIBRARIES) |       endif(CMAKE_REQUIRED_LIBRARIES) | ||||||
|     TRY_RUN(${VARIABLE} HAVE_${VARIABLE} |       try_run(${VARIABLE} HAVE_${VARIABLE} | ||||||
|       ${CMAKE_BINARY_DIR} |         ${CMAKE_BINARY_DIR} | ||||||
|       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckTypeSize.c" |         "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckTypeSize.c" | ||||||
|       CMAKE_FLAGS -DCOMPILE_DEFINITIONS:STRING=${MACRO_CHECK_TYPE_SIZE_FLAGS} |         CMAKE_FLAGS -DCOMPILE_DEFINITIONS:STRING=${MACRO_CHECK_TYPE_SIZE_FLAGS} | ||||||
|       "${CHECK_TYPE_SIZE_ADD_LIBRARIES}" |         "${CHECK_TYPE_SIZE_ADD_LIBRARIES}" | ||||||
|       OUTPUT_VARIABLE OUTPUT) |         OUTPUT_VARIABLE OUTPUT) | ||||||
|     IF(HAVE_${VARIABLE}) |       if(HAVE_${VARIABLE}) | ||||||
|       MESSAGE(STATUS "Check size of ${TYPE} - done") |         message(STATUS "Check size of ${TYPE} - done") | ||||||
|       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log  |         file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log  | ||||||
|         "Determining size of ${TYPE} passed with the following output:\n${OUTPUT}\n\n") |           "Determining size of ${TYPE} passed with the following output:\n${OUTPUT}\n\n") | ||||||
|     ELSE(HAVE_${VARIABLE}) |       else(HAVE_${VARIABLE}) | ||||||
|       MESSAGE(STATUS "Check size of ${TYPE} - failed") |         message(STATUS "Check size of ${TYPE} - failed") | ||||||
|       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log  |         file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log  | ||||||
|         "Determining size of ${TYPE} failed with the following output:\n${OUTPUT}\nCheckTypeSize.c:\n${CHECK_TYPE_SIZE_FILE_CONTENT}\n\n") |           "Determining size of ${TYPE} failed with the following output:\n${OUTPUT}\nCheckTypeSize.c:\n${CHECK_TYPE_SIZE_FILE_CONTENT}\n\n") | ||||||
|     ENDIF(HAVE_${VARIABLE}) |       endif(HAVE_${VARIABLE}) | ||||||
|   ENDIF("HAVE_${VARIABLE}" MATCHES "^HAVE_${VARIABLE}$") |     endif("HAVE_${VARIABLE}" MATCHES "^HAVE_${VARIABLE}$") | ||||||
|   ENDIF(NOT DEFINED ${VARIABLE}) |   endif(NOT DEFINED ${VARIABLE}) | ||||||
|   SET(CMAKE_ALLOW_UNKNOWN_VARIABLE_READ_ACCESS ) |   set(CMAKE_ALLOW_UNKNOWN_VARIABLE_READ_ACCESS ) | ||||||
| ENDMACRO(CHECK_TYPE_SIZE) | endmacro(CHECK_TYPE_SIZE) | ||||||
|   | |||||||
| @@ -12,43 +12,43 @@ | |||||||
| #  CMAKE_REQUIRED_INCLUDES = list of include directories | #  CMAKE_REQUIRED_INCLUDES = list of include directories | ||||||
| #  CMAKE_REQUIRED_LIBRARIES = list of libraries to link | #  CMAKE_REQUIRED_LIBRARIES = list of libraries to link | ||||||
|  |  | ||||||
| MACRO(CURL_CHECK_C_SOURCE_COMPILES SOURCE VAR) | macro(CURL_CHECK_C_SOURCE_COMPILES SOURCE VAR) | ||||||
|   IF("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") |   if("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") | ||||||
|     SET(message "${VAR}") |     set(message "${VAR}") | ||||||
|     # If the number of arguments is greater than 2 (SOURCE VAR) |     # If the number of arguments is greater than 2 (SOURCE VAR) | ||||||
|     IF(${ARGC} GREATER 2) |     if(${ARGC} GREATER 2) | ||||||
|       # then add the third argument as a message |       # then add the third argument as a message | ||||||
|       SET(message "${ARGV2} (${VAR})") |       set(message "${ARGV2} (${VAR})") | ||||||
|     ENDIF(${ARGC} GREATER 2) |     endif(${ARGC} GREATER 2) | ||||||
|     SET(MACRO_CHECK_FUNCTION_DEFINITIONS |     set(MACRO_CHECK_FUNCTION_DEFINITIONS | ||||||
|       "-D${VAR} ${CMAKE_REQUIRED_FLAGS}") |       "-D${VAR} ${CMAKE_REQUIRED_FLAGS}") | ||||||
|     IF(CMAKE_REQUIRED_LIBRARIES) |     if(CMAKE_REQUIRED_LIBRARIES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES | ||||||
|         "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") |         "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") | ||||||
|     ELSE(CMAKE_REQUIRED_LIBRARIES) |     else(CMAKE_REQUIRED_LIBRARIES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES) |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES) | ||||||
|     ENDIF(CMAKE_REQUIRED_LIBRARIES) |     endif(CMAKE_REQUIRED_LIBRARIES) | ||||||
|     IF(CMAKE_REQUIRED_INCLUDES) |     if(CMAKE_REQUIRED_INCLUDES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES | ||||||
|         "-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}") |         "-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}") | ||||||
|     ELSE(CMAKE_REQUIRED_INCLUDES) |     else(CMAKE_REQUIRED_INCLUDES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES) |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES) | ||||||
|     ENDIF(CMAKE_REQUIRED_INCLUDES) |     endif(CMAKE_REQUIRED_INCLUDES) | ||||||
|     SET(src "") |     set(src "") | ||||||
|     FOREACH(def ${EXTRA_DEFINES}) |     foreach(def ${EXTRA_DEFINES}) | ||||||
|       SET(src "${src}#define ${def} 1\n") |       set(src "${src}#define ${def} 1\n") | ||||||
|     ENDFOREACH(def) |     endforeach(def) | ||||||
|     FOREACH(inc ${HEADER_INCLUDES}) |     foreach(inc ${HEADER_INCLUDES}) | ||||||
|       SET(src "${src}#include <${inc}>\n") |       set(src "${src}#include <${inc}>\n") | ||||||
|     ENDFOREACH(inc) |     endforeach(inc) | ||||||
|  |  | ||||||
|     SET(src "${src}\nint main() { ${SOURCE} ; return 0; }") |     set(src "${src}\nint main() { ${SOURCE} ; return 0; }") | ||||||
|     SET(CMAKE_CONFIGURABLE_FILE_CONTENT "${src}") |     set(CMAKE_CONFIGURABLE_FILE_CONTENT "${src}") | ||||||
|     CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/CMake/CMakeConfigurableFile.in |     configure_file(${CMAKE_CURRENT_SOURCE_DIR}/CMake/CMakeConfigurableFile.in | ||||||
|       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c" |       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c" | ||||||
|       IMMEDIATE) |       IMMEDIATE) | ||||||
|     MESSAGE(STATUS "Performing Test ${message}") |     message(STATUS "Performing Test ${message}") | ||||||
|     TRY_COMPILE(${VAR} |     try_compile(${VAR} | ||||||
|       ${CMAKE_BINARY_DIR} |       ${CMAKE_BINARY_DIR} | ||||||
|       ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c |       ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c | ||||||
|       COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} |       COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} | ||||||
| @@ -56,20 +56,20 @@ MACRO(CURL_CHECK_C_SOURCE_COMPILES SOURCE VAR) | |||||||
|       "${CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES}" |       "${CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES}" | ||||||
|       "${CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES}" |       "${CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES}" | ||||||
|       OUTPUT_VARIABLE OUTPUT) |       OUTPUT_VARIABLE OUTPUT) | ||||||
|     IF(${VAR}) |     if(${VAR}) | ||||||
|       SET(${VAR} 1 CACHE INTERNAL "Test ${message}") |       set(${VAR} 1 CACHE INTERNAL "Test ${message}") | ||||||
|       MESSAGE(STATUS "Performing Test ${message} - Success") |       message(STATUS "Performing Test ${message} - Success") | ||||||
|       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log |       file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log | ||||||
|         "Performing C SOURCE FILE Test ${message} succeded with the following output:\n" |         "Performing C SOURCE FILE Test ${message} succeded with the following output:\n" | ||||||
|         "${OUTPUT}\n" |         "${OUTPUT}\n" | ||||||
|         "Source file was:\n${src}\n") |         "Source file was:\n${src}\n") | ||||||
|     ELSE(${VAR}) |     else(${VAR}) | ||||||
|       MESSAGE(STATUS "Performing Test ${message} - Failed") |       message(STATUS "Performing Test ${message} - Failed") | ||||||
|       SET(${VAR} "" CACHE INTERNAL "Test ${message}") |       set(${VAR} "" CACHE INTERNAL "Test ${message}") | ||||||
|       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log |       file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log | ||||||
|         "Performing C SOURCE FILE Test ${message} failed with the following output:\n" |         "Performing C SOURCE FILE Test ${message} failed with the following output:\n" | ||||||
|         "${OUTPUT}\n" |         "${OUTPUT}\n" | ||||||
|         "Source file was:\n${src}\n") |         "Source file was:\n${src}\n") | ||||||
|     ENDIF(${VAR}) |     endif(${VAR}) | ||||||
|   ENDIF("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") |   endif("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") | ||||||
| ENDMACRO(CURL_CHECK_C_SOURCE_COMPILES) | endmacro(CURL_CHECK_C_SOURCE_COMPILES) | ||||||
|   | |||||||
| @@ -12,43 +12,43 @@ | |||||||
| #  CMAKE_REQUIRED_INCLUDES = list of include directories | #  CMAKE_REQUIRED_INCLUDES = list of include directories | ||||||
| #  CMAKE_REQUIRED_LIBRARIES = list of libraries to link | #  CMAKE_REQUIRED_LIBRARIES = list of libraries to link | ||||||
|  |  | ||||||
| MACRO(CURL_CHECK_C_SOURCE_RUNS SOURCE VAR) | macro(CURL_CHECK_C_SOURCE_RUNS SOURCE VAR) | ||||||
|   IF("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") |   if("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") | ||||||
|     SET(message "${VAR}") |     set(message "${VAR}") | ||||||
|     # If the number of arguments is greater than 2 (SOURCE VAR) |     # If the number of arguments is greater than 2 (SOURCE VAR) | ||||||
|     IF(${ARGC} GREATER 2) |     if(${ARGC} GREATER 2) | ||||||
|       # then add the third argument as a message |       # then add the third argument as a message | ||||||
|       SET(message "${ARGV2} (${VAR})") |       set(message "${ARGV2} (${VAR})") | ||||||
|     ENDIF(${ARGC} GREATER 2) |     endif(${ARGC} GREATER 2) | ||||||
|     SET(MACRO_CHECK_FUNCTION_DEFINITIONS |     set(MACRO_CHECK_FUNCTION_DEFINITIONS | ||||||
|       "-D${VAR} ${CMAKE_REQUIRED_FLAGS}") |       "-D${VAR} ${CMAKE_REQUIRED_FLAGS}") | ||||||
|     IF(CMAKE_REQUIRED_LIBRARIES) |     if(CMAKE_REQUIRED_LIBRARIES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES | ||||||
|         "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") |         "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") | ||||||
|     ELSE(CMAKE_REQUIRED_LIBRARIES) |     else(CMAKE_REQUIRED_LIBRARIES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES) |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_LIBRARIES) | ||||||
|     ENDIF(CMAKE_REQUIRED_LIBRARIES) |     endif(CMAKE_REQUIRED_LIBRARIES) | ||||||
|     IF(CMAKE_REQUIRED_INCLUDES) |     if(CMAKE_REQUIRED_INCLUDES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES | ||||||
|         "-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}") |         "-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}") | ||||||
|     ELSE(CMAKE_REQUIRED_INCLUDES) |     else(CMAKE_REQUIRED_INCLUDES) | ||||||
|       SET(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES) |       set(CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES) | ||||||
|     ENDIF(CMAKE_REQUIRED_INCLUDES) |     endif(CMAKE_REQUIRED_INCLUDES) | ||||||
|     SET(src "") |     set(src "") | ||||||
|     FOREACH(def ${EXTRA_DEFINES}) |     foreach(def ${EXTRA_DEFINES}) | ||||||
|       SET(src "${src}#define ${def} 1\n") |       set(src "${src}#define ${def} 1\n") | ||||||
|     ENDFOREACH(def) |     endforeach(def) | ||||||
|     FOREACH(inc ${HEADER_INCLUDES}) |     foreach(inc ${HEADER_INCLUDES}) | ||||||
|       SET(src "${src}#include <${inc}>\n") |       set(src "${src}#include <${inc}>\n") | ||||||
|     ENDFOREACH(inc) |     endforeach(inc) | ||||||
|  |  | ||||||
|     SET(src "${src}\nint main() { ${SOURCE} ; return 0; }") |     set(src "${src}\nint main() { ${SOURCE} ; return 0; }") | ||||||
|     SET(CMAKE_CONFIGURABLE_FILE_CONTENT "${src}") |     set(CMAKE_CONFIGURABLE_FILE_CONTENT "${src}") | ||||||
|     CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/CMake/CMakeConfigurableFile.in |     configure_file(${CMAKE_CURRENT_SOURCE_DIR}/CMake/CMakeConfigurableFile.in | ||||||
|       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c" |       "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c" | ||||||
|       IMMEDIATE) |       IMMEDIATE) | ||||||
|     MESSAGE(STATUS "Performing Test ${message}") |     message(STATUS "Performing Test ${message}") | ||||||
|     TRY_RUN(${VAR} ${VAR}_COMPILED |     try_run(${VAR} ${VAR}_COMPILED | ||||||
|       ${CMAKE_BINARY_DIR} |       ${CMAKE_BINARY_DIR} | ||||||
|       ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c |       ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/src.c | ||||||
|       COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} |       COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} | ||||||
| @@ -57,27 +57,27 @@ MACRO(CURL_CHECK_C_SOURCE_RUNS SOURCE VAR) | |||||||
|       "${CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES}" |       "${CURL_CHECK_C_SOURCE_COMPILES_ADD_INCLUDES}" | ||||||
|       OUTPUT_VARIABLE OUTPUT) |       OUTPUT_VARIABLE OUTPUT) | ||||||
|     # if it did not compile make the return value fail code of 1 |     # if it did not compile make the return value fail code of 1 | ||||||
|     IF(NOT ${VAR}_COMPILED) |     if(NOT ${VAR}_COMPILED) | ||||||
|       SET(${VAR} 1) |       set(${VAR} 1) | ||||||
|     ENDIF(NOT ${VAR}_COMPILED) |     endif(NOT ${VAR}_COMPILED) | ||||||
|     # if the return value was 0 then it worked |     # if the return value was 0 then it worked | ||||||
|     SET(result_var ${${VAR}}) |     set(result_var ${${VAR}}) | ||||||
|     IF("${result_var}" EQUAL 0) |     if("${result_var}" EQUAL 0) | ||||||
|       SET(${VAR} 1 CACHE INTERNAL "Test ${message}") |       set(${VAR} 1 CACHE INTERNAL "Test ${message}") | ||||||
|       MESSAGE(STATUS "Performing Test ${message} - Success") |       message(STATUS "Performing Test ${message} - Success") | ||||||
|       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log |       file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log | ||||||
|         "Performing C SOURCE FILE Test ${message} succeded with the following output:\n" |         "Performing C SOURCE FILE Test ${message} succeded with the following output:\n" | ||||||
|         "${OUTPUT}\n" |         "${OUTPUT}\n" | ||||||
|         "Return value: ${${VAR}}\n" |         "Return value: ${${VAR}}\n" | ||||||
|         "Source file was:\n${src}\n") |         "Source file was:\n${src}\n") | ||||||
|     ELSE("${result_var}" EQUAL 0) |     else("${result_var}" EQUAL 0) | ||||||
|       MESSAGE(STATUS "Performing Test ${message} - Failed") |       message(STATUS "Performing Test ${message} - Failed") | ||||||
|       SET(${VAR} "" CACHE INTERNAL "Test ${message}") |       set(${VAR} "" CACHE INTERNAL "Test ${message}") | ||||||
|       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log |       file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log | ||||||
|         "Performing C SOURCE FILE Test ${message} failed with the following output:\n" |         "Performing C SOURCE FILE Test ${message} failed with the following output:\n" | ||||||
|         "${OUTPUT}\n" |         "${OUTPUT}\n" | ||||||
|         "Return value: ${result_var}\n" |         "Return value: ${result_var}\n" | ||||||
|         "Source file was:\n${src}\n") |         "Source file was:\n${src}\n") | ||||||
|     ENDIF("${result_var}" EQUAL 0) |     endif("${result_var}" EQUAL 0) | ||||||
|   ENDIF("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") |   endif("${VAR}" MATCHES "^${VAR}$" OR "${VAR}" MATCHES "UNKNOWN") | ||||||
| ENDMACRO(CURL_CHECK_C_SOURCE_RUNS) | endmacro(CURL_CHECK_C_SOURCE_RUNS) | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										42
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | # - Find c-ares | ||||||
|  | # Find the c-ares includes and library | ||||||
|  | # This module defines | ||||||
|  | #  CARES_INCLUDE_DIR, where to find ares.h, etc. | ||||||
|  | #  CARES_LIBRARIES, the libraries needed to use c-ares. | ||||||
|  | #  CARES_FOUND, If false, do not try to use c-ares. | ||||||
|  | # also defined, but not for general use are | ||||||
|  | # CARES_LIBRARY, where to find the c-ares library. | ||||||
|  | 	 | ||||||
|  | FIND_PATH(CARES_INCLUDE_DIR ares.h | ||||||
|  |   /usr/local/include | ||||||
|  |   /usr/include | ||||||
|  |   ) | ||||||
|  |  	 | ||||||
|  | SET(CARES_NAMES ${CARES_NAMES} cares) | ||||||
|  | FIND_LIBRARY(CARES_LIBRARY | ||||||
|  |   NAMES ${CARES_NAMES} | ||||||
|  |   PATHS /usr/lib /usr/local/lib | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  | IF (CARES_LIBRARY AND CARES_INCLUDE_DIR) | ||||||
|  |   SET(CARES_LIBRARIES ${CARES_LIBRARY}) | ||||||
|  |   SET(CARES_FOUND "YES") | ||||||
|  | ELSE (CARES_LIBRARY AND CARES_INCLUDE_DIR) | ||||||
|  |   SET(CARES_FOUND "NO") | ||||||
|  | ENDIF (CARES_LIBRARY AND CARES_INCLUDE_DIR) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | IF (CARES_FOUND) | ||||||
|  |   IF (NOT CARES_FIND_QUIETLY) | ||||||
|  |     MESSAGE(STATUS "Found c-ares: ${CARES_LIBRARIES}") | ||||||
|  |   ENDIF (NOT CARES_FIND_QUIETLY) | ||||||
|  | ELSE (CARES_FOUND) | ||||||
|  |   IF (CARES_FIND_REQUIRED) | ||||||
|  |     MESSAGE(FATAL_ERROR "Could not find c-ares library") | ||||||
|  |   ENDIF (CARES_FIND_REQUIRED) | ||||||
|  | ENDIF (CARES_FOUND) | ||||||
|  |  | ||||||
|  | MARK_AS_ADVANCED( | ||||||
|  |   CARES_LIBRARY | ||||||
|  |   CARES_INCLUDE_DIR | ||||||
|  |   ) | ||||||
| @@ -1,19 +1,19 @@ | |||||||
| # Extension of the standard FindOpenSSL.cmake | # Extension of the standard FindOpenSSL.cmake | ||||||
| # Adds OPENSSL_INCLUDE_DIRS and libeay32 | # Adds OPENSSL_INCLUDE_DIRS and libeay32 | ||||||
| INCLUDE("${CMAKE_ROOT}/Modules/FindOpenSSL.cmake") | include("${CMAKE_ROOT}/Modules/FindOpenSSL.cmake") | ||||||
|  |  | ||||||
| # Bill Hoffman told that libeay32 is necessary for him: | # Bill Hoffman told that libeay32 is necessary for him: | ||||||
| FIND_LIBRARY(SSL_LIBEAY NAMES libeay32) | find_library(SSL_LIBEAY NAMES libeay32) | ||||||
|  |  | ||||||
| IF(OPENSSL_FOUND) | if(OPENSSL_FOUND) | ||||||
| 	IF(SSL_LIBEAY) |   if(SSL_LIBEAY) | ||||||
| 		LIST(APPEND OPENSSL_LIBRARIES ${SSL_LIBEAY}) |     list(APPEND OPENSSL_LIBRARIES ${SSL_LIBEAY}) | ||||||
| 	ELSE() |   else() | ||||||
| 		SET(OPENSSL_FOUND FALSE) |     set(OPENSSL_FOUND FALSE) | ||||||
| 	ENDIF() |   endif() | ||||||
| ENDIF() | endif() | ||||||
|  |  | ||||||
|  |  | ||||||
| IF(OPENSSL_FOUND) | if(OPENSSL_FOUND) | ||||||
| 	SET(OPENSSL_INCLUDE_DIRS ${OPENSSL_INCLUDE_DIR}) |   set(OPENSSL_INCLUDE_DIRS ${OPENSSL_INCLUDE_DIR}) | ||||||
| ENDIF() | endif() | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| # Locate zlib | # Locate zlib | ||||||
| INCLUDE("${CMAKE_ROOT}/Modules/FindZLIB.cmake") | include("${CMAKE_ROOT}/Modules/FindZLIB.cmake") | ||||||
|  |  | ||||||
| FIND_LIBRARY(ZLIB_LIBRARY_DEBUG NAMES zd zlibd zdlld zlib1d ) | find_library(ZLIB_LIBRARY_DEBUG NAMES zd zlibd zdlld zlib1d ) | ||||||
|  |  | ||||||
| IF(ZLIB_FOUND AND ZLIB_LIBRARY_DEBUG) | if(ZLIB_FOUND AND ZLIB_LIBRARY_DEBUG) | ||||||
|   SET( ZLIB_LIBRARIES optimized "${ZLIB_LIBRARY}" debug ${ZLIB_LIBRARY_DEBUG}) |   set( ZLIB_LIBRARIES optimized "${ZLIB_LIBRARY}" debug ${ZLIB_LIBRARY_DEBUG}) | ||||||
| ENDIF() | endif() | ||||||
|   | |||||||
| @@ -1,250 +1,250 @@ | |||||||
| INCLUDE(CurlCheckCSourceCompiles) | include(CurlCheckCSourceCompiles) | ||||||
| SET(EXTRA_DEFINES "__unused1\n#undef inline\n#define __unused2") | set(EXTRA_DEFINES "__unused1\n#undef inline\n#define __unused2") | ||||||
| SET(HEADER_INCLUDES) | set(HEADER_INCLUDES) | ||||||
| SET(headers_hack) | set(headers_hack) | ||||||
|  |  | ||||||
| MACRO(add_header_include check header) | macro(add_header_include check header) | ||||||
|   IF(${check}) |   if(${check}) | ||||||
|     SET(headers_hack |     set(headers_hack | ||||||
|       "${headers_hack}\n#include <${header}>") |       "${headers_hack}\n#include <${header}>") | ||||||
|     #SET(HEADER_INCLUDES |     #SET(HEADER_INCLUDES | ||||||
|     #  ${HEADER_INCLUDES} |     #  ${HEADER_INCLUDES} | ||||||
|     #  "${header}") |     #  "${header}") | ||||||
|   ENDIF(${check}) |   endif(${check}) | ||||||
| ENDMACRO(add_header_include) | endmacro(add_header_include) | ||||||
|  |  | ||||||
| SET(signature_call_conv) | set(signature_call_conv) | ||||||
| IF(HAVE_WINDOWS_H) | if(HAVE_WINDOWS_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_WINSOCK2_H "winsock2.h") | ||||||
|   add_header_include(HAVE_WINSOCK_H "winsock.h") |   add_header_include(HAVE_WINSOCK_H "winsock.h") | ||||||
|   SET(EXTRA_DEFINES ${EXTRA_DEFINES} |   set(EXTRA_DEFINES ${EXTRA_DEFINES} | ||||||
|     "__unused7\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif\n#define __unused3") |     "__unused7\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif\n#define __unused3") | ||||||
|   SET(signature_call_conv "PASCAL") |   set(signature_call_conv "PASCAL") | ||||||
| ELSE(HAVE_WINDOWS_H) | else(HAVE_WINDOWS_H) | ||||||
|   add_header_include(HAVE_SYS_TYPES_H "sys/types.h") |   add_header_include(HAVE_SYS_TYPES_H "sys/types.h") | ||||||
|   add_header_include(HAVE_SYS_SOCKET_H "sys/socket.h") |   add_header_include(HAVE_SYS_SOCKET_H "sys/socket.h") | ||||||
| ENDIF(HAVE_WINDOWS_H) | endif(HAVE_WINDOWS_H) | ||||||
|  |  | ||||||
| SET(EXTRA_DEFINES_BACKUP "${EXTRA_DEFINES}") | set(EXTRA_DEFINES_BACKUP "${EXTRA_DEFINES}") | ||||||
| SET(EXTRA_DEFINES "${EXTRA_DEFINES_BACKUP}\n${headers_hack}\n${extern_line}\n#define __unused5") | set(EXTRA_DEFINES "${EXTRA_DEFINES_BACKUP}\n${headers_hack}\n${extern_line}\n#define __unused5") | ||||||
| CURL_CHECK_C_SOURCE_COMPILES("recv(0, 0, 0, 0)" curl_cv_recv) | curl_check_c_source_compiles("recv(0, 0, 0, 0)" curl_cv_recv) | ||||||
| IF(curl_cv_recv) | if(curl_cv_recv) | ||||||
|   #    AC_CACHE_CHECK([types of arguments and return type for recv], |   #    AC_CACHE_CHECK([types of arguments and return type for recv], | ||||||
|   #[curl_cv_func_recv_args], [ |   #[curl_cv_func_recv_args], [ | ||||||
|   #SET(curl_cv_func_recv_args "unknown") |   #SET(curl_cv_func_recv_args "unknown") | ||||||
|   #for recv_retv in 'int' 'ssize_t'; do |   #for recv_retv in 'int' 'ssize_t'; do | ||||||
|   IF(NOT DEFINED curl_cv_func_recv_args OR "${curl_cv_func_recv_args}" STREQUAL "unknown") |   if(NOT DEFINED curl_cv_func_recv_args OR "${curl_cv_func_recv_args}" STREQUAL "unknown") | ||||||
|     FOREACH(recv_retv "int" "ssize_t" ) |     foreach(recv_retv "int" "ssize_t" ) | ||||||
|       FOREACH(recv_arg1 "int" "ssize_t" "SOCKET") |       foreach(recv_arg1 "int" "ssize_t" "SOCKET") | ||||||
|         FOREACH(recv_arg2 "void *" "char *") |         foreach(recv_arg2 "void *" "char *") | ||||||
|           FOREACH(recv_arg3 "size_t" "int" "socklen_t" "unsigned int") |           foreach(recv_arg3 "size_t" "int" "socklen_t" "unsigned int") | ||||||
|             FOREACH(recv_arg4 "int" "unsigned int") |             foreach(recv_arg4 "int" "unsigned int") | ||||||
|               IF(NOT curl_cv_func_recv_done) |               if(NOT curl_cv_func_recv_done) | ||||||
|                 SET(curl_cv_func_recv_test "UNKNOWN") |                 set(curl_cv_func_recv_test "UNKNOWN") | ||||||
|                 SET(extern_line "extern ${recv_retv} ${signature_call_conv} recv(${recv_arg1}, ${recv_arg2}, ${recv_arg3}, ${recv_arg4})\;") |                 set(extern_line "extern ${recv_retv} ${signature_call_conv} recv(${recv_arg1}, ${recv_arg2}, ${recv_arg3}, ${recv_arg4})\;") | ||||||
|                 SET(EXTRA_DEFINES "${EXTRA_DEFINES_BACKUP}\n${headers_hack}\n${extern_line}\n#define __unused5") |                 set(EXTRA_DEFINES "${EXTRA_DEFINES_BACKUP}\n${headers_hack}\n${extern_line}\n#define __unused5") | ||||||
|                 CURL_CHECK_C_SOURCE_COMPILES(" |                 curl_check_c_source_compiles(" | ||||||
|                     ${recv_arg1} s=0; |                     ${recv_arg1} s=0; | ||||||
|                     ${recv_arg2} buf=0; |                     ${recv_arg2} buf=0; | ||||||
|                     ${recv_arg3} len=0; |                     ${recv_arg3} len=0; | ||||||
|                     ${recv_arg4} flags=0; |                     ${recv_arg4} flags=0; | ||||||
|                     ${recv_retv} res = recv(s, buf, len, flags)" |                     ${recv_retv} res = recv(s, buf, len, flags)" | ||||||
|                     curl_cv_func_recv_test |                   curl_cv_func_recv_test | ||||||
|                     "${recv_retv} recv(${recv_arg1}, ${recv_arg2}, ${recv_arg3}, ${recv_arg4})") |                   "${recv_retv} recv(${recv_arg1}, ${recv_arg2}, ${recv_arg3}, ${recv_arg4})") | ||||||
|                 IF(curl_cv_func_recv_test) |                 if(curl_cv_func_recv_test) | ||||||
|                   SET(curl_cv_func_recv_args |                   set(curl_cv_func_recv_args | ||||||
|                     "${recv_arg1},${recv_arg2},${recv_arg3},${recv_arg4},${recv_retv}") |                     "${recv_arg1},${recv_arg2},${recv_arg3},${recv_arg4},${recv_retv}") | ||||||
|                   SET(RECV_TYPE_ARG1 "${recv_arg1}") |                   set(RECV_TYPE_ARG1 "${recv_arg1}") | ||||||
|                   SET(RECV_TYPE_ARG2 "${recv_arg2}") |                   set(RECV_TYPE_ARG2 "${recv_arg2}") | ||||||
|                   SET(RECV_TYPE_ARG3 "${recv_arg3}") |                   set(RECV_TYPE_ARG3 "${recv_arg3}") | ||||||
|                   SET(RECV_TYPE_ARG4 "${recv_arg4}") |                   set(RECV_TYPE_ARG4 "${recv_arg4}") | ||||||
|                   SET(RECV_TYPE_RETV "${recv_retv}") |                   set(RECV_TYPE_RETV "${recv_retv}") | ||||||
|                   SET(HAVE_RECV 1) |                   set(HAVE_RECV 1) | ||||||
|                   SET(curl_cv_func_recv_done 1) |                   set(curl_cv_func_recv_done 1) | ||||||
|                 ENDIF(curl_cv_func_recv_test) |                 endif(curl_cv_func_recv_test) | ||||||
|               ENDIF(NOT curl_cv_func_recv_done) |               endif(NOT curl_cv_func_recv_done) | ||||||
|             ENDFOREACH(recv_arg4) |             endforeach(recv_arg4) | ||||||
|           ENDFOREACH(recv_arg3) |           endforeach(recv_arg3) | ||||||
|         ENDFOREACH(recv_arg2) |         endforeach(recv_arg2) | ||||||
|       ENDFOREACH(recv_arg1) |       endforeach(recv_arg1) | ||||||
|     ENDFOREACH(recv_retv)  |     endforeach(recv_retv)  | ||||||
|   ELSE(NOT DEFINED curl_cv_func_recv_args OR "${curl_cv_func_recv_args}" STREQUAL "unknown") |   else(NOT DEFINED curl_cv_func_recv_args OR "${curl_cv_func_recv_args}" STREQUAL "unknown") | ||||||
|     STRING(REGEX REPLACE "^([^,]*),[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG1 "${curl_cv_func_recv_args}") |     string(REGEX REPLACE "^([^,]*),[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG1 "${curl_cv_func_recv_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,([^,]*),[^,]*,[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG2 "${curl_cv_func_recv_args}") |     string(REGEX REPLACE "^[^,]*,([^,]*),[^,]*,[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG2 "${curl_cv_func_recv_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,([^,]*),[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG3 "${curl_cv_func_recv_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,([^,]*),[^,]*,[^,]*$" "\\1" RECV_TYPE_ARG3 "${curl_cv_func_recv_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,([^,]*),[^,]*$" "\\1" RECV_TYPE_ARG4 "${curl_cv_func_recv_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,([^,]*),[^,]*$" "\\1" RECV_TYPE_ARG4 "${curl_cv_func_recv_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,([^,]*)$" "\\1" RECV_TYPE_RETV "${curl_cv_func_recv_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,([^,]*)$" "\\1" RECV_TYPE_RETV "${curl_cv_func_recv_args}") | ||||||
|     #MESSAGE("RECV_TYPE_ARG1 ${RECV_TYPE_ARG1}") |     #MESSAGE("RECV_TYPE_ARG1 ${RECV_TYPE_ARG1}") | ||||||
|     #MESSAGE("RECV_TYPE_ARG2 ${RECV_TYPE_ARG2}") |     #MESSAGE("RECV_TYPE_ARG2 ${RECV_TYPE_ARG2}") | ||||||
|     #MESSAGE("RECV_TYPE_ARG3 ${RECV_TYPE_ARG3}") |     #MESSAGE("RECV_TYPE_ARG3 ${RECV_TYPE_ARG3}") | ||||||
|     #MESSAGE("RECV_TYPE_ARG4 ${RECV_TYPE_ARG4}") |     #MESSAGE("RECV_TYPE_ARG4 ${RECV_TYPE_ARG4}") | ||||||
|     #MESSAGE("RECV_TYPE_RETV ${RECV_TYPE_RETV}") |     #MESSAGE("RECV_TYPE_RETV ${RECV_TYPE_RETV}") | ||||||
|   ENDIF(NOT DEFINED curl_cv_func_recv_args OR "${curl_cv_func_recv_args}" STREQUAL "unknown") |   endif(NOT DEFINED curl_cv_func_recv_args OR "${curl_cv_func_recv_args}" STREQUAL "unknown") | ||||||
|    |    | ||||||
|   IF("${curl_cv_func_recv_args}" STREQUAL "unknown") |   if("${curl_cv_func_recv_args}" STREQUAL "unknown") | ||||||
|     MESSAGE(FATAL_ERROR "Cannot find proper types to use for recv args") |     message(FATAL_ERROR "Cannot find proper types to use for recv args") | ||||||
|   ENDIF("${curl_cv_func_recv_args}" STREQUAL "unknown") |   endif("${curl_cv_func_recv_args}" STREQUAL "unknown") | ||||||
| ELSE(curl_cv_recv) | else(curl_cv_recv) | ||||||
|   MESSAGE(FATAL_ERROR "Unable to link function recv") |   message(FATAL_ERROR "Unable to link function recv") | ||||||
| ENDIF(curl_cv_recv) | endif(curl_cv_recv) | ||||||
| SET(curl_cv_func_recv_args "${curl_cv_func_recv_args}" CACHE INTERNAL "Arguments for recv") | set(curl_cv_func_recv_args "${curl_cv_func_recv_args}" CACHE INTERNAL "Arguments for recv") | ||||||
| SET(HAVE_RECV 1) | set(HAVE_RECV 1) | ||||||
|  |  | ||||||
| CURL_CHECK_C_SOURCE_COMPILES("send(0, 0, 0, 0)" curl_cv_send) | curl_check_c_source_compiles("send(0, 0, 0, 0)" curl_cv_send) | ||||||
| IF(curl_cv_send) | if(curl_cv_send) | ||||||
|   #    AC_CACHE_CHECK([types of arguments and return type for send], |   #    AC_CACHE_CHECK([types of arguments and return type for send], | ||||||
|   #[curl_cv_func_send_args], [ |   #[curl_cv_func_send_args], [ | ||||||
|   #SET(curl_cv_func_send_args "unknown") |   #SET(curl_cv_func_send_args "unknown") | ||||||
|   #for send_retv in 'int' 'ssize_t'; do |   #for send_retv in 'int' 'ssize_t'; do | ||||||
|   IF(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown") |   if(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown") | ||||||
|     FOREACH(send_retv "int" "ssize_t" ) |     foreach(send_retv "int" "ssize_t" ) | ||||||
|       FOREACH(send_arg1 "int" "ssize_t" "SOCKET") |       foreach(send_arg1 "int" "ssize_t" "SOCKET") | ||||||
|         FOREACH(send_arg2 "const void *" "void *" "char *" "const char *") |         foreach(send_arg2 "const void *" "void *" "char *" "const char *") | ||||||
|           FOREACH(send_arg3 "size_t" "int" "socklen_t" "unsigned int") |           foreach(send_arg3 "size_t" "int" "socklen_t" "unsigned int") | ||||||
|             FOREACH(send_arg4 "int" "unsigned int") |             foreach(send_arg4 "int" "unsigned int") | ||||||
|               IF(NOT curl_cv_func_send_done) |               if(NOT curl_cv_func_send_done) | ||||||
|                 SET(curl_cv_func_send_test "UNKNOWN") |                 set(curl_cv_func_send_test "UNKNOWN") | ||||||
|                 SET(extern_line "extern ${send_retv} ${signature_call_conv} send(${send_arg1}, ${send_arg2}, ${send_arg3}, ${send_arg4})\;") |                 set(extern_line "extern ${send_retv} ${signature_call_conv} send(${send_arg1}, ${send_arg2}, ${send_arg3}, ${send_arg4})\;") | ||||||
|                 SET(EXTRA_DEFINES "${EXTRA_DEFINES_BACKUP}\n${headers_hack}\n${extern_line}\n#define __unused5") |                 set(EXTRA_DEFINES "${EXTRA_DEFINES_BACKUP}\n${headers_hack}\n${extern_line}\n#define __unused5") | ||||||
|                 CURL_CHECK_C_SOURCE_COMPILES(" |                 curl_check_c_source_compiles(" | ||||||
|                     ${send_arg1} s=0; |                     ${send_arg1} s=0; | ||||||
|                     ${send_arg2} buf=0; |                     ${send_arg2} buf=0; | ||||||
|                     ${send_arg3} len=0; |                     ${send_arg3} len=0; | ||||||
|                     ${send_arg4} flags=0; |                     ${send_arg4} flags=0; | ||||||
|                     ${send_retv} res = send(s, buf, len, flags)" |                     ${send_retv} res = send(s, buf, len, flags)" | ||||||
|                     curl_cv_func_send_test |                   curl_cv_func_send_test | ||||||
|                     "${send_retv} send(${send_arg1}, ${send_arg2}, ${send_arg3}, ${send_arg4})") |                   "${send_retv} send(${send_arg1}, ${send_arg2}, ${send_arg3}, ${send_arg4})") | ||||||
|                 IF(curl_cv_func_send_test) |                 if(curl_cv_func_send_test) | ||||||
|                   #MESSAGE("Found arguments: ${curl_cv_func_send_test}") |                   #MESSAGE("Found arguments: ${curl_cv_func_send_test}") | ||||||
|                   STRING(REGEX REPLACE "(const) .*" "\\1" send_qual_arg2 "${send_arg2}") |                   string(REGEX REPLACE "(const) .*" "\\1" send_qual_arg2 "${send_arg2}") | ||||||
|                   STRING(REGEX REPLACE "const (.*)" "\\1" send_arg2 "${send_arg2}") |                   string(REGEX REPLACE "const (.*)" "\\1" send_arg2 "${send_arg2}") | ||||||
|                   SET(curl_cv_func_send_args |                   set(curl_cv_func_send_args | ||||||
|                     "${send_arg1},${send_arg2},${send_arg3},${send_arg4},${send_retv},${send_qual_arg2}") |                     "${send_arg1},${send_arg2},${send_arg3},${send_arg4},${send_retv},${send_qual_arg2}") | ||||||
|                   SET(SEND_TYPE_ARG1 "${send_arg1}") |                   set(SEND_TYPE_ARG1 "${send_arg1}") | ||||||
|                   SET(SEND_TYPE_ARG2 "${send_arg2}") |                   set(SEND_TYPE_ARG2 "${send_arg2}") | ||||||
|                   SET(SEND_TYPE_ARG3 "${send_arg3}") |                   set(SEND_TYPE_ARG3 "${send_arg3}") | ||||||
|                   SET(SEND_TYPE_ARG4 "${send_arg4}") |                   set(SEND_TYPE_ARG4 "${send_arg4}") | ||||||
|                   SET(SEND_TYPE_RETV "${send_retv}") |                   set(SEND_TYPE_RETV "${send_retv}") | ||||||
|                   SET(HAVE_SEND 1) |                   set(HAVE_SEND 1) | ||||||
|                   SET(curl_cv_func_send_done 1) |                   set(curl_cv_func_send_done 1) | ||||||
|                 ENDIF(curl_cv_func_send_test) |                 endif(curl_cv_func_send_test) | ||||||
|               ENDIF(NOT curl_cv_func_send_done) |               endif(NOT curl_cv_func_send_done) | ||||||
|             ENDFOREACH(send_arg4) |             endforeach(send_arg4) | ||||||
|           ENDFOREACH(send_arg3) |           endforeach(send_arg3) | ||||||
|         ENDFOREACH(send_arg2) |         endforeach(send_arg2) | ||||||
|       ENDFOREACH(send_arg1) |       endforeach(send_arg1) | ||||||
|     ENDFOREACH(send_retv)  |     endforeach(send_retv)  | ||||||
|   ELSE(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown") |   else(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown") | ||||||
|     STRING(REGEX REPLACE "^([^,]*),[^,]*,[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG1 "${curl_cv_func_send_args}") |     string(REGEX REPLACE "^([^,]*),[^,]*,[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG1 "${curl_cv_func_send_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,([^,]*),[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG2 "${curl_cv_func_send_args}") |     string(REGEX REPLACE "^[^,]*,([^,]*),[^,]*,[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG2 "${curl_cv_func_send_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,([^,]*),[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG3 "${curl_cv_func_send_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,([^,]*),[^,]*,[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG3 "${curl_cv_func_send_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,([^,]*),[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG4 "${curl_cv_func_send_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,([^,]*),[^,]*,[^,]*$" "\\1" SEND_TYPE_ARG4 "${curl_cv_func_send_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,([^,]*),[^,]*$" "\\1" SEND_TYPE_RETV "${curl_cv_func_send_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,([^,]*),[^,]*$" "\\1" SEND_TYPE_RETV "${curl_cv_func_send_args}") | ||||||
|     STRING(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,[^,]*,([^,]*)$" "\\1" SEND_QUAL_ARG2 "${curl_cv_func_send_args}") |     string(REGEX REPLACE "^[^,]*,[^,]*,[^,]*,[^,]*,[^,]*,([^,]*)$" "\\1" SEND_QUAL_ARG2 "${curl_cv_func_send_args}") | ||||||
|     #MESSAGE("SEND_TYPE_ARG1 ${SEND_TYPE_ARG1}") |     #MESSAGE("SEND_TYPE_ARG1 ${SEND_TYPE_ARG1}") | ||||||
|     #MESSAGE("SEND_TYPE_ARG2 ${SEND_TYPE_ARG2}") |     #MESSAGE("SEND_TYPE_ARG2 ${SEND_TYPE_ARG2}") | ||||||
|     #MESSAGE("SEND_TYPE_ARG3 ${SEND_TYPE_ARG3}") |     #MESSAGE("SEND_TYPE_ARG3 ${SEND_TYPE_ARG3}") | ||||||
|     #MESSAGE("SEND_TYPE_ARG4 ${SEND_TYPE_ARG4}") |     #MESSAGE("SEND_TYPE_ARG4 ${SEND_TYPE_ARG4}") | ||||||
|     #MESSAGE("SEND_TYPE_RETV ${SEND_TYPE_RETV}") |     #MESSAGE("SEND_TYPE_RETV ${SEND_TYPE_RETV}") | ||||||
|     #MESSAGE("SEND_QUAL_ARG2 ${SEND_QUAL_ARG2}") |     #MESSAGE("SEND_QUAL_ARG2 ${SEND_QUAL_ARG2}") | ||||||
|   ENDIF(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown") |   endif(NOT DEFINED curl_cv_func_send_args OR "${curl_cv_func_send_args}" STREQUAL "unknown") | ||||||
|    |    | ||||||
|   IF("${curl_cv_func_send_args}" STREQUAL "unknown") |   if("${curl_cv_func_send_args}" STREQUAL "unknown") | ||||||
|     MESSAGE(FATAL_ERROR "Cannot find proper types to use for send args") |     message(FATAL_ERROR "Cannot find proper types to use for send args") | ||||||
|   ENDIF("${curl_cv_func_send_args}" STREQUAL "unknown") |   endif("${curl_cv_func_send_args}" STREQUAL "unknown") | ||||||
|   SET(SEND_QUAL_ARG2 "const") |   set(SEND_QUAL_ARG2 "const") | ||||||
| ELSE(curl_cv_send) | else(curl_cv_send) | ||||||
|   MESSAGE(FATAL_ERROR "Unable to link function send") |   message(FATAL_ERROR "Unable to link function send") | ||||||
| ENDIF(curl_cv_send) | endif(curl_cv_send) | ||||||
| SET(curl_cv_func_send_args "${curl_cv_func_send_args}" CACHE INTERNAL "Arguments for send") | set(curl_cv_func_send_args "${curl_cv_func_send_args}" CACHE INTERNAL "Arguments for send") | ||||||
| SET(HAVE_SEND 1) | set(HAVE_SEND 1) | ||||||
|  |  | ||||||
| SET(EXTRA_DEFINES "${EXTRA_DEFINES}\n${headers_hack}\n#define __unused5") | set(EXTRA_DEFINES "${EXTRA_DEFINES}\n${headers_hack}\n#define __unused5") | ||||||
| CURL_CHECK_C_SOURCE_COMPILES("int flag = MSG_NOSIGNAL" HAVE_MSG_NOSIGNAL) | curl_check_c_source_compiles("int flag = MSG_NOSIGNAL" HAVE_MSG_NOSIGNAL) | ||||||
|  |  | ||||||
| SET(EXTRA_DEFINES "__unused1\n#undef inline\n#define __unused2") | set(EXTRA_DEFINES "__unused1\n#undef inline\n#define __unused2") | ||||||
| SET(HEADER_INCLUDES) | set(HEADER_INCLUDES) | ||||||
| SET(headers_hack) | set(headers_hack) | ||||||
|  |  | ||||||
| MACRO(add_header_include check header) | macro(add_header_include check header) | ||||||
|   IF(${check}) |   if(${check}) | ||||||
|     SET(headers_hack |     set(headers_hack | ||||||
|       "${headers_hack}\n#include <${header}>") |       "${headers_hack}\n#include <${header}>") | ||||||
|     #SET(HEADER_INCLUDES |     #SET(HEADER_INCLUDES | ||||||
|     #  ${HEADER_INCLUDES} |     #  ${HEADER_INCLUDES} | ||||||
|     #  "${header}") |     #  "${header}") | ||||||
|   ENDIF(${check}) |   endif(${check}) | ||||||
| ENDMACRO(add_header_include header) | endmacro(add_header_include header) | ||||||
|  |  | ||||||
| IF(HAVE_WINDOWS_H) | if(HAVE_WINDOWS_H) | ||||||
|   SET(EXTRA_DEFINES ${EXTRA_DEFINES} |   set(EXTRA_DEFINES ${EXTRA_DEFINES} | ||||||
|     "__unused7\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif\n#define __unused3") |     "__unused7\n#ifndef WIN32_LEAN_AND_MEAN\n#define WIN32_LEAN_AND_MEAN\n#endif\n#define __unused3") | ||||||
|   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_WINSOCK2_H "winsock2.h") | ||||||
|   add_header_include(HAVE_WINSOCK_H "winsock.h") |   add_header_include(HAVE_WINSOCK_H "winsock.h") | ||||||
| ELSE(HAVE_WINDOWS_H) | else(HAVE_WINDOWS_H) | ||||||
|   add_header_include(HAVE_SYS_TYPES_H "sys/types.h") |   add_header_include(HAVE_SYS_TYPES_H "sys/types.h") | ||||||
|   add_header_include(HAVE_SYS_TIME_H "sys/time.h") |   add_header_include(HAVE_SYS_TIME_H "sys/time.h") | ||||||
|   add_header_include(TIME_WITH_SYS_TIME "time.h") |   add_header_include(TIME_WITH_SYS_TIME "time.h") | ||||||
|   add_header_include(HAVE_TIME_H "time.h") |   add_header_include(HAVE_TIME_H "time.h") | ||||||
| ENDIF(HAVE_WINDOWS_H) | endif(HAVE_WINDOWS_H) | ||||||
| SET(EXTRA_DEFINES "${EXTRA_DEFINES}\n${headers_hack}\n#define __unused5") | set(EXTRA_DEFINES "${EXTRA_DEFINES}\n${headers_hack}\n#define __unused5") | ||||||
| CURL_CHECK_C_SOURCE_COMPILES("struct timeval ts;\nts.tv_sec  = 0;\nts.tv_usec = 0" HAVE_STRUCT_TIMEVAL) | curl_check_c_source_compiles("struct timeval ts;\nts.tv_sec  = 0;\nts.tv_usec = 0" HAVE_STRUCT_TIMEVAL) | ||||||
|  |  | ||||||
|  |  | ||||||
| INCLUDE(CurlCheckCSourceRuns) | include(CurlCheckCSourceRuns) | ||||||
| SET(EXTRA_DEFINES) | set(EXTRA_DEFINES) | ||||||
| SET(HEADER_INCLUDES) | set(HEADER_INCLUDES) | ||||||
| IF(HAVE_SYS_POLL_H) | if(HAVE_SYS_POLL_H) | ||||||
|   SET(HEADER_INCLUDES "sys/poll.h") |   set(HEADER_INCLUDES "sys/poll.h") | ||||||
| ENDIF(HAVE_SYS_POLL_H) | endif(HAVE_SYS_POLL_H) | ||||||
| CURL_CHECK_C_SOURCE_RUNS("return poll((void *)0, 0, 10 /*ms*/)" HAVE_POLL_FINE) | curl_check_c_source_runs("return poll((void *)0, 0, 10 /*ms*/)" HAVE_POLL_FINE) | ||||||
|  |  | ||||||
| SET(HAVE_SIG_ATOMIC_T 1) | set(HAVE_SIG_ATOMIC_T 1) | ||||||
| SET(EXTRA_DEFINES) | set(EXTRA_DEFINES) | ||||||
| SET(HEADER_INCLUDES) | set(HEADER_INCLUDES) | ||||||
| IF(HAVE_SIGNAL_H) | if(HAVE_SIGNAL_H) | ||||||
|   SET(HEADER_INCLUDES "signal.h") |   set(HEADER_INCLUDES "signal.h") | ||||||
|   SET(CMAKE_EXTRA_INCLUDE_FILES "signal.h") |   set(CMAKE_EXTRA_INCLUDE_FILES "signal.h") | ||||||
| ENDIF(HAVE_SIGNAL_H) | endif(HAVE_SIGNAL_H) | ||||||
| CHECK_TYPE_SIZE("sig_atomic_t" SIZEOF_SIG_ATOMIC_T) | check_type_size("sig_atomic_t" SIZEOF_SIG_ATOMIC_T) | ||||||
| IF(HAVE_SIZEOF_SIG_ATOMIC_T) | if(HAVE_SIZEOF_SIG_ATOMIC_T) | ||||||
|   CURL_CHECK_C_SOURCE_COMPILES("static volatile sig_atomic_t dummy = 0" HAVE_SIG_ATOMIC_T_NOT_VOLATILE) |   curl_check_c_source_compiles("static volatile sig_atomic_t dummy = 0" HAVE_SIG_ATOMIC_T_NOT_VOLATILE) | ||||||
|   IF(NOT HAVE_SIG_ATOMIC_T_NOT_VOLATILE) |   if(NOT HAVE_SIG_ATOMIC_T_NOT_VOLATILE) | ||||||
|     SET(HAVE_SIG_ATOMIC_T_VOLATILE 1) |     set(HAVE_SIG_ATOMIC_T_VOLATILE 1) | ||||||
|   ENDIF(NOT HAVE_SIG_ATOMIC_T_NOT_VOLATILE) |   endif(NOT HAVE_SIG_ATOMIC_T_NOT_VOLATILE) | ||||||
| ENDIF(HAVE_SIZEOF_SIG_ATOMIC_T) | endif(HAVE_SIZEOF_SIG_ATOMIC_T) | ||||||
|  |  | ||||||
| SET(CHECK_TYPE_SIZE_PREINCLUDE | set(CHECK_TYPE_SIZE_PREINCLUDE | ||||||
|   "#undef inline") |   "#undef inline") | ||||||
|  |  | ||||||
| IF(HAVE_WINDOWS_H) | if(HAVE_WINDOWS_H) | ||||||
|   SET(CHECK_TYPE_SIZE_PREINCLUDE "${CHECK_TYPE_SIZE_PREINCLUDE} |   set(CHECK_TYPE_SIZE_PREINCLUDE "${CHECK_TYPE_SIZE_PREINCLUDE} | ||||||
|   #ifndef WIN32_LEAN_AND_MEAN |   #ifndef WIN32_LEAN_AND_MEAN | ||||||
|   #define WIN32_LEAN_AND_MEAN |   #define WIN32_LEAN_AND_MEAN | ||||||
|   #endif |   #endif | ||||||
|   #include <windows.h>") |   #include <windows.h>") | ||||||
|   IF(HAVE_WINSOCK2_H) |   if(HAVE_WINSOCK2_H) | ||||||
|     SET(CHECK_TYPE_SIZE_PREINCLUDE "${CHECK_TYPE_SIZE_PREINCLUDE}\n#include <winsock2.h>") |     set(CHECK_TYPE_SIZE_PREINCLUDE "${CHECK_TYPE_SIZE_PREINCLUDE}\n#include <winsock2.h>") | ||||||
|   ENDIF(HAVE_WINSOCK2_H) |   endif(HAVE_WINSOCK2_H) | ||||||
| ELSE(HAVE_WINDOWS_H) | else(HAVE_WINDOWS_H) | ||||||
|   IF(HAVE_SYS_SOCKET_H) |   if(HAVE_SYS_SOCKET_H) | ||||||
|     SET(CMAKE_EXTRA_INCLUDE_FILES ${CMAKE_EXTRA_INCLUDE_FILES} |     set(CMAKE_EXTRA_INCLUDE_FILES ${CMAKE_EXTRA_INCLUDE_FILES} | ||||||
|       "sys/socket.h") |       "sys/socket.h") | ||||||
|   ENDIF(HAVE_SYS_SOCKET_H) |   endif(HAVE_SYS_SOCKET_H) | ||||||
|   IF(HAVE_NETINET_IN_H) |   if(HAVE_NETINET_IN_H) | ||||||
|     SET(CMAKE_EXTRA_INCLUDE_FILES ${CMAKE_EXTRA_INCLUDE_FILES} |     set(CMAKE_EXTRA_INCLUDE_FILES ${CMAKE_EXTRA_INCLUDE_FILES} | ||||||
|       "netinet/in.h") |       "netinet/in.h") | ||||||
|   ENDIF(HAVE_NETINET_IN_H) |   endif(HAVE_NETINET_IN_H) | ||||||
|   IF(HAVE_ARPA_INET_H) |   if(HAVE_ARPA_INET_H) | ||||||
|     SET(CMAKE_EXTRA_INCLUDE_FILES ${CMAKE_EXTRA_INCLUDE_FILES} |     set(CMAKE_EXTRA_INCLUDE_FILES ${CMAKE_EXTRA_INCLUDE_FILES} | ||||||
|       "arpa/inet.h") |       "arpa/inet.h") | ||||||
|   ENDIF(HAVE_ARPA_INET_H) |   endif(HAVE_ARPA_INET_H) | ||||||
| ENDIF(HAVE_WINDOWS_H) | endif(HAVE_WINDOWS_H) | ||||||
|  |  | ||||||
| CHECK_TYPE_SIZE("struct sockaddr_storage" SIZEOF_STRUCT_SOCKADDR_STORAGE) | check_type_size("struct sockaddr_storage" SIZEOF_STRUCT_SOCKADDR_STORAGE) | ||||||
| IF(HAVE_SIZEOF_STRUCT_SOCKADDR_STORAGE) | if(HAVE_SIZEOF_STRUCT_SOCKADDR_STORAGE) | ||||||
|   SET(HAVE_STRUCT_SOCKADDR_STORAGE 1) |   set(HAVE_STRUCT_SOCKADDR_STORAGE 1) | ||||||
| ENDIF(HAVE_SIZEOF_STRUCT_SOCKADDR_STORAGE) | endif(HAVE_SIZEOF_STRUCT_SOCKADDR_STORAGE) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,121 +1,121 @@ | |||||||
| IF(NOT UNIX) | if(NOT UNIX) | ||||||
|   IF(WIN32) |   if(WIN32) | ||||||
|     SET(HAVE_LIBDL 0) |     set(HAVE_LIBDL 0) | ||||||
|     SET(HAVE_LIBUCB 0) |     set(HAVE_LIBUCB 0) | ||||||
|     SET(HAVE_LIBSOCKET 0) |     set(HAVE_LIBSOCKET 0) | ||||||
|     SET(NOT_NEED_LIBNSL 0) |     set(NOT_NEED_LIBNSL 0) | ||||||
|     SET(HAVE_LIBNSL 0) |     set(HAVE_LIBNSL 0) | ||||||
|     SET(HAVE_LIBZ 0) |     set(HAVE_LIBZ 0) | ||||||
|     SET(HAVE_LIBCRYPTO 0) |     set(HAVE_LIBCRYPTO 0) | ||||||
|  |  | ||||||
|     SET(HAVE_DLOPEN 0) |     set(HAVE_DLOPEN 0) | ||||||
|  |  | ||||||
|     SET(HAVE_ALLOCA_H 0) |     set(HAVE_ALLOCA_H 0) | ||||||
|     SET(HAVE_ARPA_INET_H 0) |     set(HAVE_ARPA_INET_H 0) | ||||||
|     SET(HAVE_DLFCN_H 0) |     set(HAVE_DLFCN_H 0) | ||||||
|     SET(HAVE_FCNTL_H 1) |     set(HAVE_FCNTL_H 1) | ||||||
|     SET(HAVE_FEATURES_H 0) |     set(HAVE_FEATURES_H 0) | ||||||
|     SET(HAVE_INTTYPES_H 0) |     set(HAVE_INTTYPES_H 0) | ||||||
|     SET(HAVE_IO_H 1) |     set(HAVE_IO_H 1) | ||||||
|     SET(HAVE_MALLOC_H 1) |     set(HAVE_MALLOC_H 1) | ||||||
|     SET(HAVE_MEMORY_H 1) |     set(HAVE_MEMORY_H 1) | ||||||
|     SET(HAVE_NETDB_H 0) |     set(HAVE_NETDB_H 0) | ||||||
|     SET(HAVE_NETINET_IF_ETHER_H 0) |     set(HAVE_NETINET_IF_ETHER_H 0) | ||||||
|     SET(HAVE_NETINET_IN_H 0) |     set(HAVE_NETINET_IN_H 0) | ||||||
|     SET(HAVE_NET_IF_H 0) |     set(HAVE_NET_IF_H 0) | ||||||
|     SET(HAVE_PROCESS_H 1) |     set(HAVE_PROCESS_H 1) | ||||||
|     SET(HAVE_PWD_H 0) |     set(HAVE_PWD_H 0) | ||||||
|     SET(HAVE_SETJMP_H 1) |     set(HAVE_SETJMP_H 1) | ||||||
|     SET(HAVE_SGTTY_H 0) |     set(HAVE_SGTTY_H 0) | ||||||
|     SET(HAVE_SIGNAL_H 1) |     set(HAVE_SIGNAL_H 1) | ||||||
|     SET(HAVE_SOCKIO_H 0) |     set(HAVE_SOCKIO_H 0) | ||||||
|     SET(HAVE_STDINT_H 0) |     set(HAVE_STDINT_H 0) | ||||||
|     SET(HAVE_STDLIB_H 1) |     set(HAVE_STDLIB_H 1) | ||||||
|     SET(HAVE_STRINGS_H 0) |     set(HAVE_STRINGS_H 0) | ||||||
|     SET(HAVE_STRING_H 1) |     set(HAVE_STRING_H 1) | ||||||
|     SET(HAVE_SYS_PARAM_H 0) |     set(HAVE_SYS_PARAM_H 0) | ||||||
|     SET(HAVE_SYS_POLL_H 0) |     set(HAVE_SYS_POLL_H 0) | ||||||
|     SET(HAVE_SYS_SELECT_H 0) |     set(HAVE_SYS_SELECT_H 0) | ||||||
|     SET(HAVE_SYS_SOCKET_H 0) |     set(HAVE_SYS_SOCKET_H 0) | ||||||
|     SET(HAVE_SYS_SOCKIO_H 0) |     set(HAVE_SYS_SOCKIO_H 0) | ||||||
|     SET(HAVE_SYS_STAT_H 1) |     set(HAVE_SYS_STAT_H 1) | ||||||
|     SET(HAVE_SYS_TIME_H 0) |     set(HAVE_SYS_TIME_H 0) | ||||||
|     SET(HAVE_SYS_TYPES_H 1) |     set(HAVE_SYS_TYPES_H 1) | ||||||
|     SET(HAVE_SYS_UTIME_H 1) |     set(HAVE_SYS_UTIME_H 1) | ||||||
|     SET(HAVE_TERMIOS_H 0) |     set(HAVE_TERMIOS_H 0) | ||||||
|     SET(HAVE_TERMIO_H 0) |     set(HAVE_TERMIO_H 0) | ||||||
|     SET(HAVE_TIME_H 1) |     set(HAVE_TIME_H 1) | ||||||
|     SET(HAVE_UNISTD_H 0) |     set(HAVE_UNISTD_H 0) | ||||||
|     SET(HAVE_UTIME_H 0) |     set(HAVE_UTIME_H 0) | ||||||
|     SET(HAVE_X509_H 0) |     set(HAVE_X509_H 0) | ||||||
|     SET(HAVE_ZLIB_H 0) |     set(HAVE_ZLIB_H 0) | ||||||
|  |  | ||||||
|     SET(HAVE_SIZEOF_LONG_DOUBLE 1) |     set(HAVE_SIZEOF_LONG_DOUBLE 1) | ||||||
|     SET(SIZEOF_LONG_DOUBLE 8) |     set(SIZEOF_LONG_DOUBLE 8) | ||||||
|  |  | ||||||
|     SET(HAVE_SOCKET 1) |     set(HAVE_SOCKET 1) | ||||||
|     SET(HAVE_POLL 0) |     set(HAVE_POLL 0) | ||||||
|     SET(HAVE_SELECT 1) |     set(HAVE_SELECT 1) | ||||||
|     SET(HAVE_STRDUP 1) |     set(HAVE_STRDUP 1) | ||||||
|     SET(HAVE_STRSTR 1) |     set(HAVE_STRSTR 1) | ||||||
|     SET(HAVE_STRTOK_R 0) |     set(HAVE_STRTOK_R 0) | ||||||
|     SET(HAVE_STRFTIME 1) |     set(HAVE_STRFTIME 1) | ||||||
|     SET(HAVE_UNAME 0) |     set(HAVE_UNAME 0) | ||||||
|     SET(HAVE_STRCASECMP 0) |     set(HAVE_STRCASECMP 0) | ||||||
|     SET(HAVE_STRICMP 1) |     set(HAVE_STRICMP 1) | ||||||
|     SET(HAVE_STRCMPI 1) |     set(HAVE_STRCMPI 1) | ||||||
|     SET(HAVE_GETHOSTBYADDR 1) |     set(HAVE_GETHOSTBYADDR 1) | ||||||
|     SET(HAVE_GETTIMEOFDAY 0) |     set(HAVE_GETTIMEOFDAY 0) | ||||||
|     SET(HAVE_INET_ADDR 1) |     set(HAVE_INET_ADDR 1) | ||||||
|     SET(HAVE_INET_NTOA 1) |     set(HAVE_INET_NTOA 1) | ||||||
|     SET(HAVE_INET_NTOA_R 0) |     set(HAVE_INET_NTOA_R 0) | ||||||
|     SET(HAVE_TCGETATTR 0) |     set(HAVE_TCGETATTR 0) | ||||||
|     SET(HAVE_TCSETATTR 0) |     set(HAVE_TCSETATTR 0) | ||||||
|     SET(HAVE_PERROR 1) |     set(HAVE_PERROR 1) | ||||||
|     SET(HAVE_CLOSESOCKET 1) |     set(HAVE_CLOSESOCKET 1) | ||||||
|     SET(HAVE_SETVBUF 0) |     set(HAVE_SETVBUF 0) | ||||||
|     SET(HAVE_SIGSETJMP 0) |     set(HAVE_SIGSETJMP 0) | ||||||
|     SET(HAVE_GETPASS_R 0) |     set(HAVE_GETPASS_R 0) | ||||||
|     SET(HAVE_STRLCAT 0) |     set(HAVE_STRLCAT 0) | ||||||
|     SET(HAVE_GETPWUID 0) |     set(HAVE_GETPWUID 0) | ||||||
|     SET(HAVE_GETEUID 0) |     set(HAVE_GETEUID 0) | ||||||
|     SET(HAVE_UTIME 1) |     set(HAVE_UTIME 1) | ||||||
|     SET(HAVE_RAND_EGD 0) |     set(HAVE_RAND_EGD 0) | ||||||
|     SET(HAVE_RAND_SCREEN 0) |     set(HAVE_RAND_SCREEN 0) | ||||||
|     SET(HAVE_RAND_STATUS 0) |     set(HAVE_RAND_STATUS 0) | ||||||
|     SET(HAVE_GMTIME_R 0) |     set(HAVE_GMTIME_R 0) | ||||||
|     SET(HAVE_LOCALTIME_R 0) |     set(HAVE_LOCALTIME_R 0) | ||||||
|     SET(HAVE_GETHOSTBYADDR_R 0) |     set(HAVE_GETHOSTBYADDR_R 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R 0) |     set(HAVE_GETHOSTBYNAME_R 0) | ||||||
|     SET(HAVE_SIGNAL_FUNC 1) |     set(HAVE_SIGNAL_FUNC 1) | ||||||
|     SET(HAVE_SIGNAL_MACRO 0) |     set(HAVE_SIGNAL_MACRO 0) | ||||||
|  |  | ||||||
|     SET(HAVE_GETHOSTBYADDR_R_5 0) |     set(HAVE_GETHOSTBYADDR_R_5 0) | ||||||
|     SET(HAVE_GETHOSTBYADDR_R_5_REENTRANT 0) |     set(HAVE_GETHOSTBYADDR_R_5_REENTRANT 0) | ||||||
|     SET(HAVE_GETHOSTBYADDR_R_7 0) |     set(HAVE_GETHOSTBYADDR_R_7 0) | ||||||
|     SET(HAVE_GETHOSTBYADDR_R_7_REENTRANT 0) |     set(HAVE_GETHOSTBYADDR_R_7_REENTRANT 0) | ||||||
|     SET(HAVE_GETHOSTBYADDR_R_8 0) |     set(HAVE_GETHOSTBYADDR_R_8 0) | ||||||
|     SET(HAVE_GETHOSTBYADDR_R_8_REENTRANT 0) |     set(HAVE_GETHOSTBYADDR_R_8_REENTRANT 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R_3 0) |     set(HAVE_GETHOSTBYNAME_R_3 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R_3_REENTRANT 0) |     set(HAVE_GETHOSTBYNAME_R_3_REENTRANT 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R_5 0) |     set(HAVE_GETHOSTBYNAME_R_5 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R_5_REENTRANT 0) |     set(HAVE_GETHOSTBYNAME_R_5_REENTRANT 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R_6 0) |     set(HAVE_GETHOSTBYNAME_R_6 0) | ||||||
|     SET(HAVE_GETHOSTBYNAME_R_6_REENTRANT 0) |     set(HAVE_GETHOSTBYNAME_R_6_REENTRANT 0) | ||||||
|  |  | ||||||
|     SET(TIME_WITH_SYS_TIME 0) |     set(TIME_WITH_SYS_TIME 0) | ||||||
|     SET(HAVE_O_NONBLOCK 0) |     set(HAVE_O_NONBLOCK 0) | ||||||
|     SET(HAVE_IN_ADDR_T 0) |     set(HAVE_IN_ADDR_T 0) | ||||||
|     SET(HAVE_INET_NTOA_R_DECL 0) |     set(HAVE_INET_NTOA_R_DECL 0) | ||||||
|     SET(HAVE_INET_NTOA_R_DECL_REENTRANT 0) |     set(HAVE_INET_NTOA_R_DECL_REENTRANT 0) | ||||||
|     SET(HAVE_GETADDRINFO 0) |     set(HAVE_GETADDRINFO 0) | ||||||
|     SET(STDC_HEADERS 1) |     set(STDC_HEADERS 1) | ||||||
|     SET(RETSIGTYPE_TEST 1) |     set(RETSIGTYPE_TEST 1) | ||||||
|  |  | ||||||
|     SET(HAVE_SIGACTION 0) |     set(HAVE_SIGACTION 0) | ||||||
|     SET(HAVE_MACRO_SIGSETJMP 0) |     set(HAVE_MACRO_SIGSETJMP 0) | ||||||
|   ELSE(WIN32) |   else(WIN32) | ||||||
|     MESSAGE("This file should be included on Windows platform only") |     message("This file should be included on Windows platform only") | ||||||
|   ENDIF(WIN32) |   endif(WIN32) | ||||||
| ENDIF(NOT UNIX) | endif(NOT UNIX) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,31 +1,31 @@ | |||||||
| # File containing various utilities | # File containing various utilities | ||||||
|  |  | ||||||
| # Converts a CMake list to a string containing elements separated by spaces | # Converts a CMake list to a string containing elements separated by spaces | ||||||
| FUNCTION(TO_LIST_SPACES _LIST_NAME OUTPUT_VAR) | function(TO_LIST_SPACES _LIST_NAME OUTPUT_VAR) | ||||||
|   SET(NEW_LIST_SPACE) |   set(NEW_LIST_SPACE) | ||||||
|   FOREACH(ITEM ${${_LIST_NAME}}) |   foreach(ITEM ${${_LIST_NAME}}) | ||||||
|     SET(NEW_LIST_SPACE "${NEW_LIST_SPACE} ${ITEM}") |     set(NEW_LIST_SPACE "${NEW_LIST_SPACE} ${ITEM}") | ||||||
|   ENDFOREACH() |   endforeach() | ||||||
|   STRING(STRIP ${NEW_LIST_SPACE} NEW_LIST_SPACE) |   string(STRIP ${NEW_LIST_SPACE} NEW_LIST_SPACE) | ||||||
|   SET(${OUTPUT_VAR} "${NEW_LIST_SPACE}" PARENT_SCOPE) |   set(${OUTPUT_VAR} "${NEW_LIST_SPACE}" PARENT_SCOPE) | ||||||
| ENDFUNCTION() | endfunction() | ||||||
|  |  | ||||||
| # Appends a lis of item to a string which is a space-separated list, if they don't already exist. | # Appends a lis of item to a string which is a space-separated list, if they don't already exist. | ||||||
| FUNCTION(LIST_SPACES_APPEND_ONCE LIST_NAME) | function(LIST_SPACES_APPEND_ONCE LIST_NAME) | ||||||
|   STRING(REPLACE " " ";" _LIST ${${LIST_NAME}}) |   string(REPLACE " " ";" _LIST ${${LIST_NAME}}) | ||||||
|   LIST(APPEND _LIST ${ARGN}) |   list(APPEND _LIST ${ARGN}) | ||||||
|   LIST(REMOVE_DUPLICATES _LIST) |   list(REMOVE_DUPLICATES _LIST) | ||||||
|   TO_LIST_SPACES(_LIST NEW_LIST_SPACE) |   to_list_spaces(_LIST NEW_LIST_SPACE) | ||||||
|   SET(${LIST_NAME} "${NEW_LIST_SPACE}" PARENT_SCOPE) |   set(${LIST_NAME} "${NEW_LIST_SPACE}" PARENT_SCOPE) | ||||||
| ENDFUNCTION() | endfunction() | ||||||
|  |  | ||||||
| # Convinience function that does the same as LIST(FIND ...) but with a TRUE/FALSE return value. | # Convinience function that does the same as LIST(FIND ...) but with a TRUE/FALSE return value. | ||||||
| # Ex: IN_STR_LIST(MY_LIST "Searched item" WAS_FOUND) | # Ex: IN_STR_LIST(MY_LIST "Searched item" WAS_FOUND) | ||||||
| FUNCTION(IN_STR_LIST LIST_NAME ITEM_SEARCHED RETVAL) | function(IN_STR_LIST LIST_NAME ITEM_SEARCHED RETVAL) | ||||||
| 	LIST(FIND ${LIST_NAME} ${ITEM_SEARCHED} FIND_POS) |   list(FIND ${LIST_NAME} ${ITEM_SEARCHED} FIND_POS) | ||||||
| 	IF(${FIND_POS} EQUAL -1) |   if(${FIND_POS} EQUAL -1) | ||||||
| 		SET(${RETVAL} FALSE PARENT_SCOPE) |     set(${RETVAL} FALSE PARENT_SCOPE) | ||||||
| 	ELSE() |   else() | ||||||
| 		SET(${RETVAL} TRUE PARENT_SCOPE) |     set(${RETVAL} TRUE PARENT_SCOPE) | ||||||
| 	ENDIF() |   endif() | ||||||
| ENDFUNCTION() | endfunction() | ||||||
|   | |||||||
							
								
								
									
										1087
									
								
								CMakeLists.txt
									
									
									
									
									
								
							
							
						
						
									
										1087
									
								
								CMakeLists.txt
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -8,6 +8,6 @@ set(CTEST_PROJECT_NAME "CURL") | |||||||
| set(CTEST_NIGHTLY_START_TIME "00:00:00 EST") | set(CTEST_NIGHTLY_START_TIME "00:00:00 EST") | ||||||
|  |  | ||||||
| set(CTEST_DROP_METHOD "http") | set(CTEST_DROP_METHOD "http") | ||||||
| set(CTEST_DROP_SITE "www.cdash.org") | set(CTEST_DROP_SITE "my.cdash.org") | ||||||
| set(CTEST_DROP_LOCATION "/CDashPublic/submit.php?project=CURL") | set(CTEST_DROP_LOCATION "/submit.php?project=CURL") | ||||||
| set(CTEST_DROP_SITE_CDASH TRUE) | set(CTEST_DROP_SITE_CDASH TRUE) | ||||||
|   | |||||||
| @@ -32,8 +32,8 @@ CMake/FindZLIB.cmake CMake/OtherTests.cmake CMake/Platforms/WindowsCache.cmake \ | |||||||
| CMake/Utilities.cmake include/curl/curlbuild.h.cmake | CMake/Utilities.cmake include/curl/curlbuild.h.cmake | ||||||
|  |  | ||||||
| EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | ||||||
|  curl-style.el sample.emacs RELEASE-NOTES buildconf buildconf.bat	\ |  curl-style.el sample.emacs RELEASE-NOTES buildconf 	\ | ||||||
|  libcurl.pc.in vc6curl.dsw MacOSX-Framework $(CMAKE_DIST) |  libcurl.pc.in vc6curl.dsw MacOSX-Framework Android.mk $(CMAKE_DIST) | ||||||
|  |  | ||||||
| bin_SCRIPTS = curl-config | bin_SCRIPTS = curl-config | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| Curl and libcurl 7.19.5 | Curl and libcurl 7.19.6 | ||||||
|  |  | ||||||
|  Public curl releases:         111 |  Public curl releases:         112 | ||||||
|  Command line options:         132 |  Command line options:         132 | ||||||
|  curl_easy_setopt() options:   163 |  curl_easy_setopt() options:   163 | ||||||
|  Public functions in libcurl:  58 |  Public functions in libcurl:  58 | ||||||
| @@ -9,45 +9,42 @@ Curl and libcurl 7.19.5 | |||||||
|  |  | ||||||
| This release includes the following changes: | This release includes the following changes: | ||||||
|  |  | ||||||
|  o libcurl now closes all dead connections whenever you attempt to open a new |  o CURLOPT_FTPPORT (and curl's -P/--ftpport) support port ranges | ||||||
|    connection |  o Added CURLOPT_SSH_KNOWNHOSTS, CURLOPT_SSH_KEYFUNCTION, CURLOPT_SSH_KEYDATA | ||||||
|  o libssh2's version number can now be figured out run-time instead of using |  o CURLOPT_QUOTE, CURLOPT_POSTQUOTE and CURLOPT_PREQUOTE can be told to ignore | ||||||
|    the build-time fixed number |    error responses when used with FTP | ||||||
|  o CURLOPT_SEEKFUNCTION may now return CURL_SEEKFUNC_CANTSEEK |  | ||||||
|  o curl can now upload with resume even when reading from a pipe |  | ||||||
|  o a build-time configured curl_socklen_t is now used instead of socklen_t |  | ||||||
|  |  | ||||||
| This release includes the following bugfixes: | This release includes the following bugfixes: | ||||||
|  |  | ||||||
|  o NTLM authentication memory leak on SSPI enabled Windows builds |  o crash on bad socket close with FTP | ||||||
|  o fixed the GnuTLS-using code to do correct return code checks |  o leaking cookie memory when duplicate domains or paths were used | ||||||
|  o an alloc-related call in the OpenSSL-using code didn't check the return value |  o build fix for Symbian | ||||||
|  o curl_easy_duphandle() failed to duplicate cookies at times |  o CURLOPT_USERPWD set to NULL clears auth credentials | ||||||
|  o missing TELNET timeout support in Windows builds |  o libcurl-NSS build fixes | ||||||
|  o missing Curl_read() and write callback result checking in TELNET transfers |  o configure script fixed for VMS | ||||||
|  o more ciphers enabled in libcurl built to use NSS |  o set Content-Length: with POST and PUT failed with NTLM auth | ||||||
|  o properly return an error code in curl_easy_recv |  o allow building libcurl for VxWorks | ||||||
|  o Sun compilers specific preprocessor block removed from curlbuild.h.dist |  o curl tool exit codes fixed for VMS | ||||||
|  o allow creation of four way fat libcurl Mac OS X Framework |  o --no-buffer treated correctly | ||||||
|  o several memory leaks in libcurl+NSS |  o djgpp build fix | ||||||
|  o improved the CURLOPT_NOBODY set to 0 confusions |  o configure detection of GnuTLS now based on pkg-config as well | ||||||
|  o persistent connections when doing FTP over a HTTP proxy |  o libcurl-NSS client cert handling segfaults | ||||||
|  o --libcurl bogus strings where other data was pointed to |  o curl uploading from stdin/pipes now works in non-blocking way so that it | ||||||
|  o crash related to FTP and "Re-used connection seems dead, get a new one" |    continues the downloading even when the read stalls | ||||||
|  o CURLINFO_APPCONNECT_TIME with the multi interface |  o ftp credentials are added to the url if needed for http proxies | ||||||
|  o Enhanced upload speeds on Windows |  o curl -o - sends data to stdout using binary mode on windows | ||||||
|  o TFTP problems after a failed transfer to the same host |  o fixed the separators for "array" style string that CURLINFO_CERTINFO returns | ||||||
|  o improved out of the box TPF compatibility |  o auth problem over several hosts with re-used connection | ||||||
|  o HTTP PUT protocol line endings portions mangled from CRLF to CRCRLF |  o improved the support for client certificates in libcurl+NSS | ||||||
|  o Rejected SSL session ids are killed properly (for OpenSSL and GnuTLS builds) |  o fix leak in gtls code | ||||||
|  o Deal with the TFTP OACK packet |  o missing algorithms in libcurl+OpenSSL | ||||||
|  o fixed roff mistakes in man pages |  o with noproxy set you could still get a proxy if a proxy env was set | ||||||
|  o use SOCKS proxy with the multi interface |  o rand seeding on libcurl on windows built with OpenSSL was not thread-safe | ||||||
|  o fixed the Curl_getoff_all_pipelines SIGSEGV  |  o fixed the zero byte inserted in cert name flaw in libcurl+OpenSSL | ||||||
|  o POST, NTLM and following a redirect hang |  o don't try SNI with SSLv2 or SSLv3 (OpenSSL and GnuTLS builds) | ||||||
|  o libcurl+NSS endless loop on incorrect password for private key |  o libcurl+OpenSSL would wrongly acknowledge a cert if CN matched but | ||||||
|  o gzip decompression memory leak |    subjectAltName didn't | ||||||
|  o no_proxy flaw with user name in URL |  o TFTP upload sent illegal TSIZE packets | ||||||
|  |  | ||||||
| This release includes the following known bugs: | This release includes the following known bugs: | ||||||
|  |  | ||||||
| @@ -56,12 +53,12 @@ This release includes the following known bugs: | |||||||
| 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: | ||||||
|  |  | ||||||
|  Daniel Fandrich, Yang Tse, David James, Chris Deidun, Bill Egert, |  Yang Tse, Daniel Fandrich, Kamil Dudka, Caolan McNamara, Frank McGeough, | ||||||
|  Andre Guibert de Bruet, Andreas Farber, Frank Hempel, Pierre Brico, |  Andre Guibert de Bruet, Mike Crowe, Claes Jakobsson, John E. Malmberg, | ||||||
|  Kamil Dudka, Jim Freeman, Daniel Johnson, Toshio Kuratomi, Martin Storsjo, |  Aaron Oneal, Igor Novoseltsev, Eric Wong, Bill Hoffman, Daniel Steinberg, | ||||||
|  Pramod Sharma, Gisle Vanem, Lenaic Lefever, Rainer Koenig, Sven Wegener, |  Fabian Keil, Michal Marek, Reuven Wachtfogel, Markus Koetter, | ||||||
|  Tim Chen, Constantine Sapuntzakis, David McCreedy, Michael Smith, |  Constantine Sapuntzakis, David Binderman, Johan van Selst, Alexander Beedie, | ||||||
|  Colin Watson, Ebenezer Ikonne, Laurent Rabret, Michael Cronenworth, |  Tanguy Fautre, Scott Cantor, Curt Bogmine, Peter Sylvester, Benbuck Nason, | ||||||
|  Balint Szilakszi, James Bursa |  Carsten Lange | ||||||
|  |  | ||||||
|         Thanks! (and sorry if I forgot to mention someone) |         Thanks! (and sorry if I forgot to mention someone) | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								TODO-RELEASE
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								TODO-RELEASE
									
									
									
									
									
								
							| @@ -1,9 +1,31 @@ | |||||||
| To be addressed in 7.19.6 (planned release: July 2009) | To be addressed in 7.19.7 (planned release: October 2009) | ||||||
| ========================= | ========================= | ||||||
|  |  | ||||||
| 226 - Active Mode FTPS Data Port Range | 248 - "Pausing pipeline problems." | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-07/0214.html | ||||||
|  |  | ||||||
| 235 - KNOWN_BUG #65 | 251 - TFTP block size / better integration in transfer | ||||||
|       Code adjustment for FTP over socks proxy remains |       http://curl.haxx.se/mail/lib-2009-08/0028.html | ||||||
|  |  | ||||||
|  | 254 - Problem re-using easy handle after call to curl_multi_remove_handle | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-07/0249.html | ||||||
|  |      | ||||||
|  | 255 - debugging a crash in Curl_pgrsTime/checkPendPipeline? | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-08/0066.html | ||||||
|  |  | ||||||
|  | 256 - "More questions about ares behavior" | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-08/0012.html | ||||||
|  |  | ||||||
|  | 244 - patch for [out] parameters | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-06/0342.html | ||||||
|  |  | ||||||
|  | 245 - HTTP version getinfo | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-06/0312.html | ||||||
|  |  | ||||||
|  | 247 - Using CURLINFO_ERROR in Curl_failf | ||||||
|  |       http://curl.haxx.se/mail/lib-2009-06/0065.html | ||||||
|  |  | ||||||
|  | 253 - add option to disable SNI for TLS handshakes | ||||||
|  |  | ||||||
|  | 257 - | ||||||
|  |  | ||||||
| 240 -  |  | ||||||
|   | |||||||
							
								
								
									
										51
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										51
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -1852,7 +1852,7 @@ AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | |||||||
|   AC_REQUIRE([AC_HEADER_TIME])dnl |   AC_REQUIRE([AC_HEADER_TIME])dnl | ||||||
|   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK])dnl |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK])dnl | ||||||
|   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK2])dnl |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK2])dnl | ||||||
|   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h) |   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h sys/socket.h) | ||||||
|   AC_CACHE_CHECK([for struct timeval], [ac_cv_struct_timeval], [ |   AC_CACHE_CHECK([for struct timeval], [ac_cv_struct_timeval], [ | ||||||
|     AC_COMPILE_IFELSE([ |     AC_COMPILE_IFELSE([ | ||||||
|       AC_LANG_PROGRAM([[ |       AC_LANG_PROGRAM([[ | ||||||
| @@ -1882,6 +1882,9 @@ AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | |||||||
| #ifdef HAVE_TIME_H | #ifdef HAVE_TIME_H | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_SOCKET_H | ||||||
|  | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
|       ]],[[ |       ]],[[ | ||||||
|         struct timeval ts; |         struct timeval ts; | ||||||
| @@ -2199,6 +2202,52 @@ AC_DEFUN([CURL_CHECK_LIBS_CLOCK_GETTIME_MONOTONIC], [ | |||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CURL_CHECK_LIBS_CONNECT | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if network connect function is already available | ||||||
|  | dnl using current libraries or if another one is required. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CURL_CHECK_LIBS_CONNECT], [ | ||||||
|  |   AC_REQUIRE([CURL_INCLUDES_WINSOCK2])dnl | ||||||
|  |   AC_MSG_CHECKING([for connect in libraries]) | ||||||
|  |   tst_connect_save_LIBS="$LIBS" | ||||||
|  |   tst_connect_need_LIBS="unknown" | ||||||
|  |   for tst_lib in '' '-lsocket' ; do | ||||||
|  |     if test "$tst_connect_need_LIBS" = "unknown"; then | ||||||
|  |       LIBS="$tst_lib $tst_connect_save_LIBS" | ||||||
|  |       AC_LINK_IFELSE([ | ||||||
|  |         AC_LANG_PROGRAM([[ | ||||||
|  |           $curl_includes_winsock2 | ||||||
|  |           #ifndef HAVE_WINDOWS_H | ||||||
|  |             int connect(int, void*, int); | ||||||
|  |           #endif | ||||||
|  |         ]],[[ | ||||||
|  |           if(0 != connect(0, 0, 0)) | ||||||
|  |             return 1; | ||||||
|  |         ]]) | ||||||
|  |       ],[ | ||||||
|  |         tst_connect_need_LIBS="$tst_lib" | ||||||
|  |       ]) | ||||||
|  |     fi | ||||||
|  |   done | ||||||
|  |   LIBS="$tst_connect_save_LIBS" | ||||||
|  |   # | ||||||
|  |   case X-"$tst_connect_need_LIBS" in | ||||||
|  |     X-unknown) | ||||||
|  |       AC_MSG_RESULT([cannot find connect]) | ||||||
|  |       AC_MSG_ERROR([cannot find connect function in libraries.]) | ||||||
|  |       ;; | ||||||
|  |     X-) | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       ;; | ||||||
|  |     *) | ||||||
|  |       AC_MSG_RESULT([$tst_connect_need_LIBS]) | ||||||
|  |       LIBS="$tst_connect_need_LIBS $tst_connect_save_LIBS" | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CURL_DEFINE_UNQUOTED (VARIABLE, [VALUE]) | dnl CURL_DEFINE_UNQUOTED (VARIABLE, [VALUE]) | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Like AC_DEFINE_UNQUOTED this macro will define a C preprocessor | dnl Like AC_DEFINE_UNQUOTED this macro will define a C preprocessor | ||||||
|   | |||||||
| @@ -1,4 +1,6 @@ | |||||||
|  | *.html | ||||||
| *.lo | *.lo | ||||||
|  | *.pdf | ||||||
| .deps | .deps | ||||||
| .libs | .libs | ||||||
| Makefile | Makefile | ||||||
| @@ -10,8 +12,8 @@ ares_build.h | |||||||
| ares_version.h.dist | ares_version.h.dist | ||||||
| autom4te.cache | autom4te.cache | ||||||
| config.guess | config.guess | ||||||
| config.h | ares_config.h | ||||||
| config.h.in | ares_config.h.in | ||||||
| config.log | config.log | ||||||
| config.lt | config.lt | ||||||
| config.status | config.status | ||||||
| @@ -22,5 +24,6 @@ libcares.la | |||||||
| libcares.pc | libcares.pc | ||||||
| libtool | libtool | ||||||
| ltmain.sh | ltmain.sh | ||||||
|  | man3 | ||||||
| missing | missing | ||||||
| stamp-h* | stamp-h* | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								ares/CHANGES
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								ares/CHANGES
									
									
									
									
									
								
							| @@ -1,5 +1,53 @@ | |||||||
|   Changelog for the c-ares project |   Changelog for the c-ares project | ||||||
|  |  | ||||||
|  | * 3 Aug 2009 (Daniel Stenberg) | ||||||
|  | - Joshua Kwan fixed the init routine to fill in the defaults for stuff that | ||||||
|  |   fails to get inited by other means. This fixes a case of when the c-ares | ||||||
|  |   init fails when internet access is fone. | ||||||
|  |  | ||||||
|  | - Timo Teras changed the reason code used in the resolve callback done when | ||||||
|  |   ares_cancel() is used, to be ARES_ECANCELLED instead of ARES_ETIMEOUT to | ||||||
|  |   better allow the callback to know what's happening. | ||||||
|  |  | ||||||
|  | * 14 Jul 2009 (Guenter Knauf) | ||||||
|  | - renamed generated config.h to ares_config.h to avoid any future clashes | ||||||
|  |   with config.h from other projects. | ||||||
|  |    | ||||||
|  | * June 8 2009 (Yang Tse) | ||||||
|  | - Removed buildconf.bat from release and daily snapshot archives. This | ||||||
|  |   file is only for CVS tree checkout builds. | ||||||
|  |  | ||||||
|  | * May 26 2009 (Yang Tse) | ||||||
|  | - Added --enable-curldebug configure option to enable and disable building | ||||||
|  |   with the low-level curl debug memory tracking 'feature' to allow decoupled | ||||||
|  |   setting from --enable-debug, allowing again to build c-ares independently | ||||||
|  |   out of the CVS tree. | ||||||
|  |  | ||||||
|  |   For the c-ares library option --enable-debug enables debug build features | ||||||
|  |   which are _not_ related with memory tracking. For the c-ares library when | ||||||
|  |   --enable-debug is given it does not enable the memory tracking feature. If | ||||||
|  |   you wish to enable the curl debug memory tracking you must use configure | ||||||
|  |   option --enable-curldebug explicitily to do so. | ||||||
|  |  | ||||||
|  |   Internally, definition of preprocessor symbol DEBUGBUILD restricts code | ||||||
|  |   which is only compiled for debug enabled builds. And symbol CURLDEBUG is | ||||||
|  |   used to differentiate code which is _only_ used for memory tracking. | ||||||
|  |  | ||||||
|  | * May 19 2009 (Yang Tse) | ||||||
|  | - Introduced ares_library_init() and ares_library_cleanup() functions. | ||||||
|  |  | ||||||
|  |   This is an API and ABI break for Win32/64 systems. Non-Win32/64 build targets | ||||||
|  |   using c-ares 1.6.1 can still survive without calling these functions. Read all | ||||||
|  |   the details on ares_library_init(3) and ares_library_cleanup(3) man pages that | ||||||
|  |   are included. | ||||||
|  |  | ||||||
|  |   curl/libcurl 7.19.5 is fully compatible with c-ares 1.6.1 on all systems. | ||||||
|  |  | ||||||
|  |   In order to use c-ares 1.6.1 with curl/libcurl on Win32/64 systems it is | ||||||
|  |   required that curl/libcurl is 7.19.5 or newer. In other words, it is not | ||||||
|  |   possible on Win32/64 to use c-ares 1.6.1 with a curl/libcurl version less | ||||||
|  |   than 7.19.5 | ||||||
|  |  | ||||||
| * May 11 2009 (Daniel Stenberg) | * May 11 2009 (Daniel Stenberg) | ||||||
| - Gregor Jasny made c-ares link with libtool 's -export-symbols-regex option to | - Gregor Jasny made c-ares link with libtool 's -export-symbols-regex option to | ||||||
|   only expose functions starting with ares_. |   only expose functions starting with ares_. | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								ares/CVS-INFO
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								ares/CVS-INFO
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  |  | ||||||
|  | CVS-INFO | ||||||
|  |  | ||||||
|  | This file is only present in the CVS - never in release archives. It is used | ||||||
|  | as a sentinel file in buildconf.bat in order to differentiate a CVS checkout | ||||||
|  | from release and daily snapshot archives. | ||||||
|  |  | ||||||
| @@ -14,11 +14,13 @@ ACLOCAL_AMFLAGS = -I m4 | |||||||
| # libcurl, but we do this anyway for convenience. | # libcurl, but we do this anyway for convenience. | ||||||
| # | # | ||||||
| # $(top_builddir)/../include is for libcurl's generated curl/curlbuild.h file | # $(top_builddir)/../include is for libcurl's generated curl/curlbuild.h file | ||||||
| # $(top_builddir) is for c-ares's generated config.h file | # $(top_srcdir)/../include is for libcurl's external include files | ||||||
|  | # $(top_builddir) is for c-ares's generated ares_config.h file | ||||||
| # $(top_srcdir) is for c-ares's lib/setup.h and other "c-ares-private" files | # $(top_srcdir) is for c-ares's lib/setup.h and other "c-ares-private" files | ||||||
|  |  | ||||||
| if CURLDEBUG | if CURLDEBUG | ||||||
| INCLUDES = -I$(top_builddir)/../include \ | INCLUDES = -I$(top_builddir)/../include \ | ||||||
|  |            -I$(top_srcdir)/../include   \ | ||||||
|            -I$(top_builddir)            \ |            -I$(top_builddir)            \ | ||||||
|            -I$(top_srcdir) |            -I$(top_srcdir) | ||||||
| else | else | ||||||
| @@ -33,7 +35,7 @@ man_MANS = $(MANPAGES) | |||||||
| MSVCFILES = vc/vc.dsw vc/acountry/acountry.dsp vc/adig/adig.dsp \ | MSVCFILES = vc/vc.dsw vc/acountry/acountry.dsp vc/adig/adig.dsp \ | ||||||
|  vc/ahost/ahost.dsp vc/areslib/areslib.dsp vc/areslib/areslib.dsw |  vc/ahost/ahost.dsp vc/areslib/areslib.dsp vc/areslib/areslib.dsw | ||||||
|  |  | ||||||
| if DEBUGBUILD | if CURLDEBUG | ||||||
| PROGS = | PROGS = | ||||||
| else | else | ||||||
| PROGS = ahost adig acountry | PROGS = ahost adig acountry | ||||||
| @@ -46,7 +48,9 @@ noinst_PROGRAMS =$(PROGS) | |||||||
| EXTRA_DIST = AUTHORS CHANGES README.cares Makefile.inc Makefile.dj	   \ | EXTRA_DIST = AUTHORS CHANGES README.cares Makefile.inc Makefile.dj	   \ | ||||||
|  Makefile.m32 Makefile.netware Makefile.vc6 $(man_MANS) $(MSVCFILES)	   \ |  Makefile.m32 Makefile.netware Makefile.vc6 $(man_MANS) $(MSVCFILES)	   \ | ||||||
|  config-win32.h RELEASE-NOTES libcares.pc.in buildconf get_ver.awk maketgz \ |  config-win32.h RELEASE-NOTES libcares.pc.in buildconf get_ver.awk maketgz \ | ||||||
|  TODO ares_build.h.in buildconf.bat |  TODO ares_build.h.in $(PDFPAGES) | ||||||
|  |  | ||||||
|  | CLEANFILES = $(PDFPAGES) $(HTMLPAGES) | ||||||
|  |  | ||||||
| DISTCLEANFILES = ares_build.h | DISTCLEANFILES = ares_build.h | ||||||
|  |  | ||||||
| @@ -87,7 +91,7 @@ if NO_UNDEFINED | |||||||
| UNDEF = -no-undefined | UNDEF = -no-undefined | ||||||
| endif | endif | ||||||
|  |  | ||||||
| EXPORT_SYMBOLS = -export-symbols-regex '^ares_[[:alnum:]].*' | # EXPORT_SYMBOLS = -export-symbols-regex '^ares_[[:alnum:]].*' | ||||||
|  |  | ||||||
| libcares_la_LDFLAGS = $(UNDEF) $(VER) $(EXPORT_SYMBOLS) | libcares_la_LDFLAGS = $(UNDEF) $(VER) $(EXPORT_SYMBOLS) | ||||||
|  |  | ||||||
| @@ -103,13 +107,52 @@ libcares_la_HEADERS = ares.h ares_version.h ares_dns.h \ | |||||||
| 	ares_build.h ares_rules.h | 	ares_build.h ares_rules.h | ||||||
|  |  | ||||||
| ahost_SOURCES = ahost.c ares_getopt.c ares_getopt.h | ahost_SOURCES = ahost.c ares_getopt.c ares_getopt.h | ||||||
| ahost_LDADD = $(top_builddir)/$(lib_LTLIBRARIES) | ahost_LDADD = $(top_builddir)/libcares.la | ||||||
|  |  | ||||||
| adig_SOURCES = adig.c ares_getopt.c ares_getopt.h | adig_SOURCES = adig.c ares_getopt.c ares_getopt.h | ||||||
| adig_LDADD = $(top_builddir)/$(lib_LTLIBRARIES) | adig_LDADD = $(top_builddir)/libcares.la | ||||||
|  |  | ||||||
| acountry_SOURCES = acountry.c ares_getopt.c ares_getopt.h | acountry_SOURCES = acountry.c ares_getopt.c ares_getopt.h | ||||||
| acountry_LDADD = $(top_builddir)/$(lib_LTLIBRARIES) | acountry_LDADD = $(top_builddir)/libcares.la | ||||||
|  |  | ||||||
|  | SOURCEDMANDIR = man3 | ||||||
|  | SOURCEDMANPAGES = ares_init.3 | ||||||
|  |  | ||||||
|  | clean-local: clean-sourced-manpages | ||||||
|  |  | ||||||
|  | clean-sourced-manpages: | ||||||
|  | 	@srcdmandir='$(SOURCEDMANDIR)'; \ | ||||||
|  | 	echo "rm -rf $(top_builddir)/$$srcdmandir"; \ | ||||||
|  | 	rm -rf $(top_builddir)/$$srcdmandir | ||||||
|  |  | ||||||
|  | sourced-manpages: clean-sourced-manpages | ||||||
|  | 	@srcdmandir='$(SOURCEDMANDIR)'; \ | ||||||
|  | 	srcdmanfiles='$(SOURCEDMANPAGES)'; \ | ||||||
|  | 	mkdir $(top_builddir)/$$srcdmandir; \ | ||||||
|  | 	for file in $$srcdmanfiles; do \ | ||||||
|  | 	  if test -f $(top_srcdir)/$$file; then \ | ||||||
|  | 	    echo "cp $(top_srcdir)/$$file $(top_builddir)/$$srcdmandir/$$file"; \ | ||||||
|  | 	    cp $(top_srcdir)/$$file $(top_builddir)/$$srcdmandir/$$file; \ | ||||||
|  | 	  fi; \ | ||||||
|  | 	done | ||||||
|  |  | ||||||
|  | MAN2HTML = roffit --mandir=. < $< >$@ | ||||||
|  |  | ||||||
|  | SUFFIXES = .3 .html | ||||||
|  |  | ||||||
|  | html: sourced-manpages $(HTMLPAGES) | ||||||
|  |  | ||||||
|  | .3.html: | ||||||
|  | 	$(MAN2HTML) | ||||||
|  |  | ||||||
|  | pdf: sourced-manpages $(PDFPAGES) | ||||||
|  |  | ||||||
|  | .3.pdf: | ||||||
|  | 	@(foo=`echo $@ | sed -e 's/\.[0-9]$$//g'`; \ | ||||||
|  | 	groff -Tps -man $< >$$foo.ps; \ | ||||||
|  | 	ps2pdf $$foo.ps $@; \ | ||||||
|  | 	rm $$foo.ps; \ | ||||||
|  | 	echo "converted $< to $@") | ||||||
|  |  | ||||||
| # Make files named *.dist replace the file without .dist extension | # Make files named *.dist replace the file without .dist extension | ||||||
| dist-hook: | dist-hook: | ||||||
|   | |||||||
| @@ -4,37 +4,17 @@ | |||||||
| # | # | ||||||
| # $Id$ | # $Id$ | ||||||
|  |  | ||||||
|  |  | ||||||
| TOPDIR = .. | TOPDIR = .. | ||||||
|  |  | ||||||
| include ../packages/DOS/common.dj | include ../packages/DOS/common.dj | ||||||
|  |  | ||||||
| include Makefile.inc | include Makefile.inc | ||||||
|  |  | ||||||
| CFLAGS += -DWATT32 -DHAVE_AF_INET6 -DHAVE_PF_INET6 -DHAVE_IOCTLSOCKET \ | CFLAGS += -DWATT32 -Dselect=select_s | ||||||
|           -DHAVE_IOCTLSOCKET_FIONBIO -DHAVE_STRUCT_IN6_ADDR \ |  | ||||||
|           -DHAVE_SOCKADDR_IN6_SIN6_SCOPE_ID -DHAVE_SYS_TIME_H \ |  | ||||||
|           -DHAVE_STRUCT_SOCKADDR_IN6 -DHAVE_STRUCT_ADDRINFO \ |  | ||||||
|           -DHAVE_ARPA_NAMESER_H -DHAVE_ARPA_INET_H -DHAVE_SYS_SOCKET_H \ |  | ||||||
|           -DHAVE_SYS_UIO_H -DHAVE_NETINET_IN_H -DHAVE_NETINET_TCP_H \ |  | ||||||
|           -DNS_INADDRSZ=4 -DHAVE_RECV -DHAVE_SEND -DHAVE_GETTIMEOFDAY \ |  | ||||||
|           -DSEND_TYPE_ARG1='int'   -DSEND_QUAL_ARG2='const' \ |  | ||||||
|           -DSEND_TYPE_ARG2='void*' -DSEND_TYPE_ARG3='int' \ |  | ||||||
|           -DSEND_TYPE_ARG4='int'   -DSEND_TYPE_RETV='int' \ |  | ||||||
|           -DRECV_TYPE_ARG1='int'   -DRECV_TYPE_ARG2='void*' \ |  | ||||||
|           -DRECV_TYPE_ARG3='int'   -DRECV_TYPE_ARG4='int' \ |  | ||||||
|           -DRECV_TYPE_RETV='int'   -DHAVE_STRUCT_TIMEVAL \ |  | ||||||
|           -Dselect=select_s        -UHAVE_CONFIG_H \ |  | ||||||
|           -DRECVFROM_TYPE_ARG1='int' -DRECVFROM_TYPE_ARG2='void' \ |  | ||||||
|           -DRECVFROM_TYPE_ARG3='int' -DRECVFROM_TYPE_ARG4='int' \ |  | ||||||
|           -DRECVFROM_TYPE_ARG6='int' -DRECVFROM_TYPE_RETV='int' \ |  | ||||||
|           -DRECVFROM_TYPE_ARG5='struct sockaddr' -DHAVE_RECVFROM \ |  | ||||||
|           -DRECVFROM_TYPE_ARG2_IS_VOID -DHAVE_STRDUP -DHAVE_NETDB_H \ |  | ||||||
|           -DHAVE_STRCASECMP -DHAVE_STRNCASECMP -DHAVE_GETHOSTNAME \ |  | ||||||
|           -DHAVE_LIMITS_H |  | ||||||
|  |  | ||||||
| LDFLAGS = -s | LDFLAGS = -s | ||||||
|  |  | ||||||
| ifeq ($(USE_DEBUG),1) | ifeq ($(USE_CURLDEBUG),1) | ||||||
|   EX_LIBS  = ../lib/libcurl.a |   EX_LIBS  = ../lib/libcurl.a | ||||||
|   OBJ_HACK = $(OBJECTS) |   OBJ_HACK = $(OBJECTS) | ||||||
| else | else | ||||||
| @@ -57,12 +37,15 @@ EX_LIBS += $(WATT32_ROOT)/lib/libwatt.a | |||||||
|  |  | ||||||
| OBJECTS = $(addprefix $(OBJ_DIR)/, $(CSOURCES:.c=.o)) | OBJECTS = $(addprefix $(OBJ_DIR)/, $(CSOURCES:.c=.o)) | ||||||
|  |  | ||||||
| all: $(OBJ_DIR) libcares.a ahost.exe adig.exe acountry.exe | all: $(OBJ_DIR) ares_config.h libcares.a ahost.exe adig.exe acountry.exe | ||||||
| 	@echo Welcome to c-ares. | 	@echo Welcome to c-ares. | ||||||
|  |  | ||||||
| libcares.a: $(OBJECTS) | libcares.a: $(OBJECTS) | ||||||
| 	ar rs $@ $? | 	ar rs $@ $? | ||||||
|  |  | ||||||
|  | ares_config.h: config.dos | ||||||
|  | 	$(COPY) $^ $@ | ||||||
|  |  | ||||||
| ahost.exe: ahost.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | ahost.exe: ahost.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | ||||||
| 	$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS) | 	$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS) | ||||||
|  |  | ||||||
| @@ -72,12 +55,30 @@ adig.exe: adig.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | |||||||
| acountry.exe: acountry.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | acountry.exe: acountry.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | ||||||
| 	$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS) | 	$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS) | ||||||
|  |  | ||||||
| clean: | # clean generated files | ||||||
| 	rm -f $(OBJECTS) libcares.a | # | ||||||
|  | genclean: | ||||||
|  | 	- $(DELETE) ares_config.h | ||||||
|  |  | ||||||
| vclean realclean: clean | # clean object files and subdir | ||||||
| 	rm -f ahost.exe adig.exe acountry.exe depend.dj | # | ||||||
| 	- rmdir $(OBJ_DIR) | objclean: genclean | ||||||
|  | 	- $(DELETE) $(OBJ_DIR)$(DS)*.o | ||||||
|  | 	- $(RMDIR) $(OBJ_DIR) | ||||||
|  |  | ||||||
|  | # clean without removing built library and programs | ||||||
|  | # | ||||||
|  | clean: objclean | ||||||
|  | 	- $(DELETE) depend.dj | ||||||
|  |  | ||||||
|  | # clean everything | ||||||
|  | # | ||||||
|  | realclean vclean: clean | ||||||
|  | 	- $(DELETE) libcares.a | ||||||
|  | 	- $(DELETE) acountry.exe | ||||||
|  | 	- $(DELETE) adig.exe | ||||||
|  | 	- $(DELETE) ahost.exe | ||||||
|  | 	- $(DELETE) libcares.a | ||||||
|  |  | ||||||
| -include depend.dj | -include depend.dj | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,25 +1,157 @@ | |||||||
| CSOURCES = ares_fds.c ares_getsock.c ares_process.c ares_free_hostent.c	\ |  | ||||||
| ares_query.c ares__close_sockets.c ares_free_string.c ares_search.c	\ |  | ||||||
| ares__get_hostent.c ares_gethostbyaddr.c ares_send.c ares__read_line.c	\ |  | ||||||
| ares_gethostbyname.c ares_strerror.c ares_cancel.c ares_init.c		\ |  | ||||||
| ares_timeout.c ares_destroy.c ares_mkquery.c ares_version.c		\ |  | ||||||
| ares_expand_name.c ares_parse_a_reply.c windows_port.c ares_strdup.c	\ |  | ||||||
| ares_expand_string.c ares_parse_ptr_reply.c ares_parse_aaaa_reply.c	\ |  | ||||||
| ares_getnameinfo.c inet_net_pton.c bitncmp.c inet_ntop.c ares_writev.c	\ |  | ||||||
| ares_parse_ns_reply.c ares_llist.c ares__timeval.c ares_strcasecmp.c	\ |  | ||||||
| ares_library_init.c |  | ||||||
|  |  | ||||||
| HHEADERS = ares.h ares_private.h setup.h ares_dns.h ares_version.h          \ | CSOURCES = ares__close_sockets.c	\ | ||||||
|  nameser.h inet_net_pton.h inet_ntop.h ares_ipv6.h bitncmp.h setup_once.h   \ |   ares__get_hostent.c			\ | ||||||
|  ares_llist.h ares_strdup.h ares_strcasecmp.h ares_writev.h ares_build.h    \ |   ares__read_line.c			\ | ||||||
|  ares_rules.h ares_library_init.h |   ares__timeval.c			\ | ||||||
|  |   ares_cancel.c				\ | ||||||
|  |   ares_destroy.c			\ | ||||||
|  |   ares_expand_name.c			\ | ||||||
|  |   ares_expand_string.c			\ | ||||||
|  |   ares_fds.c				\ | ||||||
|  |   ares_free_hostent.c			\ | ||||||
|  |   ares_free_string.c			\ | ||||||
|  |   ares_gethostbyaddr.c			\ | ||||||
|  |   ares_gethostbyname.c			\ | ||||||
|  |   ares_getnameinfo.c			\ | ||||||
|  |   ares_getsock.c			\ | ||||||
|  |   ares_init.c				\ | ||||||
|  |   ares_library_init.c			\ | ||||||
|  |   ares_llist.c				\ | ||||||
|  |   ares_mkquery.c			\ | ||||||
|  |   ares_parse_a_reply.c			\ | ||||||
|  |   ares_parse_aaaa_reply.c		\ | ||||||
|  |   ares_parse_ns_reply.c			\ | ||||||
|  |   ares_parse_ptr_reply.c		\ | ||||||
|  |   ares_process.c			\ | ||||||
|  |   ares_query.c				\ | ||||||
|  |   ares_search.c				\ | ||||||
|  |   ares_send.c				\ | ||||||
|  |   ares_strcasecmp.c			\ | ||||||
|  |   ares_strdup.c				\ | ||||||
|  |   ares_strerror.c			\ | ||||||
|  |   ares_timeout.c			\ | ||||||
|  |   ares_version.c			\ | ||||||
|  |   ares_writev.c				\ | ||||||
|  |   bitncmp.c				\ | ||||||
|  |   inet_net_pton.c			\ | ||||||
|  |   inet_ntop.c				\ | ||||||
|  |   windows_port.c | ||||||
|  |  | ||||||
|  | HHEADERS = ares.h			\ | ||||||
|  |   ares_build.h				\ | ||||||
|  |   ares_dns.h				\ | ||||||
|  |   ares_ipv6.h				\ | ||||||
|  |   ares_library_init.h			\ | ||||||
|  |   ares_llist.h				\ | ||||||
|  |   ares_private.h			\ | ||||||
|  |   ares_rules.h				\ | ||||||
|  |   ares_strcasecmp.h			\ | ||||||
|  |   ares_strdup.h				\ | ||||||
|  |   ares_version.h			\ | ||||||
|  |   ares_writev.h				\ | ||||||
|  |   bitncmp.h				\ | ||||||
|  |   inet_net_pton.h			\ | ||||||
|  |   inet_ntop.h				\ | ||||||
|  |   nameser.h				\ | ||||||
|  |   setup.h				\ | ||||||
|  |   setup_once.h | ||||||
|  |  | ||||||
|  | MANPAGES = ares_cancel.3		\ | ||||||
|  |   ares_destroy.3			\ | ||||||
|  |   ares_destroy_options.3		\ | ||||||
|  |   ares_dup.3				\ | ||||||
|  |   ares_expand_name.3			\ | ||||||
|  |   ares_expand_string.3			\ | ||||||
|  |   ares_fds.3				\ | ||||||
|  |   ares_free_hostent.3			\ | ||||||
|  |   ares_free_string.3			\ | ||||||
|  |   ares_gethostbyaddr.3			\ | ||||||
|  |   ares_gethostbyname.3			\ | ||||||
|  |   ares_gethostbyname_file.3		\ | ||||||
|  |   ares_getnameinfo.3			\ | ||||||
|  |   ares_getsock.3			\ | ||||||
|  |   ares_init.3				\ | ||||||
|  |   ares_init_options.3			\ | ||||||
|  |   ares_library_cleanup.3		\ | ||||||
|  |   ares_library_init.3			\ | ||||||
|  |   ares_mkquery.3			\ | ||||||
|  |   ares_parse_a_reply.3			\ | ||||||
|  |   ares_parse_aaaa_reply.3		\ | ||||||
|  |   ares_parse_ns_reply.3			\ | ||||||
|  |   ares_parse_ptr_reply.3		\ | ||||||
|  |   ares_process.3			\ | ||||||
|  |   ares_query.3				\ | ||||||
|  |   ares_save_options.3			\ | ||||||
|  |   ares_search.3				\ | ||||||
|  |   ares_send.3				\ | ||||||
|  |   ares_set_socket_callback.3		\ | ||||||
|  |   ares_strerror.3			\ | ||||||
|  |   ares_timeout.3			\ | ||||||
|  |   ares_version.3 | ||||||
|  |  | ||||||
|  | HTMLPAGES = ares_cancel.html		\ | ||||||
|  |   ares_destroy.html			\ | ||||||
|  |   ares_destroy_options.html		\ | ||||||
|  |   ares_dup.html				\ | ||||||
|  |   ares_expand_name.html			\ | ||||||
|  |   ares_expand_string.html		\ | ||||||
|  |   ares_fds.html				\ | ||||||
|  |   ares_free_hostent.html		\ | ||||||
|  |   ares_free_string.html			\ | ||||||
|  |   ares_gethostbyaddr.html		\ | ||||||
|  |   ares_gethostbyname.html		\ | ||||||
|  |   ares_gethostbyname_file.html		\ | ||||||
|  |   ares_getnameinfo.html			\ | ||||||
|  |   ares_getsock.html			\ | ||||||
|  |   ares_init.html			\ | ||||||
|  |   ares_init_options.html		\ | ||||||
|  |   ares_library_cleanup.html		\ | ||||||
|  |   ares_library_init.html		\ | ||||||
|  |   ares_mkquery.html			\ | ||||||
|  |   ares_parse_a_reply.html		\ | ||||||
|  |   ares_parse_aaaa_reply.html		\ | ||||||
|  |   ares_parse_ns_reply.html		\ | ||||||
|  |   ares_parse_ptr_reply.html		\ | ||||||
|  |   ares_process.html			\ | ||||||
|  |   ares_query.html			\ | ||||||
|  |   ares_save_options.html		\ | ||||||
|  |   ares_search.html			\ | ||||||
|  |   ares_send.html			\ | ||||||
|  |   ares_set_socket_callback.html		\ | ||||||
|  |   ares_strerror.html			\ | ||||||
|  |   ares_timeout.html			\ | ||||||
|  |   ares_version.html | ||||||
|  |  | ||||||
|  | PDFPAGES = ares_cancel.pdf		\ | ||||||
|  |   ares_destroy.pdf			\ | ||||||
|  |   ares_destroy_options.pdf		\ | ||||||
|  |   ares_dup.pdf				\ | ||||||
|  |   ares_expand_name.pdf			\ | ||||||
|  |   ares_expand_string.pdf		\ | ||||||
|  |   ares_fds.pdf				\ | ||||||
|  |   ares_free_hostent.pdf			\ | ||||||
|  |   ares_free_string.pdf			\ | ||||||
|  |   ares_gethostbyaddr.pdf		\ | ||||||
|  |   ares_gethostbyname.pdf		\ | ||||||
|  |   ares_gethostbyname_file.pdf		\ | ||||||
|  |   ares_getnameinfo.pdf			\ | ||||||
|  |   ares_getsock.pdf			\ | ||||||
|  |   ares_init.pdf				\ | ||||||
|  |   ares_init_options.pdf			\ | ||||||
|  |   ares_library_cleanup.pdf		\ | ||||||
|  |   ares_library_init.pdf			\ | ||||||
|  |   ares_mkquery.pdf			\ | ||||||
|  |   ares_parse_a_reply.pdf		\ | ||||||
|  |   ares_parse_aaaa_reply.pdf		\ | ||||||
|  |   ares_parse_ns_reply.pdf		\ | ||||||
|  |   ares_parse_ptr_reply.pdf		\ | ||||||
|  |   ares_process.pdf			\ | ||||||
|  |   ares_query.pdf			\ | ||||||
|  |   ares_save_options.pdf			\ | ||||||
|  |   ares_search.pdf			\ | ||||||
|  |   ares_send.pdf				\ | ||||||
|  |   ares_set_socket_callback.pdf		\ | ||||||
|  |   ares_strerror.pdf			\ | ||||||
|  |   ares_timeout.pdf			\ | ||||||
|  |   ares_version.pdf | ||||||
|  |  | ||||||
| MANPAGES= ares_destroy.3 ares_expand_name.3 ares_expand_string.3 ares_fds.3 \ |  | ||||||
|  ares_free_hostent.3 ares_free_string.3 ares_gethostbyaddr.3		    \ |  | ||||||
|  ares_gethostbyname.3 ares_init.3 ares_init_options.3 ares_mkquery.3	    \ |  | ||||||
|  ares_parse_a_reply.3 ares_parse_ptr_reply.3 ares_process.3		    \ |  | ||||||
|  ares_query.3 ares_search.3 ares_send.3 ares_strerror.3 ares_timeout.3	    \ |  | ||||||
|  ares_version.3 ares_cancel.3 ares_parse_aaaa_reply.3 ares_getnameinfo.3    \ |  | ||||||
|  ares_getsock.3 ares_parse_ns_reply.3 ares_dup.3 \ |  | ||||||
|  ares_destroy_options.3 ares_save_options.3 ares_gethostbyname_file.3       \ |  | ||||||
|  ares_set_socket_callback.3 |  | ||||||
|   | |||||||
| @@ -160,7 +160,7 @@ lib: prebuild $(LTARGET) | |||||||
|  |  | ||||||
| nlm: prebuild $(TARGETS) | nlm: prebuild $(TARGETS) | ||||||
|  |  | ||||||
| prebuild: $(OBJDIR) ares_build.h $(OBJDIR)/version.inc config.h | prebuild: $(OBJDIR) ares_build.h $(OBJDIR)/version.inc ares_config.h | ||||||
|  |  | ||||||
| install: $(INSTDIR) all | install: $(INSTDIR) all | ||||||
| 	@$(CP) *.nlm $(INSTDIR) | 	@$(CP) *.nlm $(INSTDIR) | ||||||
| @@ -170,7 +170,7 @@ install: $(INSTDIR) all | |||||||
| 	@$(CP) ../RELEASE-NOTES $(INSTDIR) | 	@$(CP) ../RELEASE-NOTES $(INSTDIR) | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	-$(RM) $(LTARGET) $(TARGETS) config.h | 	-$(RM) $(LTARGET) $(TARGETS) ares_config.h | ||||||
| 	-$(RM) -r $(OBJDIR) | 	-$(RM) -r $(OBJDIR) | ||||||
| 	-$(RM) -r arpa | 	-$(RM) -r arpa | ||||||
|  |  | ||||||
| @@ -269,7 +269,7 @@ ifeq ($(LD),nlmconv) | |||||||
| 	@echo $(DL)output $(notdir $(@:.def=.nlm))$(DL) >> $@ | 	@echo $(DL)output $(notdir $(@:.def=.nlm))$(DL) >> $@ | ||||||
| endif | endif | ||||||
|  |  | ||||||
| config.h: Makefile.netware | ares_config.h: Makefile.netware | ||||||
| 	@echo Creating $@ | 	@echo Creating $@ | ||||||
| 	@echo $(DL)/* $@ for NetWare target.$(DL) > $@ | 	@echo $(DL)/* $@ for NetWare target.$(DL) > $@ | ||||||
| 	@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@ | 	@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@ | ||||||
|   | |||||||
| @@ -12,8 +12,8 @@ USE_WATT32  = 0 | |||||||
| # Configurations: | # Configurations: | ||||||
| #  -MD   - msvcrt.dll,  threads, release (normal) | #  -MD   - msvcrt.dll,  threads, release (normal) | ||||||
| #  -MDd  - msvcrtd.dll, threads, debug | #  -MDd  - msvcrtd.dll, threads, debug | ||||||
| #  -ML   - libc, no threads,     release | #  -ML   - libc, no threads,     release (not available on VC-2008+) | ||||||
| #  -MLd  - libc, no threads,     debug | #  -MLd  - libc, no threads,     debug   (not available on VC-2008+) | ||||||
| #  -MT   - libc, threads,        release | #  -MT   - libc, threads,        release | ||||||
| #  -MTd  - libc, threads,        debug | #  -MTd  - libc, threads,        debug | ||||||
|  |  | ||||||
| @@ -26,7 +26,7 @@ OBJ_DIR  = VC6_obj | |||||||
| DEF_FILE = cares.def | DEF_FILE = cares.def | ||||||
|  |  | ||||||
| !if "$(USE_WATT32)" == "1" | !if "$(USE_WATT32)" == "1" | ||||||
| CFLAGS  = $(CFLAGS) -UWIN32 -DWATT32 -D_USE_32BIT_TIME_T -I$(WATT_ROOT)\inc | CFLAGS  = $(CFLAGS) -UWIN32 -DWATT32 -I$(WATT_ROOT)\inc | ||||||
| EX_LIBS = $(WATT_ROOT)\lib\wattcpvc_imp.lib | EX_LIBS = $(WATT_ROOT)\lib\wattcpvc_imp.lib | ||||||
|  |  | ||||||
| !else | !else | ||||||
| @@ -35,7 +35,7 @@ EX_LIBS = advapi32.lib ws2_32.lib | |||||||
| !endif | !endif | ||||||
|  |  | ||||||
| !if "$(DEBUG_MODEL)" == "d" | !if "$(DEBUG_MODEL)" == "d" | ||||||
| CFLAGS  = $(CFLAGS) -D_DEBUG -GZ | CFLAGS  = $(CFLAGS) -DDEBUGBUILD -D_DEBUG -GZ | ||||||
| LDFLAGS = $(LDFLAGS) -debug -fixed:no | LDFLAGS = $(LDFLAGS) -debug -fixed:no | ||||||
|  |  | ||||||
| !else | !else | ||||||
|   | |||||||
| @@ -7,15 +7,21 @@ Changed: | |||||||
|  o ares_gethostbyname() now supports 'AF_UNSPEC' as a family for resolving |  o ares_gethostbyname() now supports 'AF_UNSPEC' as a family for resolving | ||||||
|    either AF_INET6 or AF_INET |    either AF_INET6 or AF_INET | ||||||
|  o a build-time configured ares_socklen_t is now used instead of socklen_t |  o a build-time configured ares_socklen_t is now used instead of socklen_t | ||||||
|  |  o new ares_library_init() and ares_library_cleanup() functions | ||||||
|  |  o new --enable-curldebug configure option | ||||||
|  |  o ARES_ECANCELLED is now sent as reason for ares_cancel() | ||||||
|  |  | ||||||
| Fixed: | Fixed: | ||||||
|  |  | ||||||
|  o ares_parse_*_reply() functions now return ARES_EBADRESP instead of |  o ares_parse_*_reply() functions now return ARES_EBADRESP instead of | ||||||
|    ARES_EBADNAME if the name in the response failed to decode |    ARES_EBADNAME if the name in the response failed to decode | ||||||
|  o only expose/export symbols starting with 'ares_' |  o only expose/export symbols starting with 'ares_' | ||||||
|  |  o fix \Device\TCP handle leaks triggered by buggy iphlpapi.dll | ||||||
|  |  o init without internet gone no longer fails | ||||||
|  |  | ||||||
| Thanks go to these friendly people for their efforts and contributions: | Thanks go to these friendly people for their efforts and contributions: | ||||||
|  |  | ||||||
|  Phil Blundell, Japheth Cleaver, Yang Tse, Gregor Jasny |  Phil Blundell, Japheth Cleaver, Yang Tse, Gregor Jasny, Joshua Kwan, | ||||||
|  |  Timo Teras | ||||||
|  |  | ||||||
| Have fun! | Have fun! | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								ares/TODO
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								ares/TODO
									
									
									
									
									
								
							| @@ -6,3 +6,13 @@ ares_gethostbyname | |||||||
| - When built to support IPv6, it needs to also support PF_UNSPEC or similar, | - When built to support IPv6, it needs to also support PF_UNSPEC or similar, | ||||||
|   so that an application can ask for any protocol and then c-ares would return |   so that an application can ask for any protocol and then c-ares would return | ||||||
|   all known resolves and not just explicitly IPv4 _or_ IPv6 resolves. |   all known resolves and not just explicitly IPv4 _or_ IPv6 resolves. | ||||||
|  |  | ||||||
|  | ares_process | ||||||
|  |  | ||||||
|  | - Upon next ABI breakage ares_process() should be changed to return 'int' | ||||||
|  |   and return ARES_ENOTINITIALIZED if ares_library_init() has not been called. | ||||||
|  |  | ||||||
|  | ares_process_fd | ||||||
|  |  | ||||||
|  | - Upon next ABI breakage ares_process_fd() should be changed to return | ||||||
|  |   'int' and return ARES_ENOTINITIALIZED if library has not been initialized. | ||||||
|   | |||||||
| @@ -1320,7 +1320,7 @@ AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | |||||||
|   AC_REQUIRE([AC_HEADER_TIME])dnl |   AC_REQUIRE([AC_HEADER_TIME])dnl | ||||||
|   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK])dnl |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK])dnl | ||||||
|   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK2])dnl |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK2])dnl | ||||||
|   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h) |   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h sys/socket.h) | ||||||
|   AC_CACHE_CHECK([for struct timeval], [ac_cv_struct_timeval], [ |   AC_CACHE_CHECK([for struct timeval], [ac_cv_struct_timeval], [ | ||||||
|     AC_COMPILE_IFELSE([ |     AC_COMPILE_IFELSE([ | ||||||
|       AC_LANG_PROGRAM([[ |       AC_LANG_PROGRAM([[ | ||||||
| @@ -1350,6 +1350,9 @@ AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | |||||||
| #ifdef HAVE_TIME_H | #ifdef HAVE_TIME_H | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_SOCKET_H | ||||||
|  | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
|       ]],[[ |       ]],[[ | ||||||
|         struct timeval ts; |         struct timeval ts; | ||||||
| @@ -1667,6 +1670,52 @@ AC_DEFUN([CURL_CHECK_LIBS_CLOCK_GETTIME_MONOTONIC], [ | |||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_LIBS_CONNECT | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if network connect function is already available | ||||||
|  | dnl using current libraries or if another one is required. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_LIBS_CONNECT], [ | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_WINSOCK2])dnl | ||||||
|  |   AC_MSG_CHECKING([for connect in libraries]) | ||||||
|  |   tst_connect_save_LIBS="$LIBS" | ||||||
|  |   tst_connect_need_LIBS="unknown" | ||||||
|  |   for tst_lib in '' '-lsocket' ; do | ||||||
|  |     if test "$tst_connect_need_LIBS" = "unknown"; then | ||||||
|  |       LIBS="$tst_lib $tst_connect_save_LIBS" | ||||||
|  |       AC_LINK_IFELSE([ | ||||||
|  |         AC_LANG_PROGRAM([[ | ||||||
|  |           $cares_includes_winsock2 | ||||||
|  |           #ifndef HAVE_WINDOWS_H | ||||||
|  |             int connect(int, void*, int); | ||||||
|  |           #endif | ||||||
|  |         ]],[[ | ||||||
|  |           if(0 != connect(0, 0, 0)) | ||||||
|  |             return 1; | ||||||
|  |         ]]) | ||||||
|  |       ],[ | ||||||
|  |         tst_connect_need_LIBS="$tst_lib" | ||||||
|  |       ]) | ||||||
|  |     fi | ||||||
|  |   done | ||||||
|  |   LIBS="$tst_connect_save_LIBS" | ||||||
|  |   # | ||||||
|  |   case X-"$tst_connect_need_LIBS" in | ||||||
|  |     X-unknown) | ||||||
|  |       AC_MSG_RESULT([cannot find connect]) | ||||||
|  |       AC_MSG_ERROR([cannot find connect function in libraries.]) | ||||||
|  |       ;; | ||||||
|  |     X-) | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       ;; | ||||||
|  |     *) | ||||||
|  |       AC_MSG_RESULT([$tst_connect_need_LIBS]) | ||||||
|  |       LIBS="$tst_connect_need_LIBS $tst_connect_save_LIBS" | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_DEFINE_UNQUOTED (VARIABLE, [VALUE]) | dnl CARES_DEFINE_UNQUOTED (VARIABLE, [VALUE]) | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Like AC_DEFINE_UNQUOTED this macro will define a C preprocessor | dnl Like AC_DEFINE_UNQUOTED this macro will define a C preprocessor | ||||||
|   | |||||||
| @@ -10,8 +10,8 @@ | |||||||
|  *   CNAME = zz<CC>.countries.nerd.dk with address 127.0.x.y (ver 1) or |  *   CNAME = zz<CC>.countries.nerd.dk with address 127.0.x.y (ver 1) or | ||||||
|  *   CNAME = <a.b.c.d>.zz.countries.nerd.dk with address 127.0.x.y (ver 2) |  *   CNAME = <a.b.c.d>.zz.countries.nerd.dk with address 127.0.x.y (ver 2) | ||||||
|  * |  * | ||||||
|  * The 2 letter country code in <CC> and the ISO-3166 country |  * The 2 letter country code is in <CC> and the ISO-3166 country | ||||||
|  * number in x.y (number = x*256 + y). Version 2 of the protocol is missing |  * number is in x.y (number = x*256 + y). Version 2 of the protocol is missing | ||||||
|  * the <CC> number. |  * the <CC> number. | ||||||
|  * |  * | ||||||
|  * Ref: http://countries.nerd.dk/more.html |  * Ref: http://countries.nerd.dk/more.html | ||||||
| @@ -612,9 +612,14 @@ static void find_country_from_cname(const char *cname, struct in_addr addr) | |||||||
|     printf("Name for country-number %d not found.\n", cnumber); |     printf("Name for country-number %d not found.\n", cnumber); | ||||||
|   else |   else | ||||||
|     { |     { | ||||||
|       if (ver_1 && *(unsigned short*)&country->short_name != *(unsigned*)&ccode_A2) |       if (ver_1) | ||||||
|         printf("short-name mismatch; %s vs %s\n", country->short_name, ccode_A2); |         { | ||||||
|  |           if ((country->short_name[0] != ccode_A2[0]) || | ||||||
|  |               (country->short_name[1] != ccode_A2[1]) || | ||||||
|  |               (country->short_name[2] != ccode_A2[2])) | ||||||
|  |             printf("short-name mismatch; %s vs %s\n", | ||||||
|  |                    country->short_name, ccode_A2); | ||||||
|  |         } | ||||||
|       printf("%s (%s), number %d.\n", |       printf("%s (%s), number %d.\n", | ||||||
|              country->long_name, country->short_name, cnumber); |              country->long_name, country->short_name, cnumber); | ||||||
|     } |     } | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								ares/adig.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								ares/adig.c
									
									
									
									
									
								
							| @@ -84,6 +84,11 @@ | |||||||
| #define T_SRV 33 /* server selection */ | #define T_SRV 33 /* server selection */ | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* AIX portability check */ | ||||||
|  | #ifndef T_NAPTR | ||||||
|  | #define T_NAPTR 35 /* naming authority pointer */ | ||||||
|  | #endif | ||||||
|  |  | ||||||
| struct nv { | struct nv { | ||||||
|   const char *name; |   const char *name; | ||||||
|   int value; |   int value; | ||||||
| @@ -214,9 +219,10 @@ int main(int argc, char **argv) | |||||||
|               if (strcmp(flags[i].name, optarg) == 0) |               if (strcmp(flags[i].name, optarg) == 0) | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|           if (i == nflags) |           if (i < nflags) | ||||||
|  |             options.flags |= flags[i].value; | ||||||
|  |           else | ||||||
|             usage(); |             usage(); | ||||||
|           options.flags |= flags[i].value; |  | ||||||
|           break; |           break; | ||||||
|  |  | ||||||
|         case 's': |         case 's': | ||||||
| @@ -251,9 +257,10 @@ int main(int argc, char **argv) | |||||||
|               if (strcasecmp(classes[i].name, optarg) == 0) |               if (strcasecmp(classes[i].name, optarg) == 0) | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|           if (i == nclasses) |           if (i < nclasses) | ||||||
|  |             dnsclass = classes[i].value; | ||||||
|  |           else | ||||||
|             usage(); |             usage(); | ||||||
|           dnsclass = classes[i].value; |  | ||||||
|           break; |           break; | ||||||
|  |  | ||||||
|         case 't': |         case 't': | ||||||
| @@ -263,9 +270,10 @@ int main(int argc, char **argv) | |||||||
|               if (strcasecmp(types[i].name, optarg) == 0) |               if (strcasecmp(types[i].name, optarg) == 0) | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|           if (i == ntypes) |           if (i < ntypes) | ||||||
|  |             type = types[i].value; | ||||||
|  |           else | ||||||
|             usage(); |             usage(); | ||||||
|           type = types[i].value; |  | ||||||
|           break; |           break; | ||||||
|  |  | ||||||
|         case 'T': |         case 'T': | ||||||
|   | |||||||
| @@ -86,6 +86,7 @@ extern "C" { | |||||||
| #define ARES_ENOMEM             15 | #define ARES_ENOMEM             15 | ||||||
| #define ARES_EDESTRUCTION       16 | #define ARES_EDESTRUCTION       16 | ||||||
| #define ARES_EBADSTR            17 | #define ARES_EBADSTR            17 | ||||||
|  | #define ARES_ECANCELLED         21 | ||||||
|  |  | ||||||
| /* ares_getnameinfo error codes */ | /* ares_getnameinfo error codes */ | ||||||
| #define ARES_EBADFLAGS          18 | #define ARES_EBADFLAGS          18 | ||||||
| @@ -94,10 +95,12 @@ extern "C" { | |||||||
| #define ARES_ENONAME            19 | #define ARES_ENONAME            19 | ||||||
| #define ARES_EBADHINTS          20 | #define ARES_EBADHINTS          20 | ||||||
|  |  | ||||||
|  | /* Uninitialized library error code */ | ||||||
|  | #define ARES_ENOTINITIALIZED    21 | ||||||
|  |  | ||||||
| /* ares_library_init error codes */ | /* ares_library_init error codes */ | ||||||
| #define ARES_ELOADIPHLPAPI           21 | #define ARES_ELOADIPHLPAPI           22 | ||||||
| #define ARES_ELOADADVAPI32           22 | #define ARES_EADDRGETNETWORKPARAMS   23 | ||||||
| #define ARES_EADDRGetNetworkParams   23 |  | ||||||
|  |  | ||||||
| /* Flag values */ | /* Flag values */ | ||||||
| #define ARES_FLAG_USEVC         (1 << 0) | #define ARES_FLAG_USEVC         (1 << 0) | ||||||
|   | |||||||
| @@ -54,14 +54,14 @@ void ares__close_sockets(ares_channel channel, struct server_state *server) | |||||||
|   if (server->tcp_socket != ARES_SOCKET_BAD) |   if (server->tcp_socket != ARES_SOCKET_BAD) | ||||||
|     { |     { | ||||||
|       SOCK_STATE_CALLBACK(channel, server->tcp_socket, 0, 0); |       SOCK_STATE_CALLBACK(channel, server->tcp_socket, 0, 0); | ||||||
|       closesocket(server->tcp_socket); |       sclose(server->tcp_socket); | ||||||
|       server->tcp_socket = ARES_SOCKET_BAD; |       server->tcp_socket = ARES_SOCKET_BAD; | ||||||
|       server->tcp_connection_generation = ++channel->tcp_connection_generation; |       server->tcp_connection_generation = ++channel->tcp_connection_generation; | ||||||
|     } |     } | ||||||
|   if (server->udp_socket != ARES_SOCKET_BAD) |   if (server->udp_socket != ARES_SOCKET_BAD) | ||||||
|     { |     { | ||||||
|       SOCK_STATE_CALLBACK(channel, server->udp_socket, 0, 0); |       SOCK_STATE_CALLBACK(channel, server->udp_socket, 0, 0); | ||||||
|       closesocket(server->udp_socket); |       sclose(server->udp_socket); | ||||||
|       server->udp_socket = ARES_SOCKET_BAD; |       server->udp_socket = ARES_SOCKET_BAD; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ ares_cancel \- Cancel a resolve | |||||||
| The \fBares_cancel\fP function cancels all lookups/requests made on the the | The \fBares_cancel\fP function cancels all lookups/requests made on the the | ||||||
| name service channel identified by \fIchannel\fP.  \fBares_cancel\fP invokes | name service channel identified by \fIchannel\fP.  \fBares_cancel\fP invokes | ||||||
| the callbacks for each pending query on the channel, passing a status of | the callbacks for each pending query on the channel, passing a status of | ||||||
| .BR ARES_ETIMEOUT . | .BR ARES_ECANCELLED . | ||||||
| These calls give the callbacks a chance to clean up any state which | These calls give the callbacks a chance to clean up any state which | ||||||
| might have been stored in their arguments. | might have been stored in their arguments. | ||||||
| .SH SEE ALSO | .SH SEE ALSO | ||||||
| @@ -35,5 +35,10 @@ might have been stored in their arguments. | |||||||
| .BR ares_destroy (3) | .BR ares_destroy (3) | ||||||
| .SH NOTES | .SH NOTES | ||||||
| This function was added in c-ares 1.2.0 | This function was added in c-ares 1.2.0 | ||||||
|  |  | ||||||
|  | c-ares 1.6.0 and earlier pass a status of | ||||||
|  | .BR ARES_ETIMEOUT | ||||||
|  | instead of | ||||||
|  | .BR ARES_ECANCELLED . | ||||||
| .SH AUTHOR | .SH AUTHOR | ||||||
| Dirk Manske | Dirk Manske | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ void ares_cancel(ares_channel channel) | |||||||
|   { |   { | ||||||
|     query = list_node->data; |     query = list_node->data; | ||||||
|     list_node = list_node->next;  /* since we're deleting the query */ |     list_node = list_node->next;  /* since we're deleting the query */ | ||||||
|     query->callback(query->arg, ARES_ETIMEOUT, 0, NULL, 0); |     query->callback(query->arg, ARES_ECANCELLED, 0, NULL, 0); | ||||||
|     ares__free_query(query); |     ares__free_query(query); | ||||||
|   } |   } | ||||||
| #ifndef NDEBUG | #ifndef NDEBUG | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .\" Copyright (C) 2007-2008 by Daniel Stenberg | .\" Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
| .\" | .\" | ||||||
| .\" Permission to use, copy, modify, and distribute this | .\" Permission to use, copy, modify, and distribute this | ||||||
| .\" software and its documentation for any purpose and without | .\" software and its documentation for any purpose and without | ||||||
| @@ -14,7 +14,7 @@ | |||||||
| .\" this software for any purpose.  It is provided "as is" | .\" this software for any purpose.  It is provided "as is" | ||||||
| .\" without express or implied warranty. | .\" without express or implied warranty. | ||||||
| .\" | .\" | ||||||
| .TH ARES_DUP 3 "2 Dec 2008" | .TH ARES_DUP 3 "26 May 2009" | ||||||
| .SH NAME | .SH NAME | ||||||
| ares_dup \- Duplicate a resolver channel | ares_dup \- Duplicate a resolver channel | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -35,7 +35,8 @@ with additional options set exactly as the \fIsource\fP channel has them | |||||||
| configured. | configured. | ||||||
| .SH SEE ALSO | .SH SEE ALSO | ||||||
| .BR ares_destroy(3), | .BR ares_destroy(3), | ||||||
| .BR ares_init(3) | .BR ares_init(3), | ||||||
|  | .BR ares_library_init(3) | ||||||
| .SH AVAILABILITY | .SH AVAILABILITY | ||||||
| ares_dup(3) was added in c-ares 1.6.0 | ares_dup(3) was added in c-ares 1.6.0 | ||||||
| .SH AUTHOR | .SH AUTHOR | ||||||
|   | |||||||
| @@ -1,150 +1,150 @@ | |||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .\" Copyright 2005 by Dominick Meglio. | .\" Copyright 2005 by Dominick Meglio. | ||||||
| .\" | .\" | ||||||
| .\" Permission to use, copy, modify, and distribute this | .\" Permission to use, copy, modify, and distribute this | ||||||
| .\" software and its documentation for any purpose and without | .\" software and its documentation for any purpose and without | ||||||
| .\" fee is hereby granted, provided that the above copyright | .\" fee is hereby granted, provided that the above copyright | ||||||
| .\" notice appear in all copies and that both that copyright | .\" notice appear in all copies and that both that copyright | ||||||
| .\" notice and this permission notice appear in supporting | .\" notice and this permission notice appear in supporting | ||||||
| .\" documentation, and that the name of M.I.T. not be used in | .\" documentation, and that the name of M.I.T. not be used in | ||||||
| .\" advertising or publicity pertaining to distribution of the | .\" advertising or publicity pertaining to distribution of the | ||||||
| .\" software without specific, written prior permission. | .\" software without specific, written prior permission. | ||||||
| .\" M.I.T. makes no representations about the suitability of | .\" M.I.T. makes no representations about the suitability of | ||||||
| .\" this software for any purpose.  It is provided "as is" | .\" this software for any purpose.  It is provided "as is" | ||||||
| .\" without express or implied warranty. | .\" without express or implied warranty. | ||||||
| .\" | .\" | ||||||
| .TH ARES_GETNAMEINFO 3 "1 May 2009" | .TH ARES_GETNAMEINFO 3 "1 May 2009" | ||||||
| .SH NAME | .SH NAME | ||||||
| ares_getnameinfo \- Address-to-nodename translation in protocol-independent manner | ares_getnameinfo \- Address-to-nodename translation in protocol-independent manner | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .nf | .nf | ||||||
| .B #include <ares.h> | .B #include <ares.h> | ||||||
| .PP | .PP | ||||||
| .B typedef void (*ares_nameinfo_callback)(void *\fIarg\fP, int \fIstatus\fP, | .B typedef void (*ares_nameinfo_callback)(void *\fIarg\fP, int \fIstatus\fP, | ||||||
| .B	int \fItimeouts\fP, char *\fInode\fP, char *\fIservice\fP) | .B	int \fItimeouts\fP, char *\fInode\fP, char *\fIservice\fP) | ||||||
| .PP | .PP | ||||||
| .B void ares_getnameinfo(ares_channel \fIchannel\fP, const struct sockaddr *\fIsa\fP, | .B void ares_getnameinfo(ares_channel \fIchannel\fP, const struct sockaddr *\fIsa\fP, | ||||||
| .B 	ares_socklen_t \fIsalen\fP, int \fIflags\fP, ares_nameinfo_callback \fIcallback\fP, | .B 	ares_socklen_t \fIsalen\fP, int \fIflags\fP, ares_nameinfo_callback \fIcallback\fP, | ||||||
| .B 	void *\fIarg\fP) | .B 	void *\fIarg\fP) | ||||||
| .fi | .fi | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The | The | ||||||
| .B ares_getnameinfo | .B ares_getnameinfo | ||||||
| function is defined for protocol-independent address translation. The function | function is defined for protocol-independent address translation. The function | ||||||
| is a combination of \fIares_gethostbyaddr(3)\fP and \fIgetservbyport(3)\fP. The function will | is a combination of \fIares_gethostbyaddr(3)\fP and \fIgetservbyport(3)\fP. The function will | ||||||
| translate the address either by executing a host query on the name service channel | translate the address either by executing a host query on the name service channel | ||||||
| identified by | identified by | ||||||
| .IR channel  | .IR channel  | ||||||
| or it will attempt to resolve it locally if possible. | or it will attempt to resolve it locally if possible. | ||||||
| The parameters | The parameters | ||||||
| .I sa | .I sa | ||||||
| and | and | ||||||
| .I len | .I len | ||||||
| give the address as a sockaddr structure, and | give the address as a sockaddr structure, and | ||||||
| .I flags | .I flags | ||||||
| gives the options that the function will use.  Valid flags are listed below: | gives the options that the function will use.  Valid flags are listed below: | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_NOFQDN | .B ARES_NI_NOFQDN | ||||||
| Only the nodename portion of the FQDN is returned for local hosts. | Only the nodename portion of the FQDN is returned for local hosts. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_NUMERICHOST | .B ARES_NI_NUMERICHOST | ||||||
| The numeric form of the hostname is returned rather than the name. | The numeric form of the hostname is returned rather than the name. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_NAMEREQD | .B ARES_NI_NAMEREQD | ||||||
| An error is returned if the hostname cannot be found in the DNS. | An error is returned if the hostname cannot be found in the DNS. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_NUMERICSERV | .B ARES_NI_NUMERICSERV | ||||||
| The numeric form of the service is returned rather than the name. | The numeric form of the service is returned rather than the name. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_TCP | .B ARES_NI_TCP | ||||||
| The service name is to be looked up for the TCP protocol. | The service name is to be looked up for the TCP protocol. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_UDP | .B ARES_NI_UDP | ||||||
| The service name is to be looked up for the UDP protocol. | The service name is to be looked up for the UDP protocol. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_SCTP | .B ARES_NI_SCTP | ||||||
| The service name is to be looked up for the SCTP protocol. | The service name is to be looked up for the SCTP protocol. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_DCCP | .B ARES_NI_DCCP | ||||||
| The service name is to be looked up for the DCCP protocol. | The service name is to be looked up for the DCCP protocol. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_NUMERICSCOPE | .B ARES_NI_NUMERICSCOPE | ||||||
| The numeric form of the scope ID is returned rather than the name. | The numeric form of the scope ID is returned rather than the name. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_LOOKUPHOST | .B ARES_NI_LOOKUPHOST | ||||||
| A hostname lookup is being requested. | A hostname lookup is being requested. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_NI_LOOKUPSERVICE | .B ARES_NI_LOOKUPSERVICE | ||||||
| A service name lookup is being requested. | A service name lookup is being requested. | ||||||
| .PP | .PP | ||||||
| When the query | When the query | ||||||
| is complete or has  | is complete or has  | ||||||
| failed, the ares library will invoke \fIcallback\fP.  Completion or failure of  | failed, the ares library will invoke \fIcallback\fP.  Completion or failure of  | ||||||
| the query may happen immediately, or may happen during a later call to | the query may happen immediately, or may happen during a later call to | ||||||
| \fIares_process(3)\fP, \fIares_destroy(3)\fP or \fIares_cancel(3)\fP. | \fIares_process(3)\fP, \fIares_destroy(3)\fP or \fIares_cancel(3)\fP. | ||||||
| .PP | .PP | ||||||
| The callback argument | The callback argument | ||||||
| .I arg | .I arg | ||||||
| is copied from the | is copied from the | ||||||
| .B ares_getnameinfo | .B ares_getnameinfo | ||||||
| argument | argument | ||||||
| .IR arg . | .IR arg . | ||||||
| The callback argument | The callback argument | ||||||
| .I status | .I status | ||||||
| indicates whether the query succeeded and, if not, how it failed.  It | indicates whether the query succeeded and, if not, how it failed.  It | ||||||
| may have any of the following values: | may have any of the following values: | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_SUCCESS | .B ARES_SUCCESS | ||||||
| The host lookup completed successfully. | The host lookup completed successfully. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_ENOTIMP | .B ARES_ENOTIMP | ||||||
| The ares library does not know how to look up addresses of type | The ares library does not know how to look up addresses of type | ||||||
| .IR family . | .IR family . | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_ENOTFOUND | .B ARES_ENOTFOUND | ||||||
| The address | The address | ||||||
| .I addr | .I addr | ||||||
| was not found. | was not found. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_ENOMEM | .B ARES_ENOMEM | ||||||
| Memory was exhausted. | Memory was exhausted. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_EDESTRUCTION | .B ARES_EDESTRUCTION | ||||||
| The name service channel | The name service channel | ||||||
| .I channel | .I channel | ||||||
| is being destroyed; the query will not be completed. | is being destroyed; the query will not be completed. | ||||||
| .TP 19 | .TP 19 | ||||||
| .B ARES_EBADFLAGS | .B ARES_EBADFLAGS | ||||||
| The | The | ||||||
| .I flags | .I flags | ||||||
| parameter contains an illegal value. | parameter contains an illegal value. | ||||||
| .PP | .PP | ||||||
| The callback argument | The callback argument | ||||||
| .I timeouts | .I timeouts | ||||||
| reports how many times a query timed out during the execution of the | reports how many times a query timed out during the execution of the | ||||||
| given request. | given request. | ||||||
| .PP | .PP | ||||||
| On successful completion of the query, the callback argument | On successful completion of the query, the callback argument | ||||||
| .I node | .I node | ||||||
| contains a string representing the hostname (assuming  | contains a string representing the hostname (assuming  | ||||||
| .B ARES_NI_LOOKUPHOST | .B ARES_NI_LOOKUPHOST | ||||||
| was specified). Additionally,  | was specified). Additionally,  | ||||||
| .I service | .I service | ||||||
| contains a string representing the service name (assuming | contains a string representing the service name (assuming | ||||||
| .B ARES_NI_LOOKUPSERVICE | .B ARES_NI_LOOKUPSERVICE | ||||||
| was specified). | was specified). | ||||||
| If the query did not complete successfully, or one of the values | If the query did not complete successfully, or one of the values | ||||||
| was not requested,  | was not requested,  | ||||||
| .I node | .I node | ||||||
| or | or | ||||||
| .I service | .I service | ||||||
| will be  | will be  | ||||||
| .BR NULL . | .BR NULL . | ||||||
| .SH SEE ALSO | .SH SEE ALSO | ||||||
| .BR ares_process (3), | .BR ares_process (3), | ||||||
| .BR ares_getaddrinfo (3) | .BR ares_getaddrinfo (3) | ||||||
| .SH AUTHOR | .SH AUTHOR | ||||||
| Dominick Meglio | Dominick Meglio | ||||||
| .br | .br | ||||||
| Copyright 2005 by Dominick Meglio. | Copyright 2005 by Dominick Meglio. | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .\" Copyright 1998 by the Massachusetts Institute of Technology. | .\" Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
| .\" Copyright (C) 2007-2008 by Daniel Stenberg | .\" Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
| .\" | .\" | ||||||
| .\" Permission to use, copy, modify, and distribute this | .\" Permission to use, copy, modify, and distribute this | ||||||
| .\" software and its documentation for any purpose and without | .\" software and its documentation for any purpose and without | ||||||
| @@ -15,7 +15,7 @@ | |||||||
| .\" this software for any purpose.  It is provided "as is" | .\" this software for any purpose.  It is provided "as is" | ||||||
| .\" without express or implied warranty. | .\" without express or implied warranty. | ||||||
| .\" | .\" | ||||||
| .TH ARES_INIT 3 "13 May 2008" | .TH ARES_INIT 3 "26 May 2009" | ||||||
| .SH NAME | .SH NAME | ||||||
| ares_init, ares_init_options \- Initialize a resolver channel | ares_init, ares_init_options \- Initialize a resolver channel | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -184,10 +184,16 @@ A configuration file could not be read. | |||||||
| .TP 14 | .TP 14 | ||||||
| .B ARES_ENOMEM | .B ARES_ENOMEM | ||||||
| The process's available memory was exhausted. | The process's available memory was exhausted. | ||||||
|  | .TP 14 | ||||||
|  | .B ARES_ENOTINITIALIZED | ||||||
|  | c-ares library initialization not yet performed. | ||||||
| .SH SEE ALSO | .SH SEE ALSO | ||||||
| .BR ares_destroy(3), | .BR ares_destroy(3), | ||||||
| .BR ares_dup(3) | .BR ares_dup(3), | ||||||
|  | .BR ares_library_init(3) | ||||||
| .SH AUTHOR | .SH AUTHOR | ||||||
| Greg Hudson, MIT Information Systems | Greg Hudson, MIT Information Systems | ||||||
| .br | .br | ||||||
| Copyright 1998 by the Massachusetts Institute of Technology. | Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  | .br | ||||||
|  | Copyright (C) 2004-2009 by Daniel Stenberg. | ||||||
|   | |||||||
| @@ -129,6 +129,9 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | |||||||
|     curl_memlimit(atoi(env)); |     curl_memlimit(atoi(env)); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |   if (ares_library_initialized() != ARES_SUCCESS) | ||||||
|  |     return ARES_ENOTINITIALIZED; | ||||||
|  |  | ||||||
|   channel = malloc(sizeof(struct ares_channeldata)); |   channel = malloc(sizeof(struct ares_channeldata)); | ||||||
|   if (!channel) { |   if (!channel) { | ||||||
|     *channelptr = NULL; |     *channelptr = NULL; | ||||||
| @@ -198,12 +201,15 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | |||||||
|       DEBUGF(fprintf(stderr, "Error: init_by_resolv_conf failed: %s\n", |       DEBUGF(fprintf(stderr, "Error: init_by_resolv_conf failed: %s\n", | ||||||
|                      ares_strerror(status))); |                      ares_strerror(status))); | ||||||
|   } |   } | ||||||
|   if (status == ARES_SUCCESS) { |  | ||||||
|     status = init_by_defaults(channel); |   /* | ||||||
|     if (status != ARES_SUCCESS) |    * No matter what failed or succeeded, seed defaults to provide | ||||||
|       DEBUGF(fprintf(stderr, "Error: init_by_defaults failed: %s\n", |    * useful behavior for things that we missed. | ||||||
|                      ares_strerror(status))); |    */ | ||||||
|   } |   status = init_by_defaults(channel); | ||||||
|  |   if (status != ARES_SUCCESS) | ||||||
|  |     DEBUGF(fprintf(stderr, "Error: init_by_defaults failed: %s\n", | ||||||
|  |                    ares_strerror(status))); | ||||||
|  |  | ||||||
|   /* Generate random key */ |   /* Generate random key */ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										74
									
								
								ares/ares_library_cleanup.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								ares/ares_library_cleanup.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,74 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .\" Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  | .\" Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
|  | .\" | ||||||
|  | .\" Permission to use, copy, modify, and distribute this | ||||||
|  | .\" software and its documentation for any purpose and without | ||||||
|  | .\" fee is hereby granted, provided that the above copyright | ||||||
|  | .\" notice appear in all copies and that both that copyright | ||||||
|  | .\" notice and this permission notice appear in supporting | ||||||
|  | .\" documentation, and that the name of M.I.T. not be used in | ||||||
|  | .\" advertising or publicity pertaining to distribution of the | ||||||
|  | .\" software without specific, written prior permission. | ||||||
|  | .\" M.I.T. makes no representations about the suitability of | ||||||
|  | .\" this software for any purpose.  It is provided "as is" | ||||||
|  | .\" without express or implied warranty. | ||||||
|  | .\" | ||||||
|  | .TH ARES_LIBRARY_CLEANUP 3 "19 May 2009" | ||||||
|  | .SH NAME | ||||||
|  | ares_library_cleanup \- c-ares library deinitialization | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .nf | ||||||
|  | .B #include <ares.h> | ||||||
|  | .PP | ||||||
|  | .B void ares_library_cleanup(void) | ||||||
|  | .PP | ||||||
|  | .B cc file.c -lcares | ||||||
|  | .fi | ||||||
|  | .SH DESCRIPTION | ||||||
|  | .PP | ||||||
|  | The | ||||||
|  | .B ares_library_cleanup | ||||||
|  | function uninitializes the c-ares library, freeing all resources | ||||||
|  | previously aquired by \fIares_library_init(3)\fP when the library | ||||||
|  | was initialized. | ||||||
|  | .PP | ||||||
|  | This function must be called when the program using c-ares will | ||||||
|  | no longer need any c-ares function. Once the program has called | ||||||
|  | \fIares_library_cleanup(3)\fP it shall not make any further call to any | ||||||
|  | c-ares function. | ||||||
|  | .PP | ||||||
|  | This function does not cancel any pending c-ares lookups or requests | ||||||
|  | previously done. Program  must use \fIares_cancel(3)\fP for this purpose. | ||||||
|  | .PP | ||||||
|  | .B This function is not thread safe. | ||||||
|  | You have to call it once the program is about to terminate, but this call must | ||||||
|  | be done once the program has terminated every single thread that it could have | ||||||
|  | initiated. This is required to avoid potential race conditions in library | ||||||
|  | deinitialization, and also due to the fact that \fIares_library_cleanup(3)\fP | ||||||
|  | might call functions from other libraries that are thread unsafe, and could | ||||||
|  | conflict with any other thread that is already using these other libraries. | ||||||
|  | .PP | ||||||
|  | Win32/64 application DLLs shall not call \fIares_library_cleanup(3)\fP from | ||||||
|  | the DllMain function. Doing so will produce deadlocks and other problems. | ||||||
|  | .SH AVAILABILITY | ||||||
|  | This function was first introduced in c-ares version 1.6.1 along with the | ||||||
|  | definition of preprocessor symbol \fICARES_HAVE_ARES_LIBRARY_CLEANUP\fP as an | ||||||
|  | indication of the availability of this function. | ||||||
|  | .PP | ||||||
|  | Since the introduction of this function, it is absolutely mandatory to call it | ||||||
|  | for any Win32/64 program using c-ares. | ||||||
|  | .PP | ||||||
|  | Non-Win32/64 systems can still use c-ares version 1.6.1 without calling | ||||||
|  | \fIares_library_cleanup(3)\fP due to the fact that it is nearly a do-nothing | ||||||
|  | function on non-Win32/64 platforms. | ||||||
|  | .SH SEE ALSO | ||||||
|  | .BR ares_library_init(3), | ||||||
|  | .BR ares_cancel(3) | ||||||
|  | .SH AUTHOR | ||||||
|  | Yang Tse | ||||||
|  | .PP | ||||||
|  | Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  | .br | ||||||
|  | Copyright (C) 2004-2009 by Daniel Stenberg. | ||||||
							
								
								
									
										97
									
								
								ares/ares_library_init.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								ares/ares_library_init.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .\" Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  | .\" Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
|  | .\" | ||||||
|  | .\" Permission to use, copy, modify, and distribute this | ||||||
|  | .\" software and its documentation for any purpose and without | ||||||
|  | .\" fee is hereby granted, provided that the above copyright | ||||||
|  | .\" notice appear in all copies and that both that copyright | ||||||
|  | .\" notice and this permission notice appear in supporting | ||||||
|  | .\" documentation, and that the name of M.I.T. not be used in | ||||||
|  | .\" advertising or publicity pertaining to distribution of the | ||||||
|  | .\" software without specific, written prior permission. | ||||||
|  | .\" M.I.T. makes no representations about the suitability of | ||||||
|  | .\" this software for any purpose.  It is provided "as is" | ||||||
|  | .\" without express or implied warranty. | ||||||
|  | .\" | ||||||
|  | .TH ARES_LIBRARY_INIT 3 "19 May 2009" | ||||||
|  | .SH NAME | ||||||
|  | ares_library_init \- c-ares library initialization | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .nf | ||||||
|  | .B #include <ares.h> | ||||||
|  | .PP | ||||||
|  | .B int ares_library_init(int \fIflags\fP) | ||||||
|  | .PP | ||||||
|  | .B cc file.c -lcares | ||||||
|  | .fi | ||||||
|  | .SH DESCRIPTION | ||||||
|  | .PP | ||||||
|  | The | ||||||
|  | .B ares_library_init | ||||||
|  | function performs initializations internally required by the c-ares | ||||||
|  | library that must take place before any other function provided by | ||||||
|  | c-ares can be used in a program. | ||||||
|  | .PP | ||||||
|  | This function must be called one time within the life of a program, | ||||||
|  | before the program actually executes any other c-ares library function. | ||||||
|  | Initializations done by this function remain effective until a | ||||||
|  | call to \fIares_library_cleanup(3)\fP is performed. | ||||||
|  | .PP | ||||||
|  | Successive calls to this function do nothing, only the first call done | ||||||
|  | when c-ares is in an uninitialized state is actually effective. | ||||||
|  | .PP | ||||||
|  | The | ||||||
|  | .I flags | ||||||
|  | parameter is a bit pattern that tells c-ares exactly which features | ||||||
|  | should be initialized, as described below. Set the desired bits by | ||||||
|  | ORing the values together. In normal operation you should specify | ||||||
|  | \fIARES_LIB_INIT_ALL\fP. Don't use any other value unless you are | ||||||
|  | familiar with it and trying to control some internal c-ares feature. | ||||||
|  | .PP | ||||||
|  | .B This function is not thread safe. | ||||||
|  | You have to call it once the program has started, but this call must be done | ||||||
|  | before the program starts any other thread. This is required to avoid | ||||||
|  | potential race conditions in library initialization, and also due to the fact | ||||||
|  | that \fIares_library_init(3)\fP might call functions from other libraries that | ||||||
|  | are thread unsafe, and could conflict with any other thread that is already | ||||||
|  | using these other libraries. | ||||||
|  | .PP | ||||||
|  | Win32/64 application DLLs shall not call \fIares_library_init(3)\fP from the | ||||||
|  | DllMain function. Doing so will produce deadlocks and other problems. | ||||||
|  | .SH FLAGS | ||||||
|  | .TP 5 | ||||||
|  | .B ARES_LIB_INIT_ALL | ||||||
|  | Initialize everything possible. This sets all known bits. | ||||||
|  | .TP | ||||||
|  | .B ARES_LIB_INIT_WIN32 | ||||||
|  | Initialize Win32/64 specific libraries. | ||||||
|  | .TP | ||||||
|  | .B ARES_LIB_INIT_NONE | ||||||
|  | Initialize nothing extra. This sets no bit. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | Upon successful completion, ares_library_init() will return 0.  Otherwise, a | ||||||
|  | non-zero error number will be returned to indicate the error. Except for | ||||||
|  | \fIares_strerror(3)\fP, you shall not call any other c-ares function upon | ||||||
|  | \fIares_library_init(3)\fP failure. | ||||||
|  | .SH AVAILABILITY | ||||||
|  | This function was first introduced in c-ares version 1.6.1 along with the | ||||||
|  | definition of preprocessor symbol \fICARES_HAVE_ARES_LIBRARY_INIT\fP as an | ||||||
|  | indication of the availability of this function. | ||||||
|  | .PP | ||||||
|  | Since the introduction of this function it is absolutely mandatory to | ||||||
|  | call it for any Win32/64 program using c-ares. | ||||||
|  | .PP | ||||||
|  | Non-Win32/64 systems can still use c-ares version 1.6.1 without calling | ||||||
|  | \fIares_library_init(3)\fP due to the fact that it is nearly a do-nothing | ||||||
|  | function on non-Win32/64 platforms at this point. | ||||||
|  | .SH SEE ALSO | ||||||
|  | .BR ares_library_cleanup(3), | ||||||
|  | .BR ares_strerror(3) | ||||||
|  | .SH AUTHOR | ||||||
|  | Yang Tse | ||||||
|  | .PP | ||||||
|  | Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  | .br | ||||||
|  | Copyright (C) 2004-2009 by Daniel Stenberg. | ||||||
| @@ -1,5 +1,21 @@ | |||||||
| /* $Id$ */ | /* $Id$ */ | ||||||
|  |  | ||||||
|  | /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  |  * Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
|  |  * | ||||||
|  |  * Permission to use, copy, modify, and distribute this | ||||||
|  |  * software and its documentation for any purpose and without | ||||||
|  |  * fee is hereby granted, provided that the above copyright | ||||||
|  |  * notice appear in all copies and that both that copyright | ||||||
|  |  * notice and this permission notice appear in supporting | ||||||
|  |  * documentation, and that the name of M.I.T. not be used in | ||||||
|  |  * advertising or publicity pertaining to distribution of the | ||||||
|  |  * software without specific, written prior permission. | ||||||
|  |  * M.I.T. makes no representations about the suitability of | ||||||
|  |  * this software for any purpose.  It is provided "as is" | ||||||
|  |  * without express or implied warranty. | ||||||
|  |  */ | ||||||
|  |  | ||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #include "ares.h" | #include "ares.h" | ||||||
| @@ -38,26 +54,23 @@ static int ares_win32_init(void) | |||||||
|   if (!fpGetNetworkParams) |   if (!fpGetNetworkParams) | ||||||
|     { |     { | ||||||
|       FreeLibrary(hnd_iphlpapi); |       FreeLibrary(hnd_iphlpapi); | ||||||
|       return ARES_EADDRGetNetworkParams; |       return ARES_EADDRGETNETWORKPARAMS; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |   /* | ||||||
|  |    * When advapi32.dll is unavailable or advapi32.dll has no SystemFunction036, | ||||||
|  |    * also known as RtlGenRandom, which is the case for Windows versions prior | ||||||
|  |    * to WinXP then c-ares uses portable rand() function. Then don't error here. | ||||||
|  |    */ | ||||||
|  |  | ||||||
|   hnd_advapi32 = 0; |   hnd_advapi32 = 0; | ||||||
|   hnd_advapi32 = LoadLibrary("advapi32.dll"); |   hnd_advapi32 = LoadLibrary("advapi32.dll"); | ||||||
|   if (!hnd_advapi32) |   if (hnd_advapi32) | ||||||
|     { |     { | ||||||
|       FreeLibrary(hnd_iphlpapi); |       fpSystemFunction036 = (fpSystemFunction036_t) | ||||||
|       return ARES_ELOADADVAPI32; |         GetProcAddress(hnd_advapi32, "SystemFunction036"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   fpSystemFunction036 = (fpSystemFunction036_t) |  | ||||||
|     GetProcAddress(hnd_advapi32, "SystemFunction036"); |  | ||||||
|  |  | ||||||
|   /* |  | ||||||
|    * Intentionally avoid checking if the address of SystemFunction036, a.k.a. |  | ||||||
|    * RtlGenRandom, has been located or not. This function is only available on |  | ||||||
|    * WinXP and later. When unavailable c-ares uses portable rand() function. |  | ||||||
|    */ |  | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   return ARES_SUCCESS; |   return ARES_SUCCESS; | ||||||
| } | } | ||||||
| @@ -107,3 +120,14 @@ void ares_library_cleanup(void) | |||||||
|   ares_init_flags = ARES_LIB_INIT_NONE; |   ares_init_flags = ARES_LIB_INIT_NONE; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int ares_library_initialized(void) | ||||||
|  | { | ||||||
|  | #ifdef WIN32 | ||||||
|  |   if (!ares_initialized) | ||||||
|  |     return ARES_ENOTINITIALIZED; | ||||||
|  | #endif | ||||||
|  |   return ARES_SUCCESS; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,6 +3,22 @@ | |||||||
|  |  | ||||||
| /* $Id$ */ | /* $Id$ */ | ||||||
|  |  | ||||||
|  | /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  |  * Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
|  |  * | ||||||
|  |  * Permission to use, copy, modify, and distribute this | ||||||
|  |  * software and its documentation for any purpose and without | ||||||
|  |  * fee is hereby granted, provided that the above copyright | ||||||
|  |  * notice appear in all copies and that both that copyright | ||||||
|  |  * notice and this permission notice appear in supporting | ||||||
|  |  * documentation, and that the name of M.I.T. not be used in | ||||||
|  |  * advertising or publicity pertaining to distribution of the | ||||||
|  |  * software without specific, written prior permission. | ||||||
|  |  * M.I.T. makes no representations about the suitability of | ||||||
|  |  * this software for any purpose.  It is provided "as is" | ||||||
|  |  * without express or implied warranty. | ||||||
|  |  */ | ||||||
|  |  | ||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
| /* $Id$ */ | /* $Id$ */ | ||||||
|  |  | ||||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  * Copyright (C) 2004-2008 by Daniel Stenberg |  * Copyright (C) 2004-2009 by Daniel Stenberg | ||||||
|  * |  * | ||||||
|  * Permission to use, copy, modify, and distribute this |  * Permission to use, copy, modify, and distribute this | ||||||
|  * software and its documentation for any purpose and without |  * software and its documentation for any purpose and without | ||||||
| @@ -32,16 +32,11 @@ | |||||||
|  |  | ||||||
| #if !defined(WIN32) || defined(WATT32) | #if !defined(WIN32) || defined(WATT32) | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| /* We define closesocket() here so that we can use this function all over |  | ||||||
|    the source code for closing sockets. */ |  | ||||||
| #define closesocket(x) close(x) |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef WATT32 | #ifdef WATT32 | ||||||
| #include <tcp.h> | #include <tcp.h> | ||||||
| #include <sys/ioctl.h> | #include <sys/ioctl.h> | ||||||
| #undef  closesocket |  | ||||||
| #define closesocket(s)    close_s(s) |  | ||||||
| #define writev(s,v,c)     writev_s(s,v,c) | #define writev(s,v,c)     writev_s(s,v,c) | ||||||
| #define HAVE_WRITEV 1 | #define HAVE_WRITEV 1 | ||||||
| #endif | #endif | ||||||
| @@ -310,6 +305,8 @@ int ares__timeadd(struct timeval *now, | |||||||
| /* return time offset between now and (future) check, in milliseconds */ | /* return time offset between now and (future) check, in milliseconds */ | ||||||
| long ares__timeoffset(struct timeval *now, | long ares__timeoffset(struct timeval *now, | ||||||
|                       struct timeval *check); |                       struct timeval *check); | ||||||
|  | /* returns ARES_SUCCESS if library has been initialized */ | ||||||
|  | int ares_library_initialized(void); | ||||||
| void ares__rc4(rc4_key* key,unsigned char *buffer_ptr, int buffer_len); | void ares__rc4(rc4_key* key,unsigned char *buffer_ptr, int buffer_len); | ||||||
| void ares__send_query(ares_channel channel, struct query *query, | void ares__send_query(ares_channel channel, struct query *query, | ||||||
|                       struct timeval *now); |                       struct timeval *now); | ||||||
| @@ -338,8 +335,8 @@ long ares__tvdiff(struct timeval t1, struct timeval t2); | |||||||
| #ifdef CURLDEBUG | #ifdef CURLDEBUG | ||||||
| /* This is low-level hard-hacking memory leak tracking and similar. Using the | /* This is low-level hard-hacking memory leak tracking and similar. Using the | ||||||
|    libcurl lowlevel code from within library is ugly and only works when |    libcurl lowlevel code from within library is ugly and only works when | ||||||
|    c-ares is built and linked with a similarly debug-build libcurl, but we do |    c-ares is built and linked with a similarly curldebug-enabled libcurl, | ||||||
|    this anyway for convenience. */ |    but we do this anyway for convenience. */ | ||||||
| #include "../lib/memdebug.h" | #include "../lib/memdebug.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -896,7 +896,7 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | |||||||
|   /* Configure it. */ |   /* Configure it. */ | ||||||
|   if (configure_socket(s, channel) < 0) |   if (configure_socket(s, channel) < 0) | ||||||
|     { |     { | ||||||
|        closesocket(s); |        sclose(s); | ||||||
|        return -1; |        return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -911,7 +911,7 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | |||||||
|   if (setsockopt(s, IPPROTO_TCP, TCP_NODELAY, |   if (setsockopt(s, IPPROTO_TCP, TCP_NODELAY, | ||||||
|                  (void *)&opt, sizeof(opt)) == -1) |                  (void *)&opt, sizeof(opt)) == -1) | ||||||
|     { |     { | ||||||
|        closesocket(s); |        sclose(s); | ||||||
|        return -1; |        return -1; | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
| @@ -927,7 +927,7 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | |||||||
|  |  | ||||||
|       if (err != EINPROGRESS && err != EWOULDBLOCK) |       if (err != EINPROGRESS && err != EWOULDBLOCK) | ||||||
|         { |         { | ||||||
|           closesocket(s); |           sclose(s); | ||||||
|           return -1; |           return -1; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -938,7 +938,7 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | |||||||
|                                         channel->sock_create_cb_data); |                                         channel->sock_create_cb_data); | ||||||
|       if (err < 0) |       if (err < 0) | ||||||
|         { |         { | ||||||
|           closesocket(s); |           sclose(s); | ||||||
|           return err; |           return err; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -963,7 +963,7 @@ static int open_udp_socket(ares_channel channel, struct server_state *server) | |||||||
|   /* Set the socket non-blocking. */ |   /* Set the socket non-blocking. */ | ||||||
|   if (configure_socket(s, channel) < 0) |   if (configure_socket(s, channel) < 0) | ||||||
|     { |     { | ||||||
|        closesocket(s); |        sclose(s); | ||||||
|        return -1; |        return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -978,7 +978,7 @@ static int open_udp_socket(ares_channel channel, struct server_state *server) | |||||||
|  |  | ||||||
|       if (err != EINPROGRESS && err != EWOULDBLOCK) |       if (err != EINPROGRESS && err != EWOULDBLOCK) | ||||||
|         { |         { | ||||||
|           closesocket(s); |           sclose(s); | ||||||
|           return -1; |           return -1; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -989,7 +989,7 @@ static int open_udp_socket(ares_channel channel, struct server_state *server) | |||||||
|                                         channel->sock_create_cb_data); |                                         channel->sock_create_cb_data); | ||||||
|       if (err < 0) |       if (err < 0) | ||||||
|         { |         { | ||||||
|           closesocket(s); |           sclose(s); | ||||||
|           return err; |           return err; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -44,8 +44,8 @@ const char *ares_strerror(int code) | |||||||
|     "Illegal flags specified", |     "Illegal flags specified", | ||||||
|     "Given hostname is not numeric", |     "Given hostname is not numeric", | ||||||
|     "Illegal hints flags specified", |     "Illegal hints flags specified", | ||||||
|  |     "c-ares library initialization not yet performed", | ||||||
|     "Error loading iphlpapi.dll", |     "Error loading iphlpapi.dll", | ||||||
|     "Error loading advapi32.dll", |  | ||||||
|     "Could not find GetNetworkParams function" |     "Could not find GetNetworkParams function" | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -42,4 +42,4 @@ ${libtoolize} --copy --automake --force | |||||||
| ${ACLOCAL:-aclocal} -I m4 $ACLOCAL_FLAGS | ${ACLOCAL:-aclocal} -I m4 $ACLOCAL_FLAGS | ||||||
| ${AUTOHEADER:-autoheader} | ${AUTOHEADER:-autoheader} | ||||||
| ${AUTOCONF:-autoconf} | ${AUTOCONF:-autoconf} | ||||||
| ${AUTOMAKE:-automake} --add-missing | ${AUTOMAKE:-automake} --add-missing --copy | ||||||
|   | |||||||
| @@ -1,8 +1,21 @@ | |||||||
| @echo off | @echo off | ||||||
| REM set up a CVS tree to build when there's no autotools | REM | ||||||
| REM $Revision$ | REM $Id$ | ||||||
| REM $Date$ | REM | ||||||
|  | REM This batch file must be used to set up a CVS tree to build on | ||||||
|  | REM systems where there is no autotools support (i.e. Microsoft). | ||||||
|  | REM | ||||||
|  | REM This file is not included nor needed for c-ares' release | ||||||
|  | REM archives, neither for c-ares' daily snapshot archives. | ||||||
|  |  | ||||||
| REM create ares_build.h | if exist CVS-INFO goto start_doing | ||||||
|  | ECHO ERROR: This file shall only be used with a c-ares CVS tree checkout. | ||||||
|  | goto end_all | ||||||
|  | :start_doing | ||||||
|  |  | ||||||
|  | if not exist ares_build.h.dist goto end_ares_build_h | ||||||
| copy /Y ares_build.h.dist ares_build.h | copy /Y ares_build.h.dist ares_build.h | ||||||
|  | :end_ares_build_h | ||||||
|  |  | ||||||
|  | :end_all | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										112
									
								
								ares/config.dos
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								ares/config.dos
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,112 @@ | |||||||
|  | #ifndef HEADER_CONFIG_DOS_H | ||||||
|  | #define HEADER_CONFIG_DOS_H | ||||||
|  |  | ||||||
|  | /* $Id$ */ | ||||||
|  |  | ||||||
|  | /* ================================================================ */ | ||||||
|  | /*       ares/config.dos - Hand crafted config file for DOS         */ | ||||||
|  | /* ================================================================ */ | ||||||
|  |  | ||||||
|  | #define PACKAGE  "c-ares" | ||||||
|  |  | ||||||
|  | #define HAVE_GETTIMEOFDAY      1 | ||||||
|  | #define HAVE_IOCTLSOCKET       1 | ||||||
|  | #define HAVE_IOCTLSOCKET_FIONBIO   1 | ||||||
|  | #define HAVE_LIMITS_H          1 | ||||||
|  | #define HAVE_NET_IF_H          1 | ||||||
|  | #define HAVE_RECV              1 | ||||||
|  | #define HAVE_RECVFROM          1 | ||||||
|  | #define HAVE_SEND              1 | ||||||
|  | #define HAVE_STRDUP            1 | ||||||
|  | #define HAVE_STRICMP           1 | ||||||
|  | #define HAVE_STRUCT_IN6_ADDR   1 | ||||||
|  | #define HAVE_STRUCT_TIMEVAL    1 | ||||||
|  | #define HAVE_SYS_IOCTL_H       1 | ||||||
|  | #define HAVE_SYS_SOCKET_H      1 | ||||||
|  | #define HAVE_SYS_STAT_H        1 | ||||||
|  | #define HAVE_SYS_TYPES_H       1 | ||||||
|  | #define HAVE_TIME_H            1 | ||||||
|  | #define HAVE_UNISTD_H          1 | ||||||
|  |  | ||||||
|  | #define NEED_MALLOC_H          1 | ||||||
|  |  | ||||||
|  | #define RETSIGTYPE             void | ||||||
|  | #define TIME_WITH_SYS_TIME     1 | ||||||
|  |  | ||||||
|  | /* Qualifiers for send(), recv(), recvfrom() and getnameinfo(). */ | ||||||
|  |  | ||||||
|  | #define SEND_TYPE_ARG1         int | ||||||
|  | #define SEND_QUAL_ARG2         const | ||||||
|  | #define SEND_TYPE_ARG2         void * | ||||||
|  | #define SEND_TYPE_ARG3         int | ||||||
|  | #define SEND_TYPE_ARG4         int | ||||||
|  | #define SEND_TYPE_RETV         int | ||||||
|  |  | ||||||
|  | #define RECV_TYPE_ARG1         int | ||||||
|  | #define RECV_TYPE_ARG2         void * | ||||||
|  | #define RECV_TYPE_ARG3         int | ||||||
|  | #define RECV_TYPE_ARG4         int | ||||||
|  | #define RECV_TYPE_RETV         int | ||||||
|  |  | ||||||
|  | #define RECVFROM_TYPE_ARG1     int | ||||||
|  | #define RECVFROM_TYPE_ARG2     void | ||||||
|  | #define RECVFROM_TYPE_ARG3     int | ||||||
|  | #define RECVFROM_TYPE_ARG4     int | ||||||
|  | #define RECVFROM_TYPE_ARG5     struct sockaddr | ||||||
|  | #define RECVFROM_TYPE_ARG6     int | ||||||
|  | #define RECVFROM_TYPE_RETV     int | ||||||
|  | #define RECVFROM_TYPE_ARG2_IS_VOID 1 | ||||||
|  |  | ||||||
|  | #define BSD | ||||||
|  |  | ||||||
|  | #if defined(__HIGHC__) || \ | ||||||
|  |     (defined(__GNUC__) && (__GNUC__ < 4)) | ||||||
|  | #define ssize_t    int | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /* Target HAVE_x section */ | ||||||
|  |  | ||||||
|  | #if defined(DJGPP) | ||||||
|  |   #define HAVE_STRCASECMP           1 | ||||||
|  |   #define HAVE_STRNCASECMP          1 | ||||||
|  |   #define HAVE_SYS_TIME_H           1 | ||||||
|  |   #define HAVE_VARIADIC_MACROS_GCC  1 | ||||||
|  |  | ||||||
|  |   /* Because djgpp <= 2.03 doesn't have snprintf() etc. */ | ||||||
|  |   #if (DJGPP_MINOR < 4) | ||||||
|  |     #define _MPRINTF_REPLACE | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  | #elif defined(__WATCOMC__) | ||||||
|  |   #define HAVE_STRCASECMP 1 | ||||||
|  |  | ||||||
|  | #elif defined(__HIGHC__) | ||||||
|  |   #define HAVE_SYS_TIME_H 1 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef WATT32 | ||||||
|  |   #define HAVE_AF_INET6                    1 | ||||||
|  |   #define HAVE_ARPA_INET_H                 1 | ||||||
|  |   #define HAVE_ARPA_NAMESER_H              1 | ||||||
|  |   #define HAVE_CLOSESOCKET_CAMEL           1 | ||||||
|  |   #define HAVE_GETHOSTNAME                 1 | ||||||
|  |   #define HAVE_NETDB_H                     1 | ||||||
|  |   #define HAVE_NETINET_IN_H                1 | ||||||
|  |   #define HAVE_NETINET_TCP_H               1 | ||||||
|  |   #define HAVE_PF_INET6                    1 | ||||||
|  |   #define HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID  1 | ||||||
|  |   #define HAVE_STRUCT_ADDRINFO             1 | ||||||
|  |   #define HAVE_STRUCT_IN6_ADDR             1 | ||||||
|  |   #define HAVE_STRUCT_SOCKADDR_IN6         1 | ||||||
|  |   #define HAVE_SYS_SOCKET_H                1 | ||||||
|  |   #define HAVE_SYS_UIO_H                   1 | ||||||
|  |   #define NS_INADDRSZ                      4 | ||||||
|  |   #define HAVE_STRUCT_SOCKADDR_IN6         1 | ||||||
|  |   #define CloseSocket(s)                   close_s((s)) | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #undef word | ||||||
|  | #undef byte | ||||||
|  |  | ||||||
|  | #endif /* HEADER_CONFIG_DOS_H */ | ||||||
|  |  | ||||||
| @@ -7,12 +7,13 @@ AC_INIT([c-ares], [-], | |||||||
| CARES_OVERRIDE_AUTOCONF | CARES_OVERRIDE_AUTOCONF | ||||||
|  |  | ||||||
| AC_CONFIG_SRCDIR([ares_ipv6.h]) | AC_CONFIG_SRCDIR([ares_ipv6.h]) | ||||||
| AM_CONFIG_HEADER([config.h ares_build.h]) | AM_CONFIG_HEADER([ares_config.h ares_build.h]) | ||||||
| AM_MAINTAINER_MODE | AM_MAINTAINER_MODE | ||||||
|  |  | ||||||
| CARES_CHECK_OPTION_DEBUG | CARES_CHECK_OPTION_DEBUG | ||||||
| CARES_CHECK_OPTION_OPTIMIZE | CARES_CHECK_OPTION_OPTIMIZE | ||||||
| CARES_CHECK_OPTION_WARNINGS | CARES_CHECK_OPTION_WARNINGS | ||||||
|  | CARES_CHECK_OPTION_CURLDEBUG | ||||||
|  |  | ||||||
| CARES_CHECK_PATH_SEPARATOR | CARES_CHECK_PATH_SEPARATOR | ||||||
|  |  | ||||||
| @@ -94,11 +95,6 @@ esac | |||||||
| dnl support building of Windows DLLs | dnl support building of Windows DLLs | ||||||
| AC_LIBTOOL_WIN32_DLL | AC_LIBTOOL_WIN32_DLL | ||||||
|  |  | ||||||
| CARES_PROCESS_DEBUG_BUILD_OPTS |  | ||||||
|  |  | ||||||
| AM_CONDITIONAL(DEBUGBUILD, test x$want_debug = xyes) |  | ||||||
| AM_CONDITIONAL(CURLDEBUG, test x$want_debug = xyes) |  | ||||||
|  |  | ||||||
| dnl force libtool to build static libraries with PIC on AMD64-Linux & FreeBSD | dnl force libtool to build static libraries with PIC on AMD64-Linux & FreeBSD | ||||||
| AC_MSG_CHECKING([if arch-OS host is AMD64-Linux/FreeBSD (to build static libraries with PIC)]) | AC_MSG_CHECKING([if arch-OS host is AMD64-Linux/FreeBSD (to build static libraries with PIC)]) | ||||||
| case $host in | case $host in | ||||||
| @@ -114,18 +110,6 @@ esac | |||||||
| dnl libtool setup | dnl libtool setup | ||||||
| AC_PROG_LIBTOOL | AC_PROG_LIBTOOL | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([if we need -no-undefined]) |  | ||||||
| case $host in |  | ||||||
|   *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) |  | ||||||
|     need_no_undefined=yes |  | ||||||
|     ;; |  | ||||||
|   *) |  | ||||||
|     need_no_undefined=no |  | ||||||
|     ;; |  | ||||||
| esac |  | ||||||
| AC_MSG_RESULT($need_no_undefined) |  | ||||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl platform/compiler/architecture specific checks/flags | dnl platform/compiler/architecture specific checks/flags | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -161,6 +145,12 @@ esac | |||||||
| CARES_CHECK_COMPILER_HALT_ON_ERROR | CARES_CHECK_COMPILER_HALT_ON_ERROR | ||||||
| CARES_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | CARES_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | ||||||
|  |  | ||||||
|  | CARES_CHECK_NO_UNDEFINED | ||||||
|  | AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||||
|  |  | ||||||
|  | CARES_CHECK_CURLDEBUG | ||||||
|  | AM_CONDITIONAL(CURLDEBUG, test x$want_curldebug = xyes) | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Compilation based checks should not be done before this point. | dnl Compilation based checks should not be done before this point. | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -347,8 +337,7 @@ if test "$ac_cv_lib_resolve_strcasecmp" = "$ac_cv_func_strcasecmp"; then | |||||||
| fi | fi | ||||||
| ac_cv_func_strcasecmp="no" | ac_cv_func_strcasecmp="no" | ||||||
|  |  | ||||||
| dnl socket lib? | CARES_CHECK_LIBS_CONNECT | ||||||
| AC_CHECK_FUNC(connect, , [ AC_CHECK_LIB(socket, connect) ]) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl In case that function clock_gettime with monotonic timer is available, | dnl In case that function clock_gettime with monotonic timer is available, | ||||||
| @@ -448,6 +437,7 @@ AC_CHECK_HEADERS( | |||||||
|        netinet/tcp.h \ |        netinet/tcp.h \ | ||||||
|        net/if.h \ |        net/if.h \ | ||||||
|        errno.h \ |        errno.h \ | ||||||
|  |        socket.h \ | ||||||
|        strings.h \ |        strings.h \ | ||||||
|        stdbool.h \ |        stdbool.h \ | ||||||
|        time.h \ |        time.h \ | ||||||
| @@ -544,6 +534,9 @@ CURL_CHECK_FUNC_RECVFROM | |||||||
| CURL_CHECK_FUNC_SEND | CURL_CHECK_FUNC_SEND | ||||||
| CURL_CHECK_MSG_NOSIGNAL | CURL_CHECK_MSG_NOSIGNAL | ||||||
|  |  | ||||||
|  | CARES_CHECK_FUNC_CLOSESOCKET | ||||||
|  | CARES_CHECK_FUNC_CLOSESOCKET_CAMEL | ||||||
|  | CARES_CHECK_FUNC_CONNECT | ||||||
| CARES_CHECK_FUNC_FCNTL | CARES_CHECK_FUNC_FCNTL | ||||||
| CARES_CHECK_FUNC_FREEADDRINFO | CARES_CHECK_FUNC_FREEADDRINFO | ||||||
| CARES_CHECK_FUNC_GETADDRINFO | CARES_CHECK_FUNC_GETADDRINFO | ||||||
| @@ -557,6 +550,7 @@ CARES_CHECK_FUNC_IOCTL | |||||||
| CARES_CHECK_FUNC_IOCTLSOCKET | CARES_CHECK_FUNC_IOCTLSOCKET | ||||||
| CARES_CHECK_FUNC_IOCTLSOCKET_CAMEL | CARES_CHECK_FUNC_IOCTLSOCKET_CAMEL | ||||||
| CARES_CHECK_FUNC_SETSOCKOPT | CARES_CHECK_FUNC_SETSOCKOPT | ||||||
|  | CARES_CHECK_FUNC_SOCKET | ||||||
| CARES_CHECK_FUNC_STRCASECMP | CARES_CHECK_FUNC_STRCASECMP | ||||||
| CARES_CHECK_FUNC_STRCMPI | CARES_CHECK_FUNC_STRCMPI | ||||||
| CARES_CHECK_FUNC_STRDUP | CARES_CHECK_FUNC_STRDUP | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ | |||||||
| #*************************************************************************** | #*************************************************************************** | ||||||
|  |  | ||||||
| # File version for 'aclocal' use. Keep it a single number. | # File version for 'aclocal' use. Keep it a single number. | ||||||
| # serial 51 | # serial 56 | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_CHECK_COMPILER | dnl CARES_CHECK_COMPILER | ||||||
| @@ -24,6 +24,7 @@ dnl ------------------------------------------------- | |||||||
| dnl Verify if the C compiler being used is known. | dnl Verify if the C compiler being used is known. | ||||||
|  |  | ||||||
| AC_DEFUN([CARES_CHECK_COMPILER], [ | AC_DEFUN([CARES_CHECK_COMPILER], [ | ||||||
|  |   AC_BEFORE([$0],[CARES_CHECK_NO_UNDEFINED])dnl | ||||||
|   # |   # | ||||||
|   compiler_id="unknown" |   compiler_id="unknown" | ||||||
|   compiler_num="0" |   compiler_num="0" | ||||||
| @@ -1070,36 +1071,120 @@ squeeze() { | |||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_PROCESS_DEBUG_BUILD_OPTS | dnl CARES_CHECK_CURLDEBUG | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Settings which depend on configure's debug given | dnl Settings which depend on configure's curldebug given | ||||||
| dnl option, and further configure the build process. | dnl option, and other additional configure pre-requisites. | ||||||
| dnl Don't use this macro for compiler dependant stuff. | dnl Using the curl debug memory tracking feature in c-ares | ||||||
|  | dnl is a hack that actually can only be used/enabled when | ||||||
|  | dnl c-ares is built directly in curl's CVS tree, as a static | ||||||
|  | dnl library or as a shared one on those systems on which | ||||||
|  | dnl shared libraries support undefined symbols, along with | ||||||
|  | dnl an equally configured libcurl. | ||||||
|  |  | ||||||
| AC_DEFUN([CARES_PROCESS_DEBUG_BUILD_OPTS], [ | AC_DEFUN([CARES_CHECK_CURLDEBUG], [ | ||||||
|   AC_REQUIRE([CARES_CHECK_OPTION_DEBUG])dnl |  | ||||||
|   AC_REQUIRE([CARES_SHFUNC_SQUEEZE])dnl |   AC_REQUIRE([CARES_SHFUNC_SQUEEZE])dnl | ||||||
|   AC_BEFORE([$0],[AC_PROG_LIBTOOL])dnl |   cares_builddir=`pwd` | ||||||
|  |   supports_curldebug="unknown" | ||||||
|  |   if test "$want_curldebug" = "yes"; then | ||||||
|  |     if test "x$enable_shared" != "xno" && | ||||||
|  |       test "x$enable_shared" != "xyes"; then | ||||||
|  |       AC_MSG_WARN([unknown enable_shared setting.]) | ||||||
|  |       supports_curldebug="no" | ||||||
|  |     fi | ||||||
|  |     if test "x$enable_static" != "xno" && | ||||||
|  |       test "x$enable_static" != "xyes"; then | ||||||
|  |       AC_MSG_WARN([unknown enable_static setting.]) | ||||||
|  |       supports_curldebug="no" | ||||||
|  |     fi | ||||||
|  |     if test "$supports_curldebug" != "no"; then | ||||||
|  |       if test "$enable_shared" = "yes" && | ||||||
|  |         test "$need_no_undefined" = "yes"; then | ||||||
|  |         supports_curldebug="no" | ||||||
|  |         AC_MSG_WARN([shared library does not support undefined symbols.]) | ||||||
|  |       fi | ||||||
|  |       if test ! -f "$srcdir/../include/curl/curlbuild.h.dist"; then | ||||||
|  |         AC_MSG_WARN([c-ares source not embedded in curl's CVS tree.]) | ||||||
|  |         supports_curldebug="no" | ||||||
|  |       elif test ! -f "$srcdir/../include/curl/Makefile.in"; then | ||||||
|  |         AC_MSG_WARN([curl's buildconf has not been run.]) | ||||||
|  |         supports_curldebug="no" | ||||||
|  |       elif test ! -f "$cares_builddir/../libcurl.pc" || | ||||||
|  |         test ! -f "$cares_builddir/../include/curl/curlbuild.h"; then | ||||||
|  |         AC_MSG_WARN([curl's configure has not been run.]) | ||||||
|  |         supports_curldebug="no" | ||||||
|  |       elif test ! -f "$cares_builddir/../lib/curl_config.h"; then | ||||||
|  |         AC_MSG_WARN([libcurl's curl_config.h is missing.]) | ||||||
|  |         supports_curldebug="no" | ||||||
|  |       elif test ! -f "$cares_builddir/../config.status"; then | ||||||
|  |         AC_MSG_WARN([curl's config.status is missing.]) | ||||||
|  |         supports_curldebug="no" | ||||||
|  |       fi | ||||||
|  |       if test "$supports_curldebug" != "no"; then | ||||||
|  |         grep '^#define USE_ARES' "$cares_builddir/../lib/curl_config.h" >/dev/null | ||||||
|  |         if test "$?" -ne "0"; then | ||||||
|  |           AC_MSG_WARN([libcurl configured without c-ares support.]) | ||||||
|  |           supports_curldebug="no" | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
|  |       if test "$supports_curldebug" != "no"; then | ||||||
|  |         grep 'CPPFLAGS.*CURLDEBUG' "$cares_builddir/../config.status" >/dev/null | ||||||
|  |         if test "$?" -ne "0"; then | ||||||
|  |           AC_MSG_WARN([libcurl configured without curldebug support.]) | ||||||
|  |           supports_curldebug="no" | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|   # |   # | ||||||
|   if test "$want_debug" = "yes"; then |   if test "$want_curldebug" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if curl debug memory tracking can be enabled]) | ||||||
|     dnl when doing the debug stuff, use static library only |     test "$supports_curldebug" = "no" || supports_curldebug="yes" | ||||||
|     AC_DISABLE_SHARED |     AC_MSG_RESULT([$supports_curldebug]) | ||||||
|  |     if test "$supports_curldebug" = "no"; then | ||||||
|     debugbuild="yes" |       AC_MSG_WARN([cannot enable curl debug memory tracking.]) | ||||||
|  |       want_curldebug="no" | ||||||
|     dnl the entire --enable-debug is a hack that lives and runs on top of |     fi | ||||||
|     dnl libcurl stuff so this BUILDING_LIBCURL is not THAT much uglier |   fi | ||||||
|  |   # | ||||||
|  |   if test "$want_curldebug" = "yes"; then | ||||||
|  |     dnl TODO: Verify if the BUILDING_LIBCURL definition is still required. | ||||||
|     AC_DEFINE(BUILDING_LIBCURL, 1, [when building as static part of libcurl]) |     AC_DEFINE(BUILDING_LIBCURL, 1, [when building as static part of libcurl]) | ||||||
|  |     # CPPFLAGS="$CPPFLAGS -DCURLDEBUG" | ||||||
|     CPPFLAGS="$CPPFLAGS -DCURLDEBUG" |     CPPFLAGS="$CPPFLAGS -DCURLDEBUG -I../lib" | ||||||
|  |  | ||||||
|     dnl CHECKME: Do we still need so specify this include path here? |  | ||||||
|     CPPFLAGS="$CPPFLAGS -I$srcdir/../include" |  | ||||||
|  |  | ||||||
|     squeeze CPPFLAGS |     squeeze CPPFLAGS | ||||||
|   fi |   fi | ||||||
|   # |   # | ||||||
|  |   if test "$want_debug" = "yes"; then | ||||||
|  |     CPPFLAGS="$CPPFLAGS -DDEBUGBUILD" | ||||||
|  |     squeeze CPPFLAGS | ||||||
|  |   fi | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_NO_UNDEFINED | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Checks if the -no-undefined flag must be used when | ||||||
|  | dnl building shared libraries. This is required on all | ||||||
|  | dnl systems on which shared libraries should not have | ||||||
|  | dnl references to undefined symbols. This check should | ||||||
|  | dnl not be done before AC-PROG-LIBTOOL. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_NO_UNDEFINED], [ | ||||||
|  |   AC_BEFORE([$0],[CARES_CHECK_CURLDEBUG])dnl | ||||||
|  |   AC_MSG_CHECKING([if shared libraries need -no-undefined]) | ||||||
|  |   need_no_undefined="no" | ||||||
|  |   case $host in | ||||||
|  |     *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc* | *-*-aix*) | ||||||
|  |       need_no_undefined="yes" | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  |   if test "x$allow_undefined" = "xno"; then | ||||||
|  |     need_no_undefined="yes" | ||||||
|  |   elif test "x$allow_undefined_flag" = "xunsupported"; then | ||||||
|  |     need_no_undefined="yes" | ||||||
|  |   fi | ||||||
|  |   AC_MSG_RESULT($need_no_undefined) | ||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| #*************************************************************************** | #*************************************************************************** | ||||||
| # $Id$ | # $Id$ | ||||||
| # | # | ||||||
| # Copyright (C) 2008 by Daniel Stenberg et al | # Copyright (C) 2008 - 2009 by Daniel Stenberg et al | ||||||
| # | # | ||||||
| # Permission to use, copy, modify, and distribute this software and its | # Permission to use, copy, modify, and distribute this software and its | ||||||
| # documentation for any purpose and without fee is hereby granted, provided | # documentation for any purpose and without fee is hereby granted, provided | ||||||
| @@ -16,7 +16,46 @@ | |||||||
| #*************************************************************************** | #*************************************************************************** | ||||||
|  |  | ||||||
| # File version for 'aclocal' use. Keep it a single number. | # File version for 'aclocal' use. Keep it a single number. | ||||||
| # serial 3 | # serial 5 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_OPTION_CURLDEBUG | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if configure has been invoked with option | ||||||
|  | dnl --enable-curldebug or --disable-curldebug, and set | ||||||
|  | dnl shell variable want_curldebug value as appropriate. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_OPTION_CURLDEBUG], [ | ||||||
|  |   AC_BEFORE([$0],[CARES_CHECK_CURLDEBUG])dnl | ||||||
|  |   AC_MSG_CHECKING([whether to enable curl debug memory tracking]) | ||||||
|  |   OPT_CURLDEBUG_BUILD="default" | ||||||
|  |   AC_ARG_ENABLE(curldebug, | ||||||
|  | AC_HELP_STRING([--enable-curldebug],[Enable curl debug memory tracking]) | ||||||
|  | AC_HELP_STRING([--disable-curldebug],[Disable curl debug memory tracking]), | ||||||
|  |   OPT_CURLDEBUG_BUILD=$enableval) | ||||||
|  |   case "$OPT_CURLDEBUG_BUILD" in | ||||||
|  |     no) | ||||||
|  |       dnl --disable-curldebug option used | ||||||
|  |       want_curldebug="no" | ||||||
|  |       ;; | ||||||
|  |     default) | ||||||
|  |       dnl configure option not specified | ||||||
|  |       want_curldebug="no" | ||||||
|  |       ;; | ||||||
|  |     *) | ||||||
|  |       dnl --enable-curldebug option used. | ||||||
|  |       dnl The use of this option value is a request to enable curl's | ||||||
|  |       dnl debug memory tracking for the c-ares library. This is a big | ||||||
|  |       dnl hack that can only be done when a whole bunch of requisites | ||||||
|  |       dnl are simultaneously satisfied. Later on, these requisites are | ||||||
|  |       dnl verified and if they are not fully satisfied the option will | ||||||
|  |       dnl be ignored and act as if --disable-curldebug had been given | ||||||
|  |       dnl setting shell variable want_curldebug to 'no'. | ||||||
|  |       want_curldebug="yes" | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  |   AC_MSG_RESULT([$want_curldebug]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_CHECK_OPTION_DEBUG | dnl CARES_CHECK_OPTION_DEBUG | ||||||
| @@ -27,6 +66,7 @@ dnl variable want_debug value as appropriate. | |||||||
|  |  | ||||||
| AC_DEFUN([CARES_CHECK_OPTION_DEBUG], [ | AC_DEFUN([CARES_CHECK_OPTION_DEBUG], [ | ||||||
|   AC_BEFORE([$0],[CARES_CHECK_OPTION_WARNINGS])dnl |   AC_BEFORE([$0],[CARES_CHECK_OPTION_WARNINGS])dnl | ||||||
|  |   AC_BEFORE([$0],[CARES_CHECK_OPTION_CURLDEBUG])dnl | ||||||
|   AC_BEFORE([$0],[CARES_CHECK_PROG_CC])dnl |   AC_BEFORE([$0],[CARES_CHECK_PROG_CC])dnl | ||||||
|   AC_MSG_CHECKING([whether to enable debug build options]) |   AC_MSG_CHECKING([whether to enable debug build options]) | ||||||
|   OPT_DEBUG_BUILD="default" |   OPT_DEBUG_BUILD="default" | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ | |||||||
| #*************************************************************************** | #*************************************************************************** | ||||||
|  |  | ||||||
| # File version for 'aclocal' use. Keep it a single number. | # File version for 'aclocal' use. Keep it a single number. | ||||||
| # serial 29 | # serial 32 | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_INCLUDES_ARPA_INET | dnl CARES_INCLUDES_ARPA_INET | ||||||
| @@ -91,6 +91,27 @@ cares_includes_netdb="\ | |||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_INCLUDES_SOCKET | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Set up variable with list of headers that must be | ||||||
|  | dnl included when socket.h is to be included. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_INCLUDES_SOCKET], [ | ||||||
|  | cares_includes_socket="\ | ||||||
|  | /* includes start */ | ||||||
|  | #ifdef HAVE_SYS_TYPES_H | ||||||
|  | #  include <sys/types.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SOCKET_H | ||||||
|  | #  include <socket.h> | ||||||
|  | #endif | ||||||
|  | /* includes end */" | ||||||
|  |   AC_CHECK_HEADERS( | ||||||
|  |     sys/types.h socket.h, | ||||||
|  |     [], [], [$cares_includes_socket]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_INCLUDES_STDLIB | dnl CARES_INCLUDES_STDLIB | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Set up variable with list of headers that must be | dnl Set up variable with list of headers that must be | ||||||
| @@ -319,6 +340,288 @@ cares_preprocess_callconv="\ | |||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_FUNC_CLOSESOCKET | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if closesocket is available, prototyped, and | ||||||
|  | dnl can be compiled. If all of these are true, and | ||||||
|  | dnl usage has not been previously disallowed with | ||||||
|  | dnl shell variable cares_disallow_closesocket, then | ||||||
|  | dnl HAVE_CLOSESOCKET will be defined. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_FUNC_CLOSESOCKET], [ | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_WINSOCK2])dnl | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_SOCKET])dnl | ||||||
|  |   # | ||||||
|  |   tst_links_closesocket="unknown" | ||||||
|  |   tst_proto_closesocket="unknown" | ||||||
|  |   tst_compi_closesocket="unknown" | ||||||
|  |   tst_allow_closesocket="unknown" | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if closesocket can be linked]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_PROGRAM([[ | ||||||
|  |       $cares_includes_winsock2 | ||||||
|  |       $cares_includes_socket | ||||||
|  |     ]],[[ | ||||||
|  |       if(0 != closesocket(0)) | ||||||
|  |         return 1; | ||||||
|  |     ]]) | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     tst_links_closesocket="yes" | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     tst_links_closesocket="no" | ||||||
|  |   ]) | ||||||
|  |   # | ||||||
|  |   if test "$tst_links_closesocket" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if closesocket is prototyped]) | ||||||
|  |     AC_EGREP_CPP([closesocket],[ | ||||||
|  |       $cares_includes_winsock2 | ||||||
|  |       $cares_includes_socket | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_proto_closesocket="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_proto_closesocket="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_proto_closesocket" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if closesocket is compilable]) | ||||||
|  |     AC_COMPILE_IFELSE([ | ||||||
|  |       AC_LANG_PROGRAM([[ | ||||||
|  |         $cares_includes_winsock2 | ||||||
|  |         $cares_includes_socket | ||||||
|  |       ]],[[ | ||||||
|  |         if(0 != closesocket(0)) | ||||||
|  |           return 1; | ||||||
|  |       ]]) | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_compi_closesocket="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_compi_closesocket="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_compi_closesocket" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if closesocket usage allowed]) | ||||||
|  |     if test "x$cares_disallow_closesocket" != "xyes"; then | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_allow_closesocket="yes" | ||||||
|  |     else | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_allow_closesocket="no" | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if closesocket might be used]) | ||||||
|  |   if test "$tst_links_closesocket" = "yes" && | ||||||
|  |      test "$tst_proto_closesocket" = "yes" && | ||||||
|  |      test "$tst_compi_closesocket" = "yes" && | ||||||
|  |      test "$tst_allow_closesocket" = "yes"; then | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     AC_DEFINE_UNQUOTED(HAVE_CLOSESOCKET, 1, | ||||||
|  |       [Define to 1 if you have the closesocket function.]) | ||||||
|  |     ac_cv_func_closesocket="yes" | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     ac_cv_func_closesocket="no" | ||||||
|  |   fi | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_FUNC_CLOSESOCKET_CAMEL | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if CloseSocket is available, prototyped, and | ||||||
|  | dnl can be compiled. If all of these are true, and | ||||||
|  | dnl usage has not been previously disallowed with | ||||||
|  | dnl shell variable cares_disallow_closesocket_camel, | ||||||
|  | dnl then HAVE_CLOSESOCKET_CAMEL will be defined. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_FUNC_CLOSESOCKET_CAMEL], [ | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_SYS_SOCKET])dnl | ||||||
|  |   # | ||||||
|  |   tst_links_closesocket_camel="unknown" | ||||||
|  |   tst_proto_closesocket_camel="unknown" | ||||||
|  |   tst_compi_closesocket_camel="unknown" | ||||||
|  |   tst_allow_closesocket_camel="unknown" | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if CloseSocket can be linked]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_PROGRAM([[ | ||||||
|  |       $cares_includes_sys_socket | ||||||
|  |     ]],[[ | ||||||
|  |       if(0 != CloseSocket(0)) | ||||||
|  |         return 1; | ||||||
|  |     ]]) | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     tst_links_closesocket_camel="yes" | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     tst_links_closesocket_camel="no" | ||||||
|  |   ]) | ||||||
|  |   # | ||||||
|  |   if test "$tst_links_closesocket_camel" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if CloseSocket is prototyped]) | ||||||
|  |     AC_EGREP_CPP([CloseSocket],[ | ||||||
|  |       $cares_includes_sys_socket | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_proto_closesocket_camel="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_proto_closesocket_camel="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_proto_closesocket_camel" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if CloseSocket is compilable]) | ||||||
|  |     AC_COMPILE_IFELSE([ | ||||||
|  |       AC_LANG_PROGRAM([[ | ||||||
|  |         $cares_includes_sys_socket | ||||||
|  |       ]],[[ | ||||||
|  |         if(0 != CloseSocket(0)) | ||||||
|  |           return 1; | ||||||
|  |       ]]) | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_compi_closesocket_camel="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_compi_closesocket_camel="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_compi_closesocket_camel" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if CloseSocket usage allowed]) | ||||||
|  |     if test "x$cares_disallow_closesocket_camel" != "xyes"; then | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_allow_closesocket_camel="yes" | ||||||
|  |     else | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_allow_closesocket_camel="no" | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if CloseSocket might be used]) | ||||||
|  |   if test "$tst_links_closesocket_camel" = "yes" && | ||||||
|  |      test "$tst_proto_closesocket_camel" = "yes" && | ||||||
|  |      test "$tst_compi_closesocket_camel" = "yes" && | ||||||
|  |      test "$tst_allow_closesocket_camel" = "yes"; then | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     AC_DEFINE_UNQUOTED(HAVE_CLOSESOCKET_CAMEL, 1, | ||||||
|  |       [Define to 1 if you have the CloseSocket camel case function.]) | ||||||
|  |     ac_cv_func_closesocket_camel="yes" | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     ac_cv_func_closesocket_camel="no" | ||||||
|  |   fi | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_FUNC_CONNECT | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if connect is available, prototyped, and | ||||||
|  | dnl can be compiled. If all of these are true, and | ||||||
|  | dnl usage has not been previously disallowed with | ||||||
|  | dnl shell variable cares_disallow_connect, then | ||||||
|  | dnl HAVE_CONNECT will be defined. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_FUNC_CONNECT], [ | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_WINSOCK2])dnl | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_SYS_SOCKET])dnl | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_SOCKET])dnl | ||||||
|  |   # | ||||||
|  |   tst_links_connect="unknown" | ||||||
|  |   tst_proto_connect="unknown" | ||||||
|  |   tst_compi_connect="unknown" | ||||||
|  |   tst_allow_connect="unknown" | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if connect can be linked]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_PROGRAM([[ | ||||||
|  |       $cares_includes_winsock2 | ||||||
|  |       $cares_includes_sys_socket | ||||||
|  |       $cares_includes_socket | ||||||
|  |     ]],[[ | ||||||
|  |       if(0 != connect(0, 0, 0)) | ||||||
|  |         return 1; | ||||||
|  |     ]]) | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     tst_links_connect="yes" | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     tst_links_connect="no" | ||||||
|  |   ]) | ||||||
|  |   # | ||||||
|  |   if test "$tst_links_connect" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if connect is prototyped]) | ||||||
|  |     AC_EGREP_CPP([connect],[ | ||||||
|  |       $cares_includes_winsock2 | ||||||
|  |       $cares_includes_sys_socket | ||||||
|  |       $cares_includes_socket | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_proto_connect="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_proto_connect="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_proto_connect" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if connect is compilable]) | ||||||
|  |     AC_COMPILE_IFELSE([ | ||||||
|  |       AC_LANG_PROGRAM([[ | ||||||
|  |         $cares_includes_winsock2 | ||||||
|  |         $cares_includes_sys_socket | ||||||
|  |         $cares_includes_socket | ||||||
|  |       ]],[[ | ||||||
|  |         if(0 != connect(0, 0, 0)) | ||||||
|  |           return 1; | ||||||
|  |       ]]) | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_compi_connect="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_compi_connect="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_compi_connect" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if connect usage allowed]) | ||||||
|  |     if test "x$cares_disallow_connect" != "xyes"; then | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_allow_connect="yes" | ||||||
|  |     else | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_allow_connect="no" | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if connect might be used]) | ||||||
|  |   if test "$tst_links_connect" = "yes" && | ||||||
|  |      test "$tst_proto_connect" = "yes" && | ||||||
|  |      test "$tst_compi_connect" = "yes" && | ||||||
|  |      test "$tst_allow_connect" = "yes"; then | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     AC_DEFINE_UNQUOTED(HAVE_CONNECT, 1, | ||||||
|  |       [Define to 1 if you have the connect function.]) | ||||||
|  |     ac_cv_func_connect="yes" | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     ac_cv_func_connect="no" | ||||||
|  |   fi | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_CHECK_FUNC_FCNTL | dnl CARES_CHECK_FUNC_FCNTL | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Verify if fcntl is available, prototyped, and | dnl Verify if fcntl is available, prototyped, and | ||||||
| @@ -2074,6 +2377,104 @@ AC_DEFUN([CARES_CHECK_FUNC_SETSOCKOPT_SO_NONBLOCK], [ | |||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CARES_CHECK_FUNC_SOCKET | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify if socket is available, prototyped, and | ||||||
|  | dnl can be compiled. If all of these are true, and | ||||||
|  | dnl usage has not been previously disallowed with | ||||||
|  | dnl shell variable cares_disallow_socket, then | ||||||
|  | dnl HAVE_SOCKET will be defined. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CARES_CHECK_FUNC_SOCKET], [ | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_WINSOCK2])dnl | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_SYS_SOCKET])dnl | ||||||
|  |   AC_REQUIRE([CARES_INCLUDES_SOCKET])dnl | ||||||
|  |   # | ||||||
|  |   tst_links_socket="unknown" | ||||||
|  |   tst_proto_socket="unknown" | ||||||
|  |   tst_compi_socket="unknown" | ||||||
|  |   tst_allow_socket="unknown" | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if socket can be linked]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_PROGRAM([[ | ||||||
|  |       $cares_includes_winsock2 | ||||||
|  |       $cares_includes_sys_socket | ||||||
|  |       $cares_includes_socket | ||||||
|  |     ]],[[ | ||||||
|  |       if(0 != socket(0, 0, 0)) | ||||||
|  |         return 1; | ||||||
|  |     ]]) | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     tst_links_socket="yes" | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     tst_links_socket="no" | ||||||
|  |   ]) | ||||||
|  |   # | ||||||
|  |   if test "$tst_links_socket" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if socket is prototyped]) | ||||||
|  |     AC_EGREP_CPP([socket],[ | ||||||
|  |       $cares_includes_winsock2 | ||||||
|  |       $cares_includes_sys_socket | ||||||
|  |       $cares_includes_socket | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_proto_socket="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_proto_socket="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_proto_socket" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if socket is compilable]) | ||||||
|  |     AC_COMPILE_IFELSE([ | ||||||
|  |       AC_LANG_PROGRAM([[ | ||||||
|  |         $cares_includes_winsock2 | ||||||
|  |         $cares_includes_sys_socket | ||||||
|  |         $cares_includes_socket | ||||||
|  |       ]],[[ | ||||||
|  |         if(0 != socket(0, 0, 0)) | ||||||
|  |           return 1; | ||||||
|  |       ]]) | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_compi_socket="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_compi_socket="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_compi_socket" = "yes"; then | ||||||
|  |     AC_MSG_CHECKING([if socket usage allowed]) | ||||||
|  |     if test "x$cares_disallow_socket" != "xyes"; then | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_allow_socket="yes" | ||||||
|  |     else | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_allow_socket="no" | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if socket might be used]) | ||||||
|  |   if test "$tst_links_socket" = "yes" && | ||||||
|  |      test "$tst_proto_socket" = "yes" && | ||||||
|  |      test "$tst_compi_socket" = "yes" && | ||||||
|  |      test "$tst_allow_socket" = "yes"; then | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     AC_DEFINE_UNQUOTED(HAVE_SOCKET, 1, | ||||||
|  |       [Define to 1 if you have the socket function.]) | ||||||
|  |     ac_cv_func_socket="yes" | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     ac_cv_func_socket="no" | ||||||
|  |   fi | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CARES_CHECK_FUNC_STRCASECMP | dnl CARES_CHECK_FUNC_STRCASECMP | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Verify if strcasecmp is available, prototyped, and | dnl Verify if strcasecmp is available, prototyped, and | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								ares/maketgz
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								ares/maketgz
									
									
									
									
									
								
							| @@ -48,10 +48,24 @@ print "makes a new configure script\n"; | |||||||
| print "running configure\n"; | print "running configure\n"; | ||||||
| `./configure`; | `./configure`; | ||||||
|  |  | ||||||
|  | # generate HTML versions of man pages | ||||||
|  | # Deactivated for now. It seems that man pages need some adjustments | ||||||
|  | # relative to paragraph and/or line breaks for proper html formatting. | ||||||
|  | # EXTRA_DIST will need $(HTMLPAGES) when this is fully activated. | ||||||
|  | # print "running make html\n"; | ||||||
|  | # `make -s html`; | ||||||
|  |  | ||||||
|  | # generate PDF versions of man pages | ||||||
|  | print "running make pdf\n"; | ||||||
|  | `make -s pdf`; | ||||||
|  |  | ||||||
| # now make the actual tarball | # now make the actual tarball | ||||||
| print "running make dist\n"; | print "running make dist\n"; | ||||||
| `make dist VERSION=$version`; | `make dist VERSION=$version`; | ||||||
|  |  | ||||||
|  | # remove temporay sourced man pages | ||||||
|  | `make -s clean-sourced-manpages`; | ||||||
|  |  | ||||||
| print "removing temporary configure.ac file\n"; | print "removing temporary configure.ac file\n"; | ||||||
| `rm configure.ac.dist`; | `rm configure.ac.dist`; | ||||||
| print "removing temporary ares_version.h file\n"; | print "removing temporary ares_version.h file\n"; | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifdef HAVE_CONFIG_H | #ifdef HAVE_CONFIG_H | ||||||
| #include "config.h" | #include "ares_config.h" | ||||||
| #else | #else | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
| @@ -154,7 +154,7 @@ | |||||||
| #endif /* HAVE_CONFIG_H */ | #endif /* HAVE_CONFIG_H */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Recent autoconf versions define these symbols in config.h. We don't |  * Recent autoconf versions define these symbols in ares_config.h. We don't | ||||||
|  * want them (since they collide with the libcurl ones when we build |  * want them (since they collide with the libcurl ones when we build | ||||||
|  *  --enable-debug) so we undef them again here. |  *  --enable-debug) so we undef them again here. | ||||||
|  */ |  */ | ||||||
|   | |||||||
| @@ -222,6 +222,19 @@ struct timeval { | |||||||
| #endif /* if 0 */ | #endif /* if 0 */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Function-like macro definition used to close a socket. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #if defined(HAVE_CLOSESOCKET) | ||||||
|  | #  define sclose(x)  closesocket((x)) | ||||||
|  | #elif defined(HAVE_CLOSESOCKET_CAMEL) | ||||||
|  | #  define sclose(x)  CloseSocket((x)) | ||||||
|  | #else | ||||||
|  | #  define sclose(x)  close((x)) | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Uppercase macro versions of ANSI/ISO is*() functions/macros which |  * Uppercase macro versions of ANSI/ISO is*() functions/macros which | ||||||
|  * avoid negative number inputs with argument byte codes > 127. |  * avoid negative number inputs with argument byte codes > 127. | ||||||
| @@ -297,7 +310,7 @@ typedef int sig_atomic_t; | |||||||
|  * Macro used to include code only in debug builds. |  * Macro used to include code only in debug builds. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifdef CURLDEBUG | #ifdef DEBUGBUILD | ||||||
| #define DEBUGF(x) x | #define DEBUGF(x) x | ||||||
| #else | #else | ||||||
| #define DEBUGF(x) do { } while (0) | #define DEBUGF(x) do { } while (0) | ||||||
| @@ -308,7 +321,7 @@ typedef int sig_atomic_t; | |||||||
|  * Macro used to include assertion code only in debug builds. |  * Macro used to include assertion code only in debug builds. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #if defined(CURLDEBUG) && defined(HAVE_ASSERT_H) | #if defined(DEBUGBUILD) && defined(HAVE_ASSERT_H) | ||||||
| #define DEBUGASSERT(x) assert(x) | #define DEBUGASSERT(x) assert(x) | ||||||
| #else | #else | ||||||
| #define DEBUGASSERT(x) do { } while (0) | #define DEBUGASSERT(x) do { } while (0) | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
|  | Debug | ||||||
|  | Release | ||||||
| acountry.dep | acountry.dep | ||||||
| acountry.mak | acountry.mak | ||||||
| acountry.plg | acountry.plg | ||||||
|   | |||||||
| @@ -63,8 +63,8 @@ LIB32=link.exe -lib | |||||||
| # PROP Output_Dir "Debug" | # PROP Output_Dir "Debug" | ||||||
| # PROP Intermediate_Dir "Debug" | # PROP Intermediate_Dir "Debug" | ||||||
| # PROP Target_Dir "" | # PROP Target_Dir "" | ||||||
| # ADD BASE CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /FD /GZ /c | # ADD BASE CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "DEBUGBUILD" /D "_DEBUG" /D "_MBCS" /D "_LIB" /FD /GZ /c | ||||||
| # ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /FD /GZ /c | # ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "DEBUGBUILD" /D "_DEBUG" /D "_MBCS" /D "_LIB" /FD /GZ /c | ||||||
| # ADD BASE RSC /l 0x409 /d "_DEBUG" | # ADD BASE RSC /l 0x409 /d "_DEBUG" | ||||||
| # ADD RSC /l 0x409 /d "_DEBUG" | # ADD RSC /l 0x409 /d "_DEBUG" | ||||||
| BSC32=bscmake.exe | BSC32=bscmake.exe | ||||||
|   | |||||||
							
								
								
									
										104
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										104
									
								
								buildconf
									
									
									
									
									
								
							| @@ -88,7 +88,7 @@ if test -z "$ac_version"; then | |||||||
|   echo "            You need autoconf version $need_autoconf or newer installed." |   echo "            You need autoconf version $need_autoconf or newer installed." | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | fi | ||||||
| IFS=.; set $ac_version; IFS=' ' | old_IFS=$IFS; IFS='.'; set $ac_version; IFS=$old_IFS | ||||||
| if test "$1" = "2" -a "$2" -lt "57" || test "$1" -lt "2"; then | if test "$1" = "2" -a "$2" -lt "57" || test "$1" -lt "2"; then | ||||||
|   echo "buildconf: autoconf version $ac_version found." |   echo "buildconf: autoconf version $ac_version found." | ||||||
|   echo "            You need autoconf version $need_autoconf or newer installed." |   echo "            You need autoconf version $need_autoconf or newer installed." | ||||||
| @@ -121,7 +121,7 @@ if test -z "$ah_version"; then | |||||||
|   echo "            You need autoheader version 2.50 or newer installed." |   echo "            You need autoheader version 2.50 or newer installed." | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | fi | ||||||
| IFS=.; set $ah_version; IFS=' ' | old_IFS=$IFS; IFS='.'; set $ah_version; IFS=$old_IFS | ||||||
| if test "$1" = "2" -a "$2" -lt "50" || test "$1" -lt "2"; then | if test "$1" = "2" -a "$2" -lt "50" || test "$1" -lt "2"; then | ||||||
|   echo "buildconf: autoheader version $ah_version found." |   echo "buildconf: autoheader version $ah_version found." | ||||||
|   echo "            You need autoheader version 2.50 or newer installed." |   echo "            You need autoheader version 2.50 or newer installed." | ||||||
| @@ -143,7 +143,7 @@ if test -z "$am_version"; then | |||||||
|   echo "            You need automake version $need_automake or newer installed." |   echo "            You need automake version $need_automake or newer installed." | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | fi | ||||||
| IFS=.; set $am_version; IFS=' ' | old_IFS=$IFS; IFS='.'; set $am_version; IFS=$old_IFS | ||||||
| if test "$1" = "1" -a "$2" -lt "7" || test "$1" -lt "1"; then | if test "$1" = "1" -a "$2" -lt "7" || test "$1" -lt "1"; then | ||||||
|   echo "buildconf: automake version $am_version found." |   echo "buildconf: automake version $am_version found." | ||||||
|   echo "            You need automake version $need_automake or newer installed." |   echo "            You need automake version $need_automake or newer installed." | ||||||
| @@ -191,28 +191,28 @@ else | |||||||
|   libtoolize=`findtool $LIBTOOLIZE` |   libtoolize=`findtool $LIBTOOLIZE` | ||||||
| fi | fi | ||||||
|  |  | ||||||
| lt_pversion=`$libtool --version 2>/dev/null|head -n 1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | lt_pver=`$libtool --version 2>/dev/null|head -n 1` | ||||||
| if test -z "$lt_pversion"; then | lt_qver=`echo $lt_pver|sed -e "s/([^)]*)//g" -e "s/^[^0-9]*//g"` | ||||||
|  | lt_version=`echo $lt_qver|sed -e "s/[- ].*//" -e "s/\([a-z]*\)$//"` | ||||||
|  | if test -z "$lt_version"; then | ||||||
|   echo "buildconf: libtool not found." |   echo "buildconf: libtool not found." | ||||||
|   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" |   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | fi | ||||||
| lt_version=`echo $lt_pversion|sed -e 's/\([a-z]*\)$//'` | old_IFS=$IFS; IFS='.'; set $lt_version; IFS=$old_IFS | ||||||
| IFS=.; set $lt_version; IFS=' ' | lt_major=$1 | ||||||
|  | lt_minor=$2 | ||||||
|  | lt_patch=$3 | ||||||
| lt_status="good" | lt_status="good" | ||||||
|  |  | ||||||
| major=$1 | if test "$lt_major" = "$LIBTOOL_WANTED_MAJOR"; then | ||||||
| minor=$2 |    if test "$lt_minor" -lt "$LIBTOOL_WANTED_MINOR"; then | ||||||
| patch=$3 |  | ||||||
|  |  | ||||||
| if test "$major" = "$LIBTOOL_WANTED_MAJOR"; then |  | ||||||
|    if test "$minor" -lt "$LIBTOOL_WANTED_MINOR"; then |  | ||||||
|       lt_status="bad" |       lt_status="bad" | ||||||
|    elif test -n "$LIBTOOL_WANTED_PATCH"; then |    elif test -n "$LIBTOOL_WANTED_PATCH"; then | ||||||
|        if test "$minor" -gt "$LIBTOOL_WANTED_MINOR"; then |        if test "$lt_minor" -gt "$LIBTOOL_WANTED_MINOR"; then | ||||||
|          lt_status="good" |          lt_status="good" | ||||||
|        elif test -n "$patch"; then |        elif test -n "$lt_patch"; then | ||||||
|           if test "$patch" -lt "$LIBTOOL_WANTED_PATCH"; then |           if test "$lt_patch" -lt "$LIBTOOL_WANTED_PATCH"; then | ||||||
|              lt_status="bad" |              lt_status="bad" | ||||||
|           fi |           fi | ||||||
|        else |        else | ||||||
| @@ -221,7 +221,7 @@ if test "$major" = "$LIBTOOL_WANTED_MAJOR"; then | |||||||
|    fi |    fi | ||||||
| fi | fi | ||||||
| if test $lt_status != "good"; then | if test $lt_status != "good"; then | ||||||
|   echo "buildconf: libtool version $lt_pversion found." |   echo "buildconf: libtool version $lt_version found." | ||||||
|   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" |   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | fi | ||||||
| @@ -257,15 +257,23 @@ PERL=`findtool ${PERL:-perl}` | |||||||
| # Remove files generated on previous buildconf/configure run. | # Remove files generated on previous buildconf/configure run. | ||||||
| # | # | ||||||
| for fname in .deps \ | for fname in .deps \ | ||||||
|  |     .libs \ | ||||||
|  |     *.la \ | ||||||
|  |     *.lo \ | ||||||
|  |     *.a \ | ||||||
|  |     *.o \ | ||||||
|  |     Makefile \ | ||||||
|     Makefile.in \ |     Makefile.in \ | ||||||
|     aclocal.m4 \ |     aclocal.m4 \ | ||||||
|     aclocal.m4.bak \ |     aclocal.m4.bak \ | ||||||
|  |     ares_build.h \ | ||||||
|     autom4te.cache \ |     autom4te.cache \ | ||||||
|     compile \ |     compile \ | ||||||
|     config.guess \ |     config.guess \ | ||||||
|     config.h \ |     curl_config.h \ | ||||||
|     config.h.in \ |     curl_config.h.in \ | ||||||
|     config.log \ |     config.log \ | ||||||
|  |     config.lt \ | ||||||
|     config.status \ |     config.status \ | ||||||
|     config.sub \ |     config.sub \ | ||||||
|     configure \ |     configure \ | ||||||
| @@ -313,8 +321,8 @@ fi | |||||||
| echo "buildconf: running autoheader" | echo "buildconf: running autoheader" | ||||||
| ${AUTOHEADER:-autoheader} || die "The autoheader command failed" | ${AUTOHEADER:-autoheader} || die "The autoheader command failed" | ||||||
|  |  | ||||||
| echo "buildconf: cp lib/config.h.in src/config.h.in" | echo "buildconf: cp lib/curl_config.h.in src/curl_config.h.in" | ||||||
| cp lib/config.h.in src/config.h.in | cp lib/curl_config.h.in src/curl_config.h.in | ||||||
|  |  | ||||||
| echo "buildconf: running autoconf" | echo "buildconf: running autoconf" | ||||||
| ${AUTOCONF:-autoconf}     || die "The autoconf command failed" | ${AUTOCONF:-autoconf}     || die "The autoconf command failed" | ||||||
| @@ -329,5 +337,59 @@ fi | |||||||
| echo "buildconf: running automake" | echo "buildconf: running automake" | ||||||
| ${AUTOMAKE:-automake} -a -c  || die "The automake command failed" | ${AUTOMAKE:-automake} -a -c  || die "The automake command failed" | ||||||
|  |  | ||||||
|  | #-------------------------------------------------------------------------- | ||||||
|  | # Depending on the libtool and automake versions being used, config.guess | ||||||
|  | # might not be installed in the subdirectory until automake has finished. | ||||||
|  | # So we can not attempt to use it until this very last buildconf stage. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | if test ! -f ./config.guess; then | ||||||
|  |   echo "buildconf: config.guess not found" | ||||||
|  | else | ||||||
|  |   buildhost=`./config.guess 2>/dev/null|head -n 1` | ||||||
|  |   case $buildhost in | ||||||
|  |     *-*-hpux*) | ||||||
|  |       need_lt_major=1 | ||||||
|  |       need_lt_minor=5 | ||||||
|  |       need_lt_patch=24 | ||||||
|  |       need_lt_check="yes" | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  |   if test ! -z "$need_lt_check"; then | ||||||
|  |     if test -z "$lt_major"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |     elif test "$lt_major" -gt "$need_lt_major"; then | ||||||
|  |       lt_status="good" | ||||||
|  |     elif test "$lt_major" -lt "$need_lt_major"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |     elif test -z "$lt_minor"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |     elif test "$lt_minor" -gt "$need_lt_minor"; then | ||||||
|  |       lt_status="good" | ||||||
|  |     elif test "$lt_minor" -lt "$need_lt_minor"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |     elif test -z "$lt_patch"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |     elif test "$lt_patch" -gt "$need_lt_patch"; then | ||||||
|  |       lt_status="good" | ||||||
|  |     elif test "$lt_patch" -lt "$need_lt_patch"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |     else | ||||||
|  |       lt_status="good" | ||||||
|  |     fi | ||||||
|  |     if test "$lt_status" != "good"; then | ||||||
|  |       need_lt_version="$need_lt_major.$need_lt_minor.$need_lt_patch" | ||||||
|  |       echo "buildconf: libtool version $lt_version found." | ||||||
|  |       echo "            $buildhost requires libtool $need_lt_version or newer installed." | ||||||
|  |       rm -f configure | ||||||
|  |       exit 1 | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | #-------------------------------------------------------------------------- | ||||||
|  | # Finished succesfully. | ||||||
|  | # | ||||||
|  |  | ||||||
| echo "buildconf: OK" | echo "buildconf: OK" | ||||||
| exit 0 | exit 0 | ||||||
|   | |||||||
| @@ -1,16 +1,32 @@ | |||||||
| @echo off | @echo off | ||||||
| REM set up a CVS tree to build when there's no autotools | REM | ||||||
| REM $Revision$ | REM $Id$ | ||||||
| REM $Date$ | REM | ||||||
|  | REM This batch file must be used to set up a CVS tree to build on | ||||||
|  | REM systems where there is no autotools support (i.e. Microsoft). | ||||||
|  | REM | ||||||
|  | REM This file is not included nor needed for curl's release | ||||||
|  | REM archives, neither for curl's daily snapshot archives. | ||||||
|  |  | ||||||
|  | if exist CVS-INFO goto start_doing | ||||||
|  | ECHO ERROR: This file shall only be used with a curl CVS tree checkout. | ||||||
|  | goto end_all | ||||||
|  | :start_doing | ||||||
|  |  | ||||||
| REM create hugehelp.c | REM create hugehelp.c | ||||||
| copy src\hugehelp.c.cvs src\hugehelp.c | if not exist src\hugehelp.c.cvs goto end_hugehelp_c | ||||||
|  | copy /Y src\hugehelp.c.cvs src\hugehelp.c | ||||||
|  | :end_hugehelp_c | ||||||
|  |  | ||||||
| REM create Makefile | REM create Makefile | ||||||
| copy Makefile.dist Makefile | if not exist Makefile.dist goto end_makefile | ||||||
|  | copy /Y Makefile.dist Makefile | ||||||
|  | :end_makefile | ||||||
|  |  | ||||||
| REM create curlbuild.h | REM create curlbuild.h | ||||||
| copy include\curl\curlbuild.h.dist include\curl\curlbuild.h | 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 setup c-ares CVS tree | REM setup c-ares CVS tree | ||||||
| if not exist ares\buildconf.bat goto end_c_ares | if not exist ares\buildconf.bat goto end_c_ares | ||||||
| @@ -19,3 +35,5 @@ call buildconf.bat | |||||||
| cd .. | cd .. | ||||||
| :end_c_ares | :end_c_ares | ||||||
|  |  | ||||||
|  | :end_all | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										109
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										109
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -35,12 +35,13 @@ 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]) | ||||||
|  |  | ||||||
| AC_CONFIG_SRCDIR([lib/urldata.h]) | AC_CONFIG_SRCDIR([lib/urldata.h]) | ||||||
| AM_CONFIG_HEADER(lib/config.h src/config.h include/curl/curlbuild.h) | AM_CONFIG_HEADER(lib/curl_config.h src/curl_config.h include/curl/curlbuild.h) | ||||||
| AM_MAINTAINER_MODE | AM_MAINTAINER_MODE | ||||||
|  |  | ||||||
| CURL_CHECK_OPTION_DEBUG | CURL_CHECK_OPTION_DEBUG | ||||||
| CURL_CHECK_OPTION_OPTIMIZE | CURL_CHECK_OPTION_OPTIMIZE | ||||||
| CURL_CHECK_OPTION_WARNINGS | CURL_CHECK_OPTION_WARNINGS | ||||||
|  | CURL_CHECK_OPTION_CURLDEBUG | ||||||
|  |  | ||||||
| CURL_CHECK_PATH_SEPARATOR | CURL_CHECK_PATH_SEPARATOR | ||||||
|  |  | ||||||
| @@ -155,8 +156,6 @@ AC_SYS_LARGEFILE | |||||||
| dnl support building of Windows DLLs | dnl support building of Windows DLLs | ||||||
| AC_LIBTOOL_WIN32_DLL | AC_LIBTOOL_WIN32_DLL | ||||||
|  |  | ||||||
| CURL_PROCESS_DEBUG_BUILD_OPTS |  | ||||||
|  |  | ||||||
| dnl force libtool to build static libraries with PIC on AMD64-Linux & FreeBSD | dnl force libtool to build static libraries with PIC on AMD64-Linux & FreeBSD | ||||||
| AC_MSG_CHECKING([if arch-OS host is AMD64-Linux/FreeBSD (to build static libraries with PIC)]) | AC_MSG_CHECKING([if arch-OS host is AMD64-Linux/FreeBSD (to build static libraries with PIC)]) | ||||||
| case $host in | case $host in | ||||||
| @@ -172,18 +171,6 @@ esac | |||||||
| dnl libtool setup | dnl libtool setup | ||||||
| AC_PROG_LIBTOOL | AC_PROG_LIBTOOL | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([if we need -no-undefined]) |  | ||||||
| case $host in |  | ||||||
|   *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) |  | ||||||
|     need_no_undefined=yes |  | ||||||
|     ;; |  | ||||||
|   *) |  | ||||||
|     need_no_undefined=no |  | ||||||
|     ;; |  | ||||||
| esac |  | ||||||
| AC_MSG_RESULT($need_no_undefined) |  | ||||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) |  | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([if we need -mimpure-text]) | AC_MSG_CHECKING([if we need -mimpure-text]) | ||||||
| mimpure=no | mimpure=no | ||||||
| case $host in | case $host in | ||||||
| @@ -270,6 +257,12 @@ esac | |||||||
| CURL_CHECK_COMPILER_HALT_ON_ERROR | CURL_CHECK_COMPILER_HALT_ON_ERROR | ||||||
| CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | ||||||
|  |  | ||||||
|  | CURL_CHECK_NO_UNDEFINED | ||||||
|  | AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||||
|  |  | ||||||
|  | CURL_CHECK_CURLDEBUG | ||||||
|  | AM_CONDITIONAL(CURLDEBUG, test x$want_curldebug = xyes) | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Compilation based checks should not be done before this point. | dnl Compilation based checks should not be done before this point. | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -663,8 +656,7 @@ if test "$ac_cv_lib_resolve_strcasecmp" = "$ac_cv_func_strcasecmp"; then | |||||||
| fi | fi | ||||||
| ac_cv_func_strcasecmp="no" | ac_cv_func_strcasecmp="no" | ||||||
|  |  | ||||||
| dnl socket lib? | CURL_CHECK_LIBS_CONNECT | ||||||
| AC_CHECK_FUNC(connect, , [ AC_CHECK_LIB(socket, connect) ]) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl In case that function clock_gettime with monotonic timer is available, | dnl In case that function clock_gettime with monotonic timer is available, | ||||||
| @@ -1554,25 +1546,9 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
|  |  | ||||||
|   if test X"$OPT_GNUTLS" != Xno; then |   if test X"$OPT_GNUTLS" != Xno; then | ||||||
|  |  | ||||||
|     AC_MSG_NOTICE([OPT_GNUTLS is $OPT_GNUTLS]) |  | ||||||
|  |  | ||||||
|     addld="" |     addld="" | ||||||
|     if test "x$OPT_GNUTLS" = "xyes"; then |     if test "x$OPT_GNUTLS" = "xyes"; then | ||||||
|       check=`libgnutls-config --version 2>/dev/null` |       dnl this is with no partiular path given | ||||||
|       if test -n "$check"; then |  | ||||||
|         addlib=`libgnutls-config --libs` |  | ||||||
|         addcflags=`libgnutls-config --cflags` |  | ||||||
|         version=`libgnutls-config --version` |  | ||||||
|         gtlslib=`libgnutls-config --prefix`/lib$libsuff |  | ||||||
|       fi |  | ||||||
|     else |  | ||||||
|       addlib=`$OPT_GNUTLS/bin/libgnutls-config --libs` |  | ||||||
|       addcflags=`$OPT_GNUTLS/bin/libgnutls-config --cflags` |  | ||||||
|       version=`$OPT_GNUTLS/bin/libgnutls-config --version 2>/dev/null` |  | ||||||
|       gtlslib=$OPT_GNUTLS/lib$libsuff |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|     if test -z "$version"; then |  | ||||||
|       CURL_CHECK_PKGCONFIG(gnutls) |       CURL_CHECK_PKGCONFIG(gnutls) | ||||||
|  |  | ||||||
|       if test "$PKGCONFIG" != "no" ; then |       if test "$PKGCONFIG" != "no" ; then | ||||||
| @@ -1581,8 +1557,34 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
|         addcflags=`$PKGCONFIG --cflags-only-I gnutls` |         addcflags=`$PKGCONFIG --cflags-only-I gnutls` | ||||||
|         version=`$PKGCONFIG --modversion gnutls` |         version=`$PKGCONFIG --modversion gnutls` | ||||||
|         gtlslib=`echo $addld | $SED -e 's/-L//'` |         gtlslib=`echo $addld | $SED -e 's/-L//'` | ||||||
|  |       else | ||||||
|  |         dnl without pkg-config, we try libgnutls-config as that was how it | ||||||
|  |         dnl used to be done | ||||||
|  |         check=`libgnutls-config --version 2>/dev/null` | ||||||
|  |         if test -n "$check"; then | ||||||
|  |           addlib=`libgnutls-config --libs` | ||||||
|  |           addcflags=`libgnutls-config --cflags` | ||||||
|  |           version=`libgnutls-config --version` | ||||||
|  |           gtlslib=`libgnutls-config --prefix`/lib$libsuff | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
|  |     else | ||||||
|  |       dnl this is with a given path, first check if there's a libgnutls-config | ||||||
|  |       dnl there and if not, make an educated guess | ||||||
|  |       check=`$OPT_GNUTLS/libgnutls-config --version 2>/dev/null` | ||||||
|  |       if test -n "$check"; then | ||||||
|  |         addlib=`$OPT_GNUTLS/libgnutls-config --libs` | ||||||
|  |         addcflags=`$OPT_GNUTLS/libgnutls-config --cflags` | ||||||
|  |         version=`$OPT_GNUTLS/libgnutls-config --version` | ||||||
|  |         gtlslib=`$OPT_GNUTLS/libgnutls-config --prefix`/lib$libsuff | ||||||
|  |       else | ||||||
|  |         dnl without pkg-config and libgnutls-config, we guess a lot! | ||||||
|  |         addlib=-lgnutls | ||||||
|  |         addld=-L$OPT_GNUTLS/lib$libsuff | ||||||
|  |         addcflags=-I$OPT_GNUTLS/include | ||||||
|  |         version="" # we just don't know | ||||||
|  |         gtlslib=$OPT_GNUTLS/lib$libsuff | ||||||
|       fi |       fi | ||||||
|  |  | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if test -z "$version"; then |     if test -z "$version"; then | ||||||
| @@ -1663,10 +1665,10 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | |||||||
|       fi |       fi | ||||||
|     else |     else | ||||||
|       # Without pkg-config, we'll kludge in some defaults |       # Without pkg-config, we'll kludge in some defaults | ||||||
|       addlib="-lssl3 -lsmime3 -lnss3 -lplds4 -lplc4 -lnspr4 -lpthread -ldl" |       addlib="-L$OPT_NSS/lib -lssl3 -lsmime3 -lnss3 -lplds4 -lplc4 -lnspr4 -lpthread -ldl" | ||||||
|       addcflags="-I$OPT_NSS/include" |       addcflags="-I$OPT_NSS/include" | ||||||
|       version="unknown" |       version="unknown" | ||||||
|       gtlsprefix=$OPT_GNUTLS |       nssprefix=$OPT_NSS | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     dnl Check for functionPK11_CreateGenericObject |     dnl Check for functionPK11_CreateGenericObject | ||||||
| @@ -1907,6 +1909,7 @@ AC_CHECK_HEADERS( | |||||||
|         sys/utime.h \ |         sys/utime.h \ | ||||||
|         sys/poll.h \ |         sys/poll.h \ | ||||||
|         poll.h \ |         poll.h \ | ||||||
|  |         socket.h \ | ||||||
|         sys/resource.h \ |         sys/resource.h \ | ||||||
|         libgen.h \ |         libgen.h \ | ||||||
|         locale.h \ |         locale.h \ | ||||||
| @@ -2017,6 +2020,9 @@ CURL_CHECK_FUNC_SEND | |||||||
| CURL_CHECK_MSG_NOSIGNAL | CURL_CHECK_MSG_NOSIGNAL | ||||||
|  |  | ||||||
| CURL_CHECK_FUNC_ALARM | CURL_CHECK_FUNC_ALARM | ||||||
|  | CURL_CHECK_FUNC_CLOSESOCKET | ||||||
|  | CURL_CHECK_FUNC_CLOSESOCKET_CAMEL | ||||||
|  | CURL_CHECK_FUNC_CONNECT | ||||||
| CURL_CHECK_FUNC_FCNTL | CURL_CHECK_FUNC_FCNTL | ||||||
| CURL_CHECK_FUNC_FDOPEN | CURL_CHECK_FUNC_FDOPEN | ||||||
| CURL_CHECK_FUNC_FREEADDRINFO | CURL_CHECK_FUNC_FREEADDRINFO | ||||||
| @@ -2044,6 +2050,7 @@ CURL_CHECK_FUNC_SIGACTION | |||||||
| CURL_CHECK_FUNC_SIGINTERRUPT | CURL_CHECK_FUNC_SIGINTERRUPT | ||||||
| CURL_CHECK_FUNC_SIGNAL | CURL_CHECK_FUNC_SIGNAL | ||||||
| CURL_CHECK_FUNC_SIGSETJMP | CURL_CHECK_FUNC_SIGSETJMP | ||||||
|  | CURL_CHECK_FUNC_SOCKET | ||||||
| CURL_CHECK_FUNC_STRCASECMP | CURL_CHECK_FUNC_STRCASECMP | ||||||
| CURL_CHECK_FUNC_STRCASESTR | CURL_CHECK_FUNC_STRCASESTR | ||||||
| CURL_CHECK_FUNC_STRCMPI | CURL_CHECK_FUNC_STRCMPI | ||||||
| @@ -2072,7 +2079,6 @@ case $host in | |||||||
| esac | esac | ||||||
|  |  | ||||||
| AC_CHECK_FUNCS([basename \ | AC_CHECK_FUNCS([basename \ | ||||||
|   closesocket \ |  | ||||||
|   fork \ |   fork \ | ||||||
|   geteuid \ |   geteuid \ | ||||||
|   getpass_r \ |   getpass_r \ | ||||||
| @@ -2087,7 +2093,6 @@ AC_CHECK_FUNCS([basename \ | |||||||
|   setlocale \ |   setlocale \ | ||||||
|   setmode \ |   setmode \ | ||||||
|   setrlimit \ |   setrlimit \ | ||||||
|   socket \ |  | ||||||
|   uname \ |   uname \ | ||||||
|   utime |   utime | ||||||
| ],[ | ],[ | ||||||
| @@ -2200,6 +2205,9 @@ fi | |||||||
| dnl set variable for use in automakefile(s) | dnl set variable for use in automakefile(s) | ||||||
| AM_CONDITIONAL(USE_MANUAL, test x"$USE_MANUAL" = x1) | AM_CONDITIONAL(USE_MANUAL, test x"$USE_MANUAL" = x1) | ||||||
|  |  | ||||||
|  | aresembedded="unknown" | ||||||
|  | configure_rundir=`pwd` | ||||||
|  | embedded_ares_builddir="$configure_rundir/ares" | ||||||
| AC_MSG_CHECKING([whether to enable c-ares]) | AC_MSG_CHECKING([whether to enable c-ares]) | ||||||
| AC_ARG_ENABLE(ares, | AC_ARG_ENABLE(ares, | ||||||
| AC_HELP_STRING([--enable-ares=PATH],[Enable c-ares for name lookups]) | AC_HELP_STRING([--enable-ares=PATH],[Enable c-ares for name lookups]) | ||||||
| @@ -2230,14 +2238,9 @@ AC_HELP_STRING([--disable-ares],[Disable c-ares for name lookups]), | |||||||
|          if test -d "$srcdir/ares"; then |          if test -d "$srcdir/ares"; then | ||||||
|             aresembedded="yes" |             aresembedded="yes" | ||||||
|             AC_CONFIG_SUBDIRS(ares) |             AC_CONFIG_SUBDIRS(ares) | ||||||
|             aresinc=`cd $srcdir/ares && pwd` |             dnl Since c-ares has installable configured header files, path | ||||||
|             CPPFLAGS="$CPPFLAGS -I$aresinc" |             dnl inclusion is fully done in makefiles for in-tree builds. | ||||||
|  |             LDFLAGS="$LDFLAGS -L$embedded_ares_builddir" | ||||||
|             dnl the pwd= below cannot 'cd' into the ares dir to get the full |  | ||||||
|             dnl path to it, since it may not exist yet if we build outside of |  | ||||||
|             dnl the source tree |  | ||||||
|             pwd=`pwd` |  | ||||||
|             LDFLAGS="$LDFLAGS -L$pwd/ares" |  | ||||||
|          fi |          fi | ||||||
|        else |        else | ||||||
|          CPPFLAGS="$CPPFLAGS -I$enableval/include" |          CPPFLAGS="$CPPFLAGS -I$enableval/include" | ||||||
| @@ -2275,6 +2278,9 @@ AC_HELP_STRING([--disable-ares],[Disable c-ares for name lookups]), | |||||||
|        AC_MSG_RESULT(no) |        AC_MSG_RESULT(no) | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | dnl set variable for use in automakefile(s) | ||||||
|  | AM_CONDITIONAL(USE_EMBEDDED_ARES, test x$aresembedded = xyes) | ||||||
|  |  | ||||||
| dnl ************************************************************ | dnl ************************************************************ | ||||||
| dnl disable verbose text strings | dnl disable verbose text strings | ||||||
| dnl | dnl | ||||||
| @@ -2399,7 +2405,7 @@ AC_HELP_STRING([--disable-hidden-symbols],[Leave all symbols with default visibi | |||||||
|  |  | ||||||
| dnl ************************************************************ | dnl ************************************************************ | ||||||
| dnl enforce SONAME bump | dnl enforce SONAME bump | ||||||
| dnl  | dnl | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([whether to enforce SONAME bump]) | AC_MSG_CHECKING([whether to enforce SONAME bump]) | ||||||
| AC_ARG_ENABLE(soname-bump, | AC_ARG_ENABLE(soname-bump, | ||||||
| @@ -2530,6 +2536,11 @@ squeeze CURL_LIBS | |||||||
| squeeze LIBCURL_LIBS | squeeze LIBCURL_LIBS | ||||||
| squeeze TEST_SERVER_LIBS | squeeze TEST_SERVER_LIBS | ||||||
|  |  | ||||||
|  | if test "x$want_curldebug_assumed" = "xyes" && | ||||||
|  |   test "x$want_curldebug" = "xyes" && test "x$HAVE_ARES" = "x1"; then | ||||||
|  |   ac_configure_args="$ac_configure_args --enable-curldebug" | ||||||
|  | fi | ||||||
|  |  | ||||||
| AC_CONFIG_FILES([Makefile \ | AC_CONFIG_FILES([Makefile \ | ||||||
|            docs/Makefile \ |            docs/Makefile \ | ||||||
|            docs/examples/Makefile \ |            docs/examples/Makefile \ | ||||||
| @@ -2583,7 +2594,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | |||||||
|   ca cert bundle:  ${ca} |   ca cert bundle:  ${ca} | ||||||
|   ca cert path:    ${capath} |   ca cert path:    ${capath} | ||||||
|   LDAP support:    ${curl_ldap_msg} |   LDAP support:    ${curl_ldap_msg} | ||||||
|   LDAPS support:   ${curl_ldaps_msg}  |   LDAPS support:   ${curl_ldaps_msg} | ||||||
| ]) | ]) | ||||||
|  |  | ||||||
| if test "x$soname_bump" = "xyes"; then | if test "x$soname_bump" = "xyes"; then | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ autom4te.cache | |||||||
| *.patch | *.patch | ||||||
| CVS | CVS | ||||||
| *.asc | *.asc | ||||||
| config.h | curl_config.h | ||||||
| *.la | *.la | ||||||
| *.lai | *.lai | ||||||
| libtool | libtool | ||||||
|   | |||||||
							
								
								
									
										31
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| Updated: Feb 23, 2009 (http://curl.haxx.se/docs/faq.html) | Updated: Jun 9, 2009 (http://curl.haxx.se/docs/faq.html) | ||||||
|                                   _   _ ____  _ |                                   _   _ ____  _ | ||||||
|                               ___| | | |  _ \| | |                               ___| | | |  _ \| | | ||||||
|                              / __| | | | |_) | | |                              / __| | | | |_) | | | ||||||
| @@ -19,6 +19,7 @@ FAQ | |||||||
|   1.9 Where do I buy commercial support for curl? |   1.9 Where do I buy commercial support for curl? | ||||||
|   1.10 How many are using curl? |   1.10 How many are using curl? | ||||||
|   1.11 Why don't you update ca-bundle.crt |   1.11 Why don't you update ca-bundle.crt | ||||||
|  |   1.12 I have a problem who can I chat with? | ||||||
|  |  | ||||||
|  2. Install Related Problems |  2. Install Related Problems | ||||||
|   2.1 configure doesn't find OpenSSL even when it is installed |   2.1 configure doesn't find OpenSSL even when it is installed | ||||||
| @@ -88,6 +89,7 @@ FAQ | |||||||
|   5.12 Can I make libcurl fake or hide my real IP address? |   5.12 Can I make libcurl fake or hide my real IP address? | ||||||
|   5.13 How do I stop an ongoing transfer? |   5.13 How do I stop an ongoing transfer? | ||||||
|   5.14 Using C++ non-static functions for callbacks? |   5.14 Using C++ non-static functions for callbacks? | ||||||
|  |   5.15 How do I get an FTP directory listing?  | ||||||
|  |  | ||||||
|  6. License Issues |  6. License Issues | ||||||
|   6.1 I have a GPL program, can I use the libcurl library? |   6.1 I have a GPL program, can I use the libcurl library? | ||||||
| @@ -344,6 +346,12 @@ FAQ | |||||||
|   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: http://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? | ||||||
|  |  | ||||||
|  |   There's a bunch of friendly people hanging out in the #curl channel on the | ||||||
|  |   IRC network irc.freenode.net. If you're polite and nice, chances are big | ||||||
|  |   that you can get -- or provide -- help instantly. | ||||||
|  |  | ||||||
|  |  | ||||||
| 2. Install Related Problems | 2. Install Related Problems | ||||||
|  |  | ||||||
| @@ -1123,6 +1131,27 @@ FAQ | |||||||
|      curl_easy_setopt(hcurl, CURLOPT_WRITEFUNCTION, YourClass:staticFunction); |      curl_easy_setopt(hcurl, CURLOPT_WRITEFUNCTION, YourClass:staticFunction); | ||||||
|      curl_easy_setopt(hcurl, CURLOPT_WRITEDATA, this); |      curl_easy_setopt(hcurl, CURLOPT_WRITEDATA, this); | ||||||
|  |  | ||||||
|  |   5.15 How do I get an FTP directory listing?  | ||||||
|  |  | ||||||
|  |   If you end the FTP URL you request with a slash, libcurl will provide you | ||||||
|  |   with a directory listing of that given directory. You can also set | ||||||
|  |   CURLOPT_CUSTOMREQUEST to alter what exact listing command libcurl would use | ||||||
|  |   to list the files. | ||||||
|  |  | ||||||
|  |   The follow-up question that tend to follow the previous one, is how a | ||||||
|  |   program is supposed to parse the directory listing. How does it know what's | ||||||
|  |   a file and what's a dir and what's a symlink etc. The harsh reality is that | ||||||
|  |   FTP provides no such fine and easy-to-parse output. The output format FTP | ||||||
|  |   servers respond to LIST commands are entirely at the server's own liking and | ||||||
|  |   the NLST output doesn't reveal any types and in many cases don't even | ||||||
|  |   include all the directory entries. Also, both LIST and NLST tend to hide | ||||||
|  |   unix-style hidden files (those that start with a dot) by default so you need | ||||||
|  |   to do "LIST -a" or similar to see them. | ||||||
|  |  | ||||||
|  |   The application thus needs to parse the LIST output. One such existing | ||||||
|  |   list parser is available at http://cr.yp.to/ftpparse.html | ||||||
|  |  | ||||||
|  |  | ||||||
| 6. License Issues | 6. License Issues | ||||||
|  |  | ||||||
|   Curl and libcurl are released under a MIT/X derivate license. The license is |   Curl and libcurl are released under a MIT/X derivate license. The license is | ||||||
|   | |||||||
							
								
								
									
										37
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -206,8 +206,8 @@ Win32 | |||||||
|    environment variables, for example: |    environment variables, for example: | ||||||
|  |  | ||||||
|      set ZLIB_PATH=c:\zlib-1.2.3 |      set ZLIB_PATH=c:\zlib-1.2.3 | ||||||
|      set OPENSSL_PATH=c:\openssl-0.9.8g |      set OPENSSL_PATH=c:\openssl-0.9.8k | ||||||
|      set LIBSSH2_PATH=c:\libssh2-0.17 |      set LIBSSH2_PATH=c:\libssh2-1.1 | ||||||
|  |  | ||||||
|    ATTENTION: if you want to build with libssh2 support you have to use latest |    ATTENTION: if you want to build with libssh2 support you have to use latest | ||||||
|    version 0.17 - previous versions will NOT work with 7.17.0 and later! |    version 0.17 - previous versions will NOT work with 7.17.0 and later! | ||||||
| @@ -275,7 +275,7 @@ Win32 | |||||||
|    Before running nmake define the OPENSSL_PATH environment variable with |    Before running nmake define the OPENSSL_PATH environment variable with | ||||||
|    the root/base directory of OpenSSL, for example: |    the root/base directory of OpenSSL, for example: | ||||||
|  |  | ||||||
|      set OPENSSL_PATH=c:\openssl-0.9.8g |      set OPENSSL_PATH=c:\openssl-0.9.8k | ||||||
|  |  | ||||||
|    Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root |    Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root | ||||||
|    directory.  'nmake vc-ssl' will create a libcurl static and dynamic |    directory.  'nmake vc-ssl' will create a libcurl static and dynamic | ||||||
| @@ -566,9 +566,8 @@ NetWare | |||||||
|    - optional OpenSSL sources (version 0.9.8 or later build with BSD sockets); |    - optional OpenSSL sources (version 0.9.8 or later build with BSD sockets); | ||||||
|      you can find precompiled packages at: |      you can find precompiled packages at: | ||||||
|      http://www.gknw.net/development/ossl/netware/ |      http://www.gknw.net/development/ossl/netware/ | ||||||
|      for CLIB-based builds OpenSSL needs to be patched to build with BSD |      for CLIB-based builds OpenSSL 0.9.8h or later is required  - earlier versions | ||||||
|      sockets (currently only a winsock-based CLIB build is supported): |      dont support buildunf with CLIB BSD sockets. | ||||||
|      http://www.gknw.net/development/ossl/netware/patches/v_0.9.8g/openssl-0.9.8g.diff |  | ||||||
|    - optional SSH2 sources (version 0.17 or later); |    - optional SSH2 sources (version 0.17 or later); | ||||||
|  |  | ||||||
|    Set a search path to your compiler, linker and tools; on Linux make |    Set a search path to your compiler, linker and tools; on Linux make | ||||||
| @@ -706,6 +705,32 @@ Symbian OS | |||||||
|    to obtain that first. |    to obtain that first. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | VxWorks | ||||||
|  | ======== | ||||||
|  |    Build for VxWorks is performed using cross compilation. | ||||||
|  |    That means you build on Windows machine using VxWorks tools and  | ||||||
|  |    run the built image on the VxWorks device. | ||||||
|  |     | ||||||
|  |    To build libcurl for VxWorks you need: | ||||||
|  |     | ||||||
|  |       - CYGWIN (free, http://cygwin.com/) | ||||||
|  |       - Wind River Workbench (commercial) | ||||||
|  |  | ||||||
|  |    If you have CYGWIN and Workbench installed on you machine | ||||||
|  |    follow after next steps: | ||||||
|  |  | ||||||
|  |     1. Open the Command Prompt window and change directory ('cd') | ||||||
|  |        to the libcurl 'lib' folder. | ||||||
|  |     2. Add CYGWIN 'bin' folder to the PATH environment variable. | ||||||
|  |        For example, type 'set PATH=C:/embedded/cygwin/bin;%PATH%'. | ||||||
|  |     3. Adjust environment variables defined in 'Environment' section | ||||||
|  |        of the Makefile.vxworks file to point to your software folders. | ||||||
|  |     4. Build the libcurl by typing 'make -f ./Makefile.vxworks' | ||||||
|  |     | ||||||
|  |    As a result the libcurl.a library should be created in the 'lib' folder.    | ||||||
|  |    To clean the build results type 'make -f ./Makefile.vxworks clean'. | ||||||
|  |     | ||||||
|  |  | ||||||
| CROSS COMPILE | CROSS COMPILE | ||||||
| ============= | ============= | ||||||
|    (This section was graciously brought to us by Jim Duey, with additions by |    (This section was graciously brought to us by Jim Duey, with additions by | ||||||
|   | |||||||
							
								
								
									
										65
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										65
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  |                                   _   _ ____  _ | ||||||
|  |                               ___| | | |  _ \| | | ||||||
|  |                              / __| | | | |_) | | | ||||||
|  |                             | (__| |_| |  _ <| |___ | ||||||
|  |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
|  |                                 How To Compile with CMake | ||||||
|  |  | ||||||
|  | Building with CMake | ||||||
|  | ========================== | ||||||
|  |    This document describes how to compile, build and install curl and libcurl | ||||||
|  |    from source code using the CMake build tool. To build with CMake, you will | ||||||
|  |    of course have to first install CMake.  The minimum required version of | ||||||
|  |    CMake is specifed in the file CMakeLists.txt found in the top of the curl | ||||||
|  |    source tree. Once the correct version of CMake is installed you can follow | ||||||
|  |    the instructions below for the platform you are building on. | ||||||
|  |    | ||||||
|  |    CMake builds can be configured either from the command line, or from one | ||||||
|  |    of CMake's GUI's.   | ||||||
|  |  | ||||||
|  | Command Line CMake | ||||||
|  | ================== | ||||||
|  |    A command line build of Curl is similar to the autotools build of Curl. It | ||||||
|  |    consists of the following steps after you have unpacked the source. | ||||||
|  |        # 1st create an out of source build tree parallel to the curl source | ||||||
|  |        # tree and change into that directory | ||||||
|  |        mkdir curl-build | ||||||
|  |        cd curl-build | ||||||
|  |        # now run CMake from the build tree, giving it the path to the top of | ||||||
|  |        # the Curl source tree.  CMake will pick a compiler for you. If you | ||||||
|  |        # want to specifiy the compile, you can set the CC environment | ||||||
|  |        # variable prior to running CMake. | ||||||
|  |        cmake ../curl   | ||||||
|  |        make | ||||||
|  |        # currently make test and make install are not implemented | ||||||
|  |        #make test | ||||||
|  |        #make install | ||||||
|  |  | ||||||
|  | ccmake | ||||||
|  | ========= | ||||||
|  |      CMake comes with a curses based interface called ccmake.  To run ccmake on | ||||||
|  |      a curl use the instructions for the command line cmake, but substitue | ||||||
|  |      ccmake ../curl for cmake ../curl.  This will bring up a curses interface | ||||||
|  |      with instructions on the bottom of the screen. You can press the "c" key | ||||||
|  |      to configure the project, and the "g" key to generate the project. After | ||||||
|  |      the project is generated, you can run make. | ||||||
|  |  | ||||||
|  | cmake-gui | ||||||
|  | ========= | ||||||
|  |      CMake also comes with a Qt based GUI called cmake-gui. To configure with | ||||||
|  |      cmake-gui, you run cmake-gui and follow these steps: | ||||||
|  |         1. Fill in the "Where is the source code" combo box with the path to | ||||||
|  |         the curl source tree. | ||||||
|  |         2. Fill in the "Where to build the binaries" combo box with the path | ||||||
|  |         to the directory for your build tree, ideally this should not be the | ||||||
|  |         same as the source tree, but a parallel diretory called curl-build or | ||||||
|  |         something similar.   | ||||||
|  |         3. Once the source and binary directories are specified, press the | ||||||
|  |         "Configure" button. | ||||||
|  |         4. Select the native build tool that you want to use.   | ||||||
|  |         5. At this point you can change any of the options presented in the | ||||||
|  |         GUI.  Once you have selected all the options you want, click the | ||||||
|  |         "Generate" button.  | ||||||
|  |         6. Run the native build tool that you used CMake to genratate. | ||||||
|  |          | ||||||
| @@ -103,9 +103,9 @@ Windows vs Unix | |||||||
|  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All |  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All | ||||||
|  conditionals that deal with features *should* instead be in the format |  conditionals that deal with features *should* instead be in the format | ||||||
|  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, |  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, | ||||||
|  we maintain two config-win32.h files (one in lib/ and one in src/) that are |  we maintain two curl_config-win32.h files (one in lib/ and one in src/) that | ||||||
|  supposed to look exactly as a config.h file would have looked like on a |  are supposed to look exactly as a curl_config.h file would have looked like on | ||||||
|  Windows machine! |  a Windows machine! | ||||||
|  |  | ||||||
|  Generally speaking: always remember that this will be compiled on dozens of |  Generally speaking: always remember that this will be compiled on dozens of | ||||||
|  operating systems. Don't walk on the edge. |  operating systems. Don't walk on the edge. | ||||||
|   | |||||||
| @@ -3,6 +3,30 @@ 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! | ||||||
|  |  | ||||||
|  | 72. "Pausing pipeline problems." | ||||||
|  |   http://curl.haxx.se/mail/lib-2009-07/0214.html | ||||||
|  |  | ||||||
|  | 71. TFTP block size / better integration in transfer | ||||||
|  |   http://curl.haxx.se/mail/lib-2009-08/0028.html | ||||||
|  |  | ||||||
|  | 70. Problem re-using easy handle after call to curl_multi_remove_handle | ||||||
|  |   http://curl.haxx.se/mail/lib-2009-07/0249.html | ||||||
|  |      | ||||||
|  | 69. debugging a crash in Curl_pgrsTime/checkPendPipeline? | ||||||
|  |   http://curl.haxx.se/mail/lib-2009-08/0066.html | ||||||
|  |  | ||||||
|  | 68. "More questions about ares behavior". | ||||||
|  |   http://curl.haxx.se/mail/lib-2009-08/0012.html | ||||||
|  |  | ||||||
|  | 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 | ||||||
|  |   string the app provides. There are several browsers that already do this | ||||||
|  |   encoding. The key seems to be the updated draft to RFC2231: | ||||||
|  |   http://tools.ietf.org/html/draft-reschke-rfc2231-in-http-02 | ||||||
|  |  | ||||||
|  | 66. When using telnet, the time limitation options don't work. | ||||||
|  |   http://curl.haxx.se/bug/view.cgi?id=2818950 | ||||||
|  |  | ||||||
| 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 | ||||||
|   for the data transfer isn't more or less instant as the code does not |   for the data transfer isn't more or less instant as the code does not | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								docs/README.cmake
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										16
									
								
								docs/README.cmake
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  |                                   _   _ ____  _      | ||||||
|  |                               ___| | | |  _ \| |     | ||||||
|  |                              / __| | | | |_) | |     | ||||||
|  |                             | (__| |_| |  _ <| |___  | ||||||
|  |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
|  | README.cmake | ||||||
|  |   Read the README file first. | ||||||
|  |  | ||||||
|  |   Curl contains CMake build files that provide a way to build Curl with the | ||||||
|  |   CMake build tool (www.cmake.org). CMake is a cross platform meta build tool | ||||||
|  |   that generates native makefiles and IDE project files. The CMake build | ||||||
|  |   system can be used to build Curl on any of its supported platforms.  | ||||||
|  |  | ||||||
|  |   Read the INSTALL.cmake file for instructions on how to compile curl with | ||||||
|  |   CMake.   | ||||||
							
								
								
									
										16
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -33,6 +33,7 @@ Andi Jahja | |||||||
| Andre Guibert de Bruet | Andre Guibert de Bruet | ||||||
| Andreas Damm | Andreas Damm | ||||||
| Andreas Faerber | Andreas Faerber | ||||||
|  | Andreas Farber | ||||||
| Andreas Ntaflos | Andreas Ntaflos | ||||||
| Andreas Olsson | Andreas Olsson | ||||||
| Andreas Rieke | Andreas Rieke | ||||||
| @@ -63,6 +64,7 @@ Ates Goral | |||||||
| Augustus Saunders | Augustus Saunders | ||||||
| Avery Fay | Avery Fay | ||||||
| Axel Tillequin | Axel Tillequin | ||||||
|  | Balint Szilakszi | ||||||
| Bart Whiteley | Bart Whiteley | ||||||
| Bas Mevissen | Bas Mevissen | ||||||
| Ben Greear | Ben Greear | ||||||
| @@ -71,6 +73,7 @@ Ben Van Hof | |||||||
| Benjamin Gerard | Benjamin Gerard | ||||||
| Bernard Leak | Bernard Leak | ||||||
| Bertrand Demiddelaer | Bertrand Demiddelaer | ||||||
|  | Bill Egert | ||||||
| Bjorn Reese | Bjorn Reese | ||||||
| Bj<EFBFBD>rn Stenberg | Bj<EFBFBD>rn Stenberg | ||||||
| Bob Schader | Bob Schader | ||||||
| @@ -94,6 +97,7 @@ Chad Monroe | |||||||
| Chih-Chung Chang | Chih-Chung Chang | ||||||
| Chris "Bob Bob" | Chris "Bob Bob" | ||||||
| Chris Combes | Chris Combes | ||||||
|  | Chris Deidun | ||||||
| Chris Flerackers | Chris Flerackers | ||||||
| Chris Gaukroger | Chris Gaukroger | ||||||
| Chris Maltby | Chris Maltby | ||||||
| @@ -188,6 +192,7 @@ Dustin Boswell | |||||||
| Dylan Ellicott | Dylan Ellicott | ||||||
| Dylan Salisbury | Dylan Salisbury | ||||||
| Early Ehlinger | Early Ehlinger | ||||||
|  | Ebenezer Ikonne | ||||||
| Edin Kadribasic | Edin Kadribasic | ||||||
| Eduard Bloch | Eduard Bloch | ||||||
| Eetu Ojanen | Eetu Ojanen | ||||||
| @@ -322,6 +327,7 @@ Jes Badwal | |||||||
| Jesper Jensen | Jesper Jensen | ||||||
| Jesse Noller | Jesse Noller | ||||||
| Jim Drash | Jim Drash | ||||||
|  | Jim Freeman | ||||||
| Jim Meyering | Jim Meyering | ||||||
| Jocelyn Jaubert | Jocelyn Jaubert | ||||||
| Joe Halpin | Joe Halpin | ||||||
| @@ -397,9 +403,11 @@ Lars J. Aas | |||||||
| Lars Nilsson | Lars Nilsson | ||||||
| Lars Torben Wilson | Lars Torben Wilson | ||||||
| Lau Hang Kin | Lau Hang Kin | ||||||
|  | Laurent Rabret | ||||||
| Legoff Vincent | Legoff Vincent | ||||||
| Lehel Bernadt | Lehel Bernadt | ||||||
| Len Krause | Len Krause | ||||||
|  | Lenaic Lefever | ||||||
| Lenny Rachitsky | Lenny Rachitsky | ||||||
| Liam Healy | Liam Healy | ||||||
| Linas Vepstas | Linas Vepstas | ||||||
| @@ -437,6 +445,7 @@ Martin C. Martin | |||||||
| Martin Drasar | Martin Drasar | ||||||
| Martin Hedenfalk | Martin Hedenfalk | ||||||
| Martin Skinner | Martin Skinner | ||||||
|  | Martin Storsjo | ||||||
| Marty Kuhrt | Marty Kuhrt | ||||||
| Maruko | Maruko | ||||||
| Massimiliano Ziccardi | Massimiliano Ziccardi | ||||||
| @@ -456,11 +465,13 @@ Mekonikum | |||||||
| Mettgut Jamalla | Mettgut Jamalla | ||||||
| Michael Benedict | Michael Benedict | ||||||
| Michael Calmer | Michael Calmer | ||||||
|  | Michael Cronenworth | ||||||
| Michael Curtis | Michael Curtis | ||||||
| Michael Goffioul | Michael Goffioul | ||||||
| Michael Jahn | Michael Jahn | ||||||
| Michael Jerris | Michael Jerris | ||||||
| Michael Mealling | Michael Mealling | ||||||
|  | Michael Smith | ||||||
| Michael Wallner | Michael Wallner | ||||||
| Michal Bonino | Michal Bonino | ||||||
| Michal Marek | Michal Marek | ||||||
| @@ -547,12 +558,14 @@ Philippe Hameau | |||||||
| Philippe Raoult | Philippe Raoult | ||||||
| Philippe Vaucher | Philippe Vaucher | ||||||
| Pierre | Pierre | ||||||
|  | Pierre Brico | ||||||
| Pooyan McSporran | Pooyan McSporran | ||||||
| Pramod Sharma | Pramod Sharma | ||||||
| Puneet Pawaia | Puneet Pawaia | ||||||
| Quagmire | Quagmire | ||||||
| Rafa Muyo | Rafa Muyo | ||||||
| Rafael Sagula | Rafael Sagula | ||||||
|  | Rainer Koenig | ||||||
| Ralf S. Engelschall | Ralf S. Engelschall | ||||||
| Ralph Beckmann | Ralph Beckmann | ||||||
| Ralph Mitchell | Ralph Mitchell | ||||||
| @@ -651,6 +664,7 @@ Steven Bazyl | |||||||
| Steven G. Johnson | Steven G. Johnson | ||||||
| Stoned Elipot | Stoned Elipot | ||||||
| Sven Neuhaus | Sven Neuhaus | ||||||
|  | Sven Wegener | ||||||
| S<EFBFBD>bastien Willemijns | S<EFBFBD>bastien Willemijns | ||||||
| T. Bharath | T. Bharath | ||||||
| T. Yamada | T. Yamada | ||||||
| @@ -662,6 +676,7 @@ Thomas Tonino | |||||||
| Tim Ansell | Tim Ansell | ||||||
| Tim Baker | Tim Baker | ||||||
| Tim Bartley | Tim Bartley | ||||||
|  | Tim Chen | ||||||
| Tim Costello | Tim Costello | ||||||
| Tim Sneddon | Tim Sneddon | ||||||
| Tobias Rundstr<74>m | Tobias Rundstr<74>m | ||||||
| @@ -682,6 +697,7 @@ Ton Voon | |||||||
| Toon Verwaest | Toon Verwaest | ||||||
| Tor Arntsen | Tor Arntsen | ||||||
| Torsten Foertsch | Torsten Foertsch | ||||||
|  | Toshio Kuratomi | ||||||
| Toshiyuki Maezawa | Toshiyuki Maezawa | ||||||
| Traian Nicolescu | Traian Nicolescu | ||||||
| Troels Walsted Hansen | Troels Walsted Hansen | ||||||
|   | |||||||
| @@ -480,7 +480,7 @@ waits for a reply from the server. | |||||||
| .IP "-F/--form <name=content>" | .IP "-F/--form <name=content>" | ||||||
| (HTTP) This lets curl emulate a filled-in form in which a user has pressed the | (HTTP) This lets curl emulate a filled-in form in which a user has pressed the | ||||||
| submit button. This causes curl to POST data using the Content-Type | submit button. This causes curl to POST data using the Content-Type | ||||||
| multipart/form-data according to RFC1867. This enables uploading of binary | multipart/form-data according to RFC2388. This enables uploading of binary | ||||||
| files etc. To force the 'content' part to be a file, prefix the file name | files etc. To force the 'content' part to be a file, prefix the file name | ||||||
| with an @ sign. To just get the content part from a file, prefix the file name | with an @ sign. To just get the content part from a file, prefix the file name | ||||||
| with the symbol <. The difference between @ and < is then that @ makes a file | with the symbol <. The difference between @ and < is then that @ makes a file | ||||||
| @@ -953,6 +953,12 @@ connection | |||||||
| If this option is used several times, the last one will be used. Disable the | If this option is used several times, the last one will be used. Disable the | ||||||
| use of PORT with \fI--ftp-pasv\fP. Disable the attempt to use the EPRT command | use of PORT with \fI--ftp-pasv\fP. Disable the attempt to use the EPRT command | ||||||
| instead of PORT by using \fI--disable-eprt\fP. EPRT is really PORT++. | instead of PORT by using \fI--disable-eprt\fP. EPRT is really PORT++. | ||||||
|  |  | ||||||
|  | Starting in 7.19.5, you can append \&":[start]-[end]\&" to the right of the | ||||||
|  | address, to tell curl what TCP port range to use. That means you specify a | ||||||
|  | port range, from a lower to a higher number. A single number works as well, | ||||||
|  | but do note that it increases the risk of failure since the port may not be | ||||||
|  | available. | ||||||
| .IP "-q" | .IP "-q" | ||||||
| If used as the first parameter on the command line, the \fIcurlrc\fP config | If used as the first parameter on the command line, the \fIcurlrc\fP config | ||||||
| file will not be read and used. See the \fI-K/--config\fP for details on the | file will not be read and used. See the \fI-K/--config\fP for details on the | ||||||
|   | |||||||
| @@ -13,7 +13,11 @@ | |||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
| #  include <io.h> | #  include <io.h> | ||||||
| #else | #else | ||||||
| #  include <stdint.h> | #  ifdef __VMS | ||||||
|  |      typedef int intptr_t; | ||||||
|  | #  else | ||||||
|  | #    include <stdint.h> | ||||||
|  | #  endif | ||||||
| #  include <unistd.h> | #  include <unistd.h> | ||||||
| #endif | #endif | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|   | |||||||
| @@ -29,11 +29,12 @@ void dump(const char *text, | |||||||
|     /* without the hex output, we can fit more on screen */ |     /* without the hex output, we can fit more on screen */ | ||||||
|     width = 0x40; |     width = 0x40; | ||||||
|  |  | ||||||
|   fprintf(stream, "%s, %zd bytes (0x%zx)\n", text, size, size); |   fprintf(stream, "%s, %010.10ld bytes (0x%08.8lx)\n", | ||||||
|  |           text, (long)size, (long)size); | ||||||
|  |  | ||||||
|   for(i=0; i<size; i+= width) { |   for(i=0; i<size; i+= width) { | ||||||
|  |  | ||||||
|     fprintf(stream, "%04zx: ", i); |     fprintf(stream, "%04.4lx: ", (long)i); | ||||||
|  |  | ||||||
|     if(!nohex) { |     if(!nohex) { | ||||||
|       /* hex not disabled, show it */ |       /* hex not disabled, show it */ | ||||||
|   | |||||||
| @@ -55,6 +55,7 @@ int main(int argc, char **argv) | |||||||
|   CURLcode res; |   CURLcode res; | ||||||
|   FILE *hd_src; |   FILE *hd_src; | ||||||
|   struct stat file_info; |   struct stat file_info; | ||||||
|  |   curl_off_t fsize; | ||||||
|  |  | ||||||
|   struct curl_slist *headerlist=NULL; |   struct curl_slist *headerlist=NULL; | ||||||
|   static const char buf_1 [] = "RNFR " UPLOAD_FILE_AS; |   static const char buf_1 [] = "RNFR " UPLOAD_FILE_AS; | ||||||
| @@ -65,7 +66,9 @@ int main(int argc, char **argv) | |||||||
|     printf("Couldnt open '%s': %s\n", LOCAL_FILE, strerror(errno)); |     printf("Couldnt open '%s': %s\n", LOCAL_FILE, strerror(errno)); | ||||||
|     return 1; |     return 1; | ||||||
|   } |   } | ||||||
|   printf("Local file size: %ld bytes.\n", file_info.st_size); |   fsize = (curl_off_t)file_info.st_size; | ||||||
|  |  | ||||||
|  |   printf("Local file size: %" CURL_FORMAT_CURL_OFF_T " bytes.\n", fsize); | ||||||
|  |  | ||||||
|   /* get a FILE * of the same file */ |   /* get a FILE * of the same file */ | ||||||
|   hd_src = fopen(LOCAL_FILE, "rb"); |   hd_src = fopen(LOCAL_FILE, "rb"); | ||||||
| @@ -100,7 +103,7 @@ int main(int argc, char **argv) | |||||||
|        curl_off_t. If you use CURLOPT_INFILESIZE (without _LARGE) you must |        curl_off_t. If you use CURLOPT_INFILESIZE (without _LARGE) you must | ||||||
|        make sure that to pass in a type 'long' argument. */ |        make sure that to pass in a type 'long' argument. */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, |     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, | ||||||
|                      (curl_off_t)file_info.st_size); |                      (curl_off_t)fsize); | ||||||
|  |  | ||||||
|     /* Now run off and do what you've been told! */ |     /* Now run off and do what you've been told! */ | ||||||
|     res = curl_easy_perform(curl); |     res = curl_easy_perform(curl); | ||||||
|   | |||||||
| @@ -38,11 +38,12 @@ void dump(const char *text, | |||||||
|     /* without the hex output, we can fit more on screen */ |     /* without the hex output, we can fit more on screen */ | ||||||
|     width = 0x40; |     width = 0x40; | ||||||
|  |  | ||||||
|   fprintf(stream, "%s, %zd bytes (0x%zx)\n", text, size, size); |   fprintf(stream, "%s, %010.10ld bytes (0x%08.8lx)\n", | ||||||
|  |           text, (long)size, (long)size); | ||||||
|  |  | ||||||
|   for(i=0; i<size; i+= width) { |   for(i=0; i<size; i+= width) { | ||||||
|  |  | ||||||
|     fprintf(stream, "%04zx: ", i); |     fprintf(stream, "%04.4lx: ", (long)i); | ||||||
|  |  | ||||||
|     if(!nohex) { |     if(!nohex) { | ||||||
|       /* hex not disabled, show it */ |       /* hex not disabled, show it */ | ||||||
| @@ -74,7 +75,7 @@ void dump(const char *text, | |||||||
|  |  | ||||||
| static | static | ||||||
| int my_trace(CURL *handle, curl_infotype type, | int my_trace(CURL *handle, curl_infotype type, | ||||||
|              char *data, size_t size, |              unsigned char *data, size_t size, | ||||||
|              void *userp) |              void *userp) | ||||||
| { | { | ||||||
|   const char *text; |   const char *text; | ||||||
|   | |||||||
| @@ -1,47 +1,47 @@ | |||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" *                                  _   _ ____  _ | .\" *                                  _   _ ____  _ | ||||||
| .\" *  Project                     ___| | | |  _ \| | | .\" *  Project                     ___| | | |  _ \| | | ||||||
| .\" *                             / __| | | | |_) | | | .\" *                             / __| | | | |_) | | | ||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2008, 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 http://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 | ||||||
| .\" * furnished to do so, under the terms of the COPYING file. | .\" * furnished to do so, under the terms of the COPYING file. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | .\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||||
| .\" * KIND, either express or implied. | .\" * KIND, either express or implied. | ||||||
| .\" * | .\" * | ||||||
| .\" * $Id$ | .\" * $Id$ | ||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_escape 3 "7 April 2006" "libcurl 7.15.4" "libcurl Manual" | .TH curl_easy_escape 3 "7 April 2006" "libcurl 7.15.4" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_escape - URL encodes the given string | curl_easy_escape - URL encodes the given string | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "char *curl_easy_escape( CURL *" curl ", char *" url ", int "length " );" | .BI "char *curl_easy_escape( CURL *" curl ", char *" url ", int "length " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function converts the given input string to an URL encoded string and | This function converts the given input string to an URL encoded string and | ||||||
| returns that as a new allocated string. All input characters that are not a-z, | returns that as a new allocated string. All input characters that are not a-z, | ||||||
| A-Z or 0-9 are converted to their "URL escaped" version (%NN where NN is a | A-Z or 0-9 are converted to their "URL escaped" version (%NN where NN is a | ||||||
| two-digit hexadecimal number). | two-digit hexadecimal number). | ||||||
|  |  | ||||||
| If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_escape(3)\fP | If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_escape(3)\fP | ||||||
| uses strlen() on the input \fBurl\fP to find out the size. | uses strlen() on the input \fBurl\fP to find out the size. | ||||||
|  |  | ||||||
| You must \fIcurl_free(3)\fP the returned string when you're done with it. | You must \fIcurl_free(3)\fP the returned string when you're done with it. | ||||||
| .SH AVAILABILITY | .SH AVAILABILITY | ||||||
| Added in 7.15.4 and replaces the old \fIcurl_escape(3)\fP function. | Added in 7.15.4 and replaces the old \fIcurl_escape(3)\fP function. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string or NULL if it failed. | A pointer to a zero terminated string or NULL if it failed. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl_easy_unescape "(3), " curl_free "(3), " RFC 2396 | .BR curl_easy_unescape "(3), " curl_free "(3), " RFC 2396 | ||||||
|   | |||||||
| @@ -159,7 +159,8 @@ Pass a pointer to a long to receive a bitmask indicating the authentication | |||||||
| method(s) available for your proxy authentication.  (Added in 7.10.8) | method(s) available for your proxy authentication.  (Added in 7.10.8) | ||||||
| .IP CURLINFO_OS_ERRNO | .IP CURLINFO_OS_ERRNO | ||||||
| Pass a pointer to a long to receive the errno variable from a connect failure. | Pass a pointer to a long to receive the errno variable from a connect failure. | ||||||
| (Added in 7.12.2) | Note that the value is only set on failure, it is not reset upon a | ||||||
|  | successfull operation.  (Added in 7.12.2) | ||||||
| .IP CURLINFO_NUM_CONNECTS | .IP CURLINFO_NUM_CONNECTS | ||||||
| Pass a pointer to a long to receive how many new connections libcurl had to | Pass a pointer to a long to receive how many new connections libcurl had to | ||||||
| create to achieve the previous transfer (only the successful connects are | create to achieve the previous transfer (only the successful connects are | ||||||
|   | |||||||
| @@ -282,6 +282,13 @@ NULL, the function used to accept response data will be used instead. That is, | |||||||
| it will be the function specified with \fICURLOPT_WRITEFUNCTION\fP, or if it | it will be the function specified with \fICURLOPT_WRITEFUNCTION\fP, or if it | ||||||
| is not specified or NULL - the default, stream-writing function. | is not specified or NULL - the default, stream-writing function. | ||||||
|  |  | ||||||
|  | It's important to note that the callback will be invoked for the headers of | ||||||
|  | all responses received after initiating a request and not just the final | ||||||
|  | response. This includes all responses which occur during authentication | ||||||
|  | negotiation. If you need to operate on only the headers from the final | ||||||
|  | response, you will need to collect headers in the callback yourself and use | ||||||
|  | HTTP status lines, for example, to delimit response boundaries. | ||||||
|  |  | ||||||
| Since 7.14.1: When a server sends a chunked encoded transfer, it may contain a | Since 7.14.1: When a server sends a chunked encoded transfer, it may contain a | ||||||
| trailer. That trailer is identical to a HTTP header and if such a trailer is | trailer. That trailer is identical to a HTTP header and if such a trailer is | ||||||
| received it is passed to the application using this callback as well. There | received it is passed to the application using this callback as well. There | ||||||
| @@ -863,7 +870,7 @@ data using the read callback! | |||||||
| Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||||
| You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | ||||||
|  |  | ||||||
| To make multipart/formdata posts (aka rfc1867-posts), check out the | To make multipart/formdata posts (aka RFC2388-posts), check out the | ||||||
| \fICURLOPT_HTTPPOST\fP option. | \fICURLOPT_HTTPPOST\fP option. | ||||||
| .IP CURLOPT_POSTFIELDSIZE | .IP CURLOPT_POSTFIELDSIZE | ||||||
| If you want to post data to the server without letting libcurl do a strlen() | If you want to post data to the server without letting libcurl do a strlen() | ||||||
| @@ -1063,6 +1070,23 @@ be a plain IP address, a host name, a network interface name (under Unix) or | |||||||
| just a '-' symbol to let the library use your system's default IP | just a '-' symbol to let the library use your system's default IP | ||||||
| address. Default FTP operations are passive, and thus won't use PORT. | address. Default FTP operations are passive, and thus won't use PORT. | ||||||
|  |  | ||||||
|  | The address can be followed by a ':' to specify a port, optionally followed by | ||||||
|  | a '-' to specify a port range.  If the port specified is 0, the operating | ||||||
|  | system will pick a free port.  If a range is provided and all ports in the | ||||||
|  | range are not available, libcurl will report CURLE_FTP_PORT_FAILED for the | ||||||
|  | handle.  Invalid port/range settings are ignored.  IPv6 addresses followed by | ||||||
|  | a port or portrange have to be in brackets.  IPv6 addresses without port/range | ||||||
|  | specifier can be in brackets.  (added in 7.19.5) | ||||||
|  |  | ||||||
|  | Examples with specified ports: | ||||||
|  |  | ||||||
|  | .nf | ||||||
|  |   eth0:0 | ||||||
|  |   192.168.1.2:32000-33000 | ||||||
|  |   curl.se:32123 | ||||||
|  |   [::1]:1234-4567 | ||||||
|  | .fi | ||||||
|  |  | ||||||
| You disable PORT again and go back to using the passive version by setting | You disable PORT again and go back to using the passive version by setting | ||||||
| this option to NULL. | this option to NULL. | ||||||
| .IP CURLOPT_QUOTE | .IP CURLOPT_QUOTE | ||||||
| @@ -1719,6 +1743,44 @@ Pass a char * pointing to a file name for your private key. If not used, | |||||||
| libcurl defaults to using \fB~/.ssh/id_dsa\fP. | libcurl defaults to using \fB~/.ssh/id_dsa\fP. | ||||||
| If the file is password-protected, set the password with \fICURLOPT_KEYPASSWD\fP. | If the file is password-protected, set the password with \fICURLOPT_KEYPASSWD\fP. | ||||||
| (Added in 7.16.1) | (Added in 7.16.1) | ||||||
|  | .IP CURLOPT_SSH_KNOWNHOSTS | ||||||
|  | Pass a pointer to a zero terminated string holding the file name of the | ||||||
|  | known_host file to use.  The known_hosts file should use the OpenSSH file | ||||||
|  | format as supported by libssh2. If this file is specified, libcurl will only | ||||||
|  | accept connections with hosts that are known and present in that file, with a | ||||||
|  | matching public key. Use \fICURLOPT_SSH_KEYFUNCTION\fP to alter the default | ||||||
|  | behavior on host and key (mis)matching. (Added in 7.19.6) | ||||||
|  | .IP CURLOPT_SSH_KEYFUNCTION | ||||||
|  | Pass a pointer to a curl_sshkeycallback function. It gets called when the | ||||||
|  | known_host matching has been done, to allow the application to act and decide | ||||||
|  | for libcurl how to proceed. It gets passed the CURL handle, the key from the | ||||||
|  | known_hosts file, the key from the remote site, info from libcurl on the | ||||||
|  | matching status and a custom pointer (set with \fICURLOPT_SSH_KEYDATA\fP). It | ||||||
|  | MUST return one of the following return codes to tell libcurl how to act: | ||||||
|  | .RS | ||||||
|  | .IP CURLKHSTAT_FINE_ADD_TO_FILE | ||||||
|  | The host+key is accepted and libcurl will append it to the known_hosts file | ||||||
|  | before continuing with the connection. This will also add the host+key combo | ||||||
|  | to the known_host pool kept in memory if it wasn't already present there. Note | ||||||
|  | that the adding of data to the file is done by completely replacing the file | ||||||
|  | with a new copy, so the permissions of the file must allow this. | ||||||
|  | .IP CURLKHSTAT_FINE | ||||||
|  | The host+key is accepted libcurl will continue with the connection. This will | ||||||
|  | also add the host+key combo to the known_host pool kept in memory if it wasn't | ||||||
|  | already present there. | ||||||
|  | .IP CURLKHSTAT_REJECT | ||||||
|  | The host+key is rejected. libcurl will deny the connection to continue and it | ||||||
|  | will be closed. | ||||||
|  | .IP CURLKHSTAT_DEFER | ||||||
|  | The host+key is rejected, but the SSH connection is asked to be kept alive. | ||||||
|  | This feature could be used when the app wants to somehow return back and act | ||||||
|  | on the host+key situation and then retry without needing the overhead of | ||||||
|  | setting it up from scratch again. | ||||||
|  | .RE | ||||||
|  |  (Added in 7.19.6) | ||||||
|  | .IP CURLOPT_SSH_KEYDATA | ||||||
|  | Pass a void * as parameter. This pointer will be passed along verbatim to the | ||||||
|  | callback set with \fICURLOPT_SSH_KEYFUNCTION\fP. (Added in 7.19.6) | ||||||
| .SH OTHER OPTIONS | .SH OTHER OPTIONS | ||||||
| .IP CURLOPT_PRIVATE | .IP CURLOPT_PRIVATE | ||||||
| Pass a void * as parameter, pointing to data that should be associated with | Pass a void * as parameter, pointing to data that should be associated with | ||||||
|   | |||||||
| @@ -1,52 +1,52 @@ | |||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" *                                  _   _ ____  _ | .\" *                                  _   _ ____  _ | ||||||
| .\" *  Project                     ___| | | |  _ \| | | .\" *  Project                     ___| | | |  _ \| | | ||||||
| .\" *                             / __| | | | |_) | | | .\" *                             / __| | | | |_) | | | ||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2008, 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 http://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 | ||||||
| .\" * furnished to do so, under the terms of the COPYING file. | .\" * furnished to do so, under the terms of the COPYING file. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | .\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||||
| .\" * KIND, either express or implied. | .\" * KIND, either express or implied. | ||||||
| .\" * | .\" * | ||||||
| .\" * $Id$ | .\" * $Id$ | ||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_unescape 3 "7 April 2006" "libcurl 7.15.4" "libcurl Manual" | .TH curl_easy_unescape 3 "7 April 2006" "libcurl 7.15.4" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_unescape - URL decodes the given string | curl_easy_unescape - URL decodes the given string | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "char *curl_easy_unescape( CURL *" curl ", char *" url ", int "inlength | .BI "char *curl_easy_unescape( CURL *" curl ", char *" url ", int "inlength | ||||||
| .BI ", int *" outlength " );" | .BI ", int *" outlength " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function converts the given URL encoded input string to a "plain string" | This function converts the given URL encoded input string to a "plain string" | ||||||
| and returns that in an allocated memory area. All input characters that are | and returns that in an allocated memory area. All input characters that are | ||||||
| URL encoded (%XX where XX is a two-digit hexadecimal number) are converted to | URL encoded (%XX where XX is a two-digit hexadecimal number) are converted to | ||||||
| their binary versions. | their binary versions. | ||||||
|  |  | ||||||
| If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_unescape(3)\fP | If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_unescape(3)\fP | ||||||
| will use strlen() on the input \fIurl\fP string to find out the size. | will use strlen() on the input \fIurl\fP string to find out the size. | ||||||
|  |  | ||||||
| If \fBoutlength\fP is non-NULL, the function will write the length of the | If \fBoutlength\fP is non-NULL, the function will write the length of the | ||||||
| returned string in the integer it points to. This allows an escaped string | returned string in the integer it points to. This allows an escaped string | ||||||
| containing %00 to still get used properly after unescaping. | containing %00 to still get used properly after unescaping. | ||||||
|  |  | ||||||
| You must \fIcurl_free(3)\fP the returned string when you're done with it. | You must \fIcurl_free(3)\fP the returned string when you're done with it. | ||||||
| .SH AVAILABILITY | .SH AVAILABILITY | ||||||
| Added in 7.15.4 and replaces the old \fIcurl_unescape(3)\fP function. | Added in 7.15.4 and replaces the old \fIcurl_unescape(3)\fP function. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string or NULL if it failed. | A pointer to a zero terminated string or NULL if it failed. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .I curl_easy_escape(3), curl_free(3), RFC 2396 | .I curl_easy_escape(3), curl_free(3), RFC 2396 | ||||||
|   | |||||||
| @@ -1,31 +1,31 @@ | |||||||
| .\" You can view this file with: | .\" You can view this file with: | ||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_escape 3 "6 March 2002" "libcurl 7.9" "libcurl Manual" | .TH curl_escape 3 "6 March 2002" "libcurl 7.9" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_escape - URL encodes the given string | curl_escape - URL encodes the given string | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "char *curl_escape( char *" url ", int "length " );" | .BI "char *curl_escape( char *" url ", int "length " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| Obsolete function. Use \fIcurl_easy_escape(3)\fP instead! | Obsolete function. Use \fIcurl_easy_escape(3)\fP instead! | ||||||
|  |  | ||||||
| This function will convert the given input string to an URL encoded string and | This function will convert the given input string to an URL encoded string and | ||||||
| return that as a new allocated string. All input characters that are not a-z, | return that as a new allocated string. All input characters that are not a-z, | ||||||
| A-Z or 0-9 will be converted to their "URL escaped" version (%NN where NN is a | A-Z or 0-9 will be converted to their "URL escaped" version (%NN where NN is a | ||||||
| two-digit hexadecimal number). | two-digit hexadecimal number). | ||||||
|  |  | ||||||
| If the 'length' argument is set to 0, curl_escape() will use strlen() on the | If the 'length' argument is set to 0, curl_escape() will use strlen() on the | ||||||
| input 'url' string to find out the size. | input 'url' string to find out the size. | ||||||
|  |  | ||||||
| You must curl_free() the returned string when you're done with it. | You must curl_free() the returned string when you're done with it. | ||||||
| .SH AVAILABILITY | .SH AVAILABILITY | ||||||
| Since 7.15.4, \fIcurl_easy_escape(3)\fP should be used. This function will | Since 7.15.4, \fIcurl_easy_escape(3)\fP should be used. This function will | ||||||
| be removed in a future release. | be removed in a future release. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string or NULL if it failed. | A pointer to a zero terminated string or NULL if it failed. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl_unescape "(3), " curl_free "(3), " RFC 2396 | .BR curl_unescape "(3), " curl_free "(3), " RFC 2396 | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ curl_formadd - add a section to a multipart/formdata HTTP POST | |||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| curl_formadd() is used to append sections when building a multipart/formdata | curl_formadd() is used to append sections when building a multipart/formdata | ||||||
| HTTP POST (sometimes referred to as rfc1867-style posts). Append one section at | HTTP POST (sometimes referred to as RFC2388-style posts). Append one section at | ||||||
| a time until you've added all the sections you want included and then you pass | a time until you've added all the sections you want included and then you pass | ||||||
| the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. | the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. | ||||||
| \fIlastitem\fP is set after each call and on repeated invokes it should be | \fIlastitem\fP is set after each call and on repeated invokes it should be | ||||||
|   | |||||||
| @@ -1,31 +1,31 @@ | |||||||
| .\" You can view this file with: | .\" You can view this file with: | ||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | .TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_unescape - URL decodes the given string | curl_unescape - URL decodes the given string | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "char *curl_unescape( char *" url ", int "length " );" | .BI "char *curl_unescape( char *" url ", int "length " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| Obsolete function. Use \fIcurl_easy_unescape(3)\fP instead! | Obsolete function. Use \fIcurl_easy_unescape(3)\fP instead! | ||||||
|  |  | ||||||
| This function will convert the given URL encoded input string to a "plain | This function will convert the given URL encoded input string to a "plain | ||||||
| string" and return that as a new allocated string. All input characters that | string" and return that as a new allocated string. All input characters that | ||||||
| are URL encoded (%XX where XX is a two-digit hexadecimal number) will be | are URL encoded (%XX where XX is a two-digit hexadecimal number) will be | ||||||
| converted to their plain text versions. | converted to their plain text versions. | ||||||
|  |  | ||||||
| If the 'length' argument is set to 0, curl_unescape() will use strlen() on the | If the 'length' argument is set to 0, curl_unescape() will use strlen() on the | ||||||
| input 'url' string to find out the size. | input 'url' string to find out the size. | ||||||
|  |  | ||||||
| You must curl_free() the returned string when you're done with it. | You must curl_free() the returned string when you're done with it. | ||||||
| .SH AVAILABILITY | .SH AVAILABILITY | ||||||
| Since 7.15.4, \fIcurl_easy_unescape(3)\fP should be used. This function will | Since 7.15.4, \fIcurl_easy_unescape(3)\fP should be used. This function will | ||||||
| be removed in a future release. | be removed in a future release. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string or NULL if it failed. | A pointer to a zero terminated string or NULL if it failed. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .I curl_easy_escape(3), curl_easy_unescape(3), curl_free(3), RFC 2396 | .I curl_easy_escape(3), curl_easy_unescape(3), curl_free(3), RFC 2396 | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2009, 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 | ||||||
| @@ -21,7 +21,7 @@ | |||||||
| .\" * $Id$ | .\" * $Id$ | ||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" | .\" | ||||||
| .TH curl_version_info 3 "2 Nov 2006" "libcurl 7.16.1" "libcurl Manual" | .TH curl_version_info 3 "10 June 2009" "libcurl 7.19.6" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_version_info - returns run-time libcurl version info | curl_version_info - returns run-time libcurl version info | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -105,8 +105,10 @@ supports HTTP NTLM (added in 7.10.6) | |||||||
| .IP CURL_VERSION_GSSNEGOTIATE | .IP CURL_VERSION_GSSNEGOTIATE | ||||||
| supports HTTP GSS-Negotiate (added in 7.10.6) | supports HTTP GSS-Negotiate (added in 7.10.6) | ||||||
| .IP CURL_VERSION_DEBUG | .IP CURL_VERSION_DEBUG | ||||||
| libcurl was built with extra debug capabilities built-in. This is mainly of | libcurl was built with debug capabilities (added in 7.10.6) | ||||||
| interest for libcurl hackers. (added in 7.10.6) | .IP CURL_VERSION_CURLDEBUG | ||||||
|  | libcurl was built with memory tracking debug capabilities. This is mainly of | ||||||
|  | interest for libcurl hackers. (added in 7.19.6) | ||||||
| .IP CURL_VERSION_ASYNCHDNS | .IP CURL_VERSION_ASYNCHDNS | ||||||
| libcurl was built with support for asynchronous name lookups, which allows | libcurl was built with support for asynchronous name lookups, which allows | ||||||
| more exact timeouts (even on Windows) and less blocking when using the multi | more exact timeouts (even on Windows) and less blocking when using the multi | ||||||
|   | |||||||
| @@ -119,10 +119,10 @@ If you want to re-use an easy handle that was added to the multi handle for | |||||||
| transfer, you must first remove it from the multi stack and then re-add it | transfer, you must first remove it from the multi stack and then re-add it | ||||||
| again (possibly after having altered some options at your own choice). | again (possibly after having altered some options at your own choice). | ||||||
| .SH "MULTI_SOCKET" | .SH "MULTI_SOCKET" | ||||||
| Since 7.16.0, the \fIcurl_multi_socket(3)\fP function offers a way for | Since 7.16.0, the \fIcurl_multi_socket_action(3)\fP function offers a way for | ||||||
| applications to not only avoid being forced to use select(), but it also | applications to not only avoid being forced to use select(), but it also | ||||||
| offers a much more high-performance API that will make a significant difference | offers a much more high-performance API that will make a significant | ||||||
| for applications using large numbers of simultaneous connections. | difference for applications using large numbers of simultaneous connections. | ||||||
|  |  | ||||||
| \fIcurl_multi_socket_action(3)\fP is then used | \fIcurl_multi_socket_action(3)\fP is then used | ||||||
| instead of \fIcurl_multi_perform(3)\fP. | instead of \fIcurl_multi_perform(3)\fP. | ||||||
|   | |||||||
| @@ -502,13 +502,14 @@ then passing that list to libcurl. | |||||||
| While the simple examples above cover the majority of all cases where HTTP | While the simple examples above cover the majority of all cases where HTTP | ||||||
| POST operations are required, they don't do multi-part formposts. Multi-part | POST operations are required, they don't do multi-part formposts. Multi-part | ||||||
| formposts were introduced as a better way to post (possibly large) binary data | formposts were introduced as a better way to post (possibly large) binary data | ||||||
| and were first documented in the RFC1867. They're called multi-part because | and were first documented in the RFC1867 (updated in RFC2388). They're called | ||||||
| they're built by a chain of parts, each being a single unit. Each part has its | multi-part because they're built by a chain of parts, each part being a single | ||||||
| own name and contents. You can in fact create and post a multi-part formpost | unit of data. Each part has its own name and contents. You can in fact create | ||||||
| with the regular libcurl POST support described above, but that would require | and post a multi-part formpost with the regular libcurl POST support described | ||||||
| that you build a formpost yourself and provide to libcurl. To make that | above, but that would require that you build a formpost yourself and provide | ||||||
| easier, libcurl provides \fIcurl_formadd(3)\fP. Using this function, you add | to libcurl. To make that easier, libcurl provides \fIcurl_formadd(3)\fP. Using | ||||||
| parts to the form. When you're done adding parts, you post the whole form. | this function, you add parts to the form. When you're done adding parts, you | ||||||
|  | post the whole form. | ||||||
|  |  | ||||||
| The following example sets two simple text parts with plain textual contents, | The following example sets two simple text parts with plain textual contents, | ||||||
| and then a file with binary contents and uploads the whole thing. | and then a file with binary contents and uploads the whole thing. | ||||||
| @@ -754,7 +755,7 @@ to another language and execute that. | |||||||
|  |  | ||||||
| - Read the Javascript code and rewrite the same logic in another language. | - Read the Javascript code and rewrite the same logic in another language. | ||||||
|  |  | ||||||
| - Implement a Javascript interpreted, people have successfully used the | - Implement a Javascript interpreter; people have successfully used the | ||||||
| Mozilla Javascript engine in the past. | Mozilla Javascript engine in the past. | ||||||
|  |  | ||||||
| - Ask your admins to stop this, for a static proxy setup or similar. | - Ask your admins to stop this, for a static proxy setup or similar. | ||||||
|   | |||||||
| @@ -425,6 +425,7 @@ CURL_TIMECOND_IFUNMODSINCE      7.9.7 | |||||||
| CURL_TIMECOND_LASTMOD           7.9.7 | CURL_TIMECOND_LASTMOD           7.9.7 | ||||||
| CURL_VERSION_ASYNCHDNS          7.10.7 | CURL_VERSION_ASYNCHDNS          7.10.7 | ||||||
| CURL_VERSION_CONV               7.15.4 | CURL_VERSION_CONV               7.15.4 | ||||||
|  | CURL_VERSION_CURLDEBUG          7.19.6 | ||||||
| CURL_VERSION_DEBUG              7.10.6 | CURL_VERSION_DEBUG              7.10.6 | ||||||
| CURL_VERSION_GSSNEGOTIATE       7.10.6 | CURL_VERSION_GSSNEGOTIATE       7.10.6 | ||||||
| CURL_VERSION_IDN                7.12.0 | CURL_VERSION_IDN                7.12.0 | ||||||
|   | |||||||
| @@ -48,13 +48,8 @@ | |||||||
| #include <limits.h> | #include <limits.h> | ||||||
|  |  | ||||||
| /* The include stuff here below is mainly for time_t! */ | /* The include stuff here below is mainly for time_t! */ | ||||||
| #ifdef vms | #include <sys/types.h> | ||||||
| # include <types.h> | #include <time.h> | ||||||
| # include <time.h> |  | ||||||
| #else |  | ||||||
| # include <sys/types.h> |  | ||||||
| # include <time.h> |  | ||||||
| #endif /* defined (vms) */ |  | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) && \ | #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) && \ | ||||||
|   !defined(__CYGWIN__) || defined(__MINGW32__) |   !defined(__CYGWIN__) || defined(__MINGW32__) | ||||||
| @@ -70,14 +65,15 @@ | |||||||
|    libc5-based Linux systems. Only include it on system that are known to |    libc5-based Linux systems. Only include it on system that are known to | ||||||
|    require it! */ |    require it! */ | ||||||
| #if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \ | #if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \ | ||||||
|     defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) |     defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \ | ||||||
|  |     defined(ANDROID) | ||||||
| #include <sys/select.h> | #include <sys/select.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef _WIN32_WCE | #ifndef _WIN32_WCE | ||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
| #if !defined(WIN32) && !defined(__WATCOMC__) | #if !defined(WIN32) && !defined(__WATCOMC__) && !defined(__VXWORKS__) | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #endif | #endif | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| @@ -186,7 +182,7 @@ typedef size_t (*curl_write_callback)(char *buffer, | |||||||
|                                       size_t nitems, |                                       size_t nitems, | ||||||
|                                       void *outstream); |                                       void *outstream); | ||||||
|  |  | ||||||
| /* this is the return codes for the seek callbacks */ | /* These are the return codes for the seek callbacks */ | ||||||
| #define CURL_SEEKFUNC_OK       0 | #define CURL_SEEKFUNC_OK       0 | ||||||
| #define CURL_SEEKFUNC_FAIL     1 /* fail the entire transfer */ | #define CURL_SEEKFUNC_FAIL     1 /* fail the entire transfer */ | ||||||
| #define CURL_SEEKFUNC_CANTSEEK 2 /* tell libcurl seeking can't be done, so | #define CURL_SEEKFUNC_CANTSEEK 2 /* tell libcurl seeking can't be done, so | ||||||
| @@ -497,6 +493,45 @@ typedef enum { | |||||||
|  |  | ||||||
| #define CURL_ERROR_SIZE 256 | #define CURL_ERROR_SIZE 256 | ||||||
|  |  | ||||||
|  | struct curl_khkey { | ||||||
|  |   const char *key; /* points to a zero-terminated string encoded with base64 | ||||||
|  |                       if len is zero, otherwise to the "raw" data */ | ||||||
|  |   size_t len; | ||||||
|  |   enum type { | ||||||
|  |     CURLKHTYPE_UNKNOWN, | ||||||
|  |     CURLKHTYPE_RSA1, | ||||||
|  |     CURLKHTYPE_RSA, | ||||||
|  |     CURLKHTYPE_DSS | ||||||
|  |   } keytype; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* this is the set of return values expected from the curl_sshkeycallback | ||||||
|  |    callback */ | ||||||
|  | enum curl_khstat { | ||||||
|  |   CURLKHSTAT_FINE_ADD_TO_FILE, | ||||||
|  |   CURLKHSTAT_FINE, | ||||||
|  |   CURLKHSTAT_REJECT, /* reject the connection, return an error */ | ||||||
|  |   CURLKHSTAT_DEFER,  /* do not accept it, but we can't answer right now so | ||||||
|  |                         this causes a CURLE_DEFER error but otherwise the | ||||||
|  |                         connection will be left intact etc */ | ||||||
|  |   CURLKHSTAT_LAST    /* not for use, only a marker for last-in-list */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* this is the set of status codes pass in to the callback */ | ||||||
|  | enum curl_khmatch { | ||||||
|  |   CURLKHMATCH_OK,       /* match */ | ||||||
|  |   CURLKHMATCH_MISMATCH, /* host found, key mismatch! */ | ||||||
|  |   CURLKHMATCH_MISSING,  /* no matching host/key found */ | ||||||
|  |   CURLKHMATCH_LAST      /* not for use, only a marker for last-in-list */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | typedef int | ||||||
|  |   (*curl_sshkeycallback) (CURL *easy,     /* easy handle */ | ||||||
|  |                           const struct curl_khkey *knownkey, /* known */ | ||||||
|  |                           const struct curl_khkey *foundkey, /* found */ | ||||||
|  |                           enum curl_khmatch, /* libcurl's view on the keys */ | ||||||
|  |                           void *clientp); /* custom pointer passed from app */ | ||||||
|  |  | ||||||
| /* parameter for the CURLOPT_USE_SSL option */ | /* parameter for the CURLOPT_USE_SSL option */ | ||||||
| typedef enum { | typedef enum { | ||||||
|   CURLUSESSL_NONE,    /* do not attempt to use SSL */ |   CURLUSESSL_NONE,    /* do not attempt to use SSL */ | ||||||
| @@ -1201,7 +1236,7 @@ typedef enum { | |||||||
|   CINIT(TFTP_BLKSIZE, LONG, 178), |   CINIT(TFTP_BLKSIZE, LONG, 178), | ||||||
|  |  | ||||||
|   /* Socks Service */ |   /* Socks Service */ | ||||||
|   CINIT(SOCKS5_GSSAPI_SERVICE, LONG, 179), |   CINIT(SOCKS5_GSSAPI_SERVICE, OBJECTPOINT, 179), | ||||||
|  |  | ||||||
|   /* Socks Service */ |   /* Socks Service */ | ||||||
|   CINIT(SOCKS5_GSSAPI_NEC, LONG, 180), |   CINIT(SOCKS5_GSSAPI_NEC, LONG, 180), | ||||||
| @@ -1218,6 +1253,16 @@ typedef enum { | |||||||
|      to all protocols except FILE and SCP. */ |      to all protocols except FILE and SCP. */ | ||||||
|   CINIT(REDIR_PROTOCOLS, LONG, 182), |   CINIT(REDIR_PROTOCOLS, LONG, 182), | ||||||
|  |  | ||||||
|  |   /* set the SSH knownhost file name to use */ | ||||||
|  |   CINIT(SSH_KNOWNHOSTS, OBJECTPOINT, 183), | ||||||
|  |  | ||||||
|  |   /* set the SSH host key callback, must point to a curl_sshkeycallback | ||||||
|  |      function */ | ||||||
|  |   CINIT(SSH_KEYFUNCTION, FUNCTIONPOINT, 184), | ||||||
|  |  | ||||||
|  |   /* set the SSH host key callback custom pointer */ | ||||||
|  |   CINIT(SSH_KEYDATA, OBJECTPOINT, 185), | ||||||
|  |  | ||||||
|   CURLOPT_LASTENTRY /* the last unused */ |   CURLOPT_LASTENTRY /* the last unused */ | ||||||
| } CURLoption; | } CURLoption; | ||||||
|  |  | ||||||
| @@ -1516,7 +1561,7 @@ CURL_EXTERN void curl_free(void *p); | |||||||
|  * DESCRIPTION |  * DESCRIPTION | ||||||
|  * |  * | ||||||
|  * curl_global_init() should be invoked exactly once for each application that |  * curl_global_init() should be invoked exactly once for each application that | ||||||
|  * uses libcurl and before any call of other libcurl function. |  * uses libcurl and before any call of other libcurl functions. | ||||||
|  * |  * | ||||||
|  * This function is not thread-safe! |  * This function is not thread-safe! | ||||||
|  */ |  */ | ||||||
| @@ -1790,8 +1835,8 @@ typedef struct { | |||||||
| #define CURL_VERSION_LARGEFILE (1<<9)  /* supports files bigger than 2GB */ | #define CURL_VERSION_LARGEFILE (1<<9)  /* supports files bigger than 2GB */ | ||||||
| #define CURL_VERSION_IDN       (1<<10) /* International Domain Names support */ | #define CURL_VERSION_IDN       (1<<10) /* International Domain Names support */ | ||||||
| #define CURL_VERSION_SSPI      (1<<11) /* SSPI is supported */ | #define CURL_VERSION_SSPI      (1<<11) /* SSPI is supported */ | ||||||
| #define CURL_VERSION_CONV      (1<<12) /* character conversions are | #define CURL_VERSION_CONV      (1<<12) /* character conversions supported */ | ||||||
|                                           supported */ | #define CURL_VERSION_CURLDEBUG (1<<13) /* debug memory tracking supported */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_version_info() |  * NAME curl_version_info() | ||||||
|   | |||||||
| @@ -63,6 +63,15 @@ | |||||||
|    Error Compilation_aborted_CURL_SIZEOF_LONG_already_defined |    Error Compilation_aborted_CURL_SIZEOF_LONG_already_defined | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef CURL_TYPEOF_CURL_SOCKLEN_T | ||||||
|  | #  error "CURL_TYPEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" | ||||||
|  |    Error Compilation_aborted_CURL_TYPEOF_CURL_SOCKLEN_T_already_defined | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef CURL_SIZEOF_CURL_SOCKLEN_T | ||||||
|  | #  error "CURL_SIZEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" | ||||||
|  |    Error Compilation_aborted_CURL_SIZEOF_CURL_SOCKLEN_T_already_defined | ||||||
|  | #endif | ||||||
| #ifdef CURL_TYPEOF_CURL_OFF_T | #ifdef CURL_TYPEOF_CURL_OFF_T | ||||||
| #  error "CURL_TYPEOF_CURL_OFF_T shall not be defined except in curlbuild.h" | #  error "CURL_TYPEOF_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||||
|    Error Compilation_aborted_CURL_TYPEOF_CURL_OFF_T_already_defined |    Error Compilation_aborted_CURL_TYPEOF_CURL_OFF_T_already_defined | ||||||
| @@ -126,6 +135,21 @@ | |||||||
| /* The size of `long', as computed by sizeof. */ | /* The size of `long', as computed by sizeof. */ | ||||||
| #cmakedefine CURL_SIZEOF_LONG ${CURL_SIZEOF_LONG} | #cmakedefine CURL_SIZEOF_LONG ${CURL_SIZEOF_LONG} | ||||||
|  |  | ||||||
|  | /* Integral data type used for curl_socklen_t. */ | ||||||
|  | #cmakedefine CURL_TYPEOF_CURL_SOCKLEN_T ${CURL_TYPEOF_CURL_SOCKLEN_T} | ||||||
|  |  | ||||||
|  | /* on windows socklen_t is in here */ | ||||||
|  | #ifdef _WIN32 | ||||||
|  | #  include <winsock2.h> | ||||||
|  | #  include <ws2tcpip.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /* Data type definition of curl_socklen_t. */ | ||||||
|  | typedef CURL_TYPEOF_CURL_SOCKLEN_T curl_socklen_t; | ||||||
|  |  | ||||||
|  | /* The size of `curl_socklen_t', as computed by sizeof. */ | ||||||
|  | #cmakedefine CURL_SIZEOF_CURL_SOCKLEN_T ${CURL_SIZEOF_CURL_SOCKLEN_T} | ||||||
|  |  | ||||||
| /* Signed integral data type used for curl_off_t. */ | /* Signed integral data type used for curl_off_t. */ | ||||||
| #cmakedefine CURL_TYPEOF_CURL_OFF_T ${CURL_TYPEOF_CURL_OFF_T} | #cmakedefine CURL_TYPEOF_CURL_OFF_T ${CURL_TYPEOF_CURL_OFF_T} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,13 +31,13 @@ | |||||||
|  |  | ||||||
| /* This is the version number of the libcurl package from which this header | /* This is the version number of the libcurl package from which this header | ||||||
|    file origins: */ |    file origins: */ | ||||||
| #define LIBCURL_VERSION "7.19.5-CVS" | #define LIBCURL_VERSION "7.19.6-CVS" | ||||||
|  |  | ||||||
| /* The numeric version number is also available "in parts" by using these | /* The numeric version number is also available "in parts" by using these | ||||||
|    defines: */ |    defines: */ | ||||||
| #define LIBCURL_VERSION_MAJOR 7 | #define LIBCURL_VERSION_MAJOR 7 | ||||||
| #define LIBCURL_VERSION_MINOR 19 | #define LIBCURL_VERSION_MINOR 19 | ||||||
| #define LIBCURL_VERSION_PATCH 5 | #define LIBCURL_VERSION_PATCH 6 | ||||||
|  |  | ||||||
| /* This is the numeric version of the libcurl version number, meant for easier | /* This is the numeric version of the libcurl version number, meant for easier | ||||||
|    parsing and comparions by programs. The LIBCURL_VERSION_NUM define will |    parsing and comparions by programs. The LIBCURL_VERSION_NUM define will | ||||||
| @@ -54,7 +54,7 @@ | |||||||
|    and it is always a greater number in a more recent release. It makes |    and it is always a greater number in a more recent release. It makes | ||||||
|    comparisons with greater than and less than work. |    comparisons with greater than and less than work. | ||||||
| */ | */ | ||||||
| #define LIBCURL_VERSION_NUM 0x071305 | #define LIBCURL_VERSION_NUM 0x071306 | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * This is the date and time when the full source package was created. The |  * This is the date and time when the full source package was created. The | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2009, 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 | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ DLL-Release | |||||||
| LIB-Debug | LIB-Debug | ||||||
| LIB-Release | LIB-Release | ||||||
| Makefile | Makefile | ||||||
| config.h | curl_config.h | ||||||
| getdate.c | getdate.c | ||||||
| libcurl.dsp | libcurl.dsp | ||||||
| libcurl.vcproj | libcurl.vcproj | ||||||
|   | |||||||
| @@ -1,60 +1,60 @@ | |||||||
| SET(LIB_NAME libcurl) | set(LIB_NAME libcurl) | ||||||
|  |  | ||||||
| CONFIGURE_FILE(${CURL_SOURCE_DIR}/include/curl/curlbuild.h.cmake | configure_file(${CURL_SOURCE_DIR}/include/curl/curlbuild.h.cmake | ||||||
|   ${CURL_BINARY_DIR}/include/curl/curlbuild.h) |   ${CURL_BINARY_DIR}/include/curl/curlbuild.h) | ||||||
| CONFIGURE_FILE(config.h.cmake | configure_file(curl_config.h.cmake | ||||||
|   ${CMAKE_CURRENT_BINARY_DIR}/config.h) |   ${CMAKE_CURRENT_BINARY_DIR}/curl_config.h) | ||||||
|  |  | ||||||
|  | transform_makefile_inc("Makefile.inc" "${CMAKE_CURRENT_BINARY_DIR}/Makefile.inc.cmake") | ||||||
|  | include(${CMAKE_CURRENT_BINARY_DIR}/Makefile.inc.cmake) | ||||||
|  |  | ||||||
| TRANSFORM_MAKEFILE_INC("Makefile.inc" "${CMAKE_CURRENT_BINARY_DIR}/Makefile.inc.cmake") | list(APPEND HHEADERS | ||||||
| INCLUDE(${CMAKE_CURRENT_BINARY_DIR}/Makefile.inc.cmake) |   ${CMAKE_CURRENT_BINARY_DIR}/curl_config.h | ||||||
|  |   ${CURL_BINARY_DIR}/include/curl/curlbuild.h | ||||||
|  |   ) | ||||||
|  |  | ||||||
| LIST(APPEND HHEADERS | if(MSVC) | ||||||
| 	${CMAKE_CURRENT_BINARY_DIR}/config.h |   list(APPEND CSOURCES libcurl.rc) | ||||||
| 	${CURL_BINARY_DIR}/include/curl/curlbuild.h | endif() | ||||||
| ) |  | ||||||
|  |  | ||||||
| IF(MSVC) |  | ||||||
| 	LIST(APPEND CSOURCES libcurl.rc) |  | ||||||
| ENDIF() |  | ||||||
|  |  | ||||||
| # SET(CSOURCES | # SET(CSOURCES | ||||||
|   # #  memdebug.c -not used | # #  memdebug.c -not used | ||||||
|   # # nwlib.c - Not used | # # nwlib.c - Not used | ||||||
|   # # strtok.c - specify later | # # strtok.c - specify later | ||||||
|   # # strtoofft.c - specify later | # # strtoofft.c - specify later | ||||||
| # ) | # ) | ||||||
|  |  | ||||||
| # # if we have Kerberos 4, right now this is never on | # # if we have Kerberos 4, right now this is never on | ||||||
| # #OPTION(CURL_KRB4 "Use Kerberos 4" OFF) | # #OPTION(CURL_KRB4 "Use Kerberos 4" OFF) | ||||||
| # IF(CURL_KRB4) | # IF(CURL_KRB4) | ||||||
|   # SET(CSOURCES ${CSOURCES} | # SET(CSOURCES ${CSOURCES} | ||||||
|     # krb4.c | # krb4.c | ||||||
|     # security.c | # security.c | ||||||
|     # ) | # ) | ||||||
| # ENDIF(CURL_KRB4) | # ENDIF(CURL_KRB4) | ||||||
|  |  | ||||||
| # #OPTION(CURL_MALLOC_DEBUG "Debug mallocs in Curl" OFF) | # #OPTION(CURL_MALLOC_DEBUG "Debug mallocs in Curl" OFF) | ||||||
| # MARK_AS_ADVANCED(CURL_MALLOC_DEBUG) | # MARK_AS_ADVANCED(CURL_MALLOC_DEBUG) | ||||||
| # IF(CURL_MALLOC_DEBUG) | # IF(CURL_MALLOC_DEBUG) | ||||||
|   # SET(CSOURCES ${CSOURCES} | # SET(CSOURCES ${CSOURCES} | ||||||
|     # memdebug.c | # memdebug.c | ||||||
|     # ) | # ) | ||||||
| # ENDIF(CURL_MALLOC_DEBUG) | # ENDIF(CURL_MALLOC_DEBUG) | ||||||
|  |  | ||||||
| # # only build compat strtoofft if we need to | # # only build compat strtoofft if we need to | ||||||
| # IF(NOT HAVE_STRTOLL AND NOT HAVE__STRTOI64) | # IF(NOT HAVE_STRTOLL AND NOT HAVE__STRTOI64) | ||||||
|   # SET(CSOURCES ${CSOURCES} | # SET(CSOURCES ${CSOURCES} | ||||||
|     # strtoofft.c | # strtoofft.c | ||||||
|     # ) | # ) | ||||||
| # ENDIF(NOT HAVE_STRTOLL AND NOT HAVE__STRTOI64) | # ENDIF(NOT HAVE_STRTOLL AND NOT HAVE__STRTOI64) | ||||||
|  |  | ||||||
| IF(HAVE_FEATURES_H) | if(HAVE_FEATURES_H) | ||||||
|   SET_SOURCE_FILES_PROPERTIES( |   set_source_files_properties( | ||||||
|     cookie.c |     cookie.c | ||||||
|     easy.c |     easy.c | ||||||
|     formdata.c |     formdata.c | ||||||
|     getenv.c |     getenv.c | ||||||
|  |     nonblock.c | ||||||
|     hash.c |     hash.c | ||||||
|     http.c |     http.c | ||||||
|     if2ip.c  |     if2ip.c  | ||||||
| @@ -65,57 +65,60 @@ IF(HAVE_FEATURES_H) | |||||||
|     transfer.c |     transfer.c | ||||||
|     url.c |     url.c | ||||||
|     COMPILE_FLAGS -D_BSD_SOURCE) |     COMPILE_FLAGS -D_BSD_SOURCE) | ||||||
| ENDIF(HAVE_FEATURES_H) | endif(HAVE_FEATURES_H) | ||||||
|  |  | ||||||
|  |  | ||||||
| # The rest of the build | # The rest of the build | ||||||
|  |  | ||||||
| INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/../include) | include_directories(${CMAKE_CURRENT_BINARY_DIR}/../include) | ||||||
| INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/..) | include_directories(${CMAKE_CURRENT_SOURCE_DIR}/..) | ||||||
| INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/../include) | include_directories(${CMAKE_CURRENT_SOURCE_DIR}/../include) | ||||||
| INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/..) | include_directories(${CMAKE_CURRENT_BINARY_DIR}/..) | ||||||
| INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) | include_directories(${CMAKE_CURRENT_SOURCE_DIR}) | ||||||
| INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}) | include_directories(${CMAKE_CURRENT_BINARY_DIR}) | ||||||
|  | if(CURL_USE_ARES) | ||||||
|  |   include_directories(${CARES_INCLUDE_DIR}) | ||||||
|  | endif() | ||||||
|  |  | ||||||
| IF(CURL_STATICLIB) | if(CURL_STATICLIB) | ||||||
| 	# Static lib |   # Static lib | ||||||
| 	SET(CURL_USER_DEFINED_DYNAMIC_OR_STATIC STATIC) |   set(CURL_USER_DEFINED_DYNAMIC_OR_STATIC STATIC) | ||||||
| ELSE() | else() | ||||||
| 	# DLL / so dynamic lib |   # DLL / so dynamic lib | ||||||
| 	SET(CURL_USER_DEFINED_DYNAMIC_OR_STATIC SHARED) |   set(CURL_USER_DEFINED_DYNAMIC_OR_STATIC SHARED) | ||||||
| ENDIF() | endif() | ||||||
|  |  | ||||||
| ADD_LIBRARY( | add_library( | ||||||
| 	${LIB_NAME} |   ${LIB_NAME} | ||||||
| 	${CURL_USER_DEFINED_DYNAMIC_OR_STATIC} |   ${CURL_USER_DEFINED_DYNAMIC_OR_STATIC} | ||||||
| 	${HHEADERS} ${CSOURCES} |   ${HHEADERS} ${CSOURCES} | ||||||
| ) |   ) | ||||||
|  |  | ||||||
| TARGET_LINK_LIBRARIES(${LIB_NAME} ${CURL_LIBS}) | target_link_libraries(${LIB_NAME} ${CURL_LIBS}) | ||||||
|  |  | ||||||
| IF(WIN32) | if(WIN32) | ||||||
| 	ADD_DEFINITIONS( -D_USRDLL ) |   add_definitions( -D_USRDLL ) | ||||||
| ENDIF() | endif() | ||||||
|  |  | ||||||
| SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES COMPILE_DEFINITIONS BUILDING_LIBCURL) | set_target_properties(${LIB_NAME} PROPERTIES COMPILE_DEFINITIONS BUILDING_LIBCURL) | ||||||
|  |  | ||||||
| SETUP_CURL_DEPENDENCIES(${LIB_NAME}) | setup_curl_dependencies(${LIB_NAME}) | ||||||
|  |  | ||||||
| # Remove the "lib" prefix since the library is already named "libcurl". | # Remove the "lib" prefix since the library is already named "libcurl". | ||||||
| SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES PREFIX "") | set_target_properties(${LIB_NAME} PROPERTIES PREFIX "") | ||||||
| SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES IMPORT_PREFIX "") | set_target_properties(${LIB_NAME} PROPERTIES IMPORT_PREFIX "") | ||||||
|  |  | ||||||
| IF(MSVC) | if(MSVC) | ||||||
| 	IF(NOT BUILD_RELEASE_DEBUG_DIRS) |   if(NOT BUILD_RELEASE_DEBUG_DIRS) | ||||||
| 		# Ugly workaround to remove the "/debug" or "/release" in each output |     # Ugly workaround to remove the "/debug" or "/release" in each output | ||||||
| 		SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES PREFIX "../") |     set_target_properties(${LIB_NAME} PROPERTIES PREFIX "../") | ||||||
| 		SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES IMPORT_PREFIX "../") |     set_target_properties(${LIB_NAME} PROPERTIES IMPORT_PREFIX "../") | ||||||
| 	ENDIF() |   endif() | ||||||
| ENDIF() | endif() | ||||||
|  |  | ||||||
| IF(WIN32) | if(WIN32) | ||||||
| 	IF(NOT CURL_STATICLIB) |   if(NOT CURL_STATICLIB) | ||||||
| 		# Add "_imp" as a suffix before the extension to avoid conflicting with the statically linked "libcurl.lib" |     # Add "_imp" as a suffix before the extension to avoid conflicting with the statically linked "libcurl.lib" | ||||||
| 		SET_TARGET_PROPERTIES(${LIB_NAME} PROPERTIES IMPORT_SUFFIX "_imp.lib") |     set_target_properties(${LIB_NAME} PROPERTIES IMPORT_SUFFIX "_imp.lib") | ||||||
| 	ENDIF() |   endif() | ||||||
| ENDIF() | endif() | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ CC = wcc386 | |||||||
| CFLAGS = -3s -mf -d3 -hc -zff -zgf -zq -zm -zc -s -fr=con -w2 -fpi -oilrtfm -bt=nt & | CFLAGS = -3s -mf -d3 -hc -zff -zgf -zq -zm -zc -s -fr=con -w2 -fpi -oilrtfm -bt=nt & | ||||||
|          -bd -d+ -dWIN32 -dCURL_CA_BUNDLE=getenv("CURL_CA_BUNDLE")                 & |          -bd -d+ -dWIN32 -dCURL_CA_BUNDLE=getenv("CURL_CA_BUNDLE")                 & | ||||||
|          -dBUILDING_LIBCURL -dHAVE_SPNEGO=1 -dENABLE_IPV6                          & |          -dBUILDING_LIBCURL -dHAVE_SPNEGO=1 -dENABLE_IPV6                          & | ||||||
|          -dDEBUG=1 -dCURLDEBUG -d_WIN32_WINNT=0x0501 -dWINBERAPI=__declspec(cdecl) & |          -dDEBUG=1 -dDEBUGBUILD -d_WIN32_WINNT=0x0501 -dWINBERAPI=__declspec(cdecl) & | ||||||
|          -dWINLDAPAPI=__declspec(cdecl) -I. -I..\include |          -dWINLDAPAPI=__declspec(cdecl) -I. -I..\include | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -69,7 +69,7 @@ OBJS = $(OBJ_DIR)\base64.obj           $(OBJ_DIR)\connect.obj        & | |||||||
|        $(OBJ_DIR)\telnet.obj           $(OBJ_DIR)\tftp.obj           & |        $(OBJ_DIR)\telnet.obj           $(OBJ_DIR)\tftp.obj           & | ||||||
|        $(OBJ_DIR)\timeval.obj          $(OBJ_DIR)\transfer.obj       & |        $(OBJ_DIR)\timeval.obj          $(OBJ_DIR)\transfer.obj       & | ||||||
|        $(OBJ_DIR)\url.obj              $(OBJ_DIR)\version.obj        & |        $(OBJ_DIR)\url.obj              $(OBJ_DIR)\version.obj        & | ||||||
|        $(OBJ_DIR)\slist.obj |        $(OBJ_DIR)\slist.obj            $(OBJ_DIR)\nonblock.obj | ||||||
|  |  | ||||||
| # | # | ||||||
| # Use $(OBJS) as a template to generate $(OBJS_STAT) and $(OBJS_DYN). | # Use $(OBJS) as a template to generate $(OBJS_STAT) and $(OBJS_DYN). | ||||||
| @@ -107,7 +107,7 @@ vclean realclean: clean .SYMBOLIC | |||||||
|  |  | ||||||
| .ERASE | .ERASE | ||||||
| $(RESOURCE): libcurl.rc | $(RESOURCE): libcurl.rc | ||||||
|         wrc -dCURLDEBUG=1 -q -r -zm -I..\include -fo=$@ libcurl.rc |         wrc -dDEBUGBUILD=1 -q -r -zm -I..\include -fo=$@ libcurl.rc | ||||||
|  |  | ||||||
| .ERASE | .ERASE | ||||||
| .c{$(OBJ_BASE)\dyn}.obj: | .c{$(OBJ_BASE)\dyn}.obj: | ||||||
| @@ -525,6 +525,11 @@ $(OBJ_DIR)\nss.obj: nss.c setup.h config-win32.h ..\include\curl\curlbuild.h & | |||||||
|   url.h connect.h strequal.h select.h sslgen.h ..\include\curl\mprintf.h |   url.h connect.h strequal.h select.h sslgen.h ..\include\curl\mprintf.h | ||||||
| $(OBJ_DIR)\qssl.obj: qssl.c setup.h config-win32.h ..\include\curl\curlbuild.h & | $(OBJ_DIR)\qssl.obj: qssl.c setup.h config-win32.h ..\include\curl\curlbuild.h & | ||||||
|   ..\include\curl\curlrules.h setup_once.h |   ..\include\curl\curlrules.h setup_once.h | ||||||
|  | $(OBJ_DIR)\nonblock.obj: nonblock.c setup.h config-win32.h ..\include\curl\curlbuild.h & | ||||||
|  |   ..\include\curl\curlrules.h setup_once.h nonblock.h & | ||||||
|  |   ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||||
|  |   ..\include\curl\curlrules.h ..\include\curl\easy.h & | ||||||
|  |   ..\include\curl\multi.h ..\include\curl\curl.h | ||||||
| $(OBJ_DIR)\rawstr.obj: rawstr.c setup.h config-win32.h ..\include\curl\curlbuild.h & | $(OBJ_DIR)\rawstr.obj: rawstr.c setup.h config-win32.h ..\include\curl\curlbuild.h & | ||||||
|   ..\include\curl\curlrules.h setup_once.h rawstr.h & |   ..\include\curl\curlrules.h setup_once.h rawstr.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||||
|   | |||||||
| @@ -29,16 +29,16 @@ DOCS = README.encoding README.memoryleak README.ares README.curlx	\ | |||||||
|  README.hostip README.multi_socket README.httpauth README.pipelining    \ |  README.hostip README.multi_socket README.httpauth README.pipelining    \ | ||||||
|  README.NSS README.curl_off_t |  README.NSS README.curl_off_t | ||||||
|  |  | ||||||
| CMAKE_DIST = CMakeLists.txt config.h.cmake | CMAKE_DIST = CMakeLists.txt curl_config.h.cmake | ||||||
|  |  | ||||||
| EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos $(DSP) \ | EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos $(DSP) \ | ||||||
|  vc6libcurl.dsw config-win32.h config-win32ce.h config-riscos.h            \ |  vc6libcurl.dsw config-win32.h config-win32ce.h config-riscos.h            \ | ||||||
|  config-mac.h config.h.in makefile.dj config.dos libcurl.plist             \ |  config-mac.h curl_config.h.in makefile.dj config.dos libcurl.plist        \ | ||||||
|  libcurl.rc config-amigaos.h amigaos.c amigaos.h makefile.amiga		   \ |  libcurl.rc config-amigaos.h amigaos.c amigaos.h makefile.amiga		   \ | ||||||
|  Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot   \ |  Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot   \ | ||||||
|  config-win32ce.h config-os400.h setup-os400.h config-symbian.h		   \ |  config-win32ce.h config-os400.h setup-os400.h config-symbian.h		   \ | ||||||
|  Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl		   \ |  Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl		   \ | ||||||
|  firefox-db2pem.sh $(CMAKE_DIST) |  firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h Makefile.vxworks | ||||||
|  |  | ||||||
| CLEANFILES = $(DSP) $(VCPROJ) | CLEANFILES = $(DSP) $(VCPROJ) | ||||||
|  |  | ||||||
| @@ -52,17 +52,24 @@ LIBCURL_LIBS = @LIBCURL_LIBS@ | |||||||
| # | # | ||||||
| # $(top_builddir)/include is for libcurl's generated curl/curlbuild.h file | # $(top_builddir)/include is for libcurl's generated curl/curlbuild.h file | ||||||
| # $(top_srcdir)/include is for libcurl's external include files | # $(top_srcdir)/include is for libcurl's external include files | ||||||
| # $(top_builddir)/lib is for libcurl's generated lib/config.h file | # $(top_builddir)/lib is for libcurl's generated lib/curl_config.h file | ||||||
| # $(top_srcdir)/lib is for libcurl's lib/setup.h and other "private" files | # $(top_srcdir)/lib is for libcurl's lib/setup.h and other "private" files | ||||||
| # $(top_builddir)/ares is for in-tree c-ares's generated ares_build.h file | # $(top_builddir)/ares is for in-tree c-ares's generated ares_build.h file | ||||||
| # $(top_srcdir)/ares is for in-tree c-ares's external include files | # $(top_srcdir)/ares is for in-tree c-ares's external include files | ||||||
|  |  | ||||||
|  | if USE_EMBEDDED_ARES | ||||||
| INCLUDES = -I$(top_builddir)/include \ | INCLUDES = -I$(top_builddir)/include \ | ||||||
|            -I$(top_srcdir)/include   \ |            -I$(top_srcdir)/include   \ | ||||||
|            -I$(top_builddir)/lib     \ |            -I$(top_builddir)/lib     \ | ||||||
|            -I$(top_srcdir)/lib       \ |            -I$(top_srcdir)/lib       \ | ||||||
|            -I$(top_builddir)/ares    \ |            -I$(top_builddir)/ares    \ | ||||||
|            -I$(top_srcdir)/ares |            -I$(top_srcdir)/ares | ||||||
|  | else | ||||||
|  | INCLUDES = -I$(top_builddir)/include \ | ||||||
|  |            -I$(top_srcdir)/include   \ | ||||||
|  |            -I$(top_builddir)/lib     \ | ||||||
|  |            -I$(top_srcdir)/lib | ||||||
|  | endif | ||||||
|  |  | ||||||
| if SONAME_BUMP | if SONAME_BUMP | ||||||
| # | # | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c	\ | |||||||
|   hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c	\ |   hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c	\ | ||||||
|   inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c	\ |   inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c	\ | ||||||
|   strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c          \ |   strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c          \ | ||||||
|   socks_gssapi.c socks_sspi.c curl_sspi.c slist.c |   socks_gssapi.c socks_sspi.c curl_sspi.c slist.c nonblock.c | ||||||
|  |  | ||||||
| HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | ||||||
|   progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h	\ |   progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h	\ | ||||||
| @@ -21,4 +21,4 @@ HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | |||||||
|   strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h setup.h	\ |   strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h setup.h	\ | ||||||
|   transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h	\ |   transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h	\ | ||||||
|   tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h nssg.h	\ |   tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h nssg.h	\ | ||||||
|   curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h |   curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h nonblock.h | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ AR = ar | |||||||
| LDFLAGS = -s | LDFLAGS = -s | ||||||
| RANLIB = ranlib | RANLIB = ranlib | ||||||
| RC = windres | RC = windres | ||||||
| RCFLAGS = --include-dir=../include -DCURLDEBUG=0 -O COFF -i | RCFLAGS = --include-dir=../include -DDEBUGBUILD=0 -O COFF -i | ||||||
| RM = del /q /f > NUL 2>&1 | RM = del /q /f > NUL 2>&1 | ||||||
| STRIP = strip -g | STRIP = strip -g | ||||||
|  |  | ||||||
|   | |||||||
| @@ -241,7 +241,7 @@ nlm: prebuild $(TARGET).nlm | |||||||
|  |  | ||||||
| lib: prebuild $(TARGET).$(LIBEXT) | lib: prebuild $(TARGET).$(LIBEXT) | ||||||
|  |  | ||||||
| prebuild: $(OBJDIR) $(CURL_INC)/curl/curlbuild.h $(OBJDIR)/version.inc config.h | prebuild: $(OBJDIR) $(CURL_INC)/curl/curlbuild.h $(OBJDIR)/version.inc curl_config.h | ||||||
|  |  | ||||||
| $(OBJDIR)/%.o: %.c | $(OBJDIR)/%.o: %.c | ||||||
| #	@echo Compiling $< | #	@echo Compiling $< | ||||||
| @@ -263,7 +263,7 @@ ifdef WITH_SSL | |||||||
| endif | endif | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	-$(RM) config.h | 	-$(RM) curl_config.h | ||||||
| 	-$(RM) -r $(OBJDIR) | 	-$(RM) -r $(OBJDIR) | ||||||
|  |  | ||||||
| distclean: clean | distclean: clean | ||||||
| @@ -373,7 +373,7 @@ ifeq ($(findstring nlmconv,$(LD)),nlmconv) | |||||||
| 	@echo $(DL)output $(TARGET).nlm$(DL) >> $@ | 	@echo $(DL)output $(TARGET).nlm$(DL) >> $@ | ||||||
| endif | endif | ||||||
|  |  | ||||||
| config.h: Makefile.netware | curl_config.h: Makefile.netware | ||||||
| 	@echo Creating $@ | 	@echo Creating $@ | ||||||
| 	@echo $(DL)/* $@ for NetWare target.$(DL) > $@ | 	@echo $(DL)/* $@ for NetWare target.$(DL) > $@ | ||||||
| 	@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@ | 	@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@ | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ objs =	o.base64 o.connect o.cookie o.dict \ | |||||||
| 	o.security o.select o.sendf o.speedcheck o.ssluse \ | 	o.security o.select o.sendf o.speedcheck o.ssluse \ | ||||||
| 	o.strequal o.strtok o.telnet o.timeval \ | 	o.strequal o.strtok o.telnet o.timeval \ | ||||||
| 	o.transfer o.url o.version o.strtoofft o.sslgen o.gtls \ | 	o.transfer o.url o.version o.strtoofft o.sslgen o.gtls \ | ||||||
| 	o.rawstr o.curl_addrinfo o.slist | 	o.rawstr o.curl_addrinfo o.slist o.nonblock | ||||||
|  |  | ||||||
| # Compile options: | # Compile options: | ||||||
| linkopts	= -o libcurl | linkopts	= -o libcurl | ||||||
| @@ -135,6 +135,9 @@ o.sslgen:	c.sslgen | |||||||
| o.ssluse:	c.ssluse | o.ssluse:	c.ssluse | ||||||
| 		gcc $(compileropts) -c -o ssluse.o c.ssluse | 		gcc $(compileropts) -c -o ssluse.o c.ssluse | ||||||
|  |  | ||||||
|  | o.nonblock:	c.nonblock | ||||||
|  | 		gcc $(compileropts) -c -o nonblock.o c.nonblock | ||||||
|  |  | ||||||
| o.rawstr:	c.rawstr | o.rawstr:	c.rawstr | ||||||
| 		gcc $(compileropts) -c -o rawstr.o c.rawstr | 		gcc $(compileropts) -c -o rawstr.o c.rawstr | ||||||
|  |  | ||||||
|   | |||||||
| @@ -537,11 +537,11 @@ debug-dll\libcurl.res \ | |||||||
| debug-dll-ssl-dll\libcurl.res \ | debug-dll-ssl-dll\libcurl.res \ | ||||||
| debug-dll-zlib-dll\libcurl.res \ | debug-dll-zlib-dll\libcurl.res \ | ||||||
| debug-dll-ssl-dll-zlib-dll\libcurl.res: libcurl.rc | debug-dll-ssl-dll-zlib-dll\libcurl.res: libcurl.rc | ||||||
| 	rc /dCURLDEBUG=1 /Fo $@ libcurl.rc | 	rc /dDEBUGBUILD=1 /Fo $@ libcurl.rc | ||||||
|  |  | ||||||
| release-dll\libcurl.res \ | release-dll\libcurl.res \ | ||||||
| release-dll-ssl-dll\libcurl.res \ | release-dll-ssl-dll\libcurl.res \ | ||||||
| release-dll-zlib-dll\libcurl.res \ | release-dll-zlib-dll\libcurl.res \ | ||||||
| release-dll-ssl-dll-zlib-dll\libcurl.res: libcurl.rc | release-dll-ssl-dll-zlib-dll\libcurl.res: libcurl.rc | ||||||
| 	rc /dCURLDEBUG=0 /Fo $@ libcurl.rc | 	rc /dDEBUGBUILD=0 /Fo $@ libcurl.rc | ||||||
| !ENDIF  # End of case where a config was provided. | !ENDIF  # End of case where a config was provided. | ||||||
|   | |||||||
							
								
								
									
										178
									
								
								lib/Makefile.vxworks
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								lib/Makefile.vxworks
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,178 @@ | |||||||
|  | #***************************************************************************** | ||||||
|  | # | ||||||
|  | # $Id$ | ||||||
|  | # | ||||||
|  | #Filename   : Makefile.vxworks | ||||||
|  | #Description: makefile to be used in order to compile libcurl for VxWoorks 6.3. | ||||||
|  | # | ||||||
|  | #How to use: | ||||||
|  | #             1. Adjust environment variables at the file begining | ||||||
|  | #             2. Open the Command Prompt window and change directory ('cd') | ||||||
|  | #                into the 'lib' folder | ||||||
|  | #             3. Add <CYGWIN>/bin folder to the PATH environment variable | ||||||
|  | #                For example type 'set PATH=C:/embedded/cygwin/bin;%PATH%' | ||||||
|  | #             4. Build the library by typing 'make -f ./Makefile.vxworks' | ||||||
|  | #             As a result the libcurl.a should be created in the 'lib' folder. | ||||||
|  | #             To clean package use 'make -f ./Makefile.vxworks clean' | ||||||
|  | #Requirements: | ||||||
|  | #             1. WinXP machine | ||||||
|  | #             2. Full CYGWIN installation (open source) with GNU make version | ||||||
|  | #                v3.78 or higher | ||||||
|  | #             3. WindRiver Workbench with vxWorks 6.3 (commercial) | ||||||
|  | #***************************************************************************** | ||||||
|  |  | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  | # Environment | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | export WIND_HOME := C:/embedded/Workbench2.5.0.1 | ||||||
|  | export WIND_BASE := $(WIND_HOME)/vxworks-6.3 | ||||||
|  | export WIND_HOST_TYPE := x86-win32 | ||||||
|  |  | ||||||
|  | # BUILD_TYE:= <debug>|<release> (build with debugging info or optimized) | ||||||
|  | BUILD_TYPE := debug | ||||||
|  | USER_CFLAGS:= | ||||||
|  |  | ||||||
|  | # directories where to seek for includes and libraries | ||||||
|  | OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3/include | ||||||
|  | OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3 | ||||||
|  | ZLIB_INC    := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/zlib-1.2.3 | ||||||
|  | ZLIB_LIB    := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib | ||||||
|  | ARES_INC    := | ||||||
|  | ARES_LIB    := | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  | # Compiler  | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | CC := ccppc | ||||||
|  | AR := arppc | ||||||
|  | LINK := ccppc | ||||||
|  | CFLAGS := -D__GNUC__ -D__ppc__ -msoft-float -fno-builtin -mcpu=604 -mlongcall -DCPU=PPC604 -D_GNU_TOOL -Wall -W -Winline $(USER_CFLAGS) | ||||||
|  | LDFLAGS := -nostdlib -Wl,-i -Wl,-X  | ||||||
|  | INCLUDE_FLAG := -I | ||||||
|  | C_DEBUGFLAG := -g | ||||||
|  | C_OPTFLAG := -O2 | ||||||
|  | COMPILE_ONLY_FLAG := -c | ||||||
|  | OBJ_EXTENSION := .o | ||||||
|  | CC_OBJ_OUTPUT = -o $@ | ||||||
|  | ARFLAGS := -rc | ||||||
|  | LIBS_FLAG := -l | ||||||
|  | LIBS_DIRFLAG:= -L | ||||||
|  | LD_DEBUGFLAG := $(C_DEBUGFLAG) | ||||||
|  | EXECUTE_EXTENSION := .out | ||||||
|  | TOOL_CHAIN_BIN := $(WIND_HOME)/gnu/3.4.4-vxworks-6.3/$(WIND_HOST_TYPE)/bin/ | ||||||
|  |  | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | # Add -DINET6 if the OS kernel image was built with IPv6 support | ||||||
|  | # CFLAGS += -DINET6 | ||||||
|  |  | ||||||
|  | # Set up compiler and linker flags for debug or optimization | ||||||
|  | ifeq ($(BUILD_TYPE), debug) | ||||||
|  | CFLAGS += $(C_DEBUGFLAG) | ||||||
|  | LDFLAGS += $(LD_DEBUGFLAG) | ||||||
|  | else | ||||||
|  | CFLAGS += $(C_OPTFLAG) | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | # Main Makefile and possible sub-make files | ||||||
|  | MAKEFILES := Makefile.vxworks | ||||||
|  |  | ||||||
|  | # List of external include directories | ||||||
|  | #----- | ||||||
|  | # IMPORTANT: include OPENSSL directories before system | ||||||
|  | #            in order to prevent WindRiver OpenSSL to be used. | ||||||
|  | #----- | ||||||
|  | INCLUDE_DIRS := ../include $(OPENSSL_INC) $(ZLIB_INC) $(ARES_INC) $(WIND_BASE)/target/h $(WIND_BASE)/target/h/wrn/coreip | ||||||
|  |  | ||||||
|  | # List of external libraries and their directories | ||||||
|  | LIBS_LIST := . | ||||||
|  | LIB_DIRS  := . | ||||||
|  | ifneq ($(OPENSSL_LIB), ) | ||||||
|  | LIBS_LIST += crypto ssl | ||||||
|  | LIB_DIRS  += $(OPENSSL_LIB) | ||||||
|  | endif | ||||||
|  | ifneq ($(ZLIB_LIB), ) | ||||||
|  | LIBS_LIST += z | ||||||
|  | LIB_DIRS  += $(ZLIB_LIB) | ||||||
|  | endif | ||||||
|  | ifneq ($(ARES_LIB), ) | ||||||
|  | LIBS_LIST += ares | ||||||
|  | LIB_DIRS  += $(ARES_LIB) | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # Add include and library directories and libraries | ||||||
|  | CFLAGS += $(INCLUDE_DIRS:%=$(INCLUDE_FLAG)%) | ||||||
|  | LDFLAGS += $(LIB_DIRS:%=$(LIBS_DIRFLAG)%) | ||||||
|  |  | ||||||
|  | # List of targets to make for libs target | ||||||
|  | LIBS_TARGET_LIST := libcurl.a | ||||||
|  |  | ||||||
|  | # List of execuatble applications to make in addition to libs for all target | ||||||
|  | EXE_TARGET_LIST := | ||||||
|  |  | ||||||
|  | # Support for echoing rules | ||||||
|  | # If ECHORULES variable was set (for example, using 'make' command line) | ||||||
|  | #  some shell commands in the rules will be echoed | ||||||
|  | ifneq ($(strip $(findstring $(ECHORULES), yes YES 1 true TRUE)),) | ||||||
|  | _@_ := | ||||||
|  | else | ||||||
|  | _@_ := @ | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # Directory to hold compilation intermediate files | ||||||
|  | TMP_DIR := tmp | ||||||
|  |  | ||||||
|  | # Get sources and headers to be compiled | ||||||
|  | include Makefile.inc | ||||||
|  |  | ||||||
|  | # List of headers | ||||||
|  | INCLUDE_FILES := $(HHEADERS) | ||||||
|  | INCLUDE_FILES += $(shell find ../include -name \*.h) | ||||||
|  |  | ||||||
|  | # List of sources | ||||||
|  | OBJLIST := $(CSOURCES:%.c=$(TMP_DIR)/%$(OBJ_EXTENSION)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # ---------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | #### default rule | ||||||
|  | # It should be first rule in this file | ||||||
|  | .PHONY: default | ||||||
|  | default: libcurl.a | ||||||
|  |  | ||||||
|  | #### Compiling C files | ||||||
|  | $(TMP_DIR)/%$(OBJ_EXTENSION): %.c $(MAKEFILES) | ||||||
|  | 	@echo Compiling C file $< $(ECHO_STDOUT) | ||||||
|  | 	@[ -d $(@D) ] || mkdir -p $(@D) | ||||||
|  | 	$(_@_) $(TOOL_CHAIN_BIN)$(CC) $(COMPILE_ONLY_FLAG) $(CFLAGS) $< $(CC_OBJ_OUTPUT) | ||||||
|  |  | ||||||
|  | #### Creating library | ||||||
|  | $(LIBS_TARGET_LIST): $(INCLUDE_FILES) $(MAKEFILES) $(OBJLIST) | ||||||
|  | 	@echo Creating library $@ $(ECHO_STDOUT) | ||||||
|  | 	$(_@_) [ -d $(@D) ] || mkdir -p $(@D) | ||||||
|  | 	$(_@_) rm -f $@ | ||||||
|  | 	$(_@_) $(TOOL_CHAIN_BIN)$(AR) $(ARFLAGS) $@ $(filter %$(OBJ_EXTENSION), $^) | ||||||
|  |  | ||||||
|  | #### Creating application | ||||||
|  | $(EXE_TARGET_LIST): $(INCLUDE_FILES) $(MAKEFILES) $(LIBS_TARGET_LIST) | ||||||
|  | 	@echo Creating application $@ | ||||||
|  | 	@[ -d $(@D) ] || mkdir -p $(@D) | ||||||
|  | 	$(_@_) $(TOOL_CHAIN_BIN)$(LINK) $(CC_OBJ_OUTPUT) $($(@)_EXE_OBJ_LIST) $(LDFLAGS) $($(@)_EXE_LIBS_NEEDED:%=$(LIBS_FLAG)%) $(LIBS_LIST:%=$(LIBS_FLAG)%) $(USER_LIBS_LIST) $(USER_LIBS_LIST) | ||||||
|  |  | ||||||
|  | #### Master Targets | ||||||
|  | libs: $(LIBS_TARGET_LIST) | ||||||
|  | 	@echo All libs made. | ||||||
|  |  | ||||||
|  | all: $(LIBS_TARGET_LIST) $(EXE_TARGET_LIST) $(INCLUDE_TARGET_LIST) | ||||||
|  | 	@echo All targets made. | ||||||
|  |  | ||||||
|  | # Clean up | ||||||
|  | .PHONY: clean | ||||||
|  | clean: | ||||||
|  | 	$(_@_) rm -rf $(TMP_DIR) | ||||||
|  | 	@echo libcurl was cleaned. | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user