Compare commits
	
		
			893 Commits
		
	
	
		
			curl-7_21_
			...
			curl-7_26_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | c262c35676 | ||
|   | ef60fdbd73 | ||
|   | b1f081f6e6 | ||
|   | 6cc066a2c5 | ||
|   | 0fd7fa7daf | ||
|   | 9258b84673 | ||
|   | fdf2517bd9 | ||
|   | cc36756aa2 | ||
|   | 1c58f291cc | ||
|   | 8ae1e657e8 | ||
|   | 7ba07c80a1 | ||
|   | fec096f153 | ||
|   | 499ffe2f8c | ||
|   | cf41ee3ac9 | ||
|   | e315927a1a | ||
|   | 03c1bcf4bd | ||
|   | 92f841aef7 | ||
|   | 9fafa68533 | ||
|   | e7257dcf2e | ||
|   | 3ebcfdda36 | ||
|   | 77bac26587 | ||
|   | d6773834f2 | ||
|   | 6f998400d9 | ||
|   | 64f48e884e | ||
|   | e146a5f132 | ||
|   | 1beda0cbb7 | ||
|   | 72b72fe8ed | ||
|   | bd9eb30ffd | ||
|   | dd18e714ff | ||
|   | d6c449e3b4 | ||
|   | 071f8d4182 | ||
|   | d83233501f | ||
|   | 419a50f817 | ||
|   | 975d23480c | ||
|   | 13211705cd | ||
|   | 9ec0b7e0c4 | ||
|   | 412510f974 | ||
|   | 683bfa60ad | ||
|   | 77172a242f | ||
|   | 46cd5f1dad | ||
|   | 2976de4808 | ||
|   | 560cd62272 | ||
|   | 0f54880277 | ||
|   | 5cd524df18 | ||
|   | 94111bbbd4 | ||
|   | df4205c10a | ||
|   | 9421b06397 | ||
|   | 09690be8de | ||
|   | ce8a321dd0 | ||
|   | 3833765ba5 | ||
|   | 4d28a59fc2 | ||
|   | a498daa0e0 | ||
|   | bd12c44d35 | ||
|   | 4c385cf896 | ||
|   | 7d4ed0b10e | ||
|   | 48d13b44c6 | ||
|   | 8b63b48627 | ||
|   | b9ac64c2cb | ||
|   | 4d2c3f0a4d | ||
|   | c156b916a4 | ||
|   | 865893fb14 | ||
|   | a60edcc6d4 | ||
|   | 20cb12db8d | ||
|   | 42aa796150 | ||
|   | 2a902738fb | ||
|   | bb5d4234e3 | ||
|   | 930781e168 | ||
|   | 1c3a99b52c | ||
|   | 5f04843e5b | ||
|   | 8c29bf5640 | ||
|   | 82306ebfba | ||
|   | 03d4b9f078 | ||
|   | 51114f07f1 | ||
|   | e19917296f | ||
|   | 8ed40acac6 | ||
|   | 38ae6ec1a2 | ||
|   | 9e24b9c7af | ||
|   | a144bb8b76 | ||
|   | 4d3fb91fb4 | ||
|   | bbfe118209 | ||
|   | e5c14674f0 | ||
|   | 6dba7608bf | ||
|   | 21423497ef | ||
|   | 01b0f1061d | ||
|   | 3d8c093145 | ||
|   | 919c97fa65 | ||
|   | 376b4d48fe | ||
|   | 118e73306d | ||
|   | 1dd69921d3 | ||
|   | 29e68b200c | ||
|   | 0b516b7162 | ||
|   | a0b3535735 | ||
|   | 5e852ab9d1 | ||
|   | f9bb5d2984 | ||
|   | ad595c3ba9 | ||
|   | 7031ff23bb | ||
|   | 9753c6bec5 | ||
|   | b16e3da12a | ||
|   | e7661d198f | ||
|   | 13c7b91133 | ||
|   | 950b0b770e | ||
|   | 15e1227ed4 | ||
|   | ddfe821bcf | ||
|   | 54866b68cd | ||
|   | 05a443adf2 | ||
|   | ebf315e6f3 | ||
|   | c44d45db86 | ||
|   | 7a2647e162 | ||
|   | 9bae9ddad9 | ||
|   | 004d7251ab | ||
|   | 33d044a862 | ||
|   | a9086e8a4b | ||
|   | 761c3c5446 | ||
|   | 66c0e26e28 | ||
|   | 7d1b715605 | ||
|   | 9f494fe423 | ||
|   | 809c809281 | ||
|   | 0580b60622 | ||
|   | 4bdb664c33 | ||
|   | 459435dca1 | ||
|   | 3fdb7808ef | ||
|   | 97ff646fc1 | ||
|   | 9801596fb3 | ||
|   | 982315573c | ||
|   | 9f96e6da28 | ||
|   | 01690ed2bc | ||
|   | 2da89708ec | ||
|   | 5c62a551c4 | ||
|   | 602a8a565c | ||
|   | c4a8446c70 | ||
|   | 456d8db35e | ||
|   | e952a7e710 | ||
|   | 682f0840e7 | ||
|   | f85ec43f24 | ||
|   | b5713887ae | ||
|   | 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 | 
							
								
								
									
										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) | ||||
|  | ||||
|   | ||||
							
								
								
									
										0
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -57,10 +57,6 @@ set(OS "\"${CMAKE_SYSTEM_NAME}\"") | ||||
| include_directories(${PROJECT_BINARY_DIR}/include/curl) | ||||
| include_directories( ${CURL_SOURCE_DIR}/include ) | ||||
|  | ||||
| if(WIN32) | ||||
|   set(NATIVE_WINDOWS ON) | ||||
| endif() | ||||
|  | ||||
| option(BUILD_CURL_EXE "Set to ON to build cURL executable." ON) | ||||
| option(BUILD_CURL_TESTS "Set to ON to build cURL tests." ON) | ||||
| option(CURL_STATICLIB "Set to ON to build libcurl with static linking." OFF) | ||||
| @@ -113,22 +109,11 @@ mark_as_advanced(CURL_DISABLE_HTTP) | ||||
|  | ||||
| option(CURL_DISABLE_LDAPS "to disable LDAPS" OFF) | ||||
| mark_as_advanced(CURL_DISABLE_LDAPS) | ||||
| if(WIN32) | ||||
|   set(CURL_DEFAULT_DISABLE_LDAP OFF) | ||||
|   # some windows compilers do not have wldap32 | ||||
|   if( NOT HAVE_WLDAP32) | ||||
|     set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) | ||||
|     message(STATUS "wldap32 not found CURL_DISABLE_LDAP set ON") | ||||
|     option(CURL_LDAP_WIN "Use Windows LDAP implementation" OFF) | ||||
|   else() | ||||
|     option(CURL_LDAP_WIN "Use Windows LDAP implementation" ON) | ||||
|   endif() | ||||
|   mark_as_advanced(CURL_LDAP_WIN) | ||||
| endif() | ||||
|  | ||||
| if(HTTP_ONLY) | ||||
|   set(CURL_DISABLE_FTP ON) | ||||
|   set(CURL_DISABLE_LDAP ON) | ||||
|   set(CURL_DISABLE_LDAPS ON) | ||||
|   set(CURL_DISABLE_TELNET ON) | ||||
|   set(CURL_DISABLE_DICT ON) | ||||
|   set(CURL_DISABLE_FILE ON) | ||||
| @@ -148,6 +133,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 | ||||
| @@ -219,6 +206,20 @@ check_library_exists_concat("ws2_32" getch        HAVE_LIBWS2_32) | ||||
| check_library_exists_concat("winmm"  getch        HAVE_LIBWINMM) | ||||
| check_library_exists("wldap32" cldap_open "" HAVE_WLDAP32) | ||||
|  | ||||
| if(WIN32) | ||||
|   set(CURL_DEFAULT_DISABLE_LDAP OFF) | ||||
|   # some windows compilers do not have wldap32 | ||||
|   if(NOT HAVE_WLDAP32) | ||||
|     set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) | ||||
|     message(STATUS "wldap32 not found CURL_DISABLE_LDAP set ON") | ||||
|     option(CURL_LDAP_WIN "Use Windows LDAP implementation" OFF) | ||||
|   else() | ||||
|     option(CURL_LDAP_WIN "Use Windows LDAP implementation" ON) | ||||
|   endif() | ||||
|   mark_as_advanced(CURL_LDAP_WIN) | ||||
| endif() | ||||
|  | ||||
|  | ||||
| # IF(NOT CURL_SPECIAL_LIBZ) | ||||
| #  CHECK_LIBRARY_EXISTS_CONCAT("z"      inflateEnd   HAVE_LIBZ) | ||||
| # ENDIF(NOT CURL_SPECIAL_LIBZ) | ||||
| @@ -385,6 +386,13 @@ if(NOT HAVE_LDAP_H) | ||||
|   set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) | ||||
| endif() | ||||
|  | ||||
| # No ldap, no ldaps. | ||||
| if(CURL_DISABLE_LDAP) | ||||
|   if(NOT CURL_DISABLE_LDAPS) | ||||
|     message(STATUS "LDAP needs to be enabled to support LDAPS") | ||||
|     set(CURL_DISABLE_LDAPS ON CACHE BOOL "" FORCE) | ||||
|   endif() | ||||
| endif() | ||||
|  | ||||
| check_type_size(size_t  SIZEOF_SIZE_T) | ||||
| check_type_size(ssize_t  SIZEOF_SSIZE_T) | ||||
| @@ -424,7 +432,7 @@ if(SIZEOF_LONG EQUAL 8) | ||||
|   set(CURL_FORMAT_CURL_OFF_TU "lu") | ||||
|   set(CURL_FORMAT_OFF_T "%ld") | ||||
|   set(CURL_SUFFIX_CURL_OFF_T L) | ||||
|   set(CURL_SUFFIX_CURL_OFF_TU LU) | ||||
|   set(CURL_SUFFIX_CURL_OFF_TU UL) | ||||
| endif(SIZEOF_LONG EQUAL 8) | ||||
|  | ||||
| if(SIZEOF_LONG_LONG EQUAL 8) | ||||
| @@ -434,7 +442,7 @@ if(SIZEOF_LONG_LONG EQUAL 8) | ||||
|   set(CURL_FORMAT_CURL_OFF_TU "llu") | ||||
|   set(CURL_FORMAT_OFF_T "%lld") | ||||
|   set(CURL_SUFFIX_CURL_OFF_T LL) | ||||
|   set(CURL_SUFFIX_CURL_OFF_TU LLU) | ||||
|   set(CURL_SUFFIX_CURL_OFF_TU ULL) | ||||
| endif(SIZEOF_LONG_LONG EQUAL 8) | ||||
|  | ||||
| if(NOT CURL_TYPEOF_CURL_OFF_T) | ||||
| @@ -861,4 +869,3 @@ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/curl" | ||||
|     DESTINATION include | ||||
|     FILES_MATCHING PATTERN "*.h" | ||||
|     PATTERN "curlbuild.h" EXCLUDE) | ||||
|   | ||||
							
								
								
									
										2
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								COPYING
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| COPYRIGHT AND PERMISSION NOTICE | ||||
|  | ||||
| Copyright (c) 1996 - 2011, Daniel Stenberg, <daniel@haxx.se>. | ||||
| Copyright (c) 1996 - 2012, Daniel Stenberg, <daniel@haxx.se>. | ||||
|  | ||||
| All rights reserved. | ||||
|  | ||||
|   | ||||
| @@ -36,7 +36,7 @@ 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 | ||||
|  | ||||
|   | ||||
| @@ -73,10 +73,15 @@ mingw32: | ||||
| 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=$@ | ||||
| @@ -217,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 | ||||
|   | ||||
| @@ -1,38 +1,54 @@ | ||||
| Curl and libcurl 7.21.7 | ||||
| Curl and libcurl 7.26.0 | ||||
|  | ||||
|  Public curl releases:         123 | ||||
|  Command line options:         144 | ||||
|  curl_easy_setopt() options:   186 | ||||
|  Public curl releases:         127 | ||||
|  Command line options:         151 | ||||
|  curl_easy_setopt() options:   199 | ||||
|  Public functions in libcurl:  58 | ||||
|  Known libcurl bindings:       39 | ||||
|  Contributors:                 868 | ||||
|  Contributors:                 929 | ||||
|  | ||||
| This release includes the following changes: | ||||
|  | ||||
|  o recognize the [protocol]:// prefix in proxy hosts where the protocol is one | ||||
|    of socks4, socks4a, socks5 or socks5h. | ||||
|  o Added CURLOPT_CLOSESOCKETFUNCTION and CURLOPT_CLOSESOCKETDATA | ||||
|  o nss: the minimal supported version of NSS bumped to 3.12.x | ||||
|  o nss: human-readable names are now provided for NSS errors if available | ||||
|  o add a manual page for mk-ca-bundle | ||||
|  o added --post303 and the CURL_REDIR_POST_303 option for CURLOPT_POSTREDIR | ||||
|  o smtp: Add support for DIGEST-MD5 authentication | ||||
|  o pop3: Added support for additional pop3 commands | ||||
|  | ||||
| This release includes the following bugfixes: | ||||
|  | ||||
|  o SECURITY ADVISORY: inappropriate GSSAPI delegation. Full details at | ||||
|    http://curl.haxx.se/docs/adv_20110623.html | ||||
|  o NTLM: work with unicode | ||||
|  o fix connect with SOCKS proxy when using the multi interface | ||||
|  o anyauthput.c: stdint.h must not be included unconditionally | ||||
|  o CMake: improved build | ||||
|  o SCP/SFTP enable non-blocking earlier | ||||
|  o GnuTLS handshake: fix timeout | ||||
|  o cyassl: build without filesystem | ||||
|  o HTTPS over HTTP proxy using the multi interface | ||||
|  o speedcheck: invalid timeout event on a reused handle | ||||
|  o Force connection close for HTTP 200 OK when time condition matched | ||||
|  o curl_formget: fix FILE * leak | ||||
|  o configure: improved OpenSSL detection | ||||
|  o Android build: support gingerbread | ||||
|  o CURLFORM_STREAM: acknowledge CURLFORM_FILENAME | ||||
|  o windows build: use correct MS CRT | ||||
|  o pop3: remove extra space in LIST command | ||||
|  o nss: libcurl now uses NSS_InitContext() to prevent collisions if available | ||||
|    [1] | ||||
|  o URL parse: reject numerical IPv6 addresses outside brackets [4] | ||||
|  o MD5: fix OOM memory leak [5] | ||||
|  o OpenSSL cert: provide more details when cert check fails | ||||
|  o HTTP: empty chunked POST ended up in two zero size chunks [6] | ||||
|  o fixed a regression when curl resolved to multiple addresses and the first | ||||
|    isn't supported [7] | ||||
|  o -# progress meter: avoid superfluous updates and duplicate lines [8] | ||||
|  o headers: surround GCC attribute names with double underscores [9] | ||||
|  o PolarSSL: correct return code for CRL matches | ||||
|  o PolarSSL: include version number in version string | ||||
|  o PolarSSL: add support for asynchronous connect | ||||
|  o mk-ca-bundle: revert the LWP usage [12] | ||||
|  o IPv6 cookie domain: get rid of the first bracket before the second | ||||
|  o connect.c: return changed to CURLE_COULDNT_CONNECT when opensocket fails | ||||
|  o OpenSSL: Made cert hostname check conform to RFC 6125 [10] | ||||
|  o HTTP: reset expected DL/UL sizes on redirects [11] | ||||
|  o CMake: fix Windows LDAP/LDAPS option handling [2] | ||||
|  o CMake: fix MS Visual Studio x64 unsigned long long literal suffix [3] | ||||
|  o configure: update detection logic of getaddrinfo() thread-safeness | ||||
|  o configure: check for gethostbyname in the watt lib | ||||
|  o curl-config.1: fix curl-config usage in example [13] | ||||
|  o smtp: Fixed non-escaping of dot character at beginning of line | ||||
|  o MakefileBuild.vc: use the correct IDN variable | ||||
|  o autoconf: improve handling of versioned symbols | ||||
|  o curl.1: clarify -x usage | ||||
|  o curl: shorten user-agent | ||||
|  o smtp: issue with the multi-interface always sending postdata [14] | ||||
|  o compile error with GnuTLS+Nettle fixed | ||||
|  o winbuild: fix IPv6 enabled build | ||||
|  | ||||
| This release includes the following known bugs: | ||||
|  | ||||
| @@ -41,9 +57,29 @@ 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: | ||||
|  | ||||
|  Dan Fandrich, Guenter Knauf, Vsevolod Novikov, Zmey Petroff, | ||||
|  Dagobert Michelsen, Jeff Pohlmeyer, Dmitri Shubin, Matteo Rocco, | ||||
|  Aaron Orenstein, Yang Tse, Kamil Dudka, Amr Shahin, Josue Andrade Gomes, | ||||
|  Ori Avtalion, Richard Silverman, Julien Chaffraix | ||||
|  Andrei Cipu, Armel Asselin, Benjamin Johnson, Dag Ekengren, Dave Reisner, | ||||
|  Gokhan Sengun, Guenter Knauf, Jan Schaumann, Jonathan Nieder, Kamil Dudka, | ||||
|  Lijo Antony, Olaf Flebbe, Rodrigo Silva, Steve Holme, Tatsuhiro Tsujikawa, | ||||
|  Tim Heckman, Yang Tse, Arnaud Compan, Blaise Potard, Daniel Theron, | ||||
|  Michael Mueller, Michael Wallner, Tim Heckman, Roman Mamedov, Julian Taylor, | ||||
|  Claes Jakobsson, Pierre Chapuis, Jan Ehrhardt | ||||
|  | ||||
|         Thanks! (and sorry if I forgot to mention someone) | ||||
|  | ||||
| References to bug reports and discussions on issues: | ||||
|  | ||||
|  [1] = https://bugzilla.redhat.com/738456 | ||||
|  [2] = http://curl.haxx.se/mail/lib-2012-03/0278.html | ||||
|  [3] = http://curl.haxx.se/mail/lib-2012-03/0255.html | ||||
|  [4] = http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=670126 | ||||
|  [5] = http://curl.haxx.se/mail/lib-2012-04/0246.html | ||||
|  [6] = http://curl.haxx.se/mail/archive-2012-04/0060.html | ||||
|  [7] = http://curl.haxx.se/bug/view.cgi?id=3516508 | ||||
|  [8] = http://curl.haxx.se/bug/view.cgi?id=3517418 | ||||
|  [9] = http://curl.haxx.se/mail/lib-2012-04/0127.html | ||||
|  [10] = http://tools.ietf.org/html/rfc6125#section-6.4.3 | ||||
|  [11] = http://curl.haxx.se/bug/view.cgi?id=3510057 | ||||
|  [12] = http://curl.haxx.se/mail/lib-2012-03/0238.html | ||||
|  [13] = http://curl.haxx.se/bug/view.cgi?id=3528241 | ||||
|  [14] = http://curl.haxx.se/mail/lib-2012-05/0108.html | ||||
|   | ||||
							
								
								
									
										17
									
								
								TODO-RELEASE
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								TODO-RELEASE
									
									
									
									
									
								
							| @@ -1,15 +1,10 @@ | ||||
