Compare commits
	
		
			837 Commits
		
	
	
		
			curl-7_16_
			...
			curl-7_16_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | b8d006b9d7 | ||
|   | af4edf10f5 | ||
|   | 0f9e209534 | ||
|   | 2aed8946b0 | ||
|   | 03b03f7b60 | ||
|   | a1b650ad7b | ||
|   | d978f85d55 | ||
|   | 6e7f47da5b | ||
|   | 277bab0c7b | ||
|   | fc3c5dae87 | ||
|   | 891dffb528 | ||
|   | f0b361ecc1 | ||
|   | df7eed16dd | ||
|   | 61db4f3e2a | ||
|   | fe85ae15f3 | ||
|   | cc26cc5dcd | ||
|   | eb965e2a13 | ||
|   | 4e35395d0e | ||
|   | b61b420cb8 | ||
|   | b0aa11fde7 | ||
|   | b691102ec7 | ||
|   | 2785fe7f61 | ||
|   | db5d4bd811 | ||
|   | dc3b3c6916 | ||
|   | 82d3f97659 | ||
|   | 235632ed2c | ||
|   | 68330c86e7 | ||
|   | f37dc9168a | ||
|   | 17798ed740 | ||
|   | 05ba9f9fcd | ||
|   | 96f4af4db9 | ||
|   | 3ec7f8a25a | ||
|   | 375cdf89ad | ||
|   | ab7e7144ef | ||
|   | 6f59e19b91 | ||
|   | 7800b56dc8 | ||
|   | 73c13220ee | ||
|   | 99e0597c7b | ||
|   | 3247ac1918 | ||
|   | c45d44fee9 | ||
|   | 1e718a515a | ||
|   | d23d686de2 | ||
|   | c8677e9d3f | ||
|   | a32eaffa77 | ||
|   | 1dcb99f0f7 | ||
|   | 03bc2d34da | ||
|   | 477e27f99d | ||
|   | 6a84d492f1 | ||
|   | 873d95a34c | ||
|   | 1500e95839 | ||
|   | 4f8ebd1673 | ||
|   | cd4e6fbcac | ||
|   | 2fd2ca9dac | ||
|   | 82d6240e7d | ||
|   | ad80490711 | ||
|   | 38b490a310 | ||
|   | 2ea052336f | ||
|   | 3b9eefca89 | ||
|   | 073a6cea45 | ||
|   | 345ffd1163 | ||
|   | f0ffb35d55 | ||
|   | b4d2fbae6d | ||
|   | 42a2138d11 | ||
|   | e86dfd9688 | ||
|   | a466b31574 | ||
|   | 48064f8dee | ||
|   | e71378d3c8 | ||
|   | 90d40aff72 | ||
|   | 30808dca40 | ||
|   | 8629620b1c | ||
|   | 25d2a27c64 | ||
|   | b084dc8760 | ||
|   | 2ae9536d32 | ||
|   | f5713dbb2e | ||
|   | b10ff9791b | ||
|   | 86a25239ec | ||
|   | 4c663ba9a8 | ||
|   | 713c9f8602 | ||
|   | 14b9b823e6 | ||
|   | 6a674ded0e | ||
|   | 2faba57c85 | ||
|   | 79d59ec97b | ||
|   | a49e78d9b7 | ||
|   | 9583b51d80 | ||
|   | 670273968c | ||
|   | b6820b2674 | ||
|   | b9a6dfab03 | ||
|   | 8bd7197a8f | ||
|   | ebb5e1db4b | ||
|   | 4702807da8 | ||
|   | fe1fe64fd4 | ||
|   | 9d904ee41b | ||
|   | fcc3e2ca34 | ||
|   | c25da51913 | ||
|   | 05ab8d291c | ||
|   | 70b1900dd1 | ||
|   | 380e132da3 | ||
|   | f2eb3c1f79 | ||
|   | 96c093f27c | ||
|   | a9d49769ff | ||
|   | d7616d8a0a | ||
|   | 826bbfc01c | ||
|   | 250f9670b7 | ||
|   | ed4936fd30 | ||
|   | 4dd2628093 | ||
|   | 8479785620 | ||
|   | 0427e94465 | ||
|   | 09fd3b4935 | ||
|   | 3fef839f75 | ||
|   | ea43bb013b | ||
|   | b0a4c992e7 | ||
|   | 85707460e5 | ||
|   | 41ba7666f0 | ||
|   | 4367e0513a | ||
|   | ed998270aa | ||
|   | 1b7f00b2a6 | ||
|   | ad19f95f15 | ||
|   | bcfe3cb231 | ||
|   | 805a5dcac8 | ||
|   | 0b67ee7bad | ||
|   | 9298037639 | ||
|   | f7472075d7 | ||
|   | 9f72db13c4 | ||
|   | acc4868b78 | ||
|   | 1afb67e31b | ||
|   | 2f0539d880 | ||
|   | 6f7d0a7cbd | ||
|   | 3d513f7ab1 | ||
|   | 6c8e6549d0 | ||
|   | eec105daba | ||
|   | 19a80add95 | ||
|   | 93844f64ef | ||
|   | 60588b2455 | ||
|   | 5187faeeb9 | ||
|   | 1228ec9fbb | ||
|   | 717adfeb96 | ||
|   | 503557e5ce | ||
|   | f611f42dcf | ||
|   | 7a0e0c36c5 | ||
|   | 61edee979f | ||
|   | 7a343a3f60 | ||
|   | b4d3c4a76c | ||
|   | f213d0db98 | ||
|   | 6e835ef3aa | ||
|   | ed8cb57151 | ||
|   | 9bdb05b4d6 | ||
|   | 94b253fde7 | ||
|   | 61d7e720a5 | ||
|   | 17507eac85 | ||
|   | bc1ae973da | ||
|   | 6a35841b2e | ||
|   | 28dde78dde | ||
|   | 37171809f6 | ||
|   | 3398eca7c3 | ||
|   | 3616912d22 | ||
|   | 0abccc676d | ||
|   | a93af43974 | ||
|   | 0bbc759c0c | ||
|   | 56a5c49ac0 | ||
|   | 02267eba4c | ||
|   | cea9695bcf | ||
|   | 92039629c7 | ||
|   | c8d3327e92 | ||
|   | 043070f90e | ||
|   | 36626c4b6e | ||
|   | 7f33aae067 | ||
|   | 61022f3817 | ||
|   | bf648fcfc3 | ||
|   | b0e909329e | ||
|   | ae3d5949b8 | ||
|   | c234b9d04b | ||
|   | 7a86740afd | ||
|   | 8e719e3ef5 | ||
|   | 66fc5498d2 | ||
|   | f30ae93a1f | ||
|   | 365e8eb78e | ||
|   | 76627b322e | ||
|   | 827228bd69 | ||
|   | 69c5506b69 | ||
|   | 3a2e623fc8 | ||
|   | 8aa9f01ed8 | ||
|   | b0b6a853f6 | ||
|   | 0563a7a923 | ||
|   | 945ba7cb7e | ||
|   | e3dab1bea2 | ||
|   | 9c369c695d | ||
|   | 011ccbc31a | ||
|   | f1596698ae | ||
|   | c60b52ab43 | ||
|   | 71a0d50f48 | ||
|   | 8d2a0fe85b | ||
|   | b039d883e5 | ||
|   | b3401ddbad | ||
|   | 038fe54e21 | ||
|   | 4b5a65455e | ||
|   | 2566a5d4da | ||
|   | c38c339480 | ||
|   | ea74b4b8e1 | ||
|   | 2364066be0 | ||
|   | b36376e12d | ||
|   | 8aae15b630 | ||
|   | 88bf2a2dc7 | ||
|   | 45847c5324 | ||
|   | 70cce4cddd | ||
|   | 42c0ac2008 | ||
|   | 70ddabbfb0 | ||
|   | e3716938bd | ||
|   | b122959c8b | ||
|   | 84c5e846b3 | ||
|   | 47f044265e | ||
|   | d46d995766 | ||
|   | 1a0cc60741 | ||
|   | 7cbbd1b56b | ||
|   | 5daa6b9367 | ||
|   | a7aca2e8af | ||
|   | d8d3dc9302 | ||
|   | 5be7b543d8 | ||
|   | 910ee13b20 | ||
|   | 35935d71d2 | ||
|   | de17f4436e | ||
|   | be5ade5c7a | ||
|   | 0e05a6329a | ||
|   | c518c52aba | ||
|   | e4c28abdc1 | ||
|   | a11374d994 | ||
|   | d9e89e170f | ||
|   | 47594be5c0 | ||
|   | 0d635a1119 | ||
|   | e9ffa9a3b8 | ||
|   | 248a5381d4 | ||
|   | c1ab3e2d59 | ||
|   | c895dc8a19 | ||
|   | a0a79ce853 | ||
|   | 70f9a13ecb | ||
|   | c321b9f704 | ||
|   | 7e74349b86 | ||
|   | fd016fb3ee | ||
|   | 09dd2d3856 | ||
|   | 5625e5d5b8 | ||
|   | 8a529bd987 | ||
|   | 8fe9376d54 | ||
|   | a1f72943e9 | ||
|   | 0969a96732 | ||
|   | ec8019b2a8 | ||
|   | 27d2d78059 | ||
|   | 7d48d851a2 | ||
|   | 6a2cecf153 | ||
|   | 990b15e402 | ||
|   | 584f3639e3 | ||
|   | 2886ce96b0 | ||
|   | 3344142b87 | ||
|   | f1b4f5e2ae | ||
|   | bcf0af9ddb | ||
|   | 70550a0572 | ||
|   | d7088d1032 | ||
|   | d07a874899 | ||
|   | c420113795 | ||
|   | 5c850b825b | ||
|   | 7bbad0b534 | ||
|   | 305e03905f | ||
|   | 161be66c89 | ||
|   | 4095c9de37 | ||
|   | 20d33ad7e5 | ||
|   | b8c12fe658 | ||
|   | e4d4ee8db5 | ||
|   | 8a7d58378b | ||
|   | bdbaedc452 | ||
|   | 0839621f47 | ||
|   | bf2c1e099c | ||
|   | 6c6e4710b5 | ||
|   | 5e7164f87a | ||
|   | ef10eaeb29 | ||
|   | fce4dcccd8 | ||
|   | f2beee209b | ||
|   | 9d8b22d3de | ||
|   | 5796c7b132 | ||
|   | dc2ea33e32 | ||
|   | c1f117700a | ||
|   | 7ea90c46eb | ||
|   | 4d9e24d1e4 | ||
|   | 1f236ba108 | ||
|   | d27813c2dd | ||
|   | 453e9b0dce | ||
|   | b8626c3df8 | ||
|   | f8d78d57a7 | ||
|   | 371a25eee9 | ||
|   | e535a71c71 | ||
|   | b9e5fecf5f | ||
|   | 3af08472ad | ||
|   | fdc1b61507 | ||
|   | 7fd154f094 | ||
|   | a209c32bf3 | ||
|   | 75db459f0a | ||
|   | 74e54c5a49 | ||
|   | 6fc151577e | ||
|   | 3dcc7202d5 | ||
|   | 40981286ea | ||
|   | f55a1c3a6c | ||
|   | c5586a65c2 | ||
|   | ffb11ad5c6 | ||
|   | fbb1e49215 | ||
|   | c26320d94f | ||
|   | f6e892b1b6 | ||
|   | 59302d4ba0 | ||
|   | c563a53c16 | ||
|   | 7763bb9172 | ||
|   | e37a49086e | ||
|   | a1e5c621c0 | ||
|   | f776c1d2eb | ||
|   | 3d5a8515a6 | ||
|   | 42a7905205 | ||
|   | bfa0f8c6c2 | ||
|   | 869d192ffc | ||
|   | 60bc103a78 | ||
|   | 8a0a7ce3a8 | ||
|   | 31b1e988f4 | ||
|   | 25c064c888 | ||
|   | 884171aecf | ||
|   | 45b2577974 | ||
|   | d58c7a8bdd | ||
|   | eed47311f8 | ||
|   | 59eaae42b8 | ||
|   | 59c620bfa5 | ||
|   | 4294cac701 | ||
|   | 282127fbff | ||
|   | d49e9fad19 | ||
|   | fba4cd0e62 | ||
|   | 2166645ce4 | ||
|   | 844f5b6b45 | ||
|   | 424063235b | ||
|   | 8272abef28 | ||
|   | 5fbc93c3eb | ||
|   | 8851df41c5 | ||
|   | a6f4612154 | ||
|   | 52e5e869e6 | ||
|   | 12ef1035bb | ||
|   | 6c56b5301f | ||
|   | 07b6625573 | ||
|   | fa0780bb91 | ||
|   | f08ac86834 | ||
|   | d6eca89229 | ||
|   | 2bd1d7e996 | ||
|   | 3b355421ec | ||
|   | 0dd1219668 | ||
|   | b7131009fb | ||
|   | 3d528e1b15 | ||
|   | f9a339a225 | ||
|   | 0043e87014 | ||
|   | 0f634a0c89 | ||
|   | 047cd1a533 | ||
|   | f9eb61e90a | ||
|   | 34afb0b257 | ||
|   | 6bb9bd8b69 | ||
|   | 72175c738f | ||
|   | 2288094b26 | ||
|   | 273b2b230b | ||
|   | 3229a80c9f | ||
|   | 5eba84eed3 | ||
|   | 4fb483012c | ||
|   | f1a8fd843f | ||
|   | 8920606b8b | ||
|   | 90ce18019c | ||
|   | fe10cb2ef5 | ||
|   | 842be6c52f | ||
|   | e4b754f64e | ||
|   | 34ed4642ec | ||
|   | 248f057137 | ||
|   | 2b6a0c0a7c | ||
|   | 072a8b2955 | ||
|   | 0c817b6614 | ||
|   | e9cbd0c366 | ||
|   | ff314d7600 | ||
|   | d052e545af | ||
|   | da2b75a026 | ||
|   | 0e2d3b7b6c | ||
|   | 46a50aa001 | ||
|   | 605a391178 | ||
|   | de6f82d094 | ||
|   | c1f3edbdd1 | ||
|   | a20a6f67c5 | ||
|   | 75931492c3 | ||
|   | 800b55c702 | ||
|   | a53411c0dd | ||
|   | b169aa2992 | ||
|   | 9189ac1141 | ||
|   | 5c7c79bd08 | ||
|   | 8605321d06 | ||
|   | d314453037 | ||
|   | 9cb69f77f1 | ||
|   | ee332e0c8e | ||
|   | 0188493d54 | ||
|   | ae07fd2ba8 | ||
|   | d76a734043 | ||
|   | b66def2b4c | ||
|   | 20b9ab49a7 | ||
|   | c8cd13337e | ||
|   | 40e9e40cb4 | ||
|   | 09c70dec08 | ||
|   | 0dc570862a | ||
|   | dbaf4f9361 | ||
|   | 433575068c | ||
|   | 40087ce7c0 | ||
|   | e12d46ac50 | ||
|   | 1e55ed5c7d | ||
|   | 6dd4fe0740 | ||
|   | 3789e2e6ce | ||
|   | 1962ebf8e7 | ||
|   | 7c144d5a7e | ||
|   | 0f0540d00b | ||
|   | 3f29ed6d44 | ||
|   | 1bfa7dfe39 | ||
|   | 85daec253c | ||
|   | 389a15a867 | ||
|   | 74befdfbe0 | ||
|   | d31feb8ff9 | ||
|   | 4c3568bfd6 | ||
|   | b4ef5e22e0 | ||
|   | 23786eae32 | ||
|   | c84f84c70d | ||
|   | e5f8e5e57a | ||
|   | 53a3abc76b | ||
|   | bfd6474f6b | ||
|   | d3b89e114a | ||
|   | aeddea2b71 | ||
|   | cef5b14baa | ||
|   | 82d310d0d9 | ||
|   | 4fdb42377b | ||
|   | be8a5d0aef | ||
|   | dd433679e6 | ||
|   | 99dcd33f04 | ||
|   | e817eb6cec | ||
|   | 060f7ca2d2 | ||
|   | 638c715a51 | ||
|   | af9a63287e | ||
|   | 00f36c5f45 | ||
|   | e69d82a5fb | ||
|   | d165da07fe | ||
|   | 15363cd6dc | ||
|   | b3272fd799 | ||
|   | fa31335926 | ||
|   | acc4cf87cd | ||
|   | 7444342675 | ||
|   | ee1235a7cd | ||
|   | c514a2a89a | ||
|   | e2f0580dfe | ||
|   | d165bed2d6 | ||
|   | 802a5b618e | ||
|   | 1ca763d1d1 | ||
|   | 8b26c93a59 | ||
|   | b819c72700 | ||
|   | d2cfb7fd13 | ||
|   | e37973913d | ||
|   | 8b5295d003 | ||
|   | fe0afb211e | ||
|   | 141b3d0c2f | ||
|   | 2a6a22a3b0 | ||
|   | 4937281ddc | ||
|   | 8e27ed2fdd | ||
|   | 9bf9617ad6 | ||
|   | 69565afab0 | ||
|   | 39aac63521 | ||
|   | f19d333ef6 | ||
|   | 3a634a273a | ||
|   | 06d1b029f6 | ||
|   | 45bf417301 | ||
|   | 48029d7e74 | ||
|   | 83e078256c | ||
|   | 2f5e99ca02 | ||
|   | 6014c21bc9 | ||
|   | 8c0b1dc3c5 | ||
|   | be3c5f0b94 | ||
|   | e268e8559e | ||
|   | 29bb6f65f1 | ||
|   | 37f07a54bd | ||
|   | da8c666e4f | ||
|   | c11681becd | ||
|   | 78a1e5d1a6 | ||
|   | 116f60e063 | ||
|   | 7725853446 | ||
|   | 9993e2121d | ||
|   | 9a70ce4245 | ||
|   | 7ba53a4f41 | ||
|   | 1297c54b26 | ||
|   | 1045b8d382 | ||
|   | d2bdad5945 | ||
|   | 17e8d60c01 | ||
|   | ec1b351317 | ||
|   | 75fca27f8e | ||
|   | f2cd2882a0 | ||
|   | 07d8a14ec0 | ||
|   | 31e598d2f3 | ||
|   | cbf58d88d0 | ||
|   | 300cbc2e21 | ||
|   | ec9e399668 | ||
|   | 2691f1efc8 | ||
|   | d9bf55570b | ||
|   | b54a8531a9 | ||
|   | 789fd0b74a | ||
|   | 8103915797 | ||
|   | c461254dea | ||
|   | 3f140a6008 | ||
|   | a0a47f2767 | ||
|   | 213017e9cf | ||
|   | 69f2f5cb6f | ||
|   | d46cab4a94 | ||
|   | 4dc453c087 | ||
|   | a1d5983991 | ||
|   | 4894ce16fc | ||
|   | aa4435c23b | ||
|   | dca8f962e0 | ||
|   | 059b57677c | ||
|   | 9896421586 | ||
|   | 6663608d15 | ||
|   | d21e4eb8ae | ||
|   | d381dd68cf | ||
|   | 7a97e66fb3 | ||
|   | d86e6d3ed2 | ||
|   | f99ca90540 | ||
|   | e24cb6cb90 | ||
|   | b05f408348 | ||
|   | c5e7d839d5 | ||
|   | e3ade3ccb5 | ||
|   | 71afe05b9f | ||
|   | 5a267c4312 | ||
|   | fbcf86b83e | ||
|   | 5c3f36b4b4 | ||
|   | 9de4e5ebe4 | ||
|   | 7033a1c072 | ||
|   | 4efa0d9f68 | ||
|   | e021fe9444 | ||
|   | 23d1041bd8 | ||
|   | be71ccbce3 | ||
|   | 0db485a448 | ||
|   | 6d05a33ed9 | ||
|   | 569c169559 | ||
|   | ecbc7f89c0 | ||
|   | 5649b738be | ||
|   | 0f9f6cf180 | ||
|   | 7f70dbcad5 | ||
|   | 28b932fb4e | ||
|   | a631741141 | ||
|   | c7d0966201 | ||
|   | cf491357b6 | ||
|   | 02c17651bf | ||
|   | 890b34d22e | ||
|   | e89fb10736 | ||
|   | 48e8b52fbb | ||
|   | 61f19c6ca3 | ||
|   | 8c9233f6b2 | ||
|   | 6fcf98f617 | ||
|   | 2f4fe0175b | ||
|   | 9f62ff5df6 | ||
|   | 4e3f3e751e | ||
|   | 04e6568a7e | ||
|   | 7a39b98471 | ||
|   | 4ab91a93e8 | ||
|   | 6647ca6ec5 | ||
|   | 529e01736c | ||
|   | 078fc4186b | ||
|   | fabbb3fc34 | ||
|   | 1db063e705 | ||
|   | 1fa9ef246a | ||
|   | e12220cc4c | ||
|   | 77fcad041f | ||
|   | e213555c98 | ||
|   | 3a813b3c3b | ||
|   | 028a9d6785 | ||
|   | d0aca8017f | ||
|   | 91386937ff | ||
|   | 0fc51ac5a6 | ||
|   | bc2183b440 | ||
|   | 01c4fba15c | ||
|   | 9b6474378a | ||
|   | 5446ed4733 | ||
|   | a50414f594 | ||
|   | fe7fa8e794 | ||
|   | 6a175b42db | ||
|   | a7748c2024 | ||
|   | 8f87c15bda | ||
|   | 82f52e5a6f | ||
|   | 67d2dd62f9 | ||
|   | 138b4f27b4 | ||
|   | c26ec47e90 | ||
|   | 8337a375dd | ||
|   | 8260243be1 | ||
|   | ef6f24a7ce | ||
|   | abe90019d3 | ||
|   | c185cdf2b4 | ||
|   | f71c8c7d84 | ||
|   | d32f1390b3 | ||
|   | 68f3c2adca | ||
|   | 2a8e2edf83 | ||
|   | 401598c2fe | ||
|   | d60848d04b | ||
|   | d2dd3d7e16 | ||
|   | 1c63ceb317 | ||
|   | c25283185a | ||
|   | 54db98c220 | ||
|   | 5565f45f5e | ||
|   | 49c4d9c9cd | ||
|   | c2639e0738 | ||
|   | e485a23a3e | ||
|   | d7d5baa0e2 | ||
|   | e1e55e4d04 | ||
|   | 1eb530d8dc | ||
|   | bad67830b3 | ||
|   | db22c83031 | ||
|   | a4b39c6ab8 | ||
|   | d10e174fd1 | ||
|   | e994c6af75 | ||
|   | ef442d5803 | ||
|   | 8680e010c2 | ||
|   | 4d8dcf7b77 | ||
|   | abdbd3100f | ||
|   | ddace02efe | ||
|   | 1f4c8c4f09 | ||
|   | 8162b32bad | ||
|   | daf527b276 | ||
|   | ee51c07be6 | ||
|   | 856ba4c6c6 | ||
|   | b3e23373bd | ||
|   | e5adab39b1 | ||
|   | d31153584e | ||
|   | 823d296e12 | ||
|   | e09450103b | ||
|   | fbc4407583 | ||
|   | a79e5d7925 | ||
|   | 82491d5c06 | ||
|   | b6f889085d | ||
|   | cdbbb7d900 | ||
|   | 2bf4d9a22c | ||
|   | f1918aa343 | ||
|   | 56580fc6f8 | ||
|   | 2e6600425e | ||
|   | cc021fc200 | ||
|   | e6aed92742 | ||
|   | 02fb4d96d1 | ||
|   | 43e3c5e5fa | ||
|   | 4f496f2f70 | ||
|   | d681bc7520 | ||
|   | f21a2b3270 | ||
|   | 5f5a28d20e | ||
|   | 89f9cb4041 | ||
|   | 2b280bcc69 | ||
|   | 1c0224be42 | ||
|   | dbdb7fa55a | ||
|   | 83a43bea8a | ||
|   | abb4cdafe9 | ||
|   | 2b7bcf2505 | ||
|   | 5aefdd93cb | ||
|   | 4b27fae069 | ||
|   | 10a13eba72 | ||
|   | 44ac2776ae | ||
|   | 36e3e6ed16 | ||
|   | 5f9cbc4209 | ||
|   | 3239f059b8 | ||
|   | 45bac25d90 | ||
|   | 354c8dcd82 | ||
|   | b1e4cc370d | ||
|   | 2293474b90 | ||
|   | 9e1aef7183 | ||
|   | f68323da7d | ||
|   | a61aafa325 | ||
|   | 33bea767eb | ||
|   | 9ab7cda010 | ||
|   | 6da70628c6 | ||
|   | 3bae748256 | ||
|   | 521c4b303d | ||
|   | a2effd123a | ||
|   | 7b704e173c | ||
|   | 6045d051d7 | ||
|   | cfe00ed4ad | ||
|   | 0b4bdcf18f | ||
|   | 8cade952bf | ||
|   | 385e612fa5 | ||
|   | 1886388791 | ||
|   | 32fe5b14ec | ||
|   | bbdc483671 | ||
|   | f11d3c329c | ||
|   | b0d13fa4cb | ||
|   | 0fb5a65a58 | ||
|   | c8afb02b4c | ||
|   | 869d65337e | ||
|   | 277df1c6b1 | ||
|   | 5ec5b95f54 | ||
|   | 9e61c904ac | ||
|   | 7efb955fd0 | ||
|   | 75899741b9 | ||
|   | d465199411 | ||
|   | 55123424c8 | ||
|   | f5e4a78b59 | ||
|   | 7515a75206 | ||
|   | 4750e6f3c5 | ||
|   | b7aaa4d907 | ||
|   | e61e09f658 | ||
|   | 058e993acb | ||
|   | 359d500908 | ||
|   | cb42855445 | ||
|   | d8ff0336a5 | ||
|   | 0682d25da5 | ||
|   | d86d14074d | ||
|   | 8500397cf1 | ||
|   | bd600fbebe | ||
|   | 064bbb999f | ||
|   | bedc61ac45 | ||
|   | 61a6992559 | ||
|   | ebee2e323d | ||
|   | b2f8de571f | ||
|   | cb4a5f5a2b | ||
|   | 1beb7de7e0 | ||
|   | 89ab5f4380 | ||
|   | 439b84c782 | ||
|   | 0e899d7728 | ||
|   | 1a85fb2bd0 | ||
|   | 8d11767048 | ||
|   | fcccf9aa0d | ||
|   | 72bd027537 | ||
|   | 1d44c9ccc1 | ||
|   | 33831759b5 | ||
|   | 6fe932b255 | ||
|   | 8da02df8e0 | ||
|   | 587c99351d | ||
|   | 88c8d72a21 | ||
|   | cf99fed17a | ||
|   | ca48b6bf35 | ||
|   | 4dcd606b47 | ||
|   | 393ddd6e1f | ||
|   | 840e796aa9 | ||
|   | 5fd096da8d | ||
|   | eb29c5c285 | ||
|   | 1eb286e43e | ||
|   | ae76ebe2d1 | ||
|   | e4505aefd9 | ||
|   | d6b0612882 | ||
|   | 4c65eb0af8 | ||
|   | 318a8258fd | ||
|   | 17ae28e0fe | ||
|   | 3c4f622479 | ||
|   | 3ce43764be | ||
|   | b555c60e49 | ||
|   | 2336d010ef | ||
|   | b9af0d89d5 | ||
|   | 6f2afe0c30 | ||
|   | d8c61d459e | ||
|   | 7ae5ebbeb2 | ||
|   | 7335b71dfb | ||
|   | 9583b03074 | ||
|   | 3c81d5f125 | ||
|   | 688699a046 | ||
|   | 090f5a9a45 | ||
|   | da58d03ff7 | ||
|   | 9ea3831c08 | ||
|   | a46f55b9de | ||
|   | a634f64400 | ||
|   | bcd8a3b240 | ||
|   | 04d5d1895c | ||
|   | abd2775a70 | ||
|   | 73226415fc | ||
|   | ab160ef445 | ||
|   | 268fe09322 | ||
|   | 7a557e984a | ||
|   | f1a55cbe6d | ||
|   | 1e35d95df8 | ||
|   | d8387b418d | ||
|   | adea16a294 | ||
|   | 7f2d5cab2d | ||
|   | c6ff612f6e | ||
|   | 8db353e1d7 | ||
|   | e6978117a7 | ||
|   | 5dcb055077 | ||
|   | 0b5e1a9b2f | ||
|   | 2e17a97474 | ||
|   | 74ddbd8a3b | ||
|   | b8039a821b | ||
|   | 438312f00e | ||
|   | 381ccaa391 | ||
|   | 3204494883 | ||
|   | e264f699d4 | ||
|   | 68d4b77d44 | ||
|   | e1ac99af1f | ||
|   | be0d17e812 | ||
|   | 4eb35406f4 | ||
|   | 624745ab20 | ||
|   | 9354822e09 | ||
|   | 17d4f9513e | ||
|   | f830d77307 | ||
|   | a03c76b228 | ||
|   | 35ad61429d | ||
|   | b5b3d9e5c7 | ||
|   | 6e682c2b01 | ||
|   | 7e2ea2ece0 | ||
|   | 01926d66d7 | ||
|   | 69f7d0a0ce | ||
|   | d1c84705ec | ||
|   | 3274908551 | ||
|   | c730934498 | ||
|   | 471a8b223b | ||
|   | 47ee9202c3 | ||
|   | 1bcbe89802 | ||
|   | bf57e9bb12 | ||
|   | 318a7584f3 | ||
|   | 961ec228d4 | ||
|   | a777eb3d81 | ||
|   | 7f79b52dae | ||
|   | db680edc26 | ||
|   | e6ce80458f | ||
|   | cdcb123aa8 | ||
|   | 78081a1652 | ||
|   | 7408976b15 | ||
|   | 763bb73cc3 | ||
|   | 1dee2cd55e | ||
|   | 426ecfd136 | ||
|   | 4913baed16 | ||
|   | 675f6a8901 | ||
|   | 2147284cad | ||
|   | 7f1870da5f | ||
|   | 2149a095f7 | ||
|   | e8d21adbaa | ||
|   | fa28531322 | ||
|   | deef85ca9a | ||
|   | 4f4427ff41 | ||
|   | 0ed285e84d | ||
|   | 905ca77c9e | ||
|   | 61043c7e74 | ||
|   | 4545c9f22f | ||
|   | ad772d7b48 | ||
|   | a56ef92729 | ||
|   | 561d01c450 | ||
|   | c6c8a30da1 | ||
|   | 914dbeb12c | ||
|   | 56dc90eaab | ||
|   | f51c567de3 | ||
|   | 9b2acca63e | ||
|   | afcd9f1b1c | ||
|   | 755ccbc468 | ||
|   | 0af7aec211 | ||
|   | ee085ad6bd | 
| @@ -1,3 +1,4 @@ | ||||
| compile | ||||
| config.log | ||||
| Makefile | ||||
| libtool | ||||
|   | ||||
							
								
								
									
										835
									
								
								CHANGES.1999
									
									
									
									
									
								
							
							
						
						
									
										835
									
								
								CHANGES.1999
									
									
									
									
									
								
							| @@ -1,835 +0,0 @@ | ||||
| Daniel (28 December 1999): | ||||
|  - Tim Verhoeven correctly identified that curl | ||||
|    doesn't support URL formatted file names when getting ftp. Now, there's a | ||||
|    problem with getting very weird file names off FTP servers. RFC 959 defines | ||||
|    that the file name syntax to use should be the same as in the native OS of | ||||
|    the server. Since we don't know the peer server system we currently just | ||||
|    translate the URL syntax into plain letters. It is still better and with | ||||
|    the solaris 2.6-supplied ftp server it works with spaces in the file names. | ||||
|  | ||||
| Daniel (27 December 1999): | ||||
|  - When curl parsed cookies straight off a remote site, it corrupted the input | ||||
|    data, which, if the downloaded headers were stored made very odd characters | ||||
|    in the saved data. Correctly identified and reported by Paul Harrington. | ||||
|  | ||||
| Daniel (13 December 1999): | ||||
|  - General cleanups in the library interface. There had been some bad kludges | ||||
|    added during times of stress and I did my best to clean them off. It was | ||||
|    both regarding the lib API as well as include file confusions. | ||||
|  | ||||
| Daniel (3 December 1999): | ||||
|  - A small --stderr bug was reported by Eetu Ojanen... | ||||
|  | ||||
|  - who also brought the suggestion of extending the -X flag to ftp list as | ||||
|    well. So, now it is and the long option is now --request instead. It is | ||||
|    only for ftp list for now (and the former http stuff too of course). | ||||
|  | ||||
| Lars J. Aas (24 November 1999): | ||||
|  - Patched curl to compile and build under BeOS. Doesn't work yet though! | ||||
|  | ||||
|  - Corrected the Makefile.am files to allow putting object files in | ||||
|    different directories than the sources. | ||||
|  | ||||
| Version 6.3.1 | ||||
|  | ||||
| Daniel (23 November 1999): | ||||
|  - I've had this major disk crash. My good old trust-worthy source disk died | ||||
|    along with the machine that hosted it. Thank goodness most of all the | ||||
|    things I've done are either backed up elsewhere or stored in this CVS | ||||
|    server! | ||||
|  | ||||
|  - Michael S. Steuer pointed out a bug in the -F handling | ||||
|    that made curl hang if you posted an empty variable such as '-F name='. It | ||||
|    was one of those old bugs that never have worked properly... | ||||
|  | ||||
|  - Jason Baietto pointed out a general flaw in the HTTP | ||||
|    download. Curl didn't complain if it was prematurely aborted before the | ||||
|    entire download was completed. It does now. | ||||
|  | ||||
| Daniel (19 November 1999): | ||||
|  - Chris Maltby very accurately criticized the lack of | ||||
|    return code checks on the fwrite() calls. I did a thorough check for all | ||||
|    occurrences and corrected this. | ||||
|  | ||||
| Daniel (17 November 1999): | ||||
|  - Paul Harrington pointed out that the -m/--max-time option | ||||
|    doesn't work for the slow system calls like gethostbyname()... I don't have | ||||
|    any good fix yet, just a slightly less bad one that makes curl exit hard | ||||
|    when the timeout is reached. | ||||
|  | ||||
|  - Bjorn Reese helped me point out a possible problem that might be the reason | ||||
|    why Thomas Hurst experience problems in his Amiga version. | ||||
|  | ||||
|  Daniel (12 November 1999): | ||||
|  - I found a crash in the new cookie file parser. It crashed when you gave | ||||
|    a plain http header file as input... | ||||
|  | ||||
| Version 6.3 | ||||
|  | ||||
|  Daniel (10 November 1999): | ||||
|  - I kind of found out that the HTTP time-conditional GETs (-z) aren't always | ||||
|    respected by the web server and the document is therefore sent in whole | ||||
|    again, even though it doesn't match the requested condition. After reading | ||||
|    section 13.3.4 of RFC 2616, I think I'm doing the right thing now when I do | ||||
|    my own check as well. If curl thinks the condition isn't met, the transfer | ||||
|    is aborted prematurely (after all the headers have been received). | ||||
|  | ||||
|  - After comments from Robert Linden I also rewrote some parts of the man page | ||||
|    to better describe how the -F works. | ||||
|  | ||||
|  - Michael Anti put up a new curl download mirror in | ||||
|    China:  http://www.pshowing.com/curl/ | ||||
|  | ||||
|  - I added the list of download mirrors to the README file | ||||
|  | ||||
|  - I did add more explanations to the man page | ||||
|  | ||||
|  Daniel (8 November 1999): | ||||
|  - I made the -b/--cookie option capable of reading netscape formatted cookie | ||||
|    files as well as normal http-header files. It should be able to | ||||
|    transparently figure out what kind of file it got as input. | ||||
|  | ||||
|  Daniel (29 October 1999): | ||||
|  - Another one of Sebastiaan van Erk's ideas (that has been requested before | ||||
|    but I seem to have forgotten who it was), is to add support for ranges in | ||||
|    FTP downloads. As usual, one request is just a request, when they're two | ||||
|    it is a demand. I've added simple support for X-Y style fetches. X has to | ||||
|    be the lower number, though you may omit one of the numbers. Use the -r/ | ||||
|    --range switch (previously HTTP-only). | ||||
|  | ||||
|  - Sebastiaan van Erk suggested that curl should be | ||||
|    able to show the file size of a specified file. I think this is a splendid | ||||
|    idea and the -I flag is now working for FTP. It displays the file size in | ||||
|    this manner: | ||||
|         Content-Length: XXXX | ||||
|    As it resembles normal headers, and leaves us the opportunity to add more | ||||
|    info in that display if we can come up with more in the future! It also | ||||
|    makes sense since if you access ftp through a HTTP proxy, you'd get the | ||||
|    file size the same way. | ||||
|  | ||||
|    I changed the order of the QUOTE command executions. They're now executed | ||||
|    just after the login and before any other command. I made this to enable | ||||
|    quote commands to run before the -I stuff is done too. | ||||
|  | ||||
|  - I found out that -D/--dump-header and -V/--version weren't documented in | ||||
|    the man page. | ||||
|  | ||||
|  - Many HTTP/1.1 servers do not support ranges. Don't ask me why. I did add | ||||
|    some text about this in the man page for the range option. The thread in | ||||
|    the mailing list that started this was initiated by Michael Anti. | ||||
|  | ||||
|  - I get reports about nroff crashes on solaris 2.6+ when displaying the curl | ||||
|    man page. Switch to gnroff instead, it is reported to work(!). Adam Barclay | ||||
|    reported and brought the suggestion. | ||||
|  | ||||
|  - In a dialogue with Johannes G. Kristinsson we came | ||||
|    up with the idea to let -H/--header specified headers replace the | ||||
|    internally generated headers, if you happened to select to add a header | ||||
|    that curl normally uses by itself. The advantage with this is not entirely | ||||
|    obvious, but in Johannes' case it means that he can use another Host: than | ||||
|    the one curl would set. | ||||
|  | ||||
|  Daniel (27 October 1999): | ||||
|  - Jongki Suwandi brought a nice patch for (yet another) crash when following | ||||
|    a location:. This time you had to follow a https:// server's redirect to | ||||
|    get the core. | ||||
|  | ||||
| Version 6.2 | ||||
|  | ||||
|  Daniel (21 October 1999): | ||||
|  - I think I managed to remove the suspicious (nil) that has been seen just | ||||
|    before the "Host:" in HTTP requests when -v was used. | ||||
|  - I found out that if you followed a location: when using a proxy, without | ||||
|    having specified http:// in the URL, the protocol part was added once again | ||||
|    when moving to the next URL! (The protocol part has to be added to the | ||||
|    URL when going through a proxy since it has no protocol-guessing system | ||||
|    such as curl has.) | ||||
|  - Benjamin Ritcey reported a core dump under solaris 2.6 | ||||
|    with OpenSSL 0.9.4. It turned out this was due to a bad free() in main.c | ||||
|    that occurred after the download was done and completed. | ||||
|  - Benjamin found ftp downloads to show the first line of the download meter | ||||
|    to get written twice, and I removed that problem. It was introduced with | ||||
|    the multiple URL support. | ||||
|  - Dan Zitter correctly pointed out that curl 6.1 and earlier versions didn't | ||||
|    honor RFC 2616 chapter 4 section 2, "Message Headers": "...Field names are | ||||
|    case-insensitive..."  HTTP header parsing assumed a certain casing. Dan | ||||
|    also provided me with a patch that corrected this, which I took the liberty | ||||
|    of editing slightly. | ||||
|  - Dan Zitter also provided a nice patch for config.guess to better recognize | ||||
|    the Mac OS X | ||||
|  - Dan also corrected a minor problem in the lib/Makefile that caused linking | ||||
|    to fail on OS X. | ||||
|  | ||||
|  Daniel (19 October 1999): | ||||
|  - Len Marinaccio came up with some problems with curl.  Since Windows has a | ||||
|    crippled shell, it can't redirect stderr and that causes trouble. I added | ||||
|    --stderr today which allows the user to redirect the stderr stream to a | ||||
|    file or stdout. | ||||
|  | ||||
|  Daniel (18 October 1999): | ||||
|  - The configure script now understands the '--without-ssl' flag, which now | ||||
|    totally disable SSL/https support. Previously it wasn't possible to force | ||||
|    the configure script to leave SSL alone. The previous functionality has | ||||
|    been retained. Troy Engel helped test this new one. | ||||
|  | ||||
| Version 6.1 | ||||
|  | ||||
|  Daniel (17 October 1999): | ||||
|  - I ifdef'ed or commented all the zlib stuff in the sources and configure | ||||
|    script. It turned out we needed to mock more with zlib than I initially | ||||
|    thought, to make it capable of downloading compressed HTTP documents and | ||||
|    uncompress them on the fly. I didn't mean the zlib parts of curl to become | ||||
|    more than minor so this means I halt the zlib expedition for now and wait | ||||
|    until someone either writes the code or zlib gets updated and better | ||||
|    adjusted for this kind of usage.  I won't get into details here, but a | ||||
|    short a summary is suitable: | ||||
|    - zlib can't automatically detect whether to use zlib or gzip | ||||
|      decompression methods. | ||||
|    - zlib is very neat for reading gzipped files from a file descriptor, | ||||
|      although not as nice for reading buffer-based data such as we would | ||||
|      want it. | ||||
|    - there are still some problems with the win32 version when reading from | ||||
|      a file descriptor if that is a socket | ||||
|  | ||||
|  Daniel (14 October 1999): | ||||
|  - Moved the (external) include files for libcurl into a subdirectory named | ||||
|    curl and adjusted all #include lines to use <curl/XXXX> to maintain a | ||||
|    better name space and control of the headers. This has been requested. | ||||
|  | ||||
|  Daniel (12 October 1999): | ||||
|  - I modified the 'maketgz' script to perform a 'make' too before a release | ||||
|    archive is put together in an attempt to make the time stamps better and | ||||
|    hopefully avoid the double configure-running that use to occur. | ||||
|  | ||||
|  Daniel (11 October 1999): | ||||
|  - Applied J<>rn's patches that fixes zlib for mingw32 compiles as well as | ||||
|    some other missing zlib #ifdef and more text on the multiple URL docs in | ||||
|    the man page. | ||||
|  | ||||
| Version 6.1beta | ||||
|  | ||||
|  Daniel (6 October 1999): | ||||
|  - Douglas E. Wegscheid sent me a patch that made the exact same thing as I | ||||
|    just made: the -d switch is now capable of reading post data from a named | ||||
|    file or stdin.  Use it similarly to the -F. To read the post data from a | ||||
|    given file: | ||||
|  | ||||
|         curl -d @path/to/filename www.postsite.com | ||||
|  | ||||
|    or let curl read it out from stdin: | ||||
|  | ||||
|         curl -d @- www.postit.com | ||||
|  | ||||
|  J<>rn Hartroth (3 October 1999): | ||||
|  - Brought some more patches for multiple URL functionality. The MIME | ||||
|    separation ideas are almost scrapped now, and a custom separator is being | ||||
|    used instead. This is still compile-time "flagged". | ||||
|  | ||||
|  Daniel | ||||
|  - Updated curl.1 with multiple URL info. | ||||
|  | ||||
|  Daniel (30 September 1999): | ||||
|  - Felix von Leitner brought openssl-check fixes for configure.in to work | ||||
|    out-of-the-box when the openssl files are installed in the system default | ||||
|    dirs. | ||||
|  | ||||
|  Daniel (28 September 1999) | ||||
|  - Added libz functionality. This should enable decompressing gzip, compress | ||||
|    or deflate encoding HTTP documents. It also makes curl send an accept that | ||||
|    it accepts that kind of encoding. Compressed contents usually shortens | ||||
|    download time. I *need* someone to tell me a site that uses compressed HTTP | ||||
|    documents so that I can test this out properly. | ||||
|  | ||||
|  - As a result of the adding of zlib awareness, I changed the version string | ||||
|    a little. I plan to add openldap version reporting in there too. | ||||
|  | ||||
|  Daniel (17 September 1999) | ||||
|  - Made the -F option allow stdin when specifying files. By using '-' instead | ||||
|    of file name, the data will be read from stdin. | ||||
|  | ||||
| Version 6.0 | ||||
|  | ||||
|  Daniel (13 September 1999) | ||||
|  - Added -X/--http-request <request> to enable any HTTP command to be sent. | ||||
|    Do not that your server has to support the exact string you enter. This | ||||
|    should possibly a string like DELETE or TRACE. | ||||
|  | ||||
|  - Applied Douglas' mingw32-fixes for the makefiles. | ||||
|  | ||||
|  Daniel (10 September 1999) | ||||
|  - Douglas E. Wegscheid pointed out a problem. Curl didn't check the FTP | ||||
|    servers return code properly after the --quote commands were issued. It | ||||
|    took anything non 200 as an error, when all 2XX codes should be accepted as | ||||
|    OK. | ||||
|  | ||||
|  - Sending cookies to the same site in multiple lines like curl used to do | ||||
|    turned out to be bad and breaking the cookie specs. Curl now sends all | ||||
|    cookies on a single Cookie: line. Curl is not yet RFC 2109 compliant, but I | ||||
|    doubt that many servers do use that syntax (yet). | ||||
|  | ||||
|  Daniel (8 September 1999) | ||||
|  - J<>rn helped me make sure it still compiles nicely with mingw32 under win32. | ||||
|  | ||||
|  Daniel (7 September 1999) | ||||
|  - FTP upload through proxy is now turned into a HTTP PUT. Requested by | ||||
|    Stefan Kanthak. | ||||
|  | ||||
|  - Added the ldap files to the .m32 makefile. | ||||
|  | ||||
|  Daniel (3 September 1999) | ||||
|  - Made cookie matching work while using HTTP proxy. | ||||
|  | ||||
|  Bjorn Reese (31 August 1999) | ||||
|  - Passed his ldap:// patch. Note that this requires the openldap shared | ||||
|    library to be installed and that LD_LIBRARY_PATH points to the | ||||
|    directory where the lib will be found when curl is run with a | ||||
|    ldap:// URL. | ||||
|  | ||||
|  J<>rn Hartroth (31 August 1999) | ||||
|  - Made the Mingw32 makefiles into single files. | ||||
|  - Made file:// work for Win32. The same code is now used for unix as well for | ||||
|    performance reasons. | ||||
|  | ||||
|  Douglas E. Wegscheid (30 August 1999) | ||||
|  - Patched the Mingw32 makefiles for SSL builds. | ||||
|  | ||||
|  Matthew Clarke (30 August 1999) | ||||
|  - Made a cool patch for configure.in to allow --with-ssl to specify the | ||||
|    root dir of the openssl installation, as in | ||||
|  | ||||
|         ./configure --with-ssl=/usr/ssl_here | ||||
|  | ||||
|  - Corrected the 'reconf' script to work better with some shells. | ||||
|  | ||||
|  J<>rn Hartroth (26 August 1999) | ||||
|  - Fixed the Mingw32 makefiles in lib/ and corrected the file.c for win32 | ||||
|    compiles. | ||||
|  | ||||
| Version 5.11 | ||||
|  | ||||
|  Daniel (25 August 1999) | ||||
|  - John Weismiller pointed out a bug in the header-line | ||||
|    realloc() system in download.c. | ||||
|  | ||||
|  - I added lib/file.[ch] to offer a first, simple, file:// support. It | ||||
|    probably won't do much good on win32 system at this point, but I see it | ||||
|    as a start. | ||||
|  | ||||
|  - Made the release archives get a Makefile in the root dir, which can be | ||||
|    used to start the compiling/building process easier. I haven't really | ||||
|    changed any INSTALL text yet, I wanted to get some feed-back on this | ||||
|    first. | ||||
|  | ||||
|  Daniel (17 August 1999) | ||||
|  - Another Location: bug. Curl didn't do proper relative locations if the | ||||
|    original URL had cgi-parameters that contained a slash. Nusu's page | ||||
|    again. | ||||
|  | ||||
|  - Corrected the NO_PROXY usage. It is a list of substrings that if one of | ||||
|    them matches the tail of the host name it should connect to, curl should | ||||
|    not use a proxy to connect there. Pointed out to me by Douglas | ||||
|    E. Wegscheid.  I also changed the README text a little regarding this. | ||||
|  | ||||
|  Daniel (16 August 1999) | ||||
|  - Fixed a memory bug with http-servers that sent Location: to a Location: | ||||
|    page. Nusu's page showed this too. | ||||
|  | ||||
|  - Made cookies work a lot better. Setting the same cookie name several times | ||||
|    used to add more cookies instead of replacing the former one which it | ||||
|    should've. Nusu <nus at intergorj.ro> brought me an URL that made this | ||||
|    painfully visible... | ||||
|  | ||||
|  Troy (15 August 1999) | ||||
|  - Brought new .spec files as well as a patch for configure.in that lets the | ||||
|    configure script find the openssl files better, even when the include | ||||
|    files are in /usr/include/openssl | ||||
|  | ||||
| Version 5.10 | ||||
|  | ||||
|  Daniel (13 August 1999) | ||||
|  - SSL_CTX_set_default_passwd_cb() has been modified in the 0.9.4 version of | ||||
|    OpenSSL. Now why couldn't they simply add a *new* function instead of | ||||
|    modifying the parameters of an already existing function? This way, we get | ||||
|    a compiler warning if compiling with 0.9.4 but not with earlier. So, I had | ||||
|    to come up with a #if construction that deals with this... | ||||
|  | ||||
|  - Made curl output the SSL version number get displayed properly with 0.9.4. | ||||
|  | ||||
|  Troy (12 August 1999) | ||||
|  - Added MingW32 (GCC-2.95) support under Win32. The INSTALL file was also | ||||
|    a bit rearranged. | ||||
|   | ||||
|  Daniel (12 August 1999) | ||||
|  - I had to copy a good <arpa/telnet.h> include file into the curl source | ||||
|    tree to enable the silly win32 systems to compile. The distribution rights | ||||
|    allows us to do that as long as the file remains unmodified. | ||||
|  | ||||
|  - I corrected a few minor things that made the compiler complain when | ||||
|    -Wall -pedantic was used. | ||||
|  | ||||
|  - I'm moving the official curl web page to http://curl.haxx.nu. I think it | ||||
|    will make it easier to remember as it is a lot shorter and less cryptic. | ||||
|    The old one still works and shows the same info. | ||||
|  | ||||
|  Daniel (11 August 1999) | ||||
|  - Albert Chin-A-Young mailed me another correction for NROFF in the | ||||
|    configure.in that is supposed to be better for IRIX users. | ||||
|  | ||||
|  Daniel (10 August 1999) | ||||
|  - Albert Chin-A-Young helped me with some stupid Makefile things, as well as | ||||
|    some fiddling with the getdate.c stuff that he had problems with under | ||||
|    HP-UX v10. getdate.y will now be compiled into getdate.c if the appropriate | ||||
|    yacc or bison is found by the configure script. Since this is slightly new, | ||||
|    we need to test the output getdate.c with win32 systems to make sure it | ||||
|    still compiles there. | ||||
|  | ||||
|  Daniel (5 August 1999) | ||||
|  - I've just setup a new mailing list with the intention to keep discussions | ||||
|    around libcurl development in it. I mainly expect it to be for thoughts and | ||||
|    brainstorming around a "next generation" library, rather than nitpicking | ||||
|    about the current implementation or details in the current libcurl. | ||||
|  | ||||
|    To join our happy bunch of future-looking geeks, enter 'subscribe | ||||
|    <address>' in the body of a mail and send it to | ||||
|    libcurl-request@listserv.fts.frontec.se.  Curl bug reports, the usual curl | ||||
|    talk and everything else should still be kept in this mailing list. I've | ||||
|    started to archive this mailing list and have put the libcurl web page at | ||||
|    www.fts.frontec.se/~dast/libcurl/. | ||||
|  | ||||
|  - Stefan Kanthak contacted me regarding a few problems in the configure | ||||
|    script which he discovered when trying to make curl compile and build under | ||||
|    Siemens SINIX-Z V5.42B2004! | ||||
|  | ||||
|  - Marcus Klein very accurately informed me that src/version.h was not present | ||||
|    in the CVS repository. Oh, how silly... | ||||
|  | ||||
|  - Linus Nielsen rewrote the telnet:// part and now curl offers limited telnet | ||||
|    support. If you run curl like 'curl telnet://host' you'll get all output on | ||||
|    the screen and curl will read input from stdin. You'll be able to login and | ||||
|    run commands etc, but since the output is buffered, expect to get a little | ||||
|    weird output. | ||||
|  | ||||
|    This is still in its infancy and it might get changed. We need your | ||||
|    feed-back and input in how this is best done. | ||||
|  | ||||
|    WIN32 NOTE: I bet we'll get problems when trying to compile the current | ||||
|    lib/telnet.c on win32, but I think we can sort them out in time. | ||||
|  | ||||
|  - David Sanderson reported that FORCE_ALLOCA_H or HAVE_ALLOCA_H must be | ||||
|    defined for getdate.c to compile properly on HP-UX 11.0. I updated the | ||||
|    configure script to check for alloca.h which should make it. | ||||
|  | ||||
|  Daniel (4 August 1999) | ||||
|  - I finally got to understand Marcus Klein's ftp download resume problem, | ||||
|    which turns out to be due to different outputs from different ftp | ||||
|    servers. It makes ftp download resuming a little trickier, but I've made | ||||
|    some modifications I really believe will work for most ftp servers and I do | ||||
|    hope you report if you have problems with this! | ||||
|  | ||||
|  - Added text about file transfer resuming to README.curl. | ||||
|  | ||||
|  Daniel (2 August 1999) | ||||
|  - Applied a progress-bar patch from Lars J. Aas. It offers | ||||
|    a new styled progress bar enabled with -#/--progress-bar.  | ||||
|  | ||||
|  T. Yamada <tai at imasy.or.jp> (30 July 1999) | ||||
|  - It breaks with segfault when 1) curl is using .netrc to obtain | ||||
|    username/password (option '-n'), and 2) is automatically redirected to | ||||
|    another location (option '-L'). | ||||
|  | ||||
|    There is a small bug in lib/url.c (block starting from line 641), which | ||||
|    tries to take out username/password from user- supplied command-line | ||||
|    argument ('-u' option). This block is never executed on first attempt since | ||||
|    CONF_USERPWD bit isn't set at first, but curl later turns it on when it | ||||
|    checks for CONF_NETRC bit. So when curl tries to redo everything due to | ||||
|    redirection, it segfaults trying to access *data->userpwd. | ||||
|  | ||||
| Version 5.9.1 | ||||
|  | ||||
|  Daniel (30 July 1999) | ||||
|  - Steve Walch pointed out that there is a memory leak in the formdata | ||||
|    functions. I added a FormFree() function that is now used and supposed to | ||||
|    correct this flaw. | ||||
|  | ||||
|  - Mark Wotton reported: | ||||
|    'curl -L https://www.cwa.com.au/' core dumps.  I managed to cure this by | ||||
|    correcting the cleanup procedure. The bug seems to be gone with my OpenSSL | ||||
|    0.9.2b, although still occurs when I run the ~100 years old SSLeay 0.8.0. I | ||||
|    don't know whether it is curl or SSLeay that is to blame for that. | ||||
|  | ||||
|  - Marcus Klein: | ||||
|    Reported an FTP upload resume bug that I really can't repeat nor understand. | ||||
|    I leave it here so that it won't be forgotten. | ||||
|  | ||||
|  Daniel (29 July 1999) | ||||
|  - Costya Shulyupin suggested support for longer URLs when following Location: | ||||
|    and I could only agree and fix it! | ||||
|  | ||||
|  - Leigh Purdie found a problem in the upload/POST department. It turned out | ||||
|    that http.c accidentaly cleared the pointer instead of the byte counter | ||||
|    when supposed to. | ||||
|  | ||||
|  - Costya Shulyupin pointed out a problem with port numbers and Location:. If | ||||
|    you had a server at a non-standard port that redirected to an URL using a | ||||
|    standard port number, curl still used that first port number. | ||||
|  | ||||
|  - Ralph Beckmann pointed out a problem when using both CONF_FOLLOWLOCATION | ||||
|    and CONF_FAILONERROR simultaneously. Since the CONF_FAILONERROR exits on | ||||
|    the 302-code that the follow location header outputs it will never show any | ||||
|    html on location: pages. I have now made it look for >=400 codes if | ||||
|    CONF_FOLLOWLOCATION is set. | ||||
|  | ||||
|  - 'struct slist' is now renamed to 'struct curl_slist' (as suggested by Ralph | ||||
|    Beckmann). | ||||
|  | ||||
|  - Joshua Swink and Rick Welykochy were the first to point out to me that the | ||||
|    latest OpenSSL package now have moved the standard include path. It is now | ||||
|    in /usr/local/ssl/include/openssl and I have now modified the --enable-ssl | ||||
|    option for the configure script to use that as the primary path, and I | ||||
|    leave the former path too to work with older packages of OpenSSL too. | ||||
|  | ||||
|  Daniel (9 June 1999) | ||||
|  - I finally understood the IRIX problem and now it seem to compile on it! | ||||
|    I am gonna remove those #define strcasecmp() things once and for all now. | ||||
|  | ||||
|  Daniel (4 June 1999) | ||||
|  - I adjusted the FTP reply 227 parser to make the PASV command work better | ||||
|    with more ftp servers. Appearantly the Roxen Challanger server replied | ||||
|    something curl 5.9 could deal with! :-( Reported by Ashley Reid-Montanaro | ||||
|    and Mark Butler brought a solution for it. | ||||
|  | ||||
|  Daniel (26 May 1999) | ||||
|  - Rearranged. README is new, the old one is now README.curl and I added a | ||||
|    README.libcurl with text I got from Ralph Beckmann. | ||||
|  | ||||
|  - I also updated the INSTALL text. | ||||
|  | ||||
|  Daniel (25 May 1999) | ||||
|  - David Jonathan Lowsky correctly pointed out that curl didn't properly deal | ||||
|    with form posting where the variable shouldn't have any content, as in curl | ||||
|    -F "form=" www.site.com. It was now fixed. | ||||
|  | ||||
| Version 5.9 | ||||
|  | ||||
|  Daniel (22 May 1999) | ||||
|  - I've got a bug report from Aaron Scarisbrick in which he states he has some | ||||
|    problems with -L under FreeBSD 3.0. I have previously got another bug | ||||
|    report from Stefan Grether which points at an error with similar sympthoms | ||||
|    when using win32. I made the allocation of the new url string a bit faster | ||||
|    and different, don't know if it actually improves anything though... | ||||
|  | ||||
|  Daniel (20 May 1999) | ||||
|  - Made the cookie parser deal with CRLF newlines too. | ||||
|  | ||||
|  Daniel (19 May 1999) | ||||
|  - Download() didn't properly deal with failing return codes from the sread() | ||||
|    function. Adam Coyne found the problem in the win32 version, and Troy Engel | ||||
|    helped me out isolating it. | ||||
|  | ||||
|  Daniel (16 May 1999) | ||||
|  - Richard Adams pointed out a bug I introduced in 5.8. --dump-header doesn't | ||||
|    work anymore! :-/ I fixed it now. | ||||
|  | ||||
|  - After a suggestion by Joshua Swink I added -S / --show-error to force curl | ||||
|    to display the error message in case of an error, even if -s/--silent was | ||||
|    used. | ||||
|  | ||||
|  Daniel (10 May 1999) | ||||
|  - I moved the stuff concerning HTTP, DICT and TELNET it their own source | ||||
|    files now. It is a beginning on my clean-up of the sources to make them | ||||
|    layer all those protocols better to enable more to be added easier in the | ||||
|    future! | ||||
|  | ||||
|  - Leon Breedt sent me some files I've not put into the main curl | ||||
|    archive. They're for creating the Debian package thingie. He also sent me a | ||||
|    debian package that I've made available for download at the web page | ||||
|  | ||||
|  Daniel (9 May 1999) | ||||
|  - Made it compile on cygwin too. | ||||
|  | ||||
|  Troy Engel (7 May 1999) | ||||
|  - Brought a series of patches to allow curl to compile smoothly on MSVC++ 6 | ||||
|    again! | ||||
|  | ||||
|  Daniel (6 May 1999) | ||||
|  - I changed the #ifdef HAVE_STRFTIME placement for the -z code so that it | ||||
|    will be easier to discover systems that don't have that function and thus | ||||
|    can't use -z successfully. Made the strftime() get used if WIN32 is defined | ||||
|    too. | ||||
|  | ||||
| Version 5.8 | ||||
|  | ||||
|  Daniel (5 May 1999) | ||||
|  - I've had it with this autoconf/automake mess. It seems to work allright | ||||
|    for most people who don't have automake installed, but for those who have | ||||
|    there are problems all over. | ||||
|  | ||||
|    I've got like five different bug reports on this only the last | ||||
|    week... Claudio Neves and Federico Bianchi and root <duggerj001 at | ||||
|    hawaii.rr.com> are some of them reporting this. | ||||
|  | ||||
|    Currently, I have no really good fix since I want to use automake myself to | ||||
|    generate the Makefile.in files. I've found out that the @SHELL@-problems | ||||
|    can often be fixed by manually invoking 'automake' in the archive root | ||||
|    before you run ./configure... I've hacked my maketgz script now to fiddle | ||||
|    a bit with this and my tests seem to work better than before at least! | ||||
|  | ||||
|  Daniel (4 May 1999) | ||||
|  - mkhelp.pl has been doing badly lately. I corrected a case problem in | ||||
|    the regexes. | ||||
|  | ||||
|  - I've now remade the -o option to not touch the file unless it needs to. | ||||
|    I had to do this to make -z option really fine, since now you can make a | ||||
|    curl fetch and use a local copy's time when downloading to that file, as | ||||
|    in: | ||||
|  | ||||
|         curl -z dump -o dump remote.site.com/file.html | ||||
|  | ||||
|    This will only get the file if the remote one is newer than the local. | ||||
|    I'm aware that this alters previous behaviour a little. Some scripts out | ||||
|    there may depend on that the file is always touched... | ||||
|  | ||||
|  - Corrected a bug in the SSLv2/v3 selection. | ||||
|  | ||||
|  - Felix von Leitner requested that curl should be able to send | ||||
|    "If-Modified-Since" headers, which indeed is a fair idea.  I implemented it | ||||
|    right away! Try -z <expression> where expression is a full GNU date | ||||
|    expression or a file name to get the date from! | ||||
|  | ||||
|  Stephan Lagerholm (30 Apr 1999) | ||||
|  - Pointed out a problem with the src/Makefile for FreeBSD. The RM variable | ||||
|    isn't set and causes the make to fail. | ||||
|  | ||||
|  Daniel (26 April 1999) | ||||
|  - Am I silly or what? Irving Wolfe pointed out to me that the curl version | ||||
|    number was not set properly. Hasn't been since 5.6. This was due to a bug | ||||
|    in my maketgz script! | ||||
|  | ||||
|  David Eriksson (25 Apr 1999) | ||||
|  - Found a bug in cookies.c that made it crash at times. | ||||
|  | ||||
| Version 5.7.1 | ||||
|  | ||||
|  Doug Kaufman (23 Apr 1999) | ||||
|  - Brought two sunos 4 fixes. One of them being the hostip.c fix mentioned | ||||
|    below and the other one a correction in include/stdcheaders.h | ||||
|  | ||||
|  - Added a paragraph about compiling with the US-version of openssl to the | ||||
|    INSTALL file. | ||||
|  | ||||
|  Daniel | ||||
|  - New mailing list address. Info updated on the web page as well as in the | ||||
|    README file | ||||
|  | ||||
|  Greg Onufer (20 Apr 1999) | ||||
|  - hostip.c didn't compile properly on SunOS 5.5.1. | ||||
|    It needs an #include <sys/types.h> | ||||
|  | ||||
| Version 5.7 | ||||
|  | ||||
|  Daniel (Apr 20 1999) | ||||
|  - Decided to upload a non-beta version right now! | ||||
|  | ||||
|  - Made curl support any-length HTTP headers. The destination buffer is now | ||||
|    simply enlarged every time it turns out to be too small! | ||||
|  | ||||
|  - Added the FAQ file to the archive. Still a bit smallish, but it is a | ||||
|    start. | ||||
|  | ||||
|  Eric Thelin (15 Apr 1999) | ||||
|  - Made -D accept '-' instead of filename to write to stdout. | ||||
|  | ||||
| Version 5.6.3beta | ||||
|  | ||||
|  Daniel (Apr 12 1999) | ||||
|  | ||||
|  - Changed two #ifdef WIN32 to better #ifdef <errorcode> when connect()ing | ||||
|    in url.c and ftp.c. Makes cygwin32 deal with them better too. We should | ||||
|    try to get some decent win32-replacement there. Anyone? | ||||
|  | ||||
|  - The old -3/--crlf option is now ONLY --crlf! | ||||
|  | ||||
|  - I changed the "SSL fix" to a more lame one, but that doesn't remove as | ||||
|    much functionality. Now I've enabled the lib to select what SSL version it | ||||
|    should try first. Appearantly some older SSL-servers don't like when you | ||||
|    talk v3 with them so you need to be able to force curl to talk v2 from the | ||||
|    start. The fix dated April 6 and posted on the mailing list forced curl to | ||||
|    use v2 at all times using a modern OpenSSL version, but we don't really | ||||
|    want such a crippled solution. | ||||
|   | ||||
|  - Marc Boucher sent me a patch that corrected a math error for the | ||||
|    "Curr.Speed" progress meter. | ||||
|  | ||||
|  - Eric Thelin sent me a patch that enables '-K -' to read a config file from | ||||
|    stdin. | ||||
|  | ||||
|  - I found out we didn't close the file properly before so I added it! | ||||
|  | ||||
|  Daniel (Apr 9 1999) | ||||
|  - Yu Xin pointed out a problem with ftp download resume.  It didn't work at | ||||
|    all! ;-O | ||||
|  | ||||
|  Daniel (Apr 6 1999) | ||||
|  - Corrected the version string part generated for the SSL version. | ||||
|  | ||||
|  - I found a way to make some other SSL page work with openssl 0.9.1+ that | ||||
|    previously didn't (ssleay 0.8.0 works with it though!). Trying to get | ||||
|    some real info from the OpenSSL guys to see how I should do to behave the | ||||
|    best way. SSLeay 0.8.0 shouldn't be that much in use anyway these days! | ||||
|  | ||||
| Version 5.6.2beta | ||||
|  | ||||
|  Daniel (Apr 4 1999) | ||||
|  - Finally have curl more cookie "aware". Now read carefully. This is how | ||||
|    it works. | ||||
|    To make curl read cookies from an already existing file, in plain header- | ||||
|    format (like from the headers of a previous fetch) invoke curl with the | ||||
|    -b flag like: | ||||
|  | ||||
|         curl -b file http://site/foo.html | ||||
|  | ||||
|    Curl will then use all cookies it finds matching. The old style that sets | ||||
|    a single cookie with -b is still supported and is used if the string | ||||
|    following -b includes a '=' letter, as in "-b name=daniel". | ||||
|  | ||||
|    To make curl read the cookies sent in combination with a location: (which | ||||
|    sites often do) point curl to read a non-existing file at first (i.e | ||||
|    to start with no existing cookies), like: | ||||
|  | ||||
|         curl -b nowhere http://site/setcookieandrelocate.html | ||||
|  | ||||
|  - Added a paragraph in the TODO file about the SSL problems recently | ||||
|    reported. Evidently, some kind of SSL-problem curl may need to address. | ||||
|  | ||||
|  - Better "Location:" following. | ||||
|  | ||||
|  Douglas E. Wegscheid (Tue, 30 Mar 1999) | ||||
|  - A subsecond display patch. | ||||
|  | ||||
|  Daniel (Mar 14 1999) | ||||
|  - I've separated the version number of libcurl and curl now. To make | ||||
|    things a little easier, I decided to start the curl numbering from | ||||
|    5.6 and the former version number known as "curl" is now the one | ||||
|    set for libcurl. | ||||
|  | ||||
|  - Removed the 'enable-no-pass' from configure, I doubt anyone wanted | ||||
|    that. | ||||
|  | ||||
|  - Made lots of tiny adjustments to compile smoothly with cygwin under | ||||
|    win32. It's a killer for porting this to win32, bye bye VC++! ;-) | ||||
|    Compiles and builds out-of-the-box now. See the new wordings in | ||||
|    INSTALL for details. | ||||
|  | ||||
|  - Beginning experiments with downloading multiple document from a http | ||||
|    server while remaining connected. | ||||
|  | ||||
| Version 5.6beta | ||||
|  | ||||
|  Daniel (Mar 13 1999) | ||||
|  - Since I've changed so much, I thought I'd just go ahead and implement the | ||||
|    suggestion from Douglas E. Wegscheid. -D or --dump-header is now storing | ||||
|    HTTP headers separately in the specified file. | ||||
|  | ||||
|  - Added new text to INSTALL on what to do to build this on win32 now. | ||||
|  | ||||
|  - Aaargh. I had to take a step back and prefix the shared #include files | ||||
|    in the sources with "../include/" to please VC++... | ||||
|  | ||||
|  Daniel (Mar 12 1999) | ||||
|  - Split the url.c source into many tiny sources for better readability | ||||
|    and smaller size. | ||||
|  | ||||
|  Daniel (Mar 11 1999) | ||||
|  - Started to change stuff for a move to make libcurl and a more separate | ||||
|    curl application that uses the libcurl. Made the libcurl sources into | ||||
|    the new lib directory while the curl application will remain in src as | ||||
|    before. New makefiles, adjusted configure script and so. | ||||
|  | ||||
|    libcurl.a built quickly and easily. I better make a better interface to | ||||
|    the lib functions though. | ||||
|  | ||||
|    The new root dir include/ is supposed to contain the public information | ||||
|    about the new libcurl. It is a little ugly so far :-) | ||||
|  | ||||
|  | ||||
|  Daniel (Mar 1 1999) | ||||
|  - Todd Kaufmann sent me a good link to Netscape's cookie spec as well as the | ||||
|    info that RFC 2109 specifies how to use them.  The link is now in the | ||||
|    README and the RFC in the RESOURCES. | ||||
|  | ||||
|  Daniel (Feb 23 1999) | ||||
|  - Finally made configure accept --with-ssl to look for SSL libs and includes | ||||
|    in the "standard" place /usr/local/ssl... | ||||
|  | ||||
|  Daniel (Feb 22 1999) | ||||
|  - Verified that curl linked fine with OpenSSL 0.9.1c which seems to be | ||||
|    the most recent. | ||||
|  | ||||
|  Henri Gomez (Fri Feb  5 1999) | ||||
|  - Sent in an updated curl-ssl.spec. I still miss the script that builds an | ||||
|    RPM automatically... | ||||
|  | ||||
| Version 5.5.1 | ||||
|  | ||||
|  Mark Butler (27 Jan 1999) | ||||
|  - Corrected problems in Download(). | ||||
|  | ||||
|  Danitel Stenberg (25 Jan 1999) | ||||
|  - Jeremie Petit pointed out a few flaws in the source that prevented it from | ||||
|    compile warning free with the native compiler under Digital Unix v4.0d. | ||||
|  | ||||
| Version 5.5 | ||||
|  | ||||
|  Daniel Stenberg (15 Jan 1999) | ||||
|  - Added Bjorns small text to the README about the DICT protocol. | ||||
|  | ||||
|  Daniel Stenberg (11 Jan 1999) | ||||
|  - <jswink at softcom.net> reported about the win32-versioin: "Doesn't use | ||||
|    ALL_PROXY environment variable". Turned out to be because of the static- | ||||
|    buffer nature of the win32 environment variable calls! | ||||
|  | ||||
|  Bjorn Reese (10 Jan 1999) | ||||
|  - I have attached a simple addition for the DICT protocol (RFC 2229). | ||||
|    It performs dictionary lookups. The output still needs to be better | ||||
|    formatted. | ||||
|  | ||||
|    To test it try (the exact format, and more examples are described in | ||||
|    the RFC) | ||||
|  | ||||
|         dict://dict.org/m:hello | ||||
|         dict://dict.org/m:hello::soundex | ||||
|  | ||||
|  | ||||
|  Vicente Garcia (10 Jan 1999) | ||||
|  - Corrected the progress meter for files larger than 20MB. | ||||
|  | ||||
|  Daniel Stenberg (7 Jan 1999) | ||||
|  - Corrected the -t and -T help texts. They claimed to be FTP only. | ||||
|  | ||||
| Version 5.4 | ||||
|  | ||||
|  Daniel Stenberg | ||||
|  (7 Jan 1999) | ||||
|  - Irving Wolfe reported that curl -s didn't always supress the progress | ||||
|    reporting. It was the form post that autoamtically always switched it on | ||||
|    again. This is now corrected! | ||||
|  | ||||
|  (4 Jan 1999) | ||||
|  - Andreas Kostyrka suggested I'd add PUT and he helped me out to test it. If | ||||
|    you use -t or -T now on a http or https server, PUT will be used for file | ||||
|    upload. | ||||
|  | ||||
|    I removed the former use of -T with HTTP. I doubt anyone ever really used | ||||
|    that. | ||||
|  | ||||
|  (4 Jan 1999) | ||||
|  - Erik Jacobsen found a width bug in the mprintf() function.  I corrected it | ||||
|    now. | ||||
|  | ||||
|  (4 Jan 1999) | ||||
|  - As John V. Chow pointed out to me, curl accepted very limited URL sizes. It | ||||
|    should now accept path parts that are up to at least 4096 bytes. | ||||
|  | ||||
|  - Somehow I screwed up when applying the AIX fix from Gilbert Ramirez, so | ||||
|    I redid that now. | ||||
|  | ||||
							
								
								
									
										1381
									
								
								CHANGES.2000
									
									
									
									
									
								
							
							
						
						
									
										1381
									
								
								CHANGES.2000
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1957
									
								
								CHANGES.2001
									
									
									
									
									
								
							
							
						
						
									
										1957
									
								
								CHANGES.2001
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1504
									
								
								CHANGES.2002
									
									
									
									
									
								
							
							
						
						
									
										1504
									
								
								CHANGES.2002
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1572
									
								
								CHANGES.2003
									
									
									
									
									
								
							
							
						
						
									
										1572
									
								
								CHANGES.2003
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1994
									
								
								CHANGES.2004
									
									
									
									
									
								
							
							
						
						
									
										1994
									
								
								CHANGES.2004
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1183
									
								
								CHANGES.2005
									
									
									
									
									
								
							
							
						
						
									
										1183
									
								
								CHANGES.2005
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								COPYING
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| COPYRIGHT AND PERMISSION NOTICE | ||||
|  | ||||
| Copyright (c) 1996 - 2006, Daniel Stenberg, <daniel@haxx.se>. | ||||
| Copyright (c) 1996 - 2007, Daniel Stenberg, <daniel@haxx.se>. | ||||
|  | ||||
| All rights reserved. | ||||
|  | ||||
|   | ||||
							
								
								
									
										121
									
								
								Makefile.dist
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								Makefile.dist
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # | ||||
| # This software is licensed as described in the file COPYING, which | ||||
| # you should have received as part of this distribution. The terms | ||||
| @@ -21,6 +21,8 @@ | ||||
| # $Id$ | ||||
| ########################################################################### | ||||
|  | ||||
| VC=vc6 | ||||
|  | ||||
| all: | ||||
| 	./configure | ||||
| 	make | ||||
| @@ -73,112 +75,120 @@ mingw32-ssl: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 SSL=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 SSL=1 ZLIB=1 | ||||
|  | ||||
| mingw32-ssh2-ssl: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 SSH2=1 SSL=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 SSH2=1 SSL=1 ZLIB=1 | ||||
|  | ||||
| mingw32-ssh2-ssl-sspi: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 SSH2=1 SSL=1 SSPI=1 ZLIB=1 | ||||
|  | ||||
| mingw32-clean: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 clean | ||||
| 	$(MAKE) -C src -f Makefile.m32 clean | ||||
|  | ||||
| vc-clean: | ||||
| 	cd lib | ||||
| 	nmake -f Makefile.vc6 clean | ||||
| 	nmake -f Makefile.$(VC) clean | ||||
| 	cd ..\src | ||||
| 	nmake -f Makefile.vc6 clean | ||||
| 	nmake -f Makefile.$(VC) clean | ||||
|  | ||||
| vc-all: | ||||
| 	cd lib | ||||
| 	nmake -f Makefile.vc6 cfg=release | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl | ||||
| 	nmake -f Makefile.vc6 cfg=release-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl | ||||
| 	nmake -f Makefile.vc6 cfg=debug-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release | ||||
| 	nmake -f Makefile.$(VC) cfg=release-ssl | ||||
| 	nmake -f Makefile.$(VC) cfg=release-zlib | ||||
| 	nmake -f Makefile.$(VC) cfg=release-ssl-zlib | ||||
| 	nmake -f Makefile.$(VC) cfg=release-ssl-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release-dll-ssl-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release-dll-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-ssl | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-zlib | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-ssl-zlib | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-ssl-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-dll-ssl-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-dll-zlib-dll | ||||
| 	nmake -f Makefile.$(VC) cfg=debug-dll-ssl-dll-zlib-dll | ||||
|  | ||||
| vc: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release | ||||
| 	nmake /f Makefile.$(VC) cfg=release | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 | ||||
| 	nmake /f Makefile.$(VC) | ||||
|  | ||||
| vc-zlib: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-zlib | ||||
| 	nmake /f Makefile.$(VC) cfg=release-zlib | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-zlib | ||||
| 	nmake /f Makefile.$(VC) cfg=release-zlib | ||||
|  | ||||
| vc-ssl: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl | ||||
|  | ||||
| vc-ssl-zlib: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-zlib | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl-zlib | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-zlib | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl-zlib | ||||
|  | ||||
| vc-ssl-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl-dll | ||||
|  | ||||
| vc-dll-ssl-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll | ||||
|  | ||||
| vc-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll | ||||
|  | ||||
| vc-dll-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll-zlib-dll | ||||
|  | ||||
| vc-dll-ssl-dll-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll | ||||
|  | ||||
| vc-ssl-dll-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll | ||||
|  | ||||
| vc-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-zlib-dll | ||||
| 	nmake /f Makefile.$(VC) cfg=release-zlib-dll | ||||
|  | ||||
| vc-sspi: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release WINDOWS_SSPI=1 | ||||
| 	nmake /f Makefile.$(VC) cfg=release WINDOWS_SSPI=1 | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release WINDOWS_SSPI=1 | ||||
| 	nmake /f Makefile.$(VC) cfg=release WINDOWS_SSPI=1 | ||||
|  | ||||
| djgpp: | ||||
| 	$(MAKE) -C lib -f Makefile.dj | ||||
| @@ -212,6 +222,10 @@ 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 | ||||
| @@ -220,6 +234,10 @@ netware-clean: | ||||
| 	$(MAKE) -C lib -f Makefile.netware clean | ||||
| 	$(MAKE) -C src -f Makefile.netware clean | ||||
|  | ||||
| netware-install: | ||||
| 	$(MAKE) -C lib -f Makefile.netware install | ||||
| 	$(MAKE) -C src -f Makefile.netware install | ||||
|  | ||||
| unix: all | ||||
|  | ||||
| unix-ssl: ssl | ||||
| @@ -227,3 +245,8 @@ unix-ssl: ssl | ||||
| linux: all | ||||
|  | ||||
| linux-ssl: ssl | ||||
|  | ||||
| vc8: | ||||
| 	echo "generate VC8 makefiles" | ||||
| 	sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e 's#/GZ#/RTC1#' -e 's/wsock32.lib/wsock32.lib bufferoverflowu.lib/g' -e 's/VC6/VC8/g' lib/Makefile.vc6 > lib/Makefile.vc8 | ||||
| 	sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e 's#/GZ#/RTC1#' -e 's/wsock32.lib/wsock32.lib bufferoverflowu.lib/g' -e 's/VC6/VC8/g' src/Makefile.vc6 > src/Makefile.vc8 | ||||
|   | ||||
							
								
								
									
										132
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							
							
						
						
									
										132
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							| @@ -1,80 +1,94 @@ | ||||
| Curl and libcurl 7.16.0 | ||||
| Curl and libcurl 7.16.3 | ||||
|  | ||||
|  Public curl release number:               96 | ||||
|  Releases counted from the very beginning: 123 | ||||
|  Available command line options:           112 | ||||
|  Available curl_easy_setopt() options:     133 | ||||
|  Public curl release number:               99 | ||||
|  Releases counted from the very beginning: 126 | ||||
|  Available command line options:           118 | ||||
|  Available curl_easy_setopt() options:     141 | ||||
|  Number of public functions in libcurl:    54 | ||||
|  Amount of public web site mirrors:        37 | ||||
|  Amount of public web site mirrors:        38 | ||||
|  Number of known libcurl bindings:         35 | ||||
|  Number of contributors:                   515 | ||||
|  Number of contributors:                   554 | ||||
|  | ||||
| This release includes the following changes: | ||||
|   | ||||
|  o Added CURLE_SSL_CACERT_BADFILE | ||||
|  o Added CURLMOPT_TIMERFUNCTION and CURLMOPT_TIMERDATA | ||||
|  o (FTP) the CURLOPT_SOURCE_* options are removed and so are the --3p* command | ||||
|    line options | ||||
|  o curl_multi_socket() and family are suitable to start using | ||||
|  o uses WSAPoll() on Windows Vista | ||||
|  o (FTP) --ftp-ssl-control was added | ||||
|  o CURLOPT_SSL_SESSIONID_CACHE and --no-sessionid added | ||||
|  o CURLMOPT_PIPELINING added for enabling HTTP pipelined transfers | ||||
|  o multi handles now have a shared connection cache | ||||
|  o Added support for other MS-DOS compilers (besides djgpp) | ||||
|  o CURLOPT_SOCKOPTFUNCTION and CURLOPT_SOCKOPTDATA were added | ||||
|  o (FTP) libcurl avoids sending TYPE if the desired type was already set | ||||
|  o (FTP) CURLOPT_PREQUOTE works even when CURLOPT_NOBODY is set true | ||||
|  o added curl_multi_socket_action() | ||||
|  o deprecated curl_multi_socket() | ||||
|  o uses less memory in non-pipelined use cases | ||||
|  o CURLOPT_HTTP200ALIASES matched transfers assume HTTP 1.0 compliance | ||||
|  o more than one test harness can run at the same time without conflict | ||||
|  o SFTP now supports quote commands before a transfer | ||||
|  o CURLMOPT_MAXCONNECTS added to curl_multi_setopt() | ||||
|  o upload resume works for file:// URLs | ||||
|  o asynchronous name resolves now require c-ares 1.4.0 or later | ||||
|  o added SOCKS test cases | ||||
|  o CURLOPT_FTP_CREATE_MISSING_DIRS and --ftp-create-dirs now work for SFTP | ||||
|    operations as well | ||||
|  | ||||
| This release includes the following bugfixes: | ||||
|  | ||||
|  o (HTTP) CURLOPT_FAILONERROR (curl -f) covers a few more reponse cases | ||||
|  o curl_multi_socket() and the LOW_SPEED options | ||||
|  o curl_multi_socket() expire timer during c-ares name resolves | ||||
|  o curl_multi_add_handle on an already added handle now fails gracefully | ||||
|  o multi interface crash if bad function call order was used for cleanup | ||||
|  o put a new URL in saved cookie jar files | ||||
|  o configure --with-gssapi-libs | ||||
|  o SOCKS proxy connection fixes | ||||
|  o (FTP) a failed upload does not invalidate the control connection | ||||
|  o proxy URL with user name and empty password or no password at all now work | ||||
|  o fixed a socket state problem with *multi_socket() | ||||
|  o (HTTP) NTLM hostname fix | ||||
|  o getsockname usage fixes | ||||
|  o SOCKS5 proxy connects can now time-out | ||||
|  o SOCKS5 connects that require auth no longer segfaults when auth not given | ||||
|  o multi interface using asynch resolves could get stuck in wrong state | ||||
|  o the 'running_handles' counter wasn't always updated properly when | ||||
|    curl_multi_remove_handle() was used | ||||
|  o (FTP) EPRT transfers with IPv6 didn't work properly | ||||
|  o (FTP) SINGLECWD mode and using files in the root dir | ||||
|  o (HTTP) Expect: header disabling work better | ||||
|  o (HTTP) "Expect: 100-continue" disable on second POST on re-used connection | ||||
|  o src/config.h.in is fixed | ||||
|  o (HTTP) POST data logged to the debug callback function is now correctly | ||||
|    tagged as data, not header | ||||
|  o if2up too long interface name memory leak | ||||
|  o test case 534 started to fail 2007-04-13 due to the existance of a | ||||
|    new host on the net with the same silly domain the test was using | ||||
|    for a host which was supposed not to exist. | ||||
|  o test suite SSL certificate works better with newer stunnel | ||||
|  o internal progress meter update frequency back to once per second | ||||
|  o avoid some unnecessary calls to function gettimeofday | ||||
|  o a double-free in the SSL-layer | ||||
|  o GnuTLS free of NULL credentials | ||||
|  o NSS-fix for closing down SSL | ||||
|  o bad warning from configure when gnutls was selected | ||||
|  o compilation on VMS 64-bit mode | ||||
|  o SCP/SFTP downloads could hang on the last bytes of a transfer | ||||
|  o curl_easy_duphandle() crash | ||||
|  o curl -V / curl_version*() works even when GnuTLS is used on a system without | ||||
|    a good random source | ||||
|  o curl_multi_socket() not "noticing" newly added handles | ||||
|  o lack of Content-Length and chunked encoding now requires HTTP 1.1 as well | ||||
|    to be treated as without response body | ||||
|  o connection cache growth in multi handles | ||||
|  o better handling of out of memory conditions | ||||
|  o overwriting an uploaded file with sftp now truncates it first | ||||
|  o SFTP quote commands chmod, chown, chgrp can now set a value of 0 | ||||
|  o TFTP connect timouts less than 5 seconds | ||||
|  o improved curl -w for TFTP transfers | ||||
|  o memory leak when failed OpenSSL certificate CN field checking | ||||
|  o memory leak when OpenSSL failed PKCS #12 parsing | ||||
|  o FPL-SSL when built with NSS | ||||
|  o out-of-boundary write in Curl_select() | ||||
|  o -s/--silent can now be used to toggle off the silence again | ||||
|  o builds fine on 64bit HP-UX | ||||
|  o multi interface HTTP CONNECT glitch | ||||
|  o list FTP root directories when login dir is not root | ||||
|  o no longer slows down when getting very many URLs on the same command line | ||||
|  o lock share before decreasing dirty counter | ||||
|  o no-body FTP requests on re-used connections | ||||
|  | ||||
| This release includes the following known bugs: | ||||
|  | ||||
|  o see docs/KNOWN_BUGS (http://curl.haxx.se/docs/knownbugs.html) | ||||
|  | ||||
| Other curl-related news: | ||||
|  | ||||
|  o a Smalltalk binding: http://curl.haxx.se/libcurl/smalltalk/ | ||||
|  o pycurl-7.15.5 was released: http://pycurl.sf.net | ||||
|  o PycURL 7.16.2.1 was released: http://pycurl.sf.net/ | ||||
|  o TclCurl 7.16.2 was released: | ||||
|    http://personal1.iddeo.es/andresgarci/tclcurl/english/ | ||||
|  | ||||
| New curl mirrors: | ||||
|  | ||||
|  o http://curl.geosdreams.info/ is a new Polish mirror | ||||
|  o http://curl.gfiles.org/ is a new Russian mirror | ||||
|  o http://curl.online-mirror.de/ is a new German mirror | ||||
|  o http://curl.blogvoid.com/ is a new Canadian mirror | ||||
|  o http://curl.internet.bs/ is a new United Kingdom mirror | ||||
|  o http://curl2.haxx.se/ is a new Swedish mirror | ||||
|  o http://curl.spegulo.be is a new mirror in Belgium | ||||
|  o http://curl.piotrkosoft.net is a new mirror in Poland | ||||
|  o http://curl.smudge-it.net is a new mirror in St Louis, MO, USA | ||||
|  o http://curl.askapache.com is a new mirror in Indiana, USA | ||||
|  | ||||
| This release would not have looked like this without help, code, reports and | ||||
| advice from friends like these: | ||||
|  | ||||
|  Domenico Andreoli, Armel Asselin, Gisle Vanem, Yang Tse, Andrew Biggs, | ||||
|  Peter Sylvester, David McCreedy, Dmitriy Sergeyev, Dmitry Rechkin, | ||||
|  Jari Sundell, Ravi Pratap, Michele Bini, Jeff Pohlmeyer, Michael Wallner, | ||||
|  Mike Protts, Cory Nelson, Bernard Leak, Bogdan Nicula, Dan Fandrich, | ||||
|  Nir Soffer | ||||
|  Song Ma, Dan Fandrich, Yang Tse, Jay Austin, Robert Iakobashvil, | ||||
|  James Housley, Daniel Black, Steve Little, Sonia Subramanian, Peter O'Gorman, | ||||
|  Frank Hempel, Michael Wallner, Jeff Pohlmeyer, Tobias Rundstr<74>m, | ||||
|  Anders Gustafsson, James Bursa, Kristian Gunstone, Feng Tu, | ||||
|  Andre Guibert de Bruet, Rob Crittenden, Rich Rauenzahn, Tom Regner, | ||||
|  Dave Vasilevsky, Shmulik Regev, Robson Braga Araujo, Adam Piggott, | ||||
|  Gerrit Bruchh<68>user | ||||
|  | ||||
|         Thanks! (and sorry if I forgot to mention someone) | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| To get fixed in 7.16.0 (planned release: October 2006) | ||||
| ====================== | ||||
| To be addressed before 7.16.3 (planned release: June 2007) | ||||
| ============================= | ||||
|  | ||||
| 67 - Jeff Pohlmeyer's crashing pipelining test case | ||||
| 93 -  | ||||
|  | ||||
| 69 -  | ||||
|   | ||||
							
								
								
									
										155
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										155
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2007, 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 | ||||
| @@ -685,7 +685,7 @@ AC_DEFUN([CURL_CHECK_FUNC_RECV], [ | ||||
|   ]) | ||||
|   # | ||||
|   if test "$curl_cv_recv" = "yes"; then | ||||
|     AC_CACHE_CHECK([types of arguments and return type for recv], | ||||
|     AC_CACHE_CHECK([types of args and return type for recv], | ||||
|       [curl_cv_func_recv_args], [ | ||||
|       curl_cv_func_recv_args="unknown" | ||||
|       for recv_retv in 'int' 'ssize_t'; do | ||||
| @@ -815,7 +815,7 @@ AC_DEFUN([CURL_CHECK_FUNC_SEND], [ | ||||
|   ]) | ||||
|   # | ||||
|   if test "$curl_cv_send" = "yes"; then | ||||
|     AC_CACHE_CHECK([types of arguments and return type for send], | ||||
|     AC_CACHE_CHECK([types of args and return type for send], | ||||
|       [curl_cv_func_send_args], [ | ||||
|       curl_cv_func_send_args="unknown" | ||||
|       for send_retv in 'int' 'ssize_t'; do | ||||
| @@ -1035,6 +1035,48 @@ AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | ||||
| ]) # AC_DEFUN | ||||
|  | ||||
|  | ||||
| dnl TYPE_SIG_ATOMIC_T | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check if the sig_atomic_t type is available, and | ||||
| dnl verify if it is already defined as volatile. | ||||
|  | ||||
| AC_DEFUN([TYPE_SIG_ATOMIC_T], [ | ||||
|   AC_CHECK_HEADERS(signal.h) | ||||
|   AC_CHECK_TYPE([sig_atomic_t],[ | ||||
|     AC_DEFINE(HAVE_SIG_ATOMIC_T, 1, | ||||
|       [Define to 1 if sig_atomic_t is an available typedef.]) | ||||
|   ], ,[ | ||||
| #ifdef HAVE_SIGNAL_H | ||||
| #include <signal.h> | ||||
| #endif | ||||
|   ]) | ||||
|   case "$ac_cv_type_sig_atomic_t" in | ||||
|     yes) | ||||
|       # | ||||
|       AC_MSG_CHECKING([if sig_atomic_t is already defined as volatile]) | ||||
|       AC_TRY_LINK([ | ||||
| #ifdef HAVE_SIGNAL_H | ||||
| #include <signal.h> | ||||
| #endif | ||||
|         ],[ | ||||
|           static volatile sig_atomic_t dummy = 0; | ||||
|         ],[  | ||||
|           AC_MSG_RESULT([no]) | ||||
|           ac_cv_sig_atomic_t_volatile="no" | ||||
|         ],[ | ||||
|           AC_MSG_RESULT([yes]) | ||||
|           ac_cv_sig_atomic_t_volatile="yes" | ||||
|       ]) | ||||
|       # | ||||
|       if test "$ac_cv_sig_atomic_t_volatile" = "yes"; then | ||||
|         AC_DEFINE(HAVE_SIG_ATOMIC_T_VOLATILE, 1, | ||||
|           [Define to 1 if sig_atomic_t is already defined as volatile.]) | ||||
|       fi | ||||
|       ;; | ||||
|   esac | ||||
| ]) # AC_DEFUN | ||||
|  | ||||
|  | ||||
| dnl CURL_CHECK_NONBLOCKING_SOCKET | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check for how to set a socket to non-blocking state. There seems to exist | ||||
| @@ -1809,7 +1851,8 @@ AC_DEFUN([CURL_DLLIB_NAME], | ||||
| AC_MSG_CHECKING([name of dynamic library $2]) | ||||
| dnl The shared library extension variable name changes from version to | ||||
| dnl version of libtool.  Try a few names then just set one statically. | ||||
| test -z "$shared_ext" && shared_ext="$shrext_cmds" | ||||
| test -z "$shared_ext" && eval shared_ext=\"$shrext_cmds\" | ||||
| test -z "$shared_ext" && shared_ext="$std_shrext" | ||||
| test -z "$shared_ext" && shared_ext="$shrext" | ||||
| test -z "$shared_ext" && shared_ext=".so" | ||||
|  | ||||
| @@ -1817,12 +1860,16 @@ dnl Create the library link name of the correct form for this platform | ||||
| LIBNAME_LINK_SPEC=`echo "$library_names_spec" | $SED 's/^.* //'` | ||||
| DLGUESSLIB=`name=$2 eval echo "$libname_spec"` | ||||
| DLGUESSFILE=`libname="$DLGUESSLIB" release="" major="" versuffix="" eval echo "$LIBNAME_LINK_SPEC"` | ||||
| dnl Last resort in case libtool knows nothing about shared libs on this platform | ||||
| test -z "$DLGUESSFILE" && DLGUESSFILE="$DLGUESSLIB$shared_ext" | ||||
|  | ||||
| dnl Synthesize a likely dynamic library name in case we can't find an actual one | ||||
| SO_NAME_SPEC="$soname_spec" | ||||
| dnl soname_spec undefined when identical to the 1st entry in library_names_spec | ||||
| test -z "$SO_NAME_SPEC" && SO_NAME_SPEC=`echo "$library_names_spec" | $SED 's/ .*$//'` | ||||
| DLGUESSSOFILE=`libname="$DLGUESSLIB" release="" major="" versuffix="" eval echo "$SO_NAME_SPEC"` | ||||
| dnl Last resort in case libtool knows nothing about shared libs on this platform | ||||
| test -z "$DLGUESSSOFILE" && DLGUESSSOFILE="$DLGUESSFILE" | ||||
|  | ||||
| if test "$cross_compiling" = yes; then | ||||
|   dnl Can't look at filesystem when cross-compiling | ||||
| @@ -1907,3 +1954,103 @@ main() | ||||
|     dnl if this test fails, configure has already stopped | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
|  | ||||
| dnl CURL_CHECK_VARIADIC_MACROS | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check compiler support of variadic macros | ||||
|  | ||||
| AC_DEFUN([CURL_CHECK_VARIADIC_MACROS], [ | ||||
|   AC_CACHE_CHECK([for compiler support of C99 variadic macro style], | ||||
|     [curl_cv_variadic_macros_c99], [ | ||||
|     AC_COMPILE_IFELSE([ | ||||
|       AC_LANG_PROGRAM([ | ||||
| #define c99_vmacro3(first, ...) fun3(first, __VA_ARGS__) | ||||
| #define c99_vmacro2(first, ...) fun2(first, __VA_ARGS__) | ||||
|         int fun3(int arg1, int arg2, int arg3); | ||||
|         int fun2(int arg1, int arg2); | ||||
|         int fun3(int arg1, int arg2, int arg3) | ||||
|         { return arg1 + arg2 + arg3; } | ||||
|         int fun2(int arg1, int arg2) | ||||
|         { return arg1 + arg2; } | ||||
|       ],[ | ||||
|         int res3 = c99_vmacro3(1, 2, 3); | ||||
|         int res2 = c99_vmacro2(1, 2); | ||||
|       ]) | ||||
|     ],[ | ||||
|       curl_cv_variadic_macros_c99="yes" | ||||
|     ],[ | ||||
|       curl_cv_variadic_macros_c99="no" | ||||
|     ]) | ||||
|   ]) | ||||
|   case "$curl_cv_variadic_macros_c99" in | ||||
|     yes) | ||||
|       AC_DEFINE_UNQUOTED(HAVE_VARIADIC_MACROS_C99, 1, | ||||
|         [Define to 1 if compiler supports C99 variadic macro style.]) | ||||
|       ;; | ||||
|   esac | ||||
|   AC_CACHE_CHECK([for compiler support of old gcc variadic macro style], | ||||
|     [curl_cv_variadic_macros_gcc], [ | ||||
|     AC_COMPILE_IFELSE([ | ||||
|       AC_LANG_PROGRAM([ | ||||
| #define gcc_vmacro3(first, args...) fun3(first, args) | ||||
| #define gcc_vmacro2(first, args...) fun2(first, args) | ||||
|         int fun3(int arg1, int arg2, int arg3); | ||||
|         int fun2(int arg1, int arg2); | ||||
|         int fun3(int arg1, int arg2, int arg3) | ||||
|         { return arg1 + arg2 + arg3; } | ||||
|         int fun2(int arg1, int arg2) | ||||
|         { return arg1 + arg2; } | ||||
|       ],[ | ||||
|         int res3 = gcc_vmacro3(1, 2, 3); | ||||
|         int res2 = gcc_vmacro2(1, 2); | ||||
|       ]) | ||||
|     ],[ | ||||
|       curl_cv_variadic_macros_gcc="yes" | ||||
|     ],[ | ||||
|       curl_cv_variadic_macros_gcc="no" | ||||
|     ]) | ||||
|   ]) | ||||
|   case "$curl_cv_variadic_macros_gcc" in | ||||
|     yes) | ||||
|       AC_DEFINE_UNQUOTED(HAVE_VARIADIC_MACROS_GCC, 1, | ||||
|         [Define to 1 if compiler supports old gcc variadic macro style.]) | ||||
|       ;; | ||||
|   esac | ||||
| ]) | ||||
|  | ||||
|  | ||||
| dnl CURL_CHECK_NATIVE_WINDOWS | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check if building a native Windows target | ||||
|  | ||||
| AC_DEFUN([CURL_CHECK_NATIVE_WINDOWS], [ | ||||
|   AC_REQUIRE([CURL_CHECK_HEADER_WINDOWS])dnl | ||||
|   AC_CACHE_CHECK([whether build target is a native Windows one], [ac_cv_native_windows], [ | ||||
|     if test "$ac_cv_header_windows_h" = "no"; then | ||||
|       ac_cv_native_windows="no" | ||||
|     else | ||||
|       AC_COMPILE_IFELSE([ | ||||
|         AC_LANG_PROGRAM([ | ||||
|         ],[ | ||||
| #ifdef __MINGW32__ | ||||
|           int dummy=1; | ||||
| #else | ||||
|           Not a native Windows build target. | ||||
| #endif | ||||
|         ]) | ||||
|       ],[ | ||||
|         ac_cv_native_windows="yes" | ||||
|       ],[ | ||||
|         ac_cv_native_windows="no" | ||||
|       ]) | ||||
|     fi | ||||
|   ]) | ||||
|   case "$ac_cv_native_windows" in | ||||
|     yes) | ||||
|       AC_DEFINE_UNQUOTED(NATIVE_WINDOWS, 1, | ||||
|         [Define to 1 if you are building a native Windows target.]) | ||||
|       ;; | ||||
|   esac | ||||
| ]) | ||||
|  | ||||
|   | ||||
							
								
								
									
										12
									
								
								ares/AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								ares/AUTHORS
									
									
									
									
									
								
							| @@ -14,3 +14,15 @@ Henrik Stoerner | ||||
| Yang Tse | ||||
| Nick Mathewson | ||||
| Alexander Lazic | ||||
| Andreas Rieke | ||||
| Guilherme Balena Versiani | ||||
| Brad Spencer | ||||
| Ravi Pratap | ||||
| William Ahern | ||||
| Bram Matthys | ||||
| Michael Wallner | ||||
| Vlad Dinulescu | ||||
| Brad House | ||||
| Shmulik Regev | ||||
| Ashish Sharma | ||||
| Brad Spencer | ||||
|   | ||||
							
								
								
									
										119
									
								
								ares/CHANGES
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								ares/CHANGES
									
									
									
									
									
								
							| @@ -1,5 +1,124 @@ | ||||
|   Changelog for the c-ares project | ||||
|  | ||||
| Version 1.4.0 (June 8, 2007) | ||||
|  | ||||
| * June 4 2007 (Daniel Stenberg) | ||||
|  | ||||
| - James Bursa reported a major memory problem when resolving multi-IP names | ||||
|   and I found and fixed the problem. It was added by Ashish Sharma's patch | ||||
|   two days ago. | ||||
|  | ||||
|   When I then tried to verify multiple entries in /etc/hosts after my fix, I | ||||
|   got another segfault and decided this code was not ripe for inclusion and I | ||||
|   reverted the patch. | ||||
|  | ||||
| * June 2 2007 | ||||
|  | ||||
| - Brad Spencer found and fixed three flaws in the code, found with the new | ||||
|   gcc 4.2.0 warning: -Waddress | ||||
|  | ||||
| - Brad House fixed VS2005 compiler warnings due to time_t being 64bit. | ||||
|   He also made recent Microsoft compilers use _strdup() instead of strdup(). | ||||
|  | ||||
| - Brad House's man pages for ares_save_options() and ares_destroy_options() | ||||
|   were added. | ||||
|  | ||||
| - Ashish Sharma provided a patch for supporting multiple entries in the | ||||
|   /etc/hosts file. Patch edited for coding style and functionality by me | ||||
|   (Daniel). | ||||
|  | ||||
| * May 30 2007 | ||||
|  | ||||
| - Shmulik Regev brought cryptographically secure transaction IDs: | ||||
|  | ||||
|   The c-ares library implementation uses a DNS "Transaction ID" field that is | ||||
|   seeded with a pseudo random number (based on gettimeofday) which is | ||||
|   incremented (++) between consecutive calls and is therefore rather | ||||
|   predictable. In general, predictability of DNS Transaction ID is a well | ||||
|   known security problem (e.g. | ||||
|   http://bak.spc.org/dms/archive/dns_id_attack.txt) and makes a c-ares based | ||||
|   implementation vulnerable to DNS poisoning. Credit goes to Amit Klein | ||||
|   (Trusteer) for identifying this problem. | ||||
|  | ||||
|   The patch I wrote changes the implementation to use a more secure way of | ||||
|   generating unique IDs. It starts by obtaining a key with reasonable entropy | ||||
|   which is used with an RC4 stream to generate the cryptographically secure | ||||
|   transaction IDs. | ||||
|  | ||||
|   Note that the key generation code (in ares_init:randomize_key) has two | ||||
|   versions, the Windows specific one uses a cryptographically safe function | ||||
|   provided (but undocumented :) by the operating system (described at | ||||
|   http://blogs.msdn.com/michael_howard/archive/2005/01/14/353379.aspx).  The | ||||
|   default implementation is a bit naive and uses the standard 'rand' | ||||
|   function. Surely a better way to generate random keys exists for other | ||||
|   platforms. | ||||
|  | ||||
|   The patch can be tested by using the adig utility and using the '-s' option. | ||||
|  | ||||
| - Brad House added ares_save_options() and ares_destroy_options() that can be | ||||
|   used to keep options for later re-usal when ares_init_options() is used. | ||||
|    | ||||
|   Problem: Calling ares_init() for each lookup can be unnecessarily resource | ||||
|          intensive.  On windows, it must LoadLibrary() or search the registry | ||||
|          on each call to ares_init().  On unix, it must read and parse | ||||
|          multiple files to obtain the necessary configuration information.  In | ||||
|          a single-threaded environment, it would make sense to only | ||||
|          ares_init() once, but in a heavily multi-threaded environment, it is | ||||
|          undesirable to ares_init() and ares_destroy() for each thread created | ||||
|          and track that. | ||||
|  | ||||
|   Solution: Create ares_save_options() and ares_destroy_options() functions to | ||||
|          retrieve and free options obtained from an initialized channel.  The | ||||
|          options populated can be used to pass back into ares_init_options(), | ||||
|          it should populate all needed fields and not retrieve any information | ||||
|          from the system.  Probably wise to destroy the cache every minute or | ||||
|          so to prevent the data from becoming stale. | ||||
|  | ||||
| - Daniel S added ares_process_fd() to allow applications to ask for processing | ||||
|   on specific sockets and thus avoiding select() and associated | ||||
|   functions/macros.  This function will be used by upcoming libcurl releases | ||||
|   for this very reason. It also made me export the ares_socket_t type in the | ||||
|   public ares.h header file, since ares_process_fd() uses that type for two of | ||||
|   the arguments. | ||||
|  | ||||
| * May 25 2007 | ||||
|  | ||||
| - Ravi Pratap fixed a flaw in the init_by_resolv_conf() function for windows | ||||
|   that could cause it to return a bad return code. | ||||
|  | ||||
| * April 16 2007 | ||||
|  | ||||
| - Yang Tse: Provide ares_getopt() command-line parser function as a source | ||||
|   code helper function, not belonging to the actual c-ares library. | ||||
|  | ||||
| * February 19 2007 | ||||
|  | ||||
| - Vlad Dinulescu added ares_parse_ns_reply(). | ||||
|  | ||||
| * February 13 2007 | ||||
|  | ||||
| - Yang Tse: Fix failure to get the search sequence of /etc/hosts and | ||||
|   DNS from /etc/nsswitch.conf, /etc/host.conf or /etc/svc.conf when | ||||
|   /etc/resolv.conf did not exist or was unable to read it. | ||||
|  | ||||
| * November 22 2006 | ||||
|  | ||||
| - Install ares_dns.h too | ||||
|  | ||||
| - Michael Wallner fixed this problem: When I set domains in the options | ||||
|   struct, and there are domain/search entries in /etc/resolv.conf, the domains | ||||
|   of the options struct will be overridden. | ||||
|  | ||||
| * November 6 2006 | ||||
|  | ||||
| - Yang Tse removed a couple of potential zero size memory allocations. | ||||
|  | ||||
| - Andreas Rieke fixed the line endings in the areslib.dsp file that I (Daniel) | ||||
|   broke in the 1.3.2 release. We should switch to a system where that file is | ||||
|   auto-generated. We could rip some code for that from curl... | ||||
|  | ||||
| Version 1.3.2 (November 3, 2006) | ||||
|  | ||||
| * October 12 2006 | ||||
|  | ||||
| - Prevent ares_getsock() to overflow if more than 16 sockets are used. | ||||
|   | ||||
| @@ -11,7 +11,7 @@ MSVCFILES = vc/adig/adig.dep vc/adig/adig.dsp vc/vc.dsw vc/ahost/ahost.dep \ | ||||
| # adig and ahost are just sample programs and thus not mentioned with the | ||||
| # regular sources and headers | ||||
| EXTRA_DIST = CHANGES README.cares Makefile.inc adig.c ahost.c $(man_MANS) \ | ||||
|  $(MSVCFILES) AUTHORS config-win32.h | ||||
|  $(MSVCFILES) AUTHORS config-win32.h RELEASE-NOTES | ||||
|  | ||||
|  | ||||
| VER=-version-info 1:0:0 | ||||
| @@ -59,7 +59,7 @@ libcares_la_SOURCES = $(CSOURCES) $(HHEADERS) | ||||
| # where to install the c-ares headers | ||||
| libcares_ladir = $(includedir) | ||||
| # what headers to install on 'make install': | ||||
| libcares_la_HEADERS = ares.h ares_version.h | ||||
| libcares_la_HEADERS = ares.h ares_version.h ares_dns.h | ||||
|  | ||||
| # Make files named *.dist replace the file without .dist extension | ||||
| dist-hook: | ||||
|   | ||||
| @@ -2,41 +2,62 @@ | ||||
| # c-ares Makefile for djgpp/gcc/Watt-32. | ||||
| #   By Gisle Vanem <giva@bgnett.no> 2004. | ||||
| # | ||||
| .SUFFIXES: .exe | ||||
| # $Id$ | ||||
|  | ||||
| TOPDIR = .. | ||||
|  | ||||
| include ../packages/DOS/common.dj | ||||
|  | ||||
| include Makefile.inc | ||||
|  | ||||
| WATT32_ROOT = $(subst \,/,$(WATT_ROOT)) | ||||
|  | ||||
| CC      = gcc | ||||
| CFLAGS  = -O2 -Wall -DWATT32 -Dselect=select_s -DHAVE_AF_INET6 \ | ||||
|           -DHAVE_PF_INET6 -DHAVE_IOCTLSOCKET -DHAVE_STRUCT_IN6_ADDR \ | ||||
|           -DHAVE_STRUCT_SOCKADDR_IN6 -DHAVE_STRUCT_ADDRINFO \ | ||||
|           -DHAVE_ARPA_NAMESER_H -DNS_INADDRSZ=4 \ | ||||
|           -DHAVE_SYS_TIME_H -DHAVE_TIME_H \ | ||||
|           -DTIME_WITH_SYS_TIME -DHAVE_STRUCT_TIMEVAL \ | ||||
|           -DHAVE_SOCKADDR_IN6_SIN6_SCOPE_ID -I$(WATT32_ROOT)/inc | ||||
| CFLAGS += -DWATT32 -DHAVE_AF_INET6 -DHAVE_PF_INET6 -DHAVE_FIONBIO \ | ||||
|           -DHAVE_STRUCT_IN6_ADDR -DHAVE_SOCKADDR_IN6_SIN6_SCOPE_ID \ | ||||
|           -DHAVE_SYS_TIME_H -DHAVE_STRUCT_SOCKADDR_IN6 -DHAVE_STRUCT_ADDRINFO \ | ||||
|           -DHAVE_SIGNAL_H -DHAVE_SIG_ATOMIC_T -DRETSIGTYPE='void' -DHAVE_PROCESS_H \ | ||||
|           -DHAVE_ARPA_NAMESER_H -DNS_INADDRSZ=4 -DHAVE_RECV -DHAVE_SEND \ | ||||
|           -DSEND_TYPE_ARG1='int'   -DSEND_QUAL_ARG2='const' \ | ||||
|           -DSEND_TYPE_ARG2='void*' -DSEND_TYPE_ARG3='int' \ | ||||
|           -DSEND_TYPE_ARG4='int'   -DSEND_TYPE_RETV='int' \ | ||||
|           -DRECV_TYPE_ARG1='int'   -DRECV_TYPE_ARG2='void*' \ | ||||
|           -DRECV_TYPE_ARG3='int'   -DRECV_TYPE_ARG4='int' \ | ||||
|           -DRECV_TYPE_RETV='int'   -DHAVE_STRUCT_TIMEVAL \ | ||||
|           -Dselect=select_s        -UHAVE_CONFIG_H | ||||
|  | ||||
| LDFLAGS = -s | ||||
| EX_LIBS = $(WATT32_ROOT)/lib/libwatt.a | ||||
|  | ||||
| OBJ_DIR = djgpp | ||||
| ifeq ($(USE_DEBUG),1) | ||||
|   EX_LIBS  = ../lib/libcurl.a | ||||
|   OBJ_HACK = $(OBJECTS) | ||||
| else | ||||
|   OBJ_HACK = libcares.a | ||||
| endif | ||||
|  | ||||
| ifeq ($(USE_SSL),1) | ||||
|   EX_LIBS += $(OPENSSL_ROOT)/lib/libssl.a $(OPENSSL_ROOT)/lib/libcrypt.a | ||||
| endif | ||||
|  | ||||
| ifeq ($(USE_ZLIB),1) | ||||
|   EX_LIBS += $(ZLIB_ROOT)/libz.a | ||||
| endif | ||||
|  | ||||
| ifeq ($(USE_IDNA),1) | ||||
|   EX_LIBS += $(LIBIDN_ROOT)/lib/dj_obj/libidn.a -liconv | ||||
| endif | ||||
|  | ||||
| EX_LIBS += $(WATT32_ROOT)/lib/libwatt.a | ||||
|  | ||||
| OBJECTS = $(addprefix $(OBJ_DIR)/, $(CSOURCES:.c=.o)) | ||||
|  | ||||
| all: $(OBJ_DIR) libcares.a ahost.exe adig.exe | ||||
| 	@echo Welcome to c-ares. | ||||
|  | ||||
| $(OBJ_DIR): | ||||
| 	- mkdir $(OBJ_DIR) | ||||
|  | ||||
| libcares.a: $(OBJECTS) | ||||
| 	ar rs $@ $? | ||||
|  | ||||
| ahost.exe: ahost.c libcares.a | ||||
| ahost.exe: ahost.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | ||||
| 	$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS) | ||||
|  | ||||
| adig.exe: adig.c libcares.a | ||||
| adig.exe: adig.c $(OBJ_DIR)/ares_getopt.o $(OBJ_HACK) | ||||
| 	$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS) | ||||
|  | ||||
| clean: | ||||
| @@ -46,12 +67,5 @@ vclean realclean: clean | ||||
| 	rm -f ahost.exe adig.exe depend.dj | ||||
| 	- rmdir $(OBJ_DIR) | ||||
|  | ||||
| $(OBJ_DIR)/%.o: %.c | ||||
| 	$(CC) $(CFLAGS) -o $@ -c $< | ||||
| 	@echo | ||||
|  | ||||
| depend: | ||||
| 	$(CC) -MM $(CFLAGS) $(CSOURCES) | \ | ||||
| 	sed -e 's/^\([a-zA-Z0-9_-]*\.o:\)/$$(OBJ_DIR)\/\1/' > depend.dj | ||||
|  | ||||
| -include depend.dj | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,8 @@ ares_gethostbyname.c ares_strerror.c ares_cancel.c ares_init.c		\ | ||||
| ares_timeout.c ares_destroy.c ares_mkquery.c ares_version.c		\ | ||||
| ares_expand_name.c ares_parse_a_reply.c windows_port.c			\ | ||||
| ares_expand_string.c ares_parse_ptr_reply.c ares_parse_aaaa_reply.c	\ | ||||
| ares_getnameinfo.c inet_net_pton.c bitncmp.c inet_ntop.c | ||||
| ares_getnameinfo.c inet_net_pton.c bitncmp.c inet_ntop.c		\ | ||||
| ares_parse_ns_reply.c | ||||
|  | ||||
| HHEADERS = ares.h ares_private.h setup.h ares_dns.h ares_version.h          \ | ||||
|            nameser.h inet_net_pton.h inet_ntop.h ares_ipv6.h bitncmp.h      \ | ||||
| @@ -17,5 +18,5 @@ MANPAGES= ares_destroy.3 ares_expand_name.3 ares_expand_string.3 ares_fds.3 \ | ||||
|  ares_parse_a_reply.3 ares_parse_ptr_reply.3 ares_process.3		    \ | ||||
|  ares_query.3 ares_search.3 ares_send.3 ares_strerror.3 ares_timeout.3	    \ | ||||
|  ares_version.3 ares_cancel.3 ares_parse_aaaa_reply.3 ares_getnameinfo.3    \ | ||||
|  ares_getsock.3 | ||||
|  | ||||
|  ares_getsock.3 ares_parse_ns_reply.3 \ | ||||
|  ares_destroy_options.3 ares_save_options.3 | ||||
|   | ||||
| @@ -5,27 +5,30 @@ | ||||
| ## Use: make -f Makefile.m32 [demos] | ||||
| ## | ||||
| ## Quick hack by Guenter; comments to: /dev/nul | ||||
|  | ||||
| CC = gcc | ||||
| RANLIB = ranlib | ||||
|  | ||||
| # | ||||
| ######################################################## | ||||
| ## Nothing more to do below this line! | ||||
|  | ||||
| LIB=libcares.a | ||||
| CC=gcc | ||||
| CFLAGS=-O2 -Wall | ||||
| LDFLAGS=-s | ||||
| LIBS=-lwsock32 | ||||
| LIB	= libcares.a | ||||
|  | ||||
| MANPAGES := $(patsubst %.c,%.o,$(wildcard ares_*.3)) | ||||
| CC	= gcc | ||||
| LD	= gcc | ||||
| RANLIB	= ranlib | ||||
| #RM	= rm -f | ||||
|  | ||||
| OBJS	:= $(patsubst %.c,%.o,$(wildcard ares_*.c)) | ||||
| OBJS	+= windows_port.o inet_ntop.o inet_net_pton.o bitncmp.o | ||||
| CFLAGS	= -O2 -Wall | ||||
| LDFLAGS	= -s | ||||
| LIBS	= -lwsock32 | ||||
|  | ||||
| $(LIB): ${OBJS} | ||||
| 	ar cru $@ ${OBJS} | ||||
| 	${RANLIB} $@ | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|  | ||||
| OBJLIB	:= $(patsubst %.c,%.o,$(strip $(CSOURCES))) | ||||
|  | ||||
|  | ||||
| $(LIB): $(OBJLIB) | ||||
| 	ar cru $@ $^ | ||||
| 	$(RANLIB) $@ | ||||
|  | ||||
| all: $(LIB) demos | ||||
|  | ||||
| @@ -34,16 +37,13 @@ demos: adig.exe ahost.exe | ||||
| tags: | ||||
| 	etags *.[ch] | ||||
|  | ||||
| adig.exe: adig.o $(LIB) | ||||
| 	${CC} ${LDFLAGS} -o $@ adig.o $(LIB) ${LIBS} | ||||
| %.exe: %.o ares_getopt.o $(LIB) | ||||
| 	$(LD) $(LDFLAGS) -o $@ $^ $(LIBS) | ||||
|  | ||||
| ahost.exe: ahost.o $(LIB) | ||||
| 	${CC} ${LDFLAGS} -o $@ ahost.o $(LIB) ${LIBS} | ||||
|  | ||||
| ${OBJS}: ares.h ares_dns.h ares_private.h | ||||
| $(OBJLIB): ares.h ares_dns.h ares_private.h | ||||
|  | ||||
| .c.o: | ||||
| 	${CC} -c ${CFLAGS} $< | ||||
| 	$(CC) $(CFLAGS) -c $< | ||||
|  | ||||
| check: | ||||
|  | ||||
| @@ -61,8 +61,8 @@ install: | ||||
| 	done) | ||||
|  | ||||
| clean: | ||||
| 	rm -f ${OBJS} $(LIB) adig.o adig.exe ahost.o ahost.exe | ||||
| 	$(RM) ares_getopt.o $(OBJLIB) $(LIB) adig.exe ahost.exe | ||||
|  | ||||
| distclean: clean | ||||
| 	rm -f config.cache config.log config.status Makefile | ||||
| 	$(RM) config.cache config.log config.status Makefile | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| ################################################################# | ||||
| # $Id$ | ||||
| # | ||||
| ## Makefile for building libares.lib (NetWare version - gnu make) | ||||
| ## Makefile for building libcares (NetWare version - gnu make) | ||||
| ## Use: make -f Makefile.netware | ||||
| ## | ||||
| ## Comments to: Guenter Knauf <eflash@gmx.net> | ||||
| ## Comments to: Guenter Knauf http://www.gknw.de/phpbb | ||||
| # | ||||
| ################################################################# | ||||
|  | ||||
| @@ -18,9 +19,9 @@ endif | ||||
|  | ||||
| # Edit the vars below to change NLM target settings. | ||||
| TARGETS = adig.nlm ahost.nlm | ||||
| LTARGET = libcares.lib | ||||
| LTARGET = libcares.$(LIBEXT) | ||||
| VERSION	= $(LIBCARES_VERSION) | ||||
| COPYR	= Copyright (C) 1996 - 2006, Daniel Stenberg, <daniel@haxx.se> | ||||
| COPYR	= Copyright (C) 1996 - 2007, Daniel Stenberg, <daniel@haxx.se> | ||||
| DESCR	= cURL $(subst .def,,$(notdir $@)) $(LIBCARES_VERSION_STR) - http://curl.haxx.se | ||||
| MTSAFE	= YES | ||||
| STACK	= 64000 | ||||
| @@ -69,9 +70,11 @@ CFLAGS	= $(OPT) -D$(DB) -DNETWARE -DHAVE_CONFIG_H -nostdinc | ||||
|  | ||||
| ifeq ($(CC),mwccnlm) | ||||
| LD	= mwldnlm | ||||
| LDFLAGS	= -nostdlib $(PRELUDE) $(OBJS) $(<:.def=.o) -o $@ -commandfile | ||||
| LDFLAGS	= -nostdlib $(PRELUDE) $(OBJEXE) $(<:.def=.o) -o $@ -commandfile | ||||
| AR	= mwldnlm | ||||
| ARFLAGS	= -type library -w nocmdline $(OBJDIR)/*.o -o | ||||
| ARFLAGS	= -nostdlib -type library -o | ||||
| LIBEXT	= lib | ||||
| #RANLIB	= | ||||
| CFLAGS	+= -msgstyle gcc -gccinc -inline off -opt nointrinsics -proc 586 | ||||
| CFLAGS	+= -relax_pointers | ||||
| #CFLAGS	+= -w on | ||||
| @@ -88,6 +91,8 @@ LD	= nlmconv | ||||
| LDFLAGS	= -T | ||||
| AR	= ar | ||||
| ARFLAGS	= -cq | ||||
| LIBEXT	= a | ||||
| RANLIB	= ranlib | ||||
| CFLAGS	+= -fno-builtin -fpcc-struct-return -fno-strict-aliasing | ||||
| CFLAGS	+= -Wall -Wno-format -Wno-uninitialized # -pedantic | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| @@ -129,7 +134,8 @@ endif | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|  | ||||
| OBJS	:= $(patsubst %.c,$(OBJDIR)/%.o,$(strip $(CSOURCES))) | ||||
| OBJLIB	:= $(patsubst %.c,$(OBJDIR)/%.o,$(strip $(CSOURCES))) | ||||
| OBJEXE	= $(OBJLIB) $(OBJDIR)/ares_getopt.o   | ||||
|  | ||||
| .PHONY: lib nlm prebuild dist install clean | ||||
|  | ||||
| @@ -140,7 +146,7 @@ nlm: prebuild $(TARGETS) | ||||
| prebuild: $(OBJDIR) $(OBJDIR)/version.inc config.h arpa/nameser.h | ||||
|  | ||||
| dist: all | ||||
| 	-$(RM) $(OBJS) $(OBJDIR)/*.map $(OBJDIR)/*.ncv | ||||
| 	-$(RM) $(OBJLIB) $(OBJDIR)/*.map $(OBJDIR)/*.ncv | ||||
| 	-$(RM) $(OBJDIR)/*.def $(OBJDIR)/*.xdc $(OBJDIR)/version.inc | ||||
|  | ||||
| install: $(INSTDIR) all | ||||
| @@ -155,12 +161,15 @@ clean: | ||||
| 	-$(RM) -r $(OBJDIR) | ||||
| 	-$(RM) -r arpa | ||||
|  | ||||
| %.lib: $(OBJS) | ||||
| %.$(LIBEXT): $(OBJLIB) | ||||
| 	@echo Creating $@ | ||||
| 	@-$(RM) $@ | ||||
| 	@$(AR) $(ARFLAGS) $@ $^ | ||||
| ifdef RANLIB | ||||
| 	@$(RANLIB) $@ | ||||
| endif | ||||
|  | ||||
| %.nlm: $(OBJDIR)/%.def $(OBJDIR)/%.o $(OBJDIR)/%.xdc $(OBJS) | ||||
| %.nlm: $(OBJDIR)/%.def $(OBJDIR)/%.o $(OBJDIR)/%.xdc $(OBJEXE) | ||||
| 	@echo Linking $@ | ||||
| 	@-$(RM) $@ | ||||
| 	@$(LD) $(LDFLAGS) $< | ||||
| @@ -244,7 +253,7 @@ ifdef IMPORTS | ||||
| 	@echo $(DL)import $(IMPORTS)$(DL) >> $@ | ||||
| endif | ||||
| ifeq ($(LD),nlmconv) | ||||
| 	@echo $(DL)input $(OBJS)$(DL) >> $@ | ||||
| 	@echo $(DL)input $(OBJEXE)$(DL) >> $@ | ||||
| 	@echo $(DL)input $(PRELUDE)$(DL) >> $@ | ||||
| 	@echo $(DL)output $(notdir $(@:.def=.nlm))$(DL) >> $@ | ||||
| endif | ||||
| @@ -255,6 +264,9 @@ config.h: Makefile.netware | ||||
| 	@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)#ifndef NETWARE$(DL) >> $@ | ||||
| 	@echo $(DL)#error This $(notdir $@) is created for NetWare platform!$(DL) >> $@ | ||||
| 	@echo $(DL)#endif$(DL) >> $@ | ||||
| 	@echo $(DL)#define OS "i586-pc-NetWare"$(DL) >> $@ | ||||
| 	@echo $(DL)#define VERSION "$(LIBCARES_VERSION_STR)"$(DL) >> $@ | ||||
| 	@echo $(DL)#define PACKAGE_BUGREPORT "a suitable curl mailing list => http://curl.haxx.se/mail/"$(DL) >> $@ | ||||
| @@ -281,6 +293,8 @@ config.h: Makefile.netware | ||||
| 	@echo $(DL)#define HAVE_SEND 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_SIGNAL_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_SIG_ATOMIC_T 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@ | ||||
| @@ -330,6 +344,11 @@ else | ||||
| 	@echo $(DL)#define HAVE_SYS_SOCKIO_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_NETDB_H 1$(DL) >> $@ | ||||
| endif | ||||
| 	@echo $(DL)#ifdef __GNUC__$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_VARIADIC_MACROS_GCC 1$(DL) >> $@ | ||||
| 	@echo $(DL)#else$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_VARIADIC_MACROS_C99 1$(DL) >> $@ | ||||
| 	@echo $(DL)#endif$(DL) >> $@ | ||||
| ifdef OLD_NOVELLSDK | ||||
| 	@echo $(DL)#define socklen_t int$(DL) >> $@ | ||||
| endif | ||||
|   | ||||
| @@ -67,6 +67,7 @@ OBJECTS = $(OBJ_DIR)\ares_fds.obj              \ | ||||
|           $(OBJ_DIR)\ares_expand_name.obj      \ | ||||
|           $(OBJ_DIR)\ares_parse_a_reply.obj    \ | ||||
|           $(OBJ_DIR)\ares_parse_aaaa_reply.obj \ | ||||
|           $(OBJ_DIR)\ares_parse_ns_reply.obj   \ | ||||
|           $(OBJ_DIR)\windows_port.obj          \ | ||||
|           $(OBJ_DIR)\ares_expand_string.obj    \ | ||||
|           $(OBJ_DIR)\ares_parse_ptr_reply.obj  \ | ||||
| @@ -75,6 +76,7 @@ OBJECTS = $(OBJ_DIR)\ares_fds.obj              \ | ||||
|           $(OBJ_DIR)\inet_ntop.obj | ||||
|  | ||||
| all: $(OBJ_DIR) cares.lib cares.dll cares_imp.lib ahost.exe adig.exe | ||||
|        @echo Welcome to c-ares library and examples | ||||
|  | ||||
| $(OBJ_DIR): | ||||
|        mkdir $(OBJ_DIR) | ||||
| @@ -105,6 +107,7 @@ $(DEF_FILE): $(OBJECTS) Makefile.VC6 | ||||
|        @echo   ares_mkquery           >> $@ | ||||
|        @echo   ares_parse_a_reply     >> $@ | ||||
|        @echo   ares_parse_ptr_reply   >> $@ | ||||
|        @echo   ares_parse_ns_reply    >> $@ | ||||
|        @echo   ares_process           >> $@ | ||||
|        @echo   ares_query             >> $@ | ||||
|        @echo   ares_search            >> $@ | ||||
| @@ -121,11 +124,11 @@ $(DEF_FILE): $(OBJECTS) Makefile.VC6 | ||||
|        @echo   ares_gettimeofday      >> $@ | ||||
|        @echo   ares_parse_aaaa_reply  >> $@ | ||||
|  | ||||
| ahost.exe: $(OBJ_DIR) $(OBJ_DIR)\ahost.obj cares_imp.lib | ||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\ahost.obj cares_imp.lib $(EX_LIBS) | ||||
| ahost.exe: $(OBJ_DIR) $(OBJ_DIR)\ahost.obj $(OBJ_DIR)\ares_getopt.obj cares_imp.lib | ||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\ahost.obj $(OBJ_DIR)\ares_getopt.obj cares_imp.lib $(EX_LIBS) | ||||
|  | ||||
| adig.exe: $(OBJ_DIR) $(OBJ_DIR)\adig.obj $(OBJ_DIR)\getopt.obj cares_imp.lib | ||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\adig.obj $(OBJ_DIR)\getopt.obj cares_imp.lib $(EX_LIBS) | ||||
| adig.exe: $(OBJ_DIR) $(OBJ_DIR)\adig.obj $(OBJ_DIR)\ares_getopt.obj cares_imp.lib | ||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\adig.obj $(OBJ_DIR)\ares_getopt.obj cares_imp.lib $(EX_LIBS) | ||||
|  | ||||
| clean: | ||||
|        - del $(OBJ_DIR)\*.obj *.ilk *.pdb *.pbt *.pbi *.pbo *._xe *.map | ||||
| @@ -142,56 +145,89 @@ vclean realclean: clean | ||||
| # | ||||
| $(OBJ_DIR)\ares_fds.obj: ares_fds.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_process.obj: ares_process.c setup.h setup_once.h nameser.h     \ | ||||
|   ares.h ares_dns.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_free_hostent.obj: ares_free_hostent.c setup.h setup_once.h     \ | ||||
|   ares.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_query.obj: ares_query.c setup.h setup_once.h nameser.h         \ | ||||
|   ares.h ares_dns.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares__close_sockets.obj: ares__close_sockets.c setup.h setup_once.h \ | ||||
|   ares.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_free_string.obj: ares_free_string.c setup.h setup_once.h ares.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_search.obj: ares_search.c setup.h setup_once.h nameser.h       \ | ||||
|   ares.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares__get_hostent.obj: ares__get_hostent.c setup.h setup_once.h     \ | ||||
|   ares.h ares_private.h ares_ipv6.h inet_net_pton.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_gethostbyaddr.obj: ares_gethostbyaddr.c setup.h setup_once.h   \ | ||||
|   nameser.h ares.h ares_private.h ares_ipv6.h inet_net_pton.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_send.obj: ares_send.c setup.h setup_once.h nameser.h ares.h    \ | ||||
|   ares_dns.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares__read_line.obj: ares__read_line.c setup.h setup_once.h ares.h  \ | ||||
|   ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_gethostbyname.obj: ares_gethostbyname.c setup.h setup_once.h   \ | ||||
|   nameser.h ares.h ares_private.h ares_ipv6.h inet_net_pton.h bitncmp.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_strerror.obj: ares_strerror.c setup.h setup_once.h ares.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_cancel.obj: ares_cancel.c setup.h setup_once.h ares.h          \ | ||||
|   ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_init.obj: ares_init.c setup.h setup_once.h nameser.h ares.h    \ | ||||
|   ares_private.h ares_ipv6.h inet_net_pton.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_timeout.obj: ares_timeout.c setup.h setup_once.h ares.h        \ | ||||
|   ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_destroy.obj: ares_destroy.c setup.h setup_once.h ares.h        \ | ||||
|   ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_mkquery.obj: ares_mkquery.c setup.h setup_once.h nameser.h     \ | ||||
|   ares.h ares_dns.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_version.obj: ares_version.c setup.h setup_once.h ares_version.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_expand_name.obj: ares_expand_name.c setup.h setup_once.h       \ | ||||
|   nameser.h ares.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_parse_a_reply.obj: ares_parse_a_reply.c setup.h setup_once.h   \ | ||||
|   nameser.h ares.h ares_dns.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\windows_port.obj: windows_port.c setup.h setup_once.h nameser.h     \ | ||||
|   ares.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_expand_string.obj: ares_expand_string.c setup.h setup_once.h   \ | ||||
|   nameser.h ares.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_parse_ptr_reply.obj: ares_parse_ptr_reply.c setup.h            \ | ||||
|   setup_once.h nameser.h ares.h ares_dns.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_parse_aaaa_reply.obj: ares_parse_aaaa_reply.c setup.h          \ | ||||
|   setup_once.h nameser.h ares.h ares_dns.h inet_net_pton.h ares_private.h      \ | ||||
|   ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_parse_ns_reply.obj: ares_parse_ns_reply.c setup.h              \ | ||||
|   setup_once.h nameser.h ares.h ares_dns.h ares_private.h ares_ipv6.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_getnameinfo.obj: ares_getnameinfo.c setup.h setup_once.h       \ | ||||
|   nameser.h ares.h ares_private.h ares_ipv6.h inet_ntop.h | ||||
|  | ||||
| $(OBJ_DIR)\inet_net_pton.obj: inet_net_pton.c setup.h setup_once.h nameser.h   \ | ||||
|   ares_ipv6.h inet_net_pton.h | ||||
|  | ||||
| $(OBJ_DIR)\bitncmp.obj: bitncmp.c bitncmp.h | ||||
|  | ||||
| $(OBJ_DIR)\inet_ntop.obj: inet_ntop.c setup.h setup_once.h nameser.h           \ | ||||
|   ares_ipv6.h inet_ntop.h | ||||
|  | ||||
| $(OBJ_DIR)\ares_getopt.obj: ares_getopt.c ares_getopt.h | ||||
|   | ||||
							
								
								
									
										9
									
								
								ares/RELEASE-NOTES
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								ares/RELEASE-NOTES
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| This is what's new and changed in the c-ares 1.4.1 release: | ||||
|  | ||||
|  o  | ||||
|  | ||||
| Thanks go to these friendly people for their efforts and contributions: | ||||
|  | ||||
|   | ||||
|  | ||||
| Have fun! | ||||
| @@ -663,7 +663,7 @@ AC_DEFUN([CURL_CHECK_FUNC_RECV], [ | ||||
|   ]) | ||||
|   # | ||||
|   if test "$curl_cv_recv" = "yes"; then | ||||
|     AC_CACHE_CHECK([types of arguments and return type for recv], | ||||
|     AC_CACHE_CHECK([types of args and return type for recv], | ||||
|       [curl_cv_func_recv_args], [ | ||||
|       curl_cv_func_recv_args="unknown" | ||||
|       for recv_retv in 'int' 'ssize_t'; do | ||||
| @@ -793,7 +793,7 @@ AC_DEFUN([CURL_CHECK_FUNC_SEND], [ | ||||
|   ]) | ||||
|   # | ||||
|   if test "$curl_cv_send" = "yes"; then | ||||
|     AC_CACHE_CHECK([types of arguments and return type for send], | ||||
|     AC_CACHE_CHECK([types of args and return type for send], | ||||
|       [curl_cv_func_send_args], [ | ||||
|       curl_cv_func_send_args="unknown" | ||||
|       for send_retv in 'int' 'ssize_t'; do | ||||
| @@ -1013,6 +1013,48 @@ AC_DEFUN([CURL_CHECK_STRUCT_TIMEVAL], [ | ||||
| ]) # AC_DEFUN | ||||
|  | ||||
|  | ||||
| dnl TYPE_SIG_ATOMIC_T | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check if the sig_atomic_t type is available, and | ||||
| dnl verify if it is already defined as volatile. | ||||
|  | ||||
| AC_DEFUN([TYPE_SIG_ATOMIC_T], [ | ||||
|   AC_CHECK_HEADERS(signal.h) | ||||
|   AC_CHECK_TYPE([sig_atomic_t],[ | ||||
|     AC_DEFINE(HAVE_SIG_ATOMIC_T, 1, | ||||
|       [Define to 1 if sig_atomic_t is an available typedef.]) | ||||
|   ], ,[ | ||||
| #ifdef HAVE_SIGNAL_H | ||||
| #include <signal.h> | ||||
| #endif | ||||
|   ]) | ||||
|   case "$ac_cv_type_sig_atomic_t" in | ||||
|     yes) | ||||
|       # | ||||
|       AC_MSG_CHECKING([if sig_atomic_t is already defined as volatile]) | ||||
|       AC_TRY_LINK([ | ||||
| #ifdef HAVE_SIGNAL_H | ||||
| #include <signal.h> | ||||
| #endif | ||||
|         ],[ | ||||
|           static volatile sig_atomic_t dummy = 0; | ||||
|         ],[  | ||||
|           AC_MSG_RESULT([no]) | ||||
|           ac_cv_sig_atomic_t_volatile="no" | ||||
|         ],[ | ||||
|           AC_MSG_RESULT([yes]) | ||||
|           ac_cv_sig_atomic_t_volatile="yes" | ||||
|       ]) | ||||
|       # | ||||
|       if test "$ac_cv_sig_atomic_t_volatile" = "yes"; then | ||||
|         AC_DEFINE(HAVE_SIG_ATOMIC_T_VOLATILE, 1, | ||||
|           [Define to 1 if sig_atomic_t is already defined as volatile.]) | ||||
|       fi | ||||
|       ;; | ||||
|   esac | ||||
| ]) # AC_DEFUN | ||||
|  | ||||
|  | ||||
| dnl CURL_CHECK_NONBLOCKING_SOCKET | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check for how to set a socket to non-blocking state. There seems to exist | ||||
| @@ -1155,43 +1197,6 @@ dnl end of non-blocking try-compile test | ||||
| ]) | ||||
|  | ||||
|  | ||||
| dnl TYPE_SOCKADDR_STORAGE | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check for struct sockaddr_storage. Most IPv6-enabled hosts have it, but | ||||
| dnl AIX 4.3 is one known exception. | ||||
| AC_DEFUN([TYPE_SOCKADDR_STORAGE], | ||||
| [ | ||||
|    AC_CHECK_TYPE([struct sockaddr_storage], | ||||
|         AC_DEFINE(HAVE_STRUCT_SOCKADDR_STORAGE, 1, | ||||
|                   [if struct sockaddr_storage is defined]), , | ||||
|    [ | ||||
| #undef inline | ||||
| #ifdef HAVE_WINDOWS_H | ||||
| #ifndef WIN32_LEAN_AND_MEAN | ||||
| #define WIN32_LEAN_AND_MEAN | ||||
| #endif | ||||
| #include <windows.h> | ||||
| #ifdef HAVE_WINSOCK2_H | ||||
| #include <winsock2.h> | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
| #endif | ||||
|    ]) | ||||
| ]) | ||||
|  | ||||
|  | ||||
| dnl TYPE_IN_ADDR_T | ||||
| dnl ------------------------------------------------- | ||||
| dnl Check for in_addr_t: it is used to receive the return code of inet_addr() | ||||
| @@ -1274,12 +1279,39 @@ AC_DEFUN([TYPE_IN_ADDR_T], | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|   ]) dnl AC_CHECK_TYPE | ||||
| ]) dnl AC_DEFUN | ||||
|  | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl CURL_DETECT_ICC ([ACTION-IF-YES]) | ||||
| dnl | ||||
| dnl check if this is the Intel ICC compiler, and if so run the ACTION-IF-YES | ||||
| dnl sets the $ICC variable to "yes" or "no" | ||||
| dnl ********************************************************************** | ||||
| AC_DEFUN([CURL_DETECT_ICC], | ||||
| [ | ||||
|     ICC="no" | ||||
|     AC_MSG_CHECKING([for icc in use]) | ||||
|     if test "$GCC" = "yes"; then | ||||
|        dnl check if this is icc acting as gcc in disguise | ||||
|        AC_EGREP_CPP([^__INTEL_COMPILER], [__INTEL_COMPILER], | ||||
|          dnl action if the text is found, this it has not been replaced by the | ||||
|          dnl cpp | ||||
|          ICC="no", | ||||
|          dnl the text was not found, it was replaced by the cpp | ||||
|          ICC="yes" | ||||
|          AC_MSG_RESULT([yes]) | ||||
|          [$1] | ||||
|        ) | ||||
|     fi | ||||
|     if test "$ICC" = "no"; then | ||||
|         # this is not ICC | ||||
|         AC_MSG_RESULT([no]) | ||||
|     fi | ||||
| ]) | ||||
|  | ||||
| dnl We create a function for detecting which compiler we use and then set as | ||||
| dnl pendantic compiler options as possible for that particular compiler. The | ||||
| dnl options are only used for debug-builds. | ||||
| @@ -1290,6 +1322,10 @@ dnl is changed. | ||||
|  | ||||
| AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
| [ | ||||
|     if test "z$ICC" = "z"; then | ||||
|       CURL_DETECT_ICC | ||||
|     fi | ||||
|  | ||||
|     if test "$GCC" = "yes"; then | ||||
|  | ||||
|        dnl figure out gcc version! | ||||
| @@ -1300,40 +1336,46 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|        gccnum=`(expr $num1 "*" 100 + $num2) 2>/dev/null` | ||||
|        AC_MSG_RESULT($gccver) | ||||
|  | ||||
|        AC_MSG_CHECKING([if this is icc in disguise]) | ||||
|        AC_EGREP_CPP([^__INTEL_COMPILER], [__INTEL_COMPILER], | ||||
|          dnl action if the text is found, this it has not been replaced by the | ||||
|          dnl cpp | ||||
|          ICC="no" | ||||
|          AC_MSG_RESULT([no]), | ||||
|          dnl the text was not found, it was replaced by the cpp | ||||
|          ICC="yes" | ||||
|          AC_MSG_RESULT([yes]) | ||||
|        ) | ||||
|  | ||||
|        if test "$ICC" = "yes"; then | ||||
|          dnl this is icc, not gcc. | ||||
|  | ||||
|          dnl ICC warnings we ignore: | ||||
|          dnl * 279 warns on static conditions in while expressions | ||||
|          dnl * 269 warns on our "%Od" printf formatters for curl_off_t output: | ||||
|          dnl   "invalid format string conversion" | ||||
|          dnl * 279 warns on static conditions in while expressions | ||||
|          dnl * 981 warns on "operands are evaluated in unspecified order" | ||||
|          dnl * 1418 "external definition with no prior declaration" | ||||
|          dnl * 1419 warns on "external declaration in primary source file" | ||||
|          dnl   which we know and do on purpose. | ||||
|  | ||||
|          WARN="-wd279,269" | ||||
|          WARN="-wd279,269,981,1418,1419" | ||||
|  | ||||
|          if test "$gccnum" -gt "600"; then | ||||
|             dnl icc 6.0 and older doesn't have the -Wall flag | ||||
|             WARN="-Wall $WARN" | ||||
|          fi | ||||
|        else dnl $ICC = yes | ||||
|          dnl  | ||||
|          WARN="-W -Wall -Wwrite-strings -pedantic -Wno-long-long -Wundef -Wpointer-arith -Wnested-externs -Winline -Wmissing-declarations -Wmissing-prototypes -Wsign-compare" | ||||
|          dnl this is a set of options we believe *ALL* gcc versions support: | ||||
|          WARN="-W -Wall -Wwrite-strings -pedantic -Wpointer-arith -Wnested-externs -Winline -Wmissing-prototypes" | ||||
|  | ||||
|          dnl -Wcast-align is a bit too annoying ;-) | ||||
|          dnl -Wcast-align is a bit too annoying on all gcc versions ;-) | ||||
|  | ||||
|          if test "$gccnum" -ge "207"; then | ||||
|            dnl gcc 2.7 or later | ||||
|            WARN="$WARN -Wmissing-declarations" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -gt "295"; then | ||||
|            dnl only if the compiler is newer than 2.95 since we got lots of | ||||
|            dnl "`_POSIX_C_SOURCE' is not defined" in system headers with | ||||
|            dnl gcc 2.95.4 on FreeBSD 4.9! | ||||
|            WARN="$WARN -Wundef -Wno-long-long -Wsign-compare" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -ge "296"; then | ||||
|            dnl gcc 2.96 or later | ||||
|            WARN="$WARN -Wfloat-equal" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -gt "296"; then | ||||
|            dnl this option does not exist in 2.96 | ||||
| @@ -1341,17 +1383,26 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|          fi | ||||
|  | ||||
|          dnl -Wunreachable-code seems totally unreliable on my gcc 3.3.2 on | ||||
|            dnl on i686-Linux as it gives us heaps with false positives | ||||
|          dnl on i686-Linux as it gives us heaps with false positives. | ||||
|          dnl Also, on gcc 4.0.X it is totally unbearable and complains all | ||||
|          dnl over making it unusable for generic purposes. Let's not use it. | ||||
|  | ||||
|          if test "$gccnum" -ge "303"; then | ||||
|            dnl gcc 3.3 and later | ||||
|            WARN="$WARN -Wendif-labels -Wstrict-prototypes" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -ge "304"; then | ||||
|            # try these on gcc 3.4 | ||||
|            WARN="$WARN -Wdeclaration-after-statement" | ||||
|          fi | ||||
|  | ||||
|          for flag in $CPPFLAGS; do | ||||
|            case "$flag" in | ||||
|             -I*) | ||||
|               dnl include path | ||||
|               dnl Include path, provide a -isystem option for the same dir | ||||
|               dnl to prevent warnings in those dirs. The -isystem was not very | ||||
|               dnl reliable on earlier gcc versions. | ||||
|               add=`echo $flag | sed 's/^-I/-isystem /g'` | ||||
|               WARN="$WARN $add" | ||||
|               ;; | ||||
| @@ -1362,6 +1413,12 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|  | ||||
|        CFLAGS="$CFLAGS $WARN" | ||||
|  | ||||
|       AC_MSG_NOTICE([Added this set of compiler options: $WARN]) | ||||
|  | ||||
|     else dnl $GCC = yes | ||||
|  | ||||
|       AC_MSG_NOTICE([Added no extra compiler options]) | ||||
|  | ||||
|     fi dnl $GCC = yes | ||||
|  | ||||
|     dnl strip off optimizer flags | ||||
| @@ -1474,39 +1531,3 @@ else | ||||
| fi | ||||
| ]) | ||||
|  | ||||
| # Prevent libtool for checking how to run C++ compiler and check for other | ||||
| # tools we don't want to use. We do this by m4-defining the _LT_AC_TAGCONFIG | ||||
| # variable to the code to run, as by default it uses a much more complicated | ||||
| # approach. The code below that is actually added seems to be used for cases | ||||
| # where configure has trouble figuring out what C compiler to use but where | ||||
| # the installed libtool has an idea. | ||||
| # | ||||
| # This function is a re-implemented version of the Paolo Bonzini fix posted to | ||||
| # the c-ares mailing list by Bram Matthys on May 6 2006. My version removes | ||||
| # redundant code but also adds the LTCFLAGS check that wasn't in that patch. | ||||
| # | ||||
| # Some code in this function was extracted from the generated configure script. | ||||
| # | ||||
| # CARES_CLEAR_LIBTOOL_TAGS | ||||
| AC_DEFUN([CARES_CLEAR_LIBTOOL_TAGS], | ||||
|   [m4_define([_LT_AC_TAGCONFIG], [ | ||||
|   if test -f "$ltmain"; then | ||||
|     if test ! -f "${ofile}"; then | ||||
|       AC_MSG_WARN([output file `$ofile' does not exist]) | ||||
|     fi | ||||
|  | ||||
|     if test -z "$LTCC"; then | ||||
|       eval "`$SHELL ${ofile} --config | grep '^LTCC='`" | ||||
|       if test -z "$LTCC"; then | ||||
|         AC_MSG_WARN([output file `$ofile' does not look like a libtool | ||||
| script]) | ||||
|       else | ||||
|         AC_MSG_WARN([using `LTCC=$LTCC', extracted from `$ofile']) | ||||
|       fi | ||||
|     fi | ||||
|     if test -z "$LTCFLAGS"; then | ||||
|       eval "`$SHELL ${ofile} --config | grep '^LTCFLAGS='`" | ||||
|     fi | ||||
|   fi | ||||
|   ])] | ||||
| ) | ||||
|   | ||||
							
								
								
									
										34
									
								
								ares/adig.c
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								ares/adig.c
									
									
									
									
									
								
							| @@ -16,21 +16,21 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
| #endif | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #include <netdb.h> | ||||
| #endif | ||||
| #ifdef HAVE_GETOPT_H | ||||
| #include <getopt.h> | ||||
| #include <netdb.h> | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| @@ -42,25 +42,17 @@ | ||||
| #include "ares.h" | ||||
| #include "ares_dns.h" | ||||
| #include "inet_ntop.h" | ||||
| #include "ares_getopt.h" | ||||
|  | ||||
| #ifdef WATT32 | ||||
| #undef WIN32  /* Redefined in MingW headers */ | ||||
| #endif | ||||
|  | ||||
| #ifndef INADDR_NONE | ||||
| #define INADDR_NONE 0xffffffff | ||||
| #endif | ||||
|  | ||||
| /* Mac OS X portability check */ | ||||
| #ifndef T_SRV | ||||
| #define T_SRV 33 /* server selection */ | ||||
| #endif | ||||
|  | ||||
| #ifndef optind | ||||
| extern int optind; | ||||
| extern char *optarg; | ||||
| #endif | ||||
|  | ||||
| struct nv { | ||||
|   const char *name; | ||||
|   int value; | ||||
| @@ -164,7 +156,7 @@ int main(int argc, char **argv) | ||||
|   options.flags = ARES_FLAG_NOCHECKRESP; | ||||
|   options.servers = NULL; | ||||
|   options.nservers = 0; | ||||
|   while ((c = getopt(argc, argv, "df:s:c:t:T:U:")) != -1) | ||||
|   while ((c = ares_getopt(argc, argv, "df:s:c:t:T:U:")) != -1) | ||||
|     { | ||||
|       switch (c) | ||||
|         { | ||||
| @@ -285,7 +277,7 @@ int main(int argc, char **argv) | ||||
|         break; | ||||
|       tvp = ares_timeout(channel, NULL, &tv); | ||||
|       count = select(nfds, &read_fds, &write_fds, NULL, tvp); | ||||
|       if (count < 0 && errno != EINVAL) | ||||
|       if (count < 0 && SOCKERRNO != EINVAL) | ||||
|         { | ||||
|           perror("select"); | ||||
|           return 1; | ||||
| @@ -294,6 +286,11 @@ int main(int argc, char **argv) | ||||
|     } | ||||
|  | ||||
|   ares_destroy(channel); | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
|   WSACleanup(); | ||||
| #endif | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -551,8 +548,9 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       if (p + 20 > aptr + dlen) | ||||
|         return NULL; | ||||
|       printf("\t\t\t\t\t\t( %lu %lu %lu %lu %lu )", | ||||
|              DNS__32BIT(p), DNS__32BIT(p+4), DNS__32BIT(p+8), | ||||
|              DNS__32BIT(p+12), DNS__32BIT(p+16)); | ||||
|              (unsigned long)DNS__32BIT(p), (unsigned long)DNS__32BIT(p+4), | ||||
|              (unsigned long)DNS__32BIT(p+8), (unsigned long)DNS__32BIT(p+12), | ||||
|              (unsigned long)DNS__32BIT(p+16)); | ||||
|       break; | ||||
|  | ||||
|     case T_TXT: | ||||
|   | ||||
							
								
								
									
										29
									
								
								ares/ahost.c
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								ares/ahost.c
									
									
									
									
									
								
							| @@ -16,34 +16,29 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #else | ||||
| #if !defined(WIN32) || defined(WATT32) | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
| #endif | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <netdb.h> | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #ifdef HAVE_GETOPT_H | ||||
| #include <getopt.h> | ||||
| #endif | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_dns.h" | ||||
| #include "inet_ntop.h" | ||||
| #include "inet_net_pton.h" | ||||
|  | ||||
| #ifndef INADDR_NONE | ||||
| #define INADDR_NONE 0xffffffff | ||||
| #endif | ||||
| #include "ares_getopt.h" | ||||
|  | ||||
| #ifndef HAVE_STRUCT_IN6_ADDR | ||||
| struct in6_addr | ||||
| @@ -70,10 +65,15 @@ int main(int argc, char **argv) | ||||
|   WSAStartup(wVersionRequested, &wsaData); | ||||
| #endif | ||||
|  | ||||
|   while ((c = getopt(argc,argv,"t:h")) != -1) | ||||
|   while ((c = ares_getopt(argc,argv,"dt:h")) != -1) | ||||
|     { | ||||
|       switch (c) | ||||
|         { | ||||
|         case 'd': | ||||
| #ifdef WATT32 | ||||
|           dbug_init(); | ||||
| #endif | ||||
|           break; | ||||
|         case 't': | ||||
|           if (!strcasecmp(optarg,"a")) | ||||
|             addr_family = AF_INET; | ||||
| @@ -134,6 +134,11 @@ int main(int argc, char **argv) | ||||
|     } | ||||
|  | ||||
|   ares_destroy(channel); | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
|   WSACleanup(); | ||||
| #endif | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										27
									
								
								ares/ares.h
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								ares/ares.h
									
									
									
									
									
								
							| @@ -94,6 +94,7 @@ extern "C" { | ||||
| #define ARES_OPT_DOMAINS        (1 << 7) | ||||
| #define ARES_OPT_LOOKUPS        (1 << 8) | ||||
| #define ARES_OPT_SOCK_STATE_CB  (1 << 9) | ||||
| #define ARES_OPT_SORTLIST       (1 << 10) | ||||
|  | ||||
| /* Nameinfo flag values */ | ||||
| #define ARES_NI_NOFQDN                  (1 << 0) | ||||
| @@ -136,6 +137,22 @@ extern "C" { | ||||
| #define ARES_GETSOCK_WRITABLE(bits,num) (bits & (1 << ((num) + \ | ||||
|                                          ARES_GETSOCK_MAXNUM))) | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Typedef our socket type | ||||
|  */ | ||||
|  | ||||
| #ifndef ares_socket_typedef | ||||
| #ifdef WIN32 | ||||
| typedef SOCKET ares_socket_t; | ||||
| #define ARES_SOCKET_BAD INVALID_SOCKET | ||||
| #else | ||||
| typedef int ares_socket_t; | ||||
| #define ARES_SOCKET_BAD -1 | ||||
| #endif | ||||
| #define ares_socket_typedef | ||||
| #endif /* ares_socket_typedef */ | ||||
|  | ||||
| #ifdef WIN32 | ||||
| typedef void (*ares_sock_state_cb)(void *data, | ||||
|                                    SOCKET socket, | ||||
| @@ -148,6 +165,8 @@ typedef void (*ares_sock_state_cb)(void *data, | ||||
|                                    int writable); | ||||
| #endif | ||||
|  | ||||
| struct apattern; | ||||
|  | ||||
| struct ares_options { | ||||
|   int flags; | ||||
|   int timeout; | ||||
| @@ -162,6 +181,8 @@ struct ares_options { | ||||
|   char *lookups; | ||||
|   ares_sock_state_cb sock_state_cb; | ||||
|   void *sock_state_cb_data; | ||||
|   struct apattern *sortlist; | ||||
|   int nsort; | ||||
| }; | ||||
|  | ||||
| struct hostent; | ||||
| @@ -179,6 +200,8 @@ typedef void (*ares_nameinfo_callback)(void *arg, int status, | ||||
| int ares_init(ares_channel *channelptr); | ||||
| int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
|                       int optmask); | ||||
| int ares_save_options(ares_channel channel, struct ares_options *options, int *optmask); | ||||
| void ares_destroy_options(struct ares_options *options); | ||||
| void ares_destroy(ares_channel channel); | ||||
| void ares_cancel(ares_channel channel); | ||||
| void ares_send(ares_channel channel, const unsigned char *qbuf, int qlen, | ||||
| @@ -200,6 +223,8 @@ int ares_getsock(ares_channel channel, int *socks, int numsocks); | ||||
| struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv, | ||||
|                              struct timeval *tv); | ||||
| void ares_process(ares_channel channel, fd_set *read_fds, fd_set *write_fds); | ||||
| void ares_process_fd(ares_channel channel, ares_socket_t read_fd, | ||||
|                      ares_socket_t write_fd); | ||||
|  | ||||
| int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id, | ||||
|                  int rd, unsigned char **buf, int *buflen); | ||||
| @@ -213,6 +238,8 @@ int ares_parse_aaaa_reply(const unsigned char *abuf, int alen, | ||||
|                        struct hostent **host); | ||||
| int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr, | ||||
|                          int addrlen, int family, struct hostent **host); | ||||
| int ares_parse_ns_reply(const unsigned char *abuf, int alen, | ||||
|                        struct hostent **host); | ||||
| void ares_free_string(void *str); | ||||
| void ares_free_hostent(struct hostent *host); | ||||
| const char *ares_strerror(int code); | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if !defined(WIN32) || defined(WATT32) | ||||
| #include <sys/socket.h> | ||||
| @@ -184,6 +183,7 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
|             free(hostent->h_addr_list); | ||||
|           free(hostent); | ||||
|         } | ||||
|       *host = NULL; | ||||
|       return ARES_ENOMEM; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -38,8 +38,11 @@ void ares_cancel(ares_channel channel) | ||||
|   } | ||||
|   channel->queries = NULL; | ||||
|   if (!(channel->flags & ARES_FLAG_STAYOPEN)) | ||||
|   { | ||||
|     if (channel->servers) | ||||
|     { | ||||
|       for (i = 0; i < channel->nservers; i++) | ||||
|         ares__close_sockets(channel, &channel->servers[i]); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -20,28 +20,55 @@ | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| void ares_destroy_options(struct ares_options *options) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   free(options->servers); | ||||
|   for (i = 0; i < options->ndomains; i++) | ||||
|     free(options->domains[i]); | ||||
|   free(options->domains); | ||||
|   if(options->sortlist) | ||||
|     free(options->sortlist); | ||||
|   free(options->lookups); | ||||
| } | ||||
|  | ||||
| void ares_destroy(ares_channel channel) | ||||
| { | ||||
|   int i; | ||||
|   struct query *query; | ||||
|  | ||||
|   if (!channel) | ||||
|     return; | ||||
|  | ||||
|   if (channel->servers) { | ||||
|     for (i = 0; i < channel->nservers; i++) | ||||
|       ares__close_sockets(channel, &channel->servers[i]); | ||||
|     free(channel->servers); | ||||
|   } | ||||
|  | ||||
|   if (channel->domains) { | ||||
|     for (i = 0; i < channel->ndomains; i++) | ||||
|       free(channel->domains[i]); | ||||
|     free(channel->domains); | ||||
|   } | ||||
|  | ||||
|   if(channel->sortlist) | ||||
|     free(channel->sortlist); | ||||
|  | ||||
|   if (channel->lookups) | ||||
|     free(channel->lookups); | ||||
|   while (channel->queries) | ||||
|     { | ||||
|  | ||||
|   while (channel->queries) { | ||||
|     query = channel->queries; | ||||
|     channel->queries = query->next; | ||||
|     query->callback(query->arg, ARES_EDESTRUCTION, NULL, 0); | ||||
|     if (query->tcpbuf) | ||||
|       free(query->tcpbuf); | ||||
|     if (query->skip_server) | ||||
|       free(query->skip_server); | ||||
|     free(query); | ||||
|   } | ||||
|  | ||||
|   free(channel); | ||||
| } | ||||
|   | ||||
							
								
								
									
										39
									
								
								ares/ares_destroy_options.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								ares/ares_destroy_options.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .\" Copyright 1998 by the Massachusetts Institute of Technology. | ||||
| .\" | ||||
| .\" Permission to use, copy, modify, and distribute this | ||||
| .\" software and its documentation for any purpose and without | ||||
| .\" fee is hereby granted, provided that the above copyright | ||||
| .\" notice appear in all copies and that both that copyright | ||||
| .\" notice and this permission notice appear in supporting | ||||
| .\" documentation, and that the name of M.I.T. not be used in | ||||
| .\" advertising or publicity pertaining to distribution of the | ||||
| .\" software without specific, written prior permission. | ||||
| .\" M.I.T. makes no representations about the suitability of | ||||
| .\" this software for any purpose.  It is provided "as is" | ||||
| .\" without express or implied warranty. | ||||
| .\" | ||||
| .TH ARES_DESTROY_OPTIONS 3 "1 June 2007" | ||||
| .SH NAME | ||||
| ares_destroy_options \- Destroy options initialized with ares_save_options | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <ares.h> | ||||
| .PP | ||||
| .B void ares_destroy_options(struct ares_options *\fIoptions\fP) | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_destroy_options | ||||
| function destroys the options struct identified by | ||||
| .IR options , | ||||
| freeing all memory allocated by ares_save_options. | ||||
|  | ||||
| .SH SEE ALSO | ||||
| .BR ares_save_options (3), | ||||
| .BR ares_init_options (3) | ||||
| .SH AUTHOR | ||||
| Brad House | ||||
| .br | ||||
| Copyright 1998 by the Massachusetts Institute of Technology. | ||||
| @@ -21,12 +21,13 @@ | ||||
| #define DNS__16BIT(p)                   (((p)[0] << 8) | (p)[1]) | ||||
| #define DNS__32BIT(p)                   (((p)[0] << 24) | ((p)[1] << 16) | \ | ||||
|                                          ((p)[2] << 8) | (p)[3]) | ||||
| #define DNS__SET16BIT(p, v)             (((p)[0] = ((v) >> 8) & 0xff), \ | ||||
|                                          ((p)[1] = (v) & 0xff)) | ||||
| #define DNS__SET32BIT(p, v)             (((p)[0] = ((v) >> 24) & 0xff), \ | ||||
|                                          ((p)[1] = ((v) >> 16) & 0xff), \ | ||||
|                                          ((p)[2] = ((v) >> 8) & 0xff), \ | ||||
|                                          ((p)[3] = (v) & 0xff)) | ||||
|  | ||||
| #define DNS__SET16BIT(p, v)  (((p)[0] = (unsigned char)(((v) >> 8) & 0xff)), \ | ||||
|                               ((p)[1] = (unsigned char)((v) & 0xff))) | ||||
| #define DNS__SET32BIT(p, v)  (((p)[0] = (unsigned char)(((v) >> 24) & 0xff)), \ | ||||
|                               ((p)[1] = (unsigned char)(((v) >> 16) & 0xff)), \ | ||||
|                               ((p)[2] = (unsigned char)(((v) >> 8) & 0xff)), \ | ||||
|                               ((p)[3] = (unsigned char)((v) & 0xff))) | ||||
|  | ||||
| #if 0 | ||||
| /* we cannot use this approach on systems where we can't access 16/32 bit | ||||
| @@ -54,14 +55,14 @@ | ||||
|  | ||||
| /* Macros for constructing a DNS header */ | ||||
| #define DNS_HEADER_SET_QID(h, v)      DNS__SET16BIT(h, v) | ||||
| #define DNS_HEADER_SET_QR(h, v)         ((h)[2] |= (((v) & 0x1) << 7)) | ||||
| #define DNS_HEADER_SET_OPCODE(h, v)     ((h)[2] |= (((v) & 0xf) << 3)) | ||||
| #define DNS_HEADER_SET_AA(h, v)         ((h)[2] |= (((v) & 0x1) << 2)) | ||||
| #define DNS_HEADER_SET_TC(h, v)         ((h)[2] |= (((v) & 0x1) << 1)) | ||||
| #define DNS_HEADER_SET_RD(h, v)         ((h)[2] |= (((v) & 0x1))) | ||||
| #define DNS_HEADER_SET_RA(h, v)         ((h)[3] |= (((v) & 0x1) << 7)) | ||||
| #define DNS_HEADER_SET_Z(h, v)          ((h)[3] |= (((v) & 0x7) << 4)) | ||||
| #define DNS_HEADER_SET_RCODE(h, v)      ((h)[3] |= (((v) & 0xf))) | ||||
| #define DNS_HEADER_SET_QR(h, v)       ((h)[2] |= (unsigned char)(((v) & 0x1) << 7)) | ||||
| #define DNS_HEADER_SET_OPCODE(h, v)   ((h)[2] |= (unsigned char)(((v) & 0xf) << 3)) | ||||
| #define DNS_HEADER_SET_AA(h, v)       ((h)[2] |= (unsigned char)(((v) & 0x1) << 2)) | ||||
| #define DNS_HEADER_SET_TC(h, v)       ((h)[2] |= (unsigned char)(((v) & 0x1) << 1)) | ||||
| #define DNS_HEADER_SET_RD(h, v)       ((h)[2] |= (unsigned char)((v) & 0x1)) | ||||
| #define DNS_HEADER_SET_RA(h, v)       ((h)[3] |= (unsigned char)(((v) & 0x1) << 7)) | ||||
| #define DNS_HEADER_SET_Z(h, v)        ((h)[3] |= (unsigned char)(((v) & 0x7) << 4)) | ||||
| #define DNS_HEADER_SET_RCODE(h, v)    ((h)[3] |= (unsigned char)((v) & 0xf)) | ||||
| #define DNS_HEADER_SET_QDCOUNT(h, v)  DNS__SET16BIT((h) + 4, v) | ||||
| #define DNS_HEADER_SET_ANCOUNT(h, v)  DNS__SET16BIT((h) + 6, v) | ||||
| #define DNS_HEADER_SET_NSCOUNT(h, v)  DNS__SET16BIT((h) + 8, v) | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
|   | ||||
| @@ -29,11 +29,12 @@ void ares_free_hostent(struct hostent *host) | ||||
| { | ||||
|   char **p; | ||||
|  | ||||
|   free(host->h_name); | ||||
|   free((char *)(host->h_name)); | ||||
|   for (p = host->h_aliases; *p; p++) | ||||
|     free(*p); | ||||
|   free(host->h_aliases); | ||||
|   free(host->h_addr_list[0]); | ||||
|   free(host->h_addr_list[0]); /* no matter if there is one or many entries, | ||||
|                                  there is only one malloc for all of them */ | ||||
|   free(host->h_addr_list); | ||||
|   free(host); | ||||
| } | ||||
|   | ||||
| @@ -15,7 +15,6 @@ | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -186,6 +185,7 @@ static int file_lookup(union ares_addr *addr, int family, struct hostent **host) | ||||
| { | ||||
|   FILE *fp; | ||||
|   int status; | ||||
|   int error; | ||||
|  | ||||
| #ifdef WIN32 | ||||
|   char PATH_HOSTS[MAX_PATH]; | ||||
| @@ -218,7 +218,22 @@ static int file_lookup(union ares_addr *addr, int family, struct hostent **host) | ||||
|  | ||||
|   fp = fopen(PATH_HOSTS, "r"); | ||||
|   if (!fp) | ||||
|     { | ||||
|       error = ERRNO; | ||||
|       switch(error) | ||||
|         { | ||||
|         case ENOENT: | ||||
|         case ESRCH: | ||||
|           return ARES_ENOTFOUND; | ||||
|         default: | ||||
|           DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                          error, strerror(error))); | ||||
|           DEBUGF(fprintf(stderr, "Error opening file: %s\n", | ||||
|                          PATH_HOSTS)); | ||||
|           *host = NULL; | ||||
|           return ARES_EFILE; | ||||
|         } | ||||
|     } | ||||
|   while ((status = ares__get_hostent(fp, family, host)) == ARES_SUCCESS) | ||||
|     { | ||||
|       if (family != (*host)->h_addrtype) | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -239,7 +238,7 @@ static int fake_hostent(const char *name, int family, ares_host_callback callbac | ||||
|   hostent.h_addr_list = addrs; | ||||
|   callback(arg, ARES_SUCCESS, &hostent); | ||||
|  | ||||
|   free(hostent.h_name); | ||||
|   free((char *)(hostent.h_name)); | ||||
|   return 1; | ||||
| } | ||||
|  | ||||
| @@ -248,6 +247,7 @@ static int file_lookup(const char *name, int family, struct hostent **host) | ||||
|   FILE *fp; | ||||
|   char **alias; | ||||
|   int status; | ||||
|   int error; | ||||
|  | ||||
| #ifdef WIN32 | ||||
|   char PATH_HOSTS[MAX_PATH]; | ||||
| @@ -280,8 +280,22 @@ static int file_lookup(const char *name, int family, struct hostent **host) | ||||
|  | ||||
|   fp = fopen(PATH_HOSTS, "r"); | ||||
|   if (!fp) | ||||
|     { | ||||
|       error = ERRNO; | ||||
|       switch(error) | ||||
|         { | ||||
|         case ENOENT: | ||||
|         case ESRCH: | ||||
|           return ARES_ENOTFOUND; | ||||
|  | ||||
|         default: | ||||
|           DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                          error, strerror(error))); | ||||
|           DEBUGF(fprintf(stderr, "Error opening file: %s\n", | ||||
|                          PATH_HOSTS)); | ||||
|           *host = NULL; | ||||
|           return ARES_EFILE; | ||||
|         } | ||||
|     } | ||||
|   while ((status = ares__get_hostent(fp, family, host)) == ARES_SUCCESS) | ||||
|     { | ||||
|       if (strcasecmp((*host)->h_name, name) == 0) | ||||
|   | ||||
| @@ -15,8 +15,6 @@ | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
| #include <ctype.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -110,7 +108,8 @@ void ares_getnameinfo(ares_channel channel, const struct sockaddr *sa, socklen_t | ||||
|         port = addr->sin_port; | ||||
|       else | ||||
|         port = addr6->sin6_port; | ||||
|       service = lookup_service(port, flags, buf, sizeof(buf)); | ||||
|       service = lookup_service((unsigned short)(port & 0xffff), | ||||
|                                flags, buf, sizeof(buf)); | ||||
|       callback(arg, ARES_SUCCESS, NULL, service); | ||||
|       return; | ||||
|     } | ||||
| @@ -151,7 +150,8 @@ void ares_getnameinfo(ares_channel channel, const struct sockaddr *sa, socklen_t | ||||
|           } | ||||
|         /* They also want a service */ | ||||
|         if (flags & ARES_NI_LOOKUPSERVICE) | ||||
|           service = lookup_service(port, flags, srvbuf, sizeof(srvbuf)); | ||||
|           service = lookup_service((unsigned short)(port & 0xffff), | ||||
|                                    flags, srvbuf, sizeof(srvbuf)); | ||||
|         callback(arg, ARES_SUCCESS, ipbuf, service); | ||||
|         return; | ||||
|       } | ||||
| @@ -220,7 +220,8 @@ static void nameinfo_callback(void *arg, int status, struct hostent *host) | ||||
|                  *end = 0; | ||||
|              } | ||||
|         } | ||||
|       niquery->callback(niquery->arg, ARES_SUCCESS, host->h_name, service); | ||||
|       niquery->callback(niquery->arg, ARES_SUCCESS, (char *)(host->h_name), | ||||
|                         service); | ||||
|       return; | ||||
|     } | ||||
|   /* We couldn't find the host, but it's OK, we can use the IP */ | ||||
| @@ -302,7 +303,7 @@ static char *lookup_service(unsigned short port, int flags, | ||||
|         strcpy(tmpbuf, sep->s_name); | ||||
|       else | ||||
|         /* get port as a string */ | ||||
|         sprintf(tmpbuf, "%u", ntohs(port)); | ||||
|         sprintf(tmpbuf, "%u", (unsigned int)ntohs(port)); | ||||
|       if (strlen(tmpbuf) < buflen) | ||||
|         /* return it if buffer big enough */ | ||||
|         strcpy(buf, tmpbuf); | ||||
| @@ -319,6 +320,9 @@ static char *lookup_service(unsigned short port, int flags, | ||||
| static void append_scopeid(struct sockaddr_in6 *addr6, unsigned int flags, | ||||
|                            char *buf, size_t buflen) | ||||
| { | ||||
| #ifdef HAVE_IF_INDEXTONAME | ||||
|   int is_ll, is_mcll; | ||||
| #endif | ||||
|   char fmt_u[] = "%u"; | ||||
|   char fmt_lu[] = "%lu"; | ||||
|   char tmpbuf[IF_NAMESIZE + 2]; | ||||
| @@ -328,9 +332,10 @@ static void append_scopeid(struct sockaddr_in6 *addr6, unsigned int flags, | ||||
|   tmpbuf[0] = '%'; | ||||
|  | ||||
| #ifdef HAVE_IF_INDEXTONAME | ||||
|   is_ll = IN6_IS_ADDR_LINKLOCAL(&addr6->sin6_addr); | ||||
|   is_mcll = IN6_IS_ADDR_MC_LINKLOCAL(&addr6->sin6_addr); | ||||
|   if ((flags & ARES_NI_NUMERICSCOPE) || | ||||
|       (!IN6_IS_ADDR_LINKLOCAL(&addr6->sin6_addr) | ||||
|        && !IN6_IS_ADDR_MC_LINKLOCAL(&addr6->sin6_addr))) | ||||
|       (!is_ll && !is_mcll)) | ||||
|     { | ||||
|        sprintf(&tmpbuf[1], fmt, addr6->sin6_scope_id); | ||||
|     } | ||||
| @@ -356,6 +361,7 @@ static void append_scopeid(struct sockaddr_in6 *addr6, unsigned int flags, | ||||
| static char *ares_striendstr(const char *s1, const char *s2) | ||||
| { | ||||
|   const char *c1, *c2, *c1_begin; | ||||
|   int lo1, lo2; | ||||
|   size_t s1_len = strlen(s1), s2_len = strlen(s2); | ||||
|  | ||||
|   /* If the substr is longer than the full str, it can't match */ | ||||
| @@ -368,7 +374,9 @@ static char *ares_striendstr(const char *s1, const char *s2) | ||||
|   c2 = s2; | ||||
|   while (c2 < s2+s2_len) | ||||
|     { | ||||
|       if (tolower(*c1) != tolower(*c2)) | ||||
|       lo1 = tolower(*c1); | ||||
|       lo2 = tolower(*c2); | ||||
|       if (lo1 != lo2) | ||||
|         return NULL; | ||||
|       else | ||||
|         { | ||||
|   | ||||
							
								
								
									
										123
									
								
								ares/ares_getopt.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										123
									
								
								ares/ares_getopt.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,123 @@ | ||||
| /* | ||||
|  * Original file name getopt.c  Initial import into the c-ares source tree | ||||
|  * on 2007-04-11.  Lifted from version 5.2 of the 'Open Mash' project with | ||||
|  * the modified BSD license, BSD license without the advertising clause. | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * getopt.c -- | ||||
|  * | ||||
|  *      Standard UNIX getopt function.  Code is from BSD. | ||||
|  * | ||||
|  * Copyright (c) 1987-2001 The Regents of the University of California. | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * A. Redistributions of source code must retain the above copyright notice, | ||||
|  *    this list of conditions and the following disclaimer. | ||||
|  * B. 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. | ||||
|  * C. Neither the names of the copyright holders 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 REGENTS 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. | ||||
|  */ | ||||
|  | ||||
| /* #if !defined(lint) | ||||
|  * static char sccsid[] = "@(#)getopt.c 8.2 (Berkeley) 4/2/94"; | ||||
|  * #endif | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "ares_getopt.h" | ||||
|  | ||||
| int   opterr = 1,     /* if error message should be printed */ | ||||
|       optind = 1,     /* index into parent argv vector */ | ||||
|       optopt,         /* character checked for validity */ | ||||
|       optreset;       /* reset getopt */ | ||||
| char  *optarg;        /* argument associated with option */ | ||||
|  | ||||
| #define  BADCH   (int)'?' | ||||
| #define  BADARG  (int)':' | ||||
| #define  EMSG    (char *)"" | ||||
|  | ||||
| /* | ||||
|  * ares_getopt -- | ||||
|  *    Parse argc/argv argument vector. | ||||
|  */ | ||||
| int | ||||
| ares_getopt(int nargc, char * const nargv[], const char *ostr) | ||||
| { | ||||
|     static char *place = EMSG;                /* option letter processing */ | ||||
|     char *oli;                                /* option letter list index */ | ||||
|  | ||||
|     if (optreset || !*place) {                /* update scanning pointer */ | ||||
|         optreset = 0; | ||||
|         if (optind >= nargc || *(place = nargv[optind]) != '-') { | ||||
|             place = EMSG; | ||||
|             return (EOF); | ||||
|         } | ||||
|         if (place[1] && *++place == '-') {    /* found "--" */ | ||||
|             ++optind; | ||||
|             place = EMSG; | ||||
|             return (EOF); | ||||
|         } | ||||
|     }                                         /* option letter okay? */ | ||||
|     if ((optopt = (int)*place++) == (int)':' || | ||||
|         !(oli = strchr(ostr, optopt))) { | ||||
|         /* | ||||
|          * if the user didn't specify '-' as an option, | ||||
|          * assume it means EOF. | ||||
|          */ | ||||
|         if (optopt == (int)'-') | ||||
|             return (EOF); | ||||
|         if (!*place) | ||||
|             ++optind; | ||||
|         if (opterr && *ostr != ':') | ||||
|             (void)fprintf(stderr, | ||||
|                 "%s: illegal option -- %c\n", __FILE__, optopt); | ||||
|         return (BADCH); | ||||
|     } | ||||
|     if (*++oli != ':') {                      /* don't need argument */ | ||||
|         optarg = NULL; | ||||
|         if (!*place) | ||||
|             ++optind; | ||||
|     } | ||||
|     else {                                    /* need an argument */ | ||||
|         if (*place)                           /* no white space */ | ||||
|             optarg = place; | ||||
|         else if (nargc <= ++optind) {         /* no arg */ | ||||
|             place = EMSG; | ||||
|             if (*ostr == ':') | ||||
|                 return (BADARG); | ||||
|             if (opterr) | ||||
|                 (void)fprintf(stderr, | ||||
|                     "%s: option requires an argument -- %c\n", | ||||
|                     __FILE__, optopt); | ||||
|             return (BADCH); | ||||
|         } | ||||
|          else                                 /* white space */ | ||||
|             optarg = nargv[optind]; | ||||
|         place = EMSG; | ||||
|         ++optind; | ||||
|     } | ||||
|     return (optopt);                          /* dump back option letter */ | ||||
| } | ||||
							
								
								
									
										41
									
								
								ares/ares_getopt.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								ares/ares_getopt.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| #ifndef ARES_GETOPT_H | ||||
| #define ARES_GETOPT_H | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 1987-2001 The Regents of the University of California. | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * A. Redistributions of source code must retain the above copyright notice, | ||||
|  *    this list of conditions and the following disclaimer. | ||||
|  * B. 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. | ||||
|  * C. Neither the names of the copyright holders 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 REGENTS 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. | ||||
|  */ | ||||
|  | ||||
|  | ||||
| int ares_getopt(int nargc, char * const nargv[], const char *ostr); | ||||
|  | ||||
| extern char *optarg; | ||||
| extern int optind; | ||||
| extern int opterr; | ||||
|  | ||||
|  | ||||
| #endif /* ARES_GETOPT_H */ | ||||
| @@ -1,6 +1,6 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2005 - 2006, Daniel Stenberg | ||||
| /* Copyright (C) 2005 - 2007, Daniel Stenberg | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software and its | ||||
|  * documentation for any purpose and without fee is hereby granted, provided | ||||
| @@ -14,7 +14,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
|   | ||||
							
								
								
									
										347
									
								
								ares/ares_init.c
									
									
									
									
									
								
							
							
						
						
									
										347
									
								
								ares/ares_init.c
									
									
									
									
									
								
							| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -43,6 +42,9 @@ | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #ifdef HAVE_PROCESS_H | ||||
| #include <process.h>  /* Some have getpid() here */ | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| @@ -59,7 +61,7 @@ | ||||
| #undef WIN32  /* Redefined in MingW/MSVC headers */ | ||||
| #endif | ||||
|  | ||||
| static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
| static int init_by_options(ares_channel channel, const struct ares_options *options, | ||||
|                            int optmask); | ||||
| static int init_by_environment(ares_channel channel); | ||||
| static int init_by_resolv_conf(ares_channel channel); | ||||
| @@ -70,6 +72,8 @@ static int config_nameserver(struct server_state **servers, int *nservers, | ||||
| static int set_search(ares_channel channel, const char *str); | ||||
| static int set_options(ares_channel channel, const char *str); | ||||
| static const char *try_option(const char *p, const char *q, const char *opt); | ||||
| static void init_id_key(rc4_key* key,int key_data_len); | ||||
|  | ||||
| #ifndef WIN32 | ||||
| static int sortlist_alloc(struct apattern **sortlist, int *nsort, struct apattern *pat); | ||||
| static int ip_addr(const char *s, int len, struct in_addr *addr); | ||||
| @@ -82,6 +86,12 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
| static char *try_config(char *s, const char *opt); | ||||
| #endif | ||||
|  | ||||
| #define ARES_CONFIG_CHECK(x) (x->lookups && x->nsort > -1 && \ | ||||
|                              x->nservers > -1 && \ | ||||
|                              x->ndomains > -1 && \ | ||||
|                              x->ndots > -1 && x->timeout > -1 && \ | ||||
|                              x->tries > -1) | ||||
|  | ||||
| int ares_init(ares_channel *channelptr) | ||||
| { | ||||
|   return ares_init_options(channelptr, NULL, 0); | ||||
| @@ -91,9 +101,9 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
|                       int optmask) | ||||
| { | ||||
|   ares_channel channel; | ||||
|   int i, status; | ||||
|   int i; | ||||
|   int status = ARES_SUCCESS; | ||||
|   struct server_state *server; | ||||
|   struct timeval tv; | ||||
|  | ||||
| #ifdef CURLDEBUG | ||||
|   const char *env = getenv("CARES_MEMDEBUG"); | ||||
| @@ -106,8 +116,10 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
| #endif | ||||
|  | ||||
|   channel = malloc(sizeof(struct ares_channeldata)); | ||||
|   if (!channel) | ||||
|   if (!channel) { | ||||
|     *channelptr = NULL; | ||||
|     return ARES_ENOMEM; | ||||
|   } | ||||
|  | ||||
|   /* Set everything to distinguished values so we know they haven't | ||||
|    * been set yet. | ||||
| @@ -125,22 +137,42 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
|   channel->queries = NULL; | ||||
|   channel->domains = NULL; | ||||
|   channel->sortlist = NULL; | ||||
|   channel->servers = NULL; | ||||
|   channel->sock_state_cb = NULL; | ||||
|   channel->sock_state_cb_data = NULL; | ||||
|  | ||||
|   /* Initialize configuration by each of the four sources, from highest | ||||
|    * precedence to lowest. | ||||
|    */ | ||||
|  | ||||
|   if (status == ARES_SUCCESS) { | ||||
|   status = init_by_options(channel, options, optmask); | ||||
|   if (status == ARES_SUCCESS) | ||||
|     if (status != ARES_SUCCESS) | ||||
|       DEBUGF(fprintf(stderr, "Error: init_by_options failed: %s\n", | ||||
|                      ares_strerror(status))); | ||||
|   } | ||||
|   if (status == ARES_SUCCESS) { | ||||
|     status = init_by_environment(channel); | ||||
|   if (status == ARES_SUCCESS) | ||||
|     if (status != ARES_SUCCESS) | ||||
|       DEBUGF(fprintf(stderr, "Error: init_by_environment failed: %s\n", | ||||
|                      ares_strerror(status))); | ||||
|   } | ||||
|   if (status == ARES_SUCCESS) { | ||||
|     status = init_by_resolv_conf(channel); | ||||
|   if (status == ARES_SUCCESS) | ||||
|     if (status != ARES_SUCCESS) | ||||
|       DEBUGF(fprintf(stderr, "Error: init_by_resolv_conf failed: %s\n", | ||||
|                      ares_strerror(status))); | ||||
|   } | ||||
|   if (status == ARES_SUCCESS) { | ||||
|     status = init_by_defaults(channel); | ||||
|     if (status != ARES_SUCCESS) | ||||
|       DEBUGF(fprintf(stderr, "Error: init_by_defaults failed: %s\n", | ||||
|                      ares_strerror(status))); | ||||
|   } | ||||
|   if (status != ARES_SUCCESS) | ||||
|     { | ||||
|       /* Something failed; clean up memory we may have allocated. */ | ||||
|       if (channel->nservers != -1) | ||||
|       if (channel->servers) | ||||
|         free(channel->servers); | ||||
|       if (channel->domains) | ||||
|         { | ||||
| @@ -172,22 +204,85 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
|       server->qtail = NULL; | ||||
|     } | ||||
|  | ||||
|   /* Choose a somewhat random query ID.  The main point is to avoid | ||||
|    * collisions with stale queries.  An attacker trying to spoof a DNS | ||||
|    * answer also has to guess the query ID, but it's only a 16-bit | ||||
|    * field, so there's not much to be done about that. | ||||
|    */ | ||||
|   gettimeofday(&tv, NULL); | ||||
|   channel->next_id = (unsigned short) | ||||
|     (tv.tv_sec ^ tv.tv_usec ^ getpid()) & 0xffff; | ||||
|   init_id_key(&channel->id_key, ARES_ID_KEY_LEN); | ||||
|  | ||||
|   channel->next_id = ares__generate_new_id(&channel->id_key); | ||||
|   channel->queries = NULL; | ||||
|  | ||||
|   *channelptr = channel; | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|  | ||||
| static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
| /* Save options from initialized channel */ | ||||
| int ares_save_options(ares_channel channel, struct ares_options *options, | ||||
|                       int *optmask) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   /* Zero everything out */ | ||||
|   memset(options, 0, sizeof(struct ares_options)); | ||||
|  | ||||
|   if (!ARES_CONFIG_CHECK(channel)) | ||||
|     return ARES_ENODATA; | ||||
|  | ||||
|   (*optmask) = (ARES_OPT_FLAGS|ARES_OPT_TIMEOUT|ARES_OPT_TRIES|ARES_OPT_NDOTS| | ||||
|                 ARES_OPT_UDP_PORT|ARES_OPT_TCP_PORT|ARES_OPT_SOCK_STATE_CB| | ||||
|                 ARES_OPT_SERVERS|ARES_OPT_DOMAINS|ARES_OPT_LOOKUPS| | ||||
|                 ARES_OPT_SORTLIST); | ||||
|  | ||||
|   /* Copy easy stuff */ | ||||
|   options->flags   = channel->flags; | ||||
|   options->timeout = channel->timeout; | ||||
|   options->tries   = channel->tries; | ||||
|   options->ndots   = channel->ndots; | ||||
|   options->udp_port = channel->udp_port; | ||||
|   options->tcp_port = channel->tcp_port; | ||||
|   options->sock_state_cb     = channel->sock_state_cb; | ||||
|   options->sock_state_cb_data = channel->sock_state_cb_data; | ||||
|  | ||||
|   /* Copy servers */ | ||||
|   options->servers = | ||||
|     malloc(channel->nservers * sizeof(struct server_state)); | ||||
|   if (!options->servers && channel->nservers != 0) | ||||
|     return ARES_ENOMEM; | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
|     options->servers[i] = channel->servers[i].addr; | ||||
|   options->nservers = channel->nservers; | ||||
|  | ||||
|   /* copy domains */ | ||||
|   options->domains = malloc(channel->ndomains * sizeof(char *)); | ||||
|   if (!options->domains) | ||||
|     return ARES_ENOMEM; | ||||
|   for (i = 0; i < channel->ndomains; i++) | ||||
|   { | ||||
|     options->ndomains = i; | ||||
|     options->domains[i] = strdup(channel->domains[i]); | ||||
|     if (!options->domains[i]) | ||||
|       return ARES_ENOMEM; | ||||
|   } | ||||
|   options->ndomains = channel->ndomains; | ||||
|  | ||||
|   /* copy lookups */ | ||||
|   options->lookups = strdup(channel->lookups); | ||||
|   if (!options->lookups) | ||||
|     return ARES_ENOMEM; | ||||
|  | ||||
|   /* copy sortlist */ | ||||
|   options->sortlist = malloc(channel->nsort * sizeof(struct apattern)); | ||||
|   if (!options->sortlist) | ||||
|     return ARES_ENOMEM; | ||||
|   for (i = 0; i < channel->nsort; i++) | ||||
|   { | ||||
|     memcpy(&(options->sortlist[i]), &(channel->sortlist[i]), | ||||
|            sizeof(struct apattern)); | ||||
|   } | ||||
|   options->nsort = channel->nsort; | ||||
|  | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|  | ||||
| static int init_by_options(ares_channel channel, | ||||
|                            const struct ares_options *options, | ||||
|                            int optmask) | ||||
| { | ||||
|   int i; | ||||
| @@ -213,13 +308,17 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
|  | ||||
|   /* Copy the servers, if given. */ | ||||
|   if ((optmask & ARES_OPT_SERVERS) && channel->nservers == -1) | ||||
|     { | ||||
|       /* Avoid zero size allocations at any cost */ | ||||
|       if (options->nservers > 0) | ||||
|         { | ||||
|           channel->servers = | ||||
|             malloc(options->nservers * sizeof(struct server_state)); | ||||
|       if (!channel->servers && options->nservers != 0) | ||||
|           if (!channel->servers) | ||||
|             return ARES_ENOMEM; | ||||
|           for (i = 0; i < options->nservers; i++) | ||||
|             channel->servers[i].addr = options->servers[i]; | ||||
|         } | ||||
|       channel->nservers = options->nservers; | ||||
|     } | ||||
|  | ||||
| @@ -227,9 +326,12 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
|    * we can clean up in case of error. | ||||
|    */ | ||||
|   if ((optmask & ARES_OPT_DOMAINS) && channel->ndomains == -1) | ||||
|     { | ||||
|       /* Avoid zero size allocations at any cost */ | ||||
|       if (options->ndomains > 0) | ||||
|       { | ||||
|         channel->domains = malloc(options->ndomains * sizeof(char *)); | ||||
|       if (!channel->domains && options->ndomains != 0) | ||||
|         if (!channel->domains) | ||||
|           return ARES_ENOMEM; | ||||
|         for (i = 0; i < options->ndomains; i++) | ||||
|           { | ||||
| @@ -238,6 +340,7 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
|             if (!channel->domains[i]) | ||||
|               return ARES_ENOMEM; | ||||
|           } | ||||
|       } | ||||
|       channel->ndomains = options->ndomains; | ||||
|     } | ||||
|  | ||||
| @@ -249,6 +352,19 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
|         return ARES_ENOMEM; | ||||
|     } | ||||
|  | ||||
|   /* copy sortlist */ | ||||
|   if ((optmask & ARES_OPT_SORTLIST) && channel->nsort == -1) | ||||
|     { | ||||
|       channel->sortlist = malloc(options->nsort * sizeof(struct apattern)); | ||||
|       if (!channel->sortlist) | ||||
|         return ARES_ENOMEM; | ||||
|       for (i = 0; i < options->nsort; i++) | ||||
|         { | ||||
|           memcpy(&(channel->sortlist[i]), &(options->sortlist[i]), sizeof(struct apattern)); | ||||
|         } | ||||
|       channel->nsort = options->nsort; | ||||
|     } | ||||
|  | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|  | ||||
| @@ -522,6 +638,10 @@ DhcpNameServer | ||||
|  | ||||
|   if (status == ARES_SUCCESS) | ||||
|     status = ARES_EOF; | ||||
|   else | ||||
|     /* Catch the case when all the above checks fail (which happens when there | ||||
|        is no network card or the cable is unplugged) */ | ||||
|     status = ARES_EFILE; | ||||
|  | ||||
| #elif defined(__riscos__) | ||||
|  | ||||
| @@ -540,7 +660,7 @@ DhcpNameServer | ||||
|     do { | ||||
|       space = strchr(pos, ' '); | ||||
|       if (space) | ||||
|         *space = 0; | ||||
|         *space = '\0'; | ||||
|       status = config_nameserver(&servers, &nservers, pos); | ||||
|       if (status != ARES_SUCCESS) | ||||
|         break; | ||||
| @@ -576,17 +696,21 @@ DhcpNameServer | ||||
|     char *p; | ||||
|     FILE *fp; | ||||
|     int linesize; | ||||
|     int error; | ||||
|  | ||||
|     /* Don't read resolv.conf and friends if we don't have to */ | ||||
|     if (ARES_CONFIG_CHECK(channel)) | ||||
|         return ARES_SUCCESS; | ||||
|  | ||||
|     fp = fopen(PATH_RESOLV_CONF, "r"); | ||||
|     if (!fp) | ||||
|       return (errno == ENOENT) ? ARES_SUCCESS : ARES_EFILE; | ||||
|     if (fp) { | ||||
|       while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) | ||||
|       { | ||||
|       if ((p = try_config(line, "domain"))) | ||||
|         if ((p = try_config(line, "domain")) && channel->ndomains == -1) | ||||
|           status = config_domain(channel, p); | ||||
|         else if ((p = try_config(line, "lookup")) && !channel->lookups) | ||||
|           status = config_lookup(channel, p, "bind", "file"); | ||||
|       else if ((p = try_config(line, "search"))) | ||||
|         else if ((p = try_config(line, "search")) && channel->ndomains == -1) | ||||
|           status = set_search(channel, p); | ||||
|         else if ((p = try_config(line, "nameserver")) && channel->nservers == -1) | ||||
|           status = config_nameserver(&servers, &nservers, p); | ||||
| @@ -600,8 +724,23 @@ DhcpNameServer | ||||
|           break; | ||||
|       } | ||||
|       fclose(fp); | ||||
|     } | ||||
|     else { | ||||
|       error = ERRNO; | ||||
|       switch(error) { | ||||
|       case ENOENT: | ||||
|       case ESRCH: | ||||
|         status = ARES_EOF; | ||||
|         break; | ||||
|       default: | ||||
|         DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                        error, strerror(error))); | ||||
|         DEBUGF(fprintf(stderr, "Error opening file: %s\n", PATH_RESOLV_CONF)); | ||||
|         status = ARES_EFILE; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     if (!channel->lookups) { | ||||
|     if ((status == ARES_EOF) && (!channel->lookups)) { | ||||
|       /* Many systems (Solaris, Linux, BSD's) use nsswitch.conf */ | ||||
|       fp = fopen("/etc/nsswitch.conf", "r"); | ||||
|       if (fp) { | ||||
| @@ -612,9 +751,23 @@ DhcpNameServer | ||||
|         } | ||||
|         fclose(fp); | ||||
|       } | ||||
|       else { | ||||
|         error = ERRNO; | ||||
|         switch(error) { | ||||
|         case ENOENT: | ||||
|         case ESRCH: | ||||
|           status = ARES_EOF; | ||||
|           break; | ||||
|         default: | ||||
|           DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                          error, strerror(error))); | ||||
|           DEBUGF(fprintf(stderr, "Error opening file: %s\n", "/etc/nsswitch.conf")); | ||||
|           status = ARES_EFILE; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     if (!channel->lookups) { | ||||
|     if ((status == ARES_EOF) && (!channel->lookups)) { | ||||
|       /* Linux / GNU libc 2.x and possibly others have host.conf */ | ||||
|       fp = fopen("/etc/host.conf", "r"); | ||||
|       if (fp) { | ||||
| @@ -625,9 +778,23 @@ DhcpNameServer | ||||
|         } | ||||
|         fclose(fp); | ||||
|       } | ||||
|       else { | ||||
|         error = ERRNO; | ||||
|         switch(error) { | ||||
|         case ENOENT: | ||||
|         case ESRCH: | ||||
|           status = ARES_EOF; | ||||
|           break; | ||||
|         default: | ||||
|           DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                          error, strerror(error))); | ||||
|           DEBUGF(fprintf(stderr, "Error opening file: %s\n", "/etc/host.conf")); | ||||
|           status = ARES_EFILE; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     if (!channel->lookups) { | ||||
|     if ((status == ARES_EOF) && (!channel->lookups)) { | ||||
|       /* Tru64 uses /etc/svc.conf */ | ||||
|       fp = fopen("/etc/svc.conf", "r"); | ||||
|       if (fp) { | ||||
| @@ -638,6 +805,20 @@ DhcpNameServer | ||||
|         } | ||||
|         fclose(fp); | ||||
|       } | ||||
|       else { | ||||
|         error = ERRNO; | ||||
|         switch(error) { | ||||
|         case ENOENT: | ||||
|         case ESRCH: | ||||
|           status = ARES_EOF; | ||||
|           break; | ||||
|         default: | ||||
|           DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                          error, strerror(error))); | ||||
|           DEBUGF(fprintf(stderr, "Error opening file: %s\n", "/etc/svc.conf")); | ||||
|           status = ARES_EFILE; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     if(line) | ||||
| @@ -711,7 +892,6 @@ static int init_by_defaults(ares_channel channel) | ||||
|       if (gethostname(hostname, sizeof(hostname)) == -1 | ||||
|           || !strchr(hostname, '.')) | ||||
|         { | ||||
|           channel->domains = malloc(0); | ||||
|           channel->ndomains = 0; | ||||
|         } | ||||
|       else | ||||
| @@ -752,7 +932,7 @@ static int config_domain(ares_channel channel, char *str) | ||||
|   q = str; | ||||
|   while (*q && !ISSPACE(*q)) | ||||
|     q++; | ||||
|   *q = 0; | ||||
|   *q = '\0'; | ||||
|   return set_search(channel, str); | ||||
| } | ||||
|  | ||||
| @@ -779,7 +959,7 @@ static int config_lookup(ares_channel channel, const char *str, | ||||
|       while (*p && (ISSPACE(*p) || (*p == ','))) | ||||
|         p++; | ||||
|     } | ||||
|   *l = 0; | ||||
|   *l = '\0'; | ||||
|   channel->lookups = strdup(lookups); | ||||
|   return (channel->lookups) ? ARES_SUCCESS : ARES_ENOMEM; | ||||
| } | ||||
| @@ -806,7 +986,7 @@ static int config_nameserver(struct server_state **servers, int *nservers, | ||||
|  | ||||
|     if (*p) | ||||
|     { | ||||
|       *p = 0; | ||||
|       *p = '\0'; | ||||
|       more = 1; | ||||
|     } | ||||
|  | ||||
| @@ -864,7 +1044,7 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|       while (*q && *q != '/' && *q != ';' && !ISSPACE(*q)) | ||||
|         q++; | ||||
|       memcpy(ipbuf, str, (int)(q-str)); | ||||
|       ipbuf[(int)(q-str)] = 0; | ||||
|       ipbuf[(int)(q-str)] = '\0'; | ||||
|       /* Find the prefix */ | ||||
|       if (*q == '/') | ||||
|         { | ||||
| @@ -872,29 +1052,29 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|           while (*q && *q != ';' && !ISSPACE(*q)) | ||||
|             q++; | ||||
|           memcpy(ipbufpfx, str, (int)(q-str)); | ||||
|           ipbufpfx[(int)(q-str)] = 0; | ||||
|           ipbufpfx[(int)(q-str)] = '\0'; | ||||
|           str = str2; | ||||
|         } | ||||
|       else | ||||
|         ipbufpfx[0] = 0; | ||||
|         ipbufpfx[0] = '\0'; | ||||
|       /* Lets see if it is CIDR */ | ||||
|       /* First we'll try IPv6 */ | ||||
|       if ((bits = ares_inet_net_pton(AF_INET6, ipbufpfx ? ipbufpfx : ipbuf, | ||||
|       if ((bits = ares_inet_net_pton(AF_INET6, ipbufpfx[0] ? ipbufpfx : ipbuf, | ||||
|                                      &pat.addr.addr6, | ||||
|                                      sizeof(pat.addr.addr6))) > 0) | ||||
|         { | ||||
|           pat.type = PATTERN_CIDR; | ||||
|           pat.mask.bits = bits; | ||||
|           pat.mask.bits = (unsigned short)bits; | ||||
|           pat.family = AF_INET6; | ||||
|           if (!sortlist_alloc(sortlist, nsort, &pat)) | ||||
|             return ARES_ENOMEM; | ||||
|         } | ||||
|       if (ipbufpfx && | ||||
|       if (ipbufpfx[0] && | ||||
|           (bits = ares_inet_net_pton(AF_INET, ipbufpfx, &pat.addr.addr4, | ||||
|                                      sizeof(pat.addr.addr4))) > 0) | ||||
|         { | ||||
|           pat.type = PATTERN_CIDR; | ||||
|           pat.mask.bits = bits; | ||||
|           pat.mask.bits = (unsigned short)bits; | ||||
|           pat.family = AF_INET; | ||||
|           if (!sortlist_alloc(sortlist, nsort, &pat)) | ||||
|             return ARES_ENOMEM; | ||||
| @@ -902,10 +1082,10 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|       /* See if it is just a regular IP */ | ||||
|       else if (ip_addr(ipbuf, (int)(q-str), &pat.addr.addr4) == 0) | ||||
|         { | ||||
|           if (ipbufpfx) | ||||
|           if (ipbufpfx[0]) | ||||
|             { | ||||
|               memcpy(ipbuf, str, (int)(q-str)); | ||||
|               ipbuf[(int)(q-str)] = 0; | ||||
|               ipbuf[(int)(q-str)] = '\0'; | ||||
|               if (ip_addr(ipbuf, (int)(q - str), &pat.mask.addr.addr4) != 0) | ||||
|                 natural_mask(&pat); | ||||
|             } | ||||
| @@ -940,6 +1120,7 @@ static int set_search(ares_channel channel, const char *str) | ||||
|     for(n=0; n < channel->ndomains; n++) | ||||
|       free(channel->domains[n]); | ||||
|     free(channel->domains); | ||||
|     channel->domains = NULL; | ||||
|     channel->ndomains = -1; | ||||
|   } | ||||
|  | ||||
| @@ -955,8 +1136,14 @@ static int set_search(ares_channel channel, const char *str) | ||||
|       n++; | ||||
|     } | ||||
|  | ||||
|   if (!n) | ||||
|     { | ||||
|       channel->ndomains = 0; | ||||
|       return ARES_SUCCESS; | ||||
|     } | ||||
|  | ||||
|   channel->domains = malloc(n * sizeof(char *)); | ||||
|   if (!channel->domains && n) | ||||
|   if (!channel->domains) | ||||
|     return ARES_ENOMEM; | ||||
|  | ||||
|   /* Now copy the domains. */ | ||||
| @@ -1079,3 +1266,79 @@ static void natural_mask(struct apattern *pat) | ||||
|     pat->mask.addr.addr4.s_addr = htonl(IN_CLASSC_NET); | ||||
| } | ||||
| #endif | ||||
| /* initialize an rc4 key. If possible a cryptographically secure random key | ||||
|    is generated using a suitable function (for example win32's RtlGenRandom as | ||||
|    described in | ||||
|    http://blogs.msdn.com/michael_howard/archive/2005/01/14/353379.aspx | ||||
|    otherwise the code defaults to cross-platform albeit less secure mechanism | ||||
|    using rand | ||||
| */ | ||||
| static void randomize_key(unsigned char* key,int key_data_len) | ||||
| { | ||||
|   int randomized = 0; | ||||
|   int counter=0; | ||||
| #ifdef WIN32 | ||||
|   HMODULE lib=LoadLibrary("ADVAPI32.DLL"); | ||||
|   if (lib) { | ||||
|     BOOLEAN (APIENTRY *pfn)(void*, ULONG) = | ||||
|       (BOOLEAN (APIENTRY *)(void*,ULONG))GetProcAddress(lib,"SystemFunction036"); | ||||
|     if (pfn && pfn(key,key_data_len) ) | ||||
|       randomized = 1; | ||||
|  | ||||
|     FreeLibrary(lib); | ||||
|   } | ||||
| #else /* !WIN32 */ | ||||
| #ifdef RANDOM_FILE | ||||
|   char buffer[256]; | ||||
|   FILE *f = fopen(RANDOM_FILE, "rb"); | ||||
|   if(f) { | ||||
|     size_t i; | ||||
|     size_t rc = fread(buffer, key_data_len, 1, f); | ||||
|     for(i=0; i<rc && counter < key_data_len; i++) | ||||
|       key[counter++]=buffer[i]; | ||||
|     fclose(f); | ||||
|   } | ||||
| #endif | ||||
| #endif /* WIN32 */ | ||||
|  | ||||
|   if ( !randomized ) { | ||||
|     for (;counter<key_data_len;counter++) | ||||
|       key[counter]=rand() % 256; | ||||
|   } | ||||
| } | ||||
|  | ||||
| static void init_id_key(rc4_key* key,int key_data_len) | ||||
| { | ||||
|   unsigned char index1; | ||||
|   unsigned char index2; | ||||
|   unsigned char* state; | ||||
|   short counter; | ||||
|   unsigned char *key_data_ptr = 0; | ||||
|  | ||||
|   key_data_ptr = calloc(1,key_data_len); | ||||
|   randomize_key(key->state,key_data_len); | ||||
|   state = &key->state[0]; | ||||
|   for(counter = 0; counter < 256; counter++) | ||||
|         state[counter] = counter; | ||||
|   key->x = 0; | ||||
|   key->y = 0; | ||||
|   index1 = 0; | ||||
|   index2 = 0; | ||||
|   for(counter = 0; counter < 256; counter++) | ||||
|   { | ||||
|     index2 = (key_data_ptr[index1] + state[counter] + | ||||
|               index2) % 256; | ||||
|     ARES_SWAP_BYTE(&state[counter], &state[index2]); | ||||
|  | ||||
|     index1 = (index1 + 1) % key_data_len; | ||||
|   } | ||||
|   free(key_data_ptr); | ||||
|  | ||||
| } | ||||
|  | ||||
| short ares__generate_new_id(rc4_key* key) | ||||
| { | ||||
|   short r; | ||||
|   ares__rc4(key, (unsigned char *)&r, sizeof(r)); | ||||
|   return r; | ||||
| } | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -115,7 +114,12 @@ int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id, | ||||
|   memset(q, 0, HFIXEDSZ); | ||||
|   DNS_HEADER_SET_QID(q, id); | ||||
|   DNS_HEADER_SET_OPCODE(q, QUERY); | ||||
|   DNS_HEADER_SET_RD(q, (rd) ? 1 : 0); | ||||
|   if (rd) { | ||||
|     DNS_HEADER_SET_RD(q, 1); | ||||
|   } | ||||
|   else { | ||||
|     DNS_HEADER_SET_RD(q, 0); | ||||
|   } | ||||
|   DNS_HEADER_SET_QDCOUNT(q, 1); | ||||
|  | ||||
|   /* A name of "." is a screw case for the loop below, so adjust it. */ | ||||
| @@ -141,7 +145,7 @@ int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id, | ||||
|         return ARES_EBADNAME; | ||||
|  | ||||
|       /* Encode the length and copy the data. */ | ||||
|       *q++ = len; | ||||
|       *q++ = (unsigned char)len; | ||||
|       for (p = name; *p && *p != '.'; p++) | ||||
|         { | ||||
|           if (*p == '\\' && *(p + 1) != 0) | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
|   | ||||
							
								
								
									
										66
									
								
								ares/ares_parse_ns_reply.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								ares/ares_parse_ns_reply.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| .\" | ||||
| .\" Copyright 1998 by the Massachusetts Institute of Technology. | ||||
| .\" | ||||
| .\" Permission to use, copy, modify, and distribute this | ||||
| .\" software and its documentation for any purpose and without | ||||
| .\" fee is hereby granted, provided that the above copyright | ||||
| .\" notice appear in all copies and that both that copyright | ||||
| .\" notice and this permission notice appear in supporting | ||||
| .\" documentation, and that the name of M.I.T. not be used in | ||||
| .\" advertising or publicity pertaining to distribution of the | ||||
| .\" software without specific, written prior permission. | ||||
| .\" M.I.T. makes no representations about the suitability of | ||||
| .\" this software for any purpose.  It is provided "as is" | ||||
| .\" without express or implied warranty. | ||||
| .\" | ||||
| .TH ARES_PARSE_NS_REPLY 3 "10 February 2007" | ||||
| .SH NAME | ||||
| ares_parse_ns_reply \- Parse a reply to a DNS query of type NS into a hostent | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <ares.h> | ||||
| .PP | ||||
| .B int ares_parse_ns_reply(const unsigned char *\fIabuf\fP, int \fIalen\fP, | ||||
| .B 	struct hostent **\fIhost\fP); | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_parse_ns_reply | ||||
| function parses the response to a query of type NS into a | ||||
| .BR "struct hostent" . | ||||
| The parameters | ||||
| .I abuf | ||||
| and | ||||
| .I alen | ||||
| give the contents of the response.  The result is stored in allocated | ||||
| memory and a pointer to it stored into the variable pointed to by | ||||
| .IR host .  | ||||
| The nameservers are stored into the  | ||||
| .BR aliases  | ||||
| field of the  | ||||
| .IR host  | ||||
| structure.  | ||||
| It is the caller's responsibility to free the resulting host structure | ||||
| using | ||||
| .BR ares_free_hostent (3) | ||||
| when it is no longer needed. | ||||
| .SH RETURN VALUES | ||||
| .B ares_parse_ns_reply | ||||
| can return any of the following values: | ||||
| .TP 15 | ||||
| .B ARES_SUCCESS | ||||
| The response was successfully parsed. | ||||
| .TP 15 | ||||
| .B ARES_EBADRESP | ||||
| The response was malformatted. | ||||
| .TP 15 | ||||
| .B ARES_ENODATA | ||||
| The response did not contain an answer to the query. | ||||
| .TP 15 | ||||
| .B ARES_ENOMEM | ||||
| Memory was exhausted. | ||||
| .SH SEE ALSO | ||||
| .BR ares_query (3), | ||||
| .BR ares_free_hostent (3) | ||||
| .SH AUTHOR | ||||
| Written by Vlad Dinulescu <vlad.dinulescu@avira.com>, on behalf of AVIRA Gmbh http://www.avira.com | ||||
							
								
								
									
										171
									
								
								ares/ares_parse_ns_reply.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										171
									
								
								ares/ares_parse_ns_reply.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,171 @@ | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
| * Permission to use, copy, modify, and distribute this | ||||
|  * software and its documentation for any purpose and without | ||||
| * fee is hereby granted, provided that the above copyright | ||||
|  * notice appear in all copies and that both that copyright | ||||
|  * notice and this permission notice appear in supporting | ||||
| * documentation, and that the name of M.I.T. not be used in | ||||
|  * advertising or publicity pertaining to distribution of the | ||||
| * software without specific, written prior permission. | ||||
|  * M.I.T. makes no representations about the suitability of | ||||
|  * this software for any purpose.  It is provided "as is" | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * ares_parse_ns_reply created by Vlad Dinulescu <vlad.dinulescu@avira.com> | ||||
|  *      on behalf of AVIRA Gmbh - http://www.avira.com | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "ares.h" | ||||
| #include "ares_dns.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| int ares_parse_ns_reply( const unsigned char* abuf, int alen, | ||||
|                          struct hostent** host ) | ||||
| { | ||||
|   unsigned int qdcount, ancount; | ||||
|   int status, i, rr_type, rr_class, rr_len; | ||||
|   int nameservers_num; | ||||
|   long len; | ||||
|   const unsigned char *aptr; | ||||
|   char* hostname, *rr_name, *rr_data, **nameservers; | ||||
|   struct hostent *hostent; | ||||
|  | ||||
|   /* Set *host to NULL for all failure cases. */ | ||||
|   *host = NULL; | ||||
|  | ||||
|   /* Give up if abuf doesn't have room for a header. */ | ||||
|   if ( alen < HFIXEDSZ ) | ||||
|     return ARES_EBADRESP; | ||||
|  | ||||
|   /* Fetch the question and answer count from the header. */ | ||||
|   qdcount = DNS_HEADER_QDCOUNT( abuf ); | ||||
|   ancount = DNS_HEADER_ANCOUNT( abuf ); | ||||
|   if ( qdcount != 1 ) | ||||
|     return ARES_EBADRESP; | ||||
|  | ||||
|   /* Expand the name from the question, and skip past the question. */ | ||||
|   aptr = abuf + HFIXEDSZ; | ||||
|   status = ares_expand_name( aptr, abuf, alen, &hostname, &len ); | ||||
|   if ( status != ARES_SUCCESS ) | ||||
|     return status; | ||||
|   if ( aptr + len + QFIXEDSZ > abuf + alen ) | ||||
|   { | ||||
|     free( hostname ); | ||||
|     return ARES_EBADRESP; | ||||
|   } | ||||
|   aptr += len + QFIXEDSZ; | ||||
|  | ||||
|   /* Allocate nameservers array; ancount gives an upper bound */ | ||||
|   nameservers = malloc( ( ancount + 1 ) * sizeof( char * ) ); | ||||
|   if ( !nameservers ) | ||||
|   { | ||||
|     free( hostname ); | ||||
|     return ARES_ENOMEM; | ||||
|   } | ||||
|   nameservers_num = 0; | ||||
|  | ||||
|   /* Examine each answer resource record (RR) in turn. */ | ||||
|   for ( i = 0; i < ( int ) ancount; i++ ) | ||||
|   { | ||||
|     /* Decode the RR up to the data field. */ | ||||
|     status = ares_expand_name( aptr, abuf, alen, &rr_name, &len ); | ||||
|     if ( status != ARES_SUCCESS ) | ||||
|       break; | ||||
|     aptr += len; | ||||
|     if ( aptr + RRFIXEDSZ > abuf + alen ) | ||||
|     { | ||||
|       status = ARES_EBADRESP; | ||||
|       break; | ||||
|     } | ||||
|     rr_type = DNS_RR_TYPE( aptr ); | ||||
|     rr_class = DNS_RR_CLASS( aptr ); | ||||
|     rr_len = DNS_RR_LEN( aptr ); | ||||
|     aptr += RRFIXEDSZ; | ||||
|  | ||||
|     if ( rr_class == C_IN && rr_type == T_NS ) | ||||
|     { | ||||
|       /* Decode the RR data and add it to the nameservers list */ | ||||
|       status = ares_expand_name( aptr, abuf, alen, &rr_data, &len ); | ||||
|       if ( status != ARES_SUCCESS ) | ||||
|       { | ||||
|         break; | ||||
|       } | ||||
|  | ||||
|       nameservers[nameservers_num] = malloc(strlen(rr_data)+1); | ||||
|  | ||||
|       if (nameservers[nameservers_num]==NULL) | ||||
|       { | ||||
|         free(rr_name); | ||||
|         free(rr_data); | ||||
|         status=ARES_ENOMEM; | ||||
|         break; | ||||
|       } | ||||
|       strcpy(nameservers[nameservers_num],rr_data); | ||||
|       free(rr_data); | ||||
|  | ||||
|       nameservers_num++; | ||||
|     } | ||||
|  | ||||
|     free( rr_name ); | ||||
|  | ||||
|     aptr += rr_len; | ||||
|     if ( aptr > abuf + alen ) | ||||
|     { | ||||
|       status = ARES_EBADRESP; | ||||
|       break; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if ( status == ARES_SUCCESS && nameservers_num == 0 ) | ||||
|   { | ||||
|     status = ARES_ENODATA; | ||||
|   } | ||||
|   if ( status == ARES_SUCCESS ) | ||||
|   { | ||||
|     /* We got our answer.  Allocate memory to build the host entry. */ | ||||
|     nameservers[nameservers_num] = NULL; | ||||
|     hostent = malloc( sizeof( struct hostent ) ); | ||||
|     if ( hostent ) | ||||
|     { | ||||
|       hostent->h_addr_list = malloc( 1 * sizeof( char * ) ); | ||||
|       if ( hostent->h_addr_list ) | ||||
|       { | ||||
|         /* Fill in the hostent and return successfully. */ | ||||
|         hostent->h_name = hostname; | ||||
|         hostent->h_aliases = nameservers; | ||||
|         hostent->h_addrtype = AF_INET; | ||||
|         hostent->h_length = sizeof( struct in_addr ); | ||||
|         hostent->h_addr_list[0] = NULL; | ||||
|         *host = hostent; | ||||
|         return ARES_SUCCESS; | ||||
|       } | ||||
|       free( hostent ); | ||||
|     } | ||||
|     status = ARES_ENOMEM; | ||||
|   } | ||||
|   for ( i = 0; i < nameservers_num; i++ ) | ||||
|     free( nameservers[i] ); | ||||
|   free( nameservers ); | ||||
|   free( hostname ); | ||||
|   return status; | ||||
| } | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
|   | ||||
| @@ -80,6 +80,8 @@ | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #define ARES_ID_KEY_LEN 31 | ||||
|  | ||||
| #include "ares_ipv6.h" | ||||
|  | ||||
| struct send_request { | ||||
| @@ -156,6 +158,13 @@ struct apattern { | ||||
|   unsigned short type; | ||||
| }; | ||||
|  | ||||
| typedef struct rc4_key | ||||
| { | ||||
|   unsigned char state[256]; | ||||
|   unsigned char x; | ||||
|   unsigned char y; | ||||
| } rc4_key; | ||||
|  | ||||
| struct ares_channeldata { | ||||
|   /* Configuration data */ | ||||
|   int flags; | ||||
| @@ -176,6 +185,8 @@ struct ares_channeldata { | ||||
|  | ||||
|   /* ID to use for next query */ | ||||
|   unsigned short next_id; | ||||
|   /* key to use when generating new ids */ | ||||
|   rc4_key id_key; | ||||
|  | ||||
|   /* Active queries */ | ||||
|   struct query *queries; | ||||
| @@ -184,10 +195,15 @@ struct ares_channeldata { | ||||
|   void *sock_state_cb_data; | ||||
| }; | ||||
|  | ||||
| void ares__rc4(rc4_key* key,unsigned char *buffer_ptr, int buffer_len); | ||||
| void ares__send_query(ares_channel channel, struct query *query, time_t now); | ||||
| void ares__close_sockets(ares_channel channel, struct server_state *server); | ||||
| int ares__get_hostent(FILE *fp, int family, struct hostent **host); | ||||
| int ares__read_line(FILE *fp, char **buf, int *bufsize); | ||||
| short ares__generate_new_id(rc4_key* key); | ||||
|  | ||||
| #define ARES_SWAP_BYTE(a,b) \ | ||||
|   { unsigned char swapByte = *(a);  *(a) = *(b);  *(b) = swapByte; } | ||||
|  | ||||
| #define SOCK_STATE_CALLBACK(c, s, r, w)                                 \ | ||||
|   do {                                                                  \ | ||||
|   | ||||
| @@ -24,16 +24,16 @@ ares_process \- Process events for name resolution | ||||
| .B void ares_process(ares_channel \fIchannel\fP, fd_set *\fIread_fds\fP, | ||||
| .B	fd_set *\fIwrite_fds\fP) | ||||
| .fi | ||||
| .PP | ||||
| .B void ares_process_fd(ares_channel \fIchannel\fP, | ||||
| .B      ares_socket_t \fIread_fd\fP, | ||||
| .B	ares_socket_t \fIwrite_fd\fP) | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_process | ||||
| function handles input/output events and timeouts associated with | ||||
| queries pending on the name service channel identified by | ||||
| The \fBares_process(3)\fP function handles input/output events and timeouts | ||||
| associated with queries pending on the name service channel identified by | ||||
| .IR channel . | ||||
| The file descriptor sets pointed to by | ||||
| .I read_fds | ||||
| and | ||||
| .I write_fds | ||||
| The file descriptor sets pointed to by \fIread_fds\fP and \fIwrite_fds\fP | ||||
| should have file descriptors set in them according to whether the file | ||||
| descriptors specified by \fIares_fds(3)\fP are ready for reading and writing. | ||||
| (The easiest way to determine this information is to invoke | ||||
| @@ -44,6 +44,11 @@ The | ||||
| .B ares_process | ||||
| function will invoke callbacks for pending queries if they complete | ||||
| successfully or fail. | ||||
|  | ||||
| \fBares_process_fd(3)\fP works the same way but acts and operates only on the | ||||
| specific file descriptors (sockets) you pass in to the function. Use | ||||
| ARES_SOCKET_BAD for "no action". This function is of course provided to allow | ||||
| users of c-ares to void select() in their applications and within c-ares. | ||||
| .SS EXAMPLE | ||||
| The following code fragment waits for all pending queries on a channel | ||||
| to complete: | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -54,26 +53,17 @@ | ||||
| #include "ares_dns.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| #ifndef TRUE | ||||
| /* at least Solaris 7 does not have TRUE at this point */ | ||||
| #define TRUE 1 | ||||
| #endif | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
| #define GET_ERRNO()  WSAGetLastError() | ||||
| #else | ||||
| #define GET_ERRNO()  errno | ||||
| #endif | ||||
|  | ||||
| static int try_again(int errnum); | ||||
| static void write_tcp_data(ares_channel channel, fd_set *write_fds, | ||||
|                            time_t now); | ||||
| static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now); | ||||
|                            ares_socket_t write_fd, time_t now); | ||||
| static void read_tcp_data(ares_channel channel, fd_set *read_fds, | ||||
|                           ares_socket_t read_fd, time_t now); | ||||
| static void read_udp_packets(ares_channel channel, fd_set *read_fds, | ||||
|                              time_t now); | ||||
|                              ares_socket_t read_fd, time_t now); | ||||
| static void process_timeouts(ares_channel channel, time_t now); | ||||
| static void process_answer(ares_channel channel, unsigned char *abuf, | ||||
|                            int alen, int whichserver, int tcp, int now); | ||||
|                            int alen, int whichserver, int tcp, time_t now); | ||||
| static void handle_error(ares_channel channel, int whichserver, time_t now); | ||||
| static struct query *next_server(ares_channel channel, struct query *query, time_t now); | ||||
| static int open_tcp_socket(ares_channel channel, struct server_state *server); | ||||
| @@ -91,13 +81,31 @@ void ares_process(ares_channel channel, fd_set *read_fds, fd_set *write_fds) | ||||
|   time_t now; | ||||
|  | ||||
|   time(&now); | ||||
|   write_tcp_data(channel, write_fds, now); | ||||
|   read_tcp_data(channel, read_fds, now); | ||||
|   read_udp_packets(channel, read_fds, now); | ||||
|   write_tcp_data(channel, write_fds, ARES_SOCKET_BAD, now); | ||||
|   read_tcp_data(channel, read_fds, ARES_SOCKET_BAD, now); | ||||
|   read_udp_packets(channel, read_fds, ARES_SOCKET_BAD, now); | ||||
|   process_timeouts(channel, now); | ||||
| } | ||||
|  | ||||
| /* Return 1 if the specified errno describes a readiness error, or 0 | ||||
| /* Something interesting happened on the wire, or there was a timeout. | ||||
|  * See what's up and respond accordingly. | ||||
|  */ | ||||
| void ares_process_fd(ares_channel channel, | ||||
|                      ares_socket_t read_fd, /* use ARES_SOCKET_BAD or valid | ||||
|                                                file descriptors */ | ||||
|                      ares_socket_t write_fd) | ||||
| { | ||||
|   time_t now; | ||||
|  | ||||
|   time(&now); | ||||
|   write_tcp_data(channel, NULL, write_fd, now); | ||||
|   read_tcp_data(channel, NULL, read_fd, now); | ||||
|   read_udp_packets(channel, NULL, read_fd, now); | ||||
|   process_timeouts(channel, now); | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Return 1 if the specified error number describes a readiness error, or 0 | ||||
|  * otherwise. This is mostly for HP-UX, which could return EAGAIN or | ||||
|  * EWOULDBLOCK. See this man page | ||||
|  * | ||||
| @@ -125,7 +133,10 @@ static int try_again(int errnum) | ||||
| /* If any TCP sockets select true for writing, write out queued data | ||||
|  * we have for them. | ||||
|  */ | ||||
| static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
| static void write_tcp_data(ares_channel channel, | ||||
|                            fd_set *write_fds, | ||||
|                            ares_socket_t write_fd, | ||||
|                            time_t now) | ||||
| { | ||||
|   struct server_state *server; | ||||
|   struct send_request *sendreq; | ||||
| @@ -135,14 +146,27 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|   ssize_t wcount; | ||||
|   size_t n; | ||||
|  | ||||
|   if(!write_fds && (write_fd == ARES_SOCKET_BAD)) | ||||
|     /* no possible action */ | ||||
|     return; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
|     { | ||||
|       /* Make sure server has data to send and is selected in write_fds. */ | ||||
|       /* Make sure server has data to send and is selected in write_fds or | ||||
|          write_fd. */ | ||||
|       server = &channel->servers[i]; | ||||
|       if (!server->qhead || server->tcp_socket == ARES_SOCKET_BAD | ||||
|           || !FD_ISSET(server->tcp_socket, write_fds)) | ||||
|       if (!server->qhead || server->tcp_socket == ARES_SOCKET_BAD) | ||||
|         continue; | ||||
|  | ||||
|       if(write_fds) { | ||||
|         if(!FD_ISSET(server->tcp_socket, write_fds)) | ||||
|           continue; | ||||
|       } | ||||
|       else { | ||||
|         if(server->tcp_socket != write_fd) | ||||
|           continue; | ||||
|       } | ||||
|  | ||||
|       /* Count the number of send queue items. */ | ||||
|       n = 0; | ||||
|       for (sendreq = server->qhead; sendreq; sendreq = sendreq->next) | ||||
| @@ -164,7 +188,7 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|           free(vec); | ||||
|           if (wcount < 0) | ||||
|             { | ||||
|               if (!try_again(GET_ERRNO())) | ||||
|               if (!try_again(SOCKERRNO)) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
| @@ -200,7 +224,7 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|           scount = swrite(server->tcp_socket, sendreq->data, sendreq->len); | ||||
|           if (scount < 0) | ||||
|             { | ||||
|               if (!try_again(GET_ERRNO())) | ||||
|               if (!try_again(SOCKERRNO)) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
| @@ -229,20 +253,33 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|  * allocate a buffer if we finish reading the length word, and process | ||||
|  * a packet if we finish reading one. | ||||
|  */ | ||||
| static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
| static void read_tcp_data(ares_channel channel, fd_set *read_fds, | ||||
|                           ares_socket_t read_fd, time_t now) | ||||
| { | ||||
|   struct server_state *server; | ||||
|   int i; | ||||
|   ssize_t count; | ||||
|  | ||||
|   if(!read_fds && (read_fd == ARES_SOCKET_BAD)) | ||||
|     /* no possible action */ | ||||
|     return; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
|     { | ||||
|       /* Make sure the server has a socket and is selected in read_fds. */ | ||||
|       server = &channel->servers[i]; | ||||
|       if (server->tcp_socket == ARES_SOCKET_BAD || | ||||
|           !FD_ISSET(server->tcp_socket, read_fds)) | ||||
|       if (server->tcp_socket == ARES_SOCKET_BAD) | ||||
|         continue; | ||||
|  | ||||
|       if(read_fds) { | ||||
|         if(!FD_ISSET(server->tcp_socket, read_fds)) | ||||
|           continue; | ||||
|       } | ||||
|       else { | ||||
|         if(server->tcp_socket != read_fd) | ||||
|           continue; | ||||
|       } | ||||
|  | ||||
|       if (server->tcp_lenbuf_pos != 2) | ||||
|         { | ||||
|           /* We haven't yet read a length word, so read that (or | ||||
| @@ -253,7 +290,7 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
|                         2 - server->tcp_lenbuf_pos); | ||||
|           if (count <= 0) | ||||
|             { | ||||
|               if (!(count == -1 && try_again(GET_ERRNO()))) | ||||
|               if (!(count == -1 && try_again(SOCKERRNO))) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
| @@ -280,7 +317,7 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
|                         server->tcp_length - server->tcp_buffer_pos); | ||||
|           if (count <= 0) | ||||
|             { | ||||
|               if (!(count == -1 && try_again(GET_ERRNO()))) | ||||
|               if (!(count == -1 && try_again(SOCKERRNO))) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
| @@ -305,24 +342,36 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
|  | ||||
| /* If any UDP sockets select true for reading, process them. */ | ||||
| static void read_udp_packets(ares_channel channel, fd_set *read_fds, | ||||
|                              time_t now) | ||||
|                              ares_socket_t read_fd, time_t now) | ||||
| { | ||||
|   struct server_state *server; | ||||
|   int i; | ||||
|   ssize_t count; | ||||
|   unsigned char buf[PACKETSZ + 1]; | ||||
|  | ||||
|   if(!read_fds && (read_fd == ARES_SOCKET_BAD)) | ||||
|     /* no possible action */ | ||||
|     return; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
|     { | ||||
|       /* Make sure the server has a socket and is selected in read_fds. */ | ||||
|       server = &channel->servers[i]; | ||||
|  | ||||
|       if (server->udp_socket == ARES_SOCKET_BAD || | ||||
|           !FD_ISSET(server->udp_socket, read_fds)) | ||||
|       if (server->udp_socket == ARES_SOCKET_BAD) | ||||
|         continue; | ||||
|  | ||||
|       if(read_fds) { | ||||
|         if(!FD_ISSET(server->udp_socket, read_fds)) | ||||
|           continue; | ||||
|       } | ||||
|       else { | ||||
|         if(server->udp_socket != read_fd) | ||||
|           continue; | ||||
|       } | ||||
|  | ||||
|       count = sread(server->udp_socket, buf, sizeof(buf)); | ||||
|       if (count == -1 && try_again(GET_ERRNO())) | ||||
|       if (count == -1 && try_again(SOCKERRNO)) | ||||
|         continue; | ||||
|       else if (count <= 0) | ||||
|         handle_error(channel, i, now); | ||||
| @@ -349,7 +398,7 @@ static void process_timeouts(ares_channel channel, time_t now) | ||||
|  | ||||
| /* Handle an answer from a server. */ | ||||
| static void process_answer(ares_channel channel, unsigned char *abuf, | ||||
|                            int alen, int whichserver, int tcp, int now) | ||||
|                            int alen, int whichserver, int tcp, time_t now) | ||||
| { | ||||
|   int id, tc, rcode; | ||||
|   struct query *query; | ||||
| @@ -538,7 +587,7 @@ static int nonblock(ares_socket_t sockfd,    /* operate on this */ | ||||
|   int flags; | ||||
|  | ||||
|   flags = fcntl(sockfd, F_GETFL, 0); | ||||
|   if (TRUE == nonblock) | ||||
|   if (FALSE != nonblock) | ||||
|     return fcntl(sockfd, F_SETFL, flags | O_NONBLOCK); | ||||
|   else | ||||
|     return fcntl(sockfd, F_SETFL, flags & (~O_NONBLOCK)); | ||||
| @@ -557,8 +606,12 @@ static int nonblock(ares_socket_t sockfd,    /* operate on this */ | ||||
| #endif | ||||
|  | ||||
| #if defined(HAVE_IOCTLSOCKET) && (SETBLOCK == 0) | ||||
| #ifdef WATT32 | ||||
|   char flags; | ||||
| #else | ||||
|   /* Windows? */ | ||||
|   unsigned long flags; | ||||
| #endif | ||||
|   flags = nonblock; | ||||
|  | ||||
|   return ioctlsocket(sockfd, FIONBIO, &flags); | ||||
| @@ -609,9 +662,9 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | ||||
|   memset(&sockin, 0, sizeof(sockin)); | ||||
|   sockin.sin_family = AF_INET; | ||||
|   sockin.sin_addr = server->addr; | ||||
|   sockin.sin_port = channel->tcp_port; | ||||
|   sockin.sin_port = (unsigned short)(channel->tcp_port & 0xffff); | ||||
|   if (connect(s, (struct sockaddr *) &sockin, sizeof(sockin)) == -1) { | ||||
|     int err = GET_ERRNO(); | ||||
|     int err = SOCKERRNO; | ||||
|  | ||||
|     if (err != EINPROGRESS && err != EWOULDBLOCK) { | ||||
|       closesocket(s); | ||||
| @@ -642,7 +695,7 @@ static int open_udp_socket(ares_channel channel, struct server_state *server) | ||||
|   memset(&sockin, 0, sizeof(sockin)); | ||||
|   sockin.sin_family = AF_INET; | ||||
|   sockin.sin_addr = server->addr; | ||||
|   sockin.sin_port = channel->udp_port; | ||||
|   sockin.sin_port = (unsigned short)(channel->udp_port & 0xffff); | ||||
|   if (connect(s, (struct sockaddr *) &sockin, sizeof(sockin)) == -1) | ||||
|     { | ||||
|       closesocket(s); | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -40,6 +39,64 @@ struct qquery { | ||||
|  | ||||
| static void qcallback(void *arg, int status, unsigned char *abuf, int alen); | ||||
|  | ||||
| void ares__rc4(rc4_key* key, unsigned char *buffer_ptr, int buffer_len) | ||||
| { | ||||
|   unsigned char x; | ||||
|   unsigned char y; | ||||
|   unsigned char* state; | ||||
|   unsigned char xorIndex; | ||||
|   short counter; | ||||
|  | ||||
|   x = key->x; | ||||
|   y = key->y; | ||||
|  | ||||
|   state = &key->state[0]; | ||||
|   for(counter = 0; counter < buffer_len; counter ++) | ||||
|   { | ||||
| 	x = (x + 1) % 256; | ||||
| 	y = (state[x] + y) % 256; | ||||
| 	ARES_SWAP_BYTE(&state[x], &state[y]); | ||||
|  | ||||
| 	xorIndex = (state[x] + state[y]) % 256; | ||||
|  | ||||
| 	buffer_ptr[counter] ^= state[xorIndex]; | ||||
|   } | ||||
|   key->x = x; | ||||
|   key->y = y; | ||||
| } | ||||
|  | ||||
| static struct query* find_query_by_id(ares_channel channel, int id) | ||||
| { | ||||
|   int qid; | ||||
|   struct query* q; | ||||
|   DNS_HEADER_SET_QID(((unsigned char*)&qid), id); | ||||
|  | ||||
|   /* Find the query corresponding to this packet. */ | ||||
|   for (q = channel->queries; q; q = q->next) | ||||
|   { | ||||
| 	if (q->qid == qid) | ||||
| 	  return q; | ||||
|   } | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* a unique query id is generated using an rc4 key. Since the id may already | ||||
|    be used by a running query (as infrequent as it may be), a lookup is | ||||
|    performed per id generation. In practice this search should happen only | ||||
|    once per newly generated id | ||||
| */ | ||||
| static int generate_unique_id(ares_channel channel) | ||||
| { | ||||
|   int id; | ||||
|  | ||||
|   do { | ||||
| 	id = ares__generate_new_id(&channel->id_key); | ||||
|   } while (find_query_by_id(channel,id)); | ||||
|  | ||||
|   return id; | ||||
| } | ||||
|  | ||||
| void ares_query(ares_channel channel, const char *name, int dnsclass, | ||||
|                 int type, ares_callback callback, void *arg) | ||||
| { | ||||
| @@ -51,13 +108,14 @@ void ares_query(ares_channel channel, const char *name, int dnsclass, | ||||
|   rd = !(channel->flags & ARES_FLAG_NORECURSE); | ||||
|   status = ares_mkquery(name, dnsclass, type, channel->next_id, rd, &qbuf, | ||||
|                         &qlen); | ||||
|   channel->next_id++; | ||||
|   if (status != ARES_SUCCESS) | ||||
|     { | ||||
|       callback(arg, status, NULL, 0); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   channel->next_id = generate_unique_id(channel); | ||||
|  | ||||
|   /* Allocate and fill in the query structure. */ | ||||
|   qquery = malloc(sizeof(struct qquery)); | ||||
|   if (!qquery) | ||||
|   | ||||
							
								
								
									
										49
									
								
								ares/ares_save_options.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								ares/ares_save_options.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .\" Copyright 1998 by the Massachusetts Institute of Technology. | ||||
| .\" | ||||
| .\" Permission to use, copy, modify, and distribute this | ||||
| .\" software and its documentation for any purpose and without | ||||
| .\" fee is hereby granted, provided that the above copyright | ||||
| .\" notice appear in all copies and that both that copyright | ||||
| .\" notice and this permission notice appear in supporting | ||||
| .\" documentation, and that the name of M.I.T. not be used in | ||||
| .\" advertising or publicity pertaining to distribution of the | ||||
| .\" software without specific, written prior permission. | ||||
| .\" M.I.T. makes no representations about the suitability of | ||||
| .\" this software for any purpose.  It is provided "as is" | ||||
| .\" without express or implied warranty. | ||||
| .\" | ||||
| .TH ARES_SAVE_OPTIONS 3 "1 June 2007" | ||||
| .SH NAME | ||||
| ares_save_options \- Save configuration values obtained from initialized ares_channel | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <ares.h> | ||||
| .PP | ||||
| .B void ares_save_options(ares_channel \fIchannel\fP, struct ares_options *\fIoptions\fP, int *\fIoptmask\fP) | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_save_options | ||||
| function saves the channel data identified by | ||||
| .IR channel , | ||||
| into the options struct identified by | ||||
| .IR options , | ||||
| and saves the mask of options which are set to the integer | ||||
| pointer (passed by reference) identified by | ||||
| .IR optmask . | ||||
|  | ||||
| The resultant options and optmask are then able to be | ||||
| passed directly to ares_init_options.  When the options | ||||
| are no longer needed, ares_destroy_options should be called | ||||
| to free any associated memory. | ||||
|  | ||||
|  | ||||
| .SH SEE ALSO | ||||
| .BR ares_destroy_options (3), | ||||
| .BR ares_init_options (3) | ||||
| .SH AUTHOR | ||||
| Brad House | ||||
| .br | ||||
| Copyright 1998 by the Massachusetts Institute of Technology. | ||||
| @@ -20,6 +20,7 @@ | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -216,6 +217,7 @@ static int single_domain(ares_channel channel, const char *name, char **s) | ||||
|   char *line = NULL; | ||||
|   int linesize, status; | ||||
|   const char *p, *q; | ||||
|   int error; | ||||
|  | ||||
|   /* If the name contains a trailing dot, then the single query is the name | ||||
|    * sans the trailing dot. | ||||
| @@ -265,6 +267,23 @@ static int single_domain(ares_channel channel, const char *name, char **s) | ||||
|               if (status != ARES_SUCCESS) | ||||
|                 return status; | ||||
|             } | ||||
|           else  | ||||
|             { | ||||
|               error = ERRNO; | ||||
|               switch(error)  | ||||
|                 { | ||||
|                 case ENOENT: | ||||
|                 case ESRCH: | ||||
|                   break; | ||||
|                 default: | ||||
|                   DEBUGF(fprintf(stderr, "fopen() failed with error: %d %s\n", | ||||
|                                  error, strerror(error))); | ||||
|                   DEBUGF(fprintf(stderr, "Error opening file: %s\n",  | ||||
|                                  hostaliases)); | ||||
|                   *s = NULL; | ||||
|                   return ARES_EFILE; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| @@ -73,14 +72,14 @@ void ares_send(ares_channel channel, const unsigned char *qbuf, int qlen, | ||||
|     } | ||||
|  | ||||
|   /* Compute the query ID.  Start with no timeout. */ | ||||
|   query->qid = DNS_HEADER_QID(qbuf); | ||||
|   query->qid = (unsigned short)DNS_HEADER_QID(qbuf); | ||||
|   query->timeout = 0; | ||||
|  | ||||
|   /* Form the TCP query buffer by prepending qlen (as two | ||||
|    * network-order bytes) to qbuf. | ||||
|    */ | ||||
|   query->tcpbuf[0] = (qlen >> 8) & 0xff; | ||||
|   query->tcpbuf[1] = qlen & 0xff; | ||||
|   query->tcpbuf[0] = (unsigned char)((qlen >> 8) & 0xff); | ||||
|   query->tcpbuf[1] = (unsigned char)(qlen & 0xff); | ||||
|   memcpy(query->tcpbuf + 2, qbuf, qlen); | ||||
|   query->tcplen = qlen + 2; | ||||
|  | ||||
|   | ||||
| @@ -41,9 +41,11 @@ const char *ares_strerror(int code) | ||||
|     "Out of memory", | ||||
|     "Channel is being destroyed", | ||||
|     "Misformatted string", | ||||
|     "Illegal flags specified" | ||||
|     "Illegal flags specified", | ||||
|     "Given hostname is not numeric", | ||||
|     "Illegal hints flags specified" | ||||
|   }; | ||||
|  | ||||
|   assert(code >= 0 && code < (int)(sizeof(errtext) / sizeof(*errtext))); | ||||
|   DEBUGASSERT(code >= 0 && code < (int)(sizeof(errtext) / sizeof(*errtext))); | ||||
|   return errtext[code]; | ||||
| } | ||||
|   | ||||
| @@ -16,7 +16,6 @@ | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
| @@ -32,7 +31,8 @@ struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv, | ||||
| { | ||||
|   struct query *query; | ||||
|   time_t now; | ||||
|   int offset, min_offset; | ||||
|   time_t offset, min_offset; /* these use time_t since some 32 bit systems | ||||
|                                 still use 64 bit time_t! (like VS2005) */ | ||||
|  | ||||
|   /* No queries, no timeout (and no fetch of the current time). */ | ||||
|   if (!channel->queries) | ||||
| @@ -58,7 +58,7 @@ struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv, | ||||
|    */ | ||||
|   if (min_offset != -1 && (!maxtv || min_offset <= maxtv->tv_sec)) | ||||
|     { | ||||
|       tvbuf->tv_sec = min_offset; | ||||
|       tvbuf->tv_sec = (long)min_offset; | ||||
|       tvbuf->tv_usec = 0; | ||||
|       return tvbuf; | ||||
|     } | ||||
|   | ||||
| @@ -4,12 +4,12 @@ | ||||
| #define ARES__VERSION_H | ||||
|  | ||||
| #define ARES_VERSION_MAJOR 1 | ||||
| #define ARES_VERSION_MINOR 3 | ||||
| #define ARES_VERSION_MINOR 4 | ||||
| #define ARES_VERSION_PATCH 1 | ||||
| #define ARES_VERSION ((ARES_VERSION_MAJOR<<16)|\ | ||||
|                        (ARES_VERSION_MINOR<<8)|\ | ||||
|                        (ARES_VERSION_PATCH)) | ||||
| #define ARES_VERSION_STR "1.3.1" | ||||
| #define ARES_VERSION_STR "1.4.1-CVS" | ||||
|  | ||||
| #ifdef  __cplusplus | ||||
| extern "C" { | ||||
|   | ||||
| @@ -19,9 +19,7 @@ | ||||
|  | ||||
| #ifndef HAVE_BITNCMP | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include "setup.h" | ||||
| #include "bitncmp.h" | ||||
|  | ||||
| /* | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2004 - 2005 by Daniel Stenberg et al | ||||
| /* Copyright (C) 2004 - 2006 by Daniel Stenberg et al | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software and its | ||||
|  * documentation for any purpose and without fee is hereby granted, provided | ||||
| @@ -17,7 +17,7 @@ | ||||
|  */ | ||||
|  | ||||
| /* ================================================================ */ | ||||
| /*    ares/config-win32.h - Hand crafted config file for windows    */ | ||||
| /*    ares/config-win32.h - Hand crafted config file for Windows    */ | ||||
| /* ================================================================ */ | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| @@ -29,12 +29,18 @@ | ||||
| #define HAVE_GETOPT_H 1 | ||||
| #endif | ||||
|  | ||||
| /* Define if you have the <signal.h> header file. */ | ||||
| #define HAVE_SIGNAL_H 1 | ||||
|  | ||||
| /* Define if you have the <sys/time.h> header file */ | ||||
| /* #define HAVE_SYS_TIME_H 1 */ | ||||
|  | ||||
| /* Define if you have the <time.h> header file.  */ | ||||
| #define HAVE_TIME_H 1 | ||||
|  | ||||
| /* Define if you have the <process.h> header file.  */ | ||||
| #define HAVE_PROCESS_H 1 | ||||
|  | ||||
| /* Define if you have the <unistd.h> header file.  */ | ||||
| #if defined(__MINGW32__) || defined(__WATCOMC__) || defined(__LCC__) || \ | ||||
|     defined(__POCC__) | ||||
| @@ -57,6 +63,9 @@ | ||||
| /*                        OTHER HEADER INFO                         */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|  | ||||
| /* Define if sig_atomic_t is an available typedef. */ | ||||
| #define HAVE_SIG_ATOMIC_T 1 | ||||
|  | ||||
| /* Define if you have the ANSI C header files.  */ | ||||
| #define STDC_HEADERS 1 | ||||
|  | ||||
| @@ -70,24 +79,6 @@ | ||||
| /* Define if you have the ioctlsocket function.  */ | ||||
| #define HAVE_IOCTLSOCKET 1 | ||||
|  | ||||
| /* Define if you have the getnameinfo function. */ | ||||
| #define HAVE_GETNAMEINFO 1 | ||||
|  | ||||
| /* Define to the type qualifier of arg 1 for getnameinfo. */ | ||||
| #define GETNAMEINFO_QUAL_ARG1 const | ||||
|  | ||||
| /* Define to the type of arg 1 for getnameinfo. */ | ||||
| #define GETNAMEINFO_TYPE_ARG1 struct sockaddr * | ||||
|  | ||||
| /* Define to the type of arg 2 for getnameinfo. */ | ||||
| #define GETNAMEINFO_TYPE_ARG2 socklen_t | ||||
|  | ||||
| /* Define to the type of args 4 and 6 for getnameinfo. */ | ||||
| #define GETNAMEINFO_TYPE_ARG46 DWORD | ||||
|  | ||||
| /* Define to the type of arg 7 for getnameinfo. */ | ||||
| #define GETNAMEINFO_TYPE_ARG7 int | ||||
|  | ||||
| /* Define if you have the recv function. */ | ||||
| #define HAVE_RECV 1 | ||||
|  | ||||
| @@ -127,6 +118,39 @@ | ||||
| /* Define to the function return type for send. */ | ||||
| #define SEND_TYPE_RETV int | ||||
|  | ||||
| /* Specifics for the Watt-32 tcp/ip stack */ | ||||
| #ifdef WATT32 | ||||
|   #define SOCKET              int | ||||
|   #define NS_INADDRSZ         4 | ||||
|   #define HAVE_ARPA_NAMESER_H 1 | ||||
|   #undef HAVE_WINSOCK_H | ||||
|   #undef HAVE_WINSOCK2_H | ||||
|   #undef HAVE_WS2TCPIP_H | ||||
| #endif | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| /*                       TYPEDEF REPLACEMENTS                       */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|  | ||||
| /* Define this if in_addr_t is not an available 'typedefed' type */ | ||||
| #define in_addr_t unsigned long | ||||
|  | ||||
| /* Define as the return type of signal handlers (int or void).  */ | ||||
| #define RETSIGTYPE void | ||||
|  | ||||
| /* Define ssize_t if it is not an available 'typedefed' type */ | ||||
| #if (defined(__WATCOMC__) && (__WATCOMC__ >= 1240)) || defined(__POCC__) | ||||
| #elif defined(_WIN64) | ||||
| #define ssize_t __int64 | ||||
| #else | ||||
| #define ssize_t int | ||||
| #endif | ||||
|  | ||||
| /* Define to 'int' if socklen_t is not an available 'typedefed' type */ | ||||
| #ifndef HAVE_WS2TCPIP_H | ||||
| #define socklen_t int | ||||
| #endif | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| /*                          STRUCT RELATED                          */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|   | ||||
| @@ -7,6 +7,15 @@ AM_CONFIG_HEADER(config.h) | ||||
| AM_MAINTAINER_MODE | ||||
| AM_INIT_AUTOMAKE(c-ares, CVS) | ||||
|  | ||||
| dnl | ||||
| dnl Detect the canonical host and target build environment | ||||
| dnl | ||||
|  | ||||
| AC_CANONICAL_HOST | ||||
| dnl Get system canonical name | ||||
| AC_DEFINE_UNQUOTED(OS, "${host}", [cpu-machine-OS]) | ||||
|  | ||||
| AC_AIX | ||||
| AC_PROG_CC | ||||
| AC_PROG_INSTALL | ||||
|  | ||||
| @@ -16,6 +25,7 @@ solaris*) | ||||
| 	;; | ||||
| esac | ||||
|  | ||||
| dnl support building of Windows DLLs | ||||
| AC_LIBTOOL_WIN32_DLL | ||||
|  | ||||
| dnl ************************************************************ | ||||
| @@ -61,8 +71,31 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl skip libtool C++ and Fortran compiler checks | ||||
| m4_ifdef([AC_PROG_CXX], [m4_undefine([AC_PROG_CXX])]) | ||||
| m4_defun([AC_PROG_CXX],[]) | ||||
| m4_ifdef([AC_PROG_F77], [m4_undefine([AC_PROG_F77])]) | ||||
| m4_defun([AC_PROG_F77],[]) | ||||
|  | ||||
| dnl skip libtool C++ and Fortran linker checks | ||||
| m4_ifdef([AC_LIBTOOL_CXX], [m4_undefine([AC_LIBTOOL_CXX])]) | ||||
| m4_defun([AC_LIBTOOL_CXX],[]) | ||||
| m4_ifdef([AC_LIBTOOL_F77], [m4_undefine([AC_LIBTOOL_F77])]) | ||||
| m4_defun([AC_LIBTOOL_F77],[]) | ||||
|  | ||||
| dnl force libtool to build static libraries with PIC on AMD64-linux | ||||
| AC_MSG_CHECKING([if arch-OS host is AMD64-linux (to build static libraries with PIC)]) | ||||
| case $host in | ||||
|   x86_64*linux*) | ||||
|     AC_MSG_RESULT([yes]) | ||||
|     with_pic=yes | ||||
|     ;; | ||||
|   *) | ||||
|     AC_MSG_RESULT([no]) | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| dnl libtool setup | ||||
| CARES_CLEAR_LIBTOOL_TAGS | ||||
| AC_PROG_LIBTOOL | ||||
|  | ||||
| AC_MSG_CHECKING([if we need -no-undefined]) | ||||
| @@ -77,6 +110,13 @@ esac | ||||
| AC_MSG_RESULT($need_no_undefined) | ||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl check if this is the Intel ICC compiler, and if so make it stricter | ||||
| dnl (convert warning 147 into an error) so that it properly can detect the | ||||
| dnl gethostbyname_r() version | ||||
| dnl ********************************************************************** | ||||
| CURL_DETECT_ICC([CFLAGS="$CFLAGS -we 147"]) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Checks for libraries. | ||||
| dnl ********************************************************************** | ||||
| @@ -198,6 +238,77 @@ AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]), | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
|  | ||||
| dnl Default is to try the thread-safe versions of a few functions | ||||
| OPT_THREAD=on | ||||
|  | ||||
| dnl detect AIX 4.3 or later | ||||
| AC_MSG_CHECKING([AIX 4.3 or later]) | ||||
| AC_PREPROC_IFELSE([ | ||||
| #if defined(_AIX) && defined(_AIX43) | ||||
| printf("just fine"); | ||||
| #else | ||||
| #error "this is not AIX 4.3 or later" | ||||
| #endif | ||||
| ], | ||||
|  [ AC_MSG_RESULT([yes]) | ||||
|    RECENTAIX=yes | ||||
|    OPT_THREAD=off ], | ||||
|  [ AC_MSG_RESULT([no]) ] | ||||
| ) | ||||
|  | ||||
| AC_ARG_ENABLE(thread,dnl | ||||
| AC_HELP_STRING([--disable-thread],[don't look for thread-safe functions]) | ||||
| AC_HELP_STRING([--enable-thread],[look for thread-safe functions]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|     OPT_THREAD=off | ||||
|     AC_MSG_WARN(c-ares will not get built using thread-safe functions) | ||||
|     ;; | ||||
|   *) | ||||
|     ;; | ||||
|   esac | ||||
| ] | ||||
| ) | ||||
|  | ||||
| if test X"$OPT_THREAD" = Xoff | ||||
| then | ||||
|   AC_DEFINE(DISABLED_THREADSAFE, 1, | ||||
|     [Set to explicitly specify we don't want to use thread-safe functions]) | ||||
| fi | ||||
|  | ||||
| dnl for recent AIX versions, we skip all the thread-safe checks above since | ||||
| dnl they claim a thread-safe libc using the standard API. But there are | ||||
| dnl some functions still not thread-safe. Check for these! | ||||
|  | ||||
| dnl Let's hope this split URL remains working: | ||||
| dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \ | ||||
| dnl genprogc/thread_quick_ref.htm | ||||
|  | ||||
| if test "x$RECENTAIX" = "xyes"; then | ||||
|  | ||||
|   AC_DEFINE(_THREAD_SAFE, 1, [define this if you need it to compile thread-safe code]) | ||||
|  | ||||
|   dnl check if this is the IBM xlc compiler | ||||
|   dnl Details thanks to => http://predef.sourceforge.net/ | ||||
|   AC_MSG_CHECKING([if this is the xlc compiler]) | ||||
|   AC_EGREP_CPP([^__xlC__], [__xlC__], | ||||
|          dnl action if the text is found, this it has not been replaced by the | ||||
|          dnl cpp | ||||
|          XLC="no" | ||||
|          AC_MSG_RESULT([no]), | ||||
|          dnl the text was not found, it was replaced by the cpp | ||||
|          XLC="yes" | ||||
|          AC_MSG_RESULT([yes]) | ||||
|          CFLAGS="$CFLAGS -qthreaded" | ||||
|          dnl AIX xlc has to have strict aliasing turned off. If not, | ||||
|          dnl the optimizer assumes that pointers can only point to | ||||
|          dnl an object of the same type. | ||||
|          CFLAGS="$CFLAGS -qnoansialias" | ||||
|        ) | ||||
| fi | ||||
|  | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Back to "normal" configuring | ||||
| dnl ********************************************************************** | ||||
| @@ -229,6 +340,8 @@ AC_CHECK_HEADERS( | ||||
|        netdb.h \ | ||||
|        netinet/in.h \ | ||||
|        net/if.h \ | ||||
|        errno.h \ | ||||
|        stdbool.h \ | ||||
|        arpa/nameser.h \ | ||||
|        arpa/nameser_compat.h \ | ||||
|        arpa/inet.h, | ||||
| @@ -290,6 +403,19 @@ fi | ||||
| AC_CHECK_TYPE(ssize_t, , | ||||
|    AC_DEFINE(ssize_t, int, [the signed version of size_t])) | ||||
|  | ||||
| # check for bool type | ||||
| AC_CHECK_TYPE([bool],[ | ||||
|   AC_DEFINE(HAVE_BOOL_T, 1, | ||||
|     [Define to 1 if bool is an available type.]) | ||||
| ], ,[ | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_STDBOOL_H | ||||
| #include <stdbool.h> | ||||
| #endif | ||||
| ]) | ||||
|  | ||||
| # Check for socklen_t or equivalent | ||||
| CURL_CHECK_TYPE_SOCKLEN_T | ||||
|  | ||||
| @@ -297,6 +423,10 @@ TYPE_IN_ADDR_T | ||||
|  | ||||
| TYPE_SOCKADDR_STORAGE | ||||
|  | ||||
| TYPE_SIG_ATOMIC_T | ||||
|  | ||||
| AC_TYPE_SIGNAL | ||||
|  | ||||
| CURL_CHECK_FUNC_RECV | ||||
|  | ||||
| CURL_CHECK_FUNC_SEND | ||||
| @@ -655,4 +785,20 @@ AC_C_BIGENDIAN( | ||||
|     [AC_MSG_WARN([couldn't figure out endianess, assuming little endian!])] | ||||
| ) | ||||
|  | ||||
| dnl Check for user-specified random device | ||||
| AC_ARG_WITH(random, | ||||
| AC_HELP_STRING([--with-random=FILE], | ||||
|                [read randomness from FILE (default=/dev/urandom)]), | ||||
|     [ RANDOM_FILE="$withval" ], | ||||
|     [ | ||||
|         dnl Check for random device | ||||
|         AC_CHECK_FILE("/dev/urandom", [ RANDOM_FILE="/dev/urandom"] ) | ||||
|     ] | ||||
| ) | ||||
| if test -n "$RANDOM_FILE" && test X"$RANDOM_FILE" != Xno ; then | ||||
|         AC_SUBST(RANDOM_FILE) | ||||
|         AC_DEFINE_UNQUOTED(RANDOM_FILE, "$RANDOM_FILE", | ||||
|         [a suitable file/device to read random data from]) | ||||
| fi | ||||
|  | ||||
| AC_OUTPUT(Makefile) | ||||
|   | ||||
| @@ -19,9 +19,6 @@ | ||||
|  | ||||
| #include "setup.h" | ||||
|  | ||||
|  | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| @@ -66,6 +63,11 @@ | ||||
|  * note: | ||||
|  *      network byte order assumed.  this means 192.5.5.240/28 has | ||||
|  *      0b11110000 in its fourth octet. | ||||
|  * note: | ||||
|  *      On Windows we store the error in the thread errno, not | ||||
|  *      in the winsock error code. This is to avoid loosing the | ||||
|  *      actual last winsock error. So use macro ERRNO to fetch the | ||||
|  *      errno this funtion sets when returning (-1), not SOCKERRNO. | ||||
|  * author: | ||||
|  *      Paul Vixie (ISC), June 1996 | ||||
|  */ | ||||
| @@ -86,7 +88,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|     dirty = 0; | ||||
|     src++;  /* skip x or X. */ | ||||
|     while ((ch = *src++) != '\0' && ISXDIGIT(ch)) { | ||||
|       if (isupper(ch)) | ||||
|       if (ISUPPER(ch)) | ||||
|         ch = tolower(ch); | ||||
|       n = (int)(strchr(xdigits, ch) - xdigits); | ||||
|       if (dirty == 0) | ||||
| @@ -186,11 +188,11 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|   return (bits); | ||||
|  | ||||
|   enoent: | ||||
|   errno = ENOENT; | ||||
|   SET_ERRNO(ENOENT); | ||||
|   return (-1); | ||||
|  | ||||
|   emsgsize: | ||||
|   errno = EMSGSIZE; | ||||
|   SET_ERRNO(EMSGSIZE); | ||||
|   return (-1); | ||||
| } | ||||
|  | ||||
| @@ -252,7 +254,7 @@ getv4(const char *src, unsigned char *dst, int *bitsp) | ||||
|     if (ch == '.' || ch == '/') { | ||||
|       if (dst - odst > 3)             /* too many octets? */ | ||||
|         return (0); | ||||
|       *dst++ = val; | ||||
|       *dst++ = (unsigned char)val; | ||||
|       if (ch == '/') | ||||
|         return (getbits(src, bitsp)); | ||||
|       val = 0; | ||||
| @@ -265,7 +267,7 @@ getv4(const char *src, unsigned char *dst, int *bitsp) | ||||
|     return (0); | ||||
|   if (dst - odst > 3)             /* too many octets? */ | ||||
|     return (0); | ||||
|   *dst++ = val; | ||||
|   *dst++ = (unsigned char)val; | ||||
|   return (1); | ||||
| } | ||||
|  | ||||
| @@ -321,8 +323,8 @@ inet_net_pton_ipv6(const char *src, unsigned char *dst, size_t size) | ||||
|         goto enoent; | ||||
|       if (tp + NS_INT16SZ > endp) | ||||
|         return (0); | ||||
|       *tp++ = (unsigned char) (val >> 8) & 0xff; | ||||
|       *tp++ = (unsigned char) val & 0xff; | ||||
|       *tp++ = (unsigned char)((val >> 8) & 0xff); | ||||
|       *tp++ = (unsigned char)(val & 0xff); | ||||
|       saw_xdigit = 0; | ||||
|       digits = 0; | ||||
|       val = 0; | ||||
| @@ -342,8 +344,8 @@ inet_net_pton_ipv6(const char *src, unsigned char *dst, size_t size) | ||||
|   if (saw_xdigit) { | ||||
|     if (tp + NS_INT16SZ > endp) | ||||
|       goto enoent; | ||||
|     *tp++ = (unsigned char) (val >> 8) & 0xff; | ||||
|     *tp++ = (unsigned char) val & 0xff; | ||||
|     *tp++ = (unsigned char)((val >> 8) & 0xff); | ||||
|     *tp++ = (unsigned char)(val & 0xff); | ||||
|   } | ||||
|   if (bits == -1) | ||||
|     bits = 128; | ||||
| @@ -381,11 +383,11 @@ inet_net_pton_ipv6(const char *src, unsigned char *dst, size_t size) | ||||
|   return (bits); | ||||
|  | ||||
|   enoent: | ||||
|   errno = ENOENT; | ||||
|   SET_ERRNO(ENOENT); | ||||
|   return (-1); | ||||
|  | ||||
|   emsgsize: | ||||
|   errno = EMSGSIZE; | ||||
|   SET_ERRNO(EMSGSIZE); | ||||
|   return (-1); | ||||
| } | ||||
|  | ||||
| @@ -399,6 +401,11 @@ inet_net_pton_ipv6(const char *src, unsigned char *dst, size_t size) | ||||
|  *      number of bits, either imputed classfully or specified with /CIDR, | ||||
|  *      or -1 if some failure occurred (check errno).  ENOENT means it was | ||||
|  *      not a valid network specification. | ||||
|  * note: | ||||
|  *      On Windows we store the error in the thread errno, not | ||||
|  *      in the winsock error code. This is to avoid loosing the | ||||
|  *      actual last winsock error. So use macro ERRNO to fetch the | ||||
|  *      errno this funtion sets when returning (-1), not SOCKERRNO. | ||||
|  * author: | ||||
|  *      Paul Vixie (ISC), June 1996 | ||||
|  */ | ||||
| @@ -411,7 +418,7 @@ ares_inet_net_pton(int af, const char *src, void *dst, size_t size) | ||||
|   case AF_INET6: | ||||
|     return (inet_net_pton_ipv6(src, dst, size)); | ||||
|   default: | ||||
|     errno = EAFNOSUPPORT; | ||||
|     SET_ERRNO(EAFNOSUPPORT); | ||||
|     return (-1); | ||||
|   } | ||||
| } | ||||
| @@ -429,11 +436,11 @@ int ares_inet_pton(int af, const char *src, void *dst) | ||||
|     size = sizeof(struct in6_addr); | ||||
|   else | ||||
|   { | ||||
|     errno = EAFNOSUPPORT; | ||||
|     SET_ERRNO(EAFNOSUPPORT); | ||||
|     return -1; | ||||
|   } | ||||
|   result = ares_inet_net_pton(af, src, dst, size); | ||||
|   if (result == -1 && errno == ENOENT) | ||||
|   if (result == -1 && ERRNO == ENOENT) | ||||
|     return 0; | ||||
|   return (result > -1 ? 1 : -1); | ||||
| } | ||||
|   | ||||
| @@ -18,8 +18,6 @@ | ||||
|  | ||||
| #include "setup.h" | ||||
|  | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| @@ -68,6 +66,11 @@ static const char *inet_ntop6(const unsigned char *src, char *dst, size_t size); | ||||
|  *     convert a network format address to presentation format. | ||||
|  * return: | ||||
|  *     pointer to presentation format address (`dst'), or NULL (see errno). | ||||
|  * note: | ||||
|  *      On Windows we store the error in the thread errno, not | ||||
|  *      in the winsock error code. This is to avoid loosing the | ||||
|  *      actual last winsock error. So use macro ERRNO to fetch the | ||||
|  *      errno this funtion sets when returning NULL, not SOCKERRNO. | ||||
|  * author: | ||||
|  *     Paul Vixie, 1996. | ||||
|  */ | ||||
| @@ -81,7 +84,7 @@ ares_inet_ntop(int af, const void *src, char *dst, size_t size) | ||||
|     case AF_INET6: | ||||
|       return (inet_ntop6(src, dst, size)); | ||||
|     default: | ||||
|       errno = EAFNOSUPPORT; | ||||
|       SET_ERRNO(EAFNOSUPPORT); | ||||
|       return (NULL); | ||||
|     } | ||||
|   /* NOTREACHED */ | ||||
| @@ -106,7 +109,7 @@ inet_ntop4(const unsigned char *src, char *dst, size_t size) | ||||
|  | ||||
|   if (SPRINTF((tmp, fmt, src[0], src[1], src[2], src[3])) > size) | ||||
|     { | ||||
|       errno = ENOSPC; | ||||
|       SET_ERRNO(ENOSPC); | ||||
|       return (NULL); | ||||
|     } | ||||
|     strcpy(dst, tmp); | ||||
| @@ -218,7 +221,7 @@ inet_ntop6(const unsigned char *src, char *dst, size_t size) | ||||
|    */ | ||||
|   if ((size_t)(tp - tmp) > size) | ||||
|     { | ||||
|       errno = ENOSPC; | ||||
|       SET_ERRNO(ENOSPC); | ||||
|       return (NULL); | ||||
|     } | ||||
|   strcpy(dst, tmp); | ||||
|   | ||||
| @@ -18,11 +18,6 @@ | ||||
|  | ||||
| #define MAXHOSTNAMELEN 256 | ||||
|  | ||||
| #define EINPROGRESS WSAEINPROGRESS | ||||
| #define EWOULDBLOCK WSAEWOULDBLOCK | ||||
| #define EMSGSIZE     WSAEMSGSIZE | ||||
| #define EAFNOSUPPORT WSAEAFNOSUPPORT | ||||
|  | ||||
| /* Structure for scatter/gather I/O.  */ | ||||
| struct iovec | ||||
| { | ||||
| @@ -30,7 +25,9 @@ struct iovec | ||||
|     size_t iov_len;     /* Length of data.  */ | ||||
| }; | ||||
|  | ||||
| #ifndef __WATCOMC__ | ||||
| #define getpid() _getpid() | ||||
| #endif | ||||
|  | ||||
| int ares_writev (SOCKET s, const struct iovec *vector, size_t count); | ||||
| #define writev(s,vect,count)  ares_writev(s,vect,count) | ||||
|   | ||||
							
								
								
									
										21
									
								
								ares/setup.h
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								ares/setup.h
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2004 - 2005 by Daniel Stenberg et al | ||||
| /* Copyright (C) 2004 - 2007 by Daniel Stenberg et al | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software and its | ||||
|  * documentation for any purpose and without fee is hereby granted, provided | ||||
| @@ -117,23 +117,11 @@ | ||||
| #undef VERSION | ||||
| #undef PACKAGE | ||||
|  | ||||
| /* | ||||
|  * Typedef our socket type | ||||
|  */ | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
| typedef SOCKET ares_socket_t; | ||||
| #define ARES_SOCKET_BAD INVALID_SOCKET | ||||
| #else | ||||
| typedef int ares_socket_t; | ||||
| #define ARES_SOCKET_BAD -1 | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Assume a few thing unless they're set by configure | ||||
|  */ | ||||
|  | ||||
| #if !defined(HAVE_SYS_TIME_H) && !defined(_MSC_VER) | ||||
| #if !defined(HAVE_SYS_TIME_H) && !defined(_MSC_VER) && !defined(__WATCOMC__) | ||||
| #define HAVE_SYS_TIME_H | ||||
| #endif | ||||
|  | ||||
| @@ -156,6 +144,11 @@ int ares_strcasecmp(const char *s1, const char *s2); | ||||
|    same */ | ||||
| #define strncasecmp(a,b,c) ares_strncasecmp(a,b,c) | ||||
| #define strcasecmp(a,b) ares_strcasecmp(a,b) | ||||
| #ifdef _MSC_VER | ||||
| #  if _MSC_VER >= 1400 | ||||
| #    define strdup(a) _strdup(a) | ||||
| #  endif | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| /* IPv6 compatibility */ | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2004 - 2006 by Daniel Stenberg et al | ||||
| /* Copyright (C) 2004 - 2007 by Daniel Stenberg et al | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software and its | ||||
|  * documentation for any purpose and without fee is hereby granted, provided | ||||
| @@ -27,9 +27,61 @@ | ||||
|  ********************************************************************/ | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Inclusion of common header files. | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <stdarg.h> | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
|  | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_SYS_STAT_H | ||||
| #include <sys/stat.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
| #ifdef TIME_WITH_SYS_TIME | ||||
| #include <time.h> | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_TIME_H | ||||
| #include <time.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #include <io.h> | ||||
| #include <fcntl.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_STDBOOL_H | ||||
| #include <stdbool.h> | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Definition of timeval struct for platforms that don't have it. | ||||
|  */ | ||||
|  | ||||
| #ifndef HAVE_STRUCT_TIMEVAL | ||||
| struct timeval { | ||||
|  long tv_sec; | ||||
|  long tv_usec; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * If we have the MSG_NOSIGNAL define, make sure we use | ||||
|  * it as the fourth argument of send() and recv() | ||||
|  * it as the fourth argument of function send() | ||||
|  */ | ||||
|  | ||||
| #ifdef HAVE_MSG_NOSIGNAL | ||||
| @@ -74,7 +126,7 @@ | ||||
| #define sread(x,y,z) (ssize_t)recv((RECV_TYPE_ARG1)(x), \ | ||||
|                                    (RECV_TYPE_ARG2)(y), \ | ||||
|                                    (RECV_TYPE_ARG3)(z), \ | ||||
|                                    (RECV_TYPE_ARG4)(SEND_4TH_ARG)) | ||||
|                                    (RECV_TYPE_ARG4)(0)) | ||||
| #endif | ||||
| #else /* HAVE_RECV */ | ||||
| #ifndef sread | ||||
| @@ -121,6 +173,189 @@ | ||||
| #define ISGRAPH(x)  (isgraph((int)  ((unsigned char)x))) | ||||
| #define ISALPHA(x)  (isalpha((int)  ((unsigned char)x))) | ||||
| #define ISPRINT(x)  (isprint((int)  ((unsigned char)x))) | ||||
| #define ISUPPER(x)  (isupper((int)  ((unsigned char)x))) | ||||
| #define ISLOWER(x)  (islower((int)  ((unsigned char)x))) | ||||
|  | ||||
| #define ISBLANK(x)  (int)((((unsigned char)x) == ' ') || \ | ||||
|                           (((unsigned char)x) == '\t')) | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Typedef to 'unsigned char' if bool is not an available 'typedefed' type. | ||||
|  */ | ||||
|  | ||||
| #ifndef HAVE_BOOL_T | ||||
| typedef unsigned char bool; | ||||
| #define HAVE_BOOL_T | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Default definition of uppercase TRUE and FALSE. | ||||
|  */ | ||||
|  | ||||
| #ifndef TRUE | ||||
| #define TRUE 1 | ||||
| #endif | ||||
| #ifndef FALSE | ||||
| #define FALSE 0 | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Typedef to 'int' if sig_atomic_t is not an available 'typedefed' type. | ||||
|  */ | ||||
|  | ||||
| #ifndef HAVE_SIG_ATOMIC_T | ||||
| typedef int sig_atomic_t; | ||||
| #define HAVE_SIG_ATOMIC_T | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Convenience SIG_ATOMIC_T definition | ||||
|  */ | ||||
|  | ||||
| #ifdef HAVE_SIG_ATOMIC_T_VOLATILE | ||||
| #define SIG_ATOMIC_T static sig_atomic_t | ||||
| #else | ||||
| #define SIG_ATOMIC_T static volatile sig_atomic_t | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Default return type for signal handlers. | ||||
|  */ | ||||
|  | ||||
| #ifndef RETSIGTYPE | ||||
| #define RETSIGTYPE void | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Macro used to include code only in debug builds. | ||||
|  */ | ||||
|  | ||||
| #ifdef CURLDEBUG | ||||
| #define DEBUGF(x) x | ||||
| #else | ||||
| #define DEBUGF(x) do { } while (0) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Macro used to include assertion code only in debug builds. | ||||
|  */ | ||||
|  | ||||
| #if defined(CURLDEBUG) && defined(HAVE_ASSERT_H) | ||||
| #define DEBUGASSERT(x) assert(x) | ||||
| #else | ||||
| #define DEBUGASSERT(x) do { } while (0) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Macro SOCKERRNO / SET_SOCKERRNO() returns / sets the *socket-related* errno | ||||
|  * (or equivalent) on this platform to hide platform details to code using it. | ||||
|  */ | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
| #define SOCKERRNO         ((int)WSAGetLastError()) | ||||
| #define SET_SOCKERRNO(x)  (WSASetLastError((int)(x))) | ||||
| #else | ||||
| #define SOCKERRNO         (errno) | ||||
| #define SET_SOCKERRNO(x)  (errno = (x)) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Macro ERRNO / SET_ERRNO() returns / sets the NOT *socket-related* errno | ||||
|  * (or equivalent) on this platform to hide platform details to code using it. | ||||
|  */ | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #define ERRNO         ((int)GetLastError()) | ||||
| #define SET_ERRNO(x)  (SetLastError((DWORD)(x))) | ||||
| #else | ||||
| #define ERRNO         (errno) | ||||
| #define SET_ERRNO(x)  (errno = (x)) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Portable error number symbolic names defined to Winsock error codes. | ||||
|  */ | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
| #undef  EBADF            /* override definition in errno.h */ | ||||
| #define EBADF            WSAEBADF | ||||
| #undef  EINTR            /* override definition in errno.h */ | ||||
| #define EINTR            WSAEINTR | ||||
| #undef  EINVAL           /* override definition in errno.h */ | ||||
| #define EINVAL           WSAEINVAL | ||||
| #define EWOULDBLOCK      WSAEWOULDBLOCK | ||||
| #define EINPROGRESS      WSAEINPROGRESS | ||||
| #define EALREADY         WSAEALREADY | ||||
| #define ENOTSOCK         WSAENOTSOCK | ||||
| #define EDESTADDRREQ     WSAEDESTADDRREQ | ||||
| #define EMSGSIZE         WSAEMSGSIZE | ||||
| #define EPROTOTYPE       WSAEPROTOTYPE | ||||
| #define ENOPROTOOPT      WSAENOPROTOOPT | ||||
| #define EPROTONOSUPPORT  WSAEPROTONOSUPPORT | ||||
| #define ESOCKTNOSUPPORT  WSAESOCKTNOSUPPORT | ||||
| #define EOPNOTSUPP       WSAEOPNOTSUPP | ||||
| #define EPFNOSUPPORT     WSAEPFNOSUPPORT | ||||
| #define EAFNOSUPPORT     WSAEAFNOSUPPORT | ||||
| #define EADDRINUSE       WSAEADDRINUSE | ||||
| #define EADDRNOTAVAIL    WSAEADDRNOTAVAIL | ||||
| #define ENETDOWN         WSAENETDOWN | ||||
| #define ENETUNREACH      WSAENETUNREACH | ||||
| #define ENETRESET        WSAENETRESET | ||||
| #define ECONNABORTED     WSAECONNABORTED | ||||
| #define ECONNRESET       WSAECONNRESET | ||||
| #define ENOBUFS          WSAENOBUFS | ||||
| #define EISCONN          WSAEISCONN | ||||
| #define ENOTCONN         WSAENOTCONN | ||||
| #define ESHUTDOWN        WSAESHUTDOWN | ||||
| #define ETOOMANYREFS     WSAETOOMANYREFS | ||||
| #define ETIMEDOUT        WSAETIMEDOUT | ||||
| #define ECONNREFUSED     WSAECONNREFUSED | ||||
| #define ELOOP            WSAELOOP | ||||
| #ifndef ENAMETOOLONG     /* possible previous definition in errno.h */ | ||||
| #define ENAMETOOLONG     WSAENAMETOOLONG | ||||
| #endif | ||||
| #define EHOSTDOWN        WSAEHOSTDOWN | ||||
| #define EHOSTUNREACH     WSAEHOSTUNREACH | ||||
| #ifndef ENOTEMPTY        /* possible previous definition in errno.h */ | ||||
| #define ENOTEMPTY        WSAENOTEMPTY | ||||
| #endif | ||||
| #define EPROCLIM         WSAEPROCLIM | ||||
| #define EUSERS           WSAEUSERS | ||||
| #define EDQUOT           WSAEDQUOT | ||||
| #define ESTALE           WSAESTALE | ||||
| #define EREMOTE          WSAEREMOTE | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  *  Actually use __32_getpwuid() on 64-bit VMS builds for getpwuid() | ||||
|  */ | ||||
|  | ||||
| #if defined(VMS) && \ | ||||
|     defined(__INITIAL_POINTER_SIZE) && (__INITIAL_POINTER_SIZE == 64) | ||||
| #define getpwuid __32_getpwuid | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Macro argv_item_t hides platform details to code using it. | ||||
|  */ | ||||
|  | ||||
| #ifdef VMS | ||||
| #define argv_item_t  __char_ptr32 | ||||
| #else | ||||
| #define argv_item_t  char * | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif /* __SETUP_ONCE_H */ | ||||
|   | ||||
| @@ -91,12 +91,16 @@ SOURCE=..\..\adig.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\getopt.c | ||||
| SOURCE=..\..\ares_getopt.c | ||||
| # End Source File | ||||
| # End Group | ||||
| # Begin Group "Header Files" | ||||
|  | ||||
| # PROP Default_Filter "h;hpp;hxx;hm;inl" | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_getopt.h | ||||
| # End Source File | ||||
| # End Group | ||||
| # Begin Group "Resource Files" | ||||
|  | ||||
|   | ||||
| @@ -87,10 +87,18 @@ LINK32=link.exe | ||||
|  | ||||
| SOURCE=..\..\ahost.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_getopt.c | ||||
| # End Source File | ||||
| # End Group | ||||
| # Begin Group "Header Files" | ||||
|  | ||||
| # PROP Default_Filter "h;hpp;hxx;hm;inl" | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_getopt.h | ||||
| # End Source File | ||||
| # End Group | ||||
| # Begin Group "Resource Files" | ||||
|  | ||||
|   | ||||
| @@ -129,6 +129,10 @@ SOURCE=..\..\ares_gethostbyname.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_getsock.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_init.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|   | ||||
| @@ -20,6 +20,20 @@ | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| #ifdef __WATCOMC__ | ||||
| /* | ||||
|  * Watcom needs a DllMain() in order to initialise the clib startup code. | ||||
|  */ | ||||
| BOOL | ||||
| WINAPI DllMain (HINSTANCE hnd, DWORD reason, LPVOID reserved) | ||||
| { | ||||
|   (void) hnd; | ||||
|   (void) reason; | ||||
|   (void) reserved; | ||||
|   return (TRUE); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #ifndef __MINGW32__ | ||||
| int | ||||
| ares_strncasecmp(const char *a, const char *b, int n) | ||||
| @@ -27,8 +41,8 @@ ares_strncasecmp(const char *a, const char *b, int n) | ||||
|     int i; | ||||
|  | ||||
|     for (i = 0; i < n; i++) { | ||||
|         int c1 = isupper(a[i]) ? tolower(a[i]) : a[i]; | ||||
|         int c2 = isupper(b[i]) ? tolower(b[i]) : b[i]; | ||||
|         int c1 = ISUPPER(a[i]) ? tolower(a[i]) : a[i]; | ||||
|         int c2 = ISUPPER(b[i]) ? tolower(b[i]) : b[i]; | ||||
|         if (c1 != c2) return c1-c2; | ||||
|     } | ||||
|     return 0; | ||||
| @@ -91,7 +105,7 @@ ares_writev (ares_socket_t s, const struct iovec *vector, size_t count) | ||||
|   buffer = bp = (char*) alloca (bytes); | ||||
|   if (!buffer) | ||||
|   { | ||||
|     errno = ENOMEM; | ||||
|     SET_ERRNO(ENOMEM); | ||||
|     return (-1); | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,6 @@ REM $Date$ | ||||
|  | ||||
| REM create ca-bundle.h | ||||
| echo /* This file is generated automatically */ >lib\ca-bundle.h | ||||
| echo #define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE") >>lib\ca-bundle.h | ||||
|  | ||||
| REM create hugehelp.c | ||||
| copy src\hugehelp.c.cvs src\hugehelp.c | ||||
|   | ||||
							
								
								
									
										485
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										485
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2007, 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 | ||||
| @@ -78,6 +78,7 @@ AC_SUBST(PKGADD_VENDOR) | ||||
| dnl | ||||
| dnl initialize all the info variables | ||||
|     curl_ssl_msg="no      (--with-ssl / --with-gnutls)" | ||||
|     curl_ssh_msg="no      (--with-libssh2)" | ||||
|    curl_zlib_msg="no      (--with-zlib)" | ||||
|    curl_krb4_msg="no      (--with-krb4*)" | ||||
|     curl_gss_msg="no      (--with-gssapi)" | ||||
| @@ -89,6 +90,11 @@ dnl initialize all the info variables | ||||
| curl_verbose_msg="enabled (--disable-verbose)" | ||||
|    curl_sspi_msg="no      (--enable-sspi)" | ||||
|  | ||||
| dnl | ||||
| dnl Save anything in $LIBS for later | ||||
| dnl | ||||
| ALL_LIBS=$LIBS | ||||
|  | ||||
| dnl | ||||
| dnl Detect the canonical host and target build environment | ||||
| dnl | ||||
| @@ -106,9 +112,37 @@ AC_PROG_CC | ||||
| dnl check for how to do large files | ||||
| AC_SYS_LARGEFILE | ||||
|  | ||||
| dnl check for cygwin stuff | ||||
| dnl support building of Windows DLLs | ||||
| AC_LIBTOOL_WIN32_DLL | ||||
|  | ||||
| dnl skip libtool C++ and Fortran compiler checks | ||||
| m4_ifdef([AC_PROG_CXX], [m4_undefine([AC_PROG_CXX])]) | ||||
| m4_defun([AC_PROG_CXX],[]) | ||||
| m4_ifdef([AC_PROG_CXXCPP], [m4_undefine([AC_PROG_CXXCPP])]) | ||||
| m4_defun([AC_PROG_CXXCPP],[true]) | ||||
| m4_ifdef([AC_PROG_F77], [m4_undefine([AC_PROG_F77])]) | ||||
| m4_defun([AC_PROG_F77],[]) | ||||
|  | ||||
| dnl skip libtool C++ and Fortran linker checks | ||||
| m4_ifdef([AC_LIBTOOL_CXX], [m4_undefine([AC_LIBTOOL_CXX])]) | ||||
| m4_defun([AC_LIBTOOL_CXX],[]) | ||||
| m4_ifdef([AC_LIBTOOL_CXXCPP], [m4_undefine([AC_LIBTOOL_CXXCPP])]) | ||||
| m4_defun([AC_LIBTOOL_CXXCPP],[true]) | ||||
| m4_ifdef([AC_LIBTOOL_F77], [m4_undefine([AC_LIBTOOL_F77])]) | ||||
| m4_defun([AC_LIBTOOL_F77],[]) | ||||
|  | ||||
| dnl force libtool to build static libraries with PIC on AMD64-linux | ||||
| AC_MSG_CHECKING([if arch-OS host is AMD64-linux (to build static libraries with PIC)]) | ||||
| case $host in | ||||
|   x86_64*linux*) | ||||
|     AC_MSG_RESULT([yes]) | ||||
|     with_pic=yes | ||||
|     ;; | ||||
|   *) | ||||
|     AC_MSG_RESULT([no]) | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| dnl libtool setup | ||||
| AC_PROG_LIBTOOL | ||||
|  | ||||
| @@ -157,10 +191,22 @@ case $host in | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| # Determine whether all dependent libraries must be specified when linking | ||||
| if test "X$enable_shared" = "Xyes" -a "X$link_all_deplibs" = "Xno" | ||||
| then | ||||
|     REQUIRE_LIB_DEPS=no | ||||
| else | ||||
|     REQUIRE_LIB_DEPS=yes | ||||
| fi | ||||
| AC_SUBST(REQUIRE_LIB_DEPS) | ||||
|  | ||||
| dnl The install stuff has already been taken care of by the automake stuff | ||||
| dnl AC_PROG_INSTALL | ||||
| AC_PROG_MAKE_SET | ||||
|  | ||||
| dnl check if there's a way to force code inline | ||||
| AC_C_INLINE | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Make sure that our checks for headers windows.h winsock.h winsock2.h  | ||||
| dnl and ws2tcpip.h take precedence over any other further checks which  | ||||
| @@ -373,6 +419,21 @@ then | ||||
|              ) | ||||
| fi | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl This is for Minix 3.1 | ||||
|   AC_MSG_CHECKING([for gethostbyname for Minix 3]) | ||||
|   AC_TRY_LINK([ | ||||
| /* Older Minix versions may need <net/gen/netdb.h> here instead */ | ||||
| #include <netdb.h>], | ||||
|                [gethostbyname("www.dummysite.com");], | ||||
|                [ dnl worked! | ||||
|                AC_MSG_RESULT([yes]) | ||||
|                HAVE_GETHOSTBYNAME="1"], | ||||
|                AC_MSG_RESULT(no) | ||||
|              ) | ||||
| fi | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl This is for eCos with a stubbed DNS implementation | ||||
| @@ -417,15 +478,20 @@ fi | ||||
| dnl socket lib? | ||||
| AC_CHECK_FUNC(connect, , [ AC_CHECK_LIB(socket, connect) ]) | ||||
|  | ||||
| dnl dl lib? | ||||
| AC_CHECK_FUNC(dlclose, , [ AC_CHECK_LIB(dl, dlopen) ]) | ||||
| dnl ********************************************************************** | ||||
| dnl The preceding library checks are all potentially useful for test | ||||
| dnl servers (for providing networking support).  Save the list of required | ||||
| dnl libraries at this point for use while linking those test servers. | ||||
| dnl ********************************************************************** | ||||
| TEST_SERVER_LIBS=$LIBS | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| AC_MSG_CHECKING([whether to use libgcc]) | ||||
| AC_ARG_ENABLE(libgcc, | ||||
| AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]), | ||||
| [ case "$enableval" in | ||||
|   yes) | ||||
|         LIBS="$LIBS -lgcc" | ||||
|         ALL_LIBS="$ALL_LIBS -lgcc" | ||||
|        AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(no) | ||||
| @@ -434,6 +500,9 @@ AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]), | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl dl lib? | ||||
| AC_CHECK_FUNC(dlclose, , [ AC_CHECK_LIB(dl, dlopen) ]) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the name of dynamic OpenLDAP libraries | ||||
| dnl ********************************************************************** | ||||
| @@ -841,7 +910,7 @@ dnl Default to no CA bundle | ||||
| ca="no" | ||||
| AC_ARG_WITH(ssl,dnl | ||||
| AC_HELP_STRING([--with-ssl=PATH],[Where to look for OpenSSL, PATH points to the SSL installation (default: /usr/local/ssl); when possible, set the PKG_CONFIG_PATH environment variable instead of using this option]) | ||||
| AC_HELP_STRING([--without-ssl], [disable SSL]), | ||||
| AC_HELP_STRING([--without-ssl], [disable OpenSSL]), | ||||
|   OPT_SSL=$withval) | ||||
|  | ||||
| if test X"$OPT_SSL" != Xno; then | ||||
| @@ -1021,12 +1090,35 @@ if test X"$OPT_SSL" != Xno; then | ||||
|               ]) | ||||
|  | ||||
|     dnl these can only exist if openssl exists | ||||
|     dnl yassl doesn't have SSL_get_shutdown | ||||
|  | ||||
|     AC_CHECK_FUNCS( RAND_status \ | ||||
|                     RAND_screen \ | ||||
|                     RAND_egd \ | ||||
|                     CRYPTO_cleanup_all_ex_data ) | ||||
|                     CRYPTO_cleanup_all_ex_data \ | ||||
|                     SSL_get_shutdown ) | ||||
|  | ||||
|     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 and acting like OpenSSL. | ||||
|  | ||||
|     AC_MSG_CHECKING([for yaSSL using OpenSSL compatibility mode]) | ||||
|     AC_TRY_COMPILE([ | ||||
| #include <openssl/ssl.h> | ||||
|       ],[ | ||||
| #if defined(YASSL_VERSION) && defined(OPENSSL_VERSION_NUMBER) | ||||
|         int dummy = SSL_ERROR_NONE; | ||||
| #else | ||||
|         Not the yaSSL OpenSSL compatibility header. | ||||
| #endif | ||||
|       ],[  | ||||
|         AC_MSG_RESULT([yes]) | ||||
|         AC_DEFINE_UNQUOTED(USE_YASSLEMUL, 1, | ||||
|           [Define to 1 if using yaSSL in OpenSSL compatibility mode.]) | ||||
|         curl_ssl_msg="enabled (OpenSSL emulation by yaSSL)" | ||||
|       ],[ | ||||
|         AC_MSG_RESULT([no]) | ||||
|     ]) | ||||
|   fi | ||||
|  | ||||
|   if test "$OPENSSL_ENABLED" = "1"; then | ||||
| @@ -1043,6 +1135,152 @@ if test X"$OPT_SSL" != Xno; then | ||||
|  | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the presence of ZLIB libraries and headers | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| dnl Check for & handle argument to --with-zlib. | ||||
|  | ||||
| _cppflags=$CPPFLAGS | ||||
| _ldflags=$LDFLAGS | ||||
| AC_ARG_WITH(zlib, | ||||
| AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH]) | ||||
| AC_HELP_STRING([--without-zlib],[disable use of zlib]), | ||||
|                [OPT_ZLIB="$withval"]) | ||||
|  | ||||
| if test "$OPT_ZLIB" = "no" ; then | ||||
|     AC_MSG_WARN([zlib disabled]) | ||||
| else | ||||
|   if test "$OPT_ZLIB" = "yes" ; then | ||||
|      OPT_ZLIB="" | ||||
|   fi | ||||
|  | ||||
|   if test -z "$OPT_ZLIB" ; then | ||||
|     dnl check for the lib first without setting any new path, since many | ||||
|     dnl people have it in the default path | ||||
|  | ||||
|     AC_CHECK_LIB(z, inflateEnd, | ||||
|                    dnl libz found, set the variable | ||||
|                    [HAVE_LIBZ="1"], | ||||
|                    dnl if no lib found, try /usr/local | ||||
|                    [OPT_ZLIB="/usr/local"]) | ||||
|  | ||||
|   fi | ||||
|  | ||||
|   dnl Add a nonempty path to the compiler flags | ||||
|   if test -n "$OPT_ZLIB"; then | ||||
|      CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include" | ||||
|      LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib$libsuff" | ||||
|   fi | ||||
|  | ||||
|   AC_CHECK_HEADER(zlib.h, | ||||
|     [ | ||||
|     dnl zlib.h was found | ||||
|     HAVE_ZLIB_H="1" | ||||
|     dnl if the lib wasn't found already, try again with the new paths | ||||
|     if test "$HAVE_LIBZ" != "1"; then | ||||
|       AC_CHECK_LIB(z, gzread, | ||||
|                    [ | ||||
|                    dnl the lib was found! | ||||
|                    HAVE_LIBZ="1" | ||||
|                    ], | ||||
|                    [ CPPFLAGS=$_cppflags | ||||
|                    LDFLAGS=$_ldflags]) | ||||
|     fi | ||||
|     ], | ||||
|     [ | ||||
|       dnl zlib.h was not found, restore the flags | ||||
|       CPPFLAGS=$_cppflags | ||||
|       LDFLAGS=$_ldflags] | ||||
|     ) | ||||
|  | ||||
|   if test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" != "1" | ||||
|   then | ||||
|     AC_MSG_WARN([configure found only the libz lib, not the header file!]) | ||||
|   elif test "$HAVE_LIBZ" != "1" && test "$HAVE_ZLIB_H" = "1" | ||||
|   then | ||||
|     AC_MSG_WARN([configure found only the libz header file, not the lib!]) | ||||
|   elif test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" = "1" | ||||
|   then | ||||
|     dnl both header and lib were found! | ||||
|     AC_SUBST(HAVE_LIBZ) | ||||
|     AC_DEFINE(HAVE_ZLIB_H, 1, [if you have the zlib.h header file]) | ||||
|     AC_DEFINE(HAVE_LIBZ, 1, [if zlib is available]) | ||||
|  | ||||
|     CURL_LIBS="$CURL_LIBS -lz" | ||||
|     LIBS="$LIBS -lz" | ||||
|  | ||||
|     dnl replace 'HAVE_LIBZ' in the automake makefile.ams | ||||
|     AMFIXLIB="1" | ||||
|     AC_MSG_NOTICE([found both libz and libz.h header]) | ||||
|     curl_zlib_msg="enabled" | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| dnl set variable for use in automakefile(s) | ||||
| AM_CONDITIONAL(HAVE_LIBZ, test x"$AMFIXLIB" = x1) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the presence of LIBSSH2 libraries and headers | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| dnl Default to compiler & linker defaults for LIBSSH2 files & libraries. | ||||
| OPT_LIBSSH2=off | ||||
| AC_ARG_WITH(libssh2,dnl | ||||
| AC_HELP_STRING([--with-libssh2=PATH],[Where to look for libssh2, PATH points to the LIBSSH2 installation (default: /usr/local/lib); when possible, set the PKG_CONFIG_PATH environment variable instead of using this option]) | ||||
| AC_HELP_STRING([--without-libssh2], [disable LIBSSH2]), | ||||
|   OPT_LIBSSH2=$withval) | ||||
|  | ||||
| if test X"$OPT_LIBSSH2" != Xno; then | ||||
|   dnl backup the pre-libssh2 variables | ||||
|   CLEANLDFLAGS="$LDFLAGS" | ||||
|   CLEANCPPFLAGS="$CPPFLAGS" | ||||
|   CLEANLIBS="$LIBS" | ||||
|  | ||||
|   case "$OPT_LIBSSH2" in | ||||
|   yes) | ||||
|     dnl --with-libssh2 (without path) used | ||||
|     PREFIX_LIBSSH2=/usr/local/lib | ||||
|     LIB_LIBSSH2="$PREFIX_LIBSSH2/lib$libsuff" | ||||
|     ;; | ||||
|   off) | ||||
|     dnl no --with-libssh2 option given, just check default places | ||||
|     PREFIX_LIBSSH2= | ||||
|     ;; | ||||
|   *) | ||||
|     dnl use the given --with-libssh2 spot | ||||
|     PREFIX_LIBSSH2=$OPT_LIBSSH2 | ||||
|     LIB_LIBSSH2="$PREFIX_LIBSSH2/lib$libsuff" | ||||
|     LDFLAGS="$LDFLAGS -L$LIB_LIBSSH2" | ||||
|     CPPFLAGS="$CPPFLAGS -I$PREFIX_LIBSSH2/include" | ||||
|     ;; | ||||
|   esac | ||||
|  | ||||
|   AC_CHECK_LIB(ssh2, libssh2_channel_open_ex) | ||||
|    | ||||
|   AC_CHECK_HEADERS(libssh2.h, | ||||
|     curl_ssh_msg="enabled (libSSH2)" | ||||
|     LIBSSH2_ENABLED=1 | ||||
|     AC_DEFINE(USE_LIBSSH2, 1, [if libSSH2 is in use])) | ||||
|  | ||||
|   if test X"$OPT_LIBSSH2" != Xoff && | ||||
|      test "$LIBSSH2_ENABLED" != "1"; then | ||||
|     AC_MSG_ERROR([libSSH2 libs and/or directories were not found where specified!]) | ||||
|   fi | ||||
|  | ||||
|   if test "$LIBSSH2_ENABLED" = "1"; then | ||||
|     if test -n "$LIB_LIBSSH2"; then | ||||
|        dnl when the libssh2 shared libs were found in a path that the run-time | ||||
|        dnl linker doesn't search through, we need to add it to LD_LIBRARY_PATH | ||||
|        dnl to prevent further configure tests to fail due to this | ||||
|  | ||||
|        LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_LIBSSH2" | ||||
|        export LD_LIBRARY_PATH | ||||
|        AC_MSG_NOTICE([Added $LIB_LIBSSH2 to LD_LIBRARY_PATH]) | ||||
|     fi | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the random seed preferences  | ||||
| dnl ********************************************************************** | ||||
| @@ -1121,6 +1359,7 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|        [ | ||||
|        AC_DEFINE(USE_GNUTLS, 1, [if GnuTLS is enabled]) | ||||
|        AC_SUBST(USE_GNUTLS, [1]) | ||||
|        GNUTLS_ENABLED=1 | ||||
|        USE_GNUTLS="yes" | ||||
|        curl_ssl_msg="enabled (GnuTLS)" | ||||
|        ], | ||||
| @@ -1146,12 +1385,84 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|  | ||||
|   fi dnl GNUTLS not disabled | ||||
|  | ||||
|   if test X"$USE_GNUTLS" != "Xyes"; then | ||||
|     AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.]) | ||||
|     AC_MSG_WARN([Use --with-ssl or --with-gnutls to address this.]) | ||||
| fi dnl OPENSSL != 1 | ||||
|  | ||||
| dnl ---------------------------------------------------- | ||||
| dnl NSS. Only check if GnuTLS and OpenSSL are not enabled | ||||
| dnl ---------------------------------------------------- | ||||
|  | ||||
| dnl Default to compiler & linker defaults for NSS files & libraries. | ||||
| OPT_NSS=no | ||||
|  | ||||
| AC_ARG_WITH(nss,dnl | ||||
| AC_HELP_STRING([--with-nss=PATH],[where to look for NSS, PATH points to the installation root (default: /usr/local/)]) | ||||
| AC_HELP_STRING([--without-nss], [disable NSS detection]), | ||||
|   OPT_NSS=$withval) | ||||
|  | ||||
| if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then | ||||
|  | ||||
|   if test X"$OPT_NSS" != Xno; then | ||||
|     if test "x$OPT_NSS" = "xyes"; then | ||||
|      check=`pkg-config --version 2>/dev/null` | ||||
|      if test -n "$check"; then | ||||
|        addlib=`pkg-config --libs nss` | ||||
|        addcflags=`pkg-config --cflags nss` | ||||
|        version=`pkg-config --modversion nss` | ||||
|        nssprefix=`pkg-config --variable=prefix nss` | ||||
|      fi | ||||
|     else | ||||
|       # Without pkg-config, we'll kludge in some defaults | ||||
|       addlib="-lssl3 -lsmime3 -lnss3 -lplds4 -lplc4 -lnspr4 -lpthread -ldl" | ||||
|       addcflags="-I$OPT_NSS/include"  | ||||
|       version="unknown" | ||||
|       gtlsprefix=$OPT_GNUTLS | ||||
|     fi | ||||
|     if test -n "$addlib"; then | ||||
|  | ||||
|       CLEANLIBS="$LIBS" | ||||
|       CLEANCPPFLAGS="$CPPFLAGS" | ||||
|    | ||||
|       LIBS="$LIBS $addlib" | ||||
|       if test "$addcflags" != "-I/usr/include"; then | ||||
|          CPPFLAGS="$CPPFLAGS $addcflags" | ||||
|       fi | ||||
|    | ||||
| fi dnl OPENSSL != 1 | ||||
|       AC_CHECK_LIB(nss3, NSS_Initialize, | ||||
|        [ | ||||
|        AC_DEFINE(USE_NSS, 1, [if NSS is enabled]) | ||||
|        AC_SUBST(USE_NSS, [1]) | ||||
|        USE_NSS="yes" | ||||
|        NSS_ENABLED=1 | ||||
|        curl_ssl_msg="enabled (NSS)" | ||||
|        ], | ||||
|        [ | ||||
|          LIBS="$CLEANLIBS" | ||||
|          CPPFLAGS="$CLEANCPPFLAGS" | ||||
|        ]) | ||||
|    | ||||
|       if test "x$USE_NSS" = "xyes"; then | ||||
|         AC_MSG_NOTICE([detected NSS version $version]) | ||||
|  | ||||
|         dnl when shared libs were found in a path that the run-time | ||||
|         dnl linker doesn't search through, we need to add it to | ||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||
|         dnl due to this | ||||
|  | ||||
|         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff" | ||||
|         export LD_LIBRARY_PATH | ||||
|         AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH]) | ||||
|       fi | ||||
|  | ||||
|     fi | ||||
|  | ||||
|   fi dnl NSS not disabled | ||||
|  | ||||
| fi dnl OPENSSL != 1 -a GNUTLS_ENABLED != 1 | ||||
|  | ||||
| if test "x$OPENSSL_ENABLED$GNUTLS_ENABLED$NSS_ENABLED" = "x"; then | ||||
|   AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.]) | ||||
|   AC_MSG_WARN([Use --with-ssl, --with-gnutls or --with-nss to address this.]) | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the CA bundle | ||||
| @@ -1182,93 +1493,10 @@ fi dnl only done if some kind of SSL was enabled | ||||
|  | ||||
| AM_CONDITIONAL(CABUNDLE, test x$ca != xno) | ||||
|  | ||||
|  | ||||
|  | ||||
|    | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the presence of ZLIB libraries and headers | ||||
| dnl Check for the presence of IDN libraries and headers | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| dnl Check for & handle argument to --with-zlib. | ||||
|  | ||||
| _cppflags=$CPPFLAGS | ||||
| _ldflags=$LDFLAGS | ||||
| AC_ARG_WITH(zlib, | ||||
| AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH]) | ||||
| AC_HELP_STRING([--without-zlib],[disable use of zlib]), | ||||
|                [OPT_ZLIB="$withval"]) | ||||
|  | ||||
| if test "$OPT_ZLIB" = "no" ; then | ||||
|     AC_MSG_WARN([zlib disabled]) | ||||
| else | ||||
|   if test "$OPT_ZLIB" = "yes" ; then | ||||
|      OPT_ZLIB="" | ||||
|   fi | ||||
|  | ||||
|   if test -z "$OPT_ZLIB" ; then | ||||
|     dnl check for the lib first without setting any new path, since many | ||||
|     dnl people have it in the default path | ||||
|  | ||||
|     AC_CHECK_LIB(z, inflateEnd, | ||||
|                    dnl libz found, set the variable | ||||
|                    [HAVE_LIBZ="1"], | ||||
|                    dnl if no lib found, try /usr/local | ||||
|                    [OPT_ZLIB="/usr/local"]) | ||||
|  | ||||
|   fi | ||||
|  | ||||
|   dnl Add a nonempty path to the compiler flags | ||||
|   if test -n "$OPT_ZLIB"; then | ||||
|      CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include" | ||||
|      LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib$libsuff" | ||||
|   fi | ||||
|  | ||||
|   AC_CHECK_HEADER(zlib.h, | ||||
|     [ | ||||
|     dnl zlib.h was found | ||||
|     HAVE_ZLIB_H="1" | ||||
|     dnl if the lib wasn't found already, try again with the new paths | ||||
|     if test "$HAVE_LIBZ" != "1"; then | ||||
|       AC_CHECK_LIB(z, gzread, | ||||
|                    [ | ||||
|                    dnl the lib was found! | ||||
|                    HAVE_LIBZ="1" | ||||
|                    ], | ||||
|                    [ CPPFLAGS=$_cppflags | ||||
|                    LDFLAGS=$_ldflags]) | ||||
|     fi | ||||
|     ], | ||||
|     [ | ||||
|       dnl zlib.h was not found, restore the flags | ||||
|       CPPFLAGS=$_cppflags | ||||
|       LDFLAGS=$_ldflags] | ||||
|     ) | ||||
|  | ||||
|   if test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" != "1" | ||||
|   then | ||||
|     AC_MSG_WARN([configure found only the libz lib, not the header file!]) | ||||
|   elif test "$HAVE_LIBZ" != "1" && test "$HAVE_ZLIB_H" = "1" | ||||
|   then | ||||
|     AC_MSG_WARN([configure found only the libz header file, not the lib!]) | ||||
|   elif test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" = "1" | ||||
|   then | ||||
|     dnl both header and lib were found! | ||||
|     AC_SUBST(HAVE_LIBZ) | ||||
|     AC_DEFINE(HAVE_ZLIB_H, 1, [if you have the zlib.h header file]) | ||||
|     AC_DEFINE(HAVE_LIBZ, 1, [if zlib is available]) | ||||
|  | ||||
|     LIBS="$LIBS -lz" | ||||
|  | ||||
|     dnl replace 'HAVE_LIBZ' in the automake makefile.ams | ||||
|     AMFIXLIB="1" | ||||
|     AC_MSG_NOTICE([found both libz and libz.h header]) | ||||
|     curl_zlib_msg="enabled" | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| dnl set variable for use in automakefile(s) | ||||
| AM_CONDITIONAL(HAVE_LIBZ, test x"$AMFIXLIB" = x1) | ||||
|  | ||||
| AC_MSG_CHECKING([whether to build with libidn]) | ||||
| AC_ARG_WITH(libidn, | ||||
| AC_HELP_STRING([--with-libidn=PATH],[Enable libidn usage]) | ||||
| @@ -1397,6 +1625,10 @@ if test "x$RECENTAIX" = "xyes"; then | ||||
|          XLC="yes" | ||||
|          AC_MSG_RESULT([yes]) | ||||
|          CFLAGS="$CFLAGS -qthreaded" | ||||
|          dnl AIX xlc has to have strict aliasing turned off. If not, | ||||
|          dnl the optimizer assumes that pointers can only point to | ||||
|          dnl an object of the same type. | ||||
|          CFLAGS="$CFLAGS -qnoansialias" | ||||
|        ) | ||||
|  | ||||
|  | ||||
| @@ -1413,7 +1645,7 @@ if test x$cross_compiling != xyes; then | ||||
|  | ||||
|   if test x$checkfor_gmtime_r = xyes; then | ||||
|  | ||||
|     dnl if gmtime_r was found, verify that it actuall works, as (at least) HPUX | ||||
|     dnl if gmtime_r was found, verify that it actually works, as (at least) HPUX | ||||
|     dnl 10.20 is known to have a buggy one. If it doesn't work, disable use of | ||||
|     dnl it. | ||||
|  | ||||
| @@ -1496,6 +1728,7 @@ AC_CHECK_HEADERS( | ||||
|         libgen.h \ | ||||
|         locale.h \ | ||||
|         errno.h \ | ||||
|         stdbool.h \ | ||||
|         arpa/tftp.h \ | ||||
|         sys/filio.h \ | ||||
|         setjmp.h, | ||||
| @@ -1525,6 +1758,7 @@ dnl default includes | ||||
|  | ||||
| dnl Checks for typedefs, structures, and compiler characteristics. | ||||
| AC_C_CONST | ||||
| CURL_CHECK_VARIADIC_MACROS | ||||
| AC_TYPE_SIZE_T | ||||
| AC_HEADER_TIME | ||||
| CURL_CHECK_STRUCT_TIMEVAL | ||||
| @@ -1557,6 +1791,19 @@ fi | ||||
| AC_CHECK_TYPE(ssize_t, , | ||||
|    AC_DEFINE(ssize_t, int, [the signed version of size_t])) | ||||
|  | ||||
| # check for bool type | ||||
| AC_CHECK_TYPE([bool],[ | ||||
|   AC_DEFINE(HAVE_BOOL_T, 1, | ||||
|     [Define to 1 if bool is an available type.]) | ||||
| ], ,[ | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_STDBOOL_H | ||||
| #include <stdbool.h> | ||||
| #endif | ||||
| ]) | ||||
|  | ||||
| # Check for socklen_t or equivalent | ||||
| CURL_CHECK_TYPE_SOCKLEN_T | ||||
|  | ||||
| @@ -1564,6 +1811,10 @@ TYPE_IN_ADDR_T | ||||
|  | ||||
| TYPE_SOCKADDR_STORAGE | ||||
|  | ||||
| TYPE_SIG_ATOMIC_T | ||||
|  | ||||
| AC_TYPE_SIGNAL | ||||
|  | ||||
| AC_FUNC_SELECT_ARGTYPES | ||||
|  | ||||
| CURL_CHECK_FUNC_RECV | ||||
| @@ -1574,7 +1825,7 @@ CURL_CHECK_MSG_NOSIGNAL | ||||
|  | ||||
| dnl Checks for library functions. | ||||
| dnl AC_PROG_GCC_TRADITIONAL | ||||
| AC_TYPE_SIGNAL | ||||
|  | ||||
| dnl AC_FUNC_VPRINTF | ||||
| case $host in | ||||
|   *msdosdjgpp) | ||||
| @@ -1618,7 +1869,8 @@ AC_CHECK_FUNCS( strtoll \ | ||||
|                 getprotobyname \ | ||||
|                 getrlimit \ | ||||
|                 setrlimit \ | ||||
|                 fork, | ||||
|                 fork \ | ||||
|                 setmode, | ||||
| dnl if found | ||||
| [], | ||||
| dnl if not found, $ac_func is the name we check for | ||||
| @@ -1801,10 +2053,10 @@ fi | ||||
| dnl set variable for use in automakefile(s) | ||||
| AM_CONDITIONAL(USE_MANUAL, test x"$USE_MANUAL" = x1) | ||||
|  | ||||
| AC_MSG_CHECKING([whether to enable ares]) | ||||
| AC_MSG_CHECKING([whether to enable c-ares]) | ||||
| AC_ARG_ENABLE(ares, | ||||
| AC_HELP_STRING([--enable-ares=PATH],[Enable ares for name lookups]) | ||||
| AC_HELP_STRING([--disable-ares],[Disable ares for name lookups]), | ||||
| AC_HELP_STRING([--enable-ares=PATH],[Enable c-ares for name lookups]) | ||||
| AC_HELP_STRING([--disable-ares],[Disable c-ares for name lookups]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
| @@ -1812,10 +2064,10 @@ AC_HELP_STRING([--disable-ares],[Disable ares for name lookups]), | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|  | ||||
|        if test "x$IPV6_ENABLED" = "x1"; then | ||||
|          AC_MSG_NOTICE([ares may not work properly with ipv6]) | ||||
|          AC_MSG_NOTICE([c-ares may not work properly with ipv6]) | ||||
|        fi | ||||
|  | ||||
|        AC_DEFINE(USE_ARES, 1, [Define if you want to enable ares support]) | ||||
|        AC_DEFINE(USE_ARES, 1, [Define if you want to enable c-ares support]) | ||||
|        dnl substitute HAVE_ARES for curl-config and similar | ||||
|        HAVE_ARES="1" | ||||
|        AC_SUBST(HAVE_ARES) | ||||
| @@ -1860,7 +2112,8 @@ void curl_domalloc() { } | ||||
| int main(void) | ||||
| { | ||||
|   ares_channel channel; | ||||
|   ares_cancel(channel); | ||||
|   ares_cancel(channel); /* added in 1.2.0 */ | ||||
|   ares_process_fd(channel, 0, 0); /* added in 1.4.0 */ | ||||
|   return 0; | ||||
| } | ||||
| ], | ||||
| @@ -1894,19 +2147,26 @@ AC_HELP_STRING([--disable-verbose],[Disable verbose strings]), | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
|  | ||||
| CURL_CHECK_NATIVE_WINDOWS | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl enable SSPI support | ||||
| dnl | ||||
| AC_MSG_CHECKING([whether to enable SSPI support (win32 builds only)]) | ||||
| AC_MSG_CHECKING([whether to enable SSPI support (Windows native builds only)]) | ||||
| AC_ARG_ENABLE(sspi, | ||||
| AC_HELP_STRING([--enable-sspi],[Enable SSPI]) | ||||
| AC_HELP_STRING([--disable-sspi],[Disable SSPI]), | ||||
| [ case "$enableval" in | ||||
|   yes) | ||||
|        if test "$ac_cv_native_windows" = "yes"; then | ||||
|          AC_MSG_RESULT(yes) | ||||
|          AC_DEFINE(USE_WINDOWS_SSPI, 1, [to enable SSPI support]) | ||||
|          AC_SUBST(USE_WINDOWS_SSPI) | ||||
|          curl_sspi_msg="yes" | ||||
|        else | ||||
|          AC_MSG_RESULT(no) | ||||
|          AC_MSG_WARN([--enable-sspi Ignored. Only supported on native Windows builds.]) | ||||
|        fi | ||||
|        ;; | ||||
|   *) | ||||
|        AC_MSG_RESULT(no) | ||||
| @@ -2032,9 +2292,23 @@ if test "x$ws2" = "xyes"; then | ||||
|   dnl end. | ||||
|  | ||||
|   LIBS="$LIBS -lws2_32" | ||||
|   TEST_SERVER_LIBS="$TEST_SERVER_LIBS -lws2_32" | ||||
|  | ||||
| fi | ||||
|  | ||||
| dnl | ||||
| dnl All the library dependencies put into $LIB apply to libcurl only. | ||||
| dnl Those in $CURL_LIBS apply to the curl command-line client only. | ||||
| dnl Those in $TEST_SERVER_LIBS apply to test servers only. | ||||
| dnl Those in $ALL_LIBS apply to all targets, including test targets. | ||||
| dnl | ||||
| LIBCURL_LIBS=$LIBS | ||||
|  | ||||
| AC_SUBST(LIBCURL_LIBS) | ||||
| AC_SUBST(CURL_LIBS) | ||||
| AC_SUBST(TEST_SERVER_LIBS) | ||||
| LIBS=$ALL_LIBS  dnl LIBS is a magic variable that's used for every link | ||||
|  | ||||
| AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes) | ||||
|  | ||||
| AC_CONFIG_FILES([Makefile \ | ||||
| @@ -2076,6 +2350,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | ||||
|   Install prefix:  ${prefix} | ||||
|   Compiler:        ${CC} | ||||
|   SSL support:     ${curl_ssl_msg} | ||||
|   SSH support:     ${curl_ssh_msg} | ||||
|   zlib support:    ${curl_zlib_msg} | ||||
|   krb4 support:    ${curl_krb4_msg} | ||||
|   GSSAPI support:  ${curl_gss_msg} | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 2001 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 2001 - 2007, 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 | ||||
| @@ -181,7 +181,16 @@ while test $# -gt 0; do | ||||
|        	;; | ||||
|  | ||||
|     --libs) | ||||
|        	echo -L@libdir@ -lcurl @LDFLAGS@ @LIBS@ | ||||
| 	if test "X@libdir@" != "X/usr/lib"; then | ||||
| 	   CURLLIBDIR="-L@libdir@ " | ||||
| 	else | ||||
| 	   CURLLIBDIR="" | ||||
| 	fi | ||||
| 	if test "X@REQUIRE_LIB_DEPS@" = "Xyes"; then | ||||
| 	  echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBCURL_LIBS@ @LIBS@ | ||||
| 	else | ||||
| 	  echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBS@ | ||||
| 	fi | ||||
| 	;; | ||||
|  | ||||
|     *) | ||||
|   | ||||
| @@ -142,8 +142,8 @@ Rexx | ||||
|  | ||||
| Ruby | ||||
|  | ||||
|   Written by Hirotaka Matsuyuki | ||||
|   http://www.d1.dion.ne.jp/~matuyuki/ruby.html | ||||
|   Written by Ross Bamford | ||||
|   http://curb.rubyforge.org/ | ||||
|  | ||||
| Scheme | ||||
|  | ||||
| @@ -182,7 +182,7 @@ Q | ||||
| wxWidgets | ||||
|  | ||||
|   Written by Casey O'Donnell | ||||
|   http://homepage.mac.com/codonnell/wxcurldav/ | ||||
|   http://wxcode.sourceforge.net/components/wxcurl/ | ||||
|  | ||||
| XBLite | ||||
|  | ||||
|   | ||||
| @@ -17,7 +17,9 @@ Join the Community | ||||
|  you start sending patches! We prefer patches and discussions being held on | ||||
|  the mailing list(s), not sent to individuals. | ||||
|  | ||||
| The License Issue | ||||
|  We also hang out on IRC in #curl on irc.freenode.net | ||||
|  | ||||
| License | ||||
|  | ||||
|  When contributing with code, you agree to put your changes and new code under | ||||
|  the same license curl and libcurl is already using unless stated and agreed | ||||
| @@ -43,9 +45,10 @@ The License Issue | ||||
|  | ||||
| What To Read | ||||
|  | ||||
|  Source code, the man pages, the INTERNALS document, the TODO, the most recent | ||||
|  CHANGES. Just lurking on the libcurl mailing list is gonna give you a lot of | ||||
|  insights on what's going on right now. Asking there is a good idea too. | ||||
|  Source code, the man pages, the INTERNALS document, TODO, KNOWN_BUGS, the | ||||
|  most recent CHANGES. Just lurking on the libcurl mailing list is gonna give | ||||
|  you a lot of insights on what's going on right now. Asking there is a good | ||||
|  idea too. | ||||
|  | ||||
| Naming | ||||
|  | ||||
| @@ -170,3 +173,21 @@ How To Make a Patch | ||||
|  | ||||
|         http://gnuwin32.sourceforge.net/packages/patch.htm | ||||
|         http://gnuwin32.sourceforge.net/packages/diffutils.htm | ||||
|  | ||||
| How to get your patches into the libcurl sources | ||||
|  | ||||
|  1. Submit your patch to the curl-library mailing list | ||||
|  | ||||
|  2. Make the patch against as recent sources as possible. | ||||
|  | ||||
|  3. Make sure your patch adheres to the source indent and coding style of | ||||
|     already existing source code. Failing to do so just adds more work for me. | ||||
|  | ||||
|  4. Respond to replies on the list about the patch and answer questions and/or | ||||
|     fix nits/flaws. This is very important. I will take lack of replies as a | ||||
|     sign that you're not very anxious to get your patch accepted and I tend to | ||||
|     simply drop such patches from my TODO list. | ||||
|  | ||||
|  5. If you've followed the above mentioned paragraphs and your patch still | ||||
|     hasn't been incorporated after some weeks, consider resubmitting them to | ||||
|     the list. | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
|   Date: May 15, 2006 | ||||
|   Date: February 11, 2007 | ||||
|   Author: Daniel Stenberg <daniel@haxx.se> | ||||
|   URL: http://curl.haxx.se/legal/distro-dilemma.html | ||||
|  | ||||
| Condition | ||||
|  | ||||
|  This document is written to describe the situation as it is right | ||||
|  now. libcurl 7.15.3 is currently the latest version available. Things may of | ||||
|  This document is written to describe the situation as it is right now. | ||||
|  libcurl 7.16.1 is currently the latest version available. Things may of | ||||
|  course change in the future. | ||||
|  | ||||
|  This document reflects my view and understanding of these things. Please tell | ||||
| @@ -48,24 +48,34 @@ Part of the Operating System | ||||
|  Debian does however not take this stance and has officially(?) claimed that | ||||
|  OpenSSL is not a required part of the Debian operating system | ||||
|  | ||||
|  Some people claim that this paragraph cannot be exploited this way by a Linux | ||||
|  distro, but I am not a lawyer and that is a discussion left outside of this | ||||
|  document. | ||||
|  | ||||
| GnuTLS | ||||
|  | ||||
|  With the release of libcurl 7.14.0 (May 2005), libcurl can now get built to | ||||
|  use GnuTLS instead of OpenSSL. GnuTLS is an LGPL[7] licensed library that | ||||
|  offers a matching set of features as OpenSSL does. Now, you can build and | ||||
|  distribute an TLS/SSL capable libcurl without including any Original BSD | ||||
|  licensed code. | ||||
|  Since May 2005 libcurl can get built to use GnuTLS instead of OpenSSL. GnuTLS | ||||
|  is an LGPL[7] licensed library that offers a matching set of features as | ||||
|  OpenSSL does. Now, you can build and distribute an TLS/SSL capable libcurl | ||||
|  without including any Original BSD licensed code. | ||||
|  | ||||
|  I believe Debian is the first distro to provide libcurl/GnutTLS packages. | ||||
|  I believe Debian is the first (only?) distro that provides libcurl/GnutTLS | ||||
|  packages. | ||||
|  | ||||
| GnuTLS vs OpenSSL | ||||
| yassl | ||||
|  | ||||
|  While these two libraries offer similar features, they are not equal. Both | ||||
|  libraries have features the other one lacks. libcurl does not (yet) offer a | ||||
|  standardized stable ABI if you decide to switch from using libcurl-openssl to | ||||
|  libcurl-gnutls or vice versa. The GnuTLS support is very recent in libcurl | ||||
|  and it has not been tested nor used very extensively, while the OpenSSL | ||||
|  equivalent code has been used and thus matured for more than seven (7) years. | ||||
|  libcurl can get also get built to use yassl for the TLS/SSL layer. yassl is a | ||||
|  GPL[3] licensed library. | ||||
|  | ||||
|  | ||||
| GnuTLS vs OpenSSL vs yassl | ||||
|  | ||||
|  While these three libraries offer similar features, they are not equal. | ||||
|  libcurl does not (yet) offer a standardized stable ABI if you decide to | ||||
|  switch from using libcurl-openssl to libcurl-gnutls or vice versa. The GnuTLS | ||||
|  and yassl support is very recent in libcurl and it has not been tested nor | ||||
|  used very extensively, while the OpenSSL equivalent code has been used and | ||||
|  thus matured since 1999. | ||||
|  | ||||
|  GnuTLS | ||||
|    - LGPL licensened | ||||
| @@ -82,7 +92,12 @@ GnuTLS vs OpenSSL | ||||
|    - provides crypto functions libcurl uses for NTLM | ||||
|    - libcurl can do non-blocking connects with it in 7.15.4 and later | ||||
|  | ||||
| The Better License, Original BSD or LGPL? | ||||
|  yassl | ||||
|    - GPL licensed | ||||
|    - much untested and unproven in the real work by (lib)curl users so we don't | ||||
|      know a lot about restrictions or benefits from using this | ||||
|  | ||||
| The Better License, Original BSD, GPL or LGPL? | ||||
|  | ||||
|  It isn't obvious or without debate to any objective interested party that | ||||
|  either of these licenses are the "better" or even the "preferred" one in a | ||||
| @@ -91,8 +106,8 @@ The Better License, Original BSD or LGPL? | ||||
|  Instead, I think we should accept the fact that the SSL/TLS libraries and | ||||
|  their different licenses will fit different applications and their authors | ||||
|  differently depending on the applications' licenses and their general usage | ||||
|  pattern (considering how LGPL libraries for example can be burdensome for | ||||
|  embedded systems usage). | ||||
|  pattern (considering how GPL and LGPL libraries for example can be burdensome | ||||
|  for embedded systems usage). | ||||
|  | ||||
|  In Debian land, there seems to be a common opinion that LGPL is "maximally | ||||
|  compatible" with apps while Original BSD is not. Like this: | ||||
| @@ -101,8 +116,8 @@ The Better License, Original BSD or LGPL? | ||||
|  | ||||
| More SSL Libraries | ||||
|  | ||||
|  In libcurl, there's no stopping us here. There are at least a few more Open | ||||
|  Source/Free SSL/TLS libraries and we would very much like to support them as | ||||
|  In libcurl, there's no stopping us here. There are more Open Source/Free | ||||
|  SSL/TLS libraries out there and we would very much like to support them as | ||||
|  well, to offer application authors an even wider scope of choice. | ||||
|  | ||||
| Application Angle of this Problem | ||||
| @@ -137,7 +152,7 @@ Project cURL Angle of this Problem | ||||
| Distro Angle of this Problem | ||||
|  | ||||
|  To my knowledge there is only one distro that ships libcurl built with either | ||||
|  one of the SSL libs supported. | ||||
|  OpenSSL or GnuTLS. | ||||
|  | ||||
|  Debian Linux is now (since mid September 2005) providing two different | ||||
|  libcurl packages, one for libcurl built with OpenSSL and one built with | ||||
| @@ -145,56 +160,6 @@ Distro Angle of this Problem | ||||
|  single system simultaneously. This has been said to be a transitional system | ||||
|  not desired to keep in the long run. | ||||
|  | ||||
| Fixing the Only Problem | ||||
|  | ||||
|  The only problem is thus for distributions that want to offer libcurl | ||||
|  versions built with more than one SSL/TLS library. | ||||
|  | ||||
|  Since multiple libcurl binaries using different names are ruled out, we need | ||||
|  to come up with a way to have one single libcurl that someone uses different | ||||
|  underlying libraries. The best(?) approach currently suggested involves this: | ||||
|  | ||||
|  A new intermediate library (named lib2 so far in the discussions) with the | ||||
|  single purpose of providing libcurl with SSL/TLS capabilities. It would have | ||||
|  a unified API and ABI no matter what underlying library it would use. | ||||
|  | ||||
|  There would be one lib2 binary provided for each supported SSL/TLS library. | ||||
|  For example: lib2-openssl, lib2-gnutls, lib2-yassl, lib2-matrixssl and | ||||
|  lib2-nossl. Yes, take note of the last one that provides the lib2 ABI but | ||||
|  that lacks the actual powers. | ||||
|  | ||||
|  When libcurl is built and linked, it will be linked against a lib2 with the | ||||
|  set ABI. | ||||
|  | ||||
|  When you link an app against libcurl, it would also need to provide one of | ||||
|  the (many) lib2 libs to decide what approach that fits the app. An app that | ||||
|  doesn't want SSL at all would still need to link with the lib2-nossl lib. | ||||
|  | ||||
|  GPL apps can pick the lib2-gnutls, others may pick the lib2-openssl. | ||||
|  | ||||
|  This concept works equally well both for shared and static libraries. | ||||
|  | ||||
|  A positive side effect of this approach could be a more generic "de facto" | ||||
|  standard API for SSL/TLS libraries. | ||||
|  | ||||
| When Will This Happen | ||||
|  | ||||
|  This is not a problem in curl, it doesn't solve any actual technical problems | ||||
|  in our project. Don't hold your breath for this to happen very soon (if at | ||||
|  all) unless you step forward and contribute. | ||||
|  | ||||
|  The suggestion that is outlined above is still only a suggestion. Feel free | ||||
|  to bring a better idea! | ||||
|  | ||||
|  Also, to keep in mind: I don't want this new concept to have too much of an | ||||
|  impact on the existing code. Preferably it should be possible to build the | ||||
|  code like today (without the use of lib2), should you decide to ignore the | ||||
|  problems outlined in this document. | ||||
|  | ||||
|  Work on this was suggested by Richard Atterer: | ||||
|  | ||||
|         http://curl.haxx.se/mail/lib-2005-09/0066.html | ||||
|  | ||||
| Footnotes | ||||
|  | ||||
|  [1] = http://www.xfree86.org/3.3.6/COPYRIGHT2.html#6 | ||||
|   | ||||
							
								
								
									
										63
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| Updated: November 2, 2005 (http://curl.haxx.se/docs/faq.html) | ||||
| Updated: February 11, 2007 (http://curl.haxx.se/docs/faq.html) | ||||
|                                   _   _ ____  _ | ||||
|                               ___| | | |  _ \| | | ||||
|                              / __| | | | |_) | | | ||||
| @@ -114,10 +114,10 @@ FAQ | ||||
|   libcurl | ||||
|  | ||||
|     A free and easy-to-use client-side URL transfer library, supporting FTP, | ||||
|     FTPS, HTTP, HTTPS, TELNET, DICT, FILE and LDAP.  libcurl supports | ||||
|     HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading, kerberos, HTTP | ||||
|     form based upload, proxies, cookies, user+password authentication, file | ||||
|     transfer resume, http proxy tunneling and more! | ||||
|     FTPS, HTTP, HTTPS, SCP, SFTP, TFTP, TELNET, DICT, FILE and LDAP.  libcurl | ||||
|     supports HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading, kerberos, | ||||
|     HTTP form based upload, proxies, cookies, user+password authentication, | ||||
|     file transfer resume, http proxy tunneling and more! | ||||
|  | ||||
|     libcurl is highly portable, it builds and works identically on numerous | ||||
|     platforms, including Solaris, NetBSD, FreeBSD, OpenBSD, Darwin, HPUX, | ||||
| @@ -132,7 +132,8 @@ FAQ | ||||
|     A command line tool for getting or sending files using URL syntax. | ||||
|  | ||||
|     Since curl uses libcurl, it supports a range of common Internet protocols, | ||||
|     currently including HTTP, HTTPS, FTP, FTPS, LDAP, DICT, TELNET and FILE. | ||||
|     currently including HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, LDAP, DICT, | ||||
|     TELNET and FILE. | ||||
|  | ||||
|   We pronounce curl and cURL with an initial k sound: [kurl]. | ||||
|  | ||||
| @@ -156,7 +157,7 @@ FAQ | ||||
|  | ||||
|   1.3 What is curl not? | ||||
|  | ||||
|   Curl is *not* a wget clone. That is a common misconception.  Never, during | ||||
|   Curl is not a wget clone. That is a common misconception.  Never, during | ||||
|   curl's development, have we intended curl to replace wget or compete on its | ||||
|   market. Curl is targeted at single-shot file transfers. | ||||
|  | ||||
| @@ -171,9 +172,10 @@ FAQ | ||||
|   Curl is not a PHP tool, even though it works perfectly well when used from | ||||
|   or with PHP (when using the PHP/CURL module). | ||||
|  | ||||
|   Curl is not a single-OS program. Curl exists, compiles, builds and runs | ||||
|   under a wide range of operating systems, including all modern Unixes (and a | ||||
|   bunch of older ones too), Windows, Amiga, BeOS, OS/2, OS X, QNX etc. | ||||
|   Curl is not a program for a single operating system. Curl exists, compiles, | ||||
|   builds and runs under a wide range of operating systems, including all | ||||
|   modern Unixes (and a bunch of older ones too), Windows, Amiga, BeOS, OS/2, | ||||
|   OS X, QNX etc. | ||||
|  | ||||
|   1.4 When will you make curl do XXXX ? | ||||
|  | ||||
| @@ -211,7 +213,7 @@ FAQ | ||||
|   improvements and have them inserted in the main sources (of course on the | ||||
|   condition that developers agree on that the fixes are good). | ||||
|  | ||||
|   The full list of the more than 450 contributors is found in the docs/THANKS | ||||
|   The full list of the more than 530 contributors is found in the docs/THANKS | ||||
|   file. | ||||
|  | ||||
|   curl is developed by a community, with Daniel at the wheel. | ||||
| @@ -287,13 +289,13 @@ FAQ | ||||
|  | ||||
|   Some facts to use as input to the math: | ||||
|  | ||||
|   curl packages have been downloaded from the curl.haxx.se site well over a | ||||
|   million times. curl is installed by default with most Linux | ||||
|   curl packages are downloaded from the curl.haxx.se and mirrors almost one | ||||
|   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 40 known named companies use curl in commercial environments and | ||||
|   More than 60 known named companies use curl in commercial environments and | ||||
|   products. More than 100 known named open source projects depend on | ||||
|   (lib)curl. | ||||
|  | ||||
| @@ -305,6 +307,9 @@ FAQ | ||||
|   based web servers. A guess is that a fair amount of these Linux | ||||
|   installations have curl installed. | ||||
|  | ||||
|   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 | ||||
| @@ -338,8 +343,6 @@ FAQ | ||||
|     ./configure places the -L/usr/local/ssl/lib early enough in the command | ||||
|     line to make things work | ||||
|  | ||||
|     Solution submitted by: Bob Allison <allisonb@users.sourceforge.net> | ||||
|  | ||||
|     2.1.2 only the libssl lib is missing | ||||
|  | ||||
|     If all include files and the libcrypto lib is present, with only the | ||||
| @@ -355,10 +358,10 @@ FAQ | ||||
|  | ||||
|   2.2 Does curl work/build with other SSL libraries? | ||||
|  | ||||
|   Curl has been written to use OpenSSL or GnuTLS, although there should not be | ||||
|   many problems using a different library. If anyone does "port" curl to use a | ||||
|   different SSL library, we are of course very interested in getting the | ||||
|   patch! | ||||
|   Curl has been written to use OpenSSL, GnuTLS, yassl or NSS, although there | ||||
|   should not be many problems using a different library. If anyone does "port" | ||||
|   curl to use a different SSL library, we are of course very interested in | ||||
|   getting the patch! | ||||
|  | ||||
|   2.3 Where can I find a copy of LIBEAY32.DLL? | ||||
|  | ||||
| @@ -464,10 +467,12 @@ FAQ | ||||
|   install and use them, in the libcurl section of the curl web site: | ||||
|   http://curl.haxx.se/libcurl/ | ||||
|  | ||||
|   In February 2003, there are interfaces available for the following | ||||
|   languages: Basic, C, C++, Cocoa, Dylan, Euphoria, Java, Lua, Object-Pascal, | ||||
|   Pascal, Perl, PHP, PostgreSQL, Python, Rexx, Ruby, Scheme and Tcl. By the | ||||
|   time you read this, additional ones may have appeared! | ||||
|   In February 2007, there are interfaces available for the following | ||||
|   languages: Ada95, Basic, C, C++, Ch, Cocoa, D, Dylan, Euphoria, Ferite, | ||||
|   Gambas, glib/GTK+, Java, Lisp, Lua, Mono, .NET, Object-Pascal, O'Caml, | ||||
|   Pascal, Perl, PHP, PostgreSQL, Python, R, Rexx, Ruby, Scheme, S-Lang, | ||||
|   Smalltalk, SPL, Tcl, Visual Basic, Q, wxwidgets and XBLite. By the time you | ||||
|   read this, additional ones may have appeared! | ||||
|  | ||||
|   3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP? | ||||
|  | ||||
| @@ -750,7 +755,9 @@ FAQ | ||||
|   4.9 Curl can't authenticate to the server that requires NTLM? | ||||
|  | ||||
|   This is supported in curl 7.10.6 or later. No earlier curl version knows | ||||
|   of this magic. | ||||
|   of this magic. Later versions require the OpenSSL or Microsoft Windows  | ||||
|   libraries to provide this functionality. Using GnuTLS or NSS libraries will  | ||||
|   not provide NTLM authentication functionality in curl. | ||||
|  | ||||
|   NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You | ||||
|   should not use such ones. | ||||
| @@ -839,6 +846,8 @@ FAQ | ||||
|  | ||||
|     http://www.gnu.org/software/gnutls/manual/html_node/Multi_002dthreaded-applications.html | ||||
|  | ||||
|   No special locking is needed with a NSS-powered libcurl. NSS is thread-safe. | ||||
|  | ||||
|   5.2 How can I receive all data into a large memory chunk? | ||||
|  | ||||
|   [ See also the examples/getinmemory.c source ] | ||||
| @@ -896,8 +905,6 @@ FAQ | ||||
|   Similarly, if you use CURLOPT_READDATA you must also specify | ||||
|   CURLOPT_READFUNCTION. | ||||
|  | ||||
|   (Provided by Joel DeYoung and Bob Schader) | ||||
|  | ||||
|   5.6 What about Keep-Alive or persistent connections? | ||||
|  | ||||
|   curl and libcurl have excellent support for persistent connections when | ||||
| @@ -916,8 +923,6 @@ FAQ | ||||
|   options to the command line compiler. /MD (linking against MSVCRT dll) seems | ||||
|   to be the most commonly used option. | ||||
|  | ||||
|   (Provided by Andrew Francis) | ||||
|  | ||||
|   When building an application that uses the static libcurl library, you must | ||||
|   add -DCURL_STATICLIB to your CFLAGS. Otherwise the linker will look for | ||||
|   dynamic import symbols. If you get linker error like "unknown symbol | ||||
|   | ||||
| @@ -33,6 +33,7 @@ libcurl supports | ||||
|  - supports large files (>2GB and >4GB) both upload/download | ||||
|  - replacable memory functions (malloc, free, realloc, etc) | ||||
|  - asynchronous name resolving (*6) | ||||
|  - both a push and a pull style interface | ||||
|  | ||||
| HTTP | ||||
|  - HTTP/1.1 compliant (optionally uses 1.0) | ||||
| @@ -40,6 +41,7 @@ HTTP | ||||
|  - PUT | ||||
|  - HEAD | ||||
|  - POST | ||||
|  - Pipelining | ||||
|  - multipart formpost (RFC1867-style) | ||||
|  - authentication: Basic, Digest, NTLM(*1), GSS-Negotiate/Negotiate(*3) and | ||||
|    SPNEGO (*4) to server and proxy | ||||
| @@ -94,6 +96,13 @@ FTPS (*1) | ||||
|  - explicit "AUTH TSL" and "AUTH SSL" usage to "upgrade" plain ftp:// | ||||
|    connection to use SSL for both or one of the connections | ||||
|  | ||||
| SCP (*8) | ||||
|  - both password and public key auth | ||||
|  | ||||
| SFTP (*8) | ||||
|  - both password and public key auth | ||||
|  - with custom commands sent before/after the transfer | ||||
|  | ||||
| TFTP | ||||
|  - download / upload | ||||
|  | ||||
| @@ -116,10 +125,11 @@ FILE | ||||
| FOOTNOTES | ||||
| ========= | ||||
|  | ||||
|   *1 = requires OpenSSL or GnuTLS | ||||
|   *1 = requires OpenSSL, GnuTLS, NSS or yassl | ||||
|   *2 = requires OpenLDAP | ||||
|   *3 = requires a GSSAPI-compliant library, such as Heimdal or similar. | ||||
|   *4 = requires FBopenssl | ||||
|   *5 = requires a krb4 library, such as the MIT one or similar. | ||||
|   *6 = requires c-ares | ||||
|   *7 = requires OpenSSL specificly, as GnuTLS only supports SSLv3 and TLSv1 | ||||
|   *7 = requires OpenSSL or NSS, as GnuTLS only supports SSLv3 and TLSv1 | ||||
|   *8 = requires libssh2 | ||||
|   | ||||
							
								
								
									
										74
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										74
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -140,10 +140,36 @@ UNIX | ||||
|      yassl with its OpenSSL emulation enabled and point to that directory root | ||||
|      with configure --with-ssl. | ||||
|  | ||||
|      To build with NSS support instead of OpenSSL for SSL/TLS, note that | ||||
|      you need to use both --without-ssl and --with-nss. | ||||
|  | ||||
|  | ||||
| Win32 | ||||
| ===== | ||||
|  | ||||
|    Building Windows DLLs and C run-time (CRT) linkage issues | ||||
|    --------------------------------------------------------- | ||||
|  | ||||
|    As a general rule, building a DLL with static CRT linkage is highly | ||||
|    discouraged, and intermixing CRTs in the same app is something to | ||||
|    avoid at any cost. | ||||
|  | ||||
|    Reading and comprehension of Microsoft Knowledge Base articles | ||||
|    KB94248 and KB140584 is a must for any Windows developer. Especially | ||||
|    important is full understanding if you are not going to follow the | ||||
|    advice given above. | ||||
|  | ||||
|    KB94248  - How To Use the C Run-Time | ||||
|               http://support.microsoft.com/kb/94248/en-us | ||||
|  | ||||
|    KB140584 - How to link with the correct C Run-Time (CRT) library | ||||
|               http://support.microsoft.com/kb/140584/en-us | ||||
|  | ||||
|    If your app is misbehaving in some strange way, or it is suffering | ||||
|    from memory corruption, before asking for further help, please try | ||||
|    first to rebuild every single library your app uses as well as your | ||||
|    app using the debug multithreaded dynamic C runtime. | ||||
|  | ||||
|    MingW32 | ||||
|    ------- | ||||
|  | ||||
| @@ -153,7 +179,16 @@ Win32 | ||||
|  | ||||
|    If you have any problems linking libraries or finding header files, be sure | ||||
|    to verify that the provided "Makefile.m32" files use the proper paths, and | ||||
|    adjust as necessary. | ||||
|    adjust as necessary. It is also possible to override these paths with  | ||||
|    environment variables, for example: | ||||
|  | ||||
|      set ZLIB_PATH=c:\zlib-1.2.3 | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8d | ||||
|      set LIBSSH2_PATH=c:\libssh2-0.15 | ||||
|  | ||||
|    ATTENTION: if you want to build with libssh2 support you have to use latest | ||||
|    sources fetched from CVS - the current 0.14 release will NOT work! | ||||
|    Use 'make mingw32-ssh2-ssl' to build curl with SSH2 and SSL enabled. | ||||
|  | ||||
|    Cygwin | ||||
|    ------ | ||||
| @@ -184,7 +219,7 @@ Win32 | ||||
|    documentation on how to compile zlib. Define the ZLIB_PATH environment | ||||
|    variable to the location of zlib.h and zlib.lib, for example: | ||||
|  | ||||
|      set ZLIB_PATH=c:\zlib-1.2.1 | ||||
|      set ZLIB_PATH=c:\zlib-1.2.3 | ||||
|  | ||||
|    Then run 'nmake vc-zlib' in curl's root directory. | ||||
|  | ||||
| @@ -198,7 +233,7 @@ Win32 | ||||
|    Before running nmake define the OPENSSL_PATH environment variable with | ||||
|    the root/base directory of OpenSSL, for example: | ||||
|  | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.7d | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8d | ||||
|  | ||||
|    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 | ||||
| @@ -542,21 +577,32 @@ eCos | ||||
|  | ||||
| Minix | ||||
| ===== | ||||
|    curl can be compiled on Minix 3 using gcc (ACK has a few problems due | ||||
|    to mismatched headers and libraries as of ver. 3.1.2).  The gcc and bash | ||||
|    packages must be installed first.  The default heap size allocated to | ||||
|    bash is inadequate for running configure and will result in out of memory | ||||
|    errors.  Increase it with the command: | ||||
|    curl can be compiled on Minix 3 using gcc or ACK (starting with | ||||
|    ver. 3.1.3).  The gcc and bash packages must be installed first. | ||||
|    The default heap size allocated to bash is inadequate for running | ||||
|    configure and will result in out of memory errors.  Increase it with | ||||
|    the command: | ||||
|  | ||||
|      chmem =2048000 /usr/local/bin/bash | ||||
|  | ||||
|    Make sure gcc and bash are in the PATH then configure curl with a | ||||
|    command like this: | ||||
|    Make sure gcc and bash are in the PATH with the command: | ||||
|     | ||||
|      ./configure GREP=/usr/bin/grep AR=/usr/gnu/bin/gar --disable-ldap | ||||
|      export PATH=/usr/gnu/bin:$PATH | ||||
|     | ||||
|    then configure curl with a command like this: | ||||
|  | ||||
|      ./configure CC=gcc GREP=grep AR=/usr/gnu/bin/gar --disable-ldap | ||||
|  | ||||
|    Then simply run 'make'. | ||||
|  | ||||
|    To compile with the ACK C compiler: | ||||
|  | ||||
|      chmem =1024000 /usr/lib/em_cemcom.ansi | ||||
|      chmem =512000 /usr/lib/i386/as | ||||
|      ./configure CC=cc LD=cc GREP=grep CPPFLAGS=-D_POSIX_SOURCE=1 \ | ||||
|                  --disable-ldap | ||||
|      make | ||||
|  | ||||
|  | ||||
| CROSS COMPILE | ||||
| ============= | ||||
| @@ -676,6 +722,7 @@ PORTS | ||||
|         - PowerPC Linux | ||||
|         - PowerPC Mac OS 9 | ||||
|         - PowerPC Mac OS X | ||||
|         - SuperH4 Linux 2.6.X | ||||
|         - SINIX-Z v5 | ||||
|         - Sparc Linux | ||||
|         - Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8, 9, 10 | ||||
| @@ -692,7 +739,7 @@ PORTS | ||||
|         - i386 FreeBSD | ||||
|         - i386 HURD | ||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 | ||||
|         - i386 MINIX 3.1.2 | ||||
|         - i386 MINIX 3.1 | ||||
|         - i386 NetBSD | ||||
|         - i386 Novell NetWare | ||||
|         - i386 OS/2 | ||||
| @@ -717,3 +764,6 @@ OpenSSL   http://www.openssl.org | ||||
| MingW     http://www.mingw.org | ||||
| OpenLDAP  http://www.openldap.org | ||||
| Zlib      http://www.gzip.org/zlib/ | ||||
| libssh2   http://www.libssh2.org | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -3,6 +3,30 @@ join in and help us correct one or more of these! Also be sure to check the | ||||
| changelog of the current development status, as one or more of these problems | ||||
| may have been fixed since this was written! | ||||
|  | ||||
| 44. --ftp-method nocwd does not handle URLs ending with a slash properly (it | ||||
|   should list the contents of that directory). See test case 351. | ||||
|  | ||||
| 43. There seems to be a problem when connecting to the Microsoft telnet server. | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1720605 | ||||
|  | ||||
| 41. When doing an operation over FTP that requires the ACCT command (but not | ||||
|   when logging in), the operation will fail since libcurl doesn't detect this | ||||
|   and thus fails to issue the correct command: | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1693337 | ||||
|  | ||||
| 39. Steffen Rumler's Race Condition in Curl_proxyCONNECT: | ||||
|   http://curl.haxx.se/mail/lib-2007-01/0045.html | ||||
|  | ||||
| 38. Kumar Swamy Bhatt's problem in ftp/ssl "LIST" operation: | ||||
|   http://curl.haxx.se/mail/lib-2007-01/0103.html | ||||
|  | ||||
| 37. Having more than one connection to the same host when doing NTLM | ||||
|   authentication (with performs multiple "passes" and authenticates a | ||||
|   connection rather than a HTTP request), and particularly when using the | ||||
|   multi interface, there's a risk that libcurl will re-use a wrong connection | ||||
|   when doing the different passes in the NTLM negotiation and thus fail to | ||||
|   negotiate (in seemingly mysterious ways). | ||||
|  | ||||
| 35. Both SOCKS5 and SOCKS4 proxy connections are done blocking, which is very | ||||
|   bad when used with the multi interface. | ||||
|  | ||||
| @@ -44,16 +68,14 @@ may have been fixed since this was written! | ||||
|   "system context" will make it use wrong(?) user name - at least when compared | ||||
|   to what winhttp does. See http://curl.haxx.se/bug/view.cgi?id=1281867 | ||||
|  | ||||
| 25. When doing a CONNECT request with curl it doesn't properly handle if the | ||||
|   proxy closes the connection within the authentication "negotiation phase". | ||||
|   Like if you do HTTPS or similar over a proxy and you use perhaps | ||||
|   --proxy-anyauth. | ||||
| 23. SOCKS-related problems: | ||||
|   A) libcurl doesn't support SOCKS for IPv6. | ||||
|   B) libcurl doesn't support FTPS over a SOCKS proxy. | ||||
|   C) We don't have any test cases for SOCKS proxy. | ||||
|   E) libcurl doesn't support active FTP over a SOCKS proxy | ||||
|  | ||||
| 23. We don't support SOCKS for IPv6. We don't support FTPS over a SOCKS proxy. | ||||
|   We don't have any test cases for SOCKS proxy. We probably have even more | ||||
|   bugs and lack of features when a SOCKS proxy is used. And there seem to be a | ||||
|   problem with SOCKS when doing FTP: See | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1371540 | ||||
|   We probably have even more bugs and lack of features when a SOCKS proxy is | ||||
|   used. | ||||
|  | ||||
| 22. Sending files to a FTP server using curl on VMS, might lead to curl | ||||
|   complaining on "unaligned file size" on completion. The problem is related | ||||
| @@ -95,9 +117,6 @@ may have been fixed since this was written! | ||||
|   acknowledged after the actual TCP connect (during the SOCKS "negotiate" | ||||
|   phase). | ||||
|  | ||||
| 11. Using configure --disable-[protocol] may cause 'make test' to fail for | ||||
|   tests using the disabled protocol(s). | ||||
|  | ||||
| 10. To get HTTP Negotiate authentication to work fine, you need to provide a | ||||
|   (fake) user name (this concerns both curl and the lib) because the code | ||||
|   wrongly only considers authentication if there's a user name provided. | ||||
|   | ||||
| @@ -16,7 +16,7 @@ clause). You may still build your own copies that use them all, but | ||||
| distributing them as binaries would be to violate the GPL license - unless you | ||||
| accompany your license with an exception[2]. This particular problem was | ||||
| addressed when the Modified BSD license was created, which does not have the | ||||
| annoncement clause that collides with GPL. | ||||
| announcement clause that collides with GPL. | ||||
|  | ||||
| libcurl http://curl.haxx.se/docs/copyright.html | ||||
|  | ||||
| @@ -28,7 +28,7 @@ libcurl http://curl.haxx.se/docs/copyright.html | ||||
| OpenSSL http://www.openssl.org/source/license.html | ||||
|  | ||||
|         (May be used for SSL/TLS support) Uses an Original BSD-style license | ||||
|         with an announement clause that makes it "incompatible" with GPL. You | ||||
|         with an announcement clause that makes it "incompatible" with GPL. You | ||||
|         are not allowed to ship binaries that link with OpenSSL that includes | ||||
|         GPL code (unless that specific GPL code includes an exception for | ||||
|         OpenSSL - a habit that is growing more and more common). If OpenSSL's | ||||
| @@ -47,6 +47,14 @@ yassl   http://www.yassl.com/ | ||||
|         (May be used for SSL/TLS support) Uses the GPL[1] license. If this is | ||||
|         a problem for you, consider using OpenSSL or GnuTLS instead. | ||||
|  | ||||
| NSS     http://www.mozilla.org/projects/security/pki/nss/ | ||||
|  | ||||
|         (May be used for SSL/TLS support) Is covered by the MPL[4] license, | ||||
|         the GPL[1] license and the LGPL[3] license. You may choose to license | ||||
|         the code under MPL terms, GPL terms, or LGPL terms. These licenses | ||||
|         grant you different permissions and impose different obligations. You | ||||
|         should select the license that best meets your needs. | ||||
|  | ||||
| c-ares  http://daniel.haxx.se/projects/c-ares/license.html | ||||
|  | ||||
|         (Used for asynchronous name resolves) Uses an MIT license that is very | ||||
| @@ -88,10 +96,10 @@ fbopenssl | ||||
|         that it uses the OpenSSL license and thus shares the same issues as | ||||
|         described for OpenSSL above. | ||||
|  | ||||
| libidn  http://www.gnu.org/licenses/lgpl.html | ||||
| libidn  http://josefsson.org/libidn/ | ||||
|  | ||||
|         (Used for IDNA support) Uses the GNU Lesser General Public | ||||
|         License. LGPL is a variation of GPL with slightly less aggressive | ||||
|         License [3]. LGPL is a variation of GPL with slightly less aggressive | ||||
|         "copyleft". This license requires more requirements to be met when | ||||
|         distributing binaries, see the license for details. Also note that if | ||||
|         you distribute a binary that includes this library, you must also | ||||
| @@ -104,9 +112,15 @@ OpenLDAP http://www.openldap.org/software/release/license.html | ||||
|         libcurl uses OpenLDAP as a shared library only, I have not heard of | ||||
|         anyone that ships OpenLDAP linked with libcurl in an app. | ||||
|  | ||||
| libssh2 http://www.libssh2.org/ | ||||
|  | ||||
|         (Used for scp and sftp support) libssh2 uses a Modified BSD-style | ||||
|         license. | ||||
|  | ||||
| [1] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html | ||||
| [2] = http://www.fsf.org/licenses/gpl-faq.html#GPLIncompatibleLibs details on | ||||
|       how to write such an exception to the GPL | ||||
| [3] = LGPL - GNU Lesser General Public License: | ||||
|       http://www.gnu.org/licenses/lgpl.html | ||||
| [4] = MPL - Mozilla Public License: | ||||
|       http://www.mozilla.org/MPL/ | ||||
|   | ||||
							
								
								
									
										20
									
								
								docs/MANUAL
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								docs/MANUAL
									
									
									
									
									
								
							| @@ -7,7 +7,7 @@ LATEST VERSION | ||||
|  | ||||
| SIMPLE USAGE | ||||
|  | ||||
|   Get the main page from netscape's web-server: | ||||
|   Get the main page from Netscape's web-server: | ||||
|  | ||||
|         curl http://www.netscape.com/ | ||||
|  | ||||
| @@ -39,6 +39,15 @@ SIMPLE USAGE | ||||
|  | ||||
|         curl --ftp-ssl ftp://files.are.secure.com/secrets.txt | ||||
|  | ||||
|   Get a file from an SSH server using SFTP: | ||||
|  | ||||
|         curl -u username sftp://shell.example.com/etc/issue | ||||
|  | ||||
|   Get a file from an SSH server using SCP using a private key to authenticate: | ||||
|  | ||||
|         curl -u username: --key ~/.ssh/id_dsa --pubkey ~/.ssh/id_dsa.pub \ | ||||
|         	scp://shell.example.com/~/personal.txt | ||||
|  | ||||
|  | ||||
| DOWNLOAD TO A FILE | ||||
|  | ||||
| @@ -79,9 +88,8 @@ USING PASSWORDS | ||||
|  | ||||
|  HTTP | ||||
|  | ||||
|    The HTTP URL doesn't support user and password in the URL string. Curl | ||||
|    does support that anyway to provide a ftp-style interface and thus you can | ||||
|    pick a file like: | ||||
|    Curl also supports user and password in HTTP URLs, thus you can pick a file | ||||
|    like: | ||||
|  | ||||
|         curl http://name:passwd@machine.domain/full/path/to/file | ||||
|  | ||||
| @@ -700,9 +708,9 @@ TIME CONDITIONS | ||||
|         curl -z -local.html http://remote.server.com/remote.html | ||||
|  | ||||
|  You can specify a "free text" date as condition. Tell curl to only download | ||||
|  the file if it was updated since yesterday: | ||||
|  the file if it was updated since January 12, 2012: | ||||
|  | ||||
|         curl -z yesterday http://remote.server.com/remote.html | ||||
|         curl -z "Jan 12 2012" http://remote.server.com/remote.html | ||||
|  | ||||
|  Curl will then accept a wide range of date formats. You always make the date | ||||
|  check the other way around by prepending it with a dash '-'. | ||||
|   | ||||
							
								
								
									
										39
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -4,6 +4,7 @@ | ||||
|  | ||||
|  If you have contributed but are missing here, please let us know! | ||||
|  | ||||
| Adam D. Moss | ||||
| Adrian Schuur | ||||
| Alan Pinstein | ||||
| Albert Chin-A-Young | ||||
| @@ -17,6 +18,7 @@ Alexander Kourakos | ||||
| Alexander Krasnostavsky | ||||
| Alexander Lazic | ||||
| Alexander Zhuravlev | ||||
| Alexey Simak | ||||
| Alexis Carvalho | ||||
| Amol Pattekar | ||||
| Andi Jahja | ||||
| @@ -26,6 +28,7 @@ Andreas Olsson | ||||
| Andreas Rieke | ||||
| Andres Garcia | ||||
| Andrew Benham | ||||
| Andrew Biggs | ||||
| Andrew Bushnell | ||||
| Andrew Francis | ||||
| Andrew Fuller | ||||
| @@ -36,6 +39,7 @@ Angus Mackay | ||||
| Antoine Calando | ||||
| Anton Kalmykov | ||||
| Arkadiusz Miskiewicz | ||||
| Armel Asselin | ||||
| Arve Knudsen | ||||
| Ates Goral | ||||
| Augustus Saunders | ||||
| @@ -43,12 +47,15 @@ Avery Fay | ||||
| Ben Greear | ||||
| Ben Madsen | ||||
| Benjamin Gerard | ||||
| Bernard Leak | ||||
| Bertrand Demiddelaer | ||||
| Bjorn Reese | ||||
| Bj<EFBFBD>rn Stenberg | ||||
| Bob Schader | ||||
| Bogdan Nicula | ||||
| Brad Burdick | ||||
| Bradford Bruce | ||||
| Brendan Jurd | ||||
| Brent Beardsley | ||||
| Brian Akins | ||||
| Brian Dessent | ||||
| @@ -68,6 +75,7 @@ Christian Robottom Reis | ||||
| Christophe Demory | ||||
| Christophe Legry | ||||
| Christopher R. Palmer | ||||
| Ciprian Badescu | ||||
| Clarence Gardner | ||||
| Clifford Wolf | ||||
| Cody Jones | ||||
| @@ -85,6 +93,7 @@ Dan Fandrich | ||||
| Dan Nelson | ||||
| Dan Torop | ||||
| Dan Zitter | ||||
| Daniel Johnson | ||||
| Daniel Stenberg | ||||
| Daniel at touchtunes | ||||
| Darryl House | ||||
| @@ -116,7 +125,9 @@ Dimitris Sarris | ||||
| Dinar | ||||
| Dirk Eddelbuettel | ||||
| Dirk Manske | ||||
| Dmitriy Sergeyev | ||||
| Dmitry Bartsevich | ||||
| Dmitry Rechkin | ||||
| Dolbneff A.V | ||||
| Domenico Andreoli | ||||
| Dominick Meglio | ||||
| @@ -126,6 +137,7 @@ Douglas E. Wegscheid | ||||
| Douglas R. Horner | ||||
| Dov Murik | ||||
| Duane Cathey | ||||
| Duncan Mac-Vicar Prett | ||||
| Dustin Boswell | ||||
| Dylan Ellicott | ||||
| Dylan Salisbury | ||||
| @@ -147,6 +159,7 @@ Erwan Legrand | ||||
| Erwin Authried | ||||
| Eugene Kotlyarov | ||||
| Evan Jordan | ||||
| Eygene Ryabinkin | ||||
| Fabrizio Ammollo | ||||
| Fedor Karpelevitch | ||||
| Felix von Leitner | ||||
| @@ -182,6 +195,7 @@ Gwenole Beauchesne | ||||
| G<EFBFBD>tz Babin-Ebell | ||||
| G<EFBFBD>nter Knauf | ||||
| Hamish Mackenzie | ||||
| Hang Kin Lau | ||||
| Hanno Kranzhoff | ||||
| Hans Steegers | ||||
| Hardeep Singh | ||||
| @@ -191,6 +205,7 @@ Henrik Storner | ||||
| Hzhijun | ||||
| Ian Ford | ||||
| Ian Gulliver | ||||
| Ian Turner | ||||
| Ian Wilkes | ||||
| Ignacio Vazquez-Abrams | ||||
| Igor Polyakov | ||||
| @@ -206,11 +221,13 @@ James Clancy | ||||
| James Cone | ||||
| James Gallagher | ||||
| James Griffiths | ||||
| James Housley | ||||
| James MacMillan | ||||
| Jamie Lokier | ||||
| Jamie Newton | ||||
| Jamie Wilkinson | ||||
| Jan Kunder | ||||
| Jared Lundell | ||||
| Jari Sundell | ||||
| Jason S. Priebe | ||||
| Jaz Fresh | ||||
| @@ -243,6 +260,7 @@ Jonas Forsman | ||||
| Jonatan Lander | ||||
| Jonathan Hseu | ||||
| Jongki Suwandi | ||||
| Jose Kahan | ||||
| Josh Kapell | ||||
| Juan F. Codagnone | ||||
| Juan Ignacio Herv<72>s | ||||
| @@ -251,6 +269,7 @@ Jukka Pihl | ||||
| Julian Noble | ||||
| Jun-ichiro itojun Hagino | ||||
| Jurij Smakov | ||||
| Justin Fletcher | ||||
| J<EFBFBD>rg Mueller-Tolk | ||||
| J<EFBFBD>rn Hartroth | ||||
| Kai Sommerfeld | ||||
| @@ -298,6 +317,7 @@ Luke Call | ||||
| Luong Dinh Dung | ||||
| Maciej Karpiuk | ||||
| Maciej W. Rozycki | ||||
| Manfred Schwarb | ||||
| Marc Boucher | ||||
| Marcelo Juchem  | ||||
| Marcin Konicki | ||||
| @@ -313,12 +333,15 @@ Markus Oberhumer | ||||
| Martijn Koster | ||||
| Martin C. Martin | ||||
| Martin Hedenfalk | ||||
| Martin Skinner | ||||
| Marty Kuhrt | ||||
| Maruko | ||||
| Massimiliano Ziccardi | ||||
| Mathias Axelsson | ||||
| Mats Lidell | ||||
| Matt Kraai | ||||
| Matt Veenstra | ||||
| Matt Witherspoon | ||||
| Matthew Blain | ||||
| Matthew Clarke | ||||
| Maurice Barnum | ||||
| @@ -337,28 +360,33 @@ Mihai Ionescu | ||||
| Mikael Sennerholm | ||||
| Mike Bytnar | ||||
| Mike Dobbs | ||||
| Mike Protts | ||||
| Miklos Nemeth | ||||
| Mitz Wark | ||||
| Mohamed Lrhazi | ||||
| Mohun Biswas | ||||
| Moonesamy | ||||
| Nathan O'Sullivan | ||||
| Nathanael Nerode | ||||
| Naveen Noel | ||||
| Neil Dunbar | ||||
| Neil Spring | ||||
| Nic Roets | ||||
| Nick Gimbrone | ||||
| Nick Humfrey | ||||
| Nick Zitzmann | ||||
| Nico Baggus | ||||
| Nicolas Berloquin | ||||
| Nicolas Croiset | ||||
| Nicolas Fran<61>ois | ||||
| Niels van Tongeren | ||||
| Nikita Schmidt | ||||
| Nir Soffer | ||||
| Nis Jorgensen | ||||
| Nodak Sodak | ||||
| Norbert Novotny | ||||
| Ofer | ||||
| Olaf Stueben | ||||
| Olaf St<53>ben | ||||
| Oren Tirosh | ||||
| P R Schaffner | ||||
| @@ -398,6 +426,7 @@ Ralph Beckmann | ||||
| Ralph Mitchell | ||||
| Ramana Mokkapati | ||||
| Randy McMurchy | ||||
| Ravi Pratap | ||||
| Reinout van Schouwen | ||||
| Renaud Chaillat | ||||
| Renaud Duhaut | ||||
| @@ -414,8 +443,13 @@ Richard Gorton | ||||
| Richard Prescott | ||||
| Rick Jones | ||||
| Rick Richardson | ||||
| Rob Crittenden | ||||
| Rob Jones | ||||
| Rob Stanzel | ||||
| Robert A. Monat | ||||
| Robert D. Young | ||||
| Robert Foreman | ||||
| Robert Iakobashvili | ||||
| Robert Olson | ||||
| Robert Weaver | ||||
| Robin Kay | ||||
| @@ -442,6 +476,7 @@ Scott Davis | ||||
| Sebastien Willemijns | ||||
| Sergio Ballestrero | ||||
| Seshubabu Pasam | ||||
| Sh Diao | ||||
| Shard | ||||
| Shawn Poulson | ||||
| Shmulik Regev | ||||
| @@ -452,6 +487,7 @@ Simon Liu | ||||
| Spiridonoff A.V | ||||
| Stadler Stephan | ||||
| Stefan Esser | ||||
| Stefan Krause | ||||
| Stefan Ulrich | ||||
| Stephan Bergmann | ||||
| Stephen Kick | ||||
| @@ -489,6 +525,7 @@ Tomas Szepe | ||||
| Tomasz Lacki | ||||
| Tommy Tam | ||||
| Ton Voon | ||||
| Toon Verwaest | ||||
| Tor Arntsen | ||||
| Torsten Foertsch | ||||
| Toshiyuki Maezawa | ||||
| @@ -498,6 +535,8 @@ Troy Engel | ||||
| Tupone Alfredo | ||||
| Ulf H<>rnhammar | ||||
| Ulrich Zadow | ||||
| Venkat Akella | ||||
| Victor Snezhko | ||||
| Vilmos Nebehaj | ||||
| Vincent Bronner | ||||
| Vincent Penquerc'h | ||||
|   | ||||
							
								
								
									
										26
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -43,10 +43,6 @@ TODO | ||||
|    powered libcurl the default build (which of course would require that we'd | ||||
|    bundle the c-ares source code in the libcurl source code releases). | ||||
|  | ||||
|  * Support CONNECT 407 responses that kill the connection and expect the | ||||
|    client to reconnect to complete the authentication. Currently libcurl | ||||
|    assumes that a proxy connection will be kept alive. | ||||
|  | ||||
|  * Make the curl/*.h headers include the proper system includes based on what | ||||
|    was present at the time when configure was run. Currently, the sys/select.h | ||||
|    header is for example included by curl/multi.h only on specific platforms | ||||
| @@ -161,18 +157,14 @@ TODO | ||||
|    Clark) | ||||
|  | ||||
|  * Make curl's SSL layer capable of using other free SSL libraries.  Such as | ||||
|    Mozilla Security Services | ||||
|    (http://www.mozilla.org/projects/security/pki/nss/), MatrixSSL | ||||
|    (http://www.matrixssl.org/) or yaSSL (http://yassl.com/). At least the | ||||
|    latter two could be alternatives for those looking to reduce the footprint | ||||
|    of libcurl built with OpenSSL or GnuTLS. | ||||
|    MatrixSSL (http://www.matrixssl.org/). | ||||
|  | ||||
|  * 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. | ||||
|  | ||||
|  * make the configure --with-ssl option first check for OpenSSL and then for | ||||
|    GnuTLS if OpenSSL wasn't detected. | ||||
|  * make the configure --with-ssl option first check for OpenSSL, then GnuTLS, | ||||
|    then NSS... | ||||
|  | ||||
|  GnuTLS | ||||
|  | ||||
| @@ -188,8 +180,8 @@ TODO | ||||
|  | ||||
|  * Fix the connection phase to be non-blocking when multi interface is used | ||||
|  | ||||
|  * Add a way to check if the connection seems to be alive, to corrspond to the | ||||
|    SSL_peak() way we use with OpenSSL. | ||||
|  * Add a way to check if the connection seems to be alive, to correspond to | ||||
|    the SSL_peak() way we use with OpenSSL. | ||||
|  | ||||
|  LDAP | ||||
|  | ||||
| @@ -201,10 +193,6 @@ TODO | ||||
|  | ||||
|  * RTSP - RFC2326 (protocol - very HTTP-like, also contains URL description) | ||||
|  | ||||
|  * SFTP/SCP/SSH (no RFCs for protocol nor URI/URL format). An implementation | ||||
|    should most probably use an existing ssh library, such as OpenSSH. or | ||||
|    libssh2.org | ||||
|  | ||||
|  * RSYNC (no RFCs for protocol nor URI/URL format).  An implementation should | ||||
|    most probably use an existing rsync library, such as librsync. | ||||
|  | ||||
| @@ -273,6 +261,10 @@ TODO | ||||
|  | ||||
|  TEST SUITE | ||||
|  | ||||
|  * Make our own version of stunnel for simple port forwarding to enable HTTPS | ||||
|    and FTP-SSL tests without the stunnel dependency, and it could allow us to | ||||
|    provide test tools built with either OpenSSL or GnuTLS | ||||
|  | ||||
|  * Make the test servers able to serve multiple running test suites. Like if | ||||
|    two users run 'make test' at once. | ||||
|  | ||||
|   | ||||
							
								
								
									
										145
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										145
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -21,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl 1 "23 Sep 2006" "Curl 7.16.0" "Curl Manual" | ||||
| .TH curl 1 "28 Feb 2007" "Curl 7.16.2" "Curl Manual" | ||||
| .SH NAME | ||||
| curl \- transfer a URL | ||||
| .SH SYNOPSIS | ||||
| @@ -30,8 +30,8 @@ curl \- transfer a URL | ||||
| .SH DESCRIPTION | ||||
| .B curl | ||||
| is a tool to transfer data from or to a server, using one of the supported | ||||
| protocols (HTTP, HTTPS, FTP, FTPS, TFTP, DICT, TELNET, LDAP or FILE). | ||||
| The command is designed to work without user interaction. | ||||
| protocols (HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, DICT, TELNET, LDAP or | ||||
| FILE).  The command is designed to work without user interaction. | ||||
|  | ||||
| curl offers a busload of useful tricks like proxy support, user | ||||
| authentication, ftp upload, HTTP post, SSL connections, cookies, file transfer | ||||
| @@ -167,6 +167,10 @@ difference. | ||||
| must be using valid ciphers. Read up on SSL cipher list details on this URL: | ||||
| \fIhttp://www.openssl.org/docs/apps/ciphers.html\fP | ||||
|  | ||||
| NSS ciphers are done differently than OpenSSL and GnuTLS. The full list of | ||||
| NSS ciphers is in the NSSCipherSuite entry at this URL: | ||||
| \fIhttp://directory.fedora.redhat.com/docs/mod_nss.html#Directives\fP | ||||
|  | ||||
| If this option is used several times, the last one will override the others. | ||||
| .IP "--compressed" | ||||
| (HTTP) Request a compressed response using one of the algorithms libcurl | ||||
| @@ -212,7 +216,8 @@ local directory hierarchy as needed. This option creates the dirs mentioned | ||||
| with the -o option, nothing else. If the -o file name uses no dir or if the | ||||
| dirs it mentions already exist, no dir will be created. | ||||
|  | ||||
| To create remote directories when using FTP, try \fI--ftp-create-dirs\fP. | ||||
| To create remote directories when using FTP or SFTP, try  | ||||
| \fI--ftp-create-dirs\fP. | ||||
| .IP "--crlf" | ||||
| (FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390). | ||||
|  | ||||
| @@ -320,9 +325,13 @@ is used to seed the random engine for SSL connections. See also the | ||||
| with HTTPS or FTPS. The certificate must be in PEM format.  If the optional | ||||
| password isn't specified, it will be queried for on the terminal. Note that | ||||
| this option assumes a \&"certificate" file that is the private key and the | ||||
| private certificate concatenated! See \fI--cert\P and \fI--key\fP to specify | ||||
| private certificate concatenated! See \fI--cert\fP and \fI--key\fP to specify | ||||
| them independently. | ||||
|  | ||||
| If curl is built against the NSS SSL library then this option tells | ||||
| curl the nickname of the certificate to use within the NSS database defined | ||||
| by --cacert. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--cert-type <type>" | ||||
| (SSL) Tells curl what certificate type the provided certificate is in. PEM, | ||||
| @@ -342,6 +351,9 @@ The windows version of curl will automatically look for a CA certs file named | ||||
| \'curl-ca-bundle.crt\', either in the same directory as curl.exe, or in the | ||||
| Current Working Directory, or in any folder along your PATH. | ||||
|  | ||||
| If curl is built against the NSS SSL library then this option tells | ||||
| curl the directory that the NSS certificate database resides in. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--capath <CA certificate directory>" | ||||
| (SSL) Tells curl to use the specified certificate directory to verify the | ||||
| @@ -359,7 +371,7 @@ normal cases when a HTTP server fails to deliver a document, it returns an | ||||
| HTML document stating so (which often also describes why and more). This flag | ||||
| will prevent curl from outputting that and return error 22. | ||||
|  | ||||
| This method is not fail-safe and there are occasions where non-succesful | ||||
| This method is not fail-safe and there are occasions where non-successful | ||||
| response codes will slip through, especially when authentication is involved | ||||
| (response codes 401 and 407). | ||||
|  | ||||
| @@ -371,7 +383,7 @@ has been provided, this data is sent off using the ACCT command. (Added in | ||||
|  | ||||
| If this option is used twice, the second will override the previous use. | ||||
| .IP "--ftp-create-dirs" | ||||
| (FTP) When an FTP URL/operation uses a path that doesn't currently exist on | ||||
| (FTP) When an FTP or SFTP URL/operation uses a path that doesn't currently exist on | ||||
| the server, the standard behavior of curl is to fail. Using this option, curl | ||||
| will instead attempt to create missing directories. | ||||
|  | ||||
| @@ -433,6 +445,22 @@ Terminates the connection if the server doesn't support SSL/TLS. | ||||
| (Added in 7.15.5) | ||||
|  | ||||
| If this option is used twice, the second will again disable this. | ||||
| .IP "--ftp-ssl-ccc" | ||||
| (FTP) Use CCC (Clear Command Channel) | ||||
| Shuts down the SSL/TLS layer after authenticating. The rest of the | ||||
| control channel communication will be unencrypted. This allows | ||||
| NAT routers to follow the FTP transaction. The default mode is | ||||
| passive. See --ftp-ssl-ccc-mode for other modes. | ||||
| (Added in 7.16.1) | ||||
|  | ||||
| If this option is used twice, the second will again disable this. | ||||
| .IP "--ftp-ssl-ccc-mode [active/passive]" | ||||
| (FTP) Use CCC (Clear Command Channel) | ||||
| Sets the CCC mode. The passive mode will not initiate the shutdown, but | ||||
| instead wait for the server to do it, and will not reply to the | ||||
| shutdown from the server. The active mode initiates the shutdown and | ||||
| waits for a reply from the server. | ||||
| (Added in 7.16.2) | ||||
| .IP "-F/--form <name=content>" | ||||
| (HTTP) This lets curl emulate a filled in form in which a user has pressed the | ||||
| submit button. This causes curl to POST data using the Content-Type | ||||
| @@ -555,7 +583,7 @@ See this online resource for further details: | ||||
|  | ||||
| If this option is used twice, the second time will again disable it. | ||||
| .IP "--key <key>" | ||||
| (SSL) Private key file name. Allows you to provide your private key in this | ||||
| (SSL/SSH) Private key file name. Allows you to provide your private key in this | ||||
| separate file. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| @@ -566,11 +594,11 @@ assumed. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--krb4 <level>" | ||||
| (FTP) Enable kerberos4 authentication and use. The level must be entered and | ||||
| (FTP) Enable Kerberos4 authentication and use. The level must be entered and | ||||
| should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use | ||||
| a level that is not one of these, 'private' will instead be used. | ||||
|  | ||||
| This option requires that the library was built with kerberos4 support. This | ||||
| This option requires that the library was built with Kerberos4 support. This | ||||
| is not very common. Use \fI-V/--version\fP to see if your curl supports it. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| @@ -581,9 +609,11 @@ used as if they were written on the actual command line. Options and their | ||||
| parameters must be specified on the same config file line. If the parameter is | ||||
| to contain white spaces, the parameter must be enclosed within quotes.  If the | ||||
| first column of a config line is a '#' character, the rest of the line will be | ||||
| treated as a comment. | ||||
| treated as a comment. Only write one option per physical line in the config | ||||
| file. | ||||
|  | ||||
| Specify the filename as '-' to make curl read the file from stdin. | ||||
| Specify the filename to -K/--config as '-' to make curl read the file from | ||||
| stdin. | ||||
|  | ||||
| Note that to be able to specify a URL in the config file, you need to specify | ||||
| it using the \fI--url\fP option, and not by simply writing the URL on its own | ||||
| @@ -591,7 +621,8 @@ line. So, it could look similar to this: | ||||
|  | ||||
| url = "http://curl.haxx.se/docs/" | ||||
|  | ||||
| This option can be used multiple times. | ||||
| Long option names can optionally be given in the config file without the | ||||
| initial double dashes. | ||||
|  | ||||
| When curl is invoked, it always (unless \fI-q\fP is used) checks for a default | ||||
| config file and uses it if found. The default config file is checked for in | ||||
| @@ -606,6 +637,28 @@ resort the '%USERPROFILE%\Application Data'. | ||||
| 2) On windows, if there is no _curlrc file in the home dir, it checks for one | ||||
| in the same dir the executable curl is placed. On unix-like systems, it will | ||||
| simply try to load .curlrc from the determined home dir. | ||||
|  | ||||
| .nf | ||||
| # --- Example file --- | ||||
| # this is a comment | ||||
| url = "curl.haxx.se" | ||||
| output = "curlhere.html" | ||||
| user-agent = "superagent/1.0" | ||||
|  | ||||
| # and fetch another URL too | ||||
| url = "curl.haxx.se/docs/manpage.html" | ||||
| -O | ||||
| referer = "http://nowhereatall.com/" | ||||
| # --- End of example file --- | ||||
| .fi | ||||
|  | ||||
| This option can be used multiple times to load multiple config files. | ||||
| .IP "--libcurl <file>" | ||||
| Append this option to any ordinary curl command line, and you will get a | ||||
| libcurl-using source code written to the file that does the equivalent | ||||
| operation of what your command line operation does! | ||||
|  | ||||
| If this option is used several times, the last given file name will be used. | ||||
| .IP "--limit-rate <speed>" | ||||
| Specify the maximum transfer rate you want curl to use. This feature is useful | ||||
| if you have a limited pipe and you'd like your transfer not use your entire | ||||
| @@ -615,6 +668,10 @@ The given speed is measured in bytes/second, unless a suffix is appended. | ||||
| Appending 'k' or 'K' will count the number as kilobytes, 'm' or M' makes it | ||||
| megabytes while 'g' or 'G' makes it gigabytes. Examples: 200K, 3m and 1G. | ||||
|  | ||||
| The given rate is the average speed, counted during the entire transfer. It | ||||
| means that curl might use higher transfer speeds in short bursts, but over | ||||
| time it uses no more than the given rate. | ||||
|  | ||||
| If you are also using the \fI-Y/--speed-limit\fP option, that option will take | ||||
| precedence and might cripple the rate-limiting slightly, to help keeping the | ||||
| speed-limit logic working. | ||||
| @@ -633,7 +690,7 @@ subdirectories and symbolic links. | ||||
|  | ||||
| If this option is used twice, the second will again disable list only. | ||||
| .IP "--local-port <num>[-num]" | ||||
| Set a prefered number or range of local port numbers to use for the | ||||
| Set a preferred number or range of local port numbers to use for the | ||||
| connection(s).  Note that port numbers by nature is a scarce resource that | ||||
| will be busy at times so setting this range to something too narrow might | ||||
| cause unnecessary connection setup failures. (Added in 7.15.2) | ||||
| @@ -648,6 +705,11 @@ able to intercept the user+password. See also \fI--location-trusted\fP on how | ||||
| to change this. You can limit the amount of redirects to follow by using the | ||||
| \fI--max-redirs\fP option. | ||||
|  | ||||
| When curl follows a redirect and the request is not a plain GET (for example | ||||
| POST or PUT), it will do the following request with a GET if the HTTP response | ||||
| was 301, 302, or 303. If the response code was any other 3xx code, curl will | ||||
| re-send the following request using the same unmodified method. | ||||
|  | ||||
| If this option is used twice, the second will again disable location following. | ||||
| .IP "--location-trusted" | ||||
| (HTTP/HTTPS) Like \fI-L/--location\fP, but will allow sending the name + | ||||
| @@ -769,7 +831,7 @@ nothing else. | ||||
|  | ||||
| You may use this option as many times as you have number of URLs. | ||||
| .IP "--pass <phrase>" | ||||
| (SSL) Pass phrase for the private key | ||||
| (SSL/SSH) Pass phrase for the private key | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--proxy-anyauth" | ||||
| @@ -804,9 +866,14 @@ CONNECT request and requires that the proxy allows direct connect to the | ||||
| remote port number curl wants to tunnel through to. | ||||
|  | ||||
| If this option is used twice, the second will again disable proxy tunnel. | ||||
| .IP "--pubkey <key>" | ||||
| (SSH) Public key file name. Allows you to provide your public key in this | ||||
| separate file. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-P/--ftp-port <address>" | ||||
| (FTP) Reverses the initiator/listener roles when connecting with ftp. This | ||||
| switch makes Curl use the PORT command instead of PASV. In practice, PORT | ||||
| switch makes Curl use the PORT command instead of PASV. In practise, PORT | ||||
| tells the server to connect to the client's specified address and port, while | ||||
| PASV asks the server for an ip address and port to connect to. <address> | ||||
| should be one of: | ||||
| @@ -830,14 +897,18 @@ If used as the first parameter on the command line, the \fIcurlrc\fP config | ||||
| file will not be read and used. See the \fI-K/--config\fP for details on the | ||||
| default config file search path. | ||||
| .IP "-Q/--quote <command>" | ||||
| (FTP) Send an arbitrary command to the remote FTP server. Quote commands are | ||||
| sent BEFORE the transfer is taking place (just after the initial PWD command | ||||
| to be exact). To make commands take place after a successful transfer, prefix | ||||
| them with a dash '-'. To make commands get sent after libcurl has changed | ||||
| working directory, just before the transfer command(s), prefix the command | ||||
| with '+'. You may specify any amount of commands. If the server returns | ||||
| failure for one of the commands, the entire operation will be aborted. You | ||||
| must send syntactically correct FTP commands as RFC959 defines. | ||||
| (FTP/SFTP) Send an arbitrary command to the remote FTP or SFTP server. Quote | ||||
| commands are sent BEFORE the transfer is taking place (just after the | ||||
| initial PWD command in an FTP transfer, to be exact). To make commands | ||||
| take place after a successful transfer, prefix them with a dash '-'. | ||||
| To make commands get sent after libcurl has changed working directory, | ||||
| just before the transfer command(s), prefix the command with '+' (this | ||||
| is only supported for FTP). You may specify any number of commands. If | ||||
| the server returns failure for one of the commands, the entire operation | ||||
| will be aborted. You must send syntactically correct FTP commands as | ||||
| RFC959 defines to FTP servers, or one of the following commands (with | ||||
| appropriate arguments) to SFTP servers: chgrp, chmod, chown, ln, mkdir, | ||||
| rename, rm, rmdir, symlink. | ||||
|  | ||||
| This option can be used multiple times. | ||||
| .IP "--random-file <file>" | ||||
| @@ -875,6 +946,10 @@ specifies two separate 100 bytes ranges(*)(H) | ||||
| (*) = NOTE that this will cause the server to reply with a multipart | ||||
| response! | ||||
|  | ||||
| Only digit characters (0-9) are valid in 'start' and 'stop' of range syntax | ||||
| \&'start-stop'. If a non-digit character is given in the range, the server's | ||||
| response will be indeterminable, depending on different server's configuration. | ||||
|  | ||||
| You should also be aware that many HTTP/1.1 servers do not have this feature | ||||
| enabled, so that when you attempt to get a range, you'll instead get the whole | ||||
| document. | ||||
| @@ -883,6 +958,11 @@ FTP range downloads only support the simple syntax 'start-stop' (optionally | ||||
| with one of the numbers omitted). It depends on the non-RFC command SIZE. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--raw" | ||||
| When used, it disables all internal HTTP decoding of content or transfer | ||||
| encodings and instead makes them passed on unaltered, raw. (Added in 7.16.2) | ||||
|  | ||||
| If this option is used several times, each occurrence toggles this on/off. | ||||
| .IP "-R/--remote-time" | ||||
| When used, this will make libcurl attempt to figure out the timestamp of the | ||||
| remote file, and if that is available make the local file get that same | ||||
| @@ -991,6 +1071,9 @@ Enables a full trace dump of all incoming and outgoing data, including | ||||
| descriptive information, to the given output file. Use "-" as filename to have | ||||
| the output sent to stdout. | ||||
|  | ||||
| This option overrides previous uses of \fI-v/--verbose\fP or | ||||
| \fI--trace-ascii\fP. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--trace-ascii <file>" | ||||
| Enables a full trace dump of all incoming and outgoing data, including | ||||
| @@ -1001,6 +1084,8 @@ This is very similar to \fI--trace\fP, but leaves out the hex part and only | ||||
| shows the ASCII part of the dump. It makes smaller output that might be easier | ||||
| to read for untrained humans. | ||||
|  | ||||
| This option overrides previous uses of \fI-v/--verbose\fP or \fI--trace\fP. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--trace-time" | ||||
| Prepends a time stamp to each trace or verbose line that curl displays. | ||||
| @@ -1011,7 +1096,7 @@ If this option is used several times, each occurrence will toggle it on/off. | ||||
| Specify user and password to use for server authentication. Overrides | ||||
| \fI-n/--netrc\fP and \fI--netrc-optional\fP. | ||||
|  | ||||
| If you use an SSPI-enabled curl binary and do NTLM autentication, you can | ||||
| If you use an SSPI-enabled curl binary and do NTLM authentication, you can | ||||
| force curl to pick up the user name and password from your environment by | ||||
| simply specifying a single colon with this option: "-u :". | ||||
|  | ||||
| @@ -1019,7 +1104,7 @@ If this option is used several times, the last one will be used. | ||||
| .IP "-U/--proxy-user <user:password>" | ||||
| Specify user and password to use for proxy authentication. | ||||
|  | ||||
| If you use an SSPI-enabled curl binary and do NTLM autentication, you can | ||||
| If you use an SSPI-enabled curl binary and do NTLM authentication, you can | ||||
| force curl to pick up the user name and password from your environment by | ||||
| simply specifying a single colon with this option: "-U :". | ||||
|  | ||||
| @@ -1042,7 +1127,9 @@ might be option you're looking for. | ||||
| If you think this option still doesn't give you enough details, consider using | ||||
| \fI--trace\fP or \fI--trace-ascii\fP instead. | ||||
|  | ||||
| If this option is used twice, the second will again disable verbose. | ||||
| This option overrides previous uses of \fI--trace-ascii\fP or \fI--trace\fP. | ||||
|  | ||||
| If this option is used twice, the second will do nothing extra. | ||||
| .IP "-V/--version" | ||||
| Displays information about curl and the libcurl version it uses. | ||||
|  | ||||
| @@ -1385,7 +1472,7 @@ Internal error. A function was called in a bad order. | ||||
| .IP 45 | ||||
| Interface error. A specified outgoing interface could not be used. | ||||
| .IP 46 | ||||
| Bad password entered. An error was signaled when the password was entered. | ||||
| Bad password entered. An error was signalled when the password was entered. | ||||
| .IP 47 | ||||
| Too many redirects. When following redirects, curl hit the maximum amount. | ||||
| .IP 48 | ||||
|   | ||||
| @@ -92,18 +92,15 @@ typedef struct _SockInfo { | ||||
|  | ||||
|  | ||||
| /* Update the event timer after curl_multi library calls */ | ||||
| static void update_timeout(GlobalInfo *g) | ||||
| static int multi_timer_cb(CURLM *multi, long timeout_ms, GlobalInfo *g) | ||||
| { | ||||
|   long timeout_ms; | ||||
|   struct timeval timeout; | ||||
|  | ||||
|   curl_multi_timeout(g->multi, &timeout_ms); | ||||
|   if(timeout_ms < 0) | ||||
|     return; | ||||
|  | ||||
|   timeout.tv_sec = timeout_ms/1000; | ||||
|   timeout.tv_usec = (timeout_ms%1000)*1000; | ||||
|   fprintf(MSG_OUT, "multi_timer_cb: Setting timeout to %ld ms\n", timeout_ms); | ||||
|   evtimer_add(&g->timer_event, &timeout); | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -185,9 +182,7 @@ static void event_cb(int fd, short kind, void *userp) | ||||
|   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||
|   mcode_or_die("event_cb: curl_multi_socket", rc); | ||||
|   check_run_count(g); | ||||
|   if(g->still_running) { | ||||
|     update_timeout(g); | ||||
|   } else { | ||||
|   if ( g->still_running <= 0 ) { | ||||
|     fprintf(MSG_OUT, "last transfer done, kill timeout\n"); | ||||
|     if (evtimer_pending(&g->timer_event, NULL)) { | ||||
|       evtimer_del(&g->timer_event); | ||||
| @@ -210,7 +205,6 @@ static void timer_cb(int fd, short kind, void *userp) | ||||
|   } while (rc == CURLM_CALL_MULTI_PERFORM); | ||||
|   mcode_or_die("timer_cb: curl_multi_socket", rc); | ||||
|   check_run_count(g); | ||||
|   if ( g->still_running ) { update_timeout(g); } | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -406,10 +400,11 @@ int main(int argc, char **argv) | ||||
|   evtimer_set(&g.timer_event, timer_cb, &g); | ||||
|   curl_multi_setopt(g.multi, CURLMOPT_SOCKETFUNCTION, sock_cb); | ||||
|   curl_multi_setopt(g.multi, CURLMOPT_SOCKETDATA, &g); | ||||
|   curl_multi_setopt(g.multi, CURLMOPT_TIMERFUNCTION, multi_timer_cb); | ||||
|   curl_multi_setopt(g.multi, CURLMOPT_TIMERDATA, &g); | ||||
|   do { | ||||
|     rc = curl_multi_socket_all(g.multi, &g.still_running); | ||||
|   } while (CURLM_CALL_MULTI_PERFORM == rc); | ||||
|   update_timeout(&g); | ||||
|   event_dispatch(); | ||||
|   curl_multi_cleanup(g.multi); | ||||
|   return 0; | ||||
|   | ||||
| @@ -1,13 +1,16 @@ | ||||
| #  $Id$ | ||||
| # | ||||
| #  Adapted for djgpp / Watt-32 / DOS by | ||||
| #  Gisle Vanem <giva@bgnett.no> | ||||
| # | ||||
|  | ||||
| include ../../packages/DOS/common.dj | ||||
| TOPDIR = ../.. | ||||
|  | ||||
| CFLAGS += -I../../include -DFALSE=0 -DTRUE=1 | ||||
| include $(TOPDIR)/packages/DOS/common.dj | ||||
|  | ||||
| LIBS = ../../lib/libcurl.a | ||||
| CFLAGS += -DFALSE=0 -DTRUE=1 | ||||
|  | ||||
| LIBS = $(TOPDIR)/lib/libcurl.a | ||||
|  | ||||
| ifeq ($(USE_SSL),1) | ||||
|   LIBS += $(OPENSSL_ROOT)/lib/libssl.a $(OPENSSL_ROOT)/lib/libcrypt.a | ||||
| @@ -16,21 +19,23 @@ endif | ||||
| LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a | ||||
|  | ||||
| CSOURCES = fopen.c ftpget.c ftpgetresp.c ftpupload.c getinmemory.c  \ | ||||
|            http-post.c httpput.c multi-app.c multi-double.c multi-post.c \ | ||||
|            multi-single.c persistant.c post-callback.c postit2.c \ | ||||
|            sepheaders.c simple.c simplessl.c https.c ftp3rdparty.c \ | ||||
|            getinfo.c anyauthput.c cookie_interface.c 10-at-a-time.c | ||||
|            http-post.c httpput.c https.c multi-app.c multi-double.c \ | ||||
|            multi-post.c multi-single.c persistant.c post-callback.c \ | ||||
|            postit2.c sepheaders.c simple.c simplepost.c simplessl.c \ | ||||
|            multi-debugcallback.c fileupload.c getinfo.c anyauthput.c \ | ||||
|            10-at-a-time.c # ftpuploadresume.c ftp3rdparty.c cookie_interface.c | ||||
|  | ||||
| PROGRAMS = $(CSOURCES:.c=.exe) | ||||
|  | ||||
| all: $(PROGRAMS) | ||||
| 	@echo Welcome to libcurl example program | ||||
|  | ||||
| %.exe: %.c | ||||
| 	$(CC) $(CFLAGS) -o $@ $^ $(LIBS) | ||||
| 	@echo | ||||
|  | ||||
| clean: | ||||
| 	rm -f $(PROGRAMS) | ||||
| clean vclean realclean: | ||||
| 	- rm -f $(PROGRAMS) depend.dj | ||||
|  | ||||
| # DO NOT DELETE THIS LINE | ||||
| -include depend.dj | ||||
|  | ||||
|   | ||||
| @@ -41,9 +41,6 @@ int main(int argc, char **argv) | ||||
|   /* no progress meter please */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1); | ||||
|  | ||||
|   /* shut up completely */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_MUTE, 1); | ||||
|  | ||||
|   /* send all data to this function  */ | ||||
|   curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, write_data); | ||||
|  | ||||
|   | ||||
| @@ -9,6 +9,18 @@ | ||||
|  * | ||||
|  * This example code only builds as-is on Windows. | ||||
|  * | ||||
|  * While Unix/Linux user, you do not need this software. | ||||
|  * You can achieve the same result as synctime using curl, awk and date. | ||||
|  * Set proxy as according to your network, but beware of proxy Cache-Control. | ||||
|  * | ||||
|  * To set your system clock, root access is required. | ||||
|  * # date -s "`curl -sI http://nist.time.gov/timezone.cgi?UTC/s/0 \ | ||||
|  *        | awk -F': ' '/Date: / {print $2}'`" | ||||
|  * | ||||
|  * To view remote webserver date and time. | ||||
|  * $ curl -sI http://nist.time.gov/timezone.cgi?UTC/s/0 \ | ||||
|  *        | awk -F': ' '/Date: / {print $2}' | ||||
|  * | ||||
|  * Synchronising your computer clock via Internet time server usually relies | ||||
|  * on DAYTIME, TIME, or NTP protocols. These protocols provide good accurate | ||||
|  * time synchronisation but it does not work very well through a | ||||
| @@ -300,10 +312,11 @@ int main(int argc, char *argv[]) | ||||
|              MthStr[LOCALTime.wMonth-1], LOCALTime.wYear, | ||||
|              LOCALTime.wHour, LOCALTime.wMinute, LOCALTime.wSecond, | ||||
|              LOCALTime.wMilliseconds); | ||||
|     fprintf(stderr, "\nBefore HTTP. Date: %s%s\n\n", timeBuf, tzoneBuf); | ||||
|  | ||||
|     fprintf(stderr, "Fetch: %s\n\n", conf->timeserver); | ||||
|     fprintf(stderr, "Before HTTP. Date: %s%s\n\n", timeBuf, tzoneBuf); | ||||
|  | ||||
|     /* HTTP HEAD command to the Webserver */ | ||||
|     fprintf(stderr, "Fetch: %s\n", conf->timeserver); | ||||
|     SyncTime_CURL_Fetch(curl, conf->timeserver, "index.htm", | ||||
|                         HTTP_COMMAND_HEAD); | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -39,7 +39,7 @@ this function AFTER a performed transfer if you want to get transfer- oriented | ||||
| data. | ||||
|  | ||||
| You should not free the memory returned by this function unless it is | ||||
| explictly mentioned below. | ||||
| explicitly mentioned below. | ||||
| .SH AVAILABLE INFORMATION | ||||
| The following information can be extracted: | ||||
| .IP CURLINFO_EFFECTIVE_URL | ||||
| @@ -98,13 +98,13 @@ downloaded. The amount is only for the latest transfer and will be reset again | ||||
| for each new transfer. | ||||
| .IP CURLINFO_SPEED_DOWNLOAD | ||||
| Pass a pointer to a double to receive the average download speed that curl | ||||
| measured for the complete download. | ||||
| measured for the complete download. Measured in bytes/second. | ||||
| .IP CURLINFO_SPEED_UPLOAD | ||||
| Pass a pointer to a double to receive the average upload speed that curl | ||||
| measured for the complete upload. | ||||
| measured for the complete upload. Measured in bytes/second. | ||||
| .IP CURLINFO_HEADER_SIZE | ||||
| Pass a pointer to a long to receive the total size of all the headers | ||||
| received. | ||||
| received. Measured in number of bytes. | ||||
| .IP CURLINFO_REQUEST_SIZE | ||||
| Pass a pointer to a long to receive the total size of the issued | ||||
| requests. This is so far only for HTTP requests. Note that this may be more | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -21,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl_easy_setopt 3 "19 Apr 2006" "libcurl 7.15.4" "libcurl Manual" | ||||
| .TH curl_easy_setopt 3 "22 Feb 2007" "libcurl 7.16.2" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_easy_setopt \- set options for a curl easy handle | ||||
| .SH SYNOPSIS | ||||
| @@ -345,7 +345,7 @@ A non-zero parameter tells the library to fail silently if the HTTP code | ||||
| returned is equal to or larger than 400. The default action would be to return | ||||
| the page normally, ignoring that code. | ||||
|  | ||||
| This method is not fail-safe and there are occasions where non-succesful | ||||
| This method is not fail-safe and there are occasions where non-successful | ||||
| response codes will slip through, especially when authentication is involved | ||||
| (response codes 401 and 407). | ||||
|  | ||||
| @@ -389,10 +389,12 @@ libcurl respects the environment variables \fBhttp_proxy\fP, \fBftp_proxy\fP, | ||||
| \fBall_proxy\fP etc, if any of those is set. The \fICURLOPT_PROXY\fP option | ||||
| does however override any possibly set environment variables. | ||||
|  | ||||
| Starting with 7.14.1, the proxy host string given in environment variables can | ||||
| be specified the exact same way as the proxy can be set with | ||||
| \fICURLOPT_PROXY\fP, include protocol prefix (http://) and embedded user + | ||||
| password. | ||||
| Setting the proxy string to "" (an empty string) will explicitly disable the | ||||
| use of a proxy, even if there is an environment variable set for it. | ||||
|  | ||||
| Since 7.14.1, the proxy host string given in environment variables can be | ||||
| specified the exact same way as the proxy can be set with \fICURLOPT_PROXY\fP, | ||||
| include protocol prefix (http://) and embedded user + password. | ||||
| .IP CURLOPT_PROXYPORT | ||||
| Pass a long with this option to set the proxy port to connect to unless it is | ||||
| specified in the proxy string \fICURLOPT_PROXY\fP. | ||||
| @@ -443,7 +445,7 @@ not an order. You cannot be guaranteed to actually get the given size. (Added | ||||
| in 7.10) | ||||
|  | ||||
| This size is by default set as big as possible (CURL_MAX_WRITE_SIZE), so it | ||||
| only makse sense to use this option if you want it smaller. | ||||
| only makes sense to use this option if you want it smaller. | ||||
| .IP CURLOPT_PORT | ||||
| Pass a long specifying what remote port number to connect to, instead of the | ||||
| one specified in the URL or the default port for the used protocol. | ||||
| @@ -647,7 +649,7 @@ When setting \fICURLOPT_POST\fP to a non-zero value, it will automatically set | ||||
| \fICURLOPT_NOBODY\fP to 0 (since 7.14.1). | ||||
|  | ||||
| If you issue a POST request and then want to make a HEAD or GET using the same | ||||
| re-used handle, you must explictly 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. | ||||
| .IP CURLOPT_POSTFIELDS | ||||
| Pass a char * as parameter, which should be the full data to post in an HTTP | ||||
| @@ -734,10 +736,9 @@ The linked list should be a fully valid list of struct curl_slist structs, and | ||||
| be 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. | ||||
|  | ||||
| The alias itself is not parsed for any version strings.  So if your alias is | ||||
| \&"MYHTTP/9.9", Libcurl will not treat the server as responding with HTTP | ||||
| version 9.9.  Instead Libcurl will use the value set by option | ||||
| \fICURLOPT_HTTP_VERSION\fP. | ||||
| The alias itself is not parsed for any version strings. Before libcurl 7.16.3, | ||||
| Libcurl used the value set by option \fICURLOPT_HTTP_VERSION\fP, but starting | ||||
| with 7.16.3 the protocol is assumed to match HTTP 1.0 when an alias matched. | ||||
| .IP CURLOPT_COOKIE | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used to | ||||
| set a cookie in the http request. The format of the string should be | ||||
| @@ -815,6 +816,16 @@ servers) which will report incorrect content length for files over 2 | ||||
| gigabytes. If this option is used, curl will not be able to accurately report | ||||
| progress, and will simply stop the download when the server ends the | ||||
| connection. (added in 7.14.1) | ||||
| .IP CURLOPT_HTTP_CONTENT_DECODING | ||||
| Pass a long to tell libcurl how to act on content decoding. If set to zero, | ||||
| content decoding will be disabled. If set to 1 it is enabled. Note however | ||||
| that libcurl has no default content decoding but requires you to use | ||||
| \fICURLOPT_ENCODING\fP for that. (added in 7.16.2) | ||||
| .IP CURLOPT_HTTP_TRANSFER_DECODING | ||||
| Pass a long to tell libcurl how to act on transfer decoding. If set to zero, | ||||
| transfer decoding will be disabled, if set to 1 it is enabled | ||||
| (default). libcurl does chunked transfer decoding by default unless this | ||||
| option is set to zero. (added in 7.16.2) | ||||
| .RE | ||||
| .SH FTP OPTIONS | ||||
| .IP CURLOPT_FTPPORT | ||||
| @@ -828,19 +839,20 @@ address. Default FTP operations are passive, and thus won't use PORT. | ||||
| You disable PORT again and go back to using the passive version by setting | ||||
| this option to NULL. | ||||
| .IP CURLOPT_QUOTE | ||||
| Pass a pointer to a linked list of FTP commands to pass to the server prior to | ||||
| your ftp request. This will be done before any other FTP commands are issued | ||||
| (even before the CWD command). The linked list should be a fully valid list of | ||||
| 'struct curl_slist' structs properly filled in. Use \fIcurl_slist_append(3)\fP | ||||
| to append strings (commands) to the list, and clear the entire list afterwards | ||||
| with \fIcurl_slist_free_all(3)\fP. Disable this operation again by setting a | ||||
| NULL to this option. | ||||
| Pass a pointer to a linked list of FTP or SFTP commands to pass to | ||||
| the server prior to your ftp request. This will be done before any | ||||
| other commands are issued (even before the CWD command for FTP). The | ||||
| linked list should be a fully valid list of 'struct curl_slist' structs | ||||
| properly filled in with text strings. Use \fIcurl_slist_append(3)\fP | ||||
| to append strings (commands) to the list, and clear the entire list | ||||
| afterwards with \fIcurl_slist_free_all(3)\fP. Disable this operation | ||||
| again by setting a NULL to this option. | ||||
| .IP CURLOPT_POSTQUOTE | ||||
| Pass a pointer to a linked list of FTP commands to pass to the server after | ||||
| your ftp transfer request. The linked list should be a fully valid list of | ||||
| struct curl_slist structs properly filled in as described for | ||||
| \fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this | ||||
| option. | ||||
| Pass a pointer to a linked list of FTP or SFTP commands to pass to the | ||||
| server after your ftp transfer request. The linked list should be a | ||||
| fully valid list of struct curl_slist structs properly filled in as | ||||
| described for \fICURLOPT_QUOTE\fP. Disable this operation again by | ||||
| setting a NULL to this option. | ||||
| .IP CURLOPT_PREQUOTE | ||||
| 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 | ||||
| @@ -878,6 +890,11 @@ If the server is an IPv6 host, this option will have no effect as of 7.12.3. | ||||
| Pass a long. If the value is non-zero, curl will attempt to create any remote | ||||
| directory that it fails to CWD into. CWD is the command that changes working | ||||
| directory. (Added in 7.10.7) | ||||
|  | ||||
| This setting also applies to SFTP-connections. curl will attempt to create | ||||
| the remote directory if it can't obtain a handle to the target-location. The | ||||
| creation will fail if a file of the same name as the directory to create | ||||
| already exists or lack of permissions prevents creation. (Added in 7.16.3) | ||||
| .IP CURLOPT_FTP_RESPONSE_TIMEOUT | ||||
| Pass a long.  Causes curl to set a timeout period (in seconds) on the amount | ||||
| of time that the server is allowed to take in order to generate a response | ||||
| @@ -925,6 +942,21 @@ Try "AUTH SSL" first, and only if that fails try "AUTH TLS" | ||||
| .IP CURLFTPAUTH_TLS | ||||
| Try "AUTH TLS" first, and only if that fails try "AUTH SSL" | ||||
| .RE | ||||
| .IP CURLOPT_FTP_SSL_CCC | ||||
| If enabled, this option makes libcurl use CCC (Clear Command Channel). It | ||||
| shuts down the SSL/TLS layer after authenticating. The rest of the | ||||
| control channel communication will be unencrypted. This allows NAT routers | ||||
| to follow the FTP transaction. Pass a long using one of the values below. | ||||
| (Added in 7.16.1) | ||||
| .RS | ||||
| .IP CURLFTPSSL_CCC_NONE | ||||
| Don't attempt to use CCC. | ||||
| .IP CURLFTPSSL_CCC_PASSIVE | ||||
| Do not initiate the shutdown, but wait for the server to do it. Do not send | ||||
| a reply. | ||||
| .IP CURLFTPSSL_CCC_ACTIVE | ||||
| Initiate the shutdown and wait for a reply. | ||||
| .RE | ||||
| .IP CURLOPT_FTP_ACCOUNT | ||||
| Pass a pointer to a zero-terminated string (or NULL to disable). When an FTP | ||||
| server asks for "account data" after user name and password has been provided, | ||||
| @@ -1008,10 +1040,21 @@ to POST with \fICURLOPT_POST\fP etc. | ||||
| 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 | ||||
| as a long. See also \fICURLOPT_INFILESIZE_LARGE\fP. | ||||
|  | ||||
| For uploading using SCP, this option or \fICURLOPT_INFILESIZE_LARGE\fP is | ||||
| mandatory. | ||||
|  | ||||
| Note that this option does not limit how much data libcurl will actually send, | ||||
| as that is controlled entirely by what the read callback returns. | ||||
| .IP CURLOPT_INFILESIZE_LARGE | ||||
| 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 | ||||
| as a curl_off_t. (Added in 7.11.0) | ||||
|  | ||||
| For uploading using SCP, this option or \fICURLOPT_INFILESIZE\fP is mandatory. | ||||
|  | ||||
| Note that this option does not limit how much data libcurl will actually send, | ||||
| as that is controlled entirely by what the read callback returns. | ||||
| .IP CURLOPT_UPLOAD | ||||
| A non-zero parameter tells the library to prepare for an upload. The | ||||
| \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZE\fP or | ||||
| @@ -1066,6 +1109,10 @@ SIGALRM to enable time-outing system calls. | ||||
|  | ||||
| In unix-like systems, this might cause signals to be used unless | ||||
| \fICURLOPT_NOSIGNAL\fP is set. | ||||
| .IP CURLOPT_TIMEOUT_MS | ||||
| Like \fICURLOPT_TIMEOUT\fP but takes number of milliseconds instead. If | ||||
| libcurl is built to use the standard system name resolver, that part will | ||||
| still use full-second resolution for timeouts. (Added in 7.16.2) | ||||
| .IP CURLOPT_LOW_SPEED_LIMIT | ||||
| Pass a long as parameter. It contains the transfer speed in bytes per second | ||||
| that the transfer should be below during \fICURLOPT_LOW_SPEED_TIME\fP seconds | ||||
| @@ -1080,35 +1127,30 @@ average during the transfer, the transfer will pause to keep the average rate | ||||
| less than or equal to the parameter value.  Defaults to unlimited | ||||
| speed. (Added in 7.15.5) | ||||
| .IP CURLOPT_MAX_RECV_SPEED_LARGE | ||||
| Pass a curl_off_t as parameter.  If an upload exceeds this speed on cumulative | ||||
| average during the transfer, the transfer will pause to keep the average rate | ||||
| less than or equal to the parameter value. Defaults to unlimited speed. (Added | ||||
| in 7.15.5) | ||||
| Pass a curl_off_t as parameter.  If a download exceeds this speed on | ||||
| cumulative average during the transfer, the transfer will pause to keep the | ||||
| average rate less than or equal to the parameter value. Defaults to unlimited | ||||
| speed. (Added in 7.15.5) | ||||
| .IP CURLOPT_MAXCONNECTS | ||||
| Pass a long. The set number will be the persistent connection cache size. The | ||||
| set amount will be the maximum amount of simultaneously open connections that | ||||
| libcurl may cache. Default is 5, and there isn't much point in changing this | ||||
| value unless you are perfectly aware of how this work and changes libcurl's | ||||
| behaviour. This concerns connection using any of the protocols that support | ||||
| persistent connections. | ||||
| libcurl may cache in this easy handle. Default is 5, and there isn't much | ||||
| point in changing this value unless you are perfectly aware of how this work | ||||
| and changes libcurl's behaviour. This concerns connection using any of the | ||||
| protocols that support persistent connections. | ||||
|  | ||||
| When reaching the maximum limit, curl uses the \fICURLOPT_CLOSEPOLICY\fP to | ||||
| figure out which of the existing connections to close to prevent the number of | ||||
| open connections to increase. | ||||
| When reaching the maximum limit, curl closes the oldest one in the cache to | ||||
| prevent the number of open connections to increase. | ||||
|  | ||||
| If you already have performed transfers with this curl handle, setting a | ||||
| smaller MAXCONNECTS than before may cause open connections to get closed | ||||
| unnecessarily. | ||||
|  | ||||
| Note that if you add this easy handle to a multi handle, this setting is not | ||||
| being acknowledged, but you must instead use \fIcurl_multi_setopt(3)\fP and | ||||
| the \fICURLMOPT_MAXCONNECTS\fP option. | ||||
| .IP CURLOPT_CLOSEPOLICY | ||||
| Pass a long. This option sets what policy libcurl should use when the | ||||
| connection cache is filled and one of the open connections has to be closed to | ||||
| make room for a new connection. This must be one of the CURLCLOSEPOLICY_* | ||||
| defines. Use \fICURLCLOSEPOLICY_LEAST_RECENTLY_USED\fP to make libcurl close | ||||
| the connection that was least recently used, that connection is also least | ||||
| likely to be capable of re-use. Use \fICURLCLOSEPOLICY_OLDEST\fP to make | ||||
| libcurl close the oldest connection, the one that was created first among the | ||||
| ones in the connection cache. The other close policies are not support | ||||
| yet. | ||||
| (Obsolete) This option does nothing. | ||||
| .IP CURLOPT_FRESH_CONNECT | ||||
| Pass a long. Set to non-zero to make the next transfer use a new (fresh) | ||||
| connection by force. If the connection cache is full before this connection, | ||||
| @@ -1132,6 +1174,10 @@ timeouts). See also the \fICURLOPT_TIMEOUT\fP option. | ||||
|  | ||||
| In unix-like systems, this might cause signals to be used unless | ||||
| \fICURLOPT_NOSIGNAL\fP is set. | ||||
| .IP CURLOPT_CONNECTTIMEOUT_MS | ||||
| Like \fICURLOPT_CONNECTTIMEOUT\fP but takes number of milliseconds instead. If | ||||
| libcurl is built to use the standard system name resolver, that part will | ||||
| still use full-second resolution for timeouts. (Added in 7.16.2) | ||||
| .IP CURLOPT_IPRESOLVE | ||||
| Allows an application to select what kind of IP addresses to use when | ||||
| resolving host names. This is only interesting when using host names that | ||||
| @@ -1157,6 +1203,9 @@ transfers. (Added in 7.15.2) | ||||
| Pass a pointer to a zero terminated string as parameter. The string should be | ||||
| the file name of your certificate. The default format is "PEM" and can be | ||||
| changed with \fICURLOPT_SSLCERTTYPE\fP. | ||||
|  | ||||
| With NSS this is the nickname of the certificate you wish to authenticate | ||||
| with. | ||||
| .IP CURLOPT_SSLCERTTYPE | ||||
| Pass a pointer to a zero terminated string as parameter. The string should be | ||||
| the format of your certificate. Supported formats are "PEM" and "DER".  (Added | ||||
| @@ -1182,7 +1231,8 @@ engine. You have to set the crypto engine with \fICURLOPT_SSLENGINE\fP. | ||||
| \&"DER" format key file currently does not work because of a bug in OpenSSL. | ||||
| .IP CURLOPT_SSLKEYPASSWD | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used as | ||||
| the password required to use the \fICURLOPT_SSLKEY\fP private key. | ||||
| the password required to use the \fICURLOPT_SSLKEY\fP or | ||||
| \fICURLOPT_SSH_PRIVATE_KEYFILE\fP private key. | ||||
| .IP CURLOPT_SSLENGINE | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used as | ||||
| the identifier for the crypto engine you want to use for your private | ||||
| @@ -1201,8 +1251,8 @@ Pass a long as parameter to control what version of SSL/TLS to attempt to use. | ||||
| The available options are: | ||||
| .RS | ||||
| .IP CURL_SSLVERSION_DEFAULT | ||||
| The default action. When libcurl built with OpenSSL, this will attempt to | ||||
| figure out the remote SSL protocol version. Unfortunately there are a lot of | ||||
| The default action. When libcurl built with OpenSSL or NSS, this will attempt | ||||
| to figure out the remote SSL protocol version. Unfortunately there are a lot of | ||||
| ancient and broken servers in use which cannot handle this technique and will | ||||
| fail to connect. When libcurl is built with GnuTLS, this will mean SSLv3. | ||||
| .IP CURL_SSLVERSION_TLSv1 | ||||
| @@ -1245,15 +1295,18 @@ even indicate an accessible file. | ||||
|  | ||||
| Note that option is by default set to the system path where libcurl's cacert | ||||
| bundle is assumed to be stored, as established at build time. | ||||
|  | ||||
| When built against NSS this is the directory that the NSS certificate | ||||
| database resides in. | ||||
| .IP CURLOPT_CAPATH | ||||
| Pass a char * to a zero terminated string naming a directory holding | ||||
| multiple CA certificates to verify the peer with. The certificate | ||||
| directory must be prepared using the openssl c_rehash utility. This | ||||
| makes sense only when used in combination with the | ||||
| \fICURLOPT_SSL_VERIFYPEER\fP option.  If \fICURLOPT_SSL_VERIFYPEER\fP | ||||
| is zero, \fICURLOPT_CAPATH\fP need not even indicate an accessible | ||||
| path.  The \fICURLOPT_CAPATH\fP function apparently does not work in | ||||
| Windows due to some limitation in openssl. (Added in 7.9.8) | ||||
| Pass a char * to a zero terminated string naming a directory holding multiple | ||||
| CA certificates to verify the peer with. The certificate directory must be | ||||
| prepared using the openssl c_rehash utility. This makes sense only when used | ||||
| in combination with the \fICURLOPT_SSL_VERIFYPEER\fP option.  If | ||||
| \fICURLOPT_SSL_VERIFYPEER\fP is zero, \fICURLOPT_CAPATH\fP need not even | ||||
| indicate an accessible path.  The \fICURLOPT_CAPATH\fP function apparently | ||||
| does not work in Windows due to some limitation in openssl. This option is | ||||
| OpenSSL-specific and does nothing if libcurl is built to use GnuTLS. | ||||
| .IP CURLOPT_RANDOM_FILE | ||||
| Pass a char * to a zero terminated file name. The file will be used to read | ||||
| from to seed the random engine for SSL. The more random the specified file is, | ||||
| @@ -1294,12 +1347,23 @@ Pass a char *, pointing to a zero terminated string holding the list of | ||||
| ciphers to use for the SSL connection. The list must be syntactically correct, | ||||
| it consists of one or more cipher strings separated by colons. Commas or spaces | ||||
| are also acceptable separators but colons are normally used, \!, \- and \+ can | ||||
| be used as operators. Valid examples of cipher lists include 'RC4-SHA', | ||||
| be used as operators. | ||||
|  | ||||
| For OpenSSL and GnuTLS valid examples of cipher lists include 'RC4-SHA', | ||||
| \'SHA1+DES\', 'TLSv1' and 'DEFAULT'. The default list is normally set when you | ||||
| compile OpenSSL. | ||||
|  | ||||
| You'll find more details about cipher lists on this URL: | ||||
| \fIhttp://www.openssl.org/docs/apps/ciphers.html\fP | ||||
|  | ||||
| For NSS valid examples of cipher lists include 'rsa_rc4_128_md5', | ||||
| \'rsa_aes_128_sha\', etc. With NSS you don't add/remove ciphers. If one uses | ||||
| this option then all known ciphers are disabled and only those passed in | ||||
| are enabled. | ||||
|  | ||||
| You'll find more details about the NSS cipher lists on this URL: | ||||
| \fIhttp://directory.fedora.redhat.com/docs/mod_nss.html#Directives\fP | ||||
|  | ||||
| .IP CURLOPT_SSL_SESSIONID_CACHE | ||||
| Pass a long set to 0 to disable libcurl's use of SSL session-ID caching. Set | ||||
| this to 1 to enable it. By default all transfers are done using the | ||||
| @@ -1310,8 +1374,20 @@ require you to disable this in order for you to succeed. (Added in 7.16.0) | ||||
| Pass a char * as parameter. Set the krb4 security level, this also enables | ||||
| krb4 awareness.  This is a string, 'clear', 'safe', 'confidential' or | ||||
| \&'private'.  If the string is set but doesn't match one of these, 'private' | ||||
| will be used. Set the string to NULL to disable kerberos4. The kerberos | ||||
| will be used. Set the string to NULL to disable Kerberos4. The Kerberos | ||||
| support only works for FTP. | ||||
| .SH SSH OPTIONS | ||||
| .IP CURLOPT_SSH_AUTH_TYPES | ||||
| Pass a long set to a bitmask consisting of one or more of | ||||
| CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST, | ||||
| CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. | ||||
| .IP CURLOPT_SSH_PUBLIC_KEYFILE | ||||
| Pass a char * pointing to a file name for your public key. If not used, | ||||
| libcurl defaults to using \fB~/.ssh/id_dsa.pub\fP. | ||||
| .IP CURLOPT_SSH_PRIVATE_KEYFILE | ||||
| Pass a char * pointing to a file name for your private key. If not used, | ||||
| libcurl defaults to using \fB~/.ssh/id_dsa\fP. | ||||
| If the file is password-protected, set the password with \fICURLOPT_SSLKEYPASSWD\fP. | ||||
| .SH OTHER OPTIONS | ||||
| .IP CURLOPT_PRIVATE | ||||
| Pass a char * as parameter, pointing to data that should be associated with | ||||
|   | ||||
| @@ -25,8 +25,9 @@ queue so calling this function again will not return the same message | ||||
| again. It will instead return new messages at each new invoke until the queue | ||||
| is emptied. | ||||
|  | ||||
| The data the returned pointer points to will not survive calling | ||||
| \fIcurl_multi_cleanup(3)\fP or \fIcurl_multi_remove_handle(3)\fP. | ||||
| \fBWARNING:\fP The data the returned pointer points to will not survive | ||||
| calling \fIcurl_multi_cleanup(3)\fP, \fIcurl_multi_remove_handle(3)\fP or | ||||
| \fIcurl_easy_cleanup(3)\fP. | ||||
|  | ||||
| The 'CURLMsg' struct is very simple and only contain very basic information. | ||||
| If more involved information is wanted, the particular "easy handle" in | ||||
|   | ||||
| @@ -56,6 +56,22 @@ Pass a pointer to whatever you want passed to the | ||||
| \fBcurl_multi_timer_callback\fP's third argument, the userp pointer.  This is | ||||
| not used by libcurl but only passed-thru as-is. Set the callback pointer with | ||||
| \fICURLMOPT_TIMERFUNCTION\fP. (Added in 7.16.0) | ||||
| .IP CURLMOPT_MAXCONNECTS | ||||
| Pass a long. The set number will be used as the maximum amount of | ||||
| simultaneously open connections that libcurl may cache. Default is 10, and | ||||
| libcurl will enlarge the size for each added easy handle to make it fit 4 | ||||
| times the number of added easy handles. | ||||
|  | ||||
| By setting this option, you can prevent the cache size to grow beyond the | ||||
| limit set by you. | ||||
|  | ||||
| When the cache is full, curl closes the oldest one in the cache to prevent the | ||||
| number of open connections to increase. | ||||
|  | ||||
| This option is for the multi handle's use only, when using the easy interface | ||||
| you should instead use the \fICURLOPT_MAXCONNECTS\fP option. | ||||
|  | ||||
| (Added in 7.16.3) | ||||
| .SH RETURNS | ||||
| The standard CURLMcode for multi interface error codes. Note that it returns a | ||||
| CURLM_UNKNOWN_OPTION if you try setting an option that this version of libcurl | ||||
|   | ||||
| @@ -4,29 +4,40 @@ | ||||
| .SH NAME | ||||
| curl_multi_socket \- reads/writes available data | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| CURLMcode curl_multi_socket_action(CURLM * multi_handle,  | ||||
|                                    curl_socket_t sockfd, int ev_bitmask, | ||||
|                                    int *running_handles); | ||||
|  | ||||
| CURLMcode curl_multi_socket(CURLM * multi_handle, curl_socket_t sockfd, | ||||
|                             int *running_handles); | ||||
|  | ||||
| CURLMcode curl_multi_socket_all(CURLM *multi_handle, | ||||
|                                 int *running_handles); | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| Alternative versions of \fIcurl_multi_perform(3)\fP that allows the | ||||
| application to pass in one of the file descriptors/sockets that have been | ||||
| detected to have \&"action" on them and let libcurl perform. This allows | ||||
| libcurl to not have to scan through all possible file descriptors to check for | ||||
| action. When the application has detected action on a socket handled by | ||||
| libcurl, it should call \fIcurl_multi_socket(3)\fP with the \fBsockfd\fP | ||||
| argument set to the socket with the action. | ||||
| application to pass in the file descriptor/socket that has been detected to | ||||
| have \&"action" on it and let libcurl perform. This allows libcurl to not have | ||||
| to scan through all possible file descriptors to check for action. When the | ||||
| application has detected action on a socket handled by libcurl, it should call | ||||
| \fIcurl_multi_socket_action(3)\fP with the \fBsockfd\fP argument set to the | ||||
| socket with the action. When the events on a socket are known, they can be | ||||
| passed as an events bitmask \fBev_bitmask\fP by first setting \fBev_bitmask\fP | ||||
| to 0, and then adding using bitwise OR (|) any combination of events to be | ||||
| choosen from CURL_CSELECT_IN, CURL_CSELECT_OUT or CURL_CSELECT_ERR. When the | ||||
| events on a socket are unknown, pass 0 instead, and libcurl will test the | ||||
| descriptor internally. | ||||
|  | ||||
| At return, the int \fBrunning_handles\fP points to will contain the number of | ||||
| still running easy handles within the multi handle. When this number reaches | ||||
| zero, all transfers are complete/done. Note that when you call | ||||
| \fIcurl_multi_socket(3)\fP on a specific socket and the counter decreases by | ||||
| one, it DOES NOT necessarily mean that this exact socket/transfer is the one | ||||
| that completed. Use \fIcurl_multi_info_read(3)\fP to figure out which easy | ||||
| handle that completed. | ||||
| \fIcurl_multi_socket_action(3)\fP on a specific socket and the counter | ||||
| decreases by one, it DOES NOT necessarily mean that this exact socket/transfer | ||||
| is the one that completed. Use \fIcurl_multi_info_read(3)\fP to figure out | ||||
| which easy handle that completed. | ||||
|  | ||||
| The curl_multi_socket functions inform the application about updates in the | ||||
| socket (file descriptor) status by doing none, one or multiple calls to the | ||||
| @@ -44,6 +55,10 @@ wait for socket actions \- at most \- before doing the timeout action: call | ||||
| the \fBcurl_multi_socket(3)\fP function with the \fBsockfd\fP argument set to | ||||
| CURL_SOCKET_TIMEOUT. | ||||
|  | ||||
| Usage of \fIcurl_multi_socket(3)\fP is depricated, whereas the function is | ||||
| equivalent to \fIcurl_multi_socket_action(3)\fP, when \fBev_bitmask\fP is set  | ||||
| to 0. | ||||
|  | ||||
| .SH "CALLBACK DETAILS" | ||||
|  | ||||
| The socket \fBcallback\fP function uses a prototype like this | ||||
| @@ -115,12 +130,15 @@ callback is called. | ||||
|  | ||||
| 7. Wait for action on any of libcurl's sockets | ||||
|  | ||||
| 8, When action happens, call curl_multi_socket() for the socket(s) that got | ||||
| 8, When action happens, call curl_multi_socket_action() for the socket(s) that got | ||||
| action. | ||||
|  | ||||
| 9. Go back to step 6. | ||||
| .SH AVAILABILITY | ||||
| This function was added in libcurl 7.15.4, although not deemed stable yet. | ||||
| This function was added in libcurl 7.15.4, although deemed stablesince 7.16.0. | ||||
|  | ||||
| \fIcurl_multi_socket(3)\fP is deprecated, use | ||||
| \fIcurl_multi_socket_action(3)\fP instead! | ||||
| .SH "SEE ALSO" | ||||
| .BR curl_multi_cleanup "(3), " curl_multi_init "(3), " | ||||
| .BR curl_multi_fdset "(3), " curl_multi_info_read "(3)" | ||||
|   | ||||
| @@ -24,8 +24,9 @@ The list should be freed again (after usage) with | ||||
| A null pointer is returned if anything went wrong, otherwise the new list | ||||
| pointer is returned. | ||||
| .SH EXAMPLE | ||||
| .nf | ||||
|  CURL handle; | ||||
|  curl_slist *slist=NULL; | ||||
|  struct curl_slist *slist=NULL; | ||||
|  | ||||
|  slist = curl_slist_append(slist, "pragma:"); | ||||
|  curl_easy_setopt(handle, CURLOPT_HTTPHEADER, slist); | ||||
| @@ -33,5 +34,6 @@ pointer is returned. | ||||
|  curl_easy_perform(handle); | ||||
|  | ||||
|  curl_slist_free_all(slist); /* free the list again */ | ||||
| .fi | ||||
| .SH "SEE ALSO" | ||||
| .BR curl_slist_free_all "(3), " | ||||
|   | ||||
| @@ -21,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl_version_info 3 "19 Apr 2006" "libcurl 7.15.4" "libcurl Manual" | ||||
| .TH curl_version_info 3 "2 Nov 2006" "libcurl 7.16.1" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_version_info - returns run-time libcurl version info | ||||
| .SH SYNOPSIS | ||||
| @@ -66,6 +66,11 @@ typedef struct { | ||||
|   /* when 'age' is 2 or higher, the member below also exists: */ | ||||
|   const char *libidn;       /* human readable string */ | ||||
|  | ||||
|   /* when 'age' is 3 or higher, the members below also exist: */ | ||||
|   int iconv_ver_num;       /* '_libiconv_version' if iconv support enabled */ | ||||
|  | ||||
|   const char *libssh_version; /* human readable string */ | ||||
|  | ||||
| } curl_version_info_data; | ||||
| .fi | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,27 @@ | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" *                                  _   _ ____  _ | ||||
| .\" *  Project                     ___| | | |  _ \| | | ||||
| .\" *                             / __| | | | |_) | | | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2007, 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. | ||||
| .\" * | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH libcurl-errors 3 "9 Feb 2005" "libcurl 7.13.1" "libcurl errors" | ||||
| .TH libcurl-errors 3 "8 May 2007" "libcurl 7.16.3" "libcurl errors" | ||||
| .SH NAME | ||||
| libcurl-errors \- error codes in libcurl | ||||
| .SH DESCRIPTION | ||||
| @@ -86,9 +105,10 @@ An error occurred when writing received data to a local file, or an error was | ||||
| returned to libcurl from a write callback. | ||||
| .IP "CURLE_MALFORMAT_USER (24)" | ||||
| This is never returned by current libcurl. | ||||
| .IP "CURLE_FTP_COULDNT_STOR_FILE (25)" | ||||
| FTP couldn't STOR file. The server denied the STOR operation. The error buffer | ||||
| usually contains the server's explanation to this. | ||||
| .IP "CURLE_UPLOAD_FAILED (25)" | ||||
| Failed starting the upload. For FTP, the server typcially denied the STOR | ||||
| command. The error buffer usually contains the server's explanation to this. | ||||
| (This error code was formerly known as CURLE_FTP_COULDNT_STOR_FILE.) | ||||
| .IP "CURLE_READ_ERROR (26)" | ||||
| There was a problem reading a local file or an error returned by the read | ||||
| callback. | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -21,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH libcurl-multi 3 "13 Oct 2001" "libcurl 7.10.1" "libcurl multi interface" | ||||
| .TH libcurl-multi 3 "3 Feb 2007" "libcurl 7.16.0" "libcurl multi interface" | ||||
| .SH NAME | ||||
| libcurl-multi \- how to use the multi interface | ||||
| .SH DESCRIPTION | ||||
| @@ -104,6 +104,12 @@ get more messages until the message queue is empty. The information you | ||||
| receive there includes an easy handle pointer which you may use to identify | ||||
| which easy handle the information regards. | ||||
|  | ||||
| When a single transfer is completed, the easy handle is still left added to | ||||
| the multi stack. You need to first remove the easy handle with | ||||
| \fIcurl_multi_remove_handle(3)\fP and then close it with | ||||
| \fIcurl_easy_cleanup(3)\fP, or possibly set new options to it and add it again | ||||
| with \fIcurl_multi_add_handle(3)\fP to start another transfer. | ||||
|  | ||||
| When all transfers in the multi stack are done, cleanup the multi handle with | ||||
| \fIcurl_multi_cleanup(3)\fP. Be careful and please note that you \fBMUST\fP | ||||
| invoke separate \fIcurl_easy_cleanup(3)\fP calls on every single easy handle | ||||
| @@ -112,3 +118,26 @@ to clean them up properly. | ||||
| If you want to re-use an easy handle that was added to the multi handle for | ||||
| transfer, you must first remove it from the multi stack and then re-add it | ||||
| again (possibly after having altered some options at your own choice). | ||||
| .SH "MULTI_SOCKET" | ||||
| Since 7.16.0, the \fIcurl_multi_socket(3)\fP function offers a way for | ||||
| applications to not only avoid being forced to use select(), but it also | ||||
| offers a much more high-performing API that will make a significant difference | ||||
| for applications using large numbers of simultaneous connections. | ||||
|  | ||||
| \fIcurl_multi_socket(3)\fP (and \fIcurl_multi_socket_all(3)\fP) is then used | ||||
| instead of \fIcurl_multi_perform(3)\fP. | ||||
| .SH "BLOCKING" | ||||
| A few areas in the code are still using blocking code, even when used from the | ||||
| multi interface. While we certainly want and intend for these to get fixed in | ||||
| the future, you should be aware of the following current restrictions: | ||||
|  | ||||
| .nf | ||||
|  - Name resolves on non-windows unless c-ares is used | ||||
|  - GnuTLS SSL connections | ||||
|  - Active FTP connections | ||||
|  - HTTP proxy CONNECT operations | ||||
|  - SCP and SFTP connections | ||||
|  - SFTP transfers | ||||
|  - TFTP transfers | ||||
|  - file:// transfers | ||||
| .fi | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user