Compare commits
	
		
			1335 Commits
		
	
	
		
			curl-7_9_5
			...
			curl-7_10_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | bdb5e5a250 | ||
|   | 48a580e609 | ||
|   | 1361fc69b9 | ||
|   | 93352e56d8 | ||
|   | d9246ff24d | ||
|   | 9301bc3444 | ||
|   | 76352c4e2d | ||
|   | 428f41bd12 | ||
|   | 99c32e460f | ||
|   | 83f249cf65 | ||
|   | 2c2baa93ea | ||
|   | f0278ca114 | ||
|   | 297b1b5013 | ||
|   | e9f63bf4e8 | ||
|   | 556ce1c6a1 | ||
|   | cc4ff62681 | ||
|   | 0423fd9b55 | ||
|   | 789ab20bf7 | ||
|   | b47462bd68 | ||
|   | 1a94fee42d | ||
|   | a91ce6a5d6 | ||
|   | 981ffd9fce | ||
|   | e76c960624 | ||
|   | 416c92cc6f | ||
|   | fb731eb3e7 | ||
|   | 6f2a4d290f | ||
|   | cefc8ba938 | ||
|   | d0bd644eef | ||
|   | 071c95128e | ||
|   | 1a192c489b | ||
|   | 56014e74a0 | ||
|   | 172271498d | ||
|   | f2882cb88c | ||
|   | 152f1fee40 | ||
|   | 968234e6ae | ||
|   | 5e133e2dff | ||
|   | 0049c09fc3 | ||
|   | a2a63c27f4 | ||
|   | c50a601f1a | ||
|   | bc0fd6db71 | ||
|   | 52b631fade | ||
|   | 2f0bc9d1f7 | ||
|   | 5ef6520d4e | ||
|   | 2c1925161e | ||
|   | 0529b349d5 | ||
|   | b4620364a2 | ||
|   | 634aef3895 | ||
|   | 06c86d1a8c | ||
|   | 79749f8eb4 | ||
|   | b036986b3e | ||
|   | 938f1d1da7 | ||
|   | 58b6b3df06 | ||
|   | f9c3347f7c | ||
|   | 5b72eb0b03 | ||
|   | 6dd4c13bc0 | ||
|   | e4e7db551f | ||
|   | ebfde8da56 | ||
|   | 756bc0f4b7 | ||
|   | 269d491b6a | ||
|   | 449e5bc2ad | ||
|   | 8736c11d84 | ||
|   | 45fc760985 | ||
|   | 7968e3c2de | ||
|   | 964a41c75c | ||
|   | 5931d53637 | ||
|   | 3ed3ae5bcf | ||
|   | 6519cc70c5 | ||
|   | 505a4f27fa | ||
|   | 79144eba99 | ||
|   | 26e17d89c9 | ||
|   | 4322c1106f | ||
|   | 73071dfd4f | ||
|   | b7c14b3c27 | ||
|   | 3130b44535 | ||
|   | a2bd73334f | ||
|   | 1a393f5625 | ||
|   | d4951e837e | ||
|   | 26f6365e93 | ||
|   | 3a552b1e63 | ||
|   | 69eb1790da | ||
|   | a1af6f3614 | ||
|   | 3aced61465 | ||
|   | 6f02ddfce8 | ||
|   | c2faa39b62 | ||
|   | 2d3734b8b5 | ||
|   | ed908b7f89 | ||
|   | f7d795a364 | ||
|   | 8919b39d54 | ||
|   | 84cedc094e | ||
|   | 3b2b2496d7 | ||
|   | 445684c409 | ||
|   | 898e067ccc | ||
|   | 12859e345f | ||
|   | 89f4af695e | ||
|   | 308bc9d919 | ||
|   | db566c54ae | ||
|   | 81d403e207 | ||
|   | 2bd71d70ff | ||
|   | 1eef6f44ba | ||
|   | 204f03912f | ||
|   | f8c3b3aa18 | ||
|   | d4df981463 | ||
|   | 497c6d516d | ||
|   | 8288862b7e | ||
|   | 9aae16c236 | ||
|   | 80c194a70a | ||
|   | c832b2db5b | ||
|   | 27018882ec | ||
|   | caf6e9c540 | ||
|   | e727fb82f2 | ||
|   | c78df56801 | ||
|   | d13202f43b | ||
|   | 9d139a6b35 | ||
|   | d2abe44e6f | ||
|   | bc67228576 | ||
|   | ecf32c964a | ||
|   | e58f30b82a | ||
|   | 654e3f1101 | ||
|   | 86689dc524 | ||
|   | 5f62a0c1ca | ||
|   | ad1bf0f389 | ||
|   | 9c7703ace1 | ||
|   | 4a8155b53c | ||
|   | 80d6d5c5c4 | ||
|   | c624be8388 | ||
|   | 09df1cd41e | ||
|   | 52c5b57200 | ||
|   | 5ea04a852e | ||
|   | a2eef05198 | ||
|   | 55f75af353 | ||
|   | fb6a51b8fd | ||
|   | 252cc2213e | ||
|   | 73c5f24fa4 | ||
|   | 4c80e103a0 | ||
|   | 39ea557360 | ||
|   | d0cc92a01a | ||
|   | d7980c1a45 | ||
|   | e56ae1426c | ||
|   | 696843c020 | ||
|   | 6ff5621dd7 | ||
|   | e7fb72a732 | ||
|   | 8d30d34e0c | ||
|   | bc7fe85f8a | ||
|   | 89352d92c5 | ||
|   | c32390d84c | ||
|   | 45ca866a2d | ||
|   | ceef206c21 | ||
|   | 7c6424f0a9 | ||
|   | bc942de6f1 | ||
|   | 06984df5cb | ||
|   | 4f136a3a76 | ||
|   | 363bf3ba30 | ||
|   | acb895956a | ||
|   | 21e87b9bb3 | ||
|   | c896ebcf12 | ||
|   | d288222e80 | ||
|   | 4eb2a6c9a3 | ||
|   | 2563731c4d | ||
|   | 4e410111db | ||
|   | 5670563a26 | ||
|   | 6caa656d01 | ||
|   | c12af7aed1 | ||
|   | dcb6d1c01d | ||
|   | 18234cbdac | ||
|   | 06bf988dc1 | ||
|   | 55ff4c3f08 | ||
|   | 4915002168 | ||
|   | 5bd8d60e41 | ||
|   | fc872808c5 | ||
|   | 0f4feda382 | ||
|   | 90b0f38316 | ||
|   | 18f630ab21 | ||
|   | e97fd44151 | ||
|   | b75679778f | ||
|   | 35a84ad576 | ||
|   | 4ed28be75a | ||
|   | e2f4656a86 | ||
|   | 1e14da5c60 | ||
|   | b2ef79ef3d | ||
|   | f488874ff5 | ||
|   | 23258648da | ||
|   | 6b84ebe501 | ||
|   | 07dd067f73 | ||
|   | 420744d048 | ||
|   | 01108e3a63 | ||
|   | 8026b1e194 | ||
|   | a39d77227f | ||
|   | 9f69deec7d | ||
|   | e912f772e0 | ||
|   | 0102726aeb | ||
|   | 1e7aa04040 | ||
|   | 00a7c6fe6b | ||
|   | 87f8c0d471 | ||
|   | 334d78cd18 | ||
|   | 2356325592 | ||
|   | d78ec593fa | ||
|   | d5043133e6 | ||
|   | 509f69a457 | ||
|   | 662c659220 | ||
|   | 9a6566e774 | ||
|   | 4da0428d9e | ||
|   | 8ee1177206 | ||
|   | e9154b2549 | ||
|   | d398a0dd58 | ||
|   | 7723a24297 | ||
|   | 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 | 
							
								
								
									
										14
									
								
								.cvsignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.cvsignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| config.log | ||||
| Makefile | ||||
| libtool | ||||
| Makefile.in | ||||
| aclocal.m4 | ||||
| configure | ||||
| config.h | ||||
| config.status | ||||
| curl-config | ||||
| autom4te.cache | ||||
| depcomp | ||||
| config.guess | ||||
| config.sub | ||||
| ltmain.sh | ||||
							
								
								
									
										1957
									
								
								CHANGES.2001
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1957
									
								
								CHANGES.2001
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1504
									
								
								CHANGES.2002
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1504
									
								
								CHANGES.2002
									
									
									
									
									
										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. | ||||
							
								
								
									
										39
									
								
								CVS-INFO
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								CVS-INFO
									
									
									
									
									
								
							| @@ -15,8 +15,9 @@ Compile and build instructions follow below. | ||||
|   CHANGES.0     contains ancient changes. | ||||
|   CHANGES.$year contains changes for the particular year. | ||||
|  | ||||
|   memanalyze.pl is for analyzing the output generated by curl if -DMALLOCDEBUG | ||||
|                 is used when compiling | ||||
|   tests/memanalyze.pl | ||||
|                 is for analyzing the output generated by curl if -DCURLDEBUG | ||||
|                 is used when compiling (run configure with --enable-debug) | ||||
|  | ||||
|   buildconf     builds the makefiles and configure stuff | ||||
|  | ||||
| @@ -30,25 +31,39 @@ To build after having extracted everything from CVS, do this: | ||||
| ./configure | ||||
| make | ||||
|  | ||||
|   Daniel uses a ./configure line similar to this for easier development: | ||||
|  | ||||
|   ./configure --disable-shared --enable-debug --enable-maintainer-mode | ||||
|  | ||||
|  | ||||
| REQUIREMENTS | ||||
|  | ||||
|  You need the following software installed: | ||||
|  | ||||
|  o autoconf 2.50 (or later) | ||||
|  o automake 1.5 (or later) | ||||
|  o libtool  1.4 (or later) | ||||
|  o autoconf 2.57  (or later) | ||||
|  o automake 1.7   (or later) | ||||
|  o libtool  1.4.2 (or later) | ||||
|  o GNU m4 (required by autoconf) | ||||
|  | ||||
|  o nroff + perl (if you don't have nroff and perl and you for some reason | ||||
|    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 | ||||
|    file. This will of course 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 nroff + perl | ||||
|  | ||||
|    If you don't have nroff and perl and you for some reason 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 file. This will of course | ||||
|    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 | ||||
|  | ||||
|  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) | ||||
|  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.] | ||||
|  | ||||
							
								
								
									
										26
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -2,27 +2,34 @@ | ||||
| # $Id$ | ||||
| # | ||||
|  | ||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | ||||
| AUTOMAKE_OPTIONS = foreign | ||||
|  | ||||
| EXTRA_DIST =						\ | ||||
| 	CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt	\ | ||||
| 	reconf Makefile.dist curl-config.in build_vms.com curl-mode.el | ||||
| EXTRA_DIST = CHANGES COPYING maketgz reconf Makefile.dist	\ | ||||
|   curl-config.in build_vms.com curl-style.el sample.emacs testcurl.sh | ||||
|  | ||||
| bin_SCRIPTS = curl-config | ||||
|  | ||||
| SUBDIRS = docs lib src include tests packages multi | ||||
| SUBDIRS = lib src | ||||
| DIST_SUBDIRS = $(SUBDIRS) tests include packages docs | ||||
|  | ||||
| # create a root makefile in the distribution: | ||||
| dist-hook: | ||||
| 	rm -rf $(top_builddir)/tests/log | ||||
| 	cp $(srcdir)/Makefile.dist $(distdir)/Makefile | ||||
|  | ||||
| html: | ||||
| 	cd docs; make html | ||||
|  | ||||
| pdf: | ||||
| 	cd docs; make pdf | ||||
|  | ||||
| check: test | ||||
|  | ||||
| test: | ||||
| 	@(cd tests; $(MAKE) quiet-test) | ||||
| 	@(cd tests; $(MAKE) all quiet-test) | ||||
|  | ||||
| test-full: | ||||
| 	@(cd tests; $(MAKE) all full-test) | ||||
|  | ||||
| # | ||||
| # Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros | ||||
| @@ -63,7 +70,7 @@ rpm: | ||||
| pkgadd: | ||||
| 	umask 022 ; \ | ||||
| 	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 | ||||
|  | ||||
| # | ||||
| @@ -71,3 +78,8 @@ pkgadd: | ||||
| # resulting .tar.bz2 file will end up at packages/Win32/cygwin | ||||
| cygwinbin: | ||||
| 	$(MAKE) -C packages/Win32/cygwin cygwinbin | ||||
|  | ||||
| # We extend the standard install with a custom hook: | ||||
| install-data-hook: | ||||
| 	cd include && $(MAKE) install | ||||
| 	cd docs && $(MAKE) install | ||||
|   | ||||
| @@ -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 | ||||
| # dual-licensed under the MPL and the MIT/X-derivate licenses. | ||||
| @@ -34,12 +34,12 @@ borland: | ||||
| 	cd src & make -f Makefile.b32 | ||||
|  | ||||
| mingw32: | ||||
| 	cd lib & make -f Makefile.m32 | ||||
| 	cd src & make -f Makefile.m32 | ||||
| 	cd lib & make -f Makefile.m32 ZLIB=1 | ||||
| 	cd src & make -f Makefile.m32 ZLIB=1 | ||||
|  | ||||
| mingw32-ssl: | ||||
| 	cd lib & make -f Makefile.m32 SSL=1 | ||||
| 	cd src & make -f Makefile.m32 SSL=1 | ||||
| 	cd lib & make -f Makefile.m32 SSL=1 ZLIB=1 | ||||
| 	cd src & make -f Makefile.m32 SSL=1 ZLIB=1 | ||||
|  | ||||
| vc: | ||||
| 	cd lib | ||||
| @@ -59,6 +59,10 @@ vc-ssl-dll: | ||||
| 	cd ..\src | ||||
| 	nmake -f Makefile.vc6 | ||||
|  | ||||
| djgpp: | ||||
| 	make -C lib -f Makefile.dj | ||||
| 	make -C src -f Makefile.dj | ||||
|  | ||||
| cygwin: | ||||
| 	./configure | ||||
| 	make | ||||
|   | ||||
							
								
								
									
										38
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								README
									
									
									
									
									
								
							| @@ -11,38 +11,58 @@ README | ||||