| To be addressed in 7.21.6 | ||||
| ========================= | ||||
| To be addressed in 7.27 | ||||
| ======================= | ||||
|  | ||||
| 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 | ||||
| 309 - metalink support for the curl tool | ||||
|  | ||||
| 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 | ||||
| 310 - a new authentication callback | ||||
|  | ||||
| 287 - bug 3215314 Post quote operation to rename fails in Windows | ||||
| 311 - support for SSPI schannel for SSL on windows | ||||
|  | ||||
| 289 - | ||||
| 312 -  | ||||
|   | ||||
							
								
								
									
										11
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -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 | ||||
| @@ -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="" | ||||
| @@ -228,12 +228,7 @@ AC_DEFUN([CURL_CHECK_NATIVE_WINDOWS], [ | ||||
|       ]) | ||||
|     fi | ||||
|   ]) | ||||
|   case "$ac_cv_native_windows" in | ||||
|     yes) | ||||
|       AC_DEFINE_UNQUOTED(NATIVE_WINDOWS, 1, | ||||
|         [Define to 1 if you are building a native Windows target.]) | ||||
|       ;; | ||||
|   esac | ||||
|   AM_CONDITIONAL(DOING_NATIVE_WINDOWS, test "x$ac_cv_native_windows" = xyes) | ||||
| ]) | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										169
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										169
									
								
								buildconf
									
									
									
									
									
								
							| @@ -6,7 +6,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 | ||||
| @@ -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 | ||||
|  | ||||
| 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 | ||||
| if test -z "$lt_major"; then | ||||
|   lt_status="bad" | ||||
|    elif test -n "$LIBTOOL_WANTED_PATCH"; then | ||||
|        if test "$lt_minor" -gt "$LIBTOOL_WANTED_MINOR"; then | ||||
| elif test "$lt_major" -gt "$want_lt_major"; then | ||||
|   lt_status="good" | ||||
|        elif test -n "$lt_patch"; then | ||||
|           if test "$lt_patch" -lt "$LIBTOOL_WANTED_PATCH"; then | ||||
| 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" | ||||
|           fi | ||||
| else | ||||
|           lt_status="bad" | ||||
|   lt_status="good" | ||||
| fi | ||||
|    fi | ||||
| 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,49 @@ 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" | ||||
| 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 | ||||
| else | ||||
|   echo "buildconf: perl not found" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| echo "buildconf: running autoheader" | ||||
| ${AUTOHEADER:-autoheader} || die "The 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 | ||||
| ${AUTOHEADER:-autoheader} || die "autoheader command failed" | ||||
|  | ||||
| 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 +395,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 +447,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 | ||||
| @@ -413,6 +457,5 @@ fi | ||||
| #-------------------------------------------------------------------------- | ||||
| # Finished successfully. | ||||
| # | ||||
|  | ||||
| echo "buildconf: OK" | ||||
| exit 0 | ||||
|   | ||||
							
								
								
									
										415
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										415
									
								
								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 | ||||
| @@ -34,7 +35,7 @@ This configure script may be copied, distributed and modified under the | ||||
| terms of the curl license; see COPYING for more details]) | ||||
|  | ||||
| AC_CONFIG_SRCDIR([lib/urldata.h]) | ||||
| AM_CONFIG_HEADER(lib/curl_config.h src/curl_config.h include/curl/curlbuild.h) | ||||
| AM_CONFIG_HEADER(lib/curl_config.h include/curl/curlbuild.h) | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
| AM_MAINTAINER_MODE | ||||
|  | ||||
| @@ -43,6 +44,7 @@ CURL_CHECK_OPTION_OPTIMIZE | ||||
| CURL_CHECK_OPTION_WARNINGS | ||||
| CURL_CHECK_OPTION_WERROR | ||||
| CURL_CHECK_OPTION_CURLDEBUG | ||||
| CURL_CHECK_OPTION_SYMBOL_HIDING | ||||
| CURL_CHECK_OPTION_ARES | ||||
|  | ||||
| CURL_CHECK_PATH_SEPARATOR_REQUIRED | ||||
| @@ -154,6 +156,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)" | ||||
| @@ -234,21 +237,18 @@ esac | ||||
| AC_MSG_RESULT($mimpure) | ||||
| AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes) | ||||
|  | ||||
| dnl 'STATICLIB' is, in spite of its name, not generic but only for static-only | ||||
| dnl builds on Windows | ||||
| AM_CONDITIONAL(STATICLIB, false) | ||||
|  | ||||
| AC_MSG_CHECKING([if we need BUILDING_LIBCURL]) | ||||
| use_cppflag_building_libcurl="no" | ||||
| use_cppflag_curl_staticlib="no" | ||||
| case $host in | ||||
|   *-*-mingw*) | ||||
|     AC_DEFINE(BUILDING_LIBCURL, 1, [when building libcurl itself]) | ||||
|     AC_MSG_RESULT(yes) | ||||
|     use_cppflag_building_libcurl="yes" | ||||
|     AC_MSG_CHECKING([if we need CURL_STATICLIB]) | ||||
|     if test "X$enable_shared" = "Xno" | ||||
|     then | ||||
|       AC_DEFINE(CURL_STATICLIB, 1, [when not building a shared library]) | ||||
|       AC_MSG_RESULT(yes) | ||||
|       AM_CONDITIONAL(STATICLIB, true) | ||||
|       use_cppflag_curl_staticlib="yes" | ||||
|     else | ||||
|       AC_MSG_RESULT(no) | ||||
|     fi | ||||
| @@ -257,6 +257,8 @@ case $host in | ||||
|     AC_MSG_RESULT(no) | ||||
|     ;; | ||||
| esac | ||||
| AM_CONDITIONAL(USE_CPPFLAG_BUILDING_LIBCURL, test x$use_cppflag_building_libcurl = xyes) | ||||
| AM_CONDITIONAL(USE_CPPFLAG_CURL_STATICLIB, test x$use_cppflag_curl_staticlib = xyes) | ||||
|  | ||||
| # Determine whether all dependent libraries must be specified when linking | ||||
| if test "X$enable_shared" = "Xyes" -a "X$link_all_deplibs" = "Xno" | ||||
| @@ -298,6 +300,7 @@ fi | ||||
|  | ||||
| CURL_CHECK_COMPILER_HALT_ON_ERROR | ||||
| CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | ||||
| CURL_CHECK_COMPILER_SYMBOL_HIDING | ||||
|  | ||||
| CURL_CHECK_NO_UNDEFINED | ||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||
| @@ -314,6 +317,26 @@ if test "x$cross_compiling" != "xno" && | ||||
|   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 | ||||
| @@ -630,6 +653,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 ********************************************************************** | ||||
| @@ -655,6 +697,17 @@ then | ||||
|                ]) | ||||
| fi | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl gethostbyname in the watt lib? | ||||
|   AC_CHECK_LIB(watt, gethostbyname, | ||||
|                [HAVE_GETHOSTBYNAME="1" | ||||
|                CPPFLAGS="-I/dev/env/WATT_ROOT/inc" | ||||
|                LDFLAGS="-L/dev/env/WATT_ROOT/lib" | ||||
|                LIBS="$LIBS -lwatt" | ||||
|                ]) | ||||
| fi | ||||
|  | ||||
| dnl At least one system has been identified to require BOTH nsl and socket | ||||
| dnl libs at the same time to link properly. | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| @@ -1330,7 +1383,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 | ||||
|  | ||||
| @@ -1494,7 +1547,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 | ||||
| @@ -1526,11 +1580,12 @@ 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 | ||||
|  | ||||
|        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 | ||||
|  | ||||
| @@ -1765,12 +1820,13 @@ 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 | ||||
|  | ||||
|           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 | ||||
|  | ||||
|     fi | ||||
|  | ||||
| @@ -1779,17 +1835,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 --- | ||||
| @@ -1875,12 +1947,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 | ||||
|  | ||||
|         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 | ||||
| @@ -1897,7 +1969,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) | ||||
|  | ||||
| @@ -1910,14 +1982,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]) | ||||
| @@ -1939,7 +2006,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]) | ||||
| @@ -1964,11 +2031,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 | ||||
|  | ||||
|         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 | ||||
|  | ||||
| @@ -2023,13 +2091,6 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | ||||
|         nssprefix=$OPT_NSS | ||||
|     fi | ||||
|  | ||||
|     dnl Check for functionPK11_CreateGenericObject | ||||
|     dnl this is needed for using the PEM PKCS#11 module | ||||
|     AC_CHECK_LIB(nss3, PK11_CreateGenericObject, | ||||
|      [ | ||||
|      AC_DEFINE(HAVE_PK11_CREATEGENERICOBJECT, 1, [if you have the function PK11_CreateGenericObject]) | ||||
|      AC_SUBST(HAVE_PK11_CREATEGENERICOBJECT, [1]) | ||||
|      ]) | ||||
|     if test -n "$addlib"; then | ||||
|  | ||||
|       CLEANLIBS="$LIBS" | ||||
| @@ -2040,7 +2101,8 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | ||||
|          CPPFLAGS="$CPPFLAGS $addcflags" | ||||
|       fi | ||||
|  | ||||
|       AC_CHECK_LIB(nss3, NSS_Initialize, | ||||
|       dnl The function PK11_CreateGenericObject is needed to load libnsspem.so | ||||
|       AC_CHECK_LIB(nss3, PK11_CreateGenericObject, | ||||
|        [ | ||||
|        AC_DEFINE(USE_NSS, 1, [if NSS is enabled]) | ||||
|        AC_SUBST(USE_NSS, [1]) | ||||
| @@ -2056,15 +2118,24 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | ||||
|       if test "x$USE_NSS" = "xyes"; then | ||||
|         AC_MSG_NOTICE([detected NSS version $version]) | ||||
|  | ||||
|         dnl NSS_InitContext() was introduced in NSS 3.12.5 and helps to prevent | ||||
|         dnl collisions on NSS initialization/shutdown with other libraries | ||||
|         AC_CHECK_FUNC(NSS_InitContext, | ||||
|         [ | ||||
|           AC_DEFINE(HAVE_NSS_INITCONTEXT, 1, [if you have the NSS_InitContext function]) | ||||
|           AC_SUBST(HAVE_NSS_INITCONTEXT, [1]) | ||||
|         ]) | ||||
|  | ||||
|         dnl when shared libs were found in a path that the run-time | ||||
|         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 | ||||
|  | ||||
|         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 | ||||
|  | ||||
| @@ -2220,11 +2291,12 @@ 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) | ||||
|  | ||||
|        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 | ||||
|     LDFLAGS=$CLEANLDFLAGS | ||||
| @@ -2311,55 +2383,196 @@ if test X"$OPT_LIBRTMP" != Xno; then | ||||
|  | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for linker switch for versioned symbols | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| versioned_symbols_flavour= | ||||
| AC_MSG_CHECKING([whether versioned symbols are wanted]) | ||||
| 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) | ||||
|     AC_MSG_CHECKING([if libraries can be versioned]) | ||||
|     GLD=`$LD --help < /dev/null 2>/dev/null | grep version-script` | ||||
|     if test -z "$GLD"; then | ||||
|         AC_MSG_RESULT(no) | ||||
|         AC_MSG_WARN([You need an ld version supporting the --version-script option]) | ||||
|     else | ||||
|         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" | ||||
|     fi | ||||
|     ;; | ||||
|  | ||||
|   *)   AC_MSG_RESULT(no) | ||||
|     ;; | ||||
|   esac | ||||
| ], [ | ||||
| AC_MSG_RESULT(no) | ||||
| ] | ||||
| ) | ||||
|  | ||||
| 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) | ||||
|     dnl --without-libidn option used | ||||
|     want_idn="no" | ||||
|     AC_MSG_RESULT([no]) | ||||
|     ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|   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 | ||||
|  | ||||
|        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) | ||||
| 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 "x$idn" != "xyes"; then | ||||
|           dnl check with default paths | ||||
|           idn="yes" | ||||
|           AC_CHECK_LIB(idn, idna_to_ascii_lz, , | ||||
|                        idn="") | ||||
|   # | ||||
|   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 | ||||
|  | ||||
|        if test "x$idn" = "xyes"; then | ||||
|          curl_idn_msg="enabled" | ||||
|          AC_SUBST(IDN_ENABLED, [1]) | ||||
|   # | ||||
|   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 | ||||
|  | ||||
|        ;; | ||||
| esac | ||||
|  | ||||
|  | ||||
| dnl Let's hope this split URL remains working: | ||||
| @@ -2419,6 +2632,7 @@ AC_CHECK_HEADERS( | ||||
|         stdbool.h \ | ||||
|         arpa/tftp.h \ | ||||
|         sys/filio.h \ | ||||
|         sys/wait.h \ | ||||
|         setjmp.h, | ||||
| dnl to do if not found | ||||
| [], | ||||
| @@ -2564,6 +2778,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 | ||||
| @@ -2794,6 +3009,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 | ||||
| @@ -2840,48 +3059,9 @@ AC_HELP_STRING([--disable-cookies],[Disable cookies support]), | ||||
| ) | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl Enable hiding of internal symbols in library to reduce its size and | ||||
| dnl speed dynamic linking of applications.  This currently is only supported | ||||
| dnl on gcc >= 4.0 and SunPro C. | ||||
| dnl hiding of library internal symbols | ||||
| dnl | ||||
| AC_MSG_CHECKING([whether to enable hidden symbols in the library]) | ||||
| AC_ARG_ENABLE(hidden-symbols, | ||||
| AC_HELP_STRING([--enable-hidden-symbols],[Hide internal symbols in library]) | ||||
| AC_HELP_STRING([--disable-hidden-symbols],[Leave all symbols with default visibility in library]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        ;; | ||||
|   *) | ||||
|        AC_MSG_CHECKING([whether $CC supports it]) | ||||
|        if test "$GCC" = yes ; then | ||||
|          if $CC --help --verbose 2>&1 | grep fvisibility= > /dev/null || | ||||
|            dnl clang always supports -fvisibility= but it doesn't show up | ||||
|            dnl under --help. | ||||
|            test "$compiler_id" = "CLANG"; then | ||||
|            AC_MSG_RESULT(yes) | ||||
|            AC_DEFINE(CURL_HIDDEN_SYMBOLS, 1, [to enable hidden symbols]) | ||||
|            AC_DEFINE(CURL_EXTERN_SYMBOL, [__attribute__ ((visibility ("default")))], [to make a symbol visible]) | ||||
|            CFLAGS="$CFLAGS -fvisibility=hidden" | ||||
|          else | ||||
|             AC_MSG_RESULT(no) | ||||
|           fi | ||||
|  | ||||
|        else | ||||
|          dnl Test for SunPro cc | ||||
|          if $CC 2>&1 | grep flags >/dev/null && $CC -flags | grep xldscope= >/dev/null ; then | ||||
|            AC_MSG_RESULT(yes) | ||||
|            AC_DEFINE(CURL_HIDDEN_SYMBOLS, 1, [to enable hidden symbols]) | ||||
|            AC_DEFINE(CURL_EXTERN_SYMBOL, [__global], [to make a symbol visible]) | ||||
|            CFLAGS="$CFLAGS -xldscope=hidden" | ||||
|          else | ||||
|            AC_MSG_RESULT(no) | ||||
|          fi | ||||
|        fi | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
| CURL_CONFIGURE_SYMBOL_HIDING | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl enforce SONAME bump | ||||
| @@ -2969,6 +3149,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 | ||||
| @@ -3079,6 +3262,7 @@ AC_CONFIG_FILES([Makefile \ | ||||
|            include/curl/Makefile \ | ||||
|            src/Makefile \ | ||||
|            lib/Makefile \ | ||||
|            lib/libcurl.vers \ | ||||
|            tests/Makefile \ | ||||
|            tests/data/Makefile \ | ||||
|            tests/server/Makefile \ | ||||
| @@ -3123,6 +3307,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | ||||
|   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} | ||||
|   | ||||
| @@ -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. | ||||
|   | ||||
							
								
								
									
										45
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								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) | ||||
|                                   _   _ ____  _ | ||||
|                               ___| | | |  _ \| | | ||||
|                              / __| | | | |_) | | | ||||
| @@ -306,41 +306,10 @@ FAQ | ||||
|   We don't know how many users that downloaded or installed curl and then | ||||
|   never use it. | ||||
|  | ||||
|   Some facts to use as input to the math: | ||||
|   In May 2012 Daniel did a counting game and came up with a number that may | ||||
|   be completely wrong or somewhat accurate. 300 million! | ||||
|  | ||||
|   curl packages are downloaded from the curl.haxx.se and mirrors over a | ||||
|   million times per year. curl is installed by default with most Linux | ||||
|   distributions. curl is installed by default with Mac OS X. curl and libcurl | ||||
|   as used by numerous applications that include libcurl binaries in their | ||||
|   distribution packages (like Adobe Acrobat Reader and Google Earth). | ||||
|  | ||||
|   More than a hundred known named companies use curl in commercial | ||||
|   environments and products and more than a hundred known named open source | ||||
|   projects depend on (lib)curl. | ||||
|  | ||||
|   In a poll on the curl web site mid-2005, more than 50% of the 300+ answers | ||||
|   estimated a user base of one million users or more. | ||||
|  | ||||
|   In March 2005, the "Linux Counter project" estimated a total Linux user base | ||||
|   of some 29 millions, while Netcraft detected some 4 million "active" Linux | ||||
|   based web servers. A guess is that a fair amount of these Linux | ||||
|   installations have curl installed. | ||||
|  | ||||
|   The Debian project maintains statistics on packages installed by people | ||||
|   who have voluntarily run their package counting application.  In mid-2010, | ||||
|   libcurl3 was installed on over 55000 such systems (62% of reporting systems) | ||||
|   and was one of the 320 most popular installed packages (out of about 107000 | ||||
|   possible packages). | ||||
|  | ||||
|   All this taken together, there is no doubt that there are millions of | ||||
|   (lib)curl users. | ||||
|  | ||||
|   http://curl.haxx.se/docs/companies.html | ||||
|   http://curl.haxx.se/docs/programs.html | ||||
|   http://curl.haxx.se/libcurl/using/apps.html | ||||
|   http://counter.li.org/estimates.php | ||||
|   http://news.netcraft.com/archives/2005/03/14/fedora_makes_rapid_progress.html | ||||
|   http://qa.debian.org/popcon.php?package=curl | ||||
|   See http://daniel.haxx.se/blog/2012/05/16/300m-users/ | ||||
|  | ||||
|   1.11 Why don't you update ca-bundle.crt | ||||
|  | ||||
| @@ -726,6 +695,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 | ||||
|   | ||||
							
								
								
									
										63
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -217,9 +217,9 @@ Win32 | ||||
|    adjust as necessary. It is also possible to override these paths with | ||||
|    environment variables, for example: | ||||
|  | ||||
|      set ZLIB_PATH=c:\zlib-1.2.5 | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8r | ||||
|      set LIBSSH2_PATH=c:\libssh2-1.2.8 | ||||
|      set ZLIB_PATH=c:\zlib-1.2.7 | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8x | ||||
|      set LIBSSH2_PATH=c:\libssh2-1.4.2 | ||||
|  | ||||
|    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! | ||||
| @@ -320,7 +320,7 @@ Win32 | ||||
|    documentation on how to compile zlib. Define the ZLIB_PATH environment | ||||
|    variable to the location of zlib.h and zlib.lib, for example: | ||||
|  | ||||
|      set ZLIB_PATH=c:\zlib-1.2.5 | ||||
|      set ZLIB_PATH=c:\zlib-1.2.7 | ||||
|  | ||||
|    Then run 'nmake vc-zlib' in curl's root directory. | ||||
|  | ||||
| @@ -334,7 +334,7 @@ Win32 | ||||
|    Before running nmake define the OPENSSL_PATH environment variable with | ||||
|    the root/base directory of OpenSSL, for example: | ||||
|  | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8q | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8x | ||||
|  | ||||
|    Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root | ||||
|    directory.  'nmake vc-ssl' will create a libcurl static and dynamic | ||||
| @@ -467,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 | ||||
|    ----------------------------------- | ||||
|  | ||||
| @@ -812,7 +840,30 @@ VxWorks | ||||
|  | ||||
| Android | ||||
| ======= | ||||
|    See the build notes in the Android.mk file. | ||||
|    Method using the static makefile: | ||||
|       - see the build notes in the Android.mk file. | ||||
|  | ||||
|    Method using a configure cross-compile (tested with Android NDK r7b): | ||||
|       - prepare the toolchain of the Android NDK for standalone use; this can | ||||
|         be done by invoking the script: | ||||
|         ./tools/make-standalone-toolchain.sh | ||||
|         which creates a usual cross-compile toolchain. Lets assume that you put | ||||
|         this toolchain below /opt then invoke configure with something like: | ||||
|         export PATH=/opt/arm-linux-androideabi-4.4.3/bin:$PATH | ||||
|         ./configure --host=arm-linux-androideabi [more configure options] | ||||
|         make | ||||
|       - if you want to compile directly from our GIT repo you might run into | ||||
|         this issue with older automake stuff: | ||||
|         checking host system type... | ||||
|         Invalid configuration `arm-linux-androideabi': | ||||
|         system `androideabi' not recognized | ||||
|         configure: error: /bin/sh ./config.sub arm-linux-androideabi failed | ||||
|         this issue can be fixed with using more recent versions of config.sub | ||||
|         and config.guess which can be obtained here: | ||||
|         http://git.savannah.gnu.org/gitweb/?p=config.git;a=tree | ||||
|         you need to replace your system-own versions which usually can be | ||||
|         found in your automake folder: | ||||
|         find /usr -name config.sub | ||||
|  | ||||
|  | ||||
| CROSS COMPILE | ||||
|   | ||||
							
								
								
									
										0
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -39,11 +39,11 @@ 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 | ||||
|  NSS          3.11.x | ||||
|  NSS          3.12.x | ||||
|  axTLS        1.2.7 | ||||
|  Heimdal      ? | ||||
|  | ||||
| @@ -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)  ? | ||||
| @@ -104,9 +104,9 @@ Windows vs Unix | ||||
|  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All | ||||
|  conditionals that deal with features *should* instead be in the format | ||||
|  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, | ||||
|  we maintain two curl_config-win32.h files (one in lib/ and one in src/) that | ||||
|  are supposed to look exactly as a curl_config.h file would have looked like on | ||||
|  a Windows machine! | ||||
|  we maintain a curl_config-win32.h file in lib directory that is supposed to | ||||
|  look exactly as a curl_config.h file would have looked like on a Windows | ||||
|  machine! | ||||
|  | ||||
|  Generally speaking: always remember that this will be compiled on dozens of | ||||
|  operating systems. Don't walk on the edge. | ||||
|   | ||||
| @@ -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" | ||||
|   | ||||
| @@ -13,6 +13,7 @@ MAIL ETIQUETTE | ||||
|   1.4 Subscription Required | ||||
|   1.5 Moderation of new posters | ||||
|   1.6 Handling trolls and spam | ||||
|   1.7 How to unsubscribe | ||||
|  | ||||
|  2. Sending mail | ||||
|   2.1 Reply or New Mail | ||||
| @@ -110,6 +111,20 @@ MAIL ETIQUETTE | ||||
|  | ||||
|   Don't feed the trolls! | ||||
|  | ||||
|   1.7 How to unsubscribe | ||||
|  | ||||
|   You unsubscribe the same way you subscribed in the first place. You go to | ||||
|   the page for the particular mailing list you're subscribed to and you enter | ||||
|   your email address and password and press the unsubscribe button. | ||||
|  | ||||
|   Also, this information is included in the headers of every mail that is sent | ||||
|   out to all curl related mailing lists and there's footer in each mail that | ||||
|   links to the "admin" page on which you can unsubscribe and change other | ||||
|   options. | ||||
|  | ||||
|   You NEVER EVER email the mailing list requesting someone else to get you off | ||||
|   the list. | ||||
|  | ||||
|  | ||||
| 2. Sending mail | ||||
|  | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
| @@ -22,9 +22,9 @@ | ||||
|  | ||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | ||||
|  | ||||
| man_MANS = curl.1 curl-config.1 | ||||
| GENHTMLPAGES = curl.html curl-config.html | ||||
| PDFPAGES = curl.pdf curl-config.pdf | ||||
| man_MANS = curl.1 curl-config.1 mk-ca-bundle.1 | ||||
| GENHTMLPAGES = curl.html curl-config.html mk-ca-bundle.html | ||||
| PDFPAGES = curl.pdf curl-config.pdf mk-ca-bundle.pdf | ||||
|  | ||||
| HTMLPAGES = $(GENHTMLPAGES) index.html | ||||
|  | ||||
|   | ||||
							
								
								
									
										0
									
								
								docs/README.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								docs/README.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
								
								
									
										69
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										69
									
								
								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 | ||||
