Compare commits
	
		
			501 Commits
		
	
	
		
			curl-7_15_
			...
			curl-7_16_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ef442d5803 | ||
|   | 8680e010c2 | ||
|   | 4d8dcf7b77 | ||
|   | abdbd3100f | ||
|   | ddace02efe | ||
|   | 1f4c8c4f09 | ||
|   | 8162b32bad | ||
|   | daf527b276 | ||
|   | ee51c07be6 | ||
|   | 856ba4c6c6 | ||
|   | b3e23373bd | ||
|   | e5adab39b1 | ||
|   | d31153584e | ||
|   | 823d296e12 | ||
|   | e09450103b | ||
|   | fbc4407583 | ||
|   | a79e5d7925 | ||
|   | 82491d5c06 | ||
|   | b6f889085d | ||
|   | cdbbb7d900 | ||
|   | 2bf4d9a22c | ||
|   | f1918aa343 | ||
|   | 56580fc6f8 | ||
|   | 2e6600425e | ||
|   | cc021fc200 | ||
|   | e6aed92742 | ||
|   | 02fb4d96d1 | ||
|   | 43e3c5e5fa | ||
|   | 4f496f2f70 | ||
|   | d681bc7520 | ||
|   | f21a2b3270 | ||
|   | 5f5a28d20e | ||
|   | 89f9cb4041 | ||
|   | 2b280bcc69 | ||
|   | 1c0224be42 | ||
|   | dbdb7fa55a | ||
|   | 83a43bea8a | ||
|   | abb4cdafe9 | ||
|   | 2b7bcf2505 | ||
|   | 5aefdd93cb | ||
|   | 4b27fae069 | ||
|   | 10a13eba72 | ||
|   | 44ac2776ae | ||
|   | 36e3e6ed16 | ||
|   | 5f9cbc4209 | ||
|   | 3239f059b8 | ||
|   | 45bac25d90 | ||
|   | 354c8dcd82 | ||
|   | b1e4cc370d | ||
|   | 2293474b90 | ||
|   | 9e1aef7183 | ||
|   | f68323da7d | ||
|   | a61aafa325 | ||
|   | 33bea767eb | ||
|   | 9ab7cda010 | ||
|   | 6da70628c6 | ||
|   | 3bae748256 | ||
|   | 521c4b303d | ||
|   | a2effd123a | ||
|   | 7b704e173c | ||
|   | 6045d051d7 | ||
|   | cfe00ed4ad | ||
|   | 0b4bdcf18f | ||
|   | 8cade952bf | ||
|   | 385e612fa5 | ||
|   | 1886388791 | ||
|   | 32fe5b14ec | ||
|   | bbdc483671 | ||
|   | f11d3c329c | ||
|   | b0d13fa4cb | ||
|   | 0fb5a65a58 | ||
|   | c8afb02b4c | ||
|   | 869d65337e | ||
|   | 277df1c6b1 | ||
|   | 5ec5b95f54 | ||
|   | 9e61c904ac | ||
|   | 7efb955fd0 | ||
|   | 75899741b9 | ||
|   | d465199411 | ||
|   | 55123424c8 | ||
|   | f5e4a78b59 | ||
|   | 7515a75206 | ||
|   | 4750e6f3c5 | ||
|   | b7aaa4d907 | ||
|   | e61e09f658 | ||
|   | 058e993acb | ||
|   | 359d500908 | ||
|   | cb42855445 | ||
|   | d8ff0336a5 | ||
|   | 0682d25da5 | ||
|   | d86d14074d | ||
|   | 8500397cf1 | ||
|   | bd600fbebe | ||
|   | 064bbb999f | ||
|   | bedc61ac45 | ||
|   | 61a6992559 | ||
|   | ebee2e323d | ||
|   | b2f8de571f | ||
|   | cb4a5f5a2b | ||
|   | 1beb7de7e0 | ||
|   | 89ab5f4380 | ||
|   | 439b84c782 | ||
|   | 0e899d7728 | ||
|   | 1a85fb2bd0 | ||
|   | 8d11767048 | ||
|   | fcccf9aa0d | ||
|   | 72bd027537 | ||
|   | 1d44c9ccc1 | ||
|   | 33831759b5 | ||
|   | 6fe932b255 | ||
|   | 8da02df8e0 | ||
|   | 587c99351d | ||
|   | 88c8d72a21 | ||
|   | cf99fed17a | ||
|   | ca48b6bf35 | ||
|   | 4dcd606b47 | ||
|   | 393ddd6e1f | ||
|   | 840e796aa9 | ||
|   | 5fd096da8d | ||
|   | eb29c5c285 | ||
|   | 1eb286e43e | ||
|   | ae76ebe2d1 | ||
|   | e4505aefd9 | ||
|   | d6b0612882 | ||
|   | 4c65eb0af8 | ||
|   | 318a8258fd | ||
|   | 17ae28e0fe | ||
|   | 3c4f622479 | ||
|   | 3ce43764be | ||
|   | b555c60e49 | ||
|   | 2336d010ef | ||
|   | b9af0d89d5 | ||
|   | 6f2afe0c30 | ||
|   | d8c61d459e | ||
|   | 7ae5ebbeb2 | ||
|   | 7335b71dfb | ||
|   | 9583b03074 | ||
|   | 3c81d5f125 | ||
|   | 688699a046 | ||
|   | 090f5a9a45 | ||
|   | da58d03ff7 | ||
|   | 9ea3831c08 | ||
|   | a46f55b9de | ||
|   | a634f64400 | ||
|   | bcd8a3b240 | ||
|   | 04d5d1895c | ||
|   | abd2775a70 | ||
|   | 73226415fc | ||
|   | ab160ef445 | ||
|   | 268fe09322 | ||
|   | 7a557e984a | ||
|   | f1a55cbe6d | ||
|   | 1e35d95df8 | ||
|   | d8387b418d | ||
|   | adea16a294 | ||
|   | 7f2d5cab2d | ||
|   | c6ff612f6e | ||
|   | 8db353e1d7 | ||
|   | e6978117a7 | ||
|   | 5dcb055077 | ||
|   | 0b5e1a9b2f | ||
|   | 2e17a97474 | ||
|   | 74ddbd8a3b | ||
|   | b8039a821b | ||
|   | 438312f00e | ||
|   | 381ccaa391 | ||
|   | 3204494883 | ||
|   | e264f699d4 | ||
|   | 68d4b77d44 | ||
|   | e1ac99af1f | ||
|   | be0d17e812 | ||
|   | 4eb35406f4 | ||
|   | 624745ab20 | ||
|   | 9354822e09 | ||
|   | 17d4f9513e | ||
|   | f830d77307 | ||
|   | a03c76b228 | ||
|   | 35ad61429d | ||
|   | b5b3d9e5c7 | ||
|   | 6e682c2b01 | ||
|   | 7e2ea2ece0 | ||
|   | 01926d66d7 | ||
|   | 69f7d0a0ce | ||
|   | d1c84705ec | ||
|   | 3274908551 | ||
|   | c730934498 | ||
|   | 471a8b223b | ||
|   | 47ee9202c3 | ||
|   | 1bcbe89802 | ||
|   | bf57e9bb12 | ||
|   | 318a7584f3 | ||
|   | 961ec228d4 | ||
|   | a777eb3d81 | ||
|   | 7f79b52dae | ||
|   | db680edc26 | ||
|   | e6ce80458f | ||
|   | cdcb123aa8 | ||
|   | 78081a1652 | ||
|   | 7408976b15 | ||
|   | 763bb73cc3 | ||
|   | 1dee2cd55e | ||
|   | 426ecfd136 | ||
|   | 4913baed16 | ||
|   | 675f6a8901 | ||
|   | 2147284cad | ||
|   | 7f1870da5f | ||
|   | 2149a095f7 | ||
|   | e8d21adbaa | ||
|   | fa28531322 | ||
|   | deef85ca9a | ||
|   | 4f4427ff41 | ||
|   | 0ed285e84d | ||
|   | 905ca77c9e | ||
|   | 61043c7e74 | ||
|   | 4545c9f22f | ||
|   | ad772d7b48 | ||
|   | a56ef92729 | ||
|   | 561d01c450 | ||
|   | c6c8a30da1 | ||
|   | 914dbeb12c | ||
|   | 56dc90eaab | ||
|   | f51c567de3 | ||
|   | 9b2acca63e | ||
|   | afcd9f1b1c | ||
|   | 755ccbc468 | ||
|   | 0af7aec211 | ||
|   | ee085ad6bd | ||
|   | 719bec2606 | ||
|   | b1db9dbb16 | ||
|   | 609044aea2 | ||
|   | ba481718a4 | ||
|   | 1be60dde7f | ||
|   | e92e811a61 | ||
|   | 5aa0db8681 | ||
|   | d5691211dd | ||
|   | a93695a70e | ||
|   | ce935a2697 | ||
|   | 812ce0d93f | ||
|   | bbae5b49f9 | ||
|   | 772a985dc3 | ||
|   | 8a7514de8a | ||
|   | 32ad212ac9 | ||
|   | 8a8d5c784c | ||
|   | 125830ab4b | ||
|   | 5b75b423e6 | ||
|   | 012d7e2878 | ||
|   | cd3029f36f | ||
|   | 6adaac7e18 | ||
|   | cde5e35d9b | ||
|   | ee17fba72e | ||
|   | 6296b89319 | ||
|   | 5450db9151 | ||
|   | b4700f026b | ||
|   | d771fa7c48 | ||
|   | b2c378267b | ||
|   | 384c8f3560 | ||
|   | f44ef427a2 | ||
|   | c54a4301ee | ||
|   | 36a3514225 | ||
|   | e1edd41e1b | ||
|   | 13e60c55a1 | ||
|   | 9b8b1a68f0 | ||
|   | 4ec9316155 | ||
|   | ef769500d4 | ||
|   | 23692574a2 | ||
|   | 5f6fd682a5 | ||
|   | db24518a30 | ||
|   | 90933ac660 | ||
|   | 087579a6f4 | ||
|   | de59cde155 | ||
|   | 3cd95eacdf | ||
|   | deb81b2ad4 | ||
|   | 4e717cdb30 | ||
|   | 33acd6f041 | ||
|   | 7575e6afc4 | ||
|   | 316a9f6480 | ||
|   | c6de584cad | ||
|   | d997ff6aa8 | ||
|   | b9ccecf86e | ||
|   | bd5d21aaf2 | ||
|   | 19e07771d1 | ||
|   | ef267ab449 | ||
|   | 4f6ed683e8 | ||
|   | c818e7064f | ||
|   | ead6ab2ef7 | ||
|   | 5c3dc49f44 | ||
|   | 83884180ac | ||
|   | 4cac96c33a | ||
|   | 5df4be1165 | ||
|   | 96445f1b7d | ||
|   | 4bdd7596d3 | ||
|   | 18aae32015 | ||
|   | a8996b9e52 | ||
|   | 94095c61d8 | ||
|   | 1cddd744ad | ||
|   | 786738dd00 | ||
|   | 5b8d5fdf2f | ||
|   | 694f31ca37 | ||
|   | 9c1ad0f9f7 | ||
|   | 71c6335293 | ||
|   | 8c38ea4ebc | ||
|   | 44d84ac164 | ||
|   | 930f9bd534 | ||
|   | b61fbbde46 | ||
|   | ec956b0334 | ||
|   | 44ffe0dc79 | ||
|   | e3a61fba52 | ||
|   | 65794f60ec | ||
|   | 7a710b4970 | ||
|   | 0bb20cc611 | ||
|   | 433c0c895e | ||
|   | 67e8d22958 | ||
|   | 10d1fc0e73 | ||
|   | 2260c8aa11 | ||
|   | 97eb62aff8 | ||
|   | 1855fc35f2 | ||
|   | dc3ed35313 | ||
|   | 6b868df554 | ||
|   | 5ccbbe40c2 | ||
|   | 86f93a53d6 | ||
|   | f53347631e | ||
|   | efe3cb6e1a | ||
|   | 32ac4edeed | ||
|   | 4c04c09138 | ||
|   | 47ea80baee | ||
|   | 95c3fa836b | ||
|   | ab60a12465 | ||
|   | 2d38e51867 | ||
|   | a5dda669e3 | ||
|   | 3c4f3a680a | ||
|   | b61c06384a | ||
|   | e7742bfb7c | ||
|   | 22307ae0ee | ||
|   | e150150d9f | ||
|   | 943f0733bb | ||
|   | 8274447dd9 | ||
|   | 083a84e5d0 | ||
|   | d5eb386d00 | ||
|   | 1ce7b48057 | ||
|   | cbcdd337aa | ||
|   | c144adf77c | ||
|   | d390039873 | ||
|   | 7d0c58a285 | ||
|   | 9263001b21 | ||
|   | 66ee6d07f8 | ||
|   | a40dcca794 | ||
|   | 15e3dfe1d3 | ||
|   | a1de9367ec | ||
|   | eceb37bde2 | ||
|   | 56fcf85ab6 | ||
|   | 77db81d661 | ||
|   | 2ad7fcbc2f | ||
|   | 2c62dfd124 | ||
|   | ef66497a0d | ||
|   | 1128029599 | ||
|   | befc30bc55 | ||
|   | ca5846cde9 | ||
|   | 8547ab1663 | ||
|   | 9c0e6ac365 | ||
|   | 552b963e6d | ||
|   | e2b48366d3 | ||
|   | 5e0d9aea32 | ||
|   | ae13c93b7d | ||
|   | b9f8a4a477 | ||
|   | 68e9f75708 | ||
|   | d569693f24 | ||
|   | 15d8bb2105 | ||
|   | b2ca777a08 | ||
|   | ba01198e6c | ||
|   | 6ebd5e1761 | ||
|   | 2723eda1e4 | ||
|   | 1fa3a5cce9 | ||
|   | fe8aee6b08 | ||
|   | 0639e2a6e2 | ||
|   | f1d707705e | ||
|   | 296a7db960 | ||
|   | 4c0936e72f | ||
|   | 0992e391ba | ||
|   | b22aaeef6a | ||
|   | 8090ee0e5d | ||
|   | f7d31bb3e3 | ||
|   | 9cd928674f | ||
|   | 3ea8a4d220 | ||
|   | b0d3ba76a0 | ||
|   | ab798fe5ba | ||
|   | e7d90e08b9 | ||
|   | c2404f77e9 | ||
|   | ec4a16f2e0 | ||
|   | ca5de26f50 | ||
|   | 71920d61e6 | ||
|   | 5de75eee56 | ||
|   | 2d5fc39d35 | ||
|   | c001ed53fa | ||
|   | 39e01e9349 | ||
|   | 9e54d4c7d2 | ||
|   | 56bf97ffc9 | ||
|   | 7d3e719a2c | ||
|   | e55d4fd5c1 | ||
|   | 5ee231415f | ||
|   | c866771cd2 | ||
|   | 4a24219a1a | ||
|   | 733a184ce0 | ||
|   | eee09e79e8 | ||
|   | 6df85adf3e | ||
|   | 3ee6036551 | ||
|   | fb65080548 | ||
|   | 3a5f21b0d1 | ||
|   | 13a5598dc3 | ||
|   | 5a6c89661a | ||
|   | 7c5745720a | ||
|   | 00ae13f966 | ||
|   | 29dc39fce1 | ||
|   | 5c184cfc0d | ||
|   | 055022a55f | ||
|   | c30e908034 | ||
|   | 8d24c0212e | ||
|   | 8240cea628 | ||
|   | f2a33eb372 | ||
|   | e134a40208 | ||
|   | 690888cfc1 | ||
|   | fb8d9b6645 | ||
|   | f7ddb39ee1 | ||
|   | 145084b699 | ||
|   | f1ba12607a | ||
|   | bb87b65f08 | ||
|   | b0f6e7cee4 | ||
|   | ed72d4e104 | ||
|   | 8ec1bfe897 | ||
|   | 1dec17562f | ||
|   | 9cc3795f1a | ||
|   | be1306a6c2 | ||
|   | e9160a31e0 | ||
|   | 0a670c578f | ||
|   | e3c15fc4b9 | ||
|   | dc7c915553 | ||
|   | b7eeb6e67f | ||
|   | 7e4193b538 | ||
|   | a932803eac | ||
|   | 52560142bf | ||
|   | 874a4ef8c7 | ||
|   | 0bb3ac7c31 | ||
|   | 1e9f5845ab | ||
|   | c41dfc2501 | ||
|   | 30ac7eced1 | ||
|   | 466d093a92 | ||
|   | 1e9be353c2 | ||
|   | 4f4277d9c7 | ||
|   | 6728bda5c5 | ||
|   | dc9f154823 | ||
|   | d7168a82e2 | ||
|   | c9c8ee3796 | ||
|   | c7aae10300 | ||
|   | 909941405f | ||
|   | 4031eb1d91 | ||
|   | 59cf6fd4f0 | ||
|   | 6de9732a88 | ||
|   | 1f7f500922 | ||
|   | 4b1462ec65 | ||
|   | 6ed47f0aad | ||
|   | 2d8c7ba9fc | ||
|   | 3b342d18bc | ||
|   | f24ad3800c | ||
|   | e2ff369eba | ||
|   | 9691a78f6b | ||
|   | 7ff6b6fafd | ||
|   | 7c621cfbdf | ||
|   | 5acadc9cd7 | ||
|   | 2ff609dd43 | ||
|   | da48a6ba87 | ||
|   | cd6c58216a | ||
|   | bdbd0cf27a | ||
|   | d792937686 | ||
|   | bac66ec26b | ||
|   | 77516822f6 | ||
|   | 37d8c67530 | ||
|   | cfdcae4bc7 | ||
|   | 74a6921bc4 | ||
|   | 490cccba3c | ||
|   | 839441e236 | ||
|   | ba9ea943e2 | ||
|   | 455087faae | ||
|   | 31def9e217 | ||
|   | ee3514ccdc | ||
|   | cf606d7da0 | ||
|   | eb26a581f9 | ||
|   | b04cbebf86 | ||
|   | 4272af801f | ||
|   | 0b633027cb | ||
|   | 93943ef949 | ||
|   | b184b87714 | ||
|   | a11473f85d | ||
|   | 1eedad27a2 | ||
|   | ac02d379ba | ||
|   | a4ebf5b507 | ||
|   | c410769588 | ||
|   | 997a987943 | ||
|   | 6201dc083a | ||
|   | b33f47804d | ||
|   | 7ba5e098a3 | ||
|   | 824b78021c | ||
|   | 31657c85e5 | 
							
								
								
									
										557
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										557
									
								
								CHANGES
									
									
									
									
									
								
							| @@ -6,6 +6,563 @@ | |||||||
|  |  | ||||||
|                                   Changelog |                                   Changelog | ||||||
|  |  | ||||||
|  | Version 7.16.1 (29 January 2007) | ||||||
|  |  | ||||||
|  | Daniel (29 January 2007) | ||||||
|  | - Michael Wallner reported that when doing a CONNECT with a custom User-Agent | ||||||
|  |   header, you got _two_ User-Agent headers in the CONNECT request...! Added | ||||||
|  |   test case 287 to verify the fix. | ||||||
|  |  | ||||||
|  | Daniel (28 January 2007) | ||||||
|  | - curl_easy_reset() now resets the CA bundle path correctly. | ||||||
|  |  | ||||||
|  | - David McCreedy fixed the Curl command line tool for HTTP on non-ASCII | ||||||
|  |   platforms. | ||||||
|  |  | ||||||
|  | Daniel (25 January 2007) | ||||||
|  | - Added the --libcurl [file] option to curl. Append this option to any | ||||||
|  |   ordinary curl command line, and you will get a libcurl-using source code | ||||||
|  |   written to the file that does the equivalent operation of what your command | ||||||
|  |   line operation does! | ||||||
|  |  | ||||||
|  | Dan F (24 January 2007) | ||||||
|  | - Fixed a dangling pointer problem that prevented the http_proxy environment | ||||||
|  |   variable from being properly used in many cases (and caused test case 63 | ||||||
|  |   to fail). | ||||||
|  |  | ||||||
|  | Daniel (23 January 2007) | ||||||
|  | - David McCreedy did NTLM changes mainly for non-ASCII platforms: | ||||||
|  |  | ||||||
|  |   #1 | ||||||
|  |   There's a compilation error in http_ntlm.c if USE_NTLM2SESSION is NOT | ||||||
|  |   defined.  I noticed this while testing various configurations.  Line 867 of | ||||||
|  |   the current http_ntlm.c is a closing bracket for an if/else pair that only | ||||||
|  |   gets compiled in if USE_NTLM2SESSION is defined.  But this closing bracket | ||||||
|  |   wasn't in an #ifdef so the code fails to compile unless USE_NTLM2SESSION was | ||||||
|  |   defined.  Lines 198 and 140 of my patch wraps that closing bracket in an | ||||||
|  |   #ifdef USE_NTLM2SESSION. | ||||||
|  |  | ||||||
|  |   #2 | ||||||
|  |   I noticed several picky compiler warnings when DEBUG_ME is defined.  I've | ||||||
|  |   fixed them with casting.  By the way, DEBUG_ME was a huge help in | ||||||
|  |   understanding this code. | ||||||
|  |  | ||||||
|  |   #3 | ||||||
|  |   Hopefully the last non-ASCII conversion patch for libcurl in a while.  I | ||||||
|  |   changed the "NTLMSSP" literal to hex since this signature must always be in | ||||||
|  |   ASCII. | ||||||
|  |  | ||||||
|  |   Conversion code was strategically added where necessary.  And the | ||||||
|  |   Curl_base64_encode calls were changed so the binary "blobs" http_ntlm.c | ||||||
|  |   creates are NOT translated on non-ASCII platforms. | ||||||
|  |  | ||||||
|  | Dan F (22 January 2007) | ||||||
|  | - Converted (most of) the test data files into genuine XML.  A handful still | ||||||
|  |   are not, due mainly to the lack of support for XML character entities | ||||||
|  |   (e.g. & => & ).  This will make it easier to validate test files using | ||||||
|  |   tools like xmllint, as well as to edit and view them using XML tools. | ||||||
|  |  | ||||||
|  | Daniel (16 January 2007) | ||||||
|  | - Armel Asselin improved libcurl to behave a lot better when an easy handle | ||||||
|  |   doing an FTP transfer is removed from a multi handle before completion. The | ||||||
|  |   fix also fixed the "alive counter" to be correct on "premature removal" for | ||||||
|  |   all protocols. | ||||||
|  |  | ||||||
|  | Dan F (16 January 2007) | ||||||
|  | - Fixed a small memory leak in tftp uploads discovered by curl's memory leak | ||||||
|  |   detector.  Also changed tftp downloads to URL-unescape the downloaded | ||||||
|  |   file name. | ||||||
|  |  | ||||||
|  | Daniel (14 January 2007) | ||||||
|  | - David McCreedy provided libcurl changes for doing HTTP communication on | ||||||
|  |   non-ASCII platforms. It does add some complexity, most notably with more | ||||||
|  |   #ifdefs, but I want to see this supported added and I can't see how we can | ||||||
|  |   add it without the extra stuff added. | ||||||
|  |  | ||||||
|  | - Setting CURLOPT_COOKIELIST to "ALL" when no cookies at all was present, | ||||||
|  |   libcurl would crash when trying to read a NULL pointer. | ||||||
|  |  | ||||||
|  | Daniel (12 January 2007) | ||||||
|  | - Toby Peterson found a nasty bug that prevented (lib)curl from properly | ||||||
|  |   downloading (most) things that were larger than 4GB on 32 bit systems.  Matt | ||||||
|  |   Witherspoon helped as narrow down the problem. | ||||||
|  |  | ||||||
|  | Daniel (5 January 2007) | ||||||
|  | - Linus Nielsen Feltzing introduced the --ftp-ssl-ccc command line option to | ||||||
|  |   curl that uses the new CURLOPT_FTP_SSL_CCC option in libcurl. If enabled, it | ||||||
|  |   will make libcurl shutdown SSL/TLS after the authentication is done on a | ||||||
|  |   FTP-SSL operation. | ||||||
|  |  | ||||||
|  | Daniel (4 January 2007) | ||||||
|  | - David McCreedy made changes to allow base64 encoding/decoding to work on | ||||||
|  |   non-ASCII platforms. | ||||||
|  |  | ||||||
|  | Daniel (3 January 2007) | ||||||
|  | - Matt Witherspoon fixed the flaw which made libcurl 7.16.0 always store | ||||||
|  |   downloaded data in two buffers, just to be able to deal with a special HTTP | ||||||
|  |   pipelining case. That is now only activated for pipelined transfers. In | ||||||
|  |   Matt's case, it showed as a considerable performance difference, | ||||||
|  |  | ||||||
|  | Daniel (2 January 2007) | ||||||
|  | - Victor Snezhko helped us fix bug report #1603712 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1603712) (known bug #36) --limit-rate | ||||||
|  |   (CURLOPT_MAX_SEND_SPEED_LARGE and CURLOPT_MAX_RECV_SPEED_LARGE) are broken | ||||||
|  |   on Windows (since 7.16.0, but that's when they were introduced as previous | ||||||
|  |   to that the limiting logic was made in the application only and not in the | ||||||
|  |   library). It was actually also broken on select()-based systems (as apposed | ||||||
|  |   to poll()) but we haven't had any such reports. We now use select(), Sleep() | ||||||
|  |   or delay() properly to sleep a while without waiting for anything input or | ||||||
|  |   output when the rate limiting is activated with the easy interface. | ||||||
|  |  | ||||||
|  | - Modified libcurl.pc.in to use Libs.private for the libs libcurl itself needs | ||||||
|  |   to get built static. It has been mentioned before and was again brought to | ||||||
|  |   our attention by Nathanael Nerode who filed debian bug report #405226 | ||||||
|  |   (http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=405226). | ||||||
|  |  | ||||||
|  | Daniel (29 December 2006) | ||||||
|  | - Make curl_easy_duphandle() set the magic number in the new handle. | ||||||
|  |  | ||||||
|  | Daniel (22 December 2006) | ||||||
|  | - Robert Foreman provided a prime example snippet showing how libcurl would | ||||||
|  |   get confused and not acknowledge the 'no_proxy' variable properly once it | ||||||
|  |   had used the proxy and you re-used the same easy handle. I made sure the | ||||||
|  |   proxy name is properly stored in the connect struct rather than the | ||||||
|  |   sessionhandle/easy struct. | ||||||
|  |  | ||||||
|  | - David McCreedy fixed a bad call to getsockname() that wrongly used a size_t | ||||||
|  |   variable to point to when it should be a socklen_t. | ||||||
|  |  | ||||||
|  | - When setting a proxy with environment variables and (for example) running | ||||||
|  |   'curl [URL]' with a URL without a protocol prefix, curl would not send a | ||||||
|  |   correct request as it failed to add the protocol prefix. | ||||||
|  |  | ||||||
|  | Daniel (21 December 2006) | ||||||
|  | - Robson Braga Araujo reported bug #1618359 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1618359) and subsequently provided a | ||||||
|  |   patch for it: when downloading 2 zero byte files in a row, curl 7.16.0 | ||||||
|  |   enters an infinite loop, while curl 7.16.1-20061218 does one additional | ||||||
|  |   unnecessary request. | ||||||
|  |  | ||||||
|  |   Fix: During the "Major overhaul introducing http pipelining support and | ||||||
|  |   shared connection cache within the multi handle." change, headerbytecount | ||||||
|  |   was moved to live in the Curl_transfer_keeper structure. But that structure | ||||||
|  |   is reset in the Transfer method, losing the information that we had about | ||||||
|  |   the header size. This patch moves it back to the connectdata struct. | ||||||
|  |  | ||||||
|  | Daniel (16 December 2006) | ||||||
|  | - Brendan Jurd provided a fix that now prevents libcurl from getting a SIGPIPE | ||||||
|  |   during certain conditions when GnuTLS is used. | ||||||
|  |  | ||||||
|  | Daniel (11 December 2006) | ||||||
|  | - Alexey Simak found out that when doing FTP with the multi interface and | ||||||
|  |   something went wrong like it got a bad response code back from the server, | ||||||
|  |   libcurl would leak memory. Added test case 538 to verify the fix. | ||||||
|  |  | ||||||
|  |   I also noted that the connection would get cached in that case, which | ||||||
|  |   doesn't make sense since it cannot be re-use when the authentication has | ||||||
|  |   failed. I fixed that issue too at the same time, and also that the path | ||||||
|  |   would be "remembered" in vain for cases where the connection was about to | ||||||
|  |   get closed. | ||||||
|  |  | ||||||
|  | Daniel (6 December 2006) | ||||||
|  | - Sebastien Willemijns reported bug #1603712 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1603712) which is about connections | ||||||
|  |   getting cut off prematurely when --limit-rate is used. While I found no such | ||||||
|  |   problems in my tests nor in my reading of the code, I found that the | ||||||
|  |   --limit-rate code was severly flawed (since it was moved into the lib, since | ||||||
|  |   7.15.5) when used with the easy interface and it didn't work as documented | ||||||
|  |   so I reworked it somewhat and now it works for my tests. | ||||||
|  |  | ||||||
|  | Daniel (5 December 2006) | ||||||
|  | - Stefan Krause pointed out a compiler warning with a picky MSCV compiler when | ||||||
|  |   passing a curl_off_t argument to the Curl_read_rewind() function which takes | ||||||
|  |   an size_t argument. Curl_read_rewind() also had debug code left in it and it | ||||||
|  |   was put in a different source file with no good reason when only used from | ||||||
|  |   one single spot. | ||||||
|  |  | ||||||
|  | - Sh Diao reported that CURLOPT_CLOSEPOLICY doesn't work, and indeed, there is | ||||||
|  |   no code present in the library that receives the option. Since it was not | ||||||
|  |   possible to use, we know that no current users exist and thus we simply | ||||||
|  |   removed it from the docs and made the code always use the default path of | ||||||
|  |   the code. | ||||||
|  |  | ||||||
|  | - Jared Lundell filed bug report #1604956 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1604956) which identified setting | ||||||
|  |   CURLOPT_MAXCONNECTS to zero caused libcurl to SIGSEGV. Starting now, libcurl | ||||||
|  |   will always internally use no less than 1 entry in the connection cache. | ||||||
|  |  | ||||||
|  | - Sh Diao reported that CURLOPT_FORBID_REUSE no works, and indeed it broke in | ||||||
|  |   the 7.16.0 release. | ||||||
|  |  | ||||||
|  | - Martin Skinner brought back bug report #1230118 to haunt us once again. | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1230118) curl_getdate() did not work | ||||||
|  |   properly for all input dates on Windows. It was mostly seen on some TZ time | ||||||
|  |   zones using DST. Luckily, Martin also provided a fix. | ||||||
|  |  | ||||||
|  | - Alexey Simak filed bug report #1600447 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1600447) in which he noted that active | ||||||
|  |   FTP connections don't work with the multi interface. The problem is here | ||||||
|  |   that the multi interface state machine has a state during which it can wait | ||||||
|  |   for the data connection to connect, but the active connection is not done in | ||||||
|  |   the same step in the sequence as the passive one is so it doesn't quite work | ||||||
|  |   for active. The active FTP code still use a blocking function to allow the | ||||||
|  |   remote server to connect. | ||||||
|  |  | ||||||
|  |   The fix (work-around is a better word) for this problem is to set the | ||||||
|  |   boolean prematurely that the data connection is completed, so that the "wait | ||||||
|  |   for connect" phase ends at once. | ||||||
|  |  | ||||||
|  |   The proper fix, left for the future, is of course to make the active FTP | ||||||
|  |   case to act in a non-blocking way too. | ||||||
|  |  | ||||||
|  | - Matt Witherspoon fixed a problem case when the CPU load went to 100% when a | ||||||
|  |   HTTP upload was disconnected: | ||||||
|  |  | ||||||
|  |   "What appears to be happening is that my system (Linux 2.6.17 and 2.6.13) is | ||||||
|  |   setting *only* POLLHUP on poll() when the conditions in my previous mail | ||||||
|  |   occur. As you can see, select.c:Curl_select() does not check for POLLHUP. So | ||||||
|  |   basically what was happening, is poll() was returning immediately (with | ||||||
|  |   POLLHUP set), but when Curl_select() looked at the bits, neither POLLERR or | ||||||
|  |   POLLOUT was set. This still caused Curl_readwrite() to be called, which | ||||||
|  |   quickly returned. Then the transfer() loop kept continuing at full speed | ||||||
|  |   forever." | ||||||
|  |  | ||||||
|  | Daniel (1 December 2006) | ||||||
|  | - Toon Verwaest reported that there are servers that send the Content-Range: | ||||||
|  |   header in a third, not suppported by libcurl, format and we agreed that we | ||||||
|  |   could make the parser more forgiving to accept all the three found | ||||||
|  |   variations. | ||||||
|  |  | ||||||
|  | Daniel (25 November 2006) | ||||||
|  | - Venkat Akella found out that libcurl did not like HTTP responses that simply | ||||||
|  |   responded with a single status line and no headers nor body. Starting now, a | ||||||
|  |   HTTP response on a persistent connection (i.e not set to be closed after the | ||||||
|  |   response has been taken care of) must have Content-Length or chunked | ||||||
|  |   encoding set, or libcurl will simply assume that there is no body. | ||||||
|  |  | ||||||
|  |   To my horror I learned that we had no less than 57(!) test cases that did bad | ||||||
|  |   HTTP responses like this, and even the test http server (sws) responded badly | ||||||
|  |   when queried by the test system if it is the test system. So although the | ||||||
|  |   actual fix for the problem was tiny, going through all the newly failing test | ||||||
|  |   cases got really painful and boring. | ||||||
|  |  | ||||||
|  | Daniel (24 November 2006) | ||||||
|  | - James Housley did lots of work and introduced SFTP downloads. | ||||||
|  |  | ||||||
|  | Daniel (13 November 2006) | ||||||
|  | - Ron in bug #1595348 (http://curl.haxx.se/bug/view.cgi?id=1595348) pointed | ||||||
|  |   out a stack overwrite (and the corresponding fix) on 64bit Windows when | ||||||
|  |   dealing with HTTP chunked encoding. | ||||||
|  |  | ||||||
|  | Daniel (9 November 2006) | ||||||
|  | - Nir Soffer updated libcurl.framework.make: | ||||||
|  |   o fix symlinks, should link to Versions, not to ./Versions | ||||||
|  |   o indentation improvments | ||||||
|  |  | ||||||
|  | - Dmitriy Sergeyev found a SIGSEGV with his test04.c example posted on 7 Nov | ||||||
|  |   2006. It turned out we wrongly assumed that the connection cache was present | ||||||
|  |   when tearing down a connection. | ||||||
|  |  | ||||||
|  | - Ciprian Badescu found a SIGSEGV when doing multiple TFTP transfers using the | ||||||
|  |   multi interface, but I could also repeat it doing multiple sequential ones | ||||||
|  |   with the easy interface. Using Ciprian's test case, I could fix it. | ||||||
|  |  | ||||||
|  | Daniel (8 November 2006) | ||||||
|  | - Bradford Bruce reported that when setting CURLOPT_DEBUGFUNCTION without | ||||||
|  |   CURLOPT_VERBOSE set to non-zero, you still got a few debug messages from the | ||||||
|  |   SSL handshake. This is now stopped. | ||||||
|  |  | ||||||
|  | Daniel (7 November 2006) | ||||||
|  | - Olaf fixed a leftover problem with the CONNECT fix of his that would leave a | ||||||
|  |   wrong error message in the error message buffer. | ||||||
|  |  | ||||||
|  | Daniel (3 November 2006) | ||||||
|  | - Olaf Stueben provided a patch that I edited slightly. It fixes the notorious | ||||||
|  |   KNOWN_BUGS #25, which happens when a proxy closes the connection when | ||||||
|  |   libcurl has sent CONNECT, as part of an authentication negotiation. Starting | ||||||
|  |   now, libcurl will re-connect accordingly and continue the authentication as | ||||||
|  |   it should. | ||||||
|  |  | ||||||
|  | Daniel (2 November 2006) | ||||||
|  | - James Housley brought support for SCP transfers, based on the libssh2 library | ||||||
|  |   for the actual network protocol stuff. | ||||||
|  |  | ||||||
|  |   Added these new curl_easy_setopt() options: | ||||||
|  |  | ||||||
|  |     CURLOPT_SSH_AUTH_TYPES | ||||||
|  |     CURLOPT_SSH_PUBLIC_KEYFILE | ||||||
|  |     CURLOPT_SSH_PRIVATE_KEYFILE | ||||||
|  |  | ||||||
|  | Version 7.16.0 (30 October 2006) | ||||||
|  |  | ||||||
|  | Daniel (25 October 2006) | ||||||
|  | - Fixed CURLOPT_FAILONERROR to return CURLE_HTTP_RETURNED_ERROR even for the | ||||||
|  |   case when 401 or 407 are returned, *IF* no auth credentials have been given. | ||||||
|  |   The CURLOPT_FAILONERROR option is not possible to make fool-proof for 401 | ||||||
|  |   and 407 cases when auth credentials is given, but we've now covered this | ||||||
|  |   somewhat more. | ||||||
|  |  | ||||||
|  |   You might get some amounts of headers transferred before this situation is | ||||||
|  |   detected, like for when a "100-continue" is received as a response to a | ||||||
|  |   POST/PUT and a 401 or 407 is received immediately afterwards. | ||||||
|  |  | ||||||
|  |   Added test 281 to verify this change. | ||||||
|  |  | ||||||
|  | Daniel (23 October 2006) | ||||||
|  | - Ravi Pratap provided a major update with pipelining fixes. We also no longer | ||||||
|  |   re-use connections (for pipelining) before the name resolving is done. | ||||||
|  |  | ||||||
|  | Daniel (21 October 2006) | ||||||
|  | - Nir Soffer made the tests/libtest/Makefile.am use a proper variable for all | ||||||
|  |   the single test applications' link and dependences, so that you easier can | ||||||
|  |   override those from the command line when using make. | ||||||
|  |  | ||||||
|  | - Armel Asselin separated CA cert verification problems from problems with | ||||||
|  |   reading the (local) CA cert file to let users easier pinpoint the actual | ||||||
|  |   problem. CURLE_SSL_CACERT_BADFILE (77) is the new libcurl error code. | ||||||
|  |  | ||||||
|  | Daniel (18 October 2006) | ||||||
|  | - Removed the "protocol-guessing" for URLs with host names starting with FTPS | ||||||
|  |   or TELNET since they are practically non-existant. This leaves us with only | ||||||
|  |   three different prefixes that would assume the protocol is anything but | ||||||
|  |   HTTP, and they are host names starting with "ftp.", "dict." or "ldap.". | ||||||
|  |  | ||||||
|  | Daniel (17 October 2006) | ||||||
|  | - Bug report #1579171 pointed out code flaws detected with "prefast", and they | ||||||
|  |   were 1 - a too small memory clear with memset() in the threaded resolver and | ||||||
|  |   2 - a range of potentially bad uses of the ctype family of is*() functions | ||||||
|  |   such as isdigit(), isalnum(), isprint() and more. The latter made me switch | ||||||
|  |   to using our own set of these functions/macros using uppercase letters, and | ||||||
|  |   with some extra set of crazy typecasts to avoid mistakingly passing in | ||||||
|  |   negative numbers to the underlying is*() functions. | ||||||
|  |  | ||||||
|  | - With Jeff Pohlmeyer's help, I fixed the expire timer when using | ||||||
|  |   curl_multi_socket() during name resolves with c-ares and the LOW_SPEED | ||||||
|  |   options now work fine with curl_multi_socket() as well. | ||||||
|  |  | ||||||
|  | Daniel (16 October 2006) | ||||||
|  | - Added a check in configure that simply tries to run a program (not when | ||||||
|  |   cross-compiling) in order to detect problems with run-time libraries that | ||||||
|  |   otherwise would occur when the sizeof tests for curl_off_t would run and | ||||||
|  |   thus be much more confusing to users. The check of course should run after | ||||||
|  |   all lib-checks are done and before any other test is used that would run an | ||||||
|  |   executable built for testing-purposes. | ||||||
|  |  | ||||||
|  | Dan F (13 October 2006) | ||||||
|  | - The tagging of application/x-www-form-urlencoded POST body data sent | ||||||
|  |   to the CURLOPT_DEBUGFUNCTION callback has been fixed (it was erroneously | ||||||
|  |   included as part of the header).  A message was also added to the | ||||||
|  |   command line tool to show when data is being sent, enabled when | ||||||
|  |   --verbose is used. | ||||||
|  |  | ||||||
|  | Daniel (12 October 2006) | ||||||
|  | - Starting now, adding an easy handle to a multi stack that was already added | ||||||
|  |   to a multi stack will cause CURLM_BAD_EASY_HANDLE to get returned. | ||||||
|  |  | ||||||
|  | - Jeff Pohlmeyer has been working with the hiperfifo.c example source code, | ||||||
|  |   and while doing so it became apparent that the current timeout system for | ||||||
|  |   the socket API really was a bit awkward since it become quite some work to | ||||||
|  |   be sure we have the correct timeout set. | ||||||
|  |  | ||||||
|  |   Jeff then provided the new CURLMOPT_TIMERFUNCTION that is yet another | ||||||
|  |   callback the app can set to get to know when the general timeout time | ||||||
|  |   changes and thus for an application like hiperfifo.c it makes everything a | ||||||
|  |   lot easier and nicer. There's a CURLMOPT_TIMERDATA option too of course in | ||||||
|  |   good old libcurl tradition. | ||||||
|  |  | ||||||
|  |   Jeff has also updated the hiperfifo.c example code to use this news. | ||||||
|  |  | ||||||
|  | Daniel (9 October 2006) | ||||||
|  | - Bogdan Nicula's second test case (posted Sun, 08 Oct 2006) converted to test | ||||||
|  |   case 535 and it now runs fine. Again a problem with the pipelining code not | ||||||
|  |   taking all possible (error) conditions into account. | ||||||
|  |  | ||||||
|  | Daniel (6 October 2006) | ||||||
|  | - Bogdan Nicula's hanging test case (posted Wed, 04 Oct 2006) was converted to | ||||||
|  |   test case 533 and the test now runs fine. | ||||||
|  |  | ||||||
|  | Daniel (4 October 2006) | ||||||
|  | - Dmitriy Sergeyev provided an example source code that crashed CVS libcurl | ||||||
|  |   but that worked nicely in 7.15.5. I converted it into test case 532 and | ||||||
|  |   fixed the problem. | ||||||
|  |  | ||||||
|  | Daniel (29 September 2006) | ||||||
|  | - Removed a few other no-longer present options from the header file. | ||||||
|  |  | ||||||
|  | - Support for FTP third party transfers was removed. Here's why: | ||||||
|  |  | ||||||
|  |   o The recent multi interface changes broke it and the design of the 3rd party | ||||||
|  |     transfers made it very hard to fix the problems | ||||||
|  |   o It was still blocking and thus nasty for the multi interface | ||||||
|  |   o It was a lot of extra code for a very rarely used feature | ||||||
|  |   o It didn't use the same code as for "plain" FTP transfers, so it didn't work | ||||||
|  |     fine for IPv6 and it didn't properly re-use connections and more | ||||||
|  |   o There's nobody around who's willing to work on and improve the existing | ||||||
|  |     code | ||||||
|  |  | ||||||
|  |   This does not mean that third party transfers are banned forever, only that | ||||||
|  |   they need to be done better if they are to be re-added in the future. | ||||||
|  |  | ||||||
|  |   The CURLOPT_SOURCE_* options are removed from the lib and so are the --3p* | ||||||
|  |   options from the command line tool. For this reason, I also bumped the | ||||||
|  |   version info for the lib. | ||||||
|  |  | ||||||
|  | Daniel (28 September 2006) | ||||||
|  | - Reported in #1561470 (http://curl.haxx.se/bug/view.cgi?id=1561470), libcurl | ||||||
|  |   would crash if a bad function sequence was used when shutting down after | ||||||
|  |   using the multi interface (i.e using easy_cleanup after multi_cleanup) so | ||||||
|  |   precautions have been added to make sure it doesn't any more - test case 529 | ||||||
|  |   was added to verify. | ||||||
|  |  | ||||||
|  | Daniel (27 September 2006) | ||||||
|  | - The URL in the cookie jar file is now changed since it was giving a 404. | ||||||
|  |   Reported by Timothy Stone. The new URL will take the visitor to a curl web | ||||||
|  |   site mirror with the document. | ||||||
|  |  | ||||||
|  | Daniel (24 September 2006) | ||||||
|  | - Bernard Leak fixed configure --with-gssapi-libs. | ||||||
|  |  | ||||||
|  | - Cory Nelson made libcurl use the WSAPoll() function if built for Windows | ||||||
|  |   Vista (_WIN32_WINNT >= 0x0600) | ||||||
|  |  | ||||||
|  | Daniel (23 September 2006) | ||||||
|  | - Mike Protts added --ftp-ssl-control to make curl use FTP-SSL, but only | ||||||
|  |   encrypt the control connection and use the data connection "plain". | ||||||
|  |  | ||||||
|  | - Dmitriy Sergeyev provided a patch that made the SOCKS[45] code work better | ||||||
|  |   as it now will read the full data sent from servers. The SOCKS-related code | ||||||
|  |   was also moved to the new lib/socks.c source file. | ||||||
|  |  | ||||||
|  | Daniel (21 September 2006) | ||||||
|  | - Added test case 531 in an attempt to repeat bug report #1561470 | ||||||
|  |   (http://curl.haxx.se/bug/view.cgi?id=1561470) that is said to crash when an | ||||||
|  |   FTP upload fails with the multi interface. It did not, but I made a failed | ||||||
|  |   upload still assume the control connection to be fine. | ||||||
|  |  | ||||||
|  | Daniel (20 September 2006) | ||||||
|  | - Armel Asselin fixed problems when you gave a proxy URL with user name and | ||||||
|  |   empty password or no password at all. Test case 278 and 279 were added to | ||||||
|  |   verify. | ||||||
|  |  | ||||||
|  | Daniel (12 September 2006) | ||||||
|  | - Added docs/examples/10-at-a-time.c by Michael Wallner | ||||||
|  |  | ||||||
|  | - Added docs/examples/hiperfifo.c by Jeff Pohlmeyer | ||||||
|  |  | ||||||
|  | Daniel (11 September 2006) | ||||||
|  | - Fixed my breakage from earlier today so that doing curl_easy_cleanup() on a | ||||||
|  |   handle that is part of a multi handle first removes the handle from the | ||||||
|  |   stack. | ||||||
|  |  | ||||||
|  | - Added CURLOPT_SSL_SESSIONID_CACHE and --no-sessionid to disable SSL | ||||||
|  |   session-ID re-use on demand since there obviously are broken servers out | ||||||
|  |   there that misbehave with session-IDs used. | ||||||
|  |  | ||||||
|  | - Jeff Pohlmeyer presented a *multi_socket()-using program that exposed a | ||||||
|  |   problem with it (SIGSEGV-style). It clearly showed that the existing | ||||||
|  |   socket-state and state-difference function wasn't good enough so I rewrote | ||||||
|  |   it and could then re-run Jeff's program without any crash. The previous | ||||||
|  |   version clearly could miss to tell the application when a handle changed | ||||||
|  |   from using one socket to using another. | ||||||
|  |  | ||||||
|  |   While I was at it (as I could use this as a means to track this problem | ||||||
|  |   down), I've now added a 'magic' number to the easy handle struct that is | ||||||
|  |   inited at curl_easy_init() time and cleared at curl_easy_cleanup() time that | ||||||
|  |   we can use internally to detect that an easy handle seems to be fine, or at | ||||||
|  |   least not closed or freed (freeing in debug builds fill the area with 0x13 | ||||||
|  |   bytes but in normal builds we can of course not assume any particular data | ||||||
|  |   in the freed areas). | ||||||
|  |  | ||||||
|  | Daniel (9 September 2006) | ||||||
|  | - Michele Bini fixed how the hostname is put in NTLM packages. As servers | ||||||
|  |   don't expect fully qualified names we need to cut them off at the first dot. | ||||||
|  |  | ||||||
|  | - Peter Sylvester cleaned up and fixed the getsockname() uses in ftp.c. Some | ||||||
|  |   of them can be completetly removed though... | ||||||
|  |  | ||||||
|  | Daniel (6 September 2006) | ||||||
|  | - Ravi Pratap and I have implemented HTTP Pipelining support. Enable it for a | ||||||
|  |   multi handle using CURLMOPT_PIPELINING and all HTTP connections done on that | ||||||
|  |   handle will be attempted to get pipelined instead of done in parallell as | ||||||
|  |   they are performed otherwise. | ||||||
|  |  | ||||||
|  |   As a side-effect from this work, connections are now shared between all easy | ||||||
|  |   handles within a multi handle, so if you use N easy handles for transfers, | ||||||
|  |   each of them can pick up and re-use a connection that was previously used by | ||||||
|  |   any of the handles, be it the same or one of the others. | ||||||
|  |  | ||||||
|  |   This separation of the tight relationship between connections and easy | ||||||
|  |   handles is most noticable when you close easy handles that have been used in | ||||||
|  |   a multi handle and check amount of used memory or watch the debug output, as | ||||||
|  |   there are times when libcurl will keep the easy handle around for a while | ||||||
|  |   longer to be able to close it properly. Like for sending QUIT to close down | ||||||
|  |   an FTP connection. | ||||||
|  |  | ||||||
|  |   This is a major change. | ||||||
|  |    | ||||||
|  | Daniel (4 September 2006) | ||||||
|  | - Dmitry Rechkin (http://curl.haxx.se/bug/view.cgi?id=1551412) provided a | ||||||
|  |   patch that while not fixing things very nicely, it does make the SOCKS5 | ||||||
|  |   proxy connection slightly better as it now acknowledges the timeout for | ||||||
|  |   connection and it no longer segfaults in the case when SOCKS requires | ||||||
|  |   authentication and you did not specify username:password. | ||||||
|  |  | ||||||
|  | Daniel (31 August 2006) | ||||||
|  | - Dmitriy Sergeyev found and fixed a multi interface flaw when using asynch | ||||||
|  |   name resolves. It could get stuck in the wrong state. | ||||||
|  |  | ||||||
|  | Gisle (29 August 2006) | ||||||
|  | - Added support for other MS-DOS compilers (desides djgpp). All MS-DOS | ||||||
|  |   compiler now uses the same config.dos file (renamed to config.h by | ||||||
|  |   make). libcurl now builds fine using Watcom and Metaware's High-C | ||||||
|  |   using the Watt-32 tcp/ip-stack. | ||||||
|  |  | ||||||
|  | Daniel (29 August 2006) | ||||||
|  | - David McCreedy added CURLOPT_SOCKOPTFUNCTION and CURLOPT_SOCKOPTDATA to | ||||||
|  |   allow applications to set their own socket options. | ||||||
|  |  | ||||||
|  | Daniel (25 August 2006) | ||||||
|  | - Armel Asselin reported that the 'running_handles' counter wasn't updated | ||||||
|  |   properly if you removed a "live" handle from a multi handle with | ||||||
|  |   curl_multi_remove_handle(). | ||||||
|  |  | ||||||
|  | Daniel (22 August 2006) | ||||||
|  | - David McCreedy fixed a remaining mistake from the August 19 TYPE change. | ||||||
|  |  | ||||||
|  | - Peter Sylvester pointed out a flaw in the AllowServerConnect() in the FTP | ||||||
|  |   code when doing pure ipv6 EPRT connections. | ||||||
|  |  | ||||||
|  | Daniel (19 August 2006) | ||||||
|  | - Based on a patch by Armel Asselin, the FTP code no longer re-issues the TYPE | ||||||
|  |   command on subsequent requests on a re-used connection unless it has to. | ||||||
|  |  | ||||||
|  | - Armel Asselin fixed a crash in the FTP code when using SINGLECWD mode and | ||||||
|  |   files in the root directory. | ||||||
|  |  | ||||||
|  | - Andrew Biggs pointed out a "Expect: 100-continue" flaw where libcurl didn't | ||||||
|  |   send the whole request at once, even though the Expect: header was disabled | ||||||
|  |   by the application. An effect of this change is also that small (< 1024 | ||||||
|  |   bytes) POSTs are now always sent without Expect: header since we deem it | ||||||
|  |   more costly to bother about that than the risk that we send the data in | ||||||
|  |   vain. | ||||||
|  |  | ||||||
|  | Daniel (9 August 2006) | ||||||
|  | - Armel Asselin made the CURLOPT_PREQUOTE option work fine even when | ||||||
|  |   CURLOPT_NOBODY is set true. PREQUOTE is then run roughly at the same place | ||||||
|  |   in the command sequence as it would have run if there would've been a | ||||||
|  |   transfer. | ||||||
|  |  | ||||||
|  | Daniel (8 August 2006) | ||||||
|  | - Fixed a flaw in the "Expect: 100-continue" treatment. If you did two POSTs | ||||||
|  |   on a persistent connection and allowed the first to use that header, you | ||||||
|  |   could not disable it for the second request. | ||||||
|  |  | ||||||
|  | Daniel (7 August 2006) | ||||||
|  | - Domenico Andreolfound a quick build error which happened because | ||||||
|  |   src/config.h.in was not a proper duplcate of lib/config.h.in which it | ||||||
|  |   should've been and this was due to the maketgz script not doing the cp | ||||||
|  |   properly. | ||||||
|  |  | ||||||
| Version 7.15.5 (7 August 2006) | Version 7.15.5 (7 August 2006) | ||||||
|  |  | ||||||
| Daniel (2 August 2006) | Daniel (2 August 2006) | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								COPYING
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| COPYRIGHT AND PERMISSION NOTICE | COPYRIGHT AND PERMISSION NOTICE | ||||||
|  |  | ||||||
| Copyright (c) 1996 - 2006, Daniel Stenberg, <daniel@haxx.se>. | Copyright (c) 1996 - 2007, Daniel Stenberg, <daniel@haxx.se>. | ||||||
|  |  | ||||||
| All rights reserved. | All rights reserved. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2007, 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 | ||||||
| @@ -73,6 +73,14 @@ mingw32-ssl: | |||||||
| 	$(MAKE) -C lib -f Makefile.m32 SSL=1 ZLIB=1 | 	$(MAKE) -C lib -f Makefile.m32 SSL=1 ZLIB=1 | ||||||
| 	$(MAKE) -C src -f Makefile.m32 SSL=1 ZLIB=1 | 	$(MAKE) -C src -f Makefile.m32 SSL=1 ZLIB=1 | ||||||
|  |  | ||||||
|  | mingw32-ssh2-ssl: | ||||||
|  | 	$(MAKE) -C lib -f Makefile.m32 SSH2=1 SSL=1 ZLIB=1 | ||||||
|  | 	$(MAKE) -C src -f Makefile.m32 SSH2=1 SSL=1 ZLIB=1 | ||||||
|  |  | ||||||
|  | mingw32-ssh2-ssl-sspi: | ||||||
|  | 	$(MAKE) -C lib -f Makefile.m32 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||||
|  | 	$(MAKE) -C src -f Makefile.m32 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||||
|  |  | ||||||
| mingw32-clean: | mingw32-clean: | ||||||
| 	$(MAKE) -C lib -f Makefile.m32 clean | 	$(MAKE) -C lib -f Makefile.m32 clean | ||||||
| 	$(MAKE) -C src -f Makefile.m32 clean | 	$(MAKE) -C src -f Makefile.m32 clean | ||||||
| @@ -212,6 +220,10 @@ netware-ssl-zlib: | |||||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | 	$(MAKE) -C lib -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | ||||||
| 	$(MAKE) -C src -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | 	$(MAKE) -C src -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | ||||||
|  |  | ||||||
|  | netware-ssh2-ssl-zlib: | ||||||
|  | 	$(MAKE) -C lib -f Makefile.netware WITH_SSH2=1 WITH_SSL=1 WITH_ZLIB=1 | ||||||
|  | 	$(MAKE) -C src -f Makefile.netware WITH_SSH2=1 WITH_SSL=1 WITH_ZLIB=1 | ||||||
|  |  | ||||||
| netware-zlib: | netware-zlib: | ||||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_ZLIB=1 | 	$(MAKE) -C lib -f Makefile.netware WITH_ZLIB=1 | ||||||
| 	$(MAKE) -C src -f Makefile.netware WITH_ZLIB=1 | 	$(MAKE) -C src -f Makefile.netware WITH_ZLIB=1 | ||||||
|   | |||||||
							
								
								
									
										103
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							
							
						
						
									
										103
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							| @@ -1,57 +1,86 @@ | |||||||
| Curl and libcurl 7.15.5 | Curl and libcurl 7.16.1 | ||||||
|  |  | ||||||
|  Public curl release number:               95 |  Public curl release number:               97 | ||||||
|  Releases counted from the very beginning: 122 |  Releases counted from the very beginning: 124 | ||||||
|  Available command line options:           114 |  Available command line options:           115 | ||||||
|  Available curl_easy_setopt() options:     133 |  Available curl_easy_setopt() options:     137 | ||||||
|  Number of public functions in libcurl:    54 |  Number of public functions in libcurl:    54 | ||||||
|  Amount of public web site mirrors:        33 |  Amount of public web site mirrors:        39 | ||||||
|  Number of known libcurl bindings:         32 |  Number of known libcurl bindings:         35 | ||||||
|  Number of contributors:                   506 |  Number of contributors:                   539 | ||||||
|  |  | ||||||
| This release includes the following changes: | This release includes the following changes: | ||||||
|   |   | ||||||
|  o added --ftp-ssl-reqd |  o Support for SCP and SFTP were added (powered by libssh2) | ||||||
|  o modified the prototype for the socket callback set with |  o CURLOPT_CLOSEPOLICY is now deprecated | ||||||
|    CURLMOPT_SOCKETFUNCTION |  o --ftp-ssl-ccc and CURLOPT_FTP_SSL_CCC were added | ||||||
|  o added curl_multi_assign() |  o HTTP support for non-ASCII platforms | ||||||
|  o added CURLOPT_FTP_ALTERNATIVE_TO_USER and --ftp-alternative-to-user |  o --libcurl was added | ||||||
|  o added a vcproj file for building libcurl |  | ||||||
|  o added curl_formget() |  | ||||||
|  o added CURLOPT_MAX_SEND_SPEED_LARGE and CURLOPT_MAX_RECV_SPEED_LARGE |  | ||||||
|  o added configure --enable-hidden-symbols |  | ||||||
|  o Made -K on a file that couldn't be read cause a warning to be displayed |  | ||||||
|  |  | ||||||
| This release includes the following bugfixes: | This release includes the following bugfixes: | ||||||
|  |  | ||||||
|  o chunked encoding when custom header "Transfer-Encoding: chunked" is set |  o proxy close during CONNECT authentication is now dealt with nicely | ||||||
|  o Curl_strerror() crash on unknown errors |  o the CURLOPT_DEBUGFUNCTION was sometimes called even when CURLOPT_VERBOSE | ||||||
|  o changing Content-Type when doing formposts |    was not enabled | ||||||
|  o added CURL_EXTERN to a few recent multi functions that lacked them |  o multiple TFTP transfers on the same (easy or multi) handle could cause a | ||||||
|  o splay-tree related problems for internal expire time handling |    crash | ||||||
|  o FTP ASCII CRLF counter reset |  o SIGSEGV when disconnecting on a transfer on a re-used handle when the | ||||||
|  o cookie parser now compares paths case sensitive |    host name didn't resolve | ||||||
|  o an easy handle with shared DNS cache added to a multi handle caused a crash |  o stack overwrite on 64bit Windows in the chunked decoding department | ||||||
|  o couldn't override the Proxy-Connection: header for non-CONNECT requests |  o HTTP responses on persistent connections without Content-Length nor chunked | ||||||
|  o curl_multi_fdset() could wrongly return -1 as max_fd value |    encoding are now considered to be without response body | ||||||
|  |  o Content-Range: header parsing improved | ||||||
|  |  o CPU 100% load when HTTP upload connection broke | ||||||
|  |  o active FTP didn't work with multi interface | ||||||
|  |  o curl_getdate() could be off one hour for TZ time zones with DST, on windows | ||||||
|  |  o CURLOPT_FORBID_REUSE works again | ||||||
|  |  o CURLOPT_MAXCONNECTS set to zero caused libcurl to SIGSEGV | ||||||
|  |  o rate limiting works better | ||||||
|  |  o getting FTP response code errors when using the multi-interface caused | ||||||
|  |    libcurl to leak memory | ||||||
|  |  o no more SIGPIPE when GnuTLS is used | ||||||
|  |  o FTP downloading 2 zero byte files in a row | ||||||
|  |  o using proxy and URLs without protocol prefixes | ||||||
|  |  o first using a proxy and then accessing a site that 'no_proxy' matched, | ||||||
|  |    would still make libcurl use the proxy... | ||||||
|  |  o curl_easy_duphandle() now makes a handle that is valid for the multi | ||||||
|  |    interface since the magic number is set fine | ||||||
|  |  o libcurl.pc now uses Libs.private for "private" libs | ||||||
|  |  o --limit-rate (CURLOPT_MAX_SEND_SPEED_LARGE and CURLOPT_MAX_RECV_SPEED_LARGE) | ||||||
|  |    now work on windows again | ||||||
|  |  o improved download performance by avoiding the unconditional "double copying" | ||||||
|  |  o base64 encoding/decoding works on non-ASCII platforms | ||||||
|  |  o large file downloads | ||||||
|  |  o CURLOPT_COOKIELIST set to "ALL" crash | ||||||
|  |  o easy handle removal from multi handle before completion | ||||||
|  |  o TFTP upload memory leak | ||||||
|  |  o curl_easy_reset() now resets the CA bundle path correctly | ||||||
|  |  o two User-Agent headers in CONNECT requests with custom User-Agent | ||||||
|  |  | ||||||
|  | This release includes the following known bugs: | ||||||
|  |  | ||||||
|  |  o see docs/KNOWN_BUGS (http://curl.haxx.se/docs/knownbugs.html) | ||||||
|  |  | ||||||
| Other curl-related news: | Other curl-related news: | ||||||
|  |  | ||||||
|  o yassl 1.3.7 can now be used with libcurl as an optional TLS library for |  o TclCurl 7.16.0 was released: | ||||||
|    HTTPS/FTPS support: http://www.yassl.com/ |    http://personal1.iddeo.es/andresgarci/tclcurl/english/ | ||||||
|  o cURLpp 0.6.0 was released: http://rrette.com/curlpp.html |  o Curb - Libcurl bindings for Ruby: http://curb.rubyforge.org/ | ||||||
|  o pycurl-7.15.4 was released: http://pycurl.sf.net |  | ||||||
|  |  | ||||||
| New curl mirrors: | New curl mirrors: | ||||||
|  |  | ||||||
|  o  |  o curl.miroir-francais.fr is a new French web mirror | ||||||
|  |  o curl.dsmirror.nl is a new Dutch web mirror | ||||||
|  |  | ||||||
| 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: | ||||||
|  |  | ||||||
|  Dan Fandrich, Peter Silva, Arve Knudsen, Michael Wallner, Toshiyuki Maezawa, |  James Housley, Olaf Stueben, Yang Tse, Gisle Vanem, Bradford Bruce, | ||||||
|  Ingmar Runge, Ates Goral, David McCreedy, Jari Sundell, Georg Horn, |  Ciprian Badescu, Dmitriy Sergeyev, Nir Soffer, Venkat Akella, Toon Verwaest, | ||||||
|  Gisle Vanem, Yang Tse, Michael Jerris, Dan Nelson, Yves Lejeune, |  Matt Witherspoon, Alexey Simak, Martin Skinner, Sh Diao, Jared Lundell, | ||||||
|  Maciej Karpiuk, Mark Lentczner |  Stefan Krause, Sebastien Willemijns, Alexey Simak, Brendan Jurd, | ||||||
|  |  Robson Braga Araujo, David McCreedy, Robert Foreman, Nathanael Nerode, | ||||||
|  |  Victor Snezhko, Linus Nielsen Feltzing, Toby Peterson, Dan Fandrich,  | ||||||
|  |  Armel Asselin, Michael Wallner, Guenter Knauf | ||||||
|  |  | ||||||
|         Thanks! (and sorry if I forgot to mention someone) |         Thanks! (and sorry if I forgot to mention someone) | ||||||
|   | |||||||
| @@ -1,5 +1,4 @@ | |||||||
| To get fixed in 7.15.5 (planned release: August 2006) | To get fixed in 7.16.1 (planned release: January 2007) | ||||||
| ====================== | ====================== | ||||||
|  |  | ||||||
| 66 -  | 82 -  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										135
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										135
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -976,6 +976,107 @@ AC_DEFUN([CURL_CHECK_MSG_NOSIGNAL], [ | |||||||
| ]) # AC_DEFUN | ]) # AC_DEFUN | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CURL_CHECK_STRUCT_TIMEVAL | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Check for timeval struct | ||||||
|  |  | ||||||
|  | AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | ||||||
|  |   AC_REQUIRE([AC_HEADER_TIME])dnl | ||||||
|  |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK])dnl | ||||||
|  |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK2])dnl | ||||||
|  |   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h) | ||||||
|  |   AC_CACHE_CHECK([for struct timeval], [ac_cv_struct_timeval], [ | ||||||
|  |     AC_COMPILE_IFELSE([ | ||||||
|  |       AC_LANG_PROGRAM([ | ||||||
|  | #undef inline  | ||||||
|  | #ifdef HAVE_WINDOWS_H | ||||||
|  | #ifndef WIN32_LEAN_AND_MEAN | ||||||
|  | #define WIN32_LEAN_AND_MEAN | ||||||
|  | #endif | ||||||
|  | #include <windows.h> | ||||||
|  | #ifdef HAVE_WINSOCK2_H | ||||||
|  | #include <winsock2.h> | ||||||
|  | #else | ||||||
|  | #ifdef HAVE_WINSOCK_H | ||||||
|  | #include <winsock.h> | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_TYPES_H | ||||||
|  | #include <sys/types.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
|  | #include <sys/time.h> | ||||||
|  | #ifdef TIME_WITH_SYS_TIME | ||||||
|  | #include <time.h> | ||||||
|  | #endif | ||||||
|  | #else | ||||||
|  | #ifdef HAVE_TIME_H | ||||||
|  | #include <time.h> | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  |       ],[ | ||||||
|  |         struct timeval ts; | ||||||
|  |         ts.tv_sec  = 0; | ||||||
|  |         ts.tv_usec = 0; | ||||||
|  |       ]) | ||||||
|  |     ],[ | ||||||
|  |       ac_cv_struct_timeval="yes" | ||||||
|  |     ],[ | ||||||
|  |       ac_cv_struct_timeval="no" | ||||||
|  |     ]) | ||||||
|  |   ]) | ||||||
|  |   case "$ac_cv_struct_timeval" in | ||||||
|  |     yes) | ||||||
|  |       AC_DEFINE_UNQUOTED(HAVE_STRUCT_TIMEVAL, 1, | ||||||
|  |         [Define to 1 if you have the timeval struct.]) | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  | ]) # AC_DEFUN | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl TYPE_SIG_ATOMIC_T | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Check if the sig_atomic_t type is available, and | ||||||
|  | dnl verify if it is already defined as volatile. | ||||||
|  |  | ||||||
|  | AC_DEFUN([TYPE_SIG_ATOMIC_T], [ | ||||||
|  |   AC_CHECK_HEADERS(signal.h) | ||||||
|  |   AC_CHECK_TYPE([sig_atomic_t],[ | ||||||
|  |     AC_DEFINE(HAVE_SIG_ATOMIC_T, 1, | ||||||
|  |       [Define to 1 if sig_atomic_t is an available typedef.]) | ||||||
|  |   ], ,[ | ||||||
|  | #ifdef HAVE_SIGNAL_H | ||||||
|  | #include <signal.h> | ||||||
|  | #endif | ||||||
|  |   ]) | ||||||
|  |   case "$ac_cv_type_sig_atomic_t" in | ||||||
|  |     yes) | ||||||
|  |       # | ||||||
|  |       AC_MSG_CHECKING([if sig_atomic_t is already defined as volatile]) | ||||||
|  |       AC_TRY_LINK([ | ||||||
|  | #ifdef HAVE_SIGNAL_H | ||||||
|  | #include <signal.h> | ||||||
|  | #endif | ||||||
|  |         ],[ | ||||||
|  |           static volatile sig_atomic_t dummy = 0; | ||||||
|  |         ],[  | ||||||
|  |           AC_MSG_RESULT([no]) | ||||||
|  |           ac_cv_sig_atomic_t_volatile="no" | ||||||
|  |         ],[ | ||||||
|  |           AC_MSG_RESULT([yes]) | ||||||
|  |           ac_cv_sig_atomic_t_volatile="yes" | ||||||
|  |       ]) | ||||||
|  |       # | ||||||
|  |       if test "$ac_cv_sig_atomic_t_volatile" = "yes"; then | ||||||
|  |         AC_DEFINE(HAVE_SIG_ATOMIC_T_VOLATILE, 1, | ||||||
|  |           [Define to 1 if sig_atomic_t is already defined as volatile.]) | ||||||
|  |       fi | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  | ]) # AC_DEFUN | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CURL_CHECK_NONBLOCKING_SOCKET | dnl CURL_CHECK_NONBLOCKING_SOCKET | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Check for how to set a socket to non-blocking state. There seems to exist | dnl Check for how to set a socket to non-blocking state. There seems to exist | ||||||
| @@ -1814,3 +1915,37 @@ else | |||||||
|   AC_MSG_WARN([`missing' script is too old or missing]) |   AC_MSG_WARN([`missing' script is too old or missing]) | ||||||
| fi | fi | ||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CURL_VERIFY_RUNTIMELIBS | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Verify that the shared libs found so far can be used when running | ||||||
|  | dnl programs, since otherwise the situation will create odd configure errors | ||||||
|  | dnl that are misleading people. | ||||||
|  | dnl | ||||||
|  | dnl Make sure this test is run BEFORE the first test in the script that | ||||||
|  | dnl runs anything, which at the time of this writing is the AC_CHECK_SIZEOF | ||||||
|  | dnl macro. It must also run AFTER all lib-checking macros are complete. | ||||||
|  |  | ||||||
|  | AC_DEFUN([CURL_VERIFY_RUNTIMELIBS], [ | ||||||
|  |  | ||||||
|  |   dnl this test is of course not sensible if we are cross-compiling! | ||||||
|  |   if test "x$cross_compiling" != xyes; then | ||||||
|  |  | ||||||
|  |     dnl just run a program to verify that the libs checked for previous to this | ||||||
|  |     dnl point also is available run-time! | ||||||
|  |     AC_MSG_CHECKING([run-time libs availability]) | ||||||
|  |     AC_TRY_RUN([ | ||||||
|  | main() | ||||||
|  | { | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | ], | ||||||
|  |     AC_MSG_RESULT([fine]), | ||||||
|  |     AC_MSG_RESULT([failed]) | ||||||
|  |     AC_MSG_ERROR([one or more libs available at link-time are not available run-time. Libs used at link-time: $LIBS]) | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     dnl if this test fails, configure has already stopped | ||||||
|  |   fi | ||||||
|  | ]) | ||||||
|   | |||||||
| @@ -14,3 +14,9 @@ Henrik Stoerner | |||||||
| Yang Tse | Yang Tse | ||||||
| Nick Mathewson | Nick Mathewson | ||||||
| Alexander Lazic | Alexander Lazic | ||||||
|  | Andreas Rieke | ||||||
|  | Guilherme Balena Versiani | ||||||
|  | Brad Spencer | ||||||
|  | Ravi Pratap | ||||||
|  | William Ahern | ||||||
|  | Bram Matthys | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								ares/CHANGES
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								ares/CHANGES
									
									
									
									
									
								
							| @@ -1,5 +1,45 @@ | |||||||
|   Changelog for the c-ares project |   Changelog for the c-ares project | ||||||
|  |  | ||||||
|  | * November 22 | ||||||
|  |  | ||||||
|  | - Install ares_dns.h too | ||||||
|  |  | ||||||
|  | - Michael Wallner fixed this problem: When I set domains in the options | ||||||
|  |   struct, and there are domain/search entries in /etc/resolv.conf, the domains | ||||||
|  |   of the options struct will be overridden. | ||||||
|  |  | ||||||
|  | * November 6 | ||||||
|  |  | ||||||
|  | - Yang Tse removed a couple of potential zero size memory allocations. | ||||||
|  |  | ||||||
|  | - Andreas Rieke fixed the line endings in the areslib.dsp file that I (Daniel) | ||||||
|  |   broke in the 1.3.2 release. We should switch to a system where that file is | ||||||
|  |   auto-generated. We could rip some code for that from curl... | ||||||
|  |  | ||||||
|  | Version 1.3.2 (November 3, 2006) | ||||||
|  |  | ||||||
|  | * October 12 2006 | ||||||
|  |  | ||||||
|  | - Prevent ares_getsock() to overflow if more than 16 sockets are used. | ||||||
|  |  | ||||||
|  | * September 11 2006 | ||||||
|  |  | ||||||
|  | - Guilherme Balena Versiani: I noted a strange BUG in Win32 port | ||||||
|  |   (ares_init.c/get_iphlpapi_dns_info() function): when I disable the network | ||||||
|  |   by hand or disconnect the network cable in Windows 2000 or Windows XP, my | ||||||
|  |   application gets 127.0.0.1 as the only name server. The problem comes from | ||||||
|  |   'GetNetworkParams' function, that returns the empty string "" as the only | ||||||
|  |   name server in that case. Moreover, the Windows implementation of | ||||||
|  |   inet_addr() returns INADDR_LOOPBACK instead of INADDR_NONE. | ||||||
|  |  | ||||||
|  | * August 29 2006 | ||||||
|  |  | ||||||
|  | - Brad Spencer did | ||||||
|  |  | ||||||
|  |   o made ares_version.h use extern "C" for c++ compilers | ||||||
|  |   o fixed compiler warnings in ares_getnameinfo.c | ||||||
|  |   o fixed a buffer position init for TCP reads | ||||||
|  |  | ||||||
| * August 3 2006 | * August 3 2006 | ||||||
|  |  | ||||||
| - Ravi Pratap fixed ares_getsock() to actually return the proper bitmap and | - Ravi Pratap fixed ares_getsock() to actually return the proper bitmap and | ||||||
|   | |||||||
| @@ -59,7 +59,7 @@ libcares_la_SOURCES = $(CSOURCES) $(HHEADERS) | |||||||
| # where to install the c-ares headers | # where to install the c-ares headers | ||||||
| libcares_ladir = $(includedir) | libcares_ladir = $(includedir) | ||||||
| # what headers to install on 'make install': | # what headers to install on 'make install': | ||||||
| libcares_la_HEADERS = ares.h ares_version.h | libcares_la_HEADERS = ares.h ares_version.h ares_dns.h | ||||||
|  |  | ||||||
| # Make files named *.dist replace the file without .dist extension | # Make files named *.dist replace the file without .dist extension | ||||||
| dist-hook: | dist-hook: | ||||||
|   | |||||||
							
								
								
									
										184
									
								
								ares/Makefile.dj
									
									
									
									
									
								
							
							
						
						
									
										184
									
								
								ares/Makefile.dj
									
									
									
									
									
								
							| @@ -2,32 +2,50 @@ | |||||||
| # c-ares Makefile for djgpp/gcc/Watt-32. | # c-ares Makefile for djgpp/gcc/Watt-32. | ||||||
| #   By Gisle Vanem <giva@bgnett.no> 2004. | #   By Gisle Vanem <giva@bgnett.no> 2004. | ||||||
| # | # | ||||||
| .SUFFIXES: .exe | # $Id$ | ||||||
|  |  | ||||||
|  | include ../packages/DOS/common.dj | ||||||
|  |  | ||||||
| include Makefile.inc | include Makefile.inc | ||||||
|  |  | ||||||
| WATT32_ROOT = $(subst \,/,$(WATT_ROOT)) | CFLAGS += -DWATT32 -DHAVE_AF_INET6 -DHAVE_PF_INET6 -DHAVE_FIONBIO \ | ||||||
|  |           -DHAVE_STRUCT_IN6_ADDR -DHAVE_SOCKADDR_IN6_SIN6_SCOPE_ID \ | ||||||
| CC      = gcc |           -DHAVE_SYS_TIME_H -DHAVE_STRUCT_SOCKADDR_IN6 -DHAVE_STRUCT_ADDRINFO \ | ||||||
| CFLAGS  = -O2 -Wall -DWATT32 -Dselect=select_s -DHAVE_AF_INET6 \ |           -DHAVE_SIGNAL_H -DHAVE_SIG_ATOMIC_T -DRETSIGTYPE='void' \ | ||||||
|           -DHAVE_PF_INET6 -DHAVE_IOCTLSOCKET -DHAVE_STRUCT_IN6_ADDR \ |           -DHAVE_ARPA_NAMESER_H -DNS_INADDRSZ=4 -DHAVE_RECV -DHAVE_SEND \ | ||||||
|           -DHAVE_STRUCT_SOCKADDR_IN6 -DHAVE_STRUCT_ADDRINFO \ |           -DSEND_TYPE_ARG1='int'   -DSEND_QUAL_ARG2='const' \ | ||||||
|           -DHAVE_ARPA_NAMESER_H -DNS_INADDRSZ=4 \ |           -DSEND_TYPE_ARG2='void*' -DSEND_TYPE_ARG3='int' \ | ||||||
|           -DHAVE_SOCKADDR_IN6_SIN6_SCOPE_ID -I$(WATT32_ROOT)/inc |           -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'   -UHAVE_CONFIG_H -Dselect=select_s | ||||||
|  |  | ||||||
| LDFLAGS = -s | LDFLAGS = -s | ||||||
| EX_LIBS = $(WATT32_ROOT)/lib/libwatt.a |  | ||||||
|  |  | ||||||
| OBJ_DIR = djgpp | ifeq ($(USE_DEBUG),1) | ||||||
|  |   EX_LIBS = ../lib/libcurl.a | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | ifeq ($(USE_SSL),1) | ||||||
|  |   EX_LIBS += $(OPENSSL_ROOT)/lib/libssl.a $(OPENSSL_ROOT)/lib/libcrypt.a | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | ifeq ($(USE_ZLIB),1) | ||||||
|  |   EX_LIBS += $(ZLIB_ROOT)/libz.a | ||||||
|  |   CFLAGS  += -DUSE_MANUAL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | ifeq ($(USE_IDNA),1) | ||||||
|  |   EX_LIBS += $(LIBIDN_ROOT)/lib/dj_obj/libidn.a -liconv | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | 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 | all: $(OBJ_DIR) libcares.a ahost.exe adig.exe | ||||||
| 	@echo Welcome to c-ares. | 	@echo Welcome to c-ares. | ||||||
|  |  | ||||||
| $(OBJ_DIR): |  | ||||||
| 	- mkdir $(OBJ_DIR) |  | ||||||
|  |  | ||||||
| libcares.a: $(OBJECTS) | libcares.a: $(OBJECTS) | ||||||
| 	ar rs $@ $? | 	ar rs $@ $? | ||||||
|  |  | ||||||
| @@ -44,12 +62,132 @@ vclean realclean: clean | |||||||
| 	rm -f ahost.exe adig.exe depend.dj | 	rm -f ahost.exe adig.exe depend.dj | ||||||
| 	- rmdir $(OBJ_DIR) | 	- rmdir $(OBJ_DIR) | ||||||
|  |  | ||||||
| $(OBJ_DIR)/%.o: %.c | # DO NOT DELETE THIS LINE | ||||||
| 	$(CC) $(CFLAGS) -o $@ -c $< | $(OBJ_DIR)/ares_fds.o: ares_fds.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
| 	@echo |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
| depend: |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
| 	$(CC) -MM $(CFLAGS) $(CSOURCES) | \ |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
| 	sed -e 's/^\([a-zA-Z0-9_-]*\.o:\)/$$(OBJ_DIR)\/\1/' > depend.dj | $(OBJ_DIR)/ares_getsock.o: ares_getsock.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
|  |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
| -include depend.dj |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_process.o: ares_process.c setup.h setup_once.h ares.h ares_dns.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_free_hostent.o: ares_free_hostent.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_query.o: ares_query.c setup.h setup_once.h ares.h ares_dns.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares__close_sockets.o: ares__close_sockets.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_free_string.o: ares_free_string.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_search.o: ares_search.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
|  |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares__get_hostent.o: ares__get_hostent.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h | ||||||
|  | $(OBJ_DIR)/ares_gethostbyaddr.o: ares_gethostbyaddr.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h | ||||||
|  | $(OBJ_DIR)/ares_send.o: ares_send.c setup.h setup_once.h ares.h ares_dns.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares__read_line.o: ares__read_line.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_gethostbyname.o: ares_gethostbyname.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h \ | ||||||
|  |   bitncmp.h | ||||||
|  | $(OBJ_DIR)/ares_strerror.o: ares_strerror.c setup.h setup_once.h ares.h | ||||||
|  | $(OBJ_DIR)/ares_cancel.o: ares_cancel.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
|  |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_init.o: ares_init.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
|  |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h | ||||||
|  | $(OBJ_DIR)/ares_timeout.o: ares_timeout.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
|  |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_destroy.o: ares_destroy.c setup.h setup_once.h ares.h ares_private.h \ | ||||||
|  |   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_mkquery.o: ares_mkquery.c setup.h setup_once.h ares.h ares_dns.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_version.o: ares_version.c setup.h setup_once.h ares_version.h | ||||||
|  | $(OBJ_DIR)/ares_expand_name.o: ares_expand_name.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_parse_a_reply.o: ares_parse_a_reply.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_dns.h ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/windows_port.o: windows_port.c setup.h setup_once.h | ||||||
|  | $(OBJ_DIR)/ares_expand_string.o: ares_expand_string.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_parse_ptr_reply.o: ares_parse_ptr_reply.c setup.h setup_once.h \ | ||||||
|  |   ares.h ares_dns.h ares_private.h ares_ipv6.h ../lib/memdebug.h \ | ||||||
|  |   ../lib/setup.h ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_parse_aaaa_reply.o: ares_parse_aaaa_reply.c setup.h setup_once.h \ | ||||||
|  |   ares.h ares_dns.h inet_net_pton.h ares_private.h ares_ipv6.h \ | ||||||
|  |   ../lib/memdebug.h ../lib/setup.h ../include/curl/stdcheaders.h \ | ||||||
|  |   ../include/curl/curl.h ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h | ||||||
|  | $(OBJ_DIR)/ares_getnameinfo.o: ares_getnameinfo.c setup.h setup_once.h ares.h \ | ||||||
|  |   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||||
|  |   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||||
|  |   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||||
|  |   ../include/curl/multi.h ../include/curl/curl.h inet_ntop.h | ||||||
|  | $(OBJ_DIR)/inet_net_pton.o: inet_net_pton.c setup.h setup_once.h ares_ipv6.h \ | ||||||
|  |   inet_net_pton.h | ||||||
|  | $(OBJ_DIR)/bitncmp.o: bitncmp.c bitncmp.h | ||||||
|  | $(OBJ_DIR)/inet_ntop.o: inet_ntop.c setup.h setup_once.h ares_ipv6.h inet_ntop.h | ||||||
|   | |||||||
| @@ -16,4 +16,6 @@ MANPAGES= ares_destroy.3 ares_expand_name.3 ares_expand_string.3 ares_fds.3 \ | |||||||
|  ares_gethostbyname.3 ares_init.3 ares_init_options.3 ares_mkquery.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_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_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_version.3 ares_cancel.3 ares_parse_aaaa_reply.3 ares_getnameinfo.3    \ | ||||||
|  |  ares_getsock.3 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ endif | |||||||
| TARGETS = adig.nlm ahost.nlm | TARGETS = adig.nlm ahost.nlm | ||||||
| LTARGET = libcares.lib | LTARGET = libcares.lib | ||||||
| VERSION	= $(LIBCARES_VERSION) | VERSION	= $(LIBCARES_VERSION) | ||||||
| COPYR	= Copyright (C) 1996 - 2006, Daniel Stenberg, <daniel@haxx.se> | COPYR	= Copyright (C) 1996 - 2007, Daniel Stenberg, <daniel@haxx.se> | ||||||
| DESCR	= cURL $(subst .def,,$(notdir $@)) $(LIBCARES_VERSION_STR) - http://curl.haxx.se | DESCR	= cURL $(subst .def,,$(notdir $@)) $(LIBCARES_VERSION_STR) - http://curl.haxx.se | ||||||
| MTSAFE	= YES | MTSAFE	= YES | ||||||
| STACK	= 64000 | STACK	= 64000 | ||||||
| @@ -281,6 +281,8 @@ config.h: Makefile.netware | |||||||
| 	@echo $(DL)#define HAVE_SEND 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SEND 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_SIGNAL_H 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_SIG_ATOMIC_T 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@ | ||||||
| @@ -316,9 +318,10 @@ config.h: Makefile.netware | |||||||
| 	@echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@ | 	@echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STRUCT_TIMEVAL 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | ||||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | ||||||
| ifdef NW_WINSOCK | ifdef NW_WINSOCK | ||||||
|   | |||||||
| @@ -121,8 +121,8 @@ $(DEF_FILE): $(OBJECTS) Makefile.VC6 | |||||||
|        @echo   ares_gettimeofday      >> $@ |        @echo   ares_gettimeofday      >> $@ | ||||||
|        @echo   ares_parse_aaaa_reply  >> $@ |        @echo   ares_parse_aaaa_reply  >> $@ | ||||||
|  |  | ||||||
| ahost.exe: $(OBJ_DIR) $(OBJ_DIR)\ahost.obj cares_imp.lib | ahost.exe: $(OBJ_DIR) $(OBJ_DIR)\ahost.obj $(OBJ_DIR)\getopt.obj cares_imp.lib | ||||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\ahost.obj cares_imp.lib $(EX_LIBS) |        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\ahost.obj $(OBJ_DIR)\getopt.obj cares_imp.lib $(EX_LIBS) | ||||||
|  |  | ||||||
| adig.exe: $(OBJ_DIR) $(OBJ_DIR)\adig.obj $(OBJ_DIR)\getopt.obj cares_imp.lib | adig.exe: $(OBJ_DIR) $(OBJ_DIR)\adig.obj $(OBJ_DIR)\getopt.obj cares_imp.lib | ||||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\adig.obj $(OBJ_DIR)\getopt.obj cares_imp.lib $(EX_LIBS) |        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\adig.obj $(OBJ_DIR)\getopt.obj cares_imp.lib $(EX_LIBS) | ||||||
|   | |||||||
| @@ -954,6 +954,107 @@ AC_DEFUN([CURL_CHECK_MSG_NOSIGNAL], [ | |||||||
| ]) # AC_DEFUN | ]) # AC_DEFUN | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl CURL_CHECK_STRUCT_TIMEVAL | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Check for timeval struct | ||||||
|  |  | ||||||
|  | AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | ||||||
|  |   AC_REQUIRE([AC_HEADER_TIME])dnl | ||||||
|  |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK])dnl | ||||||
|  |   AC_REQUIRE([CURL_CHECK_HEADER_WINSOCK2])dnl | ||||||
|  |   AC_CHECK_HEADERS(sys/types.h sys/time.h time.h) | ||||||
|  |   AC_CACHE_CHECK([for struct timeval], [ac_cv_struct_timeval], [ | ||||||
|  |     AC_COMPILE_IFELSE([ | ||||||
|  |       AC_LANG_PROGRAM([ | ||||||
|  | #undef inline  | ||||||
|  | #ifdef HAVE_WINDOWS_H | ||||||
|  | #ifndef WIN32_LEAN_AND_MEAN | ||||||
|  | #define WIN32_LEAN_AND_MEAN | ||||||
|  | #endif | ||||||
|  | #include <windows.h> | ||||||
|  | #ifdef HAVE_WINSOCK2_H | ||||||
|  | #include <winsock2.h> | ||||||
|  | #else | ||||||
|  | #ifdef HAVE_WINSOCK_H | ||||||
|  | #include <winsock.h> | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_TYPES_H | ||||||
|  | #include <sys/types.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
|  | #include <sys/time.h> | ||||||
|  | #ifdef TIME_WITH_SYS_TIME | ||||||
|  | #include <time.h> | ||||||
|  | #endif | ||||||
|  | #else | ||||||
|  | #ifdef HAVE_TIME_H | ||||||
|  | #include <time.h> | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  |       ],[ | ||||||
|  |         struct timeval ts; | ||||||
|  |         ts.tv_sec  = 0; | ||||||
|  |         ts.tv_usec = 0; | ||||||
|  |       ]) | ||||||
|  |     ],[ | ||||||
|  |       ac_cv_struct_timeval="yes" | ||||||
|  |     ],[ | ||||||
|  |       ac_cv_struct_timeval="no" | ||||||
|  |     ]) | ||||||
|  |   ]) | ||||||
|  |   case "$ac_cv_struct_timeval" in | ||||||
|  |     yes) | ||||||
|  |       AC_DEFINE_UNQUOTED(HAVE_STRUCT_TIMEVAL, 1, | ||||||
|  |         [Define to 1 if you have the timeval struct.]) | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  | ]) # AC_DEFUN | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl TYPE_SIG_ATOMIC_T | ||||||
|  | dnl ------------------------------------------------- | ||||||
|  | dnl Check if the sig_atomic_t type is available, and | ||||||
|  | dnl verify if it is already defined as volatile. | ||||||
|  |  | ||||||
|  | AC_DEFUN([TYPE_SIG_ATOMIC_T], [ | ||||||
|  |   AC_CHECK_HEADERS(signal.h) | ||||||
|  |   AC_CHECK_TYPE([sig_atomic_t],[ | ||||||
|  |     AC_DEFINE(HAVE_SIG_ATOMIC_T, 1, | ||||||
|  |       [Define to 1 if sig_atomic_t is an available typedef.]) | ||||||
|  |   ], ,[ | ||||||
|  | #ifdef HAVE_SIGNAL_H | ||||||
|  | #include <signal.h> | ||||||
|  | #endif | ||||||
|  |   ]) | ||||||
|  |   case "$ac_cv_type_sig_atomic_t" in | ||||||
|  |     yes) | ||||||
|  |       # | ||||||
|  |       AC_MSG_CHECKING([if sig_atomic_t is already defined as volatile]) | ||||||
|  |       AC_TRY_LINK([ | ||||||
|  | #ifdef HAVE_SIGNAL_H | ||||||
|  | #include <signal.h> | ||||||
|  | #endif | ||||||
|  |         ],[ | ||||||
|  |           static volatile sig_atomic_t dummy = 0; | ||||||
|  |         ],[  | ||||||
|  |           AC_MSG_RESULT([no]) | ||||||
|  |           ac_cv_sig_atomic_t_volatile="no" | ||||||
|  |         ],[ | ||||||
|  |           AC_MSG_RESULT([yes]) | ||||||
|  |           ac_cv_sig_atomic_t_volatile="yes" | ||||||
|  |       ]) | ||||||
|  |       # | ||||||
|  |       if test "$ac_cv_sig_atomic_t_volatile" = "yes"; then | ||||||
|  |         AC_DEFINE(HAVE_SIG_ATOMIC_T_VOLATILE, 1, | ||||||
|  |           [Define to 1 if sig_atomic_t is already defined as volatile.]) | ||||||
|  |       fi | ||||||
|  |       ;; | ||||||
|  |   esac | ||||||
|  | ]) # AC_DEFUN | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl CURL_CHECK_NONBLOCKING_SOCKET | dnl CURL_CHECK_NONBLOCKING_SOCKET | ||||||
| dnl ------------------------------------------------- | dnl ------------------------------------------------- | ||||||
| dnl Check for how to set a socket to non-blocking state. There seems to exist | dnl Check for how to set a socket to non-blocking state. There seems to exist | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								ares/adig.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								ares/adig.c
									
									
									
									
									
								
							| @@ -1,4 +1,6 @@ | |||||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  * |  * | ||||||
|  * 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 | ||||||
| @@ -16,7 +18,7 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if defined(WIN32) && !defined(WATT32) | ||||||
| #include "nameser.h" | #include "nameser.h" | ||||||
| #else | #else | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| @@ -153,8 +155,8 @@ int main(int argc, char **argv) | |||||||
|   fd_set read_fds, write_fds; |   fd_set read_fds, write_fds; | ||||||
|   struct timeval *tvp, tv; |   struct timeval *tvp, tv; | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef USE_WINSOCK | ||||||
|   WORD wVersionRequested = MAKEWORD(1,1); |   WORD wVersionRequested = MAKEWORD(USE_WINSOCK,USE_WINSOCK); | ||||||
|   WSADATA wsaData; |   WSADATA wsaData; | ||||||
|   WSAStartup(wVersionRequested, &wsaData); |   WSAStartup(wVersionRequested, &wsaData); | ||||||
| #endif | #endif | ||||||
| @@ -162,10 +164,16 @@ int main(int argc, char **argv) | |||||||
|   options.flags = ARES_FLAG_NOCHECKRESP; |   options.flags = ARES_FLAG_NOCHECKRESP; | ||||||
|   options.servers = NULL; |   options.servers = NULL; | ||||||
|   options.nservers = 0; |   options.nservers = 0; | ||||||
|   while ((c = getopt(argc, argv, "f:s:c:t:T:U:")) != -1) |   while ((c = getopt(argc, argv, "df:s:c:t:T:U:")) != -1) | ||||||
|     { |     { | ||||||
|       switch (c) |       switch (c) | ||||||
|         { |         { | ||||||
|  |         case 'd': | ||||||
|  | #ifdef WATT32 | ||||||
|  |           dbug_init(); | ||||||
|  | #endif | ||||||
|  |           break; | ||||||
|  |  | ||||||
|         case 'f': |         case 'f': | ||||||
|           /* Add a flag. */ |           /* Add a flag. */ | ||||||
|           for (i = 0; i < nflags; i++) |           for (i = 0; i < nflags; i++) | ||||||
| @@ -225,7 +233,7 @@ int main(int argc, char **argv) | |||||||
|  |  | ||||||
|         case 'T': |         case 'T': | ||||||
|           /* Set the TCP port number. */ |           /* Set the TCP port number. */ | ||||||
|           if (!isdigit((unsigned char)*optarg)) |           if (!ISDIGIT(*optarg)) | ||||||
|             usage(); |             usage(); | ||||||
|           options.tcp_port = (unsigned short)strtol(optarg, NULL, 0); |           options.tcp_port = (unsigned short)strtol(optarg, NULL, 0); | ||||||
|           optmask |= ARES_OPT_TCP_PORT; |           optmask |= ARES_OPT_TCP_PORT; | ||||||
| @@ -233,7 +241,7 @@ int main(int argc, char **argv) | |||||||
|  |  | ||||||
|         case 'U': |         case 'U': | ||||||
|           /* Set the UDP port number. */ |           /* Set the UDP port number. */ | ||||||
|           if (!isdigit((unsigned char)*optarg)) |           if (!ISDIGIT(*optarg)) | ||||||
|             usage(); |             usage(); | ||||||
|           options.udp_port = (unsigned short)strtol(optarg, NULL, 0); |           options.udp_port = (unsigned short)strtol(optarg, NULL, 0); | ||||||
|           optmask |= ARES_OPT_UDP_PORT; |           optmask |= ARES_OPT_UDP_PORT; | ||||||
|   | |||||||
| @@ -18,8 +18,7 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if !defined(WIN32) || defined(WATT32) | ||||||
| #else |  | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| @@ -64,8 +63,8 @@ int main(int argc, char **argv) | |||||||
|   struct in_addr addr4; |   struct in_addr addr4; | ||||||
|   struct in6_addr addr6; |   struct in6_addr addr6; | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef USE_WINSOCK | ||||||
|   WORD wVersionRequested = MAKEWORD(1,1); |   WORD wVersionRequested = MAKEWORD(USE_WINSOCK,USE_WINSOCK); | ||||||
|   WSADATA wsaData; |   WSADATA wsaData; | ||||||
|   WSAStartup(wVersionRequested, &wsaData); |   WSAStartup(wVersionRequested, &wsaData); | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ | |||||||
|   #include <netinet/in.h> |   #include <netinet/in.h> | ||||||
|   #include <sys/socket.h> |   #include <sys/socket.h> | ||||||
|   #include <tcp.h> |   #include <tcp.h> | ||||||
| #elif defined(WIN32) && !defined(__CYGWIN__) | #elif defined(WIN32) | ||||||
|   #include <winsock2.h> |   #include <winsock2.h> | ||||||
|   #include <windows.h> |   #include <windows.h> | ||||||
| #else | #else | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | |||||||
|  |  | ||||||
|       /* Get the address part. */ |       /* Get the address part. */ | ||||||
|       p = line; |       p = line; | ||||||
|       while (*p && !isspace((unsigned char)*p)) |       while (*p && !ISSPACE(*p)) | ||||||
|         p++; |         p++; | ||||||
|       if (!*p) |       if (!*p) | ||||||
|         continue; |         continue; | ||||||
| @@ -76,12 +76,12 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | |||||||
|  |  | ||||||
|       /* Get the canonical hostname. */ |       /* Get the canonical hostname. */ | ||||||
|       p++; |       p++; | ||||||
|       while (isspace((unsigned char)*p)) |       while (ISSPACE(*p)) | ||||||
|         p++; |         p++; | ||||||
|       if (!*p) |       if (!*p) | ||||||
|         continue; |         continue; | ||||||
|       q = p; |       q = p; | ||||||
|       while (*q && !isspace((unsigned char)*q)) |       while (*q && !ISSPACE(*q)) | ||||||
|         q++; |         q++; | ||||||
|       end_at_hostname = (*q == 0); |       end_at_hostname = (*q == 0); | ||||||
|       *q = 0; |       *q = 0; | ||||||
| @@ -92,13 +92,13 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | |||||||
|         { |         { | ||||||
|           /* Count the aliases. */ |           /* Count the aliases. */ | ||||||
|           p = q + 1; |           p = q + 1; | ||||||
|           while (isspace((unsigned char)*p)) |           while (ISSPACE(*p)) | ||||||
|             p++; |             p++; | ||||||
|           while (*p) |           while (*p) | ||||||
|             { |             { | ||||||
|               while (*p && !isspace((unsigned char)*p)) |               while (*p && !ISSPACE(*p)) | ||||||
|                 p++; |                 p++; | ||||||
|               while (isspace((unsigned char)*p)) |               while (ISSPACE(*p)) | ||||||
|                 p++; |                 p++; | ||||||
|               naliases++; |               naliases++; | ||||||
|             } |             } | ||||||
| @@ -128,12 +128,12 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | |||||||
|       if (!end_at_hostname) |       if (!end_at_hostname) | ||||||
|         { |         { | ||||||
|           p = canonical + strlen(canonical) + 1; |           p = canonical + strlen(canonical) + 1; | ||||||
|           while (isspace((unsigned char)*p)) |           while (ISSPACE(*p)) | ||||||
|             p++; |             p++; | ||||||
|           while (*p) |           while (*p) | ||||||
|             { |             { | ||||||
|               q = p; |               q = p; | ||||||
|               while (*q && !isspace((unsigned char)*q)) |               while (*q && !ISSPACE(*q)) | ||||||
|                 q++; |                 q++; | ||||||
|               hostent->h_aliases[naliases] = malloc(q - p + 1); |               hostent->h_aliases[naliases] = malloc(q - p + 1); | ||||||
|               if (hostent->h_aliases[naliases] == NULL) |               if (hostent->h_aliases[naliases] == NULL) | ||||||
| @@ -141,7 +141,7 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | |||||||
|               memcpy(hostent->h_aliases[naliases], p, q - p); |               memcpy(hostent->h_aliases[naliases], p, q - p); | ||||||
|               hostent->h_aliases[naliases][q - p] = 0; |               hostent->h_aliases[naliases][q - p] = 0; | ||||||
|               p = q; |               p = q; | ||||||
|               while (isspace((unsigned char)*p)) |               while (ISSPACE(*p)) | ||||||
|                 p++; |                 p++; | ||||||
|               naliases++; |               naliases++; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -38,8 +38,11 @@ void ares_cancel(ares_channel channel) | |||||||
|   } |   } | ||||||
|   channel->queries = NULL; |   channel->queries = NULL; | ||||||
|   if (!(channel->flags & ARES_FLAG_STAYOPEN)) |   if (!(channel->flags & ARES_FLAG_STAYOPEN)) | ||||||
|  |   { | ||||||
|  |     if (channel->servers) | ||||||
|     { |     { | ||||||
|       for (i = 0; i < channel->nservers; i++) |       for (i = 0; i < channel->nservers; i++) | ||||||
|         ares__close_sockets(channel, &channel->servers[i]); |         ares__close_sockets(channel, &channel->servers[i]); | ||||||
|     } |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -25,23 +25,37 @@ void ares_destroy(ares_channel channel) | |||||||
|   int i; |   int i; | ||||||
|   struct query *query; |   struct query *query; | ||||||
|  |  | ||||||
|  |   if (!channel) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   if (channel->servers) { | ||||||
|     for (i = 0; i < channel->nservers; i++) |     for (i = 0; i < channel->nservers; i++) | ||||||
|       ares__close_sockets(channel, &channel->servers[i]); |       ares__close_sockets(channel, &channel->servers[i]); | ||||||
|     free(channel->servers); |     free(channel->servers); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (channel->domains) { | ||||||
|     for (i = 0; i < channel->ndomains; i++) |     for (i = 0; i < channel->ndomains; i++) | ||||||
|       free(channel->domains[i]); |       free(channel->domains[i]); | ||||||
|     free(channel->domains); |     free(channel->domains); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   if(channel->sortlist) |   if(channel->sortlist) | ||||||
|     free(channel->sortlist); |     free(channel->sortlist); | ||||||
|  |  | ||||||
|  |   if (channel->lookups) | ||||||
|     free(channel->lookups); |     free(channel->lookups); | ||||||
|   while (channel->queries) |  | ||||||
|     { |   while (channel->queries) { | ||||||
|     query = channel->queries; |     query = channel->queries; | ||||||
|     channel->queries = query->next; |     channel->queries = query->next; | ||||||
|     query->callback(query->arg, ARES_EDESTRUCTION, NULL, 0); |     query->callback(query->arg, ARES_EDESTRUCTION, NULL, 0); | ||||||
|  |     if (query->tcpbuf) | ||||||
|       free(query->tcpbuf); |       free(query->tcpbuf); | ||||||
|  |     if (query->skip_server) | ||||||
|       free(query->skip_server); |       free(query->skip_server); | ||||||
|     free(query); |     free(query); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   free(channel); |   free(channel); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| /* $Id$ */ | /* $Id$ */ | ||||||
|  |  | ||||||
| /* Copyright 2005 by Daniel Stenberg. | /* Copyright (C) 2005 - 2006, Daniel Stenberg | ||||||
|  * |  * | ||||||
|  * 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 | ||||||
| @@ -39,7 +39,9 @@ int ares_getsock(ares_channel channel, | |||||||
|   if (!channel->queries) |   if (!channel->queries) | ||||||
|     return 0; |     return 0; | ||||||
|  |  | ||||||
|   for (i = 0; i < channel->nservers; i++) |   for (i = 0; | ||||||
|  |        (i < channel->nservers) && (sockindex < ARES_GETSOCK_MAXNUM); | ||||||
|  |        i++) | ||||||
|     { |     { | ||||||
|       server = &channel->servers[i]; |       server = &channel->servers[i]; | ||||||
|       if (server->udp_socket != ARES_SOCKET_BAD) |       if (server->udp_socket != ARES_SOCKET_BAD) | ||||||
| @@ -56,13 +58,12 @@ int ares_getsock(ares_channel channel, | |||||||
|            break; |            break; | ||||||
|          socks[sockindex] = server->tcp_socket; |          socks[sockindex] = server->tcp_socket; | ||||||
|          bitmap |= ARES_GETSOCK_READABLE(setbits, sockindex); |          bitmap |= ARES_GETSOCK_READABLE(setbits, sockindex); | ||||||
|          sockindex++; |  | ||||||
|  |  | ||||||
|          if (server->qhead) { |          if (server->qhead) | ||||||
|            /* then the tcp socket is also writable! */ |            /* then the tcp socket is also writable! */ | ||||||
|            bitmap |= ARES_GETSOCK_WRITABLE(setbits, sockindex-1); |            bitmap |= ARES_GETSOCK_WRITABLE(setbits, sockindex); | ||||||
|          } |  | ||||||
|  |  | ||||||
|  |          sockindex++; | ||||||
|        } |        } | ||||||
|     } |     } | ||||||
|   return bitmap; |   return bitmap; | ||||||
|   | |||||||
| @@ -125,7 +125,9 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | |||||||
|   channel->queries = NULL; |   channel->queries = NULL; | ||||||
|   channel->domains = NULL; |   channel->domains = NULL; | ||||||
|   channel->sortlist = NULL; |   channel->sortlist = NULL; | ||||||
|  |   channel->servers = NULL; | ||||||
|   channel->sock_state_cb = NULL; |   channel->sock_state_cb = NULL; | ||||||
|  |   channel->sock_state_cb_data = NULL; | ||||||
|  |  | ||||||
|   /* Initialize configuration by each of the four sources, from highest |   /* Initialize configuration by each of the four sources, from highest | ||||||
|    * precedence to lowest. |    * precedence to lowest. | ||||||
| @@ -140,7 +142,7 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | |||||||
|   if (status != ARES_SUCCESS) |   if (status != ARES_SUCCESS) | ||||||
|     { |     { | ||||||
|       /* Something failed; clean up memory we may have allocated. */ |       /* Something failed; clean up memory we may have allocated. */ | ||||||
|       if (channel->nservers != -1) |       if (channel->servers) | ||||||
|         free(channel->servers); |         free(channel->servers); | ||||||
|       if (channel->domains) |       if (channel->domains) | ||||||
|         { |         { | ||||||
| @@ -213,13 +215,17 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | |||||||
|  |  | ||||||
|   /* Copy the servers, if given. */ |   /* Copy the servers, if given. */ | ||||||
|   if ((optmask & ARES_OPT_SERVERS) && channel->nservers == -1) |   if ((optmask & ARES_OPT_SERVERS) && channel->nservers == -1) | ||||||
|  |     { | ||||||
|  |       /* Avoid zero size allocations at any cost */ | ||||||
|  |       if (options->nservers > 0) | ||||||
|         { |         { | ||||||
|           channel->servers = |           channel->servers = | ||||||
|             malloc(options->nservers * sizeof(struct server_state)); |             malloc(options->nservers * sizeof(struct server_state)); | ||||||
|       if (!channel->servers && options->nservers != 0) |           if (!channel->servers) | ||||||
|             return ARES_ENOMEM; |             return ARES_ENOMEM; | ||||||
|           for (i = 0; i < options->nservers; i++) |           for (i = 0; i < options->nservers; i++) | ||||||
|             channel->servers[i].addr = options->servers[i]; |             channel->servers[i].addr = options->servers[i]; | ||||||
|  |         } | ||||||
|       channel->nservers = options->nservers; |       channel->nservers = options->nservers; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -227,9 +233,12 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | |||||||
|    * we can clean up in case of error. |    * we can clean up in case of error. | ||||||
|    */ |    */ | ||||||
|   if ((optmask & ARES_OPT_DOMAINS) && channel->ndomains == -1) |   if ((optmask & ARES_OPT_DOMAINS) && channel->ndomains == -1) | ||||||
|  |     { | ||||||
|  |       /* Avoid zero size allocations at any cost */ | ||||||
|  |       if (options->ndomains > 0) | ||||||
|       { |       { | ||||||
|         channel->domains = malloc(options->ndomains * sizeof(char *)); |         channel->domains = malloc(options->ndomains * sizeof(char *)); | ||||||
|       if (!channel->domains && options->ndomains != 0) |         if (!channel->domains) | ||||||
|           return ARES_ENOMEM; |           return ARES_ENOMEM; | ||||||
|         for (i = 0; i < options->ndomains; i++) |         for (i = 0; i < options->ndomains; i++) | ||||||
|           { |           { | ||||||
| @@ -238,6 +247,7 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | |||||||
|             if (!channel->domains[i]) |             if (!channel->domains[i]) | ||||||
|               return ARES_ENOMEM; |               return ARES_ENOMEM; | ||||||
|           } |           } | ||||||
|  |       } | ||||||
|       channel->ndomains = options->ndomains; |       channel->ndomains = options->ndomains; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -373,7 +383,8 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size) | |||||||
|     printf ("DNS Servers:\n" |     printf ("DNS Servers:\n" | ||||||
|             "    %s (primary)\n", fi->DnsServerList.IpAddress.String); |             "    %s (primary)\n", fi->DnsServerList.IpAddress.String); | ||||||
|   } |   } | ||||||
|   if (inet_addr(fi->DnsServerList.IpAddress.String) != INADDR_NONE && |   if (strlen(fi->DnsServerList.IpAddress.String) > 0 && | ||||||
|  |       inet_addr(fi->DnsServerList.IpAddress.String) != INADDR_NONE && | ||||||
|       left > ip_size) |       left > ip_size) | ||||||
|   { |   { | ||||||
|     ret += sprintf (ret, "%s,", fi->DnsServerList.IpAddress.String); |     ret += sprintf (ret, "%s,", fi->DnsServerList.IpAddress.String); | ||||||
| @@ -581,11 +592,11 @@ DhcpNameServer | |||||||
|       return (errno == ENOENT) ? ARES_SUCCESS : ARES_EFILE; |       return (errno == ENOENT) ? ARES_SUCCESS : ARES_EFILE; | ||||||
|     while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) |     while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) | ||||||
|     { |     { | ||||||
|       if ((p = try_config(line, "domain"))) |       if ((p = try_config(line, "domain")) && channel->ndomains == -1) | ||||||
|         status = config_domain(channel, p); |         status = config_domain(channel, p); | ||||||
|       else if ((p = try_config(line, "lookup")) && !channel->lookups) |       else if ((p = try_config(line, "lookup")) && !channel->lookups) | ||||||
|         status = config_lookup(channel, p, "bind", "file"); |         status = config_lookup(channel, p, "bind", "file"); | ||||||
|       else if ((p = try_config(line, "search"))) |       else if ((p = try_config(line, "search")) && channel->ndomains == -1) | ||||||
|         status = set_search(channel, p); |         status = set_search(channel, p); | ||||||
|       else if ((p = try_config(line, "nameserver")) && channel->nservers == -1) |       else if ((p = try_config(line, "nameserver")) && channel->nservers == -1) | ||||||
|         status = config_nameserver(&servers, &nservers, p); |         status = config_nameserver(&servers, &nservers, p); | ||||||
| @@ -710,7 +721,6 @@ static int init_by_defaults(ares_channel channel) | |||||||
|       if (gethostname(hostname, sizeof(hostname)) == -1 |       if (gethostname(hostname, sizeof(hostname)) == -1 | ||||||
|           || !strchr(hostname, '.')) |           || !strchr(hostname, '.')) | ||||||
|         { |         { | ||||||
|           channel->domains = malloc(0); |  | ||||||
|           channel->ndomains = 0; |           channel->ndomains = 0; | ||||||
|         } |         } | ||||||
|       else |       else | ||||||
| @@ -749,7 +759,7 @@ static int config_domain(ares_channel channel, char *str) | |||||||
|  |  | ||||||
|   /* Set a single search domain. */ |   /* Set a single search domain. */ | ||||||
|   q = str; |   q = str; | ||||||
|   while (*q && !isspace((unsigned char)*q)) |   while (*q && !ISSPACE(*q)) | ||||||
|     q++; |     q++; | ||||||
|   *q = 0; |   *q = 0; | ||||||
|   return set_search(channel, str); |   return set_search(channel, str); | ||||||
| @@ -773,9 +783,9 @@ static int config_lookup(ares_channel channel, const char *str, | |||||||
|         if (*p == *bindch) *l++ = 'b'; |         if (*p == *bindch) *l++ = 'b'; | ||||||
|         else *l++ = 'f'; |         else *l++ = 'f'; | ||||||
|       } |       } | ||||||
|       while (*p && !isspace((unsigned char)*p) && (*p != ',')) |       while (*p && !ISSPACE(*p) && (*p != ',')) | ||||||
|         p++; |         p++; | ||||||
|       while (*p && (isspace((unsigned char)*p) || (*p == ','))) |       while (*p && (ISSPACE(*p) || (*p == ','))) | ||||||
|         p++; |         p++; | ||||||
|     } |     } | ||||||
|   *l = 0; |   *l = 0; | ||||||
| @@ -800,7 +810,7 @@ static int config_nameserver(struct server_state **servers, int *nservers, | |||||||
|   while (more) |   while (more) | ||||||
|   { |   { | ||||||
|     more = 0; |     more = 0; | ||||||
|     while (*p && !isspace(*p) && *p != ',') |     while (*p && !ISSPACE(*p) && *p != ',') | ||||||
|       p++; |       p++; | ||||||
|  |  | ||||||
|     if (*p) |     if (*p) | ||||||
| @@ -860,7 +870,7 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | |||||||
|       char ipbuf[16], ipbufpfx[32]; |       char ipbuf[16], ipbufpfx[32]; | ||||||
|       /* Find just the IP */ |       /* Find just the IP */ | ||||||
|       q = str; |       q = str; | ||||||
|       while (*q && *q != '/' && *q != ';' && !isspace((unsigned char)*q)) |       while (*q && *q != '/' && *q != ';' && !ISSPACE(*q)) | ||||||
|         q++; |         q++; | ||||||
|       memcpy(ipbuf, str, (int)(q-str)); |       memcpy(ipbuf, str, (int)(q-str)); | ||||||
|       ipbuf[(int)(q-str)] = 0; |       ipbuf[(int)(q-str)] = 0; | ||||||
| @@ -868,7 +878,7 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | |||||||
|       if (*q == '/') |       if (*q == '/') | ||||||
|         { |         { | ||||||
|           const char *str2 = q+1; |           const char *str2 = q+1; | ||||||
|           while (*q && *q != ';' && !isspace((unsigned char)*q)) |           while (*q && *q != ';' && !ISSPACE(*q)) | ||||||
|             q++; |             q++; | ||||||
|           memcpy(ipbufpfx, str, (int)(q-str)); |           memcpy(ipbufpfx, str, (int)(q-str)); | ||||||
|           ipbufpfx[(int)(q-str)] = 0; |           ipbufpfx[(int)(q-str)] = 0; | ||||||
| @@ -917,11 +927,11 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | |||||||
|         } |         } | ||||||
|       else |       else | ||||||
|         { |         { | ||||||
|           while (*q && *q != ';' && !isspace((unsigned char)*q)) |           while (*q && *q != ';' && !ISSPACE(*q)) | ||||||
|             q++; |             q++; | ||||||
|         } |         } | ||||||
|       str = q; |       str = q; | ||||||
|       while (isspace((unsigned char)*str)) |       while (ISSPACE(*str)) | ||||||
|         str++; |         str++; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -939,6 +949,7 @@ static int set_search(ares_channel channel, const char *str) | |||||||
|     for(n=0; n < channel->ndomains; n++) |     for(n=0; n < channel->ndomains; n++) | ||||||
|       free(channel->domains[n]); |       free(channel->domains[n]); | ||||||
|     free(channel->domains); |     free(channel->domains); | ||||||
|  |     channel->domains = NULL; | ||||||
|     channel->ndomains = -1; |     channel->ndomains = -1; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -947,15 +958,21 @@ static int set_search(ares_channel channel, const char *str) | |||||||
|   p = str; |   p = str; | ||||||
|   while (*p) |   while (*p) | ||||||
|     { |     { | ||||||
|       while (*p && !isspace((unsigned char)*p)) |       while (*p && !ISSPACE(*p)) | ||||||
|         p++; |         p++; | ||||||
|       while (isspace((unsigned char)*p)) |       while (ISSPACE(*p)) | ||||||
|         p++; |         p++; | ||||||
|       n++; |       n++; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |   if (!n) | ||||||
|  |     { | ||||||
|  |       channel->ndomains = 0; | ||||||
|  |       return ARES_SUCCESS; | ||||||
|  |     } | ||||||
|  |  | ||||||
|   channel->domains = malloc(n * sizeof(char *)); |   channel->domains = malloc(n * sizeof(char *)); | ||||||
|   if (!channel->domains && n) |   if (!channel->domains) | ||||||
|     return ARES_ENOMEM; |     return ARES_ENOMEM; | ||||||
|  |  | ||||||
|   /* Now copy the domains. */ |   /* Now copy the domains. */ | ||||||
| @@ -965,7 +982,7 @@ static int set_search(ares_channel channel, const char *str) | |||||||
|     { |     { | ||||||
|       channel->ndomains = n; |       channel->ndomains = n; | ||||||
|       q = p; |       q = p; | ||||||
|       while (*q && !isspace((unsigned char)*q)) |       while (*q && !ISSPACE(*q)) | ||||||
|         q++; |         q++; | ||||||
|       channel->domains[n] = malloc(q - p + 1); |       channel->domains[n] = malloc(q - p + 1); | ||||||
|       if (!channel->domains[n]) |       if (!channel->domains[n]) | ||||||
| @@ -973,7 +990,7 @@ static int set_search(ares_channel channel, const char *str) | |||||||
|       memcpy(channel->domains[n], p, q - p); |       memcpy(channel->domains[n], p, q - p); | ||||||
|       channel->domains[n][q - p] = 0; |       channel->domains[n][q - p] = 0; | ||||||
|       p = q; |       p = q; | ||||||
|       while (isspace((unsigned char)*p)) |       while (ISSPACE(*p)) | ||||||
|         p++; |         p++; | ||||||
|       n++; |       n++; | ||||||
|     } |     } | ||||||
| @@ -990,7 +1007,7 @@ static int set_options(ares_channel channel, const char *str) | |||||||
|   while (*p) |   while (*p) | ||||||
|     { |     { | ||||||
|       q = p; |       q = p; | ||||||
|       while (*q && !isspace((unsigned char)*q)) |       while (*q && !ISSPACE(*q)) | ||||||
|         q++; |         q++; | ||||||
|       val = try_option(p, q, "ndots:"); |       val = try_option(p, q, "ndots:"); | ||||||
|       if (val && channel->ndots == -1) |       if (val && channel->ndots == -1) | ||||||
| @@ -1002,7 +1019,7 @@ static int set_options(ares_channel channel, const char *str) | |||||||
|       if (val && channel->tries == -1) |       if (val && channel->tries == -1) | ||||||
|         channel->tries = atoi(val); |         channel->tries = atoi(val); | ||||||
|       p = q; |       p = q; | ||||||
|       while (isspace((unsigned char)*p)) |       while (ISSPACE(*p)) | ||||||
|         p++; |         p++; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1015,10 +1032,10 @@ static char *try_config(char *s, const char *opt) | |||||||
|   size_t len; |   size_t len; | ||||||
|  |  | ||||||
|   len = strlen(opt); |   len = strlen(opt); | ||||||
|   if (strncmp(s, opt, len) != 0 || !isspace((unsigned char)s[len])) |   if (strncmp(s, opt, len) != 0 || !ISSPACE(s[len])) | ||||||
|     return NULL; |     return NULL; | ||||||
|   s += len; |   s += len; | ||||||
|   while (isspace((unsigned char)*s)) |   while (ISSPACE(*s)) | ||||||
|     s++; |     s++; | ||||||
|   return s; |   return s; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -59,7 +59,7 @@ | |||||||
| #define TRUE 1 | #define TRUE 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS) | #ifdef USE_WINSOCK | ||||||
| #define GET_ERRNO()  WSAGetLastError() | #define GET_ERRNO()  WSAGetLastError() | ||||||
| #else | #else | ||||||
| #define GET_ERRNO()  errno | #define GET_ERRNO()  errno | ||||||
| @@ -160,7 +160,7 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | |||||||
|               vec[n].iov_len = sendreq->len; |               vec[n].iov_len = sendreq->len; | ||||||
|               n++; |               n++; | ||||||
|             } |             } | ||||||
|           wcount = (ssize_t)writev(server->tcp_socket, vec, n); |           wcount = (ssize_t)writev(server->tcp_socket, vec, (int)n); | ||||||
|           free(vec); |           free(vec); | ||||||
|           if (wcount < 0) |           if (wcount < 0) | ||||||
|             { |             { | ||||||
| @@ -297,6 +297,7 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | |||||||
|                         free(server->tcp_buffer); |                         free(server->tcp_buffer); | ||||||
|               server->tcp_buffer = NULL; |               server->tcp_buffer = NULL; | ||||||
|               server->tcp_lenbuf_pos = 0; |               server->tcp_lenbuf_pos = 0; | ||||||
|  |               server->tcp_buffer_pos = 0; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -239,15 +239,15 @@ static int single_domain(ares_channel channel, const char *name, char **s) | |||||||
|                      == ARES_SUCCESS) |                      == ARES_SUCCESS) | ||||||
|                 { |                 { | ||||||
|                   if (strncasecmp(line, name, len) != 0 || |                   if (strncasecmp(line, name, len) != 0 || | ||||||
|                       !isspace((unsigned char)line[len])) |                       !ISSPACE(line[len])) | ||||||
|                     continue; |                     continue; | ||||||
|                   p = line + len; |                   p = line + len; | ||||||
|                   while (isspace((unsigned char)*p)) |                   while (ISSPACE(*p)) | ||||||
|                     p++; |                     p++; | ||||||
|                   if (*p) |                   if (*p) | ||||||
|                     { |                     { | ||||||
|                       q = p + 1; |                       q = p + 1; | ||||||
|                       while (*q && !isspace((unsigned char)*q)) |                       while (*q && !ISSPACE(*q)) | ||||||
|                         q++; |                         q++; | ||||||
|                       *s = malloc(q - p + 1); |                       *s = malloc(q - p + 1); | ||||||
|                       if (*s) |                       if (*s) | ||||||
|   | |||||||
| @@ -5,13 +5,21 @@ | |||||||
|  |  | ||||||
| #define ARES_VERSION_MAJOR 1 | #define ARES_VERSION_MAJOR 1 | ||||||
| #define ARES_VERSION_MINOR 3 | #define ARES_VERSION_MINOR 3 | ||||||
| #define ARES_VERSION_PATCH 1 | #define ARES_VERSION_PATCH 3 | ||||||
| #define ARES_VERSION ((ARES_VERSION_MAJOR<<16)|\ | #define ARES_VERSION ((ARES_VERSION_MAJOR<<16)|\ | ||||||
|                        (ARES_VERSION_MINOR<<8)|\ |                        (ARES_VERSION_MINOR<<8)|\ | ||||||
|                        (ARES_VERSION_PATCH)) |                        (ARES_VERSION_PATCH)) | ||||||
| #define ARES_VERSION_STR "1.3.1" | #define ARES_VERSION_STR "1.3.3-CVS" | ||||||
|  |  | ||||||
|  | #ifdef  __cplusplus | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
| const char *ares_version(int *version); | const char *ares_version(int *version); | ||||||
|  |  | ||||||
|  | #ifdef  __cplusplus | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
|  |  | ||||||
| /* $Id$ */ | /* $Id$ */ | ||||||
|  |  | ||||||
| /* Copyright (C) 2004 - 2005 by Daniel Stenberg et al | /* Copyright (C) 2004 - 2006 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 | ||||||
| @@ -17,7 +17,7 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* ================================================================ */ | /* ================================================================ */ | ||||||
| /*    ares/config-win32.h - Hand crafted config file for windows    */ | /*    ares/config-win32.h - Hand crafted config file for Windows    */ | ||||||
| /* ================================================================ */ | /* ================================================================ */ | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| @@ -29,6 +29,15 @@ | |||||||
| #define HAVE_GETOPT_H 1 | #define HAVE_GETOPT_H 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* Define if you have the <signal.h> header file. */ | ||||||
|  | #define HAVE_SIGNAL_H 1 | ||||||
|  |  | ||||||
|  | /* Define if you have the <sys/time.h> header file */ | ||||||
|  | /* #define HAVE_SYS_TIME_H 1 */ | ||||||
|  |  | ||||||
|  | /* Define if you have the <time.h> header file.  */ | ||||||
|  | #define HAVE_TIME_H 1 | ||||||
|  |  | ||||||
| /* Define if you have the <unistd.h> header file.  */ | /* Define if you have the <unistd.h> header file.  */ | ||||||
| #if defined(__MINGW32__) || defined(__WATCOMC__) || defined(__LCC__) || \ | #if defined(__MINGW32__) || defined(__WATCOMC__) || defined(__LCC__) || \ | ||||||
|     defined(__POCC__) |     defined(__POCC__) | ||||||
| @@ -47,6 +56,19 @@ | |||||||
| /* Define if you have the <ws2tcpip.h> header file.  */ | /* Define if you have the <ws2tcpip.h> header file.  */ | ||||||
| #define HAVE_WS2TCPIP_H 1 | #define HAVE_WS2TCPIP_H 1 | ||||||
|  |  | ||||||
|  | /* ---------------------------------------------------------------- */ | ||||||
|  | /*                        OTHER HEADER INFO                         */ | ||||||
|  | /* ---------------------------------------------------------------- */ | ||||||
|  |  | ||||||
|  | /* Define if sig_atomic_t is an available typedef. */ | ||||||
|  | #define HAVE_SIG_ATOMIC_T 1 | ||||||
|  |  | ||||||
|  | /* Define if you have the ANSI C header files.  */ | ||||||
|  | #define STDC_HEADERS 1 | ||||||
|  |  | ||||||
|  | /* Define if you can safely include both <sys/time.h> and <time.h>.  */ | ||||||
|  | /* #define TIME_WITH_SYS_TIME 1 */ | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| /*                             FUNCTIONS                            */ | /*                             FUNCTIONS                            */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| @@ -54,24 +76,6 @@ | |||||||
| /* Define if you have the ioctlsocket function.  */ | /* Define if you have the ioctlsocket function.  */ | ||||||
| #define HAVE_IOCTLSOCKET 1 | #define HAVE_IOCTLSOCKET 1 | ||||||
|  |  | ||||||
| /* Define if you have the getnameinfo function. */ |  | ||||||
| #define HAVE_GETNAMEINFO 1 |  | ||||||
|  |  | ||||||
| /* Define to the type qualifier of arg 1 for getnameinfo. */ |  | ||||||
| #define GETNAMEINFO_QUAL_ARG1 const |  | ||||||
|  |  | ||||||
| /* Define to the type of arg 1 for getnameinfo. */ |  | ||||||
| #define GETNAMEINFO_TYPE_ARG1 struct sockaddr * |  | ||||||
|  |  | ||||||
| /* Define to the type of arg 2 for getnameinfo. */ |  | ||||||
| #define GETNAMEINFO_TYPE_ARG2 socklen_t |  | ||||||
|  |  | ||||||
| /* Define to the type of args 4 and 6 for getnameinfo. */ |  | ||||||
| #define GETNAMEINFO_TYPE_ARG46 DWORD |  | ||||||
|  |  | ||||||
| /* Define to the type of arg 7 for getnameinfo. */ |  | ||||||
| #define GETNAMEINFO_TYPE_ARG7 int |  | ||||||
|  |  | ||||||
| /* Define if you have the recv function. */ | /* Define if you have the recv function. */ | ||||||
| #define HAVE_RECV 1 | #define HAVE_RECV 1 | ||||||
|  |  | ||||||
| @@ -111,6 +115,39 @@ | |||||||
| /* Define to the function return type for send. */ | /* Define to the function return type for send. */ | ||||||
| #define SEND_TYPE_RETV int | #define SEND_TYPE_RETV int | ||||||
|  |  | ||||||
|  | /* Specifics for the Watt-32 tcp/ip stack */ | ||||||
|  | #ifdef WATT32 | ||||||
|  |   #define SOCKET              int | ||||||
|  |   #define NS_INADDRSZ         4 | ||||||
|  |   #define HAVE_ARPA_NAMESER_H 1 | ||||||
|  |   #undef HAVE_WINSOCK_H | ||||||
|  |   #undef HAVE_WINSOCK2_H | ||||||
|  |   #undef HAVE_WS2TCPIP_H | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /* ---------------------------------------------------------------- */ | ||||||
|  | /*                       TYPEDEF REPLACEMENTS                       */ | ||||||
|  | /* ---------------------------------------------------------------- */ | ||||||
|  |  | ||||||
|  | /* Define this if in_addr_t is not an available 'typedefed' type */ | ||||||
|  | #define in_addr_t unsigned long | ||||||
|  |  | ||||||
|  | /* Define as the return type of signal handlers (int or void).  */ | ||||||
|  | #define RETSIGTYPE void | ||||||
|  |  | ||||||
|  | /* Define ssize_t if it is not an available 'typedefed' type */ | ||||||
|  | #if (defined(__WATCOMC__) && (__WATCOMC__ >= 1240)) || defined(__POCC__) | ||||||
|  | #elif defined(_WIN64) | ||||||
|  | #define ssize_t __int64 | ||||||
|  | #else | ||||||
|  | #define ssize_t int | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /* Define to 'int' if socklen_t is not an available 'typedefed' type */ | ||||||
|  | #ifndef HAVE_WS2TCPIP_H | ||||||
|  | #define socklen_t int | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| /*                          STRUCT RELATED                          */ | /*                          STRUCT RELATED                          */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| @@ -121,6 +158,9 @@ | |||||||
| /* Define this if you have struct sockaddr_storage */ | /* Define this if you have struct sockaddr_storage */ | ||||||
| #define HAVE_STRUCT_SOCKADDR_STORAGE 1 | #define HAVE_STRUCT_SOCKADDR_STORAGE 1 | ||||||
|  |  | ||||||
|  | /* Define this if you have struct timeval */ | ||||||
|  | #define HAVE_STRUCT_TIMEVAL 1 | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| /*                         IPV6 COMPATIBILITY                       */ | /*                         IPV6 COMPATIBILITY                       */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
|   | |||||||
| @@ -265,6 +265,7 @@ dnl Checks for typedefs, structures, and compiler characteristics. | |||||||
| AC_C_CONST | AC_C_CONST | ||||||
| AC_TYPE_SIZE_T | AC_TYPE_SIZE_T | ||||||
| AC_HEADER_TIME | AC_HEADER_TIME | ||||||
|  | CURL_CHECK_STRUCT_TIMEVAL | ||||||
|  |  | ||||||
| AC_CHECK_SIZEOF(size_t) | AC_CHECK_SIZEOF(size_t) | ||||||
| AC_CHECK_SIZEOF(long) | AC_CHECK_SIZEOF(long) | ||||||
| @@ -296,6 +297,10 @@ TYPE_IN_ADDR_T | |||||||
|  |  | ||||||
| TYPE_SOCKADDR_STORAGE | TYPE_SOCKADDR_STORAGE | ||||||
|  |  | ||||||
|  | TYPE_SIG_ATOMIC_T | ||||||
|  |  | ||||||
|  | AC_TYPE_SIGNAL | ||||||
|  |  | ||||||
| CURL_CHECK_FUNC_RECV | CURL_CHECK_FUNC_RECV | ||||||
|  |  | ||||||
| CURL_CHECK_FUNC_SEND | CURL_CHECK_FUNC_SEND | ||||||
|   | |||||||
| @@ -79,14 +79,13 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | |||||||
|  |  | ||||||
|   ch = *src++; |   ch = *src++; | ||||||
|   if (ch == '0' && (src[0] == 'x' || src[0] == 'X') |   if (ch == '0' && (src[0] == 'x' || src[0] == 'X') | ||||||
|       && isascii((unsigned char)(src[1])) |       && ISXDIGIT(src[1])) { | ||||||
|       && isxdigit((unsigned char)(src[1]))) { |  | ||||||
|     /* Hexadecimal: Eat nybble string. */ |     /* Hexadecimal: Eat nybble string. */ | ||||||
|     if (size <= 0U) |     if (size <= 0U) | ||||||
|       goto emsgsize; |       goto emsgsize; | ||||||
|     dirty = 0; |     dirty = 0; | ||||||
|     src++;  /* skip x or X. */ |     src++;  /* skip x or X. */ | ||||||
|     while ((ch = *src++) != '\0' && isascii(ch) && isxdigit(ch)) { |     while ((ch = *src++) != '\0' && ISXDIGIT(ch)) { | ||||||
|       if (isupper(ch)) |       if (isupper(ch)) | ||||||
|         ch = tolower(ch); |         ch = tolower(ch); | ||||||
|       n = (int)(strchr(xdigits, ch) - xdigits); |       n = (int)(strchr(xdigits, ch) - xdigits); | ||||||
| @@ -106,7 +105,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | |||||||
|         goto emsgsize; |         goto emsgsize; | ||||||
|       *dst++ = (unsigned char) (tmp << 4); |       *dst++ = (unsigned char) (tmp << 4); | ||||||
|     } |     } | ||||||
|   } else if (isascii(ch) && isdigit(ch)) { |   } else if (ISDIGIT(ch)) { | ||||||
|     /* Decimal: eat dotted digit string. */ |     /* Decimal: eat dotted digit string. */ | ||||||
|     for (;;) { |     for (;;) { | ||||||
|       tmp = 0; |       tmp = 0; | ||||||
| @@ -117,7 +116,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | |||||||
|         if (tmp > 255) |         if (tmp > 255) | ||||||
|           goto enoent; |           goto enoent; | ||||||
|       } while ((ch = *src++) != '\0' && |       } while ((ch = *src++) != '\0' && | ||||||
|                isascii(ch) && isdigit(ch)); |                ISDIGIT(ch)); | ||||||
|       if (size-- <= 0U) |       if (size-- <= 0U) | ||||||
|         goto emsgsize; |         goto emsgsize; | ||||||
|       *dst++ = (unsigned char) tmp; |       *dst++ = (unsigned char) tmp; | ||||||
| @@ -126,15 +125,15 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | |||||||
|       if (ch != '.') |       if (ch != '.') | ||||||
|         goto enoent; |         goto enoent; | ||||||
|       ch = *src++; |       ch = *src++; | ||||||
|       if (!isascii(ch) || !isdigit(ch)) |       if (!ISDIGIT(ch)) | ||||||
|         goto enoent; |         goto enoent; | ||||||
|     } |     } | ||||||
|   } else |   } else | ||||||
|     goto enoent; |     goto enoent; | ||||||
|  |  | ||||||
|   bits = -1; |   bits = -1; | ||||||
|   if (ch == '/' && isascii((unsigned char)(src[0])) && |   if (ch == '/' && | ||||||
|       isdigit((unsigned char)(src[0])) && dst > odst) { |       ISDIGIT(src[0]) && dst > odst) { | ||||||
|     /* CIDR width specifier.  Nothing can follow it. */ |     /* CIDR width specifier.  Nothing can follow it. */ | ||||||
|     ch = *src++;    /* Skip over the /. */ |     ch = *src++;    /* Skip over the /. */ | ||||||
|     bits = 0; |     bits = 0; | ||||||
| @@ -142,7 +141,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | |||||||
|       n = (int)(strchr(digits, ch) - digits); |       n = (int)(strchr(digits, ch) - digits); | ||||||
|       bits *= 10; |       bits *= 10; | ||||||
|       bits += n; |       bits += n; | ||||||
|     } while ((ch = *src++) != '\0' && isascii(ch) && isdigit(ch)); |     } while ((ch = *src++) != '\0' && ISDIGIT(ch)); | ||||||
|     if (ch != '\0') |     if (ch != '\0') | ||||||
|       goto enoent; |       goto enoent; | ||||||
|     if (bits > 32) |     if (bits > 32) | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								ares/setup.h
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								ares/setup.h
									
									
									
									
									
								
							| @@ -69,6 +69,22 @@ | |||||||
| #  endif | #  endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Define USE_WINSOCK to 2 if we have and use WINSOCK2 API, else | ||||||
|  |  * define USE_WINSOCK to 1 if we have and use WINSOCK  API, else | ||||||
|  |  * undefine USE_WINSOCK. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #undef USE_WINSOCK | ||||||
|  |  | ||||||
|  | #ifdef HAVE_WINSOCK2_H | ||||||
|  | #  define USE_WINSOCK 2 | ||||||
|  | #else | ||||||
|  | #  ifdef HAVE_WINSOCK_H | ||||||
|  | #    define USE_WINSOCK 1 | ||||||
|  | #  endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Work-arounds for systems without configure support |  * Work-arounds for systems without configure support | ||||||
|  */ |  */ | ||||||
| @@ -105,7 +121,7 @@ | |||||||
|  * Typedef our socket type |  * Typedef our socket type | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(WATT32) | #ifdef USE_WINSOCK | ||||||
| typedef SOCKET ares_socket_t; | typedef SOCKET ares_socket_t; | ||||||
| #define ARES_SOCKET_BAD INVALID_SOCKET | #define ARES_SOCKET_BAD INVALID_SOCKET | ||||||
| #else | #else | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
|  |  | ||||||
| /* $Id$ */ | /* $Id$ */ | ||||||
|  |  | ||||||
| /* Copyright (C) 2004 - 2006 by Daniel Stenberg et al | /* Copyright (C) 2004 - 2007 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 | ||||||
| @@ -17,9 +17,19 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /******************************************************************** | ||||||
|  |  *                              NOTICE                              * | ||||||
|  |  *                             ========                             * | ||||||
|  |  *                                                                  * | ||||||
|  |  *  Content of header files lib/setup_once.h and ares/setup_once.h  * | ||||||
|  |  *  must be kept in sync. Modify the other one if you change this.  * | ||||||
|  |  *                                                                  * | ||||||
|  |  ********************************************************************/ | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * If we have the MSG_NOSIGNAL define, make sure we use |  * If we have the MSG_NOSIGNAL define, make sure we use | ||||||
|  * it as the fourth argument of send() and recv() |  * it as the fourth argument of function send() | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifdef HAVE_MSG_NOSIGNAL | #ifdef HAVE_MSG_NOSIGNAL | ||||||
| @@ -64,12 +74,9 @@ | |||||||
| #define sread(x,y,z) (ssize_t)recv((RECV_TYPE_ARG1)(x), \ | #define sread(x,y,z) (ssize_t)recv((RECV_TYPE_ARG1)(x), \ | ||||||
|                                    (RECV_TYPE_ARG2)(y), \ |                                    (RECV_TYPE_ARG2)(y), \ | ||||||
|                                    (RECV_TYPE_ARG3)(z), \ |                                    (RECV_TYPE_ARG3)(z), \ | ||||||
|                                    (RECV_TYPE_ARG4)(SEND_4TH_ARG)) |                                    (RECV_TYPE_ARG4)(0)) | ||||||
| #endif | #endif | ||||||
| #else /* HAVE_RECV */ | #else /* HAVE_RECV */ | ||||||
| #ifdef DJGPP |  | ||||||
| #define sread(x,y,z) (ssize_t)read_s((int)(x), (char *)(y), (int)(z)) |  | ||||||
| #endif |  | ||||||
| #ifndef sread | #ifndef sread | ||||||
|   /* */ |   /* */ | ||||||
|   Error Missing_definition_of_macro_sread |   Error Missing_definition_of_macro_sread | ||||||
| @@ -94,9 +101,6 @@ | |||||||
|                                     (SEND_TYPE_ARG4)(SEND_4TH_ARG)) |                                     (SEND_TYPE_ARG4)(SEND_4TH_ARG)) | ||||||
| #endif | #endif | ||||||
| #else /* HAVE_SEND */ | #else /* HAVE_SEND */ | ||||||
| #ifdef DJGPP |  | ||||||
| #define swrite(x,y,z) (ssize_t)write_s((int)(x), (char *)(y), (int)(z)) |  | ||||||
| #endif |  | ||||||
| #ifndef swrite | #ifndef swrite | ||||||
|   /* */ |   /* */ | ||||||
|   Error Missing_definition_of_macro_swrite |   Error Missing_definition_of_macro_swrite | ||||||
| @@ -105,5 +109,38 @@ | |||||||
| #endif /* HAVE_SEND */ | #endif /* HAVE_SEND */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Uppercase macro versions of ANSI/ISO is*() functions/macros which  | ||||||
|  |  * avoid negative number inputs with argument byte codes > 127. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #define ISSPACE(x)  (isspace((int)  ((unsigned char)x))) | ||||||
|  | #define ISDIGIT(x)  (isdigit((int)  ((unsigned char)x))) | ||||||
|  | #define ISALNUM(x)  (isalnum((int)  ((unsigned char)x))) | ||||||
|  | #define ISXDIGIT(x) (isxdigit((int) ((unsigned char)x))) | ||||||
|  | #define ISGRAPH(x)  (isgraph((int)  ((unsigned char)x))) | ||||||
|  | #define ISALPHA(x)  (isalpha((int)  ((unsigned char)x))) | ||||||
|  | #define ISPRINT(x)  (isprint((int)  ((unsigned char)x))) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Typedef to 'int' if sig_atomic_t is not an available 'typedefed' type. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef HAVE_SIG_ATOMIC_T | ||||||
|  | typedef int sig_atomic_t; | ||||||
|  | #define HAVE_SIG_ATOMIC_T | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Default return type for signal handlers. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef RETSIGTYPE | ||||||
|  | #define RETSIGTYPE void | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* __SETUP_ONCE_H */ | #endif /* __SETUP_ONCE_H */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -129,6 +129,10 @@ SOURCE=..\..\ares_gethostbyname.c | |||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
|  |  | ||||||
|  | SOURCE=..\..\ares_getsock.c | ||||||
|  | # End Source File | ||||||
|  | # Begin Source File | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_init.c | SOURCE=..\..\ares_init.c | ||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2006, 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 | ||||||
| @@ -140,7 +140,7 @@ 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_pversion=`$libtool --version 2>/dev/null|head -n 2|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | ||||||
| if test -z "$lt_pversion"; then | if test -z "$lt_pversion"; 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" | ||||||
|   | |||||||
| @@ -5,7 +5,6 @@ REM $Date$ | |||||||
|  |  | ||||||
| REM create ca-bundle.h | REM create ca-bundle.h | ||||||
| echo /* This file is generated automatically */ >lib\ca-bundle.h | echo /* This file is generated automatically */ >lib\ca-bundle.h | ||||||
| echo #define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE") >>lib\ca-bundle.h |  | ||||||
|  |  | ||||||
| REM create hugehelp.c | REM create hugehelp.c | ||||||
| copy src\hugehelp.c.cvs src\hugehelp.c | copy src\hugehelp.c.cvs src\hugehelp.c | ||||||
|   | |||||||
							
								
								
									
										82
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										82
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -28,7 +28,7 @@ dnl We don't know the version number "staticly" so we use a dash here | |||||||
| AC_INIT(curl, [-], [a suitable curl mailing list => http://curl.haxx.se/mail/]) | AC_INIT(curl, [-], [a suitable curl mailing list => http://curl.haxx.se/mail/]) | ||||||
|  |  | ||||||
| dnl configure script copyright | dnl configure script copyright | ||||||
| AC_COPYRIGHT([Copyright (c) 1998 - 2005 Daniel Stenberg, <daniel@haxx.se> | AC_COPYRIGHT([Copyright (c) 1998 - 2006 Daniel Stenberg, <daniel@haxx.se> | ||||||
| This configure script may be copied, distributed and modified under the  | This configure script may be copied, distributed and modified under the  | ||||||
| terms of the curl license; see COPYING for more details]) | terms of the curl license; see COPYING for more details]) | ||||||
|  |  | ||||||
| @@ -78,6 +78,7 @@ AC_SUBST(PKGADD_VENDOR) | |||||||
| dnl | dnl | ||||||
| dnl initialize all the info variables | dnl initialize all the info variables | ||||||
|     curl_ssl_msg="no      (--with-ssl / --with-gnutls)" |     curl_ssl_msg="no      (--with-ssl / --with-gnutls)" | ||||||
|  |     curl_ssh_msg="no      (--with-libssh2)" | ||||||
|    curl_zlib_msg="no      (--with-zlib)" |    curl_zlib_msg="no      (--with-zlib)" | ||||||
|    curl_krb4_msg="no      (--with-krb4*)" |    curl_krb4_msg="no      (--with-krb4*)" | ||||||
|     curl_gss_msg="no      (--with-gssapi)" |     curl_gss_msg="no      (--with-gssapi)" | ||||||
| @@ -747,7 +748,7 @@ AC_ARG_WITH(gssapi-includes, | |||||||
| AC_ARG_WITH(gssapi-libs, | AC_ARG_WITH(gssapi-libs, | ||||||
|   AC_HELP_STRING([--with-gssapi-libs=DIR], |   AC_HELP_STRING([--with-gssapi-libs=DIR], | ||||||
|   		 [Specify location of GSSAPI libs]), |   		 [Specify location of GSSAPI libs]), | ||||||
|   [ GSSAPI_LIBS="-L$withval" |   [ GSSAPI_LIB_DIR="-L$withval" | ||||||
|     want_gss="yes" ] |     want_gss="yes" ] | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -1043,6 +1044,74 @@ if test X"$OPT_SSL" != Xno; then | |||||||
|  |  | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check for the presence of LIBSSH2 libraries and headers | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | dnl Default to compiler & linker defaults for LIBSSH2 files & libraries. | ||||||
|  | OPT_LIBSSH2=off | ||||||
|  | AC_ARG_WITH(libssh2,dnl | ||||||
|  | AC_HELP_STRING([--with-libssh2=PATH],[Where to look for libssh2, PATH points to the LIBSSH2 installation (default: /usr/local/lib); when possible, set the PKG_CONFIG_PATH environment variable instead of using this option]) | ||||||
|  | AC_HELP_STRING([--without-libssh2], [disable LIBSSH2]), | ||||||
|  |   OPT_LIBSSH2=$withval) | ||||||
|  |  | ||||||
|  | if test X"$OPT_LIBSSH2" != Xno; then | ||||||
|  |   dnl backup the pre-libssh2 variables | ||||||
|  |   CLEANLDFLAGS="$LDFLAGS" | ||||||
|  |   CLEANCPPFLAGS="$CPPFLAGS" | ||||||
|  |   CLEANLIBS="$LIBS" | ||||||
|  |  | ||||||
|  |   case "$OPT_LIBSSH2" in | ||||||
|  |   yes) | ||||||
|  |     dnl --with-libssh2 (without path) used | ||||||
|  |     PREFIX_LIBSSH2=/usr/local/lib | ||||||
|  |     LIB_LIBSSH2="$PREFIX_LIBSSH2/lib$libsuff" | ||||||
|  |     ;; | ||||||
|  |   off) | ||||||
|  |     dnl no --with-libssh2 option given, just check default places | ||||||
|  |     PREFIX_LIBSSH2= | ||||||
|  |     ;; | ||||||
|  |   *) | ||||||
|  |     dnl use the given --with-libssh2 spot | ||||||
|  |     PREFIX_LIBSSH2=$OPT_LIBSSH2 | ||||||
|  |     LIB_LIBSSH2="$PREFIX_LIBSSH2/lib$libsuff" | ||||||
|  |     LDFLAGS="$LDFLAGS -L$LIB_LIBSSH2" | ||||||
|  |     CPPFLAGS="$CPPFLAGS -I$PREFIX_LIBSSH2/include" | ||||||
|  |     ;; | ||||||
|  |   esac | ||||||
|  |  | ||||||
|  |   if test X"$HAVECRYPTO" = X"yes"; then | ||||||
|  |     dnl This is only reasonable to do if crypto actually is there: check for | ||||||
|  |     dnl LIBSSH2 libs NOTE: it is important to do this AFTER the crypto lib | ||||||
|  |  | ||||||
|  |     AC_CHECK_LIB(ssh2, libssh2_channel_open_ex) | ||||||
|  |      | ||||||
|  |     AC_CHECK_HEADERS(libssh2.h, | ||||||
|  |       curl_ssh_msg="enabled (libSSH2)" | ||||||
|  |       LIBSSH2_ENABLED=1 | ||||||
|  |       AC_DEFINE(USE_LIBSSH2, 1, [if libSSH2 is in use])) | ||||||
|  |  | ||||||
|  |     if test X"$OPT_LIBSSH2" != Xoff && | ||||||
|  |        test "$LIBSSH2_ENABLED" != "1"; then | ||||||
|  |       AC_MSG_ERROR([libSSH2 libs and/or directories were not found where specified!]) | ||||||
|  |     fi | ||||||
|  |   else | ||||||
|  |     AC_MSG_WARN([without the use of OpenSSL libs, libssh2 cannot work]) | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  |   if test "$LIBSSH2_ENABLED" = "1"; then | ||||||
|  |     if test -n "$LIB_LIBSSH2"; then | ||||||
|  |        dnl when the libssh2 shared libs were found in a path that the run-time | ||||||
|  |        dnl linker doesn't search through, we need to add it to LD_LIBRARY_PATH | ||||||
|  |        dnl to prevent further configure tests to fail due to this | ||||||
|  |  | ||||||
|  |        LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_LIBSSH2" | ||||||
|  |        export LD_LIBRARY_PATH | ||||||
|  |        AC_MSG_NOTICE([Added $LIB_LIBSSH2 to LD_LIBRARY_PATH]) | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  | fi | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Check for the random seed preferences  | dnl Check for the random seed preferences  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -1527,6 +1596,8 @@ dnl Checks for typedefs, structures, and compiler characteristics. | |||||||
| AC_C_CONST | AC_C_CONST | ||||||
| AC_TYPE_SIZE_T | AC_TYPE_SIZE_T | ||||||
| AC_HEADER_TIME | AC_HEADER_TIME | ||||||
|  | CURL_CHECK_STRUCT_TIMEVAL | ||||||
|  | CURL_VERIFY_RUNTIMELIBS | ||||||
|  |  | ||||||
| AC_CHECK_SIZEOF(curl_off_t, ,[ | AC_CHECK_SIZEOF(curl_off_t, ,[ | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| @@ -1562,6 +1633,10 @@ TYPE_IN_ADDR_T | |||||||
|  |  | ||||||
| TYPE_SOCKADDR_STORAGE | TYPE_SOCKADDR_STORAGE | ||||||
|  |  | ||||||
|  | TYPE_SIG_ATOMIC_T | ||||||
|  |  | ||||||
|  | AC_TYPE_SIGNAL | ||||||
|  |  | ||||||
| AC_FUNC_SELECT_ARGTYPES | AC_FUNC_SELECT_ARGTYPES | ||||||
|  |  | ||||||
| CURL_CHECK_FUNC_RECV | CURL_CHECK_FUNC_RECV | ||||||
| @@ -1572,7 +1647,7 @@ CURL_CHECK_MSG_NOSIGNAL | |||||||
|  |  | ||||||
| dnl Checks for library functions. | dnl Checks for library functions. | ||||||
| dnl AC_PROG_GCC_TRADITIONAL | dnl AC_PROG_GCC_TRADITIONAL | ||||||
| AC_TYPE_SIGNAL |  | ||||||
| dnl AC_FUNC_VPRINTF | dnl AC_FUNC_VPRINTF | ||||||
| case $host in | case $host in | ||||||
|   *msdosdjgpp) |   *msdosdjgpp) | ||||||
| @@ -2074,6 +2149,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | |||||||
|   Install prefix:  ${prefix} |   Install prefix:  ${prefix} | ||||||
|   Compiler:        ${CC} |   Compiler:        ${CC} | ||||||
|   SSL support:     ${curl_ssl_msg} |   SSL support:     ${curl_ssl_msg} | ||||||
|  |   SSH support:     ${curl_ssh_msg} | ||||||
|   zlib support:    ${curl_zlib_msg} |   zlib support:    ${curl_zlib_msg} | ||||||
|   krb4 support:    ${curl_krb4_msg} |   krb4 support:    ${curl_krb4_msg} | ||||||
|   GSSAPI support:  ${curl_gss_msg} |   GSSAPI support:  ${curl_gss_msg} | ||||||
|   | |||||||
| @@ -142,8 +142,8 @@ Rexx | |||||||
|  |  | ||||||
| Ruby | Ruby | ||||||
|  |  | ||||||
|   Written by Hirotaka Matsuyuki |   Written by Ross Bamford | ||||||
|   http://www.d1.dion.ne.jp/~matuyuki/ruby.html |   http://curb.rubyforge.org/ | ||||||
|  |  | ||||||
| Scheme | Scheme | ||||||
|  |  | ||||||
| @@ -155,6 +155,11 @@ S-Lang | |||||||
|   S-Lang binding written by John E Davis |   S-Lang binding written by John E Davis | ||||||
|   http://www.jedsoft.org/slang/modules/curl.html |   http://www.jedsoft.org/slang/modules/curl.html | ||||||
|  |  | ||||||
|  | Smalltalk | ||||||
|  |  | ||||||
|  |   Smalltalk binding written by Danil Osipchuk | ||||||
|  |   http://www.squeaksource.com/CurlPlugin/ | ||||||
|  |  | ||||||
| SPL | SPL | ||||||
|  |  | ||||||
|   SPL binding written by Clifford Wolf |   SPL binding written by Clifford Wolf | ||||||
|   | |||||||
| @@ -87,7 +87,6 @@ FTP | |||||||
|  - via http-proxy |  - via http-proxy | ||||||
|  - all operations can be tunneled through a http-proxy |  - all operations can be tunneled through a http-proxy | ||||||
|  - customizable to retrieve file modification date |  - customizable to retrieve file modification date | ||||||
|  - third party transfers |  | ||||||
|  - no dir depth limit |  - no dir depth limit | ||||||
|  |  | ||||||
| FTPS (*1) | FTPS (*1) | ||||||
|   | |||||||
							
								
								
									
										129
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										129
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -16,7 +16,6 @@ Installing Binary Packages | |||||||
|  |  | ||||||
| UNIX | UNIX | ||||||
| ==== | ==== | ||||||
|  |  | ||||||
|    A normal unix installation is made in three or four steps (after you've |    A normal unix installation is made in three or four steps (after you've | ||||||
|    unpacked the source archive): |    unpacked the source archive): | ||||||
|  |  | ||||||
| @@ -141,6 +140,7 @@ UNIX | |||||||
|      yassl with its OpenSSL emulation enabled and point to that directory root |      yassl with its OpenSSL emulation enabled and point to that directory root | ||||||
|      with configure --with-ssl. |      with configure --with-ssl. | ||||||
|  |  | ||||||
|  |  | ||||||
| Win32 | Win32 | ||||||
| ===== | ===== | ||||||
|  |  | ||||||
| @@ -153,7 +153,16 @@ Win32 | |||||||
|  |  | ||||||
|    If you have any problems linking libraries or finding header files, be sure |    If you have any problems linking libraries or finding header files, be sure | ||||||
|    to verify that the provided "Makefile.m32" files use the proper paths, and |    to verify that the provided "Makefile.m32" files use the proper paths, and | ||||||
|    adjust as necessary. |    adjust as necessary. It is also possible to override these paths with  | ||||||
|  |    environment variables, for example: | ||||||
|  |  | ||||||
|  |      set ZLIB_PATH=c:\zlib-1.2.3 | ||||||
|  |      set OPENSSL_PATH=c:\openssl-0.9.8d | ||||||
|  |      set LIBSSH2_PATH=c:\libssh2-0.15 | ||||||
|  |  | ||||||
|  |    ATTENTION: if you want to build with libssh2 support you have to use latest | ||||||
|  |    sources fetched from CVS - the current 0.14 release will NOT work! | ||||||
|  |    Use 'make mingw32-ssh2-ssl' to build curl with SSH2 and SSL enabled. | ||||||
|  |  | ||||||
|    Cygwin |    Cygwin | ||||||
|    ------ |    ------ | ||||||
| @@ -184,7 +193,7 @@ Win32 | |||||||
|    documentation on how to compile zlib. Define the ZLIB_PATH environment |    documentation on how to compile zlib. Define the ZLIB_PATH environment | ||||||
|    variable to the location of zlib.h and zlib.lib, for example: |    variable to the location of zlib.h and zlib.lib, for example: | ||||||
|  |  | ||||||
|      set ZLIB_PATH=c:\zlib-1.2.1 |      set ZLIB_PATH=c:\zlib-1.2.3 | ||||||
|  |  | ||||||
|    Then run 'nmake vc-zlib' in curl's root directory. |    Then run 'nmake vc-zlib' in curl's root directory. | ||||||
|  |  | ||||||
| @@ -198,7 +207,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.7d |      set OPENSSL_PATH=c:\openssl-0.9.8d | ||||||
|  |  | ||||||
|    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 | ||||||
| @@ -292,7 +301,6 @@ Win32 | |||||||
|  |  | ||||||
| IBM OS/2 | IBM OS/2 | ||||||
| ======== | ======== | ||||||
|  |  | ||||||
|    Building under OS/2 is not much different from building under unix. |    Building under OS/2 is not much different from building under unix. | ||||||
|    You need: |    You need: | ||||||
|  |  | ||||||
| @@ -320,6 +328,7 @@ IBM OS/2 | |||||||
|    If you're getting huge binaries, probably your makefiles have the -g in |    If you're getting huge binaries, probably your makefiles have the -g in | ||||||
|    CFLAGS. |    CFLAGS. | ||||||
|  |  | ||||||
|  |  | ||||||
| VMS | VMS | ||||||
| === | === | ||||||
|    (The VMS section is in whole contributed by the friendly Nico Baggus) |    (The VMS section is in whole contributed by the friendly Nico Baggus) | ||||||
| @@ -390,6 +399,7 @@ VMS | |||||||
|    13-jul-2001 |    13-jul-2001 | ||||||
|    N. Baggus |    N. Baggus | ||||||
|  |  | ||||||
|  |  | ||||||
| QNX | QNX | ||||||
| === | === | ||||||
|    (This section was graciously brought to us by David Bentham) |    (This section was graciously brought to us by David Bentham) | ||||||
| @@ -441,17 +451,16 @@ AmigaOS | |||||||
|  |  | ||||||
| NetWare | NetWare | ||||||
| ======= | ======= | ||||||
|  |  | ||||||
|    To compile curl.nlm / libcurl.nlm you need: |    To compile curl.nlm / libcurl.nlm you need: | ||||||
|    - either any gcc / nlmconv, or CodeWarrior 7 PDK 4 or later. |    - either any gcc / nlmconv, or CodeWarrior 7 PDK 4 or later. | ||||||
|    - gnu make and awk running on the platform you compile on; |    - gnu make and awk running on the platform you compile on; | ||||||
|      native Win32 versions can be downloaded from: |      native Win32 versions can be downloaded from: | ||||||
|      http://www.gknw.com/development/prgtools/ |      http://www.gknw.net/development/prgtools/ | ||||||
|    - recent Novell LibC SDK available from: |    - recent Novell LibC SDK available from: | ||||||
|      http://developer.novell.com/ndk/libc.htm |      http://developer.novell.com/ndk/libc.htm | ||||||
|    - optional zlib sources (at the moment only dynamic linking with zlib.imp); |    - optional zlib sources (at the moment only dynamic linking with zlib.imp); | ||||||
|      sources with NetWare Makefile can be obtained from: |      sources with NetWare Makefile can be obtained from: | ||||||
|      http://www.gknw.com/mirror/zlib/ |      http://www.gknw.net/mirror/zlib/ | ||||||
|    - optional OpenSSL sources (version 0.9.8 or later which builds with BSD); |    - optional OpenSSL sources (version 0.9.8 or later which builds with BSD); | ||||||
|  |  | ||||||
|    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 | ||||||
| @@ -465,14 +474,101 @@ NetWare | |||||||
|    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked... |    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked... | ||||||
|    Any help in testing appreciated! |    Any help in testing appreciated! | ||||||
|    Builds automatically created 8 times a day from current CVS are here: |    Builds automatically created 8 times a day from current CVS are here: | ||||||
|    http://www.gknw.com/mirror/curl/autobuilds/ |    http://www.gknw.net/mirror/curl/autobuilds/ | ||||||
|    the status of these builds can be viewed at the autobuild table: |    the status of these builds can be viewed at the autobuild table: | ||||||
|    http://curl.haxx.se/auto/ |    http://curl.haxx.se/auto/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | eCos | ||||||
|  | ==== | ||||||
|  |    curl does not use the eCos build system, so you must first build eCos | ||||||
|  |    separately, then link curl to the resulting eCos library.  Here's a sample | ||||||
|  |    configure line to do so on an x86 Linux box targeting x86: | ||||||
|  |  | ||||||
|  |    GCCLIB=`gcc -print-libgcc-file-name` && \ | ||||||
|  |    CFLAGS="-D__ECOS=1 -nostdinc -I$ECOS_INSTALL/include \ | ||||||
|  |     -I`dirname $GCCLIB`/include" \ | ||||||
|  |    LDFLAGS="-nostdlib -Wl,--gc-sections -Wl,-static \ | ||||||
|  |     -L$ECOS_INSTALL/lib -Ttarget.ld -ltarget" \ | ||||||
|  |    ./configure --host=i386 --disable-shared \ | ||||||
|  |     --without-ssl --without-zlib --disable-manual --disable-ldap | ||||||
|  |  | ||||||
|  |    In most cases, eCos users will be using libcurl from within a custom | ||||||
|  |    embedded application.  Using the standard 'curl' executable from | ||||||
|  |    within eCos means facing the limitation of the standard eCos C | ||||||
|  |    startup code which does not allow passing arguments in main().  To | ||||||
|  |    run 'curl' from eCos and have it do something useful, you will need | ||||||
|  |    to either modify the eCos startup code to pass in some arguments, or | ||||||
|  |    modify the curl application itself to retrieve its arguments from | ||||||
|  |    some location set by the bootloader or hard-code them. | ||||||
|  |  | ||||||
|  |    Something like the following patch could be used to hard-code some | ||||||
|  |    arguments.  The MTAB_ENTRY line mounts a RAM disk as the root filesystem | ||||||
|  |    (without mounting some kind of filesystem, eCos errors out all file | ||||||
|  |    operations which curl does not take to well).  The next section synthesizes | ||||||
|  |    some command-line arguments for curl to use, in this case to direct curl | ||||||
|  |    to read further arguments from a file.  It then creates that file on the | ||||||
|  |    RAM disk and places within it a URL to download: a file: URL that | ||||||
|  |    just happens to point to the configuration file itself.  The results | ||||||
|  |    of running curl in this way is the contents of the configuration file | ||||||
|  |    printed to the console. | ||||||
|  |  | ||||||
|  | --- src/main.c	19 Jul 2006 19:09:56 -0000	1.363 | ||||||
|  | +++ src/main.c	24 Jul 2006 21:37:23 -0000 | ||||||
|  | @@ -4286,11 +4286,31 @@ | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |   | ||||||
|  | +#ifdef __ECOS | ||||||
|  | +#include <cyg/fileio/fileio.h> | ||||||
|  | +MTAB_ENTRY( testfs_mte1, | ||||||
|  | +                   "/", | ||||||
|  | +                   "ramfs", | ||||||
|  | +                   "", | ||||||
|  | +                   0); | ||||||
|  | +#endif | ||||||
|  |   | ||||||
|  |  int main(int argc, char *argv[]) | ||||||
|  |  { | ||||||
|  |    int res; | ||||||
|  |    struct Configurable config; | ||||||
|  | +#ifdef __ECOS | ||||||
|  | +  char *args[] = {"ecos-curl", "-K", "curlconf.txt"}; | ||||||
|  | +  FILE *f; | ||||||
|  | +  argc = sizeof(args)/sizeof(args[0]); | ||||||
|  | +  argv = args; | ||||||
|  | + | ||||||
|  | +  f = fopen("curlconf.txt", "w"); | ||||||
|  | +  if (f) { | ||||||
|  | +    fprintf(f, "--url file:curlconf.txt"); | ||||||
|  | +    fclose(f); | ||||||
|  | +  } | ||||||
|  | +#endif | ||||||
|  |    memset(&config, 0, sizeof(struct Configurable)); | ||||||
|  |   | ||||||
|  |    config.errors = stderr; /* default errors to stderr */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Minix | ||||||
|  | ===== | ||||||
|  |    curl can be compiled on Minix 3 using gcc (ACK has a few problems due | ||||||
|  |    to mismatched headers and libraries as of ver. 3.1.2).  The gcc and bash | ||||||
|  |    packages must be installed first.  The default heap size allocated to | ||||||
|  |    bash is inadequate for running configure and will result in out of memory | ||||||
|  |    errors.  Increase it with the command: | ||||||
|  |  | ||||||
|  |      chmem =2048000 /usr/local/bin/bash | ||||||
|  |  | ||||||
|  |    Make sure gcc and bash are in the PATH then configure curl with a | ||||||
|  |    command like this: | ||||||
|  |  | ||||||
|  |      ./configure GREP=/usr/bin/grep AR=/usr/gnu/bin/gar --disable-ldap | ||||||
|  |  | ||||||
|  |    Then simply run 'make'. | ||||||
|  |  | ||||||
|  |  | ||||||
| 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 | ||||||
|    Dan Fandrich) |    Dan Fandrich) | ||||||
|  |  | ||||||
| @@ -518,9 +614,9 @@ CROSS COMPILE | |||||||
|  |  | ||||||
|        ./configure --host=ARCH-OS |        ./configure --host=ARCH-OS | ||||||
|  |  | ||||||
|  |  | ||||||
| REDUCING SIZE | REDUCING SIZE | ||||||
| ============= | ============= | ||||||
|  |  | ||||||
|    There are a number of configure options that can be used to reduce the |    There are a number of configure options that can be used to reduce the | ||||||
|    size of libcurl for embedded applications where binary size is an |    size of libcurl for embedded applications where binary size is an | ||||||
|    important factor.  First, be sure to set the CFLAGS variable when |    important factor.  First, be sure to set the CFLAGS variable when | ||||||
| @@ -542,7 +638,7 @@ REDUCING SIZE | |||||||
|      --disable-crypto-auth (disables HTTP cryptographic authentication) |      --disable-crypto-auth (disables HTTP cryptographic authentication) | ||||||
|      --disable-ipv6 (disables support for IPv6) |      --disable-ipv6 (disables support for IPv6) | ||||||
|      --disable-verbose (eliminates debugging strings and error code strings) |      --disable-verbose (eliminates debugging strings and error code strings) | ||||||
|      --enable-hidden-symbols (eliminates unneeded symbols in library) |      --enable-hidden-symbols (eliminates unneeded symbols in the shared library) | ||||||
|      --without-libidn (disables support for the libidn DNS library) |      --without-libidn (disables support for the libidn DNS library) | ||||||
|      --without-ssl (disables support for SSL/TLS) |      --without-ssl (disables support for SSL/TLS) | ||||||
|      --without-zlib (disables support for on-the-fly decompression) |      --without-zlib (disables support for on-the-fly decompression) | ||||||
| @@ -553,7 +649,7 @@ REDUCING SIZE | |||||||
|    Be sure also to strip debugging symbols from your binaries after |    Be sure also to strip debugging symbols from your binaries after | ||||||
|    compiling using 'strip' (or the appropriate variant if cross-compiling). |    compiling using 'strip' (or the appropriate variant if cross-compiling). | ||||||
|    If space is really tight, you may be able to remove some unneeded |    If space is really tight, you may be able to remove some unneeded | ||||||
|    sections of the library using the -R option to objcopy (e.g. the |    sections of the shared library using the -R option to objcopy (e.g. the | ||||||
|    .comment section). |    .comment section). | ||||||
|  |  | ||||||
|    Using these techniques it is possible to create an HTTP-only shared |    Using these techniques it is possible to create an HTTP-only shared | ||||||
| @@ -589,6 +685,7 @@ PORTS | |||||||
|         - PowerPC Linux |         - PowerPC Linux | ||||||
|         - PowerPC Mac OS 9 |         - PowerPC Mac OS 9 | ||||||
|         - PowerPC Mac OS X |         - PowerPC Mac OS X | ||||||
|  |         - SuperH4 Linux 2.6.X | ||||||
|         - SINIX-Z v5 |         - SINIX-Z v5 | ||||||
|         - Sparc Linux |         - Sparc Linux | ||||||
|         - Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8, 9, 10 |         - Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8, 9, 10 | ||||||
| @@ -597,12 +694,15 @@ PORTS | |||||||
|         - StrongARM/ARM7/ARM9 Linux 2.4, 2.6 |         - StrongARM/ARM7/ARM9 Linux 2.4, 2.6 | ||||||
|         - StrongARM NetBSD 1.4.1 |         - StrongARM NetBSD 1.4.1 | ||||||
|         - Ultrix 4.3a |         - Ultrix 4.3a | ||||||
|  |         - UNICOS 9.0 | ||||||
|         - i386 BeOS |         - i386 BeOS | ||||||
|         - i386 DOS |         - i386 DOS | ||||||
|  |         - i386 eCos 1.3.1 | ||||||
|         - i386 Esix 4.1 |         - i386 Esix 4.1 | ||||||
|         - i386 FreeBSD |         - i386 FreeBSD | ||||||
|         - i386 HURD |         - i386 HURD | ||||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 |         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 | ||||||
|  |         - i386 MINIX 3.1.2 | ||||||
|         - i386 NetBSD |         - i386 NetBSD | ||||||
|         - i386 Novell NetWare |         - i386 Novell NetWare | ||||||
|         - i386 OS/2 |         - i386 OS/2 | ||||||
| @@ -627,3 +727,6 @@ OpenSSL   http://www.openssl.org | |||||||
| MingW     http://www.mingw.org | MingW     http://www.mingw.org | ||||||
| OpenLDAP  http://www.openldap.org | OpenLDAP  http://www.openldap.org | ||||||
| Zlib      http://www.gzip.org/zlib/ | Zlib      http://www.gzip.org/zlib/ | ||||||
|  | libssh2   http://www.libssh2.org | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,7 +3,31 @@ 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! | ||||||
|  |  | ||||||
| 34. The SOCKS connection codes don't properly acknowledge (connect) timeouts. | 41. Jeff Pohlmeyer's curl_multi_socket crashing case. Recipe and instructions | ||||||
|  |   here: http://curl.haxx.se/mail/lib-2007-01/0022.html | ||||||
|  |  | ||||||
|  | 40. HTTP Pipelining, NULL content | ||||||
|  |   http://curl.haxx.se/bug/view.cgi?id=1631566 | ||||||
|  |  | ||||||
|  | 39. Steffen Rumler's Race Condition in Curl_proxyCONNECT: | ||||||
|  |   http://curl.haxx.se/mail/lib-2007-01/0045.html | ||||||
|  |  | ||||||
|  | 38. Kumar Swamy Bhatt's problem in ftp/ssl "LIST" operation: | ||||||
|  |   http://curl.haxx.se/mail/lib-2007-01/0103.html | ||||||
|  |  | ||||||
|  | 37. Having more than one connection to the same host when doing NTLM | ||||||
|  |   authentication (with performs multiple "passes" and authenticates a | ||||||
|  |   connection rather than a HTTP request), and particularly when using the | ||||||
|  |   multi interface, there's a risk that libcurl will re-use a wrong connection | ||||||
|  |   when doing the different passes in the NTLM negotiation and thus fail to | ||||||
|  |   negotiate (in seemingly mysterious ways). | ||||||
|  |  | ||||||
|  | 35. Both SOCKS5 and SOCKS4 proxy connections are done blocking, which is very | ||||||
|  |   bad when used with the multi interface. | ||||||
|  |  | ||||||
|  | 34. The SOCKS4 connection codes don't properly acknowledge (connect) timeouts. | ||||||
|  |   Also see #12. According to bug #1556528, even the SOCKS5 connect code does | ||||||
|  |   not do it right: http://curl.haxx.se/bug/view.cgi?id=1556528, | ||||||
|  |  | ||||||
| 33. Doing multi-pass HTTP authentication on a non-default port does not work. | 33. Doing multi-pass HTTP authentication on a non-default port does not work. | ||||||
|   This happens because the multi-pass code abuses the redirect following code |   This happens because the multi-pass code abuses the redirect following code | ||||||
| @@ -39,12 +63,6 @@ may have been fixed since this was written! | |||||||
|   "system context" will make it use wrong(?) user name - at least when compared |   "system context" will make it use wrong(?) user name - at least when compared | ||||||
|   to what winhttp does. See http://curl.haxx.se/bug/view.cgi?id=1281867 |   to what winhttp does. See http://curl.haxx.se/bug/view.cgi?id=1281867 | ||||||
|  |  | ||||||
| 25. When doing a CONNECT request with curl it doesn't properly handle if the |  | ||||||
|   proxy closes the connection within the authentication "negotiation phase". |  | ||||||
|   Like if you do HTTPS or similar over a proxy and you use perhaps |  | ||||||
|   --proxy-anyauth. There's work in progress on this problem, and a recent |  | ||||||
|   patch was posted here: http://curl.haxx.se/mail/lib-2005-08/0074.html |  | ||||||
|  |  | ||||||
| 23. We don't support SOCKS for IPv6. We don't support FTPS over a SOCKS proxy. | 23. We don't support SOCKS for IPv6. We don't support FTPS over a SOCKS proxy. | ||||||
|   We don't have any test cases for SOCKS proxy. We probably have even more |   We don't have any test cases for SOCKS proxy. We probably have even more | ||||||
|   bugs and lack of features when a SOCKS proxy is used. And there seem to be a |   bugs and lack of features when a SOCKS proxy is used. And there seem to be a | ||||||
| @@ -68,9 +86,6 @@ may have been fixed since this was written! | |||||||
|  |  | ||||||
|    Since 7.15.4 at least line endings are converted. |    Since 7.15.4 at least line endings are converted. | ||||||
|  |  | ||||||
| 19. FTP 3rd party transfers with the multi interface doesn't work. Test: |  | ||||||
|   define CURL_MULTIEASY, rebuild curl, run test case 230 - 232. |  | ||||||
|  |  | ||||||
| 16. FTP URLs passed to curl may contain NUL (0x00) in the RFC 1738 <user>, | 16. FTP URLs passed to curl may contain NUL (0x00) in the RFC 1738 <user>, | ||||||
|   <password>, and <fpath> components, encoded as "%00".  The problem is that |   <password>, and <fpath> components, encoded as "%00".  The problem is that | ||||||
|   curl_unescape does not detect this, but instead returns a shortened C |   curl_unescape does not detect this, but instead returns a shortened C | ||||||
| @@ -92,7 +107,7 @@ may have been fixed since this was written! | |||||||
|  |  | ||||||
| 12. When connecting to a SOCKS proxy, the (connect) timeout is not properly | 12. When connecting to a SOCKS proxy, the (connect) timeout is not properly | ||||||
|   acknowledged after the actual TCP connect (during the SOCKS "negotiate" |   acknowledged after the actual TCP connect (during the SOCKS "negotiate" | ||||||
|   phase). Pointed out by Lucas. Fix: need to select() and timeout properly. |   phase). | ||||||
|  |  | ||||||
| 11. Using configure --disable-[protocol] may cause 'make test' to fail for | 11. Using configure --disable-[protocol] may cause 'make test' to fail for | ||||||
|   tests using the disabled protocol(s). |   tests using the disabled protocol(s). | ||||||
|   | |||||||
							
								
								
									
										31
									
								
								docs/MANUAL
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								docs/MANUAL
									
									
									
									
									
								
							| @@ -31,6 +31,15 @@ SIMPLE USAGE | |||||||
|  |  | ||||||
|         curl ftp://cool.haxx.se/ http://www.weirdserver.com:8000/ |         curl ftp://cool.haxx.se/ http://www.weirdserver.com:8000/ | ||||||
|  |  | ||||||
|  |   Get a file off an FTPS server: | ||||||
|  |  | ||||||
|  |         curl ftps://files.are.secure.com/secrets.txt | ||||||
|  |  | ||||||
|  |   or use the more appropriate FTPS way to get the same file: | ||||||
|  |  | ||||||
|  |         curl --ftp-ssl ftp://files.are.secure.com/secrets.txt | ||||||
|  |  | ||||||
|  |  | ||||||
| DOWNLOAD TO A FILE | DOWNLOAD TO A FILE | ||||||
|  |  | ||||||
|   Get a web page and store in a local file: |   Get a web page and store in a local file: | ||||||
| @@ -64,6 +73,10 @@ USING PASSWORDS | |||||||
|    It is just like for FTP, but you may also want to specify and use |    It is just like for FTP, but you may also want to specify and use | ||||||
|    SSL-specific options for certificates etc. |    SSL-specific options for certificates etc. | ||||||
|  |  | ||||||
|  |    Note that using FTPS:// as prefix is the "implicit" way as described in the | ||||||
|  |    standards while the recommended "explicit" way is done by using FTP:// and | ||||||
|  |    the --ftp-ssl option. | ||||||
|  |  | ||||||
|  HTTP |  HTTP | ||||||
|  |  | ||||||
|    The HTTP URL doesn't support user and password in the URL string. Curl |    The HTTP URL doesn't support user and password in the URL string. Curl | ||||||
| @@ -105,6 +118,8 @@ PROXY | |||||||
|  |  | ||||||
|         curl -U user:passwd -x my-proxy:888 http://www.get.this/ |         curl -U user:passwd -x my-proxy:888 http://www.get.this/ | ||||||
|  |  | ||||||
|  |  curl also supports SOCKS4 and SOCKS5 proxies with --socks4 and --socks5. | ||||||
|  |  | ||||||
|  See also the environment variables Curl support that offer further proxy |  See also the environment variables Curl support that offer further proxy | ||||||
|  control. |  control. | ||||||
|  |  | ||||||
| @@ -846,6 +861,22 @@ PERSISTENT CONNECTIONS | |||||||
|   transfers faster. If you use a http proxy for file transfers, practically |   transfers faster. If you use a http proxy for file transfers, practically | ||||||
|   all transfers will be persistent. |   all transfers will be persistent. | ||||||
|  |  | ||||||
|  | MULTIPLE TRANSFERS WITH A SINGLE COMMAND LINE | ||||||
|  |  | ||||||
|  |   As is mentioned above, you can download multiple files with one command line | ||||||
|  |   by simply adding more URLs. If you want those to get saved to a local file | ||||||
|  |   instead of just printed to stdout, you need to add one save option for each | ||||||
|  |   URL you specify. Note that this also goes for the -O option. | ||||||
|  |  | ||||||
|  |   For example: get two files and use -O for the first and a custom file | ||||||
|  |   name for the second: | ||||||
|  |  | ||||||
|  |     curl -O http://url.com/file.txt ftp://ftp.com/moo.exe -o moo.jpg | ||||||
|  |  | ||||||
|  |   You can also upload multiple files in a similar fashion: | ||||||
|  |  | ||||||
|  |     curl -T local1 ftp://ftp.com/moo.exe -T local2 ftp://ftp.com/moo2.txt | ||||||
|  |  | ||||||
| MAILING LISTS | MAILING LISTS | ||||||
|  |  | ||||||
|   For your convenience, we have several open mailing lists to discuss curl, |   For your convenience, we have several open mailing lists to discuss curl, | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -17,6 +17,7 @@ Alexander Kourakos | |||||||
| Alexander Krasnostavsky | Alexander Krasnostavsky | ||||||
| Alexander Lazic | Alexander Lazic | ||||||
| Alexander Zhuravlev | Alexander Zhuravlev | ||||||
|  | Alexey Simak | ||||||
| Alexis Carvalho | Alexis Carvalho | ||||||
| Amol Pattekar | Amol Pattekar | ||||||
| Andi Jahja | Andi Jahja | ||||||
| @@ -26,6 +27,7 @@ Andreas Olsson | |||||||
| Andreas Rieke | Andreas Rieke | ||||||
| Andres Garcia | Andres Garcia | ||||||
| Andrew Benham | Andrew Benham | ||||||
|  | Andrew Biggs | ||||||
| Andrew Bushnell | Andrew Bushnell | ||||||
| Andrew Francis | Andrew Francis | ||||||
| Andrew Fuller | Andrew Fuller | ||||||
| @@ -36,18 +38,23 @@ Angus Mackay | |||||||
| Antoine Calando | Antoine Calando | ||||||
| Anton Kalmykov | Anton Kalmykov | ||||||
| Arkadiusz Miskiewicz | Arkadiusz Miskiewicz | ||||||
|  | Armel Asselin | ||||||
|  | Arve Knudsen | ||||||
| Ates Goral | Ates Goral | ||||||
| Augustus Saunders | Augustus Saunders | ||||||
| Avery Fay | Avery Fay | ||||||
| Ben Greear | Ben Greear | ||||||
| Ben Madsen | Ben Madsen | ||||||
| Benjamin Gerard | Benjamin Gerard | ||||||
|  | Bernard Leak | ||||||
| Bertrand Demiddelaer | Bertrand Demiddelaer | ||||||
| Bjorn Reese | Bjorn Reese | ||||||
| Bj<EFBFBD>rn Stenberg | Bj<EFBFBD>rn Stenberg | ||||||
| Bob Schader | Bob Schader | ||||||
|  | Bogdan Nicula | ||||||
| Brad Burdick | Brad Burdick | ||||||
| Bradford Bruce | Bradford Bruce | ||||||
|  | Brendan Jurd | ||||||
| Brent Beardsley | Brent Beardsley | ||||||
| Brian Akins | Brian Akins | ||||||
| Brian Dessent | Brian Dessent | ||||||
| @@ -67,6 +74,7 @@ Christian Robottom Reis | |||||||
| Christophe Demory | Christophe Demory | ||||||
| Christophe Legry | Christophe Legry | ||||||
| Christopher R. Palmer | Christopher R. Palmer | ||||||
|  | Ciprian Badescu | ||||||
| Clarence Gardner | Clarence Gardner | ||||||
| Clifford Wolf | Clifford Wolf | ||||||
| Cody Jones | Cody Jones | ||||||
| @@ -81,6 +89,7 @@ Damien Adant | |||||||
| Dan Becker | Dan Becker | ||||||
| Dan C | Dan C | ||||||
| Dan Fandrich | Dan Fandrich | ||||||
|  | Dan Nelson | ||||||
| Dan Torop | Dan Torop | ||||||
| Dan Zitter | Dan Zitter | ||||||
| Daniel Stenberg | Daniel Stenberg | ||||||
| @@ -114,7 +123,9 @@ Dimitris Sarris | |||||||
| Dinar | Dinar | ||||||
| Dirk Eddelbuettel | Dirk Eddelbuettel | ||||||
| Dirk Manske | Dirk Manske | ||||||
|  | Dmitriy Sergeyev | ||||||
| Dmitry Bartsevich | Dmitry Bartsevich | ||||||
|  | Dmitry Rechkin | ||||||
| Dolbneff A.V | Dolbneff A.V | ||||||
| Domenico Andreoli | Domenico Andreoli | ||||||
| Dominick Meglio | Dominick Meglio | ||||||
| @@ -194,6 +205,7 @@ Ignacio Vazquez-Abrams | |||||||
| Igor Polyakov | Igor Polyakov | ||||||
| Ilguiz Latypov | Ilguiz Latypov | ||||||
| Ilja van Sprundel | Ilja van Sprundel | ||||||
|  | Ingmar Runge | ||||||
| Ingo Ralf Blum | Ingo Ralf Blum | ||||||
| Ingo Wilken | Ingo Wilken | ||||||
| Jacky Lam | Jacky Lam | ||||||
| @@ -203,11 +215,14 @@ James Clancy | |||||||
| James Cone | James Cone | ||||||
| James Gallagher | James Gallagher | ||||||
| James Griffiths | James Griffiths | ||||||
|  | James Housley | ||||||
| James MacMillan | James MacMillan | ||||||
| Jamie Lokier | Jamie Lokier | ||||||
| Jamie Newton | Jamie Newton | ||||||
| Jamie Wilkinson | Jamie Wilkinson | ||||||
| Jan Kunder | Jan Kunder | ||||||
|  | Jared Lundell | ||||||
|  | Jari Sundell | ||||||
| Jason S. Priebe | Jason S. Priebe | ||||||
| Jaz Fresh | Jaz Fresh | ||||||
| Jean Jacques Drouin | Jean Jacques Drouin | ||||||
| @@ -292,6 +307,7 @@ Lucas Adamski | |||||||
| Lukasz Czekierda | Lukasz Czekierda | ||||||
| Luke Call | Luke Call | ||||||
| Luong Dinh Dung | Luong Dinh Dung | ||||||
|  | Maciej Karpiuk | ||||||
| Maciej W. Rozycki | Maciej W. Rozycki | ||||||
| Marc Boucher | Marc Boucher | ||||||
| Marcelo Juchem  | Marcelo Juchem  | ||||||
| @@ -301,18 +317,21 @@ Marcus Webster | |||||||
| Mario Schroeder | Mario Schroeder | ||||||
| Mark Butler | Mark Butler | ||||||
| Mark Eichin | Mark Eichin | ||||||
|  | Mark Lentczner | ||||||
| Markus Koetter | Markus Koetter | ||||||
| Markus Moeller | Markus Moeller | ||||||
| Markus Oberhumer | Markus Oberhumer | ||||||
| Martijn Koster | Martijn Koster | ||||||
| Martin C. Martin | Martin C. Martin | ||||||
| Martin Hedenfalk | Martin Hedenfalk | ||||||
|  | Martin Skinner | ||||||
| Marty Kuhrt | Marty Kuhrt | ||||||
| Maruko | Maruko | ||||||
| Massimiliano Ziccardi | Massimiliano Ziccardi | ||||||
| Mathias Axelsson | Mathias Axelsson | ||||||
| Mats Lidell | Mats Lidell | ||||||
| Matt Veenstra | Matt Veenstra | ||||||
|  | Matt Witherspoon | ||||||
| Matthew Blain | Matthew Blain | ||||||
| Matthew Clarke | Matthew Clarke | ||||||
| Maurice Barnum | Maurice Barnum | ||||||
| @@ -321,6 +340,7 @@ Mettgut Jamalla | |||||||
| Michael Benedict | Michael Benedict | ||||||
| Michael Curtis | Michael Curtis | ||||||
| Michael Jahn | Michael Jahn | ||||||
|  | Michael Jerris | ||||||
| Michael Mealling | Michael Mealling | ||||||
| Michael Wallner | Michael Wallner | ||||||
| Michal Bonino | Michal Bonino | ||||||
| @@ -330,12 +350,14 @@ Mihai Ionescu | |||||||
| Mikael Sennerholm | Mikael Sennerholm | ||||||
| Mike Bytnar | Mike Bytnar | ||||||
| Mike Dobbs | Mike Dobbs | ||||||
|  | Mike Protts | ||||||
| Miklos Nemeth | Miklos Nemeth | ||||||
| Mitz Wark | Mitz Wark | ||||||
| Mohamed Lrhazi | Mohamed Lrhazi | ||||||
| Mohun Biswas | Mohun Biswas | ||||||
| Moonesamy | Moonesamy | ||||||
| Nathan O'Sullivan | Nathan O'Sullivan | ||||||
|  | Nathanael Nerode | ||||||
| Naveen Noel | Naveen Noel | ||||||
| Neil Dunbar | Neil Dunbar | ||||||
| Neil Spring | Neil Spring | ||||||
| @@ -348,10 +370,12 @@ Nicolas Croiset | |||||||
| Nicolas Fran<61>ois | Nicolas Fran<61>ois | ||||||
| Niels van Tongeren | Niels van Tongeren | ||||||
| Nikita Schmidt | Nikita Schmidt | ||||||
|  | Nir Soffer | ||||||
| Nis Jorgensen | Nis Jorgensen | ||||||
| Nodak Sodak | Nodak Sodak | ||||||
| Norbert Novotny | Norbert Novotny | ||||||
| Ofer | Ofer | ||||||
|  | Olaf Stueben | ||||||
| Olaf St<53>ben | Olaf St<53>ben | ||||||
| Oren Tirosh | Oren Tirosh | ||||||
| P R Schaffner | P R Schaffner | ||||||
| @@ -371,6 +395,7 @@ Peter Bray | |||||||
| Peter Forret | Peter Forret | ||||||
| Peter Heuchert | Peter Heuchert | ||||||
| Peter Pentchev | Peter Pentchev | ||||||
|  | Peter Silva | ||||||
| Peter Su | Peter Su | ||||||
| Peter Sylvester | Peter Sylvester | ||||||
| Peter Todd | Peter Todd | ||||||
| @@ -390,6 +415,7 @@ Ralph Beckmann | |||||||
| Ralph Mitchell | Ralph Mitchell | ||||||
| Ramana Mokkapati | Ramana Mokkapati | ||||||
| Randy McMurchy | Randy McMurchy | ||||||
|  | Ravi Pratap | ||||||
| Reinout van Schouwen | Reinout van Schouwen | ||||||
| Renaud Chaillat | Renaud Chaillat | ||||||
| Renaud Duhaut | Renaud Duhaut | ||||||
| @@ -408,6 +434,7 @@ Rick Jones | |||||||
| Rick Richardson | Rick Richardson | ||||||
| Rob Stanzel | Rob Stanzel | ||||||
| Robert D. Young | Robert D. Young | ||||||
|  | Robert Foreman | ||||||
| Robert Olson | Robert Olson | ||||||
| Robert Weaver | Robert Weaver | ||||||
| Robin Kay | Robin Kay | ||||||
| @@ -434,6 +461,7 @@ Scott Davis | |||||||
| Sebastien Willemijns | Sebastien Willemijns | ||||||
| Sergio Ballestrero | Sergio Ballestrero | ||||||
| Seshubabu Pasam | Seshubabu Pasam | ||||||
|  | Sh Diao | ||||||
| Shard | Shard | ||||||
| Shawn Poulson | Shawn Poulson | ||||||
| Shmulik Regev | Shmulik Regev | ||||||
| @@ -444,6 +472,7 @@ Simon Liu | |||||||
| Spiridonoff A.V | Spiridonoff A.V | ||||||
| Stadler Stephan | Stadler Stephan | ||||||
| Stefan Esser | Stefan Esser | ||||||
|  | Stefan Krause | ||||||
| Stefan Ulrich | Stefan Ulrich | ||||||
| Stephan Bergmann | Stephan Bergmann | ||||||
| Stephen Kick | Stephen Kick | ||||||
| @@ -481,6 +510,7 @@ Tomas Szepe | |||||||
| Tomasz Lacki | Tomasz Lacki | ||||||
| Tommy Tam | Tommy Tam | ||||||
| Ton Voon | Ton Voon | ||||||
|  | Toon Verwaest | ||||||
| Tor Arntsen | Tor Arntsen | ||||||
| Torsten Foertsch | Torsten Foertsch | ||||||
| Toshiyuki Maezawa | Toshiyuki Maezawa | ||||||
| @@ -490,6 +520,8 @@ Troy Engel | |||||||
| Tupone Alfredo | Tupone Alfredo | ||||||
| Ulf H<>rnhammar | Ulf H<>rnhammar | ||||||
| Ulrich Zadow | Ulrich Zadow | ||||||
|  | Venkat Akella | ||||||
|  | Victor Snezhko | ||||||
| Vilmos Nebehaj | Vilmos Nebehaj | ||||||
| Vincent Bronner | Vincent Bronner | ||||||
| Vincent Penquerc'h | Vincent Penquerc'h | ||||||
| @@ -506,6 +538,7 @@ Wojciech Zwiefka | |||||||
| Xavier Bouchoux | Xavier Bouchoux | ||||||
| Yang Tse | Yang Tse | ||||||
| Yarram Sunil | Yarram Sunil | ||||||
|  | Yves Lejeune | ||||||
| Zvi Har'El  | Zvi Har'El  | ||||||
| nk | nk | ||||||
| swalkaus at yahoo.com | swalkaus at yahoo.com | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -43,10 +43,6 @@ TODO | |||||||
|    powered libcurl the default build (which of course would require that we'd |    powered libcurl the default build (which of course would require that we'd | ||||||
|    bundle the c-ares source code in the libcurl source code releases). |    bundle the c-ares source code in the libcurl source code releases). | ||||||
|  |  | ||||||
|  * Support CONNECT 407 responses that kill the connection and expect the |  | ||||||
|    client to reconnect to complete the authentication. Currently libcurl |  | ||||||
|    assumes that a proxy connection will be kept alive. |  | ||||||
|  |  | ||||||
|  * Make the curl/*.h headers include the proper system includes based on what |  * Make the curl/*.h headers include the proper system includes based on what | ||||||
|    was present at the time when configure was run. Currently, the sys/select.h |    was present at the time when configure was run. Currently, the sys/select.h | ||||||
|    header is for example included by curl/multi.h only on specific platforms |    header is for example included by curl/multi.h only on specific platforms | ||||||
| @@ -115,10 +111,6 @@ TODO | |||||||
|  |  | ||||||
|  HTTP |  HTTP | ||||||
|  |  | ||||||
|  * Pipelining. Sending multiple requests before the previous one(s) are done. |  | ||||||
|    This could possibly be implemented using the multi interface to queue |  | ||||||
|    requests and the response data. |  | ||||||
|  |  | ||||||
|  * When doing CONNECT to a HTTP proxy, libcurl always uses HTTP/1.0. This has |  * When doing CONNECT to a HTTP proxy, libcurl always uses HTTP/1.0. This has | ||||||
|    never been reported as causing trouble to anyone, but should be considered |    never been reported as causing trouble to anyone, but should be considered | ||||||
|    to use the HTTP version the user has chosen. |    to use the HTTP version the user has chosen. | ||||||
| @@ -192,8 +184,8 @@ TODO | |||||||
|  |  | ||||||
|  * Fix the connection phase to be non-blocking when multi interface is used |  * Fix the connection phase to be non-blocking when multi interface is used | ||||||
|  |  | ||||||
|  * Add a way to check if the connection seems to be alive, to corrspond to the |  * Add a way to check if the connection seems to be alive, to correspond to | ||||||
|    SSL_peak() way we use with OpenSSL. |    the SSL_peak() way we use with OpenSSL. | ||||||
|  |  | ||||||
|  LDAP |  LDAP | ||||||
|  |  | ||||||
| @@ -205,10 +197,6 @@ TODO | |||||||
|  |  | ||||||
|  * RTSP - RFC2326 (protocol - very HTTP-like, also contains URL description) |  * RTSP - RFC2326 (protocol - very HTTP-like, also contains URL description) | ||||||
|  |  | ||||||
|  * SFTP/SCP/SSH (no RFCs for protocol nor URI/URL format). An implementation |  | ||||||
|    should most probably use an existing ssh library, such as OpenSSH. or |  | ||||||
|    libssh2.org |  | ||||||
|  |  | ||||||
|  * RSYNC (no RFCs for protocol nor URI/URL format).  An implementation should |  * RSYNC (no RFCs for protocol nor URI/URL format).  An implementation should | ||||||
|    most probably use an existing rsync library, such as librsync. |    most probably use an existing rsync library, such as librsync. | ||||||
|  |  | ||||||
| @@ -277,6 +265,10 @@ TODO | |||||||
|  |  | ||||||
|  TEST SUITE |  TEST SUITE | ||||||
|  |  | ||||||
|  |  * Make our own version of stunnel for simple port forwarding to enable HTTPS | ||||||
|  |    and FTP-SSL tests without the stunnel dependency, and it could allow us to | ||||||
|  |    provide test tools built with either OpenSSL or GnuTLS | ||||||
|  |  | ||||||
|  * Make the test servers able to serve multiple running test suites. Like if |  * Make the test servers able to serve multiple running test suites. Like if | ||||||
|    two users run 'make test' at once. |    two users run 'make test' at once. | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										118
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										118
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2007, 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 1 "21 Mar 2006" "Curl 7.15.4" "Curl Manual" | .TH curl 1 "3 Nov 2006" "Curl 7.16.1" "Curl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl \- transfer a URL | curl \- transfer a URL | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -30,13 +30,13 @@ curl \- transfer a URL | |||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| .B curl | .B curl | ||||||
| is a tool to transfer data from or to a server, using one of the supported | is a tool to transfer data from or to a server, using one of the supported | ||||||
| protocols (HTTP, HTTPS, FTP, FTPS, TFTP, DICT, TELNET, LDAP or FILE). | protocols (HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, DICT, TELNET, LDAP or | ||||||
| The command is designed to work without user interaction. | FILE).  The command is designed to work without user interaction. | ||||||
|  |  | ||||||
| curl offers a busload of useful tricks like proxy support, user | curl offers a busload of useful tricks like proxy support, user | ||||||
| authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file | authentication, ftp upload, HTTP post, SSL connections, cookies, file transfer | ||||||
| transfer resume and more. As you will see below, the amount of features will | resume and more. As you will see below, the amount of features will make your | ||||||
| make your head spin! | head spin! | ||||||
|  |  | ||||||
| curl is powered by libcurl for all transfer-related features. See | curl is powered by libcurl for all transfer-related features. See | ||||||
| .BR libcurl (3) | .BR libcurl (3) | ||||||
| @@ -312,25 +312,25 @@ run curl. | |||||||
|  |  | ||||||
| If this option is used several times, each occurrence will toggle this on/off. | If this option is used several times, each occurrence will toggle this on/off. | ||||||
| .IP "--egd-file <file>" | .IP "--egd-file <file>" | ||||||
| (HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The | (SSL) Specify the path name to the Entropy Gathering Daemon socket. The socket | ||||||
| socket is used to seed the random engine for SSL connections. See also the | is used to seed the random engine for SSL connections. See also the | ||||||
| \fI--random-file\fP option. | \fI--random-file\fP option. | ||||||
| .IP "-E/--cert <certificate[:password]>" | .IP "-E/--cert <certificate[:password]>" | ||||||
| (HTTPS) | (SSL) Tells curl to use the specified certificate file when getting a file | ||||||
| Tells curl to use the specified certificate file when getting a file | with HTTPS or FTPS. The certificate must be in PEM format.  If the optional | ||||||
| with HTTPS. The certificate must be in PEM format. | password isn't specified, it will be queried for on the terminal. Note that | ||||||
| If the optional password isn't specified, it will be queried for on | this option assumes a \&"certificate" file that is the private key and the | ||||||
| the terminal. Note that this certificate is the private key and the private | private certificate concatenated! See \fI--cert\fP and \fI--key\fP to specify | ||||||
| certificate concatenated! | them independently. | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--cert-type <type>" | .IP "--cert-type <type>" | ||||||
| (SSL) Tells curl what certificate type the provided certificate is in. PEM, | (SSL) Tells curl what certificate type the provided certificate is in. PEM, | ||||||
| DER and ENG are recognized types. | DER and ENG are recognized types.  If not specified, PEM is assumed. | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--cacert <CA certificate>" | .IP "--cacert <CA certificate>" | ||||||
| (HTTPS) Tells curl to use the specified certificate file to verify the | (SSL) Tells curl to use the specified certificate file to verify the | ||||||
| peer. The file may contain multiple CA certificates. The certificate(s) must | peer. The file may contain multiple CA certificates. The certificate(s) must | ||||||
| be in PEM format. | be in PEM format. | ||||||
|  |  | ||||||
| @@ -344,10 +344,10 @@ Current Working Directory, or in any folder along your PATH. | |||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--capath <CA certificate directory>" | .IP "--capath <CA certificate directory>" | ||||||
| (HTTPS) Tells curl to use the specified certificate directory to verify the | (SSL) Tells curl to use the specified certificate directory to verify the | ||||||
| peer. The certificates must be in PEM format, and the directory must have been | peer. The certificates must be in PEM format, and the directory must have been | ||||||
| processed using the c_rehash utility supplied with openssl. Using | processed using the c_rehash utility supplied with openssl. Using | ||||||
| \fI--capath\fP can allow curl to make https connections much more efficiently | \fI--capath\fP can allow curl to make SSL-connections much more efficiently | ||||||
| than using \fI--cacert\fP if the \fI--cacert\fP file contains many CA | than using \fI--cacert\fP if the \fI--cacert\fP file contains many CA | ||||||
| certificates. | certificates. | ||||||
|  |  | ||||||
| @@ -359,6 +359,10 @@ normal cases when a HTTP server fails to deliver a document, it returns an | |||||||
| HTML document stating so (which often also describes why and more). This flag | HTML document stating so (which often also describes why and more). This flag | ||||||
| will prevent curl from outputting that and return error 22. | will prevent curl from outputting that and return error 22. | ||||||
|  |  | ||||||
|  | This method is not fail-safe and there are occasions where non-succesful | ||||||
|  | response codes will slip through, especially when authentication is involved | ||||||
|  | (response codes 401 and 407). | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable silent failure. | If this option is used twice, the second will again disable silent failure. | ||||||
| .IP "--ftp-account [data]" | .IP "--ftp-account [data]" | ||||||
| (FTP) When an FTP server asks for "account data" after user name and password | (FTP) When an FTP server asks for "account data" after user name and password | ||||||
| @@ -395,7 +399,6 @@ in 7.11.0) | |||||||
|  |  | ||||||
| If this option is used several times, the following occurrences make no | If this option is used several times, the following occurrences make no | ||||||
| difference. | difference. | ||||||
|  |  | ||||||
| .IP "--ftp-alternative-to-user <command>" | .IP "--ftp-alternative-to-user <command>" | ||||||
| (FTP) If authenticating with the USER and PASS commands fails, send this | (FTP) If authenticating with the USER and PASS commands fails, send this | ||||||
| command.  When connecting to Tumbleweed's Secure Transport server over FTPS | command.  When connecting to Tumbleweed's Secure Transport server over FTPS | ||||||
| @@ -412,9 +415,16 @@ This option has no effect if PORT, EPRT or EPSV is used instead of PASV. | |||||||
| If this option is used twice, the second will again use the server's suggested | If this option is used twice, the second will again use the server's suggested | ||||||
| address. | address. | ||||||
| .IP "--ftp-ssl" | .IP "--ftp-ssl" | ||||||
| (FTP) Try to use SSL/TLS for the FTP connection. | (FTP) Try to use SSL/TLS for the FTP connection.  Reverts to a non-secure | ||||||
| Reverts to a non-secure connection if the server doesn't support SSL/TLS. | connection if the server doesn't support SSL/TLS.  See also | ||||||
| (Added in 7.11.0) | \fI--ftp-ssl-control\fP and \fI--ftp-ssl-reqd\fP for different levels of | ||||||
|  | encryption required. (Added in 7.11.0) | ||||||
|  |  | ||||||
|  | If this option is used twice, the second will again disable this. | ||||||
|  | .IP "--ftp-ssl-control" | ||||||
|  | (FTP) Require SSL/TLS for the ftp login, clear for transfer.  Allows secure | ||||||
|  | authentication, but non-encrypted data transfers for efficiency.  Fails the | ||||||
|  | transfer if the server doesn't support SSL/TLS.  (Added in 7.16.0) | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable this. | If this option is used twice, the second will again disable this. | ||||||
| .IP "--ftp-ssl-reqd" | .IP "--ftp-ssl-reqd" | ||||||
| @@ -422,6 +432,14 @@ If this option is used twice, the second will again disable this. | |||||||
| Terminates the connection if the server doesn't support SSL/TLS. | Terminates the connection if the server doesn't support SSL/TLS. | ||||||
| (Added in 7.15.5) | (Added in 7.15.5) | ||||||
|  |  | ||||||
|  | If this option is used twice, the second will again disable this. | ||||||
|  | .IP "--ftp-ssl-ccc" | ||||||
|  | (FTP) Use CCC (Clear Command Channel) | ||||||
|  | Shuts down the SSL/TLS layer after authenticating. The rest of the | ||||||
|  | control channel communication will be unencrypted. This allows | ||||||
|  | NAT routers to follow the FTP transaction. | ||||||
|  | (Added in 7.16.1) | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable this. | If this option is used twice, the second will again disable this. | ||||||
| .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 | ||||||
| @@ -489,9 +507,9 @@ of extra headers. Note that if you should add a custom header that has the | |||||||
| same name as one of the internal ones curl would use, your externally set | same name as one of the internal ones curl would use, your externally set | ||||||
| header will be used instead of the internal one. This allows you to make even | header will be used instead of the internal one. This allows you to make even | ||||||
| trickier stuff than curl would normally do. You should not replace internally | trickier stuff than curl would normally do. You should not replace internally | ||||||
| set headers without knowing perfectly well what you're doing. Replacing an | set headers without knowing perfectly well what you're doing. Remove an | ||||||
| internal header with one without content on the right side of the colon will | internal header by giving a replacement without content on the right side of | ||||||
| prevent that header from appearing. | the colon, as in: -H \&"Host:". | ||||||
|  |  | ||||||
| curl will make sure that each header you add/replace get sent with the proper | curl will make sure that each header you add/replace get sent with the proper | ||||||
| end of line marker, you should thus \fBnot\fP add that as a part of the header | end of line marker, you should thus \fBnot\fP add that as a part of the header | ||||||
| @@ -540,6 +558,9 @@ and transfers. All SSL connections are attempted to be made secure by using | |||||||
| the CA certificate bundle installed by default. This makes all connections | the CA certificate bundle installed by default. This makes all connections | ||||||
| considered "insecure" to fail unless \fI-k/--insecure\fP is used. | considered "insecure" to fail unless \fI-k/--insecure\fP is used. | ||||||
|  |  | ||||||
|  | See this online resource for further details: | ||||||
|  | \fBhttp://curl.haxx.se/docs/sslcerts.html\fP | ||||||
|  |  | ||||||
| If this option is used twice, the second time will again disable it. | If this option is used twice, the second time will again disable it. | ||||||
| .IP "--key <key>" | .IP "--key <key>" | ||||||
| (SSL) Private key file name. Allows you to provide your private key in this | (SSL) Private key file name. Allows you to provide your private key in this | ||||||
| @@ -548,7 +569,8 @@ separate file. | |||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--key-type <type>" | .IP "--key-type <type>" | ||||||
| (SSL) Private key file type. Specify which type your \fI--key\fP provided | (SSL) Private key file type. Specify which type your \fI--key\fP provided | ||||||
| private key is. DER, PEM and ENG are supported. | private key is. DER, PEM and ENG are supported. If not specified, PEM is | ||||||
|  | assumed. | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--krb4 <level>" | .IP "--krb4 <level>" | ||||||
| @@ -577,7 +599,7 @@ line. So, it could look similar to this: | |||||||
|  |  | ||||||
| url = "http://curl.haxx.se/docs/" | url = "http://curl.haxx.se/docs/" | ||||||
|  |  | ||||||
| This option can be used multiple times. | This option can be used multiple times to load multiple config files. | ||||||
|  |  | ||||||
| When curl is invoked, it always (unless \fI-q\fP is used) checks for a default | When curl is invoked, it always (unless \fI-q\fP is used) checks for a default | ||||||
| config file and uses it if found. The default config file is checked for in | config file and uses it if found. The default config file is checked for in | ||||||
| @@ -592,6 +614,12 @@ resort the '%USERPROFILE%\Application Data'. | |||||||
| 2) On windows, if there is no _curlrc file in the home dir, it checks for one | 2) On windows, if there is no _curlrc file in the home dir, it checks for one | ||||||
| in the same dir the executable curl is placed. On unix-like systems, it will | in the same dir the executable curl is placed. On unix-like systems, it will | ||||||
| simply try to load .curlrc from the determined home dir. | simply try to load .curlrc from the determined home dir. | ||||||
|  | .IP "--libcurl <file>" | ||||||
|  | Append this option to any ordinary curl command line, and you will get a | ||||||
|  | libcurl-using source code written to the file that does the equivalent | ||||||
|  | operation of what your command line operation does! | ||||||
|  |  | ||||||
|  | If this option is used several times, the last given file name will be used. | ||||||
| .IP "--limit-rate <speed>" | .IP "--limit-rate <speed>" | ||||||
| Specify the maximum transfer rate you want curl to use. This feature is useful | Specify the maximum transfer rate you want curl to use. This feature is useful | ||||||
| if you have a limited pipe and you'd like your transfer not use your entire | if you have a limited pipe and you'd like your transfer not use your entire | ||||||
| @@ -601,6 +629,10 @@ The given speed is measured in bytes/second, unless a suffix is appended. | |||||||
| Appending 'k' or 'K' will count the number as kilobytes, 'm' or M' makes it | Appending 'k' or 'K' will count the number as kilobytes, 'm' or M' makes it | ||||||
| megabytes while 'g' or 'G' makes it gigabytes. Examples: 200K, 3m and 1G. | megabytes while 'g' or 'G' makes it gigabytes. Examples: 200K, 3m and 1G. | ||||||
|  |  | ||||||
|  | The given rate is the average speed, counted during the entire transfer. It | ||||||
|  | means that curl might use higher transfer speeds in short bursts, but over | ||||||
|  | time it uses no more than the given rate. | ||||||
|  |  | ||||||
| If you are also using the \fI-Y/--speed-limit\fP option, that option will take | If you are also using the \fI-Y/--speed-limit\fP option, that option will take | ||||||
| precedence and might cripple the rate-limiting slightly, to help keeping the | precedence and might cripple the rate-limiting slightly, to help keeping the | ||||||
| speed-limit logic working. | speed-limit logic working. | ||||||
| @@ -705,6 +737,15 @@ will output the data in chunks, not necessarily exactly when the data arrives. | |||||||
| Using this option will disable that buffering. | Using this option will disable that buffering. | ||||||
|  |  | ||||||
| If this option is used twice, the second will again switch on buffering. | If this option is used twice, the second will again switch on buffering. | ||||||
|  | .IP "--no-sessionid" | ||||||
|  | (SSL) Disable curl's use of SSL session-ID caching.  By default all transfers | ||||||
|  | are done using the cache. Note that while nothing ever should get hurt by | ||||||
|  | attempting to reuse SSL session-IDs, there seem to be broken SSL | ||||||
|  | implementations in the wild that may require you to disable this in order for | ||||||
|  | you to succeed. (Added in 7.16.0) | ||||||
|  |  | ||||||
|  | If this option is used twice, the second will again switch on use of the | ||||||
|  | session cache. | ||||||
| .IP "--ntlm" | .IP "--ntlm" | ||||||
| (HTTP) Enables NTLM authentication. The NTLM authentication method was | (HTTP) Enables NTLM authentication. The NTLM authentication method was | ||||||
| designed by Microsoft and is used by IIS web servers. It is a proprietary | designed by Microsoft and is used by IIS web servers. It is a proprietary | ||||||
| @@ -818,7 +859,7 @@ must send syntactically correct FTP commands as RFC959 defines. | |||||||
|  |  | ||||||
| This option can be used multiple times. | This option can be used multiple times. | ||||||
| .IP "--random-file <file>" | .IP "--random-file <file>" | ||||||
| (HTTPS) Specify the path name to file containing what will be considered as | (SSL) Specify the path name to file containing what will be considered as | ||||||
| random data. The data is used to seed the random engine for SSL connections. | random data. The data is used to seed the random engine for SSL connections. | ||||||
| See also the \fI--egd-file\fP option. | See also the \fI--egd-file\fP option. | ||||||
| .IP "-r/--range <range>" | .IP "-r/--range <range>" | ||||||
| @@ -1196,7 +1237,7 @@ not set. | |||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "-z/--time-cond <date expression>" | .IP "-z/--time-cond <date expression>" | ||||||
| (HTTP) Request a file that has been modified later than the given time and | (HTTP/FTP) Request a file that has been modified later than the given time and | ||||||
| date, or one that has been modified before that time. The date expression can | date, or one that has been modified before that time. The date expression can | ||||||
| be all sorts of date strings or if it doesn't match any internal ones, it | be all sorts of date strings or if it doesn't match any internal ones, it | ||||||
| tries to get the time from a given file name instead! See the | tries to get the time from a given file name instead! See the | ||||||
| @@ -1218,25 +1259,14 @@ If this option is used several times, the last one will be used. | |||||||
| (HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its | (HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its | ||||||
| internally preferred: HTTP 1.1. | internally preferred: HTTP 1.1. | ||||||
| .IP "-1/--tlsv1" | .IP "-1/--tlsv1" | ||||||
| (HTTPS) | (SSL) | ||||||
| Forces curl to use TSL version 1 when negotiating with a remote TLS server. | Forces curl to use TSL version 1 when negotiating with a remote TLS server. | ||||||
| .IP "-2/--sslv2" | .IP "-2/--sslv2" | ||||||
| (HTTPS) | (SSL) | ||||||
| Forces curl to use SSL version 2 when negotiating with a remote SSL server. | Forces curl to use SSL version 2 when negotiating with a remote SSL server. | ||||||
| .IP "-3/--sslv3" | .IP "-3/--sslv3" | ||||||
| (HTTPS) | (SSL) | ||||||
| Forces curl to use SSL version 3 when negotiating with a remote SSL server. | Forces curl to use SSL version 3 when negotiating with a remote SSL server. | ||||||
| .IP "--3p-quote" |  | ||||||
| (FTP) Specify arbitrary commands to send to the source server. See the |  | ||||||
| \fI-Q/--quote\fP option for details. (Added in 7.13.0) |  | ||||||
| .IP "--3p-url" |  | ||||||
| (FTP) Activates a FTP 3rd party transfer. Specifies the source URL to get a |  | ||||||
| file from, while the "normal" URL will be used as target URL, the file that |  | ||||||
| will be written/created. |  | ||||||
|  |  | ||||||
| Note that not all FTP server allow 3rd party transfers. (Added in 7.13.0) |  | ||||||
| .IP "--3p-user" |  | ||||||
| (FTP) Specify user:password for the source URL transfer. (Added in 7.13.0) |  | ||||||
| .IP "-4/--ipv4" | .IP "-4/--ipv4" | ||||||
| If libcurl is capable of resolving an address to multiple IP versions (which | If libcurl is capable of resolving an address to multiple IP versions (which | ||||||
| it is if it is ipv6-capable), this option tells libcurl to resolve names to | it is if it is ipv6-capable), this option tells libcurl to resolve names to | ||||||
|   | |||||||
							
								
								
									
										166
									
								
								docs/examples/10-at-a-time.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								docs/examples/10-at-a-time.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,166 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _ | ||||||
|  |  *  Project                     ___| | | |  _ \| | | ||||||
|  |  *                             / __| | | | |_) | | | ||||||
|  |  *                            | (__| |_| |  _ <| |___ | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * Example application source code using the multi interface to download many | ||||||
|  |  * files, but with a capped maximum amount of simultaneous transfers. | ||||||
|  |  * | ||||||
|  |  * Written by Michael Wallner | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <curl/multi.h> | ||||||
|  |  | ||||||
|  | static const char *urls[] = { | ||||||
|  |   "http://www.microsoft.com", | ||||||
|  |   "http://www.opensource.org", | ||||||
|  |   "http://www.google.com", | ||||||
|  |   "http://www.yahoo.com", | ||||||
|  |   "http://www.ibm.com", | ||||||
|  |   "http://www.mysql.com", | ||||||
|  |   "http://www.oracle.com", | ||||||
|  |   "http://www.ripe.net", | ||||||
|  |   "http://www.iana.org", | ||||||
|  |   "http://www.amazon.com", | ||||||
|  |   "http://www.netcraft.com", | ||||||
|  |   "http://www.heise.de", | ||||||
|  |   "http://www.chip.de", | ||||||
|  |   "http://www.ca.com", | ||||||
|  |   "http://www.cnet.com", | ||||||
|  |   "http://www.news.com", | ||||||
|  |   "http://www.cnn.com", | ||||||
|  |   "http://www.wikipedia.org", | ||||||
|  |   "http://www.dell.com", | ||||||
|  |   "http://www.hp.com", | ||||||
|  |   "http://www.cert.org", | ||||||
|  |   "http://www.mit.edu", | ||||||
|  |   "http://www.nist.gov", | ||||||
|  |   "http://www.ebay.com", | ||||||
|  |   "http://www.playstation.com", | ||||||
|  |   "http://www.uefa.com", | ||||||
|  |   "http://www.ieee.org", | ||||||
|  |   "http://www.apple.com", | ||||||
|  |   "http://www.sony.com", | ||||||
|  |   "http://www.symantec.com", | ||||||
|  |   "http://www.zdnet.com", | ||||||
|  |   "http://www.fujitsu.com", | ||||||
|  |   "http://www.supermicro.com", | ||||||
|  |   "http://www.hotmail.com", | ||||||
|  |   "http://www.ecma.com", | ||||||
|  |   "http://www.bbc.co.uk", | ||||||
|  |   "http://news.google.com", | ||||||
|  |   "http://www.foxnews.com", | ||||||
|  |   "http://www.msn.com", | ||||||
|  |   "http://www.wired.com", | ||||||
|  |   "http://www.sky.com", | ||||||
|  |   "http://www.usatoday.com", | ||||||
|  |   "http://www.cbs.com", | ||||||
|  |   "http://www.nbc.com", | ||||||
|  |   "http://slashdot.org", | ||||||
|  |   "http://www.bloglines.com", | ||||||
|  |   "http://www.techweb.com", | ||||||
|  |   "http://www.newslink.org", | ||||||
|  |   "http://www.un.org", | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #define MAX 10 /* number of simultaneous transfers */ | ||||||
|  | #define CNT sizeof(urls)/sizeof(char*) /* total number of transfers to do */ | ||||||
|  |  | ||||||
|  | static int cb(char *d, size_t n, size_t l, void *p) | ||||||
|  | { | ||||||
|  |   /* take care of the data here, ignored in this example */ | ||||||
|  |   (void)d; | ||||||
|  |   (void)p; | ||||||
|  |   return n*l; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | static void init(CURLM *cm, int i) | ||||||
|  | { | ||||||
|  |   CURL *eh = curl_easy_init(); | ||||||
|  |  | ||||||
|  |   curl_easy_setopt(eh, CURLOPT_WRITEFUNCTION, cb); | ||||||
|  |   curl_easy_setopt(eh, CURLOPT_HEADER, 0); | ||||||
|  |   curl_easy_setopt(eh, CURLOPT_URL, urls[i]); | ||||||
|  |   curl_easy_setopt(eh, CURLOPT_PRIVATE, urls[i]); | ||||||
|  |   curl_easy_setopt(eh, CURLOPT_VERBOSE, 0); | ||||||
|  |  | ||||||
|  |   curl_multi_add_handle(cm, eh); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int main(void) | ||||||
|  | { | ||||||
|  |   CURLM *cm; | ||||||
|  |   CURLMsg *msg; | ||||||
|  |   long L; | ||||||
|  |   unsigned int C=0; | ||||||
|  |   int M, Q, U = -1; | ||||||
|  |   fd_set R, W, E; | ||||||
|  |   struct timeval T; | ||||||
|  |  | ||||||
|  |   curl_global_init(CURL_GLOBAL_ALL); | ||||||
|  |  | ||||||
|  |   cm = curl_multi_init(); | ||||||
|  |  | ||||||
|  |   for (C = 0; C < MAX; ++C) { | ||||||
|  |     init(cm, C); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   while (U) { | ||||||
|  |     while (CURLM_CALL_MULTI_PERFORM == curl_multi_perform(cm, &U)); | ||||||
|  |  | ||||||
|  |     if (U) { | ||||||
|  |       FD_ZERO(&R); | ||||||
|  |       FD_ZERO(&W); | ||||||
|  |       FD_ZERO(&E); | ||||||
|  |  | ||||||
|  |       if (curl_multi_fdset(cm, &R, &W, &E, &M)) { | ||||||
|  |         fprintf(stderr, "E: curl_multi_fdset\n"); | ||||||
|  |         return EXIT_FAILURE; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       /* In a real-world program you OF COURSE check the return that maxfd is | ||||||
|  |          bigger than -1 so that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|  |       if (curl_multi_timeout(cm, &L)) { | ||||||
|  |         fprintf(stderr, "E: curl_multi_timeout\n"); | ||||||
|  |         return EXIT_FAILURE; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       T.tv_sec = L/1000; | ||||||
|  |       T.tv_usec = (L%1000)*1000; | ||||||
|  |  | ||||||
|  |       if (0 > select(M+1, &R, &W, &E, &T)) { | ||||||
|  |         fprintf(stderr, "E: select\n"); | ||||||
|  |         return EXIT_FAILURE; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     while ((msg = curl_multi_info_read(cm, &Q))) { | ||||||
|  |       if (msg->msg == CURLMSG_DONE) { | ||||||
|  |         char *url; | ||||||
|  |         CURL *e = msg->easy_handle; | ||||||
|  |         curl_easy_getinfo(msg->easy_handle, CURLINFO_PRIVATE, &url); | ||||||
|  |         fprintf(stderr, "R: %d - %s <%s>\n", | ||||||
|  |                 msg->data.result, curl_easy_strerror(msg->data.result), url); | ||||||
|  |         curl_multi_remove_handle(cm, e); | ||||||
|  |         curl_easy_cleanup(e); | ||||||
|  |       } | ||||||
|  |       else { | ||||||
|  |         fprintf(stderr, "E: CURLMsg (%d)\n", msg->msg); | ||||||
|  |       } | ||||||
|  |       if (C < CNT) { | ||||||
|  |         init(cm, C++); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   curl_multi_cleanup(cm); | ||||||
|  |   curl_global_cleanup(); | ||||||
|  |  | ||||||
|  |   return EXIT_SUCCESS; | ||||||
|  | } | ||||||
| @@ -11,7 +11,8 @@ EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c		\ | |||||||
|  multi-post.c fopen.c simplepost.c makefile.dj curlx.c https.c		\ |  multi-post.c fopen.c simplepost.c makefile.dj curlx.c https.c		\ | ||||||
|  multi-debugcallback.c fileupload.c getinfo.c ftp3rdparty.c debug.c	\ |  multi-debugcallback.c fileupload.c getinfo.c ftp3rdparty.c debug.c	\ | ||||||
|  anyauthput.c htmltitle.cc htmltidy.c opensslthreadlock.c		\ |  anyauthput.c htmltitle.cc htmltidy.c opensslthreadlock.c		\ | ||||||
|  cookie_interface.c cacertinmem.c synctime.c sampleconv.c ftpuploadresume.c |  cookie_interface.c cacertinmem.c synctime.c sampleconv.c ftpuploadresume.c \ | ||||||
|  |  10-at-a-time.c hiperfifo.c ghiper.c | ||||||
|  |  | ||||||
| all: | all: | ||||||
| 	@echo "done" | 	@echo "done" | ||||||
|   | |||||||
| @@ -26,9 +26,9 @@ want you do reorganize them like: | |||||||
|   $ `curl-config --cc` -o example example.c `curl-config --cflags --libs` |   $ `curl-config --cc` -o example example.c `curl-config --cflags --libs` | ||||||
|  |  | ||||||
| *PLEASE* do not use the curl.haxx.se site as a test target for your libcurl | *PLEASE* do not use the curl.haxx.se site as a test target for your libcurl | ||||||
| applications/experiments. Even if the examples in this directory use that site | applications/experiments. Even if some of the examples use that site as a URL | ||||||
| as an example URL at some places, it doesn't mean that the URLs work or that | at some places, it doesn't mean that the URLs work or that we expect you to | ||||||
| we expect you to actually torture our web site with your tests! Thanks. | actually torture our web site with your tests!  Thanks. | ||||||
|  |  | ||||||
| EXAMPLES | EXAMPLES | ||||||
|  |  | ||||||
| @@ -43,9 +43,13 @@ fopen.c        - fopen() layer that supports opening URLs and files | |||||||
| ftp3rdparty.c  - FTP 3rd party transfer | ftp3rdparty.c  - FTP 3rd party transfer | ||||||
| ftpget.c       - simple getting a file from FTP | ftpget.c       - simple getting a file from FTP | ||||||
| ftpgetresp.c   - get the response strings from the FTP server | ftpgetresp.c   - get the response strings from the FTP server | ||||||
| ftpupload.c    - upload a file to a FTP server | ftpupload.c    - upload a file to an FTP server | ||||||
|  | ftpuploadresume.c - resume an upload to an FTP server | ||||||
| getinfo.c      - get the Content-Type from the recent transfer | getinfo.c      - get the Content-Type from the recent transfer | ||||||
| getinmemory.c  - download a file to memory only | getinmemory.c  - download a file to memory only | ||||||
|  | ghiper.c       - curl_multi_socket() using code with glib-2 | ||||||
|  | hiperfifo.c    - downloads all URLs written to the fifo, using | ||||||
|  |                  curl_multi_socket() and libevent | ||||||
| htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML | htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML | ||||||
|                  page using libxml |                  page using libxml | ||||||
| http-post.c    - HTTP POST | http-post.c    - HTTP POST | ||||||
| @@ -61,8 +65,12 @@ opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded | |||||||
| persistant.c   - request two URLs with a persistant connection | persistant.c   - request two URLs with a persistant connection | ||||||
| post-callback.c - send a HTTP POST using a callback | post-callback.c - send a HTTP POST using a callback | ||||||
| postit2.c      - send a HTTP multipart formpost | postit2.c      - send a HTTP multipart formpost | ||||||
|  | sampleconv.c   - showing how a program on a non-ASCII platform would invoke | ||||||
|  |                  callbacks to do its own codeset conversions instead of using | ||||||
|  |                  the built-in iconv functions in libcurl | ||||||
| sepheaders.c   - download headers to a separate file | sepheaders.c   - download headers to a separate file | ||||||
| simple.c       - the most simple download a URL source | simple.c       - the most simple download a URL source | ||||||
| simplepost.c   - HTTP POST | simplepost.c   - HTTP POST | ||||||
| simplessl.c    - HTTPS example with certificates many options set | simplessl.c    - HTTPS example with certificates many options set | ||||||
| synctime.c     - Sync local time by extracing date from remote HTTP servers | synctime.c     - Sync local time by extracing date from remote HTTP servers | ||||||
|  | 10-at-a-time.c - Download many files simultaneously, 10 at a time. | ||||||
|   | |||||||
| @@ -114,6 +114,13 @@ static char *curlx_usage[]={ | |||||||
|  |  | ||||||
| */ | */ | ||||||
|  |  | ||||||
|  | /*  | ||||||
|  |  * We use this ZERO_NULL to avoid picky compiler warnings, | ||||||
|  |  * when assigning a NULL pointer to a function pointer var. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #define ZERO_NULL 0 | ||||||
|  |  | ||||||
| /* This is a context that we pass to all callbacks */ | /* This is a context that we pass to all callbacks */ | ||||||
|  |  | ||||||
| typedef struct sslctxparm_st { | typedef struct sslctxparm_st { | ||||||
| @@ -236,7 +243,7 @@ static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) { | |||||||
|  |  | ||||||
|   SSL_CTX_set_verify_depth(ctx,2); |   SSL_CTX_set_verify_depth(ctx,2); | ||||||
|  |  | ||||||
|   SSL_CTX_set_verify(ctx,SSL_VERIFY_PEER,NULL); |   SSL_CTX_set_verify(ctx,SSL_VERIFY_PEER,ZERO_NULL); | ||||||
|  |  | ||||||
|   SSL_CTX_set_cert_verify_callback(ctx, ssl_app_verify_callback, parm); |   SSL_CTX_set_cert_verify_callback(ctx, ssl_app_verify_callback, parm); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -84,6 +84,9 @@ int my_trace(CURL *handle, curl_infotype type, | |||||||
|   case CURLINFO_DATA_OUT: |   case CURLINFO_DATA_OUT: | ||||||
|     text = "=> Send data"; |     text = "=> Send data"; | ||||||
|     break; |     break; | ||||||
|  |   case CURLINFO_SSL_DATA_OUT: | ||||||
|  |     text = "=> Send SSL data"; | ||||||
|  |     break; | ||||||
|   case CURLINFO_HEADER_IN: |   case CURLINFO_HEADER_IN: | ||||||
|     text = "<= Recv header"; |     text = "<= Recv header"; | ||||||
|     break; |     break; | ||||||
| @@ -93,9 +96,6 @@ int my_trace(CURL *handle, curl_infotype type, | |||||||
|   case CURLINFO_SSL_DATA_IN: |   case CURLINFO_SSL_DATA_IN: | ||||||
|     text = "<= Recv SSL data"; |     text = "<= Recv SSL data"; | ||||||
|     break; |     break; | ||||||
|   case CURLINFO_SSL_DATA_OUT: |  | ||||||
|     text = "<= Send SSL data"; |  | ||||||
|     break; |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   dump(text, stderr, data, size, config->trace_ascii); |   dump(text, stderr, data, size, config->trace_ascii); | ||||||
|   | |||||||
| @@ -153,6 +153,10 @@ fill_buffer(URL_FILE *file,int want,int waittime) | |||||||
|         /* get file descriptors from the transfers */ |         /* get file descriptors from the transfers */ | ||||||
|         curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); |         curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |         /* In a real-world program you OF COURSE check the return code of the | ||||||
|  |            function calls, *and* you make sure that maxfd is bigger than -1 | ||||||
|  |            so that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|         rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); |         rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|         switch(rc) { |         switch(rc) { | ||||||
|   | |||||||
							
								
								
									
										461
									
								
								docs/examples/ghiper.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										461
									
								
								docs/examples/ghiper.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,461 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _ | ||||||
|  |  *  Project                     ___| | | |  _ \| | | ||||||
|  |  *                             / __| | | | |_) | | | ||||||
|  |  *                            | (__| |_| |  _ <| |___ | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * Example application source code using the multi socket interface to | ||||||
|  |  * download many files at once. | ||||||
|  |  * | ||||||
|  |  * Written by Jeff Pohlmeyer | ||||||
|  |  | ||||||
|  | Requires glib-2.x and a (POSIX?) system that has mkfifo(). | ||||||
|  |  | ||||||
|  | This is an adaptation of libcurl's "hipev.c" and libevent's "event-test.c" | ||||||
|  | sample programs, adapted to use glib's g_io_channel in place of libevent. | ||||||
|  |  | ||||||
|  | When running, the program creates the named pipe "hiper.fifo" | ||||||
|  |  | ||||||
|  | Whenever there is input into the fifo, the program reads the input as a list | ||||||
|  | of URL's and creates some new easy handles to fetch each URL via the | ||||||
|  | curl_multi "hiper" API. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Thus, you can try a single URL: | ||||||
|  |   % echo http://www.yahoo.com > hiper.fifo | ||||||
|  |  | ||||||
|  | Or a whole bunch of them: | ||||||
|  |   % cat my-url-list > hiper.fifo | ||||||
|  |  | ||||||
|  | The fifo buffer is handled almost instantly, so you can even add more URL's | ||||||
|  | while the previous requests are still being downloaded. | ||||||
|  |  | ||||||
|  | This is purely a demo app, all retrieved data is simply discarded by the write | ||||||
|  | callback. | ||||||
|  |  | ||||||
|  | */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include <glib.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <fcntl.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <errno.h> | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #define MSG_OUT g_print   /* Change to "g_error" to write to stderr */ | ||||||
|  | #define SHOW_VERBOSE 0    /* Set to non-zero for libcurl messages */ | ||||||
|  | #define SHOW_PROGRESS 0   /* Set to non-zero to enable progress callback */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Global information, common to all connections */ | ||||||
|  | typedef struct _GlobalInfo { | ||||||
|  |   CURLM *multi; | ||||||
|  |   guint timer_event; | ||||||
|  |   int prev_running; | ||||||
|  |   int still_running; | ||||||
|  |   int requested; /* count: curl_easy_init() */ | ||||||
|  |   int completed; /* count: curl_easy_cleanup() */ | ||||||
|  | } GlobalInfo; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Information associated with a specific easy handle */ | ||||||
|  | typedef struct _ConnInfo { | ||||||
|  |   CURL *easy; | ||||||
|  |   char *url; | ||||||
|  |   GlobalInfo *global; | ||||||
|  |   char error[CURL_ERROR_SIZE]; | ||||||
|  | } ConnInfo; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Information associated with a specific socket */ | ||||||
|  | typedef struct _SockInfo { | ||||||
|  |   curl_socket_t sockfd; | ||||||
|  |   CURL *easy; | ||||||
|  |   int action; | ||||||
|  |   long timeout; | ||||||
|  |   GIOChannel *ch; | ||||||
|  |   guint ev; | ||||||
|  |   GlobalInfo *global; | ||||||
|  | } SockInfo; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Die if we get a bad CURLMcode somewhere */ | ||||||
|  | static void mcode_or_die(char *where, CURLMcode code) { | ||||||
|  |   if ( CURLM_OK != code ) { | ||||||
|  |     char *s; | ||||||
|  |     switch (code) { | ||||||
|  |       case     CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break; | ||||||
|  |       case     CURLM_OK:                 s="CURLM_OK";                 break; | ||||||
|  |       case     CURLM_BAD_HANDLE:         s="CURLM_BAD_HANDLE";         break; | ||||||
|  |       case     CURLM_BAD_EASY_HANDLE:    s="CURLM_BAD_EASY_HANDLE";    break; | ||||||
|  |       case     CURLM_OUT_OF_MEMORY:      s="CURLM_OUT_OF_MEMORY";      break; | ||||||
|  |       case     CURLM_INTERNAL_ERROR:     s="CURLM_INTERNAL_ERROR";     break; | ||||||
|  |       case     CURLM_BAD_SOCKET:         s="CURLM_BAD_SOCKET";         break; | ||||||
|  |       case     CURLM_UNKNOWN_OPTION:     s="CURLM_UNKNOWN_OPTION";     break; | ||||||
|  |       case     CURLM_LAST:               s="CURLM_LAST";               break; | ||||||
|  |       default: s="CURLM_unknown"; | ||||||
|  |     } | ||||||
|  |     MSG_OUT("ERROR: %s returns %s\n", where, s); | ||||||
|  |     exit(code); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Check for completed transfers, and remove their easy handles */ | ||||||
|  | static void check_run_count(GlobalInfo *g) | ||||||
|  | { | ||||||
|  |   if (g->prev_running > g->still_running) { | ||||||
|  |     char *eff_url=NULL; | ||||||
|  |     CURLMsg *msg; | ||||||
|  |     int msgs_left; | ||||||
|  |     ConnInfo *conn=NULL; | ||||||
|  |     CURL*easy; | ||||||
|  |     CURLcode res; | ||||||
|  |  | ||||||
|  |     MSG_OUT("REMAINING: %d\n", g->still_running); | ||||||
|  |     /* | ||||||
|  |       I am still uncertain whether it is safe to remove an easy handle | ||||||
|  |       from inside the curl_multi_info_read loop, so here I will search | ||||||
|  |       for completed transfers in the inner "while" loop, and then remove | ||||||
|  |       them in the outer "do-while" loop... | ||||||
|  |    */ | ||||||
|  |     do { | ||||||
|  |       easy=NULL; | ||||||
|  |       while ((msg = curl_multi_info_read(g->multi, &msgs_left))) { | ||||||
|  |         if (msg->msg == CURLMSG_DONE) { | ||||||
|  |           easy=msg->easy_handle; | ||||||
|  |           res=msg->data.result; | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       if (easy) { | ||||||
|  |           curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn); | ||||||
|  |           curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url); | ||||||
|  |           MSG_OUT("DONE: %s => (%d) %s\n", eff_url, res, conn->error); | ||||||
|  |           curl_multi_remove_handle(g->multi, easy); | ||||||
|  |           g_free(conn->url); | ||||||
|  |           curl_easy_cleanup(easy); | ||||||
|  |           g_free(conn); | ||||||
|  |           g->completed++; | ||||||
|  |       } | ||||||
|  |     } while ( easy ); | ||||||
|  |     MSG_OUT("Requested: %d Completed:%d\n", g->requested, g->completed); | ||||||
|  |   } | ||||||
|  |   g->prev_running = g->still_running; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Called by glib when our timeout expires */ | ||||||
|  | static gboolean timer_cb(gpointer data) | ||||||
|  | { | ||||||
|  |   GlobalInfo *g = (GlobalInfo *)data; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket(g->multi, CURL_SOCKET_TIMEOUT, &g->still_running); | ||||||
|  |   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||||
|  |   mcode_or_die("timer_cb: curl_multi_socket", rc); | ||||||
|  |   check_run_count(g); | ||||||
|  |   return FALSE; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Update the event timer after curl_multi library calls */ | ||||||
|  | static int update_timeout_cb(CURLM *multi, long timeout_ms, void *userp) | ||||||
|  | { | ||||||
|  |   struct timeval timeout; | ||||||
|  |   GlobalInfo *g=(GlobalInfo *)userp; | ||||||
|  |   timeout.tv_sec = timeout_ms/1000; | ||||||
|  |   timeout.tv_usec = (timeout_ms%1000)*1000; | ||||||
|  |  | ||||||
|  |   MSG_OUT("*** update_timeout_cb %ld => %ld:%ld ***\n", | ||||||
|  |               timeout_ms, timeout.tv_sec, timeout.tv_usec); | ||||||
|  |  | ||||||
|  |   g->timer_event = g_timeout_add(timeout_ms, timer_cb, g); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Called by glib when we get action on a multi socket */ | ||||||
|  | static gboolean event_cb(GIOChannel *ch, GIOCondition condition, gpointer data) | ||||||
|  | { | ||||||
|  |   GlobalInfo *g = (GlobalInfo*) data; | ||||||
|  |   CURLMcode rc; | ||||||
|  |   int fd=g_io_channel_unix_get_fd(ch); | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket(g->multi, fd, &g->still_running); | ||||||
|  |   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||||
|  |   mcode_or_die("event_cb: curl_multi_socket", rc); | ||||||
|  |   check_run_count(g); | ||||||
|  |   if(g->still_running) { | ||||||
|  |     return TRUE; | ||||||
|  |   } else { | ||||||
|  |     MSG_OUT("last transfer done, kill timeout\n"); | ||||||
|  |     if (g->timer_event) { g_source_remove(g->timer_event); } | ||||||
|  |     return FALSE; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Clean up the SockInfo structure */ | ||||||
|  | static void remsock(SockInfo *f) | ||||||
|  | { | ||||||
|  |   if (!f) { return; } | ||||||
|  |   if (f->ev) { g_source_remove(f->ev); } | ||||||
|  |   g_free(f); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Assign information to a SockInfo structure */ | ||||||
|  | static void setsock(SockInfo*f, curl_socket_t s, CURL*e, int act, GlobalInfo*g) | ||||||
|  | { | ||||||
|  |   GIOCondition kind = | ||||||
|  |      (act&CURL_POLL_IN?G_IO_IN:0)|(act&CURL_POLL_OUT?G_IO_OUT:0); | ||||||
|  |  | ||||||
|  |   f->sockfd = s; | ||||||
|  |   f->action = act; | ||||||
|  |   f->easy = e; | ||||||
|  |   if (f->ev) { g_source_remove(f->ev); } | ||||||
|  |   f->ev=g_io_add_watch(f->ch, kind, event_cb,g); | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Initialize a new SockInfo structure */ | ||||||
|  | static void addsock(curl_socket_t s, CURL *easy, int action, GlobalInfo *g) | ||||||
|  | { | ||||||
|  |   SockInfo *fdp = g_malloc0(sizeof(SockInfo)); | ||||||
|  |  | ||||||
|  |   fdp->global = g; | ||||||
|  |   fdp->ch=g_io_channel_unix_new(s); | ||||||
|  |   setsock(fdp, s, easy, action, g); | ||||||
|  |   curl_multi_assign(g->multi, s, fdp); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* CURLMOPT_SOCKETFUNCTION */ | ||||||
|  | static int sock_cb(CURL *e, curl_socket_t s, int what, void *cbp, void *sockp) | ||||||
|  | { | ||||||
|  |   GlobalInfo *g = (GlobalInfo*) cbp; | ||||||
|  |   SockInfo *fdp = (SockInfo*) sockp; | ||||||
|  |   char *whatstr[]={ "none", "IN", "OUT", "INOUT", "REMOVE" }; | ||||||
|  |  | ||||||
|  |   MSG_OUT("socket callback: s=%d e=%p what=%s ", s, e, whatstr[what]); | ||||||
|  |   if (what == CURL_POLL_REMOVE) { | ||||||
|  |     MSG_OUT("\n"); | ||||||
|  |     remsock(fdp); | ||||||
|  |   } else { | ||||||
|  |     if (!fdp) { | ||||||
|  |       MSG_OUT("Adding data: %s%s\n", | ||||||
|  |              what&CURL_POLL_IN?"READ":"", | ||||||
|  |              what&CURL_POLL_OUT?"WRITE":"" ); | ||||||
|  |       addsock(s, e, what, g); | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |       MSG_OUT( | ||||||
|  |         "Changing action from %d to %d\n", fdp->action, what); | ||||||
|  |       setsock(fdp, s, e, what, g); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* CURLOPT_WRITEFUNCTION */ | ||||||
|  | static size_t write_cb(void *ptr, size_t size, size_t nmemb, void *data) | ||||||
|  | { | ||||||
|  |   size_t realsize = size * nmemb; | ||||||
|  |   ConnInfo *conn = (ConnInfo*) data; | ||||||
|  |   (void)ptr; | ||||||
|  |   (void)conn; | ||||||
|  |   return realsize; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* CURLOPT_PROGRESSFUNCTION */ | ||||||
|  | static int prog_cb (void *p, double dltotal, double dlnow, double ult, double uln) | ||||||
|  | { | ||||||
|  |   ConnInfo *conn = (ConnInfo *)p; | ||||||
|  |   MSG_OUT("Progress: %s (%g/%g)\n", conn->url, dlnow, dltotal); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Create a new easy handle, and add it to the global curl_multi */ | ||||||
|  | static void new_conn(char *url, GlobalInfo *g ) | ||||||
|  | { | ||||||
|  |   ConnInfo *conn; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|  |   conn = g_malloc0(sizeof(ConnInfo)); | ||||||
|  |  | ||||||
|  |   conn->error[0]='\0'; | ||||||
|  |  | ||||||
|  |   conn->easy = curl_easy_init(); | ||||||
|  |   if (!conn->easy) { | ||||||
|  |     MSG_OUT("curl_easy_init() failed, exiting!\n"); | ||||||
|  |     exit(2); | ||||||
|  |   } | ||||||
|  |   conn->global = g; | ||||||
|  |   conn->url = g_strdup(url); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, &conn); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, SHOW_VERBOSE); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_NOPROGRESS, SHOW_PROGRESS?0:1); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_PROGRESSFUNCTION, prog_cb); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_PROGRESSDATA, conn); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_FOLLOWLOCATION, 1); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_CONNECTTIMEOUT, 30); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_LOW_SPEED_LIMIT, 1); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_LOW_SPEED_TIME, 30); | ||||||
|  |  | ||||||
|  |   MSG_OUT("Adding easy %p to multi %p (%s)\n", conn->easy, g->multi, url); | ||||||
|  |   rc =curl_multi_add_handle(g->multi, conn->easy); | ||||||
|  |   mcode_or_die("new_conn: curl_multi_add_handle", rc); | ||||||
|  |   g->requested++; | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket_all(g->multi, &g->still_running); | ||||||
|  |   } while (CURLM_CALL_MULTI_PERFORM == rc); | ||||||
|  |   mcode_or_die("new_conn: curl_multi_socket_all", rc); | ||||||
|  |   check_run_count(g); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* This gets called by glib whenever data is received from the fifo */ | ||||||
|  | static gboolean fifo_cb (GIOChannel *ch, GIOCondition condition, gpointer data) | ||||||
|  | { | ||||||
|  |   #define BUF_SIZE 1024 | ||||||
|  |   gsize len, tp; | ||||||
|  |   gchar *buf, *tmp, *all=NULL; | ||||||
|  |   GIOStatus rv; | ||||||
|  |  | ||||||
|  |   do { | ||||||
|  |     GError *err=NULL; | ||||||
|  |     rv = g_io_channel_read_line (ch,&buf,&len,&tp,&err); | ||||||
|  |     if ( buf ) { | ||||||
|  |       if (tp) { buf[tp]='\0'; } | ||||||
|  |       new_conn(buf,(GlobalInfo*)data); | ||||||
|  |       g_free(buf); | ||||||
|  |     } else { | ||||||
|  |       buf = g_malloc(BUF_SIZE+1); | ||||||
|  |       while (TRUE) { | ||||||
|  |         buf[BUF_SIZE]='\0'; | ||||||
|  |         g_io_channel_read_chars(ch,buf,BUF_SIZE,&len,&err); | ||||||
|  |         if (len) { | ||||||
|  |           buf[len]='\0'; | ||||||
|  |           if (all) { | ||||||
|  |             tmp=all; | ||||||
|  |             all=g_strdup_printf("%s%s", tmp, buf); | ||||||
|  |             g_free(tmp); | ||||||
|  |           } else { | ||||||
|  |             all = g_strdup(buf); | ||||||
|  |           } | ||||||
|  |         } else { | ||||||
|  |            break; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       if (all) { | ||||||
|  |         new_conn(all,(GlobalInfo*)data); | ||||||
|  |         g_free(all); | ||||||
|  |       } | ||||||
|  |       g_free(buf); | ||||||
|  |     } | ||||||
|  |     if ( err ) { | ||||||
|  |       g_error("fifo_cb: %s", err->message); | ||||||
|  |       g_free(err); | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } while ( (len) && (rv == G_IO_STATUS_NORMAL) ); | ||||||
|  |   return TRUE; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int init_fifo(void) | ||||||
|  | { | ||||||
|  |  struct stat st; | ||||||
|  |  char *fifo = "hiper.fifo"; | ||||||
|  |  int socket; | ||||||
|  |  | ||||||
|  |  if (lstat (fifo, &st) == 0) { | ||||||
|  |   if ((st.st_mode & S_IFMT) == S_IFREG) { | ||||||
|  |    errno = EEXIST; | ||||||
|  |    perror("lstat"); | ||||||
|  |    exit (1); | ||||||
|  |   } | ||||||
|  |  } | ||||||
|  |  | ||||||
|  |  unlink (fifo); | ||||||
|  |  if (mkfifo (fifo, 0600) == -1) { | ||||||
|  |   perror("mkfifo"); | ||||||
|  |   exit (1); | ||||||
|  |  } | ||||||
|  |  | ||||||
|  |  socket = open (fifo, O_RDWR | O_NONBLOCK, 0); | ||||||
|  |  | ||||||
|  |  if (socket == -1) { | ||||||
|  |   perror("open"); | ||||||
|  |   exit (1); | ||||||
|  |  } | ||||||
|  |  MSG_OUT("Now, pipe some URL's into > %s\n", fifo); | ||||||
|  |  | ||||||
|  |  return socket; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv) | ||||||
|  | { | ||||||
|  |   GlobalInfo *g; | ||||||
|  |   CURLMcode rc; | ||||||
|  |   GMainLoop*gmain; | ||||||
|  |   int fd; | ||||||
|  |   GIOChannel* ch; | ||||||
|  |   g=g_malloc0(sizeof(GlobalInfo)); | ||||||
|  |  | ||||||
|  |   fd=init_fifo(); | ||||||
|  |   ch=g_io_channel_unix_new(fd); | ||||||
|  |   g_io_add_watch(ch,G_IO_IN,fifo_cb,g); | ||||||
|  |   gmain=g_main_loop_new(NULL,FALSE); | ||||||
|  |   g->multi = curl_multi_init(); | ||||||
|  |   curl_multi_setopt(g->multi, CURLMOPT_SOCKETFUNCTION, sock_cb); | ||||||
|  |   curl_multi_setopt(g->multi, CURLMOPT_SOCKETDATA, g); | ||||||
|  |   curl_multi_setopt(g->multi, CURLMOPT_TIMERFUNCTION, update_timeout_cb); | ||||||
|  |   curl_multi_setopt(g->multi, CURLMOPT_TIMERDATA, g); | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket_all(g->multi, &g->still_running); | ||||||
|  |   } while (CURLM_CALL_MULTI_PERFORM == rc); | ||||||
|  |   g_main_loop_run(gmain); | ||||||
|  |   curl_multi_cleanup(g->multi); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
							
								
								
									
										416
									
								
								docs/examples/hiperfifo.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										416
									
								
								docs/examples/hiperfifo.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,416 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _ | ||||||
|  |  *  Project                     ___| | | |  _ \| | | ||||||
|  |  *                             / __| | | | |_) | | | ||||||
|  |  *                            | (__| |_| |  _ <| |___ | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * Example application source code using the multi socket interface to | ||||||
|  |  * download many files at once. | ||||||
|  |  * | ||||||
|  |  * Written by Jeff Pohlmeyer | ||||||
|  |  | ||||||
|  | Requires libevent and a (POSIX?) system that has mkfifo(). | ||||||
|  |  | ||||||
|  | This is an adaptation of libcurl's "hipev.c" and libevent's "event-test.c" | ||||||
|  | sample programs. | ||||||
|  |  | ||||||
|  | When running, the program creates the named pipe "hiper.fifo" | ||||||
|  |  | ||||||
|  | Whenever there is input into the fifo, the program reads the input as a list | ||||||
|  | of URL's and creates some new easy handles to fetch each URL via the | ||||||
|  | curl_multi "hiper" API. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Thus, you can try a single URL: | ||||||
|  |   % echo http://www.yahoo.com > hiper.fifo | ||||||
|  |  | ||||||
|  | Or a whole bunch of them: | ||||||
|  |   % cat my-url-list > hiper.fifo | ||||||
|  |  | ||||||
|  | The fifo buffer is handled almost instantly, so you can even add more URL's | ||||||
|  | while the previous requests are still being downloaded. | ||||||
|  |  | ||||||
|  | Note: | ||||||
|  |   For the sake of simplicity, URL length is limited to 1023 char's ! | ||||||
|  |  | ||||||
|  | This is purely a demo app, all retrieved data is simply discarded by the write | ||||||
|  | callback. | ||||||
|  |  | ||||||
|  | */ | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <sys/time.h> | ||||||
|  | #include <time.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <sys/poll.h> | ||||||
|  | #include <curl/curl.h> | ||||||
|  | #include <event.h> | ||||||
|  | #include <fcntl.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  | #include <errno.h> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #define MSG_OUT stdout /* Send info to stdout, change to stderr if you want */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Global information, common to all connections */ | ||||||
|  | typedef struct _GlobalInfo { | ||||||
|  |   struct event fifo_event; | ||||||
|  |   struct event timer_event; | ||||||
|  |   CURLM *multi; | ||||||
|  |   int prev_running; | ||||||
|  |   int still_running; | ||||||
|  |   FILE* input; | ||||||
|  | } GlobalInfo; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Information associated with a specific easy handle */ | ||||||
|  | typedef struct _ConnInfo { | ||||||
|  |   CURL *easy; | ||||||
|  |   char *url; | ||||||
|  |   GlobalInfo *global; | ||||||
|  |   char error[CURL_ERROR_SIZE]; | ||||||
|  | } ConnInfo; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Information associated with a specific socket */ | ||||||
|  | typedef struct _SockInfo { | ||||||
|  |   curl_socket_t sockfd; | ||||||
|  |   CURL *easy; | ||||||
|  |   int action; | ||||||
|  |   long timeout; | ||||||
|  |   struct event ev; | ||||||
|  |   int evset; | ||||||
|  |   GlobalInfo *global; | ||||||
|  | } SockInfo; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Update the event timer after curl_multi library calls */ | ||||||
|  | static void update_timeout(GlobalInfo *g) | ||||||
|  | { | ||||||
|  |   long timeout_ms; | ||||||
|  |   struct timeval timeout; | ||||||
|  |  | ||||||
|  |   curl_multi_timeout(g->multi, &timeout_ms); | ||||||
|  |   if(timeout_ms < 0) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   timeout.tv_sec = timeout_ms/1000; | ||||||
|  |   timeout.tv_usec = (timeout_ms%1000)*1000; | ||||||
|  |   evtimer_add(&g->timer_event, &timeout); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Die if we get a bad CURLMcode somewhere */ | ||||||
|  | void mcode_or_die(char *where, CURLMcode code) { | ||||||
|  |   if ( CURLM_OK != code ) { | ||||||
|  |     char *s; | ||||||
|  |     switch (code) { | ||||||
|  |       case     CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break; | ||||||
|  |       case     CURLM_OK:                 s="CURLM_OK";                 break; | ||||||
|  |       case     CURLM_BAD_HANDLE:         s="CURLM_BAD_HANDLE";         break; | ||||||
|  |       case     CURLM_BAD_EASY_HANDLE:    s="CURLM_BAD_EASY_HANDLE";    break; | ||||||
|  |       case     CURLM_OUT_OF_MEMORY:      s="CURLM_OUT_OF_MEMORY";      break; | ||||||
|  |       case     CURLM_INTERNAL_ERROR:     s="CURLM_INTERNAL_ERROR";     break; | ||||||
|  |       case     CURLM_BAD_SOCKET:         s="CURLM_BAD_SOCKET";         break; | ||||||
|  |       case     CURLM_UNKNOWN_OPTION:     s="CURLM_UNKNOWN_OPTION";     break; | ||||||
|  |       case     CURLM_LAST:               s="CURLM_LAST";               break; | ||||||
|  |       default: s="CURLM_unknown"; | ||||||
|  |     } | ||||||
|  |     fprintf(MSG_OUT, "ERROR: %s returns %s\n", where, s); | ||||||
|  |     exit(code); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Check for completed transfers, and remove their easy handles */ | ||||||
|  | static void check_run_count(GlobalInfo *g) | ||||||
|  | { | ||||||
|  |   if (g->prev_running > g->still_running) { | ||||||
|  |     char *eff_url=NULL; | ||||||
|  |     CURLMsg *msg; | ||||||
|  |     int msgs_left; | ||||||
|  |     ConnInfo *conn=NULL; | ||||||
|  |     CURL*easy; | ||||||
|  |     CURLcode res; | ||||||
|  |  | ||||||
|  |     fprintf(MSG_OUT, "REMAINING: %d\n", g->still_running); | ||||||
|  |     /* | ||||||
|  |       I am still uncertain whether it is safe to remove an easy handle | ||||||
|  |       from inside the curl_multi_info_read loop, so here I will search | ||||||
|  |       for completed transfers in the inner "while" loop, and then remove | ||||||
|  |       them in the outer "do-while" loop... | ||||||
|  |    */ | ||||||
|  |     do { | ||||||
|  |       easy=NULL; | ||||||
|  |       while ((msg = curl_multi_info_read(g->multi, &msgs_left))) { | ||||||
|  |         if (msg->msg == CURLMSG_DONE) { | ||||||
|  |           easy=msg->easy_handle; | ||||||
|  |           res=msg->data.result; | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       if (easy) { | ||||||
|  |           curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn); | ||||||
|  |           curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url); | ||||||
|  |           fprintf(MSG_OUT, "DONE: %s => (%d) %s\n", eff_url, res, conn->error); | ||||||
|  |           curl_multi_remove_handle(g->multi, easy); | ||||||
|  |           free(conn->url); | ||||||
|  |           curl_easy_cleanup(easy); | ||||||
|  |           free(conn); | ||||||
|  |       } | ||||||
|  |     } while ( easy ); | ||||||
|  |   } | ||||||
|  |   g->prev_running = g->still_running; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Called by libevent when we get action on a multi socket */ | ||||||
|  | static void event_cb(int fd, short kind, void *userp) | ||||||
|  | { | ||||||
|  |   GlobalInfo *g = (GlobalInfo*) userp; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket(g->multi, fd, &g->still_running); | ||||||
|  |   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||||
|  |   mcode_or_die("event_cb: curl_multi_socket", rc); | ||||||
|  |   check_run_count(g); | ||||||
|  |   if(g->still_running) { | ||||||
|  |     update_timeout(g); | ||||||
|  |   } else { | ||||||
|  |     fprintf(MSG_OUT, "last transfer done, kill timeout\n"); | ||||||
|  |     if (evtimer_pending(&g->timer_event, NULL)) { | ||||||
|  |       evtimer_del(&g->timer_event); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Called by libevent when our timeout expires */ | ||||||
|  | static void timer_cb(int fd, short kind, void *userp) | ||||||
|  | { | ||||||
|  |   (void)fd; | ||||||
|  |   (void)kind; | ||||||
|  |   GlobalInfo *g = (GlobalInfo *)userp; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket(g->multi, CURL_SOCKET_TIMEOUT, &g->still_running); | ||||||
|  |   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||||
|  |   mcode_or_die("timer_cb: curl_multi_socket", rc); | ||||||
|  |   check_run_count(g); | ||||||
|  |   if ( g->still_running ) { update_timeout(g); } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Clean up the SockInfo structure */ | ||||||
|  | static void remsock(SockInfo *f) | ||||||
|  | { | ||||||
|  |   if (!f) { return; } | ||||||
|  |   if (f->evset) { event_del(&f->ev); } | ||||||
|  |   free(f); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Assign information to a SockInfo structure */ | ||||||
|  | static void setsock(SockInfo*f, curl_socket_t s, CURL*e, int act, GlobalInfo*g) | ||||||
|  | { | ||||||
|  |   int kind = | ||||||
|  |      (act&CURL_POLL_IN?EV_READ:0)|(act&CURL_POLL_OUT?EV_WRITE:0)|EV_PERSIST; | ||||||
|  |  | ||||||
|  |   f->sockfd = s; | ||||||
|  |   f->action = act; | ||||||
|  |   f->easy = e; | ||||||
|  |   if (f->evset) { event_del(&f->ev); } | ||||||
|  |   event_set( &f->ev, f->sockfd, kind, event_cb, g); | ||||||
|  |   f->evset=1; | ||||||
|  |   event_add(&f->ev, NULL); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Initialize a new SockInfo structure */ | ||||||
|  | static void addsock(curl_socket_t s, CURL *easy, int action, GlobalInfo *g) { | ||||||
|  |   SockInfo *fdp = calloc(sizeof(SockInfo), 1); | ||||||
|  |  | ||||||
|  |   fdp->global = g; | ||||||
|  |   setsock(fdp, s, easy, action, g); | ||||||
|  |   curl_multi_assign(g->multi, s, fdp); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* CURLMOPT_SOCKETFUNCTION */ | ||||||
|  | static int sock_cb(CURL *e, curl_socket_t s, int what, void *cbp, void *sockp) | ||||||
|  | { | ||||||
|  |   GlobalInfo *g = (GlobalInfo*) cbp; | ||||||
|  |   SockInfo *fdp = (SockInfo*) sockp; | ||||||
|  |   char *whatstr[]={ "none", "IN", "OUT", "INOUT", "REMOVE" }; | ||||||
|  |  | ||||||
|  |   fprintf(MSG_OUT, | ||||||
|  |           "socket callback: s=%d e=%p what=%s ", s, e, whatstr[what]); | ||||||
|  |   if (what == CURL_POLL_REMOVE) { | ||||||
|  |     fprintf(MSG_OUT, "\n"); | ||||||
|  |     remsock(fdp); | ||||||
|  |   } else { | ||||||
|  |     if (!fdp) { | ||||||
|  |       fprintf(MSG_OUT, "Adding data: %s%s\n", | ||||||
|  |              what&CURL_POLL_IN?"READ":"", | ||||||
|  |              what&CURL_POLL_OUT?"WRITE":"" ); | ||||||
|  |       addsock(s, e, what, g); | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |       fprintf(MSG_OUT, | ||||||
|  |         "Changing action from %d to %d\n", fdp->action, what); | ||||||
|  |       setsock(fdp, s, e, what, g); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* CURLOPT_WRITEFUNCTION */ | ||||||
|  | static size_t write_cb(void *ptr, size_t size, size_t nmemb, void *data) | ||||||
|  | { | ||||||
|  |   size_t realsize = size * nmemb; | ||||||
|  |   ConnInfo *conn = (ConnInfo*) data; | ||||||
|  |   (void)ptr; | ||||||
|  |   (void)conn; | ||||||
|  |   return realsize; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* CURLOPT_PROGRESSFUNCTION */ | ||||||
|  | int prog_cb (void *p, double dltotal, double dlnow, double ult, double uln) | ||||||
|  | { | ||||||
|  |   ConnInfo *conn = (ConnInfo *)p; | ||||||
|  |   fprintf(MSG_OUT, "Progress: %s (%g/%g)\n", conn->url, dlnow, dltotal); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Create a new easy handle, and add it to the global curl_multi */ | ||||||
|  | void new_conn(char *url, GlobalInfo *g ) { | ||||||
|  |   ConnInfo *conn; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|  |   conn = calloc(1, sizeof(ConnInfo)); | ||||||
|  |   memset(conn, 0, sizeof(ConnInfo)); | ||||||
|  |   conn->error[0]='\0'; | ||||||
|  |  | ||||||
|  |   conn->easy = curl_easy_init(); | ||||||
|  |   if (!conn->easy) { | ||||||
|  |     fprintf(MSG_OUT, "curl_easy_init() failed, exiting!\n"); | ||||||
|  |     exit(2); | ||||||
|  |   } | ||||||
|  |   conn->global = g; | ||||||
|  |   conn->url = strdup(url); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, &conn); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, 0); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_NOPROGRESS, 0); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_PROGRESSFUNCTION, prog_cb); | ||||||
|  |   curl_easy_setopt(conn->easy, CURLOPT_PROGRESSDATA, conn); | ||||||
|  |   fprintf(MSG_OUT, | ||||||
|  |           "Adding easy %p to multi %p (%s)\n", conn->easy, g->multi, url); | ||||||
|  |   rc =curl_multi_add_handle(g->multi, conn->easy); | ||||||
|  |   mcode_or_die("new_conn: curl_multi_add_handle", rc); | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket_all(g->multi, &g->still_running); | ||||||
|  |   } while (CURLM_CALL_MULTI_PERFORM == rc); | ||||||
|  |   mcode_or_die("new_conn: curl_multi_socket_all", rc); | ||||||
|  |   check_run_count(g); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* This gets called whenever data is received from the fifo */ | ||||||
|  | void fifo_cb(int fd, short event, void *arg) { | ||||||
|  |   char s[1024]; | ||||||
|  |   long int rv=0; | ||||||
|  |   int n=0; | ||||||
|  |   GlobalInfo *g = (GlobalInfo *)arg; | ||||||
|  |  | ||||||
|  |   do { | ||||||
|  |     s[0]='\0'; | ||||||
|  |     rv=fscanf(g->input, "%1023s%n", s, &n); | ||||||
|  |     s[n]='\0'; | ||||||
|  |     if ( n && s[0] ) { | ||||||
|  |       new_conn(s,arg);  /* if we read a URL, go get it! */ | ||||||
|  |     } else break; | ||||||
|  |   } while ( rv != EOF); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Create a named pipe and tell libevent to monitor it */ | ||||||
|  | int init_fifo (GlobalInfo *g) { | ||||||
|  |   struct stat st; | ||||||
|  |   char *fifo = "hiper.fifo"; | ||||||
|  |   int socket; | ||||||
|  |  | ||||||
|  |   fprintf(MSG_OUT, "Creating named pipe \"%s\"\n", fifo); | ||||||
|  |   if (lstat (fifo, &st) == 0) { | ||||||
|  |     if ((st.st_mode & S_IFMT) == S_IFREG) { | ||||||
|  |       errno = EEXIST; | ||||||
|  |       perror("lstat"); | ||||||
|  |       exit (1); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   unlink(fifo); | ||||||
|  |   if (mkfifo (fifo, 0600) == -1) { | ||||||
|  |     perror("mkfifo"); | ||||||
|  |     exit (1); | ||||||
|  |   } | ||||||
|  |   socket = open(fifo, O_RDWR | O_NONBLOCK, 0); | ||||||
|  |   if (socket == -1) { | ||||||
|  |      perror("open"); | ||||||
|  |      exit (1); | ||||||
|  |   } | ||||||
|  |   g->input = fdopen(socket, "r"); | ||||||
|  |  | ||||||
|  |   fprintf(MSG_OUT, "Now, pipe some URL's into > %s\n", fifo); | ||||||
|  |   event_set(&g->fifo_event, socket, EV_READ | EV_PERSIST, fifo_cb, g); | ||||||
|  |   event_add(&g->fifo_event, NULL); | ||||||
|  |   return (0); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv) | ||||||
|  | { | ||||||
|  |   GlobalInfo g; | ||||||
|  |   CURLMcode rc; | ||||||
|  |  | ||||||
|  |   memset(&g, 0, sizeof(GlobalInfo)); | ||||||
|  |   event_init(); | ||||||
|  |   init_fifo(&g); | ||||||
|  |   g.multi = curl_multi_init(); | ||||||
|  |   evtimer_set(&g.timer_event, timer_cb, &g); | ||||||
|  |   curl_multi_setopt(g.multi, CURLMOPT_SOCKETFUNCTION, sock_cb); | ||||||
|  |   curl_multi_setopt(g.multi, CURLMOPT_SOCKETDATA, &g); | ||||||
|  |   do { | ||||||
|  |     rc = curl_multi_socket_all(g.multi, &g.still_running); | ||||||
|  |   } while (CURLM_CALL_MULTI_PERFORM == rc); | ||||||
|  |   update_timeout(&g); | ||||||
|  |   event_dispatch(); | ||||||
|  |   curl_multi_cleanup(g.multi); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -15,13 +15,13 @@ endif | |||||||
|  |  | ||||||
| LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a | LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a | ||||||
|  |  | ||||||
| PROGRAMS  = fopen.exe ftpget.exe ftpgetresp.exe ftpupload.exe \ | CSOURCES = fopen.c ftpget.c ftpgetresp.c ftpupload.c getinmemory.c \ | ||||||
|             getinmemory.exe http-post.exe httpput.exe multi-app.exe \ |            http-post.c httpput.c multi-app.c multi-double.c multi-post.c \ | ||||||
|             multi-double.exe multi-post.exe multi-single.exe \ |            multi-single.c persistant.c post-callback.c postit2.c \ | ||||||
|             persistant.exe post-callback.exe postit2.exe \ |            sepheaders.c simple.c simplessl.c https.c ftp3rdparty.c \ | ||||||
|             sepheaders.exe simple.exe simplessl.exe https.exe \ |            getinfo.c anyauthput.c cookie_interface.c 10-at-a-time.c | ||||||
|             ftp3rdparty.exe getinfo.exe anyauthput.exe \ |  | ||||||
|             cookie_interface.exe | PROGRAMS = $(CSOURCES:.c=.exe) | ||||||
|  |  | ||||||
| all: $(PROGRAMS) | all: $(PROGRAMS) | ||||||
|  |  | ||||||
| @@ -32,3 +32,5 @@ all: $(PROGRAMS) | |||||||
| clean: | clean: | ||||||
| 	rm -f $(PROGRAMS) | 	rm -f $(PROGRAMS) | ||||||
|  |  | ||||||
|  | # DO NOT DELETE THIS LINE | ||||||
|  |  | ||||||
|   | |||||||
| @@ -80,6 +80,10 @@ int main(int argc, char **argv) | |||||||
|     /* get file descriptors from the transfers */ |     /* get file descriptors from the transfers */ | ||||||
|     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); |     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |     /* In a real-world program you OF COURSE check the return code of the | ||||||
|  |        function calls, *and* you make sure that maxfd is bigger than -1 so | ||||||
|  |        that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); |     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|     switch(rc) { |     switch(rc) { | ||||||
|   | |||||||
| @@ -153,6 +153,10 @@ int main(int argc, char **argv) | |||||||
|     /* get file descriptors from the transfers */ |     /* get file descriptors from the transfers */ | ||||||
|     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); |     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |     /* In a real-world program you OF COURSE check the return code of the | ||||||
|  |        function calls, *and* you make sure that maxfd is bigger than -1 | ||||||
|  |        so that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); |     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|     switch(rc) { |     switch(rc) { | ||||||
|   | |||||||
| @@ -71,6 +71,10 @@ int main(int argc, char **argv) | |||||||
|     /* get file descriptors from the transfers */ |     /* get file descriptors from the transfers */ | ||||||
|     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); |     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |     /* In a real-world program you OF COURSE check the return code of the | ||||||
|  |        function calls, *and* you make sure that maxfd is bigger than -1 so | ||||||
|  |        that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); |     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|     switch(rc) { |     switch(rc) { | ||||||
|   | |||||||
| @@ -93,6 +93,10 @@ int main(int argc, char *argv[]) | |||||||
|       /* get file descriptors from the transfers */ |       /* get file descriptors from the transfers */ | ||||||
|       curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); |       curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |       /* In a real-world program you OF COURSE check the return code of the | ||||||
|  |          function calls, *and* you make sure that maxfd is bigger than -1 | ||||||
|  |          so that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|       rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); |       rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|       switch(rc) { |       switch(rc) { | ||||||
|   | |||||||
| @@ -65,6 +65,10 @@ int main(int argc, char **argv) | |||||||
|     /* get file descriptors from the transfers */ |     /* get file descriptors from the transfers */ | ||||||
|     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); |     curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |     /* In a real-world program you OF COURSE check the return code of the | ||||||
|  |        function calls, *and* you make sure that maxfd is bigger than -1 so | ||||||
|  |        that the call to select() below makes sense! */ | ||||||
|  |  | ||||||
|     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); |     rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|     switch(rc) { |     switch(rc) { | ||||||
|   | |||||||
| @@ -41,9 +41,6 @@ int main(int argc, char **argv) | |||||||
|   /* no progress meter please */ |   /* no progress meter please */ | ||||||
|   curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1); |   curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1); | ||||||
|  |  | ||||||
|   /* shut up completely */ |  | ||||||
|   curl_easy_setopt(curl_handle, CURLOPT_MUTE, 1); |  | ||||||
|  |  | ||||||
|   /* send all data to this function  */ |   /* send all data to this function  */ | ||||||
|   curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, write_data); |   curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, write_data); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,6 +9,18 @@ | |||||||
|  * |  * | ||||||
|  * This example code only builds as-is on Windows. |  * This example code only builds as-is on Windows. | ||||||
|  * |  * | ||||||
|  |  * While Unix/Linux user, you do not need this software. | ||||||
|  |  * You can achieve the same result as synctime using curl, awk and date. | ||||||
|  |  * Set proxy as according to your network, but beware of proxy Cache-Control. | ||||||
|  |  * | ||||||
|  |  * To set your system clock, root access is required. | ||||||
|  |  * # date -s "`curl -sI http://nist.time.gov/timezone.cgi?UTC/s/0 \ | ||||||
|  |  *        | awk -F': ' '/Date: / {print $2}'`" | ||||||
|  |  * | ||||||
|  |  * To view remote webserver date and time. | ||||||
|  |  * $ curl -sI http://nist.time.gov/timezone.cgi?UTC/s/0 \ | ||||||
|  |  *        | awk -F': ' '/Date: / {print $2}' | ||||||
|  |  * | ||||||
|  * Synchronising your computer clock via Internet time server usually relies |  * Synchronising your computer clock via Internet time server usually relies | ||||||
|  * on DAYTIME, TIME, or NTP protocols. These protocols provide good accurate |  * on DAYTIME, TIME, or NTP protocols. These protocols provide good accurate | ||||||
|  * time synchronisation but it does not work very well through a |  * time synchronisation but it does not work very well through a | ||||||
| @@ -300,10 +312,11 @@ int main(int argc, char *argv[]) | |||||||
|              MthStr[LOCALTime.wMonth-1], LOCALTime.wYear, |              MthStr[LOCALTime.wMonth-1], LOCALTime.wYear, | ||||||
|              LOCALTime.wHour, LOCALTime.wMinute, LOCALTime.wSecond, |              LOCALTime.wHour, LOCALTime.wMinute, LOCALTime.wSecond, | ||||||
|              LOCALTime.wMilliseconds); |              LOCALTime.wMilliseconds); | ||||||
|     fprintf(stderr, "\nBefore HTTP. Date: %s%s\n\n", timeBuf, tzoneBuf); |  | ||||||
|  |     fprintf(stderr, "Fetch: %s\n\n", conf->timeserver); | ||||||
|  |     fprintf(stderr, "Before HTTP. Date: %s%s\n\n", timeBuf, tzoneBuf); | ||||||
|  |  | ||||||
|     /* HTTP HEAD command to the Webserver */ |     /* HTTP HEAD command to the Webserver */ | ||||||
|     fprintf(stderr, "Fetch: %s\n", conf->timeserver); |  | ||||||
|     SyncTime_CURL_Fetch(curl, conf->timeserver, "index.htm", |     SyncTime_CURL_Fetch(curl, conf->timeserver, "index.htm", | ||||||
|                         HTTP_COMMAND_HEAD); |                         HTTP_COMMAND_HEAD); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_cleanup 3 "13 Nov 2002" "libcurl 7.7" "libcurl Manual" | .TH curl_easy_cleanup 3 "12 Oct 2006" "libcurl 7.7" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_cleanup - End a libcurl easy session | curl_easy_cleanup - End a libcurl easy session | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -21,6 +21,9 @@ more files. | |||||||
|  |  | ||||||
| When you've called this, you can safely remove all the strings you've | When you've called this, you can safely remove all the strings you've | ||||||
| previously told libcurl to use, as it won't use them anymore now. | previously told libcurl to use, as it won't use them anymore now. | ||||||
|  |  | ||||||
|  | Any uses of the \fBhandle\fP after this function has been called are | ||||||
|  | illegal. This kills the handle and all memory associated with it! | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| None | None | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2007, 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_easy_setopt 3 "19 Apr 2006" "libcurl 7.15.4" "libcurl Manual" | .TH curl_easy_setopt 3 "2 Nov 2006" "libcurl 7.16.1" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_setopt \- set options for a curl easy handle | curl_easy_setopt \- set options for a curl easy handle | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -160,12 +160,28 @@ found in \fI<curl/curl.h>\fP. This function gets called by libcurl when | |||||||
| something special I/O-related needs to be done that the library can't do by | something special I/O-related needs to be done that the library can't do by | ||||||
| itself. For now, rewinding the read data stream is the only action it can | itself. For now, rewinding the read data stream is the only action it can | ||||||
| request. The rewinding of the read data stream may be necessary when doing a | request. The rewinding of the read data stream may be necessary when doing a | ||||||
| HTTP PUT or POST with a multi-pass authentication method.  (Opion added in | HTTP PUT or POST with a multi-pass authentication method.  (Option added in | ||||||
| 7.12.3) | 7.12.3) | ||||||
| .IP CURLOPT_IOCTLDATA | .IP CURLOPT_IOCTLDATA | ||||||
| Pass a pointer that will be untouched by libcurl and passed as the 3rd | Pass a pointer that will be untouched by libcurl and passed as the 3rd | ||||||
| argument in the ioctl callback set with \fICURLOPT_IOCTLFUNCTION\fP.  (Option | argument in the ioctl callback set with \fICURLOPT_IOCTLFUNCTION\fP.  (Option | ||||||
| added in 7.12.3) | added in 7.12.3) | ||||||
|  | .IP CURLOPT_SOCKOPTFUNCTION | ||||||
|  | Function pointer that should match the \fIcurl_sockopt_callback\fP prototype | ||||||
|  | found in \fI<curl/curl.h>\fP. This function gets called by libcurl after the | ||||||
|  | socket() call but before the connect() call. The callback's \fIpurpose\fP | ||||||
|  | argument identifies the exact purpose for this particular socket, and | ||||||
|  | currently only one value is supported: \fICURLSOCKTYPE_IPCXN\fP for the | ||||||
|  | primary connection (meaning the control connection in the FTP case). Future | ||||||
|  | versions of libcurl may support more purposes. It passes the newly created | ||||||
|  | socket descriptor so additional setsockopt() calls can be done at the user's | ||||||
|  | discretion.  A non-zero return code from the callback function will signal an | ||||||
|  | unrecoverable error to the library and it will close the socket and return | ||||||
|  | \fICURLE_COULDNT_CONNECT\fP.  (Option added in 7.15.6.) | ||||||
|  | .IP CURLOPT_SOCKOPTDATA | ||||||
|  | Pass a pointer that will be untouched by libcurl and passed as the first | ||||||
|  | argument in the sockopt callback set with \fICURLOPT_SOCKOPTFUNCTION\fP. | ||||||
|  | (Option added in 7.15.6.) | ||||||
| .IP CURLOPT_PROGRESSFUNCTION | .IP CURLOPT_PROGRESSFUNCTION | ||||||
| Function pointer that should match the \fIcurl_progress_callback\fP prototype | Function pointer that should match the \fIcurl_progress_callback\fP prototype | ||||||
| found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of | found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of | ||||||
| @@ -328,6 +344,14 @@ when showing the progress meter and displaying \fICURLOPT_VERBOSE\fP data. | |||||||
| A non-zero parameter tells the library to fail silently if the HTTP code | A non-zero parameter tells the library to fail silently if the HTTP code | ||||||
| returned is equal to or larger than 400. The default action would be to return | returned is equal to or larger than 400. The default action would be to return | ||||||
| the page normally, ignoring that code. | the page normally, ignoring that code. | ||||||
|  |  | ||||||
|  | This method is not fail-safe and there are occasions where non-succesful | ||||||
|  | response codes will slip through, especially when authentication is involved | ||||||
|  | (response codes 401 and 407). | ||||||
|  |  | ||||||
|  | You might get some amounts of headers transferred before this situation is | ||||||
|  | detected, like for when a "100-continue" is received as a response to a | ||||||
|  | POST/PUT and a 401 or 407 is received immediately afterwards. | ||||||
| .SH NETWORK OPTIONS | .SH NETWORK OPTIONS | ||||||
| .IP CURLOPT_URL | .IP CURLOPT_URL | ||||||
| The actual URL to deal with. The parameter should be a char * to a zero | The actual URL to deal with. The parameter should be a char * to a zero | ||||||
| @@ -365,9 +389,10 @@ libcurl respects the environment variables \fBhttp_proxy\fP, \fBftp_proxy\fP, | |||||||
| \fBall_proxy\fP etc, if any of those is set. The \fICURLOPT_PROXY\fP option | \fBall_proxy\fP etc, if any of those is set. The \fICURLOPT_PROXY\fP option | ||||||
| does however override any possibly set environment variables. | does however override any possibly set environment variables. | ||||||
|  |  | ||||||
| Starting with 7.14.1, the proxy host string can be specified the exact same | Starting with 7.14.1, the proxy host string given in environment variables can | ||||||
| way as the proxy environment variables, include protocol prefix (http://) and | be specified the exact same way as the proxy can be set with | ||||||
| embedded user + password. | \fICURLOPT_PROXY\fP, include protocol prefix (http://) and embedded user + | ||||||
|  | password. | ||||||
| .IP CURLOPT_PROXYPORT | .IP CURLOPT_PROXYPORT | ||||||
| Pass a long with this option to set the proxy port to connect to unless it is | Pass a long with this option to set the proxy port to connect to unless it is | ||||||
| specified in the proxy string \fICURLOPT_PROXY\fP. | specified in the proxy string \fICURLOPT_PROXY\fP. | ||||||
| @@ -821,7 +846,8 @@ Pass a pointer to a linked list of FTP commands to pass to the server after | |||||||
| the transfer type is set. The linked list should be a fully valid list of | the transfer type is set. The linked list should be a fully valid list of | ||||||
| struct curl_slist structs properly filled in as described for | struct curl_slist structs properly filled in as described for | ||||||
| \fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this | \fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this | ||||||
| option. | option. Before version 7.15.6, if you also set \fICURLOPT_NOBODY\fP non-zero, | ||||||
|  | this option didn't work. | ||||||
| .IP CURLOPT_FTPLISTONLY | .IP CURLOPT_FTPLISTONLY | ||||||
| A non-zero parameter tells the library to just list the names of an ftp | A non-zero parameter tells the library to just list the names of an ftp | ||||||
| directory, instead of doing a full directory listing that would include file | directory, instead of doing a full directory listing that would include file | ||||||
| @@ -899,18 +925,12 @@ Try "AUTH SSL" first, and only if that fails try "AUTH TLS" | |||||||
| .IP CURLFTPAUTH_TLS | .IP CURLFTPAUTH_TLS | ||||||
| Try "AUTH TLS" first, and only if that fails try "AUTH SSL" | Try "AUTH TLS" first, and only if that fails try "AUTH SSL" | ||||||
| .RE | .RE | ||||||
| .IP CURLOPT_SOURCE_URL | .IP CURLOPT_FTP_SSL_CCC | ||||||
| When set, it enables a FTP third party transfer, using the set URL as source, | Pass a long that is set to 0 to disable and 1 to enable. If enabled, this | ||||||
| while \fICURLOPT_URL\fP is the target. | option makes libcurl use CCC (Clear Command Channel). It shuts down the | ||||||
| .IP CURLOPT_SOURCE_USERPWD | SSL/TLS layer after authenticating. The rest of the control channel | ||||||
| Set "username:password" to use for the source connection when doing FTP third | communication will be unencrypted. This allows NAT routers to follow the FTP | ||||||
| party transfers. | transaction.  (Added in 7.16.1) | ||||||
| .IP CURLOPT_SOURCE_QUOTE |  | ||||||
| Exactly like \fICURLOPT_QUOTE\fP, but for the source host. |  | ||||||
| .IP CURLOPT_SOURCE_PREQUOTE |  | ||||||
| Exactly like \fICURLOPT_PREQUOTE\fP, but for the source host. |  | ||||||
| .IP CURLOPT_SOURCE_POSTQUOTE |  | ||||||
| Exactly like \fICURLOPT_POSTQUOTE\fP, but for the source host. |  | ||||||
| .IP CURLOPT_FTP_ACCOUNT | .IP CURLOPT_FTP_ACCOUNT | ||||||
| Pass a pointer to a zero-terminated string (or NULL to disable). When an FTP | Pass a pointer to a zero-terminated string (or NULL to disable). When an FTP | ||||||
| server asks for "account data" after user name and password has been provided, | server asks for "account data" after user name and password has been provided, | ||||||
| @@ -955,7 +975,9 @@ techniques). Pass a NULL to this option to disable the use of ranges. | |||||||
| .IP CURLOPT_RESUME_FROM | .IP CURLOPT_RESUME_FROM | ||||||
| Pass a long as parameter. It contains the offset in number of bytes that you | Pass a long as parameter. It contains the offset in number of bytes that you | ||||||
| want the transfer to start from. Set this option to 0 to make the transfer | want the transfer to start from. Set this option to 0 to make the transfer | ||||||
| start from the beginning (effectively disabling resume). | start from the beginning (effectively disabling resume). For FTP, set this | ||||||
|  | option to -1 to make the transfer start from the end of the target file | ||||||
|  | (useful to continue an interrupted upload). | ||||||
| .IP CURLOPT_RESUME_FROM_LARGE | .IP CURLOPT_RESUME_FROM_LARGE | ||||||
| Pass a curl_off_t as parameter. It contains the offset in number of bytes that | Pass a curl_off_t as parameter. It contains the offset in number of bytes that | ||||||
| you want the transfer to start from. (Added in 7.11.0) | you want the transfer to start from. (Added in 7.11.0) | ||||||
| @@ -992,15 +1014,21 @@ to POST with \fICURLOPT_POST\fP etc. | |||||||
| When uploading a file to a remote site, this option should be used to tell | When uploading a file to a remote site, this option should be used to tell | ||||||
| libcurl what the expected size of the infile is. This value should be passed | libcurl what the expected size of the infile is. This value should be passed | ||||||
| as a long. See also \fICURLOPT_INFILESIZE_LARGE\fP. | as a long. See also \fICURLOPT_INFILESIZE_LARGE\fP. | ||||||
|  |  | ||||||
|  | Note that this option does not limit how much data libcurl will actually send, | ||||||
|  | as that is controlled entirely by what the read callback returns. | ||||||
| .IP CURLOPT_INFILESIZE_LARGE | .IP CURLOPT_INFILESIZE_LARGE | ||||||
| When uploading a file to a remote site, this option should be used to tell | When uploading a file to a remote site, this option should be used to tell | ||||||
| libcurl what the expected size of the infile is.  This value should be passed | libcurl what the expected size of the infile is.  This value should be passed | ||||||
| as a curl_off_t. (Added in 7.11.0) | as a curl_off_t. (Added in 7.11.0) | ||||||
|  |  | ||||||
|  | Note that this option does not limit how much data libcurl will actually send, | ||||||
|  | as that is controlled entirely by what the read callback returns. | ||||||
| .IP CURLOPT_UPLOAD | .IP CURLOPT_UPLOAD | ||||||
| A non-zero parameter tells the library to prepare for an upload. The | A non-zero parameter tells the library to prepare for an upload. The | ||||||
| \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZEE\fP or | \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZE\fP or | ||||||
| \fICURLOPT_INFILESIZE_LARGE\fP are also interesting for uploads. If the | \fICURLOPT_INFILESIZE_LARGE\fP options are also interesting for uploads. If | ||||||
| protocol is HTTP, uploading means using the PUT request unless you tell | the protocol is HTTP, uploading means using the PUT request unless you tell | ||||||
| libcurl otherwise. | libcurl otherwise. | ||||||
|  |  | ||||||
| Using PUT with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | Using PUT with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||||
| @@ -1061,11 +1089,13 @@ it too slow and abort. | |||||||
| .IP CURLOPT_MAX_SEND_SPEED_LARGE | .IP CURLOPT_MAX_SEND_SPEED_LARGE | ||||||
| Pass a curl_off_t as parameter.  If an upload exceeds this speed on cumulative | Pass a curl_off_t as parameter.  If an upload exceeds this speed on cumulative | ||||||
| average during the transfer, the transfer will pause to keep the average rate | average during the transfer, the transfer will pause to keep the average rate | ||||||
| less than or equal to the parameter value.  (default: 0, unlimited) | less than or equal to the parameter value.  Defaults to unlimited | ||||||
|  | speed. (Added in 7.15.5) | ||||||
| .IP CURLOPT_MAX_RECV_SPEED_LARGE | .IP CURLOPT_MAX_RECV_SPEED_LARGE | ||||||
| Pass a curl_off_t as parameter.  If an upload exceeds this speed on cumulative | Pass a curl_off_t as parameter.  If an upload exceeds this speed on cumulative | ||||||
| average during the transfer, the transfer will pause to keep the average rate | average during the transfer, the transfer will pause to keep the average rate | ||||||
| less than or equal to the parameter value.  (default: 0, unlimited) | less than or equal to the parameter value. Defaults to unlimited speed. (Added | ||||||
|  | in 7.15.5) | ||||||
| .IP CURLOPT_MAXCONNECTS | .IP CURLOPT_MAXCONNECTS | ||||||
| Pass a long. The set number will be the persistent connection cache size. The | Pass a long. The set number will be the persistent connection cache size. The | ||||||
| set amount will be the maximum amount of simultaneously open connections that | set amount will be the maximum amount of simultaneously open connections that | ||||||
| @@ -1074,23 +1104,14 @@ value unless you are perfectly aware of how this work and changes libcurl's | |||||||
| behaviour. This concerns connection using any of the protocols that support | behaviour. This concerns connection using any of the protocols that support | ||||||
| persistent connections. | persistent connections. | ||||||
|  |  | ||||||
| When reaching the maximum limit, curl uses the \fICURLOPT_CLOSEPOLICY\fP to | When reaching the maximum limit, curl closes the oldest one in the cache to | ||||||
| figure out which of the existing connections to close to prevent the number of | prevent the number of open connections to increase. | ||||||
| open connections to increase. |  | ||||||
|  |  | ||||||
| If you already have performed transfers with this curl handle, setting a | If you already have performed transfers with this curl handle, setting a | ||||||
| smaller MAXCONNECTS than before may cause open connections to get closed | smaller MAXCONNECTS than before may cause open connections to get closed | ||||||
| unnecessarily. | unnecessarily. | ||||||
| .IP CURLOPT_CLOSEPOLICY | .IP CURLOPT_CLOSEPOLICY | ||||||
| Pass a long. This option sets what policy libcurl should use when the | (Obsolete) This option does nothing. | ||||||
| connection cache is filled and one of the open connections has to be closed to |  | ||||||
| make room for a new connection. This must be one of the CURLCLOSEPOLICY_* |  | ||||||
| defines. Use \fICURLCLOSEPOLICY_LEAST_RECENTLY_USED\fP to make libcurl close |  | ||||||
| the connection that was least recently used, that connection is also least |  | ||||||
| likely to be capable of re-use. Use \fICURLCLOSEPOLICY_OLDEST\fP to make |  | ||||||
| libcurl close the oldest connection, the one that was created first among the |  | ||||||
| ones in the connection cache. The other close policies are not support |  | ||||||
| yet. |  | ||||||
| .IP CURLOPT_FRESH_CONNECT | .IP CURLOPT_FRESH_CONNECT | ||||||
| Pass a long. Set to non-zero to make the next transfer use a new (fresh) | Pass a long. Set to non-zero to make the next transfer use a new (fresh) | ||||||
| connection by force. If the connection cache is full before this connection, | connection by force. If the connection cache is full before this connection, | ||||||
| @@ -1228,14 +1249,14 @@ even indicate an accessible file. | |||||||
| Note that option is by default set to the system path where libcurl's cacert | Note that option is by default set to the system path where libcurl's cacert | ||||||
| bundle is assumed to be stored, as established at build time. | bundle is assumed to be stored, as established at build time. | ||||||
| .IP CURLOPT_CAPATH | .IP CURLOPT_CAPATH | ||||||
| Pass a char * to a zero terminated string naming a directory holding | Pass a char * to a zero terminated string naming a directory holding multiple | ||||||
| multiple CA certificates to verify the peer with. The certificate | CA certificates to verify the peer with. The certificate directory must be | ||||||
| directory must be prepared using the openssl c_rehash utility. This | prepared using the openssl c_rehash utility. This makes sense only when used | ||||||
| makes sense only when used in combination with the | in combination with the \fICURLOPT_SSL_VERIFYPEER\fP option.  If | ||||||
| \fICURLOPT_SSL_VERIFYPEER\fP option.  If \fICURLOPT_SSL_VERIFYPEER\fP | \fICURLOPT_SSL_VERIFYPEER\fP is zero, \fICURLOPT_CAPATH\fP need not even | ||||||
| is zero, \fICURLOPT_CAPATH\fP need not even indicate an accessible | indicate an accessible path.  The \fICURLOPT_CAPATH\fP function apparently | ||||||
| path.  The \fICURLOPT_CAPATH\fP function apparently does not work in | does not work in Windows due to some limitation in openssl. This option is | ||||||
| Windows due to some limitation in openssl. (Added in 7.9.8) | OpenSSL-specific and does nothing if libcurl is built to use GnuTLS. | ||||||
| .IP CURLOPT_RANDOM_FILE | .IP CURLOPT_RANDOM_FILE | ||||||
| Pass a char * to a zero terminated file name. The file will be used to read | Pass a char * to a zero terminated file name. The file will be used to read | ||||||
| from to seed the random engine for SSL. The more random the specified file is, | from to seed the random engine for SSL. The more random the specified file is, | ||||||
| @@ -1282,12 +1303,29 @@ compile OpenSSL. | |||||||
|  |  | ||||||
| You'll find more details about cipher lists on this URL: | You'll find more details about cipher lists on this URL: | ||||||
| \fIhttp://www.openssl.org/docs/apps/ciphers.html\fP | \fIhttp://www.openssl.org/docs/apps/ciphers.html\fP | ||||||
|  | .IP CURLOPT_SSL_SESSIONID_CACHE | ||||||
|  | Pass a long set to 0 to disable libcurl's use of SSL session-ID caching. Set | ||||||
|  | this to 1 to enable it. By default all transfers are done using the | ||||||
|  | cache. Note that while nothing ever should get hurt by attempting to reuse SSL | ||||||
|  | session-IDs, there seem to be broken SSL implementations in the wild that may | ||||||
|  | require you to disable this in order for you to succeed. (Added in 7.16.0) | ||||||
| .IP CURLOPT_KRB4LEVEL | .IP CURLOPT_KRB4LEVEL | ||||||
| Pass a char * as parameter. Set the krb4 security level, this also enables | Pass a char * as parameter. Set the krb4 security level, this also enables | ||||||
| krb4 awareness.  This is a string, 'clear', 'safe', 'confidential' or | krb4 awareness.  This is a string, 'clear', 'safe', 'confidential' or | ||||||
| \&'private'.  If the string is set but doesn't match one of these, 'private' | \&'private'.  If the string is set but doesn't match one of these, 'private' | ||||||
| will be used. Set the string to NULL to disable kerberos4. The kerberos | will be used. Set the string to NULL to disable kerberos4. The kerberos | ||||||
| support only works for FTP. | support only works for FTP. | ||||||
|  | .SH SSH OPTIONS | ||||||
|  | .IP CURLOPT_SSH_AUTH_TYPES | ||||||
|  | Pass a long set to a bitmask consisting of one or more of | ||||||
|  | CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST, | ||||||
|  | CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. | ||||||
|  | .IP CURLOPT_SSH_PUBLIC_KEYFILE | ||||||
|  | Pass a char * pointing to a file name for your public key. If not used, | ||||||
|  | libcurl defaults to using \fB~/.ssh/id_dsa.pub\fP. | ||||||
|  | .IP CURLOPT_SSH_PRIVATE_KEYFILE | ||||||
|  | Pass a char * pointing to a file name for your private key. If not used, | ||||||
|  | libcurl defaults to using \fB~/.ssh/id_dsa\fP. | ||||||
| .SH OTHER OPTIONS | .SH OTHER OPTIONS | ||||||
| .IP CURLOPT_PRIVATE | .IP CURLOPT_PRIVATE | ||||||
| Pass a char * as parameter, pointing to data that should be associated with | Pass a char * as parameter, pointing to data that should be associated with | ||||||
|   | |||||||
| @@ -23,88 +23,96 @@ After the \fIlastitem\fP pointer follow the real arguments. | |||||||
|  |  | ||||||
| The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to | The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to | ||||||
| NULL in the first call to this function. All list-data will be allocated by | NULL in the first call to this function. All list-data will be allocated by | ||||||
| the function itself. You must call \fIcurl_formfree\fP after the form post has | the function itself. You must call \fIcurl_formfree(3)\fP after the form post | ||||||
| been done to free the resources again. | has been done to free the resources. | ||||||
|  |  | ||||||
| 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. | ||||||
|  |  | ||||||
| First, there are some basics you need to understand about multipart/formdata | First, there are some basics you need to understand about multipart/formdata | ||||||
| posts. Each part consists of at least a NAME and a CONTENTS part. If the part | posts. Each part consists of at least a NAME and a CONTENTS part. If the part | ||||||
| is made for file upload, there are also a stored CONTENT-TYPE and a | is made for file upload, there are also a stored CONTENT-TYPE and a FILENAME. | ||||||
| FILENAME. Below here, we'll discuss on what options you use to set these | Below, we'll discuss what options you use to set these properties in the | ||||||
| properties in the parts you want to add to your post. | parts you want to add to your post. | ||||||
|  |  | ||||||
|  | The options listed first are for making normal parts. The options from | ||||||
|  | \fICURLFORM_FILE\fP through \fICURLFORM_BUFFERLENGTH\fP are for file upload | ||||||
|  | parts. | ||||||
|  |  | ||||||
| .SH OPTIONS | .SH OPTIONS | ||||||
|  |  | ||||||
| .IP CURLFORM_COPYNAME | .IP CURLFORM_COPYNAME | ||||||
| followed by string is used to set the name of this part. libcurl copies the | followed by a string which provides the \fIname\fP of this part. libcurl | ||||||
| given data, so your application doesn't need to keep it around after this | copies the string so your application doesn't need to keep it around after | ||||||
| function call. If the name isn't zero terminated properly, or if you'd like it | this function call. If the name isn't null terminated, or if you'd | ||||||
| to contain zero bytes, you need to set the length of the name with | like it to contain zero bytes, you must set its length with | ||||||
| \fBCURLFORM_NAMELENGTH\fP. | \fBCURLFORM_NAMELENGTH\fP. The copied data will be freed by | ||||||
|  | \fIcurl_formfree(3)\fP. | ||||||
|  |  | ||||||
| .IP CURLFORM_PTRNAME | .IP CURLFORM_PTRNAME | ||||||
| followed by a string is used for the name of this part. libcurl will use the | followed by a string which provides the \fIname\fP of this part. libcurl | ||||||
| pointer and refer to the data in your application, you must make sure it | will use the pointer and refer to the data in your application, so you | ||||||
| remains until curl no longer needs it. If the name isn't zero terminated | must make sure it remains until curl no longer needs it. If the name | ||||||
| properly, or if you'd like it to contain zero bytes, you need to set the | isn't null terminated, or if you'd like it to contain zero | ||||||
| length of the name with \fBCURLFORM_NAMELENGTH\fP. | bytes, you must set its length with \fBCURLFORM_NAMELENGTH\fP. | ||||||
|  |  | ||||||
| .IP CURLFORM_COPYCONTENTS | .IP CURLFORM_COPYCONTENTS | ||||||
| followed by a string is used for the contents of this part, the actual data to | followed by a pointer to the contents of this part, the actual data | ||||||
| send away. libcurl copies the given data, so your application doesn't need to | to send away. libcurl copies the provided data, so your application doesn't | ||||||
| keep it around after this function call. If the data isn't zero terminated | need to keep it around after this function call. If the data isn't null | ||||||
| properly, or if you'd like it to contain zero bytes, you need to set the | terminated, or if you'd like it to contain zero bytes, you must | ||||||
| length of the name with \fBCURLFORM_CONTENTSLENGTH\fP. | set the length of the name with \fBCURLFORM_CONTENTSLENGTH\fP. The copied | ||||||
|  | data will be freed by \fIcurl_formfree(3)\fP. | ||||||
|  |  | ||||||
| .IP CURLFORM_PTRCONTENTS | .IP CURLFORM_PTRCONTENTS | ||||||
| followed by a string is used for the contents of this part, the actual data to | followed by a pointer to the contents of this part, the actual data | ||||||
| send away. libcurl will use the pointer and refer to the data in your | to send away. libcurl will use the pointer and refer to the data in your | ||||||
| application, you must make sure it remains until curl no longer needs it. If | application, so you must make sure it remains until curl no longer needs it. | ||||||
| the data isn't zero terminated properly, or if you'd like it to contain zero | If the data isn't null terminated, or if you'd like it to contain zero bytes, | ||||||
| bytes, you need to set the length of the name with | you must set its length  with \fBCURLFORM_CONTENTSLENGTH\fP. | ||||||
| \fBCURLFORM_CONTENTSLENGTH\fP. |  | ||||||
|  |  | ||||||
| .IP CURLFORM_CONTENTSLENGTH | .IP CURLFORM_CONTENTSLENGTH | ||||||
| followed by a long setting the length of the contents. | followed by a long giving the length of the contents. | ||||||
|  |  | ||||||
| .IP CURLFORM_FILECONTENT | .IP CURLFORM_FILECONTENT | ||||||
| followed by a file name, makes that file read and the contents will be used in | followed by a filename, causes that file to be read and its contents used | ||||||
| as data in this part. | as data in this part. This part does \fInot\fP automatically become a file | ||||||
|  | upload part simply because its data was read from a file. | ||||||
|  |  | ||||||
| .IP CURLFORM_FILE | .IP CURLFORM_FILE | ||||||
| followed by a file name, makes this part a file upload part. It sets the file | followed by a filename, makes this part a file upload part. It sets the | ||||||
| name field to the actual file name used here, it gets the contents of the file | \fIfilename\fP field to the basename of the provided filename, it reads the | ||||||
| and passes as data and sets the content-type if the given file match one of | contents of the file and passes them as data and sets the content-type if the | ||||||
| the new internally known file extension.  For \fBCURLFORM_FILE\fP the user may | given file match one of the internally known file extensions.  For | ||||||
| send one or more files in one part by providing multiple \fBCURLFORM_FILE\fP | \fBCURLFORM_FILE\fP the user may send one or more files in one part by | ||||||
| arguments each followed by the filename (and each CURLFORM_FILE is allowed to | providing multiple \fBCURLFORM_FILE\fP arguments each followed by the | ||||||
| have a CURLFORM_CONTENTTYPE). | filename (and each CURLFORM_FILE is allowed to have a CURLFORM_CONTENTTYPE). | ||||||
|  |  | ||||||
| .IP CURLFORM_CONTENTTYPE | .IP CURLFORM_CONTENTTYPE | ||||||
| followed by a pointer to a string with a content-type will make curl use this | is used in combination with \fICURLFORM_FILE\fP. Followed by a pointer to a | ||||||
| given content-type for this file upload part, possibly instead of an | string which provides the content-type for this part, possibly instead of an | ||||||
| internally chosen one. | internally chosen one. | ||||||
|  |  | ||||||
| .IP CURLFORM_FILENAME | .IP CURLFORM_FILENAME | ||||||
| followed by a pointer to a string to a name, will make libcurl use the given | is used in combination with \fICURLFORM_FILE\fP. Followed by a pointer to a | ||||||
| name in the file upload part, instead of the actual file name given to | string, it tells libcurl to use the given string as the \fIfilename\fP in the | ||||||
| \fICURLFORM_FILE\fP. | file upload part instead of the actual file name. | ||||||
|  |  | ||||||
| .IP CURLFORM_BUFFER | .IP CURLFORM_BUFFER | ||||||
| followed by a string, tells libcurl that a buffer is to be used to upload data | is used for custom file upload parts without use of \fICURLFORM_FILE\fP.  It | ||||||
| instead of using a file. The given string is used as the value of the file | tells libcurl that the file contents are already present in a buffer.  The | ||||||
| name field in the content header. | parameter is a string which provides the \fIfilename\fP field in the content | ||||||
|  | header. | ||||||
|  |  | ||||||
| .IP CURLFORM_BUFFERPTR | .IP CURLFORM_BUFFERPTR | ||||||
| followed by a pointer to a data area, tells libcurl the address of the buffer | is used in combination with \fICURLFORM_BUFFER\fP. The parameter is a pointer | ||||||
| containing data to upload (as indicated with \fICURLFORM_BUFFER\fP). The | to the buffer to be uploaded. This buffer must not be freed until after | ||||||
| buffer containing this data must not be freed until after |  | ||||||
| \fIcurl_easy_cleanup(3)\fP is called. You must also use | \fIcurl_easy_cleanup(3)\fP is called. You must also use | ||||||
| \fICURLFORM_BUFFERLENGTH\fP to set the length of the given buffer area. | \fICURLFORM_BUFFERLENGTH\fP to set the number of bytes in the buffer. | ||||||
|  |  | ||||||
| .IP CURLFORM_BUFFERLENGTH | .IP CURLFORM_BUFFERLENGTH | ||||||
| followed by a long with the size of the \fICURLFORM_BUFFERPTR\fP data area, | is used in combination with \fICURLFORM_BUFFER\fP. The parameter is a | ||||||
| tells libcurl the length of the buffer to upload. | long which gives the length of the buffer. | ||||||
|  |  | ||||||
| .IP CURLFORM_ARRAY | .IP CURLFORM_ARRAY | ||||||
| Another possibility to send options to curl_formadd() is the | Another possibility to send options to curl_formadd() is the | ||||||
|   | |||||||
| @@ -20,8 +20,14 @@ NULL is returned as a signal that there is no more to get at this point. The | |||||||
| integer pointed to with \fImsgs_in_queue\fP will contain the number of | integer pointed to with \fImsgs_in_queue\fP will contain the number of | ||||||
| remaining messages after this function was called. | remaining messages after this function was called. | ||||||
|  |  | ||||||
|  | When you fetch a message using this function, it is removed from the internal | ||||||
|  | queue so calling this function again will not return the same message | ||||||
|  | again. It will instead return new messages at each new invoke until the queue | ||||||
|  | is emptied. | ||||||
|  |  | ||||||
| The data the returned pointer points to will not survive calling | The data the returned pointer points to will not survive calling | ||||||
| \fIcurl_multi_cleanup(3)\fP or \fIcurl_multi_remove_handle(3)\fP. | \fIcurl_multi_cleanup(3)\fP, \fIcurl_multi_remove_handle(3)\fP or | ||||||
|  | \fIcurl_easy_cleanup(3)\fP. | ||||||
|  |  | ||||||
| The 'CURLMsg' struct is very simple and only contain very basic information. | The 'CURLMsg' struct is very simple and only contain very basic information. | ||||||
| If more involved information is wanted, the particular "easy handle" in | If more involved information is wanted, the particular "easy handle" in | ||||||
| @@ -37,6 +43,12 @@ present in that struct and can thus be used in subsequent regular | |||||||
|      CURLcode result;   /* return code for transfer */ |      CURLcode result;   /* return code for transfer */ | ||||||
|    } data; |    } data; | ||||||
|  }; |  }; | ||||||
|  |  | ||||||
|  | When \fBmsg\fP is \fICURLMSG_DONE\fP, the message identifies a transfer that | ||||||
|  | is done, and then \fBresult\fP contains the return code for the easy handle | ||||||
|  | that just completed. | ||||||
|  |  | ||||||
|  | At this point, there is no other \fBmsg\fP types defined. | ||||||
| .SH "RETURN VALUE" | .SH "RETURN VALUE" | ||||||
| A pointer to a filled-in struct, or NULL if it failed or ran out of | A pointer to a filled-in struct, or NULL if it failed or ran out of | ||||||
| structs. It also writes the number of messages left in the queue (after this | structs. It also writes the number of messages left in the queue (after this | ||||||
|   | |||||||
| @@ -30,11 +30,15 @@ If you receive \fICURLM_CALL_MULTI_PERFORM\fP, this basically means that you | |||||||
| should call \fIcurl_multi_perform\fP again, before you select() on more | should call \fIcurl_multi_perform\fP again, before you select() on more | ||||||
| actions. You don't have to do it immediately, but the return code means that | actions. You don't have to do it immediately, but the return code means that | ||||||
| libcurl may have more data available to return or that there may be more data | libcurl may have more data available to return or that there may be more data | ||||||
| to send off before it is "satisfied". | to send off before it is "satisfied". Do note that \fIcurl_multi_perform(3)\fP | ||||||
|  | will return \fICURLM_CALL_MULTI_PERFORM\fP only when it wants to be called | ||||||
|  | again \fBimmediately\fP. When things are fine and there are nothing immediate | ||||||
|  | it wants done, it'll return \fICURLM_OK\fP and you need to wait for \&"action" | ||||||
|  | and then call this function again. | ||||||
|  |  | ||||||
| NOTE that this only returns errors etc regarding the whole multi stack. There | NOTE that this only returns errors etc regarding the whole multi stack. There | ||||||
| might still have occurred problems on individual transfers even when this | might still have occurred problems on individual transfers even when this | ||||||
| function returns OK. | function returns \fICURLM_OK\fP. | ||||||
| .SH "TYPICAL USAGE" | .SH "TYPICAL USAGE" | ||||||
| Most applications will use \fIcurl_multi_fdset(3)\fP to get the multi_handle's | Most applications will use \fIcurl_multi_fdset(3)\fP to get the multi_handle's | ||||||
| file descriptors, then it'll wait for action on them using \fBselect(3)\fP and | file descriptors, then it'll wait for action on them using \fBselect(3)\fP and | ||||||
| @@ -42,4 +46,5 @@ as soon as one or more of them are ready, \fIcurl_multi_perform(3)\fP gets | |||||||
| called. | called. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl_multi_cleanup "(3), " curl_multi_init "(3), " | .BR curl_multi_cleanup "(3), " curl_multi_init "(3), " | ||||||
| .BR curl_multi_fdset "(3), " curl_multi_info_read "(3)" | .BR curl_multi_fdset "(3), " curl_multi_info_read "(3), " | ||||||
|  | .BR libcurl-errors "(3)" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_multi_setopt 3 "8 Jan 2006" "libcurl 7.16.0" "libcurl Manual" | .TH curl_multi_setopt 3 "10 Oct 2006" "libcurl 7.16.0" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_multi_setopt \- set options for a curl multi handle | curl_multi_setopt \- set options for a curl multi handle | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -9,7 +9,7 @@ curl_multi_setopt \- set options for a curl multi handle | |||||||
| CURLMcode curl_multi_setopt(CURLM * multi_handle, CURLMoption option, param); | CURLMcode curl_multi_setopt(CURLM * multi_handle, CURLMoption option, param); | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| curl_multi_setopt() is used to tell a libcurl multi handle how to behave. By | curl_multi_setopt() is used to tell a libcurl multi handle how to behave. By | ||||||
| using the appropriate options to \fIcurl_multi_setopt\fP, you can change | using the appropriate options to \fIcurl_multi_setopt(3)\fP, you can change | ||||||
| libcurl's behaviour when using that multi handle.  All options are set with | libcurl's behaviour when using that multi handle.  All options are set with | ||||||
| the \fIoption\fP followed by the parameter \fIparam\fP. That parameter can be | the \fIoption\fP followed by the parameter \fIparam\fP. That parameter can be | ||||||
| a \fBlong\fP, a \fBfunction pointer\fP, an \fBobject pointer\fP or a | a \fBlong\fP, a \fBfunction pointer\fP, an \fBobject pointer\fP or a | ||||||
| @@ -19,19 +19,43 @@ You can only set one option in each function call. | |||||||
|  |  | ||||||
| .SH OPTIONS | .SH OPTIONS | ||||||
| .IP CURLMOPT_SOCKETFUNCTION | .IP CURLMOPT_SOCKETFUNCTION | ||||||
| Pass a pointer to a function matching the curl_socket_callback prototype. The | Pass a pointer to a function matching the \fBcurl_socket_callback\fP | ||||||
| \fIcurl_multi_socket(3)\fP functions inform the application about updates in | prototype. The \fIcurl_multi_socket(3)\fP functions inform the application | ||||||
| the socket (file descriptor) status by doing none, one or multiple calls to | about updates in the socket (file descriptor) status by doing none, one or | ||||||
| the curl_socket_callback given in the \fBparam\fP argument. They update the | multiple calls to the curl_socket_callback given in the \fBparam\fP | ||||||
| status with changes since the previous time a \fIcurl_multi_socket(3)\fP | argument. They update the status with changes since the previous time a | ||||||
| function was called. If the given callback pointer is NULL, no callback will | \fIcurl_multi_socket(3)\fP function was called. If the given callback pointer | ||||||
| be called. Set the callback's \fBuserp\fP argument with | is NULL, no callback will be called. Set the callback's \fBuserp\fP argument | ||||||
| \fICURLMOPT_SOCKETDATA\fP.  See \fIcurl_multi_socket(3)\fP for more callback | with \fICURLMOPT_SOCKETDATA\fP.  See \fIcurl_multi_socket(3)\fP for more | ||||||
| details. | callback details. | ||||||
| .IP CURLMOPT_SOCKETDATA | .IP CURLMOPT_SOCKETDATA | ||||||
| Pass a pointer to whatever you want passed to the curl_socket_callback's forth | Pass a pointer to whatever you want passed to the \fBcurl_socket_callback\fP's | ||||||
| argument, the userp pointer. This is not used by libcurl but only passed-thru | forth argument, the userp pointer. This is not used by libcurl but only | ||||||
| as-is. Set the callback pointer with \fICURLMOPT_SOCKETFUNCTION\fP. | passed-thru as-is. Set the callback pointer with | ||||||
|  | \fICURLMOPT_SOCKETFUNCTION\fP. | ||||||
|  | .IP CURLMOPT_PIPELINING | ||||||
|  | Pass a long set to 1 to enable or 0 to disable. Enabling pipelining on a multi | ||||||
|  | handle will make it attempt to perform HTTP Pipelining as far as possible for | ||||||
|  | transfers using this handle. This means that if you add a second request that | ||||||
|  | can use an already existing connection, the second request will be \&"piped" | ||||||
|  | on the same connection rather than being executed in parallell. (Added in | ||||||
|  | 7.16.0) | ||||||
|  | .IP CURLMOPT_TIMERFUNCTION | ||||||
|  | Pass a pointer to a function matching the \fBcurl_multi_timer_callback\fP | ||||||
|  | prototype.  This function will then be called when the timeout value | ||||||
|  | changes. The timeout value is at what latest time the application should call | ||||||
|  | one of the \&"performing" functions of the multi interface | ||||||
|  | (\fIcurl_multi_socket(3)\fP, \fIcurl_multi_socket_all(3)\fP and | ||||||
|  | \fIcurl_multi_perform(3)\fP) - to allow libcurl to keep timeouts and retries | ||||||
|  | etc to work. Libcurl attempts to limit calling this only when the fixed future | ||||||
|  | timeout time actually change. See also \fICURLMOPT_TIMERDATA\fP. This callback | ||||||
|  | can be used instead of, or in addition to, \fIcurl_multi_timeout(3)\fP. (Added | ||||||
|  | in 7.16.0) | ||||||
|  | .IP CURLMOPT_TIMERDATA | ||||||
|  | Pass a pointer to whatever you want passed to the | ||||||
|  | \fBcurl_multi_timer_callback\fP's third argument, the userp pointer.  This is | ||||||
|  | not used by libcurl but only passed-thru as-is. Set the callback pointer with | ||||||
|  | \fICURLMOPT_TIMERFUNCTION\fP. (Added in 7.16.0) | ||||||
| .SH RETURNS | .SH RETURNS | ||||||
| The standard CURLMcode for multi interface error codes. Note that it returns a | The standard CURLMcode for multi interface error codes. Note that it returns a | ||||||
| CURLM_UNKNOWN_OPTION if you try setting an option that this version of libcurl | CURLM_UNKNOWN_OPTION if you try setting an option that this version of libcurl | ||||||
|   | |||||||
| @@ -24,8 +24,9 @@ The list should be freed again (after usage) with | |||||||
| A null pointer is returned if anything went wrong, otherwise the new list | A null pointer is returned if anything went wrong, otherwise the new list | ||||||
| pointer is returned. | pointer is returned. | ||||||
| .SH EXAMPLE | .SH EXAMPLE | ||||||
|  | .nf | ||||||
|  CURL handle; |  CURL handle; | ||||||
|  curl_slist *slist=NULL; |  struct curl_slist *slist=NULL; | ||||||
|  |  | ||||||
|  slist = curl_slist_append(slist, "pragma:"); |  slist = curl_slist_append(slist, "pragma:"); | ||||||
|  curl_easy_setopt(handle, CURLOPT_HTTPHEADER, slist); |  curl_easy_setopt(handle, CURLOPT_HTTPHEADER, slist); | ||||||
| @@ -33,5 +34,6 @@ pointer is returned. | |||||||
|  curl_easy_perform(handle); |  curl_easy_perform(handle); | ||||||
|  |  | ||||||
|  curl_slist_free_all(slist); /* free the list again */ |  curl_slist_free_all(slist); /* free the list again */ | ||||||
|  | .fi | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl_slist_free_all "(3), " | .BR curl_slist_free_all "(3), " | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ | |||||||
| .\" * $Id$ | .\" * $Id$ | ||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" | .\" | ||||||
| .TH curl_version_info 3 "19 Apr 2006" "libcurl 7.15.4" "libcurl Manual" | .TH curl_version_info 3 "2 Nov 2006" "libcurl 7.16.1" "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 | ||||||
| @@ -66,6 +66,11 @@ typedef struct { | |||||||
|   /* when 'age' is 2 or higher, the member below also exists: */ |   /* when 'age' is 2 or higher, the member below also exists: */ | ||||||
|   const char *libidn;       /* human readable string */ |   const char *libidn;       /* human readable string */ | ||||||
|  |  | ||||||
|  |   /* when 'age' is 3 or higher, the members below also exist: */ | ||||||
|  |   int iconv_ver_num;       /* '_libiconv_version' if iconv support enabled */ | ||||||
|  |  | ||||||
|  |   const char *libssh_version; /* human readable string */ | ||||||
|  |  | ||||||
| } curl_version_info_data; | } curl_version_info_data; | ||||||
| .fi | .fi | ||||||
|  |  | ||||||
|   | |||||||
| @@ -174,7 +174,7 @@ problem with the local client certificate | |||||||
| .IP "CURLE_SSL_CIPHER (59)" | .IP "CURLE_SSL_CIPHER (59)" | ||||||
| couldn't use specified cipher | couldn't use specified cipher | ||||||
| .IP "CURLE_SSL_CACERT (60)" | .IP "CURLE_SSL_CACERT (60)" | ||||||
| problem with the CA cert (path? access rights?)  | peer certificate cannot be authenticated with known CA certificates | ||||||
| .IP "CURLE_BAD_CONTENT_ENCODING (61)" | .IP "CURLE_BAD_CONTENT_ENCODING (61)" | ||||||
| Unrecognized transfer encoding | Unrecognized transfer encoding | ||||||
| .IP "CURLE_LDAP_INVALID_URL (62)" | .IP "CURLE_LDAP_INVALID_URL (62)" | ||||||
| @@ -208,6 +208,8 @@ No such TFTP user | |||||||
| Character conversion failed | Character conversion failed | ||||||
| .IP "CURLE_CONV_REQD (76)" | .IP "CURLE_CONV_REQD (76)" | ||||||
| Caller must register conversion callbacks | Caller must register conversion callbacks | ||||||
|  | .IP "CURLE_SSL_CACERT_BADFILE (77)" | ||||||
|  | Problem with reading the SSL CA cert (path? access rights?) | ||||||
| .SH "CURLMcode" | .SH "CURLMcode" | ||||||
| This is the generic return code used by functions in the libcurl multi | This is the generic return code used by functions in the libcurl multi | ||||||
| interface. Also consider \fIcurl_multi_strerror(3)\fP. | interface. Also consider \fIcurl_multi_strerror(3)\fP. | ||||||
| @@ -219,7 +221,9 @@ Things are fine. | |||||||
| .IP "CURLM_BAD_HANDLE (1)" | .IP "CURLM_BAD_HANDLE (1)" | ||||||
| The passed-in handle is not a valid CURLM handle. | The passed-in handle is not a valid CURLM handle. | ||||||
| .IP "CURLM_BAD_EASY_HANDLE (2)" | .IP "CURLM_BAD_EASY_HANDLE (2)" | ||||||
| An easy handle was not good/valid. | An easy handle was not good/valid. It could mean that it isn't an easy handle | ||||||
|  | at all, or possibly that the handle already is in used by this or another | ||||||
|  | multi handle. | ||||||
| .IP "CURLM_OUT_OF_MEMORY (3)" | .IP "CURLM_OUT_OF_MEMORY (3)" | ||||||
| You are doomed. | You are doomed. | ||||||
| .IP "CURLM_INTERNAL_ERROR (4)" | .IP "CURLM_INTERNAL_ERROR (4)" | ||||||
|   | |||||||
| @@ -74,7 +74,7 @@ struct fdinfo { | |||||||
|   long timeout; /* as set by libcurl */ |   long timeout; /* as set by libcurl */ | ||||||
|   struct event ev; /* */ |   struct event ev; /* */ | ||||||
|   int evset; /* true if the 'ev' struct has been used in a event_set() call */ |   int evset; /* true if the 'ev' struct has been used in a event_set() call */ | ||||||
|   CURLMcode *multi; /* pointer to the multi handle */ |   CURLM *multi; /* pointer to the multi handle */ | ||||||
|   int *running_handles; /* pointer to the running_handles counter */ |   int *running_handles; /* pointer to the running_handles counter */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -86,6 +86,8 @@ static int running_handles; | |||||||
|    done, we can remove the timerevent as well */ |    done, we can remove the timerevent as well */ | ||||||
| static struct event timerevent; | static struct event timerevent; | ||||||
|  |  | ||||||
|  | static void update_timeout(CURLM *multi_handle); | ||||||
|  |  | ||||||
| /* called from libevent on action on a particular socket ("event") */ | /* called from libevent on action on a particular socket ("event") */ | ||||||
| static void eventcallback(int fd, short type, void *userp) | static void eventcallback(int fd, short type, void *userp) | ||||||
| { | { | ||||||
| @@ -110,6 +112,8 @@ static void eventcallback(int fd, short type, void *userp) | |||||||
|     if(evtimer_pending(&timerevent, NULL)) |     if(evtimer_pending(&timerevent, NULL)) | ||||||
|       evtimer_del(&timerevent); |       evtimer_del(&timerevent); | ||||||
|   } |   } | ||||||
|  |   else | ||||||
|  |     update_timeout(fdp->multi); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* called from libevent when our timer event expires */ | /* called from libevent when our timer event expires */ | ||||||
| @@ -118,8 +122,6 @@ static void timercallback(int fd, short type, void *userp) | |||||||
|   (void)fd; /* not used for this */ |   (void)fd; /* not used for this */ | ||||||
|   (void)type; /* ignored in here */ |   (void)type; /* ignored in here */ | ||||||
|   CURLM *multi_handle = (CURLM *)userp; |   CURLM *multi_handle = (CURLM *)userp; | ||||||
|   long timeout_ms; |  | ||||||
|   struct timeval timeout; |  | ||||||
|   int running_handles; |   int running_handles; | ||||||
|   CURLMcode rc; |   CURLMcode rc; | ||||||
|  |  | ||||||
| @@ -131,15 +133,9 @@ static void timercallback(int fd, short type, void *userp) | |||||||
|                            &running_handles); |                            &running_handles); | ||||||
|   } while (rc == CURLM_CALL_MULTI_PERFORM); |   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||||
|  |  | ||||||
|   if(running_handles) { |   if(running_handles) | ||||||
|     /* Get the current timeout value from libcurl and set a new timeout */ |     /* Get the current timeout value from libcurl and set a new timeout */ | ||||||
|     curl_multi_timeout(multi_handle, &timeout_ms); |     update_timeout(multi_handle); | ||||||
|  |  | ||||||
|     /* convert ms to timeval */ |  | ||||||
|     timeout.tv_sec = timeout_ms/1000; |  | ||||||
|     timeout.tv_usec = (timeout_ms%1000)*1000; |  | ||||||
|     evtimer_add(&timerevent, &timeout); |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| static void remsock(struct fdinfo *f) | static void remsock(struct fdinfo *f) | ||||||
| @@ -266,6 +262,7 @@ writecallback(void *ptr, size_t size, size_t nmemb, void *data) | |||||||
| { | { | ||||||
|   size_t realsize = size * nmemb; |   size_t realsize = size * nmemb; | ||||||
|   struct connection *c = (struct connection *)data; |   struct connection *c = (struct connection *)data; | ||||||
|  |   (void)ptr; | ||||||
|  |  | ||||||
|   c->dlcounter += realsize; |   c->dlcounter += realsize; | ||||||
|   c->global->dlcounter += realsize; |   c->global->dlcounter += realsize; | ||||||
| @@ -283,19 +280,28 @@ int num_total; | |||||||
| int num_idle; | int num_idle; | ||||||
| int num_active; | int num_active; | ||||||
|  |  | ||||||
|  | static void update_timeout(CURLM *multi_handle) | ||||||
|  | { | ||||||
|  |   long timeout_ms; | ||||||
|  |   struct timeval timeout; | ||||||
|  |  | ||||||
|  |   /* Since we need a global timeout to occur after a given time of inactivity, | ||||||
|  |      we use a single timeout-event. Get the timeout value from libcurl, and | ||||||
|  |      update it after every call to libcurl. */ | ||||||
|  |   curl_multi_timeout(multi_handle, &timeout_ms); | ||||||
|  |  | ||||||
|  |   /* convert ms to timeval */ | ||||||
|  |   timeout.tv_sec = timeout_ms/1000; | ||||||
|  |   timeout.tv_usec = (timeout_ms%1000)*1000; | ||||||
|  |   evtimer_add(&timerevent, &timeout); | ||||||
|  | } | ||||||
|  |  | ||||||
| int main(int argc, char **argv) | int main(int argc, char **argv) | ||||||
| { | { | ||||||
|   CURLM *multi_handle; |   CURLM *multi_handle; | ||||||
|   CURLMsg *msg; |   CURLMsg *msg; | ||||||
|   CURLcode code = CURLE_OK; |   CURLcode code = CURLE_OK; | ||||||
|   CURLMcode mcode = CURLM_OK; |  | ||||||
|   int rc; |  | ||||||
|   int i; |   int i; | ||||||
|   int selectmaxamount; |  | ||||||
|   struct fdinfo *fdp; |  | ||||||
|   char act; |  | ||||||
|   long timeout_ms; |  | ||||||
|   struct timeval timeout; |  | ||||||
|  |  | ||||||
|   memset(&info, 0, sizeof(struct globalinfo)); |   memset(&info, 0, sizeof(struct globalinfo)); | ||||||
|  |  | ||||||
| @@ -327,9 +333,11 @@ int main(int argc, char **argv) | |||||||
|   /* init the multi stack */ |   /* init the multi stack */ | ||||||
|   multi_handle = curl_multi_init(); |   multi_handle = curl_multi_init(); | ||||||
|  |  | ||||||
|  |   /* initialize the timeout event */ | ||||||
|  |   evtimer_set(&timerevent, timercallback, multi_handle); | ||||||
|  |  | ||||||
|   for(i=0; i< num_total; i++) { |   for(i=0; i< num_total; i++) { | ||||||
|     CURL *e; |     CURL *e; | ||||||
|     char *nl; |  | ||||||
|  |  | ||||||
|     memset(&conns[i], 0, sizeof(struct connection)); |     memset(&conns[i], 0, sizeof(struct connection)); | ||||||
|  |  | ||||||
| @@ -370,14 +378,8 @@ int main(int argc, char **argv) | |||||||
|   while(CURLM_CALL_MULTI_PERFORM == curl_multi_socket_all(multi_handle, |   while(CURLM_CALL_MULTI_PERFORM == curl_multi_socket_all(multi_handle, | ||||||
|                                                           &running_handles)); |                                                           &running_handles)); | ||||||
|  |  | ||||||
|   /* Since we need a global timeout to occur after a given time of inactivity, |   /* update timeout */ | ||||||
|      we add a single timeout-event. Get the timeout value from libcurl */ |   update_timeout(multi_handle); | ||||||
|   curl_multi_timeout(multi_handle, &timeout_ms); |  | ||||||
|   /* convert ms to timeval */ |  | ||||||
|   timeout.tv_sec = timeout_ms/1000; |  | ||||||
|   timeout.tv_usec = (timeout_ms%1000)*1000; |  | ||||||
|   evtimer_set(&timerevent, timercallback, multi_handle); |  | ||||||
|   evtimer_add(&timerevent, &timeout); |  | ||||||
|  |  | ||||||
|   /* event_dispatch() runs the event main loop. It ends when no events are |   /* event_dispatch() runs the event main loop. It ends when no events are | ||||||
|      left to wait for. */ |      left to wait for. */ | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2007, 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 | ||||||
| @@ -133,6 +133,49 @@ extern "C" { | |||||||
| #undef FILESIZEBITS | #undef FILESIZEBITS | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if defined(_WIN32) && !defined(WIN32) | ||||||
|  | /* Chris Lewis mentioned that he doesn't get WIN32 defined, only _WIN32 so we | ||||||
|  |    make this adjustment to catch this. */ | ||||||
|  | #define WIN32 1 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) && \ | ||||||
|  |   !defined(__CYGWIN__) || defined(__MINGW32__) | ||||||
|  | #if !(defined(_WINSOCKAPI_) || defined(_WINSOCK_H)) | ||||||
|  | /* The check above prevents the winsock2 inclusion if winsock.h already was | ||||||
|  |    included, since they can't co-exist without problems */ | ||||||
|  | #include <winsock2.h> | ||||||
|  | #endif | ||||||
|  | #else | ||||||
|  |  | ||||||
|  | /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish | ||||||
|  |    libc5-based Linux systems. Only include it on system that are known to | ||||||
|  |    require it! */ | ||||||
|  | #if defined(_AIX) || defined(NETWARE) || defined(__NetBSD__) || defined(__minix) | ||||||
|  | #include <sys/select.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifndef _WIN32_WCE | ||||||
|  | #include <sys/socket.h> | ||||||
|  | #endif | ||||||
|  | #ifndef __WATCOMC__ | ||||||
|  | #include <sys/time.h> | ||||||
|  | #endif | ||||||
|  | #include <sys/types.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifndef curl_socket_typedef | ||||||
|  | /* socket typedef */ | ||||||
|  | #ifdef WIN32 | ||||||
|  | typedef SOCKET curl_socket_t; | ||||||
|  | #define CURL_SOCKET_BAD INVALID_SOCKET | ||||||
|  | #else | ||||||
|  | typedef int curl_socket_t; | ||||||
|  | #define CURL_SOCKET_BAD -1 | ||||||
|  | #endif | ||||||
|  | #define curl_socket_typedef | ||||||
|  | #endif /* curl_socket_typedef */ | ||||||
|  |  | ||||||
| struct curl_httppost { | struct curl_httppost { | ||||||
|   struct curl_httppost *next;       /* next entry in the list */ |   struct curl_httppost *next;       /* next entry in the list */ | ||||||
|   char *name;                       /* pointer to allocated name */ |   char *name;                       /* pointer to allocated name */ | ||||||
| @@ -184,6 +227,14 @@ typedef size_t (*curl_read_callback)(char *buffer, | |||||||
|                                       size_t nitems, |                                       size_t nitems, | ||||||
|                                       void *instream); |                                       void *instream); | ||||||
|  |  | ||||||
|  | typedef enum  { | ||||||
|  |   CURLSOCKTYPE_IPCXN, /* socket created for a specific IP connection */ | ||||||
|  |   CURLSOCKTYPE_LAST   /* never use */ | ||||||
|  | } curlsocktype; | ||||||
|  |  | ||||||
|  | typedef int (*curl_sockopt_callback)(void *clientp, | ||||||
|  |                                      curl_socket_t curlfd, | ||||||
|  |                                      curlsocktype purpose); | ||||||
|  |  | ||||||
| #ifndef CURL_NO_OLDIES | #ifndef CURL_NO_OLDIES | ||||||
|   /* not used since 7.10.8, will be removed in a future release */ |   /* not used since 7.10.8, will be removed in a future release */ | ||||||
| @@ -339,6 +390,15 @@ typedef enum { | |||||||
|                                     CURLOPT_CONV_FROM_NETWORK_FUNCTION, |                                     CURLOPT_CONV_FROM_NETWORK_FUNCTION, | ||||||
|                                     CURLOPT_CONV_TO_NETWORK_FUNCTION, and |                                     CURLOPT_CONV_TO_NETWORK_FUNCTION, and | ||||||
|                                     CURLOPT_CONV_FROM_UTF8_FUNCTION */ |                                     CURLOPT_CONV_FROM_UTF8_FUNCTION */ | ||||||
|  |   CURLE_SSL_CACERT_BADFILE,      /* 77 - could not load CACERT file, missing | ||||||
|  |                                     or wrong format */ | ||||||
|  |   CURLE_REMOTE_FILE_NOT_FOUND,   /* 78 - remote file not found */ | ||||||
|  |   CURLE_SSH,                     /* 79 - error from the SSH layer, somewhat | ||||||
|  |                                     generic so the error message will be of | ||||||
|  |                                     interest when this has happened */ | ||||||
|  |  | ||||||
|  |   CURLE_SSL_SHUTDOWN_FAILED,     /* 80 - Failed to shut down the SSL | ||||||
|  |                                     connection */ | ||||||
|   CURL_LAST /* never use! */ |   CURL_LAST /* never use! */ | ||||||
| } CURLcode; | } CURLcode; | ||||||
|  |  | ||||||
| @@ -374,6 +434,14 @@ typedef enum { | |||||||
| #define CURLAUTH_ANY ~0               /* all types set */ | #define CURLAUTH_ANY ~0               /* all types set */ | ||||||
| #define CURLAUTH_ANYSAFE (~CURLAUTH_BASIC) | #define CURLAUTH_ANYSAFE (~CURLAUTH_BASIC) | ||||||
|  |  | ||||||
|  | #define CURLSSH_AUTH_ANY       ~0     /* all types supported by the server */ | ||||||
|  | #define CURLSSH_AUTH_NONE      0      /* none allowed, silly but complete */ | ||||||
|  | #define CURLSSH_AUTH_PUBLICKEY (1<<0) /* public/private key files */ | ||||||
|  | #define CURLSSH_AUTH_PASSWORD  (1<<1) /* password */ | ||||||
|  | #define CURLSSH_AUTH_HOST      (1<<2) /* host key files */ | ||||||
|  | #define CURLSSH_AUTH_KEYBOARD  (1<<3) /* keyboard interactive */ | ||||||
|  | #define CURLSSH_AUTH_DEFAULT CURLSSH_AUTH_ANY | ||||||
|  |  | ||||||
| #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||||
|                           the obsolete stuff removed! */ |                           the obsolete stuff removed! */ | ||||||
| /* this was the error code 50 in 7.7.3 and a few earlier versions, this | /* this was the error code 50 in 7.7.3 and a few earlier versions, this | ||||||
| @@ -436,7 +504,7 @@ typedef enum { | |||||||
|  */ |  */ | ||||||
| #if defined(__STDC__) || defined(_MSC_VER) || defined(__cplusplus) || \ | #if defined(__STDC__) || defined(_MSC_VER) || defined(__cplusplus) || \ | ||||||
|   defined(__HP_aCC) || defined(__BORLANDC__) || defined(__LCC__) || \ |   defined(__HP_aCC) || defined(__BORLANDC__) || defined(__LCC__) || \ | ||||||
|   defined(__POCC__) || defined(__SALFORDC__) |   defined(__POCC__) || defined(__SALFORDC__) || defined(__HIGHC__) | ||||||
|   /* This compiler is believed to have an ISO compatible preprocessor */ |   /* This compiler is believed to have an ISO compatible preprocessor */ | ||||||
| #define CURL_ISOCPP | #define CURL_ISOCPP | ||||||
| #else | #else | ||||||
| @@ -890,22 +958,12 @@ typedef enum { | |||||||
|   CINIT(TCP_NODELAY, LONG, 121), |   CINIT(TCP_NODELAY, LONG, 121), | ||||||
|  |  | ||||||
|   /* 122 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ |   /* 122 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||||
|  |   /* 123 OBSOLETE. Gone in 7.16.0 */ | ||||||
|   /* When doing 3rd party transfer, set the source user and password with |  | ||||||
|      this */ |  | ||||||
|   CINIT(SOURCE_USERPWD, OBJECTPOINT, 123), |  | ||||||
|  |  | ||||||
|   /* 124 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ |   /* 124 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||||
|   /* 125 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ |   /* 125 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||||
|   /* 126 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ |   /* 126 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||||
|  |   /* 127 OBSOLETE. Gone in 7.16.0 */ | ||||||
|   /* When doing 3rd party transfer, set the source pre-quote linked list |   /* 128 OBSOLETE. Gone in 7.16.0 */ | ||||||
|      of commands with this */ |  | ||||||
|   CINIT(SOURCE_PREQUOTE, OBJECTPOINT, 127), |  | ||||||
|  |  | ||||||
|   /* When doing 3rd party transfer, set the source post-quote linked list |  | ||||||
|      of commands with this */ |  | ||||||
|   CINIT(SOURCE_POSTQUOTE, OBJECTPOINT, 128), |  | ||||||
|  |  | ||||||
|   /* When FTP over SSL/TLS is selected (with CURLOPT_FTP_SSL), this option |   /* When FTP over SSL/TLS is selected (with CURLOPT_FTP_SSL), this option | ||||||
|      can be used to change libcurl's default action which is to first try |      can be used to change libcurl's default action which is to first try | ||||||
| @@ -922,12 +980,8 @@ typedef enum { | |||||||
|   CINIT(IOCTLFUNCTION, FUNCTIONPOINT, 130), |   CINIT(IOCTLFUNCTION, FUNCTIONPOINT, 130), | ||||||
|   CINIT(IOCTLDATA, OBJECTPOINT, 131), |   CINIT(IOCTLDATA, OBJECTPOINT, 131), | ||||||
|  |  | ||||||
|   /* To make a 3rd party transfer, set the source URL with this */ |   /* 132 OBSOLETE. Gone in 7.16.0 */ | ||||||
|   CINIT(SOURCE_URL, OBJECTPOINT, 132), |   /* 133 OBSOLETE. Gone in 7.16.0 */ | ||||||
|  |  | ||||||
|   /* When doing 3rd party transfer, set the source quote linked list of |  | ||||||
|      commands with this */ |  | ||||||
|   CINIT(SOURCE_QUOTE, OBJECTPOINT, 133), |  | ||||||
|  |  | ||||||
|   /* zero terminated string for pass on to the FTP server when asked for |   /* zero terminated string for pass on to the FTP server when asked for | ||||||
|      "account" info */ |      "account" info */ | ||||||
| @@ -982,6 +1036,24 @@ typedef enum { | |||||||
|   /* Pointer to command string to send if USER/PASS fails. */ |   /* Pointer to command string to send if USER/PASS fails. */ | ||||||
|   CINIT(FTP_ALTERNATIVE_TO_USER, OBJECTPOINT, 147), |   CINIT(FTP_ALTERNATIVE_TO_USER, OBJECTPOINT, 147), | ||||||
|  |  | ||||||
|  |   /* callback function for setting socket options */ | ||||||
|  |   CINIT(SOCKOPTFUNCTION, FUNCTIONPOINT, 148), | ||||||
|  |   CINIT(SOCKOPTDATA, OBJECTPOINT, 149), | ||||||
|  |  | ||||||
|  |   /* set to 0 to disable session ID re-use for this transfer, default is | ||||||
|  |      enabled (== 1) */ | ||||||
|  |   CINIT(SSL_SESSIONID_CACHE, LONG, 150), | ||||||
|  |  | ||||||
|  |   /* allowed SSH authentication methods */ | ||||||
|  |   CINIT(SSH_AUTH_TYPES, LONG, 151), | ||||||
|  |  | ||||||
|  |   /* Used by scp/sftp to do public/private key authentication */ | ||||||
|  |   CINIT(SSH_PUBLIC_KEYFILE, OBJECTPOINT, 152), | ||||||
|  |   CINIT(SSH_PRIVATE_KEYFILE, OBJECTPOINT, 153), | ||||||
|  |  | ||||||
|  |   /* Send CCC (Clear Command Channel) after authentication */ | ||||||
|  |   CINIT(FTP_SSL_CCC, LONG, 154), | ||||||
|  |  | ||||||
|   CURLOPT_LASTENTRY /* the last unused */ |   CURLOPT_LASTENTRY /* the last unused */ | ||||||
| } CURLoption; | } CURLoption; | ||||||
|  |  | ||||||
| @@ -1000,18 +1072,6 @@ typedef enum { | |||||||
|  |  | ||||||
| #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||||
|                           the obsolete stuff removed! */ |                           the obsolete stuff removed! */ | ||||||
| #define CURLOPT_HTTPREQUEST    -1 |  | ||||||
| #define CURLOPT_FTPASCII       CURLOPT_TRANSFERTEXT |  | ||||||
| #define CURLOPT_MUTE           -2 |  | ||||||
| #define CURLOPT_PASSWDFUNCTION -3 |  | ||||||
| #define CURLOPT_PASSWDDATA     -4 |  | ||||||
| #define CURLOPT_CLOSEFUNCTION  -5 |  | ||||||
|  |  | ||||||
| #define CURLOPT_SOURCE_HOST    -6 |  | ||||||
| #define CURLOPT_SOURCE_PATH    -7 |  | ||||||
| #define CURLOPT_SOURCE_PORT    -8 |  | ||||||
| #define CURLOPT_PASV_HOST      -9 |  | ||||||
|  |  | ||||||
| #else | #else | ||||||
| /* This is set if CURL_NO_OLDIES is defined at compile-time */ | /* This is set if CURL_NO_OLDIES is defined at compile-time */ | ||||||
| #undef CURLOPT_DNS_USE_GLOBAL_CACHE /* soon obsolete */ | #undef CURLOPT_DNS_USE_GLOBAL_CACHE /* soon obsolete */ | ||||||
| @@ -1471,6 +1531,7 @@ typedef enum { | |||||||
|   CURLVERSION_FIRST, |   CURLVERSION_FIRST, | ||||||
|   CURLVERSION_SECOND, |   CURLVERSION_SECOND, | ||||||
|   CURLVERSION_THIRD, |   CURLVERSION_THIRD, | ||||||
|  |   CURLVERSION_FOURTH, | ||||||
|   CURLVERSION_LAST /* never actually use this */ |   CURLVERSION_LAST /* never actually use this */ | ||||||
| } CURLversion; | } CURLversion; | ||||||
|  |  | ||||||
| @@ -1479,7 +1540,7 @@ typedef enum { | |||||||
|    meant to be a built-in version number for what kind of struct the caller |    meant to be a built-in version number for what kind of struct the caller | ||||||
|    expects. If the struct ever changes, we redefine the NOW to another enum |    expects. If the struct ever changes, we redefine the NOW to another enum | ||||||
|    from above. */ |    from above. */ | ||||||
| #define CURLVERSION_NOW CURLVERSION_THIRD | #define CURLVERSION_NOW CURLVERSION_FOURTH | ||||||
|  |  | ||||||
| typedef struct { | typedef struct { | ||||||
|   CURLversion age;          /* age of the returned struct */ |   CURLversion age;          /* age of the returned struct */ | ||||||
| @@ -1500,8 +1561,13 @@ typedef struct { | |||||||
|   /* This field was added in CURLVERSION_THIRD */ |   /* This field was added in CURLVERSION_THIRD */ | ||||||
|   const char *libidn; |   const char *libidn; | ||||||
|  |  | ||||||
|  |   /* These field were added in CURLVERSION_FOURTH */ | ||||||
|  |  | ||||||
|   /* Same as '_libiconv_version' if built with HAVE_ICONV */ |   /* Same as '_libiconv_version' if built with HAVE_ICONV */ | ||||||
|   int iconv_ver_num; |   int iconv_ver_num; | ||||||
|  |  | ||||||
|  |   const char *libssh_version; /* human readable string */ | ||||||
|  |  | ||||||
| } curl_version_info_data; | } curl_version_info_data; | ||||||
|  |  | ||||||
| #define CURL_VERSION_IPV6      (1<<0)  /* IPv6-enabled */ | #define CURL_VERSION_IPV6      (1<<0)  /* IPv6-enabled */ | ||||||
|   | |||||||
| @@ -28,13 +28,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.15.5-CVS" | #define LIBCURL_VERSION "7.16.1-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 15 | #define LIBCURL_VERSION_MINOR 16 | ||||||
| #define LIBCURL_VERSION_PATCH 5 | #define LIBCURL_VERSION_PATCH 1 | ||||||
|  |  | ||||||
| /* 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 | ||||||
| @@ -51,6 +51,6 @@ | |||||||
|    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 0x070f05 | #define LIBCURL_VERSION_NUM 0x071001 | ||||||
|  |  | ||||||
| #endif /* __CURL_CURLVER_H */ | #endif /* __CURL_CURLVER_H */ | ||||||
|   | |||||||
| @@ -28,6 +28,10 @@ | |||||||
|  |  | ||||||
| #include "curl.h" | #include "curl.h" | ||||||
|  |  | ||||||
|  | #ifdef  __cplusplus | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
| CURL_EXTERN int curl_mprintf(const char *format, ...); | CURL_EXTERN int curl_mprintf(const char *format, ...); | ||||||
| CURL_EXTERN int curl_mfprintf(FILE *fd, const char *format, ...); | CURL_EXTERN int curl_mfprintf(FILE *fd, const char *format, ...); | ||||||
| CURL_EXTERN int curl_msprintf(char *buffer, const char *format, ...); | CURL_EXTERN int curl_msprintf(char *buffer, const char *format, ...); | ||||||
| @@ -59,4 +63,8 @@ CURL_EXTERN char *curl_mvaprintf(const char *format, va_list args); | |||||||
| # define vaprintf curl_mvaprintf | # define vaprintf curl_mvaprintf | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef  __cplusplus | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif /* __CURL_MPRINTF_H */ | #endif /* __CURL_MPRINTF_H */ | ||||||
|   | |||||||
| @@ -37,34 +37,6 @@ | |||||||
|     file descriptors simultaneous easily. |     file descriptors simultaneous easily. | ||||||
|  |  | ||||||
| */ | */ | ||||||
| #if defined(_WIN32) && !defined(WIN32) |  | ||||||
| /* Chris Lewis mentioned that he doesn't get WIN32 defined, only _WIN32 so we |  | ||||||
|    make this adjustment to catch this. */ |  | ||||||
| #define WIN32 1 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) && \ |  | ||||||
|   !defined(__CYGWIN__) || defined(__MINGW32__) |  | ||||||
| #if !(defined(_WINSOCKAPI_) || defined(_WINSOCK_H)) |  | ||||||
| /* The check above prevents the winsock2 inclusion if winsock.h already was |  | ||||||
|    included, since they can't co-exist without problems */ |  | ||||||
| #include <winsock2.h> |  | ||||||
| #endif |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish |  | ||||||
|    libc5-based Linux systems. Only include it on system that are known to |  | ||||||
|    require it! */ |  | ||||||
| #if defined(_AIX) || defined(NETWARE) || defined(__NetBSD__) || defined(_MINIX) |  | ||||||
| #include <sys/select.h> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifndef _WIN32_WCE |  | ||||||
| #include <sys/socket.h> |  | ||||||
| #endif |  | ||||||
| #include <sys/time.h> |  | ||||||
| #include <sys/types.h> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * This header file should not really need to include "curl.h" since curl.h |  * This header file should not really need to include "curl.h" since curl.h | ||||||
| @@ -83,18 +55,6 @@ extern "C" { | |||||||
|  |  | ||||||
| typedef void CURLM; | typedef void CURLM; | ||||||
|  |  | ||||||
| #ifndef curl_socket_typedef |  | ||||||
| /* Public socket typedef */ |  | ||||||
| #ifdef WIN32 |  | ||||||
| typedef SOCKET curl_socket_t; |  | ||||||
| #define CURL_SOCKET_BAD INVALID_SOCKET |  | ||||||
| #else |  | ||||||
| typedef int curl_socket_t; |  | ||||||
| #define CURL_SOCKET_BAD -1 |  | ||||||
| #endif |  | ||||||
| #define curl_socket_typedef |  | ||||||
| #endif /* curl_socket_typedef */ |  | ||||||
|  |  | ||||||
| typedef enum { | typedef enum { | ||||||
|   CURLM_CALL_MULTI_PERFORM = -1, /* please call curl_multi_perform() or |   CURLM_CALL_MULTI_PERFORM = -1, /* please call curl_multi_perform() or | ||||||
|                                     curl_multi_socket*() soon */ |                                     curl_multi_socket*() soon */ | ||||||
| @@ -271,6 +231,20 @@ typedef int (*curl_socket_callback)(CURL *easy,      /* easy handle */ | |||||||
|                                                         pointer */ |                                                         pointer */ | ||||||
|                                     void *socketp);  /* private socket |                                     void *socketp);  /* private socket | ||||||
|                                                         pointer */ |                                                         pointer */ | ||||||
|  | /* | ||||||
|  |  * Name:    curl_multi_timer_callback | ||||||
|  |  * | ||||||
|  |  * Desc:    Called by libcurl whenever the library detects a change in the | ||||||
|  |  *          maximum number of milliseconds the app is allowed to wait before | ||||||
|  |  *          curl_multi_socket() or curl_multi_perform() must be called | ||||||
|  |  *          (to allow libcurl's timed events to take place). | ||||||
|  |  * | ||||||
|  |  * Returns: The callback should return zero. | ||||||
|  |  */ | ||||||
|  | typedef int (*curl_multi_timer_callback)(CURLM *multi,    /* multi handle */ | ||||||
|  |                                          long timeout_ms, /* see above */ | ||||||
|  |                                          void *userp);    /* private callback | ||||||
|  |                                                              pointer */ | ||||||
|  |  | ||||||
| CURL_EXTERN CURLMcode curl_multi_socket(CURLM *multi_handle, curl_socket_t s, | CURL_EXTERN CURLMcode curl_multi_socket(CURLM *multi_handle, curl_socket_t s, | ||||||
|                                         int *running_handles); |                                         int *running_handles); | ||||||
| @@ -310,6 +284,15 @@ typedef enum { | |||||||
|   /* This is the argument passed to the socket callback */ |   /* This is the argument passed to the socket callback */ | ||||||
|   CINIT(SOCKETDATA, OBJECTPOINT, 2), |   CINIT(SOCKETDATA, OBJECTPOINT, 2), | ||||||
|  |  | ||||||
|  |     /* set to 1 to enable pipelining for this multi handle */ | ||||||
|  |   CINIT(PIPELINING, LONG, 3), | ||||||
|  |  | ||||||
|  |    /* This is the timer callback function pointer */ | ||||||
|  |   CINIT(TIMERFUNCTION, FUNCTIONPOINT, 4), | ||||||
|  |  | ||||||
|  |   /* This is the argument passed to the timer callback */ | ||||||
|  |   CINIT(TIMERDATA, OBJECTPOINT, 5), | ||||||
|  |  | ||||||
|   CURLMOPT_LASTENTRY /* the last unused */ |   CURLMOPT_LASTENTRY /* the last unused */ | ||||||
| } CURLMoption; | } CURLMoption; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -46,7 +46,7 @@ OBJS = $(OBJ_DIR)\transfer.obj         $(OBJ_DIR)\file.obj       & | |||||||
|        $(OBJ_DIR)\hostsyn.obj          $(OBJ_DIR)\parsedate.obj  & |        $(OBJ_DIR)\hostsyn.obj          $(OBJ_DIR)\parsedate.obj  & | ||||||
|        $(OBJ_DIR)\select.obj           $(OBJ_DIR)\sslgen.obj     & |        $(OBJ_DIR)\select.obj           $(OBJ_DIR)\sslgen.obj     & | ||||||
|        $(OBJ_DIR)\gtls.obj             $(OBJ_DIR)\tftp.obj       & |        $(OBJ_DIR)\gtls.obj             $(OBJ_DIR)\tftp.obj       & | ||||||
|        $(OBJ_DIR)\splay.obj |        $(OBJ_DIR)\splay.obj	       $(OBJ_DIR)\socks.obj | ||||||
|  |  | ||||||
| RESOURCE = $(OBJ_DIR)\libcurl.res | RESOURCE = $(OBJ_DIR)\libcurl.res | ||||||
|  |  | ||||||
| @@ -93,282 +93,257 @@ $(LINK_ARG): $(__MAKEFILES__) | |||||||
| # | # | ||||||
| # Dependencies based on "gcc -MM .." | # Dependencies based on "gcc -MM .." | ||||||
| # | # | ||||||
| $(OBJ_DIR)\file.obj: file.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\file.obj: file.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h progress.h sendf.h escape.h file.h & |   http_chunks.h hostip.h hash.h llist.h splay.h progress.h sendf.h & | ||||||
|   speedcheck.h getinfo.h transfer.h url.h memory.h ..\include\curl\mprintf.h & |   escape.h file.h speedcheck.h getinfo.h transfer.h url.h memory.h & | ||||||
|   memdebug.h |   parsedate.h ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\timeval.obj: timeval.c timeval.h setup.h config-win32.h setup_once.h | ||||||
| $(OBJ_DIR)\timeval.obj: timeval.c timeval.h setup.h config-win32.h | $(OBJ_DIR)\base64.obj: base64.c setup.h config-win32.h setup_once.h & | ||||||
|  |   ..\include\curl\mprintf.h ..\include\curl\curl.h & | ||||||
| $(OBJ_DIR)\base64.obj: base64.c setup.h config-win32.h ..\include\curl\mprintf.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |  | ||||||
|   ..\include\curl\multi.h base64.h memory.h ..\include\curl\curl.h & |   ..\include\curl\multi.h base64.h memory.h ..\include\curl\curl.h & | ||||||
|   memdebug.h |   memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\hostip.obj: hostip.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
| $(OBJ_DIR)\hostip.obj: hostip.c setup.h config-win32.h urldata.h cookie.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   inet_ntop.h ..\include\curl\mprintf.h memory.h memdebug.h |   strerror.h url.h inet_ntop.h ..\include\curl\mprintf.h memory.h & | ||||||
|  |   memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\progress.obj: progress.c setup.h config-win32.h ..\include\curl\curl.h & | $(OBJ_DIR)\progress.obj: progress.c setup.h config-win32.h setup_once.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h http_chunks.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|   hostip.h hash.h llist.h sendf.h progress.h ..\include\curl\mprintf.h |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|  |   sendf.h progress.h ..\include\curl\mprintf.h | ||||||
| $(OBJ_DIR)\formdata.obj: formdata.c setup.h config-win32.h ..\include\curl\curl.h & | $(OBJ_DIR)\formdata.obj: formdata.c setup.h config-win32.h setup_once.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h strequal.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h strequal.h & | ||||||
|   memory.h ..\include\curl\mprintf.h memdebug.h |   memory.h ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\cookie.obj: cookie.c setup.h config-win32.h setup_once.h & | ||||||
| $(OBJ_DIR)\cookie.obj: cookie.c setup.h config-win32.h urldata.h cookie.h & |   ..\include\curl\mprintf.h ..\include\curl\curl.h & | ||||||
|  |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|  |   ..\include\curl\multi.h urldata.h cookie.h ..\include\curl\curl.h & | ||||||
|  |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|  |   strequal.h strtok.h sendf.h memory.h share.h strtoofft.h memdebug.h & | ||||||
|  |   .\memory.h | ||||||
|  | $(OBJ_DIR)\http.obj: http.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h strequal.h strtok.h sendf.h & |   http_chunks.h hostip.h hash.h llist.h splay.h transfer.h sendf.h & | ||||||
|   memory.h memdebug.h |   progress.h base64.h strequal.h sslgen.h http_digest.h http_ntlm.h & | ||||||
|  |   http_negotiate.h url.h share.h http.h memory.h select.h parsedate.h & | ||||||
| $(OBJ_DIR)\http.obj: http.c setup.h config-win32.h urldata.h cookie.h & |   strtoofft.h multiif.h ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | $(OBJ_DIR)\sendf.obj: sendf.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |  | ||||||
|   http_chunks.h hostip.h hash.h llist.h transfer.h sendf.h progress.h & |  | ||||||
|   base64.h strequal.h ssluse.h http_digest.h http_ntlm.h http_negotiate.h & |  | ||||||
|   url.h share.h http.h memory.h select.h ..\include\curl\mprintf.h memdebug.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\sendf.obj: sendf.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & |  | ||||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h & |  | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h connect.h & |  | ||||||
|   ..\include\curl\mprintf.h memory.h strerror.h memdebug.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\ftp.obj: ftp.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   if2ip.h progress.h transfer.h escape.h http.h ftp.h strtoofft.h & |   sendf.h connect.h sslgen.h ..\include\curl\mprintf.h memory.h & | ||||||
|   strequal.h ssluse.h connect.h strerror.h memory.h inet_ntop.h select.h & |   strerror.h easyif.h memdebug.h .\memory.h | ||||||
|   ..\include\curl\mprintf.h memdebug.h | $(OBJ_DIR)\ftp.obj: ftp.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
|  |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
| $(OBJ_DIR)\url.obj: url.c setup.h config-win32.h urldata.h cookie.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|  |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|  |   sendf.h easyif.h if2ip.h progress.h transfer.h escape.h http.h ftp.h & | ||||||
|  |   strtoofft.h strequal.h sslgen.h connect.h strerror.h memory.h & | ||||||
|  |   inet_ntop.h select.h parsedate.h sockaddr.h multiif.h & | ||||||
|  |   ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\url.obj: url.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h netrc.h base64.h ssluse.h if2ip.h & |   http_chunks.h hostip.h hash.h llist.h splay.h netrc.h base64.h sslgen.h & | ||||||
|   transfer.h sendf.h progress.h strequal.h strerror.h escape.h strtok.h & |   transfer.h sendf.h progress.h strequal.h strerror.h escape.h strtok.h & | ||||||
|   share.h content_encoding.h http_digest.h http_negotiate.h select.h multiif.h & |   share.h content_encoding.h http_digest.h http_negotiate.h select.h & | ||||||
|   ftp.h dict.h telnet.h http.h file.h ldap.h url.h connect.h inet_ntop.h & |   multiif.h ftp.h dict.h telnet.h tftp.h http.h file.h ldap.h url.h & | ||||||
|   ./ca-bundle.h ..\include\curl\mprintf.h memory.h memdebug.h |   connect.h inet_ntop.h http_ntlm.h .\ca-bundle.h & | ||||||
|  |   ..\include\curl\mprintf.h memory.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\dict.obj: dict.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\dict.obj: dict.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h transfer.h sendf.h progress.h & |   http_chunks.h hostip.h hash.h llist.h splay.h transfer.h sendf.h & | ||||||
|   strequal.h dict.h ..\include\curl\mprintf.h |   progress.h strequal.h dict.h ..\include\curl\mprintf.h memdebug.h & | ||||||
|  |   .\memory.h | ||||||
| $(OBJ_DIR)\if2ip.obj: if2ip.c setup.h config-win32.h | $(OBJ_DIR)\if2ip.obj: if2ip.c setup.h config-win32.h setup_once.h if2ip.h inet_ntop.h & | ||||||
|  |   memory.h ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||||
| $(OBJ_DIR)\speedcheck.obj: speedcheck.c setup.h config-win32.h & |   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & | ||||||
|  |   memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\speedcheck.obj: speedcheck.c setup.h config-win32.h setup_once.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   speedcheck.h |   sendf.h multiif.h speedcheck.h | ||||||
|  | $(OBJ_DIR)\ldap.obj: ldap.c setup.h config-win32.h setup_once.h | ||||||
| $(OBJ_DIR)\ldap.obj: ldap.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\ssluse.obj: ssluse.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h escape.h transfer.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h url.h inet_pton.h & | ||||||
|   strequal.h strtok.h ldap.h memory.h ..\include\curl\mprintf.h memdebug.h |   ssluse.h connect.h strequal.h select.h sslgen.h & | ||||||
|  |   ..\include\curl\mprintf.h | ||||||
| $(OBJ_DIR)\ssluse.obj: ssluse.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\version.obj: version.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |  | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |  | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h url.h inet_pton.h & |  | ||||||
|   ssluse.h connect.h strequal.h select.h ..\include\curl\mprintf.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\version.obj: version.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & |  | ||||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h & |  | ||||||
|   http_chunks.h hostip.h hash.h llist.h ..\include\curl\mprintf.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\getenv.obj: getenv.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memory.h memdebug.h |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|  |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
| $(OBJ_DIR)\escape.obj: escape.c setup.h config-win32.h ..\include\curl\curl.h & |   sslgen.h ..\include\curl\mprintf.h | ||||||
|  | $(OBJ_DIR)\getenv.obj: getenv.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memory.h & |   ..\include\curl\multi.h ..\include\curl\curl.h memory.h memdebug.h & | ||||||
|   ..\include\curl\mprintf.h memdebug.h |   .\memory.h | ||||||
|  | $(OBJ_DIR)\escape.obj: escape.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
| $(OBJ_DIR)\mprintf.obj: mprintf.c setup.h config-win32.h ..\include\curl\mprintf.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\multi.h ..\include\curl\curl.h memory.h urldata.h & | ||||||
|   ..\include\curl\multi.h memory.h ..\include\curl\curl.h memdebug.h |   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||||
|  |   splay.h easyif.h ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\telnet.obj: telnet.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\mprintf.obj: mprintf.c setup.h config-win32.h setup_once.h & | ||||||
|  |   ..\include\curl\mprintf.h ..\include\curl\curl.h & | ||||||
|  |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|  |   ..\include\curl\multi.h memory.h ..\include\curl\curl.h memdebug.h & | ||||||
|  |   .\memory.h | ||||||
|  | $(OBJ_DIR)\telnet.obj: telnet.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h transfer.h sendf.h telnet.h & |   http_chunks.h hostip.h hash.h llist.h splay.h transfer.h sendf.h & | ||||||
|   ..\include\curl\mprintf.h arpa_telnet.h memory.h select.h memdebug.h |   telnet.h connect.h ..\include\curl\mprintf.h arpa_telnet.h memory.h & | ||||||
|  |   select.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\netrc.obj: netrc.c setup.h config-win32.h ..\include\curl\curl.h & | $(OBJ_DIR)\netrc.obj: netrc.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h netrc.h strequal.h & |   ..\include\curl\multi.h ..\include\curl\curl.h netrc.h strequal.h & | ||||||
|   strtok.h memory.h ..\include\curl\mprintf.h memdebug.h |   strtok.h memory.h ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\getinfo.obj: getinfo.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
| $(OBJ_DIR)\getinfo.obj: getinfo.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   getinfo.h memory.h ssluse.h memdebug.h |   getinfo.h memory.h sslgen.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\transfer.obj: transfer.c setup.h config-win32.h setup_once.h strtoofft.h & | ||||||
| $(OBJ_DIR)\transfer.obj: transfer.c setup.h config-win32.h strtoofft.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h strequal.h urldata.h & |   ..\include\curl\multi.h ..\include\curl\curl.h strequal.h urldata.h & | ||||||
|   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & |   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||||
|   netrc.h content_encoding.h transfer.h sendf.h speedcheck.h progress.h & |   splay.h netrc.h content_encoding.h transfer.h sendf.h speedcheck.h & | ||||||
|   http.h url.h getinfo.h ssluse.h http_digest.h http_ntlm.h & |   progress.h http.h url.h getinfo.h sslgen.h http_digest.h http_ntlm.h & | ||||||
|   http_negotiate.h share.h memory.h select.h ..\include\curl\mprintf.h & |   http_negotiate.h share.h memory.h select.h multiif.h easyif.h & | ||||||
|   memdebug.h |   ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\strequal.obj: strequal.c setup.h config-win32.h setup_once.h strequal.h & | ||||||
| $(OBJ_DIR)\strequal.obj: strequal.c setup.h config-win32.h strequal.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h |   ..\include\curl\multi.h ..\include\curl\curl.h | ||||||
|  | $(OBJ_DIR)\easy.obj: easy.c setup.h config-win32.h setup_once.h strequal.h & | ||||||
| $(OBJ_DIR)\easy.obj: easy.c setup.h config-win32.h strequal.h ..\include\curl\curl.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |  | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   transfer.h ssluse.h url.h getinfo.h share.h memory.h progress.h & |   transfer.h sslgen.h url.h getinfo.h share.h strdup.h memory.h & | ||||||
|   easyif.h ..\include\curl\mprintf.h memdebug.h |   progress.h easyif.h sendf.h ..\include\curl\mprintf.h memdebug.h & | ||||||
|  |   .\memory.h | ||||||
| $(OBJ_DIR)\security.obj: security.c setup.h config-win32.h | $(OBJ_DIR)\security.obj: security.c setup.h config-win32.h setup_once.h | ||||||
|  | $(OBJ_DIR)\krb4.obj: krb4.c setup.h config-win32.h setup_once.h | ||||||
| $(OBJ_DIR)\krb4.obj: krb4.c setup.h config-win32.h | $(OBJ_DIR)\memdebug.obj: memdebug.c setup.h config-win32.h setup_once.h & | ||||||
|  |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
| $(OBJ_DIR)\memdebug.obj: memdebug.c setup.h config-win32.h ..\include\curl\curl.h & |   ..\include\curl\multi.h ..\include\curl\curl.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & |   ..\include\curl\mprintf.h urldata.h cookie.h formdata.h timeval.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\mprintf.h urldata.h cookie.h & |   http_chunks.h hostip.h hash.h llist.h splay.h memory.h memdebug.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h memory.h memdebug.h |   .\memory.h | ||||||
|  | $(OBJ_DIR)\http_chunks.obj: http_chunks.c setup.h config-win32.h setup_once.h urldata.h & | ||||||
| $(OBJ_DIR)\http_chunks.obj: http_chunks.c setup.h config-win32.h urldata.h & |  | ||||||
|   cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h & |   cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||||
|   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & |   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   content_encoding.h http.h memory.h ..\include\curl\mprintf.h memdebug.h |   sendf.h content_encoding.h http.h memory.h ..\include\curl\mprintf.h & | ||||||
|  |   memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\strtok.obj: strtok.c setup.h config-win32.h strtok.h | $(OBJ_DIR)\strtok.obj: strtok.c setup.h config-win32.h setup_once.h strtok.h | ||||||
|  | $(OBJ_DIR)\connect.obj: connect.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
| $(OBJ_DIR)\connect.obj: connect.c setup.h config-win32.h urldata.h cookie.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h if2ip.h strerror.h connect.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h if2ip.h & | ||||||
|   memory.h select.h memdebug.h |   strerror.h connect.h memory.h select.h url.h multiif.h sockaddr.h & | ||||||
|  |   inet_ntop.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\llist.obj: llist.c setup.h config-win32.h llist.h memory.h & | $(OBJ_DIR)\llist.obj: llist.c setup.h config-win32.h setup_once.h llist.h memory.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memdebug.h |   ..\include\curl\multi.h ..\include\curl\curl.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\hash.obj: hash.c setup.h config-win32.h setup_once.h hash.h llist.h memory.h & | ||||||
| $(OBJ_DIR)\hash.obj: hash.c setup.h config-win32.h hash.h llist.h memory.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memdebug.h |   ..\include\curl\multi.h ..\include\curl\curl.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\multi.obj: multi.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
| $(OBJ_DIR)\multi.obj: multi.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   transfer.h url.h connect.h progress.h memory.h easyif.h multiif.h & |   transfer.h url.h connect.h progress.h memory.h easyif.h multiif.h & | ||||||
|   memdebug.h |   sendf.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\content_encoding.obj: content_encoding.c setup.h config-win32.h setup_once.h | ||||||
| $(OBJ_DIR)\content_encoding.obj: content_encoding.c setup.h config-win32.h urldata.h & | $(OBJ_DIR)\share.obj: share.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
|  |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|  |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
|  |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|  |   share.h memory.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\http_digest.obj: http_digest.c setup.h config-win32.h setup_once.h urldata.h & | ||||||
|   cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h & |   cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||||
|   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & |   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|   content_encoding.h memory.h memdebug.h |   sendf.h strequal.h base64.h md5.h http_digest.h strtok.h url.h memory.h & | ||||||
|  |   ..\include\curl\mprintf.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\share.obj: share.c setup.h config-win32.h ..\include\curl\curl.h & | $(OBJ_DIR)\md5.obj: md5.c setup.h config-win32.h setup_once.h md5.h | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & | $(OBJ_DIR)\http_negotiate.obj: http_negotiate.c setup.h config-win32.h setup_once.h | ||||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h & | $(OBJ_DIR)\http_ntlm.obj: http_ntlm.c setup.h config-win32.h setup_once.h | ||||||
|   http_chunks.h hostip.h hash.h llist.h share.h memory.h memdebug.h | $(OBJ_DIR)\inet_pton.obj: inet_pton.c setup.h config-win32.h setup_once.h | ||||||
|  | $(OBJ_DIR)\strtoofft.obj: strtoofft.c setup.h config-win32.h setup_once.h strtoofft.h & | ||||||
| $(OBJ_DIR)\http_digest.obj: http_digest.c setup.h config-win32.h urldata.h cookie.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |  | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |  | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h strequal.h base64.h md5.h & |  | ||||||
|   http_digest.h strtok.h url.h memory.h ..\include\curl\mprintf.h memdebug.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\md5.obj: md5.c setup.h config-win32.h md5.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\http_negotiate.obj: http_negotiate.c setup.h config-win32.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\http_ntlm.obj: http_ntlm.c setup.h config-win32.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\inet_pton.obj: inet_pton.c setup.h config-win32.h inet_pton.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\strtoofft.obj: strtoofft.c setup.h config-win32.h strtoofft.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h |   ..\include\curl\multi.h ..\include\curl\curl.h | ||||||
|  | $(OBJ_DIR)\strerror.obj: strerror.c setup.h config-win32.h setup_once.h & | ||||||
| $(OBJ_DIR)\strerror.obj: strerror.c setup.h config-win32.h ..\include\curl\curl.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |  | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h strerror.h urldata.h & |   ..\include\curl\multi.h ..\include\curl\curl.h strerror.h urldata.h & | ||||||
|   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & |   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||||
|   ..\include\curl\mprintf.h |   splay.h ..\include\curl\mprintf.h | ||||||
|  | $(OBJ_DIR)\hostares.obj: hostares.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
| $(OBJ_DIR)\hostares.obj: hostares.c setup.h config-win32.h urldata.h cookie.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   ..\include\curl\mprintf.h memory.h memdebug.h |   strerror.h url.h connect.h ..\include\curl\mprintf.h memory.h & | ||||||
|  |   memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\hostasyn.obj: hostasyn.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\hostasyn.obj: hostasyn.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   ..\include\curl\mprintf.h memory.h memdebug.h |   strerror.h url.h ..\include\curl\mprintf.h memory.h memdebug.h & | ||||||
|  |   .\memory.h | ||||||
| $(OBJ_DIR)\hostip4.obj: hostip4.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\hostip4.obj: hostip4.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   ..\include\curl\mprintf.h memory.h memdebug.h |   strerror.h url.h inet_pton.h ..\include\curl\mprintf.h memory.h & | ||||||
|  |   memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\hostip6.obj: hostip6.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\hostip6.obj: hostip6.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   ..\include\curl\mprintf.h memory.h memdebug.h |   strerror.h url.h inet_pton.h connect.h ..\include\curl\mprintf.h & | ||||||
|  |   memory.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\hostsyn.obj: hostsyn.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\hostsyn.obj: hostsyn.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   ..\include\curl\mprintf.h memory.h memdebug.h |   strerror.h url.h ..\include\curl\mprintf.h memory.h memdebug.h & | ||||||
|  |   .\memory.h | ||||||
| $(OBJ_DIR)\hostthre.obj: hostthre.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\hostthre.obj: hostthre.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sendf.h share.h & | ||||||
|   ..\include\curl\mprintf.h inet_ntop.h memory.h memdebug.h |   strerror.h url.h multiif.h ..\include\curl\mprintf.h inet_ntop.h & | ||||||
|  |   memory.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\inet_ntop.obj: inet_ntop.c setup.h config-win32.h ..\include\curl\mprintf.h & | $(OBJ_DIR)\inet_ntop.obj: inet_ntop.c setup.h config-win32.h setup_once.h | ||||||
|  | $(OBJ_DIR)\parsedate.obj: parsedate.c setup.h config-win32.h setup_once.h & | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h inet_ntop.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\parsedate.obj: parsedate.c setup.h config-win32.h ..\include\curl\curl.h & |  | ||||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & |  | ||||||
|   ..\include\curl\multi.h ..\include\curl\curl.h |   ..\include\curl\multi.h ..\include\curl\curl.h | ||||||
|  | $(OBJ_DIR)\select.obj: select.c setup.h config-win32.h setup_once.h ..\include\curl\curl.h & | ||||||
| $(OBJ_DIR)\select.obj: select.c setup.h config-win32.h select.h |   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|  |   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||||
| $(OBJ_DIR)\gtls.obj: gtls.c setup.h config-win32.h |   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h splay.h & | ||||||
|  |   connect.h select.h | ||||||
| $(OBJ_DIR)\sslgen.obj: sslgen.c setup.h config-win32.h urldata.h cookie.h & | $(OBJ_DIR)\gtls.obj: gtls.c setup.h config-win32.h setup_once.h | ||||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sslgen.h & | $(OBJ_DIR)\sslgen.obj: sslgen.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|   ssluse.h gtls.h sendf.h strequal.h url.h memory.h memdebug.h |  | ||||||
|  |  | ||||||
| $(OBJ_DIR)\tftp.obj: tftp.c setup.h config-win32.h urldata.h cookie.h & |  | ||||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|   ..\include\curl\multi.h formdata.h http_chunks.h hostip.h hash.h llist.h & |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|   transfer.h sendf.h tftp.h progress.h ..\include\curl\mprintf.h memory.h & |   http_chunks.h hostip.h hash.h llist.h splay.h sslgen.h ssluse.h gtls.h & | ||||||
|   select.h memdebug.h |   sendf.h strequal.h url.h memory.h memdebug.h .\memory.h | ||||||
|  | $(OBJ_DIR)\tftp.obj: tftp.c setup.h config-win32.h setup_once.h urldata.h cookie.h & | ||||||
|  |   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||||
|  |   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||||
|  |   http_chunks.h hostip.h hash.h llist.h splay.h transfer.h sendf.h tftp.h & | ||||||
|  |   progress.h connect.h strerror.h sockaddr.h ..\include\curl\mprintf.h & | ||||||
|  |   memory.h select.h memdebug.h .\memory.h | ||||||
| $(OBJ_DIR)\splay.obj: splay.c splay.h | $(OBJ_DIR)\splay.obj: splay.c splay.h | ||||||
|  | $(OBJ_DIR)\strdup.obj: strdup.c setup.h config-win32.h setup_once.h strdup.h | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ DOCS = README.encoding README.memoryleak README.ares README.curlx	\ | |||||||
|  |  | ||||||
| EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos	\ | EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos	\ | ||||||
|  $(DSP) curllib.dsw config-win32.h config-win32ce.h config-riscos.h	\ |  $(DSP) curllib.dsw config-win32.h config-win32ce.h config-riscos.h	\ | ||||||
|  config-mac.h config.h.in ca-bundle.crt makefile.dj config.dj		\ |  config-mac.h config.h.in ca-bundle.crt makefile.dj config.dos		\ | ||||||
|  libcurl.framework.make libcurl.plist libcurl.rc config-amigaos.h	\ |  libcurl.framework.make libcurl.plist libcurl.rc config-amigaos.h	\ | ||||||
|  amigaos.c amigaos.h makefile.amiga Makefile.netware nwlib.c		\ |  amigaos.c amigaos.h makefile.amiga Makefile.netware nwlib.c		\ | ||||||
|  libcurl.imp msvcproj.head msvcproj.foot config-win32ce.h		\ |  libcurl.imp msvcproj.head msvcproj.foot config-win32ce.h		\ | ||||||
| @@ -43,9 +43,12 @@ lib_LTLIBRARIES = libcurl.la | |||||||
| # we use srcdir/include for the static global include files | # we use srcdir/include for the static global include files | ||||||
| # we use builddir/lib for the generated lib/config.h file to get found | # we use builddir/lib for the generated lib/config.h file to get found | ||||||
| # we use srcdir/lib for the lib-private header files | # we use srcdir/lib for the lib-private header files | ||||||
| INCLUDES = -I$(top_srcdir)/include -I$(top_builddir)/lib -I$(top_srcdir)/lib |  | ||||||
|  |  | ||||||
| VERSION=-version-info 3:0:0 | INCLUDES = -I$(top_srcdir)/include \ | ||||||
|  |            -I$(top_builddir)/lib   \ | ||||||
|  |            -I$(top_srcdir)/lib | ||||||
|  |  | ||||||
|  | VERSION=-version-info 4:0:0 | ||||||
|  |  | ||||||
| # This flag accepts an argument of the form current[:revision[:age]]. So, | # This flag accepts an argument of the form current[:revision[:age]]. So, | ||||||
| # passing -version-info 3:12:1 sets current to 3, revision to 12, and age to | # passing -version-info 3:12:1 sets current to 3, revision to 12, and age to | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c	\ | |||||||
|   content_encoding.c share.c http_digest.c md5.c http_negotiate.c	\ |   content_encoding.c share.c http_digest.c md5.c http_negotiate.c	\ | ||||||
|   http_ntlm.c inet_pton.c strtoofft.c strerror.c hostares.c hostasyn.c	\ |   http_ntlm.c inet_pton.c strtoofft.c strerror.c hostares.c hostasyn.c	\ | ||||||
|   hostip4.c hostip6.c hostsyn.c hostthre.c inet_ntop.c parsedate.c	\ |   hostip4.c hostip6.c hostsyn.c hostthre.c inet_ntop.c parsedate.c	\ | ||||||
|   select.c gtls.c sslgen.c tftp.c splay.c strdup.c |   select.c gtls.c sslgen.c tftp.c splay.c strdup.c socks.c ssh.c | ||||||
|  |  | ||||||
| HHEADERS = arpa_telnet.h netrc.h file.h timeval.h base64.h hostip.h	\ | HHEADERS = arpa_telnet.h netrc.h file.h timeval.h base64.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	\ | ||||||
| @@ -18,6 +18,6 @@ HHEADERS = arpa_telnet.h netrc.h file.h timeval.h base64.h hostip.h	\ | |||||||
|   share.h md5.h http_digest.h http_negotiate.h http_ntlm.h ca-bundle.h	\ |   share.h md5.h http_digest.h http_negotiate.h http_ntlm.h ca-bundle.h	\ | ||||||
|   inet_pton.h strtoofft.h strerror.h inet_ntop.h curlx.h memory.h	\ |   inet_pton.h strtoofft.h strerror.h inet_ntop.h curlx.h memory.h	\ | ||||||
|   setup.h transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h   \ |   setup.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 |   gtls.h tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,18 +2,21 @@ | |||||||
| # $Id$ | # $Id$ | ||||||
| # | # | ||||||
| ## Makefile for building libcurl.a with MingW32 (GCC-3.2) and | ## Makefile for building libcurl.a with MingW32 (GCC-3.2) and | ||||||
| ## optionally OpenSSL (0.9.7) | ## optionally OpenSSL (0.9.8) | ||||||
| ## | ## | ||||||
| ## Use: make -f Makefile.m32 | ## Use: make -f Makefile.m32 [SSL=1] [SSH2=1] [DYN=1] | ||||||
| ## | ## | ||||||
| ## Comments to: Troy Engel <tengel@sonic.net> or | ## Comments to: Troy Engel <tengel@sonic.net> or | ||||||
| ##              Joern Hartroth <hartroth@acm.org> | ##              Joern Hartroth <hartroth@acm.org> | ||||||
|  |  | ||||||
| ifndef OPENSSL_PATH | ifndef OPENSSL_PATH | ||||||
| OPENSSL_PATH = ../../openssl-0.9.7d | OPENSSL_PATH = ../../openssl-0.9.8d | ||||||
|  | endif | ||||||
|  | ifndef LIBSSH2_PATH | ||||||
|  | LIBSSH2_PATH = ../../libssh2-0.14 | ||||||
| endif | endif | ||||||
| ifndef ZLIB_PATH | ifndef ZLIB_PATH | ||||||
| ZLIB_PATH = ../../zlib-1.2.1 | ZLIB_PATH = ../../zlib-1.2.3 | ||||||
| endif | endif | ||||||
|  |  | ||||||
| CC = gcc | CC = gcc | ||||||
| @@ -26,19 +29,27 @@ STRIP = strip -g | |||||||
| ## Nothing more to do below this line! | ## Nothing more to do below this line! | ||||||
|  |  | ||||||
| INCLUDES = -I. -I../include | INCLUDES = -I. -I../include | ||||||
| CFLAGS = -g -O2 -DMINGW32 -DBUILDING_LIBCURL -DHAVE_LONGLONG | CFLAGS = -g -O2 -DBUILDING_LIBCURL -DHAVE_LONGLONG | ||||||
|  | ifdef SSH2 | ||||||
|  |   INCLUDES += -I"$(LIBSSH2_PATH)/include" -I"$(LIBSSH2_PATH)/win32" | ||||||
|  |   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H | ||||||
|  |   DLL_LIBS += -L$(LIBSSH2_PATH)/win32 -lssh2 | ||||||
|  | endif | ||||||
| ifdef SSL | ifdef SSL | ||||||
|   INCLUDES += -I"$(OPENSSL_PATH)/outinc" -I"$(OPENSSL_PATH)/outinc/openssl" |   INCLUDES += -I"$(OPENSSL_PATH)/outinc" -I"$(OPENSSL_PATH)/outinc/openssl" | ||||||
|   CFLAGS += -DUSE_SSLEAY -DUSE_OPENSSL -DHAVE_OPENSSL_ENGINE_H -DHAVE_OPENSSL_PKCS12_H \ |   CFLAGS += -DUSE_SSLEAY -DUSE_OPENSSL -DHAVE_OPENSSL_ENGINE_H -DHAVE_OPENSSL_PKCS12_H \ | ||||||
|             -DHAVE_ENGINE_LOAD_BUILTIN_ENGINES -DOPENSSL_NO_KRB5 \ |             -DHAVE_ENGINE_LOAD_BUILTIN_ENGINES -DOPENSSL_NO_KRB5 \ | ||||||
|             -DCURL_CA_BUNDLE='getenv("CURL_CA_BUNDLE")' |             -DCURL_WANTS_CA_BUNDLE_ENV | ||||||
|   DLL_LIBS = -L$(OPENSSL_PATH)/out -leay32 -lssl32 |   DLL_LIBS += -L$(OPENSSL_PATH)/out -leay32 -lssl32 | ||||||
| endif | endif | ||||||
| ifdef ZLIB | ifdef ZLIB | ||||||
|   INCLUDES += -I"$(ZLIB_PATH)" |   INCLUDES += -I"$(ZLIB_PATH)" | ||||||
|   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H |   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H | ||||||
|   DLL_LIBS += -L$(ZLIB_PATH) -lz |   DLL_LIBS += -L$(ZLIB_PATH) -lz | ||||||
| endif | endif | ||||||
|  | ifdef SSPI | ||||||
|  |   CFLAGS += -DUSE_WINDOWS_SSPI | ||||||
|  | endif | ||||||
| COMPILE = $(CC) $(INCLUDES) $(CFLAGS) | COMPILE = $(CC) $(INCLUDES) $(CFLAGS) | ||||||
|  |  | ||||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| ## Makefile for building libcurl.nlm (NetWare version - gnu make) | ## Makefile for building libcurl.nlm (NetWare version - gnu make) | ||||||
| ## Use: make -f Makefile.netware | ## Use: make -f Makefile.netware | ||||||
| ## | ## | ||||||
| ## Comments to: Guenter Knauf <eflash@gmx.net> | ## Comments to: Guenter Knauf http://www.gknw.de/phpbb | ||||||
| # | # | ||||||
| ################################################################# | ################################################################# | ||||||
|  |  | ||||||
| @@ -19,7 +19,12 @@ endif | |||||||
|  |  | ||||||
| # Edit the path below to point to the base of your OpenSSL package. | # Edit the path below to point to the base of your OpenSSL package. | ||||||
| ifndef OPENSSL_PATH | ifndef OPENSSL_PATH | ||||||
| OPENSSL_PATH = ../../openssl-0.9.8a | OPENSSL_PATH = ../../openssl-0.9.8d | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # Edit the path below to point to the base of your LibSSH2 package. | ||||||
|  | ifndef LIBSSH2_PATH | ||||||
|  | LIBSSH2_PATH = ../../libssh2-0.14 | ||||||
| endif | endif | ||||||
|  |  | ||||||
| ifndef INSTDIR | ifndef INSTDIR | ||||||
| @@ -29,7 +34,7 @@ endif | |||||||
| # Edit the vars below to change NLM target settings. | # Edit the vars below to change NLM target settings. | ||||||
| TARGET  = libcurl | TARGET  = libcurl | ||||||
| VERSION	= $(LIBCURL_VERSION) | VERSION	= $(LIBCURL_VERSION) | ||||||
| COPYR	= Copyright (C) 1996 - 2006, Daniel Stenberg, <daniel@haxx.se> | COPYR	= Copyright (C) 1996 - 2007, Daniel Stenberg, <daniel@haxx.se> | ||||||
| DESCR	= cURL libcurl $(LIBCURL_VERSION_STR) - http://curl.haxx.se | DESCR	= cURL libcurl $(LIBCURL_VERSION_STR) - http://curl.haxx.se | ||||||
| MTSAFE	= YES | MTSAFE	= YES | ||||||
| STACK	= 64000 | STACK	= 64000 | ||||||
| @@ -63,12 +68,13 @@ ifdef METROWERKS | |||||||
| else | else | ||||||
| 	CC = gcc | 	CC = gcc | ||||||
| endif | endif | ||||||
|  | AWK	= awk | ||||||
| YACC	= bison -y | YACC	= bison -y | ||||||
| CP	= cp -afv | CP	= cp -afv | ||||||
| # RM	= rm -f | # RM	= rm -f | ||||||
| # if you want to mark the target as MTSAFE you will need a tool for | # if you want to mark the target as MTSAFE you will need a tool for | ||||||
| # generating the xdc data for the linker; here's a minimal tool: | # generating the xdc data for the linker; here's a minimal tool: | ||||||
| # http://www.gknw.com/development/prgtools/mkxdc.zip | # http://www.gknw.net/development/prgtools/mkxdc.zip | ||||||
| MPKXDC	= mkxdc | MPKXDC	= mkxdc | ||||||
|  |  | ||||||
| # Global flags for all compilers | # Global flags for all compilers | ||||||
| @@ -121,6 +127,15 @@ ifdef WITH_SSL | |||||||
| 	LDLIBS += $(OPENSSL_PATH)/out_nw_libc/crypto.lib $(OPENSSL_PATH)/out_nw_libc/ssl.lib | 	LDLIBS += $(OPENSSL_PATH)/out_nw_libc/crypto.lib $(OPENSSL_PATH)/out_nw_libc/ssl.lib | ||||||
| 	IMPORTS += GetProcessSwitchCount RunningProcess | 	IMPORTS += GetProcessSwitchCount RunningProcess | ||||||
| endif | endif | ||||||
|  | ifdef WITH_SSH2 | ||||||
|  | 	INCLUDES += -I$(LIBSSH2_PATH)/include | ||||||
|  | ifdef LINK_STATIC | ||||||
|  | 	LDLIBS += $(LIBSSH2_PATH)/nw/libssh2.lib | ||||||
|  | else | ||||||
|  | 	IMPORTS += @$(LIBSSH2_PATH)/nw/libssh2.imp | ||||||
|  | 	MODULES += libssh2.nlm | ||||||
|  | endif | ||||||
|  | endif | ||||||
| ifdef WITH_ZLIB | ifdef WITH_ZLIB | ||||||
| 	INCLUDES += -I$(ZLIB_PATH) | 	INCLUDES += -I$(ZLIB_PATH) | ||||||
| ifdef LINK_STATIC | ifdef LINK_STATIC | ||||||
| @@ -184,7 +199,7 @@ $(OBJDIR)/%.o: %.c | |||||||
|  |  | ||||||
| $(OBJDIR)/version.inc: ../include/curl/curlver.h $(OBJDIR) | $(OBJDIR)/version.inc: ../include/curl/curlver.h $(OBJDIR) | ||||||
| 	@echo Creating $@ | 	@echo Creating $@ | ||||||
| 	@awk -f ../packages/NetWare/get_ver.awk $< > $@ | 	@$(AWK) -f ../packages/NetWare/get_ver.awk $< > $@ | ||||||
|  |  | ||||||
| dist: all | dist: all | ||||||
| 	-$(RM) $(OBJDIR)/*.o $(OBJDIR)/$(TARGET).map $(OBJDIR)/$(TARGET).ncv | 	-$(RM) $(OBJDIR)/*.o $(OBJDIR)/$(TARGET).map $(OBJDIR)/$(TARGET).ncv | ||||||
| @@ -205,6 +220,9 @@ clean: | |||||||
| 	-$(RM) config.h ca-bundle.h | 	-$(RM) config.h ca-bundle.h | ||||||
| 	-$(RM) -r $(OBJDIR) | 	-$(RM) -r $(OBJDIR) | ||||||
|  |  | ||||||
|  | distclean: clean | ||||||
|  | 	-$(RM) -r $(TARGET).lib $(TARGET).nlm | ||||||
|  |  | ||||||
| $(INSTDIR): | $(INSTDIR): | ||||||
| 	@mkdir $(INSTDIR) | 	@mkdir $(INSTDIR) | ||||||
|  |  | ||||||
| @@ -324,6 +342,8 @@ config.h: Makefile.netware | |||||||
| 	@echo $(DL)#define HAVE_SEND 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SEND 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_SIGNAL_H 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_SIG_ATOMIC_T 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@ | ||||||
| @@ -359,9 +379,10 @@ config.h: Makefile.netware | |||||||
| 	@echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@ | 	@echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_STRUCT_TIMEVAL 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | ||||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | ||||||
| ifdef DISABLE_LDAP | ifdef DISABLE_LDAP | ||||||
| @@ -401,18 +422,59 @@ ifdef WITH_SSL | |||||||
| 	@echo $(DL)#define HAVE_LIBCRYPTO 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_LIBCRYPTO 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define OPENSSL_NO_KRB5 1$(DL) >> $@ | 	@echo $(DL)#define OPENSSL_NO_KRB5 1$(DL) >> $@ | ||||||
| endif | endif | ||||||
|  | ifdef WITH_SSH2 | ||||||
|  | 	@echo $(DL)#define USE_LIBSSH2 1$(DL) >> $@ | ||||||
|  | 	@echo $(DL)#define HAVE_LIBSSH2_H 1$(DL) >> $@ | ||||||
|  | endif | ||||||
| ifdef OLD_NOVELLSDK | ifdef OLD_NOVELLSDK | ||||||
| 	@echo $(DL)#define socklen_t int$(DL) >> $@ | 	@echo $(DL)#define socklen_t int$(DL) >> $@ | ||||||
| endif | endif | ||||||
|  |  | ||||||
| ca-bundle.h: Makefile.netware | FORCE: ; | ||||||
|  |  | ||||||
|  | ca-bundle.h: FORCE Makefile.netware | ||||||
| 	@echo Creating $@ | 	@echo Creating $@ | ||||||
| 	@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) > $@ | ||||||
| 	@echo $(DL)** All your changes will be lost!!$(DL) >> $@ | 	@echo $(DL)** All your changes will be lost!!$(DL) >> $@ | ||||||
| 	@echo $(DL)*/$(DL) >> $@ | 	@echo $(DL)*/$(DL) >> $@ | ||||||
|  | ifdef CABUNDLE | ||||||
|  | 	@echo $(DL)#define CURL_CA_BUNDLE "$(CABUNDLE)"$(DL) >> $@ | ||||||
|  | else | ||||||
| 	@echo $(DL)#define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE")$(DL) >> $@ | 	@echo $(DL)#define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE")$(DL) >> $@ | ||||||
|  | endif | ||||||
|  |  | ||||||
| url.c: ca-bundle.h | info: $(OBJDIR)/version.inc | ||||||
|  | 	@echo Configured to build $(TARGET) with these options: | ||||||
|  | 	@echo curl version:    $(LIBCURL_VERSION_STR) | ||||||
|  | 	@echo compiler/linker: $(CC) / $(LD) | ||||||
|  | ifdef CABUNDLE | ||||||
|  | 	@echo ca-bundle path:  $(CABUNDLE) | ||||||
|  | endif | ||||||
|  | ifdef WITH_SSL | ||||||
|  | 	@echo SSL support:     enabled (OpenSSL) | ||||||
|  | else | ||||||
|  | 	@echo SSL support:     no | ||||||
|  | endif | ||||||
|  | ifdef WITH_SSH2 | ||||||
|  | 	@echo SSH2 support:    enabled (libssh2) | ||||||
|  | else | ||||||
|  | 	@echo SSH2 support:    no | ||||||
|  | endif | ||||||
|  | ifdef WITH_ZLIB | ||||||
|  | 	@echo zlib support:    enabled | ||||||
|  | else | ||||||
|  | 	@echo zlib support:    no | ||||||
|  | endif | ||||||
|  | ifdef WITH_ARES | ||||||
|  | 	@echo c-ares support:  enabled | ||||||
|  | else | ||||||
|  | 	@echo c-ares support:  no | ||||||
|  | endif | ||||||
|  | ifdef ENABLE_IPV6 | ||||||
|  | 	@echo ipv6 support:    enabled | ||||||
|  | else | ||||||
|  | 	@echo ipv6 support:    no | ||||||
|  | endif | ||||||
|  |  | ||||||
| $(LIBCARES): | $(LIBCARES): | ||||||
| 	$(MAKE) -C ../ares -f Makefile.netware lib | 	$(MAKE) -C ../ares -f Makefile.netware lib | ||||||
|   | |||||||
| @@ -132,8 +132,8 @@ CFGSET   = TRUE | |||||||
| !IF "$(CFG)" == "release-dll" | !IF "$(CFG)" == "release-dll" | ||||||
| TARGET = $(LIB_NAME).dll | TARGET = $(LIB_NAME).dll | ||||||
| DIROBJ = $(CFG) | DIROBJ = $(CFG) | ||||||
| LNK    = $(LNKDLL) $(RTLIB) $(WINLIBS) /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | LNK    = $(LNKDLL) $(WINLIBS) /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | ||||||
| CC     = $(CCNODBG) | CC     = $(CCNODBG) $(RTLIB) | ||||||
| CFGSET = TRUE | CFGSET = TRUE | ||||||
| RESOURCE = $(DIROBJ)\libcurl.res | RESOURCE = $(DIROBJ)\libcurl.res | ||||||
| !ENDIF | !ENDIF | ||||||
| @@ -481,6 +481,7 @@ X_OBJS= \ | |||||||
| 	$(DIROBJ)\content_encoding.obj \ | 	$(DIROBJ)\content_encoding.obj \ | ||||||
| 	$(DIROBJ)\tftp.obj \ | 	$(DIROBJ)\tftp.obj \ | ||||||
| 	$(DIROBJ)\splay.obj \ | 	$(DIROBJ)\splay.obj \ | ||||||
|  | 	$(DIROBJ)\socks.obj \ | ||||||
| 	$(RESOURCE) | 	$(RESOURCE) | ||||||
|  |  | ||||||
| all : $(TARGET) | all : $(TARGET) | ||||||
|   | |||||||
| @@ -12,11 +12,11 @@ c-ares: | |||||||
|   http://daniel.haxx.se/projects/c-ares/ |   http://daniel.haxx.se/projects/c-ares/ | ||||||
|  |  | ||||||
| NOTE | NOTE | ||||||
|   libcurl 7.11.1 builds with c-ares 1.1.0, but 7.11.2 and later require c-ares |   The latest libcurl version requires c-ares 1.3.2 or later to work | ||||||
|   1.2.0 or alter. |   flawlessly. | ||||||
|  |  | ||||||
|   Once upon the time libcurl built fine with the "original" ares. That is no |   Once upon the time libcurl built fine with the "original" ares. That is no | ||||||
|   longer true. You need to use c-ares. c-ares is based on ares but improved. |   longer true. You need to use c-ares. | ||||||
|  |  | ||||||
| Build c-ares | Build c-ares | ||||||
| ============ | ============ | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ Modify Your Application | |||||||
|  |  | ||||||
|   Add a line in your application code: |   Add a line in your application code: | ||||||
|  |  | ||||||
|        curl_memdebug("filename"); |        curl_memdebug("dump"); | ||||||
|  |  | ||||||
|   This will make the malloc debug system output a full trace of all resource |   This will make the malloc debug system output a full trace of all resource | ||||||
|   using functions to the given file name. Make sure you rebuild your program |   using functions to the given file name. Make sure you rebuild your program | ||||||
| @@ -45,9 +45,9 @@ Run Your Application | |||||||
|  |  | ||||||
| Analyze the Flow | Analyze the Flow | ||||||
|  |  | ||||||
|   Use the tests/memanalyze.pl perl script to analyze the memdump file: |   Use the tests/memanalyze.pl perl script to analyze the dump file: | ||||||
|  |  | ||||||
|     tests/memanalyze.pl < memdump |     tests/memanalyze.pl dump | ||||||
|  |  | ||||||
|   This now outputs a report on what resources that were allocated but never |   This now outputs a report on what resources that were allocated but never | ||||||
|   freed etc. This report is very fine for posting to the list! |   freed etc. This report is very fine for posting to the list! | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| Implementation of the curl_multi_socket API | Implementation of the curl_multi_socket API | ||||||
|  |  | ||||||
|   Most of the design decisions and debates about this new API have already |   The main ideas of the new API are simply: | ||||||
|   been held on the curl-library mailing list a long time ago so I had a basic |  | ||||||
|   idea on what approach to use. The main ideas of the new API are simply: |  | ||||||
|  |  | ||||||
|    1 - The application can use whatever event system it likes as it gets info |    1 - The application can use whatever event system it likes as it gets info | ||||||
|        from libcurl about what file descriptors libcurl waits for what action |        from libcurl about what file descriptors libcurl waits for what action | ||||||
| @@ -38,62 +36,33 @@ Implementation of the curl_multi_socket API | |||||||
|   is that we get a curl_multi_timeout() that should also work with old-style |   is that we get a curl_multi_timeout() that should also work with old-style | ||||||
|   applications that use curl_multi_perform(). |   applications that use curl_multi_perform(). | ||||||
|  |  | ||||||
|   The easy handle argument was removed fom the curl_multi_socket() function |   We also added a timer callback that makes libcurl call the application when | ||||||
|   because having it there would require the application to do a socket to easy |   the timeout value changes, and you set that with curl_multi_setopt(). | ||||||
|   handle conversion on its own. I find it very unlikely that applications |  | ||||||
|   would want to do that and since libcurl would need such a lookup on its own |  | ||||||
|   anyway since we didn't want to force applications to do that translation |  | ||||||
|   code (it would be optional), it seemed like an unnecessary option. |  | ||||||
|  |  | ||||||
|   Instead I created an internal "socket to easy handles" hash table that given |   We created an internal "socket to easy handles" hash table that given | ||||||
|   a socket (file descriptor) return the easy handle that waits for action on |   a socket (file descriptor) return the easy handle that waits for action on | ||||||
|   that socket.  This hash is made using the already existing hash code |   that socket.  This hash is made using the already existing hash code | ||||||
|   (previously only used for the DNS cache). |   (previously only used for the DNS cache). | ||||||
|  |  | ||||||
|   To make libcurl be able to report plain sockets in the socket callback, I |   To make libcurl able to report plain sockets in the socket callback, we had | ||||||
|   had to re-organize the internals of the curl_multi_fdset() etc so that the |   to re-organize the internals of the curl_multi_fdset() etc so that the | ||||||
|   conversion from sockets to fd_sets for that function is only done in the |   conversion from sockets to fd_sets for that function is only done in the | ||||||
|   last step before the data is returned. I also had to extend c-ares to get a |   last step before the data is returned. I also had to extend c-ares to get a | ||||||
|   function that can return plain sockets, as that library too returned only |   function that can return plain sockets, as that library too returned only | ||||||
|   fd_sets and that is no longer good enough. The changes done to c-ares have |   fd_sets and that is no longer good enough. The changes done to c-ares have | ||||||
|   been committed and are available in the c-ares CVS repository destined to be |   been committed and are available in the c-ares CVS repository destined to be | ||||||
|   included in the upcoming c-ares 1.3.1 release. |   included in the c-ares 1.3.1 release. | ||||||
|  |  | ||||||
|   The 'shiper' tool is the test application I wrote that uses the new |   We have done a test runs with up to 9000 connections (with a single active | ||||||
|   curl_multi_socket() in its current state. It seems to be working and it uses |   one). The curl_multi_socket() invoke then takes less than 10 microseconds in | ||||||
|   the API as it is documented and supposed to work. It is still using |   average (using the read-only-1-byte-at-a-time hack).  We are now below the | ||||||
|   select(), because I needed that during development (like until I had the |   60 microseconds "per socket action" goal (the extra 50 is the time libevent | ||||||
|   socket hash implemented etc) and because I haven't yet learned how to use |   needs). | ||||||
|   libevent or similar. |  | ||||||
|  |  | ||||||
|   The hiper/shiper tools are very simple and initiates lots of connections and |  | ||||||
|   have them running for the test period and then kills them all. |  | ||||||
|  |  | ||||||
|   Since I wasn't done with the implementation until early January I haven't |  | ||||||
|   had time to run very many measurements and checks, but I have done a few |  | ||||||
|   runs with up to a few hundred connections (with a single active one). The |  | ||||||
|   curl_multi_socket() invoke then takes 3-6 microseconds in average (using the |  | ||||||
|   read-only-1-byte-at-a-time hack). If this number does increase a lot when we |  | ||||||
|   add connections, it certainly matches my in my opinion very ambitious goal. |  | ||||||
|   We are now below the 60 microseconds "per socket action" goal. It is |  | ||||||
|   destined to be somewhat higher the more connections we have since the hash |  | ||||||
|   table gets more populated and the splay tree will grow etc. |  | ||||||
|  |  | ||||||
|   Some tests at 7000 and 9000 connections showed that the socket hash lookup |  | ||||||
|   is somewhat of a bottle neck. Its current implementation may be a bit too |  | ||||||
|   limiting. It simply has a fixed-size array, and on each entry in the array |  | ||||||
|   it has a linked list with entries. So the hash only checks which list to |  | ||||||
|   scan through. The code I had used so for used a list with merely 7 slots (as |  | ||||||
|   that is what the DNS hash uses) but with 7000 connections that would make an |  | ||||||
|   average of 1000 nodes in each list to run through. I upped that to 97 slots |  | ||||||
|   (I believe a prime is suitable) and noticed a significant speed increase.  I |  | ||||||
|   need to reconsider the hash implementation or use a rather large default |  | ||||||
|   value like this. At 9000 connections I was still below 10us per call. |  | ||||||
|  |  | ||||||
| Status Right Now | Status Right Now | ||||||
|  |  | ||||||
|   The curl_multi_socket() API is implemented according to how it is |   The curl_multi_socket() API is implemented according to how it is | ||||||
|   documented. |   documented. We deem it ready to use. | ||||||
|  |  | ||||||
|     http://curl.haxx.se/libcurl/c/curl_multi_socket.html |     http://curl.haxx.se/libcurl/c/curl_multi_socket.html | ||||||
|     http://curl.haxx.se/libcurl/c/curl_multi_timeout.html |     http://curl.haxx.se/libcurl/c/curl_multi_timeout.html | ||||||
| @@ -101,12 +70,4 @@ Status Right Now | |||||||
|  |  | ||||||
| What is Left for the curl_multi_socket API | What is Left for the curl_multi_socket API | ||||||
|  |  | ||||||
|   1 - More measuring with more extreme number of connections |   Real world usage! | ||||||
|  |  | ||||||
|   2 - More testing with actual URLs and complete from start to end transfers. |  | ||||||
|  |  | ||||||
|   I'm quite sure we don't set expire times all over in the code properly, so |  | ||||||
|   there is bound to be some timeout bugs left. |  | ||||||
|  |  | ||||||
|   What it really takes is for me to commit the code and to make an official |  | ||||||
|   release with it so that we get people "out there" to help out testing it. |  | ||||||
|   | |||||||
| @@ -1,34 +1,27 @@ | |||||||
| Doing HTTP Pipelining with libcurl | HTTP Pipelining with libcurl | ||||||
| ================================== | ============================ | ||||||
|  |  | ||||||
| Background | Background | ||||||
|  |  | ||||||
| Since pipelining implies that one or more requests are sent to a server before | Since pipelining implies that one or more requests are sent to a server before | ||||||
| the previous response(s) have been received, it cannot be implemented easily | the previous response(s) have been received, we only support it for multi | ||||||
| into libcurl's easy interface due to its synchronous nature. We therefore only | interface use. | ||||||
| aim on adding it for multi interface use. |  | ||||||
|  |  | ||||||
| Considerations | Considerations | ||||||
|  |  | ||||||
| When using the multi interface, you create one easy handle for each transfer. | When using the multi interface, you create one easy handle for each transfer. | ||||||
| Bascially any number of handles can be created, added and used with the multi | Bascially any number of handles can be created, added and used with the multi | ||||||
| interface - simultaneously. It is an interface designed to allow many | interface - simultaneously. It is an interface designed to allow many | ||||||
| simultaneous transfers while still using a single thread. | simultaneous transfers while still using a single thread. Pipelining does not | ||||||
|  | change any of these details. | ||||||
| Pipelining however, will force us to allow apps to somehow "connect" two (or |  | ||||||
| more) easy handles that are added to a multi handle. The first one sends a |  | ||||||
| request and receives a response, just as normal, while the second (and |  | ||||||
| subsequent) ones need to be attached to the first handle so that it can send |  | ||||||
| its request on the same connection and then sit and wait until its response |  | ||||||
| comes. |  | ||||||
|  |  | ||||||
| API | API | ||||||
|  |  | ||||||
| We add a new option to curl_multi_setopt() called CURLMOPT_PIPELINING that | We've added a new option to curl_multi_setopt() called CURLMOPT_PIPELINING | ||||||
| enables "attempted pipelining" and then all easy handles used on that handle | that enables "attempted pipelining" and then all easy handles used on that | ||||||
| will attempt to use an existing pipeline. | handle will attempt to use an existing pipeline. | ||||||
|  |  | ||||||
| Decisions Already Made | Details | ||||||
|  |  | ||||||
| - A pipeline is only created if a previous connection exists to the same IP | - A pipeline is only created if a previous connection exists to the same IP | ||||||
|   address that the new request is being made to use. |   address that the new request is being made to use. | ||||||
| @@ -50,22 +43,9 @@ Decisions Already Made | |||||||
|   be considered for pipelining. Also, asking for explicit pipelining on handle |   be considered for pipelining. Also, asking for explicit pipelining on handle | ||||||
|   X may be tricky when handle X get a closed connection. |   X may be tricky when handle X get a closed connection. | ||||||
|  |  | ||||||
| To Ponder About |  | ||||||
|  |  | ||||||
| - We need options to control max pipeline length, and probably how to behave | - We need options to control max pipeline length, and probably how to behave | ||||||
|   if we reach that limit. As was discussed on the list, it can probably be |   if we reach that limit. As was discussed on the list, it can probably be | ||||||
|   made very complicated, so perhaps we can think of a way to pass all |   made very complicated, so perhaps we can think of a way to pass all | ||||||
|   variables involved to a callback and let the application decide how to act |   variables involved to a callback and let the application decide how to act | ||||||
|   in specific situations. Either way, these fancy options are only interesting |   in specific situations. Either way, these fancy options are only interesting | ||||||
|   to work on when everything is working and we have working apps to test with. |   to work on when everything is working and we have working apps to test with. | ||||||
|  |  | ||||||
| - Currently (before pipelining) we do not have any code or concept that lets |  | ||||||
|   multiple handles share the same physical connection. We need to carefully |  | ||||||
|   make sure that each easy handle knows exactly what they can do and when, on |  | ||||||
|   the shared connection. |  | ||||||
|  |  | ||||||
| - We need to keep a linked list of each handle that is part of a single pipe |  | ||||||
|   so that if it breaks, we know which handles that need to resend their |  | ||||||
|   requests. The pipe linked-lists could very well be "held" in the multi |  | ||||||
|   handle struct so that they won't "belong" to a particular easy handle that |  | ||||||
|   happens to be part of the pipeline during a certain period. |  | ||||||
|   | |||||||
							
								
								
									
										98
									
								
								lib/base64.c
									
									
									
									
									
								
							
							
						
						
									
										98
									
								
								lib/base64.c
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2007, 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 | ||||||
| @@ -40,28 +40,27 @@ | |||||||
| #define _MPRINTF_REPLACE /* use our functions only */ | #define _MPRINTF_REPLACE /* use our functions only */ | ||||||
| #include <curl/mprintf.h> | #include <curl/mprintf.h> | ||||||
|  |  | ||||||
|  | #include "urldata.h" /* for the SessionHandle definition */ | ||||||
|  | #include "easyif.h"  /* for Curl_convert_... prototypes */ | ||||||
| #include "base64.h" | #include "base64.h" | ||||||
| #include "memory.h" | #include "memory.h" | ||||||
|  |  | ||||||
| /* include memdebug.h last */ | /* include memdebug.h last */ | ||||||
| #include "memdebug.h" | #include "memdebug.h" | ||||||
|  |  | ||||||
|  | /* ---- Base64 Encoding/Decoding Table --- */ | ||||||
|  | static const char table64[]= | ||||||
|  |   "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; | ||||||
|  |  | ||||||
| static void decodeQuantum(unsigned char *dest, const char *src) | static void decodeQuantum(unsigned char *dest, const char *src) | ||||||
| { | { | ||||||
|   unsigned int x = 0; |   unsigned int x = 0; | ||||||
|   int i; |   int i; | ||||||
|  |   char *found; | ||||||
|  |  | ||||||
|   for(i = 0; i < 4; i++) { |   for(i = 0; i < 4; i++) { | ||||||
|     if(src[i] >= 'A' && src[i] <= 'Z') |     if((found = strchr(table64, src[i]))) | ||||||
|       x = (x << 6) + (unsigned int)(src[i] - 'A' + 0); |       x = (x << 6) + (unsigned int)(found - table64); | ||||||
|     else if(src[i] >= 'a' && src[i] <= 'z') |  | ||||||
|       x = (x << 6) + (unsigned int)(src[i] - 'a' + 26); |  | ||||||
|     else if(src[i] >= '0' && src[i] <= '9') |  | ||||||
|       x = (x << 6) + (unsigned int)(src[i] - '0' + 52); |  | ||||||
|     else if(src[i] == '+') |  | ||||||
|       x = (x << 6) + 62; |  | ||||||
|     else if(src[i] == '/') |  | ||||||
|       x = (x << 6) + 63; |  | ||||||
|     else if(src[i] == '=') |     else if(src[i] == '=') | ||||||
|       x = (x << 6); |       x = (x << 6); | ||||||
|   } |   } | ||||||
| @@ -133,10 +132,6 @@ size_t Curl_base64_decode(const char *src, unsigned char **outptr) | |||||||
|   return rawlen; |   return rawlen; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* ---- Base64 Encoding --- */ |  | ||||||
| static const char table64[]= |  | ||||||
|   "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Curl_base64_encode() |  * Curl_base64_encode() | ||||||
|  * |  * | ||||||
| @@ -145,7 +140,8 @@ static const char table64[]= | |||||||
|  * went wrong, -1 is returned. |  * went wrong, -1 is returned. | ||||||
|  * |  * | ||||||
|  */ |  */ | ||||||
| size_t Curl_base64_encode(const char *inp, size_t insize, char **outptr) | size_t Curl_base64_encode(struct SessionHandle *data, | ||||||
|  |                           const char *inp, size_t insize, char **outptr) | ||||||
| { | { | ||||||
|   unsigned char ibuf[3]; |   unsigned char ibuf[3]; | ||||||
|   unsigned char obuf[4]; |   unsigned char obuf[4]; | ||||||
| @@ -153,6 +149,9 @@ size_t Curl_base64_encode(const char *inp, size_t insize, char **outptr) | |||||||
|   int inputparts; |   int inputparts; | ||||||
|   char *output; |   char *output; | ||||||
|   char *base64data; |   char *base64data; | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   char *convbuf; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|   char *indata = (char *)inp; |   char *indata = (char *)inp; | ||||||
|  |  | ||||||
| @@ -165,6 +164,28 @@ size_t Curl_base64_encode(const char *inp, size_t insize, char **outptr) | |||||||
|   if(NULL == output) |   if(NULL == output) | ||||||
|     return 0; |     return 0; | ||||||
|  |  | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   /* | ||||||
|  |    * The base64 data needs to be created using the network encoding | ||||||
|  |    * not the host encoding.  And we can't change the actual input | ||||||
|  |    * so we copy it to a buffer, translate it, and use that instead. | ||||||
|  |    */ | ||||||
|  |   if(data) { | ||||||
|  |     convbuf = (char*)malloc(insize); | ||||||
|  |     if(!convbuf) { | ||||||
|  |       return 0; | ||||||
|  |     } | ||||||
|  |     memcpy(convbuf, indata, insize); | ||||||
|  |     if(CURLE_OK != Curl_convert_to_network(data, convbuf, insize)) { | ||||||
|  |       free(convbuf); | ||||||
|  |       return 0; | ||||||
|  |     } | ||||||
|  |     indata = convbuf; /* switch to the converted buffer */ | ||||||
|  |   } | ||||||
|  | #else | ||||||
|  |   (void)data; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|   while(insize > 0) { |   while(insize > 0) { | ||||||
|     for (i = inputparts = 0; i < 3; i++) { |     for (i = inputparts = 0; i < 3; i++) { | ||||||
|       if(insize > 0) { |       if(insize > 0) { | ||||||
| @@ -209,6 +230,10 @@ size_t Curl_base64_encode(const char *inp, size_t insize, char **outptr) | |||||||
|   *output=0; |   *output=0; | ||||||
|   *outptr = base64data; /* make it return the actual data memory */ |   *outptr = base64data; /* make it return the actual data memory */ | ||||||
|  |  | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   if(data) | ||||||
|  |     free(convbuf); | ||||||
|  | #endif | ||||||
|   return strlen(base64data); /* return the length of the new data */ |   return strlen(base64data); /* return the length of the new data */ | ||||||
| } | } | ||||||
| /* ---- End of Base64 Encoding ---- */ | /* ---- End of Base64 Encoding ---- */ | ||||||
| @@ -231,14 +256,26 @@ int main(int argc, char **argv, char **envp) | |||||||
|   size_t base64Len; |   size_t base64Len; | ||||||
|   unsigned char *data; |   unsigned char *data; | ||||||
|   int dataLen; |   int dataLen; | ||||||
|  |   struct SessionHandle *handle = NULL; | ||||||
|  |  | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   /* get a Curl handle so Curl_base64_encode can translate properly */ | ||||||
|  |   handle = curl_easy_init(); | ||||||
|  |   if(handle == NULL) { | ||||||
|  |     fprintf(stderr, "Error: curl_easy_init failed\n"); | ||||||
|  |     return 0; | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|   data = (unsigned char *)suck(&dataLen); |   data = (unsigned char *)suck(&dataLen); | ||||||
|   base64Len = Curl_base64_encode(data, dataLen, &base64); |   base64Len = Curl_base64_encode(handle, data, dataLen, &base64); | ||||||
|  |  | ||||||
|   fprintf(stderr, "%d\n", base64Len); |   fprintf(stderr, "%d\n", base64Len); | ||||||
|   fprintf(stdout, "%s",   base64); |   fprintf(stdout, "%s\n", base64); | ||||||
|  |  | ||||||
|   free(base64); free(data); |   free(base64); free(data); | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   curl_easy_cleanup(handle); | ||||||
|  | #endif | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| @@ -261,10 +298,17 @@ int main(int argc, char **argv, char **envp) | |||||||
|   unsigned char *data; |   unsigned char *data; | ||||||
|   int dataLen; |   int dataLen; | ||||||
|   int i, j; |   int i, j; | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   /* get a Curl handle so main can translate properly */ | ||||||
|  |   struct SessionHandle *handle = curl_easy_init(); | ||||||
|  |   if(handle == NULL) { | ||||||
|  |     fprintf(stderr, "Error: curl_easy_init failed\n"); | ||||||
|  |     return 0; | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|   base64 = (char *)suck(&base64Len); |   base64 = (char *)suck(&base64Len); | ||||||
|   data = (unsigned char *)malloc(base64Len * 3/4 + 8); |   dataLen = Curl_base64_decode(base64, &data); | ||||||
|   dataLen = Curl_base64_decode(base64, data); |  | ||||||
|  |  | ||||||
|   fprintf(stderr, "%d\n", dataLen); |   fprintf(stderr, "%d\n", dataLen); | ||||||
|  |  | ||||||
| @@ -279,13 +323,21 @@ int main(int argc, char **argv, char **envp) | |||||||
|     printf(" | "); |     printf(" | "); | ||||||
|  |  | ||||||
|     for(j=0; j < 0x10; j++) |     for(j=0; j < 0x10; j++) | ||||||
|       if((j+i) < dataLen) |       if((j+i) < dataLen) { | ||||||
|         printf("%c", isgraph(data[i+j])?data[i+j]:'.'); | #ifdef CURL_DOES_CONVERSIONS | ||||||
|       else |         if(CURLE_OK != | ||||||
|  |              Curl_convert_from_network(handle, &data[i+j], (size_t)1)) | ||||||
|  |           data[i+j] = '.'; | ||||||
|  | #endif /* CURL_DOES_CONVERSIONS */ | ||||||
|  |         printf("%c", ISGRAPH(data[i+j])?data[i+j]:'.'); | ||||||
|  |       } else | ||||||
|         break; |         break; | ||||||
|     puts(""); |     puts(""); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | #ifdef CURL_DOES_CONVERSIONS | ||||||
|  |   curl_easy_cleanup(handle); | ||||||
|  | #endif | ||||||
|   free(base64); free(data); |   free(base64); free(data); | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2007, 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 | ||||||
| @@ -22,6 +22,7 @@ | |||||||
|  * |  * | ||||||
|  * $Id$ |  * $Id$ | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
| size_t Curl_base64_encode(const char *input, size_t size, char **str); | size_t Curl_base64_encode(struct SessionHandle *data, | ||||||
|  |                           const char *input, size_t size, char **str); | ||||||
| size_t Curl_base64_decode(const char *source, unsigned char **outptr); | size_t Curl_base64_decode(const char *source, unsigned char **outptr); | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -31,6 +31,8 @@ | |||||||
| #define HAVE_SETJMP_H 1 | #define HAVE_SETJMP_H 1 | ||||||
| #define HAVE_SGTTY_H 1 | #define HAVE_SGTTY_H 1 | ||||||
| #define HAVE_SIGNAL 1 | #define HAVE_SIGNAL 1 | ||||||
|  | #define HAVE_SIGNAL_H 1 | ||||||
|  | #define HAVE_SIG_ATOMIC_T 1 | ||||||
| #define HAVE_SOCKET 1 | #define HAVE_SOCKET 1 | ||||||
| #define HAVE_STRCASECMP 1 | #define HAVE_STRCASECMP 1 | ||||||
| #define HAVE_STRDUP 1 | #define HAVE_STRDUP 1 | ||||||
| @@ -39,6 +41,7 @@ | |||||||
| #define HAVE_STRINGS_H 1 | #define HAVE_STRINGS_H 1 | ||||||
| #define HAVE_STRING_H 1 | #define HAVE_STRING_H 1 | ||||||
| #define HAVE_STRSTR 1 | #define HAVE_STRSTR 1 | ||||||
|  | #define HAVE_STRUCT_TIMEVAL 1 | ||||||
| #define HAVE_SYS_PARAM_H 1 | #define HAVE_SYS_PARAM_H 1 | ||||||
| #define HAVE_SYS_SOCKET_H 1 | #define HAVE_SYS_SOCKET_H 1 | ||||||
| #define HAVE_SYS_SOCKIO_H 1 | #define HAVE_SYS_SOCKIO_H 1 | ||||||
|   | |||||||
| @@ -15,6 +15,7 @@ | |||||||
| #define HAVE_TIME_H             1 | #define HAVE_TIME_H             1 | ||||||
| #define HAVE_STDLIB_H           1 | #define HAVE_STDLIB_H           1 | ||||||
| #define HAVE_UTIME_H            1 | #define HAVE_UTIME_H            1 | ||||||
|  | #define HAVE_SYS_TIME_H         1 | ||||||
|  |  | ||||||
| #define TIME_WITH_SYS_TIME      1 | #define TIME_WITH_SYS_TIME      1 | ||||||
|  |  | ||||||
| @@ -27,9 +28,12 @@ | |||||||
| #define HAVE_MEMCPY             1 | #define HAVE_MEMCPY             1 | ||||||
| #define HAVE_SELECT             1 | #define HAVE_SELECT             1 | ||||||
| #define HAVE_SOCKET             1 | #define HAVE_SOCKET             1 | ||||||
|  | #define HAVE_STRUCT_TIMEVAL     1 | ||||||
|  |  | ||||||
| //#define HAVE_STRICMP          1 | //#define HAVE_STRICMP          1 | ||||||
| #define HAVE_SIGACTION          1 | #define HAVE_SIGACTION          1 | ||||||
|  | #define HAVE_SIGNAL_H           1 | ||||||
|  | #define HAVE_SIG_ATOMIC_T       1 | ||||||
|  |  | ||||||
| #ifdef MACOS_SSL_SUPPORT | #ifdef MACOS_SSL_SUPPORT | ||||||
| #       define USE_SSLEAY       1 | #       define USE_SSLEAY       1 | ||||||
| @@ -43,6 +47,8 @@ | |||||||
|  |  | ||||||
| #define HAVE_FIONBIO            1 | #define HAVE_FIONBIO            1 | ||||||
|  |  | ||||||
|  | #define RETSIGTYPE void | ||||||
|  |  | ||||||
| #define HAVE_GETNAMEINFO 1 | #define HAVE_GETNAMEINFO 1 | ||||||
| #define GETNAMEINFO_QUAL_ARG1 const | #define GETNAMEINFO_QUAL_ARG1 const | ||||||
| #define GETNAMEINFO_TYPE_ARG1 struct sockaddr * | #define GETNAMEINFO_TYPE_ARG1 struct sockaddr * | ||||||
|   | |||||||
| @@ -119,6 +119,9 @@ | |||||||
| /* Define if you have the `gettimeofday' function. */ | /* Define if you have the `gettimeofday' function. */ | ||||||
| #define HAVE_GETTIMEOFDAY | #define HAVE_GETTIMEOFDAY | ||||||
|  |  | ||||||
|  | /* Define if you have the `timeval' struct. */ | ||||||
|  | #define HAVE_STRUCT_TIMEVAL | ||||||
|  |  | ||||||
| /* Define if you have the `inet_addr' function. */ | /* Define if you have the `inet_addr' function. */ | ||||||
| #undef HAVE_INET_ADDR | #undef HAVE_INET_ADDR | ||||||
|  |  | ||||||
| @@ -242,6 +245,15 @@ | |||||||
| /* Define if you have the `signal' function. */ | /* Define if you have the `signal' function. */ | ||||||
| #define HAVE_SIGNAL | #define HAVE_SIGNAL | ||||||
|  |  | ||||||
|  | /* Define if you have the <signal.h> header file. */ | ||||||
|  | #define HAVE_SIGNAL_H | ||||||
|  |  | ||||||
|  | /* Define if sig_atomic_t is an available typedef. */ | ||||||
|  | #define HAVE_SIG_ATOMIC_T | ||||||
|  |  | ||||||
|  | /* Define if sig_atomic_t is already defined as volatile. */ | ||||||
|  | #undef HAVE_SIG_ATOMIC_T_VOLATILE | ||||||
|  |  | ||||||
| /* Define if you have the `socket' function. */ | /* Define if you have the `socket' function. */ | ||||||
| #define HAVE_SOCKET | #define HAVE_SOCKET | ||||||
|  |  | ||||||
|   | |||||||
| @@ -413,6 +413,15 @@ | |||||||
| /* Define to 1 if you have the `signal' function. */ | /* Define to 1 if you have the `signal' function. */ | ||||||
| #define HAVE_SIGNAL 1 | #define HAVE_SIGNAL 1 | ||||||
|  |  | ||||||
|  | /* Define to 1 if you have the <signal.h> header file. */ | ||||||
|  | #define HAVE_SIGNAL_H 1 | ||||||
|  |  | ||||||
|  | /* Define to 1 if sig_atomic_t is an available typedef. */ | ||||||
|  | #define HAVE_SIG_ATOMIC_T 1 | ||||||
|  |  | ||||||
|  | /* Define to 1 if sig_atomic_t is already defined as volatile. */ | ||||||
|  | /* #undef HAVE_SIG_ATOMIC_T_VOLATILE */ | ||||||
|  |  | ||||||
| /* If you have sigsetjmp */ | /* If you have sigsetjmp */ | ||||||
| /* #undef HAVE_SIGSETJMP */ | /* #undef HAVE_SIGSETJMP */ | ||||||
|  |  | ||||||
| @@ -475,6 +484,9 @@ | |||||||
| /* if struct sockaddr_storage is defined */ | /* if struct sockaddr_storage is defined */ | ||||||
| /* #undef HAVE_STRUCT_SOCKADDR_STORAGE */ | /* #undef HAVE_STRUCT_SOCKADDR_STORAGE */ | ||||||
|  |  | ||||||
|  | /* Define this if you have struct timeval */ | ||||||
|  | #define HAVE_STRUCT_TIMEVAL 1 | ||||||
|  |  | ||||||
| /* Define to 1 if you have the <sys/filio.h> header file. */ | /* Define to 1 if you have the <sys/filio.h> header file. */ | ||||||
| #define HAVE_SYS_FILIO_H 1 | #define HAVE_SYS_FILIO_H 1 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -57,6 +57,9 @@ | |||||||
| #define HAVE_PROCESS_H 1 | #define HAVE_PROCESS_H 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* Define if you have the <signal.h> header file. */ | ||||||
|  | #define HAVE_SIGNAL_H 1 | ||||||
|  |  | ||||||
| /* Define if you have the <sgtty.h> header file.  */ | /* Define if you have the <sgtty.h> header file.  */ | ||||||
| /* #define HAVE_SGTTY_H 1 */ | /* #define HAVE_SGTTY_H 1 */ | ||||||
|  |  | ||||||
| @@ -81,6 +84,9 @@ | |||||||
| /* Define if you have the <sys/stat.h> header file.  */ | /* Define if you have the <sys/stat.h> header file.  */ | ||||||
| #define HAVE_SYS_STAT_H 1 | #define HAVE_SYS_STAT_H 1 | ||||||
|  |  | ||||||
|  | /* Define if you have the <sys/time.h> header file */ | ||||||
|  | /* #define HAVE_SYS_TIME_H 1 */ | ||||||
|  |  | ||||||
| /* Define if you have the <sys/types.h> header file.  */ | /* Define if you have the <sys/types.h> header file.  */ | ||||||
| #define HAVE_SYS_TYPES_H 1 | #define HAVE_SYS_TYPES_H 1 | ||||||
|  |  | ||||||
| @@ -122,6 +128,9 @@ | |||||||
| /*                        OTHER HEADER INFO                         */ | /*                        OTHER HEADER INFO                         */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
|  |  | ||||||
|  | /* Define if sig_atomic_t is an available typedef. */ | ||||||
|  | #define HAVE_SIG_ATOMIC_T 1 | ||||||
|  |  | ||||||
| /* Define if you have the ANSI C header files.  */ | /* Define if you have the ANSI C header files.  */ | ||||||
| #define STDC_HEADERS 1 | #define STDC_HEADERS 1 | ||||||
|  |  | ||||||
| @@ -285,13 +294,11 @@ | |||||||
| #define in_addr_t unsigned long | #define in_addr_t unsigned long | ||||||
|  |  | ||||||
| /* Define as the return type of signal handlers (int or void).  */ | /* Define as the return type of signal handlers (int or void).  */ | ||||||
| /* #define RETSIGTYPE void */ | #define RETSIGTYPE void | ||||||
|  |  | ||||||
| /* Define to `unsigned' if size_t is not an available 'typedefed' type */ |  | ||||||
| /* #define size_t unsigned */ |  | ||||||
|  |  | ||||||
| /* Define to 'int' if ssize_t is not an available 'typedefed' type */ |  | ||||||
| #if (defined(__WATCOMC__) && (__WATCOMC__ >= 1240)) || defined(__POCC__) | #if (defined(__WATCOMC__) && (__WATCOMC__ >= 1240)) || defined(__POCC__) | ||||||
|  | #elif defined(_WIN64) | ||||||
|  | #define ssize_t __int64 | ||||||
| #else | #else | ||||||
| #define ssize_t int | #define ssize_t int | ||||||
| #endif | #endif | ||||||
| @@ -335,6 +342,9 @@ | |||||||
| #define HAVE_STRUCT_SOCKADDR_STORAGE 1 | #define HAVE_STRUCT_SOCKADDR_STORAGE 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* Define this if you have struct timeval */ | ||||||
|  | #define HAVE_STRUCT_TIMEVAL 1 | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| /*                        COMPILER SPECIFIC                         */ | /*                        COMPILER SPECIFIC                         */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| @@ -342,6 +352,11 @@ | |||||||
| /* Undef keyword 'const' if it does not work.  */ | /* Undef keyword 'const' if it does not work.  */ | ||||||
| /* #undef const */ | /* #undef const */ | ||||||
|  |  | ||||||
|  | #if defined(_MSC_VER) && (_MSC_VER > 1310) | ||||||
|  | /* MSVC 2003 has gmtime_r */ | ||||||
|  | #define HAVE_GMTIME_R | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| /*                        LDAP LIBRARY FILES                        */ | /*                        LDAP LIBRARY FILES                        */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
|   | |||||||
| @@ -48,6 +48,9 @@ | |||||||
| /* Define if you have the <netinet/in.h> header file.  */ | /* Define if you have the <netinet/in.h> header file.  */ | ||||||
| /* #define HAVE_NETINET_IN_H 1 */ | /* #define HAVE_NETINET_IN_H 1 */ | ||||||
|  |  | ||||||
|  | /* Define if you have the <signal.h> header file. */ | ||||||
|  | #define HAVE_SIGNAL_H 1 | ||||||
|  |  | ||||||
| /* Define if you have the <sgtty.h> header file.  */ | /* Define if you have the <sgtty.h> header file.  */ | ||||||
| /* #define HAVE_SGTTY_H 1 */ | /* #define HAVE_SGTTY_H 1 */ | ||||||
|  |  | ||||||
| @@ -75,6 +78,9 @@ | |||||||
| /* Define if you have the <sys/stat.h> header file.  */ | /* Define if you have the <sys/stat.h> header file.  */ | ||||||
| #define HAVE_SYS_STAT_H 1 | #define HAVE_SYS_STAT_H 1 | ||||||
|  |  | ||||||
|  | /* Define if you have the <sys/time.h> header file */ | ||||||
|  | /* #define HAVE_SYS_TIME_H 1 */ | ||||||
|  |  | ||||||
| /* Define if you have the <sys/types.h> header file.  */ | /* Define if you have the <sys/types.h> header file.  */ | ||||||
| /* #define HAVE_SYS_TYPES_H 1 */ | /* #define HAVE_SYS_TYPES_H 1 */ | ||||||
|  |  | ||||||
| @@ -111,6 +117,9 @@ | |||||||
| /*                        OTHER HEADER INFO                         */ | /*                        OTHER HEADER INFO                         */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
|  |  | ||||||
|  | /* Define if sig_atomic_t is an available typedef. */ | ||||||
|  | #define HAVE_SIG_ATOMIC_T 1 | ||||||
|  |  | ||||||
| /* Define if you have the ANSI C header files.  */ | /* Define if you have the ANSI C header files.  */ | ||||||
| #define STDC_HEADERS 1 | #define STDC_HEADERS 1 | ||||||
|  |  | ||||||
| @@ -269,13 +278,15 @@ | |||||||
| #define in_addr_t unsigned long | #define in_addr_t unsigned long | ||||||
|  |  | ||||||
| /* Define as the return type of signal handlers (int or void).  */ | /* Define as the return type of signal handlers (int or void).  */ | ||||||
| /* #define RETSIGTYPE void */ | #define RETSIGTYPE void | ||||||
|  |  | ||||||
| /* Define to `unsigned' if size_t is not an available 'typedefed' type */ | /* Define ssize_t if it is not an available 'typedefed' type */ | ||||||
| /* #define size_t unsigned */ | #if (defined(__WATCOMC__) && (__WATCOMC__ >= 1240)) || defined(__POCC__) | ||||||
|  | #elif defined(_WIN64) | ||||||
| /* Define to 'int' if ssize_t is not an available 'typedefed' type */ | #define ssize_t __int64 | ||||||
|  | #else | ||||||
| #define ssize_t int | #define ssize_t int | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* Define to 'int' if socklen_t is not an available 'typedefed' type */ | /* Define to 'int' if socklen_t is not an available 'typedefed' type */ | ||||||
| #ifndef HAVE_WS2TCPIP_H | #ifndef HAVE_WS2TCPIP_H | ||||||
| @@ -307,6 +318,9 @@ | |||||||
| /* Define this if you have struct sockaddr_storage */ | /* Define this if you have struct sockaddr_storage */ | ||||||
| /* #define HAVE_STRUCT_SOCKADDR_STORAGE 1 */ | /* #define HAVE_STRUCT_SOCKADDR_STORAGE 1 */ | ||||||
|  |  | ||||||
|  | /* Define this if you have struct timeval */ | ||||||
|  | #define HAVE_STRUCT_TIMEVAL 1 | ||||||
|  |  | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
| /*                        COMPILER SPECIFIC                         */ | /*                        COMPILER SPECIFIC                         */ | ||||||
| /* ---------------------------------------------------------------- */ | /* ---------------------------------------------------------------- */ | ||||||
|   | |||||||
| @@ -1,22 +1,24 @@ | |||||||
| #ifndef _CURL_CONFIG_DJGPP_H | #ifndef _CURL_CONFIG_DOS_H | ||||||
| #define _CURL_CONFIG_DJGPP_H | #define _CURL_CONFIG_DOS_H | ||||||
| 
 | 
 | ||||||
| /* lib/config.dj - Hand crafted config file for DJGPP. | /* lib/config.dos - Hand crafted config file for MSDOS. | ||||||
|  * |  * | ||||||
|  * $Id$ |  * $Id$ | ||||||
|  */ |  */ | ||||||
| #define OS       "MSDOS/djgpp" | #if defined(DJGPP) | ||||||
| #define PACKAGE  "curl" |   #define OS  "MSDOS/djgpp" | ||||||
| 
 | #elif defined(__HIGHC__) | ||||||
| #define CURL_CA_BUNDLE  "/dev/env/CURL_CA_BUNDLE" |   #define OS  "MSDOS/HighC" | ||||||
| 
 | #elif defined(__WATCOMC__) | ||||||
| #if (DJGPP_MINOR >= 4) |   #define OS  "MSDOS/Watcom" | ||||||
| /* #define HAVE_DLOPEN 1 maybe not (DXE3) */ | #else | ||||||
|  |   #define OS  "MSDOS/?" | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | #define PACKAGE  "curl" | ||||||
|  | 
 | ||||||
| #define HAVE_ASSERT_T          1 | #define HAVE_ASSERT_T          1 | ||||||
| #define HAVE_ARPA_INET_H       1 | #define HAVE_ARPA_INET_H       1 | ||||||
| #define HAVE_BASENAME          1 |  | ||||||
| #define HAVE_CLOSESOCKET       1 | #define HAVE_CLOSESOCKET       1 | ||||||
| #define HAVE_FCNTL_H           1 | #define HAVE_FCNTL_H           1 | ||||||
| #define HAVE_FIONBIO           1 | #define HAVE_FIONBIO           1 | ||||||
| @@ -42,21 +44,23 @@ | |||||||
| #define HAVE_NET_IF_H          1 | #define HAVE_NET_IF_H          1 | ||||||
| #define HAVE_PROCESS_H         1 | #define HAVE_PROCESS_H         1 | ||||||
| #define HAVE_PERROR            1 | #define HAVE_PERROR            1 | ||||||
|  | #define HAVE_RECV              1 | ||||||
| #define HAVE_SELECT            1 | #define HAVE_SELECT            1 | ||||||
|  | #define HAVE_SEND              1 | ||||||
| #define HAVE_SETJMP_H          1 | #define HAVE_SETJMP_H          1 | ||||||
| #define HAVE_SETLOCALE         1 | #define HAVE_SETLOCALE         1 | ||||||
| #define HAVE_SETVBUF           1 | #define HAVE_SETVBUF           1 | ||||||
| #define HAVE_SIGNAL            1 | #define HAVE_SIGNAL            1 | ||||||
| #define HAVE_SIGACTION         1 | #define HAVE_SIGNAL_H          1 | ||||||
| #define HAVE_SIGSETJMP         1 | #define HAVE_SIG_ATOMIC_T      1 | ||||||
| #define HAVE_SOCKET            1 | #define HAVE_SOCKET            1 | ||||||
| #define HAVE_SPNEGO            1 | #define HAVE_SPNEGO            1 | ||||||
| #define HAVE_STRCASECMP        1 |  | ||||||
| #define HAVE_STRDUP            1 | #define HAVE_STRDUP            1 | ||||||
| #define HAVE_STRFTIME          1 | #define HAVE_STRFTIME          1 | ||||||
| #define HAVE_STRICMP           1 | #define HAVE_STRICMP           1 | ||||||
| #define HAVE_STRSTR            1 | #define HAVE_STRSTR            1 | ||||||
| #define HAVE_STRTOLL           1 | #define HAVE_STRTOLL           1 | ||||||
|  | #define HAVE_STRUCT_TIMEVAL    1 | ||||||
| #define HAVE_SYS_IOCTL_H       1 | #define HAVE_SYS_IOCTL_H       1 | ||||||
| #define HAVE_SYS_SOCKET_H      1 | #define HAVE_SYS_SOCKET_H      1 | ||||||
| #define HAVE_SYS_STAT_H        1 | #define HAVE_SYS_STAT_H        1 | ||||||
| @@ -69,16 +73,28 @@ | |||||||
| 
 | 
 | ||||||
| #define NEED_MALLOC_H          1 | #define NEED_MALLOC_H          1 | ||||||
| 
 | 
 | ||||||
| #if (DJGPP_MINOR >= 4) |  | ||||||
| #define HAVE_STRLCAT           1 |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #define RETSIGTYPE             void | #define RETSIGTYPE             void | ||||||
| #define SIZEOF_LONG_DOUBLE     16 | #define SIZEOF_LONG_DOUBLE     16 | ||||||
| #define SIZEOF_CURL_OFF_T      4   /* no huge file support */ | #define SIZEOF_CURL_OFF_T      4   /* no huge file support */ | ||||||
| #define STDC_HEADERS           1 | #define STDC_HEADERS           1 | ||||||
| #define TIME_WITH_SYS_TIME     1 | #define TIME_WITH_SYS_TIME     1 | ||||||
| 
 | 
 | ||||||
|  | /* Qualifiers for send() and recv(). | ||||||
|  |  */ | ||||||
|  | #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 BSD | #define BSD | ||||||
| 
 | 
 | ||||||
| /* #define MALLOCDEBUG */ | /* #define MALLOCDEBUG */ | ||||||
| @@ -105,19 +121,41 @@ | |||||||
| /* to disable LDAP */ | /* to disable LDAP */ | ||||||
| #define CURL_DISABLE_LDAP        1 | #define CURL_DISABLE_LDAP        1 | ||||||
| 
 | 
 | ||||||
| /* Because djgpp <= 2.03 doesn't have snprintf() etc. |  | ||||||
|  */ |  | ||||||
| #if (DJGPP_MINOR < 4) |  | ||||||
|   #define _MPRINTF_REPLACE |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #define in_addr_t  u_long | #define in_addr_t  u_long | ||||||
| #define socklen_t  int | #define socklen_t  int | ||||||
| 
 | 
 | ||||||
| #if __GNUC__ < 4   /* gcc 4.x built-in ? */ | #if defined(__HIGHC__) || \ | ||||||
|  |     (defined(__GNUC__) && __GNUC__ < 4)   /* gcc 4.x built-in ? */ | ||||||
| #define ssize_t    int | #define ssize_t    int | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | #define CURL_CA_BUNDLE  getenv("CURL_CA_BUNDLE") | ||||||
|  | 
 | ||||||
|  | /* Target HAVE_x section | ||||||
|  |  */ | ||||||
|  | #if defined(DJGPP) | ||||||
|  |   #define HAVE_BASENAME   1 | ||||||
|  |   #define HAVE_STRCASECMP 1 | ||||||
|  |   #define HAVE_SIGACTION  1 | ||||||
|  |   #define HAVE_SIGSETJMP  1 | ||||||
|  |   #define HAVE_SYS_TIME_H 1 | ||||||
|  | 
 | ||||||
|  |   #if (DJGPP_MINOR >= 4) | ||||||
|  |     #define HAVE_STRLCAT  1 | ||||||
|  |   #endif | ||||||
|  | 
 | ||||||
|  |   /* 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 | ||||||
|  | 
 | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <tcp.h>    /* Watt-32 API */ | #include <tcp.h>    /* Watt-32 API */ | ||||||
| @@ -125,5 +163,5 @@ | |||||||
| #undef word | #undef word | ||||||
| #undef byte | #undef byte | ||||||
| 
 | 
 | ||||||
| #endif  /* _CURL_CONFIG_DJGPP_H */ | #endif  /* _CURL_CONFIG_DOS_H */ | ||||||
| 
 | 
 | ||||||
| @@ -25,7 +25,9 @@ | |||||||
|  |  | ||||||
| #ifndef WIN32 | #ifndef WIN32 | ||||||
| /* headers for non-win32 */ | /* headers for non-win32 */ | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|  | #endif | ||||||
| #ifdef HAVE_SYS_TYPES_H | #ifdef HAVE_SYS_TYPES_H | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #endif | #endif | ||||||
| @@ -82,7 +84,7 @@ | |||||||
| #define FALSE 0 | #define FALSE 0 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef USE_WINSOCK | ||||||
| #define EINPROGRESS WSAEINPROGRESS | #define EINPROGRESS WSAEINPROGRESS | ||||||
| #define EWOULDBLOCK WSAEWOULDBLOCK | #define EWOULDBLOCK WSAEWOULDBLOCK | ||||||
| #define EISCONN     WSAEISCONN | #define EISCONN     WSAEISCONN | ||||||
| @@ -119,7 +121,7 @@ singleipconnect(struct connectdata *conn, | |||||||
|  */ |  */ | ||||||
| int Curl_sockerrno(void) | int Curl_sockerrno(void) | ||||||
| { | { | ||||||
| #ifdef WIN32 | #ifdef USE_WINSOCK | ||||||
|   return (int)WSAGetLastError(); |   return (int)WSAGetLastError(); | ||||||
| #else | #else | ||||||
|   return errno; |   return errno; | ||||||
| @@ -382,11 +384,10 @@ static CURLcode bindlocal(struct connectdata *conn, | |||||||
|     if( bind(sockfd, sock, socksize) >= 0) { |     if( bind(sockfd, sock, socksize) >= 0) { | ||||||
|       /* we succeeded to bind */ |       /* we succeeded to bind */ | ||||||
|       struct Curl_sockaddr_storage add; |       struct Curl_sockaddr_storage add; | ||||||
|       size_t size; |       socklen_t size; | ||||||
|  |  | ||||||
|       size = sizeof(add); |       size = sizeof(add); | ||||||
|       if(getsockname(sockfd, (struct sockaddr *) &add, |       if(getsockname(sockfd, (struct sockaddr *) &add, &size) < 0) { | ||||||
|                      (socklen_t *)&size)<0) { |  | ||||||
|         failf(data, "getsockname() failed"); |         failf(data, "getsockname() failed"); | ||||||
|         return CURLE_HTTP_PORT_FAILED; |         return CURLE_HTTP_PORT_FAILED; | ||||||
|       } |       } | ||||||
| @@ -702,6 +703,17 @@ singleipconnect(struct connectdata *conn, | |||||||
|  |  | ||||||
|   nosigpipe(conn, sockfd); |   nosigpipe(conn, sockfd); | ||||||
|  |  | ||||||
|  |   if(data->set.fsockopt) { | ||||||
|  |     /* activate callback for setting socket options */ | ||||||
|  |     error = data->set.fsockopt(data->set.sockopt_client, | ||||||
|  |                                sockfd, | ||||||
|  |                                CURLSOCKTYPE_IPCXN); | ||||||
|  |     if (error) { | ||||||
|  |       sclose(sockfd); /* close the socket and bail out */ | ||||||
|  |       return CURL_SOCKET_BAD; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|   /* possibly bind the local end to an IP, interface or port */ |   /* possibly bind the local end to an IP, interface or port */ | ||||||
|   res = bindlocal(conn, sockfd); |   res = bindlocal(conn, sockfd); | ||||||
|   if(res) { |   if(res) { | ||||||
|   | |||||||
| @@ -62,9 +62,9 @@ enum zlibState { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| static CURLcode | static CURLcode | ||||||
| process_zlib_error(struct SessionHandle *data, | process_zlib_error(struct connectdata *conn, z_stream *z) | ||||||
|  z_stream *z) |  | ||||||
| { | { | ||||||
|  |   struct SessionHandle *data = conn->data; | ||||||
|   if (z->msg) |   if (z->msg) | ||||||
|     failf (data, "Error while processing content unencoding: %s", |     failf (data, "Error while processing content unencoding: %s", | ||||||
|            z->msg); |            z->msg); | ||||||
| @@ -84,7 +84,7 @@ exit_zlib(z_stream *z, bool *zlib_init, CURLcode result) | |||||||
| } | } | ||||||
|  |  | ||||||
| static CURLcode | static CURLcode | ||||||
| inflate_stream(struct SessionHandle *data, | inflate_stream(struct connectdata *conn, | ||||||
|                struct Curl_transfer_keeper *k) |                struct Curl_transfer_keeper *k) | ||||||
| { | { | ||||||
|   int allow_restart = 1; |   int allow_restart = 1; | ||||||
| @@ -113,7 +113,7 @@ inflate_stream(struct SessionHandle *data, | |||||||
|     if (status == Z_OK || status == Z_STREAM_END) { |     if (status == Z_OK || status == Z_STREAM_END) { | ||||||
|       allow_restart = 0; |       allow_restart = 0; | ||||||
|       if(DSIZ - z->avail_out) { |       if(DSIZ - z->avail_out) { | ||||||
|         result = Curl_client_write(data, CLIENTWRITE_BODY, decomp, |         result = Curl_client_write(conn, CLIENTWRITE_BODY, decomp, | ||||||
|                                    DSIZ - z->avail_out); |                                    DSIZ - z->avail_out); | ||||||
|         /* if !CURLE_OK, clean up, return */ |         /* if !CURLE_OK, clean up, return */ | ||||||
|         if (result) { |         if (result) { | ||||||
| @@ -128,7 +128,7 @@ inflate_stream(struct SessionHandle *data, | |||||||
|         if (inflateEnd(z) == Z_OK) |         if (inflateEnd(z) == Z_OK) | ||||||
|           return exit_zlib(z, &k->zlib_init, result); |           return exit_zlib(z, &k->zlib_init, result); | ||||||
|         else |         else | ||||||
|           return exit_zlib(z, &k->zlib_init, process_zlib_error(data, z)); |           return exit_zlib(z, &k->zlib_init, process_zlib_error(conn, z)); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       /* Done with these bytes, exit */ |       /* Done with these bytes, exit */ | ||||||
| @@ -143,7 +143,7 @@ inflate_stream(struct SessionHandle *data, | |||||||
|  |  | ||||||
|       inflateReset(z); |       inflateReset(z); | ||||||
|       if (inflateInit2(z, -MAX_WBITS) != Z_OK) { |       if (inflateInit2(z, -MAX_WBITS) != Z_OK) { | ||||||
|         return process_zlib_error(data, z); |         return process_zlib_error(conn, z); | ||||||
|       } |       } | ||||||
|       z->next_in = orig_in; |       z->next_in = orig_in; | ||||||
|       z->avail_in = nread; |       z->avail_in = nread; | ||||||
| @@ -152,14 +152,14 @@ inflate_stream(struct SessionHandle *data, | |||||||
|     } |     } | ||||||
|     else {                      /* Error; exit loop, handle below */ |     else {                      /* Error; exit loop, handle below */ | ||||||
|       free(decomp); |       free(decomp); | ||||||
|       return exit_zlib(z, &k->zlib_init, process_zlib_error(data, z)); |       return exit_zlib(z, &k->zlib_init, process_zlib_error(conn, z)); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   /* Will never get here */ |   /* Will never get here */ | ||||||
| } | } | ||||||
|  |  | ||||||
| CURLcode | CURLcode | ||||||
| Curl_unencode_deflate_write(struct SessionHandle *data, | Curl_unencode_deflate_write(struct connectdata *conn, | ||||||
|                             struct Curl_transfer_keeper *k, |                             struct Curl_transfer_keeper *k, | ||||||
|                             ssize_t nread) |                             ssize_t nread) | ||||||
| { | { | ||||||
| @@ -173,7 +173,7 @@ Curl_unencode_deflate_write(struct SessionHandle *data, | |||||||
|     z->next_in = NULL; |     z->next_in = NULL; | ||||||
|     z->avail_in = 0; |     z->avail_in = 0; | ||||||
|     if (inflateInit(z) != Z_OK) |     if (inflateInit(z) != Z_OK) | ||||||
|       return process_zlib_error(data, z); |       return process_zlib_error(conn, z); | ||||||
|     k->zlib_init = ZLIB_INIT; |     k->zlib_init = ZLIB_INIT; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -182,7 +182,7 @@ Curl_unencode_deflate_write(struct SessionHandle *data, | |||||||
|   z->avail_in = (uInt)nread; |   z->avail_in = (uInt)nread; | ||||||
|  |  | ||||||
|   /* Now uncompress the data */ |   /* Now uncompress the data */ | ||||||
|   return inflate_stream(data, k); |   return inflate_stream(conn, k); | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef OLD_ZLIB_SUPPORT | #ifdef OLD_ZLIB_SUPPORT | ||||||
| @@ -272,7 +272,7 @@ static enum { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| CURLcode | CURLcode | ||||||
| Curl_unencode_gzip_write(struct SessionHandle *data, | Curl_unencode_gzip_write(struct connectdata *conn, | ||||||
|                          struct Curl_transfer_keeper *k, |                          struct Curl_transfer_keeper *k, | ||||||
|                          ssize_t nread) |                          ssize_t nread) | ||||||
| { | { | ||||||
| @@ -289,14 +289,14 @@ Curl_unencode_gzip_write(struct SessionHandle *data, | |||||||
|     if (strcmp(zlibVersion(), "1.2.0.4") >= 0) { |     if (strcmp(zlibVersion(), "1.2.0.4") >= 0) { | ||||||
|         /* zlib ver. >= 1.2.0.4 supports transparent gzip decompressing */ |         /* zlib ver. >= 1.2.0.4 supports transparent gzip decompressing */ | ||||||
|         if (inflateInit2(z, MAX_WBITS+32) != Z_OK) { |         if (inflateInit2(z, MAX_WBITS+32) != Z_OK) { | ||||||
|           return process_zlib_error(data, z); |           return process_zlib_error(conn, z); | ||||||
|         } |         } | ||||||
|         k->zlib_init = ZLIB_INIT_GZIP; /* Transparent gzip decompress state */ |         k->zlib_init = ZLIB_INIT_GZIP; /* Transparent gzip decompress state */ | ||||||
|  |  | ||||||
|     } else { |     } else { | ||||||
|         /* we must parse the gzip header ourselves */ |         /* we must parse the gzip header ourselves */ | ||||||
|         if (inflateInit2(z, -MAX_WBITS) != Z_OK) { |         if (inflateInit2(z, -MAX_WBITS) != Z_OK) { | ||||||
|           return process_zlib_error(data, z); |           return process_zlib_error(conn, z); | ||||||
|         } |         } | ||||||
|         k->zlib_init = ZLIB_INIT;   /* Initial call state */ |         k->zlib_init = ZLIB_INIT;   /* Initial call state */ | ||||||
|     } |     } | ||||||
| @@ -307,7 +307,7 @@ Curl_unencode_gzip_write(struct SessionHandle *data, | |||||||
|      z->next_in = (Bytef *)k->str; |      z->next_in = (Bytef *)k->str; | ||||||
|      z->avail_in = (uInt)nread; |      z->avail_in = (uInt)nread; | ||||||
|      /* Now uncompress the data */ |      /* Now uncompress the data */ | ||||||
|      return inflate_stream(data, k); |      return inflate_stream(conn, k); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #ifndef OLD_ZLIB_SUPPORT | #ifndef OLD_ZLIB_SUPPORT | ||||||
| @@ -360,7 +360,7 @@ Curl_unencode_gzip_write(struct SessionHandle *data, | |||||||
|  |  | ||||||
|     case GZIP_BAD: |     case GZIP_BAD: | ||||||
|     default: |     default: | ||||||
|       return exit_zlib(z, &k->zlib_init, process_zlib_error(data, z)); |       return exit_zlib(z, &k->zlib_init, process_zlib_error(conn, z)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   } |   } | ||||||
| @@ -398,7 +398,7 @@ Curl_unencode_gzip_write(struct SessionHandle *data, | |||||||
|     case GZIP_BAD: |     case GZIP_BAD: | ||||||
|     default: |     default: | ||||||
|       free(z->next_in); |       free(z->next_in); | ||||||
|       return exit_zlib(z, &k->zlib_init, process_zlib_error(data, z)); |       return exit_zlib(z, &k->zlib_init, process_zlib_error(conn, z)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   } |   } | ||||||
| @@ -418,7 +418,7 @@ Curl_unencode_gzip_write(struct SessionHandle *data, | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* We've parsed the header, now uncompress the data */ |   /* We've parsed the header, now uncompress the data */ | ||||||
|   return inflate_stream(data, k); |   return inflate_stream(conn, k); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
| #endif /* HAVE_LIBZ */ | #endif /* HAVE_LIBZ */ | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2006, 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 | ||||||
| @@ -31,11 +31,11 @@ | |||||||
| #define ALL_CONTENT_ENCODINGS "identity" | #define ALL_CONTENT_ENCODINGS "identity" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| CURLcode Curl_unencode_deflate_write(struct SessionHandle *data, | CURLcode Curl_unencode_deflate_write(struct connectdata *conn, | ||||||
|                                      struct Curl_transfer_keeper *k, |                                      struct Curl_transfer_keeper *k, | ||||||
|                                      ssize_t nread); |                                      ssize_t nread); | ||||||
|  |  | ||||||
| CURLcode | CURLcode | ||||||
| Curl_unencode_gzip_write(struct SessionHandle *data, | Curl_unencode_gzip_write(struct connectdata *conn, | ||||||
|                          struct Curl_transfer_keeper *k, |                          struct Curl_transfer_keeper *k, | ||||||
|                          ssize_t nread); |                          ssize_t nread); | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2007, 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 | ||||||
| @@ -806,9 +806,11 @@ struct Cookie *Curl_cookie_getlist(struct CookieInfo *c, | |||||||
|  ****************************************************************************/ |  ****************************************************************************/ | ||||||
| void Curl_cookie_clearall(struct CookieInfo *cookies) | void Curl_cookie_clearall(struct CookieInfo *cookies) | ||||||
| { | { | ||||||
|  |   if(cookies) { | ||||||
|     Curl_cookie_freelist(cookies->cookies); |     Curl_cookie_freelist(cookies->cookies); | ||||||
|     cookies->cookies = NULL; |     cookies->cookies = NULL; | ||||||
|     cookies->numcookies = 0; |     cookies->numcookies = 0; | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| /***************************************************************************** | /***************************************************************************** | ||||||
| @@ -958,7 +960,7 @@ int Curl_cookie_output(struct CookieInfo *c, char *dumphere) | |||||||
|     char *format_ptr; |     char *format_ptr; | ||||||
|  |  | ||||||
|     fputs("# Netscape HTTP Cookie File\n" |     fputs("# Netscape HTTP Cookie File\n" | ||||||
|           "# http://www.netscape.com/newsref/std/cookie_spec.html\n" |           "# http://curlm.haxx.se/rfc/cookie_spec.html\n" | ||||||
|           "# This file was generated by libcurl! Edit at your own risk.\n\n", |           "# This file was generated by libcurl! Edit at your own risk.\n\n", | ||||||
|           out); |           out); | ||||||
|     co = c->cookies; |     co = c->cookies; | ||||||
|   | |||||||
| @@ -24,11 +24,13 @@ | |||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #ifdef WIN32 | #if defined(WIN32) | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #else | #else | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2006, 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 | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								lib/dict.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								lib/dict.c
									
									
									
									
									
								
							| @@ -38,7 +38,7 @@ | |||||||
| #include <sys/stat.h> | #include <sys/stat.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__) | #ifdef WIN32 | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #include <io.h> | #include <io.h> | ||||||
| #else | #else | ||||||
| @@ -46,7 +46,9 @@ | |||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|  | #endif | ||||||
| #ifdef HAVE_UNISTD_H | #ifdef HAVE_UNISTD_H | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #endif | #endif | ||||||
| @@ -104,7 +106,7 @@ static char *unescape_word(struct SessionHandle *data, char *inp) | |||||||
|     /* According to RFC2229 section 2.2, these letters need to be escaped with |     /* According to RFC2229 section 2.2, these letters need to be escaped with | ||||||
|        \[letter] */ |        \[letter] */ | ||||||
|     for(ptr = newp; |     for(ptr = newp; | ||||||
|         (byte = (unsigned char)*ptr); |         (byte = (unsigned char)*ptr) != 0; | ||||||
|         ptr++) { |         ptr++) { | ||||||
|       if ((byte <= 32) || (byte == 127) || |       if ((byte <= 32) || (byte == 127) || | ||||||
|           (byte == '\'') || (byte == '\"') || (byte == '\\')) { |           (byte == '\'') || (byte == '\"') || (byte == '\\')) { | ||||||
| @@ -132,8 +134,8 @@ CURLcode Curl_dict(struct connectdata *conn, bool *done) | |||||||
|   struct SessionHandle *data=conn->data; |   struct SessionHandle *data=conn->data; | ||||||
|   curl_socket_t sockfd = conn->sock[FIRSTSOCKET]; |   curl_socket_t sockfd = conn->sock[FIRSTSOCKET]; | ||||||
|  |  | ||||||
|   char *path = conn->path; |   char *path = data->reqdata.path; | ||||||
|   curl_off_t *bytecount = &conn->bytecount; |   curl_off_t *bytecount = &data->reqdata.keep.bytecount; | ||||||
|  |  | ||||||
|   *done = TRUE; /* unconditionally */ |   *done = TRUE; /* unconditionally */ | ||||||
|  |  | ||||||
| @@ -194,7 +196,7 @@ CURLcode Curl_dict(struct connectdata *conn, bool *done) | |||||||
|     if(result) |     if(result) | ||||||
|       failf(data, "Failed sending DICT request"); |       failf(data, "Failed sending DICT request"); | ||||||
|     else |     else | ||||||
|       result = Curl_Transfer(conn, FIRSTSOCKET, -1, FALSE, bytecount, |       result = Curl_setup_transfer(conn, FIRSTSOCKET, -1, FALSE, bytecount, | ||||||
|                                    -1, NULL); /* no upload */ |                                    -1, NULL); /* no upload */ | ||||||
|     if(result) |     if(result) | ||||||
|       return result; |       return result; | ||||||
| @@ -241,7 +243,7 @@ CURLcode Curl_dict(struct connectdata *conn, bool *done) | |||||||
|     if(result) |     if(result) | ||||||
|       failf(data, "Failed sending DICT request"); |       failf(data, "Failed sending DICT request"); | ||||||
|     else |     else | ||||||
|       result = Curl_Transfer(conn, FIRSTSOCKET, -1, FALSE, bytecount, |       result = Curl_setup_transfer(conn, FIRSTSOCKET, -1, FALSE, bytecount, | ||||||
|                                    -1, NULL); /* no upload */ |                                    -1, NULL); /* no upload */ | ||||||
|  |  | ||||||
|     if(result) |     if(result) | ||||||
| @@ -266,7 +268,7 @@ CURLcode Curl_dict(struct connectdata *conn, bool *done) | |||||||
|       if(result) |       if(result) | ||||||
|         failf(data, "Failed sending DICT request"); |         failf(data, "Failed sending DICT request"); | ||||||
|       else |       else | ||||||
|         result = Curl_Transfer(conn, FIRSTSOCKET, -1, FALSE, bytecount, |         result = Curl_setup_transfer(conn, FIRSTSOCKET, -1, FALSE, bytecount, | ||||||
|                                      -1, NULL); |                                      -1, NULL); | ||||||
|       if(result) |       if(result) | ||||||
|         return result; |         return result; | ||||||
|   | |||||||
							
								
								
									
										84
									
								
								lib/easy.c
									
									
									
									
									
								
							
							
						
						
									
										84
									
								
								lib/easy.c
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2007, 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 | ||||||
| @@ -40,7 +40,7 @@ | |||||||
|  |  | ||||||
| #include "strequal.h" | #include "strequal.h" | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__) | #ifdef WIN32 | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #include <io.h> | #include <io.h> | ||||||
| #else | #else | ||||||
| @@ -48,7 +48,9 @@ | |||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|  | #endif | ||||||
| #ifdef HAVE_UNISTD_H | #ifdef HAVE_UNISTD_H | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #endif | #endif | ||||||
| @@ -85,6 +87,7 @@ | |||||||
| #include "progress.h" | #include "progress.h" | ||||||
| #include "easyif.h" | #include "easyif.h" | ||||||
| #include "sendf.h" /* for failf function prototype */ | #include "sendf.h" /* for failf function prototype */ | ||||||
|  | #include <ca-bundle.h> | ||||||
|  |  | ||||||
| #define _MPRINTF_REPLACE /* use our functions only */ | #define _MPRINTF_REPLACE /* use our functions only */ | ||||||
| #include <curl/mprintf.h> | #include <curl/mprintf.h> | ||||||
| @@ -104,7 +107,7 @@ | |||||||
| /* The last #include file should be: */ | /* The last #include file should be: */ | ||||||
| #include "memdebug.h" | #include "memdebug.h" | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__) | #ifdef USE_WINSOCK | ||||||
| /* win32_cleanup() is for win32 socket cleanup functionality, the opposite | /* win32_cleanup() is for win32 socket cleanup functionality, the opposite | ||||||
|    of win32_init() */ |    of win32_init() */ | ||||||
| static void win32_cleanup(void) | static void win32_cleanup(void) | ||||||
| @@ -120,12 +123,12 @@ static CURLcode win32_init(void) | |||||||
|   WSADATA wsaData; |   WSADATA wsaData; | ||||||
|   int err; |   int err; | ||||||
|  |  | ||||||
| #ifdef ENABLE_IPV6 | #if defined(ENABLE_IPV6) && (USE_WINSOCK < 2) | ||||||
|   wVersionRequested = MAKEWORD(2, 0); |   Error IPV6_requires_winsock2 | ||||||
| #else |  | ||||||
|   wVersionRequested = MAKEWORD(1, 1); |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |   wVersionRequested = MAKEWORD(USE_WINSOCK, USE_WINSOCK); | ||||||
|  |  | ||||||
|   err = WSAStartup(wVersionRequested, &wsaData); |   err = WSAStartup(wVersionRequested, &wsaData); | ||||||
|  |  | ||||||
|   if (err != 0) |   if (err != 0) | ||||||
| @@ -467,6 +470,13 @@ CURLcode curl_easy_perform(CURL *curl) | |||||||
|  |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   if(!data->state.connc) { | ||||||
|  |     /* oops, no connection cache, make one up */ | ||||||
|  |     data->state.connc = Curl_mk_connc(CONNCACHE_PRIVATE, -1); | ||||||
|  |     if(!data->state.connc) | ||||||
|  |       return CURLE_OUT_OF_MEMORY; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   return Curl_perform(data); |   return Curl_perform(data); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| @@ -494,6 +504,13 @@ void Curl_easy_addmulti(struct SessionHandle *data, | |||||||
|   data->multi = multi; |   data->multi = multi; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void Curl_easy_initHandleData(struct SessionHandle *data) | ||||||
|  | { | ||||||
|  |     memset(&data->reqdata, 0, sizeof(struct HandleData)); | ||||||
|  |  | ||||||
|  |     data->reqdata.maxdownload = -1; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * curl_easy_getinfo() is an external interface that allows an app to retrieve |  * curl_easy_getinfo() is an external interface that allows an app to retrieve | ||||||
|  * information from a performed transfer and similar. |  * information from a performed transfer and similar. | ||||||
| @@ -541,16 +558,14 @@ CURL *curl_easy_duphandle(CURL *incurl) | |||||||
|  |  | ||||||
|     /* copy all userdefined values */ |     /* copy all userdefined values */ | ||||||
|     outcurl->set = data->set; |     outcurl->set = data->set; | ||||||
|     outcurl->state.numconnects = data->state.numconnects; |  | ||||||
|     outcurl->state.connects = (struct connectdata **) |  | ||||||
|       malloc(sizeof(struct connectdata *) * outcurl->state.numconnects); |  | ||||||
|  |  | ||||||
|     if(!outcurl->state.connects) { |     if(data->state.used_interface == Curl_if_multi) | ||||||
|  |       outcurl->state.connc = data->state.connc; | ||||||
|  |     else | ||||||
|  |       outcurl->state.connc = Curl_mk_connc(CONNCACHE_PRIVATE, -1); | ||||||
|  |  | ||||||
|  |     if(!outcurl->state.connc) | ||||||
|       break; |       break; | ||||||
|     } |  | ||||||
|  |  | ||||||
|     memset(outcurl->state.connects, 0, |  | ||||||
|            sizeof(struct connectdata *)*outcurl->state.numconnects); |  | ||||||
|  |  | ||||||
|     outcurl->state.lastconnect = -1; |     outcurl->state.lastconnect = -1; | ||||||
|  |  | ||||||
| @@ -572,18 +587,14 @@ CURL *curl_easy_duphandle(CURL *incurl) | |||||||
| #endif   /* CURL_DISABLE_HTTP */ | #endif   /* CURL_DISABLE_HTTP */ | ||||||
|  |  | ||||||
|     /* duplicate all values in 'change' */ |     /* duplicate all values in 'change' */ | ||||||
|  |  | ||||||
|     if(data->change.url) { |     if(data->change.url) { | ||||||
|       outcurl->change.url = strdup(data->change.url); |       outcurl->change.url = strdup(data->change.url); | ||||||
|       if(!outcurl->change.url) |       if(!outcurl->change.url) | ||||||
|         break; |         break; | ||||||
|       outcurl->change.url_alloc = TRUE; |       outcurl->change.url_alloc = TRUE; | ||||||
|     } |     } | ||||||
|     if(data->change.proxy) { |  | ||||||
|       outcurl->change.proxy = strdup(data->change.proxy); |  | ||||||
|       if(!outcurl->change.proxy) |  | ||||||
|         break; |  | ||||||
|       outcurl->change.proxy_alloc = TRUE; |  | ||||||
|     } |  | ||||||
|     if(data->change.referer) { |     if(data->change.referer) { | ||||||
|       outcurl->change.referer = strdup(data->change.referer); |       outcurl->change.referer = strdup(data->change.referer); | ||||||
|       if(!outcurl->change.referer) |       if(!outcurl->change.referer) | ||||||
| @@ -597,18 +608,29 @@ CURL *curl_easy_duphandle(CURL *incurl) | |||||||
|       break; |       break; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if defined(CURL_DOES_CONVERSIONS) && defined(HAVE_ICONV) | ||||||
|  |     outcurl->inbound_cd = iconv_open(CURL_ICONV_CODESET_OF_HOST, | ||||||
|  |                                      CURL_ICONV_CODESET_OF_NETWORK); | ||||||
|  |     outcurl->outbound_cd = iconv_open(CURL_ICONV_CODESET_OF_NETWORK, | ||||||
|  |                                       CURL_ICONV_CODESET_OF_HOST); | ||||||
|  |     outcurl->utf8_cd = iconv_open(CURL_ICONV_CODESET_OF_HOST, | ||||||
|  |                                   CURL_ICONV_CODESET_FOR_UTF8); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |     Curl_easy_initHandleData(outcurl); | ||||||
|  |  | ||||||
|  |     outcurl->magic = CURLEASY_MAGIC_NUMBER; | ||||||
|  |  | ||||||
|     fail = FALSE; /* we reach this point and thus we are OK */ |     fail = FALSE; /* we reach this point and thus we are OK */ | ||||||
|  |  | ||||||
|   } while(0); |   } while(0); | ||||||
|  |  | ||||||
|   if(fail) { |   if(fail) { | ||||||
|     if(outcurl) { |     if(outcurl) { | ||||||
|       if(outcurl->state.connects) |       if(outcurl->state.connc->type == CONNCACHE_PRIVATE) | ||||||
|         free(outcurl->state.connects); |         Curl_rm_connc(outcurl->state.connc); | ||||||
|       if(outcurl->state.headerbuff) |       if(outcurl->state.headerbuff) | ||||||
|         free(outcurl->state.headerbuff); |         free(outcurl->state.headerbuff); | ||||||
|       if(outcurl->change.proxy) |  | ||||||
|         free(outcurl->change.proxy); |  | ||||||
|       if(outcurl->change.url) |       if(outcurl->change.url) | ||||||
|         free(outcurl->change.url); |         free(outcurl->change.url); | ||||||
|       if(outcurl->change.referer) |       if(outcurl->change.referer) | ||||||
| @@ -629,12 +651,21 @@ void curl_easy_reset(CURL *curl) | |||||||
| { | { | ||||||
|   struct SessionHandle *data = (struct SessionHandle *)curl; |   struct SessionHandle *data = (struct SessionHandle *)curl; | ||||||
|  |  | ||||||
|  |   Curl_safefree(data->reqdata.pathbuffer); | ||||||
|  |   data->reqdata.pathbuffer=NULL; | ||||||
|  |  | ||||||
|  |   Curl_safefree(data->reqdata.proto.generic); | ||||||
|  |   data->reqdata.proto.generic=NULL; | ||||||
|  |  | ||||||
|   /* zero out UserDefined data: */ |   /* zero out UserDefined data: */ | ||||||
|   memset(&data->set, 0, sizeof(struct UserDefined)); |   memset(&data->set, 0, sizeof(struct UserDefined)); | ||||||
|  |  | ||||||
|   /* zero out Progress data: */ |   /* zero out Progress data: */ | ||||||
|   memset(&data->progress, 0, sizeof(struct Progress)); |   memset(&data->progress, 0, sizeof(struct Progress)); | ||||||
|  |  | ||||||
|  |   /* init Handle data */ | ||||||
|  |   Curl_easy_initHandleData(data); | ||||||
|  |  | ||||||
|   /* The remainder of these calls have been taken from Curl_open() */ |   /* The remainder of these calls have been taken from Curl_open() */ | ||||||
|  |  | ||||||
|   data->set.out = stdout; /* default output to stdout */ |   data->set.out = stdout; /* default output to stdout */ | ||||||
| @@ -680,6 +711,9 @@ void curl_easy_reset(CURL *curl) | |||||||
|   /* This is our prefered CA cert bundle since install time */ |   /* This is our prefered CA cert bundle since install time */ | ||||||
|   data->set.ssl.CAfile = (char *)CURL_CA_BUNDLE; |   data->set.ssl.CAfile = (char *)CURL_CA_BUNDLE; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |   data->set.ssh_auth_types = CURLSSH_AUTH_DEFAULT; /* defaults to any auth | ||||||
|  |                                                       type */ | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef CURL_DOES_CONVERSIONS | #ifdef CURL_DOES_CONVERSIONS | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2006, 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 | ||||||
| @@ -28,6 +28,8 @@ | |||||||
|  */ |  */ | ||||||
| void Curl_easy_addmulti(struct SessionHandle *data, void *multi); | void Curl_easy_addmulti(struct SessionHandle *data, void *multi); | ||||||
|  |  | ||||||
|  | void Curl_easy_initHandleData(struct SessionHandle *data); | ||||||
|  |  | ||||||
| CURLcode Curl_convert_to_network(struct SessionHandle *data, | CURLcode Curl_convert_to_network(struct SessionHandle *data, | ||||||
|                                  char *buffer, size_t length); |                                  char *buffer, size_t length); | ||||||
| CURLcode Curl_convert_from_network(struct SessionHandle *data, | CURLcode Curl_convert_from_network(struct SessionHandle *data, | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user