|   MANUAL document. Find out how to install Curl by reading the INSTALL | ||||
|   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 | ||||
|   find out how! | ||||
|   learn how! | ||||
|  | ||||
|   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: | ||||
|  | ||||
|         Sweden    -- ftp://ftp.sunet.se/pub/www/utilities/curl/ | ||||
|         Sweden    -- http://cool.haxx.se/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: | ||||
|  | ||||
|     cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl login | ||||
|     cvs -d :pserver:cvsread@cvs.php.net:/repository login | ||||
|  | ||||
|   (just press enter when asked for password) | ||||
|   (enter "phpfi" when asked for password) | ||||
|  | ||||
|     cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl co curl  | ||||
|     cvs -d :pserver:cvsread@cvs.php.net:/repository co curl  | ||||
|  | ||||
|   (you'll get a directory named curl created, filled with the source code) | ||||
|  | ||||
|     cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl logout | ||||
|     cvs -d :pserver:cvsread@cvs.php.net:/repository logout | ||||
|          | ||||
|   (you're off the hook!) | ||||
|  | ||||
| NOTICE | ||||
|  | ||||
|   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 | ||||
|   distribution terms. | ||||
|   | ||||
							
								
								
									
										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 | ||||
							
								
								
									
										40
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -38,7 +38,7 @@ AC_DEFUN(CURL_CHECK_NONBLOCKING_SOCKET, | ||||
| ],[ | ||||
| dnl the O_NONBLOCK test was fine | ||||
| 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 | ||||
|  | ||||
| @@ -52,7 +52,7 @@ dnl the code was bad, try a different program now, test 2 | ||||
| ],[ | ||||
| dnl FIONBIO test was good | ||||
| nonblock="FIONBIO" | ||||
| AC_DEFINE(HAVE_FIONBIO) | ||||
| AC_DEFINE(HAVE_FIONBIO, 1, [use FIONBIO for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl FIONBIO test was also bad | ||||
| 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 | ||||
| nonblock="ioctlsocket" | ||||
| AC_DEFINE(HAVE_IOCTLSOCKET) | ||||
| AC_DEFINE(HAVE_IOCTLSOCKET, 1, [use ioctlsocket() for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl ioctlsocket didnt compile! | ||||
|  | ||||
| @@ -79,11 +79,11 @@ dnl ioctlsocket didnt compile! | ||||
| ],[ | ||||
| dnl ioctlsocket test was good | ||||
| nonblock="IoctlSocket" | ||||
| AC_DEFINE(HAVE_IOCTLSOCKET_CASE) | ||||
| AC_DEFINE(HAVE_IOCTLSOCKET_CASE, 1, [use Ioctlsocket() for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl ioctlsocket didnt compile! | ||||
| nonblock="nada" | ||||
| AC_DEFINE(HAVE_DISABLED_NONBLOCKING) | ||||
| AC_DEFINE(HAVE_DISABLED_NONBLOCKING, 1, [disabled non-blocking sockets]) | ||||
| ]) | ||||
| dnl end of forth test | ||||
|  | ||||
| @@ -152,10 +152,8 @@ AC_DEFUN([TYPE_IN_ADDR_T], | ||||
|       AC_MSG_CHECKING([for in_addr_t equivalent]) | ||||
|       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= | ||||
|          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([ | ||||
|                #include <sys/types.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_EGREP_CPP(inet_ntoa_r,[ | ||||
| #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(no) | ||||
|       AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared) | ||||
|       AC_EGREP_CPP(inet_ntoa_r,[ | ||||
| #define _REENTRANT | ||||
| #include <arpa/inet.h>],[ | ||||
| 	AC_DEFINE(HAVE_INET_NTOA_R_DECL) | ||||
| 	AC_DEFINE(NEED_REENTRANT) | ||||
| 	AC_DEFINE(HAVE_INET_NTOA_R_DECL, 1, [inet_ntoa_r() is declared]) | ||||
| 	AC_DEFINE(NEED_REENTRANT, 1, [need REENTRANT defined]) | ||||
| 	AC_MSG_RESULT(yes)], | ||||
| 	AC_MSG_RESULT(no))])]) | ||||
| ]) | ||||
| @@ -302,7 +300,7 @@ struct hostent_data hdata; | ||||
| int rc; | ||||
| rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[ | ||||
|       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_MSG_RESULT(no) | ||||
|       AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments) | ||||
| @@ -318,8 +316,8 @@ struct hostent_data hdata; | ||||
| int rc; | ||||
| rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[ | ||||
| 	AC_MSG_RESULT(yes) | ||||
| 	AC_DEFINE(HAVE_GETHOSTBYADDR_R_5) | ||||
| 	AC_DEFINE(NEED_REENTRANT) | ||||
| 	AC_DEFINE(HAVE_GETHOSTBYADDR_R_5, 1, [gethostbyaddr_r() takes 5 args]) | ||||
| 	AC_DEFINE(NEED_REENTRANT, 1, [need REENTRANT]) | ||||
| 	ac_cv_gethostbyaddr_args=5],[ | ||||
| 	AC_MSG_RESULT(no) | ||||
| 	AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments) | ||||
| @@ -337,7 +335,7 @@ struct hostent * hp; | ||||
| hp = gethostbyaddr_r(address, length, type, &h, | ||||
|                      buffer, 8192, &h_errnop);],[ | ||||
| 	  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_MSG_RESULT(no) | ||||
| 	  AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments) | ||||
| @@ -356,7 +354,7 @@ int rc; | ||||
| rc = gethostbyaddr_r(address, length, type, &h, | ||||
|                      buffer, 8192, &hp, &h_errnop);],[ | ||||
| 	    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_MSG_RESULT(no) | ||||
| 	    have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])]) | ||||
| @@ -380,7 +378,7 @@ gethostbyname_r(const char *, struct hostent *, struct hostent_data *);],[ | ||||
| struct hostent_data data; | ||||
| gethostbyname_r(NULL, NULL, NULL);],[ | ||||
|       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_MSG_RESULT(no) | ||||
|       AC_MSG_CHECKING([if gethostbyname_r with -D_REENTRANT takes 3 arguments]) | ||||
| @@ -398,8 +396,8 @@ gethostbyname_r(const char *,struct hostent *, struct hostent_data *);],[ | ||||
| struct hostent_data data; | ||||
| gethostbyname_r(NULL, NULL, NULL);],[ | ||||
| 	AC_MSG_RESULT(yes) | ||||
| 	AC_DEFINE(HAVE_GETHOSTBYNAME_R_3) | ||||
| 	AC_DEFINE(NEED_REENTRANT) | ||||
| 	AC_DEFINE(HAVE_GETHOSTBYNAME_R_3, 1, [gethostbyname_r() takes 3 args]) | ||||
| 	AC_DEFINE(NEED_REENTRANT, 1, [needs REENTRANT]) | ||||
| 	ac_cv_gethostbyname_args=3],[ | ||||
| 	AC_MSG_RESULT(no) | ||||
| 	AC_MSG_CHECKING([if gethostbyname_r takes 5 arguments]) | ||||
| @@ -413,7 +411,7 @@ struct hostent * | ||||
| gethostbyname_r(const char *, struct hostent *, char *, int, int *);],[ | ||||
| gethostbyname_r(NULL, NULL, NULL, 0, NULL);],[ | ||||
| 	  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_MSG_RESULT(no) | ||||
| 	  AC_MSG_CHECKING([if gethostbyname_r takes 6 arguments]) | ||||
| @@ -428,7 +426,7 @@ gethostbyname_r(const char *, struct hostent *, char *, size_t, | ||||
| struct hostent **, int *);],[ | ||||
| gethostbyname_r(NULL, NULL, NULL, 0, NULL, NULL);],[ | ||||
| 	    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_MSG_RESULT(no) | ||||
| 	    have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"], | ||||
|   | ||||
							
								
								
									
										136
									
								
								build_vms.com
									
									
									
									
									
								
							
							
						
						
									
										136
									
								
								build_vms.com
									
									
									
									
									
								
							| @@ -1,69 +1,69 @@ | ||||
| $! | ||||
| $ | ||||
| $	on control_y then goto Common_Exit! | ||||
| $	orig = f$environment("DEFAULT") | ||||
| $	loc  = f$environment("PROCEDURE") | ||||
| $	def = f$parse("X.X;1",loc) - "X.X;1" | ||||
| $ | ||||
| $	set def 'def' | ||||
| $	cc_qual = "/define=HAVE_CONFIG_H=1/include=(""../include/"",""../"",""../../openssl-0_9_6c/include/"")" | ||||
| $	if p1 .eqs. "LISTING" then cc_qual = cc_qual + "/LIST/MACHINE" | ||||
| $	if p1 .eqs. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG" | ||||
| $	msg_qual = "" | ||||
| $	call build "[.lib]" "*.c" | ||||
| $	call build "[.src]" "*.c" | ||||
| $	call build "[.src]" "*.msg" | ||||
| $! | ||||
| $ | ||||
| $	on control_y then goto Common_Exit! | ||||
| $	orig = f$environment("DEFAULT") | ||||
| $	loc  = f$environment("PROCEDURE") | ||||
| $	def = f$parse("X.X;1",loc) - "X.X;1" | ||||
| $ | ||||
| $	set def 'def' | ||||
| $	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. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG" | ||||
| $	msg_qual = "" | ||||
| $	call build "[.lib]" "*.c" | ||||
| $	call build "[.src]" "*.c" | ||||
| $	call build "[.src]" "*.msg" | ||||
| $	link /exe=curl.exe [.src]curl/lib/include=main,[.lib]curl/lib, - | ||||
| 		[-.openssl-0_9_6c.axp.exe.ssl]libssl/lib, - | ||||
| 		[-.openssl-0_9_6c.axp.exe.crypto]libcrypto/lib | ||||
| $ | ||||
| $ | ||||
| $	goto Common_Exit | ||||
| $build:	subroutine | ||||
| $	set noon | ||||
| $	set default 'p1' | ||||
| $	search = p2 | ||||
| $	reset = f$search("reset") | ||||
| $	if f$search("CURL.OLB") .eqs. "" | ||||
| $	then | ||||
| $		LIB/CREATE/OBJECT CURL.OLB | ||||
| $	endif | ||||
| $	reset = f$search("reset",1) | ||||
| $Loop: | ||||
| $	file = f$search(search,1) | ||||
| $	if file .eqs. "" then goto EndLoop | ||||
| $		obj = f$search(f$parse(".OBJ;",file),2) | ||||
| $		if (obj .nes. "") | ||||
| $		then | ||||
| $			if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt"))) | ||||
| $			then | ||||
| $				call compile 'file' | ||||
| $				lib/object curl.OLB 'f$parse(".obj;",file)' | ||||
| $			else | ||||
| $!				write sys$output "File: ''file' is up to date" | ||||
| $			endif | ||||
| $		else | ||||
| $!			write sys$output "Object for file: ''file' does not exist" | ||||
| $			call compile 'file' | ||||
| $			lib/object curl.OLB 'f$parse(".obj;",file)' | ||||
| $		endif | ||||
| $	goto Loop | ||||
| $EndLoop: | ||||
| $	purge | ||||
| $	set def 'def' | ||||
| $	endsubroutine	! Build | ||||
| $ | ||||
| $compile:	subroutine | ||||
| $	set noon | ||||
| $	file = p1 | ||||
| $	qual = p2+p3+p4+p5+p6+p7+p8 | ||||
| $	typ = f$parse(file,,,"TYPE") - "." | ||||
| $	cmd_c = "CC "+cc_qual | ||||
| $	cmd_msg = "MESSAGE "+msg_qual | ||||
| $	x = cmd_'typ' | ||||
| $	'x' 'file' | ||||
| $	ENDSUBROUTINE	! Compile | ||||
| $ | ||||
| $Common_Exit: | ||||
| $	set default 'orig' | ||||
| $	exit | ||||
| 		[-.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 | ||||
| $	set default 'p1' | ||||
| $	search = p2 | ||||
| $	reset = f$search("reset") | ||||
| $	if f$search("CURL.OLB") .eqs. "" | ||||
| $	then | ||||
| $		LIB/CREATE/OBJECT CURL.OLB | ||||
| $	endif | ||||
| $	reset = f$search("reset",1) | ||||
| $Loop: | ||||
| $	file = f$search(search,1) | ||||
| $	if file .eqs. "" then goto EndLoop | ||||
| $		obj = f$search(f$parse(".OBJ;",file),2) | ||||
| $		if (obj .nes. "") | ||||
| $		then | ||||
| $			if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt"))) | ||||
| $			then | ||||
| $				call compile 'file' | ||||
| $				lib/object curl.OLB 'f$parse(".obj;",file)' | ||||
| $			else | ||||
| $!				write sys$output "File: ''file' is up to date" | ||||
| $			endif | ||||
| $		else | ||||
| $!			write sys$output "Object for file: ''file' does not exist" | ||||
| $			call compile 'file' | ||||
| $			lib/object curl.OLB 'f$parse(".obj;",file)' | ||||
| $		endif | ||||
| $	goto Loop | ||||
| $EndLoop: | ||||
| $	purge | ||||
| $	set def 'def' | ||||
| $	endsubroutine	! Build | ||||
| $ | ||||
| $compile:	subroutine | ||||
| $	set noon | ||||
| $	file = p1 | ||||
| $	qual = p2+p3+p4+p5+p6+p7+p8 | ||||
| $	typ = f$parse(file,,,"TYPE") - "." | ||||
| $	cmd_c = "CC "+cc_qual | ||||
| $	cmd_msg = "MESSAGE "+msg_qual | ||||
| $	x = cmd_'typ' | ||||
| $	'x' 'file' | ||||
| $	ENDSUBROUTINE	! Compile | ||||
| $ | ||||
| $Common_Exit: | ||||
| $	set default 'orig' | ||||
| $	exit | ||||
|   | ||||
							
								
								
									
										126
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										126
									
								
								buildconf
									
									
									
									
									
								
							| @@ -5,7 +5,125 @@ die(){ | ||||
| 	exit | ||||
| } | ||||
|  | ||||
| aclocal           || die "The command 'aclocal' failed" | ||||
| autoheader        || die "The command 'autoheader' failed" | ||||
| autoconf          || die "The command 'autoconf' failed" | ||||
| automake          || die "The command 'automake $MAKEFILES' failed" | ||||
| #-------------------------------------------------------------------------- | ||||
| # autoconf 2.57 or newer | ||||
| # | ||||
| 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 | ||||
|   | ||||
							
								
								
									
										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
											
										
									
								
							
							
								
								
									
										978
									
								
								configure.ac
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										978
									
								
								configure.ac
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,978 @@ | ||||
| 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 ) | ||||
| 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 ********************************************************************** | ||||
| dnl Check for GSS-API libraries | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| AC_ARG_WITH(gssapi-includes, | ||||
|   AC_HELP_STRING([--with-gssapi-includes=DIR], | ||||
|                  [Specify location of GSSAPI header]), | ||||
|   [ GSSAPI_INCS="-I$withval"  | ||||
|     want_gss="yes" ] | ||||
| ) | ||||
|  | ||||
| AC_ARG_WITH(gssapi-libs, | ||||
|   AC_HELP_STRING([--with-gssapi-libs=DIR], | ||||
|   		 [Specify location of GSSAPI libs]), | ||||
|   [ GSSAPI_LIBS="-L$withval -lgssapi" | ||||
|     want_gss="yes" ] | ||||
| ) | ||||
|  | ||||
| AC_ARG_WITH(gssapi, | ||||
|   AC_HELP_STRING([--with-gssapi=DIR], | ||||
|                  [Where to look for GSSAPI]), | ||||
|   [ GSSAPI_ROOT="$withval" | ||||
|     want_gss="yes" ] | ||||
| ) | ||||
|  | ||||
| AC_MSG_CHECKING([if GSSAPI support is requested]) | ||||
| if test x"$want_gss" = xyes; then | ||||
|   if test -z "$GSSAPI_INCS"; then | ||||
|      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then | ||||
|         gss_cppflags=`$GSSAPI_ROOT/bin/krb5-config --cflags gssapi` | ||||
| 	CPPFLAGS="$CPPFLAGS $gss_cppflags" | ||||
|      else | ||||
|         CPPFLAGS="$GSSAPI_ROOT/include" | ||||
|      fi | ||||
|   else | ||||
|      CPPFLAGS="$CPPFLAGS $GSSAPI_INCS" | ||||
|   fi | ||||
|    | ||||
|   if test -z "$GSSAPI_LIB_DIR"; then | ||||
|      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then | ||||
|         gss_ldflags=`$GSSAPI_ROOT/bin/krb5-config --libs gssapi` | ||||
| 	LDFLAGS="$LDFLAGS $gss_ldflags" | ||||
|      else | ||||
|         LDFLAGS="$LDFLAGS $GSSAPI_ROOT/lib -lgssapi" | ||||
|      fi | ||||
|   else | ||||
|      LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR" | ||||
|   fi | ||||
|  | ||||
|   AC_MSG_RESULT(yes) | ||||
|   AC_DEFINE(GSSAPI, 1, [if you have the gssapi libraries]) | ||||
|    | ||||
| 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 | ||||
| dnl Default to no CA bundle | ||||
| ca="no" | ||||
| 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) | ||||
|  | ||||
|     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 | ||||
|       CURL_CA_BUNDLE='"'$ca'"' | ||||
|       AC_SUBST(CURL_CA_BUNDLE)   | ||||
|     fi | ||||
|     AC_MSG_RESULT([$ca]) | ||||
|  | ||||
|     dnl these can only exist if openssl exists | ||||
|  | ||||
|     AC_CHECK_FUNCS( RAND_status \ | ||||
|                     RAND_screen \ | ||||
|                     RAND_egd ) | ||||
|  | ||||
|   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 | ||||
|  | ||||
| fi | ||||
|  | ||||
| AM_CONDITIONAL(CABUNDLE, test x$ca != xno) | ||||
|  | ||||
| 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 set variable for use in automakefile(s) | ||||
| AM_CONDITIONAL(HAVE_LIBZ, test x"$HAVE_LIBZ" = x1) | ||||
|  | ||||
| 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 \ | ||||
|                 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_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 -DCURLDEBUG" | ||||
|     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/DOS/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(lib/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 -Wundef -Wpointer-arith -Wcast-align -Wnested-externs -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: | ||||
|  | ||||
|   --ca        ca bundle install path | ||||
|   --cc        compiler | ||||
|   --cflags    pre-processor and compiler flags | ||||
|   --feature   newline separated list of enabled features | ||||
| @@ -43,6 +44,10 @@ while test $# -gt 0; do | ||||
|     esac | ||||
|  | ||||
|     case "$1" in | ||||
|     --ca) | ||||
| 	echo @CURL_CA_BUNDLE@ | ||||
| 	;; | ||||
|  | ||||
|     --cc) | ||||
| 	echo @CC@ | ||||
| 	;; | ||||
| @@ -61,6 +66,30 @@ while test $# -gt 0; do | ||||
| 	if test "@IPV6_ENABLED@" = "1"; then | ||||
|           echo "IPv6" | ||||
|         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) | ||||
| @@ -78,7 +107,11 @@ while test $# -gt 0; do | ||||
| 	;; | ||||
|  | ||||
|     --cflags) | ||||
|        	echo -I@includedir@ | ||||
|        	if test "X@includedir@" = "X/usr/include"; then | ||||
|           echo "" | ||||
|         else | ||||
|           echo "-I@includedir@" | ||||
|         fi | ||||
|        	;; | ||||
|  | ||||
|     --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" "time_t")) | ||||
| 	) | ||||
|   ;; 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 | ||||
|  | ||||
|   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. | ||||
|  | ||||
|   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 | ||||
|   bug reports and bug fixes. If you can't fix a bug yourself and submit a fix | ||||
|   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 | ||||
|   your bug/problem at curl's bug tracking system over at | ||||
|   bug reports and bug fixes. | ||||
|  | ||||
| WHERE TO REPORT | ||||
|  | ||||
|   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 | ||||
|  | ||||
|   (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 | ||||
|   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 | ||||
|   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. | ||||
|   bad behavior. You therefore need to tell us: | ||||
|  | ||||
|   Since curl deals with networks, it often helps us a lot if you include a | ||||
|   protocol debug dump with your bug report. The output you get by using the -v | ||||
|    - your operating system's name and 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 (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 | ||||
|   useful when reporting bugs as well. | ||||
|  | ||||
|   | ||||
| @@ -6,15 +6,16 @@ | ||||
|  | ||||
| To Think About When Contributing Source Code | ||||
|  | ||||
|  This document is intended to offer some guidelines that can be useful to keep | ||||
|  in mind when you decide to write a contribution to the project. This concerns | ||||
|  This document is intended to offer some simple guidelines that can be useful | ||||
|  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. | ||||
|  | ||||
| Join the Community | ||||
|  | ||||
|  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 | ||||
|  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 | ||||
|  | ||||
| @@ -29,9 +30,9 @@ The License Issue | ||||
|  | ||||
| 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 | ||||
|  insights on what's going on right now. | ||||
|  insights on what's going on right now. Asking there is a good idea too. | ||||
|  | ||||
| Naming | ||||
|  | ||||
| @@ -39,26 +40,32 @@ Naming | ||||
|  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, | ||||
|  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 | ||||
|  | ||||
|  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 | ||||
|  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 | ||||
|  | ||||
|  Comment your source code extensively. Commented code is quality code and | ||||
|  enables future modifications much more. Uncommented code much more risk being | ||||
|  Comment your source code extensively using C comments (/* comment */), DO NOT | ||||
|  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' | ||||
|  source code can get quite hard to read. | ||||
|  | ||||
| General Style | ||||
|  | ||||
|  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 | ||||
|  | ||||
| @@ -69,7 +76,14 @@ Non-clobbering All Over | ||||
|  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. | ||||
|  | ||||
| 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 | ||||
|  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 | ||||
|  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 | ||||
|  | ||||
|  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 | ||||
|  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! | ||||
|  | ||||
| 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 | ||||
|   | ||||
							
								
								
									
										273
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										273
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| Updated: January 22, 2002 (http://curl.haxx.se/docs/faq.shtml) | ||||
| Updated: June 17, 2003 (http://curl.haxx.se/docs/faq.html) | ||||
|                                   _   _ ____  _      | ||||
|                               ___| | | |  _ \| |     | ||||
|                              / __| | | | |_) | |     | ||||
| @@ -15,6 +15,7 @@ FAQ | ||||
|   1.5 Who makes cURL? | ||||
|   1.6 What do you get for making cURL? | ||||
|   1.7 What about CURL from curl.com? | ||||
|   1.8 I have a problem who do I mail? | ||||
|  | ||||
|  2. Install Related Problems | ||||
|   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.4 How do I tell curl to run custom FTP commands? | ||||
|   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.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.11 How do I POST with a different Content-Type? | ||||
|   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.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.8 I found a bug! | ||||
|   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.1 Is libcurl thread-safe? | ||||
| @@ -62,6 +68,7 @@ FAQ | ||||
|   5.4 Does libcurl do Winsock initing on win32 systems? | ||||
|   5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ? | ||||
|   5.6 What about Keep-Alive or persistent connections? | ||||
|   5.7 Link errors when building libcurl on Windows! | ||||
|  | ||||
|  6. License Issues | ||||
|   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 | ||||
|   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 | ||||
|   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 | ||||
|   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: | ||||
|   [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? | ||||
|  | ||||
|   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 | ||||
|   curl: | ||||
|  | ||||
|   * Curl is to remain a command line tool. If you want GUIs or fancy scripting | ||||
|     capabilities, you're free to write another tool that uses libcurl and that | ||||
|     offers this. There's no point in having a single tool that does every | ||||
|     imaginable thing. That's also one of the great advantages of having the | ||||
|     core of curl as a library. | ||||
|   * Curl -- the command line tool -- is to remain a non-graphical command line | ||||
|     tool. If you want GUIs or fancy scripting capabilities, you should look | ||||
|     for another tool that uses libcurl. | ||||
|  | ||||
|   * 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 | ||||
| @@ -150,10 +163,10 @@ FAQ | ||||
|   1.5 Who makes cURL? | ||||
|  | ||||
|   cURL and libcurl are not made by any single individual. Sure, Daniel | ||||
|   Stenberg writes the major parts, but various people's submissions are | ||||
|   important and crucial. Anyone can post their changes and improvements and | ||||
|   have them inserted in the main sources (of course on the condition that | ||||
|   developers agree on that the fixes are good). | ||||
|   Stenberg writes the major parts, but other persons' submissions are | ||||
|   important and crucial. Anyone can contribute and post their changes and | ||||
|   improvements and have them inserted in the main sources (of course on the | ||||
|   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 people that every day provide us with bug reports, suggestions, ideas | ||||
| @@ -163,23 +176,24 @@ FAQ | ||||
|  | ||||
|   1.6 What do you get for making cURL? | ||||
|  | ||||
|   Project cURL is entirely free and open. No person gets paid in any way for | ||||
|   developing curl. We all do this voluntarily on our spare time. | ||||
|   Project cURL is entirely free and open. No person gets paid for developing | ||||
|   curl. We do this voluntarily on our spare time. | ||||
|  | ||||
|   We get some help from companies. Contactor Data hosts the curl web site and | ||||
|   the main mailing list, Haxx owns the curl web site's domain and | ||||
|   sourceforge.net hosts several project tools we take advantage from like the | ||||
|   bug tracker, mailing lists and more. | ||||
|   We get some help from companies. Contactor Data hosts the curl web site, | ||||
|   Haxx owns the curl web site's domain and sourceforge.net hosts several | ||||
|   project services we take advantage from, like the bug tracker, mailing lists | ||||
|   and more. | ||||
|  | ||||
|   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 | ||||
|   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, | ||||
|   testing etc. | ||||
|   us through a banner-program or even better: by helping us coding, | ||||
|   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? | ||||
|  | ||||
|   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. | ||||
|  | ||||
|   We are in no way associated with curl.com or their CURL programming | ||||
| @@ -192,6 +206,21 @@ FAQ | ||||
|   We recognize that we will be living in parallel with curl.com and wish them | ||||
|   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.1. configure doesn't find OpenSSL even when it is installed | ||||
| @@ -251,8 +280,8 @@ FAQ | ||||
|  | ||||
|   2.4. Does cURL support Socks (RFC 1928) ? | ||||
|  | ||||
|   No. Nobody has wanted it that badly yet. We appreciate patches that bring | ||||
|   this functionality. | ||||
|   There is limited support for SOCKS5 for curl built with IPv6 support | ||||
|   disabled. | ||||
|  | ||||
|  | ||||
| 3. Usage problems | ||||
| @@ -307,16 +336,14 @@ FAQ | ||||
|   the -H/--header option. By adding a header with empty contents you safely | ||||
|   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 | ||||
|   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 | ||||
|   of language that generated the page. | ||||
|  | ||||
|   Javascript is slightly different since that is code embedded in the HTML | ||||
|   that is sent for the client to interpret and curl has no javascript | ||||
|   interpreter. | ||||
|   See also item 3.14 regarding javascript. | ||||
|  | ||||
|   3.7. Can I use curl to delete/rename a file through FTP? | ||||
|  | ||||
| @@ -334,25 +361,22 @@ FAQ | ||||
|  | ||||
|      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 | ||||
|   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 | ||||
|   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 | ||||
|   install and use them, in the libcurl section of the curl web site: | ||||
|  | ||||
|         http://curl.haxx.se/libcurl/ | ||||
|  | ||||
|   In December 2001, there are interfaces available for the following | ||||
|   languages: C/C++, Cocoa, Dylan, Java, Perl, PHP, Python, Rexx, Ruby, Scheme | ||||
|   and Tcl. By the time you read this, additional ones may have appeared! | ||||
|   In February 2003, there are interfaces available for the following | ||||
|   languages: Basic, C, C++, Cocoa, Dylan, Euphoria, Java, Lua, Object-Pascal, | ||||
|   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? | ||||
|  | ||||
| @@ -361,8 +385,8 @@ FAQ | ||||
|   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). | ||||
|  | ||||
|   Using libcurl or PHP's curl modules is just as fine and you'd just use the | ||||
|   proper library options to do the same. | ||||
|   Using libcurl is of course just as fine and you'd just use the proper | ||||
|   library options to do the same. | ||||
|  | ||||
|   3.11 How do I POST with a different Content-Type? | ||||
|  | ||||
| @@ -375,7 +399,7 @@ FAQ | ||||
|  | ||||
|   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 | ||||
|   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. | ||||
|  | ||||
|   There is one exception to this rule, and that is if you can "tunnel through" | ||||
| @@ -383,6 +407,54 @@ FAQ | ||||
|   and is generally not available as proxy admins usually disable tunneling to | ||||
|   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.1. Problems connecting to SSL servers. | ||||
| @@ -411,11 +483,12 @@ FAQ | ||||
|  | ||||
|      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 | ||||
|   need to quote the string properly when % is used in it. | ||||
|   In Windows, the standard DOS shell treats the %-letter specially and you | ||||
|   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 | ||||
|   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? | ||||
|  | ||||
| @@ -427,8 +500,7 @@ FAQ | ||||
|     curl '{curl,www}.haxx.se' | ||||
|  | ||||
|   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 | ||||
|   7.6 and later): | ||||
|   them for the curl URL "globbing" system), use the -g/--globoff option: | ||||
|  | ||||
|     curl -g 'www.site.com/weirdname[].html' | ||||
|  | ||||
| @@ -474,7 +546,7 @@ FAQ | ||||
|  | ||||
|     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 | ||||
|        HREF="http://same_url_now_with_a_trailing_slash/">here</A>. | ||||
| @@ -516,18 +588,56 @@ FAQ | ||||
|   particular platform, try contacting the person who built the package/archive | ||||
|   you have. | ||||
|  | ||||
|   If there is a bug, post a bug report in the Curl Bug Track System over at | ||||
|   http://sourceforge.net/bugs/?group_id=976 | ||||
|  | ||||
|   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. | ||||
|   If there is a bug, read the BUGS document first. Then report it as described | ||||
|   in there. | ||||
|  | ||||
|   4.9. Curl can't authenticate to the server that requires NTLM? | ||||
|  | ||||
|   NTLM is a Microsoft proprietary protocol. Unfortunately, curl does not | ||||
|   currently support that. Proprietary formats are evil. You should not use | ||||
|   such ones. | ||||
|   This is supported in curl 7.10.6 or later. No earlier curl version knows | ||||
|   of this magic. | ||||
|  | ||||
|   NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You | ||||
|   should not use 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 | ||||
|  | ||||
| @@ -579,20 +689,15 @@ FAQ | ||||
|  | ||||
|   5.3 How do I fetch multiple files with libcurl? | ||||
|  | ||||
|   Starting with version 7.7, curl and libcurl will have excellent support for | ||||
|   transferring multiple files. You should just repeatedly set new URLs with | ||||
|   curl_easy_setopt() and then transfer it with curl_easy_perform(). The handle | ||||
|   you get from curl_easy_init() is not only reusable starting with libcurl | ||||
|   7.7, but also you're encouraged to reuse it if you can, as that will enable | ||||
|   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. | ||||
|   libcurl has excellent support for transferring multiple files. You should | ||||
|   just repeatedly set new URLs with curl_easy_setopt() and then transfer it | ||||
|   with curl_easy_perform(). The handle you get from curl_easy_init() is not | ||||
|   only reusable, but you're even encouraged to reuse it if you can, as that | ||||
|   will enable libcurl to use persistent connections. | ||||
|  | ||||
|   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 ? | ||||
|  | ||||
| @@ -606,22 +711,31 @@ FAQ | ||||
|  | ||||
|   5.6 What about Keep-Alive or persistent connections? | ||||
|  | ||||
|   Starting with version 7.7, curl and libcurl will have excellent support for | ||||
|   persistent connections when transferring several files from the same server. | ||||
|   Curl will attempt to reuse connections for all URLs specified on the same | ||||
|   command line/config file, and libcurl will reuse connections for all | ||||
|   transfers that are made using the same libcurl handle. | ||||
|   curl and libcurl have excellent support for persistent connections when | ||||
|   transferring several files from the same server.  Curl will attempt to reuse | ||||
|   connections for all URLs specified on the same command line/config file, and | ||||
|   libcurl will reuse connections for all transfers that are made using the | ||||
|   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 | ||||
|  | ||||
|   Curl and libcurl are released under a MIT/X derivate license *or* the MPL, | ||||
|   the Mozilla Public License. To get a really good answer to your license | ||||
|   conflict questions, you should study the MPL and MIT/X licenses and the | ||||
|   license you are about to use and check for clashes yourself. This section is | ||||
|   just a brief summary for the cases we get the most questions. (Parts of this | ||||
|   section was much enhanced by Bjorn Reese.) | ||||
|   Curl and libcurl are released under a MIT/X derivate license. The license is | ||||
|   very liberal and should not impose a problem for your project. This section | ||||
|   is 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? | ||||
|  | ||||
| @@ -664,6 +778,5 @@ FAQ | ||||
|   discussions and a large amount of people have contributed with source code | ||||
|   knowing that this is the license we use. This license puts the restrictions | ||||
|   we want on curl/libcurl and it does not spread to other programs or | ||||
|   libraries that use it. The recent dual license modification should make it | ||||
|   possible for everyone to use libcurl or curl in their projects, no matter | ||||
|   what license they already have in use. | ||||
|   libraries that use it. It should be possible for everyone to use libcurl or | ||||
|   curl in their projects, no matter what license they already have in use. | ||||
|   | ||||
| @@ -17,27 +17,30 @@ Misc | ||||
|  - progress bar/time specs while downloading | ||||
|  - "standard" proxy environment variables support | ||||
|  - config file support | ||||
|  - compiles on win32 (reported built on 29 operating systems) | ||||
|  - compiles on win32 (reported builds on 40+ operating systems) | ||||
|  - redirectable stderr | ||||
|  - use selected network interface for outgoing traffic | ||||
|  - selectable network interface for outgoing traffic | ||||
|  - IPv6 support | ||||
|  - persistant connections | ||||
|  - socks5 support | ||||
|  - supports user name + password in proxy environment variables | ||||
|  - operations through proxy "tunnel" (using CONNECT) | ||||
|  | ||||
| HTTP | ||||
|  - HTTP/1.1 compliant | ||||
|  - HTTP/1.1 compliant (optionally uses 1.0) | ||||
|  - GET | ||||
|  - PUT | ||||
|  - HEAD | ||||
|  - POST | ||||
|  - multipart POST | ||||
|  - authentication | ||||
|  - multipart formpost (RFC1867-style) | ||||
|  - authentication (Basic, Digest, NTLM(*1), GSS-Negotiate(*3)) | ||||
|  - resume (both GET and PUT) | ||||
|  - follow redirects | ||||
|  - maximum amount of redirects to follow | ||||
|  - custom HTTP request | ||||
|  - cookie get/send fully parsed | ||||
|  - understands the netscape cookie file format | ||||
|  - custom headers (that can replace/remove internally generated headers) | ||||
|  - reads/writes the netscape cookie file format | ||||
|  - custom headers (replace/remove internally generated headers) | ||||
|  - custom user-agent string | ||||
|  - custom referer string | ||||
|  - range | ||||
| @@ -45,12 +48,16 @@ HTTP | ||||
|  - time conditions | ||||
|  - via http-proxy | ||||
|  - retrieve file modification date | ||||
|  - Content-Encoding support for deflate and gzip | ||||
|  - "Transfer-Encoding: chunked" support for "uploads" | ||||
|  | ||||
| HTTPS (*1) | ||||
|  - (all the HTTP features) | ||||
|  - using certificates | ||||
|  - verify server certificate | ||||
|  - via http-proxy | ||||
|  - select desired encryption | ||||
|  - force usage of a specific SSL version (SSLv2, SSLv3 or TLSv1) | ||||
|  | ||||
| FTP | ||||
|  - download | ||||
| @@ -90,5 +97,6 @@ GOPHER | ||||
| FILE | ||||
|  - URL support | ||||
|  | ||||
|         *1 = requires OpenSSL | ||||
|         *2 = requires OpenLDAP | ||||
|   *1 = requires OpenSSL | ||||
|   *2 = requires OpenLDAP | ||||
|   *3 = requires a GSSAPI-compliant library, such as Heimdal or similar. | ||||
|   | ||||
							
								
								
									
										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 | ||||
							
								
								
									
										123
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										123
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -28,11 +28,26 @@ UNIX | ||||
|  | ||||
|    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, | ||||
|    you need to specify that already when running configure: | ||||
|  | ||||
|         ./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 | ||||
|    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 | ||||
| @@ -71,33 +86,6 @@ UNIX | ||||
|      LIBS=-lRSAglue -lrsaref | ||||
|      (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 | ||||
|  | ||||
|      To force configure to use the standard cc compiler if both cc and gcc are | ||||
| @@ -201,33 +189,33 @@ Win32 | ||||
|  | ||||
|       Microsoft command line style | ||||
|       ---------------------------- | ||||
|         Please read the OpenSSL documentation on how to compile and install | ||||
|         the OpenSSL library.  This generates the libeay32.dll and ssleay32.dll | ||||
|         files in the out32dll subdirectory in the OpenSSL home directory.  If | ||||
|         you compiled OpenSSL static libraries (libeay32.lib, ssleay32.lib, | ||||
|         RSAglue.lib) they are created in the out32 subdirectory. | ||||
|  | ||||
|         Run the 'vcvars32.bat' file to get the proper environment variables | ||||
|         set. The vcvars32.bat file is part of the Microsoft development | ||||
|         environment and you may find it in 'C:\Program Files\Microsoft Visual | ||||
|         Studio\vc98\bin' if you installed Visual C/C++ 6 in the default | ||||
|         directory. | ||||
|         Please read the OpenSSL documentation on how to compile and install | ||||
|         the OpenSSL libraries.  The build process of OpenSSL generates the | ||||
|         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 a proper environment. The | ||||
|         vcvars32.bat file is part of the Microsoft development environment and | ||||
|         you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin' | ||||
|         provided that you installed Visual C/C++ 6 in the default directory. | ||||
|  | ||||
|         Before running nmake define the OPENSSL_PATH environment variable with | ||||
|         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 the curl's root | ||||
|         Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root | ||||
|         directory.  'nmake vc-ssl' will create a libcurl static and dynamic | ||||
|         libraries in the lib subdirectory, as well as a statically linked | ||||
|         version of curl.exe in the scr subdirectory.  This 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 making method requires that you have build the static | ||||
|         libraries of OpenSSL available in OpenSSL's out32 subdirectory. | ||||
|         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 executables requires libcurl.dll and the OpenSSL DLLs | ||||
| 	This executable requires libcurl.dll and the OpenSSL DLLs | ||||
| 	at runtime. | ||||
|  | ||||
|       Microsoft / Borland style | ||||
| @@ -236,6 +224,30 @@ Win32 | ||||
|         project properties to use the SSL include path, link with the SSL libs | ||||
|         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 | ||||
| ======== | ||||
| @@ -392,23 +404,37 @@ CROSS COMPILE | ||||
|    The '--prefix' parameter specifies where cURL will be installed.  If | ||||
|    '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 | ||||
| ===== | ||||
|    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! | ||||
|  | ||||
|         - Alpha DEC OSF 4 | ||||
|         - Alpha Digital UNIX v3.2 | ||||
|         - Alpha FreeBSD 4.1 | ||||
|         - Alpha Linux 2.2.16 | ||||
|         - Alpha FreeBSD 4.1, 4.5 | ||||
|         - Alpha Linux 2.2, 2.4 | ||||
|         - Alpha NetBSD 1.5.2 | ||||
|         - Alpha OpenBSD 3.0 | ||||
|         - Alpha OpenVMS V7.1-1H2 | ||||
|         - Alpha Tru64 v5.0 5.1 | ||||
|         - HP-PA HP-UX 9.X 10.X 11.X | ||||
|         - HP-PA Linux | ||||
|         - MIPS IRIX 6.2, 6.5 | ||||
|         - 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 Linux | ||||
|         - PowerPC Mac OS 9 | ||||
| @@ -422,6 +448,7 @@ PORTS | ||||
|         - StrongARM NetBSD 1.4.1 | ||||
|         - Ultrix 4.3a | ||||
|         - i386 BeOS | ||||
|         - i386 DOS | ||||
|         - i386 FreeBSD | ||||
|         - i386 HURD | ||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4 | ||||
| @@ -431,11 +458,15 @@ PORTS | ||||
|         - i386 SCO unix | ||||
|         - i386 Solaris 2.7 | ||||
|         - i386 Windows 95, 98, ME, NT, 2000 | ||||
|         - i386 QNX 6 | ||||
|         - i486 ncr-sysv4.3.03 (NCR MP-RAS) | ||||
|         - ia64 Linux 2.3.99 | ||||
|         - m68k AmigaOS 3 | ||||
|         - m68k Linux | ||||
|         - m68k OpenBSD | ||||
|         - m88k dg-dgux5.4R3.00 | ||||
|         - s390 Linux  | ||||
|         - XScale/PXA250 Linux 2.4 | ||||
|  | ||||
| OpenSSL | ||||
| ======= | ||||
|   | ||||
| @@ -54,7 +54,7 @@ Windows vs Unix | ||||
|  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 | ||||
|  '#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 | ||||
|  Windows machine! | ||||
|  | ||||
| @@ -69,10 +69,10 @@ Library | ||||
|  rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are | ||||
|  put in the lib/easy.c file. | ||||
|  | ||||
|  Starting with libcurl 7.8, curl_global_init_() and curl_global_cleanup() were | ||||
|  introduced. They should be called by the application to initialize and clean | ||||
|  up global stuff in the library. As of today, they just do the global SSL | ||||
|  initing if SSL is enabled. libcurl itself has no "global" scope. | ||||
|  curl_global_init_() and curl_global_cleanup() should be called by the | ||||
|  application to initialize and clean up global stuff in the library. As of | ||||
|  today, it can handle the global SSL initing if SSL is enabled and it can init | ||||
|  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 | ||||
|  makes sure we stay absolutely platform independent. | ||||
|   | ||||
							
								
								
									
										97
									
								
								docs/KNOWN_BUGS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								docs/KNOWN_BUGS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | ||||
| 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! | ||||
|  | ||||
| * LDAP output is garbled. Hardly anyone seems to care about LDAP functionality | ||||
|   in curl/libcurl why this report has been closed and set to be solved later. | ||||
|   If you feel this is something you want fixed, get in touch and we'll start | ||||
|   working. | ||||
|   http://sourceforge.net/tracker/index.php?func=detail&aid=735752&group_id=976&atid=100976 | ||||
|  | ||||
| * 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> | ||||
							
								
								
									
										129
									
								
								docs/MANUAL
									
									
									
									
									
								
							
							
						
						
									
										129
									
								
								docs/MANUAL
									
									
									
									
									
								
							| @@ -11,7 +11,7 @@ SIMPLE USAGE | ||||
|  | ||||
|         curl http://www.netscape.com/ | ||||
|  | ||||
|   Get the root README file from funet's ftp-server: | ||||
|   Get the README file the user's home directory at funet's ftp-server: | ||||
|  | ||||
|         curl ftp://ftp.funet.fi/README | ||||
|  | ||||
| @@ -19,7 +19,7 @@ SIMPLE USAGE | ||||
|  | ||||
|         curl http://www.weirdserver.com:8000/ | ||||
|  | ||||
|   Get a list of the root directory of an FTP site: | ||||
|   Get a list of a directory of an FTP site: | ||||
|  | ||||
|         curl ftp://cool.haxx.se/ | ||||
|  | ||||
| @@ -166,13 +166,21 @@ UPLOADING | ||||
|  | ||||
| VERBOSE / DEBUG | ||||
|  | ||||
|   If curl fails where it isn't supposed to, if the servers don't let you | ||||
|   in, 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 | ||||
|   receives in order to let the user see all client-server interaction. | ||||
|   If curl fails where it isn't supposed to, if the servers don't let you in, | ||||
|   if you can't understand the responses: use the -v flag to get verbose | ||||
|   fetching. Curl will output lots of info and what it sends and receives in | ||||
|   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/ | ||||
|  | ||||
|   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 | ||||
|  | ||||
|   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 | ||||
|   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>' | ||||
|   to the file name. You can also post the contents of several files in one field. | ||||
|   For example, the field name 'coolfiles' is used to send three  files, with | ||||
|   different content types using the following syntax: | ||||
|   to the file name. You can also post the contents of several files in one | ||||
|   field.  For example, the field name 'coolfiles' is used to send three files, | ||||
|   with different content types using the following syntax: | ||||
|  | ||||
|         curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \ | ||||
|         http://www.post.com/postit.cgi | ||||
|  | ||||
|   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 | ||||
|   (from an earlier file if several files are specified in a list) or else it | ||||
|   will  using the default type 'text/plain'. | ||||
|   extension (it only knows a few), or use the previously specified type (from | ||||
|   an earlier file if several files are specified in a list) or else it will | ||||
|   using the default type 'text/plain'. | ||||
|  | ||||
|   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 | ||||
|   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 | ||||
|   favourite browser, you have to read the HTML source of the form page and find | ||||
|   the names of the input fields. In our example, the input field names are | ||||
|   'file', 'yourname' and 'filedescription'. | ||||
|   favourite browser, you have to read the HTML source of the form page and | ||||
|   find the names of the input fields. In our example, the input field names | ||||
|   are 'file', 'yourname' and 'filedescription'. | ||||
|  | ||||
|         curl -F "file=@cooltext.txt" -F "yourname=Daniel" \ | ||||
|              -F "filedescription=Cool text file with cool text inside" \ | ||||
| @@ -350,6 +358,13 @@ COOKIES | ||||
|  | ||||
|         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 | ||||
|   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 | ||||
| @@ -363,7 +378,11 @@ COOKIES | ||||
|   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 | ||||
|   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 | ||||
|  | ||||
| @@ -404,12 +423,34 @@ SPEED LIMIT | ||||
|   To have curl abort the download if the speed is slower than 3000 bytes per | ||||
|   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 | ||||
|   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 | ||||
|  | ||||
| @@ -548,7 +589,7 @@ HTTPS | ||||
|   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 | ||||
|   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 | ||||
|   may need to download/compile a converter that can convert your browser's | ||||
|   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 | ||||
|   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 | ||||
|   to use: | ||||
|   SSL-version curl should use. Use -3, -2 or -1 to specify that exact SSL | ||||
|   version to use (for SSLv3, SSLv2 or TLSv1 respectively): | ||||
|  | ||||
|         curl -2 https://secure.site.com/ | ||||
|  | ||||
| @@ -689,7 +730,7 @@ 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 | ||||
|   set with | ||||
| @@ -716,9 +757,9 @@ NETRC | ||||
|   passwords, so therefor most unix programs won't read this file unless it is | ||||
|   only readable by yourself (curl doesn't care though). | ||||
|  | ||||
|   Curl supports .netrc files if told so (using the -n/--netrc option). This is | ||||
|   not restricted to only ftp, but curl can use it for all protocols where | ||||
|   authentication is used. | ||||
|   Curl supports .netrc files if told so (using the -n/--netrc and | ||||
|   --netrc-optional options). This is not restricted to only ftp, | ||||
|   but curl can use it for all protocols where authentication is used. | ||||
|  | ||||
|   A very simple .netrc file could look something like: | ||||
|  | ||||
| @@ -800,19 +841,39 @@ PERSISTANT CONNECTIONS | ||||
| MAILING LISTS | ||||
|  | ||||
|   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 | ||||
|   "subscribe <fill in your email address>" in the body. | ||||
|   curl-users | ||||
|  | ||||
|   To subscribe to the curl-library users/deverlopers list, follow the | ||||
|   instructions at http://curl.haxx.se/mail/ | ||||
|     Users of the command line tool. How to use it, what doesn't work, new | ||||
|     features, related tools, questions, news, installations, compilations, | ||||
|     running, porting etc. | ||||
|  | ||||
|   To subscribe to the curl-announce list, to only get information about new | ||||
|   releases, follow the instructions at http://curl.haxx.se/mail/ | ||||
|   curl-library | ||||
|  | ||||
|   To subscribe to the curl-and-PHP list in which curl using with PHP is | ||||
|   discussed, follow the instructions at http://curl.haxx.se/mail/ | ||||
|     Developers using or developing libcurl. Bugs, extensions, improvements. | ||||
|  | ||||
|   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 | ||||
|   these mailing lists instead of mailing any individual. | ||||
|   | ||||
| @@ -6,72 +6,43 @@ AUTOMAKE_OPTIONS = foreign no-dependencies | ||||
|  | ||||
| man_MANS = \ | ||||
| 	curl.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 | ||||
| 	curl-config.1 | ||||
|  | ||||
| HTMLPAGES = \ | ||||
| 	curl.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 | ||||
|  | ||||
| EXTRA_DIST = $(man_MANS) \ | ||||
| 	MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \ | ||||
| 	README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS \ | ||||
| 	VERSIONS $(HTMLPAGES) | ||||
| PDFPAGES = \ | ||||
| 	curl.pdf \ | ||||
| 	curl-config.pdf | ||||
|  | ||||
| SUBDIRS = examples libcurl | ||||
|  | ||||
| EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS	\ | ||||
| 	     README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS	\ | ||||
| 	     VERSIONS KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) \ | ||||
| 	     HISTORY INSTALL libcurl-the-guide $(PDFPAGES) | ||||
|  | ||||
| MAN2HTML= gnroff -man $< | man2html >$@ | ||||
|  | ||||
| SUFFIXES = .1 .3 .html | ||||
| SUFFIXES = .1 .3 .html .pdf | ||||
|  | ||||
| html: $(HTMLPAGES) | ||||
| 	cd libcurl; make html | ||||
|  | ||||
| .3.html: | ||||
| 	$(MAN2HTML) | ||||
|  | ||||
| .1.html: | ||||
| 	$(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 | ||||
|   | ||||
| @@ -13,8 +13,8 @@ README.win32 | ||||
|   are win32-based. | ||||
|  | ||||
|   The unix-style man pages are tricky to read on windows, so therefore are all | ||||
|   those pages also converted to HTML and those are also included in the | ||||
|   release archives. | ||||
|   those pages converted to HTML as well as pdf, and included in the release | ||||
|   archives. | ||||
|  | ||||
|   The main curl.1 man page is also "built-in" in the command line tool. Use a | ||||
|   command line similar to this in order to extract a separate text file: | ||||
|   | ||||
| @@ -5,10 +5,9 @@ | ||||
|                              \___|\___/|_| \_\_____| | ||||
|  | ||||
|  | ||||
| This document has been introduced in order to let you find documents that | ||||
| specify standards used by curl, software that extends curl, web pages with | ||||
| "competing" utilities and information pages that describe some of the tools | ||||
| that we use to build/compile/develop curl. | ||||
| This document lists documents that specify standards used by curl, software | ||||
| that extends curl, web pages with similar utilities and information pages that | ||||
| describe some of the tools that we use to build/compile/develop curl. | ||||
|  | ||||
| Standards | ||||
| --------- | ||||
|   | ||||
							
								
								
									
										39
									
								
								docs/SSLCERTS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								docs/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. | ||||
							
								
								
									
										12
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -79,3 +79,15 @@ that have contributed with non-trivial parts: | ||||
|  - Eric Lavigne <erlavigne@wanadoo.fr> | ||||
|  - Marcus Webster <marcus.webster@phocis.com> | ||||
|  - 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> | ||||
|  - Daniel Kouril <kouril@ics.muni.cz> | ||||
|   | ||||
							
								
								
									
										139
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										139
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -6,114 +6,87 @@ | ||||
|  | ||||
| TODO | ||||
|  | ||||
|  Things to do in project cURL. Please tell me what you think, contribute and | ||||
|  send me patches that improve things! Also check the http://curl.haxx.se/dev | ||||
|  web section for various development notes. | ||||
|  Things to do in project cURL. Please tell us what you think, contribute and | ||||
|  send us patches that improve things! Also check the http://curl.haxx.se/dev | ||||
|  web section for various technical development notes. | ||||
|  | ||||
|  LIBCURL | ||||
|  | ||||
|  * Consider an interface to libcurl that allows applications to easier get to | ||||
|    know what cookies that are sent back in the response headers. | ||||
|  * Introduce an interface to libcurl that allows applications to easier get to | ||||
|    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. http://curl.haxx.se/dev/COOKIES | ||||
|  | ||||
|  * 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/lxr/source/lib/multi.h] | ||||
|  | ||||
|  * Introduce another callback interface for upload/download that makes one | ||||
|    less copy of data and thus a faster operation. | ||||
|    [http://curl.haxx.se/dev/no_copy_callbacks.txt] | ||||
|  | ||||
|  * Add configure options that disables certain protocols in libcurl to | ||||
|    decrease footprint.  '--disable-[protocol]' where protocol is http, ftp, | ||||
|    telnet, ldap, dict or file. | ||||
|  | ||||
|  * Add asynchronous name resolving. http://curl.haxx.se/dev/async-resolver.txt | ||||
|    This should be made to work on most of the supported platforms, or | ||||
|    otherwise it isn't really interesting. | ||||
|  * Add asynchronous name resolving (http://libdenise.sf.net/). This should be | ||||
|    made to work on most of the supported platforms, or otherwise it isn't | ||||
|    really interesting. | ||||
|  | ||||
|  * Data sharing. Tell which easy handles within a multi handle that should | ||||
|    share cookies, connection cache, dns cache, ssl session cache. | ||||
|    share cookies, connection cache, dns cache, ssl session cache.  Full | ||||
|    suggestion found here: http://curl.haxx.se/dev/sharing.txt | ||||
|  | ||||
|  * 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. | ||||
|  | ||||
|  * No-faster-then-this transfers. Many people have limited bandwidth and they | ||||
|    want the ability to make sure their transfers never use more bandwith than | ||||
|    they think is good. | ||||
|    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. | ||||
|  | ||||
|  * Make sure we don't ever loop because of non-blocking sockets return | ||||
|    EWOULDBLOCK or similar. This concerns the HTTP request sending (and | ||||
|    especially regular HTTP POST), the FTP command sending etc. | ||||
|  | ||||
|  * Go through the code and verify that libcurl deals with big files >2GB and | ||||
|    >4GB all over. Bug reports indicate that it doesn't currently work | ||||
|    properly. | ||||
|    >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. | ||||
|  | ||||
|  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 | ||||
|  | ||||
|  * Document all CURLcode error codes, why they happen and what most likely | ||||
|    will make them not happen again. In a libcurl point of view. | ||||
|  * More and better | ||||
|  | ||||
|  FTP | ||||
|  | ||||
|  * 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 | ||||
|    8-bit NVT-ASCII representation (see the Telnet specification).  The | ||||
|    receiver will convert the data from the standard form to his own internal | ||||
|    form." | ||||
|  * Make CURLOPT_FTPPORT support an additional port number on the IP/if/name, | ||||
|    like "blabla:[port]" or possibly even "blabla:[portfirst]-[portsecond]". | ||||
|  | ||||
|  * 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 | ||||
|    already working http dito works. It of course requires that 'MDTM' works, | ||||
|    and it isn't a standard FTP command. | ||||
|  * FTP ASCII transfers do not follow RFC959. They don't convert the data | ||||
|    accordingly. | ||||
|  | ||||
|  * Add FTPS support with SSL for the data connection too. | ||||
|  * Since USERPWD always override the user and password specified in URLs, we | ||||
|    might need another way to specify user+password for anonymous ftp logins. | ||||
|  | ||||
|  * 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-11.txt, | ||||
|    "Securing FTP with TLS", valid until September 27th 2003. | ||||
|    http://curl.haxx.se/rfc/draft-murray-auth-ftp-ssl-11.txt | ||||
|  | ||||
|  HTTP | ||||
|  | ||||
|  * HTTP PUT for files passed on stdin *OR* when the --crlf option is | ||||
|    used. Requires libcurl to send the file with chunked content | ||||
|    encoding. [http://curl.haxx.se/dev/HTTP-PUT-stdin.txt] When the filter | ||||
|    system mentioned above gets real, it'll be a piece of cake to add. | ||||
|  | ||||
|  * Pass a list of host name to libcurl to which we allow the user name and | ||||
|    password to get sent to. Currently, it only get sent to the host name that | ||||
|    the first URL uses (to prevent others from being able to read it), but this | ||||
|    also prevents the authentication info from getting sent when following | ||||
|    locations to legitimate other host names. | ||||
|  | ||||
|  * "Content-Encoding: compress/gzip/zlib" HTTP 1.1 clearly defines how to get | ||||
|    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. MS proxies and servers sometime require that. Since that | ||||
|    protocol is a proprietary one, it involves reverse engineering and network | ||||
|    sniffing. This should however be a library-based functionality. There are a | ||||
|    few different efforts "out there" to make open source HTTP clients support | ||||
|    this and it should be possible to take advantage of other people's hard | ||||
|    work. http://modntlm.sourceforge.net/ is one. There's a web page at | ||||
|    http://www.innovation.ch/java/ntlm.html that contains detailed reverse- | ||||
|    engineered info. | ||||
|  | ||||
|  * RFC2617 compliance, "Digest Access Authentication" A valid test page seem | ||||
|    to exist at: http://hopf.math.nwu.edu/testpage/digest/ And some friendly | ||||
|    person's server source code is available at | ||||
|    http://hopf.math.nwu.edu/digestauth/index.html Then there's the Apache | ||||
|    mod_digest source code too of course.  It seems as if Netscape doesn't | ||||
|    support this, and not many servers do. Although this is a lot better | ||||
|    authentication method than the more common "Basic". Basic sends the | ||||
|    password in cleartext over the network, this "Digest" method uses a | ||||
|    challange-response protocol which increases security quite a lot. | ||||
|  * Digest, NTLM and GSS-Negotiate support for HTTP proxies. They all work | ||||
|    on direct-connections to the server. | ||||
|  | ||||
|  * Pipelining. Sending multiple requests before the previous one(s) are done. | ||||
|    This could possibly be implemented using the multi interface to queue | ||||
| @@ -167,6 +140,12 @@ TODO | ||||
|  | ||||
|  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" | ||||
|  | ||||
|  * Several URLs can be specified to get downloaded. We should be able to use | ||||
| @@ -192,6 +171,9 @@ TODO | ||||
|  | ||||
|  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 | ||||
|    ftp or http operations (for which we have test servers). | ||||
|  | ||||
| @@ -199,3 +181,10 @@ TODO | ||||
|    fork()s and it should become even more portable. | ||||
|  | ||||
|  * 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 | ||||
| .\" Written by Daniel Stenberg | ||||
| .\" | ||||
| .TH curl-config 1 "21 January 2002" "Curl 7.9.3" "curl-config manual" | ||||
| .TH curl-config 1 "8 Oct 2002" "Curl 7.10" "curl-config manual" | ||||
| .SH NAME | ||||
| curl-config \- Get information about a libcurl installation | ||||
| .SH SYNOPSIS | ||||
| @@ -11,6 +11,8 @@ curl-config \- Get information about a libcurl installation | ||||
| .B curl-config | ||||
| displays information about a previous curl and libcurl installation. | ||||
| .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" | ||||
|   | ||||
							
								
								
									
										355
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										355
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | ||||
| .\" nroff -man curl.1 | ||||
| .\" Written by Daniel Stenberg | ||||
| .\" | ||||
| .TH curl 1 "30 Nov 2001" "Curl 7.9.2" "Curl Manual" | ||||
| .TH curl 1 "18 June 2003" "Curl 7.10.6" "Curl Manual" | ||||
| .SH NAME | ||||
| curl \- transfer a URL | ||||
| .SH SYNOPSIS | ||||
| @@ -10,14 +10,18 @@ curl \- transfer a URL | ||||
| .I [URL...] | ||||
| .SH DESCRIPTION | ||||
| .B curl | ||||
| is a client to get documents/files from or send documents to a server, using | ||||
| any of the supported protocols (HTTP, HTTPS, FTP, GOPHER, DICT, TELNET, LDAP | ||||
| or FILE). The command is designed to work without user interaction or any kind | ||||
| of interactivity. | ||||
| is a tool to transfer data from or to a server, using one of the supported | ||||
| protocols (HTTP, HTTPS, FTP, FTPS, GOPHER, DICT, TELNET, LDAP or FILE). The | ||||
| command is designed to work without user interaction. | ||||
|  | ||||
| curl offers a busload of useful tricks like proxy support, user | ||||
| authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file | ||||
| transfer resume and more. | ||||
| transfer resume and more. As you will see below, the amount of features will | ||||
| make your head spin! | ||||
|  | ||||
| curl is powered by libcurl for all transfer-related features. See | ||||
| .BR libcurl (3) | ||||
| for details. | ||||
| .SH URL | ||||
| The URL syntax is protocol dependent. You'll find a detailed description in | ||||
| RFC 2396. | ||||
| @@ -48,10 +52,8 @@ specified on a single command line and cannot be used between separate curl | ||||
| invokes. | ||||
| .SH OPTIONS | ||||
| .IP "-a/--append" | ||||
| (FTP) | ||||
| When used in a ftp upload, this will tell curl to append to the target | ||||
| file instead of overwriting it. If the file doesn't exist, it will | ||||
| be created. | ||||
| (FTP) When used in an FTP upload, this will tell curl to append to the target | ||||
| file instead of overwriting it. If the file doesn't exist, it will be created. | ||||
|  | ||||
| If this option is used twice, the second one will disable append mode again. | ||||
| .IP "-A/--user-agent <agent string>" | ||||
| @@ -63,6 +65,16 @@ surround the string with single quote marks.  This can also be set with the | ||||
|  | ||||
| If this option is set more than once, the last one will be the one that's | ||||
| used. | ||||
| .IP "--anyauth" | ||||
| (HTTP) Tells curl to figure out authentication method by itself, and use the | ||||
| most secure one the remote site claims it supports. This is done by first | ||||
| doing a request and checking the response-headers, thus inducing an extra | ||||
| network round-trip. This is used instead of setting a specific authentication | ||||
| method, which you can do with \fI--digest\fP, \fI--ntlm\fP, and | ||||
| \fI--negotiate\fP. (Added in 7.10.6) | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "-b/--cookie <name=data>" | ||||
| (HTTP) | ||||
| Pass the data to the HTTP server as a cookie. It is supposedly the | ||||
| @@ -90,19 +102,30 @@ also be enforced by using an URL that ends with ";type=A". This option causes | ||||
| data sent to stdout to be in text mode for win32 systems. | ||||
|  | ||||
| If this option is used twice, the second one will disable ASCII usage. | ||||
| .IP "--basic" | ||||
| (HTTP) Tells curl to use HTTP Basic authentication. This is the default and | ||||
| this option is usually pointless, unless you use it to override a previously | ||||
| set option that sets a different authentication method (such as \fI--ntlm\fP, | ||||
| \fI--digest\fP and \fI--negotiate\fP). (Added in 7.10.6) | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "--ciphers <list of ciphers>" | ||||
| (SSL) Specifies which ciphers to use in the connection. The list of ciphers | ||||
| 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) | ||||
|  | ||||
| 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 one of the algorithms libcurl | ||||
| supports, and return the uncompressed document.  If this option is used and | ||||
| the server sends an unsupported encoding, Curl will report an error. | ||||
|  | ||||
| If this option is used several times, each occurrence will toggle it on/off. | ||||
| .IP "--connect-timeout <seconds>" | ||||
| 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 | ||||
| of no more use. This option didn't work in win32 systems until 7.7.2.  See | ||||
| also the | ||||
| .I "--max-time" | ||||
| option. | ||||
| of no more use. See also the \fI--max-time\fP option. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-c/--cookie-jar <file name>" | ||||
| @@ -113,6 +136,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 | ||||
| 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 | ||||
| used. | ||||
| .IP "-C/--continue-at <offset>" | ||||
| @@ -125,6 +154,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. | ||||
|  | ||||
| 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>" | ||||
| (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 | ||||
| @@ -162,21 +198,40 @@ want to post a binary file without the strip-newlines feature of the | ||||
|  | ||||
| If this option is used several times, the ones following the first will | ||||
| append data. | ||||
| .IP "--digest" | ||||
| (HTTP) Enables HTTP Digest authentication. This is a authentication that | ||||
| prevents the password from being sent over the wire in clear text. Use this in | ||||
| combination with the normal -u/--user option to set user name and | ||||
| password. See also \fI--ntlm\fP, \fP--negotiate\fI and \fI--anyauth\fP for | ||||
| related options. (Added in curl 7.10.6) | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "--disable-eprt" | ||||
| (FTP) Tell curl to disable the use of the EPRT and LPRT commands when doing | ||||
| active FTP transfers. Curl will normally always first attempt to use EPRT, | ||||
| then LPRT before using PORT, but with this option, it will use PORT right | ||||
| away. EPRT and LPRT are extensions to the original FTP protocol, may not work | ||||
| on all servers but enable more functionality in a better way than the | ||||
| traditional PORT command. (Aded in 7.10.5) | ||||
|  | ||||
| If this option is used several times, each occurrence will toggle this on/off. | ||||
| .IP "--disable-epsv" | ||||
| (FTP) Tell curl to disable the use of the EPSV command when doing passive FTP | ||||
| downloads. Curl will normally always first attempt to use EPSV before PASV, | ||||
| transfers. Curl will normally always first attempt to use EPSV before PASV, | ||||
| 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>" | ||||
| (HTTP/FTP) | ||||
| Write the HTTP headers to this file. Write the FTP file info to this | ||||
| file if -I/--head is used. | ||||
| Write the protocol headers to the specified file. | ||||
|  | ||||
| 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 | ||||
| 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. | ||||
| .IP "-e/--referer <URL>" | ||||
| (HTTP) Sends the "Referer Page" information to the HTTP server. This can also | ||||
| @@ -187,6 +242,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. | ||||
|  | ||||
| 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>" | ||||
| (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 | ||||
| @@ -203,17 +264,32 @@ certificate concatenated! | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--cacert <CA certificate>" | ||||
| (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. | ||||
| .IP "-f/--fail" | ||||
| (HTTP) | ||||
| 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 normal cases when a HTTP server fails to deliver a | ||||
| document, it returns a HTML document stating so (which often also | ||||
| describes why and more). This flag will prevent curl from | ||||
| outputting that and fail silently instead. | ||||
| (HTTP) 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 | ||||
| normal cases when a HTTP server fails to deliver a document, it returns a HTML | ||||
| document stating so (which often also 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. | ||||
| .IP "-F/--form <name=content>" | ||||
| @@ -230,24 +306,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 | ||||
| input: | ||||
|  | ||||
| .B curl | ||||
| -F password=@/etc/passwd www.mypasswords.com | ||||
| \fBcurl\fP -F password=@/etc/passwd www.mypasswords.com | ||||
|  | ||||
| To read the file's content from stdin insted of a file, use - where the file | ||||
| 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. | ||||
| .IP "-g/--globoff" | ||||
| 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 | ||||
| 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 | ||||
| added in curl 7.6) | ||||
| contents but they should be encoded according to the URI standard. | ||||
| .IP "-G/--get" | ||||
| 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 | ||||
| that otherwise would be used. The data will be appended to the URL with a '?' | ||||
| 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" | ||||
| Usage help. | ||||
| .IP "-H/--header <header>" | ||||
| @@ -260,7 +346,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 | ||||
| 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" | ||||
| (HTTP) | ||||
| Include the HTTP-header in the output. The HTTP-header includes things | ||||
| @@ -281,6 +367,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. | ||||
|  | ||||
| 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>" | ||||
| (FTP) Enable kerberos4 authentication and use. The level must be entered and | ||||
| should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use | ||||
| @@ -298,7 +401,26 @@ treated as a comment. | ||||
|  | ||||
| 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. | ||||
| .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" | ||||
| (FTP) | ||||
| When listing an FTP directory, this switch forces a name-only view. | ||||
| @@ -306,23 +428,34 @@ 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 | ||||
| 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. | ||||
| .IP "-L/--location" | ||||
| (HTTP/HTTPS) If the server reports that the requested page has a different | ||||
| location (indicated with the header line Location:) this flag will let curl | ||||
| attempt to reattempt the get on the new place. If used together with -i or -I, | ||||
| headers from all requested pages will be shown. If this flag is used when | ||||
| making a HTTP POST, curl will automatically switch to GET after the initial | ||||
| POST has been done. | ||||
| headers from all requested pages will be shown. If authentication is used, | ||||
| curl will only send its credentials to the initial host, so if a redirect | ||||
| takes curl to a different host, it won't intercept the user+password. See also | ||||
| \fI--location-trusted\fP on how to change this. | ||||
|  | ||||
| If this option is used twice, the second will again disable location following. | ||||
| .IP "--location-trusted" | ||||
| (HTTP/HTTPS) Like \fI--location\fP, but will allow sending the name + password | ||||
| to all hosts that the site may redirect to. This may or may not introduce a | ||||
| security breach if the site redirects you do a site to which you'll send your | ||||
| authentication info (which is plaintext in the case of HTTP Basic | ||||
| authentication). | ||||
|  | ||||
| If this option is used twice, the second will again disable location following. | ||||
| .IP "-m/--max-time <seconds>" | ||||
| 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 | ||||
| networks or links going down.  This doesn't work fully in win32 systems. | ||||
| See also the | ||||
| .I "--connect-timeout" | ||||
| option. | ||||
| networks or links going down.  This doesn't work fully in win32 systems.  See | ||||
| also the \fI--connect-timeout\fP option. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-M/--manual" | ||||
| @@ -349,6 +482,19 @@ to allow curl to ftp to the machine host.domain.com with user name | ||||
| .B "machine host.domain.com login myself password secret" | ||||
|  | ||||
| If this option is used twice, the second will again disable netrc usage. | ||||
| .IP "--negotiate" | ||||
| (HTTP) Enables GSS-Negotiate authentication. The GSS-Negotiate method was | ||||
| designed by Microsoft and is used in their web aplications. It is primarily | ||||
| meant as a support for Kerberos5 authentication but may be also used along | ||||
| with another authentication methods. For more information see IETF draft | ||||
| draft-brezak-spnego-http-04.txt. (Added in 7.10.6) | ||||
|  | ||||
| \fBNOTE\fP that this option requiures that the library was built with GSSAPI | ||||
| support. This is not very common. Use \fIcurl --version\fP to see if your | ||||
| version supports GSS-Negotiate. | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "-N/--no-buffer" | ||||
| Disables the buffering of the output stream. In normal work situations, curl | ||||
| will use a standard buffered output stream that will have the effect that it | ||||
| @@ -356,6 +502,19 @@ will output the data in chunks, not necessarily exactly when the data arrives. | ||||
| Using this option will disable that buffering. | ||||
|  | ||||
| If this option is used twice, the second will again switch on buffering. | ||||
| .IP "--ntlm" | ||||
| (HTTP) Enables NTLM authentication. The NTLM authentication method was | ||||
| designed by Microsoft and is used by IIS web servers. It is a proprietary | ||||
| protocol, reversed engineered by clever people and implemented in curl based | ||||
| on their efforts. This kind of behavior should not be endorsed, you should | ||||
| encourage everyone who uses NTLM to switch to a public and documented | ||||
| authentication method instead. Such as Digest. (Added in 7.10.6) | ||||
|  | ||||
| \fBNOTE\fP that this option requiures that the library was built with SSL | ||||
| support. Use \fIcurl --version\fP to see if your version supports NTLM. | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "-o/--output <file>" | ||||
| Write output to <file> instead of stdout. If you are using {} or [] to fetch | ||||
| multiple documents, you can use '#' followed by a number in the <file> | ||||
| @@ -369,9 +528,11 @@ or use several variables like: | ||||
|   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. | ||||
|  | ||||
| See also the --create-dirs option to create the local directories dynamically. | ||||
| .IP "-O/--remote-name" | ||||
| 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.) | ||||
| 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.) | ||||
|  | ||||
| You may use this option as many times as you have number of URLs. | ||||
| .IP "-p/--proxytunnel" | ||||
| @@ -479,6 +640,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. | ||||
|  | ||||
| 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>" | ||||
| Pass options to the telnet protocol. Supported options are: | ||||
|  | ||||
| @@ -498,10 +665,31 @@ 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. | ||||
|  | ||||
| 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 | ||||
| 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 | ||||
| 7.9.7) | ||||
| .IP "-u/--user <user:password>" | ||||
| Specify user and password to use when fetching. See README.curl for detailed | ||||
| examples of how to use this. If no password is specified, curl will | ||||
| ask for it interactively. | ||||
| 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 ask for it | ||||
| interactively. | ||||
|  | ||||
| You can also use the --digest option to enable Digest authentication when | ||||
| communicating with HTTP 1.1 servers. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-U/--proxy-user <user:password>" | ||||
| @@ -519,15 +707,30 @@ or the | ||||
| .I -O | ||||
| options. | ||||
| .IP "-v/--verbose" | ||||
| Makes the fetching more verbose/talkative. Mostly usable for | ||||
| debugging. Lines starting with '>' means data sent by curl, '<' | ||||
| means data received by curl that is hidden in normal cases and lines | ||||
| starting with '*' means additional info provided by curl. | ||||
| Makes the fetching more verbose/talkative. Mostly usable for debugging. Lines | ||||
| starting with '>' means data sent by curl, '<' means data received by curl | ||||
| that is hidden in normal cases and lines starting with '*' means additional | ||||
| 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. | ||||
| .IP "-V/--version" | ||||
| Displays the full version of curl, libcurl and other 3rd party libraries | ||||
| linked with the executable. | ||||
| Displays information about curl and the libcurl version it uses. | ||||
|  | ||||
| The first line includes the full version of curl, libcurl and other 3rd party | ||||
| libraries linked with the executable. | ||||
|  | ||||
| The second line (starts with "Protocols:") shows all protocols that libcurl | ||||
| reports to support. | ||||
|  | ||||
| The third line (starts with "Features:") shows specific features libcurl | ||||
| reports to offer. | ||||
|  | ||||
| .IP "-w/--write-out <format>" | ||||
| Defines what to display after a completed and successful operation. The format | ||||
| is a string that may contain plain text mixed with any number of variables. The | ||||
| @@ -594,6 +797,9 @@ The average download speed that curl measured for the complete download. | ||||
| .TP | ||||
| .B speed_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 | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| @@ -601,6 +807,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 | ||||
| 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 | ||||
| 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 | ||||
| @@ -623,6 +833,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 | ||||
| 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. | ||||
| .IP "-Y/--speed-limit <speed>" | ||||
| If a download is slower than this given speed, in bytes per second, for | ||||
| @@ -645,6 +858,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 | ||||
| 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. | ||||
| .IP "-3/--sslv3" | ||||
| (HTTPS) | ||||
| @@ -660,16 +879,6 @@ Make curl display progress information as a progress bar instead of the | ||||
| default statistics. | ||||
|  | ||||
| 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 | ||||
| .I ~/.curlrc | ||||
| .RS | ||||
| @@ -731,13 +940,15 @@ FTP couldn't set binary. Couldn't change transfer method to binary. | ||||
| .IP 18 | ||||
| Partial file. Only a part of the file was transfered. | ||||
| .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 | ||||
| FTP write error. The transfer was reported bad by the server. | ||||
| .IP 21 | ||||
| FTP quote error. A quote command returned error from the server. | ||||
| .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. | ||||
| .IP 23 | ||||
| Write error. Curl couldn't write data to a local filesystem or similar. | ||||
| @@ -799,6 +1010,24 @@ Malformed telnet option. | ||||
| The remote peer's SSL certificate wasn't ok | ||||
| .IP 52 | ||||
| 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 | ||||
| There will appear more error codes here in future releases. The existing ones | ||||
| 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 | ||||
|  | ||||
| EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c \ | ||||
| 	     win32sockets.c persistant.c ftpget.c Makefile.example \ | ||||
| 	     multithread.c getinmemory.c ftpupload.c httpput.c \ | ||||
| 	     simplessl.c ftpgetresp.c http-post.c | ||||
| EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c		\ | ||||
| 	     persistant.c ftpget.c Makefile.example			\ | ||||
| 	     multithread.c getinmemory.c ftpupload.c httpput.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 makefile.dj | ||||
|  | ||||
| all: | ||||
| 	@echo "done" | ||||
|   | ||||
| @@ -35,7 +35,7 @@ LIBS = -lcurl -lsocket -lnsl -lssl -lcrypto -dl | ||||
|  | ||||
| # Link the target with all objects and libraries | ||||
| $(TARGET) : $(OBJS) | ||||
| 	$(CC) $(LDFLAGS) $(LIBS) -o $(TARGET) $(OBJS) | ||||
| 	$(CC)  -o $(TARGET) $(OBJS) $(LDFLAGS) $(LIBS) | ||||
|  | ||||
| # Compile the source files into object files | ||||
| ftpget.o : ftpget.c | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| EXAMPLES | ||||
|  | ||||
| This directory is for tiny libcurl programming examples. They are meant to | ||||
| show some simple steps on how you can build your own application to take full | ||||
| This directory is for libcurl programming examples. They are meant to show | ||||
| some simple steps on how you can build your own application to take full | ||||
| advantage of libcurl. | ||||
|  | ||||
| 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: | ||||
|  | ||||
|   $ 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 | ||||
|   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. | ||||
|   $ `curl-config --cc` -o example example.c `curl-config --cflags --libs` | ||||
|  | ||||
| *PLEASE* do not use the curl.haxx.se site as a test target for your libcurl | ||||
| 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); | ||||
| } | ||||
|  | ||||
| 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);*/ | ||||
|   gdk_threads_enter(); | ||||
| @@ -50,6 +54,7 @@ void *curl_thread(void *ptr) | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, url); | ||||
|     curl_easy_setopt(curl, CURLOPT_FILE, outfile); | ||||
|     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_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 <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 | ||||
|   | ||||
| @@ -74,6 +74,10 @@ int main(int argc, char **argv) | ||||
|    * bytes big and contains the remote file. | ||||
|    * | ||||
|    * 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; | ||||
|   | ||||
							
								
								
									
										31
									
								
								docs/examples/makefile.dj
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								docs/examples/makefile.dj
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| # | ||||
| #  Adapted for djgpp / Watt-32 / DOS by | ||||
| #  Gisle Vanem <giva@bgnett.no> | ||||
| # | ||||
|  | ||||
| include ../../packages/DOS/common.dj | ||||
|  | ||||
| CFLAGS += -I../../include | ||||
|  | ||||
| LIBS = ../../lib/libcurl.a | ||||
|  | ||||
| ifeq ($(USE_SSL),1) | ||||
|   LIBS += $(OPENSSL_ROOT)/lib/libssl.a $(OPENSSL_ROOT)/lib/libcrypt.a | ||||
| endif | ||||
|  | ||||
| LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a | ||||
|  | ||||
| PROGRAMS  = fopen.exe ftpget.exe ftpgetre.exe ftpuploa.exe getinmem.exe \ | ||||
|             http-pos.exe httpput.exe multi-ap.exe multi-do.exe          \ | ||||
|             multi-po.exe multi-si.exe persista.exe post-cal.exe         \ | ||||
|             postit2.exe sepheade.exe simple.exe simpless.exe | ||||
|  | ||||
| all: $(PROGRAMS) | ||||
|  | ||||
| .c.exe: | ||||
| 	$(CC) $(CFLAGS) -o $@ $^ $(LIBS) | ||||
| 	@echo | ||||
|  | ||||
| clean: | ||||
| 	rm -f $(PROGRAMS) | ||||
|  | ||||
| @@ -1,4 +1,12 @@ | ||||
| /*
 | ||||
| /*****************************************************************************
 | ||||
|  *                                  _   _ ____  _      | ||||
|  *  Project                     ___| | | |  _ \| |     | ||||
|  *                             / __| | | | |_) | |     | ||||
|  *                            | (__| |_| |  _ <| |___  | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * This is an example application source code using the multi interface. | ||||
|  */ | ||||
| 
 | ||||
