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 | Makefile.in | ||||||
| aclocal.m4 | aclocal.m4 | ||||||
| autom4te.cache | autom4te.cache | ||||||
|  | config.cache | ||||||
| config.guess | config.guess | ||||||
| config.log | config.log | ||||||
| config.status | config.status | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| # | # | ||||||
| # Place the curl source (including this makefile) into external/curl/ in the | # 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' | # 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 | # 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 | # 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). | # into the right place (but see the note about this below). | ||||||
| # | # | ||||||
| # Dan Fandrich | # Dan Fandrich | ||||||
| # August 2010 | # November 2011 | ||||||
|  |  | ||||||
| LOCAL_PATH:= $(call my-dir) | 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(${PROJECT_BINARY_DIR}/include/curl) | ||||||
| include_directories( ${CURL_SOURCE_DIR}/include ) | 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_EXE "Set to ON to build cURL executable." ON) | ||||||
| option(BUILD_CURL_TESTS "Set to ON to build cURL tests." 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) | 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) | option(CURL_DISABLE_LDAPS "to disable LDAPS" OFF) | ||||||
| mark_as_advanced(CURL_DISABLE_LDAPS) | 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) | if(HTTP_ONLY) | ||||||
|   set(CURL_DISABLE_FTP ON) |   set(CURL_DISABLE_FTP ON) | ||||||
|   set(CURL_DISABLE_LDAP ON) |   set(CURL_DISABLE_LDAP ON) | ||||||
|  |   set(CURL_DISABLE_LDAPS ON) | ||||||
|   set(CURL_DISABLE_TELNET ON) |   set(CURL_DISABLE_TELNET ON) | ||||||
|   set(CURL_DISABLE_DICT ON) |   set(CURL_DISABLE_DICT ON) | ||||||
|   set(CURL_DISABLE_FILE 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) | mark_as_advanced(ENABLE_IPV6) | ||||||
|  |  | ||||||
| if(WIN32) | 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 |   list_spaces_append_once(CMAKE_C_STANDARD_LIBRARIES wsock32.lib ws2_32.lib)  # bufferoverflowu.lib | ||||||
|   if(CURL_DISABLE_LDAP) |   if(CURL_DISABLE_LDAP) | ||||||
|     # Remove wldap32.lib from space-separated list |     # 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_concat("winmm"  getch        HAVE_LIBWINMM) | ||||||
| check_library_exists("wldap32" cldap_open "" HAVE_WLDAP32) | 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) | # IF(NOT CURL_SPECIAL_LIBZ) | ||||||
| #  CHECK_LIBRARY_EXISTS_CONCAT("z"      inflateEnd   HAVE_LIBZ) | #  CHECK_LIBRARY_EXISTS_CONCAT("z"      inflateEnd   HAVE_LIBZ) | ||||||
| # ENDIF(NOT CURL_SPECIAL_LIBZ) | # ENDIF(NOT CURL_SPECIAL_LIBZ) | ||||||
| @@ -385,6 +386,13 @@ if(NOT HAVE_LDAP_H) | |||||||
|   set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) |   set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE) | ||||||
| endif() | 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(size_t  SIZEOF_SIZE_T) | ||||||
| check_type_size(ssize_t  SIZEOF_SSIZE_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_CURL_OFF_TU "lu") | ||||||
|   set(CURL_FORMAT_OFF_T "%ld") |   set(CURL_FORMAT_OFF_T "%ld") | ||||||
|   set(CURL_SUFFIX_CURL_OFF_T L) |   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) | endif(SIZEOF_LONG EQUAL 8) | ||||||
|  |  | ||||||
| if(SIZEOF_LONG_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_CURL_OFF_TU "llu") | ||||||
|   set(CURL_FORMAT_OFF_T "%lld") |   set(CURL_FORMAT_OFF_T "%lld") | ||||||
|   set(CURL_SUFFIX_CURL_OFF_T LL) |   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) | endif(SIZEOF_LONG_LONG EQUAL 8) | ||||||
|  |  | ||||||
| if(NOT CURL_TYPEOF_CURL_OFF_T) | if(NOT CURL_TYPEOF_CURL_OFF_T) | ||||||
| @@ -861,4 +869,3 @@ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/curl" | |||||||
|     DESTINATION include |     DESTINATION include | ||||||
|     FILES_MATCHING PATTERN "*.h" |     FILES_MATCHING PATTERN "*.h" | ||||||
|     PATTERN "curlbuild.h" EXCLUDE) |     PATTERN "curlbuild.h" EXCLUDE) | ||||||
|   |  | ||||||
							
								
								
									
										2
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								COPYING
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| COPYRIGHT AND PERMISSION NOTICE | 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. | All rights reserved. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ winbuild/MakefileBuild.vc winbuild/Makefile.vc | |||||||
| EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | ||||||
|  curl-style.el sample.emacs RELEASE-NOTES buildconf 	\ |  curl-style.el sample.emacs RELEASE-NOTES buildconf 	\ | ||||||
|  libcurl.pc.in vc6curl.dsw MacOSX-Framework Android.mk $(CMAKE_DIST)	\ |  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 | bin_SCRIPTS = curl-config | ||||||
|  |  | ||||||
|   | |||||||
| @@ -73,10 +73,15 @@ mingw32: | |||||||
| mingw32-clean: | mingw32-clean: | ||||||
| 	$(MAKE) -C lib -f Makefile.m32 clean | 	$(MAKE) -C lib -f Makefile.m32 clean | ||||||
| 	$(MAKE) -C src -f Makefile.m32 clean | 	$(MAKE) -C src -f Makefile.m32 clean | ||||||
|  | 	$(MAKE) -C docs/examples -f Makefile.m32 clean | ||||||
|  |  | ||||||
| mingw32-vclean mingw32-distclean: | mingw32-vclean mingw32-distclean: | ||||||
| 	$(MAKE) -C lib -f Makefile.m32 vclean | 	$(MAKE) -C lib -f Makefile.m32 vclean | ||||||
| 	$(MAKE) -C src -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%: | mingw32%: | ||||||
| 	$(MAKE) -C lib -f Makefile.m32 CFG=$@ | 	$(MAKE) -C lib -f Makefile.m32 CFG=$@ | ||||||
| @@ -217,34 +222,27 @@ netware: | |||||||
| 	$(MAKE) -C lib -f Makefile.netware | 	$(MAKE) -C lib -f Makefile.netware | ||||||
| 	$(MAKE) -C src -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: | netware-clean: | ||||||
| 	$(MAKE) -C lib -f Makefile.netware clean | 	$(MAKE) -C lib -f Makefile.netware clean | ||||||
| 	$(MAKE) -C src -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: | netware-install: | ||||||
| 	$(MAKE) -C lib -f Makefile.netware install | 	$(MAKE) -C lib -f Makefile.netware install | ||||||
| 	$(MAKE) -C src -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: all | ||||||
|  |  | ||||||
| unix-ssl: ssl | unix-ssl: ssl | ||||||
|   | |||||||
| @@ -1,38 +1,54 @@ | |||||||
| Curl and libcurl 7.21.7 | Curl and libcurl 7.26.0 | ||||||
|  |  | ||||||
|  Public curl releases:         123 |  Public curl releases:         127 | ||||||
|  Command line options:         144 |  Command line options:         151 | ||||||
|  curl_easy_setopt() options:   186 |  curl_easy_setopt() options:   199 | ||||||
|  Public functions in libcurl:  58 |  Public functions in libcurl:  58 | ||||||
|  Known libcurl bindings:       39 |  Known libcurl bindings:       39 | ||||||
|  Contributors:                 868 |  Contributors:                 929 | ||||||
|  |  | ||||||
| This release includes the following changes: | This release includes the following changes: | ||||||
|  |  | ||||||
|  o recognize the [protocol]:// prefix in proxy hosts where the protocol is one |  o nss: the minimal supported version of NSS bumped to 3.12.x | ||||||
|    of socks4, socks4a, socks5 or socks5h. |  o nss: human-readable names are now provided for NSS errors if available | ||||||
|  o Added CURLOPT_CLOSESOCKETFUNCTION and CURLOPT_CLOSESOCKETDATA |  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: | This release includes the following bugfixes: | ||||||
|  |  | ||||||
|  o SECURITY ADVISORY: inappropriate GSSAPI delegation. Full details at |  o nss: libcurl now uses NSS_InitContext() to prevent collisions if available | ||||||
|    http://curl.haxx.se/docs/adv_20110623.html |    [1] | ||||||
|  o NTLM: work with unicode |  o URL parse: reject numerical IPv6 addresses outside brackets [4] | ||||||
|  o fix connect with SOCKS proxy when using the multi interface |  o MD5: fix OOM memory leak [5] | ||||||
|  o anyauthput.c: stdint.h must not be included unconditionally |  o OpenSSL cert: provide more details when cert check fails | ||||||
|  o CMake: improved build |  o HTTP: empty chunked POST ended up in two zero size chunks [6] | ||||||
|  o SCP/SFTP enable non-blocking earlier |  o fixed a regression when curl resolved to multiple addresses and the first | ||||||
|  o GnuTLS handshake: fix timeout |    isn't supported [7] | ||||||
|  o cyassl: build without filesystem |  o -# progress meter: avoid superfluous updates and duplicate lines [8] | ||||||
|  o HTTPS over HTTP proxy using the multi interface |  o headers: surround GCC attribute names with double underscores [9] | ||||||
|  o speedcheck: invalid timeout event on a reused handle |  o PolarSSL: correct return code for CRL matches | ||||||
|  o Force connection close for HTTP 200 OK when time condition matched |  o PolarSSL: include version number in version string | ||||||
|  o curl_formget: fix FILE * leak |  o PolarSSL: add support for asynchronous connect | ||||||
|  o configure: improved OpenSSL detection |  o mk-ca-bundle: revert the LWP usage [12] | ||||||
|  o Android build: support gingerbread |  o IPv6 cookie domain: get rid of the first bracket before the second | ||||||
|  o CURLFORM_STREAM: acknowledge CURLFORM_FILENAME |  o connect.c: return changed to CURLE_COULDNT_CONNECT when opensocket fails | ||||||
|  o windows build: use correct MS CRT |  o OpenSSL: Made cert hostname check conform to RFC 6125 [10] | ||||||
|  o pop3: remove extra space in LIST command |  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: | 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 | This release would not have looked like this without help, code, reports and | ||||||
| advice from friends like these: | advice from friends like these: | ||||||
|  |  | ||||||
|  Dan Fandrich, Guenter Knauf, Vsevolod Novikov, Zmey Petroff, |  Andrei Cipu, Armel Asselin, Benjamin Johnson, Dag Ekengren, Dave Reisner, | ||||||
|  Dagobert Michelsen, Jeff Pohlmeyer, Dmitri Shubin, Matteo Rocco, |  Gokhan Sengun, Guenter Knauf, Jan Schaumann, Jonathan Nieder, Kamil Dudka, | ||||||
|  Aaron Orenstein, Yang Tse, Kamil Dudka, Amr Shahin, Josue Andrade Gomes, |  Lijo Antony, Olaf Flebbe, Rodrigo Silva, Steve Holme, Tatsuhiro Tsujikawa, | ||||||
|  Ori Avtalion, Richard Silverman, Julien Chaffraix |  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) |         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" | 309 - metalink support for the curl tool | ||||||
|       http://curl.haxx.se/bug/view.cgi?id=3172608 |  | ||||||
|       Would be nice if someone could verify the suggested patch |  | ||||||
|  |  | ||||||
| 285 - bug 3163118 "Allow programatic use of telnet on Windows" | 310 - a new authentication callback | ||||||
|       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 |  | ||||||
|  |  | ||||||
| 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 | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # 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 | \ |     tmp_exp=`eval "$ac_cpp conftest.$ac_ext" 2>/dev/null | \ | ||||||
|       "$GREP" CURL_DEF_TOKEN 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` |       "$SED" 's/[["]][[ ]]*[["]]//g' 2>/dev/null` | ||||||
|     if test -z "$tmp_exp" || test "$tmp_exp" = "$1"; then |     if test -z "$tmp_exp" || test "$tmp_exp" = "$1"; then | ||||||
|       tmp_exp="" |       tmp_exp="" | ||||||
| @@ -228,12 +228,7 @@ AC_DEFUN([CURL_CHECK_NATIVE_WINDOWS], [ | |||||||
|       ]) |       ]) | ||||||
|     fi |     fi | ||||||
|   ]) |   ]) | ||||||
|   case "$ac_cv_native_windows" in |   AM_CONDITIONAL(DOING_NATIVE_WINDOWS, test "x$ac_cv_native_windows" = xyes) | ||||||
|     yes) |  | ||||||
|       AC_DEFINE_UNQUOTED(NATIVE_WINDOWS, 1, |  | ||||||
|         [Define to 1 if you are building a native Windows target.]) |  | ||||||
|       ;; |  | ||||||
|   esac |  | ||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										173
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										173
									
								
								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 | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # 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(){ | die(){ | ||||||
