Compare commits
	
		
			519 Commits
		
	
	
		
			curl-7_12_
			...
			curl-7_12_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 23cf63f550 | ||
|   | 13ee90bbd4 | ||
|   | 754d6c3abd | ||
|   | c6f6e81238 | ||
|   | 7803a1a28a | ||
|   | 3d647b9a98 | ||
|   | 090a7f38be | ||
|   | 8ad47a13e5 | ||
|   | 497cc6bfaf | ||
|   | d5be114c07 | ||
|   | 6e43a4ccce | ||
|   | a07dcfd850 | ||
|   | 321511a5be | ||
|   | c5297b9fd9 | ||
|   | 7e00076586 | ||
|   | 9a8ba19b73 | ||
|   | 41e776f9db | ||
|   | 5c2d4a6bdd | ||
|   | 83b709401c | ||
|   | 3590fffeae | ||
|   | 5e2e87cc8d | ||
|   | b1bdba7db5 | ||
|   | e3d342df96 | ||
|   | ff54a74b4d | ||
|   | ccf65be0a4 | ||
|   | 7dfef13224 | ||
|   | 0b85e53af2 | ||
|   | 26cfb21c00 | ||
|   | b7acdbcb4c | ||
|   | 6e1e9caa32 | ||
|   | f71725de6e | ||
|   | 26fe6da93b | ||
|   | 8d4ac69175 | ||
|   | 4f5a6a33b4 | ||
|   | ec8ee4404b | ||
|   | e47b5d4e6c | ||
|   | 494c40fd98 | ||
|   | d3b414724b | ||
|   | 38181fbc74 | ||
|   | 8847e61fca | ||
|   | 95b84adb9b | ||
|   | b34d161703 | ||
|   | d88b3d3d5d | ||
|   | f2fb9039bd | ||
|   | a28b32aa45 | ||
|   | 1ba47e7af9 | ||
|   | 9359498b06 | ||
|   | 553082e24a | ||
|   | dc28a9c0c1 | ||
|   | 1faef62d59 | ||
|   | 0d0d5e7ee3 | ||
|   | 4f567d0f81 | ||
|   | f23d923fd3 | ||
|   | 10d6d8b2ae | ||
|   | 358e08b95d | ||
|   | e181eda253 | ||
|   | 7d3f5d7ac1 | ||
|   | 37c7a695a2 | ||
|   | 07f107ae20 | ||
|   | 5c14b3be6d | ||
|   | 1dc15ec1bc | ||
|   | 6a9ed44088 | ||
|   | bdb0620529 | ||
|   | be9ea07e87 | ||
|   | 4cf14e9f85 | ||
|   | d02b2c4308 | ||
|   | 1687a9eb94 | ||
|   | 344c6a3725 | ||
|   | f966dad306 | ||
|   | 887f41c062 | ||
|   | 4b1350e467 | ||
|   | 22a0c57746 | ||
|   | fec571f5b0 | ||
|   | 976285ccbc | ||
|   | 9b3b7ad22e | ||
|   | 1b8ac7c6b5 | ||
|   | bd2db87237 | ||
|   | df3ca59116 | ||
|   | 3ca4509ae9 | ||
|   | d531926246 | ||
|   | 357fdb60b6 | ||
|   | b6f855cb9b | ||
|   | b6646310e8 | ||
|   | 070da3c08f | ||
|   | 6b7f6369ec | ||
|   | 309e3ce4f9 | ||
|   | 8a4eb8ed45 | ||
|   | eee70dcf8e | ||
|   | c0c885a1f3 | ||
|   | a7488672bf | ||
|   | c1312cab1f | ||
|   | 8c833d375a | ||
|   | 18f14ae23d | ||
|   | 98adcdd466 | ||
|   | a2bd47c567 | ||
|   | 7b3c308eb0 | ||
|   | 1be1d3cfb8 | ||
|   | b970469df9 | ||
|   | 80a324386b | ||
|   | 163518778c | ||
|   | 7fd1ce4dc3 | ||
|   | c78ee11c41 | ||
|   | 4435e3b269 | ||
|   | b96a0dba90 | ||
|   | 30dfc00a54 | ||
|   | fe5979cfdb | ||
|   | a1f7987ad8 | ||
|   | ac269a8f68 | ||
|   | 35944744f8 | ||
|   | 4b1c0bd1e7 | ||
|   | b7ff86fa2b | ||
|   | 2c27e4ee76 | ||
|   | 6ac9e67bd7 | ||
|   | 8726a6b6ed | ||
|   | 2f26069a41 | ||
|   | d6c155ff47 | ||
|   | 15360e5e51 | ||
|   | e587a56fc0 | ||
|   | 113531432a | ||
|   | bfa74c2649 | ||
|   | 6bb215f56c | ||
|   | 8b37844e5f | ||
|   | 1445e62312 | ||
|   | 4781ff88fd | ||
|   | c28e15c682 | ||
|   | fe0585ec91 | ||
|   | 18c0b49f3d | ||
|   | 5d69c956ee | ||
|   | 93aa22ea08 | ||
|   | b7c6bc20be | ||
|   | 9bb4a95e08 | ||
|   | 0966ddafaa | ||
|   | c073625fb9 | ||
|   | 85dd4bfb8d | ||
|   | 5ae34aa8e1 | ||
|   | 0eb8414750 | ||
|   | 09717d3fc8 | ||
|   | 81a3246a56 | ||
|   | 4c8fbe9abf | ||
|   | c0d448f778 | ||
|   | 16e9a9eaef | ||
|   | 0d7446c134 | ||
|   | a4752673bb | ||
|   | 9a0d5c4ed8 | ||
|   | d85bc18178 | ||
|   | f0e66d8c76 | ||
|   | af114358c8 | ||
|   | ffe17a8197 | ||
|   | 2459e1e268 | ||
|   | a34a4af36a | ||
|   | bf51f05a50 | ||
|   | 5d94ff5974 | ||
|   | 0d4ddfa743 | ||
|   | 56c9899832 | ||
|   | 7b3fba1ad5 | ||
|   | 700e3b685a | ||
|   | 3e1caa6185 | ||
|   | 50eafb7668 | ||
|   | 25559ac02e | ||
|   | 51a87fa652 | ||
|   | b2dad0342f | ||
|   | a5abce7982 | ||
|   | de3f22b288 | ||
|   | be5cc378c8 | ||
|   | 4afc4aed73 | ||
|   | a4e1ac7952 | ||
|   | f84d2b4d36 | ||
|   | b4c7876e4b | ||
|   | 4207ef3d27 | ||
|   | b3572269a4 | ||
|   | 097d449cc1 | ||
|   | 7f44713487 | ||
|   | b7a6b78e0c | ||
|   | 855a9eff76 | ||
|   | 8e34e75100 | ||
|   | 4be60ac155 | ||
|   | 5ec4501b9d | ||
|   | e80f566a14 | ||
|   | 1729918777 | ||
|   | cef290c6b4 | ||
|   | 539e34b5df | ||
|   | 765683403f | ||
|   | cca9fca894 | ||
|   | 2b403db811 | ||
|   | 03e7b7c95f | ||
|   | 1a05a90f1c | ||
|   | dcea109bb5 | ||
|   | d46a573bbe | ||
|   | 7d0d19708a | ||
|   | 09f14efade | ||
|   | 87753cda49 | ||
|   | 66f6f43056 | ||
|   | 86f059dcfb | ||
|   | 5931d43a36 | ||
|   | 8475a0df2f | ||
|   | ccc4c9c02c | ||
|   | 16edb15600 | ||
|   | 9e7534a46e | ||
|   | 737dddaec0 | ||
|   | b5c90c9b05 | ||
|   | c3ecd552f5 | ||
|   | 56f0227c92 | ||
|   | dcb5a4df01 | ||
|   | fd64213c2f | ||
|   | fc2c06754c | ||
|   | 7ec200f4d1 | ||
|   | e53f139925 | ||
|   | 61599ceb7b | ||
|   | 6f8e3f106a | ||
|   | 8fd676f73e | ||
|   | 98a8103a3b | ||
|   | 94043b1150 | ||
|   | 1b02ad5e8a | ||
|   | 4897587615 | ||
|   | 8e2f57c82e | ||
|   | c3323b1902 | ||
|   | 59c063dfd3 | ||
|   | 8c16696f47 | ||
|   | f68950db67 | ||
|   | 710e370c34 | ||
|   | 7bb6d76d14 | ||
|   | 2467f814a8 | ||
|   | a654ef9ee6 | ||
|   | c1688733c1 | ||
|   | cd73a733c7 | ||
|   | 8ef8e949bd | ||
|   | 49111a63e6 | ||
|   | ee4ecf5155 | ||
|   | 3478253e5a | ||
|   | 6ddc59dadf | ||
|   | dc8688b8dc | ||
|   | 865e495188 | ||
|   | d3c0ed007e | ||
|   | 0dc79376e7 | ||
|   | 3ccbed1022 | ||
|   | 377e43fbb9 | ||
|   | 1f2b042b95 | ||
|   | fd49ba6c18 | ||
|   | facfa19cdd | ||
|   | 3347ced899 | ||
|   | 592686bee9 | ||
|   | f471a293ea | ||
|   | c688166066 | ||
|   | 5dcd2710d4 | ||
|   | 16d8383625 | ||
|   | 6b49fd7483 | ||
|   | f10985fc50 | ||
|   | edeac97773 | ||
|   | 40498ffdd0 | ||
|   | fd884a3cd2 | ||
|   | 1887629c5c | ||
|   | d3be5b2725 | ||
|   | 2e973684c0 | ||
|   | ab909fc4c2 | ||
|   | 4cd5220d27 | ||
|   | 24d47a6e07 | ||
|   | 8a66584db4 | ||
|   | 186f433e40 | ||
|   | 736a40fec9 | ||
|   | 4245400ae4 | ||
|   | 629bba6b35 | ||
|   | f6f2a9e4be | ||
|   | 8bfcae65ef | ||
|   | 96cf615e9d | ||
|   | e9b3e1d031 | ||
|   | 7167cde020 | ||
|   | 2a80a4c521 | ||
|   | 83f11b1c9b | ||
|   | a00e7f0f5e | ||
|   | e1607f5705 | ||
|   | cce931f27d | ||
|   | 34089c93bb | ||
|   | beb61ef429 | ||
|   | 72aff74798 | ||
|   | 8e715af480 | ||
|   | 2730842559 | ||
|   | cac269cf91 | ||
|   | 249036ada0 | ||
|   | 18d80b9e8f | ||
|   | b2d8e0b476 | ||
|   | 225a652021 | ||
|   | 38b1d96750 | ||
|   | 2f069ad3e2 | ||
|   | a3dbe03e80 | ||
|   | f4bef25b5e | ||
|   | ebf7d22503 | ||
|   | 9296d9deb8 | ||
|   | 7b95a25adc | ||
|   | 82d6cfa7fc | ||
|   | 48750d5fc7 | ||
|   | 4f0258ec09 | ||
|   | db4d0d307a | ||
|   | 2baf22e184 | ||
|   | 21d5aead47 | ||
|   | f40c9b83df | ||
|   | b9e082b811 | ||
|   | 0bfa601a9f | ||
|   | e356420123 | ||
|   | e8f85cba0f | ||
|   | 1aba99b1e7 | ||
|   | 12815d7cd6 | ||
|   | 9deb76ce3e | ||
|   | c98676068e | ||
|   | b534f74bf4 | ||
|   | 411e9b0c45 | ||
|   | 3fa1879f6a | ||
|   | d30cf22c12 | ||
|   | 557b6cfd3f | ||
|   | 84bf03b365 | ||
|   | 34342bcd19 | ||
|   | 5322a86313 | ||
|   | 1dc50e21c4 | ||
|   | 1eddbb1b47 | ||
|   | bb8591cf54 | ||
|   | a7913a62a9 | ||
|   | 6d1b37b3da | ||
|   | 34750cc738 | ||
|   | af677c4e1d | ||
|   | 298076e00f | ||
|   | 0d2cdd9773 | ||
|   | eb5d3b5a7c | ||
|   | 7663775971 | ||
|   | fe46572f2b | ||
|   | a6d4d3eeac | ||
|   | 62f97f1817 | ||
|   | 253ff7b2ad | ||
|   | c274e51654 | ||
|   | 1239e48304 | ||
|   | 52313cbac9 | ||
|   | 071218a201 | ||
|   | f0d6cc23ae | ||
|   | ceefe2e248 | ||
|   | 9a2aed7d7a | ||
|   | a91a75355d | ||
|   | 01acbfa1a5 | ||
|   | 49b2896a3b | ||
|   | 39af394a1c | ||
|   | 5c7dcc6c33 | ||
|   | 6c5ea2af27 | ||
|   | 93e084e097 | ||
|   | 1a61bcecfc | ||
|   | 3d9fb701e2 | ||
|   | 19a568a983 | ||
|   | 70c3f6a8dd | ||
|   | bb999d8213 | ||
|   | 121197bc87 | ||
|   | d5dd8e0fdc | ||
|   | c368800877 | ||
|   | 6eb58549a9 | ||
|   | 95def48071 | ||
|   | 2ee6c33412 | ||
|   | be7ce435c0 | ||
|   | f4252f8672 | ||
|   | f4f961c4ea | ||
|   | e2fe03df8e | ||
|   | 19b284c214 | ||
|   | 6b3e3095ea | ||
|   | fd2aad1d9b | ||
|   | d239fc5d04 | ||
|   | ec4da97a35 | ||
|   | bb48ccedd7 | ||
|   | afc0dfb141 | ||
|   | 8e87223195 | ||
|   | be1cece69b | ||
|   | 45be6d6645 | ||
|   | d4db35c125 | ||
|   | 94c6a5eeab | ||
|   | 35292e794a | ||
|   | c2043a7f94 | ||
|   | e752588e8d | ||
|   | 8f30dbd4f0 | ||
|   | 29eb80dbd1 | ||
|   | 6cf6f9a21e | ||
|   | 6af6a2bbe8 | ||
|   | 2576ac1c76 | ||
|   | bfeea8e6b7 | ||
|   | 2f89f2311c | ||
|   | 75e5967afd | ||
|   | 1003628103 | ||
|   | 3451e888b9 | ||
|   | 12dc142a28 | ||
|   | cb80670885 | ||
|   | c189687188 | ||
|   | 595016d393 | ||
|   | 23550fe5de | ||
|   | 8420de971f | ||
|   | 17f8f32b2e | ||
|   | 7676f40218 | ||
|   | 2de62cb06f | ||
|   | be1df3ca0a | ||
|   | 543ab6f331 | ||
|   | 2b6f7ef2a9 | ||
|   | 0d37f8564e | ||
|   | 6cd2536048 | ||
|   | 60fccf4e37 | ||
|   | 8a8028394f | ||
|   | 6a06667cc0 | ||
|   | 25bf23105d | ||
|   | 2544c78083 | ||
|   | 40b9b6f6dc | ||
|   | f5e1beddf1 | ||
|   | d4076c9a8a | ||
|   | 106695d45e | ||
|   | f71b3f48a1 | ||
|   | aa8dd932c1 | ||
|   | adbe3eefb6 | ||
|   | 33f69c0546 | ||
|   | 6c3a87a599 | ||
|   | 13cc010e38 | ||
|   | e99bf99829 | ||
|   | 2e7dcc1e2a | ||
|   | b85a036e4a | ||
|   | 7885264b29 | ||
|   | 73dd450147 | ||
|   | 96efa990f9 | ||
|   | 4e0aee9408 | ||
|   | 27d509cfe9 | ||
|   | ade8e47a8c | ||
|   | ca52c963c7 | ||
|   | 17acdb5acf | ||
|   | f6433211ae | ||
|   | 0ec4c66fba | ||
|   | 1faa9d6fd5 | ||
|   | 23d64e720d | ||
|   | b8b56248bd | ||
|   | 33929117f9 | ||
|   | 2b1673c9c8 | ||
|   | 702f549a6a | ||
|   | 428741d7cf | ||
|   | 6fa624cf8c | ||
|   | 5f60188b8a | ||
|   | 75a6fdeb58 | ||
|   | 5f3fa92062 | ||
|   | 66077ae48b | ||
|   | 92637303db | ||
|   | 811dfd710b | ||
|   | b08dc2cadb | ||
|   | f7c5a097e3 | ||
|   | 5eb3102cd1 | ||
|   | 05825a8a9f | ||
|   | 24353c4372 | ||
|   | e89ea07626 | ||
|   | b99c95ba46 | ||
|   | 9432bfe90c | ||
|   | 37bf6da9c8 | ||
|   | b3ebbd60a2 | ||
|   | e942394bdb | ||
|   | 4adfcd4fd7 | ||
|   | c10196afc0 | ||
|   | 49746d1dce | ||
|   | d46e235c2a | ||
|   | ee44677d7e | ||
|   | 20057aee2e | ||
|   | 7119679080 | ||
|   | d869b51a57 | ||
|   | dbacc81af7 | ||
|   | b233c13dca | ||
|   | 464be27479 | ||
|   | d736ac51c0 | ||
|   | e8b295ff7d | ||
|   | 4a4490d5f1 | ||
|   | 46313be2f5 | ||
|   | 723bfe42e7 | ||
|   | e35c7dcd72 | ||
|   | fa83a0573e | ||
|   | 7b97371ab1 | ||
|   | b17e32baa7 | ||
|   | cd52b9f0da | ||
|   | c3d74ffe48 | ||
|   | a231a96841 | ||
|   | 93b61bf0d3 | ||
|   | 06d39bd303 | ||
|   | 52177b1f60 | ||
|   | 566f7b5e58 | ||
|   | c8c47768c7 | ||
|   | 62ff567c47 | ||
|   | ee400f9552 | ||
|   | 9ac7629e2c | ||
|   | d72ca96a43 | ||
|   | d0dcb3b554 | ||
|   | e139e49826 | ||
|   | 3838745fdb | ||
|   | 06a5c70f4d | ||
|   | 62af3fb7b9 | ||
|   | db302a1055 | ||
|   | 847c91e568 | ||
|   | 2646af106b | ||
|   | 7261b4556b | ||
|   | 071e3cf007 | ||
|   | 164184b484 | ||
|   | 8b6e87abee | ||
|   | 45197b188e | ||
|   | 559553b169 | ||
|   | 84ec4068de | ||
|   | aea87be19e | ||
|   | 9f14744d16 | ||
|   | 1dc8c1dbc8 | ||
|   | e9812c53cb | ||
|   | ed98565963 | ||
|   | 1d3233612a | ||
|   | 8362a34cef | ||
|   | edd16d978f | ||
|   | 4356356305 | ||
|   | cb88135220 | ||
|   | 498a0fe795 | ||
|   | 0ca1b6afcf | ||
|   | d3c9f3d6f8 | ||
|   | df59ca1a45 | ||
|   | 9d84442409 | ||
|   | 5ab9d72e45 | ||
|   | 6060e7ed96 | ||
|   | 7ca7f7a725 | ||
|   | 355b3d3057 | ||
|   | d5bdf5f89c | ||
|   | 17de7e0f1c | ||
|   | 2cea484428 | ||
|   | fb3e19ae50 | ||
|   | 99db7fb222 | ||
|   | 49d0272627 | 
							
								
								
									
										587
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										587
									
								
								CHANGES
									
									
									
									
									
								
							| @@ -6,6 +6,593 @@ | |||||||
|  |  | ||||||
|                                   Changelog |                                   Changelog | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Version 7.12.3 (20 December 2004) | ||||||
|  |  | ||||||
|  | Daniel (19 December 2004) | ||||||
|  | - I investigated our PKCS12 build problem on Solaris 2.7 with OpenSSL 0.9.7e, | ||||||
|  |   and it turned out to be the fault of the zlib 1.1.4 headers doing a typedef | ||||||
|  |   named 'free_func' and the OpenSSL headers have a prototype that uses | ||||||
|  |   'free_func' in one of its arguments. This is why the compile errors out. | ||||||
|  |  | ||||||
|  |   In other words, we need to include the openssl/pkcs12.h header before the | ||||||
|  |   zlib.h header and it builds fine. The configure script now checks for this | ||||||
|  |   file and it then gets included early in lib/urldata.h. | ||||||
|  |  | ||||||
|  | Daniel (18 December 2004) | ||||||
|  | - Samuel Listopad added support for PKCS12 formatted certificates. | ||||||
|  |  | ||||||
|  | - Samuel Listopad fixed -E to support "C:/path" (with forward slash) as well. | ||||||
|  |    | ||||||
|  | Daniel (16 December 2004) | ||||||
|  | - Gisle found and fixed a problem in the directory re-use for FTP. | ||||||
|  |  | ||||||
|  |   I added test case 215 and 216 to better verify the functionality. | ||||||
|  |  | ||||||
|  | - Dinar in bug report #1086121, found a file handle leak when a multipart | ||||||
|  |   formpost (including a file upload part) was aborted before the whole file | ||||||
|  |   was sent. | ||||||
|  |  | ||||||
|  | Daniel (15 December 2004) | ||||||
|  | - Tom Lee found out that globbing of strings with backslashes didn't work as | ||||||
|  |   you'd expect. Backslashes are such a central part of windows file names that | ||||||
|  |   forcing backslashes to have to be escaped with backslashes is a bit too | ||||||
|  |   awkward to users. Starting now, you only need to escape globbing characters | ||||||
|  |   such as the five letters: "[]{},". Added test case 214 to verify this. | ||||||
|  |  | ||||||
|  | Daniel (14 December 2004) | ||||||
|  | - Harshal Pradhan patched a HTTP persistent connection flaw: if the user name | ||||||
|  |   and/or password were modified between two requests on a persistent | ||||||
|  |   connection, the second request were still made with the first setup! | ||||||
|  |  | ||||||
|  |   I added test case 519 to verify the fix. | ||||||
|  |  | ||||||
|  | Daniel (13 December 2004) | ||||||
|  | - Gisle added CURLINFO_SSL_ENGINES to curl_easy_getinfo() to allow an app | ||||||
|  |   to list all available crypto ENGINES. | ||||||
|  |  | ||||||
|  | - Gisle fixed bug report #1083542, which pointed out a problem with resuming | ||||||
|  |   large file (>4GB) file:// transfers on windows. | ||||||
|  |  | ||||||
|  | Daniel (11 December 2004) | ||||||
|  | - Made the test suite HTTP server (sws) capable of using IPv6, and then | ||||||
|  |   extended the test environment to support that and also added three test | ||||||
|  |   cases (240, 241, 242) that run tests using IPv6. Test 242 uses a URL that | ||||||
|  |   didn't work before the 10 dec fix by Kai Sommerfeld. | ||||||
|  |  | ||||||
|  | - Made a failed file:// resume output an error message | ||||||
|  |  | ||||||
|  | - Corrected the CURLE_BAD_DOWNLOAD_RESUME error message in lib/strerror.c | ||||||
|  |  | ||||||
|  | - Dan Fandrich: | ||||||
|  |  | ||||||
|  |   simplified and consolidated the SSL checks in configure and the usage of the | ||||||
|  |   defines in lib/setup.h | ||||||
|  |  | ||||||
|  |   provided a first libcurl.pc.in file for pkg-config (but the result is not | ||||||
|  |   installed anywhere at this point) | ||||||
|  |  | ||||||
|  |   extended the cross compile section in the docs/INSTALL file | ||||||
|  |  | ||||||
|  | Daniel (10 December 2004) | ||||||
|  | - When providing user name in the URL and a IPv6-style IP-address (like in | ||||||
|  |   "ftp://user@[::1]/tmp"), the URL parser didn't get the host extracted | ||||||
|  |   properly.  Reported and fixed by Kai Sommerfeld. | ||||||
|  |  | ||||||
|  | Daniel (9 December 2004) | ||||||
|  | - Ton Voon provided a configure fix that should fix the notorious (mostly | ||||||
|  |   reported on Solaris) problem where the size_t check fails due to the SSL | ||||||
|  |   libs being found in a dir not searched through by the run-time linker. | ||||||
|  |   patch-tracker entry #1081707. | ||||||
|  |  | ||||||
|  | - Bryan Henderson pointed out in bug report #1081788 that the curl-config | ||||||
|  |   --vernum output wasn't zero prefixed properly (as claimed in documentation). | ||||||
|  |   This is fixed in maketgz now. | ||||||
|  |    | ||||||
|  | Daniel (8 December 2004) | ||||||
|  | - Matt Veenstra updated the mach-O framework files for Mac OS X. | ||||||
|  |  | ||||||
|  | - Rene Bernhardt found and fixed a buffer overrun in the NTLM code, where | ||||||
|  |   libcurl always and unconditionally overwrote a stack-based array with 3 zero | ||||||
|  |   bytes. This is not an exploitable buffer overflow. No need to get alarmed. | ||||||
|  |  | ||||||
|  | Daniel (7 December 2004) | ||||||
|  | - Fixed so that the final error message is sent to the verbose info "stream" | ||||||
|  |   even if no errorbuffer is set. | ||||||
|  |  | ||||||
|  | Daniel (6 December 2004) | ||||||
|  | - Dan Fandrich added the --disable-cookies option to configure to build | ||||||
|  |   libcurl without cookie support. This is mainly useful if you want to build a | ||||||
|  |   minimalistic libcurl with no cookies support at all. Like for embedded | ||||||
|  |   systems or similar. | ||||||
|  |  | ||||||
|  | - Richard Atterer fixed libcurl's way of dealing with the EPSV | ||||||
|  |   response. Previously, libcurl would re-resolve the host name with the new | ||||||
|  |   port number and attempt to connect to that, while it should use the IP from | ||||||
|  |   the control channel. This bug made it hard to EPSV from an FTP server with | ||||||
|  |   multiple IP addresses! | ||||||
|  |  | ||||||
|  | Daniel (3 December 2004) | ||||||
|  | - Bug report #1078066: when a chunked transfer was pre-maturely closed exactly | ||||||
|  |   at a chunk boundary it was not considered an error and thus went unnoticed. | ||||||
|  |   Fixed by Maurice Barnum. | ||||||
|  |  | ||||||
|  |   Added test case 207 to verify. | ||||||
|  |  | ||||||
|  | Daniel (2 December 2004) | ||||||
|  | - Fixed the CONNECT loop to default timeout to 3600 seconds. | ||||||
|  |  | ||||||
|  |   Added test case 206 that makes CONNECT with Digest. | ||||||
|  |  | ||||||
|  |   Fixed a flaw that prepended "(nil)" to the initial CONNECT rqeuest's user- | ||||||
|  |   agent field. | ||||||
|  |  | ||||||
|  | Daniel (30 November 2004) | ||||||
|  | - Dan Fandrich's fix for libz 1.1 and "extra field" usage in a gzip stream | ||||||
|  |  | ||||||
|  | - Dan also helped me with input data to create three more test cases for the | ||||||
|  |   --compressed option. | ||||||
|  |  | ||||||
|  | Daniel (29 November 2004) | ||||||
|  | - I improved the test suite to enable binary contents in the tests (by proving | ||||||
|  |   it base64 encoded), like for testing decompress etc. Added test 220 and 221 | ||||||
|  |   for this purpose. Tests can now also depend on libz to run. | ||||||
|  |  | ||||||
|  | - As reported by Reinout van Schouwen in Mandrake's bug tracker bug 12285 | ||||||
|  |   (http://qa.mandrakesoft.com/show_bug.cgi?id=12285), when connecting to an | ||||||
|  |   IPv6 host with FTP, --disable-epsv (or --disable-eprt) effectively disables | ||||||
|  |   the ability to transfer a file. Now, when connected to an FTP server with | ||||||
|  |   IPv6, these FTP commands can't be disabled even if asked to with the | ||||||
|  |   available libcurl options. | ||||||
|  |  | ||||||
|  | Daniel (26 November 2004) | ||||||
|  | - As reported in Mandrake's bug tracker bug 12289 | ||||||
|  |   (http://qa.mandrakesoft.com/show_bug.cgi?id=12289), curl would print a | ||||||
|  |   newline to "finish" the progress meter after each redirect and not only | ||||||
|  |   after a completed transfer. | ||||||
|  |  | ||||||
|  | Daniel (25 November 2004) | ||||||
|  | - FTP improvements: | ||||||
|  |  | ||||||
|  |   If EPSV, EPRT or LPRT is tried and doesn't work, it will not be retried on | ||||||
|  |   the same server again even if a following request is made using a persistent | ||||||
|  |   connection. | ||||||
|  |  | ||||||
|  |   If a second request is made to a server, requesting a file from the same | ||||||
|  |   directory as the previous request operated on, libcurl will no longer make | ||||||
|  |   that long series of CWD commands just to end up on the same spot. Note that | ||||||
|  |   this is only for *exactly* the same dir. There is still room for improvements | ||||||
|  |   to optimize the CWD-sending when the dirs are only slightly different. | ||||||
|  |  | ||||||
|  |   Added test 210, 211 and 212 to verify these changes. Had to improve the | ||||||
|  |   test script too and added a new primitive to the test file format. | ||||||
|  |  | ||||||
|  | Daniel (24 November 2004) | ||||||
|  | - Andr<64>s Garc<72>a fixed the configure script to detect select properly when run | ||||||
|  |   with Msys/Mingw on Windows. | ||||||
|  |  | ||||||
|  | Daniel (22 November 2004) | ||||||
|  | - Made HTTP PUT and POST requests no longer use HEAD when doing multi-pass | ||||||
|  |   auth negotiation (NTLM, Digest and Negotiate), but instead use the request | ||||||
|  |   keyword "properly". Details in lib/README.httpauth. This also introduces | ||||||
|  |   CURLOPT_IOCTLFUNCTION and CURLOPT_IOCTLDATA, to be used by apps that use the | ||||||
|  |   "any" auth alternative as then libcurl may need to send the PUT/POST data | ||||||
|  |   more than once and thus may need to ask the app to "rewind" the read data | ||||||
|  |   stream to start. | ||||||
|  |  | ||||||
|  |   See also the new example using this: docs/examples/anyauthput.c | ||||||
|  |  | ||||||
|  | - David Phillips enhanced test 518. I made it depend on a "feature" so that | ||||||
|  |   systems without getrlimit() won't attempt to test 518. configure now checks | ||||||
|  |   for getrlimit() and setrlimit() for this test case. | ||||||
|  |  | ||||||
|  | Daniel (18 November 2004) | ||||||
|  | - David Phillips fixed libcurl to not crash anymore when more than FD_SETSIZE | ||||||
|  |   file descriptors are in use. Test case 518 added to verify. | ||||||
|  |  | ||||||
|  | Daniel (15 November 2004) | ||||||
|  | - To test my fix for the CURLINFO_REDIRECT_TIME bug, I added time_redirect and | ||||||
|  |   num_redirects support to the -w writeout option for the command line tool. | ||||||
|  |  | ||||||
|  | - Wojciech Zwiefka found out that CURLINFO_REDIRECT_TIME didn't work as | ||||||
|  |   documented. | ||||||
|  |    | ||||||
|  | Daniel (12 November 2004) | ||||||
|  | - Gisle Vanem modigied the MSVC and Netware makefiles to build without | ||||||
|  |   libcurl.def | ||||||
|  |  | ||||||
|  | - Dan Fandrich added the --disable-crypto-auth option to configure to allow | ||||||
|  |   libcurl to build without Digest support. (I figure it should also explicitly | ||||||
|  |   disable Negotiate and NTLM.) | ||||||
|  |  | ||||||
|  | -                 *** Modified Behaviour Alert *** | ||||||
|  |  | ||||||
|  |   Setting CURLOPT_POSTFIELDS to NULL will no longer do a GET. | ||||||
|  |  | ||||||
|  |   Setting CURLOPT_POSTFIELDS to "" will send a zero byte POST and setting | ||||||
|  |   CURLOPT_POSTFIELDS to NULL and CURLOPT_POSTFIELDSIZE to zero will also make | ||||||
|  |   a zero byte POST. Added test case 515 to verify this. | ||||||
|  |  | ||||||
|  |   Setting CURLOPT_HTTPPOST to NULL makes a zero byte post. Added test case 516 | ||||||
|  |   to verify this. | ||||||
|  |  | ||||||
|  |   CURLOPT_POSTFIELDSIZE must now be set to -1 to signal "we don't know". | ||||||
|  |   Setting it to zero simply says this is a zero byte POST. | ||||||
|  |  | ||||||
|  |   When providing POST data with a read callback, setting the size up front | ||||||
|  |   is now made with CURLOPT_POSTFIELDSIZE and not with CURLOPT_INFILESIZE. | ||||||
|  |  | ||||||
|  | Daniel (11 November 2004) | ||||||
|  | - Dan Fandrich added --disable-verbose to the configure script to allow builds | ||||||
|  |   without verbose strings in the code, to save some 12KB space. Makes sense | ||||||
|  |   only for systems with very little memory resources. | ||||||
|  |  | ||||||
|  | - Jeff Phillips found out that a date string with a year beyond 2038 could | ||||||
|  |   crash the new date parser on systems with 32bit time_t. We now check for | ||||||
|  |   this case and deal with it. | ||||||
|  |  | ||||||
|  | Daniel (10 November 2004) | ||||||
|  | - I installed Heimdal on my Debian box (using the debian package) and noticed | ||||||
|  |   that configure --with-gssapi failed to create a nice build. Fixed now. | ||||||
|  |  | ||||||
|  | Daniel (9 November 2004) | ||||||
|  | - Gisle Vanem marked all external function calls with CURL_EXTERN so that now | ||||||
|  |   the Windows, Netware and other builds no longer need libcurl.def or similar | ||||||
|  |   files. | ||||||
|  |  | ||||||
|  | Daniel (8 November 2004) | ||||||
|  | - Made the configure script check for tld.h if libidn was detected, since | ||||||
|  |   libidn 0.3.X didn't have such a header and we don't work with anything | ||||||
|  |   before libidn 0.4.1 anyway! Suse 9.1 apparently ships with a 0.3.X version | ||||||
|  |   of libidn which makes the curl 7.12.2 build fail. Jean-Philippe | ||||||
|  |   Barrette-LaPierre helped pointing this out. | ||||||
|  |  | ||||||
|  | - Ian Gulliver reported in debian bug report #278691: if curl is invoked in an | ||||||
|  |   environment where stderr is closed the -v output will still be sent to file | ||||||
|  |   descriptor 2 which then might be the network socket handle! Now we have a | ||||||
|  |   weird hack instead that attempts to make sure that file descriptor 2 is | ||||||
|  |   opened (with a call to pipe()) before libcurl is called to do the transfer. | ||||||
|  |   configure now checks for pipe() and systems without pipe don't get the weird | ||||||
|  |   hack done. | ||||||
|  |  | ||||||
|  | Daniel (5 November 2004) | ||||||
|  | - Tim Sneddon made libcurl send no more than 64K in a single first chunk when | ||||||
|  |   doing a huge POST on VMS, as this is a system limitation. Default on general | ||||||
|  |   systems is 100K. | ||||||
|  |  | ||||||
|  | Daniel (4 November 2004) | ||||||
|  | - Andres Garcia made it build on mingw againa, my --retry code broke the build. | ||||||
|  |  | ||||||
|  | Daniel (2 November 2004) | ||||||
|  | - Added --retry-max-time that allows a maximum time that may not have been | ||||||
|  |   reached for a retry to be made. If not set there is no maximum time, only | ||||||
|  |   the amount of retries set with --retry. | ||||||
|  |  | ||||||
|  | - Paul Nolan provided a patch to make libcurl build nicely on Windows CE. | ||||||
|  |  | ||||||
|  | Daniel (1 November 2004) | ||||||
|  | - When cross-compiling, the configure script no longer attempts to use | ||||||
|  |   pkg-config on the build host in order to detect OpenSSL compiler options. | ||||||
|  |  | ||||||
|  | Daniel (27 October 2004) | ||||||
|  | - Dan Fandrich: | ||||||
|  |  | ||||||
|  |   An improvement to the gzip handling of libcurl. There were two problems with | ||||||
|  |   the old version: it was possible for a malicious gzip file to cause libcurl | ||||||
|  |   to leak memory, as a buffer was malloced to hold the header and never freed | ||||||
|  |   if the header ended with no file contents.  The second problem is that the | ||||||
|  |   64 KiB decompression buffer was allocated on the stack, which caused | ||||||
|  |   unexpectedly high stack usage and overflowed the stack on some systems | ||||||
|  |   (someone complained about that in the mailing list about a year ago). | ||||||
|  |  | ||||||
|  |   Both problems are fixed by this patch. The first one is fixed when a recent | ||||||
|  |   (1.2) version of zlib is used, as it takes care of gzip header parsing | ||||||
|  |   itself.  A check for the version number is done at run-time and libcurl uses | ||||||
|  |   that feature if it's present. I've created a define OLD_ZLIB_SUPPORT that | ||||||
|  |   can be commented out to save some code space if libcurl is guaranteed to be | ||||||
|  |   using a 1.2 version of zlib. | ||||||
|  |  | ||||||
|  |   The second problem is solved by dynamically allocating the memory buffer | ||||||
|  |   instead of storing it on the stack. The allocation/free is done for every | ||||||
|  |   incoming packet, which is suboptimal, but should be dwarfed by the actual | ||||||
|  |   decompression computation. | ||||||
|  |   | ||||||
|  |   I've also factored out some common code between deflate and gzip to reduce | ||||||
|  |   the code footprint somewhat.  I've tested the gzip code on a few test files | ||||||
|  |   and I tried deflate using the freshmeat.net server, and it all looks OK. I | ||||||
|  |   didn't try running it with valgrind, however. | ||||||
|  |  | ||||||
|  | - Added a --retry option to curl that takes a numerical option for the number | ||||||
|  |   of times the operation should be retried. It is retried if a transient error | ||||||
|  |   is detected or if a timeout occurred. By default, it will first wait one | ||||||
|  |   second between the retries and then double the delay time between each retry | ||||||
|  |   until the delay time is ten minutes which then will be the delay time | ||||||
|  |   between all forthcoming retries. You can set a static delay time with | ||||||
|  |   "--retry-delay [num]" where [num] is the number of seconds to wait between | ||||||
|  |   each retry. | ||||||
|  |  | ||||||
|  | Daniel (25 October 2004) | ||||||
|  | - Tomas Pospisek filed bug report #1053287 that proved -C - and --fail on a | ||||||
|  |   file that was already completely downloaded caused an error, while it | ||||||
|  |   doesn't if you don't use --fail! I added test case 194 to verify the fix. | ||||||
|  |   Grrr. CURLOPT_FAILONERROR is now added to the list stuff to remove in | ||||||
|  |   libcurl v8 due to all the kludges needed to support it. | ||||||
|  |  | ||||||
|  | - Mohun Biswas found out that formposting a zero-byte file didn't work very | ||||||
|  |   good. I fixed. | ||||||
|  |  | ||||||
|  | Daniel (19 October 2004) | ||||||
|  | - Alexander Krasnostavsky made it possible to make FTP 3rd party transfers | ||||||
|  |   with both source and destination being the same host. It can be useful if | ||||||
|  |   you want to move a file on a server or similar. | ||||||
|  |  | ||||||
|  | - Guillaume Arluison added CURLINFO_NUM_CONNECTS to allow an app to figure | ||||||
|  |   out how many new connects a previous transfer required. | ||||||
|  |  | ||||||
|  |   I added %{num_connects} to the curl tool and added test case 192 and 193 | ||||||
|  |   to verify the new code. | ||||||
|  |  | ||||||
|  | Daniel (18 October 2004) | ||||||
|  | - Peter Wullinger pointed out that curl should call setlocale() properly to | ||||||
|  |   initiate the specific language operations, to make the IDN stuff work | ||||||
|  |   better. | ||||||
|  |  | ||||||
|  | Version 7.12.2 (18 October 2004) | ||||||
|  |  | ||||||
|  | Daniel (16 October 2004) | ||||||
|  | - Alexander Krasnostavsky made the CURLOPT_FTP_CREATE_MISSING_DIRS option work | ||||||
|  |   fine even for third party transfers. | ||||||
|  |  | ||||||
|  | - runekl at opoint.com found out (and provided a fix) that libcurl leaked | ||||||
|  |   memory for cookies with the "max-age" field set. | ||||||
|  |  | ||||||
|  | Gisle (16 October 2004) | ||||||
|  | - Issue 50 in TODO-RELEASE; Added Traian Nicolescu's patches for threaded | ||||||
|  |   resolver on Windows. Plugged some potential handle and memory leaks. | ||||||
|  |  | ||||||
|  | Daniel (14 October 2004) | ||||||
|  | - Eric Vergnaud pointed out that libcurl didn't treat ?-letters in the user | ||||||
|  |   name and password fields properly in URLs, like | ||||||
|  |   ftp://us?er:pass?word@site.com/. Added test 191 to verify the fix. | ||||||
|  |  | ||||||
|  | Daniel (11 October 2004) | ||||||
|  | - libcurl now uses SO_NOSIGPIPE for systems that support it (Mac OS X 10.2 or | ||||||
|  |   later is one) to inhibit the SIGPIPE signal when writing to a socket while | ||||||
|  |   the peer dies. The same effect is provide by the MSG_NOSIGNAL parameter to | ||||||
|  |   send() on other systems. Alan Pinstein verified the fix. | ||||||
|  |  | ||||||
|  | Daniel (10 October 2004) | ||||||
|  | - Systems with 64bit longs no longer use strtoll() or our strtoll- replacement | ||||||
|  |   to parse 64 bit numbers. strtol() works fine. Added a configure check to | ||||||
|  |   detect if [constant]LL works and if so, use that in the strtoll replacement | ||||||
|  |   code to work around compiler warnings reported by Andy Cedilnik. | ||||||
|  |  | ||||||
|  | Gisle (6 October 2004) | ||||||
|  | - For USE_LIBIDN builds: Added Top-Level-Domain (TLD) check of host-name | ||||||
|  |   used in fix_hostname(). Checks if characters in 'host->name' (indirectly | ||||||
|  |   via 'ace_hostname') are legal according to the TLD tables in libidn. | ||||||
|  |  | ||||||
|  | Daniel (6 October 2004) | ||||||
|  | - Chih-Chung Chang reported that if you use CURLOPT_RESUME_FROM and enabled | ||||||
|  |   CURLOPT_FOLLOWLOCATION, libcurl reported error if a redirect happened even | ||||||
|  |   if the new URL would provide the resumed file. Test case 188 added to verify | ||||||
|  |   the fix (together with existing test 99). | ||||||
|  |  | ||||||
|  | - Dan Fandrich fixed a configure flaw for systems that need both nsl and socket | ||||||
|  |   libs to use gethostbyname(). | ||||||
|  |  | ||||||
|  | - Removed tabs and trailing whitespace from lots of source files. | ||||||
|  |  | ||||||
|  | Daniel (5 October 2004) | ||||||
|  | - Made configure --with-libidn=PATH try the given PATH before the default | ||||||
|  |   paths to make it possible to override. | ||||||
|  |  | ||||||
|  | - If idna_strerror() is present in libidn, we can use that instead of our | ||||||
|  |   internal replacement. This function was added by Simon in libidn 0.5.6 and | ||||||
|  |   is detected by configure. | ||||||
|  |  | ||||||
|  | - It seems basename() on IRIX is in the libgen library and since we don't use | ||||||
|  |   that, configure finds libgen.h but not basename and then we get a compiler | ||||||
|  |   error because our basename() replacement doesn't match the proto in | ||||||
|  |   libgen.h. Starting now, we don't include the file if basename wasn't found | ||||||
|  |   as well. | ||||||
|  |  | ||||||
|  | Daniel (4 October 2004) | ||||||
|  | - Chris found a race condition resulting in CURLE_COULDNT_RESOLVE_HOST and | ||||||
|  |   potential crash, in the windows threaded name resolver code. | ||||||
|  |  | ||||||
|  | Daniel (3 October 2004) | ||||||
|  | - Replaced the use of isspace() in cookie.c with our own version instead since | ||||||
|  |   we have most data as 'char *' and that makes us pass in negative values if | ||||||
|  |   there is 8bit data in the string. Changing to unsigned causes too much | ||||||
|  |   warnings or too many required typecasts to the normal string functions. | ||||||
|  |   Harshal Pradhan identified this problem. | ||||||
|  |  | ||||||
|  | Daniel (2 October 2004) | ||||||
|  | - Bertrand Demiddelaer found a case where libcurl could read already freed | ||||||
|  |   data when CURLOPT_VERBOSE is used and a (very) persistent connection. It | ||||||
|  |   happened when the dns cache entry for the connection was pruned while the | ||||||
|  |   connection was still alive and then again re-used. We worked together on | ||||||
|  |   this fix. | ||||||
|  |  | ||||||
|  | - Gisle Vanem provided code that displays an error message when the (libidn | ||||||
|  |   based) IDN conversion fails. This is really due to a missing suitable | ||||||
|  |   function in the libidn API that I hope we can remove once libidn gets a | ||||||
|  |   function like this. | ||||||
|  |  | ||||||
|  | Daniel (1 October 2004) | ||||||
|  | - Aleksandar Milivojevic reported a problem in the Redhat bugzilla (see | ||||||
|  |   https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=134133) and not to | ||||||
|  |   anyone involved in the curl project! This happens when you try to curl a | ||||||
|  |   file from a proftpd site using SSL. It seems proftpd sends a somewhat | ||||||
|  |   unorthodox response code (232 instead of 230). I relaxed the response code | ||||||
|  |   check to deal with this and similar cases. | ||||||
|  |  | ||||||
|  | - Based on Fedor Karpelevitch's formpost path basename patch, file parts in | ||||||
|  |   formposts no longer include the path part. If you _really_ want them, you | ||||||
|  |   must provide your preferred full file name with CURLFORM_FILENAME. | ||||||
|  |  | ||||||
|  |   Added detection for libgen.h and basename() to configure. My custom | ||||||
|  |   basename() replacement function for systems without it, might be a bit too | ||||||
|  |   naive... | ||||||
|  |  | ||||||
|  |   Updated 6 test cases to make them work with the stripped paths. | ||||||
|  |  | ||||||
|  | Daniel (30 September 2004) | ||||||
|  | - Larry Campbell added CURLINFO_OS_ERRNO to curl_easy_getinfo() that allows an | ||||||
|  |   app to retrieve the errno variable after a (connect) failure. It will make | ||||||
|  |   sense to provide this for more failures in a more generic way, but let's | ||||||
|  |   start like this. | ||||||
|  |  | ||||||
|  | - G<>nter Knauf and Casey O'Donnell worked out an extra #if condition for the | ||||||
|  |   curl/multi.h header to work better in winsock-using apps. | ||||||
|  |  | ||||||
|  | - Jean-Philippe Barrette-LaPierre made buildconf run better on Mac OS X by | ||||||
|  |   properly using glibtoolize instead of plain libtoolize. (This is made if | ||||||
|  |   glibtool was found and used instead of plain libtool.) | ||||||
|  |  | ||||||
|  | Daniel (29 September 2004) | ||||||
|  | - Bertrand Demiddelaer fixed curl_easy_reset() so that it doesn't mistakingly | ||||||
|  |   enable the progress meter. | ||||||
|  |  | ||||||
|  | Daniel (28 September 2004) | ||||||
|  | - "Mekonikum" found out that if you built curl without SSL support, although | ||||||
|  |   your current SSL installation supports Engine, the compile fails. | ||||||
|  |  | ||||||
|  | Daniel (27 September 2004) | ||||||
|  | - When --with-ssl=PATH is used to the configure script, it no longer uses | ||||||
|  |   pkg-config to figure out extra details. That is now only done if no PATH is | ||||||
|  |   included or if SSL is checked for by default without the --with-ssl option. | ||||||
|  |  | ||||||
|  | Daniel (25 September 2004) | ||||||
|  | - Peter Sylvester pointed out that CURLOPT_SSLENGINE couldn't even be set to | ||||||
|  |   NULL when no engine was supported. It can now. | ||||||
|  |  | ||||||
|  | Daniel (22 September 2004) | ||||||
|  | - Dan Fandrich fixed three test cases to no longer use "localhost" but instead | ||||||
|  |   use "127.0.0.1" to avoid requiring that localhost resolves nicely. | ||||||
|  |  | ||||||
|  | - Jean-Claude Chauve fixed an LDAP crash when more than one record was | ||||||
|  |   retrieved. | ||||||
|  |  | ||||||
|  | Daniel (19 September 2004) | ||||||
|  | - Andreas Rieke pointed out that when attempting to connect to a host without | ||||||
|  |   a service on the specified port, curl_easy_perform() didn't properly provide | ||||||
|  |   an error message in the CURLOPT_ERRORBUFFER buffer. | ||||||
|  |  | ||||||
|  | Daniel (16 September 2004) | ||||||
|  | - Daniel at touchtunes uses the FTP+SSL server "BSDFTPD-SSL from | ||||||
|  |   http://bsdftpd-ssl.sc.ru/" which accordingly doesn't properly work with curl | ||||||
|  |   when "AUTH SSL" is issued (although the server responds fine and everything) | ||||||
|  |   but requires that curl issues "AUTH TLS" instead. See | ||||||
|  |   http://curl.haxx.se/feedback/display.cgi?id=10951944937603&support=yes | ||||||
|  |  | ||||||
|  |   Introducing CURLOPT_FTPSSLAUTH that allows the application to select which | ||||||
|  |   of the AUTH strings to attempt first. | ||||||
|  |  | ||||||
|  | - Anonymous filed bug report #1029478 which identified a bug when you 1) used | ||||||
|  |   a URL without properly seperating the host name and the parameters with a | ||||||
|  |   slash. 2) the URL had parameters to the right of a ? that contains a slash | ||||||
|  |   3) curl was told to follow Location:s 4) the request got a response that | ||||||
|  |   contained a Location: to redirect to "/dir". curl then appended the new path | ||||||
|  |   on the wrong position of the original URL. | ||||||
|  |  | ||||||
|  |   Test case 187 was added to verify that this was fixed properly. | ||||||
|  |  | ||||||
|  | Daniel (11 September 2004) | ||||||
|  | - Added parsedate.c that contains a rewrite of the date parser currently | ||||||
|  |   provided by getdate.y. The new one is MUCH smaller and will allow us to run | ||||||
|  |   away from the yacc/bison jungle. It is also slightly lacking in features | ||||||
|  |   compared to the old one, but it supports parsing of all date formats HTTP | ||||||
|  |   involves (and a fair bunch of others). | ||||||
|  |  | ||||||
|  | Daniel (10 September 2004) | ||||||
|  | - As found out by Jonas Forsman, curl didn't allow -F to set Content-Type on | ||||||
|  |   text-parts. Starting now, we can do -F "name=daniel;type=text/extra". Added | ||||||
|  |   test case 186 to verify. | ||||||
|  |  | ||||||
|  | - Bug report #1025986. When following a Location: with a custom Host: header | ||||||
|  |   replacement, curl only replaced the Host: header on the initial request | ||||||
|  |   and didn't replace it on the following ones. This resulted in requests with | ||||||
|  |   two Host: headers. | ||||||
|  |  | ||||||
|  |   Now, curl checks if the location is on the same host as the initial request | ||||||
|  |   and then continues to replace the Host: header. And when it moves to another | ||||||
|  |   host, it doesn't replace the Host: header but it also doesn't make the | ||||||
|  |   second Host: header get used in the request. | ||||||
|  |  | ||||||
|  |   This change is verified by the two new test cases 184 and 185. | ||||||
|  |  | ||||||
|  | Daniel (8 September 2004) | ||||||
|  | - Modified the test suite to be able to use and run with customized port | ||||||
|  |   numbers. This was always intended but never before possible. Now a simple | ||||||
|  |   change in the runtests.pl script can make all tests use different ports. | ||||||
|  |   The default ports in use from now on are 8990 to 8993. | ||||||
|  |  | ||||||
|  | Daniel (2 September 2004) | ||||||
|  | - Minor modification of an SSL-related error message. | ||||||
|  |  | ||||||
|  | Daniel (31 August 2004) | ||||||
|  | - David Tarendash found out that curl_multi_add_handle() returned | ||||||
|  |   CURLM_CALL_MULTI_PERFORM instead of CURLM_OK. | ||||||
|  |  | ||||||
|  | Daniel (30 August 2004) | ||||||
|  | - Make "Proxy-Connection: close" close the current proxy connection, as Roman | ||||||
|  |   Koifman found out. | ||||||
|  |  | ||||||
|  | Daniel (24 August 2004) | ||||||
|  | - Fixed a getdate problem by post-replacing the getdate.c file after the | ||||||
|  |   bison/yacc process to add the fix Harshal Pradhan suggested. The problem | ||||||
|  |   caused a crash on Windows when parsing some dates. | ||||||
|  |  | ||||||
|  | Daniel (23 August 2004) | ||||||
|  | - Roman Koifman pointed out that libcurl send Expect: 100-continue on POSTs | ||||||
|  |   even when told to use HTTP 1.0, which is not correct. Test case 180 and | ||||||
|  |   181 verify this. | ||||||
|  |  | ||||||
|  | - Added test case 182 to verify that zero byte transfers call the callback | ||||||
|  |   properly. | ||||||
|  |  | ||||||
|  | Daniel (20 August 2004) | ||||||
|  | - Alexander Krasnostavsky made the write callback get called even when a zero | ||||||
|  |   byte file is downloaded. | ||||||
|  |  | ||||||
|  | Daniel (18 August 2004) | ||||||
|  | - Ling Thio pointed out that when libcurl is built ipv6-enabled, it still did | ||||||
|  |   reverse DNS lookups when fed with a numerical IP-address (like | ||||||
|  |   http://127.0.0.1/), although it doesn't when built ipv6-disabled. libcurl | ||||||
|  |   should never do reverse lookups. | ||||||
|  |  | ||||||
|  | Daniel (17 August 2004) | ||||||
|  | - Kjetil Jacobsen noticed that when transferring a file:// URL pointing to an | ||||||
|  |   empty file, libcurl would return with the file still open. | ||||||
|  |  | ||||||
|  | - Alexander Krasnostavsky pointed out that the configure script needs to define | ||||||
|  |   _THREAD_SAFE for AIX systems to make libcurl built really thread-safe. | ||||||
|  |  | ||||||
|  |   Also added a check for the xlc compiler on AIX, and if that is detect we use | ||||||
|  |   the -qthreaded compiler option | ||||||
|  |  | ||||||
|  | Daniel (16 August 2004) | ||||||
|  | - libcurl now allows a custom "Accept-Encoding:" header override the | ||||||
|  |   internally set one that gets set with CURLOPT_ENCODING. Pointed out by Alex. | ||||||
|  |  | ||||||
|  | - Roland Krikava found and fixed a cookie problem when using a proxy (the | ||||||
|  |   path matching was wrong). I added test case 179 to verify that we now do | ||||||
|  |   right. | ||||||
|  |  | ||||||
|  | Daniel (15 August 2004) | ||||||
|  | - Casey O'Donnell fixed some MSVC makefile targets to link properly. | ||||||
|  |  | ||||||
|  | Daniel (11 August 2004) | ||||||
|  | - configure now defines _XOPEN_SOURCE to 500 on systems that need it to build | ||||||
|  |   warning-free (the only known one so far is non-gcc builds on 64bit SGI | ||||||
|  |   IRIX). (Reverted this change later as it caused compiler errors.) | ||||||
|  |  | ||||||
|  | - the FTP code now includes the server response in the error message when the | ||||||
|  |   server gives back a 530 after the password is provided, as it isn't | ||||||
|  |   necessary because of a bad user name or password. | ||||||
|  |  | ||||||
| Version 7.12.1 (10 August 2004) | Version 7.12.1 (10 August 2004) | ||||||
|  |  | ||||||
| Daniel (10 August 2004) | Daniel (10 August 2004) | ||||||
|   | |||||||
| @@ -24,7 +24,7 @@ | |||||||
| AUTOMAKE_OPTIONS = foreign | AUTOMAKE_OPTIONS = foreign | ||||||
|  |  | ||||||
| EXTRA_DIST = CHANGES COPYING maketgz reconf Makefile.dist curl-config.in \ | EXTRA_DIST = CHANGES COPYING maketgz reconf Makefile.dist curl-config.in \ | ||||||
|  curl-style.el sample.emacs RELEASE-NOTES buildconf buildconf.bat |  curl-style.el sample.emacs RELEASE-NOTES buildconf buildconf.bat libcurl.pc.in | ||||||
|  |  | ||||||
| bin_SCRIPTS = curl-config | bin_SCRIPTS = curl-config | ||||||
|  |  | ||||||
|   | |||||||
| @@ -54,16 +54,16 @@ borland-clean: | |||||||
| 	make -f Makefile.b32 clean | 	make -f Makefile.b32 clean | ||||||
|  |  | ||||||
| mingw32: | mingw32: | ||||||
| 	cd lib & make -f Makefile.m32 ZLIB=1 | 	$(MAKE) -C lib -f Makefile.m32 ZLIB=1 | ||||||
| 	cd src & make -f Makefile.m32 ZLIB=1 | 	$(MAKE) -C src -f Makefile.m32 ZLIB=1 | ||||||
|  |  | ||||||
| mingw32-ssl: | mingw32-ssl: | ||||||
| 	cd lib & make -f Makefile.m32 SSL=1 ZLIB=1 | 	$(MAKE) -C lib -f Makefile.m32 SSL=1 ZLIB=1 | ||||||
| 	cd src & make -f Makefile.m32 SSL=1 ZLIB=1 | 	$(MAKE) -C src -f Makefile.m32 SSL=1 ZLIB=1 | ||||||
|  |  | ||||||
| mingw32-clean: | mingw32-clean: | ||||||
| 	cd lib & make -f Makefile.m32 clean | 	$(MAKE) -C lib -f Makefile.m32 clean | ||||||
| 	cd src & make -f Makefile.m32 clean | 	$(MAKE) -C src -f Makefile.m32 clean | ||||||
|  |  | ||||||
| vc: | vc: | ||||||
| 	cd lib | 	cd lib | ||||||
| @@ -102,8 +102,8 @@ vc-libcurl-ssl-dll: | |||||||
| 	nmake /f Makefile.vc6 | 	nmake /f Makefile.vc6 | ||||||
|  |  | ||||||
| djgpp: | djgpp: | ||||||
| 	make -C lib -f Makefile.dj | 	$(MAKE) -C lib -f Makefile.dj | ||||||
| 	make -C src -f Makefile.dj | 	$(MAKE) -C src -f Makefile.dj | ||||||
|  |  | ||||||
| cygwin: | cygwin: | ||||||
| 	./configure | 	./configure | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								README
									
									
									
									
									
								
							| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| README | README | ||||||
|  |  | ||||||
|   Curl is a command line tool for transfering data specified with URL |   Curl is a command line tool for transferring data specified with URL | ||||||
|   syntax. Find out how to use Curl by reading the curl.1 man page or the |   syntax. Find out how to use Curl by reading the curl.1 man page or the | ||||||
|   MANUAL document. Find out how to install Curl by reading the INSTALL |   MANUAL document. Find out how to install Curl by reading the INSTALL | ||||||
|   document. |   document. | ||||||
|   | |||||||
							
								
								
									
										132
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							
							
						
						
									
										132
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							| @@ -1,83 +1,81 @@ | |||||||
| Curl and libcurl 7.12.1 | Curl and libcurl 7.12.3 | ||||||
|  |  | ||||||
|  Public curl release number:               82 |  Public curl release number:               84 | ||||||
|  Releases counted from the very beginning: 109 |  Releases counted from the very beginning: 111 | ||||||
|  Available command line options:           96 |  Available command line options:           100 | ||||||
|  Available curl_easy_setopt() options:     120 |  Available curl_easy_setopt() options:     123 | ||||||
|  Number of public functions in libcurl:    36 |  Number of public functions in libcurl:    46 | ||||||
|  Amount of public web site mirrors:        12 |  Amount of public web site mirrors:        14 | ||||||
|  Number of known libcurl bindings:         26 |  Number of known libcurl bindings:         29 | ||||||
|  |  | ||||||
| This release includes the following changes: | This release includes the following changes: | ||||||
|  |  | ||||||
|  o the version string now only contains info about (sub) package versions, |  o PKCS12 certificate support added | ||||||
|    while for example krb4 and ipv6 now only are available as 'features' |  o added CURLINFO_SSL_ENGINES (and "--engine list") | ||||||
|  o added curl_easy_reset() |  o new configure options: --disable-cookies, --disable-crypto-auth and | ||||||
|  o socks proxy support even when libcurl is built ipv6-enabled |    --disable-verbose | ||||||
|  o read callbacks can stop the transfer by returning CURL_READFUNC_ABORT |  o persistent ftp request improvements | ||||||
|  o libcurl-tutorial.3 is the new man page formerly known as libcurl-the-guide |  o CURLOPT_IOCTLFUNCTION and CURLOPT_IOCTLDATA added. If your app uses HTTP | ||||||
|  o additional SSL trace data might be sent to the debug callback using two new |    Digest, NTLM or Negotiate authentication, you will most likely want to use | ||||||
|    types: CURLINFO_SSL_DATA_IN and CURLINFO_SSL_DATA_OUT |    these | ||||||
|  o multipart formposts can upload files larger than system memory |  o -w time_redirect and num_redirects | ||||||
|  o the curl tool continues with the next URL even if one transfer fails |  o no longer uses libcurl.def for building on Windows, OS/2 and Netware | ||||||
|  o FTP 3rd party transfer support - seven new setopt() options |  o builds on Windows CE | ||||||
|  |  o request retrying, --retry and family added | ||||||
|  |  o FTP 3rd party transfers with source and dest on the same host now works | ||||||
|  |  o added CURLINFO_NUM_CONNECTS | ||||||
|  |  | ||||||
| This release includes the following bugfixes: | This release includes the following bugfixes: | ||||||
|  |  | ||||||
|  o UTF-8 encoded certificate names can now be verified properly |  o curl -E on windows accepts "c:/path" with forward-slash | ||||||
|  o krb4 link problem |  o several improvements for large file support on windows | ||||||
|  o HTTP Negotiate service name now provided in uppercase |  o file handle leak in aborted multipart formpost file upload | ||||||
|  o no longer accepts any cookies with domain set to just a TLD |  o -T upload multiple files with backslashes in file names | ||||||
|  o HTTP Digest properties without quotes in the header |  o modified credentials between two requests on a persistent http connection | ||||||
|  o bad Host: header case on re-used connections over proxy |  o large file file:// resumes on Windows | ||||||
|  o duplicate Host: header case on re-used connections |  o URLs with username and IPv6 numerical addresses | ||||||
|  o curl -o name#[num] now works when no globbing for [num] exists |  o configure works better with SSL libs in a "non-standard ld.so dir" | ||||||
|  o test suite runs fine with valgrind 2.1.x |  o curl-config --vernum zero prefixed | ||||||
|  o negative Content-Length is ignored |  o bad memory access in the NTLM code | ||||||
|  o test 505 runs fine on windows |  o EPSV on multi-homed servers now works correctly | ||||||
|  o curl_share_cleanup() crash |  o chunked-encoded transfers could get closed pre-maturely without error | ||||||
|  o --trace files now get the final info lines too |  o proxy CONNECT now default timeouts after 3600 seconds | ||||||
|  o multi interface connects fine to multi-IP resolving hosts |  o disabling EPSV or EPRT is ignored when connecting to an IPv6 FTP server | ||||||
|  o --limit-rate works on Mac OS X (and other systems with bad poll()s) |  o no extra progress meter newline output after each Location: followed | ||||||
|  o cookies can now hold 4999 bytes of content |  o HTTP PUT/POST with Digest, NTLM or Negotiate no longer uses HEAD | ||||||
|  o HTTP POST/PUT with NTLM/Digest/Negotiate to a URL returning 3XX |  o works with or gracefully bails out when exceeding FD_SETSIZE file | ||||||
|  o HTTPS POST/PUT over a proxy requiring NTLM/Digest/Negotiate |    descriptors | ||||||
|  o less restrictive libidn requirements, 0.4.1 or later is fine |  o CURLINFO_REDIRECT_TIME works | ||||||
|  o HTTP POST or PUT with Digest/Negotiate/NTLM selected but the server |  o building with gssapi libs and hdeaders in the default dirs | ||||||
|    didn't require any authentication |  o curl_getdate() parsing of dates later than year 2037 with 32 bit time_t | ||||||
|  o win32 file:// transfer free memory bug |  o curl -v when stderr is closed wrote debug messages to the network socket | ||||||
|  o configure --disable-http builds a libcurl without HTTP support |  o build failure with libidn 0.3.X or older | ||||||
|  o CURLOPT_FILETIME had wrong type in curl.h, it expects a long argument |  o huge POSTs on VMS | ||||||
|  o builds fine with Borland on Windows |  o configure no longer uses pkg-config on cross-compiles | ||||||
|  o the msvc curllib.dsp now builds the libcurl.lib file |  o potential gzip decompress memory leak | ||||||
|  o builds fine on VMS |  o "-C - --fail" on a HTTP page already downloaded | ||||||
|  o builds fine on NetWare |  o formposting a zero byte file | ||||||
|  o HTTP Digest authentication with proxies uses correct user name + password |  o use setlocale() for better IDN functionality by default | ||||||
|  o builds fine with lcc-win32 |  | ||||||
|  |  | ||||||
| Other curl-related news since the previous public release: | Other curl-related news since the previous public release: | ||||||
|  |  | ||||||
|  o James Hu took over after Kevin Roth as maintainer of the curl package on |  o pycurl 7.12.2: http://pycurl.sf.net/ | ||||||
|    cygwin. Many saludos to Kevin for a work well done during many years. |  o TclCurl 0.12.2: http://personal1.iddeo.es/andresgarci/tclcurl/english/ | ||||||
|  o Gambas binding: http://gambas.sf.net |  o libcurl.NET 1.2: http://www.seasideresearch.com/downloads.html | ||||||
|  o pycurl 7.12.0 was released http://pycurl.sf.net |  o RCurl 0.5.1: http://www.omegahat.org/RCurl/ | ||||||
|  o wxWidgets binding: http://homepage.mac.com/codonnell/wxcurldav/ |  o libcurl.mono 1.0: | ||||||
|  o New Austrian curl web mirror: http://curl.gds.tuwien.ac.at |    http://forge.novell.com/modules/xfmod/project/?libcurl-mono | ||||||
|  o TclCurl 0.12.0 was released: |  o new German curl mirror: http://curl.kgt.org/ | ||||||
|    http://personal1.iddeo.es/andresgarci/tclcurl/english/ |  | ||||||
|  o Ch binding: http://chcurl.sourceforge.net |  | ||||||
|  o New US curl web mirror: http://curl.109k.com |  | ||||||
|  o glib/GTK+ binding: http://atterer.net/glibcurl/ |  | ||||||
|  o New French curl web mirror: http://curl.mirror.internet.tp |  | ||||||
|  |  | ||||||
| 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: | ||||||
|  |  | ||||||
|  Gisle Vanem, Vincent Bronner, Alexander Krasnostavsky, Chris Gaukroger, |  Peter Wullinger, Guillaume Arluison, Alexander Krasnostavsky, Mohun Biswas, | ||||||
|  G<EFBFBD>nter Knauf, Marty Kuhrt, Kjetil Jacobsen, Steven Bazyl, Seshubabu Pasam, |  Tomas Pospisek, Gisle Vanem, Dan Fandrich, Paul Nolan, Andres Garcia, Tim | ||||||
|  Luca Alteas, Jean-Louis Lemaire, David Byron, David Cohen, Rob Stanzel, |  Sneddon, Ian Gulliver, Jean-Philippe Barrette-LaPierre, Jeff Phillips, | ||||||
|  Niels van Tongeren, Andr<64>s Garc<72>a, Toby Peterson, Casey O'Donnell, Brian |  Wojciech Zwiefka, David Phillips, Reinout van Schouwen, Maurice Barnum, | ||||||
|  Akins, Bertrand Demiddelaer, Joel Chen, Dylan Salisbury, Enrico Scholz, |  Richard Atterer, Rene Bernhardt, Matt Veenstra, Bryan Henderson, Ton Voon, | ||||||
|  Alexis Carvalho |  Kai Sommerfeld, David Byron, Harshal Pradhan, Tom Lee, Dinar, Jean-Marc | ||||||
|  |  Ranger, Samuel Listopad | ||||||
|  |  | ||||||
|         Thanks! (and sorry if I forgot to mention someone) |         Thanks! (and sorry if I forgot to mention someone) | ||||||
|   | |||||||
| @@ -1,9 +1,8 @@ | |||||||
| Issues not sorted in any particular order. | Issues not sorted in any particular order. | ||||||
|  |  | ||||||
| To get fixed in 7.12.2 (planned release: December 2004) | To get fixed in 7.12.3 (planned release: December 2004) | ||||||
| ====================== | ====================== | ||||||
|  |  | ||||||
| 36. Fix HTTP Negotiate authentication so that no bogus user name needs to be | 47 - Peter Sylvester's patch for SRP on the TLS layer | ||||||
|     provided to activate it. |      Awaits OpenSSL support for this, no need to support this in libcurl before | ||||||
|  |      there's an OpenSSL release that does it. | ||||||
|  Bugfixes reported until late November |  | ||||||
|   | |||||||
| @@ -690,10 +690,15 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | |||||||
|          fi |          fi | ||||||
|        else dnl $ICC = yes |        else dnl $ICC = yes | ||||||
|          dnl this is a set of options we believe *ALL* gcc versions support: |          dnl this is a set of options we believe *ALL* gcc versions support: | ||||||
|          WARN="-W -Wall -Wwrite-strings -pedantic -Wno-long-long -Wpointer-arith -Wnested-externs -Winline -Wmissing-declarations -Wmissing-prototypes -Wsign-compare" |          WARN="-W -Wall -Wwrite-strings -pedantic -Wpointer-arith -Wnested-externs -Winline -Wmissing-prototypes" | ||||||
|  |  | ||||||
|          dnl -Wcast-align is a bit too annoying on all gcc versions ;-) |          dnl -Wcast-align is a bit too annoying on all gcc versions ;-) | ||||||
|  |  | ||||||
|  |          if test "$gccnum" -ge "207"; then | ||||||
|  |            dnl gcc 2.7 or later (well, they don't work on 2.2.2) | ||||||
|  |            WARN="$WARN -Wno-long-long -Wmissing-declarations -Wsign-compare" | ||||||
|  |          fi | ||||||
|  |  | ||||||
|          if test "$gccnum" -gt "295"; then |          if test "$gccnum" -gt "295"; then | ||||||
|            dnl only if the compiler is newer than 2.95 since we got lots of |            dnl only if the compiler is newer than 2.95 since we got lots of | ||||||
|            dnl "`_POSIX_C_SOURCE' is not defined" in system headers with |            dnl "`_POSIX_C_SOURCE' is not defined" in system headers with | ||||||
|   | |||||||
| @@ -6,3 +6,18 @@ ahost | |||||||
| config.log | config.log | ||||||
| config.status | config.status | ||||||
| aclocal.m4 | aclocal.m4 | ||||||
|  | .deps | ||||||
|  | Makefile.in | ||||||
|  | config.guess | ||||||
|  | config.h | ||||||
|  | config.h.in | ||||||
|  | config.sub | ||||||
|  | libtool | ||||||
|  | ltmain.sh | ||||||
|  | stamp-h1 | ||||||
|  | *.lo | ||||||
|  | .libs | ||||||
|  | depcomp | ||||||
|  | libcares.la | ||||||
|  | missing | ||||||
|  | ares_version.h.dist | ||||||
|   | |||||||
							
								
								
									
										61
									
								
								ares/CHANGES
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								ares/CHANGES
									
									
									
									
									
								
							| @@ -1,5 +1,66 @@ | |||||||
|   Changelog for the c-ares project |   Changelog for the c-ares project | ||||||
|  |  | ||||||
|  | * November 7 | ||||||
|  |  | ||||||
|  | - Fixed the VC project and makefile to use ares_cancel and ares_version | ||||||
|  |  | ||||||
|  | * October 24 | ||||||
|  |  | ||||||
|  | - The released ares_version.h from 1.2.1 says 1.2.0 due to a maketgz flaw. | ||||||
|  |   This is now fixed. | ||||||
|  |  | ||||||
|  | Version 1.2.1 (October 20, 2004) | ||||||
|  |  | ||||||
|  | * September 29 | ||||||
|  |  | ||||||
|  | - Henrik Stoerner fix: got a report that Tru64 Unix (the unix from Digital | ||||||
|  |   when they made Alpha's) uses /etc/svc.conf for the purpose fixed below for | ||||||
|  |   other OSes. He made c-ares check for and understand it if present. | ||||||
|  |  | ||||||
|  | - Now c-ares will use local host name lookup _before_ DNS resolving by default | ||||||
|  |   if nothing else is told. | ||||||
|  |  | ||||||
|  | * September 26 | ||||||
|  |  | ||||||
|  | - Henrik Stoerner: found out that c-ares does not look at the /etc/host.conf | ||||||
|  |   file to determine the sequence in which to search /etc/hosts and DNS.  So on | ||||||
|  |   systems where this order is defined by /etc/host.conf instead of a "lookup" | ||||||
|  |   entry in /etc/resolv.conf, c-ares will always default to looking in DNS | ||||||
|  |   first, and /etc/hosts second. | ||||||
|  |  | ||||||
|  |   c-ares now looks at | ||||||
|  |  | ||||||
|  |   1) resolv.conf (for the "lookup" line); | ||||||
|  |   2) nsswitch.fon (for the "hosts:" line); | ||||||
|  |   3) host.conf (for the "order" line). | ||||||
|  |  | ||||||
|  |   First match wins. | ||||||
|  |  | ||||||
|  | - Dominick Meglio patched: C-ares on Windows assumed that the HOSTS file is | ||||||
|  |   located in a static location. It assumed | ||||||
|  |   C:\Windows\System32\Drivers\Etc. This is a poor assumption to make. In fact, | ||||||
|  |   the location of the HOSTS file can be changed via a registry setting. | ||||||
|  |  | ||||||
|  |   There is a key called DatabasePath which specifies the path to the HOSTS | ||||||
|  |   file: | ||||||
|  |   http://www.microsoft.com/technet/itsolutions/network/deploy/depovg/tcpip2k.mspx | ||||||
|  |  | ||||||
|  |   The patch will make c-ares correctly consult the registry for the location | ||||||
|  |   of this file. | ||||||
|  |  | ||||||
|  | * August 29 | ||||||
|  |  | ||||||
|  | - Gisle Vanem fixed the MSVC build files. | ||||||
|  |  | ||||||
|  | * August 20 | ||||||
|  |  | ||||||
|  | - Gisle Vanem made c-ares build and work with his Watt-32 TCP/IP stack. | ||||||
|  |  | ||||||
|  | * August 13 | ||||||
|  |  | ||||||
|  | - Harshal Pradhan made a minor syntax change in ares_init.c to make it build | ||||||
|  |   fine with MSVC 7.1 | ||||||
|  |  | ||||||
| * July 24 | * July 24 | ||||||
|  |  | ||||||
| - Made the lib get built static only if --enable-debug is used. | - Made the lib get built static only if --enable-debug is used. | ||||||
|   | |||||||
| @@ -55,3 +55,12 @@ libcares_la_SOURCES = $(CSOURCES) $(HHEADERS) | |||||||
| 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 | ||||||
|  |  | ||||||
|  | # Make files named *.dist replace the file without .dist extension | ||||||
|  | dist-hook: | ||||||
|  | 	find $(distdir) -name "*.dist" -exec rm {} \; | ||||||
|  | 	(distit=`find $(srcdir) -name "*.dist"`; \ | ||||||
|  | 	for file in $$distit; do \ | ||||||
|  | 	  strip=`echo $$file | sed -e s/^$(srcdir)// -e s/\.dist//`; \ | ||||||
|  | 	  cp $$file $(distdir)$$strip; \ | ||||||
|  | 	done) | ||||||
|   | |||||||
| @@ -1,9 +1,11 @@ | |||||||
| # | # | ||||||
| # 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 | .SUFFIXES: .exe | ||||||
|  |  | ||||||
|  | include Makefile.inc | ||||||
|  |  | ||||||
| WATT32_ROOT = $(subst \,/,$(WATT_ROOT)) | WATT32_ROOT = $(subst \,/,$(WATT_ROOT)) | ||||||
|  |  | ||||||
| CC      = gcc | CC      = gcc | ||||||
| @@ -11,17 +13,9 @@ CFLAGS  = -O2 -Wall -DWATT32 -Dselect=select_s -I$(WATT32_ROOT)/inc | |||||||
| LDFLAGS = -s | LDFLAGS = -s | ||||||
| EX_LIBS = $(WATT32_ROOT)/lib/libwatt.a | EX_LIBS = $(WATT32_ROOT)/lib/libwatt.a | ||||||
|  |  | ||||||
| SOURCE = ares_cancel.c ares_destroy.c ares_expand_name.c ares_expand_string.c ares_fds.c \ |  | ||||||
|          ares_free_hostent.c ares_free_string.c ares_gethostbyaddr.c ares_gethostbyname.c \ |  | ||||||
|          ares_init.c ares_mkquery.c ares_parse_a_reply.c ares_parse_ptr_reply.c \ |  | ||||||
|          ares_process.c ares_query.c ares_search.c ares_send.c ares_strerror.c \ |  | ||||||
|          ares_timeout.c ares__close_sockets.c ares__get_hostent.c ares__read_line.c \ |  | ||||||
|          ares_version.c |  | ||||||
|  |  | ||||||
| OBJ_DIR = djgpp | OBJ_DIR = djgpp | ||||||
|  |  | ||||||
| OBJECTS = $(addprefix $(OBJ_DIR)/, $(SOURCE:.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. | ||||||
| @@ -50,7 +44,7 @@ $(OBJ_DIR)/%.o: %.c | |||||||
| 	@echo | 	@echo | ||||||
|  |  | ||||||
| depend: | depend: | ||||||
| 	$(CC) -MM $(CFLAGS) $(SOURCE) | \ | 	$(CC) -MM $(CFLAGS) $(CSOURCES) | \ | ||||||
| 	sed -e 's/^\([a-zA-Z0-9_-]*\.o:\)/$$(OBJ_DIR)\/\1/' > depend.dj | 	sed -e 's/^\([a-zA-Z0-9_-]*\.o:\)/$$(OBJ_DIR)\/\1/' > depend.dj | ||||||
|  |  | ||||||
| -include depend.dj | -include depend.dj | ||||||
|   | |||||||
| @@ -88,7 +88,7 @@ LD	= nlmconv | |||||||
| LDFLAGS	= -T | LDFLAGS	= -T | ||||||
| AR	= ar | AR	= ar | ||||||
| ARFLAGS	= -cq | ARFLAGS	= -cq | ||||||
| CFLAGS	+= -fno-builtin -fpack-struct -fpcc-struct-return | CFLAGS	+= -fno-builtin -fpack-struct -fpcc-struct-return -fno-strict-aliasing | ||||||
| CFLAGS	+= -Wall -Wno-format # -pedantic | CFLAGS	+= -Wall -Wno-format # -pedantic | ||||||
| ifeq ($(LIBARCH),LIBC) | ifeq ($(LIBARCH),LIBC) | ||||||
| 	PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o | 	PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								ares/ares.h
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								ares/ares.h
									
									
									
									
									
								
							| @@ -27,13 +27,20 @@ | |||||||
| #include <sys/select.h> | #include <sys/select.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if defined(WATT32) | ||||||
|  |   #include <netinet/in.h> | ||||||
|  |   #include <tcp.h> | ||||||
|  | #elif defined(WIN32) | ||||||
|   #include <winsock.h> |   #include <winsock.h> | ||||||
|   #include <windows.h> |   #include <windows.h> | ||||||
| #else | #else | ||||||
|   #include <netinet/in.h> |   #include <netinet/in.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef  __cplusplus | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #define ARES_SUCCESS            0 | #define ARES_SUCCESS            0 | ||||||
|  |  | ||||||
| /* Server error codes (ARES_ENODATA indicates no relevant answer) */ | /* Server error codes (ARES_ENODATA indicates no relevant answer) */ | ||||||
| @@ -137,4 +144,8 @@ void ares_free_hostent(struct hostent *host); | |||||||
| const char *ares_strerror(int code); | const char *ares_strerror(int code); | ||||||
| void ares_free_errmem(char *mem); | void ares_free_errmem(char *mem); | ||||||
|  |  | ||||||
|  | #ifdef  __cplusplus | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif /* ARES__H */ | #endif /* ARES__H */ | ||||||
|   | |||||||
| @@ -16,10 +16,10 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #ifdef WIN32 | #ifdef HAVE_UNISTD_H | ||||||
| #else |  | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include "ares.h" | #include "ares.h" | ||||||
| #include "ares_private.h" | #include "ares_private.h" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,9 +16,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/socket.h> | #include <sys/socket.h> | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| #include <arpa/inet.h> | #include <arpa/inet.h> | ||||||
|   | |||||||
| @@ -33,5 +33,7 @@ might have been stored in their arguments. | |||||||
| .SH SEE ALSO | .SH SEE ALSO | ||||||
| .BR ares_init (3) | .BR ares_init (3) | ||||||
| .BR ares_destroy (3) | .BR ares_destroy (3) | ||||||
|  | .SH NOTES | ||||||
|  | This function is not compatible with ares. | ||||||
| .SH AUTHOR | .SH AUTHOR | ||||||
| Dirk Manske | Dirk Manske | ||||||
|   | |||||||
| @@ -14,14 +14,14 @@ | |||||||
| .\" this software for any purpose.  It is provided "as is" | .\" this software for any purpose.  It is provided "as is" | ||||||
| .\" without express or implied warranty. | .\" without express or implied warranty. | ||||||
| .\" | .\" | ||||||
| .TH ARES_DESTROY 3 "23 July 1998" | .TH ARES_DESTROY 3 "7 December 2004" | ||||||
| .SH NAME | .SH NAME | ||||||
| ares_destroy \- Destroy a resolver channel | ares_destroy \- Destroy a resolver channel | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .nf | .nf | ||||||
| .B #include <ares.h> | .B #include <ares.h> | ||||||
| .PP | .PP | ||||||
| .B int ares_destroy(ares_channel \fIchannel\fP) | .B void ares_destroy(ares_channel \fIchannel\fP) | ||||||
| .fi | .fi | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The | The | ||||||
|   | |||||||
| @@ -16,7 +16,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 <netinet/in.h> | #include <netinet/in.h> | ||||||
|   | |||||||
| @@ -16,7 +16,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 <netinet/in.h> | #include <netinet/in.h> | ||||||
|   | |||||||
| @@ -16,9 +16,7 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef HAVE_SYS_TIME_H | ||||||
|  |  | ||||||
| #else |  | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -28,7 +26,8 @@ | |||||||
| int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds) | int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds) | ||||||
| { | { | ||||||
|   struct server_state *server; |   struct server_state *server; | ||||||
|   int i, nfds; |   ares_socket_t nfds; | ||||||
|  |   int i; | ||||||
|  |  | ||||||
|   /* No queries, no file descriptors. */ |   /* No queries, no file descriptors. */ | ||||||
|   if (!channel->queries) |   if (!channel->queries) | ||||||
| @@ -53,5 +52,5 @@ int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds) | |||||||
|             nfds = server->tcp_socket + 1; |             nfds = server->tcp_socket + 1; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   return nfds; |   return (int)nfds; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -16,9 +16,7 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if !defined(WIN32) || defined(WATT32) | ||||||
|  |  | ||||||
| #else |  | ||||||
| #include <netdb.h> | #include <netdb.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,7 +16,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/socket.h> | #include <sys/socket.h> | ||||||
| @@ -28,9 +28,14 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
| #include "ares.h" | #include "ares.h" | ||||||
| #include "ares_private.h" | #include "ares_private.h" | ||||||
|  |  | ||||||
|  | #ifdef WATT32 | ||||||
|  | #undef WIN32 | ||||||
|  | #endif | ||||||
|  |  | ||||||
| struct addr_query { | struct addr_query { | ||||||
|   /* Arguments passed to ares_gethostbyaddr() */ |   /* Arguments passed to ares_gethostbyaddr() */ | ||||||
|   ares_channel channel; |   ares_channel channel; | ||||||
| @@ -144,13 +149,24 @@ static int file_lookup(struct in_addr *addr, struct hostent **host) | |||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
|  |  | ||||||
|   char PATH_HOSTS[MAX_PATH]; |   char PATH_HOSTS[MAX_PATH]; | ||||||
|   if (IsNT) { |   if (IS_NT()) { | ||||||
|     GetSystemDirectory(PATH_HOSTS, MAX_PATH); |         char tmp[MAX_PATH]; | ||||||
|     strcat(PATH_HOSTS, PATH_HOSTS_NT); |         HKEY hkeyHosts; | ||||||
|   } else { |  | ||||||
|     GetWindowsDirectory(PATH_HOSTS, MAX_PATH); |         if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, WIN_NS_NT_KEY, 0, KEY_READ, &hkeyHosts) | ||||||
|     strcat(PATH_HOSTS, PATH_HOSTS_9X); |                 == ERROR_SUCCESS) | ||||||
|  |         { | ||||||
|  |                 DWORD dwLength = MAX_PATH; | ||||||
|  |                 RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, tmp, | ||||||
|  |                         &dwLength); | ||||||
|  |                 ExpandEnvironmentStrings(tmp, PATH_HOSTS, MAX_PATH); | ||||||
|  |                 RegCloseKey(hkeyHosts); | ||||||
|         } |         } | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |     GetWindowsDirectory(PATH_HOSTS, MAX_PATH); | ||||||
|  |  | ||||||
|  |   strcat(PATH_HOSTS, WIN_PATH_HOSTS); | ||||||
|  |  | ||||||
| #elif defined(WATT32) | #elif defined(WATT32) | ||||||
|   extern const char *_w32_GetHostsFile (void); |   extern const char *_w32_GetHostsFile (void); | ||||||
|   | |||||||
| @@ -16,7 +16,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/socket.h> | #include <sys/socket.h> | ||||||
| @@ -30,9 +30,14 @@ | |||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <ctype.h> | #include <ctype.h> | ||||||
|  |  | ||||||
| #include "ares.h" | #include "ares.h" | ||||||
| #include "ares_private.h" | #include "ares_private.h" | ||||||
|  |  | ||||||
|  | #ifdef WATT32 | ||||||
|  | #undef WIN32 | ||||||
|  | #endif | ||||||
|  |  | ||||||
| struct host_query { | struct host_query { | ||||||
|   /* Arguments passed to ares_gethostbyname() */ |   /* Arguments passed to ares_gethostbyname() */ | ||||||
|   ares_channel channel; |   ares_channel channel; | ||||||
| @@ -215,15 +220,25 @@ static int file_lookup(const char *name, struct hostent **host) | |||||||
|   int status; |   int status; | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef WIN32 | ||||||
|  |  | ||||||
|   char PATH_HOSTS[MAX_PATH]; |   char PATH_HOSTS[MAX_PATH]; | ||||||
|   if (IsNT) { |   if (IS_NT()) { | ||||||
|     GetSystemDirectory(PATH_HOSTS, MAX_PATH); |         char tmp[MAX_PATH]; | ||||||
|     strcat(PATH_HOSTS, PATH_HOSTS_NT); |         HKEY hkeyHosts; | ||||||
|   } else { |  | ||||||
|     GetWindowsDirectory(PATH_HOSTS, MAX_PATH); |         if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, WIN_NS_NT_KEY, 0, KEY_READ, &hkeyHosts) | ||||||
|     strcat(PATH_HOSTS, PATH_HOSTS_9X); |                 == ERROR_SUCCESS) | ||||||
|  |         { | ||||||
|  |                 DWORD dwLength = MAX_PATH; | ||||||
|  |                 RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, tmp, | ||||||
|  |                         &dwLength); | ||||||
|  |                 ExpandEnvironmentStrings(tmp, PATH_HOSTS, MAX_PATH); | ||||||
|  |                 RegCloseKey(hkeyHosts); | ||||||
|         } |         } | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |     GetWindowsDirectory(PATH_HOSTS, MAX_PATH); | ||||||
|  |  | ||||||
|  |   strcat(PATH_HOSTS, WIN_PATH_HOSTS); | ||||||
|  |  | ||||||
| #elif defined(WATT32) | #elif defined(WATT32) | ||||||
|   extern const char *_w32_GetHostsFile (void); |   extern const char *_w32_GetHostsFile (void); | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ | |||||||
| .\" this software for any purpose.  It is provided "as is" | .\" this software for any purpose.  It is provided "as is" | ||||||
| .\" without express or implied warranty. | .\" without express or implied warranty. | ||||||
| .\" | .\" | ||||||
| .TH ARES_INIT 3 "21 July 1998" | .TH ARES_INIT 3 "7 December 2004" | ||||||
| .SH NAME | .SH NAME | ||||||
| ares_init, ares_init_options \- Initialize a resolver channel | ares_init, ares_init_options \- Initialize a resolver channel | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -25,31 +25,20 @@ ares_init, ares_init_options \- Initialize a resolver channel | |||||||
| .B int ares_init_options(ares_channel *\fIchannel\fP, | .B int ares_init_options(ares_channel *\fIchannel\fP, | ||||||
| .B 	struct ares_options *\fIoptions\fP, int \fIoptmask\fP) | .B 	struct ares_options *\fIoptions\fP, int \fIoptmask\fP) | ||||||
| .PP | .PP | ||||||
| .B cc file.c -lares | .B cc file.c -lcares | ||||||
| .fi | .fi | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The | The \fBares_init\fP function initializes a communications channel for name | ||||||
| .B ares_init | service lookups.  If it returns successfully, \fBares_init\fP will set the | ||||||
| function initializes a communications channel for name service | variable pointed to by \fIchannel\fP to a handle used to identify the name | ||||||
| lookups.  If it returns successfully, | service channel.  The caller should invoke | ||||||
| .B ares_init |  | ||||||
| will set the variable pointed to by |  | ||||||
| .I channel |  | ||||||
| to a handle used to identify the name service channel.  The caller |  | ||||||
| should invoke |  | ||||||
| .BR ares_destroy (3) | .BR ares_destroy (3) | ||||||
| on the handle when the channel is no longer needed. | on the handle when the channel is no longer needed. | ||||||
| .PP | .PP | ||||||
| The | The \fBares_init_options\fP function also initializes a name service channel, | ||||||
| .B ares_init_options | with additional options useful for applications requiring more control over | ||||||
| function also initializes a name service channel, with additional | name service configuration. The \fIoptmask\fP parameter specifies which fields | ||||||
| options useful for applications requiring more control over name | in the structure pointed to by \fIoptions\fP are set, as follows: | ||||||
| service configuration.  The |  | ||||||
| .I optmask |  | ||||||
| parameter specifies which fields in the structure pointed to by |  | ||||||
| .I options |  | ||||||
| are set, as follows: |  | ||||||
| .PP |  | ||||||
| .TP 18 | .TP 18 | ||||||
| .B ARES_OPT_FLAGS | .B ARES_OPT_FLAGS | ||||||
| .B int \fIflags\fP; | .B int \fIflags\fP; | ||||||
| @@ -127,9 +116,11 @@ If a truncated response to a UDP query is received, do not fall back | |||||||
| to TCP; simply continue on with the truncated response. | to TCP; simply continue on with the truncated response. | ||||||
| .TP 23 | .TP 23 | ||||||
| .B ARES_FLAG_NORECURSE | .B ARES_FLAG_NORECURSE | ||||||
| Do not set the "recursion desired" bit on outgoing queries, so that | Do not set the "recursion desired" bit on outgoing queries, so that the name | ||||||
| the name server being contacted will not try to fetch the answer from | server being contacted will not try to fetch the answer from other servers if | ||||||
| other servers if it doesn't know the answer locally. | it doesn't know the answer locally. Be aware that ares will not do the | ||||||
|  | recursion for you.  Recursion must be handled by the application calling ares | ||||||
|  | if \fIARES_FLAG_NORECURSE\fP is set. | ||||||
| .TP 23 | .TP 23 | ||||||
| .B ARES_FLAG_STAYOPEN | .B ARES_FLAG_STAYOPEN | ||||||
| Do not close communciations sockets when the number of active queries | Do not close communciations sockets when the number of active queries | ||||||
|   | |||||||
| @@ -16,19 +16,25 @@ | |||||||
| #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" | ||||||
| #include <iphlpapi.h> | #include <iphlpapi.h> | ||||||
| #include <malloc.h> | #include <malloc.h> | ||||||
|  |  | ||||||
| #else | #else | ||||||
| #include <sys/param.h> | #include <sys/param.h> | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| #include <arpa/inet.h> | #include <arpa/inet.h> | ||||||
| #include <netdb.h> | #include <netdb.h> | ||||||
| #include <arpa/nameser.h> | #include <arpa/nameser.h> | ||||||
|  | #ifdef HAVE_UNISTD_H | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| @@ -39,13 +45,18 @@ | |||||||
| #include "ares.h" | #include "ares.h" | ||||||
| #include "ares_private.h" | #include "ares_private.h" | ||||||
|  |  | ||||||
|  | #ifdef WATT32 | ||||||
|  | #undef WIN32  /* Redefined in MingW/MSVC headers */ | ||||||
|  | #endif | ||||||
|  |  | ||||||
| static int init_by_options(ares_channel channel, struct ares_options *options, | static int init_by_options(ares_channel channel, struct ares_options *options, | ||||||
|                            int optmask); |                            int optmask); | ||||||
| static int init_by_environment(ares_channel channel); | static int init_by_environment(ares_channel channel); | ||||||
| static int init_by_resolv_conf(ares_channel channel); | static int init_by_resolv_conf(ares_channel channel); | ||||||
| static int init_by_defaults(ares_channel channel); | static int init_by_defaults(ares_channel channel); | ||||||
| static int config_domain(ares_channel channel, char *str); | static int config_domain(ares_channel channel, char *str); | ||||||
| static int config_lookup(ares_channel channel, const char *str); | static int config_lookup(ares_channel channel, const char *str, | ||||||
|  |                          const char *bindch, const char *filech); | ||||||
| static int config_nameserver(struct server_state **servers, int *nservers, | static int config_nameserver(struct server_state **servers, int *nservers, | ||||||
|                              char *str); |                              char *str); | ||||||
| static int config_sortlist(struct apattern **sortlist, int *nsort, | static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||||
| @@ -294,7 +305,8 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size) | |||||||
| { | { | ||||||
|   FIXED_INFO    *fi   = alloca (sizeof(*fi)); |   FIXED_INFO    *fi   = alloca (sizeof(*fi)); | ||||||
|   DWORD          size = sizeof (*fi); |   DWORD          size = sizeof (*fi); | ||||||
|   DWORD WINAPI (*GetNetworkParams) (FIXED_INFO*, DWORD*);  /* available only on Win-98/2000+ */ |   typedef DWORD (WINAPI* get_net_param_func) (FIXED_INFO*, DWORD*); | ||||||
|  |   get_net_param_func GetNetworkParams;  /* available only on Win-98/2000+ */ | ||||||
|   HMODULE        handle; |   HMODULE        handle; | ||||||
|   IP_ADDR_STRING *ipAddr; |   IP_ADDR_STRING *ipAddr; | ||||||
|   int            i, count = 0; |   int            i, count = 0; | ||||||
| @@ -310,7 +322,7 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size) | |||||||
|   if (!handle) |   if (!handle) | ||||||
|      return (0); |      return (0); | ||||||
|  |  | ||||||
|   (void*)GetNetworkParams = GetProcAddress (handle, "GetNetworkParams"); |   GetNetworkParams = (get_net_param_func) GetProcAddress (handle, "GetNetworkParams"); | ||||||
|   if (!GetNetworkParams) |   if (!GetNetworkParams) | ||||||
|      goto quit; |      goto quit; | ||||||
|  |  | ||||||
| @@ -364,7 +376,7 @@ quit: | |||||||
| static int init_by_resolv_conf(ares_channel channel) | static int init_by_resolv_conf(ares_channel channel) | ||||||
| { | { | ||||||
|   char *line = NULL; |   char *line = NULL; | ||||||
|   int status, nservers = 0, nsort = 0; |   int status = -1, nservers = 0, nsort = 0; | ||||||
|   struct server_state *servers = NULL; |   struct server_state *servers = NULL; | ||||||
|   struct apattern *sortlist = NULL; |   struct apattern *sortlist = NULL; | ||||||
|  |  | ||||||
| @@ -410,7 +422,7 @@ DhcpNameServer | |||||||
|       goto okay; |       goto okay; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (IsNT) |   if (IS_NT()) | ||||||
|   { |   { | ||||||
|     if (RegOpenKeyEx( |     if (RegOpenKeyEx( | ||||||
|           HKEY_LOCAL_MACHINE, WIN_NS_NT_KEY, 0, |           HKEY_LOCAL_MACHINE, WIN_NS_NT_KEY, 0, | ||||||
| @@ -539,7 +551,7 @@ DhcpNameServer | |||||||
|       if ((p = try_config(line, "domain"))) |       if ((p = try_config(line, "domain"))) | ||||||
|         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); |         status = config_lookup(channel, p, "bind", "file"); | ||||||
|       else if ((p = try_config(line, "search"))) |       else if ((p = try_config(line, "search"))) | ||||||
|         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) | ||||||
| @@ -553,9 +565,49 @@ DhcpNameServer | |||||||
|       if (status != ARES_SUCCESS) |       if (status != ARES_SUCCESS) | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  |     fclose(fp); | ||||||
|  |  | ||||||
|  |     if (!channel->lookups) { | ||||||
|  |       /* Many systems (Solaris, Linux, BSD's) use nsswitch.conf */ | ||||||
|  |       fp = fopen("/etc/nsswitch.conf", "r"); | ||||||
|  |       if (fp) { | ||||||
|  |         while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) | ||||||
|  |         { | ||||||
|  |           if ((p = try_config(line, "hosts:")) && !channel->lookups) | ||||||
|  |             status = config_lookup(channel, p, "dns", "files"); | ||||||
|  |         } | ||||||
|  |         fclose(fp); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (!channel->lookups) { | ||||||
|  |       /* Linux / GNU libc 2.x and possibly others have host.conf */ | ||||||
|  |       fp = fopen("/etc/host.conf", "r"); | ||||||
|  |       if (fp) { | ||||||
|  |         while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) | ||||||
|  |         { | ||||||
|  |           if ((p = try_config(line, "order")) && !channel->lookups) | ||||||
|  |             status = config_lookup(channel, p, "bind", "hosts"); | ||||||
|  |         } | ||||||
|  |         fclose(fp); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (!channel->lookups) { | ||||||
|  |       /* Tru64 uses /etc/svc.conf */ | ||||||
|  |       fp = fopen("/etc/svc.conf", "r"); | ||||||
|  |       if (fp) { | ||||||
|  |         while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) | ||||||
|  |         { | ||||||
|  |           if ((p = try_config(line, "hosts=")) && !channel->lookups) | ||||||
|  |             status = config_lookup(channel, p, "bind", "local"); | ||||||
|  |         } | ||||||
|  |         fclose(fp); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if(line) |     if(line) | ||||||
|       free(line); |       free(line); | ||||||
|     fclose(fp); |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
| @@ -649,7 +701,7 @@ static int init_by_defaults(ares_channel channel) | |||||||
|  |  | ||||||
|   if (!channel->lookups) |   if (!channel->lookups) | ||||||
|     { |     { | ||||||
|       channel->lookups = strdup("bf"); |       channel->lookups = strdup("fb"); | ||||||
|       if (!channel->lookups) |       if (!channel->lookups) | ||||||
|         return ARES_ENOMEM; |         return ARES_ENOMEM; | ||||||
|     } |     } | ||||||
| @@ -669,7 +721,8 @@ static int config_domain(ares_channel channel, char *str) | |||||||
|   return set_search(channel, str); |   return set_search(channel, str); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int config_lookup(ares_channel channel, const char *str) | static int config_lookup(ares_channel channel, const char *str, | ||||||
|  |                          const char *bindch, const char *filech) | ||||||
| { | { | ||||||
|   char lookups[3], *l; |   char lookups[3], *l; | ||||||
|   const char *p; |   const char *p; | ||||||
| @@ -682,11 +735,13 @@ static int config_lookup(ares_channel channel, const char *str) | |||||||
|   p = str; |   p = str; | ||||||
|   while (*p) |   while (*p) | ||||||
|     { |     { | ||||||
|       if ((*p == 'b' || *p == 'f') && l < lookups + 2) |       if ((*p == *bindch || *p == *filech) && l < lookups + 2) { | ||||||
| 	*l++ = *p; |         if (*p == *bindch) *l++ = 'b'; | ||||||
|       while (*p && !isspace((unsigned char)*p)) |         else *l++ = 'f'; | ||||||
|  |       } | ||||||
|  |       while (*p && !isspace((unsigned char)*p) && (*p != ',')) | ||||||
|         p++; |         p++; | ||||||
|       while (isspace((unsigned char)*p)) |       while (*p && (isspace((unsigned char)*p) || (*p == ','))) | ||||||
|         p++; |         p++; | ||||||
|     } |     } | ||||||
|   *l = 0; |   *l = 0; | ||||||
|   | |||||||
| @@ -16,7 +16,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 <netinet/in.h> | #include <netinet/in.h> | ||||||
|   | |||||||
| @@ -16,7 +16,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/socket.h> | #include <sys/socket.h> | ||||||
|   | |||||||
| @@ -16,7 +16,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/socket.h> | #include <sys/socket.h> | ||||||
|   | |||||||
| @@ -18,9 +18,7 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if !defined(WIN32) || defined(WATT32) | ||||||
|  |  | ||||||
| #else |  | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| /* We define closesocket() here so that we can use this function all over | /* We define closesocket() here so that we can use this function all over | ||||||
|    the source code for closing sockets. */ |    the source code for closing sockets. */ | ||||||
| @@ -41,15 +39,15 @@ | |||||||
| #define INADDR_NONE 0xffffffff | #define INADDR_NONE 0xffffffff | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if defined(WIN32) && !defined(WATT32) | ||||||
|  |  | ||||||
| #define IsNT ((int)GetVersion()>0) | #define IS_NT()        ((int)GetVersion() > 0) | ||||||
| #define WIN_NS_9X      "System\\CurrentControlSet\\Services\\VxD\\MSTCP" | #define WIN_NS_9X      "System\\CurrentControlSet\\Services\\VxD\\MSTCP" | ||||||
| #define WIN_NS_NT_KEY  "System\\CurrentControlSet\\Services\\Tcpip\\Parameters" | #define WIN_NS_NT_KEY  "System\\CurrentControlSet\\Services\\Tcpip\\Parameters" | ||||||
| #define NAMESERVER     "NameServer" | #define NAMESERVER     "NameServer" | ||||||
| #define DHCPNAMESERVER "DhcpNameServer" | #define DHCPNAMESERVER "DhcpNameServer" | ||||||
| #define PATH_HOSTS_NT  "\\drivers\\etc\\hosts" | #define DATABASEPATH   "DatabasePath" | ||||||
| #define PATH_HOSTS_9X  "\\hosts" | #define WIN_PATH_HOSTS  "\\hosts" | ||||||
|  |  | ||||||
| #elif defined(WATT32) | #elif defined(WATT32) | ||||||
|  |  | ||||||
| @@ -166,5 +164,9 @@ int ares__read_line(FILE *fp, char **buf, int *bufsize); | |||||||
|    libcurl lowlevel code from within library is ugly and only works when |    libcurl lowlevel code from within library is ugly and only works when | ||||||
|    c-ares is built and linked with a similarly debug-build libcurl, but we do |    c-ares is built and linked with a similarly debug-build libcurl, but we do | ||||||
|    this anyway for convenience. */ |    this anyway for convenience. */ | ||||||
|  | #ifndef CURL_EXTERN | ||||||
|  | /* ugly hack to make this compile */ | ||||||
|  | #define CURL_EXTERN | ||||||
|  | #endif | ||||||
| #include "../lib/memdebug.h" | #include "../lib/memdebug.h" | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -16,27 +16,33 @@ | |||||||
| #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/socket.h> | #include <sys/socket.h> | ||||||
|  | #ifdef HAVE_SYS_UIO_H | ||||||
| #include <sys/uio.h> | #include <sys/uio.h> | ||||||
|  | #endif | ||||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||||
| #include <netdb.h> | #include <netdb.h> | ||||||
| #include <arpa/nameser.h> | #include <arpa/nameser.h> | ||||||
|  | #ifdef HAVE_UNISTD_H | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #include <errno.h> | #include <errno.h> | ||||||
|  |  | ||||||
| #include "ares.h" | #include "ares.h" | ||||||
| #include "ares_dns.h" | #include "ares_dns.h" | ||||||
| #include "ares_private.h" | #include "ares_private.h" | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS) | ||||||
| #define GET_ERRNO()  WSAGetLastError() | #define GET_ERRNO()  WSAGetLastError() | ||||||
| #else | #else | ||||||
| #define GET_ERRNO()  errno | #define GET_ERRNO()  errno | ||||||
| @@ -234,6 +240,7 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | |||||||
|                */ |                */ | ||||||
|               process_answer(channel, server->tcp_buffer, server->tcp_length, |               process_answer(channel, server->tcp_buffer, server->tcp_length, | ||||||
|                              i, 1, now); |                              i, 1, now); | ||||||
|  |           if (server->tcp_buffer) | ||||||
|                         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; | ||||||
|   | |||||||
| @@ -16,7 +16,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 <netinet/in.h> | #include <netinet/in.h> | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ | |||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <ctype.h> | #include <ctype.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #if defined(WIN32) && !defined(WATT32) | ||||||
| #include "nameser.h" | #include "nameser.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,7 +16,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 <netinet/in.h> | #include <netinet/in.h> | ||||||
|   | |||||||
| @@ -30,7 +30,8 @@ function gets the description of the ares library error code | |||||||
| .IR code , | .IR code , | ||||||
| returning the result as a NUL-terminated C string. | returning the result as a NUL-terminated C string. | ||||||
| .SH NOTES | .SH NOTES | ||||||
| This function is not compatible with ares. | This function is not compatible with ares, it takes a different set of | ||||||
|  | arguments. | ||||||
| .SH AUTHOR | .SH AUTHOR | ||||||
| Greg Hudson, MIT Information Systems | Greg Hudson, MIT Information Systems | ||||||
| .br | .br | ||||||
|   | |||||||
| @@ -16,13 +16,12 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
| #ifdef WIN32 | #ifdef HAVE_SYS_TIME_H | ||||||
|  |  | ||||||
| #else |  | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include <time.h> | #include <time.h> | ||||||
|  |  | ||||||
| #include "ares.h" | #include "ares.h" | ||||||
| #include "ares_private.h" | #include "ares_private.h" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | |||||||
|     dnl Checks for standard header files, to make memdebug.h inclusions bettter |     dnl Checks for standard header files, to make memdebug.h inclusions bettter | ||||||
|     AC_HEADER_STDC |     AC_HEADER_STDC | ||||||
|  |  | ||||||
|     CPPFLAGS="$CPPFLAGS -DCURLDEBUG -I../include" |     CPPFLAGS="$CPPFLAGS -DCURLDEBUG -I$srcdir/../include" | ||||||
|     CFLAGS="$CFLAGS -g"  |     CFLAGS="$CFLAGS -g"  | ||||||
|  |  | ||||||
|     dnl set compiler "debug" options to become more picky, and remove |     dnl set compiler "debug" options to become more picky, and remove | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								ares/maketgz
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								ares/maketgz
									
									
									
									
									
								
							| @@ -12,6 +12,27 @@ if(!-f "ares.h") { | |||||||
|     exit; |     exit; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | my ($major, $minor, $patch)=split(/\./, $version); | ||||||
|  |  | ||||||
|  | $major += 0; | ||||||
|  | $minor += 0; | ||||||
|  | $patch += 0; | ||||||
|  |  | ||||||
|  | open(VER, "<ares_version.h") || | ||||||
|  |     die "can't open ares_version.h"; | ||||||
|  | open(NEWV, ">ares_version.h.dist"); | ||||||
|  | while(<VER>) { | ||||||
|  |     $_ =~ s/^\#define ARES_VERSION_MAJOR .*/\#define ARES_VERSION_MAJOR $major/; | ||||||
|  |     $_ =~ s/^\#define ARES_VERSION_MINOR .*/\#define ARES_VERSION_MINOR $minor/; | ||||||
|  |     $_ =~ s/^\#define ARES_VERSION_PATCH .*/\#define ARES_VERSION_PATCH $patch/; | ||||||
|  |     $_ =~ s/^\#define ARES_VERSION_STR .*/\#define ARES_VERSION_STR \"$version\"/; | ||||||
|  |  | ||||||
|  |     print NEWV $_; | ||||||
|  | } | ||||||
|  | close(VER); | ||||||
|  | close(NEWV); | ||||||
|  | print "ares_version.h.dist created\n"; | ||||||
|  |  | ||||||
| if(!-f "configure") { | if(!-f "configure") { | ||||||
|     print "running buildconf\n"; |     print "running buildconf\n"; | ||||||
|     `./buildconf`; |     `./buildconf`; | ||||||
|   | |||||||
| @@ -221,16 +221,4 @@ typedef enum __ns_rcode { | |||||||
| #define T_MAILA         ns_t_maila | #define T_MAILA         ns_t_maila | ||||||
| #define T_ANY           ns_t_any | #define T_ANY           ns_t_any | ||||||
|  |  | ||||||
| #if !(defined(__MINGW32__) || defined(NETWARE)) |  | ||||||
| /* protos for the functions we provide in windows_port.c */ |  | ||||||
| int ares_strncasecmp(const char *s1, const char *s2, size_t n); |  | ||||||
| int ares_strcasecmp(const char *s1, const char *s2); |  | ||||||
|  |  | ||||||
| /* use this define magic to prevent us from adding symbol names to the library |  | ||||||
|    that is a high-risk to collide with another libraries' attempts to do the |  | ||||||
|    same */ |  | ||||||
| #define strncasecmp(a,b,c) ares_strncasecmp(a,b,c) |  | ||||||
| #define strcasecmp(a,b) ares_strcasecmp(a,b) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif /* ARES_NAMESER_H */ | #endif /* ARES_NAMESER_H */ | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								ares/setup.h
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								ares/setup.h
									
									
									
									
									
								
							| @@ -33,7 +33,7 @@ | |||||||
| #undef PACKAGE | #undef PACKAGE | ||||||
|  |  | ||||||
| /* now typedef our socket type */ | /* now typedef our socket type */ | ||||||
| #ifdef WIN32 | #if defined(WIN32) && !defined(WATT32) | ||||||
| #include <winsock.h> | #include <winsock.h> | ||||||
| typedef SOCKET ares_socket_t; | typedef SOCKET ares_socket_t; | ||||||
| #define ARES_SOCKET_BAD INVALID_SOCKET | #define ARES_SOCKET_BAD INVALID_SOCKET | ||||||
| @@ -42,4 +42,31 @@ typedef int ares_socket_t; | |||||||
| #define ARES_SOCKET_BAD -1 | #define ARES_SOCKET_BAD -1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* Assume a few thing unless they're set by configure | ||||||
|  |  */ | ||||||
|  | #if !defined(HAVE_SYS_TIME_H) && !defined(_MSC_VER) | ||||||
|  | #define HAVE_SYS_TIME_H   | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if !defined(HAVE_UNISTD_H) && !defined(_MSC_VER) | ||||||
|  | #define HAVE_UNISTD_H  | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if !defined(HAVE_SYS_UIO_H) && !defined(WIN32) && !defined(MSDOS) | ||||||
|  | #define HAVE_SYS_UIO_H | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if (defined(WIN32) || defined(WATT32)) && \ | ||||||
|  |    !(defined(__MINGW32__) || defined(NETWARE)) | ||||||
|  | /* protos for the functions we provide in windows_port.c */ | ||||||
|  | int ares_strncasecmp(const char *s1, const char *s2, int n); | ||||||
|  | int ares_strcasecmp(const char *s1, const char *s2); | ||||||
|  |  | ||||||
|  | /* use this define magic to prevent us from adding symbol names to the library | ||||||
|  |    that is a high-risk to collide with another libraries' attempts to do the | ||||||
|  |    same */ | ||||||
|  | #define strncasecmp(a,b,c) ares_strncasecmp(a,b,c) | ||||||
|  | #define strcasecmp(a,b) ares_strcasecmp(a,b) | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif /* ARES_SETUP_H */ | #endif /* ARES_SETUP_H */ | ||||||
|   | |||||||
| @@ -109,10 +109,6 @@ SOURCE=..\..\ares_fds.c | |||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_free_errmem.c |  | ||||||
| # End Source File |  | ||||||
| # Begin Source File |  | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_free_hostent.c | SOURCE=..\..\ares_free_hostent.c | ||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
| @@ -157,6 +153,14 @@ SOURCE=..\..\ares_search.c | |||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
|  |  | ||||||
|  | SOURCE=..\..\ares_cancel.c | ||||||
|  | # End Source File | ||||||
|  | # Begin Source File | ||||||
|  |  | ||||||
|  | SOURCE=..\..\ares_version.c | ||||||
|  | # End Source File | ||||||
|  | # Begin Source File | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_send.c | SOURCE=..\..\ares_send.c | ||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
| @@ -185,6 +189,10 @@ SOURCE=..\..\ares_dns.h | |||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
|  |  | ||||||
|  | SOURCE=..\..\ares_version.h | ||||||
|  | # End Source File | ||||||
|  | # Begin Source File | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_private.h | SOURCE=..\..\ares_private.h | ||||||
| # End Source File | # End Source File | ||||||
| # Begin Source File | # Begin Source File | ||||||
|   | |||||||
| @@ -46,7 +46,6 @@ CLEAN : | |||||||
| 	-@erase "$(INTDIR)\ares_destroy.obj" | 	-@erase "$(INTDIR)\ares_destroy.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_expand_name.obj" | 	-@erase "$(INTDIR)\ares_expand_name.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_fds.obj" | 	-@erase "$(INTDIR)\ares_fds.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_free_errmem.obj" |  | ||||||
| 	-@erase "$(INTDIR)\ares_free_hostent.obj" | 	-@erase "$(INTDIR)\ares_free_hostent.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_free_string.obj" | 	-@erase "$(INTDIR)\ares_free_string.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_gethostbyaddr.obj" | 	-@erase "$(INTDIR)\ares_gethostbyaddr.obj" | ||||||
| @@ -82,7 +81,6 @@ LIB32_OBJS= \ | |||||||
| 	"$(INTDIR)\ares_destroy.obj" \ | 	"$(INTDIR)\ares_destroy.obj" \ | ||||||
| 	"$(INTDIR)\ares_expand_name.obj" \ | 	"$(INTDIR)\ares_expand_name.obj" \ | ||||||
| 	"$(INTDIR)\ares_fds.obj" \ | 	"$(INTDIR)\ares_fds.obj" \ | ||||||
| 	"$(INTDIR)\ares_free_errmem.obj" \ |  | ||||||
| 	"$(INTDIR)\ares_free_hostent.obj" \ | 	"$(INTDIR)\ares_free_hostent.obj" \ | ||||||
| 	"$(INTDIR)\ares_free_string.obj" \ | 	"$(INTDIR)\ares_free_string.obj" \ | ||||||
| 	"$(INTDIR)\ares_gethostbyaddr.obj" \ | 	"$(INTDIR)\ares_gethostbyaddr.obj" \ | ||||||
| @@ -94,6 +92,8 @@ LIB32_OBJS= \ | |||||||
| 	"$(INTDIR)\ares_process.obj" \ | 	"$(INTDIR)\ares_process.obj" \ | ||||||
| 	"$(INTDIR)\ares_query.obj" \ | 	"$(INTDIR)\ares_query.obj" \ | ||||||
| 	"$(INTDIR)\ares_search.obj" \ | 	"$(INTDIR)\ares_search.obj" \ | ||||||
|  | 	"$(INTDIR)\ares_cancel.obj" \ | ||||||
|  | 	"$(INTDIR)\ares_version.obj" \ | ||||||
| 	"$(INTDIR)\ares_send.obj" \ | 	"$(INTDIR)\ares_send.obj" \ | ||||||
| 	"$(INTDIR)\ares_strerror.obj" \ | 	"$(INTDIR)\ares_strerror.obj" \ | ||||||
| 	"$(INTDIR)\ares_timeout.obj" \ | 	"$(INTDIR)\ares_timeout.obj" \ | ||||||
| @@ -122,7 +122,6 @@ CLEAN : | |||||||
| 	-@erase "$(INTDIR)\ares_destroy.obj" | 	-@erase "$(INTDIR)\ares_destroy.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_expand_name.obj" | 	-@erase "$(INTDIR)\ares_expand_name.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_fds.obj" | 	-@erase "$(INTDIR)\ares_fds.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_free_errmem.obj" |  | ||||||
| 	-@erase "$(INTDIR)\ares_free_hostent.obj" | 	-@erase "$(INTDIR)\ares_free_hostent.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_free_string.obj" | 	-@erase "$(INTDIR)\ares_free_string.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_gethostbyaddr.obj" | 	-@erase "$(INTDIR)\ares_gethostbyaddr.obj" | ||||||
| @@ -134,6 +133,8 @@ CLEAN : | |||||||
| 	-@erase "$(INTDIR)\ares_process.obj" | 	-@erase "$(INTDIR)\ares_process.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_query.obj" | 	-@erase "$(INTDIR)\ares_query.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_search.obj" | 	-@erase "$(INTDIR)\ares_search.obj" | ||||||
|  | 	-@erase "$(INTDIR)\ares_cancel.obj" | ||||||
|  | 	-@erase "$(INTDIR)\ares_version.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_send.obj" | 	-@erase "$(INTDIR)\ares_send.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_strerror.obj" | 	-@erase "$(INTDIR)\ares_strerror.obj" | ||||||
| 	-@erase "$(INTDIR)\ares_timeout.obj" | 	-@erase "$(INTDIR)\ares_timeout.obj" | ||||||
| @@ -159,7 +160,6 @@ LIB32_OBJS= \ | |||||||
| 	"$(INTDIR)\ares_destroy.obj" \ | 	"$(INTDIR)\ares_destroy.obj" \ | ||||||
| 	"$(INTDIR)\ares_expand_name.obj" \ | 	"$(INTDIR)\ares_expand_name.obj" \ | ||||||
| 	"$(INTDIR)\ares_fds.obj" \ | 	"$(INTDIR)\ares_fds.obj" \ | ||||||
| 	"$(INTDIR)\ares_free_errmem.obj" \ |  | ||||||
| 	"$(INTDIR)\ares_free_hostent.obj" \ | 	"$(INTDIR)\ares_free_hostent.obj" \ | ||||||
| 	"$(INTDIR)\ares_free_string.obj" \ | 	"$(INTDIR)\ares_free_string.obj" \ | ||||||
| 	"$(INTDIR)\ares_gethostbyaddr.obj" \ | 	"$(INTDIR)\ares_gethostbyaddr.obj" \ | ||||||
| @@ -260,12 +260,6 @@ SOURCE=..\..\ares_fds.c | |||||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||||
|  |  | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_free_errmem.c |  | ||||||
|  |  | ||||||
| "$(INTDIR)\ares_free_errmem.obj" : $(SOURCE) "$(INTDIR)" |  | ||||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_free_hostent.c | SOURCE=..\..\ares_free_hostent.c | ||||||
|  |  | ||||||
| "$(INTDIR)\ares_free_hostent.obj" : $(SOURCE) "$(INTDIR)" | "$(INTDIR)\ares_free_hostent.obj" : $(SOURCE) "$(INTDIR)" | ||||||
| @@ -332,6 +326,18 @@ SOURCE=..\..\ares_search.c | |||||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | SOURCE=..\..\ares_version.c | ||||||
|  |  | ||||||
|  | "$(INTDIR)\ares_version.obj" : $(SOURCE) "$(INTDIR)" | ||||||
|  | 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | SOURCE=..\..\ares_cancel.c | ||||||
|  |  | ||||||
|  | "$(INTDIR)\ares_cancel.obj" : $(SOURCE) "$(INTDIR)" | ||||||
|  | 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||||
|  |  | ||||||
|  |  | ||||||
| SOURCE=..\..\ares_send.c | SOURCE=..\..\ares_send.c | ||||||
|  |  | ||||||
| "$(INTDIR)\ares_send.obj" : $(SOURCE) "$(INTDIR)" | "$(INTDIR)\ares_send.obj" : $(SOURCE) "$(INTDIR)" | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #ifdef WIN32 /* only do the following on windows */ | /* only do the following on windows | ||||||
|  |  */ | ||||||
|  | #if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS) | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <ctype.h> | #include <ctype.h> | ||||||
| @@ -8,13 +10,19 @@ | |||||||
| #include <errno.h> | #include <errno.h> | ||||||
| #include <malloc.h> | #include <malloc.h> | ||||||
|  |  | ||||||
|  | #ifdef WATT32 | ||||||
|  | #include <sys/socket.h> | ||||||
|  | #else | ||||||
| #include "nameser.h" | #include "nameser.h" | ||||||
|  | #endif | ||||||
|  | #include "ares.h" | ||||||
|  | #include "ares_private.h" | ||||||
|  |  | ||||||
| #ifndef __MINGW32__ | #ifndef __MINGW32__ | ||||||
| int | int | ||||||
| ares_strncasecmp(const char *a, const char *b, size_t n) | ares_strncasecmp(const char *a, const char *b, int n) | ||||||
| { | { | ||||||
|     size_t i; |     int i; | ||||||
|  |  | ||||||
|     for (i = 0; i < n; i++) { |     for (i = 0; i < n; i++) { | ||||||
|         int c1 = isupper(a[i]) ? tolower(a[i]) : a[i]; |         int c1 = isupper(a[i]) ? tolower(a[i]) : a[i]; | ||||||
| @@ -31,33 +39,39 @@ ares_strcasecmp(const char *a, const char *b) | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Number of micro-seconds between the beginning of the Windows epoch | ||||||
|  |  * (Jan. 1, 1601) and the Unix epoch (Jan. 1, 1970). | ||||||
|  |  */ | ||||||
|  | #if defined(_MSC_VER) || defined(__WATCOMC__) | ||||||
|  | #define EPOCH_FILETIME 11644473600000000Ui64 | ||||||
|  | #else | ||||||
|  | #define EPOCH_FILETIME 11644473600000000ULL | ||||||
|  | #endif | ||||||
|  |  | ||||||
| int | int | ||||||
| ares_gettimeofday(struct timeval *tv, struct timezone *tz) | ares_gettimeofday(struct timeval *tv, struct timezone *tz) | ||||||
| { | { | ||||||
|     FILETIME        ft; |     FILETIME        ft; | ||||||
|     LARGE_INTEGER   li; |     LARGE_INTEGER   li; | ||||||
|     __int64         t; |     __int64         t; | ||||||
|     static int      tzflag; |  | ||||||
|  |  | ||||||
|     if (tv) |     if (tv) | ||||||
|     { |     { | ||||||
|         GetSystemTimeAsFileTime(&ft); |         GetSystemTimeAsFileTime(&ft); | ||||||
|         li.LowPart  = ft.dwLowDateTime; |         li.LowPart  = ft.dwLowDateTime; | ||||||
|         li.HighPart = ft.dwHighDateTime; |         li.HighPart = ft.dwHighDateTime; | ||||||
|         t  = li.QuadPart;       /* In 100-nanosecond intervals */ |         t  = li.QuadPart / 10;   /* In micro-second intervals */ | ||||||
| #if 0 |         t -= EPOCH_FILETIME;     /* Offset to the Epoch time */ | ||||||
|         t -= EPOCHFILETIME;     /* Offset to the Epoch time */ |  | ||||||
| #endif |  | ||||||
|         t /= 10;                /* In microseconds */ |  | ||||||
|         tv->tv_sec  = (long)(t / 1000000); |         tv->tv_sec  = (long)(t / 1000000); | ||||||
|         tv->tv_usec = (long)(t % 1000000); |         tv->tv_usec = (long)(t % 1000000); | ||||||
|     } |     } | ||||||
|  |     (void) tz; | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int | int | ||||||
| ares_writev (SOCKET s, const struct iovec *vector, size_t count) | ares_writev (ares_socket_t s, const struct iovec *vector, size_t count) | ||||||
| { | { | ||||||
|   char *buffer, *bp; |   char *buffer, *bp; | ||||||
|   size_t i, bytes = 0; |   size_t i, bytes = 0; | ||||||
|   | |||||||
| @@ -101,6 +101,10 @@ libtool=`findtool glibtool 2>/dev/null` | |||||||
| if test ! -x "$libtool"; then | if test ! -x "$libtool"; then | ||||||
|   libtool=`findtool libtool` |   libtool=`findtool libtool` | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | # set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found | ||||||
|  | LIBTOOLIZE="${libtool}ize" | ||||||
|  |  | ||||||
| lt_pversion=`$libtool --version 2>/dev/null|head -1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | lt_pversion=`$libtool --version 2>/dev/null|head -1|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." | ||||||
|   | |||||||
| @@ -7,9 +7,6 @@ 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 | echo #define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE") >>lib\ca-bundle.h | ||||||
|  |  | ||||||
| REM create getdate.c |  | ||||||
| copy lib\getdate.c.cvs lib\getdate.c |  | ||||||
|  |  | ||||||
| REM create hugehelp.c | REM create hugehelp.c | ||||||
| copy src\hugehelp.c.cvs src\hugehelp.c | copy src\hugehelp.c.cvs src\hugehelp.c | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										364
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										364
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -55,7 +55,7 @@ AC_SUBST(PKGADD_NAME) | |||||||
| AC_SUBST(PKGADD_VENDOR) | AC_SUBST(PKGADD_VENDOR) | ||||||
|  |  | ||||||
| dnl | dnl | ||||||
| dnl initialize all the info variables to 'no' | dnl initialize all the info variables | ||||||
|     curl_ssl_msg="no      (--with-ssl)" |     curl_ssl_msg="no      (--with-ssl)" | ||||||
|    curl_zlib_msg="no      (--with-zlib)" |    curl_zlib_msg="no      (--with-zlib)" | ||||||
|    curl_krb4_msg="no      (--with-krb4*)" |    curl_krb4_msg="no      (--with-krb4*)" | ||||||
| @@ -65,6 +65,7 @@ dnl initialize all the info variables to 'no' | |||||||
|    curl_ipv6_msg="no      (--enable-ipv6)" |    curl_ipv6_msg="no      (--enable-ipv6)" | ||||||
|     curl_idn_msg="no      (--with-libidn)" |     curl_idn_msg="no      (--with-libidn)" | ||||||
|  curl_manual_msg="no      (--enable-manual)" |  curl_manual_msg="no      (--enable-manual)" | ||||||
|  | curl_verbose_msg="enabled (--disable-verbose)" | ||||||
|  |  | ||||||
| dnl | dnl | ||||||
| dnl Detect the canonical host and target build environment | dnl Detect the canonical host and target build environment | ||||||
| @@ -102,6 +103,7 @@ AC_MSG_RESULT($need_no_undefined) | |||||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([if we need -mimpure-text]) | AC_MSG_CHECKING([if we need -mimpure-text]) | ||||||
|  | mimpure=no | ||||||
| case $host in | case $host in | ||||||
|   *-*-solaris2*) |   *-*-solaris2*) | ||||||
|     if test "$GCC" = "yes"; then |     if test "$GCC" = "yes"; then | ||||||
| @@ -109,7 +111,6 @@ case $host in | |||||||
|     fi |     fi | ||||||
|     ;; |     ;; | ||||||
|   *) |   *) | ||||||
|     mimpure=no |  | ||||||
|     ;; |     ;; | ||||||
| esac | esac | ||||||
| AC_MSG_RESULT($mimpure) | AC_MSG_RESULT($mimpure) | ||||||
| @@ -287,7 +288,7 @@ then | |||||||
|   AC_TRY_LINK( , |   AC_TRY_LINK( , | ||||||
|              [gethostbyname();], |              [gethostbyname();], | ||||||
|              [ dnl found it! |              [ dnl found it! | ||||||
|              HAVE_GETHOSTBYNAME="1", |              HAVE_GETHOSTBYNAME="1" | ||||||
|              AC_MSG_RESULT([yes])], |              AC_MSG_RESULT([yes])], | ||||||
|              [ dnl failed! |              [ dnl failed! | ||||||
|              AC_MSG_RESULT([no]) |              AC_MSG_RESULT([no]) | ||||||
| @@ -432,35 +433,6 @@ AC_HELP_STRING([--disable-nonblocking],[Disable non-blocking socket detection]), | |||||||
|   CURL_CHECK_NONBLOCKING_SOCKET |   CURL_CHECK_NONBLOCKING_SOCKET | ||||||
| ]) | ]) | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for the random seed preferences  |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| AC_ARG_WITH(egd-socket, |  | ||||||
| AC_HELP_STRING([--with-egd-socket=FILE], |  | ||||||
|                [Entropy Gathering Daemon socket pathname]), |  | ||||||
|     [ EGD_SOCKET="$withval" ] |  | ||||||
| ) |  | ||||||
| if test -n "$EGD_SOCKET" ; then |  | ||||||
| 	AC_DEFINE_UNQUOTED(EGD_SOCKET, "$EGD_SOCKET", |  | ||||||
|         [your Entropy Gathering Daemon socket pathname] ) |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl Check for user-specified random device |  | ||||||
| AC_ARG_WITH(random, |  | ||||||
| AC_HELP_STRING([--with-random=FILE],[read randomness from FILE (default=/dev/urandom)]), |  | ||||||
|     [ RANDOM_FILE="$withval" ], |  | ||||||
|     [ |  | ||||||
|         dnl Check for random device |  | ||||||
|         AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] ) |  | ||||||
|     ] |  | ||||||
| ) |  | ||||||
| if test -n "$RANDOM_FILE" ; then |  | ||||||
| 	AC_SUBST(RANDOM_FILE) |  | ||||||
| 	AC_DEFINE_UNQUOTED(RANDOM_FILE, "$RANDOM_FILE", |  | ||||||
|         [a suitable file to read random data from]) |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Check if the operating system allows programs to write to their own argv[] | dnl Check if the operating system allows programs to write to their own argv[] | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -647,7 +619,7 @@ if test x"$want_gss" = xyes; then | |||||||
|   if test -z "$GSSAPI_INCS"; then |   if test -z "$GSSAPI_INCS"; then | ||||||
|      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then |      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then | ||||||
|         GSSAPI_INCS=`$GSSAPI_ROOT/bin/krb5-config --cflags gssapi` |         GSSAPI_INCS=`$GSSAPI_ROOT/bin/krb5-config --cflags gssapi` | ||||||
|      else |      elif test "$GSSAPI_ROOT" != "yes"; then | ||||||
|         GSSAPI_INCS="-I$GSSAPI_ROOT/include" |         GSSAPI_INCS="-I$GSSAPI_ROOT/include" | ||||||
|      fi |      fi | ||||||
|   fi |   fi | ||||||
| @@ -657,8 +629,10 @@ if test x"$want_gss" = xyes; then | |||||||
|      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then |      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then | ||||||
|         gss_ldflags=`$GSSAPI_ROOT/bin/krb5-config --libs gssapi` |         gss_ldflags=`$GSSAPI_ROOT/bin/krb5-config --libs gssapi` | ||||||
| 	LDFLAGS="$LDFLAGS $gss_ldflags" | 	LDFLAGS="$LDFLAGS $gss_ldflags" | ||||||
|      else |      elif test "$GSSAPI_ROOT" != "yes"; then | ||||||
|         LDFLAGS="$LDFLAGS -L$GSSAPI_ROOT/lib$libsuff -lgssapi" |         LDFLAGS="$LDFLAGS -L$GSSAPI_ROOT/lib$libsuff -lgssapi" | ||||||
|  |      else | ||||||
|  |         LDFLAGS="$LDFLAGS -lgssapi" | ||||||
|      fi |      fi | ||||||
|   else |   else | ||||||
|      LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR" |      LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR" | ||||||
| @@ -669,16 +643,20 @@ if test x"$want_gss" = xyes; then | |||||||
|  |  | ||||||
|   curl_gss_msg="enabled" |   curl_gss_msg="enabled" | ||||||
|  |  | ||||||
|   if test -n "$GSSAPI_INCS"; then |   AC_CHECK_HEADER(gssapi.h, | ||||||
|     # cut off the preceding -I from the include path |     [ | ||||||
|     GSSAPI_INCS=`echo $GSSAPI_INCS | sed -e s/^-I//g` |        dnl found in the given dirs | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   if test -f "$GSSAPI_INCS/gssapi.h"; then |  | ||||||
|       AC_DEFINE(HAVE_GSSHEIMDAL, 1, [if you have the Heimdal gssapi libraries]) |       AC_DEFINE(HAVE_GSSHEIMDAL, 1, [if you have the Heimdal gssapi libraries]) | ||||||
|   else |     ], | ||||||
|  |     [ | ||||||
|  |       dnl not found, check in gssapi/ subdir  | ||||||
|  |       AC_CHECK_HEADER(gssapi/gssapi.h, | ||||||
|  |         dnl found  | ||||||
|         AC_DEFINE(HAVE_GSSMIT, 1, [if you have the MIT gssapi libraries]) |         AC_DEFINE(HAVE_GSSMIT, 1, [if you have the MIT gssapi libraries]) | ||||||
|   fi |       ) | ||||||
|  |        | ||||||
|  |     ] | ||||||
|  |   ) | ||||||
|  |  | ||||||
| else | else | ||||||
|   AC_MSG_RESULT(no) |   AC_MSG_RESULT(no) | ||||||
| @@ -707,9 +685,35 @@ else | |||||||
|   CLEANCPPFLAGS="$CPPFLAGS" |   CLEANCPPFLAGS="$CPPFLAGS" | ||||||
|   CLEANLIBS="$LIBS" |   CLEANLIBS="$LIBS" | ||||||
|  |  | ||||||
|   dnl Detect the pkg-config tool, as it may have extra info about the openssl |   case "$OPT_SSL" in | ||||||
|   dnl installation we can use. I *believe* this is what we are expected to do |   yes) | ||||||
|   dnl on really recent Redhat Linux hosts. |     dnl --with-ssl (without path) used | ||||||
|  |     if test x$cross_compiling != xyes; then | ||||||
|  |       dnl only do pkg-config magic when not cross-compiling | ||||||
|  |       PKGTEST="yes" | ||||||
|  |     fi | ||||||
|  |     EXTRA_SSL=/usr/local/ssl ;; | ||||||
|  |   off) | ||||||
|  |     dnl no --with-ssl option given, just check default places | ||||||
|  |     if test x$cross_compiling != xyes; then | ||||||
|  |       dnl only do pkg-config magic when not cross-compiling | ||||||
|  |       PKGTEST="yes" | ||||||
|  |     fi | ||||||
|  |     EXTRA_SSL= ;; | ||||||
|  |   *) | ||||||
|  |     dnl check the given --with-ssl spot | ||||||
|  |     PKGTEST="no" | ||||||
|  |     EXTRA_SSL=$OPT_SSL | ||||||
|  |     LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib$libsuff" | ||||||
|  |     CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" | ||||||
|  |     ;; | ||||||
|  |   esac | ||||||
|  |  | ||||||
|  |   if test "$PKGTEST" = "yes"; then | ||||||
|  |  | ||||||
|  |     dnl Detect the pkg-config tool, as it may have extra info about the | ||||||
|  |     dnl openssl installation we can use. I *believe* this is what we are | ||||||
|  |     dnl expected to do on really recent Redhat Linux hosts. | ||||||
|  |  | ||||||
|     AC_PATH_PROG( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin) |     AC_PATH_PROG( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin) | ||||||
|     if test "$PKGCONFIG" != "no" ; then |     if test "$PKGCONFIG" != "no" ; then | ||||||
| @@ -732,19 +736,7 @@ else | |||||||
|         AC_MSG_RESULT([no]) |         AC_MSG_RESULT([no]) | ||||||
|       fi |       fi | ||||||
|     fi |     fi | ||||||
|  |   fi | ||||||
|   case "$OPT_SSL" in |  | ||||||
|   yes) |  | ||||||
|     EXTRA_SSL=/usr/local/ssl ;; |  | ||||||
|   off) |  | ||||||
|     EXTRA_SSL= ;; |  | ||||||
|   *) |  | ||||||
|     dnl check the given spot right away! |  | ||||||
|     EXTRA_SSL=$OPT_SSL |  | ||||||
|     LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib$libsuff" |  | ||||||
|     CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" |  | ||||||
|     ;; |  | ||||||
|   esac |  | ||||||
|  |  | ||||||
|   AC_CHECK_LIB(crypto, CRYPTO_lock,[ |   AC_CHECK_LIB(crypto, CRYPTO_lock,[ | ||||||
|      HAVECRYPTO="yes" |      HAVECRYPTO="yes" | ||||||
| @@ -760,7 +752,10 @@ else | |||||||
|     ]) |     ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|   if test "$HAVECRYPTO" = "yes"; then |   if test X"$HAVECRYPTO" != X"yes"; then | ||||||
|  |       AC_MSG_WARN([crypto lib was not found; SSL will be disabled]) | ||||||
|  |  | ||||||
|  |   else | ||||||
|     dnl This is only reasonable to do if crypto actually is there: check for |     dnl This is only reasonable to do if crypto actually is there: check for | ||||||
|     dnl SSL libs NOTE: it is important to do this AFTER the crypto lib |     dnl SSL libs NOTE: it is important to do this AFTER the crypto lib | ||||||
|  |  | ||||||
| @@ -794,27 +789,48 @@ else | |||||||
|         else |         else | ||||||
|             AC_MSG_RESULT(yes) |             AC_MSG_RESULT(yes) | ||||||
|         fi |         fi | ||||||
|     fi |  | ||||||
|  |  | ||||||
|  |     else | ||||||
|  |  | ||||||
|     dnl Check for SSLeay headers |       dnl Have the libraries--check for SSLeay/OpenSSL headers | ||||||
|       AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \ |       AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \ | ||||||
|                        openssl/pem.h openssl/ssl.h openssl/err.h, |                        openssl/pem.h openssl/ssl.h openssl/err.h, | ||||||
|         curl_ssl_msg="enabled" |         curl_ssl_msg="enabled" | ||||||
|       OPENSSL_ENABLED=1) |         OPENSSL_ENABLED=1 | ||||||
|  |         AC_DEFINE(USE_OPENSSL, 1, [if OpenSSL is in use])) | ||||||
|  |  | ||||||
|       if test $ac_cv_header_openssl_x509_h = no; then |       if test $ac_cv_header_openssl_x509_h = no; then | ||||||
|         AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h, |         AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h, | ||||||
|           curl_ssl_msg="enabled" |           curl_ssl_msg="enabled" | ||||||
|           OPENSSL_ENABLED=1) |           OPENSSL_ENABLED=1) | ||||||
|       fi |       fi | ||||||
|  |     fi | ||||||
|  |  | ||||||
|  |     if test X"$OPENSSL_ENABLED" = X"1"; then | ||||||
|  |        AC_DEFINE(USE_SSLEAY, 1, [if SSL is enabled]) | ||||||
|  |  | ||||||
|  |        dnl is there a pkcs12.h header present? | ||||||
|  |        AC_CHECK_HEADERS(openssl/pkcs12.h) | ||||||
|  |     fi | ||||||
|  |     USE_SSLEAY="$OPENSSL_ENABLED" | ||||||
|  |     AC_SUBST(USE_SSLEAY) | ||||||
|  |  | ||||||
|  |     if test X"$OPT_SSL" != Xoff && | ||||||
|  |        test "$OPENSSL_ENABLED" != "1"; then | ||||||
|  |       AC_MSG_ERROR([OpenSSL libs and/or directories were not found where specified!]) | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check for the CA bundle | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  |   if test X"$OPENSSL_ENABLED" = X"1"; then | ||||||
|     dnl If the ENGINE library seems to be around, check for the OpenSSL engine |     dnl If the ENGINE library seems to be around, check for the OpenSSL engine | ||||||
|     dnl header, it is kind of "separated" from the main SSL check |     dnl header, it is kind of "separated" from the main SSL check | ||||||
|     AC_CHECK_FUNC(ENGINE_init, [ AC_CHECK_HEADERS(openssl/engine.h) ]) |     AC_CHECK_FUNC(ENGINE_init, [ AC_CHECK_HEADERS(openssl/engine.h) ]) | ||||||
|  |  | ||||||
|     AC_SUBST(OPENSSL_ENABLED) |  | ||||||
|  |  | ||||||
|     AC_MSG_CHECKING([CA cert bundle install path]) |     AC_MSG_CHECKING([CA cert bundle install path]) | ||||||
|  |  | ||||||
|     AC_ARG_WITH(ca-bundle, |     AC_ARG_WITH(ca-bundle, | ||||||
| @@ -848,15 +864,50 @@ AC_HELP_STRING([--without-ca-bundle], [Don't install the CA bundle]), | |||||||
|  |  | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   if test X"$OPT_SSL" != Xoff && |   if test "$OPENSSL_ENABLED" = "1"; then | ||||||
|      test "$OPENSSL_ENABLED" != "1"; then |     dnl when the ssl shared libs were found in a path that the run-time linker | ||||||
|     AC_MSG_ERROR([OpenSSL libs and/or directories were not found where specified!]) |     dnl doesn't search through, we need to add it to LD_LIBRARY_PATH to | ||||||
|  |     dnl prevent further configure tests to fail due to this | ||||||
|  |     LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$EXTRA_SSL/lib$libsuff" | ||||||
|  |     export LD_LIBRARY_PATH | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
| fi | fi | ||||||
|  |  | ||||||
| AM_CONDITIONAL(CABUNDLE, test x$ca != xno) | AM_CONDITIONAL(CABUNDLE, test x$ca != xno) | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check for the random seed preferences  | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | if test X"$OPENSSL_ENABLED" = X"1"; then | ||||||
|  |   AC_ARG_WITH(egd-socket, | ||||||
|  |   AC_HELP_STRING([--with-egd-socket=FILE], | ||||||
|  |                  [Entropy Gathering Daemon socket pathname]), | ||||||
|  |       [ EGD_SOCKET="$withval" ] | ||||||
|  |   ) | ||||||
|  |   if test -n "$EGD_SOCKET" ; then | ||||||
|  |           AC_DEFINE_UNQUOTED(EGD_SOCKET, "$EGD_SOCKET", | ||||||
|  |           [your Entropy Gathering Daemon socket pathname] ) | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  |   dnl Check for user-specified random device | ||||||
|  |   AC_ARG_WITH(random, | ||||||
|  |   AC_HELP_STRING([--with-random=FILE], | ||||||
|  |                  [read randomness from FILE (default=/dev/urandom)]), | ||||||
|  |       [ RANDOM_FILE="$withval" ], | ||||||
|  |       [ | ||||||
|  |           dnl Check for random device | ||||||
|  |           AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] ) | ||||||
|  |       ] | ||||||
|  |   ) | ||||||
|  |   if test -n "$RANDOM_FILE" && test X"$RANDOM_FILE" != Xno ; then | ||||||
|  |           AC_SUBST(RANDOM_FILE) | ||||||
|  |           AC_DEFINE_UNQUOTED(RANDOM_FILE, "$RANDOM_FILE", | ||||||
|  |           [a suitable file to read random data from]) | ||||||
|  |   fi | ||||||
|  | fi | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Check for the presence of ZLIB libraries and headers | dnl Check for the presence of ZLIB libraries and headers | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -945,27 +996,36 @@ case "$LIBIDN" in | |||||||
|        AC_MSG_RESULT(no) |        AC_MSG_RESULT(no) | ||||||
|        ;; |        ;; | ||||||
|   *)   AC_MSG_RESULT(yes) |   *)   AC_MSG_RESULT(yes) | ||||||
|        AC_CHECK_LIB(idn, idna_to_ascii_lz, , |  | ||||||
|                     [ |        idn="" | ||||||
|                     dnl if there was a given path, try it |        dnl if there is a given path, check that FIRST | ||||||
|                     nolibidn="true" |        if test -n "$LIBIDN"; then | ||||||
|          if test "x$LIBIDN" != "xyes"; then |          if test "x$LIBIDN" != "xyes"; then | ||||||
|                       nolibidn="" dnl reset to test again |             AC_MSG_WARN([moo moo $LIBIDN]) | ||||||
|             oldLDFLAGS=$LDFLAGS |             oldLDFLAGS=$LDFLAGS | ||||||
|             oldCPPFLAGS=$CPPFLAGS |             oldCPPFLAGS=$CPPFLAGS | ||||||
|             LDFLAGS="$LDFLAGS -L$LIBIDN/lib" |             LDFLAGS="$LDFLAGS -L$LIBIDN/lib" | ||||||
|             CPPFLAGS="$CPPFLAGS -I$LIBIDN/include" |             CPPFLAGS="$CPPFLAGS -I$LIBIDN/include" | ||||||
|  |             idn="yes" | ||||||
|             AC_CHECK_LIB(idn, idna_to_ascii_4i, , |             AC_CHECK_LIB(idn, idna_to_ascii_4i, , | ||||||
|                                    nolibidn="true" |                          idn="" | ||||||
|                          LDFLAGS=$oldLDFLAGS |                          LDFLAGS=$oldLDFLAGS | ||||||
|                          CPPFLAGS=$oldCPPFLAGS) |                          CPPFLAGS=$oldCPPFLAGS) | ||||||
|          fi |          fi | ||||||
|                     ]) |        fi | ||||||
|        if test "x$nolibidn" != "xtrue"; then |  | ||||||
|  |        if test "x$idn" != "xyes"; then | ||||||
|  |           dnl check with default paths | ||||||
|  |           idn="yes" | ||||||
|  |           AC_CHECK_LIB(idn, idna_to_ascii_lz, , | ||||||
|  |                        idn="") | ||||||
|  |        fi | ||||||
|  |  | ||||||
|  |        if test "x$idn" = "xyes"; then | ||||||
|          curl_idn_msg="enabled" |          curl_idn_msg="enabled" | ||||||
|          dnl different versions of libidn have different setups of these: |          dnl different versions of libidn have different setups of these: | ||||||
|          AC_CHECK_FUNCS( idn_free ) |          AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror) | ||||||
|          AC_CHECK_HEADERS( idn-free.h ) |          AC_CHECK_HEADERS( idn-free.h tld.h ) | ||||||
|        fi |        fi | ||||||
|                      |                      | ||||||
|        ;;  |        ;;  | ||||||
| @@ -1038,6 +1098,24 @@ dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \ | |||||||
| dnl genprogc/thread_quick_ref.htm | dnl genprogc/thread_quick_ref.htm | ||||||
|  |  | ||||||
| if test "x$RECENTAIX" = "xyes"; then | if test "x$RECENTAIX" = "xyes"; then | ||||||
|  |  | ||||||
|  |   AC_DEFINE(_THREAD_SAFE, 1, [define this if you need it to compile thread-safe code]) | ||||||
|  |  | ||||||
|  |   dnl check if this is the IMB xlc compiler | ||||||
|  |   dnl Details thanks to => http://predef.sourceforge.net/ | ||||||
|  |   AC_MSG_CHECKING([if this is the xlc compiler]) | ||||||
|  |   AC_EGREP_CPP([^__xlC__], [__xlC__], | ||||||
|  |          dnl action if the text is found, this it has not been replaced by the | ||||||
|  |          dnl cpp | ||||||
|  |          XLC="no" | ||||||
|  |          AC_MSG_RESULT([no]), | ||||||
|  |          dnl the text was not found, it was replaced by the cpp | ||||||
|  |          XLC="yes" | ||||||
|  |          AC_MSG_RESULT([yes]) | ||||||
|  |          CFLAGS="$CFLAGS -qthreaded" | ||||||
|  |        ) | ||||||
|  |  | ||||||
|  |  | ||||||
|   dnl is there a localtime_r() |   dnl is there a localtime_r() | ||||||
|   CURL_CHECK_LOCALTIME_R() |   CURL_CHECK_LOCALTIME_R() | ||||||
|  |  | ||||||
| @@ -1083,12 +1161,16 @@ AC_CHECK_HEADERS( | |||||||
|         dlfcn.h \ |         dlfcn.h \ | ||||||
|         alloca.h \ |         alloca.h \ | ||||||
|         winsock.h \ |         winsock.h \ | ||||||
|  |         winsock2.h \ | ||||||
|         time.h \ |         time.h \ | ||||||
|         io.h \ |         io.h \ | ||||||
|         pwd.h \ |         pwd.h \ | ||||||
|         utime.h \ |         utime.h \ | ||||||
|         sys/utime.h \ |         sys/utime.h \ | ||||||
|         sys/poll.h \ |         sys/poll.h \ | ||||||
|  |         sys/resource.h \ | ||||||
|  |         libgen.h \ | ||||||
|  |         locale.h \ | ||||||
|         setjmp.h, |         setjmp.h, | ||||||
| dnl to do if not found | dnl to do if not found | ||||||
| [], | [], | ||||||
| @@ -1124,9 +1206,23 @@ AC_CHECK_SIZEOF(curl_off_t, ,[ | |||||||
| #include "$srcdir/include/curl/curl.h" | #include "$srcdir/include/curl/curl.h" | ||||||
| ]) | ]) | ||||||
| AC_CHECK_SIZEOF(size_t) | AC_CHECK_SIZEOF(size_t) | ||||||
|  | AC_CHECK_SIZEOF(long) | ||||||
|  | AC_CHECK_SIZEOF(time_t) | ||||||
|  |  | ||||||
| AC_CHECK_TYPE(long long, | AC_CHECK_TYPE(long long, | ||||||
|    [AC_DEFINE(HAVE_LONGLONG, 1, [if your compiler supports 'long long'])]) |    [AC_DEFINE(HAVE_LONGLONG, 1, [if your compiler supports long long])] | ||||||
|  |    longlong="yes"   | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | if test "xyes" = "x$longlong"; then | ||||||
|  |   AC_MSG_CHECKING([if numberLL works]) | ||||||
|  |   AC_COMPILE_IFELSE([long long val = 1000LL;], | ||||||
|  |    [AC_DEFINE(HAVE_LL, 1, [if your compiler supports LL])] | ||||||
|  |    AC_MSG_RESULT(yes), | ||||||
|  |    AC_MSG_RESULT(no) | ||||||
|  |   ) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
| # check for ssize_t | # check for ssize_t | ||||||
| AC_CHECK_TYPE(ssize_t, , | AC_CHECK_TYPE(ssize_t, , | ||||||
| @@ -1171,7 +1267,13 @@ AC_CHECK_FUNCS( strtoll \ | |||||||
|                 dlopen \ |                 dlopen \ | ||||||
|                 utime \ |                 utime \ | ||||||
|                 sigsetjmp \ |                 sigsetjmp \ | ||||||
|                 poll, |                 basename \ | ||||||
|  |                 setlocale \ | ||||||
|  |                 ftruncate \ | ||||||
|  |                 pipe \ | ||||||
|  |                 poll \ | ||||||
|  |                 getrlimit \ | ||||||
|  |                 setrlimit, | ||||||
| dnl if found | dnl if found | ||||||
| [], | [], | ||||||
| dnl if not found, $ac_func is the name we check for | dnl if not found, $ac_func is the name we check for | ||||||
| @@ -1188,6 +1290,20 @@ dnl if not found, $ac_func is the name we check for | |||||||
|  |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | dnl For some reason, the check above doesn't properly detect select() with | ||||||
|  | dnl Msys/Mingw | ||||||
|  | if test "$ac_cv_func_select" != "yes"; then | ||||||
|  |   AC_MSG_CHECKING([for select in ws2_32]) | ||||||
|  |   AC_TRY_LINK([#include <winsock2.h>], | ||||||
|  |                [select(0,(fd_set *)NULL,(fd_set *)NULL,(fd_set *)NULL,(struct timeval *)NULL);], | ||||||
|  |                [ dnl worked! | ||||||
|  |                AC_MSG_RESULT([yes]) | ||||||
|  |                HAVE_SELECT="1" | ||||||
|  |                AC_DEFINE_UNQUOTED(HAVE_SELECT,1)], | ||||||
|  |                [AC_MSG_ERROR(You can't compile without a select)] | ||||||
|  |              ) | ||||||
|  | fi | ||||||
|  |  | ||||||
| dnl sigsetjmp() might be a macro and no function so if it isn't found already | dnl sigsetjmp() might be a macro and no function so if it isn't found already | ||||||
| dnl we make an extra check here! | dnl we make an extra check here! | ||||||
| if test "$ac_cv_func_sigsetjmp" != "yes"; then | if test "$ac_cv_func_sigsetjmp" != "yes"; then | ||||||
| @@ -1201,6 +1317,16 @@ if test "$ac_cv_func_sigsetjmp" != "yes"; then | |||||||
|                ) |                ) | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | AC_CHECK_DECL(basename, , | ||||||
|  |               AC_DEFINE(NEED_BASENAME_PROTO, 1, [If you lack a fine basename() prototype]), | ||||||
|  | #ifdef HAVE_STRING_H | ||||||
|  | #include <string.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_LIBGEN_H | ||||||
|  | #include <libgen.h> | ||||||
|  | #endif | ||||||
|  | ) | ||||||
|  |  | ||||||
| dnl poll() might be badly emulated, as in Mac OS X 10.3 (and other BSDs?) and | dnl poll() might be badly emulated, as in Mac OS X 10.3 (and other BSDs?) and | ||||||
| dnl to find out we make an extra check here! | dnl to find out we make an extra check here! | ||||||
| if test "$ac_cv_func_poll" = "yes"; then | if test "$ac_cv_func_poll" = "yes"; then | ||||||
| @@ -1264,22 +1390,6 @@ then | |||||||
|   USE_MANUAL="no"; |   USE_MANUAL="no"; | ||||||
| fi | fi | ||||||
|  |  | ||||||
| AC_PROG_YACC |  | ||||||
|  |  | ||||||
| if test -z "$YACC" |  | ||||||
| then |  | ||||||
|   AC_MSG_CHECKING([if OK to build without bison/yacc]) |  | ||||||
|   dnl no yacc is a big deal if we have no pre-fixed getdate.y |  | ||||||
|   if test -r "$srcdir/lib/getdate.c" |  | ||||||
|   then |  | ||||||
|     dnl all is well, we don't have to generate it! |  | ||||||
|     AC_MSG_RESULT(yes) |  | ||||||
|   else |  | ||||||
|     AC_MSG_RESULT(no) |  | ||||||
|     AC_MSG_ERROR([no yacc or bison found, can't build libcurl!]) |  | ||||||
|   fi |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl ************************************************************************* | dnl ************************************************************************* | ||||||
| dnl If the manual variable still is set, then we go with providing a built-in | dnl If the manual variable still is set, then we go with providing a built-in | ||||||
| dnl manual | dnl manual | ||||||
| @@ -1365,6 +1475,26 @@ int main(void) | |||||||
|        AC_MSG_RESULT(no) |        AC_MSG_RESULT(no) | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | dnl ************************************************************ | ||||||
|  | dnl disable verbose text strings | ||||||
|  | dnl | ||||||
|  | AC_MSG_CHECKING([whether to enable verbose strings]) | ||||||
|  | AC_ARG_ENABLE(verbose, | ||||||
|  | AC_HELP_STRING([--enable-verbose],[Enable verbose strings]) | ||||||
|  | AC_HELP_STRING([--disable-verbose],[Disable verbose strings]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_VERBOSE_STRINGS, 1, [to disable verbose strings]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_VERBOSE_STRINGS) | ||||||
|  |        curl_verbose_msg="no" | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  |  | ||||||
| dnl ************************************************************ | dnl ************************************************************ | ||||||
| dnl lame option to switch on debug options | dnl lame option to switch on debug options | ||||||
| dnl | dnl | ||||||
| @@ -1390,6 +1520,44 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | |||||||
|        AC_MSG_RESULT(no) |        AC_MSG_RESULT(no) | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | dnl ************************************************************ | ||||||
|  | dnl disable cryptographic authentication | ||||||
|  | dnl | ||||||
|  | AC_MSG_CHECKING([whether to enable cryptographic authentication methods]) | ||||||
|  | AC_ARG_ENABLE(crypto-auth, | ||||||
|  | AC_HELP_STRING([--enable-crypto-auth],[Enable cryptographic authentication]) | ||||||
|  | AC_HELP_STRING([--disable-crypto-auth],[Disable cryptographic authentication]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_CRYPTO_AUTH, 1, [to disable cryptographic authentication]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_CRYPTO_AUTH) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | dnl ************************************************************ | ||||||
|  | dnl disable cookies support | ||||||
|  | dnl | ||||||
|  | AC_MSG_CHECKING([whether to enable support for cookies]) | ||||||
|  | AC_ARG_ENABLE(cookies, | ||||||
|  | AC_HELP_STRING([--enable-cookies],[Enable cookies support]) | ||||||
|  | AC_HELP_STRING([--disable-cookies],[Disable cookies support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_COOKIES, 1, [to disable cookies support]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_COOKIES) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  |  | ||||||
| AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes) | AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes) | ||||||
|  |  | ||||||
| AC_CONFIG_FILES([Makefile \ | AC_CONFIG_FILES([Makefile \ | ||||||
| @@ -1416,7 +1584,8 @@ AC_CONFIG_FILES([Makefile \ | |||||||
|            packages/EPM/curl.list \ |            packages/EPM/curl.list \ | ||||||
|            packages/EPM/Makefile \ |            packages/EPM/Makefile \ | ||||||
|            packages/vms/Makefile \ |            packages/vms/Makefile \ | ||||||
|            curl-config |            curl-config \ | ||||||
|  |            libcurl.pc | ||||||
| ]) | ]) | ||||||
| AC_OUTPUT | AC_OUTPUT | ||||||
|  |  | ||||||
| @@ -1430,10 +1599,11 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | |||||||
|   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} | ||||||
|   SNPEGO support:  ${curl_spnego_msg} |   SPNEGO support:  ${curl_spnego_msg} | ||||||
|   c-ares support:  ${curl_ares_msg} |   c-ares support:  ${curl_ares_msg} | ||||||
|   ipv6 support:    ${curl_ipv6_msg} |   ipv6 support:    ${curl_ipv6_msg} | ||||||
|   IDN support:     ${curl_idn_msg} |   IDN support:     ${curl_idn_msg} | ||||||
|   Build libcurl:   Shared=${enable_shared}, Static=${enable_static}  |   Build libcurl:   Shared=${enable_shared}, Static=${enable_static}  | ||||||
|   Built-in manual: ${curl_manual_msg} |   Built-in manual: ${curl_manual_msg} | ||||||
|  |   Verbose errors:  ${curl_verbose_msg} | ||||||
| ]) | ]) | ||||||
|   | |||||||
| @@ -45,19 +45,19 @@ while test $# -gt 0; do | |||||||
|  |  | ||||||
|     case "$1" in |     case "$1" in | ||||||
|     --ca) |     --ca) | ||||||
| 	echo @CURL_CA_BUNDLE@ | 	echo "@CURL_CA_BUNDLE@" | ||||||
| 	;; | 	;; | ||||||
|  |  | ||||||
|     --cc) |     --cc) | ||||||
| 	echo @CC@ | 	echo "@CC@" | ||||||
| 	;; | 	;; | ||||||
|  |  | ||||||
|     --prefix) |     --prefix) | ||||||
| 	echo $prefix | 	echo "$prefix" | ||||||
| 	;; | 	;; | ||||||
|  |  | ||||||
|     --feature) |     --feature) | ||||||
| 	if test "@OPENSSL_ENABLED@" = "1"; then | 	if test "@USE_SSLEAY@" = "1"; then | ||||||
|           echo "SSL" |           echo "SSL" | ||||||
|         fi |         fi | ||||||
| 	if test "@KRB4_ENABLED@" = "1"; then | 	if test "@KRB4_ENABLED@" = "1"; then | ||||||
|   | |||||||
| @@ -20,6 +20,13 @@ | |||||||
|     ) |     ) | ||||||
|   "Curl C Programming Style") |   "Curl C Programming Style") | ||||||
|  |  | ||||||
|  | (defun curl-code-cleanup () | ||||||
|  |   "no docs" | ||||||
|  |   (interactive) | ||||||
|  |   (untabify (point-min) (point-max)) | ||||||
|  |   (delete-trailing-whitespace) | ||||||
|  | ) | ||||||
|  |  | ||||||
| ;; Customizations for all of c-mode, c++-mode, and objc-mode | ;; Customizations for all of c-mode, c++-mode, and objc-mode | ||||||
| (defun curl-c-mode-common-hook () | (defun curl-c-mode-common-hook () | ||||||
|   "Curl C mode hook" |   "Curl C mode hook" | ||||||
| @@ -33,7 +40,7 @@ | |||||||
|   ;; keybindings for C, C++, and Objective-C.  We can put these in |   ;; keybindings for C, C++, and Objective-C.  We can put these in | ||||||
|   ;; c-mode-base-map because of inheritance ... |   ;; c-mode-base-map because of inheritance ... | ||||||
|   (define-key c-mode-base-map "\M-q" 'c-fill-paragraph) |   (define-key c-mode-base-map "\M-q" 'c-fill-paragraph) | ||||||
|   (define-key c-mode-base-map "\M-m" 'delete-trailing-whitespace) |   (define-key c-mode-base-map "\M-m" 'curl-code-cleanup) | ||||||
|   (setq c-recognize-knr-p nil) |   (setq c-recognize-knr-p nil) | ||||||
|   ;;; (add-hook 'write-file-hooks 'delete-trailing-whitespace t) |   ;;; (add-hook 'write-file-hooks 'delete-trailing-whitespace t) | ||||||
|   (setq show-trailing-whitespace t) |   (setq show-trailing-whitespace t) | ||||||
|   | |||||||
| @@ -17,22 +17,27 @@ archives, but must be downloaded and installed separately. | |||||||
|  |  | ||||||
| Ada95 | Ada95 | ||||||
|  |  | ||||||
|   Writtten by Andreas Almroth. |   Writtten by Andreas Almroth | ||||||
|   http://www.almroth.com/adacurl/index.html |   http://www.almroth.com/adacurl/index.html | ||||||
|  |  | ||||||
| Basic | Basic | ||||||
|  |  | ||||||
|   ScriptBasic bindings to libcurl. Writtten by Peter Verhas. |   ScriptBasic bindings to libcurl. Writtten by Peter Verhas | ||||||
|   http://scriptbasic.com/ |   http://scriptbasic.com/ | ||||||
|  |  | ||||||
| C++ | C++ | ||||||
|  |  | ||||||
|   Written by Jean-Philippe Barrette-LaPierre. |   Written by Jean-Philippe Barrette-LaPierre | ||||||
|   http://www.sourceforge.net/projects/curlpp |   http://www.sourceforge.net/projects/curlpp | ||||||
|  |  | ||||||
|  | Ch | ||||||
|  |  | ||||||
|  |   Written by Stephen Nestinger and Jonathan Rogado | ||||||
|  |   http://chcurl.sourceforge.net/ | ||||||
|  |  | ||||||
| Cocoa | Cocoa | ||||||
|  |  | ||||||
|   Written by Dan Wood. |   Written by Dan Wood | ||||||
|   http://curlhandle.sourceforge.net/ |   http://curlhandle.sourceforge.net/ | ||||||
|  |  | ||||||
| D | D | ||||||
| @@ -42,27 +47,45 @@ D | |||||||
|  |  | ||||||
| Dylan | Dylan | ||||||
|  |  | ||||||
|   Written by Chris Double. |   Written by Chris Double | ||||||
|   http://dylanlibs.sourceforge.net/ |   http://dylanlibs.sourceforge.net/ | ||||||
|  |  | ||||||
| Euphoria | Euphoria | ||||||
|  |  | ||||||
|   Written by Ray Smith. |   Written by Ray Smith | ||||||
|   http://rays-web.com/eulibcurl.htm |   http://rays-web.com/eulibcurl.htm | ||||||
|  |  | ||||||
| Ferite | Ferite | ||||||
|  |   Written by Paul Querna | ||||||
|   http://www.ferite.org/ |   http://www.ferite.org/ | ||||||
|  |  | ||||||
|  | Gambas | ||||||
|  |   http://gambas.sourceforge.net | ||||||
|  |  | ||||||
|  | glib/GTK+ | ||||||
|  |   Written by Richard Atterer | ||||||
|  |   http://atterer.net/glibcurl/ | ||||||
|  |  | ||||||
| Java | Java | ||||||
|  |  | ||||||
|   Written by Daniel Stenberg. |   Written by Daniel Stenberg | ||||||
|   http://curl.haxx.se/libcurl/java/ |   http://curl.haxx.se/libcurl/java/ | ||||||
|  |  | ||||||
| Lua | Lua | ||||||
|  |  | ||||||
|   Written by Steve Dekorte. |   Written by Steve Dekorte | ||||||
|   http://curl.haxx.se/libcurl/lua/ |   http://curl.haxx.se/libcurl/lua/ | ||||||
|  |  | ||||||
|  | .NET | ||||||
|  |  | ||||||
|  |   Written by Jeffrey Phillips | ||||||
|  |   http://www.seasideresearch.com/downloads.html | ||||||
|  |  | ||||||
|  | Mono | ||||||
|  |  | ||||||
|  |   Written by Jeffrey Phillips | ||||||
|  |   http://forge.novell.com/modules/xfmod/project/?libcurl-mono | ||||||
|  |  | ||||||
| Object-Pascal | Object-Pascal | ||||||
|  |  | ||||||
|   Free Pascal, Delphi and Kylix binding written by Christophe Espern. |   Free Pascal, Delphi and Kylix binding written by Christophe Espern. | ||||||
| @@ -70,7 +93,7 @@ Object-Pascal | |||||||
|  |  | ||||||
| O'Caml | O'Caml | ||||||
|  |  | ||||||
|   Written by Lars Nilsson. |   Written by Lars Nilsson | ||||||
|   http://sourceforge.net/projects/ocurl/ |   http://sourceforge.net/projects/ocurl/ | ||||||
|  |  | ||||||
| Pascal | Pascal | ||||||
| @@ -80,40 +103,54 @@ Pascal | |||||||
|  |  | ||||||
| Perl | Perl | ||||||
|  |  | ||||||
|   Maintained by Cris Bailiff. |   Maintained by Cris Bailiff | ||||||
|   http://curl.haxx.se/libcurl/perl/ |   http://curl.haxx.se/libcurl/perl/ | ||||||
|  |  | ||||||
| PHP | PHP | ||||||
|  |  | ||||||
|   Written by Sterling Hughes. |   Written by Sterling Hughes | ||||||
|   http://curl.haxx.se/libcurl/php/ |   http://curl.haxx.se/libcurl/php/ | ||||||
|  |  | ||||||
| PostgreSQL | PostgreSQL | ||||||
|  |  | ||||||
|   Written by Gian Paolo Ciceri. |   Written by Gian Paolo Ciceri | ||||||
|   http://gborg.postgresql.org/project/pgcurl/projdisplay.php |   http://gborg.postgresql.org/project/pgcurl/projdisplay.php | ||||||
|  |  | ||||||
| Python | Python | ||||||
|  |  | ||||||
|   Written by Kjetil Jacobsen. |   PycURL is written by Kjetil Jacobsen | ||||||
|   http://pycurl.sourceforge.net/ |   http://pycurl.sourceforge.net/ | ||||||
|  |  | ||||||
|  | R | ||||||
|  |  | ||||||
|  |   RCurl is written by Duncan Temple Lang | ||||||
|  |   http://www.omegahat.org/RCurl/ | ||||||
|  |  | ||||||
| Rexx | Rexx | ||||||
|  |  | ||||||
|   Written Mark Hessling.  |   Written Mark Hessling | ||||||
|   http://rexxcurl.sourceforge.net/ |   http://rexxcurl.sourceforge.net/ | ||||||
|  |  | ||||||
| Ruby | Ruby | ||||||
|  |  | ||||||
|   Written by Hirotaka Matsuyuki.  |   Written by Hirotaka Matsuyuki | ||||||
|   http://www.d1.dion.ne.jp/~matuyuki/ruby.html |   http://www.d1.dion.ne.jp/~matuyuki/ruby.html | ||||||
|  |  | ||||||
| Scheme | Scheme | ||||||
|  |  | ||||||
|   Bigloo binding written by Kirill Lisovsky. |   Bigloo binding written by Kirill Lisovsky | ||||||
|   http://curl.haxx.se/libcurl/scheme/ |   http://curl.haxx.se/libcurl/scheme/ | ||||||
|  |  | ||||||
| Tcl | Tcl | ||||||
|  |  | ||||||
|   Written by Andr<64>s Garc<72>a.  |   Tclcurl is written by Andr<64>s Garc<72>a | ||||||
|   http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html |   http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html | ||||||
|  |  | ||||||
|  | Q | ||||||
|  |  | ||||||
|  |   http://q-lang.sourceforge.net/ | ||||||
|  |  | ||||||
|  | wxWidgets | ||||||
|  |  | ||||||
|  |   Written by Casey O'Donnell | ||||||
|  |   http://homepage.mac.com/codonnell/wxcurldav/ | ||||||
|   | |||||||
| @@ -138,15 +138,15 @@ How To Make a Patch | |||||||
|  |  | ||||||
|  If you have modified a single file, try something like: |  If you have modified a single file, try something like: | ||||||
|  |  | ||||||
|      diff -u undmodified-file.c my-changed-one.c > my-fixes.diff |      diff -u unmodified-file.c my-changed-one.c > my-fixes.diff | ||||||
|  |  | ||||||
|  If you have modified several files, possibly in different directories, you |  If you have modified several files, possibly in different directories, you | ||||||
|  can use diff recursively: |  can use diff recursively: | ||||||
|  |  | ||||||
|      diff -ur curl-original-dir curl-modfied-sources-dir > my-fixes.diff |      diff -ur curl-original-dir curl-modified-sources-dir > my-fixes.diff | ||||||
|  |  | ||||||
|  The GNU diff and GNU patch tools exist for virtually all platforms, including |  The GNU diff and GNU patch tools exist for virtually all platforms, including | ||||||
|  all kinds of unixes and Windows: |  all kinds of Unixes and Windows: | ||||||
|  |  | ||||||
|  For unix-like operating systems: |  For unix-like operating systems: | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										162
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										162
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| Updated: August 10, 2004 (http://curl.haxx.se/docs/faq.html) | Updated: August 18, 2004 (http://curl.haxx.se/docs/faq.html) | ||||||
|                                   _   _ ____  _ |                                   _   _ ____  _ | ||||||
|                               ___| | | |  _ \| | |                               ___| | | |  _ \| | | ||||||
|                              / __| | | | |_) | | |                              / __| | | | |_) | | | ||||||
| @@ -10,10 +10,10 @@ FAQ | |||||||
|  1. Philosophy |  1. Philosophy | ||||||
|   1.1 What is cURL? |   1.1 What is cURL? | ||||||
|   1.2 What is libcurl? |   1.2 What is libcurl? | ||||||
|   1.3 What is cURL not? |   1.3 What is curl not? | ||||||
|   1.4 When will you make curl do XXXX ? |   1.4 When will you make curl do XXXX ? | ||||||
|   1.5 Who makes cURL? |   1.5 Who makes curl? | ||||||
|   1.6 What do you get for making cURL? |   1.6 What do you get for making curl? | ||||||
|   1.7 What about CURL from curl.com? |   1.7 What about CURL from curl.com? | ||||||
|   1.8 I have a problem who do I mail? |   1.8 I have a problem who do I mail? | ||||||
|  |  | ||||||
| @@ -23,7 +23,7 @@ FAQ | |||||||
|    2.1.2 only the libssl lib is missing |    2.1.2 only the libssl lib is missing | ||||||
|   2.2 Does curl work/build with other SSL libraries? |   2.2 Does curl work/build with other SSL libraries? | ||||||
|   2.3 Where can I find a copy of LIBEAY32.DLL? |   2.3 Where can I find a copy of LIBEAY32.DLL? | ||||||
|   2.4 Does cURL support Socks (RFC 1928) ? |   2.4 Does curl support Socks (RFC 1928) ? | ||||||
|  |  | ||||||
|  3. Usage Problems |  3. Usage Problems | ||||||
|   3.1 curl: (1) SSL is disabled, https: not supported |   3.1 curl: (1) SSL is disabled, https: not supported | ||||||
| @@ -41,6 +41,7 @@ FAQ | |||||||
|   3.13 Why does my single/double quotes fail? |   3.13 Why does my single/double quotes fail? | ||||||
|   3.14 Does curl support javascript or pac (automated proxy config)? |   3.14 Does curl support javascript or pac (automated proxy config)? | ||||||
|   3.15 Can I do recursive fetches with curl? |   3.15 Can I do recursive fetches with curl? | ||||||
|  |   3.16 What certificates do I need when I use SSL? | ||||||
|  |  | ||||||
|  4. Running Problems |  4. Running Problems | ||||||
|   4.1 Problems connecting to SSL servers. |   4.1 Problems connecting to SSL servers. | ||||||
| @@ -71,6 +72,7 @@ FAQ | |||||||
|   5.6 What about Keep-Alive or persistent connections? |   5.6 What about Keep-Alive or persistent connections? | ||||||
|   5.7 Link errors when building libcurl on Windows! |   5.7 Link errors when building libcurl on Windows! | ||||||
|   5.8 libcurl.so.3: open failed: No such file or directory |   5.8 libcurl.so.3: open failed: No such file or directory | ||||||
|  |   5.9 How does libcurl resolve host names? | ||||||
|  |  | ||||||
|  6. License Issues |  6. License Issues | ||||||
|   6.1 I have a GPL program, can I use the libcurl library? |   6.1 I have a GPL program, can I use the libcurl library? | ||||||
| @@ -80,24 +82,50 @@ FAQ | |||||||
|   6.5 Can I modify curl/libcurl for my program and keep the changes secret? |   6.5 Can I modify curl/libcurl for my program and keep the changes secret? | ||||||
|   6.6 Can you please change the curl/libcurl license to XXXX? |   6.6 Can you please change the curl/libcurl license to XXXX? | ||||||
|  |  | ||||||
|  |  7. PHP/CURL Issues | ||||||
|  |   7.1 What is PHP/CURL? | ||||||
|  |   7.2 Who write PHP/CURL? | ||||||
|  |   7.3 Can I perform multiple requests using the same handle? | ||||||
|  |  | ||||||
| ============================================================================== | ============================================================================== | ||||||
|  |  | ||||||
| 1. Philosophy | 1. Philosophy | ||||||
|  |  | ||||||
|   1.1 What is cURL? |   1.1 What is cURL? | ||||||
|  |  | ||||||
|   cURL (or simply just 'curl') is a command line tool for getting or sending |   cURL is the name of the project. The name is a play on 'Client for URLs', | ||||||
|   files using URL syntax. The name is a play on 'Client for URLs', originally |   originally with URL spelled in uppercase to make it obvious it deals with | ||||||
|   with URL spelled in uppercase to make it obvious it deals with URLs. The |   URLs. The fact it can also be pronounced 'see URL' also helped, it works as | ||||||
|   fact it can also be pronounced 'see URL' also helped, it works as an |   an abbrivation for "Client URL Request Library" or why not the recursive | ||||||
|   abbrivation for "Client URL Request Library" or why not the recursive |  | ||||||
|   version: "Curl URL Request Library". |   version: "Curl URL Request Library". | ||||||
|  |  | ||||||
|   Curl supports a range of common Internet protocols, currently including |   The cURL project produces two products: | ||||||
|   HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE. |  | ||||||
|  |  | ||||||
|   We spell it cURL or just curl. We pronounce it with an initial k sound: |   libcurl | ||||||
|   [kurl]. |  | ||||||
|  |     A free and easy-to-use client-side URL transfer library, supporting FTP, | ||||||
|  |     FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE and LDAP.  libcurl supports | ||||||
|  |     HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading, kerberos, HTTP | ||||||
|  |     form based upload, proxies, cookies, user+password authentication, file | ||||||
|  |     transfer resume, http proxy tunneling and more! | ||||||
|  |  | ||||||
|  |     libcurl is highly portable, it builds and works identically on numerous | ||||||
|  |     platforms, including Solaris, NetBSD, FreeBSD, OpenBSD, Darwin, HPUX, | ||||||
|  |     IRIX, AIX, Tru64, Linux, UnixWare, HURD, Windows, Amiga, OS/2, BeOs, Mac | ||||||
|  |     OS X, Ultrix, QNX, OpenVMS, RISC OS, Novell NetWare, DOS and more... | ||||||
|  |  | ||||||
|  |     libcurl is free, thread-safe, IPv6 compatible, feature rich, well | ||||||
|  |     supported and fast. | ||||||
|  |  | ||||||
|  |   curl | ||||||
|  |  | ||||||
|  |     A command line tool for getting or sending files using URL syntax. | ||||||
|  |  | ||||||
|  |     Since curl uses libcurl, it supports a range of common Internet protocols, | ||||||
|  |     currently including HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and | ||||||
|  |     FILE. | ||||||
|  |  | ||||||
|  |   We pronounce curl and cURL with an initial k sound: [kurl]. | ||||||
|  |  | ||||||
|   NOTE: there are numerous sub-projects and related projects that also use the |   NOTE: there are numerous sub-projects and related projects that also use the | ||||||
|   word curl in the project names in various combinations, but you should take |   word curl in the project names in various combinations, but you should take | ||||||
| @@ -113,7 +141,7 @@ FAQ | |||||||
|   You can use libcurl for free in your application, be it open source, |   You can use libcurl for free in your application, be it open source, | ||||||
|   commercial or closed-source. |   commercial or closed-source. | ||||||
|  |  | ||||||
|   1.3 What is cURL not? |   1.3 What is curl not? | ||||||
|  |  | ||||||
|   Curl is *not* a wget clone. That is a common misconception.  Never, during |   Curl is *not* a wget clone. That is a common misconception.  Never, during | ||||||
|   curl's development, have we intended curl to replace wget or compete on its |   curl's development, have we intended curl to replace wget or compete on its | ||||||
| @@ -128,7 +156,7 @@ FAQ | |||||||
|   script (or write a new program that interfaces libcurl) and do it. |   script (or write a new program that interfaces libcurl) and do it. | ||||||
|  |  | ||||||
|   Curl is not a PHP tool, even though it works perfectly well when used from |   Curl is not a PHP tool, even though it works perfectly well when used from | ||||||
|   or with PHP. |   or with PHP (when using the PHP/CURL module). | ||||||
|  |  | ||||||
|   Curl is not a single-OS program. Curl exists, compiles, builds and runs |   Curl is not a single-OS program. Curl exists, compiles, builds and runs | ||||||
|   under a wide range of operating systems, including all modern Unixes (and a |   under a wide range of operating systems, including all modern Unixes (and a | ||||||
| @@ -162,9 +190,9 @@ FAQ | |||||||
|   * If you write the code, chances are bigger that it will get into curl |   * If you write the code, chances are bigger that it will get into curl | ||||||
|     faster. |     faster. | ||||||
|  |  | ||||||
|   1.5 Who makes cURL? |   1.5 Who makes curl? | ||||||
|  |  | ||||||
|   cURL and libcurl are not made by any single individual. Sure, Daniel |   curl and libcurl are not made by any single individual. Sure, Daniel | ||||||
|   Stenberg writes the major parts, but other persons' submissions are |   Stenberg writes the major parts, but other persons' submissions are | ||||||
|   important and crucial. Anyone can contribute and post their changes and |   important and crucial. Anyone can contribute and post their changes and | ||||||
|   improvements and have them inserted in the main sources (of course on the |   improvements and have them inserted in the main sources (of course on the | ||||||
| @@ -176,14 +204,16 @@ FAQ | |||||||
|  |  | ||||||
|   curl is developed by a community, with Daniel at the wheel. |   curl is developed by a community, with Daniel at the wheel. | ||||||
|  |  | ||||||
|   1.6 What do you get for making cURL? |   1.6 What do you get for making curl? | ||||||
|  |  | ||||||
|   Project cURL is entirely free and open. No person gets paid for developing |   Project cURL is entirely free and open. No person gets paid for developing | ||||||
|   curl. We do this voluntarily on our spare time. |   (lib)curl. We do this voluntarily on our spare time. | ||||||
|  |  | ||||||
|   We get some help from companies. Contactor Data hosts the curl web site, |   We get some help from companies. Contactor Data hosts the curl web site, | ||||||
|   Haxx owns the curl web site's domain and sourceforge.net hosts project |   Haxx owns the curl web site's domain and sourceforge.net hosts project | ||||||
|   services we take advantage from, like the bug tracker. |   services we take advantage from, like the bug tracker. Also, some companies | ||||||
|  |   have sponsored certain parts of the development in the past and I hope some | ||||||
|  |   will continue to do so in the future. | ||||||
|  |  | ||||||
|   If you want to support our project with a donation or similar, one way of |   If you want to support our project with a donation or similar, one way of | ||||||
|   doing that would be to buy "gift certificates" at useful online shopping |   doing that would be to buy "gift certificates" at useful online shopping | ||||||
| @@ -279,7 +309,7 @@ FAQ | |||||||
|   accurate and up-to-date pointers to recent OpenSSL DLLs and other binary |   accurate and up-to-date pointers to recent OpenSSL DLLs and other binary | ||||||
|   packages. |   packages. | ||||||
|  |  | ||||||
|   2.4 Does cURL support Socks (RFC 1928) ? |   2.4 Does curl support Socks (RFC 1928) ? | ||||||
|  |  | ||||||
|   Yes, SOCKS5 is supported. |   Yes, SOCKS5 is supported. | ||||||
|  |  | ||||||
| @@ -370,7 +400,6 @@ FAQ | |||||||
|  |  | ||||||
|   Find out more about which languages that support curl directly, and how to |   Find out more about which languages that support curl directly, and how to | ||||||
|   install and use them, in the libcurl section of the curl web site: |   install and use them, in the libcurl section of the curl web site: | ||||||
|  |  | ||||||
|   http://curl.haxx.se/libcurl/ |   http://curl.haxx.se/libcurl/ | ||||||
|  |  | ||||||
|   In February 2003, there are interfaces available for the following |   In February 2003, there are interfaces available for the following | ||||||
| @@ -463,6 +492,34 @@ FAQ | |||||||
|   curlmirror perl script), and you can write programs based on libcurl to do |   curlmirror perl script), and you can write programs based on libcurl to do | ||||||
|   it, but the command line tool curl itself cannot. |   it, but the command line tool curl itself cannot. | ||||||
|  |  | ||||||
|  |   3.16 What certificates do I need when I use SSL? | ||||||
|  |  | ||||||
|  |   There are three different kinds of "certificates" to keep track of when we | ||||||
|  |   talk about using SSL-based protocols (HTTPS or FTPS) using curl or libcurl. | ||||||
|  |  | ||||||
|  |   - Client certificate. The server you communicate may require that you can | ||||||
|  |     provide this in order to prove that you actually are who you claim to be. | ||||||
|  |     If the server doesn't require this, you don't need a client certificate. | ||||||
|  |  | ||||||
|  |   - Server certificate. The server you communicate with has a server | ||||||
|  |     certificate. You can and should verify this certficate to make sure that | ||||||
|  |     you are truly talking to the real server and not a server impersonating | ||||||
|  |     it. The server certificate verifaction process is made by using a | ||||||
|  |     Certificate Authority certificate ("CA cert") that was used to sign the | ||||||
|  |     server certificate. Server certificate verification is enabled by default | ||||||
|  |     in curl and libcurl and is often the reason for problems as explained in | ||||||
|  |     FAQ entry 4.12 and the SSLCERTS document | ||||||
|  |     (http://curl.haxx.se/docs/sslcerts.html). Server certificates that are | ||||||
|  |     "self-signed" or otherwise signed by a CA that you do not have a CA cert | ||||||
|  |     for, cannot be verified. If the verification during a connect fails, you | ||||||
|  |     are refused access. You then need to explicitly disable the verification | ||||||
|  |     to connect to the server. | ||||||
|  |  | ||||||
|  |   - Certificate Authority certificate ("CA cert"). You often have several CA | ||||||
|  |     certs in a CA cert bundle that can be used to verify a server certificate | ||||||
|  |     that was signed by one of the authorities in the bundle. curl comes with a | ||||||
|  |     default CA cert bundle. You can override the default. | ||||||
|  |  | ||||||
|  |  | ||||||
| 4. Running Problems | 4. Running Problems | ||||||
|  |  | ||||||
| @@ -746,6 +803,22 @@ FAQ | |||||||
|  |  | ||||||
|   (Provided by Andrew Francis) |   (Provided by Andrew Francis) | ||||||
|  |  | ||||||
|  |   When building an application that uses the static libcurl library, you must | ||||||
|  |   add -DCURL_STATICLIB to your CFLAGS. Otherwise the linker will look for | ||||||
|  |   dynamic import symbols. If you get linker error like "unknown symbol | ||||||
|  |   __imp__curl_easy_init ..." you have linked against the wrong (static) library. | ||||||
|  |   If you want to use the curl.dll and import lib, you don't need any extra CFLAGS, | ||||||
|  |   but use one of the import libraries below. These are the libraries produced by | ||||||
|  |   the various lib/Makefile.* files: | ||||||
|  |  | ||||||
|  |   Target:          static lib.   import lib for curl*.dll. | ||||||
|  |   -------------------------------------------------------- | ||||||
|  |   MingW:           libcurl.a     libcurldll.a | ||||||
|  |   MSVC (release):  libcurl.lib   libcurl_imp.lib | ||||||
|  |   MSVC (debug):    libcurld.lib  libcurld_imp.lib | ||||||
|  |   Borland:         libcurl.lib   libcurl_imp.lib | ||||||
|  |  | ||||||
|  |  | ||||||
|   5.8 libcurl.so.3: open failed: No such file or directory |   5.8 libcurl.so.3: open failed: No such file or directory | ||||||
|  |  | ||||||
|   This is an error message you might get when you try to run a program linked |   This is an error message you might get when you try to run a program linked | ||||||
| @@ -767,6 +840,26 @@ FAQ | |||||||
|  |  | ||||||
|   'man ld.so' and 'man ld' will tell you more details |   'man ld.so' and 'man ld' will tell you more details | ||||||
|  |  | ||||||
|  |   5.9 How does libcurl resolve host names? | ||||||
|  |  | ||||||
|  |   libcurl includes a number of different name resolve functions: | ||||||
|  |  | ||||||
|  |   - The non-ipv6 resolver that can use one out of four host name resolve calls | ||||||
|  |     (depending on what your system supports): | ||||||
|  |  | ||||||
|  |     A - gethostbyname() | ||||||
|  |     B - gethostbyname_r() with 3 arguments | ||||||
|  |     C - gethostbyname_r() with 5 arguments | ||||||
|  |     D - gethostbyname_r() with 6 arguments | ||||||
|  |  | ||||||
|  |   - The ipv6-resolver that uses getaddrinfo() | ||||||
|  |  | ||||||
|  |   - The c-ares based name resolver that uses the c-ares library for resolves. | ||||||
|  |  | ||||||
|  |   - The Windows threaded resolver. It use: | ||||||
|  |  | ||||||
|  |     A - gethostbyname() on plain ipv4 windows hosts | ||||||
|  |     B - getaddrinfo() on ipv6-enabled windows hosts | ||||||
|  |  | ||||||
| 6. License Issues | 6. License Issues | ||||||
|  |  | ||||||
| @@ -818,3 +911,26 @@ FAQ | |||||||
|   we want on curl/libcurl and it does not spread to other programs or |   we want on curl/libcurl and it does not spread to other programs or | ||||||
|   libraries that use it. It should be possible for everyone to use libcurl or |   libraries that use it. It should be possible for everyone to use libcurl or | ||||||
|   curl in their projects, no matter what license they already have in use. |   curl in their projects, no matter what license they already have in use. | ||||||
|  |  | ||||||
|  | 7. PHP/CURL Issues | ||||||
|  |  | ||||||
|  |   7.1 What is PHP/CURL? | ||||||
|  |  | ||||||
|  |   The module for PHP that makes it possible for PHP programs to access curl- | ||||||
|  |   functions from within PHP. We often call it PHP/CURL to differentiate from | ||||||
|  |   curl the command line tool and libcurl the library. | ||||||
|  |  | ||||||
|  |   7.2 Who write PHP/CURL? | ||||||
|  |  | ||||||
|  |   PHP/CURL is a module that comes with the regular PHP package. It depends and | ||||||
|  |   uses libcurl, so you need to have libcurl installed properly first before | ||||||
|  |   PHP/CURL can be used. PHP/CURL is written by Sterling Hughes. | ||||||
|  |  | ||||||
|  |   7.3 Can I perform multiple requests using the same handle? | ||||||
|  |  | ||||||
|  |   Yes - at least in PHP version 4.3.8 and later (this has been known to not | ||||||
|  |   work in earlier versions, but the exact version when it started to work is | ||||||
|  |   unknown to me). | ||||||
|  |  | ||||||
|  |   After a transfer, you just set new options in the handle and make another | ||||||
|  |   transfer. This will make libcurl to re-use the same connection if it can. | ||||||
|   | |||||||
| @@ -6,26 +6,33 @@ | |||||||
|  |  | ||||||
| FEATURES | FEATURES | ||||||
|  |  | ||||||
| Misc | curl tool | ||||||
|  - full URL syntax |  - config file support | ||||||
|  |  - multiple URLs in a single command line | ||||||
|  |  - range "globbing" support: [0-13], {one,two,three} | ||||||
|  |  - multiple file upload on a single command line | ||||||
|  |  - custom maximum transfer rate | ||||||
|  |  - redirectable stderr | ||||||
|  |  | ||||||
|  | libcurl supports | ||||||
|  |  - full URL syntax with no length limit | ||||||
|  - custom maximum download time |  - custom maximum download time | ||||||
|  - custom least download speed acceptable |  - custom least download speed acceptable | ||||||
|  - custom output result after completion |  - custom output result after completion | ||||||
|  - multiple URLs |  | ||||||
|  - guesses protocol from host name unless specified |  - guesses protocol from host name unless specified | ||||||
|  - uses .netrc |  - uses .netrc | ||||||
|  - progress bar/time specs while downloading |  - progress bar/time specs while downloading | ||||||
|  - "standard" proxy environment variables support |  - "standard" proxy environment variables support | ||||||
|  - config file support |  | ||||||
|  - compiles on win32 (reported builds on 40+ operating systems) |  - compiles on win32 (reported builds on 40+ operating systems) | ||||||
|  - redirectable stderr |  | ||||||
|  - selectable network interface for outgoing traffic |  - selectable network interface for outgoing traffic | ||||||
|  - IPv6 support |  - IPv6 support on unix and Windows | ||||||
|  - persistant connections |  - persistant connections | ||||||
|  - socks5 support |  - socks5 support | ||||||
|  - supports user name + password in proxy environment variables |  - supports user name + password in proxy environment variables | ||||||
|  - operations through proxy "tunnel" (using CONNECT) |  - operations through proxy "tunnel" (using CONNECT) | ||||||
|  - supports transfers of large files (>2GB and >4GB) |  - supports large files (>2GB and >4GB) both upload/download | ||||||
|  |  - replacable memory functions (malloc, free, realloc, etc) | ||||||
|  |  - asynchronous name resolving (*6) | ||||||
|  |  | ||||||
| HTTP | HTTP | ||||||
|  - HTTP/1.1 compliant (optionally uses 1.0) |  - HTTP/1.1 compliant (optionally uses 1.0) | ||||||
| @@ -35,7 +42,7 @@ HTTP | |||||||
|  - POST |  - POST | ||||||
|  - multipart formpost (RFC1867-style) |  - multipart formpost (RFC1867-style) | ||||||
|  - authentication: Basic, Digest, NTLM(*1), GSS-Negotiate/Negotiate(*3) and |  - authentication: Basic, Digest, NTLM(*1), GSS-Negotiate/Negotiate(*3) and | ||||||
|    SPNEGO (*4) |    SPNEGO (*4) to server and proxy | ||||||
|  - resume (both GET and PUT) |  - resume (both GET and PUT) | ||||||
|  - follow redirects |  - follow redirects | ||||||
|  - maximum amount of redirects to follow |  - maximum amount of redirects to follow | ||||||
| @@ -80,6 +87,8 @@ 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 | ||||||
|  |  | ||||||
| FTPS (*1) | FTPS (*1) | ||||||
|  - explicit ftps:// support that use SSL on both connections |  - explicit ftps:// support that use SSL on both connections | ||||||
| @@ -103,6 +112,8 @@ GOPHER | |||||||
|  |  | ||||||
| FILE | FILE | ||||||
|  - URL support |  - URL support | ||||||
|  |  - "uploads" | ||||||
|  |  - resume | ||||||
|  |  | ||||||
| FOOTNOTES | FOOTNOTES | ||||||
| ========= | ========= | ||||||
| @@ -112,3 +123,4 @@ FOOTNOTES | |||||||
|   *3 = requires a GSSAPI-compliant library, such as Heimdal or similar. |   *3 = requires a GSSAPI-compliant library, such as Heimdal or similar. | ||||||
|   *4 = requires FBopenssl |   *4 = requires FBopenssl | ||||||
|   *5 = requires a krb4 library, such as the MIT one or similar. |   *5 = requires a krb4 library, such as the MIT one or similar. | ||||||
|  |   *6 = requires c-ares | ||||||
|   | |||||||
| @@ -1,25 +0,0 @@ | |||||||
| Steps To Perform When Building a Public Release |  | ||||||
|  |  | ||||||
| * "make distcheck" |  | ||||||
|  |  | ||||||
| * ./maketgz |  | ||||||
|  then upload the 3 curl packages maketgz created |  | ||||||
|  |  | ||||||
| * update these files: |  | ||||||
|   www/_download.html |  | ||||||
|   www/_changes.html |  | ||||||
|   www/_newslog.html |  | ||||||
|   www/Makefile |  | ||||||
|  |  | ||||||
| * commit the web changes |  | ||||||
|  |  | ||||||
| * 'cvs commit' |  | ||||||
|  |  | ||||||
| * 'cvs tag' |  | ||||||
|  |  | ||||||
| * write the release announcement, including: |  | ||||||
|   - changes / bugfixes |  | ||||||
|   - other curl-related news |  | ||||||
|   - contributors |  | ||||||
|  |  | ||||||
| * mail release-announcement to curl-announce and curl-users |  | ||||||
							
								
								
									
										194
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										194
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -79,8 +79,18 @@ UNIX | |||||||
|        env CPPFLAGS="-I/path/to/ssl/include" LDFLAGS="-L/path/to/ssl/lib" \ |        env CPPFLAGS="-I/path/to/ssl/include" LDFLAGS="-L/path/to/ssl/lib" \ | ||||||
|        ./configure |        ./configure | ||||||
|  |  | ||||||
|    If your SSL library was compiled with rsaref (usually for use in the United |    If you have shared SSL libs installed in a directory where your run-time | ||||||
|    States), you may also need to set: |    linker doesn't find them (which usually causes configure failures), you can | ||||||
|  |    provide the -R option to ld on some operating systems to set a hard-coded | ||||||
|  |    path to the run-time linker: | ||||||
|  |  | ||||||
|  |         LDFLAGS=-R/usr/local/ssl/lib ./configure --with-ssl | ||||||
|  |  | ||||||
|  |    Another option to the previous trick, is to set LD_LIBRARY_PATH or edit the | ||||||
|  |    /etc/ld.so.conf file. | ||||||
|  |  | ||||||
|  |    If your SSL library was compiled with rsaref (this was common in the past | ||||||
|  |    when used in the United States), you may also need to set: | ||||||
|  |  | ||||||
|      LIBS=-lRSAglue -lrsaref |      LIBS=-lRSAglue -lrsaref | ||||||
|      (as suggested by Doug Kaufman) |      (as suggested by Doug Kaufman) | ||||||
| @@ -92,7 +102,7 @@ UNIX | |||||||
|  |  | ||||||
|        CC=cc ./configure |        CC=cc ./configure | ||||||
|          or |          or | ||||||
|        env Cc=cc ./configure |        env CC=cc ./configure | ||||||
|  |  | ||||||
|      To force a static library compile, disable the shared library creation |      To force a static library compile, disable the shared library creation | ||||||
|      by running configure like: |      by running configure like: | ||||||
| @@ -158,17 +168,9 @@ Win32 | |||||||
|         Make the sources in the src/ drawer be a "win32 console application" |         Make the sources in the src/ drawer be a "win32 console application" | ||||||
|         project. Name it curl. |         project. Name it curl. | ||||||
|  |  | ||||||
|         With VC++, add 'ws2_32.lib' to the link libs when you build curl! |  | ||||||
|         Borland seems to do that itself magically. Of course you have to make |  | ||||||
|         sure it links with the libcurl too! |  | ||||||
|  |  | ||||||
|         For VC++ 6, there's an included Makefile.vc6 that should be possible |         For VC++ 6, there's an included Makefile.vc6 that should be possible | ||||||
|         to use out-of-the-box. |         to use out-of-the-box. | ||||||
|  |  | ||||||
|         Microsoft note: add /Zm200 to the compiler options to increase the |  | ||||||
|         compiler's memory allocation limit, as the hugehelp.c won't compile |  | ||||||
|         due to "too long puts string". |  | ||||||
|  |  | ||||||
|  |  | ||||||
|    With SSL: |    With SSL: | ||||||
|  |  | ||||||
| @@ -361,9 +363,9 @@ VMS | |||||||
|    +----+------------+-------------+---+ |    +----+------------+-------------+---+ | ||||||
|  |  | ||||||
|    With the Ctrl-bits an application can tell if part or the whole message has |    With the Ctrl-bits an application can tell if part or the whole message has | ||||||
|    allready been printed from the program, DCL doesn't need to print it again. |    already been printed from the program, DCL doesn't need to print it again. | ||||||
|  |  | ||||||
|    Facility - basicaly the program ID. A code assigned to the program |    Facility - basically the program ID. A code assigned to the program | ||||||
|    the name can be fetched from external or internal message libraries |    the name can be fetched from external or internal message libraries | ||||||
|    Errorcode - the errodes assigned by the application |    Errorcode - the errodes assigned by the application | ||||||
|    Sev. - severity: Even = error, off = non error |    Sev. - severity: Even = error, off = non error | ||||||
| @@ -395,7 +397,7 @@ QNX | |||||||
| === | === | ||||||
|    (This section was graciously brought to us by David Bentham) |    (This section was graciously brought to us by David Bentham) | ||||||
|  |  | ||||||
|    As QNX is targetted for resource constrained environments, the QNX headers |    As QNX is targeted for resource constrained environments, the QNX headers | ||||||
|    set conservative limits. This includes the FD_SETSIZE macro, set by default |    set conservative limits. This includes the FD_SETSIZE macro, set by default | ||||||
|    to 32. Socket descriptors returned within the CURL library may exceed this, |    to 32. Socket descriptors returned within the CURL library may exceed this, | ||||||
|    resulting in memory faults/SIGSEGV crashes when passed into select(..) |    resulting in memory faults/SIGSEGV crashes when passed into select(..) | ||||||
| @@ -405,44 +407,6 @@ QNX | |||||||
|    libcurl, by overriding CFLAGS during configure, example |    libcurl, by overriding CFLAGS during configure, example | ||||||
|    #  configure CFLAGS='-DFD_SETSIZE=64 -g -O2' |    #  configure CFLAGS='-DFD_SETSIZE=64 -g -O2' | ||||||
|  |  | ||||||
| CROSS COMPILE |  | ||||||
| ============= |  | ||||||
|  |  | ||||||
|    (This section was graciously brought to us by Jim Duey, 23-oct-2001) |  | ||||||
|  |  | ||||||
|    Download and unpack the cURL package.  Version should be 7.9.1 or later. |  | ||||||
|  |  | ||||||
|    'cd' to the new directory. (ie. curl-7.9.1-pre4) |  | ||||||
|  |  | ||||||
|    Set environment variables to point to the cross-compile toolchain and call |  | ||||||
|    configure with any options you need.  Be sure and specify the '--host' and |  | ||||||
|    '--build' parameters at configuration time.  The following script is an |  | ||||||
|    example of cross-compiling for the IBM 405GP PowerPC processor using the |  | ||||||
|    toolchain from MonteVista for Hardhat Linux. |  | ||||||
|  |  | ||||||
|    (begin script) |  | ||||||
|  |  | ||||||
|    #! /bin/sh |  | ||||||
|  |  | ||||||
|    export PATH=$PATH:/opt/hardhat/devkit/ppc/405/bin |  | ||||||
|    export CPPFLAGS="-I/opt/hardhat/devkit/ppc/405/target/usr/include" |  | ||||||
|    export AR=ppc_405-ar |  | ||||||
|    export AS=ppc_405-as |  | ||||||
|    export LD=ppc_405-ld |  | ||||||
|    export RANLIB=ppc_405-ranlib |  | ||||||
|    export CC=ppc_405-gcc |  | ||||||
|    export NM=ppc_405-nm |  | ||||||
|  |  | ||||||
|    configure --target=powerpc-hardhat-linux \ |  | ||||||
| 	--host=powerpc-hardhat-linux \ |  | ||||||
| 	--build=i586-pc-linux-gnu \ |  | ||||||
| 	--prefix=/opt/hardhat/devkit/ppc/405/target/usr/local \ |  | ||||||
| 	--exec-prefix=/usr/local |  | ||||||
|  |  | ||||||
|    (end script) |  | ||||||
|  |  | ||||||
|    The '--prefix' parameter specifies where cURL will be installed.  If |  | ||||||
|    'configure' completes successfully, do 'make' and 'make install' as usual. |  | ||||||
|  |  | ||||||
| RISC OS | RISC OS | ||||||
| ======= | ======= | ||||||
| @@ -486,31 +450,107 @@ NetWare | |||||||
|    - 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.com/development/prgtools/  | ||||||
|    - recent Novell LibC SDK availabable 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 optained from: |      sources with NetWare Makefile can be obtained from: | ||||||
|      http://www.gknw.com/mirror/zlib/ |      http://www.gknw.com/mirror/zlib/ | ||||||
|  |  | ||||||
|    Set a search path to your compiler, linker and tools; if you want to have |    Set a search path to your compiler, linker and tools; if you want to have | ||||||
|    zlib support then set the environment var ZLIB_PATH pointing to your zlib |    zlib support then set the environment var ZLIB_PATH pointing to your zlib | ||||||
|    sources, on Linux make sure the var OSTYPE contains the string 'linux'; |    sources, on Linux make sure the var OSTYPE contains the string 'linux'; | ||||||
|    and finally type 'make netware' from the top source directory... |    and finally type 'make netware' from the top source directory... | ||||||
|    I found on some Linux systems (RH9) that OS detection didnt work although |    I found on some Linux systems (RH9) that OS detection didnlt work although | ||||||
|    a 'set | grep OSTYPE' shows the var present and set; I simply overwrote it |    a 'set | grep OSTYPE' shows the var present and set; I simply overwrote it | ||||||
|    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked...; |    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked...; | ||||||
|    other options are currently not supported, although partly prepared. |    other options are currently not supported, although partly prepared. | ||||||
|    The Ares lib builds arlready fine, and both test tools work fine at least  |    The Ares lib builds arlready fine, and both test tools work fine at least  | ||||||
|    when build with CodeWarrior...; dont know yet why they fail when build with |    when build with CodeWarrior...; don't know yet why they fail when build with | ||||||
|    gcc though; if you want to compile with Ares support then set an env var |    gcc though; if you want to compile with Ares support then set an env var | ||||||
|    WITH_ARES=1; I've not tested yet including libcares into curl. |    WITH_ARES=1; I've not tested yet including libares into curl. | ||||||
|    Any help in testing appreciated! |    Any help in testing appreciated! | ||||||
|    Buils automatically created 4 times a day from current CVS are here: |    Builds automatically created 4 times a day from current CVS are here: | ||||||
|    http://www.gknw.com/mirror/curl/autobuilds/ |    http://www.gknw.com/mirror/curl/autobuilds/ | ||||||
|    the status of these buids 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/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | CROSS COMPILE | ||||||
|  | ============= | ||||||
|  |  | ||||||
|  |    (This section was graciously brought to us by Jim Duey, with additions by | ||||||
|  |    Dan Fandrich) | ||||||
|  |  | ||||||
|  |    Download and unpack the cURL package.  Version should be 7.9.1 or later. | ||||||
|  |  | ||||||
|  |    'cd' to the new directory. (e.g. cd curl-7.12.3) | ||||||
|  |  | ||||||
|  |    Set environment variables to point to the cross-compile toolchain and call | ||||||
|  |    configure with any options you need.  Be sure and specify the '--host' and | ||||||
|  |    '--build' parameters at configuration time.  The following script is an | ||||||
|  |    example of cross-compiling for the IBM 405GP PowerPC processor using the | ||||||
|  |    toolchain from MonteVista for Hardhat Linux. | ||||||
|  |  | ||||||
|  |    (begin script) | ||||||
|  |  | ||||||
|  |    #! /bin/sh | ||||||
|  |  | ||||||
|  |    export PATH=$PATH:/opt/hardhat/devkit/ppc/405/bin | ||||||
|  |    export CPPFLAGS="-I/opt/hardhat/devkit/ppc/405/target/usr/include" | ||||||
|  |    export AR=ppc_405-ar | ||||||
|  |    export AS=ppc_405-as | ||||||
|  |    export LD=ppc_405-ld | ||||||
|  |    export RANLIB=ppc_405-ranlib | ||||||
|  |    export CC=ppc_405-gcc | ||||||
|  |    export NM=ppc_405-nm | ||||||
|  |  | ||||||
|  |    ./configure --target=powerpc-hardhat-linux \ | ||||||
|  | 	--host=powerpc-hardhat-linux \ | ||||||
|  | 	--build=i586-pc-linux-gnu \ | ||||||
|  | 	--prefix=/opt/hardhat/devkit/ppc/405/target/usr/local \ | ||||||
|  | 	--exec-prefix=/usr/local | ||||||
|  |  | ||||||
|  |    (end script) | ||||||
|  |  | ||||||
|  |    You may also need to provide a parameter like '--with-random=/dev/urandom' | ||||||
|  |    to configure as it cannot detect the presence of a random number | ||||||
|  |    generating device for a target system.  The '--prefix' parameter | ||||||
|  |    specifies where cURL will be installed.  If 'configure' completes | ||||||
|  |    successfully, do 'make' and 'make install' as usual. | ||||||
|  |  | ||||||
|  |    In some cases, you may be able to simplify the above commands to as | ||||||
|  |    little as: | ||||||
|  |  | ||||||
|  |        ./configure --host=ARCH-OS | ||||||
|  |  | ||||||
|  |    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 | ||||||
|  |    important factor.  First, be sure to set the CFLAGS environment variable | ||||||
|  |    when configuring with any compiler optimization flags to reduce the | ||||||
|  |    size of the binary.  For gcc, this would mean at minimum: | ||||||
|  |  | ||||||
|  |       env CFLAGS='-Os' ./configure ... | ||||||
|  |  | ||||||
|  |    Be sure to specify as many --disable- and --without- flags on the configure | ||||||
|  |    command-line as you can to disable all the libcurl features that you | ||||||
|  |    know your application is not going to need.  Besides specifying the | ||||||
|  |    --disable-PROTOCOL flags for all the types of URLs your application | ||||||
|  |    will not use, here are some other flags that can reduce the size of the | ||||||
|  |    library: | ||||||
|  |  | ||||||
|  |      --disable-ares (disables support for the ARES DNS library) | ||||||
|  |      --disable-cookies (disables support for HTTP cookies) | ||||||
|  |      --disable-crypto-auth (disables HTTP cryptographic authentication) | ||||||
|  |      --disable-ipv6 (disables support for IPv6) | ||||||
|  |      --disable-verbose (eliminates debugging strings and error code strings) | ||||||
|  |      --without-libidn (disables support for the libidn DNS library) | ||||||
|  |      --without-ssl (disables support for SSL/TLS) | ||||||
|  |      --without-zlib (disables support for on-the-fly decompression) | ||||||
|  |  | ||||||
|  |    You may find that statically linking libcurl to your application will | ||||||
|  |    result in a lower total size. | ||||||
|  |  | ||||||
|  |  | ||||||
| PORTS | PORTS | ||||||
| ===== | ===== | ||||||
|    This is a probably incomplete list of known hardware and operating systems |    This is a probably incomplete list of known hardware and operating systems | ||||||
| @@ -546,6 +586,7 @@ PORTS | |||||||
|         - Ultrix 4.3a |         - Ultrix 4.3a | ||||||
|         - i386 BeOS |         - i386 BeOS | ||||||
|         - i386 DOS |         - i386 DOS | ||||||
|  |         - i386 Esix 4.1 | ||||||
|         - i386 FreeBSD |         - i386 FreeBSD | ||||||
|         - i386 HURD |         - i386 HURD | ||||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4 |         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4 | ||||||
| @@ -566,33 +607,10 @@ PORTS | |||||||
|         - s390 Linux  |         - s390 Linux  | ||||||
|         - XScale/PXA250 Linux 2.4 |         - XScale/PXA250 Linux 2.4 | ||||||
|  |  | ||||||
| OpenSSL | Useful URLs | ||||||
| ======= | =========== | ||||||
|  |  | ||||||
|    You'll find OpenSSL information at: |  | ||||||
|  |  | ||||||
|       http://www.openssl.org |  | ||||||
|  |  | ||||||
|  |  | ||||||
| MingW32/Cygwin |  | ||||||
| ============== |  | ||||||
|  |  | ||||||
|    You'll find MingW32 and Cygwin information at: |  | ||||||
|  |  | ||||||
|       http://www.mingw.org |  | ||||||
|  |  | ||||||
| OpenLDAP |  | ||||||
| ======== |  | ||||||
|  |  | ||||||
|    You'll find OpenLDAP information at: |  | ||||||
|  |  | ||||||
|       http://www.openldap.org |  | ||||||
|  |  | ||||||
| Zlib |  | ||||||
| ==== |  | ||||||
|  |  | ||||||
|    You'll find Zlib information at: |  | ||||||
|  |  | ||||||
|       http://www.gzip.org/zlib/ |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | OpenSSL   http://www.openssl.org | ||||||
|  | MingW     http://www.mingw.org | ||||||
|  | OpenLDAP  http://www.openldap.org | ||||||
|  | Zlib      http://www.gzip.org/zlib/ | ||||||
|   | |||||||
| @@ -3,14 +3,26 @@ 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! | ||||||
|  |  | ||||||
|  | * Test case 165 might fail on system which has libidn present, but with an | ||||||
|  |   old iconv version (2.1.3 is a known bad version), since it doesn't recognize | ||||||
|  |   the charset when named ISO8859-1. Changing the name to ISO-8859-1 makes the | ||||||
|  |   test pass, but instead makes it fail on Solaris hosts that use its native | ||||||
|  |   iconv. | ||||||
|  |  | ||||||
|  | * curl version 7.12.2 fails on AIX if compiled with --enable-ares. | ||||||
|  |   The workaround is to combine --enable-ares with --disable-shared | ||||||
|  |  | ||||||
|  | * When connecting to a SOCKS proxy, the (connect) timeout is not properly | ||||||
|  |   acknowledged after the actual TCP connect (during the SOCKS "negotiate" | ||||||
|  |   phase). Pointed out by Lucas. Fix: need to select() and timeout properly. | ||||||
|  |  | ||||||
|  | * Using configure --disable-[protocol] may cause 'make test' to fail for | ||||||
|  |   tests using the disabled protocol(s). | ||||||
|  |  | ||||||
| * To get HTTP Negotiate authentication to work fine, you need to provide a | * To get HTTP Negotiate authentication to work fine, you need to provide a | ||||||
|   (fake) user name (this concerns both curl and the lib) because the code |   (fake) user name (this concerns both curl and the lib) because the code | ||||||
|   wrongly only considers authentication if there's a user name provided. |   wrongly only considers authentication if there's a user name provided. | ||||||
|   Bug report #1004841. |   Bug report #1004841. How? http://curl.haxx.se/mail/lib-2004-08/0182.html | ||||||
|  |  | ||||||
| * If you use a very large amount of file descriptors (more than FD_SETSIZE) |  | ||||||
|   and then use libcurl, it might crash on its use of select() which then |  | ||||||
|   stores data out of bounds. Bug report #948950. |  | ||||||
|  |  | ||||||
| * --limit-rate using -d or -F does not work. This is because the limit logic | * --limit-rate using -d or -F does not work. This is because the limit logic | ||||||
|   is provided by the curl app in its read/write callbacks, and when doing |   is provided by the curl app in its read/write callbacks, and when doing | ||||||
| @@ -37,10 +49,6 @@ may have been fixed since this was written! | |||||||
|   libcurl thinks of it as the *compressed* lenght. Some explanations are here: |   libcurl thinks of it as the *compressed* lenght. Some explanations are here: | ||||||
|   http://curl.haxx.se/mail/lib-2003-06/0146.html |   http://curl.haxx.se/mail/lib-2003-06/0146.html | ||||||
|  |  | ||||||
| * Downloading 0 (zero) bytes files over FTP will not create a zero byte file |  | ||||||
|   locally, which is because libcurl doesn't call the write callback with zero |  | ||||||
|   bytes. Explained here: http://curl.haxx.se/mail/archive-2003-04/0143.html |  | ||||||
|  |  | ||||||
| * IPv6 support on AIX 4.3.3 doesn't work due to a missing sockaddr_storage | * IPv6 support on AIX 4.3.3 doesn't work due to a missing sockaddr_storage | ||||||
|   struct. It has been reported to work on AIX 5.1 though. |   struct. It has been reported to work on AIX 5.1 though. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -10,13 +10,14 @@ can lead to for end users. | |||||||
|  |  | ||||||
| I am not a lawyer and this is not legal advice! | I am not a lawyer and this is not legal advice! | ||||||
|  |  | ||||||
| One common dilemma is that GPL[*]-licensed code is not allowed to be linked | One common dilemma is that GPL[1]-licensed code is not allowed to be linked | ||||||
| with code licensed under the Original BSD license (with the announcement | with code licensed under the Original BSD license (with the announcement | ||||||
| clause, unless there's a specified exception in the GPL-licensed module). You | clause, unless there's a specified exception in the GPL-licensed module). You | ||||||
| may still build your own copies that use them all, but distributing them as | may still build your own copies that use them all, but distributing them as | ||||||
| binaries would be to violate the GPL license. This particular problem was | binaries would be to violate the GPL license - unless you accompany your | ||||||
| addressed when the Modified BSD license was created, which does not have the | license with an exception[2]. This particular problem was addressed when the | ||||||
| annoncement clause that collides with GPL. | Modified BSD license was created, which does not have the annoncement clause | ||||||
|  | that collides with GPL. | ||||||
|  |  | ||||||
| libcurl http://curl.haxx.se/docs/copyright.html | libcurl http://curl.haxx.se/docs/copyright.html | ||||||
|  |  | ||||||
| @@ -80,4 +81,6 @@ OpenLDAP http://www.openldap.org/software/release/license.html | |||||||
|         linked with libcurl in an app. |         linked with libcurl in an app. | ||||||
|  |  | ||||||
|  |  | ||||||
| [*] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html | [1] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html | ||||||
|  | [2] = http://www.fsf.org/licenses/gpl-faq.html#GPLIncompatibleLibs details on | ||||||
|  |       how to write such an exception to the GPL | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								docs/MANUAL
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								docs/MANUAL
									
									
									
									
									
								
							| @@ -170,8 +170,8 @@ UPLOADING | |||||||
|  |  | ||||||
|         curl -T - http://www.upload.com/myfile |         curl -T - http://www.upload.com/myfile | ||||||
|  |  | ||||||
|   Note that the http server must've been configured to accept PUT before this |   Note that the http server must have been configured to accept PUT before | ||||||
|   can be done successfully. |   this can be done successfully. | ||||||
|  |  | ||||||
|   For other ways to do http data upload, see the POST section below. |   For other ways to do http data upload, see the POST section below. | ||||||
|  |  | ||||||
| @@ -370,7 +370,7 @@ COOKIES | |||||||
|         curl -b headers www.example.com |         curl -b headers www.example.com | ||||||
|  |  | ||||||
|   While saving headers to a file is a working way to store cookies, it is |   While saving headers to a file is a working way to store cookies, it is | ||||||
|   however error-prone and not the prefered way to do this. Instead, make curl |   however error-prone and not the preferred way to do this. Instead, make curl | ||||||
|   save the incoming cookies using the well-known netscape cookie format like |   save the incoming cookies using the well-known netscape cookie format like | ||||||
|   this: |   this: | ||||||
|  |  | ||||||
| @@ -388,7 +388,7 @@ COOKIES | |||||||
|   file contents.  In the above command, curl will parse the header and store |   file contents.  In the above command, curl will parse the header and store | ||||||
|   the cookies received from www.example.com.  curl will send to the server the |   the cookies received from www.example.com.  curl will send to the server the | ||||||
|   stored cookies which match the request as it follows the location.  The |   stored cookies which match the request as it follows the location.  The | ||||||
|   file "empty.txt" may be a non-existant file. |   file "empty.txt" may be a nonexistent file. | ||||||
|  |  | ||||||
|   Alas, to both read and write cookies from a netscape cookie file, you can |   Alas, to both read and write cookies from a netscape cookie file, you can | ||||||
|   set both -b and -c to use the same file: |   set both -b and -c to use the same file: | ||||||
| @@ -417,7 +417,7 @@ PROGRESS METER | |||||||
|    Upload        - the average transfer speed of the upload |    Upload        - the average transfer speed of the upload | ||||||
|    Time Total    - expected time to complete the operation |    Time Total    - expected time to complete the operation | ||||||
|    Time Current  - time passed since the invoke |    Time Current  - time passed since the invoke | ||||||
|    Time Left     - expected time left to completetion |    Time Left     - expected time left to completion | ||||||
|    Curr.Speed    - the average transfer speed the last 5 seconds (the first |    Curr.Speed    - the average transfer speed the last 5 seconds (the first | ||||||
|                    5 seconds of a transfer is based on less time of course.) |                    5 seconds of a transfer is based on less time of course.) | ||||||
|  |  | ||||||
| @@ -437,14 +437,14 @@ SPEED LIMIT | |||||||
|         curl -Y 3000 -y 60 www.far-away-site.com |         curl -Y 3000 -y 60 www.far-away-site.com | ||||||
|  |  | ||||||
|   This can very well be used in combination with the overall time limit, so |   This can very well be used in combination with the overall time limit, so | ||||||
|   that the above operatioin must be completed in whole within 30 minutes: |   that the above operation must be completed in whole within 30 minutes: | ||||||
|  |  | ||||||
|         curl -m 1800 -Y 3000 -y 60 www.far-away-site.com |         curl -m 1800 -Y 3000 -y 60 www.far-away-site.com | ||||||
|  |  | ||||||
|   Forcing curl not to transfer data faster than a given rate is also possible, |   Forcing curl not to transfer data faster than a given rate is also possible, | ||||||
|   which might be useful if you're using a limited bandwidth connection and you |   which might be useful if you're using a limited bandwidth connection and you | ||||||
|   don't want your transfer to use all of it (sometimes referred to as |   don't want your transfer to use all of it (sometimes referred to as | ||||||
|   "bandwith throttle"). |   "bandwidth throttle"). | ||||||
|  |  | ||||||
|   Make curl transfer data no faster than 10 kilobytes per second: |   Make curl transfer data no faster than 10 kilobytes per second: | ||||||
|  |  | ||||||
| @@ -590,7 +590,7 @@ HTTPS | |||||||
|  |  | ||||||
|   Secure HTTP requires SSL libraries to be installed and used when curl is |   Secure HTTP requires SSL libraries to be installed and used when curl is | ||||||
|   built. If that is done, curl is capable of retrieving and posting documents |   built. If that is done, curl is capable of retrieving and posting documents | ||||||
|   using the HTTPS procotol. |   using the HTTPS protocol. | ||||||
|  |  | ||||||
|   Example: |   Example: | ||||||
|  |  | ||||||
| @@ -765,7 +765,7 @@ NETRC | |||||||
|   to specify name and password for commonly visited ftp sites in a file so |   to specify name and password for commonly visited ftp sites in a file so | ||||||
|   that you don't have to type them in each time you visit those sites. You |   that you don't have to type them in each time you visit those sites. You | ||||||
|   realize this is a big security risk if someone else gets hold of your |   realize this is a big security risk if someone else gets hold of your | ||||||
|   passwords, so therefor most unix programs won't read this file unless it is |   passwords, so therefore most unix programs won't read this file unless it is | ||||||
|   only readable by yourself (curl doesn't care though). |   only readable by yourself (curl doesn't care though). | ||||||
|  |  | ||||||
|   Curl supports .netrc files if told so (using the -n/--netrc and |   Curl supports .netrc files if told so (using the -n/--netrc and | ||||||
| @@ -830,22 +830,22 @@ TELNET | |||||||
|   to track when the login prompt is received and send the username and |   to track when the login prompt is received and send the username and | ||||||
|   password accordingly. |   password accordingly. | ||||||
|  |  | ||||||
| PERSISTANT CONNECTIONS | PERSISTENT CONNECTIONS | ||||||
|  |  | ||||||
|   Specifying multiple files on a single command line will make curl transfer |   Specifying multiple files on a single command line will make curl transfer | ||||||
|   all of them, one after the other in the specified order. |   all of them, one after the other in the specified order. | ||||||
|  |  | ||||||
|   libcurl will attempt to use persistant connections for the transfers so that |   libcurl will attempt to use persistent connections for the transfers so that | ||||||
|   the second transfer to the same host can use the same connection that was |   the second transfer to the same host can use the same connection that was | ||||||
|   already initiated and was left open in the previous transfer. This greatly |   already initiated and was left open in the previous transfer. This greatly | ||||||
|   decreases connection time for all but the first transfer and it makes a far |   decreases connection time for all but the first transfer and it makes a far | ||||||
|   better use of the network. |   better use of the network. | ||||||
|  |  | ||||||
|   Note that curl cannot use persistant connections for transfers that are used |   Note that curl cannot use persistent connections for transfers that are used | ||||||
|   in subsequence curl invokes. Try to stuff as many URLs as possible on the |   in subsequence curl invokes. Try to stuff as many URLs as possible on the | ||||||
|   same command line if they are using the same host, as that'll make the |   same command line if they are using the same host, as that'll make the | ||||||
|   transfers faster. If you use a http proxy for file transfers, practicly |   transfers faster. If you use a http proxy for file transfers, practically | ||||||
|   all transfers will be persistant. |   all transfers will be persistent. | ||||||
|  |  | ||||||
| MAILING LISTS | MAILING LISTS | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32,7 +32,41 @@ server, do one of the following: | |||||||
|     configure with the --with-ca-bundle option pointing out the path of your |     configure with the --with-ca-bundle option pointing out the path of your | ||||||
|     choice. |     choice. | ||||||
|  |  | ||||||
|     If you're using the curl command line tool, you can specify your own CA |     To do this, you need to get the CA cert for your server in PEM format and | ||||||
|  |     then append that to your CA cert bundle. | ||||||
|  |  | ||||||
|  |     If you use Internet Explorer, this is one way to get extract the CA cert | ||||||
|  |     for a particular server: | ||||||
|  |  | ||||||
|  |      o View the certificate by double-clicking the padlock | ||||||
|  |      o Find out where the CA certificate is kept (Certificate> | ||||||
|  |        Authority Information Access>URL) | ||||||
|  |      o Get a copy of the crt file using curl | ||||||
|  |      o Convert it from crt to PEM using the openssl tool: | ||||||
|  |        openssl x509 -inform DES -in yourdownloaded.crt \ | ||||||
|  |        -out outcert.pem -text | ||||||
|  |      o Append the 'outcert.pem' to the CA cert bundle or use it stand-alone | ||||||
|  |        as described below. | ||||||
|  |  | ||||||
|  |      (Thanks to Frankie V for this description) | ||||||
|  |  | ||||||
|  |     If you use the 'openssl' tool, this is one way to get extract the CA cert | ||||||
|  |     for a particular server: | ||||||
|  |  | ||||||
|  |      o openssl s_client -connect xxxxx.com:443 |tee logfile | ||||||
|  |      o type "QUIT", followed by the "ENTER" key | ||||||
|  |      o The certificate will have "BEGIN CERTIFICATE" and "END CERTIFICATE" | ||||||
|  |        markers. | ||||||
|  |      o If you want to see the data in the certificate, you can do: "openssl | ||||||
|  |        x509 -inform PEM -in certfile -text -out certdata" where certfile is | ||||||
|  |        the cert you extracted from logfile. Look in certdata. | ||||||
|  |      o If you want to trust the certificate, you can append it to your | ||||||
|  |        cert_bundle or use it stand-alone as described. Just remember that the | ||||||
|  |        security is no better than the way you obtained the certificate. | ||||||
|  |  | ||||||
|  |      (Thanks to Doug Kaufman for this description) | ||||||
|  |  | ||||||
|  |  4. If you're using the curl command line tool, you can specify your own CA | ||||||
|     cert path by setting the environment variable CURL_CA_BUNDLE to the path |     cert path by setting the environment variable CURL_CA_BUNDLE to the path | ||||||
|     of your choice. |     of your choice. | ||||||
|  |  | ||||||
| @@ -45,7 +79,7 @@ server, do one of the following: | |||||||
|       4. Windows Directory (e.g. C:\windows) |       4. Windows Directory (e.g. C:\windows) | ||||||
|       5. all directories along %PATH% |       5. all directories along %PATH% | ||||||
|  |  | ||||||
|  4. Get a better/different/newer CA cert bundle! One option is to extract the |  5. Get a better/different/newer CA cert bundle! One option is to extract the | ||||||
|     one a recent Mozilla browser uses, by following the instruction found |     one a recent Mozilla browser uses, by following the instruction found | ||||||
|     here: |     here: | ||||||
|  |  | ||||||
| @@ -56,9 +90,3 @@ certificate that isn't signed by one of the certificates in the installed CA | |||||||
| cert bundle, will cause SSL to report an error ("certificate verify failed") | cert bundle, will cause SSL to report an error ("certificate verify failed") | ||||||
| during the handshake and SSL will then refuse further communication with that | during the handshake and SSL will then refuse further communication with that | ||||||
| server. | server. | ||||||
|  |  | ||||||
| This procedure has been deemed The Right Thing even though it adds this extra |  | ||||||
| trouble for some users, since it adds security to a majority of the SSL |  | ||||||
| connections that previously weren't really secure. It turned out many people |  | ||||||
| were using previous versions of curl/libcurl without realizing the need for |  | ||||||
| the CA cert options to get truly secure SSL connections. |  | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -98,3 +98,13 @@ Gisle Vanem <gvanem@broadpark.no> | |||||||
| Giuseppe Attardi <attardi@di.unipi.it> | Giuseppe Attardi <attardi@di.unipi.it> | ||||||
| Tor Arntsen <tor@spacetec.no> | Tor Arntsen <tor@spacetec.no> | ||||||
| David Byron <DByron@everdreamcorp.com> | David Byron <DByron@everdreamcorp.com> | ||||||
|  | David Phillips | ||||||
|  | Alexander Krasnostavsky | ||||||
|  | G<EFBFBD>nter Knauf | ||||||
|  | Bertrand Demiddelaer | ||||||
|  | Peter Sylvester | ||||||
|  | Alexis S. L. Carvalho | ||||||
|  | Casey O'Donnell | ||||||
|  | Marty Kuhrt | ||||||
|  | James Bursa | ||||||
|  | Greg Hewgill | ||||||
|   | |||||||
							
								
								
									
										68
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										68
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -15,10 +15,10 @@ TODO | |||||||
|  LIBCURL |  LIBCURL | ||||||
|  |  | ||||||
|  * Introduce an interface to libcurl that allows applications to easier get to |  * Introduce an interface to libcurl that allows applications to easier get to | ||||||
|    know what cookies that are received. Pushing interface that calls a |    know what cookies that are received. CURLINFO_COOKIELIST to get a | ||||||
|    callback on each received cookie? Querying interface that asks about |    curl_slist with cookies (netscape/mozilla cookie file formatted), and | ||||||
|    existing cookies? We probably need both. Enable applications to modify |    CURLOPT_COOKIELIST to set a list of cookies (using the same format). | ||||||
|    existing cookies as well. http://curl.haxx.se/dev/COOKIES |    http://curl.haxx.se/mail/lib-2004-12/0195.html | ||||||
|  |  | ||||||
|  * Introduce another callback interface for upload/download that makes one |  * Introduce another callback interface for upload/download that makes one | ||||||
|    less copy of data and thus a faster operation. |    less copy of data and thus a faster operation. | ||||||
| @@ -33,11 +33,16 @@ TODO | |||||||
|    return informational stuff as errors, consider a new info returned by |    return informational stuff as errors, consider a new info returned by | ||||||
|    curl_easy_getinfo() #845941 |    curl_easy_getinfo() #845941 | ||||||
|  |  | ||||||
|  * Option to set the SO_KEEPALIVE socket option to make libcurl notice and |  * Use 'struct lifreq' and SIOCGLIFADDR instead of 'struct ifreq' and | ||||||
|    disconnect very long time idle connections. |    SIOCGIFADDR on newer Solaris versions as they claim the latter is obsolete. | ||||||
|  |  | ||||||
|  LIBCURL - multi interface |  LIBCURL - multi interface | ||||||
|  |  | ||||||
|  |  * Add a curl_multi_fdset() alternative that returns only two arrays with file | ||||||
|  |    desrciptors for reading and writing to allow the app to use whatever | ||||||
|  |    function it prefers. Plus, this allows apps to avoid the FD_SETSIZE problem | ||||||
|  |    with select(). | ||||||
|  |  | ||||||
|  * Add curl_multi_timeout() to make libcurl's ares-functionality better. |  * Add curl_multi_timeout() to make libcurl's ares-functionality better. | ||||||
|  |  | ||||||
|  * Make sure we don't ever loop because of non-blocking sockets return |  * Make sure we don't ever loop because of non-blocking sockets return | ||||||
| @@ -61,12 +66,10 @@ TODO | |||||||
|    authentication and file encryption.  Possible libraries and example clients |    authentication and file encryption.  Possible libraries and example clients | ||||||
|    are available from MIT or Heimdal. Requsted by Markus Moeller. |    are available from MIT or Heimdal. Requsted by Markus Moeller. | ||||||
|  |  | ||||||
|  * Optimize the way libcurl uses CWD on each new request over a persistent |  | ||||||
|    connection (on FTP) even if it doesn't have to. |  | ||||||
|  |  | ||||||
|  * REST fix for servers not behaving well on >2GB requests. This should fail |  * REST fix for servers not behaving well on >2GB requests. This should fail | ||||||
|    if the server doesn't set the pointer to the requested index. The tricky |    if the server doesn't set the pointer to the requested index. The tricky | ||||||
|    part is to figure out if the server did the right thing or not. |    (impossible?) part is to figure out if the server did the right thing or | ||||||
|  |    not. | ||||||
|  |  | ||||||
|  * Support the most common FTP proxies, Philip Newton provided a list |  * Support the most common FTP proxies, Philip Newton provided a list | ||||||
|    allegedly from ncftp: |    allegedly from ncftp: | ||||||
| @@ -111,21 +114,19 @@ TODO | |||||||
|  * Evaluate/apply Gertjan van Wingerde's SSL patches: |  * Evaluate/apply Gertjan van Wingerde's SSL patches: | ||||||
|    http://curl.haxx.se/mail/lib-2004-03/0087.html |    http://curl.haxx.se/mail/lib-2004-03/0087.html | ||||||
|  |  | ||||||
|  * If you really want to improve the SSL situation, you should probably have a |  * "Look at SSL cafile - quick traces look to me like these are done on every | ||||||
|    look at SSL cafile loading as well - quick traces look to me like these are |    request as well, when they should only be necessary once per ssl context | ||||||
|    done on every request as well, when they should only be necessary once per |    (or once per handle)". The major improvement we can rather easily do is to | ||||||
|    ssl context (or once per handle). Even better would be to support the SSL |    make sure we don't create and kill a new SSL "context" for every request, | ||||||
|    CAdir option - instead of loading all of the root CA certs for every |    but instead make one for every connection and re-use that SSL context in | ||||||
|    request, this option allows you to only read the CA chain that is actually |    the same style connections are re-used. It will make us use slightly more | ||||||
|    required (into the cache)... |    memory but it will libcurl do less creations and deletions of SSL contexts. | ||||||
|  |  | ||||||
|  * Add an interface to libcurl that enables "session IDs" to get |  * Add an interface to libcurl that enables "session IDs" to get | ||||||
|    exported/imported. Cris Bailiff said: "OpenSSL has functions which can |    exported/imported. Cris Bailiff said: "OpenSSL has functions which can | ||||||
|    serialise the current SSL state to a buffer of your choice, and |    serialise the current SSL state to a buffer of your choice, and | ||||||
|    recover/reset the state from such a buffer at a later date - this is used |    recover/reset the state from such a buffer at a later date - this is used | ||||||
|    by mod_ssl for apache to implement and SSL session ID cache". This whole |    by mod_ssl for apache to implement and SSL session ID cache". | ||||||
|    idea might become moot if we enable the 'data sharing' as mentioned in the |  | ||||||
|    LIBCURL label above. |  | ||||||
|  |  | ||||||
|  * OpenSSL supports a callback for customised verification of the peer |  * OpenSSL supports a callback for customised verification of the peer | ||||||
|    certificate, but this doesn't seem to be exposed in the libcurl APIs. Could |    certificate, but this doesn't seem to be exposed in the libcurl APIs. Could | ||||||
| @@ -134,8 +135,12 @@ TODO | |||||||
|  |  | ||||||
|  * Make curl's SSL layer option capable of using other free SSL libraries. |  * Make curl's SSL layer option capable of using other free SSL libraries. | ||||||
|    Such as the Mozilla Security Services |    Such as the Mozilla Security Services | ||||||
|    (http://www.mozilla.org/projects/security/pki/nss/) and GNUTLS |    (http://www.mozilla.org/projects/security/pki/nss/) and GnuTLS | ||||||
|    (http://gnutls.hellug.gr/) |    (http://www.gnu.org/software/gnutls/) This subject has been brought up | ||||||
|  |    again recently since GPL-licensed applications that link with libcurl MAY | ||||||
|  |    NOT distribute binaries that use OpenSSL without adding an exception clause | ||||||
|  |    to the GPL license. See the LICENSE-MIXING document and this: | ||||||
|  |    http://www.gnome.org/~markmc/openssl-and-the-gpl.html | ||||||
|  |  | ||||||
|  LDAP |  LDAP | ||||||
|  |  | ||||||
| @@ -145,6 +150,17 @@ TODO | |||||||
|  |  | ||||||
|  CLIENT |  CLIENT | ||||||
|  |  | ||||||
|  |  * "curl --sync http://example.com/feed[1-100].rss" or | ||||||
|  |    "curl --sync http://example.net/{index,calendar,history}.html" | ||||||
|  |  | ||||||
|  |    Downloads a range or set of URLs using the remote name, but only if the | ||||||
|  |    remote file is newer than the local file. A Last-Modified HTTP date header | ||||||
|  |    should also be used to set the mod date on the downloaded file. | ||||||
|  |    (idea from "Brianiac") | ||||||
|  |  | ||||||
|  |  * Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'. | ||||||
|  |    Requested by Dane Jensen and others. This is easily scripted though. | ||||||
|  |  | ||||||
|  * Add an option that prevents cURL from overwiting existing local files. When |  * Add an option that prevents cURL from overwiting existing local files. When | ||||||
|    used, and there already is an existing file with the target file name |    used, and there already is an existing file with the target file name | ||||||
|    (either -O or -o), a number should be appended (and increased if already |    (either -O or -o), a number should be appended (and increased if already | ||||||
| @@ -182,7 +198,7 @@ TODO | |||||||
|    command line. Possibly by letting ':' separate options between URLs, |    command line. Possibly by letting ':' separate options between URLs, | ||||||
|    similar to this: |    similar to this: | ||||||
|  |  | ||||||
|       curl --data foo --url url.com : |       curl --data foo --url url.com : \ | ||||||
|           --url url2.com : \ |           --url url2.com : \ | ||||||
|           --url url3.com --data foo3 |           --url url3.com --data foo3 | ||||||
|  |  | ||||||
| @@ -200,9 +216,6 @@ TODO | |||||||
|  * 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. | ||||||
|  |  | ||||||
|  * Make runtests.pl capable of changing port numbers for the servers. This was |  | ||||||
|    the intention from the start, but in practise it is now hard. |  | ||||||
|  |  | ||||||
|  * If perl wasn't found by the configure script, don't attempt to run the |  * If perl wasn't found by the configure script, don't attempt to run the | ||||||
|    tests but explain something nice why it doesn't. |    tests but explain something nice why it doesn't. | ||||||
|  |  | ||||||
| @@ -229,3 +242,6 @@ TODO | |||||||
|  |  | ||||||
|    They will instead become curlx_ - alternatives. That makes the curl app |    They will instead become curlx_ - alternatives. That makes the curl app | ||||||
|    still capable of building with them from source. |    still capable of building with them from source. | ||||||
|  |  | ||||||
|  |  * Remove support for CURLOPT_FAILONERROR, it has gotten too kludgy and weird | ||||||
|  |    internally. Let the app judge success or not for itself. | ||||||
|   | |||||||
| @@ -1,7 +1,5 @@ | |||||||
| Online:  http://curl.haxx.se/docs/httpscripting.shtml | Online:  http://curl.haxx.se/docs/httpscripting.shtml | ||||||
| Author:  Daniel Stenberg <daniel@haxx.se> | Date:    December 9, 2004 | ||||||
| Date:    November 6, 2001 |  | ||||||
| Version: 0.6 |  | ||||||
|  |  | ||||||
|                 The Art Of Scripting HTTP Requests Using Curl |                 The Art Of Scripting HTTP Requests Using Curl | ||||||
|                 ============================================= |                 ============================================= | ||||||
| @@ -139,11 +137,11 @@ Version: 0.6 | |||||||
|   you need to replace that space with %20 etc. Failing to comply with this |   you need to replace that space with %20 etc. Failing to comply with this | ||||||
|   will most likely cause your data to be received wrongly and messed up. |   will most likely cause your data to be received wrongly and messed up. | ||||||
|  |  | ||||||
|  4.3 FILE UPLOAD POST |  4.3 File Upload POST | ||||||
|  |  | ||||||
|   Back in late 1995 they defined a new way to post data over HTTP. It was |   Back in late 1995 they defined an additional way to post data over HTTP. It | ||||||
|   documented in the RFC 1867, why this method sometimes is referred to as |   is documented in the RFC 1867, why this method sometimes is referred to as | ||||||
|   a RFC1867-posting. |   RFC1867-posting. | ||||||
|  |  | ||||||
|   This method is mainly designed to better support file uploads. A form that |   This method is mainly designed to better support file uploads. A form that | ||||||
|   allows a user to upload a file could be written like this in HTML: |   allows a user to upload a file could be written like this in HTML: | ||||||
| @@ -160,7 +158,7 @@ Version: 0.6 | |||||||
|  |  | ||||||
|         curl -F upload=@localfilename -F press=OK [URL] |         curl -F upload=@localfilename -F press=OK [URL] | ||||||
|  |  | ||||||
|  4.4 HIDDEN FIELDS |  4.4 Hidden Fields | ||||||
|  |  | ||||||
|   A very common way for HTML based application to pass state information |   A very common way for HTML based application to pass state information | ||||||
|   between pages is to add hidden fields to the forms. Hidden fields are |   between pages is to add hidden fields to the forms. Hidden fields are | ||||||
| @@ -181,7 +179,7 @@ Version: 0.6 | |||||||
|  |  | ||||||
|         curl -d "birthyear=1905&press=OK&person=daniel" [URL] |         curl -d "birthyear=1905&press=OK&person=daniel" [URL] | ||||||
|  |  | ||||||
|  4.5 FIGURE OUT WHAT A POST LOOKS LIKE |  4.5 Figure Out What A POST Looks Like | ||||||
|  |  | ||||||
|   When you're about fill in a form and send to a server by using curl instead |   When you're about fill in a form and send to a server by using curl instead | ||||||
|   of a browser, you're of course very interested in sending a POST exactly the |   of a browser, you're of course very interested in sending a POST exactly the | ||||||
| @@ -204,7 +202,7 @@ Version: 0.6 | |||||||
|  |  | ||||||
|         curl -T uploadfile www.uploadhttp.com/receive.cgi |         curl -T uploadfile www.uploadhttp.com/receive.cgi | ||||||
|  |  | ||||||
| 6. AUTHENTICATION | 6. Authentication | ||||||
|  |  | ||||||
|  Authentication is the ability to tell the server your username and password |  Authentication is the ability to tell the server your username and password | ||||||
|  so that it can verify that you're allowed to do the request you're doing. The |  so that it can verify that you're allowed to do the request you're doing. The | ||||||
| @@ -229,31 +227,31 @@ Version: 0.6 | |||||||
|         curl -U proxyuser:proxypassword curl.haxx.se |         curl -U proxyuser:proxypassword curl.haxx.se | ||||||
|  |  | ||||||
|  If your proxy requires the authentication to be done using the NTLM method, |  If your proxy requires the authentication to be done using the NTLM method, | ||||||
|  use --proxy-ntlm. |  use --proxy-ntlm, if it requires Digest use --proxy-digest. | ||||||
|  |  | ||||||
|  If you use any one these user+password options but leave out the password |  If you use any one these user+password options but leave out the password | ||||||
|  part, curl will prompt for the password interactively. |  part, curl will prompt for the password interactively. | ||||||
|  |  | ||||||
|  Do note that when a program is run, its parameters are possible to see when |  Do note that when a program is run, its parameters might be possible to see | ||||||
|  listing the running processes of the system. Thus, other users may be able to |  when listing the running processes of the system. Thus, other users may be | ||||||
|  watch your passwords if you pass them as plain command line options. There |  able to watch your passwords if you pass them as plain command line | ||||||
|  are ways to circumvent this. |  options. There are ways to circumvent this. | ||||||
|  |  | ||||||
| 7. REFERER | 7. Referer | ||||||
|  |  | ||||||
|  A HTTP request may include a 'referer' field, which can be used to tell from |  A HTTP request may include a 'referer' field (yes it is misspelled), which | ||||||
|  which URL the client got to this particular resource. Some programs/scripts |  can be used to tell from which URL the client got to this particular | ||||||
|  check the referer field of requests to verify that this wasn't arriving from |  resource. Some programs/scripts check the referer field of requests to verify | ||||||
|  an external site or an unknown page. While this is a stupid way to check |  that this wasn't arriving from an external site or an unknown page. While | ||||||
|  something so easily forged, many scripts still do it. Using curl, you can put |  this is a stupid way to check something so easily forged, many scripts still | ||||||
|  anything you want in the referer-field and thus more easily be able to fool |  do it. Using curl, you can put anything you want in the referer-field and | ||||||
|  the server into serving your request. |  thus more easily be able to fool the server into serving your request. | ||||||
|  |  | ||||||
|  Use curl to set the referer field with: |  Use curl to set the referer field with: | ||||||
|  |  | ||||||
|         curl -e http://curl.haxx.se daniel.haxx.se |         curl -e http://curl.haxx.se daniel.haxx.se | ||||||
|  |  | ||||||
| 8. USER AGENT | 8. User Agent | ||||||
|  |  | ||||||
|  Very similar to the referer field, all HTTP requests may set the User-Agent |  Very similar to the referer field, all HTTP requests may set the User-Agent | ||||||
|  field. It names what user agent (client) that is being used. Many |  field. It names what user agent (client) that is being used. Many | ||||||
| @@ -275,7 +273,7 @@ Version: 0.6 | |||||||
|  |  | ||||||
|         curl -A "Mozilla/4.73 [en] (X11; U; Linux 2.2.15 i686)" [URL] |         curl -A "Mozilla/4.73 [en] (X11; U; Linux 2.2.15 i686)" [URL] | ||||||
|  |  | ||||||
| 9. REDIRECTS | 9. Redirects | ||||||
|  |  | ||||||
|  When a resource is requested from a server, the reply from the server may |  When a resource is requested from a server, the reply from the server may | ||||||
|  include a hint about where the browser should go next to find this page, or a |  include a hint about where the browser should go next to find this page, or a | ||||||
| @@ -294,7 +292,7 @@ Version: 0.6 | |||||||
|  page, you can safely use -L and -d/-F together. Curl will only use POST in |  page, you can safely use -L and -d/-F together. Curl will only use POST in | ||||||
|  the first request, and then revert to GET in the following operations. |  the first request, and then revert to GET in the following operations. | ||||||
|  |  | ||||||
| 10. COOKIES | 10. Cookies | ||||||
|  |  | ||||||
|  The way the web browsers do "client side state control" is by using |  The way the web browsers do "client side state control" is by using | ||||||
|  cookies. Cookies are just names with associated contents. The cookies are |  cookies. Cookies are just names with associated contents. The cookies are | ||||||
| @@ -366,7 +364,7 @@ Version: 0.6 | |||||||
|  |  | ||||||
|         curl https://that.secure.server.com |         curl https://that.secure.server.com | ||||||
|  |  | ||||||
|  11.1 CERTIFICATES |  11.1 Certificates | ||||||
|  |  | ||||||
|   In the HTTPS world, you use certificates to validate that you are the one |   In the HTTPS world, you use certificates to validate that you are the one | ||||||
|   you you claim to be, as an addition to normal passwords. Curl supports |   you you claim to be, as an addition to normal passwords. Curl supports | ||||||
| @@ -379,11 +377,67 @@ Version: 0.6 | |||||||
|         curl -E mycert.pem https://that.secure.server.com |         curl -E mycert.pem https://that.secure.server.com | ||||||
|  |  | ||||||
|   curl also tries to verify that the server is who it claims to be, by |   curl also tries to verify that the server is who it claims to be, by | ||||||
|   verifying the server's certificate against a CA cert bundle. Failing the |   verifying the server's certificate against a locally stored CA cert | ||||||
|   verification will cause curl to deny the connection. You must then use -k in |   bundle. Failing the verification will cause curl to deny the connection. You | ||||||
|   case you want to tell curl to ignore that the server can't be verified. |   must then use -k in case you want to tell curl to ignore that the server | ||||||
|  |   can't be verified. | ||||||
|  |  | ||||||
| 12. REFERENCES |   More about server certificate verification and ca cert bundles can be read | ||||||
|  |   in the SSLCERTS document, available online here: | ||||||
|  |  | ||||||
|  |         http://curl.haxx.se/docs/sslcerts.html | ||||||
|  |  | ||||||
|  | 12. Custom Request Elements | ||||||
|  |  | ||||||
|  |  Doing fancy stuff, you may need to add or change elements of a single curl | ||||||
|  |  request. | ||||||
|  |  | ||||||
|  |  For example, you can change the POST request to a PROPFIND and send the data | ||||||
|  |  as "Content-Type: text/xml" (instead of the default Content-Type) like this: | ||||||
|  |  | ||||||
|  |         curl -d "<xml>" -H "Content-Type: text/xml" -X PROPFIND url.com | ||||||
|  |  | ||||||
|  |  You can delete a default header by providing one without content. Like you | ||||||
|  |  can ruin the request by chopping off the Host: header: | ||||||
|  |  | ||||||
|  |         curl -H "Host:" http://mysite.com | ||||||
|  |  | ||||||
|  |  You can add headers the same way. Your server may want a "Destination:" | ||||||
|  |  header, and you can add it: | ||||||
|  |  | ||||||
|  |         curl -H "Destination: http://moo.com/nowhere" http://url.com | ||||||
|  |  | ||||||
|  | 13. Debug | ||||||
|  |  | ||||||
|  |  Many times when you run curl on a site, you'll notice that the site doesn't | ||||||
|  |  seem to respond the same way to your curl requests as it does to your | ||||||
|  |  browser's. | ||||||
|  |  | ||||||
|  |  Then you need to start making your curl requests more similar to your | ||||||
|  |  browser's requests: | ||||||
|  |  | ||||||
|  |  * Use the --trace-ascii option to store fully detailed logs of the requests | ||||||
|  |    for easier analyzing and better understanding | ||||||
|  |  | ||||||
|  |  * Make sure you check for and use cookies when needed (both reading with -b | ||||||
|  |    and writing with -c) | ||||||
|  |  | ||||||
|  |  * Set user-agent to one like a recent popular browser does | ||||||
|  |  | ||||||
|  |  * Set referer like it is set by the browser | ||||||
|  |  | ||||||
|  |  * If you use POST, make sure you send all the fields and in the same order as | ||||||
|  |    the browser does it. (See chapter 4.5 above) | ||||||
|  |  | ||||||
|  |  A very good helper to make sure you do this right, is the LiveHTTPHeader tool | ||||||
|  |  that lets you view all headers you send and receive with Mozilla/Firefox | ||||||
|  |  (even when using HTTPS). | ||||||
|  |  | ||||||
|  |  A more raw approach is to capture the HTTP traffic on the network with tools | ||||||
|  |  such as ethereal or tcpdump and check what headers that were sent and | ||||||
|  |  received by the browser. (HTTPS makes this technique inefficient.) | ||||||
|  |  | ||||||
|  | 14. References | ||||||
|  |  | ||||||
|  RFC 2616 is a must to read if you want in-depth understanding of the HTTP |  RFC 2616 is a must to read if you want in-depth understanding of the HTTP | ||||||
|  protocol. |  protocol. | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| .\" nroff -man curl-config.1 | .\" nroff -man curl-config.1 | ||||||
| .\" Written by Daniel Stenberg | .\" Written by Daniel Stenberg | ||||||
| .\" | .\" | ||||||
| .TH curl-config 1 "8 Oct 2002" "Curl 7.10" "curl-config manual" | .TH curl-config 1 "11 Dec 2004" "Curl 7.10" "curl-config manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl-config \- Get information about a libcurl installation | curl-config \- Get information about a libcurl installation | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -38,7 +38,8 @@ Outputs version information about the installed libcurl. | |||||||
| Outputs version information about the installed libcurl, in numerical mode. | Outputs version information about the installed libcurl, in numerical mode. | ||||||
| This outputs the version number, in hexadecimal, with 8 bits for each part; | This outputs the version number, in hexadecimal, with 8 bits for each part; | ||||||
| major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl | major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl | ||||||
| 12.13.14 would appear as 0c0d0e... | 12.13.14 would appear as 0c0d0e... Note that the initial zero might be | ||||||
|  | omitted. | ||||||
| .SH "EXAMPLES" | .SH "EXAMPLES" | ||||||
| What linker options do I need when I link with libcurl? | What linker options do I need when I link with libcurl? | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										117
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										117
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -21,7 +21,7 @@ | |||||||
| .\" * $Id$ | .\" * $Id$ | ||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" | .\" | ||||||
| .TH curl 1 "3 May 2004" "Curl 7.12" "Curl Manual" | .TH curl 1 "7 Dec 2004" "Curl 7.12.3" "Curl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl \- transfer a URL | curl \- transfer a URL | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -91,6 +91,11 @@ network round-trip. This is used instead of setting a specific authentication | |||||||
| method, which you can do with \fI--basic\fP, \fI--digest\fP, \fI--ntlm\fP, and | method, which you can do with \fI--basic\fP, \fI--digest\fP, \fI--ntlm\fP, and | ||||||
| \fI--negotiate\fP. (Added in 7.10.6) | \fI--negotiate\fP. (Added in 7.10.6) | ||||||
|  |  | ||||||
|  | Note that using --anyauth is not recommended if you do uploads from stdin, | ||||||
|  | since it may require data to be sent twice and then the client must be able to | ||||||
|  | rewind. If the need should arise when uploading from stdin, the upload | ||||||
|  | operation will fail. | ||||||
|  |  | ||||||
| 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 "-b/--cookie <name=data>" | .IP "-b/--cookie <name=data>" | ||||||
| @@ -160,12 +165,12 @@ won't fail or even report an error clearly. Using -v will get a warning | |||||||
| displayed, but that is the only visible feedback you get about this possibly | displayed, but that is the only visible feedback you get about this possibly | ||||||
| lethal situation. | lethal situation. | ||||||
|  |  | ||||||
| If this option is used several times, the last specfied file name will be | If this option is used several times, the last specified file name will be | ||||||
| used. | used. | ||||||
| .IP "-C/--continue-at <offset>" | .IP "-C/--continue-at <offset>" | ||||||
| Continue/Resume a previous file transfer at the given offset. The given offset | Continue/Resume a previous file transfer at the given offset. The given offset | ||||||
| is the exact number of bytes that will be skipped counted from the beginning | is the exact number of bytes that will be skipped counted from the beginning | ||||||
| of the source file before it is transfered to the destination.  If used with | of the source file before it is transferred to the destination.  If used with | ||||||
| uploads, the ftp server command SIZE will not be used by curl. | uploads, the ftp server command SIZE will not be used by curl. | ||||||
|  |  | ||||||
| Use "-C -" to tell curl to automatically find out where/how to resume the | Use "-C -" to tell curl to automatically find out where/how to resume the | ||||||
| @@ -236,7 +241,7 @@ active FTP transfers. Curl will normally always first attempt to use EPRT, | |||||||
| then LPRT before using PORT, but with this option, it will use PORT right | then LPRT before using PORT, but with this option, it will use PORT right | ||||||
| away. EPRT and LPRT are extensions to the original FTP protocol, may not work | away. EPRT and LPRT are extensions to the original FTP protocol, may not work | ||||||
| on all servers but enable more functionality in a better way than the | on all servers but enable more functionality in a better way than the | ||||||
| traditional PORT command. (Aded in 7.10.5) | traditional PORT command. (Added in 7.10.5) | ||||||
|  |  | ||||||
| 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 "--disable-epsv" | .IP "--disable-epsv" | ||||||
| @@ -265,6 +270,11 @@ automatically set the previous URL when it follows a Location: header. The | |||||||
| ";auto" string can be used alone, even if you don't set an initial referer. | ";auto" string can be used alone, even if you don't set an initial referer. | ||||||
|  |  | ||||||
| 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 "--engine <name>" | ||||||
|  | Select the OpenSSL crypto engine to use for cipher | ||||||
|  | operations. Use \fI--engine list\fP to print a list of build-time supported | ||||||
|  | engines. Note that not all (or none) of the engines may be available at | ||||||
|  | run-time. | ||||||
| .IP "--environment" | .IP "--environment" | ||||||
| (RISC OS ONLY) Sets a range of environment variables, using the names the -w | (RISC OS ONLY) Sets a range of environment variables, using the names the -w | ||||||
| option supports, to easier allow extraction of useful information after having | option supports, to easier allow extraction of useful information after having | ||||||
| @@ -328,19 +338,19 @@ will instead attempt to create missing directories. (Added in 7.10.7) | |||||||
| 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-pasv" | .IP "--ftp-pasv" | ||||||
| (FTP) Use PASV when transfering. PASV is the internal default behavior, but | (FTP) Use PASV when transfering. PASV is the internal default behavior, but | ||||||
| using this option can be used to override a previos --ftp-port option. (Added | using this option can be used to override a previous --ftp-port option. (Added | ||||||
| in 7.11.0) | in 7.11.0) | ||||||
|  |  | ||||||
| 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-ssl" | .IP "--ftp-ssl" | ||||||
| (FTP) Make the FTP connection switch to use SSL/TLS. (Added in 7.11.0) | (FTP) Make the FTP connection switch to use SSL/TLS. (Added in 7.11.0) | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable silent failure. | 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 | ||||||
| submit button. This causes curl to POST data using the content-type | submit button. This causes curl to POST data using the Content-Type | ||||||
| multipart/form-data according to RFC1867. This enables uploading of binary | multipart/form-data according to RFC1867. This enables uploading of binary | ||||||
| files etc. To force the 'content' part to be be a file, prefix the file name | files etc. To force the 'content' part to be a file, prefix the file name | ||||||
| with an @ sign. To just get the content part from a file, prefix the file name | with an @ sign. To just get the content part from a file, prefix the file name | ||||||
| with the letter <. The difference between @ and < is then that @ makes a file | with the letter <. The difference between @ and < is then that @ makes a file | ||||||
| get attached in the post as a file upload, while the < makes a text field and | get attached in the post as a file upload, while the < makes a text field and | ||||||
| @@ -352,14 +362,18 @@ input: | |||||||
|  |  | ||||||
| \fBcurl\fP -F password=@/etc/passwd www.mypasswords.com | \fBcurl\fP -F password=@/etc/passwd www.mypasswords.com | ||||||
|  |  | ||||||
| To read the file's content from stdin insted of a file, use - where the file | To read the file's content from stdin instead of a file, use - where the file | ||||||
| name should've been. This goes for both @ and < constructs. | name should've been. This goes for both @ and < constructs. | ||||||
|  |  | ||||||
| You can also tell curl what Content-Type to use for the file upload part, by | You can also tell curl what Content-Type to use by using 'type=', in a manner | ||||||
| using 'type=', in a manner similar to: | similar to: | ||||||
|  |  | ||||||
| \fBcurl\fP -F "web=@index.html;type=text/html" url.com | \fBcurl\fP -F "web=@index.html;type=text/html" url.com | ||||||
|  |  | ||||||
|  | or | ||||||
|  |  | ||||||
|  | \fBcurl\fP -F "name=daniel;type=text/foo" url.com | ||||||
|  |  | ||||||
| See further examples and details in the MANUAL. | See further examples and details in the MANUAL. | ||||||
|  |  | ||||||
| This option can be used multiple times. | This option can be used multiple times. | ||||||
| @@ -416,7 +430,7 @@ time only. | |||||||
| If this option is used twice, the second will again disable header only. | If this option is used twice, the second will again disable header only. | ||||||
| .IP "-j/--junk-session-cookies" | .IP "-j/--junk-session-cookies" | ||||||
| (HTTP) When curl is told to read cookies from a given file, this option will | (HTTP) When curl is told to read cookies from a given file, this option will | ||||||
| make it discard all "session cookies". This will basicly have the same effect | make it discard all "session cookies". This will basically have the same effect | ||||||
| as if a new session is started. Typical browsers always discard session | as if a new session is started. Typical browsers always discard session | ||||||
| cookies when they're closed down. (Added in 7.9.7) | cookies when they're closed down. (Added in 7.9.7) | ||||||
|  |  | ||||||
| @@ -444,7 +458,7 @@ If this option is used several times, the last one will be used. | |||||||
| should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use | should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use | ||||||
| a level that is not one of these, 'private' will instead be used. | a level that is not one of these, 'private' will instead be used. | ||||||
|  |  | ||||||
| This option requiures that the library was built with kerberos4 support. This | This option requires that the library was built with kerberos4 support. This | ||||||
| is not very common. Use \fI-V/--version\fP to see if your curl supports it. | is not very common. Use \fI-V/--version\fP to see if your curl supports it. | ||||||
|  |  | ||||||
| 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. | ||||||
| @@ -554,12 +568,12 @@ Very similar to \fI--netrc\fP, but this option makes the .netrc usage | |||||||
| \fBoptional\fP and not mandatory as the \fI--netrc\fP does. | \fBoptional\fP and not mandatory as the \fI--netrc\fP does. | ||||||
| .IP "--negotiate" | .IP "--negotiate" | ||||||
| (HTTP) Enables GSS-Negotiate authentication. The GSS-Negotiate method was | (HTTP) Enables GSS-Negotiate authentication. The GSS-Negotiate method was | ||||||
| designed by Microsoft and is used in their web aplications. It is primarily | designed by Microsoft and is used in their web applications. It is primarily | ||||||
| meant as a support for Kerberos5 authentication but may be also used along | meant as a support for Kerberos5 authentication but may be also used along | ||||||
| with another authentication methods. For more information see IETF draft | with another authentication methods. For more information see IETF draft | ||||||
| draft-brezak-spnego-http-04.txt. (Added in 7.10.6) | draft-brezak-spnego-http-04.txt. (Added in 7.10.6) | ||||||
|  |  | ||||||
| This option requiures that the library was built with GSSAPI support. This is | This option requires that the library was built with GSSAPI support. This is | ||||||
| not very common. Use \fI-V/--version\fP to see if your version supports | not very common. Use \fI-V/--version\fP to see if your version supports | ||||||
| GSS-Negotiate. | GSS-Negotiate. | ||||||
|  |  | ||||||
| @@ -583,7 +597,7 @@ authentication method instead. Such as Digest. (Added in 7.10.6) | |||||||
| If you want to enable NTLM for your proxy authentication, then use | If you want to enable NTLM for your proxy authentication, then use | ||||||
| \fI--proxy-ntlm\fP. | \fI--proxy-ntlm\fP. | ||||||
|  |  | ||||||
| This option requiures that the library was built with SSL support. Use | This option requires that the library was built with SSL support. Use | ||||||
| \fI-V/--version\fP to see if your curl supports NTLM. | \fI-V/--version\fP to see if your curl supports NTLM. | ||||||
|  |  | ||||||
| If this option is used several times, the following occurrences make no | If this option is used several times, the following occurrences make no | ||||||
| @@ -719,6 +733,37 @@ remote file, and if that is available make the local file get that same | |||||||
| timestamp. | timestamp. | ||||||
|  |  | ||||||
| If this option is used twice, the second time disables this again. | If this option is used twice, the second time disables this again. | ||||||
|  | .IP "--retry <num>" | ||||||
|  | If a transient error is returned when curl tries to perform a transfer, it | ||||||
|  | will retry this number of times before giving up. Setting the number to 0 | ||||||
|  | makes curl do no retries (which is the default). Transient error means either: | ||||||
|  | a timeout, an FTP 5xx response code or an HTTP 5xx response code. | ||||||
|  |  | ||||||
|  | When curl is about to retry a transfer, it will first wait one second and then | ||||||
|  | for all forthcoming retries it will double the waiting time until it reaches | ||||||
|  | 10 minutes which then will be the delay between the rest of the retries.  By | ||||||
|  | using \fI--retry-delay\fP you disable this exponential backoff algorithm. See | ||||||
|  | also \fI--retry-max-time\fP to limit the total time allowed for | ||||||
|  | retries. (Option added in 7.12.3) | ||||||
|  |  | ||||||
|  | If this option is used multiple times, the last occurrence decide the amount. | ||||||
|  | .IP "--retry-delay <seconds>" | ||||||
|  | Make curl sleep this amount of time between each retry when a transfer has | ||||||
|  | failed with a transient error (it changes the default backoff time algorithm | ||||||
|  | between retries). This option is only interesting if \fI--retry\fP is also | ||||||
|  | used. Setting this delay to zero will make curl use the default backoff time. | ||||||
|  | (Option added in 7.12.3) | ||||||
|  |  | ||||||
|  | If this option is used multiple times, the last occurrence decide the amount. | ||||||
|  | .IP "--retry-max-time <seconds>" | ||||||
|  | The retry timer is reset before the first transfer attempt. Retries will be | ||||||
|  | done as usual (see \fI--retry\fP) as long as the timer hasn't reached this | ||||||
|  | given limit. Notice that if the timer hasn't reached the limit, the request | ||||||
|  | will be made and while performing, it may take longer than this given time | ||||||
|  | period. To limit a single request\'s maximum time, use \fI-m/--max-time\fP. | ||||||
|  | Set this option to zero to not timeout retries. (Option added in 7.12.3) | ||||||
|  |  | ||||||
|  | If this option is used multiple times, the last occurrence decide the amount. | ||||||
| .IP "-s/--silent" | .IP "-s/--silent" | ||||||
| Silent mode. Don't show progress meter or error messages.  Makes | Silent mode. Don't show progress meter or error messages.  Makes | ||||||
| Curl mute. | Curl mute. | ||||||
| @@ -746,7 +791,7 @@ If this option is used several times, the last one will be used. | |||||||
| Turn on the TCP_NODELAY option. See the \fIcurl_easy_setopt(3)\fP man page for | Turn on the TCP_NODELAY option. See the \fIcurl_easy_setopt(3)\fP man page for | ||||||
| details about this option. (Added in 7.11.2) | details about this option. (Added in 7.11.2) | ||||||
|  |  | ||||||
| If this option is used several times, each occurance toggles this on/off. | If this option is used several times, each occurrence toggles this on/off. | ||||||
| .IP "-t/--telnet-option <OPT=val>" | .IP "-t/--telnet-option <OPT=val>" | ||||||
| Pass options to the telnet protocol. Supported options are: | Pass options to the telnet protocol. Supported options are: | ||||||
|  |  | ||||||
| @@ -816,7 +861,7 @@ starting with '>' means data sent by curl, '<' means data received by curl | |||||||
| that is hidden in normal cases and lines starting with '*' means additional | that is hidden in normal cases and lines starting with '*' means additional | ||||||
| info provided by curl. | info provided by curl. | ||||||
|  |  | ||||||
| Note that if you want to see HTTP headers in the output, \fI-i/--include\fP | Note that if you only want HTTP headers in the output, \fI-i/--include\fP | ||||||
| might be option you're looking for. | might be option you're looking for. | ||||||
|  |  | ||||||
| If you think this option still doesn't give you enough details, consider using | If you think this option still doesn't give you enough details, consider using | ||||||
| @@ -844,16 +889,16 @@ HTTPS and FTPS are supported. | |||||||
| .IP "libz" | .IP "libz" | ||||||
| Automatic decompression of compressed files over HTTP is supported. | Automatic decompression of compressed files over HTTP is supported. | ||||||
| .IP "NTLM" | .IP "NTLM" | ||||||
| NTLM authenticaion is supported. | NTLM authentication is supported. | ||||||
| .IP "GSS-Negotiate" | .IP "GSS-Negotiate" | ||||||
| Negotiate authenticaion is supported. | Negotiate authentication is supported. | ||||||
| .IP "Debug" | .IP "Debug" | ||||||
| This curl uses a libcurl built with Debug. This enables more error-tracking | This curl uses a libcurl built with Debug. This enables more error-tracking | ||||||
| and memory debugging etc. For curl-developers only! | and memory debugging etc. For curl-developers only! | ||||||
| .IP "AsynchDNS" | .IP "AsynchDNS" | ||||||
| This curl uses asynchronous name resolves. | This curl uses asynchronous name resolves. | ||||||
| .IP "SPNEGO" | .IP "SPNEGO" | ||||||
| SPNEGO Negotiate authenticaion is supported. | SPNEGO Negotiate authentication is supported. | ||||||
| .IP "Largefile" | .IP "Largefile" | ||||||
| This curl supports transfers of large files, files larger than 2GB. | This curl supports transfers of large files, files larger than 2GB. | ||||||
| .IP "IDN" | .IP "IDN" | ||||||
| @@ -903,9 +948,15 @@ The time, in seconds, it took from the start until the file transfer is just | |||||||
| about to begin. This includes all pre-transfer commands and negotiations that | about to begin. This includes all pre-transfer commands and negotiations that | ||||||
| are specific to the particular protocol(s) involved. | are specific to the particular protocol(s) involved. | ||||||
| .TP | .TP | ||||||
|  | .B time_redirect | ||||||
|  | The time, in seconds, it took for all redirection steps include name lookup, | ||||||
|  | connect, pretransfer and transfer before final transaction was | ||||||
|  | started. time_redirect shows the complete execution time for multiple | ||||||
|  | redirections. (Added in 7.12.3) | ||||||
|  | .TP | ||||||
| .B time_starttransfer | .B time_starttransfer | ||||||
| The time, in seconds, it took from the start until the first byte is just about | The time, in seconds, it took from the start until the first byte is just about | ||||||
| to be transfered. This includes time_pretransfer and also the time the | to be transferred. This includes time_pretransfer and also the time the | ||||||
| server needs to calculate the result. | server needs to calculate the result. | ||||||
| .TP | .TP | ||||||
| .B size_download | .B size_download | ||||||
| @@ -928,6 +979,12 @@ The average upload speed that curl measured for the complete upload. | |||||||
| .TP | .TP | ||||||
| .B content_type | .B content_type | ||||||
| The Content-Type of the requested document, if there was any. (Added in 7.9.5) | The Content-Type of the requested document, if there was any. (Added in 7.9.5) | ||||||
|  | .TP | ||||||
|  | .B num_connects | ||||||
|  | Number of new connects made in the recent transfer. (Added in 7.12.3) | ||||||
|  | .TP | ||||||
|  | .B num_redirects | ||||||
|  | Number of redirects that were followed in the request. (Added in 7.12.3) | ||||||
| .RE | .RE | ||||||
|  |  | ||||||
| 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. | ||||||
| @@ -940,7 +997,7 @@ use. If there's an environment variable setting a proxy, you can set proxy to | |||||||
| \&"" to override it. | \&"" to override it. | ||||||
|  |  | ||||||
| \fBNote\fP that all operations that are performed over a HTTP proxy will | \fBNote\fP that all operations that are performed over a HTTP proxy will | ||||||
| transparantly be converted to HTTP. It means that certain protocol specific | transparently be converted to HTTP. It means that certain protocol specific | ||||||
| operations might not be available. This is not the case if you can tunnel | operations might not be available. This is not the case if you can tunnel | ||||||
| through the proxy, as done with the \fI-p/--proxytunnel\fP option. | through the proxy, as done with the \fI-p/--proxytunnel\fP option. | ||||||
|  |  | ||||||
| @@ -972,22 +1029,18 @@ 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) | (HTTP) Request a file that has been modified later than the given time and | ||||||
| Request to get 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 | ||||||
| .BR "GNU date(1)" | \fIcurl_getdate(3)\fP man pages for date expression details. | ||||||
| or |  | ||||||
| .BR "curl_getdate(3)" |  | ||||||
| man pages for date expression details. |  | ||||||
|  |  | ||||||
| Start the date expression with a dash (-) to make it request for a document | Start the date expression with a dash (-) to make it request for a document | ||||||
| that is older than the given date/time, default is a document that is newer | that is older than the given date/time, default is a document that is newer | ||||||
| than the specified date/time. | than the specified date/time. | ||||||
|  |  | ||||||
| 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/--max-redirs <num>" | .IP "--max-redirs <num>" | ||||||
| Set maximum number of redirection-followings allowed. If \fI-L/--location\fP | Set maximum number of redirection-followings allowed. If \fI-L/--location\fP | ||||||
| is used, this option can be used to prevent curl from following redirections | is used, this option can be used to prevent curl from following redirections | ||||||
| \&"in absurdum". | \&"in absurdum". | ||||||
| @@ -1077,7 +1130,7 @@ FTP can't reconnect. Couldn't connect to the host we got in the 227-line. | |||||||
| .IP 17 | .IP 17 | ||||||
| FTP couldn't set binary. Couldn't change transfer method to binary. | FTP couldn't set binary. Couldn't change transfer method to binary. | ||||||
| .IP 18 | .IP 18 | ||||||
| Partial file. Only a part of the file was transfered. | Partial file. Only a part of the file was transferred. | ||||||
| .IP 19 | .IP 19 | ||||||
| FTP couldn't download/access the given file, the RETR (or similar) command | FTP couldn't download/access the given file, the RETR (or similar) command | ||||||
| failed. | failed. | ||||||
| @@ -1187,4 +1240,4 @@ ftp://ftp.sunet.se/pub/www/utilities/curl/ | |||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR ftp (1), | .BR ftp (1), | ||||||
| .BR wget (1), | .BR wget (1), | ||||||
| .BR snarf (1) |  | ||||||
|   | |||||||
| @@ -9,7 +9,8 @@ EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c		\ | |||||||
|  ftpupload.c httpput.c simplessl.c ftpgetresp.c http-post.c		\ |  ftpupload.c httpput.c simplessl.c ftpgetresp.c http-post.c		\ | ||||||
|  post-callback.c multi-app.c multi-double.c multi-single.c		\ |  post-callback.c multi-app.c multi-double.c multi-single.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 |  multi-debugcallback.c fileupload.c getinfo.c ftp3rdparty.c debug.c	\ | ||||||
|  |  anyauthput.c | ||||||
|  |  | ||||||
| all: | all: | ||||||
| 	@echo "done" | 	@echo "done" | ||||||
|   | |||||||
| @@ -1,4 +1,8 @@ | |||||||
| EXAMPLES |                                   _   _ ____  _ | ||||||
|  |                               ___| | | |  _ \| | | ||||||
|  |                              / __| | | | |_) | | | ||||||
|  |                             | (__| |_| |  _ <| |___ | ||||||
|  |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
| This directory is for libcurl programming examples. They are meant to show | This directory is for libcurl programming examples. They are meant to show | ||||||
| some simple steps on how you can build your own application to take full | some simple steps on how you can build your own application to take full | ||||||
| @@ -7,6 +11,8 @@ advantage of libcurl. | |||||||
| If you end up with other small but still useful example sources, please mail | If you end up with other small but still useful example sources, please mail | ||||||
| them for submission in future packages and on the web site. | them for submission in future packages and on the web site. | ||||||
|  |  | ||||||
|  | BUILDING | ||||||
|  |  | ||||||
| The Makefile.example is an example makefile that could be used to build these | The Makefile.example is an example makefile that could be used to build these | ||||||
| examples. Just edit the file according to your system and requirements first. | examples. Just edit the file according to your system and requirements first. | ||||||
|  |  | ||||||
| @@ -23,3 +29,34 @@ want you do reorganize them like: | |||||||
| applications/experiments. Even if the examples in this directory use that site | applications/experiments. Even if the examples in this directory use that site | ||||||
| as an example URL at some places, it doesn't mean that the URLs work or that | as an example URL at some places, it doesn't mean that the URLs work or that | ||||||
| we expect you to actually torture our web site with your tests! Thanks. | we expect you to actually torture our web site with your tests! Thanks. | ||||||
|  |  | ||||||
|  | EXAMPLES | ||||||
|  |  | ||||||
|  | anyauthput.c   - HTTP PUT using "any" authentication method | ||||||
|  | curlgtk.c      - download using a GTK progress bar | ||||||
|  | curlx.c        - getting file info from the remote cert data | ||||||
|  | debug.c        - showing how to use the debug callback | ||||||
|  | fileupload.c   - uploading to a file:// URL | ||||||
|  | fopen.c        - fopen() layer that supports opening URLs and files | ||||||
|  | ftp3rdparty.c  - FTP 3rd party transfer | ||||||
|  | ftpget.c       - simple getting a file from FTP | ||||||
|  | ftpgetresp.c   - get the response strings from the FTP server | ||||||
|  | ftpupload.c    - upload a file to a FTP server | ||||||
|  | getinfo.c      - get the Content-Type from the recent transfer | ||||||
|  | getinmemory.c  - download a file to memory only | ||||||
|  | http-post.c    - HTTP POST | ||||||
|  | httpput.c      - HTTP PUT a local file | ||||||
|  | https.c        - simple HTTPS transfer | ||||||
|  | multi-app.c    - a multi-interface app | ||||||
|  | multi-debugcallback.c - a multi-interface app using the debug callback | ||||||
|  | multi-double.c - a multi-interface app doing two simultaneous transfers | ||||||
|  | multi-post.c   - a multi-interface app doing a multipart formpost | ||||||
|  | multi-single.c - a multi-interface app getting a single file | ||||||
|  | multithread.c  - an example using multi-treading transfering multiple files | ||||||
|  | persistant.c   - request two URLs with a persistant connection | ||||||
|  | post-callback.c - send a HTTP POST using a callback | ||||||
|  | postit2.c      - send a HTTP multipart formpost | ||||||
|  | sepheaders.c   - download headers to a separate file | ||||||
|  | simple.c       - the most simple download a URL source | ||||||
|  | simplepost.c   - HTTP POST | ||||||
|  | simplessl.c    - HTTPS example with certificates many options set | ||||||
|   | |||||||
							
								
								
									
										35
									
								
								docs/examples/adddocsref.pl
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										35
									
								
								docs/examples/adddocsref.pl
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | #!/usr/bin/perl | ||||||
|  |  | ||||||
|  | # pass files as argument(s) | ||||||
|  |  | ||||||
|  | my $docroot="http://curl.haxx.se/libcurl/c"; | ||||||
|  |  | ||||||
|  | for $f (@ARGV) { | ||||||
|  |     open(NEW, ">$f.new"); | ||||||
|  |     open(F, "<$f"); | ||||||
|  |     while(<F>) { | ||||||
|  |         my $l = $_; | ||||||
|  |         if($l =~ /\/* $docroot/) { | ||||||
|  |             # just ignore preciously added refs | ||||||
|  |         } | ||||||
|  |         elsif($l =~ /^( *).*curl_easy_setopt\([^,]*, *([^ ,]*) *,/) { | ||||||
|  |             my ($prefix, $anc) = ($1, $2); | ||||||
|  |             $anc =~ s/_//g; | ||||||
|  |             print NEW "$prefix/* $docroot/curl_easy_setopt.html#$anc */\n"; | ||||||
|  |             print NEW $l; | ||||||
|  |         } | ||||||
|  |         elsif($l =~ /^( *).*(curl_([^\(]*))\(/) { | ||||||
|  |             my ($prefix, $func) = ($1, $2); | ||||||
|  |             print NEW "$prefix/* $docroot/$func.html */\n"; | ||||||
|  |             print NEW $l; | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             print NEW $l; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     close(F); | ||||||
|  |     close(NEW); | ||||||
|  |  | ||||||
|  |     system("mv $f $f.org"); | ||||||
|  |     system("mv $f.new $f"); | ||||||
|  | } | ||||||
							
								
								
									
										135
									
								
								docs/examples/anyauthput.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								docs/examples/anyauthput.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,135 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _ | ||||||
|  |  *  Project                     ___| | | |  _ \| | | ||||||
|  |  *                             / __| | | | |_) | | | ||||||
|  |  *                            | (__| |_| |  _ <| |___ | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <fcntl.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  |  | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | #if LIBCURL_VERSION_NUM < 0x070c03 | ||||||
|  | #error "upgrade your libcurl to no less than 7.12.3" | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This example shows a HTTP PUT operation with authentiction using "any" | ||||||
|  |  * type. It PUTs a file given as a command line argument to the URL also given | ||||||
|  |  * on the command line. | ||||||
|  |  * | ||||||
|  |  * Since libcurl 7.12.3, using "any" auth and POST/PUT requires a set ioctl | ||||||
|  |  * function. | ||||||
|  |  * | ||||||
|  |  * This example also uses its own read callback. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /* ioctl callback function */ | ||||||
|  | static curlioerr my_ioctl(CURL *handle, curliocmd cmd, void *userp) | ||||||
|  | { | ||||||
|  |   int fd = (int)userp; | ||||||
|  |  | ||||||
|  |   (void)handle; /* not used in here */ | ||||||
|  |  | ||||||
|  |   switch(cmd) { | ||||||
|  |   case CURLIOCMD_RESTARTREAD: | ||||||
|  |     /* mr libcurl kindly asks as to rewind the read data stream to start */ | ||||||
|  |     if(-1 == lseek(fd, 0, SEEK_SET)) | ||||||
|  |       /* couldn't rewind */ | ||||||
|  |       return CURLIOE_FAILRESTART; | ||||||
|  |  | ||||||
|  |     break; | ||||||
|  |  | ||||||
|  |   default: /* ignore unknown commands */ | ||||||
|  |     return CURLIOE_UNKNOWNCMD; | ||||||
|  |   } | ||||||
|  |   return CURLIOE_OK; /* success! */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* read callback function, fread() look alike */ | ||||||
|  | size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||||
|  | { | ||||||
|  |   size_t retcode; | ||||||
|  |  | ||||||
|  |   int fd = (int)stream; | ||||||
|  |  | ||||||
|  |   retcode = read(fd, ptr, size * nmemb); | ||||||
|  |  | ||||||
|  |   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||||
|  |  | ||||||
|  |   return retcode; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv) | ||||||
|  | { | ||||||
|  |   CURL *curl; | ||||||
|  |   CURLcode res; | ||||||
|  |   int hd ; | ||||||
|  |   struct stat file_info; | ||||||
|  |  | ||||||
|  |   char *file; | ||||||
|  |   char *url; | ||||||
|  |  | ||||||
|  |   if(argc < 3) | ||||||
|  |     return 1; | ||||||
|  |  | ||||||
|  |   file= argv[1]; | ||||||
|  |   url = argv[2]; | ||||||
|  |  | ||||||
|  |   /* get the file size of the local file */ | ||||||
|  |   hd = open(file, O_RDONLY) ; | ||||||
|  |   fstat(hd, &file_info); | ||||||
|  |  | ||||||
|  |   /* In windows, this will init the winsock stuff */ | ||||||
|  |   curl_global_init(CURL_GLOBAL_ALL); | ||||||
|  |  | ||||||
|  |   /* get a curl handle */ | ||||||
|  |   curl = curl_easy_init(); | ||||||
|  |   if(curl) { | ||||||
|  |     /* we want to use our own read function */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); | ||||||
|  |  | ||||||
|  |     /* which file to upload */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_READDATA, hd); | ||||||
|  |  | ||||||
|  |     /* set the ioctl function */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_IOCTLFUNCTION, my_ioctl); | ||||||
|  |  | ||||||
|  |     /* pass the file descriptor to the ioctl callback as well */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_IOCTLDATA, hd); | ||||||
|  |  | ||||||
|  |     /* enable "uploading" (which means PUT when doing HTTP) */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_UPLOAD, TRUE) ; | ||||||
|  |  | ||||||
|  |     /* specify target URL, and note that this URL should also include a file | ||||||
|  |        name, not only a directory (as you can do with GTP uploads) */ | ||||||
|  |     curl_easy_setopt(curl,CURLOPT_URL, url); | ||||||
|  |  | ||||||
|  |     /* and give the size of the upload, this supports large file sizes | ||||||
|  |        on systems that have general support for it */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, file_info.st_size); | ||||||
|  |  | ||||||
|  |     /* tell libcurl we can use "any" auth, which lets the lib pick one, but it | ||||||
|  |        also costs one extra round-trip and possibly sending of all the PUT | ||||||
|  |        data twice!!! */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_HTTPAUTH, CURLAUTH_ANY); | ||||||
|  |  | ||||||
|  |     /* set user name and password for the authentication */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password"); | ||||||
|  |  | ||||||
|  |     /* Now run off and do what you've been told! */ | ||||||
|  |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|  |     /* always cleanup */ | ||||||
|  |     curl_easy_cleanup(curl); | ||||||
|  |   } | ||||||
|  |   close(hd); /* close the local file */ | ||||||
|  |  | ||||||
|  |   curl_global_cleanup(); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -42,7 +42,7 @@ int my_progress_func(GtkWidget *Bar, | |||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| void *curl_thread(void *ptr) | void *my_thread(void *ptr) | ||||||
| { | { | ||||||
|   CURL *curl; |   CURL *curl; | ||||||
|   CURLcode res; |   CURLcode res; | ||||||
| @@ -94,7 +94,7 @@ int main(int argc, char **argv) | |||||||
|   gtk_container_add(GTK_CONTAINER(Frame2), Bar); |   gtk_container_add(GTK_CONTAINER(Frame2), Bar); | ||||||
|   gtk_widget_show_all(Window); |   gtk_widget_show_all(Window); | ||||||
|  |  | ||||||
|   if (!g_thread_create(&curl_thread, argv[1], FALSE, NULL) != 0) |   if (!g_thread_create(&my_thread, argv[1], FALSE, NULL) != 0) | ||||||
|     g_warning("can't create the thread"); |     g_warning("can't create the thread"); | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -135,7 +135,8 @@ typedef struct sslctxparm_st { | |||||||
| static char *i2s_ASN1_IA5STRING( ASN1_IA5STRING *ia5) | static char *i2s_ASN1_IA5STRING( ASN1_IA5STRING *ia5) | ||||||
| { | { | ||||||
|   char *tmp; |   char *tmp; | ||||||
| 	if(!ia5 || !ia5->length) return NULL; |   if(!ia5 || !ia5->length) | ||||||
|  |     return NULL; | ||||||
|   tmp = OPENSSL_malloc(ia5->length + 1); |   tmp = OPENSSL_malloc(ia5->length + 1); | ||||||
|   memcpy(tmp, ia5->data, ia5->length); |   memcpy(tmp, ia5->data, ia5->length); | ||||||
|   tmp[ia5->length] = 0; |   tmp[ia5->length] = 0; | ||||||
| @@ -150,7 +151,8 @@ static unsigned char *my_get_ext(X509 * cert, const int type, int extensiontype) | |||||||
|   STACK_OF(ACCESS_DESCRIPTION) * accessinfo ; |   STACK_OF(ACCESS_DESCRIPTION) * accessinfo ; | ||||||
|   accessinfo =  X509_get_ext_d2i(cert, extensiontype, NULL, NULL) ; |   accessinfo =  X509_get_ext_d2i(cert, extensiontype, NULL, NULL) ; | ||||||
|  |  | ||||||
| 	if (!sk_ACCESS_DESCRIPTION_num(accessinfo)) return NULL; |   if (!sk_ACCESS_DESCRIPTION_num(accessinfo)) | ||||||
|  |     return NULL; | ||||||
|   for (i = 0; i < sk_ACCESS_DESCRIPTION_num(accessinfo); i++) { |   for (i = 0; i < sk_ACCESS_DESCRIPTION_num(accessinfo); i++) { | ||||||
|     ACCESS_DESCRIPTION * ad = sk_ACCESS_DESCRIPTION_value(accessinfo, i); |     ACCESS_DESCRIPTION * ad = sk_ACCESS_DESCRIPTION_value(accessinfo, i); | ||||||
|     if (OBJ_obj2nid(ad->method) == type) { |     if (OBJ_obj2nid(ad->method) == type) { | ||||||
| @@ -169,23 +171,35 @@ static unsigned char *my_get_ext(X509 * cert, const int type, int extensiontype) | |||||||
|    the URL to be used in the POST. |    the URL to be used in the POST. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| static int ssl_app_verify_callback(X509_STORE_CTX *ctx, void *arg) { | static int ssl_app_verify_callback(X509_STORE_CTX *ctx, void *arg) | ||||||
|  | { | ||||||
|   sslctxparm * p = (sslctxparm *) arg; |   sslctxparm * p = (sslctxparm *) arg; | ||||||
|   int ok; |   int ok; | ||||||
|  |  | ||||||
| 	if (p->verbose > 2) BIO_printf(p->errorbio,"entering ssl_app_verify_callback\n");  |   if (p->verbose > 2) | ||||||
|  |     BIO_printf(p->errorbio,"entering ssl_app_verify_callback\n"); | ||||||
|  |  | ||||||
|   if ((ok= X509_verify_cert(ctx)) && ctx->cert) { |   if ((ok= X509_verify_cert(ctx)) && ctx->cert) { | ||||||
|     unsigned char * accessinfo ; |     unsigned char * accessinfo ; | ||||||
| 		if (p->verbose > 1) X509_print_ex(p->errorbio,ctx->cert,0,0);  |     if (p->verbose > 1) | ||||||
|  |       X509_print_ex(p->errorbio,ctx->cert,0,0); | ||||||
|  |  | ||||||
|     if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_sinfo_access)) { |     if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_sinfo_access)) { | ||||||
|         		if (p->verbose) BIO_printf(p->errorbio,"Setting URL from SIA to: %s\n",accessinfo);  |       if (p->verbose) | ||||||
|  |         BIO_printf(p->errorbio,"Setting URL from SIA to: %s\n", accessinfo); | ||||||
|  |  | ||||||
|       curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo); |       curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo); | ||||||
| 		} else 	if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_info_access)) { |     } | ||||||
|         		if (p->verbose) BIO_printf(p->errorbio,"Setting URL from AIA to: %s\n",accessinfo);  |     else if (accessinfo = my_get_ext(ctx->cert,p->accesstype, | ||||||
|  |                                      NID_info_access)) { | ||||||
|  |       if (p->verbose) | ||||||
|  |         BIO_printf(p->errorbio,"Setting URL from AIA to: %s\n", accessinfo); | ||||||
|  |  | ||||||
|       curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo); |       curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 	if (p->verbose > 2) BIO_printf(p->errorbio,"leaving ssl_app_verify_callback with %d\n",ok);  |   if (p->verbose > 2) | ||||||
|  |     BIO_printf(p->errorbio,"leaving ssl_app_verify_callback with %d\n", ok); | ||||||
|   return(ok); |   return(ok); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -217,7 +231,8 @@ static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) { | |||||||
|   SSL_CTX_set_cipher_list(ctx,"RC4-MD5"); |   SSL_CTX_set_cipher_list(ctx,"RC4-MD5"); | ||||||
|   SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY); |   SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY); | ||||||
|  |  | ||||||
| 	X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca,sk_X509_num(p->ca)-1));  |   X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca, | ||||||
|  |                                                     sk_X509_num(p->ca)-1)); | ||||||
|  |  | ||||||
|   SSL_CTX_set_verify_depth(ctx,2); |   SSL_CTX_set_verify_depth(ctx,2); | ||||||
|  |  | ||||||
| @@ -238,7 +253,6 @@ int main(int argc, char **argv) { | |||||||
|   BIO* in=NULL; |   BIO* in=NULL; | ||||||
|   BIO* out=NULL; |   BIO* out=NULL; | ||||||
|  |  | ||||||
|     |  | ||||||
|   char * outfile = NULL; |   char * outfile = NULL; | ||||||
|   char * infile = NULL ; |   char * infile = NULL ; | ||||||
|  |  | ||||||
| @@ -375,30 +389,42 @@ int main(int argc, char **argv) { | |||||||
|     BIO_printf(p.errorbio,"No trustworthy CA given.%s\n", p.p12file); goto err; |     BIO_printf(p.errorbio,"No trustworthy CA given.%s\n", p.p12file); goto err; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| 	if (p.verbose > 1) X509_print_ex(p.errorbio,p.usercert,0,0);  |   if (p.verbose > 1) | ||||||
|  |     X509_print_ex(p.errorbio,p.usercert,0,0); | ||||||
|  |  | ||||||
|   /* determine URL to go */ |   /* determine URL to go */ | ||||||
|  |  | ||||||
|   if (hostporturl) { |   if (hostporturl) { | ||||||
|     serverurl=(char*) malloc(9+strlen(hostporturl)); |     serverurl=(char*) malloc(9+strlen(hostporturl)); | ||||||
|     sprintf(serverurl,"https://%s",hostporturl); |     sprintf(serverurl,"https://%s",hostporturl); | ||||||
| 	} else if (p.accesstype != 0) { /* see whether we can find an AIA or SIA for a given access type */ |   } | ||||||
|  |   else if (p.accesstype != 0) { /* see whether we can find an AIA or SIA for a given access type */ | ||||||
|     if (!(serverurl = my_get_ext(p.usercert,p.accesstype,NID_info_access))) { |     if (!(serverurl = my_get_ext(p.usercert,p.accesstype,NID_info_access))) { | ||||||
| 			BIO_printf(p.errorbio,"no service URL in user cert cherching in others certificats\n");  |       BIO_printf(p.errorbio,"no service URL in user cert " | ||||||
|  |                  "cherching in others certificats\n"); | ||||||
|       int j=0; |       int j=0; | ||||||
|       int find=0; |       int find=0; | ||||||
|       for (j=0;j<sk_X509_num(p.ca);j++) { |       for (j=0;j<sk_X509_num(p.ca);j++) { | ||||||
| 	      			if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype,NID_info_access))) break;  |         if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype, | ||||||
| 	      			if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype,NID_sinfo_access))) break;  |                                     NID_info_access))) | ||||||
|  |           break; | ||||||
|  |         if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype, | ||||||
|  |                                     NID_sinfo_access))) | ||||||
|  |           break; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (!serverurl) { |   if (!serverurl) { | ||||||
| 	       BIO_printf(p.errorbio, "no service URL in certificats, check '-accesstype (AD_DVCS | ad_timestamping)' or use '-connect'\n"); goto err; |     BIO_printf(p.errorbio, "no service URL in certificats," | ||||||
|  |                " check '-accesstype (AD_DVCS | ad_timestamping)'" | ||||||
|  |                " or use '-connect'\n"); | ||||||
|  |     goto err; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| 	if (p.verbose) BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl); |   if (p.verbose) | ||||||
|  |     BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl); | ||||||
|  |  | ||||||
|   curl_easy_setopt(p.curl, CURLOPT_URL, serverurl); |   curl_easy_setopt(p.curl, CURLOPT_URL, serverurl); | ||||||
|  |  | ||||||
|   /* Now specify the POST binary data */ |   /* Now specify the POST binary data */ | ||||||
| @@ -413,7 +439,8 @@ int main(int argc, char **argv) { | |||||||
|   headers = curl_slist_append(headers,contenttype); |   headers = curl_slist_append(headers,contenttype); | ||||||
|   curl_easy_setopt(p.curl, CURLOPT_HTTPHEADER, headers); |   curl_easy_setopt(p.curl, CURLOPT_HTTPHEADER, headers); | ||||||
|  |  | ||||||
| 	if (p.verbose) BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl); |   if (p.verbose) | ||||||
|  |     BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl); | ||||||
|  |  | ||||||
|   { |   { | ||||||
|     FILE *outfp; |     FILE *outfp; | ||||||
| @@ -447,14 +474,18 @@ int main(int argc, char **argv) { | |||||||
|  |  | ||||||
|   /* Perform the request, res will get the return code */ |   /* Perform the request, res will get the return code */ | ||||||
|  |  | ||||||
| 	BIO_printf(p.errorbio,"%d %s %d\n", __LINE__, "curl_easy_perform", res = curl_easy_perform(p.curl)); |   BIO_printf(p.errorbio,"%d %s %d\n", __LINE__, "curl_easy_perform", | ||||||
|  |              res = curl_easy_perform(p.curl)); | ||||||
|   { |   { | ||||||
|     int result =curl_easy_getinfo(p.curl,CURLINFO_CONTENT_TYPE,&response); |     int result =curl_easy_getinfo(p.curl,CURLINFO_CONTENT_TYPE,&response); | ||||||
|     if( mimetypeaccept && p.verbose) |     if( mimetypeaccept && p.verbose) | ||||||
|       if(!strcmp(mimetypeaccept,response)) |       if(!strcmp(mimetypeaccept,response)) | ||||||
| 			BIO_printf(p.errorbio,"the response has a correct mimetype : %s\n",response); |         BIO_printf(p.errorbio,"the response has a correct mimetype : %s\n", | ||||||
|  |                    response); | ||||||
|       else |       else | ||||||
| 			BIO_printf(p.errorbio,"the reponse doesn\'t has an acceptable mime type, it is %s instead of %s\n",response,mimetypeaccept); |         BIO_printf(p.errorbio,"the reponse doesn\'t has an acceptable " | ||||||
|  |                    "mime type, it is %s instead of %s\n", | ||||||
|  |                    response,mimetypeaccept); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /*** code d'erreur si accept mime ***, egalement code return HTTP != 200 ***/ |   /*** code d'erreur si accept mime ***, egalement code return HTTP != 200 ***/ | ||||||
| @@ -470,11 +501,6 @@ int main(int argc, char **argv) { | |||||||
|   BIO_free(out); |   BIO_free(out); | ||||||
|   return (EXIT_SUCCESS); |   return (EXIT_SUCCESS); | ||||||
|  |  | ||||||
|      |  | ||||||
|   err: BIO_printf(p.errorbio,"error"); |   err: BIO_printf(p.errorbio,"error"); | ||||||
|   exit(1); |   exit(1); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										128
									
								
								docs/examples/debug.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								docs/examples/debug.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,128 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _ | ||||||
|  |  *  Project                     ___| | | |  _ \| | | ||||||
|  |  *                             / __| | | | |_) | | | ||||||
|  |  *                            | (__| |_| |  _ <| |___ | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | struct data { | ||||||
|  |   char trace_ascii; /* 1 or 0 */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | static | ||||||
|  | void dump(const char *text, | ||||||
|  |           FILE *stream, unsigned char *ptr, size_t size, | ||||||
|  |           char nohex) | ||||||
|  | { | ||||||
|  |   size_t i; | ||||||
|  |   size_t c; | ||||||
|  |  | ||||||
|  |   unsigned int width=0x10; | ||||||
|  |  | ||||||
|  |   if(nohex) | ||||||
|  |     /* without the hex output, we can fit more on screen */ | ||||||
|  |     width = 0x40; | ||||||
|  |  | ||||||
|  |   fprintf(stream, "%s, %zd bytes (0x%zx)\n", text, size, size); | ||||||
|  |  | ||||||
|  |   for(i=0; i<size; i+= width) { | ||||||
|  |  | ||||||
|  |     fprintf(stream, "%04zx: ", i); | ||||||
|  |  | ||||||
|  |     if(!nohex) { | ||||||
|  |       /* hex not disabled, show it */ | ||||||
|  |       for(c = 0; c < width; c++) | ||||||
|  |         if(i+c < size) | ||||||
|  |           fprintf(stream, "%02x ", ptr[i+c]); | ||||||
|  |         else | ||||||
|  |           fputs("   ", stream); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     for(c = 0; (c < width) && (i+c < size); c++) { | ||||||
|  |       /* check for 0D0A; if found, skip past and start a new line of output */ | ||||||
|  |       if (nohex && (i+c+1 < size) && ptr[i+c]==0x0D && ptr[i+c+1]==0x0A) { | ||||||
|  |         i+=(c+2-width); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       fprintf(stream, "%c", | ||||||
|  |               (ptr[i+c]>=0x20) && (ptr[i+c]<0x80)?ptr[i+c]:'.'); | ||||||
|  |       /* check again for 0D0A, to avoid an extra \n if it's at width */ | ||||||
|  |       if (nohex && (i+c+2 < size) && ptr[i+c+1]==0x0D && ptr[i+c+2]==0x0A) { | ||||||
|  |         i+=(c+3-width); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     fputc('\n', stream); /* newline */ | ||||||
|  |   } | ||||||
|  |   fflush(stream); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | static | ||||||
|  | int my_trace(CURL *handle, curl_infotype type, | ||||||
|  |              unsigned char *data, size_t size, | ||||||
|  |              void *userp) | ||||||
|  | { | ||||||
|  |   struct data *config = (struct data *)userp; | ||||||
|  |   const char *text; | ||||||
|  |   (void)handle; /* prevent compiler warning */ | ||||||
|  |  | ||||||
|  |   switch (type) { | ||||||
|  |   case CURLINFO_TEXT: | ||||||
|  |     fprintf(stderr, "== Info: %s", data); | ||||||
|  |   default: /* in case a new one is introduced to shock us */ | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   case CURLINFO_HEADER_OUT: | ||||||
|  |     text = "=> Send header"; | ||||||
|  |     break; | ||||||
|  |   case CURLINFO_DATA_OUT: | ||||||
|  |     text = "=> Send data"; | ||||||
|  |     break; | ||||||
|  |   case CURLINFO_HEADER_IN: | ||||||
|  |     text = "<= Recv header"; | ||||||
|  |     break; | ||||||
|  |   case CURLINFO_DATA_IN: | ||||||
|  |     text = "<= Recv data"; | ||||||
|  |     break; | ||||||
|  |   case CURLINFO_SSL_DATA_IN: | ||||||
|  |     text = "<= Recv SSL data"; | ||||||
|  |     break; | ||||||
|  |   case CURLINFO_SSL_DATA_OUT: | ||||||
|  |     text = "<= Send SSL data"; | ||||||
|  |     break; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   dump(text, stderr, data, size, config->trace_ascii); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int main(void) | ||||||
|  | { | ||||||
|  |   CURL *curl; | ||||||
|  |   CURLcode res; | ||||||
|  |   struct data config; | ||||||
|  |  | ||||||
|  |   config.trace_ascii = 1; /* enable ascii tracing */ | ||||||
|  |  | ||||||
|  |   curl = curl_easy_init(); | ||||||
|  |   if(curl) { | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace); | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &config); | ||||||
|  |  | ||||||
|  |     /* the DEBUGFUNCTION has no effect until we enable VERBOSE */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||||
|  |  | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); | ||||||
|  |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|  |     /* always cleanup */ | ||||||
|  |     curl_easy_cleanup(curl); | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -22,7 +22,7 @@ int main(void) | |||||||
|   double speed_upload, total_time; |   double speed_upload, total_time; | ||||||
|   FILE *fd; |   FILE *fd; | ||||||
|  |  | ||||||
|   fd = fopen("debugit", "r"); /* open file to upload */ |   fd = fopen("debugit", "rb"); /* open file to upload */ | ||||||
|   if(!fd) { |   if(!fd) { | ||||||
|  |  | ||||||
|     return 1; /* can't continue */ |     return 1; /* can't continue */ | ||||||
|   | |||||||
| @@ -124,7 +124,7 @@ write_callback(char *buffer, | |||||||
|  |  | ||||||
| /* use to attempt to fill the read buffer up to requested number of bytes */ | /* use to attempt to fill the read buffer up to requested number of bytes */ | ||||||
| static int | static int | ||||||
| curl_fill_buffer(URL_FILE *file,int want,int waittime) | fill_buffer(URL_FILE *file,int want,int waittime) | ||||||
| { | { | ||||||
|     fd_set fdread; |     fd_set fdread; | ||||||
|     fd_set fdwrite; |     fd_set fdwrite; | ||||||
| @@ -179,7 +179,7 @@ curl_fill_buffer(URL_FILE *file,int want,int waittime) | |||||||
|  |  | ||||||
| /* use to remove want bytes from the front of a files buffer */ | /* use to remove want bytes from the front of a files buffer */ | ||||||
| static int | static int | ||||||
| curl_use_buffer(URL_FILE *file,int want) | use_buffer(URL_FILE *file,int want) | ||||||
| { | { | ||||||
|     /* sort out buffer */ |     /* sort out buffer */ | ||||||
|     if((file->buffer_pos - want) <=0) |     if((file->buffer_pos - want) <=0) | ||||||
| @@ -333,9 +333,9 @@ url_fread(void *ptr, size_t size, size_t nmemb, URL_FILE *file) | |||||||
|     case CFTYPE_CURL: |     case CFTYPE_CURL: | ||||||
|         want = nmemb * size; |         want = nmemb * size; | ||||||
|  |  | ||||||
| 	curl_fill_buffer(file,want,1); |         fill_buffer(file,want,1); | ||||||
|  |  | ||||||
| 	/* check if theres data in the buffer - if not curl_fill_buffer() |         /* check if theres data in the buffer - if not fill_buffer() | ||||||
|          * either errored or EOF */ |          * either errored or EOF */ | ||||||
|         if(!file->buffer_pos) |         if(!file->buffer_pos) | ||||||
|             return 0; |             return 0; | ||||||
| @@ -347,7 +347,7 @@ url_fread(void *ptr, size_t size, size_t nmemb, URL_FILE *file) | |||||||
|         /* xfer data to caller */ |         /* xfer data to caller */ | ||||||
|         memcpy(ptr, file->buffer, want); |         memcpy(ptr, file->buffer, want); | ||||||
|  |  | ||||||
| 	curl_use_buffer(file,want); |         use_buffer(file,want); | ||||||
|  |  | ||||||
|         want = want / size;     /* number of items - nb correct op - checked |         want = want / size;     /* number of items - nb correct op - checked | ||||||
|                                  * with glibc code*/ |                                  * with glibc code*/ | ||||||
| @@ -377,7 +377,7 @@ url_fgets(char *ptr, int size, URL_FILE *file) | |||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     case CFTYPE_CURL: |     case CFTYPE_CURL: | ||||||
| 	curl_fill_buffer(file,want,1); |         fill_buffer(file,want,1); | ||||||
|  |  | ||||||
|         /* check if theres data in the buffer - if not fill either errored or |         /* check if theres data in the buffer - if not fill either errored or | ||||||
|          * EOF */ |          * EOF */ | ||||||
| @@ -403,7 +403,7 @@ url_fgets(char *ptr, int size, URL_FILE *file) | |||||||
|         memcpy(ptr, file->buffer, want); |         memcpy(ptr, file->buffer, want); | ||||||
|         ptr[want]=0;/* allways null terminate */ |         ptr[want]=0;/* allways null terminate */ | ||||||
|  |  | ||||||
| 	curl_use_buffer(file,want); |         use_buffer(file,want); | ||||||
|  |  | ||||||
|         /*printf("(fgets) return %d bytes %d left\n", want,file->buffer_pos);*/ |         /*printf("(fgets) return %d bytes %d left\n", want,file->buffer_pos);*/ | ||||||
|         break; |         break; | ||||||
|   | |||||||
| @@ -52,7 +52,11 @@ int main(void) | |||||||
|  |  | ||||||
|   curl = curl_easy_init(); |   curl = curl_easy_init(); | ||||||
|   if(curl) { |   if(curl) { | ||||||
|     /* Get curl 7.9.2 from sunet.se's FTP site: */ |     /* | ||||||
|  |      * Get curl 7.9.2 from sunet.se's FTP site. curl 7.9.2 is most likely not | ||||||
|  |      * present there by the time you read this, so you'd better replace the | ||||||
|  |      * URL with one that works! | ||||||
|  |      */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_URL, |     curl_easy_setopt(curl, CURLOPT_URL, | ||||||
|                      "ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz"); |                      "ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz"); | ||||||
|     /* Define our callback to get called when there's data to be written */ |     /* Define our callback to get called when there's data to be written */ | ||||||
|   | |||||||
| @@ -72,6 +72,12 @@ int main(int argc, char **argv) | |||||||
|     /* now specify which file to upload */ |     /* now specify which file to upload */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_READDATA, hd_src); |     curl_easy_setopt(curl, CURLOPT_READDATA, hd_src); | ||||||
|  |  | ||||||
|  |     /* NOTE: if you want this example to work on Windows with libcurl as a | ||||||
|  |        DLL, you MUST also provide a read callback with | ||||||
|  |        CURLOPT_READFUNCTION. Failing to do so will give you a crash since a | ||||||
|  |        DLL may not use the variable's memory when passed in to it from an app | ||||||
|  |        like this. */ | ||||||
|  |  | ||||||
|     /* and give the size of the upload (optional) */ |     /* and give the size of the upload (optional) */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, file_info.st_size); |     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, file_info.st_size); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,14 +16,18 @@ int main(void) | |||||||
|   CURL *curl; |   CURL *curl; | ||||||
|   CURLcode res; |   CURLcode res; | ||||||
|  |  | ||||||
|  |   /* http://curl.haxx.se/libcurl/c/curl_easy_init.html */ | ||||||
|   curl = curl_easy_init(); |   curl = curl_easy_init(); | ||||||
|   if(curl) { |   if(curl) { | ||||||
|  |     /* http://curl.haxx.se/libcurl/c/curl_easy_setopt.html#CURLOPTURL */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); |     curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); | ||||||
|  |     /* http://curl.haxx.se/libcurl/c/curl_easy_perform.html */ | ||||||
|     res = curl_easy_perform(curl); |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|     if(CURLE_OK == res) { |     if(CURLE_OK == res) { | ||||||
|       char *ct; |       char *ct; | ||||||
|       /* ask for the content-type */ |       /* ask for the content-type */ | ||||||
|  |       /* http://curl.haxx.se/libcurl/c/curl_easy_getinfo.html */ | ||||||
|       res = curl_easy_getinfo(curl, CURLINFO_CONTENT_TYPE, &ct); |       res = curl_easy_getinfo(curl, CURLINFO_CONTENT_TYPE, &ct); | ||||||
|  |  | ||||||
|       if((CURLE_OK == res) && ct) |       if((CURLE_OK == res) && ct) | ||||||
| @@ -31,6 +35,7 @@ int main(void) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* always cleanup */ |     /* always cleanup */ | ||||||
|  |     /* http://curl.haxx.se/libcurl/c/curl_easy_cleanup.html */ | ||||||
|     curl_easy_cleanup(curl); |     curl_easy_cleanup(curl); | ||||||
|   } |   } | ||||||
|   return 0; |   return 0; | ||||||
|   | |||||||
| @@ -24,13 +24,23 @@ struct MemoryStruct { | |||||||
|   size_t size; |   size_t size; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | void *myrealloc(void *ptr, size_t size) | ||||||
|  | { | ||||||
|  |   /* There might be a realloc() out there that doesn't like reallocing | ||||||
|  |      NULL pointers, so we take care of it here */ | ||||||
|  |   if(ptr) | ||||||
|  |     return realloc(ptr, size); | ||||||
|  |   else | ||||||
|  |     return malloc(size); | ||||||
|  | } | ||||||
|  |  | ||||||
| size_t | size_t | ||||||
| WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) | WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) | ||||||
| { | { | ||||||
|   register int realsize = size * nmemb; |   register int realsize = size * nmemb; | ||||||
|   struct MemoryStruct *mem = (struct MemoryStruct *)data; |   struct MemoryStruct *mem = (struct MemoryStruct *)data; | ||||||
|  |  | ||||||
|   mem->memory = (char *)realloc(mem->memory, mem->size + realsize + 1); |   mem->memory = (char *)myrealloc(mem->memory, mem->size + realsize + 1); | ||||||
|   if (mem->memory) { |   if (mem->memory) { | ||||||
|     memcpy(&(mem->memory[mem->size]), ptr, realsize); |     memcpy(&(mem->memory[mem->size]), ptr, realsize); | ||||||
|     mem->size += realsize; |     mem->size += realsize; | ||||||
|   | |||||||
| @@ -39,7 +39,6 @@ int main(int argc, char **argv) | |||||||
| { | { | ||||||
|   CURL *curl; |   CURL *curl; | ||||||
|   CURLcode res; |   CURLcode res; | ||||||
|   FILE *ftpfile; |  | ||||||
|   FILE * hd_src ; |   FILE * hd_src ; | ||||||
|   int hd ; |   int hd ; | ||||||
|   struct stat file_info; |   struct stat file_info; | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ PROGRAMS  = fopen.exe ftpget.exe ftpgetresp.exe ftpupload.exe \ | |||||||
|             multi-double.exe multi-post.exe multi-single.exe \ |             multi-double.exe multi-post.exe multi-single.exe \ | ||||||
|             persistant.exe post-callback.exe postit2.exe \ |             persistant.exe post-callback.exe postit2.exe \ | ||||||
|             sepheaders.exe simple.exe simplessl.exe https.exe \ |             sepheaders.exe simple.exe simplessl.exe https.exe \ | ||||||
|             ftp3rdparty.exe getinfo.exe |             ftp3rdparty.exe getinfo.exe anyauthput.exe | ||||||
|  |  | ||||||
| all: $(PROGRAMS) | all: $(PROGRAMS) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -98,8 +98,6 @@ int main(int argc, char **argv) | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   curl_multi_cleanup(multi_handle); |  | ||||||
|  |  | ||||||
|   /* See how the transfers went */ |   /* See how the transfers went */ | ||||||
|   while ((msg = curl_multi_info_read(multi_handle, &msgs_left))) { |   while ((msg = curl_multi_info_read(multi_handle, &msgs_left))) { | ||||||
|     if (msg->msg == CURLMSG_DONE) { |     if (msg->msg == CURLMSG_DONE) { | ||||||
| @@ -120,6 +118,8 @@ int main(int argc, char **argv) | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   curl_multi_cleanup(multi_handle); | ||||||
|  |  | ||||||
|   /* Free the CURL handles */ |   /* Free the CURL handles */ | ||||||
|   for (i=0; i<HANDLECOUNT; i++) |   for (i=0; i<HANDLECOUNT; i++) | ||||||
|       curl_easy_cleanup(handles[i]); |       curl_easy_cleanup(handles[i]); | ||||||
|   | |||||||
| @@ -15,7 +15,15 @@ | |||||||
| #include <pthread.h> | #include <pthread.h> | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  |  | ||||||
| /* silly list of test-URLs */ | /* | ||||||
|  |   List of URLs to fetch. | ||||||
|  |  | ||||||
|  |   If you intend to use a SSL-based protocol here you MUST setup the OpenSSL | ||||||
|  |   callback functions as described here: | ||||||
|  |  | ||||||
|  |   http://www.openssl.org/docs/crypto/threads.html#DESCRIPTION | ||||||
|  |  | ||||||
|  | */ | ||||||
| char *urls[]= { | char *urls[]= { | ||||||
|   "http://curl.haxx.se/", |   "http://curl.haxx.se/", | ||||||
|   "ftp://cool.haxx.se/", |   "ftp://cool.haxx.se/", | ||||||
| @@ -28,10 +36,8 @@ void *pull_one_url(void *url) | |||||||
|   CURL *curl; |   CURL *curl; | ||||||
|  |  | ||||||
|   curl = curl_easy_init(); |   curl = curl_easy_init(); | ||||||
|  |  | ||||||
|   curl_easy_setopt(curl, CURLOPT_URL, url); |   curl_easy_setopt(curl, CURLOPT_URL, url); | ||||||
|   curl_easy_perform(curl); |   curl_easy_perform(curl); /* ignores error */ | ||||||
|  |  | ||||||
|   curl_easy_cleanup(curl); |   curl_easy_cleanup(curl); | ||||||
|  |  | ||||||
|   return NULL; |   return NULL; | ||||||
|   | |||||||
| @@ -57,9 +57,6 @@ int main(void) | |||||||
|     /* Now specify we want to POST data */ |     /* Now specify we want to POST data */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_POST, TRUE); |     curl_easy_setopt(curl, CURLOPT_POST, TRUE); | ||||||
|  |  | ||||||
|     /* Set the expected POST size */ |  | ||||||
|     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft); |  | ||||||
|  |  | ||||||
|     /* we want to use our own read function */ |     /* we want to use our own read function */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); |     curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); | ||||||
|  |  | ||||||
| @@ -69,6 +66,47 @@ int main(void) | |||||||
|     /* get verbose debug output please */ |     /* get verbose debug output please */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); |     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |       If you use POST to a HTTP 1.1 server, you can send data without knowing | ||||||
|  |       the size before starting the POST if you use chunked encoding. You | ||||||
|  |       enable this by adding a header like "Transfer-Encoding: chunked" with | ||||||
|  |       CURLOPT_HTTPHEADER. With HTTP 1.0 or without chunked transfer, you must | ||||||
|  |       specify the size in the request. | ||||||
|  |     */ | ||||||
|  | #ifdef USE_CHUNKED | ||||||
|  |     { | ||||||
|  |       curl_slist *chunk = NULL; | ||||||
|  |  | ||||||
|  |       chunk = curl_slist_append(chunk, "Transfer-Encoding: chunked"); | ||||||
|  |       res = curl_easy_setopt(curl, CURLOPT_HTTPHEADER); | ||||||
|  |       /* use curl_slist_free_all() after the *perform() call to free this | ||||||
|  |          list again */ | ||||||
|  |     } | ||||||
|  | #else | ||||||
|  |     /* Set the expected POST size. If you want to POST large amounts of data, | ||||||
|  |        consider CURLOPT_POSTFIELDSIZE_LARGE */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef DISABLE_EXPECT | ||||||
|  |     /* | ||||||
|  |       Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" | ||||||
|  |       header.  You can disable this header with CURLOPT_HTTPHEADER as usual. | ||||||
|  |       NOTE: if you want chunked transfer too, you need to combine these two | ||||||
|  |       since you can only set one list of headers with CURLOPT_HTTPHEADER. */ | ||||||
|  |  | ||||||
|  |     /* A less good option would be to enforce HTTP 1.0, but that might also | ||||||
|  |        have other implications. */ | ||||||
|  |     { | ||||||
|  |       curl_slist *chunk = NULL; | ||||||
|  |  | ||||||
|  |       chunk = curl_slist_append(chunk, "Expect:"); | ||||||
|  |       res = curl_easy_setopt(curl, CURLOPT_HTTPHEADER); | ||||||
|  |       /* use curl_slist_free_all() after the *perform() call to free this | ||||||
|  |          list again */ | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|     /* Perform the request, res will get the return code */ |     /* Perform the request, res will get the return code */ | ||||||
|     res = curl_easy_perform(curl); |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -89,19 +89,25 @@ int main(int argc, char **argv) | |||||||
|       /* cert is stored PEM coded in file... */ |       /* cert is stored PEM coded in file... */ | ||||||
|       /* since PEM is default, we needn't set it for PEM */ |       /* since PEM is default, we needn't set it for PEM */ | ||||||
|       curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM"); |       curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM"); | ||||||
|  |  | ||||||
|       /* set the cert for client authentication */ |       /* set the cert for client authentication */ | ||||||
|       curl_easy_setopt(curl,CURLOPT_SSLCERT,pCertFile); |       curl_easy_setopt(curl,CURLOPT_SSLCERT,pCertFile); | ||||||
|  |  | ||||||
|       /* sorry, for engine we must set the passphrase |       /* sorry, for engine we must set the passphrase | ||||||
|          (if the key has one...) */ |          (if the key has one...) */ | ||||||
|       if (pPassphrase) |       if (pPassphrase) | ||||||
|         curl_easy_setopt(curl,CURLOPT_SSLKEYPASSWD,pPassphrase); |         curl_easy_setopt(curl,CURLOPT_SSLKEYPASSWD,pPassphrase); | ||||||
|  |  | ||||||
|       /* if we use a key stored in a crypto engine, |       /* if we use a key stored in a crypto engine, | ||||||
|          we must set the key type to "ENG" */ |          we must set the key type to "ENG" */ | ||||||
|       curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType); |       curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType); | ||||||
|  |  | ||||||
|       /* set the private key (file or ID in engine) */ |       /* set the private key (file or ID in engine) */ | ||||||
|       curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName); |       curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName); | ||||||
|  |  | ||||||
|       /* set the file with the certs vaildating the server */ |       /* set the file with the certs vaildating the server */ | ||||||
|       curl_easy_setopt(curl,CURLOPT_CAINFO,pCACertFile); |       curl_easy_setopt(curl,CURLOPT_CAINFO,pCACertFile); | ||||||
|  |  | ||||||
|       /* disconnect if we can't validate server's cert */ |       /* disconnect if we can't validate server's cert */ | ||||||
|       curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1); |       curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_getinfo 3 "20 Aug 2003" "libcurl 7.10.8" "libcurl Manual" | .TH curl_easy_getinfo 3 "14 Dec 2004" "libcurl 7.12.3" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_getinfo - extract information from a curl handle | curl_easy_getinfo - extract information from a curl handle | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -12,13 +12,15 @@ curl_easy_getinfo - extract information from a curl handle | |||||||
|  |  | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| Request internal information from the curl session with this function.  The | Request internal information from the curl session with this function.  The | ||||||
| third argument | third argument \fBMUST\fP be a pointer to a long, a pointer to a char *, a | ||||||
| .B MUST | pointer to a struct curl_slist * or a pointer to a double (as this | ||||||
| be a pointer to a long, a pointer to a char * or a pointer to a double (as | documentation describes further down).  The data pointed-to will be filled in | ||||||
| this documentation describes further down).  The data pointed-to will be | accordingly and can be relied upon only if the function returns CURLE_OK. | ||||||
| filled in accordingly and can be relied upon only if the function returns | This function is intended to get used AFTER a performed transfer, all results | ||||||
| CURLE_OK.  This function is intended to get used *AFTER* a performed transfer, | from this function are undefined until the transfer is completed. | ||||||
| all results from this function are undefined until the transfer is completed. |  | ||||||
|  | You should not free the memory returned by this function unless it is | ||||||
|  | explictly mentioned below. | ||||||
| .SH AVAILABLE INFORMATION | .SH AVAILABLE INFORMATION | ||||||
| The following information can be extracted: | The following information can be extracted: | ||||||
| .IP CURLINFO_EFFECTIVE_URL | .IP CURLINFO_EFFECTIVE_URL | ||||||
| @@ -86,6 +88,13 @@ than one request if FOLLOWLOCATION is true. | |||||||
| Pass a pointer to a long to receive the result of the certification | Pass a pointer to a long to receive the result of the certification | ||||||
| verification that was requested (using the CURLOPT_SSL_VERIFYPEER option to | verification that was requested (using the CURLOPT_SSL_VERIFYPEER option to | ||||||
| \fIcurl_easy_setopt(3)\fP). | \fIcurl_easy_setopt(3)\fP). | ||||||
|  | .IP CURLINFO_SSL_ENGINES | ||||||
|  | Pass the address of a 'struct curl_slist *' to receive a linked-list of | ||||||
|  | OpenSSL crypto-engines supported. Note that engines are normally implemented | ||||||
|  | in separate dynamic libraries. Hence not all the returned engines may be | ||||||
|  | available at run-time. \fBNOTE:\fP you must call \fIcurl_slist_free_all(3)\fP | ||||||
|  | on the list pointer once you're done with it, as libcurl will not free the | ||||||
|  | data for you. (Added in 7.12.3) | ||||||
| .IP CURLINFO_CONTENT_LENGTH_DOWNLOAD | .IP CURLINFO_CONTENT_LENGTH_DOWNLOAD | ||||||
| Pass a pointer to a double to receive the content-length of the download. This | Pass a pointer to a double to receive the content-length of the download. This | ||||||
| is the value read from the Content-Length: field. | is the value read from the Content-Length: field. | ||||||
| @@ -107,6 +116,16 @@ CURLOPT_HTTPAUTH option for \fIcurl_easy_setopt(3)\fP.  (Added in 7.10.8) | |||||||
| .IP CURLINFO_PROXYAUTH_AVAIL | .IP CURLINFO_PROXYAUTH_AVAIL | ||||||
| Pass a pointer to a long to receive a bitmask indicating the authentication | Pass a pointer to a long to receive a bitmask indicating the authentication | ||||||
| method(s) available for your proxy authentication.  (Added in 7.10.8) | method(s) available for your proxy authentication.  (Added in 7.10.8) | ||||||
|  | .IP CURLINFO_OS_ERRNO | ||||||
|  | Pass a pointer to a long to receive the errno variable from a connect failure. | ||||||
|  | (Added in 7.12.2) | ||||||
|  | .IP CURLINFO_NUM_CONNECTS | ||||||
|  | Pass a pointer to a long to receive how many new connections libcurl had to | ||||||
|  | create to achieve the previous transfer (only the successful connects are | ||||||
|  | counted).  Combined with \fICURLINFO_REDIRECT_COUNT\fP you are able to know | ||||||
|  | how many times libcurl successfully reused existing connection(s) or not.  See | ||||||
|  | the Connection Options of \fIcurl_easy_setopt(3)\fP to see how libcurl tries | ||||||
|  | to make persistent connections to save time.  (Added in 7.12.3) | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| If the operation was successful, CURLE_OK is returned. Otherwise an | If the operation was successful, CURLE_OK is returned. Otherwise an | ||||||
| appropriate error code will be returned. | appropriate error code will be returned. | ||||||
|   | |||||||
| @@ -1,5 +1,3 @@ | |||||||
| .\" You can view this file with: |  | ||||||
| .\" nroff -man [file] |  | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_init 3 "4 March 2002" "libcurl 7.8.1" "libcurl Manual" | .TH curl_easy_init 3 "4 March 2002" "libcurl 7.8.1" "libcurl Manual" | ||||||
| @@ -20,4 +18,4 @@ initializes curl and this call \fBMUST\fP have a corresponding call to | |||||||
| If this function returns NULL, something went wrong and you cannot use the | If this function returns NULL, something went wrong and you cannot use the | ||||||
| other curl functions. | other curl functions. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl_easy_cleanup "(3), " curl_global_init "(3) | .BR curl_easy_cleanup "(3), " curl_global_init "(3), " curl_easy_reset "(3)" | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ | |||||||
| .\" * $Id$ | .\" * $Id$ | ||||||
| .\" ************************************************************************** | .\" ************************************************************************** | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_setopt 3 "12 Mar 2004" "libcurl 7.11.1" "libcurl Manual" | .TH curl_easy_setopt 3 "29 Nov 2004" "libcurl 7.12.3" "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 | ||||||
| @@ -32,16 +32,17 @@ CURLcode curl_easy_setopt(CURL *handle, CURLoption option, parameter); | |||||||
| curl_easy_setopt() is used to tell libcurl how to behave. By using the | curl_easy_setopt() is used to tell libcurl how to behave. By using the | ||||||
| appropriate options to \fIcurl_easy_setopt\fP, you can change libcurl's | appropriate options to \fIcurl_easy_setopt\fP, you can change libcurl's | ||||||
| behavior.  All options are set with the \fIoption\fP followed by a | behavior.  All options are set with the \fIoption\fP followed by a | ||||||
| \fIparameter\fP. That parameter can be a long, a function pointer or an object | \fIparameter\fP. That parameter can be a \fBlong\fP, a \fBfunction pointer\fP, | ||||||
| pointer, all depending on what the specific option expects. Read this manual | an \fBobject pointer\fP or a \fBcurl_off_t\fP, depending on what the specific | ||||||
| carefully as bad input values may cause libcurl to behave badly!  You can only | option expects. Read this manual carefully as bad input values may cause | ||||||
| set one option in each function call. A typical application uses many | libcurl to behave badly!  You can only set one option in each function call. A | ||||||
| curl_easy_setopt() calls in the setup phase. | typical application uses many curl_easy_setopt() calls in the setup phase. | ||||||
|  |  | ||||||
| Options set with this function call are valid for all forthcoming transfers | Options set with this function call are valid for all forthcoming transfers | ||||||
| performed using this \fIhandle\fP.  The options are not in any way reset | performed using this \fIhandle\fP.  The options are not in any way reset | ||||||
| between transfers, so if you want subsequent transfers with different options, | between transfers, so if you want subsequent transfers with different options, | ||||||
| you must change them between the transfers. | you must change them between the transfers. You can optionally reset all | ||||||
|  | options back to internal default with \fIcurl_easy_reset(3)\fP. | ||||||
|  |  | ||||||
| \fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be | \fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be | ||||||
| copied by the library. Instead you should keep them available until libcurl no | copied by the library. Instead you should keep them available until libcurl no | ||||||
| @@ -92,6 +93,9 @@ of bytes actually taken care of. If that amount differs from the amount passed | |||||||
| to your function, it'll signal an error to the library and it will abort the | to your function, it'll signal an error to the library and it will abort the | ||||||
| transfer and return \fICURLE_WRITE_ERROR\fP. | transfer and return \fICURLE_WRITE_ERROR\fP. | ||||||
|  |  | ||||||
|  | This function may be called with zero bytes data if the transfered file is | ||||||
|  | empty. | ||||||
|  |  | ||||||
| Set the \fIstream\fP argument with the \fICURLOPT_WRITEDATA\fP option. | Set the \fIstream\fP argument with the \fICURLOPT_WRITEDATA\fP option. | ||||||
|  |  | ||||||
| \fBNOTE:\fP you will be passed as much data as possible in all invokes, but | \fBNOTE:\fP you will be passed as much data as possible in all invokes, but | ||||||
| @@ -138,6 +142,18 @@ don't specify a read callback, this must be a valid FILE *. | |||||||
|  |  | ||||||
| This option is also known with the older name \fICURLOPT_INFILE\fP, the name | This option is also known with the older name \fICURLOPT_INFILE\fP, the name | ||||||
| \fICURLOPT_READDATA\fP was introduced in 7.9.7. | \fICURLOPT_READDATA\fP was introduced in 7.9.7. | ||||||
|  | .IP CURLOPT_IOCTLFUNCTION | ||||||
|  | Function pointer that should match the \fIcurl_ioctl_callback\fP prototype | ||||||
|  | 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 | ||||||
|  | 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 | ||||||
|  | HTTP PUT or POST with a multi-pass authentication method.  (Opion added in | ||||||
|  | 7.12.3) | ||||||
|  | .IP CURLOPT_IOCTLDATA | ||||||
|  | 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 | ||||||
|  | added in 7.12.3) | ||||||
| .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 | ||||||
| @@ -469,29 +485,56 @@ data should be set with \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZE\fP. | |||||||
| This option is deprecated and starting with version 7.12.1 you should instead | This option is deprecated and starting with version 7.12.1 you should instead | ||||||
| use \fICURLOPT_UPLOAD\fP. | use \fICURLOPT_UPLOAD\fP. | ||||||
| .IP CURLOPT_POST | .IP CURLOPT_POST | ||||||
| A non-zero parameter tells the library to do a regular HTTP post. This is a | A non-zero parameter tells the library to do a regular HTTP post. This will | ||||||
| normal application/x-www-form-urlencoded kind, which is the most commonly used | also make the library use the a "Content-Type: | ||||||
| one by HTML forms. See the \fICURLOPT_POSTFIELDS\fP option for how to specify | application/x-www-form-urlencoded" header. (This is by far the most commonly | ||||||
| the data to post and \fICURLOPT_POSTFIELDSIZE\fP in how to set the data | used POST method). | ||||||
| size. Using the \fICURLOPT_POSTFIELDS\fP option implies this option. |  | ||||||
|  | Use the \fICURLOPT_POSTFIELDS\fP option to specify what data to post and | ||||||
|  | \fICURLOPT_POSTFIELDSIZE\fP to set the data size. | ||||||
|  |  | ||||||
|  | Optionally, you can provide data to POST using the \fICURLOPT_READFUNCTION\fP | ||||||
|  | and \fICURLOPT_READDATA\fP options but then you must make sure to not set | ||||||
|  | \fICURLOPT_POSTFIELDS\fP to anything but NULL. When providing data with a | ||||||
|  | callback, you must transmit it using chunked transfer-encoding or you must set | ||||||
|  | the size of the data with the \fICURLOPT_POSTFIELDSIZE\fP option. | ||||||
|  |  | ||||||
|  | You can override the default POST Content-Type: header by setting your own | ||||||
|  | with \fICURLOPT_HTTPHEADER\fP. | ||||||
|  |  | ||||||
|  | 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. | ||||||
|  |  | ||||||
|  | If you use POST to a HTTP 1.1 server, you can send data without knowing the | ||||||
|  | size before starting the POST if you use chunked encoding. You enable this by | ||||||
|  | adding a header like "Transfer-Encoding: chunked" with | ||||||
|  | \fICURLOPT_HTTPHEADER\fP. With HTTP 1.0 or without chunked transfer, you must | ||||||
|  | specify the size in the request. | ||||||
|  |  | ||||||
|  | NOTE: if you have issued a POST request and want to make a HEAD or GET | ||||||
|  | instead, you must explictly pick the new request type using | ||||||
|  | \fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar. | ||||||
| .IP CURLOPT_POSTFIELDS | .IP CURLOPT_POSTFIELDS | ||||||
| Pass a char * as parameter, which should be the full data to post in an HTTP | Pass a char * as parameter, which should be the full data to post in an HTTP | ||||||
| post operation. You need to make sure that the data is formatted the way you | POST operation. You must make sure that the data is formatted the way you want | ||||||
| want the server to receive it. libcurl will not convert or encode it for | the server to receive it. libcurl will not convert or encode it for you. Most | ||||||
| you. Most web servers will assume this data to be url-encoded. Take note. | web servers will assume this data to be url-encoded. Take note. | ||||||
|  |  | ||||||
| This POST is a normal application/x-www-form-urlencoded kind (and libcurl will | This POST is a normal application/x-www-form-urlencoded kind (and libcurl will | ||||||
| set that Content-Type by default when this option is used), which is the most | set that Content-Type by default when this option is used), which is the most | ||||||
| commonly used one by HTML forms. See also the \fICURLOPT_POST\fP. Using | commonly used one by HTML forms. See also the \fICURLOPT_POST\fP. Using | ||||||
| \fICURLOPT_POSTFIELDS\fP implies \fICURLOPT_POST\fP. | \fICURLOPT_POSTFIELDS\fP implies \fICURLOPT_POST\fP. | ||||||
|  |  | ||||||
|  | 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. | ||||||
|  |  | ||||||
| \fBNote:\fP to make multipart/formdata posts (aka rfc1867-posts), check out | \fBNote:\fP to make multipart/formdata posts (aka rfc1867-posts), check out | ||||||
| the \fICURLOPT_HTTPPOST\fP option. | the \fICURLOPT_HTTPPOST\fP option. | ||||||
| .IP CURLOPT_POSTFIELDSIZE | .IP CURLOPT_POSTFIELDSIZE | ||||||
| If you want to post data to the server without letting libcurl do a strlen() | If you want to post data to the server without letting libcurl do a strlen() | ||||||
| to measure the data size, this option must be used. When this option is used | to measure the data size, this option must be used. When this option is used | ||||||
| you can post fully binary data, which otherwise is likely to fail. If this | you can post fully binary data, which otherwise is likely to fail. If this | ||||||
| size is set to zero, the library will use strlen() to get the size. | size is set to -1, the library will use strlen() to get the size. | ||||||
| .IP CURLOPT_POSTFIELDSIZE_LARGE | .IP CURLOPT_POSTFIELDSIZE_LARGE | ||||||
| Pass a curl_off_t as parameter. Use this to set the size of the | Pass a curl_off_t as parameter. Use this to set the size of the | ||||||
| \fICURLOPT_POSTFIELDS\fP data to prevent libcurl from doing strlen() on the | \fICURLOPT_POSTFIELDS\fP data to prevent libcurl from doing strlen() on the | ||||||
| @@ -505,6 +548,9 @@ list of 'struct HttpPost' structs properly filled in. The best and most | |||||||
| elegant way to do this, is to use \fIcurl_formadd(3)\fP as documented. The | elegant way to do this, is to use \fIcurl_formadd(3)\fP as documented. The | ||||||
| data in this list must remain intact until you close this curl handle again | data in this list must remain intact until you close this curl handle again | ||||||
| with \fIcurl_easy_cleanup(3)\fP. | with \fIcurl_easy_cleanup(3)\fP. | ||||||
|  |  | ||||||
|  | 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. | ||||||
| .IP CURLOPT_REFERER | .IP CURLOPT_REFERER | ||||||
| Pass a pointer to a zero terminated string as parameter. It will be used to | Pass a pointer to a zero terminated string as parameter. It will be used to | ||||||
| set the Referer: header in the http request sent to the remote server. This | set the Referer: header in the http request sent to the remote server. This | ||||||
| @@ -597,7 +643,7 @@ cookies are cookies without expiry date and they are meant to be alive and | |||||||
| existing for this "session" only. | existing for this "session" only. | ||||||
| .IP CURLOPT_HTTPGET | .IP CURLOPT_HTTPGET | ||||||
| Pass a long. If the long is non-zero, this forces the HTTP request to get back | Pass a long. If the long is non-zero, this forces the HTTP request to get back | ||||||
| to GET. Only really usable if POST, PUT or a custom request have been used | to GET. usable if a POST, HEAD, PUT or a custom request have been used | ||||||
| previously using the same curl handle. | previously using the same curl handle. | ||||||
| .IP CURLOPT_HTTP_VERSION | .IP CURLOPT_HTTP_VERSION | ||||||
| Pass a long, set to one of the values described below. They force libcurl to | Pass a long, set to one of the values described below. They force libcurl to | ||||||
| @@ -660,11 +706,15 @@ LPRT) command when doing active FTP downloads (which is enabled by | |||||||
| \fICURLOPT_FTPPORT\fP). Using EPRT means that it will first attempt to use | \fICURLOPT_FTPPORT\fP). Using EPRT means that it will first attempt to use | ||||||
| EPRT and then LPRT before using PORT, but if you pass FALSE (zero) to this | EPRT and then LPRT before using PORT, but if you pass FALSE (zero) to this | ||||||
| option, it will not try using EPRT or LPRT, only plain PORT. (Added in 7.10.5) | option, it will not try using EPRT or LPRT, only plain PORT. (Added in 7.10.5) | ||||||
|  |  | ||||||
|  | If the server is an IPv6 host, this option will have no effect as of 7.12.3. | ||||||
| .IP CURLOPT_FTP_USE_EPSV | .IP CURLOPT_FTP_USE_EPSV | ||||||
| Pass a long. If the value is non-zero, it tells curl to use the EPSV command | Pass a long. If the value is non-zero, it tells curl to use the EPSV command | ||||||
| when doing passive FTP downloads (which it always does by default). Using EPSV | when doing passive FTP downloads (which it always does by default). Using EPSV | ||||||
| means that it will first attempt to use EPSV before using PASV, but if you | means that it will first attempt to use EPSV before using PASV, but if you | ||||||
| pass FALSE (zero) to this option, it will not try using EPSV, only plain PASV. | pass FALSE (zero) to this option, it will not try using EPSV, only plain PASV. | ||||||
|  |  | ||||||
|  | If the server is an IPv6 host, this option will have no effect as of 7.12.3. | ||||||
| .IP CURLOPT_FTP_CREATE_MISSING_DIRS | .IP CURLOPT_FTP_CREATE_MISSING_DIRS | ||||||
| Pass a long. If the value is non-zero, curl will attempt to create any remote | Pass a long. If the value is non-zero, curl will attempt to create any remote | ||||||
| directory that it fails to CWD into. CWD is the command that changes working | directory that it fails to CWD into. CWD is the command that changes working | ||||||
| @@ -690,6 +740,18 @@ Require SSL for the control connection or fail with \fICURLE_FTP_SSL_FAILED\fP. | |||||||
| .IP CURLFTPSSL_ALL | .IP CURLFTPSSL_ALL | ||||||
| Require SSL for all communication or fail with \fICURLE_FTP_SSL_FAILED\fP. | Require SSL for all communication or fail with \fICURLE_FTP_SSL_FAILED\fP. | ||||||
| .RE | .RE | ||||||
|  | .IP CURLOPT_FTPSSLAUTH | ||||||
|  | Pass a long using one of the values from below, to alter how libcurl issues | ||||||
|  | \&"AUTH TLS" or "AUTH SSL" when FTP over SSL is activated (see | ||||||
|  | \fICURLOPT_FTP_SSL\fP). (Added in 7.12.2) | ||||||
|  | .RS | ||||||
|  | .IP CURLFTPAUTH_DEFAULT | ||||||
|  | Allow libcurl to decide | ||||||
|  | .IP CURLFTPAUTH_SSL | ||||||
|  | Try "AUTH SSL" first, and only if that fails try "AUTH TLS" | ||||||
|  | .IP CURLFTPAUTH_TLS | ||||||
|  | Try "AUTH TLS" first, and only if that fails try "AUTH SSL" | ||||||
|  | .RE | ||||||
| .SH PROTOCOL OPTIONS | .SH PROTOCOL OPTIONS | ||||||
| .IP CURLOPT_TRANSFERTEXT | .IP CURLOPT_TRANSFERTEXT | ||||||
| A non-zero parameter tells the library to use ASCII mode for ftp transfers, | A non-zero parameter tells the library to use ASCII mode for ftp transfers, | ||||||
| @@ -712,8 +774,8 @@ 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). | ||||||
| .IP CURLOPT_RESUME_FROM_LARGE | .IP CURLOPT_RESUME_FROM_LARGE | ||||||
| Pass an curl_off_t as parameter. It contains the offset in number of bytes | Pass a curl_off_t as parameter. It contains the offset in number of bytes that | ||||||
| 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) | ||||||
| .IP CURLOPT_CUSTOMREQUEST | .IP CURLOPT_CUSTOMREQUEST | ||||||
| Pass a pointer to a zero terminated string as parameter. It will be user | Pass a pointer to a zero terminated string as parameter. It will be user | ||||||
| instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST | instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST | ||||||
| @@ -740,6 +802,10 @@ can be used after a transfer to extract the received time (if any). | |||||||
| A non-zero parameter tells the library to not include the body-part in the | A non-zero parameter tells the library to not include the body-part in the | ||||||
| output. This is only relevant for protocols that have separate header and body | output. This is only relevant for protocols that have separate header and body | ||||||
| parts. On HTTP(S) servers, this will make libcurl do a HEAD request. | parts. On HTTP(S) servers, this will make libcurl do a HEAD request. | ||||||
|  |  | ||||||
|  | To change back to GET, you should use \fICURLOPT_HTTPGET\fP. To change back to | ||||||
|  | POST, you should use \fICURLOPT_POST\fP. Setting \fICURLOPT_NOBODY\fP to zero | ||||||
|  | has no effect. | ||||||
| .IP CURLOPT_INFILESIZE | .IP CURLOPT_INFILESIZE | ||||||
| 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 | ||||||
| @@ -750,9 +816,19 @@ 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) | ||||||
| .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_INFILESIZE_LARGE\fP are also interesting | \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZEE\fP or | ||||||
| for uploads. If the protocol is HTTP, uploading means using the PUT request | \fICURLOPT_INFILESIZE_LARGE\fP are also interesting for uploads. If the | ||||||
| unless you tell libcurl otherwise. | protocol is HTTP, uploading means using the PUT request unless you tell | ||||||
|  | libcurl otherwise. | ||||||
|  |  | ||||||
|  | Using PUT with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||||
|  | You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | ||||||
|  |  | ||||||
|  | If you use PUT to a HTTP 1.1 server, you can upload data without knowing the | ||||||
|  | size before starting the transfer if you use chunked encoding. You enable this | ||||||
|  | by adding a header like "Transfer-Encoding: chunked" with | ||||||
|  | \fICURLOPT_HTTPHEADER\fP. With HTTP 1.0 or without chunked transfer, you must | ||||||
|  | specify the size. | ||||||
| .IP CURLOPT_MAXFILESIZE | .IP CURLOPT_MAXFILESIZE | ||||||
| Pass a long as parameter. This allows you to specify the maximum size (in | Pass a long as parameter. This allows you to specify the maximum size (in | ||||||
| bytes) of a file to download. If the file requested is larger than this value, | bytes) of a file to download. If the file requested is larger than this value, | ||||||
| @@ -983,4 +1059,4 @@ If you try to set an option that libcurl doesn't know about, perhaps because | |||||||
| the library is too old to support it or the option was removed in a recent | the library is too old to support it or the option was removed in a recent | ||||||
| version, this function will return \fICURLE_FAILED_INIT\fP. | version, this function will return \fICURLE_FAILED_INIT\fP. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl_easy_init "(3), " curl_easy_cleanup "(3), " | .BR curl_easy_init "(3), " curl_easy_cleanup "(3), " curl_easy_reset "(3), " | ||||||
|   | |||||||
| @@ -12,6 +12,8 @@ curl_easy_strerror - return string describing error code | |||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The curl_easy_strerror() function returns a string describing the CURLcode | The curl_easy_strerror() function returns a string describing the CURLcode | ||||||
| error code passed in the argument \fIerrornum\fP. | error code passed in the argument \fIerrornum\fP. | ||||||
|  |  | ||||||
|  | This function was added in libcurl 7.12.0 | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string. | A pointer to a zero terminated string. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
|   | |||||||
| @@ -26,34 +26,37 @@ 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\fP after the form post has | ||||||
| been done to free the resources again. | been done to free the resources again. | ||||||
|  |  | ||||||
|  | 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. | ||||||
|  |  | ||||||
| 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. Below here, we'll discuss on what options you use to set these | FILENAME. Below here, we'll discuss on what options you use to set these | ||||||
| properties in the parts you want to add to your post. | properties in the parts you want to add to your post. | ||||||
| .SH OPTIONS | .SH OPTIONS | ||||||
| .B CURLFORM_COPYNAME | .IP CURLFORM_COPYNAME | ||||||
| followed by string is used to set the name of this part. libcurl copies the | followed by string is used to set the name of this part. libcurl copies the | ||||||
| given data, so your application doesn't need to keep it around after this | given data, so your application doesn't need to keep it around after this | ||||||
| function call. If the name isn't zero terminated properly, or if you'd like it | function call. If the name isn't zero terminated properly, or if you'd like it | ||||||
| to contain zero bytes, you need to set the length of the name with | to contain zero bytes, you need to set the length of the name with | ||||||
| \fBCURLFORM_NAMELENGTH\fP. | \fBCURLFORM_NAMELENGTH\fP. | ||||||
|  |  | ||||||
| .B 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 is used for the name of this part. libcurl will use the | ||||||
| pointer and refer to the data in your application, you must make sure it | pointer and refer to the data in your application, you must make sure it | ||||||
| remains until curl no longer needs it. If the name isn't zero terminated | remains until curl no longer needs it. If the name isn't zero terminated | ||||||
| properly, or if you'd like it to contain zero bytes, you need to set the | properly, or if you'd like it to contain zero bytes, you need to set the | ||||||
| length of the name with \fBCURLFORM_NAMELENGTH\fP. | length of the name with \fBCURLFORM_NAMELENGTH\fP. | ||||||
|  |  | ||||||
| .B CURLFORM_COPYCONTENTS | .IP CURLFORM_COPYCONTENTS | ||||||
| followed by a string is used for the contents of this part, the actual data to | followed by a string is used for the contents of this part, the actual data to | ||||||
| send away. libcurl copies the given data, so your application doesn't need to | send away. libcurl copies the given data, so your application doesn't need to | ||||||
| keep it around after this function call. If the data isn't zero terminated | keep it around after this function call. If the data isn't zero terminated | ||||||
| properly, or if you'd like it to contain zero bytes, you need to set the | properly, or if you'd like it to contain zero bytes, you need to set the | ||||||
| length of the name with \fBCURLFORM_CONTENTSLENGTH\fP. | length of the name with \fBCURLFORM_CONTENTSLENGTH\fP. | ||||||
|  |  | ||||||
| .B CURLFORM_PTRCONTENTS | .IP CURLFORM_PTRCONTENTS | ||||||
| followed by a string is used for the contents of this part, the actual data to | followed by a string is used for the contents of this part, the actual data to | ||||||
| send away. libcurl will use the pointer and refer to the data in your | 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, you must make sure it remains until curl no longer needs it. If | ||||||
| @@ -61,11 +64,14 @@ the data isn't zero terminated properly, or if you'd like it to contain zero | |||||||
| bytes, you need to set the length of the name with | bytes, you need to set the length of the name with | ||||||
| \fBCURLFORM_CONTENTSLENGTH\fP. | \fBCURLFORM_CONTENTSLENGTH\fP. | ||||||
|  |  | ||||||
| .B CURLFORM_FILECONTENT | .IP CURLFORM_CONTENTSLENGTH | ||||||
|  | followed by a long setting the length of the contents. | ||||||
|  |  | ||||||
|  | .IP CURLFORM_FILECONTENT | ||||||
| followed by a file name, makes that file read and the contents will be used in | followed by a file name, makes that file read and the contents will be used in | ||||||
| as data in this part. | as data in this part. | ||||||
|  |  | ||||||
| .B CURLFORM_FILE | .IP CURLFORM_FILE | ||||||
| followed by a file name, makes this part a file upload part. It sets the file | followed by a file name, makes this part a file upload part. It sets the file | ||||||
| name field to the actual file name used here, it gets the contents of the file | name field to the actual file name used here, it gets the contents of the file | ||||||
| and passes as data and sets the content-type if the given file match one of | and passes as data and sets the content-type if the given file match one of | ||||||
| @@ -74,32 +80,33 @@ send one or more files in one part by providing multiple \fBCURLFORM_FILE\fP | |||||||
| arguments each followed by the filename (and each CURLFORM_FILE is allowed to | arguments each followed by the filename (and each CURLFORM_FILE is allowed to | ||||||
| have a CURLFORM_CONTENTTYPE). | have a CURLFORM_CONTENTTYPE). | ||||||
|  |  | ||||||
| .B CURLFORM_CONTENTTYPE | .IP CURLFORM_CONTENTTYPE | ||||||
| followed by a pointer to a string with a content-type will make curl use this | followed by a pointer to a string with a content-type will make curl use this | ||||||
| given content-type for this file upload part, possibly instead of an | given content-type for this file upload part, possibly instead of an | ||||||
| internally chosen one. | internally chosen one. | ||||||
|  |  | ||||||
| .B CURLFORM_FILENAME | .IP CURLFORM_FILENAME | ||||||
| followed by a pointer to a string to a name, will make libcurl use the given | followed by a pointer to a string to a name, will make libcurl use the given | ||||||
| name in the file upload part, instead of the actual file name given to | name in the file upload part, instead of the actual file name given to | ||||||
| \fICURLFORM_FILE\fP. | \fICURLFORM_FILE\fP. | ||||||
|  |  | ||||||
| .B BCURLFORM_BUFFER | .IP BCURLFORM_BUFFER | ||||||
| followed by a string, tells libcurl that a buffer is to be used to upload data | followed by a string, tells libcurl that a buffer is to be used to upload data | ||||||
| instead of using a file. The given string is used as the value of the file | instead of using a file. The given string is used as the value of the file | ||||||
| name field in the content header. | name field in the content header. | ||||||
|  |  | ||||||
| .B CURLFORM_BUFFERPTR | .IP CURLFORM_BUFFERPTR | ||||||
| followed by a pointer to a data area, tells libcurl the address of the buffer | followed by a pointer to a data area, tells libcurl the address of the buffer | ||||||
| containing data to upload (as indicated with \fICURLFORM_BUFFER\fP). The | containing data to upload (as indicated with \fICURLFORM_BUFFER\fP). The | ||||||
| buffer containing this data must not be freed until after | buffer containing this data must not be freed until after | ||||||
| \fIcurl_easy_cleanup(3)\fP is called. | \fIcurl_easy_cleanup(3)\fP is called. You must also use | ||||||
|  | \fICURLFORM_BUFFERLENGTH\fP to set the length of the given buffer area. | ||||||
|  |  | ||||||
| .B CURLFORM_BUFFERLENGTH | .IP CURLFORM_BUFFERLENGTH | ||||||
| followed by a long with the size of the \fICURLFORM_BUFFERPTR\fP data area, | followed by a long with the size of the \fICURLFORM_BUFFERPTR\fP data area, | ||||||
| tells libcurl the length of the buffer to upload. | tells libcurl the length of the buffer to upload. | ||||||
|  |  | ||||||
| .B 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 | ||||||
| \fBCURLFORM_ARRAY\fP option, that passes a struct curl_forms array pointer as | \fBCURLFORM_ARRAY\fP option, that passes a struct curl_forms array pointer as | ||||||
| its value. Each curl_forms structure element has a CURLformoption and a char | its value. Each curl_forms structure element has a CURLformoption and a char | ||||||
| @@ -107,7 +114,7 @@ pointer. The final element in the array must be a CURLFORM_END. All available | |||||||
| options can be used in an array, except the CURLFORM_ARRAY option itself!  The | options can be used in an array, except the CURLFORM_ARRAY option itself!  The | ||||||
| last argument in such an array must always be \fBCURLFORM_END\fP. | last argument in such an array must always be \fBCURLFORM_END\fP. | ||||||
|  |  | ||||||
| .B CURLFORM_CONTENTHEADER | .IP CURLFORM_CONTENTHEADER | ||||||
| specifies extra headers for the form POST section.  This takes a curl_slist | specifies extra headers for the form POST section.  This takes a curl_slist | ||||||
| prepared in the usual way using \fBcurl_slist_append\fP and appends the list | prepared in the usual way using \fBcurl_slist_append\fP and appends the list | ||||||
| of headers to those libcurl automatically generates. The list must exist while | of headers to those libcurl automatically generates. The list must exist while | ||||||
| @@ -126,8 +133,8 @@ defines. | |||||||
| .SH EXAMPLE | .SH EXAMPLE | ||||||
| .nf | .nf | ||||||
|  |  | ||||||
|  struct HttpPost* post = NULL; |  struct curl_httppost* post = NULL; | ||||||
|  struct HttpPost* last = NULL; |  struct curl_httppost* last = NULL; | ||||||
|  char namebuffer[] = "name buffer"; |  char namebuffer[] = "name buffer"; | ||||||
|  long namelength = strlen(namebuffer); |  long namelength = strlen(namebuffer); | ||||||
|  char buffer[] = "test buffer"; |  char buffer[] = "test buffer"; | ||||||
|   | |||||||
| @@ -4,35 +4,36 @@ | |||||||
| .\" | .\" | ||||||
| .TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual" | .TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_getdate - Convert an date in a ASCII string to number of seconds since | curl_getdate - Convert an date string to number of seconds since January 1, | ||||||
| January 1, 1970 | 1970 | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "time_t curl_getdate(char *" datestring ", time_t *"now" ); | .BI "time_t curl_getdate(char *" datestring ", time_t *"now " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function returns the number of seconds since January 1st 1970, for the | This function returns the number of seconds since January 1st 1970 in the UTC | ||||||
| date and time that the | time zone, for the date and time that the \fIdatestring\fP parameter | ||||||
| .I datestring | specifies. The \fInow\fP parameter is not used, pass a NULL there. | ||||||
| parameter specifies. The  |  | ||||||
| .I now | \fBNOTE:\fP This function was rewritten for the 7.12.2 release and this | ||||||
| parameter is there and should hold the current time to allow the datestring to | documentation covers the functionality of the new one. The new one is not | ||||||
| specify relative dates/times. Read further in the date string parser section | feature-complete with the old one, but most of the formats supported by the | ||||||
| below. | new one was supported by the old too. | ||||||
| .SH PARSING DATES AND TIMES | .SH PARSING DATES AND TIMES | ||||||
| A "date" is a string, possibly empty, containing many items separated by | A "date" is a string containing several items separated by whitespace. The | ||||||
| whitespace.  The whitespace may be omitted when no ambiguity arises.  The | order of the items is immaterial.  A date string may contain many flavors of | ||||||
| empty string means the beginning of today (i.e., midnight).  Order of the | items: | ||||||
| items is immaterial.  A date string may contain many flavors of items: |  | ||||||
| .TP 0.8i | .TP 0.8i | ||||||
| .B calendar date items | .B calendar date items | ||||||
| This can be specified in a number of different ways. Including 1970-09-17, 70-9-17, 70-09-17, 9/17/72, 24 September 1972, 24 Sept 72, 24 Sep 72, Sep 24, 1972, 24-sep-72, 24sep72. | Can be specified several ways. Month names can only be three-letter | ||||||
| The year can also be omitted, for example: 9/17 or "sep 17". | abbrivations, numbers can be zero-prefixed and the year may use 2 or 4 digits. | ||||||
|  | Examples: 06 Nov 1994, 06-Nov-94 and Nov-94 6. | ||||||
| .TP | .TP | ||||||
| .B time of the day items | .B time of the day items | ||||||
| This string specifies the time on a given day. Syntax supported includes: | This string specifies the time on a given day. You must specify it with 6 | ||||||
| 18:19:0, 18:19, 6:19pm, 18:19-0500 (for specifying the time zone as well). | digits with two colons: HH:MM:SS. To not include the time in a date string, | ||||||
|  | will make the function assume 00:00:00. Example: 18:19:21. | ||||||
| .TP | .TP | ||||||
| .B time zone items | .B time zone items | ||||||
| Specifies international time zone. There are a few acronyms supported, but in | Specifies international time zone. There are a few acronyms supported, but in | ||||||
| @@ -40,41 +41,55 @@ general you should instead use the specific relative time compared to | |||||||
| UTC. Supported formats include: -1200, MST, +0100. | UTC. Supported formats include: -1200, MST, +0100. | ||||||
| .TP | .TP | ||||||
| .B day of the week items | .B day of the week items | ||||||
| Specifies a day of the week. If this is mentioned alone it means that day of | Specifies a day of the week. Days of the week may be spelled out in full: | ||||||
| the week in the future. | `Sunday', `Monday', etc or they may be abbreviated to their first three | ||||||
|  | letters. This is usually not info that adds anything. | ||||||
| Days of the week may be spelled out in full: `Sunday', `Monday', etc or they |  | ||||||
| may be abbreviated to their first three letters, optionally followed by a |  | ||||||
| period.  The special abbreviations `Tues' for `Tuesday', `Wednes' for |  | ||||||
| `Wednesday' and `Thur' or `Thurs' for `Thursday' are also allowed. |  | ||||||
|  |  | ||||||
| A number may precede a day of the week item to move forward supplementary |  | ||||||
| weeks.  It is best used in expression like `third monday'.  In this context, |  | ||||||
| `last DAY' or `next DAY' is also acceptable; they move one week before or |  | ||||||
| after the day that DAY by itself would represent. |  | ||||||
| .TP |  | ||||||
| .B relative items |  | ||||||
| A relative item adjusts a date (or the current date if none) forward or |  | ||||||
| backward. Example syntax includes: "1 year", "1 year ago", "2 days", "4 |  | ||||||
| weeks". |  | ||||||
|  |  | ||||||
| The string `tomorrow' is worth one day in the future (equivalent to `day'), |  | ||||||
| the string `yesterday' is worth one day in the past (equivalent to `day ago'). |  | ||||||
| .TP | .TP | ||||||
| .B pure numbers | .B pure numbers | ||||||
| If the decimal number is of the form YYYYMMDD and no other calendar date item | If a decimal number of the form YYYYMMDD appears, then YYYY is read as the | ||||||
| appears before it in the date string, then YYYY is read as the year, MM as the | year, MM as the month number and DD as the day of the month, for the specified | ||||||
| month number and DD as the day of the month, for the specified calendar date. | calendar date. | ||||||
| .PP | .PP | ||||||
|  | .SH EXAMPLES | ||||||
|  | .nf | ||||||
|  | Sun, 06 Nov 1994 08:49:37 GMT | ||||||
|  | Sunday, 06-Nov-94 08:49:37 GMT | ||||||
|  | Sun Nov  6 08:49:37 1994 | ||||||
|  | 06 Nov 1994 08:49:37 GMT | ||||||
|  | 06-Nov-94 08:49:37 GMT | ||||||
|  | Nov  6 08:49:37 1994 | ||||||
|  | 06 Nov 1994 08:49:37 | ||||||
|  | 06-Nov-94 08:49:37 | ||||||
|  | 1994 Nov 6 08:49:37 | ||||||
|  | GMT 08:49:37 06-Nov-94 Sunday | ||||||
|  | 94 6 Nov 08:49:37 | ||||||
|  | 1994 Nov 6 | ||||||
|  | 06-Nov-94 | ||||||
|  | Sun Nov 6 94 | ||||||
|  | 1994.Nov.6 | ||||||
|  | Sun/Nov/6/94/GMT | ||||||
|  | Sun, 06 Nov 1994 08:49:37 CET | ||||||
|  | 06 Nov 1994 08:49:37 EST | ||||||
|  | Sun, 12 Sep 2004 15:05:58 -0700 | ||||||
|  | Sat, 11 Sep 2004 21:32:11 +0200 | ||||||
|  | 20040912 15:05:58 -0700 | ||||||
|  | 20040911 +0200 | ||||||
|  | .fi | ||||||
|  | .SH STANDARDS | ||||||
|  | This parser was written to handle date formats specified in RFC 822 (including | ||||||
|  | the update in RFC 1123) using time zone name or time zone delta and RFC 850 | ||||||
|  | (obsoleted by RFC 1036) and ANSI C's asctime() format. These formats are the | ||||||
|  | only ones RFC2616 says HTTP applications may use. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| This function returns zero when it fails to parse the date string. Otherwise | This function returns -1 when it fails to parse the date string. Otherwise it | ||||||
| it returns the number of seconds as described. | returns the number of seconds as described. | ||||||
| .SH AUTHORS |  | ||||||
| Originally written by Steven M. Bellovin <smb@research.att.com> while at the |  | ||||||
| University of North Carolina at Chapel Hill.  Later tweaked by a couple of |  | ||||||
| people on Usenet.  Completely overhauled by Rich $alz <rsalz@bbn.com> and Jim |  | ||||||
| Berets <jberets@bbn.com> in August, 1990. |  | ||||||
|  |  | ||||||
| It has been modified extensively since imported to curl. | If the year is larger than 2037 on systems with 32 bit time_t, this function | ||||||
| .SH "SEE ALSO" | will return 0x7fffffff (since that is the largest possible 31 bit number). | ||||||
| .BR GNU date(1) | .SH REWRITE | ||||||
|  | The former version of this function was built with yacc and was not only very | ||||||
|  | large, it was also never quite understood and it wasn't possible to build with | ||||||
|  | non-GNU tools since only Bison could make it thread-safe! | ||||||
|  |  | ||||||
|  | The rewrite was done for 7.12.2. The new one is much smaller and use simpler | ||||||
|  | code. | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_multi_info_read 3 "27 Feb 2002" "libcurl 7.10.3" "libcurl Manual" | .TH curl_multi_info_read 3 "18 Dec 2004" "libcurl 7.10.3" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_multi_info_read - read multi stack informationals | curl_multi_info_read - read multi stack informationals | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -21,7 +21,7 @@ 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. | ||||||
|  |  | ||||||
| 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. | \fIcurl_multi_cleanup(3)\fP or \fIcurl_multi_remove_handle(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 | ||||||
|   | |||||||
| @@ -16,6 +16,13 @@ function does not require that there actually is any data available for | |||||||
| reading or that data can be written, it can be called just in case. It will | reading or that data can be written, it can be called just in case. It will | ||||||
| write the number of handles that still transfer data in the second argument's | write the number of handles that still transfer data in the second argument's | ||||||
| integer-pointer. | integer-pointer. | ||||||
|  |  | ||||||
|  | When you call curl_multi_perform() and the amount of \fIrunning_handles\fP is | ||||||
|  | changed from the previous call (or is less than the amount of easy handles | ||||||
|  | you've added to the multi handle), you know that there is one or more | ||||||
|  | transfers less "running". You can then call \fIcurl_multi_info_read(3)\fP to | ||||||
|  | get information about each individual completed transfer, and that returned | ||||||
|  | info includes CURLcode and more. | ||||||
| .SH "RETURN VALUE" | .SH "RETURN VALUE" | ||||||
| CURLMcode type, general libcurl multi interface error code. | CURLMcode type, general libcurl multi interface error code. | ||||||
|  |  | ||||||
| @@ -34,4 +41,5 @@ file descriptors, then it'll wait for action on them using select() and as | |||||||
| soon as one or more of them are ready, \fIcurl_multi_perform(3)\fP gets | 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)," curl_multi_fdset "(3)" | .BR curl_multi_cleanup "(3), " curl_multi_init "(3), " | ||||||
|  | .BR curl_multi_fdset "(3), " curl_multi_info_read "(3)" | ||||||
|   | |||||||
| @@ -12,6 +12,8 @@ curl_multi_strerror - return string describing error code | |||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The curl_multi_strerror() function returns a string describing the CURLMcode | The curl_multi_strerror() function returns a string describing the CURLMcode | ||||||
| error code passed in the argument \fIerrornum\fP. | error code passed in the argument \fIerrornum\fP. | ||||||
|  |  | ||||||
|  | This function was added in libcurl 7.12.0 | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string. | A pointer to a zero terminated string. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ curl_share_cleanup - Clean up a shared object | |||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "CURLSHcode curl_share_cleanup( );" | .BI "CURLSHcode curl_share_cleanup(CURLSH *" share_handle ");" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function deletes a shared object. The share handle cannot be used anymore | This function deletes a shared object. The share handle cannot be used anymore | ||||||
|   | |||||||
| @@ -12,6 +12,8 @@ curl_share_strerror - return string describing error code | |||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The curl_share_strerror() function returns a string describing the CURLSHcode | The curl_share_strerror() function returns a string describing the CURLSHcode | ||||||
| error code passed in the argument \fIerrornum\fP. | error code passed in the argument \fIerrornum\fP. | ||||||
|  |  | ||||||
|  | This function was added in libcurl 7.12.0 | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string. | A pointer to a zero terminated string. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
|   | |||||||
| @@ -45,8 +45,9 @@ server is probably not an OK FTP server. | |||||||
| We were denied access when trying to login to an FTP server or when trying to | We were denied access when trying to login to an FTP server or when trying to | ||||||
| change working directory to the one given in the URL. | change working directory to the one given in the URL. | ||||||
| .IP "CURLE_FTP_USER_PASSWORD_INCORRECT (10)" | .IP "CURLE_FTP_USER_PASSWORD_INCORRECT (10)" | ||||||
| The username and/or the password were incorrect when trying to login to an FTP | The FTP server rejected access to the server after the password was sent to | ||||||
| server. | it. It might be because the username and/or the password were incorrect or | ||||||
|  | just that the server is not allowing you access for the moment etc. | ||||||
| .IP "CURLE_FTP_WEIRD_PASS_REPLY (11)" | .IP "CURLE_FTP_WEIRD_PASS_REPLY (11)" | ||||||
| After having sent the FTP password to the server, libcurl expects a proper | After having sent the FTP password to the server, libcurl expects a proper | ||||||
| reply. This error code indicates that an unexpected code was returned. | reply. This error code indicates that an unexpected code was returned. | ||||||
| @@ -173,7 +174,7 @@ Failure with receiving network data. | |||||||
| .IP "CURLE_SHARE_IN_USE (57)" | .IP "CURLE_SHARE_IN_USE (57)" | ||||||
| Share is in use | Share is in use | ||||||
| .IP "CURLE_SSL_CERTPROBLEM (58)" | .IP "CURLE_SSL_CERTPROBLEM (58)" | ||||||
| problem with the local certificate | 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)" | ||||||
|   | |||||||
| @@ -47,15 +47,35 @@ typedef void CURL; | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Decorate exportable functions for Win32 DLL linking. | ||||||
|  |  * This avoids using a .def file for building libcurl.dll. | ||||||
|  |  */ | ||||||
|  | #if (defined(WIN32) || defined(_WIN32)) && !defined(CURL_STATICLIB) | ||||||
|  | #if defined(BUILDING_LIBCURL) | ||||||
|  | #define CURL_EXTERN  __declspec(dllexport) | ||||||
|  | #else | ||||||
|  | #define CURL_EXTERN  __declspec(dllimport) | ||||||
|  | #endif | ||||||
|  | #else | ||||||
|  | #define CURL_EXTERN | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * We want the typedef curl_off_t setup for large file support on all |  * We want the typedef curl_off_t setup for large file support on all | ||||||
|  * platforms. We also provide a CURL_FORMAT_OFF_T define to use in *printf |  * platforms. We also provide a CURL_FORMAT_OFF_T define to use in *printf | ||||||
|  * format strings when outputting a variable of type curl_off_t. |  * format strings when outputting a variable of type curl_off_t. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #if defined(_MSC_VER) || defined(__LCC__) | #if defined(_MSC_VER) || defined(__LCC__) | ||||||
| /* MSVC */ | /* MSVC */ | ||||||
|  | #ifdef _WIN32_WCE | ||||||
|  |   typedef long curl_off_t; | ||||||
|  | #define CURL_FORMAT_OFF_T "%ld" | ||||||
|  | #else | ||||||
|   typedef signed __int64 curl_off_t; |   typedef signed __int64 curl_off_t; | ||||||
| #define CURL_FORMAT_OFF_T "%I64d" | #define CURL_FORMAT_OFF_T "%I64d" | ||||||
|  | #endif | ||||||
| #else /* _MSC_VER || __LCC__ */ | #else /* _MSC_VER || __LCC__ */ | ||||||
| #if (defined(__GNUC__) && defined(WIN32)) || defined(__WATCOMC__) | #if (defined(__GNUC__) && defined(WIN32)) || defined(__WATCOMC__) | ||||||
| /* gcc on windows or Watcom */ | /* gcc on windows or Watcom */ | ||||||
| @@ -143,19 +163,39 @@ typedef size_t (*curl_write_callback)(char *buffer, | |||||||
|                                       size_t nitems, |                                       size_t nitems, | ||||||
|                                       void *outstream); |                                       void *outstream); | ||||||
|  |  | ||||||
| /* This is a brand new return code for the read callback that will signal | /* This is a return code for the read callback that, when returned, will | ||||||
|    the caller to immediately abort the current transfer. */ |    signal libcurl to immediately abort the current transfer. */ | ||||||
| #define CURL_READFUNC_ABORT 0x10000000 | #define CURL_READFUNC_ABORT 0x10000000 | ||||||
| typedef size_t (*curl_read_callback)(char *buffer, | typedef size_t (*curl_read_callback)(char *buffer, | ||||||
|                                       size_t size, |                                       size_t size, | ||||||
|                                       size_t nitems, |                                       size_t nitems, | ||||||
|                                       void *instream); |                                       void *instream); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #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 */ | ||||||
| typedef int (*curl_passwd_callback)(void *clientp, | typedef int (*curl_passwd_callback)(void *clientp, | ||||||
|                                     const char *prompt, |                                     const char *prompt, | ||||||
|                                     char *buffer, |                                     char *buffer, | ||||||
|                                     int buflen); |                                     int buflen); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | typedef enum { | ||||||
|  |   CURLIOE_OK,            /* I/O operation successful */ | ||||||
|  |   CURLIOE_UNKNOWNCMD,    /* command was unknown to callback */ | ||||||
|  |   CURLIOE_FAILRESTART,   /* failed to restart the read */ | ||||||
|  |   CURLIOE_LAST           /* never use */ | ||||||
|  | } curlioerr; | ||||||
|  |  | ||||||
|  | typedef enum  { | ||||||
|  |   CURLIOCMD_NOP,         /* no operation */ | ||||||
|  |   CURLIOCMD_RESTARTREAD, /* restart the read stream from start */ | ||||||
|  |   CURLIOCMD_LAST         /* never use */ | ||||||
|  | } curliocmd; | ||||||
|  |  | ||||||
|  | typedef curlioerr (*curl_ioctl_callback)(CURL *handle, | ||||||
|  |                                          int cmd, | ||||||
|  |                                          void *clientp); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * The following typedef's are signatures of malloc, free, realloc, strdup and |  * The following typedef's are signatures of malloc, free, realloc, strdup and | ||||||
| @@ -262,7 +302,9 @@ typedef enum { | |||||||
|   CURLE_LDAP_INVALID_URL,        /* 62 - Invalid LDAP URL */ |   CURLE_LDAP_INVALID_URL,        /* 62 - Invalid LDAP URL */ | ||||||
|   CURLE_FILESIZE_EXCEEDED,       /* 63 - Maximum file size exceeded */ |   CURLE_FILESIZE_EXCEEDED,       /* 63 - Maximum file size exceeded */ | ||||||
|   CURLE_FTP_SSL_FAILED,          /* 64 - Requested FTP SSL level failed */ |   CURLE_FTP_SSL_FAILED,          /* 64 - Requested FTP SSL level failed */ | ||||||
|  |   CURLE_SEND_FAIL_REWIND,        /* 65 - Sending the data requires a rewind | ||||||
|  |                                     that failed */ | ||||||
|  |   CURLE_SSL_ENGINE_INITFAILED,   /* 66 - failed to initialise ENGINE */ | ||||||
|   CURL_LAST /* never use! */ |   CURL_LAST /* never use! */ | ||||||
| } CURLcode; | } CURLcode; | ||||||
|  |  | ||||||
| @@ -274,9 +316,12 @@ typedef CURLcode (*curl_ssl_ctx_callback)(CURL *curl,    /* easy handle */ | |||||||
| /* Make a spelling correction for the operation timed-out define */ | /* Make a spelling correction for the operation timed-out define */ | ||||||
| #define CURLE_OPERATION_TIMEDOUT CURLE_OPERATION_TIMEOUTED | #define CURLE_OPERATION_TIMEDOUT CURLE_OPERATION_TIMEOUTED | ||||||
|  |  | ||||||
|  | #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||||
|  |                           the obsolete stuff removed! */ | ||||||
| /* backwards compatibility with older names */ | /* backwards compatibility with older names */ | ||||||
| #define CURLE_HTTP_NOT_FOUND CURLE_HTTP_RETURNED_ERROR | #define CURLE_HTTP_NOT_FOUND CURLE_HTTP_RETURNED_ERROR | ||||||
| #define CURLE_HTTP_PORT_FAILED CURLE_INTERFACE_FAILED | #define CURLE_HTTP_PORT_FAILED CURLE_INTERFACE_FAILED | ||||||
|  | #endif | ||||||
|  |  | ||||||
| typedef enum { | typedef enum { | ||||||
|   CURLPROXY_HTTP = 0, |   CURLPROXY_HTTP = 0, | ||||||
| @@ -292,17 +337,21 @@ 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) | ||||||
|  |  | ||||||
|  | #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||||
|  |                           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 | ||||||
|    is no longer used by libcurl but is instead #defined here only to not |    is no longer used by libcurl but is instead #defined here only to not | ||||||
|    make programs break */ |    make programs break */ | ||||||
| #define CURLE_ALREADY_COMPLETE 99999 | #define CURLE_ALREADY_COMPLETE 99999 | ||||||
|  |  | ||||||
| /* This is just to make older programs not break: */ | /* These are just to make older programs not break: */ | ||||||
| #define CURLE_FTP_PARTIAL_FILE CURLE_PARTIAL_FILE | #define CURLE_FTP_PARTIAL_FILE CURLE_PARTIAL_FILE | ||||||
| #define CURLE_FTP_BAD_DOWNLOAD_RESUME CURLE_BAD_DOWNLOAD_RESUME | #define CURLE_FTP_BAD_DOWNLOAD_RESUME CURLE_BAD_DOWNLOAD_RESUME | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #define CURL_ERROR_SIZE 256 | #define CURL_ERROR_SIZE 256 | ||||||
|  |  | ||||||
|  | /* parameter for the CURLOPT_FTP_SSL option */ | ||||||
| typedef enum { | typedef enum { | ||||||
|   CURLFTPSSL_NONE,    /* do not attempt to use SSL */ |   CURLFTPSSL_NONE,    /* do not attempt to use SSL */ | ||||||
|   CURLFTPSSL_TRY,     /* try using SSL, proceed anyway otherwise */ |   CURLFTPSSL_TRY,     /* try using SSL, proceed anyway otherwise */ | ||||||
| @@ -311,6 +360,14 @@ typedef enum { | |||||||
|   CURLFTPSSL_LAST     /* not an option, never use */ |   CURLFTPSSL_LAST     /* not an option, never use */ | ||||||
| } curl_ftpssl; | } curl_ftpssl; | ||||||
|  |  | ||||||
|  | /* parameter for the CURLOPT_FTPSSLAUTH option */ | ||||||
|  | typedef enum { | ||||||
|  |   CURLFTPAUTH_DEFAULT, /* let libcurl decide */ | ||||||
|  |   CURLFTPAUTH_SSL,     /* use "AUTH SSL" */ | ||||||
|  |   CURLFTPAUTH_TLS,     /* use "AUTH TLS" */ | ||||||
|  |   CURLFTPAUTH_LAST /* not an option, never use */ | ||||||
|  | } curl_ftpauth; | ||||||
|  |  | ||||||
| /* long may be 32 or 64 bits, but we should never depend on anything else | /* long may be 32 or 64 bits, but we should never depend on anything else | ||||||
|    but 32 */ |    but 32 */ | ||||||
| #define CURLOPTTYPE_LONG          0 | #define CURLOPTTYPE_LONG          0 | ||||||
| @@ -813,6 +870,21 @@ typedef enum { | |||||||
|      of commands with this */ |      of commands with this */ | ||||||
|   CINIT(SOURCE_POSTQUOTE, OBJECTPOINT, 128), |   CINIT(SOURCE_POSTQUOTE, OBJECTPOINT, 128), | ||||||
|  |  | ||||||
|  |   /* 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 | ||||||
|  |      "AUTH SSL" and then "AUTH TLS" in this order, and proceed when a OK | ||||||
|  |      response has been received. | ||||||
|  |  | ||||||
|  |      Available parameters are: | ||||||
|  |      CURLFTPAUTH_DEFAULT - let libcurl decide | ||||||
|  |      CURLFTPAUTH_SSL     - try "AUTH SSL" first, then TLS | ||||||
|  |      CURLFTPAUTH_TLS     - try "AUTH TLS" first, then SSL | ||||||
|  |   */ | ||||||
|  |   CINIT(FTPSSLAUTH, LONG, 129), | ||||||
|  |  | ||||||
|  |   CINIT(IOCTLFUNCTION, FUNCTIONPOINT, 130), | ||||||
|  |   CINIT(IOCTLDATA, OBJECTPOINT, 131), | ||||||
|  |  | ||||||
|   CURLOPT_LASTENTRY /* the last unused */ |   CURLOPT_LASTENTRY /* the last unused */ | ||||||
| } CURLoption; | } CURLoption; | ||||||
|  |  | ||||||
| @@ -894,8 +966,8 @@ typedef enum { | |||||||
|  |  | ||||||
| /* curl_strequal() and curl_strnequal() are subject for removal in a future | /* curl_strequal() and curl_strnequal() are subject for removal in a future | ||||||
|    libcurl, see lib/README.curlx for details */ |    libcurl, see lib/README.curlx for details */ | ||||||
| extern int (curl_strequal)(const char *s1, const char *s2); | CURL_EXTERN int (curl_strequal)(const char *s1, const char *s2); | ||||||
| extern int (curl_strnequal)(const char *s1, const char *s2, size_t n); | CURL_EXTERN int (curl_strnequal)(const char *s1, const char *s2, size_t n); | ||||||
|  |  | ||||||
| /* name is uppercase CURLFORM_<name> */ | /* name is uppercase CURLFORM_<name> */ | ||||||
| #ifdef CFINIT | #ifdef CFINIT | ||||||
| @@ -984,7 +1056,7 @@ typedef enum { | |||||||
|  * adds one part that together construct a full post. Then use |  * adds one part that together construct a full post. Then use | ||||||
|  * CURLOPT_HTTPPOST to send it off to libcurl. |  * CURLOPT_HTTPPOST to send it off to libcurl. | ||||||
|  */ |  */ | ||||||
| CURLFORMcode curl_formadd(struct curl_httppost **httppost, | CURL_EXTERN CURLFORMcode curl_formadd(struct curl_httppost **httppost, | ||||||
|                                       struct curl_httppost **last_post, |                                       struct curl_httppost **last_post, | ||||||
|                                       ...); |                                       ...); | ||||||
|  |  | ||||||
| @@ -995,7 +1067,7 @@ CURLFORMcode curl_formadd(struct curl_httppost **httppost, | |||||||
|  * |  * | ||||||
|  * Free a multipart formpost previously built with curl_formadd(). |  * Free a multipart formpost previously built with curl_formadd(). | ||||||
|  */ |  */ | ||||||
| void curl_formfree(struct curl_httppost *form); | CURL_EXTERN void curl_formfree(struct curl_httppost *form); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_getenv() |  * NAME curl_getenv() | ||||||
| @@ -1005,7 +1077,7 @@ void curl_formfree(struct curl_httppost *form); | |||||||
|  * Returns a malloc()'ed string that MUST be curl_free()ed after usage is |  * Returns a malloc()'ed string that MUST be curl_free()ed after usage is | ||||||
|  * complete. DEPRECATED - see lib/README.curlx |  * complete. DEPRECATED - see lib/README.curlx | ||||||
|  */ |  */ | ||||||
| char *curl_getenv(const char *variable); | CURL_EXTERN char *curl_getenv(const char *variable); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_version() |  * NAME curl_version() | ||||||
| @@ -1014,7 +1086,7 @@ char *curl_getenv(const char *variable); | |||||||
|  * |  * | ||||||
|  * Returns a static ascii string of the libcurl version. |  * Returns a static ascii string of the libcurl version. | ||||||
|  */ |  */ | ||||||
| char *curl_version(void); | CURL_EXTERN char *curl_version(void); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_escape() |  * NAME curl_escape() | ||||||
| @@ -1025,7 +1097,7 @@ char *curl_version(void); | |||||||
|  * %XX versions). This function returns a new allocated string or NULL if an |  * %XX versions). This function returns a new allocated string or NULL if an | ||||||
|  * error occurred. |  * error occurred. | ||||||
|  */ |  */ | ||||||
| char *curl_escape(const char *string, int length); | CURL_EXTERN char *curl_escape(const char *string, int length); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_unescape() |  * NAME curl_unescape() | ||||||
| @@ -1036,7 +1108,7 @@ char *curl_escape(const char *string, int length); | |||||||
|  * versions). This function returns a new allocated string or NULL if an error |  * versions). This function returns a new allocated string or NULL if an error | ||||||
|  * occurred. |  * occurred. | ||||||
|  */ |  */ | ||||||
| char *curl_unescape(const char *string, int length); | CURL_EXTERN char *curl_unescape(const char *string, int length); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_free() |  * NAME curl_free() | ||||||
| @@ -1046,7 +1118,7 @@ char *curl_unescape(const char *string, int length); | |||||||
|  * Provided for de-allocation in the same translation unit that did the |  * Provided for de-allocation in the same translation unit that did the | ||||||
|  * allocation. Added in libcurl 7.10 |  * allocation. Added in libcurl 7.10 | ||||||
|  */ |  */ | ||||||
| void curl_free(void *p); | CURL_EXTERN void curl_free(void *p); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_global_init() |  * NAME curl_global_init() | ||||||
| @@ -1056,7 +1128,7 @@ void curl_free(void *p); | |||||||
|  * curl_global_init() should be invoked exactly once for each application that |  * curl_global_init() should be invoked exactly once for each application that | ||||||
|  * uses libcurl |  * uses libcurl | ||||||
|  */ |  */ | ||||||
| CURLcode curl_global_init(long flags); | CURL_EXTERN CURLcode curl_global_init(long flags); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_global_init_mem() |  * NAME curl_global_init_mem() | ||||||
| @@ -1071,7 +1143,7 @@ CURLcode curl_global_init(long flags); | |||||||
|  * callback routines with be invoked by this library instead of the system |  * callback routines with be invoked by this library instead of the system | ||||||
|  * memory management routines like malloc, free etc. |  * memory management routines like malloc, free etc. | ||||||
|  */ |  */ | ||||||
| CURLcode curl_global_init_mem(long flags, | CURL_EXTERN CURLcode curl_global_init_mem(long flags, | ||||||
|                                           curl_malloc_callback m, |                                           curl_malloc_callback m, | ||||||
|                                           curl_free_callback f, |                                           curl_free_callback f, | ||||||
|                                           curl_realloc_callback r, |                                           curl_realloc_callback r, | ||||||
| @@ -1086,7 +1158,7 @@ CURLcode curl_global_init_mem(long flags, | |||||||
|  * curl_global_cleanup() should be invoked exactly once for each application |  * curl_global_cleanup() should be invoked exactly once for each application | ||||||
|  * that uses libcurl |  * that uses libcurl | ||||||
|  */ |  */ | ||||||
| void curl_global_cleanup(void); | CURL_EXTERN void curl_global_cleanup(void); | ||||||
|  |  | ||||||
| /* linked-list structure for the CURLOPT_QUOTE option (and other) */ | /* linked-list structure for the CURLOPT_QUOTE option (and other) */ | ||||||
| struct curl_slist { | struct curl_slist { | ||||||
| @@ -1102,7 +1174,8 @@ struct curl_slist { | |||||||
|  * Appends a string to a linked list. If no list exists, it will be created |  * Appends a string to a linked list. If no list exists, it will be created | ||||||
|  * first. Returns the new list, after appending. |  * first. Returns the new list, after appending. | ||||||
|  */ |  */ | ||||||
| struct curl_slist *curl_slist_append(struct curl_slist *, const char *); | CURL_EXTERN struct curl_slist *curl_slist_append(struct curl_slist *, | ||||||
|  |                                                  const char *); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_slist_free_all() |  * NAME curl_slist_free_all() | ||||||
| @@ -1111,7 +1184,7 @@ struct curl_slist *curl_slist_append(struct curl_slist *, const char *); | |||||||
|  * |  * | ||||||
|  * free a previously built curl_slist. |  * free a previously built curl_slist. | ||||||
|  */ |  */ | ||||||
| void curl_slist_free_all(struct curl_slist *); | CURL_EXTERN void curl_slist_free_all(struct curl_slist *); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_getdate() |  * NAME curl_getdate() | ||||||
| @@ -1123,11 +1196,12 @@ void curl_slist_free_all(struct curl_slist *); | |||||||
|  * where the specified time is relative now, like 'two weeks' or 'tomorrow' |  * where the specified time is relative now, like 'two weeks' or 'tomorrow' | ||||||
|  * etc. |  * etc. | ||||||
|  */ |  */ | ||||||
| time_t curl_getdate(const char *p, const time_t *now); | CURL_EXTERN time_t curl_getdate(const char *p, const time_t *now); | ||||||
|  |  | ||||||
| #define CURLINFO_STRING   0x100000 | #define CURLINFO_STRING   0x100000 | ||||||
| #define CURLINFO_LONG     0x200000 | #define CURLINFO_LONG     0x200000 | ||||||
| #define CURLINFO_DOUBLE   0x300000 | #define CURLINFO_DOUBLE   0x300000 | ||||||
|  | #define CURLINFO_SLIST    0x400000 | ||||||
| #define CURLINFO_MASK     0x0fffff | #define CURLINFO_MASK     0x0fffff | ||||||
| #define CURLINFO_TYPEMASK 0xf00000 | #define CURLINFO_TYPEMASK 0xf00000 | ||||||
|  |  | ||||||
| @@ -1157,9 +1231,12 @@ typedef enum { | |||||||
|   CURLINFO_HTTP_CONNECTCODE = CURLINFO_LONG   + 22, |   CURLINFO_HTTP_CONNECTCODE = CURLINFO_LONG   + 22, | ||||||
|   CURLINFO_HTTPAUTH_AVAIL   = CURLINFO_LONG   + 23, |   CURLINFO_HTTPAUTH_AVAIL   = CURLINFO_LONG   + 23, | ||||||
|   CURLINFO_PROXYAUTH_AVAIL  = CURLINFO_LONG   + 24, |   CURLINFO_PROXYAUTH_AVAIL  = CURLINFO_LONG   + 24, | ||||||
|  |   CURLINFO_OS_ERRNO         = CURLINFO_LONG   + 25, | ||||||
|  |   CURLINFO_NUM_CONNECTS     = CURLINFO_LONG   + 26, | ||||||
|  |   CURLINFO_SSL_ENGINES      = CURLINFO_SLIST  + 27, | ||||||
|   /* Fill in new entries below here! */ |   /* Fill in new entries below here! */ | ||||||
|  |  | ||||||
|   CURLINFO_LASTONE          = 23 |   CURLINFO_LASTONE          = 28 | ||||||
| } CURLINFO; | } CURLINFO; | ||||||
|  |  | ||||||
| /* CURLINFO_RESPONSE_CODE is the new name for the option previously known as | /* CURLINFO_RESPONSE_CODE is the new name for the option previously known as | ||||||
| @@ -1242,9 +1319,9 @@ typedef enum { | |||||||
|   CURLSHOPT_LAST  /* never use */ |   CURLSHOPT_LAST  /* never use */ | ||||||
| } CURLSHoption; | } CURLSHoption; | ||||||
|  |  | ||||||
| CURLSH *curl_share_init(void); | CURL_EXTERN CURLSH *curl_share_init(void); | ||||||
| CURLSHcode curl_share_setopt(CURLSH *, CURLSHoption option, ...); | CURL_EXTERN CURLSHcode curl_share_setopt(CURLSH *, CURLSHoption option, ...); | ||||||
| CURLSHcode curl_share_cleanup(CURLSH *); | CURL_EXTERN CURLSHcode curl_share_cleanup(CURLSH *); | ||||||
|  |  | ||||||
| /**************************************************************************** | /**************************************************************************** | ||||||
|  * Structures for querying information about the curl library at runtime. |  * Structures for querying information about the curl library at runtime. | ||||||
| @@ -1304,7 +1381,7 @@ typedef struct { | |||||||
|  * This function returns a pointer to a static copy of the version info |  * This function returns a pointer to a static copy of the version info | ||||||
|  * struct. See above. |  * struct. See above. | ||||||
|  */ |  */ | ||||||
| curl_version_info_data *curl_version_info(CURLversion); | CURL_EXTERN curl_version_info_data *curl_version_info(CURLversion); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_easy_strerror() |  * NAME curl_easy_strerror() | ||||||
| @@ -1315,7 +1392,7 @@ curl_version_info_data *curl_version_info(CURLversion); | |||||||
|  * into the equivalent human readable error string.  This is useful |  * into the equivalent human readable error string.  This is useful | ||||||
|  * for printing meaningful error messages. |  * for printing meaningful error messages. | ||||||
|  */ |  */ | ||||||
| const char *curl_easy_strerror(CURLcode); | CURL_EXTERN const char *curl_easy_strerror(CURLcode); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_share_strerror() |  * NAME curl_share_strerror() | ||||||
| @@ -1326,7 +1403,7 @@ const char *curl_easy_strerror(CURLcode); | |||||||
|  * into the equivalent human readable error string.  This is useful |  * into the equivalent human readable error string.  This is useful | ||||||
|  * for printing meaningful error messages. |  * for printing meaningful error messages. | ||||||
|  */ |  */ | ||||||
| const char *curl_share_strerror(CURLSHcode); | CURL_EXTERN const char *curl_share_strerror(CURLSHcode); | ||||||
|  |  | ||||||
| #ifdef  __cplusplus | #ifdef  __cplusplus | ||||||
| } | } | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ | |||||||
|  |  | ||||||
| /* 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.12.1-CVS" | #define LIBCURL_VERSION "7.12.3-CVS" | ||||||
|  |  | ||||||
| /* 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 | ||||||
| @@ -44,12 +44,12 @@ | |||||||
|    always a greater number in a more recent release. It makes comparisons with |    always a greater number in a more recent release. It makes comparisons with | ||||||
|    greater than and less than work. |    greater than and less than work. | ||||||
| */ | */ | ||||||
| #define LIBCURL_VERSION_NUM 0x070c01 | #define LIBCURL_VERSION_NUM 0x070c03 | ||||||
|  |  | ||||||
| /* 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 12 | #define LIBCURL_VERSION_MINOR 12 | ||||||
| #define LIBCURL_VERSION_PATCH 1 | #define LIBCURL_VERSION_PATCH 3 | ||||||
|  |  | ||||||
| #endif /* __CURL_CURLVER_H */ | #endif /* __CURL_CURLVER_H */ | ||||||
|   | |||||||
| @@ -26,10 +26,10 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| CURL *curl_easy_init(void); | CURL_EXTERN CURL *curl_easy_init(void); | ||||||
| CURLcode curl_easy_setopt(CURL *curl, CURLoption option, ...); | CURL_EXTERN CURLcode curl_easy_setopt(CURL *curl, CURLoption option, ...); | ||||||
| CURLcode curl_easy_perform(CURL *curl); | CURL_EXTERN CURLcode curl_easy_perform(CURL *curl); | ||||||
| void curl_easy_cleanup(CURL *curl); | CURL_EXTERN void curl_easy_cleanup(CURL *curl); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_easy_getinfo() |  * NAME curl_easy_getinfo() | ||||||
| @@ -44,7 +44,7 @@ void curl_easy_cleanup(CURL *curl); | |||||||
|  * performed transfer, all results from this function are undefined until the |  * performed transfer, all results from this function are undefined until the | ||||||
|  * transfer is completed. |  * transfer is completed. | ||||||
|  */ |  */ | ||||||
| CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...); | CURL_EXTERN CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...); | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -59,7 +59,7 @@ CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...); | |||||||
|  * curl_easy_duphandle() for each new thread to avoid a series of identical |  * curl_easy_duphandle() for each new thread to avoid a series of identical | ||||||
|  * curl_easy_setopt() invokes in every thread. |  * curl_easy_setopt() invokes in every thread. | ||||||
|  */ |  */ | ||||||
| CURL* curl_easy_duphandle(CURL *curl); | CURL_EXTERN CURL* curl_easy_duphandle(CURL *curl); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_easy_reset() |  * NAME curl_easy_reset() | ||||||
| @@ -72,7 +72,7 @@ CURL* curl_easy_duphandle(CURL *curl); | |||||||
|  * It does keep: live connections, the Session ID cache, the DNS cache and the |  * It does keep: live connections, the Session ID cache, the DNS cache and the | ||||||
|  * cookies. |  * cookies. | ||||||
|  */ |  */ | ||||||
| void curl_easy_reset(CURL *curl); | CURL_EXTERN void curl_easy_reset(CURL *curl); | ||||||
|  |  | ||||||
| #ifdef  __cplusplus | #ifdef  __cplusplus | ||||||
| } | } | ||||||
|   | |||||||
| @@ -27,16 +27,18 @@ | |||||||
| #include <stdarg.h> | #include <stdarg.h> | ||||||
| #include <stdio.h> /* needed for FILE */ | #include <stdio.h> /* needed for FILE */ | ||||||
|  |  | ||||||
| int curl_mprintf(const char *format, ...); | #include "curl.h" | ||||||
| int curl_mfprintf(FILE *fd, const char *format, ...); |  | ||||||
| int curl_msprintf(char *buffer, const char *format, ...); | CURL_EXTERN int curl_mprintf(const char *format, ...); | ||||||
| int curl_msnprintf(char *buffer, size_t maxlength, const char *format, ...); | CURL_EXTERN int curl_mfprintf(FILE *fd, const char *format, ...); | ||||||
| int curl_mvprintf(const char *format, va_list args); | CURL_EXTERN int curl_msprintf(char *buffer, const char *format, ...); | ||||||
| int curl_mvfprintf(FILE *fd, const char *format, va_list args); | CURL_EXTERN int curl_msnprintf(char *buffer, size_t maxlength, const char *format, ...); | ||||||
| int curl_mvsprintf(char *buffer, const char *format, va_list args); | CURL_EXTERN int curl_mvprintf(const char *format, va_list args); | ||||||
| int curl_mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list args); | CURL_EXTERN int curl_mvfprintf(FILE *fd, const char *format, va_list args); | ||||||
| char *curl_maprintf(const char *format, ...); | CURL_EXTERN int curl_mvsprintf(char *buffer, const char *format, va_list args); | ||||||
| char *curl_mvaprintf(const char *format, va_list args); | CURL_EXTERN int curl_mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list args); | ||||||
|  | CURL_EXTERN char *curl_maprintf(const char *format, ...); | ||||||
|  | CURL_EXTERN char *curl_mvaprintf(const char *format, va_list args); | ||||||
|  |  | ||||||
| #ifdef _MPRINTF_REPLACE | #ifdef _MPRINTF_REPLACE | ||||||
| # define printf curl_mprintf | # define printf curl_mprintf | ||||||
|   | |||||||
| @@ -51,8 +51,13 @@ | |||||||
| #define WIN32 1 | #define WIN32 1 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__) | #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) || \ | ||||||
|  |   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> | #include <winsock2.h> | ||||||
|  | #endif | ||||||
| #else | #else | ||||||
|  |  | ||||||
| /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish | /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish | ||||||
| @@ -108,7 +113,7 @@ typedef struct CURLMsg CURLMsg; | |||||||
|  * Desc:    inititalize multi-style curl usage |  * Desc:    inititalize multi-style curl usage | ||||||
|  * Returns: a new CURLM handle to use in all 'curl_multi' functions. |  * Returns: a new CURLM handle to use in all 'curl_multi' functions. | ||||||
|  */ |  */ | ||||||
| CURLM *curl_multi_init(void); | CURL_EXTERN CURLM *curl_multi_init(void); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Name:    curl_multi_add_handle() |  * Name:    curl_multi_add_handle() | ||||||
| @@ -116,7 +121,7 @@ CURLM *curl_multi_init(void); | |||||||
|  * Desc:    add a standard curl handle to the multi stack |  * Desc:    add a standard curl handle to the multi stack | ||||||
|  * Returns: CURLMcode type, general multi error code. |  * Returns: CURLMcode type, general multi error code. | ||||||
|  */ |  */ | ||||||
| CURLMcode curl_multi_add_handle(CURLM *multi_handle, | CURL_EXTERN CURLMcode curl_multi_add_handle(CURLM *multi_handle, | ||||||
|                                             CURL *curl_handle); |                                             CURL *curl_handle); | ||||||
|  |  | ||||||
|  /* |  /* | ||||||
| @@ -125,7 +130,7 @@ CURLMcode curl_multi_add_handle(CURLM *multi_handle, | |||||||
|   * Desc:    removes a curl handle from the multi stack again |   * Desc:    removes a curl handle from the multi stack again | ||||||
|   * Returns: CURLMcode type, general multi error code. |   * Returns: CURLMcode type, general multi error code. | ||||||
|   */ |   */ | ||||||
| CURLMcode curl_multi_remove_handle(CURLM *multi_handle, | CURL_EXTERN CURLMcode curl_multi_remove_handle(CURLM *multi_handle, | ||||||
|                                                CURL *curl_handle); |                                                CURL *curl_handle); | ||||||
|  |  | ||||||
|  /* |  /* | ||||||
| @@ -136,7 +141,7 @@ CURLMcode curl_multi_remove_handle(CURLM *multi_handle, | |||||||
|   *          them are ready. |   *          them are ready. | ||||||
|   * Returns: CURLMcode type, general multi error code. |   * Returns: CURLMcode type, general multi error code. | ||||||
|   */ |   */ | ||||||
| CURLMcode curl_multi_fdset(CURLM *multi_handle, | CURL_EXTERN CURLMcode curl_multi_fdset(CURLM *multi_handle, | ||||||
|                                        fd_set *read_fd_set, |                                        fd_set *read_fd_set, | ||||||
|                                        fd_set *write_fd_set, |                                        fd_set *write_fd_set, | ||||||
|                                        fd_set *exc_fd_set, |                                        fd_set *exc_fd_set, | ||||||
| @@ -158,7 +163,7 @@ CURLMcode curl_multi_fdset(CURLM *multi_handle, | |||||||
|   *          still have occurred problems on invidual transfers even when this |   *          still have occurred problems on invidual transfers even when this | ||||||
|   *          returns OK. |   *          returns OK. | ||||||
|   */ |   */ | ||||||
| CURLMcode curl_multi_perform(CURLM *multi_handle, | CURL_EXTERN CURLMcode curl_multi_perform(CURLM *multi_handle, | ||||||
|                                          int *running_handles); |                                          int *running_handles); | ||||||
|  |  | ||||||
|  /* |  /* | ||||||
| @@ -170,7 +175,7 @@ CURLMcode curl_multi_perform(CURLM *multi_handle, | |||||||
|   *          in the middle of a transfer. |   *          in the middle of a transfer. | ||||||
|   * Returns: CURLMcode type, general multi error code. |   * Returns: CURLMcode type, general multi error code. | ||||||
|   */ |   */ | ||||||
| CURLMcode curl_multi_cleanup(CURLM *multi_handle); | CURL_EXTERN CURLMcode curl_multi_cleanup(CURLM *multi_handle); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Name:    curl_multi_info_read() |  * Name:    curl_multi_info_read() | ||||||
| @@ -200,7 +205,7 @@ CURLMcode curl_multi_cleanup(CURLM *multi_handle); | |||||||
|  *          queue (after this read) in the integer the second argument points |  *          queue (after this read) in the integer the second argument points | ||||||
|  *          to. |  *          to. | ||||||
|  */ |  */ | ||||||
| CURLMsg *curl_multi_info_read(CURLM *multi_handle, | CURL_EXTERN CURLMsg *curl_multi_info_read(CURLM *multi_handle, | ||||||
|                                           int *msgs_in_queue); |                                           int *msgs_in_queue); | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -212,7 +217,7 @@ CURLMsg *curl_multi_info_read(CURLM *multi_handle, | |||||||
|  * into the equivalent human readable error string.  This is useful |  * into the equivalent human readable error string.  This is useful | ||||||
|  * for printing meaningful error messages. |  * for printing meaningful error messages. | ||||||
|  */ |  */ | ||||||
| const char *curl_multi_strerror(CURLMcode); | CURL_EXTERN const char *curl_multi_strerror(CURLMcode); | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } /* end of extern "C" */ | } /* end of extern "C" */ | ||||||
|   | |||||||
| @@ -8,3 +8,4 @@ config.h | |||||||
| stamp-* | stamp-* | ||||||
| ca-bundle.h | ca-bundle.h | ||||||
| getdate.c | getdate.c | ||||||
|  | curllib.dsp | ||||||
|   | |||||||
| @@ -24,16 +24,15 @@ AUTOMAKE_OPTIONS = foreign nostdinc | |||||||
|  |  | ||||||
| DSP = curllib.dsp | DSP = curllib.dsp | ||||||
|  |  | ||||||
| EXTRA_DIST = getdate.y Makefile.b32 Makefile.m32	\ | EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos $(DSP)    \ | ||||||
|   Makefile.vc6 Makefile.riscos libcurl.def $(DSP) curllib.dsw		\ |  curllib.dsw config-vms.h config-win32.h config-win32ce.h config-riscos.h     \ | ||||||
|   config-vms.h config-win32.h config-riscos.h config-mac.h config.h.in	\ |  config-mac.h config.h.in ca-bundle.crt README.encoding README.memoryleak     \ | ||||||
|   ca-bundle.crt README.encoding README.memoryleak README.ares		\ |  README.ares README.curlx makefile.dj config.dj libcurl.framework.make	      \ | ||||||
|   README.curlx makefile.dj config.dj libcurl.framework.make		\ |  libcurl.plist libcurl.rc config-amigaos.h amigaos.c amigaos.h makefile.amiga \ | ||||||
|   libcurl.plist libcurl.rc config-amigaos.h amigaos.c amigaos.h		\ |  Makefile.netware nwlib.c libcurl.imp msvcproj.head msvcproj.foot	      \ | ||||||
|   makefile.amiga Makefile.netware nwlib.c libcurl.imp	\ |  config-win32ce.h README.httpauth | ||||||
|   msvcproj.head msvcproj.foot |  | ||||||
|  |  | ||||||
| CLEANFILES = $(DSP) getdate.c | CLEANFILES = $(DSP) | ||||||
|  |  | ||||||
| lib_LTLIBRARIES = libcurl.la | lib_LTLIBRARIES = libcurl.la | ||||||
|  |  | ||||||
| @@ -90,16 +89,10 @@ include Makefile.inc | |||||||
|  |  | ||||||
| libcurl_la_SOURCES = $(CSOURCES) $(HHEADERS) | libcurl_la_SOURCES = $(CSOURCES) $(HHEADERS) | ||||||
|  |  | ||||||
| WIN32SOURCES = $(CSOURCES) libcurl.def | WIN32SOURCES = $(CSOURCES) | ||||||
| WIN32HEADERS = $(HHEADERS) config-win32.h | WIN32HEADERS = $(HHEADERS) config-win32.h | ||||||
|  |  | ||||||
| BUILT_SOURCES = $(srcdir)/getdate.c $(top_builddir)/lib/ca-bundle.h | BUILT_SOURCES = $(top_builddir)/lib/ca-bundle.h | ||||||
|  |  | ||||||
| # Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule. |  | ||||||
| $(srcdir)/getdate.c: getdate.y |  | ||||||
| 	cd $(srcdir) && \ |  | ||||||
| 	  $(YACC) $(YFLAGS) getdate.y; \ |  | ||||||
| 	  mv -f y.tab.c getdate.c |  | ||||||
|  |  | ||||||
| $(top_builddir)/lib/ca-bundle.h: Makefile.in Makefile | $(top_builddir)/lib/ca-bundle.h: Makefile.in Makefile | ||||||
| 	@if test -f $@; then \ | 	@if test -f $@; then \ | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user