| @@ -9,10 +17,8 @@ | ||||
| #include <sys/time.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| 
 | ||||
| /* To start with, we include the header from the lib directory. This should
 | ||||
|    later of course be moved to the proper include dir. */ | ||||
| #include "../lib/multi.h" | ||||
| /* curl stuff */ | ||||
| #include <curl/curl.h> | ||||
| 
 | ||||
| /*
 | ||||
|  * Download a HTTP file and upload an FTP file simultaneously. | ||||
| @@ -77,7 +83,8 @@ int main(int argc, char **argv) | ||||
|     default: | ||||
|       /* one or more of curl's file descriptors say there's data to read
 | ||||
|          or write */ | ||||
|       curl_multi_perform(multi_handle, &still_running); | ||||
|       while(CURLM_CALL_MULTI_PERFORM == | ||||
|             curl_multi_perform(multi_handle, &still_running)); | ||||
|       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> | ||||
| @@ -9,9 +17,8 @@ | ||||
| #include <sys/time.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| /* To start with, we include the header from the lib directory. This should
 | ||||
|    later of course be moved to the proper include dir. */ | ||||
| #include "../lib/multi.h" | ||||
| /* curl stuff */ | ||||
| #include <curl/curl.h> | ||||
| 
 | ||||
| /*
 | ||||
|  * Simply download two HTTP files! | ||||
| @@ -73,7 +80,8 @@ int main(int argc, char **argv) | ||||
|     case 0: | ||||
|     default: | ||||
|       /* 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; | ||||
|     } | ||||
|   } | ||||
							
								
								
									
										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. | ||||
|  */ | ||||
| 
 | ||||