| 	echo "$@" |   echo "buildconf: $@" | ||||||
| 	exit |   exit 1 | ||||||
| } | } | ||||||
|  |  | ||||||
| #-------------------------------------------------------------------------- | #-------------------------------------------------------------------------- | ||||||
| @@ -33,11 +36,8 @@ die(){ | |||||||
| findtool(){ | findtool(){ | ||||||
|   file="$1" |   file="$1" | ||||||
|  |  | ||||||
|   if { echo $file | grep "/" >/dev/null 2>&1; } then |   if { echo "$file" | grep "/" >/dev/null 2>&1; } then | ||||||
|     # we only check for the explicit file name if the file is given |     # when file is given with a path check it first | ||||||
|     # including a slash. Use ./ for current dir. Previously this would |  | ||||||
|     # otherwise always cause findtool to search the local dir first, which |  | ||||||
|     # is wrong. |  | ||||||
|     if test -f "$file"; then |     if test -f "$file"; then | ||||||
|       echo "$file" |       echo "$file" | ||||||
|       return |       return | ||||||
| @@ -80,16 +80,19 @@ removethis(){ | |||||||
| # Ensure that buildconf runs from the subdirectory where configure.ac lives | # Ensure that buildconf runs from the subdirectory where configure.ac lives | ||||||
| # | # | ||||||
| if test ! -f configure.ac || | if test ! -f configure.ac || | ||||||
|   test ! -f src/main.c || |   test ! -f src/tool_main.c || | ||||||
|   test ! -f lib/urldata.h || |   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 "Can not run buildconf from outside of curl's source subdirectory!" | ||||||
|   echo "Change to the subdirectory where buildconf is found, and try again." |   echo "Change to the subdirectory where buildconf is found, and try again." | ||||||
|   exit 1 |   exit 1 | ||||||
| fi | 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" | need_autoconf="2.57" | ||||||
| ac_version=`${AUTOCONF:-autoconf} --version 2>/dev/null|head -n 1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | 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 |   exit 1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| echo "buildconf: autoconf version $ac_version (ok)" | if test "$1" = "2" -a "$2" -eq "67"; then | ||||||
|  |   echo "buildconf: autoconf version $ac_version (BAD)" | ||||||
|  |   echo "            Unpatched version generates broken configure script." | ||||||
|  | elif test "$1" = "2" -a "$2" -eq "68"; then | ||||||
|  |   echo "buildconf: autoconf version $ac_version (BAD)" | ||||||
|  |   echo "            Unpatched version generates unusable configure script." | ||||||
|  | else | ||||||
|  |   echo "buildconf: autoconf version $ac_version (ok)" | ||||||
|  | fi | ||||||
|  |  | ||||||
| am4te_version=`${AUTOM4TE:-autom4te} --version 2>/dev/null|head -n 1| sed -e 's/autom4te\(.*\)/\1/' -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | 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 | if test -z "$am4te_version"; then | ||||||
| @@ -178,27 +189,24 @@ else | |||||||
| fi | fi | ||||||
|  |  | ||||||
| #-------------------------------------------------------------------------- | #-------------------------------------------------------------------------- | ||||||
| # libtool check | # GNU libtool preliminary check | ||||||
| # | # | ||||||
| LIBTOOL_WANTED_MAJOR=1 | want_lt_major=1 | ||||||
| LIBTOOL_WANTED_MINOR=4 | want_lt_minor=4 | ||||||
| LIBTOOL_WANTED_PATCH=2 | want_lt_patch=2 | ||||||
| LIBTOOL_WANTED_VERSION=1.4.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` | libtool=`findtool glibtool 2>/dev/null` | ||||||
| if test ! -x "$libtool"; then | if test ! -x "$libtool"; then | ||||||
|   libtool=`findtool ${LIBTOOL:-libtool}` |   libtool=`findtool ${LIBTOOL:-libtool}` | ||||||
| fi | fi | ||||||
|  | if test -z "$libtool"; then | ||||||
| if test -z "$LIBTOOLIZE"; then |   echo "buildconf: libtool not found." | ||||||
|   # set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found |   echo "            You need GNU libtool $want_lt_version or newer installed." | ||||||
|   # $libtool is already the full path |   exit 1 | ||||||
|   libtoolize="${libtool}ize" |  | ||||||
| else |  | ||||||
|   libtoolize=`findtool $LIBTOOLIZE` |  | ||||||
| fi | fi | ||||||
|  |  | ||||||
| lt_pver=`$libtool --version 2>/dev/null|head -n 1` | 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]*\)$//"` | lt_version=`echo $lt_qver|sed -e "s/[- ].*//" -e "s/\([a-z]*\)$//"` | ||||||
| if test -z "$lt_version"; then | if test -z "$lt_version"; then | ||||||
|   echo "buildconf: libtool not found." |   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 |   exit 1 | ||||||
| fi | fi | ||||||
| old_IFS=$IFS; IFS='.'; set $lt_version; IFS=$old_IFS | old_IFS=$IFS; IFS='.'; set $lt_version; IFS=$old_IFS | ||||||
| lt_major=$1 | lt_major=$1 | ||||||
| lt_minor=$2 | lt_minor=$2 | ||||||
| lt_patch=$3 | lt_patch=$3 | ||||||
| lt_status="good" |  | ||||||
|  |  | ||||||
| if test "$lt_major" = "$LIBTOOL_WANTED_MAJOR"; then | if test -z "$lt_major"; then | ||||||
|    if test "$lt_minor" -lt "$LIBTOOL_WANTED_MINOR"; then |  | ||||||
|   lt_status="bad" |   lt_status="bad" | ||||||
|    elif test -n "$LIBTOOL_WANTED_PATCH"; then | elif test "$lt_major" -gt "$want_lt_major"; then | ||||||
|        if test "$lt_minor" -gt "$LIBTOOL_WANTED_MINOR"; then |  | ||||||
|   lt_status="good" |   lt_status="good" | ||||||
|        elif test -n "$lt_patch"; then | elif test "$lt_major" -lt "$want_lt_major"; then | ||||||
|           if test "$lt_patch" -lt "$LIBTOOL_WANTED_PATCH"; then |  | ||||||
|   lt_status="bad" |   lt_status="bad" | ||||||
|           fi | elif test -z "$lt_minor"; then | ||||||
|        else |  | ||||||
|   lt_status="bad" |   lt_status="bad" | ||||||
|        fi | elif test "$lt_minor" -gt "$want_lt_minor"; then | ||||||
|    fi |   lt_status="good" | ||||||
|  | elif test "$lt_minor" -lt "$want_lt_minor"; then | ||||||
|  |   lt_status="bad" | ||||||
|  | elif test -z "$lt_patch"; then | ||||||
|  |   lt_status="bad" | ||||||
|  | elif test "$lt_patch" -gt "$want_lt_patch"; then | ||||||
|  |   lt_status="good" | ||||||
|  | elif test "$lt_patch" -lt "$want_lt_patch"; then | ||||||
|  |   lt_status="bad" | ||||||
|  | else | ||||||
|  |   lt_status="good" | ||||||
| fi | fi | ||||||
| if test $lt_status != "good"; then | if test "$lt_status" != "good"; then | ||||||
|   echo "buildconf: libtool version $lt_version found." |   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 |   exit 1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| echo "buildconf: libtool version $lt_version (ok)" | 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 | 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 |   exit 1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| @@ -266,6 +287,10 @@ fi | |||||||
| # perl check | # perl check | ||||||
| # | # | ||||||
| PERL=`findtool ${PERL:-perl}` | 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. | # Remove files generated on previous buildconf/configure run. | ||||||
| @@ -301,6 +326,7 @@ for fname in .deps \ | |||||||
|     libcurl.pc \ |     libcurl.pc \ | ||||||
|     libtool \ |     libtool \ | ||||||
|     libtool.m4 \ |     libtool.m4 \ | ||||||
|  |     libtool.m4.tmp \ | ||||||
|     ltmain.sh \ |     ltmain.sh \ | ||||||
|     ltoptions.m4 \ |     ltoptions.m4 \ | ||||||
|     ltsugar.m4 \ |     ltsugar.m4 \ | ||||||
| @@ -317,32 +343,49 @@ done | |||||||
| # | # | ||||||
|  |  | ||||||
| echo "buildconf: running libtoolize" | 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 | # When using libtool 1.5.X (X < 26) we copy libtool.m4 to our local m4 | ||||||
|   echo "buildconf: cURL m4 macros not found" | # subdirectory and this local copy is patched to fix some warnings that | ||||||
|   exit 1 | # 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 | fi | ||||||
|  |  | ||||||
| echo "buildconf: running aclocal" | 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: converting all mv to mv -f in local aclocal.m4" | ||||||
|   echo "buildconf: running aclocal hack to convert all mv to mv -f" | $PERL -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4 | ||||||
|   $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" | echo "buildconf: running autoheader" | ||||||
| ${AUTOHEADER:-autoheader} || die "The autoheader command failed" | ${AUTOHEADER:-autoheader} || die "autoheader command failed" | ||||||
|  |  | ||||||
| echo "buildconf: cp lib/curl_config.h.in src/curl_config.h.in" |  | ||||||
| cp lib/curl_config.h.in src/curl_config.h.in |  | ||||||
|  |  | ||||||
| echo "buildconf: running autoconf" | echo "buildconf: running autoconf" | ||||||
| ${AUTOCONF:-autoconf}     || die "The autoconf command failed" | ${AUTOCONF:-autoconf} || die "autoconf command failed" | ||||||
|  |  | ||||||
| if test -d ares; then | if test -d ares; then | ||||||
|   cd ares |   cd ares | ||||||
| @@ -352,14 +395,15 @@ if test -d ares; then | |||||||
| fi | fi | ||||||
|  |  | ||||||
| echo "buildconf: running automake" | 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 | # Depending on the libtool and automake versions being used, config.guess | ||||||
| # might not be installed in the subdirectory until automake has finished. | # 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. | # So we can not attempt to use it until this very last buildconf stage. | ||||||
| # | # | ||||||
|  |  | ||||||
| if test ! -f ./config.guess; then | if test ! -f ./config.guess; then | ||||||
|   echo "buildconf: config.guess not found" |   echo "buildconf: config.guess not found" | ||||||
| else | else | ||||||
| @@ -403,7 +447,7 @@ else | |||||||
|     if test "$lt_status" != "good"; then |     if test "$lt_status" != "good"; then | ||||||
|       need_lt_version="$need_lt_major.$need_lt_minor.$need_lt_patch" |       need_lt_version="$need_lt_major.$need_lt_minor.$need_lt_patch" | ||||||
|       echo "buildconf: libtool version $lt_version found." |       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 |       rm -f configure | ||||||
|       exit 1 |       exit 1 | ||||||
|     fi |     fi | ||||||
| @@ -413,6 +457,5 @@ fi | |||||||
| #-------------------------------------------------------------------------- | #-------------------------------------------------------------------------- | ||||||
| # Finished successfully. | # Finished successfully. | ||||||
| # | # | ||||||
|  |  | ||||||
| echo "buildconf: OK" | echo "buildconf: OK" | ||||||
| exit 0 | exit 0 | ||||||
|   | |||||||
							
								
								
									
										427
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										427
									
								
								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 | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # 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 | 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/]) | AC_INIT([curl], [-], [a suitable curl mailing list: http://curl.haxx.se/mail/]) | ||||||
|  |  | ||||||
|  | XC_OVR_ZZ50 | ||||||
| CURL_OVERRIDE_AUTOCONF | CURL_OVERRIDE_AUTOCONF | ||||||
|  |  | ||||||
| dnl configure script copyright | 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]) | terms of the curl license; see COPYING for more details]) | ||||||
|  |  | ||||||
| AC_CONFIG_SRCDIR([lib/urldata.h]) | 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]) | AC_CONFIG_MACRO_DIR([m4]) | ||||||
| AM_MAINTAINER_MODE | AM_MAINTAINER_MODE | ||||||
|  |  | ||||||
| @@ -43,6 +44,7 @@ CURL_CHECK_OPTION_OPTIMIZE | |||||||
| CURL_CHECK_OPTION_WARNINGS | CURL_CHECK_OPTION_WARNINGS | ||||||
| CURL_CHECK_OPTION_WERROR | CURL_CHECK_OPTION_WERROR | ||||||
| CURL_CHECK_OPTION_CURLDEBUG | CURL_CHECK_OPTION_CURLDEBUG | ||||||
|  | CURL_CHECK_OPTION_SYMBOL_HIDING | ||||||
| CURL_CHECK_OPTION_ARES | CURL_CHECK_OPTION_ARES | ||||||
|  |  | ||||||
| CURL_CHECK_PATH_SEPARATOR_REQUIRED | CURL_CHECK_PATH_SEPARATOR_REQUIRED | ||||||
| @@ -154,6 +156,7 @@ curl_tls_srp_msg="no      (--enable-tls-srp)" | |||||||
|    curl_ipv6_msg="no      (--enable-ipv6)" |    curl_ipv6_msg="no      (--enable-ipv6)" | ||||||
|     curl_idn_msg="no      (--with-libidn)" |     curl_idn_msg="no      (--with-libidn)" | ||||||
|  curl_manual_msg="no      (--enable-manual)" |  curl_manual_msg="no      (--enable-manual)" | ||||||
|  | curl_libcurl_msg="enabled (--disable-libcurl-option)" | ||||||
| curl_verbose_msg="enabled (--disable-verbose)" | curl_verbose_msg="enabled (--disable-verbose)" | ||||||
|    curl_sspi_msg="no      (--enable-sspi)" |    curl_sspi_msg="no      (--enable-sspi)" | ||||||
|    curl_ldap_msg="no      (--enable-ldap / --with-ldap-lib / --with-lber-lib)" |    curl_ldap_msg="no      (--enable-ldap / --with-ldap-lib / --with-lber-lib)" | ||||||
| @@ -234,21 +237,18 @@ esac | |||||||
| AC_MSG_RESULT($mimpure) | AC_MSG_RESULT($mimpure) | ||||||
| AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes) | 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]) | AC_MSG_CHECKING([if we need BUILDING_LIBCURL]) | ||||||
|  | use_cppflag_building_libcurl="no" | ||||||
|  | use_cppflag_curl_staticlib="no" | ||||||
| case $host in | case $host in | ||||||
|   *-*-mingw*) |   *-*-mingw*) | ||||||
|     AC_DEFINE(BUILDING_LIBCURL, 1, [when building libcurl itself]) |  | ||||||
|     AC_MSG_RESULT(yes) |     AC_MSG_RESULT(yes) | ||||||
|  |     use_cppflag_building_libcurl="yes" | ||||||
|     AC_MSG_CHECKING([if we need CURL_STATICLIB]) |     AC_MSG_CHECKING([if we need CURL_STATICLIB]) | ||||||
|     if test "X$enable_shared" = "Xno" |     if test "X$enable_shared" = "Xno" | ||||||
|     then |     then | ||||||
|       AC_DEFINE(CURL_STATICLIB, 1, [when not building a shared library]) |  | ||||||
|       AC_MSG_RESULT(yes) |       AC_MSG_RESULT(yes) | ||||||
|       AM_CONDITIONAL(STATICLIB, true) |       use_cppflag_curl_staticlib="yes" | ||||||
|     else |     else | ||||||
|       AC_MSG_RESULT(no) |       AC_MSG_RESULT(no) | ||||||
|     fi |     fi | ||||||
| @@ -257,6 +257,8 @@ case $host in | |||||||
|     AC_MSG_RESULT(no) |     AC_MSG_RESULT(no) | ||||||
|     ;; |     ;; | ||||||
| esac | 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 | # Determine whether all dependent libraries must be specified when linking | ||||||
| if test "X$enable_shared" = "Xyes" -a "X$link_all_deplibs" = "Xno" | 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_HALT_ON_ERROR | ||||||
| CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE | ||||||
|  | CURL_CHECK_COMPILER_SYMBOL_HIDING | ||||||
|  |  | ||||||
| CURL_CHECK_NO_UNDEFINED | CURL_CHECK_NO_UNDEFINED | ||||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||||
| @@ -314,6 +317,26 @@ if test "x$cross_compiling" != "xno" && | |||||||
|   supports_unittests=no |   supports_unittests=no | ||||||
| fi | 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. | dnl Build unit tests when option --enable-debug is given. | ||||||
| if test "x$want_debug" = "xyes" && | if test "x$want_debug" = "xyes" && | ||||||
|    test "x$supports_unittests" = "xyes"; then |    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 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 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 ********************************************************************** | ||||||
| dnl Checks for libraries. | dnl Checks for libraries. | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -655,6 +697,17 @@ then | |||||||
|                ]) |                ]) | ||||||
| fi | 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 At least one system has been identified to require BOTH nsl and socket | ||||||
| dnl libs at the same time to link properly. | dnl libs at the same time to link properly. | ||||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | if test "$HAVE_GETHOSTBYNAME" != "1" | ||||||
| @@ -1330,7 +1383,7 @@ if test X"$OPT_SSL" != Xno; then | |||||||
|     dnl the user told us to look |     dnl the user told us to look | ||||||
|     OPENSSL_PCDIR="$OPT_SSL/lib/pkgconfig" |     OPENSSL_PCDIR="$OPT_SSL/lib/pkgconfig" | ||||||
|     AC_MSG_NOTICE([PKG_CONFIG_LIBDIR will be set to "$OPENSSL_PCDIR"]) |     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" |       PKGTEST="yes" | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @@ -1494,7 +1547,8 @@ if test X"$OPT_SSL" != Xno; then | |||||||
|                     RAND_egd \ |                     RAND_egd \ | ||||||
|                     ENGINE_cleanup \ |                     ENGINE_cleanup \ | ||||||
|                     CRYPTO_cleanup_all_ex_data \ |                     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 Make an attempt to detect if this is actually yassl's headers and | ||||||
|     dnl OpenSSL emulation layer. We still leave everything else believing |     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 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 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 |        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" |          LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_OPENSSL" | ||||||
|          export LD_LIBRARY_PATH |          export LD_LIBRARY_PATH | ||||||
|          AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH]) |          AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH]) | ||||||
|        fi |        fi | ||||||
|  |     fi | ||||||
|     CURL_CHECK_OPENSSL_API |     CURL_CHECK_OPENSSL_API | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
| @@ -1765,12 +1820,13 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
|           dnl linker doesn't search through, we need to add it to |           dnl linker doesn't search through, we need to add it to | ||||||
|           dnl LD_LIBRARY_PATH to prevent further configure tests to fail |           dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||||
|           dnl due to this |           dnl due to this | ||||||
|  |           if test "x$cross_compiling" != "xyes"; then  | ||||||
|             LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlslib" |             LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlslib" | ||||||
|             export LD_LIBRARY_PATH |             export LD_LIBRARY_PATH | ||||||
|             AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH]) |             AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH]) | ||||||
|           fi |           fi | ||||||
|         fi |         fi | ||||||
|  |       fi | ||||||
|  |  | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @@ -1779,17 +1835,33 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
| fi dnl OPENSSL != 1 | fi dnl OPENSSL != 1 | ||||||
|  |  | ||||||
| dnl --- | dnl --- | ||||||
| dnl If GnuTLS is enabled, we MUST verify that it uses libgcrypt since | dnl Check which crypto backend GnuTLS uses | ||||||
| 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 --- | dnl --- | ||||||
|  |  | ||||||
| if test "$GNUTLS_ENABLED" = "1"; then | if test "$GNUTLS_ENABLED" = "1"; then | ||||||
|   AC_CHECK_LIB(gcrypt, |   USE_GNUTLS_NETTLE= | ||||||
|                gcry_control, , |   # First check if we can detect either crypto library via transitive linking | ||||||
|     [ |   AC_CHECK_LIB(gnutls, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ]) | ||||||
|       AC_MSG_ERROR([need GnuTLS built with gcrypt to function with GnuTLS]) |   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 | fi | ||||||
|  |  | ||||||
| dnl --- | dnl --- | ||||||
| @@ -1875,12 +1947,12 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
|         dnl linker doesn't search through, we need to add it to |         dnl linker doesn't search through, we need to add it to | ||||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail |         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||||
|         dnl due to this |         dnl due to this | ||||||
|  |         if test "x$cross_compiling" != "xyes"; then | ||||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib" |           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib" | ||||||
|           export LD_LIBRARY_PATH |           export LD_LIBRARY_PATH | ||||||
|           AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH]) |           AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH]) | ||||||
|         fi |         fi | ||||||
|  |       fi | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|   fi dnl PolarSSL not disabled |   fi dnl PolarSSL not disabled | ||||||
| @@ -1897,7 +1969,7 @@ OPT_CYASSL=no | |||||||
| _cppflags=$CPPFLAGS | _cppflags=$CPPFLAGS | ||||||
| _ldflags=$LDFLAGS | _ldflags=$LDFLAGS | ||||||
| AC_ARG_WITH(cyassl,dnl | 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]), | AC_HELP_STRING([--without-cyassl], [disable CyaSSL detection]), | ||||||
|   OPT_CYASSL=$withval) |   OPT_CYASSL=$withval) | ||||||
|  |  | ||||||
| @@ -1910,14 +1982,9 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if test -z "$OPT_CYASSL" ; then |     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" |       AC_CHECK_LIB(cyassl, CyaSSL_Init, | ||||||
|  |  | ||||||
|       LDFLAGS="$LDFLAGS -L$trycyassldir/lib" |  | ||||||
|       CPPFLAGS="$CPPFLAGS -I$trycyassldir/include" |  | ||||||
|  |  | ||||||
|       AC_CHECK_LIB(cyassl, InitCyaSSL, |  | ||||||
|       dnl libcyassl found, set the variable |       dnl libcyassl found, set the variable | ||||||
|        [ |        [ | ||||||
|          AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) |          AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) | ||||||
| @@ -1939,7 +2006,7 @@ if test "$OPENSSL_ENABLED" != "1"; then | |||||||
|          CPPFLAGS="$CPPFLAGS $addcflags" |          CPPFLAGS="$CPPFLAGS $addcflags" | ||||||
|       fi |       fi | ||||||
|  |  | ||||||
|       AC_CHECK_LIB(cyassl, InitCyaSSL, |       AC_CHECK_LIB(cyassl, CyaSSL_Init, | ||||||
|        [ |        [ | ||||||
|        AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) |        AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled]) | ||||||
|        AC_SUBST(USE_CYASSL, [1]) |        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 linker doesn't search through, we need to add it to | ||||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail |         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||||
|         dnl due to this |         dnl due to this | ||||||
|  |         if test "x$cross_compiling" != "xyes"; then | ||||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$cyassllib" |           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$cyassllib" | ||||||
|           export LD_LIBRARY_PATH |           export LD_LIBRARY_PATH | ||||||
|           AC_MSG_NOTICE([Added $cyassllib to LD_LIBRARY_PATH]) |           AC_MSG_NOTICE([Added $cyassllib to LD_LIBRARY_PATH]) | ||||||
|         fi |         fi | ||||||
|  |       fi | ||||||
|  |  | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @@ -2023,13 +2091,6 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | |||||||
|         nssprefix=$OPT_NSS |         nssprefix=$OPT_NSS | ||||||
|     fi |     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 |     if test -n "$addlib"; then | ||||||
|  |  | ||||||
|       CLEANLIBS="$LIBS" |       CLEANLIBS="$LIBS" | ||||||
| @@ -2040,7 +2101,8 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | |||||||
|          CPPFLAGS="$CPPFLAGS $addcflags" |          CPPFLAGS="$CPPFLAGS $addcflags" | ||||||
|       fi |       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_DEFINE(USE_NSS, 1, [if NSS is enabled]) | ||||||
|        AC_SUBST(USE_NSS, [1]) |        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 |       if test "x$USE_NSS" = "xyes"; then | ||||||
|         AC_MSG_NOTICE([detected NSS version $version]) |         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 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 linker doesn't search through, we need to add it to | ||||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail |         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||||
|         dnl due to this |         dnl due to this | ||||||
|  |         if test "x$cross_compiling" != "xyes"; then | ||||||
|           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff" |           LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff" | ||||||
|           export LD_LIBRARY_PATH |           export LD_LIBRARY_PATH | ||||||
|           AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH]) |           AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH]) | ||||||
|         fi |         fi | ||||||
|  |       fi | ||||||
|  |  | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
| @@ -2220,11 +2291,12 @@ if test X"$OPT_LIBSSH2" != Xno; then | |||||||
|        dnl libssh2_session_handshake was added in 1.2.8 |        dnl libssh2_session_handshake was added in 1.2.8 | ||||||
|        AC_CHECK_FUNCS( libssh2_version libssh2_init libssh2_exit \ |        AC_CHECK_FUNCS( libssh2_version libssh2_init libssh2_exit \ | ||||||
|                        libssh2_scp_send64 libssh2_session_handshake) |                        libssh2_scp_send64 libssh2_session_handshake) | ||||||
|  |        if test "x$cross_compiling" != "xyes"; then | ||||||
|          LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2" |          LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2" | ||||||
|          export LD_LIBRARY_PATH |          export LD_LIBRARY_PATH | ||||||
|          AC_MSG_NOTICE([Added $DIR_SSH2 to LD_LIBRARY_PATH]) |          AC_MSG_NOTICE([Added $DIR_SSH2 to LD_LIBRARY_PATH]) | ||||||
|        fi |        fi | ||||||
|  |     fi | ||||||
|   else |   else | ||||||
|     dnl no libssh2, revert back to clean variables |     dnl no libssh2, revert back to clean variables | ||||||
|     LDFLAGS=$CLEANLDFLAGS |     LDFLAGS=$CLEANLDFLAGS | ||||||
| @@ -2311,56 +2383,197 @@ if test X"$OPT_LIBRTMP" != Xno; then | |||||||
|  |  | ||||||
| fi | 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 ********************************************************************** | ||||||
| dnl Check for the presence of IDN libraries and headers | dnl Check for the presence of IDN libraries and headers | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([whether to build with libidn]) | AC_MSG_CHECKING([whether to build with libidn]) | ||||||
|  | OPT_IDN="default" | ||||||
| AC_ARG_WITH(libidn, | AC_ARG_WITH(libidn, | ||||||
| AC_HELP_STRING([--with-libidn=PATH],[Enable libidn usage]) | AC_HELP_STRING([--with-libidn=PATH],[Enable libidn usage]) | ||||||
| AC_HELP_STRING([--without-libidn],[Disable libidn usage]), | AC_HELP_STRING([--without-libidn],[Disable libidn usage]), | ||||||
|   [LIBIDN="$withval"]) |   [OPT_IDN=$withval]) | ||||||
|  | case "$OPT_IDN" in | ||||||
| case "$LIBIDN" in |  | ||||||
|   no) |   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 | ||||||
|        idn="" |     want_idn="yes" | ||||||
|        dnl if there is a given path, check that FIRST |     want_idn_path="default" | ||||||
|        if test -n "$LIBIDN"; then |     AC_MSG_RESULT([(assumed) yes]) | ||||||
|          if test "x$LIBIDN" != "xyes"; then |     ;; | ||||||
|             oldLDFLAGS=$LDFLAGS |   yes) | ||||||
|             oldCPPFLAGS=$CPPFLAGS |     dnl --with-libidn option used without path | ||||||
|             LDFLAGS="$LDFLAGS -L$LIBIDN/lib" |     want_idn="yes" | ||||||
|             CPPFLAGS="$CPPFLAGS -I$LIBIDN/include" |     want_idn_path="default" | ||||||
|             idn="yes" |     AC_MSG_RESULT([yes]) | ||||||
|             AC_CHECK_LIB(idn, idna_to_ascii_4i, , |     ;; | ||||||
|                          idn="" |   *) | ||||||
|                          LDFLAGS=$oldLDFLAGS |     dnl --with-libidn option used with path | ||||||
|                          CPPFLAGS=$oldCPPFLAGS) |     want_idn="yes" | ||||||
|          fi |     want_idn_path="$withval" | ||||||
|        fi |     AC_MSG_RESULT([yes ($withval)]) | ||||||
|  |  | ||||||
|        if test "x$idn" != "xyes"; then |  | ||||||
|           dnl check with default paths |  | ||||||
|           idn="yes" |  | ||||||
|           AC_CHECK_LIB(idn, idna_to_ascii_lz, , |  | ||||||
|                        idn="") |  | ||||||
|        fi |  | ||||||
|  |  | ||||||
|        if test "x$idn" = "xyes"; then |  | ||||||
|          curl_idn_msg="enabled" |  | ||||||
|          AC_SUBST(IDN_ENABLED, [1]) |  | ||||||
|          dnl different versions of libidn have different setups of these: |  | ||||||
|          AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror) |  | ||||||
|          AC_CHECK_HEADERS( idn-free.h tld.h ) |  | ||||||
|        fi |  | ||||||
|  |  | ||||||
|     ;; |     ;; | ||||||
| esac | esac | ||||||
|  |  | ||||||
|  | if test "$want_idn" = "yes"; then | ||||||
|  |   dnl idn library support has been requested | ||||||
|  |   clean_CPPFLAGS="$CPPFLAGS" | ||||||
|  |   clean_LDFLAGS="$LDFLAGS" | ||||||
|  |   clean_LIBS="$LIBS" | ||||||
|  |   PKGCONFIG="no" | ||||||
|  |   # | ||||||
|  |   if test "$want_idn_path" != "default"; then | ||||||
|  |     dnl path has been specified | ||||||
|  |     IDN_PCDIR="$want_idn_path/lib$libsuff/pkgconfig" | ||||||
|  |     CURL_CHECK_PKGCONFIG(libidn, [$IDN_PCDIR]) | ||||||
|  |     if test "$PKGCONFIG" != "no"; then | ||||||
|  |       IDN_LIBS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl | ||||||
|  |         $PKGCONFIG --libs-only-l libidn 2>/dev/null` | ||||||
|  |       IDN_LDFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl | ||||||
|  |         $PKGCONFIG --libs-only-L libidn 2>/dev/null` | ||||||
|  |       IDN_CPPFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl | ||||||
|  |         $PKGCONFIG --cflags-only-I libidn 2>/dev/null` | ||||||
|  |       IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/-L//'` | ||||||
|  |     else | ||||||
|  |       dnl pkg-config not available or provides no info | ||||||
|  |       IDN_LIBS="-lidn" | ||||||
|  |       IDN_LDFLAGS="-L$want_idn_path/lib$libsuff" | ||||||
|  |       IDN_CPPFLAGS="-I$want_idn_path/include" | ||||||
|  |       IDN_DIR="$want_idn_path/lib$libsuff" | ||||||
|  |     fi | ||||||
|  |   else | ||||||
|  |     dnl path not specified | ||||||
|  |     CURL_CHECK_PKGCONFIG(libidn) | ||||||
|  |     if test "$PKGCONFIG" != "no"; then | ||||||
|  |       IDN_LIBS=`$PKGCONFIG --libs-only-l libidn 2>/dev/null` | ||||||
|  |       IDN_LDFLAGS=`$PKGCONFIG --libs-only-L libidn 2>/dev/null` | ||||||
|  |       IDN_CPPFLAGS=`$PKGCONFIG --cflags-only-I libidn 2>/dev/null` | ||||||
|  |       IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/-L//'` | ||||||
|  |     else | ||||||
|  |       dnl pkg-config not available or provides no info | ||||||
|  |       IDN_LIBS="-lidn" | ||||||
|  |     fi | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$PKGCONFIG" != "no"; then | ||||||
|  |     AC_MSG_NOTICE([pkg-config: IDN_LIBS: "$IDN_LIBS"]) | ||||||
|  |     AC_MSG_NOTICE([pkg-config: IDN_LDFLAGS: "$IDN_LDFLAGS"]) | ||||||
|  |     AC_MSG_NOTICE([pkg-config: IDN_CPPFLAGS: "$IDN_CPPFLAGS"]) | ||||||
|  |     AC_MSG_NOTICE([pkg-config: IDN_DIR: "$IDN_DIR"]) | ||||||
|  |   else | ||||||
|  |     AC_MSG_NOTICE([IDN_LIBS: "$IDN_LIBS"]) | ||||||
|  |     AC_MSG_NOTICE([IDN_LDFLAGS: "$IDN_LDFLAGS"]) | ||||||
|  |     AC_MSG_NOTICE([IDN_CPPFLAGS: "$IDN_CPPFLAGS"]) | ||||||
|  |     AC_MSG_NOTICE([IDN_DIR: "$IDN_DIR"]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   CPPFLAGS="$IDN_CPPFLAGS $CPPFLAGS" | ||||||
|  |   LDFLAGS="$IDN_LDFLAGS $LDFLAGS" | ||||||
|  |   LIBS="$IDN_LIBS $LIBS" | ||||||
|  |   # | ||||||
|  |   AC_MSG_CHECKING([if idna_to_ascii_4i can be linked]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_FUNC_LINK_TRY([idna_to_ascii_4i]) | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     tst_links_libidn="yes" | ||||||
|  |   ],[ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |     tst_links_libidn="no" | ||||||
|  |   ]) | ||||||
|  |   if test "$tst_links_libidn" = "no"; then | ||||||
|  |     AC_MSG_CHECKING([if idna_to_ascii_lz can be linked]) | ||||||
|  |     AC_LINK_IFELSE([ | ||||||
|  |       AC_LANG_FUNC_LINK_TRY([idna_to_ascii_lz]) | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([yes]) | ||||||
|  |       tst_links_libidn="yes" | ||||||
|  |     ],[ | ||||||
|  |       AC_MSG_RESULT([no]) | ||||||
|  |       tst_links_libidn="no" | ||||||
|  |     ]) | ||||||
|  |   fi | ||||||
|  |   # | ||||||
|  |   if test "$tst_links_libidn" = "yes"; then | ||||||
|  |     AC_DEFINE(HAVE_LIBIDN, 1, [Define to 1 if you have the `idn' library (-lidn).]) | ||||||
|  |     dnl different versions of libidn have different setups of these: | ||||||
|  |     AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror ) | ||||||
|  |     AC_CHECK_HEADERS( idn-free.h tld.h ) | ||||||
|  |     if test "x$ac_cv_header_tld_h" = "xyes"; then | ||||||
|  |       AC_SUBST([IDN_ENABLED], [1]) | ||||||
|  |       curl_idn_msg="enabled" | ||||||
|  |       if test -n "$IDN_DIR"; then | ||||||
|  |         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$IDN_DIR" | ||||||
|  |         export LD_LIBRARY_PATH | ||||||
|  |         AC_MSG_NOTICE([Added $IDN_DIR to LD_LIBRARY_PATH]) | ||||||
|  |       fi | ||||||
|  |     else | ||||||
|  |       AC_MSG_WARN([Libraries for IDN support too old: IDN disabled]) | ||||||
|  |       CPPFLAGS="$clean_CPPFLAGS" | ||||||
|  |       LDFLAGS="$clean_LDFLAGS" | ||||||
|  |       LIBS="$clean_LIBS" | ||||||
|  |     fi | ||||||
|  |   else | ||||||
|  |     AC_MSG_WARN([Cannot find libraries for IDN support: IDN disabled]) | ||||||
|  |     CPPFLAGS="$clean_CPPFLAGS" | ||||||
|  |     LDFLAGS="$clean_LDFLAGS" | ||||||
|  |     LIBS="$clean_LIBS" | ||||||
|  |   fi | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl Let's hope this split URL remains working: | dnl Let's hope this split URL remains working: | ||||||
| dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \ | dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \ | ||||||
| @@ -2419,6 +2632,7 @@ AC_CHECK_HEADERS( | |||||||
|         stdbool.h \ |         stdbool.h \ | ||||||
|         arpa/tftp.h \ |         arpa/tftp.h \ | ||||||
|         sys/filio.h \ |         sys/filio.h \ | ||||||
|  |         sys/wait.h \ | ||||||
|         setjmp.h, |         setjmp.h, | ||||||
| dnl to do if not found | dnl to do if not found | ||||||
| [], | [], | ||||||
| @@ -2564,6 +2778,7 @@ CURL_CHECK_FUNC_SIGINTERRUPT | |||||||
| CURL_CHECK_FUNC_SIGNAL | CURL_CHECK_FUNC_SIGNAL | ||||||
| CURL_CHECK_FUNC_SIGSETJMP | CURL_CHECK_FUNC_SIGSETJMP | ||||||
| CURL_CHECK_FUNC_SOCKET | CURL_CHECK_FUNC_SOCKET | ||||||
|  | CURL_CHECK_FUNC_SOCKETPAIR | ||||||
| CURL_CHECK_FUNC_STRCASECMP | CURL_CHECK_FUNC_STRCASECMP | ||||||
| CURL_CHECK_FUNC_STRCASESTR | CURL_CHECK_FUNC_STRCASESTR | ||||||
| CURL_CHECK_FUNC_STRCMPI | CURL_CHECK_FUNC_STRCMPI | ||||||
| @@ -2794,6 +3009,10 @@ AC_HELP_STRING([--disable-crypto-auth],[Disable cryptographic authentication]), | |||||||
|        AC_MSG_RESULT(yes) |        AC_MSG_RESULT(yes) | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | CURL_CHECK_OPTION_NTLM_WB | ||||||
|  |  | ||||||
|  | CURL_CHECK_NTLM_WB | ||||||
|  |  | ||||||
| dnl ************************************************************ | dnl ************************************************************ | ||||||
| dnl disable TLS-SRP authentication | dnl disable TLS-SRP authentication | ||||||
| dnl | dnl | ||||||
| @@ -2840,48 +3059,9 @@ AC_HELP_STRING([--disable-cookies],[Disable cookies support]), | |||||||
| ) | ) | ||||||
|  |  | ||||||
| dnl ************************************************************ | dnl ************************************************************ | ||||||
| dnl Enable hiding of internal symbols in library to reduce its size and | dnl hiding of library internal symbols | ||||||
| dnl speed dynamic linking of applications.  This currently is only supported |  | ||||||
| dnl on gcc >= 4.0 and SunPro C. |  | ||||||
| dnl | dnl | ||||||
| AC_MSG_CHECKING([whether to enable hidden symbols in the library]) | CURL_CONFIGURE_SYMBOL_HIDING | ||||||
| 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) |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| dnl ************************************************************ | dnl ************************************************************ | ||||||
| dnl enforce SONAME bump | 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" \ |   if test "x$USE_SSLEAY" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \ | ||||||
|       -o "x$GNUTLS_ENABLED" = "x1" -o "x$NSS_ENABLED" = "x1"; then |       -o "x$GNUTLS_ENABLED" = "x1" -o "x$NSS_ENABLED" = "x1"; then | ||||||
|     SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM" |     SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM" | ||||||
|  |     if test "x$NTLM_WB_ENABLED" = "x1"; then | ||||||
|  |       SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM_WB" | ||||||
|  |     fi | ||||||
|   fi |   fi | ||||||
| fi | fi | ||||||
| if test "x$USE_TLS_SRP" = "x1"; then | if test "x$USE_TLS_SRP" = "x1"; then | ||||||
| @@ -3079,6 +3262,7 @@ AC_CONFIG_FILES([Makefile \ | |||||||
|            include/curl/Makefile \ |            include/curl/Makefile \ | ||||||
|            src/Makefile \ |            src/Makefile \ | ||||||
|            lib/Makefile \ |            lib/Makefile \ | ||||||
|  |            lib/libcurl.vers \ | ||||||
|            tests/Makefile \ |            tests/Makefile \ | ||||||
|            tests/data/Makefile \ |            tests/data/Makefile \ | ||||||
|            tests/server/Makefile \ |            tests/server/Makefile \ | ||||||
| @@ -3123,6 +3307,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | |||||||
|   IDN support:      ${curl_idn_msg} |   IDN support:      ${curl_idn_msg} | ||||||
|   Build libcurl:    Shared=${enable_shared}, Static=${enable_static} |   Build libcurl:    Shared=${enable_shared}, Static=${enable_static} | ||||||
|   Built-in manual:  ${curl_manual_msg} |   Built-in manual:  ${curl_manual_msg} | ||||||
|  |   --libcurl option: ${curl_libcurl_msg} | ||||||
|   Verbose errors:   ${curl_verbose_msg} |   Verbose errors:   ${curl_verbose_msg} | ||||||
|   SSPI support:     ${curl_sspi_msg} |   SSPI support:     ${curl_sspi_msg} | ||||||
|   ca cert bundle:   ${ca} |   ca cert bundle:   ${ca} | ||||||
|   | |||||||
| @@ -142,9 +142,9 @@ while test $# -gt 0; do | |||||||
| 	   CURLLIBDIR="" | 	   CURLLIBDIR="" | ||||||
| 	fi | 	fi | ||||||
| 	if test "X@REQUIRE_LIB_DEPS@" = "Xyes"; then | 	if test "X@REQUIRE_LIB_DEPS@" = "Xyes"; then | ||||||
| 	  echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBCURL_LIBS@ @LIBS@ | 	  echo ${CURLLIBDIR}-lcurl @LIBCURL_LIBS@ @LIBS@ | ||||||
| 	else | 	else | ||||||
| 	  echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBS@ | 	  echo ${CURLLIBDIR}-lcurl @LIBS@ | ||||||
| 	fi | 	fi | ||||||
| 	;; | 	;; | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										83
									
								
								docs/BUGS
									
									
									
									
									
								
							
							
						
						
									
										83
									
								
								docs/BUGS
									
									
									
									
									
								
							| @@ -6,21 +6,34 @@ | |||||||
|  |  | ||||||
| BUGS | 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 |   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 |   of writing (September 2011), there are about 66000 lines of source code, and | ||||||
|   the time you read this it has probably grown even more. |   by the time you read this it has probably grown even more. | ||||||
|  |  | ||||||
|   Of course there are lots of bugs left. And lots of misfeatures. |   Of course there are lots of bugs left. And lots of misfeatures. | ||||||
|  |  | ||||||
|   To help us make curl the stable and solid product we want it to be, we need |   To help us make curl the stable and solid product we want it to be, we need | ||||||
|   bug reports and bug fixes. |   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 |   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 |   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 |   have a go at a solution. You can optionally also post your bug/problem at | ||||||
|   tracking system over at |   curl's bug tracking system over at | ||||||
|  |  | ||||||
|         http://sourceforge.net/bugs/?group_id=976 |         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 |   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/ |   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 |   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 |   understand what's wrong, what you expected to happen and how to repeat the | ||||||
|   bad behavior. You therefore need to tell us: |   bad behavior. You therefore need to tell us: | ||||||
|  |  | ||||||
|    - your operating system's name and version number (uname -a under a unix |    - your operating system's name and version number | ||||||
|      is fine) |  | ||||||
|    - what version of curl you're using (curl -V is fine) |    - what version of curl you're using (curl -V is fine) | ||||||
|  |  | ||||||
|    - versions of the used libraries that libcurl is built to use |    - versions of the used libraries that libcurl is built to use | ||||||
|  |  | ||||||
|    - what URL you were working with (if possible), at least which protocol |    - what URL you were working with (if possible), at least which protocol | ||||||
|  |  | ||||||
|   and anything and everything else you think matters. Tell us what you |   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 |   The address and how to subscribe to the mailing lists are detailed in the | ||||||
|   MANUAL file. |   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 |   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 |   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 |   crashed. Include the stack trace with your detailed bug report. It'll help a | ||||||
|   lot. |   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.3 How To Make a Patch without git | ||||||
|  3.4 How to get your changes into the main sources |  3.4 How to get your changes into the main sources | ||||||
|  3.5 Write good commit messages |  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 |  and make sure that you have your own user and email setup correctly in git | ||||||
|  before you commit |  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 |   We don't know how many users that downloaded or installed curl and then | ||||||
|   never use it. |   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 |   See http://daniel.haxx.se/blog/2012/05/16/300m-users/ | ||||||
|   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 |  | ||||||
|  |  | ||||||
|   1.11 Why don't you update ca-bundle.crt |   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/ |     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? |   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 |   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 |    adjust as necessary. It is also possible to override these paths with | ||||||
|    environment variables, for example: |    environment variables, for example: | ||||||
|  |  | ||||||
|      set ZLIB_PATH=c:\zlib-1.2.5 |      set ZLIB_PATH=c:\zlib-1.2.7 | ||||||
|      set OPENSSL_PATH=c:\openssl-0.9.8r |      set OPENSSL_PATH=c:\openssl-0.9.8x | ||||||
|      set LIBSSH2_PATH=c:\libssh2-1.2.8 |      set LIBSSH2_PATH=c:\libssh2-1.4.2 | ||||||
|  |  | ||||||
|    ATTENTION: if you want to build with libssh2 support you have to use latest |    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! |    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 |    documentation on how to compile zlib. Define the ZLIB_PATH environment | ||||||
|    variable to the location of zlib.h and zlib.lib, for example: |    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. |    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 |    Before running nmake define the OPENSSL_PATH environment variable with | ||||||
|    the root/base directory of OpenSSL, for example: |    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 |    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 |    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. |      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 |    Important static libcurl usage note | ||||||
|    ----------------------------------- |    ----------------------------------- | ||||||
|  |  | ||||||
| @@ -812,7 +840,30 @@ VxWorks | |||||||
|  |  | ||||||
| Android | 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 | 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 |  libssh2      0.16 | ||||||
|  c-ares       1.6.0 |  c-ares       1.6.0 | ||||||
|  libidn       0.4.1 |  libidn       0.4.1 | ||||||
|  cyassl       1.4.0 |  cyassl       2.0.0 | ||||||
|  openldap     2.0 |  openldap     2.0 | ||||||
|  MIT krb5 lib 1.2.4 |  MIT krb5 lib 1.2.4 | ||||||
|  qsossl       V5R2M0 |  qsossl       V5R2M0 | ||||||
|  NSS          3.11.x |  NSS          3.12.x | ||||||
|  axTLS        1.2.7 |  axTLS        1.2.7 | ||||||
|  Heimdal      ? |  Heimdal      ? | ||||||
|  |  | ||||||
| @@ -68,7 +68,7 @@ Portability | |||||||
|  GNU Autoconf 2.57 |  GNU Autoconf 2.57 | ||||||
|  GNU Automake 1.7 (we currently avoid 1.10 due to Solaris-related bugs) |  GNU Automake 1.7 (we currently avoid 1.10 due to Solaris-related bugs) | ||||||
|  GNU M4       1.4 |  GNU M4       1.4 | ||||||
|  perl         4 |  perl         5.004 | ||||||
|  roffit       0.5 |  roffit       0.5 | ||||||
|  groff        ? (any version that supports "groff -Tps -man [in] [out]") |  groff        ? (any version that supports "groff -Tps -man [in] [out]") | ||||||
|  ps2pdf (gs)  ? |  ps2pdf (gs)  ? | ||||||
| @@ -104,9 +104,9 @@ Windows vs Unix | |||||||
|  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All |  Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All | ||||||
|  conditionals that deal with features *should* instead be in the format |  conditionals that deal with features *should* instead be in the format | ||||||
|  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, |  '#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts, | ||||||
|  we maintain two curl_config-win32.h files (one in lib/ and one in src/) that |  we maintain a curl_config-win32.h file in lib directory that is supposed to | ||||||
|  are supposed to look exactly as a curl_config.h file would have looked like on |  look exactly as a curl_config.h file would have looked like on a Windows | ||||||
|  a Windows machine! |  machine! | ||||||
|  |  | ||||||
|  Generally speaking: always remember that this will be compiled on dozens of |  Generally speaking: always remember that this will be compiled on dozens of | ||||||
|  operating systems. Don't walk on the edge. |  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 | changelog of the current development status, as one or more of these problems | ||||||
| may have been fixed since this was written! | may have been fixed since this was written! | ||||||
|  |  | ||||||
|  | 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 | 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 |   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 |   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/mail/lib-2009-10/0024.html | ||||||
|   http://curl.haxx.se/bug/view.cgi?id=2944325 |   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 | 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 |   sends the 220 response or otherwise is dead slow, libcurl will not | ||||||
|   acknowledge the connection timeout during that phase but only the "real" |   acknowledge the connection timeout during that phase but only the "real" | ||||||
|   | |||||||
| @@ -13,6 +13,7 @@ MAIL ETIQUETTE | |||||||
|   1.4 Subscription Required |   1.4 Subscription Required | ||||||
|   1.5 Moderation of new posters |   1.5 Moderation of new posters | ||||||
|   1.6 Handling trolls and spam |   1.6 Handling trolls and spam | ||||||
|  |   1.7 How to unsubscribe | ||||||
|  |  | ||||||
|  2. Sending mail |  2. Sending mail | ||||||
|   2.1 Reply or New Mail |   2.1 Reply or New Mail | ||||||
| @@ -110,6 +111,20 @@ MAIL ETIQUETTE | |||||||
|  |  | ||||||
|   Don't feed the trolls! |   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 | 2. Sending mail | ||||||
|  |  | ||||||
|   | |||||||
| @@ -328,7 +328,7 @@ POST (HTTP) | |||||||
|   If the content-type is not specified, curl will try to guess from the file |   If the content-type is not specified, curl will try to guess from the file | ||||||
|   extension (it only knows a few), or use the previously specified type (from |   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 |   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 |   Emulate a fill-in form with -F. Let's say you fill in three fields in a | ||||||
|   form. One field is a file name which to post, one field is your name and one |   form. One field is a file name which to post, one field is your name and one | ||||||
|   | |||||||
| @@ -22,9 +22,9 @@ | |||||||
|  |  | ||||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | AUTOMAKE_OPTIONS = foreign no-dependencies | ||||||
|  |  | ||||||
| man_MANS = curl.1 curl-config.1 | man_MANS = curl.1 curl-config.1 mk-ca-bundle.1 | ||||||
| GENHTMLPAGES = curl.html curl-config.html | GENHTMLPAGES = curl.html curl-config.html mk-ca-bundle.html | ||||||
| PDFPAGES = curl.pdf curl-config.pdf | PDFPAGES = curl.pdf curl-config.pdf mk-ca-bundle.pdf | ||||||
|  |  | ||||||
| HTMLPAGES = $(GENHTMLPAGES) index.html | 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! |  If you have contributed but are missing here, please let us know! | ||||||
|  |  | ||||||
| Aaron Oneal | Aaron Oneal | ||||||
|  | Aaron Orenstein | ||||||
| Adam D. Moss | Adam D. Moss | ||||||
| Adam Light | Adam Light | ||||||
| Adam Piggott | Adam Piggott | ||||||
|  | Adam Tkac | ||||||
| Adrian Schuur | Adrian Schuur | ||||||
|  | Adriano Meirelles | ||||||
| Akos Pasztory | Akos Pasztory | ||||||
| Alan Pinstein | Alan Pinstein | ||||||
|  | Albert Chin | ||||||
| Albert Chin-A-Young | Albert Chin-A-Young | ||||||
| Albert Choy | Albert Choy | ||||||
| Ale Vesely | Ale Vesely | ||||||
|  | Alejandro Alvarez | ||||||
| Aleksandar Milivojevic | Aleksandar Milivojevic | ||||||
|  | Alessandro Ghedini | ||||||
| Alessandro Vesely | Alessandro Vesely | ||||||
| Alex Bligh | Alex Bligh | ||||||
| Alex Fishman | Alex Fishman | ||||||
| Alex Neblett | Alex Neblett | ||||||
| Alex Suykov | Alex Suykov | ||||||
|  | Alex Vinnik | ||||||
| Alex aka WindEagle | Alex aka WindEagle | ||||||
| Alexander Beedie | Alexander Beedie | ||||||
| Alexander Kourakos | Alexander Kourakos | ||||||
| @@ -29,6 +36,7 @@ Alexander Zhuravlev | |||||||
| Alexey Borzov | Alexey Borzov | ||||||
| Alexey Pesternikov | Alexey Pesternikov | ||||||
| Alexey Simak | Alexey Simak | ||||||
|  | Alexey Zakhlestin | ||||||
| Alexis Carvalho | Alexis Carvalho | ||||||
| Alfred Gebert | Alfred Gebert | ||||||
| Allen Pulsifer | Allen Pulsifer | ||||||
| @@ -47,6 +55,7 @@ Andreas Rieke | |||||||
| Andreas Schuldei | Andreas Schuldei | ||||||
| Andreas Wurf | Andreas Wurf | ||||||
| Andrei Benea | Andrei Benea | ||||||
|  | Andrei Cipu | ||||||
| Andres Garcia | Andres Garcia | ||||||
| Andrew Benham | Andrew Benham | ||||||
| Andrew Biggs | Andrew Biggs | ||||||
| @@ -63,10 +72,12 @@ Andy Tsouladze | |||||||
| Angus Mackay | Angus Mackay | ||||||
| Anthony Bryan | Anthony Bryan | ||||||
| Antoine Calando | Antoine Calando | ||||||
|  | Anton Bychkov | ||||||
| Anton Kalmykov | Anton Kalmykov | ||||||
| Arkadiusz Miskiewicz | Arkadiusz Miskiewicz | ||||||
| Armel Asselin | Armel Asselin | ||||||
| Arnaud Ebalard | Arnaud Ebalard | ||||||
|  | Arthur Murray | ||||||
| Arve Knudsen | Arve Knudsen | ||||||
| Ates Goral | Ates Goral | ||||||
| Augustus Saunders | Augustus Saunders | ||||||
| @@ -80,9 +91,11 @@ Ben Greear | |||||||
| Ben Madsen | Ben Madsen | ||||||
| Ben Noordhuis | Ben Noordhuis | ||||||
| Ben Van Hof | Ben Van Hof | ||||||
|  | Ben Winslow | ||||||
| Benbuck Nason | Benbuck Nason | ||||||
| Benjamin Gerard | Benjamin Gerard | ||||||
| Bernard Leak | Bernard Leak | ||||||
|  | Bernhard Reutner-Fischer | ||||||
| Bertrand Demiddelaer | Bertrand Demiddelaer | ||||||
| Bill Egert | Bill Egert | ||||||
| Bill Hoffman | Bill Hoffman | ||||||
| @@ -97,6 +110,7 @@ Brad Burdick | |||||||
| Brad Hards | Brad Hards | ||||||
| Brad King | Brad King | ||||||
| Bradford Bruce | Bradford Bruce | ||||||
|  | Brandon Wang | ||||||
| Brendan Jurd | Brendan Jurd | ||||||
| Brent Beardsley | Brent Beardsley | ||||||
| Brian Akins | Brian Akins | ||||||
| @@ -113,7 +127,9 @@ Camille Moncelier | |||||||
| Caolan McNamara | Caolan McNamara | ||||||
| Carsten Lange | Carsten Lange | ||||||
| Casey O'Donnell | Casey O'Donnell | ||||||
|  | Cedric Deltheil | ||||||
| Chad Monroe | Chad Monroe | ||||||
|  | Chandrakant Bagul | ||||||
| Charles Kerr | Charles Kerr | ||||||
| Chih-Chung Chang | Chih-Chung Chang | ||||||
| Chris "Bob Bob" | Chris "Bob Bob" | ||||||
| @@ -125,6 +141,8 @@ Chris Gaukroger | |||||||
| Chris Maltby | Chris Maltby | ||||||
| Chris Mumford | Chris Mumford | ||||||
| Chris Smowton | Chris Smowton | ||||||
|  | Christian Grothoff | ||||||
|  | Christian Hagele | ||||||
| Christian Krause | Christian Krause | ||||||
| Christian Kurz | Christian Kurz | ||||||
| Christian Robottom Reis | Christian Robottom Reis | ||||||
| @@ -135,6 +153,7 @@ Christophe Legry | |||||||
| Christopher Conroy | Christopher Conroy | ||||||
| Christopher Palow | Christopher Palow | ||||||
| Christopher R. Palmer | Christopher R. Palmer | ||||||
|  | Christopher Stone | ||||||
| Ciprian Badescu | Ciprian Badescu | ||||||
| Claes Jakobsson | Claes Jakobsson | ||||||
| Clarence Gardner | Clarence Gardner | ||||||
| @@ -149,8 +168,10 @@ Craig A West | |||||||
| Craig Davison | Craig Davison | ||||||
| Craig Markwardt | Craig Markwardt | ||||||
| Cris Bailiff | Cris Bailiff | ||||||
|  | Cristian Rodriguez | ||||||
| Curt Bogmine | Curt Bogmine | ||||||
| Cyrill Osterwalder | Cyrill Osterwalder | ||||||
|  | Dagobert Michelsen | ||||||
| Damien Adant | Damien Adant | ||||||
| Dan Becker | Dan Becker | ||||||
| Dan C | Dan C | ||||||
| @@ -218,6 +239,7 @@ Dmitry Rechkin | |||||||
| Dolbneff A.V | Dolbneff A.V | ||||||
| Domenico Andreoli | Domenico Andreoli | ||||||
| Dominick Meglio | Dominick Meglio | ||||||
|  | Dominique Leuenberger | ||||||
| Doug Kaufman | Doug Kaufman | ||||||
| Doug Porter | Doug Porter | ||||||
| Douglas E. Wegscheid | Douglas E. Wegscheid | ||||||
| @@ -258,6 +280,7 @@ Erwin Authried | |||||||
| Eugene Kotlyarov | Eugene Kotlyarov | ||||||
| Evan Jordan | Evan Jordan | ||||||
| Eygene Ryabinkin | Eygene Ryabinkin | ||||||
|  | Fabian Hiernaux | ||||||
| Fabian Keil | Fabian Keil | ||||||
| Fabrizio Ammollo | Fabrizio Ammollo | ||||||
| Fedor Karpelevitch | Fedor Karpelevitch | ||||||
| @@ -270,11 +293,13 @@ Frank Keeney | |||||||
| Frank McGeough | Frank McGeough | ||||||
| Frank Meier | Frank Meier | ||||||
| Frank Ticheler | Frank Ticheler | ||||||
|  | Frank Van Uffelen | ||||||
| Fred Machado | Fred Machado | ||||||
| Fred New | Fred New | ||||||
| Fred Noz | Fred Noz | ||||||
| Frederic Lepied | Frederic Lepied | ||||||
| Gabriel Kuri | Gabriel Kuri | ||||||
|  | Garrett Holmstrom | ||||||
| Gary Maxwell | Gary Maxwell | ||||||
| Gautam Kachroo | Gautam Kachroo | ||||||
| Gautam Mani | Gautam Mani | ||||||
| @@ -298,6 +323,7 @@ Giuseppe Attardi | |||||||
| Giuseppe D'Ambrosio | Giuseppe D'Ambrosio | ||||||
| Glen Nakamura | Glen Nakamura | ||||||
| Glen Scott | Glen Scott | ||||||
|  | Gokhan Sengun | ||||||
| Grant Erickson | Grant Erickson | ||||||
| Greg Hewgill | Greg Hewgill | ||||||
| Greg Morse | Greg Morse | ||||||
| @@ -323,6 +349,7 @@ Heinrich Ko | |||||||
| Hendrik Visage | Hendrik Visage | ||||||
| Henrik Storner | Henrik Storner | ||||||
| Henry Ludemann | Henry Ludemann | ||||||
|  | Herve Amblard | ||||||
| Hidemoto Nakada | Hidemoto Nakada | ||||||
| Hoi-Ho Chan | Hoi-Ho Chan | ||||||
| Hongli Lai | Hongli Lai | ||||||
| @@ -364,6 +391,8 @@ Jan Kunder | |||||||
| Jan Van Boghout | Jan Van Boghout | ||||||
| Jared Lundell | Jared Lundell | ||||||
| Jari Sundell | Jari Sundell | ||||||
|  | Jason Glasgow | ||||||
|  | Jason Liu | ||||||
| Jason McDonald | Jason McDonald | ||||||
| Jason S. Priebe | Jason S. Priebe | ||||||
| Jay Austin | Jay Austin | ||||||
| @@ -384,11 +413,13 @@ Jeffrey Pohlmeyer | |||||||
| Jeremy Friesner | Jeremy Friesner | ||||||
| Jerome Muffat-Meridol | Jerome Muffat-Meridol | ||||||
| Jerome Vouillon | Jerome Vouillon | ||||||
|  | Jerry Wu | ||||||
| Jes Badwal | Jes Badwal | ||||||
| Jesper Jensen | Jesper Jensen | ||||||
| Jesse Noller | Jesse Noller | ||||||
| Jim Drash | Jim Drash | ||||||
| Jim Freeman | Jim Freeman | ||||||
|  | Jim Hollinger | ||||||
| Jim Meyering | Jim Meyering | ||||||
| Jocelyn Jaubert | Jocelyn Jaubert | ||||||
| Joe Halpin | Joe Halpin | ||||||
| @@ -398,11 +429,13 @@ Jofell Gallardo | |||||||
| Johan Anderson | Johan Anderson | ||||||
| Johan Nilsson | Johan Nilsson | ||||||
| Johan van Selst | Johan van Selst | ||||||
|  | Johannes Bauer | ||||||
| John Bradshaw | John Bradshaw | ||||||
| John Crow | John Crow | ||||||
| John Dennis | John Dennis | ||||||
| John E. Malmberg | John E. Malmberg | ||||||
| John Janssen | John Janssen | ||||||
|  | John Joseph Bachir | ||||||
| John Kelly | John Kelly | ||||||
| John Lask | John Lask | ||||||
| John Lightsey | John Lightsey | ||||||
| @@ -417,6 +450,7 @@ Jon Sargeant | |||||||
| Jon Travis | Jon Travis | ||||||
| Jon Turner | Jon Turner | ||||||
| Jonas Forsman | Jonas Forsman | ||||||
|  | Jonas Schnelli | ||||||
| Jonatan Lander | Jonatan Lander | ||||||
| Jonathan Hseu | Jonathan Hseu | ||||||
| Jongki Suwandi | Jongki Suwandi | ||||||
| @@ -425,6 +459,7 @@ Josef Wolf | |||||||
| Josh Kapell | Josh Kapell | ||||||
| Joshua Kwan | Joshua Kwan | ||||||
| Josue Andrade Gomes | Josue Andrade Gomes | ||||||
|  | Juan Barreto | ||||||
| Juan F. Codagnone | Juan F. Codagnone | ||||||
| Juan Ignacio Herv<72>s | Juan Ignacio Herv<72>s | ||||||
| Judson Bishop | Judson Bishop | ||||||
| @@ -432,6 +467,7 @@ Juergen Wilke | |||||||
| Jukka Pihl | Jukka Pihl | ||||||
| Julian Noble | Julian Noble | ||||||
| Julien Chaffraix | Julien Chaffraix | ||||||
|  | Julien Royer | ||||||
| Jun-ichiro itojun Hagino | Jun-ichiro itojun Hagino | ||||||
| Jurij Smakov | Jurij Smakov | ||||||
| Justin Fletcher | Justin Fletcher | ||||||
| @@ -503,18 +539,22 @@ Luke Call | |||||||
| Luong Dinh Dung | Luong Dinh Dung | ||||||
| Maciej Karpiuk | Maciej Karpiuk | ||||||
| Maciej W. Rozycki | Maciej W. Rozycki | ||||||
|  | Mamoru Tasaka | ||||||
|  | Mandy Wu | ||||||
| Manfred Schwarb | Manfred Schwarb | ||||||
| Manuel Massing | Manuel Massing | ||||||
| Marc Boucher | Marc Boucher | ||||||
| Marc Kleine-Budde | Marc Kleine-Budde | ||||||
| Marcel Roelofs | Marcel Roelofs | ||||||
| Marcelo Juchem | Marcelo Juchem | ||||||
|  | Marcin Adamski | ||||||
| Marcin Konicki | Marcin Konicki | ||||||
| Marco G. Salvagno | Marco G. Salvagno | ||||||
| Marco Maggi | Marco Maggi | ||||||
| Marcus Sundberg | Marcus Sundberg | ||||||
| Marcus Webster | Marcus Webster | ||||||
| Mario Schroeder | Mario Schroeder | ||||||
|  | Mark Brand | ||||||
| Mark Butler | Mark Butler | ||||||
| Mark Davies | Mark Davies | ||||||
| Mark Eichin | Mark Eichin | ||||||
| @@ -544,6 +584,7 @@ Matt Kraai | |||||||
| Matt Veenstra | Matt Veenstra | ||||||
| Matt Witherspoon | Matt Witherspoon | ||||||
| Matt Wixson | Matt Wixson | ||||||
|  | Matteo Rocco | ||||||
| Matthew Blain | Matthew Blain | ||||||
| Matthew Clarke | Matthew Clarke | ||||||
| Matthias Bolte | Matthias Bolte | ||||||
| @@ -552,6 +593,7 @@ Mauro Iorio | |||||||
| Max Katsev | Max Katsev | ||||||
| Maxim Ivanov | Maxim Ivanov | ||||||
| Maxim Perenesenko | Maxim Perenesenko | ||||||
|  | Maxim Prohorov | ||||||
| Mehmet Bozkurt | Mehmet Bozkurt | ||||||
| Mekonikum | Mekonikum | ||||||
| Mettgut Jamalla | Mettgut Jamalla | ||||||
| @@ -559,10 +601,12 @@ Michael Benedict | |||||||
| Michael Calmer | Michael Calmer | ||||||
| Michael Cronenworth | Michael Cronenworth | ||||||
| Michael Curtis | Michael Curtis | ||||||
|  | Michael Day | ||||||
| Michael Goffioul | Michael Goffioul | ||||||
| Michael Jahn | Michael Jahn | ||||||
| Michael Jerris | Michael Jerris | ||||||
| Michael Mealling | Michael Mealling | ||||||
|  | Michael Mueller | ||||||
| Michael Smith | Michael Smith | ||||||
| Michael Stillwell | Michael Stillwell | ||||||
| Michael Wallner | Michael Wallner | ||||||
| @@ -588,6 +632,7 @@ Moonesamy | |||||||
| Nathan Coulter | Nathan Coulter | ||||||
| Nathan O'Sullivan | Nathan O'Sullivan | ||||||
| Nathanael Nerode | Nathanael Nerode | ||||||
|  | Naveen Chandran | ||||||
| Naveen Noel | Naveen Noel | ||||||
| Neil Dunbar | Neil Dunbar | ||||||
| Neil Spring | Neil Spring | ||||||
| @@ -605,6 +650,7 @@ Nikita Schmidt | |||||||
| Nikitinskit Dmitriy | Nikitinskit Dmitriy | ||||||
| Niklas Angebrand | Niklas Angebrand | ||||||
| Nikolai Kondrashov | Nikolai Kondrashov | ||||||
|  | Nikos Mavrogiannopoulos | ||||||
| Ning Dong | Ning Dong | ||||||
| Nir Soffer | Nir Soffer | ||||||
| Nis Jorgensen | Nis Jorgensen | ||||||
| @@ -615,15 +661,19 @@ Ofer | |||||||
| Olaf Stueben | Olaf Stueben | ||||||
| Olaf St<53>ben | Olaf St<53>ben | ||||||
| Oren Tirosh | Oren Tirosh | ||||||
|  | Ori Avtalion | ||||||
| P R Schaffner | P R Schaffner | ||||||
|  | Paolo Piacentini | ||||||
| Pascal Terjan | Pascal Terjan | ||||||
| Pasha Kuznetsov | Pasha Kuznetsov | ||||||
| Pat Ray | Pat Ray | ||||||
|  | Patrice Guerin | ||||||
| Patrick Bihan-Faou | Patrick Bihan-Faou | ||||||
| Patrick Monnerat | Patrick Monnerat | ||||||
| Patrick Scott | Patrick Scott | ||||||
| Patrick Smith | Patrick Smith | ||||||
| Patrik Thunstrom | Patrik Thunstrom | ||||||
|  | Pau Garcia i Quiles | ||||||
| Paul Harrington | Paul Harrington | ||||||
| Paul Howarth | Paul Howarth | ||||||
| Paul Marquis | Paul Marquis | ||||||
| @@ -641,6 +691,7 @@ Pete Su | |||||||
| Peter Bray | Peter Bray | ||||||
| Peter Forret | Peter Forret | ||||||
| Peter Heuchert | Peter Heuchert | ||||||
|  | Peter Hjalmarsson | ||||||
| Peter Korsgaard | Peter Korsgaard | ||||||
| Peter Lamberg | Peter Lamberg | ||||||
| Peter O'Gorman | Peter O'Gorman | ||||||
| @@ -664,6 +715,7 @@ Philippe Vaucher | |||||||
| Pierre | Pierre | ||||||
| Pierre Brico | Pierre Brico | ||||||
| Pierre Joye | Pierre Joye | ||||||
|  | Pierre Ynard | ||||||
| Pooyan McSporran | Pooyan McSporran | ||||||
| Pramod Sharma | Pramod Sharma | ||||||
| Puneet Pawaia | Puneet Pawaia | ||||||
| @@ -690,6 +742,7 @@ Renaud Duhaut | |||||||
| Rene Bernhardt | Rene Bernhardt | ||||||
| Rene Rebe | Rene Rebe | ||||||
| Reuven Wachtfogel | Reuven Wachtfogel | ||||||
|  | Reza Arbab | ||||||
| Ricardo Cadime | Ricardo Cadime | ||||||
| Rich Gray | Rich Gray | ||||||
| Rich Rauenzahn | Rich Rauenzahn | ||||||
| @@ -700,16 +753,19 @@ Richard Clayton | |||||||
| Richard Cooper | Richard Cooper | ||||||
| Richard Gorton | Richard Gorton | ||||||
| Richard Prescott | Richard Prescott | ||||||
|  | Richard Silverman | ||||||
| Rick Jones | Rick Jones | ||||||
| Rick Richardson | Rick Richardson | ||||||
| Rob Crittenden | Rob Crittenden | ||||||
| Rob Jones | Rob Jones | ||||||
| Rob Stanzel | Rob Stanzel | ||||||
|  | Rob Ward | ||||||
| Robert A. Monat | Robert A. Monat | ||||||
| Robert D. Young | Robert D. Young | ||||||
| Robert Foreman | Robert Foreman | ||||||
| Robert Iakobashvili | Robert Iakobashvili | ||||||
| Robert Olson | Robert Olson | ||||||
|  | Robert Schumann | ||||||
| Robert Weaver | Robert Weaver | ||||||
| Robin Cornelius | Robin Cornelius | ||||||
| Robin Johnson | Robin Johnson | ||||||
| @@ -778,6 +834,8 @@ Stephen Kick | |||||||
| Stephen More | Stephen More | ||||||
| Sterling Hughes | Sterling Hughes | ||||||
| Steve Green | Steve Green | ||||||
|  | Steve H Truong | ||||||
|  | Steve Holme | ||||||
| Steve Lhomme | Steve Lhomme | ||||||
| Steve Little | Steve Little | ||||||
| Steve Marx | Steve Marx | ||||||
| @@ -786,6 +844,7 @@ Steve Roskowski | |||||||
| Steven Bazyl | Steven Bazyl | ||||||
| Steven G. Johnson | Steven G. Johnson | ||||||
| Steven M. Schweda | Steven M. Schweda | ||||||
|  | Steven Parkes | ||||||
| Stoned Elipot | Stoned Elipot | ||||||
| Sven Anders | Sven Anders | ||||||
| Sven Neuhaus | Sven Neuhaus | ||||||
| @@ -793,10 +852,12 @@ Sven Wegener | |||||||
| S<EFBFBD>bastien Willemijns | S<EFBFBD>bastien Willemijns | ||||||
| T. Bharath | T. Bharath | ||||||
| T. Yamada | T. Yamada | ||||||
|  | Taneli Vahakangas | ||||||
| Tanguy Fautre | Tanguy Fautre | ||||||
| Temprimus | Temprimus | ||||||
| Thomas J. Moore | Thomas J. Moore | ||||||
| Thomas Klausner | Thomas Klausner | ||||||
|  | Thomas L. Shinnick | ||||||
| Thomas Lopatic | Thomas Lopatic | ||||||
| Thomas Schwinge | Thomas Schwinge | ||||||
| Thomas Tonino | Thomas Tonino | ||||||
| @@ -805,6 +866,7 @@ Tim Baker | |||||||
| Tim Bartley | Tim Bartley | ||||||
| Tim Chen | Tim Chen | ||||||
| Tim Costello | Tim Costello | ||||||
|  | Tim Harder | ||||||
| Tim Newsome | Tim Newsome | ||||||
| Tim Sneddon | Tim Sneddon | ||||||
| Tinus van den Berg | Tinus van den Berg | ||||||
| @@ -812,6 +874,7 @@ Tobias Rundstr | |||||||
| Toby Peterson | Toby Peterson | ||||||
| Todd A Ouska | Todd A Ouska | ||||||
| Todd Kulesza | Todd Kulesza | ||||||
|  | Todd Ouska | ||||||
| Todd Vierling | Todd Vierling | ||||||
| Tom Benoist | Tom Benoist | ||||||
| Tom Donovan | Tom Donovan | ||||||
| @@ -820,6 +883,7 @@ Tom Mattison | |||||||
| Tom Moers | Tom Moers | ||||||
| Tom Mueller | Tom Mueller | ||||||
| Tom Regner | Tom Regner | ||||||
|  | Tom Wright | ||||||
| Tom Zerucha | Tom Zerucha | ||||||
| Tomas Pospisek | Tomas Pospisek | ||||||
| Tomas Szepe | Tomas Szepe | ||||||
| @@ -827,6 +891,7 @@ Tomasz Lacki | |||||||
| Tommie Gannert | Tommie Gannert | ||||||
| Tommy Tam | Tommy Tam | ||||||
| Ton Voon | Ton Voon | ||||||
|  | Toni Moreno | ||||||
| Toon Verwaest | Toon Verwaest | ||||||
| Tor Arntsen | Tor Arntsen | ||||||
| Torsten Foertsch | Torsten Foertsch | ||||||
| @@ -849,11 +914,13 @@ Vincent Sanders | |||||||
| Vincent Torri | Vincent Torri | ||||||
| Vlad Grachov | Vlad Grachov | ||||||
| Vlad Ureche | Vlad Ureche | ||||||
|  | Vladimir Grishchenko | ||||||
| Vladimir Lazarenko | Vladimir Lazarenko | ||||||
| Vojtech Janota | Vojtech Janota | ||||||
| Vojtech Minarik | Vojtech Minarik | ||||||
| Vsevolod Novikov | Vsevolod Novikov | ||||||
| Walter J. Mack | Walter J. Mack | ||||||
|  | Ward Willats | ||||||
| Wayne Haigh | Wayne Haigh | ||||||
| Werner Koch | Werner Koch | ||||||
| Wesley Laxton | Wesley Laxton | ||||||
| @@ -861,10 +928,12 @@ Wesley Miaw | |||||||
| Wez Furlong | Wez Furlong | ||||||
| Wilfredo Sanchez | Wilfredo Sanchez | ||||||
| Wojciech Zwiefka | Wojciech Zwiefka | ||||||
|  | Wu Yongzheng | ||||||
| Xavier Bouchoux | Xavier Bouchoux | ||||||
| Yang Tse | Yang Tse | ||||||
| Yarram Sunil | Yarram Sunil | ||||||
| Yehoshua Hershberg | Yehoshua Hershberg | ||||||
|  | Yukihiro Kawada | ||||||
| Yuriy Sosov | Yuriy Sosov | ||||||
| Yves Lejeune | Yves Lejeune | ||||||
| Zmey Petroff | Zmey Petroff | ||||||
|   | |||||||
							
								
								
									
										276
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										276
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -12,16 +12,16 @@ | |||||||
|  All bugs documented in the KNOWN_BUGS document are subject for fixing! |  All bugs documented in the KNOWN_BUGS document are subject for fixing! | ||||||
|  |  | ||||||
|  1. libcurl |  1. libcurl | ||||||
|  1.1 Zero-copy interface |  | ||||||
|  1.2 More data sharing |  1.2 More data sharing | ||||||
|  1.3 struct lifreq |  1.3 struct lifreq | ||||||
|  1.4 signal-based resolver timeouts |  1.4 signal-based resolver timeouts | ||||||
|  1.5 get rid of PATH_MAX |  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. libcurl - multi interface | ||||||
|  2.1 More non-blocking |  2.1 More non-blocking | ||||||
|  2.2 Remove easy interface internally |  2.2 Remove easy interface internally | ||||||
|  2.3 Avoid having to remove/readd handles |  | ||||||
|  2.4 Fix HTTP Pipelining for PUT |  2.4 Fix HTTP Pipelining for PUT | ||||||
|  |  | ||||||
|  3. Documentation |  3. Documentation | ||||||
| @@ -54,63 +54,69 @@ | |||||||
|  7.5 Export session ids |  7.5 Export session ids | ||||||
|  7.6 Provide callback for cert verification |  7.6 Provide callback for cert verification | ||||||
|  7.7 Support other SSL libraries |  7.7 Support other SSL libraries | ||||||
|  7.8  Support SRP on the TLS layer |  | ||||||
|  7.9 improve configure --with-ssl |  7.9 improve configure --with-ssl | ||||||
|  |  | ||||||
|  8. GnuTLS |  8. GnuTLS | ||||||
|  8.1 SSL engine stuff |  8.1 SSL engine stuff | ||||||
|  8.2 SRP |  | ||||||
|  8.3 check connection |  8.3 check connection | ||||||
|  8.4 non-gcrypt |  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. POP3 | ||||||
|  10.1 RSYNC |  10.1 APOP Authentication | ||||||
|  |  10.2 Other authentication mechanims | ||||||
|  |  10.3 auth= in URLs | ||||||
|   |   | ||||||
|  11. Client |  11. Other protocols | ||||||
|  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 |  | ||||||
|  |  | ||||||
|  12. Build |  12. New protocols | ||||||
|  12.1 roffit |  12.1 RSYNC | ||||||
|  |  | ||||||
|  13. Test suite |  13. Client | ||||||
|  13.1 SSL tunnel |  13.1 sync | ||||||
|  13.2 nicer lacking perl message |  13.2 glob posts | ||||||
|  13.3 more protocols supported |  13.3 prevent file overwriting | ||||||
|  13.4 more platforms supported |  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. Build | ||||||
|  14.1 http-style HEAD output for ftp |  14.1 roffit | ||||||
|  14.2 combine error codes |  | ||||||
|  14.3 extend CURLOPT_SOCKOPTFUNCTION prototype |  | ||||||
|  |  | ||||||
|  15. Next major release |  15. Test suite | ||||||
|  15.1 cleanup return codes |  15.1 SSL tunnel | ||||||
|  15.2 remove obsolete defines |  15.2 nicer lacking perl message | ||||||
|  15.3 size_t |  15.3 more protocols supported | ||||||
|  15.4 remove several functions |  15.4 more platforms supported | ||||||
|  15.5 remove CURLOPT_FAILONERROR |  | ||||||
|  15.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE |  16. Next SONAME bump | ||||||
|  15.7 remove progress meter from libcurl |  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. 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 | 1.2 More data sharing | ||||||
|  |  | ||||||
|  curl_share_* functions already exist and work, and they can be extended to |  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 |  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. |  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. libcurl - multi interface | ||||||
|  |  | ||||||
| 2.1 More non-blocking | 2.1 More non-blocking | ||||||
| @@ -153,7 +181,6 @@ | |||||||
|  |  | ||||||
|  - Name resolves on non-windows unless c-ares is used |  - Name resolves on non-windows unless c-ares is used | ||||||
|  - NSS SSL connections |  - NSS SSL connections | ||||||
|  - Active FTP connections |  | ||||||
|  - HTTP proxy CONNECT operations |  - HTTP proxy CONNECT operations | ||||||
|  - SOCKS proxy handshakes |  - SOCKS proxy handshakes | ||||||
|  - file:// transfers |  - file:// transfers | ||||||
| @@ -170,23 +197,6 @@ | |||||||
|  internally use and assume the multi interface. The select()-loop should use |  internally use and assume the multi interface. The select()-loop should use | ||||||
|  curl_multi_socket(). |  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 | 2.4 Fix HTTP Pipelining for PUT | ||||||
|  |  | ||||||
|  HTTP Pipelining can be a way to greatly enhance performance for multiple |  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 |  Make curl's SSL layer capable of using other free SSL libraries.  Such as | ||||||
|  MatrixSSL (http://www.matrixssl.org/). |  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 | 7.9 improve configure --with-ssl | ||||||
|  |  | ||||||
|  make the configure --with-ssl option first check for OpenSSL, then GnuTLS, |  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? |  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 | 8.3 check connection | ||||||
|  |  | ||||||
|  Add a way to check if the connection seems to be alive, to correspond to the |  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 |  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. |  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 | 9.2 Specify the preferred authentication mechanism | ||||||
|  most probably use an existing rsync library, such as librsync. |  | ||||||
|  |  | ||||||
| 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.com/feed[1-100].rss" or | ||||||
|  "curl --sync http://example.net/{index,calendar,history}.html" |  "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 |  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. |  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'. |  Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'. | ||||||
|  This is easily scripted though. |  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 |  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 |  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 |  existing). So that index.html becomes first index.html.1 and then | ||||||
|  index.html.2 etc. |  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 |  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 |  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 |  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 |  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 |  Extending the capabilities of the multipart formposting. How about leaving | ||||||
|  the ';type=foo' syntax as it is and adding an extra tag (headers) which |  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, |  which should overwrite the program reasonable defaults (plain/text, | ||||||
|  8bit...) |  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 |  Provide a way to make options bound to a specific URL among several on the | ||||||
|  command line. Possibly by letting ':' separate options between URLs, |  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. |  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 |  Add metalink support to curl (http://www.metalinker.org/). This is most useful | ||||||
|  with simultaneous parallel transfers (11.6) but not necessary. |  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. |   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 |   This can be useful to tell when support for a particular feature hasn't been | ||||||
|   compiled into the library. |   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 |  Consider extending 'roffit' to produce decent ASCII output, and use that | ||||||
|  instead of (g)nroff when building src/hugehelp.c |  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 |  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 |  and FTP-SSL tests without the stunnel dependency, and it could allow us to | ||||||
|  provide test tools built with either OpenSSL or GnuTLS |  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 |  If perl wasn't found by the configure script, don't attempt to run the tests | ||||||
|  but explain something nice why it doesn't. |  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 |  Extend the test suite to include more protocols. The telnet could just do ftp | ||||||
|  or http operations (for which we have test servers). |  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 |  Make the test suite work on more platforms. OpenBSD and Mac OS. Remove | ||||||
|  fork()s and it should become even more portable. |  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 |  #undef CURL_FTP_HTTPSTYLE_HEAD in lib/ftp.c to remove the HTTP-style headers | ||||||
|  from being output in NOBODY requests over ftp |  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 |  Combine some of the error codes to remove duplicates.  The original | ||||||
|  numbering should not be changed, and the old identifiers would be |  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_NOTFOUND => CURLE_REMOTE_FILE_NOT_FOUND | ||||||
|     CURLE_TFTP_PERM => CURLE_REMOTE_ACCESS_DENIED |     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 |  The current prototype only provides 'purpose' that tells what the | ||||||
|  connection/socket is for, but not any protocol or similar. It makes it hard |  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 |  for applications to differentiate on TCP vs UDP and even HTTP vs FTP and | ||||||
|  similar. |  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 |  curl_easy_cleanup() returns void, but curl_multi_cleanup() returns a | ||||||
|  CURLMcode. These should be changed to be the same. |  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 |  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 |  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: |  remove the following functions from the public API: | ||||||
|  |  | ||||||
| @@ -549,18 +602,18 @@ to provide the data to send. | |||||||
|  |  | ||||||
|  curl_multi_socket_all |  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 |  Remove support for CURLOPT_FAILONERROR, it has gotten too kludgy and weird | ||||||
|  internally. Let the app judge success or not for itself. |  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 |  Remove support for a global DNS cache. Anything global is silly, and we | ||||||
|  already offer the share interface for the same functionality but done |  already offer the share interface for the same functionality but done | ||||||
|  "right". |  "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. |  The internally provided progress meter output doesn't belong in the library. | ||||||
|  Basically no application wants it (apart from curl) but instead applications |  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 |  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 |  variable types passed to it instead of doubles so that big files work | ||||||
|  correctly. |  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: |  The version numbering is always built up using the same system: | ||||||
|  |  | ||||||
|         X.Y[.Z][-preN] |         X.Y[.Z] | ||||||
|  |  | ||||||
|  Where |  Where | ||||||
|    X is main version number |    X is main version number | ||||||
|    Y is release number |    Y is release number | ||||||
|    Z is patch 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 |  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 |  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 |  included in the version number. | ||||||
|  pre releases (they're never used in public, official, releases). |  | ||||||
|  |  | ||||||
|  The main version number will get bumped when *really* big, world colliding |  The main version number will get bumped when *really* big, world colliding | ||||||
|  changes are made. The release number is bumped when big changes are |  changes are made. The release number is bumped when changes are performed or | ||||||
|  performed. The patch number is bumped when the changes are mere bugfixes and |  things/features are added. The patch number is bumped when the changes are | ||||||
|  only minor feature changes. The pre-release is a counter, to identify which |  mere bugfixes. | ||||||
|  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. |  | ||||||
|  |  | ||||||
|  It means that after release 1.2.3, we can release 2.0 if something really big |  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 |  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 |  were fixed. | ||||||
|  for the brave people to try before the actual release. |  | ||||||
|  |  | ||||||
|  Bumping, as in increasing the number with 1, is unconditionally only |  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 |  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 |         #define LIBCURL_VERSION_NUM 0xXXYYZZ | ||||||
|  |  | ||||||
|  Where XX, YY and ZZ are the main version, release and patch numbers in |  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 |  hexadecimal. All three number fields are always represented using two digits | ||||||
|  would appear as "0x010200" while version 9.11.7 appears as "0x090b07". |  (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 |  This 6-digit hexadecimal number is always a greater number in a more recent | ||||||
|  always a greater number in a more recent release. It makes comparisons with |  release. It makes comparisons with greater than and less than work. | ||||||
|  greater than and less than work. |  | ||||||
|  |  | ||||||
|  This number is also available as three separate defines: |  This number is also available as three separate defines: | ||||||
|  LIBCURL_VERSION_MAJOR, LIBCURL_VERSION_MINOR and LIBCURL_VERSION_PATCH. |  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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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? | 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" | .SH "SEE ALSO" | ||||||
| .BR curl (1) | .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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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 | .SH NAME | ||||||
| curl \- transfer a URL | curl \- transfer a URL | ||||||
| .SH SYNOPSIS | .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 | 7.19.0. Previously most options were toggled on/off on repeated use of the | ||||||
| same command line option.) | same command line option.) | ||||||
| .IP "-#, --progress-bar" | .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" | .IP "-0, --http1.0" | ||||||
| (HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its | (HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its | ||||||
| internally preferred: HTTP 1.1. | 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 | file format. If you set the file name to a single dash, "-", the cookies will | ||||||
| be written to stdout. | 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 | 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 | won't fail or even report an error clearly. Using -v will get a warning | ||||||
| displayed, but that is the only visible feedback you get about this possibly | displayed, but that is the only visible feedback you get about this possibly | ||||||
| @@ -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 | sign appended, resulting in \fIname=urlencoded-file-content\fP. Note that the | ||||||
| name is expected to be URL-encoded already. | name is expected to be URL-encoded already. | ||||||
| .RE | .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" | .IP "--digest" | ||||||
| (HTTP) Enables HTTP Digest authentication. This is a authentication that | (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 | 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, | transfers. Curl will normally always first attempt to use EPSV before PASV, | ||||||
| but with this option, it will not try using EPSV. | but with this option, it will not try using EPSV. | ||||||
|  |  | ||||||
| \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. | is an alias for \fB--disable-epsv\fP. | ||||||
|  |  | ||||||
| Disabling EPSV only changes the passive behavior. If you want to switch to | 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. | If this option is used several times, the last one will be used. | ||||||
| .IP "--capath <CA certificate directory>" | .IP "--capath <CA certificate directory>" | ||||||
| (SSL) Tells curl to use the specified certificate directory to verify the | (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 | peer. Multiple paths can be provided by separating them with ":" (e.g. | ||||||
| OpenSSL, the directory must have been processed using the c_rehash utility | \&"path1:path2:path3"). The certificates must be in PEM format, and if curl is | ||||||
| supplied with OpenSSL. Using \fI--capath\fP can allow OpenSSL-powered curl to | built against OpenSSL, the directory must have been processed using the | ||||||
| make SSL-connections much more efficiently than using \fI--cacert\fP if the | c_rehash utility supplied with OpenSSL. Using \fI--capath\fP can allow | ||||||
| \fI--cacert\fP file contains many CA certificates. | 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" | .IP "-f, --fail" | ||||||
| (HTTP) Fail silently (no output at all) on server errors. This is mostly done | (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 | 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 | trickier stuff than curl would normally do. You should not replace internally | ||||||
| set headers without knowing perfectly well what you're doing. Remove an | 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 | 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 | 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 | 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 | 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) | 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>" | .IP "--key <key>" | ||||||
| (SSL/SSH) Private key file name. Allows you to provide your private key in this | (SSL/SSH) Private key file name. Allows you to provide your private key in this | ||||||
| separate file. | 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. | re-send the following request using the same unmodified method. | ||||||
| .IP "--libcurl <file>" | .IP "--libcurl <file>" | ||||||
| Append this option to any ordinary curl command line, and you will get a | 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! | 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 | If this option is used several times, the last given file name will be | ||||||
| used. (Added in 7.16.1) | used. (Added in 7.16.1) | ||||||
| .IP "--limit-rate <speed>" | .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. | 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. | 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>" | .IP "--mail-from <address>" | ||||||
| (SMTP) Specify a single address that the given mail should get sent from. | (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. | default config file search path. | ||||||
| .IP "-Q, --quote <command>" | .IP "-Q, --quote <command>" | ||||||
| (FTP/SFTP) Send an arbitrary command to the remote FTP or SFTP server. Quote | (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 | commands are sent BEFORE the transfer takes place (just after the initial PWD | ||||||
| initial PWD command in an FTP transfer, to be exact). To make commands | command in an FTP transfer, to be exact). To make commands take place after a | ||||||
| take place after a successful transfer, prefix them with a dash '-'. | successful transfer, prefix them with a dash '-'.  To make commands be sent | ||||||
| To make commands be sent after libcurl has changed the working directory, | after libcurl has changed the working directory, just before the transfer | ||||||
| just before the transfer command(s), prefix the command with a '+' (this | command(s), prefix the command with a '+' (this is only supported for | ||||||
| is only supported for FTP). You may specify any number of commands. If | FTP). You may specify any number of commands. If the server returns failure | ||||||
| the server returns failure for one of the commands, the entire operation | for one of the commands, the entire operation will be aborted. You must send | ||||||
| will be aborted. You must send syntactically correct FTP commands as | syntactically correct FTP commands as RFC 959 defines to FTP servers, or one | ||||||
| RFC 959 defines to FTP servers, or one of the commands listed below to | of the commands listed below to SFTP servers.  This option can be used | ||||||
| SFTP servers.  This option can be used multiple times. | 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 | 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 | 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 | 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. | 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]>" | .IP "--socks4 <host[:port]>" | ||||||
| Use the specified SOCKS4 proxy. If the port number is not specified, it is | Use the specified SOCKS4 proxy. If the port number is not specified, it is | ||||||
| assumed at port 1080. (Added in 7.15.2) | 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 | This option overrides any previous use of \fI-x, --proxy\fP, as they are | ||||||
| mutually exclusive. | mutually exclusive. | ||||||
|  |  | ||||||
| Since 7.21.7, this option is superfluous since you can specify a | Since 7.21.7, this option is superfluous since you can specify a socks5 | ||||||
| socks5-hostnamae proxy with \fI-x, --proxy\fP using a socks5h:// protocol | hostname proxy with \fI-x, --proxy\fP using a socks5h:// protocol prefix. | ||||||
| prefix. |  | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. (This option | 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 | 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). | unprotected exchange of the protection mode negotiation. (Added in 7.19.4). | ||||||
| .IP "--stderr <file>" | .IP "--stderr <file>" | ||||||
| Redirect all writes to stderr to the specified file instead. If the file name | 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 | is a plain '-', it is instead written to stdout. | ||||||
| you're using a shell with decent redirecting capabilities. |  | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "-t, --telnet-option <OPT=val>" | .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 | The URL that was fetched last. This is most meaningful if you've told curl | ||||||
| to follow location: headers. | to follow location: headers. | ||||||
| .TP | .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 | .B http_code | ||||||
| The numerical response code that was found in the last retrieved HTTP(S) or | 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 | 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 | .RE | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .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 | Use the specified HTTP proxy. If the port number is not specified, it is | ||||||
| assumed at port 1080. | 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 | not be available. This is not the case if you can tunnel through the proxy, as | ||||||
| one with the \fI-p, --proxytunnel\fP option. | 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 | The proxy host can be specified the exact same way as the proxy environment | ||||||
| variables, including the protocol prefix (http://) and the embedded user + | variables, including the protocol prefix (http://) and the embedded user + | ||||||
| password. | password. | ||||||
| @@ -1576,6 +1614,14 @@ Specifies a custom FTP command to use instead of LIST when doing file lists | |||||||
| with FTP. | with FTP. | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
|  |  | ||||||
|  | .IP "--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>" | .IP "-y, --speed-time <time>" | ||||||
| If a download is slower than speed-limit bytes per second during a speed-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 | 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. | not set. | ||||||
|  |  | ||||||
| If this option is used several times, the last one will be used. | If this option is used several times, the last one will be used. | ||||||
| .IP "-z, --time-cond <date expression>" | .IP "-z/--time-cond <date expression>|<file>" | ||||||
| (HTTP/FTP/FILE) Request a file that has been modified later than the given time | (HTTP/FTP) Request a file that has been modified later than the given time and | ||||||
| and date, or one that has been modified before that time. The date expression | date, or one that has been modified before that time. The <date expression> can | ||||||
| can be all sorts of date strings or if it doesn't match any internal ones, it | be all sorts of date strings or if it doesn't match any internal ones, it is | ||||||
| tries to get the time from a given file name instead! See the | taken as a filename and tries to get the modification date (mtime) from <file> | ||||||
| \fIcurl_getdate(3)\fP man pages for date expression details. | 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 | Start the date expression with a dash (-) to make it request for a document | ||||||
| that is older than the given date/time, default is a document that is newer | that is older than the given date/time, default is a document that is newer | ||||||
| @@ -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 | 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 | lower case version has precedence. http_proxy is an exception as it is only | ||||||
| available in lower case. | 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]" | .IP "http_proxy [protocol://]<host>[:port]" | ||||||
| Sets the proxy server to use for HTTP. | Sets the proxy server to use for HTTP. | ||||||
| .IP "HTTPS_PROXY [protocol://]<host>[:port]" | .IP "HTTPS_PROXY [protocol://]<host>[:port]" | ||||||
| Sets the proxy server to use for HTTPS. | Sets the proxy server to use for HTTPS. | ||||||
| .IP "FTP_PROXY [protocol://]<host>[:port]" | .IP "[url-protocol]_PROXY [protocol://]<host>[:port]" | ||||||
| Sets the proxy server to use for FTP. | 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]" | .IP "ALL_PROXY [protocol://]<host>[:port]" | ||||||
| Sets the proxy server to use if no protocol-specific proxy is set. | Sets the proxy server to use if no protocol-specific proxy is set. | ||||||
| .IP "NO_PROXY <comma-separated list of hosts>" | .IP "NO_PROXY <comma-separated list of hosts>" | ||||||
| list of host names that shouldn't go through any proxy. If set to a asterisk | list of host names that shouldn't go through any proxy. If set to a asterisk | ||||||
| \&'*' only, it matches all hosts. | \&'*' 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 | If no protocol is specified in the proxy string or if the string doesn't match | ||||||
| specify alternative proxy protocols. Use socks4://, socks4a:// or socks5:// to | a supported one, the proxy will be treated as a HTTP proxy. | ||||||
| request the specific SOCKS version to be used. No protocol specified, http:// |  | ||||||
| and all others will be treated as HTTP proxies. | 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 | .SH EXIT CODES | ||||||
| There are a bunch of different error codes and their corresponding error | 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, | 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" | .SH "SEE ALSO" | ||||||
| .BR ftp (1), | .BR ftp (1), | ||||||
| .BR wget (1) | .BR wget (1) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -4,6 +4,7 @@ certinfo | |||||||
| chkspeed | chkspeed | ||||||
| cookie_interface | cookie_interface | ||||||
| debug | debug | ||||||
|  | externalsocket | ||||||
| fileupload | fileupload | ||||||
| fopen | fopen | ||||||
| ftp-wildcard | ftp-wildcard | ||||||
| @@ -17,14 +18,20 @@ http-post | |||||||
| httpcustomheader | httpcustomheader | ||||||
| httpput | httpput | ||||||
| https | https | ||||||
|  | imap | ||||||
| multi-app | multi-app | ||||||
| multi-debugcallback | multi-debugcallback | ||||||
| multi-double | multi-double | ||||||
| multi-post | multi-post | ||||||
| multi-single | multi-single | ||||||
| persistant | persistant | ||||||
|  | pop3s | ||||||
|  | pop3slist | ||||||
| post-callback | post-callback | ||||||
| postit2 | postit2 | ||||||
|  | progressfunc | ||||||
|  | resolve | ||||||
|  | rtsp | ||||||
| sendrecv | sendrecv | ||||||
| sepheaders | sepheaders | ||||||
| simple | simple | ||||||
| @@ -33,3 +40,4 @@ simplesmtp | |||||||
| simplessl | simplessl | ||||||
| smtp-multi | smtp-multi | ||||||
| smtp-tls | 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 | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # you should have received as part of this distribution. The terms | ||||||
| @@ -23,7 +23,7 @@ | |||||||
| AUTOMAKE_OPTIONS = foreign nostdinc | AUTOMAKE_OPTIONS = foreign nostdinc | ||||||
|  |  | ||||||
| EXTRA_DIST = README Makefile.example Makefile.inc Makefile.m32 \ | 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 | # 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 | # $(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 | LIBDIR = $(top_builddir)/lib | ||||||
|  |  | ||||||
| if STATICLIB | AM_CPPFLAGS = -DCURL_NO_OLDIES | ||||||
| # we need this define when building with a static lib on Windows |  | ||||||
| STATICCPPFLAGS = -DCURL_STATICLIB |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| 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 | # Dependencies | ||||||
| LDADD = $(LIBDIR)/libcurl.la | 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 \ |   https multi-app multi-debugcallback multi-double multi-post multi-single \ | ||||||
|   persistant post-callback postit2 sepheaders simple simplepost simplessl  \ |   persistant post-callback postit2 sepheaders simple simplepost simplessl  \ | ||||||
|   sendrecv httpcustomheader certinfo chkspeed ftpgetinfo ftp-wildcard \ |   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 | # These examples require external dependencies that may not be commonly | ||||||
| # available on POSIX systems, so don't bother attempting to compile them here. | # available on POSIX systems, so don't bother attempting to compile them here. | ||||||
|   | |||||||
| @@ -19,31 +19,50 @@ | |||||||
| # KIND, either express or implied. | # KIND, either express or implied. | ||||||
| # | # | ||||||
| ########################################################################### | ########################################################################### | ||||||
| ######################################################################### |  | ||||||
| # | # | ||||||
| ## Makefile for building curl examples with MingW32 | ## Makefile for building curl examples with MingW (GCC-3.2 or later) | ||||||
| ## and optionally OpenSSL (0.9.8), libssh2 (0.18), zlib (1.2.3) | ## and optionally OpenSSL (0.9.8), libssh2 (1.3), zlib (1.2.5), librtmp (2.3) | ||||||
| ## | ## | ||||||
| ## Usage: | ## Usage:   mingw32-make -f Makefile.m32 CFG=-feature1[-feature2][-feature3][...] | ||||||
| ## mingw32-make -f Makefile.m32 [SSL=1] [SSH2=1] [ZLIB=1] [SSPI=1] [IPV6=1] [DYN=1] | ## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-spi-winidn | ||||||
| ## | ## | ||||||
| ## Hint: you can also set environment vars to control the build, f.e.: | ## 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 | ## set ZLIB=1 | ||||||
| ## | # | ||||||
| ######################################################################### | ########################################################################### | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your Zlib sources. | # Edit the path below to point to the base of your Zlib sources. | ||||||
| ifndef ZLIB_PATH | ifndef ZLIB_PATH | ||||||
| ZLIB_PATH = ../../zlib-1.2.3 | ZLIB_PATH = ../../../zlib-1.2.7 | ||||||
| endif | endif | ||||||
| # Edit the path below to point to the base of your OpenSSL package. | # Edit the path below to point to the base of your OpenSSL package. | ||||||
| ifndef OPENSSL_PATH | 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 | endif | ||||||
| # Edit the path below to point to the base of your LibSSH2 package. | # Edit the path below to point to the base of your LibSSH2 package. | ||||||
| ifndef LIBSSH2_PATH | 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 | endif | ||||||
| # Edit the path below to point to the base of your Novell LDAP NDK. | # Edit the path below to point to the base of your Novell LDAP NDK. | ||||||
| ifndef LDAP_SDK | ifndef LDAP_SDK | ||||||
| @@ -51,25 +70,76 @@ LDAP_SDK = c:/novell/ndk/cldapsdk/win32 | |||||||
| endif | endif | ||||||
|  |  | ||||||
| PROOT = ../.. | PROOT = ../.. | ||||||
| ARES_LIB = $(PROOT)/ares |  | ||||||
|  |  | ||||||
| SSL = 1 | # Edit the path below to point to the base of your c-ares package. | ||||||
| ZLIB = 1 | 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 | CC = gcc | ||||||
| CFLAGS = -g -O2 -Wall | CFLAGS = -g -O2 -Wall | ||||||
|  | CFLAGS += -fno-strict-aliasing | ||||||
|  | ifeq ($(ARCH),w64) | ||||||
|  | CFLAGS += -D_AMD64_ | ||||||
|  | endif | ||||||
| # comment LDFLAGS below to keep debug info | # comment LDFLAGS below to keep debug info | ||||||
| LDFLAGS = -s | LDFLAGS = -s | ||||||
| RC = windres | RC = windres | ||||||
| RCFLAGS = --include-dir=$(PROOT)/include -O COFF -i | RCFLAGS = --include-dir=$(PROOT)/include -O COFF -i | ||||||
| RM = del /q /f > NUL 2>&1 |  | ||||||
|  | RM = del /q /f 2>NUL | ||||||
| CP = copy | CP = copy | ||||||
|  |  | ||||||
| ######################################################## | ######################################################## | ||||||
| ## Nothing more to do below this line! | ## 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 | INCLUDES = -I. -I$(PROOT) -I$(PROOT)/include -I$(PROOT)/lib | ||||||
| LINK = $(CC) $(LDFLAGS) -o $@ |  | ||||||
|  |  | ||||||
| ifdef DYN | ifdef DYN | ||||||
|   curl_DEPENDENCIES = $(PROOT)/lib/libcurldll.a $(PROOT)/lib/libcurl.dll |   curl_DEPENDENCIES = $(PROOT)/lib/libcurldll.a $(PROOT)/lib/libcurl.dll | ||||||
| @@ -81,34 +151,45 @@ else | |||||||
| endif | endif | ||||||
| ifdef ARES | ifdef ARES | ||||||
|   ifndef DYN |   ifndef DYN | ||||||
|     curl_DEPENDENCIES += $(ARES_LIB)/libcares.a |     curl_DEPENDENCIES += $(LIBCARES_PATH)/libcares.a | ||||||
|   endif |   endif | ||||||
|   CFLAGS += -DUSE_ARES |   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 | endif | ||||||
| ifdef SSH2 | ifdef SSH2 | ||||||
|   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H |   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H | ||||||
|   curl_LDADD += -L$(LIBSSH2_PATH)/win32 -lssh2 |   curl_LDADD += -L"$(LIBSSH2_PATH)/win32" -lssh2 | ||||||
| endif | endif | ||||||
| ifdef SSL | ifdef SSL | ||||||
|   INCLUDES += -I"$(OPENSSL_PATH)/outinc" |  | ||||||
|   CFLAGS += -DUSE_SSLEAY -DHAVE_OPENSSL_ENGINE_H |   CFLAGS += -DUSE_SSLEAY -DHAVE_OPENSSL_ENGINE_H | ||||||
|   ifdef DYN |   curl_LDADD += -L"$(OPENSSL_LIBPATH)" $(OPENSSL_LIBS) | ||||||
|     curl_LDADD += -L$(OPENSSL_PATH)/out -leay32 -lssl32 |  | ||||||
|   else |  | ||||||
|     curl_LDADD += -L$(OPENSSL_PATH)/out -lssl -lcrypto -lgdi32 |  | ||||||
|   endif |  | ||||||
| endif | endif | ||||||
| ifdef ZLIB | ifdef ZLIB | ||||||
|   INCLUDES += -I"$(ZLIB_PATH)" |   INCLUDES += -I"$(ZLIB_PATH)" | ||||||
|   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H |   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 | endif | ||||||
| ifdef SSPI | ifdef SSPI | ||||||
|   CFLAGS += -DUSE_WINDOWS_SSPI |   CFLAGS += -DUSE_WINDOWS_SSPI | ||||||
| endif | endif | ||||||
|  | ifdef SPNEGO | ||||||
|  |   CFLAGS += -DHAVE_SPNEGO | ||||||
|  | endif | ||||||
| ifdef IPV6 | ifdef IPV6 | ||||||
|   CFLAGS += -DENABLE_IPV6 |   CFLAGS += -DENABLE_IPV6 -D_WIN32_WINNT=0x0501 | ||||||
| endif | endif | ||||||
| ifdef LDAPS | ifdef LDAPS | ||||||
|   CFLAGS += -DHAVE_LDAP_SSL |   CFLAGS += -DHAVE_LDAP_SSL | ||||||
| @@ -123,32 +204,32 @@ ifdef USE_LDAP_OPENLDAP | |||||||
| endif | endif | ||||||
| ifndef USE_LDAP_NOVELL | ifndef USE_LDAP_NOVELL | ||||||
| ifndef USE_LDAP_OPENLDAP | ifndef USE_LDAP_OPENLDAP | ||||||
| curl_LDADD += -lwldap32 |   curl_LDADD += -lwldap32 | ||||||
| endif | endif | ||||||
| endif | endif | ||||||
| curl_LDADD += -lws2_32 | curl_LDADD += -lws2_32 | ||||||
| COMPILE = $(CC) $(INCLUDES) $(CFLAGS) |  | ||||||
|  |  | ||||||
| # Makefile.inc provides the check_PROGRAMS and COMPLICATED_EXAMPLES defines | # Makefile.inc provides the check_PROGRAMS and COMPLICATED_EXAMPLES defines | ||||||
| include Makefile.inc | include Makefile.inc | ||||||
|  |  | ||||||
| example_PROGRAMS := $(patsubst %,%.exe,$(strip $(check_PROGRAMS))) | check_PROGRAMS := $(patsubst %,%.exe,$(strip $(check_PROGRAMS))) | ||||||
|  | check_PROGRAMS += ftpuploadresume.exe synctime.exe | ||||||
| .SUFFIXES: .rc .res .o .exe |  | ||||||
|  |  | ||||||
|  |  | ||||||
| all: $(example_PROGRAMS) | all: $(check_PROGRAMS) | ||||||
|  |  | ||||||
| .o.exe: $(curl_DEPENDENCIES) | %.exe: %.o $(curl_DEPENDENCIES) | ||||||
| 	$(LINK) $< $(curl_LDADD) | 	$(CC) $(LDFLAGS) -o $@ $< $(curl_LDADD) | ||||||
|  |  | ||||||
| .c.o: | %.o: %.c | ||||||
| 	$(COMPILE) -c $< | 	$(CC) $(INCLUDES) $(CFLAGS) -c $< | ||||||
|  |  | ||||||
| .rc.res: | %.res: %.rc | ||||||
| 	$(RC) $(RCFLAGS) $< -o $@ | 	$(RC) $(RCFLAGS) $< -o $@ | ||||||
|  |  | ||||||
| clean: | 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 | http-post.c    - HTTP POST | ||||||
| httpput.c      - HTTP PUT a local file | httpput.c      - HTTP PUT a local file | ||||||
| https.c        - simple HTTPS transfer | https.c        - simple HTTPS transfer | ||||||
|  | imap.c         - simple IMAP transfer | ||||||
| multi-app.c    - a multi-interface app | multi-app.c    - a multi-interface app | ||||||
| multi-debugcallback.c - a multi-interface app using the debug callback | multi-debugcallback.c - a multi-interface app using the debug callback | ||||||
| multi-double.c - a multi-interface app doing two simultaneous transfers | 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 | multithread.c  - an example using multi-treading transferring multiple files | ||||||
| opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded | opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded | ||||||
| persistant.c   - request two URLs with a persistent connection | 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 | post-callback.c - send a HTTP POST using a callback | ||||||
| postit2.c      - send a HTTP multipart formpost | postit2.c      - send a HTTP multipart formpost | ||||||
| sampleconv.c   - showing how a program on a non-ASCII platform would invoke | 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 | simplepost.c   - HTTP POST | ||||||
| simplessl.c    - HTTPS example with certificates many options set | simplessl.c    - HTTPS example with certificates many options set | ||||||
| synctime.c     - Sync local time by extracting date from remote HTTP servers | 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. | 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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -27,6 +27,7 @@ | |||||||
| #  ifdef __VMS | #  ifdef __VMS | ||||||
|      typedef int intptr_t; |      typedef int intptr_t; | ||||||
| #  endif | #  endif | ||||||
|  | #  include <stdint.h> | ||||||
| #  include <unistd.h> | #  include <unistd.h> | ||||||
| #endif | #endif | ||||||
| #include <sys/types.h> | #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) | static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||||
| { | { | ||||||
|   size_t retcode; |   size_t retcode; | ||||||
|  |   curl_off_t nread; | ||||||
|  |  | ||||||
|   intptr_t fd = (intptr_t)stream; |   intptr_t fd = (intptr_t)stream; | ||||||
|  |  | ||||||
|   retcode = read(fd, ptr, size * nmemb); |   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; |   return retcode; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -22,8 +22,6 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #include <curl/curl.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) | static size_t wrfu(void *ptr,  size_t  size,  size_t  nmemb,  void *stream) | ||||||
| { | { | ||||||
|   | |||||||
| @@ -35,8 +35,6 @@ | |||||||
| #include <time.h> | #include <time.h> | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
| #include <curl/types.h> |  | ||||||
| #include <curl/easy.h> |  | ||||||
|  |  | ||||||
| #define URL_BASE "http://speedtest.your.domain/" | #define URL_BASE "http://speedtest.your.domain/" | ||||||
| #define URL_1M   URL_BASE "file_1M.bin" | #define URL_1M   URL_BASE "file_1M.bin" | ||||||
|   | |||||||
| @@ -13,8 +13,6 @@ | |||||||
| #include <gtk/gtk.h> | #include <gtk/gtk.h> | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
| #include <curl/types.h> /* new for v7 */ |  | ||||||
| #include <curl/easy.h> /* new for v7 */ |  | ||||||
|  |  | ||||||
| GtkWidget *Bar; | 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_cipher_list(ctx,"RC4-MD5"); | ||||||
|   SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY); |   SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY); | ||||||
|  |  | ||||||
|   X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca, |   X509_STORE_add_cert(SSL_CTX_get_cert_store(ctx), sk_X509_value(p->ca, sk_X509_num(p->ca)-1)); | ||||||
|                                                     sk_X509_num(p->ca)-1)); |  | ||||||
|  |  | ||||||
|   SSL_CTX_set_verify_depth(ctx,2); |   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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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 long file_is_downloaded(struct callback_data *data); | ||||||
|  |  | ||||||
| static size_t write_it(char *buff, size_t size, size_t nmemb, | 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) | 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, | 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; |   size_t written = 0; | ||||||
|   if(data->output) |   if(data->output) | ||||||
|     written = fwrite(buff, size, nmemb, data->output); |     written = fwrite(buff, size, nmemb, data->output); | ||||||
|   | |||||||
| @@ -22,8 +22,6 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #include <curl/curl.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. |  * This is an example showing how to get a single file from an FTP server. | ||||||
|   | |||||||
| @@ -23,8 +23,6 @@ | |||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
| #include <curl/curl.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 |  * This is an example showing how to check a single file's size and mtime | ||||||
|   | |||||||
| @@ -22,8 +22,6 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #include <curl/curl.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 |  * 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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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. */ |    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) | 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 |   /* in real-world cases, this would probably get this data differently | ||||||
|      as this fread() stuff is exactly what the library already would do |      as this fread() stuff is exactly what the library already would do | ||||||
|      by default internally */ |      by default internally */ | ||||||
|   size_t retcode = fread(ptr, size, nmemb, stream); |   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; |   return retcode; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ | |||||||
|  |  | ||||||
| /* The MinGW headers are missing a few Win32 function definitions, | /* The MinGW headers are missing a few Win32 function definitions, | ||||||
|    you shouldn't need this if you use VC++ */ |    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, ...); | int __cdecl _snscanf(const char * input, size_t length, const char * format, ...); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -36,10 +36,10 @@ struct MemoryStruct { | |||||||
|  |  | ||||||
|  |  | ||||||
| static size_t | 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; |   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); |   mem->memory = realloc(mem->memory, mem->size + realsize + 1); | ||||||
|   if (mem->memory == NULL) { |   if (mem->memory == NULL) { | ||||||
| @@ -48,7 +48,7 @@ WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) | |||||||
|     exit(EXIT_FAILURE); |     exit(EXIT_FAILURE); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   memcpy(&(mem->memory[mem->size]), ptr, realsize); |   memcpy(&(mem->memory[mem->size]), contents, realsize); | ||||||
|   mem->size += realsize; |   mem->size += realsize; | ||||||
|   mem->memory[mem->size] = 0; |   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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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) | static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||||
| { | { | ||||||
|   size_t retcode; |   size_t retcode; | ||||||
|  |   curl_off_t nread; | ||||||
|  |  | ||||||
|   /* in real-world cases, this would probably get this data differently |   /* in real-world cases, this would probably get this data differently | ||||||
|      as this fread() stuff is exactly what the library already would do |      as this fread() stuff is exactly what the library already would do | ||||||
|      by default internally */ |      by default internally */ | ||||||
|   retcode = fread(ptr, size, nmemb, stream); |   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; |   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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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 { | struct WriteThis { | ||||||
|   const char *readptr; |   const char *readptr; | ||||||
|   int sizeleft; |   long sizeleft; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp) | static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp) | ||||||
| @@ -96,7 +96,7 @@ int main(void) | |||||||
| #else | #else | ||||||
|     /* Set the expected POST size. If you want to POST large amounts of data, |     /* Set the expected POST size. If you want to POST large amounts of data, | ||||||
|        consider CURLOPT_POSTFIELDSIZE_LARGE */ |        consider CURLOPT_POSTFIELDSIZE_LARGE */ | ||||||
|     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (curl_off_t)pooh.sizeleft); |     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef DISABLE_EXPECT | #ifdef DISABLE_EXPECT | ||||||
|   | |||||||
| @@ -37,8 +37,6 @@ | |||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
| #include <curl/types.h> |  | ||||||
| #include <curl/easy.h> |  | ||||||
|  |  | ||||||
| int main(int argc, char *argv[]) | 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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -64,6 +64,7 @@ int main(void) | |||||||
|   curl_socket_t sockfd; /* socket */ |   curl_socket_t sockfd; /* socket */ | ||||||
|   long sockextr; |   long sockextr; | ||||||
|   size_t iolen; |   size_t iolen; | ||||||
|  |   curl_off_t nread; | ||||||
|  |  | ||||||
|   curl = curl_easy_init(); |   curl = curl_easy_init(); | ||||||
|   if(curl) { |   if(curl) { | ||||||
| @@ -122,7 +123,9 @@ int main(void) | |||||||
|       if(CURLE_OK != res) |       if(CURLE_OK != res) | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|       printf("Received %u bytes.\n", iolen); |       nread = (curl_off_t)iolen; | ||||||
|  |  | ||||||
|  |       printf("Received %" CURL_FORMAT_CURL_OFF_T " bytes.\n", nread); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* always cleanup */ |     /* always cleanup */ | ||||||
|   | |||||||
| @@ -24,8 +24,6 @@ | |||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
|  |  | ||||||
| #include <curl/curl.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) | static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream) | ||||||
| { | { | ||||||
|   | |||||||
| @@ -22,9 +22,6 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
| #include <curl/types.h> |  | ||||||
| #include <curl/easy.h> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* some requirements for this to work: | /* some requirements for this to work: | ||||||
|    1.   set pCertFile to the file with the client certificate |    1.   set pCertFile to the file with the client certificate | ||||||
|   | |||||||
| @@ -37,8 +37,6 @@ | |||||||
| #include <pthread.h> | #include <pthread.h> | ||||||
|  |  | ||||||
| #include <curl/curl.h> | #include <curl/curl.h> | ||||||
| #include <curl/types.h> /* new for v7 */ |  | ||||||
| #include <curl/easy.h> /* new for v7 */ |  | ||||||
|  |  | ||||||
| #define NUMT 4 | #define NUMT 4 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -123,13 +123,13 @@ int main(void) | |||||||
|    curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); |    curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); | ||||||
|    curl_easy_setopt(curl, CURLOPT_MAIL_FROM, MAILFROM); |    curl_easy_setopt(curl, CURLOPT_MAIL_FROM, MAILFROM); | ||||||
|    curl_easy_setopt(curl, CURLOPT_MAIL_RCPT, rcpt_list); |    curl_easy_setopt(curl, CURLOPT_MAIL_RCPT, rcpt_list); | ||||||
|    curl_easy_setopt(curl, CURLOPT_USE_SSL, CURLUSESSL_ALL); |    curl_easy_setopt(curl, CURLOPT_USE_SSL, (long)CURLUSESSL_ALL); | ||||||
|    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER,0); |    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); | ||||||
|    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0); |    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); | ||||||
|    curl_easy_setopt(curl, CURLOPT_READDATA, &pooh); |    curl_easy_setopt(curl, CURLOPT_READDATA, &pooh); | ||||||
|    curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); |    curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L); | ||||||
|    curl_easy_setopt(curl, CURLOPT_SSLVERSION, 0); |    curl_easy_setopt(curl, CURLOPT_SSLVERSION, 0L); | ||||||
|    curl_easy_setopt(curl, CURLOPT_SSL_SESSIONID_CACHE, 0); |    curl_easy_setopt(curl, CURLOPT_SSL_SESSIONID_CACHE, 0L); | ||||||
|    curl_multi_add_handle(mcurl, curl); |    curl_multi_add_handle(mcurl, curl); | ||||||
|  |  | ||||||
|    mp_timedout = 0; |    mp_timedout = 0; | ||||||
|   | |||||||
| @@ -94,13 +94,13 @@ int main(void) | |||||||
|      * of using CURLUSESSL_TRY here, because if TLS upgrade fails, the transfer |      * of using CURLUSESSL_TRY here, because if TLS upgrade fails, the transfer | ||||||
|      * will continue anyway - see the security discussion in the libcurl |      * will continue anyway - see the security discussion in the libcurl | ||||||
|      * tutorial for more details. */ |      * 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 |     /* If your server doesn't have a valid certificate, then you can disable | ||||||
|      * part of the Transport Layer Security protection by setting the |      * part of the Transport Layer Security protection by setting the | ||||||
|      * CURLOPT_SSL_VERIFYPEER and CURLOPT_SSL_VERIFYHOST options to 0 (false). |      * 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_VERIFYPEER, 0L); | ||||||
|      *   curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0); |      *   curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); | ||||||
|      * That is, in general, a bad idea. It is still better than sending your |      * That is, in general, a bad idea. It is still better than sending your | ||||||
|      * authentication details in plain text though. |      * authentication details in plain text though. | ||||||
|      * Instead, you should get the issuer certificate (or the host certificate |      * 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 |     /* 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. |      * 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) */ |     /* send the message (including headers) */ | ||||||
|     res = curl_easy_perform(curl); |     res = curl_easy_perform(curl); | ||||||
|   | |||||||
| @@ -147,7 +147,7 @@ size_t SyncTime_CURL_WriteHeader(void *ptr, size_t size, size_t nmemb, | |||||||
|                                          TmpStr1 & 2? */ |                                          TmpStr1 & 2? */ | ||||||
|         AutoSyncTime = 0; |         AutoSyncTime = 0; | ||||||
|       else { |       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, |                          TmpStr1, &SYSTime.wDay, TmpStr2, &SYSTime.wYear, | ||||||
|                          &SYSTime.wHour, &SYSTime.wMinute, &SYSTime.wSecond); |                          &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) | CLEANFILES = $(HTMLPAGES) $(PDFPAGES) | ||||||
|  |  | ||||||
| EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) libcurl.m4 ABI \ | EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) libcurl.m4 ABI \ | ||||||
|   symbols-in-versions |   symbols-in-versions symbols.pl | ||||||
| MAN2HTML= roffit --mandir=. < $< >$@ | MAN2HTML= roffit --mandir=. < $< >$@ | ||||||
|  |  | ||||||
| SUFFIXES = .3 .html | 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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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 | has kept open until now. Don't call this function if you intend to transfer | ||||||
| more files. | more files. | ||||||
|  |  | ||||||
| Any uses of the \fBhandle\fP after this function has been called are | Occasionally you may get your progress callback or header callback called from | ||||||
| illegal. This kills the handle and all memory associated with it! | 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 | 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 | 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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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 | .IP CURLINFO_EFFECTIVE_URL | ||||||
| Pass a pointer to a char pointer to receive the last used effective URL. | Pass a pointer to a char pointer to receive the last used effective URL. | ||||||
| .IP CURLINFO_RESPONSE_CODE | .IP CURLINFO_RESPONSE_CODE | ||||||
| Pass a pointer to a long to receive the last received HTTP or FTP code. This | Pass a pointer to a long to receive the last received HTTP, FTP or SMTP | ||||||
| option was known as CURLINFO_HTTP_CODE in libcurl 7.10.7 and earlier. This | response code. This option was previously known as CURLINFO_HTTP_CODE in | ||||||
| will be zero if no server response code has been received. Note that a proxy's | libcurl 7.10.7 and earlier. The value will be zero if no server response code | ||||||
| CONNECT response should be read with \fICURLINFO_HTTP_CONNECTCODE\fP and not | has been received. Note that a proxy's CONNECT response should be read with | ||||||
| this. | \fICURLINFO_HTTP_CONNECTCODE\fP and not this. | ||||||
|  |  | ||||||
|  | Support for SMTP responses added in 7.25.0. | ||||||
| .IP CURLINFO_HTTP_CONNECTCODE | .IP CURLINFO_HTTP_CONNECTCODE | ||||||
| Pass a pointer to a long to receive the last received proxy response code to a | Pass a pointer to a long to receive the last received proxy response code to a | ||||||
| CONNECT request. | 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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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 | 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 | 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 | 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 | .IP CURLOPT_WILDCARDMATCH | ||||||
| Set this option to 1 if you want to transfer multiple files according to a | 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 | 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, | 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 | 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 | thousands. The maximum amount of body data that can be passed to the write | ||||||
| is defined in the curl.h header file: CURL_MAX_WRITE_SIZE. | 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 | .IP CURLOPT_WRITEDATA | ||||||
| Data pointer to pass to the file write function. If you use the | 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 | \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 | 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) | many systems! (Option added in 7.18.0) | ||||||
| .IP CURLOPT_SEEKDATA | .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 | \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) | you don't specify a seek callback, NULL is passed. (Option added in 7.18.0) | ||||||
| .IP CURLOPT_SOCKOPTFUNCTION | .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 | 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 | 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 | 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 | Added in 7.21.5, the callback function may return | ||||||
| \fICURL_SOCKOPT_ALREADY_CONNECTED\fP, which tells libcurl that the socket is | \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 | .IP CURLOPT_SOCKOPTDATA | ||||||
| Pass a pointer that will be untouched by libcurl and passed as the first | Pass a pointer that will be untouched by libcurl and passed as the first | ||||||
| argument in the sockopt callback set with \fICURLOPT_SOCKOPTFUNCTION\fP. | 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 | .IP CURLOPT_OPENSOCKETFUNCTION | ||||||
| Function pointer that should match the \fIcurl_opensocket_callback\fP | Function pointer that should match the \fIcurl_opensocket_callback\fP | ||||||
| prototype found in \fI<curl/curl.h>\fP. This function gets called by libcurl | 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 | instead of the \fIsocket(2)\fP call. The callback's \fIpurpose\fP argument | ||||||
| identifies the exact purpose for this particular socket, and currently only | identifies the exact purpose for this particular socket: | ||||||
| one value is supported: \fICURLSOCKTYPE_IPCXN\fP for the primary connection | \fICURLSOCKTYPE_IPCXN\fP is for IP based connections. Future versions of | ||||||
| (meaning the control connection in the FTP case). Future versions of libcurl | libcurl may support more purposes. It passes the resolved peer address as a | ||||||
| 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 | \fIaddress\fP argument so the callback can modify the address or refuse to | ||||||
| connect at all. The callback function should return the socket or | 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 | \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) | 1 if there was an error.  (Option added in 7.21.7) | ||||||
| .IP CURLOPT_CLOSESOCKETDATA | .IP CURLOPT_CLOSESOCKETDATA | ||||||
| Pass a pointer that will be untouched by libcurl and passed as the first | 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) | \fICURLOPT_CLOSESOCKETFUNCTION\fP.  (Option added in 7.21.7) | ||||||
| .IP CURLOPT_PROGRESSFUNCTION | .IP CURLOPT_PROGRESSFUNCTION | ||||||
| Function pointer that should match the \fIcurl_progress_callback\fP prototype | Function pointer that should match the \fIcurl_progress_callback\fP prototype | ||||||
| @@ -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 | to your function, it'll signal an error to the library. This will abort the | ||||||
| transfer and return \fICURL_WRITE_ERROR\fP. | 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 | 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 | \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, | 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: | 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 | header among the regular response-headers mention what header(s) to expect in | ||||||
| the trailer. | 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 | .IP CURLOPT_WRITEHEADER | ||||||
| (This option is also known as \fBCURLOPT_HEADERDATA\fP) Pass a pointer to be | (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 | 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 | Function pointer that should match the following prototype: \fBCURLcode | ||||||
| sslctxfun(CURL *curl, void *sslctx, void *parm);\fP This function gets called | 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 | processed all other SSL related options to give a last chance to an | ||||||
| application to modify the behaviour of openssl's ssl initialization. The | 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 | \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 | 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 | libraries is necessary. For example, using this function allows you to use | ||||||
| openssl callbacks to add additional validation code for certificates, and even | 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 | case).  See also the example section for a replacement of the key, certificate | ||||||
| and trust file settings. | and trust file settings. | ||||||
| .IP CURLOPT_SSL_CTX_DATA | .IP CURLOPT_SSL_CTX_DATA | ||||||
| @@ -582,20 +593,162 @@ POST/PUT and a 401 or 407 is received immediately afterwards. | |||||||
| .SH NETWORK OPTIONS | .SH NETWORK OPTIONS | ||||||
| .IP CURLOPT_URL | .IP CURLOPT_URL | ||||||
| The actual URL to deal with. The parameter should be a char * to a zero | 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 | scheme://host:port/path | ||||||
| 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. |  | ||||||
|  |  | ||||||
| The string given to CURLOPT_URL must be url-encoded and follow RFC 2396 | For a greater explanation of the format please see RFC 3986 | ||||||
| (http://curl.haxx.se/rfc/rfc2396.txt). | (http://curl.haxx.se/rfc/rfc3986.txt). | ||||||
|  |  | ||||||
| Starting with version 7.20.0, the fragment part of the URI will not be send as | If the given URL lacks the scheme, or protocol, part ("http://" or "ftp://" | ||||||
| part of the path, which was the case previously. | 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 | \fICURLOPT_URL\fP is the only option that \fBmust\fP be set before | ||||||
| \fIcurl_easy_perform(3)\fP is called. | \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. | not specified, libcurl will default to using port 1080 for proxies. | ||||||
| \fICURLOPT_PROXYPORT\fP. | \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 | 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 | 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 | \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 | .IP CURLOPT_PROXYTYPE | ||||||
| Pass a long with this option to set type of the proxy. Available options for | 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), | 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 | \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) | (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 | 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 | 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. | \fICURLOPT_HTTP_VERSION\fP. | ||||||
| .IP CURLOPT_NOPROXY | .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 | 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 | 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 | 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 | 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 | network interface. The name can be an interface name, an IP address, or a host | ||||||
| name. | 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 | .IP CURLOPT_LOCALPORT | ||||||
| Pass a long. This sets the local port number of the socket used for | 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 | connection. This can be used in combination with \fICURLOPT_INTERFACE\fP and | ||||||
| @@ -756,6 +918,20 @@ overdone. | |||||||
| .IP CURLOPT_ADDRESS_SCOPE | .IP CURLOPT_ADDRESS_SCOPE | ||||||
| Pass a long specifying the scope_id value to use when connecting to IPv6 | 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) | 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) | .SH NAMES and PASSWORDS OPTIONS (Authentication) | ||||||
| .IP CURLOPT_NETRC | .IP CURLOPT_NETRC | ||||||
| This parameter controls the preference of libcurl between using user names and | 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 | Microsoft. It uses a challenge-response and hash concept similar to Digest, to | ||||||
| prevent the password from being eavesdropped. | prevent the password from being eavesdropped. | ||||||
|  |  | ||||||
| You need to build libcurl with OpenSSL support for this option to work, or | You need to build libcurl with either OpenSSL, GnuTLS or NSS support for this | ||||||
| build libcurl on Windows. | 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 | .IP CURLAUTH_ANY | ||||||
| This is a convenience macro that sets all bits and thus makes libcurl pick 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 | 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) | to work. (Added in 7.21.4) | ||||||
| .RE | .RE | ||||||
| .IP CURLOPT_TLSAUTH_USERNAME | .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 | to use for the TLS authentication method specified with the | ||||||
| \fICURLOPT_TLSAUTH_TYPE\fP option. Requires that the | \fICURLOPT_TLSAUTH_TYPE\fP option. Requires that the | ||||||
| \fICURLOPT_TLS_PASSWORD\fP option also be set. (Added in 7.21.4) | \fICURLOPT_TLS_PASSWORD\fP option also be set. (Added in 7.21.4) | ||||||
| .IP CURLOPT_TLSAUTH_PASSWORD | .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 | to use for the TLS authentication method specified with the | ||||||
| \fICURLOPT_TLSAUTH_TYPE\fP option. Requires that the | \fICURLOPT_TLSAUTH_TYPE\fP option. Requires that the | ||||||
| \fICURLOPT_TLS_USERNAME\fP option also be set. (Added in 7.21.4) | \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: | automatically set the Referer: field in requests where it follows a Location: | ||||||
| redirect. | redirect. | ||||||
| .IP CURLOPT_ACCEPT_ENCODING | .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. | enables decoding of a response when a Content-Encoding: header is received. | ||||||
| Three encodings are supported: \fIidentity\fP, which does nothing, | Three encodings are supported: \fIidentity\fP, which does nothing, | ||||||
| \fIdeflate\fP which requests the server to compress its response using the | \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) | (Added in 7.21.6) | ||||||
| .IP CURLOPT_FOLLOWLOCATION | .IP CURLOPT_FOLLOWLOCATION | ||||||
| A parameter set to 1 tells the library to follow any Location: header that the | 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 | 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 | 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) | an infinite number of redirects (which is the default) | ||||||
| .IP CURLOPT_POSTREDIR | .IP CURLOPT_POSTREDIR | ||||||
| Pass a bitmask to control how libcurl acts on redirects after POSTs that get a | 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 | \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 | not convert POST requests into GET requests when following a 301 | ||||||
| redirection. Setting bit 1 (value CURL_REDIR_POST_302) makes libcurl maintain | 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 | the request method after a 302 redirect. Setting bit 2 (value | ||||||
| define that sets both bits. | \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 | 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 | 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 | re-used handle, you must explicitly set the new request type using | ||||||
| \fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar. | \fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar. | ||||||
| .IP CURLOPT_POSTFIELDS | .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 | 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 | 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. | 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 | data to figure out the size. This is the large file version of the | ||||||
| \fICURLOPT_POSTFIELDSIZE\fP option. (Added in 7.11.1) | \fICURLOPT_POSTFIELDSIZE\fP option. (Added in 7.11.1) | ||||||
| .IP CURLOPT_COPYPOSTFIELDS | .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 | POST operation. It behaves as the \fICURLOPT_POSTFIELDS\fP option, but the | ||||||
| original data are copied by the library, allowing the application to overwrite | original data are copied by the library, allowing the application to overwrite | ||||||
| the original data after setting this option. | 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;" | multiple cookies in one string like this: "name1=content1; name2=content2;" | ||||||
| etc. | 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 | multiple requests are done due to authentication, followed redirections or | ||||||
| similar, they will all get this cookie passed on. | 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) | option is set to zero. (added in 7.16.2) | ||||||
| .SH SMTP OPTIONS | .SH SMTP OPTIONS | ||||||
| .IP CURLOPT_MAIL_FROM | .IP CURLOPT_MAIL_FROM | ||||||
| Pass a pointer to a zero terminated string as parameter. It will be used to | Pass a pointer to a zero terminated string as parameter. This should be used | ||||||
| specify the sender address in a mail when sending an SMTP mail with libcurl. | 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 | An originator email address should be specified with angled brackets (<>) | ||||||
| (<>) which libcurl will not add for you before version 7.21.4. Failing to | around it, which if not specified, will be added by libcurl from version | ||||||
| provide such brackets may cause the server to reject your mail. | 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) | (Added in 7.20.0) | ||||||
| .IP CURLOPT_MAIL_RCPT | .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 | 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. | 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 | Each recipient should be specified within a pair of angled brackets (<>), | ||||||
| you not use an angle bracket as first letter libcurl will assume you provide a | however, should you not use an angled bracket as the first character libcurl | ||||||
| single email address only and enclose that with angle brackets for you. | will assume you provided a single email address and enclose that address | ||||||
|  | within brackets for you. | ||||||
|  |  | ||||||
| (Added in 7.20.0) | (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 | .SH TFTP OPTIONS | ||||||
| .IP CURLOPT_TFTP_BLKSIZE | .IP CURLOPT_TFTP_BLKSIZE | ||||||
| Specify block size to use for TFTP data transmission. Valid range as per RFC | 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 | You disable PORT again and go back to using the passive version by setting | ||||||
| this option to NULL. | this option to NULL. | ||||||
| .IP CURLOPT_QUOTE | .IP CURLOPT_QUOTE | ||||||
| Pass a pointer to a linked list of FTP or SFTP commands to pass to | Pass a pointer to a linked list of FTP or SFTP commands to pass to the server | ||||||
| the server prior to your FTP request. This will be done before any | prior to your FTP request. This will be done before any other commands are | ||||||
| other commands are issued (even before the CWD command for FTP). The | issued (even before the CWD command for FTP). The linked list should be a | ||||||
| linked list should be a fully valid list of 'struct curl_slist' structs | fully valid list of 'struct curl_slist' structs properly filled in with text | ||||||
| properly filled in with text strings. Use \fIcurl_slist_append(3)\fP | strings. Use \fIcurl_slist_append(3)\fP to append strings (commands) to the | ||||||
| to append strings (commands) to the list, and clear the entire list | list, and clear the entire list afterwards with | ||||||
| afterwards with \fIcurl_slist_free_all(3)\fP. Disable this operation | \fIcurl_slist_free_all(3)\fP. Disable this operation again by setting a NULL | ||||||
| again by setting a NULL to this option. | to this option. When speaking to a FTP (or SFTP since 7.24.0) server, prefix | ||||||
| The set of valid FTP commands depends on the server (see RFC959 for a | the command with an asterisk (*) to make libcurl continue even if the command | ||||||
| list of mandatory commands). | fails as by default libcurl will stop at first failure. | ||||||
| The valid SFTP commands are: chgrp, chmod, chown, ln, mkdir, pwd, |  | ||||||
| rename, rm, rmdir, symlink (see | 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)) | .BR curl (1)) | ||||||
| (SFTP support added in 7.16.3) | (SFTP support added in 7.16.3) | ||||||
| .IP CURLOPT_POSTQUOTE | .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 | 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 | struct curl_slist structs properly filled in as described for | ||||||
| \fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this | \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. | option didn't work. | ||||||
| .IP CURLOPT_DIRLISTONLY | .IP CURLOPT_DIRLISTONLY | ||||||
| A parameter set to 1 tells the library to just list the names of files in a | 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. | Initiate the shutdown and wait for a reply. | ||||||
| .RE | .RE | ||||||
| .IP CURLOPT_FTP_ACCOUNT | .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, | 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) | this data is sent off using the ACCT command. (Added in 7.13.0) | ||||||
| .IP CURLOPT_FTP_FILEMETHOD | .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 | 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 | 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 | 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) | \fICURL_RTSPREQ_SET_PARAMETER\fP (Added in 7.20.0) | ||||||
| .IP CURL_RTSPREQ_SETUP | .IP CURL_RTSPREQ_SETUP | ||||||
| Setup is used to initialize the transport layer for the session. The | 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 | .IP CURL_RTSPREQ_GET_PARAMETER | ||||||
| Retrieve a parameter from the server. By default, libcurl will automatically | Retrieve a parameter from the server. By default, libcurl will automatically | ||||||
| include a \fIContent-Type: text/parameters\fP header on all non-empty requests | 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). | (see \fICURL_RTSPREQ_SET_PARAMETER\fP). | ||||||
| Applications wishing to send a heartbeat message (e.g. in the presence of a | 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. | 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 | .IP CURL_RTSPREQ_SET_PARAMETER | ||||||
| Set a parameter on the server. By default, libcurl will automatically include | 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 | 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 | 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 an HTTP | may either use \fICURLOPT_UPLOAD\fP with \fICURLOPT_READDATA\fP like a HTTP | ||||||
| PUT, or it may use \fICURLOPT_POSTFIELDS\fP like an HTTP POST. No chunked | PUT, or it may use \fICURLOPT_POSTFIELDS\fP like a HTTP POST. No chunked | ||||||
| transfers are allowed, so the application must set the | transfers are allowed, so the application must set the | ||||||
| \fICURLOPT_INFILESIZE\fP in the former and \fICURLOPT_POSTFIELDSIZE\fP in 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 | 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. | simply sets the mode to ASCII and performs a standard transfer. | ||||||
| .IP CURLOPT_PROXY_TRANSFER_MODE | .IP CURLOPT_PROXY_TRANSFER_MODE | ||||||
| Pass a long. If the value is set to 1 (one), it tells libcurl to set the | 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 | 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 | 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 | 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 | 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) | you want the transfer to start from. (Added in 7.11.0) | ||||||
| .IP CURLOPT_CUSTOMREQUEST | .IP CURLOPT_CUSTOMREQUEST | ||||||
| Pass a pointer to a zero terminated string as parameter. It will be used | Pass a pointer to a zero terminated string as parameter. It can be used to | ||||||
| instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST | specify the request instead of GET or HEAD when performing HTTP based | ||||||
| when doing a FTP directory listing. This is useful for doing DELETE or other | requests, instead of LIST and NLST when performing FTP directory listings and | ||||||
| more or less obscure HTTP requests. Don't do this at will, make sure your | instead of LIST and RETR when issuing POP3 based commands. This is | ||||||
| server supports the command first. | 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 | 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 | something, you don't actually change how libcurl behaves or acts in regards | ||||||
| the particular request method, it will only change the actual string sent in | to the particular request method, it will only change the actual string sent | ||||||
| the request. | in the request. | ||||||
|  |  | ||||||
| For example: if you tell libcurl to do a HEAD request, but then change the | 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 | 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. | Restore to the internal default by setting this to NULL. | ||||||
|  |  | ||||||
| Many people have wrongly used this option to replace the entire request with | 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 | their own, including multiple headers and POST contents. While that might | ||||||
| in many cases, it will cause libcurl to send invalid requests and it could | work in many cases, it will cause libcurl to send invalid requests and it | ||||||
| possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and | could possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and | ||||||
| \fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to | \fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to | ||||||
| replace or extend the set of headers sent by libcurl. Use | replace or extend the set of headers sent by libcurl. Use | ||||||
| \fICURLOPT_HTTP_VERSION\fP to change HTTP version. | \fICURLOPT_HTTP_VERSION\fP to change HTTP version. | ||||||
|  |  | ||||||
|  | (Support for POP3 added in 7.26.0) | ||||||
| .IP CURLOPT_FILETIME | .IP CURLOPT_FILETIME | ||||||
| Pass a long. If it is 1, libcurl will attempt to get the modification date of | 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 | 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). | can be used after a transfer to extract the received time (if any). | ||||||
| .IP CURLOPT_NOBODY | .IP CURLOPT_NOBODY | ||||||
| A parameter set to 1 tells the library to not include the body-part in the | 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 | output. This is only relevant for protocols that have separate header and | ||||||
| parts. On HTTP(S) servers, this will make libcurl do a HEAD request. | 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 change request to GET, you should use \fICURLOPT_HTTPGET\fP. Change | ||||||
| to POST with \fICURLOPT_POST\fP etc. | request to POST with \fICURLOPT_POST\fP etc. | ||||||
| .IP CURLOPT_INFILESIZE | .IP CURLOPT_INFILESIZE | ||||||
| When uploading a file to a remote site, this option should be used to tell | When uploading a file to a remote site, this option should be used to tell | ||||||
| libcurl what the expected size of the infile is. This value should be passed | libcurl what the expected size of the infile is. This value should be passed | ||||||
| @@ -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 | For uploading using SCP, this option or \fICURLOPT_INFILESIZE_LARGE\fP is | ||||||
| mandatory. | 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 | This option does not limit how much data libcurl will actually send, as that | ||||||
| is controlled entirely by what the read callback returns. | is controlled entirely by what the read callback returns. | ||||||
| .IP CURLOPT_INFILESIZE_LARGE | .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 | In unix-like systems, this might cause signals to be used unless | ||||||
| \fICURLOPT_NOSIGNAL\fP is set. | \fICURLOPT_NOSIGNAL\fP is set. | ||||||
|  |  | ||||||
|  | Default timeout is 0 (zero) which means it never times out. | ||||||
| .IP CURLOPT_TIMEOUT_MS | .IP CURLOPT_TIMEOUT_MS | ||||||
| Like \fICURLOPT_TIMEOUT\fP but takes number of milliseconds instead. If | Like \fICURLOPT_TIMEOUT\fP but takes number of milliseconds instead. If | ||||||
| libcurl is built to use the standard system name resolver, that portion | libcurl is built to use the standard system name resolver, that portion | ||||||
| @@ -1802,9 +2031,9 @@ re-use (default behavior). | |||||||
| .IP CURLOPT_CONNECTTIMEOUT | .IP CURLOPT_CONNECTTIMEOUT | ||||||
| Pass a long. It should contain the maximum time in seconds that you allow the | 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 | 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 | it has connected, this option is of no more use. Set to zero to switch to the | ||||||
| connection timeout (it will then only timeout on the system's internal | default built-in connection timeout - 300 seconds. See also the | ||||||
| timeouts). See also the \fICURLOPT_TIMEOUT\fP option. | \fICURLOPT_TIMEOUT\fP option. | ||||||
|  |  | ||||||
| In unix-like systems, this might cause signals to be used unless | In unix-like systems, this might cause signals to be used unless | ||||||
| \fICURLOPT_NOSIGNAL\fP is set. | \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. | and port number must exactly match what was already added previously. | ||||||
|  |  | ||||||
| (Added in 7.21.3) | (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 | .SH SSL and SECURITY OPTIONS | ||||||
| .IP CURLOPT_SSLCERT | .IP CURLOPT_SSLCERT | ||||||
| Pass a pointer to a zero terminated string as parameter. The string should be | 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 | 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. | 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 | 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 | 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 | 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 | 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 | 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) | 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 | .IP CURLOPT_KRBLEVEL | ||||||
| Pass a char * as parameter. Set the kerberos security level for FTP; this also | Pass a char * as parameter. Set the kerberos security level for FTP; this also | ||||||
| enables kerberos awareness.  This is a string, \&'clear', \&'safe', | 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. | support for FTP. | ||||||
|  |  | ||||||
| (This option was known as CURLOPT_KRB4LEVEL up to 7.16.3) | (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 | .SH SSH OPTIONS | ||||||
| .IP CURLOPT_SSH_AUTH_TYPES | .IP CURLOPT_SSH_AUTH_TYPES | ||||||
| Pass a long set to a bitmask consisting of one or more of | Pass a long set to a bitmask consisting of one or more of | ||||||
| CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST, | CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST, | ||||||
| CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. | CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. Currently | ||||||
| (Added in 7.16.1) | CURLSSH_AUTH_HOST has no effect. (Added in 7.16.1) | ||||||
| .IP CURLOPT_SSH_HOST_PUBLIC_KEY_MD5 | .IP CURLOPT_SSH_HOST_PUBLIC_KEY_MD5 | ||||||
| Pass a char * pointing to a string containing 32 hexadecimal digits. The | 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 | 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 | 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 | variable is set, and just "id_dsa.pub" in the current directory if HOME is not | ||||||
| set.  (Added in 7.16.1) | 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 | .IP CURLOPT_SSH_PRIVATE_KEYFILE | ||||||
| Pass a char * pointing to a file name for your private key. If not used, | 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 | 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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * you should have received as part of this distribution. The terms | ||||||
| @@ -23,9 +23,9 @@ | |||||||
| .SH NAME | .SH NAME | ||||||
| curl_easy_strerror - return string describing error code | curl_easy_strerror - return string describing error code | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
| .nf | #include <curl/curl.h> | ||||||
| .B #include <curl/curl.h> |  | ||||||
| .BI "const char *curl_easy_strerror(CURLcode " errornum ");" | const char *curl_easy_strerror(CURLcode errornum); | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| The curl_easy_strerror() function returns a string describing the CURLcode | The curl_easy_strerror() function returns a string describing the CURLcode | ||||||
| error code passed in the argument \fIerrornum\fP. | error code passed in the argument \fIerrornum\fP. | ||||||
|   | |||||||
| @@ -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 | 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. | 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 | 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 | 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 | 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 | 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 | 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. | 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 | .SH RETURN VALUE | ||||||
| CURLMcode type, general libcurl multi interface error code. See | CURLMcode type, general libcurl multi interface error code. See | ||||||
| \fIlibcurl-errors(3)\fP | \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 | 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 | the same multi handle will share DNS cache by default without this having to | ||||||
| be used! | 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 | .RE | ||||||
| .IP CURLSHOPT_UNSHARE | .IP CURLSHOPT_UNSHARE | ||||||
| This option does the opposite of \fICURLSHOPT_SHARE\fP. It specifies that | 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 | .IP CURL_VERSION_CONV | ||||||
| libcurl was built with support for character conversions, as provided by the | libcurl was built with support for character conversions, as provided by the | ||||||
| CURLOPT_CONV_* callbacks. (Added in 7.15.4) | 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 | .RE | ||||||
| \fIssl_version\fP is an ASCII string for the OpenSSL version used. If libcurl | \fIssl_version\fP is an ASCII string for the OpenSSL version used. If libcurl | ||||||
| has no SSL support, this is NULL. | 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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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)" | .IP "CURLE_REMOTE_ACCESS_DENIED (9)" | ||||||
| We were denied access to the resource given in the URL.  For FTP, this occurs | We were denied access to the resource given in the URL.  For FTP, this occurs | ||||||
| while trying to change to the remote directory. | 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)" | .IP "CURLE_FTP_WEIRD_PASS_REPLY (11)" | ||||||
| After having sent the FTP password to the server, libcurl expects a proper | After having sent the FTP password to the server, libcurl expects a proper | ||||||
| reply. This error code indicates that an unexpected code was returned. | reply. This error code indicates that an unexpected code was returned. | ||||||
|  | .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)" | .IP "CURLE_FTP_WEIRD_PASV_REPLY (13)" | ||||||
| libcurl failed to get a sensible result back from the server as a response to | 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. | either a PASV or a EPSV command. The server is flawed. | ||||||
| .IP "CURLE_FTP_WEIRD_227_FORMAT (14)" | .IP "CURLE_FTP_WEIRD_227_FORMAT (14)" | ||||||
| FTP servers return a 227-line as a response to a PASV command. If libcurl | 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. | 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)" | .IP "CURLE_FTP_CANT_GET_HOST (15)" | ||||||
| An internal failure to lookup the host used for the new connection. | An internal failure to lookup the host used for the new connection. | ||||||
| .IP "CURLE_FTP_COULDNT_SET_TYPE (17)" | .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)" | .IP "CURLE_SSL_ISSUER_ERROR (83)" | ||||||
| Issuer check failed (Added in 7.19.0) | Issuer check failed (Added in 7.19.0) | ||||||
| .IP "CURLE_FTP_PRET_FAILED (84)" | .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)" | .IP "CURLE_RTSP_CSEQ_ERROR (85)" | ||||||
| Mismatch of RTSP CSeq numbers. | Mismatch of RTSP CSeq numbers. | ||||||
| .IP "CURLE_RTSP_SESSION_ERROR (86)" | .IP "CURLE_RTSP_SESSION_ERROR (86)" | ||||||
| @@ -277,3 +281,6 @@ An invalid share object was passed to the function. | |||||||
| .IP "CURLSHE_NOMEM (4)" | .IP "CURLSHE_NOMEM (4)" | ||||||
| Not enough memory was available. | Not enough memory was available. | ||||||
| (Added in 7.12.0) | (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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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 | for input on your own private file descriptors at the same time or perhaps | ||||||
| timeout every now and then, should you want that. | 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 | \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 | 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 | 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 | 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). | again (possibly after having altered some options at your own choice). | ||||||
| .SH "MULTI_SOCKET" | .SH "MULTI_SOCKET" | ||||||
| Since 7.16.0, the \fIcurl_multi_socket_action(3)\fP function offers a way for | \fIcurl_multi_socket_action(3)\fP function offers a way for applications to | ||||||
| applications to not only avoid being forced to use select(), but it also | not only avoid being forced to use select(), but it also offers a much more | ||||||
| offers a much more high-performance API that will make a significant | high-performance API that will make a significant difference for applications | ||||||
| difference for applications using large numbers of simultaneous connections. | using large numbers of simultaneous connections. | ||||||
|  |  | ||||||
| \fIcurl_multi_socket_action(3)\fP is then used | \fIcurl_multi_socket_action(3)\fP is then used instead of | ||||||
| instead of \fIcurl_multi_perform(3)\fP. | \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" | .SH "BLOCKING" | ||||||
| A few areas in the code are still using blocking code, even when used from the | 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 | 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: | the future, you should be aware of the following current restrictions: | ||||||
|  |  | ||||||
| .nf | .nf | ||||||
|  - Name resolves on non-windows unless c-ares is used |  - Name resolves unless the c-ares or threaded-resolver backends are used | ||||||
|  - GnuTLS SSL connections |  | ||||||
|  - NSS SSL connections |  - NSS SSL connections | ||||||
|  - Active FTP connections |  | ||||||
|  - HTTP proxy CONNECT operations |  - HTTP proxy CONNECT operations | ||||||
|  - SOCKS proxy handshakes |  - SOCKS proxy handshakes | ||||||
|  - file:// transfers |  - 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 | .\" * This software is licensed as described in the file COPYING, which | ||||||
| .\" * you should have received as part of this distribution. The terms | .\" * 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. | of all the details needed to get the file moved from one machine to another. | ||||||
|  |  | ||||||
| .SH "Multi-threading Issues" | .SH "Multi-threading Issues" | ||||||
| The first basic rule is that you must \fBnever\fP share a libcurl handle (be | The first basic rule is that you must \fBnever\fP simultaneously share a | ||||||
| it easy or multi or whatever) between multiple threads. Only use one handle in | libcurl handle (be it easy or multi or whatever) between multiple | ||||||
| one thread at a time. | 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 | 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) - | 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 | the name of the server we want to talk to. This includes the port number if | ||||||
| anything but default. | 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" | .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 | \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 | 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, | block. | ||||||
| as that is a signal that it still has local data to send or remote data to |  | ||||||
| receive. |  | ||||||
|  |  | ||||||
| The best usage of this interface is when you do a select() on all possible | 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 | 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 ] |  [ seeding, passwords, keys, certificates, ENGINE, ca certs ] | ||||||
|  |  | ||||||
| .SH "Sharing Data Between Easy Handles" | .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" | .SH "Footnotes" | ||||||
|  |  | ||||||
| .IP "[1]" | .IP "[1]" | ||||||
|   | |||||||
| @@ -146,7 +146,7 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG], | |||||||
|            _libcurl_save_libs=$LIBS |            _libcurl_save_libs=$LIBS | ||||||
|            LIBS="$LIBCURL $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 | /* Try and use a few common options to force a failure if we are | ||||||
|    missing symbols or can't link. */ |    missing symbols or can't link. */ | ||||||
| int x; | int x; | ||||||
| @@ -157,7 +157,8 @@ x=CURLOPT_FILE; | |||||||
| x=CURLOPT_ERRORBUFFER; | x=CURLOPT_ERRORBUFFER; | ||||||
| x=CURLOPT_STDERR; | x=CURLOPT_STDERR; | ||||||
| x=CURLOPT_VERBOSE; | 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 |            CPPFLAGS=$_libcurl_save_cppflags | ||||||
|            LIBS=$_libcurl_save_libs |            LIBS=$_libcurl_save_libs | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ CURLAUTH_DIGEST_IE              7.19.3 | |||||||
| CURLAUTH_GSSNEGOTIATE           7.10.6 | CURLAUTH_GSSNEGOTIATE           7.10.6 | ||||||
| CURLAUTH_NONE                   7.10.6 | CURLAUTH_NONE                   7.10.6 | ||||||
| CURLAUTH_NTLM                   7.10.6 | CURLAUTH_NTLM                   7.10.6 | ||||||
|  | CURLAUTH_NTLM_WB                7.22.0 | ||||||
| CURLAUTH_ONLY                   7.21.3 | CURLAUTH_ONLY                   7.21.3 | ||||||
| CURLCLOSEPOLICY_CALLBACK        7.7 | CURLCLOSEPOLICY_CALLBACK        7.7 | ||||||
| CURLCLOSEPOLICY_LEAST_RECENTLY_USED 7.7 | CURLCLOSEPOLICY_LEAST_RECENTLY_USED 7.7 | ||||||
| @@ -44,6 +45,8 @@ CURLE_COULDNT_RESOLVE_PROXY     7.1 | |||||||
| CURLE_FAILED_INIT               7.1 | CURLE_FAILED_INIT               7.1 | ||||||
| CURLE_FILESIZE_EXCEEDED         7.10.8 | CURLE_FILESIZE_EXCEEDED         7.10.8 | ||||||
| CURLE_FILE_COULDNT_READ_FILE    7.1 | 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_ACCESS_DENIED         7.1 | ||||||
| CURLE_FTP_BAD_DOWNLOAD_RESUME   7.1           7.1 | CURLE_FTP_BAD_DOWNLOAD_RESUME   7.1           7.1 | ||||||
| CURLE_FTP_BAD_FILE_LIST         7.21.0 | 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              7.19.4 | ||||||
| CURLFTP_CREATE_DIR_NONE         7.19.4 | CURLFTP_CREATE_DIR_NONE         7.19.4 | ||||||
| CURLFTP_CREATE_DIR_RETRY        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_APPCONNECT_TIME        7.19.0 | ||||||
| CURLINFO_CERTINFO               7.19.1 | CURLINFO_CERTINFO               7.19.1 | ||||||
| CURLINFO_CONDITION_UNMET        7.19.4 | CURLINFO_CONDITION_UNMET        7.19.4 | ||||||
| @@ -282,6 +288,7 @@ CURLOPTTYPE_FUNCTIONPOINT       7.1 | |||||||
| CURLOPTTYPE_LONG                7.1 | CURLOPTTYPE_LONG                7.1 | ||||||
| CURLOPTTYPE_OBJECTPOINT         7.1 | CURLOPTTYPE_OBJECTPOINT         7.1 | ||||||
| CURLOPTTYPE_OFF_T               7.11.0 | CURLOPTTYPE_OFF_T               7.11.0 | ||||||
|  | CURLOPT_ACCEPTTIMEOUT_MS        7.24.0 | ||||||
| CURLOPT_ACCEPT_ENCODING         7.21.6 | CURLOPT_ACCEPT_ENCODING         7.21.6 | ||||||
| CURLOPT_ADDRESS_SCOPE           7.19.0 | CURLOPT_ADDRESS_SCOPE           7.19.0 | ||||||
| CURLOPT_APPEND                  7.17.0 | CURLOPT_APPEND                  7.17.0 | ||||||
| @@ -316,6 +323,7 @@ CURLOPT_DEBUGDATA               7.9.6 | |||||||
| CURLOPT_DEBUGFUNCTION           7.9.6 | CURLOPT_DEBUGFUNCTION           7.9.6 | ||||||
| CURLOPT_DIRLISTONLY             7.17.0 | CURLOPT_DIRLISTONLY             7.17.0 | ||||||
| CURLOPT_DNS_CACHE_TIMEOUT       7.9.3 | 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_DNS_USE_GLOBAL_CACHE    7.9.3         7.11.1 | ||||||
| CURLOPT_EGDSOCKET               7.7 | CURLOPT_EGDSOCKET               7.7 | ||||||
| CURLOPT_ENCODING                7.10 | 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_EPRT            7.10.5 | ||||||
| CURLOPT_FTP_USE_EPSV            7.9.2 | CURLOPT_FTP_USE_EPSV            7.9.2 | ||||||
| CURLOPT_FTP_USE_PRET            7.20.0 | CURLOPT_FTP_USE_PRET            7.20.0 | ||||||
|  | CURLOPT_GSSAPI_DELEGATION       7.22.0 | ||||||
| CURLOPT_HEADER                  7.1 | CURLOPT_HEADER                  7.1 | ||||||
| CURLOPT_HEADERDATA              7.10 | CURLOPT_HEADERDATA              7.10 | ||||||
| CURLOPT_HEADERFUNCTION          7.7.2 | CURLOPT_HEADERFUNCTION          7.7.2 | ||||||
| @@ -375,6 +384,7 @@ CURLOPT_LOCALPORT               7.15.2 | |||||||
| CURLOPT_LOCALPORTRANGE          7.15.2 | CURLOPT_LOCALPORTRANGE          7.15.2 | ||||||
| CURLOPT_LOW_SPEED_LIMIT         7.1 | CURLOPT_LOW_SPEED_LIMIT         7.1 | ||||||
| CURLOPT_LOW_SPEED_TIME          7.1 | CURLOPT_LOW_SPEED_TIME          7.1 | ||||||
|  | CURLOPT_MAIL_AUTH               7.25.0 | ||||||
| CURLOPT_MAIL_FROM               7.20.0 | CURLOPT_MAIL_FROM               7.20.0 | ||||||
| CURLOPT_MAIL_RCPT               7.20.0 | CURLOPT_MAIL_RCPT               7.20.0 | ||||||
| CURLOPT_MAXCONNECTS             7.7 | 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_PASSWDDATA              7.4.2         7.11.1      7.15.5 | ||||||
| CURLOPT_PASSWDFUNCTION          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_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_PORT                    7.1 | ||||||
| CURLOPT_POST                    7.1 | CURLOPT_POST                    7.1 | ||||||
| CURLOPT_POST301                 7.17.1        7.19.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_CIPHER_LIST         7.9 | ||||||
| CURLOPT_SSL_CTX_DATA            7.10.6 | CURLOPT_SSL_CTX_DATA            7.10.6 | ||||||
| CURLOPT_SSL_CTX_FUNCTION        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_SESSIONID_CACHE     7.16.0 | ||||||
| CURLOPT_SSL_VERIFYHOST          7.8.1 | CURLOPT_SSL_VERIFYHOST          7.8.1 | ||||||
| CURLOPT_SSL_VERIFYPEER          7.4.2 | CURLOPT_SSL_VERIFYPEER          7.4.2 | ||||||
| CURLOPT_STDERR                  7.1 | 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_TCP_NODELAY             7.11.2 | ||||||
| CURLOPT_TELNETOPTIONS           7.7 | CURLOPT_TELNETOPTIONS           7.7 | ||||||
| CURLOPT_TFTP_BLKSIZE            7.19.4 | CURLOPT_TFTP_BLKSIZE            7.19.4 | ||||||
| @@ -545,6 +559,7 @@ CURLSHE_BAD_OPTION              7.10.3 | |||||||
| CURLSHE_INVALID                 7.10.3 | CURLSHE_INVALID                 7.10.3 | ||||||
| CURLSHE_IN_USE                  7.10.3 | CURLSHE_IN_USE                  7.10.3 | ||||||
| CURLSHE_NOMEM                   7.12.0 | CURLSHE_NOMEM                   7.12.0 | ||||||
|  | CURLSHE_NOT_BUILT_IN            7.23.0 | ||||||
| CURLSHE_OK                      7.10.3 | CURLSHE_OK                      7.10.3 | ||||||
| CURLSHOPT_LOCKFUNC              7.10.3 | CURLSHOPT_LOCKFUNC              7.10.3 | ||||||
| CURLSHOPT_NONE                  7.10.3 | CURLSHOPT_NONE                  7.10.3 | ||||||
| @@ -552,7 +567,7 @@ CURLSHOPT_SHARE                 7.10.3 | |||||||
| CURLSHOPT_UNLOCKFUNC            7.10.3 | CURLSHOPT_UNLOCKFUNC            7.10.3 | ||||||
| CURLSHOPT_UNSHARE               7.10.3 | CURLSHOPT_UNSHARE               7.10.3 | ||||||
| CURLSHOPT_USERDATA              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_ANY                7.16.1 | ||||||
| CURLSSH_AUTH_DEFAULT            7.16.1 | CURLSSH_AUTH_DEFAULT            7.16.1 | ||||||
| CURLSSH_AUTH_HOST               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_NONE               7.16.1 | ||||||
| CURLSSH_AUTH_PASSWORD           7.16.1 | CURLSSH_AUTH_PASSWORD           7.16.1 | ||||||
| CURLSSH_AUTH_PUBLICKEY          7.16.1 | CURLSSH_AUTH_PUBLICKEY          7.16.1 | ||||||
|  | CURLSSLOPT_ALLOW_BEAST          7.25.0 | ||||||
| CURLUSESSL_ALL                  7.17.0 | CURLUSESSL_ALL                  7.17.0 | ||||||
| CURLUSESSL_CONTROL              7.17.0 | CURLUSESSL_CONTROL              7.17.0 | ||||||
| CURLUSESSL_NONE                 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_GET_ALL              7.19.1 | ||||||
| CURL_REDIR_POST_301             7.19.1 | CURL_REDIR_POST_301             7.19.1 | ||||||
| CURL_REDIR_POST_302             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_REDIR_POST_ALL             7.19.1 | ||||||
| CURL_RTSPREQ_ANNOUNCE           7.20.0 | CURL_RTSPREQ_ANNOUNCE           7.20.0 | ||||||
| CURL_RTSPREQ_DESCRIBE           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_LARGEFILE          7.11.1 | ||||||
| CURL_VERSION_LIBZ               7.10 | CURL_VERSION_LIBZ               7.10 | ||||||
| CURL_VERSION_NTLM               7.10.6 | CURL_VERSION_NTLM               7.10.6 | ||||||
|  | CURL_VERSION_NTLM_WB            7.22.0 | ||||||
| CURL_VERSION_SPNEGO             7.10.8 | CURL_VERSION_SPNEGO             7.10.8 | ||||||
| CURL_VERSION_SSL                7.10 | CURL_VERSION_SSL                7.10 | ||||||
| CURL_VERSION_SSPI               7.13.2 | 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 | curlbuild.h | ||||||
|  | stamp-h2 | ||||||
| stamp-h3 | stamp-h3 | ||||||
| curlver.h.dist | 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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -55,34 +55,32 @@ | |||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #include <time.h> | #include <time.h> | ||||||
|  |  | ||||||
| #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__GNUC__) && \ | #if defined(WIN32) && !defined(_WIN32_WCE) && !defined(__CYGWIN__) | ||||||
|   !defined(__CYGWIN__) || defined(__MINGW32__) | #if !(defined(_WINSOCKAPI_) || defined(_WINSOCK_H) || defined(__LWIP_OPT_H__)) | ||||||
| #if !(defined(_WINSOCKAPI_) || defined(_WINSOCK_H)) |  | ||||||
| /* The check above prevents the winsock2 inclusion if winsock.h already was | /* The check above prevents the winsock2 inclusion if winsock.h already was | ||||||
|    included, since they can't co-exist without problems */ |    included, since they can't co-exist without problems */ | ||||||
| #include <winsock2.h> | #include <winsock2.h> | ||||||
| #include <ws2tcpip.h> | #include <ws2tcpip.h> | ||||||
| #endif | #endif | ||||||
| #else | #endif | ||||||
|  |  | ||||||
| /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish | /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish | ||||||
|    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! */ |    require it! */ | ||||||
| #if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \ | #if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \ | ||||||
|     defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \ |     defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \ | ||||||
|     defined(ANDROID) || \ |     defined(ANDROID) || defined(__ANDROID__) || \ | ||||||
|    (defined(__FreeBSD_version) && (__FreeBSD_version < 800000)) |    (defined(__FreeBSD_version) && (__FreeBSD_version < 800000)) | ||||||
| #include <sys/select.h> | #include <sys/select.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef _WIN32_WCE | #if !defined(WIN32) && !defined(_WIN32_WCE) | ||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if !defined(WIN32) && !defined(__WATCOMC__) && !defined(__VXWORKS__) | #if !defined(WIN32) && !defined(__WATCOMC__) && !defined(__VXWORKS__) | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
| #endif | #endif | ||||||
| #include <sys/types.h> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef __BEOS__ | #ifdef __BEOS__ | ||||||
| #include <support/SupportDefs.h> | #include <support/SupportDefs.h> | ||||||
| @@ -122,7 +120,7 @@ typedef void CURL; | |||||||
|  |  | ||||||
| #ifndef curl_socket_typedef | #ifndef curl_socket_typedef | ||||||
| /* socket typedef */ | /* socket typedef */ | ||||||
| #ifdef WIN32 | #if defined(WIN32) && !defined(__LWIP_OPT_H__) | ||||||
| typedef SOCKET curl_socket_t; | typedef SOCKET curl_socket_t; | ||||||
| #define CURL_SOCKET_BAD INVALID_SOCKET | #define CURL_SOCKET_BAD INVALID_SOCKET | ||||||
| #else | #else | ||||||
| @@ -189,10 +187,10 @@ typedef int (*curl_progress_callback)(void *clientp, | |||||||
| #define CURL_MAX_HTTP_HEADER (100*1024) | #define CURL_MAX_HTTP_HEADER (100*1024) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /* This is a magic return code for the write callback that, when returned, | /* This is a magic return code for the write callback that, when returned, | ||||||
|    will signal libcurl to pause receiving on the current transfer. */ |    will signal libcurl to pause receiving on the current transfer. */ | ||||||
| #define CURL_WRITEFUNC_PAUSE 0x10000001 | #define CURL_WRITEFUNC_PAUSE 0x10000001 | ||||||
|  |  | ||||||
| typedef size_t (*curl_write_callback)(char *buffer, | typedef size_t (*curl_write_callback)(char *buffer, | ||||||
|                                       size_t size, |                                       size_t size, | ||||||
|                                       size_t nitems, |                                       size_t nitems, | ||||||
| @@ -413,9 +411,12 @@ typedef enum { | |||||||
|   CURLE_REMOTE_ACCESS_DENIED,    /* 9 a service was denied by the server |   CURLE_REMOTE_ACCESS_DENIED,    /* 9 a service was denied by the server | ||||||
|                                     due to lack of access - when login fails |                                     due to lack of access - when login fails | ||||||
|                                     this is not returned. */ |                                     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_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_PASV_REPLY,    /* 13 */ | ||||||
|   CURLE_FTP_WEIRD_227_FORMAT,    /* 14 */ |   CURLE_FTP_WEIRD_227_FORMAT,    /* 14 */ | ||||||
|   CURLE_FTP_CANT_GET_HOST,       /* 15 */ |   CURLE_FTP_CANT_GET_HOST,       /* 15 */ | ||||||
| @@ -513,13 +514,16 @@ typedef enum { | |||||||
|   CURLE_RTSP_SESSION_ERROR,      /* 86 - mismatch of RTSP Session Ids */ |   CURLE_RTSP_SESSION_ERROR,      /* 86 - mismatch of RTSP Session Ids */ | ||||||
|   CURLE_FTP_BAD_FILE_LIST,       /* 87 - unable to parse FTP file list */ |   CURLE_FTP_BAD_FILE_LIST,       /* 87 - unable to parse FTP file list */ | ||||||
|   CURLE_CHUNK_FAILED,            /* 88 - chunk callback reported error */ |   CURLE_CHUNK_FAILED,            /* 88 - chunk callback reported error */ | ||||||
|  |  | ||||||
|   CURL_LAST /* never use! */ |   CURL_LAST /* never use! */ | ||||||
| } CURLcode; | } CURLcode; | ||||||
|  |  | ||||||
| #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||||
|                           the obsolete stuff removed! */ |                           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 */ | /*  compatibility with older names */ | ||||||
| #define CURLOPT_ENCODING CURLOPT_ACCEPT_ENCODING | #define CURLOPT_ENCODING CURLOPT_ACCEPT_ENCODING | ||||||
|  |  | ||||||
| @@ -594,16 +598,31 @@ typedef enum { | |||||||
|                                    in 7.18.0 */ |                                    in 7.18.0 */ | ||||||
| } curl_proxytype;  /* this enum was added in 7.10 */ | } curl_proxytype;  /* this enum was added in 7.10 */ | ||||||
|  |  | ||||||
| #define CURLAUTH_NONE         0       /* nothing */ | /* | ||||||
| #define CURLAUTH_BASIC        (1<<0)  /* Basic (default) */ |  * Bitmasks for CURLOPT_HTTPAUTH and CURLOPT_PROXYAUTH options: | ||||||
| #define CURLAUTH_DIGEST       (1<<1)  /* Digest */ |  * | ||||||
| #define CURLAUTH_GSSNEGOTIATE (1<<2)  /* GSS-Negotiate */ |  * CURLAUTH_NONE         - No HTTP authentication | ||||||
| #define CURLAUTH_NTLM         (1<<3)  /* NTLM */ |  * CURLAUTH_BASIC        - HTTP Basic authentication (default) | ||||||
| #define CURLAUTH_DIGEST_IE    (1<<4)  /* Digest with IE flavour */ |  * CURLAUTH_DIGEST       - HTTP Digest authentication | ||||||
| #define CURLAUTH_ONLY         (1<<31) /* used together with a single other |  * CURLAUTH_GSSNEGOTIATE - HTTP GSS-Negotiate authentication | ||||||
|                                          type to force no auth or just that |  * CURLAUTH_NTLM         - HTTP NTLM authentication | ||||||
|                                          single type */ |  * CURLAUTH_DIGEST_IE    - HTTP Digest authentication with IE flavour | ||||||
| #define CURLAUTH_ANY (~CURLAUTH_DIGEST_IE)  /* all fine types set */ |  * 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 CURLAUTH_ANYSAFE      (~(CURLAUTH_BASIC|CURLAUTH_DIGEST_IE)) | ||||||
|  |  | ||||||
| #define CURLSSH_AUTH_ANY       ~0     /* all types supported by the server */ | #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_KEYBOARD  (1<<3) /* keyboard interactive */ | ||||||
| #define CURLSSH_AUTH_DEFAULT CURLSSH_AUTH_ANY | #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 | #define CURL_ERROR_SIZE 256 | ||||||
|  |  | ||||||
| struct curl_khkey { | struct curl_khkey { | ||||||
| @@ -664,6 +687,15 @@ typedef enum { | |||||||
|   CURLUSESSL_LAST     /* not an option, never use */ |   CURLUSESSL_LAST     /* not an option, never use */ | ||||||
| } curl_usessl; | } 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 | #ifndef CURL_NO_OLDIES /* define this to test if your app builds with all | ||||||
|                           the obsolete stuff removed! */ |                           the obsolete stuff removed! */ | ||||||
|  |  | ||||||
| @@ -916,9 +948,7 @@ typedef enum { | |||||||
|   /* send linked-list of post-transfer QUOTE commands */ |   /* send linked-list of post-transfer QUOTE commands */ | ||||||
|   CINIT(POSTQUOTE, OBJECTPOINT, 39), |   CINIT(POSTQUOTE, OBJECTPOINT, 39), | ||||||
|  |  | ||||||
|   /* Pass a pointer to string of the output using full variable-replacement |   CINIT(WRITEINFO, OBJECTPOINT, 40), /* DEPRECATED, do not use! */ | ||||||
|      as described elsewhere. */ |  | ||||||
|   CINIT(WRITEINFO, OBJECTPOINT, 40), |  | ||||||
|  |  | ||||||
|   CINIT(VERBOSE, LONG, 41),      /* talk a lot */ |   CINIT(VERBOSE, LONG, 41),      /* talk a lot */ | ||||||
|   CINIT(HEADER, LONG, 42),       /* throw the header out too */ |   CINIT(HEADER, LONG, 42),       /* throw the header out too */ | ||||||
| @@ -994,8 +1024,7 @@ typedef enum { | |||||||
|   /* Max amount of cached alive connections */ |   /* Max amount of cached alive connections */ | ||||||
|   CINIT(MAXCONNECTS, LONG, 71), |   CINIT(MAXCONNECTS, LONG, 71), | ||||||
|  |  | ||||||
|   /* 72 - DEPRECATED */ |   CINIT(CLOSEPOLICY, LONG, 72), /* DEPRECATED, do not use! */ | ||||||
|   CINIT(CLOSEPOLICY, LONG, 72), |  | ||||||
|  |  | ||||||
|   /* 73 = OBSOLETE */ |   /* 73 = OBSOLETE */ | ||||||
|  |  | ||||||
| @@ -1069,7 +1098,7 @@ typedef enum { | |||||||
|   CINIT(SSLENGINE_DEFAULT, LONG, 90), |   CINIT(SSLENGINE_DEFAULT, LONG, 90), | ||||||
|  |  | ||||||
|   /* Non-zero value means to use the global dns cache */ |   /* 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 */ |   /* DNS cache timeout */ | ||||||
|   CINIT(DNS_CACHE_TIMEOUT, LONG, 92), |   CINIT(DNS_CACHE_TIMEOUT, LONG, 92), | ||||||
| @@ -1483,6 +1512,29 @@ typedef enum { | |||||||
|   CINIT(CLOSESOCKETFUNCTION, FUNCTIONPOINT, 208), |   CINIT(CLOSESOCKETFUNCTION, FUNCTIONPOINT, 208), | ||||||
|   CINIT(CLOSESOCKETDATA, OBJECTPOINT, 209), |   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 */ |   CURLOPT_LASTENTRY /* the last unused */ | ||||||
| } CURLoption; | } CURLoption; | ||||||
|  |  | ||||||
| @@ -1586,13 +1638,16 @@ enum CURL_TLSAUTH { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| /* symbols to use with CURLOPT_POSTREDIR. | /* 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 and CURL_REDIR_POST_303 | ||||||
|    CURL_REDIR_POST_301 | CURL_REDIR_POST_302 == CURL_REDIR_POST_ALL */ |    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_GET_ALL  0 | ||||||
| #define CURL_REDIR_POST_301 1 | #define CURL_REDIR_POST_301 1 | ||||||
| #define CURL_REDIR_POST_302 2 | #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 { | typedef enum { | ||||||
|   CURL_TIMECOND_NONE, |   CURL_TIMECOND_NONE, | ||||||
| @@ -2011,7 +2066,8 @@ typedef enum { | |||||||
|   CURLSHE_BAD_OPTION, /* 1 */ |   CURLSHE_BAD_OPTION, /* 1 */ | ||||||
|   CURLSHE_IN_USE,     /* 2 */ |   CURLSHE_IN_USE,     /* 2 */ | ||||||
|   CURLSHE_INVALID,    /* 3 */ |   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 */ |   CURLSHE_LAST        /* never use */ | ||||||
| } CURLSHcode; | } CURLSHcode; | ||||||
|  |  | ||||||
| @@ -2092,8 +2148,9 @@ typedef struct { | |||||||
| #define CURL_VERSION_CONV      (1<<12) /* character conversions supported */ | #define CURL_VERSION_CONV      (1<<12) /* character conversions supported */ | ||||||
| #define CURL_VERSION_CURLDEBUG (1<<13) /* debug memory tracking 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_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() |  * NAME curl_version_info() | ||||||
|  * |  * | ||||||
|  * DESCRIPTION |  * DESCRIPTION | ||||||
|   | |||||||
| @@ -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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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 */ |    a script at release-time. This was made its own header file in 7.11.2 */ | ||||||
|  |  | ||||||
| /* This is the global package copyright */ | /* 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 | /* This is the version number of the libcurl package from which this header | ||||||
|    file origins: */ |    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 | /* The numeric version number is also available "in parts" by using these | ||||||
|    defines: */ |    defines: */ | ||||||
| #define LIBCURL_VERSION_MAJOR 7 | #define LIBCURL_VERSION_MAJOR 7 | ||||||
| #define LIBCURL_VERSION_MINOR 21 | #define LIBCURL_VERSION_MINOR 26 | ||||||
| #define LIBCURL_VERSION_PATCH 7 | #define LIBCURL_VERSION_PATCH 0 | ||||||
|  |  | ||||||
| /* This is the numeric version of the libcurl version number, meant for easier | /* This is the numeric version of the libcurl version number, meant for easier | ||||||
|    parsing and comparions by programs. The LIBCURL_VERSION_NUM define will |    parsing and comparions by programs. The LIBCURL_VERSION_NUM define will | ||||||
| @@ -53,7 +53,7 @@ | |||||||
|    and it is always a greater number in a more recent release. It makes |    and it is always a greater number in a more recent release. It makes | ||||||
|    comparisons with greater than and less than work. |    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 |  * 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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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") */ | /* To define a new warning, use _CURL_WARNING(identifier, "message") */ | ||||||
| #define _CURL_WARNING(id, message)                                            \ | #define _CURL_WARNING(id, message)                                            \ | ||||||
|   static void __attribute__((warning(message))) __attribute__((unused))       \ |   static void __attribute__((__warning__(message)))                           \ | ||||||
|   __attribute__((noinline)) id(void) { __asm__(""); } |   __attribute__((__unused__)) __attribute__((__noinline__))                   \ | ||||||
|  |   id(void) { __asm__(""); } | ||||||
|  |  | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_long, | _CURL_WARNING(_curl_easy_setopt_err_long, | ||||||
|   "curl_easy_setopt expects a long argument for this option") |   "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 */ | /* evaluates to true if expr is abuffer suitable for CURLOPT_ERRORBUFFER */ | ||||||
| /* XXX: also check size of an char[] array? */ | /* XXX: also check size of an char[] array? */ | ||||||
| #define _curl_is_error_buffer(expr)                                           \ | #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[])) |    __builtin_types_compatible_p(__typeof__(expr), char[])) | ||||||
|  |  | ||||||
| /* evaluates to true if expr is of type (const) void* or (const) FILE* */ | /* 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_callback1) ||                \ | ||||||
|    _curl_callback_compatible((expr), _curl_debug_callback2) ||                \ |    _curl_callback_compatible((expr), _curl_debug_callback2) ||                \ | ||||||
|    _curl_callback_compatible((expr), _curl_debug_callback3) ||                \ |    _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 *, | typedef int (_curl_debug_callback1) (CURL *, | ||||||
|     curl_infotype, char *, size_t, void *); |     curl_infotype, char *, size_t, void *); | ||||||
| typedef int (_curl_debug_callback2) (CURL *, | typedef int (_curl_debug_callback2) (CURL *, | ||||||
| @@ -530,6 +536,14 @@ typedef int (_curl_debug_callback3) (CURL *, | |||||||
|     curl_infotype, const char *, size_t, void *); |     curl_infotype, const char *, size_t, void *); | ||||||
| typedef int (_curl_debug_callback4) (CURL *, | typedef int (_curl_debug_callback4) (CURL *, | ||||||
|     curl_infotype, const char *, size_t, const void *); |     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" */ | /* evaluates to true if expr is of type curl_ssl_ctx_callback or "similar" */ | ||||||
| /* this is getting even messier... */ | /* this is getting even messier... */ | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -10,3 +10,4 @@ libcurl.plist.dist | |||||||
| libcurl.vcproj | libcurl.vcproj | ||||||
| vc6libcurl.dsp | vc6libcurl.dsp | ||||||
| Makefile.vc10.dist | Makefile.vc10.dist | ||||||
|  | libcurl.vers | ||||||
|   | |||||||
| @@ -83,13 +83,13 @@ CFLAGS += -dWANT_IDN_PROTOTYPES | |||||||
| !ifdef %zlib_root | !ifdef %zlib_root | ||||||
| ZLIB_ROOT = $(%zlib_root) | ZLIB_ROOT = $(%zlib_root) | ||||||
| !else | !else | ||||||
| ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.5 | ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.7 | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
| !ifdef %libssh2_root | !ifdef %libssh2_root | ||||||
| LIBSSH2_ROOT = $(%libssh2_root) | LIBSSH2_ROOT = $(%libssh2_root) | ||||||
| !else | !else | ||||||
| LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.2.8 | LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.4.2 | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
| !ifdef %librtmp_root | !ifdef %librtmp_root | ||||||
| @@ -101,7 +101,7 @@ LIBRTMP_ROOT = ..$(DS)..$(DS)rtmpdump-2.3 | |||||||
| !ifdef %openssl_root | !ifdef %openssl_root | ||||||
| OPENSSL_ROOT = $(%openssl_root) | OPENSSL_ROOT = $(%openssl_root) | ||||||
| !else | !else | ||||||
| OPENSSL_ROOT = ..$(DS)..$(DS)openssl-0.9.8r | OPENSSL_ROOT = ..$(DS)..$(DS)openssl-0.9.8x | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
| !ifdef %ares_root | !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 | # This software is licensed as described in the file COPYING, which | ||||||
| # you should have received as part of this distribution. The terms | # 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)                 \ | EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 $(DSP)                 \ | ||||||
|  vc6libcurl.dsw config-win32.h config-win32ce.h config-riscos.h            \ |  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      \ |  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   \ |  Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot   \ | ||||||
|  config-win32ce.h config-os400.h setup-os400.h config-symbian.h		   \ |  config-win32ce.h config-os400.h setup-os400.h config-symbian.h		   \ | ||||||
|  Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl		   \ |  Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl		   \ | ||||||
| @@ -48,6 +48,8 @@ LIBCURL_LIBS = @LIBCURL_LIBS@ | |||||||
| # This might hold -Werror | # This might hold -Werror | ||||||
| CFLAGS += @CURL_CFLAG_EXTRAS@ | 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 | # 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 | # $(top_builddir), to ensure that these paths which belong to the library | ||||||
| # being currently built and tested are searched before the library which | # 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 |            -I$(top_srcdir)/lib | ||||||
| endif | 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 | if SONAME_BUMP | ||||||
| # | # | ||||||
| # Bumping of SONAME conditionally may seem like a weird thing to do, and yeah | # Bumping of SONAME conditionally may seem like a weird thing to do, and yeah | ||||||
| @@ -116,7 +130,19 @@ if MIMPURE | |||||||
| MIMPURE = -mimpure-text | MIMPURE = -mimpure-text | ||||||
| endif | 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 | # unit testing static library built only along with unit tests | ||||||
| if BUILD_UNITTESTS | if BUILD_UNITTESTS | ||||||
| @@ -127,6 +153,7 @@ endif | |||||||
|  |  | ||||||
| libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS | libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS | ||||||
| libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS) | libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS) | ||||||
|  | libcurlu_la_CFLAGS = $(AM_CFLAGS) | ||||||
|  |  | ||||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||||
| include Makefile.inc | include Makefile.inc | ||||||
|   | |||||||
| @@ -22,12 +22,12 @@ BCCDIR = $(MAKEDIR)\.. | |||||||
|  |  | ||||||
| # Edit the path below to point to the base of your Zlib sources. | # Edit the path below to point to the base of your Zlib sources. | ||||||
| !ifndef ZLIB_PATH | !ifndef ZLIB_PATH | ||||||
| ZLIB_PATH = ..\..\zlib-1.2.5 | ZLIB_PATH = ..\..\zlib-1.2.7 | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your OpenSSL package. | # Edit the path below to point to the base of your OpenSSL package. | ||||||
| !ifndef OPENSSL_PATH | !ifndef OPENSSL_PATH | ||||||
| OPENSSL_PATH = ..\..\openssl-0.9.8q | OPENSSL_PATH = ..\..\openssl-0.9.8x | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
| # Set libcurl static lib, dll and import lib | # 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		\ |   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	\ |   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	\ |   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	\ |   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	\ |   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		\ |   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		\ |   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		\ |   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	\ |   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	\ | 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	\ |   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	\ |   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		\ |   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	\ |   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	\ |   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	\ |   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	\ |   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_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	\ |   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	\ |   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) | ## Makefile for building libcurl.a with MingW (GCC-3.2 or later) | ||||||
| ## and optionally OpenSSL (0.9.8), libssh2 (1.2), zlib (1.2.5), librtmp (2.3) | ## 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][...] | ## Usage:   mingw32-make -f Makefile.m32 CFG=-feature1[-feature2][-feature3][...] | ||||||
| ## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-sspi-winidn | ## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-sspi-winidn | ||||||
| ## | ## | ||||||
| ## Hint: you can also set environment vars to control the build, f.e.: | ## 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 | ## 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. | # Edit the path below to point to the base of your Zlib sources. | ||||||
| ifndef ZLIB_PATH | ifndef ZLIB_PATH | ||||||
| ZLIB_PATH = ../../zlib-1.2.5 | ZLIB_PATH = ../../zlib-1.2.7 | ||||||
| endif | endif | ||||||
| # Edit the path below to point to the base of your OpenSSL package. | # Edit the path below to point to the base of your OpenSSL package. | ||||||
| ifndef OPENSSL_PATH | 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 | endif | ||||||
| # Edit the path below to point to the base of your LibSSH2 package. | # Edit the path below to point to the base of your LibSSH2 package. | ||||||
| ifndef LIBSSH2_PATH | ifndef LIBSSH2_PATH | ||||||
| LIBSSH2_PATH = ../../libssh2-1.2.8 | LIBSSH2_PATH = ../../libssh2-1.4.2 | ||||||
| endif | endif | ||||||
| # Edit the path below to point to the base of your librtmp package. | # Edit the path below to point to the base of your librtmp package. | ||||||
| ifndef LIBRTMP_PATH | ifndef LIBRTMP_PATH | ||||||
| @@ -34,7 +41,7 @@ endif | |||||||
| ifndef LIBIDN_PATH | ifndef LIBIDN_PATH | ||||||
| LIBIDN_PATH = ../../libidn-1.18 | LIBIDN_PATH = ../../libidn-1.18 | ||||||
| endif | 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 | # Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1 | ||||||
| # http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815 | # http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815 | ||||||
| ifndef WINIDN_PATH | ifndef WINIDN_PATH | ||||||
| @@ -45,22 +52,35 @@ ifndef LDAP_SDK | |||||||
| LDAP_SDK = c:/novell/ndk/cldapsdk/win32 | LDAP_SDK = c:/novell/ndk/cldapsdk/win32 | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  | PROOT = .. | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your c-ares package. | # Edit the path below to point to the base of your c-ares package. | ||||||
| ifndef LIBCARES_PATH | 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 | endif | ||||||
|  |  | ||||||
| CC = gcc | CC = gcc | ||||||
| CFLAGS = -g -O2 -Wall | CFLAGS = -g -O2 -Wall | ||||||
|  | CFLAGS += -fno-strict-aliasing | ||||||
|  | ifeq ($(ARCH),w64) | ||||||
|  | CFLAGS += -D_AMD64_ | ||||||
|  | endif | ||||||
| # comment LDFLAGS below to keep debug info | # comment LDFLAGS below to keep debug info | ||||||
| LDFLAGS = -s | LDFLAGS = -s | ||||||
| AR = ar | AR = ar | ||||||
| RANLIB = ranlib | RANLIB = ranlib | ||||||
| RC = windres | RC = windres | ||||||
| RCFLAGS = --include-dir=../include -DDEBUGBUILD=0 -O COFF -i | RCFLAGS = --include-dir=$(PROOT)/include -DDEBUGBUILD=0 -O COFF -i | ||||||
| RM = del /q /f 2>NUL |  | ||||||
| STRIP = strip -g | STRIP = strip -g | ||||||
|  |  | ||||||
|  | RM = del /q /f 2>NUL | ||||||
|  | CP = copy | ||||||
|  |  | ||||||
| ######################################################## | ######################################################## | ||||||
| ## Nothing more to do below this line! | ## Nothing more to do below this line! | ||||||
|  |  | ||||||
| @@ -95,6 +115,9 @@ endif | |||||||
| ifeq ($(findstring -sspi,$(CFG)),-sspi) | ifeq ($(findstring -sspi,$(CFG)),-sspi) | ||||||
| SSPI = 1 | SSPI = 1 | ||||||
| endif | endif | ||||||
|  | ifeq ($(findstring -spnego,$(CFG)),-spnego) | ||||||
|  | SPNEGO = 1 | ||||||
|  | endif | ||||||
| ifeq ($(findstring -ldaps,$(CFG)),-ldaps) | ifeq ($(findstring -ldaps,$(CFG)),-ldaps) | ||||||
| LDAPS = 1 | LDAPS = 1 | ||||||
| endif | endif | ||||||
| @@ -104,10 +127,11 @@ endif | |||||||
|  |  | ||||||
| INCLUDES = -I. -I../include | INCLUDES = -I. -I../include | ||||||
| CFLAGS += -DBUILDING_LIBCURL | CFLAGS += -DBUILDING_LIBCURL | ||||||
|  |  | ||||||
| ifdef ARES | ifdef ARES | ||||||
|   INCLUDES += -I$(LIBCARES_PATH) |   INCLUDES += -I"$(LIBCARES_PATH)" | ||||||
|   CFLAGS += -DUSE_ARES |   CFLAGS += -DUSE_ARES | ||||||
|   DLL_LIBS += -L$(LIBCARES_PATH) -lcares |   DLL_LIBS += -L"$(LIBCARES_PATH)" -lcares | ||||||
|   libcurl_dll_DEPENDENCIES = $(LIBCARES_PATH)/libcares.a |   libcurl_dll_DEPENDENCIES = $(LIBCARES_PATH)/libcares.a | ||||||
| endif | endif | ||||||
| ifdef RTMP | ifdef RTMP | ||||||
| @@ -118,37 +142,39 @@ endif | |||||||
| ifdef SSH2 | ifdef SSH2 | ||||||
|   INCLUDES += -I"$(LIBSSH2_PATH)/include" -I"$(LIBSSH2_PATH)/win32" |   INCLUDES += -I"$(LIBSSH2_PATH)/include" -I"$(LIBSSH2_PATH)/win32" | ||||||
|   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H |   CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H | ||||||
|   DLL_LIBS += -L$(LIBSSH2_PATH)/win32 -lssh2 |   DLL_LIBS += -L"$(LIBSSH2_PATH)/win32" -lssh2 | ||||||
| endif | endif | ||||||
| ifdef SSL | 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 \ |   CFLAGS += -DUSE_SSLEAY -DUSE_OPENSSL -DHAVE_OPENSSL_ENGINE_H -DHAVE_OPENSSL_PKCS12_H \ | ||||||
|             -DHAVE_ENGINE_LOAD_BUILTIN_ENGINES -DOPENSSL_NO_KRB5 \ |             -DHAVE_ENGINE_LOAD_BUILTIN_ENGINES -DOPENSSL_NO_KRB5 \ | ||||||
|             -DCURL_WANTS_CA_BUNDLE_ENV |             -DCURL_WANTS_CA_BUNDLE_ENV | ||||||
|   DLL_LIBS += -L$(OPENSSL_PATH)/out -leay32 -lssl32 |   DLL_LIBS += -L"$(OPENSSL_LIBPATH)" $(OPENSSL_LIBS) | ||||||
| endif | endif | ||||||
| ifdef ZLIB | ifdef ZLIB | ||||||
|   INCLUDES += -I"$(ZLIB_PATH)" |   INCLUDES += -I"$(ZLIB_PATH)" | ||||||
|   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H |   CFLAGS += -DHAVE_LIBZ -DHAVE_ZLIB_H | ||||||
|   DLL_LIBS += -L$(ZLIB_PATH) -lz |   DLL_LIBS += -L"$(ZLIB_PATH)" -lz | ||||||
| endif | endif | ||||||
| ifdef IDN | ifdef IDN | ||||||
|   INCLUDES += -I"$(LIBIDN_PATH)/include" |   INCLUDES += -I"$(LIBIDN_PATH)/include" | ||||||
|   CFLAGS += -DUSE_LIBIDN |   CFLAGS += -DUSE_LIBIDN | ||||||
|   DLL_LIBS += -L$(LIBIDN_PATH)/lib -lidn |   DLL_LIBS += -L"$(LIBIDN_PATH)/lib" -lidn | ||||||
| else | else | ||||||
| ifdef WINIDN | ifdef WINIDN | ||||||
|   INCLUDES += -I"$(WINIDN_PATH)/include" |  | ||||||
|   CFLAGS += -DHAVE_NORMALIZATION_H |  | ||||||
|   CFLAGS += -DUSE_WIN32_IDN |   CFLAGS += -DUSE_WIN32_IDN | ||||||
|  |   CFLAGS += -DWANT_IDN_PROTOTYPES | ||||||
|   DLL_LIBS += -L"$(WINIDN_PATH)" -lnormaliz |   DLL_LIBS += -L"$(WINIDN_PATH)" -lnormaliz | ||||||
| endif | endif | ||||||
| endif | endif | ||||||
| ifdef SSPI | ifdef SSPI | ||||||
|   CFLAGS += -DUSE_WINDOWS_SSPI |   CFLAGS += -DUSE_WINDOWS_SSPI | ||||||
| endif | endif | ||||||
|  | ifdef SPNEGO | ||||||
|  |   CFLAGS += -DHAVE_SPNEGO | ||||||
|  | endif | ||||||
| ifdef IPV6 | ifdef IPV6 | ||||||
|   CFLAGS += -DENABLE_IPV6 |   CFLAGS += -DENABLE_IPV6 -D_WIN32_WINNT=0x0501 | ||||||
| endif | endif | ||||||
| ifdef LDAPS | ifdef LDAPS | ||||||
|   CFLAGS += -DHAVE_LDAP_SSL |   CFLAGS += -DHAVE_LDAP_SSL | ||||||
| @@ -165,11 +191,10 @@ ifdef USE_LDAP_OPENLDAP | |||||||
| endif | endif | ||||||
| ifndef USE_LDAP_NOVELL | ifndef USE_LDAP_NOVELL | ||||||
| ifndef USE_LDAP_OPENLDAP | ifndef USE_LDAP_OPENLDAP | ||||||
| DLL_LIBS += -lwldap32 |   DLL_LIBS += -lwldap32 | ||||||
| endif | endif | ||||||
| endif | endif | ||||||
| DLL_LIBS += -lws2_32 | DLL_LIBS += -lws2_32 | ||||||
| COMPILE = $(CC) $(INCLUDES) $(CFLAGS) |  | ||||||
|  |  | ||||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||||
| include Makefile.inc | include Makefile.inc | ||||||
| @@ -183,7 +208,6 @@ libcurl_a_DEPENDENCIES := $(strip $(CSOURCES) $(HHEADERS)) | |||||||
|  |  | ||||||
| RESOURCE = libcurl.res | RESOURCE = libcurl.res | ||||||
|  |  | ||||||
| .SUFFIXES: .rc .res |  | ||||||
|  |  | ||||||
| all: $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) | 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) \ | 	$(CC) $(LDFLAGS) -shared -Wl,--out-implib,$(libcurl_dll_a_LIBRARY) \ | ||||||
| 	  -o $@ $(libcurl_a_OBJECTS) $(RESOURCE) $(DLL_LIBS) | 	  -o $@ $(libcurl_a_OBJECTS) $(RESOURCE) $(DLL_LIBS) | ||||||
|  |  | ||||||
| .c.o: | %.o: %.c $(PROOT)/include/curl/curlbuild.h | ||||||
| 	$(COMPILE) -c $< | 	$(CC) $(INCLUDES) $(CFLAGS) -c $< | ||||||
|  |  | ||||||
| .rc.res: | %.res: %.rc | ||||||
| 	$(RC) $(RCFLAGS) $< -o $@ | 	$(RC) $(RCFLAGS) $< -o $@ | ||||||
|  |  | ||||||
| clean: | 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) | 	-$(RM) $(libcurl_a_OBJECTS) $(RESOURCE) | ||||||
|  |  | ||||||
| distclean vclean: clean | distclean vclean: clean | ||||||
| 	-$(RM) $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_a_LIBRARY) | 	-$(RM) $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_a_LIBRARY) | ||||||
|  |  | ||||||
| FORCE: ; |  | ||||||
|  |  | ||||||
| $(LIBCARES_PATH)/libcares.a: | $(LIBCARES_PATH)/libcares.a: | ||||||
| 	$(MAKE) -C $(LIBCARES_PATH) -f Makefile.m32 | 	$(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. | # Edit the path below to point to the base of your Zlib sources. | ||||||
| ifndef ZLIB_PATH | ifndef ZLIB_PATH | ||||||
| ZLIB_PATH = ../../zlib-1.2.5 | ZLIB_PATH = ../../zlib-1.2.7 | ||||||
| endif | endif | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your OpenSSL package. | # Edit the path below to point to the base of your OpenSSL package. | ||||||
| ifndef OPENSSL_PATH | ifndef OPENSSL_PATH | ||||||
| OPENSSL_PATH = ../../openssl-0.9.8r | OPENSSL_PATH = ../../openssl-0.9.8x | ||||||
| endif | endif | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your LibSSH2 package. | # Edit the path below to point to the base of your LibSSH2 package. | ||||||
| ifndef LIBSSH2_PATH | ifndef LIBSSH2_PATH | ||||||
| LIBSSH2_PATH = ../../libssh2-1.2.8 | LIBSSH2_PATH = ../../libssh2-1.4.2 | ||||||
| endif | endif | ||||||
|  |  | ||||||
| # Edit the path below to point to the base of your axTLS package. | # 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 | LIBRTMP_PATH = ../../librtmp-2.3 | ||||||
| endif | 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. | # Edit the path below to point to the base of your c-ares package. | ||||||
| ifndef LIBCARES_PATH | ifndef LIBCARES_PATH | ||||||
| LIBCARES_PATH = ../ares | LIBCARES_PATH = ../ares | ||||||
| @@ -95,7 +100,7 @@ else | |||||||
| endif | endif | ||||||
| PERL	= perl | PERL	= perl | ||||||
| # Here you can find a native Win32 binary of the original awk: | # 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 | AWK	= awk | ||||||
| CP	= cp -afv | CP	= cp -afv | ||||||
| MKDIR	= mkdir | MKDIR	= mkdir | ||||||
| @@ -181,6 +186,43 @@ CURL_LIB = ../lib | |||||||
|  |  | ||||||
| INCLUDES = -I$(CURL_INC) -I$(CURL_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 | ifdef WITH_ARES | ||||||
| 	INCLUDES += -I$(LIBCARES_PATH) | 	INCLUDES += -I$(LIBCARES_PATH) | ||||||
| 	LDLIBS += $(LIBCARES_PATH)/libcares.$(LIBEXT) | 	LDLIBS += $(LIBCARES_PATH)/libcares.$(LIBEXT) | ||||||
| @@ -204,6 +246,10 @@ ifdef WITH_SSL | |||||||
| 	LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/crypto.$(LIBEXT) | 	LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/crypto.$(LIBEXT) | ||||||
| 	IMPORTS += GetProcessSwitchCount RunningProcess | 	IMPORTS += GetProcessSwitchCount RunningProcess | ||||||
| 	INSTDEP += ca-bundle.crt | 	INSTDEP += ca-bundle.crt | ||||||
|  | ifdef WITH_SPNEGO | ||||||
|  | 	INCLUDES += -I$(FBOPENSSL_PATH)/include | ||||||
|  | 	LDLIBS += $(FBOPENSSL_PATH)/nw/fbopenssl.$(LIBEXT) | ||||||
|  | endif | ||||||
| else | else | ||||||
| ifdef WITH_AXTLS | ifdef WITH_AXTLS | ||||||
| 	INCLUDES += -I$(AXTLS_PATH)/inc | 	INCLUDES += -I$(AXTLS_PATH)/inc | ||||||
| @@ -498,6 +544,7 @@ endif | |||||||
| 	@echo $(DL)#define USE_MANUAL 1$(DL) >> $@ | 	@echo $(DL)#define USE_MANUAL 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_ARPA_INET_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_ARPA_INET_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_ASSERT_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_ERR_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_FCNTL_H 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_FCNTL_H 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_GETHOSTBYADDR 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_LIBSSL 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define HAVE_LIBCRYPTO 1$(DL) >> $@ | 	@echo $(DL)#define HAVE_LIBCRYPTO 1$(DL) >> $@ | ||||||
| 	@echo $(DL)#define OPENSSL_NO_KRB5 1$(DL) >> $@ | 	@echo $(DL)#define OPENSSL_NO_KRB5 1$(DL) >> $@ | ||||||
|  | ifdef WITH_SPNEGO | ||||||
|  | 	@echo $(DL)#define HAVE_SPNEGO 1$(DL) >> $@ | ||||||
|  | endif | ||||||
| else | else | ||||||
| ifdef WITH_AXTLS | ifdef WITH_AXTLS | ||||||
| 	@echo $(DL)#define USE_AXTLS 1$(DL) >> $@ | 	@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 | # Makefile for building libcurl with MSVC6 | ||||||
| @@ -59,15 +64,16 @@ | |||||||
|  |  | ||||||
| !INCLUDE ..\Makefile.msvc.names | !INCLUDE ..\Makefile.msvc.names | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| !IFNDEF OPENSSL_PATH | !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 | !ENDIF | ||||||
|  |  | ||||||
| !IFNDEF ZLIB_PATH | !IFNDEF ZLIB_PATH | ||||||
| ZLIB_PATH  = ../../zlib-1.2.5 | ZLIB_PATH  = ../../zlib-1.2.7 | ||||||
| !ENDIF | !ENDIF | ||||||
|  |  | ||||||
| !IFNDEF MACHINE | !IFNDEF MACHINE | ||||||
| @@ -100,6 +106,7 @@ WINDOWS_SDK_PATH = "$(PROGRAMFILES)\Microsoft SDK" | |||||||
| CCNODBG    = cl.exe /O2 /DNDEBUG | CCNODBG    = cl.exe /O2 /DNDEBUG | ||||||
| CCDEBUG    = cl.exe /Od /Gm /Zi /D_DEBUG /GZ | CCDEBUG    = cl.exe /Od /Gm /Zi /D_DEBUG /GZ | ||||||
| CFLAGSSSL  = /DUSE_SSLEAY /I "$(OPENSSL_PATH)/inc32" /I "$(OPENSSL_PATH)/inc32/openssl" | 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)" | 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 | CFLAGS     = /I. /I../include /nologo /W3 /GX /DWIN32 /YX /FD /c /DBUILDING_LIBCURL /D_BIND_TO_CURRENT_VCLIBS_VERSION=1 | ||||||
| CFLAGSLIB  = /DCURL_STATICLIB | CFLAGSLIB  = /DCURL_STATICLIB | ||||||
| @@ -219,6 +226,36 @@ CC       = $(CCNODBG) $(RTLIB) $(CFLAGSSSL) $(CFLAGSZLIB) $(CFLAGSLIB) | |||||||
| CFGSET   = TRUE | CFGSET   = TRUE | ||||||
| !ENDIF | !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 | # release-dll | ||||||
|  |  | ||||||
| @@ -418,6 +455,7 @@ RESOURCE = $(DIROBJ)\libcurl.res | |||||||
| !MESSAGE   release-ssl                  - release static library with ssl | !MESSAGE   release-ssl                  - release static library with ssl | ||||||
| !MESSAGE   release-zlib                 - release static library with zlib | !MESSAGE   release-zlib                 - release static library with zlib | ||||||
| !MESSAGE   release-ssl-zlib             - release static library with ssl and 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-ssl-dll              - release static library with dynamic ssl | ||||||
| !MESSAGE   release-zlib-dll             - release static library with dynamic zlib | !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 | !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-ssl-dll          - release dynamic library with dynamic ssl | ||||||
| !MESSAGE   release-dll-zlib-dll         - release dynamic library with dynamic zlib | !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   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                        - debug static library | ||||||
| !MESSAGE   debug-ssl                    - debug static library with ssl | !MESSAGE   debug-ssl                    - debug static library with ssl | ||||||
| !MESSAGE   debug-zlib                   - debug static library with zlib | !MESSAGE   debug-zlib                   - debug static library with zlib | ||||||
| @@ -467,6 +506,10 @@ X_OBJS= \ | |||||||
| 	$(DIROBJ)\curl_fnmatch.obj \ | 	$(DIROBJ)\curl_fnmatch.obj \ | ||||||
| 	$(DIROBJ)\curl_gethostname.obj \ | 	$(DIROBJ)\curl_gethostname.obj \ | ||||||
| 	$(DIROBJ)\curl_memrchr.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_rand.obj \ | ||||||
| 	$(DIROBJ)\curl_rtmp.obj \ | 	$(DIROBJ)\curl_rtmp.obj \ | ||||||
| 	$(DIROBJ)\curl_sspi.obj \ | 	$(DIROBJ)\curl_sspi.obj \ | ||||||
| @@ -494,7 +537,6 @@ X_OBJS= \ | |||||||
| 	$(DIROBJ)\http_digest.obj \ | 	$(DIROBJ)\http_digest.obj \ | ||||||
| 	$(DIROBJ)\http_negotiate.obj \ | 	$(DIROBJ)\http_negotiate.obj \ | ||||||
|         $(DIROBJ)\http_negotiate_sspi.obj \ |         $(DIROBJ)\http_negotiate_sspi.obj \ | ||||||
| 	$(DIROBJ)\http_ntlm.obj \ |  | ||||||
| 	$(DIROBJ)\http.obj \ | 	$(DIROBJ)\http.obj \ | ||||||
| 	$(DIROBJ)\http_proxy.obj \ | 	$(DIROBJ)\http_proxy.obj \ | ||||||
| 	$(DIROBJ)\if2ip.obj \ | 	$(DIROBJ)\if2ip.obj \ | ||||||
|   | |||||||
| @@ -33,10 +33,10 @@ BUILD_TYPE := debug | |||||||
| USER_CFLAGS:= | USER_CFLAGS:= | ||||||
|  |  | ||||||
| # directories where to seek for includes and libraries | # directories where to seek for includes and libraries | ||||||
| OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3/include | OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8x-vxWorks6.3/include | ||||||
| OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3 | OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8x-vxWorks6.3 | ||||||
| ZLIB_INC    := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/zlib-1.2.3 | ZLIB_INC    := D:/libraries/zlib/zlib-1.2.7-VxWorks6.3/zlib-1.2.7 | ||||||
| ZLIB_LIB    := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib | ZLIB_LIB    := D:/libraries/zlib/zlib-1.2.7-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib | ||||||
| ARES_INC    := | ARES_INC    := | ||||||
| ARES_LIB    := | 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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * 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 "amigaos.h" | ||||||
| #include <amitcp/socketbasetags.h> |  | ||||||
|  |  | ||||||
| struct Library *SocketBase = NULL; | struct Library *SocketBase = NULL; | ||||||
| extern int errno, h_errno; | extern int errno, h_errno; | ||||||
| @@ -35,7 +38,7 @@ void __request(const char *msg); | |||||||
| # define __request( msg )       Printf( msg "\n\a") | # define __request( msg )       Printf( msg "\n\a") | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| void amiga_cleanup() | void Curl_amiga_cleanup() | ||||||
| { | { | ||||||
|   if(SocketBase) { |   if(SocketBase) { | ||||||
|     CloseLibrary(SocketBase); |     CloseLibrary(SocketBase); | ||||||
| @@ -43,7 +46,7 @@ void amiga_cleanup() | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| BOOL amiga_init() | bool Curl_amiga_init() | ||||||
| { | { | ||||||
|   if(!SocketBase) |   if(!SocketBase) | ||||||
|     SocketBase = OpenLibrary("bsdsocket.library", 4); |     SocketBase = OpenLibrary("bsdsocket.library", 4); | ||||||
| @@ -61,20 +64,14 @@ BOOL amiga_init() | |||||||
|   } |   } | ||||||
|  |  | ||||||
| #ifndef __libnix__ | #ifndef __libnix__ | ||||||
|   atexit(amiga_cleanup); |   atexit(Curl_amiga_cleanup); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   return TRUE; |   return TRUE; | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef __libnix__ | #ifdef __libnix__ | ||||||
| ADD2EXIT(amiga_cleanup,-50); | ADD2EXIT(Curl_amiga_cleanup,-50); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #else /* __AMIGA__ */ | #endif /* __AMIGA__ && ! __ixemul__ */ | ||||||
|  |  | ||||||
| #ifdef __POCC__ |  | ||||||
| #  pragma warn(disable:2024)  /* Disable warning #2024: Empty input file */ |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif /* __AMIGA__ */ |  | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| #ifndef LIBCURL_AMIGAOS_H | #ifndef HEADER_CURL_AMIGAOS_H | ||||||
| #define LIBCURL_AMIGAOS_H | #define HEADER_CURL_AMIGAOS_H | ||||||
| /*************************************************************************** | /*************************************************************************** | ||||||
|  *                                  _   _ ____  _ |  *                                  _   _ ____  _ | ||||||
|  *  Project                     ___| | | |  _ \| | |  *  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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -21,37 +21,19 @@ | |||||||
|  * KIND, either express or implied. |  * 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> | #else | ||||||
| #include <exec/execbase.h> |  | ||||||
|  |  | ||||||
| #include <proto/exec.h> | #define Curl_amiga_init() 1 | ||||||
| #include <proto/dos.h> | #define Curl_amiga_cleanup() Curl_nop_stmt | ||||||
|  |  | ||||||
| #include <sys/socket.h> |  | ||||||
|  |  | ||||||
| #include "config-amigaos.h" |  | ||||||
|  |  | ||||||
| #ifndef select |  | ||||||
| # define select(args...) WaitSelect( args, NULL) |  | ||||||
| #endif | #endif | ||||||
| #ifndef ioctl |  | ||||||
| # define ioctl(a,b,c,d)  IoctlSocket( (LONG)a, (ULONG)b, (char*)c) |  | ||||||
| #endif |  | ||||||
| #define _AMIGASF        1 |  | ||||||
|  |  | ||||||
| extern void amiga_cleanup(); | #endif /* HEADER_CURL_AMIGAOS_H */ | ||||||
| extern BOOL amiga_init(); |  | ||||||
|  |  | ||||||
| #else /* __ixemul__ */ |  | ||||||
|  |  | ||||||
| #warning compiling with ixemul... |  | ||||||
|  |  | ||||||
| #endif /* __ixemul__ */ |  | ||||||
| #endif /* __AMIGA__ */ |  | ||||||
| #endif /* LIBCURL_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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -26,9 +26,11 @@ | |||||||
|  * Telnet option defines. Add more here if in need. |  * Telnet option defines. Add more here if in need. | ||||||
|  */ |  */ | ||||||
| #define CURL_TELOPT_BINARY   0  /* binary 8bit data */ | #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_SGA      3  /* Suppress Go Ahead */ | ||||||
| #define CURL_TELOPT_EXOPL  255  /* EXtended OPtions List */ | #define CURL_TELOPT_EXOPL  255  /* EXtended OPtions List */ | ||||||
| #define CURL_TELOPT_TTYPE   24  /* Terminal TYPE */ | #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_XDISPLOC 35 /* X DISPlay LOCation */ | ||||||
|  |  | ||||||
| #define CURL_TELOPT_NEW_ENVIRON 39  /* NEW ENVIRONment variables */ | #define CURL_TELOPT_NEW_ENVIRON 39  /* NEW ENVIRONment variables */ | ||||||
|   | |||||||
| @@ -22,8 +22,6 @@ | |||||||
|  |  | ||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #include <string.h> |  | ||||||
|  |  | ||||||
| #ifdef HAVE_LIMITS_H | #ifdef HAVE_LIMITS_H | ||||||
| #include <limits.h> | #include <limits.h> | ||||||
| #endif | #endif | ||||||
| @@ -39,16 +37,12 @@ | |||||||
| #ifdef HAVE_ARPA_INET_H | #ifdef HAVE_ARPA_INET_H | ||||||
| #include <arpa/inet.h> | #include <arpa/inet.h> | ||||||
| #endif | #endif | ||||||
| #ifdef HAVE_STDLIB_H |  | ||||||
| #include <stdlib.h>     /* required for free() prototypes */ |  | ||||||
| #endif |  | ||||||
| #ifdef HAVE_UNISTD_H | #ifdef HAVE_UNISTD_H | ||||||
| #include <unistd.h>     /* for the close() proto */ | #include <unistd.h>     /* for the close() proto */ | ||||||
| #endif | #endif | ||||||
| #ifdef __VMS | #ifdef __VMS | ||||||
| #include <in.h> | #include <in.h> | ||||||
| #include <inet.h> | #include <inet.h> | ||||||
| #include <stdlib.h> |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef HAVE_PROCESS_H | #ifdef HAVE_PROCESS_H | ||||||
| @@ -233,18 +227,19 @@ int Curl_resolver_getsock(struct connectdata *conn, | |||||||
|   struct timeval maxtime; |   struct timeval maxtime; | ||||||
|   struct timeval timebuf; |   struct timeval timebuf; | ||||||
|   struct timeval *timeout; |   struct timeval *timeout; | ||||||
|  |   long milli; | ||||||
|   int max = ares_getsock((ares_channel)conn->data->state.resolver, |   int max = ares_getsock((ares_channel)conn->data->state.resolver, | ||||||
|                          (ares_socket_t *)socks, numsocks); |                          (ares_socket_t *)socks, numsocks); | ||||||
|  |  | ||||||
|  |  | ||||||
|   maxtime.tv_sec = CURL_TIMEOUT_RESOLVE; |   maxtime.tv_sec = CURL_TIMEOUT_RESOLVE; | ||||||
|   maxtime.tv_usec = 0; |   maxtime.tv_usec = 0; | ||||||
|  |  | ||||||
|   timeout = ares_timeout((ares_channel)conn->data->state.resolver, &maxtime, |   timeout = ares_timeout((ares_channel)conn->data->state.resolver, &maxtime, | ||||||
|                          &timebuf); |                          &timebuf); | ||||||
|  |   milli = (timeout->tv_sec * 1000) + (timeout->tv_usec/1000); | ||||||
|   Curl_expire(conn->data, |   if(milli == 0) | ||||||
|               (timeout->tv_sec * 1000) + (timeout->tv_usec/1000)); |     milli += 10; | ||||||
|  |   Curl_expire(conn->data, milli); | ||||||
|  |  | ||||||
|   return max; |   return max; | ||||||
| } | } | ||||||
| @@ -336,9 +331,12 @@ CURLcode Curl_resolver_is_resolved(struct connectdata *conn, | |||||||
|     res->temp_ai = NULL; |     res->temp_ai = NULL; | ||||||
|     destroy_async_data(&conn->async); |     destroy_async_data(&conn->async); | ||||||
|     if(!conn->async.dns) { |     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)); |             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; |     *dns = conn->async.dns; | ||||||
|   } |   } | ||||||
| @@ -424,7 +422,7 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn, | |||||||
|   if(!conn->async.dns) { |   if(!conn->async.dns) { | ||||||
|     /* a name was not resolved */ |     /* a name was not resolved */ | ||||||
|     if((timeout < 0) || (conn->async.status == ARES_ETIMEOUT)) { |     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); |         failf(data, "Resolving proxy timed out: %s", conn->proxy.dispname); | ||||||
|         rc = CURLE_COULDNT_RESOLVE_PROXY; |         rc = CURLE_COULDNT_RESOLVE_PROXY; | ||||||
|       } |       } | ||||||
| @@ -434,7 +432,7 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn, | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     else if(conn->async.done) { |     else if(conn->async.done) { | ||||||
|       if(conn->bits.httpproxy) { |       if(conn->bits.proxy) { | ||||||
|         failf(data, "Could not resolve proxy: %s (%s)", conn->proxy.dispname, |         failf(data, "Could not resolve proxy: %s (%s)", conn->proxy.dispname, | ||||||
|               ares_strerror(conn->async.status)); |               ares_strerror(conn->async.status)); | ||||||
|         rc = CURLE_COULDNT_RESOLVE_PROXY; |         rc = CURLE_COULDNT_RESOLVE_PROXY; | ||||||
| @@ -584,6 +582,7 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | |||||||
|     res->last_status = ARES_ENOTFOUND; |     res->last_status = ARES_ENOTFOUND; | ||||||
| #ifdef ENABLE_IPV6 /* CURLRES_IPV6 */ | #ifdef ENABLE_IPV6 /* CURLRES_IPV6 */ | ||||||
|     if(family == PF_UNSPEC) { |     if(family == PF_UNSPEC) { | ||||||
|  |       if(Curl_ipv6works()) { | ||||||
|         res->num_pending = 2; |         res->num_pending = 2; | ||||||
|  |  | ||||||
|         /* areschannel is already setup in the Curl_open() function */ |         /* 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, |         ares_gethostbyname((ares_channel)data->state.resolver, hostname, | ||||||
|                             PF_INET6, query_completed_cb, conn); |                             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 |     else | ||||||
| #endif /* CURLRES_IPV6 */ | #endif /* CURLRES_IPV6 */ | ||||||
|     { |     { | ||||||
| @@ -606,4 +613,31 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | |||||||
|   } |   } | ||||||
|   return NULL; /* no struct yet */ |   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 */ | #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 |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -22,9 +22,6 @@ | |||||||
|  |  | ||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #include <string.h> |  | ||||||
| #include <errno.h> |  | ||||||
|  |  | ||||||
| #ifdef HAVE_SYS_SOCKET_H | #ifdef HAVE_SYS_SOCKET_H | ||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
| @@ -37,16 +34,12 @@ | |||||||
| #ifdef HAVE_ARPA_INET_H | #ifdef HAVE_ARPA_INET_H | ||||||
| #include <arpa/inet.h> | #include <arpa/inet.h> | ||||||
| #endif | #endif | ||||||
| #ifdef HAVE_STDLIB_H |  | ||||||
| #include <stdlib.h>     /* required for free() prototypes */ |  | ||||||
| #endif |  | ||||||
| #ifdef HAVE_UNISTD_H | #ifdef HAVE_UNISTD_H | ||||||
| #include <unistd.h>     /* for the close() proto */ | #include <unistd.h>     /* for the close() proto */ | ||||||
| #endif | #endif | ||||||
| #ifdef __VMS | #ifdef __VMS | ||||||
| #include <in.h> | #include <in.h> | ||||||
| #include <inet.h> | #include <inet.h> | ||||||
| #include <stdlib.h> |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(USE_THREADS_POSIX) | #if defined(USE_THREADS_POSIX) | ||||||
| @@ -182,7 +175,6 @@ struct thread_sync_data { | |||||||
|  |  | ||||||
| struct thread_data { | struct thread_data { | ||||||
|   curl_thread_t thread_hnd; |   curl_thread_t thread_hnd; | ||||||
|   curl_socket_t dummy_sock; |  | ||||||
|   unsigned int poll_interval; |   unsigned int poll_interval; | ||||||
|   int interval_end; |   int interval_end; | ||||||
|   struct thread_sync_data tsd; |   struct thread_sync_data tsd; | ||||||
| @@ -336,9 +328,6 @@ static void destroy_async_data (struct Curl_async *async) | |||||||
|   if(async->os_specific) { |   if(async->os_specific) { | ||||||
|     struct thread_data *td = (struct thread_data*) async->os_specific; |     struct thread_data *td = (struct thread_data*) async->os_specific; | ||||||
|  |  | ||||||
|     if(td->dummy_sock != CURL_SOCKET_BAD) |  | ||||||
|       sclose(td->dummy_sock); |  | ||||||
|  |  | ||||||
|     if(td->thread_hnd != curl_thread_t_null) |     if(td->thread_hnd != curl_thread_t_null) | ||||||
|       Curl_thread_join(&td->thread_hnd); |       Curl_thread_join(&td->thread_hnd); | ||||||
|  |  | ||||||
| @@ -371,7 +360,6 @@ static bool init_resolve_thread (struct connectdata *conn, | |||||||
|   conn->async.done = FALSE; |   conn->async.done = FALSE; | ||||||
|   conn->async.status = 0; |   conn->async.status = 0; | ||||||
|   conn->async.dns = NULL; |   conn->async.dns = NULL; | ||||||
|   td->dummy_sock = CURL_SOCKET_BAD; |  | ||||||
|   td->thread_hnd = curl_thread_t_null; |   td->thread_hnd = curl_thread_t_null; | ||||||
|  |  | ||||||
|   if(!init_thread_sync_data(&td->tsd, hostname, port, hints)) |   if(!init_thread_sync_data(&td->tsd, hostname, port, hints)) | ||||||
| @@ -382,16 +370,6 @@ static bool init_resolve_thread (struct connectdata *conn, | |||||||
|   if(!conn->async.hostname) |   if(!conn->async.hostname) | ||||||
|     goto err_exit; |     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 | #ifdef HAVE_GETADDRINFO | ||||||
|   td->thread_hnd = Curl_thread_create(getaddrinfo_thread, &td->tsd); |   td->thread_hnd = Curl_thread_create(getaddrinfo_thread, &td->tsd); | ||||||
| #else | #else | ||||||
| @@ -421,7 +399,7 @@ static bool init_resolve_thread (struct connectdata *conn, | |||||||
|    socket error string function can be used for this pupose. */ |    socket error string function can be used for this pupose. */ | ||||||
| static const char *gai_strerror(int ecode) | static const char *gai_strerror(int ecode) | ||||||
| { | { | ||||||
|   switch (ecode){ |   switch (ecode) { | ||||||
|   case EAI_AGAIN: |   case EAI_AGAIN: | ||||||
|     return "The name could not be resolved at this time"; |     return "The name could not be resolved at this time"; | ||||||
|   case EAI_BADFLAGS: |   case EAI_BADFLAGS: | ||||||
| @@ -581,17 +559,9 @@ int Curl_resolver_getsock(struct connectdata *conn, | |||||||
|                           curl_socket_t *socks, |                           curl_socket_t *socks, | ||||||
|                           int numsocks) |                           int numsocks) | ||||||
| { | { | ||||||
|   const struct thread_data *td = |   (void)conn; | ||||||
|     (const struct thread_data *) conn->async.os_specific; |   (void)socks; | ||||||
|  |   (void)numsocks; | ||||||
|   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); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -633,14 +603,28 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | |||||||
|                                          int *waitp) |                                          int *waitp) | ||||||
| { | { | ||||||
|   struct addrinfo hints; |   struct addrinfo hints; | ||||||
|  |   struct in_addr in; | ||||||
|   Curl_addrinfo *res; |   Curl_addrinfo *res; | ||||||
|   int error; |   int error; | ||||||
|   char sbuf[NI_MAXSERV]; |   char sbuf[NI_MAXSERV]; | ||||||
|   int pf = PF_INET; |   int pf = PF_INET; | ||||||
|  | #ifdef CURLRES_IPV6 | ||||||
|  |   struct in6_addr in6; | ||||||
|  | #endif /* CURLRES_IPV6 */ | ||||||
|  |  | ||||||
|   *waitp = 0; /* default to synchronous response */ |   *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. |    * 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 */ |     /* the stack seems to be a non-ipv6 one */ | ||||||
|     pf = PF_INET; |     pf = PF_INET; | ||||||
|  |  | ||||||
| #endif /* !CURLRES_IPV4 */ | #endif /* CURLRES_IPV6 */ | ||||||
|  |  | ||||||
|   memset(&hints, 0, sizeof(hints)); |   memset(&hints, 0, sizeof(hints)); | ||||||
|   hints.ai_family = pf; |   hints.ai_family = pf; | ||||||
| @@ -689,4 +673,13 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | |||||||
|  |  | ||||||
| #endif /* !HAVE_GETADDRINFO */ | #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 */ | #endif /* CURLRES_THREADED */ | ||||||
|   | |||||||
| @@ -146,15 +146,15 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn, | |||||||
|  |  | ||||||
| #ifndef CURLRES_ASYNCH | #ifndef CURLRES_ASYNCH | ||||||
| /* convert these functions if an asynch resolver isn't used */ | /* 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_is_resolved(x,y) CURLE_COULDNT_RESOLVE_HOST | ||||||
| #define Curl_resolver_wait_resolv(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_getsock(x,y,z) 0 | ||||||
| #define Curl_resolver_duphandle(x,y) CURLE_OK | #define Curl_resolver_duphandle(x,y) CURLE_OK | ||||||
| #define Curl_resolver_init(x) CURLE_OK | #define Curl_resolver_init(x) CURLE_OK | ||||||
| #define Curl_resolver_global_init() CURLE_OK | #define Curl_resolver_global_init() CURLE_OK | ||||||
| #define Curl_resolver_global_cleanup() | #define Curl_resolver_global_cleanup() Curl_nop_stmt | ||||||
| #define Curl_resolver_cleanup(x) | #define Curl_resolver_cleanup(x) Curl_nop_stmt | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef CURLRES_ASYNCH | #ifdef CURLRES_ASYNCH | ||||||
|   | |||||||
							
								
								
									
										38
									
								
								lib/axtls.c
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								lib/axtls.c
									
									
									
									
									
								
							| @@ -27,13 +27,11 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "setup.h" | #include "setup.h" | ||||||
|  |  | ||||||
| #ifdef USE_AXTLS | #ifdef USE_AXTLS | ||||||
| #include <axTLS/ssl.h> | #include <axTLS/ssl.h> | ||||||
| #include "axtls.h" | #include "axtls.h" | ||||||
|  |  | ||||||
| #include <string.h> |  | ||||||
| #include <stdlib.h> |  | ||||||
| #include <ctype.h> |  | ||||||
| #ifdef HAVE_SYS_SOCKET_H | #ifdef HAVE_SYS_SOCKET_H | ||||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||||
| #endif | #endif | ||||||
| @@ -58,7 +56,7 @@ static int SSL_read(SSL *ssl, void *buf, int num) | |||||||
|  |  | ||||||
|   while((ret = ssl_read(ssl, &read_buf)) == SSL_OK); |   while((ret = ssl_read(ssl, &read_buf)) == SSL_OK); | ||||||
|  |  | ||||||
|   if(ret > SSL_OK){ |   if(ret > SSL_OK) { | ||||||
|     memcpy(buf, read_buf, ret > num ? num : ret); |     memcpy(buf, read_buf, ret > num ? num : ret); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -187,10 +185,10 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|   /* Load the trusted CA cert bundle file */ |   /* Load the trusted CA cert bundle file */ | ||||||
|   if(data->set.ssl.CAfile) { |   if(data->set.ssl.CAfile) { | ||||||
|     if(ssl_obj_load(ssl_ctx, SSL_OBJ_X509_CACERT, data->set.ssl.CAfile, NULL) |     if(ssl_obj_load(ssl_ctx, SSL_OBJ_X509_CACERT, data->set.ssl.CAfile, NULL) | ||||||
|        != SSL_OK){ |        != SSL_OK) { | ||||||
|       infof(data, "error reading ca cert file %s \n", |       infof(data, "error reading ca cert file %s \n", | ||||||
|             data->set.ssl.CAfile); |             data->set.ssl.CAfile); | ||||||
|       if(data->set.ssl.verifypeer){ |       if(data->set.ssl.verifypeer) { | ||||||
|         Curl_axtls_close(conn, sockindex); |         Curl_axtls_close(conn, sockindex); | ||||||
|         return CURLE_SSL_CACERT_BADFILE; |         return CURLE_SSL_CACERT_BADFILE; | ||||||
|       } |       } | ||||||
| @@ -208,13 +206,13 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|    */ |    */ | ||||||
|  |  | ||||||
|   /* Load client certificate */ |   /* Load client certificate */ | ||||||
|   if(data->set.str[STRING_CERT]){ |   if(data->set.str[STRING_CERT]) { | ||||||
|     i=0; |     i=0; | ||||||
|     /* Instead of trying to analyze cert type here, let axTLS try them all. */ |     /* Instead of trying to analyze cert type here, let axTLS try them all. */ | ||||||
|     while(cert_types[i] != 0){ |     while(cert_types[i] != 0) { | ||||||
|       ssl_fcn_return = ssl_obj_load(ssl_ctx, cert_types[i], |       ssl_fcn_return = ssl_obj_load(ssl_ctx, cert_types[i], | ||||||
|                                     data->set.str[STRING_CERT], NULL); |                                     data->set.str[STRING_CERT], NULL); | ||||||
|       if(ssl_fcn_return == SSL_OK){ |       if(ssl_fcn_return == SSL_OK) { | ||||||
|         infof(data, "successfully read cert file %s \n", |         infof(data, "successfully read cert file %s \n", | ||||||
|               data->set.str[STRING_CERT]); |               data->set.str[STRING_CERT]); | ||||||
|         break; |         break; | ||||||
| @@ -222,7 +220,7 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|       i++; |       i++; | ||||||
|     } |     } | ||||||
|     /* Tried all cert types, none worked. */ |     /* Tried all cert types, none worked. */ | ||||||
|     if(cert_types[i] == 0){ |     if(cert_types[i] == 0) { | ||||||
|       failf(data, "%s is not x509 or pkcs12 format", |       failf(data, "%s is not x509 or pkcs12 format", | ||||||
|             data->set.str[STRING_CERT]); |             data->set.str[STRING_CERT]); | ||||||
|       Curl_axtls_close(conn, sockindex); |       Curl_axtls_close(conn, sockindex); | ||||||
| @@ -233,13 +231,13 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|   /* Load client key. |   /* Load client key. | ||||||
|      If a pkcs12 file successfully loaded a cert, then there's nothing to do |      If a pkcs12 file successfully loaded a cert, then there's nothing to do | ||||||
|      because the key has already been loaded. */ |      because the key has already been loaded. */ | ||||||
|   if(data->set.str[STRING_KEY] && cert_types[i] != SSL_OBJ_PKCS12){ |   if(data->set.str[STRING_KEY] && cert_types[i] != SSL_OBJ_PKCS12) { | ||||||
|     i=0; |     i=0; | ||||||
|     /* Instead of trying to analyze key type here, let axTLS try them all. */ |     /* Instead of trying to analyze key type here, let axTLS try them all. */ | ||||||
|     while(key_types[i] != 0){ |     while(key_types[i] != 0) { | ||||||
|       ssl_fcn_return = ssl_obj_load(ssl_ctx, key_types[i], |       ssl_fcn_return = ssl_obj_load(ssl_ctx, key_types[i], | ||||||
|                                     data->set.str[STRING_KEY], NULL); |                                     data->set.str[STRING_KEY], NULL); | ||||||
|       if(ssl_fcn_return == SSL_OK){ |       if(ssl_fcn_return == SSL_OK) { | ||||||
|         infof(data, "successfully read key file %s \n", |         infof(data, "successfully read key file %s \n", | ||||||
|               data->set.str[STRING_KEY]); |               data->set.str[STRING_KEY]); | ||||||
|         break; |         break; | ||||||
| @@ -247,7 +245,7 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|       i++; |       i++; | ||||||
|     } |     } | ||||||
|     /* Tried all key types, none worked. */ |     /* Tried all key types, none worked. */ | ||||||
|     if(key_types[i] == 0){ |     if(key_types[i] == 0) { | ||||||
|       failf(data, "Failure: %s is not a supported key file", |       failf(data, "Failure: %s is not a supported key file", | ||||||
|             data->set.str[STRING_KEY]); |             data->set.str[STRING_KEY]); | ||||||
|       Curl_axtls_close(conn, sockindex); |       Curl_axtls_close(conn, sockindex); | ||||||
| @@ -273,7 +271,7 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|  |  | ||||||
|   /* Check to make sure handshake was ok. */ |   /* Check to make sure handshake was ok. */ | ||||||
|   ssl_fcn_return = ssl_handshake_status(ssl); |   ssl_fcn_return = ssl_handshake_status(ssl); | ||||||
|   if(ssl_fcn_return != SSL_OK){ |   if(ssl_fcn_return != SSL_OK) { | ||||||
|     Curl_axtls_close(conn, sockindex); |     Curl_axtls_close(conn, sockindex); | ||||||
|     ssl_display_error(ssl_fcn_return); /* goes to stdout. */ |     ssl_display_error(ssl_fcn_return); /* goes to stdout. */ | ||||||
|     return map_error_to_curl(ssl_fcn_return); |     return map_error_to_curl(ssl_fcn_return); | ||||||
| @@ -285,8 +283,8 @@ Curl_axtls_connect(struct connectdata *conn, | |||||||
|    */ |    */ | ||||||
|  |  | ||||||
|   /* Verify server's certificate */ |   /* Verify server's certificate */ | ||||||
|   if(data->set.ssl.verifypeer){ |   if(data->set.ssl.verifypeer) { | ||||||
|     if(ssl_verify_cert(ssl) != SSL_OK){ |     if(ssl_verify_cert(ssl) != SSL_OK) { | ||||||
|       Curl_axtls_close(conn, sockindex); |       Curl_axtls_close(conn, sockindex); | ||||||
|       failf(data, "server cert verify failed"); |       failf(data, "server cert verify failed"); | ||||||
|       return CURLE_SSL_CONNECT_ERROR; |       return CURLE_SSL_CONNECT_ERROR; | ||||||
| @@ -415,7 +413,7 @@ int Curl_axtls_shutdown(struct connectdata *conn, int sockindex) | |||||||
|       nread = (ssize_t)SSL_read(conn->ssl[sockindex].ssl, buf, |       nread = (ssize_t)SSL_read(conn->ssl[sockindex].ssl, buf, | ||||||
|                                 sizeof(buf)); |                                 sizeof(buf)); | ||||||
|  |  | ||||||
|       if(nread < SSL_OK){ |       if(nread < SSL_OK) { | ||||||
|         failf(data, "close notify alert not received during shutdown"); |         failf(data, "close notify alert not received during shutdown"); | ||||||
|         retval = -1; |         retval = -1; | ||||||
|       } |       } | ||||||
| @@ -447,13 +445,13 @@ static ssize_t axtls_recv(struct connectdata *conn, /* connection data */ | |||||||
|  |  | ||||||
|   infof(conn->data, "  axtls_recv\n"); |   infof(conn->data, "  axtls_recv\n"); | ||||||
|  |  | ||||||
|   if(connssl){ |   if(connssl) { | ||||||
|     ret = (ssize_t)SSL_read(conn->ssl[num].ssl, buf, (int)buffersize); |     ret = (ssize_t)SSL_read(conn->ssl[num].ssl, buf, (int)buffersize); | ||||||
|  |  | ||||||
|     /* axTLS isn't terribly generous about error reporting */ |     /* axTLS isn't terribly generous about error reporting */ | ||||||
|     /* With patched axTLS, SSL_CLOSE_NOTIFY=-3.  Hard-coding until axTLS |     /* With patched axTLS, SSL_CLOSE_NOTIFY=-3.  Hard-coding until axTLS | ||||||
|        team approves proposed fix. */ |        team approves proposed fix. */ | ||||||
|     if(ret == -3 ){ |     if(ret == -3 ) { | ||||||
|       Curl_axtls_close(conn, num); |       Curl_axtls_close(conn, num); | ||||||
|     } |     } | ||||||
|     else if(ret < 0) { |     else if(ret < 0) { | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user