Compare commits
	
		
			1239 Commits
		
	
	
		
			curl-7_9_3
			...
			curl-7_10_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 95a4b8db68 | ||
|   | 663c1898a3 | ||
|   | 465de793e8 | ||
|   | de9b76cef0 | ||
|   | 1747a8d3d9 | ||
|   | 1094e79749 | ||
|   | 22569681bc | ||
|   | e615d117a0 | ||
|   | a51258b6bb | ||
|   | 8894bd07b6 | ||
|   | ec45a9e825 | ||
|   | 871358a6e5 | ||
|   | 2e2e0fba60 | ||
|   | 4a5139e3f4 | ||
|   | 8f85933d7c | ||
|   | 246f3a63f6 | ||
|   | e99eff4eb0 | ||
|   | c0197f19cf | ||
|   | 3994d67eea | ||
|   | 9ead79c9d4 | ||
|   | 9371aed46c | ||
|   | 940707ad66 | ||
|   | e6c267fb4c | ||
|   | 93538fccd6 | ||
|   | 83a7fad308 | ||
|   | 3c7e33388e | ||
|   | 7b0f35edb6 | ||
|   | 94a157d0b0 | ||
|   | ca04620253 | ||
|   | 073ef0b36a | ||
|   | c41c05d4f4 | ||
|   | f1ea54e07a | ||
|   | a139ce901a | ||
|   | 7431957113 | ||
|   | 1752d80915 | ||
|   | aa7420e109 | ||
|   | a290d4b9db | ||
|   | 19a4314e7f | ||
|   | d166e85e0a | ||
|   | f213e857ab | ||
|   | eb6130baa7 | ||
|   | f69ea2c68a | ||
|   | 078441d477 | ||
|   | 95f6b15a67 | ||
|   | ee29dbdb8f | ||
|   | 15f3f4c93f | ||
|   | 6932e94e0e | ||
|   | 3ef06d7efe | ||
|   | fb012b48e9 | ||
|   | bc77bf217f | ||
|   | 37d1e9351e | ||
|   | 4494c0dee0 | ||
|   | 26afc604ac | ||
|   | 9aefcada19 | ||
|   | 69fc363760 | ||
|   | bea02ddebe | ||
|   | 3fb257c39c | ||
|   | 7c96c5a39b | ||
|   | efd836d971 | ||
|   | 836aaa1647 | ||
|   | bf2b3dbf3e | ||
|   | b4fa2ff995 | ||
|   | 2f9cabc30b | ||
|   | 63593f5597 | ||
|   | c0acaa5d2c | ||
|   | 2e46f8d0a6 | ||
|   | 51da6aaa07 | ||
|   | c8b79e36db | ||
|   | 208374bcc9 | ||
|   | 7f0a6e7203 | ||
|   | 54ebb9cfd4 | ||
|   | 49e9c1495b | ||
|   | a84b0fbd52 | ||
|   | c95814c04d | ||
|   | 9f8123f1b8 | ||
|   | 8b23db4f4d | ||
|   | d77cc13374 | ||
|   | 9a12db1aa2 | ||
|   | eb54d34bec | ||
|   | 4b1203d4c9 | ||
|   | 183a9c6244 | ||
|   | 1f2294d585 | ||
|   | 0b839c4f77 | ||
|   | 1d4fd1fcae | ||
|   | b1d8d72c16 | ||
|   | bafb68b844 | ||
|   | 21873b52e9 | ||
|   | 0aa8b82871 | ||
|   | f9781afafd | ||
|   | fece361a55 | ||
|   | 7b51b2f128 | ||
|   | 22d88fb28e | ||
|   | f7c5b28e76 | ||
|   | 5760f2a307 | ||
|   | ee46efb5a5 | ||
|   | eb6ffebfc7 | ||
|   | c06c44f286 | ||
|   | 019c4088cf | ||
|   | 0b0a88b78d | ||
|   | 028e9cc56f | ||
|   | e0d8615ece | ||
|   | c8ecbda40b | ||
|   | 2324c10d43 | ||
|   | 89cfa76291 | ||
|   | 072070a22c | ||
|   | 3c3ad134ea | ||
|   | a4ffcfd4d5 | ||
|   | 136670c58a | ||
|   | 28169725fa | ||
|   | 5b13106f54 | ||
|   | 1a2db0dfb1 | ||
|   | 696f95bb0a | ||
|   | acec588fe3 | ||
|   | 6ed0da8e98 | ||
|   | 7fd91d70bd | ||
|   | 61788a0389 | ||
|   | 0821447b5b | ||
|   | 3cba274ba6 | ||
|   | df7bbcfd21 | ||
|   | 021d406f0c | ||
|   | 294569c502 | ||
|   | bfd00ac2ed | ||
|   | 735a4714f4 | ||
|   | 827fd47198 | ||
|   | e26b917661 | ||
|   | 92872a2a3c | ||
|   | 16ddb09cb4 | ||
|   | d37031f14e | ||
|   | b4e84ca7d2 | ||
|   | 47970b9e6f | ||
|   | f65f120d50 | ||
|   | df00ec3c82 | ||
|   | ad6fca28f9 | ||
|   | fd33923496 | ||
|   | a55649dc82 | ||
|   | 9558f229db | ||
|   | 7917bfb1c9 | ||
|   | 25f611ca42 | ||
|   | e6eb49e7e0 | ||
|   | 9a075f53dc | ||
|   | 4b3f800c03 | ||
|   | 82bc76b243 | ||
|   | 18b9b04907 | ||
|   | 87f1f08b36 | ||
|   | 7d7ebbe9f7 | ||
|   | 5111ce782f | ||
|   | 20b0e563ce | ||
|   | 8b6cf239a3 | ||
|   | bcc285cffd | ||
|   | d5ba030942 | ||
|   | 803f43592a | ||
|   | 904b9ccaa3 | ||
|   | 89721ff04a | ||
|   | 6164823921 | ||
|   | f8b3c47f99 | ||
|   | 56dd2da962 | ||
|   | 68bb74d172 | ||
|   | bf5e12c8e0 | ||
|   | de11f5e53a | ||
|   | b125e8e23a | ||
|   | b28b616eb2 | ||
|   | 4534ca238d | ||
|   | cee0e94294 | ||
|   | 8319ea7078 | ||
|   | 5334a58f9b | ||
|   | 2616bdc4cd | ||
|   | c149b3f797 | ||
|   | d349eb3d43 | ||
|   | 9b43ade1c0 | ||
|   | ad05d0a8d9 | ||
|   | e6bfbe9683 | ||
|   | c871efca4b | ||
|   | 12c72b419c | ||
|   | a15b7691ca | ||
|   | 01618d323b | ||
|   | bb6d0e37e3 | ||
|   | 24a6100897 | ||
|   | 0251563c98 | ||
|   | 72673a351b | ||
|   | 96b7131844 | ||
|   | dcc2f16416 | ||
|   | c2b8a04000 | ||
|   | d65587b06c | ||
|   | 1ab0134522 | ||
|   | afffce80f0 | ||
|   | 70b80b0160 | ||
|   | 64067a04b5 | ||
|   | 38cf0268c0 | ||
|   | 2d2034703f | ||
|   | 571ceeff90 | ||
|   | 34c4ba4321 | ||
|   | babb372eb9 | ||
|   | 5b9b82c1cd | ||
|   | 075c534270 | ||
|   | f317f8b149 | ||
|   | f8d552dde5 | ||
|   | 606f72bb13 | ||
|   | 327e6a2b4f | ||
|   | be8f6c7f5c | ||
|   | 073448e0ea | ||
|   | f136f435b5 | ||
|   | ebea6b487b | ||
|   | e5b7dc56e6 | ||
|   | c2d8025a0a | ||
|   | 853e240e1d | ||
|   | 8755a6d1ac | ||
|   | 9f723061cb | ||
|   | 652683fc04 | ||
|   | 83a463891d | ||
|   | 957b618fdc | ||
|   | ebe5191b63 | ||
|   | c426234df7 | ||
|   | 8c3a10392e | ||
|   | d0e44946e9 | ||
|   | 46a593d968 | ||
|   | eb0cc34951 | ||
|   | 1c7dfda4bc | ||
|   | 3c0e4a2fa1 | ||
|   | c753072ae1 | ||
|   | 243942a7aa | ||
|   | 8d5ac8b43c | ||
|   | 17962b3d2e | ||
|   | f70acd5979 | ||
|   | ffe5c46224 | ||
|   | 3242ea5f66 | ||
|   | 39a282bffc | ||
|   | 29583004ce | ||
|   | 0a1a185874 | ||
|   | 8f809e2a93 | ||
|   | f216059b49 | ||
|   | 9121b1f41d | ||
|   | 60e015d0c1 | ||
|   | 7e049fca61 | ||
|   | 0f0e4de6a4 | ||
|   | bc1102922b | ||
|   | a3d3642a30 | ||
|   | 248eb47329 | ||
|   | 52ebf50607 | ||
|   | d34a4b126e | ||
|   | de96719a45 | ||
|   | 9876ed09fe | ||
|   | 17cbbe3dc5 | ||
|   | b995af17eb | ||
|   | 6589579850 | ||
|   | 5ddc260fc2 | ||
|   | db5c9cd4c0 | ||
|   | 9b6d010aef | ||
|   | 065b87e949 | ||
|   | a6206a3aef | ||
|   | 30639ed72b | ||
|   | 9d02a39e13 | ||
|   | fc0af0d4d1 | ||
|   | a683416081 | ||
|   | 9faf57ee8d | ||
|   | 44b9ccb7e2 | ||
|   | de003d9cf8 | ||
|   | 8a2a523c70 | ||
|   | c3dfe50aaf | ||
|   | 9659d862c7 | ||
|   | 69ab4cd391 | ||
|   | 498f3985b3 | ||
|   | 977175d4fd | ||
|   | 3ddc7b9390 | ||
|   | 10e9bf623f | ||
|   | 48a5c64e94 | ||
|   | 140606ccd5 | ||
|   | f56d006f93 | ||
|   | beb13a1d3e | ||
|   | fa47138327 | ||
|   | 9421d4510a | ||
|   | ff8abfca85 | ||
|   | 5c858965b8 | ||
|   | e3f83cb17a | ||
|   | de6008e01a | ||
|   | 6417e696df | ||
|   | 5d28f3781b | ||
|   | 10026bb62e | ||
|   | 21c16f923c | ||
|   | 32cef52f0d | ||
|   | e7dd7c54ff | ||
|   | b0b50bd12a | ||
|   | f2c6057490 | ||
|   | 169b2eeb94 | ||
|   | f81d027f60 | ||
|   | 872eeb7339 | ||
|   | 7f67a28c2a | ||
|   | 30a46e1135 | ||
|   | 3a01478ce8 | ||
|   | 53d71fab60 | ||
|   | be891f112c | ||
|   | 89934239d7 | ||
|   | 8986037fdd | ||
|   | a7c72b7abf | ||
|   | 409ac80710 | ||
|   | fc7bebdf55 | ||
|   | ca52549557 | ||
|   | 8948a65654 | ||
|   | b4e33cfcc7 | ||
|   | 86742e8334 | ||
|   | 173b35eaf8 | ||
|   | 2b054e5309 | ||
|   | a302ff1605 | ||
|   | f7bb4e6138 | ||
|   | 5c5489916b | ||
|   | 5627cf7167 | ||
|   | c05dae4a68 | ||
|   | 57e61e3743 | ||
|   | a6c395c156 | ||
|   | 543e0b1e0f | ||
|   | 64b0ff875f | ||
|   | a034208a00 | ||
|   | 5f1251586b | ||
|   | 6f6cffdc32 | ||
|   | 21a98ef264 | ||
|   | aa90436435 | ||
|   | 61225052f9 | ||
|   | dee3163d95 | ||
|   | 8b0668b99e | ||
|   | 8471a82c85 | ||
|   | ed4dff63b9 | ||
|   | 838e776542 | ||
|   | 39c12790bc | ||
|   | 126e6d6645 | ||
|   | 5796a1b282 | ||
|   | 90982529fc | ||
|   | aba51d6b60 | ||
|   | 49bc4567bb | ||
|   | 2ac52705c6 | ||
|   | d0eb56dd97 | ||
|   | b9c60df04b | ||
|   | 8c236e4dfa | ||
|   | 154a59f21f | ||
|   | 9689e1c548 | ||
|   | 5a83976c99 | ||
|   | b5276a9a69 | ||
|   | 30377baa5e | ||
|   | aa8b7dd336 | ||
|   | f26a338a54 | ||
|   | c4383f1d99 | ||
|   | 4527995e66 | ||
|   | b0fbb98f41 | ||
|   | 63667dfd96 | ||
|   | 77c388c928 | ||
|   | a69b814ded | ||
|   | c51ada766d | ||
|   | ef2709f97c | ||
|   | bf9b9ca29d | ||
|   | 64f224bb22 | ||
|   | 285a8fe4d0 | ||
|   | 3773d76dfd | ||
|   | 94c5c7bd6d | ||
|   | 12cfc4c0b0 | ||
|   | 9a2de6e6ee | ||
|   | 2ede47b8c8 | ||
|   | 76e107506f | ||
|   | 6f35ed51dc | ||
|   | c94ba66310 | ||
|   | a15133f5cf | ||
|   | cc09e9d4c2 | ||
|   | 16e0da2c4b | ||
|   | ed22f75241 | ||
|   | ba25cad6e2 | ||
|   | abb01123cb | ||
|   | e2d249f8c5 | ||
|   | 4a2ac166fa | ||
|   | 5fab55383d | ||
|   | f152f23a68 | ||
|   | 24e78b3571 | ||
|   | 9a239edb52 | ||
|   | abcc5c5a82 | ||
|   | cb5ba675a7 | ||
|   | 2288086695 | ||
|   | 61421b7a8f | ||
|   | 6a7e53a7c7 | ||
|   | ca134d5522 | ||
|   | ec24efda74 | ||
|   | 7f0f10e498 | ||
|   | aa5af100b4 | ||
|   | 37ae32f688 | ||
|   | d0cffdec5d | ||
|   | 0f34521612 | ||
|   | e69362df22 | ||
|   | 3de8f6f38e | ||
|   | 5359bc8083 | ||
|   | eb6a14fe10 | ||
|   | 2912537533 | ||
|   | cfb32da198 | ||
|   | 9b4f92130f | ||
|   | 5a2ab686a6 | ||
|   | 3b8583b014 | ||
|   | ed29552b1e | ||
|   | a2ada3cf96 | ||
|   | 88825a1187 | ||
|   | 264e7fc58b | ||
|   | 1698015e3c | ||
|   | 39dc14c002 | ||
|   | 04c499a5fc | ||
|   | efbe930a69 | ||
|   | 747f87f61e | ||
|   | 5a4c56fc44 | ||
|   | 81f45ba92a | ||
|   | a5dc4e32f2 | ||
|   | 2b839853ec | ||
|   | 66b6cd68ed | ||
|   | 0ef3d90838 | ||
|   | 5cc50f9b27 | ||
|   | e879e26a5b | ||
|   | 96d84150e1 | ||
|   | 2aa0c6c488 | ||
|   | 811138386f | ||
|   | c433cf7459 | ||
|   | e0d6ebc2f2 | ||
|   | 4938991ab8 | ||
|   | 13722f536e | ||
|   | 57f0e3292d | ||
|   | da5ae565ab | ||
|   | 87c5066242 | ||
|   | b528bde470 | ||
|   | 57572e550f | ||
|   | 3aea0d3d68 | ||
|   | 9ae920c1b6 | ||
|   | dff406a360 | ||
|   | d346ba5c3c | ||
|   | 978541adc2 | ||
|   | 637bce2707 | ||
|   | 07e3dc2ee2 | ||
|   | ead065d803 | ||
|   | 0150bff7b4 | ||
|   | 0f493b6038 | ||
|   | f26b709c50 | ||
|   | ae10d9cf22 | ||
|   | 81af9674ed | ||
|   | b63df7991a | ||
|   | a79990465c | ||
|   | ad6bd530ac | ||
|   | c1b369fd4c | ||
|   | 01fcd3c2d5 | ||
|   | 7196d784d3 | ||
|   | 0f0aaf51e0 | ||
|   | b5f493c55a | ||
|   | 0aa031beb9 | ||
|   | db6ff224f8 | ||
|   | b3c7cd61f3 | ||
|   | 9ae05c4d91 | ||
|   | 264e6f6efd | ||
|   | ec7bccf671 | ||
|   | 49f75ee8ce | ||
|   | 4bcc866c52 | ||
|   | c65e088caf | ||
|   | 6ca4116555 | ||
|   | f6cdb820af | ||
|   | 081e5a82ff | ||
|   | 2ad2a4bd9f | ||
|   | 645e700da3 | ||
|   | 92aea29a30 | ||
|   | e1c01af929 | ||
|   | 7ef749497d | ||
|   | d72aa49126 | ||
|   | e92bd312ec | ||
|   | b097c2cfb0 | ||
|   | a39cdc80b7 | ||
|   | a47250810e | ||
|   | 1f50f3031f | ||
|   | 75145dd753 | ||
|   | d0b97f7e1f | ||
|   | 199a0311e2 | ||
|   | fa446f860f | ||
|   | 7a74303f3c | ||
|   | 7d9eabb981 | ||
|   | ff5308a5af | ||
|   | 3f8ba3a986 | ||
|   | 4a555de1b2 | ||
|   | d27e4a08f9 | ||
|   | bf678a1ca9 | ||
|   | 13a903de28 | ||
|   | a3c14c031e | ||
|   | e90d528026 | ||
|   | d64dd77993 | ||
|   | 113850a748 | ||
|   | 1c49a00d64 | ||
|   | eef6c83503 | ||
|   | ceb5648eb7 | ||
|   | a0eadb76ea | ||
|   | 065852e46c | ||
|   | e5e2fb8274 | ||
|   | 0210b3c893 | ||
|   | 7df5677b46 | ||
|   | 2e71876b28 | ||
|   | 11576b1142 | ||
|   | ce011b8a2d | ||
|   | 12cfb4f7ee | ||
|   | 9e1123debe | ||
|   | c7354142c0 | ||
|   | dee84f448f | ||
|   | 1607711603 | ||
|   | 8bca5e05b8 | ||
|   | f68505ee23 | ||
|   | d2174da641 | ||
|   | 255b1e68d0 | ||
|   | fbee6b87f5 | ||
|   | 3836a70f97 | ||
|   | e0ec9fa294 | ||
|   | 80fe50590f | ||
|   | ae18d1c55a | ||
|   | 75194373e0 | ||
|   | f3875048f6 | ||
|   | 210af986ad | ||
|   | c03044f492 | ||
|   | 522b85ae21 | ||
|   | 208e56dbe9 | ||
|   | 42acb00c81 | ||
|   | ca6e770837 | ||
|   | 775968003c | ||
|   | 323d3e9b5d | ||
|   | 16f9755e73 | ||
|   | 66eb98bb0a | ||
|   | 299546f5c0 | ||
|   | 7be9b4c418 | ||
|   | 03c22b4576 | ||
|   | ef749fa9ce | ||
|   | a23c92596e | ||
|   | abb1497c98 | ||
|   | 7a8594da43 | ||
|   | cbf28daed9 | ||
|   | 0ff1ca30c3 | ||
|   | 2cff251863 | ||
|   | 73d996bf26 | ||
|   | 5bc78cb724 | ||
|   | cdba92ac3c | ||
|   | 6d28f92ffe | ||
|   | 01387f42c5 | ||
|   | 8f52b731f4 | ||
|   | d442088ed3 | ||
|   | 22a323890a | ||
|   | 163bba1410 | ||
|   | db1c618fcf | ||
|   | 01bdfa7b6d | ||
|   | 6a88c8d845 | ||
|   | b8a6913e09 | ||
|   | 744d8c1006 | ||
|   | c2e2c98d81 | ||
|   | 3fa353a2d3 | ||
|   | c27c9f80d2 | ||
|   | b5a74715cf | ||
|   | 13ee2901f4 | ||
|   | 32c03eadd6 | ||
|   | 0fa512f26d | ||
|   | 219d88518c | ||
|   | ecf3aee43a | ||
|   | 7f08cab73e | ||
|   | c4e9ef199e | ||
|   | 9e612b5550 | ||
|   | 203633d34d | ||
|   | 45bd009bb1 | ||
|   | ee656415c4 | ||
|   | 156aad198f | ||
|   | b1ffb79a50 | ||
|   | d6654bfe00 | ||
|   | eefdd67d22 | ||
|   | 86a86d7afd | ||
|   | b6dac2b484 | ||
|   | e6367abae9 | ||
|   | fc4d1d9a60 | ||
|   | 94bae20776 | ||
|   | bb8c8d273c | ||
|   | ee600ace37 | ||
|   | da86e32eb4 | ||
|   | b5bbc04ad1 | ||
|   | 265c58611f | ||
|   | 25c973a39e | ||
|   | 123c7b32db | ||
|   | e2d8e2c4ae | ||
|   | 701509d322 | ||
|   | c3cc616264 | ||
|   | 91b84b89e4 | ||
|   | 017ec204a9 | ||
|   | 8dbfecd153 | ||
|   | 512db1bc54 | ||
|   | e157aabd4d | ||
|   | db2fea448c | ||
|   | dd82d69b8c | ||
|   | 27328281b7 | ||
|   | 51d205b267 | ||
|   | 84800914f6 | ||
|   | 9b296e65bd | ||
|   | 5f649a1649 | ||
|   | daea056210 | ||
|   | 30c0db06bd | ||
|   | 91168c005c | ||
|   | cfa0054077 | ||
|   | 3d5820648b | ||
|   | d08df97fe5 | ||
|   | fd6624a058 | ||
|   | 8aa41dd04b | ||
|   | e890113fc6 | ||
|   | e2e64798b5 | ||
|   | b9b6a6566a | ||
|   | dc9e415602 | ||
|   | 84fa12c885 | ||
|   | 296b35fe9b | ||
|   | 0ff89b9c3c | ||
|   | 3b33540c99 | ||
|   | 29d0174253 | ||
|   | cc7f2a0d08 | ||
|   | b1579aed2f | ||
|   | 9247daf953 | ||
|   | 9031e33b66 | ||
|   | 1ee1f5f427 | ||
|   | a5874a5393 | ||
|   | 969217c9d9 | ||
|   | e399502c7a | ||
|   | 6883f0c49f | ||
|   | 3fc2c813cc | ||
|   | 9de4b99fc7 | ||
|   | 24e7036822 | ||
|   | ec9acbcda7 | ||
|   | c0460660d5 | ||
|   | b03f4919fb | ||
|   | 08620743b9 | ||
|   | 41362f063a | ||
|   | 5b3069e265 | ||
|   | b466924717 | ||
|   | cbc0f65fa3 | ||
|   | 35089a4289 | ||
|   | aef3131e92 | ||
|   | 342fce97af | ||
|   | fb5d267bd0 | ||
|   | c19844a0a3 | ||
|   | 22cf05519a | ||
|   | 511ce35631 | ||
|   | e9b7548dd6 | ||
|   | 010cde0a4a | ||
|   | cac5251a98 | ||
|   | 3b825bcbfb | ||
|   | 31959fb24b | ||
|   | 5e9675ad1e | ||
|   | 084b7675b2 | ||
|   | ed8be5bc55 | ||
|   | efca2943a0 | ||
|   | 371da7132f | ||
|   | 9a3ff5c46a | ||
|   | b36c654a3d | ||
|   | ddeb2613ec | ||
|   | 2d02d20911 | ||
|   | b2563b9f9f | ||
|   | fccf6925b1 | ||
|   | 4a7cf65064 | ||
|   | 56587e2821 | ||
|   | 33b8e71583 | ||
|   | 1c96128695 | ||
|   | ca516b1b26 | ||
|   | ba4e69bebc | ||
|   | de5e9f100c | ||
|   | 955da86a3e | ||
|   | 8d85be4c5e | ||
|   | 93eadfb10f | ||
|   | f8e0b18439 | ||
|   | 64bbe9dfaf | ||
|   | 2e8a9416af | ||
|   | 5dd40bd0bb | ||
|   | 1822dd0549 | ||
|   | 751e49fb0a | ||
|   | 56c43604d0 | ||
|   | 7438c378be | ||
|   | 0e0caf7c06 | ||
|   | 5644f4a295 | ||
|   | 98e1605b17 | ||
|   | 73f0e32d1a | ||
|   | 713cb56fea | ||
|   | bd3bb70ee8 | ||
|   | 8aa3f14303 | ||
|   | ac285b453e | ||
|   | daf55705e4 | ||
|   | 7140baae72 | ||
|   | 27a2e590cd | ||
|   | 7172fa058a | ||
|   | c0790ccf08 | ||
|   | 87c43517cd | ||
|   | 6561ec524b | ||
|   | 982c5460f0 | ||
|   | 2a3a8848f3 | ||
|   | 752520e428 | ||
|   | 8095b776fe | ||
|   | e504103e2c | ||
|   | 904183262a | ||
|   | 2a0bc64226 | ||
|   | 6b975c308c | ||
|   | 74be55a477 | ||
|   | 394832c2d6 | ||
|   | f636c12255 | ||
|   | 03e4a8214c | ||
|   | 6d7785a35b | ||
|   | 904f579332 | ||
|   | a72d789b08 | ||
|   | 87ad7ace18 | ||
|   | 35153eb524 | ||
|   | c8ee1fa62e | ||
|   | 5c1a6ed719 | ||
|   | 9d68fde148 | ||
|   | c7d517f6d2 | ||
|   | 183f1531d3 | ||
|   | 6dfe0ec31e | ||
|   | 8b3f1cebda | ||
|   | 086daf913c | ||
|   | 6a3e2272e9 | ||
|   | d0e0bf53a6 | ||
|   | 0009e4dfb9 | ||
|   | 30b7a9f172 | ||
|   | c74cb59e08 | ||
|   | c1f29a8e08 | ||
|   | cb895ec335 | ||
|   | 2df4866cfa | ||
|   | 423a1cf486 | ||
|   | 7aeb63c817 | ||
|   | 476fa1f4d2 | ||
|   | 0bea215560 | ||
|   | 3c20b98d99 | ||
|   | 8bcdda29d4 | ||
|   | c88036405f | ||
|   | 60cddab4f2 | ||
|   | 411ca1c050 | ||
|   | d1be3a4a1d | ||
|   | b5dd257427 | ||
|   | 4cf953678d | ||
|   | ca5678c8c1 | ||
|   | 9e4594be53 | ||
|   | d16c757c28 | ||
|   | 312bcafd05 | ||
|   | be24652d4d | ||
|   | 6ab44d9439 | ||
|   | 108cb14d1f | ||
|   | b98308b524 | ||
|   | 215c445583 | ||
|   | 20d8e32a58 | ||
|   | 33306b2749 | ||
|   | 94eeeba79a | ||
|   | ecd29a289a | ||
|   | e7d0af72e3 | ||
|   | fcb1d3521a | ||
|   | 890bf3bd27 | ||
|   | dafd81178f | ||
|   | 99dfdebc64 | ||
|   | c1cfdd6323 | ||
|   | 264a9bc6ed | ||
|   | f79f5cbf82 | ||
|   | 7313501e30 | ||
|   | d8b2c819e7 | ||
|   | 69f6d14b81 | ||
|   | 9f3856e646 | ||
|   | a46e2e9900 | ||
|   | 14f0dd2dd0 | ||
|   | c051438fa1 | ||
|   | 52e32ac1d3 | ||
|   | 7f8ad34ba2 | ||
|   | a9c0302454 | ||
|   | a33e89b44a | ||
|   | e203ecebee | ||
|   | 2f8e7f56b3 | ||
|   | 2443e1f38c | ||
|   | eb164098b7 | ||
|   | 62527fa98a | ||
|   | b9f8e80b14 | ||
|   | b79e250ed2 | ||
|   | fc5c9d8f17 | ||
|   | 72d57a8ee6 | ||
|   | 23262e30bc | ||
|   | 8b4ad40ed6 | ||
|   | d7e9797365 | ||
|   | e54e0c7877 | ||
|   | 5cb06d8fd6 | ||
|   | 2b34d4e1f7 | ||
|   | c7aa095fac | ||
|   | 93f1784526 | ||
|   | 559dc503c2 | ||
|   | 414afe0935 | ||
|   | 4ad4f3fc70 | ||
|   | 67273eed9b | ||
|   | 3c63e1d8d9 | ||
|   | cae555c977 | ||
|   | 407583e8e2 | ||
|   | 131645dc31 | ||
|   | dafd644fe7 | ||
|   | 73cc1742af | ||
|   | 87afd7686f | ||
|   | 8ce10b5dfa | ||
|   | 943e31b35c | ||
|   | 20f85b94df | ||
|   | 17b784381e | ||
|   | e3031fddb9 | ||
|   | 38c994a7ae | ||
|   | 85e2e96fb6 | ||
|   | be35b3ad03 | ||
|   | dbbd871ea1 | ||
|   | 813911db59 | ||
|   | 3c49b405de | ||
|   | 4cfffd6c4a | ||
|   | e9f1c12f0f | ||
|   | 4fe252847c | ||
|   | 109cbbe9c5 | ||
|   | fd3881eaa6 | ||
|   | 08ef208fb7 | ||
|   | 8c45e2a641 | ||
|   | 25dc520163 | ||
|   | fc37ef9e4b | ||
|   | 11ba367fc9 | ||
|   | 78473f71eb | ||
|   | 8b77f40f99 | ||
|   | d866716565 | ||
|   | 307d0effe2 | ||
|   | b47b053e54 | ||
|   | b79f01caf3 | ||
|   | 0db227f55e | ||
|   | ac48b38842 | ||
|   | 0cbb9365c6 | ||
|   | 798b8c522b | ||
|   | 15bc7e19f9 | ||
|   | 0be3f1a063 | ||
|   | c0257c6721 | ||
|   | 9aec0fc7de | ||
|   | bce5e0d82c | ||
|   | 62032ee248 | ||
|   | 775645f29b | ||
|   | 99c0456872 | ||
|   | 0236bee5de | ||
|   | 59c11b82d5 | ||
|   | 98871d1e9e | ||
|   | b40dc5d742 | ||
|   | 17b0723713 | ||
|   | ec585e8907 | ||
|   | 0aeb25ff3b | ||
|   | a928f2c4aa | ||
|   | 51fcee6f81 | ||
|   | 654be65590 | ||
|   | 105ec79b2b | ||
|   | c759d8427a | ||
|   | c7b03d6479 | ||
|   | 2080738883 | ||
|   | 48bc73c271 | ||
|   | 3d0969d1d1 | ||
|   | 323f195036 | ||
|   | c3c392fc98 | ||
|   | 5d2944c211 | ||
|   | fe3ba1dd11 | ||
|   | 0c00eb93a0 | ||
|   | baa77ec13b | ||
|   | 9263652c6d | ||
|   | bc74375543 | ||
|   | edb1756050 | ||
|   | 5215f6f654 | ||
|   | 1913b4eeed | ||
|   | b44a4da5df | ||
|   | 919878fbb2 | ||
|   | 06bdf83419 | ||
|   | 2ff2810a92 | ||
|   | 20d9c1b30d | ||
|   | bbe10cb0cb | ||
|   | daba8f3a70 | ||
|   | 1458c3668d | ||
|   | 980a47b42b | ||
|   | f7ca561b06 | ||
|   | cacd756efd | ||
|   | 8539e76cb9 | ||
|   | 3bbf694d5a | ||
|   | 44debdde62 | ||
|   | c6cf2b8e93 | ||
|   | 69c5452b25 | ||
|   | d321056e8d | ||
|   | d9a1a59f22 | ||
|   | 0b898b5a8a | ||
|   | a9e0885be0 | ||
|   | 57ff28c9b7 | ||
|   | 86cc34c0de | ||
|   | 39028f1bd4 | ||
|   | 71f4c05665 | ||
|   | 9ef9797998 | ||
|   | ab9374de57 | ||
|   | 913e997061 | ||
|   | 8e50d6b6f3 | ||
|   | 2db0744a7b | ||
|   | 2de0028349 | ||
|   | 35d04c5398 | ||
|   | b1becd0ed5 | ||
|   | bd9650bc81 | ||
|   | 969a25d1b2 | ||
|   | f144f77ba7 | ||
|   | abea1f8910 | ||
|   | 8eaa7fec76 | ||
|   | fdace647e8 | ||
|   | d7531c18fc | ||
|   | ef3f978784 | ||
|   | e410860e0e | ||
|   | c64fca1b0c | ||
|   | 15b2a3af91 | ||
|   | 8358505b6d | ||
|   | 1c42779845 | ||
|   | 32823f17e0 | ||
|   | e1c2e3f5e9 | ||
|   | 044755b30f | ||
|   | 9aa22399a8 | ||
|   | f564905ac4 | ||
|   | 00e4f81446 | ||
|   | 8927ddec16 | ||
|   | f6525ae200 | ||
|   | 0be7944d66 | ||
|   | 47819ea86e | ||
|   | 96ce3461ad | ||
|   | 8b6d555421 | ||
|   | 3b9ef8dfc8 | ||
|   | db6d4bcf47 | ||
|   | 471f1d694f | ||
|   | 495f6f6bd3 | ||
|   | 36e35b6f60 | ||
|   | 192606bc4b | ||
|   | 53a9fdf078 | ||
|   | ef436bdbe8 | ||
|   | 72d722b07b | ||
|   | 21fc402c01 | ||
|   | 381f77756d | ||
|   | a386562d9a | ||
|   | 2bc84fb163 | ||
|   | 08f8917acb | ||
|   | 62d205a2ec | ||
|   | 29e873b12d | ||
|   | 95f78080ab | ||
|   | 9549cfde02 | ||
|   | 2361aabbef | ||
|   | e0cc8d2ce9 | ||
|   | 53c0e97117 | ||
|   | bb44791bf3 | ||
|   | 9ebcfe9dff | ||
|   | f339bf613c | ||
|   | b00c59816d | ||
|   | a00918116d | ||
|   | d26c318321 | ||
|   | eb8770506f | ||
|   | c06171a802 | ||
|   | 5528c1eaa5 | ||
|   | 93516effe4 | ||
|   | 38e518c710 | ||
|   | 3f6133be27 | ||
|   | c3bfb355c5 | ||
|   | c69dd14cbc | ||
|   | 7954652b80 | ||
|   | ca35b39900 | ||
|   | 09df9b90c3 | ||
|   | 308ae5cbf2 | ||
|   | 1cd5cdfccb | ||
|   | 606e7fd744 | ||
|   | e8109b09b1 | ||
|   | 536ea60d73 | ||
|   | 3390b6446c | ||
|   | bfc7f1e4ac | ||
|   | 8ba410a56e | ||
|   | 14d1da3ae0 | ||
|   | 2a72641a0b | ||
|   | 9c4e5dc3ee | ||
|   | 540e5ffa90 | ||
|   | c1a57591ee | ||
|   | 1a4f72dd4f | ||
|   | c3c8bbd3b2 | ||
|   | fb7d34cea8 | ||
|   | 0866c1b52d | ||
|   | 136f728b49 | ||
|   | 5d28a857a4 | ||
|   | edbe0d166c | ||
|   | 4db8c8b1a3 | ||
|   | 2b16b8604a | ||
|   | f630929810 | ||
|   | 016abdfef6 | ||
|   | fd915609cd | ||
|   | 064697fde6 | ||
|   | a03fd7b81c | ||
|   | 1cfcbc50a6 | ||
|   | ea1f138c08 | ||
|   | d560207ea1 | ||
|   | 90b51831fd | ||
|   | 38ed8938d8 | ||
|   | 547e91dbf0 | ||
|   | 04da96e044 | ||
|   | 4a7def101b | ||
|   | 541e5a3b82 | ||
|   | 5af61716aa | ||
|   | 6f3e0051c3 | ||
|   | 703ecc3521 | ||
|   | 67b0f9aacd | ||
|   | 854277bae5 | ||
|   | ca9760756a | ||
|   | f1f993a25b | ||
|   | eb0f727818 | ||
|   | dc3d0289d6 | ||
|   | bd830c6f4d | ||
|   | 51d602f973 | ||
|   | 30d5401f31 | ||
|   | ab6b0f9843 | ||
|   | c560327f26 | ||
|   | 28939dd45c | ||
|   | 3853e3d6f3 | ||
|   | 6062a1bd68 | ||
|   | 8d94688fd1 | ||
|   | 6b4532b592 | ||
|   | 286fb6f645 | ||
|   | 340caf5da3 | ||
|   | 171c4fd49f | ||
|   | b8a0fb1dfe | ||
|   | e65993bccb | ||
|   | 7ffb4660ec | ||
|   | 974f314f57 | ||
|   | 4cec22fa19 | ||
|   | 069477d35c | ||
|   | eaff1a344e | ||
|   | 1fe1e39a88 | ||
|   | 33b06f56f0 | ||
|   | 61a84abe2a | ||
|   | 3d03100079 | ||
|   | 5297a52bf0 | ||
|   | 88631276e8 | ||
|   | 2c0d9ad64c | ||
|   | 5c691ed835 | ||
|   | f73864a045 | ||
|   | 94da04fcac | ||
|   | 5f758fbd11 | ||
|   | fb29529a52 | ||
|   | 3cd2673077 | ||
|   | d242214e18 | ||
|   | 468b787272 | ||
|   | cfdb6f851c | ||
|   | 7886f120f3 | ||
|   | 76fe69b133 | ||
|   | e1bae4fc7e | ||
|   | bc9705f758 | ||
|   | c819e234b8 | ||
|   | ce021b79a7 | ||
|   | 805a2f6f99 | ||
|   | eb78400b53 | ||
|   | 4852f9ffbd | ||
|   | c8d2ad2513 | ||
|   | 9f374c2050 | ||
|   | 5799852424 | ||
|   | 6417fa95cf | ||
|   | 61f6284a35 | ||
|   | 6b1a1a62a3 | ||
|   | feacb4b481 | ||
|   | fe3c874001 | ||
|   | d9459b54d9 | ||
|   | 017be8a882 | ||
|   | b86e543a13 | ||
|   | c2d4fd876c | ||
|   | 58cad04bbb | ||
|   | 9bb64d6827 | ||
|   | 4441df90c1 | ||
|   | f51f2417c5 | ||
|   | aad617647d | ||
|   | 49c0d62dda | ||
|   | f752098ba5 | ||
|   | a4477b9e4b | ||
|   | ad3cef0fc8 | ||
|   | d89dbe5bd6 | ||
|   | b0475dbdbc | ||
|   | 60b2e74fa3 | ||
|   | cda16297d1 | ||
|   | d6c9a72e15 | ||
|   | 4d7b1512c1 | ||
|   | d8a35d745e | ||
|   | e22657ea13 | ||
|   | d06d6b5534 | ||
|   | cec8ab1fde | ||
|   | 9fc62a8dd0 | ||
|   | 61540b98c2 | ||
|   | 465ae39e86 | ||
|   | 01f04b9a41 | ||
|   | 34f9ab1046 | ||
|   | 699876778b | ||
|   | 8fc5a0d19e | ||
|   | 62b5926d58 | ||
|   | 4d1037f385 | ||
|   | e4addb3975 | ||
|   | 2aef351980 | ||
|   | d88c153c7d | ||
|   | 9e9883082e | ||
|   | 71440df4c7 | ||
|   | 80b004a57d | ||
|   | ea8476a2dc | ||
|   | cb85ca18ab | ||
|   | f1103b95cf | ||
|   | aa5ff53bcf | ||
|   | 907dabed5d | ||
|   | 0cacbc892c | ||
|   | 6753c3c715 | ||
|   | 36e1363e3d | ||
|   | d1a711eb6a | ||
|   | d8dea4dcc7 | ||
|   | ca161737bc | ||
|   | 3612c3774e | ||
|   | e6a65bb3ef | ||
|   | ff291eee48 | ||
|   | 66b8f48a88 | ||
|   | 634760cbdc | ||
|   | a23a897ad2 | ||
|   | d9c244278d | ||
|   | b6c4185b27 | ||
|   | 5896d35e72 | ||
|   | b4dfdd8bbc | ||
|   | e6ed3478ea | ||
|   | db08d9c6b9 | ||
|   | 9490278ece | ||
|   | fd8bf5f171 | ||
|   | c9bc14a222 | ||
|   | 63708cbfb0 | ||
|   | d9f307623c | ||
|   | 540f77a627 | ||
|   | 71bb2d0b8b | ||
|   | 87dc44e434 | ||
|   | 29e0fcd091 | ||
|   | 2e9a798f09 | ||
|   | b32a39f44f | ||
|   | d86f9611b3 | ||
|   | 6a62fc4a40 | ||
|   | 7cdd6455d7 | ||
|   | e4fefd088d | ||
|   | 95e601e2b1 | ||
|   | b1ffe7b74a | ||
|   | 417c8fb602 | ||
|   | 85efa64c31 | ||
|   | d8cb026e80 | ||
|   | 41dd5121f0 | ||
|   | 94482d7ca5 | ||
|   | 4d0e51aead | ||
|   | ae8a8c8ba4 | ||
|   | 7d043f46d5 | ||
|   | cbca19d6c2 | ||
|   | b40b9677b6 | ||
|   | c80ad865db | ||
|   | 758eae49ab | ||
|   | 721b05e343 | ||
|   | a333bddeeb | ||
|   | 4c6a52fe90 | ||
|   | 792d73a9cf | ||
|   | 9a95a3f8c3 | ||
|   | 485edb777f | ||
|   | a8c3431ae9 | ||
|   | 6fe4a6fa9a | ||
|   | 6d8c7356d6 | ||
|   | a782c96e81 | ||
|   | c795123cd5 | ||
|   | 0ec370e6fb | ||
|   | 3d5732d4e0 | ||
|   | b795929858 | ||
|   | 535258ffe4 | ||
|   | cc161b96ac | ||
|   | 5c4b422b18 | ||
|   | 89bad584c3 | ||
|   | e21926f7f0 | ||
|   | e452f467d4 | ||
|   | dfda7ba456 | ||
|   | feb6b6445e | ||
|   | 0b57fa9c51 | ||
|   | 55c6f60c90 | ||
|   | 9def011e8e | ||
|   | 7cf6e8c9cc | ||
|   | cdee43aa59 | ||
|   | 9c25b58b4c | ||
|   | 83f35463f5 | ||
|   | 818cdb879e | ||
|   | 3eead2d6c4 | ||
|   | 5cffe055ad | ||
|   | 3d4511daf3 | ||
|   | 4748b40ad9 | ||
|   | c40b4f6c39 | ||
|   | d3b96dd394 | ||
|   | f946df640b | ||
|   | fef78bd6f1 | ||
|   | 9e6cc86bf7 | ||
|   | b544c5fa5c | ||
|   | afa64ee31f | ||
|   | e9bfef0eb1 | ||
|   | ddbcccd43d | ||
|   | 5370d7a6eb | ||
|   | 685b180ab6 | ||
|   | 9dab850874 | ||
|   | 0d5bfe883e | ||
|   | cc2f1d4894 | ||
|   | a8dd13db4c | ||
|   | 325391aef9 | ||
|   | 3474ec4ecb | ||
|   | ec1736d488 | ||
|   | 4522579688 | ||
|   | 907a6e0eed | ||
|   | d20186a7b8 | ||
|   | b28051881e | ||
|   | bdea56cd3f | ||
|   | 8a3ec2c659 | ||
|   | 14e9420d2c | ||
|   | 5b58e61f28 | ||
|   | be2f3071b5 | ||
|   | 85dbf82d93 | ||
|   | a9c4963cc0 | ||
|   | a4934387d5 | ||
|   | e88a2ec6fc | ||
|   | 0666960173 | ||
|   | f114caca90 | ||
|   | 9468c9c796 | ||
|   | 76c53c690c | ||
|   | c341b11aaf | ||
|   | 6212e6990a | ||
|   | 28049a183c | ||
|   | 5d3dd7911e | ||
|   | ae8375516b | ||
|   | e3f10eb825 | ||
|   | 2b1f683239 | ||
|   | a2b19c9a63 | ||
|   | 4146ce8267 | ||
|   | 170bd6dafc | ||
|   | 7e16ec8724 | ||
|   | 8c459156f8 | ||
|   | 2db894807b | ||
|   | 95ceeb6e0b | ||
|   | c9c00d2a23 | ||
|   | 1afe49864d | ||
|   | 6924bee3a0 | ||
|   | 39d4552dab | ||
|   | a23c63738f | ||
|   | e911945c55 | ||
|   | 6d58d13710 | ||
|   | 0b177cb165 | ||
|   | 3e31b619de | ||
|   | f925979b2f | ||
|   | 49f7fa82b9 | ||
|   | e4cd4cf3f3 | ||
|   | e74b20926d | ||
|   | a312127c91 | ||
|   | 1dc5bf4f73 | ||
|   | 01cfe670c5 | ||
|   | fd307bfe29 | ||
|   | a00de093a7 | ||
|   | 7bfe853af3 | ||
|   | cbaecca8e9 | ||
|   | 8edfb370a8 | ||
|   | 4c08c8f7db | ||
|   | c174680a03 | 
							
								
								
									
										11
									
								
								.cvsignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								.cvsignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | config.log | ||||||
|  | Makefile | ||||||
|  | libtool | ||||||
|  | Makefile.in | ||||||
|  | aclocal.m4 | ||||||
|  | configure | ||||||
|  | config.h | ||||||
|  | config.status | ||||||
|  | curl-config | ||||||
|  | autom4te.cache | ||||||
|  | depcomp | ||||||
							
								
								
									
										1957
									
								
								CHANGES.2001
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1957
									
								
								CHANGES.2001
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										21
									
								
								COPYING
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								COPYING
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | COPYRIGHT AND PERMISSION NOTICE | ||||||
|  |  | ||||||
|  | Copyright (c) 1996 - 2003, Daniel Stenberg, <daniel@haxx.se>. | ||||||
|  |  | ||||||
|  | All rights reserved. | ||||||
|  |  | ||||||
|  | Permission to use, copy, modify, and distribute this software for any purpose | ||||||
|  | with or without fee is hereby granted, provided that the above copyright | ||||||
|  | notice and this permission notice appear in all copies. | ||||||
|  |  | ||||||
|  | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN | ||||||
|  | NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, | ||||||
|  | DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | ||||||
|  | OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE | ||||||
|  | OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
|  |  | ||||||
|  | Except as contained in this notice, the name of a copyright holder shall not | ||||||
|  | be used in advertising or otherwise to promote the sale, use or other dealings | ||||||
|  | in this Software without prior written authorization of the copyright holder. | ||||||
							
								
								
									
										37
									
								
								CVS-INFO
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								CVS-INFO
									
									
									
									
									
								
							| @@ -15,7 +15,8 @@ Compile and build instructions follow below. | |||||||
|   CHANGES.0     contains ancient changes. |   CHANGES.0     contains ancient changes. | ||||||
|   CHANGES.$year contains changes for the particular year. |   CHANGES.$year contains changes for the particular year. | ||||||
|  |  | ||||||
|   memanalyze.pl is for analyzing the output generated by curl if -DMALLOCDEBUG |   tests/memanalyze.pl | ||||||
|  |                 is for analyzing the output generated by curl if -DMALLOCDEBUG | ||||||
|                 is used when compiling |                 is used when compiling | ||||||
|  |  | ||||||
|   buildconf     builds the makefiles and configure stuff |   buildconf     builds the makefiles and configure stuff | ||||||
| @@ -30,25 +31,39 @@ To build after having extracted everything from CVS, do this: | |||||||
| ./configure | ./configure | ||||||
| make | make | ||||||
|  |  | ||||||
|  |   Daniel uses a ./configure line similar to this for easier development: | ||||||
|  |  | ||||||
|  |   ./configure --disable-shared --enable-debug --enable-maintainer-mode | ||||||
|  |  | ||||||
|  |  | ||||||
| REQUIREMENTS | REQUIREMENTS | ||||||
|  |  | ||||||
|  You need the following software installed: |  You need the following software installed: | ||||||
|  |  | ||||||
|  o autoconf 2.50 (or later) |  o autoconf 2.57  (or later) | ||||||
|  o automake 1.5 (or later) |  o automake 1.7   (or later) | ||||||
|  o libtool  1.4 (or later) |  o libtool  1.4.2 (or later) | ||||||
|  o GNU m4 (required by autoconf) |  o GNU m4 (required by autoconf) | ||||||
|  |  | ||||||
|  o nroff + perl (if you don't have nroff and perl and you for some reason |  o nroff + perl | ||||||
|    don't want to install them, you can rename the source file |  | ||||||
|    src/hugehelp.c.cvs to src/hugehelp.c and avoid having to generate this |    If you don't have nroff and perl and you for some reason don't want to | ||||||
|    file. This will of course give you an older version of the file that isn't |    install them, you can rename the source file src/hugehelp.c.cvs to | ||||||
|    up-to-date. That file was checked in once and won't be updated very |    src/hugehelp.c and avoid having to generate this file. This will of course | ||||||
|    regularly.) |    give you an older version of the file that isn't up-to-date. That file was | ||||||
|  |    checked in once and won't be updated very regularly. | ||||||
|  |  | ||||||
|  |  o yacc/bison  | ||||||
|  |  | ||||||
|  |    If you don't have yacc or bison, you must rename the lib/getdate.c.cvs file | ||||||
|  |    to lib/getdate.c to be able to build libcurl. yacc/bison is normally used | ||||||
|  |    to generate the lib/getdate.c file from the lib/getdate.y source file. | ||||||
|  |  | ||||||
| MAC OS X | MAC OS X | ||||||
|  |  | ||||||
|  For Mac OS X users, Guido Neitzer write down the following step-by-step guide: |  With Mac OS X 10.2 and the associated Developer Tools, the installed versions | ||||||
|  |  of the build tools are adequate.  For Mac OS X 10.1 users, Guido Neitzer | ||||||
|  |  wrote the following step-by-step guide: | ||||||
|  |  | ||||||
|  1. Install fink (http://fink.sourceforge.net) |  1. Install fink (http://fink.sourceforge.net) | ||||||
|  2. Update fink to the newest version (with the installed fink) |  2. Update fink to the newest version (with the installed fink) | ||||||
|   | |||||||
							
								
								
									
										25
									
								
								LEGAL
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								LEGAL
									
									
									
									
									
								
							| @@ -1,25 +0,0 @@ | |||||||
|  Copyright (C) 1998-2001, Daniel Stenberg, <daniel@haxx.se>, et al. |  | ||||||
|  |  | ||||||
|  Everyone is permitted to copy and distribute verbatim copies of this license |  | ||||||
|  document, but changing it is not allowed. |  | ||||||
|  |  | ||||||
|  In order to be useful for every potential user, the curl and libcurl are |  | ||||||
|  dual-licensed under the MPL and the MIT/X-derivate licenses. |  | ||||||
|  |  | ||||||
|  You may opt to use, copy, modify, merge, publish, distribute and/or sell |  | ||||||
|  copies of the Software, and permit persons to whom the Software is furnished |  | ||||||
|  to do so, under the terms of the MPL or the MIT/X-derivate licenses. You may |  | ||||||
|  pick one of these licenses. The files MITX.txt and MPL-1.1.txt contain the |  | ||||||
|  license texts. |  | ||||||
|  |  | ||||||
|  As a courtesy to the open-source and free software community, we ask you to |  | ||||||
|  dual-license any modifications that you make as well, under the terms of this |  | ||||||
|  document. |  | ||||||
|  |  | ||||||
|  Please remember to always keep the licensing information included in |  | ||||||
|  individual source files up-to-date, so as to avoid misleading anyone as to |  | ||||||
|  the status of these files. |  | ||||||
|  |  | ||||||
|  I will use a submission policy according to which I will only enter |  | ||||||
|  contributions into the CVS tree if the contributor agrees to both licenses |  | ||||||
|  and this dual-license approach. |  | ||||||
							
								
								
									
										27
									
								
								MITX.txt
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								MITX.txt
									
									
									
									
									
								
							| @@ -1,27 +0,0 @@ | |||||||
| COPYRIGHT AND PERMISSION NOTICE |  | ||||||
|  |  | ||||||
| Copyright (c) 1996 - 2001, Daniel Stenberg, <daniel@haxx.se>. |  | ||||||
|  |  | ||||||
| All rights reserved. |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy |  | ||||||
| of this software and associated documentation files (the "Software"), to deal |  | ||||||
| in the Software without restriction, including without limitation the rights |  | ||||||
| to use, copy, modify, merge, publish, distribute, and/or sell copies of the |  | ||||||
| Software, and to permit persons to whom the Software is furnished to do so, |  | ||||||
| provided that the above copyright notice(s) and this permission notice appear |  | ||||||
| in all copies of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |  | ||||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |  | ||||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN |  | ||||||
| NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS NOTICE BE |  | ||||||
| LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY |  | ||||||
| DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |  | ||||||
| ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN |  | ||||||
| CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |  | ||||||
|  |  | ||||||
| Except as contained in this notice, the name of a copyright holder shall not |  | ||||||
| be used in advertising or otherwise to promote the sale, use or other dealings |  | ||||||
| in this Software without prior written authorization of the copyright holder. |  | ||||||
|  |  | ||||||
							
								
								
									
										470
									
								
								MPL-1.1.txt
									
									
									
									
									
								
							
							
						
						
									
										470
									
								
								MPL-1.1.txt
									
									
									
									
									
								
							| @@ -1,470 +0,0 @@ | |||||||
|                           MOZILLA PUBLIC LICENSE |  | ||||||
|                                 Version 1.1 |  | ||||||
|  |  | ||||||
|                               --------------- |  | ||||||
|  |  | ||||||
| 1. Definitions. |  | ||||||
|  |  | ||||||
|      1.0.1. "Commercial Use" means distribution or otherwise making the |  | ||||||
|      Covered Code available to a third party. |  | ||||||
|  |  | ||||||
|      1.1. "Contributor" means each entity that creates or contributes to |  | ||||||
|      the creation of Modifications. |  | ||||||
|  |  | ||||||
|      1.2. "Contributor Version" means the combination of the Original |  | ||||||
|      Code, prior Modifications used by a Contributor, and the Modifications |  | ||||||
|      made by that particular Contributor. |  | ||||||
|  |  | ||||||
|      1.3. "Covered Code" means the Original Code or Modifications or the |  | ||||||
|      combination of the Original Code and Modifications, in each case |  | ||||||
|      including portions thereof. |  | ||||||
|  |  | ||||||
|      1.4. "Electronic Distribution Mechanism" means a mechanism generally |  | ||||||
|      accepted in the software development community for the electronic |  | ||||||
|      transfer of data. |  | ||||||
|  |  | ||||||
|      1.5. "Executable" means Covered Code in any form other than Source |  | ||||||
|      Code. |  | ||||||
|  |  | ||||||
|      1.6. "Initial Developer" means the individual or entity identified |  | ||||||
|      as the Initial Developer in the Source Code notice required by Exhibit |  | ||||||
|      A. |  | ||||||
|  |  | ||||||
|      1.7. "Larger Work" means a work which combines Covered Code or |  | ||||||
|      portions thereof with code not governed by the terms of this License. |  | ||||||
|  |  | ||||||
|      1.8. "License" means this document. |  | ||||||
|  |  | ||||||
|      1.8.1. "Licensable" means having the right to grant, to the maximum |  | ||||||
|      extent possible, whether at the time of the initial grant or |  | ||||||
|      subsequently acquired, any and all of the rights conveyed herein. |  | ||||||
|  |  | ||||||
|      1.9. "Modifications" means any addition to or deletion from the |  | ||||||
|      substance or structure of either the Original Code or any previous |  | ||||||
|      Modifications. When Covered Code is released as a series of files, a |  | ||||||
|      Modification is: |  | ||||||
|           A. Any addition to or deletion from the contents of a file |  | ||||||
|           containing Original Code or previous Modifications. |  | ||||||
|  |  | ||||||
|           B. Any new file that contains any part of the Original Code or |  | ||||||
|           previous Modifications. |  | ||||||
|  |  | ||||||
|      1.10. "Original Code" means Source Code of computer software code |  | ||||||
|      which is described in the Source Code notice required by Exhibit A as |  | ||||||
|      Original Code, and which, at the time of its release under this |  | ||||||
|      License is not already Covered Code governed by this License. |  | ||||||
|  |  | ||||||
|      1.10.1. "Patent Claims" means any patent claim(s), now owned or |  | ||||||
|      hereafter acquired, including without limitation,  method, process, |  | ||||||
|      and apparatus claims, in any patent Licensable by grantor. |  | ||||||
|  |  | ||||||
|      1.11. "Source Code" means the preferred form of the Covered Code for |  | ||||||
|      making modifications to it, including all modules it contains, plus |  | ||||||
|      any associated interface definition files, scripts used to control |  | ||||||
|      compilation and installation of an Executable, or source code |  | ||||||
|      differential comparisons against either the Original Code or another |  | ||||||
|      well known, available Covered Code of the Contributor's choice. The |  | ||||||
|      Source Code can be in a compressed or archival form, provided the |  | ||||||
|      appropriate decompression or de-archiving software is widely available |  | ||||||
|      for no charge. |  | ||||||
|  |  | ||||||
|      1.12. "You" (or "Your")  means an individual or a legal entity |  | ||||||
|      exercising rights under, and complying with all of the terms of, this |  | ||||||
|      License or a future version of this License issued under Section 6.1. |  | ||||||
|      For legal entities, "You" includes any entity which controls, is |  | ||||||
|      controlled by, or is under common control with You. For purposes of |  | ||||||
|      this definition, "control" means (a) the power, direct or indirect, |  | ||||||
|      to cause the direction or management of such entity, whether by |  | ||||||
|      contract or otherwise, or (b) ownership of more than fifty percent |  | ||||||
|      (50%) of the outstanding shares or beneficial ownership of such |  | ||||||
|      entity. |  | ||||||
|  |  | ||||||
| 2. Source Code License. |  | ||||||
|  |  | ||||||
|      2.1. The Initial Developer Grant. |  | ||||||
|      The Initial Developer hereby grants You a world-wide, royalty-free, |  | ||||||
|      non-exclusive license, subject to third party intellectual property |  | ||||||
|      claims: |  | ||||||
|           (a)  under intellectual property rights (other than patent or |  | ||||||
|           trademark) Licensable by Initial Developer to use, reproduce, |  | ||||||
|           modify, display, perform, sublicense and distribute the Original |  | ||||||
|           Code (or portions thereof) with or without Modifications, and/or |  | ||||||
|           as part of a Larger Work; and |  | ||||||
|  |  | ||||||
|           (b) under Patents Claims infringed by the making, using or |  | ||||||
|           selling of Original Code, to make, have made, use, practice, |  | ||||||
|           sell, and offer for sale, and/or otherwise dispose of the |  | ||||||
|           Original Code (or portions thereof). |  | ||||||
|  |  | ||||||
|           (c) the licenses granted in this Section 2.1(a) and (b) are |  | ||||||
|           effective on the date Initial Developer first distributes |  | ||||||
|           Original Code under the terms of this License. |  | ||||||
|  |  | ||||||
|           (d) Notwithstanding Section 2.1(b) above, no patent license is |  | ||||||
|           granted: 1) for code that You delete from the Original Code; 2) |  | ||||||
|           separate from the Original Code;  or 3) for infringements caused |  | ||||||
|           by: i) the modification of the Original Code or ii) the |  | ||||||
|           combination of the Original Code with other software or devices. |  | ||||||
|  |  | ||||||
|      2.2. Contributor Grant. |  | ||||||
|      Subject to third party intellectual property claims, each Contributor |  | ||||||
|      hereby grants You a world-wide, royalty-free, non-exclusive license |  | ||||||
|  |  | ||||||
|           (a)  under intellectual property rights (other than patent or |  | ||||||
|           trademark) Licensable by Contributor, to use, reproduce, modify, |  | ||||||
|           display, perform, sublicense and distribute the Modifications |  | ||||||
|           created by such Contributor (or portions thereof) either on an |  | ||||||
|           unmodified basis, with other Modifications, as Covered Code |  | ||||||
|           and/or as part of a Larger Work; and |  | ||||||
|  |  | ||||||
|           (b) under Patent Claims infringed by the making, using, or |  | ||||||
|           selling of  Modifications made by that Contributor either alone |  | ||||||
|           and/or in combination with its Contributor Version (or portions |  | ||||||
|           of such combination), to make, use, sell, offer for sale, have |  | ||||||
|           made, and/or otherwise dispose of: 1) Modifications made by that |  | ||||||
|           Contributor (or portions thereof); and 2) the combination of |  | ||||||
|           Modifications made by that Contributor with its Contributor |  | ||||||
|           Version (or portions of such combination). |  | ||||||
|  |  | ||||||
|           (c) the licenses granted in Sections 2.2(a) and 2.2(b) are |  | ||||||
|           effective on the date Contributor first makes Commercial Use of |  | ||||||
|           the Covered Code. |  | ||||||
|  |  | ||||||
|           (d)    Notwithstanding Section 2.2(b) above, no patent license is |  | ||||||
|           granted: 1) for any code that Contributor has deleted from the |  | ||||||
|           Contributor Version; 2)  separate from the Contributor Version; |  | ||||||
|           3)  for infringements caused by: i) third party modifications of |  | ||||||
|           Contributor Version or ii)  the combination of Modifications made |  | ||||||
|           by that Contributor with other software  (except as part of the |  | ||||||
|           Contributor Version) or other devices; or 4) under Patent Claims |  | ||||||
|           infringed by Covered Code in the absence of Modifications made by |  | ||||||
|           that Contributor. |  | ||||||
|  |  | ||||||
| 3. Distribution Obligations. |  | ||||||
|  |  | ||||||
|      3.1. Application of License. |  | ||||||
|      The Modifications which You create or to which You contribute are |  | ||||||
|      governed by the terms of this License, including without limitation |  | ||||||
|      Section 2.2. The Source Code version of Covered Code may be |  | ||||||
|      distributed only under the terms of this License or a future version |  | ||||||
|      of this License released under Section 6.1, and You must include a |  | ||||||
|      copy of this License with every copy of the Source Code You |  | ||||||
|      distribute. You may not offer or impose any terms on any Source Code |  | ||||||
|      version that alters or restricts the applicable version of this |  | ||||||
|      License or the recipients' rights hereunder. However, You may include |  | ||||||
|      an additional document offering the additional rights described in |  | ||||||
|      Section 3.5. |  | ||||||
|  |  | ||||||
|      3.2. Availability of Source Code. |  | ||||||
|      Any Modification which You create or to which You contribute must be |  | ||||||
|      made available in Source Code form under the terms of this License |  | ||||||
|      either on the same media as an Executable version or via an accepted |  | ||||||
|      Electronic Distribution Mechanism to anyone to whom you made an |  | ||||||
|      Executable version available; and if made available via Electronic |  | ||||||
|      Distribution Mechanism, must remain available for at least twelve (12) |  | ||||||
|      months after the date it initially became available, or at least six |  | ||||||
|      (6) months after a subsequent version of that particular Modification |  | ||||||
|      has been made available to such recipients. You are responsible for |  | ||||||
|      ensuring that the Source Code version remains available even if the |  | ||||||
|      Electronic Distribution Mechanism is maintained by a third party. |  | ||||||
|  |  | ||||||
|      3.3. Description of Modifications. |  | ||||||
|      You must cause all Covered Code to which You contribute to contain a |  | ||||||
|      file documenting the changes You made to create that Covered Code and |  | ||||||
|      the date of any change. You must include a prominent statement that |  | ||||||
|      the Modification is derived, directly or indirectly, from Original |  | ||||||
|      Code provided by the Initial Developer and including the name of the |  | ||||||
|      Initial Developer in (a) the Source Code, and (b) in any notice in an |  | ||||||
|      Executable version or related documentation in which You describe the |  | ||||||
|      origin or ownership of the Covered Code. |  | ||||||
|  |  | ||||||
|      3.4. Intellectual Property Matters |  | ||||||
|           (a) Third Party Claims. |  | ||||||
|           If Contributor has knowledge that a license under a third party's |  | ||||||
|           intellectual property rights is required to exercise the rights |  | ||||||
|           granted by such Contributor under Sections 2.1 or 2.2, |  | ||||||
|           Contributor must include a text file with the Source Code |  | ||||||
|           distribution titled "LEGAL" which describes the claim and the |  | ||||||
|           party making the claim in sufficient detail that a recipient will |  | ||||||
|           know whom to contact. If Contributor obtains such knowledge after |  | ||||||
|           the Modification is made available as described in Section 3.2, |  | ||||||
|           Contributor shall promptly modify the LEGAL file in all copies |  | ||||||
|           Contributor makes available thereafter and shall take other steps |  | ||||||
|           (such as notifying appropriate mailing lists or newsgroups) |  | ||||||
|           reasonably calculated to inform those who received the Covered |  | ||||||
|           Code that new knowledge has been obtained. |  | ||||||
|  |  | ||||||
|           (b) Contributor APIs. |  | ||||||
|           If Contributor's Modifications include an application programming |  | ||||||
|           interface and Contributor has knowledge of patent licenses which |  | ||||||
|           are reasonably necessary to implement that API, Contributor must |  | ||||||
|           also include this information in the LEGAL file. |  | ||||||
|  |  | ||||||
|                (c)    Representations. |  | ||||||
|           Contributor represents that, except as disclosed pursuant to |  | ||||||
|           Section 3.4(a) above, Contributor believes that Contributor's |  | ||||||
|           Modifications are Contributor's original creation(s) and/or |  | ||||||
|           Contributor has sufficient rights to grant the rights conveyed by |  | ||||||
|           this License. |  | ||||||
|  |  | ||||||
|      3.5. Required Notices. |  | ||||||
|      You must duplicate the notice in Exhibit A in each file of the Source |  | ||||||
|      Code.  If it is not possible to put such notice in a particular Source |  | ||||||
|      Code file due to its structure, then You must include such notice in a |  | ||||||
|      location (such as a relevant directory) where a user would be likely |  | ||||||
|      to look for such a notice.  If You created one or more Modification(s) |  | ||||||
|      You may add your name as a Contributor to the notice described in |  | ||||||
|      Exhibit A.  You must also duplicate this License in any documentation |  | ||||||
|      for the Source Code where You describe recipients' rights or ownership |  | ||||||
|      rights relating to Covered Code.  You may choose to offer, and to |  | ||||||
|      charge a fee for, warranty, support, indemnity or liability |  | ||||||
|      obligations to one or more recipients of Covered Code. However, You |  | ||||||
|      may do so only on Your own behalf, and not on behalf of the Initial |  | ||||||
|      Developer or any Contributor. You must make it absolutely clear than |  | ||||||
|      any such warranty, support, indemnity or liability obligation is |  | ||||||
|      offered by You alone, and You hereby agree to indemnify the Initial |  | ||||||
|      Developer and every Contributor for any liability incurred by the |  | ||||||
|      Initial Developer or such Contributor as a result of warranty, |  | ||||||
|      support, indemnity or liability terms You offer. |  | ||||||
|  |  | ||||||
|      3.6. Distribution of Executable Versions. |  | ||||||
|      You may distribute Covered Code in Executable form only if the |  | ||||||
|      requirements of Section 3.1-3.5 have been met for that Covered Code, |  | ||||||
|      and if You include a notice stating that the Source Code version of |  | ||||||
|      the Covered Code is available under the terms of this License, |  | ||||||
|      including a description of how and where You have fulfilled the |  | ||||||
|      obligations of Section 3.2. The notice must be conspicuously included |  | ||||||
|      in any notice in an Executable version, related documentation or |  | ||||||
|      collateral in which You describe recipients' rights relating to the |  | ||||||
|      Covered Code. You may distribute the Executable version of Covered |  | ||||||
|      Code or ownership rights under a license of Your choice, which may |  | ||||||
|      contain terms different from this License, provided that You are in |  | ||||||
|      compliance with the terms of this License and that the license for the |  | ||||||
|      Executable version does not attempt to limit or alter the recipient's |  | ||||||
|      rights in the Source Code version from the rights set forth in this |  | ||||||
|      License. If You distribute the Executable version under a different |  | ||||||
|      license You must make it absolutely clear that any terms which differ |  | ||||||
|      from this License are offered by You alone, not by the Initial |  | ||||||
|      Developer or any Contributor. You hereby agree to indemnify the |  | ||||||
|      Initial Developer and every Contributor for any liability incurred by |  | ||||||
|      the Initial Developer or such Contributor as a result of any such |  | ||||||
|      terms You offer. |  | ||||||
|  |  | ||||||
|      3.7. Larger Works. |  | ||||||
|      You may create a Larger Work by combining Covered Code with other code |  | ||||||
|      not governed by the terms of this License and distribute the Larger |  | ||||||
|      Work as a single product. In such a case, You must make sure the |  | ||||||
|      requirements of this License are fulfilled for the Covered Code. |  | ||||||
|  |  | ||||||
| 4. Inability to Comply Due to Statute or Regulation. |  | ||||||
|  |  | ||||||
|      If it is impossible for You to comply with any of the terms of this |  | ||||||
|      License with respect to some or all of the Covered Code due to |  | ||||||
|      statute, judicial order, or regulation then You must: (a) comply with |  | ||||||
|      the terms of this License to the maximum extent possible; and (b) |  | ||||||
|      describe the limitations and the code they affect. Such description |  | ||||||
|      must be included in the LEGAL file described in Section 3.4 and must |  | ||||||
|      be included with all distributions of the Source Code. Except to the |  | ||||||
|      extent prohibited by statute or regulation, such description must be |  | ||||||
|      sufficiently detailed for a recipient of ordinary skill to be able to |  | ||||||
|      understand it. |  | ||||||
|  |  | ||||||
| 5. Application of this License. |  | ||||||
|  |  | ||||||
|      This License applies to code to which the Initial Developer has |  | ||||||
|      attached the notice in Exhibit A and to related Covered Code. |  | ||||||
|  |  | ||||||
| 6. Versions of the License. |  | ||||||
|  |  | ||||||
|      6.1. New Versions. |  | ||||||
|      Netscape Communications Corporation ("Netscape") may publish revised |  | ||||||
|      and/or new versions of the License from time to time. Each version |  | ||||||
|      will be given a distinguishing version number. |  | ||||||
|  |  | ||||||
|      6.2. Effect of New Versions. |  | ||||||
|      Once Covered Code has been published under a particular version of the |  | ||||||
|      License, You may always continue to use it under the terms of that |  | ||||||
|      version. You may also choose to use such Covered Code under the terms |  | ||||||
|      of any subsequent version of the License published by Netscape. No one |  | ||||||
|      other than Netscape has the right to modify the terms applicable to |  | ||||||
|      Covered Code created under this License. |  | ||||||
|  |  | ||||||
|      6.3. Derivative Works. |  | ||||||
|      If You create or use a modified version of this License (which you may |  | ||||||
|      only do in order to apply it to code which is not already Covered Code |  | ||||||
|      governed by this License), You must (a) rename Your license so that |  | ||||||
|      the phrases "Mozilla", "MOZILLAPL", "MOZPL", "Netscape", |  | ||||||
|      "MPL", "NPL" or any confusingly similar phrase do not appear in your |  | ||||||
|      license (except to note that your license differs from this License) |  | ||||||
|      and (b) otherwise make it clear that Your version of the license |  | ||||||
|      contains terms which differ from the Mozilla Public License and |  | ||||||
|      Netscape Public License. (Filling in the name of the Initial |  | ||||||
|      Developer, Original Code or Contributor in the notice described in |  | ||||||
|      Exhibit A shall not of themselves be deemed to be modifications of |  | ||||||
|      this License.) |  | ||||||
|  |  | ||||||
| 7. DISCLAIMER OF WARRANTY. |  | ||||||
|  |  | ||||||
|      COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, |  | ||||||
|      WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, |  | ||||||
|      WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE IS FREE OF |  | ||||||
|      DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. |  | ||||||
|      THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE |  | ||||||
|      IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, |  | ||||||
|      YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE |  | ||||||
|      COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER |  | ||||||
|      OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF |  | ||||||
|      ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER. |  | ||||||
|  |  | ||||||
| 8. TERMINATION. |  | ||||||
|  |  | ||||||
|      8.1.  This License and the rights granted hereunder will terminate |  | ||||||
|      automatically if You fail to comply with terms herein and fail to cure |  | ||||||
|      such breach within 30 days of becoming aware of the breach. All |  | ||||||
|      sublicenses to the Covered Code which are properly granted shall |  | ||||||
|      survive any termination of this License. Provisions which, by their |  | ||||||
|      nature, must remain in effect beyond the termination of this License |  | ||||||
|      shall survive. |  | ||||||
|  |  | ||||||
|      8.2.  If You initiate litigation by asserting a patent infringement |  | ||||||
|      claim (excluding declatory judgment actions) against Initial Developer |  | ||||||
|      or a Contributor (the Initial Developer or Contributor against whom |  | ||||||
|      You file such action is referred to as "Participant")  alleging that: |  | ||||||
|  |  | ||||||
|      (a)  such Participant's Contributor Version directly or indirectly |  | ||||||
|      infringes any patent, then any and all rights granted by such |  | ||||||
|      Participant to You under Sections 2.1 and/or 2.2 of this License |  | ||||||
|      shall, upon 60 days notice from Participant terminate prospectively, |  | ||||||
|      unless if within 60 days after receipt of notice You either: (i) |  | ||||||
|      agree in writing to pay Participant a mutually agreeable reasonable |  | ||||||
|      royalty for Your past and future use of Modifications made by such |  | ||||||
|      Participant, or (ii) withdraw Your litigation claim with respect to |  | ||||||
|      the Contributor Version against such Participant.  If within 60 days |  | ||||||
|      of notice, a reasonable royalty and payment arrangement are not |  | ||||||
|      mutually agreed upon in writing by the parties or the litigation claim |  | ||||||
|      is not withdrawn, the rights granted by Participant to You under |  | ||||||
|      Sections 2.1 and/or 2.2 automatically terminate at the expiration of |  | ||||||
|      the 60 day notice period specified above. |  | ||||||
|  |  | ||||||
|      (b)  any software, hardware, or device, other than such Participant's |  | ||||||
|      Contributor Version, directly or indirectly infringes any patent, then |  | ||||||
|      any rights granted to You by such Participant under Sections 2.1(b) |  | ||||||
|      and 2.2(b) are revoked effective as of the date You first made, used, |  | ||||||
|      sold, distributed, or had made, Modifications made by that |  | ||||||
|      Participant. |  | ||||||
|  |  | ||||||
|      8.3.  If You assert a patent infringement claim against Participant |  | ||||||
|      alleging that such Participant's Contributor Version directly or |  | ||||||
|      indirectly infringes any patent where such claim is resolved (such as |  | ||||||
|      by license or settlement) prior to the initiation of patent |  | ||||||
|      infringement litigation, then the reasonable value of the licenses |  | ||||||
|      granted by such Participant under Sections 2.1 or 2.2 shall be taken |  | ||||||
|      into account in determining the amount or value of any payment or |  | ||||||
|      license. |  | ||||||
|  |  | ||||||
|      8.4.  In the event of termination under Sections 8.1 or 8.2 above, |  | ||||||
|      all end user license agreements (excluding distributors and resellers) |  | ||||||
|      which have been validly granted by You or any distributor hereunder |  | ||||||
|      prior to termination shall survive termination. |  | ||||||
|  |  | ||||||
| 9. LIMITATION OF LIABILITY. |  | ||||||
|  |  | ||||||
|      UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT |  | ||||||
|      (INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL |  | ||||||
|      DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED CODE, |  | ||||||
|      OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR |  | ||||||
|      ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY |  | ||||||
|      CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, |  | ||||||
|      WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER |  | ||||||
|      COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN |  | ||||||
|      INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF |  | ||||||
|      LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY |  | ||||||
|      RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW |  | ||||||
|      PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE |  | ||||||
|      EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO |  | ||||||
|      THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU. |  | ||||||
|  |  | ||||||
| 10. U.S. GOVERNMENT END USERS. |  | ||||||
|  |  | ||||||
|      The Covered Code is a "commercial item," as that term is defined in |  | ||||||
|      48 C.F.R. 2.101 (Oct. 1995), consisting of "commercial computer |  | ||||||
|      software" and "commercial computer software documentation," as such |  | ||||||
|      terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48 |  | ||||||
|      C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995), |  | ||||||
|      all U.S. Government End Users acquire Covered Code with only those |  | ||||||
|      rights set forth herein. |  | ||||||
|  |  | ||||||
| 11. MISCELLANEOUS. |  | ||||||
|  |  | ||||||
|      This License represents the complete agreement concerning subject |  | ||||||
|      matter hereof. If any provision of this License is held to be |  | ||||||
|      unenforceable, such provision shall be reformed only to the extent |  | ||||||
|      necessary to make it enforceable. This License shall be governed by |  | ||||||
|      California law provisions (except to the extent applicable law, if |  | ||||||
|      any, provides otherwise), excluding its conflict-of-law provisions. |  | ||||||
|      With respect to disputes in which at least one party is a citizen of, |  | ||||||
|      or an entity chartered or registered to do business in the United |  | ||||||
|      States of America, any litigation relating to this License shall be |  | ||||||
|      subject to the jurisdiction of the Federal Courts of the Northern |  | ||||||
|      District of California, with venue lying in Santa Clara County, |  | ||||||
|      California, with the losing party responsible for costs, including |  | ||||||
|      without limitation, court costs and reasonable attorneys' fees and |  | ||||||
|      expenses. The application of the United Nations Convention on |  | ||||||
|      Contracts for the International Sale of Goods is expressly excluded. |  | ||||||
|      Any law or regulation which provides that the language of a contract |  | ||||||
|      shall be construed against the drafter shall not apply to this |  | ||||||
|      License. |  | ||||||
|  |  | ||||||
| 12. RESPONSIBILITY FOR CLAIMS. |  | ||||||
|  |  | ||||||
|      As between Initial Developer and the Contributors, each party is |  | ||||||
|      responsible for claims and damages arising, directly or indirectly, |  | ||||||
|      out of its utilization of rights under this License and You agree to |  | ||||||
|      work with Initial Developer and Contributors to distribute such |  | ||||||
|      responsibility on an equitable basis. Nothing herein is intended or |  | ||||||
|      shall be deemed to constitute any admission of liability. |  | ||||||
|  |  | ||||||
| 13. MULTIPLE-LICENSED CODE. |  | ||||||
|  |  | ||||||
|      Initial Developer may designate portions of the Covered Code as |  | ||||||
|      "Multiple-Licensed".  "Multiple-Licensed" means that the Initial |  | ||||||
|      Developer permits you to utilize portions of the Covered Code under |  | ||||||
|      Your choice of the NPL or the alternative licenses, if any, specified |  | ||||||
|      by the Initial Developer in the file described in Exhibit A. |  | ||||||
|  |  | ||||||
| EXHIBIT A -Mozilla Public License. |  | ||||||
|  |  | ||||||
|      ``The contents of this file are subject to the Mozilla Public License |  | ||||||
|      Version 1.1 (the "License"); you may not use this file except in |  | ||||||
|      compliance with the License. You may obtain a copy of the License at |  | ||||||
|      http://www.mozilla.org/MPL/ |  | ||||||
|  |  | ||||||
|      Software distributed under the License is distributed on an "AS IS" |  | ||||||
|      basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the |  | ||||||
|      License for the specific language governing rights and limitations |  | ||||||
|      under the License. |  | ||||||
|  |  | ||||||
|      The Original Code is ______________________________________. |  | ||||||
|  |  | ||||||
|      The Initial Developer of the Original Code is ________________________. |  | ||||||
|      Portions created by ______________________ are Copyright (C) ______ |  | ||||||
|      _______________________. All Rights Reserved. |  | ||||||
|  |  | ||||||
|      Contributor(s): ______________________________________. |  | ||||||
|  |  | ||||||
|      Alternatively, the contents of this file may be used under the terms |  | ||||||
|      of the _____ license (the  "[___] License"), in which case the |  | ||||||
|      provisions of [______] License are applicable instead of those |  | ||||||
|      above.  If you wish to allow use of your version of this file only |  | ||||||
|      under the terms of the [____] License and not to allow others to use |  | ||||||
|      your version of this file under the MPL, indicate your decision by |  | ||||||
|      deleting  the provisions above and replace  them with the notice and |  | ||||||
|      other provisions required by the [___] License.  If you do not delete |  | ||||||
|      the provisions above, a recipient may use your version of this file |  | ||||||
|      under either the MPL or the [___] License." |  | ||||||
|  |  | ||||||
|      [NOTE: The text of this Exhibit A may differ slightly from the text of |  | ||||||
|      the notices in the Source Code files of the Original Code. You should |  | ||||||
|      use the text of this Exhibit A rather than the text found in the |  | ||||||
|      Original Code Source Code for Your Modifications.] |  | ||||||
|  |  | ||||||
							
								
								
									
										19
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -2,29 +2,34 @@ | |||||||
| # $Id$ | # $Id$ | ||||||
| # | # | ||||||
|  |  | ||||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | AUTOMAKE_OPTIONS = foreign | ||||||
|  |  | ||||||
| EXTRA_DIST =						\ | EXTRA_DIST = CHANGES COPYING maketgz SSLCERTS reconf Makefile.dist	\ | ||||||
| 	CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt	\ |   curl-config.in build_vms.com curl-style.el sample.emacs testcurl.sh | ||||||
| 	reconf Makefile.dist curl-config.in build_vms.com curl-mode.el \ |  | ||||||
| 	config-vms.h config-win32.h config-riscos.h config-mac.h |  | ||||||
|  |  | ||||||
| bin_SCRIPTS = curl-config | bin_SCRIPTS = curl-config | ||||||
|  |  | ||||||
| SUBDIRS = docs lib src include tests packages multi | SUBDIRS = docs lib src include tests packages | ||||||
|  |  | ||||||
| # create a root makefile in the distribution: | # create a root makefile in the distribution: | ||||||
| dist-hook: | dist-hook: | ||||||
|  | 	rm -rf $(top_builddir)/tests/log | ||||||
| 	cp $(srcdir)/Makefile.dist $(distdir)/Makefile | 	cp $(srcdir)/Makefile.dist $(distdir)/Makefile | ||||||
|  |  | ||||||
| html: | html: | ||||||
| 	cd docs; make html | 	cd docs; make html | ||||||
|  |  | ||||||
|  | pdf: | ||||||
|  | 	cd docs; make pdf | ||||||
|  |  | ||||||
| check: test | check: test | ||||||
|  |  | ||||||
| test: | test: | ||||||
| 	@(cd tests; $(MAKE) quiet-test) | 	@(cd tests; $(MAKE) quiet-test) | ||||||
|  |  | ||||||
|  | test-full: | ||||||
|  | 	@(cd tests; $(MAKE) full-test) | ||||||
|  |  | ||||||
| # | # | ||||||
| # Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros | # Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros | ||||||
| # must contain the following line: | # must contain the following line: | ||||||
| @@ -64,7 +69,7 @@ rpm: | |||||||
| pkgadd: | pkgadd: | ||||||
| 	umask 022 ; \ | 	umask 022 ; \ | ||||||
| 	make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \ | 	make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \ | ||||||
| 	cat LEGAL MITX.txt MPL-1.1.txt > $(srcdir)/packages/Solaris/copyright ; \ | 	cat COPYING > $(srcdir)/packages/Solaris/copyright ; \ | ||||||
| 	cd $(srcdir)/packages/Solaris && $(MAKE) package | 	cd $(srcdir)/packages/Solaris && $(MAKE) package | ||||||
|  |  | ||||||
| # | # | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| #                            | (__| |_| |  _ <| |___  | #                            | (__| |_| |  _ <| |___  | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 2002, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| # | # | ||||||
| # In order to be useful for every potential user, curl and libcurl are | # In order to be useful for every potential user, curl and libcurl are | ||||||
| # dual-licensed under the MPL and the MIT/X-derivate licenses. | # dual-licensed under the MPL and the MIT/X-derivate licenses. | ||||||
| @@ -34,12 +34,12 @@ borland: | |||||||
| 	cd src & make -f Makefile.b32 | 	cd src & make -f Makefile.b32 | ||||||
|  |  | ||||||
| mingw32: | mingw32: | ||||||
| 	cd lib & make -f Makefile.m32 | 	cd lib & make -f Makefile.m32 ZLIB=1 | ||||||
| 	cd src & make -f Makefile.m32 | 	cd src & make -f Makefile.m32 ZLIB=1 | ||||||
|  |  | ||||||
| mingw32-ssl: | mingw32-ssl: | ||||||
| 	cd lib & make -f Makefile.m32 SSL=1 | 	cd lib & make -f Makefile.m32 SSL=1 ZLIB=1 | ||||||
| 	cd src & make -f Makefile.m32 SSL=1 | 	cd src & make -f Makefile.m32 SSL=1 ZLIB=1 | ||||||
|  |  | ||||||
| vc: | vc: | ||||||
| 	cd lib | 	cd lib | ||||||
| @@ -51,6 +51,12 @@ vc-ssl: | |||||||
| 	cd lib | 	cd lib | ||||||
| 	nmake -f Makefile.vc6 cfg=release-ssl | 	nmake -f Makefile.vc6 cfg=release-ssl | ||||||
| 	cd ..\src | 	cd ..\src | ||||||
|  | 	nmake -f Makefile.vc6 cfg=release-ssl | ||||||
|  |  | ||||||
|  | vc-ssl-dll: | ||||||
|  | 	cd lib | ||||||
|  | 	nmake -f Makefile.vc6 cfg=release-ssl-dll | ||||||
|  | 	cd ..\src | ||||||
| 	nmake -f Makefile.vc6 | 	nmake -f Makefile.vc6 | ||||||
|  |  | ||||||
| cygwin: | cygwin: | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								README
									
									
									
									
									
								
							| @@ -11,23 +11,41 @@ README | |||||||
|   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. | ||||||
|  |  | ||||||
|   libcurl is a library that Curl is using to do its job. It is readily |   libcurl is the library curl is using to do its job. It is readily | ||||||
|   available to be used by your software. Read the libcurl.3 man page to |   available to be used by your software. Read the libcurl.3 man page to | ||||||
|   find out how! |   learn how! | ||||||
|  |  | ||||||
|   You find answers to the most frequent questions we get in the FAQ document. |   You find answers to the most frequent questions we get in the FAQ document. | ||||||
|  |  | ||||||
|   Study the LEGAL file for distribution terms and similar. |   Study the COPYING file for distribution terms and similar. | ||||||
|  |  | ||||||
|   Always try the Curl web site for the latest news: | CONTACT | ||||||
|  |  | ||||||
|         http://curl.haxx.se |   If you have problems, questions, ideas or suggestions, please contact us | ||||||
|  |   by posting to a suitable mailing list. See http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
|  |   Many major contributors to the project are listed in the THANKS document. | ||||||
|  |  | ||||||
|  | WEB SITE | ||||||
|  |  | ||||||
|  |   Visit the curl web site or mirrors for the latest news: | ||||||
|  |  | ||||||
|  |         Sweden    -- http://curl.haxx.se/ | ||||||
|  |         US        -- http://curl.sf.net/ | ||||||
|  |         Australia -- http://curl.planetmirror.com/ | ||||||
|  |  | ||||||
|  | DOWNLOAD | ||||||
|  |  | ||||||
|   The official download mirror sites are: |   The official download mirror sites are: | ||||||
|  |  | ||||||
|         Sweden    -- ftp://ftp.sunet.se/pub/www/utilities/curl/ |         Sweden    -- ftp://ftp.sunet.se/pub/www/utilities/curl/ | ||||||
|         Sweden    -- http://cool.haxx.se/curl/ |         Sweden    -- http://cool.haxx.se/curl/ | ||||||
|         Germany   -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/ |         Germany   -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/ | ||||||
|  |         Australia -- http://curl.planetmirror.com/download/ | ||||||
|  |         US        -- http://curl.sourceforge.net/download/ | ||||||
|  |         Hongkong  -- http://www.execve.net/curl/ | ||||||
|  |  | ||||||
|  | CVS | ||||||
|  |  | ||||||
|   To download the very latest source off the CVS server do this: |   To download the very latest source off the CVS server do this: | ||||||
|  |  | ||||||
| @@ -43,6 +61,8 @@ README | |||||||
|          |          | ||||||
|   (you're off the hook!) |   (you're off the hook!) | ||||||
|  |  | ||||||
|  | NOTICE | ||||||
|  |  | ||||||
|   Curl contains pieces of source code that is Copyright (c) 1998, 1999 |   Curl contains pieces of source code that is Copyright (c) 1998, 1999 | ||||||
|   Kungliga Tekniska H<>gskolan. This notice is included here to comply with the |   Kungliga Tekniska H<>gskolan. This notice is included here to comply with the | ||||||
|   distribution terms. |   distribution terms. | ||||||
|   | |||||||
							
								
								
									
										39
									
								
								SSLCERTS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								SSLCERTS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  |                       Peer SSL Certificate Verification | ||||||
|  |                       ================================= | ||||||
|  |  | ||||||
|  | Starting in 7.10, libcurl performs peer SSL certificate verification by | ||||||
|  | default. This is done by installing a default CA cert bundle on 'make install' | ||||||
|  | (or similar), that CA bundle package is used by default on operations against | ||||||
|  | SSL servers. | ||||||
|  |  | ||||||
|  | Alas, if you communicate with HTTPS servers using certificates that are signed | ||||||
|  | by CAs present in the bundle, you will not notice any changed behavior and you | ||||||
|  | will seamlessly get a higher security level on your SSL connections since you | ||||||
|  | can be sure that the remote server really is the one it claims to be. | ||||||
|  |  | ||||||
|  | If the remote server uses a self-signed certificate, or if you don't install | ||||||
|  | curl's CA cert bundle or if it uses a certificate signed by a CA that isn't | ||||||
|  | included in the bundle, then you need to do one of the following: | ||||||
|  |  | ||||||
|  |  1. Tell libcurl to *not* verify the peer. With libcurl you disable with with | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, FALSE); | ||||||
|  |  | ||||||
|  |     With the curl command tool, you disable this with -k/--insecure. | ||||||
|  |  | ||||||
|  |  2. Get a CA certificate that can verify the remote server and use the proper | ||||||
|  |     option to point out this CA cert for verification when connecting. For | ||||||
|  |     libcurl hackers: curl_easy_setopt(curl, CURLOPT_CAPATH, capath); | ||||||
|  |  | ||||||
|  |     With the curl command tool: --cacert [file] | ||||||
|  |  | ||||||
|  | Neglecting to use one of the above menthods when dealing with a server using a | ||||||
|  | certficate that isn't signed by one of the certficates in the installed CA | ||||||
|  | cert bundle, will cause SSL to report an error ("certificate verify failed") | ||||||
|  | during the handshake and SSL will then refuse further communication with that | ||||||
|  | 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. | ||||||
							
								
								
									
										66
									
								
								acconfig.h
									
									
									
									
									
								
							
							
						
						
									
										66
									
								
								acconfig.h
									
									
									
									
									
								
							| @@ -1,66 +0,0 @@ | |||||||
| /* Name of this package! */ |  | ||||||
| #undef PACKAGE |  | ||||||
|  |  | ||||||
| /* Version number of this archive. */ |  | ||||||
| #undef VERSION |  | ||||||
|  |  | ||||||
| /* Define if you have the getpass function.  */ |  | ||||||
| #undef HAVE_GETPASS |  | ||||||
|  |  | ||||||
| /* Define cpu-machine-OS */ |  | ||||||
| #undef OS |  | ||||||
|  |  | ||||||
| /* Define if you have the gethostbyaddr_r() function with 5 arguments */ |  | ||||||
| #undef HAVE_GETHOSTBYADDR_R_5 |  | ||||||
|  |  | ||||||
| /* Define if you have the gethostbyaddr_r() function with 7 arguments */ |  | ||||||
| #undef HAVE_GETHOSTBYADDR_R_7 |  | ||||||
|  |  | ||||||
| /* Define if you have the gethostbyaddr_r() function with 8 arguments */ |  | ||||||
| #undef HAVE_GETHOSTBYADDR_R_8 |  | ||||||
|  |  | ||||||
| /* Define if you have the gethostbyname_r() function with 3 arguments */ |  | ||||||
| #undef HAVE_GETHOSTBYNAME_R_3 |  | ||||||
|  |  | ||||||
| /* Define if you have the gethostbyname_r() function with 5 arguments */ |  | ||||||
| #undef HAVE_GETHOSTBYNAME_R_5 |  | ||||||
|  |  | ||||||
| /* Define if you have the gethostbyname_r() function with 6 arguments */ |  | ||||||
| #undef HAVE_GETHOSTBYNAME_R_6 |  | ||||||
|  |  | ||||||
| /* Define if you have the inet_ntoa_r function declared. */ |  | ||||||
| #undef HAVE_INET_NTOA_R_DECL |  | ||||||
|  |  | ||||||
| /* Define if you need the _REENTRANT define for some functions */ |  | ||||||
| #undef NEED_REENTRANT |  | ||||||
|  |  | ||||||
| /* Define if you have the Kerberos4 libraries (including -ldes) */ |  | ||||||
| #undef KRB4 |  | ||||||
|  |  | ||||||
| /* Define if you want to enable IPv6 support */ |  | ||||||
| #undef ENABLE_IPV6 |  | ||||||
|  |  | ||||||
| /* Define this to 'int' if ssize_t is not an available typedefed type */ |  | ||||||
| #undef ssize_t |  | ||||||
|  |  | ||||||
| /* Define this to 'int' if socklen_t is not an available typedefed type */ |  | ||||||
| #undef socklen_t |  | ||||||
|  |  | ||||||
| /* Define this as a suitable file to read random data from */ |  | ||||||
| #undef RANDOM_FILE |  | ||||||
|  |  | ||||||
| /* Define this to your Entropy Gathering Daemon socket pathname */ |  | ||||||
| #undef EGD_SOCKET |  | ||||||
|  |  | ||||||
| /* Define if you have a working OpenSSL installation */ |  | ||||||
| #undef OPENSSL_ENABLED |  | ||||||
|  |  | ||||||
| /* Define the one correct non-blocking socket method below */ |  | ||||||
| #undef HAVE_FIONBIO |  | ||||||
| #undef HAVE_IOCTLSOCKET |  | ||||||
| #undef HAVE_IOCTLSOCKET_CASE |  | ||||||
| #undef HAVE_O_NONBLOCK |  | ||||||
| #undef HAVE_DISABLED_NONBLOCKING |  | ||||||
|  |  | ||||||
| /* Define this to 'int' if in_addr_t is not an available typedefed type */ |  | ||||||
| #undef in_addr_t |  | ||||||
							
								
								
									
										42
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -38,7 +38,7 @@ AC_DEFUN(CURL_CHECK_NONBLOCKING_SOCKET, | |||||||
| ],[ | ],[ | ||||||
| dnl the O_NONBLOCK test was fine | dnl the O_NONBLOCK test was fine | ||||||
| nonblock="O_NONBLOCK" | nonblock="O_NONBLOCK" | ||||||
| AC_DEFINE(HAVE_O_NONBLOCK) | AC_DEFINE(HAVE_O_NONBLOCK, 1, [use O_NONBLOCK for non-blocking sockets]) | ||||||
| ],[ | ],[ | ||||||
| dnl the code was bad, try a different program now, test 2 | dnl the code was bad, try a different program now, test 2 | ||||||
|  |  | ||||||
| @@ -52,7 +52,7 @@ dnl the code was bad, try a different program now, test 2 | |||||||
| ],[ | ],[ | ||||||
| dnl FIONBIO test was good | dnl FIONBIO test was good | ||||||
| nonblock="FIONBIO" | nonblock="FIONBIO" | ||||||
| AC_DEFINE(HAVE_FIONBIO) | AC_DEFINE(HAVE_FIONBIO, 1, [use FIONBIO for non-blocking sockets]) | ||||||
| ],[ | ],[ | ||||||
| dnl FIONBIO test was also bad | dnl FIONBIO test was also bad | ||||||
| dnl the code was bad, try a different program now, test 3 | dnl the code was bad, try a different program now, test 3 | ||||||
| @@ -66,7 +66,7 @@ dnl the code was bad, try a different program now, test 3 | |||||||
| ],[ | ],[ | ||||||
| dnl ioctlsocket test was good | dnl ioctlsocket test was good | ||||||
| nonblock="ioctlsocket" | nonblock="ioctlsocket" | ||||||
| AC_DEFINE(HAVE_IOCTLSOCKET) | AC_DEFINE(HAVE_IOCTLSOCKET, 1, [use ioctlsocket() for non-blocking sockets]) | ||||||
| ],[ | ],[ | ||||||
| dnl ioctlsocket didnt compile! | dnl ioctlsocket didnt compile! | ||||||
|  |  | ||||||
| @@ -79,11 +79,11 @@ dnl ioctlsocket didnt compile! | |||||||
| ],[ | ],[ | ||||||
| dnl ioctlsocket test was good | dnl ioctlsocket test was good | ||||||
| nonblock="IoctlSocket" | nonblock="IoctlSocket" | ||||||
| AC_DEFINE(HAVE_IOCTLSOCKET_CASE) | AC_DEFINE(HAVE_IOCTLSOCKET_CASE, 1, [use Ioctlsocket() for non-blocking sockets]) | ||||||
| ],[ | ],[ | ||||||
| dnl ioctlsocket didnt compile! | dnl ioctlsocket didnt compile! | ||||||
| nonblock="nada" | nonblock="nada" | ||||||
| AC_DEFINE(HAVE_DISABLED_NONBLOCKING) | AC_DEFINE(HAVE_DISABLED_NONBLOCKING, 1, [disabled non-blocking sockets]) | ||||||
| ]) | ]) | ||||||
| dnl end of forth test | dnl end of forth test | ||||||
|  |  | ||||||
| @@ -152,10 +152,8 @@ AC_DEFUN([TYPE_IN_ADDR_T], | |||||||
|       AC_MSG_CHECKING([for in_addr_t equivalent]) |       AC_MSG_CHECKING([for in_addr_t equivalent]) | ||||||
|       AC_CACHE_VAL([curl_cv_in_addr_t_equiv], |       AC_CACHE_VAL([curl_cv_in_addr_t_equiv], | ||||||
|       [ |       [ | ||||||
|          # Systems have either "struct sockaddr *" or |  | ||||||
|          # "void *" as the second argument to getpeername |  | ||||||
|          curl_cv_in_addr_t_equiv= |          curl_cv_in_addr_t_equiv= | ||||||
|          for t in int size_t unsigned long "unsigned long"; do |          for t in "unsigned long" int size_t unsigned long; do | ||||||
|             AC_TRY_COMPILE([ |             AC_TRY_COMPILE([ | ||||||
|                #include <sys/types.h> |                #include <sys/types.h> | ||||||
|                #include <sys/socket.h> |                #include <sys/socket.h> | ||||||
| @@ -272,15 +270,15 @@ AC_DEFUN(CURL_CHECK_INET_NTOA_R, | |||||||
|     AC_MSG_CHECKING(whether inet_ntoa_r is declared) |     AC_MSG_CHECKING(whether inet_ntoa_r is declared) | ||||||
|     AC_EGREP_CPP(inet_ntoa_r,[ |     AC_EGREP_CPP(inet_ntoa_r,[ | ||||||
| #include <arpa/inet.h>],[ | #include <arpa/inet.h>],[ | ||||||
|       AC_DEFINE(HAVE_INET_NTOA_R_DECL) |       AC_DEFINE(HAVE_INET_NTOA_R_DECL, 1, [inet_ntoa_r() is declared]) | ||||||
|       AC_MSG_RESULT(yes)],[ |       AC_MSG_RESULT(yes)],[ | ||||||
|       AC_MSG_RESULT(no) |       AC_MSG_RESULT(no) | ||||||
|       AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared) |       AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared) | ||||||
|       AC_EGREP_CPP(inet_ntoa_r,[ |       AC_EGREP_CPP(inet_ntoa_r,[ | ||||||
| #define _REENTRANT | #define _REENTRANT | ||||||
| #include <arpa/inet.h>],[ | #include <arpa/inet.h>],[ | ||||||
| 	AC_DEFINE(HAVE_INET_NTOA_R_DECL) | 	AC_DEFINE(HAVE_INET_NTOA_R_DECL, 1, [inet_ntoa_r() is declared]) | ||||||
| 	AC_DEFINE(NEED_REENTRANT) | 	AC_DEFINE(NEED_REENTRANT, 1, [need REENTRANT defined]) | ||||||
| 	AC_MSG_RESULT(yes)], | 	AC_MSG_RESULT(yes)], | ||||||
| 	AC_MSG_RESULT(no))])]) | 	AC_MSG_RESULT(no))])]) | ||||||
| ]) | ]) | ||||||
| @@ -302,7 +300,7 @@ struct hostent_data hdata; | |||||||
| int rc; | int rc; | ||||||
| rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[ | rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[ | ||||||
|       AC_MSG_RESULT(yes) |       AC_MSG_RESULT(yes) | ||||||
|       AC_DEFINE(HAVE_GETHOSTBYADDR_R_5) |       AC_DEFINE(HAVE_GETHOSTBYADDR_R_5, 1, [gethostbyaddr_r() takes 5 args]) | ||||||
|       ac_cv_gethostbyaddr_args=5],[ |       ac_cv_gethostbyaddr_args=5],[ | ||||||
|       AC_MSG_RESULT(no) |       AC_MSG_RESULT(no) | ||||||
|       AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments) |       AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments) | ||||||
| @@ -318,8 +316,8 @@ struct hostent_data hdata; | |||||||
| int rc; | int rc; | ||||||
| rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[ | rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[ | ||||||
| 	AC_MSG_RESULT(yes) | 	AC_MSG_RESULT(yes) | ||||||
| 	AC_DEFINE(HAVE_GETHOSTBYADDR_R_5) | 	AC_DEFINE(HAVE_GETHOSTBYADDR_R_5, 1, [gethostbyaddr_r() takes 5 args]) | ||||||
| 	AC_DEFINE(NEED_REENTRANT) | 	AC_DEFINE(NEED_REENTRANT, 1, [need REENTRANT]) | ||||||
| 	ac_cv_gethostbyaddr_args=5],[ | 	ac_cv_gethostbyaddr_args=5],[ | ||||||
| 	AC_MSG_RESULT(no) | 	AC_MSG_RESULT(no) | ||||||
| 	AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments) | 	AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments) | ||||||
| @@ -337,7 +335,7 @@ struct hostent * hp; | |||||||
| hp = gethostbyaddr_r(address, length, type, &h, | hp = gethostbyaddr_r(address, length, type, &h, | ||||||
|                      buffer, 8192, &h_errnop);],[ |                      buffer, 8192, &h_errnop);],[ | ||||||
| 	  AC_MSG_RESULT(yes) | 	  AC_MSG_RESULT(yes) | ||||||
| 	  AC_DEFINE(HAVE_GETHOSTBYADDR_R_7) | 	  AC_DEFINE(HAVE_GETHOSTBYADDR_R_7, 1, [gethostbyaddr_r() takes 7 args] ) | ||||||
| 	  ac_cv_gethostbyaddr_args=7],[ | 	  ac_cv_gethostbyaddr_args=7],[ | ||||||
| 	  AC_MSG_RESULT(no) | 	  AC_MSG_RESULT(no) | ||||||
| 	  AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments) | 	  AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments) | ||||||
| @@ -356,7 +354,7 @@ int rc; | |||||||
| rc = gethostbyaddr_r(address, length, type, &h, | rc = gethostbyaddr_r(address, length, type, &h, | ||||||
|                      buffer, 8192, &hp, &h_errnop);],[ |                      buffer, 8192, &hp, &h_errnop);],[ | ||||||
| 	    AC_MSG_RESULT(yes) | 	    AC_MSG_RESULT(yes) | ||||||
| 	    AC_DEFINE(HAVE_GETHOSTBYADDR_R_8) | 	    AC_DEFINE(HAVE_GETHOSTBYADDR_R_8, 1, [gethostbyaddr_r() takes 8 args]) | ||||||
| 	    ac_cv_gethostbyaddr_args=8],[ | 	    ac_cv_gethostbyaddr_args=8],[ | ||||||
| 	    AC_MSG_RESULT(no) | 	    AC_MSG_RESULT(no) | ||||||
| 	    have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])]) | 	    have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])]) | ||||||
| @@ -377,9 +375,10 @@ AC_DEFUN(CURL_CHECK_GETHOSTBYNAME_R, | |||||||
|  |  | ||||||
| int | int | ||||||
| gethostbyname_r(const char *, struct hostent *, struct hostent_data *);],[ | gethostbyname_r(const char *, struct hostent *, struct hostent_data *);],[ | ||||||
|  | struct hostent_data data; | ||||||
| gethostbyname_r(NULL, NULL, NULL);],[ | gethostbyname_r(NULL, NULL, NULL);],[ | ||||||
|       AC_MSG_RESULT(yes) |       AC_MSG_RESULT(yes) | ||||||
|       AC_DEFINE(HAVE_GETHOSTBYNAME_R_3) |       AC_DEFINE(HAVE_GETHOSTBYNAME_R_3, 1, [gethostbyname_r() takes 3 args]) | ||||||
|       ac_cv_gethostbyname_args=3],[ |       ac_cv_gethostbyname_args=3],[ | ||||||
|       AC_MSG_RESULT(no) |       AC_MSG_RESULT(no) | ||||||
|       AC_MSG_CHECKING([if gethostbyname_r with -D_REENTRANT takes 3 arguments]) |       AC_MSG_CHECKING([if gethostbyname_r with -D_REENTRANT takes 3 arguments]) | ||||||
| @@ -394,10 +393,11 @@ gethostbyname_r(NULL, NULL, NULL);],[ | |||||||
|  |  | ||||||
| int | int | ||||||
| gethostbyname_r(const char *,struct hostent *, struct hostent_data *);],[ | gethostbyname_r(const char *,struct hostent *, struct hostent_data *);],[ | ||||||
|  | struct hostent_data data; | ||||||
| gethostbyname_r(NULL, NULL, NULL);],[ | gethostbyname_r(NULL, NULL, NULL);],[ | ||||||
| 	AC_MSG_RESULT(yes) | 	AC_MSG_RESULT(yes) | ||||||
| 	AC_DEFINE(HAVE_GETHOSTBYNAME_R_3) | 	AC_DEFINE(HAVE_GETHOSTBYNAME_R_3, 1, [gethostbyname_r() takes 3 args]) | ||||||
| 	AC_DEFINE(NEED_REENTRANT) | 	AC_DEFINE(NEED_REENTRANT, 1, [needs REENTRANT]) | ||||||
| 	ac_cv_gethostbyname_args=3],[ | 	ac_cv_gethostbyname_args=3],[ | ||||||
| 	AC_MSG_RESULT(no) | 	AC_MSG_RESULT(no) | ||||||
| 	AC_MSG_CHECKING([if gethostbyname_r takes 5 arguments]) | 	AC_MSG_CHECKING([if gethostbyname_r takes 5 arguments]) | ||||||
| @@ -411,7 +411,7 @@ struct hostent * | |||||||
| gethostbyname_r(const char *, struct hostent *, char *, int, int *);],[ | gethostbyname_r(const char *, struct hostent *, char *, int, int *);],[ | ||||||
| gethostbyname_r(NULL, NULL, NULL, 0, NULL);],[ | gethostbyname_r(NULL, NULL, NULL, 0, NULL);],[ | ||||||
| 	  AC_MSG_RESULT(yes) | 	  AC_MSG_RESULT(yes) | ||||||
| 	  AC_DEFINE(HAVE_GETHOSTBYNAME_R_5) | 	  AC_DEFINE(HAVE_GETHOSTBYNAME_R_5, 1, [gethostbyname_r() takes 5 args]) | ||||||
|           ac_cv_gethostbyname_args=5],[ |           ac_cv_gethostbyname_args=5],[ | ||||||
| 	  AC_MSG_RESULT(no) | 	  AC_MSG_RESULT(no) | ||||||
| 	  AC_MSG_CHECKING([if gethostbyname_r takes 6 arguments]) | 	  AC_MSG_CHECKING([if gethostbyname_r takes 6 arguments]) | ||||||
| @@ -426,7 +426,7 @@ gethostbyname_r(const char *, struct hostent *, char *, size_t, | |||||||
| struct hostent **, int *);],[ | struct hostent **, int *);],[ | ||||||
| gethostbyname_r(NULL, NULL, NULL, 0, NULL, NULL);],[ | gethostbyname_r(NULL, NULL, NULL, 0, NULL, NULL);],[ | ||||||
| 	    AC_MSG_RESULT(yes) | 	    AC_MSG_RESULT(yes) | ||||||
| 	    AC_DEFINE(HAVE_GETHOSTBYNAME_R_6) | 	    AC_DEFINE(HAVE_GETHOSTBYNAME_R_6, 1, [gethostbyname_r() takes 6 args]) | ||||||
|             ac_cv_gethostbyname_args=6],[ |             ac_cv_gethostbyname_args=6],[ | ||||||
| 	    AC_MSG_RESULT(no) | 	    AC_MSG_RESULT(no) | ||||||
| 	    have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"], | 	    have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"], | ||||||
|   | |||||||
							
								
								
									
										136
									
								
								build_vms.com
									
									
									
									
									
								
							
							
						
						
									
										136
									
								
								build_vms.com
									
									
									
									
									
								
							| @@ -1,67 +1,69 @@ | |||||||
| $! | $! | ||||||
| $ | $ | ||||||
| $	on control_y then goto Common_Exit! | $	on control_y then goto Common_Exit! | ||||||
| $	orig = f$environment("DEFAULT") | $	orig = f$environment("DEFAULT") | ||||||
| $	loc  = f$environment("PROCEDURE") | $	loc  = f$environment("PROCEDURE") | ||||||
| $	def = f$parse("X.X;1",loc) - "X.X;1" | $	def = f$parse("X.X;1",loc) - "X.X;1" | ||||||
| $ | $ | ||||||
| $	set def 'def' | $	set def 'def' | ||||||
| $	cc_qual = "/define=HAVE_CONFIG_H=1/include=(""../include/"",""../"")" | $	cc_qual = "/define=HAVE_CONFIG_H=1/include=(""../include/"",""../"",""../../openssl-0_9_7/include/"")" | ||||||
| $	if p1 .eqs. "LISTING" then cc_qual = cc_qual + "/LIST/MACHINE" | $	if p1 .eqs. "LISTING" then cc_qual = cc_qual + "/LIST/MACHINE" | ||||||
| $	if p1 .eqs. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG" | $	if p1 .eqs. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG" | ||||||
| $	msg_qual = "" | $	msg_qual = "" | ||||||
| $	call build "[.lib]" "*.c" | $	call build "[.lib]" "*.c" | ||||||
| $	call build "[.src]" "*.c" | $	call build "[.src]" "*.c" | ||||||
| $	call build "[.src]" "*.msg" | $	call build "[.src]" "*.msg" | ||||||
| $	link /exe=curl.exe [.src]curl/lib/include=main,[.lib]curl/lib | $	link /exe=curl.exe [.src]curl/lib/include=main,[.lib]curl/lib, - | ||||||
| $ | 		[-.openssl-0_9_7.axp.exe.ssl]libssl/lib, - | ||||||
| $ | 		[-.openssl-0_9_7.axp.exe.crypto]libcrypto/lib | ||||||
| $	goto Common_Exit | $ | ||||||
| $build:	subroutine | $ | ||||||
| $	set noon | $	goto Common_Exit | ||||||
| $	set default 'p1' | $build:	subroutine | ||||||
| $	search = p2 | $	set noon | ||||||
| $	reset = f$search("reset") | $	set default 'p1' | ||||||
| $	if f$search("CURL.OLB") .eqs. "" | $	search = p2 | ||||||
| $	then | $	reset = f$search("reset") | ||||||
| $		LIB/CREATE/OBJECT CURL.OLB | $	if f$search("CURL.OLB") .eqs. "" | ||||||
| $	endif | $	then | ||||||
| $	reset = f$search("reset",1) | $		LIB/CREATE/OBJECT CURL.OLB | ||||||
| $Loop: | $	endif | ||||||
| $	file = f$search(search,1) | $	reset = f$search("reset",1) | ||||||
| $	if file .eqs. "" then goto EndLoop | $Loop: | ||||||
| $		obj = f$search(f$parse(".OBJ;",file),2) | $	file = f$search(search,1) | ||||||
| $		if (obj .nes. "") | $	if file .eqs. "" then goto EndLoop | ||||||
| $		then | $		obj = f$search(f$parse(".OBJ;",file),2) | ||||||
| $			if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt"))) | $		if (obj .nes. "") | ||||||
| $			then | $		then | ||||||
| $				call compile 'file' | $			if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt"))) | ||||||
| $				lib/object curl.OLB 'f$parse(".obj;",file)' | $			then | ||||||
| $			else | $				call compile 'file' | ||||||
| $!				write sys$output "File: ''file' is up to date" | $				lib/object curl.OLB 'f$parse(".obj;",file)' | ||||||
| $			endif | $			else | ||||||
| $		else | $!				write sys$output "File: ''file' is up to date" | ||||||
| $!			write sys$output "Object for file: ''file' does not exist" | $			endif | ||||||
| $			call compile 'file' | $		else | ||||||
| $			lib/object curl.OLB 'f$parse(".obj;",file)' | $!			write sys$output "Object for file: ''file' does not exist" | ||||||
| $		endif | $			call compile 'file' | ||||||
| $	goto Loop | $			lib/object curl.OLB 'f$parse(".obj;",file)' | ||||||
| $EndLoop: | $		endif | ||||||
| $	purge | $	goto Loop | ||||||
| $	set def 'def' | $EndLoop: | ||||||
| $	endsubroutine	! Build | $	purge | ||||||
| $ | $	set def 'def' | ||||||
| $compile:	subroutine | $	endsubroutine	! Build | ||||||
| $	set noon | $ | ||||||
| $	file = p1 | $compile:	subroutine | ||||||
| $	qual = p2+p3+p4+p5+p6+p7+p8 | $	set noon | ||||||
| $	typ = f$parse(file,,,"TYPE") - "." | $	file = p1 | ||||||
| $	cmd_c = "CC "+cc_qual | $	qual = p2+p3+p4+p5+p6+p7+p8 | ||||||
| $	cmd_msg = "MESSAGE "+msg_qual | $	typ = f$parse(file,,,"TYPE") - "." | ||||||
| $	x = cmd_'typ' | $	cmd_c = "CC "+cc_qual | ||||||
| $	'x' 'file' | $	cmd_msg = "MESSAGE "+msg_qual | ||||||
| $	ENDSUBROUTINE	! Compile | $	x = cmd_'typ' | ||||||
| $ | $	'x' 'file' | ||||||
| $Common_Exit: | $	ENDSUBROUTINE	! Compile | ||||||
| $	set default 'orig' | $ | ||||||
| $	exit | $Common_Exit: | ||||||
|  | $	set default 'orig' | ||||||
|  | $	exit | ||||||
|   | |||||||
							
								
								
									
										126
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										126
									
								
								buildconf
									
									
									
									
									
								
							| @@ -5,7 +5,125 @@ die(){ | |||||||
| 	exit | 	exit | ||||||
| } | } | ||||||
|  |  | ||||||
| aclocal           || die "The command 'aclocal' failed" | #-------------------------------------------------------------------------- | ||||||
| autoheader        || die "The command 'autoheader' failed" | # autoconf 2.57 or newer | ||||||
| autoconf          || die "The command 'autoconf' failed" | # | ||||||
| automake          || die "The command 'automake $MAKEFILES' failed" | need_autoconf="2.57" | ||||||
|  | ac_version=`${AUTOCONF:-autoconf} --version 2>/dev/null|head -1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||||
|  | if test -z "$ac_version"; then | ||||||
|  |   echo "buildconf: autoconf not found." | ||||||
|  |   echo "            You need autoconf version $need_autoconf or newer installed." | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  | IFS=.; set $ac_version; IFS=' ' | ||||||
|  | if test "$1" = "2" -a "$2" -lt "57" || test "$1" -lt "2"; then | ||||||
|  |   echo "buildconf: autoconf version $ac_version found." | ||||||
|  |   echo "            You need autoconf version $need_autoconf or newer installed." | ||||||
|  |   echo "            If you have a sufficient autoconf installed, but it" | ||||||
|  |   echo "            is not named 'autoconf', then try setting the" | ||||||
|  |   echo "            AUTOCONF environment variable." | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | echo "buildconf: autoconf version $ac_version (ok)" | ||||||
|  |  | ||||||
|  | #-------------------------------------------------------------------------- | ||||||
|  | # autoheader 2.50 or newer | ||||||
|  | # | ||||||
|  | ah_version=`${AUTOHEADER:-autoheader} --version 2>/dev/null|head -1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||||
|  | if test -z "$ah_version"; then | ||||||
|  |   echo "buildconf: autoheader not found." | ||||||
|  |   echo "            You need autoheader version 2.50 or newer installed." | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  | IFS=.; set $ah_version; IFS=' ' | ||||||
|  | if test "$1" = "2" -a "$2" -lt "50" || test "$1" -lt "2"; then | ||||||
|  |   echo "buildconf: autoheader version $ah_version found." | ||||||
|  |   echo "            You need autoheader version 2.50 or newer installed." | ||||||
|  |   echo "            If you have a sufficient autoheader installed, but it" | ||||||
|  |   echo "            is not named 'autoheader', then try setting the" | ||||||
|  |   echo "            AUTOHEADER environment variable." | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | echo "buildconf: autoheader version $ah_version (ok)" | ||||||
|  |  | ||||||
|  | #-------------------------------------------------------------------------- | ||||||
|  | # automake 1.7 or newer | ||||||
|  | # | ||||||
|  | need_automake="1.7" | ||||||
|  | am_version=`${AUTOMAKE:-automake} --version 2>/dev/null|head -1| sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//'` | ||||||
|  | if test -z "$am_version"; then | ||||||
|  |   echo "buildconf: automake not found." | ||||||
|  |   echo "            You need automake version $need_automake or newer installed." | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  | IFS=.; set $am_version; IFS=' ' | ||||||
|  | if test "$1" = "1" -a "$2" -lt "7" || test "$1" -lt "1"; then | ||||||
|  |   echo "buildconf: automake version $am_version found." | ||||||
|  |   echo "            You need automake version $need_automake or newer installed." | ||||||
|  |   echo "            If you have a sufficient automake installed, but it" | ||||||
|  |   echo "            is not named 'autommake', then try setting the" | ||||||
|  |   echo "            AUTOMAKE environment variable." | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | echo "buildconf: automake version $am_version (ok)" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #-------------------------------------------------------------------------- | ||||||
|  | # libtool check | ||||||
|  | # | ||||||
|  | LIBTOOL_WANTED_MAJOR=1 | ||||||
|  | LIBTOOL_WANTED_MINOR=4 | ||||||
|  | LIBTOOL_WANTED_PATCH=2 | ||||||
|  | LIBTOOL_WANTED_VERSION=1.4.2 | ||||||
|  |  | ||||||
|  | libtool=`which glibtool 2>/dev/null` | ||||||
|  | if test ! -x "$libtool"; then | ||||||
|  |   libtool=`which libtool` | ||||||
|  | fi | ||||||
|  | #lt_pversion=`${LIBTOOL:-$libtool} --version 2>/dev/null|head -1| sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//'` | ||||||
|  | lt_pversion=`$libtool --version 2>/dev/null|head -1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | ||||||
|  | if test -z "$lt_pversion"; then | ||||||
|  |   echo "buildconf: libtool not found." | ||||||
|  |   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  | lt_version=`echo $lt_pversion` #|sed -e 's/\([a-z]*\)$/.\1/'` | ||||||
|  | IFS=.; set $lt_version; IFS=' ' | ||||||
|  | lt_status="good" | ||||||
|  | if test "$1" = "$LIBTOOL_WANTED_MAJOR"; then | ||||||
|  |    if test "$2" -lt "$LIBTOOL_WANTED_MINOR"; then | ||||||
|  |       lt_status="bad" | ||||||
|  |    elif test ! -z "$LIBTOOL_WANTED_PATCH"; then | ||||||
|  |        if test -n "$3"; then | ||||||
|  |           if test "$3" -lt "$LIBTOOL_WANTED_PATCH"; then | ||||||
|  |              lt_status="bad" | ||||||
|  |           fi | ||||||
|  |        fi | ||||||
|  |    fi | ||||||
|  | fi | ||||||
|  | if test $lt_status != "good"; then | ||||||
|  |   echo "buildconf: libtool version $lt_pversion found." | ||||||
|  |   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | echo "buildconf: libtool version $lt_version (ok)" | ||||||
|  |  | ||||||
|  | # ------------------------------------------------------------ | ||||||
|  |  | ||||||
|  | # run the correct scripts now | ||||||
|  |  | ||||||
|  | echo "buildconf: running libtoolize" | ||||||
|  | ${LIBTOOLIZE:-libtoolize} --copy --automake || die "The command '${LIBTOOLIZE:-libtoolize}  --copy --automake' failed" | ||||||
|  | echo "buildconf: running aclocal" | ||||||
|  | ${ACLOCAL:-aclocal}       || die "The command '${AUTOHEADER:-aclocal}' failed" | ||||||
|  | echo "buildconf: running autoheader" | ||||||
|  | ${AUTOHEADER:-autoheader} || die "The command '${AUTOHEADER:-autoheader}' failed" | ||||||
|  | echo "buildconf: running autoconf" | ||||||
|  | ${AUTOCONF:-autoconf}     || die "The command '${AUTOCONF:-autoconf}' failed" | ||||||
|  | echo "buildconf: running automake" | ||||||
|  | ${AUTOMAKE:-automake} -a  || die "The command '${AUTOMAKE:-automake} -a' failed" | ||||||
|  | exit 0 | ||||||
|   | |||||||
| @@ -1,25 +0,0 @@ | |||||||
|  |  | ||||||
| #define socklen_t int |  | ||||||
|  |  | ||||||
| #define HAVE_SYS_SOCKET_H |  | ||||||
| #define HAVE_ARPA_INET_H |  | ||||||
| #define HAVE_SYS_SELECT_H |  | ||||||
| #define HAVE_FCNTL_H |  | ||||||
| #define HAVE_GETTIMEOFDAY |  | ||||||
|  |  | ||||||
| #define HAVE_SELECT |  | ||||||
| #define HAVE_SOCKET |  | ||||||
| #define ifr_dstaddr ifr_addr |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <sys/socket.h> |  | ||||||
| #include <sys/if.h> |  | ||||||
| #include <sys/fcntl.h> |  | ||||||
| #include <sys/ioctl.h> |  | ||||||
| #include <netinet/in.h> |  | ||||||
| #include <netdb.h> |  | ||||||
|  |  | ||||||
| #define ioctl(a,b,c,d) (ioctl(a,b,c) * (d==d)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #define OS "RISC OS" |  | ||||||
							
								
								
									
										1317
									
								
								config.guess
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1317
									
								
								config.guess
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1411
									
								
								config.sub
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1411
									
								
								config.sub
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										921
									
								
								configure.ac
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										921
									
								
								configure.ac
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,921 @@ | |||||||
|  | dnl $Id$ | ||||||
|  | dnl Process this file with autoconf to produce a configure script. | ||||||
|  |  | ||||||
|  | dnl Ensure that this file is processed with autoconf 2.50 or newer | ||||||
|  | dnl Don't even think about removing this check! | ||||||
|  | AC_PREREQ(2.50) | ||||||
|  |  | ||||||
|  | dnl We don't know the version number "staticly" so we use a dash here | ||||||
|  | AC_INIT(curl, [-], [curl-bug@haxx.se]) | ||||||
|  |  | ||||||
|  | dnl configure script copyright | ||||||
|  | AC_COPYRIGHT([Copyright (c) 1998 - 2003 Daniel Stenberg, <daniel@haxx.se> | ||||||
|  | This configure script may be copied, distributed and modified under the  | ||||||
|  | terms of the curl license; see COPYING for more details]) | ||||||
|  |  | ||||||
|  | AC_CONFIG_SRCDIR([lib/urldata.h]) | ||||||
|  | AM_CONFIG_HEADER(lib/config.h src/config.h tests/server/config.h lib/ca-bundle.h) | ||||||
|  | AM_MAINTAINER_MODE | ||||||
|  |  | ||||||
|  | AC_PATH_PROG( SED, sed, , $PATH:/usr/bin:/usr/local/bin) | ||||||
|  | AC_SUBST(SED) | ||||||
|  |  | ||||||
|  | dnl figure out the libcurl version | ||||||
|  | VERSION=`$SED -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h` | ||||||
|  | AM_INIT_AUTOMAKE(curl,$VERSION) | ||||||
|  | AC_MSG_CHECKING([curl version]) | ||||||
|  | AC_MSG_RESULT($VERSION) | ||||||
|  |  | ||||||
|  | dnl | ||||||
|  | dnl we extract the numerical version for curl-config only | ||||||
|  | VERSIONNUM=`$SED -ne 's/^#define LIBCURL_VERSION_NUM 0x\(.*\)/\1/p' ${srcdir}/include/curl/curl.h` | ||||||
|  | AC_SUBST(VERSIONNUM) | ||||||
|  |  | ||||||
|  | dnl Solaris pkgadd support definitions | ||||||
|  | PKGADD_PKG="HAXXcurl" | ||||||
|  | PKGADD_NAME="cURL - a client that groks URLs" | ||||||
|  | PKGADD_VENDOR="curl.haxx.se" | ||||||
|  | AC_SUBST(PKGADD_PKG) | ||||||
|  | AC_SUBST(PKGADD_NAME) | ||||||
|  | AC_SUBST(PKGADD_VENDOR) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl | ||||||
|  | dnl Detect the canonical host and target build environment | ||||||
|  | dnl | ||||||
|  |  | ||||||
|  | AC_CANONICAL_HOST | ||||||
|  | dnl Get system canonical name | ||||||
|  | AC_DEFINE_UNQUOTED(OS, "${host}", [cpu-machine-OS]) | ||||||
|  |  | ||||||
|  | dnl Check for AIX weirdos | ||||||
|  | AC_AIX | ||||||
|  |  | ||||||
|  | dnl Checks for programs. | ||||||
|  | AC_PROG_CC | ||||||
|  |  | ||||||
|  | dnl check for how to do large files | ||||||
|  | AC_SYS_LARGEFILE | ||||||
|  |  | ||||||
|  | dnl check for cygwin stuff | ||||||
|  | AC_LIBTOOL_WIN32_DLL | ||||||
|  |  | ||||||
|  | dnl libtool setup | ||||||
|  | AM_PROG_LIBTOOL | ||||||
|  |  | ||||||
|  | case $host in | ||||||
|  |   *-*-cygwin | *-*-mingw* | *-*-pw32*) | ||||||
|  |     need_no_undefined=yes | ||||||
|  |     ;; | ||||||
|  |   *) | ||||||
|  |     need_no_undefined=no | ||||||
|  |     ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||||
|  |  | ||||||
|  | dnl The install stuff has already been taken care of by the automake stuff | ||||||
|  | dnl AC_PROG_INSTALL | ||||||
|  | AC_PROG_MAKE_SET | ||||||
|  |  | ||||||
|  | dnl ************************************************************ | ||||||
|  | dnl switch off particular protocols | ||||||
|  | dnl | ||||||
|  | AC_MSG_CHECKING([whether to support http]) | ||||||
|  | AC_ARG_ENABLE(http, | ||||||
|  | AC_HELP_STRING([--enable-http],[Enable HTTP support]) | ||||||
|  | AC_HELP_STRING([--disable-http],[Disable HTTP support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_HTTP, 1, [to disable HTTP]) | ||||||
|  |        AC_MSG_WARN([disable HTTP disables FTP over proxy and GOPHER too]) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable GOPHER]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_HTTP) | ||||||
|  |        AC_SUBST(CURL_DISABLE_GOPHER) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  | AC_MSG_CHECKING([whether to support ftp]) | ||||||
|  | AC_ARG_ENABLE(ftp, | ||||||
|  | AC_HELP_STRING([--enable-ftp],[Enable FTP support]) | ||||||
|  | AC_HELP_STRING([--disable-ftp],[Disable FTP support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_FTP, 1, [to disable FTP]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_FTP) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  | AC_MSG_CHECKING([whether to support gopher]) | ||||||
|  | AC_ARG_ENABLE(gopher, | ||||||
|  | AC_HELP_STRING([--enable-gopher],[Enable GOPHER support]) | ||||||
|  | AC_HELP_STRING([--disable-gopher],[Disable GOPHER support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable GOPHER]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_GOPHER) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  | AC_MSG_CHECKING([whether to support file]) | ||||||
|  | AC_ARG_ENABLE(file, | ||||||
|  | AC_HELP_STRING([--enable-file],[Enable FILE support]) | ||||||
|  | AC_HELP_STRING([--disable-file],[Disable FILE support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_FILE, 1, [to disable FILE]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_FILE) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  | AC_MSG_CHECKING([whether to support ldap]) | ||||||
|  | AC_ARG_ENABLE(ldap, | ||||||
|  | AC_HELP_STRING([--enable-ldap],[Enable LDAP support]) | ||||||
|  | AC_HELP_STRING([--disable-ldap],[Disable LDAP support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_LDAP) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  | AC_MSG_CHECKING([whether to support dict]) | ||||||
|  | AC_ARG_ENABLE(dict, | ||||||
|  | AC_HELP_STRING([--enable-dict],[Enable DICT support]) | ||||||
|  | AC_HELP_STRING([--disable-dict],[Disable DICT support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_DICT, 1, [to disable DICT]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_DICT) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  | AC_MSG_CHECKING([whether to support telnet]) | ||||||
|  | AC_ARG_ENABLE(telnet, | ||||||
|  | AC_HELP_STRING([--enable-telnet],[Enable TELNET support]) | ||||||
|  | AC_HELP_STRING([--disable-telnet],[Disable TELNET support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        AC_DEFINE(CURL_DISABLE_TELNET, 1, [to disable TELNET]) | ||||||
|  |        AC_SUBST(CURL_DISABLE_TELNET) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Checks for IPv6 | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | AC_MSG_CHECKING([whether to enable ipv6]) | ||||||
|  | AC_ARG_ENABLE(ipv6, | ||||||
|  | AC_HELP_STRING([--enable-ipv6],[Enable ipv6 (with ipv4) support]) | ||||||
|  | AC_HELP_STRING([--disable-ipv6],[Disable ipv6 support]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        ipv6=no | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |        ipv6=yes | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |  | ||||||
|  |   AC_TRY_RUN([ /* is AF_INET6 available? */ | ||||||
|  | #include <sys/types.h> | ||||||
|  | #include <sys/socket.h> | ||||||
|  | main() | ||||||
|  | { | ||||||
|  |  if (socket(AF_INET6, SOCK_STREAM, 0) < 0) | ||||||
|  |    exit(1); | ||||||
|  |  else | ||||||
|  |    exit(0); | ||||||
|  | } | ||||||
|  | ], | ||||||
|  |   AC_MSG_RESULT(yes) | ||||||
|  |   ipv6=yes, | ||||||
|  |   AC_MSG_RESULT(no) | ||||||
|  |   ipv6=no, | ||||||
|  |   AC_MSG_RESULT(no) | ||||||
|  |   ipv6=no | ||||||
|  | )) | ||||||
|  |  | ||||||
|  | if test "$ipv6" = "yes"; then | ||||||
|  |   CURL_CHECK_WORKING_GETADDRINFO | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Checks for libraries. | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | dnl gethostbyname in the nsl lib? | ||||||
|  | AC_CHECK_FUNC(gethostbyname, , [ AC_CHECK_LIB(nsl, gethostbyname) ]) | ||||||
|  |  | ||||||
|  | if test "$ac_cv_lib_nsl_gethostbyname" != "yes" -a "$ac_cv_func_gethostbyname" != "yes"; then | ||||||
|  |   dnl gethostbyname in the socket lib? | ||||||
|  |   AC_CHECK_FUNC(gethostbyname, , [ AC_CHECK_LIB(socket, gethostbyname) ]) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | dnl At least one system has been identified to require BOTH nsl and | ||||||
|  | dnl socket libs to link properly. | ||||||
|  | if test "$ac_cv_lib_nsl_gethostbyname" = "$ac_cv_func_gethostbyname"; then | ||||||
|  |   AC_MSG_CHECKING([trying both nsl and socket libs]) | ||||||
|  |   my_ac_save_LIBS=$LIBS | ||||||
|  |   LIBS="-lnsl -lsocket $LIBS" | ||||||
|  |   AC_TRY_LINK( , | ||||||
|  |              [gethostbyname();], | ||||||
|  |              my_ac_link_result=success, | ||||||
|  |              my_ac_link_result=failure ) | ||||||
|  |  | ||||||
|  |   if test "$my_ac_link_result" = "failure"; then | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     AC_MSG_ERROR([couldn't find libraries for gethostbyname()]) | ||||||
|  |     dnl restore LIBS | ||||||
|  |     LIBS=$my_ac_save_LIBS | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |   fi | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | dnl resolve lib? | ||||||
|  | AC_CHECK_FUNC(strcasecmp, , [ AC_CHECK_LIB(resolve, strcasecmp) ]) | ||||||
|  |  | ||||||
|  | if test "$ac_cv_lib_resolve_strcasecmp" = "$ac_cv_func_strcasecmp"; then | ||||||
|  |   AC_CHECK_LIB(resolve, strcasecmp, | ||||||
|  |               [LIBS="-lresolve $LIBS"], | ||||||
|  |                , | ||||||
|  |                -lnsl) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | dnl socket lib? | ||||||
|  | AC_CHECK_FUNC(connect, , [ AC_CHECK_LIB(socket, connect) ]) | ||||||
|  |  | ||||||
|  | dnl dl lib? | ||||||
|  | AC_CHECK_FUNC(dlclose, , [ AC_CHECK_LIB(dl, dlopen) ]) | ||||||
|  |  | ||||||
|  | AC_MSG_CHECKING([whether to use libgcc]) | ||||||
|  | AC_ARG_ENABLE(libgcc, | ||||||
|  | AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   yes) | ||||||
|  |         LIBS="$LIBS -lgcc" | ||||||
|  |        AC_MSG_RESULT(yes) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(no) | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check how non-blocking sockets are set | ||||||
|  | dnl ********************************************************************** | ||||||
|  | AC_ARG_ENABLE(nonblocking, | ||||||
|  | AC_HELP_STRING([--enable-nonblocking],[Enable detecting how to do it]) | ||||||
|  | AC_HELP_STRING([--disable-nonblocking],[Disable non-blocking socket detection]), | ||||||
|  | [ | ||||||
|  |   if test "$enableval" = "no" ; then | ||||||
|  |     AC_MSG_WARN([non-blocking sockets disabled]) | ||||||
|  |     AC_DEFINE(HAVE_DISABLED_NONBLOCKING, 1, | ||||||
|  |     [to disable NON-BLOCKING connections]) | ||||||
|  |   else | ||||||
|  |     CURL_CHECK_NONBLOCKING_SOCKET | ||||||
|  |   fi | ||||||
|  | ], | ||||||
|  | [ | ||||||
|  |   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 Check if the operating system allows programs to write to their own argv[] | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | AC_MSG_CHECKING([if argv can be written to]) | ||||||
|  | AC_RUN_IFELSE([[ | ||||||
|  | int main(int argc, char ** argv) { | ||||||
|  | 	argv[0][0] = ' '; | ||||||
|  | 	return (argv[0][0] == ' ')?0:1; | ||||||
|  | } | ||||||
|  | 	]], | ||||||
|  | 	AC_DEFINE(HAVE_WRITABLE_ARGV, 1, [Define this symbol if your OS supports changing the contents of argv]) | ||||||
|  | 	AC_MSG_RESULT(yes), | ||||||
|  | 	AC_MSG_RESULT(no), | ||||||
|  |         AC_MSG_RESULT(no) | ||||||
|  |         AC_MSG_WARN([the previous check could not be made default was used]) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check for the presence of Kerberos4 libraries and headers | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | AC_ARG_WITH(krb4-includes, | ||||||
|  | AC_HELP_STRING([--with-krb4-includes=DIR], | ||||||
|  |                [Specify location of kerberos4 headers]),[ | ||||||
|  |  CPPFLAGS="$CPPFLAGS -I$withval" | ||||||
|  |  KRB4INC="$withval" | ||||||
|  |  want_krb4=yes | ||||||
|  |  ]) | ||||||
|  |  | ||||||
|  | AC_ARG_WITH(krb4-libs, | ||||||
|  | AC_HELP_STRING([--with-krb4-libs=DIR],[Specify location of kerberos4 libs]),[ | ||||||
|  |  LDFLAGS="$LDFLAGS -L$withval" | ||||||
|  |  KRB4LIB="$withval" | ||||||
|  |  want_krb4=yes | ||||||
|  |  ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | OPT_KRB4=off | ||||||
|  | AC_ARG_WITH(krb4,dnl | ||||||
|  | AC_HELP_STRING([--with-krb4=DIR],[where to look for Kerberos4]),[ | ||||||
|  |   OPT_KRB4="$withval" | ||||||
|  |   if test X"$OPT_KRB4" != Xyes | ||||||
|  |   then | ||||||
|  |     LDFLAGS="$LDFLAGS -L$OPT_KRB4/lib" | ||||||
|  |     KRB4LIB="$OPT_KRB4/lib" | ||||||
|  |     CPPFLAGS="$CPPFLAGS -I$OPT_KRB4/include" | ||||||
|  |     KRB4INC="$OPT_KRB4/include" | ||||||
|  |   fi | ||||||
|  |   want_krb4="yes" | ||||||
|  |  ]) | ||||||
|  |  | ||||||
|  | AC_MSG_CHECKING([if Kerberos4 support is requested]) | ||||||
|  |  | ||||||
|  | if test "$want_krb4" = yes | ||||||
|  | then | ||||||
|  |   if test "$ipv6" = "yes"; then | ||||||
|  |     echo krb4 is not compatible with IPv6 | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  |   AC_MSG_RESULT(yes) | ||||||
|  |  | ||||||
|  |   dnl Check for & handle argument to --with-krb4 | ||||||
|  |  | ||||||
|  |   AC_MSG_CHECKING(where to look for Kerberos4) | ||||||
|  |   if test X"$OPT_KRB4" = Xyes | ||||||
|  |   then | ||||||
|  |     AC_MSG_RESULT([defaults]) | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([libs in $KRB4LIB, headers in $KRB4INC]) | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  |   dnl Check for DES library | ||||||
|  |   AC_CHECK_LIB(des, des_pcbc_encrypt, | ||||||
|  |   [ | ||||||
|  |     AC_CHECK_HEADERS(des.h) | ||||||
|  |  | ||||||
|  |     dnl resolv lib? | ||||||
|  |     AC_CHECK_FUNC(res_search, , [AC_CHECK_LIB(resolv, res_search)]) | ||||||
|  |  | ||||||
|  |     dnl Check for the Kerberos4 library | ||||||
|  |     AC_CHECK_LIB(krb, krb_net_read, | ||||||
|  |     [ | ||||||
|  |       dnl Check for header files | ||||||
|  |       AC_CHECK_HEADERS(krb.h) | ||||||
|  |  | ||||||
|  |       dnl we found the required libraries, add to LIBS | ||||||
|  |       LIBS="-lkrb -ldes $LIBS" | ||||||
|  |  | ||||||
|  |       dnl Check for function krb_get_our_ip_for_realm | ||||||
|  |       dnl this is needed for NAT networks | ||||||
|  |       AC_CHECK_FUNCS(krb_get_our_ip_for_realm) | ||||||
|  |  | ||||||
|  |       dnl add define KRB4 | ||||||
|  |       AC_DEFINE(KRB4, 1, | ||||||
|  |       [if you have the Kerberos4 libraries (including -ldes)]) | ||||||
|  |  | ||||||
|  |       dnl substitute it too! | ||||||
|  |       KRB4_ENABLED=1 | ||||||
|  |       AC_SUBST(KRB4_ENABLED) | ||||||
|  |  | ||||||
|  |       dnl the krb4 stuff needs a strlcpy() | ||||||
|  |       AC_CHECK_FUNCS(strlcpy) | ||||||
|  |  | ||||||
|  |     ]) | ||||||
|  |   ]) | ||||||
|  | else | ||||||
|  |   AC_MSG_RESULT(no) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | 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) | ||||||
|  | if test "$PKGCONFIG" != "no" ; then | ||||||
|  |   AC_MSG_CHECKING([for OpenSSL options using pkg-config]) | ||||||
|  |  | ||||||
|  |   $PKGCONFIG --exists openssl | ||||||
|  |   SSL_EXISTS=$? | ||||||
|  |  | ||||||
|  |   if test "$SSL_EXISTS" -eq "0"; then | ||||||
|  |     SSL_LIBS=`$PKGCONFIG --libs-only-l openssl 2>/dev/null` | ||||||
|  |     SSL_LDFLAGS=`$PKGCONFIG --libs-only-L openssl 2>/dev/null` | ||||||
|  |     SSL_CPPFLAGS=`$PKGCONFIG --cflags-only-I openssl 2>/dev/null` | ||||||
|  |  | ||||||
|  |     LIBS="$LIBS $SSL_LIBS" | ||||||
|  |     CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS" | ||||||
|  |     LDFLAGS="$LDFLAGS $SSL_LDFLAGS" | ||||||
|  |  | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |   else | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check for the presence of SSL libraries and headers | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | dnl Default to compiler & linker defaults for SSL files & libraries. | ||||||
|  | OPT_SSL=off | ||||||
|  | AC_ARG_WITH(ssl,dnl | ||||||
|  | AC_HELP_STRING([--with-ssl=PATH],[where to look for SSL, PATH points to the SSL installation (default: /usr/local/ssl)]) | ||||||
|  | AC_HELP_STRING([--without-ssl], [disable SSL]), | ||||||
|  |   OPT_SSL=$withval) | ||||||
|  |  | ||||||
|  | if test X"$OPT_SSL" = Xno | ||||||
|  | then | ||||||
|  |   AC_MSG_WARN(SSL/https support disabled)   | ||||||
|  | else | ||||||
|  |  | ||||||
|  |   dnl Check for and handle argument to --with-ssl. | ||||||
|  |  | ||||||
|  |   dnl save the pre-ssl check flags for a while | ||||||
|  |   CLEANLDFLAGS="$LDFLAGS" | ||||||
|  |   CLEANCPPFLAGS="$CPPFLAGS" | ||||||
|  |  | ||||||
|  |   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" | ||||||
|  |     CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" | ||||||
|  |     ;; | ||||||
|  |   esac | ||||||
|  |  | ||||||
|  |   AC_CHECK_LIB(crypto, CRYPTO_lock,[ | ||||||
|  |      HAVECRYPTO="yes" | ||||||
|  |      ],[ | ||||||
|  |      OLDLDFLAGS="$LDFLAGS" | ||||||
|  |      OLDCPPFLAGS="$CPPFLAGS" | ||||||
|  |      LDFLAGS="$CLEANLDFLAGS -L$EXTRA_SSL/lib" | ||||||
|  |      CPPFLAGS="$CLEANCPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" | ||||||
|  |      AC_CHECK_LIB(crypto, CRYPTO_add_lock,[ | ||||||
|  |        HAVECRYPTO="yes" ], [ | ||||||
|  |        LDFLAGS="$OLDLDFLAGS" | ||||||
|  |        CPPFLAGS="$OLDCPPFLAGS" | ||||||
|  |        ]) | ||||||
|  |     ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   if test "$HAVECRYPTO" = "yes"; then | ||||||
|  |     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 | ||||||
|  |  | ||||||
|  |     AC_CHECK_LIB(crypto, CRYPTO_add_lock) | ||||||
|  |     AC_CHECK_LIB(ssl, SSL_connect) | ||||||
|  |  | ||||||
|  |     if test "$ac_cv_lib_ssl_SSL_connect" != yes; then | ||||||
|  |         dnl we didn't find the SSL lib, try the RSAglue/rsaref stuff | ||||||
|  |         AC_MSG_CHECKING(for ssl with RSAglue/rsaref libs in use); | ||||||
|  |         OLIBS=$LIBS | ||||||
|  |         LIBS="$LIBS -lRSAglue -lrsaref" | ||||||
|  |         AC_CHECK_LIB(ssl, SSL_connect) | ||||||
|  |         if test "$ac_cv_lib_ssl_SSL_connect" != yes; then | ||||||
|  |             dnl still no SSL_connect | ||||||
|  |             AC_MSG_RESULT(no) | ||||||
|  |             LIBS=$OLIBS | ||||||
|  |         else | ||||||
|  |             AC_MSG_RESULT(yes) | ||||||
|  |         fi | ||||||
|  |     fi | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     dnl Check for SSLeay headers | ||||||
|  |     AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \ | ||||||
|  |                      openssl/pem.h openssl/ssl.h openssl/err.h, | ||||||
|  |       OPENSSL_ENABLED=1) | ||||||
|  |  | ||||||
|  |     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, | ||||||
|  |         OPENSSL_ENABLED=1) | ||||||
|  |     fi | ||||||
|  |  | ||||||
|  |     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 | ||||||
|  |     AC_CHECK_FUNC(ENGINE_init, [ AC_CHECK_HEADERS(openssl/engine.h) ]) | ||||||
|  |  | ||||||
|  |     AC_SUBST(OPENSSL_ENABLED) | ||||||
|  |  | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  |   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 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   dnl these can only exist if openssl exists | ||||||
|  |  | ||||||
|  |   AC_CHECK_FUNCS( RAND_status \ | ||||||
|  |                   RAND_screen \ | ||||||
|  |                   RAND_egd ) | ||||||
|  |  | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Check for the presence of ZLIB libraries and headers | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | dnl Check for & handle argument to --with-zlib. | ||||||
|  |  | ||||||
|  | _cppflags=$CPPFLAGS | ||||||
|  | _ldflags=$LDFLAGS | ||||||
|  | OPT_ZLIB="/usr/local" | ||||||
|  | AC_ARG_WITH(zlib, | ||||||
|  | AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH]) | ||||||
|  | AC_HELP_STRING([--without-zlib],[disable use of zlib]), | ||||||
|  |                [OPT_ZLIB="$withval"]) | ||||||
|  |  | ||||||
|  | case "$OPT_ZLIB" in | ||||||
|  |   no) | ||||||
|  |     AC_MSG_WARN([zlib disabled]) ;; | ||||||
|  |   *) | ||||||
|  |     dnl check for the lib first without setting any new path, since many | ||||||
|  |     dnl people have it in the default path | ||||||
|  |  | ||||||
|  |     AC_CHECK_LIB(z, inflateEnd, , | ||||||
|  |                    [if test -d "$OPT_ZLIB"; then | ||||||
|  |                       CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include" | ||||||
|  |                       LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib" | ||||||
|  |                    fi]) | ||||||
|  |  | ||||||
|  |     AC_CHECK_HEADER(zlib.h,[ | ||||||
|  |       AC_CHECK_LIB(z, gzread, | ||||||
|  |                    [HAVE_LIBZ="1" | ||||||
|  |                    AC_SUBST(HAVE_LIBZ) | ||||||
|  |                    LIBS="$LIBS -lz" | ||||||
|  |                    AC_DEFINE(HAVE_ZLIB_H, 1, [if you have the zlib.h header file]) | ||||||
|  |                    AC_DEFINE(HAVE_LIBZ, 1, [If zlib is available])], | ||||||
|  |                    [ CPPFLAGS=$_cppflags | ||||||
|  |                    LDFLAGS=$_ldflags])], | ||||||
|  |       [ CPPFLAGS=$_cppflags | ||||||
|  |       LDFLAGS=$_ldflags] | ||||||
|  |     ) | ||||||
|  |     ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | dnl Default is to try the thread-safe versions of a few functions | ||||||
|  | OPT_THREAD=on | ||||||
|  |  | ||||||
|  | dnl detect AIX 4.3 or later | ||||||
|  | dnl see full docs on this reasoning in the lib/hostip.c source file | ||||||
|  | AC_MSG_CHECKING([AIX 4.3 or later]) | ||||||
|  | AC_PREPROC_IFELSE([ | ||||||
|  | #if defined(_AIX) && defined(_AIX43) | ||||||
|  | printf("just fine"); | ||||||
|  | #else | ||||||
|  | #error "this is not AIX 4.3 or later" | ||||||
|  | #endif | ||||||
|  | ], | ||||||
|  |  [ AC_MSG_RESULT([yes]) | ||||||
|  |    OPT_THREAD=off ], | ||||||
|  |  [ AC_MSG_RESULT([no]) ] | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | AC_ARG_ENABLE(thread,dnl | ||||||
|  | AC_HELP_STRING([--disable-thread],[don't look for thread-safe functions]), | ||||||
|  |   OPT_THREAD=off | ||||||
|  |   AC_MSG_WARN(libcurl will not get built using thread-safe functions) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | if test X"$OPT_THREAD" = Xoff | ||||||
|  | then | ||||||
|  |   AC_DEFINE(DISABLED_THREADSAFE, 1, \ | ||||||
|  | Set to explicitly specify we don't want to use thread-safe functions) | ||||||
|  | else | ||||||
|  |  | ||||||
|  |   dnl dig around for gethostbyname_r() | ||||||
|  |   CURL_CHECK_GETHOSTBYNAME_R() | ||||||
|  |  | ||||||
|  |   dnl dig around for gethostbyaddr_r() | ||||||
|  |   CURL_CHECK_GETHOSTBYADDR_R() | ||||||
|  |  | ||||||
|  |   dnl poke around for inet_ntoa_r() | ||||||
|  |   CURL_CHECK_INET_NTOA_R() | ||||||
|  |  | ||||||
|  |   dnl is there a localtime_r() | ||||||
|  |   CURL_CHECK_LOCALTIME_R() | ||||||
|  |  | ||||||
|  |   AC_CHECK_FUNCS( gmtime_r ) | ||||||
|  |  | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | dnl ********************************************************************** | ||||||
|  | dnl Back to "normal" configuring | ||||||
|  | dnl ********************************************************************** | ||||||
|  |  | ||||||
|  | dnl Checks for header files. | ||||||
|  | AC_HEADER_STDC | ||||||
|  |  | ||||||
|  | dnl First check for the very most basic headers. Then we can use these | ||||||
|  | dnl ones as default-headers when checking for the rest! | ||||||
|  | AC_CHECK_HEADERS( | ||||||
|  |         sys/types.h \ | ||||||
|  |         sys/time.h \ | ||||||
|  |         sys/select.h \ | ||||||
|  |         sys/socket.h \ | ||||||
|  |         unistd.h \ | ||||||
|  |         malloc.h \ | ||||||
|  |         stdlib.h \ | ||||||
|  |         arpa/inet.h \ | ||||||
|  |         net/if.h \ | ||||||
|  |         netinet/in.h \ | ||||||
|  |         netdb.h \ | ||||||
|  |         sys/sockio.h \ | ||||||
|  |         sys/stat.h \ | ||||||
|  |         sys/param.h \ | ||||||
|  |         termios.h \ | ||||||
|  |         termio.h \ | ||||||
|  |         sgtty.h \ | ||||||
|  |         fcntl.h \ | ||||||
|  |         dlfcn.h \ | ||||||
|  |         alloca.h \ | ||||||
|  |         winsock.h \ | ||||||
|  |         time.h \ | ||||||
|  |         io.h \ | ||||||
|  |         pwd.h \ | ||||||
|  |         utime.h \ | ||||||
|  |         sys/utime.h \ | ||||||
|  |         sys/poll.h \ | ||||||
|  |         setjmp.h, | ||||||
|  | dnl to do if not found | ||||||
|  | [], | ||||||
|  | dnl to do if found | ||||||
|  | [], | ||||||
|  | dnl default includes | ||||||
|  | [ | ||||||
|  | #ifdef HAVE_SYS_TYPES_H | ||||||
|  | #include <sys/types.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_TIME_H | ||||||
|  | #include <sys/time.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_SELECT_H | ||||||
|  | #include <sys/select.h> | ||||||
|  | #endif | ||||||
|  | #ifdef HAVE_SYS_SOCKET_H | ||||||
|  | #include <sys/socket.h> | ||||||
|  | #endif | ||||||
|  | ] | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | dnl Checks for typedefs, structures, and compiler characteristics. | ||||||
|  | AC_C_CONST | ||||||
|  | AC_TYPE_SIZE_T | ||||||
|  | AC_HEADER_TIME | ||||||
|  |  | ||||||
|  | # mprintf() checks: | ||||||
|  |  | ||||||
|  | # check for 'long double' | ||||||
|  | # AC_CHECK_SIZEOF(long double, 8) | ||||||
|  | # check for 'long long' | ||||||
|  | # AC_CHECK_SIZEOF(long long, 4) | ||||||
|  |  | ||||||
|  | # check for ssize_t | ||||||
|  | AC_CHECK_TYPE(ssize_t, int) | ||||||
|  |  | ||||||
|  | TYPE_SOCKLEN_T | ||||||
|  | TYPE_IN_ADDR_T | ||||||
|  |  | ||||||
|  | AC_FUNC_SELECT_ARGTYPES | ||||||
|  |  | ||||||
|  | dnl Checks for library functions. | ||||||
|  | dnl AC_PROG_GCC_TRADITIONAL | ||||||
|  | AC_TYPE_SIGNAL | ||||||
|  | dnl AC_FUNC_VPRINTF | ||||||
|  | AC_CHECK_FUNCS( socket \ | ||||||
|  |                 select \ | ||||||
|  |                 strdup \ | ||||||
|  |                 strstr \ | ||||||
|  |                 strtok_r \ | ||||||
|  |                 strftime \ | ||||||
|  |                 uname \ | ||||||
|  |                 strcasecmp \ | ||||||
|  |                 stricmp \ | ||||||
|  |                 strcmpi \ | ||||||
|  |                 gethostbyaddr \ | ||||||
|  |                 gettimeofday \ | ||||||
|  |                 inet_addr \ | ||||||
|  |                 inet_ntoa \ | ||||||
|  |                 tcsetattr \ | ||||||
|  |                 tcgetattr \ | ||||||
|  |                 perror \ | ||||||
|  |                 closesocket \ | ||||||
|  |                 setvbuf \ | ||||||
|  |                 sigaction \ | ||||||
|  |                 signal \ | ||||||
|  |                 getpass_r \ | ||||||
|  |                 strlcat \ | ||||||
|  |                 getpwuid \ | ||||||
|  |                 geteuid \ | ||||||
|  |                 dlopen \ | ||||||
|  |                 utime \ | ||||||
|  |                 sigsetjmp \ | ||||||
|  |                 poll, | ||||||
|  | dnl if found | ||||||
|  | [], | ||||||
|  | dnl if not found, $ac_func is the name we check for | ||||||
|  |   func="$ac_func" | ||||||
|  |   AC_MSG_CHECKING([deeper for $func]) | ||||||
|  |   AC_TRY_LINK( [], | ||||||
|  |                [ $func ();], | ||||||
|  |                AC_MSG_RESULT(yes!) | ||||||
|  |                eval "ac_cv_func_$func=yes" | ||||||
|  |                def=`echo "HAVE_$func" | tr 'a-z' 'A-Z'` | ||||||
|  |                AC_DEFINE_UNQUOTED($def, 1, [If you have $func]), | ||||||
|  |                AC_MSG_RESULT(but still no) | ||||||
|  |                ) | ||||||
|  |  | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | dnl sigsetjmp() might be a macro and no function so if it isn't found already | ||||||
|  | dnl we make an extra check here! | ||||||
|  | if test "$ac_cv_func_sigsetjmp" != "yes"; then | ||||||
|  |   AC_MSG_CHECKING([for sigsetjmp defined as macro]) | ||||||
|  |   AC_TRY_LINK( [#include <setjmp.h>], | ||||||
|  |                [sigjmp_buf jmpenv; | ||||||
|  |                 sigsetjmp(jmpenv, 1);], | ||||||
|  |                AC_MSG_RESULT(yes) | ||||||
|  |                AC_DEFINE(HAVE_SIGSETJMP, 1, [If you have sigsetjmp]), | ||||||
|  |                AC_MSG_RESULT(no) | ||||||
|  |                ) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | AC_PATH_PROG( PERL, perl, ,  | ||||||
|  |   $PATH:/usr/local/bin/perl:/usr/bin/:/usr/local/bin ) | ||||||
|  | AC_SUBST(PERL) | ||||||
|  |  | ||||||
|  | AC_PATH_PROGS( NROFF, gnroff nroff, ,  | ||||||
|  |   $PATH:/usr/bin/:/usr/local/bin ) | ||||||
|  | AC_SUBST(NROFF) | ||||||
|  |  | ||||||
|  | AC_MSG_CHECKING([CA cert bundle install path]) | ||||||
|  |  | ||||||
|  | AC_ARG_WITH(ca-bundle, | ||||||
|  | AC_HELP_STRING([--with-ca-bundle=FILE], [File name to install the CA bundle as]) | ||||||
|  | AC_HELP_STRING([--without-ca-bundle], [Don't install the CA bundle]), | ||||||
|  |    [ ca="$withval" ], | ||||||
|  |    [ | ||||||
|  |   if test "x$prefix" != xNONE; then | ||||||
|  |     ca="$prefix/share/curl/curl-ca-bundle.crt" | ||||||
|  |   else | ||||||
|  |     ca="$ac_default_prefix/share/curl/curl-ca-bundle.crt" | ||||||
|  |   fi | ||||||
|  |    ] ) | ||||||
|  |  | ||||||
|  | if test X"$OPT_SSL" = Xno | ||||||
|  | then | ||||||
|  |   ca="no" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | if test "x$ca" = "xno"; then | ||||||
|  |   dnl let's not keep "no" as path name, blank it instead | ||||||
|  |   ca="" | ||||||
|  | else | ||||||
|  |   AC_DEFINE_UNQUOTED(CURL_CA_BUNDLE, "$ca", [CA bundle full path name]) | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | CURL_CA_BUNDLE="$ca" | ||||||
|  | AC_SUBST(CURL_CA_BUNDLE) | ||||||
|  | AC_MSG_RESULT([$ca]) | ||||||
|  |  | ||||||
|  | AC_PROG_YACC | ||||||
|  |  | ||||||
|  | dnl AC_PATH_PROG( RANLIB, ranlib, /usr/bin/ranlib,  | ||||||
|  | dnl   $PATH:/usr/bin/:/usr/local/bin ) | ||||||
|  | dnl AC_SUBST(RANLIB) | ||||||
|  |  | ||||||
|  | dnl ************************************************************ | ||||||
|  | dnl lame option to switch on debug options | ||||||
|  | dnl | ||||||
|  | AC_MSG_CHECKING([whether to enable debug options]) | ||||||
|  | AC_ARG_ENABLE(debug, | ||||||
|  | AC_HELP_STRING([--enable-debug],[Enable pedantic debug options]) | ||||||
|  | AC_HELP_STRING([--disable-debug],[Disable debug options]), | ||||||
|  | [ case "$enableval" in | ||||||
|  |   no) | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  |        ;; | ||||||
|  |   *)   AC_MSG_RESULT(yes) | ||||||
|  |  | ||||||
|  |     CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG" | ||||||
|  |     CFLAGS="$CFLAGS -g"  | ||||||
|  |     if test "$GCC" = "yes"; then | ||||||
|  |        CFLAGS="$CFLAGS -W -Wall -Wwrite-strings -pedantic -Wundef -Wpointer-arith -Wnested-externs" | ||||||
|  |     fi | ||||||
|  |     dnl strip off optimizer flags | ||||||
|  |     NEWFLAGS="" | ||||||
|  |     for flag in $CFLAGS; do | ||||||
|  |       case "$flag" in | ||||||
|  |       -O*) | ||||||
|  |         dnl echo "cut off $flag" | ||||||
|  |         ;; | ||||||
|  |       *) | ||||||
|  |         NEWFLAGS="$NEWFLAGS $flag" | ||||||
|  |         ;; | ||||||
|  |       esac | ||||||
|  |     done | ||||||
|  |     CFLAGS=$NEWFLAGS | ||||||
|  |        ;; | ||||||
|  |   esac ], | ||||||
|  |        AC_MSG_RESULT(no) | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | AC_CONFIG_FILES([Makefile \ | ||||||
|  | 	   docs/Makefile \ | ||||||
|  |            docs/examples/Makefile \ | ||||||
|  |            docs/libcurl/Makefile \ | ||||||
|  | 	   include/Makefile \ | ||||||
|  | 	   include/curl/Makefile \ | ||||||
|  | 	   src/Makefile \ | ||||||
|  |            lib/Makefile \ | ||||||
|  |            tests/Makefile \ | ||||||
|  |            tests/data/Makefile \ | ||||||
|  |            tests/server/Makefile \ | ||||||
|  |            tests/libtest/Makefile \ | ||||||
|  | 	   packages/Makefile \ | ||||||
|  | 	   packages/Win32/Makefile \ | ||||||
|  | 	   packages/Win32/cygwin/Makefile \ | ||||||
|  | 	   packages/Linux/Makefile \ | ||||||
|  | 	   packages/Linux/RPM/Makefile \ | ||||||
|  | 	   packages/Linux/RPM/curl.spec \ | ||||||
|  | 	   packages/Linux/RPM/curl-ssl.spec \ | ||||||
|  |            packages/Solaris/Makefile \ | ||||||
|  |            packages/EPM/curl.list \ | ||||||
|  |            packages/EPM/Makefile \ | ||||||
|  |            curl-config | ||||||
|  | ]) | ||||||
|  | AC_OUTPUT | ||||||
							
								
								
									
										615
									
								
								configure.in
									
									
									
									
									
								
							
							
						
						
									
										615
									
								
								configure.in
									
									
									
									
									
								
							| @@ -1,615 +0,0 @@ | |||||||
| dnl $Id$ |  | ||||||
| dnl Process this file with autoconf to produce a configure script. |  | ||||||
|  |  | ||||||
| dnl Ensure that this file is processed with autoconf 2.50 or newer |  | ||||||
| dnl Don't even think about removing this check! |  | ||||||
| AC_PREREQ(2.50) |  | ||||||
|  |  | ||||||
| dnl First some basic init macros |  | ||||||
| AC_INIT |  | ||||||
| AC_CONFIG_SRCDIR([lib/urldata.h]) |  | ||||||
| AM_CONFIG_HEADER(config.h src/config.h) |  | ||||||
|  |  | ||||||
| dnl figure out the libcurl version |  | ||||||
| VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h` |  | ||||||
| AM_INIT_AUTOMAKE(curl,$VERSION) |  | ||||||
|  |  | ||||||
| dnl |  | ||||||
| dnl we extract the numerical version for curl-config only |  | ||||||
| VERSIONNUM=`sed -ne 's/^#define LIBCURL_VERSION_NUM 0x\(.*\)/\1/p' ${srcdir}/include/curl/curl.h` |  | ||||||
| AC_SUBST(VERSIONNUM) |  | ||||||
|  |  | ||||||
| dnl Solaris pkgadd support definitions |  | ||||||
| PKGADD_PKG="HAXXcurl" |  | ||||||
| PKGADD_NAME="cURL - a client that groks URLs" |  | ||||||
| PKGADD_VENDOR="curl.haxx.se" |  | ||||||
| AC_SUBST(PKGADD_PKG) |  | ||||||
| AC_SUBST(PKGADD_NAME) |  | ||||||
| AC_SUBST(PKGADD_VENDOR) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl |  | ||||||
| dnl Detect the canonical host and target build environment |  | ||||||
| dnl |  | ||||||
|  |  | ||||||
| AC_CANONICAL_HOST |  | ||||||
| dnl Get system canonical name |  | ||||||
| AC_DEFINE_UNQUOTED(OS, "${host}") |  | ||||||
|  |  | ||||||
| dnl Check for AIX weirdos |  | ||||||
| AC_AIX |  | ||||||
|  |  | ||||||
| dnl Checks for programs. |  | ||||||
| AC_PROG_CC |  | ||||||
|  |  | ||||||
| dnl check for how to do large files |  | ||||||
| AC_SYS_LARGEFILE |  | ||||||
|  |  | ||||||
| dnl check for cygwin stuff |  | ||||||
| AC_LIBTOOL_WIN32_DLL |  | ||||||
|  |  | ||||||
| dnl libtool setup |  | ||||||
| AM_PROG_LIBTOOL |  | ||||||
|  |  | ||||||
| dnl The install stuff has already been taken care of by the automake stuff |  | ||||||
| dnl AC_PROG_INSTALL |  | ||||||
| AC_PROG_MAKE_SET |  | ||||||
|  |  | ||||||
| dnl ************************************************************ |  | ||||||
| dnl lame option to switch on debug options |  | ||||||
| dnl |  | ||||||
| AC_MSG_CHECKING([whether to enable debug options]) |  | ||||||
| AC_ARG_ENABLE(debug, |  | ||||||
| [  --enable-debug		Enable pedantic debug options |  | ||||||
|   --disable-debug		Disable debug options], |  | ||||||
| [ case "$enableval" in |  | ||||||
|   no) |  | ||||||
|        AC_MSG_RESULT(no) |  | ||||||
|        ;; |  | ||||||
|   *)   AC_MSG_RESULT(yes) |  | ||||||
|  |  | ||||||
|     CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG" |  | ||||||
|     CFLAGS="-W -Wall -Wwrite-strings -pedantic -g"  |  | ||||||
|        ;; |  | ||||||
|   esac ], |  | ||||||
|        AC_MSG_RESULT(no) |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Checks for IPv6 |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([whether to enable ipv6]) |  | ||||||
| AC_ARG_ENABLE(ipv6, |  | ||||||
| [  --enable-ipv6		Enable ipv6 (with ipv4) support |  | ||||||
|   --disable-ipv6		Disable ipv6 support], |  | ||||||
| [ case "$enableval" in |  | ||||||
|   no) |  | ||||||
|        AC_MSG_RESULT(no) |  | ||||||
|        ipv6=no |  | ||||||
|        ;; |  | ||||||
|   *)   AC_MSG_RESULT(yes) |  | ||||||
|        ipv6=yes |  | ||||||
|        ;; |  | ||||||
|   esac ], |  | ||||||
|  |  | ||||||
|   AC_TRY_RUN([ /* is AF_INET6 available? */ |  | ||||||
| #include <sys/types.h> |  | ||||||
| #include <sys/socket.h> |  | ||||||
| main() |  | ||||||
| { |  | ||||||
|  if (socket(AF_INET6, SOCK_STREAM, 0) < 0) |  | ||||||
|    exit(1); |  | ||||||
|  else |  | ||||||
|    exit(0); |  | ||||||
| } |  | ||||||
| ], |  | ||||||
|   AC_MSG_RESULT(yes) |  | ||||||
|   ipv6=yes, |  | ||||||
|   AC_MSG_RESULT(no) |  | ||||||
|   ipv6=no, |  | ||||||
|   AC_MSG_RESULT(no) |  | ||||||
|   ipv6=no |  | ||||||
| )) |  | ||||||
|  |  | ||||||
| if test "$ipv6" = "yes"; then |  | ||||||
|   CURL_CHECK_WORKING_GETADDRINFO |  | ||||||
| fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Checks for libraries. |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| dnl gethostbyname in the nsl lib? |  | ||||||
| AC_CHECK_FUNC(gethostbyname, , AC_CHECK_LIB(nsl, gethostbyname)) |  | ||||||
|  |  | ||||||
| if test "$ac_cv_lib_nsl_gethostbyname" != "yes" -a "$ac_cv_func_gethostbyname" != "yes"; then |  | ||||||
|   dnl gethostbyname in the socket lib? |  | ||||||
|   AC_CHECK_FUNC(gethostbyname, , AC_CHECK_LIB(socket, gethostbyname)) |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl At least one system has been identified to require BOTH nsl and |  | ||||||
| dnl socket libs to link properly. |  | ||||||
| if test "$ac_cv_lib_nsl_gethostbyname" = "$ac_cv_func_gethostbyname"; then |  | ||||||
|   AC_MSG_CHECKING([trying both nsl and socket libs]) |  | ||||||
|   my_ac_save_LIBS=$LIBS |  | ||||||
|   LIBS="-lnsl -lsocket $LIBS" |  | ||||||
|   AC_TRY_LINK( , |  | ||||||
|              [gethostbyname();], |  | ||||||
|              my_ac_link_result=success, |  | ||||||
|              my_ac_link_result=failure ) |  | ||||||
|  |  | ||||||
|   if test "$my_ac_link_result" = "failure"; then |  | ||||||
|     AC_MSG_RESULT([no]) |  | ||||||
|     AC_MSG_ERROR([couldn't find libraries for gethostbyname()]) |  | ||||||
|     dnl restore LIBS |  | ||||||
|     LIBS=$my_ac_save_LIBS |  | ||||||
|   else |  | ||||||
|     AC_MSG_RESULT([yes]) |  | ||||||
|   fi |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl resolve lib? |  | ||||||
| AC_CHECK_FUNC(strcasecmp, , AC_CHECK_LIB(resolve, strcasecmp)) |  | ||||||
|  |  | ||||||
| if test "$ac_cv_lib_resolve_strcasecmp" = "$ac_cv_func_strcasecmp"; then |  | ||||||
|   AC_CHECK_LIB(resolve, strcasecmp, |  | ||||||
|               [LIBS="-lresolve $LIBS"], |  | ||||||
|                , |  | ||||||
|                -lnsl) |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl socket lib? |  | ||||||
| AC_CHECK_FUNC(connect, , AC_CHECK_LIB(socket, connect)) |  | ||||||
|  |  | ||||||
| dnl ucb lib? |  | ||||||
| AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname)) |  | ||||||
|  |  | ||||||
| dnl dl lib? |  | ||||||
| AC_CHECK_FUNC(dlclose, , AC_CHECK_LIB(dl, dlopen)) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check how non-blocking sockets are set |  | ||||||
| dnl ********************************************************************** |  | ||||||
| AC_ARG_ENABLE(nonblocking, |  | ||||||
| [  --enable-nonblocking  Makes the script detect how to do it |  | ||||||
|   --disable-nonblocking Makes the script disable non-blocking sockets], |  | ||||||
| [ |  | ||||||
|   if test "$enableval" = "no" ; then |  | ||||||
|     AC_MSG_WARN([non-blocking sockets disabled]) |  | ||||||
|     AC_DEFINE(HAVE_DISABLED_NONBLOCKING) |  | ||||||
|   else |  | ||||||
|     CURL_CHECK_NONBLOCKING_SOCKET |  | ||||||
|   fi |  | ||||||
| ], |  | ||||||
| [ |  | ||||||
|   CURL_CHECK_NONBLOCKING_SOCKET |  | ||||||
| ]) |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for the random seed preferences  |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| AC_ARG_WITH(egd-socket, |  | ||||||
|     [  --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") |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl Check for user-specified random device |  | ||||||
| AC_ARG_WITH(random, |  | ||||||
|     [  --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") |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for the presence of Kerberos4 libraries and headers |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| AC_ARG_WITH(krb4-includes, |  | ||||||
|  [  --with-krb4-includes[=DIR]   Specify location of kerberos4 headers],[ |  | ||||||
|  CPPFLAGS="$CPPFLAGS -I$withval" |  | ||||||
|  KRB4INC="$withval" |  | ||||||
|  want_krb4=yes |  | ||||||
|  ]) |  | ||||||
|  |  | ||||||
| AC_ARG_WITH(krb4-libs, |  | ||||||
|  [  --with-krb4-libs[=DIR]   Specify location of kerberos4 libs],[ |  | ||||||
|  LDFLAGS="$LDFLAGS -L$withval" |  | ||||||
|  KRB4LIB="$withval" |  | ||||||
|  want_krb4=yes |  | ||||||
|  ]) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| OPT_KRB4=off |  | ||||||
| AC_ARG_WITH(krb4,dnl |  | ||||||
| [  --with-krb4[=DIR]       where to look for Kerberos4],[ |  | ||||||
|   OPT_KRB4="$withval" |  | ||||||
|   if test X"$OPT_KRB4" != Xyes |  | ||||||
|   then |  | ||||||
|     LDFLAGS="$LDFLAGS -L$OPT_KRB4/lib" |  | ||||||
|     KRB4LIB="$OPT_KRB4/lib" |  | ||||||
|     CPPFLAGS="$CPPFLAGS -I$OPT_KRB4/include" |  | ||||||
|     KRB4INC="$OPT_KRB4/include" |  | ||||||
|   fi |  | ||||||
|   want_krb4="yes" |  | ||||||
|  ]) |  | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([if Kerberos4 support is requested]) |  | ||||||
|  |  | ||||||
| if test "$want_krb4" = yes |  | ||||||
| then |  | ||||||
|   if test "$ipv6" = "yes"; then |  | ||||||
|     echo krb4 is not compatible with IPv6 |  | ||||||
|     exit 1 |  | ||||||
|   fi |  | ||||||
|   AC_MSG_RESULT(yes) |  | ||||||
|  |  | ||||||
|   dnl Check for & handle argument to --with-krb4 |  | ||||||
|  |  | ||||||
|   AC_MSG_CHECKING(where to look for Kerberos4) |  | ||||||
|   if test X"$OPT_KRB4" = Xyes |  | ||||||
|   then |  | ||||||
|     AC_MSG_RESULT([defaults]) |  | ||||||
|   else |  | ||||||
|     AC_MSG_RESULT([libs in $KRB4LIB, headers in $KRB4INC]) |  | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   dnl Check for DES library |  | ||||||
|   AC_CHECK_LIB(des, des_pcbc_encrypt, |  | ||||||
|   [ |  | ||||||
|     AC_CHECK_HEADERS(des.h) |  | ||||||
|  |  | ||||||
|     dnl resolv lib? |  | ||||||
|     AC_CHECK_FUNC(res_search, , AC_CHECK_LIB(resolv, res_search)) |  | ||||||
|  |  | ||||||
|     dnl Check for the Kerberos4 library |  | ||||||
|     AC_CHECK_LIB(krb, krb_net_read, |  | ||||||
|     [ |  | ||||||
|       dnl Check for header files |  | ||||||
|       AC_CHECK_HEADERS(krb.h) |  | ||||||
|  |  | ||||||
|       dnl we found the required libraries, add to LIBS |  | ||||||
|       LIBS="-lkrb -ldes $LIBS" |  | ||||||
|  |  | ||||||
|       dnl Check for function krb_get_our_ip_for_realm |  | ||||||
|       dnl this is needed for NAT networks |  | ||||||
|       AC_CHECK_FUNCS(krb_get_our_ip_for_realm) |  | ||||||
|  |  | ||||||
|       dnl add define KRB4 |  | ||||||
|       AC_DEFINE(KRB4) |  | ||||||
|  |  | ||||||
|       dnl substitute it too! |  | ||||||
|       KRB4_ENABLED=1 |  | ||||||
|       AC_SUBST(KRB4_ENABLED) |  | ||||||
|  |  | ||||||
|       dnl the krb4 stuff needs a strlcpy() |  | ||||||
|       AC_CHECK_FUNCS(strlcpy) |  | ||||||
|  |  | ||||||
|     ]) |  | ||||||
|   ]) |  | ||||||
| else |  | ||||||
|   AC_MSG_RESULT(no) |  | ||||||
| fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for the presence of SSL libraries and headers |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| dnl Default to compiler & linker defaults for SSL files & libraries. |  | ||||||
| OPT_SSL=off |  | ||||||
| AC_ARG_WITH(ssl,dnl |  | ||||||
| [  --with-ssl[=DIR]        where to look for SSL [compiler/linker default paths] |  | ||||||
|                           DIR points to the SSL installation [/usr/local/ssl]], |  | ||||||
|   OPT_SSL=$withval |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| if test X"$OPT_SSL" = Xno |  | ||||||
| then |  | ||||||
|   AC_MSG_WARN(SSL/https support disabled)   |  | ||||||
| else |  | ||||||
|  |  | ||||||
|   dnl Check for and handle argument to --with-ssl. |  | ||||||
|  |  | ||||||
|   dnl save the pre-ssl check flags for a while |  | ||||||
|   CLEANLDFLAGS="$LDFLAGS" |  | ||||||
|   CLEANCPPFLAGS="$CPPFLAGS" |  | ||||||
|  |  | ||||||
|   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" |  | ||||||
|     CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" |  | ||||||
|     ;; |  | ||||||
|   esac |  | ||||||
|  |  | ||||||
|   AC_CHECK_LIB(crypto, CRYPTO_lock,[ |  | ||||||
|      HAVECRYPTO="yes" |  | ||||||
|      ],[ |  | ||||||
|      OLDLDFLAGS="$LDFLAGS" |  | ||||||
|      OLDCPPFLAGS="$CPPFLAGS" |  | ||||||
|      LDFLAGS="$CLEANLDFLAGS -L$EXTRA_SSL/lib" |  | ||||||
|      CPPFLAGS="$CLEANCPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" |  | ||||||
|      AC_CHECK_LIB(crypto, CRYPTO_add_lock,[ |  | ||||||
|        HAVECRYPTO="yes" ], [ |  | ||||||
|        LDFLAGS="$OLDLDFLAGS" |  | ||||||
|        CPPFLAGS="$OLDCPPFLAGS" |  | ||||||
|        ]) |  | ||||||
|     ]) |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   if test "$HAVECRYPTO" = "yes"; then |  | ||||||
|     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 |  | ||||||
|  |  | ||||||
|     AC_CHECK_LIB(crypto, CRYPTO_add_lock) |  | ||||||
|     AC_CHECK_LIB(ssl, SSL_connect) |  | ||||||
|  |  | ||||||
|     if test "$ac_cv_lib_ssl_SSL_connect" != yes; then |  | ||||||
|         dnl we didn't find the SSL lib, try the RSAglue/rsaref stuff |  | ||||||
|         AC_MSG_CHECKING(for ssl with RSAglue/rsaref libs in use); |  | ||||||
|         OLIBS=$LIBS |  | ||||||
|         LIBS="$LIBS -lRSAglue -lrsaref" |  | ||||||
|         AC_CHECK_LIB(ssl, SSL_connect) |  | ||||||
|         if test "$ac_cv_lib_ssl_SSL_connect" != yes; then |  | ||||||
|             dnl still no SSL_connect |  | ||||||
|             AC_MSG_RESULT(no) |  | ||||||
|             LIBS=$OLIBS |  | ||||||
|         else |  | ||||||
|             AC_MSG_RESULT(yes) |  | ||||||
|         fi |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     dnl Check for SSLeay headers |  | ||||||
|     AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \ |  | ||||||
|                      openssl/pem.h openssl/ssl.h openssl/err.h, |  | ||||||
|       OPENSSL_ENABLED=1) |  | ||||||
|  |  | ||||||
|     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, |  | ||||||
|         OPENSSL_ENABLED=1) |  | ||||||
|     fi |  | ||||||
|  |  | ||||||
|     dnl Check for the OpenSSL engine header, it is kind of "separated" |  | ||||||
|     dnl from the main SSL check |  | ||||||
|     AC_CHECK_HEADERS(openssl/engine.h) |  | ||||||
|  |  | ||||||
|     AC_SUBST(OPENSSL_ENABLED) |  | ||||||
|  |  | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   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 |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   dnl these can only exist if openssl exists |  | ||||||
|  |  | ||||||
|   AC_CHECK_FUNCS( RAND_status \ |  | ||||||
|                   RAND_screen \ |  | ||||||
|                   RAND_egd ) |  | ||||||
|  |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Check for the presence of ZLIB libraries and headers |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| dnl Default to compiler & linker defaults for files & libraries. |  | ||||||
| dnl OPT_ZLIB=no |  | ||||||
| dnl AC_ARG_WITH(zlib,dnl |  | ||||||
| dnl [  --with-zlib[=DIR]  where to look for ZLIB [compiler/linker default paths] |  | ||||||
| dnl                      DIR points to the ZLIB installation prefix [/usr/local]], |  | ||||||
| dnl  OPT_ZLIB=$withval, |  | ||||||
| dnl ) |  | ||||||
|  |  | ||||||
| dnl Check for & handle argument to --with-zlib. |  | ||||||
| dnl |  | ||||||
| dnl NOTE:  We *always* look for ZLIB headers & libraries, all this option |  | ||||||
| dnl        does is change where we look (by adjusting LIBS and CPPFLAGS.) |  | ||||||
| dnl |  | ||||||
|  |  | ||||||
| dnl AC_MSG_CHECKING(where to look for ZLIB) |  | ||||||
| dnl if test X"$OPT_ZLIB" = Xno |  | ||||||
| dnl then |  | ||||||
| dnl 	AC_MSG_RESULT([defaults (or given in environment)]) |  | ||||||
| dnl else |  | ||||||
| dnl	test X"$OPT_ZLIB" = Xyes && OPT_ZLIB=/usr/local |  | ||||||
| dnl	LIBS="$LIBS -L$OPT_ZLIB/lib" |  | ||||||
| dnl	CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include" |  | ||||||
| dnl	AC_MSG_RESULT([$OPT_ZLIB]) |  | ||||||
| dnl fi |  | ||||||
|  |  | ||||||
| dnl z lib? |  | ||||||
| dnl AC_CHECK_FUNC(gzread, , AC_CHECK_LIB(z, gzread)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl Default is to try the thread-safe versions of a few functions |  | ||||||
| OPT_THREAD=on |  | ||||||
| AC_ARG_ENABLE(thread,dnl |  | ||||||
| [  --disable-thread       tell configure to not look for thread-safe functions], |  | ||||||
|   OPT_THREAD=off |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| if test X"$OPT_THREAD" = Xoff |  | ||||||
| then |  | ||||||
|   AC_MSG_WARN(libcurl will not get built using thread-safe functions) |  | ||||||
|   AC_DEFINE(DISABLED_THREADSAFE, 1, \ |  | ||||||
| Set to explicitly specify we don't want to use thread-safe functions) |  | ||||||
| else |  | ||||||
|  |  | ||||||
|   dnl dig around for gethostbyname_r() |  | ||||||
|   CURL_CHECK_GETHOSTBYNAME_R() |  | ||||||
|  |  | ||||||
|   dnl dig around for gethostbyaddr_r() |  | ||||||
|   CURL_CHECK_GETHOSTBYADDR_R() |  | ||||||
|  |  | ||||||
|   dnl poke around for inet_ntoa_r() |  | ||||||
|   CURL_CHECK_INET_NTOA_R() |  | ||||||
|  |  | ||||||
|   dnl is there a localtime_r() |  | ||||||
|   CURL_CHECK_LOCALTIME_R() |  | ||||||
|  |  | ||||||
|   AC_CHECK_FUNCS( gmtime_r ) |  | ||||||
|  |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| dnl ********************************************************************** |  | ||||||
| dnl Back to "normal" configuring |  | ||||||
| dnl ********************************************************************** |  | ||||||
|  |  | ||||||
| dnl Checks for header files. |  | ||||||
| AC_HEADER_STDC |  | ||||||
| AC_CHECK_HEADERS( \ |  | ||||||
|         unistd.h \ |  | ||||||
|         malloc.h \ |  | ||||||
|         stdlib.h \ |  | ||||||
|         arpa/inet.h \ |  | ||||||
|         net/if.h \ |  | ||||||
|         netinet/in.h \ |  | ||||||
| 	netinet/if_ether.h \ |  | ||||||
|         netdb.h \ |  | ||||||
|         sys/select.h \ |  | ||||||
|         sys/socket.h \ |  | ||||||
|         sys/sockio.h \ |  | ||||||
|         sys/stat.h \ |  | ||||||
|         sys/types.h \ |  | ||||||
|         sys/time.h \ |  | ||||||
|         sys/param.h \ |  | ||||||
|         termios.h \ |  | ||||||
|         termio.h \ |  | ||||||
|         sgtty.h \ |  | ||||||
|         fcntl.h \ |  | ||||||
|         dlfcn.h \ |  | ||||||
|         alloca.h \ |  | ||||||
|         winsock.h \ |  | ||||||
|         time.h \ |  | ||||||
|         io.h \ |  | ||||||
|         pwd.h \ |  | ||||||
|         utime.h \ |  | ||||||
|         sys/utime.h |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| dnl Check for libz header |  | ||||||
| dnl AC_CHECK_HEADERS(zlib.h) |  | ||||||
|  |  | ||||||
| dnl Checks for typedefs, structures, and compiler characteristics. |  | ||||||
| AC_C_CONST |  | ||||||
| AC_TYPE_SIZE_T |  | ||||||
| AC_HEADER_TIME |  | ||||||
|  |  | ||||||
| # mprintf() checks: |  | ||||||
|  |  | ||||||
| # check for 'long double' |  | ||||||
| AC_CHECK_SIZEOF(long double, 8) |  | ||||||
| # check for 'long long' |  | ||||||
| AC_CHECK_SIZEOF(long long, 4) |  | ||||||
|  |  | ||||||
| # check for ssize_t |  | ||||||
| AC_CHECK_TYPE(ssize_t, int) |  | ||||||
|  |  | ||||||
| TYPE_SOCKLEN_T |  | ||||||
| TYPE_IN_ADDR_T |  | ||||||
|  |  | ||||||
| dnl Checks for library functions. |  | ||||||
| dnl AC_PROG_GCC_TRADITIONAL |  | ||||||
| AC_TYPE_SIGNAL |  | ||||||
| dnl AC_FUNC_VPRINTF |  | ||||||
| AC_CHECK_FUNCS( socket \ |  | ||||||
|                 select \ |  | ||||||
|                 strdup \ |  | ||||||
|                 strstr \ |  | ||||||
|                 strtok_r \ |  | ||||||
|                 strftime \ |  | ||||||
|                 uname \ |  | ||||||
|                 strcasecmp \ |  | ||||||
|                 stricmp \ |  | ||||||
|                 strcmpi \ |  | ||||||
|                 gethostname \ |  | ||||||
|                 gethostbyaddr \ |  | ||||||
|                 gettimeofday \ |  | ||||||
|                 inet_addr \ |  | ||||||
|                 inet_ntoa \ |  | ||||||
|                 tcsetattr \ |  | ||||||
|                 tcgetattr \ |  | ||||||
|                 perror \ |  | ||||||
|                 closesocket \ |  | ||||||
|                 setvbuf \ |  | ||||||
|                 sigaction \ |  | ||||||
|                 signal \ |  | ||||||
|                 getpass_r \ |  | ||||||
|                 strlcat \ |  | ||||||
|                 getpwuid \ |  | ||||||
|                 geteuid \ |  | ||||||
|                 dlopen \ |  | ||||||
|                 utime |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| dnl removed 'getpass' check on October 26, 2000 |  | ||||||
|  |  | ||||||
| if test "$ac_cv_func_select" != "yes"; then |  | ||||||
|   AC_MSG_ERROR(Can't work without an existing select() function) |  | ||||||
| fi |  | ||||||
| if test "$ac_cv_func_socket" != "yes"; then |  | ||||||
|   AC_MSG_ERROR(Can't work without an existing socket() function) |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| AC_PATH_PROG( PERL, perl, ,  |  | ||||||
|   $PATH:/usr/local/bin/perl:/usr/bin/:/usr/local/bin ) |  | ||||||
| AC_SUBST(PERL) |  | ||||||
|  |  | ||||||
| AC_PATH_PROGS( NROFF, gnroff nroff, ,  |  | ||||||
|   $PATH:/usr/bin/:/usr/local/bin ) |  | ||||||
| AC_SUBST(NROFF) |  | ||||||
|  |  | ||||||
| AC_PROG_YACC |  | ||||||
|  |  | ||||||
| dnl AC_PATH_PROG( RANLIB, ranlib, /usr/bin/ranlib,  |  | ||||||
| dnl   $PATH:/usr/bin/:/usr/local/bin ) |  | ||||||
| dnl AC_SUBST(RANLIB) |  | ||||||
|  |  | ||||||
| AC_CONFIG_FILES([Makefile \ |  | ||||||
| 	   docs/Makefile \ |  | ||||||
|            docs/examples/Makefile \ |  | ||||||
| 	   include/Makefile \ |  | ||||||
| 	   include/curl/Makefile \ |  | ||||||
| 	   src/Makefile \ |  | ||||||
| 	   multi/Makefile \ |  | ||||||
|            lib/Makefile \ |  | ||||||
|            tests/Makefile \ |  | ||||||
|            tests/data/Makefile \ |  | ||||||
| 	   packages/Makefile \ |  | ||||||
| 	   packages/Win32/Makefile \ |  | ||||||
| 	   packages/Win32/cygwin/Makefile \ |  | ||||||
| 	   packages/Linux/Makefile \ |  | ||||||
| 	   packages/Linux/RPM/Makefile \ |  | ||||||
| 	   packages/Linux/RPM/curl.spec \ |  | ||||||
| 	   packages/Linux/RPM/curl-ssl.spec \ |  | ||||||
|            packages/Solaris/Makefile \ |  | ||||||
|            curl-config |  | ||||||
| ]) |  | ||||||
| AC_OUTPUT |  | ||||||
|  |  | ||||||
| @@ -16,6 +16,7 @@ Usage: curl-config [OPTION] | |||||||
|  |  | ||||||
| Available values for OPTION include: | Available values for OPTION include: | ||||||
|  |  | ||||||
|  |   --ca        ca bundle install path | ||||||
|   --cc        compiler |   --cc        compiler | ||||||
|   --cflags    pre-processor and compiler flags |   --cflags    pre-processor and compiler flags | ||||||
|   --feature   newline separated list of enabled features |   --feature   newline separated list of enabled features | ||||||
| @@ -43,6 +44,10 @@ while test $# -gt 0; do | |||||||
|     esac |     esac | ||||||
|  |  | ||||||
|     case "$1" in |     case "$1" in | ||||||
|  |     --ca) | ||||||
|  | 	echo @CURL_CA_BUNDLE@ | ||||||
|  | 	;; | ||||||
|  |  | ||||||
|     --cc) |     --cc) | ||||||
| 	echo @CC@ | 	echo @CC@ | ||||||
| 	;; | 	;; | ||||||
| @@ -61,6 +66,30 @@ while test $# -gt 0; do | |||||||
| 	if test "@IPV6_ENABLED@" = "1"; then | 	if test "@IPV6_ENABLED@" = "1"; then | ||||||
|           echo "IPv6" |           echo "IPv6" | ||||||
|         fi |         fi | ||||||
|  | 	if test "@HAVE_LIBZ@" = "1"; then | ||||||
|  |           echo "libz" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_HTTP@" = "1"; then | ||||||
|  |           echo "HTTP-disabled" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_FTP@" = "1"; then | ||||||
|  |           echo "FTP-disabled" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_GOPHER@" = "1"; then | ||||||
|  |           echo "GOPHER-disabled" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_FILE@" = "1"; then | ||||||
|  |           echo "FILE-disabled" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_TELNET@" = "1"; then | ||||||
|  |           echo "TELNET-disabled" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_LDAP@" = "1"; then | ||||||
|  |           echo "LDAP-disabled" | ||||||
|  |         fi | ||||||
|  | 	if test "@CURL_DISABLE_DICT@" = "1"; then | ||||||
|  |           echo "DICT-disabled" | ||||||
|  |         fi | ||||||
| 	;; | 	;; | ||||||
|  |  | ||||||
|     --version) |     --version) | ||||||
| @@ -78,7 +107,11 @@ while test $# -gt 0; do | |||||||
| 	;; | 	;; | ||||||
|  |  | ||||||
|     --cflags) |     --cflags) | ||||||
|        	echo -I@includedir@ |        	if test "X@includedir@" = "X/usr/include"; then | ||||||
|  |           echo "" | ||||||
|  |         else | ||||||
|  |           echo "-I@includedir@" | ||||||
|  |         fi | ||||||
|        	;; |        	;; | ||||||
|  |  | ||||||
|     --libs) |     --libs) | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								curl-mode.el
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								curl-mode.el
									
									
									
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| ;;;; Emacs Lisp help for writing curl code. ;;;; |  | ||||||
|  |  | ||||||
| ;;; In C files, put something like this to load this file automatically: |  | ||||||
| ;; |  | ||||||
| ;;   /* ----------------------------------------------------------------- |  | ||||||
| ;;    * local variables: |  | ||||||
| ;;    * eval: (load-file "../curl-mode.el") |  | ||||||
| ;;    * end: |  | ||||||
| ;;    */ |  | ||||||
| ;; |  | ||||||
| ;; (note: make sure to get the path right in the argument to load-file). |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ;;; The curl hacker's C conventions |  | ||||||
|  |  | ||||||
| ;;; we use intent-level 2 |  | ||||||
| (setq c-basic-offset 2) |  | ||||||
| ;;; never ever use tabs to indent! |  | ||||||
| (setq indent-tabs-mode nil) |  | ||||||
| ;;; I like this, stolen from Subversion! ;-) |  | ||||||
| (setq angry-mob-with-torches-and-pitchforks t) |  | ||||||
							
								
								
									
										50
									
								
								curl-style.el
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								curl-style.el
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | |||||||
|  | ;;;; Emacs Lisp help for writing curl code. ;;;; | ||||||
|  | ;;;; $Id$ | ||||||
|  |  | ||||||
|  | ;;; The curl hacker's C conventions. | ||||||
|  |  | ||||||
|  | ;;; After loading this file and added the mode-hook you can in C | ||||||
|  | ;;; files, put something like this to use the curl style | ||||||
|  | ;;; automatically: | ||||||
|  | ;; | ||||||
|  | ;;   /* ----------------------------------------------------------------- | ||||||
|  | ;;    * local variables: | ||||||
|  | ;;    * eval: (set c-file-style "curl") | ||||||
|  | ;;    * end: | ||||||
|  | ;;    */ | ||||||
|  | ;; | ||||||
|  |  | ||||||
|  | (defconst curl-c-style | ||||||
|  |   '((c-basic-offset . 2) | ||||||
|  |     (c-comment-only-line-offset . 0) | ||||||
|  |     (c-hanging-braces-alist     . ((substatement-open before after))) | ||||||
|  |     (c-offsets-alist . ((topmost-intro        . 0) | ||||||
|  | 			(topmost-intro-cont   . 0) | ||||||
|  | 			(substatement         . +) | ||||||
|  | 			(substatement-open    . 0) | ||||||
|  | 			(statement-case-intro . +) | ||||||
|  | 			(statement-case-open  . 0) | ||||||
|  | 			(case-label           . 0) | ||||||
|  | 			)) | ||||||
|  |     ) | ||||||
|  |   "Curl C Programming Style") | ||||||
|  |  | ||||||
|  | ;; Customizations for all of c-mode, c++-mode, and objc-mode | ||||||
|  | (defun curl-c-mode-common-hook () | ||||||
|  |   "Curl C mode hook" | ||||||
|  |   ;; add curl style and set it for the current buffer | ||||||
|  |   (c-add-style "curl" curl-c-style t) | ||||||
|  |   (setq tab-width 8 | ||||||
|  | 	indent-tabs-mode nil		; Use spaces. Not tabs. | ||||||
|  | 	comment-column 40 | ||||||
|  | 	c-font-lock-extra-types (append '("bool" "CURL" "CURLcode" "ssize_t" "size_t" "socklen_t" "fd_set")) | ||||||
|  | 	) | ||||||
|  |   ;; keybindings for C, C++, and Objective-C.  We can put these in | ||||||
|  |   ;; c-mode-base-map because of inheritance ... | ||||||
|  |   (define-key c-mode-base-map "\M-q" 'c-fill-paragraph) | ||||||
|  |   (setq c-recognize-knr-p nil) | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  | ;; Set this is in your .emacs if you want to use the c-mode-hook as | ||||||
|  | ;; defined here right out of the box. | ||||||
|  | ; (add-hook 'c-mode-common-hook 'curl-c-mode-common-hook) | ||||||
							
								
								
									
										5
									
								
								docs/.cvsignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								docs/.cvsignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | Makefile | ||||||
|  | Makefile.in | ||||||
|  | *html | ||||||
|  | *ps | ||||||
|  | *pdf | ||||||
							
								
								
									
										96
									
								
								docs/BINDINGS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								docs/BINDINGS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,96 @@ | |||||||
|  |                                   _   _ ____  _      | ||||||
|  |                               ___| | | |  _ \| |     | ||||||
|  |                              / __| | | | |_) | |     | ||||||
|  |                             | (__| |_| |  _ <| |___  | ||||||
|  |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
|  |                                libcurl bindings | ||||||
|  |  | ||||||
|  | Creative people have written particular bindings or interfaces for various | ||||||
|  | environments and programming languages. Using one of these allows you to take | ||||||
|  | advantage of curl powers from within your favourite language or system. | ||||||
|  |  | ||||||
|  | This is a list of all known interfaces as of this writing. | ||||||
|  |  | ||||||
|  | The bindings listed below are not part of the curl/libcurl distribution | ||||||
|  | archives, but must be downloaded and installed separately. | ||||||
|  |  | ||||||
|  | Basic | ||||||
|  |  | ||||||
|  |   ScriptBasic bindings to libcurl. Writtten by Peter Verhas. | ||||||
|  |   http://scriptbasic.com/ | ||||||
|  |  | ||||||
|  | C++ | ||||||
|  |  | ||||||
|  |   Maintained by Jean-Philippe Barrette-LaPierre. | ||||||
|  |   http://curl.haxx.se/libcurl/cplusplus/ | ||||||
|  |  | ||||||
|  | Cocoa | ||||||
|  |  | ||||||
|  |   Written by Dan Wood. | ||||||
|  |   http://curlhandle.sourceforge.net/ | ||||||
|  |  | ||||||
|  | Dylan | ||||||
|  |  | ||||||
|  |   Written by Chris Double. | ||||||
|  |   http://dylanlibs.sourceforge.net/ | ||||||
|  |  | ||||||
|  | Java | ||||||
|  |  | ||||||
|  |   Written by Daniel Stenberg. | ||||||
|  |   http://curl.haxx.se/libcurl/java/ | ||||||
|  |  | ||||||
|  | Lua | ||||||
|  |  | ||||||
|  |   Written by Steve Dekorte. | ||||||
|  |   http://curl.haxx.se/libcurl/lua/ | ||||||
|  |  | ||||||
|  | Object-Pascal | ||||||
|  |  | ||||||
|  |   Free Pascal, Delphi and Kylix binding written by Christophe Espern. | ||||||
|  |   http://www.tekool.com/opcurl | ||||||
|  |  | ||||||
|  | Pascal | ||||||
|  |  | ||||||
|  |   Free Pascal, Delphi and Kylix binding written by Jeffrey Pohlmeyer. | ||||||
|  |   http://houston.quik.com/jkp/curlpas/ | ||||||
|  |  | ||||||
|  | Perl | ||||||
|  |  | ||||||
|  |   Maintained by Cris Bailiff. | ||||||
|  |   http://curl.haxx.se/libcurl/perl/ | ||||||
|  |  | ||||||
|  | PHP | ||||||
|  |  | ||||||
|  |   Written by Sterling Hughes. | ||||||
|  |   http://curl.haxx.se/libcurl/php/ | ||||||
|  |  | ||||||
|  | PostgreSQL | ||||||
|  |  | ||||||
|  |   Written by Gian Paolo Ciceri. | ||||||
|  |   http://gborg.postgresql.org/project/pgcurl/projdisplay.php | ||||||
|  |  | ||||||
|  | Python | ||||||
|  |  | ||||||
|  |   Written by Kjetil Jacobsen. | ||||||
|  |   http://pycurl.sourceforge.net/ | ||||||
|  |  | ||||||
|  | Rexx | ||||||
|  |  | ||||||
|  |   Written Mark Hessling.  | ||||||
|  |   http://rexxcurl.sourceforge.net/ | ||||||
|  |  | ||||||
|  | Ruby | ||||||
|  |  | ||||||
|  |   Written by Hirotaka Matsuyuki.  | ||||||
|  |   http://www.d1.dion.ne.jp/~matuyuki/ruby.html | ||||||
|  |  | ||||||
|  | Scheme | ||||||
|  |  | ||||||
|  |   Bigloo binding written by Kirill Lisovsky. | ||||||
|  |   http://curl.haxx.se/libcurl/scheme/ | ||||||
|  |  | ||||||
|  | Tcl | ||||||
|  |  | ||||||
|  |   Written by Andr<64>s Garc<72>a.  | ||||||
|  |   http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html | ||||||
							
								
								
									
										41
									
								
								docs/BUGS
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								docs/BUGS
									
									
									
									
									
								
							| @@ -8,28 +8,47 @@ $Id$ | |||||||
| BUGS | BUGS | ||||||
|  |  | ||||||
|   Curl and libcurl have grown substantially since the beginning. At the time |   Curl and libcurl have grown substantially since the beginning. At the time | ||||||
|   of writing (mid March 2001), there are 23000 lines of source code, and by |   of writing (end of March 2003), there are 35000 lines of source code, and by | ||||||
|   the time you read this it has probably grown even more. |   the time you read this it has probably grown even more. | ||||||
|  |  | ||||||
|   Of course there are lots of bugs left. And lots of misfeatures. |   Of course there are lots of bugs left. And lots of misfeatures. | ||||||
|  |  | ||||||
|   To help us make curl the stable and solid product we want it to be, we need |   To help us make curl the stable and solid product we want it to be, we need | ||||||
|   bug reports and bug fixes. If you can't fix a bug yourself and submit a fix |   bug reports and bug fixes. | ||||||
|   for it, try to report an as detailed report as possible to the curl mailing |  | ||||||
|   list to allow one of us to have a go at a solution. You should also post | WHERE TO REPORT | ||||||
|   your bug/problem at curl's bug tracking system over at |  | ||||||
|  |   If you can't fix a bug yourself and submit a fix for it, try to report an as | ||||||
|  |   detailed report as possible to a curl mailing list to allow one of us to | ||||||
|  |   have a go at a solution. You should also post your bug/problem at curl's bug | ||||||
|  |   tracking system over at | ||||||
|  |  | ||||||
|         http://sourceforge.net/bugs/?group_id=976 |         http://sourceforge.net/bugs/?group_id=976 | ||||||
|  |  | ||||||
|  |   (but please read the sections below first before doing that) | ||||||
|  |  | ||||||
|  |   If you feel you need to ask around first, find a suitable mailing list and | ||||||
|  |   post there. The lists are available on http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
|  | WHAT TO REPORT | ||||||
|  |  | ||||||
|   When reporting a bug, you should include information that will help us |   When reporting a bug, you should include information that will help us | ||||||
|   understand what's wrong, what you expected to happen and how to repeat the |   understand what's wrong, what you expected to happen and how to repeat the | ||||||
|   bad behavior. You therefore need to supply your operating system's name and |   bad behavior. You therefore need to tell us: | ||||||
|   version number (uname -a under a unix is fine), what version of curl you're |  | ||||||
|   using (curl -V is fine), what URL you were working with and anything else |  | ||||||
|   you think matters. |  | ||||||
|  |  | ||||||
|   Since curl deals with networks, it often helps us a lot if you include a |    - your operating system's name and version number (uname -a under a unix | ||||||
|   protocol debug dump with your bug report. The output you get by using the -v |      is fine) | ||||||
|  |    - what version of curl you're using (curl -V is fine) | ||||||
|  |    - what URL you were working with (if possible), at least which protocol | ||||||
|  |  | ||||||
|  |   and anything and everything else you think matters. Tell us what you | ||||||
|  |   expected to happen, tell use what did happen, tell us how you could make it | ||||||
|  |   work another way. Dig around, try out, test. Then include all the tiny bits | ||||||
|  |   and pieces in your report. You will benefit from this yourself, as it will | ||||||
|  |   enable us to help you quicker and more accurately. | ||||||
|  |  | ||||||
|  |   Since curl deals with networks, it often helps us if you include a protocol | ||||||
|  |   debug dump with your bug report. The output you get by using the -v | ||||||
|   flag. Usually, you also get more info by using -i so that is likely to be |   flag. Usually, you also get more info by using -i so that is likely to be | ||||||
|   useful when reporting bugs as well. |   useful when reporting bugs as well. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -6,15 +6,16 @@ | |||||||
|  |  | ||||||
| To Think About When Contributing Source Code | To Think About When Contributing Source Code | ||||||
|  |  | ||||||
|  This document is intended to offer some guidelines that can be useful to keep |  This document is intended to offer some simple guidelines that can be useful | ||||||
|  in mind when you decide to write a contribution to the project. This concerns |  to keep in mind when you decide to contribute to the project. This concerns | ||||||
|  new features as well as corrections to existing flaws or bugs. |  new features as well as corrections to existing flaws or bugs. | ||||||
|  |  | ||||||
| Join the Community | Join the Community | ||||||
|  |  | ||||||
|  Skip over to http://curl.haxx.se/mail/ and join the appropriate mailing |  Skip over to http://curl.haxx.se/mail/ and join the appropriate mailing | ||||||
|  list(s).  Read up on details before you post questions. Read this file before |  list(s).  Read up on details before you post questions. Read this file before | ||||||
|  you start sending patches! |  you start sending patches! We prefer patches and discussions being held on | ||||||
|  |  the mailing list(s), not sent to individuals. | ||||||
|  |  | ||||||
| The License Issue | The License Issue | ||||||
|  |  | ||||||
| @@ -29,9 +30,9 @@ The License Issue | |||||||
|  |  | ||||||
| What To Read | What To Read | ||||||
|  |  | ||||||
|  Source code, the man pages, the INTERALS document, the TODO, the most recent |  Source code, the man pages, the INTERNALS document, the TODO, the most recent | ||||||
|  CHANGES. Just lurking on the libcurl mailing list is gonna give you a lot of |  CHANGES. Just lurking on the libcurl mailing list is gonna give you a lot of | ||||||
|  insights on what's going on right now. |  insights on what's going on right now. Asking there is a good idea too. | ||||||
|  |  | ||||||
| Naming | Naming | ||||||
|  |  | ||||||
| @@ -39,26 +40,32 @@ Naming | |||||||
|  names. It doesn't necessarily have to mean that you should use the same as in |  names. It doesn't necessarily have to mean that you should use the same as in | ||||||
|  other places of the code, just that the names should be logical, |  other places of the code, just that the names should be logical, | ||||||
|  understandable and be named according to what they're used for. File-local |  understandable and be named according to what they're used for. File-local | ||||||
|  functions should be made static. |  functions should be made static. We like lower case names. | ||||||
|  |  | ||||||
|  |  See the INTERNALS document on how we name non-exported library-global | ||||||
|  |  symbols. | ||||||
|  |  | ||||||
| Indenting | Indenting | ||||||
|  |  | ||||||
|  Please try using the same indenting levels and bracing method as all the |  Please try using the same indenting levels and bracing method as all the | ||||||
|  other code already does. It makes the source code a lot easier to follow if |  other code already does. It makes the source code a lot easier to follow if | ||||||
|  all of it is written using the same style. We don't ask you to like it, we |  all of it is written using the same style. We don't ask you to like it, we | ||||||
|  just ask you to follow the tradition! ;-) |  just ask you to follow the tradition! ;-) This mainly means: 2-level indents, | ||||||
|  |  using spaces only (no tabs) and having the opening brace ({) on the same line | ||||||
|  |  as the if() or while(). | ||||||
|  |  | ||||||
| Commenting | Commenting | ||||||
|  |  | ||||||
|  Comment your source code extensively. Commented code is quality code and |  Comment your source code extensively using C comments (/* comment */), DO NOT | ||||||
|  enables future modifications much more. Uncommented code much more risk being |  use C++ comments (// this style). Commented code is quality code and enables | ||||||
|  |  future modifications much more. Uncommented code much more risk being | ||||||
|  completely replaced when someone wants to extend things, since other persons' |  completely replaced when someone wants to extend things, since other persons' | ||||||
|  source code can get quite hard to read. |  source code can get quite hard to read. | ||||||
|  |  | ||||||
| General Style | General Style | ||||||
|  |  | ||||||
|  Keep your functions small. If they're small you avoid a lot of mistakes and |  Keep your functions small. If they're small you avoid a lot of mistakes and | ||||||
|  you don't accidentally mix up variables. |  you don't accidentally mix up variables etc. | ||||||
|  |  | ||||||
| Non-clobbering All Over | Non-clobbering All Over | ||||||
|  |  | ||||||
| @@ -69,7 +76,14 @@ Non-clobbering All Over | |||||||
|  functionality, try writing it in a new source file. If you fix bugs, try to |  functionality, try writing it in a new source file. If you fix bugs, try to | ||||||
|  fix one bug at a time and send them as separate patches. |  fix one bug at a time and send them as separate patches. | ||||||
|  |  | ||||||
| Separate Patches Doing Different Things | Platform Dependent Code | ||||||
|  |  | ||||||
|  |  Use #ifdef HAVE_FEATURE to do conditional code. We avoid checking for | ||||||
|  |  particular operating systems or hardware in the #ifdef lines. The | ||||||
|  |  HAVE_FEATURE shall be generated by the configure script for unix-like systems | ||||||
|  |  and they are hard-coded in the config-[system].h files for the others. | ||||||
|  |  | ||||||
|  | Separate Patches | ||||||
|  |  | ||||||
|  It is annoying when you get a huge patch from someone that is said to fix 511 |  It is annoying when you get a huge patch from someone that is said to fix 511 | ||||||
|  odd problems, but discussions and opinions don't agree with 510 of them - or |  odd problems, but discussions and opinions don't agree with 510 of them - or | ||||||
| @@ -94,6 +108,10 @@ Document | |||||||
|  small description of your fix or your new features with every contribution so |  small description of your fix or your new features with every contribution so | ||||||
|  that it can be swiftly added to the package documentation. |  that it can be swiftly added to the package documentation. | ||||||
|  |  | ||||||
|  |  The documentation is always made in man pages (nroff formatted) or plain | ||||||
|  |  ASCII files. All HTML files on the web site and in the release archives are | ||||||
|  |  generated from the nroff/ASCII versions. | ||||||
|  |  | ||||||
| Write Access to CVS Repository | Write Access to CVS Repository | ||||||
|  |  | ||||||
|  If you are a frequent contributor, or have another good reason, you can of |  If you are a frequent contributor, or have another good reason, you can of | ||||||
| @@ -111,3 +129,31 @@ Test Cases | |||||||
|  in the test suite. Every feature that is added should get at least one valid |  in the test suite. Every feature that is added should get at least one valid | ||||||
|  test case that verifies that it works as documented. If every submitter also |  test case that verifies that it works as documented. If every submitter also | ||||||
|  post a few test cases, it won't end up as a heavy burden on a single person! |  post a few test cases, it won't end up as a heavy burden on a single person! | ||||||
|  |  | ||||||
|  | How To Make a Patch | ||||||
|  |  | ||||||
|  |  Keep a copy of the unmodified curl sources. Make your changes in a separate | ||||||
|  |  source tree. When you think you have something that you want to offer the | ||||||
|  |  curl community, use GNU diff to generate patches. | ||||||
|  |  | ||||||
|  |  If you have modified a single file, try something like: | ||||||
|  |  | ||||||
|  |      diff -u undmodified-file.c my-changed-one.c > my-fixes.diff | ||||||
|  |  | ||||||
|  |  If you have modified several files, possibly in different directories, you | ||||||
|  |  can use diff recursively: | ||||||
|  |  | ||||||
|  |      diff -ur curl-original-dir curl-modfied-sources-dir > my-fixes.diff | ||||||
|  |  | ||||||
|  |  The GNU diff and GNU patch tools exist for virtually all platforms, including | ||||||
|  |  all kinds of unixes and Windows: | ||||||
|  |  | ||||||
|  |  For unix-like operating systems: | ||||||
|  |  | ||||||
|  |         http://www.fsf.org/software/patch/patch.html | ||||||
|  |         http://www.gnu.org/directory/diffutils.html | ||||||
|  |  | ||||||
|  |  For Windows: | ||||||
|  |  | ||||||
|  |         http://gnuwin32.sourceforge.net/packages/patch.htm | ||||||
|  |         http://gnuwin32.sourceforge.net/packages/diffutils.htm | ||||||
|   | |||||||
							
								
								
									
										261
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										261
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| Updated: December 21, 2001 (http://curl.haxx.se/docs/faq.shtml) | Updated: May 9, 2003 (http://curl.haxx.se/docs/faq.html) | ||||||
|                                   _   _ ____  _      |                                   _   _ ____  _      | ||||||
|                               ___| | | |  _ \| |     |                               ___| | | |  _ \| |     | ||||||
|                              / __| | | | |_) | |     |                              / __| | | | |_) | |     | ||||||
| @@ -15,6 +15,7 @@ FAQ | |||||||
|   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? | ||||||
|  |  | ||||||
|  2. Install Related Problems |  2. Install Related Problems | ||||||
|   2.1 configure doesn't find OpenSSL even when it is installed |   2.1 configure doesn't find OpenSSL even when it is installed | ||||||
| @@ -30,13 +31,15 @@ FAQ | |||||||
|   3.3 Why doesn't my posting using -F work? |   3.3 Why doesn't my posting using -F work? | ||||||
|   3.4 How do I tell curl to run custom FTP commands? |   3.4 How do I tell curl to run custom FTP commands? | ||||||
|   3.5 How can I disable the Pragma: nocache header? |   3.5 How can I disable the Pragma: nocache header? | ||||||
|   3.6 Does curl support javascript, ASP, XML, XHTML or HTML version Y? |   3.6 Does curl support ASP, XML, XHTML or HTML version Y? | ||||||
|   3.7 Can I use curl to delete/rename a file through FTP? |   3.7 Can I use curl to delete/rename a file through FTP? | ||||||
|   3.8 How do I tell curl to follow HTTP redirects? |   3.8 How do I tell curl to follow HTTP redirects? | ||||||
|   3.9 How do I use curl in my favourite programming language? |   3.9 How do I use curl in my favorite programming language? | ||||||
|   3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP? |   3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP? | ||||||
|   3.11 How do I POST with a different Content-Type? |   3.11 How do I POST with a different Content-Type? | ||||||
|   3.12 Why do FTP specific features over HTTP proxy fail? |   3.12 Why do FTP specific features over HTTP proxy fail? | ||||||
|  |   3.13 Why does my single/double quotes fail? | ||||||
|  |   3.14 Does curl support javascript or pac (automated proxy config)? | ||||||
|  |  | ||||||
|  4. Running Problems |  4. Running Problems | ||||||
|   4.1 Problems connecting to SSL servers. |   4.1 Problems connecting to SSL servers. | ||||||
| @@ -54,6 +57,9 @@ FAQ | |||||||
|   4.7 How do I keep user names and passwords secret in Curl command lines? |   4.7 How do I keep user names and passwords secret in Curl command lines? | ||||||
|   4.8 I found a bug! |   4.8 I found a bug! | ||||||
|   4.9 Curl can't authenticate to the server that requires NTLM? |   4.9 Curl can't authenticate to the server that requires NTLM? | ||||||
|  |   4.10 My HTTP request using HEAD, PUT or DELETE doesn't work! | ||||||
|  |   4.11 Why does my HTTP range requests return the full document? | ||||||
|  |   4.12 Why do I get "certificate verify failed" ? | ||||||
|  |  | ||||||
|  5. libcurl Issues |  5. libcurl Issues | ||||||
|   5.1 Is libcurl thread-safe? |   5.1 Is libcurl thread-safe? | ||||||
| @@ -62,6 +68,7 @@ FAQ | |||||||
|   5.4 Does libcurl do Winsock initing on win32 systems? |   5.4 Does libcurl do Winsock initing on win32 systems? | ||||||
|   5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ? |   5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ? | ||||||
|   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! | ||||||
|  |  | ||||||
|  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,7 +87,9 @@ FAQ | |||||||
|   cURL (or simply just 'curl') is a command line tool for getting or sending |   cURL (or simply just 'curl') is a command line tool for getting or sending | ||||||
|   files using URL syntax. The name is a play on 'Client for URLs', originally |   files using URL syntax. The name is a play on 'Client for URLs', originally | ||||||
|   with URL spelled in uppercase to make it obvious it deals with URLs. The |   with URL spelled in uppercase to make it obvious it deals with URLs. The | ||||||
|   fact it can also be pronounced 'see URL' also helped. |   fact it can also be pronounced 'see URL' also helped, it works as an | ||||||
|  |   abbrivation for "Client URL Request Library" or why not the recursive | ||||||
|  |   version: "Curl is a URL Request Library". | ||||||
|  |  | ||||||
|   Curl supports a range of common Internet protocols, currently including |   Curl supports a range of common Internet protocols, currently including | ||||||
|   HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE. |   HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE. | ||||||
| @@ -88,6 +97,12 @@ FAQ | |||||||
|   We spell it cURL or just curl. We pronounce it with an initial k sound: |   We spell it cURL or just curl. We pronounce it with an initial k sound: | ||||||
|   [kurl]. |   [kurl]. | ||||||
|  |  | ||||||
|  |   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 | ||||||
|  |   notice that this FAQ is directed at the command-line tool named curl (and | ||||||
|  |   libcurl the library), and may therefore not be valid for other curl | ||||||
|  |   projects. | ||||||
|  |  | ||||||
|   1.2 What is libcurl? |   1.2 What is libcurl? | ||||||
|  |  | ||||||
|   libcurl is a reliable and portable library which provides you with an easy |   libcurl is a reliable and portable library which provides you with an easy | ||||||
| @@ -123,11 +138,9 @@ FAQ | |||||||
|   better. We do however believe in a few rules when it comes to the future of |   better. We do however believe in a few rules when it comes to the future of | ||||||
|   curl: |   curl: | ||||||
|  |  | ||||||
|   * Curl is to remain a command line tool. If you want GUIs or fancy scripting |   * Curl -- the command line tool -- is to remain a non-graphical command line | ||||||
|     capabilities, you're free to write another tool that uses libcurl and that |     tool. If you want GUIs or fancy scripting capabilities, you should look | ||||||
|     offers this. There's no point in having a single tool that does every |     for another tool that uses libcurl. | ||||||
|     imaginable thing. That's also one of the great advantages of having the |  | ||||||
|     core of curl as a library. |  | ||||||
|  |  | ||||||
|   * We do not add things to curl that other small and available tools already |   * We do not add things to curl that other small and available tools already | ||||||
|     do very fine at the side. Curl's output is fine to pipe into another |     do very fine at the side. Curl's output is fine to pipe into another | ||||||
| @@ -150,10 +163,10 @@ FAQ | |||||||
|   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 various people's submissions are |   Stenberg writes the major parts, but other persons' submissions are | ||||||
|   important and crucial. Anyone can post their changes and improvements and |   important and crucial. Anyone can contribute and post their changes and | ||||||
|   have them inserted in the main sources (of course on the condition that |   improvements and have them inserted in the main sources (of course on the | ||||||
|   developers agree on that the fixes are good). |   condition that developers agree on that the fixes are good). | ||||||
|  |  | ||||||
|   The list of contributors in the docs/THANKS file is only a small part of all |   The list of contributors in the docs/THANKS file is only a small part of all | ||||||
|   the people that every day provide us with bug reports, suggestions, ideas |   the people that every day provide us with bug reports, suggestions, ideas | ||||||
| @@ -163,24 +176,24 @@ FAQ | |||||||
|  |  | ||||||
|   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, without any commercial interests or |   Project cURL is entirely free and open. No person gets paid for developing | ||||||
|   money involved. No person gets paid in any way for developing curl. We all |   curl. We do this voluntarily on our spare time. | ||||||
|   do this voluntarily on our spare time. |  | ||||||
|  |  | ||||||
|   We get some help from companies. Contactor Data hosts the curl web site and |   We get some help from companies. Contactor Data hosts the curl web site, | ||||||
|   the main mailing list, Haxx owns the curl web site's domain and |   Haxx owns the curl web site's domain and sourceforge.net hosts several | ||||||
|   sourceforge.net hosts several project tools we take advantage from like the |   project services we take advantage from, like the bug tracker, mailing lists | ||||||
|   bug tracker, mailing lists and more. |   and more. | ||||||
|  |  | ||||||
|   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 | ||||||
|   sites, such as amazon.com or thinkgeek.com. Another way would be to sponsor |   sites, such as amazon.com or thinkgeek.com. Another way would be to sponsor | ||||||
|   us through a banner-program or by simply helping us coding, documenting, |   us through a banner-program or even better: by helping us coding, | ||||||
|   testing etc. |   documenting, testing etc. You're welcome to send us a buck using paypal, as | ||||||
|  |   described here: http://curl.haxx.se/donation.html | ||||||
|  |  | ||||||
|   1.7 What about CURL from curl.com? |   1.7 What about CURL from curl.com? | ||||||
|  |  | ||||||
|   During the summer 2001, curl.com has been busy advertising their client-side |   During the summer 2001, curl.com was busy advertising their client-side | ||||||
|   programming language for the web, named CURL. |   programming language for the web, named CURL. | ||||||
|  |  | ||||||
|   We are in no way associated with curl.com or their CURL programming |   We are in no way associated with curl.com or their CURL programming | ||||||
| @@ -193,6 +206,21 @@ FAQ | |||||||
|   We recognize that we will be living in parallel with curl.com and wish them |   We recognize that we will be living in parallel with curl.com and wish them | ||||||
|   every success. |   every success. | ||||||
|  |  | ||||||
|  |   1.8 I have a problem who do I mail? | ||||||
|  |  | ||||||
|  |   Please do not mail any single individual unless you really need to. Keep | ||||||
|  |   curl-related questions on a suitable mailing list. All available mailing | ||||||
|  |   lists are listed in the MANUAL document and online at | ||||||
|  |   http://curl.haxx.se/mail/ | ||||||
|  |  | ||||||
|  |   Keeping curl-related questions and discussions on mailing lists allows | ||||||
|  |   others to join in and help, to share their ideas, contribute their | ||||||
|  |   suggestions and spread their wisdom. Keeping discussions on public mailing | ||||||
|  |   lists also allows for others to learn from this (both current and future | ||||||
|  |   users thanks to the web based archives of the mailing lists), thus saving us | ||||||
|  |   from having to repeat ourselves even more. Thanks for respecting this. | ||||||
|  |  | ||||||
|  |  | ||||||
| 2. Install Related Problems | 2. Install Related Problems | ||||||
|  |  | ||||||
|   2.1. configure doesn't find OpenSSL even when it is installed |   2.1. configure doesn't find OpenSSL even when it is installed | ||||||
| @@ -252,8 +280,8 @@ FAQ | |||||||
|  |  | ||||||
|   2.4. Does cURL support Socks (RFC 1928) ? |   2.4. Does cURL support Socks (RFC 1928) ? | ||||||
|  |  | ||||||
|   No. Nobody has wanted it that badly yet. We appreciate patches that bring |   There is limited support for SOCKS5 for curl built with IPv6 support | ||||||
|   this functionality. |   disabled. | ||||||
|  |  | ||||||
|  |  | ||||||
| 3. Usage problems | 3. Usage problems | ||||||
| @@ -308,16 +336,14 @@ FAQ | |||||||
|   the -H/--header option. By adding a header with empty contents you safely |   the -H/--header option. By adding a header with empty contents you safely | ||||||
|   disable that one. Use -H "Pragma:" to disable that specific header. |   disable that one. Use -H "Pragma:" to disable that specific header. | ||||||
|  |  | ||||||
|   3.6. Does curl support javascript, ASP, XML, XHTML or HTML version Y? |   3.6. Does curl support ASP, XML, XHTML or HTML version Y? | ||||||
|  |  | ||||||
|   To curl, all contents are alike. It doesn't matter how the page was |   To curl, all contents are alike. It doesn't matter how the page was | ||||||
|   generated. It may be ASP, PHP, Perl, shell-script, SSI or plain |   generated. It may be ASP, PHP, Perl, shell-script, SSI or plain | ||||||
|   HTML-files. There's no difference to curl and it doesn't even know what kind |   HTML-files. There's no difference to curl and it doesn't even know what kind | ||||||
|   of language that generated the page. |   of language that generated the page. | ||||||
|  |  | ||||||
|   Javascript is slightly different since that is code embedded in the HTML |   See also item 3.14 regarding javascript. | ||||||
|   that is sent for the client to interpret and curl has no javascript |  | ||||||
|   interpreter. |  | ||||||
|  |  | ||||||
|   3.7. Can I use curl to delete/rename a file through FTP? |   3.7. Can I use curl to delete/rename a file through FTP? | ||||||
|  |  | ||||||
| @@ -335,25 +361,22 @@ FAQ | |||||||
|  |  | ||||||
|      curl -L http://redirector.com |      curl -L http://redirector.com | ||||||
|  |  | ||||||
|   3.9 How do I use curl in my favourite programming language? |   3.9 How do I use curl in my favorite programming language? | ||||||
|  |  | ||||||
|   There exist many language interfaces/bindings for curl that integrates it |   There exist many language interfaces/bindings for curl that integrates it | ||||||
|   better with various languages. If you are fluid in a script language, you |   better with various languages. If you are fluid in a script language, you | ||||||
|   may very well opt to use such an interface instead of using the command line |   may very well opt to use such an interface instead of using the command line | ||||||
|   tool. |   tool. | ||||||
|  |  | ||||||
|   At the time of writing, there are bindings for the five language mentioned |  | ||||||
|   above, but chances are there are even more by the time you read this. Or you |  | ||||||
|   may be able you write your own wrapper for a not-yet supported language! |  | ||||||
|  |  | ||||||
|   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 December 2001, there are interfaces available for the following |   In February 2003, there are interfaces available for the following | ||||||
|   languages: C/C++, Cocoa, Dylan, Java, Perl, PHP, Python, Rexx, Ruby, Scheme |   languages: Basic, C, C++, Cocoa, Dylan, Euphoria, Java, Lua, Object-Pascal, | ||||||
|   and Tcl. By the time you read this, additional ones may have appeared! |   Pascal, Perl, PHP, PostgreSQL, Python, Rexx, Ruby, Scheme and Tcl. By the | ||||||
|  |   time you read this, additional ones may have appeared! | ||||||
|  |  | ||||||
|   3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP? |   3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP? | ||||||
|  |  | ||||||
| @@ -362,8 +385,8 @@ FAQ | |||||||
|   XML-RPC are all such ones. You can use -X to set custom requests and -H to |   XML-RPC are all such ones. You can use -X to set custom requests and -H to | ||||||
|   set custom headers (or replace internally generated ones). |   set custom headers (or replace internally generated ones). | ||||||
|  |  | ||||||
|   Using libcurl or PHP's curl modules is just as fine and you'd just use the |   Using libcurl is of course just as fine and you'd just use the proper | ||||||
|   proper library options to do the same. |   library options to do the same. | ||||||
|  |  | ||||||
|   3.11 How do I POST with a different Content-Type? |   3.11 How do I POST with a different Content-Type? | ||||||
|  |  | ||||||
| @@ -376,7 +399,7 @@ FAQ | |||||||
|  |  | ||||||
|   Because when you use a HTTP proxy, the protocol spoken on the network will |   Because when you use a HTTP proxy, the protocol spoken on the network will | ||||||
|   be HTTP, even if you specify a FTP URL. This effectively means that you |   be HTTP, even if you specify a FTP URL. This effectively means that you | ||||||
|   normally can't use FTP specific features such as ftp upload and ftp quote |   normally can't use FTP specific features such as FTP upload and FTP quote | ||||||
|   etc. |   etc. | ||||||
|  |  | ||||||
|   There is one exception to this rule, and that is if you can "tunnel through" |   There is one exception to this rule, and that is if you can "tunnel through" | ||||||
| @@ -384,6 +407,54 @@ FAQ | |||||||
|   and is generally not available as proxy admins usually disable tunneling to |   and is generally not available as proxy admins usually disable tunneling to | ||||||
|   other ports than 443 (which is used for HTTPS access through proxies). |   other ports than 443 (which is used for HTTPS access through proxies). | ||||||
|  |  | ||||||
|  |   3.13 Why does my single/double quotes fail? | ||||||
|  |  | ||||||
|  |   To specify a command line option that includes spaces, you might need to | ||||||
|  |   put the entire option within quotes. Like in: | ||||||
|  |  | ||||||
|  |    curl -d " with spaces " url.com | ||||||
|  |    | ||||||
|  |   or perhaps | ||||||
|  |  | ||||||
|  |    curl -d ' with spaces ' url.com | ||||||
|  |  | ||||||
|  |   Exactly what kind of quotes and how to do this is entirely up to the shell | ||||||
|  |   or command line interpreter that you are using. For most unix shells, you | ||||||
|  |   can more or less pick either single (') or double (") quotes. For | ||||||
|  |   Windows/DOS prompts I believe you're forced to use double (") quotes. | ||||||
|  |  | ||||||
|  |   Please study the documentation for your particular environment. Examples in | ||||||
|  |   the curl docs will use a mix of both these ones as shown above. You must | ||||||
|  |   adjust them to work in your environment. | ||||||
|  |  | ||||||
|  |   Remember that curl works and runs on more operating systems than most single | ||||||
|  |   individuals have ever tried. | ||||||
|  |  | ||||||
|  |   3.14 Does curl support javascript or pac (automated proxy config)? | ||||||
|  |  | ||||||
|  |   Many web pages do magic stuff using embedded javascript. Curl and libcurl | ||||||
|  |   have no built-in support for that, so it will be treated just like any other | ||||||
|  |   contents. | ||||||
|  |  | ||||||
|  |   .pac files are a netscape invention and are sometimes used by organizations | ||||||
|  |   to allow them to differentiate which proxies to use. The .pac contents is | ||||||
|  |   just a javascript program that gets invoked by the browser and that returns | ||||||
|  |   the name of the proxy to connect to. Since curl doesn't support javascript, | ||||||
|  |   it can't support .pac proxy configuration either. | ||||||
|  |  | ||||||
|  |   Some work-arounds usually suggested to overcome this javascript dependency: | ||||||
|  |  | ||||||
|  |     - Depending on the javascript complexity, write up a script that | ||||||
|  |       translates it to another language and execute that. | ||||||
|  |  | ||||||
|  |     - Read the javascript code and rewrite the same logic in another language. | ||||||
|  |  | ||||||
|  |     - Implement a javascript interpreted, people have successfully used the | ||||||
|  |       Mozilla javascript engine in the past. | ||||||
|  |  | ||||||
|  |     - Ask your admins to stop this, for a static proxy setup or similar. | ||||||
|  |  | ||||||
|  |  | ||||||
| 4. Running Problems | 4. Running Problems | ||||||
|  |  | ||||||
|   4.1. Problems connecting to SSL servers. |   4.1. Problems connecting to SSL servers. | ||||||
| @@ -412,11 +483,12 @@ FAQ | |||||||
|  |  | ||||||
|      curl 'http://www.altavista.com/cgi-bin/query?text=yes&q=curl' |      curl 'http://www.altavista.com/cgi-bin/query?text=yes&q=curl' | ||||||
|  |  | ||||||
|   In win32, the standard DOS shell treats the %-letter specially and you may |   In Windows, the standard DOS shell treats the %-letter specially and you | ||||||
|   need to quote the string properly when % is used in it. |   need to use TWO %-letters for each single one you want to use in the URL. | ||||||
|  |  | ||||||
|   Also note that if you want the literal %-letter to be part of the data you |   Also note that if you want the literal %-letter to be part of the data you | ||||||
|   pass in a POST using -d/--data you must encode it as '%25'. |   pass in a POST using -d/--data you must encode it as '%25' (which then also | ||||||
|  |   needs the %-letter doubled on Windows machines). | ||||||
|  |  | ||||||
|   4.3. How can I use {, }, [ or ] to specify multiple URLs? |   4.3. How can I use {, }, [ or ] to specify multiple URLs? | ||||||
|  |  | ||||||
| @@ -428,8 +500,7 @@ FAQ | |||||||
|     curl '{curl,www}.haxx.se' |     curl '{curl,www}.haxx.se' | ||||||
|  |  | ||||||
|   To be able to use those letters as actual parts of the URL (without using |   To be able to use those letters as actual parts of the URL (without using | ||||||
|   them for the curl URL "globbing" system), use the -g/--globoff option (curl |   them for the curl URL "globbing" system), use the -g/--globoff option: | ||||||
|   7.6 and later): |  | ||||||
|  |  | ||||||
|     curl -g 'www.site.com/weirdname[].html' |     curl -g 'www.site.com/weirdname[].html' | ||||||
|  |  | ||||||
| @@ -475,7 +546,7 @@ FAQ | |||||||
|  |  | ||||||
|     4.5.6 "301 Moved Permanently" |     4.5.6 "301 Moved Permanently" | ||||||
|   |   | ||||||
|     If you get this return code and an HTML outpt similar to this: |     If you get this return code and an HTML output similar to this: | ||||||
|  |  | ||||||
|        <H1>Moved Permanently</H1> The document has moved <A |        <H1>Moved Permanently</H1> The document has moved <A | ||||||
|        HREF="http://same_url_now_with_a_trailing_slash/">here</A>. |        HREF="http://same_url_now_with_a_trailing_slash/">here</A>. | ||||||
| @@ -517,12 +588,8 @@ FAQ | |||||||
|   particular platform, try contacting the person who built the package/archive |   particular platform, try contacting the person who built the package/archive | ||||||
|   you have. |   you have. | ||||||
|  |  | ||||||
|   If there is a bug, post a bug report in the Curl Bug Track System over at |   If there is a bug, read the BUGS document first. Then report it as described | ||||||
|   http://sourceforge.net/bugs/?group_id=976 |   in there. | ||||||
|  |  | ||||||
|   Always include as many details you can think of, including curl version, |  | ||||||
|   operating system name and version and complete instructions how to repeat |  | ||||||
|   the bug. |  | ||||||
|  |  | ||||||
|   4.9. Curl can't authenticate to the server that requires NTLM? |   4.9. Curl can't authenticate to the server that requires NTLM? | ||||||
|  |  | ||||||
| @@ -530,6 +597,46 @@ FAQ | |||||||
|   currently support that. Proprietary formats are evil. You should not use |   currently support that. Proprietary formats are evil. You should not use | ||||||
|   such ones. |   such ones. | ||||||
|  |  | ||||||
|  |   4.10 My HTTP request using HEAD, PUT or DELETE doesn't work! | ||||||
|  |  | ||||||
|  |   Many web servers allow or demand that the administrator configures the | ||||||
|  |   server properly for these requests to work on the web server. | ||||||
|  |  | ||||||
|  |   Some servers seem to support HEAD only on certain kinds of URLs. | ||||||
|  |  | ||||||
|  |   To fully grasp this, try the documentation for the particular server | ||||||
|  |   software you're trying to interact with. This is not anything curl can do | ||||||
|  |   anything about. | ||||||
|  |  | ||||||
|  |   4.11 Why does my HTTP range requests return the full document? | ||||||
|  |  | ||||||
|  |   Because the range may not be supported by the server, or the server may | ||||||
|  |   choose to ignore it and return the full document anyway. | ||||||
|  |  | ||||||
|  |   4.12 Why do I get "certificate verify failed" ? | ||||||
|  |  | ||||||
|  |   You invoke curl 7.10 or later to communicate on a https:// URL and get an | ||||||
|  |   error back looking something similar to this: | ||||||
|  |  | ||||||
|  |       curl: (35) SSL: error:14090086:SSL routines:  | ||||||
|  |       SSL3_GET_SERVER_CERTIFICATE:certificate verify failed | ||||||
|  |  | ||||||
|  |   Then it means that curl couldn't verify that the server's certificate was | ||||||
|  |   good. Curl verifies the certificate using the CA cert bundle that comes with | ||||||
|  |   the curl installation. | ||||||
|  |  | ||||||
|  |   To disable the verification (which makes it act like curl did before 7.10), | ||||||
|  |   use -k. This does however enable man-in-the-middle attacks. | ||||||
|  |  | ||||||
|  |   If you get this failure but are having a CA cert bundle installed and used, | ||||||
|  |   the server's certificate is not signed by one of the CA's in the bundle. It | ||||||
|  |   might for example be self-signed. You then correct this problem by obtaining | ||||||
|  |   a valid CA cert for the server. Or again, decrease the security by disabling | ||||||
|  |   this check. | ||||||
|  |  | ||||||
|  |   Details are also in the SSLCERTS file in the release archives, found online | ||||||
|  |   here: http://curl.haxx.se/docs/sslcerts.html | ||||||
|  |  | ||||||
| 5. libcurl Issues | 5. libcurl Issues | ||||||
|  |  | ||||||
|   5.1. Is libcurl thread-safe? |   5.1. Is libcurl thread-safe? | ||||||
| @@ -580,20 +687,15 @@ FAQ | |||||||
|  |  | ||||||
|   5.3 How do I fetch multiple files with libcurl? |   5.3 How do I fetch multiple files with libcurl? | ||||||
|  |  | ||||||
|   Starting with version 7.7, curl and libcurl will have excellent support for |   libcurl has excellent support for transferring multiple files. You should | ||||||
|   transferring multiple files. You should just repeatedly set new URLs with |   just repeatedly set new URLs with curl_easy_setopt() and then transfer it | ||||||
|   curl_easy_setopt() and then transfer it with curl_easy_perform(). The handle |   with curl_easy_perform(). The handle you get from curl_easy_init() is not | ||||||
|   you get from curl_easy_init() is not only reusable starting with libcurl |   only reusable, but you're even encouraged to reuse it if you can, as that | ||||||
|   7.7, but also you're encouraged to reuse it if you can, as that will enable |   will enable libcurl to use persistent connections. | ||||||
|   libcurl to use persistent connections. |  | ||||||
|  |  | ||||||
|   For libcurl prior to 7.7, there was no multiple file support. The only |  | ||||||
|   available way to do multiple requests was to init/perform/cleanup for each |  | ||||||
|   transfer. |  | ||||||
|  |  | ||||||
|   5.4 Does libcurl do Winsock initialization on win32 systems? |   5.4 Does libcurl do Winsock initialization on win32 systems? | ||||||
|  |  | ||||||
|   Yes (since 7.8.1) if told to in the curl_global_init() call. |   Yes, if told to in the curl_global_init() call. | ||||||
|  |  | ||||||
|   5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ? |   5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ? | ||||||
|  |  | ||||||
| @@ -607,22 +709,31 @@ FAQ | |||||||
|  |  | ||||||
|   5.6 What about Keep-Alive or persistent connections? |   5.6 What about Keep-Alive or persistent connections? | ||||||
|  |  | ||||||
|   Starting with version 7.7, curl and libcurl will have excellent support for |   curl and libcurl have excellent support for persistent connections when | ||||||
|   persistent connections when transferring several files from the same server. |   transferring several files from the same server.  Curl will attempt to reuse | ||||||
|   Curl will attempt to reuse connections for all URLs specified on the same |   connections for all URLs specified on the same command line/config file, and | ||||||
|   command line/config file, and libcurl will reuse connections for all |   libcurl will reuse connections for all transfers that are made using the | ||||||
|   transfers that are made using the same libcurl handle. |   same libcurl handle. | ||||||
|  |  | ||||||
|  |   5.7 Link errors when building libcurl on Windows! | ||||||
|  |  | ||||||
|  |   You need to make sure that your project, and all the libraries (both static | ||||||
|  |   and dynamic) that it links against, are compiled/linked against the same run | ||||||
|  |   time library. | ||||||
|  |  | ||||||
|  |   This is determined by the /MD, /ML, /MT (and their corresponding /M?d) | ||||||
|  |   options to the command line compiler. /MD (linking against MSVCRT dll) seems | ||||||
|  |   to be the most commonly used option. | ||||||
|  |  | ||||||
|  |   (Provided by Andrew Francis) | ||||||
|  |  | ||||||
|   Previous versions had no persistent connection support. |  | ||||||
|  |  | ||||||
| 6. License Issues | 6. License Issues | ||||||
|  |  | ||||||
|   Curl and libcurl are released under a MIT/X derivate license *or* the MPL, |   Curl and libcurl are released under a MIT/X derivate license. The license is | ||||||
|   the Mozilla Public License. To get a really good answer to your license |   very liberal and should not impose a problem for your project. This section | ||||||
|   conflict questions, you should study the MPL and MIT/X licenses and the |   is just a brief summary for the cases we get the most questions. (Parts of | ||||||
|   license you are about to use and check for clashes yourself. This section is |   this section was much enhanced by Bjorn Reese.) | ||||||
|   just a brief summary for the cases we get the most questions. (Parts of this |  | ||||||
|   section was much enhanced by Bjorn Reese.) |  | ||||||
|  |  | ||||||
|   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? | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										116
									
								
								docs/HISTORY
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								docs/HISTORY
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | |||||||
|  |                                   _   _ ____  _      | ||||||
|  |                               ___| | | |  _ \| |     | ||||||
|  |                              / __| | | | |_) | |     | ||||||
|  |                             | (__| |_| |  _ <| |___  | ||||||
|  |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
|  |                           How cURL Became Like This | ||||||
|  |  | ||||||
|  |  | ||||||
|  | In the second half of 1997, Daniel Stenberg came up with the idea to make | ||||||
|  | currency-exchange calculations available to Internet Relay Chat (IRC) | ||||||
|  | users. All the necessary data are published on the Web; he just needed to | ||||||
|  | automate their retrieval. | ||||||
|  |  | ||||||
|  | Daniel simply adopted an existing command-line open-source tool, httpget, that | ||||||
|  | Brazilian Rafael Sagula had written. After a few minor adjustments, it did | ||||||
|  | just what he needed. | ||||||
|  |  | ||||||
|  | Soon, he found currencies on a GOPHER site, so support for that had to go in, | ||||||
|  | and not before long FTP download support was added as well. The name of the | ||||||
|  | project was changed to urlget to better fit what it actually did now, since | ||||||
|  | the http-only days were already passed. | ||||||
|  |  | ||||||
|  | The project slowly grew bigger. When upload capabilities were added and the | ||||||
|  | name once again was misleading, a second name change was made and on March 20, | ||||||
|  | 1998 curl 4 was released. (The version numbering from the previous names were | ||||||
|  | kept.) | ||||||
|  |  | ||||||
|  | (Unrelated to this project a company called Curl Corporation filed a US | ||||||
|  | trademark on the name "CURL" on May 18 1998. That company had then already | ||||||
|  | registered the curl.com domain back in November of the previous year. All this | ||||||
|  | was much later brought into the lights.) | ||||||
|  |  | ||||||
|  | SSL support was added, powered by the SSLeay library. | ||||||
|  |  | ||||||
|  | August 1998, added project curl to freshmeat.net. | ||||||
|  |  | ||||||
|  | October 1998, with the curl 4.9 release and the introduction of cookie | ||||||
|  | support, curl was no longer released under the GPL license. Now we're at 4000 | ||||||
|  | lines of code, we switched over to the MPL license to restrict the effects of | ||||||
|  | "copyleft". | ||||||
|  |  | ||||||
|  | November 1998, configure script and reported successful compiles on several | ||||||
|  | major operating systems. The never-quite-understood -F option was added and | ||||||
|  | curl could now simulate quite a lot of a browser. | ||||||
|  |  | ||||||
|  | Curl 5 was released in December 1998 and introduced the first ever curl man | ||||||
|  | page. People started making Linux RPM packages out of it. | ||||||
|  |  | ||||||
|  | January 1999, DICT support added. | ||||||
|  |  | ||||||
|  | OpenSSL took over where SSLeay was abandoned. | ||||||
|  |  | ||||||
|  | May 1999, first Debian package. | ||||||
|  |  | ||||||
|  | August 1999, LDAP:// and FILE:// support added. The curl web site gets 1300 | ||||||
|  | visits weekly. | ||||||
|  |  | ||||||
|  | Released curl 6.0 in September. 15000 lines of code. | ||||||
|  |  | ||||||
|  | December 28 1999, added the project on Sourceforge and started using its | ||||||
|  | services for managing the project. | ||||||
|  |  | ||||||
|  | Spring 2000, major internal overhaul to provide a suitable library interface. | ||||||
|  | The first non-beta release was named 7.1 and arrived in August. This offered | ||||||
|  | the easy interface and turned out to be the beginning of actually getting | ||||||
|  | other software and programs to get based on and powered by libcurl. Almost | ||||||
|  | 20000 lines of code. | ||||||
|  |  | ||||||
|  | August 2000, the curl web site gets 4000 visits weekly. | ||||||
|  |  | ||||||
|  | The PHP guys adopted libcurl already the same month, when the first ever third | ||||||
|  | party libcurl binding showed up. CURL has been a supported module in PHP since | ||||||
|  | the release of PHP 4.0.2. This would soon get followers. More than 16 | ||||||
|  | different bindings exist at the time of this writing. | ||||||
|  |  | ||||||
|  | September 2000, kerberos4 support was added. | ||||||
|  |  | ||||||
|  | In November 2000 started the work on a test suite for curl. It was later | ||||||
|  | re-written from scratch again. | ||||||
|  |  | ||||||
|  | January 2001, Daniel released curl 7.5.2 under a new license again: MIT (or | ||||||
|  | MPL). The MIT license is extremely liberal and can be used combined with GPL | ||||||
|  | in other projects. This would finally put an end to the "complaints" from | ||||||
|  | people involved in GPLed projects that previously were prohibited from using | ||||||
|  | libcurl while it was released under MPL only. (Due to the fact that MPL is | ||||||
|  | deemed "GPL incompatible".) | ||||||
|  |  | ||||||
|  | curl supports HTTP 1.1 starting with the release of 7.7, March 22 2001. This | ||||||
|  | also introduced libcurl's ability to do persistent connections. 24000 lines of | ||||||
|  | code. | ||||||
|  |  | ||||||
|  | August 2001. curl is bundled in Mac OS X, 10.1. It was already becoming more | ||||||
|  | and more of a standard utility of Linux distributions and a regular in the BSD | ||||||
|  | ports collections. The curl web site gets 8000 visits weekly. Curl Corporation | ||||||
|  | contacted Daniel to discuss "the name issue". After Daniel's reply, they have | ||||||
|  | never since got in touch again. | ||||||
|  |  | ||||||
|  | September 2001, libcurl 7.9 introduces cookie jar and curl_formadd(). During | ||||||
|  | the forthcoming 7.9.x releases, we introduced the multi interface slowly and | ||||||
|  | without much whistles. | ||||||
|  |  | ||||||
|  | June 2002, the curl web site gets 13000 visits weekly. curl and libcurl is | ||||||
|  | 35000 lines of code. Reported successful compiles on more than 40 combinations | ||||||
|  | of CPUs and operating systems. | ||||||
|  |  | ||||||
|  | To estimate number of users of the curl tool or libcurl library is next to | ||||||
|  | impossible. Around 5000 downloaded packages each week from the main site gives | ||||||
|  | a hint, but the packages are mirrored extensively, bundled with numerous OS | ||||||
|  | distributions and otherwise retrieved as part of other software. | ||||||
|  |  | ||||||
|  | September 2002, with the release of curl 7.10 it is released under the MIT | ||||||
|  | license only. | ||||||
|  |  | ||||||
|  | February 2003, the curl site averages at 20000 visits weekly. At any given | ||||||
|  | moment, there's an average of 3 people browsing the curl.haxx.se site. | ||||||
							
								
								
									
										25
									
								
								docs/HOWTO-RELEASE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								docs/HOWTO-RELEASE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | 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 | ||||||
							
								
								
									
										125
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										125
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -28,11 +28,26 @@ UNIX | |||||||
|  |  | ||||||
|    You probably need to be root when doing the last command. |    You probably need to be root when doing the last command. | ||||||
|  |  | ||||||
|  |    If you have checked out the sources from the CVS repository, read the | ||||||
|  |    CVS-INFO on how to proceed. | ||||||
|  |  | ||||||
|  |    Get a full listing of all available configure options by invoking it like: | ||||||
|  |  | ||||||
|  |         ./configure --help | ||||||
|  |  | ||||||
|    If you want to install curl in a different file hierarchy than /usr/local, |    If you want to install curl in a different file hierarchy than /usr/local, | ||||||
|    you need to specify that already when running configure: |    you need to specify that already when running configure: | ||||||
|  |  | ||||||
|         ./configure --prefix=/path/to/curl/tree |         ./configure --prefix=/path/to/curl/tree | ||||||
|  |  | ||||||
|  |    If you happen to have write permission in that directory, you can do 'make | ||||||
|  |    install' without being root. An example of this would be to make a local | ||||||
|  |    install in your own home directory: | ||||||
|  |  | ||||||
|  |         ./configure --prefix=$HOME | ||||||
|  |         make | ||||||
|  |         make install | ||||||
|  |  | ||||||
|    The configure script always tries to find a working SSL library unless |    The configure script always tries to find a working SSL library unless | ||||||
|    explicitly told not to. If you have OpenSSL installed in the default search |    explicitly told not to. If you have OpenSSL installed in the default search | ||||||
|    path for your compiler/linker, you don't need to do anything special. If |    path for your compiler/linker, you don't need to do anything special. If | ||||||
| @@ -71,33 +86,6 @@ UNIX | |||||||
|      LIBS=-lRSAglue -lrsaref |      LIBS=-lRSAglue -lrsaref | ||||||
|      (as suggested by Doug Kaufman) |      (as suggested by Doug Kaufman) | ||||||
|  |  | ||||||
|    KNOWN PROBLEMS (these ones should not happen anymore) |  | ||||||
|  |  | ||||||
|      If you happen to have autoconf installed, but a version older than 2.12 |  | ||||||
|      you will get into trouble. Then you can still build curl by issuing these |  | ||||||
|      commands (note that this requires curl to be built staticly): (from Ralph |  | ||||||
|      Beckmann) |  | ||||||
|  |  | ||||||
|        ./configure [...] |  | ||||||
|        cd lib; make; cd .. |  | ||||||
|        cd src; make; cd .. |  | ||||||
|        cp src/curl elsewhere/bin/ |  | ||||||
|  |  | ||||||
|      As suggested by David West, you can make a faked version of autoconf and |  | ||||||
|      autoheader: |  | ||||||
|  |  | ||||||
|        ----start of autoconf---- |  | ||||||
|        #!/bin/bash |  | ||||||
|        #fake autoconf for building curl |  | ||||||
|        if [ "$1" = "--version" ] then |  | ||||||
|          echo "Autoconf version 2.13" |  | ||||||
|        fi |  | ||||||
|        ----end of autoconf---- |  | ||||||
|  |  | ||||||
|      Then make autoheader a symbolic link to the same script and make sure |  | ||||||
|      they're executable and set to appear in the path *BEFORE* the actual (but |  | ||||||
|      obsolete) autoconf and autoheader scripts. |  | ||||||
|  |  | ||||||
|    MORE OPTIONS |    MORE OPTIONS | ||||||
|  |  | ||||||
|      To force configure to use the standard cc compiler if both cc and gcc are |      To force configure to use the standard cc compiler if both cc and gcc are | ||||||
| @@ -201,17 +189,34 @@ Win32 | |||||||
|  |  | ||||||
|       Microsoft command line style |       Microsoft command line style | ||||||
|       ---------------------------- |       ---------------------------- | ||||||
|  |  | ||||||
|         Please read the OpenSSL documentation on how to compile and install |         Please read the OpenSSL documentation on how to compile and install | ||||||
|         the OpenSSL library.  This generates the libeay32.dll and ssleay32.dll |         the OpenSSL libraries.  The build process of OpenSSL generates the | ||||||
|         files. |         libeay32.dll and ssleay32.dll files in the out32dll subdirectory in | ||||||
|  |         the OpenSSL home directory.  OpenSSL static libraries (libeay32.lib, | ||||||
|  |         ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory. | ||||||
|  |  | ||||||
|         Run the 'vcvars32.bat' file to get the proper environment variables |         Run the 'vcvars32.bat' file to get a proper environment. The | ||||||
|         set. Edit the makefile.vc6 in the lib directory and define |         vcvars32.bat file is part of the Microsoft development environment and | ||||||
|         OPENSSL_PATH.  Set the location of the OpenSSL library and run 'nmake |         you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin' | ||||||
|         vc-ssl' in the root directory. |         provided that you installed Visual C/C++ 6 in the default directory. | ||||||
|  |  | ||||||
|         The vcvars32.bat file is part of the Microsoft development |         Before running nmake define the OPENSSL_PATH environment variable with | ||||||
|         environment. |         the root/base directory of OpenSSL, for example: | ||||||
|  |  | ||||||
|  |           set OPENSSL_PATH=c:\openssl-0.9.6b | ||||||
|  |  | ||||||
|  |         Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root | ||||||
|  |         directory.  'nmake vc-ssl' will create a libcurl static and dynamic | ||||||
|  |         libraries in the lib subdirectory, as well as a statically linked | ||||||
|  |         version of curl.exe in the src subdirectory.  This statically linked | ||||||
|  |         version is a standalone executable not requiring any DLL at | ||||||
|  |         runtime. This make method requires that you have the static OpenSSL | ||||||
|  |         libraries available in OpenSSL's out32 subdirectory. | ||||||
|  | 	'nmake vc-ssl-dll' creates the libcurl dynamic library and | ||||||
|  | 	links curl.exe against libcurl and OpenSSL dynamically. | ||||||
|  | 	This executable requires libcurl.dll and the OpenSSL DLLs | ||||||
|  | 	at runtime. | ||||||
|  |  | ||||||
|       Microsoft / Borland style |       Microsoft / Borland style | ||||||
|       ------------------------- |       ------------------------- | ||||||
| @@ -219,6 +224,30 @@ Win32 | |||||||
|         project properties to use the SSL include path, link with the SSL libs |         project properties to use the SSL include path, link with the SSL libs | ||||||
|         and define the USE_SSLEAY symbol. |         and define the USE_SSLEAY symbol. | ||||||
|  |  | ||||||
|  |    Disabling Specific Protocols: | ||||||
|  |  | ||||||
|  |       The configure utility, unfortunately, is not available for the Windows | ||||||
|  |       environment, therefore, you cannot use the various disable-protocol | ||||||
|  |       options of the configure utility on this platform. | ||||||
|  |  | ||||||
|  |       However, you can use the following defines to disable specific | ||||||
|  |       protocols: | ||||||
|  |  | ||||||
|  |       HTTP_ONLY             disables all protocols except HTTP | ||||||
|  |       CURL_DISABLE_FTP      disables FTP | ||||||
|  |       CURL_DISABLE_LDAP     disables LDAP | ||||||
|  |       CURL_DISABLE_TELNET   disables TELNET | ||||||
|  |       CURL_DISABLE_DICT     disables DICT | ||||||
|  |       CURL_DISABLE_FILE     disables FILE | ||||||
|  |       CURL_DISABLE_GOPHER   disables GOPHER | ||||||
|  |  | ||||||
|  |       If you want to set any of these defines you have the following | ||||||
|  |       possibilities: | ||||||
|  |  | ||||||
|  |       - Modify lib/setup.h | ||||||
|  |       - Modify lib/Makefile.vc6 | ||||||
|  |       - Add defines to Project/Settings/C/C++/General/Preprocessor Definitions | ||||||
|  |         in the curllib.dsw/curllib.dsp Visual C++ 6 IDE project. | ||||||
|  |  | ||||||
| IBM OS/2 | IBM OS/2 | ||||||
| ======== | ======== | ||||||
| @@ -375,23 +404,37 @@ CROSS COMPILE | |||||||
|    The '--prefix' parameter specifies where cURL will be installed.  If |    The '--prefix' parameter specifies where cURL will be installed.  If | ||||||
|    'configure' completes successfully, do 'make' and 'make install' as usual. |    'configure' completes successfully, do 'make' and 'make install' as usual. | ||||||
|  |  | ||||||
|  | RISC OS | ||||||
|  | ======= | ||||||
|  |    The library can be cross-compiled using gccsdk as follows: | ||||||
|  |  | ||||||
|  |         CC=riscos-gcc AR=riscos-ar RANLIB='riscos-ar -s' ./configure \ | ||||||
|  |              --host=arm-riscos-aof --without-random --disable-shared | ||||||
|  |         make | ||||||
|  |  | ||||||
|  |    where riscos-gcc and riscos-ar are links to the gccsdk tools. | ||||||
|  |    You can then link your program with curl/lib/.libs/libcurl.a | ||||||
|  |  | ||||||
| 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 | ||||||
|    that curl has been compiled for. If you know one system curl compiles and |    that curl has been compiled for. If you know a system curl compiles and | ||||||
|    runs on, that isn't listed, please let us know! |    runs on, that isn't listed, please let us know! | ||||||
|  |  | ||||||
|         - Alpha DEC OSF 4 |         - Alpha DEC OSF 4 | ||||||
|         - Alpha Digital UNIX v3.2 |         - Alpha Digital UNIX v3.2 | ||||||
|         - Alpha FreeBSD 4.1 |         - Alpha FreeBSD 4.1, 4.5 | ||||||
|         - Alpha Linux 2.2.16 |         - Alpha Linux 2.2, 2.4 | ||||||
|  |         - Alpha NetBSD 1.5.2 | ||||||
|  |         - Alpha OpenBSD 3.0 | ||||||
|         - Alpha OpenVMS V7.1-1H2 |         - Alpha OpenVMS V7.1-1H2 | ||||||
|         - Alpha Tru64 v5.0 5.1 |         - Alpha Tru64 v5.0 5.1 | ||||||
|         - HP-PA HP-UX 9.X 10.X 11.X |         - HP-PA HP-UX 9.X 10.X 11.X | ||||||
|         - HP-PA Linux |         - HP-PA Linux | ||||||
|         - MIPS IRIX 6.2, 6.5 |         - MIPS IRIX 6.2, 6.5 | ||||||
|         - MIPS Linux |         - MIPS Linux | ||||||
|         - Power AIX 4.2, 4.3.1, 4.3.2 |         - Pocket PC/Win CE 3.0 | ||||||
|  |         - Power AIX 3.2.5, 4.2, 4.3.1, 4.3.2, 5.1 | ||||||
|         - PowerPC Darwin 1.0 |         - PowerPC Darwin 1.0 | ||||||
|         - PowerPC Linux |         - PowerPC Linux | ||||||
|         - PowerPC Mac OS 9 |         - PowerPC Mac OS 9 | ||||||
| @@ -414,11 +457,15 @@ PORTS | |||||||
|         - i386 SCO unix |         - i386 SCO unix | ||||||
|         - i386 Solaris 2.7 |         - i386 Solaris 2.7 | ||||||
|         - i386 Windows 95, 98, ME, NT, 2000 |         - i386 Windows 95, 98, ME, NT, 2000 | ||||||
|  |         - i386 QNX 6 | ||||||
|  |         - i486 ncr-sysv4.3.03 (NCR MP-RAS) | ||||||
|         - ia64 Linux 2.3.99 |         - ia64 Linux 2.3.99 | ||||||
|         - m68k AmigaOS 3 |         - m68k AmigaOS 3 | ||||||
|         - m68k Linux |         - m68k Linux | ||||||
|         - m68k OpenBSD |         - m68k OpenBSD | ||||||
|  |         - m88k dg-dgux5.4R3.00 | ||||||
|         - s390 Linux  |         - s390 Linux  | ||||||
|  |         - XScale/PXA250 Linux 2.4 | ||||||
|  |  | ||||||
| OpenSSL | OpenSSL | ||||||
| ======= | ======= | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ Windows vs Unix | |||||||
|  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All |  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All | ||||||
|  conditionals that deal with features *should* instead be in the format |  conditionals that deal with features *should* instead be in the format | ||||||
|  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, |  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, | ||||||
|  we maintain two config-win32.h files (one in / and one in src/) that are |  we maintain two config-win32.h files (one in lib/ and one in src/) that are | ||||||
|  supposed to look exactly as a config.h file would have looked like on a |  supposed to look exactly as a config.h file would have looked like on a | ||||||
|  Windows machine! |  Windows machine! | ||||||
|  |  | ||||||
| @@ -69,10 +69,10 @@ Library | |||||||
|  rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are |  rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are | ||||||
|  put in the lib/easy.c file. |  put in the lib/easy.c file. | ||||||
|  |  | ||||||
|  Starting with libcurl 7.8, curl_global_init_() and curl_global_cleanup() were |  curl_global_init_() and curl_global_cleanup() should be called by the | ||||||
|  introduced. They should be called by the application to initialize and clean |  application to initialize and clean up global stuff in the library. As of | ||||||
|  up global stuff in the library. As of today, they just do the global SSL |  today, it can handle the global SSL initing if SSL is enabled and it can init | ||||||
|  initing if SSL is enabled. libcurl itself has no "global" scope. |  the socket layer on windows machines. libcurl itself has no "global" scope. | ||||||
|  |  | ||||||
|  All printf()-style functions use the supplied clones in lib/mprintf.c. This |  All printf()-style functions use the supplied clones in lib/mprintf.c. This | ||||||
|  makes sure we stay absolutely platform independent. |  makes sure we stay absolutely platform independent. | ||||||
|   | |||||||
							
								
								
									
										91
									
								
								docs/KNOWN_BUGS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								docs/KNOWN_BUGS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | These are problems known to exist at the time of this release. Feel free to | ||||||
|  | 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 | ||||||
|  | may have been fixed since this was written! | ||||||
|  |  | ||||||
|  | * 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. | ||||||
|  |  | ||||||
|  | * Running 'make test' on Mac OS X gives 4 errors. This seems to be related | ||||||
|  |   to some kind of libtool problem: | ||||||
|  |   http://curl.haxx.se/mail/archive-2002-03/0029.html and | ||||||
|  |   http://curl.haxx.se/mail/archive-2002-03/0033.html | ||||||
|  |  | ||||||
|  | * libcurl does not deal nicely with files larger than 2GB | ||||||
|  |  | ||||||
|  | * GOPHER transfers seem broken | ||||||
|  |  | ||||||
|  | * configure --disable-http is not fully supported. All other protocols seem | ||||||
|  |   to work to disable. | ||||||
|  |  | ||||||
|  | * The -m parameter does not work when using telnet with curl on Windows. | ||||||
|  |  | ||||||
|  | * If a HTTP server responds to a HEAD request and includes a body (thus | ||||||
|  |   violating the RFC2616), curl won't wait to read the response but just stop | ||||||
|  |   reading and return back. If a second request (let's assume a GET) is then | ||||||
|  |   immediately made to the same server again, the connection will be re-used | ||||||
|  |   fine of course, and the second request will be sent off but when the | ||||||
|  |   response is to get read, the previous response-body is what curl will read | ||||||
|  |   and havoc is what happens. | ||||||
|  |   More details on this is found in this libcurl mailing list thread: | ||||||
|  |   http://curl.haxx.se/mail/lib-2002-08/0000.html | ||||||
|  |  | ||||||
|  | ------------------------------------------------------------------------------ | ||||||
|  |  | ||||||
|  | Q: My program blows up when I run lots of curl_easy_perform() calls on a | ||||||
|  | single thread | ||||||
|  | Q: My program dies when a single thread re-enters the win32 select() call | ||||||
|  | via curl_easy_perform() | ||||||
|  | Q: --- add your own flavour here --- | ||||||
|  |  | ||||||
|  | Single Threaded Re-Entracy | ||||||
|  | -------------------------- | ||||||
|  |  | ||||||
|  | There is a glitch / trick to using cURL on Win32 related to re-entrancy. | ||||||
|  | This experience was gained on verion 7.9.4 using Windows NT SP3 in a banking | ||||||
|  | environment (just in case you wanted to know). | ||||||
|  |  | ||||||
|  | If you have already called curl_easy_perform(), and *somehow* you cause your | ||||||
|  | single thread of execution to make another call to curl_easy_perform() - the | ||||||
|  | windows socket() call used to create a new socket for the second connection | ||||||
|  | can return with 10044 / 10043 error codes. | ||||||
|  |  | ||||||
|  | The WSA errors we experienced are: | ||||||
|  | WSAEPROTONOSUPPORT  | ||||||
|  | (10043)  | ||||||
|  | Protocol not supported.  | ||||||
|  | The requested protocol has not been configured into the system, or no | ||||||
|  | implementation for it exists. For example, a socket call requests a | ||||||
|  | SOCK_DGRAM socket, but specifies a stream protocol.  | ||||||
|  |  | ||||||
|  | WSAESOCKTNOSUPPORT  | ||||||
|  | (10044)  | ||||||
|  | Socket type not supported.  | ||||||
|  | The support for the specified socket type does not exist in this address | ||||||
|  | family. For example, the optional type SOCK_RAW might be selected in a | ||||||
|  | socket call, and the implementation does not support SOCK_RAW sockets at | ||||||
|  | all.  | ||||||
|  |  | ||||||
|  | We have experienced this by creating a timer that ticks every 20ms, and on | ||||||
|  | the tick making a curl_easy_perform() call.  The call usually completed in | ||||||
|  | about 300ms.  And we expected (before this test) that the timer would NOT be | ||||||
|  | fired during a call to curl_easy_perform(), howvever, while the first | ||||||
|  | curl_easy_perform() is running a tick *is* fired by the windows API somehow, | ||||||
|  | and we then call curl_easy_perform() again - thus single threaded | ||||||
|  | re-entrancy is achieved. | ||||||
|  |  | ||||||
|  | Notes: | ||||||
|  | * We made sure that a new CURL structure was being used for each | ||||||
|  | curl_easy_perform() request, and that the curl_global_init() had been called | ||||||
|  | beforehand.   | ||||||
|  | * I'm happy to answer any questions about this problem to try to track it | ||||||
|  | down. | ||||||
|  | * Once the socket() call started failing, there is no hope - it never works | ||||||
|  | again. | ||||||
|  | * Slowing the timer down to give each request enough time to complete solves | ||||||
|  | this problem completely. | ||||||
|  |  | ||||||
|  | If anyone has the source code to the WinNT implementation of socket() and | ||||||
|  | can figure out WHY this can occur, more tracing can be performed. | ||||||
|  |  | ||||||
|  |         John Clayton <John.Clayton at barclayscapital.com> | ||||||
							
								
								
									
										135
									
								
								docs/MANUAL
									
									
									
									
									
								
							
							
						
						
									
										135
									
								
								docs/MANUAL
									
									
									
									
									
								
							| @@ -166,13 +166,21 @@ UPLOADING | |||||||
|  |  | ||||||
| VERBOSE / DEBUG | VERBOSE / DEBUG | ||||||
|  |  | ||||||
|   If curl fails where it isn't supposed to, if the servers don't let you |   If curl fails where it isn't supposed to, if the servers don't let you in, | ||||||
|   in, if you can't understand the responses: use the -v flag to get VERBOSE |   if you can't understand the responses: use the -v flag to get verbose | ||||||
|   fetching. Curl will output lots of info and all data it sends and |   fetching. Curl will output lots of info and what it sends and receives in | ||||||
|   receives in order to let the user see all client-server interaction. |   order to let the user see all client-server interaction (but it won't show | ||||||
|  |   you the actual data). | ||||||
|  |  | ||||||
|         curl -v ftp://ftp.upload.com/ |         curl -v ftp://ftp.upload.com/ | ||||||
|  |  | ||||||
|  |   To get even more details and information on what curl does, try using the | ||||||
|  |   --trace or --trace-ascii options with a given file name to log to, like | ||||||
|  |   this: | ||||||
|  |  | ||||||
|  |         curl --trace trace.txt www.haxx.se | ||||||
|  |   | ||||||
|  |  | ||||||
| DETAILED INFORMATION | DETAILED INFORMATION | ||||||
|  |  | ||||||
|   Different protocols provide different ways of getting detailed information |   Different protocols provide different ways of getting detailed information | ||||||
| @@ -246,25 +254,25 @@ POST (HTTP) | |||||||
|   -F accepts parameters like -F "name=contents". If you want the contents to |   -F accepts parameters like -F "name=contents". If you want the contents to | ||||||
|   be read from a file, use <@filename> as contents. When specifying a file, |   be read from a file, use <@filename> as contents. When specifying a file, | ||||||
|   you can also specify the file content type by appending ';type=<mime type>' |   you can also specify the file content type by appending ';type=<mime type>' | ||||||
|   to the file name. You can also post the contents of several files in one field. |   to the file name. You can also post the contents of several files in one | ||||||
|   For example, the field name 'coolfiles' is used to send three  files, with |   field.  For example, the field name 'coolfiles' is used to send three files, | ||||||
|   different content types using the following syntax: |   with different content types using the following syntax: | ||||||
|  |  | ||||||
|         curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \ |         curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \ | ||||||
|         http://www.post.com/postit.cgi |         http://www.post.com/postit.cgi | ||||||
|  |  | ||||||
|   If the content-type is not specified, curl will try to guess from the file |   If the content-type is not specified, curl will try to guess from the file | ||||||
|   extension  (it only knows a few), or use the previously specified type |   extension (it only knows a few), or use the previously specified type (from | ||||||
|   (from an earlier file if several files are specified in a list) or else it |   an earlier file if several files are specified in a list) or else it will | ||||||
|   will  using the default type 'text/plain'. |   using the default type 'text/plain'. | ||||||
|  |  | ||||||
|   Emulate a fill-in form with -F. Let's say you fill in three fields in a |   Emulate a fill-in form with -F. Let's say you fill in three fields in a | ||||||
|   form. One field is a file name which to post, one field is your name and one |   form. One field is a file name which to post, one field is your name and one | ||||||
|   field is a file description. We want to post the file we have written named |   field is a file description. We want to post the file we have written named | ||||||
|   "cooltext.txt". To let curl do the posting of this data instead of your |   "cooltext.txt". To let curl do the posting of this data instead of your | ||||||
|   favourite browser, you have to read the HTML source of the form page and find |   favourite browser, you have to read the HTML source of the form page and | ||||||
|   the names of the input fields. In our example, the input field names are |   find the names of the input fields. In our example, the input field names | ||||||
|   'file', 'yourname' and 'filedescription'. |   are 'file', 'yourname' and 'filedescription'. | ||||||
|  |  | ||||||
|         curl -F "file=@cooltext.txt" -F "yourname=Daniel" \ |         curl -F "file=@cooltext.txt" -F "yourname=Daniel" \ | ||||||
|              -F "filedescription=Cool text file with cool text inside" \ |              -F "filedescription=Cool text file with cool text inside" \ | ||||||
| @@ -350,6 +358,13 @@ 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 | ||||||
|  |   however error-prone and not the prefered way to do this. Instead, make curl | ||||||
|  |   save the incoming cookies using the well-known netscape cookie format like | ||||||
|  |   this: | ||||||
|  |  | ||||||
|  |         curl -c cookies.txt www.example.com | ||||||
|  |  | ||||||
|   Note that by specifying -b you enable the "cookie awareness" and with -L |   Note that by specifying -b you enable the "cookie awareness" and with -L | ||||||
|   you can make curl follow a location: (which often is used in combination |   you can make curl follow a location: (which often is used in combination | ||||||
|   with cookies). So that if a site sends cookies and a location, you can |   with cookies). So that if a site sends cookies and a location, you can | ||||||
| @@ -363,7 +378,11 @@ COOKIES | |||||||
|   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 non-existant file. | ||||||
|    |  | ||||||
|  |   Alas, to both read and write cookies from a netscape cookie file, you can | ||||||
|  |   set both -b and -c to use the same file: | ||||||
|  |  | ||||||
|  |         curl -b cookies.txt -c cookies.txt www.example.com | ||||||
|  |  | ||||||
| PROGRESS METER | PROGRESS METER | ||||||
|  |  | ||||||
| @@ -404,12 +423,34 @@ SPEED LIMIT | |||||||
|   To have curl abort the download if the speed is slower than 3000 bytes per |   To have curl abort the download if the speed is slower than 3000 bytes per | ||||||
|   second for 1 minute, run: |   second for 1 minute, run: | ||||||
|  |  | ||||||
|         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 operatioin 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, | ||||||
|  |   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 | ||||||
|  |   "bandwith throttle"). | ||||||
|  |  | ||||||
|  |   Make curl transfer data no faster than 10 kilobytes per second: | ||||||
|  |  | ||||||
|  |         curl --limit-rate 10K www.far-away-site.com | ||||||
|  |  | ||||||
|  |     or | ||||||
|  |  | ||||||
|  |         curl --limit-rate 10240 www.far-away-site.com | ||||||
|  |  | ||||||
|  |   Or prevent curl from uploading data faster than 1 megabyte per second: | ||||||
|  |  | ||||||
|  |         curl -T upload --limit-rate 1M ftp://uploadshereplease.com | ||||||
|  |  | ||||||
|  |   When using the --limit-rate option, the transfer rate is regulated on a | ||||||
|  |   per-second basis, which will cause the total transfer speed to become lower | ||||||
|  |   than the given number. Sometimes of course substantially lower, if your | ||||||
|  |   transfer stalls during periods. | ||||||
|  |  | ||||||
| CONFIG FILE | CONFIG FILE | ||||||
|  |  | ||||||
| @@ -548,7 +589,7 @@ HTTPS | |||||||
|   from sites that require valid certificates. The only drawback is that the |   from sites that require valid certificates. The only drawback is that the | ||||||
|   certificate needs to be in PEM-format. PEM is a standard and open format to |   certificate needs to be in PEM-format. PEM is a standard and open format to | ||||||
|   store certificates with, but it is not used by the most commonly used |   store certificates with, but it is not used by the most commonly used | ||||||
|   browsers (Netscape and MSEI both use the so called PKCS#12 format). If you |   browsers (Netscape and MSIE both use the so called PKCS#12 format). If you | ||||||
|   want curl to use the certificates you use with your (favourite) browser, you |   want curl to use the certificates you use with your (favourite) browser, you | ||||||
|   may need to download/compile a converter that can convert your browser's |   may need to download/compile a converter that can convert your browser's | ||||||
|   formatted certificates to PEM formatted ones. This kind of converter is |   formatted certificates to PEM formatted ones. This kind of converter is | ||||||
| @@ -567,8 +608,8 @@ HTTPS | |||||||
|  |  | ||||||
|   Many older SSL-servers have problems with SSLv3 or TLS, that newer versions |   Many older SSL-servers have problems with SSLv3 or TLS, that newer versions | ||||||
|   of OpenSSL etc is using, therefore it is sometimes useful to specify what |   of OpenSSL etc is using, therefore it is sometimes useful to specify what | ||||||
|   SSL-version curl should use. Use -3 or -2 to specify that exact SSL version |   SSL-version curl should use. Use -3, -2 or -1 to specify that exact SSL | ||||||
|   to use: |   version to use (for SSLv3, SSLv2 or TLSv1 respectively): | ||||||
|  |  | ||||||
|         curl -2 https://secure.site.com/ |         curl -2 https://secure.site.com/ | ||||||
|  |  | ||||||
| @@ -668,8 +709,14 @@ LDAP | |||||||
|   and offer ldap:// support. |   and offer ldap:// support. | ||||||
|  |  | ||||||
|   LDAP is a complex thing and writing an LDAP query is not an easy task. I do |   LDAP is a complex thing and writing an LDAP query is not an easy task. I do | ||||||
|   advice you to dig up the syntax description for that elsewhere, RFC 1959 if |   advice you to dig up the syntax description for that elsewhere. Two places | ||||||
|   no other place is better. |   that might suit you are: | ||||||
|  |  | ||||||
|  |   Netscape's "Netscape Directory SDK 3.0 for C Programmer's Guide Chapter 10: | ||||||
|  |   Working with LDAP URLs": | ||||||
|  |   http://developer.netscape.com/docs/manuals/dirsdk/csdk30/url.htm | ||||||
|  |  | ||||||
|  |   RFC 2255, "The LDAP URL Format" http://www.rfc-editor.org/rfc/rfc2255.txt | ||||||
|  |  | ||||||
|   To show you an example, this is now I can get all people from my local LDAP |   To show you an example, this is now I can get all people from my local LDAP | ||||||
|   server that has a certain sub-domain in their email address: |   server that has a certain sub-domain in their email address: | ||||||
| @@ -683,7 +730,7 @@ ENVIRONMENT VARIABLES | |||||||
|  |  | ||||||
|   Curl reads and understands the following environment variables: |   Curl reads and understands the following environment variables: | ||||||
|  |  | ||||||
|         HTTP_PROXY, HTTPS_PROXY, FTP_PROXY, GOPHER_PROXY |         http_proxy, HTTPS_PROXY, FTP_PROXY, GOPHER_PROXY | ||||||
|  |  | ||||||
|   They should be set for protocol-specific proxies. General proxy should be |   They should be set for protocol-specific proxies. General proxy should be | ||||||
|   set with |   set with | ||||||
| @@ -710,9 +757,9 @@ NETRC | |||||||
|   passwords, so therefor most unix programs won't read this file unless it is |   passwords, so therefor 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 option). This is |   Curl supports .netrc files if told so (using the -n/--netrc and | ||||||
|   not restricted to only ftp, but curl can use it for all protocols where |   --netrc-optional options). This is not restricted to only ftp, | ||||||
|   authentication is used. |   but curl can use it for all protocols where authentication is used. | ||||||
|  |  | ||||||
|   A very simple .netrc file could look something like: |   A very simple .netrc file could look something like: | ||||||
|  |  | ||||||
| @@ -794,19 +841,39 @@ PERSISTANT CONNECTIONS | |||||||
| MAILING LISTS | MAILING LISTS | ||||||
|  |  | ||||||
|   For your convenience, we have several open mailing lists to discuss curl, |   For your convenience, we have several open mailing lists to discuss curl, | ||||||
|   its development and things relevant to this. |   its development and things relevant to this. Get all info at | ||||||
|  |   http://curl.haxx.se/mail/. The lists available are: | ||||||
|  |  | ||||||
|   To subscribe to the main curl list, mail curl-request@contactor.se with |   curl-users | ||||||
|   "subscribe <fill in your email address>" in the body. |  | ||||||
|  |  | ||||||
|   To subscribe to the curl-library users/deverlopers list, follow the |     Users of the command line tool. How to use it, what doesn't work, new | ||||||
|   instructions at http://curl.haxx.se/mail/ |     features, related tools, questions, news, installations, compilations, | ||||||
|  |     running, porting etc. | ||||||
|  |  | ||||||
|   To subscribe to the curl-announce list, to only get information about new |   curl-library | ||||||
|   releases, follow the instructions at http://curl.haxx.se/mail/ |  | ||||||
|  |  | ||||||
|   To subscribe to the curl-and-PHP list in which curl using with PHP is |     Developers using or developing libcurl. Bugs, extensions, improvements. | ||||||
|   discussed, follow the instructions at http://curl.haxx.se/mail/ |  | ||||||
|  |   curl-announce | ||||||
|  |  | ||||||
|  |     Low-traffic. Only announcements of new public versions. | ||||||
|  |  | ||||||
|  |   curl-and-PHP | ||||||
|  |  | ||||||
|  |     Using the curl functions in PHP. Everything curl with a PHP angle. Or PHP | ||||||
|  |     with a curl angle. | ||||||
|  |  | ||||||
|  |   curl-commits | ||||||
|  |  | ||||||
|  |     Receives notifications on all CVS commits done to the curl source module. | ||||||
|  |     This can become quite a large amount of mails during intense development, | ||||||
|  |     be aware. This is for us who like email... | ||||||
|  |  | ||||||
|  |   curl-www-commits | ||||||
|  |  | ||||||
|  |     Receives notifications on all CVS commits done to the curl www module | ||||||
|  |     (basicly the web site).  This can become quite a large amount of mails | ||||||
|  |     during intense changing, be aware. This is for us who like email... | ||||||
|  |  | ||||||
|   Please direct curl questions, feature requests and trouble reports to one of |   Please direct curl questions, feature requests and trouble reports to one of | ||||||
|   these mailing lists instead of mailing any individual. |   these mailing lists instead of mailing any individual. | ||||||
|   | |||||||
| @@ -6,72 +6,43 @@ AUTOMAKE_OPTIONS = foreign no-dependencies | |||||||
|  |  | ||||||
| man_MANS = \ | man_MANS = \ | ||||||
| 	curl.1 \ | 	curl.1 \ | ||||||
| 	curl-config.1 \ | 	curl-config.1 | ||||||
| 	curl_easy_cleanup.3 \ |  | ||||||
| 	curl_easy_getinfo.3 \ |  | ||||||
| 	curl_easy_init.3 \ |  | ||||||
| 	curl_easy_perform.3 \ |  | ||||||
| 	curl_easy_setopt.3 \ |  | ||||||
| 	curl_easy_duphandle.3 \ |  | ||||||
| 	curl_formparse.3 \ |  | ||||||
| 	curl_formadd.3 \ |  | ||||||
| 	curl_formfree.3 \ |  | ||||||
| 	curl_getdate.3 \ |  | ||||||
| 	curl_getenv.3 \ |  | ||||||
| 	curl_slist_append.3 \ |  | ||||||
| 	curl_slist_free_all.3 \ |  | ||||||
| 	curl_version.3 \ |  | ||||||
| 	curl_escape.3 \ |  | ||||||
| 	curl_unescape.3 \ |  | ||||||
| 	curl_strequal.3 \ |  | ||||||
| 	curl_strnequal.3 \ |  | ||||||
| 	curl_mprintf.3 \ |  | ||||||
| 	curl_global_init.3 \ |  | ||||||
| 	curl_global_cleanup.3 \ |  | ||||||
| 	libcurl.3 |  | ||||||
|  |  | ||||||
| SUBDIRS = examples |  | ||||||
|  |  | ||||||
| HTMLPAGES = \ | HTMLPAGES = \ | ||||||
| 	curl.html \ | 	curl.html \ | ||||||
| 	curl-config.html \ | 	curl-config.html \ | ||||||
| 	curl_easy_cleanup.html \ |  | ||||||
| 	curl_easy_getinfo.html \ |  | ||||||
| 	curl_easy_init.html \ |  | ||||||
| 	curl_easy_perform.html \ |  | ||||||
| 	curl_easy_setopt.html \ |  | ||||||
| 	curl_easy_duphandle.html \ |  | ||||||
| 	curl_formadd.html \ |  | ||||||
| 	curl_formparse.html \ |  | ||||||
| 	curl_formfree.html \ |  | ||||||
| 	curl_getdate.html \ |  | ||||||
| 	curl_getenv.html \ |  | ||||||
| 	curl_slist_append.html \ |  | ||||||
| 	curl_slist_free_all.html \ |  | ||||||
| 	curl_version.html \ |  | ||||||
| 	curl_escape.html \ |  | ||||||
| 	curl_unescape.html \ |  | ||||||
| 	curl_strequal.html \ |  | ||||||
| 	curl_strnequal.html \ |  | ||||||
| 	curl_mprintf.html \ |  | ||||||
| 	curl_global_init.html \ |  | ||||||
| 	curl_global_cleanup.html \ |  | ||||||
| 	libcurl.html \ |  | ||||||
| 	index.html | 	index.html | ||||||
|  |  | ||||||
| EXTRA_DIST = $(man_MANS) \ | PDFPAGES = \ | ||||||
| 	MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \ | 	curl.pdf \ | ||||||
| 	README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS \ | 	curl-config.pdf | ||||||
| 	VERSIONS $(HTMLPAGES) |  | ||||||
|  | SUBDIRS = examples libcurl | ||||||
|  |  | ||||||
|  | EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS		\ | ||||||
|  | 	     README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS	\ | ||||||
|  | 	     VERSIONS KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) \ | ||||||
|  | 	     HISTORY INSTALL libcurl-the-guide $(PDFPAGES) | ||||||
|  |  | ||||||
| MAN2HTML= gnroff -man $< | man2html >$@ | MAN2HTML= gnroff -man $< | man2html >$@ | ||||||
|  |  | ||||||
| SUFFIXES = .1 .3 .html | SUFFIXES = .1 .3 .html .pdf | ||||||
|  |  | ||||||
| html: $(HTMLPAGES) | html: $(HTMLPAGES) | ||||||
|  | 	cd libcurl; make html | ||||||
|  |  | ||||||
| .3.html: | .3.html: | ||||||
| 	$(MAN2HTML) | 	$(MAN2HTML) | ||||||
|  |  | ||||||
| .1.html: | .1.html: | ||||||
| 	$(MAN2HTML) | 	$(MAN2HTML) | ||||||
|  |  | ||||||
|  | MAN2PDF = groff -Tps -man curl.1 $< >$@ | ||||||
|  |  | ||||||
|  | pdf: | ||||||
|  | 	for file in $(man_MANS); do \ | ||||||
|  | 	  foo=`echo $$file | sed -e 's/\.[0-9]$$//g'`; \ | ||||||
|  | 	  groff -Tps -man $$file >$$foo.ps; \ | ||||||
|  | 	  ps2pdf $$foo.ps $$foo.pdf; \ | ||||||
|  | 	done | ||||||
|  | 	cd libcurl; make pdf | ||||||
|   | |||||||
| @@ -5,10 +5,9 @@ | |||||||
|                              \___|\___/|_| \_\_____| |                              \___|\___/|_| \_\_____| | ||||||
|  |  | ||||||
|  |  | ||||||
| This document has been introduced in order to let you find documents that | This document lists documents that specify standards used by curl, software | ||||||
| specify standards used by curl, software that extends curl, web pages with | that extends curl, web pages with similar utilities and information pages that | ||||||
| "competing" utilities and information pages that describe some of the tools | describe some of the tools that we use to build/compile/develop curl. | ||||||
| that we use to build/compile/develop curl. |  | ||||||
|  |  | ||||||
| Standards | Standards | ||||||
| --------- | --------- | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -79,3 +79,14 @@ that have contributed with non-trivial parts: | |||||||
|  - Eric Lavigne <erlavigne@wanadoo.fr> |  - Eric Lavigne <erlavigne@wanadoo.fr> | ||||||
|  - Marcus Webster <marcus.webster@phocis.com> |  - Marcus Webster <marcus.webster@phocis.com> | ||||||
|  - G<>tz Babin-Ebell <babin<69>ebell@trustcenter.de> |  - G<>tz Babin-Ebell <babin<69>ebell@trustcenter.de> | ||||||
|  |  - Andreas Damm <andreas-sourceforge@radab.org> | ||||||
|  |  - Jacky Lam <sylam@emsoftltd.com> | ||||||
|  |  - James Gallagher <jgallagher@gso.uri.edu> | ||||||
|  |  - Kjetil Jacobsen <kjetilja@cs.uit.no> | ||||||
|  |  - Markus F.X.J. Oberhumer <markus@oberhumer.com> | ||||||
|  |  - Miklos Nemeth <mnemeth@kfkisystems.com> | ||||||
|  |  - Kevin Roth <kproth@users.sourceforge.net> | ||||||
|  |  - Ralph Mitchell <rmitchell@eds.com> | ||||||
|  |  - Dan Fandrich <dan@coneharvesters.com> | ||||||
|  |  - Jean-Philippe Barrette-LaPierre <jpb@rrette.com> | ||||||
|  |  - Richard Bramante <RBramante@on.com> | ||||||
|   | |||||||
							
								
								
									
										194
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										194
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -6,72 +6,105 @@ | |||||||
|  |  | ||||||
| TODO | TODO | ||||||
|  |  | ||||||
|  Things to do in project cURL. Please tell me what you think, contribute and |  Things to do in project cURL. Please tell us what you think, contribute and | ||||||
|  send me patches that improve things! Also check the http://curl.haxx.se/dev |  send us patches that improve things! Also check the http://curl.haxx.se/dev | ||||||
|  web section for various development notes. |  web section for various technical development notes. | ||||||
|  |  | ||||||
|  LIBCURL |  LIBCURL | ||||||
|  |  | ||||||
|  * Consider 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 sent back in the response headers. |    know what cookies that are received. Pushing interface that calls a | ||||||
|  |    callback on each received cookie? Querying interface that asks about | ||||||
|  |    existing cookies? We probably need both. Enable applications to modify | ||||||
|  |    existing cookies as well. | ||||||
|  |  | ||||||
|  * Make content encoding/decoding internally be made using a filter system. |  * Make content encoding/decoding internally be made using a filter system. | ||||||
|  |  | ||||||
|  * The new 'multi' interface is being designed. Work out the details, start |  | ||||||
|    implementing and write test applications! |  | ||||||
|    [http://curl.haxx.se/dev/multi.h] |  | ||||||
|  |  | ||||||
|  * Add a name resolve cache to libcurl to make repeated fetches to the same |  | ||||||
|    host name (when persitancy isn't available) faster. |  | ||||||
|  |  | ||||||
|  * 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. | ||||||
|    [http://curl.haxx.se/dev/no_copy_callbacks.txt] |    [http://curl.haxx.se/dev/no_copy_callbacks.txt] | ||||||
|  |  | ||||||
|  * Add configure options that disables certain protocols in libcurl to |  * Add asynchronous name resolving (http://libdenise.sf.net/). This should be | ||||||
|    decrease footprint.  '--disable-[protocol]' where protocol is http, ftp, |    made to work on most of the supported platforms, or otherwise it isn't | ||||||
|    telnet, ldap, dict or file. |    really interesting. | ||||||
|  |  | ||||||
|  * Add asynchronous name resolving. http://curl.haxx.se/dev/async-resolver.txt |  * Data sharing. Tell which easy handles within a multi handle that should | ||||||
|  |    share cookies, connection cache, dns cache, ssl session cache.  Full | ||||||
|  |    suggestion found here: http://curl.haxx.se/dev/sharing.txt | ||||||
|  |  | ||||||
|  * Strip any trailing CR from the error message when Curl_failf() is used. |  * Mutexes. By adding mutex callback support, the 'data sharing' mentioned | ||||||
|  |    above can be made between several easy handles running in different threads | ||||||
|  |    too. The actual mutex implementations will be left for the application to | ||||||
|  |    implement, libcurl will merely call 'getmutex' and 'leavemutex' callbacks. | ||||||
|  |    Part of the sharing suggestion at: http://curl.haxx.se/dev/sharing.txt | ||||||
|  |  | ||||||
|  |  * Set the SO_KEEPALIVE socket option to make libcurl notice and disconnect | ||||||
|  |    very long time idle connections. | ||||||
|  |  | ||||||
|  |  * Go through the code and verify that libcurl deals with big files >2GB and | ||||||
|  |    >4GB all over. Bug reports (and source reviews) indicate that it doesn't | ||||||
|  |    currently work properly. | ||||||
|  |  | ||||||
|  |  * CURLOPT_MAXFILESIZE. Prevent downloads that are larger than the specified | ||||||
|  |    size. CURLE_FILESIZE_EXCEEDED would then be returned. Gautam Mani | ||||||
|  |    requested. That is, the download should not even begin but be aborted | ||||||
|  |    immediately. | ||||||
|  |  | ||||||
|  |  * Allow the http_proxy (and other) environment variables to contain user and | ||||||
|  |    password as well in the style: http://proxyuser:proxypasswd@proxy:port | ||||||
|  |    Berend Reitsma suggested. | ||||||
|  |  | ||||||
|  |  LIBCURL - multi interface | ||||||
|  |  | ||||||
|  |  * Make sure we don't ever loop because of non-blocking sockets return | ||||||
|  |    EWOULDBLOCK or similar. This FTP command sending, the SSL connection etc. | ||||||
|  |  | ||||||
|  |  * Make transfers treated more carefully. We need a way to tell libcurl we | ||||||
|  |    have data to write, as the current system expects us to upload data each | ||||||
|  |    time the socket is writable and there is no way to say that we want to | ||||||
|  |    upload data soon just not right now, without that aborting the upload. The | ||||||
|  |    opposite situation should be possible as well, that we tell libcurl we're | ||||||
|  |    ready to accept read data. Today libcurl feeds the data as soon as it is | ||||||
|  |    available for reading, no matter what. | ||||||
|  |  | ||||||
|  DOCUMENTATION |  DOCUMENTATION | ||||||
|  |  | ||||||
|  * Document all CURLcode error codes, why they happen and what most likely |  * More and better | ||||||
|    will make them not happen again. |  | ||||||
|  |  | ||||||
|  FTP |  FTP | ||||||
|  |  | ||||||
|  |  * Make CURLOPT_FTPPORT support an additional port number on the IP/if/name, | ||||||
|  |    like "blabla:[port]" or possibly even "blabla:[portfirst]-[portsecond]". | ||||||
|  |  | ||||||
|  * FTP ASCII upload does not follow RFC959 section 3.1.1.1: "The sender |  * FTP ASCII upload does not follow RFC959 section 3.1.1.1: "The sender | ||||||
|    converts the data from an internal character representation to the standard |    converts the data from an internal character representation to the standard | ||||||
|    8-bit NVT-ASCII representation (see the Telnet specification).  The |    8-bit NVT-ASCII representation (see the Telnet specification).  The | ||||||
|    receiver will convert the data from the standard form to his own internal |    receiver will convert the data from the standard form to his own internal | ||||||
|    form." |    form." | ||||||
|  |  | ||||||
|  |  * Since USERPWD always override the user and password specified in URLs, we | ||||||
|  |    might need another way to specify user+password for anonymous ftp logins. | ||||||
|  |  | ||||||
|  * An option to only download remote FTP files if they're newer than the local |  * An option to only download remote FTP files if they're newer than the local | ||||||
|    one is a good idea, and it would fit right into the same syntax as the |    one is a good idea, and it would fit right into the same syntax as the | ||||||
|    already working http dito works. It of course requires that 'MDTM' works, |    already working http dito works (-z). It of course requires that 'MDTM' | ||||||
|    and it isn't a standard FTP command. |    works, and it isn't a standard FTP command. | ||||||
|  |  | ||||||
|  * Suggested on the mailing list: CURLOPT_FTP_MKDIR...! |  * Add FTPS support with SSL for the data connection too.  This should be made | ||||||
|  |    according to the specs written in draft-murray-auth-ftp-ssl-08.txt, | ||||||
|  |    "Securing FTP with TLS" | ||||||
|  |  | ||||||
|  * Always use the FTP SIZE command before downloading, as that makes it more |  * --disable-epsv exists, but for active connections we have no --disable-eprt | ||||||
|    likely that we know the size when downloading. Some sites support SIZE but |    (or even --disable-lprt). | ||||||
|    don't show the size in the RETR response! |  | ||||||
|  |  | ||||||
|  HTTP |  HTTP | ||||||
|  |  | ||||||
|  * HTTP PUT for files passed on stdin *OR* when the --crlf option is |  * If the "body" of the POST is < MSS it really aught to be sent along with | ||||||
|    used. Requires libcurl to send the file with chunked content |    the headers. More generally, if the last chunk of the POST body is < MSS, | ||||||
|    encoding. [http://curl.haxx.se/dev/HTTP-PUT-stdin.txt] When the filter |    it should be sent with the previous chunk (which may be the POST headers). | ||||||
|    system mentioned above gets real, it'll be a piece of cake to add. |    So long as any one send is larger than MSS (or there is only one send when | ||||||
|  |    < MSS :), the Nagle Algorithm will not be a problem on any stack where | ||||||
|  * "Content-Encoding: compress/gzip/zlib" HTTP 1.1 clearly defines how to get |    Nagle is implemented correctly. (pointed out by Rick Jones) | ||||||
|    and decode compressed documents. There is the zlib that is pretty good at |  | ||||||
|    decompressing stuff. This work was started in October 1999 but halted again |  | ||||||
|    since it proved more work than we thought. It is still a good idea to |  | ||||||
|    implement though. This requires the filter system mentioned above. |  | ||||||
|  |  | ||||||
|  * Authentication: NTLM. Support for that MS crap called NTLM |  * Authentication: NTLM. Support for that MS crap called NTLM | ||||||
|    authentication. MS proxies and servers sometime require that. Since that |    authentication. MS proxies and servers sometime require that. Since that | ||||||
| @@ -83,50 +116,102 @@ TODO | |||||||
|    http://www.innovation.ch/java/ntlm.html that contains detailed reverse- |    http://www.innovation.ch/java/ntlm.html that contains detailed reverse- | ||||||
|    engineered info. |    engineered info. | ||||||
|  |  | ||||||
|  * RFC2617 compliance, "Digest Access Authentication" |  * RFC2617 compliance, "Digest Access Authentication" A valid test page seem | ||||||
|    A valid test page seem to exist at: |    to exist at: http://hopf.math.nwu.edu/testpage/digest/ And some friendly | ||||||
|    http://hopf.math.nwu.edu/testpage/digest/ |    person's server source code is available at | ||||||
|    And some friendly person's server source code is available at |    http://hopf.math.nwu.edu/digestauth/index.html Then there's the Apache | ||||||
|    http://hopf.math.nwu.edu/digestauth/index.html |    mod_digest source code too of course.  It seems as if Netscape doesn't | ||||||
|    Then there's the Apache mod_digest source code too of course.  It seems as |    support this, and not many servers do. Although this is a lot better | ||||||
|    if Netscape doesn't support this, and not many servers do. Although this is |    authentication method than the more common "Basic". Basic sends the | ||||||
|    a lot better authentication method than the more common "Basic". Basic |    password in cleartext over the network, this "Digest" method uses a | ||||||
|    sends the password in cleartext over the network, this "Digest" method uses |    challange-response protocol which increases security quite a lot. | ||||||
|    a challange-response protocol which increases security quite a lot. |  | ||||||
|  |  * Pipelining. Sending multiple requests before the previous one(s) are done. | ||||||
|  |    This could possibly be implemented using the multi interface to queue | ||||||
|  |    requests and the response data. | ||||||
|  |  | ||||||
|  TELNET |  TELNET | ||||||
|  |  | ||||||
|  * Make TELNET work on windows98! |  * Make TELNET work on windows98! | ||||||
|  |  | ||||||
|  |  * Reading input (to send to the remote server) on stdin is a crappy solution | ||||||
|  |    for library purposes. We need to invent a good way for the application to | ||||||
|  |    be able to provide the data to send. | ||||||
|  |  | ||||||
|  |  * Move the telnet support's network select() loop go away and merge the code | ||||||
|  |    into the main transfer loop. Until this is done, the multi interface won't | ||||||
|  |    work for telnet. | ||||||
|  |  | ||||||
|  SSL |  SSL | ||||||
|  |  | ||||||
|  |  * If you really want to improve the SSL situation, you should probably have a | ||||||
|  |    look at SSL cafile loading as well - quick traces look to me like these are | ||||||
|  |    done on every request as well, when they should only be necessary once per | ||||||
|  |    ssl context (or once per handle). Even better would be to support the SSL | ||||||
|  |    CAdir option - instead of loading all of the root CA certs for every | ||||||
|  |    request, this option allows you to only read the CA chain that is actually | ||||||
|  |    required (into the cache)... | ||||||
|  |  | ||||||
|  * 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" |    by mod_ssl for apache to implement and SSL session ID cache". This whole | ||||||
|  |    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 | ||||||
|  |    certificate, but this doesn't seem to be exposed in the libcurl APIs. Could | ||||||
|  |    it be? There's so much that could be done if it were! (brought by Chris | ||||||
|  |    Clark) | ||||||
|  |  | ||||||
|  * 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://gnutls.hellug.gr/) | ||||||
|  |  | ||||||
|  |  LDAP | ||||||
|  |  | ||||||
|  |  * Look over the implementation. The looping will have to "go away" from the | ||||||
|  |    lib/ldap.c source file and get moved to the main network code so that the | ||||||
|  |    multi interface and friends will work for LDAP as well. | ||||||
|  |  | ||||||
|  CLIENT |  CLIENT | ||||||
|  |  | ||||||
|  |  * 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 | ||||||
|  |    (either -O or -o), a number should be appended (and increased if already | ||||||
|  |    existing). So that index.html becomes first index.html.1 and then | ||||||
|  |    index.html.2 etc. Jeff Pohlmeyer suggested. | ||||||
|  |  | ||||||
|  * "curl ftp://site.com/*.txt" |  * "curl ftp://site.com/*.txt" | ||||||
|  |  | ||||||
|  * Several URLs can be specified to get downloaded. We should be able to use |  * Several URLs can be specified to get downloaded. We should be able to use | ||||||
|    the same syntax to specify several files to get uploaded (using the same |    the same syntax to specify several files to get uploaded (using the same | ||||||
|    persistant connection), using -T. |    persistant connection), using -T. | ||||||
|  |  | ||||||
|  * Say you have a list of FTP addresses to download in a file named |  * When the multi interface has been implemented and proved to work, the | ||||||
|    ftp-list.txt: "cat ftp-list.txt | xargs curl -O -O -O [...]". curl _needs_ |    client could be told to use maximum N simultaneous transfers and then just | ||||||
|    an "-Oalways" flag -- all addresses on the command line use the base |    make sure that happens. It should of course not make more than one | ||||||
|    filename to store locally.  Else a script must precount the # of URLs, |    connection to the same remote host. | ||||||
|    construct the proper number of "-O"s... |  | ||||||
|  |  * Extending the capabilities of the multipart formposting. How about leaving | ||||||
|  |    the ';type=foo' syntax as it is and adding an extra tag (headers) which | ||||||
|  |    works like this: curl -F "coolfiles=@fil1.txt;headers=@fil1.hdr" where | ||||||
|  |    fil1.hdr contains extra headers like | ||||||
|  |  | ||||||
|  |      Content-Type: text/plain; charset=KOI8-R" | ||||||
|  |      Content-Transfer-Encoding: base64 | ||||||
|  |      X-User-Comment: Please don't use browser specific HTML code | ||||||
|  |  | ||||||
|  |    which should overwrite the program reasonable defaults (plain/text, | ||||||
|  |    8bit...) (Idea brough to us by kromJx) | ||||||
|  |  | ||||||
|  TEST SUITE |  TEST SUITE | ||||||
|  |  | ||||||
|  |  * If perl wasn't found by the configure script, don't attempt to run the | ||||||
|  |    tests but explain something nice why it doesn't. | ||||||
|  |  | ||||||
|  * Extend the test suite to include more protocols. The telnet could just do |  * Extend the test suite to include more protocols. The telnet could just do | ||||||
|    ftp or http operations (for which we have test servers). |    ftp or http operations (for which we have test servers). | ||||||
|  |  | ||||||
| @@ -134,3 +219,10 @@ TODO | |||||||
|    fork()s and it should become even more portable. |    fork()s and it should become even more portable. | ||||||
|  |  | ||||||
|  * Introduce a test suite that tests libcurl better and more explicitly. |  * Introduce a test suite that tests libcurl better and more explicitly. | ||||||
|  |  | ||||||
|  | NEXT MAJOR RELEASE | ||||||
|  |  | ||||||
|  |  * curl_easy_cleanup() returns void, but curl_multi_cleanup() returns a | ||||||
|  |    CURLMcode. These should be changed to be the same. | ||||||
|  |  | ||||||
|  |  * curl_formparse() should be removed | ||||||
|   | |||||||
| @@ -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 "16 August 2001" "Curl 7.8.1" "curl-config manual" | .TH curl-config 1 "8 Oct 2002" "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 | ||||||
| @@ -11,6 +11,10 @@ curl-config \- Get information about a libcurl installation | |||||||
| .B curl-config | .B curl-config | ||||||
| displays information about a previous curl and libcurl installation. | displays information about a previous curl and libcurl installation. | ||||||
| .SH OPTIONS | .SH OPTIONS | ||||||
|  | .IP "--ca" | ||||||
|  | Displays the built-in path to the CA cert bundle this libcurl uses. | ||||||
|  | .IP "--cc" | ||||||
|  | Displays the compiler used to build libcurl. | ||||||
| .IP "--cflags" | .IP "--cflags" | ||||||
| Set of compiler options (CFLAGS) to use when compiling files that use | Set of compiler options (CFLAGS) to use when compiling files that use | ||||||
| libcurl. Currently that is only thw include path to the curl include files. | libcurl. Currently that is only thw include path to the curl include files. | ||||||
| @@ -38,18 +42,23 @@ major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl | |||||||
| .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? | ||||||
|  |  | ||||||
|   curl-config --libs |   $ curl-config --libs | ||||||
|  |  | ||||||
| What compiler options do I need when I compile using libcurl functions? | What compiler options do I need when I compile using libcurl functions? | ||||||
|  |  | ||||||
|   curl-config --cflags |   $ curl-config --cflags | ||||||
|  |  | ||||||
| How do I know if libcurl was built with SSL support? | How do I know if libcurl was built with SSL support? | ||||||
|  |  | ||||||
|   curl-config --feature | grep SSL |   $ curl-config --feature | grep SSL | ||||||
|  |  | ||||||
| What's the installed libcurl version? | What's the installed libcurl version? | ||||||
|  |  | ||||||
|   curl-config --version |   $ curl-config --version | ||||||
|  |  | ||||||
|  | How do I build a single file with a one-line command? | ||||||
|  |  | ||||||
|  |   $ `curl-config --cc --cflags --libs` -o example example.c | ||||||
|  |  | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .BR curl (1) | .BR curl (1) | ||||||
|   | |||||||
							
								
								
									
										240
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										240
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | |||||||
| .\" nroff -man curl.1 | .\" nroff -man curl.1 | ||||||
| .\" Written by Daniel Stenberg | .\" Written by Daniel Stenberg | ||||||
| .\" | .\" | ||||||
| .TH curl 1 "30 Nov 2001" "Curl 7.9.2" "Curl Manual" | .TH curl 1 "14 Feb 2003" "Curl 7.10.3" "Curl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl \- transfer a URL | curl \- transfer a URL | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -95,14 +95,15 @@ If this option is used twice, the second one will disable ASCII usage. | |||||||
| must be using valid ciphers. Read up on SSL cipher list details on this URL: | must be using valid ciphers. Read up on SSL cipher list details on this URL: | ||||||
| .I http://www.openssl.org/docs/apps/ciphers.html (Option added in curl 7.9) | .I http://www.openssl.org/docs/apps/ciphers.html (Option added in curl 7.9) | ||||||
|  |  | ||||||
| If this option is used severl times, the last one will override the others. | If this option is used several times, the last one will override the others. | ||||||
|  | .IP "--compressed" | ||||||
|  | (HTTP) Request a compressed response using the deflate or gzip | ||||||
|  | algorithms and return the uncompressed document.  If this option is used | ||||||
|  | and the server sends an unsupported encoding, Curl will report an error. | ||||||
| .IP "--connect-timeout <seconds>" | .IP "--connect-timeout <seconds>" | ||||||
| Maximum time in seconds that you allow the connection to the server to take. | Maximum time in seconds that you allow the connection to the server to take. | ||||||
| This only limits the connection phase, once curl has connected this option is | This only limits the connection phase, once curl has connected this option is | ||||||
| of no more use. This option didn't work in win32 systems until 7.7.2.  See | of no more use. See also the \fI--max-time\fP option. | ||||||
| also the |  | ||||||
| .I "--max-time" |  | ||||||
| option. |  | ||||||
|  |  | ||||||
| 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 "-c/--cookie-jar <file name>" | .IP "-c/--cookie-jar <file name>" | ||||||
| @@ -113,6 +114,12 @@ no file will be written. The file will be written using the Netscape cookie | |||||||
| file format. If you set the file name to a single dash, "-", the cookies will | file format. If you set the file name to a single dash, "-", the cookies will | ||||||
| be written to stdout. (Option added in curl 7.9) | be written to stdout. (Option added in curl 7.9) | ||||||
|  |  | ||||||
|  | .B NOTE | ||||||
|  | If the cookie jar can't be created or written to, the whole curl operation | ||||||
|  | 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 | ||||||
|  | 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 specfied file name will be | ||||||
| used. | used. | ||||||
| .IP "-C/--continue-at <offset>" | .IP "-C/--continue-at <offset>" | ||||||
| @@ -125,6 +132,13 @@ Use "-C -" to tell curl to automatically find out where/how to resume the | |||||||
| transfer. It then uses the given output/input files to figure that out. | transfer. It then uses the given output/input files to figure that out. | ||||||
|  |  | ||||||
| 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 "--create-dirs" | ||||||
|  | When used in conjunction with the -o option, curl will create the necessary  | ||||||
|  | local directory hierarchy as needed. | ||||||
|  | .IP "--crlf" | ||||||
|  | (FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390). | ||||||
|  |  | ||||||
|  | If this option is used twice, the second will again disable crlf converting. | ||||||
| .IP "-d/--data <data>" | .IP "-d/--data <data>" | ||||||
| (HTTP) Sends the specified data in a POST request to the HTTP server, in a way | (HTTP) Sends the specified data in a POST request to the HTTP server, in a way | ||||||
| that can emulate as if a user has filled in a HTML form and pressed the submit | that can emulate as if a user has filled in a HTML form and pressed the submit | ||||||
| @@ -167,16 +181,17 @@ append data. | |||||||
| downloads. Curl will normally always first attempt to use EPSV before PASV, | downloads. Curl will normally always first attempt to use EPSV before PASV, | ||||||
| but with this option, it will not try using EPSV. | but with this option, it will not try using EPSV. | ||||||
|  |  | ||||||
| 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 "-D/--dump-header <file>" | .IP "-D/--dump-header <file>" | ||||||
| (HTTP/FTP) | Write the protocol headers to the specified file. | ||||||
| Write the HTTP headers to this file. Write the FTP file info to this |  | ||||||
| file if -I/--head is used. |  | ||||||
|  |  | ||||||
| This option is handy to use when you want to store the cookies that a HTTP | This option is handy to use when you want to store the cookies that a HTTP | ||||||
| site sends to you. The cookies could then be read in a second curl invoke by | site sends to you. The cookies could then be read in a second curl invoke by | ||||||
| using the -b/--cookie option! | using the -b/--cookie option! | ||||||
|  |  | ||||||
|  | When used on FTP, the ftp server response lines are considered being "headers" | ||||||
|  | and thus are saved there. | ||||||
|  |  | ||||||
| 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 "-e/--referer <URL>" | .IP "-e/--referer <URL>" | ||||||
| (HTTP) Sends the "Referer Page" information to the HTTP server. This can also | (HTTP) Sends the "Referer Page" information to the HTTP server. This can also | ||||||
| @@ -187,6 +202,12 @@ previous URL when it follows a Location: header. The ";auto" string can be | |||||||
| used alone, even if you don't set an initial referer. | 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 "--environment" | ||||||
|  | (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 | ||||||
|  | run curl. | ||||||
|  |  | ||||||
|  | If this option is used several times, each occurrence will toggle this on/off. | ||||||
| .IP "--egd-file <file>" | .IP "--egd-file <file>" | ||||||
| (HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The | (HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The | ||||||
| socket is used to seed the random engine for SSL connections. See also the | socket is used to seed the random engine for SSL connections. See also the | ||||||
| @@ -203,17 +224,32 @@ certificate concatenated! | |||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "--cacert <CA certificate>" | .IP "--cacert <CA certificate>" | ||||||
| (HTTPS) Tells curl to use the specified certificate file to verify the | (HTTPS) Tells curl to use the specified certificate file to verify the | ||||||
| peer. The certificate must be in PEM format. | peer. The file may contain multiple CA certificates. The certificate(s) must | ||||||
|  | be in PEM format. | ||||||
|  |  | ||||||
|  | curl recognizes the environment variable named 'CURL_CA_BUNDLE' if that is | ||||||
|  | set, and uses the given path as a path to a CA cert bundle. This option | ||||||
|  | overrides that variable. | ||||||
|  |  | ||||||
|  | The windows version of curl will automatically look for a CA certs file named | ||||||
|  | \'curl-ca-bundle.crt\', either in the same directory as curl.exe, or in the | ||||||
|  | Current Working Directory, or in any folder along your PATH. | ||||||
|  |  | ||||||
|  | If this option is used several times, the last one will be used. | ||||||
|  | .IP "--capath <CA certificate directory>" | ||||||
|  | (HTTPS) Tells curl to use the specified certificate directory to verify the | ||||||
|  | peer. The certificates must be in PEM format, and the directory must have been | ||||||
|  | processed using the c_rehash utility supplied with openssl. Using --capath can | ||||||
|  | allow curl to make https connections much more efficiently than using --cacert | ||||||
|  | if the --cacert file contains many CA certificates. | ||||||
|  |  | ||||||
| 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 "-f/--fail" | .IP "-f/--fail" | ||||||
| (HTTP) | (HTTP) Fail silently (no output at all) on server errors. This is mostly done | ||||||
| Fail silently (no output at all) on server errors. This is mostly done | like this to better enable scripts etc to better deal with failed attempts. In | ||||||
| like this to better enable scripts etc to better deal with failed | normal cases when a HTTP server fails to deliver a document, it returns a HTML | ||||||
| attempts. In normal cases when a HTTP server fails to deliver a | document stating so (which often also describes why and more). This flag will | ||||||
| document, it returns a HTML document stating so (which often also | prevent curl from outputting that and fail silently instead. | ||||||
| describes why and more). This flag will prevent curl from |  | ||||||
| outputting that and fail silently instead. |  | ||||||
|  |  | ||||||
| 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 "-F/--form <name=content>" | .IP "-F/--form <name=content>" | ||||||
| @@ -230,24 +266,34 @@ Example, to send your password file to the server, where | |||||||
| \&'password' is the name of the form-field to which /etc/passwd will be the | \&'password' is the name of the form-field to which /etc/passwd will be the | ||||||
| input: | input: | ||||||
|  |  | ||||||
| .B curl | \fBcurl\fP -F password=@/etc/passwd www.mypasswords.com | ||||||
| -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 insted 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 | ||||||
|  | using 'type=', in a manner similar to: | ||||||
|  |  | ||||||
|  | \fBcurl\fP -F "web=@index.html;type=text/html" url.com | ||||||
|  |  | ||||||
|  | See further examples and details in the MANUAL. | ||||||
|  |  | ||||||
| This option can be used multiple times. | This option can be used multiple times. | ||||||
| .IP "-g/--globoff" | .IP "-g/--globoff" | ||||||
| This option switches off the "URL globbing parser". When you set this option, | This option switches off the "URL globbing parser". When you set this option, | ||||||
| you can specify URLs that contain the letters {}[] without having them being | you can specify URLs that contain the letters {}[] without having them being | ||||||
| interpreted by curl itself. Note that these letters are not normal legal URL | interpreted by curl itself. Note that these letters are not normal legal URL | ||||||
| contents but they should be encoded according to the URI standard. (Option | contents but they should be encoded according to the URI standard. | ||||||
| added in curl 7.6) |  | ||||||
| .IP "-G/--get" | .IP "-G/--get" | ||||||
| When used, this option will make all data specified with -d/--data or | When used, this option will make all data specified with -d/--data or | ||||||
| --data-binary to be used in a HTTP GET request instead of the POST request | --data-binary to be used in a HTTP GET request instead of the POST request | ||||||
| that otherwise would be used. The data will be appended to the URL with a '?' | that otherwise would be used. The data will be appended to the URL with a '?' | ||||||
| separator. (Option added in curl 7.9) | separator. (Option added in curl 7.9) | ||||||
|  |  | ||||||
|  | If used in combination with -I, the POST data will instead be appended to the | ||||||
|  | URL with a HEAD request. | ||||||
|  |  | ||||||
|  | If used multiple times, nothing special happens. | ||||||
| .IP "-h/--help" | .IP "-h/--help" | ||||||
| Usage help. | Usage help. | ||||||
| .IP "-H/--header <header>" | .IP "-H/--header <header>" | ||||||
| @@ -260,7 +306,7 @@ set headers without knowing perfectly well what you're doing. Replacing an | |||||||
| internal header with one without content on the right side of the colon will | internal header with one without content on the right side of the colon will | ||||||
| prevent that header from appearing. | prevent that header from appearing. | ||||||
|  |  | ||||||
| This option can be used multiple times. | This option can be used multiple times to add/replace/remove multiple headers. | ||||||
| .IP "-i/--include" | .IP "-i/--include" | ||||||
| (HTTP) | (HTTP) | ||||||
| Include the HTTP-header in the output. The HTTP-header includes things | Include the HTTP-header in the output. The HTTP-header includes things | ||||||
| @@ -281,6 +327,23 @@ which this uses to get nothing but the header of a document. When used | |||||||
| on a FTP file, curl displays the file size only. | on a FTP file, curl displays the file size 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" | ||||||
|  | (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 | ||||||
|  | as if a new session is started. Typical browsers always discard session | ||||||
|  | cookies when they're closed down. (Added in 7.9.7) | ||||||
|  |  | ||||||
|  | If this option is used several times, each occurrence will toggle this on/off. | ||||||
|  | .IP "-k/--insecure" | ||||||
|  | (SSL) This option explicitly allows curl to perform "insecure" SSL connections | ||||||
|  | and transfers. Starting with curl 7.10, all SSL connections will be attempted | ||||||
|  | to be made secure by using the CA certificate bundle installed by | ||||||
|  | default. This makes all connections considered "insecure" to fail unless | ||||||
|  | -k/--insecure is used. | ||||||
|  |  | ||||||
|  | This option is ignored if --cacert or --capath is used! | ||||||
|  |  | ||||||
|  | If this option is used twice, the second time will again disable it. | ||||||
| .IP "--krb4 <level>" | .IP "--krb4 <level>" | ||||||
| (FTP) Enable kerberos4 authentication and use. The level must be entered and | (FTP) Enable kerberos4 authentication and use. The level must be entered and | ||||||
| should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use | should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use | ||||||
| @@ -298,7 +361,26 @@ treated as a comment. | |||||||
|  |  | ||||||
| Specify the filename as '-' to make curl read the file from stdin. | Specify the filename as '-' to make curl read the file from stdin. | ||||||
|  |  | ||||||
|  | Note that to be able to specify a URL in the config file, you need to specify | ||||||
|  | it using the --url option, and not by simply writing the URL on its own | ||||||
|  | line. So, it could look similar to this: | ||||||
|  |  | ||||||
|  | url = "http://curl.haxx.se/docs/" | ||||||
|  |  | ||||||
| This option can be used multiple times. | This option can be used multiple times. | ||||||
|  | .IP "--limit-rate <speed>" | ||||||
|  | Specify the maximum transfer rate you want curl to use. This feature is useful | ||||||
|  | if you have a limited pipe and you'd like your transfer not use your entire | ||||||
|  | bandwidth. | ||||||
|  |  | ||||||
|  | The given speed is measured in bytes/second, unless a suffix is | ||||||
|  | appended. Appending 'k' or 'K' will count the number as kilobytes, 'm' or M' | ||||||
|  | makes it megabytes while 'g' or 'G' makes it gigabytes. Examples: 200K, 3m and | ||||||
|  | 1G. | ||||||
|  |  | ||||||
|  | This option was introduced in curl 7.10. | ||||||
|  |  | ||||||
|  | If this option is used several times, the last one will be used. | ||||||
| .IP "-l/--list-only" | .IP "-l/--list-only" | ||||||
| (FTP) | (FTP) | ||||||
| When listing an FTP directory, this switch forces a name-only view. | When listing an FTP directory, this switch forces a name-only view. | ||||||
| @@ -306,6 +388,10 @@ Especially useful if you want to machine-parse the contents of an FTP | |||||||
| directory since the normal directory view doesn't use a standard look | directory since the normal directory view doesn't use a standard look | ||||||
| or format. | or format. | ||||||
|  |  | ||||||
|  | This option causes an FTP NLST command to be sent.  Some FTP servers | ||||||
|  | list only files in their response to NLST; they do not include | ||||||
|  | subdirectories and symbolic links. | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable list only. | If this option is used twice, the second will again disable list only. | ||||||
| .IP "-L/--location" | .IP "-L/--location" | ||||||
| (HTTP/HTTPS) If the server reports that the requested page has a different | (HTTP/HTTPS) If the server reports that the requested page has a different | ||||||
| @@ -319,10 +405,8 @@ If this option is used twice, the second will again disable location following. | |||||||
| .IP "-m/--max-time <seconds>" | .IP "-m/--max-time <seconds>" | ||||||
| Maximum time in seconds that you allow the whole operation to take.  This is | Maximum time in seconds that you allow the whole operation to take.  This is | ||||||
| useful for preventing your batch jobs from hanging for hours due to slow | useful for preventing your batch jobs from hanging for hours due to slow | ||||||
| networks or links going down.  This doesn't work fully in win32 systems. | networks or links going down.  This doesn't work fully in win32 systems.  See | ||||||
| See also the | also the \fI--connect-timeout\fP option. | ||||||
| .I "--connect-timeout" |  | ||||||
| option. |  | ||||||
|  |  | ||||||
| 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 "-M/--manual" | .IP "-M/--manual" | ||||||
| @@ -369,6 +453,8 @@ or use several variables like: | |||||||
|   curl http://{site,host}.host[1-5].com -o "#1_#2" |   curl http://{site,host}.host[1-5].com -o "#1_#2" | ||||||
|  |  | ||||||
| You may use this option as many times as you have number of URLs. | You may use this option as many times as you have number of URLs. | ||||||
|  |  | ||||||
|  | See also the --create-dirs option to create the local directories dynamically. | ||||||
| .IP "-O/--remote-name" | .IP "-O/--remote-name" | ||||||
| Write output to a local file named like the remote file we get. (Only | Write output to a local file named like the remote file we get. (Only | ||||||
| the file part of the remote file is used, the path is cut off.) | the file part of the remote file is used, the path is cut off.) | ||||||
| @@ -479,6 +565,12 @@ If this option is used twice, the second will again disable mute. | |||||||
| When used with -s it makes curl show error message if it fails. | When used with -s it makes curl show error message if it fails. | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable show error. | If this option is used twice, the second will again disable show error. | ||||||
|  | .IP "--stderr <file>" | ||||||
|  | Redirect all writes to stderr to the specified file instead. If the file name | ||||||
|  | is a plain '-', it is instead written to stdout. This option has no point when | ||||||
|  | you're using a shell with decent redirecting capabilities. | ||||||
|  |  | ||||||
|  | If this option is used several times, the last one will be used. | ||||||
| .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: | ||||||
|  |  | ||||||
| @@ -498,10 +590,28 @@ this is used on a http(s) server, the PUT command will be used. | |||||||
| Use the file name "-" (a single dash) to use stdin instead of a given file. | Use the file name "-" (a single dash) to use stdin instead of a given file. | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
|  | .IP "--trace <file>" | ||||||
|  | Enables a full trace dump of all incoming and outgoing data, including | ||||||
|  | descriptive information, to the given output file. Use "-" as filename to have | ||||||
|  | the output sent to stdout. | ||||||
|  |  | ||||||
|  | If this option is used several times, the last one will be used. (Added in | ||||||
|  | curl 7.9.7) | ||||||
|  | .IP "--trace-ascii <file>" | ||||||
|  | Enables a full trace dump of all incoming and outgoing data, including | ||||||
|  | descriptive information, to the given output file. Use "-" as filename to have | ||||||
|  | the output sent to stdout. | ||||||
|  |  | ||||||
|  | This is very similar to --trace, but leaves out the hex part and only shows | ||||||
|  | the ASCII part of the dump. It makes smaller output that might be easier to | ||||||
|  | read for untrained humans. | ||||||
|  |  | ||||||
|  | If this option is used several times, the last one will be used. (Added in | ||||||
|  | curl 7.9.7) | ||||||
| .IP "-u/--user <user:password>" | .IP "-u/--user <user:password>" | ||||||
| Specify user and password to use when fetching. See README.curl for detailed | Specify user and password to use when fetching. Read the MANUAL for detailed | ||||||
| examples of how to use this. If no password is specified, curl will | examples of how to use this. If no password is specified, curl will ask for it | ||||||
| ask for it interactively. | interactively. | ||||||
|  |  | ||||||
| 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 "-U/--proxy-user <user:password>" | .IP "-U/--proxy-user <user:password>" | ||||||
| @@ -510,7 +620,7 @@ password is specified, curl will ask for it interactively. | |||||||
|  |  | ||||||
| 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 "--url <URL>" | .IP "--url <URL>" | ||||||
| Specify a URL to fetch. This option is mostly handy when you wanna specify | Specify a URL to fetch. This option is mostly handy when you want to specify | ||||||
| URL(s) in a config file. | URL(s) in a config file. | ||||||
|  |  | ||||||
| This option may be used any number of times. To control where this URL is written, use the | This option may be used any number of times. To control where this URL is written, use the | ||||||
| @@ -519,10 +629,16 @@ or the | |||||||
| .I -O | .I -O | ||||||
| options. | options. | ||||||
| .IP "-v/--verbose" | .IP "-v/--verbose" | ||||||
| Makes the fetching more verbose/talkative. Mostly usable for | Makes the fetching more verbose/talkative. Mostly usable for debugging. Lines | ||||||
| debugging. Lines starting with '>' means data sent by curl, '<' | starting with '>' means data sent by curl, '<' means data received by curl | ||||||
| means data received by curl that is hidden in normal cases and lines | that is hidden in normal cases and lines starting with '*' means additional | ||||||
| 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 | ||||||
|  | might be option you're looking for. | ||||||
|  |  | ||||||
|  | If you think this option still doesn't give you enough details, consider using | ||||||
|  | \fI--trace\fP or \fI--trace-ascii\fP instead. | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable verbose. | If this option is used twice, the second will again disable verbose. | ||||||
| .IP "-V/--version" | .IP "-V/--version" | ||||||
| @@ -538,7 +654,7 @@ write "@-". | |||||||
| The variables present in the output format will be substituted by the value or | The variables present in the output format will be substituted by the value or | ||||||
| text that curl thinks fit, as described below. All variables are specified | text that curl thinks fit, as described below. All variables are specified | ||||||
| like %{variable_name} and to output a normal % you just write them like | like %{variable_name} and to output a normal % you just write them like | ||||||
| %%. You can output a newline by using \\n, a carrige return with \\r and a tab | %%. You can output a newline by using \\n, a carriage return with \\r and a tab | ||||||
| space with \\t. | space with \\t. | ||||||
|  |  | ||||||
| .B NOTE: | .B NOTE: | ||||||
| @@ -594,6 +710,9 @@ The average download speed that curl measured for the complete download. | |||||||
| .TP | .TP | ||||||
| .B speed_upload | .B speed_upload | ||||||
| The average upload speed that curl measured for the complete upload. | The average upload speed that curl measured for the complete upload. | ||||||
|  | .TP | ||||||
|  | .B content_type | ||||||
|  | The Content-Type of the requested document, if there was any. (Added in 7.9.5) | ||||||
| .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. | ||||||
| @@ -601,6 +720,10 @@ If this option is used several times, the last one will be used. | |||||||
| Use specified HTTP proxy. If the port number is not specified, it is assumed | Use specified HTTP proxy. If the port number is not specified, it is assumed | ||||||
| at port 1080. | at port 1080. | ||||||
|  |  | ||||||
|  | This option overrides existing environment variables that sets proxy to | ||||||
|  | use. If there's an environment variable setting a proxy, you can set proxy to | ||||||
|  | "" 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 | transparantly 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 | ||||||
| @@ -623,6 +746,9 @@ If a download is slower than speed-limit bytes per second during a speed-time | |||||||
| period, the download gets aborted. If speed-time is used, the default | period, the download gets aborted. If speed-time is used, the default | ||||||
| speed-limit will be 1 unless set with -y. | speed-limit will be 1 unless set with -y. | ||||||
|  |  | ||||||
|  | This option controls transfers and thus will not affect slow connects etc. If | ||||||
|  | this is a concern for you, try the \fI--connect-timeout\fP option. | ||||||
|  |  | ||||||
| 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 "-Y/--speed-limit <speed>" | .IP "-Y/--speed-limit <speed>" | ||||||
| If a download is slower than this given speed, in bytes per second, for | If a download is slower than this given speed, in bytes per second, for | ||||||
| @@ -645,6 +771,12 @@ 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. | ||||||
|  | .IP "-Z/--max-redirs <num>" | ||||||
|  | Set maximum number of redirection-followings allowed. If -L/--location is | ||||||
|  | used, this option can be used to prevent curl from following redirections "in | ||||||
|  | absurdum". | ||||||
|  |  | ||||||
| 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 "-3/--sslv3" | .IP "-3/--sslv3" | ||||||
| (HTTPS) | (HTTPS) | ||||||
| @@ -660,16 +792,6 @@ Make curl display progress information as a progress bar instead of the | |||||||
| default statistics. | default statistics. | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable the progress bar. | If this option is used twice, the second will again disable the progress bar. | ||||||
| .IP "--crlf" |  | ||||||
| (FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390). |  | ||||||
|  |  | ||||||
| If this option is used twice, the second will again disable crlf converting. |  | ||||||
| .IP "--stderr <file>" |  | ||||||
| Redirect all writes to stderr to the specified file instead. If the file name |  | ||||||
| is a plain '-', it is instead written to stdout. This option has no point when |  | ||||||
| you're using a shell with decent redirecting capabilities. |  | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. |  | ||||||
| .SH FILES | .SH FILES | ||||||
| .I ~/.curlrc | .I ~/.curlrc | ||||||
| .RS | .RS | ||||||
| @@ -731,13 +853,15 @@ 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 transfered. | ||||||
| .IP 19 | .IP 19 | ||||||
| FTP couldn't RETR file. The RETR command failed. | FTP couldn't download/access the given file, the RETR (or similar) command | ||||||
|  | failed. | ||||||
| .IP 20 | .IP 20 | ||||||
| FTP write error. The transfer was reported bad by the server. | FTP write error. The transfer was reported bad by the server. | ||||||
| .IP 21 | .IP 21 | ||||||
| FTP quote error. A quote command returned error from the server. | FTP quote error. A quote command returned error from the server. | ||||||
| .IP 22 | .IP 22 | ||||||
| HTTP not found. The requested page was not found. This return code only | HTTP page not retrieved. The requested url was not found or returned another | ||||||
|  | error with the HTTP error code being 400 or above. This return code only | ||||||
| appears if --fail is used. | appears if --fail is used. | ||||||
| .IP 23 | .IP 23 | ||||||
| Write error. Curl couldn't write data to a local filesystem or similar. | Write error. Curl couldn't write data to a local filesystem or similar. | ||||||
| @@ -788,7 +912,7 @@ Internal error. A function was called in a bad order. | |||||||
| .IP 45 | .IP 45 | ||||||
| Interface error. A specified outgoing interface could not be used. | Interface error. A specified outgoing interface could not be used. | ||||||
| .IP 46 | .IP 46 | ||||||
| Bad password entered. An error was signalled when the password was entered. | Bad password entered. An error was signaled when the password was entered. | ||||||
| .IP 47 | .IP 47 | ||||||
| Too many redirects. When following redirects, curl hit the maximum amount. | Too many redirects. When following redirects, curl hit the maximum amount. | ||||||
| .IP 48 | .IP 48 | ||||||
| @@ -799,6 +923,24 @@ Malformed telnet option. | |||||||
| The remote peer's SSL certificate wasn't ok | The remote peer's SSL certificate wasn't ok | ||||||
| .IP 52 | .IP 52 | ||||||
| The server didn't reply anything, which here is considered an error. | The server didn't reply anything, which here is considered an error. | ||||||
|  | .IP 53 | ||||||
|  | SSL crypto engine not found | ||||||
|  | .IP 54 | ||||||
|  | Cannot set SSL crypto engine as default | ||||||
|  | .IP 55 | ||||||
|  | Failed sending network data | ||||||
|  | .IP 56 | ||||||
|  | Failure in receiving network data | ||||||
|  | .IP 57 | ||||||
|  | Share is in use (internal error) | ||||||
|  | .IP 58 | ||||||
|  | Problem with the local certificate | ||||||
|  | .IP 59 | ||||||
|  | Couldn't use specified SSL cipher | ||||||
|  | .IP 60 | ||||||
|  | Problem with the CA cert (path? permission?) | ||||||
|  | .IP 61 | ||||||
|  | Unrecognized transfer encoding | ||||||
| .IP XX | .IP XX | ||||||
| There will appear more error codes here in future releases. The existing ones | There will appear more error codes here in future releases. The existing ones | ||||||
| are meant to never change. | are meant to never change. | ||||||
|   | |||||||
| @@ -1,29 +0,0 @@ | |||||||
| .\" You can view this file with: |  | ||||||
| .\" nroff -man [file] |  | ||||||
| .\" $Id$ |  | ||||||
| .\" |  | ||||||
| .TH curl_easy_cleanup 3 "5 March 2001" "libcurl 7.7" "libcurl Manual" |  | ||||||
| .SH NAME |  | ||||||
| curl_easy_cleanup - End a libcurl session |  | ||||||
| .SH SYNOPSIS |  | ||||||
| .B #include <curl/curl.h> |  | ||||||
| .sp |  | ||||||
| .BI "void curl_easy_cleanup(CURL *" handle ");" |  | ||||||
| .ad |  | ||||||
| .SH DESCRIPTION |  | ||||||
| This function must be the last function to call for a curl session. It is the |  | ||||||
| opposite of the |  | ||||||
| .I curl_easy_init |  | ||||||
| function and must be called with the same |  | ||||||
| .I handle |  | ||||||
| as input as the curl_easy_init call returned. |  | ||||||
|  |  | ||||||
| This will effectively close all connections libcurl has been used and possibly |  | ||||||
| has kept open until now. Don't call this function if you intend to transfer |  | ||||||
| more files (libcurl 7.7 or later). |  | ||||||
| .SH RETURN VALUE |  | ||||||
| None |  | ||||||
| .SH "SEE ALSO" |  | ||||||
| .BR curl_easy_init "(3), " |  | ||||||
| .SH BUGS |  | ||||||
| Surely there are some, you tell me! |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| .\" You can view this file with: |  | ||||||
| .\" nroff -man [file] |  | ||||||
| .\" $Id$ |  | ||||||
| .\" |  | ||||||
| .TH curl_easy_init 3 "14 August 2001" "libcurl 7.8.1" "libcurl Manual" |  | ||||||
| .SH NAME |  | ||||||
| curl_easy_init - Start a libcurl session |  | ||||||
| .SH SYNOPSIS |  | ||||||
| .B #include <curl/curl.h> |  | ||||||
| .sp |  | ||||||
| .BI "CURL *curl_easy_init( );" |  | ||||||
| .ad |  | ||||||
| .SH DESCRIPTION |  | ||||||
| This function must be the first function to call, and it returns a CURL handle |  | ||||||
| that you shall use as input to the other easy-functions. The init calls |  | ||||||
| intializes curl and this call MUST have a corresponding call to |  | ||||||
| .I curl_easy_cleanup |  | ||||||
| when the operation is complete. |  | ||||||
|  |  | ||||||
| On win32 systems, if you want to init the winsock stuff manually, libcurl will |  | ||||||
| not do that for you. WSAStartup() and WSACleanup() should then be called |  | ||||||
| accordingly.  If you want libcurl to handle this, use the CURL_GLOBAL_WIN32 |  | ||||||
| flag in the initial curl_global_init() call. |  | ||||||
|  |  | ||||||
| Using libcurl 7.7 and later, you should perform all your sequential file |  | ||||||
| transfers using the same curl handle. This enables libcurl to use persistant |  | ||||||
| connections where possible. |  | ||||||
| .SH RETURN VALUE |  | ||||||
| If this function returns NULL, something went wrong and you cannot use the |  | ||||||
| other curl functions. |  | ||||||
| .SH "SEE ALSO" |  | ||||||
| .BR curl_easy_cleanup "(3), " curl_global_init "(3) |  | ||||||
| .SH BUGS |  | ||||||
| Surely there are some, you tell me! |  | ||||||
| @@ -1,165 +0,0 @@ | |||||||
| .\" You can view this file with: |  | ||||||
| .\" nroff -man [file] |  | ||||||
| .\" $Id$ |  | ||||||
| .\" |  | ||||||
| .TH curl_formadd 3 "29 October 2001" "libcurl 7.9.1" "libcurl Manual" |  | ||||||
| .SH NAME |  | ||||||
| curl_formadd - add a section to a multipart/formdata HTTP POST |  | ||||||
| .SH SYNOPSIS |  | ||||||
| .B #include <curl/curl.h> |  | ||||||
| .sp |  | ||||||
| .BI "int curl_formadd(struct HttpPost ** " firstitem, |  | ||||||
| .BI "struct HttpPost ** " lastitem, " ...);" |  | ||||||
| .ad |  | ||||||
| .SH DESCRIPTION |  | ||||||
| curl_formadd() is used to append sections when building a multipart/formdata |  | ||||||
| HTTP POST (sometimes refered to as rfc1867-style posts). Append one section at |  | ||||||
| a time until you've added all the sections you want included and then you pass |  | ||||||
| the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. |  | ||||||
| \fIlastitem\fP is set after each call and on repeated invokes it should be |  | ||||||
| left as set to allow repeated invokes to find the end of the list faster. |  | ||||||
|  |  | ||||||
| After the \fIlastitem\fP pointer follow the real arguments. (If the following |  | ||||||
| description confuses you, jump directly to the examples): |  | ||||||
|  |  | ||||||
| \fBCURLFORM_COPYNAME\fP or \fBCURLFORM_PTRNAME\fP followed by a string is used |  | ||||||
| for the name of the section. Optionally one may use \fBCURLFORM_NAMELENGTH\fP |  | ||||||
| to specify the length of the name (allowing null characters within the |  | ||||||
| name). All options that use the word COPY in their names copy the given |  | ||||||
| contents, while the ones with PTR in their names simply points to the (static) |  | ||||||
| data you must make sure remain until curl no longer needs it. |  | ||||||
|  |  | ||||||
| The four options for providing values are: \fBCURLFORM_COPYCONTENTS\fP, |  | ||||||
| \fBCURLFORM_PTRCONTENTS\fP, \fBCURLFORM_FILE\fP, or \fBCURLFORM_FILECONTENT\fP |  | ||||||
| followed by a char or void pointer (allowed for PTRCONTENTS). |  | ||||||
|  |  | ||||||
| \fBCURLFORM_FILECONTENT\fP does a normal post like \fBCURLFORM_COPYCONTENTS\fP |  | ||||||
| but the actual value is read from the filename given as a string. |  | ||||||
|  |  | ||||||
| Other arguments may be \fBCURLFORM_CONTENTTYPE\fP if the user wishes to |  | ||||||
| specify one (for FILE if no type is given the library tries to provide the |  | ||||||
| correct one; for CONTENTS no Content-Type is sent in this case). |  | ||||||
|  |  | ||||||
| For \fBCURLFORM_PTRCONTENTS\fP or \fBCURLFORM_COPYNAME\fP the user may also |  | ||||||
| add \fBCURLFORM_CONTENTSLENGTH\fP followed by the length as a long (if not |  | ||||||
| given the library will use strlen to determine the length). |  | ||||||
|  |  | ||||||
| For \fBCURLFORM_FILE\fP the user may send multiple files in one section by |  | ||||||
| providing multiple \fBCURLFORM_FILE\fP arguments each followed by the filename |  | ||||||
| (and each FILE is allowed to have a CONTENTTYPE). |  | ||||||
|  |  | ||||||
| Another possibility to send single or multiple files in one section is to use |  | ||||||
| \fBCURLFORM_ARRAY\fP that gets a struct curl_forms array pointer as its |  | ||||||
| value. Each structure element has a CURLformoption and a char pointer. For the |  | ||||||
| options only \fBCURLFORM_FILE\fP, \fBCURLFORM_CONTENTTYPE\fP, and |  | ||||||
| \fBCURLFORM_END\fP (that is used to determine the end of the array and thus |  | ||||||
| must be the option of the last and no other element of the curl_forms array) |  | ||||||
| are allowed. The effect of this parameter is the same as giving multiple |  | ||||||
| \fBCURLFORM_FILE\fP options possibly with \fBCURLFORM_CONTENTTYPE\fP after or |  | ||||||
| before each \fBCURLFORM_FILE\fP option. |  | ||||||
|  |  | ||||||
| Should you need to specify extra headers for the form POST section, use |  | ||||||
| \fBCURLFORM_CONTENTHEADER\fP. This takes a curl_slist prepared in the usual way |  | ||||||
| using \fBcurl_slist_append\fP and appends the list of headers to those Curl |  | ||||||
| automatically generates for \fBCURLFORM_CONTENTTYPE\fP and the content  |  | ||||||
| disposition. The list must exist while the POST occurs, if you free it before |  | ||||||
| the post completes you may experience problems. |  | ||||||
|  |  | ||||||
| The last argument in such an array must always be \fBCURLFORM_END\fP. |  | ||||||
|  |  | ||||||
| The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to |  | ||||||
| NULL in the first call to this function. All list-data will be allocated by |  | ||||||
| the function itself. You must call \fIcurl_formfree\fP after the form post has |  | ||||||
| been done to free the resources again. |  | ||||||
|  |  | ||||||
| This function will copy all input data except the data pointed to by the |  | ||||||
| arguments after \fBCURLFORM_PTRNAME\fP and \fBCURLFORM_PTRCONTENTS\fP and keep |  | ||||||
| its own version of it allocated until you call \fIcurl_formfree\fP. When |  | ||||||
| you've passed the pointer to \fIcurl_easy_setopt\fP, you must not free the |  | ||||||
| list until after you've called \fIcurl_easy_cleanup\fP for the curl handle. If |  | ||||||
| you provide a pointer as an arguments after \fBCURLFORM_PTRNAME\fP or |  | ||||||
| \fBCURLFORM_PTRCONTENTS\fP you must ensure that the pointer stays valid until |  | ||||||
| you call \fIcurl_form_free\fP and \fIcurl_easy_cleanup\fP. |  | ||||||
|  |  | ||||||
| See example below. |  | ||||||
| .SH RETURN VALUE |  | ||||||
| Returns non-zero if an error occurs. |  | ||||||
| .SH EXAMPLE |  | ||||||
| .nf |  | ||||||
|  |  | ||||||
|  HttpPost* post = NULL; |  | ||||||
|  HttpPost* last = NULL; |  | ||||||
|  char namebuffer[] = "name buffer"; |  | ||||||
|  long namelength = strlen(namebuffer); |  | ||||||
|  char buffer[] = "test buffer"; |  | ||||||
|  char htmlbuffer[] = "<HTML>test buffer</HTML>"; |  | ||||||
|  long htmlbufferlength = strlen(htmlbuffer); |  | ||||||
|  struct curl_forms forms[3]; |  | ||||||
|  char file1[] = "my-face.jpg"; |  | ||||||
|  char file2[] = "your-face.jpg"; |  | ||||||
|  /* add null character into htmlbuffer, to demonstrate that |  | ||||||
|     transfers of buffers containing null characters actually work |  | ||||||
|  */ |  | ||||||
|  htmlbuffer[8] = '\\0'; |  | ||||||
|  |  | ||||||
|  /* Add simple name/content section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "name", |  | ||||||
|               CURLFORM_COPYCONTENTS, "content", CURLFORM_END);  |  | ||||||
|  |  | ||||||
|  /* Add simple name/content/contenttype section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "htmlcode", |  | ||||||
|               CURLFORM_COPYCONTENTS, "<HTML></HTML>", |  | ||||||
|               CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add name/ptrcontent section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "name_for_ptrcontent", |  | ||||||
|               CURLFORM_PTRCONTENTS, buffer, CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add ptrname/ptrcontent section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_PTRNAME, namebuffer, |  | ||||||
| 	      CURLFORM_PTRCONTENTS, buffer, CURLFORM_NAMELENGTH, |  | ||||||
| 	      namelength, CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add name/ptrcontent/contenttype section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "html_code_with_hole", |  | ||||||
|               CURLFORM_PTRCONTENTS, htmlbuffer, |  | ||||||
|               CURLFORM_CONTENTSLENGTH, htmlbufferlength, |  | ||||||
|               CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add simple file section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture", |  | ||||||
|               CURLFORM_FILE, "my-face.jpg", CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add file/contenttype section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture", |  | ||||||
|               CURLFORM_FILE, "my-face.jpg", |  | ||||||
|               CURLFORM_CONTENTTYPE, "image/jpeg", CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add two file section */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures", |  | ||||||
|               CURLFORM_FILE, "my-face.jpg", |  | ||||||
|               CURLFORM_FILE, "your-face.jpg", CURLFORM_END); |  | ||||||
|  |  | ||||||
|  /* Add two file section using CURLFORM_ARRAY */ |  | ||||||
|  forms[0].option = CURLFORM_FILE; |  | ||||||
|  forms[0].value  = file1; |  | ||||||
|  forms[1].option = CURLFORM_FILE; |  | ||||||
|  forms[1].value  = file2; |  | ||||||
|  forms[2].option  = CURLFORM_END; |  | ||||||
|  |  | ||||||
|  /* no option needed for the end marker */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures", |  | ||||||
|               CURLFORM_ARRAY, forms, CURLFORM_END); |  | ||||||
|  /* Add the content of a file as a normal post text value */ |  | ||||||
|  curl_formadd(&post, &last, CURLFORM_COPYNAME, "filecontent", |  | ||||||
|               CURLFORM_FILECONTENT, ".bashrc", CURLFORM_END); |  | ||||||
|  /* Set the form info */ |  | ||||||
|  curl_easy_setopt(curl, CURLOPT_HTTPPOST, post); |  | ||||||
|  |  | ||||||
| .SH "SEE ALSO" |  | ||||||
| .BR curl_easy_setopt "(3), " |  | ||||||
| .BR curl_formparse "(3) [deprecated], " |  | ||||||
| .BR curl_formfree "(3)" |  | ||||||
| .SH BUGS |  | ||||||
| Surely there are some, you tell me! |  | ||||||
|  |  | ||||||
| @@ -1,29 +0,0 @@ | |||||||
| .\" You can view this file with: |  | ||||||
| .\" nroff -man [file] |  | ||||||
| .\" $Id$ |  | ||||||
| .\" |  | ||||||
| .TH curl_slist_append 3 "5 March 2001" "libcurl 7.0" "libcurl Manual" |  | ||||||
| .SH NAME |  | ||||||
| curl_slist_append - add a string to an slist |  | ||||||
| .SH SYNOPSIS |  | ||||||
| .B #include <curl/curl.h> |  | ||||||
| .sp |  | ||||||
| .BI "struct curl_slist *curl_slist_append(struct curl_slist *" list, |  | ||||||
| .BI "const char * "string ");" |  | ||||||
| .ad |  | ||||||
| .SH DESCRIPTION |  | ||||||
| curl_slist_append() appends a specified string to a linked list of |  | ||||||
| strings. The existing |  | ||||||
| .I list |  | ||||||
| should be passed as the first argument while the new list is returned from |  | ||||||
| this function. The specified |  | ||||||
| .I string |  | ||||||
| has been appended when this function returns. |  | ||||||
| .SH RETURN VALUE |  | ||||||
| A null pointer is returned if anything went wrong, otherwise the new list |  | ||||||
| pointer is returned. |  | ||||||
| .SH "SEE ALSO" |  | ||||||
| .BR curl_slist_free_all "(3), " |  | ||||||
| .SH BUGS |  | ||||||
| Surely there are some, you tell me! |  | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								docs/examples/.cvsignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								docs/examples/.cvsignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | Makefile | ||||||
|  | Makefile.in | ||||||
| @@ -4,10 +4,12 @@ | |||||||
|  |  | ||||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | AUTOMAKE_OPTIONS = foreign no-dependencies | ||||||
|  |  | ||||||
| EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit.c postit2.c \ | EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c		\ | ||||||
| 	     win32sockets.c persistant.c ftpget.c Makefile.example \ | 	     persistant.c ftpget.c Makefile.example			\ | ||||||
| 	     multithread.c getinmemory.c ftpupload.c httpput.c \ | 	     multithread.c getinmemory.c ftpupload.c httpput.c		\ | ||||||
| 	     simplessl.c ftpgetresp.c http-post.c | 	     simplessl.c ftpgetresp.c http-post.c post-callback.c	\ | ||||||
|  | 	     multi-app.c multi-double.c multi-single.c multi-post.c	\ | ||||||
|  | 	     fopen.c simplepost.c | ||||||
|  |  | ||||||
| all: | all: | ||||||
| 	@echo "done" | 	@echo "done" | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ LIBS = -lcurl -lsocket -lnsl -lssl -lcrypto -dl | |||||||
|  |  | ||||||
| # Link the target with all objects and libraries | # Link the target with all objects and libraries | ||||||
| $(TARGET) : $(OBJS) | $(TARGET) : $(OBJS) | ||||||
| 	$(CC) $(LDFLAGS) $(LIBS) -o $(TARGET) $(OBJS) | 	$(CC)  -o $(TARGET) $(OBJS) $(LDFLAGS) $(LIBS) | ||||||
|  |  | ||||||
| # Compile the source files into object files | # Compile the source files into object files | ||||||
| ftpget.o : ftpget.c | ftpget.o : ftpget.c | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| EXAMPLES | EXAMPLES | ||||||
|  |  | ||||||
| This directory is for tiny libcurl programming examples. They are meant to | This directory is for libcurl programming examples. They are meant to show | ||||||
| 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 | ||||||
| advantage of libcurl. | 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 | ||||||
| @@ -12,11 +12,14 @@ examples. Just edit the file according to your system and requirements first. | |||||||
|  |  | ||||||
| Most examples should build fine using a command line like this: | Most examples should build fine using a command line like this: | ||||||
|  |  | ||||||
|   $ gcc `curl-config --cflags` `curl-config --libs` -o example example.c |   $ `curl-config --cc --cflags --libs` -o example example.c | ||||||
|  |  | ||||||
| Try the php/examples/ directory for PHP programming snippets! | Some compilers don't like having the arguments in this order but instead | ||||||
|  | want you do reorganize them like: | ||||||
|  |  | ||||||
|   *PLEASE* do not use the curl.haxx.se site as a test target for your libcurl |   $ `curl-config --cc` -o example example.c `curl-config --cflags --libs` | ||||||
|   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 | *PLEASE* do not use the curl.haxx.se site as a test target for your libcurl | ||||||
|   that we expect you to actually torture our web site with your tests! Thanks. | 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 | ||||||
|  | we expect you to actually torture our web site with your tests! Thanks. | ||||||
|   | |||||||
| @@ -26,7 +26,11 @@ size_t my_read_func(void *ptr, size_t size, size_t nmemb, FILE *stream) | |||||||
|   return fread(ptr, size, nmemb, stream); |   return fread(ptr, size, nmemb, stream); | ||||||
| } | } | ||||||
|  |  | ||||||
| int my_progress_func(GtkWidget *Bar, int t, int d) | int my_progress_func(GtkWidget *Bar, | ||||||
|  |                      double t, /* dltotal */ | ||||||
|  |                      double d, /* dlnow */ | ||||||
|  |                      double ultotal, | ||||||
|  |                      double ulnow) | ||||||
| { | { | ||||||
| /*  printf("%d / %d (%g %%)\n", d, t, d*100.0/t);*/ | /*  printf("%d / %d (%g %%)\n", d, t, d*100.0/t);*/ | ||||||
|   gdk_threads_enter(); |   gdk_threads_enter(); | ||||||
| @@ -50,6 +54,7 @@ void *curl_thread(void *ptr) | |||||||
|     curl_easy_setopt(curl, CURLOPT_URL, url); |     curl_easy_setopt(curl, CURLOPT_URL, url); | ||||||
|     curl_easy_setopt(curl, CURLOPT_FILE, outfile); |     curl_easy_setopt(curl, CURLOPT_FILE, outfile); | ||||||
|     curl_easy_setopt(curl, CURLOPT_READFUNCTION, my_read_func); |     curl_easy_setopt(curl, CURLOPT_READFUNCTION, my_read_func); | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_NOPROGRESS, FALSE); | ||||||
|     curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, my_progress_func); |     curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, my_progress_func); | ||||||
|     curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, Bar); |     curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, Bar); | ||||||
|      |      | ||||||
|   | |||||||
							
								
								
									
										235
									
								
								docs/examples/fopen.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										235
									
								
								docs/examples/fopen.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,235 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * This example source code introduces an fopen()/fread()/fclose() emulation | ||||||
|  |  * for URL reads. Using an approach similar to this, you could replace your | ||||||
|  |  * program's fopen() with this url_fopen() and fread() with url_fread() and | ||||||
|  |  * it should be possible to read remote streams instead of (only) local files. | ||||||
|  |  * | ||||||
|  |  * See the main() function at the bottom that shows a tiny app in action. | ||||||
|  |  * | ||||||
|  |  * This source code is a proof of concept. It will need further attention to | ||||||
|  |  * become production-use useful and solid. | ||||||
|  |  * | ||||||
|  |  * This example requires libcurl 7.9.7 or later. | ||||||
|  |  */ | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include <sys/time.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  |  | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | #if (LIBCURL_VERSION_NUM < 0x070907) | ||||||
|  | #error "too old libcurl version, get the latest!" | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | struct data { | ||||||
|  |   int type; | ||||||
|  |   union { | ||||||
|  |     CURL *curl; | ||||||
|  |     FILE *file; | ||||||
|  |   } handle; | ||||||
|  |  | ||||||
|  |   /* This is the documented biggest possible buffer chunk we can get from | ||||||
|  |      libcurl in one single callback! */ | ||||||
|  |   char buffer[CURL_MAX_WRITE_SIZE]; | ||||||
|  |  | ||||||
|  |   char *readptr; /* read from here */ | ||||||
|  |   int bytes;     /* bytes available from read pointer */ | ||||||
|  |  | ||||||
|  |   CURLMcode m;   /* stored from a previous url_fread() */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | typedef struct data URL_FILE; | ||||||
|  |  | ||||||
|  | /* we use a global one for convenience */ | ||||||
|  | CURLM *multi_handle; | ||||||
|  |  | ||||||
|  | static | ||||||
|  | size_t write_callback(char *buffer, | ||||||
|  |                       size_t size, | ||||||
|  |                       size_t nitems, | ||||||
|  |                       void *userp) | ||||||
|  | { | ||||||
|  |   URL_FILE *url = (URL_FILE *)userp; | ||||||
|  |   size *= nitems; | ||||||
|  |  | ||||||
|  |   memcpy(url->readptr, buffer, size); | ||||||
|  |   url->readptr += size; | ||||||
|  |   url->bytes += size; | ||||||
|  |  | ||||||
|  |   fprintf(stderr, "callback %d size bytes\n", size); | ||||||
|  |  | ||||||
|  |   return size; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | URL_FILE *url_fopen(char *url, char *operation) | ||||||
|  | { | ||||||
|  |   /* this code could check for URLs or types in the 'url' and | ||||||
|  |      basicly use the real fopen() for standard files */ | ||||||
|  |  | ||||||
|  |   URL_FILE *file; | ||||||
|  |   int still_running; | ||||||
|  |   (void)operation; | ||||||
|  |  | ||||||
|  |   file = (URL_FILE *)malloc(sizeof(URL_FILE)); | ||||||
|  |   if(!file) | ||||||
|  |     return NULL; | ||||||
|  |  | ||||||
|  |   memset(file, 0, sizeof(URL_FILE)); | ||||||
|  |  | ||||||
|  |   file->type = 1; /* marked as URL, use 0 for plain file */ | ||||||
|  |   file->handle.curl = curl_easy_init(); | ||||||
|  |  | ||||||
|  |   curl_easy_setopt(file->handle.curl, CURLOPT_URL, url); | ||||||
|  |   curl_easy_setopt(file->handle.curl, CURLOPT_FILE, file); | ||||||
|  |   curl_easy_setopt(file->handle.curl, CURLOPT_VERBOSE, FALSE); | ||||||
|  |   curl_easy_setopt(file->handle.curl, CURLOPT_WRITEFUNCTION, write_callback); | ||||||
|  |  | ||||||
|  |   if(!multi_handle) | ||||||
|  |     multi_handle = curl_multi_init(); | ||||||
|  |  | ||||||
|  |   curl_multi_add_handle(multi_handle, file->handle.curl); | ||||||
|  |  | ||||||
|  |   while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |         curl_multi_perform(multi_handle, &still_running)); | ||||||
|  |  | ||||||
|  |   /* if still_running would be 0 now, we should return NULL */ | ||||||
|  |  | ||||||
|  |   return file; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void url_fclose(URL_FILE *file) | ||||||
|  | { | ||||||
|  |   /* make sure the easy handle is not in the multi handle anymore */ | ||||||
|  |   curl_multi_remove_handle(multi_handle, file->handle.curl); | ||||||
|  |  | ||||||
|  |   /* cleanup */ | ||||||
|  |   curl_easy_cleanup(file->handle.curl); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | size_t url_fread(void *ptr, size_t size, size_t nmemb, URL_FILE *file) | ||||||
|  | { | ||||||
|  |   fd_set fdread; | ||||||
|  |   fd_set fdwrite; | ||||||
|  |   fd_set fdexcep; | ||||||
|  |   int maxfd; | ||||||
|  |   struct timeval timeout; | ||||||
|  |   int rc; | ||||||
|  |   int still_running = 0; | ||||||
|  |  | ||||||
|  |   if(!file->bytes) { /* no data available at this point */ | ||||||
|  |  | ||||||
|  |     file->readptr = file->buffer; /* reset read pointer */ | ||||||
|  |  | ||||||
|  |     if(CURLM_CALL_MULTI_PERFORM == file->m) { | ||||||
|  |       while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |             curl_multi_perform(multi_handle, &still_running)) { | ||||||
|  |         if(file->bytes) { | ||||||
|  |           printf("(fread) WOAH! THis happened!\n"); | ||||||
|  |           break;         | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       if(!still_running) { | ||||||
|  |         printf("DONE RUNNING AROUND!\n"); | ||||||
|  |         return 0; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     do { | ||||||
|  |  | ||||||
|  |       FD_ZERO(&fdread); | ||||||
|  |       FD_ZERO(&fdwrite); | ||||||
|  |       FD_ZERO(&fdexcep); | ||||||
|  |    | ||||||
|  |       /* set a suitable timeout to fail on */ | ||||||
|  |       timeout.tv_sec = 500; /* 5 minutes */ | ||||||
|  |       timeout.tv_usec = 0; | ||||||
|  |  | ||||||
|  |       /* get file descriptors from the transfers */ | ||||||
|  |       curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |       rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|  |       switch(rc) { | ||||||
|  |       case -1: | ||||||
|  |         /* select error */ | ||||||
|  |         break; | ||||||
|  |       case 0: | ||||||
|  |         break; | ||||||
|  |       default: | ||||||
|  |         /* timeout or readable/writable sockets */ | ||||||
|  |         printf("select() returned %d!\n", rc); | ||||||
|  |         do { | ||||||
|  |           file->m = curl_multi_perform(multi_handle, &still_running); | ||||||
|  |            | ||||||
|  |           if(file->bytes) | ||||||
|  |             /* we have received data, return that now */ | ||||||
|  |             break; | ||||||
|  |            | ||||||
|  |         } while(CURLM_CALL_MULTI_PERFORM == file->m); | ||||||
|  |  | ||||||
|  |          | ||||||
|  |         if(!still_running) | ||||||
|  |           printf("DONE RUNNING AROUND!\n"); | ||||||
|  |          | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |     } while(still_running && (file->bytes <= 0)); | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |     printf("(fread) Skip network read\n"); | ||||||
|  |  | ||||||
|  |   if(file->bytes) { | ||||||
|  |     /* data already available, return that */ | ||||||
|  |     int want = size * nmemb; | ||||||
|  |  | ||||||
|  |     if(file->bytes < want) | ||||||
|  |       want = file->bytes; | ||||||
|  |  | ||||||
|  |     memcpy(ptr, file->readptr, want); | ||||||
|  |     file->readptr += want; | ||||||
|  |     file->bytes -= want; | ||||||
|  |  | ||||||
|  |     printf("(fread) return %d bytes\n", want); | ||||||
|  |  | ||||||
|  |     return want; | ||||||
|  |   } | ||||||
|  |   return 0; /* no data available to return */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int main(int argc, char *argv[]) | ||||||
|  | { | ||||||
|  |   URL_FILE *handle; | ||||||
|  |   int nread; | ||||||
|  |   char buffer[256]; | ||||||
|  |  | ||||||
|  |   (void)argc; | ||||||
|  |   (void)argv; | ||||||
|  |  | ||||||
|  |   handle = url_fopen("http://curl.haxx.se/", "r"); | ||||||
|  |  | ||||||
|  |   if(!handle) { | ||||||
|  |     printf("couldn't url_fopen()\n"); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   do { | ||||||
|  |     nread = url_fread(buffer, sizeof(buffer), 1, handle); | ||||||
|  |  | ||||||
|  |     printf("We got: %d bytes\n", nread); | ||||||
|  |   } while(nread); | ||||||
|  |  | ||||||
|  |   url_fclose(handle); | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -11,6 +11,9 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  | #include <fcntl.h> | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * This example shows an FTP upload, with a rename of the file just after |  * This example shows an FTP upload, with a rename of the file just after | ||||||
|   | |||||||
| @@ -74,6 +74,10 @@ int main(int argc, char **argv) | |||||||
|    * bytes big and contains the remote file. |    * bytes big and contains the remote file. | ||||||
|    * |    * | ||||||
|    * Do something nice with it! |    * Do something nice with it! | ||||||
|  |    * | ||||||
|  |    * You should be aware of the fact that at this point we might have an | ||||||
|  |    * allocated data block, and nothing has yet deallocated that data. So when | ||||||
|  |    * you're done with it, you should free() it as a nice application. | ||||||
|    */ |    */ | ||||||
|  |  | ||||||
|   return 0; |   return 0; | ||||||
|   | |||||||
| @@ -1,4 +1,12 @@ | |||||||
| /*
 | /*****************************************************************************
 | ||||||
|  |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  * This is an example application source code using the multi interface. |  * This is an example application source code using the multi interface. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| @@ -9,10 +17,8 @@ | |||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| 
 | 
 | ||||||
| 
 | /* curl stuff */ | ||||||
| /* To start with, we include the header from the lib directory. This should
 | #include <curl/curl.h> | ||||||
|    later of course be moved to the proper include dir. */ |  | ||||||
| #include "../lib/multi.h" |  | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Download a HTTP file and upload an FTP file simultaneously. |  * Download a HTTP file and upload an FTP file simultaneously. | ||||||
| @@ -77,7 +83,8 @@ int main(int argc, char **argv) | |||||||
|     default: |     default: | ||||||
|       /* one or more of curl's file descriptors say there's data to read
 |       /* one or more of curl's file descriptors say there's data to read
 | ||||||
|          or write */ |          or write */ | ||||||
|       curl_multi_perform(multi_handle, &still_running); |       while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |             curl_multi_perform(multi_handle, &still_running)); | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -1,5 +1,13 @@ | |||||||
| /*
 | /*****************************************************************************
 | ||||||
|  * This is a simple example using the multi interface. |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * This is a very simple example using the multi interface. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| @@ -9,9 +17,8 @@ | |||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| 
 | 
 | ||||||
| /* To start with, we include the header from the lib directory. This should
 | /* curl stuff */ | ||||||
|    later of course be moved to the proper include dir. */ | #include <curl/curl.h> | ||||||
| #include "../lib/multi.h" |  | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Simply download two HTTP files! |  * Simply download two HTTP files! | ||||||
| @@ -73,7 +80,8 @@ int main(int argc, char **argv) | |||||||
|     case 0: |     case 0: | ||||||
|     default: |     default: | ||||||
|       /* timeout or readable/writable sockets */ |       /* timeout or readable/writable sockets */ | ||||||
|       curl_multi_perform(multi_handle, &still_running); |       while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |             curl_multi_perform(multi_handle, &still_running)); | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
							
								
								
									
										126
									
								
								docs/examples/multi-post.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								docs/examples/multi-post.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * This is an example application source code using the multi interface | ||||||
|  |  * to do a multipart formpost without "blocking". | ||||||
|  |  */ | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include <sys/time.h> | ||||||
|  |  | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | int main(int argc, char *argv[]) | ||||||
|  | { | ||||||
|  |   CURL *curl; | ||||||
|  |   CURLcode res; | ||||||
|  |  | ||||||
|  |   CURLM *multi_handle; | ||||||
|  |   int still_running; | ||||||
|  |  | ||||||
|  |   struct HttpPost *formpost=NULL; | ||||||
|  |   struct HttpPost *lastptr=NULL; | ||||||
|  |   struct curl_slist *headerlist=NULL; | ||||||
|  |   char buf[] = "Expect:"; | ||||||
|  |  | ||||||
|  |   /* Fill in the file upload field */ | ||||||
|  |   curl_formadd(&formpost, | ||||||
|  |                &lastptr, | ||||||
|  |                CURLFORM_COPYNAME, "sendfile", | ||||||
|  |                CURLFORM_FILE, "postit2.c", | ||||||
|  |                CURLFORM_END); | ||||||
|  |  | ||||||
|  |   /* Fill in the filename field */ | ||||||
|  |   curl_formadd(&formpost, | ||||||
|  |                &lastptr, | ||||||
|  |                CURLFORM_COPYNAME, "filename", | ||||||
|  |                CURLFORM_COPYCONTENTS, "postit2.c", | ||||||
|  |                CURLFORM_END); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   /* Fill in the submit field too, even if this is rarely needed */ | ||||||
|  |   curl_formadd(&formpost, | ||||||
|  |                &lastptr, | ||||||
|  |                CURLFORM_COPYNAME, "submit", | ||||||
|  |                CURLFORM_COPYCONTENTS, "send", | ||||||
|  |                CURLFORM_END); | ||||||
|  |  | ||||||
|  |   curl = curl_easy_init(); | ||||||
|  |   multi_handle = curl_multi_init(); | ||||||
|  |  | ||||||
|  |   /* initalize custom header list (stating that Expect: 100-continue is not | ||||||
|  |      wanted */ | ||||||
|  |   headerlist = curl_slist_append(headerlist, buf); | ||||||
|  |   if(curl && multi_handle) { | ||||||
|  |     int perform=0; | ||||||
|  |  | ||||||
|  |     /* what URL that receives this POST */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_URL, | ||||||
|  |                      "http://www.fillinyoururl.com/upload.cgi"); | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||||
|  |  | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist); | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost); | ||||||
|  |  | ||||||
|  |     curl_multi_add_handle(multi_handle, curl); | ||||||
|  |  | ||||||
|  |     while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |           curl_multi_perform(multi_handle, &still_running)); | ||||||
|  |  | ||||||
|  |     while(still_running) { | ||||||
|  |       struct timeval timeout; | ||||||
|  |       int rc; /* select() return code */ | ||||||
|  |  | ||||||
|  |       fd_set fdread; | ||||||
|  |       fd_set fdwrite; | ||||||
|  |       fd_set fdexcep; | ||||||
|  |       int maxfd; | ||||||
|  |  | ||||||
|  |       FD_ZERO(&fdread); | ||||||
|  |       FD_ZERO(&fdwrite); | ||||||
|  |       FD_ZERO(&fdexcep); | ||||||
|  |  | ||||||
|  |       /* set a suitable timeout to play around with */ | ||||||
|  |       timeout.tv_sec = 1; | ||||||
|  |       timeout.tv_usec = 0; | ||||||
|  |  | ||||||
|  |       /* get file descriptors from the transfers */ | ||||||
|  |       curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |  | ||||||
|  |       rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|  |       switch(rc) { | ||||||
|  |       case -1: | ||||||
|  |         /* select error */ | ||||||
|  |         break; | ||||||
|  |       case 0: | ||||||
|  |         printf("timeout!\n"); | ||||||
|  |       default: | ||||||
|  |         /* timeout or readable/writable sockets */ | ||||||
|  |         printf("perform!\n"); | ||||||
|  |         while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |               curl_multi_perform(multi_handle, &still_running)); | ||||||
|  |         printf("running: %d!\n", still_running); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     curl_multi_cleanup(multi_handle); | ||||||
|  |  | ||||||
|  |     /* always cleanup */ | ||||||
|  |     curl_easy_cleanup(curl); | ||||||
|  |  | ||||||
|  |     /* then cleanup the formpost chain */ | ||||||
|  |     curl_formfree(formpost); | ||||||
|  |  | ||||||
|  |     /* free slist */ | ||||||
|  |     curl_slist_free_all (headerlist); | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -1,4 +1,12 @@ | |||||||
| /*
 | /*****************************************************************************
 | ||||||
|  |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  * This is a very simple example using the multi interface. |  * This is a very simple example using the multi interface. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| @@ -9,9 +17,8 @@ | |||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| 
 | 
 | ||||||
| /* To start with, we include the header from the lib directory. This should
 | /* curl stuff */ | ||||||
|    later of course be moved to the proper include dir. */ | #include <curl/curl.h> | ||||||
| #include "../lib/multi.h" |  | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Simply download a HTTP file. |  * Simply download a HTTP file. | ||||||
| @@ -67,7 +74,8 @@ int main(int argc, char **argv) | |||||||
|     case 0: |     case 0: | ||||||
|     default: |     default: | ||||||
|       /* timeout or readable/writable sockets */ |       /* timeout or readable/writable sockets */ | ||||||
|       curl_multi_perform(multi_handle, &still_running); |       while(CURLM_CALL_MULTI_PERFORM == | ||||||
|  |             curl_multi_perform(multi_handle, &still_running)); | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
							
								
								
									
										89
									
								
								docs/examples/post-callback.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								docs/examples/post-callback.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  * | ||||||
|  |  * An example source code that issues a HTTP POST and we provide the actual | ||||||
|  |  * data through a read callback. | ||||||
|  |  * | ||||||
|  |  * Please be aware of the fact that the size of the posted data MUST be | ||||||
|  |  * specified before the transfer is being made (with CURLOPT_POSTFIELDSIZE). | ||||||
|  |  * This requirement will change when libcurl starts supporting chunked-encoded | ||||||
|  |  * sends. | ||||||
|  |  * | ||||||
|  |  * This example requires libcurl 7.9.6 or later. | ||||||
|  |  */ | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | #if LIBCURL_VERSION_NUM < 0x070906 | ||||||
|  | #error this example source requires libcurl 7.9.6 or newer | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | char data[]="this is what we post to the silly web server"; | ||||||
|  |  | ||||||
|  | struct WriteThis { | ||||||
|  |   char *readptr; | ||||||
|  |   int sizeleft; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp) | ||||||
|  | { | ||||||
|  |   struct WriteThis *pooh = (struct WriteThis *)userp; | ||||||
|  |  | ||||||
|  |   if(size*nmemb < 1) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   if(pooh->sizeleft) { | ||||||
|  |     *(char *)ptr = pooh->readptr[0]; /* copy one single byte */ | ||||||
|  |     pooh->readptr++;                 /* advance pointer */ | ||||||
|  |     pooh->sizeleft--;                /* less data left */ | ||||||
|  |     return 1;                        /* we return 1 byte at a time! */ | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return -1;                         /* no more data left to deliver */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int main(void) | ||||||
|  | { | ||||||
|  |   CURL *curl; | ||||||
|  |   CURLcode res; | ||||||
|  |  | ||||||
|  |   struct WriteThis pooh; | ||||||
|  |  | ||||||
|  |   pooh.readptr = data; | ||||||
|  |   pooh.sizeleft = strlen(data); | ||||||
|  |  | ||||||
|  |   curl = curl_easy_init(); | ||||||
|  |   if(curl) { | ||||||
|  |     /* First set the URL that is about to receive our POST. */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_URL, | ||||||
|  |                      "http://receivingsite.com.pooh/index.cgi"); | ||||||
|  |     /* Now specify we want to POST data */ | ||||||
|  |     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 */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); | ||||||
|  |  | ||||||
|  |     /* pointer to pass to our read function */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_INFILE, &pooh); | ||||||
|  |  | ||||||
|  |     /* get verbose debug output please */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||||
|  |  | ||||||
|  |     /* Perform the request, res will get the return code */ | ||||||
|  |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|  |     /* always cleanup */ | ||||||
|  |     curl_easy_cleanup(curl); | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -1,71 +0,0 @@ | |||||||
| /***************************************************************************** |  | ||||||
|  *                                  _   _ ____  _      |  | ||||||
|  *  Project                     ___| | | |  _ \| |     |  | ||||||
|  *                             / __| | | | |_) | |     |  | ||||||
|  *                            | (__| |_| |  _ <| |___  |  | ||||||
|  *                             \___|\___/|_| \_\_____| |  | ||||||
|  * |  | ||||||
|  * $Id$ |  | ||||||
|  * |  | ||||||
|  * Example code that uploads a file name 'foo' to a remote script that accepts |  | ||||||
|  * "HTML form based" (as described in RFC1738) uploads using HTTP POST. |  | ||||||
|  * |  | ||||||
|  * The imaginary form we'll fill in looks like: |  | ||||||
|  * |  | ||||||
|  * <form method="post" enctype="multipart/form-data" action="examplepost.cgi"> |  | ||||||
|  * Enter file: <input type="file" name="sendfile" size="40"> |  | ||||||
|  * Enter file name: <input type="text" name="filename" size="30"> |  | ||||||
|  * <input type="submit" value="send" name="submit"> |  | ||||||
|  * </form> |  | ||||||
|  * |  | ||||||
|  * This exact source code has not been verified to work. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| /* to make this work under windows, use the win32-functions from the |  | ||||||
|    win32socket.c file as well */ |  | ||||||
|  |  | ||||||
| #include <stdio.h> |  | ||||||
|  |  | ||||||
| #include <curl/curl.h> |  | ||||||
| #include <curl/types.h> |  | ||||||
| #include <curl/easy.h> |  | ||||||
|  |  | ||||||
| int main(int argc, char **argv) |  | ||||||
| { |  | ||||||
|   CURL *curl; |  | ||||||
|   CURLcode res; |  | ||||||
|  |  | ||||||
|   struct HttpPost *formpost=NULL; |  | ||||||
|   struct HttpPost *lastptr=NULL; |  | ||||||
|  |  | ||||||
|   /* Fill in the file upload field */ |  | ||||||
|   curl_formparse("sendfile=@foo", |  | ||||||
|                  &formpost, |  | ||||||
|                  &lastptr); |  | ||||||
|  |  | ||||||
|   /* Fill in the filename field */ |  | ||||||
|   curl_formparse("filename=foo", |  | ||||||
|                  &formpost, |  | ||||||
|                  &lastptr); |  | ||||||
|    |  | ||||||
|  |  | ||||||
|   /* Fill in the submit field too, even if this is rarely needed */ |  | ||||||
|   curl_formparse("submit=send", |  | ||||||
|                  &formpost, |  | ||||||
|                  &lastptr); |  | ||||||
|  |  | ||||||
|   curl = curl_easy_init(); |  | ||||||
|   if(curl) { |  | ||||||
|     /* what URL that receives this POST */ |  | ||||||
|     curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/examplepost.cgi"); |  | ||||||
|     curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost); |  | ||||||
|     res = curl_easy_perform(curl); |  | ||||||
|  |  | ||||||
|     /* always cleanup */ |  | ||||||
|     curl_easy_cleanup(curl); |  | ||||||
|  |  | ||||||
|     /* then cleanup the formpost chain */ |  | ||||||
|     curl_formfree(formpost); |  | ||||||
|   } |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
| @@ -21,7 +21,7 @@ | |||||||
|  |  | ||||||
| size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream) | size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream) | ||||||
| { | { | ||||||
|   written = fwrite(ptr, size, nmemb, (FILE *)stream); |   int written = fwrite(ptr, size, nmemb, (FILE *)stream); | ||||||
|   return written; |   return written; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -63,6 +63,10 @@ int main(int argc, char **argv) | |||||||
|   /* we want the headers to this file handle */ |   /* we want the headers to this file handle */ | ||||||
|   curl_easy_setopt(curl_handle,   CURLOPT_WRITEHEADER ,headerfile); |   curl_easy_setopt(curl_handle,   CURLOPT_WRITEHEADER ,headerfile); | ||||||
|  |  | ||||||
|  |   /* | ||||||
|  |    * Notice here that if you want the actual data sent anywhere else but | ||||||
|  |    * stdout, you should consider using the CURLOPT_WRITEDATA option.  */ | ||||||
|  |  | ||||||
|   /* get it! */ |   /* get it! */ | ||||||
|   curl_easy_perform(curl_handle); |   curl_easy_perform(curl_handle); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										36
									
								
								docs/examples/simplepost.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								docs/examples/simplepost.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | /***************************************************************************** | ||||||
|  |  *                                  _   _ ____  _      | ||||||
|  |  *  Project                     ___| | | |  _ \| |     | ||||||
|  |  *                             / __| | | | |_) | |     | ||||||
|  |  *                            | (__| |_| |  _ <| |___  | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * $Id$ | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | int main(void) | ||||||
|  | { | ||||||
|  |   CURL *curl; | ||||||
|  |   CURLcode res; | ||||||
|  |  | ||||||
|  |   char *postthis="moo mooo moo moo"; | ||||||
|  |  | ||||||
|  |   curl = curl_easy_init(); | ||||||
|  |   if(curl) { | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_URL, "http://posthere.com"); | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postthis); | ||||||
|  |  | ||||||
|  |     /* if we don't provide POSTFIELDSIZE, libcurl will strlen() by | ||||||
|  |        itself */ | ||||||
|  |     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, strlen(postthis)); | ||||||
|  |  | ||||||
|  |     res = curl_easy_perform(curl); | ||||||
|  |  | ||||||
|  |     /* always cleanup */ | ||||||
|  |     curl_easy_cleanup(curl); | ||||||
|  |   } | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -66,7 +66,7 @@ int main(int argc, char **argv) | |||||||
|   curl = curl_easy_init(); |   curl = curl_easy_init(); | ||||||
|   if(curl) { |   if(curl) { | ||||||
|     /* what call to write: */ |     /* what call to write: */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://curl.haxx.se"); |     curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://your.favourite.ssl.site"); | ||||||
|     curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile); |     curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile); | ||||||
|  |  | ||||||
|     while(1)                    /* do some ugly short cut... */ |     while(1)                    /* do some ugly short cut... */ | ||||||
|   | |||||||
| @@ -1,49 +0,0 @@ | |||||||
|  |  | ||||||
| /* |  | ||||||
|  * Note: This is only required if you use curl 7.8 or lower, later  |  | ||||||
|  * versions provide an option to curl_global_init() that does the |  | ||||||
|  * win32 initialization for you. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * These are example functions doing socket init that Windows |  | ||||||
|  * require. If you don't use windows, you can safely ignore this crap. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <windows.h> |  | ||||||
|  |  | ||||||
| void win32_cleanup(void) |  | ||||||
| { |  | ||||||
|   WSACleanup(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int win32_init(void) |  | ||||||
| { |  | ||||||
|   WORD wVersionRequested;   |  | ||||||
|   WSADATA wsaData;  |  | ||||||
|   int err;  |  | ||||||
|   wVersionRequested = MAKEWORD(1, 1);  |  | ||||||
|      |  | ||||||
|   err = WSAStartup(wVersionRequested, &wsaData);  |  | ||||||
|      |  | ||||||
|   if (err != 0)  |  | ||||||
|     /* Tell the user that we couldn't find a useable */  |  | ||||||
|     /* winsock.dll.     */  |  | ||||||
|     return 1; |  | ||||||
|      |  | ||||||
|   /* Confirm that the Windows Sockets DLL supports 1.1.*/  |  | ||||||
|   /* Note that if the DLL supports versions greater */  |  | ||||||
|   /* than 1.1 in addition to 1.1, it will still return */  |  | ||||||
|   /* 1.1 in wVersion since that is the version we */  |  | ||||||
|   /* requested. */  |  | ||||||
|      |  | ||||||
|   if ( LOBYTE( wsaData.wVersion ) != 1 ||  |  | ||||||
|        HIBYTE( wsaData.wVersion ) != 1 ) {  |  | ||||||
|     /* Tell the user that we couldn't find a useable */  |  | ||||||
|  |  | ||||||
|     /* winsock.dll. */  |  | ||||||
|     WSACleanup();  |  | ||||||
|     return 1;  |  | ||||||
|   } |  | ||||||
|   return 0; /* 0 is ok */ |  | ||||||
| } |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| HTML> | <HTML> | ||||||
| <HEAD> | <HEAD> | ||||||
| <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> | <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> | ||||||
| <TITLE>Index to Curl documentation</TITLE> | <TITLE>Index to Curl documentation</TITLE> | ||||||
| @@ -8,31 +8,14 @@ HTML> | |||||||
| <H1 ALIGN="CENTER">Index to Curl documentation</H1> | <H1 ALIGN="CENTER">Index to Curl documentation</H1> | ||||||
|  |  | ||||||
| <H2>Programs</H2> | <H2>Programs</H2> | ||||||
| <P><A HREF="curl-config.html">curl-config.html</A> | <a href="curl-config.html">curl-config</A> | ||||||
| <P><A HREF="curl.html">curl.html</A> | <br><a href="curl.html">curl</A> | ||||||
|  |  | ||||||
|  | <h2>Tutorial</h2> | ||||||
|  | <a href="TheArtOfHttpScripting">The Art Of Scripting HTTP Requests Using Curl</a> (plain text) | ||||||
|  |  | ||||||
|  | <h2>libcurl</h2> | ||||||
|  | See the <a href="libcurl/index.html">libcurl section</a> | ||||||
|  |  | ||||||
| <H2>Library routines</H2> |  | ||||||
| <P><A HREF="libcurl.html">libcurl.html</A> |  | ||||||
| <P><A HREF="curl_easy_cleanup.html">curl_easy_cleanup.html</A> |  | ||||||
| <P><A HREF="curl_easy_duphandle.html">curl_easy_duphandle.html</A> |  | ||||||
| <P><A HREF="curl_easy_getinfo.html">curl_easy_getinfo.html</A> |  | ||||||
| <P><A HREF="curl_easy_init.html">curl_easy_init.html</A> |  | ||||||
| <P><A HREF="curl_easy_perform.html">curl_easy_perform.html</A> |  | ||||||
| <P><A HREF="curl_easy_setopt.html">curl_easy_setopt.html</A> |  | ||||||
| <P><A HREF="curl_escape.html">curl_escape.html</A> |  | ||||||
| <P><A HREF="curl_formadd.html">curl_formadd.html</A> |  | ||||||
| <P><A HREF="curl_formfree.html">curl_formfree.html</A> |  | ||||||
| <P><A HREF="curl_formparse.html">curl_formparse.html</A> |  | ||||||
| <P><A HREF="curl_getdate.html">curl_getdate.html</A> |  | ||||||
| <P><A HREF="curl_getenv.html">curl_getenv.html</A> |  | ||||||
| <P><A HREF="curl_global_cleanup.html">curl_global_cleanup.html</A> |  | ||||||
| <P><A HREF="curl_global_init.html">curl_global_init.html</A> |  | ||||||
| <P><A HREF="curl_mprintf.html">curl_mprintf.html</A> |  | ||||||
| <P><A HREF="curl_slist_append.html">curl_slist_append.html</A> |  | ||||||
| <P><A HREF="curl_slist_free_all.html">curl_slist_free_all.html</A> |  | ||||||
| <P><A HREF="curl_strequal.html">curl_strequal.html</A> |  | ||||||
| <P><A HREF="curl_strnequal.html">curl_strnequal.html</A> |  | ||||||
| <P><A HREF="curl_unescape.html">curl_unescape.html</A> |  | ||||||
| <P><A HREF="curl_version.html">curl_version.html</A> |  | ||||||
| </BODY> | </BODY> | ||||||
| </HTML> | </HTML> | ||||||
|   | |||||||
| @@ -9,10 +9,10 @@ PROGRAMMING WITH LIBCURL | |||||||
|  |  | ||||||
| About this Document | About this Document | ||||||
|  |  | ||||||
|  This document will attempt to describe the general principle and some basic |  This document attempts to describe the general principles and some basic | ||||||
|  approaches to consider when programming with libcurl. The text will focus |  approaches to consider when programming with libcurl. The text will focus | ||||||
|  mainly on the C/C++ interface but might apply fairly well on other interfaces |  mainly on the C interface but might apply fairly well on other interfaces as | ||||||
|  as well as they usually follow the C one pretty closely. |  well as they usually follow the C one pretty closely. | ||||||
|  |  | ||||||
|  This document will refer to 'the user' as the person writing the source code |  This document will refer to 'the user' as the person writing the source code | ||||||
|  that uses libcurl. That would probably be you or someone in your position. |  that uses libcurl. That would probably be you or someone in your position. | ||||||
| @@ -20,13 +20,15 @@ About this Document | |||||||
|  source code that you write that is using libcurl for transfers. The program |  source code that you write that is using libcurl for transfers. The program | ||||||
|  is outside libcurl and libcurl is outside of the program. |  is outside libcurl and libcurl is outside of the program. | ||||||
|  |  | ||||||
|  |  To get the more details on all options and functions described herein, please | ||||||
|  |  refer to their respective man pages. | ||||||
|  |  | ||||||
| Building | Building | ||||||
|  |  | ||||||
|   There are many different ways to build C programs. This chapter will assume |  There are many different ways to build C programs. This chapter will assume a | ||||||
|   a unix-style build process. If you use a different build system, you can |  unix-style build process. If you use a different build system, you can still | ||||||
|   still read this to get general information that may apply to your |  read this to get general information that may apply to your environment as | ||||||
|   environment as well. |  well. | ||||||
|  |  | ||||||
|   Compiling the Program |   Compiling the Program | ||||||
|  |  | ||||||
| @@ -112,9 +114,10 @@ Global Preparation | |||||||
|  call initialized. |  call initialized. | ||||||
|  |  | ||||||
|  Repeated calls to curl_global_init() and curl_global_cleanup() should be |  Repeated calls to curl_global_init() and curl_global_cleanup() should be | ||||||
|  avoided. They should be called once each. |  avoided. They should only be called once each. | ||||||
|  |  | ||||||
| Handle the easy libcurl |  | ||||||
|  | Handle the Easy libcurl | ||||||
|  |  | ||||||
|  libcurl version 7 is oriented around the so called easy interface. All |  libcurl version 7 is oriented around the so called easy interface. All | ||||||
|  operations in the easy interface are prefixed with 'curl_easy'. |  operations in the easy interface are prefixed with 'curl_easy'. | ||||||
| @@ -135,9 +138,22 @@ Handle the easy libcurl | |||||||
|  |  | ||||||
|  It returns an easy handle. Using that you proceed to the next step: setting |  It returns an easy handle. Using that you proceed to the next step: setting | ||||||
|  up your preferred actions. A handle is just a logic entity for the upcoming |  up your preferred actions. A handle is just a logic entity for the upcoming | ||||||
|  transfer or series of transfers. One of the most basic properties to set in |  transfer or series of transfers. | ||||||
|  the handle is the URL. You set your preferred URL to transfer with |  | ||||||
|  CURLOPT_URL in a manner similar to: |  You set properties and options for this handle using curl_easy_setopt(). They | ||||||
|  |  control how the subsequent transfer or transfers will be made. Options remain | ||||||
|  |  set in the handle until set again to something different. Alas, multiple | ||||||
|  |  requests using the same handle will use the same options. | ||||||
|  |  | ||||||
|  |  Many of the informationals you set in libcurl are "strings", pointers to data | ||||||
|  |  terminated with a zero byte. Keep in mind that when you set strings with | ||||||
|  |  curl_easy_setopt(), libcurl will not copy the data. It will merely point to | ||||||
|  |  the data. You MUST make sure that the data remains available for libcurl to | ||||||
|  |  use until finished or until you use the same option again to point to | ||||||
|  |  something else. | ||||||
|  |  | ||||||
|  |  One of the most basic properties to set in the handle is the URL. You set | ||||||
|  |  your preferred URL to transfer with CURLOPT_URL in a manner similar to: | ||||||
|  |  | ||||||
|     curl_easy_setopt(easyhandle, CURLOPT_URL, "http://curl.haxx.se/"); |     curl_easy_setopt(easyhandle, CURLOPT_URL, "http://curl.haxx.se/"); | ||||||
|  |  | ||||||
| @@ -200,6 +216,24 @@ Handle the easy libcurl | |||||||
|  previous |  previous | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Multi-threading issues | ||||||
|  |  | ||||||
|  |  libcurl is completely thread safe, except for two issues: signals and alarm | ||||||
|  |  handlers. Signals are needed for a SIGPIPE handler, and the alarm() syscall | ||||||
|  |  is used to catch timeouts (mostly during DNS lookup). | ||||||
|  |  | ||||||
|  |  So when using multiple threads you should first ignore SIGPIPE in your main | ||||||
|  |  thread and set the CURLOPT_NOSIGNAL option to TRUE for all handles. | ||||||
|  |  | ||||||
|  |  Everything will work fine except that timeouts are not honored during the DNS | ||||||
|  |  lookup - this would require some sort of asynchronous DNS lookup (which is | ||||||
|  |  planned for a future libcurl version). | ||||||
|  |  | ||||||
|  |  For SIGPIPE info see the UNIX Socket FAQ at | ||||||
|  |  http://www.unixguide.net/network/socketfaq/2.22.shtml | ||||||
|  |  | ||||||
|  |  Also, note that CURLOPT_DNS_USE_GLOBAL_CACHE is not thread-safe. | ||||||
|  |  | ||||||
| When It Doesn't Work | When It Doesn't Work | ||||||
|  |  | ||||||
|  There will always be times when the transfer fails for some reason. You might |  There will always be times when the transfer fails for some reason. You might | ||||||
| @@ -222,6 +256,14 @@ When It Doesn't Work | |||||||
|  possible of your code that uses libcurl, operating system name and version, |  possible of your code that uses libcurl, operating system name and version, | ||||||
|  compiler name and version etc. |  compiler name and version etc. | ||||||
|  |  | ||||||
|  |  If CURLOPT_VERBOSE is not enough, you increase the level of debug data your | ||||||
|  |  application receive by using the CURLOPT_DEBUGFUNCTION. | ||||||
|  |  | ||||||
|  |  Getting some in-depth knowledge about the protocols involved is never wrong, | ||||||
|  |  and if you're trying to do funny things, you might very well understand | ||||||
|  |  libcurl and how to use it better if you study the appropriate RFC documents | ||||||
|  |  at least briefly. | ||||||
|  |  | ||||||
|  |  | ||||||
| Upload Data to a Remote Site | Upload Data to a Remote Site | ||||||
|  |  | ||||||
| @@ -238,12 +280,13 @@ Upload Data to a Remote Site | |||||||
|  the custom pointer libcurl will pass to our read callback. The read callback |  the custom pointer libcurl will pass to our read callback. The read callback | ||||||
|  should have a prototype similar to: |  should have a prototype similar to: | ||||||
|  |  | ||||||
|    size_t function(char *buffer, size_t size, size_t nitems, void *userp); |     size_t function(char *bufptr, size_t size, size_t nitems, void *userp); | ||||||
|  |  | ||||||
|  Where buffer is the pointer to a buffer we fill in with data to upload and |  Where bufptr is the pointer to a buffer we fill in with data to upload and | ||||||
|  size*nitems is the size of the buffer. The 'userp' pointer is the custom |  size*nitems is the size of the buffer and therefore also the maximum amount | ||||||
|  pointer we set to point to a struct of ours to pass private data between the |  of data we can return to libcurl in this call. The 'userp' pointer is the | ||||||
|  application and the callback. |  custom pointer we set to point to a struct of ours to pass private data | ||||||
|  |  between the application and the callback. | ||||||
|  |  | ||||||
|     curl_easy_setopt(easyhandle, CURLOPT_READFUNCTION, read_function); |     curl_easy_setopt(easyhandle, CURLOPT_READFUNCTION, read_function); | ||||||
|  |  | ||||||
| @@ -254,12 +297,12 @@ Upload Data to a Remote Site | |||||||
|     curl_easy_setopt(easyhandle, CURLOPT_UPLOAD, TRUE); |     curl_easy_setopt(easyhandle, CURLOPT_UPLOAD, TRUE); | ||||||
|  |  | ||||||
|  A few protocols won't behave properly when uploads are done without any prior |  A few protocols won't behave properly when uploads are done without any prior | ||||||
|  knowledge of the expected file size. HTTP PUT is one example [1]. So, set the |  knowledge of the expected file size. So, set the upload file size using the | ||||||
|  upload file size using the CURLOPT_INFILESIZE like this: |  CURLOPT_INFILESIZE for all known file sizes like this[1]: | ||||||
|  |  | ||||||
|     curl_easy_setopt(easyhandle, CURLOPT_INFILESIZE, file_size); |     curl_easy_setopt(easyhandle, CURLOPT_INFILESIZE, file_size); | ||||||
|  |  | ||||||
|  So, then you call curl_easy_perform() this time, it'll perform all necessary |  When you call curl_easy_perform() this time, it'll perform all the necessary | ||||||
|  operations and when it has invoked the upload it'll call your supplied |  operations and when it has invoked the upload it'll call your supplied | ||||||
|  callback to get the data to upload. The program should return as much data as |  callback to get the data to upload. The program should return as much data as | ||||||
|  possible in every invoke, as that is likely to make the upload perform as |  possible in every invoke, as that is likely to make the upload perform as | ||||||
| @@ -273,11 +316,207 @@ Passwords | |||||||
|  to be able to download or upload the data of your choice. libcurl offers |  to be able to download or upload the data of your choice. libcurl offers | ||||||
|  several ways to specify them. |  several ways to specify them. | ||||||
|  |  | ||||||
|   [ URL, options, callback ] |  Most protocols support that you specify the name and password in the URL | ||||||
|  |  itself. libcurl will detect this and use them accordingly. This is written | ||||||
|  |  like this: | ||||||
|  |  | ||||||
|  |         protocol://user:password@example.com/path/ | ||||||
|  |  | ||||||
|  |  If you need any odd letters in your user name or password, you should enter | ||||||
|  |  them URL encoded, as %XX where XX is a two-digit hexadecimal number. | ||||||
|  |  | ||||||
|  |  libcurl also provides options to set various passwords. The user name and | ||||||
|  |  password as shown embedded in the URL can instead get set with the | ||||||
|  |  CURLOPT_USERPWD option. The argument passed to libcurl should be a char * to | ||||||
|  |  a string in the format "user:password:". In a manner like this: | ||||||
|  |  | ||||||
|  |         curl_easy_setopt(easyhandle, CURLOPT_USERPWD, "myname:thesecret"); | ||||||
|  |  | ||||||
|  |  Another case where name and password might be needed at times, is for those | ||||||
|  |  users who need to athenticate themselves to a proxy they use. libcurl offers | ||||||
|  |  another option for this, the CURLOPT_PROXYUSERPWD. It is used quite similar | ||||||
|  |  to the CURLOPT_USERPWD option like this: | ||||||
|  |  | ||||||
|  |         curl_easy_setopt(easyhandle, CURLOPT_PROXYUSERPWD, "myname:thesecret"); | ||||||
|  |   | ||||||
|  |  There's a long time unix "standard" way of storing ftp user names and | ||||||
|  |  passwords, namely in the $HOME/.netrc file. The file should be made private | ||||||
|  |  so that only the user may read it (see also the "Security Considerations" | ||||||
|  |  chapter), as it might contain the password in plain text. libcurl has the | ||||||
|  |  ability to use this file to figure out what set of user name and password to | ||||||
|  |  use for a particular host. As an extension to the normal functionality, | ||||||
|  |  libcurl also supports this file for non-FTP protocols such as HTTP. To make | ||||||
|  |  curl use this file, use the CURLOPT_NETRC option: | ||||||
|  |  | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_NETRC, TRUE); | ||||||
|  |  | ||||||
|  |  And a very basic example of how such a .netrc file may look like: | ||||||
|  |  | ||||||
|  |     machine myhost.mydomain.com | ||||||
|  |     login userlogin | ||||||
|  |     password secretword | ||||||
|  |  | ||||||
|  |  All these examples have been cases where the password has been optional, or | ||||||
|  |  at least you could leave it out and have libcurl attempt to do its job | ||||||
|  |  without it. There are times when the password isn't optional, like when | ||||||
|  |  you're using an SSL private key for secure transfers. | ||||||
|  |  | ||||||
|  |  You can in this situation either pass a password to libcurl to use to unlock | ||||||
|  |  the private key, or you can let libcurl prompt the user for it. If you prefer | ||||||
|  |  to ask the user, then you can provide your own callback function that will be | ||||||
|  |  called when libcurl wants the password. That way, you can control how the | ||||||
|  |  question will appear to the user. | ||||||
|  |  | ||||||
|  |  To pass the known private key password to libcurl: | ||||||
|  |  | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_SSLKEYPASSWD, "keypassword"); | ||||||
|  |  | ||||||
|  |  To make a password callback: | ||||||
|  |  | ||||||
|  |     int enter_passwd(void *ourp, const char *prompt, char *buffer, int len); | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_PASSWDFUNCTION, enter_passwd); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | HTTP POSTing | ||||||
|  |  | ||||||
|  |  We get many questions regarding how to issue HTTP POSTs with libcurl the | ||||||
|  |  proper way. This chapter will thus include examples using both different | ||||||
|  |  versions of HTTP POST that libcurl supports. | ||||||
|  |  | ||||||
|  |  The first version is the simple POST, the most common version, that most HTML | ||||||
|  |  pages using the <form> tag uses. We provide a pointer to the data and tell | ||||||
|  |  libcurl to post it all to the remote site: | ||||||
|  |  | ||||||
|  |     char *data="name=daniel&project=curl"; | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_POSTFIELDS, data); | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_URL, "http://posthere.com/"); | ||||||
|  |  | ||||||
|  |     curl_easy_perform(easyhandle); /* post away! */ | ||||||
|  |  | ||||||
|  |  Simple enough, huh? Since you set the POST options with the | ||||||
|  |  CURLOPT_POSTFIELDS, this automaticly switches the handle to use POST in the | ||||||
|  |  upcoming request. | ||||||
|  |  | ||||||
|  |  Ok, so what if you want to post binary data that also requires you to set the | ||||||
|  |  Content-Type: header of the post? Well, binary posts prevents libcurl from | ||||||
|  |  being able to do strlen() on the data to figure out the size, so therefore we | ||||||
|  |  must tell libcurl the size of the post data. Setting headers in libcurl | ||||||
|  |  requests are done in a generic way, by building a list of our own headers and | ||||||
|  |  then passing that list to libcurl. | ||||||
|  |  | ||||||
|  |     struct curl_slist *headers=NULL; | ||||||
|  |     headers = curl_slist_append(headers, "Content-Type: text/xml"); | ||||||
|  |  | ||||||
|  |     /* post binary data */ | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_POSTFIELDS, binaryptr); | ||||||
|  |  | ||||||
|  |     /* set the size of the postfields data */ | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_POSTFIELDSIZE, 23); | ||||||
|  |  | ||||||
|  |     /* pass our list of custom made headers */ | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_HTTPHEADER, headers); | ||||||
|  |  | ||||||
|  |     curl_easy_perform(easyhandle); /* post away! */ | ||||||
|  |  | ||||||
|  |     curl_slist_free_all(headers); /* free the header list */ | ||||||
|  |  | ||||||
|  |  While the simple examples above cover the majority of all cases where HTTP | ||||||
|  |  POST operations are required, they don't do multipart formposts. Multipart | ||||||
|  |  formposts were introduced as a better way to post (possibly large) binary | ||||||
|  |  data and was first documented in the RFC1867. They're called multipart | ||||||
|  |  because they're built by a chain of parts, each being a single unit. Each | ||||||
|  |  part has its own name and contents. You can in fact create and post a | ||||||
|  |  multipart formpost with the regular libcurl POST support described above, but | ||||||
|  |  that would require that you build a formpost yourself and provide to | ||||||
|  |  libcurl. To make that easier, libcurl provides curl_formadd(). Using this | ||||||
|  |  function, you add parts to the form. When you're done adding parts, you post | ||||||
|  |  the whole form. | ||||||
|  |  | ||||||
|  |  The following example sets two simple text parts with plain textual contents, | ||||||
|  |  and then a file with binary contents and upload the whole thing. | ||||||
|  |  | ||||||
|  |     struct curl_httppost *post=NULL; | ||||||
|  |     struct curl_httppost *last=NULL; | ||||||
|  |     curl_formadd(&post, &last, | ||||||
|  |                  CURLFORM_COPYNAME, "name", | ||||||
|  |                  CURLFORM_COPYCONTENTS, "daniel", CURLFORM_END); | ||||||
|  |     curl_formadd(&post, &last, | ||||||
|  |                  CURLFORM_COPYNAME, "project", | ||||||
|  |                  CURLFORM_COPYCONTENTS, "curl", CURLFORM_END); | ||||||
|  |     curl_formadd(&post, &last, | ||||||
|  |                  CURLFORM_COPYNAME, "logotype-image", | ||||||
|  |                  CURLFORM_FILECONTENT, "curl.png", CURLFORM_END); | ||||||
|  |  | ||||||
|  |     /* Set the form info */ | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_HTTPPOST, post); | ||||||
|  |  | ||||||
|  |     curl_easy_perform(easyhandle); /* post away! */ | ||||||
|  |  | ||||||
|  |     /* free the post data again */ | ||||||
|  |     curl_formfree(post); | ||||||
|  |  | ||||||
|  |  Multipart formposts are chains of parts using MIME-style separators and | ||||||
|  |  headers. It means that each one of these separate parts get a few headers set | ||||||
|  |  that describe the individual content-type, size etc. To enable your | ||||||
|  |  application to handicraft this formpost even more, libcurl allows you to | ||||||
|  |  supply your own set of custom headers to such an individual form part. You | ||||||
|  |  can of course supply headers to as many parts you like, but this little | ||||||
|  |  example will show how you set headers to one specific part when you add that | ||||||
|  |  to the post handle: | ||||||
|  |  | ||||||
|  |     struct curl_slist *headers=NULL; | ||||||
|  |     headers = curl_slist_append(headers, "Content-Type: text/xml"); | ||||||
|  |  | ||||||
|  |     curl_formadd(&post, &last, | ||||||
|  |                  CURLFORM_COPYNAME, "logotype-image", | ||||||
|  |                  CURLFORM_FILECONTENT, "curl.xml", | ||||||
|  |                  CURLFORM_CONTENTHEADER, headers, | ||||||
|  |                  CURLFORM_END); | ||||||
|  |  | ||||||
|  |     curl_easy_perform(easyhandle); /* post away! */ | ||||||
|  |  | ||||||
|  |     curl_formfree(post); /* free post */ | ||||||
|  |     curl_slist_free_all(post); /* free custom header list */ | ||||||
|  |  | ||||||
|  |  Since all options on an easyhandle are "sticky", they remain the same until | ||||||
|  |  changed even if you do call curl_easy_perform(), you may need to tell curl to | ||||||
|  |  go back to a plain GET request if you intend to do such a one as your next | ||||||
|  |  request. You force an easyhandle to back to GET by using the CURLOPT_HTTPGET | ||||||
|  |  option: | ||||||
|  |  | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_HTTPGET, TRUE); | ||||||
|  |  | ||||||
|  |  Just setting CURLOPT_POSTFIELDS to "" or NULL will *not* stop libcurl from | ||||||
|  |  doing a POST. It will just make it POST without any data to send! | ||||||
|  |  | ||||||
|  |  | ||||||
| Showing Progress | Showing Progress | ||||||
|  |  | ||||||
|  |  For historical and traditional reasons, libcurl has a built-in progress meter | ||||||
|  |  that can be switched on and then makes it presents a progress meter in your | ||||||
|  |  terminal. | ||||||
|  |  | ||||||
|  |  Switch on the progress meter by, oddly enough, set CURLOPT_NOPROGRESS to | ||||||
|  |  FALSE. This option is set to TRUE by default. | ||||||
|  |  | ||||||
|  |  For most applications however, the built-in progress meter is useless and | ||||||
|  |  what instead is interesting is the ability to specify a progress | ||||||
|  |  callback. The function pointer you pass to libcurl will then be called on | ||||||
|  |  irregular intervals with information about the current transfer. | ||||||
|  |  | ||||||
|  |  Set the progress callback by using CURLOPT_PROGRESSFUNCTION. And pass a | ||||||
|  |  pointer to a function that matches this prototype: | ||||||
|  |  | ||||||
|  |         int progress_callback(void *clientp, | ||||||
|  |                               double dltotal, | ||||||
|  |                               double dlnow, | ||||||
|  |                               double ultotal, | ||||||
|  |                               double ulnow); | ||||||
|  |  | ||||||
|  |  If any of the input arguments is unknown, a 0 will be passed. The first | ||||||
|  |  argument, the 'clientp' is the pointer you pass to libcurl with | ||||||
|  |  CURLOPT_PROGRESSDATA. libcurl won't touch it. | ||||||
|  |  | ||||||
|  |  | ||||||
| libcurl with C++ | libcurl with C++ | ||||||
|  |  | ||||||
| @@ -301,23 +540,558 @@ libcurl with C++ | |||||||
|  any "this" pointer available etc. |  any "this" pointer available etc. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Proxies | ||||||
|  |  | ||||||
|  |  What "proxy" means according to Merriam-Webster: "a person authorized to act | ||||||
|  |  for another" but also "the agency, function, or office of a deputy who acts | ||||||
|  |  as a substitute for another". | ||||||
|  |  | ||||||
|  |  Proxies are exceedingly common these days. Companies often only offer | ||||||
|  |  internet access to employees through their HTTP proxies. Network clients or | ||||||
|  |  user-agents ask the proxy for docuements, the proxy does the actual request | ||||||
|  |  and then it returns them. | ||||||
|  |  | ||||||
|  |  libcurl has full support for HTTP proxies, so when a given URL is wanted, | ||||||
|  |  libcurl will ask the proxy for it instead of trying to connect to the actual | ||||||
|  |  host identified in the URL. | ||||||
|  |  | ||||||
|  |  The fact that the proxy is a HTTP proxy puts certain restrictions on what can | ||||||
|  |  actually happen. A requested URL that might not be a HTTP URL will be still | ||||||
|  |  be passed to the HTTP proxy to deliver back to libcurl. This happens | ||||||
|  |  transparantly, and an application may not need to know. I say "may", because | ||||||
|  |  at times it is very important to understand that all operations over a HTTP | ||||||
|  |  proxy is using the HTTP protocol. For example, you can't invoke your own | ||||||
|  |  custom FTP commands or even proper FTP directory listings. | ||||||
|  |  | ||||||
|  |   Proxy Options | ||||||
|  |  | ||||||
|  |     To tell libcurl to use a proxy at a given port number: | ||||||
|  |  | ||||||
|  |        curl_easy_setopt(easyhandle, CURLOPT_PROXY, "proxy-host.com:8080"); | ||||||
|  |  | ||||||
|  |     Some proxies require user authentication before allowing a request, and | ||||||
|  |     you pass that information similar to this: | ||||||
|  |  | ||||||
|  |        curl_easy_setopt(easyhandle, CURLOPT_PROXYUSERPWD, "user:password"); | ||||||
|  |  | ||||||
|  |     If you want to, you can specify the host name only in the CURLOPT_PROXY | ||||||
|  |     option, and set the port number separately with CURLOPT_PROXYPORT. | ||||||
|  |  | ||||||
|  |   Environment Variables | ||||||
|  |  | ||||||
|  |     libcurl automaticly checks and uses a set of environment variables to know | ||||||
|  |     what proxies to use for certain protocols. The names of the variables are | ||||||
|  |     following an ancient de facto standard and are built up as | ||||||
|  |     "[protocol]_proxy" (note the lower casing). Which makes the variable | ||||||
|  |     'http_proxy' checked for a name of a proxy to use when the input URL is | ||||||
|  |     HTTP. Following the same rule, the variable named 'ftp_proxy' is checked | ||||||
|  |     for FTP URLs. Again, the proxies are always HTTP proxies, the different | ||||||
|  |     names of the variables simply allows different HTTP proxies to be used. | ||||||
|  |  | ||||||
|  |     The proxy environment variable contents should be in the format | ||||||
|  |     "[protocol://]machine[:port]". Where the protocol:// part is simply | ||||||
|  |     ignored if present (so http://proxy and bluerk://proxy will do the same) | ||||||
|  |     and the optional port number specifies on which port the proxy operates on | ||||||
|  |     the host. If not specified, the internal default port number will be used | ||||||
|  |     and that is most likely *not* the one you would like it to be. | ||||||
|  |  | ||||||
|  |     There are two special environment variables. 'all_proxy' is what sets | ||||||
|  |     proxy for any URL in case the protocol specific variable wasn't set, and | ||||||
|  |     'no_proxy' defines a list of hosts that should not use a proxy even though | ||||||
|  |     a variable may say so. If 'no_proxy' is a plain asterisk ("*") it matches | ||||||
|  |     all hosts. | ||||||
|  |  | ||||||
|  |   SSL and Proxies | ||||||
|  |  | ||||||
|  |     SSL is for secure point-to-point connections. This involves strong | ||||||
|  |     encryption and similar things, which effectivly makes it impossible for a | ||||||
|  |     proxy to operate as a "man in between" which the proxy's task is, as | ||||||
|  |     previously discussed. Instead, the only way to have SSL work over a HTTP | ||||||
|  |     proxy is to ask the proxy to tunnel trough everything without being able | ||||||
|  |     to check or fiddle with the traffic. | ||||||
|  |  | ||||||
|  |     Opening an SSL connection over a HTTP proxy is therefor a matter of asking | ||||||
|  |     the proxy for a straight connection to the target host on a specified | ||||||
|  |     port. This is made with the HTTP request CONNECT. ("please mr proxy, | ||||||
|  |     connect me to that remote host"). | ||||||
|  |  | ||||||
|  |     Because of the nature of this operation, where the proxy has no idea what | ||||||
|  |     kind of data that is passed in and out through this tunnel, this breaks | ||||||
|  |     some of the very few advantages that come from using a proxy, such as | ||||||
|  |     caching.  Many organizations prevent this kind of tunneling to other | ||||||
|  |     destination port numbers than 443 (which is the default HTTPS port | ||||||
|  |     number). | ||||||
|  |  | ||||||
|  |   Tunneling Through Proxy | ||||||
|  |  | ||||||
|  |     As explained above, tunneling is required for SSL to work and often even | ||||||
|  |     restricted to the operation intended for SSL; HTTPS. | ||||||
|  |  | ||||||
|  |     This is however not the only time proxy-tunneling might offer benefits to | ||||||
|  |     you or your application. | ||||||
|  |  | ||||||
|  |     As tunneling opens a direct connection from your application to the remote | ||||||
|  |     machine, it suddenly also re-introduces the ability to do non-HTTP | ||||||
|  |     operations over a HTTP proxy. You can in fact use things such as FTP | ||||||
|  |     upload or FTP custom commands this way. | ||||||
|  |  | ||||||
|  |     Again, this is often prevented by the adminstrators of proxies and is | ||||||
|  |     rarely allowed. | ||||||
|  |  | ||||||
|  |     Tell libcurl to use proxy tunneling like this: | ||||||
|  |  | ||||||
|  |        curl_easy_setopt(easyhandle, CURLOPT_HTTPPROXYTUNNEL, TRUE); | ||||||
|  |  | ||||||
|  |     In fact, there might even be times when you want to do plain HTTP | ||||||
|  |     operations using a tunnel like this, as it then enables you to operate on | ||||||
|  |     the remote server instead of asking the proxy to do so. libcurl will not | ||||||
|  |     stand in the way for such innovative actions either! | ||||||
|  |  | ||||||
|  |   Proxy Auto-Config | ||||||
|  |  | ||||||
|  |     Netscape first came up with this. It is basicly a web page (usually using | ||||||
|  |     a .pac extension) with a javascript that when executed by the browser with | ||||||
|  |     the requested URL as input, returns information to the browser on how to | ||||||
|  |     connect to the URL. The returned information might be "DIRECT" (which | ||||||
|  |     means no proxy should be used), "PROXY host:port" (to tell the browser | ||||||
|  |     where the proxy for this particular URL is) or "SOCKS host:port" (to | ||||||
|  |     direct the brower to a SOCKS proxy). | ||||||
|  |  | ||||||
|  |     libcurl has no means to interpret or evaluate javascript and thus it | ||||||
|  |     doesn't support this. If you get yourself in a position where you face | ||||||
|  |     this nasty invention, the following advice have been mentioned and used in | ||||||
|  |     the past: | ||||||
|  |  | ||||||
|  |     - Depending on the javascript complexity, write up a script that | ||||||
|  |       translates it to another language and execute that. | ||||||
|  |  | ||||||
|  |     - Read the javascript code and rewrite the same logic in another language. | ||||||
|  |  | ||||||
|  |     - Implement a javascript interpreted, people have successfully used the | ||||||
|  |       Mozilla javascript engine in the past. | ||||||
|  |  | ||||||
|  |     - Ask your admins to stop this, for a static proxy setup or similar. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Persistancy Is The Way to Happiness | ||||||
|  |  | ||||||
|  |  Re-cycling the same easy handle several times when doing multiple requests is | ||||||
|  |  the way to go. | ||||||
|  |  | ||||||
|  |  After each single curl_easy_perform() operation, libcurl will keep the | ||||||
|  |  connection alive and open. A subsequent request using the same easy handle to | ||||||
|  |  the same host might just be able to use the already open connection! This | ||||||
|  |  reduces network impact a lot. | ||||||
|  |  | ||||||
|  |  Even if the connection is dropped, all connections involving SSL to the same | ||||||
|  |  host again, will benefit from libcurl's session ID cache that drasticly | ||||||
|  |  reduces re-connection time. | ||||||
|  |  | ||||||
|  |  FTP connections that are kept alive saves a lot of time, as the command- | ||||||
|  |  response roundtrips are skipped, and also you don't risk getting blocked | ||||||
|  |  without permission to login again like on many FTP servers only allowing N | ||||||
|  |  persons to be logged in at the same time. | ||||||
|  |  | ||||||
|  |  libcurl caches DNS name resolving results, to make lookups of a previously | ||||||
|  |  looked up name a lot faster. | ||||||
|  |  | ||||||
|  |  Other interesting details that improve performance for subsequent requests | ||||||
|  |  may also be added in the future. | ||||||
|  |  | ||||||
|  |  Each easy handle will attempt to keep the last few connections alive for a | ||||||
|  |  while in case they are to be used again. You can set the size of this "cache" | ||||||
|  |  with the CURLOPT_MAXCONNECTS option. Default is 5. It is very seldom any | ||||||
|  |  point in changing this value, and if you think of changing this it is often | ||||||
|  |  just a matter of thinking again. | ||||||
|  |  | ||||||
|  |  When the connection cache gets filled, libcurl must close an existing | ||||||
|  |  connection in order to get room for the new one. To know which connection to | ||||||
|  |  close, libcurl uses a "close policy" that you can affect with the | ||||||
|  |  CURLOPT_CLOSEPOLICY option. There's only two polices implemented as of this | ||||||
|  |  writing (libcurl 7.9.4) and they are: | ||||||
|  |  | ||||||
|  |   CURLCLOSEPOLICY_LEAST_RECENTLY_USED simply close the one that hasn't been | ||||||
|  |   used for the longest time. This is the default behavior. | ||||||
|  |  | ||||||
|  |   CURLCLOSEPOLICY_OLDEST closes the oldest connection, the one that was | ||||||
|  |   createst the longest time ago. | ||||||
|  |  | ||||||
|  |  There are, or at least were, plans to support a close policy that would call | ||||||
|  |  a user-specified callback to let the user be able to decide which connection | ||||||
|  |  to dump when this is necessary and therefor is the CURLOPT_CLOSEFUNCTION an | ||||||
|  |  existing option still today. Nothing ever uses this though and this will not | ||||||
|  |  be used within the forseeable future either. | ||||||
|  |  | ||||||
|  |  To force your upcoming request to not use an already existing connection (it | ||||||
|  |  will even close one first if there happens to be one alive to the same host | ||||||
|  |  you're about to operate on), you can do that by setting CURLOPT_FRESH_CONNECT | ||||||
|  |  to TRUE. In a similar spirit, you can also forbid the upcoming request to be | ||||||
|  |  "lying" around and possibly get re-used after the request by setting | ||||||
|  |  CURLOPT_FORBID_REUSE to TRUE. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | HTTP Headers Used by libcurl | ||||||
|  |  | ||||||
|  |  When you use libcurl to do HTTP requeests, it'll pass along a series of | ||||||
|  |  headers automaticly. It might be good for you to know and understand these | ||||||
|  |  ones. | ||||||
|  |  | ||||||
|  |   Host | ||||||
|  |  | ||||||
|  |     This header is required by HTTP 1.1 and even many 1.0 servers and should | ||||||
|  |     be the name of the server we want to talk to. This includes the port | ||||||
|  |     number if anything but default. | ||||||
|  |  | ||||||
|  |   Pragma | ||||||
|  |  | ||||||
|  |     "no-cache". Tells a possible proxy to not grap a copy from the cache but | ||||||
|  |     to fetch a fresh one. | ||||||
|  |  | ||||||
|  |   Accept: | ||||||
|  |  | ||||||
|  |     "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*". Cloned from a | ||||||
|  |     browser once a hundred years ago. | ||||||
|  |  | ||||||
|  |   Expect: | ||||||
|  |  | ||||||
|  |     When doing multi-part formposts, libcurl will set this header to | ||||||
|  |     "100-continue" to ask the server for an "OK" message before it proceeds | ||||||
|  |     with sending the data part of the post. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Customizing Operations | ||||||
|  |  | ||||||
|  |  There is an ongoing development today where more and more protocols are built | ||||||
|  |  upon HTTP for transport. This has obvious benefits as HTTP is a tested and | ||||||
|  |  reliable protocol that is widely deployed and have excellent proxy-support. | ||||||
|  |  | ||||||
|  |  When you use one of these protocols, and even when doing other kinds of | ||||||
|  |  programming you may need to change the traditional HTTP (or FTP or...) | ||||||
|  |  manners. You may need to change words, headers or various data. | ||||||
|  |  | ||||||
|  |  libcurl is your friend here too. | ||||||
|  |  | ||||||
|  |   CUSTOMREQUEST | ||||||
|  |  | ||||||
|  |     If just changing the actual HTTP request keyword is what you want, like | ||||||
|  |     when GET, HEAD or POST is not good enough for you, CURLOPT_CUSTOMREQUEST | ||||||
|  |     is there for you. It is very simple to use: | ||||||
|  |  | ||||||
|  |        curl_easy_setopt(easyhandle, CURLOPT_CUSTOMREQUEST, "MYOWNRUQUEST"); | ||||||
|  |  | ||||||
|  |     When using the custom request, you change the request keyword of the | ||||||
|  |     actual request you are performing. Thus, by default you make GET request | ||||||
|  |     but you can also make a POST operation (as described before) and then | ||||||
|  |     replace the POST keyword if you want to. You're the boss. | ||||||
|  |  | ||||||
|  |   Modify Headers | ||||||
|  |  | ||||||
|  |     HTTP-like protocols pass a series of headers to the server when doing the | ||||||
|  |     request, and you're free to pass any amount of extra headers that you | ||||||
|  |     think fit. Adding headers are this easy: | ||||||
|  |  | ||||||
|  |        struct curl_slist *headers=NULL; /* init to NULL is important */ | ||||||
|  |  | ||||||
|  |        headers = curl_slist_append(headers, "Hey-server-hey: how are you?"); | ||||||
|  |        headers = curl_slist_append(headers, "X-silly-content: yes"); | ||||||
|  |  | ||||||
|  |        /* pass our list of custom made headers */ | ||||||
|  |        curl_easy_setopt(easyhandle, CURLOPT_HTTPHEADER, headers); | ||||||
|  |  | ||||||
|  |        curl_easy_perform(easyhandle); /* transfer http */ | ||||||
|  |  | ||||||
|  |        curl_slist_free_all(headers); /* free the header list */ | ||||||
|  |  | ||||||
|  |    ... and if you think some of the internally generated headers, such as | ||||||
|  |    Accept: or Host: don't contain the data you want them to contain, you can | ||||||
|  |    replace them by simply setting them too: | ||||||
|  |  | ||||||
|  |        headers = curl_slist_append(headers, "Accept: Agent-007"); | ||||||
|  |        headers = curl_slist_append(headers, "Host: munged.host.line"); | ||||||
|  |  | ||||||
|  |   Delete Headers | ||||||
|  |  | ||||||
|  |     If you replace an existing header with one with no contents, you will | ||||||
|  |     prevent the header from being sent. Like if you want to completely prevent | ||||||
|  |     the "Accept:" header to be sent, you can disable it with code similar to | ||||||
|  |     this: | ||||||
|  |  | ||||||
|  |        headers = curl_slist_append(headers, "Accept:"); | ||||||
|  |  | ||||||
|  |     Both replacing and cancelling internal headers should be done with careful | ||||||
|  |     consideration and you should be aware that you may violate the HTTP | ||||||
|  |     protocol when doing so. | ||||||
|  |  | ||||||
|  |   Enforcing chunked transfer-encoding | ||||||
|  |  | ||||||
|  |     By making sure a request uses the custom header "Transfer-Encoding: | ||||||
|  |     chunked" when doing a non-GET HTTP operation, libcurl will switch over to | ||||||
|  |     "chunked" upload, even though the size of the data to upload might be | ||||||
|  |     known. By default, libcurl usually switches over to chunked upload | ||||||
|  |     automaticly if the upload data size is unknown. | ||||||
|  |  | ||||||
|  |   HTTP Version | ||||||
|  |  | ||||||
|  |     There's only one aspect left in the HTTP requests that we haven't yet | ||||||
|  |     mentioned how to modify: the version field. All HTTP requests includes the | ||||||
|  |     version number to tell the server which version we support. libcurl speak | ||||||
|  |     HTTP 1.1 by default. Some very old servers don't like getting 1.1-requests | ||||||
|  |     and when dealing with stubborn old things like that, you can tell libcurl | ||||||
|  |     to use 1.0 instead by doing something like this: | ||||||
|  |  | ||||||
|  |        curl_easy_setopt(easyhandle, CURLOPT_HTTP_VERSION, | ||||||
|  |                                     CURLHTTP_VERSION_1_0); | ||||||
|  |  | ||||||
|  |   FTP Custom Commands | ||||||
|  |  | ||||||
|  |     Not all protocols are HTTP-like, and thus the above may not help you when | ||||||
|  |     you want to make for example your FTP transfers to behave differently. | ||||||
|  |  | ||||||
|  |     Sending custom commands to a FTP server means that you need to send the | ||||||
|  |     comands exactly as the FTP server expects them (RFC959 is a good guide | ||||||
|  |     here), and you can only use commands that work on the control-connection | ||||||
|  |     alone. All kinds of commands that requires data interchange and thus needs | ||||||
|  |     a data-connection must be left to libcurl's own judgement. Also be aware | ||||||
|  |     that libcurl will do its very best to change directory to the target | ||||||
|  |     directory before doing any transfer, so if you change directory (with CWD | ||||||
|  |     or similar) you might confuse libcurl and then it might not attempt to | ||||||
|  |     transfer the file in the correct remote directory. | ||||||
|  |  | ||||||
|  |     A little example that deletes a given file before an operation: | ||||||
|  |  | ||||||
|  |       headers = curl_slist_append(headers, "DELE file-to-remove"); | ||||||
|  |  | ||||||
|  |       /* pass the list of custom commands to the handle */ | ||||||
|  |       curl_easy_setopt(easyhandle, CURLOPT_QUOTE, headers); | ||||||
|  |  | ||||||
|  |       curl_easy_perform(easyhandle); /* transfer ftp data! */ | ||||||
|  |  | ||||||
|  |       curl_slist_free_all(headers); /* free the header list */ | ||||||
|  |  | ||||||
|  |     If you would instead want this operation (or chain of operations) to | ||||||
|  |     happen _after_ the data transfer took place the option to | ||||||
|  |     curl_easy_setopt() would instead be called CURLOPT_POSTQUOTE and used the | ||||||
|  |     exact same way. | ||||||
|  |  | ||||||
|  |     The custom FTP command will be issued to the server in the same order they | ||||||
|  |     are added to the list, and if a command gets an error code returned back | ||||||
|  |     from the server, no more commands will be issued and libcurl will bail out | ||||||
|  |     with an error code (CURLE_FTP_QUOTE_ERROR). Note that if you use | ||||||
|  |     CURLOPT_QUOTE to send commands before a transfer, no transfer will | ||||||
|  |     actually take place when a quote command has failed. | ||||||
|  |  | ||||||
|  |     If you set the CURLOPT_HEADER to true, you will tell libcurl to get | ||||||
|  |     information about the target file and output "headers" about it. The | ||||||
|  |     headers will be in "HTTP-style", looking like they do in HTTP. | ||||||
|  |  | ||||||
|  |     The option to enable headers or to run custom FTP commands may be useful | ||||||
|  |     to combine with CURLOPT_NOBODY. If this option is set, no actual file | ||||||
|  |     content transfer will be performed. | ||||||
|  |  | ||||||
|  |   FTP Custom CUSTOMREQUEST | ||||||
|  |  | ||||||
|  |     If you do what list the contents of a FTP directory using your own defined | ||||||
|  |     FTP command, CURLOPT_CUSTOMREQUEST will do just that. "NLST" is the | ||||||
|  |     default one for listing directories but you're free to pass in your idea | ||||||
|  |     of a good alternative. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Cookies Without Chocolate Chips | ||||||
|  |  | ||||||
|  |  In the HTTP sense, a cookie is a name with an associated value. A server | ||||||
|  |  sends the name and value to the client, and expects it to get sent back on | ||||||
|  |  every subsequent request to the server that matches the particular conditions | ||||||
|  |  set. The conditions include that the domain name and path match and that the | ||||||
|  |  cookie hasn't become too old. | ||||||
|  |  | ||||||
|  |  In real-world cases, servers send new cookies to replace existing one to | ||||||
|  |  update them. Server use cookies to "track" users and to keep "sessions". | ||||||
|  |  | ||||||
|  |  Cookies are sent from server to clients with the header Set-Cookie: and | ||||||
|  |  they're sent from clients to servers with the Cookie: header. | ||||||
|  |  | ||||||
|  |  To just send whatever cookie you want to a server, you can use CURLOPT_COOKIE | ||||||
|  |  to set a cookie string like this: | ||||||
|  |  | ||||||
|  |     curl_easy_setopt(easyhandle, CURLOPT_COOKIE, "name1=var1; name2=var2;"); | ||||||
|  |  | ||||||
|  |  In many cases, that is not enough. You might want to dynamicly save whatever | ||||||
|  |  cookies the remote server passes to you, and make sure those cookies are then | ||||||
|  |  use accordingly on later requests. | ||||||
|  |  | ||||||
|  |  One way to do this, is to save all headers you receive in a plain file and | ||||||
|  |  when you make a request, you tell libcurl to read the previous headers to | ||||||
|  |  figure out which cookies to use. Set header file to read cookies from with | ||||||
|  |  CURLOPT_COOKIEFILE. | ||||||
|  |  | ||||||
|  |  The CURLOPT_COOKIEFILE option also automaticly enables the cookie parser in | ||||||
|  |  libcurl. Until the cookie parser is enabled, libcurl will not parse or | ||||||
|  |  understand incoming cookies and they will just be ignored. However, when the | ||||||
|  |  parser is enabled the cookies will be understood and the cookies will be kept | ||||||
|  |  in memory and used properly in subsequent requests when the same handle is | ||||||
|  |  used. Many times this is enough, and you may not have to save the cookies to | ||||||
|  |  disk at all. Note that the file you specify to CURLOPT_COOKIEFILE doesn't | ||||||
|  |  have to exist to enable the parser, so a common way to just enable the parser | ||||||
|  |  and not read able might be to use a file name you know doesn't exist. | ||||||
|  |  | ||||||
|  |  If you rather use existing cookies that you've previously received with your | ||||||
|  |  Netscape or Mozilla browsers, you can make libcurl use that cookie file as | ||||||
|  |  input. The CURLOPT_COOKIEFILE is used for that too, as libcurl will | ||||||
|  |  automaticly find out what kind of file it is and act accordingly. | ||||||
|  |  | ||||||
|  |  The perhaps most advanced cookie operation libcurl offers, is saving the | ||||||
|  |  entire internal cookie state back into a Netscape/Mozilla formatted cookie | ||||||
|  |  file. We call that the cookie-jar. When you set a file name with | ||||||
|  |  CURLOPT_COOKIEJAR, that file name will be created and all received cookies | ||||||
|  |  will be stored in it when curl_easy_cleanup() is called. This enabled cookies | ||||||
|  |  to get passed on properly between multiple handles without any information | ||||||
|  |  getting lost. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | FTP Peculiarities We Need | ||||||
|  |  | ||||||
|  |  FTP transfers use a second TCP/IP connection for the data transfer. This is | ||||||
|  |  usually a fact you can forget and ignore but at times this fact will come | ||||||
|  |  back to haunt you. libcurl offers several different ways to custom how the | ||||||
|  |  second connection is being made. | ||||||
|  |  | ||||||
|  |  libcurl can either connect to the server a second time or tell the server to | ||||||
|  |  connect back to it. The first option is the default and it is also what works | ||||||
|  |  best for all the people behind firewalls, NATs or IP-masquarading setups. | ||||||
|  |  libcurl then tells the server to open up a new port and wait for a second | ||||||
|  |  connection. This is by default attempted with EPSV first, and if that doesn't | ||||||
|  |  work it tries PASV instead. (EPSV is an extension to the original FTP spec | ||||||
|  |  and does not exist nor work on all FTP servers.) | ||||||
|  |  | ||||||
|  |  You can prevent libcurl from first trying the EPSV command by setting | ||||||
|  |  CURLOPT_FTP_USE_EPSV to FALSE. | ||||||
|  |  | ||||||
|  |  In some cases, you will prefer to have the server connect back to you for the | ||||||
|  |  second connection. This might be when the server is perhaps behind a firewall | ||||||
|  |  or something and only allows connections on a single port. libcurl then | ||||||
|  |  informs the remote server which IP address and port number to connect to. | ||||||
|  |  This is made with the CURLOPT_FTPPORT option. If you set it to "-", libcurl | ||||||
|  |  will use your system's "default IP address". If you want to use a particular | ||||||
|  |  IP, you can set the full IP address, a host name to resolve to an IP address | ||||||
|  |  or even a local network interface name that libcurl will get the IP address | ||||||
|  |  from. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Headers Equal Fun | ||||||
|  |  | ||||||
|  |  Some protocols provide "headers", meta-data separated from the normal | ||||||
|  |  data. These headers are by default not included in the normal data stream, | ||||||
|  |  but you can make them appear in the data stream by setting CURLOPT_HEADER to | ||||||
|  |  TRUE. | ||||||
|  |  | ||||||
|  |  What might be even more useful, is libcurl's ability to separate the headers | ||||||
|  |  from the data and thus make the callbacks differ. You can for example set a | ||||||
|  |  different pointer to pass to the ordinary write callback by setting | ||||||
|  |  CURLOPT_WRITEHEADER. | ||||||
|  |  | ||||||
|  |  Or, you can set an entirely separate function to receive the headers, by | ||||||
|  |  using CURLOPT_HEADERFUNCTION. | ||||||
|  |  | ||||||
|  |  The headers are passed to the callback function one by one, and you can | ||||||
|  |  depend on that fact. It makes it easier for you to add custom header parsers | ||||||
|  |  etc. | ||||||
|  |  | ||||||
|  |  "Headers" for FTP transfers equal all the FTP server responses. They aren't | ||||||
|  |  actually true headers, but in this case we pretend they are! ;-) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Post Transfer Information | ||||||
|  |  | ||||||
|  |  [ curl_easy_getinfo ] | ||||||
|  |  | ||||||
|  |  | ||||||
| Security Considerations | Security Considerations | ||||||
|  |  | ||||||
|  |  libcurl is in itself not insecure. If used the right way, you can use libcurl | ||||||
|  |  to transfer data pretty safely. | ||||||
|  |  | ||||||
| Certificates and Other SSL Tricks |  There are of course many things to consider that may loosen up this | ||||||
|  |  situation: | ||||||
|  |  | ||||||
|  |   Command Lines | ||||||
|  |  | ||||||
|  |     If you use a command line tool (such as curl) that uses libcurl, and you | ||||||
|  |     give option to the tool on the command line those options can very likely | ||||||
|  |     get read by other users of your system when they use 'ps' or other tools | ||||||
|  |     to list currently running processes. | ||||||
|  |  | ||||||
|  |     To avoid this problem, never feed sensitive things to programs using | ||||||
|  |     command line options. | ||||||
|  |  | ||||||
|  |   .netrc | ||||||
|  |  | ||||||
|  |     .netrc is a pretty handy file/feature that allows you to login quickly and | ||||||
|  |     automaticly to frequently visited sites. The file contains passwords in | ||||||
|  |     clear text and is a real security risk. In some cases, your .netrc is also | ||||||
|  |     stored in a home directory that is NFS mounted or used on another network | ||||||
|  |     based file system, so the clear text password will fly through your | ||||||
|  |     network every time anyone reads that file! | ||||||
|  |  | ||||||
|  |     To avoid this problem, don't use .netrc files and never store passwords in | ||||||
|  |     plain text anywhere. | ||||||
|  |  | ||||||
|  |   Clear Text Passwords | ||||||
|  |  | ||||||
|  |     Many of the protocols libcurl supports send name and password unencrypted | ||||||
|  |     as clear text (HTTP Basic authentication, FTP, TELNET etc). It is very | ||||||
|  |     easy for anyone on your network or a network nearby yours, to just fire up | ||||||
|  |     a network analyzer tool and evesdrop on your passwords. Don't let the fact | ||||||
|  |     that HTTP uses base64 encoded passwords fool you. They may not look | ||||||
|  |     readable at a first glance, but they very easily "deciphered" by anyone | ||||||
|  |     within seconds. | ||||||
|  |  | ||||||
|  |     To avoid this problem, use protocols that don't let snoopers see your | ||||||
|  |     password: HTTPS, FTPS and FTP-kerberos are a few examples. HTTP Digest | ||||||
|  |     authentication allows this too, but isn't supported by libcurl as of this | ||||||
|  |     writing. | ||||||
|  |  | ||||||
|  |   Showing What You Do | ||||||
|  |  | ||||||
|  |     On a related issue, be aware that even in situations like when you have | ||||||
|  |     problems with libcurl and ask somone for help, everything you reveal in | ||||||
|  |     order to get best possible help might also impose certain security related | ||||||
|  |     risks. Host names, user names, paths, operating system specifics etc (not | ||||||
|  |     to mention passwords of course) may in fact be used by intruders to gain | ||||||
|  |     additional information of a potential target. | ||||||
|  |  | ||||||
|  |     To avoid this problem, you must of course use your common sense. Often, | ||||||
|  |     you can just edit out the senstive data or just rearch/replace your true | ||||||
|  |     information with faked data. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | SSL, Certificates and Other Tricks | ||||||
|  |  | ||||||
|  |  [ seeding, passwords, keys, certificates, ENGINE, ca certs ] | ||||||
|  |  | ||||||
|  | Multiple Transfers Using the multi Interface | ||||||
|  |  | ||||||
|  |  The easy interface as described in detail in this document is a synchronous | ||||||
|  |  interface that transfers one file at a time and doesn't return until its | ||||||
|  |  done. | ||||||
|  |  | ||||||
|  |  The multi interface on the other hand, allows your program to transfer | ||||||
|  |  multiple files in both directions at the same time, without forcing you to | ||||||
|  |  use multiple threads. | ||||||
|  |  | ||||||
|  |  [fill in lots of more multi stuff here] | ||||||
|  |  | ||||||
| Future | Future | ||||||
|  |  | ||||||
|  |  [ sharing between handles, mutexes, pipelining ] | ||||||
|  |  | ||||||
|  |  | ||||||
| ----- | ----- | ||||||
| Footnotes: | Footnotes: | ||||||
|  |  | ||||||
| [1] = HTTP PUT without knowing the size prior to transfer is indeed possible, | [1] = libcurl 7.10.3 and later have the ability to switch over to chunked | ||||||
|       but libcurl does not support the chunked transfers on uploading that is |       Tranfer-Encoding in cases were HTTP uploads are done with data of an | ||||||
|       necessary for this feature to work. We'd gratefully appreciate patches |       unknown size. | ||||||
|       that bring this functionality... |  | ||||||
|  |  | ||||||
| [2] = This happens on Windows machines when libcurl is built and used as a | [2] = This happens on Windows machines when libcurl is built and used as a | ||||||
|       DLL. However, you can still do this on Windows if you link with a static |       DLL. However, you can still do this on Windows if you link with a static | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								docs/libcurl/.cvsignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								docs/libcurl/.cvsignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | Makefile | ||||||
|  | Makefile.in | ||||||
|  | *html | ||||||
|  | *ps | ||||||
|  | *pdf | ||||||
							
								
								
									
										132
									
								
								docs/libcurl/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										132
									
								
								docs/libcurl/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,132 @@ | |||||||
|  | # | ||||||
|  | # $Id$ | ||||||
|  | # | ||||||
|  |  | ||||||
|  | AUTOMAKE_OPTIONS = foreign no-dependencies | ||||||
|  |  | ||||||
|  | man_MANS = \ | ||||||
|  | 	curl_easy_cleanup.3 \ | ||||||
|  | 	curl_easy_getinfo.3 \ | ||||||
|  | 	curl_easy_init.3 \ | ||||||
|  | 	curl_easy_perform.3 \ | ||||||
|  | 	curl_easy_setopt.3 \ | ||||||
|  | 	curl_easy_duphandle.3 \ | ||||||
|  | 	curl_formparse.3 \ | ||||||
|  | 	curl_formadd.3 \ | ||||||
|  | 	curl_formfree.3 \ | ||||||
|  | 	curl_getdate.3 \ | ||||||
|  | 	curl_getenv.3 \ | ||||||
|  | 	curl_slist_append.3 \ | ||||||
|  | 	curl_slist_free_all.3 \ | ||||||
|  | 	curl_version.3 \ | ||||||
|  | 	curl_version_info.3 \ | ||||||
|  | 	curl_escape.3 \ | ||||||
|  | 	curl_unescape.3 \ | ||||||
|  | 	curl_free.3 \ | ||||||
|  | 	curl_strequal.3 \ | ||||||
|  | 	curl_strnequal.3 \ | ||||||
|  | 	curl_mprintf.3 \ | ||||||
|  | 	curl_global_init.3 \ | ||||||
|  | 	curl_global_cleanup.3 \ | ||||||
|  | 	libcurl.3 \ | ||||||
|  | 	curl_multi_add_handle.3 \ | ||||||
|  | 	curl_multi_cleanup.3 \ | ||||||
|  | 	curl_multi_fdset.3 \ | ||||||
|  | 	curl_multi_info_read.3 \ | ||||||
|  | 	curl_multi_init.3 \ | ||||||
|  | 	curl_multi_perform.3 \ | ||||||
|  | 	curl_multi_remove_handle.3 \ | ||||||
|  | 	libcurl-multi.3 \ | ||||||
|  | 	libcurl-errors.3 | ||||||
|  |  | ||||||
|  | HTMLPAGES = \ | ||||||
|  | 	curl_easy_cleanup.html \ | ||||||
|  | 	curl_easy_getinfo.html \ | ||||||
|  | 	curl_easy_init.html \ | ||||||
|  | 	curl_easy_perform.html \ | ||||||
|  | 	curl_easy_setopt.html \ | ||||||
|  | 	curl_easy_duphandle.html \ | ||||||
|  | 	curl_formadd.html \ | ||||||
|  | 	curl_formparse.html \ | ||||||
|  | 	curl_formfree.html \ | ||||||
|  | 	curl_getdate.html \ | ||||||
|  | 	curl_getenv.html \ | ||||||
|  | 	curl_slist_append.html \ | ||||||
|  | 	curl_slist_free_all.html \ | ||||||
|  | 	curl_version.html \ | ||||||
|  | 	curl_version_info.html \ | ||||||
|  | 	curl_escape.html \ | ||||||
|  | 	curl_unescape.html \ | ||||||
|  | 	curl_free.html \ | ||||||
|  | 	curl_strequal.html \ | ||||||
|  | 	curl_strnequal.html \ | ||||||
|  | 	curl_mprintf.html \ | ||||||
|  | 	curl_global_init.html \ | ||||||
|  | 	curl_global_cleanup.html \ | ||||||
|  | 	libcurl.html \ | ||||||
|  | 	curl_multi_add_handle.html \ | ||||||
|  | 	curl_multi_cleanup.html \ | ||||||
|  | 	curl_multi_fdset.html \ | ||||||
|  | 	curl_multi_info_read.html \ | ||||||
|  | 	curl_multi_init.html \ | ||||||
|  | 	curl_multi_perform.html \ | ||||||
|  | 	curl_multi_remove_handle.html \ | ||||||
|  | 	libcurl-multi.html \ | ||||||
|  | 	libcurl-errors.html \ | ||||||
|  | 	index.html | ||||||
|  |  | ||||||
|  | PDFPAGES = \ | ||||||
|  | 	curl_easy_cleanup.pdf \ | ||||||
|  | 	curl_easy_getinfo.pdf \ | ||||||
|  | 	curl_easy_init.pdf \ | ||||||
|  | 	curl_easy_perform.pdf \ | ||||||
|  | 	curl_easy_setopt.pdf \ | ||||||
|  | 	curl_easy_duphandle.pdf \ | ||||||
|  | 	curl_formadd.pdf \ | ||||||
|  | 	curl_formparse.pdf \ | ||||||
|  | 	curl_formfree.pdf \ | ||||||
|  | 	curl_getdate.pdf \ | ||||||
|  | 	curl_getenv.pdf \ | ||||||
|  | 	curl_slist_append.pdf \ | ||||||
|  | 	curl_slist_free_all.pdf \ | ||||||
|  | 	curl_version.pdf \ | ||||||
|  | 	curl_version_info.pdf \ | ||||||
|  | 	curl_escape.pdf \ | ||||||
|  | 	curl_unescape.pdf \ | ||||||
|  | 	curl_free.pdf \ | ||||||
|  | 	curl_strequal.pdf \ | ||||||
|  | 	curl_strnequal.pdf \ | ||||||
|  | 	curl_mprintf.pdf \ | ||||||
|  | 	curl_global_init.pdf \ | ||||||
|  | 	curl_global_cleanup.pdf \ | ||||||
|  | 	libcurl.pdf \ | ||||||
|  | 	curl_multi_add_handle.pdf \ | ||||||
|  | 	curl_multi_cleanup.pdf \ | ||||||
|  | 	curl_multi_fdset.pdf \ | ||||||
|  | 	curl_multi_info_read.pdf \ | ||||||
|  | 	curl_multi_init.pdf \ | ||||||
|  | 	curl_multi_perform.pdf \ | ||||||
|  | 	curl_multi_remove_handle.pdf \ | ||||||
|  | 	libcurl-multi.pdf \ | ||||||
|  | 	libcurl-errors.pdf | ||||||
|  |  | ||||||
|  | EXTRA_DIST = $(man_MANS) $(HTMLPAGES) $(PDFPAGES) | ||||||
|  |  | ||||||
|  | MAN2HTML= gnroff -man $< | man2html >$@ | ||||||
|  |  | ||||||
|  | SUFFIXES = .1 .3 .html | ||||||
|  |  | ||||||
|  | html: $(HTMLPAGES) | ||||||
|  |  | ||||||
|  | .3.html: | ||||||
|  | 	$(MAN2HTML) | ||||||
|  |  | ||||||
|  | .1.html: | ||||||
|  | 	$(MAN2HTML) | ||||||
|  |  | ||||||
|  | pdf: | ||||||
|  | 	for file in $(man_MANS); do \ | ||||||
|  | 	  foo=`echo $$file | sed -e 's/\.[0-9]$$//g'`; \ | ||||||
|  | 	  groff -Tps -man $$file >$$foo.ps; \ | ||||||
|  | 	  ps2pdf $$foo.ps $$foo.pdf; \ | ||||||
|  | 	done | ||||||
							
								
								
									
										28
									
								
								docs/libcurl/curl_easy_cleanup.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								docs/libcurl/curl_easy_cleanup.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_easy_cleanup 3 "13 Nov 2002" "libcurl 7.7" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_easy_cleanup - End a libcurl easy session | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "void curl_easy_cleanup(CURL *" handle ");" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | This function must be the last function to call for an easy session. It is the | ||||||
|  | opposite of the \fIcurl_easy_init\fP function and must be called with the same | ||||||
|  | \fIhandle\fP as input that the curl_easy_init call returned. | ||||||
|  |  | ||||||
|  | This will effectively close all connections this handle has used and possibly | ||||||
|  | has kept open until now. Don't call this function if you intend to transfer | ||||||
|  | more files. | ||||||
|  |  | ||||||
|  | When you've called this, you can safely remove all the strings you've | ||||||
|  | previously told libcurl to use, as it won't use them anymore now. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | None | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_easy_init "(3), " | ||||||
|  |  | ||||||
| @@ -2,7 +2,7 @@ | |||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_easy_init 3 "5 March 2001" "libcurl 7.6.1" "libcurl Manual" | .TH curl_easy_init 3 "25 Apr 2002" "libcurl 7.9.7" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_getinfo - Extract information from a curl session (added in 7.4) | curl_easy_getinfo - Extract information from a curl session (added in 7.4) | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| @@ -30,13 +30,17 @@ Pass a pointer to a long to receive the last received HTTP code. | |||||||
| .TP | .TP | ||||||
| .B CURLINFO_FILETIME | .B CURLINFO_FILETIME | ||||||
| Pass a pointer to a long to receive the remote time of the retrieved | Pass a pointer to a long to receive the remote time of the retrieved | ||||||
| document. If you get 0, it can be because of many reasons (unknown, the server | document. If you get -1, it can be because of many reasons (unknown, the | ||||||
| hides it or the server doesn't support the command that tells document time | server hides it or the server doesn't support the command that tells document | ||||||
| etc) and the time of the document is unknown. (Added in 7.5) | time etc) and the time of the document is unknown. Note that you must tell the | ||||||
|  | server to collect this information before the transfer is made, by using the | ||||||
|  | CURLOPT_FILETIME option to \fIcurl_easy_setopt(3)\fP. (Added in 7.5) | ||||||
| .TP | .TP | ||||||
| .B CURLINFO_TOTAL_TIME | .B CURLINFO_TOTAL_TIME | ||||||
| Pass a pointer to a double to receive the total transaction time in seconds | Pass a pointer to a double to receive the total transaction time in seconds | ||||||
| for the previous transfer. | for the previous transfer. This time does not include the connect time, so if | ||||||
|  | you want the complete operation time, you should add the | ||||||
|  | CURLINFO_CONNECT_TIME. | ||||||
| .TP | .TP | ||||||
| .B CURLINFO_NAMELOOKUP_TIME | .B CURLINFO_NAMELOOKUP_TIME | ||||||
| Pass a pointer to a double to receive the time, in seconds, it took from the | Pass a pointer to a double to receive the time, in seconds, it took from the | ||||||
| @@ -58,13 +62,24 @@ start until the first byte is just about to be transfered. This includes | |||||||
| CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate | CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate | ||||||
| the result. | the result. | ||||||
| .TP | .TP | ||||||
|  | .B CURLINFO_REDIRECT_TIME | ||||||
|  | Pass a pointer to a double to receive the total time, in seconds, it took for | ||||||
|  | all redirection steps include name lookup, connect, pretransfer and transfer | ||||||
|  | before final transaction was started. CURLINFO_REDIRECT_TIME contains the | ||||||
|  | complete execution time for multiple redirections.  (Added in 7.9.7) | ||||||
|  | .TP | ||||||
|  | .B CURLINFO_REDIRECT_COUNT | ||||||
|  | Pass a pointer to a long to receive the total number of redirections that were | ||||||
|  | actually followed.  (Added in 7.9.7) | ||||||
|  | .TP | ||||||
| .B CURLINFO_SIZE_UPLOAD | .B CURLINFO_SIZE_UPLOAD | ||||||
| Pass a pointer to a double to receive the total amount of bytes that were | Pass a pointer to a double to receive the total amount of bytes that were | ||||||
| uploaded. | uploaded. | ||||||
| .TP | .TP | ||||||
| .B CURLINFO_SIZE_DOWNLOAD | .B CURLINFO_SIZE_DOWNLOAD | ||||||
| Pass a pointer to a double to receive the total amount of bytes that were | Pass a pointer to a double to receive the total amount of bytes that were | ||||||
| downloaded. | downloaded. The amount is only for the latest transfer and will be reset again | ||||||
|  | for each new transfer. | ||||||
| .TP | .TP | ||||||
| .B CURLINFO_SPEED_DOWNLOAD | .B CURLINFO_SPEED_DOWNLOAD | ||||||
| Pass a pointer to a double to receive the average download speed that curl | Pass a pointer to a double to receive the average download speed that curl | ||||||
| @@ -95,8 +110,18 @@ is the value read from the Content-Length: field.  (Added in 7.6.1) | |||||||
| .B CURLINFO_CONTENT_LENGTH_UPLOAD | .B CURLINFO_CONTENT_LENGTH_UPLOAD | ||||||
| Pass a pointer to a double to receive the specified size of the upload. | Pass a pointer to a double to receive the specified size of the upload. | ||||||
| (Added in 7.6.1) | (Added in 7.6.1) | ||||||
|  | .TP | ||||||
|  | .B CURLINFO_CONTENT_TYPE | ||||||
|  | Pass a pointer to a 'char *' to receive the content-type of the downloaded | ||||||
|  | object. This is the value read from the Content-Type: field. If you get NULL, | ||||||
|  | it means that the server didn't send a valid Content-Type header or that the | ||||||
|  | protocol used doesn't support this.  (Added in 7.9.4) | ||||||
|  | .TP | ||||||
|  | .B CURLINFO_PRIVATE | ||||||
|  | Pass a pointer to a 'char *' to receive the pointer to the private data | ||||||
|  | associated with the curl handle (set with the CURLOPT_PRIVATE option to curl_easy_setopt). | ||||||
|  | (Added in 7.10.3) | ||||||
| .PP | .PP | ||||||
| 
 |  | ||||||
| .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. | ||||||
							
								
								
									
										25
									
								
								docs/libcurl/curl_easy_init.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								docs/libcurl/curl_easy_init.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_easy_init 3 "4 March 2002" "libcurl 7.8.1" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_easy_init - Start a libcurl easy session | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "CURL *curl_easy_init( );" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | This function must be the first function to call, and it returns a CURL easy | ||||||
|  | handle that you must use as input to other easy-functions. curl_easy_init | ||||||
|  | intializes curl and this call MUST have a corresponding call to | ||||||
|  | \fIcurl_easy_cleanup\fP when the operation is complete. | ||||||
|  |  | ||||||
|  | .SH RETURN VALUE | ||||||
|  | If this function returns NULL, something went wrong and you cannot use the | ||||||
|  | other curl functions. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_easy_cleanup "(3), " curl_global_init "(3) | ||||||
|  | .SH BUGS | ||||||
|  | Surely there are some, you tell me! | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,28 +1,26 @@ | |||||||
| .\" You can view this file with: | .\" You can view this file with: | ||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_escape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | .TH curl_escape 3 "6 March 2002" "libcurl 7.9" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_escape - URL encodes the given string | curl_escape - URL encodes the given string | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "char *curl_escape( char *" url ", int "length " );" | .BI "char *curl_escape( char *" url ", int "length " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function will convert the given input string to an URL encoded string and | This function will convert the given input string to an URL encoded string and | ||||||
| return that as a new allocated string. All input characters that are not a-z, | return that as a new allocated string. All input characters that are not a-z, | ||||||
| A-Z or 0-9 will be converted to their "URL escaped" version. If a sequence of | A-Z or 0-9 will be converted to their "URL escaped" version (%NN where NN is a | ||||||
| %NN (where NN is a two-digit hexadecimal number) is found in the string to | two-digit hexadecimal number). | ||||||
| encode, that 3-letter combination will be copied to the output unmodifed, | 
 | ||||||
| assuming that it is an already encoded piece of data. | If the 'length' argument is set to 0, curl_escape() will use strlen() on the | ||||||
| 
 | input 'url' string to find out the size. | ||||||
| If the 'length' argument is set to 0, curl_escape() will use strlen() on the | 
 | ||||||
| input 'url' string to find out the size. | You must curl_free() the returned string when you're done with it. | ||||||
| 
 | .SH RETURN VALUE | ||||||
| You must free() the returned string when you're done with it. | A pointer to a zero terminated string or NULL if it failed. | ||||||
| .SH RETURN VALUE | .SH "SEE ALSO" | ||||||
| A pointer to a zero terminated string or NULL if it failed. | .I curl_unescape(), curl_free(), RFC 2396 | ||||||
| .SH "SEE ALSO" |  | ||||||
| .I curl_unescape(), RFC 2396 |  | ||||||
							
								
								
									
										212
									
								
								docs/libcurl/curl_formadd.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										212
									
								
								docs/libcurl/curl_formadd.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,212 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_formadd 3 "24 June 2002" "libcurl 7.9.8" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_formadd - add a section to a multipart/formdata HTTP POST | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "CURLFORMcode curl_formadd(struct HttpPost ** " firstitem, | ||||||
|  | .BI "struct HttpPost ** " lastitem, " ...);" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | curl_formadd() is used to append sections when building a multipart/formdata | ||||||
|  | HTTP POST (sometimes refered to as rfc1867-style posts). Append one section at | ||||||
|  | a time until you've added all the sections you want included and then you pass | ||||||
|  | the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. | ||||||
|  | \fIlastitem\fP is set after each call and on repeated invokes it should be | ||||||
|  | left as set to allow repeated invokes to find the end of the list faster. | ||||||
|  |  | ||||||
|  | After the \fIlastitem\fP pointer follow the real arguments. | ||||||
|  |  | ||||||
|  | The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to | ||||||
|  | NULL in the first call to this function. All list-data will be allocated by | ||||||
|  | the function itself. You must call \fIcurl_formfree\fP after the form post has | ||||||
|  | been done to free the resources again. | ||||||
|  |  | ||||||
|  | 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 | ||||||
|  | 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 | ||||||
|  | properties in the parts you want to add to your post. | ||||||
|  | .SH OPTIONS | ||||||
|  | .B CURLFORM_COPYNAME | ||||||
|  | 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 | ||||||
|  | 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 | ||||||
|  | \fBCURLFORM_NAMELENGTH\fP. | ||||||
|  |  | ||||||
|  | .B CURLFORM_PTRNAME | ||||||
|  | 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 | ||||||
|  | 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 | ||||||
|  | length of the name with \fBCURLFORM_NAMELENGTH\fP. | ||||||
|  |  | ||||||
|  | .B CURLFORM_COPYCONTENTS | ||||||
|  | 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 | ||||||
|  | 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 | ||||||
|  | length of the name with \fBCURLFORM_CONTENTSLENGTH\fP. | ||||||
|  |  | ||||||
|  | .B CURLFORM_PTRCONTENTS | ||||||
|  | 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 | ||||||
|  | application, you must make sure it remains until curl no longer needs it. If | ||||||
|  | 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 | ||||||
|  | \fBCURLFORM_CONTENTSLENGTH\fP. | ||||||
|  |  | ||||||
|  | .B CURLFORM_FILECONTENT | ||||||
|  | followed by a file name, makes that file read and the contents will be used in | ||||||
|  | as data in this part. | ||||||
|  |  | ||||||
|  | .B CURLFORM_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 | ||||||
|  | and passes as data and sets the content-type if the given file match one of | ||||||
|  | the new internally known file extension.  For \fBCURLFORM_FILE\fP the user may | ||||||
|  | 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 | ||||||
|  | have a CURLFORM_CONTENTTYPE). | ||||||
|  |  | ||||||
|  | .B CURLFORM_CONTENTTYPE | ||||||
|  | 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 | ||||||
|  | internally chosen one. | ||||||
|  |  | ||||||
|  | .B CURLFORM_FILENAME | ||||||
|  | followed by a pointer to a string to a name, will make libcurl use the given | ||||||
|  | name in the file upload part, intead of the actual file name given to | ||||||
|  | \fICURLFORM_FILE\fP. | ||||||
|  |  | ||||||
|  | .B BCURLFORM_BUFFER | ||||||
|  | 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 | ||||||
|  | name field in the content header. | ||||||
|  |  | ||||||
|  | .B CURLFORM_BUFFERPTR | ||||||
|  | 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 | ||||||
|  | buffer containing this data must not be freed until after curl_easy_cleanup is | ||||||
|  | called. | ||||||
|  |  | ||||||
|  | .B CURLFORM_BUFFERLENGTH | ||||||
|  | followed by a long with the size of the \fICURLFORM_BUFFERPTR\fP data area, | ||||||
|  | tells libcurl the length of the buffer to upload. | ||||||
|  |  | ||||||
|  | .B CURLFORM_ARRAY | ||||||
|  | Another possibility to send options to curl_formadd() is the | ||||||
|  | \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 | ||||||
|  | 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 | ||||||
|  | last argument in such an array must always be \fBCURLFORM_END\fP. | ||||||
|  |  | ||||||
|  | .B CURLFORM_CONTENTHEADER | ||||||
|  | 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 | ||||||
|  | of headers to those libcurl automatically generates. The list must exist while | ||||||
|  | the POST occurs, if you free it before the post completes you may experience | ||||||
|  | problems. | ||||||
|  |  | ||||||
|  | When you've passed the HttpPost pointer to \fIcurl_easy_setopt\fP (using the | ||||||
|  | \fICURLOPT_HTTPPOST\fP option), you must not free the list until after you've | ||||||
|  | called \fIcurl_easy_cleanup\fP for the curl handle. | ||||||
|  |  | ||||||
|  | See example below. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | 0 means everything was ok, non-zero means an error occurred as | ||||||
|  | .I <curl/curl.h> | ||||||
|  | defines. | ||||||
|  | .SH EXAMPLE | ||||||
|  | .nf | ||||||
|  |  | ||||||
|  |  struct HttpPost* post = NULL; | ||||||
|  |  struct HttpPost* last = NULL; | ||||||
|  |  char namebuffer[] = "name buffer"; | ||||||
|  |  long namelength = strlen(namebuffer); | ||||||
|  |  char buffer[] = "test buffer"; | ||||||
|  |  char htmlbuffer[] = "<HTML>test buffer</HTML>"; | ||||||
|  |  long htmlbufferlength = strlen(htmlbuffer); | ||||||
|  |  struct curl_forms forms[3]; | ||||||
|  |  char file1[] = "my-face.jpg"; | ||||||
|  |  char file2[] = "your-face.jpg"; | ||||||
|  |  /* add null character into htmlbuffer, to demonstrate that | ||||||
|  |     transfers of buffers containing null characters actually work | ||||||
|  |  */ | ||||||
|  |  htmlbuffer[8] = '\\0'; | ||||||
|  |  | ||||||
|  |  /* Add simple name/content section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "name", | ||||||
|  |               CURLFORM_COPYCONTENTS, "content", CURLFORM_END);  | ||||||
|  |  | ||||||
|  |  /* Add simple name/content/contenttype section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "htmlcode", | ||||||
|  |               CURLFORM_COPYCONTENTS, "<HTML></HTML>", | ||||||
|  |               CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add name/ptrcontent section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "name_for_ptrcontent", | ||||||
|  |               CURLFORM_PTRCONTENTS, buffer, CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add ptrname/ptrcontent section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_PTRNAME, namebuffer, | ||||||
|  | 	      CURLFORM_PTRCONTENTS, buffer, CURLFORM_NAMELENGTH, | ||||||
|  | 	      namelength, CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add name/ptrcontent/contenttype section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "html_code_with_hole", | ||||||
|  |               CURLFORM_PTRCONTENTS, htmlbuffer, | ||||||
|  |               CURLFORM_CONTENTSLENGTH, htmlbufferlength, | ||||||
|  |               CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add simple file section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture", | ||||||
|  |               CURLFORM_FILE, "my-face.jpg", CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add file/contenttype section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture", | ||||||
|  |               CURLFORM_FILE, "my-face.jpg", | ||||||
|  |               CURLFORM_CONTENTTYPE, "image/jpeg", CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add two file section */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures", | ||||||
|  |               CURLFORM_FILE, "my-face.jpg", | ||||||
|  |               CURLFORM_FILE, "your-face.jpg", CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* Add two file section using CURLFORM_ARRAY */ | ||||||
|  |  forms[0].option = CURLFORM_FILE; | ||||||
|  |  forms[0].value  = file1; | ||||||
|  |  forms[1].option = CURLFORM_FILE; | ||||||
|  |  forms[1].value  = file2; | ||||||
|  |  forms[2].option  = CURLFORM_END; | ||||||
|  |  | ||||||
|  |  /* Add a buffer to upload */ | ||||||
|  |  curl_formadd(&post, &last, | ||||||
|  |               CURLFORM_COPYNAME, "name", | ||||||
|  |               CURLFORM_BUFFER, "data", | ||||||
|  |               CURLFORM_BUFFERPTR, record, | ||||||
|  |               CURLFORM_BUFFERLENGTH, record_length, | ||||||
|  |               CURLFORM_END); | ||||||
|  |  | ||||||
|  |  /* no option needed for the end marker */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures", | ||||||
|  |               CURLFORM_ARRAY, forms, CURLFORM_END); | ||||||
|  |  /* Add the content of a file as a normal post text value */ | ||||||
|  |  curl_formadd(&post, &last, CURLFORM_COPYNAME, "filecontent", | ||||||
|  |               CURLFORM_FILECONTENT, ".bashrc", CURLFORM_END); | ||||||
|  |  /* Set the form info */ | ||||||
|  |  curl_easy_setopt(curl, CURLOPT_HTTPPOST, post); | ||||||
|  |  | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_easy_setopt "(3), " | ||||||
|  | .BR curl_formparse "(3) [deprecated], " | ||||||
|  | .BR curl_formfree "(3)" | ||||||
|  | .SH BUGS | ||||||
|  | Surely there are some, you tell me! | ||||||
|  |  | ||||||
							
								
								
									
										17
									
								
								docs/libcurl/curl_free.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								docs/libcurl/curl_free.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id:  | ||||||
|  | .\" | ||||||
|  | .TH curl_free 3 "24 Sept 2002" "libcurl 7.10" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_free - reclaim memory that has been obtained through a libcurl call | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "void *curl_free( char *" ptr " );" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | curl_free reclaims memory that has been obtained through a libcurl call.  | ||||||
|  | Use curl_free() instead of free() to avoid anomalies that can result from differences in memory management between your application and libcurl. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .I curl_unescape(), curl_free() | ||||||
							
								
								
									
										20
									
								
								docs/libcurl/curl_multi_add_handle.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								docs/libcurl/curl_multi_add_handle.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_add_handle 3 "4 March 2002" "libcurl 7.9.5" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_add_handle - add an easy handle to a multi session | ||||||
|  | .SH SYNOPSIS | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | CURLMcode curl_multi_add_handle(CURLM *multi_handle, CURL *easy_handle); | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | Adds a standard easy handle to the multi stack. This will make this multi | ||||||
|  | handle control the specified easy handle. | ||||||
|  |  | ||||||
|  | When an easy handle has been added to a multi stack, you can not and you must | ||||||
|  | not use curl_easy_perform() on that handle! | ||||||
|  | .SH RETURN VALUE | ||||||
|  | CURLMcode type, general libcurl multi interface error code. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_cleanup "(3)," curl_multi_init "(3)" | ||||||
							
								
								
									
										18
									
								
								docs/libcurl/curl_multi_cleanup.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								docs/libcurl/curl_multi_cleanup.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_cleanup 3 "1 March 2002" "libcurl 7.9.5" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_cleanup - close down a multi session | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "CURLMcode curl_multi_cleanup( CURLM *multi_handle );" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | Cleans up and removes a whole multi stack. It does not free or touch any | ||||||
|  | individual easy handles in any way - they still need to be closed | ||||||
|  | individually, using the usual curl_easy_cleanup() way. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | CURLMcode type, general libcurl multi interface error code. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_init "(3)," curl_easy_cleanup "(3)," curl_easy_init "(3)" | ||||||
							
								
								
									
										27
									
								
								docs/libcurl/curl_multi_fdset.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								docs/libcurl/curl_multi_fdset.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_fdset 3 "3 May 2002" "libcurl 7.9.5" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_fdset - extracts file descriptor information from a multi handle | ||||||
|  | .SH SYNOPSIS | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | CURLMcode curl_multi_fdset(CURLM *multi_handle, | ||||||
|  |                            fd_set *read_fd_set, | ||||||
|  |                            fd_set *write_fd_set, | ||||||
|  |                            fd_set *exc_fd_set, | ||||||
|  |                            int *max_fd); | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | This function extracts file descriptor information from a given multi_handle. | ||||||
|  | libcurl returns its fd_set sets. The application can use these to select() or | ||||||
|  | poll() on. The curl_multi_perform() function should be called as soon as one | ||||||
|  | of them are ready to be read from or written to. | ||||||
|  |  | ||||||
|  | NOTE that once this call is made, you must not remove the sets you point to, | ||||||
|  | as libcurl will need to be able to read them. It needs them after select() | ||||||
|  | calls, to know if certain sockets are readable or writable. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | CURLMcode type, general libcurl multi interface error code. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_cleanup "(3)," curl_multi_init "(3)" | ||||||
							
								
								
									
										44
									
								
								docs/libcurl/curl_multi_info_read.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								docs/libcurl/curl_multi_info_read.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_info_read 3 "27 Feb 2002" "libcurl 7.10.3" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_info_read - read multi stack informationals | ||||||
|  | .SH SYNOPSIS | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | CURLMsg *curl_multi_info_read( CURLM *multi_handle, | ||||||
|  |                                int *msgs_in_queue); | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | Ask the multi handle if there are any messages/informationals from the | ||||||
|  | individual transfers. Messages may include informationals such as an error | ||||||
|  | code from the transfer or just the fact that a transfer is completed. More | ||||||
|  | details on these should be written down as well. | ||||||
|  |  | ||||||
|  | Repeated calls to this function will return a new struct each time, until a | ||||||
|  | NULL is returned as a signal that there is no more to get at this point. The | ||||||
|  | integer pointed to with \fImsgs_in_queue\fP will contain the number of | ||||||
|  | remaining messages after this function was called. | ||||||
|  |  | ||||||
|  | The data the returned pointer points to will not survive calling | ||||||
|  | curl_multi_cleanup(). | ||||||
|  |  | ||||||
|  | The 'CURLMsg' struct is very simple and only contain very basic informations. | ||||||
|  | If more involved information is wanted, the particular "easy handle" in | ||||||
|  | present in that struct and can thus be used in subsequent regular | ||||||
|  | curl_easy_getinfo() calls (or similar): | ||||||
|  |  | ||||||
|  |  struct CURLMsg { | ||||||
|  |    CURLMSG msg;       /* what this message means */ | ||||||
|  |    CURL *easy_handle; /* the handle it concerns */ | ||||||
|  |    union { | ||||||
|  |      void *whatever;    /* message-specific data */ | ||||||
|  |      CURLcode result;   /* return code for transfer */ | ||||||
|  |    } data; | ||||||
|  |  }; | ||||||
|  | .SH "RETURN VALUE" | ||||||
|  | A pointer to a filled-in struct, or NULL if it failed or ran out of | ||||||
|  | structs. It also writes the number of messages left in the queue (after this | ||||||
|  | read) in the integer the second argument points to. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_cleanup "(3), " curl_multi_init "(3), " curl_multi_perform "(3)" | ||||||
							
								
								
									
										22
									
								
								docs/libcurl/curl_multi_init.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								docs/libcurl/curl_multi_init.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_init 3 "1 March 2002" "libcurl 7.9.5" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_init - Start a multi session | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "CURLM *curl_multi_init( );" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | This function returns a CURLM handle to be used as input to all the other | ||||||
|  | multi-functions, sometimes refered to as a multi handle on some places in the | ||||||
|  | documentation. This init call MUST have a corresponding call to | ||||||
|  | \fIcurl_multi_cleanup\fP when the operation is complete. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | If this function returns NULL, something went wrong and you cannot use the | ||||||
|  | other curl functions. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_cleanup "(3)," curl_global_init "(3)," curl_easy_init "(3)" | ||||||
|  | .SH BUGS | ||||||
|  | Surely there are some, you tell me! | ||||||
							
								
								
									
										36
									
								
								docs/libcurl/curl_multi_perform.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								docs/libcurl/curl_multi_perform.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_perform 3 "1 March 2002" "libcurl 7.9.5" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_perform - reads/writes available data from each easy handle | ||||||
|  | .SH SYNOPSIS | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | CURLMcode curl_multi_perform(CURLM *multi_handle, int *running_handles); | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | When the app thinks there's data available for the multi_handle, it should | ||||||
|  | call this function to read/write whatever there is to read or write right | ||||||
|  | now. curl_multi_perform() returns as soon as the reads/writes are done. This | ||||||
|  | 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 | ||||||
|  | write the number of handles that still transfer data in the second argument's | ||||||
|  | integer-pointer. | ||||||
|  | .SH "RETURN VALUE" | ||||||
|  | CURLMcode type, general libcurl multi interface error code. | ||||||
|  |  | ||||||
|  | If you receive \fICURLM_CALL_MULTI_PERFORM\fP, this basicly means that you | ||||||
|  | should call \fIcurl_multi_perform\fP again, before you select() on more | ||||||
|  | actions. You don't have to do it immediately, but the return code means that | ||||||
|  | libcurl may have more data available to return or that there may be more data | ||||||
|  | to send off before it is "satisfied". | ||||||
|  |  | ||||||
|  | NOTE that this only returns errors etc regarding the whole multi stack. There | ||||||
|  | might still have occurred problems on invidual transfers even when this | ||||||
|  | function returns OK. | ||||||
|  | .SH "TYPICAL USAGE" | ||||||
|  | Most application will use \fIcurl_multi_fdset\fP to get the multi_handle's | ||||||
|  | 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\fP gets called. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_cleanup "(3)," curl_multi_init "(3)" | ||||||
							
								
								
									
										23
									
								
								docs/libcurl/curl_multi_remove_handle.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								docs/libcurl/curl_multi_remove_handle.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_multi_remove_handle 3 "6 March 2002" "libcurl 7.9.5" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_multi_remove_handle - remove an easy handle from a multi session | ||||||
|  | .SH SYNOPSIS | ||||||
|  | #include <curl/curl.h> | ||||||
|  |  | ||||||
|  | CURLMcode curl_multi_remove_handle(CURLM *multi_handle, CURL *easy_handle); | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | Removes a given easy_handle from the multi_handle. This will make the | ||||||
|  | specified easy handle be removed from this multi handle's control. | ||||||
|  |  | ||||||
|  | When the easy handle has been removed from a multi stack, it is again | ||||||
|  | perfectly legal to invoke \fIcurl_easy_perform()\fP on this easy handle. | ||||||
|  |  | ||||||
|  | Removing a handle while being used, will effectively halt all transfers in | ||||||
|  | progress. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | CURLMcode type, general libcurl multi interface error code. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_multi_cleanup "(3)," curl_multi_init "(3)" | ||||||
							
								
								
									
										38
									
								
								docs/libcurl/curl_slist_append.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								docs/libcurl/curl_slist_append.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_slist_append 3 "21 Feb 2003" "libcurl 7.10.4" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_slist_append - add a string to an slist | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "struct curl_slist *curl_slist_append(struct curl_slist *" list, | ||||||
|  | .BI "const char * "string ");" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | curl_slist_append() appends a specified string to a linked list of | ||||||
|  | strings. The existing \fIlist\fP should be passed as the first argument while | ||||||
|  | the new list is returned from this function. The specified \fIstring\fP has | ||||||
|  | been appended when this function returns. | ||||||
|  |  | ||||||
|  | The list should be freed again (after usage) with \fBcurl_slist_free_all()\fP. | ||||||
|  | .SH RETURN VALUE | ||||||
|  | A null pointer is returned if anything went wrong, otherwise the new list | ||||||
|  | pointer is returned. | ||||||
|  | .SH EXAMPLE | ||||||
|  |  CURL handle; | ||||||
|  |  curl_slist *slist=NULL; | ||||||
|  |  | ||||||
|  |  slist = curl_slist_append(slist, "pragma:"); | ||||||
|  |  curl_easy_setopt(handle, CURLOPT_HTTPHEADER, slist); | ||||||
|  |  | ||||||
|  |  curl_easy_perform(handle); | ||||||
|  |  | ||||||
|  |  curl_slist_free_all(slist); /* free the list again */ | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | .BR curl_slist_free_all "(3), " | ||||||
|  | .SH BUGS | ||||||
|  | None. | ||||||
|  |  | ||||||
| @@ -1,27 +1,27 @@ | |||||||
| .\" You can view this file with: | .\" You can view this file with: | ||||||
| .\" nroff -man [file] | .\" nroff -man [file] | ||||||
| .\" $Id$ | .\" $Id$ | ||||||
| .\" | .\" | ||||||
| .TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | .TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | ||||||
| .SH NAME | .SH NAME | ||||||
| curl_unescape - URL decodes the given string | curl_unescape - URL decodes the given string | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp | .sp | ||||||
| .BI "char *curl_unescape( char *" url ", int "length " );" | .BI "char *curl_unescape( char *" url ", int "length " );" | ||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function will convert the given URL encoded input string to a "plain | This function will convert the given URL encoded input string to a "plain | ||||||
| string" and return that as a new allocated string. All input characters that | string" and return that as a new allocated string. All input characters that | ||||||
| are URL encoded (%XX where XX is a two-digit hexadecimal number, or +) will be | are URL encoded (%XX where XX is a two-digit hexadecimal number, or +) will be | ||||||
| converted to their plain text versions (up to a ? letter, no letters to the | converted to their plain text versions (up to a ? letter, no + letters to the | ||||||
| right of a ? letter will be converted). | right of a ? letter will be converted). | ||||||
| 
 | 
 | ||||||
| If the 'length' argument is set to 0, curl_unescape() will use strlen() on the | If the 'length' argument is set to 0, curl_unescape() will use strlen() on the | ||||||
| input 'url' string to find out the size. | input 'url' string to find out the size. | ||||||
| 
 | 
 | ||||||
| You must free() the returned string when you're done with it. | You must curl_free() the returned string when you're done with it. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| A pointer to a zero terminated string or NULL if it failed. | A pointer to a zero terminated string or NULL if it failed. | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
| .I curl_escape(), RFC 2396 | .I curl_escape(), curl_free(), RFC 2396 | ||||||
							
								
								
									
										93
									
								
								docs/libcurl/curl_version_info.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								docs/libcurl/curl_version_info.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH curl_version_info 3 "30 Sep 2002" "libcurl 7.10" "libcurl Manual" | ||||||
|  | .SH NAME | ||||||
|  | curl_version_info - returns run-time libcurl version info | ||||||
|  | .SH SYNOPSIS | ||||||
|  | .B #include <curl/curl.h> | ||||||
|  | .sp | ||||||
|  | .BI "curl_version_info_data *curl_version_info( CURLversion "type ");" | ||||||
|  | .ad | ||||||
|  | .SH DESCRIPTION | ||||||
|  | Returns a pointer to a filled in struct with information about various | ||||||
|  | run-time features in libcurl. \fItype\fP should be set to the version of this | ||||||
|  | functionality by the time you write your program. This way, libcurl will | ||||||
|  | always return a proper struct that your program understands, while programs in | ||||||
|  | the future might get an different struct. CURLVERSION_NOW will be the most | ||||||
|  | recent one for the library you have installed: | ||||||
|  |  | ||||||
|  |         data = curl_version_info(CURLVERSION_NOW); | ||||||
|  |  | ||||||
|  | Applications should use this information to judge if things are possible to do | ||||||
|  | or not, instead of using compile-time checks, as dynamic/DLL libraries can be | ||||||
|  | changed independent of applications. | ||||||
|  |  | ||||||
|  | The curl_version_info_data struct looks like this | ||||||
|  |  | ||||||
|  | .nf | ||||||
|  | typedef struct { | ||||||
|  |   CURLversion age;          /* 0 - this kind of struct */ | ||||||
|  |   const char *version;      /* human readable string */ | ||||||
|  |   unsigned int version_num; /* numeric representation */ | ||||||
|  |   const char *host;         /* human readable string */ | ||||||
|  |   int features;             /* bitmask, see below */ | ||||||
|  |   char *ssl_version;        /* human readable string */ | ||||||
|  |   long ssl_version_num;     /* number */ | ||||||
|  |   char *libz_version;       /* human readable string */ | ||||||
|  |   const char *protocols[];  /* list of protocols */ | ||||||
|  | } curl_version_info_data; | ||||||
|  | .fi | ||||||
|  |  | ||||||
|  | \fIage\fP describes what kind of struct this is. It is always 0 now. In a | ||||||
|  | future libcurl, if this struct changes, this age counter may be increased, and | ||||||
|  | then the struct for number 1 will look different (except for this first struct | ||||||
|  | field). | ||||||
|  |  | ||||||
|  | \fIversion\fP is just an ascii string for the libcurl version. | ||||||
|  |  | ||||||
|  | \fIversion_num\fP is a 6 digit hexadecimal number created like this: <2 digits | ||||||
|  | major number> | <2 digits minor number> | <2 digits patch number>. Version | ||||||
|  | 7.9.8 is therefore returned as 0x070908. | ||||||
|  |  | ||||||
|  | \fIhost\fP is an ascii string showing what host information that this libcurl | ||||||
|  | was built for. As discovered by a configure script or set by the build | ||||||
|  | environment. | ||||||
|  |  | ||||||
|  | \fIfeatures\fP can have none, one or more bits set, and the currently defined | ||||||
|  | bits are: | ||||||
|  | .TP 5.5 | ||||||
|  | .B CURL_VERSION_IPV6 | ||||||
|  | supports IPv6 | ||||||
|  | .TP | ||||||
|  | .B CURL_VERSION_KERBEROS4 | ||||||
|  | supports kerberos4 (when using FTP) | ||||||
|  | .TP | ||||||
|  | .B CURL_VERSION_SSL | ||||||
|  | supports SSL (HTTPS/FTPS) | ||||||
|  | .TP | ||||||
|  | .B CURL_VERSION_LIBZ | ||||||
|  | supports HTTP deflate using libz | ||||||
|  | .PP | ||||||
|  | \fIssl_version\fP is an ascii string for the OpenSSL version used. If libcurl | ||||||
|  | has no SSL support, this is NULL. | ||||||
|  |  | ||||||
|  | \fIssl_version_num\fP is the numerical OpenSSL version value as defined by the | ||||||
|  | OpenSSL project. If libcurl has no SSL support, this is 0. | ||||||
|  |  | ||||||
|  | \fIlibz_version\fP is an ascii string (there is no numerical version). If | ||||||
|  | libcurl has no libz support, this is NULL. | ||||||
|  |  | ||||||
|  | \fIprotocols\fP is a pointer to an array of char * pointers, containing the | ||||||
|  | names protocols that libcurl supports (using lowercase letters). The protocol | ||||||
|  | names are the same as would be used in URLs. The array is terminated by a NULL | ||||||
|  | entry. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .SH RETURN VALUE | ||||||
|  | A pointer to a curl_version_info_data struct. | ||||||
|  | .SH "SEE ALSO" | ||||||
|  | \fIcurl_version(3)\fP | ||||||
|  | .SH BUGS | ||||||
|  | No known bugs. | ||||||
							
								
								
									
										52
									
								
								docs/libcurl/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								docs/libcurl/index.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | <HTML> | ||||||
|  | <HEAD> | ||||||
|  | <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> | ||||||
|  | <TITLE>Index to libcurl documentation</TITLE> | ||||||
|  | </HEAD> | ||||||
|  |  | ||||||
|  | <BODY> | ||||||
|  | <H1 ALIGN="CENTER">Index to libcurl documentation</H1> | ||||||
|  |  | ||||||
|  | <H2>Programs</H2> | ||||||
|  | <P><A HREF="../index.html">curl and tools</A> | ||||||
|  |  | ||||||
|  | <h2>Overviews</h2> | ||||||
|  | <A HREF="libcurl.html">libcurl</A> | ||||||
|  | <br><a href="libcurl-multi.html">libcurl-multi</a> | ||||||
|  | <br><a href="libcurl-errors.html">libcurl-errors</a> | ||||||
|  | <br><a href="../libcurl-the-guide">libcurl-the-guide</a> (plain text) | ||||||
|  |  | ||||||
|  | <H2>Library Functions (A-Z)</H2> | ||||||
|  | <a href="curl_easy_cleanup.html">curl_easy_cleanup</A> | ||||||
|  | <br><a href="curl_easy_duphandle.html">curl_easy_duphandle</A> | ||||||
|  | <br><a href="curl_easy_getinfo.html">curl_easy_getinfo</A> | ||||||
|  | <br><a href="curl_easy_init.html">curl_easy_init</A> | ||||||
|  | <br><a href="curl_easy_perform.html">curl_easy_perform</A> | ||||||
|  | <br><a href="curl_easy_setopt.html">curl_easy_setopt</A> | ||||||
|  | <br><a href="curl_escape.html">curl_escape</A> | ||||||
|  | <br><a href="curl_formadd.html">curl_formadd</A> | ||||||
|  | <br><a href="curl_formfree.html">curl_formfree</A> | ||||||
|  | <br><a href="curl_formparse.html">curl_formparse</A> | ||||||
|  | <br><a href="curl_free.html">curl_free</A> | ||||||
|  | <br><a href="curl_getdate.html">curl_getdate</A> | ||||||
|  | <br><a href="curl_getenv.html">curl_getenv</A> | ||||||
|  | <br><a href="curl_global_cleanup.html">curl_global_cleanup</A> | ||||||
|  | <br><a href="curl_global_init.html">curl_global_init</A> | ||||||
|  | <br><a href="curl_mprintf.html">curl_mprintf</A> | ||||||
|  | <br><a href="curl_multi_add_handle.html">curl_multi_add_handle</a> | ||||||
|  | <br><a href="curl_multi_cleanup.html">curl_multi_cleanup</a> | ||||||
|  | <br><a href="curl_multi_fdset.html">curl_multi_fdset</a> | ||||||
|  | <br><a href="curl_multi_info_read.html">curl_multi_info_read</a> | ||||||
|  | <br><a href="curl_multi_init.html">curl_multi_init</a> | ||||||
|  | <br><a href="curl_multi_perform.html">curl_multi_perform</a> | ||||||
|  | <br><a href="curl_multi_remove_handle.html">curl_multi_remove_handle</a> | ||||||
|  | <br><a href="curl_slist_append.html">curl_slist_append</A> | ||||||
|  | <br><a href="curl_slist_free_all.html">curl_slist_free_all</A> | ||||||
|  | <br><a href="curl_strequal.html">curl_strequal</A> | ||||||
|  | <br><a href="curl_strnequal.html">curl_strnequal</A> | ||||||
|  | <br><a href="curl_unescape.html">curl_unescape</A> | ||||||
|  | <br><a href="curl_version.html">curl_version</A> | ||||||
|  | <br><a href="curl_version_info.html">curl_version_info</A> | ||||||
|  |  | ||||||
|  | </BODY> | ||||||
|  | </HTML> | ||||||
							
								
								
									
										240
									
								
								docs/libcurl/libcurl-errors.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										240
									
								
								docs/libcurl/libcurl-errors.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,240 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH libcurl-errors 3 "18 Dec 2002" "libcurl 7.10.3" "libcurl errors" | ||||||
|  | .SH NAME | ||||||
|  | error codes in libcurl | ||||||
|  | .SH DESCRIPTION | ||||||
|  | This man page includes most, if not all, available error codes in libcurl. | ||||||
|  | Why they occur and possibly what you can do to fix the problem. | ||||||
|  | .SH "CURLcode" | ||||||
|  | Almost all "easy" interface functions return a CURLcode error code. No matter | ||||||
|  | what, using \fICURLOPT_ERRORBUFFER\fP is a good idea as it will give you a | ||||||
|  | human readable error string that may offer more details about the error cause | ||||||
|  | than just the error code does. | ||||||
|  |  | ||||||
|  | This man page is meant to describe libcurl 7.9.6 and later. Earlier versions | ||||||
|  | might have had quirks not mentioned here. | ||||||
|  |  | ||||||
|  | CURLcode is one of the following: | ||||||
|  | .RS 1 | ||||||
|  | .TP 5 | ||||||
|  | .B CURLE_OK (0) | ||||||
|  | All fine. Proceed as usual. | ||||||
|  | .TP | ||||||
|  | .B CURLE_UNSUPPORTED_PROTOCOL (1) | ||||||
|  | The URL you passed to libcurl used a protocol that this libcurl does not | ||||||
|  | support. The support might be a compile-time option that you didn't use, it | ||||||
|  | can be a misspelled protocol string or just a protocol libcurl has no code | ||||||
|  | for. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FAILED_INIT (2) | ||||||
|  | Very early initialization code failed. This is likely to be an internal error | ||||||
|  | or problem. | ||||||
|  | .TP | ||||||
|  | .B CURLE_URL_MALFORMAT (3) | ||||||
|  | The URL was not properly formatted. | ||||||
|  | .TP | ||||||
|  | .B CURLE_URL_MALFORMAT_USER (4) | ||||||
|  | URL user malformatted. The user-part of the URL syntax was not correct. | ||||||
|  | .TP | ||||||
|  | .B CURLE_COULDNT_RESOLVE_PROXY (5) | ||||||
|  | Couldn't resolve proxy. The given proxy host could not be resolved. | ||||||
|  | .TP | ||||||
|  | .B CURLE_COULDNT_RESOLVE_HOST (6) | ||||||
|  | Couldn't resolve host. The given remote host was not resolved. | ||||||
|  | .TP | ||||||
|  | .B CURLE_COULDNT_CONNECT (7) | ||||||
|  | Failed to connect() to host or proxy. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_WEIRD_SERVER_REPLY (8) | ||||||
|  | After connecting to a FTP server, libcurl expects to get a certain reply back. | ||||||
|  | This error code implies that it god a strange or bad reply. The given remote | ||||||
|  | server is probably not an OK FTP server. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_ACCESS_DENIED (9) | ||||||
|  | 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. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_USER_PASSWORD_INCORRECT (10) | ||||||
|  | The username and/or the password were incorrect when trying to login to an FTP | ||||||
|  | server. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_WEIRD_PASS_REPLY (11) | ||||||
|  | After having sent the FTP password to the server, libcurl expects a proper | ||||||
|  | reply. This error code indicates that an unexpected code was returned. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_WEIRD_USER_REPLY (12) | ||||||
|  | After having sent user name to the FTP server, libcurl expects a proper | ||||||
|  | reply. This error code indicates that an unexpected code was returned. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_WEIRD_PASV_REPLY (13) | ||||||
|  | libcurl failed to get a sensible result back from the server as a response to | ||||||
|  | either a PASV or a EPSV command. The server is flawed. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_WEIRD_227_FORMAT (14) | ||||||
|  | FTP servers return a 227-line as a response to a PASV command. If libcurl | ||||||
|  | fails to parse that line, this return code is passed back. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_CANT_GET_HOST (15) | ||||||
|  | An internal failure to lookup the host used for the new connection. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_CANT_RECONNECT (16) | ||||||
|  | A bad return code on either PASV or EPSV was sent by the FTP server, | ||||||
|  | preventing libcurl from being able to continue. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_COULDNT_SET_BINARY (17) | ||||||
|  | Received an error when trying to set the transfer mode to binary. | ||||||
|  | .TP | ||||||
|  | .B CURLE_PARTIAL_FILE (18) | ||||||
|  | A file transfer was shorter or larger than expected. This happens when the | ||||||
|  | server first reports an expected transfer size, and then delivers data that | ||||||
|  | doesn't match the previously given size. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_COULDNT_RETR_FILE (19) | ||||||
|  | This was either a weird reply to a 'RETR' command or a zero byte transfer | ||||||
|  | complete. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_WRITE_ERROR (20) | ||||||
|  | After a completed file transfer, the FTP server did not respond a proper | ||||||
|  | \"transfer successful\" code. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_QUOTE_ERROR (21) | ||||||
|  | When sending custom "QUOTE" commands to the remote server, one of the commands | ||||||
|  | returned an error code that was 400 or higher. | ||||||
|  | .TP | ||||||
|  | .B CURLE_HTTP_RETURNED_ERROR (22) | ||||||
|  | This is returned if CURLOPT_FAILONERROR is set TRUE and the HTTP server | ||||||
|  | returns an error code that is >= 400. | ||||||
|  | .TP | ||||||
|  | .B CURLE_WRITE_ERROR (23) | ||||||
|  | An error occurred when writing received data to a local file, or an error was | ||||||
|  | returned to libcurl from a write callback. | ||||||
|  | .TP | ||||||
|  | .B CURLE_MALFORMAT_USER (24) | ||||||
|  | Malformat user. User name badly specified. *Not currently used* | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_COULDNT_STOR_FILE (25) | ||||||
|  | FTP couldn't STOR file. The server denied the STOR operation. The error buffer | ||||||
|  | usually contains the server's explanation to this. | ||||||
|  | .TP | ||||||
|  | .B CURLE_READ_ERROR (26) | ||||||
|  | There was a problem reading a local file or an error returned by the read | ||||||
|  | callback. | ||||||
|  | .TP | ||||||
|  | .B CURLE_OUT_OF_MEMORY (27) | ||||||
|  | Out of memory. A memory allocation request failed. This is serious badness and | ||||||
|  | things are severly screwed up if this ever occur. | ||||||
|  | .TP | ||||||
|  | .B CURLE_OPERATION_TIMEOUTED (28) | ||||||
|  | Operation timeout. The specified time-out period was reached according to the | ||||||
|  | conditions. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_COULDNT_SET_ASCII (29) | ||||||
|  | libcurl failed to set ASCII transfer type (TYPE A). | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_PORT_FAILED (30) | ||||||
|  | The FTP PORT command returned error. This mostly happen when you haven't | ||||||
|  | specified a good enough address for libcurl to use. See \fICURLOPT_FTPPORT\fP. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_COULDNT_USE_REST (31) | ||||||
|  | The FTP REST command returned error. This should never happen if the server is | ||||||
|  | sane. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_COULDNT_GET_SIZE (32) | ||||||
|  | The FTP SIZE command returned errror. SIZE is not a kosher FTP command, it is | ||||||
|  | an extension and not all servers support it. This is not a surprising error. | ||||||
|  | .TP | ||||||
|  | .B CURLE_HTTP_RANGE_ERROR (33) | ||||||
|  | The HTTP server does not support or accept range requests. | ||||||
|  | .TP | ||||||
|  | .B CURLE_HTTP_POST_ERROR (34) | ||||||
|  | This is an odd error that mainly occurs due to internal confusion. | ||||||
|  | .TP | ||||||
|  | .B CURLE_SSL_CONNECT_ERROR (35) | ||||||
|  | A problem occured somewhere in the SSL/TLS handshake. You really want the | ||||||
|  | error buffer and read the message there as it pinpoints the problem slightly | ||||||
|  | more. Could be certificates (file formats, paths, permissions), passwords, and | ||||||
|  | others. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FTP_BAD_DOWNLOAD_RESUME (36) | ||||||
|  | Attempting FTP resume beyond file size. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FILE_COULDNT_READ_FILE (37) | ||||||
|  | A file given with FILE:// couldn't be opened. Most likely because the file | ||||||
|  | path doesn't identify an existing file. Did you check file permissions? | ||||||
|  | .TP | ||||||
|  | .B CURLE_LDAP_CANNOT_BIND (38) | ||||||
|  | LDAP cannot bind. LDAP bind operation failed. | ||||||
|  | .TP | ||||||
|  | .B CURLE_LDAP_SEARCH_FAILED (39) | ||||||
|  | LDAP search failed. | ||||||
|  | .TP | ||||||
|  | .B CURLE_LIBRARY_NOT_FOUND (40) | ||||||
|  | Library not found. The LDAP library was not found. | ||||||
|  | .TP | ||||||
|  | .B CURLE_FUNCTION_NOT_FOUND (41) | ||||||
|  | Function not found. A required LDAP function was not found. | ||||||
|  | .TP | ||||||
|  | .B CURLE_ABORTED_BY_CALLBACK (42) | ||||||
|  | Aborted by callback. A callback returned "abort" to libcurl. | ||||||
|  | .TP | ||||||
|  | .B CURLE_BAD_FUNCTION_ARGUMENT (43) | ||||||
|  | Internal error. A function was called with a bad parameter. | ||||||
|  | .TP | ||||||
|  | .B CURLE_BAD_CALLING_ORDER (44) | ||||||
|  | Internal error. A function was called in a bad order. | ||||||
|  | .TP | ||||||
|  | .B CURLE_HTTP_PORT_FAILED (45) | ||||||
|  | Interface error. A specified outgoing interface could not be used. Set which | ||||||
|  | interface to use for outgoing connections' source IP address with | ||||||
|  | CURLOPT_INTERFACE. | ||||||
|  | .TP | ||||||
|  | .B CURLE_BAD_PASSWORD_ENTERED (46) | ||||||
|  | Bad password entered. An error was signaled when the password was | ||||||
|  | entered. This can also be the result of a "bad password" returned from a | ||||||
|  | specified password callback. | ||||||
|  | .TP | ||||||
|  | .B CURLE_TOO_MANY_REDIRECTS (47) | ||||||
|  | Too many redirects. When following redirects, libcurl hit the maximum amount. | ||||||
|  | Set your limit with CURLOPT_MAXREDIRS. | ||||||
|  | .TP | ||||||
|  | .B CURLE_UNKNOWN_TELNET_OPTION (48) | ||||||
|  | An option set with CURLOPT_TELNETOPTIONS was not recognized/known. Refer to | ||||||
|  | the appropriate documentation. | ||||||
|  | .TP | ||||||
|  | .B CURLE_TELNET_OPTION_SYNTAX (49) | ||||||
|  | A telnet option string was Illegally formatted. | ||||||
|  | .TP | ||||||
|  | .B CURLE_OBSOLETE (50) | ||||||
|  | This is not an error. This used to be another error code in an old libcurl | ||||||
|  | version and is currently unused. | ||||||
|  | .TP | ||||||
|  | .B CURLE_SSL_PEER_CERTIFICATE (51) | ||||||
|  | The remote server's SSL certificate was deemed not OK. | ||||||
|  | .TP | ||||||
|  | .B CURLE_GOT_NOTHING (52) | ||||||
|  | Nothing was returned from the server, and under the circumstances, getting | ||||||
|  | nothing is considered an error. | ||||||
|  | .TP | ||||||
|  | .B CURLE_SSL_ENGINE_NOTFOUND (53) | ||||||
|  | The specified crypto engine wasn't found. | ||||||
|  | .TP | ||||||
|  | .B CURLE_SSL_ENGINE_SETFAILED (54) | ||||||
|  | Failed setting the selected SSL crypto engine as default! | ||||||
|  | .TP | ||||||
|  | .B CURLE_SEND_ERROR (55) | ||||||
|  | Failed sending network data. | ||||||
|  | .TP | ||||||
|  | .B CURLE_RECV_ERROR (56) | ||||||
|  | Failure with receiving network data. | ||||||
|  | .TP | ||||||
|  | .B CURL_LAST | ||||||
|  | This is not an error, but in the curl/curl.h file this can be used to know how | ||||||
|  | many existing error codes there are. | ||||||
|  | .RE | ||||||
|  |  | ||||||
|  | .SH "CURLMcode" | ||||||
|  | This is the generic return code used by functions in the libcurl multi | ||||||
|  | interface. | ||||||
							
								
								
									
										100
									
								
								docs/libcurl/libcurl-multi.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								docs/libcurl/libcurl-multi.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | |||||||
|  | .\" You can view this file with: | ||||||
|  | .\" nroff -man [file] | ||||||
|  | .\" $Id$ | ||||||
|  | .\" | ||||||
|  | .TH libcurl-multi 5 "13 Oct 2001" "libcurl 7.10.1" "libcurl multi interface" | ||||||
|  | .SH NAME | ||||||
|  | libcurl-multi \- how to use the multi interface | ||||||
|  | .SH DESCRIPTION | ||||||
|  | This is an overview on how to use the libcurl multi interface in your C | ||||||
|  | programs. There are specific man pages for each function mentioned in | ||||||
|  | here. There's also the libcurl-the-guide document for a complete tutorial to | ||||||
|  | programming with libcurl and the \fIlibcurl(3)\fP man page for an overview of | ||||||
|  | the libcurl easy interface. | ||||||
|  |  | ||||||
|  | All functions in the multi interface are prefixed with curl_multi. | ||||||
|  | .SH "PLEASE NOTICE" | ||||||
|  | The multi interface is a rather new member of the libcurl family. It has not | ||||||
|  | yet been very widely used. It may still be a few more bugs lurking in there | ||||||
|  | than we are used to. That said, it might also just work in every aspect you | ||||||
|  | try it. Please report all bugs and oddities you see. | ||||||
|  | .SH "OBJECTIVES" | ||||||
|  | The multi interface introduces several new abilities that the easy interface | ||||||
|  | refuses to offer. They are mainly: | ||||||
|  |  | ||||||
|  | 1. Enable a "pull" interface. The application that uses libcurl decides where | ||||||
|  | and when to ask libcurl to get/send data. | ||||||
|  |  | ||||||
|  | 2. Enable multiple simultaneous transfers in the same thread without making it | ||||||
|  | complicated for the application. | ||||||
|  |  | ||||||
|  | 3. Enable the application to select() on its own file descriptors and curl's | ||||||
|  | file descriptors simultaneous easily. | ||||||
|  | .SH "ONE MULTI HANDLE MANY EASY HANDLES" | ||||||
|  | To use the multi interface, you must first create a 'multi handle' with | ||||||
|  | \fIcurl_multi_init\fP. This handle is then used as input to all further | ||||||
|  | curl_multi_* functions. | ||||||
|  |  | ||||||
|  | Each single transfer is built up with an easy handle. You must create them, | ||||||
|  | and setup the appropriate options for each easy handle, as outlined in the | ||||||
|  | \fIlibcurl(3)\fP man page, using \fIcurl_easy_setopt(3)\fP. | ||||||
|  |  | ||||||
|  | When the easy handle is setup for a transfer, then instead of using | ||||||
|  | \fIcurl_easy_perform\fP (as when using the easy interface for transfers), you | ||||||
|  | should instead add the easy handle to the multi handle using | ||||||
|  | \fIcurl_easy_add_handl\fP. The multi handle is sometimes referred to as a | ||||||
|  | \'multi stack\' because of the fact that it may hold a large amount of easy | ||||||
|  | handles. | ||||||
|  |  | ||||||
|  | Should you change your mind, the easy handle is again removed from the multi | ||||||
|  | stack using \fIcurl_multi_remove_handle\fP. Once removed from the multi | ||||||
|  | handle, you can again use other easy interface functions like | ||||||
|  | \fIcurl_easy_perform\fP on the handle or whatever you think is necessary. | ||||||
|  |  | ||||||
|  | Adding the easy handle to the multi handle does not start the transfer. | ||||||
|  | Remember that one of the main ideas with this interface is to let your | ||||||
|  | application drive. You drive the transfers by invoking | ||||||
|  | \fIcurl_multi_perform\fP. libcurl will then transfer data if there is anything | ||||||
|  | available to transfer. It'll use the callbacks and everything else you have | ||||||
|  | setup in the individual easy handles. It'll transfer data on all current | ||||||
|  | transfers in the multi stack that are ready to transfer anything. It may be | ||||||
|  | all, it may be none. | ||||||
|  |  | ||||||
|  | Your application can acquire knowledge from libcurl when it would like to get | ||||||
|  | invoked to transfer data, so that you don't have to busy-loop and call that | ||||||
|  | \fIcurl_multi_perform\fP like crazy. \fIcurl_multi_fdset\fP offers an | ||||||
|  | interface using which you can extract fd_sets from libcurl to use in select() | ||||||
|  | or poll() calls in order to get to know when the transfers in the multi stack | ||||||
|  | might need attention. This also makes it very easy for your program to wait | ||||||
|  | for input on your own private file descriptors at the same time or perhaps | ||||||
|  | timeout every now and then, should you want that. | ||||||
|  |  | ||||||
|  | A little note here about the return codes from the multi functions, and | ||||||
|  | especially the \fIcurl_multi_perform\fP: if you receive | ||||||
|  | \fICURLM_CALL_MULTI_PERFORM\fP, this basicly means that you should call | ||||||
|  | \fIcurl_multi_perform\fP again, before you select() on more actions. You don't | ||||||
|  | have to do it immediately, but the return code means that libcurl may have | ||||||
|  | more data available to return or that there may be more data to send off | ||||||
|  | before it is "satisfied". | ||||||
|  |  | ||||||
|  | \fIcurl_multi_perform\fP stores the number of still running transfers in one | ||||||
|  | of its input arguments, and by reading that you can figure out when all the | ||||||
|  | transfers in the multi handles are done. 'done' does not mean successful. One | ||||||
|  | or more of the transfers may have failed. Tracking when this number changes, | ||||||
|  | you know when one or more transfers are done. | ||||||
|  |  | ||||||
|  | To get information about completed transfers, to figure out success or not and | ||||||
|  | similar, \fIcurl_multi_info_read\fP should be called. It can return a message | ||||||
|  | about a current or previous transfer. Repeated invokes of the function get | ||||||
|  | more messages until the message queue is empty. The information you receive | ||||||
|  | there includes an easy handle pointer which you may use to identify which easy | ||||||
|  | handle the information regards. | ||||||
|  |  | ||||||
|  | When all transfers in the multi stack are done, cleanup the multi handle with | ||||||
|  | \fIcurl_multi_cleanup\fP. Be careful and please note that you \fBMUST\fP | ||||||
|  | invoke separate \fIcurl_easy_cleanup\fP calls on every single easy handle to | ||||||
|  | clean them up properly. | ||||||
|  |  | ||||||
|  | If you want to re-use an easy handle that was added to the multi handle for | ||||||
|  | transfer, you must first remove it from the multi stack and then re-add it | ||||||
|  | again (possbily after having altered some options at your own choice). | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user