| @@ -9,9 +17,8 @@ | ||||
| #include <sys/time.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| /* To start with, we include the header from the lib directory. This should
 | ||||
|    later of course be moved to the proper include dir. */ | ||||
| #include "../lib/multi.h" | ||||
| /* curl stuff */ | ||||
| #include <curl/curl.h> | ||||
| 
 | ||||
| /*
 | ||||
|  * Simply download a HTTP file. | ||||
| @@ -67,7 +74,8 @@ int main(int argc, char **argv) | ||||
|     case 0: | ||||
|     default: | ||||
|       /* 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; | ||||
|     } | ||||
|   } | ||||
							
								
								
									
										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; | ||||
| } | ||||
| @@ -21,7 +21,7 @@ | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
| @@ -63,6 +63,10 @@ int main(int argc, char **argv) | ||||
|   /* we want the headers to this file handle */ | ||||
|   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! */ | ||||
|   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; | ||||
| } | ||||
| @@ -40,7 +40,7 @@ int main(int argc, char **argv) | ||||
|   FILE *headerfile; | ||||
|  | ||||
|   const char *pCertFile = "testcert.pem"; | ||||
|   const char *pCACertFile="cacert.pem" | ||||
|   const char *pCACertFile="cacert.pem"; | ||||
|  | ||||
|   const char *pKeyName; | ||||
|   const char *pKeyType; | ||||
| @@ -66,7 +66,7 @@ int main(int argc, char **argv) | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     /* 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); | ||||
|  | ||||
|     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> | ||||
| <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> | ||||
| <TITLE>Index to Curl documentation</TITLE> | ||||
| @@ -8,31 +8,14 @@ HTML> | ||||
| <H1 ALIGN="CENTER">Index to Curl documentation</H1> | ||||
|  | ||||
| <H2>Programs</H2> | ||||
| <P><A HREF="curl-config.html">curl-config.html</A> | ||||
| <P><A HREF="curl.html">curl.html</A> | ||||
| <a href="curl-config.html">curl-config</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> | ||||
| </HTML> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ PROGRAMMING WITH LIBCURL | ||||
|  | ||||
| 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 | ||||
|  mainly on the C interface but might apply fairly well on other interfaces as | ||||
|  well as they usually follow the C one pretty closely. | ||||
| @@ -114,7 +114,8 @@ Global Preparation | ||||
|  call initialized. | ||||
|  | ||||
|  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 | ||||
|  | ||||
| @@ -215,6 +216,24 @@ Handle the Easy libcurl | ||||
|  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 | ||||
|  | ||||
|  There will always be times when the transfer fails for some reason. You might | ||||
| @@ -237,6 +256,9 @@ When It Doesn't Work | ||||
|  possible of your code that uses libcurl, operating system name and version, | ||||
|  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 | ||||
| @@ -275,8 +297,8 @@ Upload Data to a Remote Site | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_UPLOAD, TRUE); | ||||
|  | ||||
|  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 | ||||
|  upload file size using the CURLOPT_INFILESIZE like this: | ||||
|  knowledge of the expected file size. So, set the upload file size using the | ||||
|  CURLOPT_INFILESIZE for all known file sizes like this[1]: | ||||
|  | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_INFILESIZE, file_size); | ||||
|  | ||||
| @@ -386,7 +408,7 @@ HTTP POSTing | ||||
|     headers = curl_slist_append(headers, "Content-Type: text/xml"); | ||||
|  | ||||
|     /* post binary data */ | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_POSTFIELD, binaryptr); | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_POSTFIELDS, binaryptr); | ||||
|  | ||||
|     /* set the size of the postfields data */ | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_POSTFIELDSIZE, 23); | ||||
| @@ -413,8 +435,8 @@ HTTP POSTing | ||||
|  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 HttpPost *post=NULL; | ||||
|     struct HttpPost *last=NULL; | ||||
|     struct curl_httppost *post=NULL; | ||||
|     struct curl_httppost *last=NULL; | ||||
|     curl_formadd(&post, &last, | ||||
|                  CURLFORM_COPYNAME, "name", | ||||
|                  CURLFORM_COPYCONTENTS, "daniel", CURLFORM_END); | ||||
| @@ -470,7 +492,30 @@ HTTP POSTing | ||||
|  | ||||
| Showing Progress | ||||
|  | ||||
|  [ built-in progress meter, progress callback ] | ||||
|  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++ | ||||
| @@ -685,6 +730,35 @@ Persistancy Is The Way to Happiness | ||||
|  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 | ||||
| @@ -697,94 +771,233 @@ Customizing Operations | ||||
|  | ||||
|  libcurl is your friend here too. | ||||
|  | ||||
|  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: | ||||
|   CUSTOMREQUEST | ||||
|  | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_CUSTOMREQUEST, "MYOWNRUQUEST"); | ||||
|     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: | ||||
|  | ||||
|  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. | ||||
|        curl_easy_setopt(easyhandle, CURLOPT_CUSTOMREQUEST, "MYOWNRUQUEST"); | ||||
|  | ||||
|  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: | ||||
|     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. | ||||
|  | ||||
|     struct curl_slist *headers; | ||||
|   Modify Headers | ||||
|  | ||||
|     headers = curl_slist_append(headers, "Hey-server-hey: how are you?"); | ||||
|     headers = curl_slist_append(headers, "X-silly-content: yes"); | ||||
|     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: | ||||
|  | ||||
|     /* pass our list of custom made headers */ | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_HTTPHEADER, headers); | ||||
|        struct curl_slist *headers=NULL; /* init to NULL is important */ | ||||
|  | ||||
|     curl_easy_perform(easyhandle); /* transfer http */ | ||||
|        headers = curl_slist_append(headers, "Hey-server-hey: how are you?"); | ||||
|        headers = curl_slist_append(headers, "X-silly-content: yes"); | ||||
|  | ||||
|     curl_slist_free_all(headers); /* free the header list */ | ||||
|        /* pass our list of custom made headers */ | ||||
|        curl_easy_setopt(easyhandle, CURLOPT_HTTPHEADER, headers); | ||||
|  | ||||
|  ... and if you think some of the internally generated headers, such as | ||||
|  User-Agent:, Accept: or Host: don't contain the data you want them to | ||||
|  contain, you can replace them by simply setting them too: | ||||
|        curl_easy_perform(easyhandle); /* transfer http */ | ||||
|  | ||||
|     headers = curl_slist_append(headers, "User-Agent: 007"); | ||||
|     headers = curl_slist_append(headers, "Host: munged.host.line"); | ||||
|        curl_slist_free_all(headers); /* free the header list */ | ||||
|  | ||||
|  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: | ||||
|    ... 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:"); | ||||
|        headers = curl_slist_append(headers, "Accept: Agent-007"); | ||||
|        headers = curl_slist_append(headers, "Host: munged.host.line"); | ||||
|  | ||||
|  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. | ||||
|   Delete Headers | ||||
|  | ||||
|  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. | ||||
|     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: | ||||
|  | ||||
|  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. | ||||
|        headers = curl_slist_append(headers, "Accept:"); | ||||
|  | ||||
|  A little example that deletes a given file before an operation: | ||||
|     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. | ||||
|  | ||||
|     headers = curl_slist_append(headers, "DELE file-to-remove"); | ||||
|   Enforcing chunked transfer-encoding | ||||
|  | ||||
|     /* pass the list of custom commands to the handle */ | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_QUOTE, headers); | ||||
|     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. | ||||
|  | ||||
|     curl_easy_perform(easyhandle); /* transfer ftp data! */ | ||||
|   HTTP Version | ||||
|  | ||||
|     curl_slist_free_all(headers); /* free the header list */ | ||||
|     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: | ||||
|  | ||||
|  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. | ||||
|        curl_easy_setopt(easyhandle, CURLOPT_HTTP_VERSION, | ||||
|                                     CURLHTTP_VERSION_1_0); | ||||
|  | ||||
|  The custom FTP command will be issued to the server in the same order they | ||||
|  are built in 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. Note that if you use CURLOPT_QUOTE to send commands before a | ||||
|  transfer, no transfer will actually take place then. | ||||
|   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. | ||||
|  | ||||
|  [ custom FTP commands without transfer, FTP "header-only", HTTP 1.0 ] | ||||
|  | ||||
| Cookies Without Chocolate Chips | ||||
|  | ||||
|  [ set cookies, read cookies from file, cookie-jar ] | ||||
|  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 | ||||
|  | ||||
|  [ use the header callback for HTTP, FTP etc ] | ||||
|  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 | ||||
| @@ -794,26 +1007,91 @@ Post Transfer Information | ||||
|  | ||||
| Security Considerations | ||||
|  | ||||
|  [ ps output, netrc plain text, plain text protocols / base64 ] | ||||
|  libcurl is in itself not insecure. If used the right way, you can use libcurl | ||||
|  to transfer data pretty safely. | ||||
|  | ||||
|  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 | ||||
|  | ||||
|  [ multi interface, sharing between handles, mutexes, pipelining ] | ||||
|  [ sharing between handles, mutexes, pipelining ] | ||||
|  | ||||
|  | ||||
| ----- | ||||
| Footnotes: | ||||
|  | ||||
| [1] = HTTP PUT without knowing the size prior to transfer is indeed possible, | ||||
|       but libcurl does not support the chunked transfers on uploading that is | ||||
|       necessary for this feature to work. We'd gratefully appreciate patches | ||||
|       that bring this functionality... | ||||
| [1] = libcurl 7.10.3 and later have the ability to switch over to chunked | ||||
|       Tranfer-Encoding in cases were HTTP uploads are done with data of an | ||||
|       unknown size. | ||||
|  | ||||
|  | ||||
| [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 | ||||
|   | ||||
							
								
								
									
										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] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_easy_init 3 "31 Jan 2001" "libcurl 7.9.4" "libcurl Manual" | ||||