| @@ -47,6 +55,7 @@ Andreas Rieke | ||||
| Andreas Schuldei | ||||
| Andreas Wurf | ||||
| Andrei Benea | ||||
| Andrei Cipu | ||||
| Andres Garcia | ||||
| Andrew Benham | ||||
| Andrew Biggs | ||||
| @@ -63,10 +72,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 | ||||
| @@ -80,9 +91,11 @@ 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 | ||||
| @@ -97,6 +110,7 @@ Brad Burdick | ||||
| Brad Hards | ||||
| Brad King | ||||
| Bradford Bruce | ||||
| Brandon Wang | ||||
| Brendan Jurd | ||||
| Brent Beardsley | ||||
| Brian Akins | ||||
| @@ -113,7 +127,9 @@ Camille Moncelier | ||||
| Caolan McNamara | ||||
| Carsten Lange | ||||
| Casey O'Donnell | ||||
| Cedric Deltheil | ||||
| Chad Monroe | ||||
| Chandrakant Bagul | ||||
| Charles Kerr | ||||
| Chih-Chung Chang | ||||
| Chris "Bob Bob" | ||||
| @@ -125,6 +141,8 @@ Chris Gaukroger | ||||
| Chris Maltby | ||||
| Chris Mumford | ||||
| Chris Smowton | ||||
| Christian Grothoff | ||||
| Christian Hagele | ||||
| Christian Krause | ||||
| Christian Kurz | ||||
| Christian Robottom Reis | ||||
| @@ -135,6 +153,7 @@ Christophe Legry | ||||
| Christopher Conroy | ||||
| Christopher Palow | ||||
| Christopher R. Palmer | ||||
| Christopher Stone | ||||
| Ciprian Badescu | ||||
| Claes Jakobsson | ||||
| Clarence Gardner | ||||
| @@ -149,8 +168,10 @@ Craig A West | ||||
| Craig Davison | ||||
| Craig Markwardt | ||||
| Cris Bailiff | ||||
| Cristian Rodriguez | ||||
| Curt Bogmine | ||||
| Cyrill Osterwalder | ||||
| Dagobert Michelsen | ||||
| Damien Adant | ||||
| Dan Becker | ||||
| Dan C | ||||
| @@ -218,6 +239,7 @@ Dmitry Rechkin | ||||
| Dolbneff A.V | ||||
| Domenico Andreoli | ||||
| Dominick Meglio | ||||
| Dominique Leuenberger | ||||
| Doug Kaufman | ||||
| Doug Porter | ||||
| Douglas E. Wegscheid | ||||
| @@ -258,6 +280,7 @@ Erwin Authried | ||||
| Eugene Kotlyarov | ||||
| Evan Jordan | ||||
| Eygene Ryabinkin | ||||
| Fabian Hiernaux | ||||
| Fabian Keil | ||||
| Fabrizio Ammollo | ||||
| Fedor Karpelevitch | ||||
| @@ -270,11 +293,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 | ||||
| @@ -298,6 +323,7 @@ Giuseppe Attardi | ||||
| Giuseppe D'Ambrosio | ||||
| Glen Nakamura | ||||
| Glen Scott | ||||
| Gokhan Sengun | ||||
| Grant Erickson | ||||
| Greg Hewgill | ||||
| Greg Morse | ||||
| @@ -323,6 +349,7 @@ Heinrich Ko | ||||
| Hendrik Visage | ||||
| Henrik Storner | ||||
| Henry Ludemann | ||||
| Herve Amblard | ||||
| Hidemoto Nakada | ||||
| Hoi-Ho Chan | ||||
| Hongli Lai | ||||
| @@ -364,6 +391,8 @@ Jan Kunder | ||||
| Jan Van Boghout | ||||
| Jared Lundell | ||||
| Jari Sundell | ||||
| Jason Glasgow | ||||
| Jason Liu | ||||
| Jason McDonald | ||||
| Jason S. Priebe | ||||
| Jay Austin | ||||
| @@ -384,11 +413,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 | ||||
| @@ -398,11 +429,13 @@ Jofell Gallardo | ||||
| Johan Anderson | ||||
| Johan Nilsson | ||||
| Johan van Selst | ||||
| Johannes Bauer | ||||
| John Bradshaw | ||||
| John Crow | ||||
| John Dennis | ||||
| John E. Malmberg | ||||
| John Janssen | ||||
| John Joseph Bachir | ||||
| John Kelly | ||||
| John Lask | ||||
| John Lightsey | ||||
| @@ -417,6 +450,7 @@ Jon Sargeant | ||||
| Jon Travis | ||||
| Jon Turner | ||||
| Jonas Forsman | ||||
| Jonas Schnelli | ||||
| Jonatan Lander | ||||
| Jonathan Hseu | ||||
| Jongki Suwandi | ||||
| @@ -425,6 +459,7 @@ Josef Wolf | ||||
| Josh Kapell | ||||
| Joshua Kwan | ||||
| Josue Andrade Gomes | ||||
| Juan Barreto | ||||
| Juan F. Codagnone | ||||
| Juan Ignacio Herv<72>s | ||||
| Judson Bishop | ||||
| @@ -432,6 +467,7 @@ Juergen Wilke | ||||
| Jukka Pihl | ||||
| Julian Noble | ||||
| Julien Chaffraix | ||||
| Julien Royer | ||||
| Jun-ichiro itojun Hagino | ||||
| Jurij Smakov | ||||
| Justin Fletcher | ||||
| @@ -503,18 +539,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 | ||||
| @@ -544,6 +584,7 @@ Matt Kraai | ||||
| Matt Veenstra | ||||
| Matt Witherspoon | ||||
| Matt Wixson | ||||
| Matteo Rocco | ||||
| Matthew Blain | ||||
| Matthew Clarke | ||||
| Matthias Bolte | ||||
| @@ -552,6 +593,7 @@ Mauro Iorio | ||||
| Max Katsev | ||||
| Maxim Ivanov | ||||
| Maxim Perenesenko | ||||
| Maxim Prohorov | ||||
| Mehmet Bozkurt | ||||
| Mekonikum | ||||
| Mettgut Jamalla | ||||
| @@ -559,10 +601,12 @@ Michael Benedict | ||||
| Michael Calmer | ||||
| Michael Cronenworth | ||||
| Michael Curtis | ||||
| Michael Day | ||||
| Michael Goffioul | ||||
| Michael Jahn | ||||
| Michael Jerris | ||||
| Michael Mealling | ||||
| Michael Mueller | ||||
| Michael Smith | ||||
| Michael Stillwell | ||||
| Michael Wallner | ||||
| @@ -588,6 +632,7 @@ Moonesamy | ||||
| Nathan Coulter | ||||
| Nathan O'Sullivan | ||||
| Nathanael Nerode | ||||
| Naveen Chandran | ||||
| Naveen Noel | ||||
| Neil Dunbar | ||||
| Neil Spring | ||||
| @@ -605,6 +650,7 @@ Nikita Schmidt | ||||
| Nikitinskit Dmitriy | ||||
| Niklas Angebrand | ||||
| Nikolai Kondrashov | ||||
| Nikos Mavrogiannopoulos | ||||
| Ning Dong | ||||
| Nir Soffer | ||||
| Nis Jorgensen | ||||
| @@ -615,15 +661,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 | ||||
| @@ -641,6 +691,7 @@ Pete Su | ||||
| Peter Bray | ||||
| Peter Forret | ||||
| Peter Heuchert | ||||
| Peter Hjalmarsson | ||||
| Peter Korsgaard | ||||
| Peter Lamberg | ||||
| Peter O'Gorman | ||||
| @@ -664,6 +715,7 @@ Philippe Vaucher | ||||
| Pierre | ||||
| Pierre Brico | ||||
| Pierre Joye | ||||
| Pierre Ynard | ||||
| Pooyan McSporran | ||||
| Pramod Sharma | ||||
| Puneet Pawaia | ||||
| @@ -690,6 +742,7 @@ Renaud Duhaut | ||||
| Rene Bernhardt | ||||
| Rene Rebe | ||||
| Reuven Wachtfogel | ||||
| Reza Arbab | ||||
| Ricardo Cadime | ||||
| Rich Gray | ||||
| Rich Rauenzahn | ||||
| @@ -700,16 +753,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 | ||||
| @@ -778,6 +834,8 @@ Stephen Kick | ||||
| Stephen More | ||||
| Sterling Hughes | ||||
| Steve Green | ||||
| Steve H Truong | ||||
| Steve Holme | ||||
| Steve Lhomme | ||||
| Steve Little | ||||
| Steve Marx | ||||
| @@ -786,6 +844,7 @@ Steve Roskowski | ||||
| Steven Bazyl | ||||
| Steven G. Johnson | ||||
| Steven M. Schweda | ||||
| Steven Parkes | ||||
| Stoned Elipot | ||||
| Sven Anders | ||||
| Sven Neuhaus | ||||
| @@ -793,10 +852,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 | ||||
| @@ -805,6 +866,7 @@ Tim Baker | ||||
| Tim Bartley | ||||
| Tim Chen | ||||
| Tim Costello | ||||
| Tim Harder | ||||
| Tim Newsome | ||||
| Tim Sneddon | ||||
| Tinus van den Berg | ||||
| @@ -812,6 +874,7 @@ Tobias Rundstr | ||||
| Toby Peterson | ||||
| Todd A Ouska | ||||
| Todd Kulesza | ||||
| Todd Ouska | ||||
| Todd Vierling | ||||
| Tom Benoist | ||||
| Tom Donovan | ||||
| @@ -820,6 +883,7 @@ Tom Mattison | ||||
| Tom Moers | ||||
| Tom Mueller | ||||
| Tom Regner | ||||
| Tom Wright | ||||
| Tom Zerucha | ||||
| Tomas Pospisek | ||||
| Tomas Szepe | ||||
| @@ -827,6 +891,7 @@ Tomasz Lacki | ||||
| Tommie Gannert | ||||
| Tommy Tam | ||||
| Ton Voon | ||||
| Toni Moreno | ||||
| Toon Verwaest | ||||
| Tor Arntsen | ||||
| Torsten Foertsch | ||||
| @@ -849,11 +914,13 @@ 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 | ||||
| @@ -861,10 +928,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 | ||||
|   | ||||
							
								
								
									
										276
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										276
									
								
								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,63 +54,69 @@ | ||||
