Compare commits
	
		
			972 Commits
		
	
	
		
			curl-7_21_
			...
			curl-7_25_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | c1babfad8a | ||
|   | b8b2cf612b | ||
|   | fe93b0a874 | ||
|   | e8a32438c2 | ||
|   | 97b66ebefe | ||
|   | d2e5222ebc | ||
|   | 3aab542e77 | ||
|   | 3c80309c27 | ||
|   | c83de6d076 | ||
|   | 805788e043 | ||
|   | dddcd3b042 | ||
|   | c6825b7a6b | ||
|   | e6a89cb6c4 | ||
|   | fe7613932e | ||
|   | ffb67599b3 | ||
|   | 47236d89c0 | ||
|   | ad77420ac7 | ||
|   | 804da995c5 | ||
|   | ede9ad43fc | ||
|   | 0c8e36c18a | ||
|   | 862bb7bade | ||
|   | b329fc7023 | ||
|   | 8af4b657d0 | ||
|   | 97386c3c84 | ||
|   | e25590a2b3 | ||
|   | 79afcbefb4 | ||
|   | e650dbde86 | ||
|   | b50e9e9e9e | ||
|   | 9f0e1689f1 | ||
|   | f7e2ab629e | ||
|   | 2764bf2c5b | ||
|   | 41b0237834 | ||
|   | cabd010dd4 | ||
|   | c55a0809bb | ||
|   | 4ee2df4b46 | ||
|   | 4d71d1b17f | ||
|   | d185960a6d | ||
|   | 79b6f4a2d3 | ||
|   | 5430007222 | ||
|   | 779fa13ef9 | ||
|   | 1a7bba1975 | ||
|   | 21130dab4f | ||
|   | c3cae332c5 | ||
|   | 9954242980 | ||
|   | 2f1ad7d6e2 | ||
|   | 30c44edad3 | ||
|   | 77a21ff623 | ||
|   | 035ef06bda | ||
|   | 3d98aed5b3 | ||
|   | 4cf742f34f | ||
|   | 4bf3131979 | ||
|   | 5c409d03ec | ||
|   | a053560cfa | ||
|   | 674699b212 | ||
|   | 154c0d4b93 | ||
|   | b685481d52 | ||
|   | 0cf0ab6f30 | ||
|   | ee7e4fc1d1 | ||
|   | 0201280533 | ||
|   | 69406f0be7 | ||
|   | ea4ceca222 | ||
|   | 714accd090 | ||
|   | 35e965c9a0 | ||
|   | 2b26eb9857 | ||
|   | e71ac0c6fa | ||
|   | 7ed25fcc5c | ||
|   | ecc93caaeb | ||
|   | ebf3138992 | ||
|   | 8ef8a2b5ac | ||
|   | 62d15f159e | ||
|   | 2a699bc6e9 | ||
|   | 2a266c1c7c | ||
|   | 705f0f7a5b | ||
|   | ea055407fa | ||
|   | 4405039fdc | ||
|   | 65103efe49 | ||
|   | 466150bc64 | ||
|   | f710aa40b3 | ||
|   | f4d3c0cbfb | ||
|   | 4d2737bcb2 | ||
|   | 8ee2576b6f | ||
|   | 575f3c30ed | ||
|   | cf9fb08ca4 | ||
|   | 5a53409e2c | ||
|   | e277d3b52b | ||
|   | 93e344bbf4 | ||
|   | 75b6f7d9ef | ||
|   | a8e063b087 | ||
|   | 70f71bb99f | ||
|   | c11c30a8c8 | ||
|   | 75ca568fa1 | ||
|   | db1a856b4f | ||
|   | ee57e9dea6 | ||
|   | 6e2fd2c9ea | ||
|   | 5d7a319a55 | ||
|   | 7883cd5af3 | ||
|   | d7af7de5b2 | ||
|   | a7e8f4aabc | ||
|   | e64d332e79 | ||
|   | 00e615de7e | ||
|   | b2aaf3c2ad | ||
|   | c41f304c43 | ||
|   | d56b4c3f89 | ||
|   | d1becc3231 | ||
|   | f55f95d49c | ||
|   | 61d31a3caf | ||
|   | 4b9af77d54 | ||
|   | 5d70a61b94 | ||
|   | 51c485342b | ||
|   | 4563eeb9f4 | ||
|   | 2cafb0e97c | ||
|   | 6ea7acf5a9 | ||
|   | a20daf90e3 | ||
|   | 24526d0c0f | ||
|   | a752850acc | ||
|   | 2b9fafd622 | ||
|   | 0ce2bca741 | ||
|   | b15024be4d | ||
|   | 21401840fa | ||
|   | e3e24e5b36 | ||
|   | 18c6c8a5e7 | ||
|   | c731fc58ea | ||
|   | 6d62c5a6fc | ||
|   | f1092b387e | ||
|   | 8e82ef9c32 | ||
|   | d016f5f5f5 | ||
|   | d4bf87dc0e | ||
|   | 54dede4166 | ||
|   | 9f20379fe4 | ||
|   | 123c92c904 | ||
|   | d28411c3cc | ||
|   | 2705af6267 | ||
|   | f34ddb90e6 | ||
|   | dd69a3e868 | ||
|   | 812fa73057 | ||
|   | 52824ed1ab | ||
|   | 4897f4e517 | ||
|   | 81524cbfa0 | ||
|   | 8ef7a5706e | ||
|   | c358bab809 | ||
|   | 4bc6c1a026 | ||
|   | 3a55daee3d | ||
|   | 7bd2add06f | ||
|   | 3b06f1fb36 | ||
|   | db4f69ef06 | ||
|   | 277022b2e4 | ||
|   | 0f8239d5b4 | ||
|   | a4202be655 | ||
|   | 2f4a487a68 | ||
|   | 82180643f4 | ||
|   | 585b89a6c3 | ||
|   | cc69e56ce3 | ||
|   | 8e25d1b93b | ||
|   | 63e2718f8d | ||
|   | 7f472618de | ||
|   | 08107111ac | ||
|   | a3403db02f | ||
|   | c9a3cab6c4 | ||
|   | f4949e56eb | ||
|   | 81ebdd9e28 | ||
|   | 207cf15032 | ||
|   | 5e0a44e4d5 | ||
|   | 9e3f8c4850 | ||
|   | 90343c76c6 | ||
|   | ecd75e8cb8 | ||
|   | e63c9f8ff3 | ||
|   | ed0364343d | ||
|   | 5c0ad9581d | ||
|   | e99128a5c9 | ||
|   | 33c2e1cafc | ||
|   | 84f736981c | ||
|   | 82c344a347 | ||
|   | 9f7f6a62ff | ||
|   | 98292bcdd0 | ||
|   | 996f2454ba | ||
|   | 99a12baa34 | ||
|   | 4f8db8bf95 | ||
|   | 5ac9ec7205 | ||
|   | f8cd217f04 | ||
|   | 84e7ea2ffc | ||
|   | 2caa454dc1 | ||
|   | 3e4181f88e | ||
|   | e71e226f6b | ||
|   | b0eb963bc7 | ||
|   | 2cf9e78a22 | ||
|   | 430527a1d7 | ||
|   | 1afbccc676 | ||
|   | 1dd654644a | ||
|   | ba238e3a18 | ||
|   | 4bb140bfc9 | ||
|   | 926916e28e | ||
|   | 3d6e2ec925 | ||
|   | 380bade777 | ||
|   | 26ce3ac328 | ||
|   | 130fac6c16 | ||
|   | 6222ef8052 | ||
|   | b06ed249d2 | ||
|   | 377471f387 | ||
|   | dfdac61522 | ||
|   | c834213ad5 | ||
|   | 5527417afa | ||
|   | bedfafe38e | ||
|   | e9040f2954 | ||
|   | 51d4885ca0 | ||
|   | ce896875f8 | ||
|   | eb6e9593c4 | ||
|   | 5c71544fc6 | ||
|   | 7799ac434e | ||
|   | 7cc2e8b349 | ||
|   | 3c18b38dcc | ||
|   | 1fc5cd6a1a | ||
|   | af9bc1604c | ||
|   | b235d5ade8 | ||
|   | ee3d3adc6f | ||
|   | 583a902789 | ||
|   | 7b8590d1f5 | ||
|   | 9b185aac43 | ||
|   | 34f9ec0c54 | ||
|   | 7111ca6f5f | ||
|   | 612a61b267 | ||
|   | cd4cd66839 | ||
|   | 4c4e8ba1f0 | ||
|   | de6f4f356e | ||
|   | 66c5076252 | ||
|   | b9b772fefe | ||
|   | 07efe110cc | ||
|   | 6e4835c795 | ||
|   | ba057c2e19 | ||
|   | 1259ccf747 | ||
|   | 07e3b7512c | ||
|   | 50d88bf4b5 | ||
|   | 1cacf853da | ||
|   | 9dbe6565d4 | ||
|   | 2b24dd870e | ||
|   | 46724b87b7 | ||
|   | 82a4d26e7f | ||
|   | 2b0e09b0f9 | ||
|   | 361cd03d58 | ||
|   | 7e4daaf908 | ||
|   | 3bbe219be2 | ||
|   | 347f951c39 | ||
|   | c50dbf670f | ||
|   | 0cf05af744 | ||
|   | d5b5f64bce | ||
|   | 088ba97a24 | ||
|   | 9109cdec11 | ||
|   | 5971d401d4 | ||
|   | 62d3652b43 | ||
|   | d81f5ea3e0 | ||
|   | adc88ca203 | ||
|   | 83350c9cc4 | ||
|   | bdb647814e | ||
|   | c92234c3bc | ||
|   | 7e02f7fdee | ||
|   | bd94807003 | ||
|   | 1038d0aa16 | ||
|   | f80a508297 | ||
|   | af64666434 | ||
|   | 2d72489f0f | ||
|   | dda815b776 | ||
|   | 8d3efb6be0 | ||
|   | 11e52ef0a1 | ||
|   | 71ce2470dc | ||
|   | 874855b743 | ||
|   | ac54d27d4b | ||
|   | 2d833852f6 | ||
|   | 0604b2fb90 | ||
|   | 8f50a5c7e5 | ||
|   | 703fa0a6a8 | ||
|   | 97d7a9260e | ||
|   | 4a4d04446d | ||
|   | b9223a17b8 | ||
|   | f712ace9d7 | ||
|   | 2c905fd1f8 | ||
|   | 4403e82f32 | ||
|   | c482e946f7 | ||
|   | 46bd8b330a | ||
|   | 78feaff9d8 | ||
|   | 28bac99674 | ||
|   | 7248439fec | ||
|   | c532604b13 | ||
|   | 64f328c787 | ||
|   | c0db5ff678 | ||
|   | 66617b79d7 | ||
|   | f64812ca63 | ||
|   | 10ecdf5078 | ||
|   | bb4eb58996 | ||
|   | fc8809f993 | ||
|   | 35f61c404d | ||
|   | 97b73fec7a | ||
|   | 8d0a504f0d | ||
|   | 967b2f87a8 | ||
|   | b9660dc4b2 | ||
|   | 591c29aa49 | ||
|   | 5e0aa3aac9 | ||
|   | 7cfd10e255 | ||
|   | 95ddbdb1db | ||
|   | 6c4216b2a7 | ||
|   | 10120e6ab5 | ||
|   | 082e8a3b03 | ||
|   | fd765c627f | ||
|   | c8ffb4049a | ||
|   | e3166df1bb | ||
|   | 06a83e8050 | ||
|   | 2c09d21fdf | ||
|   | 4851dafcf1 | ||
|   | 73029dca5a | ||
|   | 5b57c54416 | ||
|   | 7fe9a50ab5 | ||
|   | 6fa6567b92 | ||
|   | 93e57d0628 | ||
|   | a873b95c21 | ||
|   | 6bdeca967d | ||
|   | 3f5e267b9d | ||
|   | f7dfe2b87a | ||
|   | af425efe83 | ||
|   | 9cfc0c73a7 | ||
|   | 49e3b2e03a | ||
|   | 8bfc3a800a | ||
|   | b24c28e6c2 | ||
|   | 0b315c1cf1 | ||
|   | e2928e1555 | ||
|   | f5bb370186 | ||
|   | bae4e3f035 | ||
|   | 3676ec9680 | ||
|   | 8ccf7bf8d7 | ||
|   | c761fcb055 | ||
|   | ddeab48245 | ||
|   | b0d42da26b | ||
|   | 120025b7f8 | ||
|   | 692f344118 | ||
|   | 51e5a2bf3f | ||
|   | 8165e05f29 | ||
|   | 4c88866737 | ||
|   | 4464583a6e | ||
|   | 22502c9550 | ||
|   | 39c6d18d9c | ||
|   | f4405d30e0 | ||
|   | e8d8843a02 | ||
|   | 134e87c53b | ||
|   | 515f11e79b | ||
|   | 5850cc4808 | ||
|   | c295565569 | ||
|   | e771344611 | ||
|   | a4471045bb | ||
|   | cc76bbe79b | ||
|   | d7934b8bd4 | ||
|   | d67b75c9f9 | ||
|   | 95d23d1ceb | ||
|   | a4758c3276 | ||
|   | 9d0d1ada05 | ||
|   | 629d2e3450 | ||
|   | 90fcad63cb | ||
|   | 1399c3da0d | ||
|   | ff0a295cdb | ||
|   | 4fa0166173 | ||
|   | adaa3f6e14 | ||
|   | cf0f6729e7 | ||
|   | 8036da870c | ||
|   | 2621dd42a4 | ||
|   | 2c8c46619b | ||
|   | ecbb08cea3 | ||
|   | 491c5a497c | ||
|   | 06e6755e87 | ||
|   | 052a08ff59 | ||
|   | f6980bbf24 | ||
|   | d47d95ac3b | ||
|   | b229c8ca8b | ||
|   | 337252bdd4 | ||
|   | 840eff44f2 | ||
|   | ff03ee2a3c | ||
|   | 62bcf005f4 | ||
|   | 1a416cd27a | ||
|   | 54ef47a5a0 | ||
|   | 8af94de50a | ||
|   | 1bab38780b | ||
|   | fd10c047df | ||
|   | ea12c72d12 | ||
|   | 47e4537ac6 | ||
|   | 03adff1eba | ||
|   | 34770b8ab0 | ||
|   | 880cf0bedc | ||
|   | bff78cc18e | ||
|   | 584dc8b8af | ||
|   | a84b8a3922 | ||
|   | acaf466401 | ||
|   | 71c9453393 | ||
|   | 17f48fe879 | ||
|   | b82bd05354 | ||
|   | 1958fe5745 | ||
|   | f7bfdbabf2 | ||
|   | 7afccf7a1e | ||
|   | 4a57bf6d10 | ||
|   | 7296b2aa25 | ||
|   | 6c849321d7 | ||
|   | 0f19e0145a | ||
|   | ec73fd89ed | ||
|   | 5bf0d74120 | ||
|   | fd87d9d2b9 | ||
|   | 0572ad6d01 | ||
|   | aa7d5b946a | ||
|   | 49b79b7631 | ||
|   | ca2c326361 | ||
|   | 5c809178c2 | ||
|   | fa77f54a03 | ||
|   | bc007d8ef5 | ||
|   | d0dbd1e98e | ||
|   | 4d327d20c6 | ||
|   | 185ed3409a | ||
|   | d54bcebad4 | ||
|   | 0435800f65 | ||
|   | 56ed07f7df | ||
|   | 381459fa65 | ||
|   | 15e3e45170 | ||
|   | 9dd85bced5 | ||
|   | 5d45285cf3 | ||
|   | 3d19e1eedf | ||
|   | 7be872c389 | ||
|   | 0c903ea189 | ||
|   | affed6725e | ||
|   | 7f304ab84f | ||
|   | e709cc8627 | ||
|   | db060304de | ||
|   | 5898a6a09b | ||
|   | 57fffa728b | ||
|   | 421a460278 | ||
|   | 5793bc370c | ||
|   | ff5ba6e43d | ||
|   | 9f2f8d5122 | ||
|   | bd158607ca | ||
|   | a2d4a98ddd | ||
|   | b4fccc1d8e | ||
|   | e2be8ceed9 | ||
|   | d439830621 | ||
|   | f4853db5e6 | ||
|   | d9f686db88 | ||
|   | a1087db5c6 | ||
|   | 400055bfaa | ||
|   | 5801ddb85c | ||
|   | 38b5744266 | ||
|   | bc28a35dbc | ||
|   | d2a47021c0 | ||
|   | 119f43360b | ||
|   | e276802ff8 | ||
|   | 2d6796aac5 | ||
|   | bb94b92894 | ||
|   | 230459dd00 | ||
|   | 745014b726 | ||
|   | b3ea4881a8 | ||
|   | c6702c7d3f | ||
|   | 8bab6700d9 | ||
|   | 081e289315 | ||
|   | 5f0764870f | ||
|   | 87a45c7998 | ||
|   | dafa2fc944 | ||
|   | ef3f1f3146 | ||
|   | ba52e0a93b | ||
|   | 40c27e299f | ||
|   | fa775b56de | ||
|   | fb3845a438 | ||
|   | 3c3aa09c65 | ||
|   | 01c172f5e8 | ||
|   | e9cf4cb791 | ||
|   | 322f3d5af7 | ||
|   | c1057fc9aa | ||
|   | 62b0fdca9e | ||
|   | 3317160c19 | ||
|   | 28526ed6e0 | ||
|   | e4172d934d | ||
|   | 977825a68c | ||
|   | a6b69b64ad | ||
|   | 9ecf53e154 | ||
|   | 84221006c9 | ||
|   | a6c168b893 | ||
|   | dee7a08f64 | ||
|   | cd3cf55b47 | ||
|   | 98a61d8e2e | ||
|   | 81b41095ef | ||
|   | 49c35a7f9f | ||
|   | 57119495da | ||
|   | fdecb56cbf | ||
|   | 00532341b5 | ||
|   | dae0b7d1aa | ||
|   | 42be24af89 | ||
|   | 260b0f4d0c | ||
|   | f50d4647d0 | ||
|   | 805b4740c7 | ||
|   | a75888f1d3 | ||
|   | b4b642eb45 | ||
|   | c0159d0edc | ||
|   | 93579cc363 | ||
|   | 4322d512ea | ||
|   | e4819ae1ef | ||
|   | 43c59765e1 | ||
|   | e533f59025 | ||
|   | e6697ef59c | ||
|   | ff9d858722 | ||
|   | f7583b2dea | ||
|   | 6b33873c57 | ||
|   | 90080da5fe | ||
|   | 0216e517d0 | ||
|   | aff70e2e95 | ||
|   | 6790a543d4 | ||
|   | 2411adb40b | ||
|   | d52cd3bd17 | ||
|   | 64c613c27a | ||
|   | 73b18a9d24 | ||
|   | 1bac153ea3 | ||
|   | 432044b774 | ||
|   | 9dfd7a3d13 | ||
|   | deb3321092 | ||
|   | 68253ca52e | ||
|   | 50c3c20416 | ||
|   | 4e9a1c5bba | ||
|   | 587ed3234b | ||
|   | 94d64f8d4c | ||
|   | 0d3584c482 | ||
|   | 2a9fec16cc | ||
|   | 777f9aea13 | ||
|   | 72c14bd6f0 | ||
|   | 0413e24891 | ||
|   | be8e68494c | ||
|   | a7d8894291 | ||
|   | 08a5a9b68d | ||
|   | 303c90074d | ||
|   | 443ab77e1f | ||
|   | 7b7c45879e | ||
|   | 81ead2c4e7 | ||
|   | 28d09cb0f5 | ||
|   | 2147492050 | ||
|   | 58a7c51362 | ||
|   | 450975b0c3 | ||
|   | 5658aa9574 | ||
|   | 6539047694 | ||
|   | 774ad4e31d | ||
|   | f764da8afb | ||
|   | c8ba8740b9 | ||
|   | 46df51a391 | ||
|   | e9e894905c | ||
|   | a50210710a | ||
|   | eb44ac0138 | ||
|   | d52f3eb598 | ||
|   | 8e154225b5 | ||
|   | 196e0d699f | ||
|   | 809cde5416 | ||
|   | 476f194d7f | ||
|   | bdc311cf98 | ||
|   | a405a8976d | ||
|   | 6b75d2c2df | ||
|   | 2be65bb0c5 | ||
|   | f02325ea65 | ||
|   | b98594c8bf | ||
|   | ded3638d97 | ||
|   | 9194e17003 | ||
|   | 749dbfbc87 | ||
|   | 6b59bc1805 | ||
|   | 0a5bbb2ac1 | ||
|   | f2285a6d39 | ||
|   | fdf157abdf | ||
|   | 437848d754 | ||
|   | 38fff918f9 | ||
|   | 5ea65fbc79 | ||
|   | 0b018a0a05 | ||
|   | d20408e816 | ||
|   | c06de20025 | ||
|   | e495f82f86 | ||
|   | 3445fa2e3f | ||
|   | 5a45dc4a29 | ||
|   | 78199b6030 | ||
|   | 05ef245170 | ||
|   | 662c1d87f3 | ||
|   | 135f694058 | ||
|   | 260ee6b7bf | ||
|   | b976d108f1 | ||
|   | b4f6319cf7 | ||
|   | e18c3f447e | ||
|   | 0fd2bf3726 | ||
|   | 407e08baad | ||
|   | 186463e7fa | ||
|   | d535cff775 | ||
|   | f5ad192d23 | ||
|   | e83421baf4 | ||
|   | aa5c72af15 | ||
|   | b9c63b9a73 | ||
|   | cb5e72bf62 | ||
|   | e882416e75 | ||
|   | fd00b382b2 | ||
|   | cce6508242 | ||
|   | af809923e4 | ||
|   | 006b011cdf | ||
|   | a659cc4794 | ||
|   | 1c400b4e5e | ||
|   | 61ae7e9ce7 | ||
|   | 838dd8f594 | ||
|   | aaab5fa299 | ||
|   | 2d7c79af76 | ||
|   | 38c5e81a67 | ||
|   | 3af9ba166c | ||
|   | 7b054a42aa | ||
|   | b998d95b4d | ||
|   | d44896508c | ||
|   | 9afb343368 | ||
|   | 1833984664 | ||
|   | 31a1af5ebb | ||
|   | 9710f387c4 | ||
|   | 4ed7abb537 | ||
|   | ef2059a44c | ||
|   | 93ba8b9560 | ||
|   | ade87b32c7 | ||
|   | d6f319fb64 | ||
|   | b9d5e72adc | ||
|   | 6a7ce5cc76 | ||
|   | 7d738baeb5 | ||
|   | 44b44a751d | ||
|   | 2828b8ef9e | ||
|   | e575cbc815 | ||
|   | f0c59c6c2c | ||
|   | dfb18da5dc | ||
|   | 0c4ec8033b | ||
|   | dc4f9d185d | ||
|   | 98fb0ef73e | ||
|   | 08b05efd20 | ||
|   | b4d6db83de | ||
|   | e209f3f176 | ||
|   | a30ede868a | ||
|   | 40afeea2fb | ||
|   | e40c663d36 | ||
|   | c8766ed3fb | ||
|   | 1e4187f8bf | ||
|   | 8bd877d179 | ||
|   | 5538904d77 | ||
|   | a472ceb174 | ||
|   | 092189c664 | ||
|   | 301e907aed | ||
|   | 3293150da2 | ||
|   | 784971743d | ||
|   | 448f982d54 | ||
|   | f396d94736 | ||
|   | 657d02fbac | ||
|   | 8e2de86723 | ||
|   | 4b48adb876 | ||
|   | c7fb556f26 | ||
|   | 5ed17de326 | ||
|   | 209cf2df37 | ||
|   | 7c21c1c4f9 | ||
|   | f8831d55e0 | ||
|   | 43d2c66454 | ||
|   | 27dbc3f526 | ||
|   | 9f10dabc43 | ||
|   | 45d883d88d | ||
|   | 3ef6418b61 | ||
|   | 56ef3e295f | ||
|   | 3dcc0df5cc | ||
|   | da3ae20da5 | ||
|   | 73548e1d22 | ||
|   | 56a0635216 | ||
|   | 967deb43f8 | ||
|   | 3d919440c8 | ||
|   | 339fef4440 | ||
|   | 15379f0614 | ||
|   | f2a6373629 | ||
|   | 2ccffbb37e | ||
|   | 1db023d3cb | ||
|   | 91ad42412f | ||
|   | 7d69e31023 | ||
|   | 704dc18440 | ||
|   | b0f18c4beb | ||
|   | 40e1d03c5d | ||
|   | c95fec5e5b | ||
|   | 817b863466 | ||
|   | f6272dd9b8 | ||
|   | 40597fd942 | ||
|   | f0fae85acd | ||
|   | e1f3536bac | ||
|   | afe88d85f4 | ||
|   | 17f343290c | ||
|   | 75fa3d2d6e | ||
|   | 9812446c65 | ||
|   | 5eb2396cd1 | ||
|   | 86b50a1fe5 | ||
|   | 8f890470f1 | ||
|   | a6ed2b8426 | ||
|   | b56bbabee0 | ||
|   | a04912bb65 | ||
|   | 519d0c0dd2 | ||
|   | d2c22411af | ||
|   | c4142034ff | ||
|   | efc8ef7cc4 | ||
|   | b698f90051 | ||
|   | ddf0b30ffd | ||
|   | a7864c41db | ||
|   | ebf42c4be7 | ||
|   | 7688a99bef | ||
|   | 10a0bed485 | ||
|   | cc3e01cfae | ||
|   | 65cc163195 | ||
|   | 9417e71f4a | ||
|   | bc6e6a465a | ||
|   | ad8193fbb9 | ||
|   | bcbac913d6 | ||
|   | 5cdbfa1837 | ||
|   | c01c000b16 | ||
|   | 35051d274f | ||
|   | 9779553221 | ||
|   | 435e2bc757 | ||
|   | 99848d3dab | ||
|   | 02e59579ef | ||
|   | dddf9aa610 | ||
|   | 4eb08ac1c0 | ||
|   | 6ac4eeab2f | ||
|   | 8350fb8f2f | ||
|   | cfcca89b76 | ||
|   | 41c6c78a08 | ||
|   | 78bbd0eecf | ||
|   | f1586cb477 | ||
|   | 983f3d70f9 | ||
|   | 0337b87197 | ||
|   | 0a26b0e3e7 | ||
|   | ef2176109f | ||
|   | 27b8814017 | ||
|   | dcc8481a13 | ||
|   | 3f9b4afdfd | ||
|   | d007c3ca76 | ||
|   | 0ae15092d4 | ||
|   | b9313af838 | ||
|   | d0d36f312f | ||
|   | d95f45cd40 | ||
|   | 177fd0a14c | ||
|   | aa26c2751a | ||
|   | a6d4807d02 | ||
|   | 650a504b2f | ||
|   | e3a9804d3a | ||
|   | 9c1f50c583 | ||
|   | 6e3285d5b1 | ||
|   | 44b5847237 | ||
|   | ee4ed46128 | ||
|   | 2af0287856 | ||
|   | 20485a4885 | ||
|   | 6488e03f44 | ||
|   | b680fd180b | ||
|   | dc97475ded | ||
|   | c6e3081090 | ||
|   | 902d3dc33d | ||
|   | c7a4df16e0 | ||
|   | bcf50283fc | ||
|   | 3e16c3e73e | ||
|   | 3e71ebe4eb | ||
|   | bfca0e2f50 | ||
|   | 2e2e5f247a | ||
|   | ac28971aa6 | ||
|   | fb48e2050b | ||
|   | 78480892cd | ||
|   | b7e242de0e | ||
|   | 17a2d70dc4 | ||
|   | 43ce5580a8 | ||
|   | 0215f7cb4d | ||
|   | 67f28662e1 | ||
|   | 57d51be60c | ||
|   | 8da5da9b65 | ||
|   | 42c6b7577f | ||
|   | e5010ec3ff | ||
|   | 5c314c6bb4 | ||
|   | 9016958aa8 | ||
|   | 1614dc0745 | ||
|   | af6dcc92d5 | ||
|   | 57064e4a0d | ||
|   | d9e71809cb | ||
|   | a7cc54a5a8 | ||
|   | c9a82f39e2 | ||
|   | e4bca6a01c | ||
|   | 56e5302b53 | ||
|   | 4cbc6fc6ab | ||
|   | c9f16e67ef | ||
|   | f851f76857 | ||
|   | 0126b4a959 | ||
|   | 49a8fe5142 | ||
|   | 8fc4be9e7b | ||
|   | 70eee054f2 | ||
|   | 0aedccc18a | ||
|   | 85881f9f35 | ||
|   | 84e13f2e07 | ||
|   | 832e827518 | ||
|   | a6fa7fc38e | ||
|   | b122f8be61 | ||
|   | 950fb3efcc | ||
|   | ee015947d4 | ||
|   | a2a2863306 | ||
|   | b688f2c260 | ||
|   | c4dd8df081 | ||
|   | 0f7bea7c3a | ||
|   | d5cc77b744 | ||
|   | 36a22f9074 | ||
|   | 6e0dd48f97 | ||
|   | cb2f300364 | ||
|   | 7530a28878 | ||
|   | e8d73c9c2d | ||
|   | 8a3c0fe56c | ||
|   | f551aa5c16 | ||
|   | 377f88364e | ||
|   | c0b9dd27b5 | ||
|   | 6aff805942 | ||
|   | b772f3a321 | ||
|   | 7559b77727 | ||
|   | 4f170ee8f9 | ||
|   | fba00c9f7b | ||
|   | 10a7d05be3 | ||
|   | 9776f3445d | ||
|   | adeac15d8e | ||
|   | 5d4e5593d5 | ||
|   | c2eb8c932d | ||
|   | a6f14e17b7 | ||
|   | b3740f0e09 | ||
|   | 2a31dde76c | ||
|   | bf749bb2c5 | ||
|   | 65a9fa59dc | ||
|   | 9eea43dce2 | ||
|   | 910d7953aa | ||
|   | 970117ef2d | ||
|   | aa76dec33a | ||
|   | d6bb8dcc23 | ||
|   | 685359d4c3 | ||
|   | a689072f33 | ||
|   | 3d64ed25df | ||
|   | ecfe0b5b18 | ||
|   | 9460896cbe | ||
|   | a87102c792 | ||
|   | 2e7a2027f1 | ||
|   | ae677edf90 | ||
|   | f5d78919af | ||
|   | f3d77f772d | ||
|   | 7dd449d843 | ||
|   | f461c6e61d | ||
|   | 3c9ff41a1f | ||
|   | c8c8816a97 | ||
|   | 5d39dea3b3 | ||
|   | 9f390a356e | ||
|   | 017ee34bba | ||
|   | 340228cc81 | ||
|   | edf282c096 | ||
|   | a947a9ac62 | ||
|   | 9b5343054a | ||
|   | b735717606 | ||
|   | ec33742d1b | ||
|   | 2ea31b0e6f | ||
|   | de70ddb749 | ||
|   | a41c7f9736 | ||
|   | 512b2f7740 | ||
|   | 8bdc48eddb | ||
|   | 328600e02b | ||
|   | e2747ebbc0 | ||
|   | 41ebda02b2 | ||
|   | 30c9799f72 | ||
|   | bed6b89a2f | ||
|   | 3e70c28ce5 | ||
|   | 79cc6c244a | ||
|   | d30ddd9977 | ||
|   | 8b849265d8 | ||
|   | fce7276f54 | ||
|   | 004d84fcc1 | ||
|   | 02f3ff3b0a | ||
|   | 3f6ffcd26d | ||
|   | 3912e7bde3 | ||
|   | 488521427f | ||
|   | e83816bfcf | ||
|   | b578534508 | ||
|   | 5db30a1d8c | ||
|   | 664ff30650 | ||
|   | 873d70a6d8 | ||
|   | 6dfa16c3c4 | ||
|   | 60f0ebbdc9 | ||
|   | b5d170b551 | ||
|   | d4e000906a | ||
|   | bb7ff942d3 | ||
|   | 48a40f0402 | ||
|   | 0c8e6f598a | ||
|   | 2ef7a28a71 | ||
|   | 2a02c07a15 | ||
|   | 212d8c8f65 | ||
|   | b996b202c4 | ||
|   | 32001ac414 | ||
|   | 9c629e5348 | ||
|   | f0612f166a | ||
|   | e34131db78 | ||
|   | 335dfa793c | ||
|   | 574aecee20 | ||
|   | 51075a6777 | ||
|   | 4508ea103f | ||
|   | 558f997e99 | ||
|   | fda0985bfd | ||
|   | 93ec4555ff | ||
|   | 61877b569f | ||
|   | dc15a88076 | ||
|   | adae5926dd | ||
|   | ade337d79e | ||
|   | 365db94e0a | ||
|   | d4ebf3c6b0 | ||
|   | f78fa6a57d | ||
|   | 038a631274 | ||
|   | 7d94af497d | ||
|   | a490961b10 | ||
|   | 821301de15 | ||
|   | 3440f4d374 | ||
|   | f83c36934f | ||
|   | c4bc1d473f | ||
|   | 5b7e1f9efe | ||
|   | c33aee1667 | ||
|   | 3b1b26578f | ||
|   | 2cbe885c1a | ||
|   | 4a42e5cdaa | ||
|   | 53ef3493bf | ||
|   | cbd98b2c28 | ||
|   | 4685db9462 | ||
|   | 45de057920 | ||
|   | aa87f0ab15 | ||
|   | 6a6981503e | ||
|   | 889d1e973f | ||
|   | 1b758b01c1 | ||
|   | 7ddcc8fea4 | ||
|   | 068d656c6d | ||
|   | 92f722017c | ||
|   | 9869668884 | ||
|   | b903186fa0 | ||
|   | 592eda8e3f | ||
|   | 6d013b0aab | ||
|   | bcc29cda8e | ||
|   | 4235457129 | ||
|   | e9542ccab6 | ||
|   | 7de2f9271c | ||
|   | 24d84da073 | ||
|   | ca015f1a45 | ||
|   | 722f286f80 | ||
|   | f20b4606de | ||
|   | c985a8df51 | ||
|   | a0fad3017e | ||
|   | 2a05025510 | ||
|   | d8373cb992 | ||
|   | 17df5d8caa | ||
|   | 210278d9a1 | ||
|   | 5942362847 | ||
|   | 7d86e467fa | ||
|   | 7609b32e7c | ||
|   | 1702a2c08d | ||
|   | 9230be0797 | ||
|   | 7872c8d5a2 | ||
|   | 37b9fe104a | ||
|   | 3242abd87a | ||
|   | 1b6df743f6 | ||
|   | c2c8948190 | ||
|   | c6a0abdd97 | ||
|   | 9039d19f01 | ||
|   | c828646f60 | ||
|   | eb65a49bef | ||
|   | b2140a09f8 | ||
|   | 519bec7c91 | ||
|   | 24e5a40156 | ||
|   | 2d1b6242f2 | ||
|   | a5db4a46ac | ||
|   | 65aadf2118 | ||
|   | 24667466f0 | ||
|   | 5aae3c13e2 | ||
|   | 8e4fb01e64 | ||
|   | ebb37eac8b | ||
|   | 9d191a6a40 | ||
|   | be973b6f91 | ||
|   | 2db6f7e703 | ||
|   | 0790b27910 | ||
|   | e80b957789 | ||
|   | 213939c8ba | ||
|   | 82ecc85d9e | ||
|   | 84f809e7a8 | ||
|   | cae351e9f5 | ||
|   | 909acfbbba | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -14,6 +14,7 @@ Makefile | ||||
| Makefile.in | ||||
| aclocal.m4 | ||||
| autom4te.cache | ||||
| config.cache | ||||
| config.guess | ||||
| config.log | ||||
| config.status | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| # | ||||
| # Place the curl source (including this makefile) into external/curl/ in the | ||||
| # Android source tree.  Then build them with 'make curl' or just 'make libcurl' | ||||
| # from the Android root. Tested with Android 1.5 and 2.1 | ||||
| # from the Android root. Tested with Android versions 1.5, 2.1-2.3 | ||||
| # | ||||
| # Note: you must first create a curl_config.h file by running configure in the | ||||
| # Android environment. The only way I've found to do this is tricky. Perform a | ||||
| @@ -42,7 +42,7 @@ | ||||
| # into the right place (but see the note about this below). | ||||
| # | ||||
| # Dan Fandrich | ||||
| # August 2010 | ||||
| # November 2011 | ||||
|  | ||||
| LOCAL_PATH:= $(call my-dir) | ||||
|  | ||||
| @@ -62,8 +62,7 @@ CURL_HEADERS := \ | ||||
| 	mprintf.h \ | ||||
| 	multi.h \ | ||||
| 	stdcheaders.h \ | ||||
| 	typecheck-gcc.h \ | ||||
| 	types.h | ||||
| 	typecheck-gcc.h | ||||
|  | ||||
| LOCAL_SRC_FILES := $(addprefix lib/,$(CSOURCES)) | ||||
| LOCAL_C_INCLUDES += $(LOCAL_PATH)/include/ | ||||
| @@ -73,6 +72,7 @@ LOCAL_COPY_HEADERS_TO := libcurl/curl | ||||
| LOCAL_COPY_HEADERS := $(addprefix include/curl/,$(CURL_HEADERS)) | ||||
|  | ||||
| LOCAL_MODULE:= libcurl | ||||
| LOCAL_MODULE_TAGS := optional | ||||
|  | ||||
| # Copy the licence to a place where Android will find it. | ||||
| # Actually, this doesn't quite work because the build system searches | ||||
| @@ -93,6 +93,7 @@ include $(LOCAL_PATH)/src/Makefile.inc | ||||
| LOCAL_SRC_FILES := $(addprefix src/,$(CURL_CFILES)) | ||||
|  | ||||
| LOCAL_MODULE := curl | ||||
| LOCAL_MODULE_TAGS := optional | ||||
| LOCAL_STATIC_LIBRARIES := libcurl | ||||
| LOCAL_SYSTEM_SHARED_LIBRARIES := libc | ||||
|  | ||||
|   | ||||
							
								
								
									
										0
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -23,7 +23,6 @@ include(Utilities) | ||||
|  | ||||
| project( CURL C ) | ||||
|  | ||||
|  | ||||
| file (READ ${CURL_SOURCE_DIR}/include/curl/curlver.h CURL_VERSION_H_CONTENTS) | ||||
| string (REGEX MATCH "LIBCURL_VERSION_MAJOR[ \t]+([0-9]+)" | ||||
|   LIBCURL_VERSION_MJ ${CURL_VERSION_H_CONTENTS}) | ||||
| @@ -149,6 +148,8 @@ option(ENABLE_IPV6 "Define if you want to enable IPv6 support" OFF) | ||||
| mark_as_advanced(ENABLE_IPV6) | ||||
|  | ||||
| if(WIN32) | ||||
|   # Windows standard libraries are located in C:/Program Files/Microsoft SDKs/[...] | ||||
|   # They are already included in the default MSVC LIBPATH => no find_library is needed! | ||||
|   list_spaces_append_once(CMAKE_C_STANDARD_LIBRARIES wsock32.lib ws2_32.lib)  # bufferoverflowu.lib | ||||
|   if(CURL_DISABLE_LDAP) | ||||
|     # Remove wldap32.lib from space-separated list | ||||
| @@ -191,12 +192,12 @@ if(WIN32) | ||||
| endif(WIN32) | ||||
|  | ||||
| # This macro checks if the symbol exists in the library and if it | ||||
| # does, it appends library to the list. | ||||
| # does, it prepends library to the list. | ||||
| macro(CHECK_LIBRARY_EXISTS_CONCAT LIBRARY SYMBOL VARIABLE) | ||||
|   check_library_exists("${LIBRARY};${CURL_LIBS}" ${SYMBOL} "" | ||||
|   check_library_exists("${LIBRARY};${CURL_LIBS}" ${SYMBOL} "${CMAKE_LIBRARY_PATH}" | ||||
|     ${VARIABLE}) | ||||
|   if(${VARIABLE}) | ||||
|     set(CURL_LIBS ${CURL_LIBS} ${LIBRARY}) | ||||
|     set(CURL_LIBS ${LIBRARY} ${CURL_LIBS}) | ||||
|   endif(${VARIABLE}) | ||||
| endmacro(CHECK_LIBRARY_EXISTS_CONCAT) | ||||
|  | ||||
| @@ -224,25 +225,6 @@ check_library_exists("wldap32" cldap_open "" HAVE_WLDAP32) | ||||
| #  CHECK_LIBRARY_EXISTS_CONCAT("z"      inflateEnd   HAVE_LIBZ) | ||||
| # ENDIF(NOT CURL_SPECIAL_LIBZ) | ||||
|  | ||||
| option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON) | ||||
| mark_as_advanced(CMAKE_USE_OPENSSL) | ||||
| if(CMAKE_USE_OPENSSL) | ||||
|   if(WIN32) | ||||
|     find_package(OpenSSL) | ||||
|     if(OPENSSL_FOUND) | ||||
|       set(USE_SSLEAY TRUE) | ||||
|       set(USE_OPENSSL TRUE) | ||||
|       list(APPEND CURL_LIBS ${OPENSSL_LIBRARIES} ) | ||||
|     else() | ||||
|       set(CMAKE_USE_OPENSSL FALSE) | ||||
|       message(STATUS "OpenSSL NOT Found, disabling CMAKE_USE_OPENSSL") | ||||
|     endif() | ||||
|   else(WIN32) | ||||
|     check_library_exists_concat("crypto" CRYPTO_lock  HAVE_LIBCRYPTO) | ||||
|     check_library_exists_concat("ssl"    SSL_connect  HAVE_LIBSSL) | ||||
|   endif(WIN32) | ||||
| endif(CMAKE_USE_OPENSSL) | ||||
|  | ||||
| # Check for idn | ||||
| check_library_exists_concat("idn" idna_to_ascii_lz HAVE_LIBIDN) | ||||
|  | ||||
| @@ -271,6 +253,25 @@ if(CURL_ZLIB)  # AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE | ||||
|   endif() | ||||
| endif() | ||||
|  | ||||
| option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON) | ||||
| mark_as_advanced(CMAKE_USE_OPENSSL) | ||||
| if(CMAKE_USE_OPENSSL) | ||||
|   if(WIN32) | ||||
|     find_package(OpenSSL) | ||||
|     if(OPENSSL_FOUND) | ||||
|       set(USE_SSLEAY TRUE) | ||||
|       set(USE_OPENSSL TRUE) | ||||
|       list(APPEND CURL_LIBS ${OPENSSL_LIBRARIES} ) | ||||
|     else() | ||||
|       set(CMAKE_USE_OPENSSL FALSE) | ||||
|       message(STATUS "OpenSSL NOT Found, disabling CMAKE_USE_OPENSSL") | ||||
|     endif() | ||||
|   else(WIN32) | ||||
|     check_library_exists_concat("crypto" CRYPTO_lock  HAVE_LIBCRYPTO) | ||||
|     check_library_exists_concat("ssl"    SSL_connect  HAVE_LIBSSL) | ||||
|   endif(WIN32) | ||||
| endif(CMAKE_USE_OPENSSL) | ||||
|  | ||||
| # If we have features.h, then do the _BSD_SOURCE magic | ||||
| check_include_file("features.h"       HAVE_FEATURES_H) | ||||
|  | ||||
| @@ -852,3 +853,13 @@ endif() | ||||
| if(NOT CURL_CONFIG_HAS_BEEN_RUN_BEFORE) | ||||
|   set(CURL_CONFIG_HAS_BEEN_RUN_BEFORE 1 CACHE INTERNAL "Flag to track whether this is the first time running CMake or if CMake has been configured before") | ||||
| endif() | ||||
|  | ||||
| # Installation. | ||||
| # First, install generated curlbuild.h | ||||
| install(FILES "${CMAKE_CURRENT_BINARY_DIR}/include/curl/curlbuild.h" | ||||
|     DESTINATION include/curl ) | ||||
| # Next, install other headers excluding curlbuild.h | ||||
| install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/curl" | ||||
|     DESTINATION include | ||||
|     FILES_MATCHING PATTERN "*.h" | ||||
|     PATTERN "curlbuild.h" EXCLUDE) | ||||
|   | ||||
							
								
								
									
										10
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -36,12 +36,12 @@ winbuild/MakefileBuild.vc winbuild/Makefile.vc | ||||
| EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | ||||
|  curl-style.el sample.emacs RELEASE-NOTES buildconf 	\ | ||||
|  libcurl.pc.in vc6curl.dsw MacOSX-Framework Android.mk $(CMAKE_DIST)	\ | ||||
|  Makefile.msvc.names $(WINBUILD_DIST) | ||||
|  Makefile.msvc.names $(WINBUILD_DIST) lib/libcurl.vers.in | ||||
|  | ||||
| bin_SCRIPTS = curl-config | ||||
|  | ||||
| SUBDIRS = lib src | ||||
| DIST_SUBDIRS = $(SUBDIRS) tests include packages docs | ||||
| SUBDIRS = lib src include | ||||
| DIST_SUBDIRS = $(SUBDIRS) tests packages docs | ||||
|  | ||||
| pkgconfigdir = $(libdir)/pkgconfig | ||||
| pkgconfig_DATA = libcurl.pc | ||||
| @@ -155,3 +155,7 @@ ca-bundle: lib/mk-ca-bundle.pl | ||||
| ca-firefox: lib/firefox-db2pem.sh | ||||
| 	@echo "generate a fresh ca-bundle.crt" | ||||
| 	./lib/firefox-db2pem.sh lib/ca-bundle.crt | ||||
|  | ||||
| checksrc: | ||||
| 	cd lib && $(MAKE) checksrc | ||||
| 	cd src && $(MAKE) checksrc | ||||
|   | ||||
| @@ -70,29 +70,22 @@ mingw32: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 | ||||
| 	$(MAKE) -C src -f Makefile.m32 | ||||
|  | ||||
| mingw32-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 ZLIB=1 | ||||
|  | ||||
| mingw32-ssl-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 SSL=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 SSL=1 ZLIB=1 | ||||
|  | ||||
| mingw32-ssh2-ssl-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 SSH2=1 SSL=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 SSH2=1 SSL=1 ZLIB=1 | ||||
|  | ||||
| mingw32-ssh2-ssl-sspi-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||
|  | ||||
| mingw32-rtmp-ssh2-ssl-sspi-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 RTMP=1 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 RTMP=1 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||
|  | ||||
| mingw32-clean: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 clean | ||||
| 	$(MAKE) -C src -f Makefile.m32 clean | ||||
| 	$(MAKE) -C docs/examples -f Makefile.m32 clean | ||||
|  | ||||
| mingw32-vclean mingw32-distclean: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 vclean | ||||
| 	$(MAKE) -C src -f Makefile.m32 vclean | ||||
| 	$(MAKE) -C docs/examples -f Makefile.m32 vclean | ||||
|  | ||||
| mingw32-examples%: | ||||
| 	$(MAKE) -C docs/examples -f Makefile.m32 CFG=$@ | ||||
|  | ||||
| mingw32%: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 CFG=$@ | ||||
| 	$(MAKE) -C src -f Makefile.m32 CFG=$@ | ||||
|  | ||||
| vc-clean: $(VC) | ||||
| 	cd lib | ||||
| @@ -229,34 +222,27 @@ netware: | ||||
| 	$(MAKE) -C lib -f Makefile.netware | ||||
| 	$(MAKE) -C src -f Makefile.netware | ||||
|  | ||||
| netware-ares: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_ARES=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_ARES=1 | ||||
|  | ||||
| netware-ssl: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_SSL=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_SSL=1 | ||||
|  | ||||
| netware-ssl-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | ||||
|  | ||||
| netware-ssh2-ssl-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_SSH2=1 WITH_SSL=1 WITH_ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_SSH2=1 WITH_SSL=1 WITH_ZLIB=1 | ||||
|  | ||||
| netware-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_ZLIB=1 | ||||
|  | ||||
| netware-clean: | ||||
| 	$(MAKE) -C lib -f Makefile.netware clean | ||||
| 	$(MAKE) -C src -f Makefile.netware clean | ||||
| 	$(MAKE) -C docs/examples -f Makefile.netware clean | ||||
|  | ||||
| netware-vclean netware-distclean: | ||||
| 	$(MAKE) -C lib -f Makefile.netware vclean | ||||
| 	$(MAKE) -C src -f Makefile.netware vclean | ||||
| 	$(MAKE) -C docs/examples -f Makefile.netware vclean | ||||
|  | ||||
| netware-install: | ||||
| 	$(MAKE) -C lib -f Makefile.netware install | ||||
| 	$(MAKE) -C src -f Makefile.netware install | ||||
|  | ||||
| netware-examples-%: | ||||
| 	$(MAKE) -C docs/examples -f Makefile.netware CFG=$@ | ||||
|  | ||||
| netware-%: | ||||
| 	$(MAKE) -C lib -f Makefile.netware CFG=$@ | ||||
| 	$(MAKE) -C src -f Makefile.netware CFG=$@ | ||||
|  | ||||
| unix: all | ||||
|  | ||||
| unix-ssl: ssl | ||||
|   | ||||
							
								
								
									
										129
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							
							
						
						
									
										129
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							| @@ -1,69 +1,49 @@ | ||||
| Curl and libcurl 7.21.5 | ||||
| Curl and libcurl 7.25.0 | ||||
|  | ||||
|  Public curl releases:         121 | ||||
|  Command line options:         143 | ||||
|  curl_easy_setopt() options:   185 | ||||
|  Public curl releases:         127 | ||||
|  Command line options:         151 | ||||
|  curl_easy_setopt() options:   199 | ||||
|  Public functions in libcurl:  58 | ||||
|  Known libcurl bindings:       39 | ||||
|  Contributors:                 854 | ||||
|  Contributors:                 929 | ||||
|  | ||||
| This release includes the following changes: | ||||
|  | ||||
|  o SOCKOPTFUNCTION: callback can say already-connected | ||||
|  o Added --netrc-file | ||||
|  o Added (new) support for cyassl | ||||
|  o TSL-SRP: enabled with OpenSSL | ||||
|  o Added CURLE_NOT_BUILT_IN and CURLE_UNKNOWN_OPTION | ||||
|  o configure: add option disable --libcurl output [1] | ||||
|  o --ssl-allow-beast and CURLOPT_SSL_OPTIONS added [2] | ||||
|  o Added CURLOPT_TCP_KEEPALIVE, CURLOPT_TCP_KEEPIDLE, CURLOPT_TCP_KEEPINTVL [4] | ||||
|  o curl: use new library-side TCP_KEEPALIVE options [5] | ||||
|  o Added a new CURLOPT_MAIL_AUTH option [13] | ||||
|  o Added support for --mail-auth [14] | ||||
|  o --libcurl now also works with -F and more! [15] | ||||
|  | ||||
| This release includes the following bugfixes: | ||||
|  | ||||
|  o nss: avoid memory leak on SSL connection failure | ||||
|  o nss: do not ignore failure of SSL handshake | ||||
|  o multi: better failed connect handling when using FTP, SMTP, POP3 and IMAP | ||||
|  o runtests.pl: fix pid number concatenation that prevented it from killing | ||||
|    the correct process at times | ||||
|  o PolarSSL: Return 0 on receiving TLS CLOSE_NOTIFY alert | ||||
|  o curl_easy_setopt.3: Removed wrong reference to CURLOPT_USERPASSWORD | ||||
|  o multi: close connection on timeout | ||||
|  o IMAP in multi mode does SSL connections non-blocking | ||||
|  o honours the --disable-ldaps configure option | ||||
|  o Force setopt constants written by --libcurl to be long | ||||
|  o ssh_connect: treat libssh2 return code better | ||||
|  o SFTP upload could stall the state machine when the multi_socket API was | ||||
|    used | ||||
|  o SFTP and SCP could leak memory when used with the multi interface and  | ||||
|    the connection was closed | ||||
|  o Added missing file to repair the MSVC makefiles | ||||
|  o Fixed detection of recvfrom arguments on Android/bionic | ||||
|  o GSS: handle reuse fix | ||||
|  o transfer: avoid insane conversion of time_t | ||||
|  o nss: do not ignore value of CURLOPT_SSL_VERIFYPEER in certain cases | ||||
|  o SMTP-multi: non-blocking connect | ||||
|  o SFTP-multi: set cselect for sftp and scp to fix "stall" risk | ||||
|  o configure: removed wrongly claimed default paths | ||||
|  o pop3: fixed torture tests to succeed | ||||
|  o symbols-in-versions: many corrections | ||||
|  o if a HTTP request gets retried because the connection was dead, rewind if | ||||
|    any data was sent as part of it | ||||
|  o only probe for working ipv6 once and then re-use that info for further | ||||
|    requests | ||||
|  o requests that are asked to bound to a local interface/port will no longer | ||||
|    wrongly re-use connections that aren't | ||||
|  o libcurl.m4: Add missing quotes in AC_LINK_IFELSE | ||||
|  o progress output: don't print the last update on a separate line | ||||
|  o POP3: the command to send is STLS, not STARTTLS | ||||
|  o POP3: PASS command was not sent after upgrade to TLS | ||||
|  o configure: fix libtool warning | ||||
|  o nss: allow to use multiple client certificates for a single host | ||||
|  o HTTP pipelining: Fix handling of zero-length responses | ||||
|  o Don't list NTLM in curl-config when HTTP is disabled | ||||
|  o curl_easy_setopt.3: CURLOPT_RESOLVE typo version | ||||
|  o OpenSSL: build fine with no-sslv2 versions | ||||
|  o checkconnection: don't call with NULL pointer with RTSP and multi interface | ||||
|  o Borland makefile updates | ||||
|  o configure: libssh2 link fix without pkg-config | ||||
|  o certinfo crash | ||||
|  o CCC crash | ||||
|  o --max-redirs: allow negative numbers as option value [3] | ||||
|  o parse_proxy: bail out on zero-length proxy names [6] | ||||
|  o configure: don't modify LD_LIBRARY_PATH for cross compiles [7] | ||||
|  o curl_easy_reset: reset the referer string [8] | ||||
|  o curl tool: don't abort glob-loop due to failures [9] | ||||
|  o CONNECT: send correct Host: with IPv6 numerical address [10] | ||||
|  o Explicitly link to the nettle/gcrypt libraries [11] | ||||
|  o more resilient connection times among IP addresses [12] | ||||
|  o winbuild: fix IPV6 and IDN options | ||||
|  o SMTP: Fixed error when using CURLOPT_CONNECT_ONLY | ||||
|  o cyassl: update to CyaSSL 2.0.x API | ||||
|  o smtp: Fixed an issue with the EOB checking | ||||
|  o pop3: Fixed drop of final CRLF in EOB checking [16] | ||||
|  o smtp: Fixed an issue with writing postdata | ||||
|  o smtp: Added support for returning SMTP response codes | ||||
|  o CONNECT: fix ipv6 address in the Request-Line [17] | ||||
|  o curl-config: only provide libraries with --libs | ||||
|  o LWIP: don't consider HAVE_ERRNO_H to be winsock [19] | ||||
|  o ssh: tunnel through HTTP proxy if requested | ||||
|  o cookies: strip off [brackets] from numerical ipv6 host names [20] | ||||
|  o libcurl docs: version corrections [18] | ||||
|  o cmake: list_spaces_append_once failure [22] | ||||
|  o resolve with c-ares: don't resolve IPv6 when not working [21] | ||||
|  o smtp: changed error code for EHLO and HELO responses | ||||
|  o parsedate: fix a numeric overflow | ||||
|  | ||||
| This release includes the following known bugs: | ||||
|  | ||||
| @@ -72,10 +52,35 @@ This release includes the following known bugs: | ||||
| This release would not have looked like this without help, code, reports and | ||||
| advice from friends like these: | ||||
|  | ||||
|  Mike Crowe, Kamil Dudka, Julien Chaffraix, Hoi-Ho Chan, Ben Noordhuis, | ||||
|  Dan Fandrich, Henry Ludemann, Karl M, Manuel Massing, Marcus Sundberg, | ||||
|  Stefan Krause, Todd A Ouska, Saqib Ali, Andre Guibert de Bruet, | ||||
|  Tor Arntsen, Vincent Torri, Dave Reisner, Chris Smowton, Tinus van den Berg, | ||||
|  Hongli Lai, Gisle Vanem, Andrei Benea, Mehmet Bozkurt | ||||
|  Colin Hogben, Alessandro Ghedini, Kamil Dudka, Rob Ward, Dave Reisner, | ||||
|  Martin Storsjo, Pierre Ynard, Pierre Joye, Yang Tse, Dan Fandrich, | ||||
|  Michael Day, Juan Barreto, Chandrakant Bagul, Steve Holme, Todd Ouska, | ||||
|  Rich Gray, John Joseph Bachir, Armel Asselin, Andrei Cipu, | ||||
|  Maxim Prohorov | ||||
|   | ||||
|         Thanks! (and sorry if I forgot to mention someone) | ||||
|  | ||||
| References to bug reports and discussions on issues: | ||||
|  | ||||
|  [1] = http://curl.haxx.se/mail/lib-2012-02/0009.html | ||||
|  [2] = http://curl.haxx.se/mail/lib-2012-02/0001.html | ||||
|  [3] = http://curl.haxx.se/mail/lib-2012-02/0098.html | ||||
|  [4] = http://curl.haxx.se/mail/lib-2012-01/0264.html | ||||
|  [5] = http://curl.haxx.se/mail/lib-2012-01/0263.html | ||||
|  [6] = http://curl.haxx.se/mail/lib-2012-02/0000.html | ||||
|  [7] = http://curl.haxx.se/mail/lib-2012-02/0052.html | ||||
|  [8] = http://curl.haxx.se/bug/view.cgi?id=3481551 | ||||
|  [9] = http://curl.haxx.se/bug/view.cgi?id=3481223 | ||||
|  [10] = http://curl.haxx.se/bug/view.cgi?id=3482093 | ||||
|  [11] = http://curl.haxx.se/mail/lib-2012-01/0303.html | ||||
|  [12] = http://curl.haxx.se/mail/lib-2012-01/0190.html | ||||
|  [13] = http://curl.haxx.se/libcurl/c/curl_easy_setopt.html#CURLOPTMAILAUTH | ||||
|  [14] = http://curl.haxx.se/docs/manpage.html#--mail-auth | ||||
|  [15] = http://curl.haxx.se/docs/manpage.html#--libcurl | ||||
|  [16] = http://curl.haxx.se/mail/lib-2012-02/0051.html | ||||
|  [17] = http://curl.haxx.se/bug/view.cgi?id=3493129 | ||||
|  [18] = http://curl.haxx.se/bug/view.cgi?id=3494091 | ||||
|  [19] = http://curl.haxx.se/mail/lib-2012-03/0046.html | ||||
|  [20] = http://curl.haxx.se/mail/lib-2012-03/0036.html | ||||
|  [21] = http://curl.haxx.se/mail/lib-2012-03/0045.html | ||||
|  [22] = http://curl.haxx.se/bug/view.cgi?id=3494968 | ||||
|   | ||||
							
								
								
									
										20
									
								
								TODO-RELEASE
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								TODO-RELEASE
									
									
									
									
									
								
							| @@ -1,15 +1,15 @@ | ||||
| To be addressed in 7.21.6 | ||||
| To be addressed in 7.24.1 | ||||
| ========================= | ||||
|  | ||||
| 284 - bug 3172608 "No re-authentication when HTTP connecton is closed" | ||||
|       http://curl.haxx.se/bug/view.cgi?id=3172608 | ||||
|       Would be nice if someone could verify the suggested patch | ||||
| 295 - "RTSP Authentication (#22)" https://github.com/bagder/curl/pull/22 | ||||
|  | ||||
| 285 - bug 3163118 "Allow programatic use of telnet on Windows" | ||||
|       http://curl.haxx.se/bug/view.cgi?id=3163118 | ||||
|       Would appreciate a Windows developer to give it a look before we apply | ||||
|       the suggested patch | ||||
| 296 - "OOM leak in multi code" (by Dan Fandrich) | ||||
|  | ||||
| 287 - bug 3215314 Post quote operation to rename fails in Windows | ||||
| 300 - "Polling on stray socket on sequential transfers." Andrew S | ||||
|       http://curl.haxx.se/mail/lib-2011-07/0053.html | ||||
|  | ||||
| 289 - | ||||
| 308 - Revisit option --enable-threaded-resolver at least allow selection among | ||||
|       pthreads and Windows threads when building a Windows target. | ||||
|       http://curl.haxx.se/mail/lib-2012-01/0291.html | ||||
|  | ||||
| 309 -  | ||||
|   | ||||
							
								
								
									
										25
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -51,7 +51,7 @@ CURL_DEF_TOKEN $1 | ||||
|   ],[ | ||||
|     tmp_exp=`eval "$ac_cpp conftest.$ac_ext" 2>/dev/null | \ | ||||
|       "$GREP" CURL_DEF_TOKEN 2>/dev/null | \ | ||||
|       "$SED" 's/.*CURL_DEF_TOKEN[[ ]]//' 2>/dev/null | \ | ||||
|       "$SED" 's/.*CURL_DEF_TOKEN[[ ]][[ ]]*//' 2>/dev/null | \ | ||||
|       "$SED" 's/[["]][[ ]]*[["]]//g' 2>/dev/null` | ||||
|     if test -z "$tmp_exp" || test "$tmp_exp" = "$1"; then | ||||
|       tmp_exp="" | ||||
| @@ -1663,7 +1663,7 @@ AC_DEFUN([CURL_CHECK_FUNC_RECVFROM], [ | ||||
|           for recvfrom_arg2 in 'char *' 'void *'; do | ||||
|             for recvfrom_arg3 in 'size_t' 'int' 'socklen_t' 'unsigned int'; do | ||||
|               for recvfrom_arg4 in 'int' 'unsigned int'; do | ||||
|                 for recvfrom_arg5 in 'const struct sockaddr *' 'struct sockaddr *' 'void *'; do | ||||
|                 for recvfrom_arg5 in 'struct sockaddr *' 'void *' 'const struct sockaddr *'; do | ||||
|                   for recvfrom_arg6 in 'socklen_t *' 'int *' 'unsigned int *' 'size_t *' 'void *'; do | ||||
|                     if test "$curl_cv_func_recvfrom_args" = "unknown"; then | ||||
|                       AC_COMPILE_IFELSE([ | ||||
| @@ -1731,7 +1731,7 @@ AC_DEFUN([CURL_CHECK_FUNC_RECVFROM], [ | ||||
|       shift | ||||
|       # | ||||
|       recvfrom_ptrt_arg2=$[2] | ||||
|       recvfrom_ptrt_arg5=$[5] | ||||
|       recvfrom_qual_ptrt_arg5=$[5] | ||||
|       recvfrom_ptrt_arg6=$[6] | ||||
|       # | ||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG1, $[1], | ||||
| @@ -1753,12 +1753,25 @@ AC_DEFUN([CURL_CHECK_FUNC_RECVFROM], [ | ||||
|           ;; | ||||
|       esac | ||||
|       # | ||||
|       case "$recvfrom_qual_ptrt_arg5" in | ||||
|         const*) | ||||
|           recvfrom_qual_arg5=const | ||||
|           recvfrom_ptrt_arg5=`echo $recvfrom_qual_ptrt_arg5 | sed 's/^const //'` | ||||
|         ;; | ||||
|         *) | ||||
|           recvfrom_qual_arg5= | ||||
|           recvfrom_ptrt_arg5=$recvfrom_qual_ptrt_arg5 | ||||
|         ;; | ||||
|       esac | ||||
|       # | ||||
|       recvfrom_type_arg2=`echo $recvfrom_ptrt_arg2 | sed 's/ \*//'` | ||||
|       recvfrom_type_arg5=`echo $recvfrom_ptrt_arg5 | sed 's/ \*//'` | ||||
|       recvfrom_type_arg6=`echo $recvfrom_ptrt_arg6 | sed 's/ \*//'` | ||||
|       # | ||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG2, $recvfrom_type_arg2, | ||||
|         [Define to the type pointed by arg 2 for recvfrom.]) | ||||
|       AC_DEFINE_UNQUOTED(RECVFROM_QUAL_ARG5, $recvfrom_qual_arg5, | ||||
|         [Define to the type qualifier pointed by arg 5 for recvfrom.]) | ||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG5, $recvfrom_type_arg5, | ||||
|         [Define to the type pointed by arg 5 for recvfrom.]) | ||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG6, $recvfrom_type_arg6, | ||||
| @@ -2843,7 +2856,7 @@ AC_DEFUN([DO_CURL_OFF_T_CHECK], [ | ||||
|     tmp_includes="" | ||||
|     tmp_source="" | ||||
|     tmp_fmt="" | ||||
|     case AS_TR_SH([$1]) in | ||||
|     case XC_SH_TR_SH([$1]) in | ||||
|       int64_t) | ||||
|         tmp_includes="$curl_includes_inttypes" | ||||
|         tmp_source="char f@<:@@:>@ = PRId64;" | ||||
| @@ -2901,7 +2914,7 @@ AC_DEFUN([DO_CURL_OFF_T_SUFFIX_CHECK], [ | ||||
|   curl_suffix_curl_off_t="unknown" | ||||
|   curl_suffix_curl_off_tu="unknown" | ||||
|   # | ||||
|   case AS_TR_SH([$1]) in | ||||
|   case XC_SH_TR_SH([$1]) in | ||||
|     long_long | __longlong | __longlong_t) | ||||
|       tst_suffixes="LL::" | ||||
|       ;; | ||||
| @@ -3073,7 +3086,7 @@ AC_DEFUN([CURL_CONFIGURE_CURL_OFF_T], [ | ||||
|     curl_format_curl_off_tu=`echo "$curl_format_curl_off_tu" | "$SED" 's/D$/U/'` | ||||
|   else | ||||
|     x_pull_headers="no" | ||||
|     case AS_TR_SH([$curl_typeof_curl_off_t]) in | ||||
|     case XC_SH_TR_SH([$curl_typeof_curl_off_t]) in | ||||
|       long_long | __longlong | __longlong_t) | ||||
|         curl_format_curl_off_t="lld" | ||||
|         curl_format_curl_off_tu="llu" | ||||
|   | ||||
							
								
								
									
										180
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										180
									
								
								buildconf
									
									
									
									
									
								
							| @@ -6,7 +6,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # | ||||
| # This software is licensed as described in the file COPYING, which | ||||
| # you should have received as part of this distribution. The terms | ||||
| @@ -21,9 +21,12 @@ | ||||
| # | ||||
| ########################################################################### | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # die prints argument string to stdout and exits this shell script. | ||||
| # | ||||
| die(){ | ||||
| 	echo "$@" | ||||
| 	exit | ||||
|   echo "buildconf: $@" | ||||
|   exit 1 | ||||
| } | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| @@ -33,11 +36,8 @@ die(){ | ||||
| findtool(){ | ||||
|   file="$1" | ||||
|  | ||||
|   if { echo $file | grep "/" >/dev/null 2>&1; } then | ||||
|     # we only check for the explicit file name if the file is given | ||||
|     # including a slash. Use ./ for current dir. Previously this would | ||||
|     # otherwise always cause findtool to search the local dir first, which | ||||
|     # is wrong. | ||||
|   if { echo "$file" | grep "/" >/dev/null 2>&1; } then | ||||
|     # when file is given with a path check it first | ||||
|     if test -f "$file"; then | ||||
|       echo "$file" | ||||
|       return | ||||
| @@ -80,16 +80,19 @@ removethis(){ | ||||
| # Ensure that buildconf runs from the subdirectory where configure.ac lives | ||||
| # | ||||
| if test ! -f configure.ac || | ||||
|   test ! -f src/main.c || | ||||
|   test ! -f src/tool_main.c || | ||||
|   test ! -f lib/urldata.h || | ||||
|   test ! -f include/curl/curl.h; then | ||||
|   test ! -f include/curl/curl.h || | ||||
|   test ! -f m4/curl-functions.m4; then | ||||
|   echo "Can not run buildconf from outside of curl's source subdirectory!" | ||||
|   echo "Change to the subdirectory where buildconf is found, and try again." | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # autoconf 2.57 or newer | ||||
| # autoconf 2.57 or newer. Unpatched version 2.67 does not generate proper | ||||
| # configure script. Unpatched version 2.68 is simply unusable, we should | ||||
| # disallow 2.68 usage. | ||||
| # | ||||
| need_autoconf="2.57" | ||||
| ac_version=`${AUTOCONF:-autoconf} --version 2>/dev/null|head -n 1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||
| @@ -108,7 +111,15 @@ if test "$1" = "2" -a "$2" -lt "57" || test "$1" -lt "2"; then | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| echo "buildconf: autoconf version $ac_version (ok)" | ||||
| if test "$1" = "2" -a "$2" -eq "67"; then | ||||
|   echo "buildconf: autoconf version $ac_version (BAD)" | ||||
|   echo "            Unpatched version generates broken configure script." | ||||
| elif test "$1" = "2" -a "$2" -eq "68"; then | ||||
|   echo "buildconf: autoconf version $ac_version (BAD)" | ||||
|   echo "            Unpatched version generates unusable configure script." | ||||
| else | ||||
|   echo "buildconf: autoconf version $ac_version (ok)" | ||||
| fi | ||||
|  | ||||
| am4te_version=`${AUTOM4TE:-autom4te} --version 2>/dev/null|head -n 1| sed -e 's/autom4te\(.*\)/\1/' -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||
| if test -z "$am4te_version"; then | ||||
| @@ -178,27 +189,24 @@ else | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # libtool check | ||||
| # GNU libtool preliminary check | ||||
| # | ||||
| LIBTOOL_WANTED_MAJOR=1 | ||||
| LIBTOOL_WANTED_MINOR=4 | ||||
| LIBTOOL_WANTED_PATCH=2 | ||||
| LIBTOOL_WANTED_VERSION=1.4.2 | ||||
| want_lt_major=1 | ||||
| want_lt_minor=4 | ||||
| want_lt_patch=2 | ||||
| want_lt_version=1.4.2 | ||||
|  | ||||
| # This approach that tries 'glibtool' first is intended for systems that | ||||
| # have GNU libtool named as 'glibtool' and libtool not being GNU's. | ||||
|  | ||||
| # this approach that tries 'glibtool' first is some kind of work-around for | ||||
| # some BSD-systems I believe that use to provide the GNU libtool named | ||||
| # glibtool, with 'libtool' being something completely different. | ||||
| libtool=`findtool glibtool 2>/dev/null` | ||||
| if test ! -x "$libtool"; then | ||||
|   libtool=`findtool ${LIBTOOL:-libtool}` | ||||
| fi | ||||
|  | ||||
| if test -z "$LIBTOOLIZE"; then | ||||
|   # set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found | ||||
|   # $libtool is already the full path | ||||
|   libtoolize="${libtool}ize" | ||||
| else | ||||
|   libtoolize=`findtool $LIBTOOLIZE` | ||||
| if test -z "$libtool"; then | ||||
|   echo "buildconf: libtool not found." | ||||
|   echo "            You need GNU libtool $want_lt_version or newer installed." | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| lt_pver=`$libtool --version 2>/dev/null|head -n 1` | ||||
| @@ -206,42 +214,55 @@ lt_qver=`echo $lt_pver|sed -e "s/([^)]*)//g" -e "s/^[^0-9]*//g"` | ||||
| lt_version=`echo $lt_qver|sed -e "s/[- ].*//" -e "s/\([a-z]*\)$//"` | ||||
| if test -z "$lt_version"; then | ||||
|   echo "buildconf: libtool not found." | ||||
|   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||
|   echo "            You need GNU libtool $want_lt_version or newer installed." | ||||
|   exit 1 | ||||
| fi | ||||
| old_IFS=$IFS; IFS='.'; set $lt_version; IFS=$old_IFS | ||||
| lt_major=$1 | ||||
| lt_minor=$2 | ||||
| lt_patch=$3 | ||||
| lt_status="good" | ||||
|  | ||||
| if test "$lt_major" = "$LIBTOOL_WANTED_MAJOR"; then | ||||
|    if test "$lt_minor" -lt "$LIBTOOL_WANTED_MINOR"; then | ||||
|       lt_status="bad" | ||||
|    elif test -n "$LIBTOOL_WANTED_PATCH"; then | ||||
|        if test "$lt_minor" -gt "$LIBTOOL_WANTED_MINOR"; then | ||||
|          lt_status="good" | ||||
|        elif test -n "$lt_patch"; then | ||||
|           if test "$lt_patch" -lt "$LIBTOOL_WANTED_PATCH"; then | ||||
|              lt_status="bad" | ||||
|           fi | ||||
|        else | ||||
|           lt_status="bad" | ||||
|        fi | ||||
|    fi | ||||
| if test -z "$lt_major"; then | ||||
|   lt_status="bad" | ||||
| elif test "$lt_major" -gt "$want_lt_major"; then | ||||
|   lt_status="good" | ||||
| elif test "$lt_major" -lt "$want_lt_major"; then | ||||
|   lt_status="bad" | ||||
| elif test -z "$lt_minor"; then | ||||
|   lt_status="bad" | ||||
| elif test "$lt_minor" -gt "$want_lt_minor"; then | ||||
|   lt_status="good" | ||||
| elif test "$lt_minor" -lt "$want_lt_minor"; then | ||||
|   lt_status="bad" | ||||
| elif test -z "$lt_patch"; then | ||||
|   lt_status="bad" | ||||
| elif test "$lt_patch" -gt "$want_lt_patch"; then | ||||
|   lt_status="good" | ||||
| elif test "$lt_patch" -lt "$want_lt_patch"; then | ||||
|   lt_status="bad" | ||||
| else | ||||
|   lt_status="good" | ||||
| fi | ||||
| if test $lt_status != "good"; then | ||||
| if test "$lt_status" != "good"; then | ||||
|   echo "buildconf: libtool version $lt_version found." | ||||
|   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||
|   echo "            You need GNU libtool $want_lt_version or newer installed." | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| echo "buildconf: libtool version $lt_version (ok)" | ||||
|  | ||||
| if test -f "$libtoolize"; then | ||||
|   echo "buildconf: libtoolize found" | ||||
| #-------------------------------------------------------------------------- | ||||
| # GNU libtoolize check | ||||
| # | ||||
| if test -z "$LIBTOOLIZE"; then | ||||
|   # use (g)libtoolize from same location as (g)libtool | ||||
|   libtoolize="${libtool}ize" | ||||
| else | ||||
|   echo "buildconf: libtoolize not found. Weird libtool installation!" | ||||
|   libtoolize=`findtool $LIBTOOLIZE` | ||||
| fi | ||||
| if test ! -f "$libtoolize"; then | ||||
|   echo "buildconf: libtoolize not found." | ||||
|   echo "            You need GNU libtoolize $want_lt_version or newer installed." | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| @@ -266,6 +287,10 @@ fi | ||||
| # perl check | ||||
| # | ||||
| PERL=`findtool ${PERL:-perl}` | ||||
| if test -z "$PERL"; then | ||||
|   echo "buildconf: perl not found" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # Remove files generated on previous buildconf/configure run. | ||||
| @@ -301,6 +326,7 @@ for fname in .deps \ | ||||
|     libcurl.pc \ | ||||
|     libtool \ | ||||
|     libtool.m4 \ | ||||
|     libtool.m4.tmp \ | ||||
|     ltmain.sh \ | ||||
|     ltoptions.m4 \ | ||||
|     ltsugar.m4 \ | ||||
| @@ -317,32 +343,52 @@ done | ||||
| # | ||||
|  | ||||
| echo "buildconf: running libtoolize" | ||||
| $libtoolize --copy --automake --force || die "The libtoolize command failed" | ||||
| ${libtoolize} --copy --automake --force || die "libtoolize command failed" | ||||
|  | ||||
| if test ! -f m4/curl-functions.m4; then | ||||
|   echo "buildconf: cURL m4 macros not found" | ||||
|   exit 1 | ||||
| # When using libtool 1.5.X (X < 26) we copy libtool.m4 to our local m4 | ||||
| # subdirectory and this local copy is patched to fix some warnings that | ||||
| # are triggered when running aclocal and using autoconf 2.62 or later. | ||||
|  | ||||
| if test "$lt_major" = "1" && test "$lt_minor" = "5"; then | ||||
|   if test -z "$lt_patch" || test "$lt_patch" -lt "26"; then | ||||
|     echo "buildconf: copying libtool.m4 to local m4 subdir" | ||||
|     ac_dir=`${ACLOCAL:-aclocal} --print-ac-dir` | ||||
|     if test -f $ac_dir/libtool.m4; then | ||||
|       cp -f $ac_dir/libtool.m4 m4/libtool.m4 | ||||
|     else | ||||
|       echo "buildconf: $ac_dir/libtool.m4 not found" | ||||
|     fi | ||||
|     if test -f m4/libtool.m4; then | ||||
|       echo "buildconf: renaming some variables in local m4/libtool.m4" | ||||
|       $PERL -i.tmp -pe \ | ||||
|         's/lt_prog_compiler_pic_works/lt_cv_prog_compiler_pic_works/g; \ | ||||
|          s/lt_prog_compiler_static_works/lt_cv_prog_compiler_static_works/g;' \ | ||||
|         m4/libtool.m4 | ||||
|       rm -f m4/libtool.m4.tmp | ||||
|     fi | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| if test -f m4/libtool.m4; then | ||||
|   echo "buildconf: converting all mv to mv -f in local m4/libtool.m4" | ||||
|   $PERL -i.tmp -pe 's/\bmv +([^-\s])/mv -f $1/g' m4/libtool.m4 | ||||
|   rm -f m4/libtool.m4.tmp | ||||
| fi | ||||
|  | ||||
| echo "buildconf: running aclocal" | ||||
| ${ACLOCAL:-aclocal} -I m4 $ACLOCAL_FLAGS || die "The aclocal command line failed" | ||||
| ${ACLOCAL:-aclocal} -I m4 $ACLOCAL_FLAGS || die "aclocal command failed" | ||||
|  | ||||
| if test -n "$PERL"; then | ||||
|   echo "buildconf: running aclocal hack to convert all mv to mv -f" | ||||
|   $PERL -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4 | ||||
| else | ||||
|   echo "buildconf: perl not found" | ||||
|   exit 1 | ||||
| fi | ||||
| echo "buildconf: converting all mv to mv -f in local aclocal.m4" | ||||
| $PERL -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4 | ||||
|  | ||||
| echo "buildconf: running autoheader" | ||||
| ${AUTOHEADER:-autoheader} || die "The autoheader command failed" | ||||
| ${AUTOHEADER:-autoheader} || die "autoheader command failed" | ||||
|  | ||||
| echo "buildconf: cp lib/curl_config.h.in src/curl_config.h.in" | ||||
| cp lib/curl_config.h.in src/curl_config.h.in | ||||
|  | ||||
| echo "buildconf: running autoconf" | ||||
| ${AUTOCONF:-autoconf}     || die "The autoconf command failed" | ||||
| ${AUTOCONF:-autoconf} || die "autoconf command failed" | ||||
|  | ||||
| if test -d ares; then | ||||
|   cd ares | ||||
| @@ -352,14 +398,15 @@ if test -d ares; then | ||||
| fi | ||||
|  | ||||
| echo "buildconf: running automake" | ||||
| ${AUTOMAKE:-automake} -a -c  || die "The automake command failed" | ||||
| ${AUTOMAKE:-automake} --add-missing --copy || die "automake command failed" | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # GNU libtool complementary check | ||||
| # | ||||
| # Depending on the libtool and automake versions being used, config.guess | ||||
| # might not be installed in the subdirectory until automake has finished. | ||||
| # So we can not attempt to use it until this very last buildconf stage. | ||||
| # | ||||
|  | ||||
| if test ! -f ./config.guess; then | ||||
|   echo "buildconf: config.guess not found" | ||||
| else | ||||
| @@ -403,7 +450,7 @@ else | ||||
|     if test "$lt_status" != "good"; then | ||||
|       need_lt_version="$need_lt_major.$need_lt_minor.$need_lt_patch" | ||||
|       echo "buildconf: libtool version $lt_version found." | ||||
|       echo "            $buildhost requires libtool $need_lt_version or newer installed." | ||||
|       echo "            $buildhost requires GNU libtool $need_lt_version or newer installed." | ||||
|       rm -f configure | ||||
|       exit 1 | ||||
|     fi | ||||
| @@ -411,8 +458,7 @@ else | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # Finished succesfully. | ||||
| # Finished successfully. | ||||
| # | ||||
|  | ||||
| echo "buildconf: OK" | ||||
| exit 0 | ||||
|   | ||||
| @@ -27,6 +27,11 @@ if not exist include\curl\curlbuild.h.dist goto end_curlbuild_h | ||||
| copy /Y include\curl\curlbuild.h.dist include\curl\curlbuild.h | ||||
| :end_curlbuild_h | ||||
|  | ||||
| REM create src\config-win32.h | ||||
| if not exist lib\config-win32.h goto end_config_win32_h | ||||
| copy /Y lib\config-win32.h src\config-win32.h | ||||
| :end_config_win32_h | ||||
|  | ||||
| REM setup c-ares git tree | ||||
| if not exist ares\buildconf.bat goto end_c_ares | ||||
| cd ares | ||||
|   | ||||
							
								
								
									
										463
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										463
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # | ||||
| # This software is licensed as described in the file COPYING, which | ||||
| # you should have received as part of this distribution. The terms | ||||
| @@ -26,6 +26,7 @@ AC_PREREQ(2.57) | ||||
| dnl We don't know the version number "statically" so we use a dash here | ||||
| AC_INIT([curl], [-], [a suitable curl mailing list: http://curl.haxx.se/mail/]) | ||||
|  | ||||
| XC_OVR_ZZ50 | ||||
| CURL_OVERRIDE_AUTOCONF | ||||
|  | ||||
| dnl configure script copyright | ||||
| @@ -154,6 +155,7 @@ curl_tls_srp_msg="no      (--enable-tls-srp)" | ||||
|    curl_ipv6_msg="no      (--enable-ipv6)" | ||||
|     curl_idn_msg="no      (--with-libidn)" | ||||
|  curl_manual_msg="no      (--enable-manual)" | ||||
| curl_libcurl_msg="enabled (--disable-libcurl-option)" | ||||
| curl_verbose_msg="enabled (--disable-verbose)" | ||||
|    curl_sspi_msg="no      (--enable-sspi)" | ||||
|    curl_ldap_msg="no      (--enable-ldap / --with-ldap-lib / --with-lber-lib)" | ||||
| @@ -305,6 +307,44 @@ AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||
| CURL_CHECK_CURLDEBUG | ||||
| AM_CONDITIONAL(CURLDEBUG, test x$want_curldebug = xyes) | ||||
|  | ||||
| supports_unittests=yes | ||||
| # cross-compilation of unit tests static library/programs fails when | ||||
| # libcurl shared library is built. This might be due to a libtool or | ||||
| # automake issue. In this case we disable unit tests. | ||||
| if test "x$cross_compiling" != "xno" && | ||||
|    test "x$enable_shared" != "xno"; then | ||||
|   supports_unittests=no | ||||
| fi | ||||
|  | ||||
| # IRIX 6.5.24 gcc 3.3 autobuilds fail unittests library compilation due to | ||||
| # a problem related with OpenSSL headers and library versions not matching. | ||||
| # Disable unit tests while time to further investigate this is found. | ||||
| case $host in | ||||
|   mips-sgi-irix6.5) | ||||
|     if test "$compiler_id" = "GNU_C"; then | ||||
|       supports_unittests=no | ||||
|     fi | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| # All AIX autobuilds fails unit tests linking against unittests library | ||||
| # due to unittests library being built with no symbols or members. Libtool ? | ||||
| # Disable unit tests while time to further investigate this is found. | ||||
| case $host_os in | ||||
|   aix*) | ||||
|     supports_unittests=no | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| dnl Build unit tests when option --enable-debug is given. | ||||
| if test "x$want_debug" = "xyes" && | ||||
|    test "x$supports_unittests" = "xyes"; then | ||||
|   want_unittests=yes | ||||
| else | ||||
|   want_unittests=no | ||||
| fi | ||||
| AM_CONDITIONAL(BUILD_UNITTESTS, test x$want_unittests = xyes) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Compilation based checks should not be done before this point. | ||||
| dnl ********************************************************************** | ||||
| @@ -612,6 +652,25 @@ AC_HELP_STRING([--disable-manual],[Disable built-in manual]), | ||||
| dnl The actual use of the USE_MANUAL variable is done much later in this | ||||
| dnl script to allow other actions to disable it as well. | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl disable C code generation support | ||||
| dnl | ||||
| AC_MSG_CHECKING([whether to enable generation of C code]) | ||||
| AC_ARG_ENABLE(libcurl_option, | ||||
| AC_HELP_STRING([--enable-libcurl-option],[Enable --libcurl C code generation support]) | ||||
| AC_HELP_STRING([--disable-libcurl-option],[Disable --libcurl C code generation support]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_LIBCURL_OPTION, 1, [to disable --libcurl C code generation option]) | ||||
|        curl_libcurl_msg="no" | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Checks for libraries. | ||||
| dnl ********************************************************************** | ||||
| @@ -1312,7 +1371,7 @@ if test X"$OPT_SSL" != Xno; then | ||||
|     dnl the user told us to look | ||||
|     OPENSSL_PCDIR="$OPT_SSL/lib/pkgconfig" | ||||
|     AC_MSG_NOTICE([PKG_CONFIG_LIBDIR will be set to "$OPENSSL_PCDIR"]) | ||||
|     if test -e "$OPENSSL_PCDIR/openssl.pc"; then | ||||
|     if test -f "$OPENSSL_PCDIR/openssl.pc"; then | ||||
|       PKGTEST="yes" | ||||
|     fi | ||||
|  | ||||
| @@ -1476,7 +1535,8 @@ if test X"$OPT_SSL" != Xno; then | ||||
|                     RAND_egd \ | ||||
|                     ENGINE_cleanup \ | ||||
|                     CRYPTO_cleanup_all_ex_data \ | ||||
|                     SSL_get_shutdown ) | ||||
|                     SSL_get_shutdown \ | ||||
|                     SSLv2_client_method ) | ||||
|  | ||||
|     dnl Make an attempt to detect if this is actually yassl's headers and | ||||
|     dnl OpenSSL emulation layer. We still leave everything else believing | ||||
| @@ -1508,11 +1568,13 @@ if test X"$OPT_SSL" != Xno; then | ||||
|        dnl when the ssl shared libs were found in a path that the run-time | ||||
|        dnl linker doesn't search through, we need to add it to LD_LIBRARY_PATH | ||||
|        dnl to prevent further configure tests to fail due to this | ||||
|  | ||||
|        LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_OPENSSL" | ||||
|        export LD_LIBRARY_PATH | ||||
|        AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH]) | ||||
|        if test "x$cross_compiling" != "xyes"; then | ||||
|          LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_OPENSSL" | ||||
|          export LD_LIBRARY_PATH | ||||
|          AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH]) | ||||
|        fi | ||||
|     fi | ||||
|     CURL_CHECK_OPENSSL_API | ||||
|   fi | ||||
|  | ||||
| fi | ||||
| @@ -1624,8 +1686,12 @@ if test X"$OPENSSL_ENABLED" = X"1"; then | ||||
|                  [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 x$cross_compiling != xyes; then | ||||
|             dnl Check for random device | ||||
|             AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] ) | ||||
|           else | ||||
|             AC_MSG_WARN([skipped the /dev/urandom detection when cross-compiling]) | ||||
|           fi | ||||
|       ] | ||||
|   ) | ||||
|   if test -n "$RANDOM_FILE" && test X"$RANDOM_FILE" != Xno ; then | ||||
| @@ -1742,10 +1808,11 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|           dnl linker doesn't search through, we need to add it to | ||||
|           dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||
|           dnl due to this | ||||
|  | ||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlslib" | ||||
|           export LD_LIBRARY_PATH | ||||
|           AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH]) | ||||
|           if test "x$cross_compiling" != "xyes"; then  | ||||
|             LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlslib" | ||||
|             export LD_LIBRARY_PATH | ||||
|             AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH]) | ||||
|           fi | ||||
|         fi | ||||
|       fi | ||||
|  | ||||
| @@ -1756,17 +1823,33 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
| fi dnl OPENSSL != 1 | ||||
|  | ||||
| dnl --- | ||||
| dnl If GnuTLS is enabled, we MUST verify that it uses libgcrypt since | ||||
| dnl curl code relies on that but recent GnuTLS versions can in fact build | ||||
| dnl with different crypto libraries which curl right now cannot handle | ||||
| dnl Check which crypto backend GnuTLS uses | ||||
| dnl --- | ||||
|  | ||||
| if test "$GNUTLS_ENABLED" = "1"; then | ||||
|   AC_CHECK_LIB(gcrypt, | ||||
|                gcry_control, , | ||||
|     [ | ||||
|       AC_MSG_ERROR([need GnuTLS built with gcrypt to function with GnuTLS]) | ||||
|     ]) | ||||
|   USE_GNUTLS_NETTLE= | ||||
|   # First check if we can detect either crypto library via transitive linking | ||||
|   AC_CHECK_LIB(gnutls, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ]) | ||||
|   if test "$USE_GNUTLS_NETTLE" = ""; then | ||||
|     AC_CHECK_LIB(gnutls, gcry_control, [ USE_GNUTLS_NETTLE=0 ]) | ||||
|   fi | ||||
|   # If not, try linking directly to both of them to see if they are available | ||||
|   if test "$USE_GNUTLS_NETTLE" = ""; then | ||||
|     AC_CHECK_LIB(nettle, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ]) | ||||
|   fi | ||||
|   if test "$USE_GNUTLS_NETTLE" = ""; then | ||||
|     AC_CHECK_LIB(gcrypt, gcry_control, [ USE_GNUTLS_NETTLE=0 ]) | ||||
|   fi | ||||
|   if test "$USE_GNUTLS_NETTLE" = ""; then | ||||
|     AC_MSG_ERROR([GnuTLS found, but neither gcrypt nor nettle found]) | ||||
|   fi | ||||
|   if test "$USE_GNUTLS_NETTLE" = "1"; then | ||||
|     AC_DEFINE(USE_GNUTLS_NETTLE, 1, [if GnuTLS uses nettle as crypto backend]) | ||||
|     AC_SUBST(USE_GNUTLS_NETTLE, [1]) | ||||
|     LIBS="$LIBS -lnettle" | ||||
|   else | ||||
|     LIBS="$LIBS -lgcrypt" | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| dnl --- | ||||
| @@ -1852,12 +1935,12 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|         dnl linker doesn't search through, we need to add it to | ||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||
|         dnl due to this | ||||
|  | ||||
|         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib" | ||||
|         export LD_LIBRARY_PATH | ||||
|         AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH]) | ||||
|         if test "x$cross_compiling" != "xyes"; then | ||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib" | ||||
|           export LD_LIBRARY_PATH | ||||
|           AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH]) | ||||
|         fi | ||||
|       fi | ||||
|  | ||||
|     fi | ||||
|  | ||||
|   fi dnl PolarSSL not disabled | ||||
| @@ -1874,7 +1957,7 @@ OPT_CYASSL=no | ||||
| _cppflags=$CPPFLAGS | ||||
| _ldflags=$LDFLAGS | ||||
| AC_ARG_WITH(cyassl,dnl | ||||
| AC_HELP_STRING([--with-cyassl=PATH],[where to look for CyaSSL, PATH points to the installation root (default: /usr/local/cyassl)]) | ||||
| AC_HELP_STRING([--with-cyassl=PATH],[where to look for CyaSSL, PATH points to the installation root (default: system lib default)]) | ||||
| AC_HELP_STRING([--without-cyassl], [disable CyaSSL detection]), | ||||
|   OPT_CYASSL=$withval) | ||||
|  | ||||
| @@ -1887,14 +1970,9 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|     fi | ||||
|  | ||||
|     if test -z "$OPT_CYASSL" ; then | ||||
|       dnl check for lib in default first | ||||
|       dnl check for lib in system default first | ||||
|  | ||||
|       trycyassldir="/usr/local/cyassl" | ||||
|  | ||||
|       LDFLAGS="$LDFLAGS -L$trycyassldir/lib" | ||||
|       CPPFLAGS="$CPPFLAGS -I$trycyassldir/include" | ||||
|  | ||||
|       AC_CHECK_LIB(cyassl, InitCyaSSL, | ||||
|       AC_CHECK_LIB(cyassl, CyaSSL_Init, | ||||
|       dnl libcyassl found, set the variable | ||||
|        [ | ||||
|          AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) | ||||
| @@ -1916,7 +1994,7 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|          CPPFLAGS="$CPPFLAGS $addcflags" | ||||
|       fi | ||||
|  | ||||
|       AC_CHECK_LIB(cyassl, InitCyaSSL, | ||||
|       AC_CHECK_LIB(cyassl, CyaSSL_Init, | ||||
|        [ | ||||
|        AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) | ||||
|        AC_SUBST(USE_CYASSL, [1]) | ||||
| @@ -1941,10 +2019,11 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|         dnl linker doesn't search through, we need to add it to | ||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||
|         dnl due to this | ||||
|  | ||||
|         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$cyassllib" | ||||
|         export LD_LIBRARY_PATH | ||||
|         AC_MSG_NOTICE([Added $cyassllib to LD_LIBRARY_PATH]) | ||||
|         if test "x$cross_compiling" != "xyes"; then | ||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$cyassllib" | ||||
|           export LD_LIBRARY_PATH | ||||
|           AC_MSG_NOTICE([Added $cyassllib to LD_LIBRARY_PATH]) | ||||
|         fi | ||||
|       fi | ||||
|  | ||||
|     fi | ||||
| @@ -2037,10 +2116,11 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | ||||
|         dnl linker doesn't search through, we need to add it to | ||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||
|         dnl due to this | ||||
|  | ||||
|         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff" | ||||
|         export LD_LIBRARY_PATH | ||||
|         AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH]) | ||||
|         if test "x$cross_compiling" != "xyes"; then | ||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff" | ||||
|           export LD_LIBRARY_PATH | ||||
|           AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH]) | ||||
|         fi | ||||
|       fi | ||||
|  | ||||
|     fi | ||||
| @@ -2197,10 +2277,11 @@ if test X"$OPT_LIBSSH2" != Xno; then | ||||
|        dnl libssh2_session_handshake was added in 1.2.8 | ||||
|        AC_CHECK_FUNCS( libssh2_version libssh2_init libssh2_exit \ | ||||
|                        libssh2_scp_send64 libssh2_session_handshake) | ||||
|  | ||||
|        LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2" | ||||
|        export LD_LIBRARY_PATH | ||||
|        AC_MSG_NOTICE([Added $DIR_SSH2 to LD_LIBRARY_PATH]) | ||||
|        if test "x$cross_compiling" != "xyes"; then | ||||
|          LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2" | ||||
|          export LD_LIBRARY_PATH | ||||
|          AC_MSG_NOTICE([Added $DIR_SSH2 to LD_LIBRARY_PATH]) | ||||
|        fi | ||||
|     fi | ||||
|   else | ||||
|     dnl no libssh2, revert back to clean variables | ||||
| @@ -2288,56 +2369,202 @@ if test X"$OPT_LIBRTMP" != Xno; then | ||||
|  | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for linker switch for versioned symbols | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| AC_MSG_CHECKING([if libraries can be versioned]) | ||||
| GLD=`$LD --help < /dev/null 2>/dev/null | grep version-script` | ||||
| if test -z "$GLD"; then | ||||
|     versioned_symbols_flavour= | ||||
|     AC_MSG_RESULT(no) | ||||
|     AC_MSG_WARN(*** | ||||
| *** You need an ld version supporting the --version-script option. | ||||
| ) | ||||
| else | ||||
|     AC_MSG_RESULT(yes) | ||||
|  | ||||
| AC_MSG_CHECKING([whether versioned symbols are wanted]) | ||||
| versioned_symbols_flavour= | ||||
|  | ||||
| AC_ARG_ENABLE(versioned-symbols, | ||||
| AC_HELP_STRING([--enable-versioned-symbols], [Enable versioned symbols in shared library]) | ||||
| AC_HELP_STRING([--disable-versioned-symbols], [Disable versioned symbols in shared library]), | ||||
| [ case "$enableval" in | ||||
|   yes) AC_MSG_RESULT(yes) | ||||
|     if test "x$OPENSSL_ENABLED" = "x1"; then | ||||
|       versioned_symbols_flavour="OPENSSL_" | ||||
|     elif test "x$GNUTLS_ENABLED" == "x1"; then | ||||
|       versioned_symbols_flavour="GNUTLS_" | ||||
|     elif test "x$NSS_ENABLED" == "x1"; then | ||||
|       versioned_symbols_flavour="NSS_" | ||||
|     elif test "x$POLARSSL_ENABLED" == "x1"; then | ||||
|       versioned_symbols_flavour="POLARSSL_" | ||||
|     elif test "x$CYASSL_ENABLED" == "x1"; then | ||||
|       versioned_symbols_flavour="CYASSL_" | ||||
|     elif test "x$AXTLS_ENABLED" == "x1"; then | ||||
|       versioned_symbols_flavour="AXTLS_" | ||||
|     else | ||||
|       versioned_symbols_flavour="" | ||||
|     fi | ||||
|     versioned_symbols="yes" | ||||
|     ;; | ||||
|  | ||||
|   *)   AC_MSG_RESULT(no) | ||||
|     ;; | ||||
|   esac | ||||
| ], [ | ||||
| AC_MSG_RESULT(no) | ||||
| ] | ||||
| ) | ||||
| fi | ||||
|  | ||||
| AC_SUBST(VERSIONED_FLAVOUR, ["$versioned_symbols_flavour"]) | ||||
| AM_CONDITIONAL(VERSIONED_SYMBOLS, test "x$versioned_symbols" = "xyes") | ||||
|  | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the presence of IDN libraries and headers | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| AC_MSG_CHECKING([whether to build with libidn]) | ||||
| OPT_IDN="default" | ||||
| AC_ARG_WITH(libidn, | ||||
| AC_HELP_STRING([--with-libidn=PATH],[Enable libidn usage]) | ||||
| AC_HELP_STRING([--without-libidn],[Disable libidn usage]), | ||||
|   [LIBIDN="$withval"]) | ||||
|  | ||||
| case "$LIBIDN" in | ||||
|   [OPT_IDN=$withval]) | ||||
| case "$OPT_IDN" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|  | ||||
|        idn="" | ||||
|        dnl if there is a given path, check that FIRST | ||||
|        if test -n "$LIBIDN"; then | ||||
|          if test "x$LIBIDN" != "xyes"; then | ||||
|             oldLDFLAGS=$LDFLAGS | ||||
|             oldCPPFLAGS=$CPPFLAGS | ||||
|             LDFLAGS="$LDFLAGS -L$LIBIDN/lib" | ||||
|             CPPFLAGS="$CPPFLAGS -I$LIBIDN/include" | ||||
|             idn="yes" | ||||
|             AC_CHECK_LIB(idn, idna_to_ascii_4i, , | ||||
|                          idn="" | ||||
|                          LDFLAGS=$oldLDFLAGS | ||||
|                          CPPFLAGS=$oldCPPFLAGS) | ||||
|          fi | ||||
|        fi | ||||
|  | ||||
|        if test "x$idn" != "xyes"; then | ||||
|           dnl check with default paths | ||||
|           idn="yes" | ||||
|           AC_CHECK_LIB(idn, idna_to_ascii_lz, , | ||||
|                        idn="") | ||||
|        fi | ||||
|  | ||||
|        if test "x$idn" = "xyes"; then | ||||
|          curl_idn_msg="enabled" | ||||
|          AC_SUBST(IDN_ENABLED, [1]) | ||||
|          dnl different versions of libidn have different setups of these: | ||||
|          AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror) | ||||
|          AC_CHECK_HEADERS( idn-free.h tld.h ) | ||||
|        fi | ||||
|  | ||||
|        ;; | ||||
|     dnl --without-libidn option used | ||||
|     want_idn="no" | ||||
|     AC_MSG_RESULT([no]) | ||||
|     ;; | ||||
|   default) | ||||
|     dnl configure option not specified | ||||
|     want_idn="yes" | ||||
|     want_idn_path="default" | ||||
|     AC_MSG_RESULT([(assumed) yes]) | ||||
|     ;; | ||||
|   yes) | ||||
|     dnl --with-libidn option used without path | ||||
|     want_idn="yes" | ||||
|     want_idn_path="default" | ||||
|     AC_MSG_RESULT([yes]) | ||||
|     ;; | ||||
|   *) | ||||
|     dnl --with-libidn option used with path | ||||
|     want_idn="yes" | ||||
|     want_idn_path="$withval" | ||||
|     AC_MSG_RESULT([yes ($withval)]) | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| if test "$want_idn" = "yes"; then | ||||
|   dnl idn library support has been requested | ||||
|   clean_CPPFLAGS="$CPPFLAGS" | ||||
|   clean_LDFLAGS="$LDFLAGS" | ||||
|   clean_LIBS="$LIBS" | ||||
|   PKGCONFIG="no" | ||||
|   # | ||||
|   if test "$want_idn_path" != "default"; then | ||||
|     dnl path has been specified | ||||
|     IDN_PCDIR="$want_idn_path/lib$libsuff/pkgconfig" | ||||
|     CURL_CHECK_PKGCONFIG(libidn, [$IDN_PCDIR]) | ||||
|     if test "$PKGCONFIG" != "no"; then | ||||
|       IDN_LIBS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl | ||||
|         $PKGCONFIG --libs-only-l libidn 2>/dev/null` | ||||
|       IDN_LDFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl | ||||
|         $PKGCONFIG --libs-only-L libidn 2>/dev/null` | ||||
|       IDN_CPPFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl | ||||
|         $PKGCONFIG --cflags-only-I libidn 2>/dev/null` | ||||
|       IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/-L//'` | ||||
|     else | ||||
|       dnl pkg-config not available or provides no info | ||||
|       IDN_LIBS="-lidn" | ||||
|       IDN_LDFLAGS="-L$want_idn_path/lib$libsuff" | ||||
|       IDN_CPPFLAGS="-I$want_idn_path/include" | ||||
|       IDN_DIR="$want_idn_path/lib$libsuff" | ||||
|     fi | ||||
|   else | ||||
|     dnl path not specified | ||||
|     CURL_CHECK_PKGCONFIG(libidn) | ||||
|     if test "$PKGCONFIG" != "no"; then | ||||
|       IDN_LIBS=`$PKGCONFIG --libs-only-l libidn 2>/dev/null` | ||||
|       IDN_LDFLAGS=`$PKGCONFIG --libs-only-L libidn 2>/dev/null` | ||||
|       IDN_CPPFLAGS=`$PKGCONFIG --cflags-only-I libidn 2>/dev/null` | ||||
|       IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/-L//'` | ||||
|     else | ||||
|       dnl pkg-config not available or provides no info | ||||
|       IDN_LIBS="-lidn" | ||||
|     fi | ||||
|   fi | ||||
|   # | ||||
|   if test "$PKGCONFIG" != "no"; then | ||||
|     AC_MSG_NOTICE([pkg-config: IDN_LIBS: "$IDN_LIBS"]) | ||||
|     AC_MSG_NOTICE([pkg-config: IDN_LDFLAGS: "$IDN_LDFLAGS"]) | ||||
|     AC_MSG_NOTICE([pkg-config: IDN_CPPFLAGS: "$IDN_CPPFLAGS"]) | ||||
|     AC_MSG_NOTICE([pkg-config: IDN_DIR: "$IDN_DIR"]) | ||||
|   else | ||||
|     AC_MSG_NOTICE([IDN_LIBS: "$IDN_LIBS"]) | ||||
|     AC_MSG_NOTICE([IDN_LDFLAGS: "$IDN_LDFLAGS"]) | ||||
|     AC_MSG_NOTICE([IDN_CPPFLAGS: "$IDN_CPPFLAGS"]) | ||||
|     AC_MSG_NOTICE([IDN_DIR: "$IDN_DIR"]) | ||||
|   fi | ||||
|   # | ||||
|   CPPFLAGS="$IDN_CPPFLAGS $CPPFLAGS" | ||||
|   LDFLAGS="$IDN_LDFLAGS $LDFLAGS" | ||||
|   LIBS="$IDN_LIBS $LIBS" | ||||
|   # | ||||
|   AC_MSG_CHECKING([if idna_to_ascii_4i can be linked]) | ||||
|   AC_LINK_IFELSE([ | ||||
|     AC_LANG_FUNC_LINK_TRY([idna_to_ascii_4i]) | ||||
|   ],[ | ||||
|     AC_MSG_RESULT([yes]) | ||||
|     tst_links_libidn="yes" | ||||
|   ],[ | ||||
|     AC_MSG_RESULT([no]) | ||||
|     tst_links_libidn="no" | ||||
|   ]) | ||||
|   if test "$tst_links_libidn" = "no"; then | ||||
|     AC_MSG_CHECKING([if idna_to_ascii_lz can be linked]) | ||||
|     AC_LINK_IFELSE([ | ||||
|       AC_LANG_FUNC_LINK_TRY([idna_to_ascii_lz]) | ||||
|     ],[ | ||||
|       AC_MSG_RESULT([yes]) | ||||
|       tst_links_libidn="yes" | ||||
|     ],[ | ||||
|       AC_MSG_RESULT([no]) | ||||
|       tst_links_libidn="no" | ||||
|     ]) | ||||
|   fi | ||||
|   # | ||||
|   if test "$tst_links_libidn" = "yes"; then | ||||
|     AC_DEFINE(HAVE_LIBIDN, 1, [Define to 1 if you have the `idn' library (-lidn).]) | ||||
|     dnl different versions of libidn have different setups of these: | ||||
|     AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror ) | ||||
|     AC_CHECK_HEADERS( idn-free.h tld.h ) | ||||
|     if test "x$ac_cv_header_tld_h" = "xyes"; then | ||||
|       AC_SUBST([IDN_ENABLED], [1]) | ||||
|       curl_idn_msg="enabled" | ||||
|       if test -n "$IDN_DIR"; then | ||||
|         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$IDN_DIR" | ||||
|         export LD_LIBRARY_PATH | ||||
|         AC_MSG_NOTICE([Added $IDN_DIR to LD_LIBRARY_PATH]) | ||||
|       fi | ||||
|     else | ||||
|       AC_MSG_WARN([Libraries for IDN support too old: IDN disabled]) | ||||
|       CPPFLAGS="$clean_CPPFLAGS" | ||||
|       LDFLAGS="$clean_LDFLAGS" | ||||
|       LIBS="$clean_LIBS" | ||||
|     fi | ||||
|   else | ||||
|     AC_MSG_WARN([Cannot find libraries for IDN support: IDN disabled]) | ||||
|     CPPFLAGS="$clean_CPPFLAGS" | ||||
|     LDFLAGS="$clean_LDFLAGS" | ||||
|     LIBS="$clean_LIBS" | ||||
|   fi | ||||
| fi | ||||
|  | ||||
|  | ||||
| dnl Let's hope this split URL remains working: | ||||
| dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \ | ||||
| @@ -2396,6 +2623,7 @@ AC_CHECK_HEADERS( | ||||
|         stdbool.h \ | ||||
|         arpa/tftp.h \ | ||||
|         sys/filio.h \ | ||||
|         sys/wait.h \ | ||||
|         setjmp.h, | ||||
| dnl to do if not found | ||||
| [], | ||||
| @@ -2517,6 +2745,7 @@ CURL_CHECK_FUNC_FREEIFADDRS | ||||
| CURL_CHECK_FUNC_FSETXATTR | ||||
| CURL_CHECK_FUNC_FTRUNCATE | ||||
| CURL_CHECK_FUNC_GETADDRINFO | ||||
| CURL_CHECK_FUNC_GAI_STRERROR | ||||
| CURL_CHECK_FUNC_GETHOSTBYADDR | ||||
| CURL_CHECK_FUNC_GETHOSTBYADDR_R | ||||
| CURL_CHECK_FUNC_GETHOSTBYNAME | ||||
| @@ -2540,6 +2769,7 @@ CURL_CHECK_FUNC_SIGINTERRUPT | ||||
| CURL_CHECK_FUNC_SIGNAL | ||||
| CURL_CHECK_FUNC_SIGSETJMP | ||||
| CURL_CHECK_FUNC_SOCKET | ||||
| CURL_CHECK_FUNC_SOCKETPAIR | ||||
| CURL_CHECK_FUNC_STRCASECMP | ||||
| CURL_CHECK_FUNC_STRCASESTR | ||||
| CURL_CHECK_FUNC_STRCMPI | ||||
| @@ -2593,7 +2823,7 @@ AC_CHECK_FUNCS([fork \ | ||||
|     ],[ | ||||
|       AC_MSG_RESULT([yes]) | ||||
|       eval "ac_cv_func_$func=yes" | ||||
|       AC_DEFINE_UNQUOTED(AS_TR_CPP([HAVE_$func]), [1], | ||||
|       AC_DEFINE_UNQUOTED(XC_SH_TR_CPP([HAVE_$func]), [1], | ||||
|         [Define to 1 if you have the $func function.]) | ||||
|     ],[ | ||||
|       AC_MSG_RESULT([but still no]) | ||||
| @@ -2770,6 +3000,10 @@ AC_HELP_STRING([--disable-crypto-auth],[Disable cryptographic authentication]), | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
|  | ||||
| CURL_CHECK_OPTION_NTLM_WB | ||||
|  | ||||
| CURL_CHECK_NTLM_WB | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl disable TLS-SRP authentication | ||||
| dnl | ||||
| @@ -2945,6 +3179,9 @@ if test "x$CURL_DISABLE_HTTP" != "x1"; then | ||||
|   if test "x$USE_SSLEAY" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \ | ||||
|       -o "x$GNUTLS_ENABLED" = "x1" -o "x$NSS_ENABLED" = "x1"; then | ||||
|     SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM" | ||||
|     if test "x$NTLM_WB_ENABLED" = "x1"; then | ||||
|       SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM_WB" | ||||
|     fi | ||||
|   fi | ||||
| fi | ||||
| if test "x$USE_TLS_SRP" = "x1"; then | ||||
| @@ -3055,6 +3292,7 @@ AC_CONFIG_FILES([Makefile \ | ||||
|            include/curl/Makefile \ | ||||
|            src/Makefile \ | ||||
|            lib/Makefile \ | ||||
|            lib/libcurl.vers \ | ||||
|            tests/Makefile \ | ||||
|            tests/data/Makefile \ | ||||
|            tests/server/Makefile \ | ||||
| @@ -3083,31 +3321,32 @@ CURL_GENERATE_CONFIGUREHELP_PM | ||||
|  | ||||
| AC_MSG_NOTICE([Configured to build curl/libcurl: | ||||
|  | ||||
|   curl version:    ${CURLVERSION} | ||||
|   Host setup:      ${host} | ||||
|   Install prefix:  ${prefix} | ||||
|   Compiler:        ${CC} | ||||
|   SSL support:     ${curl_ssl_msg} | ||||
|   SSH support:     ${curl_ssh_msg} | ||||
|   zlib support:    ${curl_zlib_msg} | ||||
|   krb4 support:    ${curl_krb4_msg} | ||||
|   GSSAPI support:  ${curl_gss_msg} | ||||
|   SPNEGO support:  ${curl_spnego_msg} | ||||
|   TLS-SRP support: ${curl_tls_srp_msg} | ||||
|   resolver:        ${curl_res_msg} | ||||
|   ipv6 support:    ${curl_ipv6_msg} | ||||
|   IDN support:     ${curl_idn_msg} | ||||
|   Build libcurl:   Shared=${enable_shared}, Static=${enable_static} | ||||
|   Built-in manual: ${curl_manual_msg} | ||||
|   Verbose errors:  ${curl_verbose_msg} | ||||
|   SSPI support:    ${curl_sspi_msg} | ||||
|   ca cert bundle:  ${ca} | ||||
|   ca cert path:    ${capath} | ||||
|   LDAP support:    ${curl_ldap_msg} | ||||
|   LDAPS support:   ${curl_ldaps_msg} | ||||
|   RTSP support:    ${curl_rtsp_msg} | ||||
|   RTMP support:    ${curl_rtmp_msg} | ||||
|   Protocols:       ${SUPPORT_PROTOCOLS} | ||||
|   curl version:     ${CURLVERSION} | ||||
|   Host setup:       ${host} | ||||
|   Install prefix:   ${prefix} | ||||
|   Compiler:         ${CC} | ||||
|   SSL support:      ${curl_ssl_msg} | ||||
|   SSH support:      ${curl_ssh_msg} | ||||
|   zlib support:     ${curl_zlib_msg} | ||||
|   krb4 support:     ${curl_krb4_msg} | ||||
|   GSSAPI support:   ${curl_gss_msg} | ||||
|   SPNEGO support:   ${curl_spnego_msg} | ||||
|   TLS-SRP support:  ${curl_tls_srp_msg} | ||||
|   resolver:         ${curl_res_msg} | ||||
|   ipv6 support:     ${curl_ipv6_msg} | ||||
|   IDN support:      ${curl_idn_msg} | ||||
|   Build libcurl:    Shared=${enable_shared}, Static=${enable_static} | ||||
|   Built-in manual:  ${curl_manual_msg} | ||||
|   --libcurl option: ${curl_libcurl_msg} | ||||
|   Verbose errors:   ${curl_verbose_msg} | ||||
|   SSPI support:     ${curl_sspi_msg} | ||||
|   ca cert bundle:   ${ca} | ||||
|   ca cert path:     ${capath} | ||||
|   LDAP support:     ${curl_ldap_msg} | ||||
|   LDAPS support:    ${curl_ldaps_msg} | ||||
|   RTSP support:     ${curl_rtsp_msg} | ||||
|   RTMP support:     ${curl_rtmp_msg} | ||||
|   Protocols:        ${SUPPORT_PROTOCOLS} | ||||
| ]) | ||||
|  | ||||
| if test "x$soname_bump" = "xyes"; then | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 2001 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 2001 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # | ||||
| # This software is licensed as described in the file COPYING, which | ||||
| # you should have received as part of this distribution. The terms | ||||
| @@ -94,7 +94,7 @@ while test $# -gt 0; do | ||||
| 	;; | ||||
|  | ||||
|     --version) | ||||
| 	echo libcurl @VERSION@ | ||||
| 	echo libcurl @CURLVERSION@ | ||||
| 	exit 0 | ||||
| 	;; | ||||
|  | ||||
| @@ -113,7 +113,7 @@ while test $# -gt 0; do | ||||
| 	  # silent success | ||||
| 	  exit 0 | ||||
| 	else | ||||
| 	  echo "requested version $checkfor is newer than existing @VERSION@" | ||||
| 	  echo "requested version $checkfor is newer than existing @CURLVERSION@" | ||||
| 	  exit 1 | ||||
| 	fi | ||||
| 	;; | ||||
| @@ -142,9 +142,9 @@ while test $# -gt 0; do | ||||
| 	   CURLLIBDIR="" | ||||
| 	fi | ||||
| 	if test "X@REQUIRE_LIB_DEPS@" = "Xyes"; then | ||||
| 	  echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBCURL_LIBS@ @LIBS@ | ||||
| 	  echo ${CURLLIBDIR}-lcurl @LIBCURL_LIBS@ @LIBS@ | ||||
| 	else | ||||
| 	  echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBS@ | ||||
| 	  echo ${CURLLIBDIR}-lcurl @LIBS@ | ||||
| 	fi | ||||
| 	;; | ||||
|  | ||||
|   | ||||
							
								
								
									
										83
									
								
								docs/BUGS
									
									
									
									
									
								
							
							
						
						
									
										83
									
								
								docs/BUGS
									
									
									
									
									
								
							| @@ -6,21 +6,34 @@ | ||||
|  | ||||
| BUGS | ||||
|  | ||||
|  1. Bugs | ||||
|   1.1 There are still bugs | ||||
|   1.2 Where to report | ||||
|   1.3 What to report | ||||
|   1.4 libcurl problems | ||||
|   1.5 Who will fix the problems | ||||
|   1.6 How to get a stack trace | ||||
|   1.7 Bugs in libcurl bindings | ||||
|  | ||||
| ============================================================================== | ||||
|  | ||||
| 1.1 There are still bugs | ||||
|  | ||||
|   Curl and libcurl have grown substantially since the beginning. At the time | ||||
|   of writing (July 2007), there are about 47000 lines of source code, and by | ||||
|   the time you read this it has probably grown even more. | ||||
|   of writing (September 2011), there are about 66000 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. | ||||
|  | ||||
| WHERE TO REPORT | ||||
| 1.2 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 | ||||
|   have a go at a solution. You can optionally also post your bug/problem at | ||||
|   curl's bug tracking system over at | ||||
|  | ||||
|         http://sourceforge.net/bugs/?group_id=976 | ||||
|  | ||||
| @@ -29,16 +42,18 @@ WHERE TO REPORT | ||||
|   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 | ||||
| 1.3 What to report | ||||
|  | ||||
|   When reporting a bug, you should include all 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 tell us: | ||||
|  | ||||
|    - your operating system's name and version number (uname -a under a unix | ||||
|      is fine) | ||||
|    - your operating system's name and version number | ||||
|  | ||||
|    - what version of curl you're using (curl -V is fine) | ||||
|  | ||||
|    - versions of the used libraries that libcurl is built to use | ||||
|  | ||||
|    - what URL you were working with (if possible), at least which protocol | ||||
|  | ||||
|   and anything and everything else you think matters. Tell us what you | ||||
| @@ -59,7 +74,48 @@ WHAT TO REPORT | ||||
|   The address and how to subscribe to the mailing lists are detailed in the | ||||
|   MANUAL file. | ||||
|  | ||||
| HOW TO GET A STACK TRACE | ||||
| 1.4 libcurl problems | ||||
|  | ||||
|   First, post all libcurl problems on the curl-library mailing list. | ||||
|  | ||||
|   When you've written your own application with libcurl to perform transfers, | ||||
|   it is even more important to be specific and detailed when reporting bugs. | ||||
|  | ||||
|   Tell us the libcurl version and your operating system. Tell us the name and | ||||
|   version of all relevant sub-components like for example the SSL library | ||||
|   you're using and what name resolving your libcurl uses. If you use SFTP or | ||||
|   SCP, the libssh2 version is relevant etc. | ||||
|  | ||||
|   Showing us a real source code example repeating your problem is the best way | ||||
|   to get our attention and it will greatly increase our chances to understand | ||||
|   your problem and to work on a fix (if we agree it truly is a problem). | ||||
|  | ||||
|   Lots of problems that appear to be libcurl problems are actually just abuses | ||||
|   of the libcurl API or other malfunctions in your applications. It is adviced | ||||
|   that you run your problematic program using a memory debug tool like | ||||
|   valgrind or similar before you post memory-related or "crashing" problems to | ||||
|   us. | ||||
|  | ||||
| 1.5 Who will fix the problems | ||||
|  | ||||
|   If the problems or bugs you describe are considered to be bugs, we want to | ||||
|   have the problems fixed. | ||||
|  | ||||
|   There are no developers in the curl project that are paid to work on bugs. | ||||
|   All developers that take on reported bugs do this on a voluntary basis. We | ||||
|   do it out of an ambition to keep curl and libcurl excellent products and out | ||||
|   of pride. | ||||
|  | ||||
|   But please do not assume that you can just lump over something to us and it | ||||
|   will then magically be fixed after some given time. Most often we need | ||||
|   feedback and help to understand what you've experienced and how to repeat a | ||||
|   problem. Then we may only be able to assist YOU to debug the problem and to | ||||
|   track down the proper fix. | ||||
|  | ||||
|   We get reports from many people every month and each report can take a | ||||
|   considerable amount of time to really go to the bottom with. | ||||
|  | ||||
| 1.6 How to get a stack trace | ||||
|  | ||||
|   First, you must make sure that you compile all sources with -g and that you | ||||
|   don't 'strip' the final executable. Try to avoid optimizing the code as | ||||
| @@ -79,3 +135,12 @@ HOW TO GET A STACK TRACE | ||||
|   crashed. Include the stack trace with your detailed bug report. It'll help a | ||||
|   lot. | ||||
|  | ||||
| 1.7 Bugs in libcurl bindings | ||||
|  | ||||
|   There will of course pop up bugs in libcurl bindings. You should then | ||||
|   primarily approach the team that works on that particular binding and see | ||||
|   what you can do to help them fix the problem. | ||||
|  | ||||
|   If you suspect that the problem exists in the underlying libcurl, then | ||||
|   please convert your program over to plain C and follow the steps outlined | ||||
|   above. | ||||
|   | ||||
| @@ -34,6 +34,7 @@ | ||||
|  3.3 How To Make a Patch without git | ||||
|  3.4 How to get your changes into the main sources | ||||
|  3.5 Write good commit messages | ||||
|  3.6 Please don't send pull requests | ||||
|  | ||||
| ============================================================================== | ||||
|  | ||||
| @@ -276,3 +277,27 @@ | ||||
|  and make sure that you have your own user and email setup correctly in git | ||||
|  before you commit | ||||
|  | ||||
| 3.6 Please don't send pull requests | ||||
|  | ||||
|  With git (and expecially github) it is easy and tempting to send a pull | ||||
|  request to one or more people in the curl project to have changes merged this | ||||
|  way instead of mailing patches to the curl-library mailing list. | ||||
|  | ||||
|  We don't like that. We want them mailed for these reasons: | ||||
|  | ||||
|  - Peer review. Anyone and everyone on the list can review, comment and | ||||
|    improve on the patch. Pull requests limit this ability. | ||||
|  | ||||
|  - Anyone can merge the patch into their own trees for testing and those who | ||||
|    have push rights can push it to the main repo. It doesn't have to be anyone | ||||
|    the patch author knows beforehand. | ||||
|  | ||||
|  - Commit messages can be tweaked and changed if merged locally instead of | ||||
|    using github. Merges directly on github requires the changes to be perfect | ||||
|    already, which they seldomly are. | ||||
|  | ||||
|  - Merges on github prevents rebases and even enforces --no-ff which is a git | ||||
|    style we don't otherwise use in the project | ||||
|  | ||||
|  However: once patches have been reviewed and deemed fine on list they are | ||||
|  perfectly OK to be pulled from a published git tree. | ||||
|   | ||||
							
								
								
									
										37
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| Updated: March 8, 2011 (http://curl.haxx.se/docs/faq.html) | ||||
| Updated: December 7, 2011 (http://curl.haxx.se/docs/faq.html) | ||||
|                                   _   _ ____  _ | ||||
|                               ___| | | |  _ \| | | ||||
|                              / __| | | | |_) | | | ||||
| @@ -36,7 +36,7 @@ FAQ | ||||
|   3.2 How do I tell curl to resume a transfer? | ||||
|   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.5 How can I disable the Accept: */* header? | ||||
|   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? | ||||
| @@ -491,7 +491,6 @@ FAQ | ||||
|   3.2 How do I tell curl to resume a transfer? | ||||
|  | ||||
|   Curl supports resumed transfers both ways on both FTP and HTTP. | ||||
|  | ||||
|   Try the -C option. | ||||
|  | ||||
|   3.3 Why doesn't my posting using -F work? | ||||
| @@ -517,11 +516,11 @@ FAQ | ||||
|   FTP commands without transferring anything. Therefore you must always specify | ||||
|   a URL to transfer to/from even when doing custom FTP commands. | ||||
|  | ||||
|   3.5 How can I disable the Pragma: nocache header? | ||||
|   3.5 How can I disable the Accept: */* header? | ||||
|  | ||||
|   You can change all internally generated headers by adding a replacement with | ||||
|   the -H/--header option. By adding a header with empty contents you safely | ||||
|   disable that one. Use -H "Pragma:" to disable that specific header. | ||||
|   disable that one. Use -H "Accept:" to disable that specific header. | ||||
|  | ||||
|   3.6 Does curl support ASP, XML, XHTML or HTML version Y? | ||||
|  | ||||
| @@ -565,6 +564,12 @@ FAQ | ||||
|   install and use them, in the libcurl section of the curl web site: | ||||
|   http://curl.haxx.se/libcurl/ | ||||
|  | ||||
|   All the various bindings to libcurl are made by other projects and people, | ||||
|   outside of the cURL project. The cURL project itself only produces libcurl | ||||
|   with its plain C API. If you don't find anywhere else to ask you can ask | ||||
|   about bindings on the curl-library list too, but be prepared that people on | ||||
|   that list may not know anything about bindings. | ||||
|  | ||||
|   In October 2009, there were interfaces available for the following | ||||
|   languages: Ada95, Basic, C, C++, Ch, Cocoa, D, Dylan, Eiffel, Euphoria, | ||||
|   Ferite, Gambas, glib/GTK+, Haskell, ILE/RPG, Java, Lisp, Lua, Mono, .NET, | ||||
| @@ -721,6 +726,12 @@ FAQ | ||||
|  | ||||
|     curl --header "Host: www.example.com" http://127.0.0.1/ | ||||
|  | ||||
|   You can also opt to add faked host name entries to curl with the --resolve | ||||
|   option. That has the added benefit that things like redirects will also work | ||||
|   properly. The above operation would instead be done as: | ||||
|  | ||||
|     curl --resolve www.example.com:80:127.0.0.1 http://www.example.com/ | ||||
|  | ||||
|   3.20 How to SFTP from my user's home directory? | ||||
|  | ||||
|   Contrary to how FTP works, SFTP and SCP URLs specify the exact directory to | ||||
| @@ -1152,6 +1163,11 @@ FAQ | ||||
|   libcurl will reuse connections for all transfers that are made using the | ||||
|   same libcurl handle. | ||||
|  | ||||
|   When you use the easy interface, the connection cache is kept within the | ||||
|   easy handle. If you instead use the multi interface, the connection cache | ||||
|   will be kept within the multi handle and will be shared among all the easy | ||||
|   handles that are used within the same multi handle. | ||||
|  | ||||
|   5.7 Link errors when building libcurl on Windows! | ||||
|  | ||||
|   You need to make sure that your project, and all the libraries (both static | ||||
| @@ -1260,14 +1276,13 @@ FAQ | ||||
|   With the easy interface you make sure to return the correct error code from | ||||
|   one of the callbacks, but none of them are instant. There is no function you | ||||
|   can call from another thread or similar that will stop it immediately. | ||||
|   Instead you need to make sure that one of the callbacks you use return an | ||||
|   appropriate value that will stop the transfer. | ||||
|  | ||||
|   Suitable callbacks that you can do this with include the progress callback, | ||||
|   the read callback and the write callback. | ||||
|   Instead, you need to make sure that one of the callbacks you use returns an | ||||
|   appropriate value that will stop the transfer.  Suitable callbacks that you | ||||
|   can do this with include the progress callback, the read callback and the | ||||
|   write callback. | ||||
|  | ||||
|   If you're using the multi interface, you can also stop a transfer by | ||||
|   removing the particular easy handle from the multi stack. At any moment you | ||||
|   removing the particular easy handle from the multi stack at any moment you | ||||
|   think the transfer is done. | ||||
|  | ||||
|   5.14 Using C++ non-static functions for callbacks? | ||||
|   | ||||
							
								
								
									
										36
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -14,6 +14,12 @@ Installing Binary Packages | ||||
|    binary package. This document describes how to compile, build and install | ||||
|    curl and libcurl from source code. | ||||
|  | ||||
| Building from git | ||||
| ================= | ||||
|  | ||||
|    If you get your code off a git repository, see the GIT-INFO file in the | ||||
|    root directory for specific instructions on how to proceed. | ||||
|  | ||||
| UNIX | ||||
| ==== | ||||
|    A normal unix installation is made in three or four steps (after you've | ||||
| @@ -213,7 +219,7 @@ Win32 | ||||
|  | ||||
|      set ZLIB_PATH=c:\zlib-1.2.5 | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8r | ||||
|      set LIBSSH2_PATH=c:\libssh2-1.2.7 | ||||
|      set LIBSSH2_PATH=c:\libssh2-1.2.8 | ||||
|  | ||||
|    ATTENTION: if you want to build with libssh2 support you have to use latest | ||||
|    version 0.17 - previous versions will NOT work with 7.17.0 and later! | ||||
| @@ -461,6 +467,34 @@ Win32 | ||||
|      in the vc6libcurl.dsw/vc6libcurl.dsp Visual C++ 6 IDE project. | ||||
|  | ||||
|  | ||||
|    Using BSD-style lwIP instead of Winsock TCP/IP stack in Win32 builds | ||||
|    -------------------------------------------------------------------- | ||||
|  | ||||
|    In order to compile libcurl and curl using BSD-style lwIP TCP/IP stack | ||||
|    it is necessary to make definition of preprocessor symbol USE_LWIPSOCK | ||||
|    visible to libcurl and curl compilation processes. To set this definition | ||||
|    you have the following alternatives: | ||||
|  | ||||
|    - Modify lib/config-win32.h and src/config-win32.h | ||||
|    - Modify lib/Makefile.vc6 | ||||
|    - Add definition to Project/Settings/C/C++/General/Preprocessor Definitions | ||||
|      in the vc6libcurl.dsw/vc6libcurl.dsp Visual C++ 6 IDE project. | ||||
|  | ||||
|    Once that libcurl has been built with BSD-style lwIP TCP/IP stack support, | ||||
|    in order to use it with your program it is mandatory that your program | ||||
|    includes lwIP header file <lwip/opt.h> (or another lwIP header that includes | ||||
|    this) before including any libcurl header. Your program does not need the | ||||
|    USE_LWIPSOCK preprocessor definition which is for libcurl internals only. | ||||
|  | ||||
|    Compilation has been verified with lwIP 1.4.0 and contrib-1.4.0 from: | ||||
|  | ||||
|    http://download.savannah.gnu.org/releases/lwip/lwip-1.4.0.zip | ||||
|    http://download.savannah.gnu.org/releases/lwip/contrib-1.4.0.zip | ||||
|  | ||||
|    This BSD-style lwIP TCP/IP stack support must be considered experimental | ||||
|    given that it has been verified that lwIP 1.4.0 still needs some polish, | ||||
|    and libcurl might yet need some additional adjustment, caveat emptor. | ||||
|  | ||||
|    Important static libcurl usage note | ||||
|    ----------------------------------- | ||||
|  | ||||
|   | ||||
							
								
								
									
										16
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										16
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -18,6 +18,17 @@ Building with CMake | ||||
|    CMake builds can be configured either from the command line, or from one | ||||
|    of CMake's GUI's. | ||||
|  | ||||
| Important notice | ||||
| ================== | ||||
|    If you got your curl sources from a distribution tarball, make sure to | ||||
|    delete the generic 'include/curl/curlbuild.h' file that comes with it: | ||||
|        rm -f curl/include/curl/curlbuild.h | ||||
|  | ||||
|    The purpose of this file is to provide reasonable definitions for systems | ||||
|    where autoconfiguration is not available. CMake will create its own | ||||
|    version of this file in its build directory. If the "generic" version | ||||
|    is not deleted, weird build errors may occur on some systems. | ||||
|  | ||||
| Command Line CMake | ||||
| ================== | ||||
|    A command line build of Curl is similar to the autotools build of Curl. It | ||||
| @@ -32,9 +43,10 @@ Command Line CMake | ||||
|        # variable prior to running CMake. | ||||
|        cmake ../curl | ||||
|        make | ||||
|        # currently make test and make install are not implemented | ||||
|        # currently make test is not implemented | ||||
|        #make test | ||||
|        #make install | ||||
|        # Install to default location: | ||||
|        make install | ||||
|  | ||||
| ccmake | ||||
| ========= | ||||
|   | ||||
| @@ -39,7 +39,7 @@ Portability | ||||
|  libssh2      0.16 | ||||
|  c-ares       1.6.0 | ||||
|  libidn       0.4.1 | ||||
|  cyassl       1.4.0 | ||||
|  cyassl       2.0.0 | ||||
|  openldap     2.0 | ||||
|  MIT krb5 lib 1.2.4 | ||||
|  qsossl       V5R2M0 | ||||
| @@ -68,7 +68,7 @@ Portability | ||||
|  GNU Autoconf 2.57 | ||||
|  GNU Automake 1.7 (we currently avoid 1.10 due to Solaris-related bugs) | ||||
|  GNU M4       1.4 | ||||
|  perl         4 | ||||
|  perl         5.004 | ||||
|  roffit       0.5 | ||||
|  groff        ? (any version that supports "groff -Tps -man [in] [out]") | ||||
|  ps2pdf (gs)  ? | ||||
|   | ||||
| @@ -3,6 +3,15 @@ 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! | ||||
|  | ||||
| 78. curl and libcurl don't always signal the client properly when "sending" | ||||
|   zero bytes files - it makes for example the command line client not creating | ||||
|   any file at all. Like when using FTP. | ||||
|   http://curl.haxx.se/bug/view.cgi?id=3438362 | ||||
|  | ||||
| 77. CURLOPT_FORBID_REUSE on a handle prevents NTLM from working since it | ||||
|   "absuses" the underlying connection re-use system and if connections are | ||||
|   forced to close they break the NTLM support. | ||||
|  | ||||
| 76. The SOCKET type in Win64 is 64 bits large (and thus so is curl_socket_t on | ||||
|   that platform), and long is only 32 bits. It makes it impossible for | ||||
|   curl_easy_getinfo() to return a socket properly with the CURLINFO_LASTSOCKET | ||||
| @@ -12,12 +21,6 @@ may have been fixed since this was written! | ||||
|   http://curl.haxx.se/mail/lib-2009-10/0024.html | ||||
|   http://curl.haxx.se/bug/view.cgi?id=2944325 | ||||
|  | ||||
| 74. The HTTP spec allows headers to be merged and become comma-separated | ||||
|   instead of being repeated several times. This also include Authenticate: and | ||||
|   Proxy-Authenticate: headers and while this hardly every happens in real life | ||||
|   it will confuse libcurl which does not properly support it for all headers - | ||||
|   like those Authenticate headers. | ||||
|  | ||||
| 73. if a connection is made to a FTP server but the server then just never | ||||
|   sends the 220 response or otherwise is dead slow, libcurl will not | ||||
|   acknowledge the connection timeout during that phase but only the "real" | ||||
|   | ||||
| @@ -328,7 +328,7 @@ POST (HTTP) | ||||
|   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'. | ||||
|   use the default type 'application/octet-stream'. | ||||
|  | ||||
|   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 | ||||
|   | ||||
							
								
								
									
										0
									
								
								docs/README.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/README.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
								
								
									
										75
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -5,21 +5,28 @@ | ||||
|  If you have contributed but are missing here, please let us know! | ||||
|  | ||||
| Aaron Oneal | ||||
| Aaron Orenstein | ||||
| Adam D. Moss | ||||
| Adam Light | ||||
| Adam Piggott | ||||
| Adam Tkac | ||||
| Adrian Schuur | ||||
| Adriano Meirelles | ||||
| Akos Pasztory | ||||
| Alan Pinstein | ||||
| Albert Chin | ||||
| Albert Chin-A-Young | ||||
| Albert Choy | ||||
| Ale Vesely | ||||
| Alejandro Alvarez | ||||
| Aleksandar Milivojevic | ||||
| Alessandro Ghedini | ||||
| Alessandro Vesely | ||||
| Alex Bligh | ||||
| Alex Fishman | ||||
| Alex Neblett | ||||
| Alex Suykov | ||||
| Alex Vinnik | ||||
| Alex aka WindEagle | ||||
| Alexander Beedie | ||||
| Alexander Kourakos | ||||
| @@ -29,6 +36,7 @@ Alexander Zhuravlev | ||||
| Alexey Borzov | ||||
| Alexey Pesternikov | ||||
| Alexey Simak | ||||
| Alexey Zakhlestin | ||||
| Alexis Carvalho | ||||
| Alfred Gebert | ||||
| Allen Pulsifer | ||||
| @@ -63,10 +71,12 @@ Andy Tsouladze | ||||
| Angus Mackay | ||||
| Anthony Bryan | ||||
| Antoine Calando | ||||
| Anton Bychkov | ||||
| Anton Kalmykov | ||||
| Arkadiusz Miskiewicz | ||||
| Armel Asselin | ||||
| Arnaud Ebalard | ||||
| Arthur Murray | ||||
| Arve Knudsen | ||||
| Ates Goral | ||||
| Augustus Saunders | ||||
| @@ -78,10 +88,13 @@ Bas Mevissen | ||||
| Ben Darnell | ||||
| Ben Greear | ||||
| Ben Madsen | ||||
| Ben Noordhuis | ||||
| Ben Van Hof | ||||
| Ben Winslow | ||||
| Benbuck Nason | ||||
| Benjamin Gerard | ||||
| Bernard Leak | ||||
| Bernhard Reutner-Fischer | ||||
| Bertrand Demiddelaer | ||||
| Bill Egert | ||||
| Bill Hoffman | ||||
| @@ -96,6 +109,7 @@ Brad Burdick | ||||
| Brad Hards | ||||
| Brad King | ||||
| Bradford Bruce | ||||
| Brandon Wang | ||||
| Brendan Jurd | ||||
| Brent Beardsley | ||||
| Brian Akins | ||||
| @@ -112,6 +126,7 @@ Camille Moncelier | ||||
| Caolan McNamara | ||||
| Carsten Lange | ||||
| Casey O'Donnell | ||||
| Cedric Deltheil | ||||
| Chad Monroe | ||||
| Charles Kerr | ||||
| Chih-Chung Chang | ||||
| @@ -123,6 +138,9 @@ Chris Flerackers | ||||
| Chris Gaukroger | ||||
| Chris Maltby | ||||
| Chris Mumford | ||||
| Chris Smowton | ||||
| Christian Grothoff | ||||
| Christian Hagele | ||||
| Christian Krause | ||||
| Christian Kurz | ||||
| Christian Robottom Reis | ||||
| @@ -133,6 +151,7 @@ Christophe Legry | ||||
| Christopher Conroy | ||||
| Christopher Palow | ||||
| Christopher R. Palmer | ||||
| Christopher Stone | ||||
| Ciprian Badescu | ||||
| Claes Jakobsson | ||||
| Clarence Gardner | ||||
| @@ -147,8 +166,10 @@ Craig A West | ||||
| Craig Davison | ||||
| Craig Markwardt | ||||
| Cris Bailiff | ||||
| Cristian Rodriguez | ||||
| Curt Bogmine | ||||
| Cyrill Osterwalder | ||||
| Dagobert Michelsen | ||||
| Damien Adant | ||||
| Dan Becker | ||||
| Dan C | ||||
| @@ -216,6 +237,7 @@ Dmitry Rechkin | ||||
| Dolbneff A.V | ||||
| Domenico Andreoli | ||||
| Dominick Meglio | ||||
| Dominique Leuenberger | ||||
| Doug Kaufman | ||||
| Doug Porter | ||||
| Douglas E. Wegscheid | ||||
| @@ -256,6 +278,7 @@ Erwin Authried | ||||
| Eugene Kotlyarov | ||||
| Evan Jordan | ||||
| Eygene Ryabinkin | ||||
| Fabian Hiernaux | ||||
| Fabian Keil | ||||
| Fabrizio Ammollo | ||||
| Fedor Karpelevitch | ||||
| @@ -268,11 +291,13 @@ Frank Keeney | ||||
| Frank McGeough | ||||
| Frank Meier | ||||
| Frank Ticheler | ||||
| Frank Van Uffelen | ||||
| Fred Machado | ||||
| Fred New | ||||
| Fred Noz | ||||
| Frederic Lepied | ||||
| Gabriel Kuri | ||||
| Garrett Holmstrom | ||||
| Gary Maxwell | ||||
| Gautam Kachroo | ||||
| Gautam Mani | ||||
| @@ -296,6 +321,7 @@ Giuseppe Attardi | ||||
| Giuseppe D'Ambrosio | ||||
| Glen Nakamura | ||||
| Glen Scott | ||||
| Gokhan Sengun | ||||
| Grant Erickson | ||||
| Greg Hewgill | ||||
| Greg Morse | ||||
| @@ -320,6 +346,8 @@ Heikki Korpela | ||||
| Heinrich Ko | ||||
| Hendrik Visage | ||||
| Henrik Storner | ||||
| Henry Ludemann | ||||
| Herve Amblard | ||||
| Hidemoto Nakada | ||||
| Hoi-Ho Chan | ||||
| Hongli Lai | ||||
| @@ -361,6 +389,8 @@ Jan Kunder | ||||
| Jan Van Boghout | ||||
| Jared Lundell | ||||
| Jari Sundell | ||||
| Jason Glasgow | ||||
| Jason Liu | ||||
| Jason McDonald | ||||
| Jason S. Priebe | ||||
| Jay Austin | ||||
| @@ -381,11 +411,13 @@ Jeffrey Pohlmeyer | ||||
| Jeremy Friesner | ||||
| Jerome Muffat-Meridol | ||||
| Jerome Vouillon | ||||
| Jerry Wu | ||||
| Jes Badwal | ||||
| Jesper Jensen | ||||
| Jesse Noller | ||||
| Jim Drash | ||||
| Jim Freeman | ||||
| Jim Hollinger | ||||
| Jim Meyering | ||||
| Jocelyn Jaubert | ||||
| Joe Halpin | ||||
| @@ -395,6 +427,7 @@ Jofell Gallardo | ||||
| Johan Anderson | ||||
| Johan Nilsson | ||||
| Johan van Selst | ||||
| Johannes Bauer | ||||
| John Bradshaw | ||||
| John Crow | ||||
| John Dennis | ||||
| @@ -414,6 +447,7 @@ Jon Sargeant | ||||
| Jon Travis | ||||
| Jon Turner | ||||
| Jonas Forsman | ||||
| Jonas Schnelli | ||||
| Jonatan Lander | ||||
| Jonathan Hseu | ||||
| Jongki Suwandi | ||||
| @@ -421,6 +455,7 @@ Jose Kahan | ||||
| Josef Wolf | ||||
| Josh Kapell | ||||
| Joshua Kwan | ||||
| Josue Andrade Gomes | ||||
| Juan F. Codagnone | ||||
| Juan Ignacio Herv<72>s | ||||
| Judson Bishop | ||||
| @@ -428,6 +463,7 @@ Juergen Wilke | ||||
| Jukka Pihl | ||||
| Julian Noble | ||||
| Julien Chaffraix | ||||
| Julien Royer | ||||
| Jun-ichiro itojun Hagino | ||||
| Jurij Smakov | ||||
| Justin Fletcher | ||||
| @@ -438,6 +474,7 @@ Kai-Uwe Rommel | ||||
| Kalle Vahlman | ||||
| Kamil Dudka | ||||
| Kang-Jin Lee | ||||
| Karl M | ||||
| Karl Moerder | ||||
| Karol Pietrzak | ||||
| Kaspar Brand | ||||
| @@ -498,16 +535,22 @@ Luke Call | ||||
| Luong Dinh Dung | ||||
| Maciej Karpiuk | ||||
| Maciej W. Rozycki | ||||
| Mamoru Tasaka | ||||
| Mandy Wu | ||||
| Manfred Schwarb | ||||
| Manuel Massing | ||||
| Marc Boucher | ||||
| Marc Kleine-Budde | ||||
| Marcel Roelofs | ||||
| Marcelo Juchem | ||||
| Marcin Adamski | ||||
| Marcin Konicki | ||||
| Marco G. Salvagno | ||||
| Marco Maggi | ||||
| Marcus Sundberg | ||||
| Marcus Webster | ||||
| Mario Schroeder | ||||
| Mark Brand | ||||
| Mark Butler | ||||
| Mark Davies | ||||
| Mark Eichin | ||||
| @@ -537,6 +580,7 @@ Matt Kraai | ||||
| Matt Veenstra | ||||
| Matt Witherspoon | ||||
| Matt Wixson | ||||
| Matteo Rocco | ||||
| Matthew Blain | ||||
| Matthew Clarke | ||||
| Matthias Bolte | ||||
| @@ -545,6 +589,7 @@ Mauro Iorio | ||||
| Max Katsev | ||||
| Maxim Ivanov | ||||
| Maxim Perenesenko | ||||
| Mehmet Bozkurt | ||||
| Mekonikum | ||||
| Mettgut Jamalla | ||||
| Michael Benedict | ||||
| @@ -555,6 +600,7 @@ Michael Goffioul | ||||
| Michael Jahn | ||||
| Michael Jerris | ||||
| Michael Mealling | ||||
| Michael Mueller | ||||
| Michael Smith | ||||
| Michael Stillwell | ||||
| Michael Wallner | ||||
| @@ -580,6 +626,7 @@ Moonesamy | ||||
| Nathan Coulter | ||||
| Nathan O'Sullivan | ||||
| Nathanael Nerode | ||||
| Naveen Chandran | ||||
| Naveen Noel | ||||
| Neil Dunbar | ||||
| Neil Spring | ||||
| @@ -597,6 +644,7 @@ Nikita Schmidt | ||||
| Nikitinskit Dmitriy | ||||
| Niklas Angebrand | ||||
| Nikolai Kondrashov | ||||
| Nikos Mavrogiannopoulos | ||||
| Ning Dong | ||||
| Nir Soffer | ||||
| Nis Jorgensen | ||||
| @@ -607,15 +655,19 @@ Ofer | ||||
| Olaf Stueben | ||||
| Olaf St<53>ben | ||||
| Oren Tirosh | ||||
| Ori Avtalion | ||||
| P R Schaffner | ||||
| Paolo Piacentini | ||||
| Pascal Terjan | ||||
| Pasha Kuznetsov | ||||
| Pat Ray | ||||
| Patrice Guerin | ||||
| Patrick Bihan-Faou | ||||
| Patrick Monnerat | ||||
| Patrick Scott | ||||
| Patrick Smith | ||||
| Patrik Thunstrom | ||||
| Pau Garcia i Quiles | ||||
| Paul Harrington | ||||
| Paul Howarth | ||||
| Paul Marquis | ||||
| @@ -633,6 +685,7 @@ Pete Su | ||||
| Peter Bray | ||||
| Peter Forret | ||||
| Peter Heuchert | ||||
| Peter Hjalmarsson | ||||
| Peter Korsgaard | ||||
| Peter Lamberg | ||||
| Peter O'Gorman | ||||
| @@ -666,6 +719,7 @@ Rafa Muyo | ||||
| Rafael Sagula | ||||
| Rainer Canavan | ||||
| Rainer Koenig | ||||
| Rajesh Naganathan | ||||
| Ralf S. Engelschall | ||||
| Ralph Beckmann | ||||
| Ralph Mitchell | ||||
| @@ -681,6 +735,7 @@ Renaud Duhaut | ||||
| Rene Bernhardt | ||||
| Rene Rebe | ||||
| Reuven Wachtfogel | ||||
| Reza Arbab | ||||
| Ricardo Cadime | ||||
| Rich Gray | ||||
| Rich Rauenzahn | ||||
| @@ -691,16 +746,19 @@ Richard Clayton | ||||
| Richard Cooper | ||||
| Richard Gorton | ||||
| Richard Prescott | ||||
| Richard Silverman | ||||
| Rick Jones | ||||
| Rick Richardson | ||||
| Rob Crittenden | ||||
| Rob Jones | ||||
| Rob Stanzel | ||||
| Rob Ward | ||||
| Robert A. Monat | ||||
| Robert D. Young | ||||
| Robert Foreman | ||||
| Robert Iakobashvili | ||||
| Robert Olson | ||||
| Robert Schumann | ||||
| Robert Weaver | ||||
| Robin Cornelius | ||||
| Robin Johnson | ||||
| @@ -720,6 +778,7 @@ Ruslan Gazizov | ||||
| Rutger Hofman | ||||
| Ryan Chan | ||||
| Ryan Nelson | ||||
| Ryan Schmidt | ||||
| S. Moonesamy | ||||
| Salvador D<>vila | ||||
| Salvatore Sorrentino | ||||
| @@ -730,6 +789,7 @@ Samuel Listopad | ||||
| Samuel Thibault | ||||
| Sander Gates | ||||
| Sandor Feldi | ||||
| Saqib Ali | ||||
| Saul good | ||||
| Scott Barrett | ||||
| Scott Cantor | ||||
| @@ -767,6 +827,8 @@ Stephen Kick | ||||
| Stephen More | ||||
| Sterling Hughes | ||||
| Steve Green | ||||
| Steve H Truong | ||||
| Steve Holme | ||||
| Steve Lhomme | ||||
| Steve Little | ||||
| Steve Marx | ||||
| @@ -775,6 +837,7 @@ Steve Roskowski | ||||
| Steven Bazyl | ||||
| Steven G. Johnson | ||||
| Steven M. Schweda | ||||
| Steven Parkes | ||||
| Stoned Elipot | ||||
| Sven Anders | ||||
| Sven Neuhaus | ||||
| @@ -782,10 +845,12 @@ Sven Wegener | ||||
| S<EFBFBD>bastien Willemijns | ||||
| T. Bharath | ||||
| T. Yamada | ||||
| Taneli Vahakangas | ||||
| Tanguy Fautre | ||||
| Temprimus | ||||
| Thomas J. Moore | ||||
| Thomas Klausner | ||||
| Thomas L. Shinnick | ||||
| Thomas Lopatic | ||||
| Thomas Schwinge | ||||
| Thomas Tonino | ||||
| @@ -794,10 +859,13 @@ Tim Baker | ||||
| Tim Bartley | ||||
| Tim Chen | ||||
| Tim Costello | ||||
| Tim Harder | ||||
| Tim Newsome | ||||
| Tim Sneddon | ||||
| Tinus van den Berg | ||||
| Tobias Rundstr<74>m | ||||
| Toby Peterson | ||||
| Todd A Ouska | ||||
| Todd Kulesza | ||||
| Todd Vierling | ||||
| Tom Benoist | ||||
| @@ -807,6 +875,7 @@ Tom Mattison | ||||
| Tom Moers | ||||
| Tom Mueller | ||||
| Tom Regner | ||||
| Tom Wright | ||||
| Tom Zerucha | ||||
| Tomas Pospisek | ||||
| Tomas Szepe | ||||
| @@ -814,6 +883,7 @@ Tomasz Lacki | ||||
| Tommie Gannert | ||||
| Tommy Tam | ||||
| Ton Voon | ||||
| Toni Moreno | ||||
| Toon Verwaest | ||||
| Tor Arntsen | ||||
| Torsten Foertsch | ||||
| @@ -833,13 +903,16 @@ Vincent Bronner | ||||
| Vincent Le Normand | ||||
| Vincent Penquerc'h | ||||
| Vincent Sanders | ||||
| Vincent Torri | ||||
| Vlad Grachov | ||||
| Vlad Ureche | ||||
| Vladimir Grishchenko | ||||
| Vladimir Lazarenko | ||||
| Vojtech Janota | ||||
| Vojtech Minarik | ||||
| Vsevolod Novikov | ||||
| Walter J. Mack | ||||
| Ward Willats | ||||
| Wayne Haigh | ||||
| Werner Koch | ||||
| Wesley Laxton | ||||
| @@ -847,10 +920,12 @@ Wesley Miaw | ||||
| Wez Furlong | ||||
| Wilfredo Sanchez | ||||
| Wojciech Zwiefka | ||||
| Wu Yongzheng | ||||
| Xavier Bouchoux | ||||
| Yang Tse | ||||
| Yarram Sunil | ||||
| Yehoshua Hershberg | ||||
| Yukihiro Kawada | ||||
| Yuriy Sosov | ||||
| Yves Lejeune | ||||
| Zmey Petroff | ||||
|   | ||||
							
								
								
									
										90
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										90
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -12,16 +12,16 @@ | ||||
|  All bugs documented in the KNOWN_BUGS document are subject for fixing! | ||||
|  | ||||
|  1. libcurl | ||||
|  1.1 Zero-copy interface | ||||
|  1.2 More data sharing | ||||
|  1.3 struct lifreq | ||||
|  1.4 signal-based resolver timeouts | ||||
|  1.5 get rid of PATH_MAX | ||||
|  1.6 progress callback without doubles | ||||
|  1.7 Happy Eyeball dual stack connect | ||||
|  | ||||
|  2. libcurl - multi interface | ||||
|  2.1 More non-blocking | ||||
|  2.2 Remove easy interface internally | ||||
|  2.3 Avoid having to remove/readd handles | ||||
|  2.4 Fix HTTP Pipelining for PUT | ||||
|  | ||||
|  3. Documentation | ||||
| @@ -54,12 +54,10 @@ | ||||
|  7.5 Export session ids | ||||
|  7.6 Provide callback for cert verification | ||||
|  7.7 Support other SSL libraries | ||||
|  7.8  Support SRP on the TLS layer | ||||
|  7.9 improve configure --with-ssl | ||||
|  | ||||
|  8. GnuTLS | ||||
|  8.1 SSL engine stuff | ||||
|  8.2 SRP | ||||
|  8.3 check connection | ||||
|  8.4 non-gcrypt | ||||
|  | ||||
| @@ -77,6 +75,7 @@ | ||||
|  11.6 url-specific options | ||||
|  11.7 metalink support | ||||
|  11.8 warning when setting an option | ||||
|  11.9 IPv6 addresses with globbing | ||||
|  | ||||
|  12. Build | ||||
|  12.1 roffit | ||||
| @@ -100,17 +99,13 @@ | ||||
|  15.5 remove CURLOPT_FAILONERROR | ||||
|  15.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE | ||||
|  15.7 remove progress meter from libcurl | ||||
|  15.8 remove 'curl_httppost' from public | ||||
|  15.9 have form functions use CURL handle argument | ||||
|  | ||||
| ============================================================================== | ||||
|  | ||||
| 1. libcurl | ||||
|  | ||||
| 1.1 Zero-copy interface | ||||
|  | ||||
|  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] | ||||
|  | ||||
| 1.2 More data sharing | ||||
|  | ||||
|  curl_share_* functions already exist and work, and they can be extended to | ||||
| @@ -144,6 +139,28 @@ | ||||
|  we need libssh2 to properly tell us when we pass in a too small buffer and | ||||
|  its current API (as of libssh2 1.2.7) doesn't. | ||||
|  | ||||
| 1.6 progress callback without doubles | ||||
|  | ||||
|  The progress callback was introduced way back in the days and the choice to | ||||
|  use doubles in the arguments was possibly good at the time. Today the doubles | ||||
|  only confuse users and make the amounts less precise. We should introduce | ||||
|  another progress callback option that take precedence over the old one and | ||||
|  have both co-exist for a forseeable time until we can remove the double-using | ||||
|  one. | ||||
|  | ||||
| 1.7 Happy Eyeball dual stack connect | ||||
|  | ||||
|  In order to make alternative technologies not suffer when transitioning, like | ||||
|  when introducing IPv6 as an alternative to IPv4 and there are more than one | ||||
|  option existing simultaneously there are reasons to reconsider internal | ||||
|  choices. | ||||
|  | ||||
|  To make libcurl do blazing fast IPv6 in a dual-stack configuration, this needs | ||||
|  to be addressed: | ||||
|  | ||||
|     http://tools.ietf.org/html/draft-ietf-v6ops-happy-eyeballs-07 | ||||
|  | ||||
|  | ||||
| 2. libcurl - multi interface | ||||
|  | ||||
| 2.1 More non-blocking | ||||
| @@ -153,7 +170,6 @@ | ||||
|  | ||||
|  - Name resolves on non-windows unless c-ares is used | ||||
|  - NSS SSL connections | ||||
|  - Active FTP connections | ||||
|  - HTTP proxy CONNECT operations | ||||
|  - SOCKS proxy handshakes | ||||
|  - file:// transfers | ||||
| @@ -170,23 +186,6 @@ | ||||
|  internally use and assume the multi interface. The select()-loop should use | ||||
|  curl_multi_socket(). | ||||
|  | ||||
| 2.3 Avoid having to remove/readd handles | ||||
|  | ||||
|  curl_multi_handle_control() - this can control the easy handle (while) added | ||||
|  to a multi handle in various ways: | ||||
|  | ||||
|  o RESTART, unconditionally restart this easy handle's transfer from the | ||||
|    start, re-init the state | ||||
|  | ||||
|  o RESTART_COMPLETED, restart this easy handle's transfer but only if the | ||||
|    existing transfer has already completed and it is in a "finished state". | ||||
|  | ||||
|  o STOP, just stop this transfer and consider it completed | ||||
|  | ||||
|  o PAUSE? | ||||
|  | ||||
|  o RESUME? | ||||
|  | ||||
| 2.4 Fix HTTP Pipelining for PUT | ||||
|  | ||||
|  HTTP Pipelining can be a way to greatly enhance performance for multiple | ||||
| @@ -334,12 +333,6 @@ to provide the data to send. | ||||
|  Make curl's SSL layer capable of using other free SSL libraries.  Such as | ||||
|  MatrixSSL (http://www.matrixssl.org/). | ||||
|  | ||||
| 7.8  Support SRP on the TLS layer | ||||
|  | ||||
|  Peter Sylvester's patch for SRP on the TLS layer.  Awaits OpenSSL support for | ||||
|  this, no need to support this in libcurl before there's an OpenSSL release | ||||
|  that does it. | ||||
|  | ||||
| 7.9 improve configure --with-ssl | ||||
|  | ||||
|  make the configure --with-ssl option first check for OpenSSL, then GnuTLS, | ||||
| @@ -351,11 +344,6 @@ to provide the data to send. | ||||
|  | ||||
|  Is this even possible? | ||||
|  | ||||
| 8.2 SRP | ||||
|  | ||||
|  Work out a common method with Peter Sylvester's OpenSSL-patch for SRP on the | ||||
|  TLS to provide name and password. GnuTLS already supports it... | ||||
|  | ||||
| 8.3 check connection | ||||
|  | ||||
|  Add a way to check if the connection seems to be alive, to correspond to the | ||||
| @@ -451,6 +439,13 @@ to provide the data to send. | ||||
|   This can be useful to tell when support for a particular feature hasn't been | ||||
|   compiled into the library. | ||||
|  | ||||
| 11.9 IPv6 addresses with globbing | ||||
|  | ||||
|   Currently the command line client needs to get url globbing disabled (with | ||||
|   -g) for it to support IPv6 numerical addresses. This is a rather silly flaw | ||||
|   that should be corrected. It probably involves a smarter detection of the | ||||
|   '[' and ']' letters. | ||||
|  | ||||
| 12. Build | ||||
|  | ||||
| 12.1 roffit | ||||
| @@ -569,3 +564,20 @@ to provide the data to send. | ||||
|  The progress callback should then be bumped as well to get proper 64bit | ||||
|  variable types passed to it instead of doubles so that big files work | ||||
|  correctly. | ||||
|  | ||||
| 15.8 remove 'curl_httppost' from public | ||||
|  | ||||
|  curl_formadd() was made to fill in a public struct, but the fact that the | ||||
|  struct is public is never really used by application for their own advantage | ||||
|  but instead often restricts how the form functions can or can't be modified. | ||||
|  | ||||
|  Changing them to return a private handle will benefit the implementation and | ||||
|  allow us much greater freedoms while still maintining a solid API and ABI. | ||||
|  | ||||
| 15.9 have form functions use CURL handle argument | ||||
|  | ||||
|  curl_formadd() and curl_formget() both currently have no CURL handle | ||||
|  argument, but both can use a callback that is set in the easy handle, and | ||||
|  thus curl_formget() with callback cannot function without first having | ||||
|  curl_easy_perform() (or similar) called - which is hard to grasp and a design | ||||
|  mistake. | ||||
|   | ||||
| @@ -11,32 +11,25 @@ Version Numbers and Releases | ||||
|  | ||||
|  The version numbering is always built up using the same system: | ||||
|  | ||||
|         X.Y[.Z][-preN] | ||||
|         X.Y[.Z] | ||||
|  | ||||
|  Where | ||||
|    X is main version number | ||||
|    Y is release number | ||||
|    Z is patch number | ||||
|    N is pre-release number | ||||
|  | ||||
|  One of these numbers will get bumped in each new release. The numbers to the | ||||
|  right of a bumped number will be reset to zero. If Z is zero, it may not be | ||||
|  included in the version number. The pre release number is only included in | ||||
|  pre releases (they're never used in public, official, releases). | ||||
|  included in the version number. | ||||
|  | ||||
|  The main version number will get bumped when *really* big, world colliding | ||||
|  changes are made. The release number is bumped when big changes are | ||||
|  performed. The patch number is bumped when the changes are mere bugfixes and | ||||
|  only minor feature changes. The pre-release is a counter, to identify which | ||||
|  pre-release a certain release is. | ||||
|  | ||||
|  When reaching the end of a pre-release period, the version without the | ||||
|  pre-release part will be released as a public release. | ||||
|  changes are made. The release number is bumped when changes are performed or | ||||
|  things/features are added. The patch number is bumped when the changes are | ||||
|  mere bugfixes. | ||||
|  | ||||
|  It means that after release 1.2.3, we can release 2.0 if something really big | ||||
|  has been made, 1.3 if not that big changes were made or 1.2.4 if mostly bugs | ||||
|  were fixed. Before 1.2.4 is released, we might release a 1.2.4-pre1 release | ||||
|  for the brave people to try before the actual release. | ||||
|  were fixed. | ||||
|  | ||||
|  Bumping, as in increasing the number with 1, is unconditionally only | ||||
|  affecting one of the numbers (except the ones to the right of it, that may be | ||||
| @@ -56,12 +49,12 @@ Version Numbers and Releases | ||||
|         #define LIBCURL_VERSION_NUM 0xXXYYZZ | ||||
|  | ||||
|  Where XX, YY and ZZ are the main version, release and patch numbers in | ||||
|  hexadecimal. All three numbers are always represented using two digits.  1.2 | ||||
|  would appear as "0x010200" while version 9.11.7 appears as "0x090b07". | ||||
|  hexadecimal. All three number fields are always represented using two digits | ||||
|  (eight bits each). 1.2 would appear as "0x010200" while version 9.11.7 | ||||
|  appears as "0x090b07". | ||||
|  | ||||
|  This 6-digit hexadecimal number does not show pre-release number, and it is | ||||
|  always a greater number in a more recent release. It makes comparisons with | ||||
|  greater than and less than work. | ||||
|  This 6-digit hexadecimal number is always a greater number in a more recent | ||||
|  release. It makes comparisons with greater than and less than work. | ||||
|  | ||||
|  This number is also available as three separate defines: | ||||
|  LIBCURL_VERSION_MAJOR, LIBCURL_VERSION_MINOR and LIBCURL_VERSION_PATCH. | ||||
|   | ||||
							
								
								
									
										1045
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										1045
									
								
								docs/curl.1
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										8
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -4,6 +4,7 @@ certinfo | ||||
| chkspeed | ||||
| cookie_interface | ||||
| debug | ||||
| externalsocket | ||||
| fileupload | ||||
| fopen | ||||
| ftp-wildcard | ||||
| @@ -17,14 +18,20 @@ http-post | ||||
| httpcustomheader | ||||
| httpput | ||||
| https | ||||
| imap | ||||
| multi-app | ||||
| multi-debugcallback | ||||
| multi-double | ||||
| multi-post | ||||
| multi-single | ||||
| persistant | ||||
| pop3s | ||||
| pop3slist | ||||
| post-callback | ||||
| postit2 | ||||
| progressfunc | ||||
| resolve | ||||
| rtsp | ||||
| sendrecv | ||||
| sepheaders | ||||
| simple | ||||
| @@ -33,3 +40,4 @@ simplesmtp | ||||
| simplessl | ||||
| smtp-multi | ||||
| smtp-tls | ||||
| url2file | ||||
|   | ||||
| @@ -23,7 +23,7 @@ | ||||
| AUTOMAKE_OPTIONS = foreign nostdinc | ||||
|  | ||||
| EXTRA_DIST = README Makefile.example Makefile.inc Makefile.m32 \ | ||||
| 	makefile.dj $(COMPLICATED_EXAMPLES) | ||||
| 	Makefile.netware makefile.dj printf_macro.h $(COMPLICATED_EXAMPLES) | ||||
|  | ||||
| # Specify our include paths here, and do it relative to $(top_srcdir) and | ||||
| # $(top_builddir), to ensure that these paths which belong to the library | ||||
|   | ||||
| @@ -4,7 +4,8 @@ check_PROGRAMS = 10-at-a-time anyauthput cookie_interface debug fileupload \ | ||||
|   https multi-app multi-debugcallback multi-double multi-post multi-single \ | ||||
|   persistant post-callback postit2 sepheaders simple simplepost simplessl  \ | ||||
|   sendrecv httpcustomheader certinfo chkspeed ftpgetinfo ftp-wildcard \ | ||||
|   smtp-multi simplesmtp smtp-tls | ||||
|   smtp-multi simplesmtp smtp-tls rtsp externalsocket resolve \ | ||||
|   progressfunc pop3s pop3slist imap url2file | ||||
|  | ||||
| # These examples require external dependencies that may not be commonly | ||||
| # available on POSIX systems, so don't bother attempting to compile them here. | ||||
|   | ||||
| @@ -19,31 +19,50 @@ | ||||
| # KIND, either express or implied. | ||||
| # | ||||
| ########################################################################### | ||||
| ######################################################################### | ||||
| # | ||||
| ## Makefile for building curl examples with MingW32 | ||||
| ## and optionally OpenSSL (0.9.8), libssh2 (0.18), zlib (1.2.3) | ||||
| ## Makefile for building curl examples with MingW (GCC-3.2 or later) | ||||
| ## and optionally OpenSSL (0.9.8), libssh2 (1.3), zlib (1.2.5), librtmp (2.3) | ||||
| ## | ||||
| ## Usage: | ||||
| ## mingw32-make -f Makefile.m32 [SSL=1] [SSH2=1] [ZLIB=1] [SSPI=1] [IPV6=1] [DYN=1] | ||||
| ## Usage:   mingw32-make -f Makefile.m32 CFG=-feature1[-feature2][-feature3][...] | ||||
| ## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-spi-winidn | ||||
| ## | ||||
| ## Hint: you can also set environment vars to control the build, f.e.: | ||||
| ## set ZLIB_PATH=c:/zlib-1.2.3 | ||||
| ## set ZLIB_PATH=c:/zlib-1.2.5 | ||||
| ## set ZLIB=1 | ||||
| ## | ||||
| ######################################################################### | ||||
| # | ||||
| ########################################################################### | ||||
|  | ||||
| # Edit the path below to point to the base of your Zlib sources. | ||||
| ifndef ZLIB_PATH | ||||
| ZLIB_PATH = ../../zlib-1.2.3 | ||||
| ZLIB_PATH = ../../../zlib-1.2.5 | ||||
| endif | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../openssl-0.9.8k | ||||
| OPENSSL_PATH = ../../../openssl-0.9.8r | ||||
| endif | ||||
| ifndef OPENSSL_LIBPATH | ||||
| OPENSSL_LIBPATH = $(OPENSSL_PATH)/out | ||||
| endif | ||||
| ifndef OPENSSL_LIBS | ||||
| OPENSSL_LIBS = -leay32 -lssl32 | ||||
| endif | ||||
| # Edit the path below to point to the base of your LibSSH2 package. | ||||
| ifndef LIBSSH2_PATH | ||||
| LIBSSH2_PATH = ../../libssh2-1.2 | ||||
| LIBSSH2_PATH = ../../../libssh2-1.3.0 | ||||
| endif | ||||
| # Edit the path below to point to the base of your librtmp package. | ||||
| ifndef LIBRTMP_PATH | ||||
| LIBRTMP_PATH = ../../../librtmp-2.3 | ||||
| endif | ||||
| # Edit the path below to point to the base of your libidn package. | ||||
| ifndef LIBIDN_PATH | ||||
| LIBIDN_PATH = ../../../libidn-1.18 | ||||
| endif | ||||
| # Edit the path below to point to the base of your MS IDN package. | ||||
| # Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1 | ||||
| # http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815 | ||||
| ifndef WINIDN_PATH | ||||
| WINIDN_PATH = ../../../Microsoft IDN Mitigation APIs | ||||
| endif | ||||
| # Edit the path below to point to the base of your Novell LDAP NDK. | ||||
| ifndef LDAP_SDK | ||||
| @@ -51,25 +70,76 @@ LDAP_SDK = c:/novell/ndk/cldapsdk/win32 | ||||
| endif | ||||
|  | ||||
| PROOT = ../.. | ||||
| ARES_LIB = $(PROOT)/ares | ||||
|  | ||||
| SSL = 1 | ||||
| ZLIB = 1 | ||||
| # Edit the path below to point to the base of your c-ares package. | ||||
| ifndef LIBCARES_PATH | ||||
| LIBCARES_PATH = $(PROOT)/ares | ||||
| endif | ||||
|  | ||||
| # Edit the var below to set to your architecture or set environment var. | ||||
| ifndef ARCH | ||||
| ARCH = w32 | ||||
| endif | ||||
|  | ||||
| CC = gcc | ||||
| CFLAGS = -g -O2 -Wall | ||||
| CFLAGS += -fno-strict-aliasing | ||||
| ifeq ($(ARCH),w64) | ||||
| CFLAGS += -D_AMD64_ | ||||
| endif | ||||
| # comment LDFLAGS below to keep debug info | ||||
| LDFLAGS = -s | ||||
| RC = windres | ||||
| RCFLAGS = --include-dir=$(PROOT)/include -O COFF -i | ||||
| RM = del /q /f > NUL 2>&1 | ||||
|  | ||||
| RM = del /q /f 2>NUL | ||||
| CP = copy | ||||
|  | ||||
| ######################################################## | ||||
| ## Nothing more to do below this line! | ||||
|  | ||||
| ifeq ($(findstring -dyn,$(CFG)),-dyn) | ||||
| DYN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ares,$(CFG)),-ares) | ||||
| ARES = 1 | ||||
| endif | ||||
| ifeq ($(findstring -rtmp,$(CFG)),-rtmp) | ||||
| RTMP = 1 | ||||
| SSL = 1 | ||||
| ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ssh2,$(CFG)),-ssh2) | ||||
| SSH2 = 1 | ||||
| SSL = 1 | ||||
| ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ssl,$(CFG)),-ssl) | ||||
| SSL = 1 | ||||
| endif | ||||
| ifeq ($(findstring -zlib,$(CFG)),-zlib) | ||||
| ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -idn,$(CFG)),-idn) | ||||
| IDN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -winidn,$(CFG)),-winidn) | ||||
| WINIDN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -sspi,$(CFG)),-sspi) | ||||
| SSPI = 1 | ||||
| endif | ||||
| ifeq ($(findstring -spnego,$(CFG)),-spnego) | ||||
| SPNEGO = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ldaps,$(CFG)),-ldaps) | ||||
| LDAPS = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ipv6,$(CFG)),-ipv6) | ||||
| IPV6 = 1 | ||||
| endif | ||||
|  | ||||
| INCLUDES = -I. -I$(PROOT) -I$(PROOT)/include -I$(PROOT)/lib | ||||
| LINK = $(CC) $(LDFLAGS) -o $@ | ||||
|  | ||||
| ifdef DYN | ||||
|   curl_DEPENDENCIES = $(PROOT)/lib/libcurldll.a $(PROOT)/lib/libcurl.dll | ||||
| @@ -81,34 +151,45 @@ else | ||||
| endif | ||||
| ifdef ARES | ||||
|   ifndef DYN | ||||
|     curl_DEPENDENCIES += $(ARES_LIB)/libcares.a | ||||
|     curl_DEPENDENCIES += $(LIBCARES_PATH)/libcares.a | ||||
|   endif | ||||
|   CFLAGS += -DUSE_ARES | ||||
|   curl_LDADD += -L$(ARES_LIB) -lcares | ||||
|   curl_LDADD += -L"$(LIBCARES_PATH)" -lcares | ||||
| endif | ||||
| ifdef RTMP | ||||
|   CFLAGS += -DUSE_LIBRTMP | ||||
|   curl_LDADD += -L"$(LIBRTMP_PATH)/librtmp" -lrtmp -lwinmm | ||||
| endif | ||||
| ifdef SSH2 | ||||
|   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H | ||||
|   curl_LDADD += -L$(LIBSSH2_PATH)/win32 -lssh2 | ||||
|   curl_LDADD += -L"$(LIBSSH2_PATH)/win32" -lssh2 | ||||
| endif | ||||
| ifdef SSL | ||||
|   INCLUDES += -I"$(OPENSSL_PATH)/outinc" | ||||
|   CFLAGS += -DUSE_SSLEAY -DHAVE_OPENSSL_ENGINE_H | ||||
|   ifdef DYN | ||||
|     curl_LDADD += -L$(OPENSSL_PATH)/out -leay32 -lssl32 | ||||
|   else | ||||
|     curl_LDADD += -L$(OPENSSL_PATH)/out -lssl -lcrypto -lgdi32 | ||||
|   endif | ||||
|   curl_LDADD += -L"$(OPENSSL_LIBPATH)" $(OPENSSL_LIBS) | ||||
| endif | ||||
| ifdef ZLIB | ||||
|   INCLUDES += -I"$(ZLIB_PATH)" | ||||
|   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H | ||||
|   curl_LDADD += -L$(ZLIB_PATH) -lz | ||||
|   curl_LDADD += -L"$(ZLIB_PATH)" -lz | ||||
| endif | ||||
| ifdef IDN | ||||
|   CFLAGS += -DUSE_LIBIDN | ||||
|   curl_LDADD += -L"$(LIBIDN_PATH)/lib" -lidn | ||||
| else | ||||
| ifdef WINIDN | ||||
|   CFLAGS += -DUSE_WIN32_IDN | ||||
|   curl_LDADD += -L"$(WINIDN_PATH)" -lnormaliz | ||||
| endif | ||||
| endif | ||||
| ifdef SSPI | ||||
|   CFLAGS += -DUSE_WINDOWS_SSPI | ||||
| endif | ||||
| ifdef SPNEGO | ||||
|   CFLAGS += -DHAVE_SPNEGO | ||||
| endif | ||||
| ifdef IPV6 | ||||
|   CFLAGS += -DENABLE_IPV6 | ||||
|   CFLAGS += -DENABLE_IPV6 -D_WIN32_WINNT=0x0501 | ||||
| endif | ||||
| ifdef LDAPS | ||||
|   CFLAGS += -DHAVE_LDAP_SSL | ||||
| @@ -123,32 +204,32 @@ ifdef USE_LDAP_OPENLDAP | ||||
| endif | ||||
| ifndef USE_LDAP_NOVELL | ||||
| ifndef USE_LDAP_OPENLDAP | ||||
| curl_LDADD += -lwldap32 | ||||
|   curl_LDADD += -lwldap32 | ||||
| endif | ||||
| endif | ||||
| curl_LDADD += -lws2_32 | ||||
| COMPILE = $(CC) $(INCLUDES) $(CFLAGS) | ||||
|  | ||||
| # Makefile.inc provides the check_PROGRAMS and COMPLICATED_EXAMPLES defines | ||||
| include Makefile.inc | ||||
|  | ||||
| example_PROGRAMS := $(patsubst %,%.exe,$(strip $(check_PROGRAMS))) | ||||
|  | ||||
| .SUFFIXES: .rc .res .o .exe | ||||
| check_PROGRAMS := $(patsubst %,%.exe,$(strip $(check_PROGRAMS))) | ||||
| check_PROGRAMS += ftpuploadresume.exe synctime.exe | ||||
|  | ||||
|  | ||||
| all: $(example_PROGRAMS) | ||||
| all: $(check_PROGRAMS) | ||||
|  | ||||
| .o.exe: $(curl_DEPENDENCIES) | ||||
| 	$(LINK) $< $(curl_LDADD) | ||||
| %.exe: %.o $(curl_DEPENDENCIES) | ||||
| 	$(CC) $(LDFLAGS) -o $@ $< $(curl_LDADD) | ||||
|  | ||||
| .c.o: | ||||
| 	$(COMPILE) -c $< | ||||
| %.o: %.c | ||||
| 	$(CC) $(INCLUDES) $(CFLAGS) -c $< | ||||
|  | ||||
| .rc.res: | ||||
| %.res: %.rc | ||||
| 	$(RC) $(RCFLAGS) $< -o $@ | ||||
|  | ||||
| clean: | ||||
| 	$(RM) $(example_PROGRAMS) | ||||
| 	-$(RM) $(check_PROGRAMS:.exe=.o) | ||||
|  | ||||
| distclean vclean: clean | ||||
| 	-$(RM) $(check_PROGRAMS) | ||||
|  | ||||
|   | ||||
							
								
								
									
										441
									
								
								docs/examples/Makefile.netware
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										441
									
								
								docs/examples/Makefile.netware
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,441 @@ | ||||
| ################################################################# | ||||
| # | ||||
| ## Makefile for building curl.nlm (NetWare version - gnu make) | ||||
| ## Use: make -f Makefile.netware | ||||
| ## | ||||
| ## Comments to: Guenter Knauf http://www.gknw.net/phpbb | ||||
| # | ||||
| ################################################################# | ||||
|  | ||||
| # Edit the path below to point to the base of your Novell NDK. | ||||
| ifndef NDKBASE | ||||
| NDKBASE	= c:/novell | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your Zlib sources. | ||||
| ifndef ZLIB_PATH | ||||
| ZLIB_PATH = ../../../zlib-1.2.5 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../../openssl-0.9.8r | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your LibSSH2 package. | ||||
| ifndef LIBSSH2_PATH | ||||
| LIBSSH2_PATH = ../../../libssh2-1.3.0 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your axTLS package. | ||||
| ifndef AXTLS_PATH | ||||
| AXTLS_PATH = ../../../axTLS-1.2.7 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your libidn package. | ||||
| ifndef LIBIDN_PATH | ||||
| LIBIDN_PATH = ../../../libidn-1.18 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your librtmp package. | ||||
| ifndef LIBRTMP_PATH | ||||
| LIBRTMP_PATH = ../../../librtmp-2.3 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your fbopenssl package. | ||||
| ifndef FBOPENSSL_PATH | ||||
| FBOPENSSL_PATH = ../../fbopenssl-0.4 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your c-ares package. | ||||
| ifndef LIBCARES_PATH | ||||
| LIBCARES_PATH = ../../ares | ||||
| endif | ||||
|  | ||||
| ifndef INSTDIR | ||||
| INSTDIR	= ..$(DS)..$(DS)curl-$(LIBCURL_VERSION_STR)-bin-nw | ||||
| endif | ||||
|  | ||||
| # Edit the vars below to change NLM target settings. | ||||
| TARGET  = examples | ||||
| VERSION	= $(LIBCURL_VERSION) | ||||
| COPYR	= Copyright (C) $(LIBCURL_COPYRIGHT_STR) | ||||
| DESCR	= cURL ($(LIBARCH)) | ||||
| MTSAFE	= YES | ||||
| STACK	= 8192 | ||||
| SCREEN	= Example Program | ||||
| # Comment the line below if you dont want to load protected automatically. | ||||
| # LDRING = 3 | ||||
|  | ||||
| # Uncomment the next line to enable linking with POSIX semantics. | ||||
| # POSIXFL = 1 | ||||
|  | ||||
| # Edit the var below to point to your lib architecture. | ||||
| ifndef LIBARCH | ||||
| LIBARCH = LIBC | ||||
| endif | ||||
|  | ||||
| # must be equal to NDEBUG or DEBUG, CURLDEBUG | ||||
| ifndef DB | ||||
| DB	= NDEBUG | ||||
| endif | ||||
| # Optimization: -O<n> or debugging: -g | ||||
| ifeq ($(DB),NDEBUG) | ||||
| 	OPT	= -O2 | ||||
| 	OBJDIR	= release | ||||
| else | ||||
| 	OPT	= -g | ||||
| 	OBJDIR	= debug | ||||
| endif | ||||
|  | ||||
| # The following lines defines your compiler. | ||||
| ifdef CWFolder | ||||
| 	METROWERKS = $(CWFolder) | ||||
| endif | ||||
| ifdef METROWERKS | ||||
| 	# MWCW_PATH = $(subst \,/,$(METROWERKS))/Novell Support | ||||
| 	MWCW_PATH = $(subst \,/,$(METROWERKS))/Novell Support/Metrowerks Support | ||||
| 	CC = mwccnlm | ||||
| else | ||||
| 	CC = gcc | ||||
| endif | ||||
| PERL	= perl | ||||
| # Here you can find a native Win32 binary of the original awk: | ||||
| # http://www.gknw.net/development/prgtools/awk-20100523.zip | ||||
| AWK	= awk | ||||
| CP	= cp -afv | ||||
| MKDIR	= mkdir | ||||
| # RM	= rm -f | ||||
| # If you want to mark the target as MTSAFE you will need a tool for | ||||
| # generating the xdc data for the linker; here's a minimal tool: | ||||
| # http://www.gknw.net/development/prgtools/mkxdc.zip | ||||
| MPKXDC	= mkxdc | ||||
|  | ||||
| # LIBARCH_U = $(shell $(AWK) 'BEGIN {print toupper(ARGV[1])}' $(LIBARCH)) | ||||
| LIBARCH_L = $(shell $(AWK) 'BEGIN {print tolower(ARGV[1])}' $(LIBARCH)) | ||||
|  | ||||
| # Include the version info retrieved from curlver.h | ||||
| -include $(OBJDIR)/version.inc | ||||
|  | ||||
| # Global flags for all compilers | ||||
| CFLAGS	+= $(OPT) -D$(DB) -DNETWARE -DHAVE_CONFIG_H -nostdinc | ||||
|  | ||||
| ifeq ($(CC),mwccnlm) | ||||
| LD	= mwldnlm | ||||
| LDFLAGS	= -nostdlib $< $(PRELUDE) $(LDLIBS) -o $@ -commandfile | ||||
| LIBEXT	= lib | ||||
| CFLAGS	+= -gccinc -inline off -opt nointrinsics -proc 586 | ||||
| CFLAGS	+= -relax_pointers | ||||
| #CFLAGS	+= -w on | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| ifeq ($(POSIXFL),1) | ||||
| 	PRELUDE = $(NDK_LIBC)/imports/posixpre.o | ||||
| else | ||||
| 	PRELUDE = $(NDK_LIBC)/imports/libcpre.o | ||||
| endif | ||||
| 	CFLAGS += -align 4 | ||||
| else | ||||
| 	# PRELUDE = $(NDK_CLIB)/imports/clibpre.o | ||||
| 	# to avoid the __init_* / __deinit_* whoes dont use prelude from NDK | ||||
| 	PRELUDE = "$(MWCW_PATH)/libraries/runtime/prelude.obj" | ||||
| 	# CFLAGS += -include "$(MWCW_PATH)/headers/nlm_clib_prefix.h" | ||||
| 	CFLAGS += -align 1 | ||||
| endif | ||||
| else | ||||
| LD	= nlmconv | ||||
| LDFLAGS	= -T | ||||
| LIBEXT	= a | ||||
| CFLAGS	+= -m32 | ||||
| CFLAGS  += -fno-builtin -fno-strict-aliasing | ||||
| ifeq ($(findstring gcc,$(CC)),gcc) | ||||
| CFLAGS  += -fpcc-struct-return | ||||
| endif | ||||
| CFLAGS	+= -Wall # -pedantic | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| ifeq ($(POSIXFL),1) | ||||
| 	PRELUDE = $(NDK_LIBC)/imports/posixpre.gcc.o | ||||
| else | ||||
| 	PRELUDE = $(NDK_LIBC)/imports/libcpre.gcc.o | ||||
| endif | ||||
| else | ||||
| 	# PRELUDE = $(NDK_CLIB)/imports/clibpre.gcc.o | ||||
| 	# to avoid the __init_* / __deinit_* whoes dont use prelude from NDK | ||||
| 	# http://www.gknw.net/development/mk_nlm/gcc_pre.zip | ||||
| 	PRELUDE = $(NDK_ROOT)/pre/prelude.o | ||||
| 	CFLAGS += -include $(NDKBASE)/nlmconv/genlm.h | ||||
| endif | ||||
| endif | ||||
|  | ||||
| NDK_ROOT = $(NDKBASE)/ndk | ||||
| ifndef NDK_CLIB | ||||
| NDK_CLIB = $(NDK_ROOT)/nwsdk | ||||
| endif | ||||
| ifndef NDK_LIBC | ||||
| NDK_LIBC = $(NDK_ROOT)/libc | ||||
| endif | ||||
| ifndef NDK_LDAP | ||||
| NDK_LDAP = $(NDK_ROOT)/cldapsdk/netware | ||||
| endif | ||||
| CURL_INC = ../../include | ||||
| CURL_LIB = ../../lib | ||||
|  | ||||
| INCLUDES = -I$(CURL_INC) | ||||
|  | ||||
| ifeq ($(findstring -static,$(CFG)),-static) | ||||
| LINK_STATIC = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ares,$(CFG)),-ares) | ||||
| WITH_ARES = 1 | ||||
| endif | ||||
| ifeq ($(findstring -rtmp,$(CFG)),-rtmp) | ||||
| WITH_RTMP = 1 | ||||
| WITH_SSL = 1 | ||||
| WITH_ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ssh2,$(CFG)),-ssh2) | ||||
| WITH_SSH2 = 1 | ||||
| WITH_SSL = 1 | ||||
| WITH_ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -axtls,$(CFG)),-axtls) | ||||
| WITH_AXTLS = 1 | ||||
| WITH_SSL = | ||||
| else | ||||
| ifeq ($(findstring -ssl,$(CFG)),-ssl) | ||||
| WITH_SSL = 1 | ||||
| endif | ||||
| endif | ||||
| ifeq ($(findstring -zlib,$(CFG)),-zlib) | ||||
| WITH_ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -idn,$(CFG)),-idn) | ||||
| WITH_IDN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -spnego,$(CFG)),-spnego) | ||||
| WITH_SPNEGO = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ipv6,$(CFG)),-ipv6) | ||||
| ENABLE_IPV6 = 1 | ||||
| endif | ||||
|  | ||||
| ifdef LINK_STATIC | ||||
| 	LDLIBS	= $(CURL_LIB)/libcurl.$(LIBEXT) | ||||
| ifdef WITH_ARES | ||||
| 	LDLIBS += $(LIBCARES_PATH)/libcares.$(LIBEXT) | ||||
| endif | ||||
| else | ||||
| 	MODULES	= libcurl.nlm | ||||
| 	IMPORTS	= @$(CURL_LIB)/libcurl.imp | ||||
| endif | ||||
| ifdef WITH_SSH2 | ||||
| 	# INCLUDES += -I$(LIBSSH2_PATH)/include | ||||
| ifdef LINK_STATIC | ||||
| 	LDLIBS += $(LIBSSH2_PATH)/nw/libssh2.$(LIBEXT) | ||||
| else | ||||
| 	MODULES += libssh2.nlm | ||||
| 	IMPORTS += @$(LIBSSH2_PATH)/nw/libssh2.imp | ||||
| endif | ||||
| endif | ||||
| ifdef WITH_RTMP | ||||
| 	# INCLUDES += -I$(LIBRTMP_PATH) | ||||
| ifdef LINK_STATIC | ||||
| 	LDLIBS += $(LIBRTMP_PATH)/librtmp/librtmp.$(LIBEXT) | ||||
| endif | ||||
| endif | ||||
| ifdef WITH_SSL | ||||
| 	INCLUDES += -I$(OPENSSL_PATH)/outinc_nw_$(LIBARCH_L) | ||||
| 	LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/ssl.$(LIBEXT) | ||||
| 	LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/crypto.$(LIBEXT) | ||||
| 	IMPORTS += GetProcessSwitchCount RunningProcess | ||||
| ifdef WITH_SPNEGO | ||||
| 	# INCLUDES += -I$(FBOPENSSL_PATH)/include | ||||
| 	LDLIBS += $(FBOPENSSL_PATH)/nw/fbopenssl.$(LIBEXT) | ||||
| endif | ||||
| else | ||||
| ifdef WITH_AXTLS | ||||
| 	INCLUDES += -I$(AXTLS_PATH)/inc | ||||
| ifdef LINK_STATIC | ||||
| 	LDLIBS += $(AXTLS_PATH)/lib/libaxtls.$(LIBEXT) | ||||
| else | ||||
| 	MODULES += libaxtls.nlm | ||||
| 	IMPORTS += $(AXTLS_PATH)/lib/libaxtls.imp | ||||
| endif | ||||
| endif | ||||
| endif | ||||
| ifdef WITH_ZLIB | ||||
| 	# INCLUDES += -I$(ZLIB_PATH) | ||||
| ifdef LINK_STATIC | ||||
| 	LDLIBS += $(ZLIB_PATH)/nw/$(LIBARCH)/libz.$(LIBEXT) | ||||
| else | ||||
| 	MODULES += libz.nlm | ||||
| 	IMPORTS += @$(ZLIB_PATH)/nw/$(LIBARCH)/libz.imp | ||||
| endif | ||||
| endif | ||||
| ifdef WITH_IDN | ||||
| 	# INCLUDES += -I$(LIBIDN_PATH)/include | ||||
| 	LDLIBS += $(LIBIDN_PATH)/lib/libidn.$(LIBEXT) | ||||
| endif | ||||
|  | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| 	INCLUDES += -I$(NDK_LIBC)/include | ||||
| 	# INCLUDES += -I$(NDK_LIBC)/include/nks | ||||
| 	# INCLUDES += -I$(NDK_LIBC)/include/winsock | ||||
| 	CFLAGS += -D_POSIX_SOURCE | ||||
| else | ||||
| 	INCLUDES += -I$(NDK_CLIB)/include/nlm | ||||
| 	# INCLUDES += -I$(NDK_CLIB)/include | ||||
| endif | ||||
| ifndef DISABLE_LDAP | ||||
| 	# INCLUDES += -I$(NDK_LDAP)/$(LIBARCH_L)/inc | ||||
| endif | ||||
| CFLAGS	+= $(INCLUDES) | ||||
|  | ||||
| ifeq ($(MTSAFE),YES) | ||||
| 	XDCOPT = -n | ||||
| endif | ||||
| ifeq ($(MTSAFE),NO) | ||||
| 	XDCOPT = -u | ||||
| endif | ||||
| ifdef XDCOPT | ||||
| 	XDCDATA = $(OBJDIR)/$(TARGET).xdc | ||||
| endif | ||||
|  | ||||
| ifeq ($(findstring /sh,$(SHELL)),/sh) | ||||
| DL	= ' | ||||
| DS	= / | ||||
| PCT	= % | ||||
| #-include $(NDKBASE)/nlmconv/ncpfs.inc | ||||
| else | ||||
| DS	= \\ | ||||
| PCT	= %% | ||||
| endif | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|  | ||||
| check_PROGRAMS := $(patsubst %,%.nlm,$(strip $(check_PROGRAMS))) | ||||
|  | ||||
| .PRECIOUS: $(OBJDIR)/%.o $(OBJDIR)/%.def $(OBJDIR)/%.xdc | ||||
|  | ||||
|  | ||||
| all: prebuild $(check_PROGRAMS) | ||||
|  | ||||
| prebuild: $(OBJDIR) $(OBJDIR)/version.inc | ||||
|  | ||||
| $(OBJDIR)/%.o: %.c | ||||
| 	@echo Compiling $< | ||||
| 	$(CC) $(CFLAGS) -c $< -o $@ | ||||
|  | ||||
| $(OBJDIR)/version.inc: $(CURL_INC)/curl/curlver.h $(OBJDIR) | ||||
| 	@echo Creating $@ | ||||
| 	@$(AWK) -f ../../packages/NetWare/get_ver.awk $< > $@ | ||||
|  | ||||
| install: $(INSTDIR) all | ||||
| 	@$(CP) $(check_PROGRAMS) $(INSTDIR) | ||||
|  | ||||
| clean: | ||||
| 	-$(RM) -r $(OBJDIR) | ||||
|  | ||||
| distclean vclean: clean | ||||
| 	-$(RM) $(check_PROGRAMS) | ||||
|  | ||||
| $(OBJDIR) $(INSTDIR): | ||||
| 	@$(MKDIR) $@ | ||||
|  | ||||
| %.nlm: $(OBJDIR)/%.o $(OBJDIR)/%.def $(XDCDATA) | ||||
| 	@echo Linking $@ | ||||
| 	@-$(RM) $@ | ||||
| 	@$(LD) $(LDFLAGS) $(OBJDIR)/$(@:.nlm=.def) | ||||
|  | ||||
| $(OBJDIR)/%.xdc: Makefile.netware | ||||
| 	@echo Creating $@ | ||||
| 	@$(MPKXDC) $(XDCOPT) $@ | ||||
|  | ||||
| $(OBJDIR)/%.def: Makefile.netware | ||||
| 	@echo $(DL)# DEF file for linking with $(LD)$(DL) > $@ | ||||
| 	@echo $(DL)# Do not edit this file - it is created by Make!$(DL) >> $@ | ||||
| 	@echo $(DL)# All your changes will be lost!!$(DL) >> $@ | ||||
| 	@echo $(DL)#$(DL) >> $@ | ||||
| 	@echo $(DL)copyright "$(COPYR)"$(DL) >> $@ | ||||
| 	@echo $(DL)description "$(DESCR) $(notdir $(@:.def=)) Example"$(DL) >> $@ | ||||
| 	@echo $(DL)version $(VERSION)$(DL) >> $@ | ||||
| ifdef NLMTYPE | ||||
| 	@echo $(DL)type $(NLMTYPE)$(DL) >> $@ | ||||
| endif | ||||
| ifdef STACK | ||||
| 	@echo $(DL)stack $(STACK)$(DL) >> $@ | ||||
| endif | ||||
| ifdef SCREEN | ||||
| 	@echo $(DL)screenname "$(DESCR) $(notdir $(@:.def=)) $(SCREEN)"$(DL) >> $@ | ||||
| else | ||||
| 	@echo $(DL)screenname "DEFAULT"$(DL) >> $@ | ||||
| endif | ||||
| ifneq ($(DB),NDEBUG) | ||||
| 	@echo $(DL)debug$(DL) >> $@ | ||||
| endif | ||||
| 	@echo $(DL)threadname "_$(notdir $(@:.def=))"$(DL) >> $@ | ||||
| ifdef XDCDATA | ||||
| 	@echo $(DL)xdcdata $(XDCDATA)$(DL) >> $@ | ||||
| endif | ||||
| ifeq ($(LDRING),0) | ||||
| 	@echo $(DL)flag_on 16$(DL) >> $@ | ||||
| endif | ||||
| ifeq ($(LDRING),3) | ||||
| 	@echo $(DL)flag_on 512$(DL) >> $@ | ||||
| endif | ||||
| ifeq ($(LIBARCH),CLIB) | ||||
| 	@echo $(DL)start _Prelude$(DL) >> $@ | ||||
| 	@echo $(DL)exit _Stop$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_CLIB)/imports/clib.imp$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_CLIB)/imports/threads.imp$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_CLIB)/imports/nlmlib.imp$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_CLIB)/imports/socklib.imp$(DL) >> $@ | ||||
| 	@echo $(DL)module clib$(DL) >> $@ | ||||
| ifndef DISABLE_LDAP | ||||
| 	@echo $(DL)import @$(NDK_LDAP)/clib/imports/ldapsdk.imp$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_LDAP)/clib/imports/ldapssl.imp$(DL) >> $@ | ||||
| #	@echo $(DL)import @$(NDK_LDAP)/clib/imports/ldapx.imp$(DL) >> $@ | ||||
| 	@echo $(DL)module ldapsdk ldapssl$(DL) >> $@ | ||||
| endif | ||||
| else | ||||
| ifeq ($(POSIXFL),1) | ||||
| 	@echo $(DL)flag_on 4194304$(DL) >> $@ | ||||
| endif | ||||
| 	@echo $(DL)flag_on 64$(DL) >> $@ | ||||
| 	@echo $(DL)pseudopreemption$(DL) >> $@ | ||||
| ifeq ($(findstring posixpre,$(PRELUDE)),posixpre) | ||||
| 	@echo $(DL)start POSIX_Start$(DL) >> $@ | ||||
| 	@echo $(DL)exit POSIX_Stop$(DL) >> $@ | ||||
| 	@echo $(DL)check POSIX_CheckUnload$(DL) >> $@ | ||||
| else | ||||
| 	@echo $(DL)start _LibCPrelude$(DL) >> $@ | ||||
| 	@echo $(DL)exit _LibCPostlude$(DL) >> $@ | ||||
| 	@echo $(DL)check _LibCCheckUnload$(DL) >> $@ | ||||
| endif | ||||
| 	@echo $(DL)import @$(NDK_LIBC)/imports/libc.imp$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_LIBC)/imports/netware.imp$(DL) >> $@ | ||||
| 	@echo $(DL)module libc$(DL) >> $@ | ||||
| ifndef DISABLE_LDAP | ||||
| 	@echo $(DL)import @$(NDK_LDAP)/libc/imports/lldapsdk.imp$(DL) >> $@ | ||||
| 	@echo $(DL)import @$(NDK_LDAP)/libc/imports/lldapssl.imp$(DL) >> $@ | ||||
| #	@echo $(DL)import @$(NDK_LDAP)/libc/imports/lldapx.imp$(DL) >> $@ | ||||
| 	@echo $(DL)module lldapsdk lldapssl$(DL) >> $@ | ||||
| endif | ||||
| endif | ||||
| ifdef MODULES | ||||
| 	@echo $(DL)module $(MODULES)$(DL) >> $@ | ||||
| endif | ||||
| ifdef EXPORTS | ||||
| 	@echo $(DL)export $(EXPORTS)$(DL) >> $@ | ||||
| endif | ||||
| ifdef IMPORTS | ||||
| 	@echo $(DL)import $(IMPORTS)$(DL) >> $@ | ||||
| endif | ||||
| ifeq ($(findstring nlmconv,$(LD)),nlmconv) | ||||
| 	@echo $(DL)input $(PRELUDE)$(DL) >> $@ | ||||
| 	@echo $(DL)input $(@:.def=.o)$(DL) >> $@ | ||||
| ifdef LDLIBS | ||||
| 	@echo $(DL)input $(LDLIBS)$(DL) >> $@ | ||||
| endif | ||||
| 	@echo $(DL)output $(notdir $(@:.def=.nlm))$(DL) >> $@ | ||||
| endif | ||||
| @@ -55,6 +55,7 @@ htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML | ||||
| http-post.c    - HTTP POST | ||||
| httpput.c      - HTTP PUT a local file | ||||
| https.c        - simple HTTPS transfer | ||||
| imap.c         - simple IMAP transfer | ||||
| multi-app.c    - a multi-interface app | ||||
| multi-debugcallback.c - a multi-interface app using the debug callback | ||||
| multi-double.c - a multi-interface app doing two simultaneous transfers | ||||
| @@ -63,6 +64,8 @@ multi-single.c - a multi-interface app getting a single file | ||||
| multithread.c  - an example using multi-treading transferring multiple files | ||||
| opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded | ||||
| persistant.c   - request two URLs with a persistent connection | ||||
| pop3s.c        - POP3S transfer | ||||
| pop3slist.c    - POP3S LIST | ||||
| post-callback.c - send a HTTP POST using a callback | ||||
| postit2.c      - send a HTTP multipart formpost | ||||
| sampleconv.c   - showing how a program on a non-ASCII platform would invoke | ||||
| @@ -73,4 +76,5 @@ simple.c       - the most simple download a URL source | ||||
| simplepost.c   - HTTP POST | ||||
| simplessl.c    - HTTPS example with certificates many options set | ||||
| synctime.c     - Sync local time by extracting date from remote HTTP servers | ||||
| url2file.c     - download a document and store it in a file | ||||
| 10-at-a-time.c - Download many files simultaneously, 10 at a time. | ||||
|   | ||||
| @@ -26,9 +26,8 @@ | ||||
| #else | ||||
| #  ifdef __VMS | ||||
|      typedef int intptr_t; | ||||
| #  else | ||||
| #    include <stdint.h> | ||||
| #  endif | ||||
| #  include <stdint.h> | ||||
| #  include <unistd.h> | ||||
| #endif | ||||
| #include <sys/types.h> | ||||
| @@ -43,6 +42,7 @@ | ||||
| #endif | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include "printf_macro.h" | ||||
|  | ||||
| #if LIBCURL_VERSION_NUM < 0x070c03 | ||||
| #error "upgrade your libcurl to no less than 7.12.3" | ||||
| @@ -94,7 +94,7 @@ static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
|  | ||||
|   retcode = read(fd, ptr, size * nmemb); | ||||
|  | ||||
|   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||
|   fprintf(stderr, "*** We read %" _FMT_SIZE_T " bytes from file\n", retcode); | ||||
|  | ||||
|   return retcode; | ||||
| } | ||||
|   | ||||
| @@ -22,8 +22,6 @@ | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| static size_t wrfu(void *ptr,  size_t  size,  size_t  nmemb,  void *stream) | ||||
| { | ||||
|   | ||||
| @@ -35,8 +35,6 @@ | ||||
| #include <time.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| #define URL_BASE "http://speedtest.your.domain/" | ||||
| #define URL_1M   URL_BASE "file_1M.bin" | ||||
|   | ||||
| @@ -13,8 +13,6 @@ | ||||
| #include <gtk/gtk.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> /* new for v7 */ | ||||
| #include <curl/easy.h> /* new for v7 */ | ||||
|  | ||||
| GtkWidget *Bar; | ||||
|  | ||||
|   | ||||
| @@ -239,8 +239,7 @@ static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) { | ||||
|   SSL_CTX_set_cipher_list(ctx,"RC4-MD5"); | ||||
|   SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY); | ||||
|  | ||||
|   X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca, | ||||
|                                                     sk_X509_num(p->ca)-1)); | ||||
|   X509_STORE_add_cert(SSL_CTX_get_cert_store(ctx), sk_X509_value(p->ca, sk_X509_num(p->ca)-1)); | ||||
|  | ||||
|   SSL_CTX_set_verify_depth(ctx,2); | ||||
|  | ||||
|   | ||||
							
								
								
									
										143
									
								
								docs/examples/externalsocket.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										143
									
								
								docs/examples/externalsocket.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,143 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| /* | ||||
|  * This is an example demonstrating how an application can pass in a custom | ||||
|  * socket to libcurl to use. This example also handles the connect itself. | ||||
|  */ | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #include <windows.h> | ||||
| #include <winsock2.h> | ||||
| #include <ws2tcpip.h> | ||||
| #define close closesocket | ||||
| #else | ||||
| #include <sys/types.h>        /*  socket types              */ | ||||
| #include <sys/socket.h>       /*  socket definitions        */ | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h>        /*  inet (3) funtions         */ | ||||
| #include <unistd.h>           /*  misc. UNIX functions      */ | ||||
| #endif | ||||
|  | ||||
| #include <errno.h> | ||||
|  | ||||
| /* The IP address and port number to connect to */ | ||||
| #define IPADDR "127.0.0.1" | ||||
| #define PORTNUM 80 | ||||
|  | ||||
| static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   int written = fwrite(ptr, size, nmemb, (FILE *)stream); | ||||
|   return written; | ||||
| } | ||||
|  | ||||
| static curl_socket_t opensocket(void *clientp, | ||||
|                                 curlsocktype purpose, | ||||
|                                 struct curl_sockaddr *address) | ||||
| { | ||||
|   curl_socket_t sockfd = *(curl_socket_t *)clientp; | ||||
|   /* the actual externally set socket is passed in via the OPENSOCKETDATA | ||||
|      option */ | ||||
|   return sockfd; | ||||
| } | ||||
|  | ||||
| static int sockopt_callback(void *clientp, curl_socket_t curlfd, | ||||
|                             curlsocktype purpose) | ||||
| { | ||||
|   /* This return code was added in libcurl 7.21.5 */ | ||||
|   return CURL_SOCKOPT_ALREADY_CONNECTED; | ||||
| } | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res; | ||||
|   struct sockaddr_in servaddr;  /*  socket address structure  */ | ||||
|   curl_socket_t sockfd; | ||||
|  | ||||
| #ifdef WIN32 | ||||
|   WSADATA wsaData; | ||||
|   int initwsa; | ||||
|  | ||||
|   if((initwsa = WSAStartup(MAKEWORD(2,0), &wsaData)) != 0) { | ||||
|     printf("WSAStartup failed: %d\n", initwsa); | ||||
|     return 1; | ||||
|   } | ||||
| #endif | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     /* | ||||
|      * Note that libcurl will internally think that you connect to the host | ||||
|      * and port that you specify in the URL option. | ||||
|      */ | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "http://99.99.99.99:9999"); | ||||
|  | ||||
|     /* Create the socket "manually" */ | ||||
|     if( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0 ) { | ||||
|       printf("Error creating listening socket.\n"); | ||||
|       return 3; | ||||
|     } | ||||
|  | ||||
|     memset(&servaddr, 0, sizeof(servaddr)); | ||||
|     servaddr.sin_family = AF_INET; | ||||
|     servaddr.sin_port   = htons(PORTNUM); | ||||
|  | ||||
|     if (INADDR_NONE == (servaddr.sin_addr.s_addr = inet_addr(IPADDR))) | ||||
|       return 2; | ||||
|  | ||||
|     if(connect(sockfd,(struct sockaddr *) &servaddr, sizeof(servaddr)) == | ||||
|        -1) { | ||||
|       close(sockfd); | ||||
|       printf("client error: connect: %s\n", strerror(errno)); | ||||
|       return 1; | ||||
|     } | ||||
|  | ||||
|     /* no progress meter please */ | ||||
|     curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 1L); | ||||
|  | ||||
|     /* send all data to this function  */ | ||||
|     curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data); | ||||
|  | ||||
|     /* call this function to get a socket */ | ||||
|     curl_easy_setopt(curl, CURLOPT_OPENSOCKETFUNCTION, opensocket); | ||||
|     curl_easy_setopt(curl, CURLOPT_OPENSOCKETDATA, &sockfd); | ||||
|  | ||||
|     /* call this function to set options for the socket */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SOCKOPTFUNCTION, sockopt_callback); | ||||
|  | ||||
|     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||
|  | ||||
|     res = curl_easy_perform(curl); | ||||
|  | ||||
|     curl_easy_cleanup(curl); | ||||
|  | ||||
|     if(res) { | ||||
|       printf("libcurl error: %d\n", res); | ||||
|       return 4; | ||||
|     } | ||||
|   } | ||||
|   return 0; | ||||
| } | ||||
| @@ -22,8 +22,6 @@ | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| /* | ||||
|  * This is an example showing how to get a single file from an FTP server. | ||||
|   | ||||
| @@ -23,8 +23,6 @@ | ||||
| #include <string.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| /* | ||||
|  * This is an example showing how to check a single file's size and mtime | ||||
|   | ||||
| @@ -22,8 +22,6 @@ | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| /* | ||||
|  * Similar to ftpget.c but this also stores the received response-lines | ||||
|   | ||||
| @@ -32,6 +32,7 @@ | ||||
| #else | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #include "printf_macro.h" | ||||
|  | ||||
| /* | ||||
|  * This example shows an FTP upload, with a rename of the file just after | ||||
| @@ -56,7 +57,7 @@ static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
|      by default internally */ | ||||
|   size_t retcode = fread(ptr, size, nmemb, stream); | ||||
|  | ||||
|   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||
|   fprintf(stderr, "*** We read %" _FMT_SIZE_T " bytes from file\n", retcode); | ||||
|   return retcode; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -39,7 +39,7 @@ | ||||
|  | ||||
| /* The MinGW headers are missing a few Win32 function definitions, | ||||
|    you shouldn't need this if you use VC++ */ | ||||
| #ifdef __MINGW32__ | ||||
| #if defined(__MINGW32__) && !defined(__MINGW64__) | ||||
| int __cdecl _snscanf(const char * input, size_t length, const char * format, ...); | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -36,10 +36,10 @@ struct MemoryStruct { | ||||
|  | ||||
|  | ||||
| static size_t | ||||
| WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) | ||||
| WriteMemoryCallback(void *contents, size_t size, size_t nmemb, void *userp) | ||||
| { | ||||
|   size_t realsize = size * nmemb; | ||||
|   struct MemoryStruct *mem = (struct MemoryStruct *)data; | ||||
|   struct MemoryStruct *mem = (struct MemoryStruct *)userp; | ||||
|  | ||||
|   mem->memory = realloc(mem->memory, mem->size + realsize + 1); | ||||
|   if (mem->memory == NULL) { | ||||
| @@ -48,7 +48,7 @@ WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) | ||||
|     exit(EXIT_FAILURE); | ||||
|   } | ||||
|  | ||||
|   memcpy(&(mem->memory[mem->size]), ptr, realsize); | ||||
|   memcpy(&(mem->memory[mem->size]), contents, realsize); | ||||
|   mem->size += realsize; | ||||
|   mem->memory[mem->size] = 0; | ||||
|  | ||||
|   | ||||
| @@ -25,6 +25,7 @@ | ||||
| #include <unistd.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include "printf_macro.h" | ||||
|  | ||||
| /* | ||||
|  * This example shows a HTTP PUT operation. PUTs a file given as a command | ||||
| @@ -45,7 +46,7 @@ static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
|      by default internally */ | ||||
|   retcode = fread(ptr, size, nmemb, stream); | ||||
|  | ||||
|   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||
|   fprintf(stderr, "*** We read %" _FMT_SIZE_T " bytes from file\n", retcode); | ||||
|  | ||||
|   return retcode; | ||||
| } | ||||
|   | ||||
							
								
								
									
										44
									
								
								docs/examples/imap.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								docs/examples/imap.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include <stdio.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res; | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     /* Set username and password */ | ||||
|     curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password"); | ||||
|  | ||||
|     /* This will fetch the mailbox named "foobar" */ | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "imap://imap.example.com/foobar"); | ||||
|  | ||||
|     res = curl_easy_perform(curl); | ||||
|  | ||||
|     /* always cleanup */ | ||||
|     curl_easy_cleanup(curl); | ||||
|   } | ||||
|   return (int)res; | ||||
| } | ||||
							
								
								
									
										68
									
								
								docs/examples/pop3s.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								docs/examples/pop3s.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include <stdio.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res; | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     /* Set username and password */ | ||||
|     curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password"); | ||||
|  | ||||
|     /* This will only fetch the message with ID "1" of the given mailbox */ | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "pop3s://user@pop.example.com/1"); | ||||
|  | ||||
| #ifdef SKIP_PEER_VERIFICATION | ||||
|     /* | ||||
|      * If you want to connect to a site who isn't using a certificate that is | ||||
|      * signed by one of the certs in the CA bundle you have, you can skip the | ||||
|      * verification of the server's certificate. This makes the connection | ||||
|      * A LOT LESS SECURE. | ||||
|      * | ||||
|      * If you have a CA cert for the server stored someplace else than in the | ||||
|      * default bundle, then the CURLOPT_CAPATH option might come handy for | ||||
|      * you. | ||||
|      */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); | ||||
| #endif | ||||
|  | ||||
| #ifdef SKIP_HOSTNAME_VERFICATION | ||||
|     /* | ||||
|      * If the site you're connecting to uses a different host name that what | ||||
|      * they have mentioned in their server certificate's commonName (or | ||||
|      * subjectAltName) fields, libcurl will refuse to connect. You can skip | ||||
|      * this check, but this will make the connection less secure. | ||||
|      */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); | ||||
| #endif | ||||
|  | ||||
|     res = curl_easy_perform(curl); | ||||
|  | ||||
|     /* always cleanup */ | ||||
|     curl_easy_cleanup(curl); | ||||
|   } | ||||
|   return 0; | ||||
| } | ||||
							
								
								
									
										68
									
								
								docs/examples/pop3slist.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								docs/examples/pop3slist.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include <stdio.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res; | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     /* Set username and password */ | ||||
|     curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password"); | ||||
|  | ||||
|     /* This will list every message of the given mailbox */ | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "pop3s://user@pop.example.com/"); | ||||
|  | ||||
| #ifdef SKIP_PEER_VERIFICATION | ||||
|     /* | ||||
|      * If you want to connect to a site who isn't using a certificate that is | ||||
|      * signed by one of the certs in the CA bundle you have, you can skip the | ||||
|      * verification of the server's certificate. This makes the connection | ||||
|      * A LOT LESS SECURE. | ||||
|      * | ||||
|      * If you have a CA cert for the server stored someplace else than in the | ||||
|      * default bundle, then the CURLOPT_CAPATH option might come handy for | ||||
|      * you. | ||||
|      */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); | ||||
| #endif | ||||
|  | ||||
| #ifdef SKIP_HOSTNAME_VERFICATION | ||||
|     /* | ||||
|      * If the site you're connecting to uses a different host name that what | ||||
|      * they have mentioned in their server certificate's commonName (or | ||||
|      * subjectAltName) fields, libcurl will refuse to connect. You can skip | ||||
|      * this check, but this will make the connection less secure. | ||||
|      */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); | ||||
| #endif | ||||
|  | ||||
|     res = curl_easy_perform(curl); | ||||
|  | ||||
|     /* always cleanup */ | ||||
|     curl_easy_cleanup(curl); | ||||
|   } | ||||
|   return 0; | ||||
| } | ||||
| @@ -37,8 +37,6 @@ | ||||
| #include <string.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| int main(int argc, char *argv[]) | ||||
| { | ||||
|   | ||||
							
								
								
									
										45
									
								
								docs/examples/printf_macro.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								docs/examples/printf_macro.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| /* Simple hack trying to get a valid printf format string for size_t. | ||||
|  * If that fails for your platform you can define your own _FMT_SIZE_T, | ||||
|  * f.e.: -D_FMT_SIZE_T="zd" | ||||
|  */ | ||||
| #ifndef _PRINTF_MACRO_H | ||||
| #define _PRINTF_MACRO_H | ||||
|  | ||||
| #ifndef _FMT_SIZE_T | ||||
| #ifdef WIN32 | ||||
| #define _FMT_SIZE_T "Id" | ||||
| #else | ||||
| /* | ||||
| "zd" is a GNU extension to POSIX; so we dont use it for size_t but hack around | ||||
| #define _FMT_SIZE_T "zd" | ||||
| */ | ||||
| #ifdef __x86_64__ | ||||
| #define _FMT_SIZE_T "lu" | ||||
| #else | ||||
| #define _FMT_SIZE_T "u" | ||||
| #endif /* __x86_64__ */ | ||||
| #endif /* WIN32 */ | ||||
| #endif /* !_FMT_SIZE_T */ | ||||
|  | ||||
| #endif /* !_PRINTF_MACRO_H */ | ||||
							
								
								
									
										84
									
								
								docs/examples/progressfunc.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								docs/examples/progressfunc.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,84 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include <stdio.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| #define STOP_DOWNLOAD_AFTER_THIS_MANY_BYTES         6000 | ||||
| #define MINIMAL_PROGRESS_FUNCTIONALITY_INTERVAL     3 | ||||
|  | ||||
| struct myprogress { | ||||
|   double lastruntime; | ||||
|   CURL *curl; | ||||
| }; | ||||
|  | ||||
| static int progress(void *p, | ||||
|                     double dltotal, double dlnow, | ||||
|                     double ultotal, double ulnow) | ||||
| { | ||||
|   struct myprogress *myp = (struct myprogress *)p; | ||||
|   CURL *curl = myp->curl; | ||||
|   double curtime = 0; | ||||
|  | ||||
|   curl_easy_getinfo(curl, CURLINFO_TOTAL_TIME, &curtime); | ||||
|  | ||||
|   /* under certain circumstances it may be desirable for certain functionality | ||||
|      to only run every N seconds, in order to do this the transaction time can | ||||
|      be used */ | ||||
|   if((curtime - myp->lastruntime) >= MINIMAL_PROGRESS_FUNCTIONALITY_INTERVAL) { | ||||
|     myp->lastruntime = curtime; | ||||
|     fprintf(stderr, "TOTAL TIME: %f \r\n", curtime); | ||||
|   } | ||||
|  | ||||
|   fprintf(stderr, "UP: %g of %g  DOWN: %g of %g\r\n", | ||||
|           ulnow, ultotal, dlnow, dltotal); | ||||
|  | ||||
|   if(dlnow > STOP_DOWNLOAD_AFTER_THIS_MANY_BYTES) | ||||
|     return 1; | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res=0; | ||||
|   struct myprogress prog; | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     prog.lastruntime = 0; | ||||
|     prog.curl = curl; | ||||
|  | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/"); | ||||
|     curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, progress); | ||||
|     /* pass the struct pointer into the progress function */ | ||||
|     curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, &prog); | ||||
|     curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0L); | ||||
|     res = curl_easy_perform(curl); | ||||
|  | ||||
|     if(res) | ||||
|       fprintf(stderr, "%s\n", curl_easy_strerror(res)); | ||||
|  | ||||
|     /* always cleanup */ | ||||
|     curl_easy_cleanup(curl); | ||||
|   } | ||||
|   return (int)res; | ||||
| } | ||||
							
								
								
									
										51
									
								
								docs/examples/resolve.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								docs/examples/resolve.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include <stdio.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res = CURLE_OK; | ||||
|   struct curl_slist *host = NULL; | ||||
|  | ||||
|   /* Each single name resolve string should be written using the format | ||||
|      HOST:PORT:ADDRESS where HOST is the name libcurl will try to resolve, | ||||
|      PORT is the port number of the service where libcurl wants to connect to | ||||
|      the HOST and ADDRESS is the numerical IP address | ||||
|    */ | ||||
|   host = curl_slist_append(NULL, "example.com:80:127.0.0.1"); | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
|     curl_easy_setopt(curl, CURLOPT_RESOLVE, host); | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "http://example.com"); | ||||
|     res = curl_easy_perform(curl); | ||||
|  | ||||
|     /* always cleanup */ | ||||
|     curl_easy_cleanup(curl); | ||||
|   } | ||||
|  | ||||
|   curl_slist_free_all(host); | ||||
|  | ||||
|   return (int)res; | ||||
| } | ||||
							
								
								
									
										271
									
								
								docs/examples/rtsp.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										271
									
								
								docs/examples/rtsp.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,271 @@ | ||||
| /* | ||||
|  * Copyright (c) 2011, Jim Hollinger | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
|  * are met: | ||||
|  *   * Redistributions of source code must retain the above copyright | ||||
|  *     notice, this list of conditions and the following disclaimer. | ||||
|  *   * Redistributions in binary form must reproduce the above copyright | ||||
|  *     notice, this list of conditions and the following disclaimer in the | ||||
|  *     documentation and/or other materials provided with the distribution. | ||||
|  *   * Neither the name of Jim Hollinger nor the names of its contributors | ||||
|  *     may be used to endorse or promote products derived from this | ||||
|  *     software without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #if defined (WIN32) | ||||
| #  include <conio.h>  /* _getch() */ | ||||
| #else | ||||
| #  include <termios.h> | ||||
| #  include <unistd.h> | ||||
|  | ||||
| static int _getch(void) | ||||
| { | ||||
|   struct termios oldt, newt; | ||||
|   int ch; | ||||
|   tcgetattr( STDIN_FILENO, &oldt ); | ||||
|   newt = oldt; | ||||
|   newt.c_lflag &= ~( ICANON | ECHO ); | ||||
|   tcsetattr( STDIN_FILENO, TCSANOW, &newt ); | ||||
|   ch = getchar(); | ||||
|   tcsetattr( STDIN_FILENO, TCSANOW, &oldt ); | ||||
|   return ch; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| #define VERSION_STR  "V1.0" | ||||
|  | ||||
| /* error handling macros */ | ||||
| #define my_curl_easy_setopt(A, B, C) \ | ||||
|   if ((res = curl_easy_setopt((A), (B), (C))) != CURLE_OK) \ | ||||
|     fprintf(stderr, "curl_easy_setopt(%s, %s, %s) failed: %d\n", \ | ||||
|             #A, #B, #C, res); | ||||
|  | ||||
| #define my_curl_easy_perform(A) \ | ||||
|   if ((res = curl_easy_perform((A))) != CURLE_OK) \ | ||||
|     fprintf(stderr, "curl_easy_perform(%s) failed: %d\n", #A, res); | ||||
|  | ||||
|  | ||||
| /* send RTSP OPTIONS request */ | ||||
| static void rtsp_options(CURL *curl, const char *uri) | ||||
| { | ||||
|   CURLcode res = CURLE_OK; | ||||
|   printf("\nRTSP: OPTIONS %s\n", uri); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_STREAM_URI, uri); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_REQUEST, (long)CURL_RTSPREQ_OPTIONS); | ||||
|   my_curl_easy_perform(curl); | ||||
| } | ||||
|  | ||||
|  | ||||
| /* send RTSP DESCRIBE request and write sdp response to a file */ | ||||
| static void rtsp_describe(CURL *curl, const char *uri, | ||||
|                           const char *sdp_filename) | ||||
| { | ||||
|   CURLcode res = CURLE_OK; | ||||
|   FILE *sdp_fp = fopen(sdp_filename, "wt"); | ||||
|   printf("\nRTSP: DESCRIBE %s\n", uri); | ||||
|   if (sdp_fp == NULL) { | ||||
|     fprintf(stderr, "Could not open '%s' for writing\n", sdp_filename); | ||||
|     sdp_fp = stdout; | ||||
|   } | ||||
|   else { | ||||
|     printf("Writing SDP to '%s'\n", sdp_filename); | ||||
|   } | ||||
|   my_curl_easy_setopt(curl, CURLOPT_WRITEDATA, sdp_fp); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_REQUEST, (long)CURL_RTSPREQ_DESCRIBE); | ||||
|   my_curl_easy_perform(curl); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_WRITEDATA, stdout); | ||||
|   if (sdp_fp != stdout) { | ||||
|     fclose(sdp_fp); | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* send RTSP SETUP request */ | ||||
| static void rtsp_setup(CURL *curl, const char *uri, const char *transport) | ||||
| { | ||||
|   CURLcode res = CURLE_OK; | ||||
|   printf("\nRTSP: SETUP %s\n", uri); | ||||
|   printf("      TRANSPORT %s\n", transport); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_STREAM_URI, uri); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_TRANSPORT, transport); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_REQUEST, (long)CURL_RTSPREQ_SETUP); | ||||
|   my_curl_easy_perform(curl); | ||||
| } | ||||
|  | ||||
|  | ||||
| /* send RTSP PLAY request */ | ||||
| static void rtsp_play(CURL *curl, const char *uri, const char *range) | ||||
| { | ||||
|   CURLcode res = CURLE_OK; | ||||
|   printf("\nRTSP: PLAY %s\n", uri); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_STREAM_URI, uri); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RANGE, range); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_REQUEST, (long)CURL_RTSPREQ_PLAY); | ||||
|   my_curl_easy_perform(curl); | ||||
| } | ||||
|  | ||||
|  | ||||
| /* send RTSP TEARDOWN request */ | ||||
| static void rtsp_teardown(CURL *curl, const char *uri) | ||||
| { | ||||
|   CURLcode res = CURLE_OK; | ||||
|   printf("\nRTSP: TEARDOWN %s\n", uri); | ||||
|   my_curl_easy_setopt(curl, CURLOPT_RTSP_REQUEST, (long)CURL_RTSPREQ_TEARDOWN); | ||||
|   my_curl_easy_perform(curl); | ||||
| } | ||||
|  | ||||
|  | ||||
| /* convert url into an sdp filename */ | ||||
| static void get_sdp_filename(const char *url, char *sdp_filename) | ||||
| { | ||||
|   const char *s = strrchr(url, '/'); | ||||
|   strcpy(sdp_filename, "video.sdp"); | ||||
|   if (s != NULL) { | ||||
|     s++; | ||||
|     if (s[0] != '\0') { | ||||
|       sprintf(sdp_filename, "%s.sdp", s); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| /* scan sdp file for media control attribute */ | ||||
| static void get_media_control_attribute(const char *sdp_filename, | ||||
|                                         char *control) | ||||
| { | ||||
|   int max_len = 256; | ||||
|   char *s = malloc(max_len); | ||||
|   FILE *sdp_fp = fopen(sdp_filename, "rt"); | ||||
|   control[0] = '\0'; | ||||
|   if (sdp_fp != NULL) { | ||||
|     while (fgets(s, max_len - 2, sdp_fp) != NULL) { | ||||
|       sscanf(s, " a = control: %s", control); | ||||
|     } | ||||
|     fclose(sdp_fp); | ||||
|   } | ||||
|   free(s); | ||||
| } | ||||
|  | ||||
|  | ||||
| /* main app */ | ||||
| int main(int argc, char * const argv[]) | ||||
| { | ||||
| #if 1 | ||||
|   const char *transport = "RTP/AVP;unicast;client_port=1234-1235";  /* UDP */ | ||||
| #else | ||||
|   const char *transport = "RTP/AVP/TCP;unicast;client_port=1234-1235";  /* TCP */ | ||||
| #endif | ||||
|   const char *range = "0.000-"; | ||||
|   int rc = EXIT_SUCCESS; | ||||
|   char *basename = NULL; | ||||
|  | ||||
|   printf("\nRTSP request %s\n", VERSION_STR); | ||||
|   printf("    Project web site: http://code.google.com/p/rtsprequest/\n"); | ||||
|   printf("    Requires cURL V7.20 or greater\n\n"); | ||||
|  | ||||
|   /* check command line */ | ||||
|   if ((argc != 2) && (argc != 3)) { | ||||
|     basename = strrchr(argv[0], '/'); | ||||
|     if (basename == NULL) { | ||||
|       basename = strrchr(argv[0], '\\'); | ||||
|     } | ||||
|     if (basename == NULL) { | ||||
|       basename = argv[0]; | ||||
|     } else { | ||||
|       basename++; | ||||
|     } | ||||
|     printf("Usage:   %s url [transport]\n", basename); | ||||
|     printf("         url of video server\n"); | ||||
|     printf("         transport (optional) specifier for media stream protocol\n"); | ||||
|     printf("         default transport: %s\n", transport); | ||||
|     printf("Example: %s rtsp://192.168.0.2/media/video1\n\n", basename); | ||||
|     rc = EXIT_FAILURE; | ||||
|   } else { | ||||
|     const char *url = argv[1]; | ||||
|     char *uri = malloc(strlen(url) + 32); | ||||
|     char *sdp_filename = malloc(strlen(url) + 32); | ||||
|     char *control = malloc(strlen(url) + 32); | ||||
|     CURLcode res; | ||||
|     get_sdp_filename(url, sdp_filename); | ||||
|     if (argc == 3) { | ||||
|       transport = argv[2]; | ||||
|     } | ||||
|  | ||||
|     /* initialize curl */ | ||||
|     res = curl_global_init(CURL_GLOBAL_ALL); | ||||
|     if (res == CURLE_OK) { | ||||
|       curl_version_info_data *data = curl_version_info(CURLVERSION_NOW); | ||||
|       CURL *curl; | ||||
|       fprintf(stderr, "    cURL V%s loaded\n", data->version); | ||||
|  | ||||
|       /* initialize this curl session */ | ||||
|       curl = curl_easy_init(); | ||||
|       if (curl != NULL) { | ||||
|         my_curl_easy_setopt(curl, CURLOPT_VERBOSE, 0L); | ||||
|         my_curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 1L); | ||||
|         my_curl_easy_setopt(curl, CURLOPT_WRITEHEADER, stdout); | ||||
|         my_curl_easy_setopt(curl, CURLOPT_URL, url); | ||||
|  | ||||
|         /* request server options */ | ||||
|         sprintf(uri, "%s", url); | ||||
|         rtsp_options(curl, uri); | ||||
|  | ||||
|         /* request session description and write response to sdp file */ | ||||
|         rtsp_describe(curl, uri, sdp_filename); | ||||
|  | ||||
|         /* get media control attribute from sdp file */ | ||||
|         get_media_control_attribute(sdp_filename, control); | ||||
|  | ||||
|         /* setup media stream */ | ||||
|         sprintf(uri, "%s/%s", url, control); | ||||
|         rtsp_setup(curl, uri, transport); | ||||
|  | ||||
|         /* start playing media stream */ | ||||
|         sprintf(uri, "%s/", url); | ||||
|         rtsp_play(curl, uri, range); | ||||
|         printf("Playing video, press any key to stop ..."); | ||||
|         _getch(); | ||||
|         printf("\n"); | ||||
|  | ||||
|         /* teardown session */ | ||||
|         rtsp_teardown(curl, uri); | ||||
|  | ||||
|         /* cleanup */ | ||||
|         curl_easy_cleanup(curl); | ||||
|         curl = NULL; | ||||
|       } else { | ||||
|         fprintf(stderr, "curl_easy_init() failed\n"); | ||||
|       } | ||||
|       curl_global_cleanup(); | ||||
|     } else { | ||||
|       fprintf(stderr, "curl_global_init(%s) failed: %d\n", | ||||
|               "CURL_GLOBAL_ALL", res); | ||||
|     } | ||||
|     free(control); | ||||
|     free(sdp_filename); | ||||
|     free(uri); | ||||
|   } | ||||
|  | ||||
|   return rc; | ||||
| } | ||||
| @@ -24,6 +24,7 @@ | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <curl/curl.h> | ||||
| #include "printf_macro.h" | ||||
|  | ||||
| /* Auxiliary function that waits on the socket. */ | ||||
| static int wait_on_socket(curl_socket_t sockfd, int for_recv, long timeout_ms) | ||||
| @@ -122,7 +123,7 @@ int main(void) | ||||
|       if(CURLE_OK != res) | ||||
|         break; | ||||
|  | ||||
|       printf("Received %u bytes.\n", iolen); | ||||
|       printf("Received %" _FMT_SIZE_T " bytes.\n", iolen); | ||||
|     } | ||||
|  | ||||
|     /* always cleanup */ | ||||
|   | ||||
| @@ -24,8 +24,6 @@ | ||||
| #include <unistd.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
| static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   | ||||
| @@ -22,9 +22,6 @@ | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| #include <curl/easy.h> | ||||
|  | ||||
|  | ||||
| /* some requirements for this to work: | ||||
|    1.   set pCertFile to the file with the client certificate | ||||
|   | ||||
| @@ -37,8 +37,6 @@ | ||||
| #include <pthread.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> /* new for v7 */ | ||||
| #include <curl/easy.h> /* new for v7 */ | ||||
|  | ||||
| #define NUMT 4 | ||||
|  | ||||
|   | ||||
| @@ -123,13 +123,13 @@ int main(void) | ||||
|    curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); | ||||
|    curl_easy_setopt(curl, CURLOPT_MAIL_FROM, MAILFROM); | ||||
|    curl_easy_setopt(curl, CURLOPT_MAIL_RCPT, rcpt_list); | ||||
|    curl_easy_setopt(curl, CURLOPT_USE_SSL, CURLUSESSL_ALL); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER,0); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0); | ||||
|    curl_easy_setopt(curl, CURLOPT_USE_SSL, (long)CURLUSESSL_ALL); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); | ||||
|    curl_easy_setopt(curl, CURLOPT_READDATA, &pooh); | ||||
|    curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSLVERSION, 0); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSL_SESSIONID_CACHE, 0); | ||||
|    curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSLVERSION, 0L); | ||||
|    curl_easy_setopt(curl, CURLOPT_SSL_SESSIONID_CACHE, 0L); | ||||
|    curl_multi_add_handle(mcurl, curl); | ||||
|  | ||||
|    mp_timedout = 0; | ||||
|   | ||||
| @@ -94,13 +94,13 @@ int main(void) | ||||
|      * of using CURLUSESSL_TRY here, because if TLS upgrade fails, the transfer | ||||
|      * will continue anyway - see the security discussion in the libcurl | ||||
|      * tutorial for more details. */ | ||||
|     curl_easy_setopt(curl, CURLOPT_USE_SSL, CURLUSESSL_ALL); | ||||
|     curl_easy_setopt(curl, CURLOPT_USE_SSL, (long)CURLUSESSL_ALL); | ||||
|  | ||||
|     /* If your server doesn't have a valid certificate, then you can disable | ||||
|      * part of the Transport Layer Security protection by setting the | ||||
|      * CURLOPT_SSL_VERIFYPEER and CURLOPT_SSL_VERIFYHOST options to 0 (false). | ||||
|      *   curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0); | ||||
|      *   curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0); | ||||
|      *   curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); | ||||
|      *   curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); | ||||
|      * That is, in general, a bad idea. It is still better than sending your | ||||
|      * authentication details in plain text though. | ||||
|      * Instead, you should get the issuer certificate (or the host certificate | ||||
| @@ -135,7 +135,7 @@ int main(void) | ||||
|     /* Since the traffic will be encrypted, it is very useful to turn on debug | ||||
|      * information within libcurl to see what is happening during the transfer. | ||||
|      */ | ||||
|     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||
|     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L); | ||||
|  | ||||
|     /* send the message (including headers) */ | ||||
|     res = curl_easy_perform(curl); | ||||
|   | ||||
| @@ -147,7 +147,7 @@ size_t SyncTime_CURL_WriteHeader(void *ptr, size_t size, size_t nmemb, | ||||
|                                          TmpStr1 & 2? */ | ||||
|         AutoSyncTime = 0; | ||||
|       else { | ||||
|         RetVal = sscanf ((char *)(ptr), "Date: %s %d %s %d %d:%d:%d", | ||||
|         RetVal = sscanf ((char *)(ptr), "Date: %s %hu %s %hu %hu:%hu:%hu", | ||||
|                          TmpStr1, &SYSTime.wDay, TmpStr2, &SYSTime.wYear, | ||||
|                          &SYSTime.wHour, &SYSTime.wMinute, &SYSTime.wSecond); | ||||
|  | ||||
|   | ||||
							
								
								
									
										81
									
								
								docs/examples/url2file.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								docs/examples/url2file.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
|  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
|  * | ||||
|  * 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 COPYING file. | ||||
|  * | ||||
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <unistd.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   size_t written = fwrite(ptr, size, nmemb, (FILE *)stream); | ||||
|   return written; | ||||
| } | ||||
|  | ||||
| int main(int argc, char *argv[]) | ||||
| { | ||||
|   CURL *curl_handle; | ||||
|   static const char *pagefilename = "page.out"; | ||||
|   FILE *pagefile; | ||||
|  | ||||
|   if(argc < 2 ) { | ||||
|     printf("Usage: %s <URL>\n", argv[0]); | ||||
|     return 1; | ||||
|   } | ||||
|  | ||||
|   curl_global_init(CURL_GLOBAL_ALL); | ||||
|  | ||||
|   /* init the curl session */ | ||||
|   curl_handle = curl_easy_init(); | ||||
|  | ||||
|   /* set URL to get here */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_URL, argv[1]); | ||||
|  | ||||
|   /* Switch on full protocol/debug output while testing */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_VERBOSE, 1L); | ||||
|  | ||||
|   /* disable progress meter, set to 0L to enable and disable debug output */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1L); | ||||
|  | ||||
|   /* send all data to this function  */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, write_data); | ||||
|  | ||||
|   /* open the file */ | ||||
|   pagefile = fopen(pagefilename, "wb"); | ||||
|   if (pagefile) { | ||||
|  | ||||
|     /* write the page body to this file handle. CURLOPT_FILE is also known as | ||||
|        CURLOPT_WRITEDATA*/ | ||||
|     curl_easy_setopt(curl_handle, CURLOPT_FILE, pagefile); | ||||
|  | ||||
|     /* get it! */ | ||||
|     curl_easy_perform(curl_handle); | ||||
|  | ||||
|     /* close the header file */ | ||||
|     fclose(pagefile); | ||||
|   } | ||||
|  | ||||
|   /* cleanup curl stuff */ | ||||
|   curl_easy_cleanup(curl_handle); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -82,7 +82,7 @@ PDFPAGES = curl_easy_cleanup.pdf curl_easy_getinfo.pdf			 \ | ||||
| CLEANFILES = $(HTMLPAGES) $(PDFPAGES) | ||||
|  | ||||
| EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) libcurl.m4 ABI \ | ||||
|   symbols-in-versions | ||||
|   symbols-in-versions symbols.pl | ||||
| MAN2HTML= roffit --mandir=. < $< >$@ | ||||
|  | ||||
| SUFFIXES = .3 .html | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -37,8 +37,15 @@ 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. | ||||
|  | ||||
| Any uses of the \fBhandle\fP after this function has been called are | ||||
| illegal. This kills the handle and all memory associated with it! | ||||
| Occasionally you may get your progress callback or header callback called from | ||||
| within \fIcurl_easy_cleanup(3)\fP (if previously set for the handle using | ||||
| \fIcurl_easy_setopt(3)\fP). Like if libcurl decides to shut down the | ||||
| connection and the protocol is of a kind that requires a command/response | ||||
| sequence before disconnect. Examples of such protocols are FTP, POP3 and IMAP. | ||||
|  | ||||
| Any uses of the \fBhandle\fP after this function has been called and have | ||||
| returned, are illegal. This kills the handle and all memory associated with | ||||
| it! | ||||
|  | ||||
| With libcurl versions prior to 7.17.: when you've called this, you can safely | ||||
| remove all the strings you've previously told libcurl to use, as it won't use | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -31,8 +31,8 @@ curl_easy_escape - URL encodes the given string | ||||
| .SH DESCRIPTION | ||||
| This function converts the given input string to an URL encoded string and | ||||
| returns that as a new allocated string. All input characters that are not a-z, | ||||
| A-Z or 0-9 are converted to their "URL escaped" version (%NN where NN is a | ||||
| two-digit hexadecimal number). | ||||
| A-Z, 0-9, '-', '.', '_' or '~' are converted to their "URL escaped" version | ||||
| (%NN where NN is a two-digit hexadecimal number). | ||||
|  | ||||
| If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_escape(3)\fP | ||||
| uses strlen() on the input \fBurl\fP to find out the size. | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -44,11 +44,13 @@ The following information can be extracted: | ||||
| .IP CURLINFO_EFFECTIVE_URL | ||||
| Pass a pointer to a char pointer to receive the last used effective URL. | ||||
| .IP CURLINFO_RESPONSE_CODE | ||||
| Pass a pointer to a long to receive the last received HTTP or FTP code. This | ||||
| option was known as CURLINFO_HTTP_CODE in libcurl 7.10.7 and earlier. This | ||||
| will be zero if no server response code has been received. Note that a proxy's | ||||
| CONNECT response should be read with \fICURLINFO_HTTP_CONNECTCODE\fP and not | ||||
| this. | ||||
| Pass a pointer to a long to receive the last received HTTP, FTP or SMTP | ||||
| response code. This option was previously known as CURLINFO_HTTP_CODE in | ||||
| libcurl 7.10.7 and earlier. The value will be zero if no server response code | ||||
| has been received. Note that a proxy's CONNECT response should be read with | ||||
| \fICURLINFO_HTTP_CONNECTCODE\fP and not this. | ||||
|  | ||||
| Support for SMTP responses added in 7.25.0. | ||||
| .IP CURLINFO_HTTP_CONNECTCODE | ||||
| Pass a pointer to a long to receive the last received proxy response code to a | ||||
| CONNECT request. | ||||
| @@ -80,12 +82,13 @@ waits in line for the pipeline and more. (Added in 7.19.0) | ||||
| Pass a pointer to a double to receive the time, in seconds, it took from the | ||||
| start until the file transfer is just about to begin. This includes all | ||||
| pre-transfer commands and negotiations that are specific to the particular | ||||
| protocol(s) involved. | ||||
| protocol(s) involved. It does \fInot\fP involve the sending of the protocol- | ||||
| specific request that triggers a transfer. | ||||
| .IP CURLINFO_STARTTRANSFER_TIME | ||||
| Pass a pointer to a double to receive the time, in seconds, it took from the | ||||
| start until the first byte is just about to be transferred. This includes | ||||
| CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate | ||||
| the result. | ||||
| start until the first byte is received by libcurl. This includes | ||||
| CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate the | ||||
| result. | ||||
| .IP 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 | ||||
| @@ -275,7 +278,7 @@ file transfer is just about to begin. This includes all pre-transfer commands | ||||
| and negotiations that are specific to the particular protocol(s) involved. | ||||
| .IP STARTTRANSFER | ||||
| \fICURLINFO_STARTTRANSFER_TIME\fP. The time it took from the start until the | ||||
| first byte is just about to be transferred. | ||||
| first byte is received by libcurl. | ||||
| .IP TOTAL | ||||
| \fICURLINFO_TOTAL_TIME\fP. Total time of the previous request. | ||||
| .IP REDIRECT | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -68,8 +68,9 @@ A parameter set to 1 tells the library to include the header in the body | ||||
| output. This is only relevant for protocols that actually have headers | ||||
| preceding the data (like HTTP). | ||||
| .IP CURLOPT_NOPROGRESS | ||||
| A parameter set to 1 tells the library to shut off the built-in progress meter | ||||
| completely. | ||||
| Pass a long. If set to 1, it tells the library to shut off the progress meter | ||||
| completely. It will also present the \fICURLOPT_PROGRESSFUNCTION\fP from | ||||
| getting called. | ||||
|  | ||||
| Future versions of libcurl are likely to not have any built-in progress meter | ||||
| at all. | ||||
| @@ -90,7 +91,9 @@ SIGPIPE signals, which otherwise are sent by the system when trying to send | ||||
| data to a socket which is closed in the other end. libcurl makes an effort to | ||||
| never cause such SIGPIPEs to trigger, but some operating systems have no way | ||||
| to avoid them and even on those that have there are some corner cases when | ||||
| they may still happen, contrary to our desire. | ||||
| they may still happen, contrary to our desire. In addition, using | ||||
| \fICURLAUTH_NTLM_WB\fP authentication could cause a SIGCHLD signal to be | ||||
| raised. | ||||
| .IP CURLOPT_WILDCARDMATCH | ||||
| Set this option to 1 if you want to transfer multiple files according to a | ||||
| file name pattern. The pattern can be specified as part of the | ||||
| @@ -105,18 +108,18 @@ This feature is only supported by the FTP download for now. | ||||
|  | ||||
| A brief introduction of its syntax follows: | ||||
| .RS | ||||
| .IP "\fB*\fP - ASTERISK" | ||||
| .IP "* - ASTERISK" | ||||
| \&ftp://example.com/some/path/\fB*.txt\fP (for all txt's from the root | ||||
| directory) | ||||
| .RE | ||||
| .RS | ||||
| .IP "\fB?\fP - QUESTION MARK" | ||||
| .IP "? - QUESTION MARK" | ||||
| Question mark matches any (exactly one) character. | ||||
|  | ||||
| \&ftp://example.com/some/path/\fBphoto?.jpeg\fP | ||||
| .RE | ||||
| .RS | ||||
| .IP "\fB[\fP - BRACKET EXPRESSION" | ||||
| .IP "[ - BRACKET EXPRESSION" | ||||
| The left bracket opens a bracket expression. The question mark and asterisk have | ||||
| no special meaning in a bracket expression. Each bracket expression ends by the | ||||
| right bracket and matches exactly one character. Some examples follow: | ||||
| @@ -145,7 +148,7 @@ Using the rules above, a file name pattern can be constructed: | ||||
| .SH CALLBACK OPTIONS | ||||
| .IP CURLOPT_WRITEFUNCTION | ||||
| Function pointer that should match the following prototype: \fBsize_t | ||||
| function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP This | ||||
| function( char *ptr, size_t size, size_t nmemb, void *userdata);\fP This | ||||
| function gets called by libcurl as soon as there is data received that needs | ||||
| to be saved. The size of the data pointed to by \fIptr\fP is \fIsize\fP | ||||
| multiplied with \fInmemb\fP, it will not be zero terminated. Return the number | ||||
| @@ -168,8 +171,12 @@ Set the \fIuserdata\fP argument with the \fICURLOPT_WRITEDATA\fP option. | ||||
|  | ||||
| The callback function will be passed as much data as possible in all invokes, | ||||
| but you cannot possibly make any assumptions. It may be one byte, it may be | ||||
| thousands. The maximum amount of data that can be passed to the write callback | ||||
| is defined in the curl.h header file: CURL_MAX_WRITE_SIZE. | ||||
| thousands. The maximum amount of body data that can be passed to the write | ||||
| callback is defined in the curl.h header file: CURL_MAX_WRITE_SIZE (the usual | ||||
| default is 16K). If you however have \fICURLOPT_HEADER\fP set, which sends | ||||
| header data to the write callback, you can get up to | ||||
| \fICURL_MAX_HTTP_HEADER\fP bytes of header data passed into it. This usually | ||||
| means 100K. | ||||
| .IP CURLOPT_WRITEDATA | ||||
| Data pointer to pass to the file write function. If you use the | ||||
| \fICURLOPT_WRITEFUNCTION\fP option, this is the pointer you'll get as | ||||
| @@ -259,7 +266,7 @@ If you forward the input arguments directly to "fseek" or "lseek", note that | ||||
| the data type for \fIoffset\fP is not the same as defined for curl_off_t on | ||||
| many systems! (Option added in 7.18.0) | ||||
| .IP CURLOPT_SEEKDATA | ||||
| Data pointer to pass to the file read function. If you use the | ||||
| Data pointer to pass to the file seek function. If you use the | ||||
| \fICURLOPT_SEEKFUNCTION\fP option, this is the pointer you'll get as input. If | ||||
| you don't specify a seek callback, NULL is passed. (Option added in 7.18.0) | ||||
| .IP CURLOPT_SOCKOPTFUNCTION | ||||
| @@ -274,7 +281,7 @@ socket descriptor so additional setsockopt() calls can be done at the user's | ||||
| discretion.  Return 0 (zero) from the callback on success. Return 1 from the | ||||
| callback function to signal an unrecoverable error to the library and it will | ||||
| close the socket and return \fICURLE_COULDNT_CONNECT\fP.  (Option added in | ||||
| 7.15.6.) | ||||
| 7.16.0) | ||||
|  | ||||
| Added in 7.21.5, the callback function may return | ||||
| \fICURL_SOCKOPT_ALREADY_CONNECTED\fP, which tells libcurl that the socket is | ||||
| @@ -282,15 +289,14 @@ in fact already connected and then libcurl will not attempt to connect it. | ||||
| .IP CURLOPT_SOCKOPTDATA | ||||
| Pass a pointer that will be untouched by libcurl and passed as the first | ||||
| argument in the sockopt callback set with \fICURLOPT_SOCKOPTFUNCTION\fP. | ||||
| (Option added in 7.15.6.) | ||||
| (Option added in 7.16.0) | ||||
| .IP CURLOPT_OPENSOCKETFUNCTION | ||||
| Function pointer that should match the \fIcurl_opensocket_callback\fP | ||||
| prototype found in \fI<curl/curl.h>\fP. This function gets called by libcurl | ||||
| instead of the \fIsocket(2)\fP call. The callback's \fIpurpose\fP argument | ||||
| identifies the exact purpose for this particular socket, and currently only | ||||
| one value is supported: \fICURLSOCKTYPE_IPCXN\fP for the primary connection | ||||
| (meaning the control connection in the FTP case). Future versions of libcurl | ||||
| may support more purposes. It passes the resolved peer address as a | ||||
| identifies the exact purpose for this particular socket: | ||||
| \fICURLSOCKTYPE_IPCXN\fP is for IP based connections. Future versions of | ||||
| libcurl may support more purposes. It passes the resolved peer address as a | ||||
| \fIaddress\fP argument so the callback can modify the address or refuse to | ||||
| connect at all. The callback function should return the socket or | ||||
| \fICURL_SOCKET_BAD\fP in case no connection should be established or any error | ||||
| @@ -307,6 +313,17 @@ address blacklisting.  The default behavior is: | ||||
| Pass a pointer that will be untouched by libcurl and passed as the first | ||||
| argument in the opensocket callback set with \fICURLOPT_OPENSOCKETFUNCTION\fP. | ||||
| (Option added in 7.17.1.) | ||||
| .IP CURLOPT_CLOSESOCKETFUNCTION | ||||
| Function pointer that should match the \fIcurl_closesocket_callback\fP | ||||
| prototype found in \fI<curl/curl.h>\fP. This function gets called by libcurl | ||||
| instead of the \fIclose(3)\fP or \fIclosesocket(3)\fP call when sockets are | ||||
| closed (not for any other file descriptors). This is pretty much the reverse | ||||
| to the \fICURLOPT_OPENSOCKETFUNCTION\fP option. Return 0 to signal success and | ||||
| 1 if there was an error.  (Option added in 7.21.7) | ||||
| .IP CURLOPT_CLOSESOCKETDATA | ||||
| Pass a pointer that will be untouched by libcurl and passed as the first | ||||
| argument in the closesocket callback set with | ||||
| \fICURLOPT_CLOSESOCKETFUNCTION\fP.  (Option added in 7.21.7) | ||||
| .IP CURLOPT_PROGRESSFUNCTION | ||||
| Function pointer that should match the \fIcurl_progress_callback\fP prototype | ||||
| found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of | ||||
| @@ -331,15 +348,18 @@ Function pointer that should match the following prototype: \fIsize_t | ||||
| function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP. This | ||||
| function gets called by libcurl as soon as it has received header data. The | ||||
| header callback will be called once for each header and only complete header | ||||
| lines are passed on to the callback. Parsing headers should be easy enough | ||||
| using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP | ||||
| multiplied with \fInmemb\fP. Do not assume that the header line is zero | ||||
| terminated! The pointer named \fIuserdata\fP is the one you set with the | ||||
| lines are passed on to the callback. Parsing headers is very easy using | ||||
| this. The size of the data pointed to by \fIptr\fP is \fIsize\fP multiplied | ||||
| with \fInmemb\fP. Do not assume that the header line is zero terminated! The | ||||
| pointer named \fIuserdata\fP is the one you set with the | ||||
| \fICURLOPT_WRITEHEADER\fP option. The callback function must return the number | ||||
| of bytes actually taken care of. If that amount differs from the amount passed | ||||
| to your function, it'll signal an error to the library. This will abort the | ||||
| transfer and return \fICURL_WRITE_ERROR\fP. | ||||
|  | ||||
| A complete header that is passed to this function can be up to | ||||
| \fICURL_MAX_HTTP_HEADER\fP (100K) bytes. | ||||
|  | ||||
| If this option is not set, or if it is set to NULL, but | ||||
| \fICURLOPT_HEADERDATA\fP (\fICURLOPT_WRITEHEADER\fP) is set to anything but | ||||
| NULL, the function used to accept response data will be used instead. That is, | ||||
| @@ -353,19 +373,20 @@ negotiation. If you need to operate on only the headers from the final | ||||
| response, you will need to collect headers in the callback yourself and use | ||||
| HTTP status lines, for example, to delimit response boundaries. | ||||
|  | ||||
| Since 7.14.1: When a server sends a chunked encoded transfer, it may contain a | ||||
| trailer. That trailer is identical to a HTTP header and if such a trailer is | ||||
| received it is passed to the application using this callback as well. There | ||||
| are several ways to detect it being a trailer and not an ordinary header: 1) | ||||
| it comes after the response-body. 2) it comes after the final header line (CR | ||||
| LF) 3) a Trailer: header among the response-headers mention what header to | ||||
| expect in the trailer. | ||||
| When a server sends a chunked encoded transfer, it may contain a trailer. That | ||||
| trailer is identical to a HTTP header and if such a trailer is received it is | ||||
| passed to the application using this callback as well. There are several ways | ||||
| to detect it being a trailer and not an ordinary header: 1) it comes after the | ||||
| response-body. 2) it comes after the final header line (CR LF) 3) a Trailer: | ||||
| header among the regular response-headers mention what header(s) to expect in | ||||
| the trailer. | ||||
| .IP CURLOPT_WRITEHEADER | ||||
| (This option is also known as \fBCURLOPT_HEADERDATA\fP) Pass a pointer to be | ||||
| used to write the header part of the received data to. If you don't use your | ||||
| own callback to take care of the writing, this must be a valid FILE *. See | ||||
| also the \fICURLOPT_HEADERFUNCTION\fP option above on how to set a custom | ||||
| get-all-headers callback. | ||||
| used to write the header part of the received data to. If you don't use | ||||
| \fICURLOPT_WRITEFUNCTION\fP or \fICURLOPT_HEADERFUNCTION\fP to take care of | ||||
| the writing, this must be a valid FILE * as the internal default will then be | ||||
| a plain fwrite(). See also the \fICURLOPT_HEADERFUNCTION\fP option above on | ||||
| how to set a custom get-all-headers callback. | ||||
| .IP CURLOPT_DEBUGFUNCTION | ||||
| Function pointer that should match the following prototype: \fIint | ||||
| curl_debug_callback (CURL *, curl_infotype, char *, size_t, void *);\fP | ||||
| @@ -398,7 +419,7 @@ built against another SSL library, this functionality is absent. | ||||
|  | ||||
| Function pointer that should match the following prototype: \fBCURLcode | ||||
| sslctxfun(CURL *curl, void *sslctx, void *parm);\fP This function gets called | ||||
| by libcurl just before the initialization of an SSL connection after having | ||||
| by libcurl just before the initialization of a SSL connection after having | ||||
| processed all other SSL related options to give a last chance to an | ||||
| application to modify the behaviour of openssl's ssl initialization. The | ||||
| \fIsslctx\fP parameter is actually a pointer to an openssl \fISSL_CTX\fP. If | ||||
| @@ -413,7 +434,7 @@ the SSL negotiation. The SSL_CTX pointer will be a new one every time. | ||||
| To use this properly, a non-trivial amount of knowledge of the openssl | ||||
| libraries is necessary. For example, using this function allows you to use | ||||
| openssl callbacks to add additional validation code for certificates, and even | ||||
| to change the actual URI of an HTTPS request (example used in the lib509 test | ||||
| to change the actual URI of a HTTPS request (example used in the lib509 test | ||||
| case).  See also the example section for a replacement of the key, certificate | ||||
| and trust file settings. | ||||
| .IP CURLOPT_SSL_CTX_DATA | ||||
| @@ -569,20 +590,162 @@ POST/PUT and a 401 or 407 is received immediately afterwards. | ||||
| .SH NETWORK OPTIONS | ||||
| .IP CURLOPT_URL | ||||
| The actual URL to deal with. The parameter should be a char * to a zero | ||||
| terminated string. | ||||
| terminated string which must be URL-encoded in the following format: | ||||
|  | ||||
| If the given URL lacks the protocol part ("http://" or "ftp://" etc), it will | ||||
| attempt to guess which protocol to use based on the given host name. If the | ||||
| given protocol of the set URL is not supported, libcurl will return on error | ||||
| (\fICURLE_UNSUPPORTED_PROTOCOL\fP) when you call \fIcurl_easy_perform(3)\fP or | ||||
| \fIcurl_multi_perform(3)\fP. Use \fIcurl_version_info(3)\fP for detailed info | ||||
| on which protocols are supported. | ||||
| scheme://host:port/path | ||||
|  | ||||
| The string given to CURLOPT_URL must be url-encoded and follow RFC 2396 | ||||
| (http://curl.haxx.se/rfc/rfc2396.txt). | ||||
| For a greater explanation of the format please see RFC 3986 | ||||
| (http://curl.haxx.se/rfc/rfc3986.txt). | ||||
|  | ||||
| Starting with version 7.20.0, the fragment part of the URI will not be send as | ||||
| part of the path, which was the case previously. | ||||
| If the given URL lacks the scheme, or protocol, part ("http://" or "ftp://" | ||||
| etc), libcurl will attempt to resolve which protocol to use based on the | ||||
| given host mame. If the protocol is not supported, libcurl will return | ||||
| (\fICURLE_UNSUPPORTED_PROTOCOL\fP) when you call \fIcurl_easy_perform(3)\fP | ||||
| or \fIcurl_multi_perform(3)\fP. Use \fIcurl_version_info(3)\fP for detailed | ||||
| information on which protocols are supported. | ||||
|  | ||||
| The host part of the URL contains the address of the server that you want to | ||||
| connect to. This can be the fully qualified domain name of the server, the | ||||
| local network name of the machine on your network or the IP address of the | ||||
| server or machine represented by either an IPv4 or IPv6 address. For example: | ||||
|  | ||||
| http://www.example.com/ | ||||
|  | ||||
| http://hostname/ | ||||
|  | ||||
| http://192.168.0.1/ | ||||
|  | ||||
| http://[2001:1890:1112:1::20]/ | ||||
|  | ||||
| It is also possible to specify the user name and password as part of the | ||||
| host, for some protocols, when connecting to servers that require | ||||
| authentication. | ||||
|  | ||||
| For example the following types of authentication support this: | ||||
|  | ||||
| http://user:password@www.domain.com | ||||
| ftp://user:password@ftp.domain.com | ||||
| pop3://user:password@mail.domain.com | ||||
|  | ||||
| The port is optional and when not specified libcurl will use the default port | ||||
| based on the determined or specified protocol: 80 for http, 21 for ftp and 25 | ||||
| for smtp, etc. The following examples show how to specify the port: | ||||
|  | ||||
| http://www.weirdserver.com:8080/ - This will connect to a web server using | ||||
| port 8080. | ||||
|  | ||||
| smtp://mail.domain.com:587/ - This will connect to a smtp server on the | ||||
| alternative mail port. | ||||
|  | ||||
| The path part of the URL is protocol specific and whilst some examples are | ||||
| given below this list is not conclusive: | ||||
|  | ||||
| .B HTTP | ||||
|  | ||||
| The path part of a HTTP request specifies the file to retrieve and from what | ||||
| directory. If the directory is not specified then the web server's root | ||||
| directory is used. If the file is omitted then the default document will be | ||||
| retrieved for either the directory specified or the root directory. The | ||||
| exact resource returned for each URL is entirely dependent on the server's | ||||
| configuration. | ||||
|  | ||||
| http://www.netscape.com - This gets the main page (index.html in this | ||||
| example) from Netscape's web server. | ||||
|  | ||||
| http://www.netscape.com/index.html - This returns the main page from Netscape | ||||
| by specifying the page to get. | ||||
|  | ||||
| http://www.netscape.com/contactus/ - This returns the default document from | ||||
| the contactus directory. | ||||
|  | ||||
| .B FTP | ||||
|  | ||||
| The path part of an FTP request specifies the file to retrieve and from what | ||||
| directory. If the file part is omitted then libcurl downloads the directory | ||||
| listing for the directory specified. If the directory is omitted then | ||||
| the directory listing for the root / home directory will be returned. | ||||
|  | ||||
| ftp://cool.haxx.se - This retrieves the directory listing for our FTP server. | ||||
|  | ||||
| ftp://cool.haxx.se/readme.txt - This downloads the file readme.txt from the | ||||
| root directory. | ||||
|  | ||||
| ftp://cool.haxx.se/libcurl/readme.txt - This downloads readme.txt from the | ||||
| libcurl directory. | ||||
|  | ||||
| ftp://user:password@my.example.com/readme.txt - This retrieves the readme.txt | ||||
| file from the user's home directory. When a username and password is | ||||
| specified, everything that is specified in the path part is relative to the | ||||
| user's home directory. To retrieve files from the root directory or a | ||||
| directory underneath the root directory then the absolute path must be | ||||
| specified by prepending an additional forward slash to the beginning of the | ||||
| path. | ||||
|  | ||||
| ftp://user:password@my.example.com//readme.txt - This retrieves the readme.txt | ||||
| from the root directory when logging in as a specified user. | ||||
|  | ||||
| .B SMTP | ||||
|  | ||||
| The path part of a SMTP request specifies the host name to present during | ||||
| communication with the mail server. If the path is omitted then libcurl will | ||||
| attempt to resolve the local computer's host name. However, this may not | ||||
| return the fully qualified domain name that is required by some mail servers | ||||
| and specifying this path allows you to set an alternative name, such as | ||||
| your machine's fully qualified domain name, which you might have obtained | ||||
| from an external function such as gethostname or getaddrinfo. | ||||
|  | ||||
| smtp://mail.domain.com - This connects to the mail server at domain.com and | ||||
| sends your local computer's host name in the HELO / EHLO command. | ||||
|  | ||||
| smtp://mail.domain.com/client.domain.com - This will send client.domain.com in | ||||
| the HELO / EHLO command to the mail server at domain.com. | ||||
|  | ||||
| .B POP3 | ||||
|  | ||||
| The path part of a POP3 request specifies the mailbox (message) to retrieve. | ||||
| If the mailbox is not specified then a list of waiting messages is returned | ||||
| instead. | ||||
|  | ||||
| pop3://user:password@mail.domain.com - This lists the available messages | ||||
| pop3://user:password@mail.domain.com/1 - This retrieves the first message | ||||
|  | ||||
| .B SCP | ||||
|  | ||||
| The path part of a SCP request specifies the file to retrieve and from what | ||||
| directory. The file part may not be omitted. The file is taken as an absolute | ||||
| path from the root directory on the server. To specify a path relative to | ||||
| the user's home directory on the server, prepend ~/ to the path portion. | ||||
| If the user name is not embedded in the URL, it can be set with the | ||||
| \fICURLOPT_USERPWD\fP or \fBCURLOPT_USERNAME\fP option. | ||||
|  | ||||
| scp://user@example.com/etc/issue - This specifies the file /etc/issue | ||||
|  | ||||
| scp://example.com/~/my-file - This specifies the file my-file in the | ||||
| user's home directory on the server | ||||
|  | ||||
| .B SFTP | ||||
|  | ||||
| The path part of a SFTP request specifies the file to retrieve and from what | ||||
| directory. If the file part is omitted then libcurl downloads the directory | ||||
| listing for the directory specified.  If the path ends in a / then a directory | ||||
| listing is returned instead of a file.  If the path is omitted entirely then | ||||
| the directory listing for the root / home directory will be returned. | ||||
| If the user name is not embedded in the URL, it can be set with the | ||||
| \fICURLOPT_USERPWD\fP or \fBCURLOPT_USERNAME\fP option. | ||||
|  | ||||
| sftp://user:password@example.com/etc/issue - This specifies the file | ||||
| /etc/issue | ||||
|  | ||||
| sftp://user@example.com/~/my-file - This specifies the file my-file in the | ||||
| user's home directory | ||||
|  | ||||
| sftp://ssh.example.com/~/Documents/ - This requests a directory listing | ||||
| of the Documents directory under the user's home directory | ||||
|  | ||||
| .B NOTES | ||||
|  | ||||
| Starting with version 7.20.0, the fragment part of the URI will not be sent as | ||||
| part of the path, which was previously the case. | ||||
|  | ||||
| \fICURLOPT_URL\fP is the only option that \fBmust\fP be set before | ||||
| \fIcurl_easy_perform(3)\fP is called. | ||||
| @@ -615,7 +778,7 @@ proxy's port number may optionally be specified with the separate option. If | ||||
| not specified, libcurl will default to using port 1080 for proxies. | ||||
| \fICURLOPT_PROXYPORT\fP. | ||||
|  | ||||
| When you tell the library to use an HTTP proxy, libcurl will transparently | ||||
| When you tell the library to use a HTTP proxy, libcurl will transparently | ||||
| convert operations to HTTP even if you specify an FTP URL etc. This may have | ||||
| an impact on what other features of the library you can use, such as | ||||
| \fICURLOPT_QUOTE\fP and similar FTP specifics that don't work unless you | ||||
| @@ -632,17 +795,29 @@ use of a proxy, even if there is an environment variable set for it. | ||||
| Since 7.14.1, the proxy host string given in environment variables can be | ||||
| specified the exact same way as the proxy can be set with \fICURLOPT_PROXY\fP, | ||||
| include protocol prefix (http://) and embedded user + password. | ||||
|  | ||||
| Since 7.21.7, the proxy string may be specified with a protocol:// prefix to | ||||
| specify alternative proxy protocols. Use socks4://, socks4a://, socks5:// or | ||||
| socks5h:// (the last one to enable socks5 and asking the proxy to do the | ||||
| resolving, also known as CURLPROXY_SOCKS5_HOSTNAME type) to request the | ||||
| specific SOCKS version to be used. No protocol specified, http:// and all | ||||
| others will be treated as HTTP proxies. | ||||
| .IP CURLOPT_PROXYPORT | ||||
| Pass a long with this option to set the proxy port to connect to unless it is | ||||
| specified in the proxy string \fICURLOPT_PROXY\fP. | ||||
| .IP CURLOPT_PROXYTYPE | ||||
| Pass a long with this option to set type of the proxy. Available options for | ||||
| this are \fICURLPROXY_HTTP\fP, \fICURLPROXY_HTTP_1_0\fP (added in 7.19.4), | ||||
| \fICURLPROXY_SOCKS4\fP (added in 7.15.2), \fICURLPROXY_SOCKS5\fP, | ||||
| \fICURLPROXY_SOCKS4\fP (added in 7.10), \fICURLPROXY_SOCKS5\fP, | ||||
| \fICURLPROXY_SOCKS4A\fP (added in 7.18.0) and \fICURLPROXY_SOCKS5_HOSTNAME\fP | ||||
| (added in 7.18.0). The HTTP type is default. (Added in 7.10) | ||||
|  | ||||
| If you set \fBCURLOPT_PROXYTYPE\fP to \fICURLPROXY_HTTP_1_0\fP, it will only | ||||
| affect how libcurl speaks to a proxy when CONNECT is used. The HTTP version | ||||
| used for "regular" HTTP requests is instead controlled with | ||||
| \fICURLOPT_HTTP_VERSION\fP. | ||||
| .IP CURLOPT_NOPROXY | ||||
| Pass a pointer to a zero terminated string. The should be a comma- separated | ||||
| Pass a pointer to a zero terminated string. This should be a comma separated | ||||
| list of hosts which do not use a proxy, if one is specified.  The only | ||||
| wildcard is a single * character, which matches all hosts, and effectively | ||||
| disables the proxy. Each name in this list is matched as either a domain which | ||||
| @@ -668,6 +843,15 @@ negotiation. (Added in 7.19.4). | ||||
| Pass a char * as parameter. This sets the interface name to use as outgoing | ||||
| network interface. The name can be an interface name, an IP address, or a host | ||||
| name. | ||||
|  | ||||
| Starting with 7.24.0: If the parameter starts with "if!" then it is treated as | ||||
| only as interface name and no attempt will ever be named to do treat it as an | ||||
| IP address or to do name resolution on it.  If the parameter starts with | ||||
| \&"host!" it is treated as either an IP address or a hostname.  Hostnames are | ||||
| resolved synchronously.  Using the if! format is highly recommended when using | ||||
| the multi interfaces to avoid allowing the code to block.  If "if!" is | ||||
| specified but the parameter does not match an existing interface, | ||||
| CURLE_INTERFACE_FAILED is returned. | ||||
| .IP CURLOPT_LOCALPORT | ||||
| Pass a long. This sets the local port number of the socket used for | ||||
| connection. This can be used in combination with \fICURLOPT_INTERFACE\fP and | ||||
| @@ -731,6 +915,20 @@ overdone. | ||||
| .IP CURLOPT_ADDRESS_SCOPE | ||||
| Pass a long specifying the scope_id value to use when connecting to IPv6 | ||||
| link-local or site-local addresses. (Added in 7.19.0) | ||||
| .IP CURLOPT_TCP_KEEPALIVE | ||||
| Pass a long. If set to 1, TCP keepalive probes will be sent. The delay and | ||||
| frequency of these probes can be controlled by the \fICURLOPT_TCP_KEEPIDLE\fP | ||||
| and \fICURLOPT_TCP_KEEPINTVL\fP options, provided the operating system supports | ||||
| them. Set to 0 (default behavior) to disable keepalive probes (Added in | ||||
| 7.25.0). | ||||
| .IP CURLOPT_TCP_KEEPIDLE | ||||
| Pass a long. Sets the delay, in seconds, that the operating system will wait | ||||
| while the connection is idle before sending keepalive probes. Not all operating | ||||
| systems support this option. (Added in 7.25.0) | ||||
| .IP CURLOPT_TCP_KEEPINTVL | ||||
| Pass a long. Sets the interval, in seconds, that the operating system will wait | ||||
| between sending keepalive probes. Not all operating systems support this | ||||
| option. (Added in 7.25.0) | ||||
| .SH NAMES and PASSWORDS OPTIONS (Authentication) | ||||
| .IP CURLOPT_NETRC | ||||
| This parameter controls the preference of libcurl between using user names and | ||||
| @@ -863,8 +1061,22 @@ HTTP NTLM authentication. A proprietary protocol invented and used by | ||||
| Microsoft. It uses a challenge-response and hash concept similar to Digest, to | ||||
| prevent the password from being eavesdropped. | ||||
|  | ||||
| You need to build libcurl with OpenSSL support for this option to work, or | ||||
| build libcurl on Windows. | ||||
| You need to build libcurl with either OpenSSL or NSS support for this option | ||||
| to work, or build libcurl on Windows. | ||||
| .IP CURLAUTH_NTLM_WB | ||||
| NTLM delegating to winbind helper. Authentication is performed by a separate | ||||
| binary application that is executed when needed. The name of the application | ||||
| is specified at compile time but is typically /usr/bin/ntlm_auth | ||||
| (Added in 7.22.0) | ||||
|  | ||||
| Note that libcurl will fork when necessary to run the winbind application and | ||||
| kill it when complete, calling waitpid() to await its exit when done. On POSIX | ||||
| operating systems, killing the process will cause a SIGCHLD signal to be | ||||
| raised (regardless of whether \fICURLOPT_NOSIGNAL\fP is set), which must be | ||||
| handled intelligently by the application. In particular, the application must | ||||
| not unconditionally call wait() in its SIGCHLD signal handler to avoid being | ||||
| subject to a race condition.  This behavior is subject to change in future | ||||
| versions of libcurl. | ||||
| .IP CURLAUTH_ANY | ||||
| This is a convenience macro that sets all bits and thus makes libcurl pick any | ||||
| it finds suitable. libcurl will automatically select the one it finds most | ||||
| @@ -892,12 +1104,12 @@ You need to build libcurl with GnuTLS or OpenSSL with TLS-SRP support for this | ||||
| to work. (Added in 7.21.4) | ||||
| .RE | ||||
| .IP CURLOPT_TLSAUTH_USERNAME | ||||
| Pass a char * as parameter, which should point to the zero-terminated username | ||||
| Pass a char * as parameter, which should point to the zero terminated username | ||||
| to use for the TLS authentication method specified with the | ||||
| \fICURLOPT_TLSAUTH_TYPE\fP option. Requires that the | ||||
| \fICURLOPT_TLS_PASSWORD\fP option also be set. (Added in 7.21.4) | ||||
| .IP CURLOPT_TLSAUTH_PASSWORD | ||||
| Pass a char * as parameter, which should point to the zero-terminated password | ||||
| Pass a char * as parameter, which should point to the zero terminated password | ||||
| to use for the TLS authentication method specified with the | ||||
| \fICURLOPT_TLSAUTH_TYPE\fP option. Requires that the | ||||
| \fICURLOPT_TLS_USERNAME\fP option also be set. (Added in 7.21.4) | ||||
| @@ -916,8 +1128,8 @@ work. (Added in 7.10.7) | ||||
| Pass a parameter set to 1 to enable this. When enabled, libcurl will | ||||
| automatically set the Referer: field in requests where it follows a Location: | ||||
| redirect. | ||||
| .IP CURLOPT_ENCODING | ||||
| Sets the contents of the Accept-Encoding: header sent in an HTTP request, and | ||||
| .IP CURLOPT_ACCEPT_ENCODING | ||||
| Sets the contents of the Accept-Encoding: header sent in a HTTP request, and | ||||
| enables decoding of a response when a Content-Encoding: header is received. | ||||
| Three encodings are supported: \fIidentity\fP, which does nothing, | ||||
| \fIdeflate\fP which requests the server to compress its response using the | ||||
| @@ -928,9 +1140,24 @@ supported encodings is sent. | ||||
| This is a request, not an order; the server may or may not do it.  This option | ||||
| must be set (to any non-NULL value) or else any unsolicited encoding done by | ||||
| the server is ignored. See the special file lib/README.encoding for details. | ||||
|  | ||||
| (This option was called CURLOPT_ENCODING before 7.21.6) | ||||
| .IP CURLOPT_TRANSFER_ENCODING | ||||
| Adds a request for compressed Transfer Encoding in the outgoing HTTP | ||||
| request. If the server supports this and so desires, it can respond with the | ||||
| HTTP resonse sent using a compressed Transfer-Encoding that will be | ||||
| automatically uncompressed by libcurl on receival. | ||||
|  | ||||
| Transfer-Encoding differs slightly from the Content-Encoding you ask for with | ||||
| \fBCURLOPT_ACCEPT_ENCODING\fP in that a Transfer-Encoding is strictly meant to | ||||
| be for the transfer and thus MUST be decoded before the data arrives in the | ||||
| client. Traditionally, Transfer-Encoding has been much less used and supported | ||||
| by both HTTP clients and HTTP servers. | ||||
|  | ||||
| (Added in 7.21.6) | ||||
| .IP CURLOPT_FOLLOWLOCATION | ||||
| A parameter set to 1 tells the library to follow any Location: header that the | ||||
| server sends as part of an HTTP header. | ||||
| server sends as part of a HTTP header. | ||||
|  | ||||
| This means that the library will re-send the same request on the new location | ||||
| and follow new Location: headers all the way until no more such headers are | ||||
| @@ -1010,7 +1237,7 @@ If you issue a POST request and then want to make a HEAD or GET using the same | ||||
| re-used handle, you must explicitly set the new request type using | ||||
| \fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar. | ||||
| .IP CURLOPT_POSTFIELDS | ||||
| Pass a void * as parameter, which should be the full data to post in an HTTP | ||||
| Pass a void * as parameter, which should be the full data to post in a HTTP | ||||
| POST operation. You must make sure that the data is formatted the way you want | ||||
| the server to receive it. libcurl will not convert or encode it for you. Most | ||||
| web servers will assume this data to be url-encoded. | ||||
| @@ -1045,7 +1272,7 @@ Pass a curl_off_t as parameter. Use this to set the size of the | ||||
| data to figure out the size. This is the large file version of the | ||||
| \fICURLOPT_POSTFIELDSIZE\fP option. (Added in 7.11.1) | ||||
| .IP CURLOPT_COPYPOSTFIELDS | ||||
| Pass a char * as parameter, which should be the full data to post in an HTTP | ||||
| Pass a char * as parameter, which should be the full data to post in a HTTP | ||||
| POST operation. It behaves as the \fICURLOPT_POSTFIELDS\fP option, but the | ||||
| original data are copied by the library, allowing the application to overwrite | ||||
| the original data after setting this option. | ||||
| @@ -1132,7 +1359,7 @@ option and thus you need to concatenate them all in one single string. Set | ||||
| multiple cookies in one string like this: "name1=content1; name2=content2;" | ||||
| etc. | ||||
|  | ||||
| This option sets the cookie header explictly in the outgoing request(s). If | ||||
| This option sets the cookie header explicitly in the outgoing request(s). If | ||||
| multiple requests are done due to authentication, followed redirections or | ||||
| similar, they will all get this cookie passed on. | ||||
|  | ||||
| @@ -1217,25 +1444,48 @@ transfer decoding will be disabled, if set to 1 it is enabled | ||||
| option is set to zero. (added in 7.16.2) | ||||
| .SH SMTP OPTIONS | ||||
| .IP CURLOPT_MAIL_FROM | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used to | ||||
| specify the sender address in a mail when sending an SMTP mail with libcurl. | ||||
| Pass a pointer to a zero terminated string as parameter. This should be used | ||||
| to specify the sender's email address when sending SMTP mail with libcurl. | ||||
|  | ||||
| An originator email address in SMTP lingo is specified within angle brackets | ||||
| (<>) which libcurl will not add for you before version 7.21.4. Failing to | ||||
| provide such brackets may cause the server to reject your mail. | ||||
| An originator email address should be specified with angled brackets (<>) | ||||
| around it, which if not specified, will be added by libcurl from version | ||||
| 7.21.4 onwards. Failing to provide such brackets may cause the server to | ||||
| reject the email. | ||||
|  | ||||
| If this parameter is not specified then an empty address will be sent to the | ||||
| mail server which may or may not cause the email to be rejected. | ||||
|  | ||||
| (Added in 7.20.0) | ||||
| .IP CURLOPT_MAIL_RCPT | ||||
| Pass a pointer to a linked list of recipients to pass to the server in your | ||||
| SMTP mail request.  The linked list should be a fully valid list of \fBstruct | ||||
| SMTP mail request. The linked list should be a fully valid list of \fBstruct | ||||
| curl_slist\fP structs properly filled in. Use \fIcurl_slist_append(3)\fP to | ||||
| create the list and \fIcurl_slist_free_all(3)\fP to clean up an entire list. | ||||
|  | ||||
| Each recipient in SMTP lingo is specified with angle brackets (<>), but should | ||||
| you not use an angle bracket as first letter libcurl will assume you provide a | ||||
| single email address only and enclose that with angle brackets for you. | ||||
| Each recipient should be specified within a pair of angled brackets (<>), | ||||
| however, should you not use an angled bracket as the first character libcurl | ||||
| will assume you provided a single email address and enclose that address | ||||
| within brackets for you. | ||||
|  | ||||
| (Added in 7.20.0) | ||||
| .IP CURLOPT_MAIL_AUTH | ||||
| Pass a pointer to a zero terminated string as parameter. This will be used | ||||
| to specify the authentication address (identity) of a submitted message that | ||||
| is being relayed to another server. | ||||
|  | ||||
| This optional parameter allows co-operating agents in a trusted environment to | ||||
| communicate the authentication of individual messages and should only be used | ||||
| by the application program, using libcurl, if the application is itself a | ||||
| mail server acting in such an environment. If the application is operating as | ||||
| such and the AUTH address is not known or is invalid, then an empty string | ||||
| should be used for this parameter. | ||||
|  | ||||
| Unlike CURLOPT_MAIL_FROM and CURLOPT_MAIL_RCPT, the address should not be | ||||
| specified within a pair of angled brackets (<>). However, if an empty string | ||||
| is used then a pair of brackets will be sent by libcurl as required by | ||||
| RFC-2554. | ||||
|  | ||||
| (Added in 7.24.0) | ||||
| .SH TFTP OPTIONS | ||||
| .IP CURLOPT_TFTP_BLKSIZE | ||||
| Specify block size to use for TFTP data transmission. Valid range as per RFC | ||||
| @@ -1273,18 +1523,22 @@ Examples with specified ports: | ||||
| You disable PORT again and go back to using the passive version by setting | ||||
| this option to NULL. | ||||
| .IP CURLOPT_QUOTE | ||||
| Pass a pointer to a linked list of FTP or SFTP commands to pass to | ||||
| the server prior to your FTP request. This will be done before any | ||||
| other commands are issued (even before the CWD command for FTP). The | ||||
| linked list should be a fully valid list of 'struct curl_slist' structs | ||||
| properly filled in with text strings. Use \fIcurl_slist_append(3)\fP | ||||
| to append strings (commands) to the list, and clear the entire list | ||||
| afterwards with \fIcurl_slist_free_all(3)\fP. Disable this operation | ||||
| again by setting a NULL to this option. | ||||
| The set of valid FTP commands depends on the server (see RFC959 for a | ||||
| list of mandatory commands). | ||||
| The valid SFTP commands are: chgrp, chmod, chown, ln, mkdir, pwd, | ||||
| rename, rm, rmdir, symlink (see | ||||
| Pass a pointer to a linked list of FTP or SFTP commands to pass to the server | ||||
| prior to your FTP request. This will be done before any other commands are | ||||
| issued (even before the CWD command for FTP). The linked list should be a | ||||
| fully valid list of 'struct curl_slist' structs properly filled in with text | ||||
| strings. Use \fIcurl_slist_append(3)\fP to append strings (commands) to the | ||||
| list, and clear the entire list afterwards with | ||||
| \fIcurl_slist_free_all(3)\fP. Disable this operation again by setting a NULL | ||||
| to this option. When speaking to a FTP (or SFTP since 7.24.0) server, prefix | ||||
| the command with an asterisk (*) to make libcurl continue even if the command | ||||
| fails as by default libcurl will stop at first failure. | ||||
|  | ||||
| The set of valid FTP commands depends on the server (see RFC959 for a list of | ||||
| mandatory commands). | ||||
|  | ||||
| The valid SFTP commands are: chgrp, chmod, chown, ln, mkdir, pwd, rename, rm, | ||||
| rmdir, symlink (see | ||||
| .BR curl (1)) | ||||
| (SFTP support added in 7.16.3) | ||||
| .IP CURLOPT_POSTQUOTE | ||||
| @@ -1298,7 +1552,7 @@ Pass a pointer to a linked list of FTP commands to pass to the server after | ||||
| the transfer type is set. The linked list should be a fully valid list of | ||||
| struct curl_slist structs properly filled in as described for | ||||
| \fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this | ||||
| option. Before version 7.15.6, if you also set \fICURLOPT_NOBODY\fP to 1, this | ||||
| option. Before version 7.16.0, if you also set \fICURLOPT_NOBODY\fP to 1, this | ||||
| option didn't work. | ||||
| .IP CURLOPT_DIRLISTONLY | ||||
| A parameter set to 1 tells the library to just list the names of files in a | ||||
| @@ -1411,7 +1665,7 @@ a reply. | ||||
| Initiate the shutdown and wait for a reply. | ||||
| .RE | ||||
| .IP CURLOPT_FTP_ACCOUNT | ||||
| Pass a pointer to a zero-terminated string (or NULL to disable). When an FTP | ||||
| Pass a pointer to a zero terminated string (or NULL to disable). When an FTP | ||||
| server asks for "account data" after user name and password has been provided, | ||||
| this data is sent off using the ACCT command. (Added in 7.13.0) | ||||
| .IP CURLOPT_FTP_FILEMETHOD | ||||
| @@ -1453,7 +1707,7 @@ needed for this method)\fP  (Added in 7.20.0) | ||||
| When sent by a client, this method changes the description of the session. For | ||||
| example, if a client is using the server to record a meeting, the client can | ||||
| use Announce to inform the server of all the meta-information about the | ||||
| session.  ANNOUNCE acts like an HTTP PUT or POST just like | ||||
| session.  ANNOUNCE acts like a HTTP PUT or POST just like | ||||
| \fICURL_RTSPREQ_SET_PARAMETER\fP (Added in 7.20.0) | ||||
| .IP CURL_RTSPREQ_SETUP | ||||
| Setup is used to initialize the transport layer for the session. The | ||||
| @@ -1476,7 +1730,7 @@ different connections.  (Added in 7.20.0) | ||||
| .IP CURL_RTSPREQ_GET_PARAMETER | ||||
| Retrieve a parameter from the server. By default, libcurl will automatically | ||||
| include a \fIContent-Type: text/parameters\fP header on all non-empty requests | ||||
| unless a custom one is set. GET_PARAMETER acts just like an HTTP PUT or POST | ||||
| unless a custom one is set. GET_PARAMETER acts just like a HTTP PUT or POST | ||||
| (see \fICURL_RTSPREQ_SET_PARAMETER\fP). | ||||
| Applications wishing to send a heartbeat message (e.g. in the presence of a | ||||
| server-specified timeout) should send use an empty GET_PARAMETER request. | ||||
| @@ -1484,9 +1738,9 @@ server-specified timeout) should send use an empty GET_PARAMETER request. | ||||
| .IP CURL_RTSPREQ_SET_PARAMETER | ||||
| Set a parameter on the server. By default, libcurl will automatically include | ||||
| a \fIContent-Type: text/parameters\fP header unless a custom one is set. The | ||||
| interaction with SET_PARAMTER is much like an HTTP PUT or POST. An application | ||||
| may either use \fICURLOPT_UPLOAD\fP with \fICURLOPT_READDATA\fP like an HTTP | ||||
| PUT, or it may use \fICURLOPT_POSTFIELDS\fP like an HTTP POST. No chunked | ||||
| interaction with SET_PARAMTER is much like a HTTP PUT or POST. An application | ||||
| may either use \fICURLOPT_UPLOAD\fP with \fICURLOPT_READDATA\fP like a HTTP | ||||
| PUT, or it may use \fICURLOPT_POSTFIELDS\fP like a HTTP POST. No chunked | ||||
| transfers are allowed, so the application must set the | ||||
| \fICURLOPT_INFILESIZE\fP in the former and \fICURLOPT_POSTFIELDSIZE\fP in the | ||||
| latter. Also, there is no use of multi-part POSTs within RTSP. (Added in | ||||
| @@ -1548,7 +1802,7 @@ over FTP. This is a known limitation/flaw that nobody has rectified. libcurl | ||||
| simply sets the mode to ASCII and performs a standard transfer. | ||||
| .IP CURLOPT_PROXY_TRANSFER_MODE | ||||
| Pass a long. If the value is set to 1 (one), it tells libcurl to set the | ||||
| transfer mode (binary or ASCII) for FTP transfers done via an HTTP proxy, by | ||||
| transfer mode (binary or ASCII) for FTP transfers done via a HTTP proxy, by | ||||
| appending ;type=a or ;type=i to the URL. Without this setting, or it being set | ||||
| to 0 (zero, the default), \fICURLOPT_TRANSFERTEXT\fP has no effect when doing | ||||
| FTP via a proxy. Beware that not all proxies support this feature.  (Added in | ||||
| @@ -1586,7 +1840,7 @@ Pass a curl_off_t as parameter. It contains the offset in number of bytes that | ||||
| you want the transfer to start from. (Added in 7.11.0) | ||||
| .IP CURLOPT_CUSTOMREQUEST | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used | ||||
| instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST | ||||
| instead of GET or HEAD when doing a HTTP request, or instead of LIST or NLST | ||||
| when doing a FTP directory listing. This is useful for doing DELETE or other | ||||
| more or less obscure HTTP requests. Don't do this at will, make sure your | ||||
| server supports the command first. | ||||
| @@ -1633,6 +1887,9 @@ as a long. See also \fICURLOPT_INFILESIZE_LARGE\fP. | ||||
| For uploading using SCP, this option or \fICURLOPT_INFILESIZE_LARGE\fP is | ||||
| mandatory. | ||||
|  | ||||
| When sending emails using SMTP, this command can be used to specify the | ||||
| optional SIZE parameter for the MAIL FROM command. (Added in 7.23.0) | ||||
|  | ||||
| This option does not limit how much data libcurl will actually send, as that | ||||
| is controlled entirely by what the read callback returns. | ||||
| .IP CURLOPT_INFILESIZE_LARGE | ||||
| @@ -1762,9 +2019,9 @@ re-use (default behavior). | ||||
| .IP CURLOPT_CONNECTTIMEOUT | ||||
| Pass a long. It should contain the maximum time in seconds that you allow the | ||||
| connection to the server to take.  This only limits the connection phase, once | ||||
| it has connected, this option is of no more use. Set to zero to disable | ||||
| connection timeout (it will then only timeout on the system's internal | ||||
| timeouts). See also the \fICURLOPT_TIMEOUT\fP option. | ||||
| it has connected, this option is of no more use. Set to zero to switch to the | ||||
| default built-in connection timeout - 300 seconds. See also the | ||||
| \fICURLOPT_TIMEOUT\fP option. | ||||
|  | ||||
| In unix-like systems, this might cause signals to be used unless | ||||
| \fICURLOPT_NOSIGNAL\fP is set. | ||||
| @@ -1836,6 +2093,24 @@ resolves, by including a string in the linked list that uses the format | ||||
| and port number must exactly match what was already added previously. | ||||
|  | ||||
| (Added in 7.21.3) | ||||
| .IP CURLOPT_DNS_SERVERS | ||||
| Set the list of DNS servers to be used instead of the system default. | ||||
| The format of the dns servers option is: | ||||
|  | ||||
| host[:port][,host[:port]]... | ||||
|  | ||||
| For example: | ||||
|  | ||||
| 192.168.1.100,192.168.1.101,3.4.5.6 | ||||
|  | ||||
| This option requires that libcurl was built with a resolver backend that | ||||
| supports this operation. The c-ares backend is the only such one. | ||||
|  | ||||
| (Added in 7.24.0) | ||||
| .IP CURLOPT_ACCEPTTIMEOUT_MS | ||||
| Pass a long telling libcurl the maximum number of milliseconds to wait for a | ||||
| server to connect back to libcurl when an active FTP connection is used. If no | ||||
| timeout is set, the internal default of 60000 will be used. (Added in 7.24.0) | ||||
| .SH SSL and SECURITY OPTIONS | ||||
| .IP CURLOPT_SSLCERT | ||||
| Pass a pointer to a zero terminated string as parameter. The string should be | ||||
| @@ -1908,7 +2183,7 @@ Pass a long as parameter. By default, curl assumes a value of 1. | ||||
| This option determines whether curl verifies the authenticity of the peer's | ||||
| certificate. A value of 1 means curl verifies; 0 (zero) means it doesn't. | ||||
|  | ||||
| When negotiating an SSL connection, the server sends a certificate indicating | ||||
| When negotiating a SSL connection, the server sends a certificate indicating | ||||
| its identity.  Curl verifies whether the certificate is authentic, i.e. that | ||||
| you can trust that the server is who the certificate says it is.  This trust | ||||
| is based on a chain of digital signatures, rooted in certification authority | ||||
| @@ -2057,6 +2332,16 @@ this to 1 to enable it. By default all transfers are done using the | ||||
| cache. While nothing ever should get hurt by attempting to reuse SSL | ||||
| session-IDs, there seem to be broken SSL implementations in the wild that may | ||||
| require you to disable this in order for you to succeed. (Added in 7.16.0) | ||||
| .IP CURLOPT_SSL_OPTIONS | ||||
| Pass a long with a bitmask to tell libcurl about specific SSL behaviors. | ||||
|  | ||||
| CURLSSLOPT_ALLOW_BEAST is the only supported bit and by setting this the user | ||||
| will tell libcurl to not attempt to use any work-arounds for a security flaw | ||||
| in the SSL3 and TLS1.0 protocols.  If this option isn't used or this bit is | ||||
| set to 0, the SSL layer libcurl uses may use a work-around for this flaw | ||||
| although it might cause interoperability problems with some (older) SSL | ||||
| implementations. WARNING: avoiding this work-around loosens the security, and | ||||
| by setting this option to 1 you ask for exactly that. (Added in 7.25.0) | ||||
| .IP CURLOPT_KRBLEVEL | ||||
| Pass a char * as parameter. Set the kerberos security level for FTP; this also | ||||
| enables kerberos awareness.  This is a string, \&'clear', \&'safe', | ||||
| @@ -2065,12 +2350,20 @@ of these, 'private' will be used. Set the string to NULL to disable kerberos | ||||
| support for FTP. | ||||
|  | ||||
| (This option was known as CURLOPT_KRB4LEVEL up to 7.16.3) | ||||
| .IP CURLOPT_GSSAPI_DELEGATION | ||||
| Set the parameter to CURLGSSAPI_DELEGATION_FLAG to allow unconditional GSSAPI | ||||
| credential delegation.  The delegation is disabled by default since 7.21.7. | ||||
| Set the parameter to CURLGSSAPI_DELEGATION_POLICY_FLAG to delegate only if | ||||
| the OK-AS-DELEGATE flag is set in the service ticket in case this feature is | ||||
| supported by the GSSAPI implementation and the definition of | ||||
| GSS_C_DELEG_POLICY_FLAG was available at compile-time. | ||||
| (Added in 7.22.0) | ||||
| .SH SSH OPTIONS | ||||
| .IP CURLOPT_SSH_AUTH_TYPES | ||||
| Pass a long set to a bitmask consisting of one or more of | ||||
| CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST, | ||||
| CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. | ||||
| (Added in 7.16.1) | ||||
| CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. Currently | ||||
| CURLSSH_AUTH_HOST has no effect. (Added in 7.16.1) | ||||
| .IP CURLOPT_SSH_HOST_PUBLIC_KEY_MD5 | ||||
| Pass a char * pointing to a string containing 32 hexadecimal digits. The | ||||
| string should be the 128 bit MD5 checksum of the remote host's public key, and | ||||
| @@ -2078,13 +2371,15 @@ libcurl will reject the connection to the host unless the md5sums match. This | ||||
| option is only for SCP and SFTP transfers. (Added in 7.17.1) | ||||
| .IP CURLOPT_SSH_PUBLIC_KEYFILE | ||||
| Pass a char * pointing to a file name for your public key. If not used, | ||||
| libcurl defaults to using \fB~/.ssh/id_dsa.pub\fP. | ||||
| (Added in 7.16.1) | ||||
| libcurl defaults to \fB$HOME/.ssh/id_dsa.pub\fP if the HOME environment | ||||
| variable is set, and just "id_dsa.pub" in the current directory if HOME is not | ||||
| set.  (Added in 7.16.1) | ||||
| .IP CURLOPT_SSH_PRIVATE_KEYFILE | ||||
| Pass a char * pointing to a file name for your private key. If not used, | ||||
| libcurl defaults to using \fB~/.ssh/id_dsa\fP.  If the file is | ||||
| password-protected, set the password with \fICURLOPT_KEYPASSWD\fP. (Added in | ||||
| 7.16.1) | ||||
| libcurl defaults to \fB$HOME/.ssh/id_dsa\fP if the HOME environment variable | ||||
| is set, and just "id_dsa" in the current directory if HOME is not set.  If the | ||||
| file is password-protected, set the password with | ||||
| \fICURLOPT_KEYPASSWD\fP. (Added in 7.16.1) | ||||
| .IP CURLOPT_SSH_KNOWNHOSTS | ||||
| Pass a pointer to a zero terminated string holding the file name of the | ||||
| known_host file to use.  The known_hosts file should use the OpenSSH file | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -23,9 +23,9 @@ | ||||
| .SH NAME | ||||
| curl_easy_strerror - return string describing error code | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <curl/curl.h> | ||||
| .BI "const char *curl_easy_strerror(CURLcode " errornum ");" | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| const char *curl_easy_strerror(CURLcode errornum); | ||||
| .SH DESCRIPTION | ||||
| The curl_easy_strerror() function returns a string describing the CURLcode | ||||
| error code passed in the argument \fIerrornum\fP. | ||||
|   | ||||
| @@ -30,18 +30,19 @@ curl_formadd - add a section to a multipart/formdata HTTP POST | ||||
| .ad | ||||
| .SH DESCRIPTION | ||||
| curl_formadd() is used to append sections when building a multipart/formdata | ||||
| HTTP POST (sometimes referred to as RFC2388-style posts). Append one section at | ||||
| a time until you've added all the sections you want included and then you pass | ||||
| 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. | ||||
| HTTP POST (sometimes referred to as RFC2388-style posts). Append one section | ||||
| at a time until you've added all the sections you want included and then you | ||||
| pass the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. | ||||
| \fIlastitem\fP is set after each \fIcurl_formadd(3)\fP 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 | ||||
| The pointers \fIfirstitem\fP and \fIlastitem\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(3)\fP after the form post | ||||
| has been done to free the resources. | ||||
| the function itself. You must call \fIcurl_formfree(3)\fP on the | ||||
| \fIfirstitem\P after the form post has been done to free the resources. | ||||
|  | ||||
| Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||
| You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | ||||
|   | ||||
| @@ -31,6 +31,13 @@ curl_formfree - free a previously build multipart/formdata HTTP POST chain | ||||
| curl_formfree() is used to clean up data previously built/appended with | ||||
| \fIcurl_formadd(3)\fP. This must be called when the data has been used, which | ||||
| typically means after \fIcurl_easy_perform(3)\fP has been called. | ||||
|  | ||||
| The pointer to free is the same pointer you passed to the | ||||
| \fBCURLOPT_HTTPPOST\fP option, which is the \fIfirstitem\fP pointer from the | ||||
| \fIcurl_formadd(3)\fP invoke(s). | ||||
|  | ||||
| \fBform\fP is the pointer as returned from a previous call to | ||||
| \fIcurl_formadd(3)\fP and may be NULL. | ||||
| .SH RETURN VALUE | ||||
| None | ||||
| .SH "SEE ALSO" | ||||
|   | ||||
| @@ -23,24 +23,27 @@ | ||||
| .SH NAME | ||||
| curl_formget - serialize a previously built multipart/formdata HTTP POST chain | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <curl/curl.h> | ||||
| .sp | ||||
| .BI "void curl_formget(struct curl_httppost *" form, " void *" arg, | ||||
| .BI " curl_formget_callback " append ");" | ||||
| .ad | ||||
|  | ||||
| void curl_formget(struct curl_httppost * form, void *userp, | ||||
|                   curl_formget_callback append ); | ||||
| .SH DESCRIPTION | ||||
| curl_formget() is used to serialize data previously built/appended with | ||||
| \fIcurl_formadd(3)\fP. Accepts a void pointer as second argument which will be | ||||
| passed to the curl_formget_callback function. | ||||
| \fIcurl_formadd(3)\fP. Accepts a void pointer as second argument named | ||||
| \fIuserp\fP which will be passed as the first argument to the | ||||
| curl_formget_callback function. | ||||
|  | ||||
| .BI "typedef size_t (*curl_formget_callback)(void *" arg, " const char *" buf, | ||||
| .BI "typedef size_t (*curl_formget_callback)(void *" userp, " const char *" buf, | ||||
| .BI " size_t " len ");" | ||||
| .nf | ||||
|  | ||||
| The curl_formget_callback will be executed for each part of the HTTP POST | ||||
| chain. The void *arg pointer will be the one passed as second argument to | ||||
| curl_formget(). The character buffer passed to it must not be freed. The | ||||
| chain. The character buffer passed to the callback must not be freed. The | ||||
| callback should return the buffer length passed to it on success. | ||||
|  | ||||
| If the \fBCURLFORM_STREAM\fP option is used in the formpost, it will prevent | ||||
| \fIcurl_formget(3)\fP from working until you've performed the actual HTTP | ||||
| request as only then will libcurl get the actual read callback to use! | ||||
| .SH RETURN VALUE | ||||
| 0 means everything was ok, non-zero means an error occurred | ||||
| .SH EXAMPLE | ||||
| @@ -52,6 +55,7 @@ callback should return the buffer length passed to it on success. | ||||
|    (*(size_t *) arg) += len; | ||||
|    return len; | ||||
|  } | ||||
|  | ||||
|  size_t print_httppost(struct curl_httppost *post) | ||||
|  { | ||||
|    size_t total_size = 0; | ||||
|   | ||||
| @@ -40,19 +40,28 @@ but be sure to FD_ZERO them before calling this function as | ||||
| otherwise remove any others. The \fIcurl_multi_perform(3)\fP function should be | ||||
| called as soon as one of them is ready to be read from or written to. | ||||
|  | ||||
| To be sure to have up-to-date results, you should call | ||||
| \fIcurl_multi_perform\fP until it does not return CURLM_CALL_MULTI_PERFORM | ||||
| prior to calling \fIcurl_multi_fdset\fP.  This will make sure that libcurl has | ||||
| updated the handles' socket states. | ||||
|  | ||||
| If no file descriptors are set by libcurl, \fImax_fd\fP will contain -1 when | ||||
| this function returns. Otherwise it will contain the higher descriptor number | ||||
| libcurl set. | ||||
| libcurl set. When libcurl returns -1 in \fImax_fd\fP, it is because libcurl | ||||
| currently does something that isn't possible for your application to monitor | ||||
| with a socket and unfortunately you can then not know exactly when the current | ||||
| action is completed using select(). When max_fd returns with -1, you need to | ||||
| wait a while and then proceed and call \fIcurl_multi_perform\fP anyway. How | ||||
| long to wait? I would suggest 100 milliseconds at least, but you may want to | ||||
| test it out in your own particular conditions to find a suitable value. | ||||
|  | ||||
| When doing select(), you should use \fBcurl_multi_timeout\fP to figure out how | ||||
| long to wait for action. Call \fIcurl_multi_perform\fP even if no activity has | ||||
| been seen on the fd_sets after the timeout expires as otherwise internal | ||||
| retries and timeouts may not work as you'd think and want. | ||||
|  | ||||
| If one of the sockets used by libcurl happens to be larger than what can be | ||||
| set in an fd_set, which on POSIX systems means that the file descriptor is | ||||
| larger than FD_SETSIZE, then libcurl will try to not set it. Setting a too | ||||
| large file descriptor in an fd_set implies an out of bounds write which can | ||||
| cause crashes, or worse. The effect of NOT storing it will possibly save you | ||||
| from the crash, but will make your program NOT wait for sockets it should wait | ||||
| for... | ||||
| .SH RETURN VALUE | ||||
| CURLMcode type, general libcurl multi interface error code. See | ||||
| \fIlibcurl-errors(3)\fP | ||||
|   | ||||
| @@ -64,6 +64,11 @@ Cached DNS hosts will be shared across the easy handles using this shared | ||||
| object. Note that when you use the multi interface, all easy handles added to | ||||
| the same multi handle will share DNS cache by default without this having to | ||||
| be used! | ||||
| .IP CURL_LOCK_DATA_SSL_SESSION | ||||
| SSL session IDs will be shared accross the easy handles using this shared | ||||
| object. This will reduce the time spent in the SSL handshake when reconnecting | ||||
| to the same server. Note SSL session IDs are reused within the same easy handle | ||||
| by default. | ||||
| .RE | ||||
| .IP CURLSHOPT_UNSHARE | ||||
| This option does the opposite of \fICURLSHOPT_SHARE\fP. It specifies that | ||||
|   | ||||
| @@ -128,6 +128,11 @@ the app having to pass them on. (Added in 7.13.2) | ||||
| .IP CURL_VERSION_CONV | ||||
| libcurl was built with support for character conversions, as provided by the | ||||
| CURLOPT_CONV_* callbacks. (Added in 7.15.4) | ||||
| .IP CURL_VERSION_TLSAUTH_SRP | ||||
| libcurl was built with support for TLS-SRP. (Added in 7.21.4) | ||||
| .IP CURL_VERSION_NTLM_WB | ||||
| libcurl was built with support for NTLM delegation to a winbind helper. | ||||
| (Added in 7.22.0) | ||||
| .RE | ||||
| \fIssl_version\fP is an ASCII string for the OpenSSL version used. If libcurl | ||||
| has no SSL support, this is NULL. | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -66,20 +66,21 @@ remote server is probably not an OK FTP server. | ||||
| .IP "CURLE_REMOTE_ACCESS_DENIED (9)" | ||||
| We were denied access to the resource given in the URL.  For FTP, this occurs | ||||
| while trying to change to the remote directory. | ||||
| .IP "CURLE_FTP_ACCEPT_FAILED (10)" | ||||
| While waiting for the server to connect back when an active FTP session is | ||||
| used, an error code was sent over the control connection or similar. | ||||
| .IP "CURLE_FTP_WEIRD_PASS_REPLY (11)" | ||||
| After having sent the FTP password to the server, libcurl expects a proper | ||||
| reply. This error code indicates that an unexpected code was returned. | ||||
| .IP "CURLE_FTP_ACCEPT_TIMEOUT (12)" | ||||
| During an active FTP session while waiting for the server to connect, the | ||||
| \fICURLOPT_ACCEPTTIMOUT_MS\fP (or the internal default) timeout expired. | ||||
| .IP "CURLE_FTP_WEIRD_PASV_REPLY (13)" | ||||
| libcurl failed to get a sensible result back from the server as a response to | ||||
| either a PASV or a EPSV command. The server is flawed. | ||||
| .IP "CURLE_FTP_WEIRD_227_FORMAT (14)" | ||||
| FTP servers return a 227-line as a response to a PASV command. If libcurl | ||||
| fails to parse that line, this return code is passed back. | ||||
| .IP "CURLE_FTP_PRET_FAILED (84)" | ||||
| The FTP server does not understand the PRET command at all or does not support | ||||
| the given argument. Be careful when using \fICURLOPT_CUSTOMREQUEST\fP, a | ||||
| custom LIST command will be sent with PRET CMD before PASV as well. (Added in | ||||
| 7.20.0) | ||||
| .IP "CURLE_FTP_CANT_GET_HOST (15)" | ||||
| An internal failure to lookup the host used for the new connection. | ||||
| .IP "CURLE_FTP_COULDNT_SET_TYPE (17)" | ||||
| @@ -227,7 +228,10 @@ Failed to load CRL file (Added in 7.19.0) | ||||
| .IP "CURLE_SSL_ISSUER_ERROR (83)" | ||||
| Issuer check failed (Added in 7.19.0) | ||||
| .IP "CURLE_FTP_PRET_FAILED (84)" | ||||
| PRET command failed | ||||
| The FTP server does not understand the PRET command at all or does not support | ||||
| the given argument. Be careful when using \fICURLOPT_CUSTOMREQUEST\fP, a | ||||
| custom LIST command will be sent with PRET CMD before PASV as well. (Added in | ||||
| 7.20.0) | ||||
| .IP "CURLE_RTSP_CSEQ_ERROR (85)" | ||||
| Mismatch of RTSP CSeq numbers. | ||||
| .IP "CURLE_RTSP_SESSION_ERROR (86)" | ||||
| @@ -277,3 +281,6 @@ An invalid share object was passed to the function. | ||||
| .IP "CURLSHE_NOMEM (4)" | ||||
| Not enough memory was available. | ||||
| (Added in 7.12.0) | ||||
| .IP "CURLSHE_NOT_BUILT_IN (5)" | ||||
| The requsted sharing could not be done because the library you use don't have | ||||
| that particular feature enabled. (Added in 7.23.0) | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -82,14 +82,6 @@ might need attention. This also makes it very easy for your program to wait | ||||
| for input on your own private file descriptors at the same time or perhaps | ||||
| timeout every now and then, should you want that. | ||||
|  | ||||
| A little note here about the return codes from the multi functions, and | ||||
| especially the \fIcurl_multi_perform(3)\fP: if you receive | ||||
| \fICURLM_CALL_MULTI_PERFORM\fP, this basically means that you should call | ||||
| \fIcurl_multi_perform(3)\fP again, before you select() on more actions. You | ||||
| don't have to do it immediately, but the return code means that libcurl may | ||||
| have more data available to return or that there may be more data to send off | ||||
| before it is "satisfied". | ||||
|  | ||||
| \fIcurl_multi_perform(3)\fP stores the number of still running transfers in | ||||
| one of its input arguments, and by reading that you can figure out when all | ||||
| the transfers in the multi handles are done. 'done' does not mean | ||||
| @@ -118,23 +110,40 @@ If you want to re-use an easy handle that was added to the multi handle for | ||||
| transfer, you must first remove it from the multi stack and then re-add it | ||||
| again (possibly after having altered some options at your own choice). | ||||
| .SH "MULTI_SOCKET" | ||||
| Since 7.16.0, the \fIcurl_multi_socket_action(3)\fP function offers a way for | ||||
| applications to not only avoid being forced to use select(), but it also | ||||
| offers a much more high-performance API that will make a significant | ||||
| difference for applications using large numbers of simultaneous connections. | ||||
| \fIcurl_multi_socket_action(3)\fP function offers a way for applications to | ||||
| not only avoid being forced to use select(), but it also offers a much more | ||||
| high-performance API that will make a significant difference for applications | ||||
| using large numbers of simultaneous connections. | ||||
|  | ||||
| \fIcurl_multi_socket_action(3)\fP is then used | ||||
| instead of \fIcurl_multi_perform(3)\fP. | ||||
| \fIcurl_multi_socket_action(3)\fP is then used instead of | ||||
| \fIcurl_multi_perform(3)\fP. | ||||
|  | ||||
| When using this API, you add easy handles to the multi handle just as with the | ||||
| normal multi interface. Then you also set two callbacks with the | ||||
| CURLMOPT_SOCKETFUNCTION and CURLMOPT_TIMERFUNCTION options to | ||||
| \fIcurl_multi_setopt(3)\fP. | ||||
|  | ||||
| The API is then designed to inform your application about which sockets | ||||
| libcurl is currently using and for what activities (read and/or write) on | ||||
| those sockets your application is expected to wait for. | ||||
|  | ||||
| Your application must then make sure to receive all sockets informed about in | ||||
| the CURLMOPT_SOCKETFUNCTION callback and make sure it reacts on the given | ||||
| activity on them. When a socket has the given activity, you call | ||||
| \fIcurl_multi_socket_action(3)\fP specifying which socket and action there | ||||
| are. | ||||
|  | ||||
| The CURLMOPT_TIMERFUNCTION callback is called to set a timeout. When that | ||||
| timeout expires, your application should call the | ||||
| \fIcurl_multi_socket_action(3)\fP function saying it was due to a timeout. | ||||
| .SH "BLOCKING" | ||||
| A few areas in the code are still using blocking code, even when used from the | ||||
| multi interface. While we certainly want and intend for these to get fixed in | ||||
| the future, you should be aware of the following current restrictions: | ||||
|  | ||||
| .nf | ||||
|  - Name resolves on non-windows unless c-ares is used | ||||
|  - GnuTLS SSL connections | ||||
|  - Name resolves unless the c-ares or threaded-resolver backends are used | ||||
|  - NSS SSL connections | ||||
|  - Active FTP connections | ||||
|  - HTTP proxy CONNECT operations | ||||
|  - SOCKS proxy handshakes | ||||
|  - file:// transfers | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -249,9 +249,11 @@ complication for you. Given simply the URL to a file, libcurl will take care | ||||
| of all the details needed to get the file moved from one machine to another. | ||||
|  | ||||
| .SH "Multi-threading Issues" | ||||
| The first basic rule is that you must \fBnever\fP share a libcurl handle (be | ||||
| it easy or multi or whatever) between multiple threads. Only use one handle in | ||||
| one thread at a time. | ||||
| The first basic rule is that you must \fBnever\fP simultaneously share a | ||||
| libcurl handle (be it easy or multi or whatever) between multiple | ||||
| threads. Only use one handle in one thread at any time. You can pass the | ||||
| handles around among threads, but you must never use a single handle from more | ||||
| than one thread at any given time. | ||||
|  | ||||
| libcurl is completely thread safe, except for two issues: signals and SSL/TLS | ||||
| handlers. Signals are used for timing out name resolves (during DNS lookup) - | ||||
| @@ -815,10 +817,6 @@ 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. | ||||
|  | ||||
| .IP "Pragma" | ||||
| \&"no-cache". Tells a possible proxy to not grab a copy from the cache but to | ||||
| fetch a fresh one. | ||||
|  | ||||
| .IP "Accept" | ||||
| \&"*/*". | ||||
|  | ||||
| @@ -1301,9 +1299,7 @@ ones at any time), you start the transfers by calling | ||||
|  | ||||
| \fIcurl_multi_perform(3)\fP is asynchronous. It will only execute as little as | ||||
| possible and then return back control to your program. It is designed to never | ||||
| block. If it returns CURLM_CALL_MULTI_PERFORM you better call it again soon, | ||||
| as that is a signal that it still has local data to send or remote data to | ||||
| receive. | ||||
| block. | ||||
|  | ||||
| The best usage of this interface is when you do a select() on all possible | ||||
| file descriptors or sockets to know when to call libcurl again. This also | ||||
| @@ -1339,9 +1335,21 @@ to figure out success on each individual transfer. | ||||
|  [ seeding, passwords, keys, certificates, ENGINE, ca certs ] | ||||
|  | ||||
| .SH "Sharing Data Between Easy Handles" | ||||
| You can share some data between easy handles when the easy interface is used, | ||||
| and some data is share automatically when you use the multi interface. | ||||
|  | ||||
|  [ fill in ] | ||||
| When you add easy handles to a multi handle, these easy handles will | ||||
| automatically share a lot of the data that otherwise would be kept on a | ||||
| per-easy handle basis when the easy interface is used. | ||||
|  | ||||
| The DNS cache is shared between handles within a multi handle, making | ||||
| subsequent name resolvings faster and the connection pool that is kept to | ||||
| better allow persistent connections and connection re-use is shared. If you're | ||||
| using the easy interface, you can still share these between specific easy | ||||
| handles by using the share interface, see \fIlibcurl-share(3)\fP. | ||||
|  | ||||
| Some things are never shared automatically, not within multi handles, like for | ||||
| example cookies so the only way to share that is with the share interface. | ||||
| .SH "Footnotes" | ||||
|  | ||||
| .IP "[1]" | ||||
|   | ||||
| @@ -146,7 +146,7 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG], | ||||
|            _libcurl_save_libs=$LIBS | ||||
|            LIBS="$LIBCURL $LIBS" | ||||
|  | ||||
|            AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <curl/curl.h>],[ | ||||
|            AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <curl/curl.h>]],[[ | ||||
| /* Try and use a few common options to force a failure if we are | ||||
|    missing symbols or can't link. */ | ||||
| int x; | ||||
| @@ -157,7 +157,8 @@ x=CURLOPT_FILE; | ||||
| x=CURLOPT_ERRORBUFFER; | ||||
| x=CURLOPT_STDERR; | ||||
| x=CURLOPT_VERBOSE; | ||||
| ])],libcurl_cv_lib_curl_usable=yes,libcurl_cv_lib_curl_usable=no) | ||||
| if (x) ; | ||||
| ]])],libcurl_cv_lib_curl_usable=yes,libcurl_cv_lib_curl_usable=no) | ||||
|  | ||||
|            CPPFLAGS=$_libcurl_save_cppflags | ||||
|            LIBS=$_libcurl_save_libs | ||||
|   | ||||
| @@ -20,6 +20,7 @@ CURLAUTH_DIGEST_IE              7.19.3 | ||||
| CURLAUTH_GSSNEGOTIATE           7.10.6 | ||||
| CURLAUTH_NONE                   7.10.6 | ||||
| CURLAUTH_NTLM                   7.10.6 | ||||
| CURLAUTH_NTLM_WB                7.22.0 | ||||
| CURLAUTH_ONLY                   7.21.3 | ||||
| CURLCLOSEPOLICY_CALLBACK        7.7 | ||||
| CURLCLOSEPOLICY_LEAST_RECENTLY_USED 7.7 | ||||
| @@ -44,6 +45,8 @@ CURLE_COULDNT_RESOLVE_PROXY     7.1 | ||||
| CURLE_FAILED_INIT               7.1 | ||||
| CURLE_FILESIZE_EXCEEDED         7.10.8 | ||||
| CURLE_FILE_COULDNT_READ_FILE    7.1 | ||||
| CURLE_FTP_ACCEPT_FAILED         7.24.0 | ||||
| CURLE_FTP_ACCEPT_TIMEOUT        7.24.0 | ||||
| CURLE_FTP_ACCESS_DENIED         7.1 | ||||
| CURLE_FTP_BAD_DOWNLOAD_RESUME   7.1           7.1 | ||||
| CURLE_FTP_BAD_FILE_LIST         7.21.0 | ||||
| @@ -186,6 +189,9 @@ CURLFTPSSL_TRY                  7.11.0        7.17.0 | ||||
| CURLFTP_CREATE_DIR              7.19.4 | ||||
| CURLFTP_CREATE_DIR_NONE         7.19.4 | ||||
| CURLFTP_CREATE_DIR_RETRY        7.19.4 | ||||
| CURLGSSAPI_DELEGATION_FLAG      7.22.0 | ||||
| CURLGSSAPI_DELEGATION_NONE      7.22.0 | ||||
| CURLGSSAPI_DELEGATION_POLICY_FLAG 7.22.0 | ||||
| CURLINFO_APPCONNECT_TIME        7.19.0 | ||||
| CURLINFO_CERTINFO               7.19.1 | ||||
| CURLINFO_CONDITION_UNMET        7.19.4 | ||||
| @@ -282,6 +288,8 @@ CURLOPTTYPE_FUNCTIONPOINT       7.1 | ||||
| CURLOPTTYPE_LONG                7.1 | ||||
| CURLOPTTYPE_OBJECTPOINT         7.1 | ||||
| CURLOPTTYPE_OFF_T               7.11.0 | ||||
| CURLOPT_ACCEPTTIMEOUT_MS        7.24.0 | ||||
| CURLOPT_ACCEPT_ENCODING         7.21.6 | ||||
| CURLOPT_ADDRESS_SCOPE           7.19.0 | ||||
| CURLOPT_APPEND                  7.17.0 | ||||
| CURLOPT_AUTOREFERER             7.1 | ||||
| @@ -294,6 +302,8 @@ CURLOPT_CHUNK_DATA              7.21.0 | ||||
| CURLOPT_CHUNK_END_FUNCTION      7.21.0 | ||||
| CURLOPT_CLOSEFUNCTION           7.7           7.11.1      7.15.5 | ||||
| CURLOPT_CLOSEPOLICY             7.7           7.16.1 | ||||
| CURLOPT_CLOSESOCKETDATA         7.21.7 | ||||
| CURLOPT_CLOSESOCKETFUNCTION     7.21.7 | ||||
| CURLOPT_CONNECTTIMEOUT          7.7 | ||||
| CURLOPT_CONNECTTIMEOUT_MS       7.16.2 | ||||
| CURLOPT_CONNECT_ONLY            7.15.2 | ||||
| @@ -313,6 +323,7 @@ CURLOPT_DEBUGDATA               7.9.6 | ||||
| CURLOPT_DEBUGFUNCTION           7.9.6 | ||||
| CURLOPT_DIRLISTONLY             7.17.0 | ||||
| CURLOPT_DNS_CACHE_TIMEOUT       7.9.3 | ||||
| CURLOPT_DNS_SERVERS             7.24.0 | ||||
| CURLOPT_DNS_USE_GLOBAL_CACHE    7.9.3         7.11.1 | ||||
| CURLOPT_EGDSOCKET               7.7 | ||||
| CURLOPT_ENCODING                7.10 | ||||
| @@ -341,6 +352,7 @@ CURLOPT_FTP_SSL_CCC             7.16.1 | ||||
| CURLOPT_FTP_USE_EPRT            7.10.5 | ||||
| CURLOPT_FTP_USE_EPSV            7.9.2 | ||||
| CURLOPT_FTP_USE_PRET            7.20.0 | ||||
| CURLOPT_GSSAPI_DELEGATION       7.22.0 | ||||
| CURLOPT_HEADER                  7.1 | ||||
| CURLOPT_HEADERDATA              7.10 | ||||
| CURLOPT_HEADERFUNCTION          7.7.2 | ||||
| @@ -372,6 +384,7 @@ CURLOPT_LOCALPORT               7.15.2 | ||||
| CURLOPT_LOCALPORTRANGE          7.15.2 | ||||
| CURLOPT_LOW_SPEED_LIMIT         7.1 | ||||
| CURLOPT_LOW_SPEED_TIME          7.1 | ||||
| CURLOPT_MAIL_AUTH               7.25.0 | ||||
| CURLOPT_MAIL_FROM               7.20.0 | ||||
| CURLOPT_MAIL_RCPT               7.20.0 | ||||
| CURLOPT_MAXCONNECTS             7.7 | ||||
| @@ -395,7 +408,7 @@ CURLOPT_OPENSOCKETFUNCTION      7.17.1 | ||||
| CURLOPT_PASSWDDATA              7.4.2         7.11.1      7.15.5 | ||||
| CURLOPT_PASSWDFUNCTION          7.4.2         7.11.1      7.15.5 | ||||
| CURLOPT_PASSWORD                7.19.1 | ||||
| CURLOPT_PASV_HOST               7.12.1        7.15.6      7.15.5 | ||||
| CURLOPT_PASV_HOST               7.12.1        7.16.0      7.15.5 | ||||
| CURLOPT_PORT                    7.1 | ||||
| CURLOPT_POST                    7.1 | ||||
| CURLOPT_POST301                 7.17.1        7.19.1 | ||||
| @@ -470,10 +483,14 @@ CURLOPT_SSLVERSION              7.1 | ||||
| CURLOPT_SSL_CIPHER_LIST         7.9 | ||||
| CURLOPT_SSL_CTX_DATA            7.10.6 | ||||
| CURLOPT_SSL_CTX_FUNCTION        7.10.6 | ||||
| CURLOPT_SSL_OPTIONS             7.25.0 | ||||
| CURLOPT_SSL_SESSIONID_CACHE     7.16.0 | ||||
| CURLOPT_SSL_VERIFYHOST          7.8.1 | ||||
| CURLOPT_SSL_VERIFYPEER          7.4.2 | ||||
| CURLOPT_STDERR                  7.1 | ||||
| CURLOPT_TCP_KEEPALIVE           7.25.0 | ||||
| CURLOPT_TCP_KEEPIDLE            7.25.0 | ||||
| CURLOPT_TCP_KEEPINTVL           7.25.0 | ||||
| CURLOPT_TCP_NODELAY             7.11.2 | ||||
| CURLOPT_TELNETOPTIONS           7.7 | ||||
| CURLOPT_TFTP_BLKSIZE            7.19.4 | ||||
| @@ -485,6 +502,7 @@ CURLOPT_TLSAUTH_PASSWORD        7.21.4 | ||||
| CURLOPT_TLSAUTH_TYPE            7.21.4 | ||||
| CURLOPT_TLSAUTH_USERNAME        7.21.4 | ||||
| CURLOPT_TRANSFERTEXT            7.1.1 | ||||
| CURLOPT_TRANSFER_ENCODING       7.21.6 | ||||
| CURLOPT_UNRESTRICTED_AUTH       7.10.4 | ||||
| CURLOPT_UPLOAD                  7.1 | ||||
| CURLOPT_URL                     7.1 | ||||
| @@ -541,6 +559,7 @@ CURLSHE_BAD_OPTION              7.10.3 | ||||
| CURLSHE_INVALID                 7.10.3 | ||||
| CURLSHE_IN_USE                  7.10.3 | ||||
| CURLSHE_NOMEM                   7.12.0 | ||||
| CURLSHE_NOT_BUILT_IN            7.23.0 | ||||
| CURLSHE_OK                      7.10.3 | ||||
| CURLSHOPT_LOCKFUNC              7.10.3 | ||||
| CURLSHOPT_NONE                  7.10.3 | ||||
| @@ -548,7 +567,7 @@ CURLSHOPT_SHARE                 7.10.3 | ||||
| CURLSHOPT_UNLOCKFUNC            7.10.3 | ||||
| CURLSHOPT_UNSHARE               7.10.3 | ||||
| CURLSHOPT_USERDATA              7.10.3 | ||||
| CURLSOCKTYPE_IPCXN              7.15.6 | ||||
| CURLSOCKTYPE_IPCXN              7.16.0 | ||||
| CURLSSH_AUTH_ANY                7.16.1 | ||||
| CURLSSH_AUTH_DEFAULT            7.16.1 | ||||
| CURLSSH_AUTH_HOST               7.16.1 | ||||
| @@ -556,6 +575,7 @@ CURLSSH_AUTH_KEYBOARD           7.16.1 | ||||
| CURLSSH_AUTH_NONE               7.16.1 | ||||
| CURLSSH_AUTH_PASSWORD           7.16.1 | ||||
| CURLSSH_AUTH_PUBLICKEY          7.16.1 | ||||
| CURLSSLOPT_ALLOW_BEAST          7.25.0 | ||||
| CURLUSESSL_ALL                  7.17.0 | ||||
| CURLUSESSL_CONTROL              7.17.0 | ||||
| CURLUSESSL_NONE                 7.17.0 | ||||
| @@ -671,6 +691,7 @@ CURL_VERSION_KERBEROS4          7.10 | ||||
| CURL_VERSION_LARGEFILE          7.11.1 | ||||
| CURL_VERSION_LIBZ               7.10 | ||||
| CURL_VERSION_NTLM               7.10.6 | ||||
| CURL_VERSION_NTLM_WB            7.22.0 | ||||
| CURL_VERSION_SPNEGO             7.10.8 | ||||
| CURL_VERSION_SSL                7.10 | ||||
| CURL_VERSION_SSPI               7.13.2 | ||||
|   | ||||
							
								
								
									
										100
									
								
								docs/libcurl/symbols.pl
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										100
									
								
								docs/libcurl/symbols.pl
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| #!/usr/bin/perl | ||||
| #*************************************************************************** | ||||
| #                                  _   _ ____  _ | ||||
| #  Project                     ___| | | |  _ \| | | ||||
| #                             / __| | | | |_) | | | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # | ||||
| # This software is licensed as described in the file COPYING, which | ||||
| # you should have received as part of this distribution. The terms | ||||
| # are also available at http://curl.haxx.se/docs/copyright.html. | ||||
| # | ||||
| # 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 COPYING file. | ||||
| # | ||||
| # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
| # KIND, either express or implied. | ||||
| # | ||||
| ########################################################################### | ||||
| # | ||||
| # Experience has shown that the symbols-in-versions file is very useful to | ||||
| # applications that want to build with a wide range of libcurl versions. | ||||
| # It is however easy to get it wrong and the source gets a bit messy with all | ||||
| # the fixed numerical comparisions. | ||||
| # | ||||
| # The point of this script is to provide an easy-to-use macro for libcurl- | ||||
| # using applications to do preprocessor checks for specific libcurl defines, | ||||
| # and yet make the code clearly show what the macro is used for. | ||||
| # | ||||
| # Run this script and generate libcurl-symbols.h and then use that header in | ||||
| # a fashion similar to: | ||||
| # | ||||
| # #include "libcurl-symbols.h" | ||||
| # | ||||
| # #if LIBCURL_HAS(CURLOPT_MUTE) | ||||
| #   has mute | ||||
| # #else | ||||
| #   no mute | ||||
| # #endif | ||||
| # | ||||
| # | ||||
| open F, "<symbols-in-versions"; | ||||
|  | ||||
| sub str2num { | ||||
|     my ($str)=@_; | ||||
|     if($str =~ /([0-9]*)\.([0-9]*)\.*([0-9]*)/) { | ||||
|         return sprintf("0x%06x", $1<<16 | $2 << 8 | $3); | ||||
|     } | ||||
| } | ||||
|  | ||||
| print <<EOS | ||||
|  | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| #define LIBCURL_HAS(x) \\ | ||||
|   (defined(x ## _FIRST) && (x ## _FIRST <= LIBCURL_VERSION_NUM) && \\ | ||||
|    (!defined(x ## _LAST) || ( x ## _LAST >= LIBCURL_VERSION_NUM))) | ||||
|  | ||||
| EOS | ||||
|     ; | ||||
|  | ||||
| while(<F>) { | ||||
|     if(/^(CURL[^ ]*)[ \t]*(.*)/) { | ||||
|         my ($sym, $vers)=($1, $2); | ||||
|  | ||||
|         my $intr; | ||||
|         my $rm; | ||||
|         my $dep; | ||||
|  | ||||
|         # is there removed info? | ||||
|         if($vers =~ /([\d.]+)[ \t-]+([\d.]+)[ \t]+([\d.]+)/) { | ||||
|             ($intr, $dep, $rm)=($1, $2, $3); | ||||
|         } | ||||
|         # is it a dep-only line? | ||||
|         elsif($vers =~ /([\d.]+)[ \t-]+([\d.]+)/) { | ||||
|             ($intr, $dep)=($1, $2); | ||||
|         } | ||||
|         else { | ||||
|             $intr = $vers; | ||||
|         } | ||||
|  | ||||
|         my $inum = str2num($intr); | ||||
|  | ||||
|         print <<EOS | ||||
| #define ${sym}_FIRST $inum /* Added in $intr */ | ||||
| EOS | ||||
| ; | ||||
|         my $irm = str2num($rm); | ||||
|         if($rm) { | ||||
|         print <<EOS | ||||
| #define ${sym}_LAST $irm /* Last featured in $rm */ | ||||
| EOS | ||||
| ; | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -36,7 +36,7 @@ The following notes apply to libcurl version 7.19.0 and later. | ||||
| * If you intend to distribute an already compiled libcurl library you _MUST_ | ||||
|   also distribute along with it the generated curl/curlbuild.h which has been | ||||
|   used to compile it. Otherwise the library will be of no use for the users of | ||||
|   the library that you have built. It is _your_ responsability to provide this | ||||
|   the library that you have built. It is _your_ responsibility to provide this | ||||
|   file. No one at the cURL project can know how you have built the library. | ||||
|  | ||||
| * File curl/curlbuild.h includes platform and configuration dependent info, | ||||
|   | ||||
| @@ -20,7 +20,7 @@ | ||||
| # | ||||
| ########################################################################### | ||||
| pkginclude_HEADERS = \ | ||||
| 	curl.h curlver.h easy.h mprintf.h stdcheaders.h types.h multi.h \ | ||||
| 	curl.h curlver.h easy.h mprintf.h stdcheaders.h multi.h \ | ||||
| 	typecheck-gcc.h curlbuild.h curlrules.h | ||||
|  | ||||
| pkgincludedir= $(includedir)/curl | ||||
| @@ -44,3 +44,10 @@ EXTRA_DIST = curlbuild.h.in | ||||
|  | ||||
| DISTCLEANFILES = curlbuild.h | ||||
|  | ||||
| checksrc: | ||||
| 	@@PERL@ $(top_srcdir)/lib/checksrc.pl -Wcurlbuild.h -D$(top_srcdir)/include/curl $(pkginclude_HEADERS) $(EXTRA_DIST) | ||||
|  | ||||
| if CURLDEBUG | ||||
| # for debug builds, we scan the sources on all regular make invokes | ||||
| all-local: checksrc | ||||
| endif | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -55,34 +55,32 @@ | ||||
| #include <sys/types.h> | ||||
| #include <time.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) && \ | ||||
|   !defined(__CYGWIN__) || defined(__MINGW32__) | ||||
| #if !(defined(_WINSOCKAPI_) || defined(_WINSOCK_H)) | ||||
| #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__CYGWIN__) | ||||
| #if !(defined(_WINSOCKAPI_) || defined(_WINSOCK_H) || defined(__LWIP_OPT_H__)) | ||||
| /* The check above prevents the winsock2 inclusion if winsock.h already was | ||||
|    included, since they can't co-exist without problems */ | ||||
| #include <winsock2.h> | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #else | ||||
| #endif | ||||
|  | ||||
| /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish | ||||
|    libc5-based Linux systems. Only include it on system that are known to | ||||
|    libc5-based Linux systems. Only include it on systems that are known to | ||||
|    require it! */ | ||||
| #if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \ | ||||
|     defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \ | ||||
|     defined(ANDROID) || \ | ||||
|     defined(ANDROID) || defined(__ANDROID__) || \ | ||||
|    (defined(__FreeBSD_version) && (__FreeBSD_version < 800000)) | ||||
| #include <sys/select.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef _WIN32_WCE | ||||
| #if !defined(WIN32) && !defined(_WIN32_WCE) | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
|  | ||||
| #if !defined(WIN32) && !defined(__WATCOMC__) && !defined(__VXWORKS__) | ||||
| #include <sys/time.h> | ||||
| #endif | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef __BEOS__ | ||||
| #include <support/SupportDefs.h> | ||||
| @@ -122,7 +120,7 @@ typedef void CURL; | ||||
|  | ||||
| #ifndef curl_socket_typedef | ||||
| /* socket typedef */ | ||||
| #ifdef WIN32 | ||||
| #if defined(WIN32) && !defined(__LWIP_OPT_H__) | ||||
| typedef SOCKET curl_socket_t; | ||||
| #define CURL_SOCKET_BAD INVALID_SOCKET | ||||
| #else | ||||
| @@ -189,10 +187,10 @@ typedef int (*curl_progress_callback)(void *clientp, | ||||
| #define CURL_MAX_HTTP_HEADER (100*1024) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* This is a magic return code for the write callback that, when returned, | ||||
|    will signal libcurl to pause receiving on the current transfer. */ | ||||
| #define CURL_WRITEFUNC_PAUSE 0x10000001 | ||||
|  | ||||
| typedef size_t (*curl_write_callback)(char *buffer, | ||||
|                                       size_t size, | ||||
|                                       size_t nitems, | ||||
| @@ -341,6 +339,9 @@ typedef curl_socket_t | ||||
|                             curlsocktype purpose, | ||||
|                             struct curl_sockaddr *address); | ||||
|  | ||||
| typedef int | ||||
| (*curl_closesocket_callback)(void *clientp, curl_socket_t item); | ||||
|  | ||||
| typedef enum { | ||||
|   CURLIOE_OK,            /* I/O operation successful */ | ||||
|   CURLIOE_UNKNOWNCMD,    /* command was unknown to callback */ | ||||
| @@ -410,9 +411,12 @@ typedef enum { | ||||
|   CURLE_REMOTE_ACCESS_DENIED,    /* 9 a service was denied by the server | ||||
|                                     due to lack of access - when login fails | ||||
|                                     this is not returned. */ | ||||
|   CURLE_OBSOLETE10,              /* 10 - NOT USED */ | ||||
|   CURLE_FTP_ACCEPT_FAILED,       /* 10 - [was obsoleted in April 2006 for | ||||
|                                     7.15.4, reused in Dec 2011 for 7.24.0]*/ | ||||
|   CURLE_FTP_WEIRD_PASS_REPLY,    /* 11 */ | ||||
|   CURLE_OBSOLETE12,              /* 12 - NOT USED */ | ||||
|   CURLE_FTP_ACCEPT_TIMEOUT,      /* 12 - timeout occurred accepting server | ||||
|                                     [was obsoleted in August 2007 for 7.17.0, | ||||
|                                     reused in Dec 2011 for 7.24.0]*/ | ||||
|   CURLE_FTP_WEIRD_PASV_REPLY,    /* 13 */ | ||||
|   CURLE_FTP_WEIRD_227_FORMAT,    /* 14 */ | ||||
|   CURLE_FTP_CANT_GET_HOST,       /* 15 */ | ||||
| @@ -467,7 +471,7 @@ typedef enum { | ||||
|   CURLE_SSL_CERTPROBLEM,         /* 58 - problem with the local certificate */ | ||||
|   CURLE_SSL_CIPHER,              /* 59 - couldn't use specified cipher */ | ||||
|   CURLE_SSL_CACERT,              /* 60 - problem with the CA cert (path?) */ | ||||
|   CURLE_BAD_CONTENT_ENCODING,    /* 61 - Unrecognized transfer encoding */ | ||||
|   CURLE_BAD_CONTENT_ENCODING,    /* 61 - Unrecognized/bad encoding */ | ||||
|   CURLE_LDAP_INVALID_URL,        /* 62 - Invalid LDAP URL */ | ||||
|   CURLE_FILESIZE_EXCEEDED,       /* 63 - Maximum file size exceeded */ | ||||
|   CURLE_USE_SSL_FAILED,          /* 64 - Requested FTP SSL level failed */ | ||||
| @@ -507,17 +511,21 @@ typedef enum { | ||||
|                                     7.19.0) */ | ||||
|   CURLE_FTP_PRET_FAILED,         /* 84 - a PRET command failed */ | ||||
|   CURLE_RTSP_CSEQ_ERROR,         /* 85 - mismatch of RTSP CSeq numbers */ | ||||
|   CURLE_RTSP_SESSION_ERROR,      /* 86 - mismatch of RTSP Session Identifiers */ | ||||
|   CURLE_RTSP_SESSION_ERROR,      /* 86 - mismatch of RTSP Session Ids */ | ||||
|   CURLE_FTP_BAD_FILE_LIST,       /* 87 - unable to parse FTP file list */ | ||||
|   CURLE_CHUNK_FAILED,            /* 88 - chunk callback reported error */ | ||||
|  | ||||
|   CURL_LAST /* never use! */ | ||||
| } CURLcode; | ||||
|  | ||||
| #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||
|                           the obsolete stuff removed! */ | ||||
|  | ||||
| /* Backwards compatibility with older names */ | ||||
| /* Previously obsoletes error codes re-used in 7.24.0 */ | ||||
| #define CURLE_OBSOLETE10 CURLE_FTP_ACCEPT_FAILED | ||||
| #define CURLE_OBSOLETE12 CURLE_FTP_ACCEPT_TIMEOUT | ||||
|  | ||||
| /*  compatibility with older names */ | ||||
| #define CURLOPT_ENCODING CURLOPT_ACCEPT_ENCODING | ||||
|  | ||||
| /* The following were added in 7.21.5, April 2011 */ | ||||
| #define CURLE_UNKNOWN_TELNET_OPTION CURLE_UNKNOWN_OPTION | ||||
| @@ -528,7 +536,7 @@ typedef enum { | ||||
|  | ||||
| /* The following were added in 7.17.0 */ | ||||
| /* These are scheduled to disappear by 2009 */ | ||||
| #define CURLE_OBSOLETE CURLE_OBSOLETE50 /* noone should be using this! */ | ||||
| #define CURLE_OBSOLETE CURLE_OBSOLETE50 /* no one should be using this! */ | ||||
| #define CURLE_BAD_PASSWORD_ENTERED CURLE_OBSOLETE46 | ||||
| #define CURLE_BAD_CALLING_ORDER CURLE_OBSOLETE44 | ||||
| #define CURLE_FTP_USER_PASSWORD_INCORRECT CURLE_OBSOLETE10 | ||||
| @@ -596,6 +604,7 @@ typedef enum { | ||||
| #define CURLAUTH_GSSNEGOTIATE (1<<2)  /* GSS-Negotiate */ | ||||
| #define CURLAUTH_NTLM         (1<<3)  /* NTLM */ | ||||
| #define CURLAUTH_DIGEST_IE    (1<<4)  /* Digest with IE flavour */ | ||||
| #define CURLAUTH_NTLM_WB      (1<<5)  /* NTLM delegating to winbind helper */ | ||||
| #define CURLAUTH_ONLY         (1<<31) /* used together with a single other | ||||
|                                          type to force no auth or just that | ||||
|                                          single type */ | ||||
| @@ -610,6 +619,10 @@ typedef enum { | ||||
| #define CURLSSH_AUTH_KEYBOARD  (1<<3) /* keyboard interactive */ | ||||
| #define CURLSSH_AUTH_DEFAULT CURLSSH_AUTH_ANY | ||||
|  | ||||
| #define CURLGSSAPI_DELEGATION_NONE        0      /* no delegation (default) */ | ||||
| #define CURLGSSAPI_DELEGATION_POLICY_FLAG (1<<0) /* if permitted by policy */ | ||||
| #define CURLGSSAPI_DELEGATION_FLAG        (1<<1) /* delegate always */ | ||||
|  | ||||
| #define CURL_ERROR_SIZE 256 | ||||
|  | ||||
| struct curl_khkey { | ||||
| @@ -660,6 +673,15 @@ typedef enum { | ||||
|   CURLUSESSL_LAST     /* not an option, never use */ | ||||
| } curl_usessl; | ||||
|  | ||||
| /* Definition of bits for the CURLOPT_SSL_OPTIONS argument: */ | ||||
|  | ||||
| /* - ALLOW_BEAST tells libcurl to allow the BEAST SSL vulnerability in the | ||||
|    name of improving interoperability with older servers. Some SSL libraries | ||||
|    have introduced work-arounds for this flaw but those work-arounds sometimes | ||||
|    make the SSL communication fail. To regain functionality with those broken | ||||
|    servers, a user can this way allow the vulnerability back. */ | ||||
| #define CURLSSLOPT_ALLOW_BEAST (1<<0) | ||||
|  | ||||
| #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||
|                           the obsolete stuff removed! */ | ||||
|  | ||||
| @@ -754,7 +776,7 @@ typedef enum { | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_ISOCPP | ||||
| #define CINIT(name,type,number) CURLOPT_ ## name = CURLOPTTYPE_ ## type + number | ||||
| #define CINIT(na,t,nu) CURLOPT_ ## na = CURLOPTTYPE_ ## t + nu | ||||
| #else | ||||
| /* The macro "##" is ISO C, we assume pre-ISO C doesn't support it. */ | ||||
| #define LONG          CURLOPTTYPE_LONG | ||||
| @@ -912,9 +934,7 @@ typedef enum { | ||||
|   /* send linked-list of post-transfer QUOTE commands */ | ||||
|   CINIT(POSTQUOTE, OBJECTPOINT, 39), | ||||
|  | ||||
|   /* Pass a pointer to string of the output using full variable-replacement | ||||
|      as described elsewhere. */ | ||||
|   CINIT(WRITEINFO, OBJECTPOINT, 40), | ||||
|   CINIT(WRITEINFO, OBJECTPOINT, 40), /* DEPRECATED, do not use! */ | ||||
|  | ||||
|   CINIT(VERBOSE, LONG, 41),      /* talk a lot */ | ||||
|   CINIT(HEADER, LONG, 42),       /* throw the header out too */ | ||||
| @@ -923,7 +943,7 @@ typedef enum { | ||||
|   CINIT(FAILONERROR, LONG, 45),  /* no output on http error codes >= 300 */ | ||||
|   CINIT(UPLOAD, LONG, 46),       /* this is an upload */ | ||||
|   CINIT(POST, LONG, 47),         /* HTTP POST method */ | ||||
|   CINIT(DIRLISTONLY, LONG, 48),  /* return bare names when listing directories */ | ||||
|   CINIT(DIRLISTONLY, LONG, 48),  /* bare names when listing directories */ | ||||
|  | ||||
|   CINIT(APPEND, LONG, 50),       /* Append instead of overwrite on upload! */ | ||||
|  | ||||
| @@ -990,9 +1010,7 @@ typedef enum { | ||||
|   /* Max amount of cached alive connections */ | ||||
|   CINIT(MAXCONNECTS, LONG, 71), | ||||
|  | ||||
|   /* What policy to use when closing connections when the cache is filled | ||||
|      up */ | ||||
|   CINIT(CLOSEPOLICY, LONG, 72), | ||||
|   CINIT(CLOSEPOLICY, LONG, 72), /* DEPRECATED, do not use! */ | ||||
|  | ||||
|   /* 73 = OBSOLETE */ | ||||
|  | ||||
| @@ -1066,7 +1084,7 @@ typedef enum { | ||||
|   CINIT(SSLENGINE_DEFAULT, LONG, 90), | ||||
|  | ||||
|   /* Non-zero value means to use the global dns cache */ | ||||
|   CINIT(DNS_USE_GLOBAL_CACHE, LONG, 91), /* To become OBSOLETE soon */ | ||||
|   CINIT(DNS_USE_GLOBAL_CACHE, LONG, 91), /* DEPRECATED, do not use! */ | ||||
|  | ||||
|   /* DNS cache timeout */ | ||||
|   CINIT(DNS_CACHE_TIMEOUT, LONG, 92), | ||||
| @@ -1103,8 +1121,9 @@ typedef enum { | ||||
|   CINIT(PROXYTYPE, LONG, 101), | ||||
|  | ||||
|   /* Set the Accept-Encoding string. Use this to tell a server you would like | ||||
|      the response to be compressed. */ | ||||
|   CINIT(ENCODING, OBJECTPOINT, 102), | ||||
|      the response to be compressed. Before 7.21.6, this was known as | ||||
|      CURLOPT_ENCODING */ | ||||
|   CINIT(ACCEPT_ENCODING, OBJECTPOINT, 102), | ||||
|  | ||||
|   /* Set pointer to private data */ | ||||
|   CINIT(PRIVATE, OBJECTPOINT, 103), | ||||
| @@ -1117,8 +1136,8 @@ typedef enum { | ||||
|      and password to whatever host the server decides. */ | ||||
|   CINIT(UNRESTRICTED_AUTH, LONG, 105), | ||||
|  | ||||
|   /* Specifically switch on or off the FTP engine's use of the EPRT command ( it | ||||
|      also disables the LPRT attempt). By default, those ones will always be | ||||
|   /* Specifically switch on or off the FTP engine's use of the EPRT command ( | ||||
|      it also disables the LPRT attempt). By default, those ones will always be | ||||
|      attempted before the good old traditional PORT command. */ | ||||
|   CINIT(FTP_USE_EPRT, LONG, 106), | ||||
|  | ||||
| @@ -1462,6 +1481,46 @@ typedef enum { | ||||
|   /* Set authentication type for authenticated TLS */ | ||||
|   CINIT(TLSAUTH_TYPE, OBJECTPOINT, 206), | ||||
|  | ||||
|   /* Set to 1 to enable the "TE:" header in HTTP requests to ask for | ||||
|      compressed transfer-encoded responses. Set to 0 to disable the use of TE: | ||||
|      in outgoing requests. The current default is 0, but it might change in a | ||||
|      future libcurl release. | ||||
|  | ||||
|      libcurl will ask for the compressed methods it knows of, and if that | ||||
|      isn't any, it will not ask for transfer-encoding at all even if this | ||||
|      option is set to 1. | ||||
|  | ||||
|   */ | ||||
|   CINIT(TRANSFER_ENCODING, LONG, 207), | ||||
|  | ||||
|   /* Callback function for closing socket (instead of close(2)). The callback | ||||
|      should have type curl_closesocket_callback */ | ||||
|   CINIT(CLOSESOCKETFUNCTION, FUNCTIONPOINT, 208), | ||||
|   CINIT(CLOSESOCKETDATA, OBJECTPOINT, 209), | ||||
|  | ||||
|   /* allow GSSAPI credential delegation */ | ||||
|   CINIT(GSSAPI_DELEGATION, LONG, 210), | ||||
|  | ||||
|   /* Set the name servers to use for DNS resolution */ | ||||
|   CINIT(DNS_SERVERS, OBJECTPOINT, 211), | ||||
|  | ||||
|   /* Time-out accept operations (currently for FTP only) after this amount | ||||
|      of miliseconds. */ | ||||
|   CINIT(ACCEPTTIMEOUT_MS, LONG, 212), | ||||
|  | ||||
|   /* Set TCP keepalive */ | ||||
|   CINIT(TCP_KEEPALIVE, LONG, 213), | ||||
|  | ||||
|   /* non-universal keepalive knobs (Linux, AIX, HP-UX, more) */ | ||||
|   CINIT(TCP_KEEPIDLE, LONG, 214), | ||||
|   CINIT(TCP_KEEPINTVL, LONG, 215), | ||||
|  | ||||
|   /* Enable/disable specific SSL features with a bitmask, see CURLSSLOPT_* */ | ||||
|   CINIT(SSL_OPTIONS, LONG, 216), | ||||
|  | ||||
|   /* set the SMTP auth originator */ | ||||
|   CINIT(MAIL_AUTH, OBJECTPOINT, 217), | ||||
|  | ||||
|   CURLOPT_LASTENTRY /* the last unused */ | ||||
| } CURLoption; | ||||
|  | ||||
| @@ -1690,7 +1749,8 @@ CURL_EXTERN CURLFORMcode curl_formadd(struct curl_httppost **httppost, | ||||
|  * Should return the buffer length passed to it as the argument "len" on | ||||
|  *   success. | ||||
|  */ | ||||
| typedef size_t (*curl_formget_callback)(void *arg, const char *buf, size_t len); | ||||
| typedef size_t (*curl_formget_callback)(void *arg, const char *buf, | ||||
|                                         size_t len); | ||||
|  | ||||
| /* | ||||
|  * NAME curl_formget() | ||||
| @@ -1989,8 +2049,9 @@ typedef enum { | ||||
|   CURLSHE_BAD_OPTION, /* 1 */ | ||||
|   CURLSHE_IN_USE,     /* 2 */ | ||||
|   CURLSHE_INVALID,    /* 3 */ | ||||
|   CURLSHE_NOMEM,      /* out of memory */ | ||||
|   CURLSHE_LAST /* never use */ | ||||
|   CURLSHE_NOMEM,      /* 4 out of memory */ | ||||
|   CURLSHE_NOT_BUILT_IN, /* 5 feature not present in lib */ | ||||
|   CURLSHE_LAST        /* never use */ | ||||
| } CURLSHcode; | ||||
|  | ||||
| typedef enum { | ||||
| @@ -2070,8 +2131,9 @@ typedef struct { | ||||
| #define CURL_VERSION_CONV      (1<<12) /* character conversions supported */ | ||||
| #define CURL_VERSION_CURLDEBUG (1<<13) /* debug memory tracking supported */ | ||||
| #define CURL_VERSION_TLSAUTH_SRP (1<<14) /* TLS-SRP auth is supported */ | ||||
| #define CURL_VERSION_NTLM_WB   (1<<15) /* NTLM delegating to winbind helper */ | ||||
|  | ||||
| /* | ||||
|  /* | ||||
|  * NAME curl_version_info() | ||||
|  * | ||||
|  * DESCRIPTION | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -58,52 +58,52 @@ | ||||
| /* ================================================================ */ | ||||
|  | ||||
| #ifdef CURL_SIZEOF_LONG | ||||
| #  error "CURL_SIZEOF_LONG shall not be defined except in curlbuild.h" | ||||
| #error "CURL_SIZEOF_LONG shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_SIZEOF_LONG_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_TYPEOF_CURL_SOCKLEN_T | ||||
| #  error "CURL_TYPEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_TYPEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_TYPEOF_CURL_SOCKLEN_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_SIZEOF_CURL_SOCKLEN_T | ||||
| #  error "CURL_SIZEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_SIZEOF_CURL_SOCKLEN_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_SIZEOF_CURL_SOCKLEN_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_TYPEOF_CURL_OFF_T | ||||
| #  error "CURL_TYPEOF_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_TYPEOF_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_TYPEOF_CURL_OFF_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_FORMAT_CURL_OFF_T | ||||
| #  error "CURL_FORMAT_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_FORMAT_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_FORMAT_CURL_OFF_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_FORMAT_CURL_OFF_TU | ||||
| #  error "CURL_FORMAT_CURL_OFF_TU shall not be defined except in curlbuild.h" | ||||
| #error "CURL_FORMAT_CURL_OFF_TU shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_FORMAT_CURL_OFF_TU_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_FORMAT_OFF_T | ||||
| #  error "CURL_FORMAT_OFF_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_FORMAT_OFF_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_FORMAT_OFF_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_SIZEOF_CURL_OFF_T | ||||
| #  error "CURL_SIZEOF_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_SIZEOF_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_SIZEOF_CURL_OFF_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_SUFFIX_CURL_OFF_T | ||||
| #  error "CURL_SUFFIX_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
| #error "CURL_SUFFIX_CURL_OFF_T shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_SUFFIX_CURL_OFF_T_already_defined | ||||
| #endif | ||||
|  | ||||
| #ifdef CURL_SUFFIX_CURL_OFF_TU | ||||
| #  error "CURL_SUFFIX_CURL_OFF_TU shall not be defined except in curlbuild.h" | ||||
| #error "CURL_SUFFIX_CURL_OFF_TU shall not be defined except in curlbuild.h" | ||||
|    Error Compilation_aborted_CURL_SUFFIX_CURL_OFF_TU_already_defined | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -26,17 +26,17 @@ | ||||
|    a script at release-time. This was made its own header file in 7.11.2 */ | ||||
|  | ||||
| /* This is the global package copyright */ | ||||
| #define LIBCURL_COPYRIGHT "1996 - 2011 Daniel Stenberg, <daniel@haxx.se>." | ||||
| #define LIBCURL_COPYRIGHT "1996 - 2012 Daniel Stenberg, <daniel@haxx.se>." | ||||
|  | ||||
| /* This is the version number of the libcurl package from which this header | ||||
|    file origins: */ | ||||
| #define LIBCURL_VERSION "7.21.5-DEV" | ||||
| #define LIBCURL_VERSION "7.25.0-DEV" | ||||
|  | ||||
| /* The numeric version number is also available "in parts" by using these | ||||
|    defines: */ | ||||
| #define LIBCURL_VERSION_MAJOR 7 | ||||
| #define LIBCURL_VERSION_MINOR 21 | ||||
| #define LIBCURL_VERSION_PATCH 5 | ||||
| #define LIBCURL_VERSION_MINOR 25 | ||||
| #define LIBCURL_VERSION_PATCH 0 | ||||
|  | ||||
| /* This is the numeric version of the libcurl version number, meant for easier | ||||
|    parsing and comparions by programs. The LIBCURL_VERSION_NUM define will | ||||
| @@ -53,7 +53,7 @@ | ||||
|    and it is always a greater number in a more recent release. It makes | ||||
|    comparisons with greater than and less than work. | ||||
| */ | ||||
| #define LIBCURL_VERSION_NUM 0x071505 | ||||
| #define LIBCURL_VERSION_NUM 0x071900 | ||||
|  | ||||
| /* | ||||
|  * This is the date and time when the full source package was created. The | ||||
|   | ||||
| @@ -53,8 +53,8 @@ CURL_EXTERN CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...); | ||||
|  * | ||||
|  * Creates a new curl session handle with the same options set for the handle | ||||
|  * passed in. Duplicating a handle could only be a matter of cloning data and | ||||
|  * options, internal state info and things like persistant connections cannot | ||||
|  * be transfered. It is useful in multithreaded applications when you can run | ||||
|  * options, internal state info and things like persistent connections cannot | ||||
|  * be transferred. It is useful in multithreaded applications when you can run | ||||
|  * curl_easy_duphandle() for each new thread to avoid a series of identical | ||||
|  * curl_easy_setopt() invokes in every thread. | ||||
|  */ | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -41,66 +41,66 @@ | ||||
| #define curl_easy_setopt(handle, option, value)                               \ | ||||
| __extension__ ({                                                              \ | ||||
|   __typeof__ (option) _curl_opt = option;                                     \ | ||||
|   if (__builtin_constant_p(_curl_opt)) {                                      \ | ||||
|     if (_curl_is_long_option(_curl_opt))                                      \ | ||||
|       if (!_curl_is_long(value))                                              \ | ||||
|   if(__builtin_constant_p(_curl_opt)) {                                       \ | ||||
|     if(_curl_is_long_option(_curl_opt))                                       \ | ||||
|       if(!_curl_is_long(value))                                               \ | ||||
|         _curl_easy_setopt_err_long();                                         \ | ||||
|     if (_curl_is_off_t_option(_curl_opt))                                     \ | ||||
|       if (!_curl_is_off_t(value))                                             \ | ||||
|     if(_curl_is_off_t_option(_curl_opt))                                      \ | ||||
|       if(!_curl_is_off_t(value))                                              \ | ||||
|         _curl_easy_setopt_err_curl_off_t();                                   \ | ||||
|     if (_curl_is_string_option(_curl_opt))                                    \ | ||||
|       if (!_curl_is_string(value))                                            \ | ||||
|     if(_curl_is_string_option(_curl_opt))                                     \ | ||||
|       if(!_curl_is_string(value))                                             \ | ||||
|         _curl_easy_setopt_err_string();                                       \ | ||||
|     if (_curl_is_write_cb_option(_curl_opt))                                  \ | ||||
|       if (!_curl_is_write_cb(value))                                          \ | ||||
|     if(_curl_is_write_cb_option(_curl_opt))                                   \ | ||||
|       if(!_curl_is_write_cb(value))                                           \ | ||||
|         _curl_easy_setopt_err_write_callback();                               \ | ||||
|     if ((_curl_opt) == CURLOPT_READFUNCTION)                                  \ | ||||
|       if (!_curl_is_read_cb(value))                                           \ | ||||
|     if((_curl_opt) == CURLOPT_READFUNCTION)                                   \ | ||||
|       if(!_curl_is_read_cb(value))                                            \ | ||||
|         _curl_easy_setopt_err_read_cb();                                      \ | ||||
|     if ((_curl_opt) == CURLOPT_IOCTLFUNCTION)                                 \ | ||||
|       if (!_curl_is_ioctl_cb(value))                                          \ | ||||
|     if((_curl_opt) == CURLOPT_IOCTLFUNCTION)                                  \ | ||||
|       if(!_curl_is_ioctl_cb(value))                                           \ | ||||
|         _curl_easy_setopt_err_ioctl_cb();                                     \ | ||||
|     if ((_curl_opt) == CURLOPT_SOCKOPTFUNCTION)                               \ | ||||
|       if (!_curl_is_sockopt_cb(value))                                        \ | ||||
|     if((_curl_opt) == CURLOPT_SOCKOPTFUNCTION)                                \ | ||||
|       if(!_curl_is_sockopt_cb(value))                                         \ | ||||
|         _curl_easy_setopt_err_sockopt_cb();                                   \ | ||||
|     if ((_curl_opt) == CURLOPT_OPENSOCKETFUNCTION)                            \ | ||||
|       if (!_curl_is_opensocket_cb(value))                                     \ | ||||
|     if((_curl_opt) == CURLOPT_OPENSOCKETFUNCTION)                             \ | ||||
|       if(!_curl_is_opensocket_cb(value))                                      \ | ||||
|         _curl_easy_setopt_err_opensocket_cb();                                \ | ||||
|     if ((_curl_opt) == CURLOPT_PROGRESSFUNCTION)                              \ | ||||
|       if (!_curl_is_progress_cb(value))                                       \ | ||||
|     if((_curl_opt) == CURLOPT_PROGRESSFUNCTION)                               \ | ||||
|       if(!_curl_is_progress_cb(value))                                        \ | ||||
|         _curl_easy_setopt_err_progress_cb();                                  \ | ||||
|     if ((_curl_opt) == CURLOPT_DEBUGFUNCTION)                                 \ | ||||
|       if (!_curl_is_debug_cb(value))                                          \ | ||||
|     if((_curl_opt) == CURLOPT_DEBUGFUNCTION)                                  \ | ||||
|       if(!_curl_is_debug_cb(value))                                           \ | ||||
|         _curl_easy_setopt_err_debug_cb();                                     \ | ||||
|     if ((_curl_opt) == CURLOPT_SSL_CTX_FUNCTION)                              \ | ||||
|       if (!_curl_is_ssl_ctx_cb(value))                                        \ | ||||
|     if((_curl_opt) == CURLOPT_SSL_CTX_FUNCTION)                               \ | ||||
|       if(!_curl_is_ssl_ctx_cb(value))                                         \ | ||||
|         _curl_easy_setopt_err_ssl_ctx_cb();                                   \ | ||||
|     if (_curl_is_conv_cb_option(_curl_opt))                                   \ | ||||
|       if (!_curl_is_conv_cb(value))                                           \ | ||||
|     if(_curl_is_conv_cb_option(_curl_opt))                                    \ | ||||
|       if(!_curl_is_conv_cb(value))                                            \ | ||||
|         _curl_easy_setopt_err_conv_cb();                                      \ | ||||
|     if ((_curl_opt) == CURLOPT_SEEKFUNCTION)                                  \ | ||||
|       if (!_curl_is_seek_cb(value))                                           \ | ||||
|     if((_curl_opt) == CURLOPT_SEEKFUNCTION)                                   \ | ||||
|       if(!_curl_is_seek_cb(value))                                            \ | ||||
|         _curl_easy_setopt_err_seek_cb();                                      \ | ||||
|     if (_curl_is_cb_data_option(_curl_opt))                                   \ | ||||
|       if (!_curl_is_cb_data(value))                                           \ | ||||
|     if(_curl_is_cb_data_option(_curl_opt))                                    \ | ||||
|       if(!_curl_is_cb_data(value))                                            \ | ||||
|         _curl_easy_setopt_err_cb_data();                                      \ | ||||
|     if ((_curl_opt) == CURLOPT_ERRORBUFFER)                                   \ | ||||
|       if (!_curl_is_error_buffer(value))                                      \ | ||||
|     if((_curl_opt) == CURLOPT_ERRORBUFFER)                                    \ | ||||
|       if(!_curl_is_error_buffer(value))                                       \ | ||||
|         _curl_easy_setopt_err_error_buffer();                                 \ | ||||
|     if ((_curl_opt) == CURLOPT_STDERR)                                        \ | ||||
|       if (!_curl_is_FILE(value))                                              \ | ||||
|     if((_curl_opt) == CURLOPT_STDERR)                                         \ | ||||
|       if(!_curl_is_FILE(value))                                               \ | ||||
|         _curl_easy_setopt_err_FILE();                                         \ | ||||
|     if (_curl_is_postfields_option(_curl_opt))                                \ | ||||
|       if (!_curl_is_postfields(value))                                        \ | ||||
|     if(_curl_is_postfields_option(_curl_opt))                                 \ | ||||
|       if(!_curl_is_postfields(value))                                         \ | ||||
|         _curl_easy_setopt_err_postfields();                                   \ | ||||
|     if ((_curl_opt) == CURLOPT_HTTPPOST)                                      \ | ||||
|       if (!_curl_is_arr((value), struct curl_httppost))                       \ | ||||
|     if((_curl_opt) == CURLOPT_HTTPPOST)                                       \ | ||||
|       if(!_curl_is_arr((value), struct curl_httppost))                        \ | ||||
|         _curl_easy_setopt_err_curl_httpost();                                 \ | ||||
|     if (_curl_is_slist_option(_curl_opt))                                     \ | ||||
|       if (!_curl_is_arr((value), struct curl_slist))                          \ | ||||
|     if(_curl_is_slist_option(_curl_opt))                                      \ | ||||
|       if(!_curl_is_arr((value), struct curl_slist))                           \ | ||||
|         _curl_easy_setopt_err_curl_slist();                                   \ | ||||
|     if ((_curl_opt) == CURLOPT_SHARE)                                         \ | ||||
|       if (!_curl_is_ptr((value), CURLSH))                                     \ | ||||
|     if((_curl_opt) == CURLOPT_SHARE)                                          \ | ||||
|       if(!_curl_is_ptr((value), CURLSH))                                      \ | ||||
|         _curl_easy_setopt_err_CURLSH();                                       \ | ||||
|   }                                                                           \ | ||||
|   curl_easy_setopt(handle, _curl_opt, value);                                 \ | ||||
| @@ -111,18 +111,18 @@ __extension__ ({                                                              \ | ||||
| #define curl_easy_getinfo(handle, info, arg)                                  \ | ||||
| __extension__ ({                                                              \ | ||||
|   __typeof__ (info) _curl_info = info;                                        \ | ||||
|   if (__builtin_constant_p(_curl_info)) {                                     \ | ||||
|     if (_curl_is_string_info(_curl_info))                                     \ | ||||
|       if (!_curl_is_arr((arg), char *))                                       \ | ||||
|   if(__builtin_constant_p(_curl_info)) {                                      \ | ||||
|     if(_curl_is_string_info(_curl_info))                                      \ | ||||
|       if(!_curl_is_arr((arg), char *))                                        \ | ||||
|         _curl_easy_getinfo_err_string();                                      \ | ||||
|     if (_curl_is_long_info(_curl_info))                                       \ | ||||
|       if (!_curl_is_arr((arg), long))                                         \ | ||||
|     if(_curl_is_long_info(_curl_info))                                        \ | ||||
|       if(!_curl_is_arr((arg), long))                                          \ | ||||
|         _curl_easy_getinfo_err_long();                                        \ | ||||
|     if (_curl_is_double_info(_curl_info))                                     \ | ||||
|       if (!_curl_is_arr((arg), double))                                       \ | ||||
|     if(_curl_is_double_info(_curl_info))                                      \ | ||||
|       if(!_curl_is_arr((arg), double))                                        \ | ||||
|         _curl_easy_getinfo_err_double();                                      \ | ||||
|     if (_curl_is_slist_info(_curl_info))                                      \ | ||||
|       if (!_curl_is_arr((arg), struct curl_slist *))                          \ | ||||
|     if(_curl_is_slist_info(_curl_info))                                       \ | ||||
|       if(!_curl_is_arr((arg), struct curl_slist *))                           \ | ||||
|         _curl_easy_getinfo_err_curl_slist();                                  \ | ||||
|   }                                                                           \ | ||||
|   curl_easy_getinfo(handle, _curl_info, arg);                                 \ | ||||
| @@ -149,7 +149,8 @@ _CURL_WARNING(_curl_easy_setopt_err_long, | ||||
| _CURL_WARNING(_curl_easy_setopt_err_curl_off_t, | ||||
|   "curl_easy_setopt expects a curl_off_t argument for this option") | ||||
| _CURL_WARNING(_curl_easy_setopt_err_string, | ||||
|   "curl_easy_setopt expects a string (char* or char[]) argument for this option" | ||||
|               "curl_easy_setopt expects a " | ||||
|               "string (char* or char[]) argument for this option" | ||||
|   ) | ||||
| _CURL_WARNING(_curl_easy_setopt_err_write_callback, | ||||
|   "curl_easy_setopt expects a curl_write_callback argument for this option") | ||||
| @@ -160,7 +161,8 @@ _CURL_WARNING(_curl_easy_setopt_err_ioctl_cb, | ||||
| _CURL_WARNING(_curl_easy_setopt_err_sockopt_cb, | ||||
|   "curl_easy_setopt expects a curl_sockopt_callback argument for this option") | ||||
| _CURL_WARNING(_curl_easy_setopt_err_opensocket_cb, | ||||
|   "curl_easy_setopt expects a curl_opensocket_callback argument for this option" | ||||
|               "curl_easy_setopt expects a " | ||||
|               "curl_opensocket_callback argument for this option" | ||||
|   ) | ||||
| _CURL_WARNING(_curl_easy_setopt_err_progress_cb, | ||||
|   "curl_easy_setopt expects a curl_progress_callback argument for this option") | ||||
| @@ -173,9 +175,11 @@ _CURL_WARNING(_curl_easy_setopt_err_conv_cb, | ||||
| _CURL_WARNING(_curl_easy_setopt_err_seek_cb, | ||||
|   "curl_easy_setopt expects a curl_seek_callback argument for this option") | ||||
| _CURL_WARNING(_curl_easy_setopt_err_cb_data, | ||||
|   "curl_easy_setopt expects a private data pointer as argument for this option") | ||||
|               "curl_easy_setopt expects a " | ||||
|               "private data pointer as argument for this option") | ||||
| _CURL_WARNING(_curl_easy_setopt_err_error_buffer, | ||||
|   "curl_easy_setopt expects a char buffer of CURL_ERROR_SIZE as argument for this option") | ||||
|               "curl_easy_setopt expects a " | ||||
|               "char buffer of CURL_ERROR_SIZE as argument for this option") | ||||
| _CURL_WARNING(_curl_easy_setopt_err_FILE, | ||||
|   "curl_easy_setopt expects a FILE* argument for this option") | ||||
| _CURL_WARNING(_curl_easy_setopt_err_postfields, | ||||
| @@ -224,7 +228,7 @@ _CURL_WARNING(_curl_easy_getinfo_err_curl_slist, | ||||
|    (option) == CURLOPT_PROXYUSERNAME ||                                       \ | ||||
|    (option) == CURLOPT_PROXYPASSWORD ||                                       \ | ||||
|    (option) == CURLOPT_NOPROXY ||                                             \ | ||||
|    (option) == CURLOPT_ENCODING ||                                            \ | ||||
|    (option) == CURLOPT_ACCEPT_ENCODING ||                                     \ | ||||
|    (option) == CURLOPT_REFERER ||                                             \ | ||||
|    (option) == CURLOPT_USERAGENT ||                                           \ | ||||
|    (option) == CURLOPT_COOKIE ||                                              \ | ||||
| @@ -388,7 +392,8 @@ _CURL_WARNING(_curl_easy_getinfo_err_curl_slist, | ||||
| /* evaluates to true if expr is abuffer suitable for CURLOPT_ERRORBUFFER */ | ||||
| /* XXX: also check size of an char[] array? */ | ||||
| #define _curl_is_error_buffer(expr)                                           \ | ||||
|   (__builtin_types_compatible_p(__typeof__(expr), char *) ||                  \ | ||||
|   (_curl_is_NULL(expr) ||                                                     \ | ||||
|    __builtin_types_compatible_p(__typeof__(expr), char *) ||                  \ | ||||
|    __builtin_types_compatible_p(__typeof__(expr), char[])) | ||||
|  | ||||
| /* evaluates to true if expr is of type (const) void* or (const) FILE* */ | ||||
| @@ -481,7 +486,8 @@ typedef int (_curl_sockopt_callback1)(void *, curl_socket_t, curlsocktype); | ||||
| typedef int (_curl_sockopt_callback2)(const void *, curl_socket_t, | ||||
|                                       curlsocktype); | ||||
|  | ||||
| /* evaluates to true if expr is of type curl_opensocket_callback or "similar" */ | ||||
| /* evaluates to true if expr is of type curl_opensocket_callback or | ||||
|    "similar" */ | ||||
| #define _curl_is_opensocket_cb(expr)                                    \ | ||||
|   (_curl_is_NULL(expr) ||                                                     \ | ||||
|    __builtin_types_compatible_p(__typeof__(expr), curl_opensocket_callback) ||\ | ||||
| @@ -516,7 +522,11 @@ typedef int (_curl_progress_callback2)(const void *, | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback1) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback2) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback3) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback4)) | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback4) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback5) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback6) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback7) ||                \ | ||||
|    _curl_callback_compatible((expr), _curl_debug_callback8)) | ||||
| typedef int (_curl_debug_callback1) (CURL *, | ||||
|     curl_infotype, char *, size_t, void *); | ||||
| typedef int (_curl_debug_callback2) (CURL *, | ||||
| @@ -525,6 +535,14 @@ typedef int (_curl_debug_callback3) (CURL *, | ||||
|     curl_infotype, const char *, size_t, void *); | ||||
| typedef int (_curl_debug_callback4) (CURL *, | ||||
|     curl_infotype, const char *, size_t, const void *); | ||||
| typedef int (_curl_debug_callback5) (CURL *, | ||||
|     curl_infotype, unsigned char *, size_t, void *); | ||||
| typedef int (_curl_debug_callback6) (CURL *, | ||||
|     curl_infotype, unsigned char *, size_t, const void *); | ||||
| typedef int (_curl_debug_callback7) (CURL *, | ||||
|     curl_infotype, const unsigned char *, size_t, void *); | ||||
| typedef int (_curl_debug_callback8) (CURL *, | ||||
|     curl_infotype, const unsigned char *, size_t, const void *); | ||||
|  | ||||
| /* evaluates to true if expr is of type curl_ssl_ctx_callback or "similar" */ | ||||
| /* this is getting even messier... */ | ||||
| @@ -550,7 +568,8 @@ typedef CURLcode (_curl_ssl_ctx_callback4)(CURL *, const void *, const void *); | ||||
| typedef CURLcode (_curl_ssl_ctx_callback5)(CURL *, SSL_CTX, void *); | ||||
| typedef CURLcode (_curl_ssl_ctx_callback6)(CURL *, SSL_CTX, const void *); | ||||
| typedef CURLcode (_curl_ssl_ctx_callback7)(CURL *, const SSL_CTX, void *); | ||||
| typedef CURLcode (_curl_ssl_ctx_callback8)(CURL *, const SSL_CTX, const void *); | ||||
| typedef CURLcode (_curl_ssl_ctx_callback8)(CURL *, const SSL_CTX, | ||||
|                                            const void *); | ||||
| #else | ||||
| typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback5; | ||||
| typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback6; | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| /* not used */ | ||||
							
								
								
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -10,3 +10,4 @@ libcurl.plist.dist | ||||
| libcurl.vcproj | ||||
| vc6libcurl.dsp | ||||
| Makefile.vc10.dist | ||||
| libcurl.vers | ||||
|   | ||||
| @@ -122,3 +122,5 @@ if(WIN32) | ||||
|     set_target_properties(${LIB_NAME} PROPERTIES IMPORT_SUFFIX "_imp.lib") | ||||
|   endif() | ||||
| endif() | ||||
|  | ||||
| install(TARGETS ${LIB_NAME} DESTINATION lib) | ||||
|   | ||||
| @@ -70,6 +70,13 @@ CFLAGS += -d_WIN32_WINNT=0x0501 -dENABLE_IPV6 | ||||
| CFLAGS += -dUSE_WINDOWS_SSPI | ||||
| !endif | ||||
|  | ||||
| !ifdef %use_winidn | ||||
| CFLAGS += -dWINVER=0x0600 -dUSE_WIN32_IDN | ||||
| !  if $(__VERSION__) <= 1290 | ||||
| CFLAGS += -dWANT_IDN_PROTOTYPES | ||||
| !  endif | ||||
| !endif | ||||
|  | ||||
| # | ||||
| # Change to suite. | ||||
| # | ||||
| @@ -82,7 +89,7 @@ ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.5 | ||||
| !ifdef %libssh2_root | ||||
| LIBSSH2_ROOT = $(%libssh2_root) | ||||
| !else | ||||
| LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.2.7 | ||||
| LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.3.0 | ||||
| !endif | ||||
|  | ||||
| !ifdef %librtmp_root | ||||
| @@ -229,6 +236,14 @@ $(LINK_ARG): $(__MAKEFILES__) | ||||
| !ifdef %use_ares | ||||
| 	@%append $^@ library $(ARES_ROOT)$(DS)cares.lib | ||||
| !endif | ||||
| !ifdef %use_winidn | ||||
| !  if $(__VERSION__) > 1290 | ||||
| 	@%append $^@ library normaliz.lib | ||||
| !  else | ||||
| 	@%append $^@ import '_IdnToAscii@20' 'NORMALIZ.DLL'.'IdnToAscii' | ||||
| 	@%append $^@ import '_IdnToUnicode@20' 'NORMALIZ.DLL'.'IdnToUnicode' | ||||
| !  endif | ||||
| !endif | ||||
|  | ||||
| $(LIB_ARG): $(__MAKEFILES__) | ||||
| 	%create $^@ | ||||
|   | ||||
| @@ -38,7 +38,7 @@ EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 $(DSP)                 \ | ||||
|  config-win32ce.h config-os400.h setup-os400.h config-symbian.h		   \ | ||||
|  Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl		   \ | ||||
|  mk-ca-bundle.vbs firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h	   \ | ||||
|  Makefile.vxworks config-vms.h | ||||
|  Makefile.vxworks config-vms.h checksrc.pl | ||||
|  | ||||
| CLEANFILES = $(DSP) $(VCPROJ) | ||||
|  | ||||
| @@ -46,7 +46,7 @@ lib_LTLIBRARIES = libcurl.la | ||||
| LIBCURL_LIBS = @LIBCURL_LIBS@ | ||||
|  | ||||
| # This might hold -Werror | ||||
| libcurl_la_CFLAGS = $(CFLAGS) @CURL_CFLAG_EXTRAS@ | ||||
| CFLAGS += @CURL_CFLAG_EXTRAS@ | ||||
|  | ||||
| # Specify our include paths here, and do it relative to $(top_srcdir) and | ||||
| # $(top_builddir), to ensure that these paths which belong to the library | ||||
| @@ -106,7 +106,7 @@ endif | ||||
| # For the full guide on libcurl ABI rules, see docs/libcurl/ABI | ||||
|  | ||||
| if NO_UNDEFINED | ||||
| # The -no-undefined flag is CRUCIAL for this to build fine on Cygwin. | ||||
| # The -no-undefined flag is crucial to build fine on some platforms | ||||
| UNDEF = -no-undefined | ||||
| endif | ||||
|  | ||||
| @@ -116,18 +116,22 @@ if MIMPURE | ||||
| MIMPURE = -mimpure-text | ||||
| endif | ||||
|  | ||||
| LINKFLAGS=$(UNDEF) $(MIMPURE) $(LIBCURL_LIBS) | ||||
|  | ||||
| libcurl_la_LDFLAGS = $(LINKFLAGS) $(VERSIONINFO) | ||||
|  | ||||
| # as unit testing will compile and link everything an extra time, we only | ||||
| # do it if debug is enabled | ||||
| if CURLDEBUG | ||||
| noinst_LTLIBRARIES = libcurlu.la | ||||
| libcurlu_la_CFLAGS = -DUNITTESTS | ||||
| libcurlu_la_LDFLAGS = -static $(LINKFLAGS) | ||||
| if VERSIONED_SYMBOLS | ||||
| VERSIONED_SYMBOLS = -Wl,--version-script=libcurl.vers | ||||
| endif | ||||
|  | ||||
| libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(VERSIONED_SYMBOLS) $(LIBCURL_LIBS) | ||||
|  | ||||
| # unit testing static library built only along with unit tests | ||||
| if BUILD_UNITTESTS | ||||
| noinst_LTLIBRARIES = libcurlu.la | ||||
| else | ||||
| noinst_LTLIBRARIES = | ||||
| endif | ||||
|  | ||||
| libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS | ||||
| libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS) | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|  | ||||
| @@ -184,3 +188,12 @@ $(VCPROJ): vc8proj.head vc8proj.foot Makefile.am | ||||
| 	echo "<File RelativePath=\""$$file"\"></File>" $(VCPROJOUT); \ | ||||
| 	done; \ | ||||
| 	cat $(srcdir)/vc8proj.foot $(VCPROJOUT) ) | ||||
|  | ||||
|  | ||||
| checksrc: | ||||
| 	@@PERL@ $(top_srcdir)/lib/checksrc.pl -D$(top_srcdir)/lib $(CSOURCES) $(HHEADERS) | ||||
|  | ||||
| if CURLDEBUG | ||||
| # for debug builds, we scan the sources on all regular make invokes | ||||
| all-local: checksrc | ||||
| endif | ||||
|   | ||||
| @@ -14,14 +14,16 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c	\ | ||||
|   curl_fnmatch.c fileinfo.c ftplistparser.c wildcard.c krb5.c		\ | ||||
|   memdebug.c http_chunks.c strtok.c connect.c llist.c hash.c multi.c	\ | ||||
|   content_encoding.c share.c http_digest.c md4.c md5.c curl_rand.c	\ | ||||
|   http_negotiate.c http_ntlm.c inet_pton.c strtoofft.c strerror.c	\ | ||||
|   hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c	\ | ||||
|   inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c	\ | ||||
|   strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c		\ | ||||
|   socks_gssapi.c socks_sspi.c curl_sspi.c slist.c nonblock.c		\ | ||||
|   curl_memrchr.c imap.c pop3.c smtp.c pingpong.c rtsp.c curl_threads.c	\ | ||||
|   warnless.c hmac.c polarssl.c curl_rtmp.c openldap.c curl_gethostname.c\ | ||||
|   gopher.c axtls.c idn_win32.c http_negotiate_sspi.c cyassl.c http_proxy.c | ||||
|   http_negotiate.c inet_pton.c strtoofft.c strerror.c			\ | ||||
|   hostasyn.c hostip4.c hostip6.c hostsyn.c inet_ntop.c parsedate.c	\ | ||||
|   select.c gtls.c sslgen.c tftp.c splay.c strdup.c socks.c ssh.c nss.c	\ | ||||
|   qssl.c rawstr.c curl_addrinfo.c socks_gssapi.c socks_sspi.c		\ | ||||
|   curl_sspi.c slist.c nonblock.c curl_memrchr.c imap.c pop3.c smtp.c	\ | ||||
|   pingpong.c rtsp.c curl_threads.c warnless.c hmac.c polarssl.c		\ | ||||
|   curl_rtmp.c openldap.c curl_gethostname.c gopher.c axtls.c		\ | ||||
|   idn_win32.c http_negotiate_sspi.c cyassl.c http_proxy.c non-ascii.c	\ | ||||
|   asyn-ares.c asyn-thread.c curl_gssapi.c curl_ntlm.c curl_ntlm_wb.c	\ | ||||
|   curl_ntlm_core.c curl_ntlm_msgs.c | ||||
|  | ||||
| HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | ||||
|   progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h	\ | ||||
| @@ -29,12 +31,12 @@ HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | ||||
|   getinfo.h strequal.h krb4.h memdebug.h http_chunks.h curl_rand.h	\ | ||||
|   curl_fnmatch.h wildcard.h fileinfo.h ftplistparser.h strtok.h		\ | ||||
|   connect.h llist.h hash.h content_encoding.h share.h curl_md4.h	\ | ||||
|   curl_md5.h http_digest.h http_negotiate.h http_ntlm.h inet_pton.h	\ | ||||
|   curl_md5.h http_digest.h http_negotiate.h inet_pton.h			\ | ||||
|   strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h setup.h	\ | ||||
|   transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h	\ | ||||
|   tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h nssg.h	\ | ||||
|   curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h nonblock.h	\ | ||||
|   curl_memrchr.h imap.h pop3.h smtp.h pingpong.h rtsp.h curl_threads.h	\ | ||||
|   warnless.h curl_hmac.h polarssl.h curl_rtmp.h curl_gethostname.h      \ | ||||
|   gopher.h axtls.h cyassl.h http_proxy.h | ||||
|  | ||||
|   warnless.h curl_hmac.h polarssl.h curl_rtmp.h curl_gethostname.h	\ | ||||
|   gopher.h axtls.h cyassl.h http_proxy.h non-ascii.h asyn.h curl_ntlm.h \ | ||||
|   curl_gssapi.h curl_ntlm_wb.h curl_ntlm_core.h curl_ntlm_msgs.h | ||||
|   | ||||
							
								
								
									
										149
									
								
								lib/Makefile.m32
									
									
									
									
									
								
							
							
						
						
									
										149
									
								
								lib/Makefile.m32
									
									
									
									
									
								
							| @@ -1,18 +1,16 @@ | ||||
| ######################################################################### | ||||
| ########################################################################### | ||||
| # | ||||
| ## Makefile for building libcurl.a with MingW32 (GCC-3.2 or later) | ||||
| ## and optionally OpenSSL (0.9.8), libssh2 (1.2), zlib (1.2.5) | ||||
| ## Makefile for building libcurl.a with MingW (GCC-3.2 or later) | ||||
| ## and optionally OpenSSL (0.9.8), libssh2 (1.3), zlib (1.2.5), librtmp (2.3) | ||||
| ## | ||||
| ## Usage: | ||||
| ## mingw32-make -f Makefile.m32 [SSL=1] [SSH2=1] [ZLIB=1] [IDN=1] [SSPI=1] [IPV6=1] [LDAPS=1] [RTMP=1] [DYN=1] | ||||
| ## Usage:   mingw32-make -f Makefile.m32 CFG=-feature1[-feature2][-feature3][...] | ||||
| ## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-sspi-winidn | ||||
| ## | ||||
| ## Hint: you can also set environment vars to control the build, f.e.: | ||||
| ## set ZLIB_PATH=c:/zlib-1.2.5 | ||||
| ## set ZLIB=1 | ||||
| ## | ||||
| ## Comments to: Troy Engel <tengel@sonic.net> or | ||||
| ##              Joern Hartroth <hartroth@acm.org> | ||||
| ######################################################################### | ||||
| # | ||||
| ########################################################################### | ||||
|  | ||||
| # Edit the path below to point to the base of your Zlib sources. | ||||
| ifndef ZLIB_PATH | ||||
| @@ -22,47 +20,118 @@ endif | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../openssl-0.9.8r | ||||
| endif | ||||
| ifndef OPENSSL_INCLUDE | ||||
| OPENSSL_INCLUDE = $(OPENSSL_PATH)/outinc | ||||
| endif | ||||
| ifndef OPENSSL_LIBPATH | ||||
| OPENSSL_LIBPATH = $(OPENSSL_PATH)/out | ||||
| endif | ||||
| ifndef OPENSSL_LIBS | ||||
| OPENSSL_LIBS = -leay32 -lssl32 | ||||
| endif | ||||
| # Edit the path below to point to the base of your LibSSH2 package. | ||||
| ifndef LIBSSH2_PATH | ||||
| LIBSSH2_PATH = ../../libssh2-1.2.7 | ||||
| LIBSSH2_PATH = ../../libssh2-1.3.0 | ||||
| endif | ||||
| # Edit the path below to point to the base of your librtmp package. | ||||
| ifndef LIBRTMP_PATH | ||||
| LIBRTMP_PATH = ../../librtmp-2.3 | ||||
| endif | ||||
| # Edit the path below to point to the base of your libidn package. | ||||
| ifndef LIBIDN_PATH | ||||
| LIBIDN_PATH = ../../libidn-1.18 | ||||
| endif | ||||
| # Edit the path below to point to the base of your librtmp package. | ||||
| ifndef LIBRTMP_PATH | ||||
| LIBRTMP_PATH = ../../librtmp-2.3 | ||||
| # Edit the path below to point to the base of your MS IDN package. | ||||
| # Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1 | ||||
| # http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815 | ||||
| ifndef WINIDN_PATH | ||||
| WINIDN_PATH = ../../Microsoft IDN Mitigation APIs | ||||
| endif | ||||
| # Edit the path below to point to the base of your Novell LDAP NDK. | ||||
| ifndef LDAP_SDK | ||||
| LDAP_SDK = c:/novell/ndk/cldapsdk/win32 | ||||
| endif | ||||
|  | ||||
| PROOT = .. | ||||
|  | ||||
| # Edit the path below to point to the base of your c-ares package. | ||||
| ifndef LIBCARES_PATH | ||||
| LIBCARES_PATH = ../ares | ||||
| LIBCARES_PATH = $(PROOT)/ares | ||||
| endif | ||||
|  | ||||
| # Edit the var below to set to your architecture or set environment var. | ||||
| ifndef ARCH | ||||
| ARCH = w32 | ||||
| endif | ||||
|  | ||||
| CC = gcc | ||||
| AR = ar | ||||
| CFLAGS = -g -O2 -Wall | ||||
| CFLAGS += -fno-strict-aliasing | ||||
| ifeq ($(ARCH),w64) | ||||
| CFLAGS += -D_AMD64_ | ||||
| endif | ||||
| # comment LDFLAGS below to keep debug info | ||||
| LDFLAGS = -s | ||||
| AR = ar | ||||
| RANLIB = ranlib | ||||
| RC = windres | ||||
| RCFLAGS = --include-dir=../include -DDEBUGBUILD=0 -O COFF -i | ||||
| RM = del /q /f 2>NUL | ||||
| RCFLAGS = --include-dir=$(PROOT)/include -DDEBUGBUILD=0 -O COFF -i | ||||
| STRIP = strip -g | ||||
|  | ||||
| RM = del /q /f 2>NUL | ||||
| CP = copy | ||||
|  | ||||
| ######################################################## | ||||
| ## Nothing more to do below this line! | ||||
|  | ||||
| ifeq ($(findstring -dyn,$(CFG)),-dyn) | ||||
| DYN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ares,$(CFG)),-ares) | ||||
| ARES = 1 | ||||
| endif | ||||
| ifeq ($(findstring -rtmp,$(CFG)),-rtmp) | ||||
| RTMP = 1 | ||||
| SSL = 1 | ||||
| ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ssh2,$(CFG)),-ssh2) | ||||
| SSH2 = 1 | ||||
| SSL = 1 | ||||
| ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ssl,$(CFG)),-ssl) | ||||
| SSL = 1 | ||||
| endif | ||||
| ifeq ($(findstring -zlib,$(CFG)),-zlib) | ||||
| ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -idn,$(CFG)),-idn) | ||||
| IDN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -winidn,$(CFG)),-winidn) | ||||
| WINIDN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -sspi,$(CFG)),-sspi) | ||||
| SSPI = 1 | ||||
| endif | ||||
| ifeq ($(findstring -spnego,$(CFG)),-spnego) | ||||
| SPNEGO = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ldaps,$(CFG)),-ldaps) | ||||
| LDAPS = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ipv6,$(CFG)),-ipv6) | ||||
| IPV6 = 1 | ||||
| endif | ||||
|  | ||||
| INCLUDES = -I. -I../include | ||||
| CFLAGS = -g -O2 -DBUILDING_LIBCURL | ||||
| CFLAGS += -DBUILDING_LIBCURL | ||||
|  | ||||
| ifdef ARES | ||||
|   INCLUDES += -I$(LIBCARES_PATH) | ||||
|   INCLUDES += -I"$(LIBCARES_PATH)" | ||||
|   CFLAGS += -DUSE_ARES | ||||
|   DLL_LIBS += -L$(LIBCARES_PATH) -lcares | ||||
|   DLL_LIBS += -L"$(LIBCARES_PATH)" -lcares | ||||
|   libcurl_dll_DEPENDENCIES = $(LIBCARES_PATH)/libcares.a | ||||
| endif | ||||
| ifdef RTMP | ||||
| @@ -73,30 +142,39 @@ endif | ||||
| ifdef SSH2 | ||||
|   INCLUDES += -I"$(LIBSSH2_PATH)/include" -I"$(LIBSSH2_PATH)/win32" | ||||
|   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H | ||||
|   DLL_LIBS += -L$(LIBSSH2_PATH)/win32 -lssh2 | ||||
|   DLL_LIBS += -L"$(LIBSSH2_PATH)/win32" -lssh2 | ||||
| endif | ||||
| ifdef SSL | ||||
|   INCLUDES += -I"$(OPENSSL_PATH)/outinc" -I"$(OPENSSL_PATH)/outinc/openssl" | ||||
|   INCLUDES += -I"$(OPENSSL_INCLUDE)" | ||||
|   CFLAGS += -DUSE_SSLEAY -DUSE_OPENSSL -DHAVE_OPENSSL_ENGINE_H -DHAVE_OPENSSL_PKCS12_H \ | ||||
|             -DHAVE_ENGINE_LOAD_BUILTIN_ENGINES -DOPENSSL_NO_KRB5 \ | ||||
|             -DCURL_WANTS_CA_BUNDLE_ENV | ||||
|   DLL_LIBS += -L$(OPENSSL_PATH)/out -leay32 -lssl32 | ||||
|   DLL_LIBS += -L"$(OPENSSL_LIBPATH)" $(OPENSSL_LIBS) | ||||
| endif | ||||
| ifdef ZLIB | ||||
|   INCLUDES += -I"$(ZLIB_PATH)" | ||||
|   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H | ||||
|   DLL_LIBS += -L$(ZLIB_PATH) -lz | ||||
|   DLL_LIBS += -L"$(ZLIB_PATH)" -lz | ||||
| endif | ||||
| ifdef IDN | ||||
|   INCLUDES += -I"$(LIBIDN_PATH)/include" | ||||
|   CFLAGS += -DUSE_LIBIDN | ||||
|   DLL_LIBS += -L$(LIBIDN_PATH)/lib -lidn | ||||
|   DLL_LIBS += -L"$(LIBIDN_PATH)/lib" -lidn | ||||
| else | ||||
| ifdef WINIDN | ||||
|   CFLAGS += -DUSE_WIN32_IDN | ||||
|   CFLAGS += -DWANT_IDN_PROTOTYPES | ||||
|   DLL_LIBS += -L"$(WINIDN_PATH)" -lnormaliz | ||||
| endif | ||||
| endif | ||||
| ifdef SSPI | ||||
|   CFLAGS += -DUSE_WINDOWS_SSPI | ||||
| endif | ||||
| ifdef SPNEGO | ||||
|   CFLAGS += -DHAVE_SPNEGO | ||||
| endif | ||||
| ifdef IPV6 | ||||
|   CFLAGS += -DENABLE_IPV6 | ||||
|   CFLAGS += -DENABLE_IPV6 -D_WIN32_WINNT=0x0501 | ||||
| endif | ||||
| ifdef LDAPS | ||||
|   CFLAGS += -DHAVE_LDAP_SSL | ||||
| @@ -113,11 +191,10 @@ ifdef USE_LDAP_OPENLDAP | ||||
| endif | ||||
| ifndef USE_LDAP_NOVELL | ||||
| ifndef USE_LDAP_OPENLDAP | ||||
| DLL_LIBS += -lwldap32 | ||||
|   DLL_LIBS += -lwldap32 | ||||
| endif | ||||
| endif | ||||
| DLL_LIBS += -lws2_32 | ||||
| COMPILE = $(CC) $(INCLUDES) $(CFLAGS) | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
| @@ -131,7 +208,6 @@ libcurl_a_DEPENDENCIES := $(strip $(CSOURCES) $(HHEADERS)) | ||||
|  | ||||
| RESOURCE = libcurl.res | ||||
|  | ||||
| .SUFFIXES: .rc .res | ||||
|  | ||||
| all: $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) | ||||
|  | ||||
| @@ -148,20 +224,25 @@ $(libcurl_dll_LIBRARY): $(libcurl_a_OBJECTS) $(RESOURCE) $(libcurl_dll_DEPENDENC | ||||
| 	$(CC) $(LDFLAGS) -shared -Wl,--out-implib,$(libcurl_dll_a_LIBRARY) \ | ||||
| 	  -o $@ $(libcurl_a_OBJECTS) $(RESOURCE) $(DLL_LIBS) | ||||
|  | ||||
| .c.o: | ||||
| 	$(COMPILE) -c $< | ||||
| %.o: %.c $(PROOT)/include/curl/curlbuild.h | ||||
| 	$(CC) $(INCLUDES) $(CFLAGS) -c $< | ||||
|  | ||||
| .rc.res: | ||||
| %.res: %.rc | ||||
| 	$(RC) $(RCFLAGS) $< -o $@ | ||||
|  | ||||
| clean: | ||||
| ifeq "$(wildcard $(PROOT)/include/curl/curlbuild.h.dist)" "$(PROOT)/include/curl/curlbuild.h.dist" | ||||
| 	-$(RM) $(subst /,\,$(PROOT)/include/curl/curlbuild.h) | ||||
| endif | ||||
| 	-$(RM) $(libcurl_a_OBJECTS) $(RESOURCE) | ||||
|  | ||||
| distclean vclean: clean | ||||
| 	-$(RM) $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_a_LIBRARY) | ||||
|  | ||||
| FORCE: ; | ||||
|  | ||||
| $(LIBCARES_PATH)/libcares.a: | ||||
| 	$(MAKE) -C $(LIBCARES_PATH) -f Makefile.m32 | ||||
|  | ||||
| $(PROOT)/include/curl/curlbuild.h: | ||||
| 	@echo Creating $@ | ||||
| 	@$(CP) $(subst /,\,$@).dist $(subst /,\,$@) | ||||
|  | ||||
|   | ||||
| @@ -24,7 +24,7 @@ endif | ||||
|  | ||||
| # Edit the path below to point to the base of your LibSSH2 package. | ||||
| ifndef LIBSSH2_PATH | ||||
| LIBSSH2_PATH = ../../libssh2-1.2.7 | ||||
| LIBSSH2_PATH = ../../libssh2-1.3.0 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your axTLS package. | ||||
| @@ -42,6 +42,11 @@ ifndef LIBRTMP_PATH | ||||
| LIBRTMP_PATH = ../../librtmp-2.3 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your fbopenssl package. | ||||
| ifndef FBOPENSSL_PATH | ||||
| FBOPENSSL_PATH = ../../fbopenssl-0.4 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your c-ares package. | ||||
| ifndef LIBCARES_PATH | ||||
| LIBCARES_PATH = ../ares | ||||
| @@ -95,7 +100,7 @@ else | ||||
| endif | ||||
| PERL	= perl | ||||
| # Here you can find a native Win32 binary of the original awk: | ||||
| # http://www.gknw.net/development/prgtools/awk-20070501.zip | ||||
| # http://www.gknw.net/development/prgtools/awk-20100523.zip | ||||
| AWK	= awk | ||||
| CP	= cp -afv | ||||
| MKDIR	= mkdir | ||||
| @@ -181,6 +186,43 @@ CURL_LIB = ../lib | ||||
|  | ||||
| INCLUDES = -I$(CURL_INC) -I$(CURL_LIB) | ||||
|  | ||||
| ifeq ($(findstring -static,$(CFG)),-static) | ||||
| LINK_STATIC = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ares,$(CFG)),-ares) | ||||
| WITH_ARES = 1 | ||||
| endif | ||||
| ifeq ($(findstring -rtmp,$(CFG)),-rtmp) | ||||
| WITH_RTMP = 1 | ||||
| WITH_SSL = 1 | ||||
| WITH_ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ssh2,$(CFG)),-ssh2) | ||||
| WITH_SSH2 = 1 | ||||
| WITH_SSL = 1 | ||||
| WITH_ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -axtls,$(CFG)),-axtls) | ||||
| WITH_AXTLS = 1 | ||||
| WITH_SSL = | ||||
| else | ||||
| ifeq ($(findstring -ssl,$(CFG)),-ssl) | ||||
| WITH_SSL = 1 | ||||
| endif | ||||
| endif | ||||
| ifeq ($(findstring -zlib,$(CFG)),-zlib) | ||||
| WITH_ZLIB = 1 | ||||
| endif | ||||
| ifeq ($(findstring -idn,$(CFG)),-idn) | ||||
| WITH_IDN = 1 | ||||
| endif | ||||
| ifeq ($(findstring -spnego,$(CFG)),-spnego) | ||||
| WITH_SPNEGO = 1 | ||||
| endif | ||||
| ifeq ($(findstring -ipv6,$(CFG)),-ipv6) | ||||
| ENABLE_IPV6 = 1 | ||||
| endif | ||||
|  | ||||
| ifdef WITH_ARES | ||||
| 	INCLUDES += -I$(LIBCARES_PATH) | ||||
| 	LDLIBS += $(LIBCARES_PATH)/libcares.$(LIBEXT) | ||||
| @@ -204,6 +246,10 @@ ifdef WITH_SSL | ||||
| 	LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/crypto.$(LIBEXT) | ||||
| 	IMPORTS += GetProcessSwitchCount RunningProcess | ||||
| 	INSTDEP += ca-bundle.crt | ||||
| ifdef WITH_SPNEGO | ||||
| 	INCLUDES += -I$(FBOPENSSL_PATH)/include | ||||
| 	LDLIBS += $(FBOPENSSL_PATH)/nw/fbopenssl.$(LIBEXT) | ||||
| endif | ||||
| else | ||||
| ifdef WITH_AXTLS | ||||
| 	INCLUDES += -I$(AXTLS_PATH)/inc | ||||
| @@ -498,6 +544,7 @@ endif | ||||
| 	@echo $(DL)#define USE_MANUAL 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ARPA_INET_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ASSERT_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ERRNO_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ERR_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_FCNTL_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_GETHOSTBYADDR 1$(DL) >> $@ | ||||
| @@ -583,6 +630,9 @@ ifdef WITH_SSL | ||||
| 	@echo $(DL)#define HAVE_LIBSSL 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_LIBCRYPTO 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define OPENSSL_NO_KRB5 1$(DL) >> $@ | ||||
| ifdef WITH_SPNEGO | ||||
| 	@echo $(DL)#define HAVE_SPNEGO 1$(DL) >> $@ | ||||
| endif | ||||
| else | ||||
| ifdef WITH_AXTLS | ||||
| 	@echo $(DL)#define USE_AXTLS 1$(DL) >> $@ | ||||
|   | ||||
| @@ -20,6 +20,11 @@ | ||||
| # | ||||
| #*************************************************************************** | ||||
|  | ||||
| # All files in the Makefile.vc* series are generated automatically from the | ||||
| # one made for MSVC version 6. Alas, if you want to do changes to any of the | ||||
| # fiels and send back to the project, edit the version six, make your diff and | ||||
| # mail curl-library. | ||||
|  | ||||
| ########################################################################### | ||||
| # | ||||
| # Makefile for building libcurl with MSVC6 | ||||
| @@ -59,13 +64,14 @@ | ||||
|  | ||||
| !INCLUDE ..\Makefile.msvc.names | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| !IFNDEF OPENSSL_PATH | ||||
| OPENSSL_PATH   = ../../openssl-0.9.8r | ||||
| !ENDIF | ||||
|  | ||||
| !IFNDEF LIBSSH2_PATH | ||||
| LIBSSH2_PATH   = ../../libssh2-1.2.8 | ||||
| !ENDIF | ||||
|  | ||||
| !IFNDEF ZLIB_PATH | ||||
| ZLIB_PATH  = ../../zlib-1.2.5 | ||||
| !ENDIF | ||||
| @@ -100,8 +106,9 @@ WINDOWS_SDK_PATH = "$(PROGRAMFILES)\Microsoft SDK" | ||||
| CCNODBG    = cl.exe /O2 /DNDEBUG | ||||
| CCDEBUG    = cl.exe /Od /Gm /Zi /D_DEBUG /GZ | ||||
| CFLAGSSSL  = /DUSE_SSLEAY /I "$(OPENSSL_PATH)/inc32" /I "$(OPENSSL_PATH)/inc32/openssl" | ||||
| CFLAGSSSH2 = /DUSE_LIBSSH2 /DCURL_DISABLE_LDAP /DHAVE_LIBSSH2 /DHAVE_LIBSSH2_H /DLIBSSH2_WIN32 /DLIBSSH2_LIBRARY /I "$(LIBSSH2_PATH)/include" | ||||
| CFLAGSZLIB = /DHAVE_ZLIB_H /DHAVE_ZLIB /DHAVE_LIBZ /I "$(ZLIB_PATH)" | ||||
| CFLAGS     = /I. /I../include /nologo /W3 /GX /DWIN32 /YX /FD /c /DBUILDING_LIBCURL | ||||
| CFLAGS     = /I. /I../include /nologo /W3 /GX /DWIN32 /YX /FD /c /DBUILDING_LIBCURL /D_BIND_TO_CURRENT_VCLIBS_VERSION=1 | ||||
| CFLAGSLIB  = /DCURL_STATICLIB | ||||
| LNKDLL     = link.exe /DLL | ||||
| LNKLIB     = link.exe /lib | ||||
| @@ -219,6 +226,36 @@ CC       = $(CCNODBG) $(RTLIB) $(CFLAGSSSL) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-ssl-ssh2-zlib | ||||
|  | ||||
| !IF "$(CFG)" == "release-ssl-ssh2-zlib" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32" | ||||
| LFLAGSSSH2 = "/LIBPATH:$(LIBSSH2_PATH)" | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(LFLAGSSSL) $(LFLAGSSSH2) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCNODBG) $(RTLIB) $(CFLAGSSSL) $(CFLAGSSSH2) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(LIBSSH2_PATH)/Release/src/libssh2.lib $(ZLIB_PATH)/zlib.lib | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl-ssh2-zlib | ||||
|  | ||||
| !IF "$(CFG)" == "debug-ssl-ssh2-zlib" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LFLAGSSSH2 = "/LIBPATH:$(LIBSSH2_PATH)" | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32" | ||||
| LNK      = $(LNKLIB) $(ZLIBLIBS) $(LFLAGSSSL) $(LFLAGSSSH2) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(RTLIBD) $(CFLAGSSSL) $(CFLAGSSSH2) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(LIBSSH2_PATH)/Release/src/libssh2.lib $(ZLIB_PATH)/zlib.lib | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-dll | ||||
|  | ||||
| @@ -418,6 +455,7 @@ RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !MESSAGE   release-ssl                  - release static library with ssl | ||||
| !MESSAGE   release-zlib                 - release static library with zlib | ||||
| !MESSAGE   release-ssl-zlib             - release static library with ssl and zlib | ||||
| !MESSAGE   release-ssl-ssh2-zlib        - release static library with ssl, ssh2 and zlib | ||||
| !MESSAGE   release-ssl-dll              - release static library with dynamic ssl | ||||
| !MESSAGE   release-zlib-dll             - release static library with dynamic zlib | ||||
| !MESSAGE   release-ssl-dll-zlib-dll     - release static library with dynamic ssl and dynamic zlib | ||||
| @@ -425,6 +463,7 @@ RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !MESSAGE   release-dll-ssl-dll          - release dynamic library with dynamic ssl | ||||
| !MESSAGE   release-dll-zlib-dll         - release dynamic library with dynamic zlib | ||||
| !MESSAGE   release-dll-ssl-dll-zlib-dll - release dynamic library with dynamic ssl and dynamic zlib | ||||
| !MESSAGE   debug-ssl-ssh2-zlib          - debug static library with ssl, ssh2 and zlib | ||||
| !MESSAGE   debug                        - debug static library | ||||
| !MESSAGE   debug-ssl                    - debug static library with ssl | ||||
| !MESSAGE   debug-zlib                   - debug static library with zlib | ||||
| @@ -457,6 +496,8 @@ clean: | ||||
| # A config was provided, so the library can be built. | ||||
| # | ||||
| X_OBJS= \ | ||||
| 	$(DIROBJ)\asyn-ares.obj \ | ||||
| 	$(DIROBJ)\asyn-thread.obj \ | ||||
| 	$(DIROBJ)\base64.obj \ | ||||
| 	$(DIROBJ)\connect.obj \ | ||||
| 	$(DIROBJ)\content_encoding.obj \ | ||||
| @@ -465,6 +506,10 @@ X_OBJS= \ | ||||
| 	$(DIROBJ)\curl_fnmatch.obj \ | ||||
| 	$(DIROBJ)\curl_gethostname.obj \ | ||||
| 	$(DIROBJ)\curl_memrchr.obj \ | ||||
| 	$(DIROBJ)\curl_ntlm.obj \ | ||||
| 	$(DIROBJ)\curl_ntlm_core.obj \ | ||||
| 	$(DIROBJ)\curl_ntlm_msgs.obj \ | ||||
| 	$(DIROBJ)\curl_ntlm_wb.obj \ | ||||
| 	$(DIROBJ)\curl_rand.obj \ | ||||
| 	$(DIROBJ)\curl_rtmp.obj \ | ||||
| 	$(DIROBJ)\curl_sspi.obj \ | ||||
| @@ -479,22 +524,19 @@ X_OBJS= \ | ||||
| 	$(DIROBJ)\ftp.obj \ | ||||
| 	$(DIROBJ)\getenv.obj \ | ||||
| 	$(DIROBJ)\getinfo.obj \ | ||||
| 	$(DIROBJ)\gtls.obj \ | ||||
| 	$(DIROBJ)\gopher.obj \ | ||||
| 	$(DIROBJ)\gtls.obj \ | ||||
| 	$(DIROBJ)\hash.obj \ | ||||
| 	$(DIROBJ)\hmac.obj \ | ||||
| 	$(DIROBJ)\hostares.obj \ | ||||
| 	$(DIROBJ)\hostasyn.obj \ | ||||
| 	$(DIROBJ)\hostip4.obj \ | ||||
| 	$(DIROBJ)\hostip6.obj \ | ||||
| 	$(DIROBJ)\hostip.obj \ | ||||
| 	$(DIROBJ)\hostsyn.obj \ | ||||
| 	$(DIROBJ)\hostthre.obj \ | ||||
| 	$(DIROBJ)\http_chunks.obj \ | ||||
| 	$(DIROBJ)\http_digest.obj \ | ||||
| 	$(DIROBJ)\http_negotiate.obj \ | ||||
|         $(DIROBJ)\http_negotiate_sspi.obj \ | ||||
| 	$(DIROBJ)\http_ntlm.obj \ | ||||
| 	$(DIROBJ)\http.obj \ | ||||
| 	$(DIROBJ)\http_proxy.obj \ | ||||
| 	$(DIROBJ)\if2ip.obj \ | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| #Description: makefile to be used in order to compile libcurl for VxWoorks 6.3. | ||||
| # | ||||
| #How to use: | ||||
| #             1. Adjust environment variables at the file begining | ||||
| #             1. Adjust environment variables at the file beginning | ||||
| #             2. Open the Command Prompt window and change directory ('cd') | ||||
| #                into the 'lib' folder | ||||
| #             3. Add <CYGWIN>/bin folder to the PATH environment variable | ||||
|   | ||||
| @@ -33,21 +33,21 @@ Gallagher, and support for the 'gzip' encoding was added by Dan Fandrich. | ||||
|  | ||||
| To cause libcurl to request a content encoding use: | ||||
|  | ||||
|     curl_easy_setopt(curl, CURLOPT_ENCODING, <string>) | ||||
|     curl_easy_setopt(curl, CURLOPT_ACCEPT_ENCODING, <string>) | ||||
|  | ||||
| where <string> is the intended value of the Accept-Encoding header. | ||||
|  | ||||
| Currently, libcurl only understands how to process responses that use the | ||||
| "deflate" or "gzip" Content-Encoding, so the only values for CURLOPT_ENCODING | ||||
| that will work (besides "identity," which does nothing) are "deflate" and | ||||
| "gzip" If a response is encoded using the "compress" or methods, libcurl will | ||||
| return an error indicating that the response could not be decoded.  If | ||||
| <string> is NULL no Accept-Encoding header is generated.  If <string> is a | ||||
| zero-length string, then an Accept-Encoding header containing all supported | ||||
| encodings will be generated. | ||||
| "deflate" or "gzip" Content-Encoding, so the only values for | ||||
| CURLOPT_ACCEPT_ENCODING that will work (besides "identity," which does | ||||
| nothing) are "deflate" and "gzip" If a response is encoded using the | ||||
| "compress" or methods, libcurl will return an error indicating that the | ||||
| response could not be decoded.  If <string> is NULL no Accept-Encoding header | ||||
| is generated.  If <string> is a zero-length string, then an Accept-Encoding | ||||
| header containing all supported encodings will be generated. | ||||
|  | ||||
| The CURLOPT_ENCODING must be set to any non-NULL value for content to be | ||||
| automatically decoded.  If it is not set and the server still sends encoded | ||||
| The CURLOPT_ACCEPT_ENCODING must be set to any non-NULL value for content to | ||||
| be automatically decoded.  If it is not set and the server still sends encoded | ||||
| content (despite not having been asked), the data is returned in its raw form | ||||
| and the Content-Encoding type is not checked. | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -26,9 +26,11 @@ | ||||
|  * Telnet option defines. Add more here if in need. | ||||
|  */ | ||||
| #define CURL_TELOPT_BINARY   0  /* binary 8bit data */ | ||||
| #define CURL_TELOPT_SGA      3  /* Supress Go Ahead */ | ||||
| #define CURL_TELOPT_ECHO     1  /* just echo! */ | ||||
| #define CURL_TELOPT_SGA      3  /* Suppress Go Ahead */ | ||||
| #define CURL_TELOPT_EXOPL  255  /* EXtended OPtions List */ | ||||
| #define CURL_TELOPT_TTYPE   24  /* Terminal TYPE */ | ||||
| #define CURL_TELOPT_NAWS    31  /* Negotiate About Window Size */ | ||||
| #define CURL_TELOPT_XDISPLOC 35 /* X DISPlay LOCation */ | ||||
|  | ||||
| #define CURL_TELOPT_NEW_ENVIRON 39  /* NEW ENVIRONment variables */ | ||||
|   | ||||
| @@ -22,8 +22,6 @@ | ||||
| 
 | ||||
| #include "setup.h" | ||||
| 
 | ||||
| #include <string.h> | ||||
| 
 | ||||
| #ifdef HAVE_LIMITS_H | ||||
| #include <limits.h> | ||||
| #endif | ||||
| @@ -39,16 +37,12 @@ | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
| #ifdef HAVE_STDLIB_H | ||||
| #include <stdlib.h>     /* required for free() prototypes */ | ||||
| #endif | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h>     /* for the close() proto */ | ||||
| #endif | ||||
| #ifdef __VMS | ||||
| #include <in.h> | ||||
| #include <inet.h> | ||||
| #include <stdlib.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef HAVE_PROCESS_H | ||||
| @@ -60,6 +54,14 @@ | ||||
| #define in_addr_t unsigned long | ||||
| #endif | ||||
| 
 | ||||
| /***********************************************************************
 | ||||
|  * Only for ares-enabled builds | ||||
|  * And only for functions that fulfill the asynch resolver backend API | ||||
|  * as defined in asyn.h, nothing else belongs in this file! | ||||
|  **********************************************************************/ | ||||
| 
 | ||||
| #ifdef CURLRES_ARES | ||||
| 
 | ||||
| #include "urldata.h" | ||||
| #include "sendf.h" | ||||
| #include "hostip.h" | ||||
| @@ -76,18 +78,140 @@ | ||||
| #define _MPRINTF_REPLACE /* use our functions only */ | ||||
| #include <curl/mprintf.h> | ||||
| 
 | ||||
| #  if defined(CURL_STATICLIB) && !defined(CARES_STATICLIB) && \ | ||||
|      (defined(WIN32) || defined(_WIN32) || defined(__SYMBIAN32__)) | ||||
| #    define CARES_STATICLIB | ||||
| #  endif | ||||
| #  include <ares.h> | ||||
| 
 | ||||
| #if ARES_VERSION >= 0x010500 | ||||
| /* c-ares 1.5.0 or later, the callback proto is modified */ | ||||
| #define HAVE_CARES_CALLBACK_TIMEOUTS 1 | ||||
| #endif | ||||
| 
 | ||||
| #include "curl_memory.h" | ||||
| /* The last #include file should be: */ | ||||
| #include "memdebug.h" | ||||
| 
 | ||||
| /***********************************************************************
 | ||||
|  * Only for ares-enabled builds | ||||
|  **********************************************************************/ | ||||
| 
 | ||||
| #ifdef CURLRES_ARES | ||||
| struct ResolverResults { | ||||
|   int num_pending; /* number of ares_gethostbyname() requests */ | ||||
|   Curl_addrinfo *temp_ai; /* intermediary result while fetching c-ares parts */ | ||||
|   int last_status; | ||||
| }; | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolv_fdset() is called when someone from the outside world (using | ||||
|  * Curl_resolver_global_init() - the generic low-level asynchronous name | ||||
|  * resolve API.  Called from curl_global_init() to initialize global resolver | ||||
|  * environment.  Initializes ares library. | ||||
|  */ | ||||
| int Curl_resolver_global_init(void) | ||||
| { | ||||
| #ifdef CARES_HAVE_ARES_LIBRARY_INIT | ||||
|   if(ares_library_init(ARES_LIB_INIT_ALL)) { | ||||
|     return CURLE_FAILED_INIT; | ||||
|   } | ||||
| #endif | ||||
|   return CURLE_OK; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_global_cleanup() | ||||
|  * | ||||
|  * Called from curl_global_cleanup() to destroy global resolver environment. | ||||
|  * Deinitializes ares library. | ||||
|  */ | ||||
| void Curl_resolver_global_cleanup(void) | ||||
| { | ||||
| #ifdef CARES_HAVE_ARES_LIBRARY_CLEANUP | ||||
|   ares_library_cleanup(); | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_init() | ||||
|  * | ||||
|  * Called from curl_easy_init() -> Curl_open() to initialize resolver | ||||
|  * URL-state specific environment ('resolver' member of the UrlState | ||||
|  * structure).  Fills the passed pointer by the initialized ares_channel. | ||||
|  */ | ||||
| CURLcode Curl_resolver_init(void **resolver) | ||||
| { | ||||
|   int status = ares_init((ares_channel*)resolver); | ||||
|   if(status != ARES_SUCCESS) { | ||||
|     if(status == ARES_ENOMEM) | ||||
|       return CURLE_OUT_OF_MEMORY; | ||||
|     else | ||||
|       return CURLE_FAILED_INIT; | ||||
|   } | ||||
|   return CURLE_OK; | ||||
|   /* make sure that all other returns from this function should destroy the
 | ||||
|      ares channel before returning error! */ | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_cleanup() | ||||
|  * | ||||
|  * Called from curl_easy_cleanup() -> Curl_close() to cleanup resolver | ||||
|  * URL-state specific environment ('resolver' member of the UrlState | ||||
|  * structure).  Destroys the ares channel. | ||||
|  */ | ||||
| void Curl_resolver_cleanup(void *resolver) | ||||
| { | ||||
|   ares_destroy((ares_channel)resolver); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_duphandle() | ||||
|  * | ||||
|  * Called from curl_easy_duphandle() to duplicate resolver URL-state specific | ||||
|  * environment ('resolver' member of the UrlState structure).  Duplicates the | ||||
|  * 'from' ares channel and passes the resulting channel to the 'to' pointer. | ||||
|  */ | ||||
| int Curl_resolver_duphandle(void **to, void *from) | ||||
| { | ||||
|   /* Clone the ares channel for the new handle */ | ||||
|   if(ARES_SUCCESS != ares_dup((ares_channel*)to,(ares_channel)from)) | ||||
|     return CURLE_FAILED_INIT; | ||||
|   return CURLE_OK; | ||||
| } | ||||
| 
 | ||||
| static void destroy_async_data (struct Curl_async *async); | ||||
| 
 | ||||
| /*
 | ||||
|  * Cancel all possibly still on-going resolves for this connection. | ||||
|  */ | ||||
| void Curl_resolver_cancel(struct connectdata *conn) | ||||
| { | ||||
|   if(conn && conn->data && conn->data->state.resolver) | ||||
|     ares_cancel((ares_channel)conn->data->state.resolver); | ||||
|   destroy_async_data(&conn->async); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * destroy_async_data() cleans up async resolver data. | ||||
|  */ | ||||
| static void destroy_async_data (struct Curl_async *async) | ||||
| { | ||||
|   if(async->hostname) | ||||
|     free(async->hostname); | ||||
| 
 | ||||
|   if(async->os_specific) { | ||||
|     struct ResolverResults *res = (struct ResolverResults *)async->os_specific; | ||||
|     if(res) { | ||||
|       if(res->temp_ai) { | ||||
|         Curl_freeaddrinfo(res->temp_ai); | ||||
|         res->temp_ai = NULL; | ||||
|       } | ||||
|       free(res); | ||||
|     } | ||||
|     async->os_specific = NULL; | ||||
|   } | ||||
| 
 | ||||
|   async->hostname = NULL; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_fdset() is called when someone from the outside world (using | ||||
|  * curl_multi_fdset()) wants to get our fd_set setup and we're talking with | ||||
|  * ares. The caller must make sure that this function is only called when we | ||||
|  * have a working ares channel. | ||||
| @@ -95,25 +219,27 @@ | ||||
|  * Returns: CURLE_OK always! | ||||
|  */ | ||||
| 
 | ||||
| int Curl_resolv_getsock(struct connectdata *conn, | ||||
|                         curl_socket_t *socks, | ||||
|                         int numsocks) | ||||
| int Curl_resolver_getsock(struct connectdata *conn, | ||||
|                           curl_socket_t *socks, | ||||
|                           int numsocks) | ||||
| 
 | ||||
| { | ||||
|   struct timeval maxtime; | ||||
|   struct timeval timebuf; | ||||
|   struct timeval *timeout; | ||||
|   int max = ares_getsock(conn->data->state.areschannel, | ||||
|   long milli; | ||||
|   int max = ares_getsock((ares_channel)conn->data->state.resolver, | ||||
|                          (ares_socket_t *)socks, numsocks); | ||||
| 
 | ||||
| 
 | ||||
|   maxtime.tv_sec = CURL_TIMEOUT_RESOLVE; | ||||
|   maxtime.tv_usec = 0; | ||||
| 
 | ||||
|   timeout = ares_timeout(conn->data->state.areschannel, &maxtime, &timebuf); | ||||
| 
 | ||||
|   Curl_expire(conn->data, | ||||
|               (timeout->tv_sec * 1000) + (timeout->tv_usec/1000)); | ||||
|   timeout = ares_timeout((ares_channel)conn->data->state.resolver, &maxtime, | ||||
|                          &timebuf); | ||||
|   milli = (timeout->tv_sec * 1000) + (timeout->tv_usec/1000); | ||||
|   if(milli == 0) | ||||
|     milli += 10; | ||||
|   Curl_expire(conn->data, milli); | ||||
| 
 | ||||
|   return max; | ||||
| } | ||||
| @@ -138,7 +264,8 @@ static int waitperform(struct connectdata *conn, int timeout_ms) | ||||
|   int i; | ||||
|   int num = 0; | ||||
| 
 | ||||
|   bitmask = ares_getsock(data->state.areschannel, socks, ARES_GETSOCK_MAXNUM); | ||||
|   bitmask = ares_getsock((ares_channel)data->state.resolver, socks, | ||||
|                          ARES_GETSOCK_MAXNUM); | ||||
| 
 | ||||
|   for(i=0; i < ARES_GETSOCK_MAXNUM; i++) { | ||||
|     pfd[i].events = 0; | ||||
| @@ -165,11 +292,12 @@ static int waitperform(struct connectdata *conn, int timeout_ms) | ||||
|   if(!nfds) | ||||
|     /* Call ares_process() unconditonally here, even if we simply timed out
 | ||||
|        above, as otherwise the ares name resolve won't timeout! */ | ||||
|     ares_process_fd(data->state.areschannel, ARES_SOCKET_BAD, ARES_SOCKET_BAD); | ||||
|     ares_process_fd((ares_channel)data->state.resolver, ARES_SOCKET_BAD, | ||||
|                     ARES_SOCKET_BAD); | ||||
|   else { | ||||
|     /* move through the descriptors and ask for processing on them */ | ||||
|     for(i=0; i < num; i++) | ||||
|       ares_process_fd(data->state.areschannel, | ||||
|       ares_process_fd((ares_channel)data->state.resolver, | ||||
|                       pfd[i].revents & (POLLRDNORM|POLLIN)? | ||||
|                       pfd[i].fd:ARES_SOCKET_BAD, | ||||
|                       pfd[i].revents & (POLLWRNORM|POLLOUT)? | ||||
| @@ -179,27 +307,36 @@ static int waitperform(struct connectdata *conn, int timeout_ms) | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_is_resolved() is called repeatedly to check if a previous name resolve | ||||
|  * request has completed. It should also make sure to time-out if the | ||||
|  * operation seems to take too long. | ||||
|  * Curl_resolver_is_resolved() is called repeatedly to check if a previous | ||||
|  * name resolve request has completed. It should also make sure to time-out if | ||||
|  * the operation seems to take too long. | ||||
|  * | ||||
|  * Returns normal CURLcode errors. | ||||
|  */ | ||||
| CURLcode Curl_is_resolved(struct connectdata *conn, | ||||
|                           struct Curl_dns_entry **dns) | ||||
| CURLcode Curl_resolver_is_resolved(struct connectdata *conn, | ||||
|                                    struct Curl_dns_entry **dns) | ||||
| { | ||||
|   struct SessionHandle *data = conn->data; | ||||
|   struct ResolverResults *res = (struct ResolverResults *) | ||||
|     conn->async.os_specific; | ||||
| 
 | ||||
|   *dns = NULL; | ||||
| 
 | ||||
|   waitperform(conn, 0); | ||||
| 
 | ||||
|   if(conn->async.done) { | ||||
|     /* we're done, kill the ares handle */ | ||||
|   if(res && !res->num_pending) { | ||||
|     (void)Curl_addrinfo_callback(conn, res->last_status, res->temp_ai); | ||||
|     /* temp_ai ownership is moved to the connection, so we need not free-up
 | ||||
|        them */ | ||||
|     res->temp_ai = NULL; | ||||
|     destroy_async_data(&conn->async); | ||||
|     if(!conn->async.dns) { | ||||
|       failf(data, "Could not resolve host: %s (%s)", conn->host.dispname, | ||||
|       failf(data, "Could not resolve %s: %s (%s)", | ||||
|             conn->bits.proxy?"proxy":"host", | ||||
|             conn->host.dispname, | ||||
|             ares_strerror(conn->async.status)); | ||||
|       return CURLE_COULDNT_RESOLVE_HOST; | ||||
|       return conn->bits.proxy?CURLE_COULDNT_RESOLVE_PROXY: | ||||
|         CURLE_COULDNT_RESOLVE_HOST; | ||||
|     } | ||||
|     *dns = conn->async.dns; | ||||
|   } | ||||
| @@ -208,21 +345,24 @@ CURLcode Curl_is_resolved(struct connectdata *conn, | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_wait_for_resolv() waits for a resolve to finish. This function should | ||||
|  * be avoided since using this risk getting the multi interface to "hang". | ||||
|  * Curl_resolver_wait_resolv() | ||||
|  * | ||||
|  * waits for a resolve to finish. This function should be avoided since using | ||||
|  * this risk getting the multi interface to "hang". | ||||
|  * | ||||
|  * If 'entry' is non-NULL, make it point to the resolved dns entry | ||||
|  * | ||||
|  * Returns CURLE_COULDNT_RESOLVE_HOST if the host was not resolved, and | ||||
|  * CURLE_OPERATION_TIMEDOUT if a time-out occurred. | ||||
|  */ | ||||
| CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|                               struct Curl_dns_entry **entry) | ||||
| CURLcode Curl_resolver_wait_resolv(struct connectdata *conn, | ||||
|                                    struct Curl_dns_entry **entry) | ||||
| { | ||||
|   CURLcode rc=CURLE_OK; | ||||
|   struct SessionHandle *data = conn->data; | ||||
|   long timeout; | ||||
|   struct timeval now = Curl_tvnow(); | ||||
|   struct Curl_dns_entry *temp_entry; | ||||
| 
 | ||||
|   timeout = Curl_timeleft(data, &now, TRUE); | ||||
|   if(!timeout) | ||||
| @@ -240,7 +380,7 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|     store.tv_sec = itimeout/1000; | ||||
|     store.tv_usec = (itimeout%1000)*1000; | ||||
| 
 | ||||
|     tvp = ares_timeout(data->state.areschannel, &store, &tv); | ||||
|     tvp = ares_timeout((ares_channel)data->state.resolver, &store, &tv); | ||||
| 
 | ||||
|     /* use the timeout period ares returned to us above if less than one
 | ||||
|        second is left, otherwise just use 1000ms to make sure the progress | ||||
| @@ -251,6 +391,7 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|       timeout_ms = 1000; | ||||
| 
 | ||||
|     waitperform(conn, timeout_ms); | ||||
|     Curl_resolver_is_resolved(conn,&temp_entry); | ||||
| 
 | ||||
|     if(conn->async.done) | ||||
|       break; | ||||
| @@ -267,7 +408,7 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|     } | ||||
|     if(timeout < 0) { | ||||
|       /* our timeout, so we cancel the ares operation */ | ||||
|       ares_cancel(data->state.areschannel); | ||||
|       ares_cancel((ares_channel)data->state.resolver); | ||||
|       break; | ||||
|     } | ||||
|   } | ||||
| @@ -281,7 +422,7 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|   if(!conn->async.dns) { | ||||
|     /* a name was not resolved */ | ||||
|     if((timeout < 0) || (conn->async.status == ARES_ETIMEOUT)) { | ||||
|       if (conn->bits.httpproxy) { | ||||
|       if(conn->bits.proxy) { | ||||
|         failf(data, "Resolving proxy timed out: %s", conn->proxy.dispname); | ||||
|         rc = CURLE_COULDNT_RESOLVE_PROXY; | ||||
|       } | ||||
| @@ -291,7 +432,7 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|       } | ||||
|     } | ||||
|     else if(conn->async.done) { | ||||
|       if (conn->bits.httpproxy) { | ||||
|       if(conn->bits.proxy) { | ||||
|         failf(data, "Could not resolve proxy: %s (%s)", conn->proxy.dispname, | ||||
|               ares_strerror(conn->async.status)); | ||||
|         rc = CURLE_COULDNT_RESOLVE_PROXY; | ||||
| @@ -313,53 +454,73 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|   return rc; | ||||
| } | ||||
| 
 | ||||
| /* Connects results to the list */ | ||||
| static void compound_results(struct ResolverResults *res, | ||||
|                              Curl_addrinfo *ai) | ||||
| { | ||||
|   Curl_addrinfo *ai_tail; | ||||
|   if(!ai) | ||||
|     return; | ||||
|   ai_tail = ai; | ||||
| 
 | ||||
|   while(ai_tail->ai_next) | ||||
|     ai_tail = ai_tail->ai_next; | ||||
| 
 | ||||
|   /* Add the new results to the list of old results. */ | ||||
|   ai_tail->ai_next = res->temp_ai; | ||||
|   res->temp_ai = ai; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * ares_query_completed_cb() is the callback that ares will call when | ||||
|  * the host query initiated by ares_gethostbyname() from Curl_getaddrinfo(), | ||||
|  * when using ares, is completed either successfully or with failure. | ||||
|  */ | ||||
| static void ares_query_completed_cb(void *arg,  /* (struct connectdata *) */ | ||||
|                                     int status, | ||||
| static void query_completed_cb(void *arg,  /* (struct connectdata *) */ | ||||
|                                int status, | ||||
| #ifdef HAVE_CARES_CALLBACK_TIMEOUTS | ||||
|                                     int timeouts, | ||||
|                                int timeouts, | ||||
| #endif | ||||
|                                     struct hostent *hostent) | ||||
|                                struct hostent *hostent) | ||||
| { | ||||
|   struct connectdata *conn = (struct connectdata *)arg; | ||||
|   struct Curl_addrinfo * ai = NULL; | ||||
|   struct ResolverResults *res; | ||||
| 
 | ||||
| #ifdef HAVE_CARES_CALLBACK_TIMEOUTS | ||||
|   (void)timeouts; /* ignored */ | ||||
| #endif | ||||
| 
 | ||||
|   switch(status) { | ||||
|   case CURL_ASYNC_SUCCESS: | ||||
|     ai = Curl_he2ai(hostent, conn->async.port); | ||||
|     break; | ||||
|   case ARES_EDESTRUCTION: | ||||
|     /* this ares handle is getting destroyed, the 'arg' pointer may not be
 | ||||
|        valid! */ | ||||
|   if(ARES_EDESTRUCTION == status) | ||||
|     /* when this ares handle is getting destroyed, the 'arg' pointer may not
 | ||||
|        be valid so only defer it when we know the 'status' says its fine! */ | ||||
|     return; | ||||
|   default: | ||||
|     /* do nothing */ | ||||
|     break; | ||||
|   } | ||||
| 
 | ||||
|   (void)Curl_addrinfo_callback(arg, status, ai); | ||||
|   res = (struct ResolverResults *)conn->async.os_specific; | ||||
|   res->num_pending--; | ||||
| 
 | ||||
|   if(CURL_ASYNC_SUCCESS == status) { | ||||
|     Curl_addrinfo *ai = Curl_he2ai(hostent, conn->async.port); | ||||
|     if(ai) { | ||||
|       compound_results(res, ai); | ||||
|     } | ||||
|   } | ||||
|   /* A successful result overwrites any previous error */ | ||||
|   if(res->last_status != ARES_SUCCESS) | ||||
|     res->last_status = status; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_getaddrinfo() - when using ares | ||||
|  * Curl_resolver_getaddrinfo() - when using ares | ||||
|  * | ||||
|  * Returns name information about the given hostname and port number. If | ||||
|  * successful, the 'hostent' is returned and the forth argument will point to | ||||
|  * memory we need to free after use. That memory *MUST* be freed with | ||||
|  * Curl_freeaddrinfo(), nothing else. | ||||
|  */ | ||||
| Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
|                                 const char *hostname, | ||||
|                                 int port, | ||||
|                                 int *waitp) | ||||
| Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|                                          const char *hostname, | ||||
|                                          int port, | ||||
|                                          int *waitp) | ||||
| { | ||||
|   char *bufp; | ||||
|   struct SessionHandle *data = conn->data; | ||||
| @@ -379,10 +540,9 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
| 
 | ||||
| #ifdef ENABLE_IPV6 /* CURLRES_IPV6 */ | ||||
|   /* Otherwise, check if this is an IPv6 address string */ | ||||
|   if (Curl_inet_pton (AF_INET6, hostname, &in6) > 0) { | ||||
|   if(Curl_inet_pton (AF_INET6, hostname, &in6) > 0) | ||||
|     /* This must be an IPv6 address literal.  */ | ||||
|     return Curl_ip2addr(AF_INET6, &in6, hostname, port); | ||||
|   } | ||||
| 
 | ||||
|   switch(conn->ip_version) { | ||||
|   default: | ||||
| @@ -402,38 +562,82 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
| #endif /* CURLRES_IPV6 */ | ||||
| 
 | ||||
|   bufp = strdup(hostname); | ||||
| 
 | ||||
|   if(bufp) { | ||||
|     struct ResolverResults *res = NULL; | ||||
|     Curl_safefree(conn->async.hostname); | ||||
|     conn->async.hostname = bufp; | ||||
|     conn->async.port = port; | ||||
|     conn->async.done = FALSE;   /* not done */ | ||||
|     conn->async.status = 0;     /* clear */ | ||||
|     conn->async.dns = NULL;     /* clear */ | ||||
|     conn->async.temp_ai = NULL; /* clear */ | ||||
|     res = calloc(sizeof(struct ResolverResults),1); | ||||
|     if(!res) { | ||||
|       Curl_safefree(conn->async.hostname); | ||||
|       conn->async.hostname = NULL; | ||||
|       return NULL; | ||||
|     } | ||||
|     conn->async.os_specific = res; | ||||
| 
 | ||||
|     /* initial status - failed */ | ||||
|     res->last_status = ARES_ENOTFOUND; | ||||
| #ifdef ENABLE_IPV6 /* CURLRES_IPV6 */ | ||||
|     if(family == PF_UNSPEC) { | ||||
|       conn->async.num_pending = 2; | ||||
|       if(Curl_ipv6works()) { | ||||
|         res->num_pending = 2; | ||||
| 
 | ||||
|       /* areschannel is already setup in the Curl_open() function */ | ||||
|       ares_gethostbyname(data->state.areschannel, hostname, PF_INET, | ||||
|                          ares_query_completed_cb, conn); | ||||
|       ares_gethostbyname(data->state.areschannel, hostname, PF_INET6, | ||||
|                          ares_query_completed_cb, conn); | ||||
|         /* areschannel is already setup in the Curl_open() function */ | ||||
|         ares_gethostbyname((ares_channel)data->state.resolver, hostname, | ||||
|                             PF_INET, query_completed_cb, conn); | ||||
|         ares_gethostbyname((ares_channel)data->state.resolver, hostname, | ||||
|                             PF_INET6, query_completed_cb, conn); | ||||
|       } | ||||
|       else { | ||||
|         res->num_pending = 1; | ||||
| 
 | ||||
|         /* areschannel is already setup in the Curl_open() function */ | ||||
|         ares_gethostbyname((ares_channel)data->state.resolver, hostname, | ||||
|                             PF_INET, query_completed_cb, conn); | ||||
|       } | ||||
|     } | ||||
|     else | ||||
| #endif /* CURLRES_IPV6 */ | ||||
|     { | ||||
|       conn->async.num_pending = 1; | ||||
|       res->num_pending = 1; | ||||
| 
 | ||||
|       /* areschannel is already setup in the Curl_open() function */ | ||||
|       ares_gethostbyname(data->state.areschannel, hostname, family, | ||||
|                          ares_query_completed_cb, conn); | ||||
|       ares_gethostbyname((ares_channel)data->state.resolver, hostname, family, | ||||
|                          query_completed_cb, conn); | ||||
|     } | ||||
| 
 | ||||
|     *waitp = 1; /* expect asynchronous response */ | ||||
|   } | ||||
|   return NULL; /* no struct yet */ | ||||
| } | ||||
| 
 | ||||
| CURLcode Curl_set_dns_servers(struct SessionHandle *data, | ||||
|                               char *servers) | ||||
| { | ||||
|   CURLcode result = CURLE_NOT_BUILT_IN; | ||||
| #if (ARES_VERSION >= 0x010704) | ||||
|   int ares_result = ares_set_servers_csv(data->state.resolver, servers); | ||||
|   switch(ares_result) { | ||||
|   case ARES_SUCCESS: | ||||
|     result = CURLE_OK; | ||||
|     break; | ||||
|   case ARES_ENOMEM: | ||||
|     result = CURLE_OUT_OF_MEMORY; | ||||
|     break; | ||||
|   case ARES_ENOTINITIALIZED: | ||||
|   case ARES_ENODATA: | ||||
|   case ARES_EBADSTR: | ||||
|   default: | ||||
|     result = CURLE_BAD_FUNCTION_ARGUMENT; | ||||
|     break; | ||||
|   } | ||||
| #else /* too old c-ares version! */ | ||||
|   (void)data; | ||||
|   (void)servers; | ||||
| #endif | ||||
|   return result; | ||||
| } | ||||
| #endif /* CURLRES_ARES */ | ||||
| @@ -5,7 +5,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -22,9 +22,6 @@ | ||||
| 
 | ||||
| #include "setup.h" | ||||
| 
 | ||||
| #include <string.h> | ||||
| #include <errno.h> | ||||
| 
 | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| @@ -37,16 +34,12 @@ | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
| #ifdef HAVE_STDLIB_H | ||||
| #include <stdlib.h>     /* required for free() prototypes */ | ||||
| #endif | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h>     /* for the close() proto */ | ||||
| #endif | ||||
| #ifdef __VMS | ||||
| #include <in.h> | ||||
| #include <inet.h> | ||||
| #include <stdlib.h> | ||||
| #endif | ||||
| 
 | ||||
| #if defined(USE_THREADS_POSIX) | ||||
| @@ -64,6 +57,12 @@ | ||||
| #define in_addr_t unsigned long | ||||
| #endif | ||||
| 
 | ||||
| #ifdef HAVE_GETADDRINFO | ||||
| #  define RESOLVER_ENOMEM  EAI_MEMORY | ||||
| #else | ||||
| #  define RESOLVER_ENOMEM  ENOMEM | ||||
| #endif | ||||
| 
 | ||||
| #include "urldata.h" | ||||
| #include "sendf.h" | ||||
| #include "hostip.h" | ||||
| @@ -88,6 +87,71 @@ | ||||
|  **********************************************************************/ | ||||
| #ifdef CURLRES_THREADED | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_global_init() | ||||
|  * Called from curl_global_init() to initialize global resolver environment. | ||||
|  * Does nothing here. | ||||
|  */ | ||||
| int Curl_resolver_global_init(void) | ||||
| { | ||||
|   return CURLE_OK; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_global_cleanup() | ||||
|  * Called from curl_global_cleanup() to destroy global resolver environment. | ||||
|  * Does nothing here. | ||||
|  */ | ||||
| void Curl_resolver_global_cleanup(void) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_init() | ||||
|  * Called from curl_easy_init() -> Curl_open() to initialize resolver | ||||
|  * URL-state specific environment ('resolver' member of the UrlState | ||||
|  * structure).  Does nothing here. | ||||
|  */ | ||||
| CURLcode Curl_resolver_init(void **resolver) | ||||
| { | ||||
|   (void)resolver; | ||||
|   return CURLE_OK; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_cleanup() | ||||
|  * Called from curl_easy_cleanup() -> Curl_close() to cleanup resolver | ||||
|  * URL-state specific environment ('resolver' member of the UrlState | ||||
|  * structure).  Does nothing here. | ||||
|  */ | ||||
| void Curl_resolver_cleanup(void *resolver) | ||||
| { | ||||
|   (void)resolver; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_duphandle() | ||||
|  * Called from curl_easy_duphandle() to duplicate resolver URL state-specific | ||||
|  * environment ('resolver' member of the UrlState structure).  Does nothing | ||||
|  * here. | ||||
|  */ | ||||
| int Curl_resolver_duphandle(void **to, void *from) | ||||
| { | ||||
|   (void)to; | ||||
|   (void)from; | ||||
|   return CURLE_OK; | ||||
| } | ||||
| 
 | ||||
| static void destroy_async_data(struct Curl_async *); | ||||
| 
 | ||||
| /*
 | ||||
|  * Cancel all possibly still on-going resolves for this connection. | ||||
|  */ | ||||
| void Curl_resolver_cancel(struct connectdata *conn) | ||||
| { | ||||
|   destroy_async_data(&conn->async); | ||||
| } | ||||
| 
 | ||||
| /* This function is used to init a threaded resolve */ | ||||
| static bool init_resolve_thread(struct connectdata *conn, | ||||
|                                 const char *hostname, int port, | ||||
| @@ -111,13 +175,12 @@ struct thread_sync_data { | ||||
| 
 | ||||
| struct thread_data { | ||||
|   curl_thread_t thread_hnd; | ||||
|   curl_socket_t dummy_sock; | ||||
|   unsigned int poll_interval; | ||||
|   int interval_end; | ||||
|   struct thread_sync_data tsd; | ||||
| }; | ||||
| 
 | ||||
| static struct thread_sync_data * conn_thread_sync_data(struct connectdata *conn) | ||||
| static struct thread_sync_data *conn_thread_sync_data(struct connectdata *conn) | ||||
| { | ||||
|   return &(((struct thread_data *)conn->async.os_specific)->tsd); | ||||
| } | ||||
| @@ -128,7 +191,7 @@ static struct thread_sync_data * conn_thread_sync_data(struct connectdata *conn) | ||||
| static | ||||
| void destroy_thread_sync_data(struct thread_sync_data * tsd) | ||||
| { | ||||
|   if (tsd->mtx) { | ||||
|   if(tsd->mtx) { | ||||
|     Curl_mutex_destroy(tsd->mtx); | ||||
|     free(tsd->mtx); | ||||
|   } | ||||
| @@ -136,7 +199,7 @@ void destroy_thread_sync_data(struct thread_sync_data * tsd) | ||||
|   if(tsd->hostname) | ||||
|     free(tsd->hostname); | ||||
| 
 | ||||
|   if (tsd->res) | ||||
|   if(tsd->res) | ||||
|     Curl_freeaddrinfo(tsd->res); | ||||
| 
 | ||||
|   memset(tsd,0,sizeof(*tsd)); | ||||
| @@ -160,7 +223,8 @@ int init_thread_sync_data(struct thread_sync_data * tsd, | ||||
| #endif | ||||
| 
 | ||||
|   tsd->mtx = malloc(sizeof(curl_mutex_t)); | ||||
|   if (tsd->mtx == NULL) goto err_exit; | ||||
|   if(tsd->mtx == NULL) | ||||
|     goto err_exit; | ||||
| 
 | ||||
|   Curl_mutex_init(tsd->mtx); | ||||
| 
 | ||||
| @@ -170,7 +234,8 @@ int init_thread_sync_data(struct thread_sync_data * tsd, | ||||
|    * thread during gethostbyname execution. | ||||
|    */ | ||||
|   tsd->hostname = strdup(hostname); | ||||
|   if (!tsd->hostname) goto err_exit; | ||||
|   if(!tsd->hostname) | ||||
|     goto err_exit; | ||||
| 
 | ||||
|   return 1; | ||||
| 
 | ||||
| @@ -186,9 +251,9 @@ static int getaddrinfo_complete(struct connectdata *conn) | ||||
|   int rc; | ||||
| 
 | ||||
|   rc = Curl_addrinfo_callback(conn, tsd->sock_error, tsd->res); | ||||
|   /* The tsd->res structure has been copied to async.dns and perhaps the DNS cache.
 | ||||
|      Set our copy to NULL so destroy_thread_sync_data doesn't free it. | ||||
|    */ | ||||
|   /* The tsd->res structure has been copied to async.dns and perhaps the DNS
 | ||||
|      cache.  Set our copy to NULL so destroy_thread_sync_data doesn't free it. | ||||
|   */ | ||||
|   tsd->res = NULL; | ||||
| 
 | ||||
|   return rc; | ||||
| @@ -213,10 +278,10 @@ static unsigned int CURL_STDCALL getaddrinfo_thread (void *arg) | ||||
| 
 | ||||
|   rc = Curl_getaddrinfo_ex(tsd->hostname, service, &tsd->hints, &tsd->res); | ||||
| 
 | ||||
|   if (rc != 0) { | ||||
|     tsd->sock_error = SOCKERRNO; | ||||
|     if (tsd->sock_error == 0) | ||||
|       tsd->sock_error = ENOMEM; | ||||
|   if(rc != 0) { | ||||
|     tsd->sock_error = SOCKERRNO?SOCKERRNO:rc; | ||||
|     if(tsd->sock_error == 0) | ||||
|       tsd->sock_error = RESOLVER_ENOMEM; | ||||
|   } | ||||
| 
 | ||||
|   Curl_mutex_acquire(tsd->mtx); | ||||
| @@ -237,10 +302,10 @@ static unsigned int CURL_STDCALL gethostbyname_thread (void *arg) | ||||
| 
 | ||||
|   tsd->res = Curl_ipv4_resolve_r(tsd->hostname, tsd->port); | ||||
| 
 | ||||
|   if (!tsd->res) { | ||||
|   if(!tsd->res) { | ||||
|     tsd->sock_error = SOCKERRNO; | ||||
|     if (tsd->sock_error == 0) | ||||
|       tsd->sock_error = ENOMEM; | ||||
|     if(tsd->sock_error == 0) | ||||
|       tsd->sock_error = RESOLVER_ENOMEM; | ||||
|   } | ||||
| 
 | ||||
|   Curl_mutex_acquire(tsd->mtx); | ||||
| @@ -253,10 +318,9 @@ static unsigned int CURL_STDCALL gethostbyname_thread (void *arg) | ||||
| #endif /* HAVE_GETADDRINFO */ | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_destroy_thread_data() cleans up async resolver data and thread handle. | ||||
|  * Complementary of ares_destroy. | ||||
|  * destroy_async_data() cleans up async resolver data and thread handle. | ||||
|  */ | ||||
| void Curl_destroy_thread_data (struct Curl_async *async) | ||||
| static void destroy_async_data (struct Curl_async *async) | ||||
| { | ||||
|   if(async->hostname) | ||||
|     free(async->hostname); | ||||
| @@ -264,10 +328,7 @@ void Curl_destroy_thread_data (struct Curl_async *async) | ||||
|   if(async->os_specific) { | ||||
|     struct thread_data *td = (struct thread_data*) async->os_specific; | ||||
| 
 | ||||
|     if (td->dummy_sock != CURL_SOCKET_BAD) | ||||
|       sclose(td->dummy_sock); | ||||
| 
 | ||||
|     if (td->thread_hnd != curl_thread_t_null) | ||||
|     if(td->thread_hnd != curl_thread_t_null) | ||||
|       Curl_thread_join(&td->thread_hnd); | ||||
| 
 | ||||
|     destroy_thread_sync_data(&td->tsd); | ||||
| @@ -289,7 +350,7 @@ static bool init_resolve_thread (struct connectdata *conn, | ||||
|                                  const struct addrinfo *hints) | ||||
| { | ||||
|   struct thread_data *td = calloc(1, sizeof(struct thread_data)); | ||||
|   int err = ENOMEM; | ||||
|   int err = RESOLVER_ENOMEM; | ||||
| 
 | ||||
|   conn->async.os_specific = (void*) td; | ||||
|   if(!td) | ||||
| @@ -299,10 +360,9 @@ static bool init_resolve_thread (struct connectdata *conn, | ||||
|   conn->async.done = FALSE; | ||||
|   conn->async.status = 0; | ||||
|   conn->async.dns = NULL; | ||||
|   td->dummy_sock = CURL_SOCKET_BAD; | ||||
|   td->thread_hnd = curl_thread_t_null; | ||||
| 
 | ||||
|   if (!init_thread_sync_data(&td->tsd, hostname, port, hints)) | ||||
|   if(!init_thread_sync_data(&td->tsd, hostname, port, hints)) | ||||
|     goto err_exit; | ||||
| 
 | ||||
|   Curl_safefree(conn->async.hostname); | ||||
| @@ -310,16 +370,6 @@ static bool init_resolve_thread (struct connectdata *conn, | ||||
|   if(!conn->async.hostname) | ||||
|     goto err_exit; | ||||
| 
 | ||||
| #ifdef WIN32 | ||||
|   /* This socket is only to keep Curl_resolv_fdset() and select() happy;
 | ||||
|    * should never become signalled for read since it's unbound but | ||||
|    * Windows needs at least 1 socket in select(). | ||||
|    */ | ||||
|   td->dummy_sock = socket(AF_INET, SOCK_DGRAM, 0); | ||||
|   if (td->dummy_sock == CURL_SOCKET_BAD) | ||||
|     goto err_exit; | ||||
| #endif | ||||
| 
 | ||||
| #ifdef HAVE_GETADDRINFO | ||||
|   td->thread_hnd = Curl_thread_create(getaddrinfo_thread, &td->tsd); | ||||
| #else | ||||
| @@ -336,37 +386,93 @@ static bool init_resolve_thread (struct connectdata *conn, | ||||
|   return TRUE; | ||||
| 
 | ||||
|  err_exit: | ||||
|   Curl_destroy_thread_data(&conn->async); | ||||
|   destroy_async_data(&conn->async); | ||||
| 
 | ||||
|   SET_ERRNO(err); | ||||
| 
 | ||||
|   return FALSE; | ||||
| } | ||||
| 
 | ||||
| #if defined(HAVE_GETADDRINFO) && !defined(HAVE_GAI_STRERROR) && !defined(WIN32) | ||||
| /* NetWare has getaddrinfo but lacks gai_strerror.
 | ||||
|    Windows has a gai_strerror but it is bad (not thread-safe) and the generic | ||||
|    socket error string function can be used for this pupose. */ | ||||
| static const char *gai_strerror(int ecode) | ||||
| { | ||||
|   switch (ecode) { | ||||
|   case EAI_AGAIN: | ||||
|     return "The name could not be resolved at this time"; | ||||
|   case EAI_BADFLAGS: | ||||
|     return "The flags parameter had an invalid value"; | ||||
|   case EAI_FAIL: | ||||
|     return "A non-recoverable error occurred when attempting to " | ||||
|       "resolve the name"; | ||||
|   case EAI_FAMILY: | ||||
|     return "The address family was not recognized"; | ||||
|   case EAI_MEMORY: | ||||
|     return "Out of memory"; | ||||
|   case EAI_NONAME: | ||||
|     return "The name does not resolve for the supplied parameters"; | ||||
|   case EAI_SERVICE: | ||||
|     return "The service passed was not recognized for the " | ||||
|       "specified socket type" | ||||
|   case EAI_SOCKTYPE: | ||||
|     return "The intended socket type was not recognized" | ||||
|   case EAI_SYSTEM: | ||||
|     return "A system error occurred"; | ||||
|   case EAI_OVERFLOW: | ||||
|     return "An argument buffer overflowed"; | ||||
|   default: | ||||
|     return "Unknown error"; | ||||
| 
 | ||||
| /* define this now as this is a private implementation of said function */ | ||||
| #define HAVE_GAI_STRERROR | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_wait_for_resolv() waits for a resolve to finish. This function should | ||||
|  * be avoided since using this risk getting the multi interface to "hang". | ||||
|  * resolver_error() calls failf() with the appropriate message after a resolve | ||||
|  * error | ||||
|  */ | ||||
| 
 | ||||
| static void resolver_error(struct connectdata *conn, const char *host_or_proxy) | ||||
| { | ||||
|   failf(conn->data, "Could not resolve %s: %s; %s", host_or_proxy, | ||||
|         conn->async.hostname, | ||||
| #ifdef HAVE_GAI_STRERROR | ||||
|         /* NetWare doesn't have gai_strerror and on Windows it isn't deemed
 | ||||
|            thread-safe */ | ||||
|         gai_strerror(conn->async.status) | ||||
| #else | ||||
|         Curl_strerror(conn, conn->async.status) | ||||
| #endif | ||||
|     ); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_resolver_wait_resolv() | ||||
|  * | ||||
|  * waits for a resolve to finish. This function should be avoided since using | ||||
|  * this risk getting the multi interface to "hang". | ||||
|  * | ||||
|  * If 'entry' is non-NULL, make it point to the resolved dns entry | ||||
|  * | ||||
|  * This is the version for resolves-in-a-thread. | ||||
|  */ | ||||
| CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
|                               struct Curl_dns_entry **entry) | ||||
| CURLcode Curl_resolver_wait_resolv(struct connectdata *conn, | ||||
|                                    struct Curl_dns_entry **entry) | ||||
| { | ||||
|   struct thread_data   *td = (struct thread_data*) conn->async.os_specific; | ||||
|   struct SessionHandle *data = conn->data; | ||||
|   CURLcode rc = CURLE_OK; | ||||
| 
 | ||||
|   DEBUGASSERT(conn && td); | ||||
| 
 | ||||
|   /* wait for the thread to resolve the name */ | ||||
|   if (Curl_thread_join(&td->thread_hnd)) { | ||||
|   if(Curl_thread_join(&td->thread_hnd)) | ||||
|     rc = getaddrinfo_complete(conn); | ||||
|   } else { | ||||
|   else | ||||
|     DEBUGASSERT(0); | ||||
|   } | ||||
| 
 | ||||
|   conn->async.done = TRUE; | ||||
| 
 | ||||
| @@ -375,18 +481,17 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
| 
 | ||||
|   if(!conn->async.dns) { | ||||
|     /* a name was not resolved */ | ||||
|     if (conn->bits.httpproxy) { | ||||
|       failf(data, "Could not resolve proxy: %s; %s", | ||||
|             conn->async.hostname, Curl_strerror(conn, conn->async.status)); | ||||
|     if(conn->bits.httpproxy) { | ||||
|       resolver_error(conn, "proxy"); | ||||
|       rc = CURLE_COULDNT_RESOLVE_PROXY; | ||||
|     } else { | ||||
|       failf(data, "Could not resolve host: %s; %s", | ||||
|             conn->async.hostname, Curl_strerror(conn, conn->async.status)); | ||||
|     } | ||||
|     else { | ||||
|       resolver_error(conn, "host"); | ||||
|       rc = CURLE_COULDNT_RESOLVE_HOST; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   Curl_destroy_thread_data(&conn->async); | ||||
|   destroy_async_data(&conn->async); | ||||
| 
 | ||||
|   if(!conn->async.dns) | ||||
|     conn->bits.close = TRUE; | ||||
| @@ -395,12 +500,12 @@ CURLcode Curl_wait_for_resolv(struct connectdata *conn, | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_is_resolved() is called repeatedly to check if a previous name resolve | ||||
|  * request has completed. It should also make sure to time-out if the | ||||
|  * operation seems to take too long. | ||||
|  * Curl_resolver_is_resolved() is called repeatedly to check if a previous | ||||
|  * name resolve request has completed. It should also make sure to time-out if | ||||
|  * the operation seems to take too long. | ||||
|  */ | ||||
| CURLcode Curl_is_resolved(struct connectdata *conn, | ||||
|                           struct Curl_dns_entry **entry) | ||||
| CURLcode Curl_resolver_is_resolved(struct connectdata *conn, | ||||
|                                    struct Curl_dns_entry **entry) | ||||
| { | ||||
|   struct SessionHandle *data = conn->data; | ||||
|   struct thread_data   *td = (struct thread_data*) conn->async.os_specific; | ||||
| @@ -408,7 +513,7 @@ CURLcode Curl_is_resolved(struct connectdata *conn, | ||||
| 
 | ||||
|   *entry = NULL; | ||||
| 
 | ||||
|   if (!td) { | ||||
|   if(!td) { | ||||
|     DEBUGASSERT(td); | ||||
|     return CURLE_COULDNT_RESOLVE_HOST; | ||||
|   } | ||||
| @@ -417,30 +522,30 @@ CURLcode Curl_is_resolved(struct connectdata *conn, | ||||
|   done = td->tsd.done; | ||||
|   Curl_mutex_release(td->tsd.mtx); | ||||
| 
 | ||||
|   if (done) { | ||||
|   if(done) { | ||||
|     getaddrinfo_complete(conn); | ||||
|     Curl_destroy_thread_data(&conn->async); | ||||
|     destroy_async_data(&conn->async); | ||||
| 
 | ||||
|     if(!conn->async.dns) { | ||||
|       failf(data, "Could not resolve host: %s; %s", | ||||
|             conn->host.name, Curl_strerror(conn, conn->async.status)); | ||||
|       resolver_error(conn, "host"); | ||||
|       return CURLE_COULDNT_RESOLVE_HOST; | ||||
|     } | ||||
|     *entry = conn->async.dns; | ||||
|   } else { | ||||
|   } | ||||
|   else { | ||||
|     /* poll for name lookup done with exponential backoff up to 250ms */ | ||||
|     int elapsed = Curl_tvdiff(Curl_tvnow(), data->progress.t_startsingle); | ||||
|     if (elapsed < 0) | ||||
|     if(elapsed < 0) | ||||
|       elapsed = 0; | ||||
| 
 | ||||
|     if (td->poll_interval == 0) | ||||
|     if(td->poll_interval == 0) | ||||
|       /* Start at 1ms poll interval */ | ||||
|       td->poll_interval = 1; | ||||
|     else if (elapsed >= td->interval_end) | ||||
|     else if(elapsed >= td->interval_end) | ||||
|       /* Back-off exponentially if last interval expired  */ | ||||
|       td->poll_interval *= 2; | ||||
| 
 | ||||
|     if (td->poll_interval > 250) | ||||
|     if(td->poll_interval > 250) | ||||
|       td->poll_interval = 250; | ||||
| 
 | ||||
|     td->interval_end = elapsed + td->poll_interval; | ||||
| @@ -450,21 +555,13 @@ CURLcode Curl_is_resolved(struct connectdata *conn, | ||||
|   return CURLE_OK; | ||||
| } | ||||
| 
 | ||||
| int Curl_resolv_getsock(struct connectdata *conn, | ||||
|                         curl_socket_t *socks, | ||||
|                         int numsocks) | ||||
| int Curl_resolver_getsock(struct connectdata *conn, | ||||
|                           curl_socket_t *socks, | ||||
|                           int numsocks) | ||||
| { | ||||
|   const struct thread_data *td = | ||||
|     (const struct thread_data *) conn->async.os_specific; | ||||
| 
 | ||||
|   if(td && td->dummy_sock != CURL_SOCKET_BAD) { | ||||
|     if(numsocks) { | ||||
|       /* return one socket waiting for readable, even though this is just
 | ||||
|          a dummy */ | ||||
|       socks[0] = td->dummy_sock; | ||||
|       return GETSOCK_READSOCK(0); | ||||
|     } | ||||
|   } | ||||
|   (void)conn; | ||||
|   (void)socks; | ||||
|   (void)numsocks; | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| @@ -472,10 +569,10 @@ int Curl_resolv_getsock(struct connectdata *conn, | ||||
| /*
 | ||||
|  * Curl_getaddrinfo() - for platforms without getaddrinfo | ||||
|  */ | ||||
| Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
|                                 const char *hostname, | ||||
|                                 int port, | ||||
|                                 int *waitp) | ||||
| Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|                                          const char *hostname, | ||||
|                                          int port, | ||||
|                                          int *waitp) | ||||
| { | ||||
|   struct in_addr in; | ||||
| 
 | ||||
| @@ -498,23 +595,36 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
| #else /* !HAVE_GETADDRINFO */ | ||||
| 
 | ||||
| /*
 | ||||
|  * Curl_getaddrinfo() - for getaddrinfo | ||||
|  * Curl_resolver_getaddrinfo() - for getaddrinfo | ||||
|  */ | ||||
| Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
|                                 const char *hostname, | ||||
|                                 int port, | ||||
|                                 int *waitp) | ||||
| Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|                                          const char *hostname, | ||||
|                                          int port, | ||||
|                                          int *waitp) | ||||
| { | ||||
|   struct addrinfo hints; | ||||
|   struct in_addr in; | ||||
|   Curl_addrinfo *res; | ||||
|   int error; | ||||
|   char sbuf[NI_MAXSERV]; | ||||
|   int pf = PF_INET; | ||||
|   struct SessionHandle *data = conn->data; | ||||
| #ifdef CURLRES_IPV6 | ||||
|   struct in6_addr in6; | ||||
| #endif /* CURLRES_IPV6 */ | ||||
| 
 | ||||
|   *waitp = 0; /* default to synchronous response */ | ||||
| 
 | ||||
| #ifndef CURLRES_IPV4 | ||||
|   /* First check if this is an IPv4 address string */ | ||||
|   if(Curl_inet_pton(AF_INET, hostname, &in) > 0) | ||||
|     /* This is a dotted IP address 123.123.123.123-style */ | ||||
|     return Curl_ip2addr(AF_INET, &in, hostname, port); | ||||
| 
 | ||||
| #ifdef CURLRES_IPV6 | ||||
|   /* check if this is an IPv6 address string */ | ||||
|   if(Curl_inet_pton (AF_INET6, hostname, &in6) > 0) | ||||
|     /* This is an IPv6 address literal */ | ||||
|     return Curl_ip2addr(AF_INET6, &in6, hostname, port); | ||||
| 
 | ||||
|   /*
 | ||||
|    * Check if a limited name resolve has been requested. | ||||
|    */ | ||||
| @@ -534,7 +644,7 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
|     /* the stack seems to be a non-ipv6 one */ | ||||
|     pf = PF_INET; | ||||
| 
 | ||||
| #endif /* !CURLRES_IPV4 */ | ||||
| #endif /* CURLRES_IPV6 */ | ||||
| 
 | ||||
|   memset(&hints, 0, sizeof(hints)); | ||||
|   hints.ai_family = pf; | ||||
| @@ -549,12 +659,12 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
|   } | ||||
| 
 | ||||
|   /* fall-back to blocking version */ | ||||
|   infof(data, "init_resolve_thread() failed for %s; %s\n", | ||||
|   infof(conn->data, "init_resolve_thread() failed for %s; %s\n", | ||||
|         hostname, Curl_strerror(conn, ERRNO)); | ||||
| 
 | ||||
|   error = Curl_getaddrinfo_ex(hostname, sbuf, &hints, &res); | ||||
|   if(error) { | ||||
|     infof(data, "getaddrinfo() failed for %s:%d; %s\n", | ||||
|     infof(conn->data, "getaddrinfo() failed for %s:%d; %s\n", | ||||
|           hostname, port, Curl_strerror(conn, SOCKERRNO)); | ||||
|     return NULL; | ||||
|   } | ||||
| @@ -563,4 +673,13 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn, | ||||
| 
 | ||||
| #endif /* !HAVE_GETADDRINFO */ | ||||
| 
 | ||||
| CURLcode Curl_set_dns_servers(struct SessionHandle *data, | ||||
|                               char *servers) | ||||
| { | ||||
|   (void)data; | ||||
|   (void)servers; | ||||
|   return CURLE_NOT_BUILT_IN; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| #endif /* CURLRES_THREADED */ | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user