| .TH curl_easy_init 3 "25 Apr 2002" "libcurl 7.9.7" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_easy_getinfo - Extract information from a curl session (added in 7.4) | ||||
| .SH SYNOPSIS | ||||
| @@ -38,7 +38,9 @@ CURLOPT_FILETIME option to \fIcurl_easy_setopt(3)\fP. (Added in 7.5) | ||||
| .TP | ||||
| .B CURLINFO_TOTAL_TIME | ||||
| 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 | ||||
| .B CURLINFO_NAMELOOKUP_TIME | ||||
| Pass a pointer to a double to receive the time, in seconds, it took from the | ||||
| @@ -60,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 | ||||
| the result. | ||||
| .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 | ||||
| Pass a pointer to a double to receive the total amount of bytes that were | ||||
| uploaded. | ||||
| .TP | ||||
| .B CURLINFO_SIZE_DOWNLOAD | ||||
| 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 | ||||
| .B CURLINFO_SPEED_DOWNLOAD | ||||
| Pass a pointer to a double to receive the average download speed that curl | ||||
| @@ -103,8 +116,12 @@ 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 | ||||
| 
 | ||||
| .SH RETURN VALUE | ||||
| If the operation was successful, CURLE_OK is returned. Otherwise an | ||||
| 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: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_escape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_escape - URL encodes the given string | ||||
| .SH SYNOPSIS | ||||
| .B #include <curl/curl.h> | ||||
| .sp | ||||
| .BI "char *curl_escape( char *" url ", int "length " );" | ||||
| .ad | ||||
| .SH DESCRIPTION | ||||
| 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, | ||||
| A-Z or 0-9 will be converted to their "URL escaped" version. If a sequence of | ||||
| %NN (where NN is a two-digit hexadecimal number) is found in the string to | ||||
| 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. | ||||
| 
 | ||||