|  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 | ||||
|  | ||||
|  9. Other protocols | ||||
|  9. SMTP | ||||
|  9.1 Other authentication mechanims | ||||
|  9.2 Specify the preferred authentication mechanism | ||||
|  9.3 Initial response | ||||
|  9.4 Pipelining | ||||
|   | ||||
|  10. New protocols | ||||
|  10.1 RSYNC | ||||
|  10. POP3 | ||||
|  10.1 APOP Authentication | ||||
|  10.2 Other authentication mechanims | ||||
|  10.3 auth= in URLs | ||||
|   | ||||
|  11. Client | ||||
|  11.1 sync | ||||
|  11.2 glob posts | ||||
|  11.3 prevent file overwriting | ||||
|  11.4 simultaneous parallel transfers | ||||
|  11.5 provide formpost headers | ||||
|  11.6 url-specific options | ||||
|  11.7 metalink support | ||||
|  11.8 warning when setting an option | ||||
|  11. Other protocols | ||||
|  | ||||
|  12. Build | ||||
|  12.1 roffit | ||||
|  12. New protocols | ||||
|  12.1 RSYNC | ||||
|  | ||||
|  13. Test suite | ||||
|  13.1 SSL tunnel | ||||
|  13.2 nicer lacking perl message | ||||
|  13.3 more protocols supported | ||||
|  13.4 more platforms supported | ||||
|  13. Client | ||||
|  13.1 sync | ||||
|  13.2 glob posts | ||||
|  13.3 prevent file overwriting | ||||
|  13.4 simultaneous parallel transfers | ||||
|  13.5 provide formpost headers | ||||
|  13.6 url-specific options | ||||
|  13.7 metalink support | ||||
|  13.8 warning when setting an option | ||||
|  13.9 IPv6 addresses with globbing | ||||
|  | ||||
|  14. Next SONAME bump | ||||
|  14.1 http-style HEAD output for ftp | ||||
|  14.2 combine error codes | ||||
|  14.3 extend CURLOPT_SOCKOPTFUNCTION prototype | ||||
|  14. Build | ||||
|  14.1 roffit | ||||
|  | ||||
|  15. Next major release | ||||
|  15.1 cleanup return codes | ||||
|  15.2 remove obsolete defines | ||||
|  15.3 size_t | ||||
|  15.4 remove several functions | ||||
|  15.5 remove CURLOPT_FAILONERROR | ||||
|  15.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE | ||||
|  15.7 remove progress meter from libcurl | ||||
|  15. Test suite | ||||
|  15.1 SSL tunnel | ||||
|  15.2 nicer lacking perl message | ||||
|  15.3 more protocols supported | ||||
|  15.4 more platforms supported | ||||
|  | ||||
|  16. Next SONAME bump | ||||
|  16.1 http-style HEAD output for ftp | ||||
|  16.2 combine error codes | ||||
|  16.3 extend CURLOPT_SOCKOPTFUNCTION prototype | ||||
|  | ||||
|  17. Next major release | ||||
|  17.1 cleanup return codes | ||||
|  17.2 remove obsolete defines | ||||
|  17.3 size_t | ||||
|  17.4 remove several functions | ||||
|  17.5 remove CURLOPT_FAILONERROR | ||||
|  17.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE | ||||
|  17.7 remove progress meter from libcurl | ||||
|  17.8 remove 'curl_httppost' from public | ||||
|  17.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 +150,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/rfc6555 | ||||
|  | ||||
|  | ||||
| 2. libcurl - multi interface | ||||
|  | ||||
| 2.1 More non-blocking | ||||
| @@ -153,7 +181,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 +197,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 +344,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 +355,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 | ||||
| @@ -372,18 +371,65 @@ to provide the data to send. | ||||
|  The correct fix would be to detect which crypto layer that is in use and | ||||
|  adapt our code to use that instead of blindly assuming gcrypt. | ||||
|  | ||||
| 9. Other protocols | ||||
| 9. SMTP | ||||
|  | ||||
| 10. New protocols | ||||
| 9.1 Other authentication mechanims | ||||
|  | ||||
| 10.1 RSYNC | ||||
|  Add support for other authentication mechanisms such as digest-md5 and | ||||
|  gssapi. | ||||
|  | ||||
|  There's no RFC for protocol nor URI/URL format.  An implementation should | ||||
|  most probably use an existing rsync library, such as librsync. | ||||
| 9.2 Specify the preferred authentication mechanism | ||||
|  | ||||
| 11. Client | ||||
|  Add the ability to specify the preferred authentication mechanism or a list | ||||
|  of mechanims that should be used. Not only that, but the order that is | ||||
|  returned by the server during the EHLO response should be honored by curl. | ||||
|   | ||||
| 11.1 sync | ||||
| 9.3 Initial response | ||||
|  | ||||
|  Add the ability for the user to specify whether the initial response is | ||||
|  included in the AUTH command. Some email servers, such as Microsoft | ||||
|  Exchange, can work with either whilst others need to have the initial | ||||
|  response sent separately: | ||||
|   | ||||
|  http://curl.haxx.se/mail/lib-2012-03/0114.html | ||||
|   | ||||
| 9.4 Pipelining | ||||
|  | ||||
|  Add support for pipelining emails. | ||||
|   | ||||
| 10. POP3 | ||||
|  | ||||
| 10.1 APOP Authentication | ||||
|  | ||||
|  Add support for the APOP command rather than using plain text authentication | ||||
|  (USER and PASS) as this is very week security wise. Note: The APOP command | ||||
|  is specified as "APOP <username> <md5 password>", however, it isn't | ||||
|  supported by all mail servers. | ||||
|   | ||||
| 10.2 Other authentication mechanims | ||||
|  | ||||
|  SASL offers support for additional authentication mechanisms via the AUTH | ||||
|  command. Detection of an email server's support for SASL authentication | ||||
|  can be detected via the CAPA command whilst a list of supported mechanisms | ||||
|  can be retrieved with an empty AUTH command. | ||||
|   | ||||
| 10.3 auth= in URLs | ||||
|  | ||||
|  Being able to specify the preferred authentication mechanim in the URL as | ||||
|  per RFC-2384 (http://tools.ietf.org/html/rfc2384). | ||||
|   | ||||
| 11. Other protocols | ||||
|  | ||||
| 12. New protocols | ||||
|  | ||||
| 12.1 RSYNC | ||||
|  | ||||
|  There's no RFC for the protocol or an URI/URL format.  An implementation | ||||
|  should most probably use an existing rsync library, such as librsync. | ||||
|  | ||||
| 13. Client | ||||
|  | ||||
| 13.1 sync | ||||
|  | ||||
|  "curl --sync http://example.com/feed[1-100].rss" or | ||||
|  "curl --sync http://example.net/{index,calendar,history}.html" | ||||
| @@ -392,12 +438,12 @@ to provide the data to send. | ||||
|  remote file is newer than the local file. A Last-Modified HTTP date header | ||||
|  should also be used to set the mod date on the downloaded file. | ||||
|  | ||||
| 11.2 glob posts | ||||
| 13.2 glob posts | ||||
|  | ||||
|  Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'. | ||||
|  This is easily scripted though. | ||||
|  | ||||
| 11.3 prevent file overwriting | ||||
| 13.3 prevent file overwriting | ||||
|  | ||||
|  Add an option that prevents cURL from overwriting existing local files. When | ||||
|  used, and there already is an existing file with the target file name | ||||
| @@ -405,14 +451,14 @@ to provide the data to send. | ||||
|  existing). So that index.html becomes first index.html.1 and then | ||||
|  index.html.2 etc. | ||||
|  | ||||
| 11.4 simultaneous parallel transfers | ||||
| 13.4 simultaneous parallel transfers | ||||
|  | ||||
|  The client could be told to use maximum N simultaneous parallel transfers and | ||||
|  then just make sure that happens. It should of course not make more than one | ||||
|  connection to the same remote host. This would require the client to use the | ||||
|  multi interface. http://curl.haxx.se/bug/feature.cgi?id=1558595 | ||||
|  | ||||
| 11.5 provide formpost headers | ||||
| 13.5 provide formpost headers | ||||
|  | ||||
|  Extending the capabilities of the multipart formposting. How about leaving | ||||
|  the ';type=foo' syntax as it is and adding an extra tag (headers) which | ||||
| @@ -426,7 +472,7 @@ to provide the data to send. | ||||
|  which should overwrite the program reasonable defaults (plain/text, | ||||
|  8bit...) | ||||
|  | ||||
| 11.6 url-specific options | ||||
| 13.6 url-specific options | ||||
|  | ||||
|  Provide a way to make options bound to a specific URL among several on the | ||||
|  command line. Possibly by letting ':' separate options between URLs, | ||||
| @@ -440,55 +486,62 @@ to provide the data to send. | ||||
|  | ||||
|  The example would do a POST-GET-POST combination on a single command line. | ||||
|  | ||||
| 11.7 metalink support | ||||
| 13.7 metalink support | ||||
|  | ||||
|  Add metalink support to curl (http://www.metalinker.org/). This is most useful | ||||
|  with simultaneous parallel transfers (11.6) but not necessary. | ||||
|  | ||||
| 11.8 warning when setting an option | ||||
| 13.8 warning when setting an option | ||||
|  | ||||
|   Display a warning when libcurl returns an error when setting an option. | ||||
|   This can be useful to tell when support for a particular feature hasn't been | ||||
|   compiled into the library. | ||||
|  | ||||
| 12. Build | ||||
| 13.9 IPv6 addresses with globbing | ||||
|  | ||||
| 12.1 roffit | ||||
|   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. | ||||
|  | ||||
| 14. Build | ||||
|  | ||||
| 14.1 roffit | ||||
|  | ||||
|  Consider extending 'roffit' to produce decent ASCII output, and use that | ||||
|  instead of (g)nroff when building src/hugehelp.c | ||||
|  | ||||
| 13. Test suite | ||||
| 15. Test suite | ||||
|  | ||||
| 13.1 SSL tunnel | ||||
| 15.1 SSL tunnel | ||||
|  | ||||
|  Make our own version of stunnel for simple port forwarding to enable HTTPS | ||||
|  and FTP-SSL tests without the stunnel dependency, and it could allow us to | ||||
|  provide test tools built with either OpenSSL or GnuTLS | ||||
|  | ||||
| 13.2 nicer lacking perl message | ||||
| 15.2 nicer lacking perl message | ||||
|  | ||||
|  If perl wasn't found by the configure script, don't attempt to run the tests | ||||
|  but explain something nice why it doesn't. | ||||
|  | ||||
| 13.3 more protocols supported | ||||
| 15.3 more protocols supported | ||||
|  | ||||
|  Extend the test suite to include more protocols. The telnet could just do ftp | ||||
|  or http operations (for which we have test servers). | ||||
|  | ||||
| 13.4 more platforms supported | ||||
| 15.4 more platforms supported | ||||
|  | ||||
|  Make the test suite work on more platforms. OpenBSD and Mac OS. Remove | ||||
|  fork()s and it should become even more portable. | ||||
|  | ||||
| 14. Next SONAME bump | ||||
| 16. Next SONAME bump | ||||
|  | ||||
| 14.1 http-style HEAD output for ftp | ||||
| 16.1 http-style HEAD output for ftp | ||||
|  | ||||
|  #undef CURL_FTP_HTTPSTYLE_HEAD in lib/ftp.c to remove the HTTP-style headers | ||||
|  from being output in NOBODY requests over ftp | ||||
|  | ||||
| 14.2 combine error codes | ||||
| 16.2 combine error codes | ||||
|  | ||||
|  Combine some of the error codes to remove duplicates.  The original | ||||
|  numbering should not be changed, and the old identifiers would be | ||||
| @@ -506,29 +559,29 @@ to provide the data to send. | ||||
|     CURLE_TFTP_NOTFOUND => CURLE_REMOTE_FILE_NOT_FOUND | ||||
|     CURLE_TFTP_PERM => CURLE_REMOTE_ACCESS_DENIED | ||||
|  | ||||
| 14.3 extend CURLOPT_SOCKOPTFUNCTION prototype | ||||
| 16.3 extend CURLOPT_SOCKOPTFUNCTION prototype | ||||
|  | ||||
|  The current prototype only provides 'purpose' that tells what the | ||||
|  connection/socket is for, but not any protocol or similar. It makes it hard | ||||
|  for applications to differentiate on TCP vs UDP and even HTTP vs FTP and | ||||
|  similar. | ||||
|  | ||||
| 15. Next major release | ||||
| 17. Next major release | ||||
|  | ||||
| 15.1 cleanup return codes | ||||
| 17.1 cleanup return codes | ||||
|  | ||||
|  curl_easy_cleanup() returns void, but curl_multi_cleanup() returns a | ||||
|  CURLMcode. These should be changed to be the same. | ||||
|  | ||||
| 15.2 remove obsolete defines | ||||
| 17.2 remove obsolete defines | ||||
|  | ||||
|  remove obsolete defines from curl/curl.h | ||||
|  | ||||
| 15.3 size_t | ||||
| 17.3 size_t | ||||
|  | ||||
|  make several functions use size_t instead of int in their APIs | ||||
|  | ||||
| 15.4 remove several functions | ||||
| 17.4 remove several functions | ||||
|  | ||||
|  remove the following functions from the public API: | ||||
|  | ||||
| @@ -549,18 +602,18 @@ to provide the data to send. | ||||
|  | ||||
|  curl_multi_socket_all | ||||
|  | ||||
| 15.5 remove CURLOPT_FAILONERROR | ||||
| 17.5 remove CURLOPT_FAILONERROR | ||||
|  | ||||
|  Remove support for CURLOPT_FAILONERROR, it has gotten too kludgy and weird | ||||
|  internally. Let the app judge success or not for itself. | ||||
|  | ||||
| 15.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE | ||||
| 17.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE | ||||
|  | ||||
|  Remove support for a global DNS cache. Anything global is silly, and we | ||||
|  already offer the share interface for the same functionality but done | ||||
|  "right". | ||||
|  | ||||
| 15.7 remove progress meter from libcurl | ||||
| 17.7 remove progress meter from libcurl | ||||
|  | ||||
|  The internally provided progress meter output doesn't belong in the library. | ||||
|  Basically no application wants it (apart from curl) but instead applications | ||||
| @@ -569,3 +622,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. | ||||
|  | ||||
| 17.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. | ||||
|  | ||||
| 17.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. | ||||
|   | ||||
| @@ -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 | ||||
| @@ -93,7 +93,6 @@ What's the installed libcurl version? | ||||
|  | ||||
| How do I build a single file with a one-line command? | ||||
|  | ||||
|   $ `curl-config --cc --cflags --libs` -o example example.c | ||||
|  | ||||
|   $ `curl-config --cc --cflags` -o example example.c `curl-config --libs` | ||||
| .SH "SEE ALSO" | ||||
| .BR curl (1) | ||||
|   | ||||
							
								
								
									
										156
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										156
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -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 | ||||
| @@ -20,7 +20,7 @@ | ||||
| .\" * | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl 1 "14 April 2009" "Curl 7.21.6" "Curl Manual" | ||||
| .TH curl 1 "16 February 2012" "Curl 7.25.0" "Curl Manual" | ||||
| .SH NAME | ||||
| curl \- transfer a URL | ||||
| .SH SYNOPSIS | ||||
| @@ -110,7 +110,8 @@ the --option version of them. (This concept with --no options was added in | ||||
| 7.19.0. Previously most options were toggled on/off on repeated use of the | ||||
| same command line option.) | ||||
| .IP "-#, --progress-bar" | ||||
| Make curl display progress information as a progress bar instead of the | ||||
| Make curl display progress as a simple progress bar instead of the standard, | ||||
| more informational, meter. | ||||
| .IP "-0, --http1.0" | ||||
| (HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its | ||||
| internally preferred: HTTP 1.1. | ||||
| @@ -194,7 +195,10 @@ no file will be written. The file will be written using the Netscape cookie | ||||
| file format. If you set the file name to a single dash, "-", the cookies will | ||||
| be written to stdout. | ||||
|  | ||||
| .B NOTE | ||||
| This command line option will activate the cookie engine that makes curl | ||||
| record and use cookies. Another way to activate it is to use the \fI-b, | ||||
| --cookie\fP option. | ||||
|  | ||||
| If the cookie jar can't be created or written to, the whole curl operation | ||||
| won't fail or even report an error clearly. Using -v will get a warning | ||||
| displayed, but that is the only visible feedback you get about this possibly | ||||
| @@ -320,6 +324,18 @@ URL-encode that data and pass it on in the POST. The name part gets an equal | ||||
| sign appended, resulting in \fIname=urlencoded-file-content\fP. Note that the | ||||
| name is expected to be URL-encoded already. | ||||
| .RE | ||||
| .IP "--delegation LEVEL" | ||||
| Set \fILEVEL\fP to tell the server what it is allowed to delegate when it | ||||
| comes to user credentials. Used with GSS/kerberos. | ||||
| .RS | ||||
| .IP "none" | ||||
| Don't allow any delegation. | ||||
| .IP "policy" | ||||
| Delegates if and only if the OK-AS-DELEGATE flag is set in the Kerberos | ||||
| service ticket, which is a matter of realm policy. | ||||
| .IP "always" | ||||
| Unconditionally allow the server to delegate. | ||||
| .RE | ||||
| .IP "--digest" | ||||
| (HTTP) Enables HTTP Digest authentication. This is a authentication that | ||||
| prevents the password from being sent over the wire in clear text. Use this in | ||||
| @@ -348,7 +364,7 @@ passive mode you need to not use \fI-P, --ftp-port\fP or force it with | ||||
| transfers. Curl will normally always first attempt to use EPSV before PASV, | ||||
| but with this option, it will not try using EPSV. | ||||
|  | ||||
| \fB--epsv\fP can be used to explicitly enable EPRT again and \fB--no-epsv\fP | ||||
| \fB--epsv\fP can be used to explicitly enable EPSV again and \fB--no-epsv\fP | ||||
| is an alias for \fB--disable-epsv\fP. | ||||
|  | ||||
| Disabling EPSV only changes the passive behavior. If you want to switch to | ||||
| @@ -418,13 +434,15 @@ may be loaded. | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--capath <CA certificate directory>" | ||||
| (SSL) Tells curl to use the specified certificate directory to verify the | ||||
| peer. The certificates must be in PEM format, and if curl is built against | ||||
| OpenSSL, the directory must have been processed using the c_rehash utility | ||||
| supplied with OpenSSL. Using \fI--capath\fP can allow OpenSSL-powered curl to | ||||
| make SSL-connections much more efficiently than using \fI--cacert\fP if the | ||||
| \fI--cacert\fP file contains many CA certificates. | ||||
| peer. Multiple paths can be provided by separating them with ":" (e.g. | ||||
| \&"path1:path2:path3"). The certificates must be in PEM format, and if curl is | ||||
| built against OpenSSL, the directory must have been processed using the | ||||
| c_rehash utility supplied with OpenSSL. Using \fI--capath\fP can allow | ||||
| OpenSSL-powered curl to make SSL-connections much more efficiently than using | ||||
| \fI--cacert\fP if the \fI--cacert\fP file contains many CA certificates. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| If this option is set, the default capath value will be ignored, and if it is | ||||
| used several times, the last one will be used. | ||||
| .IP "-f, --fail" | ||||
| (HTTP) Fail silently (no output at all) on server errors. This is mostly done | ||||
| to better enable scripts etc to better deal with failed attempts. In | ||||
| @@ -577,7 +595,9 @@ header will be used instead of the internal one. This allows you to make even | ||||
| trickier stuff than curl would normally do. You should not replace internally | ||||
| set headers without knowing perfectly well what you're doing. Remove an | ||||
| internal header by giving a replacement without content on the right side of | ||||
| the colon, as in: -H \&"Host:". | ||||
| the colon, as in: -H \&"Host:". If you send the custom header with no-value then | ||||
| its header must be terminated with a semicolon, such as \-H "X-Custom-Header;" | ||||
| to send "X-Custom-Header:". | ||||
|  | ||||
| curl will make sure that each header you add/replace is sent with the proper | ||||
| end-of-line marker, you should thus \fBnot\fP add that as a part of the header | ||||
| @@ -691,7 +711,8 @@ currently effective on operating systems offering the TCP_KEEPIDLE and | ||||
| TCP_KEEPINTVL socket options (meaning Linux, recent AIX, HP-UX and more). This | ||||
| option has no effect if \fI--no-keepalive\fP is used. (Added in 7.18.0) | ||||
|  | ||||
| If this option is used multiple times, the last occurrence sets the amount. | ||||
| If this option is used multiple times, the last occurrence sets the amount. If | ||||
| unspecified, the option defaults to 60 seconds. | ||||
| .IP "--key <key>" | ||||
| (SSL/SSH) Private key file name. Allows you to provide your private key in this | ||||
| separate file. | ||||
| @@ -741,13 +762,9 @@ was 301, 302, or 303. If the response code was any other 3xx code, curl will | ||||
| re-send the following request using the same unmodified method. | ||||
| .IP "--libcurl <file>" | ||||
| Append this option to any ordinary curl command line, and you will get a | ||||
| libcurl-using source code written to the file that does the equivalent | ||||
| libcurl-using C source code written to the file that does the equivalent | ||||
| of what your command-line operation does! | ||||
|  | ||||
| NOTE: this does not properly support -F and the sending of multipart | ||||
| formposts, so in those cases the output program will be missing necessary | ||||
| calls to \fIcurl_formadd(3)\fP, and possibly more. | ||||
|  | ||||
| If this option is used several times, the last given file name will be | ||||
| used. (Added in 7.16.1) | ||||
| .IP "--limit-rate <speed>" | ||||
| @@ -785,6 +802,12 @@ useful for preventing your batch jobs from hanging for hours due to slow | ||||
| networks or links going down.  See also the \fI--connect-timeout\fP option. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--mail-auth <address>" | ||||
| (SMTP) Specify a single address. This will be used to specify the | ||||
| authentication address (identity) of a submitted message that is being relayed | ||||
| to another server. | ||||
|  | ||||
| (Added in 7.25.0) | ||||
| .IP "--mail-from <address>" | ||||
| (SMTP) Specify a single address that the given mail should get sent from. | ||||
|  | ||||
| @@ -1068,16 +1091,18 @@ file will not be read and used. See the \fI-K, --config\fP for details on the | ||||
| default config file search path. | ||||
| .IP "-Q, --quote <command>" | ||||
| (FTP/SFTP) Send an arbitrary command to the remote FTP or SFTP server. Quote | ||||
| commands are sent BEFORE the transfer takes place (just after the | ||||
| initial PWD command in an FTP transfer, to be exact). To make commands | ||||
| take place after a successful transfer, prefix them with a dash '-'. | ||||
| To make commands be sent after libcurl has changed the working directory, | ||||
| just before the transfer command(s), prefix the command with a '+' (this | ||||
| is only supported for FTP). You may specify any number of commands. If | ||||
| the server returns failure for one of the commands, the entire operation | ||||
| will be aborted. You must send syntactically correct FTP commands as | ||||
| RFC 959 defines to FTP servers, or one of the commands listed below to | ||||
| SFTP servers.  This option can be used multiple times. | ||||
| commands are sent BEFORE the transfer takes place (just after the initial PWD | ||||
| command in an FTP transfer, to be exact). To make commands take place after a | ||||
| successful transfer, prefix them with a dash '-'.  To make commands be sent | ||||
| after libcurl has changed the working directory, just before the transfer | ||||
| command(s), prefix the command with a '+' (this is only supported for | ||||
| FTP). You may specify any number of commands. If the server returns failure | ||||
| for one of the commands, the entire operation will be aborted. You must send | ||||
| syntactically correct FTP commands as RFC 959 defines to FTP servers, or one | ||||
| of the commands listed below to SFTP servers.  This option can be used | ||||
| multiple times. When speaking to a FTP server, prefix the command with an | ||||
| asterisk (*) to make libcurl continue even if the command fails as by default | ||||
| curl will stop at first failure. | ||||
|  | ||||
| SFTP is a binary protocol. Unlike for FTP, libcurl interprets SFTP quote | ||||
| commands itself before sending them to the server.  File names may be quoted | ||||
| @@ -1236,6 +1261,12 @@ connection if the server doesn't support SSL/TLS. (Added in 7.20.0) | ||||
|  | ||||
| This option was formerly known as \fI--ftp-ssl-reqd\fP (added in 7.15.5). That | ||||
| option name can still be used but will be removed in a future version. | ||||
| .IP "--ssl-allow-beast" | ||||
| (SSL) This option tells curl to not work around a security flaw in the SSL3 | ||||
| and TLS1.0 protocols known as BEAST.  If this option isn't used, the SSL layer | ||||
| may use work-arounds known to cause interoperability problems with some older | ||||
| SSL implementations. WARNING: this option loosens the SSL security, and by | ||||
| using this flag you ask for exactly that.  (Added in 7.25.0) | ||||
| .IP "--socks4 <host[:port]>" | ||||
| Use the specified SOCKS4 proxy. If the port number is not specified, it is | ||||
| assumed at port 1080. (Added in 7.15.2) | ||||
| @@ -1266,9 +1297,8 @@ the port number is not specified, it is assumed at port 1080. (Added in | ||||
| This option overrides any previous use of \fI-x, --proxy\fP, as they are | ||||
| mutually exclusive. | ||||
|  | ||||
| Since 7.21.7, this option is superfluous since you can specify a | ||||
| socks5-hostnamae proxy with \fI-x, --proxy\fP using a socks5h:// protocol | ||||
| prefix. | ||||
| Since 7.21.7, this option is superfluous since you can specify a socks5 | ||||
| hostname proxy with \fI-x, --proxy\fP using a socks5h:// protocol prefix. | ||||
|  | ||||
| If this option is used several times, the last one will be used. (This option | ||||
| was previously wrongly documented and used as --socks without the number | ||||
| @@ -1303,8 +1333,7 @@ implementation does not.  The option \fI--socks5-gssapi-nec\fP allows the | ||||
| unprotected exchange of the protection mode negotiation. (Added in 7.19.4). | ||||
| .IP "--stderr <file>" | ||||
| Redirect all writes to stderr to the specified file instead. If the file name | ||||
| is a plain '-', it is instead written to stdout. This option has no point when | ||||
| you're using a shell with decent redirecting capabilities. | ||||
| is a plain '-', it is instead written to stdout. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-t, --telnet-option <OPT=val>" | ||||
| @@ -1456,6 +1485,11 @@ The variables available at this point are: | ||||
| The URL that was fetched last. This is most meaningful if you've told curl | ||||
| to follow location: headers. | ||||
| .TP | ||||
| .B filename_effective | ||||
| The ultimate filename that curl writes out to. This is only meaningful if curl | ||||
| is told to write to a file with the --remote-name or --output option. It's most | ||||
| useful in combination with the --remote-header-name option. (Added in 7.25.1) | ||||
| .TP | ||||
| .B http_code | ||||
| The numerical response code that was found in the last retrieved HTTP(S) or | ||||
| FTP(s) transfer. In 7.18.2 the alias \fBresponse_code\fP was added to show the | ||||
| @@ -1540,7 +1574,7 @@ means the verification was successful. (Added in 7.19.0) | ||||
| .RE | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-x, --proxy <[protocol://][user@password]proxyhost[:port]>" | ||||
| .IP "-x, --proxy <[protocol://][user:password@]proxyhost[:port]>" | ||||
| Use the specified HTTP proxy. If the port number is not specified, it is | ||||
| assumed at port 1080. | ||||
|  | ||||
| @@ -1553,6 +1587,10 @@ converted to HTTP. It means that certain protocol specific operations might | ||||
| not be available. This is not the case if you can tunnel through the proxy, as | ||||
| one with the \fI-p, --proxytunnel\fP option. | ||||
|  | ||||
| User and password that might be provided in the proxy string are URL decoded | ||||
| by libcurl. This allows you to pass in special characters such as @ by using | ||||
| %40 or pass in a colon with %3a. | ||||
|  | ||||
| The proxy host can be specified the exact same way as the proxy environment | ||||
| variables, including the protocol prefix (http://) and the embedded user + | ||||
| password. | ||||
| @@ -1576,6 +1614,14 @@ Specifies a custom FTP command to use instead of LIST when doing file lists | ||||
| with FTP. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
|  | ||||
| .IP "--xattr" | ||||
| When saving output to a file, this option tells curl to store certain file | ||||
| metadata in extened file attributes. Currently, the URL is stored in the | ||||
| xdg.origin.url attribute and, for HTTP, the content type is stored in | ||||
| the mime_type attribute. If the file system does not support extended | ||||
| attributes, a warning is issued. | ||||
|  | ||||
| .IP "-y, --speed-time <time>" | ||||
| If a download is slower than speed-limit bytes per second during a speed-time | ||||
| period, the download gets aborted. If speed-time is used, the default | ||||
| @@ -1591,12 +1637,12 @@ speed-time seconds it gets aborted. speed-time is set with -y and is 30 if | ||||
| not set. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-z, --time-cond <date expression>" | ||||
| (HTTP/FTP/FILE) Request a file that has been modified later than the given time | ||||
| and date, or one that has been modified before that time. The date expression | ||||
| can be all sorts of date strings or if it doesn't match any internal ones, it | ||||
| tries to get the time from a given file name instead! See the | ||||
| \fIcurl_getdate(3)\fP man pages for date expression details. | ||||
| .IP "-z/--time-cond <date expression>|<file>" | ||||
| (HTTP/FTP) Request a file that has been modified later than the given time and | ||||
| date, or one that has been modified before that time. The <date expression> can | ||||
| be all sorts of date strings or if it doesn't match any internal ones, it is | ||||
| taken as a filename and tries to get the modification date (mtime) from <file> | ||||
| instead. See the \fIcurl_getdate(3)\fP man pages for date expression details. | ||||
|  | ||||
| Start the date expression with a dash (-) to make it request for a document | ||||
| that is older than the given date/time, default is a document that is newer | ||||
| @@ -1656,22 +1702,39 @@ Default config file, see \fI-K, --config\fP for details. | ||||
| The environment variables can be specified in lower case or upper case. The | ||||
| lower case version has precedence. http_proxy is an exception as it is only | ||||
| available in lower case. | ||||
|  | ||||
| Using an environment variable to set the proxy has the same effect as using | ||||
| the \fI--proxy\fP option. | ||||
|  | ||||
| .IP "http_proxy [protocol://]<host>[:port]" | ||||
| Sets the proxy server to use for HTTP. | ||||
| .IP "HTTPS_PROXY [protocol://]<host>[:port]" | ||||
| Sets the proxy server to use for HTTPS. | ||||
| .IP "FTP_PROXY [protocol://]<host>[:port]" | ||||
| Sets the proxy server to use for FTP. | ||||
| .IP "[url-protocol]_PROXY [protocol://]<host>[:port]" | ||||
| Sets the proxy server to use for [url-protocol], where the protocol is a | ||||
| protocol that curl supports and as specified in a URL. FTP, FTPS, POP3, IMAP, | ||||
| SMTP, LDAP etc. | ||||
| .IP "ALL_PROXY [protocol://]<host>[:port]" | ||||
| Sets the proxy server to use if no protocol-specific proxy is set. | ||||
| .IP "NO_PROXY <comma-separated list of hosts>" | ||||
| list of host names that shouldn't go through any proxy. If set to a asterisk | ||||
| \&'*' only, it matches all hosts. | ||||
| .SH "PROXY PROTOCOL PREFIXES" | ||||
| Since curl version 7.21.7, the proxy string may be specified with a | ||||
| protocol:// prefix to specify alternative proxy protocols. | ||||
|  | ||||
| Since 7.21.7, the proxy string may be specified with a protocol:// prefix to | ||||
| specify alternative proxy protocols. Use socks4://, socks4a:// or socks5:// to | ||||
| request the specific SOCKS version to be used. No protocol specified, http:// | ||||
| and all others will be treated as HTTP proxies. | ||||
| If no protocol is specified in the proxy string or if the string doesn't match | ||||
| a supported one, the proxy will be treated as a HTTP proxy. | ||||
|  | ||||
| The supported proxy protocol prefixes are as follows: | ||||
| .IP "socks4://" | ||||
| Makes it the equivalent of \fI--socks4\fP | ||||
| .IP "socks4a://" | ||||
| Makes it the equivalent of \fI--socks4a\fP | ||||
| .IP "socks5://" | ||||
| Makes it the equivalent of \fI--socks5\fP | ||||
| .IP "socks5h://" | ||||
| Makes it the equivalent of \fI--socks5-hostname\fP | ||||
| .SH EXIT CODES | ||||
| There are a bunch of different error codes and their corresponding error | ||||
| messages that may appear during bad conditions. At the time of this writing, | ||||
| @@ -1852,4 +1915,3 @@ ftp://ftp.sunet.se/pub/www/utilities/curl/ | ||||
| .SH "SEE ALSO" | ||||
| .BR ftp (1), | ||||
| .BR wget (1) | ||||
|  | ||||
|   | ||||
							
								
								
									
										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 | ||||
|   | ||||
| @@ -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,7 +23,7 @@ | ||||
| AUTOMAKE_OPTIONS = foreign nostdinc | ||||
|  | ||||
| EXTRA_DIST = README Makefile.example Makefile.inc Makefile.m32 \ | ||||
| 	makefile.dj $(COMPLICATED_EXAMPLES) | ||||
| 	Makefile.netware makefile.dj $(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 | ||||
| @@ -40,12 +40,12 @@ INCLUDES = -I$(top_builddir)/include/curl \ | ||||
|  | ||||
| LIBDIR = $(top_builddir)/lib | ||||
|  | ||||
| if STATICLIB | ||||
| # we need this define when building with a static lib on Windows | ||||
| STATICCPPFLAGS = -DCURL_STATICLIB | ||||
| endif | ||||
| AM_CPPFLAGS = -DCURL_NO_OLDIES | ||||
|  | ||||
| CPPFLAGS = -DCURL_NO_OLDIES $(STATICCPPFLAGS) | ||||
| # Mostly for Windows build targets, when using static libcurl | ||||
| if USE_CPPFLAG_CURL_STATICLIB | ||||
| AM_CPPFLAGS += -DCURL_STATICLIB | ||||
| endif | ||||
|  | ||||
| # Dependencies | ||||
| LDADD = $(LIBDIR)/libcurl.la | ||||
|   | ||||
| @@ -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.7 | ||||
| ## 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.7 | ||||
| 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.8x | ||||
| 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.4.2 | ||||
| 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 | ||||
| @@ -127,28 +208,28 @@ 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.7 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../../openssl-0.9.8x | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your LibSSH2 package. | ||||
| ifndef LIBSSH2_PATH | ||||
| LIBSSH2_PATH = ../../../libssh2-1.4.2 | ||||
| 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. | ||||
|   | ||||
| @@ -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 | ||||
| @@ -27,6 +27,7 @@ | ||||
| #  ifdef __VMS | ||||
|      typedef int intptr_t; | ||||
| #  endif | ||||
| #  include <stdint.h> | ||||
| #  include <unistd.h> | ||||
| #endif | ||||
| #include <sys/types.h> | ||||
| @@ -87,12 +88,16 @@ static curlioerr my_ioctl(CURL *handle, curliocmd cmd, void *userp) | ||||
| static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   size_t retcode; | ||||
|   curl_off_t nread; | ||||
|  | ||||
|   intptr_t fd = (intptr_t)stream; | ||||
|  | ||||
|   retcode = read(fd, ptr, size * nmemb); | ||||
|  | ||||
|   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||
|   nread = (curl_off_t)retcode; | ||||
|  | ||||
|   fprintf(stderr, "*** We read %" CURL_FORMAT_CURL_OFF_T | ||||
|           " bytes from file\n", nread); | ||||
|  | ||||
|   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); | ||||
|  | ||||
|   | ||||
							
								
								
									
										149
									
								
								docs/examples/externalsocket.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								docs/examples/externalsocket.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,149 @@ | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  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. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| /* | ||||
|  * 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; | ||||
|   (void)purpose; | ||||
|   (void)address; | ||||
|   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) | ||||
| { | ||||
|   (void)clientp; | ||||
|   (void)curlfd; | ||||
|   (void)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)) == CURL_SOCKET_BAD ) { | ||||
|       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; | ||||
| } | ||||
| @@ -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 | ||||
| @@ -33,7 +33,7 @@ static long file_is_comming(struct curl_fileinfo *finfo, | ||||
| static long file_is_downloaded(struct callback_data *data); | ||||
|  | ||||
| static size_t write_it(char *buff, size_t size, size_t nmemb, | ||||
|                        struct callback_data *data); | ||||
|                        void *cb_data); | ||||
|  | ||||
| int main(int argc, char **argv) | ||||
| { | ||||
| @@ -135,8 +135,9 @@ static long file_is_downloaded(struct callback_data *data) | ||||
| } | ||||
|  | ||||
| static size_t write_it(char *buff, size_t size, size_t nmemb, | ||||
|                        struct callback_data *data) | ||||
|                        void *cb_data) | ||||
| { | ||||
|   struct callback_data *data = cb_data; | ||||
|   size_t written = 0; | ||||
|   if(data->output) | ||||
|     written = fwrite(buff, size, nmemb, data->output); | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
| @@ -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 | ||||
| @@ -51,12 +51,16 @@ | ||||
|    variable's memory when passed in to it from an app like this. */ | ||||
| static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   curl_off_t nread; | ||||
|   /* in real-world cases, this would probably get this data differently | ||||
|      as this fread() stuff is exactly what the library already would do | ||||
|      by default internally */ | ||||
|   size_t retcode = fread(ptr, size, nmemb, stream); | ||||
|  | ||||
|   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||
|   nread = (curl_off_t)retcode; | ||||
|  | ||||
|   fprintf(stderr, "*** We read %" CURL_FORMAT_CURL_OFF_T | ||||
|           " bytes from file\n", nread); | ||||
|   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; | ||||
|  | ||||
|   | ||||
| @@ -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 | ||||
| @@ -39,13 +39,17 @@ | ||||
| static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   size_t retcode; | ||||
|   curl_off_t nread; | ||||
|  | ||||
|   /* in real-world cases, this would probably get this data differently | ||||
|      as this fread() stuff is exactly what the library already would do | ||||
|      by default internally */ | ||||
|   retcode = fread(ptr, size, nmemb, stream); | ||||
|  | ||||
|   fprintf(stderr, "*** We read %d bytes from file\n", retcode); | ||||
|   nread = (curl_off_t)retcode; | ||||
|  | ||||
|   fprintf(stderr, "*** We read %" CURL_FORMAT_CURL_OFF_T | ||||
|           " bytes from file\n", nread); | ||||
|  | ||||
|   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 = CURLE_OK; | ||||
|  | ||||
|   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; | ||||
| } | ||||
| @@ -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 | ||||
| @@ -30,7 +30,7 @@ const char data[]="this is what we post to the silly web server"; | ||||
|  | ||||
| struct WriteThis { | ||||
|   const char *readptr; | ||||
|   int sizeleft; | ||||
|   long sizeleft; | ||||
| }; | ||||
|  | ||||
| static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp) | ||||
| @@ -96,7 +96,7 @@ int main(void) | ||||
| #else | ||||
|     /* Set the expected POST size. If you want to POST large amounts of data, | ||||
|        consider CURLOPT_POSTFIELDSIZE_LARGE */ | ||||
|     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (curl_off_t)pooh.sizeleft); | ||||
|     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft); | ||||
| #endif | ||||
|  | ||||
| #ifdef DISABLE_EXPECT | ||||
|   | ||||
| @@ -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[]) | ||||
| { | ||||
|   | ||||
							
								
								
									
										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; | ||||
| } | ||||
| @@ -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 | ||||
| @@ -64,6 +64,7 @@ int main(void) | ||||
|   curl_socket_t sockfd; /* socket */ | ||||
|   long sockextr; | ||||
|   size_t iolen; | ||||
|   curl_off_t nread; | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if(curl) { | ||||
| @@ -122,7 +123,9 @@ int main(void) | ||||
|       if(CURLE_OK != res) | ||||
|         break; | ||||
|  | ||||
|       printf("Received %u bytes.\n", iolen); | ||||
|       nread = (curl_off_t)iolen; | ||||
|  | ||||
|       printf("Received %" CURL_FORMAT_CURL_OFF_T " bytes.\n", nread); | ||||
|     } | ||||
|  | ||||
|     /* 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 - 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 | ||||
| @@ -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. | ||||
|   | ||||
| @@ -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 | ||||
| @@ -91,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 | ||||
| @@ -169,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 | ||||
| @@ -260,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 | ||||
| @@ -275,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 | ||||
| @@ -283,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 | ||||
| @@ -317,7 +322,7 @@ 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 opensocket callback set with | ||||
| 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 | ||||
| @@ -352,6 +357,9 @@ of bytes actually taken care of. If that amount differs from the amount passed | ||||
| to your function, it'll signal an error to the library. This will abort the | ||||
| transfer and return \fICURL_WRITE_ERROR\fP. | ||||
|  | ||||
| A complete HTTP 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, | ||||
| @@ -372,6 +380,9 @@ 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. | ||||
|  | ||||
| For non-HTTP protocols like FTP, POP3, IMAP and SMTP this function will get | ||||
| called with the server responses to the commands that libcurl sends. | ||||
| .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 | ||||
| @@ -411,7 +422,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 | ||||
| @@ -426,7 +437,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 | ||||
| @@ -582,20 +593,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. | ||||
| @@ -628,7 +781,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 | ||||
| @@ -658,16 +811,16 @@ 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 controled with | ||||
| 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 | ||||
| @@ -693,6 +846,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 | ||||
| @@ -756,6 +918,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 | ||||
| @@ -888,8 +1064,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, GnuTLS 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 | ||||
| @@ -917,12 +1107,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) | ||||
| @@ -942,7 +1132,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_ACCEPT_ENCODING | ||||
| Sets the contents of the Accept-Encoding: header sent in an HTTP request, and | ||||
| 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 | ||||
| @@ -970,7 +1160,7 @@ 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 | ||||
| @@ -993,12 +1183,13 @@ Setting the limit to 0 will make libcurl refuse any redirect. Set it to -1 for | ||||
| an infinite number of redirects (which is the default) | ||||
| .IP CURLOPT_POSTREDIR | ||||
| Pass a bitmask to control how libcurl acts on redirects after POSTs that get a | ||||
| 301 or 302 response back.  A parameter with bit 0 set (value | ||||
| 301, 302 or 303 response back.  A parameter with bit 0 set (value | ||||
| \fBCURL_REDIR_POST_301\fP) tells the library to respect RFC 2616/10.3.2 and | ||||
| not convert POST requests into GET requests when following a 301 | ||||
| redirection. Setting bit 1 (value CURL_REDIR_POST_302) makes libcurl maintain | ||||
| the request method after a 302 redirect. CURL_REDIR_POST_ALL is a convenience | ||||
| define that sets both bits. | ||||
| the request method after a 302 redirect. Setting bit 2 (value | ||||
| \fBCURL_REDIR_POST_303) makes libcurl maintain the request method after a 302 | ||||
| redirect. CURL_REDIR_POST_ALL is a convenience define that sets both bits. | ||||
|  | ||||
| The non-RFC behaviour is ubiquitous in web browsers, so the library does the | ||||
| conversion by default to maintain consistency. However, a server may require a | ||||
| @@ -1050,7 +1241,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. | ||||
| @@ -1085,7 +1276,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. | ||||
| @@ -1172,7 +1363,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. | ||||
|  | ||||
| @@ -1257,12 +1448,16 @@ 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 | ||||
| @@ -1271,11 +1466,30 @@ 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 | ||||
| @@ -1313,18 +1527,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 | ||||
| @@ -1338,7 +1556,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 | ||||
| @@ -1451,7 +1669,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 | ||||
| @@ -1493,7 +1711,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 | ||||
| @@ -1516,7 +1734,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. | ||||
| @@ -1524,9 +1742,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 | ||||
| @@ -1588,7 +1806,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 | ||||
| @@ -1625,16 +1843,20 @@ source file to the remote target file. | ||||
| 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 | ||||
| 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. | ||||
| Pass a pointer to a zero terminated string as parameter. It can be used to | ||||
| specify the request instead of GET or HEAD when performing HTTP based | ||||
| requests, instead of LIST and NLST when performing FTP directory listings and | ||||
| instead of LIST and RETR when issuing POP3 based commands. This is | ||||
| particularly useful, for example, for performing a HTTP DELETE request or a | ||||
| POP3 DELE command. | ||||
|  | ||||
| Please don't perform this at will, on HTTP based requests, by making sure | ||||
| your server supports the command you are sending first. | ||||
|   | ||||
| When you change the request method by setting \fBCURLOPT_CUSTOMREQUEST\fP to | ||||
| something, you don't actually change how libcurl behaves or acts in regards to | ||||
| the particular request method, it will only change the actual string sent in | ||||
| the request. | ||||
| something, you don't actually change how libcurl behaves or acts in regards | ||||
| to the particular request method, it will only change the actual string sent | ||||
| in the request. | ||||
|  | ||||
| For example: if you tell libcurl to do a HEAD request, but then change the | ||||
| request to a "GET" with \fBCURLOPT_CUSTOMREQUEST\fP you'll still see libcurl | ||||
| @@ -1646,12 +1868,14 @@ POST, use \fICURLOPT_POST\fP or \fICURLOPT_POSTFIELDS\fP and so on. | ||||
| Restore to the internal default by setting this to NULL. | ||||
|  | ||||
| Many people have wrongly used this option to replace the entire request with | ||||
| their own, including multiple headers and POST contents. While that might work | ||||
| in many cases, it will cause libcurl to send invalid requests and it could | ||||
| possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and | ||||
| their own, including multiple headers and POST contents. While that might | ||||
| work in many cases, it will cause libcurl to send invalid requests and it | ||||
| could possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and | ||||
| \fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to | ||||
| replace or extend the set of headers sent by libcurl. Use | ||||
| \fICURLOPT_HTTP_VERSION\fP to change HTTP version. | ||||
|  | ||||
| (Support for POP3 added in 7.26.0) | ||||
| .IP CURLOPT_FILETIME | ||||
| Pass a long. If it is 1, libcurl will attempt to get the modification date of | ||||
| the remote document in this operation. This requires that the remote server | ||||
| @@ -1660,11 +1884,11 @@ sends the time or replies to a time querying command. The | ||||
| can be used after a transfer to extract the received time (if any). | ||||
| .IP CURLOPT_NOBODY | ||||
| A parameter set to 1 tells the library to not include the body-part in the | ||||
| output. This is only relevant for protocols that have separate header and body | ||||
| parts. On HTTP(S) servers, this will make libcurl do a HEAD request. | ||||
| output. This is only relevant for protocols that have separate header and | ||||
| body parts. On HTTP(S) servers, this will make libcurl do a HEAD request. | ||||
|  | ||||
| To change request to GET, you should use \fICURLOPT_HTTPGET\fP. Change request | ||||
| to POST with \fICURLOPT_POST\fP etc. | ||||
| To change request to GET, you should use \fICURLOPT_HTTPGET\fP. Change | ||||
| request to POST with \fICURLOPT_POST\fP etc. | ||||
| .IP CURLOPT_INFILESIZE | ||||
| When uploading a file to a remote site, this option should be used to tell | ||||
| libcurl what the expected size of the infile is. This value should be passed | ||||
| @@ -1673,6 +1897,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 | ||||
| @@ -1741,6 +1968,8 @@ SIGALRM to enable time-outing system calls. | ||||
|  | ||||
| In unix-like systems, this might cause signals to be used unless | ||||
| \fICURLOPT_NOSIGNAL\fP is set. | ||||
|  | ||||
| Default timeout is 0 (zero) which means it never times out. | ||||
| .IP CURLOPT_TIMEOUT_MS | ||||
| Like \fICURLOPT_TIMEOUT\fP but takes number of milliseconds instead. If | ||||
| libcurl is built to use the standard system name resolver, that portion | ||||
| @@ -1802,9 +2031,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. | ||||
| @@ -1876,6 +2105,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 | ||||
| @@ -1948,7 +2195,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 | ||||
| @@ -2097,6 +2344,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', | ||||
| @@ -2105,12 +2362,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 | ||||
| @@ -2121,6 +2386,9 @@ Pass a char * pointing to a file name for your public key. If not used, | ||||
| 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) | ||||
| If an empty string is passed, libcurl will pass no public key to libssh2 | ||||
| which then tries to compute it from the private key, this is known to work | ||||
| when libssh2 1.4.0+ is linked against OpenSSL. (Added in 7.26.0) | ||||
| .IP CURLOPT_SSH_PRIVATE_KEYFILE | ||||
| Pass a char * pointing to a file name for your private key. If not used, | ||||
| libcurl defaults to \fB$HOME/.ssh/id_dsa\fP if the HOME environment variable | ||||
|   | ||||
| @@ -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. | ||||
|   | ||||
| @@ -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,7 @@ 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 | ||||
| @@ -316,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 | ||||
| @@ -344,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 | ||||
| @@ -375,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 | ||||
| @@ -398,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 | ||||
| @@ -473,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 | ||||
| @@ -545,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 | ||||
| @@ -552,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 | ||||
| @@ -560,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 | ||||
| @@ -633,6 +649,7 @@ CURL_READFUNC_PAUSE             7.18.0 | ||||
| CURL_REDIR_GET_ALL              7.19.1 | ||||
| CURL_REDIR_POST_301             7.19.1 | ||||
| CURL_REDIR_POST_302             7.19.1 | ||||
| CURL_REDIR_POST_303             7.25.1 | ||||
| CURL_REDIR_POST_ALL             7.19.1 | ||||
| CURL_RTSPREQ_ANNOUNCE           7.20.0 | ||||
| CURL_RTSPREQ_DESCRIBE           7.20.0 | ||||
| @@ -675,6 +692,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 | ||||
| ; | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
							
								
								
									
										51
									
								
								docs/mk-ca-bundle.1
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								docs/mk-ca-bundle.1
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| .Dd April 27, 2012 | ||||
| .Dt MK-CA-BUNDLE 1 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm mk-ca-bundle | ||||
| .Nd create a new ca-bundle.crt from mozilla's certdata.txt | ||||
| .Sh SYNOPSIS | ||||
| .Nm | ||||
| .Op Fl bilnqtuv | ||||
| .Or outputfile | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Nm | ||||
| tool downloads the certdata.txt file from Mozilla's source tree, then | ||||
| parses certdata.txt and extracts CA Root Certificates into PEM format. | ||||
| These are then processed with the OpenSSL commandline tool to produce the | ||||
| final ca-bundle.crt file. | ||||
| .Sh OPTIONS | ||||
| The following options are supported by | ||||
| .Nm : | ||||
| .Bl -tag -width _h | ||||
| .It Fl b | ||||
| backup an existing version of ca-bundle.crt | ||||
| .It Fl i | ||||
| print version info about used modules | ||||
| .It Fl l | ||||
| print license info about certdata.txt | ||||
| .It Fl n | ||||
| no download of certdata.txt (to use existing) | ||||
| .It Fl q | ||||
| be really quiet (no progress output at all) | ||||
| .It Fl t | ||||
| include plain text listing of certificates | ||||
| .It Fl u | ||||
| unlink (remove) certdata.txt after processing | ||||
| .It Fl v | ||||
| be verbose and print out processed CAs | ||||
| .El | ||||
| .Sh EXIT STATUS | ||||
| .Ex -std | ||||
| .Sh SEE ALSO | ||||
| .Xr curl 1 | ||||
| .Sh HISTORY | ||||
| .Nm | ||||
| was based on the parse-certs script written by | ||||
| .An Roland Krikava | ||||
| and hacked by | ||||
| .An Guenter Knauf . | ||||
| This manual page was written by | ||||
| .An Jan Schaumann | ||||
| .Aq jschauma@netmeister.org . | ||||
							
								
								
									
										1
									
								
								include/curl/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								include/curl/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,4 @@ | ||||
| curlbuild.h | ||||
| stamp-h2 | ||||
| stamp-h3 | ||||
| curlver.h.dist | ||||
|   | ||||
| @@ -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, | ||||
| @@ -413,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 */ | ||||
| @@ -513,13 +514,16 @@ typedef enum { | ||||
|   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! */ | ||||
|  | ||||
| /* 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 | ||||
|  | ||||
| @@ -594,16 +598,31 @@ typedef enum { | ||||
|                                    in 7.18.0 */ | ||||
| } curl_proxytype;  /* this enum was added in 7.10 */ | ||||
|  | ||||
| #define CURLAUTH_NONE         0       /* nothing */ | ||||
| #define CURLAUTH_BASIC        (1<<0)  /* Basic (default) */ | ||||
| #define CURLAUTH_DIGEST       (1<<1)  /* Digest */ | ||||
| #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_ONLY         (1<<31) /* used together with a single other | ||||
|                                          type to force no auth or just that | ||||
|                                          single type */ | ||||
| #define CURLAUTH_ANY (~CURLAUTH_DIGEST_IE)  /* all fine types set */ | ||||
| /* | ||||
|  * Bitmasks for CURLOPT_HTTPAUTH and CURLOPT_PROXYAUTH options: | ||||
|  * | ||||
|  * CURLAUTH_NONE         - No HTTP authentication | ||||
|  * CURLAUTH_BASIC        - HTTP Basic authentication (default) | ||||
|  * CURLAUTH_DIGEST       - HTTP Digest authentication | ||||
|  * CURLAUTH_GSSNEGOTIATE - HTTP GSS-Negotiate authentication | ||||
|  * CURLAUTH_NTLM         - HTTP NTLM authentication | ||||
|  * CURLAUTH_DIGEST_IE    - HTTP Digest authentication with IE flavour | ||||
|  * CURLAUTH_NTLM_WB      - HTTP NTLM authentication delegated to winbind helper | ||||
|  * CURLAUTH_ONLY         - Use together with a single other type to force no | ||||
|  *                         authentication or just that single type | ||||
|  * CURLAUTH_ANY          - All fine types set | ||||
|  * CURLAUTH_ANYSAFE      - All fine types except Basic | ||||
|  */ | ||||
|  | ||||
| #define CURLAUTH_NONE         ((unsigned long)0) | ||||
| #define CURLAUTH_BASIC        (((unsigned long)1)<<0) | ||||
| #define CURLAUTH_DIGEST       (((unsigned long)1)<<1) | ||||
| #define CURLAUTH_GSSNEGOTIATE (((unsigned long)1)<<2) | ||||
| #define CURLAUTH_NTLM         (((unsigned long)1)<<3) | ||||
| #define CURLAUTH_DIGEST_IE    (((unsigned long)1)<<4) | ||||
| #define CURLAUTH_NTLM_WB      (((unsigned long)1)<<5) | ||||
| #define CURLAUTH_ONLY         (((unsigned long)1)<<31) | ||||
| #define CURLAUTH_ANY          (~CURLAUTH_DIGEST_IE) | ||||
| #define CURLAUTH_ANYSAFE      (~(CURLAUTH_BASIC|CURLAUTH_DIGEST_IE)) | ||||
|  | ||||
| #define CURLSSH_AUTH_ANY       ~0     /* all types supported by the server */ | ||||
| @@ -614,6 +633,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 { | ||||
| @@ -664,6 +687,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! */ | ||||
|  | ||||
| @@ -916,9 +948,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 */ | ||||
| @@ -994,8 +1024,7 @@ typedef enum { | ||||
|   /* Max amount of cached alive connections */ | ||||
|   CINIT(MAXCONNECTS, LONG, 71), | ||||
|  | ||||
|   /* 72 - DEPRECATED */ | ||||
|   CINIT(CLOSEPOLICY, LONG, 72), | ||||
|   CINIT(CLOSEPOLICY, LONG, 72), /* DEPRECATED, do not use! */ | ||||
|  | ||||
|   /* 73 = OBSOLETE */ | ||||
|  | ||||
| @@ -1069,7 +1098,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), | ||||
| @@ -1483,6 +1512,29 @@ typedef enum { | ||||
|   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; | ||||
|  | ||||
| @@ -1586,13 +1638,16 @@ enum CURL_TLSAUTH { | ||||
| }; | ||||
|  | ||||
| /* symbols to use with CURLOPT_POSTREDIR. | ||||
|    CURL_REDIR_POST_301 and CURL_REDIR_POST_302 can be bitwise ORed so that | ||||
|    CURL_REDIR_POST_301 | CURL_REDIR_POST_302 == CURL_REDIR_POST_ALL */ | ||||
|    CURL_REDIR_POST_301, CURL_REDIR_POST_302 and CURL_REDIR_POST_303 | ||||
|    can be bitwise ORed so that CURL_REDIR_POST_301 | CURL_REDIR_POST_302 | ||||
|    | CURL_REDIR_POST_303 == CURL_REDIR_POST_ALL */ | ||||
|  | ||||
| #define CURL_REDIR_GET_ALL  0 | ||||
| #define CURL_REDIR_POST_301 1 | ||||
| #define CURL_REDIR_POST_302 2 | ||||
| #define CURL_REDIR_POST_ALL (CURL_REDIR_POST_301|CURL_REDIR_POST_302) | ||||
| #define CURL_REDIR_POST_303 4 | ||||
| #define CURL_REDIR_POST_ALL \ | ||||
|     (CURL_REDIR_POST_301|CURL_REDIR_POST_302|CURL_REDIR_POST_303) | ||||
|  | ||||
| typedef enum { | ||||
|   CURL_TIMECOND_NONE, | ||||
| @@ -2011,7 +2066,8 @@ typedef enum { | ||||
|   CURLSHE_BAD_OPTION, /* 1 */ | ||||
|   CURLSHE_IN_USE,     /* 2 */ | ||||
|   CURLSHE_INVALID,    /* 3 */ | ||||
|   CURLSHE_NOMEM,      /* out of memory */ | ||||
|   CURLSHE_NOMEM,      /* 4 out of memory */ | ||||
|   CURLSHE_NOT_BUILT_IN, /* 5 feature not present in lib */ | ||||
|   CURLSHE_LAST        /* never use */ | ||||
| } CURLSHcode; | ||||
|  | ||||
| @@ -2092,6 +2148,7 @@ 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() | ||||
|   | ||||
| @@ -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.7-DEV" | ||||
| #define LIBCURL_VERSION "7.26.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 7 | ||||
| #define LIBCURL_VERSION_MINOR 26 | ||||
| #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 0x071507 | ||||
| #define LIBCURL_VERSION_NUM 0x071A00 | ||||
|  | ||||
| /* | ||||
|  * This is the date and time when the full source package was created. The | ||||
|   | ||||
| @@ -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 | ||||
| @@ -141,8 +141,9 @@ __extension__ ({                                                              \ | ||||
|  | ||||
| /* To define a new warning, use _CURL_WARNING(identifier, "message") */ | ||||
| #define _CURL_WARNING(id, message)                                            \ | ||||
|   static void __attribute__((warning(message))) __attribute__((unused))       \ | ||||
|   __attribute__((noinline)) id(void) { __asm__(""); } | ||||
|   static void __attribute__((__warning__(message)))                           \ | ||||
|   __attribute__((__unused__)) __attribute__((__noinline__))                   \ | ||||
|   id(void) { __asm__(""); } | ||||
|  | ||||
| _CURL_WARNING(_curl_easy_setopt_err_long, | ||||
|   "curl_easy_setopt expects a long argument for this option") | ||||
| @@ -392,7 +393,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* */ | ||||
| @@ -521,7 +523,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 *, | ||||
| @@ -530,6 +536,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... */ | ||||
|   | ||||
							
								
								
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -10,3 +10,4 @@ libcurl.plist.dist | ||||
| libcurl.vcproj | ||||
| vc6libcurl.dsp | ||||
| Makefile.vc10.dist | ||||
| libcurl.vers | ||||
|   | ||||
| @@ -83,13 +83,13 @@ CFLAGS += -dWANT_IDN_PROTOTYPES | ||||
| !ifdef %zlib_root | ||||
| ZLIB_ROOT = $(%zlib_root) | ||||
| !else | ||||
| ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.5 | ||||
| ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.7 | ||||
| !endif | ||||
|  | ||||
| !ifdef %libssh2_root | ||||
| LIBSSH2_ROOT = $(%libssh2_root) | ||||
| !else | ||||
| LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.2.8 | ||||
| LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.4.2 | ||||
| !endif | ||||
|  | ||||
| !ifdef %librtmp_root | ||||
| @@ -101,7 +101,7 @@ LIBRTMP_ROOT = ..$(DS)..$(DS)rtmpdump-2.3 | ||||
| !ifdef %openssl_root | ||||
| OPENSSL_ROOT = $(%openssl_root) | ||||
| !else | ||||
| OPENSSL_ROOT = ..$(DS)..$(DS)openssl-0.9.8r | ||||
| OPENSSL_ROOT = ..$(DS)..$(DS)openssl-0.9.8x | ||||
| !endif | ||||
|  | ||||
| !ifdef %ares_root | ||||
|   | ||||
| @@ -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 | ||||
| @@ -33,7 +33,7 @@ CMAKE_DIST = CMakeLists.txt curl_config.h.cmake | ||||
| EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 $(DSP)                 \ | ||||
|  vc6libcurl.dsw config-win32.h config-win32ce.h config-riscos.h            \ | ||||
|  config-mac.h curl_config.h.in makefile.dj config-dos.h libcurl.plist      \ | ||||
|  libcurl.rc config-amigaos.h amigaos.c amigaos.h makefile.amiga		   \ | ||||
|  libcurl.rc config-amigaos.h makefile.amiga                                \ | ||||
|  Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot   \ | ||||
|  config-win32ce.h config-os400.h setup-os400.h config-symbian.h		   \ | ||||
|  Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl		   \ | ||||
| @@ -48,6 +48,8 @@ LIBCURL_LIBS = @LIBCURL_LIBS@ | ||||
| # This might hold -Werror | ||||
| CFLAGS += @CURL_CFLAG_EXTRAS@ | ||||
|  | ||||
| CFLAG_CURL_SYMBOL_HIDING = @CFLAG_CURL_SYMBOL_HIDING@ | ||||
|  | ||||
| # 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 | ||||
| # being currently built and tested are searched before the library which | ||||
| @@ -77,6 +79,18 @@ INCLUDES = -I$(top_builddir)/include/curl \ | ||||
|            -I$(top_srcdir)/lib | ||||
| endif | ||||
|  | ||||
| AM_CPPFLAGS = | ||||
|  | ||||
| # Mostly for Windows build targets, when building libcurl library | ||||
| if USE_CPPFLAG_BUILDING_LIBCURL | ||||
| AM_CPPFLAGS += -DBUILDING_LIBCURL | ||||
| endif | ||||
|  | ||||
| # Mostly for Windows build targets, when building static libcurl | ||||
| if USE_CPPFLAG_CURL_STATICLIB | ||||
| AM_CPPFLAGS += -DCURL_STATICLIB | ||||
| endif | ||||
|  | ||||
| if SONAME_BUMP | ||||
| # | ||||
| # Bumping of SONAME conditionally may seem like a weird thing to do, and yeah | ||||
| @@ -116,7 +130,19 @@ if MIMPURE | ||||
| MIMPURE = -mimpure-text | ||||
| endif | ||||
|  | ||||
| libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(LIBCURL_LIBS) | ||||
| if VERSIONED_SYMBOLS | ||||
| VERSIONED_SYMBOLS = -Wl,--version-script=libcurl.vers | ||||
| endif | ||||
|  | ||||
| libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(VERSIONED_SYMBOLS) $(LIBCURL_LIBS) | ||||
|  | ||||
| if DOING_CURL_SYMBOL_HIDING | ||||
| libcurl_la_CPPFLAGS = $(AM_CPPFLAGS) -DCURL_HIDDEN_SYMBOLS | ||||
| libcurl_la_CFLAGS = $(AM_CFLAGS) $(CFLAG_CURL_SYMBOL_HIDING) | ||||
| else | ||||
| libcurl_la_CPPFLAGS = $(AM_CPPFLAGS) | ||||
| libcurl_la_CFLAGS = $(AM_CFLAGS) | ||||
| endif | ||||
|  | ||||
| # unit testing static library built only along with unit tests | ||||
| if BUILD_UNITTESTS | ||||
| @@ -127,6 +153,7 @@ endif | ||||
|  | ||||
| libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS | ||||
| libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS) | ||||
| libcurlu_la_CFLAGS = $(AM_CFLAGS) | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|   | ||||
| @@ -22,12 +22,12 @@ BCCDIR = $(MAKEDIR)\.. | ||||
|  | ||||
| # Edit the path below to point to the base of your Zlib sources. | ||||
| !ifndef ZLIB_PATH | ||||
| ZLIB_PATH = ..\..\zlib-1.2.5 | ||||
| ZLIB_PATH = ..\..\zlib-1.2.7 | ||||
| !endif | ||||
|  | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| !ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ..\..\openssl-0.9.8q | ||||
| OPENSSL_PATH = ..\..\openssl-0.9.8x | ||||
| !endif | ||||
|  | ||||
| # Set libcurl static lib, dll and import lib | ||||
|   | ||||
| @@ -14,7 +14,7 @@ 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	\ | ||||
|   http_negotiate.c inet_pton.c strtoofft.c strerror.c amigaos.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		\ | ||||
| @@ -22,7 +22,8 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.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 | ||||
|   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	\ | ||||
| @@ -30,11 +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 amigaos.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 non-ascii.h asyn.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 | ||||
|   | ||||
| @@ -1,30 +1,37 @@ | ||||
| ######################################################################### | ||||
| ########################################################################### | ||||
| # | ||||
| ## 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), librtmp (2.3) | ||||
| ## 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 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_PATH=c:/zlib-1.2.7 | ||||
| ## 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 | ||||
| ZLIB_PATH = ../../zlib-1.2.5 | ||||
| ZLIB_PATH = ../../zlib-1.2.7 | ||||
| endif | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../openssl-0.9.8r | ||||
| OPENSSL_PATH = ../../openssl-0.9.8x | ||||
| 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.8 | ||||
| LIBSSH2_PATH = ../../libssh2-1.4.2 | ||||
| endif | ||||
| # Edit the path below to point to the base of your librtmp package. | ||||
| ifndef LIBRTMP_PATH | ||||
| @@ -34,7 +41,7 @@ endif | ||||
| ifndef LIBIDN_PATH | ||||
| LIBIDN_PATH = ../../libidn-1.18 | ||||
| endif | ||||
| # Edit the path below to point to the base of your MS idndlpackage.  | ||||
| # 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 | ||||
| @@ -45,22 +52,35 @@ 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 | ||||
| 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! | ||||
|  | ||||
| @@ -95,6 +115,9 @@ 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 | ||||
| @@ -104,10 +127,11 @@ endif | ||||
|  | ||||
| INCLUDES = -I. -I../include | ||||
| 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 | ||||
| @@ -118,37 +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 | ||||
|   INCLUDES += -I"$(WINIDN_PATH)/include" | ||||
|   CFLAGS += -DHAVE_NORMALIZATION_H | ||||
|   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 | ||||
| @@ -169,7 +195,6 @@ DLL_LIBS += -lwldap32 | ||||
| endif | ||||
| endif | ||||
| DLL_LIBS += -lws2_32 | ||||
| COMPILE = $(CC) $(INCLUDES) $(CFLAGS) | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
| @@ -183,7 +208,6 @@ libcurl_a_DEPENDENCIES := $(strip $(CSOURCES) $(HHEADERS)) | ||||
|  | ||||
| RESOURCE = libcurl.res | ||||
|  | ||||
| .SUFFIXES: .rc .res | ||||
|  | ||||
| all: $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) | ||||
|  | ||||
| @@ -200,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 /,\,$@) | ||||
|  | ||||
|   | ||||
| @@ -14,17 +14,17 @@ endif | ||||
|  | ||||
| # Edit the path below to point to the base of your Zlib sources. | ||||
| ifndef ZLIB_PATH | ||||
| ZLIB_PATH = ../../zlib-1.2.5 | ||||
| ZLIB_PATH = ../../zlib-1.2.7 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../openssl-0.9.8r | ||||
| OPENSSL_PATH = ../../openssl-0.9.8x | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your LibSSH2 package. | ||||
| ifndef LIBSSH2_PATH | ||||
| LIBSSH2_PATH = ../../libssh2-1.2.8 | ||||
| LIBSSH2_PATH = ../../libssh2-1.4.2 | ||||
| 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,15 +64,16 @@ | ||||
|  | ||||
| !INCLUDE ..\Makefile.msvc.names | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| !IFNDEF OPENSSL_PATH | ||||
| OPENSSL_PATH   = ../../openssl-0.9.8r | ||||
| OPENSSL_PATH   = ../../openssl-0.9.8x | ||||
| !ENDIF | ||||
|  | ||||
| !IFNDEF LIBSSH2_PATH | ||||
| LIBSSH2_PATH   = ../../libssh2-1.4.2 | ||||
| !ENDIF | ||||
|  | ||||
| !IFNDEF ZLIB_PATH | ||||
| ZLIB_PATH  = ../../zlib-1.2.5 | ||||
| ZLIB_PATH  = ../../zlib-1.2.7 | ||||
| !ENDIF | ||||
|  | ||||
| !IFNDEF MACHINE | ||||
| @@ -100,6 +106,7 @@ 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 /D_BIND_TO_CURRENT_VCLIBS_VERSION=1 | ||||
| CFLAGSLIB  = /DCURL_STATICLIB | ||||
| @@ -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 | ||||
| @@ -467,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 \ | ||||
| @@ -494,7 +537,6 @@ X_OBJS= \ | ||||
| 	$(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 \ | ||||
|   | ||||
| @@ -33,10 +33,10 @@ BUILD_TYPE := debug | ||||
| USER_CFLAGS:= | ||||
|  | ||||
| # directories where to seek for includes and libraries | ||||
| OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3/include | ||||
| OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3 | ||||
| ZLIB_INC    := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/zlib-1.2.3 | ||||
| ZLIB_LIB    := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib | ||||
| OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8x-vxWorks6.3/include | ||||
| OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8x-vxWorks6.3 | ||||
| ZLIB_INC    := D:/libraries/zlib/zlib-1.2.7-VxWorks6.3/zlib-1.2.7 | ||||
| ZLIB_LIB    := D:/libraries/zlib/zlib-1.2.7-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib | ||||
| ARES_INC    := | ||||
| ARES_LIB    := | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2009, 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 | ||||
| @@ -20,10 +20,13 @@ | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #ifdef __AMIGA__ /* Any AmigaOS flavour */ | ||||
| #include "setup.h" | ||||
|  | ||||
| #if defined(__AMIGA__) && !defined(__ixemul__) | ||||
|  | ||||
| #include <amitcp/socketbasetags.h> | ||||
|  | ||||
| #include "amigaos.h" | ||||
| #include <amitcp/socketbasetags.h> | ||||
|  | ||||
| struct Library *SocketBase = NULL; | ||||
| extern int errno, h_errno; | ||||
| @@ -35,7 +38,7 @@ void __request(const char *msg); | ||||
| # define __request( msg )       Printf( msg "\n\a") | ||||
| #endif | ||||
|  | ||||
| void amiga_cleanup() | ||||
| void Curl_amiga_cleanup() | ||||
| { | ||||
|   if(SocketBase) { | ||||
|     CloseLibrary(SocketBase); | ||||
| @@ -43,7 +46,7 @@ void amiga_cleanup() | ||||
|   } | ||||
| } | ||||
|  | ||||
| BOOL amiga_init() | ||||
| bool Curl_amiga_init() | ||||
| { | ||||
|   if(!SocketBase) | ||||
|     SocketBase = OpenLibrary("bsdsocket.library", 4); | ||||
| @@ -61,20 +64,14 @@ BOOL amiga_init() | ||||
|   } | ||||
|  | ||||
| #ifndef __libnix__ | ||||
|   atexit(amiga_cleanup); | ||||
|   atexit(Curl_amiga_cleanup); | ||||
| #endif | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| #ifdef __libnix__ | ||||
| ADD2EXIT(amiga_cleanup,-50); | ||||
| ADD2EXIT(Curl_amiga_cleanup,-50); | ||||
| #endif | ||||
|  | ||||
| #else /* __AMIGA__ */ | ||||
|  | ||||
| #ifdef __POCC__ | ||||
| #  pragma warn(disable:2024)  /* Disable warning #2024: Empty input file */ | ||||
| #endif | ||||
|  | ||||
| #endif /* __AMIGA__ */ | ||||
| #endif /* __AMIGA__ && ! __ixemul__ */ | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #ifndef LIBCURL_AMIGAOS_H | ||||
| #define LIBCURL_AMIGAOS_H | ||||
| #ifndef HEADER_CURL_AMIGAOS_H | ||||
| #define HEADER_CURL_AMIGAOS_H | ||||
| /*************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2007, 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 | ||||
| @@ -21,37 +21,19 @@ | ||||
|  * KIND, either express or implied. | ||||
|  * | ||||
|  ***************************************************************************/ | ||||
| #include "setup.h" | ||||
|  | ||||
| #ifdef __AMIGA__ /* Any AmigaOS flavour */ | ||||
| #if defined(__AMIGA__) && !defined(__ixemul__) | ||||
|  | ||||
| #ifndef __ixemul__ | ||||
| bool Curl_amiga_init(); | ||||
| void Curl_amiga_cleanup(); | ||||
|  | ||||
| #include <exec/types.h> | ||||
| #include <exec/execbase.h> | ||||
| #else | ||||
|  | ||||
| #include <proto/exec.h> | ||||
| #include <proto/dos.h> | ||||
| #define Curl_amiga_init() 1 | ||||
| #define Curl_amiga_cleanup() Curl_nop_stmt | ||||
|  | ||||
| #include <sys/socket.h> | ||||
|  | ||||
| #include "config-amigaos.h" | ||||
|  | ||||
| #ifndef select | ||||
| # define select(args...) WaitSelect( args, NULL) | ||||
| #endif | ||||
| #ifndef ioctl | ||||
| # define ioctl(a,b,c,d)  IoctlSocket( (LONG)a, (ULONG)b, (char*)c) | ||||
| #endif | ||||
| #define _AMIGASF        1 | ||||
|  | ||||
| extern void amiga_cleanup(); | ||||
| extern BOOL amiga_init(); | ||||
|  | ||||
| #else /* __ixemul__ */ | ||||
|  | ||||
| #warning compiling with ixemul... | ||||
|  | ||||
| #endif /* __ixemul__ */ | ||||
| #endif /* __AMIGA__ */ | ||||
| #endif /* LIBCURL_AMIGAOS_H */ | ||||
| #endif /* HEADER_CURL_AMIGAOS_H */ | ||||
|  | ||||
|   | ||||
| @@ -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_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 | ||||
| @@ -233,18 +227,19 @@ int Curl_resolver_getsock(struct connectdata *conn, | ||||
|   struct timeval maxtime; | ||||
|   struct timeval timebuf; | ||||
|   struct timeval *timeout; | ||||
|   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((ares_channel)conn->data->state.resolver, &maxtime, | ||||
|                          &timebuf); | ||||
|  | ||||
|   Curl_expire(conn->data, | ||||
|               (timeout->tv_sec * 1000) + (timeout->tv_usec/1000)); | ||||
|   milli = (timeout->tv_sec * 1000) + (timeout->tv_usec/1000); | ||||
|   if(milli == 0) | ||||
|     milli += 10; | ||||
|   Curl_expire(conn->data, milli); | ||||
|  | ||||
|   return max; | ||||
| } | ||||
| @@ -336,9 +331,12 @@ CURLcode Curl_resolver_is_resolved(struct connectdata *conn, | ||||
|     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; | ||||
|   } | ||||
| @@ -424,7 +422,7 @@ CURLcode Curl_resolver_wait_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; | ||||
|       } | ||||
| @@ -434,7 +432,7 @@ CURLcode Curl_resolver_wait_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; | ||||
| @@ -584,6 +582,7 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|     res->last_status = ARES_ENOTFOUND; | ||||
| #ifdef ENABLE_IPV6 /* CURLRES_IPV6 */ | ||||
|     if(family == PF_UNSPEC) { | ||||
|       if(Curl_ipv6works()) { | ||||
|         res->num_pending = 2; | ||||
|  | ||||
|         /* areschannel is already setup in the Curl_open() function */ | ||||
| @@ -592,6 +591,14 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *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 */ | ||||
|     { | ||||
| @@ -606,4 +613,31 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|   } | ||||
|   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) | ||||
| @@ -182,7 +175,6 @@ 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; | ||||
| @@ -336,9 +328,6 @@ static void destroy_async_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) | ||||
|       Curl_thread_join(&td->thread_hnd); | ||||
|  | ||||
| @@ -371,7 +360,6 @@ 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)) | ||||
| @@ -382,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_resolver_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 | ||||
| @@ -581,17 +559,9 @@ 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; | ||||
| } | ||||
|  | ||||
| @@ -633,14 +603,28 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|                                          int *waitp) | ||||
| { | ||||
|   struct addrinfo hints; | ||||
|   struct in_addr in; | ||||
|   Curl_addrinfo *res; | ||||
|   int error; | ||||
|   char sbuf[NI_MAXSERV]; | ||||
|   int pf = PF_INET; | ||||
| #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. | ||||
|    */ | ||||
| @@ -660,7 +644,7 @@ Curl_addrinfo *Curl_resolver_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; | ||||
| @@ -689,4 +673,13 @@ Curl_addrinfo *Curl_resolver_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 */ | ||||
|   | ||||
| @@ -146,15 +146,15 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | ||||
|  | ||||
| #ifndef CURLRES_ASYNCH | ||||
| /* convert these functions if an asynch resolver isn't used */ | ||||
| #define Curl_resolver_cancel(x) | ||||
| #define Curl_resolver_cancel(x) Curl_nop_stmt | ||||
| #define Curl_resolver_is_resolved(x,y) CURLE_COULDNT_RESOLVE_HOST | ||||
| #define Curl_resolver_wait_resolv(x,y) CURLE_COULDNT_RESOLVE_HOST | ||||
| #define Curl_resolver_getsock(x,y,z) 0 | ||||
| #define Curl_resolver_duphandle(x,y) CURLE_OK | ||||
| #define Curl_resolver_init(x) CURLE_OK | ||||
| #define Curl_resolver_global_init() CURLE_OK | ||||
| #define Curl_resolver_global_cleanup() | ||||
| #define Curl_resolver_cleanup(x) | ||||
| #define Curl_resolver_global_cleanup() Curl_nop_stmt | ||||
| #define Curl_resolver_cleanup(x) Curl_nop_stmt | ||||
| #endif | ||||
|  | ||||
| #ifdef CURLRES_ASYNCH | ||||
|   | ||||
| @@ -27,13 +27,11 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
|  | ||||
| #ifdef USE_AXTLS | ||||
| #include <axTLS/ssl.h> | ||||
| #include "axtls.h" | ||||
|  | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include <ctype.h> | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user