Compare commits
	
		
			1069 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 | ||
|   | 8da5da9b65 | ||
|   | 42c6b7577f | ||
|   | e5010ec3ff | ||
|   | 5c314c6bb4 | ||
|   | 9016958aa8 | ||
|   | 1614dc0745 | ||
|   | af6dcc92d5 | ||
|   | 57064e4a0d | ||
|   | d9e71809cb | ||
|   | a7cc54a5a8 | ||
|   | c9a82f39e2 | ||
|   | e4bca6a01c | ||
|   | 56e5302b53 | ||
|   | 4cbc6fc6ab | ||
|   | c9f16e67ef | ||
|   | f851f76857 | ||
|   | 0126b4a959 | ||
|   | 49a8fe5142 | ||
|   | 8fc4be9e7b | ||
|   | 70eee054f2 | ||
|   | 0aedccc18a | ||
|   | 85881f9f35 | ||
|   | 84e13f2e07 | ||
|   | 832e827518 | ||
|   | a6fa7fc38e | ||
|   | b122f8be61 | ||
|   | 950fb3efcc | ||
|   | ee015947d4 | ||
|   | a2a2863306 | ||
|   | b688f2c260 | ||
|   | c4dd8df081 | ||
|   | 0f7bea7c3a | ||
|   | d5cc77b744 | ||
|   | 36a22f9074 | ||
|   | 6e0dd48f97 | ||
|   | cb2f300364 | ||
|   | 7530a28878 | ||
|   | e8d73c9c2d | ||
|   | 8a3c0fe56c | ||
|   | f551aa5c16 | ||
|   | 377f88364e | ||
|   | c0b9dd27b5 | ||
|   | 6aff805942 | ||
|   | b772f3a321 | ||
|   | 7559b77727 | ||
|   | 4f170ee8f9 | ||
|   | fba00c9f7b | ||
|   | 10a7d05be3 | ||
|   | 9776f3445d | ||
|   | adeac15d8e | ||
|   | 5d4e5593d5 | ||
|   | c2eb8c932d | ||
|   | a6f14e17b7 | ||
|   | b3740f0e09 | ||
|   | 2a31dde76c | ||
|   | bf749bb2c5 | ||
|   | 65a9fa59dc | ||
|   | 9eea43dce2 | ||
|   | 910d7953aa | ||
|   | 970117ef2d | ||
|   | aa76dec33a | ||
|   | d6bb8dcc23 | ||
|   | 685359d4c3 | ||
|   | a689072f33 | ||
|   | 3d64ed25df | ||
|   | ecfe0b5b18 | ||
|   | 9460896cbe | ||
|   | a87102c792 | ||
|   | 2e7a2027f1 | ||
|   | ae677edf90 | ||
|   | f5d78919af | ||
|   | f3d77f772d | ||
|   | 7dd449d843 | ||
|   | f461c6e61d | ||
|   | 3c9ff41a1f | ||
|   | c8c8816a97 | ||
|   | 5d39dea3b3 | ||
|   | 9f390a356e | ||
|   | 017ee34bba | ||
|   | 340228cc81 | ||
|   | edf282c096 | ||
|   | a947a9ac62 | ||
|   | 9b5343054a | ||
|   | b735717606 | ||
|   | ec33742d1b | ||
|   | 2ea31b0e6f | ||
|   | de70ddb749 | ||
|   | a41c7f9736 | ||
|   | 512b2f7740 | ||
|   | 8bdc48eddb | ||
|   | 328600e02b | ||
|   | e2747ebbc0 | ||
|   | 41ebda02b2 | ||
|   | 30c9799f72 | ||
|   | bed6b89a2f | ||
|   | 3e70c28ce5 | ||
|   | 79cc6c244a | ||
|   | d30ddd9977 | ||
|   | 8b849265d8 | ||
|   | fce7276f54 | ||
|   | 004d84fcc1 | ||
|   | 02f3ff3b0a | ||
|   | 3f6ffcd26d | ||
|   | 3912e7bde3 | ||
|   | 488521427f | ||
|   | e83816bfcf | ||
|   | b578534508 | ||
|   | 5db30a1d8c | ||
|   | 664ff30650 | ||
|   | 873d70a6d8 | ||
|   | 6dfa16c3c4 | ||
|   | 60f0ebbdc9 | ||
|   | b5d170b551 | ||
|   | d4e000906a | ||
|   | bb7ff942d3 | ||
|   | 48a40f0402 | ||
|   | 0c8e6f598a | ||
|   | 2ef7a28a71 | ||
|   | 2a02c07a15 | ||
|   | 212d8c8f65 | ||
|   | b996b202c4 | ||
|   | 32001ac414 | ||
|   | 9c629e5348 | ||
|   | f0612f166a | ||
|   | e34131db78 | ||
|   | 335dfa793c | ||
|   | 574aecee20 | ||
|   | 51075a6777 | ||
|   | 4508ea103f | ||
|   | 558f997e99 | ||
|   | fda0985bfd | ||
|   | 93ec4555ff | ||
|   | 61877b569f | ||
|   | dc15a88076 | ||
|   | adae5926dd | ||
|   | ade337d79e | ||
|   | 365db94e0a | ||
|   | d4ebf3c6b0 | ||
|   | f78fa6a57d | ||
|   | 038a631274 | ||
|   | 7d94af497d | ||
|   | a490961b10 | ||
|   | 821301de15 | ||
|   | 3440f4d374 | ||
|   | f83c36934f | ||
|   | c4bc1d473f | ||
|   | 5b7e1f9efe | ||
|   | c33aee1667 | ||
|   | 3b1b26578f | ||
|   | 2cbe885c1a | ||
|   | 4a42e5cdaa | ||
|   | 53ef3493bf | ||
|   | cbd98b2c28 | ||
|   | 4685db9462 | ||
|   | 45de057920 | ||
|   | aa87f0ab15 | ||
|   | 6a6981503e | ||
|   | 889d1e973f | ||
|   | 1b758b01c1 | ||
|   | 7ddcc8fea4 | ||
|   | 068d656c6d | ||
|   | 92f722017c | ||
|   | 9869668884 | ||
|   | b903186fa0 | ||
|   | 592eda8e3f | ||
|   | 6d013b0aab | ||
|   | bcc29cda8e | ||
|   | 4235457129 | ||
|   | e9542ccab6 | ||
|   | 7de2f9271c | ||
|   | 24d84da073 | ||
|   | ca015f1a45 | ||
|   | 722f286f80 | ||
|   | f20b4606de | ||
|   | c985a8df51 | ||
|   | a0fad3017e | 
							
								
								
									
										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) | ||||||
|  |  | ||||||
| @@ -62,8 +62,7 @@ CURL_HEADERS := \ | |||||||
| 	mprintf.h \ | 	mprintf.h \ | ||||||
| 	multi.h \ | 	multi.h \ | ||||||
| 	stdcheaders.h \ | 	stdcheaders.h \ | ||||||
| 	typecheck-gcc.h \ | 	typecheck-gcc.h | ||||||
| 	types.h |  | ||||||
|  |  | ||||||
| LOCAL_SRC_FILES := $(addprefix lib/,$(CSOURCES)) | LOCAL_SRC_FILES := $(addprefix lib/,$(CSOURCES)) | ||||||
| LOCAL_C_INCLUDES += $(LOCAL_PATH)/include/ | LOCAL_C_INCLUDES += $(LOCAL_PATH)/include/ | ||||||
| @@ -73,6 +72,7 @@ LOCAL_COPY_HEADERS_TO := libcurl/curl | |||||||
| LOCAL_COPY_HEADERS := $(addprefix include/curl/,$(CURL_HEADERS)) | LOCAL_COPY_HEADERS := $(addprefix include/curl/,$(CURL_HEADERS)) | ||||||
|  |  | ||||||
| LOCAL_MODULE:= libcurl | LOCAL_MODULE:= libcurl | ||||||
|  | LOCAL_MODULE_TAGS := optional | ||||||
|  |  | ||||||
| # Copy the licence to a place where Android will find it. | # Copy the licence to a place where Android will find it. | ||||||
| # Actually, this doesn't quite work because the build system searches | # Actually, this doesn't quite work because the build system searches | ||||||
| @@ -93,6 +93,7 @@ include $(LOCAL_PATH)/src/Makefile.inc | |||||||
| LOCAL_SRC_FILES := $(addprefix src/,$(CURL_CFILES)) | LOCAL_SRC_FILES := $(addprefix src/,$(CURL_CFILES)) | ||||||
|  |  | ||||||
| LOCAL_MODULE := curl | LOCAL_MODULE := curl | ||||||
|  | LOCAL_MODULE_TAGS := optional | ||||||
| LOCAL_STATIC_LIBRARIES := libcurl | LOCAL_STATIC_LIBRARIES := libcurl | ||||||
| LOCAL_SYSTEM_SHARED_LIBRARIES := libc | LOCAL_SYSTEM_SHARED_LIBRARIES := libc | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										0
									
								
								CMake/FindCARES.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -23,7 +23,6 @@ include(Utilities) | |||||||
|  |  | ||||||
| project( CURL C ) | project( CURL C ) | ||||||
|  |  | ||||||
|  |  | ||||||
| file (READ ${CURL_SOURCE_DIR}/include/curl/curlver.h CURL_VERSION_H_CONTENTS) | file (READ ${CURL_SOURCE_DIR}/include/curl/curlver.h CURL_VERSION_H_CONTENTS) | ||||||
| string (REGEX MATCH "LIBCURL_VERSION_MAJOR[ \t]+([0-9]+)" | string (REGEX MATCH "LIBCURL_VERSION_MAJOR[ \t]+([0-9]+)" | ||||||
|   LIBCURL_VERSION_MJ ${CURL_VERSION_H_CONTENTS}) |   LIBCURL_VERSION_MJ ${CURL_VERSION_H_CONTENTS}) | ||||||
| @@ -58,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) | ||||||
| @@ -114,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) | ||||||
| @@ -149,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 | ||||||
| @@ -191,12 +177,12 @@ if(WIN32) | |||||||
| endif(WIN32) | endif(WIN32) | ||||||
|  |  | ||||||
| # This macro checks if the symbol exists in the library and if it | # This macro checks if the symbol exists in the library and if it | ||||||
| # does, it appends library to the list. | # does, it prepends library to the list. | ||||||
| macro(CHECK_LIBRARY_EXISTS_CONCAT LIBRARY SYMBOL VARIABLE) | macro(CHECK_LIBRARY_EXISTS_CONCAT LIBRARY SYMBOL VARIABLE) | ||||||
|   check_library_exists("${LIBRARY};${CURL_LIBS}" ${SYMBOL} "" |   check_library_exists("${LIBRARY};${CURL_LIBS}" ${SYMBOL} "${CMAKE_LIBRARY_PATH}" | ||||||
|     ${VARIABLE}) |     ${VARIABLE}) | ||||||
|   if(${VARIABLE}) |   if(${VARIABLE}) | ||||||
|     set(CURL_LIBS ${CURL_LIBS} ${LIBRARY}) |     set(CURL_LIBS ${LIBRARY} ${CURL_LIBS}) | ||||||
|   endif(${VARIABLE}) |   endif(${VARIABLE}) | ||||||
| endmacro(CHECK_LIBRARY_EXISTS_CONCAT) | endmacro(CHECK_LIBRARY_EXISTS_CONCAT) | ||||||
|  |  | ||||||
| @@ -220,29 +206,24 @@ 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) | ||||||
|  |  | ||||||
| option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON) |  | ||||||
| mark_as_advanced(CMAKE_USE_OPENSSL) |  | ||||||
| if(CMAKE_USE_OPENSSL) |  | ||||||
|   if(WIN32) |  | ||||||
|     find_package(OpenSSL) |  | ||||||
|     if(OPENSSL_FOUND) |  | ||||||
|       set(USE_SSLEAY TRUE) |  | ||||||
|       set(USE_OPENSSL TRUE) |  | ||||||
|       list(APPEND CURL_LIBS ${OPENSSL_LIBRARIES} ) |  | ||||||
|     else() |  | ||||||
|       set(CMAKE_USE_OPENSSL FALSE) |  | ||||||
|       message(STATUS "OpenSSL NOT Found, disabling CMAKE_USE_OPENSSL") |  | ||||||
|     endif() |  | ||||||
|   else(WIN32) |  | ||||||
|     check_library_exists_concat("crypto" CRYPTO_lock  HAVE_LIBCRYPTO) |  | ||||||
|     check_library_exists_concat("ssl"    SSL_connect  HAVE_LIBSSL) |  | ||||||
|   endif(WIN32) |  | ||||||
| endif(CMAKE_USE_OPENSSL) |  | ||||||
|  |  | ||||||
| # Check for idn | # Check for idn | ||||||
| check_library_exists_concat("idn" idna_to_ascii_lz HAVE_LIBIDN) | check_library_exists_concat("idn" idna_to_ascii_lz HAVE_LIBIDN) | ||||||
|  |  | ||||||
| @@ -271,6 +252,25 @@ if(CURL_ZLIB)  # AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE | |||||||
|   endif() |   endif() | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
|  | option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON) | ||||||
|  | mark_as_advanced(CMAKE_USE_OPENSSL) | ||||||
|  | if(CMAKE_USE_OPENSSL) | ||||||
|  |   if(WIN32) | ||||||
|  |     find_package(OpenSSL) | ||||||
|  |     if(OPENSSL_FOUND) | ||||||
|  |       set(USE_SSLEAY TRUE) | ||||||
|  |       set(USE_OPENSSL TRUE) | ||||||
|  |       list(APPEND CURL_LIBS ${OPENSSL_LIBRARIES} ) | ||||||
|  |     else() | ||||||
|  |       set(CMAKE_USE_OPENSSL FALSE) | ||||||
|  |       message(STATUS "OpenSSL NOT Found, disabling CMAKE_USE_OPENSSL") | ||||||
|  |     endif() | ||||||
|  |   else(WIN32) | ||||||
|  |     check_library_exists_concat("crypto" CRYPTO_lock  HAVE_LIBCRYPTO) | ||||||
|  |     check_library_exists_concat("ssl"    SSL_connect  HAVE_LIBSSL) | ||||||
|  |   endif(WIN32) | ||||||
|  | endif(CMAKE_USE_OPENSSL) | ||||||
|  |  | ||||||
| # If we have features.h, then do the _BSD_SOURCE magic | # If we have features.h, then do the _BSD_SOURCE magic | ||||||
| check_include_file("features.h"       HAVE_FEATURES_H) | check_include_file("features.h"       HAVE_FEATURES_H) | ||||||
|  |  | ||||||
| @@ -386,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) | ||||||
| @@ -425,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) | ||||||
| @@ -435,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) | ||||||
| @@ -852,3 +859,13 @@ endif() | |||||||
| if(NOT CURL_CONFIG_HAS_BEEN_RUN_BEFORE) | if(NOT CURL_CONFIG_HAS_BEEN_RUN_BEFORE) | ||||||
|   set(CURL_CONFIG_HAS_BEEN_RUN_BEFORE 1 CACHE INTERNAL "Flag to track whether this is the first time running CMake or if CMake has been configured before") |   set(CURL_CONFIG_HAS_BEEN_RUN_BEFORE 1 CACHE INTERNAL "Flag to track whether this is the first time running CMake or if CMake has been configured before") | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
|  | # Installation. | ||||||
|  | # First, install generated curlbuild.h | ||||||
|  | install(FILES "${CMAKE_CURRENT_BINARY_DIR}/include/curl/curlbuild.h" | ||||||
|  |     DESTINATION include/curl ) | ||||||
|  | # Next, install other headers excluding curlbuild.h | ||||||
|  | install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/curl" | ||||||
|  |     DESTINATION include | ||||||
|  |     FILES_MATCHING PATTERN "*.h" | ||||||
|  |     PATTERN "curlbuild.h" EXCLUDE) | ||||||
|   | |||||||
							
								
								
									
										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. | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -36,12 +36,12 @@ winbuild/MakefileBuild.vc winbuild/Makefile.vc | |||||||
| EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in	\ | 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 | ||||||
|  |  | ||||||
| SUBDIRS = lib src | SUBDIRS = lib src include | ||||||
| DIST_SUBDIRS = $(SUBDIRS) tests include packages docs | DIST_SUBDIRS = $(SUBDIRS) tests packages docs | ||||||
|  |  | ||||||
| pkgconfigdir = $(libdir)/pkgconfig | pkgconfigdir = $(libdir)/pkgconfig | ||||||
| pkgconfig_DATA = libcurl.pc | pkgconfig_DATA = libcurl.pc | ||||||
| @@ -155,3 +155,7 @@ ca-bundle: lib/mk-ca-bundle.pl | |||||||
| ca-firefox: lib/firefox-db2pem.sh | ca-firefox: lib/firefox-db2pem.sh | ||||||
| 	@echo "generate a fresh ca-bundle.crt" | 	@echo "generate a fresh ca-bundle.crt" | ||||||
| 	./lib/firefox-db2pem.sh lib/ca-bundle.crt | 	./lib/firefox-db2pem.sh lib/ca-bundle.crt | ||||||
|  |  | ||||||
|  | checksrc: | ||||||
|  | 	cd lib && $(MAKE) checksrc | ||||||
|  | 	cd src && $(MAKE) checksrc | ||||||
|   | |||||||
| @@ -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,22 +1,54 @@ | |||||||
| Curl and libcurl 7.21.6 | Curl and libcurl 7.26.0 | ||||||
|  |  | ||||||
|  Public curl releases:         122 |  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:                 865 |  Contributors:                 929 | ||||||
|  |  | ||||||
| This release includes the following changes: | This release includes the following changes: | ||||||
|  |  | ||||||
|  o Added --tr-encoding and CURLOPT_TRANSFER_ENCODING |  o nss: the minimal supported version of NSS bumped to 3.12.x | ||||||
|  |  o nss: human-readable names are now provided for NSS errors if available | ||||||
|  |  o add a manual page for mk-ca-bundle | ||||||
|  |  o added --post303 and the CURL_REDIR_POST_303 option for CURLOPT_POSTREDIR | ||||||
|  |  o smtp: Add support for DIGEST-MD5 authentication | ||||||
|  |  o pop3: Added support for additional pop3 commands | ||||||
|  |  | ||||||
| This release includes the following bugfixes: | This release includes the following bugfixes: | ||||||
|  |  | ||||||
|  o curl-config: fix --version |  o nss: libcurl now uses NSS_InitContext() to prevent collisions if available | ||||||
|  o curl_easy_setopt.3: CURLOPT_PROXYTYPE clarification |    [1] | ||||||
|  o use HTTPS properly after CONNECT |  o URL parse: reject numerical IPv6 addresses outside brackets [4] | ||||||
|  o SFTP: close file before post quote operations |  o MD5: fix OOM memory leak [5] | ||||||
|  |  o OpenSSL cert: provide more details when cert check fails | ||||||
|  |  o HTTP: empty chunked POST ended up in two zero size chunks [6] | ||||||
|  |  o fixed a regression when curl resolved to multiple addresses and the first | ||||||
|  |    isn't supported [7] | ||||||
|  |  o -# progress meter: avoid superfluous updates and duplicate lines [8] | ||||||
|  |  o headers: surround GCC attribute names with double underscores [9] | ||||||
|  |  o PolarSSL: correct return code for CRL matches | ||||||
|  |  o PolarSSL: include version number in version string | ||||||
|  |  o PolarSSL: add support for asynchronous connect | ||||||
|  |  o mk-ca-bundle: revert the LWP usage [12] | ||||||
|  |  o IPv6 cookie domain: get rid of the first bracket before the second | ||||||
|  |  o connect.c: return changed to CURLE_COULDNT_CONNECT when opensocket fails | ||||||
|  |  o OpenSSL: Made cert hostname check conform to RFC 6125 [10] | ||||||
|  |  o HTTP: reset expected DL/UL sizes on redirects [11] | ||||||
|  |  o CMake: fix Windows LDAP/LDAPS option handling [2] | ||||||
|  |  o CMake: fix MS Visual Studio x64 unsigned long long literal suffix [3] | ||||||
|  |  o configure: update detection logic of getaddrinfo() thread-safeness | ||||||
|  |  o configure: check for gethostbyname in the watt lib | ||||||
|  |  o curl-config.1: fix curl-config usage in example [13] | ||||||
|  |  o smtp: Fixed non-escaping of dot character at beginning of line | ||||||
|  |  o MakefileBuild.vc: use the correct IDN variable | ||||||
|  |  o autoconf: improve handling of versioned symbols | ||||||
|  |  o curl.1: clarify -x usage | ||||||
|  |  o curl: shorten user-agent | ||||||
|  |  o smtp: issue with the multi-interface always sending postdata [14] | ||||||
|  |  o compile error with GnuTLS+Nettle fixed | ||||||
|  |  o winbuild: fix IPv6 enabled build | ||||||
|  |  | ||||||
| This release includes the following known bugs: | This release includes the following known bugs: | ||||||
|  |  | ||||||
| @@ -25,8 +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: | ||||||
|  |  | ||||||
|  Patrick Monnerat, Dan Fandrich, Gisle Vanem, Guenter Knauf, |  Andrei Cipu, Armel Asselin, Benjamin Johnson, Dag Ekengren, Dave Reisner, | ||||||
|  Rajesh Naganathan, Josue Andrade Gomes, Ryan Schmidt, Fabian Keil, |  Gokhan Sengun, Guenter Knauf, Jan Schaumann, Jonathan Nieder, Kamil Dudka, | ||||||
|  Julien Chaffraix |  Lijo Antony, Olaf Flebbe, Rodrigo Silva, Steve Holme, Tatsuhiro Tsujikawa, | ||||||
|  |  Tim Heckman, Yang Tse, Arnaud Compan, Blaise Potard, Daniel Theron, | ||||||
|  |  Michael Mueller, Michael Wallner, Tim Heckman, Roman Mamedov, Julian Taylor, | ||||||
|  |  Claes Jakobsson, Pierre Chapuis, Jan Ehrhardt | ||||||
|  |  | ||||||
|         Thanks! (and sorry if I forgot to mention someone) |         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 -  | ||||||
|   | |||||||
							
								
								
									
										34
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								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 |  | ||||||
| ]) | ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1663,7 +1658,7 @@ AC_DEFUN([CURL_CHECK_FUNC_RECVFROM], [ | |||||||
|           for recvfrom_arg2 in 'char *' 'void *'; do |           for recvfrom_arg2 in 'char *' 'void *'; do | ||||||
|             for recvfrom_arg3 in 'size_t' 'int' 'socklen_t' 'unsigned int'; do |             for recvfrom_arg3 in 'size_t' 'int' 'socklen_t' 'unsigned int'; do | ||||||
|               for recvfrom_arg4 in 'int' 'unsigned int'; do |               for recvfrom_arg4 in 'int' 'unsigned int'; do | ||||||
|                 for recvfrom_arg5 in 'const struct sockaddr *' 'struct sockaddr *' 'void *'; do |                 for recvfrom_arg5 in 'struct sockaddr *' 'void *' 'const struct sockaddr *'; do | ||||||
|                   for recvfrom_arg6 in 'socklen_t *' 'int *' 'unsigned int *' 'size_t *' 'void *'; do |                   for recvfrom_arg6 in 'socklen_t *' 'int *' 'unsigned int *' 'size_t *' 'void *'; do | ||||||
|                     if test "$curl_cv_func_recvfrom_args" = "unknown"; then |                     if test "$curl_cv_func_recvfrom_args" = "unknown"; then | ||||||
|                       AC_COMPILE_IFELSE([ |                       AC_COMPILE_IFELSE([ | ||||||
| @@ -1731,7 +1726,7 @@ AC_DEFUN([CURL_CHECK_FUNC_RECVFROM], [ | |||||||
|       shift |       shift | ||||||
|       # |       # | ||||||
|       recvfrom_ptrt_arg2=$[2] |       recvfrom_ptrt_arg2=$[2] | ||||||
|       recvfrom_ptrt_arg5=$[5] |       recvfrom_qual_ptrt_arg5=$[5] | ||||||
|       recvfrom_ptrt_arg6=$[6] |       recvfrom_ptrt_arg6=$[6] | ||||||
|       # |       # | ||||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG1, $[1], |       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG1, $[1], | ||||||
| @@ -1753,12 +1748,25 @@ AC_DEFUN([CURL_CHECK_FUNC_RECVFROM], [ | |||||||
|           ;; |           ;; | ||||||
|       esac |       esac | ||||||
|       # |       # | ||||||
|  |       case "$recvfrom_qual_ptrt_arg5" in | ||||||
|  |         const*) | ||||||
|  |           recvfrom_qual_arg5=const | ||||||
|  |           recvfrom_ptrt_arg5=`echo $recvfrom_qual_ptrt_arg5 | sed 's/^const //'` | ||||||
|  |         ;; | ||||||
|  |         *) | ||||||
|  |           recvfrom_qual_arg5= | ||||||
|  |           recvfrom_ptrt_arg5=$recvfrom_qual_ptrt_arg5 | ||||||
|  |         ;; | ||||||
|  |       esac | ||||||
|  |       # | ||||||
|       recvfrom_type_arg2=`echo $recvfrom_ptrt_arg2 | sed 's/ \*//'` |       recvfrom_type_arg2=`echo $recvfrom_ptrt_arg2 | sed 's/ \*//'` | ||||||
|       recvfrom_type_arg5=`echo $recvfrom_ptrt_arg5 | sed 's/ \*//'` |       recvfrom_type_arg5=`echo $recvfrom_ptrt_arg5 | sed 's/ \*//'` | ||||||
|       recvfrom_type_arg6=`echo $recvfrom_ptrt_arg6 | sed 's/ \*//'` |       recvfrom_type_arg6=`echo $recvfrom_ptrt_arg6 | sed 's/ \*//'` | ||||||
|       # |       # | ||||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG2, $recvfrom_type_arg2, |       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG2, $recvfrom_type_arg2, | ||||||
|         [Define to the type pointed by arg 2 for recvfrom.]) |         [Define to the type pointed by arg 2 for recvfrom.]) | ||||||
|  |       AC_DEFINE_UNQUOTED(RECVFROM_QUAL_ARG5, $recvfrom_qual_arg5, | ||||||
|  |         [Define to the type qualifier pointed by arg 5 for recvfrom.]) | ||||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG5, $recvfrom_type_arg5, |       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG5, $recvfrom_type_arg5, | ||||||
|         [Define to the type pointed by arg 5 for recvfrom.]) |         [Define to the type pointed by arg 5 for recvfrom.]) | ||||||
|       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG6, $recvfrom_type_arg6, |       AC_DEFINE_UNQUOTED(RECVFROM_TYPE_ARG6, $recvfrom_type_arg6, | ||||||
| @@ -2843,7 +2851,7 @@ AC_DEFUN([DO_CURL_OFF_T_CHECK], [ | |||||||
|     tmp_includes="" |     tmp_includes="" | ||||||
|     tmp_source="" |     tmp_source="" | ||||||
|     tmp_fmt="" |     tmp_fmt="" | ||||||
|     case AS_TR_SH([$1]) in |     case XC_SH_TR_SH([$1]) in | ||||||
|       int64_t) |       int64_t) | ||||||
|         tmp_includes="$curl_includes_inttypes" |         tmp_includes="$curl_includes_inttypes" | ||||||
|         tmp_source="char f@<:@@:>@ = PRId64;" |         tmp_source="char f@<:@@:>@ = PRId64;" | ||||||
| @@ -2901,7 +2909,7 @@ AC_DEFUN([DO_CURL_OFF_T_SUFFIX_CHECK], [ | |||||||
|   curl_suffix_curl_off_t="unknown" |   curl_suffix_curl_off_t="unknown" | ||||||
|   curl_suffix_curl_off_tu="unknown" |   curl_suffix_curl_off_tu="unknown" | ||||||
|   # |   # | ||||||
|   case AS_TR_SH([$1]) in |   case XC_SH_TR_SH([$1]) in | ||||||
|     long_long | __longlong | __longlong_t) |     long_long | __longlong | __longlong_t) | ||||||
|       tst_suffixes="LL::" |       tst_suffixes="LL::" | ||||||
|       ;; |       ;; | ||||||
| @@ -3073,7 +3081,7 @@ AC_DEFUN([CURL_CONFIGURE_CURL_OFF_T], [ | |||||||
|     curl_format_curl_off_tu=`echo "$curl_format_curl_off_tu" | "$SED" 's/D$/U/'` |     curl_format_curl_off_tu=`echo "$curl_format_curl_off_tu" | "$SED" 's/D$/U/'` | ||||||
|   else |   else | ||||||
|     x_pull_headers="no" |     x_pull_headers="no" | ||||||
|     case AS_TR_SH([$curl_typeof_curl_off_t]) in |     case XC_SH_TR_SH([$curl_typeof_curl_off_t]) in | ||||||
|       long_long | __longlong | __longlong_t) |       long_long | __longlong | __longlong_t) | ||||||
|         curl_format_curl_off_t="lld" |         curl_format_curl_off_t="lld" | ||||||
|         curl_format_curl_off_tu="llu" |         curl_format_curl_off_tu="llu" | ||||||
|   | |||||||
							
								
								
									
										169
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										169
									
								
								buildconf
									
									
									
									
									
								
							| @@ -6,7 +6,7 @@ | |||||||
| #                            | (__| |_| |  _ <| |___ | #                            | (__| |_| |  _ <| |___ | ||||||
| #                             \___|\___/|_| \_\_____| | #                             \___|\___/|_| \_\_____| | ||||||
| # | # | ||||||
| # Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | # Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| # | # | ||||||
| # This software is licensed as described in the file COPYING, which | # 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 | ||||||
|  |  | ||||||
|  | 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)" |   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" | ||||||
|  | elif test -z "$lt_minor"; then | ||||||
|  |   lt_status="bad" | ||||||
|  | elif test "$lt_minor" -gt "$want_lt_minor"; then | ||||||
|  |   lt_status="good" | ||||||
|  | elif test "$lt_minor" -lt "$want_lt_minor"; then | ||||||
|  |   lt_status="bad" | ||||||
|  | elif test -z "$lt_patch"; then | ||||||
|  |   lt_status="bad" | ||||||
|  | elif test "$lt_patch" -gt "$want_lt_patch"; then | ||||||
|  |   lt_status="good" | ||||||
|  | elif test "$lt_patch" -lt "$want_lt_patch"; then | ||||||
|   lt_status="bad" |   lt_status="bad" | ||||||
|           fi |  | ||||||
| else | else | ||||||
|           lt_status="bad" |   lt_status="good" | ||||||
| fi | fi | ||||||
|    fi | if test "$lt_status" != "good"; then | ||||||
| fi |  | ||||||
| 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 | ||||||
|   | |||||||
							
								
								
									
										441
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										441
									
								
								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) | ||||||
| @@ -305,6 +308,44 @@ AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | |||||||
| CURL_CHECK_CURLDEBUG | CURL_CHECK_CURLDEBUG | ||||||
| AM_CONDITIONAL(CURLDEBUG, test x$want_curldebug = xyes) | AM_CONDITIONAL(CURLDEBUG, test x$want_curldebug = xyes) | ||||||
|  |  | ||||||
|  | supports_unittests=yes | ||||||
|  | # cross-compilation of unit tests static library/programs fails when | ||||||
|  | # libcurl shared library is built. This might be due to a libtool or | ||||||
|  | # automake issue. In this case we disable unit tests. | ||||||
|  | if test "x$cross_compiling" != "xno" && | ||||||
|  |    test "x$enable_shared" != "xno"; then | ||||||
|  |   supports_unittests=no | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # IRIX 6.5.24 gcc 3.3 autobuilds fail unittests library compilation due to | ||||||
|  | # a problem related with OpenSSL headers and library versions not matching. | ||||||
|  | # Disable unit tests while time to further investigate this is found. | ||||||
|  | case $host in | ||||||
|  |   mips-sgi-irix6.5) | ||||||
|  |     if test "$compiler_id" = "GNU_C"; then | ||||||
|  |       supports_unittests=no | ||||||
|  |     fi | ||||||
|  |     ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | # All AIX autobuilds fails unit tests linking against unittests library | ||||||
|  | # due to unittests library being built with no symbols or members. Libtool ? | ||||||
|  | # Disable unit tests while time to further investigate this is found. | ||||||
|  | case $host_os in | ||||||
|  |   aix*) | ||||||
|  |     supports_unittests=no | ||||||
|  |     ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | dnl Build unit tests when option --enable-debug is given. | ||||||
|  | if test "x$want_debug" = "xyes" && | ||||||
|  |    test "x$supports_unittests" = "xyes"; then | ||||||
|  |   want_unittests=yes | ||||||
|  | else | ||||||
|  |   want_unittests=no | ||||||
|  | fi | ||||||
|  | AM_CONDITIONAL(BUILD_UNITTESTS, test x$want_unittests = xyes) | ||||||
|  |  | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| dnl Compilation based checks should not be done before this point. | dnl Compilation based checks should not be done before this point. | ||||||
| dnl ********************************************************************** | dnl ********************************************************************** | ||||||
| @@ -612,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 ********************************************************************** | ||||||
| @@ -637,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" | ||||||
| @@ -1312,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 | ||||||
|  |  | ||||||
| @@ -1476,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 | ||||||
| @@ -1508,12 +1580,14 @@ 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 |     fi | ||||||
|  |     CURL_CHECK_OPENSSL_API | ||||||
|  |   fi | ||||||
|  |  | ||||||
| fi | fi | ||||||
|  |  | ||||||
| @@ -1624,8 +1698,12 @@ if test X"$OPENSSL_ENABLED" = X"1"; then | |||||||
|                  [read randomness from FILE (default=/dev/urandom)]), |                  [read randomness from FILE (default=/dev/urandom)]), | ||||||
|       [ RANDOM_FILE="$withval" ], |       [ RANDOM_FILE="$withval" ], | ||||||
|       [ |       [ | ||||||
|  |           if test x$cross_compiling != xyes; then | ||||||
|             dnl Check for random device |             dnl Check for random device | ||||||
|             AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] ) |             AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] ) | ||||||
|  |           else | ||||||
|  |             AC_MSG_WARN([skipped the /dev/urandom detection when cross-compiling]) | ||||||
|  |           fi | ||||||
|       ] |       ] | ||||||
|   ) |   ) | ||||||
|   if test -n "$RANDOM_FILE" && test X"$RANDOM_FILE" != Xno ; then |   if test -n "$RANDOM_FILE" && test X"$RANDOM_FILE" != Xno ; then | ||||||
| @@ -1742,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 | ||||||
|  |  | ||||||
| @@ -1756,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 --- | ||||||
| @@ -1852,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 | ||||||
| @@ -1874,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) | ||||||
|  |  | ||||||
| @@ -1887,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]) | ||||||
| @@ -1916,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]) | ||||||
| @@ -1941,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 | ||||||
|  |  | ||||||
| @@ -2000,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" | ||||||
| @@ -2017,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]) | ||||||
| @@ -2033,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 | ||||||
|  |  | ||||||
| @@ -2197,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 | ||||||
| @@ -2288,55 +2383,196 @@ 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 | ||||||
|  |     want_idn="yes" | ||||||
|  |     want_idn_path="default" | ||||||
|  |     AC_MSG_RESULT([(assumed) yes]) | ||||||
|  |     ;; | ||||||
|  |   yes) | ||||||
|  |     dnl --with-libidn option used without path | ||||||
|  |     want_idn="yes" | ||||||
|  |     want_idn_path="default" | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |     ;; | ||||||
|  |   *) | ||||||
|  |     dnl --with-libidn option used with path | ||||||
|  |     want_idn="yes" | ||||||
|  |     want_idn_path="$withval" | ||||||
|  |     AC_MSG_RESULT([yes ($withval)]) | ||||||
|  |     ;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|        idn="" | if test "$want_idn" = "yes"; then | ||||||
|        dnl if there is a given path, check that FIRST |   dnl idn library support has been requested | ||||||
|        if test -n "$LIBIDN"; then |   clean_CPPFLAGS="$CPPFLAGS" | ||||||
|          if test "x$LIBIDN" != "xyes"; then |   clean_LDFLAGS="$LDFLAGS" | ||||||
|             oldLDFLAGS=$LDFLAGS |   clean_LIBS="$LIBS" | ||||||
|             oldCPPFLAGS=$CPPFLAGS |   PKGCONFIG="no" | ||||||
|             LDFLAGS="$LDFLAGS -L$LIBIDN/lib" |   # | ||||||
|             CPPFLAGS="$CPPFLAGS -I$LIBIDN/include" |   if test "$want_idn_path" != "default"; then | ||||||
|             idn="yes" |     dnl path has been specified | ||||||
|             AC_CHECK_LIB(idn, idna_to_ascii_4i, , |     IDN_PCDIR="$want_idn_path/lib$libsuff/pkgconfig" | ||||||
|                          idn="" |     CURL_CHECK_PKGCONFIG(libidn, [$IDN_PCDIR]) | ||||||
|                          LDFLAGS=$oldLDFLAGS |     if test "$PKGCONFIG" != "no"; then | ||||||
|                          CPPFLAGS=$oldCPPFLAGS) |       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 | ||||||
|   fi |   fi | ||||||
|  |   # | ||||||
|        if test "x$idn" != "xyes"; then |   if test "$PKGCONFIG" != "no"; then | ||||||
|           dnl check with default paths |     AC_MSG_NOTICE([pkg-config: IDN_LIBS: "$IDN_LIBS"]) | ||||||
|           idn="yes" |     AC_MSG_NOTICE([pkg-config: IDN_LDFLAGS: "$IDN_LDFLAGS"]) | ||||||
|           AC_CHECK_LIB(idn, idna_to_ascii_lz, , |     AC_MSG_NOTICE([pkg-config: IDN_CPPFLAGS: "$IDN_CPPFLAGS"]) | ||||||
|                        idn="") |     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 |   fi | ||||||
|  |   # | ||||||
|        if test "x$idn" = "xyes"; then |   CPPFLAGS="$IDN_CPPFLAGS $CPPFLAGS" | ||||||
|          curl_idn_msg="enabled" |   LDFLAGS="$IDN_LDFLAGS $LDFLAGS" | ||||||
|          AC_SUBST(IDN_ENABLED, [1]) |   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: |     dnl different versions of libidn have different setups of these: | ||||||
|     AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror ) |     AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror ) | ||||||
|     AC_CHECK_HEADERS( idn-free.h tld.h ) |     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 | fi | ||||||
|  |  | ||||||
|        ;; |  | ||||||
| esac |  | ||||||
|  |  | ||||||
|  |  | ||||||
| dnl Let's hope this split URL remains working: | dnl Let's hope this split URL remains working: | ||||||
| @@ -2396,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 | ||||||
| [], | [], | ||||||
| @@ -2517,6 +2754,7 @@ CURL_CHECK_FUNC_FREEIFADDRS | |||||||
| CURL_CHECK_FUNC_FSETXATTR | CURL_CHECK_FUNC_FSETXATTR | ||||||
| CURL_CHECK_FUNC_FTRUNCATE | CURL_CHECK_FUNC_FTRUNCATE | ||||||
| CURL_CHECK_FUNC_GETADDRINFO | CURL_CHECK_FUNC_GETADDRINFO | ||||||
|  | CURL_CHECK_FUNC_GAI_STRERROR | ||||||
| CURL_CHECK_FUNC_GETHOSTBYADDR | CURL_CHECK_FUNC_GETHOSTBYADDR | ||||||
| CURL_CHECK_FUNC_GETHOSTBYADDR_R | CURL_CHECK_FUNC_GETHOSTBYADDR_R | ||||||
| CURL_CHECK_FUNC_GETHOSTBYNAME | CURL_CHECK_FUNC_GETHOSTBYNAME | ||||||
| @@ -2540,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 | ||||||
| @@ -2593,7 +2832,7 @@ AC_CHECK_FUNCS([fork \ | |||||||
|     ],[ |     ],[ | ||||||
|       AC_MSG_RESULT([yes]) |       AC_MSG_RESULT([yes]) | ||||||
|       eval "ac_cv_func_$func=yes" |       eval "ac_cv_func_$func=yes" | ||||||
|       AC_DEFINE_UNQUOTED(AS_TR_CPP([HAVE_$func]), [1], |       AC_DEFINE_UNQUOTED(XC_SH_TR_CPP([HAVE_$func]), [1], | ||||||
|         [Define to 1 if you have the $func function.]) |         [Define to 1 if you have the $func function.]) | ||||||
|     ],[ |     ],[ | ||||||
|       AC_MSG_RESULT([but still no]) |       AC_MSG_RESULT([but still no]) | ||||||
| @@ -2770,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 | ||||||
| @@ -2816,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 | ||||||
| @@ -2945,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 | ||||||
| @@ -3055,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 \ | ||||||
| @@ -3099,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. | ||||||
|   | |||||||
							
								
								
									
										74
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										74
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| Updated: March 8, 2011 (http://curl.haxx.se/docs/faq.html) | Updated: December 7, 2011 (http://curl.haxx.se/docs/faq.html) | ||||||
|                                   _   _ ____  _ |                                   _   _ ____  _ | ||||||
|                               ___| | | |  _ \| | |                               ___| | | |  _ \| | | ||||||
|                              / __| | | | |_) | | |                              / __| | | | |_) | | | ||||||
| @@ -36,7 +36,7 @@ FAQ | |||||||
|   3.2 How do I tell curl to resume a transfer? |   3.2 How do I tell curl to resume a transfer? | ||||||
|   3.3 Why doesn't my posting using -F work? |   3.3 Why doesn't my posting using -F work? | ||||||
|   3.4 How do I tell curl to run custom FTP commands? |   3.4 How do I tell curl to run custom FTP commands? | ||||||
|   3.5 How can I disable the Pragma: nocache header? |   3.5 How can I disable the Accept: */* header? | ||||||
|   3.6 Does curl support ASP, XML, XHTML or HTML version Y? |   3.6 Does curl support ASP, XML, XHTML or HTML version Y? | ||||||
|   3.7 Can I use curl to delete/rename a file through FTP? |   3.7 Can I use curl to delete/rename a file through FTP? | ||||||
|   3.8 How do I tell curl to follow HTTP redirects? |   3.8 How do I tell curl to follow HTTP redirects? | ||||||
| @@ -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 | ||||||
|  |  | ||||||
| @@ -491,7 +460,6 @@ FAQ | |||||||
|   3.2 How do I tell curl to resume a transfer? |   3.2 How do I tell curl to resume a transfer? | ||||||
|  |  | ||||||
|   Curl supports resumed transfers both ways on both FTP and HTTP. |   Curl supports resumed transfers both ways on both FTP and HTTP. | ||||||
|  |  | ||||||
|   Try the -C option. |   Try the -C option. | ||||||
|  |  | ||||||
|   3.3 Why doesn't my posting using -F work? |   3.3 Why doesn't my posting using -F work? | ||||||
| @@ -517,11 +485,11 @@ FAQ | |||||||
|   FTP commands without transferring anything. Therefore you must always specify |   FTP commands without transferring anything. Therefore you must always specify | ||||||
|   a URL to transfer to/from even when doing custom FTP commands. |   a URL to transfer to/from even when doing custom FTP commands. | ||||||
|  |  | ||||||
|   3.5 How can I disable the Pragma: nocache header? |   3.5 How can I disable the Accept: */* header? | ||||||
|  |  | ||||||
|   You can change all internally generated headers by adding a replacement with |   You can change all internally generated headers by adding a replacement with | ||||||
|   the -H/--header option. By adding a header with empty contents you safely |   the -H/--header option. By adding a header with empty contents you safely | ||||||
|   disable that one. Use -H "Pragma:" to disable that specific header. |   disable that one. Use -H "Accept:" to disable that specific header. | ||||||
|  |  | ||||||
|   3.6 Does curl support ASP, XML, XHTML or HTML version Y? |   3.6 Does curl support ASP, XML, XHTML or HTML version Y? | ||||||
|  |  | ||||||
| @@ -565,6 +533,12 @@ FAQ | |||||||
|   install and use them, in the libcurl section of the curl web site: |   install and use them, in the libcurl section of the curl web site: | ||||||
|   http://curl.haxx.se/libcurl/ |   http://curl.haxx.se/libcurl/ | ||||||
|  |  | ||||||
|  |   All the various bindings to libcurl are made by other projects and people, | ||||||
|  |   outside of the cURL project. The cURL project itself only produces libcurl | ||||||
|  |   with its plain C API. If you don't find anywhere else to ask you can ask | ||||||
|  |   about bindings on the curl-library list too, but be prepared that people on | ||||||
|  |   that list may not know anything about bindings. | ||||||
|  |  | ||||||
|   In October 2009, there were interfaces available for the following |   In October 2009, there were interfaces available for the following | ||||||
|   languages: Ada95, Basic, C, C++, Ch, Cocoa, D, Dylan, Eiffel, Euphoria, |   languages: Ada95, Basic, C, C++, Ch, Cocoa, D, Dylan, Eiffel, Euphoria, | ||||||
|   Ferite, Gambas, glib/GTK+, Haskell, ILE/RPG, Java, Lisp, Lua, Mono, .NET, |   Ferite, Gambas, glib/GTK+, Haskell, ILE/RPG, Java, Lisp, Lua, Mono, .NET, | ||||||
| @@ -721,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 | ||||||
| @@ -1152,6 +1132,11 @@ FAQ | |||||||
|   libcurl will reuse connections for all transfers that are made using the |   libcurl will reuse connections for all transfers that are made using the | ||||||
|   same libcurl handle. |   same libcurl handle. | ||||||
|  |  | ||||||
|  |   When you use the easy interface, the connection cache is kept within the | ||||||
|  |   easy handle. If you instead use the multi interface, the connection cache | ||||||
|  |   will be kept within the multi handle and will be shared among all the easy | ||||||
|  |   handles that are used within the same multi handle. | ||||||
|  |  | ||||||
|   5.7 Link errors when building libcurl on Windows! |   5.7 Link errors when building libcurl on Windows! | ||||||
|  |  | ||||||
|   You need to make sure that your project, and all the libraries (both static |   You need to make sure that your project, and all the libraries (both static | ||||||
| @@ -1260,14 +1245,13 @@ FAQ | |||||||
|   With the easy interface you make sure to return the correct error code from |   With the easy interface you make sure to return the correct error code from | ||||||
|   one of the callbacks, but none of them are instant. There is no function you |   one of the callbacks, but none of them are instant. There is no function you | ||||||
|   can call from another thread or similar that will stop it immediately. |   can call from another thread or similar that will stop it immediately. | ||||||
|   Instead you need to make sure that one of the callbacks you use return an |   Instead, you need to make sure that one of the callbacks you use returns an | ||||||
|   appropriate value that will stop the transfer. |   appropriate value that will stop the transfer.  Suitable callbacks that you | ||||||
|  |   can do this with include the progress callback, the read callback and the | ||||||
|   Suitable callbacks that you can do this with include the progress callback, |   write callback. | ||||||
|   the read callback and the write callback. |  | ||||||
|  |  | ||||||
|   If you're using the multi interface, you can also stop a transfer by |   If you're using the multi interface, you can also stop a transfer by | ||||||
|   removing the particular easy handle from the multi stack. At any moment you |   removing the particular easy handle from the multi stack at any moment you | ||||||
|   think the transfer is done. |   think the transfer is done. | ||||||
|  |  | ||||||
|   5.14 Using C++ non-static functions for callbacks? |   5.14 Using C++ non-static functions for callbacks? | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										69
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -14,6 +14,12 @@ Installing Binary Packages | |||||||
|    binary package. This document describes how to compile, build and install |    binary package. This document describes how to compile, build and install | ||||||
|    curl and libcurl from source code. |    curl and libcurl from source code. | ||||||
|  |  | ||||||
|  | Building from git | ||||||
|  | ================= | ||||||
|  |  | ||||||
|  |    If you get your code off a git repository, see the GIT-INFO file in the | ||||||
|  |    root directory for specific instructions on how to proceed. | ||||||
|  |  | ||||||
| UNIX | UNIX | ||||||
| ==== | ==== | ||||||
|    A normal unix installation is made in three or four steps (after you've |    A normal unix installation is made in three or four steps (after you've | ||||||
| @@ -211,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! | ||||||
| @@ -314,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. | ||||||
|  |  | ||||||
| @@ -328,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 | ||||||
| @@ -461,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 | ||||||
|    ----------------------------------- |    ----------------------------------- | ||||||
|  |  | ||||||
| @@ -806,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 | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										16
									
								
								docs/INSTALL.cmake
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -18,6 +18,17 @@ Building with CMake | |||||||
|    CMake builds can be configured either from the command line, or from one |    CMake builds can be configured either from the command line, or from one | ||||||
|    of CMake's GUI's. |    of CMake's GUI's. | ||||||
|  |  | ||||||
|  | Important notice | ||||||
|  | ================== | ||||||
|  |    If you got your curl sources from a distribution tarball, make sure to | ||||||
|  |    delete the generic 'include/curl/curlbuild.h' file that comes with it: | ||||||
|  |        rm -f curl/include/curl/curlbuild.h | ||||||
|  |  | ||||||
|  |    The purpose of this file is to provide reasonable definitions for systems | ||||||
|  |    where autoconfiguration is not available. CMake will create its own | ||||||
|  |    version of this file in its build directory. If the "generic" version | ||||||
|  |    is not deleted, weird build errors may occur on some systems. | ||||||
|  |  | ||||||
| Command Line CMake | Command Line CMake | ||||||
| ================== | ================== | ||||||
|    A command line build of Curl is similar to the autotools build of Curl. It |    A command line build of Curl is similar to the autotools build of Curl. It | ||||||
| @@ -32,9 +43,10 @@ Command Line CMake | |||||||
|        # variable prior to running CMake. |        # variable prior to running CMake. | ||||||
|        cmake ../curl |        cmake ../curl | ||||||
|        make |        make | ||||||
|        # currently make test and make install are not implemented |        # currently make test is not implemented | ||||||
|        #make test |        #make test | ||||||
|        #make install |        # Install to default location: | ||||||
|  |        make install | ||||||
|  |  | ||||||
| ccmake | ccmake | ||||||
| ========= | ========= | ||||||
|   | |||||||
| @@ -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
									
								
							
							
								
								
									
										72
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										72
									
								
								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 | ||||||
| @@ -424,6 +458,8 @@ Jose Kahan | |||||||
| Josef Wolf | Josef Wolf | ||||||
| Josh Kapell | Josh Kapell | ||||||
| Joshua Kwan | Joshua Kwan | ||||||
|  | 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 | ||||||
| @@ -431,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 | ||||||
| @@ -502,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 | ||||||
| @@ -543,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 | ||||||
| @@ -551,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 | ||||||
| @@ -558,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 | ||||||
| @@ -587,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 | ||||||
| @@ -604,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 | ||||||
| @@ -614,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 | ||||||
| @@ -640,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 | ||||||
| @@ -663,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 | ||||||
| @@ -673,6 +726,7 @@ Rafa Muyo | |||||||
| Rafael Sagula | Rafael Sagula | ||||||
| Rainer Canavan | Rainer Canavan | ||||||
| Rainer Koenig | Rainer Koenig | ||||||
|  | Rajesh Naganathan | ||||||
| Ralf S. Engelschall | Ralf S. Engelschall | ||||||
| Ralph Beckmann | Ralph Beckmann | ||||||
| Ralph Mitchell | Ralph Mitchell | ||||||
| @@ -688,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 | ||||||
| @@ -698,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 | ||||||
| @@ -727,6 +785,7 @@ Ruslan Gazizov | |||||||
| Rutger Hofman | Rutger Hofman | ||||||
| Ryan Chan | Ryan Chan | ||||||
| Ryan Nelson | Ryan Nelson | ||||||
|  | Ryan Schmidt | ||||||
| S. Moonesamy | S. Moonesamy | ||||||
| Salvador D<>vila | Salvador D<>vila | ||||||
| Salvatore Sorrentino | Salvatore Sorrentino | ||||||
| @@ -775,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 | ||||||
| @@ -783,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 | ||||||
| @@ -790,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 | ||||||
| @@ -802,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 | ||||||
| @@ -809,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 | ||||||
| @@ -817,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 | ||||||
| @@ -824,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 | ||||||
| @@ -846,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 | ||||||
| @@ -858,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) | ||||||
|   | |||||||
							
								
								
									
										1065
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										1065
									
								
								docs/curl.1
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										8
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								docs/examples/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -4,6 +4,7 @@ certinfo | |||||||
| chkspeed | 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 | ||||||
| @@ -127,28 +208,28 @@ 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 | ||||||
| @@ -26,9 +26,8 @@ | |||||||
| #else | #else | ||||||
| #  ifdef __VMS | #  ifdef __VMS | ||||||
|      typedef int intptr_t; |      typedef int intptr_t; | ||||||
| #  else |  | ||||||
| #    include <stdint.h> |  | ||||||
| #  endif | #  endif | ||||||
|  | #  include <stdint.h> | ||||||
| #  include <unistd.h> | #  include <unistd.h> | ||||||
| #endif | #endif | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| @@ -89,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 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is licensed as described in the file COPYING, which | .\" * 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 | ||||||
| @@ -31,8 +31,8 @@ curl_easy_escape - URL encodes the given string | |||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| This function converts the given input string to an URL encoded string and | This function converts the given input string to an URL encoded string and | ||||||
| returns that as a new allocated string. All input characters that are not a-z, | returns that as a new allocated string. All input characters that are not a-z, | ||||||
| A-Z or 0-9 are converted to their "URL escaped" version (%NN where NN is a | A-Z, 0-9, '-', '.', '_' or '~' are converted to their "URL escaped" version | ||||||
| two-digit hexadecimal number). | (%NN where NN is a two-digit hexadecimal number). | ||||||
|  |  | ||||||
| If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_escape(3)\fP | If the \fBlength\fP argument is set to 0 (zero), \fIcurl_easy_escape(3)\fP | ||||||
| uses strlen() on the input \fBurl\fP to find out the size. | uses strlen() on the input \fBurl\fP to find out the size. | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is licensed as described in the file COPYING, which | .\" * 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. | ||||||
| @@ -80,12 +82,13 @@ waits in line for the pipeline and more. (Added in 7.19.0) | |||||||
| Pass a pointer to a double to receive the time, in seconds, it took from the | Pass a pointer to a double to receive the time, in seconds, it took from the | ||||||
| start until the file transfer is just about to begin. This includes all | start until the file transfer is just about to begin. This includes all | ||||||
| pre-transfer commands and negotiations that are specific to the particular | pre-transfer commands and negotiations that are specific to the particular | ||||||
| protocol(s) involved. | protocol(s) involved. It does \fInot\fP involve the sending of the protocol- | ||||||
|  | specific request that triggers a transfer. | ||||||
| .IP CURLINFO_STARTTRANSFER_TIME | .IP CURLINFO_STARTTRANSFER_TIME | ||||||
| Pass a pointer to a double to receive the time, in seconds, it took from the | Pass a pointer to a double to receive the time, in seconds, it took from the | ||||||
| start until the first byte is just about to be transferred. This includes | start until the first byte is received by libcurl. This includes | ||||||
| CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate | CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate the | ||||||
| the result. | result. | ||||||
| .IP CURLINFO_REDIRECT_TIME | .IP CURLINFO_REDIRECT_TIME | ||||||
| Pass a pointer to a double to receive the total time, in seconds, it took for | Pass a pointer to a double to receive the total time, in seconds, it took for | ||||||
| all redirection steps include name lookup, connect, pretransfer and transfer | all redirection steps include name lookup, connect, pretransfer and transfer | ||||||
| @@ -275,7 +278,7 @@ file transfer is just about to begin. This includes all pre-transfer commands | |||||||
| and negotiations that are specific to the particular protocol(s) involved. | and negotiations that are specific to the particular protocol(s) involved. | ||||||
| .IP STARTTRANSFER | .IP STARTTRANSFER | ||||||
| \fICURLINFO_STARTTRANSFER_TIME\fP. The time it took from the start until the | \fICURLINFO_STARTTRANSFER_TIME\fP. The time it took from the start until the | ||||||
| first byte is just about to be transferred. | first byte is received by libcurl. | ||||||
| .IP TOTAL | .IP TOTAL | ||||||
| \fICURLINFO_TOTAL_TIME\fP. Total time of the previous request. | \fICURLINFO_TOTAL_TIME\fP. Total time of the previous request. | ||||||
| .IP REDIRECT | .IP REDIRECT | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is licensed as described in the file COPYING, which | .\" * 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 | ||||||
| @@ -68,8 +68,9 @@ A parameter set to 1 tells the library to include the header in the body | |||||||
| output. This is only relevant for protocols that actually have headers | output. This is only relevant for protocols that actually have headers | ||||||
| preceding the data (like HTTP). | preceding the data (like HTTP). | ||||||
| .IP CURLOPT_NOPROGRESS | .IP CURLOPT_NOPROGRESS | ||||||
| A parameter set to 1 tells the library to shut off the built-in progress meter | Pass a long. If set to 1, it tells the library to shut off the progress meter | ||||||
| completely. | completely. It will also present the \fICURLOPT_PROGRESSFUNCTION\fP from | ||||||
|  | getting called. | ||||||
|  |  | ||||||
| Future versions of libcurl are likely to not have any built-in progress meter | Future versions of libcurl are likely to not have any built-in progress meter | ||||||
| at all. | at all. | ||||||
| @@ -90,7 +91,9 @@ SIGPIPE signals, which otherwise are sent by the system when trying to send | |||||||
| data to a socket which is closed in the other end. libcurl makes an effort to | 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 | ||||||
| @@ -105,18 +108,18 @@ This feature is only supported by the FTP download for now. | |||||||
|  |  | ||||||
| A brief introduction of its syntax follows: | A brief introduction of its syntax follows: | ||||||
| .RS | .RS | ||||||
| .IP "\fB*\fP - ASTERISK" | .IP "* - ASTERISK" | ||||||
| \&ftp://example.com/some/path/\fB*.txt\fP (for all txt's from the root | \&ftp://example.com/some/path/\fB*.txt\fP (for all txt's from the root | ||||||
| directory) | directory) | ||||||
| .RE | .RE | ||||||
| .RS | .RS | ||||||
| .IP "\fB?\fP - QUESTION MARK" | .IP "? - QUESTION MARK" | ||||||
| Question mark matches any (exactly one) character. | Question mark matches any (exactly one) character. | ||||||
|  |  | ||||||
| \&ftp://example.com/some/path/\fBphoto?.jpeg\fP | \&ftp://example.com/some/path/\fBphoto?.jpeg\fP | ||||||
| .RE | .RE | ||||||
| .RS | .RS | ||||||
| .IP "\fB[\fP - BRACKET EXPRESSION" | .IP "[ - BRACKET EXPRESSION" | ||||||
| The left bracket opens a bracket expression. The question mark and asterisk have | The left bracket opens a bracket expression. The question mark and asterisk have | ||||||
| no special meaning in a bracket expression. Each bracket expression ends by the | no special meaning in a bracket expression. Each bracket expression ends by the | ||||||
| right bracket and matches exactly one character. Some examples follow: | right bracket and matches exactly one character. Some examples follow: | ||||||
| @@ -145,7 +148,7 @@ Using the rules above, a file name pattern can be constructed: | |||||||
| .SH CALLBACK OPTIONS | .SH CALLBACK OPTIONS | ||||||
| .IP CURLOPT_WRITEFUNCTION | .IP CURLOPT_WRITEFUNCTION | ||||||
| Function pointer that should match the following prototype: \fBsize_t | Function pointer that should match the following prototype: \fBsize_t | ||||||
| function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP This | function( char *ptr, size_t size, size_t nmemb, void *userdata);\fP This | ||||||
| function gets called by libcurl as soon as there is data received that needs | function gets called by libcurl as soon as there is data received that needs | ||||||
| to be saved. The size of the data pointed to by \fIptr\fP is \fIsize\fP | to be saved. The size of the data pointed to by \fIptr\fP is \fIsize\fP | ||||||
| multiplied with \fInmemb\fP, it will not be zero terminated. Return the number | multiplied with \fInmemb\fP, it will not be zero terminated. Return the number | ||||||
| @@ -168,8 +171,12 @@ Set the \fIuserdata\fP argument with the \fICURLOPT_WRITEDATA\fP option. | |||||||
|  |  | ||||||
| The callback function will be passed as much data as possible in all invokes, | 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 | ||||||
| @@ -259,7 +266,7 @@ If you forward the input arguments directly to "fseek" or "lseek", note that | |||||||
| the data type for \fIoffset\fP is not the same as defined for curl_off_t on | 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 | ||||||
| @@ -274,7 +281,7 @@ socket descriptor so additional setsockopt() calls can be done at the user's | |||||||
| discretion.  Return 0 (zero) from the callback on success. Return 1 from the | 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 | ||||||
| @@ -282,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 | ||||||
| @@ -307,6 +313,17 @@ address blacklisting.  The default behavior is: | |||||||
| 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 \fICURLOPT_OPENSOCKETFUNCTION\fP. | argument in the opensocket callback set with \fICURLOPT_OPENSOCKETFUNCTION\fP. | ||||||
| (Option added in 7.17.1.) | (Option added in 7.17.1.) | ||||||
|  | .IP CURLOPT_CLOSESOCKETFUNCTION | ||||||
|  | Function pointer that should match the \fIcurl_closesocket_callback\fP | ||||||
|  | prototype found in \fI<curl/curl.h>\fP. This function gets called by libcurl | ||||||
|  | instead of the \fIclose(3)\fP or \fIclosesocket(3)\fP call when sockets are | ||||||
|  | closed (not for any other file descriptors). This is pretty much the reverse | ||||||
|  | to the \fICURLOPT_OPENSOCKETFUNCTION\fP option. Return 0 to signal success and | ||||||
|  | 1 if there was an error.  (Option added in 7.21.7) | ||||||
|  | .IP CURLOPT_CLOSESOCKETDATA | ||||||
|  | Pass a pointer that will be untouched by libcurl and passed as the first | ||||||
|  | argument in the closesocket callback set with | ||||||
|  | \fICURLOPT_CLOSESOCKETFUNCTION\fP.  (Option added in 7.21.7) | ||||||
| .IP CURLOPT_PROGRESSFUNCTION | .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 | ||||||
| found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of | found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of | ||||||
| @@ -331,15 +348,18 @@ Function pointer that should match the following prototype: \fIsize_t | |||||||
| function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP. This | function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP. This | ||||||
| function gets called by libcurl as soon as it has received header data. The | function gets called by libcurl as soon as it has received header data. The | ||||||
| header callback will be called once for each header and only complete header | header callback will be called once for each header and only complete header | ||||||
| lines are passed on to the callback. Parsing headers should be easy enough | lines are passed on to the callback. Parsing headers is very easy using | ||||||
| using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP | this. The size of the data pointed to by \fIptr\fP is \fIsize\fP multiplied | ||||||
| multiplied with \fInmemb\fP. Do not assume that the header line is zero | with \fInmemb\fP. Do not assume that the header line is zero terminated! The | ||||||
| terminated! The pointer named \fIuserdata\fP is the one you set with the | pointer named \fIuserdata\fP is the one you set with the | ||||||
| \fICURLOPT_WRITEHEADER\fP option. The callback function must return the number | \fICURLOPT_WRITEHEADER\fP option. The callback function must return the number | ||||||
| of bytes actually taken care of. If that amount differs from the amount passed | 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, | ||||||
| @@ -353,19 +373,23 @@ negotiation. If you need to operate on only the headers from the final | |||||||
| response, you will need to collect headers in the callback yourself and use | response, you will need to collect headers in the callback yourself and use | ||||||
| HTTP status lines, for example, to delimit response boundaries. | HTTP status lines, for example, to delimit response boundaries. | ||||||
|  |  | ||||||
| Since 7.14.1: When a server sends a chunked encoded transfer, it may contain a | When a server sends a chunked encoded transfer, it may contain a trailer. That | ||||||
| trailer. That trailer is identical to a HTTP header and if such a trailer is | trailer is identical to a HTTP header and if such a trailer is received it is | ||||||
| received it is passed to the application using this callback as well. There | passed to the application using this callback as well. There are several ways | ||||||
| are several ways to detect it being a trailer and not an ordinary header: 1) | to detect it being a trailer and not an ordinary header: 1) it comes after the | ||||||
| it comes after the response-body. 2) it comes after the final header line (CR | response-body. 2) it comes after the final header line (CR LF) 3) a Trailer: | ||||||
| LF) 3) a Trailer: header among the response-headers mention what header to | header among the regular response-headers mention what header(s) to expect in | ||||||
| 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 your | used to write the header part of the received data to. If you don't use | ||||||
| own callback to take care of the writing, this must be a valid FILE *. See | \fICURLOPT_WRITEFUNCTION\fP or \fICURLOPT_HEADERFUNCTION\fP to take care of | ||||||
| also the \fICURLOPT_HEADERFUNCTION\fP option above on how to set a custom | the writing, this must be a valid FILE * as the internal default will then be | ||||||
| get-all-headers callback. | a plain fwrite(). See also the \fICURLOPT_HEADERFUNCTION\fP option above on | ||||||
|  | how to set a custom get-all-headers callback. | ||||||
| .IP CURLOPT_DEBUGFUNCTION | .IP CURLOPT_DEBUGFUNCTION | ||||||
| Function pointer that should match the following prototype: \fIint | Function pointer that should match the following prototype: \fIint | ||||||
| curl_debug_callback (CURL *, curl_infotype, char *, size_t, void *);\fP | curl_debug_callback (CURL *, curl_infotype, char *, size_t, void *);\fP | ||||||
| @@ -398,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 | ||||||
| @@ -413,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 | ||||||
| @@ -569,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. | ||||||
| @@ -615,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 | ||||||
| @@ -632,22 +798,29 @@ use of a proxy, even if there is an environment variable set for it. | |||||||
| Since 7.14.1, the proxy host string given in environment variables can be | Since 7.14.1, the proxy host string given in environment variables can be | ||||||
| specified the exact same way as the proxy can be set with \fICURLOPT_PROXY\fP, | specified the exact same way as the proxy can be set with \fICURLOPT_PROXY\fP, | ||||||
| include protocol prefix (http://) and embedded user + password. | include protocol prefix (http://) and embedded user + password. | ||||||
|  |  | ||||||
|  | Since 7.21.7, the proxy string may be specified with a protocol:// prefix to | ||||||
|  | specify alternative proxy protocols. Use socks4://, socks4a://, socks5:// or | ||||||
|  | socks5h:// (the last one to enable socks5 and asking the proxy to do the | ||||||
|  | resolving, also known as CURLPROXY_SOCKS5_HOSTNAME type) to request the | ||||||
|  | specific SOCKS version to be used. No protocol specified, http:// and all | ||||||
|  | others will be treated as HTTP proxies. | ||||||
| .IP CURLOPT_PROXYPORT | .IP CURLOPT_PROXYPORT | ||||||
| Pass a long with this option to set the proxy port to connect to unless it is | Pass a long with this option to set the proxy port to connect to unless it is | ||||||
| specified in the proxy string \fICURLOPT_PROXY\fP. | 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 | ||||||
| @@ -673,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 | ||||||
| @@ -736,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 | ||||||
| @@ -868,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 | ||||||
| @@ -897,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) | ||||||
| @@ -922,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 | ||||||
| @@ -950,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 | ||||||
| @@ -973,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 | ||||||
| @@ -1030,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. | ||||||
| @@ -1065,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. | ||||||
| @@ -1152,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. | ||||||
|  |  | ||||||
| @@ -1237,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 | ||||||
| @@ -1251,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 | ||||||
| @@ -1293,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 | ||||||
| @@ -1318,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 | ||||||
| @@ -1431,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 | ||||||
| @@ -1473,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 | ||||||
| @@ -1496,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. | ||||||
| @@ -1504,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 | ||||||
| @@ -1568,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 | ||||||
| @@ -1605,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 | ||||||
| @@ -1626,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 | ||||||
| @@ -1640,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 | ||||||
| @@ -1653,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 | ||||||
| @@ -1721,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 | ||||||
| @@ -1782,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. | ||||||
| @@ -1856,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 | ||||||
| @@ -1928,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 | ||||||
| @@ -2077,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', | ||||||
| @@ -2085,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 | ||||||
| @@ -2098,13 +2383,18 @@ libcurl will reject the connection to the host unless the md5sums match. This | |||||||
| option is only for SCP and SFTP transfers. (Added in 7.17.1) | option is only for SCP and SFTP transfers. (Added in 7.17.1) | ||||||
| .IP CURLOPT_SSH_PUBLIC_KEYFILE | .IP CURLOPT_SSH_PUBLIC_KEYFILE | ||||||
| Pass a char * pointing to a file name for your public key. If not used, | Pass a char * pointing to a file name for your public key. If not used, | ||||||
| libcurl defaults to using \fB~/.ssh/id_dsa.pub\fP. | libcurl defaults to \fB$HOME/.ssh/id_dsa.pub\fP if the HOME environment | ||||||
| (Added in 7.16.1) | variable is set, and just "id_dsa.pub" in the current directory if HOME is not | ||||||
|  | set.  (Added in 7.16.1) | ||||||
|  | If an empty string is passed, libcurl will pass no public key to libssh2 | ||||||
|  | which then tries to compute it from the private key, this is known to work | ||||||
|  | when libssh2 1.4.0+ is linked against OpenSSL. (Added in 7.26.0) | ||||||
| .IP CURLOPT_SSH_PRIVATE_KEYFILE | .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 using \fB~/.ssh/id_dsa\fP.  If the file is | libcurl defaults to \fB$HOME/.ssh/id_dsa\fP if the HOME environment variable | ||||||
| password-protected, set the password with \fICURLOPT_KEYPASSWD\fP. (Added in | is set, and just "id_dsa" in the current directory if HOME is not set.  If the | ||||||
| 7.16.1) | file is password-protected, set the password with | ||||||
|  | \fICURLOPT_KEYPASSWD\fP. (Added in 7.16.1) | ||||||
| .IP CURLOPT_SSH_KNOWNHOSTS | .IP CURLOPT_SSH_KNOWNHOSTS | ||||||
| Pass a pointer to a zero terminated string holding the file name of the | Pass a pointer to a zero terminated string holding the file name of the | ||||||
| known_host file to use.  The known_hosts file should use the OpenSSH file | known_host file to use.  The known_hosts file should use the OpenSSH file | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| .\" *                            | (__| |_| |  _ <| |___ | .\" *                            | (__| |_| |  _ <| |___ | ||||||
| .\" *                             \___|\___/|_| \_\_____| | .\" *                             \___|\___/|_| \_\_____| | ||||||
| .\" * | .\" * | ||||||
| .\" * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | .\" * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
| .\" * | .\" * | ||||||
| .\" * This software is licensed as described in the file COPYING, which | .\" * 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. | ||||||
|   | |||||||
| @@ -30,18 +30,19 @@ curl_formadd - add a section to a multipart/formdata HTTP POST | |||||||
| .ad | .ad | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| curl_formadd() is used to append sections when building a multipart/formdata | curl_formadd() is used to append sections when building a multipart/formdata | ||||||
| HTTP POST (sometimes referred to as RFC2388-style posts). Append one section at | HTTP POST (sometimes referred to as RFC2388-style posts). Append one section | ||||||
| a time until you've added all the sections you want included and then you pass | at a time until you've added all the sections you want included and then you | ||||||
| the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. | pass the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP. | ||||||
| \fIlastitem\fP is set after each call and on repeated invokes it should be | \fIlastitem\fP is set after each \fIcurl_formadd(3)\fP call and on repeated | ||||||
| left as set to allow repeated invokes to find the end of the list faster. | invokes it should be left as set to allow repeated invokes to find the end of | ||||||
|  | the list faster. | ||||||
|  |  | ||||||
| After the \fIlastitem\fP pointer follow the real arguments. | After the \fIlastitem\fP pointer follow the real arguments. | ||||||
|  |  | ||||||
| The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to | The pointers \fIfirstitem\fP and \fIlastitem\fP should both be pointing to | ||||||
| NULL in the first call to this function. All list-data will be allocated by | NULL in the first call to this function. All list-data will be allocated by | ||||||
| the function itself. You must call \fIcurl_formfree(3)\fP after the form post | the function itself. You must call \fIcurl_formfree(3)\fP on the | ||||||
| has been done to free the resources. | \fIfirstitem\P after the form post has been done to free the resources. | ||||||
|  |  | ||||||
| Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||||
| You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | ||||||
|   | |||||||
| @@ -31,6 +31,13 @@ curl_formfree - free a previously build multipart/formdata HTTP POST chain | |||||||
| curl_formfree() is used to clean up data previously built/appended with | curl_formfree() is used to clean up data previously built/appended with | ||||||
| \fIcurl_formadd(3)\fP. This must be called when the data has been used, which | \fIcurl_formadd(3)\fP. This must be called when the data has been used, which | ||||||
| typically means after \fIcurl_easy_perform(3)\fP has been called. | typically means after \fIcurl_easy_perform(3)\fP has been called. | ||||||
|  |  | ||||||
|  | The pointer to free is the same pointer you passed to the | ||||||
|  | \fBCURLOPT_HTTPPOST\fP option, which is the \fIfirstitem\fP pointer from the | ||||||
|  | \fIcurl_formadd(3)\fP invoke(s). | ||||||
|  |  | ||||||
|  | \fBform\fP is the pointer as returned from a previous call to | ||||||
|  | \fIcurl_formadd(3)\fP and may be NULL. | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| None | None | ||||||
| .SH "SEE ALSO" | .SH "SEE ALSO" | ||||||
|   | |||||||
| @@ -23,24 +23,27 @@ | |||||||
| .SH NAME | .SH NAME | ||||||
| curl_formget - serialize a previously built multipart/formdata HTTP POST chain | curl_formget - serialize a previously built multipart/formdata HTTP POST chain | ||||||
| .SH SYNOPSIS | .SH SYNOPSIS | ||||||
|  | .nf | ||||||
| .B #include <curl/curl.h> | .B #include <curl/curl.h> | ||||||
| .sp |  | ||||||
| .BI "void curl_formget(struct curl_httppost *" form, " void *" arg, | void curl_formget(struct curl_httppost * form, void *userp, | ||||||
| .BI " curl_formget_callback " append ");" |                   curl_formget_callback append ); | ||||||
| .ad |  | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| curl_formget() is used to serialize data previously built/appended with | curl_formget() is used to serialize data previously built/appended with | ||||||
| \fIcurl_formadd(3)\fP. Accepts a void pointer as second argument which will be | \fIcurl_formadd(3)\fP. Accepts a void pointer as second argument named | ||||||
| passed to the curl_formget_callback function. | \fIuserp\fP which will be passed as the first argument to the | ||||||
|  | curl_formget_callback function. | ||||||
|  |  | ||||||
| .BI "typedef size_t (*curl_formget_callback)(void *" arg, " const char *" buf, | .BI "typedef size_t (*curl_formget_callback)(void *" userp, " const char *" buf, | ||||||
| .BI " size_t " len ");" | .BI " size_t " len ");" | ||||||
| .nf |  | ||||||
|  |  | ||||||
| The curl_formget_callback will be executed for each part of the HTTP POST | The curl_formget_callback will be executed for each part of the HTTP POST | ||||||
| chain. The void *arg pointer will be the one passed as second argument to | chain. The character buffer passed to the callback must not be freed. The | ||||||
| curl_formget(). The character buffer passed to it must not be freed. The |  | ||||||
| callback should return the buffer length passed to it on success. | callback should return the buffer length passed to it on success. | ||||||
|  |  | ||||||
|  | If the \fBCURLFORM_STREAM\fP option is used in the formpost, it will prevent | ||||||
|  | \fIcurl_formget(3)\fP from working until you've performed the actual HTTP | ||||||
|  | request as only then will libcurl get the actual read callback to use! | ||||||
| .SH RETURN VALUE | .SH RETURN VALUE | ||||||
| 0 means everything was ok, non-zero means an error occurred | 0 means everything was ok, non-zero means an error occurred | ||||||
| .SH EXAMPLE | .SH EXAMPLE | ||||||
| @@ -52,6 +55,7 @@ callback should return the buffer length passed to it on success. | |||||||
|    (*(size_t *) arg) += len; |    (*(size_t *) arg) += len; | ||||||
|    return len; |    return len; | ||||||
|  } |  } | ||||||
|  |  | ||||||
|  size_t print_httppost(struct curl_httppost *post) |  size_t print_httppost(struct curl_httppost *post) | ||||||
|  { |  { | ||||||
|    size_t total_size = 0; |    size_t total_size = 0; | ||||||
|   | |||||||
| @@ -40,19 +40,28 @@ but be sure to FD_ZERO them before calling this function as | |||||||
| otherwise remove any others. The \fIcurl_multi_perform(3)\fP function should be | 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 | ||||||
| @@ -295,6 +302,8 @@ CURLOPT_CHUNK_DATA              7.21.0 | |||||||
| CURLOPT_CHUNK_END_FUNCTION      7.21.0 | CURLOPT_CHUNK_END_FUNCTION      7.21.0 | ||||||
| CURLOPT_CLOSEFUNCTION           7.7           7.11.1      7.15.5 | CURLOPT_CLOSEFUNCTION           7.7           7.11.1      7.15.5 | ||||||
| CURLOPT_CLOSEPOLICY             7.7           7.16.1 | CURLOPT_CLOSEPOLICY             7.7           7.16.1 | ||||||
|  | CURLOPT_CLOSESOCKETDATA         7.21.7 | ||||||
|  | CURLOPT_CLOSESOCKETFUNCTION     7.21.7 | ||||||
| CURLOPT_CONNECTTIMEOUT          7.7 | CURLOPT_CONNECTTIMEOUT          7.7 | ||||||
| CURLOPT_CONNECTTIMEOUT_MS       7.16.2 | CURLOPT_CONNECTTIMEOUT_MS       7.16.2 | ||||||
| CURLOPT_CONNECT_ONLY            7.15.2 | CURLOPT_CONNECT_ONLY            7.15.2 | ||||||
| @@ -314,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 | ||||||
| @@ -342,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 | ||||||
| @@ -373,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 | ||||||
| @@ -396,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 | ||||||
| @@ -471,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 | ||||||
| @@ -543,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 | ||||||
| @@ -550,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 | ||||||
| @@ -558,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 | ||||||
| @@ -631,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 | ||||||
| @@ -673,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 | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ | |||||||
| # | # | ||||||
| ########################################################################### | ########################################################################### | ||||||
| pkginclude_HEADERS = \ | pkginclude_HEADERS = \ | ||||||
| 	curl.h curlver.h easy.h mprintf.h stdcheaders.h types.h multi.h \ | 	curl.h curlver.h easy.h mprintf.h stdcheaders.h multi.h \ | ||||||
| 	typecheck-gcc.h curlbuild.h curlrules.h | 	typecheck-gcc.h curlbuild.h curlrules.h | ||||||
|  |  | ||||||
| pkgincludedir= $(includedir)/curl | pkgincludedir= $(includedir)/curl | ||||||
| @@ -44,3 +44,10 @@ EXTRA_DIST = curlbuild.h.in | |||||||
|  |  | ||||||
| DISTCLEANFILES = curlbuild.h | DISTCLEANFILES = curlbuild.h | ||||||
|  |  | ||||||
|  | checksrc: | ||||||
|  | 	@@PERL@ $(top_srcdir)/lib/checksrc.pl -Wcurlbuild.h -D$(top_srcdir)/include/curl $(pkginclude_HEADERS) $(EXTRA_DIST) | ||||||
|  |  | ||||||
|  | if CURLDEBUG | ||||||
|  | # for debug builds, we scan the sources on all regular make invokes | ||||||
|  | all-local: checksrc | ||||||
|  | endif | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * 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, | ||||||
| @@ -341,6 +339,9 @@ typedef curl_socket_t | |||||||
|                             curlsocktype purpose, |                             curlsocktype purpose, | ||||||
|                             struct curl_sockaddr *address); |                             struct curl_sockaddr *address); | ||||||
|  |  | ||||||
|  | typedef int | ||||||
|  | (*curl_closesocket_callback)(void *clientp, curl_socket_t item); | ||||||
|  |  | ||||||
| typedef enum { | typedef enum { | ||||||
|   CURLIOE_OK,            /* I/O operation successful */ |   CURLIOE_OK,            /* I/O operation successful */ | ||||||
|   CURLIOE_UNKNOWNCMD,    /* command was unknown to callback */ |   CURLIOE_UNKNOWNCMD,    /* command was unknown to callback */ | ||||||
| @@ -410,9 +411,12 @@ typedef enum { | |||||||
|   CURLE_REMOTE_ACCESS_DENIED,    /* 9 a service was denied by the server |   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 */ | ||||||
| @@ -507,16 +511,19 @@ typedef enum { | |||||||
|                                     7.19.0) */ |                                     7.19.0) */ | ||||||
|   CURLE_FTP_PRET_FAILED,         /* 84 - a PRET command failed */ |   CURLE_FTP_PRET_FAILED,         /* 84 - a PRET command failed */ | ||||||
|   CURLE_RTSP_CSEQ_ERROR,         /* 85 - mismatch of RTSP CSeq numbers */ |   CURLE_RTSP_CSEQ_ERROR,         /* 85 - mismatch of RTSP CSeq numbers */ | ||||||
|   CURLE_RTSP_SESSION_ERROR,      /* 86 - mismatch of RTSP Session Identifiers */ |   CURLE_RTSP_SESSION_ERROR,      /* 86 - mismatch of RTSP Session Ids */ | ||||||
|   CURLE_FTP_BAD_FILE_LIST,       /* 87 - unable to parse FTP file list */ |   CURLE_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 | ||||||
|  |  | ||||||
| @@ -591,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 */ | ||||||
| @@ -611,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 { | ||||||
| @@ -661,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! */ | ||||||
|  |  | ||||||
| @@ -755,7 +790,7 @@ typedef enum { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef CURL_ISOCPP | #ifdef CURL_ISOCPP | ||||||
| #define CINIT(name,type,number) CURLOPT_ ## name = CURLOPTTYPE_ ## type + number | #define CINIT(na,t,nu) CURLOPT_ ## na = CURLOPTTYPE_ ## t + nu | ||||||
| #else | #else | ||||||
| /* The macro "##" is ISO C, we assume pre-ISO C doesn't support it. */ | /* The macro "##" is ISO C, we assume pre-ISO C doesn't support it. */ | ||||||
| #define LONG          CURLOPTTYPE_LONG | #define LONG          CURLOPTTYPE_LONG | ||||||
| @@ -913,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 */ | ||||||
| @@ -924,7 +957,7 @@ typedef enum { | |||||||
|   CINIT(FAILONERROR, LONG, 45),  /* no output on http error codes >= 300 */ |   CINIT(FAILONERROR, LONG, 45),  /* no output on http error codes >= 300 */ | ||||||
|   CINIT(UPLOAD, LONG, 46),       /* this is an upload */ |   CINIT(UPLOAD, LONG, 46),       /* this is an upload */ | ||||||
|   CINIT(POST, LONG, 47),         /* HTTP POST method */ |   CINIT(POST, LONG, 47),         /* HTTP POST method */ | ||||||
|   CINIT(DIRLISTONLY, LONG, 48),  /* return bare names when listing directories */ |   CINIT(DIRLISTONLY, LONG, 48),  /* bare names when listing directories */ | ||||||
|  |  | ||||||
|   CINIT(APPEND, LONG, 50),       /* Append instead of overwrite on upload! */ |   CINIT(APPEND, LONG, 50),       /* Append instead of overwrite on upload! */ | ||||||
|  |  | ||||||
| @@ -991,9 +1024,7 @@ typedef enum { | |||||||
|   /* Max amount of cached alive connections */ |   /* Max amount of cached alive connections */ | ||||||
|   CINIT(MAXCONNECTS, LONG, 71), |   CINIT(MAXCONNECTS, LONG, 71), | ||||||
|  |  | ||||||
|   /* What policy to use when closing connections when the cache is filled |   CINIT(CLOSEPOLICY, LONG, 72), /* DEPRECATED, do not use! */ | ||||||
|      up */ |  | ||||||
|   CINIT(CLOSEPOLICY, LONG, 72), |  | ||||||
|  |  | ||||||
|   /* 73 = OBSOLETE */ |   /* 73 = OBSOLETE */ | ||||||
|  |  | ||||||
| @@ -1067,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), | ||||||
| @@ -1119,8 +1150,8 @@ typedef enum { | |||||||
|      and password to whatever host the server decides. */ |      and password to whatever host the server decides. */ | ||||||
|   CINIT(UNRESTRICTED_AUTH, LONG, 105), |   CINIT(UNRESTRICTED_AUTH, LONG, 105), | ||||||
|  |  | ||||||
|   /* Specifically switch on or off the FTP engine's use of the EPRT command ( it |   /* Specifically switch on or off the FTP engine's use of the EPRT command ( | ||||||
|      also disables the LPRT attempt). By default, those ones will always be |      it also disables the LPRT attempt). By default, those ones will always be | ||||||
|      attempted before the good old traditional PORT command. */ |      attempted before the good old traditional PORT command. */ | ||||||
|   CINIT(FTP_USE_EPRT, LONG, 106), |   CINIT(FTP_USE_EPRT, LONG, 106), | ||||||
|  |  | ||||||
| @@ -1476,6 +1507,34 @@ typedef enum { | |||||||
|   */ |   */ | ||||||
|   CINIT(TRANSFER_ENCODING, LONG, 207), |   CINIT(TRANSFER_ENCODING, LONG, 207), | ||||||
|  |  | ||||||
|  |   /* Callback function for closing socket (instead of close(2)). The callback | ||||||
|  |      should have type curl_closesocket_callback */ | ||||||
|  |   CINIT(CLOSESOCKETFUNCTION, FUNCTIONPOINT, 208), | ||||||
|  |   CINIT(CLOSESOCKETDATA, OBJECTPOINT, 209), | ||||||
|  |  | ||||||
|  |   /* allow GSSAPI credential delegation */ | ||||||
|  |   CINIT(GSSAPI_DELEGATION, LONG, 210), | ||||||
|  |  | ||||||
|  |   /* Set the name servers to use for DNS resolution */ | ||||||
|  |   CINIT(DNS_SERVERS, OBJECTPOINT, 211), | ||||||
|  |  | ||||||
|  |   /* Time-out accept operations (currently for FTP only) after this amount | ||||||
|  |      of miliseconds. */ | ||||||
|  |   CINIT(ACCEPTTIMEOUT_MS, LONG, 212), | ||||||
|  |  | ||||||
|  |   /* Set TCP keepalive */ | ||||||
|  |   CINIT(TCP_KEEPALIVE, LONG, 213), | ||||||
|  |  | ||||||
|  |   /* non-universal keepalive knobs (Linux, AIX, HP-UX, more) */ | ||||||
|  |   CINIT(TCP_KEEPIDLE, LONG, 214), | ||||||
|  |   CINIT(TCP_KEEPINTVL, LONG, 215), | ||||||
|  |  | ||||||
|  |   /* Enable/disable specific SSL features with a bitmask, see CURLSSLOPT_* */ | ||||||
|  |   CINIT(SSL_OPTIONS, LONG, 216), | ||||||
|  |  | ||||||
|  |   /* set the SMTP auth originator */ | ||||||
|  |   CINIT(MAIL_AUTH, OBJECTPOINT, 217), | ||||||
|  |  | ||||||
|   CURLOPT_LASTENTRY /* the last unused */ |   CURLOPT_LASTENTRY /* the last unused */ | ||||||
| } CURLoption; | } CURLoption; | ||||||
|  |  | ||||||
| @@ -1579,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, | ||||||
| @@ -1704,7 +1766,8 @@ CURL_EXTERN CURLFORMcode curl_formadd(struct curl_httppost **httppost, | |||||||
|  * Should return the buffer length passed to it as the argument "len" on |  * Should return the buffer length passed to it as the argument "len" on | ||||||
|  *   success. |  *   success. | ||||||
|  */ |  */ | ||||||
| typedef size_t (*curl_formget_callback)(void *arg, const char *buf, size_t len); | typedef size_t (*curl_formget_callback)(void *arg, const char *buf, | ||||||
|  |                                         size_t len); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * NAME curl_formget() |  * NAME curl_formget() | ||||||
| @@ -2003,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; | ||||||
|  |  | ||||||
| @@ -2084,6 +2148,7 @@ 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() | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * 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 | ||||||
|   | |||||||
| @@ -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.6-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 6 | #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 0x071506 | #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,15 +141,17 @@ __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") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_curl_off_t, | _CURL_WARNING(_curl_easy_setopt_err_curl_off_t, | ||||||
|   "curl_easy_setopt expects a curl_off_t argument for this option") |   "curl_easy_setopt expects a curl_off_t argument for this option") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_string, | _CURL_WARNING(_curl_easy_setopt_err_string, | ||||||
|   "curl_easy_setopt expects a string (char* or char[]) argument for this option" |               "curl_easy_setopt expects a " | ||||||
|  |               "string (char* or char[]) argument for this option" | ||||||
|   ) |   ) | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_write_callback, | _CURL_WARNING(_curl_easy_setopt_err_write_callback, | ||||||
|   "curl_easy_setopt expects a curl_write_callback argument for this option") |   "curl_easy_setopt expects a curl_write_callback argument for this option") | ||||||
| @@ -160,7 +162,8 @@ _CURL_WARNING(_curl_easy_setopt_err_ioctl_cb, | |||||||
| _CURL_WARNING(_curl_easy_setopt_err_sockopt_cb, | _CURL_WARNING(_curl_easy_setopt_err_sockopt_cb, | ||||||
|   "curl_easy_setopt expects a curl_sockopt_callback argument for this option") |   "curl_easy_setopt expects a curl_sockopt_callback argument for this option") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_opensocket_cb, | _CURL_WARNING(_curl_easy_setopt_err_opensocket_cb, | ||||||
|   "curl_easy_setopt expects a curl_opensocket_callback argument for this option" |               "curl_easy_setopt expects a " | ||||||
|  |               "curl_opensocket_callback argument for this option" | ||||||
|   ) |   ) | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_progress_cb, | _CURL_WARNING(_curl_easy_setopt_err_progress_cb, | ||||||
|   "curl_easy_setopt expects a curl_progress_callback argument for this option") |   "curl_easy_setopt expects a curl_progress_callback argument for this option") | ||||||
| @@ -173,9 +176,11 @@ _CURL_WARNING(_curl_easy_setopt_err_conv_cb, | |||||||
| _CURL_WARNING(_curl_easy_setopt_err_seek_cb, | _CURL_WARNING(_curl_easy_setopt_err_seek_cb, | ||||||
|   "curl_easy_setopt expects a curl_seek_callback argument for this option") |   "curl_easy_setopt expects a curl_seek_callback argument for this option") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_cb_data, | _CURL_WARNING(_curl_easy_setopt_err_cb_data, | ||||||
|   "curl_easy_setopt expects a private data pointer as argument for this option") |               "curl_easy_setopt expects a " | ||||||
|  |               "private data pointer as argument for this option") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_error_buffer, | _CURL_WARNING(_curl_easy_setopt_err_error_buffer, | ||||||
|   "curl_easy_setopt expects a char buffer of CURL_ERROR_SIZE as argument for this option") |               "curl_easy_setopt expects a " | ||||||
|  |               "char buffer of CURL_ERROR_SIZE as argument for this option") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_FILE, | _CURL_WARNING(_curl_easy_setopt_err_FILE, | ||||||
|   "curl_easy_setopt expects a FILE* argument for this option") |   "curl_easy_setopt expects a FILE* argument for this option") | ||||||
| _CURL_WARNING(_curl_easy_setopt_err_postfields, | _CURL_WARNING(_curl_easy_setopt_err_postfields, | ||||||
| @@ -388,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* */ | ||||||
| @@ -481,7 +487,8 @@ typedef int (_curl_sockopt_callback1)(void *, curl_socket_t, curlsocktype); | |||||||
| typedef int (_curl_sockopt_callback2)(const void *, curl_socket_t, | typedef int (_curl_sockopt_callback2)(const void *, curl_socket_t, | ||||||
|                                       curlsocktype); |                                       curlsocktype); | ||||||
|  |  | ||||||
| /* evaluates to true if expr is of type curl_opensocket_callback or "similar" */ | /* evaluates to true if expr is of type curl_opensocket_callback or | ||||||
|  |    "similar" */ | ||||||
| #define _curl_is_opensocket_cb(expr)                                    \ | #define _curl_is_opensocket_cb(expr)                                    \ | ||||||
|   (_curl_is_NULL(expr) ||                                                     \ |   (_curl_is_NULL(expr) ||                                                     \ | ||||||
|    __builtin_types_compatible_p(__typeof__(expr), curl_opensocket_callback) ||\ |    __builtin_types_compatible_p(__typeof__(expr), curl_opensocket_callback) ||\ | ||||||
| @@ -516,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 *, | ||||||
| @@ -525,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... */ | ||||||
| @@ -550,7 +569,8 @@ typedef CURLcode (_curl_ssl_ctx_callback4)(CURL *, const void *, const void *); | |||||||
| typedef CURLcode (_curl_ssl_ctx_callback5)(CURL *, SSL_CTX, void *); | typedef CURLcode (_curl_ssl_ctx_callback5)(CURL *, SSL_CTX, void *); | ||||||
| typedef CURLcode (_curl_ssl_ctx_callback6)(CURL *, SSL_CTX, const void *); | typedef CURLcode (_curl_ssl_ctx_callback6)(CURL *, SSL_CTX, const void *); | ||||||
| typedef CURLcode (_curl_ssl_ctx_callback7)(CURL *, const SSL_CTX, void *); | typedef CURLcode (_curl_ssl_ctx_callback7)(CURL *, const SSL_CTX, void *); | ||||||
| typedef CURLcode (_curl_ssl_ctx_callback8)(CURL *, const SSL_CTX, const void *); | typedef CURLcode (_curl_ssl_ctx_callback8)(CURL *, const SSL_CTX, | ||||||
|  |                                            const void *); | ||||||
| #else | #else | ||||||
| typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback5; | typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback5; | ||||||
| typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback6; | typedef _curl_ssl_ctx_callback1 _curl_ssl_ctx_callback6; | ||||||
|   | |||||||
| @@ -1 +0,0 @@ | |||||||
| /* not used */ |  | ||||||
							
								
								
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								lib/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -10,3 +10,4 @@ libcurl.plist.dist | |||||||
| libcurl.vcproj | libcurl.vcproj | ||||||
| vc6libcurl.dsp | vc6libcurl.dsp | ||||||
| Makefile.vc10.dist | Makefile.vc10.dist | ||||||
|  | libcurl.vers | ||||||
|   | |||||||
| @@ -122,3 +122,5 @@ if(WIN32) | |||||||
|     set_target_properties(${LIB_NAME} PROPERTIES IMPORT_SUFFIX "_imp.lib") |     set_target_properties(${LIB_NAME} PROPERTIES IMPORT_SUFFIX "_imp.lib") | ||||||
|   endif() |   endif() | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
|  | install(TARGETS ${LIB_NAME} DESTINATION lib) | ||||||
|   | |||||||
| @@ -70,19 +70,26 @@ CFLAGS += -d_WIN32_WINNT=0x0501 -dENABLE_IPV6 | |||||||
| CFLAGS += -dUSE_WINDOWS_SSPI | CFLAGS += -dUSE_WINDOWS_SSPI | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
|  | !ifdef %use_winidn | ||||||
|  | CFLAGS += -dWINVER=0x0600 -dUSE_WIN32_IDN | ||||||
|  | !  if $(__VERSION__) <= 1290 | ||||||
|  | CFLAGS += -dWANT_IDN_PROTOTYPES | ||||||
|  | !  endif | ||||||
|  | !endif | ||||||
|  |  | ||||||
| # | # | ||||||
| # Change to suite. | # Change to suite. | ||||||
| # | # | ||||||
| !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 | ||||||
| @@ -94,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 | ||||||
| @@ -229,6 +236,14 @@ $(LINK_ARG): $(__MAKEFILES__) | |||||||
| !ifdef %use_ares | !ifdef %use_ares | ||||||
| 	@%append $^@ library $(ARES_ROOT)$(DS)cares.lib | 	@%append $^@ library $(ARES_ROOT)$(DS)cares.lib | ||||||
| !endif | !endif | ||||||
|  | !ifdef %use_winidn | ||||||
|  | !  if $(__VERSION__) > 1290 | ||||||
|  | 	@%append $^@ library normaliz.lib | ||||||
|  | !  else | ||||||
|  | 	@%append $^@ import '_IdnToAscii@20' 'NORMALIZ.DLL'.'IdnToAscii' | ||||||
|  | 	@%append $^@ import '_IdnToUnicode@20' 'NORMALIZ.DLL'.'IdnToUnicode' | ||||||
|  | !  endif | ||||||
|  | !endif | ||||||
|  |  | ||||||
| $(LIB_ARG): $(__MAKEFILES__) | $(LIB_ARG): $(__MAKEFILES__) | ||||||
| 	%create $^@ | 	%create $^@ | ||||||
|   | |||||||
| @@ -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,12 +33,12 @@ 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		   \ | ||||||
|  mk-ca-bundle.vbs firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h	   \ |  mk-ca-bundle.vbs firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h	   \ | ||||||
|  Makefile.vxworks config-vms.h |  Makefile.vxworks config-vms.h checksrc.pl | ||||||
|  |  | ||||||
| CLEANFILES = $(DSP) $(VCPROJ) | CLEANFILES = $(DSP) $(VCPROJ) | ||||||
|  |  | ||||||
| @@ -46,7 +46,9 @@ lib_LTLIBRARIES = libcurl.la | |||||||
| LIBCURL_LIBS = @LIBCURL_LIBS@ | LIBCURL_LIBS = @LIBCURL_LIBS@ | ||||||
|  |  | ||||||
| # This might hold -Werror | # This might hold -Werror | ||||||
| libcurl_la_CFLAGS = $(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 | ||||||
| @@ -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 | ||||||
| @@ -106,7 +120,7 @@ endif | |||||||
| # For the full guide on libcurl ABI rules, see docs/libcurl/ABI | # For the full guide on libcurl ABI rules, see docs/libcurl/ABI | ||||||
|  |  | ||||||
| if NO_UNDEFINED | if NO_UNDEFINED | ||||||
| # The -no-undefined flag is CRUCIAL for this to build fine on Cygwin. | # The -no-undefined flag is crucial to build fine on some platforms | ||||||
| UNDEF = -no-undefined | UNDEF = -no-undefined | ||||||
| endif | endif | ||||||
|  |  | ||||||
| @@ -116,18 +130,31 @@ if MIMPURE | |||||||
| MIMPURE = -mimpure-text | MIMPURE = -mimpure-text | ||||||
| endif | endif | ||||||
|  |  | ||||||
| LINKFLAGS=$(UNDEF) $(MIMPURE) $(LIBCURL_LIBS) | if VERSIONED_SYMBOLS | ||||||
|  | VERSIONED_SYMBOLS = -Wl,--version-script=libcurl.vers | ||||||
| libcurl_la_LDFLAGS = $(LINKFLAGS) $(VERSIONINFO) |  | ||||||
|  |  | ||||||
| # as unit testing will compile and link everything an extra time, we only |  | ||||||
| # do it if debug is enabled |  | ||||||
| if CURLDEBUG |  | ||||||
| noinst_LTLIBRARIES = libcurlu.la |  | ||||||
| libcurlu_la_CFLAGS = -DUNITTESTS |  | ||||||
| libcurlu_la_LDFLAGS = -static $(LINKFLAGS) |  | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  | libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(VERSIONED_SYMBOLS) $(LIBCURL_LIBS) | ||||||
|  |  | ||||||
|  | if DOING_CURL_SYMBOL_HIDING | ||||||
|  | libcurl_la_CPPFLAGS = $(AM_CPPFLAGS) -DCURL_HIDDEN_SYMBOLS | ||||||
|  | libcurl_la_CFLAGS = $(AM_CFLAGS) $(CFLAG_CURL_SYMBOL_HIDING) | ||||||
|  | else | ||||||
|  | libcurl_la_CPPFLAGS = $(AM_CPPFLAGS) | ||||||
|  | libcurl_la_CFLAGS = $(AM_CFLAGS) | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # unit testing static library built only along with unit tests | ||||||
|  | if BUILD_UNITTESTS | ||||||
|  | noinst_LTLIBRARIES = libcurlu.la | ||||||
|  | else | ||||||
|  | noinst_LTLIBRARIES = | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS | ||||||
|  | libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS) | ||||||
|  | libcurlu_la_CFLAGS = $(AM_CFLAGS) | ||||||
|  |  | ||||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||||
| include Makefile.inc | include Makefile.inc | ||||||
|  |  | ||||||
| @@ -184,3 +211,12 @@ $(VCPROJ): vc8proj.head vc8proj.foot Makefile.am | |||||||
| 	echo "<File RelativePath=\""$$file"\"></File>" $(VCPROJOUT); \ | 	echo "<File RelativePath=\""$$file"\"></File>" $(VCPROJOUT); \ | ||||||
| 	done; \ | 	done; \ | ||||||
| 	cat $(srcdir)/vc8proj.foot $(VCPROJOUT) ) | 	cat $(srcdir)/vc8proj.foot $(VCPROJOUT) ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | checksrc: | ||||||
|  | 	@@PERL@ $(top_srcdir)/lib/checksrc.pl -D$(top_srcdir)/lib $(CSOURCES) $(HHEADERS) | ||||||
|  |  | ||||||
|  | if CURLDEBUG | ||||||
|  | # for debug builds, we scan the sources on all regular make invokes | ||||||
|  | all-local: checksrc | ||||||
|  | endif | ||||||
|   | |||||||
| @@ -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,15 +14,16 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c	\ | |||||||
|   curl_fnmatch.c fileinfo.c ftplistparser.c wildcard.c krb5.c		\ |   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		\ | ||||||
|   hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c	\ |   hostasyn.c hostip4.c hostip6.c hostsyn.c inet_ntop.c parsedate.c	\ | ||||||
|   inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c	\ |   select.c gtls.c sslgen.c tftp.c splay.c strdup.c socks.c ssh.c nss.c	\ | ||||||
|   strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c		\ |   qssl.c rawstr.c curl_addrinfo.c socks_gssapi.c socks_sspi.c		\ | ||||||
|   socks_gssapi.c socks_sspi.c curl_sspi.c slist.c nonblock.c		\ |   curl_sspi.c slist.c nonblock.c curl_memrchr.c imap.c pop3.c smtp.c	\ | ||||||
|   curl_memrchr.c imap.c pop3.c smtp.c pingpong.c rtsp.c curl_threads.c	\ |   pingpong.c rtsp.c curl_threads.c warnless.c hmac.c polarssl.c		\ | ||||||
|   warnless.c hmac.c polarssl.c curl_rtmp.c openldap.c curl_gethostname.c\ |   curl_rtmp.c openldap.c curl_gethostname.c gopher.c axtls.c		\ | ||||||
|   gopher.c axtls.c idn_win32.c http_negotiate_sspi.c cyassl.c http_proxy.c \ |   idn_win32.c http_negotiate_sspi.c cyassl.c http_proxy.c non-ascii.c	\ | ||||||
|   non-ascii.c |   asyn-ares.c asyn-thread.c curl_gssapi.c curl_ntlm.c curl_ntlm_wb.c	\ | ||||||
|  |   curl_ntlm_core.c curl_ntlm_msgs.c | ||||||
|  |  | ||||||
| HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | 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,12 +31,12 @@ HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h	\ | |||||||
|   getinfo.h strequal.h krb4.h memdebug.h http_chunks.h curl_rand.h	\ |   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 |   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 | ||||||
| @@ -169,7 +195,6 @@ 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,8 +106,9 @@ 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 | 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 | ||||||
| LNKDLL     = link.exe /DLL | LNKDLL     = link.exe /DLL | ||||||
| LNKLIB     = link.exe /lib | LNKLIB     = link.exe /lib | ||||||
| @@ -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 | ||||||
| @@ -457,6 +496,8 @@ clean: | |||||||
| # A config was provided, so the library can be built. | # A config was provided, so the library can be built. | ||||||
| # | # | ||||||
| X_OBJS= \ | X_OBJS= \ | ||||||
|  | 	$(DIROBJ)\asyn-ares.obj \ | ||||||
|  | 	$(DIROBJ)\asyn-thread.obj \ | ||||||
| 	$(DIROBJ)\base64.obj \ | 	$(DIROBJ)\base64.obj \ | ||||||
| 	$(DIROBJ)\connect.obj \ | 	$(DIROBJ)\connect.obj \ | ||||||
| 	$(DIROBJ)\content_encoding.obj \ | 	$(DIROBJ)\content_encoding.obj \ | ||||||
| @@ -465,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 \ | ||||||
| @@ -479,22 +524,19 @@ X_OBJS= \ | |||||||
| 	$(DIROBJ)\ftp.obj \ | 	$(DIROBJ)\ftp.obj \ | ||||||
| 	$(DIROBJ)\getenv.obj \ | 	$(DIROBJ)\getenv.obj \ | ||||||
| 	$(DIROBJ)\getinfo.obj \ | 	$(DIROBJ)\getinfo.obj \ | ||||||
| 	$(DIROBJ)\gtls.obj \ |  | ||||||
| 	$(DIROBJ)\gopher.obj \ | 	$(DIROBJ)\gopher.obj \ | ||||||
|  | 	$(DIROBJ)\gtls.obj \ | ||||||
| 	$(DIROBJ)\hash.obj \ | 	$(DIROBJ)\hash.obj \ | ||||||
| 	$(DIROBJ)\hmac.obj \ | 	$(DIROBJ)\hmac.obj \ | ||||||
| 	$(DIROBJ)\hostares.obj \ |  | ||||||
| 	$(DIROBJ)\hostasyn.obj \ | 	$(DIROBJ)\hostasyn.obj \ | ||||||
| 	$(DIROBJ)\hostip4.obj \ | 	$(DIROBJ)\hostip4.obj \ | ||||||
| 	$(DIROBJ)\hostip6.obj \ | 	$(DIROBJ)\hostip6.obj \ | ||||||
| 	$(DIROBJ)\hostip.obj \ | 	$(DIROBJ)\hostip.obj \ | ||||||
| 	$(DIROBJ)\hostsyn.obj \ | 	$(DIROBJ)\hostsyn.obj \ | ||||||
| 	$(DIROBJ)\hostthre.obj \ |  | ||||||
| 	$(DIROBJ)\http_chunks.obj \ | 	$(DIROBJ)\http_chunks.obj \ | ||||||
| 	$(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 \ | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user