| You must free() the returned string when you're done with it. | ||||
| .SH RETURN VALUE | ||||
| A pointer to a zero terminated string or NULL if it failed. | ||||
| .SH "SEE ALSO" | ||||
| .I curl_unescape(), RFC 2396 | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_escape 3 "6 March 2002" "libcurl 7.9" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_escape - URL encodes the given string | ||||
| .SH SYNOPSIS | ||||
| .B #include <curl/curl.h> | ||||
| .sp | ||||
| .BI "char *curl_escape( char *" url ", int "length " );" | ||||
| .ad | ||||
| .SH DESCRIPTION | ||||
| 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, | ||||
| A-Z or 0-9 will be converted to their "URL escaped" version (%NN where NN is a | ||||
| two-digit hexadecimal number). | ||||
| 
 | ||||
| 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 | ||||
| A pointer to a zero terminated string or NULL if it failed. | ||||
| .SH "SEE ALSO" | ||||
| .I curl_unescape(), curl_free(), 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)" | ||||
							
								
								
									
										39
									
								
								docs/libcurl/curl_slist_append.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								docs/libcurl/curl_slist_append.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_slist_append 3 "19 Jun 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. curl_slist_append() copies the | ||||
| string. | ||||
|  | ||||
| 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: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_unescape - URL decodes the given string | ||||
| .SH SYNOPSIS | ||||
| .B #include <curl/curl.h> | ||||
| .sp | ||||
| .BI "char *curl_unescape( char *" url ", int "length " );" | ||||
| .ad | ||||
| .SH DESCRIPTION | ||||
| 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 | ||||
| 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 | ||||
| right of a ? letter will be converted). | ||||
| 
 | ||||
