Compare commits
	
		
			1227 Commits
		
	
	
		
			curl-7_15_
			...
			curl-7_16_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 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 | ||
|   | 719bec2606 | ||
|   | b1db9dbb16 | ||
|   | 609044aea2 | ||
|   | ba481718a4 | ||
|   | 1be60dde7f | ||
|   | e92e811a61 | ||
|   | 5aa0db8681 | ||
|   | d5691211dd | ||
|   | a93695a70e | ||
|   | ce935a2697 | ||
|   | 812ce0d93f | ||
|   | bbae5b49f9 | ||
|   | 772a985dc3 | ||
|   | 8a7514de8a | ||
|   | 32ad212ac9 | ||
|   | 8a8d5c784c | ||
|   | 125830ab4b | ||
|   | 5b75b423e6 | ||
|   | 012d7e2878 | ||
|   | cd3029f36f | ||
|   | 6adaac7e18 | ||
|   | cde5e35d9b | ||
|   | ee17fba72e | ||
|   | 6296b89319 | ||
|   | 5450db9151 | ||
|   | b4700f026b | ||
|   | d771fa7c48 | ||
|   | b2c378267b | ||
|   | 384c8f3560 | ||
|   | f44ef427a2 | ||
|   | c54a4301ee | ||
|   | 36a3514225 | ||
|   | e1edd41e1b | ||
|   | 13e60c55a1 | ||
|   | 9b8b1a68f0 | ||
|   | 4ec9316155 | ||
|   | ef769500d4 | ||
|   | 23692574a2 | ||
|   | 5f6fd682a5 | ||
|   | db24518a30 | ||
|   | 90933ac660 | ||
|   | 087579a6f4 | ||
|   | de59cde155 | ||
|   | 3cd95eacdf | ||
|   | deb81b2ad4 | ||
|   | 4e717cdb30 | ||
|   | 33acd6f041 | ||
|   | 7575e6afc4 | ||
|   | 316a9f6480 | ||
|   | c6de584cad | ||
|   | d997ff6aa8 | ||
|   | b9ccecf86e | ||
|   | bd5d21aaf2 | ||
|   | 19e07771d1 | ||
|   | ef267ab449 | ||
|   | 4f6ed683e8 | ||
|   | c818e7064f | ||
|   | ead6ab2ef7 | ||
|   | 5c3dc49f44 | ||
|   | 83884180ac | ||
|   | 4cac96c33a | ||
|   | 5df4be1165 | ||
|   | 96445f1b7d | ||
|   | 4bdd7596d3 | ||
|   | 18aae32015 | ||
|   | a8996b9e52 | ||
|   | 94095c61d8 | ||
|   | 1cddd744ad | ||
|   | 786738dd00 | ||
|   | 5b8d5fdf2f | ||
|   | 694f31ca37 | ||
|   | 9c1ad0f9f7 | ||
|   | 71c6335293 | ||
|   | 8c38ea4ebc | ||
|   | 44d84ac164 | ||
|   | 930f9bd534 | ||
|   | b61fbbde46 | ||
|   | ec956b0334 | ||
|   | 44ffe0dc79 | ||
|   | e3a61fba52 | ||
|   | 65794f60ec | ||
|   | 7a710b4970 | ||
|   | 0bb20cc611 | ||
|   | 433c0c895e | ||
|   | 67e8d22958 | ||
|   | 10d1fc0e73 | ||
|   | 2260c8aa11 | ||
|   | 97eb62aff8 | ||
|   | 1855fc35f2 | ||
|   | dc3ed35313 | ||
|   | 6b868df554 | ||
|   | 5ccbbe40c2 | ||
|   | 86f93a53d6 | ||
|   | f53347631e | ||
|   | efe3cb6e1a | ||
|   | 32ac4edeed | ||
|   | 4c04c09138 | ||
|   | 47ea80baee | ||
|   | 95c3fa836b | ||
|   | ab60a12465 | ||
|   | 2d38e51867 | ||
|   | a5dda669e3 | ||
|   | 3c4f3a680a | ||
|   | b61c06384a | ||
|   | e7742bfb7c | ||
|   | 22307ae0ee | ||
|   | e150150d9f | ||
|   | 943f0733bb | ||
|   | 8274447dd9 | ||
|   | 083a84e5d0 | ||
|   | d5eb386d00 | ||
|   | 1ce7b48057 | ||
|   | cbcdd337aa | ||
|   | c144adf77c | ||
|   | d390039873 | ||
|   | 7d0c58a285 | ||
|   | 9263001b21 | ||
|   | 66ee6d07f8 | ||
|   | a40dcca794 | ||
|   | 15e3dfe1d3 | ||
|   | a1de9367ec | ||
|   | eceb37bde2 | ||
|   | 56fcf85ab6 | ||
|   | 77db81d661 | ||
|   | 2ad7fcbc2f | ||
|   | 2c62dfd124 | ||
|   | ef66497a0d | ||
|   | 1128029599 | ||
|   | befc30bc55 | ||
|   | ca5846cde9 | ||
|   | 8547ab1663 | ||
|   | 9c0e6ac365 | ||
|   | 552b963e6d | ||
|   | e2b48366d3 | ||
|   | 5e0d9aea32 | ||
|   | ae13c93b7d | ||
|   | b9f8a4a477 | ||
|   | 68e9f75708 | ||
|   | d569693f24 | ||
|   | 15d8bb2105 | ||
|   | b2ca777a08 | ||
|   | ba01198e6c | ||
|   | 6ebd5e1761 | ||
|   | 2723eda1e4 | ||
|   | 1fa3a5cce9 | ||
|   | fe8aee6b08 | ||
|   | 0639e2a6e2 | ||
|   | f1d707705e | ||
|   | 296a7db960 | ||
|   | 4c0936e72f | ||
|   | 0992e391ba | ||
|   | b22aaeef6a | ||
|   | 8090ee0e5d | ||
|   | f7d31bb3e3 | ||
|   | 9cd928674f | ||
|   | 3ea8a4d220 | ||
|   | b0d3ba76a0 | ||
|   | ab798fe5ba | ||
|   | e7d90e08b9 | ||
|   | c2404f77e9 | ||
|   | ec4a16f2e0 | ||
|   | ca5de26f50 | ||
|   | 71920d61e6 | ||
|   | 5de75eee56 | ||
|   | 2d5fc39d35 | ||
|   | c001ed53fa | ||
|   | 39e01e9349 | ||
|   | 9e54d4c7d2 | ||
|   | 56bf97ffc9 | ||
|   | 7d3e719a2c | ||
|   | e55d4fd5c1 | ||
|   | 5ee231415f | ||
|   | c866771cd2 | ||
|   | 4a24219a1a | ||
|   | 733a184ce0 | ||
|   | eee09e79e8 | ||
|   | 6df85adf3e | ||
|   | 3ee6036551 | ||
|   | fb65080548 | ||
|   | 3a5f21b0d1 | ||
|   | 13a5598dc3 | ||
|   | 5a6c89661a | ||
|   | 7c5745720a | ||
|   | 00ae13f966 | ||
|   | 29dc39fce1 | ||
|   | 5c184cfc0d | ||
|   | 055022a55f | ||
|   | c30e908034 | ||
|   | 8d24c0212e | ||
|   | 8240cea628 | ||
|   | f2a33eb372 | ||
|   | e134a40208 | ||
|   | 690888cfc1 | ||
|   | fb8d9b6645 | ||
|   | f7ddb39ee1 | ||
|   | 145084b699 | ||
|   | f1ba12607a | ||
|   | bb87b65f08 | ||
|   | b0f6e7cee4 | ||
|   | ed72d4e104 | ||
|   | 8ec1bfe897 | ||
|   | 1dec17562f | ||
|   | 9cc3795f1a | ||
|   | be1306a6c2 | ||
|   | e9160a31e0 | ||
|   | 0a670c578f | ||
|   | e3c15fc4b9 | ||
|   | dc7c915553 | ||
|   | b7eeb6e67f | ||
|   | 7e4193b538 | ||
|   | a932803eac | ||
|   | 52560142bf | ||
|   | 874a4ef8c7 | ||
|   | 0bb3ac7c31 | ||
|   | 1e9f5845ab | ||
|   | c41dfc2501 | ||
|   | 30ac7eced1 | ||
|   | 466d093a92 | ||
|   | 1e9be353c2 | ||
|   | 4f4277d9c7 | ||
|   | 6728bda5c5 | ||
|   | dc9f154823 | ||
|   | d7168a82e2 | ||
|   | c9c8ee3796 | ||
|   | c7aae10300 | ||
|   | 909941405f | ||
|   | 4031eb1d91 | ||
|   | 59cf6fd4f0 | ||
|   | 6de9732a88 | ||
|   | 1f7f500922 | ||
|   | 4b1462ec65 | ||
|   | 6ed47f0aad | ||
|   | 2d8c7ba9fc | ||
|   | 3b342d18bc | ||
|   | f24ad3800c | ||
|   | e2ff369eba | ||
|   | 9691a78f6b | ||
|   | 7ff6b6fafd | ||
|   | 7c621cfbdf | ||
|   | 5acadc9cd7 | ||
|   | 2ff609dd43 | ||
|   | da48a6ba87 | ||
|   | cd6c58216a | ||
|   | bdbd0cf27a | ||
|   | d792937686 | ||
|   | bac66ec26b | ||
|   | 77516822f6 | ||
|   | 37d8c67530 | ||
|   | cfdcae4bc7 | ||
|   | 74a6921bc4 | ||
|   | 490cccba3c | ||
|   | 839441e236 | ||
|   | ba9ea943e2 | ||
|   | 455087faae | ||
|   | 31def9e217 | ||
|   | ee3514ccdc | ||
|   | cf606d7da0 | ||
|   | eb26a581f9 | ||
|   | b04cbebf86 | ||
|   | 4272af801f | ||
|   | 0b633027cb | ||
|   | 93943ef949 | ||
|   | b184b87714 | ||
|   | a11473f85d | ||
|   | 1eedad27a2 | ||
|   | ac02d379ba | ||
|   | a4ebf5b507 | ||
|   | c410769588 | ||
|   | 997a987943 | ||
|   | 6201dc083a | ||
|   | b33f47804d | ||
|   | 7ba5e098a3 | ||
|   | 824b78021c | ||
|   | 31657c85e5 | ||
|   | 7010e5ea84 | ||
|   | 2cba6b246d | ||
|   | 52cc2a7a0c | ||
|   | c012e2b408 | ||
|   | 646a6b604f | ||
|   | cca00a6378 | ||
|   | 10b7fc7e51 | ||
|   | 43e4544d51 | ||
|   | 21aa8f0b45 | ||
|   | b708fa51ad | ||
|   | 8709f6c4b3 | ||
|   | 2ac560e58b | ||
|   | 8f8ba9486d | ||
|   | f55924b3e0 | ||
|   | 7240acdebc | ||
|   | b9b06b00bf | ||
|   | 51f258d103 | ||
|   | 4c75f1c7b7 | ||
|   | ed7bff1fec | ||
|   | 01a79be2c9 | ||
|   | d211fcd34f | ||
|   | 159834171e | ||
|   | 8a38c72c48 | ||
|   | fbcdc192d5 | ||
|   | ee642859ef | ||
|   | 9f579f12fc | ||
|   | 825a526789 | ||
|   | ae8a01ead6 | ||
|   | 9dde0b54a3 | ||
|   | f1343b2f55 | ||
|   | 962b7985e6 | ||
|   | 5a1c64d316 | ||
|   | 01b2cf82ec | ||
|   | c033c4c71c | ||
|   | aa791ee5cf | ||
|   | 305671e2ab | ||
|   | d654736834 | ||
|   | 2c81bfead5 | ||
|   | 77b3bc239d | ||
|   | c10d15aa0f | ||
|   | a88deadd6f | ||
|   | e6ea8f1199 | ||
|   | 4d4151f6c1 | ||
|   | 518becfe2e | ||
|   | 6f6b93da02 | ||
|   | 45b1843dc9 | ||
|   | cb86a302d8 | ||
|   | d15ed439ae | ||
|   | b765e1f3b7 | ||
|   | 2527b53019 | ||
|   | 78a47826b2 | ||
|   | ecfaa4f869 | ||
|   | f36adcdb73 | ||
|   | 13616f8f96 | ||
|   | ab486d1e27 | ||
|   | 9111909c1d | ||
|   | 4a1a1a75fb | ||
|   | e4d6ade4b3 | ||
|   | c82e880f5b | ||
|   | f2aa3b21e0 | ||
|   | 385db0e97d | ||
|   | 4e58da5222 | ||
|   | 1c6ebb0782 | ||
|   | 7e8b84c3e7 | ||
|   | 132067b081 | ||
|   | 8c36fc8f31 | ||
|   | 93858efe73 | ||
|   | ba7f27a3f6 | ||
|   | 2f70fb7015 | ||
|   | 655ec6bf8e | ||
|   | c4ad533300 | ||
|   | 5cdbd0cf4a | ||
|   | a55c70d4ae | ||
|   | 02938a010d | ||
|   | e40641bf7c | ||
|   | 27c0b43897 | ||
|   | d46de5ab8b | ||
|   | 73ebb0edde | ||
|   | 684245d6ce | ||
|   | d157c29269 | ||
|   | 4d2e81661b | ||
|   | 483a586d55 | ||
|   | 4ac54f8c2c | ||
|   | 840aacf7dd | ||
|   | ab4256d53a | ||
|   | 46c5e562bf | ||
|   | 42f5a90d09 | ||
|   | ef82da93fb | ||
|   | 06d05b18b2 | ||
|   | 431c4bd6e3 | ||
|   | f72c4e82fd | ||
|   | 9c83a20a27 | ||
|   | 773bec5ae5 | ||
|   | f3c508f6e8 | ||
|   | 2aa4710745 | ||
|   | 3b0a920fad | ||
|   | daef1cf34d | ||
|   | bd8d4637a3 | ||
|   | d2cefc140a | ||
|   | ccfce89423 | ||
|   | 700cd5805c | ||
|   | 498aad8587 | ||
|   | 73f407b7ae | ||
|   | 4be7dcba48 | ||
|   | f0694c582e | ||
|   | f90f0c98d9 | ||
|   | 95aecc5dbb | ||
|   | f975fd03a1 | ||
|   | 8272874704 | ||
|   | 86f4cead16 | ||
|   | 88a1a10e6f | ||
|   | 624e657210 | ||
|   | 2278e8f1ba | ||
|   | 58176d1484 | ||
|   | 10489879f7 | ||
|   | fe22872d14 | ||
|   | 4d95d23d99 | ||
|   | c6fc5a1a26 | ||
|   | 012d75442a | ||
|   | dcc7900e7c | ||
|   | 34f5e8ad0e | ||
|   | c2fee9894a | ||
|   | abd983e851 | ||
|   | 28611704d9 | ||
|   | 305dddeab0 | ||
|   | ee8112b42f | ||
|   | ca319f63ad | ||
|   | a09a8164db | ||
|   | e5cf6a20a7 | ||
|   | af5e6e7e6d | ||
|   | 70f2b5e877 | ||
|   | 8ef454dcbe | ||
|   | 551a041283 | ||
|   | 03288943af | ||
|   | 725f734bae | ||
|   | 0f32460656 | ||
|   | 25180cc850 | ||
|   | 2a0e41cab9 | ||
|   | 05edd48ad0 | ||
|   | 266ab95557 | ||
|   | 0a4bba565c | ||
|   | 2ddb9d57aa | ||
|   | 4f012ad703 | ||
|   | a1cd180082 | ||
|   | bc2f0c7dcb | ||
|   | c6ae0ebcbf | ||
|   | c6ec576cbb | ||
|   | 55329b56cb | ||
|   | 7e43d06b60 | ||
|   | 89f54f3739 | ||
|   | 01fa02d0b5 | ||
|   | 8bed45340a | ||
|   | 55138753c6 | ||
|   | 43369b8096 | ||
|   | bec1977137 | ||
|   | 4c08eb4b11 | ||
|   | 0163730437 | ||
|   | 39745ac38e | ||
|   | cacf8bbb58 | ||
|   | a1c6d5861a | ||
|   | 589c4596d8 | ||
|   | 7a6d7fca42 | ||
|   | 5305c9f1e8 | ||
|   | b1022ea4c1 | ||
|   | 380a74a4ed | ||
|   | ff709848a6 | ||
|   | 279dd6d878 | ||
|   | 2e0ad842d0 | ||
|   | a3949c7786 | ||
|   | 2320606262 | ||
|   | b01286d280 | ||
|   | 64f72c22b9 | ||
|   | 856114d05c | ||
|   | 98b8c4b0c9 | ||
|   | 01f5f0be5a | ||
|   | eb6d404753 | ||
|   | c508ab1aef | ||
|   | 0793dc922c | ||
|   | 00a41ab296 | ||
|   | 37f4877e56 | ||
|   | a6fc45c02f | ||
|   | 25411e01db | ||
|   | a8ac6f1dc1 | ||
|   | dfe1884c25 | ||
|   | 3e5dcc8bcd | ||
|   | ff81900784 | ||
|   | 4cb30a3057 | ||
|   | 72f80b88f7 | ||
|   | 3008d8133c | ||
|   | 4524618bf2 | ||
|   | 55d22ba10c | ||
|   | 76cf020750 | ||
|   | f13ac35edf | ||
|   | 59582a9d9d | ||
|   | 6246bbc656 | ||
|   | 1b028b419b | ||
|   | 4c6c768422 | ||
|   | 1d3969b215 | ||
|   | 94116d9ebc | ||
|   | cc5174a89a | ||
|   | 31552100c5 | ||
|   | 8df5dcb193 | ||
|   | 7929600798 | ||
|   | a05ea124b9 | ||
|   | 6a03ab3ad4 | ||
|   | 6a151c1312 | ||
|   | 990e56fb13 | ||
|   | 2bd3033f68 | ||
|   | fe105a07e3 | ||
|   | a5782defd3 | ||
|   | bcccd2fe74 | ||
|   | 404e23734b | ||
|   | 973d63f4f2 | ||
|   | 405d98ee63 | ||
|   | f81724969d | ||
|   | edb5444fa3 | ||
|   | e877cb7bd7 | ||
|   | 482b3ba702 | ||
|   | 752acedc0b | ||
|   | fb88723afc | ||
|   | 3718737091 | ||
|   | 3d3f056f7e | ||
|   | c60621c367 | ||
|   | 606562aa7e | ||
|   | f689d06ca9 | ||
|   | 7cfd7f3fb1 | ||
|   | 4a8dfb3461 | ||
|   | 3752b3aead | ||
|   | b81d41df22 | ||
|   | dadf3f06ee | ||
|   | 8ed0d5675f | ||
|   | d5e9041344 | ||
|   | d99c20f628 | ||
|   | 973ed24dc8 | ||
|   | 5d5f5e3be8 | ||
|   | d9e14408f0 | ||
|   | c9c5ce2365 | ||
|   | 975534370f | ||
|   | 28605f6bd3 | ||
|   | 3c6d3b69c2 | ||
|   | 00312e95fe | ||
|   | 4223130bb0 | ||
|   | c811e1ce70 | ||
|   | 77475f2ad0 | ||
|   | 3680a2f6f5 | ||
|   | 1946058e7b | ||
|   | 73daf8ce33 | ||
|   | 094ceeba14 | ||
|   | 3b7359a27a | ||
|   | df9108e19b | ||
|   | 6307e783d8 | ||
|   | b9cd73c76d | ||
|   | b62c230ca2 | ||
|   | 800193da9b | ||
|   | 577ba5783c | ||
|   | 9bece2b313 | ||
|   | e85e30546c | ||
|   | 758f6eed51 | ||
|   | 80ee5d3bd8 | ||
|   | dd06c60ada | ||
|   | 6ca627ae74 | ||
|   | 80a0b81c2a | ||
|   | 06a7b0561b | ||
|   | 12db20be4e | ||
|   | 3cbb1b2b64 | ||
|   | d75e587613 | ||
|   | 414c57d138 | ||
|   | c14a84e6f2 | ||
|   | def0db30e7 | ||
|   | 6ef7a81a3b | ||
|   | 95152aec68 | ||
|   | 8ed6762363 | ||
|   | 87c5ed8bec | ||
|   | ecc6c1f501 | ||
|   | 3d8338b0d4 | ||
|   | c91e25518f | ||
|   | a8dddeab61 | ||
|   | 8f0a5ab660 | ||
|   | db03d4bdd0 | ||
|   | 0ec96e4279 | ||
|   | 6e520c4cdc | ||
|   | 1e8683d72d | ||
|   | 2df622fd14 | ||
|   | fede784fa2 | ||
|   | f191b143e9 | ||
|   | 59212553b5 | ||
|   | e532b196cc | ||
|   | 0f5232280c | ||
|   | 38898ba4af | ||
|   | 48f56d9600 | ||
|   | 17bf5ac2fc | ||
|   | 343b882d80 | ||
|   | db06d21339 | ||
|   | 19240f08bb | ||
|   | d774730f83 | ||
|   | c2edf42567 | ||
|   | 08f0e55b4f | ||
|   | deeb74b7e4 | ||
|   | 0542002d7a | ||
|   | c1e307f585 | ||
|   | 7b4ba43dcf | ||
|   | b0e4debaab | ||
|   | 676597e961 | ||
|   | 686d90745b | ||
|   | 5dc02d53c3 | ||
|   | 0598547b58 | ||
|   | 67c7745f5d | ||
|   | a2c289646d | ||
|   | e6efecd054 | ||
|   | 778b6a86c0 | ||
|   | e5babd086d | ||
|   | c212ebbdda | ||
|   | 83b8de3d43 | ||
|   | e174d374f2 | ||
|   | 4edb93508d | ||
|   | 38c994b83b | ||
|   | 1b8643d4c9 | ||
|   | d3c796f5b0 | ||
|   | 83d8a6a450 | ||
|   | a21a77d230 | ||
|   | 260b88c197 | ||
|   | 655331a91b | ||
|   | 09e569f83d | ||
|   | e4a4b562c4 | ||
|   | 35b4a755f9 | ||
|   | 5a4b43848a | ||
|   | d98869a088 | ||
|   | 4d33cf739d | ||
|   | 34e7daf989 | ||
|   | b0adcd6a46 | ||
|   | be285cde3f | ||
|   | 0ff1faf7f2 | ||
|   | bcc62cc9e3 | ||
|   | 97b466d409 | ||
|   | f17d9bba14 | ||
|   | d74725ce67 | ||
|   | 3dad55d7a8 | ||
|   | 598ffeea89 | ||
|   | 83367f67de | ||
|   | 15f2647d71 | ||
|   | 6421d69bff | ||
|   | 18081e30e1 | ||
|   | 97181b5c0d | ||
|   | a63f9887b9 | ||
|   | 1282aad4a5 | ||
|   | b8fad99f09 | ||
|   | c7e9e60b05 | ||
|   | 47f2e1da73 | ||
|   | 5975229919 | ||
|   | 38295e8a75 | ||
|   | f9612b5eaf | ||
|   | 5cf2ef2ef7 | ||
|   | 938b5c886e | ||
|   | 0618e68200 | ||
|   | bac52f3969 | ||
|   | d494d62953 | ||
|   | 7206181385 | ||
|   | 3f22901a43 | ||
|   | f70f11fc70 | ||
|   | cffebd7fd6 | ||
|   | b8c8e7349f | ||
|   | 8bba99ae56 | ||
|   | b5c5f57613 | ||
|   | 33df856925 | ||
|   | ce09cedd2e | ||
|   | 7d68101f83 | ||
|   | aa50a00898 | ||
|   | 26f112ba55 | ||
|   | 159b9162f8 | ||
|   | d7999f9fcb | ||
|   | f13eba4c78 | ||
|   | 050e82e088 | ||
|   | 88377e5b61 | ||
|   | 241af465fd | ||
|   | 59510a554d | ||
|   | b10aa95d28 | ||
|   | 097bee681a | ||
|   | 8548c2fc61 | ||
|   | dc4fbd2e97 | ||
|   | 60b029869f | ||
|   | f592ea6c30 | ||
|   | a39ac3d94a | ||
|   | 4b23ddc002 | ||
|   | 4486d336a6 | ||
|   | 45e4b811b0 | ||
|   | 0e6a1a4420 | ||
|   | b8bf708db9 | ||
|   | 6fdbb01194 | ||
|   | d29147565c | ||
|   | 75c9430559 | ||
|   | 9ac99a80c3 | ||
|   | a15d107dde | ||
|   | 09897b8146 | ||
|   | 29e446e508 | ||
|   | 10beb36b1c | ||
|   | a65a888866 | ||
|   | 98180b5cc7 | ||
|   | 92009181af | ||
|   | 831bdb9f63 | ||
|   | 50a4dbbb5e | ||
|   | ad6511c313 | ||
|   | 7a37fa4aef | ||
|   | dcee24191f | ||
|   | 87bcb6f377 | ||
|   | b0bc2f00d2 | ||
|   | 3b19c7d0d9 | ||
|   | 12f5c67bf5 | ||
|   | d7a83d8995 | ||
|   | 7725729d90 | ||
|   | e96445bd02 | ||
|   | da2c124675 | ||
|   | 8cb695a963 | ||
|   | 54cbd7e154 | ||
|   | 5994b62930 | ||
|   | 2fbf94b0f3 | ||
|   | 32bc30e210 | ||
|   | f3bc8e6ce1 | ||
|   | 16f3a32bec | ||
|   | c44d2498e3 | ||
|   | 2aed209efa | ||
|   | b55b780d7b | ||
|   | 8d4eb2bc1f | ||
|   | 67bf4f28ff | ||
|   | 803582f8ac | ||
|   | 03603f392a | ||
|   | fcfd6d9504 | ||
|   | c31451cf13 | ||
|   | 5deff1a179 | ||
|   | e236a1c99b | ||
|   | a2f3094eb0 | ||
|   | 65afc576ea | ||
|   | 8971f656b4 | ||
|   | 394ce9ee39 | ||
|   | 67a83c1b34 | ||
|   | 1e8d094274 | ||
|   | 4c35a40858 | ||
|   | 802b2aaf6a | ||
|   | 0e79a8944b | ||
|   | bebf70667d | ||
|   | d9bd5de0b1 | ||
|   | 31c7aa0ba4 | ||
|   | fc2388189f | ||
|   | 4431338691 | ||
|   | bda1e9aeab | ||
|   | 4969ca768d | ||
|   | 2acd1c1642 | ||
|   | e1e753179a | ||
|   | f4cc8153ae | ||
|   | e4d8cb4ee0 | ||
|   | 723a78ae3f | ||
|   | cd9d0d7dec | ||
|   | 665d4f08c8 | ||
|   | 00c7780fcb | ||
|   | 15ab13dc42 | ||
|   | 8a0ca3066e | ||
|   | ea01755bb4 | ||
|   | 69c2084a18 | ||
|   | 99c0a1a7d0 | ||
|   | 5acf997e69 | ||
|   | dd87e4ed39 | ||
|   | 2f8c26ba8a | ||
|   | 81b9793807 | ||
|   | 7278f17e8f | ||
|   | 66c7427df0 | ||
|   | c1a06d858d | ||
|   | 53b5fdbe9e | ||
|   | 687cf0235e | ||
|   | b6e9229cf0 | ||
|   | 089e4848d8 | ||
|   | 58d2e7c6d1 | ||
|   | fa18d6fb76 | ||
|   | 4dcb930247 | ||
|   | 74a299fd08 | ||
|   | 532a560d87 | ||
|   | 0040a60559 | ||
|   | cc34342790 | ||
|   | bdbf6e9d19 | ||
|   | db86f765eb | ||
|   | b11dec5dd5 | ||
|   | 86becc7591 | ||
|   | 8922bc038b | ||
|   | 009f5790a4 | ||
|   | 0536b6c459 | ||
|   | 0e3ebd9841 | ||
|   | 598965a606 | ||
|   | d7a2938849 | ||
|   | a683658675 | ||
|   | 25169f68b7 | ||
|   | e5247ae65d | ||
|   | a718cb05ff | ||
|   | b466ef2581 | ||
|   | c7a634641f | ||
|   | e4388643f1 | ||
|   | bc4208201c | ||
|   | a0d69d52a1 | ||
|   | c23a1be139 | ||
|   | 9799f7afb0 | ||
|   | 6358b24fac | ||
|   | b58634316f | ||
|   | e3657644d6 | ||
|   | 7d1e3ebeed | ||
|   | 9e61dfe85e | ||
|   | 7b51aafa86 | ||
|   | 5f487123df | ||
|   | f1f32477e3 | ||
|   | df2b1251a0 | ||
|   | 02c7cf6fa5 | ||
|   | 60006ff993 | ||
|   | f3af5d7b8e | ||
|   | d551412a32 | ||
|   | 6de67a134e | ||
|   | 8ec31398e0 | ||
|   | fd0d560b47 | ||
|   | cc542269a1 | ||
|   | 7b488a3bef | ||
|   | f448168501 | ||
|   | 80a8fb98db | ||
|   | 898bb397b1 | ||
|   | 74ed5b5ebd | ||
|   | 178afd81a9 | ||
|   | d6eb1a7b98 | ||
|   | 4ff56b15e9 | ||
|   | e6b98d3152 | ||
|   | 5fd8dd2dce | ||
|   | 0ad3e046a4 | ||
|   | d6c5d24af3 | ||
|   | 8a3280a2de | ||
|   | 450a0a647a | ||
|   | 676c0cf123 | ||
|   | a731319321 | ||
|   | 81b06a09b7 | ||
|   | 23b34744d9 | ||
|   | bc8590aa12 | ||
|   | 939d368d5f | ||
|   | 336e3b8baf | ||
|   | 47c06fa308 | ||
|   | b7f447f8d8 | ||
|   | 03af76b631 | ||
|   | e105d5c28f | ||
|   | d6ffb4c177 | ||
|   | 6dbfce1031 | ||
|   | fea5ddf585 | ||
|   | b9f39c2711 | ||
|   | 5acac0309a | ||
|   | 78febad718 | ||
|   | a6a5bba0a9 | ||
|   | 51581c034d | ||
|   | 8f25a95b47 | ||
|   | 7f5d092223 | ||
|   | 2e5cccd1b6 | ||
|   | 2645782f89 | ||
|   | 9533092511 | ||
|   | 6005a461bb | ||
|   | e2df946eee | ||
|   | d14588120f | ||
|   | ab31cfa664 | ||
|   | af1c397969 | ||
|   | 947f9deed5 | ||
|   | ce95eee903 | ||
|   | b15f3bb969 | ||
|   | 998e8cba19 | ||
|   | e3f523ab2a | ||
|   | 36485e56ed | ||
|   | b4113360f6 | ||
|   | 2d71e22f08 | ||
|   | 2ae67c431c | ||
|   | 4b1a91b64f | ||
|   | 4f69318e12 | ||
|   | 1cc98ab50f | ||
|   | a6494602fd | ||
|   | 50ec78b488 | ||
|   | 7d044d14f9 | ||
|   | df03d5a8b2 | ||
|   | 6a0ed81e67 | ||
|   | c94f3e8188 | ||
|   | 1e5f6cc1dc | ||
|   | b1fece74e3 | ||
|   | fdbe0df6e7 | ||
|   | 93d59520e4 | ||
|   | b68d3a073b | ||
|   | 2100311f41 | ||
|   | e1269e3156 | ||
|   | c88d61b044 | ||
|   | f49df54a36 | ||
|   | 952bbc4410 | ||
|   | 1eb4b85d72 | ||
|   | 59b6cb9e91 | ||
|   | e06afaeb7a | ||
|   | 8c6f654b26 | ||
|   | 1d8212e53a | ||
|   | 083c5e17e1 | ||
|   | 272231fb09 | ||
|   | 67b4d9b232 | ||
|   | 21709e1557 | ||
|   | 9c312637d1 | ||
|   | feacad7f68 | ||
|   | 6513303498 | ||
|   | 3e2a52b034 | ||
|   | 176d4e85e9 | ||
|   | 84d30dffb6 | ||
|   | 0fd282b078 | ||
|   | cdf4afbe50 | ||
|   | b222b2304e | ||
|   | fdf9900114 | ||
|   | 5867eb2dd2 | ||
|   | 61f145e3de | ||
|   | b97e7fc730 | ||
|   | 01cbf08064 | ||
|   | fec632e948 | ||
|   | 6aab5b57e1 | ||
|   | d2a27e02ce | ||
|   | b55506a76d | ||
|   | afc2aa2b3f | ||
|   | d055b269ed | ||
|   | 8a246a4a9f | ||
|   | 2f684351bf | ||
|   | 74e5beab9d | ||
|   | b41765f441 | ||
|   | 05a6013f42 | ||
|   | cfff544d67 | ||
|   | 599d9642ca | ||
|   | 0264faaa4e | ||
|   | 4022a60ea7 | ||
|   | 39e366fc11 | ||
|   | 096675824f | ||
|   | 80bfa76ac9 | ||
|   | b2e553a82e | ||
|   | 772b64d9d3 | ||
|   | 92c0de518e | ||
|   | ff96456513 | ||
|   | e89adbef51 | ||
|   | 22a6a6cf81 | ||
|   | fd870e4e8a | ||
|   | d52ed3fff2 | ||
|   | bac17ab7d8 | ||
|   | 9ace303528 | ||
|   | 7e81c35cdc | ||
|   | 0f125d9bcf | ||
|   | d4714517c0 | ||
|   | 280e4bf4c3 | ||
|   | adf462fe05 | ||
|   | c2862742ab | ||
|   | 8a712eb5af | ||
|   | d58790af17 | ||
|   | 9ef7a13403 | ||
|   | a5da1219bb | ||
|   | be524fed38 | ||
|   | 042016b85e | ||
|   | f6da574324 | ||
|   | b09d5c3135 | ||
|   | ec65c3fd53 | ||
|   | 7ca2f31c8d | ||
|   | 2275737a5d | ||
|   | 5e3836055f | ||
|   | 37a6a0bb3e | ||
|   | 6bcca3eca9 | ||
|   | ce40b8d531 | ||
|   | 9f109b94b8 | ||
|   | 89024febde | ||
|   | b7a673c6e2 | ||
|   | 7f68be770d | ||
|   | 4f173f35db | ||
|   | ae9fbe573e | ||
|   | 29676f473d | ||
|   | a5fcb26ab1 | ||
|   | d68b1a1e8c | ||
|   | bd8baed138 | ||
|   | 00a7dda273 | ||
|   | 4dba07c384 | ||
|   | 4d39c6b7cc | ||
|   | 7d6f6158c9 | ||
|   | 6863dbbc0c | ||
|   | 28b96efd8b | ||
|   | 0f82af0f49 | ||
|   | f0d839436f | ||
|   | f1aa4b4127 | ||
|   | ccdb43f7f1 | ||
|   | 72900f0f90 | ||
|   | 3ad958ddb1 | ||
|   | 2c77cc90f4 | ||
|   | db4c33b4fb | ||
|   | 3fb04115fc | ||
|   | 4faaa32aef | ||
|   | cab59b4c32 | ||
|   | 931eff89f5 | ||
|   | 175335808b | ||
|   | e00216581e | ||
|   | 23951ec00c | ||
|   | a8fc5d0f9f | ||
|   | f5e85bab1c | ||
|   | 9a44fa83dc | ||
|   | 6b1e54da62 | ||
|   | b91421b107 | ||
|   | 43b3954fa5 | ||
|   | 80f2e3f263 | ||
|   | 9ea423b4c1 | ||
|   | b259c9c535 | ||
|   | 80f481a5f7 | ||
|   | 115fe1b577 | ||
|   | 06d6ea651e | ||
|   | 966fa848a0 | ||
|   | 6f8fe67ace | ||
|   | d49edc8e09 | ||
|   | 3b9c20fe31 | ||
|   | bd72c5eacf | ||
|   | 9d152a77fd | ||
|   | 33dc28b905 | ||
|   | 43ce64dcca | ||
|   | 9e0882ba98 | ||
|   | c890149c8c | ||
|   | 1a1ab2e2e8 | ||
|   | 715b706caa | ||
|   | bfa9c42c25 | ||
|   | 9d98f97e1b | ||
|   | 5eb5ce6ff3 | ||
|   | be9c873a6e | ||
|   | 034d80f6cd | ||
|   | 021e786c71 | ||
|   | 0c6bb8cb66 | ||
|   | 4d7f08a99e | ||
|   | fdef584681 | ||
|   | f335bac8a3 | ||
|   | 51369753bb | ||
|   | 82a4c2bce3 | ||
|   | e73c6e039e | ||
|   | 19bad0844f | 
| @@ -12,3 +12,4 @@ depcomp | ||||
| config.guess | ||||
| config.sub | ||||
| ltmain.sh | ||||
| libcurl.pc | ||||
|   | ||||
							
								
								
									
										1183
									
								
								CHANGES.2005
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1183
									
								
								CHANGES.2005
									
									
									
									
									
										Normal file
									
								
							
										
											
												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 - 2005, Daniel Stenberg, <daniel@haxx.se>. | ||||
| Copyright (c) 1996 - 2007, Daniel Stenberg, <daniel@haxx.se>. | ||||
|  | ||||
| All rights reserved. | ||||
|  | ||||
|   | ||||
							
								
								
									
										6
									
								
								CVS-INFO
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								CVS-INFO
									
									
									
									
									
								
							| @@ -53,12 +53,6 @@ installed: | ||||
|    give you an older version of the file that isn't up-to-date. That file was | ||||
|    checked in once and won't be updated very regularly. | ||||
|  | ||||
|  o yacc/bison  | ||||
|  | ||||
|    If you don't have yacc or bison, you must rename the lib/getdate.c.cvs file | ||||
|    to lib/getdate.c to be able to build libcurl. yacc/bison is normally used | ||||
|    to generate the lib/getdate.c file from the lib/getdate.y source file. | ||||
|  | ||||
| MAC OS X | ||||
|  | ||||
|  With Mac OS X 10.2 and the associated Developer Tools, the installed versions | ||||
|   | ||||
| @@ -31,6 +31,9 @@ bin_SCRIPTS = curl-config | ||||
| SUBDIRS = lib src | ||||
| DIST_SUBDIRS = $(SUBDIRS) tests include packages docs | ||||
|  | ||||
| pkgconfigdir = $(libdir)/pkgconfig | ||||
| pkgconfig_DATA = libcurl.pc | ||||
|  | ||||
| dist-hook: | ||||
| 	rm -rf $(top_builddir)/tests/log | ||||
| 	find $(distdir) -name "*.dist" -exec rm {} \; | ||||
|   | ||||
| @@ -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 | ||||
| @@ -73,6 +73,14 @@ 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 | ||||
| @@ -212,6 +220,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 | ||||
|   | ||||
							
								
								
									
										29
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								README
									
									
									
									
									
								
							| @@ -7,7 +7,7 @@ | ||||
| README | ||||
|  | ||||
|   Curl is a command line tool for transferring data specified with URL | ||||
|   syntax. Find out how to use Curl by reading the curl.1 man page or the | ||||
|   syntax. Find out how to use curl by reading the curl.1 man page or the | ||||
|   MANUAL document. Find out how to install Curl by reading the INSTALL | ||||
|   document. | ||||
|  | ||||
| @@ -32,31 +32,8 @@ WEB SITE | ||||
|  | ||||
|   Visit the curl web site or mirrors for the latest news and downloads: | ||||
|  | ||||
|         Sweden    -- http://curl.haxx.se/ | ||||
|         Australia -- http://curl.planetmirror.com/ | ||||
|         Austria   -- http://curl.gds.tuwien.ac.at/ | ||||
|         Canada    -- http://curl.meulie.net/ | ||||
|         Denmark   -- http://curl.cofman.dk/ | ||||
|         Estonia   -- http://curl.wildyou.net/ | ||||
|         France    -- http://curl.mirror.internet.tp/ | ||||
|         Germany   -- http://curl.miscellaneousmirror.org/ | ||||
|         Germany   -- http://curl.mirror.at.stealer.net/ | ||||
|         Germany   -- http://curl.mirroring.de/ | ||||
|         Germany   -- http://curl.mons-new-media.de/ | ||||
|         Germany   -- http://curl.netmirror.org/ | ||||
|         Russia    -- http://curl.tsuren.net/ | ||||
|         Taiwan    -- http://curl.cs.pu.edu.tw/ | ||||
|         Thailand  -- http://curl.siamu.ac.th/ | ||||
|         US (AZ)   -- http://curl.islandofpoker.com/ | ||||
|         US (CA)   -- http://curl.mirror.redwire.net/ | ||||
|         US (CA)   -- http://curl.mirrormonster.com/ | ||||
|         US (CA)   -- http://curl.signal42.com/ | ||||
|         US (CA)   -- http://curl.tolix.org/ | ||||
|         US (CA)   -- http://curl.webhosting76.com/ | ||||
|         US (TX)   -- http://curl.109k.com/ | ||||
|         US (TX)   -- http://curl.mirrors.cyberservers.net/ | ||||
|         US (TX)   -- http://curl.seekmeup.com/ | ||||
|         US (TX)   -- http://curl.hostingzero.com/ | ||||
|         Sweden       http://curl.haxx.se/ | ||||
|         Mirrors      http://curlm.haxx.se/ | ||||
|  | ||||
| CVS | ||||
|  | ||||
|   | ||||
							
								
								
									
										102
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							
							
						
						
									
										102
									
								
								RELEASE-NOTES
									
									
									
									
									
								
							| @@ -1,46 +1,86 @@ | ||||
| Curl and libcurl 7.15.0 | ||||
| Curl and libcurl 7.16.1 | ||||
|  | ||||
|  Public curl release number:               90 | ||||
|  Releases counted from the very beginning: 117 | ||||
|  Available command line options:           109 | ||||
|  Available curl_easy_setopt() options:     124 | ||||
|  Number of public functions in libcurl:    46 | ||||
|  Amount of public web site mirrors:        24 | ||||
|  Number of known libcurl bindings:         32 | ||||
|  Number of contributors:                   451 | ||||
|  Public curl release number:               97 | ||||
|  Releases counted from the very beginning: 124 | ||||
|  Available command line options:           115 | ||||
|  Available curl_easy_setopt() options:     137 | ||||
|  Number of public functions in libcurl:    54 | ||||
|  Amount of public web site mirrors:        39 | ||||
|  Number of known libcurl bindings:         35 | ||||
|  Number of contributors:                   539 | ||||
|  | ||||
| This release includes the following changes: | ||||
|   | ||||
|  o --ftp-skip-pasv-ip / CURLOPT_FTP_SKIP_PASV_IP (sponsored by CU*Answers) | ||||
|  o TFTP support added | ||||
|  o Support for SCP and SFTP were added (powered by libssh2) | ||||
|  o CURLOPT_CLOSEPOLICY is now deprecated | ||||
|  o --ftp-ssl-ccc and CURLOPT_FTP_SSL_CCC were added | ||||
|  o HTTP support for non-ASCII platforms | ||||
|  o --libcurl was added | ||||
|  | ||||
| This release includes the following bugfixes: | ||||
|  | ||||
|  o user+domain name buffer overflow in the NTLM code (security flaw) | ||||
|  o -z over FTP now considers equal timestamps "not modified since" | ||||
|  o Weird characters removed from the configure script | ||||
|  o Fixed time zone offsets for MEST and CEST for the time parser | ||||
|  o HTTP Content-Range header parser crash | ||||
|  o FTPS negotiation timeouts/errors | ||||
|  o SSPI works even for Windows 9x | ||||
|  o crash in --dump-header on FTP | ||||
|  o test 56 runs better | ||||
|  o proxy close during CONNECT authentication is now dealt with nicely | ||||
|  o the CURLOPT_DEBUGFUNCTION was sometimes called even when CURLOPT_VERBOSE | ||||
|    was not enabled | ||||
|  o multiple TFTP transfers on the same (easy or multi) handle could cause a | ||||
|    crash | ||||
|  o SIGSEGV when disconnecting on a transfer on a re-used handle when the | ||||
|    host name didn't resolve | ||||
|  o stack overwrite on 64bit Windows in the chunked decoding department | ||||
|  o HTTP responses on persistent connections without Content-Length nor chunked | ||||
|    encoding are now considered to be without response body | ||||
|  o Content-Range: header parsing improved | ||||
|  o CPU 100% load when HTTP upload connection broke | ||||
|  o active FTP didn't work with multi interface | ||||
|  o curl_getdate() could be off one hour for TZ time zones with DST, on windows | ||||
|  o CURLOPT_FORBID_REUSE works again | ||||
|  o CURLOPT_MAXCONNECTS set to zero caused libcurl to SIGSEGV | ||||
|  o rate limiting works better | ||||
|  o getting FTP response code errors when using the multi-interface caused | ||||
|    libcurl to leak memory | ||||
|  o no more SIGPIPE when GnuTLS is used | ||||
|  o FTP downloading 2 zero byte files in a row | ||||
|  o using proxy and URLs without protocol prefixes | ||||
|  o first using a proxy and then accessing a site that 'no_proxy' matched, | ||||
|    would still make libcurl use the proxy... | ||||
|  o curl_easy_duphandle() now makes a handle that is valid for the multi | ||||
|    interface since the magic number is set fine | ||||
|  o libcurl.pc now uses Libs.private for "private" libs | ||||
|  o --limit-rate (CURLOPT_MAX_SEND_SPEED_LARGE and CURLOPT_MAX_RECV_SPEED_LARGE) | ||||
|    now work on windows again | ||||
|  o improved download performance by avoiding the unconditional "double copying" | ||||
|  o base64 encoding/decoding works on non-ASCII platforms | ||||
|  o large file downloads | ||||
|  o CURLOPT_COOKIELIST set to "ALL" crash | ||||
|  o easy handle removal from multi handle before completion | ||||
|  o TFTP upload memory leak | ||||
|  o curl_easy_reset() now resets the CA bundle path correctly | ||||
|  o two User-Agent headers in CONNECT requests with custom User-Agent | ||||
|  | ||||
| Other curl-related news since the previous public release: | ||||
| This release includes the following known bugs: | ||||
|  | ||||
|  o http://curl.freemirror.de/ is a new German mirror | ||||
|  o All curl relatd mailing list information and subscribers on cool.haxx.se | ||||
|    were lost due to a malicious user exploiting a security hole on the | ||||
|    server. Attempts have been made to put back susbcribers on the lists, but | ||||
|    many have been lost: http://curl.haxx.se/mail/lost.html | ||||
|  o New S-Lang binding: http://curl.haxx.se/libcurl/slang/ | ||||
|  o TclCurl 0.14.1: http://personal1.iddeo.es/andresgarci/tclcurl/english/ | ||||
|  o pycurl 7.14.1: http://pycurl.sf.net/ | ||||
|  o see docs/KNOWN_BUGS (http://curl.haxx.se/docs/knownbugs.html) | ||||
|  | ||||
| Other curl-related news: | ||||
|  | ||||
|  o TclCurl 7.16.0 was released: | ||||
|    http://personal1.iddeo.es/andresgarci/tclcurl/english/ | ||||
|  o Curb - Libcurl bindings for Ruby: http://curb.rubyforge.org/ | ||||
|  | ||||
| New curl mirrors: | ||||
|  | ||||
|  o curl.miroir-francais.fr is a new French web mirror | ||||
|  o curl.dsmirror.nl is a new Dutch web mirror | ||||
|  | ||||
| This release would not have looked like this without help, code, reports and | ||||
| advice from friends like these: | ||||
|  | ||||
|  o John Kelly, Nicolas Fran<61>ois, Scott Davis, Ben Madsen, Dmitry Bartsevich, | ||||
|    David Yan, Michael Wallner, Domenico Andreoli, Darryl House | ||||
|  James Housley, Olaf Stueben, Yang Tse, Gisle Vanem, Bradford Bruce, | ||||
|  Ciprian Badescu, Dmitriy Sergeyev, Nir Soffer, Venkat Akella, Toon Verwaest, | ||||
|  Matt Witherspoon, Alexey Simak, Martin Skinner, Sh Diao, Jared Lundell, | ||||
|  Stefan Krause, Sebastien Willemijns, Alexey Simak, Brendan Jurd, | ||||
|  Robson Braga Araujo, David McCreedy, Robert Foreman, Nathanael Nerode, | ||||
|  Victor Snezhko, Linus Nielsen Feltzing, Toby Peterson, Dan Fandrich,  | ||||
|  Armel Asselin, Michael Wallner, Guenter Knauf | ||||
|  | ||||
|         Thanks! (and sorry if I forgot to mention someone) | ||||
|   | ||||
| @@ -1,7 +1,4 @@ | ||||
| To get fixed in 7.15.0 (planned release: November 2005) | ||||
| To get fixed in 7.16.1 (planned release: January 2007) | ||||
| ====================== | ||||
|  | ||||
| 60 - CONNECT 407 responses that kills the connection (not very likely though) | ||||
|  | ||||
| 63 -  | ||||
|  | ||||
| 82 -  | ||||
|   | ||||
							
								
								
									
										1410
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										1410
									
								
								acinclude.m4
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -11,3 +11,12 @@ Dan Fandrich | ||||
| Gisle Vanem | ||||
| Gunter Knauf | ||||
| Henrik Stoerner | ||||
| Yang Tse | ||||
| Nick Mathewson | ||||
| Alexander Lazic | ||||
| Andreas Rieke | ||||
| Guilherme Balena Versiani | ||||
| Brad Spencer | ||||
| Ravi Pratap | ||||
| William Ahern | ||||
| Bram Matthys | ||||
|   | ||||
							
								
								
									
										111
									
								
								ares/CHANGES
									
									
									
									
									
								
							
							
						
						
									
										111
									
								
								ares/CHANGES
									
									
									
									
									
								
							| @@ -1,18 +1,123 @@ | ||||
|   Changelog for the c-ares project | ||||
|  | ||||
| * November 22 | ||||
|  | ||||
| - 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 | ||||
|  | ||||
| - 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. | ||||
|  | ||||
| * September 11 2006 | ||||
|  | ||||
| - Guilherme Balena Versiani: I noted a strange BUG in Win32 port | ||||
|   (ares_init.c/get_iphlpapi_dns_info() function): when I disable the network | ||||
|   by hand or disconnect the network cable in Windows 2000 or Windows XP, my | ||||
|   application gets 127.0.0.1 as the only name server. The problem comes from | ||||
|   'GetNetworkParams' function, that returns the empty string "" as the only | ||||
|   name server in that case. Moreover, the Windows implementation of | ||||
|   inet_addr() returns INADDR_LOOPBACK instead of INADDR_NONE. | ||||
|  | ||||
| * August 29 2006 | ||||
|  | ||||
| - Brad Spencer did | ||||
|  | ||||
|   o made ares_version.h use extern "C" for c++ compilers | ||||
|   o fixed compiler warnings in ares_getnameinfo.c | ||||
|   o fixed a buffer position init for TCP reads | ||||
|  | ||||
| * August 3 2006 | ||||
|  | ||||
| - Ravi Pratap fixed ares_getsock() to actually return the proper bitmap and | ||||
|   not always zero! | ||||
|  | ||||
| Version 1.3.1 (June 24, 2006) | ||||
|  | ||||
| * July 23, 2006 | ||||
|  | ||||
| - Gisle Vanem added getopt() to the ahost program. Currently accepts | ||||
|   only [-t {a|aaaa}] to specify address family in ares_gethostbyname(). | ||||
|  | ||||
| * June 19, 2006 | ||||
|  | ||||
| - (wahern) Removed "big endian" DNS section and RR data integer parser | ||||
|   macros from ares_dns.h, which break c-ares on my Sparc64. Bit-wise | ||||
|   operations in C operate on logical values. And in any event the octets are | ||||
|   already in big-endian (aka network) byte order so they're being reversed | ||||
|   (thus the source of the breakage). | ||||
|  | ||||
| * June 18, 2006 | ||||
|  | ||||
| - William Ahern handles EAGAIN/EWOULDBLOCK errors in most of the I/O calls | ||||
|   from area_process.c. | ||||
|  | ||||
|   TODO: Handle one last EAGAIN for a UDP socket send(2) in | ||||
|   ares__send_query(). | ||||
|  | ||||
| * May 10, 2006 | ||||
|  | ||||
| - Bram Matthys brought my attention to a libtool peculiarity where detecting | ||||
|   things such as C++ compiler actually is a bad thing and since we don't need | ||||
|   that detection I added a work-around, much inspired by a previous patch by | ||||
|   Paolo Bonzini. This also shortens the configure script quite a lot. | ||||
|  | ||||
| * May 3, 2006 | ||||
|  | ||||
| - Nick Mathewson added the ARES_OPT_SOCK_STATE_CB option that when set makes | ||||
|   c-ares call a callback on socket state changes. A better way than the | ||||
|   ares_getsock() to get full control over the socket state. | ||||
|  | ||||
| * January 9, 2006 | ||||
|  | ||||
| - Alexander Lazic improved the getservbyport_r() configure check. | ||||
|  | ||||
| * January 6, 2006 | ||||
|  | ||||
| - Alexander Lazic pointed out that the buildconf should use the ACLOCAL_FLAGS | ||||
|   variable for easier controlling what it does and how it runs. | ||||
|  | ||||
| * January 5, 2006 | ||||
|  | ||||
| - James Bursa fixed c-ares to find the hosts file on RISC OS, and made it | ||||
|   build with newer gcc versions that no longer defines "riscos". | ||||
|  | ||||
| * December 22 | ||||
|  | ||||
| - Daniel Stenberg added ares_getsock() that extracts the set of sockets to | ||||
|   wait for action on. Similar to ares_fds() but not restricted to using | ||||
|   select() for the waiting. | ||||
|  | ||||
| * November 25 | ||||
|  | ||||
| - Yang Tse fixed some send() / recv() compiler warnings | ||||
|  | ||||
| * September 18 | ||||
|  | ||||
| - Added constants that will be used by ares_getaddrinfo | ||||
|  | ||||
| - Made ares_getnameinfo use the reentrant getservbyport (getservbyport_r) if it is | ||||
|   available to ensure it works properly in a threaded environment. | ||||
| - Made ares_getnameinfo use the reentrant getservbyport (getservbyport_r) if it | ||||
|   is available to ensure it works properly in a threaded environment. | ||||
|  | ||||
| * September 10 | ||||
|  | ||||
| - configure fix for detecting a member in the sockaddr_in6 struct which failed | ||||
|   on ipv6-enabled HP-UX 11.00 | ||||
|  | ||||
| Version 1.3.0 (August 29, 2004) | ||||
| Version 1.3.0 (August 29, 2005) | ||||
|  | ||||
| * August 21 | ||||
|  | ||||
|   | ||||
| @@ -13,6 +13,7 @@ Makefile.in | ||||
| Makefile.dj | ||||
| Makefile.m32 | ||||
| Makefile.netware | ||||
| Makefile.vc6 | ||||
| install-sh | ||||
| mkinstalldirs | ||||
| configure | ||||
|   | ||||
| @@ -4,15 +4,14 @@ lib_LTLIBRARIES = libcares.la | ||||
|  | ||||
| man_MANS = $(MANPAGES) | ||||
|  | ||||
| MSVCFILES = vc/adig/adig.dep vc/adig/adig.dsp vc/adig/adig.mak	\ | ||||
|  vc/adig/adig.plg vc/vc.dsw vc/ahost/ahost.dep vc/ahost/ahost.dsp	\ | ||||
|  vc/ahost/ahost.mak vc/ahost/ahost.plg vc/areslib/areslib.dep		\ | ||||
|  vc/areslib/areslib.dsp vc/areslib/areslib.mak vc/areslib/areslib.plg | ||||
| MSVCFILES = vc/adig/adig.dep vc/adig/adig.dsp vc/vc.dsw vc/ahost/ahost.dep \ | ||||
|  vc/ahost/ahost.dsp vc/areslib/areslib.dep vc/areslib/areslib.dsp	   \ | ||||
|  vc/areslib/areslib.dsw | ||||
|  | ||||
| # 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 | ||||
|  $(MSVCFILES) AUTHORS config-win32.h | ||||
|  | ||||
|  | ||||
| VER=-version-info 1:0:0 | ||||
| @@ -44,7 +43,13 @@ VER=-version-info 1:0:0 | ||||
| # set age to 0. (c:r:a=0) | ||||
| # | ||||
|  | ||||
| libcares_la_LDFLAGS = $(VER) | ||||
| if NO_UNDEFINED | ||||
| # The -no-undefined flag is crucial for this to build fine on some platforms | ||||
| UNDEF = -no-undefined | ||||
| endif | ||||
|  | ||||
|  | ||||
| libcares_la_LDFLAGS = $(UNDEF) $(VER) | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
| @@ -54,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: | ||||
|   | ||||
							
								
								
									
										179
									
								
								ares/Makefile.dj
									
									
									
									
									
								
							
							
						
						
									
										179
									
								
								ares/Makefile.dj
									
									
									
									
									
								
							| @@ -2,27 +2,50 @@ | ||||
| # c-ares Makefile for djgpp/gcc/Watt-32. | ||||
| #   By Gisle Vanem <giva@bgnett.no> 2004. | ||||
| # | ||||
| .SUFFIXES: .exe | ||||
| # $Id$ | ||||
|  | ||||
| include ../packages/DOS/common.dj | ||||
|  | ||||
| include Makefile.inc | ||||
|  | ||||
| WATT32_ROOT = $(subst \,/,$(WATT_ROOT)) | ||||
| 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_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'   -UHAVE_CONFIG_H -Dselect=select_s | ||||
|  | ||||
| CC      = gcc | ||||
| CFLAGS  = -O2 -Wall -DWATT32 -Dselect=select_s -I$(WATT32_ROOT)/inc | ||||
| LDFLAGS = -s | ||||
| EX_LIBS = $(WATT32_ROOT)/lib/libwatt.a | ||||
|  | ||||
| OBJ_DIR = djgpp | ||||
| ifeq ($(USE_DEBUG),1) | ||||
|   EX_LIBS = ../lib/libcurl.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 | ||||
|   CFLAGS  += -DUSE_MANUAL | ||||
| 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 $@ $? | ||||
|  | ||||
| @@ -39,12 +62,132 @@ 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 | ||||
| # DO NOT DELETE THIS LINE | ||||
| $(OBJ_DIR)/ares_fds.o: ares_fds.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_getsock.o: ares_getsock.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_process.o: ares_process.c setup.h setup_once.h ares.h ares_dns.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_free_hostent.o: ares_free_hostent.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_query.o: ares_query.c setup.h setup_once.h ares.h ares_dns.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares__close_sockets.o: ares__close_sockets.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_free_string.o: ares_free_string.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_search.o: ares_search.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares__get_hostent.o: ares__get_hostent.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h | ||||
| $(OBJ_DIR)/ares_gethostbyaddr.o: ares_gethostbyaddr.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h | ||||
| $(OBJ_DIR)/ares_send.o: ares_send.c setup.h setup_once.h ares.h ares_dns.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares__read_line.o: ares__read_line.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_gethostbyname.o: ares_gethostbyname.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h \ | ||||
|   bitncmp.h | ||||
| $(OBJ_DIR)/ares_strerror.o: ares_strerror.c setup.h setup_once.h ares.h | ||||
| $(OBJ_DIR)/ares_cancel.o: ares_cancel.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_init.o: ares_init.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h inet_net_pton.h | ||||
| $(OBJ_DIR)/ares_timeout.o: ares_timeout.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_destroy.o: ares_destroy.c setup.h setup_once.h ares.h ares_private.h \ | ||||
|   ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_mkquery.o: ares_mkquery.c setup.h setup_once.h ares.h ares_dns.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_version.o: ares_version.c setup.h setup_once.h ares_version.h | ||||
| $(OBJ_DIR)/ares_expand_name.o: ares_expand_name.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_parse_a_reply.o: ares_parse_a_reply.c setup.h setup_once.h ares.h \ | ||||
|   ares_dns.h ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/windows_port.o: windows_port.c setup.h setup_once.h | ||||
| $(OBJ_DIR)/ares_expand_string.o: ares_expand_string.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_parse_ptr_reply.o: ares_parse_ptr_reply.c setup.h setup_once.h \ | ||||
|   ares.h ares_dns.h ares_private.h ares_ipv6.h ../lib/memdebug.h \ | ||||
|   ../lib/setup.h ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_parse_aaaa_reply.o: ares_parse_aaaa_reply.c setup.h setup_once.h \ | ||||
|   ares.h ares_dns.h inet_net_pton.h ares_private.h ares_ipv6.h \ | ||||
|   ../lib/memdebug.h ../lib/setup.h ../include/curl/stdcheaders.h \ | ||||
|   ../include/curl/curl.h ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h | ||||
| $(OBJ_DIR)/ares_getnameinfo.o: ares_getnameinfo.c setup.h setup_once.h ares.h \ | ||||
|   ares_private.h ares_ipv6.h ../lib/memdebug.h ../lib/setup.h \ | ||||
|   ../include/curl/stdcheaders.h ../include/curl/curl.h \ | ||||
|   ../include/curl/curlver.h ../include/curl/easy.h \ | ||||
|   ../include/curl/multi.h ../include/curl/curl.h inet_ntop.h | ||||
| $(OBJ_DIR)/inet_net_pton.o: inet_net_pton.c setup.h setup_once.h ares_ipv6.h \ | ||||
|   inet_net_pton.h | ||||
| $(OBJ_DIR)/bitncmp.o: bitncmp.c bitncmp.h | ||||
| $(OBJ_DIR)/inet_ntop.o: inet_ntop.c setup.h setup_once.h ares_ipv6.h inet_ntop.h | ||||
|   | ||||
| @@ -1,18 +1,21 @@ | ||||
| CSOURCES = ares_fds.c ares_process.c ares_free_hostent.c ares_query.c       \ | ||||
| ares__close_sockets.c ares_free_string.c ares_search.c ares__get_hostent.c  \ | ||||
| ares_gethostbyaddr.c ares_send.c ares__read_line.c 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 | ||||
| CSOURCES = ares_fds.c ares_getsock.c ares_process.c ares_free_hostent.c	\ | ||||
| ares_query.c ares__close_sockets.c ares_free_string.c ares_search.c	\ | ||||
| ares__get_hostent.c ares_gethostbyaddr.c ares_send.c ares__read_line.c	\ | ||||
| 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 | ||||
|  | ||||
| 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 | ||||
|            nameser.h inet_net_pton.h inet_ntop.h ares_ipv6.h bitncmp.h      \ | ||||
|            setup_once.h  | ||||
|  | ||||
| MANPAGES= ares_destroy.3 ares_expand_name.3 ares_expand_string.3 ares_fds.3 \ | ||||
|  ares_free_hostent.3 ares_free_string.3 ares_gethostbyaddr.3                \ | ||||
|  ares_gethostbyname.3 ares_init.3 ares_init_options.3 ares_mkquery.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_version.3 ares_cancel.3 ares_parse_aaaa_reply.3 ares_getnameinfo.3    \ | ||||
|  ares_getsock.3 | ||||
|  | ||||
|   | ||||
| @@ -7,29 +7,21 @@ | ||||
| ## Quick hack by Guenter; comments to: /dev/nul | ||||
|  | ||||
| CC = gcc | ||||
| AR = ar | ||||
| RANLIB = ranlib | ||||
| STRIP = strip -g | ||||
| #RM = rm -f  | ||||
|  | ||||
| ######################################################## | ||||
| ## Nothing more to do below this line! | ||||
|  | ||||
| LIB=libcares.a | ||||
| CC=gcc | ||||
| #CPPFLAGS=@CPPFLAGS@ | ||||
| WARN_FLAGS=-Wall | ||||
| CFLAGS=-O2 | ||||
| CFLAGS+=${WARN_CFLAGS} ${ERROR_CFLAGS} | ||||
| DEFS=-DMINGW32 | ||||
| CFLAGS=-O2 -Wall | ||||
| LDFLAGS=-s | ||||
| LIBS=-lwsock32 | ||||
| ALL_CFLAGS=${CPPFLAGS} ${CFLAGS} ${DEFS} | ||||
|  | ||||
| MANPAGES := $(patsubst %.c,%.o,$(wildcard ares_*.3)) | ||||
|  | ||||
| OBJS	:= $(patsubst %.c,%.o,$(wildcard ares_*.c)) | ||||
| OBJS	+= windows_port.o | ||||
| OBJS	+= windows_port.o inet_ntop.o inet_net_pton.o bitncmp.o | ||||
|  | ||||
| $(LIB): ${OBJS} | ||||
| 	ar cru $@ ${OBJS} | ||||
| @@ -51,7 +43,7 @@ ahost.exe: ahost.o $(LIB) | ||||
| ${OBJS}: ares.h ares_dns.h ares_private.h | ||||
|  | ||||
| .c.o: | ||||
| 	${CC} -c ${ALL_CFLAGS} $< | ||||
| 	${CC} -c ${CFLAGS} $< | ||||
|  | ||||
| check: | ||||
|  | ||||
| @@ -73,3 +65,4 @@ clean: | ||||
|  | ||||
| distclean: clean | ||||
| 	rm -f config.cache config.log config.status Makefile | ||||
|  | ||||
|   | ||||
| @@ -20,7 +20,7 @@ endif | ||||
| TARGETS = adig.nlm ahost.nlm | ||||
| LTARGET = libcares.lib | ||||
| VERSION	= $(LIBCARES_VERSION) | ||||
| COPYR	= Copyright (C) 1996 - 2005, 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 | ||||
| @@ -88,7 +88,7 @@ LD	= nlmconv | ||||
| LDFLAGS	= -T | ||||
| AR	= ar | ||||
| ARFLAGS	= -cq | ||||
| CFLAGS	+= -fno-builtin -fpack-struct -fpcc-struct-return -fno-strict-aliasing | ||||
| CFLAGS	+= -fno-builtin -fpcc-struct-return -fno-strict-aliasing | ||||
| CFLAGS	+= -Wall -Wno-format -Wno-uninitialized # -pedantic | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| 	PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o | ||||
| @@ -256,8 +256,8 @@ config.h: Makefile.netware | ||||
| 	@echo $(DL)** All your changes will be lost!!$(DL) >> $@ | ||||
| 	@echo $(DL)*/$(DL) >> $@ | ||||
| 	@echo $(DL)#define OS "i586-pc-NetWare"$(DL) >> $@ | ||||
| 	@echo $(DL)#define VERSION "$(LIBCURL_VERSION_STR)"$(DL) >> $@ | ||||
| 	@echo $(DL)#define PACKAGE_BUGREPORT "curl-bug@haxx.se"$(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) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ARPA_INET_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ARPA_NAMESER_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_ASSERT_H 1$(DL) >> $@ | ||||
| @@ -276,9 +276,13 @@ config.h: Makefile.netware | ||||
| 	@echo $(DL)#define HAVE_LONGLONG 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_MALLOC_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_NETINET_IN_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_RECV 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_SELECT 1$(DL) >> $@ | ||||
| 	@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) >> $@ | ||||
| @@ -297,15 +301,27 @@ config.h: Makefile.netware | ||||
| 	@echo $(DL)#define HAVE_TIME_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_UNAME 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_UNISTD_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define RECV_TYPE_ARG1 int$(DL) >> $@ | ||||
| 	@echo $(DL)#define RECV_TYPE_ARG2 char *$(DL) >> $@ | ||||
| 	@echo $(DL)#define RECV_TYPE_ARG3 int$(DL) >> $@ | ||||
| 	@echo $(DL)#define RECV_TYPE_ARG4 int$(DL) >> $@ | ||||
| 	@echo $(DL)#define RECV_TYPE_RETV int$(DL) >> $@ | ||||
| 	@echo $(DL)#define RETSIGTYPE void$(DL) >> $@ | ||||
| 	@echo $(DL)#define SEND_QUAL_ARG2$(DL) >> $@ | ||||
| 	@echo $(DL)#define SEND_TYPE_ARG1 int$(DL) >> $@ | ||||
| 	@echo $(DL)#define SEND_TYPE_ARG2 char *$(DL) >> $@ | ||||
| 	@echo $(DL)#define SEND_TYPE_ARG3 int$(DL) >> $@ | ||||
| 	@echo $(DL)#define SEND_TYPE_ARG4 int$(DL) >> $@ | ||||
| 	@echo $(DL)#define SEND_TYPE_RETV int$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_CURL_OFF_T 4$(DL) >> $@ | ||||
| 	@echo $(DL)#define STDC_HEADERS 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_TIMEVAL 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | ||||
| ifdef NW_WINSOCK | ||||
|   | ||||
							
								
								
									
										197
									
								
								ares/Makefile.vc6
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										197
									
								
								ares/Makefile.vc6
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,197 @@ | ||||
| # $Id$ | ||||
| # | ||||
| # C-ares makefile for MSVC6+ | ||||
| # G. Vanem <giva@bgnett.no>. | ||||
| # | ||||
|  | ||||
| CFG_MODEL   = MD | ||||
| DEBUG_MODEL = d | ||||
| USE_WATT32  = 0 | ||||
|  | ||||
| # | ||||
| # Configurations: | ||||
| #  -MD   - msvcrt.dll,  threads, release (normal) | ||||
| #  -MDd  - msvcrtd.dll, threads, debug | ||||
| #  -ML   - libc, no threads,     release | ||||
| #  -MLd  - libc, no threads,     debug | ||||
| #  -MT   - libc, threads,        release | ||||
| #  -MTd  - libc, threads,        debug | ||||
|  | ||||
| CC = cl | ||||
|  | ||||
| CFLAGS  = -nologo -$(CFG_MODEL)$(DEBUG_MODEL) -W3 -Yd -Zi | ||||
| LDFLAGS = -machine:i386 -map | ||||
|  | ||||
| OBJ_DIR  = VC6_obj | ||||
| DEF_FILE = cares.def | ||||
|  | ||||
| !if "$(USE_WATT32)" == "1" | ||||
| CFLAGS  = $(CFLAGS) -UWIN32 -DWATT32 -I$(WATT_ROOT)\inc | ||||
| EX_LIBS = $(WATT_ROOT)\lib\wattcpvc_imp.lib | ||||
|  | ||||
| !else | ||||
| CFLAGS  = $(CFLAGS) -DWIN32 -DWIN32_LEAN_AND_MEAN | ||||
| EX_LIBS = advapi32.lib ws2_32.lib | ||||
| !endif | ||||
|  | ||||
| !if "$(DEBUG_MODEL)" == "d" | ||||
| CFLAGS  = $(CFLAGS) -D_DEBUG -GZ | ||||
| LDFLAGS = $(LDFLAGS) -debug -fixed:no | ||||
|  | ||||
| !else | ||||
| CFLAGS  = $(CFLAGS) -O2 -Og | ||||
| LDFLAGS = $(LDFLAGS) -release | ||||
| !endif | ||||
|  | ||||
| OBJECTS = $(OBJ_DIR)\ares_fds.obj              \ | ||||
|           $(OBJ_DIR)\ares_process.obj          \ | ||||
|           $(OBJ_DIR)\ares_free_hostent.obj     \ | ||||
|           $(OBJ_DIR)\ares_query.obj            \ | ||||
|           $(OBJ_DIR)\ares__close_sockets.obj   \ | ||||
|           $(OBJ_DIR)\ares_free_string.obj      \ | ||||
|           $(OBJ_DIR)\ares_search.obj           \ | ||||
|           $(OBJ_DIR)\ares__get_hostent.obj     \ | ||||
|           $(OBJ_DIR)\ares_gethostbyaddr.obj    \ | ||||
|           $(OBJ_DIR)\ares_getsock.obj          \ | ||||
|           $(OBJ_DIR)\ares_send.obj             \ | ||||
|           $(OBJ_DIR)\ares__read_line.obj       \ | ||||
|           $(OBJ_DIR)\ares_gethostbyname.obj    \ | ||||
|           $(OBJ_DIR)\ares_getnameinfo.obj      \ | ||||
|           $(OBJ_DIR)\ares_strerror.obj         \ | ||||
|           $(OBJ_DIR)\ares_cancel.obj           \ | ||||
|           $(OBJ_DIR)\ares_init.obj             \ | ||||
|           $(OBJ_DIR)\ares_timeout.obj          \ | ||||
|           $(OBJ_DIR)\ares_destroy.obj          \ | ||||
|           $(OBJ_DIR)\ares_mkquery.obj          \ | ||||
|           $(OBJ_DIR)\ares_version.obj          \ | ||||
|           $(OBJ_DIR)\ares_expand_name.obj      \ | ||||
|           $(OBJ_DIR)\ares_parse_a_reply.obj    \ | ||||
|           $(OBJ_DIR)\ares_parse_aaaa_reply.obj \ | ||||
|           $(OBJ_DIR)\windows_port.obj          \ | ||||
|           $(OBJ_DIR)\ares_expand_string.obj    \ | ||||
|           $(OBJ_DIR)\ares_parse_ptr_reply.obj  \ | ||||
|           $(OBJ_DIR)\bitncmp.obj               \ | ||||
|           $(OBJ_DIR)\inet_net_pton.obj         \ | ||||
|           $(OBJ_DIR)\inet_ntop.obj | ||||
|  | ||||
| all: $(OBJ_DIR) cares.lib cares.dll cares_imp.lib ahost.exe adig.exe | ||||
|  | ||||
| $(OBJ_DIR): | ||||
|        mkdir $(OBJ_DIR) | ||||
|  | ||||
| cares.lib: $(OBJ_DIR) $(OBJECTS) | ||||
|        lib -nologo -out:$@ $(OBJECTS) | ||||
|  | ||||
| cares_imp.lib cares.dll: $(OBJ_DIR) $(DEF_FILE) $(OBJECTS) | ||||
|        link $(LDFLAGS) -dll -implib:cares_imp.lib -out:cares.dll \ | ||||
|             -def:$(DEF_FILE) $(OBJECTS) $(EX_LIBS) | ||||
|  | ||||
| $(DEF_FILE): $(OBJECTS) Makefile.VC6 | ||||
|        @echo ; Generated. DO NOT EDIT  > $@ | ||||
|        @echo LIBRARY cares.dll        >> $@ | ||||
|        @echo EXPORTS                  >> $@ | ||||
|        @echo   ares_cancel            >> $@ | ||||
|        @echo   ares_destroy           >> $@ | ||||
|        @echo   ares_expand_name       >> $@ | ||||
|        @echo   ares_expand_string     >> $@ | ||||
|        @echo   ares_fds               >> $@ | ||||
|        @echo   ares_free_hostent      >> $@ | ||||
|        @echo   ares_free_string       >> $@ | ||||
|        @echo   ares_gethostbyaddr     >> $@ | ||||
|        @echo   ares_gethostbyname     >> $@ | ||||
|        @echo   ares_getsock           >> $@ | ||||
|        @echo   ares_init              >> $@ | ||||
|        @echo   ares_init_options      >> $@ | ||||
|        @echo   ares_mkquery           >> $@ | ||||
|        @echo   ares_parse_a_reply     >> $@ | ||||
|        @echo   ares_parse_ptr_reply   >> $@ | ||||
|        @echo   ares_process           >> $@ | ||||
|        @echo   ares_query             >> $@ | ||||
|        @echo   ares_search            >> $@ | ||||
|        @echo   ares_strerror          >> $@ | ||||
|        @echo   ares_strncasecmp       >> $@ | ||||
|        @echo   ares_strcasecmp        >> $@ | ||||
|        @echo   ares_timeout           >> $@ | ||||
|        @echo   ares_version           >> $@ | ||||
|        @echo   ares_inet_net_pton     >> $@ | ||||
|        @echo   ares_inet_ntop         >> $@ | ||||
|        @echo   ares_inet_pton         >> $@ | ||||
|        @echo   ares_writev            >> $@ | ||||
|        @echo   ares_getnameinfo       >> $@ | ||||
|        @echo   ares_gettimeofday      >> $@ | ||||
|        @echo   ares_parse_aaaa_reply  >> $@ | ||||
|  | ||||
| ahost.exe: $(OBJ_DIR) $(OBJ_DIR)\ahost.obj $(OBJ_DIR)\getopt.obj cares_imp.lib | ||||
|        link $(LDFLAGS) -out:$@ $(OBJ_DIR)\ahost.obj $(OBJ_DIR)\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) | ||||
|  | ||||
| clean: | ||||
|        - del $(OBJ_DIR)\*.obj *.ilk *.pdb *.pbt *.pbi *.pbo *._xe *.map | ||||
|  | ||||
| vclean realclean: clean | ||||
|        - del $(DEF_FILE) cares.lib cares_imp.* cares.dll ahost.exe adig.exe | ||||
|        - rd $(OBJ_DIR) | ||||
|  | ||||
| .c{$(OBJ_DIR)}.obj: | ||||
|        $(CC) $(CFLAGS) -Fo$*.obj -c $< | ||||
|  | ||||
| # | ||||
| # Copyright "gcc -MM .." | ||||
| # | ||||
| $(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_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 | ||||
							
								
								
									
										1248
									
								
								ares/acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										1248
									
								
								ares/acinclude.m4
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										89
									
								
								ares/adig.c
									
									
									
									
									
								
							
							
						
						
									
										89
									
								
								ares/adig.c
									
									
									
									
									
								
							| @@ -1,4 +1,6 @@ | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|  * software and its documentation for any purpose and without | ||||
| @@ -16,7 +18,7 @@ | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| #include <sys/time.h> | ||||
| @@ -27,14 +29,23 @@ | ||||
| #include <unistd.h> | ||||
| #include <netdb.h> | ||||
| #endif | ||||
| #ifdef HAVE_GETOPT_H | ||||
| #include <getopt.h> | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_dns.h" | ||||
| #include "inet_ntop.h" | ||||
|  | ||||
| #ifdef WATT32 | ||||
| #undef WIN32  /* Redefined in MingW headers */ | ||||
| #endif | ||||
|  | ||||
| #ifndef INADDR_NONE | ||||
| #define INADDR_NONE 0xffffffff | ||||
| @@ -45,8 +56,10 @@ | ||||
| #define T_SRV 33 /* server selection */ | ||||
| #endif | ||||
|  | ||||
| #ifndef optind | ||||
| extern int optind; | ||||
| extern char *optarg; | ||||
| #endif | ||||
|  | ||||
| struct nv { | ||||
|   const char *name; | ||||
| @@ -142,8 +155,8 @@ int main(int argc, char **argv) | ||||
|   fd_set read_fds, write_fds; | ||||
|   struct timeval *tvp, tv; | ||||
|  | ||||
| #ifdef WIN32 | ||||
|   WORD wVersionRequested = MAKEWORD(1,1); | ||||
| #ifdef USE_WINSOCK | ||||
|   WORD wVersionRequested = MAKEWORD(USE_WINSOCK,USE_WINSOCK); | ||||
|   WSADATA wsaData; | ||||
|   WSAStartup(wVersionRequested, &wsaData); | ||||
| #endif | ||||
| @@ -151,10 +164,16 @@ int main(int argc, char **argv) | ||||
|   options.flags = ARES_FLAG_NOCHECKRESP; | ||||
|   options.servers = NULL; | ||||
|   options.nservers = 0; | ||||
|   while ((c = getopt(argc, argv, "f:s:c:t:T:U:")) != -1) | ||||
|   while ((c = getopt(argc, argv, "df:s:c:t:T:U:")) != -1) | ||||
|     { | ||||
|       switch (c) | ||||
|         { | ||||
|         case 'd': | ||||
| #ifdef WATT32 | ||||
|           dbug_init(); | ||||
| #endif | ||||
|           break; | ||||
|  | ||||
|         case 'f': | ||||
|           /* Add a flag. */ | ||||
|           for (i = 0; i < nflags; i++) | ||||
| @@ -214,17 +233,17 @@ int main(int argc, char **argv) | ||||
|  | ||||
|         case 'T': | ||||
|           /* Set the TCP port number. */ | ||||
|           if (!isdigit((unsigned char)*optarg)) | ||||
|           if (!ISDIGIT(*optarg)) | ||||
|             usage(); | ||||
|           options.tcp_port = strtol(optarg, NULL, 0); | ||||
|           options.tcp_port = (unsigned short)strtol(optarg, NULL, 0); | ||||
|           optmask |= ARES_OPT_TCP_PORT; | ||||
|           break; | ||||
|  | ||||
|         case 'U': | ||||
|           /* Set the UDP port number. */ | ||||
|           if (!isdigit((unsigned char)*optarg)) | ||||
|           if (!ISDIGIT(*optarg)) | ||||
|             usage(); | ||||
|           options.udp_port = strtol(optarg, NULL, 0); | ||||
|           options.udp_port = (unsigned short)strtol(optarg, NULL, 0); | ||||
|           optmask |= ARES_OPT_UDP_PORT; | ||||
|           break; | ||||
|         } | ||||
| @@ -385,7 +404,7 @@ static const unsigned char *display_question(const unsigned char *aptr, | ||||
|    */ | ||||
|   if (aptr + QFIXEDSZ > abuf + alen) | ||||
|     { | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       return NULL; | ||||
|     } | ||||
|  | ||||
| @@ -401,7 +420,7 @@ static const unsigned char *display_question(const unsigned char *aptr, | ||||
|   if (dnsclass != C_IN) | ||||
|     printf("\t%s", class_name(dnsclass)); | ||||
|   printf("\t%s\n", type_name(type)); | ||||
|   free(name); | ||||
|   ares_free_string(name); | ||||
|   return aptr; | ||||
| } | ||||
|  | ||||
| @@ -412,7 +431,7 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|   char *name; | ||||
|   int type, dnsclass, ttl, dlen, status; | ||||
|   long len; | ||||
|   struct in_addr addr; | ||||
|   char addr[46]; | ||||
|  | ||||
|   /* Parse the RR name. */ | ||||
|   status = ares_expand_name(aptr, abuf, alen, &name, &len); | ||||
| @@ -425,7 +444,7 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|    */ | ||||
|   if (aptr + RRFIXEDSZ > abuf + alen) | ||||
|     { | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       return NULL; | ||||
|     } | ||||
|  | ||||
| @@ -438,7 +457,7 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|   aptr += RRFIXEDSZ; | ||||
|   if (aptr + dlen > abuf + alen) | ||||
|     { | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       return NULL; | ||||
|     } | ||||
|  | ||||
| @@ -447,7 +466,7 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|   if (dnsclass != C_IN) | ||||
|     printf("\t%s", class_name(dnsclass)); | ||||
|   printf("\t%s", type_name(type)); | ||||
|   free(name); | ||||
|   ares_free_string(name); | ||||
|  | ||||
|   /* Display the RR data.  Don't touch aptr. */ | ||||
|   switch (type) | ||||
| @@ -465,7 +484,7 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t%s.", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       break; | ||||
|  | ||||
|     case T_HINFO: | ||||
| @@ -474,12 +493,12 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       len = *p; | ||||
|       if (p + len + 1 > aptr + dlen) | ||||
|         return NULL; | ||||
|       printf("\t%.*s", len, p + 1); | ||||
|       printf("\t%.*s", (int)len, p + 1); | ||||
|       p += len + 1; | ||||
|       len = *p; | ||||
|       if (p + len + 1 > aptr + dlen) | ||||
|         return NULL; | ||||
|       printf("\t%.*s", len, p + 1); | ||||
|       printf("\t%.*s", (int)len, p + 1); | ||||
|       break; | ||||
|  | ||||
|     case T_MINFO: | ||||
| @@ -489,13 +508,13 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t%s.", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       p += len; | ||||
|       status = ares_expand_name(p, abuf, alen, &name, &len); | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t%s.", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       break; | ||||
|  | ||||
|     case T_MX: | ||||
| @@ -504,12 +523,12 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|        */ | ||||
|       if (dlen < 2) | ||||
|         return NULL; | ||||
|       printf("\t%d", (aptr[0] << 8) | aptr[1]); | ||||
|       printf("\t%d", DNS__16BIT(aptr)); | ||||
|       status = ares_expand_name(aptr + 2, abuf, alen, &name, &len); | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t%s.", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       break; | ||||
|  | ||||
|     case T_SOA: | ||||
| @@ -521,22 +540,19 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t%s.\n", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       p += len; | ||||
|       status = ares_expand_name(p, abuf, alen, &name, &len); | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t\t\t\t\t\t%s.\n", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       p += len; | ||||
|       if (p + 20 > aptr + dlen) | ||||
|         return NULL; | ||||
|       printf("\t\t\t\t\t\t( %d %d %d %d %d )", | ||||
|              (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3], | ||||
|              (p[4] << 24) | (p[5] << 16) | (p[6] << 8) | p[7], | ||||
|              (p[8] << 24) | (p[9] << 16) | (p[10] << 8) | p[11], | ||||
|              (p[12] << 24) | (p[13] << 16) | (p[14] << 8) | p[15], | ||||
|              (p[16] << 24) | (p[17] << 16) | (p[18] << 8) | p[19]); | ||||
|       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)); | ||||
|       break; | ||||
|  | ||||
|     case T_TXT: | ||||
| @@ -548,7 +564,7 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|           len = *p; | ||||
|           if (p + len + 1 > aptr + dlen) | ||||
|             return NULL; | ||||
|           printf("\t%.*s", len, p + 1); | ||||
|           printf("\t%.*s", (int)len, p + 1); | ||||
|           p += len + 1; | ||||
|         } | ||||
|       break; | ||||
| @@ -557,8 +573,14 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       /* The RR data is a four-byte Internet address. */ | ||||
|       if (dlen != 4) | ||||
|         return NULL; | ||||
|       memcpy(&addr, aptr, sizeof(struct in_addr)); | ||||
|       printf("\t%s", inet_ntoa(addr)); | ||||
|       printf("\t%s", ares_inet_ntop(AF_INET,aptr,addr,sizeof(addr))); | ||||
|       break; | ||||
|  | ||||
|     case T_AAAA: | ||||
|       /* The RR data is a 16-byte IPv6 address. */ | ||||
|       if (dlen != 16) | ||||
|         return NULL; | ||||
|       printf("\t%s", ares_inet_ntop(AF_INET6,aptr,addr,sizeof(addr))); | ||||
|       break; | ||||
|  | ||||
|     case T_WKS: | ||||
| @@ -578,11 +600,12 @@ static const unsigned char *display_rr(const unsigned char *aptr, | ||||
|       if (status != ARES_SUCCESS) | ||||
|         return NULL; | ||||
|       printf("\t%s.", name); | ||||
|       free(name); | ||||
|       ares_free_string(name); | ||||
|       break; | ||||
|  | ||||
|     default: | ||||
|       printf("\t[Unknown RR; cannot parse]"); | ||||
|       break; | ||||
|     } | ||||
|   printf("\n"); | ||||
|  | ||||
|   | ||||
							
								
								
									
										89
									
								
								ares/ahost.c
									
									
									
									
									
								
							
							
						
						
									
										89
									
								
								ares/ahost.c
									
									
									
									
									
								
							| @@ -1,4 +1,6 @@ | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|  * software and its documentation for any purpose and without | ||||
| @@ -16,8 +18,7 @@ | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #else | ||||
| #if !defined(WIN32) || defined(WATT32) | ||||
| #include <sys/time.h> | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| @@ -29,31 +30,67 @@ | ||||
| #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 | ||||
|  | ||||
| #ifndef HAVE_STRUCT_IN6_ADDR | ||||
| struct in6_addr | ||||
| { | ||||
|   unsigned char s6_addr[16]; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| static void callback(void *arg, int status, struct hostent *host); | ||||
| static void usage(void); | ||||
|  | ||||
| int main(int argc, char **argv) | ||||
| { | ||||
|   ares_channel channel; | ||||
|   int status, nfds; | ||||
|   int status, nfds, c, addr_family = AF_INET; | ||||
|   fd_set read_fds, write_fds; | ||||
|   struct timeval *tvp, tv; | ||||
|   struct in_addr addr; | ||||
|   struct in_addr addr4; | ||||
|   struct in6_addr addr6; | ||||
|  | ||||
| #ifdef WIN32 | ||||
|   WORD wVersionRequested = MAKEWORD(1,1); | ||||
| #ifdef USE_WINSOCK | ||||
|   WORD wVersionRequested = MAKEWORD(USE_WINSOCK,USE_WINSOCK); | ||||
|   WSADATA wsaData; | ||||
|   WSAStartup(wVersionRequested, &wsaData); | ||||
| #endif | ||||
|  | ||||
|   if (argc <= 1) | ||||
|   while ((c = getopt(argc,argv,"t:h")) != -1) | ||||
|     { | ||||
|       switch (c) | ||||
|         { | ||||
|         case 't': | ||||
|           if (!strcasecmp(optarg,"a")) | ||||
|             addr_family = AF_INET; | ||||
|           else if (!strcasecmp(optarg,"aaaa")) | ||||
|             addr_family = AF_INET6; | ||||
|           else | ||||
|             usage(); | ||||
|           break; | ||||
|         case 'h': | ||||
|         default: | ||||
|           usage(); | ||||
|           break; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   argc -= optind; | ||||
|   argv += optind; | ||||
|   if (argc < 1) | ||||
|     usage(); | ||||
|  | ||||
|   status = ares_init(&channel); | ||||
| @@ -64,15 +101,21 @@ int main(int argc, char **argv) | ||||
|     } | ||||
|  | ||||
|   /* Initiate the queries, one per command-line argument. */ | ||||
|   for (argv++; *argv; argv++) | ||||
|   for ( ; *argv; argv++) | ||||
|     { | ||||
|       addr.s_addr = inet_addr(*argv); | ||||
|       if (addr.s_addr == INADDR_NONE) | ||||
|         ares_gethostbyname(channel, *argv, AF_INET, callback, *argv); | ||||
|       if (ares_inet_pton(AF_INET, *argv, &addr4) == 1) | ||||
|         { | ||||
|           ares_gethostbyaddr(channel, &addr4, sizeof(addr4), AF_INET, callback, | ||||
|                              *argv); | ||||
|         } | ||||
|       else if (ares_inet_pton(AF_INET6, *argv, &addr6) == 1) | ||||
|         { | ||||
|           ares_gethostbyaddr(channel, &addr6, sizeof(addr6), AF_INET6, callback, | ||||
|                              *argv); | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           ares_gethostbyaddr(channel, &addr, sizeof(addr), AF_INET, callback, | ||||
|                              *argv); | ||||
|           ares_gethostbyname(channel, *argv, addr_family, callback, *argv); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -95,7 +138,6 @@ int main(int argc, char **argv) | ||||
|  | ||||
| static void callback(void *arg, int status, struct hostent *host) | ||||
| { | ||||
|   struct in_addr addr; | ||||
|   char **p; | ||||
|  | ||||
|   if (status != ARES_SUCCESS) | ||||
| @@ -106,13 +148,26 @@ static void callback(void *arg, int status, struct hostent *host) | ||||
|  | ||||
|   for (p = host->h_addr_list; *p; p++) | ||||
|     { | ||||
|       memcpy(&addr, *p, sizeof(struct in_addr)); | ||||
|       printf("%-32s\t%s\n", host->h_name, inet_ntoa(addr)); | ||||
|       char addr_buf[46] = "??"; | ||||
|  | ||||
|       ares_inet_ntop(host->h_addrtype, *p, addr_buf, sizeof(addr_buf)); | ||||
|       printf("%-32s\t%s", host->h_name, addr_buf); | ||||
| #if 0 | ||||
|       if (host->h_aliases[0]) | ||||
|         { | ||||
|            int i; | ||||
|  | ||||
|            printf (", Aliases: "); | ||||
|            for (i = 0; host->h_aliases[i]; i++) | ||||
|                printf("%s ", host->h_aliases[i]); | ||||
|         } | ||||
| #endif | ||||
|       puts(""); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void usage(void) | ||||
| { | ||||
|   fprintf(stderr, "usage: ahost {host|addr} ...\n"); | ||||
|   fprintf(stderr, "usage: ahost [-t {a|aaaa}] {host|addr} ...\n"); | ||||
|   exit(1); | ||||
| } | ||||
|   | ||||
							
								
								
									
										60
									
								
								ares/ares.h
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								ares/ares.h
									
									
									
									
									
								
							| @@ -32,7 +32,7 @@ | ||||
|   #include <sys/socket.h> | ||||
|   #include <tcp.h> | ||||
| #elif defined(WIN32) | ||||
|   #include <winsock.h> | ||||
|   #include <winsock2.h> | ||||
|   #include <windows.h> | ||||
| #else | ||||
|   #include <netinet/in.h> | ||||
| @@ -70,8 +70,8 @@ extern "C" { | ||||
| #define ARES_EBADFLAGS          18 | ||||
|  | ||||
| /* ares_getaddrinfo error codes */ | ||||
| #define ARES_ENONAME		19 | ||||
| #define ARES_EBADHINTS		20 | ||||
| #define ARES_ENONAME            19 | ||||
| #define ARES_EBADHINTS          20 | ||||
|  | ||||
| /* Flag values */ | ||||
| #define ARES_FLAG_USEVC         (1 << 0) | ||||
| @@ -93,6 +93,7 @@ extern "C" { | ||||
| #define ARES_OPT_SERVERS        (1 << 6) | ||||
| #define ARES_OPT_DOMAINS        (1 << 7) | ||||
| #define ARES_OPT_LOOKUPS        (1 << 8) | ||||
| #define ARES_OPT_SOCK_STATE_CB  (1 << 9) | ||||
|  | ||||
| /* Nameinfo flag values */ | ||||
| #define ARES_NI_NOFQDN                  (1 << 0) | ||||
| @@ -108,27 +109,44 @@ extern "C" { | ||||
| #define ARES_NI_LOOKUPHOST              (1 << 8) | ||||
| #define ARES_NI_LOOKUPSERVICE           (1 << 9) | ||||
| /* Reserved for future use */ | ||||
| #define ARES_NI_IDN			(1 << 10) | ||||
| #define ARES_NI_IDN_ALLOW_UNASSIGNED	(1 << 11) | ||||
| #define ARES_NI_IDN                     (1 << 10) | ||||
| #define ARES_NI_IDN_ALLOW_UNASSIGNED    (1 << 11) | ||||
| #define ARES_NI_IDN_USE_STD3_ASCII_RULES (1 << 12) | ||||
|  | ||||
| /* Addrinfo flag values */ | ||||
| #define ARES_AI_CANONNAME		(1 << 0) | ||||
| #define ARES_AI_NUMERICHOST		(1 << 1) | ||||
| #define ARES_AI_PASSIVE			(1 << 2) | ||||
| #define ARES_AI_NUMERICSERV		(1 << 3) | ||||
| #define ARES_AI_V4MAPPED		(1 << 4) | ||||
| #define ARES_AI_ALL			(1 << 5) | ||||
| #define ARES_AI_ADDRCONFIG		(1 << 6) | ||||
| #define ARES_AI_CANONNAME               (1 << 0) | ||||
| #define ARES_AI_NUMERICHOST             (1 << 1) | ||||
| #define ARES_AI_PASSIVE                 (1 << 2) | ||||
| #define ARES_AI_NUMERICSERV             (1 << 3) | ||||
| #define ARES_AI_V4MAPPED                (1 << 4) | ||||
| #define ARES_AI_ALL                     (1 << 5) | ||||
| #define ARES_AI_ADDRCONFIG              (1 << 6) | ||||
| /* Reserved for future use */ | ||||
| #define ARES_AI_IDN			(1 << 10) | ||||
| #define ARES_AI_IDN_ALLOW_UNASSIGNED	(1 << 11) | ||||
| #define ARES_AI_IDN                     (1 << 10) | ||||
| #define ARES_AI_IDN_ALLOW_UNASSIGNED    (1 << 11) | ||||
| #define ARES_AI_IDN_USE_STD3_ASCII_RULES (1 << 12) | ||||
| #define ARES_AI_CANONIDN		(1 << 13) | ||||
| #define ARES_AI_CANONIDN                (1 << 13) | ||||
|  | ||||
| #define ARES_AI_MASK			(ARES_AI_CANONNAME|ARES_AI_NUMERICHOST|ARES_AI_PASSIVE| \ | ||||
| 				 	 ARES_AI_NUMERICSERV|ARES_AI_V4MAPPED|ARES_AI_ALL| \ | ||||
| 					 ARES_AI_ADDRCONFIG) | ||||
| #define ARES_AI_MASK (ARES_AI_CANONNAME|ARES_AI_NUMERICHOST|ARES_AI_PASSIVE| \ | ||||
|                       ARES_AI_NUMERICSERV|ARES_AI_V4MAPPED|ARES_AI_ALL| \ | ||||
|                       ARES_AI_ADDRCONFIG) | ||||
| #define ARES_GETSOCK_MAXNUM 16 /* ares_getsock() can return info about this | ||||
|                                   many sockets */ | ||||
| #define ARES_GETSOCK_READABLE(bits,num) (bits & (1<< (num))) | ||||
| #define ARES_GETSOCK_WRITABLE(bits,num) (bits & (1 << ((num) + \ | ||||
|                                          ARES_GETSOCK_MAXNUM))) | ||||
|  | ||||
| #ifdef WIN32 | ||||
| typedef void (*ares_sock_state_cb)(void *data, | ||||
|                                    SOCKET socket, | ||||
|                                    int readable, | ||||
|                                    int writable); | ||||
| #else | ||||
| typedef void (*ares_sock_state_cb)(void *data, | ||||
|                                    int socket, | ||||
|                                    int readable, | ||||
|                                    int writable); | ||||
| #endif | ||||
|  | ||||
| struct ares_options { | ||||
|   int flags; | ||||
| @@ -142,6 +160,8 @@ struct ares_options { | ||||
|   char **domains; | ||||
|   int ndomains; | ||||
|   char *lookups; | ||||
|   ares_sock_state_cb sock_state_cb; | ||||
|   void *sock_state_cb_data; | ||||
| }; | ||||
|  | ||||
| struct hostent; | ||||
| @@ -172,9 +192,11 @@ void ares_gethostbyname(ares_channel channel, const char *name, int family, | ||||
| void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen, | ||||
|                         int family, ares_host_callback callback, void *arg); | ||||
| void ares_getnameinfo(ares_channel channel, const struct sockaddr *sa, | ||||
|                       socklen_t salen, int flags, ares_nameinfo_callback callback, | ||||
|                       socklen_t salen, int flags, | ||||
|                       ares_nameinfo_callback callback, | ||||
|                       void *arg); | ||||
| int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds); | ||||
| 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); | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -23,7 +25,7 @@ | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| void ares__close_sockets(struct server_state *server) | ||||
| void ares__close_sockets(ares_channel channel, struct server_state *server) | ||||
| { | ||||
|   struct send_request *sendreq; | ||||
|  | ||||
| @@ -46,11 +48,13 @@ void ares__close_sockets(struct server_state *server) | ||||
|   /* Close the TCP and UDP sockets. */ | ||||
|   if (server->tcp_socket != ARES_SOCKET_BAD) | ||||
|     { | ||||
|       SOCK_STATE_CALLBACK(channel, server->tcp_socket, 0, 0); | ||||
|       closesocket(server->tcp_socket); | ||||
|       server->tcp_socket = ARES_SOCKET_BAD; | ||||
|     } | ||||
|   if (server->udp_socket != ARES_SOCKET_BAD) | ||||
|     { | ||||
|       SOCK_STATE_CALLBACK(channel, server->udp_socket, 0, 0); | ||||
|       closesocket(server->udp_socket); | ||||
|       server->udp_socket = ARES_SOCKET_BAD; | ||||
|     } | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -52,7 +54,7 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
|  | ||||
|       /* Get the address part. */ | ||||
|       p = line; | ||||
|       while (*p && !isspace((unsigned char)*p)) | ||||
|       while (*p && !ISSPACE(*p)) | ||||
|         p++; | ||||
|       if (!*p) | ||||
|         continue; | ||||
| @@ -74,12 +76,12 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
|  | ||||
|       /* Get the canonical hostname. */ | ||||
|       p++; | ||||
|       while (isspace((unsigned char)*p)) | ||||
|       while (ISSPACE(*p)) | ||||
|         p++; | ||||
|       if (!*p) | ||||
|         continue; | ||||
|       q = p; | ||||
|       while (*q && !isspace((unsigned char)*q)) | ||||
|       while (*q && !ISSPACE(*q)) | ||||
|         q++; | ||||
|       end_at_hostname = (*q == 0); | ||||
|       *q = 0; | ||||
| @@ -90,13 +92,13 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
|         { | ||||
|           /* Count the aliases. */ | ||||
|           p = q + 1; | ||||
|           while (isspace((unsigned char)*p)) | ||||
|           while (ISSPACE(*p)) | ||||
|             p++; | ||||
|           while (*p) | ||||
|             { | ||||
|               while (*p && !isspace((unsigned char)*p)) | ||||
|               while (*p && !ISSPACE(*p)) | ||||
|                 p++; | ||||
|               while (isspace((unsigned char)*p)) | ||||
|               while (ISSPACE(*p)) | ||||
|                 p++; | ||||
|               naliases++; | ||||
|             } | ||||
| @@ -126,12 +128,12 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
|       if (!end_at_hostname) | ||||
|         { | ||||
|           p = canonical + strlen(canonical) + 1; | ||||
|           while (isspace((unsigned char)*p)) | ||||
|           while (ISSPACE(*p)) | ||||
|             p++; | ||||
|           while (*p) | ||||
|             { | ||||
|               q = p; | ||||
|               while (*q && !isspace((unsigned char)*q)) | ||||
|               while (*q && !ISSPACE(*q)) | ||||
|                 q++; | ||||
|               hostent->h_aliases[naliases] = malloc(q - p + 1); | ||||
|               if (hostent->h_aliases[naliases] == NULL) | ||||
| @@ -139,7 +141,7 @@ int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
|               memcpy(hostent->h_aliases[naliases], p, q - p); | ||||
|               hostent->h_aliases[naliases][q - p] = 0; | ||||
|               p = q; | ||||
|               while (isspace((unsigned char)*p)) | ||||
|               while (ISSPACE(*p)) | ||||
|                 p++; | ||||
|               naliases++; | ||||
|             } | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -50,7 +52,7 @@ int ares__read_line(FILE *fp, char **buf, int *bufsize) | ||||
|       if ((*buf)[len - 1] == '\n') | ||||
|         { | ||||
|           (*buf)[len - 1] = 0; | ||||
|           return ARES_SUCCESS; | ||||
|           break; | ||||
|         } | ||||
|       offset = len; | ||||
|  | ||||
| @@ -61,4 +63,5 @@ int ares__read_line(FILE *fp, char **buf, int *bufsize) | ||||
|       *buf = newbuf; | ||||
|       *bufsize *= 2; | ||||
|     } | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|   | ||||
| @@ -34,6 +34,6 @@ might have been stored in their arguments. | ||||
| .BR ares_init (3) | ||||
| .BR ares_destroy (3) | ||||
| .SH NOTES | ||||
| This function is not compatible with ares. | ||||
| This function was added in c-ares 1.2.0 | ||||
| .SH AUTHOR | ||||
| Dirk Manske | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2004 by Daniel Stenberg et al | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software and its | ||||
| @@ -37,7 +39,10 @@ void ares_cancel(ares_channel channel) | ||||
|   channel->queries = NULL; | ||||
|   if (!(channel->flags & ARES_FLAG_STAYOPEN)) | ||||
|   { | ||||
|     for (i = 0; i < channel->nservers; i++) | ||||
|       ares__close_sockets(&channel->servers[i]); | ||||
|     if (channel->servers) | ||||
|     { | ||||
|       for (i = 0; i < channel->nservers; i++) | ||||
|         ares__close_sockets(channel, &channel->servers[i]); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -23,23 +25,37 @@ void ares_destroy(ares_channel channel) | ||||
|   int i; | ||||
|   struct query *query; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
|     ares__close_sockets(&channel->servers[i]); | ||||
|   free(channel->servers); | ||||
|   for (i = 0; i < channel->ndomains; i++) | ||||
|     free(channel->domains[i]); | ||||
|   free(channel->domains); | ||||
|   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); | ||||
|   free(channel->lookups); | ||||
|   while (channel->queries) | ||||
|     { | ||||
|       query = channel->queries; | ||||
|       channel->queries = query->next; | ||||
|       query->callback(query->arg, ARES_EDESTRUCTION, NULL, 0); | ||||
|  | ||||
|   if (channel->lookups) | ||||
|     free(channel->lookups); | ||||
|  | ||||
|   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(query); | ||||
|   } | ||||
|  | ||||
|   free(channel); | ||||
| } | ||||
|   | ||||
| @@ -28,6 +28,15 @@ | ||||
|                                          ((p)[2] = ((v) >> 8) & 0xff), \ | ||||
|                                          ((p)[3] = (v) & 0xff)) | ||||
|  | ||||
| #if 0 | ||||
| /* we cannot use this approach on systems where we can't access 16/32 bit | ||||
|    data on un-aligned addresses */ | ||||
| #define DNS__16BIT(p)                   ntohs(*(unsigned short*)(p)) | ||||
| #define DNS__32BIT(p)                   ntohl(*(unsigned long*)(p)) | ||||
| #define DNS__SET16BIT(p, v)             *(unsigned short*)(p) = htons(v) | ||||
| #define DNS__SET32BIT(p, v)             *(unsigned long*)(p) = htonl(v) | ||||
| #endif | ||||
|  | ||||
| /* Macros for parsing a DNS header */ | ||||
| #define DNS_HEADER_QID(h)               DNS__16BIT(h) | ||||
| #define DNS_HEADER_QR(h)                (((h)[2] >> 7) & 0x1) | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -44,13 +46,13 @@ int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds) | ||||
|             nfds = server->udp_socket + 1; | ||||
|         } | ||||
|       if (server->tcp_socket != ARES_SOCKET_BAD) | ||||
|         { | ||||
|           FD_SET(server->tcp_socket, read_fds); | ||||
|           if (server->qhead) | ||||
|             FD_SET(server->tcp_socket, write_fds); | ||||
|           if (server->tcp_socket >= nfds) | ||||
|             nfds = server->tcp_socket + 1; | ||||
|         } | ||||
|        { | ||||
|          FD_SET(server->tcp_socket, read_fds); | ||||
|          if (server->qhead) | ||||
|            FD_SET(server->tcp_socket, write_fds); | ||||
|          if (server->tcp_socket >= nfds) | ||||
|            nfds = server->tcp_socket + 1; | ||||
| 	} | ||||
|     } | ||||
|   return (int)nfds; | ||||
| } | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 2000 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -16,6 +18,7 @@ | ||||
| #include "setup.h" | ||||
| #include <stdlib.h> | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| void ares_free_string(void *str) | ||||
| { | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -170,7 +172,7 @@ static void host_callback(void *arg, int status, unsigned char *abuf, int alen) | ||||
|     } | ||||
|   else if (status == ARES_ENODATA && hquery->family == AF_INET6) | ||||
|     { | ||||
|       /* There was no AAAA now lookup an A */ | ||||
|       /* There was no AAAA. Now lookup an A */ | ||||
|       hquery->family = AF_INET; | ||||
|       ares_search(hquery->channel, hquery->name, C_IN, T_A, host_callback, | ||||
|                   hquery); | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 2005 by Dominick Meglio | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -68,17 +70,19 @@ struct nameinfo_query { | ||||
| #endif | ||||
|  | ||||
| static void nameinfo_callback(void *arg, int status, struct hostent *host); | ||||
| static char *lookup_service(unsigned short port, int flags, char *buf); | ||||
| static char *lookup_service(unsigned short port, int flags, | ||||
|                             char *buf, size_t buflen); | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
| static char *append_scopeid(struct sockaddr_in6 *addr6, unsigned int scopeid, char *buf); | ||||
| static void append_scopeid(struct sockaddr_in6 *addr6, unsigned int scopeid, | ||||
|                            char *buf, size_t buflen); | ||||
| #endif | ||||
| static char *ares_striendstr(const char *s1, const char *s2); | ||||
|  | ||||
| void ares_getnameinfo(ares_channel channel, const struct sockaddr *sa, socklen_t salen, | ||||
|                       int flags, ares_nameinfo_callback callback, void *arg) | ||||
| { | ||||
|   struct sockaddr_in *addr; | ||||
|   struct sockaddr_in6 *addr6; | ||||
|   struct sockaddr_in *addr = NULL; | ||||
|   struct sockaddr_in6 *addr6 = NULL; | ||||
|   struct nameinfo_query *niquery; | ||||
|  | ||||
|   /* Verify the buffer size */ | ||||
| @@ -106,7 +110,7 @@ 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); | ||||
|       service = lookup_service(port, flags, buf, sizeof(buf)); | ||||
|       callback(arg, ARES_SUCCESS, NULL, service); | ||||
|       return; | ||||
|     } | ||||
| @@ -119,7 +123,7 @@ void ares_getnameinfo(ares_channel channel, const struct sockaddr *sa, socklen_t | ||||
|       { | ||||
|         unsigned int port = 0; | ||||
|         char ipbuf[IPBUFSIZ]; | ||||
|         char srvbuf[32]; | ||||
|         char srvbuf[33]; | ||||
|         char *service = NULL; | ||||
|         ipbuf[0] = 0; | ||||
|  | ||||
| @@ -137,7 +141,7 @@ void ares_getnameinfo(ares_channel channel, const struct sockaddr *sa, socklen_t | ||||
|             port = addr6->sin6_port; | ||||
|             /* If the system supports scope IDs, use it */ | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
|             append_scopeid(addr6, flags, ipbuf); | ||||
|             append_scopeid(addr6, flags, ipbuf, sizeof(ipbuf)); | ||||
| #endif | ||||
|           } | ||||
|         else | ||||
| @@ -147,7 +151,7 @@ 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); | ||||
|           service = lookup_service(port, flags, srvbuf, sizeof(srvbuf)); | ||||
|         callback(arg, ARES_SUCCESS, ipbuf, service); | ||||
|         return; | ||||
|       } | ||||
| @@ -195,10 +199,10 @@ static void nameinfo_callback(void *arg, int status, struct hostent *host) | ||||
|         { | ||||
|           if (niquery->family == AF_INET) | ||||
|             service = lookup_service(niquery->addr.addr4.sin_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|                                      niquery->flags, srvbuf, sizeof(srvbuf)); | ||||
|           else | ||||
|             service = lookup_service(niquery->addr.addr6.sin6_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|                                      niquery->flags, srvbuf, sizeof(srvbuf)); | ||||
|         } | ||||
|       /* NOFQDN means we have to strip off the domain name portion. | ||||
|          We do this by determining our own domain name, then searching the string | ||||
| @@ -229,7 +233,7 @@ static void nameinfo_callback(void *arg, int status, struct hostent *host) | ||||
|         { | ||||
|           ares_inet_ntop(AF_INET6, &niquery->addr.addr6.sin6_addr, ipbuf, IPBUFSIZ); | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
|           append_scopeid(&niquery->addr.addr6, niquery->flags, ipbuf); | ||||
|           append_scopeid(&niquery->addr.addr6, niquery->flags, ipbuf, sizeof(ipbuf)); | ||||
| #endif | ||||
|         } | ||||
|       /* They want a service too */ | ||||
| @@ -237,10 +241,10 @@ static void nameinfo_callback(void *arg, int status, struct hostent *host) | ||||
|         { | ||||
|           if (niquery->family == AF_INET) | ||||
|             service = lookup_service(niquery->addr.addr4.sin_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|                                      niquery->flags, srvbuf, sizeof(srvbuf)); | ||||
|           else | ||||
|             service = lookup_service(niquery->addr.addr6.sin6_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|                                      niquery->flags, srvbuf, sizeof(srvbuf)); | ||||
|         } | ||||
|       niquery->callback(niquery->arg, ARES_SUCCESS, ipbuf, service); | ||||
|       return; | ||||
| @@ -250,28 +254,21 @@ static void nameinfo_callback(void *arg, int status, struct hostent *host) | ||||
| } | ||||
|  | ||||
| static char *lookup_service(unsigned short port, int flags, | ||||
|                             char *buf) /* 33 bytes buffer */ | ||||
|                             char *buf, size_t buflen) | ||||
| { | ||||
|   const char *proto; | ||||
|   struct servent *sep; | ||||
| #ifdef HAVE_GETSERVBYPORT_R | ||||
|   struct servent se; | ||||
| #endif | ||||
|   char tmpbuf[4096]; | ||||
|  | ||||
|   if (port) | ||||
|     { | ||||
|       /* Just return the port as a string */ | ||||
|       if (flags & ARES_NI_NUMERICSERV) | ||||
|         sprintf(buf, "%u", ntohs(port)); | ||||
|         sep = NULL; | ||||
|       else | ||||
|         { | ||||
|           struct servent *se; | ||||
|           const char *proto; | ||||
| #if GETSERVBYPORT_R_ARGS == 6 | ||||
|           struct servent ret; | ||||
|           char buf[4096]; | ||||
|           int len = 4096; | ||||
| #elif GETSERVBYPORT_R_ARGS == 5 | ||||
|           char buf[4096]; | ||||
|           int len = 4096; | ||||
| #elif GETSERVBYPORT_R_ARGS == 4 | ||||
|           struct servent ret; | ||||
|           struct servent_data sed; | ||||
| #endif | ||||
|           if (flags & ARES_NI_UDP) | ||||
|             proto = "udp"; | ||||
|           else if (flags & ARES_NI_SCTP) | ||||
| @@ -281,65 +278,77 @@ static char *lookup_service(unsigned short port, int flags, | ||||
|           else | ||||
|             proto = "tcp"; | ||||
| #ifdef HAVE_GETSERVBYPORT_R | ||||
|           sep = &se; | ||||
|           memset(tmpbuf, 0, sizeof(tmpbuf)); | ||||
| #if GETSERVBYPORT_R_ARGS == 6 | ||||
|           se = &ret; | ||||
|           if (getservbyport_r(port, proto, se, buf, len, &ret)) | ||||
|             se = NULL; | ||||
|           if (getservbyport_r(port, proto, &se, (void *)tmpbuf, sizeof(tmpbuf), &sep) != 0) | ||||
|             sep = NULL; | ||||
| #elif GETSERVBYPORT_R_ARGS == 5 | ||||
|           se = getservbyport_r(port, proto, se, buf, len); | ||||
|           sep = getservbyport_r(port, proto, &se, (void *)tmpbuf, sizeof(tmpbuf)); | ||||
| #elif GETSERVBYPORT_R_ARGS == 4 | ||||
|           se = &ret; | ||||
|           if (getservbyport_r(port, proto, se, &sed) == -1) | ||||
|             se = NULL; | ||||
|           if (getservbyport_r(port, proto, &se, (void *)tmpbuf) != 0) | ||||
|             sep = NULL; | ||||
| #else | ||||
|           /* Lets just hope the OS uses TLS! */ | ||||
|           se = getservbyport(port, proto); | ||||
|           sep = getservbyport(port, proto); | ||||
| #endif | ||||
| #else | ||||
|           /* Lets just hope the OS uses TLS! */ | ||||
|           se = getservbyport(port, proto); | ||||
|           sep = getservbyport(port, proto); | ||||
| #endif | ||||
|           if (se && se->s_name) { | ||||
|             size_t len = strlen(se->s_name); | ||||
|             if(len < 33) { | ||||
|               strcpy(buf, se->s_name); | ||||
|             } | ||||
|             else | ||||
|               /* too big name to fit the buffer */ | ||||
|               buf[0]=0; | ||||
|           } | ||||
|           else | ||||
|             sprintf(buf, "%u", ntohs(port)); | ||||
|         } | ||||
|       if (sep && sep->s_name) | ||||
|         /* get service name */ | ||||
|         strcpy(tmpbuf, sep->s_name); | ||||
|       else | ||||
|         /* get port as a string */ | ||||
|         sprintf(tmpbuf, "%u", ntohs(port)); | ||||
|       if (strlen(tmpbuf) < buflen) | ||||
|         /* return it if buffer big enough */ | ||||
|         strcpy(buf, tmpbuf); | ||||
|       else | ||||
|         /* avoid reusing previous one */ | ||||
|         buf[0] = '\0'; | ||||
|       return buf; | ||||
|     } | ||||
|   buf[0] = '\0'; | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
| static char *append_scopeid(struct sockaddr_in6 *addr6, unsigned int flags, | ||||
|                             char *buf) | ||||
| static void append_scopeid(struct sockaddr_in6 *addr6, unsigned int flags, | ||||
|                            char *buf, size_t buflen) | ||||
| { | ||||
|   char tmpbuf[IF_NAMESIZE + 1]; | ||||
|   char fmt_u[] = "%u"; | ||||
|   char fmt_lu[] = "%lu"; | ||||
|   char tmpbuf[IF_NAMESIZE + 2]; | ||||
|   size_t bufl; | ||||
|   char *fmt = (sizeof(addr6->sin6_scope_id) > sizeof(unsigned int))?fmt_lu:fmt_u; | ||||
|  | ||||
|   tmpbuf[0] = '%'; | ||||
|  | ||||
| #ifdef HAVE_IF_INDEXTONAME | ||||
|   if ((flags & ARES_NI_NUMERICSCOPE) || | ||||
|       (!IN6_IS_ADDR_LINKLOCAL(&addr6->sin6_addr) | ||||
|        && !IN6_IS_ADDR_MC_LINKLOCAL(&addr6->sin6_addr))) | ||||
|     { | ||||
|        sprintf(&tmpbuf[1], "%u", addr6->sin6_scope_id); | ||||
|        sprintf(&tmpbuf[1], fmt, addr6->sin6_scope_id); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       if (if_indextoname(addr6->sin6_scope_id, &tmpbuf[1]) == NULL) | ||||
|         sprintf(&tmpbuf[1], "%u", addr6->sin6_scope_id); | ||||
|         sprintf(&tmpbuf[1], fmt, addr6->sin6_scope_id); | ||||
|     } | ||||
| #else | ||||
|   sprintf(&tmpbuf[1], "%u", addr6->sin6_scope_id); | ||||
|   sprintf(&tmpbuf[1], fmt, addr6->sin6_scope_id); | ||||
|   (void) flags; | ||||
| #endif | ||||
|   strcat(buf, tmpbuf); | ||||
|   return buf; | ||||
|   tmpbuf[IF_NAMESIZE + 1] = '\0'; | ||||
|   bufl = strlen(buf); | ||||
|  | ||||
|   if(bufl + strlen(tmpbuf) < buflen) | ||||
|     /* only append the scopeid string if it fits in the target buffer */ | ||||
|     strcpy(&buf[bufl], tmpbuf); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
							
								
								
									
										58
									
								
								ares/ares_getsock.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								ares/ares_getsock.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .\" Copyright 1998 by Daniel Stenberg | ||||
| .\" | ||||
| .\" 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_GETSOCK 3 "22 December 2005" | ||||
| .SH NAME | ||||
| ares_getsock \- get file descriptors to wait on | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <ares.h> | ||||
| .PP | ||||
| .B int ares_getsock(ares_channel \fIchannel\fP, int *\fIsocks\fP,  | ||||
| .B int \fInumsocks\fP); | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_getsock | ||||
| function retrieves the set of file descriptors which the calling | ||||
| application should wait on for reading and/or writing for the | ||||
| processing of name service queries pending on the name service channel | ||||
| identified by | ||||
| .IR channel . | ||||
| File descriptors will be set in the integer array pointed to by | ||||
| \fIsocks\fP. | ||||
| \fInumsocks\fP is the size of the given array in number of ints. | ||||
|  | ||||
| This function can only return information about up to 16 sockets. If more are | ||||
| in use (however unlikely that is), they are simply not reported back. | ||||
| .SH RETURN VALUES | ||||
| \fBares_getsock\fP returns a bitmask for what actions to wait for on the | ||||
| different sockets. The ares.h header file provides these convenience macros to | ||||
| extract the information appropriately: | ||||
|  | ||||
| .nf | ||||
| #define ARES_GETSOCK_MAXNUM 16 /* ares_getsock() can return info about | ||||
|                                   this many sockets */ | ||||
| #define ARES_GETSOCK_READABLE(bits,num) (bits & (1<< (num))) | ||||
| #define ARES_GETSOCK_WRITABLE(bits,num) (bits & (1 << ((num) + \ | ||||
|                                          ARES_GETSOCK_MAXNUM))) | ||||
| .fi | ||||
| .SH NOTES | ||||
| This function was added in c-ares 1.3.1 | ||||
| .SH SEE ALSO | ||||
| .BR ares_timeout (3), | ||||
| .BR ares_fds (3), | ||||
| .BR ares_process (3) | ||||
							
								
								
									
										70
									
								
								ares/ares_getsock.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								ares/ares_getsock.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2005 - 2006, Daniel Stenberg | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
| #endif | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| int ares_getsock(ares_channel channel, | ||||
|                  int *s, | ||||
|                  int numsocks) /* size of the 'socks' array */ | ||||
| { | ||||
|   struct server_state *server; | ||||
|   int i; | ||||
|   int sockindex=0; | ||||
|   int bitmap = 0; | ||||
|   unsigned int setbits = 0xffffffff; | ||||
|  | ||||
|   ares_socket_t *socks = (ares_socket_t *)s; | ||||
|  | ||||
|   /* No queries, no file descriptors. */ | ||||
|   if (!channel->queries) | ||||
|     return 0; | ||||
|  | ||||
|   for (i = 0; | ||||
|        (i < channel->nservers) && (sockindex < ARES_GETSOCK_MAXNUM); | ||||
|        i++) | ||||
|     { | ||||
|       server = &channel->servers[i]; | ||||
|       if (server->udp_socket != ARES_SOCKET_BAD) | ||||
|         { | ||||
|           if(sockindex >= numsocks) | ||||
|             break; | ||||
|           socks[sockindex] = server->udp_socket; | ||||
|           bitmap |= ARES_GETSOCK_READABLE(setbits, sockindex); | ||||
|           sockindex++; | ||||
|         } | ||||
|       if (server->tcp_socket != ARES_SOCKET_BAD) | ||||
|        { | ||||
|          if(sockindex >= numsocks) | ||||
|            break; | ||||
|          socks[sockindex] = server->tcp_socket; | ||||
|          bitmap |= ARES_GETSOCK_READABLE(setbits, sockindex); | ||||
|  | ||||
|          if (server->qhead) | ||||
|            /* then the tcp socket is also writable! */ | ||||
|            bitmap |= ARES_GETSOCK_WRITABLE(setbits, sockindex); | ||||
|  | ||||
|          sockindex++; | ||||
|        } | ||||
|     } | ||||
|   return bitmap; | ||||
| } | ||||
| @@ -98,6 +98,24 @@ The lookups to perform for host queries. | ||||
| .I lookups | ||||
| should be set to a string of the characters "b" or "f", where "b" | ||||
| indicates a DNS lookup and "f" indicates a lookup in the hosts file. | ||||
| .TP 18 | ||||
| .B ARES_OPT_SOCK_STATE_CB | ||||
| .B void (*\fIsock_state_cb\fP)(void *data, int s, int read, int write); | ||||
| .br | ||||
| .B void *\fIsock_state_cb_data\fP; | ||||
| .br | ||||
| A callback function to be invoked when a socket changes state. | ||||
| .I s | ||||
| will be passed the socket whose state has changed; | ||||
| .I read | ||||
| will be set to true if the socket should listen for read events, and | ||||
| .I write | ||||
| will be set to true if the socket should listen for write events. | ||||
| The value of | ||||
| .I sock_state_cb_data | ||||
| will be passed as the | ||||
| .I data | ||||
| argument. | ||||
| .PP | ||||
| The | ||||
| .I flags | ||||
|   | ||||
							
								
								
									
										113
									
								
								ares/ares_init.c
									
									
									
									
									
								
							
							
						
						
									
										113
									
								
								ares/ares_init.c
									
									
									
									
									
								
							| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -93,6 +95,16 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
|   struct server_state *server; | ||||
|   struct timeval tv; | ||||
|  | ||||
| #ifdef CURLDEBUG | ||||
|   const char *env = getenv("CARES_MEMDEBUG"); | ||||
|  | ||||
|   if (env) | ||||
|     curl_memdebug(env); | ||||
|   env = getenv("CARES_MEMLIMIT"); | ||||
|   if (env) | ||||
|     curl_memlimit(atoi(env)); | ||||
| #endif | ||||
|  | ||||
|   channel = malloc(sizeof(struct ares_channeldata)); | ||||
|   if (!channel) | ||||
|     return ARES_ENOMEM; | ||||
| @@ -113,6 +125,9 @@ 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. | ||||
| @@ -127,7 +142,7 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
|   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) | ||||
|         { | ||||
| @@ -192,16 +207,25 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
|     channel->udp_port = options->udp_port; | ||||
|   if ((optmask & ARES_OPT_TCP_PORT) && channel->tcp_port == -1) | ||||
|     channel->tcp_port = options->tcp_port; | ||||
|   if ((optmask & ARES_OPT_SOCK_STATE_CB) && channel->sock_state_cb == NULL) | ||||
|     { | ||||
|       channel->sock_state_cb = options->sock_state_cb; | ||||
|       channel->sock_state_cb_data = options->sock_state_cb_data; | ||||
|     } | ||||
|  | ||||
|   /* Copy the servers, if given. */ | ||||
|   if ((optmask & ARES_OPT_SERVERS) && channel->nservers == -1) | ||||
|     { | ||||
|       channel->servers = | ||||
|         malloc(options->nservers * sizeof(struct server_state)); | ||||
|       if (!channel->servers && options->nservers != 0) | ||||
|         return ARES_ENOMEM; | ||||
|       for (i = 0; i < options->nservers; i++) | ||||
|         channel->servers[i].addr = options->servers[i]; | ||||
|       /* Avoid zero size allocations at any cost */ | ||||
|       if (options->nservers > 0) | ||||
|         { | ||||
|           channel->servers = | ||||
|             malloc(options->nservers * sizeof(struct server_state)); | ||||
|           if (!channel->servers) | ||||
|             return ARES_ENOMEM; | ||||
|           for (i = 0; i < options->nservers; i++) | ||||
|             channel->servers[i].addr = options->servers[i]; | ||||
|         } | ||||
|       channel->nservers = options->nservers; | ||||
|     } | ||||
|  | ||||
| @@ -210,16 +234,20 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
|    */ | ||||
|   if ((optmask & ARES_OPT_DOMAINS) && channel->ndomains == -1) | ||||
|     { | ||||
|       channel->domains = malloc(options->ndomains * sizeof(char *)); | ||||
|       if (!channel->domains && options->ndomains != 0) | ||||
|         return ARES_ENOMEM; | ||||
|       for (i = 0; i < options->ndomains; i++) | ||||
|         { | ||||
|           channel->ndomains = i; | ||||
|           channel->domains[i] = strdup(options->domains[i]); | ||||
|           if (!channel->domains[i]) | ||||
|             return ARES_ENOMEM; | ||||
|         } | ||||
|       /* Avoid zero size allocations at any cost */ | ||||
|       if (options->ndomains > 0) | ||||
|       { | ||||
|         channel->domains = malloc(options->ndomains * sizeof(char *)); | ||||
|         if (!channel->domains) | ||||
|           return ARES_ENOMEM; | ||||
|         for (i = 0; i < options->ndomains; i++) | ||||
|           { | ||||
|             channel->ndomains = i; | ||||
|             channel->domains[i] = strdup(options->domains[i]); | ||||
|             if (!channel->domains[i]) | ||||
|               return ARES_ENOMEM; | ||||
|           } | ||||
|       } | ||||
|       channel->ndomains = options->ndomains; | ||||
|     } | ||||
|  | ||||
| @@ -355,7 +383,8 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size) | ||||
|     printf ("DNS Servers:\n" | ||||
|             "    %s (primary)\n", fi->DnsServerList.IpAddress.String); | ||||
|   } | ||||
|   if (inet_addr(fi->DnsServerList.IpAddress.String) != INADDR_NONE && | ||||
|   if (strlen(fi->DnsServerList.IpAddress.String) > 0 && | ||||
|       inet_addr(fi->DnsServerList.IpAddress.String) != INADDR_NONE && | ||||
|       left > ip_size) | ||||
|   { | ||||
|     ret += sprintf (ret, "%s,", fi->DnsServerList.IpAddress.String); | ||||
| @@ -504,7 +533,7 @@ DhcpNameServer | ||||
|   if (status == ARES_SUCCESS) | ||||
|     status = ARES_EOF; | ||||
|  | ||||
| #elif defined(riscos) | ||||
| #elif defined(__riscos__) | ||||
|  | ||||
|   /* Under RISC OS, name servers are listed in the | ||||
|      system variable Inet$Resolvers, space separated. */ | ||||
| @@ -563,11 +592,11 @@ DhcpNameServer | ||||
|       return (errno == ENOENT) ? ARES_SUCCESS : ARES_EFILE; | ||||
|     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); | ||||
| @@ -692,7 +721,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 | ||||
| @@ -731,7 +759,7 @@ static int config_domain(ares_channel channel, char *str) | ||||
|  | ||||
|   /* Set a single search domain. */ | ||||
|   q = str; | ||||
|   while (*q && !isspace((unsigned char)*q)) | ||||
|   while (*q && !ISSPACE(*q)) | ||||
|     q++; | ||||
|   *q = 0; | ||||
|   return set_search(channel, str); | ||||
| @@ -755,9 +783,9 @@ static int config_lookup(ares_channel channel, const char *str, | ||||
|         if (*p == *bindch) *l++ = 'b'; | ||||
|         else *l++ = 'f'; | ||||
|       } | ||||
|       while (*p && !isspace((unsigned char)*p) && (*p != ',')) | ||||
|       while (*p && !ISSPACE(*p) && (*p != ',')) | ||||
|         p++; | ||||
|       while (*p && (isspace((unsigned char)*p) || (*p == ','))) | ||||
|       while (*p && (ISSPACE(*p) || (*p == ','))) | ||||
|         p++; | ||||
|     } | ||||
|   *l = 0; | ||||
| @@ -782,7 +810,7 @@ static int config_nameserver(struct server_state **servers, int *nservers, | ||||
|   while (more) | ||||
|   { | ||||
|     more = 0; | ||||
|     while (*p && !isspace(*p) && *p != ',') | ||||
|     while (*p && !ISSPACE(*p) && *p != ',') | ||||
|       p++; | ||||
|  | ||||
|     if (*p) | ||||
| @@ -842,7 +870,7 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|       char ipbuf[16], ipbufpfx[32]; | ||||
|       /* Find just the IP */ | ||||
|       q = str; | ||||
|       while (*q && *q != '/' && *q != ';' && !isspace((unsigned char)*q)) | ||||
|       while (*q && *q != '/' && *q != ';' && !ISSPACE(*q)) | ||||
|         q++; | ||||
|       memcpy(ipbuf, str, (int)(q-str)); | ||||
|       ipbuf[(int)(q-str)] = 0; | ||||
| @@ -850,7 +878,7 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|       if (*q == '/') | ||||
|         { | ||||
|           const char *str2 = q+1; | ||||
|           while (*q && *q != ';' && !isspace((unsigned char)*q)) | ||||
|           while (*q && *q != ';' && !ISSPACE(*q)) | ||||
|             q++; | ||||
|           memcpy(ipbufpfx, str, (int)(q-str)); | ||||
|           ipbufpfx[(int)(q-str)] = 0; | ||||
| @@ -899,11 +927,11 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           while (*q && *q != ';' && !isspace((unsigned char)*q)) | ||||
|           while (*q && *q != ';' && !ISSPACE(*q)) | ||||
|             q++; | ||||
|         } | ||||
|       str = q; | ||||
|       while (isspace((unsigned char)*str)) | ||||
|       while (ISSPACE(*str)) | ||||
|         str++; | ||||
|     } | ||||
|  | ||||
| @@ -921,6 +949,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; | ||||
|   } | ||||
|  | ||||
| @@ -929,15 +958,21 @@ static int set_search(ares_channel channel, const char *str) | ||||
|   p = str; | ||||
|   while (*p) | ||||
|     { | ||||
|       while (*p && !isspace((unsigned char)*p)) | ||||
|       while (*p && !ISSPACE(*p)) | ||||
|         p++; | ||||
|       while (isspace((unsigned char)*p)) | ||||
|       while (ISSPACE(*p)) | ||||
|         p++; | ||||
|       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. */ | ||||
| @@ -947,7 +982,7 @@ static int set_search(ares_channel channel, const char *str) | ||||
|     { | ||||
|       channel->ndomains = n; | ||||
|       q = p; | ||||
|       while (*q && !isspace((unsigned char)*q)) | ||||
|       while (*q && !ISSPACE(*q)) | ||||
|         q++; | ||||
|       channel->domains[n] = malloc(q - p + 1); | ||||
|       if (!channel->domains[n]) | ||||
| @@ -955,7 +990,7 @@ static int set_search(ares_channel channel, const char *str) | ||||
|       memcpy(channel->domains[n], p, q - p); | ||||
|       channel->domains[n][q - p] = 0; | ||||
|       p = q; | ||||
|       while (isspace((unsigned char)*p)) | ||||
|       while (ISSPACE(*p)) | ||||
|         p++; | ||||
|       n++; | ||||
|     } | ||||
| @@ -972,7 +1007,7 @@ static int set_options(ares_channel channel, const char *str) | ||||
|   while (*p) | ||||
|     { | ||||
|       q = p; | ||||
|       while (*q && !isspace((unsigned char)*q)) | ||||
|       while (*q && !ISSPACE(*q)) | ||||
|         q++; | ||||
|       val = try_option(p, q, "ndots:"); | ||||
|       if (val && channel->ndots == -1) | ||||
| @@ -984,7 +1019,7 @@ static int set_options(ares_channel channel, const char *str) | ||||
|       if (val && channel->tries == -1) | ||||
|         channel->tries = atoi(val); | ||||
|       p = q; | ||||
|       while (isspace((unsigned char)*p)) | ||||
|       while (ISSPACE(*p)) | ||||
|         p++; | ||||
|     } | ||||
|  | ||||
| @@ -997,10 +1032,10 @@ static char *try_config(char *s, const char *opt) | ||||
|   size_t len; | ||||
|  | ||||
|   len = strlen(opt); | ||||
|   if (strncmp(s, opt, len) != 0 || !isspace((unsigned char)s[len])) | ||||
|   if (strncmp(s, opt, len) != 0 || !ISSPACE(s[len])) | ||||
|     return NULL; | ||||
|   s += len; | ||||
|   while (isspace((unsigned char)*s)) | ||||
|   while (ISSPACE(*s)) | ||||
|     s++; | ||||
|   return s; | ||||
| } | ||||
|   | ||||
| @@ -42,12 +42,12 @@ struct sockaddr_in6 | ||||
| #ifndef HAVE_STRUCT_ADDRINFO | ||||
| struct addrinfo  | ||||
| { | ||||
|   int ai_flags; | ||||
|   int ai_family; | ||||
|   int ai_socktype; | ||||
|   int ai_protocol; | ||||
|   size_t ai_addrlen; | ||||
|   char *ai_cannonname; | ||||
|   int              ai_flags; | ||||
|   int              ai_family; | ||||
|   int              ai_socktype; | ||||
|   int              ai_protocol; | ||||
|   socklen_t        ai_addrlen;   /* Follow rfc3493 struct addrinfo */ | ||||
|   char            *ai_canonname; | ||||
|   struct sockaddr *ai_addr; | ||||
|   struct addrinfo *ai_next; | ||||
| }; | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -30,6 +32,7 @@ | ||||
| #include <string.h> | ||||
| #include "ares.h" | ||||
| #include "ares_dns.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| /* Header format, from RFC 1035: | ||||
|  *                                  1  1  1  1  1  1 | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 2005 Dominick Meglio | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| #ifndef __ARES_PRIVATE_H | ||||
| #define __ARES_PRIVATE_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
| @@ -62,6 +65,10 @@ | ||||
| #define PATH_RESOLV_CONF "sys:/etc/resolv.cfg" | ||||
| #define PATH_HOSTS              "sys:/etc/hosts" | ||||
|  | ||||
| #elif defined(__riscos__) | ||||
|  | ||||
| #define PATH_HOSTS             "InetDBase:Hosts" | ||||
|  | ||||
| #else | ||||
|  | ||||
| #define PATH_RESOLV_CONF        "/etc/resolv.conf" | ||||
| @@ -172,13 +179,22 @@ struct ares_channeldata { | ||||
|  | ||||
|   /* Active queries */ | ||||
|   struct query *queries; | ||||
|  | ||||
|   ares_sock_state_cb sock_state_cb; | ||||
|   void *sock_state_cb_data; | ||||
| }; | ||||
|  | ||||
| void ares__send_query(ares_channel channel, struct query *query, time_t now); | ||||
| void ares__close_sockets(struct server_state *server); | ||||
| 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); | ||||
|  | ||||
| #define SOCK_STATE_CALLBACK(c, s, r, w)                                 \ | ||||
|   do {                                                                  \ | ||||
|     if ((c)->sock_state_cb)                                             \ | ||||
|       (c)->sock_state_cb((c)->sock_state_cb_data, (s), (r), (w));       \ | ||||
|   } while (0) | ||||
|  | ||||
| #ifdef CURLDEBUG | ||||
| /* This is low-level hard-hacking memory leak tracking and similar. Using the | ||||
|    libcurl lowlevel code from within library is ugly and only works when | ||||
| @@ -186,3 +202,6 @@ int ares__read_line(FILE *fp, char **buf, int *bufsize); | ||||
|    this anyway for convenience. */ | ||||
| #include "../lib/memdebug.h" | ||||
| #endif | ||||
|  | ||||
| #endif /* __ARES_PRIVATE_H */ | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -30,6 +32,8 @@ | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif /* WIN32 && !WATT32 */ | ||||
|  | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| @@ -39,7 +43,6 @@ | ||||
| #ifdef NETWARE | ||||
| #include <sys/filio.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| @@ -56,12 +59,13 @@ | ||||
| #define TRUE 1 | ||||
| #endif | ||||
|  | ||||
| #if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS) | ||||
| #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); | ||||
| @@ -93,6 +97,31 @@ void ares_process(ares_channel channel, fd_set *read_fds, fd_set *write_fds) | ||||
|   process_timeouts(channel, now); | ||||
| } | ||||
|  | ||||
| /* Return 1 if the specified errno describes a readiness error, or 0 | ||||
|  * otherwise. This is mostly for HP-UX, which could return EAGAIN or | ||||
|  * EWOULDBLOCK. See this man page | ||||
|  * | ||||
|  * 	http://devrsrc1.external.hp.com/STKS/cgi-bin/man2html?manpage=/usr/share/man/man2.Z/send.2 | ||||
|  */ | ||||
| static int try_again(int errnum) | ||||
| { | ||||
| #if !defined EWOULDBLOCK && !defined EAGAIN | ||||
| #error "Neither EWOULDBLOCK nor EAGAIN defined" | ||||
| #endif | ||||
|   switch (errnum) | ||||
|     { | ||||
| #ifdef EWOULDBLOCK | ||||
|     case EWOULDBLOCK: | ||||
|       return 1; | ||||
| #endif | ||||
| #if defined EAGAIN && EAGAIN != EWOULDBLOCK | ||||
|     case EAGAIN: | ||||
|       return 1; | ||||
| #endif | ||||
|     } | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| /* If any TCP sockets select true for writing, write out queued data | ||||
|  * we have for them. | ||||
|  */ | ||||
| @@ -103,7 +132,7 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|   struct iovec *vec; | ||||
|   int i; | ||||
|   ssize_t scount; | ||||
|   int wcount; | ||||
|   ssize_t wcount; | ||||
|   size_t n; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
| @@ -131,11 +160,12 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|               vec[n].iov_len = sendreq->len; | ||||
|               n++; | ||||
|             } | ||||
|           wcount = writev(server->tcp_socket, vec, n); | ||||
|           wcount = (ssize_t)writev(server->tcp_socket, vec, (int)n); | ||||
|           free(vec); | ||||
|           if (wcount < 0) | ||||
|             { | ||||
|               handle_error(channel, i, now); | ||||
|               if (!try_again(GET_ERRNO())) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
|  | ||||
| @@ -148,7 +178,10 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|                   wcount -= sendreq->len; | ||||
|                   server->qhead = sendreq->next; | ||||
|                   if (server->qhead == NULL) | ||||
|                     server->qtail = NULL; | ||||
|                     { | ||||
|                       SOCK_STATE_CALLBACK(channel, server->tcp_socket, 1, 0); | ||||
|                       server->qtail = NULL; | ||||
|                     } | ||||
|                   free(sendreq); | ||||
|                 } | ||||
|               else | ||||
| @@ -164,11 +197,11 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|           /* Can't allocate iovecs; just send the first request. */ | ||||
|           sendreq = server->qhead; | ||||
|  | ||||
|           scount = send(server->tcp_socket, sendreq->data, sendreq->len, 0); | ||||
|  | ||||
|           scount = swrite(server->tcp_socket, sendreq->data, sendreq->len); | ||||
|           if (scount < 0) | ||||
|             { | ||||
|               handle_error(channel, i, now); | ||||
|               if (!try_again(GET_ERRNO())) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
|  | ||||
| @@ -177,7 +210,10 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now) | ||||
|             { | ||||
|               server->qhead = sendreq->next; | ||||
|               if (server->qhead == NULL) | ||||
|                 server->qtail = NULL; | ||||
|                 { | ||||
|                   SOCK_STATE_CALLBACK(channel, server->tcp_socket, 1, 0); | ||||
|                   server->qtail = NULL; | ||||
|                 } | ||||
|               free(sendreq); | ||||
|             } | ||||
|           else | ||||
| @@ -196,7 +232,8 @@ 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) | ||||
| { | ||||
|   struct server_state *server; | ||||
|   int i, count; | ||||
|   int i; | ||||
|   ssize_t count; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
|     { | ||||
| @@ -211,16 +248,17 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
|           /* We haven't yet read a length word, so read that (or | ||||
|            * what's left to read of it). | ||||
|            */ | ||||
|           count = recv(server->tcp_socket, | ||||
|                        server->tcp_lenbuf + server->tcp_buffer_pos, | ||||
|                        2 - server->tcp_buffer_pos, 0); | ||||
|           count = sread(server->tcp_socket, | ||||
|                         server->tcp_lenbuf + server->tcp_lenbuf_pos, | ||||
|                         2 - server->tcp_lenbuf_pos); | ||||
|           if (count <= 0) | ||||
|             { | ||||
|               handle_error(channel, i, now); | ||||
|               if (!(count == -1 && try_again(GET_ERRNO()))) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
|  | ||||
|           server->tcp_lenbuf_pos += count; | ||||
|           server->tcp_lenbuf_pos += (int)count; | ||||
|           if (server->tcp_lenbuf_pos == 2) | ||||
|             { | ||||
|               /* We finished reading the length word.  Decode the | ||||
| @@ -237,16 +275,17 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
|       else | ||||
|         { | ||||
|           /* Read data into the allocated buffer. */ | ||||
|           count = recv(server->tcp_socket, | ||||
|                        server->tcp_buffer + server->tcp_buffer_pos, | ||||
|                        server->tcp_length - server->tcp_buffer_pos, 0); | ||||
|           count = sread(server->tcp_socket, | ||||
|                         server->tcp_buffer + server->tcp_buffer_pos, | ||||
|                         server->tcp_length - server->tcp_buffer_pos); | ||||
|           if (count <= 0) | ||||
|             { | ||||
|               handle_error(channel, i, now); | ||||
|               if (!(count == -1 && try_again(GET_ERRNO()))) | ||||
|                   handle_error(channel, i, now); | ||||
|               continue; | ||||
|             } | ||||
|  | ||||
|           server->tcp_buffer_pos += count; | ||||
|           server->tcp_buffer_pos += (int)count; | ||||
|           if (server->tcp_buffer_pos == server->tcp_length) | ||||
|             { | ||||
|               /* We finished reading this answer; process it and | ||||
| @@ -258,6 +297,7 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now) | ||||
|                         free(server->tcp_buffer); | ||||
|               server->tcp_buffer = NULL; | ||||
|               server->tcp_lenbuf_pos = 0; | ||||
|               server->tcp_buffer_pos = 0; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @@ -268,7 +308,8 @@ static void read_udp_packets(ares_channel channel, fd_set *read_fds, | ||||
|                              time_t now) | ||||
| { | ||||
|   struct server_state *server; | ||||
|   int i, count; | ||||
|   int i; | ||||
|   ssize_t count; | ||||
|   unsigned char buf[PACKETSZ + 1]; | ||||
|  | ||||
|   for (i = 0; i < channel->nservers; i++) | ||||
| @@ -280,11 +321,13 @@ static void read_udp_packets(ares_channel channel, fd_set *read_fds, | ||||
|           !FD_ISSET(server->udp_socket, read_fds)) | ||||
|         continue; | ||||
|  | ||||
|       count = recv(server->udp_socket, buf, sizeof(buf), 0); | ||||
|       if (count <= 0) | ||||
|       count = sread(server->udp_socket, buf, sizeof(buf)); | ||||
|       if (count == -1 && try_again(GET_ERRNO())) | ||||
|         continue; | ||||
|       else if (count <= 0) | ||||
|         handle_error(channel, i, now); | ||||
|  | ||||
|       process_answer(channel, buf, count, i, 0, now); | ||||
|       process_answer(channel, buf, (int)count, i, 0, now); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -378,7 +421,7 @@ static void handle_error(ares_channel channel, int whichserver, time_t now) | ||||
|   struct query *query, *next; | ||||
|  | ||||
|   /* Reset communications with this server. */ | ||||
|   ares__close_sockets(&channel->servers[whichserver]); | ||||
|   ares__close_sockets(channel, &channel->servers[whichserver]); | ||||
|  | ||||
|   /* Tell all queries talking to this server to move on and not try | ||||
|    * this server again. | ||||
| @@ -450,7 +493,10 @@ void ares__send_query(ares_channel channel, struct query *query, time_t now) | ||||
|       if (server->qtail) | ||||
|         server->qtail->next = sendreq; | ||||
|       else | ||||
|         server->qhead = sendreq; | ||||
|         { | ||||
|           SOCK_STATE_CALLBACK(channel, server->tcp_socket, 1, 1); | ||||
|           server->qhead = sendreq; | ||||
|         } | ||||
|       server->qtail = sendreq; | ||||
|       query->timeout = 0; | ||||
|     } | ||||
| @@ -465,8 +511,9 @@ void ares__send_query(ares_channel channel, struct query *query, time_t now) | ||||
|               return; | ||||
|             } | ||||
|         } | ||||
|       if (send(server->udp_socket, query->qbuf, query->qlen, 0) == -1) | ||||
|       if (swrite(server->udp_socket, query->qbuf, query->qlen) == -1) | ||||
|         { | ||||
|           /* FIXME: Handle EAGAIN here since it likely can happen. */ | ||||
|           query->skip_server[query->server] = 1; | ||||
|           next_server(channel, query, now); | ||||
|           return; | ||||
| @@ -572,6 +619,7 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   SOCK_STATE_CALLBACK(channel, s, 1, 0); | ||||
|   server->tcp_buffer_pos = 0; | ||||
|   server->tcp_socket = s; | ||||
|   return 0; | ||||
| @@ -601,6 +649,8 @@ static int open_udp_socket(ares_channel channel, struct server_state *server) | ||||
|       return -1; | ||||
|     } | ||||
|  | ||||
|   SOCK_STATE_CALLBACK(channel, s, 1, 0); | ||||
|  | ||||
|   server->udp_socket = s; | ||||
|   return 0; | ||||
| } | ||||
| @@ -711,7 +761,7 @@ static struct query *end_query (ares_channel channel, struct query *query, int s | ||||
|   if (!channel->queries && !(channel->flags & ARES_FLAG_STAYOPEN)) | ||||
|     { | ||||
|       for (i = 0; i < channel->nservers; i++) | ||||
|         ares__close_sockets(&channel->servers[i]); | ||||
|         ares__close_sockets(channel, &channel->servers[i]); | ||||
|     } | ||||
|   return (next); | ||||
| } | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
| @@ -237,15 +239,15 @@ static int single_domain(ares_channel channel, const char *name, char **s) | ||||
|                      == ARES_SUCCESS) | ||||
|                 { | ||||
|                   if (strncasecmp(line, name, len) != 0 || | ||||
|                       !isspace((unsigned char)line[len])) | ||||
|                       !ISSPACE(line[len])) | ||||
|                     continue; | ||||
|                   p = line + len; | ||||
|                   while (isspace((unsigned char)*p)) | ||||
|                   while (ISSPACE(*p)) | ||||
|                     p++; | ||||
|                   if (*p) | ||||
|                     { | ||||
|                       q = p + 1; | ||||
|                       while (*q && !isspace((unsigned char)*q)) | ||||
|                       while (*q && !ISSPACE(*q)) | ||||
|                         q++; | ||||
|                       *s = malloc(q - p + 1); | ||||
|                       if (*s) | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright 1998 by the Massachusetts Institute of Technology. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this | ||||
|   | ||||
| @@ -5,13 +5,21 @@ | ||||
|  | ||||
| #define ARES_VERSION_MAJOR 1 | ||||
| #define ARES_VERSION_MINOR 3 | ||||
| #define ARES_VERSION_PATCH 0 | ||||
| #define ARES_VERSION_PATCH 3 | ||||
| #define ARES_VERSION ((ARES_VERSION_MAJOR<<16)|\ | ||||
|                        (ARES_VERSION_MINOR<<8)|\ | ||||
|                        (ARES_VERSION_PATCH)) | ||||
| #define ARES_VERSION_STR "1.3.0" | ||||
| #define ARES_VERSION_STR "1.3.3-CVS" | ||||
|  | ||||
| #ifdef  __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| const char *ares_version(int *version); | ||||
|  | ||||
| #ifdef  __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") | ||||
|  * Copyright (c) 1996,1999 by Internet Software Consortium. | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| #ifndef __ARES_BITNCMP_H | ||||
| #define __ARES_BITNCMP_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
| @@ -14,13 +17,10 @@ | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
|  | ||||
| #ifndef BITNCMP_H | ||||
| #define BITNCMP_H | ||||
|  | ||||
| #ifndef HAVE_BITNCMP | ||||
| int ares_bitncmp(const void *l, const void *r, int n); | ||||
| #else | ||||
| #define ares_bitncmp(x,y,z) bitncmp(x,y,z) | ||||
| #endif | ||||
|  | ||||
| #endif /* BITNCMP_H */ | ||||
| #endif /* __ARES_BITNCMP_H */ | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| ${LIBTOOLIZE:-libtoolize} --copy --automake --force | ||||
| ${ACLOCAL:-aclocal} | ||||
| ${ACLOCAL:-aclocal} $ACLOCAL_FLAGS | ||||
| ${AUTOHEADER:-autoheader} | ||||
| ${AUTOCONF:-autoconf} | ||||
| ${AUTOMAKE:-automake} --add-missing | ||||
|   | ||||
							
								
								
									
										184
									
								
								ares/config-win32.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										184
									
								
								ares/config-win32.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,184 @@ | ||||
| #ifndef __ARES_CONFIG_WIN32_H | ||||
| #define __ARES_CONFIG_WIN32_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* 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 | ||||
|  * 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/config-win32.h - Hand crafted config file for Windows    */ | ||||
| /* ================================================================ */ | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| /*                          HEADER FILES                            */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|  | ||||
| /* Define if you have the <getopt.h> header file.  */ | ||||
| #if defined(__MINGW32__) | ||||
| #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 <unistd.h> header file.  */ | ||||
| #if defined(__MINGW32__) || defined(__WATCOMC__) || defined(__LCC__) || \ | ||||
|     defined(__POCC__) | ||||
| #define HAVE_UNISTD_H 1 | ||||
| #endif | ||||
|  | ||||
| /* Define if you have the <windows.h> header file.  */ | ||||
| #define HAVE_WINDOWS_H 1 | ||||
|  | ||||
| /* Define if you have the <winsock.h> header file.  */ | ||||
| #define HAVE_WINSOCK_H 1 | ||||
|  | ||||
| /* Define if you have the <winsock2.h> header file.  */ | ||||
| #define HAVE_WINSOCK2_H 1 | ||||
|  | ||||
| /* Define if you have the <ws2tcpip.h> header file.  */ | ||||
| #define HAVE_WS2TCPIP_H 1 | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| /*                        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 | ||||
|  | ||||
| /* Define if you can safely include both <sys/time.h> and <time.h>.  */ | ||||
| /* #define TIME_WITH_SYS_TIME 1 */ | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| /*                             FUNCTIONS                            */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|  | ||||
| /* Define if you have the ioctlsocket function.  */ | ||||
| #define HAVE_IOCTLSOCKET 1 | ||||
|  | ||||
| /* Define if you have the recv function. */ | ||||
| #define HAVE_RECV 1 | ||||
|  | ||||
| /* Define to the type of arg 1 for recv. */ | ||||
| #define RECV_TYPE_ARG1 SOCKET | ||||
|  | ||||
| /* Define to the type of arg 2 for recv. */ | ||||
| #define RECV_TYPE_ARG2 char * | ||||
|  | ||||
| /* Define to the type of arg 3 for recv. */ | ||||
| #define RECV_TYPE_ARG3 int | ||||
|  | ||||
| /* Define to the type of arg 4 for recv. */ | ||||
| #define RECV_TYPE_ARG4 int | ||||
|  | ||||
| /* Define to the function return type for recv. */ | ||||
| #define RECV_TYPE_RETV int | ||||
|  | ||||
| /* Define if you have the send function. */ | ||||
| #define HAVE_SEND 1 | ||||
|  | ||||
| /* Define to the type of arg 1 for send. */ | ||||
| #define SEND_TYPE_ARG1 SOCKET | ||||
|  | ||||
| /* Define to the type qualifier of arg 2 for send. */ | ||||
| #define SEND_QUAL_ARG2 const | ||||
|  | ||||
| /* Define to the type of arg 2 for send. */ | ||||
| #define SEND_TYPE_ARG2 char * | ||||
|  | ||||
| /* Define to the type of arg 3 for send. */ | ||||
| #define SEND_TYPE_ARG3 int | ||||
|  | ||||
| /* Define to the type of arg 4 for send. */ | ||||
| #define SEND_TYPE_ARG4 int | ||||
|  | ||||
| /* 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                          */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|  | ||||
| /* Define this if you have struct addrinfo */ | ||||
| #define HAVE_STRUCT_ADDRINFO 1 | ||||
|  | ||||
| /* Define this if you have struct sockaddr_storage */ | ||||
| #define HAVE_STRUCT_SOCKADDR_STORAGE 1 | ||||
|  | ||||
| /* Define this if you have struct timeval */ | ||||
| #define HAVE_STRUCT_TIMEVAL 1 | ||||
|  | ||||
| /* ---------------------------------------------------------------- */ | ||||
| /*                         IPV6 COMPATIBILITY                       */ | ||||
| /* ---------------------------------------------------------------- */ | ||||
|  | ||||
| /* Define this if you have address family AF_INET6 */ | ||||
| #define HAVE_AF_INET6 1 | ||||
|  | ||||
| /* Define this if you have protocol family PF_INET6 */ | ||||
| #define HAVE_PF_INET6 1 | ||||
|  | ||||
| /* Define this if you have struct in6_addr */ | ||||
| #define HAVE_STRUCT_IN6_ADDR 1 | ||||
|  | ||||
| /* Define this if you have struct sockaddr_in6 */ | ||||
| #define HAVE_STRUCT_SOCKADDR_IN6 1 | ||||
|  | ||||
| /* Define this if you have sockaddr_in6 with scopeid */ | ||||
| #define HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID 1 | ||||
|  | ||||
|  | ||||
| #endif  /* __ARES_CONFIG_WIN32_H */ | ||||
| @@ -1,5 +1,8 @@ | ||||
|  | ||||
| dnl Process this file with autoconf to produce a configure script. | ||||
| AC_PREREQ(2.57) | ||||
| AC_INIT(ares_init.c) | ||||
| AC_CONFIG_SRCDIR([ares_ipv6.h]) | ||||
| AM_CONFIG_HEADER(config.h) | ||||
| AM_MAINTAINER_MODE | ||||
| AM_INIT_AUTOMAKE(c-ares, CVS) | ||||
| @@ -13,12 +16,7 @@ solaris*) | ||||
| 	;; | ||||
| esac | ||||
|  | ||||
| # check for ssize_t | ||||
| AC_CHECK_TYPE(ssize_t, , | ||||
|    AC_DEFINE(ssize_t, int, [the signed version of size_t])) | ||||
|  | ||||
| AC_SEARCH_LIBS(gethostbyname, nsl) | ||||
| AC_SEARCH_LIBS(socket, socket) | ||||
| AC_LIBTOOL_WIN32_DLL | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl Option to switch on debug options. This makes an assumption that | ||||
| @@ -38,9 +36,6 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | ||||
|     dnl when doing the debug stuff, use static library only | ||||
|     AC_DISABLE_SHARED | ||||
|  | ||||
|     dnl Checks for standard header files, to make memdebug.h inclusions bettter | ||||
|     AC_HEADER_STDC | ||||
|  | ||||
|     dnl the entire --enable-debug is a hack that lives and runs on top of | ||||
|     dnl libcurl stuff so this BUILDING_LIBCURL is not THAT much uglier | ||||
|     AC_DEFINE(BUILDING_LIBCURL, 1, [when building as static part of libcurl]) | ||||
| @@ -48,6 +43,15 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | ||||
|     CPPFLAGS="$CPPFLAGS -DCURLDEBUG -I$srcdir/../include" | ||||
|     CFLAGS="$CFLAGS -g"  | ||||
|  | ||||
|     dnl check for how to do large files, needed to get the curl_off_t check | ||||
|     dnl done right | ||||
|     AC_SYS_LARGEFILE | ||||
|  | ||||
|     AC_CHECK_SIZEOF(curl_off_t, ,[ | ||||
| #include <stdio.h> | ||||
| #include "$srcdir/../include/curl/curl.h" | ||||
|     ]) | ||||
|  | ||||
|     dnl set compiler "debug" options to become more picky, and remove | ||||
|     dnl optimize options from CFLAGS | ||||
|     CURL_CC_DEBUG_OPTS | ||||
| @@ -57,8 +61,164 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl libtool setup | ||||
| CARES_CLEAR_LIBTOOL_TAGS | ||||
| AC_PROG_LIBTOOL | ||||
|  | ||||
| AC_MSG_CHECKING([if we need -no-undefined]) | ||||
| case $host in | ||||
|   *-*-cygwin | *-*-mingw* | *-*-pw32*) | ||||
|     need_no_undefined=yes | ||||
|     ;; | ||||
|   *) | ||||
|     need_no_undefined=no | ||||
|     ;; | ||||
| esac | ||||
| AC_MSG_RESULT($need_no_undefined) | ||||
| AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Checks for libraries. | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| dnl gethostbyname without lib or in the nsl lib? | ||||
| AC_CHECK_FUNC(gethostbyname, | ||||
|               [HAVE_GETHOSTBYNAME="1" | ||||
|               ], | ||||
|               [ AC_CHECK_LIB(nsl, gethostbyname, | ||||
|                              [HAVE_GETHOSTBYNAME="1" | ||||
|                              LIBS="$LIBS -lnsl" | ||||
|                              ]) | ||||
|               ]) | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl gethostbyname in the socket lib? | ||||
|   AC_CHECK_LIB(socket, gethostbyname, | ||||
|                [HAVE_GETHOSTBYNAME="1" | ||||
|                LIBS="$LIBS -lsocket" | ||||
|                ]) | ||||
| fi | ||||
|  | ||||
| dnl At least one system has been identified to require BOTH nsl and socket | ||||
| dnl libs at the same time to link properly. | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   AC_MSG_CHECKING([for gethostbyname with both nsl and socket libs]) | ||||
|   my_ac_save_LIBS=$LIBS | ||||
|   LIBS="-lnsl -lsocket $LIBS" | ||||
|   AC_TRY_LINK( , | ||||
|              [gethostbyname();], | ||||
|              [ dnl found it! | ||||
|              HAVE_GETHOSTBYNAME="1" | ||||
|              AC_MSG_RESULT([yes])], | ||||
|              [ dnl failed! | ||||
|              AC_MSG_RESULT([no]) | ||||
|              dnl restore LIBS | ||||
|              LIBS=$my_ac_save_LIBS] | ||||
|              ) | ||||
| fi | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl This is for Msys/Mingw | ||||
|   AC_MSG_CHECKING([for gethostbyname in ws2_32]) | ||||
|   my_ac_save_LIBS=$LIBS | ||||
|   LIBS="-lws2_32 $LIBS" | ||||
|   AC_TRY_LINK([#include <winsock2.h>], | ||||
|                [gethostbyname("www.dummysite.com");], | ||||
|                [ dnl worked! | ||||
|                ws2="yes" | ||||
|                AC_MSG_RESULT([yes]) | ||||
|                HAVE_GETHOSTBYNAME="1"], | ||||
|                [ dnl failed, restore LIBS | ||||
|                LIBS=$my_ac_save_LIBS | ||||
|                AC_MSG_RESULT(no)] | ||||
|              ) | ||||
| fi | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl This is for eCos with a stubbed DNS implementation | ||||
|   AC_MSG_CHECKING([for gethostbyname for eCos]) | ||||
|   AC_TRY_LINK([ | ||||
| #include <stdio.h> | ||||
| #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 gethostbyname in the net lib - for BeOS | ||||
|   AC_CHECK_LIB(net, gethostbyname, | ||||
|                [HAVE_GETHOSTBYNAME="1" | ||||
|                LIBS="$LIBS -lnet" | ||||
|                ]) | ||||
| fi | ||||
|  | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" = "1"; then | ||||
|   AC_DEFINE(HAVE_GETHOSTBYNAME, 1, [If you have gethostbyname]) | ||||
| else | ||||
|   AC_MSG_ERROR([couldn't find libraries for gethostbyname()]) | ||||
| fi | ||||
|  | ||||
| dnl resolve lib? | ||||
| AC_CHECK_FUNC(strcasecmp, , [ AC_CHECK_LIB(resolve, strcasecmp) ]) | ||||
|  | ||||
| if test "$ac_cv_lib_resolve_strcasecmp" = "$ac_cv_func_strcasecmp"; then | ||||
|   AC_CHECK_LIB(resolve, strcasecmp, | ||||
|               [LIBS="-lresolve $LIBS"], | ||||
|                , | ||||
|                -lnsl) | ||||
| 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) ]) | ||||
|  | ||||
| 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" | ||||
|        AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(no) | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Back to "normal" configuring | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| dnl Checks for header files. | ||||
| AC_HEADER_STDC | ||||
|  | ||||
| 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  | ||||
| dnl could be done later using AC_CHECK_HEADER or AC_CHECK_HEADERS for | ||||
| dnl this specific header files. And do them before its results are used. | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| CURL_CHECK_HEADER_WINDOWS | ||||
| CURL_CHECK_HEADER_WINSOCK | ||||
| CURL_CHECK_HEADER_WINSOCK2 | ||||
| CURL_CHECK_HEADER_WS2TCPIP | ||||
|  | ||||
| CURL_CHECK_HEADER_MALLOC | ||||
|  | ||||
| dnl check for a few basic system headers we need | ||||
| AC_CHECK_HEADERS( | ||||
|        sys/types.h \ | ||||
| @@ -67,16 +227,23 @@ AC_CHECK_HEADERS( | ||||
|        sys/socket.h \ | ||||
|        sys/ioctl.h \ | ||||
|        netdb.h \ | ||||
|        winsock.h \ | ||||
|        netinet/in.h \ | ||||
|        net/if.h \ | ||||
|        arpa/nameser.h \ | ||||
|        arpa/nameser_compat.h \ | ||||
|        arpa/inet.h, , , | ||||
|        arpa/inet.h, | ||||
| dnl to do if not found | ||||
| [], | ||||
| dnl to do if found | ||||
| [], | ||||
| dnl default includes | ||||
| [ | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_TIME_H | ||||
| #include <sys/time.h> | ||||
| #endif | ||||
| dnl We do this default-include simply to make sure that the nameser_compat.h | ||||
| dnl header *REALLY* can be include after the new nameser.h. It seems AIX 5.1 | ||||
| dnl (and others?) is not designed to allow this. | ||||
| @@ -88,39 +255,78 @@ dnl *Sigh* these are needed in order for net/if.h to get properly detected. | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| ] | ||||
|   ) | ||||
| ) | ||||
|  | ||||
| AC_CHECK_TYPE(socklen_t, , | ||||
|    AC_DEFINE(socklen_t, int, [the length of a socket address]),  | ||||
|    [ | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
|    ]) | ||||
| dnl Checks for typedefs, structures, and compiler characteristics. | ||||
| AC_C_CONST | ||||
| AC_TYPE_SIZE_T | ||||
| AC_HEADER_TIME | ||||
| CURL_CHECK_STRUCT_TIMEVAL | ||||
|  | ||||
| AC_CHECK_SIZEOF(size_t) | ||||
| AC_CHECK_SIZEOF(long) | ||||
| AC_CHECK_SIZEOF(time_t) | ||||
|  | ||||
| AC_CHECK_TYPE(long long, | ||||
|    [AC_DEFINE(HAVE_LONGLONG, 1, [if your compiler supports long long])] | ||||
|    longlong="yes"   | ||||
| ) | ||||
|  | ||||
| if test "xyes" = "x$longlong"; then | ||||
|   AC_MSG_CHECKING([if numberLL works]) | ||||
|   AC_COMPILE_IFELSE([long long val = 1000LL;], | ||||
|    [AC_DEFINE(HAVE_LL, 1, [if your compiler supports LL])] | ||||
|    AC_MSG_RESULT(yes), | ||||
|    AC_MSG_RESULT(no) | ||||
|   ) | ||||
| fi | ||||
|  | ||||
|  | ||||
| # check for ssize_t | ||||
| AC_CHECK_TYPE(ssize_t, , | ||||
|    AC_DEFINE(ssize_t, int, [the signed version of size_t])) | ||||
|  | ||||
| # Check for socklen_t or equivalent | ||||
| CURL_CHECK_TYPE_SOCKLEN_T | ||||
|  | ||||
| TYPE_IN_ADDR_T | ||||
|  | ||||
| TYPE_SOCKADDR_STORAGE | ||||
|  | ||||
| TYPE_SIG_ATOMIC_T | ||||
|  | ||||
| AC_TYPE_SIGNAL | ||||
|  | ||||
| CURL_CHECK_FUNC_RECV | ||||
|  | ||||
| CURL_CHECK_FUNC_SEND | ||||
|  | ||||
| CURL_CHECK_MSG_NOSIGNAL | ||||
|  | ||||
| dnl check for AF_INET6 | ||||
| CARES_CHECK_CONSTANT( | ||||
|   [ | ||||
| #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_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
|  | ||||
|   ], [PF_INET6],  | ||||
|      AC_DEFINE_UNQUOTED(HAVE_PF_INET6,1,[Define to 1 if you have PF_INET6.]) | ||||
| ) | ||||
| @@ -128,16 +334,23 @@ CARES_CHECK_CONSTANT( | ||||
| dnl check for PF_INET6 | ||||
| CARES_CHECK_CONSTANT( | ||||
|   [ | ||||
| #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_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
|  | ||||
|   ], [AF_INET6],  | ||||
|      AC_DEFINE_UNQUOTED(HAVE_AF_INET6,1,[Define to 1 if you have AF_INET6.]) | ||||
| ) | ||||
| @@ -146,14 +359,25 @@ CARES_CHECK_CONSTANT( | ||||
| dnl check for the in6_addr structure | ||||
| CARES_CHECK_STRUCT( | ||||
|   [ | ||||
| #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> | ||||
| #ifdef HAVE_WS2TCPIP_H | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #endif | ||||
|   ], [in6_addr],  | ||||
|      AC_DEFINE_UNQUOTED(HAVE_STRUCT_IN6_ADDR,1,[Define to 1 if you have struct in6_addr.]) | ||||
| @@ -162,14 +386,25 @@ CARES_CHECK_STRUCT( | ||||
| dnl check for the sockaddr_in6 structure | ||||
| CARES_CHECK_STRUCT( | ||||
|   [ | ||||
| #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> | ||||
| #ifdef HAVE_WS2TCPIP_H | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #endif | ||||
|   ], [sockaddr_in6],  | ||||
|      AC_DEFINE_UNQUOTED(HAVE_STRUCT_SOCKADDR_IN6,1, | ||||
| @@ -181,14 +416,25 @@ AC_CHECK_MEMBER(struct sockaddr_in6.sin6_scope_id, | ||||
|       [Define to 1 if your struct sockaddr_in6 has sin6_scope_id.]) | ||||
|    , , | ||||
|   [ | ||||
| #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> | ||||
| #ifdef HAVE_WS2TCPIP_H | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #endif | ||||
|   ]) | ||||
|  | ||||
| @@ -197,12 +443,22 @@ AC_CHECK_MEMBER(struct addrinfo.ai_flags, | ||||
|      AC_DEFINE_UNQUOTED(HAVE_STRUCT_ADDRINFO,1, | ||||
|        [Define to 1 if you have struct addrinfo.]),, | ||||
|   [ | ||||
| #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> | ||||
| #ifdef HAVE_WS2TCPIP_H | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| @@ -211,10 +467,30 @@ AC_CHECK_MEMBER(struct addrinfo.ai_flags, | ||||
| #endif | ||||
| #ifdef HAVE_NETDB_H | ||||
| #include <netdb.h> | ||||
| #endif | ||||
| #endif | ||||
|   ] | ||||
| ) | ||||
|  | ||||
|  | ||||
| AC_CHECK_FUNCS( bitncmp \ | ||||
|                 if_indextoname, | ||||
| dnl if found | ||||
| [], | ||||
| dnl if not found, $ac_func is the name we check for | ||||
| func="$ac_func" | ||||
| AC_MSG_CHECKING([deeper for $func]) | ||||
| AC_TRY_LINK( [], | ||||
|              [ $func ();], | ||||
|              AC_MSG_RESULT(yes!) | ||||
|              eval "ac_cv_func_$func=yes" | ||||
|              def=`echo "HAVE_$func" | tr 'a-z' 'A-Z'` | ||||
|              AC_DEFINE_UNQUOTED($def, 1, [If you have $func]), | ||||
|              AC_MSG_RESULT(but still no) | ||||
|              ) | ||||
| ) | ||||
|  | ||||
|  | ||||
| dnl check for inet_pton | ||||
| AC_CHECK_FUNCS(inet_pton) | ||||
| dnl Some systems have it, but not IPv6 | ||||
| @@ -228,9 +504,6 @@ AC_TRY_RUN( | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| @@ -260,9 +533,6 @@ AC_TRY_RUN( | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| @@ -294,9 +564,6 @@ AC_TRY_RUN( | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| @@ -312,48 +579,84 @@ int main() | ||||
|   } | ||||
|   ], [ | ||||
|        AC_MSG_RESULT(yes) | ||||
|        AC_DEFINE_UNQUOTED(HAVE_INET_NTOP_IPV6,1,[Define to 1 if inet_ntop supports IPv6.]) | ||||
|        AC_DEFINE_UNQUOTED(HAVE_INET_NTOP_IPV6,1, | ||||
|           [Define to 1 if inet_ntop supports IPv6.]) | ||||
|      ], AC_MSG_RESULT(no),AC_MSG_RESULT(no)) | ||||
| fi | ||||
|  | ||||
| AC_CHECK_SIZEOF(struct in6_addr, , | ||||
| [ | ||||
| #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> | ||||
| #ifdef HAVE_WS2TCPIP_H | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #endif | ||||
| ] | ||||
| ) | ||||
|  | ||||
| AC_CHECK_SIZEOF(struct in_addr, , | ||||
| [ | ||||
| #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> | ||||
| #ifdef HAVE_WS2TCPIP_H | ||||
| #include <ws2tcpip.h> | ||||
| #endif | ||||
| #endif | ||||
| #else | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #endif | ||||
| ] | ||||
| ) | ||||
|  | ||||
| AC_CHECK_FUNCS([bitncmp if_indextoname]) | ||||
|  | ||||
| dnl God bless non-standardized functions! We need to see which getservbyport_r variant is available | ||||
| dnl Check if the getnameinfo function is available | ||||
| dnl and get the types of five of its arguments. | ||||
| CURL_CHECK_FUNC_GETNAMEINFO | ||||
|  | ||||
|  | ||||
| dnl God bless non-standardized functions! We need to see which getservbyport_r | ||||
| dnl variant is available | ||||
| CARES_CHECK_GETSERVBYPORT_R | ||||
|  | ||||
| CURL_CHECK_NONBLOCKING_SOCKET | ||||
|  | ||||
| AC_C_BIGENDIAN( | ||||
|     [AC_DEFINE(ARES_BIG_ENDIAN, 1, | ||||
|       [define this if ares is built for a big endian system])], | ||||
|     , | ||||
|     [AC_MSG_WARN([couldn't figure out endianess, assuming little endian!])] | ||||
| ) | ||||
|  | ||||
| AC_OUTPUT(Makefile) | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") | ||||
|  * Copyright (c) 1996,1999 by Internet Software Consortium. | ||||
| @@ -77,14 +79,13 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|  | ||||
|   ch = *src++; | ||||
|   if (ch == '0' && (src[0] == 'x' || src[0] == 'X') | ||||
|       && isascii((unsigned char)(src[1])) | ||||
|       && isxdigit((unsigned char)(src[1]))) { | ||||
|       && ISXDIGIT(src[1])) { | ||||
|     /* Hexadecimal: Eat nybble string. */ | ||||
|     if (size <= 0U) | ||||
|       goto emsgsize; | ||||
|     dirty = 0; | ||||
|     src++;  /* skip x or X. */ | ||||
|     while ((ch = *src++) != '\0' && isascii(ch) && isxdigit(ch)) { | ||||
|     while ((ch = *src++) != '\0' && ISXDIGIT(ch)) { | ||||
|       if (isupper(ch)) | ||||
|         ch = tolower(ch); | ||||
|       n = (int)(strchr(xdigits, ch) - xdigits); | ||||
| @@ -104,7 +105,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|         goto emsgsize; | ||||
|       *dst++ = (unsigned char) (tmp << 4); | ||||
|     } | ||||
|   } else if (isascii(ch) && isdigit(ch)) { | ||||
|   } else if (ISDIGIT(ch)) { | ||||
|     /* Decimal: eat dotted digit string. */ | ||||
|     for (;;) { | ||||
|       tmp = 0; | ||||
| @@ -115,7 +116,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|         if (tmp > 255) | ||||
|           goto enoent; | ||||
|       } while ((ch = *src++) != '\0' && | ||||
|                isascii(ch) && isdigit(ch)); | ||||
|                ISDIGIT(ch)); | ||||
|       if (size-- <= 0U) | ||||
|         goto emsgsize; | ||||
|       *dst++ = (unsigned char) tmp; | ||||
| @@ -124,15 +125,15 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|       if (ch != '.') | ||||
|         goto enoent; | ||||
|       ch = *src++; | ||||
|       if (!isascii(ch) || !isdigit(ch)) | ||||
|       if (!ISDIGIT(ch)) | ||||
|         goto enoent; | ||||
|     } | ||||
|   } else | ||||
|     goto enoent; | ||||
|  | ||||
|   bits = -1; | ||||
|   if (ch == '/' && isascii((unsigned char)(src[0])) && | ||||
|       isdigit((unsigned char)(src[0])) && dst > odst) { | ||||
|   if (ch == '/' && | ||||
|       ISDIGIT(src[0]) && dst > odst) { | ||||
|     /* CIDR width specifier.  Nothing can follow it. */ | ||||
|     ch = *src++;    /* Skip over the /. */ | ||||
|     bits = 0; | ||||
| @@ -140,7 +141,7 @@ inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
|       n = (int)(strchr(digits, ch) - digits); | ||||
|       bits *= 10; | ||||
|       bits += n; | ||||
|     } while ((ch = *src++) != '\0' && isascii(ch) && isdigit(ch)); | ||||
|     } while ((ch = *src++) != '\0' && ISDIGIT(ch)); | ||||
|     if (ch != '\0') | ||||
|       goto enoent; | ||||
|     if (bits > 32) | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| #ifndef __ARES_INET_NET_PTON_H | ||||
| #define __ARES_INET_NET_PTON_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
| @@ -14,9 +17,6 @@ | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
|  | ||||
| #ifndef INET_NET_PTON_H | ||||
| #define INET_NET_PTON_H | ||||
|  | ||||
| #if defined(HAVE_INET_PTON) && defined(HAVE_INET_PTON_IPV6) | ||||
| #define ares_inet_pton(x,y,z) inet_pton(x,y,z) | ||||
| #else | ||||
| @@ -28,4 +28,4 @@ int ares_inet_pton(int af, const char *src, void *dst); | ||||
| int ares_inet_net_pton(int af, const char *src, void *dst, size_t size); | ||||
| #endif | ||||
|  | ||||
| #endif /* INET_NET_PTON_H */ | ||||
| #endif /* __ARES_INET_NET_PTON_H */ | ||||
|   | ||||
							
								
								
									
										240
									
								
								ares/inet_ntop.c
									
									
									
									
									
								
							
							
						
						
									
										240
									
								
								ares/inet_ntop.c
									
									
									
									
									
								
							| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (c) 1996 by Internet Software Consortium. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
| @@ -63,144 +65,164 @@ static const char *inet_ntop6(const unsigned char *src, char *dst, size_t size); | ||||
|  | ||||
| /* char * | ||||
|  * inet_ntop(af, src, dst, size) | ||||
|  *	convert a network format address to presentation format. | ||||
|  *     convert a network format address to presentation format. | ||||
|  * return: | ||||
|  *	pointer to presentation format address (`dst'), or NULL (see errno). | ||||
|  *     pointer to presentation format address (`dst'), or NULL (see errno). | ||||
|  * author: | ||||
|  *	Paul Vixie, 1996. | ||||
|  *     Paul Vixie, 1996. | ||||
|  */ | ||||
| const char * | ||||
| ares_inet_ntop(int af, const void *src, char *dst, size_t size) | ||||
| { | ||||
|  | ||||
| 	switch (af) { | ||||
| 	case AF_INET: | ||||
| 		return (inet_ntop4(src, dst, size)); | ||||
| 	case AF_INET6: | ||||
| 		return (inet_ntop6(src, dst, size)); | ||||
| 	default: | ||||
| 		errno = EAFNOSUPPORT; | ||||
| 		return (NULL); | ||||
| 	} | ||||
| 	/* NOTREACHED */ | ||||
|   switch (af) | ||||
|     { | ||||
|     case AF_INET: | ||||
|       return (inet_ntop4(src, dst, size)); | ||||
|     case AF_INET6: | ||||
|       return (inet_ntop6(src, dst, size)); | ||||
|     default: | ||||
|       errno = EAFNOSUPPORT; | ||||
|       return (NULL); | ||||
|     } | ||||
|   /* NOTREACHED */ | ||||
| } | ||||
|  | ||||
| /* const char * | ||||
|  * inet_ntop4(src, dst, size) | ||||
|  *	format an IPv4 address, more or less like inet_ntoa() | ||||
|  *     format an IPv4 address, more or less like inet_ntoa() | ||||
|  * return: | ||||
|  *	`dst' (as a const) | ||||
|  *     `dst' (as a const) | ||||
|  * notes: | ||||
|  *	(1) uses no statics | ||||
|  *	(2) takes a unsigned char* not an in_addr as input | ||||
|  *     (1) uses no statics | ||||
|  *     (2) takes a unsigned char* not an in_addr as input | ||||
|  * author: | ||||
|  *	Paul Vixie, 1996. | ||||
|  *     Paul Vixie, 1996. | ||||
|  */ | ||||
| static const char * | ||||
| inet_ntop4(const unsigned char *src, char *dst, size_t size) | ||||
| { | ||||
| 	static const char fmt[] = "%u.%u.%u.%u"; | ||||
| 	char tmp[sizeof "255.255.255.255"]; | ||||
|   static const char fmt[] = "%u.%u.%u.%u"; | ||||
|   char tmp[sizeof "255.255.255.255"]; | ||||
|  | ||||
| 	if (SPRINTF((tmp, fmt, src[0], src[1], src[2], src[3])) > size) { | ||||
| 		errno = ENOSPC; | ||||
| 		return (NULL); | ||||
| 	} | ||||
| 	strcpy(dst, tmp); | ||||
| 	return (dst); | ||||
|   if (SPRINTF((tmp, fmt, src[0], src[1], src[2], src[3])) > size) | ||||
|     { | ||||
|       errno = ENOSPC; | ||||
|       return (NULL); | ||||
|     } | ||||
|     strcpy(dst, tmp); | ||||
|     return (dst); | ||||
| } | ||||
|  | ||||
| /* const char * | ||||
|  * inet_ntop6(src, dst, size) | ||||
|  *	convert IPv6 binary address into presentation (printable) format | ||||
|  *    convert IPv6 binary address into presentation (printable) format | ||||
|  * author: | ||||
|  *	Paul Vixie, 1996. | ||||
|  *    Paul Vixie, 1996. | ||||
|  */ | ||||
| static const char * | ||||
| inet_ntop6(const unsigned char *src, char *dst, size_t size) | ||||
| { | ||||
| 	/* | ||||
| 	 * Note that int32_t and int16_t need only be "at least" large enough | ||||
| 	 * to contain a value of the specified size.  On some systems, like | ||||
| 	 * Crays, there is no such thing as an integer variable with 16 bits. | ||||
| 	 * Keep this in mind if you think this function should have been coded | ||||
| 	 * to use pointer overlays.  All the world's not a VAX. | ||||
| 	 */ | ||||
| 	char tmp[sizeof "ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255"], *tp; | ||||
| 	struct { int base, len; } best, cur; | ||||
| 	unsigned int words[NS_IN6ADDRSZ / NS_INT16SZ]; | ||||
| 	int i; | ||||
|   /* | ||||
|    * Note that int32_t and int16_t need only be "at least" large enough | ||||
|    * to contain a value of the specified size.  On some systems, like | ||||
|    * Crays, there is no such thing as an integer variable with 16 bits. | ||||
|    * Keep this in mind if you think this function should have been coded | ||||
|    * to use pointer overlays.  All the world's not a VAX. | ||||
|    */ | ||||
|   char tmp[sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255")]; | ||||
|   char *tp; | ||||
|   struct { | ||||
|     long base; | ||||
|     long len; | ||||
|   } best, cur; | ||||
|   unsigned long words[NS_IN6ADDRSZ / NS_INT16SZ]; | ||||
|   int i; | ||||
|  | ||||
| 	/* | ||||
| 	 * Preprocess: | ||||
| 	 *	Copy the input (bytewise) array into a wordwise array. | ||||
| 	 *	Find the longest run of 0x00's in src[] for :: shorthanding. | ||||
| 	 */ | ||||
| 	memset(words, '\0', sizeof words); | ||||
| 	for (i = 0; i < NS_IN6ADDRSZ; i++) | ||||
| 		words[i / 2] |= (src[i] << ((1 - (i % 2)) << 3)); | ||||
| 	best.base = -1; | ||||
| 	cur.base = -1; | ||||
| 	for (i = 0; i < (NS_IN6ADDRSZ / NS_INT16SZ); i++) { | ||||
| 		if (words[i] == 0) { | ||||
| 			if (cur.base == -1) | ||||
| 				cur.base = i, cur.len = 1; | ||||
| 			else | ||||
| 				cur.len++; | ||||
| 		} else { | ||||
| 			if (cur.base != -1) { | ||||
| 				if (best.base == -1 || cur.len > best.len) | ||||
| 					best = cur; | ||||
| 				cur.base = -1; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	if (cur.base != -1) { | ||||
| 		if (best.base == -1 || cur.len > best.len) | ||||
| 			best = cur; | ||||
| 	} | ||||
| 	if (best.base != -1 && best.len < 2) | ||||
| 		best.base = -1; | ||||
|   /* | ||||
|    * Preprocess: | ||||
|    *  Copy the input (bytewise) array into a wordwise array. | ||||
|    *  Find the longest run of 0x00's in src[] for :: shorthanding. | ||||
|    */ | ||||
|   memset(words, '\0', sizeof(words)); | ||||
|   for (i = 0; i < NS_IN6ADDRSZ; i++) | ||||
|       words[i / 2] |= (src[i] << ((1 - (i % 2)) << 3)); | ||||
|  | ||||
| 	/* | ||||
| 	 * Format the result. | ||||
| 	 */ | ||||
| 	tp = tmp; | ||||
| 	for (i = 0; i < (NS_IN6ADDRSZ / NS_INT16SZ); i++) { | ||||
| 		/* Are we inside the best run of 0x00's? */ | ||||
| 		if (best.base != -1 && i >= best.base && | ||||
| 		    i < (best.base + best.len)) { | ||||
| 			if (i == best.base) | ||||
| 				*tp++ = ':'; | ||||
| 			continue; | ||||
| 		} | ||||
| 		/* Are we following an initial run of 0x00s or any real hex? */ | ||||
| 		if (i != 0) | ||||
| 			*tp++ = ':'; | ||||
| 		/* Is this address an encapsulated IPv4? */ | ||||
| 		if (i == 6 && best.base == 0 && | ||||
| 		    (best.len == 6 || (best.len == 5 && words[5] == 0xffff))) { | ||||
| 			if (!inet_ntop4(src+12, tp, sizeof tmp - (tp - tmp))) | ||||
| 				return (NULL); | ||||
| 			tp += strlen(tp); | ||||
| 			break; | ||||
| 		} | ||||
| 		tp += SPRINTF((tp, "%x", words[i])); | ||||
| 	} | ||||
| 	/* Was it a trailing run of 0x00's? */ | ||||
| 	if (best.base != -1 && (best.base + best.len) == (NS_IN6ADDRSZ / NS_INT16SZ)) | ||||
| 		*tp++ = ':'; | ||||
| 	*tp++ = '\0'; | ||||
|   best.base = -1; | ||||
|   cur.base = -1; | ||||
|   best.len = 0; | ||||
|   cur.len = 0; | ||||
|  | ||||
| 	/* | ||||
| 	 * Check for overflow, copy, and we're done. | ||||
| 	 */ | ||||
| 	if ((size_t)(tp - tmp) > size) { | ||||
| 		errno = ENOSPC; | ||||
| 		return (NULL); | ||||
| 	} | ||||
| 	strcpy(dst, tmp); | ||||
| 	return (dst); | ||||
|   for (i = 0; i < (NS_IN6ADDRSZ / NS_INT16SZ); i++) | ||||
|     { | ||||
|       if (words[i] == 0) | ||||
|         { | ||||
|           if (cur.base == -1) | ||||
|             cur.base = i, cur.len = 1; | ||||
|           else | ||||
|             cur.len++; | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           if (cur.base != -1) | ||||
|             { | ||||
|               if (best.base == -1 || cur.len > best.len) | ||||
|                 best = cur; | ||||
|               cur.base = -1; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|   if (cur.base != -1) | ||||
|     { | ||||
|       if (best.base == -1 || cur.len > best.len) | ||||
|         best = cur; | ||||
|     } | ||||
|   if (best.base != -1 && best.len < 2) | ||||
|     best.base = -1; | ||||
|  | ||||
|   /* | ||||
|    * Format the result. | ||||
|    */ | ||||
|   tp = tmp; | ||||
|   for (i = 0; i < (NS_IN6ADDRSZ / NS_INT16SZ); i++) | ||||
|     { | ||||
|       /* Are we inside the best run of 0x00's? */ | ||||
|       if (best.base != -1 && i >= best.base && | ||||
|           i < (best.base + best.len)) | ||||
|         { | ||||
|           if (i == best.base) | ||||
|              *tp++ = ':'; | ||||
|           continue; | ||||
|         } | ||||
|       /* Are we following an initial run of 0x00s or any real hex? */ | ||||
|       if (i != 0) | ||||
|         *tp++ = ':'; | ||||
|       /* Is this address an encapsulated IPv4? */ | ||||
|       if (i == 6 && best.base == 0 && | ||||
|           (best.len == 6 || (best.len == 5 && words[5] == 0xffff))) | ||||
|         { | ||||
|           if (!inet_ntop4(src+12, tp, sizeof(tmp) - (tp - tmp))) | ||||
|             return (NULL); | ||||
|           tp += strlen(tp); | ||||
|           break; | ||||
|         } | ||||
|         tp += SPRINTF((tp, "%lx", words[i])); | ||||
|     } | ||||
|  | ||||
|   /* Was it a trailing run of 0x00's? */ | ||||
|   if (best.base != -1 && (best.base + best.len) == (NS_IN6ADDRSZ / NS_INT16SZ)) | ||||
|     *tp++ = ':'; | ||||
|   *tp++ = '\0'; | ||||
|  | ||||
|   /* | ||||
|    * Check for overflow, copy, and we're done. | ||||
|    */ | ||||
|   if ((size_t)(tp - tmp) > size) | ||||
|     { | ||||
|       errno = ENOSPC; | ||||
|       return (NULL); | ||||
|     } | ||||
|   strcpy(dst, tmp); | ||||
|   return (dst); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| #ifndef __ARES_INET_NTOP_H | ||||
| #define __ARES_INET_NTOP_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
| @@ -14,13 +17,10 @@ | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
|  | ||||
| #ifndef INET_NTOP_H | ||||
| #define INET_NTOP_H | ||||
|  | ||||
| #ifdef HAVE_INET_NTOP | ||||
| #if defined(HAVE_INET_NTOP) && defined(HAVE_INET_NTOP_IPV6) | ||||
| #define ares_inet_ntop(w,x,y,z) inet_ntop(w,x,y,z) | ||||
| #else | ||||
| const char *ares_inet_ntop(int af, const void *src, char *dst, size_t size); | ||||
| #endif | ||||
|  | ||||
| #endif /* INET_NET_NTOP_H */ | ||||
| #endif /* __ARES_INET_NTOP_H */ | ||||
|   | ||||
| @@ -1,3 +1,5 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| #ifndef ARES_NAMESER_H | ||||
| #define ARES_NAMESER_H | ||||
|  | ||||
| @@ -5,7 +7,9 @@ | ||||
|    port build */ | ||||
|  | ||||
| #ifndef NETWARE | ||||
| #ifndef __CYGWIN__ | ||||
| #include <windows.h> | ||||
| #endif | ||||
| #include <process.h> /* for the _getpid() proto */ | ||||
| #endif  /* !NETWARE */ | ||||
| #include <sys/types.h> | ||||
| @@ -16,7 +20,7 @@ | ||||
|  | ||||
| #define EINPROGRESS WSAEINPROGRESS | ||||
| #define EWOULDBLOCK WSAEWOULDBLOCK | ||||
| #define EMSGSIZE WSAEMSGSIZE | ||||
| #define EMSGSIZE     WSAEMSGSIZE | ||||
| #define EAFNOSUPPORT WSAEAFNOSUPPORT | ||||
|  | ||||
| /* Structure for scatter/gather I/O.  */ | ||||
|   | ||||
							
								
								
									
										120
									
								
								ares/setup.h
									
									
									
									
									
								
							
							
						
						
									
										120
									
								
								ares/setup.h
									
									
									
									
									
								
							| @@ -1,5 +1,7 @@ | ||||
| #ifndef ARES_SETUP_H | ||||
| #define ARES_SETUP_H | ||||
| #ifndef __ARES_SETUP_H | ||||
| #define __ARES_SETUP_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* Copyright (C) 2004 - 2005 by Daniel Stenberg et al | ||||
|  * | ||||
| @@ -14,17 +16,99 @@ | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
|  | ||||
| #if !defined(WIN32) && defined(__WIN32__) | ||||
| /* Borland fix */ | ||||
| #define WIN32 | ||||
| #endif | ||||
|  | ||||
| #if !defined(WIN32) && defined(_WIN32) | ||||
| /* VS2005 on x64 fix */ | ||||
| #define WIN32 | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Include configuration script results or hand-crafted | ||||
|  * configuration file for platforms which lack config tool. | ||||
|  */ | ||||
|  | ||||
| #ifdef HAVE_CONFIG_H | ||||
| #include "config.h" | ||||
| #else | ||||
| /* simple work-around for now, for systems without configure support */ | ||||
|  | ||||
| #ifdef WIN32 | ||||
| #include "config-win32.h" | ||||
| #endif | ||||
|  | ||||
| #endif /* HAVE_CONFIG_H */ | ||||
|  | ||||
| /* | ||||
|  * Include header files for windows builds before redefining anything. | ||||
|  * Use this preproessor block only to include or exclude windows.h, | ||||
|  * winsock2.h, ws2tcpip.h or winsock.h. Any other windows thing belongs | ||||
|  * to any other further and independant block.  Under Cygwin things work | ||||
|  * just as under linux (e.g. <sys/socket.h>) and the winsock headers should | ||||
|  * never be included when __CYGWIN__ is defined.  configure script takes | ||||
|  * care of this, not defining HAVE_WINDOWS_H, HAVE_WINSOCK_H, HAVE_WINSOCK2_H, | ||||
|  * neither HAVE_WS2TCPIP_H when __CYGWIN__ is defined. | ||||
|  */ | ||||
|  | ||||
| #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> | ||||
| #    ifdef HAVE_WS2TCPIP_H | ||||
| #       include <ws2tcpip.h> | ||||
| #    endif | ||||
| #  else | ||||
| #    ifdef HAVE_WINSOCK_H | ||||
| #      include <winsock.h> | ||||
| #    endif | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Define USE_WINSOCK to 2 if we have and use WINSOCK2 API, else | ||||
|  * define USE_WINSOCK to 1 if we have and use WINSOCK  API, else | ||||
|  * undefine USE_WINSOCK. | ||||
|  */ | ||||
|  | ||||
| #undef USE_WINSOCK | ||||
|  | ||||
| #ifdef HAVE_WINSOCK2_H | ||||
| #  define USE_WINSOCK 2 | ||||
| #else | ||||
| #  ifdef HAVE_WINSOCK_H | ||||
| #    define USE_WINSOCK 1 | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Work-arounds for systems without configure support | ||||
|  */ | ||||
|  | ||||
| #ifndef HAVE_CONFIG_H | ||||
|  | ||||
| #if defined(__DJGPP__) || (defined(__WATCOMC__) && (__WATCOMC__ >= 1240)) || \ | ||||
|     defined(__POCC__) | ||||
| #else | ||||
| #define ssize_t int | ||||
| #endif | ||||
|  | ||||
| #ifndef HAVE_WS2TCPIP_H | ||||
| #define socklen_t int | ||||
| #endif | ||||
|  | ||||
| /* Recent autoconf versions define these symbols in config.h. We don't want | ||||
|    them (since they collide with the libcurl ones when we build | ||||
|    --enable-debug) so we undef them again here. */ | ||||
| #endif /* HAVE_CONFIG_H */ | ||||
|  | ||||
| /* | ||||
|  * Recent autoconf versions define these symbols in config.h. We don't | ||||
|  * want them (since they collide with the libcurl ones when we build | ||||
|  *  --enable-debug) so we undef them again here. | ||||
|  */ | ||||
|  | ||||
| #undef PACKAGE_STRING | ||||
| #undef PACKAGE_TARNAME | ||||
| #undef PACKAGE_VERSION | ||||
| @@ -33,9 +117,11 @@ | ||||
| #undef VERSION | ||||
| #undef PACKAGE | ||||
|  | ||||
| /* now typedef our socket type */ | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include <winsock.h> | ||||
| /* | ||||
|  * Typedef our socket type | ||||
|  */ | ||||
|  | ||||
| #ifdef USE_WINSOCK | ||||
| typedef SOCKET ares_socket_t; | ||||
| #define ARES_SOCKET_BAD INVALID_SOCKET | ||||
| #else | ||||
| @@ -43,8 +129,10 @@ typedef int ares_socket_t; | ||||
| #define ARES_SOCKET_BAD -1 | ||||
| #endif | ||||
|  | ||||
| /* Assume a few thing unless they're set by configure | ||||
| /* | ||||
|  * Assume a few thing unless they're set by configure | ||||
|  */ | ||||
|  | ||||
| #if !defined(HAVE_SYS_TIME_H) && !defined(_MSC_VER) | ||||
| #define HAVE_SYS_TIME_H | ||||
| #endif | ||||
| @@ -58,7 +146,7 @@ typedef int ares_socket_t; | ||||
| #endif | ||||
|  | ||||
| #if (defined(WIN32) || defined(WATT32)) && \ | ||||
|    !(defined(__MINGW32__) || defined(NETWARE)) | ||||
|    !(defined(__MINGW32__) || defined(NETWARE) || defined(__DJGPP__)) | ||||
| /* protos for the functions we provide in windows_port.c */ | ||||
| int ares_strncasecmp(const char *s1, const char *s2, int n); | ||||
| int ares_strcasecmp(const char *s1, const char *s2); | ||||
| @@ -79,4 +167,12 @@ int ares_strcasecmp(const char *s1, const char *s2); | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #endif /* ARES_SETUP_H */ | ||||
| /* | ||||
|  * Include macros and defines that should only be processed once. | ||||
|  */ | ||||
|  | ||||
| #ifndef __SETUP_ONCE_H | ||||
| #include "setup_once.h" | ||||
| #endif | ||||
|  | ||||
| #endif /* __ARES_SETUP_H */ | ||||
|   | ||||
							
								
								
									
										146
									
								
								ares/setup_once.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								ares/setup_once.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| #ifndef __SETUP_ONCE_H | ||||
| #define __SETUP_ONCE_H | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* 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 | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************************************************** | ||||
|  *                              NOTICE                              * | ||||
|  *                             ========                             * | ||||
|  *                                                                  * | ||||
|  *  Content of header files lib/setup_once.h and ares/setup_once.h  * | ||||
|  *  must be kept in sync. Modify the other one if you change this.  * | ||||
|  *                                                                  * | ||||
|  ********************************************************************/ | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * If we have the MSG_NOSIGNAL define, make sure we use | ||||
|  * it as the fourth argument of function send() | ||||
|  */ | ||||
|  | ||||
| #ifdef HAVE_MSG_NOSIGNAL | ||||
| #define SEND_4TH_ARG MSG_NOSIGNAL | ||||
| #else | ||||
| #define SEND_4TH_ARG 0 | ||||
| #endif  | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * The definitions for the return type and arguments types | ||||
|  * of functions recv() and send() belong and come from the | ||||
|  * configuration file. Do not define them in any other place. | ||||
|  * | ||||
|  * HAVE_RECV is defined if you have a function named recv() | ||||
|  * which is used to read incoming data from sockets. If your | ||||
|  * function has another name then don't define HAVE_RECV. | ||||
|  * | ||||
|  * If HAVE_RECV is defined then RECV_TYPE_ARG1, RECV_TYPE_ARG2, | ||||
|  * RECV_TYPE_ARG3, RECV_TYPE_ARG4 and RECV_TYPE_RETV must also | ||||
|  * be defined. | ||||
|  * | ||||
|  * HAVE_SEND is defined if you have a function named send() | ||||
|  * which is used to write outgoing data on a connected socket. | ||||
|  * If yours has another name then don't define HAVE_SEND. | ||||
|  * | ||||
|  * If HAVE_SEND is defined then SEND_TYPE_ARG1, SEND_QUAL_ARG2, | ||||
|  * SEND_TYPE_ARG2, SEND_TYPE_ARG3, SEND_TYPE_ARG4 and | ||||
|  * SEND_TYPE_RETV must also be defined. | ||||
|  */ | ||||
|  | ||||
| #ifdef HAVE_RECV | ||||
| #if !defined(RECV_TYPE_ARG1) || \ | ||||
|     !defined(RECV_TYPE_ARG2) || \ | ||||
|     !defined(RECV_TYPE_ARG3) || \ | ||||
|     !defined(RECV_TYPE_ARG4) || \ | ||||
|     !defined(RECV_TYPE_RETV) | ||||
|   /* */ | ||||
|   Error Missing_definition_of_return_and_arguments_types_of_recv | ||||
|   /* */ | ||||
| #else | ||||
| #define sread(x,y,z) (ssize_t)recv((RECV_TYPE_ARG1)(x), \ | ||||
|                                    (RECV_TYPE_ARG2)(y), \ | ||||
|                                    (RECV_TYPE_ARG3)(z), \ | ||||
|                                    (RECV_TYPE_ARG4)(0)) | ||||
| #endif | ||||
| #else /* HAVE_RECV */ | ||||
| #ifndef sread | ||||
|   /* */ | ||||
|   Error Missing_definition_of_macro_sread | ||||
|   /* */ | ||||
| #endif | ||||
| #endif /* HAVE_RECV */ | ||||
|  | ||||
| #ifdef HAVE_SEND | ||||
| #if !defined(SEND_TYPE_ARG1) || \ | ||||
|     !defined(SEND_QUAL_ARG2) || \ | ||||
|     !defined(SEND_TYPE_ARG2) || \ | ||||
|     !defined(SEND_TYPE_ARG3) || \ | ||||
|     !defined(SEND_TYPE_ARG4) || \ | ||||
|     !defined(SEND_TYPE_RETV) | ||||
|   /* */ | ||||
|   Error Missing_definition_of_return_and_arguments_types_of_send | ||||
|   /* */ | ||||
| #else | ||||
| #define swrite(x,y,z) (ssize_t)send((SEND_TYPE_ARG1)(x), \ | ||||
|                                     (SEND_TYPE_ARG2)(y), \ | ||||
|                                     (SEND_TYPE_ARG3)(z), \ | ||||
|                                     (SEND_TYPE_ARG4)(SEND_4TH_ARG)) | ||||
| #endif | ||||
| #else /* HAVE_SEND */ | ||||
| #ifndef swrite | ||||
|   /* */ | ||||
|   Error Missing_definition_of_macro_swrite | ||||
|   /* */ | ||||
| #endif | ||||
| #endif /* HAVE_SEND */ | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Uppercase macro versions of ANSI/ISO is*() functions/macros which  | ||||
|  * avoid negative number inputs with argument byte codes > 127. | ||||
|  */ | ||||
|  | ||||
| #define ISSPACE(x)  (isspace((int)  ((unsigned char)x))) | ||||
| #define ISDIGIT(x)  (isdigit((int)  ((unsigned char)x))) | ||||
| #define ISALNUM(x)  (isalnum((int)  ((unsigned char)x))) | ||||
| #define ISXDIGIT(x) (isxdigit((int) ((unsigned char)x))) | ||||
| #define ISGRAPH(x)  (isgraph((int)  ((unsigned char)x))) | ||||
| #define ISALPHA(x)  (isalpha((int)  ((unsigned char)x))) | ||||
| #define ISPRINT(x)  (isprint((int)  ((unsigned char)x))) | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * 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 | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Default return type for signal handlers. | ||||
|  */ | ||||
|  | ||||
| #ifndef RETSIGTYPE | ||||
| #define RETSIGTYPE void | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif /* __SETUP_ONCE_H */ | ||||
|  | ||||
| @@ -1,213 +0,0 @@ | ||||
| # Microsoft Developer Studio Generated NMAKE File, Based on adig.dsp | ||||
| !IF "$(CFG)" == "" | ||||
| CFG=adig - Win32 Debug | ||||
| !MESSAGE No configuration specified. Defaulting to adig - Win32 Debug. | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(CFG)" != "adig - Win32 Release" && "$(CFG)" != "adig - Win32 Debug" | ||||
| !MESSAGE Invalid configuration "$(CFG)" specified. | ||||
| !MESSAGE You can specify a configuration when running NMAKE | ||||
| !MESSAGE by defining the macro CFG on the command line. For example: | ||||
| !MESSAGE  | ||||
| !MESSAGE NMAKE /f "adig.mak" CFG="adig - Win32 Debug" | ||||
| !MESSAGE  | ||||
| !MESSAGE Possible choices for configuration are: | ||||
| !MESSAGE  | ||||
| !MESSAGE "adig - Win32 Release" (based on "Win32 (x86) Console Application") | ||||
| !MESSAGE "adig - Win32 Debug" (based on "Win32 (x86) Console Application") | ||||
| !MESSAGE  | ||||
| !ERROR An invalid configuration is specified. | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(OS)" == "Windows_NT" | ||||
| NULL= | ||||
| !ELSE  | ||||
| NULL=nul | ||||
| !ENDIF  | ||||
|  | ||||
| CPP=cl.exe | ||||
| RSC=rc.exe | ||||
|  | ||||
| !IF  "$(CFG)" == "adig - Win32 Release" | ||||
|  | ||||
| OUTDIR=.\Release | ||||
| INTDIR=.\Release | ||||
| # Begin Custom Macros | ||||
| OutDir=.\Release | ||||
| # End Custom Macros | ||||
|  | ||||
| !IF "$(RECURSE)" == "0"  | ||||
|  | ||||
| ALL : "$(OUTDIR)\adig.exe" | ||||
|  | ||||
| !ELSE  | ||||
|  | ||||
| ALL : "areslib - Win32 Release" "$(OUTDIR)\adig.exe" | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(RECURSE)" == "1"  | ||||
| CLEAN :"areslib - Win32 ReleaseCLEAN"  | ||||
| !ELSE  | ||||
| CLEAN : | ||||
| !ENDIF  | ||||
| 	-@erase "$(INTDIR)\adig.obj" | ||||
| 	-@erase "$(INTDIR)\getopt.obj" | ||||
| 	-@erase "$(INTDIR)\vc60.idb" | ||||
| 	-@erase "$(OUTDIR)\adig.exe" | ||||
|  | ||||
| "$(OUTDIR)" : | ||||
|     if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" | ||||
|  | ||||
| CPP_PROJ=/nologo /MD /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /Fp"$(INTDIR)\adig.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /c  | ||||
| BSC32=bscmake.exe | ||||
| BSC32_FLAGS=/nologo /o"$(OUTDIR)\adig.bsc"  | ||||
| BSC32_SBRS= \ | ||||
| 	 | ||||
| LINK32=link.exe | ||||
| LINK32_FLAGS=wsock32.lib areslib.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /incremental:no /pdb:"$(OUTDIR)\adig.pdb" /machine:I386 /out:"$(OUTDIR)\adig.exe" /libpath:"..\areslib\Release"  | ||||
| LINK32_OBJS= \ | ||||
| 	"$(INTDIR)\adig.obj" \ | ||||
| 	"$(INTDIR)\getopt.obj" \ | ||||
| 	"..\areslib\Release\areslib.lib" | ||||
|  | ||||
| "$(OUTDIR)\adig.exe" : "$(OUTDIR)" $(DEF_FILE) $(LINK32_OBJS) | ||||
|     $(LINK32) @<< | ||||
|   $(LINK32_FLAGS) $(LINK32_OBJS) | ||||
| << | ||||
|  | ||||
| !ELSEIF  "$(CFG)" == "adig - Win32 Debug" | ||||
|  | ||||
| OUTDIR=.\Debug | ||||
| INTDIR=.\Debug | ||||
| # Begin Custom Macros | ||||
| OutDir=.\Debug | ||||
| # End Custom Macros | ||||
|  | ||||
| !IF "$(RECURSE)" == "0"  | ||||
|  | ||||
| ALL : "$(OUTDIR)\adig.exe" | ||||
|  | ||||
| !ELSE  | ||||
|  | ||||
| ALL : "areslib - Win32 Debug" "$(OUTDIR)\adig.exe" | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(RECURSE)" == "1"  | ||||
| CLEAN :"areslib - Win32 DebugCLEAN"  | ||||
| !ELSE  | ||||
| CLEAN : | ||||
| !ENDIF  | ||||
| 	-@erase "$(INTDIR)\adig.obj" | ||||
| 	-@erase "$(INTDIR)\getopt.obj" | ||||
| 	-@erase "$(INTDIR)\vc60.idb" | ||||
| 	-@erase "$(INTDIR)\vc60.pdb" | ||||
| 	-@erase "$(OUTDIR)\adig.exe" | ||||
| 	-@erase "$(OUTDIR)\adig.ilk" | ||||
| 	-@erase "$(OUTDIR)\adig.pdb" | ||||
|  | ||||
| "$(OUTDIR)" : | ||||
|     if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" | ||||
|  | ||||
| CPP_PROJ=/nologo /MLd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /Fp"$(INTDIR)\adig.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /GZ  /c  | ||||
| BSC32=bscmake.exe | ||||
| BSC32_FLAGS=/nologo /o"$(OUTDIR)\adig.bsc"  | ||||
| BSC32_SBRS= \ | ||||
| 	 | ||||
| LINK32=link.exe | ||||
| LINK32_FLAGS=wsock32.lib areslib.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /incremental:yes /pdb:"$(OUTDIR)\adig.pdb" /debug /machine:I386 /out:"$(OUTDIR)\adig.exe" /pdbtype:sept /libpath:"..\areslib\Debug"  | ||||
| LINK32_OBJS= \ | ||||
| 	"$(INTDIR)\adig.obj" \ | ||||
| 	"$(INTDIR)\getopt.obj" \ | ||||
| 	"..\areslib\Debug\areslib.lib" | ||||
|  | ||||
| "$(OUTDIR)\adig.exe" : "$(OUTDIR)" $(DEF_FILE) $(LINK32_OBJS) | ||||
|     $(LINK32) @<< | ||||
|   $(LINK32_FLAGS) $(LINK32_OBJS) | ||||
| << | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| .c{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cpp{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cxx{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .c{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cpp{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cxx{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
|  | ||||
| !IF "$(NO_EXTERNAL_DEPS)" != "1" | ||||
| !IF EXISTS("adig.dep") | ||||
| !INCLUDE "adig.dep" | ||||
| !ELSE  | ||||
| !MESSAGE Warning: cannot find "adig.dep" | ||||
| !ENDIF  | ||||
| !ENDIF  | ||||
|  | ||||
|  | ||||
| !IF "$(CFG)" == "adig - Win32 Release" || "$(CFG)" == "adig - Win32 Debug" | ||||
| SOURCE=..\..\adig.c | ||||
|  | ||||
| "$(INTDIR)\adig.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\getopt.c | ||||
|  | ||||
| "$(INTDIR)\getopt.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| !IF  "$(CFG)" == "adig - Win32 Release" | ||||
|  | ||||
| "areslib - Win32 Release" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Release"  | ||||
|    cd "..\adig" | ||||
|  | ||||
| "areslib - Win32 ReleaseCLEAN" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Release" RECURSE=1 CLEAN  | ||||
|    cd "..\adig" | ||||
|  | ||||
| !ELSEIF  "$(CFG)" == "adig - Win32 Debug" | ||||
|  | ||||
| "areslib - Win32 Debug" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug"  | ||||
|    cd "..\adig" | ||||
|  | ||||
| "areslib - Win32 DebugCLEAN" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug" RECURSE=1 CLEAN  | ||||
|    cd "..\adig" | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| @@ -1,77 +0,0 @@ | ||||
| <html> | ||||
| <body> | ||||
| <pre> | ||||
| <h1>Build Log</h1> | ||||
| <h3> | ||||
| --------------------Configuration: areslib - Win32 Release-------------------- | ||||
| </h3> | ||||
| <h3>Command Lines</h3> | ||||
| Creating temporary file "C:\DOCUME~1\liren\LOCALS~1\Temp\RSP615A.tmp" with contents | ||||
| [ | ||||
| /nologo /MD /W3 /GX /O2 /I "..\.." /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /Fp"Release/areslib.pch" /YX /Fo"Release/" /Fd"Release/" /FD /c  | ||||
| "Z:\ARES-1.1.1\ares_gethostbyname.c" | ||||
| "Z:\ARES-1.1.1\ares_init.c" | ||||
| ] | ||||
| Creating command line "cl.exe @C:\DOCUME~1\liren\LOCALS~1\Temp\RSP615A.tmp"  | ||||
| Creating temporary file "C:\DOCUME~1\liren\LOCALS~1\Temp\RSP615B.tmp" with contents | ||||
| [ | ||||
| /nologo /out:"Release\areslib.lib"  | ||||
| ".\Release\ares__close_sockets.obj" | ||||
| ".\Release\ares__get_hostent.obj" | ||||
| ".\Release\ares__read_line.obj" | ||||
| ".\Release\ares_destroy.obj" | ||||
| ".\Release\ares_expand_name.obj" | ||||
| ".\Release\ares_fds.obj" | ||||
| ".\Release\ares_free_errmem.obj" | ||||
| ".\Release\ares_free_hostent.obj" | ||||
| ".\Release\ares_free_string.obj" | ||||
| ".\Release\ares_gethostbyaddr.obj" | ||||
| ".\Release\ares_gethostbyname.obj" | ||||
| ".\Release\ares_init.obj" | ||||
| ".\Release\ares_mkquery.obj" | ||||
| ".\Release\ares_parse_a_reply.obj" | ||||
| ".\Release\ares_parse_ptr_reply.obj" | ||||
| ".\Release\ares_process.obj" | ||||
| ".\Release\ares_query.obj" | ||||
| ".\Release\ares_search.obj" | ||||
| ".\Release\ares_send.obj" | ||||
| ".\Release\ares_strerror.obj" | ||||
| ".\Release\ares_timeout.obj" | ||||
| ".\Release\windows_port.obj" | ||||
| ] | ||||
| Creating command line "link.exe -lib @C:\DOCUME~1\liren\LOCALS~1\Temp\RSP615B.tmp" | ||||
| <h3>Output Window</h3> | ||||
| Compiling... | ||||
| ares_gethostbyname.c | ||||
| Z:\ARES-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_init.c | ||||
| Z:\ARES-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| Z:\ARES-1.1.1\ares_init.c(141) : warning C4013: '_getpid' undefined; assuming extern returning int | ||||
| Z:\ARES-1.1.1\ares_init.c(236) : warning C4101: 'p' : unreferenced local variable | ||||
| Z:\ARES-1.1.1\ares_init.c(237) : warning C4101: 'linesize' : unreferenced local variable | ||||
| Z:\ARES-1.1.1\ares_init.c(235) : warning C4101: 'fp' : unreferenced local variable | ||||
| Creating library... | ||||
| <h3> | ||||
| --------------------Configuration: adig - Win32 Release-------------------- | ||||
| </h3> | ||||
| <h3>Command Lines</h3> | ||||
| Creating temporary file "C:\DOCUME~1\liren\LOCALS~1\Temp\RSP615C.tmp" with contents | ||||
| [ | ||||
| wsock32.lib areslib.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /incremental:no /pdb:"Release/adig.pdb" /machine:I386 /out:"Release/adig.exe" /libpath:"..\areslib\Release"  | ||||
| ".\Release\adig.obj" | ||||
| ".\Release\getopt.obj" | ||||
| "\ARES-1.1.1\vc\areslib\Release\areslib.lib" | ||||
| ] | ||||
| Creating command line "link.exe @C:\DOCUME~1\liren\LOCALS~1\Temp\RSP615C.tmp" | ||||
| <h3>Output Window</h3> | ||||
| Linking... | ||||
|  | ||||
|  | ||||
|  | ||||
| <h3>Results</h3> | ||||
| adig.exe - 0 error(s), 6 warning(s) | ||||
| </pre> | ||||
| </body> | ||||
| </html> | ||||
| @@ -1,223 +0,0 @@ | ||||
| # Microsoft Developer Studio Generated NMAKE File, Based on ahost.dsp | ||||
| !IF "$(CFG)" == "" | ||||
| CFG=ahost - Win32 Debug | ||||
| !MESSAGE No configuration specified. Defaulting to ahost - Win32 Debug. | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(CFG)" != "ahost - Win32 Release" && "$(CFG)" != "ahost - Win32 Debug" | ||||
| !MESSAGE Invalid configuration "$(CFG)" specified. | ||||
| !MESSAGE You can specify a configuration when running NMAKE | ||||
| !MESSAGE by defining the macro CFG on the command line. For example: | ||||
| !MESSAGE  | ||||
| !MESSAGE NMAKE /f "ahost.mak" CFG="ahost - Win32 Debug" | ||||
| !MESSAGE  | ||||
| !MESSAGE Possible choices for configuration are: | ||||
| !MESSAGE  | ||||
| !MESSAGE "ahost - Win32 Release" (based on "Win32 (x86) Console Application") | ||||
| !MESSAGE "ahost - Win32 Debug" (based on "Win32 (x86) Console Application") | ||||
| !MESSAGE  | ||||
| !ERROR An invalid configuration is specified. | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(OS)" == "Windows_NT" | ||||
| NULL= | ||||
| !ELSE  | ||||
| NULL=nul | ||||
| !ENDIF  | ||||
|  | ||||
| CPP=cl.exe | ||||
| RSC=rc.exe | ||||
|  | ||||
| !IF  "$(CFG)" == "ahost - Win32 Release" | ||||
|  | ||||
| OUTDIR=.\Release | ||||
| INTDIR=.\Release | ||||
| # Begin Custom Macros | ||||
| OutDir=.\Release | ||||
| # End Custom Macros | ||||
|  | ||||
| !IF "$(RECURSE)" == "0"  | ||||
|  | ||||
| ALL : "$(OUTDIR)\ahost.exe" | ||||
|  | ||||
| !ELSE  | ||||
|  | ||||
| ALL : "areslib - Win32 Release" "$(OUTDIR)\ahost.exe" | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(RECURSE)" == "1"  | ||||
| CLEAN :"areslib - Win32 ReleaseCLEAN"  | ||||
| !ELSE  | ||||
| CLEAN : | ||||
| !ENDIF  | ||||
| 	-@erase "$(INTDIR)\ahost.obj" | ||||
| 	-@erase "$(INTDIR)\vc60.idb" | ||||
| 	-@erase "$(OUTDIR)\ahost.exe" | ||||
|  | ||||
| "$(OUTDIR)" : | ||||
|     if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" | ||||
|  | ||||
| CPP_PROJ=/nologo /MD /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /Fp"$(INTDIR)\ahost.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /c  | ||||
| BSC32=bscmake.exe | ||||
| BSC32_FLAGS=/nologo /o"$(OUTDIR)\ahost.bsc"  | ||||
| BSC32_SBRS= \ | ||||
| 	 | ||||
| LINK32=link.exe | ||||
| LINK32_FLAGS=wsock32.lib areslib.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /incremental:no /pdb:"$(OUTDIR)\ahost.pdb" /machine:I386 /out:"$(OUTDIR)\ahost.exe" /libpath:"..\areslib\Release"  | ||||
| LINK32_OBJS= \ | ||||
| 	"$(INTDIR)\ahost.obj" \ | ||||
| 	"..\areslib\Release\areslib.lib" | ||||
|  | ||||
| "$(OUTDIR)\ahost.exe" : "$(OUTDIR)" $(DEF_FILE) $(LINK32_OBJS) | ||||
|     $(LINK32) @<< | ||||
|   $(LINK32_FLAGS) $(LINK32_OBJS) | ||||
| << | ||||
|  | ||||
| !ELSEIF  "$(CFG)" == "ahost - Win32 Debug" | ||||
|  | ||||
| OUTDIR=.\Debug | ||||
| INTDIR=.\Debug | ||||
| # Begin Custom Macros | ||||
| OutDir=.\Debug | ||||
| # End Custom Macros | ||||
|  | ||||
| !IF "$(RECURSE)" == "0"  | ||||
|  | ||||
| ALL : "$(OUTDIR)\ahost.exe" "$(OUTDIR)\ahost.bsc" | ||||
|  | ||||
| !ELSE  | ||||
|  | ||||
| ALL : "areslib - Win32 Debug" "$(OUTDIR)\ahost.exe" "$(OUTDIR)\ahost.bsc" | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| !IF "$(RECURSE)" == "1"  | ||||
| CLEAN :"areslib - Win32 DebugCLEAN"  | ||||
| !ELSE  | ||||
| CLEAN : | ||||
| !ENDIF  | ||||
| 	-@erase "$(INTDIR)\ahost.obj" | ||||
| 	-@erase "$(INTDIR)\ahost.sbr" | ||||
| 	-@erase "$(INTDIR)\vc60.idb" | ||||
| 	-@erase "$(INTDIR)\vc60.pdb" | ||||
| 	-@erase "$(OUTDIR)\ahost.bsc" | ||||
| 	-@erase "$(OUTDIR)\ahost.exe" | ||||
| 	-@erase "$(OUTDIR)\ahost.ilk" | ||||
| 	-@erase "$(OUTDIR)\ahost.pdb" | ||||
|  | ||||
| "$(OUTDIR)" : | ||||
|     if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" | ||||
|  | ||||
| CPP_PROJ=/nologo /MLd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /FR"$(INTDIR)\\" /Fp"$(INTDIR)\ahost.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /GZ  /c  | ||||
| BSC32=bscmake.exe | ||||
| BSC32_FLAGS=/nologo /o"$(OUTDIR)\ahost.bsc"  | ||||
| BSC32_SBRS= \ | ||||
| 	"$(INTDIR)\ahost.sbr" | ||||
|  | ||||
| "$(OUTDIR)\ahost.bsc" : "$(OUTDIR)" $(BSC32_SBRS) | ||||
|     $(BSC32) @<< | ||||
|   $(BSC32_FLAGS) $(BSC32_SBRS) | ||||
| << | ||||
|  | ||||
| LINK32=link.exe | ||||
| LINK32_FLAGS=wsock32.lib areslib.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /incremental:yes /pdb:"$(OUTDIR)\ahost.pdb" /debug /machine:I386 /out:"$(OUTDIR)\ahost.exe" /pdbtype:sept /libpath:"..\areslib\Debug"  | ||||
| LINK32_OBJS= \ | ||||
| 	"$(INTDIR)\ahost.obj" \ | ||||
| 	"..\areslib\Debug\areslib.lib" | ||||
|  | ||||
| "$(OUTDIR)\ahost.exe" : "$(OUTDIR)" $(DEF_FILE) $(LINK32_OBJS) | ||||
|     $(LINK32) @<< | ||||
|   $(LINK32_FLAGS) $(LINK32_OBJS) | ||||
| << | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| .c{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cpp{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cxx{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .c{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cpp{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
| .cxx{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $<  | ||||
| << | ||||
|  | ||||
|  | ||||
| !IF "$(NO_EXTERNAL_DEPS)" != "1" | ||||
| !IF EXISTS("ahost.dep") | ||||
| !INCLUDE "ahost.dep" | ||||
| !ELSE  | ||||
| !MESSAGE Warning: cannot find "ahost.dep" | ||||
| !ENDIF  | ||||
| !ENDIF  | ||||
|  | ||||
|  | ||||
| !IF "$(CFG)" == "ahost - Win32 Release" || "$(CFG)" == "ahost - Win32 Debug" | ||||
| SOURCE=..\..\ahost.c | ||||
|  | ||||
| !IF  "$(CFG)" == "ahost - Win32 Release" | ||||
|  | ||||
|  | ||||
| "$(INTDIR)\ahost.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| !ELSEIF  "$(CFG)" == "ahost - Win32 Debug" | ||||
|  | ||||
|  | ||||
| "$(INTDIR)\ahost.obj"	"$(INTDIR)\ahost.sbr" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| !IF  "$(CFG)" == "ahost - Win32 Release" | ||||
|  | ||||
| "areslib - Win32 Release" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Release"  | ||||
|    cd "..\ahost" | ||||
|  | ||||
| "areslib - Win32 ReleaseCLEAN" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Release" RECURSE=1 CLEAN  | ||||
|    cd "..\ahost" | ||||
|  | ||||
| !ELSEIF  "$(CFG)" == "ahost - Win32 Debug" | ||||
|  | ||||
| "areslib - Win32 Debug" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug"  | ||||
|    cd "..\ahost" | ||||
|  | ||||
| "areslib - Win32 DebugCLEAN" :  | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug" RECURSE=1 CLEAN  | ||||
|    cd "..\ahost" | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
|  | ||||
| !ENDIF  | ||||
|  | ||||
| @@ -1,16 +0,0 @@ | ||||
| <html> | ||||
| <body> | ||||
| <pre> | ||||
| <h1>Build Log</h1> | ||||
| <h3> | ||||
| --------------------Configuration: ahost - Win32 Release-------------------- | ||||
| </h3> | ||||
| <h3>Command Lines</h3> | ||||
|  | ||||
|  | ||||
|  | ||||
| <h3>Results</h3> | ||||
| ahost.exe - 0 error(s), 0 warning(s) | ||||
| </pre> | ||||
| </body> | ||||
| </html> | ||||
| @@ -63,8 +63,8 @@ LIB32=link.exe -lib | ||||
| # PROP Output_Dir "Debug" | ||||
| # PROP Intermediate_Dir "Debug" | ||||
| # PROP Target_Dir "" | ||||
| # ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ  /c | ||||
| # ADD CPP /nologo /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ  /c | ||||
| # ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c | ||||
| # ADD CPP /nologo /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c | ||||
| # ADD BASE RSC /l 0x409 /d "_DEBUG" | ||||
| # ADD RSC /l 0x409 /d "_DEBUG" | ||||
| BSC32=bscmake.exe | ||||
| @@ -97,6 +97,10 @@ SOURCE=..\..\ares__read_line.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_cancel.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_destroy.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
| @@ -125,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 | ||||
| @@ -137,6 +145,10 @@ SOURCE=..\..\ares_parse_a_reply.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_parse_aaaa_reply.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_parse_ptr_reply.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
| @@ -153,14 +165,6 @@ SOURCE=..\..\ares_search.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_cancel.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_version.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_send.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
| @@ -173,6 +177,22 @@ SOURCE=..\..\ares_timeout.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_version.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\bitncmp.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\inet_net_pton.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\inet_ntop.c | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\windows_port.c | ||||
| # End Source File | ||||
| # End Group | ||||
| @@ -189,7 +209,7 @@ SOURCE=..\..\ares_dns.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_version.h | ||||
| SOURCE=..\..\ares_ipv6.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| @@ -197,6 +217,22 @@ SOURCE=..\..\ares_private.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\ares_version.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\bitncmp.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\inet_net_pton.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\inet_ntop.h | ||||
| # End Source File | ||||
| # Begin Source File | ||||
|  | ||||
| SOURCE=..\..\nameser.h | ||||
| # End Source File | ||||
| # End Group | ||||
|   | ||||
							
								
								
									
										29
									
								
								ares/vc/areslib/areslib.dsw
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								ares/vc/areslib/areslib.dsw
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| Microsoft Developer Studio Workspace File, Format Version 6.00 | ||||
| # WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE! | ||||
|  | ||||
| ############################################################################### | ||||
|  | ||||
| Project: "areslib"=.\areslib.dsp - Package Owner=<4> | ||||
|  | ||||
| Package=<5> | ||||
| {{{ | ||||
| }}} | ||||
|  | ||||
| Package=<4> | ||||
| {{{ | ||||
| }}} | ||||
|  | ||||
| ############################################################################### | ||||
|  | ||||
| Global: | ||||
|  | ||||
| Package=<5> | ||||
| {{{ | ||||
| }}} | ||||
|  | ||||
| Package=<3> | ||||
| {{{ | ||||
| }}} | ||||
|  | ||||
| ############################################################################### | ||||
|  | ||||
| @@ -1,367 +0,0 @@ | ||||
| # Microsoft Developer Studio Generated NMAKE File, Based on areslib.dsp | ||||
| !IF "$(CFG)" == "" | ||||
| CFG=areslib - Win32 Debug | ||||
| !MESSAGE No configuration specified. Defaulting to areslib - Win32 Debug. | ||||
| !ENDIF | ||||
|  | ||||
| !IF "$(CFG)" != "areslib - Win32 Release" && "$(CFG)" != "areslib - Win32 Debug" | ||||
| !MESSAGE Invalid configuration "$(CFG)" specified. | ||||
| !MESSAGE You can specify a configuration when running NMAKE | ||||
| !MESSAGE by defining the macro CFG on the command line. For example: | ||||
| !MESSAGE | ||||
| !MESSAGE NMAKE /f "areslib.mak" CFG="areslib - Win32 Debug" | ||||
| !MESSAGE | ||||
| !MESSAGE Possible choices for configuration are: | ||||
| !MESSAGE | ||||
| !MESSAGE "areslib - Win32 Release" (based on "Win32 (x86) Static Library") | ||||
| !MESSAGE "areslib - Win32 Debug" (based on "Win32 (x86) Static Library") | ||||
| !MESSAGE | ||||
| !ERROR An invalid configuration is specified. | ||||
| !ENDIF | ||||
|  | ||||
| !IF "$(OS)" == "Windows_NT" | ||||
| NULL= | ||||
| !ELSE | ||||
| NULL=nul | ||||
| !ENDIF | ||||
|  | ||||
| CPP=cl.exe | ||||
| RSC=rc.exe | ||||
|  | ||||
| !IF  "$(CFG)" == "areslib - Win32 Release" | ||||
|  | ||||
| OUTDIR=.\Release | ||||
| INTDIR=.\Release | ||||
| # Begin Custom Macros | ||||
| OutDir=.\Release | ||||
| # End Custom Macros | ||||
|  | ||||
| ALL : "$(OUTDIR)\areslib.lib" | ||||
|  | ||||
|  | ||||
| CLEAN : | ||||
| 	-@erase "$(INTDIR)\ares__close_sockets.obj" | ||||
| 	-@erase "$(INTDIR)\ares__get_hostent.obj" | ||||
| 	-@erase "$(INTDIR)\ares__read_line.obj" | ||||
| 	-@erase "$(INTDIR)\ares_destroy.obj" | ||||
| 	-@erase "$(INTDIR)\ares_expand_name.obj" | ||||
| 	-@erase "$(INTDIR)\ares_fds.obj" | ||||
| 	-@erase "$(INTDIR)\ares_free_hostent.obj" | ||||
| 	-@erase "$(INTDIR)\ares_free_string.obj" | ||||
| 	-@erase "$(INTDIR)\ares_gethostbyaddr.obj" | ||||
| 	-@erase "$(INTDIR)\ares_gethostbyname.obj" | ||||
| 	-@erase "$(INTDIR)\ares_init.obj" | ||||
| 	-@erase "$(INTDIR)\ares_mkquery.obj" | ||||
| 	-@erase "$(INTDIR)\ares_parse_a_reply.obj" | ||||
| 	-@erase "$(INTDIR)\ares_parse_ptr_reply.obj" | ||||
| 	-@erase "$(INTDIR)\ares_process.obj" | ||||
| 	-@erase "$(INTDIR)\ares_query.obj" | ||||
| 	-@erase "$(INTDIR)\ares_search.obj" | ||||
| 	-@erase "$(INTDIR)\ares_send.obj" | ||||
| 	-@erase "$(INTDIR)\ares_strerror.obj" | ||||
| 	-@erase "$(INTDIR)\ares_timeout.obj" | ||||
| 	-@erase "$(INTDIR)\vc60.idb" | ||||
| 	-@erase "$(INTDIR)\windows_port.obj" | ||||
| 	-@erase "$(OUTDIR)\areslib.lib" | ||||
|  | ||||
| "$(OUTDIR)" : | ||||
|     if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" | ||||
|  | ||||
| CPP_PROJ=/nologo /MD /W3 /GX /O2 /I "..\.." /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /Fp"$(INTDIR)\areslib.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /c | ||||
| BSC32=bscmake.exe | ||||
| BSC32_FLAGS=/nologo /o"$(OUTDIR)\areslib.bsc" | ||||
| BSC32_SBRS= \ | ||||
|  | ||||
| LIB32=link.exe -lib | ||||
| LIB32_FLAGS=/nologo /out:"$(OUTDIR)\areslib.lib" | ||||
| LIB32_OBJS= \ | ||||
| 	"$(INTDIR)\ares__close_sockets.obj" \ | ||||
| 	"$(INTDIR)\ares__get_hostent.obj" \ | ||||
| 	"$(INTDIR)\ares__read_line.obj" \ | ||||
| 	"$(INTDIR)\ares_destroy.obj" \ | ||||
| 	"$(INTDIR)\ares_expand_name.obj" \ | ||||
| 	"$(INTDIR)\ares_fds.obj" \ | ||||
| 	"$(INTDIR)\ares_free_hostent.obj" \ | ||||
| 	"$(INTDIR)\ares_free_string.obj" \ | ||||
| 	"$(INTDIR)\ares_gethostbyaddr.obj" \ | ||||
| 	"$(INTDIR)\ares_gethostbyname.obj" \ | ||||
| 	"$(INTDIR)\ares_init.obj" \ | ||||
| 	"$(INTDIR)\ares_mkquery.obj" \ | ||||
| 	"$(INTDIR)\ares_parse_a_reply.obj" \ | ||||
| 	"$(INTDIR)\ares_parse_ptr_reply.obj" \ | ||||
| 	"$(INTDIR)\ares_process.obj" \ | ||||
| 	"$(INTDIR)\ares_query.obj" \ | ||||
| 	"$(INTDIR)\ares_search.obj" \ | ||||
| 	"$(INTDIR)\ares_cancel.obj" \ | ||||
| 	"$(INTDIR)\ares_version.obj" \ | ||||
| 	"$(INTDIR)\ares_send.obj" \ | ||||
| 	"$(INTDIR)\ares_strerror.obj" \ | ||||
| 	"$(INTDIR)\ares_timeout.obj" \ | ||||
| 	"$(INTDIR)\windows_port.obj" | ||||
|  | ||||
| "$(OUTDIR)\areslib.lib" : "$(OUTDIR)" $(DEF_FILE) $(LIB32_OBJS) | ||||
|     $(LIB32) @<< | ||||
|   $(LIB32_FLAGS) $(DEF_FLAGS) $(LIB32_OBJS) | ||||
| << | ||||
|  | ||||
| !ELSEIF  "$(CFG)" == "areslib - Win32 Debug" | ||||
|  | ||||
| OUTDIR=.\Debug | ||||
| INTDIR=.\Debug | ||||
| # Begin Custom Macros | ||||
| OutDir=.\Debug | ||||
| # End Custom Macros | ||||
|  | ||||
| ALL : "$(OUTDIR)\areslib.lib" | ||||
|  | ||||
|  | ||||
| CLEAN : | ||||
| 	-@erase "$(INTDIR)\ares__close_sockets.obj" | ||||
| 	-@erase "$(INTDIR)\ares__get_hostent.obj" | ||||
| 	-@erase "$(INTDIR)\ares__read_line.obj" | ||||
| 	-@erase "$(INTDIR)\ares_destroy.obj" | ||||
| 	-@erase "$(INTDIR)\ares_expand_name.obj" | ||||
| 	-@erase "$(INTDIR)\ares_fds.obj" | ||||
| 	-@erase "$(INTDIR)\ares_free_hostent.obj" | ||||
| 	-@erase "$(INTDIR)\ares_free_string.obj" | ||||
| 	-@erase "$(INTDIR)\ares_gethostbyaddr.obj" | ||||
| 	-@erase "$(INTDIR)\ares_gethostbyname.obj" | ||||
| 	-@erase "$(INTDIR)\ares_init.obj" | ||||
| 	-@erase "$(INTDIR)\ares_mkquery.obj" | ||||
| 	-@erase "$(INTDIR)\ares_parse_a_reply.obj" | ||||
| 	-@erase "$(INTDIR)\ares_parse_ptr_reply.obj" | ||||
| 	-@erase "$(INTDIR)\ares_process.obj" | ||||
| 	-@erase "$(INTDIR)\ares_query.obj" | ||||
| 	-@erase "$(INTDIR)\ares_search.obj" | ||||
| 	-@erase "$(INTDIR)\ares_cancel.obj" | ||||
| 	-@erase "$(INTDIR)\ares_version.obj" | ||||
| 	-@erase "$(INTDIR)\ares_send.obj" | ||||
| 	-@erase "$(INTDIR)\ares_strerror.obj" | ||||
| 	-@erase "$(INTDIR)\ares_timeout.obj" | ||||
| 	-@erase "$(INTDIR)\vc60.idb" | ||||
| 	-@erase "$(INTDIR)\vc60.pdb" | ||||
| 	-@erase "$(INTDIR)\windows_port.obj" | ||||
| 	-@erase "$(OUTDIR)\areslib.lib" | ||||
|  | ||||
| "$(OUTDIR)" : | ||||
|     if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" | ||||
|  | ||||
| CPP_PROJ=/nologo /MLd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /Fp"$(INTDIR)\areslib.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /GZ  /c | ||||
| BSC32=bscmake.exe | ||||
| BSC32_FLAGS=/nologo /o"$(OUTDIR)\areslib.bsc" | ||||
| BSC32_SBRS= \ | ||||
|  | ||||
| LIB32=link.exe -lib | ||||
| LIB32_FLAGS=/nologo /out:"$(OUTDIR)\areslib.lib" | ||||
| LIB32_OBJS= \ | ||||
| 	"$(INTDIR)\ares__close_sockets.obj" \ | ||||
| 	"$(INTDIR)\ares__get_hostent.obj" \ | ||||
| 	"$(INTDIR)\ares__read_line.obj" \ | ||||
| 	"$(INTDIR)\ares_destroy.obj" \ | ||||
| 	"$(INTDIR)\ares_expand_name.obj" \ | ||||
| 	"$(INTDIR)\ares_fds.obj" \ | ||||
| 	"$(INTDIR)\ares_free_hostent.obj" \ | ||||
| 	"$(INTDIR)\ares_free_string.obj" \ | ||||
| 	"$(INTDIR)\ares_gethostbyaddr.obj" \ | ||||
| 	"$(INTDIR)\ares_gethostbyname.obj" \ | ||||
| 	"$(INTDIR)\ares_init.obj" \ | ||||
| 	"$(INTDIR)\ares_mkquery.obj" \ | ||||
| 	"$(INTDIR)\ares_parse_a_reply.obj" \ | ||||
| 	"$(INTDIR)\ares_parse_ptr_reply.obj" \ | ||||
| 	"$(INTDIR)\ares_process.obj" \ | ||||
| 	"$(INTDIR)\ares_query.obj" \ | ||||
| 	"$(INTDIR)\ares_search.obj" \ | ||||
| 	"$(INTDIR)\ares_send.obj" \ | ||||
| 	"$(INTDIR)\ares_strerror.obj" \ | ||||
| 	"$(INTDIR)\ares_timeout.obj" \ | ||||
| 	"$(INTDIR)\windows_port.obj" | ||||
|  | ||||
| "$(OUTDIR)\areslib.lib" : "$(OUTDIR)" $(DEF_FILE) $(LIB32_OBJS) | ||||
|     $(LIB32) @<< | ||||
|   $(LIB32_FLAGS) $(DEF_FLAGS) $(LIB32_OBJS) | ||||
| << | ||||
|  | ||||
| !ENDIF | ||||
|  | ||||
| .c{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $< | ||||
| << | ||||
|  | ||||
| .cpp{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $< | ||||
| << | ||||
|  | ||||
| .cxx{$(INTDIR)}.obj:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $< | ||||
| << | ||||
|  | ||||
| .c{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $< | ||||
| << | ||||
|  | ||||
| .cpp{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $< | ||||
| << | ||||
|  | ||||
| .cxx{$(INTDIR)}.sbr:: | ||||
|    $(CPP) @<< | ||||
|    $(CPP_PROJ) $< | ||||
| << | ||||
|  | ||||
|  | ||||
| !IF "$(NO_EXTERNAL_DEPS)" != "1" | ||||
| !IF EXISTS("areslib.dep") | ||||
| !INCLUDE "areslib.dep" | ||||
| !ELSE | ||||
| !MESSAGE Warning: cannot find "areslib.dep" | ||||
| !ENDIF | ||||
| !ENDIF | ||||
|  | ||||
|  | ||||
| !IF "$(CFG)" == "areslib - Win32 Release" || "$(CFG)" == "areslib - Win32 Debug" | ||||
| SOURCE=..\..\ares__close_sockets.c | ||||
|  | ||||
| "$(INTDIR)\ares__close_sockets.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares__get_hostent.c | ||||
|  | ||||
| "$(INTDIR)\ares__get_hostent.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares__read_line.c | ||||
|  | ||||
| "$(INTDIR)\ares__read_line.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_destroy.c | ||||
|  | ||||
| "$(INTDIR)\ares_destroy.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_expand_name.c | ||||
|  | ||||
| "$(INTDIR)\ares_expand_name.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_fds.c | ||||
|  | ||||
| "$(INTDIR)\ares_fds.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_free_hostent.c | ||||
|  | ||||
| "$(INTDIR)\ares_free_hostent.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_free_string.c | ||||
|  | ||||
| "$(INTDIR)\ares_free_string.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_gethostbyaddr.c | ||||
|  | ||||
| "$(INTDIR)\ares_gethostbyaddr.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_gethostbyname.c | ||||
|  | ||||
| "$(INTDIR)\ares_gethostbyname.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_init.c | ||||
|  | ||||
| "$(INTDIR)\ares_init.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_mkquery.c | ||||
|  | ||||
| "$(INTDIR)\ares_mkquery.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_parse_a_reply.c | ||||
|  | ||||
| "$(INTDIR)\ares_parse_a_reply.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_parse_ptr_reply.c | ||||
|  | ||||
| "$(INTDIR)\ares_parse_ptr_reply.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_process.c | ||||
|  | ||||
| "$(INTDIR)\ares_process.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_query.c | ||||
|  | ||||
| "$(INTDIR)\ares_query.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_search.c | ||||
|  | ||||
| "$(INTDIR)\ares_search.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_version.c | ||||
|  | ||||
| "$(INTDIR)\ares_version.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_cancel.c | ||||
|  | ||||
| "$(INTDIR)\ares_cancel.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_send.c | ||||
|  | ||||
| "$(INTDIR)\ares_send.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_strerror.c | ||||
|  | ||||
| "$(INTDIR)\ares_strerror.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\ares_timeout.c | ||||
|  | ||||
| "$(INTDIR)\ares_timeout.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
| SOURCE=..\..\windows_port.c | ||||
|  | ||||
| "$(INTDIR)\windows_port.obj" : $(SOURCE) "$(INTDIR)" | ||||
| 	$(CPP) $(CPP_PROJ) $(SOURCE) | ||||
|  | ||||
|  | ||||
|  | ||||
| !ENDIF | ||||
|  | ||||
| @@ -1,125 +0,0 @@ | ||||
| <html> | ||||
| <body> | ||||
| <pre> | ||||
| <h1>Build Log</h1> | ||||
| <h3> | ||||
| --------------------Configuration: areslib - Win32 Release-------------------- | ||||
| </h3> | ||||
| <h3>Command Lines</h3> | ||||
| Creating temporary file "C:\DOCUME~1\liren\LOCALS~1\Temp\RSP603D.tmp" with contents | ||||
| [ | ||||
| /nologo /MD /W3 /GX /O2 /I "..\.." /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /Fp"Release/areslib.pch" /YX /Fo"Release/" /Fd"Release/" /FD /c  | ||||
| "Z:\ares-1.1.1\ares__close_sockets.c" | ||||
| "Z:\ares-1.1.1\ares__get_hostent.c" | ||||
| "Z:\ares-1.1.1\ares__read_line.c" | ||||
| "Z:\ares-1.1.1\ares_destroy.c" | ||||
| "Z:\ares-1.1.1\ares_expand_name.c" | ||||
| "Z:\ares-1.1.1\ares_fds.c" | ||||
| "Z:\ares-1.1.1\ares_free_errmem.c" | ||||
| "Z:\ares-1.1.1\ares_free_hostent.c" | ||||
| "Z:\ares-1.1.1\ares_free_string.c" | ||||
| "Z:\ares-1.1.1\ares_gethostbyaddr.c" | ||||
| "Z:\ares-1.1.1\ares_gethostbyname.c" | ||||
| "Z:\ares-1.1.1\ares_init.c" | ||||
| "Z:\ares-1.1.1\ares_mkquery.c" | ||||
| "Z:\ares-1.1.1\ares_parse_a_reply.c" | ||||
| "Z:\ares-1.1.1\ares_parse_ptr_reply.c" | ||||
| "Z:\ares-1.1.1\ares_process.c" | ||||
| "Z:\ares-1.1.1\ares_query.c" | ||||
| "Z:\ares-1.1.1\ares_search.c" | ||||
| "Z:\ares-1.1.1\ares_send.c" | ||||
| "Z:\ares-1.1.1\ares_strerror.c" | ||||
| "Z:\ares-1.1.1\ares_timeout.c" | ||||
| "Z:\ares-1.1.1\windows_port.c" | ||||
| ] | ||||
| Creating command line "cl.exe @C:\DOCUME~1\liren\LOCALS~1\Temp\RSP603D.tmp"  | ||||
| Creating temporary file "C:\DOCUME~1\liren\LOCALS~1\Temp\RSP603E.tmp" with contents | ||||
| [ | ||||
| /nologo /out:"Release\areslib.lib"  | ||||
| ".\Release\ares__close_sockets.obj" | ||||
| ".\Release\ares__get_hostent.obj" | ||||
| ".\Release\ares__read_line.obj" | ||||
| ".\Release\ares_destroy.obj" | ||||
| ".\Release\ares_expand_name.obj" | ||||
| ".\Release\ares_fds.obj" | ||||
| ".\Release\ares_free_errmem.obj" | ||||
| ".\Release\ares_free_hostent.obj" | ||||
| ".\Release\ares_free_string.obj" | ||||
| ".\Release\ares_gethostbyaddr.obj" | ||||
| ".\Release\ares_gethostbyname.obj" | ||||
| ".\Release\ares_init.obj" | ||||
| ".\Release\ares_mkquery.obj" | ||||
| ".\Release\ares_parse_a_reply.obj" | ||||
| ".\Release\ares_parse_ptr_reply.obj" | ||||
| ".\Release\ares_process.obj" | ||||
| ".\Release\ares_query.obj" | ||||
| ".\Release\ares_search.obj" | ||||
| ".\Release\ares_send.obj" | ||||
| ".\Release\ares_strerror.obj" | ||||
| ".\Release\ares_timeout.obj" | ||||
| ".\Release\windows_port.obj" | ||||
| ] | ||||
| Creating command line "link.exe -lib @C:\DOCUME~1\liren\LOCALS~1\Temp\RSP603E.tmp" | ||||
| <h3>Output Window</h3> | ||||
| Compiling... | ||||
| ares__close_sockets.c | ||||
| Z:\ares-1.1.1\ares__close_sockets.c(46) : warning C4013: 'close' undefined; assuming extern returning int | ||||
| ares__get_hostent.c | ||||
| ares__read_line.c | ||||
| ares_destroy.c | ||||
| ares_expand_name.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_fds.c | ||||
| ares_free_errmem.c | ||||
| ares_free_hostent.c | ||||
| ares_free_string.c | ||||
| ares_gethostbyaddr.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_gethostbyname.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_init.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| Z:\ares-1.1.1\ares_init.c(141) : warning C4013: '_getpid' undefined; assuming extern returning int | ||||
| Z:\ares-1.1.1\ares_init.c(236) : warning C4101: 'p' : unreferenced local variable | ||||
| Z:\ares-1.1.1\ares_init.c(237) : warning C4101: 'linesize' : unreferenced local variable | ||||
| Z:\ares-1.1.1\ares_init.c(235) : warning C4101: 'fp' : unreferenced local variable | ||||
| ares_mkquery.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_parse_a_reply.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| Z:\ares-1.1.1\ares_parse_a_reply.c(90) : warning C4018: '<' : signed/unsigned mismatch | ||||
| ares_parse_ptr_reply.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| Z:\ares-1.1.1\ares_parse_ptr_reply.c(71) : warning C4018: '<' : signed/unsigned mismatch | ||||
| ares_process.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_query.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_search.c | ||||
| Z:\ares-1.1.1\ares_search.c(229) : warning C4013: 'strncasecmp' undefined; assuming extern returning int | ||||
| ares_send.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| ares_strerror.c | ||||
| ares_timeout.c | ||||
| windows_port.c | ||||
| Z:\ares-1.1.1\nameser.h(153) : warning C4005: 'NOERROR' : macro redefinition | ||||
|         C:\Program Files\Microsoft Visual Studio\VC98\INCLUDE\winerror.h(8022) : see previous definition of 'NOERROR' | ||||
| Creating library... | ||||
|  | ||||
|  | ||||
|  | ||||
| <h3>Results</h3> | ||||
| areslib.lib - 0 error(s), 19 warning(s) | ||||
| </pre> | ||||
| </body> | ||||
| </html> | ||||
| @@ -1,5 +1,7 @@ | ||||
| #include "setup.h" | ||||
|  | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* only do the following on windows | ||||
|  */ | ||||
| #if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS) | ||||
| @@ -100,6 +102,6 @@ ares_writev (ares_socket_t s, const struct iovec *vector, size_t count) | ||||
|     memcpy (bp, vector[i].iov_base, vector[i].iov_len); | ||||
|     bp += vector[i].iov_len; | ||||
|   } | ||||
|   return send (s, (const void*)buffer, bytes, 0); | ||||
|   return (int)swrite(s, buffer, bytes); | ||||
| } | ||||
| #endif /* WIN32 builds only */ | ||||
|   | ||||
							
								
								
									
										53
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								buildconf
									
									
									
									
									
								
							| @@ -1,4 +1,26 @@ | ||||
| #!/bin/sh | ||||
| #*************************************************************************** | ||||
| #                                  _   _ ____  _ | ||||
| #  Project                     ___| | | |  _ \| | | ||||
| #                             / __| | | | |_) | | | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2006, 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$ | ||||
| ########################################################################### | ||||
|  | ||||
| die(){ | ||||
| 	echo "$@" | ||||
| @@ -13,6 +35,7 @@ findtool(){ | ||||
|   IFS=":" | ||||
|   for path in $PATH | ||||
|   do | ||||
|     # echo "checks for $file in $path" >&2 | ||||
|     if test -f "$path/$file"; then | ||||
|       echo "$path/$file" | ||||
|       return | ||||
| @@ -85,8 +108,7 @@ fi | ||||
|  | ||||
| echo "buildconf: automake version $am_version (ok)" | ||||
|  | ||||
| ac=`findtool aclocal` | ||||
|  | ||||
| ac=`findtool ${ACLOCAL:-aclocal}` | ||||
| if test -z "$ac"; then | ||||
|   echo "buildconf: aclocal not found. Weird automake installation!" | ||||
|   exit 1 | ||||
| @@ -107,13 +129,18 @@ LIBTOOL_WANTED_VERSION=1.4.2 | ||||
| # glibtool, with 'libtool' being something completely different. | ||||
| libtool=`findtool glibtool 2>/dev/null` | ||||
| if test ! -x "$libtool"; then | ||||
|   libtool=`findtool libtool` | ||||
|   libtool=`findtool ${LIBTOOL:-libtool}` | ||||
| fi | ||||
|  | ||||
| # set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found | ||||
| LIBTOOLIZE="${libtool}ize" | ||||
| if test -z "$LIBTOOLIZE"; then | ||||
|   # set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found | ||||
|   # $libtool is already the full path | ||||
|   libtoolize="${libtool}ize" | ||||
| else | ||||
|   libtoolize=`findtool $LIBTOOLIZE` | ||||
| fi | ||||
|  | ||||
| lt_pversion=`$libtool --version 2>/dev/null|head -n 1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | ||||
| lt_pversion=`$libtool --version 2>/dev/null|head -n 2|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | ||||
| if test -z "$lt_pversion"; then | ||||
|   echo "buildconf: libtool not found." | ||||
|   echo "            You need libtool version $LIBTOOL_WANTED_VERSION or newer installed" | ||||
| @@ -150,7 +177,7 @@ fi | ||||
|  | ||||
| echo "buildconf: libtool version $lt_version (ok)" | ||||
|  | ||||
| if test -f "$LIBTOOLIZE"; then | ||||
| if test -f "$libtoolize"; then | ||||
|   echo "buildconf: libtoolize found" | ||||
| else | ||||
|   echo "buildconf: libtoolize not found. Weird libtool installation!" | ||||
| @@ -173,14 +200,14 @@ fi | ||||
| #-------------------------------------------------------------------------- | ||||
| # perl check | ||||
| # | ||||
| PERL=`findtool perl` | ||||
| PERL=`findtool ${PERL:-perl}` | ||||
|  | ||||
| # ------------------------------------------------------------ | ||||
|  | ||||
| # run the correct scripts now | ||||
|  | ||||
| echo "buildconf: running libtoolize" | ||||
| ${LIBTOOLIZE:-libtoolize} --copy --automake --force || die "The libtool command failed" | ||||
| $libtoolize --copy --automake --force || die "The libtoolize command failed" | ||||
| echo "buildconf: running aclocal" | ||||
| ${ACLOCAL:-aclocal} $ACLOCAL_FLAGS || die "The aclocal command line failed" | ||||
| if test -n "$PERL"; then | ||||
| @@ -199,12 +226,8 @@ ${AUTOCONF:-autoconf}     || die "The autoconf command failed" | ||||
|  | ||||
| if test -d ares; then | ||||
|   cd ares | ||||
|   echo "buildconf: running ares/libtoolize" | ||||
| ${LIBTOOLIZE:-libtoolize} --copy --automake --force || die "The libtool command failed" | ||||
|   echo "buildconf: running ares/aclocal" | ||||
|   ${ACLOCAL:-aclocal} $ACLOCAL_FLAGS || die "The ares aclocal command failed" | ||||
|   echo "buildconf: running ares/autoconf" | ||||
|   ${AUTOCONF:-autoconf}     || die "The ares autoconf command failed" | ||||
|   echo "buildconf: running in ares" | ||||
|   ./buildconf | ||||
|   cd .. | ||||
| fi | ||||
|  | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
							
								
								
									
										402
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										402
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,4 +1,25 @@ | ||||
| dnl $Id$ | ||||
| #*************************************************************************** | ||||
| #                                  _   _ ____  _ | ||||
| #  Project                     ___| | | |  _ \| | | ||||
| #                             / __| | | | |_) | | | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2006, 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$ | ||||
| ########################################################################### | ||||
| dnl Process this file with autoconf to produce a configure script. | ||||
|  | ||||
| AC_PREREQ(2.57) | ||||
| @@ -7,7 +28,7 @@ dnl We don't know the version number "staticly" so we use a dash here | ||||
| AC_INIT(curl, [-], [a suitable curl mailing list => http://curl.haxx.se/mail/]) | ||||
|  | ||||
| dnl configure script copyright | ||||
| AC_COPYRIGHT([Copyright (c) 1998 - 2005 Daniel Stenberg, <daniel@haxx.se> | ||||
| AC_COPYRIGHT([Copyright (c) 1998 - 2006 Daniel Stenberg, <daniel@haxx.se> | ||||
| This configure script may be copied, distributed and modified under the  | ||||
| terms of the curl license; see COPYING for more details]) | ||||
|  | ||||
| @@ -57,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)" | ||||
| @@ -140,6 +162,19 @@ dnl The install stuff has already been taken care of by the automake stuff | ||||
| dnl AC_PROG_INSTALL | ||||
| AC_PROG_MAKE_SET | ||||
|  | ||||
| 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  | ||||
| dnl could be done later using AC_CHECK_HEADER or AC_CHECK_HEADERS for | ||||
| dnl this specific header files. And do them before its results are used. | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| CURL_CHECK_HEADER_WINDOWS | ||||
| CURL_CHECK_HEADER_WINSOCK | ||||
| CURL_CHECK_HEADER_WINSOCK2 | ||||
| CURL_CHECK_HEADER_WS2TCPIP | ||||
|  | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl switch off particular protocols | ||||
| dnl | ||||
| @@ -151,10 +186,8 @@ AC_HELP_STRING([--disable-http],[Disable HTTP support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_HTTP, 1, [to disable HTTP]) | ||||
|        AC_MSG_WARN([disable HTTP disables FTP over proxy and GOPHER too]) | ||||
|        AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable GOPHER]) | ||||
|        AC_MSG_WARN([disable HTTP disables FTP over proxy]) | ||||
|        AC_SUBST(CURL_DISABLE_HTTP, [1]) | ||||
|        AC_SUBST(CURL_DISABLE_GOPHER, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -176,21 +209,6 @@ AC_HELP_STRING([--disable-ftp],[Disable FTP support]), | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
| AC_MSG_CHECKING([whether to support gopher]) | ||||
| AC_ARG_ENABLE(gopher, | ||||
| AC_HELP_STRING([--enable-gopher],[Enable GOPHER support]) | ||||
| AC_HELP_STRING([--disable-gopher],[Disable GOPHER support]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable GOPHER]) | ||||
|        AC_SUBST(CURL_DISABLE_GOPHER, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
| AC_MSG_CHECKING([whether to support file]) | ||||
| AC_ARG_ENABLE(file, | ||||
| AC_HELP_STRING([--enable-file],[Enable FILE support]) | ||||
| @@ -289,6 +307,12 @@ AC_HELP_STRING([--disable-manual],[Disable built-in manual]), | ||||
| dnl The actual use of the USE_MANUAL variable is done much later in this | ||||
| dnl script to allow other actions to disable it as well. | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl 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. | ||||
| @@ -350,6 +374,21 @@ then | ||||
|              ) | ||||
| fi | ||||
|  | ||||
| if test "$HAVE_GETHOSTBYNAME" != "1" | ||||
| then | ||||
|   dnl This is for eCos with a stubbed DNS implementation | ||||
|   AC_MSG_CHECKING([for gethostbyname for eCos]) | ||||
|   AC_TRY_LINK([ | ||||
| #include <stdio.h> | ||||
| #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 gethostbyname in the net lib - for BeOS | ||||
| @@ -449,20 +488,31 @@ dnl ********************************************************************** | ||||
| dnl Check for the presence of the winmm library. | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| AC_MSG_CHECKING([for timeGetTime in winmm]) | ||||
| my_ac_save_LIBS=$LIBS | ||||
| LIBS="-lwinmm $LIBS" | ||||
| AC_TRY_LINK([#include <windef.h> | ||||
|              #include <mmsystem.h> | ||||
|              ], | ||||
|              [timeGetTime();], | ||||
|              [ dnl worked! | ||||
|              AC_MSG_RESULT([yes]) | ||||
|              ], | ||||
|              [ dnl failed, restore LIBS | ||||
|              LIBS=$my_ac_save_LIBS | ||||
|              AC_MSG_RESULT(no)] | ||||
|            ) | ||||
| case $host in | ||||
|   *-*-cygwin*) | ||||
|     dnl Under Cygwin, winmm exists but is not needed as WIN32 is not #defined | ||||
|     dnl and gettimeofday() will be used regardless of the outcome of this test. | ||||
|     dnl Skip this test, otherwise -lwinmm will be needlessly added to LIBS | ||||
|     dnl (and recorded as such in the .la file, potentially affecting downstream | ||||
|     dnl clients of the library.) | ||||
|     ;; | ||||
|   *) | ||||
|     AC_MSG_CHECKING([for timeGetTime in winmm]) | ||||
|     my_ac_save_LIBS=$LIBS | ||||
|     LIBS="-lwinmm $LIBS" | ||||
|     AC_TRY_LINK([#include <windef.h> | ||||
|                  #include <mmsystem.h> | ||||
|                  ], | ||||
|                  [timeGetTime();], | ||||
|                  [ dnl worked! | ||||
|                  AC_MSG_RESULT([yes]) | ||||
|                  ], | ||||
|                  [ dnl failed, restore LIBS | ||||
|                  LIBS=$my_ac_save_LIBS | ||||
|                  AC_MSG_RESULT(no)] | ||||
|                ) | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Checks for IPv6 | ||||
| @@ -503,10 +553,6 @@ main() | ||||
|  | ||||
| if test "$ipv6" = "yes"; then | ||||
|   curl_ipv6_msg="enabled" | ||||
|  | ||||
|   CURL_CHECK_WORKING_GETADDRINFO | ||||
|  | ||||
|   CURL_CHECK_NI_WITHSCOPEID | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| @@ -702,7 +748,7 @@ AC_ARG_WITH(gssapi-includes, | ||||
| AC_ARG_WITH(gssapi-libs, | ||||
|   AC_HELP_STRING([--with-gssapi-libs=DIR], | ||||
|   		 [Specify location of GSSAPI libs]), | ||||
|   [ GSSAPI_LIBS="-L$withval" | ||||
|   [ GSSAPI_LIB_DIR="-L$withval" | ||||
|     want_gss="yes" ] | ||||
| ) | ||||
|  | ||||
| @@ -795,7 +841,7 @@ OPT_SSL=off | ||||
| dnl Default to no CA bundle | ||||
| ca="no" | ||||
| AC_ARG_WITH(ssl,dnl | ||||
| AC_HELP_STRING([--with-ssl=PATH],[where to look for SSL, PATH points to the SSL installation (default: /usr/local/ssl)]) | ||||
| 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]), | ||||
|   OPT_SSL=$withval) | ||||
|  | ||||
| @@ -865,18 +911,26 @@ if test X"$OPT_SSL" != Xno; then | ||||
|   fi | ||||
|  | ||||
|   dnl This is for Msys/Mingw | ||||
|   AC_MSG_CHECKING([for gdi32]) | ||||
|   my_ac_save_LIBS=$LIBS | ||||
|   LIBS="-lgdi32 $LIBS" | ||||
|   AC_TRY_LINK([#include <windef.h> | ||||
|                #include <wingdi.h>], | ||||
|                [GdiFlush();], | ||||
|                [ dnl worked! | ||||
|                AC_MSG_RESULT([yes])], | ||||
|                [ dnl failed, restore LIBS | ||||
|                LIBS=$my_ac_save_LIBS | ||||
|                AC_MSG_RESULT(no)] | ||||
|               ) | ||||
|   case $host in     | ||||
|     *-*-cygwin*) | ||||
|       dnl Under Cygwin this is extraneous and causes an unnecessary -lgdi32 | ||||
|       dnl to be added to LIBS and recorded in the .la file. | ||||
|       ;; | ||||
|     *) | ||||
|       AC_MSG_CHECKING([for gdi32]) | ||||
|       my_ac_save_LIBS=$LIBS | ||||
|       LIBS="-lgdi32 $LIBS" | ||||
|       AC_TRY_LINK([#include <windef.h> | ||||
|                    #include <wingdi.h>], | ||||
|                    [GdiFlush();], | ||||
|                    [ dnl worked! | ||||
|                    AC_MSG_RESULT([yes])], | ||||
|                    [ dnl failed, restore LIBS | ||||
|                    LIBS=$my_ac_save_LIBS | ||||
|                    AC_MSG_RESULT(no)] | ||||
|                   ) | ||||
|       ;; | ||||
|   esac | ||||
|  | ||||
|   AC_CHECK_LIB(crypto, CRYPTO_lock,[ | ||||
|      HAVECRYPTO="yes" | ||||
| @@ -924,9 +978,18 @@ if test X"$OPT_SSL" != Xno; then | ||||
|         AC_DEFINE(USE_OPENSSL, 1, [if OpenSSL is in use])) | ||||
|  | ||||
|       if test $ac_cv_header_openssl_x509_h = no; then | ||||
|         AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h, | ||||
|         dnl we don't use the "action" part of the AC_CHECK_HEADERS macro | ||||
|         dnl since 'err.h' might in fact find a krb4 header with the same | ||||
|         dnl name | ||||
|         AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h) | ||||
|  | ||||
|         if test $ac_cv_header_x509_h = yes &&  | ||||
|            test $ac_cv_header_crypto_h = yes && | ||||
|            test $ac_cv_header_ssl_h = yes; then | ||||
|           dnl three matches | ||||
|           curl_ssl_msg="enabled (OpenSSL)" | ||||
|           OPENSSL_ENABLED=1) | ||||
|           OPENSSL_ENABLED=1 | ||||
|         fi | ||||
|       fi | ||||
|     fi | ||||
|  | ||||
| @@ -981,6 +1044,74 @@ if test X"$OPT_SSL" != Xno; then | ||||
|  | ||||
| fi | ||||
|  | ||||
| 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 | ||||
|  | ||||
|   if test X"$HAVECRYPTO" = X"yes"; then | ||||
|     dnl This is only reasonable to do if crypto actually is there: check for | ||||
|     dnl LIBSSH2 libs NOTE: it is important to do this AFTER the crypto lib | ||||
|  | ||||
|     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 | ||||
|   else | ||||
|     AC_MSG_WARN([without the use of OpenSSL libs, libssh2 cannot work]) | ||||
|   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 ********************************************************************** | ||||
| @@ -1047,10 +1178,10 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|     fi | ||||
|     if test -n "$addlib"; then | ||||
|  | ||||
|       CLEANLDFLAGS="$LDFLAGS" | ||||
|       CLEANLIBS="$LIBS" | ||||
|       CLEANCPPFLAGS="$CPPFLAGS" | ||||
|    | ||||
|       LDFLAGS="$LDFLAGS $addlib" | ||||
|       LIBS="$LIBS $addlib" | ||||
|       if test "$addcflags" != "-I/usr/include"; then | ||||
|          CPPFLAGS="$CPPFLAGS $addcflags" | ||||
|       fi | ||||
| @@ -1063,7 +1194,7 @@ if test "$OPENSSL_ENABLED" != "1"; then | ||||
|        curl_ssl_msg="enabled (GnuTLS)" | ||||
|        ], | ||||
|        [ | ||||
|          LDFLAGS="$CLEANLDFLAGS" | ||||
|          LIBS="$CLEANLIBS" | ||||
|          CPPFLAGS="$CLEANCPPFLAGS" | ||||
|        ]) | ||||
|    | ||||
| @@ -1288,8 +1419,8 @@ AC_HELP_STRING([--enable-thread],[look for thread-safe functions]), | ||||
|  | ||||
| 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) | ||||
|   AC_DEFINE(DISABLED_THREADSAFE, 1, | ||||
|     [Set to explicitly specify we don't want to use thread-safe functions]) | ||||
| else | ||||
|   if test "$ipv6" != "yes"; then | ||||
|     dnl dig around for gethostbyname_r() | ||||
| @@ -1380,7 +1511,8 @@ if test x$cross_compiling != xyes; then | ||||
|      AC_MSG_RESULT(no) | ||||
|     , | ||||
|     dnl not invoked when crosscompiling) | ||||
|     ]) | ||||
|      echo "hej" | ||||
|     ) | ||||
|   fi | ||||
| else | ||||
|   dnl and for crosscompilings | ||||
| @@ -1395,7 +1527,9 @@ dnl ********************************************************************** | ||||
| dnl Checks for header files. | ||||
| AC_HEADER_STDC | ||||
|  | ||||
| dnl First check for the very most basic headers. Then we can use these | ||||
| CURL_CHECK_HEADER_MALLOC | ||||
|  | ||||
| dnl Now check for the very most basic headers. Then we can use these | ||||
| dnl ones as default-headers when checking for the rest! | ||||
| AC_CHECK_HEADERS( | ||||
|         sys/types.h \ | ||||
| @@ -1405,7 +1539,6 @@ AC_CHECK_HEADERS( | ||||
|         sys/ioctl.h \ | ||||
|         assert.h \ | ||||
|         unistd.h \ | ||||
|         malloc.h \ | ||||
|         stdlib.h \ | ||||
|         limits.h \ | ||||
|         arpa/inet.h \ | ||||
| @@ -1422,8 +1555,6 @@ AC_CHECK_HEADERS( | ||||
|         fcntl.h \ | ||||
|         dlfcn.h \ | ||||
|         alloca.h \ | ||||
|         winsock.h \ | ||||
|         winsock2.h \ | ||||
|         time.h \ | ||||
|         io.h \ | ||||
|         pwd.h \ | ||||
| @@ -1465,6 +1596,8 @@ dnl Checks for typedefs, structures, and compiler characteristics. | ||||
| AC_C_CONST | ||||
| AC_TYPE_SIZE_T | ||||
| AC_HEADER_TIME | ||||
| CURL_CHECK_STRUCT_TIMEVAL | ||||
| CURL_VERIFY_RUNTIMELIBS | ||||
|  | ||||
| AC_CHECK_SIZEOF(curl_off_t, ,[ | ||||
| #include <stdio.h> | ||||
| @@ -1493,17 +1626,36 @@ fi | ||||
| AC_CHECK_TYPE(ssize_t, , | ||||
|    AC_DEFINE(ssize_t, int, [the signed version of size_t])) | ||||
|  | ||||
| TYPE_SOCKLEN_T | ||||
| # Check for socklen_t or equivalent | ||||
| CURL_CHECK_TYPE_SOCKLEN_T | ||||
|  | ||||
| TYPE_IN_ADDR_T | ||||
|  | ||||
| TYPE_SOCKADDR_STORAGE | ||||
|  | ||||
| TYPE_SIG_ATOMIC_T | ||||
|  | ||||
| AC_TYPE_SIGNAL | ||||
|  | ||||
| AC_FUNC_SELECT_ARGTYPES | ||||
|  | ||||
| CURL_CHECK_FUNC_RECV | ||||
|  | ||||
| CURL_CHECK_FUNC_SEND | ||||
|  | ||||
| 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) | ||||
|      ac_cv_func_pipe=no | ||||
|      skipcheck_pipe=yes | ||||
|      AC_MSG_NOTICE([skip check for pipe on msdosdjgpp]) | ||||
|     ;; | ||||
| esac | ||||
| AC_CHECK_FUNCS( strtoll \ | ||||
|                 socket \ | ||||
|                 select \ | ||||
| @@ -1536,12 +1688,16 @@ AC_CHECK_FUNCS( strtoll \ | ||||
|                 ftruncate \ | ||||
|                 pipe \ | ||||
|                 poll \ | ||||
|                 getprotobyname \ | ||||
|                 getrlimit \ | ||||
|                 setrlimit, | ||||
|                 setrlimit \ | ||||
|                 fork, | ||||
| dnl if found | ||||
| [], | ||||
| dnl if not found, $ac_func is the name we check for | ||||
|   func="$ac_func" | ||||
| func="$ac_func" | ||||
| eval skipcheck=\$skipcheck_$func | ||||
| if test "x$skipcheck" != "xyes"; then | ||||
|   AC_MSG_CHECKING([deeper for $func]) | ||||
|   AC_TRY_LINK( [], | ||||
|                [ $func ();], | ||||
| @@ -1551,21 +1707,38 @@ dnl if not found, $ac_func is the name we check for | ||||
|                AC_DEFINE_UNQUOTED($def, 1, [If you have $func]), | ||||
|                AC_MSG_RESULT(but still no) | ||||
|                ) | ||||
|  | ||||
| fi | ||||
| ) | ||||
|  | ||||
| dnl For some reason, the check above doesn't properly detect select() with | ||||
| dnl Msys/Mingw | ||||
| if test "$ac_cv_func_select" != "yes"; then | ||||
| if test "$ac_cv_func_select" = "no"; then | ||||
|   AC_MSG_CHECKING([for select in ws2_32]) | ||||
|   AC_TRY_LINK([#include <winsock2.h>], | ||||
|                [select(0,(fd_set *)NULL,(fd_set *)NULL,(fd_set *)NULL,(struct timeval *)NULL);], | ||||
|                [ dnl worked! | ||||
|                AC_MSG_RESULT([yes]) | ||||
|                HAVE_SELECT="1" | ||||
|                AC_DEFINE_UNQUOTED(HAVE_SELECT,1)], | ||||
|                [AC_MSG_ERROR(You can't compile without a select)] | ||||
|              ) | ||||
|   AC_TRY_LINK([ | ||||
| #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> | ||||
| #else | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #include <winsock.h> | ||||
| #endif | ||||
| #endif | ||||
| #endif | ||||
|     ],[ | ||||
|       select(0,(fd_set *)NULL,(fd_set *)NULL,(fd_set *)NULL,(struct timeval *)NULL); | ||||
|     ],[  | ||||
|       AC_MSG_RESULT([yes]) | ||||
|       HAVE_SELECT="1" | ||||
|       AC_DEFINE_UNQUOTED(HAVE_SELECT, 1, | ||||
|         [Define to 1 if you have the select function.]) | ||||
|     ],[ | ||||
|       AC_MSG_ERROR([You can't compile without a select]) | ||||
|   ]) | ||||
| fi | ||||
|  | ||||
| dnl sigsetjmp() might be a macro and no function so if it isn't found already | ||||
| @@ -1589,8 +1762,30 @@ AC_CHECK_DECL(basename, , | ||||
| #ifdef HAVE_LIBGEN_H | ||||
| #include <libgen.h> | ||||
| #endif | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| ) | ||||
|  | ||||
| AC_CHECK_DECL(inet_pton, , | ||||
|               AC_DEFINE(HAVE_NO_INET_PTON_PROTO, 1, | ||||
|                         [Defined if no inet_pton() prototype available]), | ||||
| [ | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
| ] | ||||
| ) | ||||
|  | ||||
| dnl Check if the getnameinfo function is available | ||||
| dnl and get the types of five of its arguments. | ||||
| CURL_CHECK_FUNC_GETNAMEINFO | ||||
|  | ||||
| if test "$ipv6" = "yes"; then | ||||
|   CURL_CHECK_WORKING_GETADDRINFO | ||||
|   CURL_CHECK_NI_WITHSCOPEID | ||||
| fi | ||||
|  | ||||
| AC_MSG_CHECKING([if we are Mac OS X (to disable poll)]) | ||||
| disable_poll=no | ||||
| case $host in | ||||
| @@ -1784,7 +1979,6 @@ AC_HELP_STRING([--disable-sspi],[Disable SSPI]), | ||||
|        AC_MSG_RESULT(yes) | ||||
|        AC_DEFINE(USE_WINDOWS_SSPI, 1, [to enable SSPI support]) | ||||
|        AC_SUBST(USE_WINDOWS_SSPI) | ||||
|        LIBS="$LIBS -lsecur32" | ||||
|        curl_sspi_msg="yes" | ||||
|        ;; | ||||
|   *) | ||||
| @@ -1857,6 +2051,52 @@ AC_HELP_STRING([--disable-cookies],[Disable cookies support]), | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl Enable hiding of internal symbols in library to reduce its size and | ||||
| dnl speed dynamic linking of applications.  This currently is only supported | ||||
| dnl on gcc >= 4.0 and SunPro C. | ||||
| dnl | ||||
| AC_MSG_CHECKING([whether to enable hidden symbols in the library]) | ||||
| AC_ARG_ENABLE(hidden-symbols, | ||||
| AC_HELP_STRING([--enable-hidden-symbols],[Hide internal symbols in library]) | ||||
| AC_HELP_STRING([--disable-hidden-symbols],[Leave all symbols with default visibility in library]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        ;; | ||||
|   *)    | ||||
|        AC_MSG_CHECKING([whether $CC supports it]) | ||||
|        if test "$GCC" = yes ; then | ||||
|          if $CC --help --verbose 2>&1 | grep fvisibility= > /dev/null ; then | ||||
| 	   AC_MSG_RESULT(yes) | ||||
| 	   AC_DEFINE(CURL_HIDDEN_SYMBOLS, 1, [to enable hidden symbols]) | ||||
| 	   AC_SUBST(CURL_HIDDEN_SYMBOLS) | ||||
| 	   AC_DEFINE(CURL_EXTERN_SYMBOL, [__attribute__ ((visibility ("default")))], [to make a symbol visible]) | ||||
| 	   AC_SUBST(CURL_EXTERN_SYMBOL) | ||||
| 	   CFLAGS="$CFLAGS -fvisibility=hidden" | ||||
|          else | ||||
|             AC_MSG_RESULT(no) | ||||
|           fi | ||||
|  | ||||
|        else | ||||
|        	 dnl Test for SunPro cc | ||||
|        	 if $CC 2>&1 | grep flags >/dev/null && $CC -flags | grep xldscope= >/dev/null ; then | ||||
|            AC_MSG_RESULT(yes) | ||||
| 	   AC_DEFINE(CURL_HIDDEN_SYMBOLS, 1, [to enable hidden symbols]) | ||||
| 	   AC_SUBST(CURL_HIDDEN_SYMBOLS) | ||||
| 	   AC_DEFINE(CURL_EXTERN_SYMBOL, [__global], [to make a symbol visible]) | ||||
| 	   AC_SUBST(CURL_EXTERN_SYMBOL) | ||||
| 	   CFLAGS="$CFLAGS -xldscope=hidden" | ||||
|          else | ||||
|            AC_MSG_RESULT(no) | ||||
|          fi | ||||
|        fi | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl ************************************************************ | ||||
| if test "x$ws2" = "xyes"; then | ||||
|  | ||||
|   dnl If ws2_32 is wanted, make sure it is the _last_ lib in LIBS (makes | ||||
| @@ -1894,6 +2134,9 @@ AC_CONFIG_FILES([Makefile \ | ||||
|            packages/EPM/curl.list \ | ||||
|            packages/EPM/Makefile \ | ||||
|            packages/vms/Makefile \ | ||||
|            packages/AIX/Makefile \ | ||||
|            packages/AIX/RPM/Makefile \ | ||||
|            packages/AIX/RPM/curl.spec \ | ||||
|            curl-config \ | ||||
|            libcurl.pc | ||||
| ]) | ||||
| @@ -1906,6 +2149,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} | ||||
|   | ||||
| @@ -1,10 +1,30 @@ | ||||
| #! /bin/sh | ||||
| #*************************************************************************** | ||||
| #                                  _   _ ____  _ | ||||
| #  Project                     ___| | | |  _ \| | | ||||
| #                             / __| | | | |_) | | | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 2001 - 2006, 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$ | ||||
| ########################################################################### | ||||
| # | ||||
| # The idea to this kind of setup info script was stolen from numerous | ||||
| # other packages, such as neon, libxml and gnome. | ||||
| # | ||||
| # $Id$ | ||||
| # | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| includedir=@includedir@ | ||||
| @@ -19,6 +39,7 @@ Available values for OPTION include: | ||||
|   --ca        ca bundle install path | ||||
|   --cc        compiler | ||||
|   --cflags    pre-processor and compiler flags | ||||
|   --checkfor [version] check for (lib)curl of the specified version | ||||
|   --features  newline separated list of enabled features | ||||
|   --protocols newline separated list of enabled protocols | ||||
|   --help      display this help and exit | ||||
| @@ -101,9 +122,6 @@ while test $# -gt 0; do | ||||
|             echo "FTPS" | ||||
|           fi | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_GOPHER@" != "1"; then | ||||
|           echo "GOPHER" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_FILE@" != "1"; then | ||||
|           echo "FILE" | ||||
|         fi | ||||
| @@ -125,6 +143,26 @@ while test $# -gt 0; do | ||||
| 	exit 0 | ||||
| 	;; | ||||
|  | ||||
|     --checkfor) | ||||
|         checkfor=$2 | ||||
|         cmajor=`echo $checkfor | cut -d. -f1` | ||||
|         cminor=`echo $checkfor | cut -d. -f2` | ||||
|         # when extracting the patch part we strip off everything after a | ||||
| 	# dash as that's used for things like version 1.2.3-CVS | ||||
| 	cpatch=`echo $checkfor | cut -d. -f3 | cut -d- -f1` | ||||
|         checknum=`echo "$cmajor*256*256 + $cminor*256 + ${cpatch:-0}" | bc` | ||||
|         numuppercase=`echo @VERSIONNUM@ | tr 'a-f' 'A-F'` | ||||
|         nownum=`echo "obase=10; ibase=16; $numuppercase" | bc` | ||||
|  | ||||
| 	if test "$nownum" -ge "$checknum"; then | ||||
| 	  # silent success | ||||
| 	  exit 0 | ||||
| 	else | ||||
| 	  echo "requested version $checkfor is newer than existing @VERSION@" | ||||
| 	  exit 1 | ||||
| 	fi | ||||
| 	;; | ||||
|  | ||||
|     --vernum) | ||||
| 	echo @VERSIONNUM@ | ||||
| 	exit 0 | ||||
|   | ||||
| @@ -46,8 +46,8 @@ Cocoa | ||||
|  | ||||
| D | ||||
|  | ||||
|   Written by Charles Sanders and James Wavro | ||||
|   http://www.atari-soldiers.com/libcurl.html | ||||
|   Written by Kenneth Bogert | ||||
|   http://curl.haxx.se/libcurl/d/ | ||||
|  | ||||
| Dylan | ||||
|  | ||||
| @@ -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 | ||||
|  | ||||
| @@ -155,6 +155,16 @@ S-Lang | ||||
|   S-Lang binding written by John E Davis | ||||
|   http://www.jedsoft.org/slang/modules/curl.html | ||||
|  | ||||
| Smalltalk | ||||
|  | ||||
|   Smalltalk binding written by Danil Osipchuk | ||||
|   http://www.squeaksource.com/CurlPlugin/ | ||||
|  | ||||
| SPL | ||||
|  | ||||
|   SPL binding written by Clifford Wolf | ||||
|   http://www.clifford.at/spl/ | ||||
|  | ||||
| Tcl | ||||
|  | ||||
|   Tclcurl is written by Andr<64>s Garc<72>a | ||||
| @@ -173,3 +183,8 @@ wxWidgets | ||||
|  | ||||
|   Written by Casey O'Donnell | ||||
|   http://homepage.mac.com/codonnell/wxcurldav/ | ||||
|  | ||||
| XBLite | ||||
|  | ||||
|   Written by David Szafranski | ||||
|   http://perso.wanadoo.fr/xblite/libraries.html | ||||
|   | ||||
| @@ -4,11 +4,11 @@ | ||||
|                             | (__| |_| |  _ <| |___ | ||||
|                              \___|\___/|_| \_\_____| | ||||
|  | ||||
| To Think About When Contributing Source Code | ||||
|                         When Contributing Source Code | ||||
|  | ||||
|  This document is intended to offer some simple guidelines that can be useful | ||||
|  to keep in mind when you decide to contribute to the project. This concerns | ||||
|  new features as well as corrections to existing flaws or bugs. | ||||
|  This document is intended to offer guidelines that can be useful to keep in | ||||
|  mind when you decide to contribute to the project. This concerns new features | ||||
|  as well as corrections to existing flaws or bugs. | ||||
|  | ||||
| Join the Community | ||||
|  | ||||
| @@ -20,13 +20,26 @@ Join the Community | ||||
| The License Issue | ||||
|  | ||||
|  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 otherwise. | ||||
|  the same license curl and libcurl is already using unless stated and agreed | ||||
|  otherwise. | ||||
|  | ||||
|  If you add a larger piece of code, you can opt to make that file or set of | ||||
|  files to use a different license as long as they don't enforce any changes to | ||||
|  the rest of the package and they make sense. Such "separate parts" can not be | ||||
|  GPL (as we don't want the GPL virus to attack users of libcurl) but they must | ||||
|  use "GPL compatible" licenses. | ||||
|  GPL licensed (as we don't want copyleft to affect users of libcurl) but they | ||||
|  must use "GPL compatible" licenses (as we want to allow users to use libcurl | ||||
|  properly in GPL licensed environments). | ||||
|  | ||||
|  When changing existing source code, you do not alter the copyright of the | ||||
|  original file(s). The copyright will still be owned by the original | ||||
|  creator(s) or those who have been assigned copyright by the original | ||||
|  author(s). | ||||
|  | ||||
|  By submitting a patch to the curl project, you are assumed to have the right | ||||
|  to the code and to be allowed by your employer or whatever to hand over that | ||||
|  patch/code to us. We will credit you for your changes as far as possible, to | ||||
|  give credit but also to keep a trace back to who made what changes. Please | ||||
|  always provide us with your full real name when contributing! | ||||
|  | ||||
| What To Read | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
|   Date: September 30, 2005 | ||||
|   Date: May 15, 2006 | ||||
|   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.14.1 is currently the latest version available. Things may (or | ||||
|  perhaps will) of course change in the future. | ||||
|  now. libcurl 7.15.3 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 | ||||
|  me where and how you think I'm wrong, and I'll try to correct my mistakes. | ||||
| @@ -16,11 +16,10 @@ Background | ||||
|  The Free Software Foundation has deemed the Original BSD license[1] to be | ||||
|  "incompatible"[2] with GPL[3]. I'd rather say it is the other way around, but | ||||
|  the point is the same: if you distribute a binary version of a GPL program, | ||||
|  it MUST NOT be linked with any Original BSD-licensed parts or | ||||
|  libraries. Doing so will violate the GPL license. For a long time, very many | ||||
|  GPL licensed programs have avoided this license mess by adding an | ||||
|  exception[8] to their license. And many others have just closed their eyes | ||||
|  for this problem. | ||||
|  it MUST NOT be linked with any Original BSD-licensed parts or libraries. | ||||
|  Doing so will violate the GPL license. For a long time, very many GPL | ||||
|  licensed programs have avoided this license mess by adding an exception[8] to | ||||
|  their license. And many others have just closed their eyes for this problem. | ||||
|  | ||||
|  libcurl is MIT-style[4] licensed - how on earth did this dilemma fall onto | ||||
|  our plates? | ||||
| @@ -33,7 +32,10 @@ Background | ||||
|  tend to), you have a clash. GPL vs Original BSD. | ||||
|  | ||||
|  This dilemma is not libcurl-specific nor is it specific to any particular | ||||
|  Linux distro. | ||||
|  Linux distro. (This article mentions and refers to Debian several times, but | ||||
|  only because Debian seems to be the only Linux distro to have faced this | ||||
|  issue yet since no other distro is shipping libcurl built with two SSL | ||||
|  libraries.) | ||||
|  | ||||
| Part of the Operating System | ||||
|  | ||||
| @@ -46,25 +48,13 @@ 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 | ||||
|  | ||||
| Debian-legal | ||||
|  | ||||
|  In August 2004 I figured I should start pulling people's attention to this to | ||||
|  see if anyone has any bright ideas or if they would dismiss my worries based | ||||
|  on some elegant writing I had missed somewhere: | ||||
|  | ||||
|  My post to debian-legal on August 12 2004: | ||||
|  | ||||
|         http://lists.debian.org/debian-legal/2004/08/msg00279.html | ||||
|  | ||||
|  Several people agreed then that this is a known and rather big problem, but | ||||
|  the following discussion didn't result in much. | ||||
|  | ||||
| GnuTLS | ||||
|  | ||||
|  With the release of libcurl 7.14.0 (May 2005), it can now get built to use | ||||
|  GnuTLS instead of OpenSSL. GnuTLS is a LGPL[7] licensed library that offers a | ||||
|  matching set of features as OpenSSL does. Now, you can build and distribute | ||||
|  an SSL capable libcurl without including any Original BSD licensed code. | ||||
|  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. | ||||
|  | ||||
|  I believe Debian is the first distro to provide libcurl/GnutTLS packages. | ||||
|  | ||||
| @@ -77,11 +67,20 @@ GnuTLS vs OpenSSL | ||||
|  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. | ||||
|  | ||||
|  In August 2005, the debian-devel mailing list discovered the license issue as | ||||
|  a GPL licensed application wanted SSL capabilities from libcurl and thus was | ||||
|  forced to use the GnuTLS powered libcurl. For a reason that is unknown to me, | ||||
|  the application authors didn't want to or was unable to add an exception to | ||||
|  their GPL license. Alas, the license problem hit the fan again. | ||||
|  GnuTLS | ||||
|    - LGPL licensened | ||||
|    - supports SRP | ||||
|    - lacks SSLv2 support | ||||
|    - lacks MD2 support (used by at least some CA certs) | ||||
|    - lacks the crypto functions libcurl uses for NTLM | ||||
|  | ||||
|  OpenSSL | ||||
|    - Original BSD licensened | ||||
|    - lacks SRP | ||||
|    - supports SSLv2 | ||||
|    - older and more widely used | ||||
|    - 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? | ||||
|  | ||||
| @@ -109,20 +108,21 @@ More SSL Libraries | ||||
| Application Angle of this Problem | ||||
|  | ||||
|  libcurl is built to use one SSL/TLS library. It uses a single fixed name (by | ||||
|  default), and applications are built/linked to use that single lib. Replacing | ||||
|  one libcurl instance with another one that uses the other SSL/TLS library | ||||
|  might break one or more applications (due to ABI differences and/or different | ||||
|  feature set). You want your application to use the libcurl it was built for. | ||||
|  default) on the built/created lib file, and applications are built/linked to | ||||
|  use that single lib. Replacing one libcurl instance with another one that | ||||
|  uses the other SSL/TLS library might break one or more applications (due to | ||||
|  ABI differences and/or different feature set). You want your application to | ||||
|  use the libcurl it was built for. | ||||
|  | ||||
| Project cURL Angle of this Problem | ||||
|  | ||||
|  We distribute libcurl and everyone may build libcurl with either library. At | ||||
|  We distribute libcurl and everyone may build libcurl with either library at | ||||
|  their choice. This problem is not directly a problem of ours. It merely | ||||
|  affects users - GPL application authors only - of our lib as it comes | ||||
|  included and delivered on some distros. | ||||
|  | ||||
|  libcurl has different ABI when built with different SSL/TLS libraries due to | ||||
|  two reasons: | ||||
|  these reasons: | ||||
|  | ||||
|  1. No one has worked on fixing this. The mutex/lock callbacks should be set | ||||
|     with a generic libcurl function that should use the proper underlying | ||||
| @@ -131,13 +131,19 @@ Project cURL Angle of this Problem | ||||
|  2. The CURLOPT_SSL_CTX_FUNCTION option is not possible to "emulate" on GnuTLS | ||||
|     but simply requires OpenSSL. | ||||
|  | ||||
|  3. There might be some other subtle differences just because nobody has yet | ||||
|     tried to make a fixed ABI like this. | ||||
|  | ||||
| Distro Angle of this Problem | ||||
|  | ||||
|  A distro can provide separate libcurls built with different SSL/TLS libraries | ||||
|  to work around this, but at least Debian seems to be very hostile against | ||||
|  such an approach, probably since it makes things like devel packages for the | ||||
|  different libs collide since they would provide the same include files and | ||||
|  man pages etc. | ||||
|  To my knowledge there is only one distro that ships libcurl built with either | ||||
|  one of the SSL libs supported. | ||||
|  | ||||
|  Debian Linux is now (since mid September 2005) providing two different | ||||
|  libcurl packages, one for libcurl built with OpenSSL and one built with | ||||
|  GnuTLS. They use different .so names and can this both be installed in a | ||||
|  single system simultaneously. This has been said to be a transitional system | ||||
|  not desired to keep in the long run. | ||||
|  | ||||
| Fixing the Only Problem | ||||
|  | ||||
| @@ -173,9 +179,9 @@ Fixing the Only Problem | ||||
|  | ||||
| When Will This Happen | ||||
|  | ||||
|  Note again that 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. | ||||
|  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! | ||||
| @@ -185,7 +191,7 @@ When Will This Happen | ||||
|  code like today (without the use of lib2), should you decide to ignore the | ||||
|  problems outlined in this document. | ||||
|  | ||||
|  Update: Work on this has been initiated by Richard Atterer: | ||||
|  Work on this was suggested by Richard Atterer: | ||||
|  | ||||
|         http://curl.haxx.se/mail/lib-2005-09/0066.html | ||||
|  | ||||
|   | ||||
							
								
								
									
										132
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										132
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| Updated: August 26, 2005 (http://curl.haxx.se/docs/faq.html) | ||||
| Updated: November 2, 2005 (http://curl.haxx.se/docs/faq.html) | ||||
|                                   _   _ ____  _ | ||||
|                               ___| | | |  _ \| | | ||||
|                              / __| | | | |_) | | | ||||
| @@ -16,6 +16,8 @@ FAQ | ||||
|   1.6 What do you get for making curl? | ||||
|   1.7 What about CURL from curl.com? | ||||
|   1.8 I have a problem who do I mail? | ||||
|   1.9 Where do I buy commercial support for curl? | ||||
|   1.10 How many are using curl? | ||||
|  | ||||
|  2. Install Related Problems | ||||
|   2.1 configure doesn't find OpenSSL even when it is installed | ||||
| @@ -88,6 +90,7 @@ FAQ | ||||
|   6.4 I have a program that uses LGPL libraries, can I use libcurl? | ||||
|   6.5 Can I modify curl/libcurl for my program and keep the changes secret? | ||||
|   6.6 Can you please change the curl/libcurl license to XXXX? | ||||
|   6.7 What are my obligations when using libcurl in my commerical apps? | ||||
|  | ||||
|  7. PHP/CURL Issues | ||||
|   7.1 What is PHP/CURL? | ||||
| @@ -111,7 +114,7 @@ FAQ | ||||
|   libcurl | ||||
|  | ||||
|     A free and easy-to-use client-side URL transfer library, supporting FTP, | ||||
|     FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE and LDAP.  libcurl supports | ||||
|     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! | ||||
| @@ -129,8 +132,7 @@ 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, GOPHER, LDAP, DICT, TELNET and | ||||
|     FILE. | ||||
|     currently including HTTP, HTTPS, FTP, FTPS, LDAP, DICT, TELNET and FILE. | ||||
|  | ||||
|   We pronounce curl and cURL with an initial k sound: [kurl]. | ||||
|  | ||||
| @@ -148,6 +150,10 @@ FAQ | ||||
|   You can use libcurl for free in your application, be it open source, | ||||
|   commercial or closed-source. | ||||
|  | ||||
|   libcurl is most probably the most portable, most powerful and most often | ||||
|   used C-based multi-platform file transfer library on this planet - be it | ||||
|   open source or commercial. | ||||
|  | ||||
|   1.3 What is curl not? | ||||
|  | ||||
|   Curl is *not* a wget clone. That is a common misconception.  Never, during | ||||
| @@ -205,7 +211,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 400 contributors is found in the docs/THANKS | ||||
|   The full list of the more than 450 contributors is found in the docs/THANKS | ||||
|   file. | ||||
|  | ||||
|   curl is developed by a community, with Daniel at the wheel. | ||||
| @@ -259,6 +265,52 @@ FAQ | ||||
|   flaw is announced to the world, thus lessen the impact the problem will have | ||||
|   on existing users. | ||||
|  | ||||
|   1.9 Where do I buy commercial support for curl? | ||||
|  | ||||
|   curl is fully open source. It means you can hire any skilled engineer to fix | ||||
|   your curl-related problems. | ||||
|  | ||||
|   We list available alternatives on the curl web site: | ||||
|   http://curl.haxx.se/support.html | ||||
|  | ||||
|   1.10 How many are using curl? | ||||
|  | ||||
|   It is impossible to tell. | ||||
|  | ||||
|   We don't know how many users that knowingly have installed and use curl. | ||||
|  | ||||
|   We don't know how many users that use curl without knowing that they are in | ||||
|   fact using it. | ||||
|  | ||||
|   We don't know how many users that downloaded or installed curl and then | ||||
|   never use it. | ||||
|  | ||||
|   Some facts to use as input to the math: | ||||
|  | ||||
|   curl packages have been downloaded from the curl.haxx.se site well over a | ||||
|   million times. 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 | ||||
|   products. More than 100 known named open source projects depend on | ||||
|   (lib)curl. | ||||
|  | ||||
|   In a poll on the curl web site mid-2005, more than 50% of the 300+ answers | ||||
|   estimated a user base of one million users or more. | ||||
|  | ||||
|   In March 2005, the "Linux Counter project" estimated a total Linux user base | ||||
|   of some 29 millions, while Netcraft detected some 4 million "active" Linux | ||||
|   based web servers. A guess is that a fair amount of these Linux | ||||
|   installations have curl installed. | ||||
|  | ||||
|   http://curl.haxx.se/docs/companies.html | ||||
|   http://curl.haxx.se/docs/programs.html | ||||
|   http://curl.haxx.se/libcurl/using/apps.html | ||||
|   http://counter.li.org/estimates.php | ||||
|   http://news.netcraft.com/archives/2005/03/14/fedora_makes_rapid_progress.html | ||||
|  | ||||
|  | ||||
| 2. Install Related Problems | ||||
|  | ||||
| @@ -514,22 +566,24 @@ FAQ | ||||
|   - Server certificate. The server you communicate with has a server | ||||
|     certificate. You can and should verify this certificate to make sure that | ||||
|     you are truly talking to the real server and not a server impersonating | ||||
|     it. The server certificate verification process is made by using a | ||||
|     Certificate Authority certificate ("CA cert") that was used to sign the | ||||
|     server certificate. Server certificate verification is enabled by default | ||||
|     in curl and libcurl and is often the reason for problems as explained in | ||||
|     FAQ entry 4.12 and the SSLCERTS document | ||||
|     (http://curl.haxx.se/docs/sslcerts.html). Server certificates that are | ||||
|     "self-signed" or otherwise signed by a CA that you do not have a CA cert | ||||
|     for, cannot be verified. If the verification during a connect fails, you | ||||
|     are refused access. You then need to explicitly disable the verification | ||||
|     to connect to the server. | ||||
|     it. | ||||
|  | ||||
|   - Certificate Authority certificate ("CA cert"). You often have several CA | ||||
|     certs in a CA cert bundle that can be used to verify a server certificate | ||||
|     that was signed by one of the authorities in the bundle. curl comes with a | ||||
|     default CA cert bundle. You can override the default. | ||||
|  | ||||
|     The server certificate verification process is made by using a Certificate | ||||
|     Authority certificate ("CA cert") that was used to sign the server | ||||
|     certificate. Server certificate verification is enabled by default in curl | ||||
|     and libcurl and is often the reason for problems as explained in FAQ entry | ||||
|     4.12 and the SSLCERTS document | ||||
|     (http://curl.haxx.se/docs/sslcerts.html). Server certificates that are | ||||
|     "self-signed" or otherwise signed by a CA that you do not have a CA cert | ||||
|     for, cannot be verified. If the verification during a connect fails, you | ||||
|     are refused access. You then need to explicitly disable the verification | ||||
|     to connect to the server. | ||||
|  | ||||
|   3.17 How do I list the root dir of an FTP server? | ||||
|  | ||||
|   There are two ways. The way defined in the RFC is to use an encoded slash | ||||
| @@ -546,6 +600,8 @@ FAQ | ||||
|   | ||||
|   No. | ||||
|  | ||||
|   But you could easily write your own program using libcurl to do such stunts. | ||||
|  | ||||
|  | ||||
| 4. Running Problems | ||||
|  | ||||
| @@ -751,11 +807,11 @@ FAQ | ||||
|   curl supports HTTP redirects fine (see item 3.8). Browsers generally support | ||||
|   at least two other ways to perform directs that curl does not: | ||||
|  | ||||
|     1 - Meta tags. You can write a HTML tag that will cause the browser to | ||||
|         redirect to another given URL after a certain time. | ||||
|   - Meta tags. You can write a HTML tag that will cause the browser to | ||||
|     redirect to another given URL after a certain time. | ||||
|  | ||||
|     2 - Javascript. You can write a javascript program embeded in a HTML page | ||||
|         that redirects the browser to another given URL. | ||||
|   - Javascript. You can write a javascript program embeded in a HTML page | ||||
|     that redirects the browser to another given URL. | ||||
|  | ||||
|   There is no way to make curl follow these redirects. You must either | ||||
|   manually figure out what the page is set to do, or you write a script that | ||||
| @@ -793,8 +849,8 @@ FAQ | ||||
|  | ||||
|   One solution to this problem could be to have a pointer to a struct that you | ||||
|   pass to the callback function. You set the pointer using the | ||||
|   curl_easy_setopt(CURLOPT_FILE) function. Then that pointer will be passed to | ||||
|   the callback instead of a FILE * to a file: | ||||
|   CURLOPT_WRITEDATA option. Then that pointer will be passed to the callback | ||||
|   instead of a FILE * to a file: | ||||
|  | ||||
|         /* imaginary struct */ | ||||
|         struct MemoryStruct { | ||||
| @@ -901,7 +957,10 @@ FAQ | ||||
|  | ||||
|   5.9 How does libcurl resolve host names? | ||||
|  | ||||
|   libcurl includes a number of different name resolve functions: | ||||
|   libcurl supports a large a number of different name resolve functions. One | ||||
|   of them is picked at build-time and will be used unconditionally. Thus, if | ||||
|   you want to change name resolver function you must rebuild libcurl and tell | ||||
|   it to use a different function. | ||||
|  | ||||
|   - The non-ipv6 resolver that can use one out of four host name resolve calls | ||||
|     (depending on what your system supports): | ||||
| @@ -914,6 +973,8 @@ FAQ | ||||
|   - The ipv6-resolver that uses getaddrinfo() | ||||
|  | ||||
|   - The c-ares based name resolver that uses the c-ares library for resolves. | ||||
|     Using this offers asynchronous name resolves but it currently has no IPv6 | ||||
|     support. | ||||
|  | ||||
|   - The Windows threaded resolver. It use: | ||||
|  | ||||
| @@ -926,8 +987,8 @@ FAQ | ||||
|   5.10 How do I prevent libcurl from writing the response to stdout? | ||||
|  | ||||
|   libcurl provides a default built-in write function that writes received data | ||||
|   to stdout. Set a WRITEFUNCTION to receive the data, or possibly set | ||||
|   WRITEDATA to a different FILE * handle. | ||||
|   to stdout. Set the CURLOPT_WRITEFUNCTION to receive the data, or possibly | ||||
|   set CURLOPT_WRITEDATA to a different FILE * handle. | ||||
|  | ||||
|   5.11 How do I make libcurl not receive the whole HTTP response? | ||||
|  | ||||
| @@ -956,6 +1017,9 @@ FAQ | ||||
|   is just a brief summary for the cases we get the most questions. (Parts of | ||||
|   this section was much enhanced by Bjorn Reese.) | ||||
|  | ||||
|   We are not lawyers and this is not legal advice. You should probably consult | ||||
|   one if you want true and accurate legal insights without our prejudice. | ||||
|  | ||||
|   6.1 I have a GPL program, can I use the libcurl library? | ||||
|  | ||||
|   Yes! | ||||
| @@ -1000,6 +1064,26 @@ FAQ | ||||
|   libraries that use it. It should be possible for everyone to use libcurl or | ||||
|   curl in their projects, no matter what license they already have in use. | ||||
|  | ||||
|   6.7 What are my obligations when using libcurl in my commerical apps? | ||||
|  | ||||
|   Next to none. All you need to adhere to is the MIT-style license (stated in | ||||
|   the COPYING file) which basically says you have to include the copyright | ||||
|   notice in "all copies" and that you may not use the copyright holder's name | ||||
|   when promoting your software. | ||||
|  | ||||
|   You do not have to release any of your source code. | ||||
|  | ||||
|   You do not have to reveal or make public any changes to the libcurl source | ||||
|   code. | ||||
|  | ||||
|   You do not have to reveal or make public that you are using libcurl within | ||||
|   your app. | ||||
|  | ||||
|   As can be seen here: http://curl.haxx.se/docs/companies.html and | ||||
|   elsewhere, more and more companies are dicovering the power | ||||
|   of libcurl and take advantage of it even in commercial environments. | ||||
|  | ||||
|  | ||||
| 7. PHP/CURL Issues | ||||
|  | ||||
|   7.1 What is PHP/CURL? | ||||
|   | ||||
| @@ -87,14 +87,16 @@ FTP | ||||
|  - via http-proxy | ||||
|  - all operations can be tunneled through a http-proxy | ||||
|  - customizable to retrieve file modification date | ||||
|  - third party transfers | ||||
|  - no dir depth limit | ||||
|  | ||||
| FTPS (*1) | ||||
|  - explicit ftps:// support that use SSL on both connections | ||||
|  - implicit "AUTH TSL" and "AUTH SSL" usage to "upgrade" plain ftp:// | ||||
|  - implicit ftps:// support that use SSL on both connections | ||||
|  - explicit "AUTH TSL" and "AUTH SSL" usage to "upgrade" plain ftp:// | ||||
|    connection to use SSL for both or one of the connections | ||||
|  | ||||
| TFTP | ||||
|  - download / upload | ||||
|  | ||||
| TELNET | ||||
|  - connection negotiation | ||||
|  - custom telnet options | ||||
| @@ -106,10 +108,6 @@ LDAP (*2) | ||||
| DICT | ||||
|  - extended DICT URL support | ||||
|  | ||||
| GOPHER | ||||
|  - GET | ||||
|  - via http-proxy | ||||
|  | ||||
| FILE | ||||
|  - URL support | ||||
|  - "uploads" | ||||
|   | ||||
							
								
								
									
										423
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										423
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -16,7 +16,6 @@ Installing Binary Packages | ||||
|  | ||||
| UNIX | ||||
| ==== | ||||
|  | ||||
|    A normal unix installation is made in three or four steps (after you've | ||||
|    unpacked the source archive): | ||||
|  | ||||
| @@ -52,12 +51,12 @@ UNIX | ||||
|    path for your compiler/linker, you don't need to do anything special. If | ||||
|    you have OpenSSL installed in /usr/local/ssl, you can run configure like: | ||||
|  | ||||
| 	./configure --with-ssl | ||||
|         ./configure --with-ssl | ||||
|  | ||||
|    If you have OpenSSL installed somewhere else (for example, /opt/OpenSSL,) | ||||
|    you can run configure like this: | ||||
|  | ||||
| 	./configure --with-ssl=/opt/OpenSSL | ||||
|         ./configure --with-ssl=/opt/OpenSSL | ||||
|  | ||||
|    If you insist on forcing a build without SSL support, even though you may | ||||
|    have OpenSSL installed in your system, you can run configure like this: | ||||
| @@ -129,180 +128,179 @@ UNIX | ||||
|      If you're a curl developer and use gcc, you might want to enable more | ||||
|      debug options with the --enable-debug option. | ||||
|  | ||||
|      curl can be built to use a whole range of libraries to provide various | ||||
|      useful services, and configure will try to auto-detect a decent | ||||
|      default. But if you want to alter it, you can select how to deal with | ||||
|      each individual library. | ||||
|  | ||||
|      To build with GnuTLS support instead of OpenSSL for SSL/TLS, note that | ||||
|      you need to use both --without-ssl and --with-gnutls. | ||||
|  | ||||
|      To build with yassl support instead of OpenSSL or GunTLS, you must build | ||||
|      yassl with its OpenSSL emulation enabled and point to that directory root | ||||
|      with configure --with-ssl. | ||||
|  | ||||
|  | ||||
| Win32 | ||||
| ===== | ||||
|  | ||||
|    Without SSL: | ||||
|    MingW32 | ||||
|    ------- | ||||
|  | ||||
|       MingW32 (GCC-2.95) style | ||||
|       ------------------------ | ||||
|         Run the 'mingw32.bat' file to get the proper environment variables | ||||
|         set, then run 'make mingw32' in the root dir. | ||||
|    Run the 'mingw32.bat' file to get the proper environment variables set, | ||||
|    then run 'make mingw32' in the root dir. Use 'make mingw32-ssl' to build | ||||
|    curl SSL enabled. | ||||
|  | ||||
|         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. | ||||
|    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. It is also possible to override these paths with  | ||||
|    environment variables, for example: | ||||
|  | ||||
|       Cygwin style | ||||
|       ------------ | ||||
|         Almost identical to the unix installation. Run the configure script in | ||||
|         the curl root with 'sh configure'. Make sure you have the sh | ||||
|         executable in /bin/ or you'll see the configure fail towards the end. | ||||
|      set ZLIB_PATH=c:\zlib-1.2.3 | ||||
|      set OPENSSL_PATH=c:\openssl-0.9.8d | ||||
|      set LIBSSH2_PATH=c:\libssh2-0.15 | ||||
|  | ||||
|         Run 'make' | ||||
|    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. | ||||
|  | ||||
|       Microsoft command line style | ||||
|       ---------------------------- | ||||
|         Run the 'vcvars32.bat' file to get the proper environment variables | ||||
|         set, then run 'nmake vc' in the root dir. | ||||
|    Cygwin | ||||
|    ------ | ||||
|  | ||||
|         The vcvars32.bat file is part of the Microsoft development | ||||
|         environment. | ||||
|    Almost identical to the unix installation. Run the configure script in the | ||||
|    curl root with 'sh configure'. Make sure you have the sh executable in | ||||
|    /bin/ or you'll see the configure fail towards the end. | ||||
|  | ||||
|       IDE-style | ||||
|       ------------------------- | ||||
|         If you use VC++, Borland or similar compilers. Include all lib source | ||||
|         files in a static lib "project" (all .c and .h files that is). | ||||
|         (you should name it libcurl or similar) | ||||
|    Run 'make' | ||||
|  | ||||
|         Make the sources in the src/ drawer be a "win32 console application" | ||||
|         project. Name it curl. | ||||
|    Dev-Cpp | ||||
|    ------- | ||||
|  | ||||
|         For VC++ 6, there's an included Makefile.vc6 that should be possible | ||||
|         to use out-of-the-box. | ||||
|    See the separate INSTALL.devcpp file for details. | ||||
|  | ||||
|    MSVC from command line | ||||
|    ---------------------- | ||||
|  | ||||
|    Run the 'vcvars32.bat' file to get a proper environment. The | ||||
|    vcvars32.bat file is part of the Microsoft development environment and | ||||
|    you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin' | ||||
|    provided that you installed Visual C/C++ 6 in the default directory. | ||||
|  | ||||
|    Then run 'nmake vc' in curl's root directory. | ||||
|  | ||||
|    If you want to compile with zlib support, you will need to build | ||||
|    zlib (http://www.gzip.org/zlib/) as well. Please read the zlib | ||||
|    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.3 | ||||
|  | ||||
|    Then run 'nmake vc-zlib' in curl's root directory. | ||||
|  | ||||
|    If you want to compile with SSL support you need the OpenSSL package. | ||||
|    Please read the OpenSSL documentation on how to compile and install | ||||
|    the OpenSSL libraries.  The build process of OpenSSL generates the | ||||
|    libeay32.dll and ssleay32.dll files in the out32dll subdirectory in | ||||
|    the OpenSSL home directory.  OpenSSL static libraries (libeay32.lib, | ||||
|    ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory. | ||||
|  | ||||
|    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.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 | ||||
|    libraries in the lib subdirectory, as well as a statically linked | ||||
|    version of curl.exe in the src subdirectory.  This statically linked | ||||
|    version is a standalone executable not requiring any DLL at | ||||
|    runtime. This make method requires that you have the static OpenSSL | ||||
|    libraries available in OpenSSL's out32 subdirectory. | ||||
|    'nmake vc-ssl-dll' creates the libcurl dynamic library and | ||||
|    links curl.exe against libcurl and OpenSSL dynamically. | ||||
|    This executable requires libcurl.dll and the OpenSSL DLLs | ||||
|    at runtime. | ||||
|    Run 'nmake vc-ssl-zlib' to build with both ssl and zlib support. | ||||
|  | ||||
|    Borland C++ compiler | ||||
|    --------------------- | ||||
|  | ||||
|    compile openssl | ||||
|  | ||||
|    Make sure you include the paths to curl/include and openssl/inc32 in | ||||
|    your bcc32.cnf file | ||||
|  | ||||
|    eg : -I"c:\Bcc55\include;c:\path_curl\include;c:\path_openssl\inc32" | ||||
|  | ||||
|    Check to make sure that all of the sources listed in lib/Makefile.b32 | ||||
|    are present in the /path_to_curl/lib directory. (Check the src | ||||
|    directory for missing ones.) | ||||
|  | ||||
|    Make sure the environment variable "BCCDIR" is set to the install | ||||
|    location for the compiler eg : c:\Borland\BCC55 | ||||
|  | ||||
|    command line: | ||||
|    make -f /path_to_curl/lib/Makefile-ssl.b32 | ||||
|  | ||||
|    compile simplessl.c with appropriate links | ||||
|  | ||||
|    c:\curl\docs\examples\> bcc32 -L c:\path_to_curl\lib\libcurl.lib | ||||
|                                  -L c:\borland\bcc55\lib\psdk\ws2_32.lib | ||||
|                                  -L c:\openssl\out32\libeay32.lib | ||||
|                                  -L c:\openssl\out32\ssleay32.lib | ||||
|                                  simplessl.c | ||||
|  | ||||
|  | ||||
|    With SSL: | ||||
|    MSVC IDE | ||||
|    -------- | ||||
|  | ||||
|       MingW32 (GCC-2.95) style | ||||
|       ------------------------ | ||||
|         Run the 'mingw32.bat' file to get the proper environment variables | ||||
|         set, then run 'make mingw32-ssl' in the root dir. | ||||
|    If you use VC++, Borland or similar compilers. Include all lib source | ||||
|    files in a static lib "project" (all .c and .h files that is). | ||||
|    (you should name it libcurl or similar) | ||||
|  | ||||
|         If you have any problems linking libraries or finding header files, be | ||||
|         sure to look at the provided "Makefile.m32" files for the proper | ||||
|         paths, and adjust as necessary. | ||||
|    Make the sources in the src/ drawer be a "win32 console application" | ||||
|    project. Name it curl. | ||||
|  | ||||
|       Cygwin style | ||||
|       ------------ | ||||
|         Haven't done, nor got any reports on how to do. It should although be | ||||
|         identical to the unix setup for the same purpose. See above. | ||||
|  | ||||
|       Microsoft command line style | ||||
|       ---------------------------- | ||||
|  | ||||
|         Run the 'vcvars32.bat' file to get a proper environment. The | ||||
|         vcvars32.bat file is part of the Microsoft development environment and | ||||
|         you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin' | ||||
|         provided that you installed Visual C/C++ 6 in the default directory. | ||||
|  | ||||
|         Then run 'nmake vc' in curl's root directory. | ||||
|  | ||||
|         If you want to compile with zlib support, you will need to build | ||||
|         zlib (http://www.gzip.org/zlib/) as well. Please read the zlib | ||||
|         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 | ||||
|  | ||||
|         Then run 'nmake vc-zlib' in curl's root directory. | ||||
|  | ||||
|         If you want to compile with SSL support you need the OpenSSL package. | ||||
|         Please read the OpenSSL documentation on how to compile and install | ||||
|         the OpenSSL libraries.  The build process of OpenSSL generates the | ||||
|         libeay32.dll and ssleay32.dll files in the out32dll subdirectory in | ||||
|         the OpenSSL home directory.  OpenSSL static libraries (libeay32.lib, | ||||
|         ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory. | ||||
|  | ||||
|         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 | ||||
|  | ||||
|         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 | ||||
|         libraries in the lib subdirectory, as well as a statically linked | ||||
|         version of curl.exe in the src subdirectory.  This statically linked | ||||
|         version is a standalone executable not requiring any DLL at | ||||
|         runtime. This make method requires that you have the static OpenSSL | ||||
|         libraries available in OpenSSL's out32 subdirectory. | ||||
|         'nmake vc-ssl-dll' creates the libcurl dynamic library and | ||||
|         links curl.exe against libcurl and OpenSSL dynamically. | ||||
|         This executable requires libcurl.dll and the OpenSSL DLLs | ||||
|         at runtime. | ||||
|         Run 'nmake vc-ssl-zlib' to build with both ssl and zlib support. | ||||
|  | ||||
|       Microsoft / Borland style | ||||
|       ------------------------- | ||||
|         If you have OpenSSL, and want curl to take advantage of it, edit your | ||||
|         project properties to use the SSL include path, link with the SSL libs | ||||
|         and define the USE_SSLEAY symbol. | ||||
|  | ||||
|       Using Borland C++ compiler version 5.5.1 (available as free download | ||||
|       from Borland's site) | ||||
|       --------------------------------------------------------------------- | ||||
|  | ||||
|         compile openssl | ||||
|  | ||||
|         Make sure you include the paths to curl/include and openssl/inc32 in | ||||
|         your bcc32.cnf file | ||||
|    For VC++ 6, there's an included Makefile.vc6 that should be possible | ||||
|    to use out-of-the-box. | ||||
|  | ||||
|  | ||||
|         eg : -I"c:\Bcc55\include;c:\path_curl\include;c:\path_openssl\inc32" | ||||
|    Disabling Specific Protocols in Win32 builds | ||||
|    -------------------------------------------- | ||||
|  | ||||
|         Check to make sure that all of the sources listed in lib/Makefile.b32 | ||||
|         are present in the /path_to_curl/lib directory. (Check the src | ||||
|         directory for missing ones.) | ||||
|    The configure utility, unfortunately, is not available for the Windows | ||||
|    environment, therefore, you cannot use the various disable-protocol | ||||
|    options of the configure utility on this platform. | ||||
|  | ||||
|         Make sure the environment variable "BCCDIR" is set to the install | ||||
|         location for the compiler eg : c:\Borland\BCC55 | ||||
|    However, you can use the following defines to disable specific | ||||
|    protocols: | ||||
|  | ||||
|         command line: | ||||
|         make -f /path_to_curl/lib/Makefile-ssl.b32 | ||||
|    HTTP_ONLY             disables all protocols except HTTP | ||||
|    CURL_DISABLE_FTP      disables FTP | ||||
|    CURL_DISABLE_LDAP     disables LDAP | ||||
|    CURL_DISABLE_TELNET   disables TELNET | ||||
|    CURL_DISABLE_DICT     disables DICT | ||||
|    CURL_DISABLE_FILE     disables FILE | ||||
|  | ||||
|         compile simplessl.c with appropriate links | ||||
|    If you want to set any of these defines you have the following | ||||
|    possibilities: | ||||
|  | ||||
|         c:\curl\docs\examples\> bcc32 -L c:\path_to_curl\lib\libcurl.lib | ||||
|                                       -L c:\borland\bcc55\lib\psdk\ws2_32.lib | ||||
|                                       -L c:\openssl\out32\libeay32.lib | ||||
|                                       -L c:\openssl\out32\ssleay32.lib | ||||
|                                       simplessl.c | ||||
|  | ||||
|    Disabling Specific Protocols: | ||||
|  | ||||
|       The configure utility, unfortunately, is not available for the Windows | ||||
|       environment, therefore, you cannot use the various disable-protocol | ||||
|       options of the configure utility on this platform. | ||||
|  | ||||
|       However, you can use the following defines to disable specific | ||||
|       protocols: | ||||
|  | ||||
|       HTTP_ONLY             disables all protocols except HTTP | ||||
|       CURL_DISABLE_FTP      disables FTP | ||||
|       CURL_DISABLE_LDAP     disables LDAP | ||||
|       CURL_DISABLE_TELNET   disables TELNET | ||||
|       CURL_DISABLE_DICT     disables DICT | ||||
|       CURL_DISABLE_FILE     disables FILE | ||||
|       CURL_DISABLE_GOPHER   disables GOPHER | ||||
|  | ||||
|       If you want to set any of these defines you have the following | ||||
|       possibilities: | ||||
|  | ||||
|       - Modify lib/setup.h | ||||
|       - Modify lib/Makefile.vc6 | ||||
|       - Add defines to Project/Settings/C/C++/General/Preprocessor Definitions | ||||
|         in the curllib.dsw/curllib.dsp Visual C++ 6 IDE project. | ||||
|    - Modify lib/setup.h | ||||
|    - Modify lib/Makefile.vc6 | ||||
|    - Add defines to Project/Settings/C/C++/General/Preprocessor Definitions | ||||
|      in the curllib.dsw/curllib.dsp Visual C++ 6 IDE project. | ||||
|  | ||||
|  | ||||
|    Important (with SSL or not): | ||||
|       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. | ||||
|    Important static libcurl usage note | ||||
|    ----------------------------------- | ||||
|  | ||||
|    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. | ||||
|  | ||||
|  | ||||
| IBM OS/2 | ||||
| ======== | ||||
|  | ||||
|    Building under OS/2 is not much different from building under unix. | ||||
|    You need: | ||||
|  | ||||
| @@ -330,6 +328,7 @@ IBM OS/2 | ||||
|    If you're getting huge binaries, probably your makefiles have the -g in | ||||
|    CFLAGS. | ||||
|  | ||||
|  | ||||
| VMS | ||||
| === | ||||
|    (The VMS section is in whole contributed by the friendly Nico Baggus) | ||||
| @@ -400,6 +399,7 @@ VMS | ||||
|    13-jul-2001 | ||||
|    N. Baggus | ||||
|  | ||||
|  | ||||
| QNX | ||||
| === | ||||
|    (This section was graciously brought to us by David Bentham) | ||||
| @@ -451,17 +451,16 @@ AmigaOS | ||||
|  | ||||
| NetWare | ||||
| ======= | ||||
|  | ||||
|    To compile curl.nlm / libcurl.nlm you need: | ||||
|    - either any gcc / nlmconv, or CodeWarrior 7 PDK 4 or later. | ||||
|    - gnu make and awk running on the platform you compile on; | ||||
|      native Win32 versions can be downloaded from: | ||||
|      http://www.gknw.com/development/prgtools/ | ||||
|      http://www.gknw.net/development/prgtools/ | ||||
|    - recent Novell LibC SDK available from: | ||||
|      http://developer.novell.com/ndk/libc.htm | ||||
|    - optional zlib sources (at the moment only dynamic linking with zlib.imp); | ||||
|      sources with NetWare Makefile can be obtained from: | ||||
|      http://www.gknw.com/mirror/zlib/ | ||||
|      http://www.gknw.net/mirror/zlib/ | ||||
|    - optional OpenSSL sources (version 0.9.8 or later which builds with BSD); | ||||
|  | ||||
|    Set a search path to your compiler, linker and tools; on Linux make | ||||
| @@ -475,14 +474,101 @@ NetWare | ||||
|    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked... | ||||
|    Any help in testing appreciated! | ||||
|    Builds automatically created 8 times a day from current CVS are here: | ||||
|    http://www.gknw.com/mirror/curl/autobuilds/ | ||||
|    http://www.gknw.net/mirror/curl/autobuilds/ | ||||
|    the status of these builds can be viewed at the autobuild table: | ||||
|    http://curl.haxx.se/auto/ | ||||
|  | ||||
|  | ||||
| eCos | ||||
| ==== | ||||
|    curl does not use the eCos build system, so you must first build eCos | ||||
|    separately, then link curl to the resulting eCos library.  Here's a sample | ||||
|    configure line to do so on an x86 Linux box targeting x86: | ||||
|  | ||||
|    GCCLIB=`gcc -print-libgcc-file-name` && \ | ||||
|    CFLAGS="-D__ECOS=1 -nostdinc -I$ECOS_INSTALL/include \ | ||||
|     -I`dirname $GCCLIB`/include" \ | ||||
|    LDFLAGS="-nostdlib -Wl,--gc-sections -Wl,-static \ | ||||
|     -L$ECOS_INSTALL/lib -Ttarget.ld -ltarget" \ | ||||
|    ./configure --host=i386 --disable-shared \ | ||||
|     --without-ssl --without-zlib --disable-manual --disable-ldap | ||||
|  | ||||
|    In most cases, eCos users will be using libcurl from within a custom | ||||
|    embedded application.  Using the standard 'curl' executable from | ||||
|    within eCos means facing the limitation of the standard eCos C | ||||
|    startup code which does not allow passing arguments in main().  To | ||||
|    run 'curl' from eCos and have it do something useful, you will need | ||||
|    to either modify the eCos startup code to pass in some arguments, or | ||||
|    modify the curl application itself to retrieve its arguments from | ||||
|    some location set by the bootloader or hard-code them. | ||||
|  | ||||
|    Something like the following patch could be used to hard-code some | ||||
|    arguments.  The MTAB_ENTRY line mounts a RAM disk as the root filesystem | ||||
|    (without mounting some kind of filesystem, eCos errors out all file | ||||
|    operations which curl does not take to well).  The next section synthesizes | ||||
|    some command-line arguments for curl to use, in this case to direct curl | ||||
|    to read further arguments from a file.  It then creates that file on the | ||||
|    RAM disk and places within it a URL to download: a file: URL that | ||||
|    just happens to point to the configuration file itself.  The results | ||||
|    of running curl in this way is the contents of the configuration file | ||||
|    printed to the console. | ||||
|  | ||||
| --- src/main.c	19 Jul 2006 19:09:56 -0000	1.363 | ||||
| +++ src/main.c	24 Jul 2006 21:37:23 -0000 | ||||
| @@ -4286,11 +4286,31 @@ | ||||
|  } | ||||
|   | ||||
|   | ||||
| +#ifdef __ECOS | ||||
| +#include <cyg/fileio/fileio.h> | ||||
| +MTAB_ENTRY( testfs_mte1, | ||||
| +                   "/", | ||||
| +                   "ramfs", | ||||
| +                   "", | ||||
| +                   0); | ||||
| +#endif | ||||
|   | ||||
|  int main(int argc, char *argv[]) | ||||
|  { | ||||
|    int res; | ||||
|    struct Configurable config; | ||||
| +#ifdef __ECOS | ||||
| +  char *args[] = {"ecos-curl", "-K", "curlconf.txt"}; | ||||
| +  FILE *f; | ||||
| +  argc = sizeof(args)/sizeof(args[0]); | ||||
| +  argv = args; | ||||
| + | ||||
| +  f = fopen("curlconf.txt", "w"); | ||||
| +  if (f) { | ||||
| +    fprintf(f, "--url file:curlconf.txt"); | ||||
| +    fclose(f); | ||||
| +  } | ||||
| +#endif | ||||
|    memset(&config, 0, sizeof(struct Configurable)); | ||||
|   | ||||
|    config.errors = stderr; /* default errors to stderr */ | ||||
|  | ||||
|  | ||||
| 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: | ||||
|  | ||||
|      chmem =2048000 /usr/local/bin/bash | ||||
|  | ||||
|    Make sure gcc and bash are in the PATH then configure curl with a | ||||
|    command like this: | ||||
|  | ||||
|      ./configure GREP=/usr/bin/grep AR=/usr/gnu/bin/gar --disable-ldap | ||||
|  | ||||
|    Then simply run 'make'. | ||||
|  | ||||
|  | ||||
| CROSS COMPILE | ||||
| ============= | ||||
|  | ||||
|    (This section was graciously brought to us by Jim Duey, with additions by | ||||
|    Dan Fandrich) | ||||
|  | ||||
| @@ -528,13 +614,17 @@ CROSS COMPILE | ||||
|  | ||||
|        ./configure --host=ARCH-OS | ||||
|  | ||||
|  | ||||
| REDUCING SIZE | ||||
| ============= | ||||
|    There are a number of configure options that can be used to reduce the | ||||
|    size of libcurl for embedded applications where binary size is an | ||||
|    important factor.  First, be sure to set the CFLAGS environment variable | ||||
|    when configuring with any compiler optimization flags to reduce the | ||||
|    size of the binary.  For gcc, this would mean at minimum: | ||||
|    important factor.  First, be sure to set the CFLAGS variable when | ||||
|    configuring with any relevant compiler optimization flags to reduce the | ||||
|    size of the binary.  For gcc, this would mean at minimum the -Os option | ||||
|    and probably the -march=X option as well, e.g.: | ||||
|  | ||||
|       env CFLAGS='-Os' ./configure ... | ||||
|       ./configure CFLAGS='-Os' ... | ||||
|  | ||||
|    Be sure to specify as many --disable- and --without- flags on the configure | ||||
|    command-line as you can to disable all the libcurl features that you | ||||
| @@ -548,10 +638,24 @@ CROSS COMPILE | ||||
|      --disable-crypto-auth (disables HTTP cryptographic authentication) | ||||
|      --disable-ipv6 (disables support for IPv6) | ||||
|      --disable-verbose (eliminates debugging strings and error code strings) | ||||
|      --enable-hidden-symbols (eliminates unneeded symbols in the shared library) | ||||
|      --without-libidn (disables support for the libidn DNS library) | ||||
|      --without-ssl (disables support for SSL/TLS) | ||||
|      --without-zlib (disables support for on-the-fly decompression) | ||||
|  | ||||
|    The GNU linker has a number of options to reduce the size of the libcurl | ||||
|    dynamic libraries on some platforms even further. Specify them by giving | ||||
|    the options -Wl,-Bsymbolic and -Wl,-s on the gcc command-line.   | ||||
|    Be sure also to strip debugging symbols from your binaries after | ||||
|    compiling using 'strip' (or the appropriate variant if cross-compiling). | ||||
|    If space is really tight, you may be able to remove some unneeded | ||||
|    sections of the shared library using the -R option to objcopy (e.g. the | ||||
|    .comment section). | ||||
|  | ||||
|    Using these techniques it is possible to create an HTTP-only shared | ||||
|    libcurl library for i386 Linux platforms that is less than 90 KB in | ||||
|    size (as of version 7.15.4). | ||||
|  | ||||
|    You may find that statically linking libcurl to your application will | ||||
|    result in a lower total size. | ||||
|  | ||||
| @@ -581,6 +685,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 | ||||
| @@ -589,12 +694,15 @@ PORTS | ||||
|         - StrongARM/ARM7/ARM9 Linux 2.4, 2.6 | ||||
|         - StrongARM NetBSD 1.4.1 | ||||
|         - Ultrix 4.3a | ||||
|         - UNICOS 9.0 | ||||
|         - i386 BeOS | ||||
|         - i386 DOS | ||||
|         - i386 eCos 1.3.1 | ||||
|         - i386 Esix 4.1 | ||||
|         - i386 FreeBSD | ||||
|         - i386 HURD | ||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 | ||||
|         - i386 MINIX 3.1.2 | ||||
|         - i386 NetBSD | ||||
|         - i386 Novell NetWare | ||||
|         - i386 OS/2 | ||||
| @@ -619,3 +727,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 | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										302
									
								
								docs/INSTALL.devcpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										302
									
								
								docs/INSTALL.devcpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,302 @@ | ||||
| DevCpp-Mingw Install & Compilation                                   Sept 2005 | ||||
| ================================== | ||||
|  | ||||
| Reference Emails available at curl@haxx.se:  | ||||
|  | ||||
|   Libcurl Install and Use Issues | ||||
|   Awaiting an Answer for Win 32 Install  | ||||
|   res = curl_easy_perform(curl); Error | ||||
|   Makefile Issues | ||||
|    | ||||
|  | ||||
| Having previously done a thorough review of what was available that met my | ||||
| requirements under GPL, I settled for Libcurl as the software of choice for | ||||
| many reasons not the least of which was the support. | ||||
|  | ||||
| Background | ||||
| ---------- | ||||
|  | ||||
| This quest started when I innocently tried to incorporate the libcurl library | ||||
| into my simple source code. I figured that a few easy steps would accomplish | ||||
| this without major headaches. I had no idea that I would be facing an almost | ||||
| insurmountable challenge. | ||||
|  | ||||
| The main problem lies in two areas. First the bulk of support for libcurl | ||||
| exists for a Unix/linux command line environments. This is of little help when | ||||
| it comes to Windows O/S. | ||||
|  | ||||
| Secondly the help that does exist for the Windows O/S focused around mingw | ||||
| thru a command line argument environment. | ||||
|  | ||||
| You may ask "Why is this a problem?" | ||||
|  | ||||
| I'm using a Windows O/S with DevCpp. For those of you who are unfamiliar with | ||||
| DevCpp, it is a window shell GUI that replaces the command line environment | ||||
| for gcc. A definite improvement that I am unwilling to give up. However using | ||||
| DevCpp presented its own set of issues. Inadvertently I also made some | ||||
| careless errors such as compiling the 7.14 version of Makefile with an older | ||||
| version of source code. Thanks to Dan Fandrich for picking this up. | ||||
|  | ||||
| I did eventually with the help of Daniel, Phillipe and others manage to | ||||
| implement successfully (the only mingw available version) | ||||
| curl-7.13.0-win32-ssl-devel-mingw32 into the DevCpp environment. Only the | ||||
| dynamic libcurl.dll libcurldll.a libraries worked. The static library which I | ||||
| was interested in did not. Furthermore when I tried to implement one of the | ||||
| examples included with the curl package (get info.c) it caused the executable | ||||
| to crash. Tracing the bug I found it in the code and function res = | ||||
| curl_easy_perform(curl);. | ||||
|  | ||||
| At this point I had to make a choice as to whether invest my limited | ||||
| time-energy resource to fixing the bug or to compile the new version | ||||
| available. After searching the archives I found a very similar or the same bug | ||||
| reported from version 7.12x on. Daniel did inform me that he thought that this | ||||
| bug had been fixed with the latest version. So I proceeded to compile the | ||||
| latest SSL version where I faced other challenges. | ||||
|  | ||||
| In order to make this process unremarkable for others using the same | ||||
| environment I decided to document the process so that others will find it | ||||
| routine. It would be a shame if newbies could not implement this excellent | ||||
| package for their use. | ||||
|  | ||||
| I would like to thank the many others in this forum and in the DevCpp forum | ||||
| for their help. Without your help I may either have given up or it would have | ||||
| taken me many times longer to achieve success. | ||||
|  | ||||
| The Cookbook Approach | ||||
| --------------------- | ||||
|  | ||||
| This discussion will be confined to a SSL static library compilation and | ||||
| installation. Limited mention and comments will be inserted where appropriate | ||||
| to help with non-SSL, dynamic libraries and executables. | ||||
|  | ||||
|  | ||||
|    Using Makefile from DevCpp to compile Libcurl libraries | ||||
|  | ||||
| Preamble | ||||
| -------- | ||||
|  | ||||
| Using the latest version release - curl-7.14.0.tar.gz. Curl source code is | ||||
| platform independent. This simply means that the source code can be compiled | ||||
| for any Operating System (Linux/Unix Windows etc. and variations of thereof). | ||||
|  | ||||
| The first thing to note is that inside curl-7.14.0 you will find two folders | ||||
| lib and src. Both contain Makefile.m32 (required for win mingw library or exe | ||||
| compilation) files which are different. The main difference between these two | ||||
| folders and the makefiles is that the src folder contents are used to compile | ||||
| an executable file(curl.exe) while the lib folder contents are used to compile | ||||
| a static (libcurl.a) and dynamic (libcurl.dll & libcurldll.a) file that can be | ||||
| used to compile libcurl with your own source code so that one can use and | ||||
| access all libcurl functions. | ||||
|  | ||||
| Before we start please make sure that DevCpp is installed properly. In | ||||
| particular make sure you have no spaces in the name of any of the directories | ||||
| and subdirectories where DevCpp is installed. Failure to comply with the | ||||
| install instructions may produce erratic behaviour in DevCpp. For further info | ||||
| check the following sites | ||||
|  | ||||
| http://aditsu.freeunixhost.com/dev-cpp-faq.html | ||||
| http://sourceforge.net/forum/message.php?msg_id=3252213 | ||||
|  | ||||
| As I have mentioned before I will confine this to the SSL Library compilations | ||||
| but the process is very similar for compilation of the executable - curl.exe; | ||||
| just substitute the src folder makefile in its stead. | ||||
|  | ||||
| First use a text processor Notepad, or your own favourite text processor. To | ||||
| engage your favourite text processor, select Makefile.m32 click once with your | ||||
| mouse on file icon; icon turns blue, press the shift key and right-click on | ||||
| mouse, menu appears select "Open with", select your favourite text processor. | ||||
|  | ||||
| Next read the contents of Makefile.m32. It includes instructions on its use. | ||||
|  | ||||
| Method I - DOS Command Line | ||||
| --------------------------- | ||||
|   | ||||
| Note - The only reason I have included this method is that Method II which is | ||||
| the preferred method for compiling does not allow for the setting of option | ||||
| switches (e.g. SSL = 1 or SSL =0). At least that's what they tell me at the | ||||
| Dev-Cpp forum. | ||||
|  | ||||
| 1 - Make a copy of (D:\Dev-Cpp\bin) bin folder and name it "bin Original" | ||||
| place it in the Dev-Cpp installed directory (D:\Dev-Cpp\ for this example) | ||||
|  | ||||
| 2 - Copy the entire contents of the LIB folder of curl-7.14.0.tar.gz or zip | ||||
| version into the bin folder above (D:\Dev-Cpp\bin). The reason being is that | ||||
| the make.exe file resides in this folder. Make.exe will use - Makefile.m32, | ||||
| Makefile.inc, and the source code included in the lib folder to compile the | ||||
| source code. There is a PATH issue with make.exe that remains unresolved at | ||||
| least for me. Unless the entire source code to be compiled is placed entirely | ||||
| within the directory of make.exe an error message will be generated - "file | ||||
| xxxx.yyy not available". | ||||
|  | ||||
| 3- Go to Dev-Cpp\bin and double click on make .exe. You will see a DOS window | ||||
| quickly pop up and close very quickly. Not to worry! Please do not skip this | ||||
| step. | ||||
|  | ||||
| 4- Click on the start button\Programs\MS-DOS Prompt.Once the DOS Window is up | ||||
| Type the disk drive letter (e.g. E: ) engage the enter button. The path should | ||||
| automatically take you to the directory of the make.exe file. | ||||
|  | ||||
| 5- To compile the source code simply type at the DOS prompt make -f | ||||
| Makefile.m32 as per instructions contained in the Makefile.m32 file (use any | ||||
| text processor to read instructions). I don't believe that this makefile | ||||
| allows for the option of non SSL. Ignore any warnings. | ||||
|  | ||||
| 6- Collect and make copies of libcurl.a, libcurl.dll, libcurldll.a and any *.o | ||||
| compilations you might need in another directory outside of the bin directory | ||||
| as you will need this files shortly to set up libcurl for use with | ||||
| Dev-cpp. For most apps *.o is not required. Later on we will show what to do | ||||
| with these files. | ||||
|  | ||||
| 7- You are finished but before closing we need to do cleanup - erase the bin | ||||
| folder and rename the "bin Original" folder created in step 1 to bin. | ||||
|  | ||||
| Note to compile a curl executable the process is probably similar but instead | ||||
| of using the LIB folder contents use the SRC folder contents and Makefiles in | ||||
| curl-7.14.0.tar.gz. File directories relative placements must be respected for | ||||
| compiling to take place successfully. This may not be possible with the PATH | ||||
| problem that make.exe experiences. If anyone has solved this PATH issue and | ||||
| please make sure it actually works on Win 9x/2000/XP before letting me | ||||
| know. Then please let me or Daniel in on the solution so that it can be | ||||
| included with these instructions. Thanks. | ||||
|  | ||||
| or | ||||
|  | ||||
| Method II - Dev-Cpp GUI | ||||
| ----------------------- | ||||
|  | ||||
| 1- Copy the entire contents of the LIB folder of curl-7.14.0.tar.gz or zip | ||||
| version into any folder outside of (Dev-Cpp\bin). | ||||
|  | ||||
| 2- Drop the File/New/click on Project. | ||||
|  | ||||
| 3- New Project Dialogue box appears. Double click on the Static Library. | ||||
|  | ||||
| 4- Create Project Dialogue box appears. Select the LIB folder location to | ||||
| place and locate your Project File Name. Placing the Project File Name | ||||
| elsewhere may cause problems (PATH issue problem again). | ||||
|  | ||||
| 5- Drop down the Project/Project Options. Project Options Dialogue box | ||||
| appears. | ||||
|  | ||||
| 6- Select the Makefile tab in the Project Options Dialogue Box. Check Box - | ||||
| Use Custom Makefile. Click on the Folder icon at the extreme right of the | ||||
| Check Box. Select Makefile.m32 in the folder wherever you have placed the | ||||
| contents of the LIB Folder. Press OK and close the Dialogue Box. | ||||
|  | ||||
| 7- Drop the Menu Project/Click on Add to Project. Open File Dialogue Box | ||||
| appears.  The Dialogue Box should open in the folder wherever you have placed | ||||
| the contents of the LIB Folder. If not go there. | ||||
|  | ||||
| 8- Select Crtl-A to select all files in the LIB folder. Click on open to add | ||||
| files and close box. Wait till all files are added. This may take 30 seconds | ||||
| or longer. | ||||
|  | ||||
| 9- Drop the Menu Execute/Click on Compile.  | ||||
|  | ||||
| 10- That's it. | ||||
|  | ||||
|  | ||||
|    The following steps must be completed if Curl is to work properly | ||||
|    ================================================================= | ||||
|  | ||||
| LIB folder inclusions (*.a placement) | ||||
| ------------------------------------- | ||||
|  | ||||
| 1- Refer to Method I - DOS Command Line point # 6 Take libcurl.a, libcurldll.a | ||||
| and install it in the directory C( or whichever drive Dev is installed) | ||||
| :\Dev-Cpp\lib. | ||||
|  | ||||
|  | ||||
| Include Folder | ||||
| -------------- | ||||
|  | ||||
| 1- Create a new folder by the name of curl (do not change the name curl to | ||||
| some other name as it will cause major issues) in the directory | ||||
| C:\Dev-Cpp\include. | ||||
|  | ||||
| 2- Copy the entire contents of the curl folder of curl-7.14.0.tar.gz or zip | ||||
|  version into the newly created curl directory - C:\Dev-Cpp\include\curl. | ||||
|  | ||||
| Links To Include And Lib Folder | ||||
| ------------------------------- | ||||
|  | ||||
| 1- Drop the Menu - Tools\Compiler Options\Directories\Libraries. Make sure | ||||
| that C( or whichever drive Dev is installed):\DEV-CPP\lib is included. | ||||
|  | ||||
| 2- Next select the Menu - Tools\Compiler Options\Directories\C Includes. Make | ||||
| sure that C:\DEV-CPP\include and C:\Dev-Cpp\include\curl are included. | ||||
|  | ||||
| 3- Next select the Menu - Tools\Compiler Options\Directories\C++ | ||||
| Includes. Make sure that C:\DEV-CPP\include and C:\Dev-Cpp\include\curl are | ||||
| included. | ||||
|  | ||||
| Linker Links | ||||
| ------------ | ||||
|  | ||||
| 1- Drop the Menu - Tools\Compiler Options\Directories\Compiler. | ||||
|  | ||||
| 2- Make sure that the box "Add these commands to the linker command line" is | ||||
| checked. | ||||
|  | ||||
| 3- Include in the white space immediately below the box referred in 2 -lcurl | ||||
| -lws2_32 -lwinmm. | ||||
|  | ||||
| SSL Files | ||||
| --------- | ||||
|  | ||||
| 1- Get the latest openSSL (as of time of this writing) | ||||
| openssl-0.9.7e-win32-bin.zip for the minimalist package of the openssl-0.9.7e | ||||
| binaries ported to MS Windows 95/98/NT/XP using the MingW32/GCC-3.1 | ||||
| development environment. The file may be downloaded at | ||||
| http://curl.haxx.se/download/. | ||||
|  | ||||
| 2- Open the above zip file. You will find two files - SDL.dll, | ||||
| SDL_mixer.dll. Install them in the directory C:\WINDOWS\SYSTEM32 for Win 9x | ||||
| users and c:\winnt\system32 for NT-family users. | ||||
|  | ||||
| Multithreading Files | ||||
| -------------------- | ||||
|  | ||||
| To be completed | ||||
|  | ||||
| #define | ||||
| ------- | ||||
|  | ||||
| 1- Make sure that your program includes the following - #define CURL_STATICLIB | ||||
| must be declared FIRST before any other define functions may be | ||||
| added. Otherwise you may experience link errors. | ||||
|  | ||||
| 2- Don't forget to include   #include "curl/curl.h". | ||||
|  | ||||
| e.g. | ||||
|     #define CURL_STATICLIB  | ||||
| #include <windows.h> | ||||
|     #include "curl/curl.h" | ||||
| #include <fstream> | ||||
| #include <iostream> | ||||
| #include <vector> | ||||
| etc... | ||||
|  | ||||
|  | ||||
| Static or Dynamic Library | ||||
| ------------------------- | ||||
|  | ||||
| The above steps apply for the use by a static library. Should you choose to | ||||
| use a dynamic library you will be required to perform these additional steps. | ||||
|  | ||||
| 1- Refer to Method I - DOS Command Line point # 6. Install libcurl.dll in the | ||||
| directory C:\WINDOWS\SYSTEM32 for Win 9x users and c:\winnt\system32 for | ||||
| NT-family users. | ||||
|  | ||||
| 2- Refer to Linker Links point 3 - Replace -lcurl with -lcurldll. | ||||
|  | ||||
| Voila you're done. | ||||
|  | ||||
| The non-SSL static Library build may not be possible to use at least as of the | ||||
| time of this writing - v7.14. Check reference emails - Phillipe and I found it | ||||
| impossible to fully compile as certain files were missing for linking. No big | ||||
| loss as SSL is a major plus. | ||||
|  | ||||
| Hope this Helps | ||||
|  | ||||
| Tom | ||||
| @@ -3,25 +3,71 @@ 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! | ||||
|  | ||||
| 41. Jeff Pohlmeyer's curl_multi_socket crashing case. Recipe and instructions | ||||
|   here: http://curl.haxx.se/mail/lib-2007-01/0022.html | ||||
|  | ||||
| 40. HTTP Pipelining, NULL content | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1631566 | ||||
|  | ||||
| 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. | ||||
|  | ||||
| 34. The SOCKS4 connection codes don't properly acknowledge (connect) timeouts. | ||||
|   Also see #12. According to bug #1556528, even the SOCKS5 connect code does | ||||
|   not do it right: http://curl.haxx.se/bug/view.cgi?id=1556528, | ||||
|  | ||||
| 33. Doing multi-pass HTTP authentication on a non-default port does not work. | ||||
|   This happens because the multi-pass code abuses the redirect following code | ||||
|   for doing multiple requests, and when we following redirects to an absolute | ||||
|   URL we must use the newly specified port and not the one specified in the | ||||
|   original URL. A proper fix to this would need to separate the negotiation | ||||
|   "redirect" from an actual redirect. | ||||
|  | ||||
| 32. (At least on Windows) If libcurl is built with c-ares and there's no DNS | ||||
|   server configured in the system, the ares_init() call fails and thus | ||||
|   curl_easy_init() fails as well. This causes weird effects for people who use | ||||
|   numerical IP addresses only. | ||||
|  | ||||
| 31. "curl-config --libs" will include details set in LDFLAGS when configure is | ||||
|   run that might be needed only for building libcurl. Similarly, it might | ||||
|   include options that perhaps aren't suitable both for static and dynamic | ||||
|   linking. Further, curl-config --cflags suffers from the same effects with | ||||
|   CFLAGS/CPPFLAGS. | ||||
|  | ||||
| 30. You need to use -g to the command line tool in order to use RFC2732-style | ||||
|   IPv6 numerical addresses in URLs. | ||||
|  | ||||
| 29. IPv6 URLs with zone ID is not supported. | ||||
|   http://www.ietf.org/internet-drafts/draft-fenner-literal-zone-02.txt | ||||
|   specifies the use of a plus sign instead of a percent when specifying zone | ||||
|   IDs in URLs to get around the problem of percent signs being | ||||
|   special. According to the reporter, Firefox deals with the URL _with_ a | ||||
|   percent letter (which seems like a blatant URL spec violation). | ||||
|  | ||||
|    See http://curl.haxx.se/bug/view.cgi?id=1371118 | ||||
|  | ||||
| 26. NTLM authentication using SSPI (on Windows) when (lib)curl is running in | ||||
|   "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. There's work in progress on this problem, and a recent | ||||
|   patch was posted here: http://curl.haxx.se/mail/lib-2005-08/0074.html | ||||
|  | ||||
| 24. Harshal Pradhan's Use-after-free with libcurl+ares. This probably occurs | ||||
|   because there is a pending ares callback that gets called after the | ||||
|   connection struct has been freed in libcurl: | ||||
|         http://curl.haxx.se/mail/lib-2005-08/0022.html | ||||
|   Fixing this properly most likely requires a new c-ares function. | ||||
|  | ||||
| 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. | ||||
|   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 | ||||
|  | ||||
| 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 | ||||
| @@ -38,11 +84,7 @@ may have been fixed since this was written! | ||||
|      specification).  The receiver will convert the data from the standard | ||||
|      form to his own internal form. | ||||
|  | ||||
| 19. FTP 3rd party transfers with the multi interface doesn't work. Test: | ||||
|   define CURL_MULTIEASY, rebuild curl, run test case 230 - 232. | ||||
|  | ||||
| 18. test case 57 has </test> that should be </client> but when corrected, the | ||||
|   test case fails! | ||||
|    Since 7.15.4 at least line endings are converted. | ||||
|  | ||||
| 16. FTP URLs passed to curl may contain NUL (0x00) in the RFC 1738 <user>, | ||||
|   <password>, and <fpath> components, encoded as "%00".  The problem is that | ||||
| @@ -65,7 +107,7 @@ may have been fixed since this was written! | ||||
|  | ||||
| 12. When connecting to a SOCKS proxy, the (connect) timeout is not properly | ||||
|   acknowledged after the actual TCP connect (during the SOCKS "negotiate" | ||||
|   phase). Pointed out by Lucas. Fix: need to select() and timeout properly. | ||||
|   phase). | ||||
|  | ||||
| 11. Using configure --disable-[protocol] may cause 'make test' to fail for | ||||
|   tests using the disabled protocol(s). | ||||
| @@ -76,10 +118,6 @@ may have been fixed since this was written! | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1004841. How? | ||||
|   http://curl.haxx.se/mail/lib-2004-08/0182.html | ||||
|  | ||||
| 9. --limit-rate using -d or -F does not work. This is because the limit logic | ||||
|   is provided by the curl app in its read/write callbacks, and when doing | ||||
|   -d/-F the callbacks aren't used! http://curl.haxx.se/bug/view.cgi?id=921395 | ||||
|  | ||||
| 8. Doing resumed upload over HTTP does not work with '-C -', because curl | ||||
|   doesn't do a HEAD first to get the initial size. This needs to be done | ||||
|   manually for HTTP PUT resume to work, and then '-C [index]'. | ||||
| @@ -101,8 +139,6 @@ may have been fixed since this was written! | ||||
|   libcurl thinks of it as the *compressed* length. Some explanations are here: | ||||
|   http://curl.haxx.se/mail/lib-2003-06/0146.html | ||||
|  | ||||
| 3. GOPHER transfers seem broken | ||||
|  | ||||
| 2. If a HTTP server responds to a HEAD request and includes a body (thus | ||||
|   violating the RFC2616), curl won't wait to read the response but just stop | ||||
|   reading and return back. If a second request (let's assume a GET) is then | ||||
|   | ||||
| @@ -32,7 +32,8 @@ OpenSSL http://www.openssl.org/source/license.html | ||||
|         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 | ||||
|         licensing is a problem for you, consider using GnuTLS instead. | ||||
|         licensing is a problem for you, consider using GnuTLS or yassl | ||||
|         instead. | ||||
|  | ||||
| GnuTLS  http://www.gnutls.org/ | ||||
|  | ||||
| @@ -41,6 +42,11 @@ GnuTLS  http://www.gnutls.org/ | ||||
|         GnuTLS itself depends on and uses other libs (libgcrypt and | ||||
|         libgpg-error) and they too are LGPL- or GPL-licensed. | ||||
|  | ||||
| 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. | ||||
|  | ||||
| c-ares  http://daniel.haxx.se/projects/c-ares/license.html | ||||
|  | ||||
|         (Used for asynchronous name resolves) Uses an MIT license that is very | ||||
| @@ -56,9 +62,9 @@ krb4 | ||||
|  | ||||
|         While nothing in particular says that a Kerberos4 library must use any | ||||
|         particular license, the one I've tried and used successfully so far | ||||
|         (kth-krb4) is Original BSD-licensed with the announcement clause. Some | ||||
|         of the code in libcurl that is written to deal with Kerberos4 likewise | ||||
|         have such a license. | ||||
|         (kth-krb4) is partly Original BSD-licensed with the announcement | ||||
|         clause. Some of the code in libcurl that is written to deal with | ||||
|         Kerberos4 is Modified BSD-licensed. | ||||
|  | ||||
| MIT Kerberos http://web.mit.edu/kerberos/www/dist/ | ||||
|  | ||||
|   | ||||
							
								
								
									
										43
									
								
								docs/MANUAL
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								docs/MANUAL
									
									
									
									
									
								
							| @@ -23,10 +23,6 @@ SIMPLE USAGE | ||||
|  | ||||
|         curl ftp://cool.haxx.se/ | ||||
|  | ||||
|   Get a gopher document from funet's gopher server: | ||||
|  | ||||
|         curl gopher://gopher.funet.fi | ||||
|  | ||||
|   Get the definition of curl from a dictionary: | ||||
|  | ||||
|         curl dict://dict.org/m:curl | ||||
| @@ -35,6 +31,15 @@ SIMPLE USAGE | ||||
|  | ||||
|         curl ftp://cool.haxx.se/ http://www.weirdserver.com:8000/ | ||||
|  | ||||
|   Get a file off an FTPS server: | ||||
|  | ||||
|         curl ftps://files.are.secure.com/secrets.txt | ||||
|  | ||||
|   or use the more appropriate FTPS way to get the same file: | ||||
|  | ||||
|         curl --ftp-ssl ftp://files.are.secure.com/secrets.txt | ||||
|  | ||||
|  | ||||
| DOWNLOAD TO A FILE | ||||
|  | ||||
|   Get a web page and store in a local file: | ||||
| @@ -68,6 +73,10 @@ USING PASSWORDS | ||||
|    It is just like for FTP, but you may also want to specify and use | ||||
|    SSL-specific options for certificates etc. | ||||
|  | ||||
|    Note that using FTPS:// as prefix is the "implicit" way as described in the | ||||
|    standards while the recommended "explicit" way is done by using FTP:// and | ||||
|    the --ftp-ssl option. | ||||
|  | ||||
|  HTTP | ||||
|  | ||||
|    The HTTP URL doesn't support user and password in the URL string. Curl | ||||
| @@ -94,10 +103,6 @@ USING PASSWORDS | ||||
|  | ||||
|    Probably most commonly used with private certificates, as explained below. | ||||
|  | ||||
|  GOPHER | ||||
|  | ||||
|    Curl features no password support for gopher. | ||||
|  | ||||
| PROXY | ||||
|  | ||||
|  Get an ftp file using a proxy named my-proxy that uses port 888: | ||||
| @@ -113,6 +118,8 @@ PROXY | ||||
|  | ||||
|         curl -U user:passwd -x my-proxy:888 http://www.get.this/ | ||||
|  | ||||
|  curl also supports SOCKS4 and SOCKS5 proxies with --socks4 and --socks5. | ||||
|  | ||||
|  See also the environment variables Curl support that offer further proxy | ||||
|  control. | ||||
|  | ||||
| @@ -734,7 +741,7 @@ LDAP | ||||
|   Working with LDAP URLs": | ||||
|   http://developer.netscape.com/docs/manuals/dirsdk/csdk30/url.htm | ||||
|  | ||||
|   RFC 2255, "The LDAP URL Format" http://www.rfc-editor.org/rfc/rfc2255.txt | ||||
|   RFC 2255, "The LDAP URL Format" http://curl.haxx.se/rfc/rfc2255.txt | ||||
|  | ||||
|   To show you an example, this is now I can get all people from my local LDAP | ||||
|   server that has a certain sub-domain in their email address: | ||||
| @@ -748,7 +755,7 @@ ENVIRONMENT VARIABLES | ||||
|  | ||||
|   Curl reads and understands the following environment variables: | ||||
|  | ||||
|         http_proxy, HTTPS_PROXY, FTP_PROXY, GOPHER_PROXY | ||||
|         http_proxy, HTTPS_PROXY, FTP_PROXY | ||||
|  | ||||
|   They should be set for protocol-specific proxies. General proxy should be | ||||
|   set with | ||||
| @@ -854,6 +861,22 @@ PERSISTENT CONNECTIONS | ||||
|   transfers faster. If you use a http proxy for file transfers, practically | ||||
|   all transfers will be persistent. | ||||
|  | ||||
| MULTIPLE TRANSFERS WITH A SINGLE COMMAND LINE | ||||
|  | ||||
|   As is mentioned above, you can download multiple files with one command line | ||||
|   by simply adding more URLs. If you want those to get saved to a local file | ||||
|   instead of just printed to stdout, you need to add one save option for each | ||||
|   URL you specify. Note that this also goes for the -O option. | ||||
|  | ||||
|   For example: get two files and use -O for the first and a custom file | ||||
|   name for the second: | ||||
|  | ||||
|     curl -O http://url.com/file.txt ftp://ftp.com/moo.exe -o moo.jpg | ||||
|  | ||||
|   You can also upload multiple files in a similar fashion: | ||||
|  | ||||
|     curl -T local1 ftp://ftp.com/moo.exe -T local2 ftp://ftp.com/moo2.txt | ||||
|  | ||||
| MAILING LISTS | ||||
|  | ||||
|   For your convenience, we have several open mailing lists to discuss curl, | ||||
|   | ||||
| @@ -14,10 +14,10 @@ SUBDIRS = examples libcurl | ||||
|  | ||||
| CLEANFILES = $(GENHTMLPAGES) $(PDFPAGES) | ||||
|  | ||||
| EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS	\ | ||||
|  README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS	\ | ||||
|  KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL		\ | ||||
|  $(PDFPAGES) LICENSE-MIXING README.netware DISTRO-DILEMMA | ||||
| EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS	 \ | ||||
|  README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS	 \ | ||||
|  KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL		 \ | ||||
|  $(PDFPAGES) LICENSE-MIXING README.netware DISTRO-DILEMMA INSTALL.devcpp | ||||
|  | ||||
| MAN2HTML= roffit < $< >$@ | ||||
|  | ||||
|   | ||||
							
								
								
									
										90
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										90
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -8,19 +8,26 @@ Adrian Schuur | ||||
| Alan Pinstein | ||||
| Albert Chin-A-Young | ||||
| Albert Choy | ||||
| Ale Vesely | ||||
| Aleksandar Milivojevic | ||||
| Alex Neblett | ||||
| Alex Suykov | ||||
| Alex aka WindEagle | ||||
| Alexander Kourakos | ||||
| Alexander Krasnostavsky | ||||
| Alexander Lazic | ||||
| Alexander Zhuravlev | ||||
| Alexey Simak | ||||
| Alexis Carvalho | ||||
| Amol Pattekar | ||||
| Andi Jahja | ||||
| Andreas Damm | ||||
| Andreas Ntaflos | ||||
| Andreas Olsson | ||||
| Andreas Rieke | ||||
| Andres Garcia | ||||
| Andrew Benham | ||||
| Andrew Biggs | ||||
| Andrew Bushnell | ||||
| Andrew Francis | ||||
| Andrew Fuller | ||||
| @@ -31,21 +38,29 @@ Angus Mackay | ||||
| Antoine Calando | ||||
| Anton Kalmykov | ||||
| Arkadiusz Miskiewicz | ||||
| Armel Asselin | ||||
| Arve Knudsen | ||||
| Ates Goral | ||||
| Augustus Saunders | ||||
| 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 | ||||
| Brian R Duffy | ||||
| Bruce Mitchener | ||||
| Bryan Henderson | ||||
| Bryan Henderson  | ||||
| Bryan Kemp | ||||
| Caolan McNamara | ||||
| Casey O'Donnell | ||||
| @@ -59,6 +74,7 @@ Christian Robottom Reis | ||||
| Christophe Demory | ||||
| Christophe Legry | ||||
| Christopher R. Palmer | ||||
| Ciprian Badescu | ||||
| Clarence Gardner | ||||
| Clifford Wolf | ||||
| Cody Jones | ||||
| @@ -73,10 +89,12 @@ Damien Adant | ||||
| Dan Becker | ||||
| Dan C | ||||
| Dan Fandrich | ||||
| Dan Nelson | ||||
| Dan Torop | ||||
| Dan Zitter | ||||
| Daniel Stenberg | ||||
| Daniel at touchtunes | ||||
| Darryl House | ||||
| Dave Dribin | ||||
| Dave Halbakken | ||||
| Dave Hamilton | ||||
| @@ -89,18 +107,25 @@ David Hull | ||||
| David J Meyer | ||||
| David James | ||||
| David Kimdon | ||||
| David Lang | ||||
| David LeBlanc | ||||
| David McCreedy | ||||
| David Odin | ||||
| David Phillips | ||||
| David Shaw | ||||
| David Tarendash | ||||
| David Thiel | ||||
| David Yan | ||||
| Detlef Schmier | ||||
| Diego Casorran | ||||
| Dima Barsky | ||||
| Dimitris Sarris | ||||
| Dinar | ||||
| Dirk Eddelbuettel | ||||
| Dirk Manske | ||||
| Dmitriy Sergeyev | ||||
| Dmitry Bartsevich | ||||
| Dmitry Rechkin | ||||
| Dolbneff A.V | ||||
| Domenico Andreoli | ||||
| Dominick Meglio | ||||
| @@ -108,6 +133,8 @@ Doug Kaufman | ||||
| Doug Porter | ||||
| Douglas E. Wegscheid | ||||
| Douglas R. Horner | ||||
| Dov Murik | ||||
| Duane Cathey | ||||
| Dustin Boswell | ||||
| Dylan Ellicott | ||||
| Dylan Salisbury | ||||
| @@ -127,6 +154,7 @@ Eric Young | ||||
| Erick Nuwendam | ||||
| Erwan Legrand | ||||
| Erwin Authried | ||||
| Eugene Kotlyarov | ||||
| Evan Jordan | ||||
| Fabrizio Ammollo | ||||
| Fedor Karpelevitch | ||||
| @@ -176,6 +204,8 @@ Ian Wilkes | ||||
| Ignacio Vazquez-Abrams | ||||
| Igor Polyakov | ||||
| Ilguiz Latypov | ||||
| Ilja van Sprundel | ||||
| Ingmar Runge | ||||
| Ingo Ralf Blum | ||||
| Ingo Wilken | ||||
| Jacky Lam | ||||
| @@ -185,10 +215,17 @@ 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 | ||||
| Jean Jacques Drouin | ||||
| Jean-Claude Chauve | ||||
| Jean-Louis Lemaire | ||||
| Jean-Marc Ranger | ||||
| @@ -207,6 +244,7 @@ Johan Anderson | ||||
| Johan Nilsson | ||||
| John Crow | ||||
| John Janssen | ||||
| John Kelly | ||||
| John Lask | ||||
| John McGowan | ||||
| Jon Grubbs | ||||
| @@ -229,11 +267,14 @@ J | ||||
| Kai Sommerfeld | ||||
| Kai-Uwe Rommel | ||||
| Kang-Jin Lee | ||||
| Karl Moerder | ||||
| Karol Pietrzak | ||||
| Katie Wang | ||||
| Keith MacDonald | ||||
| Keith McGuigan | ||||
| Ken Hirsch | ||||
| Ken Rastatter | ||||
| Kent Boortz | ||||
| Kevin Fisk | ||||
| Kevin Lussier | ||||
| Kevin Roth | ||||
| @@ -266,6 +307,7 @@ Lucas Adamski | ||||
| Lukasz Czekierda | ||||
| Luke Call | ||||
| Luong Dinh Dung | ||||
| Maciej Karpiuk | ||||
| Maciej W. Rozycki | ||||
| Marc Boucher | ||||
| Marcelo Juchem  | ||||
| @@ -274,17 +316,22 @@ Marco G. Salvagno | ||||
| Marcus Webster | ||||
| Mario Schroeder | ||||
| Mark Butler | ||||
| Mark Eichin | ||||
| Mark Lentczner | ||||
| Markus Koetter | ||||
| Markus Moeller | ||||
| Markus Oberhumer | ||||
| Martijn Koster | ||||
| Martin C. Martin | ||||
| Martin Hedenfalk | ||||
| Martin Skinner | ||||
| Marty Kuhrt | ||||
| Maruko | ||||
| Massimiliano Ziccardi | ||||
| Mathias Axelsson | ||||
| Mats Lidell | ||||
| Matt Veenstra | ||||
| Matt Witherspoon | ||||
| Matthew Blain | ||||
| Matthew Clarke | ||||
| Maurice Barnum | ||||
| @@ -292,17 +339,25 @@ Mekonikum | ||||
| Mettgut Jamalla | ||||
| Michael Benedict | ||||
| Michael Curtis | ||||
| Michael Jahn | ||||
| Michael Jerris | ||||
| Michael Mealling | ||||
| Michael Wallner | ||||
| Michal Bonino | ||||
| Michal Marek | ||||
| Michele Bini | ||||
| 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 | ||||
| @@ -312,10 +367,16 @@ Nick Humfrey | ||||
| 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 | ||||
| Patrick Bihan-Faou | ||||
| @@ -324,6 +385,7 @@ Paul Harrington | ||||
| Paul Marquis | ||||
| Paul Moore | ||||
| Paul Nolan | ||||
| Paul Querna | ||||
| Pavel Cenek | ||||
| Pavel Orehov | ||||
| Pawel A. Gajda | ||||
| @@ -331,7 +393,10 @@ Pedro Neves | ||||
| Pete Su | ||||
| Peter Bray | ||||
| Peter Forret | ||||
| Peter Heuchert | ||||
| Peter Pentchev | ||||
| Peter Silva | ||||
| Peter Su | ||||
| Peter Sylvester | ||||
| Peter Todd | ||||
| Peter Verhas | ||||
| @@ -341,13 +406,16 @@ Phil Karn | ||||
| Philip Gladstone | ||||
| Philippe Hameau | ||||
| Philippe Raoult | ||||
| Philippe Vaucher | ||||
| Pierre | ||||
| Puneet Pawaia | ||||
| Quagmire | ||||
| Rafael Sagula | ||||
| Ralph Beckmann | ||||
| Ralph Mitchell | ||||
| Ramana Mokkapati | ||||
| Randy McMurchy | ||||
| Ravi Pratap | ||||
| Reinout van Schouwen | ||||
| Renaud Chaillat | ||||
| Renaud Duhaut | ||||
| @@ -366,10 +434,13 @@ Rick Jones | ||||
| Rick Richardson | ||||
| Rob Stanzel | ||||
| Robert D. Young | ||||
| Robert Foreman | ||||
| Robert Olson | ||||
| Robert Weaver | ||||
| Robin Kay | ||||
| Robson Braga Araujo | ||||
| Rodney Simmons | ||||
| Roland Blom | ||||
| Roland Krikava | ||||
| Roland Zimmermann | ||||
| Roman Koifman | ||||
| @@ -386,17 +457,22 @@ Samuel D | ||||
| Samuel Listopad | ||||
| Sander Gates | ||||
| Saul good | ||||
| Scott Davis | ||||
| Sebastien Willemijns | ||||
| Sergio Ballestrero | ||||
| Seshubabu Pasam | ||||
| Sh Diao | ||||
| Shard | ||||
| Shawn Poulson | ||||
| Shmulik Regev | ||||
| Siddhartha Prakash Jain | ||||
| Simon Dick | ||||
| Simon Josefsson | ||||
| Simon Liu | ||||
| Spiridonoff A.V | ||||
| Stadler Stephan | ||||
| Stefan Esser | ||||
| Stefan Krause | ||||
| Stefan Ulrich | ||||
| Stephan Bergmann | ||||
| Stephen Kick | ||||
| @@ -413,6 +489,8 @@ Sven Neuhaus | ||||
| S<EFBFBD>bastien Willemijns | ||||
| T. Bharath | ||||
| T. Yamada | ||||
| Temprimus | ||||
| Thomas Klausner | ||||
| Thomas Schwinge | ||||
| Thomas Tonino | ||||
| Tim Baker | ||||
| @@ -421,6 +499,7 @@ Tim Costello | ||||
| Tim Sneddon | ||||
| Toby Peterson | ||||
| Todd Kulesza | ||||
| Todd Vierling | ||||
| Tom Benoist | ||||
| Tom Lee | ||||
| Tom Mattison | ||||
| @@ -431,6 +510,7 @@ Tomas Szepe | ||||
| Tomasz Lacki | ||||
| Tommy Tam | ||||
| Ton Voon | ||||
| Toon Verwaest | ||||
| Tor Arntsen | ||||
| Torsten Foertsch | ||||
| Toshiyuki Maezawa | ||||
| @@ -438,7 +518,11 @@ Traian Nicolescu | ||||
| Troels Walsted Hansen | ||||
| Troy Engel | ||||
| Tupone Alfredo | ||||
| Ulf H<>rnhammar | ||||
| Ulrich Zadow | ||||
| Venkat Akella | ||||
| Victor Snezhko | ||||
| Vilmos Nebehaj | ||||
| Vincent Bronner | ||||
| Vincent Penquerc'h | ||||
| Vincent Sanders | ||||
| @@ -451,7 +535,11 @@ Wesley Laxton | ||||
| Wez Furlong | ||||
| Wilfredo Sanchez | ||||
| Wojciech Zwiefka | ||||
| Xavier Bouchoux | ||||
| Yang Tse | ||||
| Yarram Sunil | ||||
| Yves Lejeune | ||||
| Zvi Har'El  | ||||
| nk | ||||
| swalkaus at yahoo.com | ||||
| tommink[at]post.pl | ||||
|   | ||||
							
								
								
									
										62
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -14,12 +14,6 @@ TODO | ||||
|  | ||||
|  LIBCURL | ||||
|  | ||||
|  * Introduce an interface to libcurl that allows applications to easier get to | ||||
|    know what cookies that are received. CURLINFO_COOKIELIST to get a | ||||
|    curl_slist with cookies (netscape/mozilla cookie file formatted), and | ||||
|    CURLOPT_COOKIELIST to set a list of cookies (using the same format). | ||||
|    http://curl.haxx.se/mail/lib-2004-12/0195.html | ||||
|  | ||||
|  * Introduce another callback interface for upload/download that makes one | ||||
|    less copy of data and thus a faster operation. | ||||
|    [http://curl.haxx.se/dev/no_copy_callbacks.txt] | ||||
| @@ -43,15 +37,25 @@ TODO | ||||
|  * Add option that changes the interval in which the progress callback is | ||||
|    called at most. | ||||
|  | ||||
|  * Make libcurl built with c-ares use c-ares' IPv6 abilities. They weren't | ||||
|    present when we first added c-ares support but they have been added since! | ||||
|    When this is done and works, we can actually start considering making c-ares | ||||
|    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). | ||||
|  | ||||
|  * 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 | ||||
|    we know MUST have it. This is error-prone. We therefore want the header | ||||
|    files to adapt to configure results. Those results must be stored in a new | ||||
|    header and they must use a curl name space, i.e not be HAVE_* prefix (as | ||||
|    that would risk collide with other apps that use libcurl and that runs | ||||
|    configure). | ||||
|  | ||||
|  LIBCURL - multi interface | ||||
|  | ||||
|  * Add a curl_multi_fdset() alternative. this allows apps to avoid the | ||||
|    FD_SETSIZE problem with select(). | ||||
|  | ||||
|  * Add curl_multi_timeout() to make libcurl's ares-functionality better. | ||||
|  | ||||
|  * Make sure we don't ever loop because of non-blocking sockets return | ||||
|    EWOULDBLOCK or similar. This FTP command sending, the SSL connection etc. | ||||
|    EWOULDBLOCK or similar. The GnuTLS connection etc. | ||||
|  | ||||
|  * Make transfers treated more carefully. We need a way to tell libcurl we | ||||
|    have data to write, as the current system expects us to upload data each | ||||
| @@ -61,10 +65,6 @@ TODO | ||||
|    ready to accept read data. Today libcurl feeds the data as soon as it is | ||||
|    available for reading, no matter what. | ||||
|  | ||||
|  * Add curl_multi_socket() and family to the multi interface that gets file | ||||
|    descriptors, as an alternative to the curl_multi_fdset(). This is necessary | ||||
|    to allow apps to properly avoid the FD_SETSIZE problem. | ||||
|  | ||||
|  * Make curl_easy_perform() a wrapper-function that simply creates a multi | ||||
|    handle, adds the easy handle to it, runs curl_multi_perform() until the | ||||
|    transfer is done, then detach the easy handle, destroy the multi handle and | ||||
| @@ -83,7 +83,7 @@ TODO | ||||
|  | ||||
|  * Support GSS/Kerberos 5 for ftp file transfer. This will allow user | ||||
|    authentication and file encryption.  Possible libraries and example clients | ||||
|    are available from MIT or Heimdal. Requsted by Markus Moeller. | ||||
|    are available from MIT or Heimdal. Requested by Markus Moeller. | ||||
|  | ||||
|  * REST fix for servers not behaving well on >2GB requests. This should fail | ||||
|    if the server doesn't set the pointer to the requested index. The tricky | ||||
| @@ -111,10 +111,6 @@ TODO | ||||
|  | ||||
|  HTTP | ||||
|  | ||||
|  * Pipelining. Sending multiple requests before the previous one(s) are done. | ||||
|    This could possibly be implemented using the multi interface to queue | ||||
|    requests and the response data. | ||||
|  | ||||
|  * When doing CONNECT to a HTTP proxy, libcurl always uses HTTP/1.0. This has | ||||
|    never been reported as causing trouble to anyone, but should be considered | ||||
|    to use the HTTP version the user has chosen. | ||||
| @@ -131,6 +127,10 @@ TODO | ||||
|  | ||||
|  SSL | ||||
|  | ||||
|  * Provide a libcurl API for setting mutex callbacks in the underlying SSL | ||||
|    library, so that the same application code can use mutex-locking | ||||
|    independently of OpenSSL or GnutTLS being used. | ||||
|  | ||||
|  * Anton Fedorov's "dumpcert" patch: | ||||
|    http://curl.haxx.se/mail/lib-2004-03/0088.html | ||||
|  | ||||
| @@ -182,6 +182,11 @@ TODO | ||||
|  * Work out a common method with Peter Sylvester's OpenSSL-patch for SRP | ||||
|    on the TLS to provide name and password | ||||
|  | ||||
|  * 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 correspond to | ||||
|    the SSL_peak() way we use with OpenSSL. | ||||
|  | ||||
|  LDAP | ||||
|  | ||||
|  * Look over the implementation. The looping will have to "go away" from the | ||||
| @@ -190,17 +195,8 @@ TODO | ||||
|  | ||||
|  NEW PROTOCOLS | ||||
|  | ||||
|  * TFTP - RFC1350 (protocol) and RFC3617 (URI format) | ||||
|  | ||||
|    Dan Fandrich: I wrote a tftp protocol module as part of the I-Boot | ||||
|    bootloader under a BSD-style license with attribution clause | ||||
|    http://download.intrinsyc.com/supported/tools/i-boot-lite/i-boot-lite-1.8/src/libs/net/tftp.c | ||||
|  | ||||
|  * 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. | ||||
|  | ||||
|  * RSYNC (no RFCs for protocol nor URI/URL format).  An implementation should | ||||
|    most probably use an existing rsync library, such as librsync. | ||||
|  | ||||
| @@ -217,7 +213,7 @@ TODO | ||||
|  * Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'. | ||||
|    Requested by Dane Jensen and others. This is easily scripted though. | ||||
|  | ||||
|  * Add an option that prevents cURL from overwiting existing local files. When | ||||
|  * Add an option that prevents cURL from overwriting existing local files. When | ||||
|    used, and there already is an existing file with the target file name | ||||
|    (either -O or -o), a number should be appended (and increased if already | ||||
|    existing). So that index.html becomes first index.html.1 and then | ||||
| @@ -269,6 +265,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. | ||||
|  | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2006, 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-config 1 "25 Jan 2004" "Curl 7.13.0" "curl-config manual" | ||||
| .TH curl-config 1 "25 Jan 2004" "Curl 7.15.4" "curl-config manual" | ||||
| .SH NAME | ||||
| curl-config \- Get information about a libcurl installation | ||||
| .SH SYNOPSIS | ||||
| @@ -37,6 +37,11 @@ Displays the compiler used to build libcurl. | ||||
| .IP "--cflags" | ||||
| Set of compiler options (CFLAGS) to use when compiling files that use | ||||
| libcurl. Currently that is only thw include path to the curl include files. | ||||
| .IP "--checkfor [version]" | ||||
| Specify the oldest possible libcurl version string you want, and this  | ||||
| script will return 0 if the current installation is new enough or it  | ||||
| returns 1 and outputs a text saying that the current version is not new  | ||||
| enough. (Added in 7.15.4) | ||||
| .IP "--feature" | ||||
| Lists what particular main features the installed libcurl was built with. At | ||||
| the time of writing, this list may include SSL, KRB4 or IPv6. Do not assume | ||||
| @@ -53,10 +58,10 @@ in $prefix/lib and its header files are installed in $prefix/include and so | ||||
| on. The prefix is set with "configure --prefix". | ||||
| .IP "--protocols" | ||||
| Lists what particular protocols the installed libcurl was built to support. At | ||||
| the time of writing, this list may include HTTP, HTTPS, FTP, FTPS, GOPHER, | ||||
| FILE, TELNET, LDAP, DICT. Do not assume any particular order. The protocols | ||||
| will be listed using uppercase and are separated by newlines. There may be | ||||
| none, one or several protocols in the list. (Added in 7.13.0) | ||||
| the time of writing, this list may include HTTP, HTTPS, FTP, FTPS, FILE, | ||||
| TELNET, LDAP, DICT. Do not assume any particular order. The protocols will | ||||
| be listed using uppercase and are separated by newlines. There may be none, | ||||
| one or several protocols in the list. (Added in 7.13.0) | ||||
| .IP "--version" | ||||
| Outputs version information about the installed libcurl. | ||||
| .IP "--vernum" | ||||
| @@ -64,7 +69,7 @@ Outputs version information about the installed libcurl, in numerical mode. | ||||
| This outputs the version number, in hexadecimal, with 8 bits for each part; | ||||
| major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl | ||||
| 12.13.14 would appear as 0c0d0e... Note that the initial zero might be | ||||
| omitted. | ||||
| omitted. (This option was broken in the 7.15.0 release.) | ||||
| .SH "EXAMPLES" | ||||
| What linker options do I need when I link with libcurl? | ||||
|  | ||||
|   | ||||
							
								
								
									
										356
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										356
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -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,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl 1 "4 Sep 2005" "Curl 7.14.2" "Curl Manual" | ||||
| .TH curl 1 "3 Nov 2006" "Curl 7.16.1" "Curl Manual" | ||||
| .SH NAME | ||||
| curl \- transfer a URL | ||||
| .SH SYNOPSIS | ||||
| @@ -30,20 +30,20 @@ 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, GOPHER, 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 (https:) connections, cookies, file | ||||
| transfer resume and more. As you will see below, the amount of features will | ||||
| make your head spin! | ||||
| authentication, ftp upload, HTTP post, SSL connections, cookies, file transfer | ||||
| resume and more. As you will see below, the amount of features will make your | ||||
| head spin! | ||||
|  | ||||
| curl is powered by libcurl for all transfer-related features. See | ||||
| .BR libcurl (3) | ||||
| for details. | ||||
| .SH URL | ||||
| The URL syntax is protocol dependent. You'll find a detailed description in | ||||
| RFC 2396. | ||||
| RFC 3986. | ||||
|  | ||||
| You can specify multiple URLs or parts of URLs by writing part sets within | ||||
| braces as in: | ||||
| @@ -64,6 +64,12 @@ several ones next to each other: | ||||
| You can specify any amount of URLs on the command line. They will be fetched | ||||
| in a sequential manner in the specified order. | ||||
|  | ||||
| Since curl 7.15.1 you can also specify step counter for the ranges, so that | ||||
| you can get every Nth number or letter: | ||||
|  | ||||
|  http://www.numericals.com/file[1-100:10].txt | ||||
|  http://www.letters.com/file[a-z:2].txt | ||||
|  | ||||
| If you specify URL without protocol:// prefix, curl will attempt to guess what | ||||
| protocol you might want. It will then default to HTTP but try other protocols | ||||
| based on often-used host name prefixes. For example, for host names starting | ||||
| @@ -74,6 +80,24 @@ getting many files from the same server will not do multiple connects / | ||||
| handshakes. This improves speed. Of course this is only done on files | ||||
| specified on a single command line and cannot be used between separate curl | ||||
| invokes. | ||||
| .SH "PROGRESS METER" | ||||
| curl normally displays a progress meter during operations, indicating amount | ||||
| of transfered data, transfer speeds and estimated time left etc. | ||||
|  | ||||
| However, since curl displays data to the terminal by default, if you invoke | ||||
| curl to do an operation and it is about to write data to the terminal, it | ||||
| \fIdisables\fP the progress meter as otherwise it would mess up the output | ||||
| mixing progress meter and response data. | ||||
|  | ||||
| If you want a progress meter for HTTP POST or PUT requests, you need to | ||||
| redirect the response output to a file, using shell redirect (>), -o [file] or | ||||
| similar. | ||||
|  | ||||
| It is not the same case for FTP upload as that operation is not spitting out | ||||
| any response data to the terminal. | ||||
|  | ||||
| If you prefer a progress "bar" instead of the regular meter, \fI-#\fP is your | ||||
| friend. | ||||
| .SH OPTIONS | ||||
| .IP "-a/--append" | ||||
| (FTP) When used in an FTP upload, this will tell curl to append to the target | ||||
| @@ -94,7 +118,7 @@ most secure one the remote site claims it supports. This is done by first | ||||
| doing a request and checking the response-headers, thus inducing an extra | ||||
| network round-trip. This is used instead of setting a specific authentication | ||||
| method, which you can do with \fI--basic\fP, \fI--digest\fP, \fI--ntlm\fP, and | ||||
| \fI--negotiate\fP. (Added in 7.10.6) | ||||
| \fI--negotiate\fP. | ||||
|  | ||||
| Note that using --anyauth is not recommended if you do uploads from stdin, | ||||
| since it may require data to be sent twice and then the client must be able to | ||||
| @@ -134,7 +158,7 @@ If this option is used twice, the second one will disable ASCII usage. | ||||
| (HTTP) Tells curl to use HTTP Basic authentication. This is the default and | ||||
| this option is usually pointless, unless you use it to override a previously | ||||
| set option that sets a different authentication method (such as \fI--ntlm\fP, | ||||
| \fI--digest\fP and \fI--negotiate\fP). (Added in 7.10.6) | ||||
| \fI--digest\fP and \fI--negotiate\fP). | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| @@ -192,7 +216,8 @@ To create remote directories when using FTP, try \fI--ftp-create-dirs\fP. | ||||
| .IP "--crlf" | ||||
| (FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390). | ||||
|  | ||||
| If this option is used twice, the second will again disable crlf converting. | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "-d/--data <data>" | ||||
| (HTTP) Sends the specified data in a POST request to the HTTP server, in a way | ||||
| that can emulate as if a user has filled in a HTML form and pressed the submit | ||||
| @@ -236,7 +261,7 @@ append data. | ||||
| prevents the password from being sent over the wire in clear text. Use this in | ||||
| combination with the normal \fI-u/--user\fP option to set user name and | ||||
| password. See also \fI--ntlm\fP, \fI--negotiate\fP and \fI--anyauth\fP for | ||||
| related options. (Added in curl 7.10.6) | ||||
| related options. | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| @@ -246,7 +271,7 @@ active FTP transfers. Curl will normally always first attempt to use EPRT, | ||||
| then LPRT before using PORT, but with this option, it will use PORT right | ||||
| away. EPRT and LPRT are extensions to the original FTP protocol, may not work | ||||
| on all servers but enable more functionality in a better way than the | ||||
| traditional PORT command. (Added in 7.10.5) | ||||
| traditional PORT command. | ||||
|  | ||||
| If this option is used several times, each occurrence will toggle this on/off. | ||||
| .IP "--disable-epsv" | ||||
| @@ -270,9 +295,9 @@ If this option is used several times, the last one will be used. | ||||
| .IP "-e/--referer <URL>" | ||||
| (HTTP) Sends the "Referer Page" information to the HTTP server. This can also | ||||
| be set with the \fI-H/--header\fP flag of course.  When used with | ||||
| \fI-L/--location\fP you can append ";auto" to the referer URL to make curl | ||||
| \fI-L/--location\fP you can append ";auto" to the --referer URL to make curl | ||||
| automatically set the previous URL when it follows a Location: header. The | ||||
| \&";auto" string can be used alone, even if you don't set an initial referer. | ||||
| \&";auto" string can be used alone, even if you don't set an initial --referer. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--engine <name>" | ||||
| @@ -287,25 +312,25 @@ run curl. | ||||
|  | ||||
| If this option is used several times, each occurrence will toggle this on/off. | ||||
| .IP "--egd-file <file>" | ||||
| (HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The | ||||
| socket is used to seed the random engine for SSL connections. See also the | ||||
| (SSL) Specify the path name to the Entropy Gathering Daemon socket. The socket | ||||
| is used to seed the random engine for SSL connections. See also the | ||||
| \fI--random-file\fP option. | ||||
| .IP "-E/--cert <certificate[:password]>" | ||||
| (HTTPS) | ||||
| Tells curl to use the specified certificate file when getting a file | ||||
| with HTTPS. 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 certificate is the private key and the private | ||||
| certificate concatenated! | ||||
| (SSL) Tells curl to use the specified certificate file when getting a file | ||||
| 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\fP and \fI--key\fP to specify | ||||
| them independently. | ||||
|  | ||||
| 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, | ||||
| DER and ENG are recognized types. | ||||
| DER and ENG are recognized types.  If not specified, PEM is assumed. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--cacert <CA certificate>" | ||||
| (HTTPS) Tells curl to use the specified certificate file to verify the | ||||
| (SSL) Tells curl to use the specified certificate file to verify the | ||||
| peer. The file may contain multiple CA certificates. The certificate(s) must | ||||
| be in PEM format. | ||||
|  | ||||
| @@ -319,10 +344,10 @@ Current Working Directory, or in any folder along your PATH. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--capath <CA certificate directory>" | ||||
| (HTTPS) Tells curl to use the specified certificate directory to verify the | ||||
| (SSL) Tells curl to use the specified certificate directory to verify the | ||||
| peer. The certificates must be in PEM format, and the directory must have been | ||||
| processed using the c_rehash utility supplied with openssl. Using | ||||
| \fI--capath\fP can allow curl to make https connections much more efficiently | ||||
| \fI--capath\fP can allow curl to make SSL-connections much more efficiently | ||||
| than using \fI--cacert\fP if the \fI--cacert\fP file contains many CA | ||||
| certificates. | ||||
|  | ||||
| @@ -330,9 +355,13 @@ If this option is used several times, the last one will be used. | ||||
| .IP "-f/--fail" | ||||
| (HTTP) Fail silently (no output at all) on server errors. This is mostly done | ||||
| like this to better enable scripts etc to better deal with failed attempts. In | ||||
| normal cases when a HTTP server fails to deliver a document, it returns a HTML | ||||
| document stating so (which often also describes why and more). This flag will | ||||
| prevent curl from outputting that and fail silently instead. | ||||
| 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 | ||||
| response codes will slip through, especially when authentication is involved | ||||
| (response codes 401 and 407). | ||||
|  | ||||
| If this option is used twice, the second will again disable silent failure. | ||||
| .IP "--ftp-account [data]" | ||||
| @@ -344,15 +373,37 @@ 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 | ||||
| the server, the standard behavior of curl is to fail. Using this option, curl | ||||
| will instead attempt to create missing directories. (Added in 7.10.7) | ||||
| will instead attempt to create missing directories. | ||||
|  | ||||
| If this option is used twice, the second will again disable silent failure. | ||||
| If this option is used twice, the second will again disable directory creation. | ||||
| .IP "--ftp-method [method]" | ||||
| (FTP) Control what method curl should use to reach a file on a FTP(S) | ||||
| server. The method argument should be one of the following alternatives: | ||||
| .RS | ||||
| .IP multicwd | ||||
| curl does a single CWD operation for each path part in the given URL. For deep | ||||
| hierarchies this means very many commands. This is how RFC1738 says it should | ||||
| be done. This is the default but the slowest behavior. | ||||
| .IP nocwd | ||||
| curl does no CWD at all. curl will do SIZE, RETR, STOR etc and give a full | ||||
| path to the server for all these commands. This is the fastest behavior. | ||||
| .IP singlecwd | ||||
| curl does one CWD with the full target directory and then operates on the file | ||||
| \&"normally" (like in the multicwd case). This is somewhat more standards | ||||
| compliant than 'nocwd' but without the full penalty of 'multicwd'. | ||||
| .RE | ||||
| .IP "--ftp-pasv" | ||||
| (FTP) Use PASV when transferring. PASV is the internal default behavior, but | ||||
| using this option can be used to override a previous --ftp-port option. (Added | ||||
| in 7.11.0) | ||||
|  | ||||
| If this option is used twice, the second will again disable silent failure. | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "--ftp-alternative-to-user <command>" | ||||
| (FTP) If authenticating with the USER and PASS commands fails, send this | ||||
| command.  When connecting to Tumbleweed's Secure Transport server over FTPS | ||||
| using a client certificate, using "SITE AUTH" will tell the server to retrieve | ||||
| the username from the certificate. (Added in 7.15.5) | ||||
| .IP "--ftp-skip-pasv-ip" | ||||
| (FTP) Tell curl to not use the IP address the server suggests in its response | ||||
| to curl's PASV command when curl connects the data connection. Instead curl | ||||
| @@ -361,9 +412,33 @@ connection. (Added in 7.14.2) | ||||
|  | ||||
| This option has no effect if PORT, EPRT or EPSV is used instead of PASV. | ||||
|  | ||||
| If this option is used twice, the second will again disable silent failure. | ||||
| If this option is used twice, the second will again use the server's suggested | ||||
| address. | ||||
| .IP "--ftp-ssl" | ||||
| (FTP) Make the FTP connection switch to use SSL/TLS. (Added in 7.11.0) | ||||
| (FTP) Try to use SSL/TLS for the FTP connection.  Reverts to a non-secure | ||||
| connection if the server doesn't support SSL/TLS.  See also | ||||
| \fI--ftp-ssl-control\fP and \fI--ftp-ssl-reqd\fP for different levels of | ||||
| encryption required. (Added in 7.11.0) | ||||
|  | ||||
| If this option is used twice, the second will again disable this. | ||||
| .IP "--ftp-ssl-control" | ||||
| (FTP) Require SSL/TLS for the ftp login, clear for transfer.  Allows secure | ||||
| authentication, but non-encrypted data transfers for efficiency.  Fails the | ||||
| transfer if the server doesn't support SSL/TLS.  (Added in 7.16.0) | ||||
|  | ||||
| If this option is used twice, the second will again disable this. | ||||
| .IP "--ftp-ssl-reqd" | ||||
| (FTP) Require SSL/TLS for the FTP connection. | ||||
| 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. | ||||
| (Added in 7.16.1) | ||||
|  | ||||
| If this option is used twice, the second will again disable this. | ||||
| .IP "-F/--form <name=content>" | ||||
| @@ -422,7 +497,8 @@ with a '?'  separator. | ||||
| If used in combination with -I, the POST data will instead be appended to the | ||||
| URL with a HEAD request. | ||||
|  | ||||
| If used multiple times, nothing special happens. | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "-h/--help" | ||||
| Usage help. | ||||
| .IP "-H/--header <header>" | ||||
| @@ -431,9 +507,9 @@ of extra headers. Note that if you should add a custom header that has the | ||||
| same name as one of the internal ones curl would use, your externally set | ||||
| header will be used instead of the internal one. This allows you to make even | ||||
| trickier stuff than curl would normally do. You should not replace internally | ||||
| set headers without knowing perfectly well what you're doing. Replacing an | ||||
| internal header with one without content on the right side of the colon will | ||||
| prevent that header from appearing. | ||||
| set headers without knowing perfectly well what you're doing. Remove an | ||||
| internal header by giving a replacement without content on the right side of | ||||
| the colon, as in: -H \&"Host:". | ||||
|  | ||||
| curl will make sure that each header you add/replace get sent with the proper | ||||
| end of line marker, you should thus \fBnot\fP add that as a part of the header | ||||
| @@ -473,15 +549,17 @@ If this option is used twice, the second will again disable header only. | ||||
| (HTTP) When curl is told to read cookies from a given file, this option will | ||||
| make it discard all "session cookies". This will basically have the same effect | ||||
| as if a new session is started. Typical browsers always discard session | ||||
| cookies when they're closed down. (Added in 7.9.7) | ||||
| cookies when they're closed down. | ||||
|  | ||||
| If this option is used several times, each occurrence will toggle this on/off. | ||||
| .IP "-k/--insecure" | ||||
| (SSL) This option explicitly allows curl to perform "insecure" SSL connections | ||||
| and transfers. Starting with curl 7.10, all SSL connections will be attempted | ||||
| to be made secure by using the CA certificate bundle installed by | ||||
| default. This makes all connections considered "insecure" to fail unless | ||||
| \fI-k/--insecure\fP is used. | ||||
| and transfers. All SSL connections are attempted to be made secure by using | ||||
| the CA certificate bundle installed by default. This makes all connections | ||||
| considered "insecure" to fail unless \fI-k/--insecure\fP is used. | ||||
|  | ||||
| See this online resource for further details: | ||||
| \fBhttp://curl.haxx.se/docs/sslcerts.html\fP | ||||
|  | ||||
| If this option is used twice, the second time will again disable it. | ||||
| .IP "--key <key>" | ||||
| @@ -491,7 +569,8 @@ separate file. | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--key-type <type>" | ||||
| (SSL) Private key file type. Specify which type your \fI--key\fP provided | ||||
| private key is. DER, PEM and ENG are supported. | ||||
| private key is. DER, PEM and ENG are supported. If not specified, PEM is | ||||
| assumed. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--krb4 <level>" | ||||
| @@ -508,7 +587,7 @@ Specify which config file to read curl arguments from. The config file is a | ||||
| text file in which command line arguments can be written which then will be | ||||
| 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 inclosed within quotes.  If the | ||||
| 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. | ||||
|  | ||||
| @@ -520,7 +599,7 @@ line. So, it could look similar to this: | ||||
|  | ||||
| url = "http://curl.haxx.se/docs/" | ||||
|  | ||||
| This option can be used multiple times. | ||||
| This option can be used multiple times to load multiple config files. | ||||
|  | ||||
| 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 | ||||
| @@ -535,6 +614,12 @@ 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. | ||||
| .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 | ||||
| @@ -544,12 +629,14 @@ 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. | ||||
|  | ||||
| This option was introduced in curl 7.10. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-l/--list-only" | ||||
| (FTP) | ||||
| @@ -563,15 +650,21 @@ list only files in their response to NLST; they do not include | ||||
| 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 | ||||
| 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) | ||||
| .IP "-L/--location" | ||||
| (HTTP/HTTPS) If the server reports that the requested page has a different | ||||
| location (indicated with the header line Location:) this flag will let curl | ||||
| attempt to reattempt the get on the new place. If used together with | ||||
| \fI-i/--include\fP or \fI-I/--head\fP, headers from all requested pages will | ||||
| be shown. If authentication is used, curl will only send its credentials to | ||||
| the initial host, so if a redirect takes curl to a different host, it won't | ||||
| intercept the user+password. See also \fI--location-trusted\fP on how to | ||||
| change this. | ||||
| (HTTP/HTTPS) If the server reports that the requested page has moved to a | ||||
| different location (indicated with a Location: header and a 3XX response code) | ||||
| this option will make curl redo the request on the new place. If used together | ||||
| with \fI-i/--include\fP or \fI-I/--head\fP, headers from all requested pages | ||||
| will be shown. When authentication is used, curl only sends its credentials to | ||||
| the initial host. If a redirect takes curl to a different host, it won't be | ||||
| 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. | ||||
|  | ||||
| If this option is used twice, the second will again disable location following. | ||||
| .IP "--location-trusted" | ||||
| @@ -625,12 +718,16 @@ Very similar to \fI--netrc\fP, but this option makes the .netrc usage | ||||
| designed by Microsoft and is used in their web applications. It is primarily | ||||
| meant as a support for Kerberos5 authentication but may be also used along | ||||
| with another authentication methods. For more information see IETF draft | ||||
| draft-brezak-spnego-http-04.txt. (Added in 7.10.6) | ||||
| draft-brezak-spnego-http-04.txt. | ||||
|  | ||||
| This option requires that the library was built with GSSAPI support. This is | ||||
| not very common. Use \fI-V/--version\fP to see if your version supports | ||||
| GSS-Negotiate. | ||||
|  | ||||
| When using this option, you must also provide a fake -u/--user option to | ||||
| activate the authentication code properly. Sending a '-u :' is enough as the | ||||
| user name and password from the -u option aren't actually used. | ||||
|  | ||||
| If this option is used several times, the following occurrences make no | ||||
| difference. | ||||
| .IP "-N/--no-buffer" | ||||
| @@ -640,13 +737,22 @@ will output the data in chunks, not necessarily exactly when the data arrives. | ||||
| Using this option will disable that buffering. | ||||
|  | ||||
| If this option is used twice, the second will again switch on buffering. | ||||
| .IP "--no-sessionid" | ||||
| (SSL) Disable curl's use of SSL session-ID caching.  By default all transfers | ||||
| are done using the cache. Note that while nothing ever should get hurt by | ||||
| attempting to reuse SSL session-IDs, there seem to be broken SSL | ||||
| implementations in the wild that may require you to disable this in order for | ||||
| you to succeed. (Added in 7.16.0) | ||||
|  | ||||
| If this option is used twice, the second will again switch on use of the | ||||
| session cache. | ||||
| .IP "--ntlm" | ||||
| (HTTP) Enables NTLM authentication. The NTLM authentication method was | ||||
| designed by Microsoft and is used by IIS web servers. It is a proprietary | ||||
| protocol, reversed engineered by clever people and implemented in curl based | ||||
| on their efforts. This kind of behavior should not be endorsed, you should | ||||
| encourage everyone who uses NTLM to switch to a public and documented | ||||
| authentication method instead. Such as Digest. (Added in 7.10.6) | ||||
| authentication method instead. Such as Digest. | ||||
|  | ||||
| If you want to enable NTLM for your proxy authentication, then use | ||||
| \fI--proxy-ntlm\fP. | ||||
| @@ -676,8 +782,8 @@ dynamically. | ||||
| Write output to a local file named like the remote file we get. (Only the file | ||||
| part of the remote file is used, the path is cut off.) | ||||
|  | ||||
| The remote file name to use for saving is extracted from the given URL. | ||||
| Nothing else | ||||
| The remote file name to use for saving is extracted from the given URL, | ||||
| nothing else. | ||||
|  | ||||
| You may use this option as many times as you have number of URLs. | ||||
| .IP "--pass <phrase>" | ||||
| @@ -686,8 +792,8 @@ You may use this option as many times as you have number of URLs. | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--proxy-anyauth" | ||||
| Tells curl to pick a suitable authentication method when communicating with | ||||
| the given proxy. This will cause an extra request/response round-trip. Added | ||||
| in curl 7.13.2. | ||||
| the given proxy. This will cause an extra request/response round-trip. (Added | ||||
| in 7.13.2) | ||||
|  | ||||
| If this option is used twice, the second will again disable the proxy use-any | ||||
| authentication. | ||||
| @@ -730,7 +836,8 @@ i.e "192.168.10.1" to specify exact IP number | ||||
| .IP "host name" | ||||
| i.e "my.host.domain" to specify machine | ||||
| .IP "-" | ||||
| (any single-letter string) to make it pick the machine's default | ||||
| make curl pick the same IP address that is already used for the control | ||||
| connection | ||||
| .RE | ||||
|  | ||||
| If this option is used several times, the last one will be used. Disable the | ||||
| @@ -752,7 +859,7 @@ must send syntactically correct FTP commands as RFC959 defines. | ||||
|  | ||||
| This option can be used multiple times. | ||||
| .IP "--random-file <file>" | ||||
| (HTTPS) Specify the path name to file containing what will be considered as | ||||
| (SSL) Specify the path name to file containing what will be considered as | ||||
| random data. The data is used to seed the random engine for SSL connections. | ||||
| See also the \fI--egd-file\fP option. | ||||
| .IP "-r/--range <range>" | ||||
| @@ -770,7 +877,7 @@ specifies the second 500 bytes | ||||
| .B -500 | ||||
| specifies the last 500 bytes | ||||
| .TP | ||||
| .B 9500 | ||||
| .B 9500- | ||||
| specifies the bytes from offset 9500 and forward | ||||
| .TP | ||||
| .B 0-0,-1 | ||||
| @@ -811,7 +918,7 @@ for all forthcoming retries it will double the waiting time until it reaches | ||||
| 10 minutes which then will be the delay between the rest of the retries.  By | ||||
| using \fI--retry-delay\fP you disable this exponential backoff algorithm. See | ||||
| also \fI--retry-max-time\fP to limit the total time allowed for | ||||
| retries. (Option added in 7.12.3) | ||||
| retries. (Added in 7.12.3) | ||||
|  | ||||
| If this option is used multiple times, the last occurrence decide the amount. | ||||
| .IP "--retry-delay <seconds>" | ||||
| @@ -819,7 +926,7 @@ Make curl sleep this amount of time between each retry when a transfer has | ||||
| failed with a transient error (it changes the default backoff time algorithm | ||||
| between retries). This option is only interesting if \fI--retry\fP is also | ||||
| used. Setting this delay to zero will make curl use the default backoff time. | ||||
| (Option added in 7.12.3) | ||||
| (Added in 7.12.3) | ||||
|  | ||||
| If this option is used multiple times, the last occurrence decide the amount. | ||||
| .IP "--retry-max-time <seconds>" | ||||
| @@ -828,26 +935,36 @@ done as usual (see \fI--retry\fP) as long as the timer hasn't reached this | ||||
| given limit. Notice that if the timer hasn't reached the limit, the request | ||||
| will be made and while performing, it may take longer than this given time | ||||
| period. To limit a single request\'s maximum time, use \fI-m/--max-time\fP. | ||||
| Set this option to zero to not timeout retries. (Option added in 7.12.3) | ||||
| Set this option to zero to not timeout retries. (Added in 7.12.3) | ||||
|  | ||||
| If this option is used multiple times, the last occurrence decide the amount. | ||||
| .IP "-s/--silent" | ||||
| Silent mode. Don't show progress meter or error messages.  Makes | ||||
| Curl mute. | ||||
|  | ||||
| If this option is used twice, the second will again disable mute. | ||||
| If this option is used twice, the second will again disable silent mode. | ||||
| .IP "-S/--show-error" | ||||
| When used with -s it makes curl show error message if it fails. | ||||
|  | ||||
| If this option is used twice, the second will again disable show error. | ||||
| .IP "--socks <host[:port]>" | ||||
| Use the specified SOCKS5 proxy. If the port number is not specified, it is | ||||
| assumed at port 1080. (Option added in 7.11.1) | ||||
| .IP "--socks4 <host[:port]>" | ||||
| Use the specified SOCKS4 proxy. If the port number is not specified, it is | ||||
| assumed at port 1080. (Added in 7.15.2) | ||||
|  | ||||
| This option overrides any previous use of \fI-x/--proxy\fP, as they are | ||||
| mutually exclusive. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--socks5 <host[:port]>" | ||||
| Use the specified SOCKS5 proxy. If the port number is not specified, it is | ||||
| assumed at port 1080. (Added in 7.11.1) | ||||
|  | ||||
| This option overrides any previous use of \fI-x/--proxy\fP, as they are | ||||
| mutually exclusive. | ||||
|  | ||||
| If this option is used several times, the last one will be used. (This option | ||||
| was previously wrongly documented and used as --socks without the number | ||||
| appended.) | ||||
| .IP "--stderr <file>" | ||||
| Redirect all writes to stderr to the specified file instead. If the file name | ||||
| is a plain '-', it is instead written to stdout. This option has no point when | ||||
| @@ -877,13 +994,10 @@ this is used on a http(s) server, the PUT command will be used. | ||||
|  | ||||
| Use the file name "-" (a single dash) to use stdin instead of a given file. | ||||
|  | ||||
| Before 7.10.8, when this option was used several times, the last one was used. | ||||
|  | ||||
| In curl 7.10.8 and later, you can specify one -T for each URL on the command | ||||
| line. Each -T + URL pair specifies what to upload and to where. curl also | ||||
| supports "globbing" of the -T argument, meaning that you can upload multiple | ||||
| files to a single URL by using the same URL globbing style supported in the | ||||
| URL, like this: | ||||
| You can specify one -T for each URL on the command line. Each -T + URL pair | ||||
| specifies what to upload and to where. curl also supports "globbing" of the -T | ||||
| argument, meaning that you can upload multiple files to a single URL by using | ||||
| the same URL globbing style supported in the URL, like this: | ||||
|  | ||||
| curl -T "{file1,file2}" http://www.uploadtothissite.com | ||||
|  | ||||
| @@ -895,8 +1009,7 @@ 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. | ||||
|  | ||||
| If this option is used several times, the last one will be used. (Added in | ||||
| 7.9.7) | ||||
| 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 | ||||
| descriptive information, to the given output file. Use "-" as filename to have | ||||
| @@ -906,21 +1019,28 @@ 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. | ||||
|  | ||||
| If this option is used several times, the last one will be used. (Added in | ||||
| 7.9.7) | ||||
| 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. | ||||
| (Added in 7.14.0) | ||||
|  | ||||
| If this option is used several times, each occurrence will toggle it on/off. | ||||
| (Added in 7.14.0        ) | ||||
| .IP "-u/--user <user:password>" | ||||
| 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 | ||||
| force curl to pick up the user name and password from your environment by | ||||
| simply specifying a single colon with this option: "-u :". | ||||
|  | ||||
| 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 | ||||
| force curl to pick up the user name and password from your environment by | ||||
| simply specifying a single colon with this option: "-U :". | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "--url <URL>" | ||||
| Specify a URL to fetch. This option is mostly handy when you want to specify | ||||
| @@ -1058,13 +1178,17 @@ The average download speed that curl measured for the complete download. | ||||
| The average upload speed that curl measured for the complete upload. | ||||
| .TP | ||||
| .B content_type | ||||
| The Content-Type of the requested document, if there was any. (Added in 7.9.5) | ||||
| The Content-Type of the requested document, if there was any. | ||||
| .TP | ||||
| .B num_connects | ||||
| Number of new connects made in the recent transfer. (Added in 7.12.3) | ||||
| .TP | ||||
| .B num_redirects | ||||
| Number of redirects that were followed in the request. (Added in 7.12.3) | ||||
| .TP | ||||
| .B ftp_entry_path | ||||
| The initial path libcurl ended up in when logging on to the remote FTP | ||||
| server. (Added in 7.15.4) | ||||
| .RE | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| @@ -1113,7 +1237,7 @@ not set. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-z/--time-cond <date expression>" | ||||
| (HTTP) Request a file that has been modified later than the given time and | ||||
| (HTTP/FTP) Request a file that has been modified later than the given time and | ||||
| date, or one that has been modified before that time. The date expression can | ||||
| be all sorts of date strings or if it doesn't match any internal ones, it | ||||
| tries to get the time from a given file name instead! See the | ||||
| @@ -1127,40 +1251,30 @@ If this option is used several times, the last one will be used. | ||||
| .IP "--max-redirs <num>" | ||||
| Set maximum number of redirection-followings allowed. If \fI-L/--location\fP | ||||
| is used, this option can be used to prevent curl from following redirections | ||||
| \&"in absurdum". | ||||
| \&"in absurdum". By default, the limit is set to 50 redirections. Set this | ||||
| option to -1 to make it limitless. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-0/--http1.0" | ||||
| (HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its | ||||
| internally preferred: HTTP 1.1. | ||||
| .IP "-1/--tlsv1" | ||||
| (HTTPS) | ||||
| (SSL) | ||||
| Forces curl to use TSL version 1 when negotiating with a remote TLS server. | ||||
| .IP "-2/--sslv2" | ||||
| (HTTPS) | ||||
| (SSL) | ||||
| Forces curl to use SSL version 2 when negotiating with a remote SSL server. | ||||
| .IP "-3/--sslv3" | ||||
| (HTTPS) | ||||
| (SSL) | ||||
| Forces curl to use SSL version 3 when negotiating with a remote SSL server. | ||||
| .IP "--3p-quote" | ||||
| (FTP) Specify arbitrary commands to send to the source server. See the | ||||
| \fI-Q/--quote\fP option for details. (Added in 7.13.0) | ||||
| .IP "--3p-url" | ||||
| (FTP) Activates a FTP 3rd party transfer. Specifies the source URL to get a | ||||
| file from, while the "normal" URL will be used as target URL, the file that | ||||
| will be written/created. | ||||
|  | ||||
| Note that not all FTP server allow 3rd party transfers. (Added in 7.13.0) | ||||
| .IP "--3p-user" | ||||
| (FTP) Specify user:password for the source URL transfer. (Added in 7.13.0) | ||||
| .IP "-4/--ipv4" | ||||
| If libcurl is capable of resolving an address to multiple IP versions (which | ||||
| it is if it is ipv6-capable), this option tells libcurl to resolve names to | ||||
| IPv4 addresses only. (Added in 7.10.8) | ||||
| IPv4 addresses only. | ||||
| .IP "-6/--ipv6" | ||||
| If libcurl is capable of resolving an address to multiple IP versions (which | ||||
| it is if it is ipv6-capable), this option tells libcurl to resolve names to | ||||
| IPv6 addresses only. (Added in 7.10.8) | ||||
| IPv6 addresses only. | ||||
| .IP "-#/--progress-bar" | ||||
| Make curl display progress information as a progress bar instead of the | ||||
| default statistics. | ||||
| @@ -1169,7 +1283,7 @@ If this option is used twice, the second will again disable the progress bar. | ||||
| .SH FILES | ||||
| .I ~/.curlrc | ||||
| .RS | ||||
| Default config file. | ||||
| Default config file, see \fI-K/--config\fP for details. | ||||
|  | ||||
| .SH ENVIRONMENT | ||||
| .IP "http_proxy [protocol://]<host>[:port]" | ||||
| @@ -1178,8 +1292,6 @@ Sets proxy server to use for HTTP. | ||||
| Sets proxy server to use for HTTPS. | ||||
| .IP "FTP_PROXY [protocol://]<host>[:port]" | ||||
| Sets proxy server to use for FTP. | ||||
| .IP "GOPHER_PROXY [protocol://]<host>[:port]" | ||||
| Sets proxy server to use for GOPHER. | ||||
| .IP "ALL_PROXY [protocol://]<host>[:port]" | ||||
| Sets proxy server to use if no protocol-specific proxy is set. | ||||
| .IP "NO_PROXY <comma-separated list of hosts>" | ||||
| @@ -1206,7 +1318,9 @@ Failed to connect to host. | ||||
| .IP 8 | ||||
| FTP weird server reply. The server sent data curl couldn't parse. | ||||
| .IP 9 | ||||
| FTP access denied. The server denied login. | ||||
| FTP access denied. The server denied login or denied access to the particular | ||||
| resource or directory you wanted to reach. Most often you tried to change to a | ||||
| directory that doesn't exist on the server. | ||||
| .IP 10 | ||||
| FTP user/password incorrect. Either one or both were not accepted by the | ||||
| server. | ||||
| @@ -1322,6 +1436,32 @@ Unrecognized transfer encoding | ||||
| Invalid LDAP URL | ||||
| .IP 63 | ||||
| Maximum file size exceeded | ||||
| .IP 64 | ||||
| Requested FTP SSL level failed | ||||
| .IP 65 | ||||
| Sending the data requires a rewind that failed | ||||
| .IP 66 | ||||
| Failed to initialise SSL Engine | ||||
| .IP 67 | ||||
| User, password or similar was not accepted and curl failed to login | ||||
| .IP 68 | ||||
| File not found on TFTP server | ||||
| .IP 69 | ||||
| Permission problem on TFTP server | ||||
| .IP 70 | ||||
| Out of disk space on TFTP server | ||||
| .IP 71 | ||||
| Illegal TFTP operation | ||||
| .IP 72 | ||||
| Unknown TFTP transfer ID | ||||
| .IP 73 | ||||
| File already exists (TFTP) | ||||
| .IP 74 | ||||
| No such user (TFTP) | ||||
| .IP 75 | ||||
| Character conversion failed | ||||
| .IP 76 | ||||
| Character conversion functions required | ||||
| .IP XX | ||||
| There will appear more error codes here in future releases. The existing ones | ||||
| are meant to never change. | ||||
|   | ||||
							
								
								
									
										166
									
								
								docs/examples/10-at-a-time.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								docs/examples/10-at-a-time.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,166 @@ | ||||
| /***************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * Example application source code using the multi interface to download many | ||||
|  * files, but with a capped maximum amount of simultaneous transfers. | ||||
|  * | ||||
|  * Written by Michael Wallner | ||||
|  */ | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <curl/multi.h> | ||||
|  | ||||
| static const char *urls[] = { | ||||
|   "http://www.microsoft.com", | ||||
|   "http://www.opensource.org", | ||||
|   "http://www.google.com", | ||||
|   "http://www.yahoo.com", | ||||
|   "http://www.ibm.com", | ||||
|   "http://www.mysql.com", | ||||
|   "http://www.oracle.com", | ||||
|   "http://www.ripe.net", | ||||
|   "http://www.iana.org", | ||||
|   "http://www.amazon.com", | ||||
|   "http://www.netcraft.com", | ||||
|   "http://www.heise.de", | ||||
|   "http://www.chip.de", | ||||
|   "http://www.ca.com", | ||||
|   "http://www.cnet.com", | ||||
|   "http://www.news.com", | ||||
|   "http://www.cnn.com", | ||||
|   "http://www.wikipedia.org", | ||||
|   "http://www.dell.com", | ||||
|   "http://www.hp.com", | ||||
|   "http://www.cert.org", | ||||
|   "http://www.mit.edu", | ||||
|   "http://www.nist.gov", | ||||
|   "http://www.ebay.com", | ||||
|   "http://www.playstation.com", | ||||
|   "http://www.uefa.com", | ||||
|   "http://www.ieee.org", | ||||
|   "http://www.apple.com", | ||||
|   "http://www.sony.com", | ||||
|   "http://www.symantec.com", | ||||
|   "http://www.zdnet.com", | ||||
|   "http://www.fujitsu.com", | ||||
|   "http://www.supermicro.com", | ||||
|   "http://www.hotmail.com", | ||||
|   "http://www.ecma.com", | ||||
|   "http://www.bbc.co.uk", | ||||
|   "http://news.google.com", | ||||
|   "http://www.foxnews.com", | ||||
|   "http://www.msn.com", | ||||
|   "http://www.wired.com", | ||||
|   "http://www.sky.com", | ||||
|   "http://www.usatoday.com", | ||||
|   "http://www.cbs.com", | ||||
|   "http://www.nbc.com", | ||||
|   "http://slashdot.org", | ||||
|   "http://www.bloglines.com", | ||||
|   "http://www.techweb.com", | ||||
|   "http://www.newslink.org", | ||||
|   "http://www.un.org", | ||||
| }; | ||||
|  | ||||
| #define MAX 10 /* number of simultaneous transfers */ | ||||
| #define CNT sizeof(urls)/sizeof(char*) /* total number of transfers to do */ | ||||
|  | ||||
| static int cb(char *d, size_t n, size_t l, void *p) | ||||
| { | ||||
|   /* take care of the data here, ignored in this example */ | ||||
|   (void)d; | ||||
|   (void)p; | ||||
|   return n*l; | ||||
| } | ||||
|  | ||||
| static void init(CURLM *cm, int i) | ||||
| { | ||||
|   CURL *eh = curl_easy_init(); | ||||
|  | ||||
|   curl_easy_setopt(eh, CURLOPT_WRITEFUNCTION, cb); | ||||
|   curl_easy_setopt(eh, CURLOPT_HEADER, 0); | ||||
|   curl_easy_setopt(eh, CURLOPT_URL, urls[i]); | ||||
|   curl_easy_setopt(eh, CURLOPT_PRIVATE, urls[i]); | ||||
|   curl_easy_setopt(eh, CURLOPT_VERBOSE, 0); | ||||
|  | ||||
|   curl_multi_add_handle(cm, eh); | ||||
| } | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURLM *cm; | ||||
|   CURLMsg *msg; | ||||
|   long L; | ||||
|   unsigned int C=0; | ||||
|   int M, Q, U = -1; | ||||
|   fd_set R, W, E; | ||||
|   struct timeval T; | ||||
|  | ||||
|   curl_global_init(CURL_GLOBAL_ALL); | ||||
|  | ||||
|   cm = curl_multi_init(); | ||||
|  | ||||
|   for (C = 0; C < MAX; ++C) { | ||||
|     init(cm, C); | ||||
|   } | ||||
|  | ||||
|   while (U) { | ||||
|     while (CURLM_CALL_MULTI_PERFORM == curl_multi_perform(cm, &U)); | ||||
|  | ||||
|     if (U) { | ||||
|       FD_ZERO(&R); | ||||
|       FD_ZERO(&W); | ||||
|       FD_ZERO(&E); | ||||
|  | ||||
|       if (curl_multi_fdset(cm, &R, &W, &E, &M)) { | ||||
|         fprintf(stderr, "E: curl_multi_fdset\n"); | ||||
|         return EXIT_FAILURE; | ||||
|       } | ||||
|  | ||||
|       /* In a real-world program you OF COURSE check the return that maxfd is | ||||
|          bigger than -1 so that the call to select() below makes sense! */ | ||||
|  | ||||
|       if (curl_multi_timeout(cm, &L)) { | ||||
|         fprintf(stderr, "E: curl_multi_timeout\n"); | ||||
|         return EXIT_FAILURE; | ||||
|       } | ||||
|  | ||||
|       T.tv_sec = L/1000; | ||||
|       T.tv_usec = (L%1000)*1000; | ||||
|  | ||||
|       if (0 > select(M+1, &R, &W, &E, &T)) { | ||||
|         fprintf(stderr, "E: select\n"); | ||||
|         return EXIT_FAILURE; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     while ((msg = curl_multi_info_read(cm, &Q))) { | ||||
|       if (msg->msg == CURLMSG_DONE) { | ||||
|         char *url; | ||||
|         CURL *e = msg->easy_handle; | ||||
|         curl_easy_getinfo(msg->easy_handle, CURLINFO_PRIVATE, &url); | ||||
|         fprintf(stderr, "R: %d - %s <%s>\n", | ||||
|                 msg->data.result, curl_easy_strerror(msg->data.result), url); | ||||
|         curl_multi_remove_handle(cm, e); | ||||
|         curl_easy_cleanup(e); | ||||
|       } | ||||
|       else { | ||||
|         fprintf(stderr, "E: CURLMsg (%d)\n", msg->msg); | ||||
|       } | ||||
|       if (C < CNT) { | ||||
|         init(cm, C++); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   curl_multi_cleanup(cm); | ||||
|   curl_global_cleanup(); | ||||
|  | ||||
|   return EXIT_SUCCESS; | ||||
| } | ||||
| @@ -11,7 +11,8 @@ EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c		\ | ||||
|  multi-post.c fopen.c simplepost.c makefile.dj curlx.c https.c		\ | ||||
|  multi-debugcallback.c fileupload.c getinfo.c ftp3rdparty.c debug.c	\ | ||||
|  anyauthput.c htmltitle.cc htmltidy.c opensslthreadlock.c		\ | ||||
|  cookie_interface.c cacertinmem.c | ||||
|  cookie_interface.c cacertinmem.c synctime.c sampleconv.c ftpuploadresume.c \ | ||||
|  10-at-a-time.c hiperfifo.c ghiper.c | ||||
|  | ||||
| all: | ||||
| 	@echo "done" | ||||
|   | ||||
| @@ -26,13 +26,15 @@ want you do reorganize them like: | ||||
|   $ `curl-config --cc` -o example example.c `curl-config --cflags --libs` | ||||
|  | ||||
| *PLEASE* do not use the curl.haxx.se site as a test target for your libcurl | ||||
| applications/experiments. Even if the examples in this directory use that site | ||||
| as an example URL at some places, it doesn't mean that the URLs work or that | ||||
| we expect you to actually torture our web site with your tests! Thanks. | ||||
| applications/experiments. Even if some of the examples use that site as a URL | ||||
| at some places, it doesn't mean that the URLs work or that we expect you to | ||||
| actually torture our web site with your tests!  Thanks. | ||||
|  | ||||
| EXAMPLES | ||||
|  | ||||
| anyauthput.c   - HTTP PUT using "any" authentication method | ||||
| cacertinmem.c  - Use a built-in PEM certificate to retrieve a https page | ||||
| cookie_interface.c - shows usage of simple cookie interface | ||||
| curlgtk.c      - download using a GTK progress bar | ||||
| curlx.c        - getting file info from the remote cert data | ||||
| debug.c        - showing how to use the debug callback | ||||
| @@ -41,9 +43,13 @@ fopen.c        - fopen() layer that supports opening URLs and files | ||||
| ftp3rdparty.c  - FTP 3rd party transfer | ||||
| ftpget.c       - simple getting a file from FTP | ||||
| ftpgetresp.c   - get the response strings from the FTP server | ||||
| ftpupload.c    - upload a file to a FTP server | ||||
| ftpupload.c    - upload a file to an FTP server | ||||
| ftpuploadresume.c - resume an upload to an FTP server | ||||
| getinfo.c      - get the Content-Type from the recent transfer | ||||
| getinmemory.c  - download a file to memory only | ||||
| ghiper.c       - curl_multi_socket() using code with glib-2 | ||||
| hiperfifo.c    - downloads all URLs written to the fifo, using | ||||
|                  curl_multi_socket() and libevent | ||||
| htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML | ||||
|                  page using libxml | ||||
| http-post.c    - HTTP POST | ||||
| @@ -55,10 +61,16 @@ multi-double.c - a multi-interface app doing two simultaneous transfers | ||||
| multi-post.c   - a multi-interface app doing a multipart formpost | ||||
| multi-single.c - a multi-interface app getting a single file | ||||
| multithread.c  - an example using multi-treading transfering multiple files | ||||
| opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded | ||||
| persistant.c   - request two URLs with a persistant connection | ||||
| post-callback.c - send a HTTP POST using a callback | ||||
| postit2.c      - send a HTTP multipart formpost | ||||
| sampleconv.c   - showing how a program on a non-ASCII platform would invoke | ||||
|                  callbacks to do its own codeset conversions instead of using | ||||
|                  the built-in iconv functions in libcurl | ||||
| sepheaders.c   - download headers to a separate file | ||||
| simple.c       - the most simple download a URL source | ||||
| simplepost.c   - HTTP POST | ||||
| simplessl.c    - HTTPS example with certificates many options set | ||||
| synctime.c     - Sync local time by extracing date from remote HTTP servers | ||||
| 10-at-a-time.c - Download many files simultaneously, 10 at a time. | ||||
|   | ||||
| @@ -114,6 +114,13 @@ static char *curlx_usage[]={ | ||||
|  | ||||
| */ | ||||
|  | ||||
| /*  | ||||
|  * We use this ZERO_NULL to avoid picky compiler warnings, | ||||
|  * when assigning a NULL pointer to a function pointer var. | ||||
|  */ | ||||
|  | ||||
| #define ZERO_NULL 0 | ||||
|  | ||||
| /* This is a context that we pass to all callbacks */ | ||||
|  | ||||
| typedef struct sslctxparm_st { | ||||
| @@ -236,7 +243,7 @@ static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) { | ||||
|  | ||||
|   SSL_CTX_set_verify_depth(ctx,2); | ||||
|  | ||||
|   SSL_CTX_set_verify(ctx,SSL_VERIFY_PEER,NULL); | ||||
|   SSL_CTX_set_verify(ctx,SSL_VERIFY_PEER,ZERO_NULL); | ||||
|  | ||||
|   SSL_CTX_set_cert_verify_callback(ctx, ssl_app_verify_callback, parm); | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user