| If the 'length' argument is set to 0, curl_unescape() will use strlen() on the | ||||
| input 'url' string to find out the size. | ||||
| 
 | ||||
| You must free() the returned string when you're done with it. | ||||
| .SH RETURN VALUE | ||||
| A pointer to a zero terminated string or NULL if it failed. | ||||
| .SH "SEE ALSO" | ||||
| .I curl_escape(), RFC 2396 | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_unescape - URL decodes the given string | ||||
| .SH SYNOPSIS | ||||
| .B #include <curl/curl.h> | ||||
| .sp | ||||
| .BI "char *curl_unescape( char *" url ", int "length " );" | ||||
| .ad | ||||
| .SH DESCRIPTION | ||||
| 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 | ||||
| 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 | ||||
| right of a ? letter will be converted). | ||||
| 
 | ||||
| If the 'length' argument is set to 0, curl_unescape() 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 | ||||
| A pointer to a zero terminated string or NULL if it failed. | ||||
| .SH "SEE ALSO" | ||||
| .I curl_escape(), curl_free(), RFC 2396 | ||||
							
								
								
									
										101
									
								
								docs/libcurl/curl_version_info.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								docs/libcurl/curl_version_info.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_version_info 3 "17 Jun 2003" "libcurl 7.10.6" "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 | ||||
| .TP | ||||
| .B CURL_VERSION_NTLM | ||||
| supports HTTP NTLM (added in 7.10.6) | ||||
| .TP | ||||
| .B CURL_VERSION_GSSNEGOTIATE | ||||
| supports HTTP GSS-Negotiate (added in 7.10.6) | ||||
| .TP | ||||
| .B CURL_VERSION_DEBUG | ||||
| libcurl was built with extra debug capabilities built-in. This is mainly of | ||||
| interest for libcurl hackers. (added in 7.10.6) | ||||
| .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> | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user