Compare commits
	
		
			874 Commits
		
	
	
		
			curl-7_12_
			...
			curl-7_15_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 96cec4dfd7 | ||
|   | 943aea6267 | ||
|   | b433e4a1e7 | ||
|   | 20f1966c0e | ||
|   | ab1f5c3edd | ||
|   | b2be6799f2 | ||
|   | ea2618fc6f | ||
|   | 62fdf8eaed | ||
|   | d3569a3572 | ||
|   | 89df76e449 | ||
|   | e5b2f33b4f | ||
|   | 934d312f50 | ||
|   | 68917eb517 | ||
|   | 3beb2f6b5d | ||
|   | b29017f15b | ||
|   | db83a0ebbc | ||
|   | 6d9fddb95d | ||
|   | 4284190cc4 | ||
|   | 5e4cbd2d24 | ||
|   | 06c3bec65d | ||
|   | e8c3bb45ba | ||
|   | 4ec55a964d | ||
|   | b9420864c0 | ||
|   | bf6588b6a7 | ||
|   | e43217e664 | ||
|   | e19ee2d102 | ||
|   | b4c53e2cfd | ||
|   | a2902de67c | ||
|   | da192f7955 | ||
|   | a2210d23c3 | ||
|   | bd5a622400 | ||
|   | b9494cb0d6 | ||
|   | 0f73af4470 | ||
|   | 45e26b5c02 | ||
|   | 6af5ea38ce | ||
|   | b6f0aa4394 | ||
|   | 774dab58f6 | ||
|   | e3bdb98f7a | ||
|   | 58d628c9f8 | ||
|   | 1e69394545 | ||
|   | 1cf798ad14 | ||
|   | da3992d2e9 | ||
|   | 48908e4633 | ||
|   | f5ae149338 | ||
|   | 3fe5311967 | ||
|   | 6a48639c68 | ||
|   | e7093b3ca8 | ||
|   | d0a4104c0c | ||
|   | 90559bed53 | ||
|   | 973a18cf03 | ||
|   | 3c666ce57a | ||
|   | a1287ec64f | ||
|   | 5fbfa1bfa8 | ||
|   | da3ecc91f8 | ||
|   | 09c8f558f7 | ||
|   | 528a149def | ||
|   | 29e36afb6b | ||
|   | 0e39543d35 | ||
|   | 0de20d8ee6 | ||
|   | cd5de5c0e5 | ||
|   | bd5afc26bd | ||
|   | 9542dfdcdc | ||
|   | 97a6d7b1a8 | ||
|   | 209b9d4374 | ||
|   | 0b8ccd0ae7 | ||
|   | 0b7f5ad508 | ||
|   | 8a38805e82 | ||
|   | 836d88a4b8 | ||
|   | d5268ed511 | ||
|   | 0e7d93858d | ||
|   | 2164d760b7 | ||
|   | b9c8de598b | ||
|   | 9889a811db | ||
|   | 9e38d882b9 | ||
|   | e8635044b5 | ||
|   | 56dea0ac9a | ||
|   | e8b77477c7 | ||
|   | 64298e528d | ||
|   | 4f1465e7c7 | ||
|   | 6120041b69 | ||
|   | 8c1213627d | ||
|   | 3e6ae6eeb8 | ||
|   | 291e9aeabd | ||
|   | a3d776187a | ||
|   | e55f502e2f | ||
|   | e369270f88 | ||
|   | 7e845e7cfd | ||
|   | 56d9624b56 | ||
|   | 911d135deb | ||
|   | 8107b90678 | ||
|   | 7722452b98 | ||
|   | 6e1a986e0f | ||
|   | e0785ade35 | ||
|   | 0177ed6f03 | ||
|   | c62635a3b5 | ||
|   | 0177476fd2 | ||
|   | 76d7dface7 | ||
|   | 982ba21460 | ||
|   | 6081c60556 | ||
|   | 2fe3c22108 | ||
|   | 75dbb3189a | ||
|   | 32330300a9 | ||
|   | 64414df27e | ||
|   | f98ec86798 | ||
|   | 87bbd13899 | ||
|   | 51a4493add | ||
|   | 5effe8f336 | ||
|   | 296eb2bd61 | ||
|   | 9853acba66 | ||
|   | 09cb9c782d | ||
|   | 575ce905b2 | ||
|   | 54887af471 | ||
|   | 573350637e | ||
|   | 49a16f7121 | ||
|   | a4773fcbbb | ||
|   | 1e038c4bc6 | ||
|   | 6ba19692a3 | ||
|   | 432dfe2b8f | ||
|   | a142372750 | ||
|   | f14195f786 | ||
|   | 9d54f9a6b7 | ||
|   | ebb91191bf | ||
|   | 8742e294d4 | ||
|   | 8882d1fa1b | ||
|   | 0c37ab5255 | ||
|   | 747a05844d | ||
|   | c7b7bf32f8 | ||
|   | 710ee3b0e0 | ||
|   | 7a8993892d | ||
|   | 5e16a77fa9 | ||
|   | ef35519696 | ||
|   | d5baaf7756 | ||
|   | 2a94387fc3 | ||
|   | 6a5c2b0fc3 | ||
|   | fc281d6440 | ||
|   | e22ac39da4 | ||
|   | 34cadb1e54 | ||
|   | 94692b904e | ||
|   | 18f3087afd | ||
|   | 15bc228ae9 | ||
|   | 2b7a38d032 | ||
|   | 90e1a6905a | ||
|   | c36af24cbd | ||
|   | a676c18502 | ||
|   | 362912ff83 | ||
|   | 46ff13f243 | ||
|   | 340a67a6f8 | ||
|   | 9294c1e76c | ||
|   | fd704f8de0 | ||
|   | d9ca9154d1 | ||
|   | 35110eca73 | ||
|   | 9ad92b3007 | ||
|   | 2f78c96330 | ||
|   | 639857ceb2 | ||
|   | 162f58c53c | ||
|   | 84c4d96e71 | ||
|   | c0d343d56d | ||
|   | 6d14a80608 | ||
|   | f451bb7c49 | ||
|   | 20b17d6b04 | ||
|   | bb2317b63c | ||
|   | 189461dc98 | ||
|   | 69af552bc1 | ||
|   | 0ae6ff9f72 | ||
|   | 8b571fbbb1 | ||
|   | f3fcd409d5 | ||
|   | a47532f88a | ||
|   | 6c157a404b | ||
|   | 4f8a49143d | ||
|   | 493d6033aa | ||
|   | 8f219af884 | ||
|   | aeb04136f7 | ||
|   | 0b8f57bf06 | ||
|   | 6508d446e1 | ||
|   | 82cb462bb4 | ||
|   | 9a264bf610 | ||
|   | 57007e80a9 | ||
|   | b6c876bdb6 | ||
|   | 57afae79eb | ||
|   | 84c2184909 | ||
|   | e358a24a75 | ||
|   | 9da9d00c62 | ||
|   | ec3f269d1f | ||
|   | 1c388a52a5 | ||
|   | 34a827bbfe | ||
|   | 726b9e2240 | ||
|   | 2236ba0d20 | ||
|   | 463c0f7096 | ||
|   | e49a7e361c | ||
|   | 6e87cf5b30 | ||
|   | 5872e8dd7e | ||
|   | e81d4ac8c8 | ||
|   | 4922904991 | ||
|   | decae2dcda | ||
|   | 16bbd13af7 | ||
|   | ee0666c8df | ||
|   | a8a8ae2e92 | ||
|   | fd1148a728 | ||
|   | 74c7b41ee7 | ||
|   | 465e19dbe9 | ||
|   | 86660c73e5 | ||
|   | 6d8a208df2 | ||
|   | c3a826fdce | ||
|   | c5d6a42abf | ||
|   | d49c144297 | ||
|   | e7de7d5eb3 | ||
|   | 20005a83d2 | ||
|   | 27926030f9 | ||
|   | 701de67b79 | ||
|   | 883479f01e | ||
|   | b37a0b0512 | ||
|   | 5c5d5270d2 | ||
|   | 36461fb2aa | ||
|   | d8dcd5e472 | ||
|   | c51b46c982 | ||
|   | b1b63c1dd1 | ||
|   | 30c93d66eb | ||
|   | 3b60bb7259 | ||
|   | c73f8e835f | ||
|   | 93558c4299 | ||
|   | 396cff5779 | ||
|   | 336154e729 | ||
|   | bb0aba34fa | ||
|   | 1dc0ce9562 | ||
|   | e4aee168b5 | ||
|   | 2c10c895da | ||
|   | c04fae3096 | ||
|   | a214af0830 | ||
|   | f21bc46e82 | ||
|   | 044327a488 | ||
|   | c4bbcc83b6 | ||
|   | eb162b73c2 | ||
|   | 29aafb9cea | ||
|   | 40eb7d0d48 | ||
|   | 1dcb2b7e65 | ||
|   | 5470b9aa73 | ||
|   | 050bd7dd0b | ||
|   | f75038634f | ||
|   | 300b4a9158 | ||
|   | 52071f3476 | ||
|   | 42ddd745f8 | ||
|   | a7846189cd | ||
|   | 4762995d1f | ||
|   | e3a530eb61 | ||
|   | d1235ff058 | ||
|   | 4370e92dbd | ||
|   | 50e9522a06 | ||
|   | b5bb9aa8e3 | ||
|   | cf2e365f23 | ||
|   | 72e532cb67 | ||
|   | ac5635f77d | ||
|   | 640d67c119 | ||
|   | 3e79693e3b | ||
|   | d55d3c2fd0 | ||
|   | 3aced17c75 | ||
|   | bac63914db | ||
|   | 6a63c51f7c | ||
|   | 632cf13767 | ||
|   | e7012a515c | ||
|   | 6b638af92f | ||
|   | c654b79c53 | ||
|   | bee7b874ea | ||
|   | 9c3fc592f7 | ||
|   | 4eab7a1ebc | ||
|   | 3d985688e4 | ||
|   | 17ea2631cd | ||
|   | b749910e6c | ||
|   | eff36caea8 | ||
|   | 6ff092f140 | ||
|   | 28bb36e53d | ||
|   | 4a091bbd8a | ||
|   | e99a6b813e | ||
|   | b9e5302f27 | ||
|   | dd7b6aef39 | ||
|   | 910b8b6a69 | ||
|   | c3207e215f | ||
|   | f83be11b85 | ||
|   | 45bce1062a | ||
|   | 8cb344bf3c | ||
|   | fcc4518cdc | ||
|   | c84839eb91 | ||
|   | 1f878aee69 | ||
|   | 84fd4686e2 | ||
|   | ede9fb4fcc | ||
|   | 723aef71e8 | ||
|   | 48964a911e | ||
|   | 6a35cb60fd | ||
|   | 1e51c3a832 | ||
|   | 205dda2b39 | ||
|   | 1c18d19da0 | ||
|   | 645729e943 | ||
|   | f425a25c98 | ||
|   | aaace2e802 | ||
|   | 3f16d9fbc9 | ||
|   | 3afc57bab8 | ||
|   | 55225106b6 | ||
|   | 1a31bff9fe | ||
|   | 4eaa3329ec | ||
|   | 028d78b993 | ||
|   | 944af98be6 | ||
|   | 2789b2b0ad | ||
|   | 7dded571de | ||
|   | 95fe8372e8 | ||
|   | ecdcb0ef67 | ||
|   | 6a04a03eb5 | ||
|   | 0c96056a94 | ||
|   | f518a5e231 | ||
|   | f581c1062e | ||
|   | 0b3deceea3 | ||
|   | fa4cd8868c | ||
|   | 8c573ca7f3 | ||
|   | 5a5cf3a51d | ||
|   | 3f23e8443e | ||
|   | a00f9b093c | ||
|   | 5f538ce3f8 | ||
|   | ebcaa3d579 | ||
|   | 60e26199a2 | ||
|   | 11defd180c | ||
|   | c82c1691ee | ||
|   | 364562f209 | ||
|   | 5d9fc28fa7 | ||
|   | e5ec5c284f | ||
|   | a90e33ad71 | ||
|   | 62ab21ce7d | ||
|   | cc8e8db1e5 | ||
|   | b19cba2016 | ||
|   | 315a9c95d5 | ||
|   | e010ac9706 | ||
|   | e4c0a85da0 | ||
|   | d3e4cdd5b0 | ||
|   | 763b812dc7 | ||
|   | 3269dfb4ab | ||
|   | e816bd259f | ||
|   | a295408e09 | ||
|   | 42a34c7cd7 | ||
|   | 9a72751958 | ||
|   | 314e6fa80b | ||
|   | b2b66f749a | ||
|   | 708ed6fded | ||
|   | 5c30fa50d6 | ||
|   | fc33c424d9 | ||
|   | b04d6dd0b1 | ||
|   | 9c5f79c56a | ||
|   | ef5eea689a | ||
|   | fd191deb49 | ||
|   | e1da1ff7d3 | ||
|   | 2b00ed7ef8 | ||
|   | d960ea959d | ||
|   | 274842ec41 | ||
|   | c06da7c84a | ||
|   | cea117b509 | ||
|   | 6078c938b2 | ||
|   | 9e95dd4821 | ||
|   | 0cc8b57d4f | ||
|   | 2179e6e797 | ||
|   | 7dde3d1825 | ||
|   | a0fe950b75 | ||
|   | 44985e8884 | ||
|   | f03366bcbf | ||
|   | d43ea83033 | ||
|   | 11bdba0007 | ||
|   | 07e58aaa79 | ||
|   | a31ddd363b | ||
|   | ed9e10f2d8 | ||
|   | 02ae3c2810 | ||
|   | 669ebb5f71 | ||
|   | 9a3e0e52cb | ||
|   | b0f856213d | ||
|   | 6f4ff1f2bf | ||
|   | d3eea61f1f | ||
|   | d59d81fae8 | ||
|   | 329ca40b6f | ||
|   | e71bd416f4 | ||
|   | ad66fc6cc2 | ||
|   | d12b44204b | ||
|   | 4be2136de4 | ||
|   | c4dbed040b | ||
|   | 366b62af2d | ||
|   | a6955aa486 | ||
|   | ad30341fa2 | ||
|   | 23da55a9f1 | ||
|   | 41e6292e7b | ||
|   | ae1d6f29d9 | ||
|   | ccfc1ddbef | ||
|   | 002de1eae2 | ||
|   | 63621bae81 | ||
|   | 85f9e6c4b9 | ||
|   | 967ec296c0 | ||
|   | c6aae9b1d7 | ||
|   | 913c370c25 | ||
|   | e5472bbd21 | ||
|   | 957c258c6d | ||
|   | abee109cd1 | ||
|   | 502e5ae6e1 | ||
|   | b8417be1f2 | ||
|   | 9e037431b4 | ||
|   | f71b3676bb | ||
|   | 50fe7b5e35 | ||
|   | 9fb253388b | ||
|   | 8cf1786296 | ||
|   | 51b17b299c | ||
|   | 78882e4642 | ||
|   | 8465a367a4 | ||
|   | 3bcfe678ab | ||
|   | d5403f3a5b | ||
|   | 26abb48533 | ||
|   | 177848ed27 | ||
|   | 656a2e93d7 | ||
|   | 6b1220b61d | ||
|   | 9d7330d879 | ||
|   | 26a5954fa0 | ||
|   | 01165e08e0 | ||
|   | 6e1633a6c5 | ||
|   | a8ff0a21bf | ||
|   | b8bc6bed97 | ||
|   | 1a4402038c | ||
|   | 5ac51cc9b5 | ||
|   | c12159ce21 | ||
|   | 4485503ecc | ||
|   | 200ac588cc | ||
|   | 0bb040822d | ||
|   | 543fbe14ee | ||
|   | e02ab66120 | ||
|   | 76c7c694c5 | ||
|   | f0057977b7 | ||
|   | e8e43f06af | ||
|   | 04b35e86d5 | ||
|   | 64ab85da4f | ||
|   | b8d7a13ea3 | ||
|   | 78a76dc905 | ||
|   | 5fa5fff0e9 | ||
|   | d323b3d816 | ||
|   | b685b5672a | ||
|   | 8f6c2f87c8 | ||
|   | f30e8b11eb | ||
|   | 8bd6d6a4de | ||
|   | b3a8f438fc | ||
|   | e78ddf0a95 | ||
|   | 5f0366c2cb | ||
|   | 779ca09775 | ||
|   | 313f1a1e83 | ||
|   | 21337f4776 | ||
|   | 53a8e5655b | ||
|   | 2d85585ae1 | ||
|   | 63d109f7be | ||
|   | c904b6b5bf | ||
|   | 6a27449922 | ||
|   | 9a9c07f571 | ||
|   | 4382204e1b | ||
|   | 6d3114efe2 | ||
|   | b62baaed95 | ||
|   | 9b391e531b | ||
|   | a0c7a6d22b | ||
|   | 14424f7058 | ||
|   | 6063dff8d0 | ||
|   | 7fba9ed398 | ||
|   | 53280a196b | ||
|   | 0bf9a5704b | ||
|   | 8182d17ae1 | ||
|   | 69b1ac7dcd | ||
|   | b15507aac3 | ||
|   | 6c2f583f51 | ||
|   | a72eaddda3 | ||
|   | dc050e45df | ||
|   | 2fcbf13920 | ||
|   | 099ae31523 | ||
|   | c2fcdf3a02 | ||
|   | 2056a538b9 | ||
|   | cd1144dc24 | ||
|   | e9d068b913 | ||
|   | ec2ad57c32 | ||
|   | 316adac511 | ||
|   | d7b11d4c33 | ||
|   | c52aa6df33 | ||
|   | a19b23b59f | ||
|   | 4e26b2a65b | ||
|   | 7c4feac6db | ||
|   | e01e364c37 | ||
|   | c13a3d7b84 | ||
|   | 67805b6dc5 | ||
|   | 0050ab2a3d | ||
|   | 60e66c6cbf | ||
|   | 5ad2a253e8 | ||
|   | b5d50e9298 | ||
|   | 37f7362aca | ||
|   | bee198def5 | ||
|   | f09e479fd6 | ||
|   | 80fe93bc33 | ||
|   | ea03ad3bee | ||
|   | feec421744 | ||
|   | 634982840e | ||
|   | fb3c85ab2f | ||
|   | a9b7c3531c | ||
|   | a7ba0d908d | ||
|   | 2fc70e2c5d | ||
|   | 7ae3f0e70c | ||
|   | 9afaa51e3f | ||
|   | c736a719f1 | ||
|   | 37a547842b | ||
|   | b9f1d43921 | ||
|   | bec6423c02 | ||
|   | 241b2b4ae3 | ||
|   | 14d9b56937 | ||
|   | 1c3766eb46 | ||
|   | 70024d61eb | ||
|   | 2085f133d6 | ||
|   | 2a045dfceb | ||
|   | 893cbaaf2f | ||
|   | 6e61939382 | ||
|   | 015a618172 | ||
|   | 2a8b91cdb9 | ||
|   | bebd5dbc5a | ||
|   | 018dbfe058 | ||
|   | c6ea597817 | ||
|   | 175b00c0a2 | ||
|   | 5ebc6e305e | ||
|   | 993600761f | ||
|   | 1d9fff80b7 | ||
|   | c712b84dd5 | ||
|   | dcf8dd4b5e | ||
|   | ba26c3fb22 | ||
|   | 41563607a8 | ||
|   | 2d4dcfb740 | ||
|   | 34854e70cf | ||
|   | 758d9fe852 | ||
|   | 6a6c0e7a73 | ||
|   | ee44eec3e1 | ||
|   | eccd0d8e37 | ||
|   | 983be0ec60 | ||
|   | 243a45d840 | ||
|   | 60ec804047 | ||
|   | c53e9ccf4a | ||
|   | 6e8e0418fc | ||
|   | e9eb52305f | ||
|   | 8501ae748c | ||
|   | da59692067 | ||
|   | bae77c0a46 | ||
|   | b42bc7329e | ||
|   | 9b3c2b6ae2 | ||
|   | 833b6df969 | ||
|   | 0b45431139 | ||
|   | 5d1349031c | ||
|   | 82388a5e4c | ||
|   | 74816fed6c | ||
|   | b4c9789d5f | ||
|   | f96fadc074 | ||
|   | f6b1173437 | ||
|   | 346992c366 | ||
|   | ab4086bc24 | ||
|   | d8e7f2b2c7 | ||
|   | 93fcb94b62 | ||
|   | 32a446cf19 | ||
|   | 94459cab98 | ||
|   | 158588640a | ||
|   | f00f050d1b | ||
|   | c4f34c60a5 | ||
|   | 371ef80dc3 | ||
|   | 84b4e9ff7c | ||
|   | 677a74fa1b | ||
|   | 8a076d1dba | ||
|   | 970722483c | ||
|   | 31443724c6 | ||
|   | 0e7614919b | ||
|   | 2bf72937d2 | ||
|   | 4e555c7b32 | ||
|   | bd7021d05b | ||
|   | 1a14555605 | ||
|   | cb3fb371ea | ||
|   | 6c6dda1b74 | ||
|   | a712808006 | ||
|   | e19c203728 | ||
|   | 8817779f23 | ||
|   | 3e5a32671c | ||
|   | d34f32b39e | ||
|   | c85a77e0b1 | ||
|   | 9406e517e6 | ||
|   | 4a56049225 | ||
|   | 04ea4b4d75 | ||
|   | 5b6b6283f3 | ||
|   | 38f07ce0fb | ||
|   | 987cdebefb | ||
|   | 6b978db369 | ||
|   | 5840c8cb70 | ||
|   | 44f2024bab | ||
|   | 410942e9df | ||
|   | 5b3730feae | ||
|   | 38f797ccd6 | ||
|   | 553c5a7501 | ||
|   | bbba9d568f | ||
|   | 11e43dd021 | ||
|   | e8ddf84871 | ||
|   | 67f04d2d5f | ||
|   | 8f646eef45 | ||
|   | d26e932858 | ||
|   | 73b9d0840c | ||
|   | 2ea4326c40 | ||
|   | 8b80ac2877 | ||
|   | 233237740d | ||
|   | f5cdac38bd | ||
|   | 760565dcad | ||
|   | b5d97b3d94 | ||
|   | 4a6cc54eb5 | ||
|   | 61133545f6 | ||
|   | bf87d13f5b | ||
|   | efaf688650 | ||
|   | 9a5c21c16f | ||
|   | 06ffb47ef2 | ||
|   | 1acbda97e0 | ||
|   | d6460aff36 | ||
|   | a357f77c4c | ||
|   | d5bdd2b2f9 | ||
|   | 562d2de303 | ||
|   | 1f68fa19c7 | ||
|   | 677ddd6160 | ||
|   | 228e627475 | ||
|   | ec4e653c6f | ||
|   | 3916d1e6cb | ||
|   | 387aaba810 | ||
|   | 9f3d9da119 | ||
|   | 76c24a0d82 | ||
|   | ffd65a1956 | ||
|   | de8947f92f | ||
|   | d2b4dedbe4 | ||
|   | 34865ffb4a | ||
|   | 62970da675 | ||
|   | 8ed31c48e0 | ||
|   | 13d40e33a4 | ||
|   | c765213aaa | ||
|   | 983bf93a24 | ||
|   | 2f8085af15 | ||
|   | 88a4dc2795 | ||
|   | b5112096d7 | ||
|   | fc80c714e8 | ||
|   | 84bc23b92f | ||
|   | d90472dd64 | ||
|   | 3b63ed8230 | ||
|   | e75441e027 | ||
|   | 0ae8b51230 | ||
|   | 547c136b4f | ||
|   | 4ed13bde55 | ||
|   | 80e01deba0 | ||
|   | fb9ae9d0e2 | ||
|   | dd54d8551b | ||
|   | 205f8b266c | ||
|   | c4ce9ac4de | ||
|   | 0e4e28fdda | ||
|   | db2370a12f | ||
|   | d1d35ba85f | ||
|   | 2ab2e7675c | ||
|   | 0472629222 | ||
|   | c4f7570a23 | ||
|   | d26cfd5791 | ||
|   | b7ffc6bb45 | ||
|   | 8a96aec567 | ||
|   | 5cd9f57137 | ||
|   | 702664e959 | ||
|   | 18d87edd6d | ||
|   | dc59795629 | ||
|   | cb9bb31f7d | ||
|   | 02706bec94 | ||
|   | 7657186bf6 | ||
|   | 42ac24448c | ||
|   | 31891b55a4 | ||
|   | aa47ac4c06 | ||
|   | b01151e81c | ||
|   | 67bd6f9ccd | ||
|   | 4869fa285b | ||
|   | d221e01406 | ||
|   | 874fc8228a | ||
|   | 6f752c64bc | ||
|   | ccb7950c4c | ||
|   | 750e771376 | ||
|   | 7012a4a291 | ||
|   | 40ab20a252 | ||
|   | 6af315e50c | ||
|   | 861b5e608b | ||
|   | f61917594e | ||
|   | 0ddab51ad8 | ||
|   | 9798432f56 | ||
|   | 5faf52619d | ||
|   | f8b4ba80e0 | ||
|   | 527f70e540 | ||
|   | 19f66c7575 | ||
|   | b7721deb02 | ||
|   | 5ba188ab2d | ||
|   | eadfd78c2e | ||
|   | 4d815c9990 | ||
|   | 176981b529 | ||
|   | 85baebd0d4 | ||
|   | ac022b2e30 | ||
|   | f169b750b8 | ||
|   | 86295eef13 | ||
|   | 32d60b2714 | ||
|   | 0a3065a2f2 | ||
|   | b98faaa8c0 | ||
|   | 73772323c9 | ||
|   | 98389066e2 | ||
|   | fb53ed4c1f | ||
|   | e719eb5b81 | ||
|   | 3858063bcd | ||
|   | d4f5fea840 | ||
|   | 22c1d48cb2 | ||
|   | e7cefd684b | ||
|   | d2485e4f20 | ||
|   | 160d6b26b0 | ||
|   | 17d61e4f29 | ||
|   | 446b9467da | ||
|   | 3970a7056c | ||
|   | 74068a6d1b | ||
|   | 8c83422fe2 | ||
|   | 61a1e3cd01 | ||
|   | 89cac6f25c | ||
|   | 62082293c5 | ||
|   | 153fd2752c | ||
|   | e649a40f5d | ||
|   | 32d76a5b57 | ||
|   | 14aa3fa258 | ||
|   | f5394cccb1 | ||
|   | 64dd9c7656 | ||
|   | 16ae0c6466 | ||
|   | 6a2e21ec8c | ||
|   | 120f17ce04 | ||
|   | ab938bb9bd | ||
|   | 33820cd2ac | ||
|   | 41def21f91 | ||
|   | d118312922 | ||
|   | 82b93e4945 | ||
|   | e36fb1ecda | ||
|   | e4a1788614 | ||
|   | 7b23eff9cf | ||
|   | 67ff8e3ea3 | ||
|   | 2248599ae1 | ||
|   | 29350b363b | ||
|   | 83c470a443 | ||
|   | ab96e2d6e9 | ||
|   | 6b81cf4bc9 | ||
|   | 0d9301539e | ||
|   | 4a9e12542d | ||
|   | 21b4105454 | ||
|   | d7648d94ca | ||
|   | 883343ba63 | ||
|   | 16b5dc710f | ||
|   | 686d767053 | ||
|   | ed3176dd6b | ||
|   | 6a99ab098c | ||
|   | b03adde546 | ||
|   | e6034ea299 | ||
|   | c7f51ebeab | ||
|   | 9a820d7a98 | ||
|   | 8dbaf534c8 | ||
|   | 91f483c591 | ||
|   | c5b448038f | ||
|   | c4ff5eb0ca | ||
|   | 0859cd2444 | ||
|   | 59b45a90cc | ||
|   | f661475962 | ||
|   | 54b02ecf09 | ||
|   | 4551e7ce49 | ||
|   | 064bc3ecbc | ||
|   | cf38a4c470 | ||
|   | aacc79a3a3 | ||
|   | 9864bf703d | ||
|   | 289a42f050 | ||
|   | ade1e79b37 | ||
|   | 2415724d5f | ||
|   | 5463177f1f | ||
|   | 4efd751eda | ||
|   | 2337efc3b1 | ||
|   | b942a25a45 | ||
|   | beab9a9696 | ||
|   | 177dbc7be0 | ||
|   | f2e71edcbd | ||
|   | fad6e5a5bc | ||
|   | 52f6c437fe | ||
|   | 80a8be6319 | ||
|   | 043d70fcdf | ||
|   | 4f7e958969 | ||
|   | 53143910a1 | ||
|   | 95656cd7f3 | ||
|   | d8f79b263d | ||
|   | 51da8552c3 | ||
|   | 7e42cb61f7 | ||
|   | 6c038680f9 | ||
|   | 291a908f19 | ||
|   | b264a03f89 | ||
|   | 7472ede32a | ||
|   | b5065e462b | ||
|   | 8dd799b4bd | ||
|   | a38520c90d | ||
|   | 3050ae57c0 | ||
|   | 01205f772c | ||
|   | 06ad5be3af | ||
|   | 2fe3829e5e | ||
|   | a0c8b9bc68 | ||
|   | 0406b1facf | ||
|   | 65dbee01e5 | ||
|   | b1080f7c9a | ||
|   | 7bfd58d41f | ||
|   | 3851c6aae2 | ||
|   | ae03fa7d8e | ||
|   | 8a14dd25a9 | ||
|   | e0bea7d541 | ||
|   | 534a8a05f3 | ||
|   | f5b8a26d9a | ||
|   | cf51f7fb65 | ||
|   | 4d1f3d3cd0 | ||
|   | f70b87b4c5 | ||
|   | 0e26355348 | ||
|   | 246ea56eab | ||
|   | 7c1bba315b | ||
|   | 9395cad379 | ||
|   | c5b2e85b47 | ||
|   | 38f8087281 | ||
|   | e3fa7d021e | ||
|   | a1813e2b2d | ||
|   | 2e62458eef | ||
|   | bb9e5565f2 | ||
|   | 29102befa6 | ||
|   | 9d1145598a | ||
|   | 065e466f1a | ||
|   | 3ac00f32af | ||
|   | 21bb852750 | ||
|   | 83bab78bda | ||
|   | 894ec46ef4 | ||
|   | 4eb1d3eb1b | ||
|   | 945423e83a | ||
|   | 9fd33c0b96 | ||
|   | 3c09f2d2bd | ||
|   | 7b4bf6a22c | ||
|   | b5b77f6367 | ||
|   | 5a8097a4d5 | ||
|   | 9cdf6fb64b | ||
|   | a137223b4f | ||
|   | 52e1ce9518 | ||
|   | 8127a34f98 | ||
|   | 2dcb8b674f | ||
|   | 1e3b1b6e47 | ||
|   | 9cdaae94cc | ||
|   | 316e74be74 | ||
|   | af69c4f4f7 | ||
|   | ad9648a215 | ||
|   | 1576f3319e | ||
|   | 8ac90316d9 | ||
|   | 35ba5c826d | ||
|   | 4f4ffa98b5 | ||
|   | b7d92c3e03 | ||
|   | 4ecf939452 | ||
|   | 7ef6b05ef1 | ||
|   | 695f95aad1 | ||
|   | 2a6ea6d7a7 | ||
|   | f5e0ff2170 | ||
|   | 814d176b86 | ||
|   | 3955b31362 | ||
|   | 4b3fb5a01c | ||
|   | 67abd4cd47 | ||
|   | 58f4af7973 | ||
|   | 99befd3a15 | ||
|   | 3acda85c2b | ||
|   | dbb69797cf | ||
|   | 2910880b15 | ||
|   | 8b5f0abef1 | ||
|   | 10b5327b19 | ||
|   | 4ba1eb26fa | ||
|   | 444f6427b8 | ||
|   | a173e07eec | ||
|   | 3de85777de | ||
|   | f4c5314890 | ||
|   | 1225ad58bd | ||
|   | 951fdeba67 | ||
|   | 327b46cced | ||
|   | 80d301257c | ||
|   | 0e59182945 | ||
|   | 7270d5ce26 | ||
|   | a142d419d2 | 
							
								
								
									
										1994
									
								
								CHANGES.2004
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1994
									
								
								CHANGES.2004
									
									
									
									
									
										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 - 2004, Daniel Stenberg, <daniel@haxx.se>. | ||||
| Copyright (c) 1996 - 2005, Daniel Stenberg, <daniel@haxx.se>. | ||||
|  | ||||
| All rights reserved. | ||||
|  | ||||
|   | ||||
							
								
								
									
										13
									
								
								Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								Makefile.am
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2005, 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 | ||||
| @@ -48,6 +48,15 @@ pdf: | ||||
|  | ||||
| check: test | ||||
|  | ||||
| if CROSSCOMPILING | ||||
| test-full: test | ||||
| test-torture: test | ||||
|  | ||||
| test: | ||||
| 	@echo "NOTICE: we can't run the tests when cross-compiling!" | ||||
|  | ||||
| else | ||||
|  | ||||
| test: | ||||
| 	@(cd tests; $(MAKE) all quiet-test) | ||||
|  | ||||
| @@ -57,6 +66,8 @@ test-full: | ||||
| test-torture: | ||||
| 	@(cd tests; $(MAKE) all torture-test) | ||||
|  | ||||
| endif | ||||
|  | ||||
| # | ||||
| # Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros | ||||
| # must contain the following line: | ||||
|   | ||||
							
								
								
									
										105
									
								
								Makefile.dist
									
									
									
									
									
								
							
							
						
						
									
										105
									
								
								Makefile.dist
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2005, 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 | ||||
| @@ -53,6 +53,18 @@ borland-clean: | ||||
| 	cd ..\src | ||||
| 	make -f Makefile.b32 clean | ||||
|  | ||||
| watcom: | ||||
| 	cd lib | ||||
| 	wmake -f Makefile.Watcom | ||||
| 	cd ..\src | ||||
| 	wmake -f Makefile.Watcom | ||||
|  | ||||
| watcom-clean: | ||||
| 	cd lib | ||||
| 	wmake -f Makefile.Watcom clean | ||||
| 	cd ..\src | ||||
| 	wmake -f Makefile.Watcom clean | ||||
|  | ||||
| mingw32: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.m32 ZLIB=1 | ||||
| @@ -65,6 +77,37 @@ mingw32-clean: | ||||
| 	$(MAKE) -C lib -f Makefile.m32 clean | ||||
| 	$(MAKE) -C src -f Makefile.m32 clean | ||||
|  | ||||
| vc-clean: | ||||
| 	cd lib | ||||
| 	nmake -f Makefile.vc6 clean | ||||
| 	cd ..\src | ||||
| 	nmake -f Makefile.vc6 clean | ||||
|  | ||||
| vc-all: | ||||
| 	cd lib | ||||
| 	nmake -f Makefile.vc6 cfg=release | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl | ||||
| 	nmake -f Makefile.vc6 cfg=release-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl | ||||
| 	nmake -f Makefile.vc6 cfg=debug-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl-zlib | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-ssl-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll-ssl-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll-zlib-dll | ||||
| 	nmake -f Makefile.vc6 cfg=debug-dll-ssl-dll-zlib-dll | ||||
|  | ||||
| vc: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release | ||||
| @@ -93,13 +136,49 @@ vc-ssl-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll | ||||
|  | ||||
| vc-libcurl-ssl-dll: | ||||
| vc-dll-ssl-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-libcurl-ssl-dll | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll | ||||
|  | ||||
| vc-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll | ||||
|  | ||||
| vc-dll-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-zlib-dll | ||||
|  | ||||
| vc-dll-ssl-dll-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-dll-ssl-dll-zlib-dll | ||||
|  | ||||
| vc-ssl-dll-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-ssl-dll-zlib-dll | ||||
|  | ||||
| vc-zlib-dll: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release-zlib-dll | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release-zlib-dll | ||||
|  | ||||
| vc-sspi: | ||||
| 	cd lib | ||||
| 	nmake /f Makefile.vc6 cfg=release WINDOWS_SSPI=1 | ||||
| 	cd ..\src | ||||
| 	nmake /f Makefile.vc6 cfg=release WINDOWS_SSPI=1 | ||||
|  | ||||
| djgpp: | ||||
| 	$(MAKE) -C lib -f Makefile.dj | ||||
| @@ -121,9 +200,21 @@ netware: | ||||
| 	$(MAKE) -C lib -f Makefile.netware | ||||
| 	$(MAKE) -C src -f Makefile.netware | ||||
|  | ||||
| netware-ares: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_ARES=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_ARES=1 | ||||
|  | ||||
| netware-ssl: | ||||
| 	$(MAKE) -C lib -f Makefile.netware SSL=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware SSL=1 | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_SSL=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_SSL=1 | ||||
|  | ||||
| netware-ssl-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_SSL=1 WITH_ZLIB=1 | ||||
|  | ||||
| netware-zlib: | ||||
| 	$(MAKE) -C lib -f Makefile.netware WITH_ZLIB=1 | ||||
| 	$(MAKE) -C src -f Makefile.netware WITH_ZLIB=1 | ||||
|  | ||||
| netware-clean: | ||||
| 	$(MAKE) -C lib -f Makefile.netware clean | ||||
|   | ||||
							
								
								
									
										38
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								README
									
									
									
									
									
								
							| @@ -26,39 +26,37 @@ CONTACT | ||||
|   If you have problems, questions, ideas or suggestions, please contact us | ||||
|   by posting to a suitable mailing list. See http://curl.haxx.se/mail/ | ||||
|  | ||||
|   Many major contributors to the project are listed in the THANKS document. | ||||
|   All contributors to the project are listed in the THANKS document. | ||||
|  | ||||
| WEB SITE | ||||
|  | ||||
|   Visit the curl web site or mirrors for the latest news: | ||||
|   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        -- http://curl.signal42.com/ | ||||
|  | ||||
| DOWNLOAD | ||||
|  | ||||
|   The official download mirror sites are: | ||||
|  | ||||
|         Australia -- http://curl.planetmirror.com/download.html | ||||
|         Estonia   -- http://curl.wildyou.net/download.html | ||||
|         Germany   -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/ | ||||
|         Germany   -- http://curl.mirror.at.stealer.net/download.html | ||||
|         Germany   -- http://curl.netmirror.org/download.html | ||||
|         Germany   -- http://www.mirrorspace.org/curl/ | ||||
|         Hongkong  -- http://www.execve.net/curl/ | ||||
|         Russia    -- http://curl.tsuren.net/download.html | ||||
|         Sweden    -- ftp://ftp.sunet.se/pub/www/utilities/curl/ | ||||
|         Sweden    -- http://cool.haxx.se/curl/ | ||||
|         Thailand  -- http://curl.siamu.ac.th/download.html | ||||
|         US (CA)   -- http://curl.mirror.redwire.net/download.html | ||||
|         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/ | ||||
|  | ||||
| CVS | ||||
|  | ||||
|   | ||||
| @@ -1,81 +1,46 @@ | ||||
| Curl and libcurl 7.12.3 | ||||
| Curl and libcurl 7.15.0 | ||||
|  | ||||
|  Public curl release number:               84 | ||||
|  Releases counted from the very beginning: 111 | ||||
|  Available command line options:           100 | ||||
|  Available curl_easy_setopt() options:     123 | ||||
|  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:        14 | ||||
|  Number of known libcurl bindings:         29 | ||||
|  Amount of public web site mirrors:        24 | ||||
|  Number of known libcurl bindings:         32 | ||||
|  Number of contributors:                   451 | ||||
|  | ||||
| This release includes the following changes: | ||||
|  | ||||
|  o PKCS12 certificate support added | ||||
|  o added CURLINFO_SSL_ENGINES (and "--engine list") | ||||
|  o new configure options: --disable-cookies, --disable-crypto-auth and | ||||
|    --disable-verbose | ||||
|  o persistent ftp request improvements | ||||
|  o CURLOPT_IOCTLFUNCTION and CURLOPT_IOCTLDATA added. If your app uses HTTP | ||||
|    Digest, NTLM or Negotiate authentication, you will most likely want to use | ||||
|    these | ||||
|  o -w time_redirect and num_redirects | ||||
|  o no longer uses libcurl.def for building on Windows, OS/2 and Netware | ||||
|  o builds on Windows CE | ||||
|  o request retrying, --retry and family added | ||||
|  o FTP 3rd party transfers with source and dest on the same host now works | ||||
|  o added CURLINFO_NUM_CONNECTS | ||||
|  o --ftp-skip-pasv-ip / CURLOPT_FTP_SKIP_PASV_IP (sponsored by CU*Answers) | ||||
|  o TFTP support added | ||||
|  | ||||
| This release includes the following bugfixes: | ||||
|  | ||||
|  o curl -E on windows accepts "c:/path" with forward-slash | ||||
|  o several improvements for large file support on windows | ||||
|  o file handle leak in aborted multipart formpost file upload | ||||
|  o -T upload multiple files with backslashes in file names | ||||
|  o modified credentials between two requests on a persistent http connection | ||||
|  o large file file:// resumes on Windows | ||||
|  o URLs with username and IPv6 numerical addresses | ||||
|  o configure works better with SSL libs in a "non-standard ld.so dir" | ||||
|  o curl-config --vernum zero prefixed | ||||
|  o bad memory access in the NTLM code | ||||
|  o EPSV on multi-homed servers now works correctly | ||||
|  o chunked-encoded transfers could get closed pre-maturely without error | ||||
|  o proxy CONNECT now default timeouts after 3600 seconds | ||||
|  o disabling EPSV or EPRT is ignored when connecting to an IPv6 FTP server | ||||
|  o no extra progress meter newline output after each Location: followed | ||||
|  o HTTP PUT/POST with Digest, NTLM or Negotiate no longer uses HEAD | ||||
|  o works with or gracefully bails out when exceeding FD_SETSIZE file | ||||
|    descriptors | ||||
|  o CURLINFO_REDIRECT_TIME works | ||||
|  o building with gssapi libs and hdeaders in the default dirs | ||||
|  o curl_getdate() parsing of dates later than year 2037 with 32 bit time_t | ||||
|  o curl -v when stderr is closed wrote debug messages to the network socket | ||||
|  o build failure with libidn 0.3.X or older | ||||
|  o huge POSTs on VMS | ||||
|  o configure no longer uses pkg-config on cross-compiles | ||||
|  o potential gzip decompress memory leak | ||||
|  o "-C - --fail" on a HTTP page already downloaded | ||||
|  o formposting a zero byte file | ||||
|  o use setlocale() for better IDN functionality by default | ||||
|  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 | ||||
|  | ||||
| Other curl-related news since the previous public release: | ||||
|  | ||||
|  o pycurl 7.12.2: http://pycurl.sf.net/ | ||||
|  o TclCurl 0.12.2: http://personal1.iddeo.es/andresgarci/tclcurl/english/ | ||||
|  o libcurl.NET 1.2: http://www.seasideresearch.com/downloads.html | ||||
|  o RCurl 0.5.1: http://www.omegahat.org/RCurl/ | ||||
|  o libcurl.mono 1.0: | ||||
|    http://forge.novell.com/modules/xfmod/project/?libcurl-mono | ||||
|  o new German curl mirror: http://curl.kgt.org/ | ||||
|  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/ | ||||
|  | ||||
| This release would not have looked like this without help, code, reports and | ||||
| advice from friends like these: | ||||
|  | ||||
|  Peter Wullinger, Guillaume Arluison, Alexander Krasnostavsky, Mohun Biswas, | ||||
|  Tomas Pospisek, Gisle Vanem, Dan Fandrich, Paul Nolan, Andres Garcia, Tim | ||||
|  Sneddon, Ian Gulliver, Jean-Philippe Barrette-LaPierre, Jeff Phillips, | ||||
|  Wojciech Zwiefka, David Phillips, Reinout van Schouwen, Maurice Barnum, | ||||
|  Richard Atterer, Rene Bernhardt, Matt Veenstra, Bryan Henderson, Ton Voon, | ||||
|  Kai Sommerfeld, David Byron, Harshal Pradhan, Tom Lee, Dinar, Jean-Marc | ||||
|  Ranger, Samuel Listopad | ||||
|  o John Kelly, Nicolas Fran<61>ois, Scott Davis, Ben Madsen, Dmitry Bartsevich, | ||||
|    David Yan, Michael Wallner, Domenico Andreoli, Darryl House | ||||
|  | ||||
|         Thanks! (and sorry if I forgot to mention someone) | ||||
|   | ||||
							
								
								
									
										11
									
								
								TODO-RELEASE
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								TODO-RELEASE
									
									
									
									
									
								
							| @@ -1,8 +1,7 @@ | ||||
| Issues not sorted in any particular order. | ||||
|  | ||||
| To get fixed in 7.12.3 (planned release: December 2004) | ||||
| To get fixed in 7.15.0 (planned release: November 2005) | ||||
| ====================== | ||||
|  | ||||
| 47 - Peter Sylvester's patch for SRP on the TLS layer | ||||
|      Awaits OpenSSL support for this, no need to support this in libcurl before | ||||
|      there's an OpenSSL release that does it. | ||||
| 60 - CONNECT 407 responses that kills the connection (not very likely though) | ||||
|  | ||||
| 63 -  | ||||
|  | ||||
|   | ||||
							
								
								
									
										181
									
								
								acinclude.m4
									
									
									
									
									
								
							
							
						
						
									
										181
									
								
								acinclude.m4
									
									
									
									
									
								
							| @@ -87,9 +87,7 @@ AC_DEFINE(HAVE_IOCTLSOCKET_CASE, 1, [use Ioctlsocket() for non-blocking sockets] | ||||
| dnl Ioctlsocket didnt compile, do test 5! | ||||
|   AC_TRY_COMPILE([ | ||||
| /* headers for SO_NONBLOCK test (BeOS) */ | ||||
| #include <sys/types.h> | ||||
| #include <unistd.h> | ||||
| #include <fcntl.h> | ||||
| #include <socket.h> | ||||
| ],[ | ||||
| /* SO_NONBLOCK source code */ | ||||
|  long b = 1; | ||||
| @@ -124,6 +122,30 @@ dnl end of non-blocking try-compile test | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
| dnl Check for struct sockaddr_storage. Most IPv6-enabled hosts have it, but | ||||
| dnl AIX 4.3 is one known exception. | ||||
| AC_DEFUN([TYPE_SOCKADDR_STORAGE], | ||||
| [ | ||||
|    AC_CHECK_TYPE([struct sockaddr_storage], | ||||
|         AC_DEFINE(HAVE_STRUCT_SOCKADDR_STORAGE, 1, | ||||
|                   [if struct sockaddr_storage is defined]), , | ||||
|    [ | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
|    ]) | ||||
|  | ||||
| ]) | ||||
|  | ||||
| dnl Check for socklen_t: historically on BSD it is an int, and in | ||||
| dnl POSIX 1g it is a type of its own, but some platforms use different | ||||
| dnl types for the argument to getsockopt, getpeername, etc.  So we | ||||
| @@ -170,8 +192,7 @@ AC_DEFUN([TYPE_SOCKLEN_T], | ||||
| ]) | ||||
|  | ||||
| dnl Check for in_addr_t: it is used to receive the return code of inet_addr() | ||||
| dnl and a few other things. If not found, we set it to unsigned int, as even | ||||
| dnl 64-bit implementations use to set it to a 32-bit type. | ||||
| dnl and a few other things. | ||||
| AC_DEFUN([TYPE_IN_ADDR_T], | ||||
| [ | ||||
|    AC_CHECK_TYPE([in_addr_t], ,[ | ||||
| @@ -236,7 +257,7 @@ exit (h == NULL ? 1 : 0); }],[ | ||||
| ]) | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl check for working getaddrinfo() | ||||
| dnl check for working getaddrinfo() that works with AI_NUMERICHOST | ||||
| dnl | ||||
| AC_DEFUN([CURL_CHECK_WORKING_GETADDRINFO],[ | ||||
|   AC_CACHE_CHECK(for working getaddrinfo, ac_cv_working_getaddrinfo,[ | ||||
| @@ -251,6 +272,7 @@ int main(void) | ||||
|     int error; | ||||
|  | ||||
|     memset(&hints, 0, sizeof(hints)); | ||||
|     hints.ai_flags = AI_NUMERICHOST; | ||||
|     hints.ai_family = AF_UNSPEC; | ||||
|     hints.ai_socktype = SOCK_STREAM; | ||||
|     error = getaddrinfo("127.0.0.1", "8080", &hints, &ai); | ||||
| @@ -324,8 +346,24 @@ dnl program worked: | ||||
| [ ac_cv_working_ni_withscopeid="yes" ], | ||||
| dnl program failed: | ||||
| [ ac_cv_working_ni_withscopeid="no" ], | ||||
| dnl we cross-compile: | ||||
| [ ac_cv_working_ni_withscopeid="yes" ] | ||||
| dnl we cross-compile, check the headers using the preprocessor | ||||
| [ | ||||
|  | ||||
|  AC_EGREP_CPP(WORKS, | ||||
| [ | ||||
| #include <stdio.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/socket.h> | ||||
| #include <netdb.h> | ||||
|  | ||||
| #ifdef NI_WITHSCOPEID | ||||
| WORKS | ||||
| #endif | ||||
| ], | ||||
|   ac_cv_working_ni_withscopeid="yes", | ||||
|   ac_cv_working_ni_withscopeid="no" ) | ||||
|  | ||||
|  ] | ||||
| ) dnl end of AC_RUN_IFELSE | ||||
|  | ||||
| ]) dnl end of AC_CACHE_CHECK | ||||
| @@ -378,34 +416,25 @@ dnl      int strerror_r(int errnum, char *buf, size_t n); | ||||
| dnl | ||||
| AC_DEFUN([CURL_CHECK_STRERROR_R], | ||||
| [ | ||||
|   dnl determine of strerror_r is present | ||||
|   AC_CHECK_FUNCS(strerror_r,[ | ||||
|   AC_CHECK_FUNCS(strerror_r) | ||||
|  | ||||
|   if test "x$ac_cv_func_strerror_r" = "xyes"; then | ||||
|  | ||||
|     AC_MSG_CHECKING(whether strerror_r is declared) | ||||
|     AC_EGREP_CPP(strerror_r,[ | ||||
| #include <string.h>],[ | ||||
|       strerror_r="yes" | ||||
|       AC_MSG_RESULT(yes)],[ | ||||
|       AC_MSG_RESULT(no) | ||||
|       AC_MSG_CHECKING(whether strerror_r with -D_THREAD_SAFE is declared) | ||||
|       AC_MSG_CHECKING(whether strerror_r with -D_REENTRANT is declared) | ||||
|       AC_EGREP_CPP(strerror_r,[ | ||||
| #define _THREAD_SAFE | ||||
| #define _REENTRANT | ||||
| #include <string.h>],[ | ||||
|         strerror_r="yes" | ||||
| 	CPPFLAGS="-D_THREAD_SAFE $CPPFLAGS" | ||||
| 	CPPFLAGS="-D_REENTRANT $CPPFLAGS" | ||||
| 	AC_MSG_RESULT(yes)], | ||||
| 	AC_MSG_RESULT(no))])]) | ||||
|  | ||||
|   if test "x$strerror_r" = "xyes"; then | ||||
|  | ||||
|     dnl check if strerror_r is properly declared in the headers | ||||
|     AC_CHECK_DECL(strerror_r, , | ||||
| 	AC_MSG_RESULT(no) | ||||
|         AC_DEFINE(HAVE_NO_STRERROR_R_DECL, 1, [we have no strerror_r() proto]) | ||||
| , | ||||
| [#include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <errno.h> | ||||
| ]) | ||||
|        ) dnl with _THREAD_SAFE | ||||
|     ]) dnl plain cpp for it | ||||
|  | ||||
|     dnl determine if this strerror_r() is glibc or POSIX | ||||
|     AC_MSG_CHECKING([for a glibc strerror_r API]) | ||||
| @@ -427,8 +456,20 @@ main () { | ||||
|     AC_DEFINE(HAVE_GLIBC_STRERROR_R, 1, [we have a glibc-style strerror_r()]) | ||||
|     AC_MSG_RESULT([yes]), | ||||
|     AC_MSG_RESULT([no]), | ||||
|     dnl cross-compiling! | ||||
|  | ||||
|     dnl Use an inferior method of strerror_r detection while cross-compiling | ||||
|     AC_EGREP_CPP(yes, [ | ||||
| #include <features.h> | ||||
| #ifdef __GLIBC__ | ||||
| yes | ||||
| #endif | ||||
| ],  | ||||
|       dnl looks like glibc, so assume a glibc-style strerror_r() | ||||
|       GLIBC_STRERROR_R="1" | ||||
|       AC_DEFINE(HAVE_GLIBC_STRERROR_R, 1, [we have a glibc-style strerror_r()]) | ||||
|       AC_MSG_RESULT([yes]), | ||||
|       AC_MSG_NOTICE([cannot determine strerror_r() style: edit lib/config.h manually!]) | ||||
|     ) dnl while cross-compiling | ||||
|     ) | ||||
|  | ||||
|     if test -z "$GLIBC_STRERROR_R"; then | ||||
| @@ -695,15 +736,15 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|          dnl -Wcast-align is a bit too annoying on all gcc versions ;-) | ||||
|  | ||||
|          if test "$gccnum" -ge "207"; then | ||||
|            dnl gcc 2.7 or later (well, they don't work on 2.2.2) | ||||
|            WARN="$WARN -Wno-long-long -Wmissing-declarations -Wsign-compare" | ||||
|            dnl gcc 2.7 or later | ||||
|            WARN="$WARN -Wmissing-declarations" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -gt "295"; then | ||||
|            dnl only if the compiler is newer than 2.95 since we got lots of | ||||
|            dnl "`_POSIX_C_SOURCE' is not defined" in system headers with | ||||
|            dnl gcc 2.95.4 on FreeBSD 4.9! | ||||
|            WARN="$WARN -Wundef" | ||||
|            WARN="$WARN -Wundef -Wno-long-long -Wsign-compare" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -ge "296"; then | ||||
| @@ -717,15 +758,18 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|          fi | ||||
|  | ||||
|          dnl -Wunreachable-code seems totally unreliable on my gcc 3.3.2 on | ||||
|          dnl on i686-Linux as it gives us heaps with false positives | ||||
|          dnl on i686-Linux as it gives us heaps with false positives. | ||||
|          dnl Also, on gcc 4.0.X it is totally unbearable and complains all | ||||
|          dnl over making it unusable for generic purposes. Let's not use it. | ||||
|  | ||||
|          if test "$gccnum" -ge "303"; then | ||||
|            dnl gcc 3.3 and later | ||||
|            WARN="$WARN -Wendif-labels -Wstrict-prototypes" | ||||
|          fi | ||||
|  | ||||
|          if test "$gccnum" -ge "304"; then | ||||
|            # try -Wunreachable-code on gcc 3.4 | ||||
|            WARN="$WARN -Wunreachable-code" | ||||
|            # try these on gcc 3.4 | ||||
|            WARN="$WARN -Wdeclaration-after-statement" | ||||
|          fi | ||||
|  | ||||
|          for flag in $CPPFLAGS; do | ||||
| @@ -768,3 +812,72 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|  | ||||
| ]) dnl end of AC_DEFUN() | ||||
|  | ||||
|  | ||||
| dnl Determine the name of the library to pass to dlopen() based on the name | ||||
| dnl that would normally be given to AC_CHECK_LIB.  The preprocessor symbol | ||||
| dnl given is set to the quoted library file name.  | ||||
| dnl The standard dynamic library file name is first generated, based on the | ||||
| dnl current system type, then a search is performed for that file on the | ||||
| dnl standard dynamic library path.  If it is a symbolic link, the destination | ||||
| dnl of the link is used as the file name, after stripping off any minor | ||||
| dnl version numbers. If a library file can't be found, a guess is made. | ||||
| dnl This macro assumes AC_PROG_LIBTOOL has been called and requires perl | ||||
| dnl to be available in the PATH, or $PERL to be set to its location. | ||||
| dnl | ||||
| dnl CURL_DLLIB_NAME(VARIABLE, library_name) | ||||
| dnl e.g. CURL_DLLIB_NAME(LDAP_NAME, ldap) on a Linux system might result | ||||
| dnl in LDAP_NAME holding the string "libldap.so.2". | ||||
|  | ||||
| AC_DEFUN([CURL_DLLIB_NAME], | ||||
| [ | ||||
| AC_MSG_CHECKING([name of dynamic library $2]) | ||||
| dnl The shared library extension variable name changes from version to | ||||
| dnl version of libtool.  Try a few names then just set one statically. | ||||
| test -z "$shared_ext" && shared_ext="$shrext_cmds" | ||||
| test -z "$shared_ext" && shared_ext="$shrext" | ||||
| test -z "$shared_ext" && shared_ext=".so" | ||||
|  | ||||
| dnl Create the library link name of the correct form for this platform | ||||
| LIBNAME_LINK_SPEC=`echo "$library_names_spec" | $SED 's/^.* //'` | ||||
| DLGUESSLIB=`name=$2 eval echo "$libname_spec"` | ||||
| DLGUESSFILE=`libname="$DLGUESSLIB" release="" major="" versuffix="" eval echo "$LIBNAME_LINK_SPEC"` | ||||
|  | ||||
| dnl Synthesize a likely dynamic library name in case we can't find an actual one | ||||
| SO_NAME_SPEC="$soname_spec" | ||||
| dnl soname_spec undefined when identical to the 1st entry in library_names_spec | ||||
| test -z "$SO_NAME_SPEC" && SO_NAME_SPEC=`echo "$library_names_spec" | $SED 's/ .*$//'` | ||||
| DLGUESSSOFILE=`libname="$DLGUESSLIB" release="" major="" versuffix="" eval echo "$SO_NAME_SPEC"` | ||||
|  | ||||
| if test "$cross_compiling" = yes; then | ||||
|   dnl Can't look at filesystem when cross-compiling | ||||
|   AC_DEFINE_UNQUOTED($1, "$DLGUESSSOFILE", [$2 dynamic library file]) | ||||
|   AC_MSG_RESULT([$DLGUESSSOFILE (guess while cross-compiling)]) | ||||
| else | ||||
|  | ||||
|   DLFOUNDFILE="" | ||||
|   if test "$sys_lib_dlsearch_path_spec" ; then | ||||
|     dnl Search for the link library name and see what it points to. | ||||
|     for direc in $sys_lib_dlsearch_path_spec ; do | ||||
|       DLTRYFILE="$direc/$DLGUESSFILE" | ||||
|       dnl Find where the symbolic link for this name points | ||||
|       changequote(<<, >>)dnl | ||||
|       << | ||||
|       DLFOUNDFILE=`${PERL:-perl} -e 'use File::Basename; (basename(readlink($ARGV[0])) =~ /^(.*[^\d]\.\d+)[\d\.]*$/ && print ${1}) || exit 1;' "$DLTRYFILE" 2>&5` | ||||
|       >> | ||||
|       changequote([, ])dnl | ||||
|       if test "$?" -eq "0"; then | ||||
|         dnl Found the file link | ||||
|         break | ||||
|       fi | ||||
|     done | ||||
|   fi | ||||
|  | ||||
|   if test -z "$DLFOUNDFILE" ; then | ||||
|     dnl Couldn't find a link library, so guess at a name. | ||||
|     DLFOUNDFILE="$DLGUESSSOFILE" | ||||
|   fi | ||||
|  | ||||
|   AC_DEFINE_UNQUOTED($1, "$DLFOUNDFILE", [$2 dynamic library file]) | ||||
|   AC_MSG_RESULT($DLFOUNDFILE) | ||||
| fi | ||||
| ]) | ||||
|   | ||||
							
								
								
									
										13
									
								
								ares/AUTHORS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								ares/AUTHORS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| c-ares is based on ares, and these are the people that have worked on it since | ||||
| the fork was made: | ||||
|  | ||||
| Daniel Stenberg | ||||
| Dominick Meglio | ||||
| liren at vivisimo.com | ||||
| James Bursa | ||||
| Duncan Wilcox | ||||
| Dirk Manske | ||||
| Dan Fandrich | ||||
| Gisle Vanem | ||||
| Gunter Knauf | ||||
| Henrik Stoerner | ||||
							
								
								
									
										84
									
								
								ares/CHANGES
									
									
									
									
									
								
							
							
						
						
									
										84
									
								
								ares/CHANGES
									
									
									
									
									
								
							| @@ -1,5 +1,89 @@ | ||||
|   Changelog for the c-ares project | ||||
|  | ||||
| * 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. | ||||
|  | ||||
| * 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) | ||||
|  | ||||
| * August 21 | ||||
|  | ||||
| - Alfredo Tupone provided a fix for the Windows code in get_iphlpapi_dns_info() | ||||
|   when getting the DNS server etc. | ||||
|  | ||||
| * June 19 | ||||
|  | ||||
| - Added some checks for the addrinfo structure. | ||||
|  | ||||
| * June 2 | ||||
|  | ||||
| - William Ahern: | ||||
|  | ||||
|   Make UDP sockets non-blocking. I've confirmed that at least on Linux 2.4 a | ||||
|   read event can come back from poll() on a valid SOCK_DGRAM socket but | ||||
|   recv(2) will still block. This patch doesn't ignore EAGAIN in | ||||
|   read_udp_packets(), though maybe it should. (This patch was edited by Daniel | ||||
|   Stenberg and a new configure test was added (imported from curl's configure) | ||||
|   to properly detect what non-blocking socket approach to use.) | ||||
|  | ||||
|   I'm not quite sure how this was happening, but I've been seeing PTR queries | ||||
|   which seem to return empty responses. At least, they were empty when calling | ||||
|   ares_expand_name() on the record. Here's a patch which guarantees to | ||||
|   NUL-terminate the expanded name. The old behavior failed to NUL-terminate if | ||||
|   len was 0, and this was causing strlen() to run past the end of the buffer | ||||
|   after calling ares_expand_name() and getting ARES_SUCCESS as the return | ||||
|   value. If q is not greater than *s then it's equal and *s is always | ||||
|   allocated with at least one byte. | ||||
|  | ||||
| * May 16 | ||||
|  | ||||
| - Added ares_getnameinfo which mimics the getnameinfo API (another feature | ||||
|   that could use testing). | ||||
|  | ||||
| * May 14 | ||||
|  | ||||
| - Added an inet_ntop function from BIND for systems that do not have it. | ||||
|  | ||||
| * April 9 | ||||
|  | ||||
| - Made sortlist support IPv6 (this can probably use some testing). | ||||
|  | ||||
| - Made sortlist support CIDR matching for IPv4. | ||||
|  | ||||
| * April 8 | ||||
|  | ||||
| - Added preliminary IPv6 support to ares_gethostbyname. Currently, sortlist | ||||
|   does not work with IPv6. Also provided an implementation of bitncmp from | ||||
|   BIND for systems that do not supply this function. This will be used to add | ||||
|   IPv6 support to sortlist. | ||||
|  | ||||
| - Made ares_gethostbyaddr support IPv6 by specifying AF_INET6 as the family. | ||||
|   The function can lookup IPv6 addresses both from files (/etc/hosts) and | ||||
|   DNS lookups. | ||||
|  | ||||
| * April 7 | ||||
|  | ||||
| - Tupone Alfredo fixed includes of arpa/nameser_compat.h to build fine on Mac | ||||
|   OS X. | ||||
|  | ||||
| * April 5 | ||||
|  | ||||
| - Dominick Meglio: Provided implementations of inet_net_pton and inet_pton | ||||
|   from BIND for systems that do not include these functions. | ||||
|  | ||||
| * March 11, 2005 | ||||
|  | ||||
| - Dominick Meglio added ares_parse_aaaa_reply.c and did various | ||||
|   adjustments. The first little steps towards IPv6 support! | ||||
|  | ||||
| * November 7 | ||||
|  | ||||
| - Fixed the VC project and makefile to use ares_cancel and ares_version | ||||
|   | ||||
| @@ -12,10 +12,10 @@ MSVCFILES = vc/adig/adig.dep vc/adig/adig.dsp vc/adig/adig.mak	\ | ||||
| # 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) | ||||
|  $(MSVCFILES) AUTHORS | ||||
|  | ||||
|  | ||||
| VER=-version-info 0:0:0 | ||||
| VER=-version-info 1:0:0 | ||||
| # This flag accepts an argument of the form current[:revision[:age]]. So, | ||||
| # passing -version-info 3:12:1 sets current to 3, revision to 12, and age to | ||||
| # 1. | ||||
|   | ||||
| @@ -3,13 +3,16 @@ 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 | ||||
| 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 | ||||
| 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 | ||||
|  | ||||
| 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_version.3 ares_cancel.3 ares_parse_aaaa_reply.3 ares_getnameinfo.3 | ||||
|   | ||||
| @@ -20,7 +20,7 @@ endif | ||||
| TARGETS = adig.nlm ahost.nlm | ||||
| LTARGET = libcares.lib | ||||
| VERSION	= $(LIBCARES_VERSION) | ||||
| COPYR	= Copyright (c) 1996 - 2004, Daniel Stenberg, <daniel@haxx.se> | ||||
| COPYR	= Copyright (C) 1996 - 2005, Daniel Stenberg, <daniel@haxx.se> | ||||
| DESCR	= cURL $(subst .def,,$(notdir $@)) $(LIBCARES_VERSION_STR) - http://curl.haxx.se | ||||
| MTSAFE	= YES | ||||
| STACK	= 64000 | ||||
| @@ -89,7 +89,7 @@ LDFLAGS	= -T | ||||
| AR	= ar | ||||
| ARFLAGS	= -cq | ||||
| CFLAGS	+= -fno-builtin -fpack-struct -fpcc-struct-return -fno-strict-aliasing | ||||
| CFLAGS	+= -Wall -Wno-format # -pedantic | ||||
| CFLAGS	+= -Wall -Wno-format -Wno-uninitialized # -pedantic | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| 	PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o | ||||
| else | ||||
| @@ -104,7 +104,7 @@ SDK_LIBC = $(NDK_ROOT)/libc | ||||
|  | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| 	INCLUDES += -I$(SDK_LIBC)/include -I$(SDK_LIBC)/include/nks | ||||
| 	INCLUDES += -I$(SDK_LIBC)/include/winsock | ||||
| 	# INCLUDES += -I$(SDK_LIBC)/include/winsock | ||||
| 	CFLAGS += -D_POSIX_SOURCE | ||||
| #	CFLAGS += -D__ANSIC__ | ||||
| else | ||||
| @@ -126,7 +126,10 @@ DL	= ' | ||||
| #-include $(NDKBASE)/nlmconv/ncpfs.inc | ||||
| endif | ||||
|  | ||||
| OBJS	:= $(patsubst %.c,$(OBJDIR)/%.o,$(wildcard ares_*.c)) | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|  | ||||
| OBJS	:= $(patsubst %.c,$(OBJDIR)/%.o,$(strip $(CSOURCES))) | ||||
|  | ||||
| .PHONY: lib nlm prebuild dist install clean | ||||
|  | ||||
| @@ -256,6 +259,7 @@ config.h: Makefile.netware | ||||
| 	@echo $(DL)#define VERSION "$(LIBCURL_VERSION_STR)"$(DL) >> $@ | ||||
| 	@echo $(DL)#define PACKAGE_BUGREPORT "curl-bug@haxx.se"$(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) >> $@ | ||||
| 	@echo $(DL)#define HAVE_DLFCN_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_DLOPEN 1$(DL) >> $@ | ||||
| @@ -297,6 +301,13 @@ config.h: Makefile.netware | ||||
| 	@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_IN6_ADDR 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | ||||
| ifdef NW_WINSOCK | ||||
| 	@echo $(DL)#define HAVE_CLOSESOCKET 1$(DL) >> $@ | ||||
| else | ||||
|   | ||||
| @@ -1,3 +1,126 @@ | ||||
| dnl Check for how to set a socket to non-blocking state. There seems to exist | ||||
| dnl four known different ways, with the one used almost everywhere being POSIX | ||||
| dnl and XPG3, while the other different ways for different systems (old BSD, | ||||
| dnl Windows and Amiga). | ||||
| dnl | ||||
| dnl There are two known platforms (AIX 3.x and SunOS 4.1.x) where the | ||||
| dnl O_NONBLOCK define is found but does not work. This condition is attempted | ||||
| dnl to get caught in this script by using an excessive number of #ifdefs... | ||||
| dnl | ||||
| AC_DEFUN([CURL_CHECK_NONBLOCKING_SOCKET], | ||||
| [ | ||||
|   AC_MSG_CHECKING([non-blocking sockets style]) | ||||
|  | ||||
|   AC_TRY_COMPILE([ | ||||
| /* headers for O_NONBLOCK test */ | ||||
| #include <sys/types.h> | ||||
| #include <unistd.h> | ||||
| #include <fcntl.h> | ||||
| ],[ | ||||
| /* try to compile O_NONBLOCK */ | ||||
|  | ||||
| #if defined(sun) || defined(__sun__) || defined(__SUNPRO_C) || defined(__SUNPRO_CC) | ||||
| # if defined(__SVR4) || defined(__srv4__) | ||||
| #  define PLATFORM_SOLARIS | ||||
| # else | ||||
| #  define PLATFORM_SUNOS4 | ||||
| # endif | ||||
| #endif | ||||
| #if (defined(_AIX) || defined(__xlC__)) && !defined(_AIX4) | ||||
| # define PLATFORM_AIX_V3 | ||||
| #endif | ||||
|  | ||||
| #if defined(PLATFORM_SUNOS4) || defined(PLATFORM_AIX_V3) || defined(__BEOS__) | ||||
| #error "O_NONBLOCK does not work on this platform" | ||||
| #endif | ||||
|   int socket; | ||||
|   int flags = fcntl(socket, F_SETFL, flags | O_NONBLOCK); | ||||
| ],[ | ||||
| dnl the O_NONBLOCK test was fine | ||||
| nonblock="O_NONBLOCK" | ||||
| AC_DEFINE(HAVE_O_NONBLOCK, 1, [use O_NONBLOCK for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl the code was bad, try a different program now, test 2 | ||||
|  | ||||
|   AC_TRY_COMPILE([ | ||||
| /* headers for FIONBIO test */ | ||||
| #include <unistd.h> | ||||
| #include <stropts.h> | ||||
| ],[ | ||||
| /* FIONBIO source test (old-style unix) */ | ||||
|  int socket; | ||||
|  int flags = ioctl(socket, FIONBIO, &flags); | ||||
| ],[ | ||||
| dnl FIONBIO test was good | ||||
| nonblock="FIONBIO" | ||||
| AC_DEFINE(HAVE_FIONBIO, 1, [use FIONBIO for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl FIONBIO test was also bad | ||||
| dnl the code was bad, try a different program now, test 3 | ||||
|  | ||||
|   AC_TRY_COMPILE([ | ||||
| /* headers for ioctlsocket test (cygwin?) */ | ||||
| #include <windows.h> | ||||
| ],[ | ||||
| /* ioctlsocket source code */ | ||||
|  int socket; | ||||
|  unsigned long flags = ioctlsocket(socket, FIONBIO, &flags); | ||||
| ],[ | ||||
| dnl ioctlsocket test was good | ||||
| nonblock="ioctlsocket" | ||||
| AC_DEFINE(HAVE_IOCTLSOCKET, 1, [use ioctlsocket() for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl ioctlsocket didnt compile!, go to test 4 | ||||
|  | ||||
|   AC_TRY_LINK([ | ||||
| /* headers for IoctlSocket test (Amiga?) */ | ||||
| #include <sys/ioctl.h> | ||||
| ],[ | ||||
| /* IoctlSocket source code */ | ||||
|  int socket; | ||||
|  int flags = IoctlSocket(socket, FIONBIO, (long)1); | ||||
| ],[ | ||||
| dnl ioctlsocket test was good | ||||
| nonblock="IoctlSocket" | ||||
| AC_DEFINE(HAVE_IOCTLSOCKET_CASE, 1, [use Ioctlsocket() for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl Ioctlsocket didnt compile, do test 5! | ||||
|   AC_TRY_COMPILE([ | ||||
| /* headers for SO_NONBLOCK test (BeOS) */ | ||||
| #include <socket.h> | ||||
| ],[ | ||||
| /* SO_NONBLOCK source code */ | ||||
|  long b = 1; | ||||
|  int socket; | ||||
|  int flags = setsockopt(socket, SOL_SOCKET, SO_NONBLOCK, &b, sizeof(b)); | ||||
| ],[ | ||||
| dnl the SO_NONBLOCK test was good | ||||
| nonblock="SO_NONBLOCK" | ||||
| AC_DEFINE(HAVE_SO_NONBLOCK, 1, [use SO_NONBLOCK for non-blocking sockets]) | ||||
| ],[ | ||||
| dnl test 5 didnt compile! | ||||
| nonblock="nada" | ||||
| AC_DEFINE(HAVE_DISABLED_NONBLOCKING, 1, [disabled non-blocking sockets]) | ||||
| ]) | ||||
| dnl end of fifth test | ||||
|  | ||||
| ]) | ||||
| dnl end of forth test | ||||
|  | ||||
| ]) | ||||
| dnl end of third test | ||||
|  | ||||
| ]) | ||||
| dnl end of second test | ||||
|  | ||||
| ]) | ||||
| dnl end of non-blocking try-compile test | ||||
|   AC_MSG_RESULT($nonblock) | ||||
|  | ||||
|   if test "$nonblock" = "nada"; then | ||||
|     AC_MSG_WARN([non-block sockets disabled]) | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
| dnl We create a function for detecting which compiler we use and then set as | ||||
| dnl pendantic compiler options as possible for that particular compiler. The | ||||
| @@ -99,3 +222,97 @@ AC_DEFUN([CURL_CC_DEBUG_OPTS], | ||||
|  | ||||
| ]) dnl end of AC_DEFUN() | ||||
|  | ||||
|  | ||||
| dnl This macro determines if the specified struct exists in the specified file | ||||
| dnl Syntax: | ||||
| dnl CARES_CHECK_STRUCT(headers, struct name, if found, [if not found]) | ||||
|  | ||||
| AC_DEFUN([CARES_CHECK_STRUCT], [ | ||||
|   AC_MSG_CHECKING([for struct $2]) | ||||
|   AC_TRY_COMPILE([$1],  | ||||
|     [ | ||||
|       struct $2 struct_instance; | ||||
|     ], ac_struct="yes", ac_found="no") | ||||
|   if test "$ac_struct" = "yes" ; then | ||||
|     AC_MSG_RESULT(yes) | ||||
|     $3 | ||||
|   else | ||||
|     AC_MSG_RESULT(no) | ||||
|     $4 | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
| dnl This macro determines if the specified constant exists in the specified file | ||||
| dnl Syntax: | ||||
| dnl CARES_CHECK_CONSTANT(headers, constant name, if found, [if not found]) | ||||
|  | ||||
| AC_DEFUN([CARES_CHECK_CONSTANT], [ | ||||
|   AC_MSG_CHECKING([for $2]) | ||||
|   AC_EGREP_CPP(VARIABLEWASDEFINED, | ||||
|    [ | ||||
|       $1 | ||||
|  | ||||
|       #ifdef $2 | ||||
|         VARIABLEWASDEFINED | ||||
|       #else | ||||
|         NJET | ||||
|       #endif | ||||
|     ], ac_constant="yes", ac_constant="no" | ||||
|   ) | ||||
|   if test "$ac_constant" = "yes" ; then | ||||
|     AC_MSG_RESULT(yes) | ||||
|     $3 | ||||
|   else | ||||
|     AC_MSG_RESULT(no) | ||||
|     $4 | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
|  | ||||
| dnl This macro determines how many parameters getservbyport_r takes | ||||
| AC_DEFUN([CARES_CHECK_GETSERVBYPORT_R], [ | ||||
|   AC_MSG_CHECKING([how many arguments getservbyport_r takes]) | ||||
|   AC_TRY_COMPILE( | ||||
|     [#include <netdb.h>], | ||||
|     [ | ||||
|       int p1, p5; | ||||
|       char *p2, p4[4096]; | ||||
|       struct servent *p3, *p6; | ||||
|       getservbyport_r(p1, p2, p3, p4, p5, &p6); | ||||
|     ], ac_func_getservbyport_r=6, | ||||
|     [AC_TRY_COMPILE( | ||||
|       [#include <netdb.h>], | ||||
|       [ | ||||
|         int p1, p5; | ||||
|         char *p2, p4[4096]; | ||||
|         struct servent *p3; | ||||
|         getservbyport_r(p1, p2, p3, p4, p5); | ||||
|       ], ac_func_getservbyport_r=5, | ||||
|       [AC_TRY_COMPILE( | ||||
|         [#include <netdb.h>], | ||||
|         [ | ||||
|           int p1; | ||||
|           char *p2; | ||||
|           struct servent *p3; | ||||
|           struct servent_data p4; | ||||
|           getservbyport_r(p1, p2, p3, &p4); | ||||
|         ], ac_func_getservbyport_r=4, ac_func_getservbyport_r=0 | ||||
|       )] | ||||
|     )] | ||||
|   ) | ||||
| if test $ac_func_getservbyport_r != "0" ; then | ||||
|   AC_MSG_RESULT($ac_func_getservbyport_r) | ||||
|   AC_DEFINE(HAVE_GETSERVBYPORT_R, 1, [Specifies whether getservbyport_r is present]) | ||||
|   AC_DEFINE_UNQUOTED(GETSERVBYPORT_R_ARGS, $ac_func_getservbyport_r, [Specifies the number of arguments to  | ||||
| getservbyport_r]) | ||||
|   if test $ac_func_getservbyport_r = "4" ; then | ||||
|    AC_DEFINE(GETSERVBYPORT_R_BUFSIZE, sizeof(struct servent_data), [Specifies the size of the buffer to pass to  | ||||
| getservbyport_r]) | ||||
|   else | ||||
|    AC_DEFINE(GETSERVBYPORT_R_BUFSIZE, 4096, [Specifies the size of the buffer to pass to getservbyport_r]) | ||||
|   fi | ||||
| else | ||||
|   AC_MSG_RESULT([not found]) | ||||
| fi | ||||
| ]) | ||||
|  | ||||
|   | ||||
							
								
								
									
										55
									
								
								ares/ares.h
									
									
									
									
									
								
							
							
						
						
									
										55
									
								
								ares/ares.h
									
									
									
									
									
								
							| @@ -29,12 +29,14 @@ | ||||
|  | ||||
| #if defined(WATT32) | ||||
|   #include <netinet/in.h> | ||||
|   #include <sys/socket.h> | ||||
|   #include <tcp.h> | ||||
| #elif defined(WIN32) | ||||
|   #include <winsock.h> | ||||
|   #include <windows.h> | ||||
| #else | ||||
|   #include <netinet/in.h> | ||||
|   #include <sys/socket.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef  __cplusplus | ||||
| @@ -64,6 +66,13 @@ extern "C" { | ||||
| #define ARES_EDESTRUCTION       16 | ||||
| #define ARES_EBADSTR            17 | ||||
|  | ||||
| /* ares_getnameinfo error codes */ | ||||
| #define ARES_EBADFLAGS          18 | ||||
|  | ||||
| /* ares_getaddrinfo error codes */ | ||||
| #define ARES_ENONAME		19 | ||||
| #define ARES_EBADHINTS		20 | ||||
|  | ||||
| /* Flag values */ | ||||
| #define ARES_FLAG_USEVC         (1 << 0) | ||||
| #define ARES_FLAG_PRIMARY       (1 << 1) | ||||
| @@ -85,6 +94,42 @@ extern "C" { | ||||
| #define ARES_OPT_DOMAINS        (1 << 7) | ||||
| #define ARES_OPT_LOOKUPS        (1 << 8) | ||||
|  | ||||
| /* Nameinfo flag values */ | ||||
| #define ARES_NI_NOFQDN                  (1 << 0) | ||||
| #define ARES_NI_NUMERICHOST             (1 << 1) | ||||
| #define ARES_NI_NAMEREQD                (1 << 2) | ||||
| #define ARES_NI_NUMERICSERV             (1 << 3) | ||||
| #define ARES_NI_DGRAM                   (1 << 4) | ||||
| #define ARES_NI_TCP                     0 | ||||
| #define ARES_NI_UDP                     ARES_NI_DGRAM | ||||
| #define ARES_NI_SCTP                    (1 << 5) | ||||
| #define ARES_NI_DCCP                    (1 << 6) | ||||
| #define ARES_NI_NUMERICSCOPE            (1 << 7) | ||||
| #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_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) | ||||
| /* Reserved for future use */ | ||||
| #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_MASK			(ARES_AI_CANONNAME|ARES_AI_NUMERICHOST|ARES_AI_PASSIVE| \ | ||||
| 				 	 ARES_AI_NUMERICSERV|ARES_AI_V4MAPPED|ARES_AI_ALL| \ | ||||
| 					 ARES_AI_ADDRCONFIG) | ||||
|  | ||||
| struct ares_options { | ||||
|   int flags; | ||||
|   int timeout; | ||||
| @@ -101,12 +146,15 @@ struct ares_options { | ||||
|  | ||||
| struct hostent; | ||||
| struct timeval; | ||||
| struct sockaddr; | ||||
| struct ares_channeldata; | ||||
| typedef struct ares_channeldata *ares_channel; | ||||
| typedef void (*ares_callback)(void *arg, int status, unsigned char *abuf, | ||||
|                               int alen); | ||||
| typedef void (*ares_host_callback)(void *arg, int status, | ||||
|                                    struct hostent *hostent); | ||||
| typedef void (*ares_nameinfo_callback)(void *arg, int status, | ||||
|                                        char *node, char *service); | ||||
|  | ||||
| int ares_init(ares_channel *channelptr); | ||||
| int ares_init_options(ares_channel *channelptr, struct ares_options *options, | ||||
| @@ -123,7 +171,9 @@ void ares_gethostbyname(ares_channel channel, const char *name, int family, | ||||
|                         ares_host_callback callback, void *arg); | ||||
| 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, | ||||
|                       void *arg); | ||||
| int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds); | ||||
| struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv, | ||||
|                              struct timeval *tv); | ||||
| @@ -137,12 +187,13 @@ int ares_expand_string(const unsigned char *encoded, const unsigned char *abuf, | ||||
|                      int alen, unsigned char **s, long *enclen); | ||||
| int ares_parse_a_reply(const unsigned char *abuf, int alen, | ||||
|                        struct hostent **host); | ||||
| int ares_parse_aaaa_reply(const unsigned char *abuf, int alen, | ||||
|                        struct hostent **host); | ||||
| int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr, | ||||
|                          int addrlen, int family, struct hostent **host); | ||||
| void ares_free_string(void *str); | ||||
| void ares_free_hostent(struct hostent *host); | ||||
| const char *ares_strerror(int code); | ||||
| void ares_free_errmem(char *mem); | ||||
|  | ||||
| #ifdef  __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -30,12 +30,15 @@ | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
| #include "inet_net_pton.h" | ||||
|  | ||||
| int ares__get_hostent(FILE *fp, struct hostent **host) | ||||
| int ares__get_hostent(FILE *fp, int family, struct hostent **host) | ||||
| { | ||||
|   char *line = NULL, *p, *q, *canonical, **alias; | ||||
|   int status, linesize, end_at_hostname, naliases; | ||||
|   struct in_addr addr; | ||||
|   struct in6_addr addr6; | ||||
|   int addrlen = sizeof(struct in_addr); | ||||
|   struct hostent *hostent = NULL; | ||||
|  | ||||
|   while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS) | ||||
| @@ -56,6 +59,17 @@ int ares__get_hostent(FILE *fp, struct hostent **host) | ||||
|       *p = 0; | ||||
|       addr.s_addr = inet_addr(line); | ||||
|       if (addr.s_addr == INADDR_NONE) | ||||
|        { | ||||
|           if (ares_inet_pton(AF_INET6, line, &addr6) > 0) | ||||
|             { | ||||
|               if (family != AF_INET6) | ||||
|                 continue; | ||||
|               addrlen = sizeof(struct in6_addr); | ||||
|             } | ||||
|           else | ||||
|             continue; | ||||
|        } | ||||
|       else if (family != AF_INET) | ||||
|         continue; | ||||
|  | ||||
|       /* Get the canonical hostname. */ | ||||
| @@ -100,7 +114,7 @@ int ares__get_hostent(FILE *fp, struct hostent **host) | ||||
|       hostent->h_addr_list = malloc(2 * sizeof(char *)); | ||||
|       if (!hostent->h_addr_list) | ||||
|         break; | ||||
|       hostent->h_addr_list[0] = malloc(sizeof(struct in_addr)); | ||||
|       hostent->h_addr_list[0] = malloc(addrlen); | ||||
|       if (!hostent->h_addr_list[0]) | ||||
|         break; | ||||
|       hostent->h_aliases = malloc((naliases + 1) * sizeof(char *)); | ||||
| @@ -134,9 +148,12 @@ int ares__get_hostent(FILE *fp, struct hostent **host) | ||||
|         } | ||||
|       hostent->h_aliases[naliases] = NULL; | ||||
|  | ||||
|       hostent->h_addrtype = AF_INET; | ||||
|       hostent->h_length = sizeof(struct in_addr); | ||||
|       memcpy(hostent->h_addr_list[0], &addr, sizeof(struct in_addr)); | ||||
|       hostent->h_addrtype = family; | ||||
|       hostent->h_length = addrlen; | ||||
|       if (family == AF_INET) | ||||
|         memcpy(hostent->h_addr_list[0], &addr, addrlen); | ||||
|       else if (family == AF_INET6) | ||||
|         memcpy(hostent->h_addr_list[0], &addr6, addrlen); | ||||
|       hostent->h_addr_list[1] = NULL; | ||||
|       *host = hostent; | ||||
|       free(line); | ||||
|   | ||||
| @@ -21,6 +21,9 @@ | ||||
| #else | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
| @@ -103,6 +106,8 @@ int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf, | ||||
|   /* Nuke the trailing period if we wrote one. */ | ||||
|   if (q > *s) | ||||
|     *(q - 1) = 0; | ||||
|   else | ||||
|     *q = 0; /* zero terminate */ | ||||
|  | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|   | ||||
| @@ -28,8 +28,8 @@ The | ||||
| .I ares_free_hostent | ||||
| function frees a | ||||
| .B struct hostent | ||||
| allocated by one of the functions \fIares_parse_a_reply(3)\fP or | ||||
| \fIares_parse_ptr_reply(3)\fP. | ||||
| allocated by one of the functions \fIares_parse_a_reply(3)\fP, | ||||
| \fIares_parse_aaaa_reply(3)\fP, or \fIares_parse_ptr_reply(3)\fP. | ||||
| .SH NOTES | ||||
| It is not necessary (and is not correct) to free the host structure passed to | ||||
| the callback functions for \fIares_gethostbyname(3)\fP or | ||||
| @@ -37,6 +37,7 @@ the callback functions for \fIares_gethostbyname(3)\fP or | ||||
| host structures when the callback returns. | ||||
| .SH SEE ALSO | ||||
| .BR ares_parse_a_reply (3), | ||||
| .BR ares_parse_aaaa_reply (3), | ||||
| .BR ares_parse_ptr_reply (3) | ||||
| .SH AUTHOR | ||||
| Greg Hudson, MIT Information Systems | ||||
|   | ||||
| @@ -12,7 +12,6 @@ | ||||
|  * this software for any purpose.  It is provided "as is" | ||||
|  * without express or implied warranty. | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
| #include <sys/types.h> | ||||
|  | ||||
| @@ -23,6 +22,9 @@ | ||||
| #include <netinet/in.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| @@ -31,6 +33,7 @@ | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
| #include "inet_net_pton.h" | ||||
|  | ||||
| #ifdef WATT32 | ||||
| #undef WIN32 | ||||
| @@ -39,7 +42,8 @@ | ||||
| struct addr_query { | ||||
|   /* Arguments passed to ares_gethostbyaddr() */ | ||||
|   ares_channel channel; | ||||
|   struct in_addr addr; | ||||
|   union ares_addr addr; | ||||
|   int family; | ||||
|   ares_host_callback callback; | ||||
|   void *arg; | ||||
|  | ||||
| @@ -51,14 +55,21 @@ static void addr_callback(void *arg, int status, unsigned char *abuf, | ||||
|                           int alen); | ||||
| static void end_aquery(struct addr_query *aquery, int status, | ||||
|                        struct hostent *host); | ||||
| static int file_lookup(struct in_addr *addr, struct hostent **host); | ||||
| static int file_lookup(union ares_addr *addr, int family, struct hostent **host); | ||||
|  | ||||
| void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen, | ||||
|                         int family, ares_host_callback callback, void *arg) | ||||
| { | ||||
|   struct addr_query *aquery; | ||||
|  | ||||
|   if (family != AF_INET || addrlen != sizeof(struct in_addr)) | ||||
|   if (family != AF_INET && family != AF_INET6) | ||||
|     { | ||||
|       callback(arg, ARES_ENOTIMP, NULL); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   if ((family == AF_INET && addrlen != sizeof(struct in_addr)) || | ||||
|       (family == AF_INET6 && addrlen != sizeof(struct in6_addr))) | ||||
|     { | ||||
|       callback(arg, ARES_ENOTIMP, NULL); | ||||
|       return; | ||||
| @@ -71,7 +82,11 @@ void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen, | ||||
|       return; | ||||
|     } | ||||
|   aquery->channel = channel; | ||||
|   memcpy(&aquery->addr, addr, sizeof(aquery->addr)); | ||||
|   if (family == AF_INET) | ||||
|     memcpy(&aquery->addr.addr4, addr, sizeof(struct in_addr)); | ||||
|   else | ||||
|     memcpy(&aquery->addr.addr6, addr, sizeof(struct in6_addr)); | ||||
|   aquery->family = family; | ||||
|   aquery->callback = callback; | ||||
|   aquery->arg = arg; | ||||
|   aquery->remaining_lookups = channel->lookups; | ||||
| @@ -82,7 +97,7 @@ void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen, | ||||
| static void next_lookup(struct addr_query *aquery) | ||||
| { | ||||
|   const char *p; | ||||
|   char name[64]; | ||||
|   char name[128]; | ||||
|   int a1, a2, a3, a4, status; | ||||
|   struct hostent *host; | ||||
|   unsigned long addr; | ||||
| @@ -92,7 +107,9 @@ static void next_lookup(struct addr_query *aquery) | ||||
|       switch (*p) | ||||
|         { | ||||
|         case 'b': | ||||
|           addr = ntohl(aquery->addr.s_addr); | ||||
|           if (aquery->family == AF_INET) | ||||
|             { | ||||
|               addr = ntohl(aquery->addr.addr4.s_addr); | ||||
|               a1 = (int)((addr >> 24) & 0xff); | ||||
|               a2 = (int)((addr >> 16) & 0xff); | ||||
|               a3 = (int)((addr >> 8) & 0xff); | ||||
| @@ -101,9 +118,27 @@ static void next_lookup(struct addr_query *aquery) | ||||
|               aquery->remaining_lookups = p + 1; | ||||
|               ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback, | ||||
|                          aquery); | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               unsigned char *bytes; | ||||
|               bytes = (unsigned char *)&aquery->addr.addr6.s6_addr; | ||||
|               sprintf(name, "%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.ip6.arpa", | ||||
|                       bytes[15]&0xf, bytes[15] >> 4, bytes[14]&0xf, bytes[14] >> 4, | ||||
|                       bytes[13]&0xf, bytes[13] >> 4, bytes[12]&0xf, bytes[12] >> 4, | ||||
|                       bytes[11]&0xf, bytes[11] >> 4, bytes[10]&0xf, bytes[10] >> 4, | ||||
|                       bytes[9]&0xf, bytes[9] >> 4, bytes[8]&0xf, bytes[8] >> 4, | ||||
|                       bytes[7]&0xf, bytes[7] >> 4, bytes[6]&0xf, bytes[6] >> 4, | ||||
|                       bytes[5]&0xf, bytes[5] >> 4, bytes[4]&0xf, bytes[4] >> 4, | ||||
|                       bytes[3]&0xf, bytes[3] >> 4, bytes[2]&0xf, bytes[2] >> 4, | ||||
|                       bytes[1]&0xf, bytes[1] >> 4, bytes[0]&0xf, bytes[0] >> 4); | ||||
|               aquery->remaining_lookups = p + 1; | ||||
|               ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback, | ||||
|                          aquery); | ||||
|             } | ||||
|           return; | ||||
|         case 'f': | ||||
|           status = file_lookup(&aquery->addr, &host); | ||||
|           status = file_lookup(&aquery->addr, aquery->family, &host); | ||||
|           if (status != ARES_ENOTFOUND) | ||||
|             { | ||||
|               end_aquery(aquery, status, host); | ||||
| @@ -122,8 +157,12 @@ static void addr_callback(void *arg, int status, unsigned char *abuf, int alen) | ||||
|  | ||||
|   if (status == ARES_SUCCESS) | ||||
|     { | ||||
|       status = ares_parse_ptr_reply(abuf, alen, &aquery->addr, | ||||
|       if (aquery->family == AF_INET) | ||||
|         status = ares_parse_ptr_reply(abuf, alen, &aquery->addr.addr4, | ||||
|                                       sizeof(struct in_addr), AF_INET, &host); | ||||
|       else | ||||
|         status = ares_parse_ptr_reply(abuf, alen, &aquery->addr.addr6, | ||||
|                                       sizeof(struct in6_addr), AF_INET6, &host); | ||||
|       end_aquery(aquery, status, host); | ||||
|     } | ||||
|   else if (status == ARES_EDESTRUCTION) | ||||
| @@ -141,13 +180,12 @@ static void end_aquery(struct addr_query *aquery, int status, | ||||
|   free(aquery); | ||||
| } | ||||
|  | ||||
| static int file_lookup(struct in_addr *addr, struct hostent **host) | ||||
| static int file_lookup(union ares_addr *addr, int family, struct hostent **host) | ||||
| { | ||||
|   FILE *fp; | ||||
|   int status; | ||||
|  | ||||
| #ifdef WIN32 | ||||
|  | ||||
|   char PATH_HOSTS[MAX_PATH]; | ||||
|   if (IS_NT()) { | ||||
|     char tmp[MAX_PATH]; | ||||
| @@ -157,7 +195,7 @@ static int file_lookup(struct in_addr *addr, struct hostent **host) | ||||
|         == ERROR_SUCCESS) | ||||
|     { | ||||
|       DWORD dwLength = MAX_PATH; | ||||
|                 RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, tmp, | ||||
|       RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, (LPBYTE)tmp, | ||||
|                       &dwLength); | ||||
|       ExpandEnvironmentStrings(tmp, PATH_HOSTS, MAX_PATH); | ||||
|       RegCloseKey(hkeyHosts); | ||||
| @@ -179,11 +217,23 @@ static int file_lookup(struct in_addr *addr, struct hostent **host) | ||||
|   fp = fopen(PATH_HOSTS, "r"); | ||||
|   if (!fp) | ||||
|     return ARES_ENOTFOUND; | ||||
|  | ||||
|   while ((status = ares__get_hostent(fp, host)) == ARES_SUCCESS) | ||||
|   while ((status = ares__get_hostent(fp, family, host)) == ARES_SUCCESS) | ||||
|     { | ||||
|       if (memcmp((*host)->h_addr, addr, sizeof(struct in_addr)) == 0) | ||||
|       if (family != (*host)->h_addrtype) | ||||
|         { | ||||
|           ares_free_hostent(*host); | ||||
|           continue; | ||||
|         } | ||||
|       if (family == AF_INET) | ||||
|         { | ||||
|           if (memcmp((*host)->h_addr, &addr->addr4, sizeof(struct in_addr)) == 0) | ||||
|             break; | ||||
|         } | ||||
|       else if (family == AF_INET6) | ||||
|         { | ||||
|           if (memcmp((*host)->h_addr, &addr->addr6, sizeof(struct in6_addr)) == 0) | ||||
|             break; | ||||
|         } | ||||
|       ares_free_hostent(*host); | ||||
|     } | ||||
|   fclose(fp); | ||||
|   | ||||
| @@ -23,8 +23,13 @@ | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <netdb.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_H | ||||
| #include <arpa/nameser.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| @@ -33,6 +38,8 @@ | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
| #include "inet_net_pton.h" | ||||
| #include "bitncmp.h" | ||||
|  | ||||
| #ifdef WATT32 | ||||
| #undef WIN32 | ||||
| @@ -44,7 +51,7 @@ struct host_query { | ||||
|   char *name; | ||||
|   ares_host_callback callback; | ||||
|   void *arg; | ||||
|  | ||||
|   int family; | ||||
|   const char *remaining_lookups; | ||||
| }; | ||||
|  | ||||
| @@ -53,13 +60,17 @@ static void host_callback(void *arg, int status, unsigned char *abuf, | ||||
|                           int alen); | ||||
| static void end_hquery(struct host_query *hquery, int status, | ||||
|                        struct hostent *host); | ||||
| static int fake_hostent(const char *name, ares_host_callback callback, | ||||
| static int fake_hostent(const char *name, int family, ares_host_callback callback, | ||||
|                         void *arg); | ||||
| static int file_lookup(const char *name, struct hostent **host); | ||||
| static int file_lookup(const char *name, int family, struct hostent **host); | ||||
| static void sort_addresses(struct hostent *host, struct apattern *sortlist, | ||||
|                            int nsort); | ||||
| static void sort6_addresses(struct hostent *host, struct apattern *sortlist, | ||||
|                            int nsort); | ||||
| static int get_address_index(struct in_addr *addr, struct apattern *sortlist, | ||||
|                              int nsort); | ||||
| static int get6_address_index(struct in6_addr *addr, struct apattern *sortlist, | ||||
|                              int nsort); | ||||
|  | ||||
| void ares_gethostbyname(ares_channel channel, const char *name, int family, | ||||
|                         ares_host_callback callback, void *arg) | ||||
| @@ -67,13 +78,13 @@ void ares_gethostbyname(ares_channel channel, const char *name, int family, | ||||
|   struct host_query *hquery; | ||||
|  | ||||
|   /* Right now we only know how to look up Internet addresses. */ | ||||
|   if (family != AF_INET) | ||||
|   if (family != AF_INET && family != AF_INET6) | ||||
|     { | ||||
|       callback(arg, ARES_ENOTIMP, NULL); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   if (fake_hostent(name, callback, arg)) | ||||
|   if (fake_hostent(name, family, callback, arg)) | ||||
|     return; | ||||
|  | ||||
|   /* Allocate and fill in the host query structure. */ | ||||
| @@ -85,6 +96,7 @@ void ares_gethostbyname(ares_channel channel, const char *name, int family, | ||||
|     } | ||||
|   hquery->channel = channel; | ||||
|   hquery->name = strdup(name); | ||||
|   hquery->family = family; | ||||
|   if (!hquery->name) | ||||
|     { | ||||
|       free(hquery); | ||||
| @@ -112,13 +124,17 @@ static void next_lookup(struct host_query *hquery) | ||||
|         case 'b': | ||||
|           /* DNS lookup */ | ||||
|           hquery->remaining_lookups = p + 1; | ||||
|           if (hquery->family == AF_INET6) | ||||
|             ares_search(hquery->channel, hquery->name, C_IN, T_AAAA, host_callback, | ||||
|                         hquery); | ||||
|           else | ||||
|             ares_search(hquery->channel, hquery->name, C_IN, T_A, host_callback, | ||||
|                         hquery); | ||||
|           return; | ||||
|  | ||||
|         case 'f': | ||||
|           /* Host file lookup */ | ||||
|           status = file_lookup(hquery->name, &host); | ||||
|           status = file_lookup(hquery->name, hquery->family, &host); | ||||
|           if (status != ARES_ENOTFOUND) | ||||
|             { | ||||
|               end_hquery(hquery, status, host); | ||||
| @@ -137,12 +153,28 @@ static void host_callback(void *arg, int status, unsigned char *abuf, int alen) | ||||
|   struct hostent *host; | ||||
|  | ||||
|   if (status == ARES_SUCCESS) | ||||
|     { | ||||
|       if (hquery->family == AF_INET) | ||||
|         { | ||||
|           status = ares_parse_a_reply(abuf, alen, &host); | ||||
|           if (host && channel->nsort) | ||||
|             sort_addresses(host, channel->sortlist, channel->nsort); | ||||
|         } | ||||
|       else if (hquery->family == AF_INET6) | ||||
|         { | ||||
|           status = ares_parse_aaaa_reply(abuf, alen, &host); | ||||
|           if (host && channel->nsort) | ||||
|             sort6_addresses(host, channel->sortlist, channel->nsort); | ||||
|         } | ||||
|       end_hquery(hquery, status, host); | ||||
|     } | ||||
|   else if (status == ARES_ENODATA && hquery->family == AF_INET6) | ||||
|     { | ||||
|       /* 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); | ||||
|     } | ||||
|   else if (status == ARES_EDESTRUCTION) | ||||
|     end_hquery(hquery, status, NULL); | ||||
|   else | ||||
| @@ -162,36 +194,34 @@ static void end_hquery(struct host_query *hquery, int status, | ||||
| /* If the name looks like an IP address, fake up a host entry, end the | ||||
|  * query immediately, and return true.  Otherwise return false. | ||||
|  */ | ||||
| static int fake_hostent(const char *name, ares_host_callback callback, | ||||
| static int fake_hostent(const char *name, int family, ares_host_callback callback, | ||||
|                         void *arg) | ||||
| { | ||||
|   struct in_addr addr; | ||||
|   struct hostent hostent; | ||||
|   const char *p; | ||||
|   char *aliases[1] = { NULL }; | ||||
|   char *addrs[2]; | ||||
|   int result = 0; | ||||
|   struct in_addr in; | ||||
|   struct in6_addr in6; | ||||
|  | ||||
|   /* It only looks like an IP address if it's all numbers and dots. */ | ||||
|   for (p = name; *p; p++) | ||||
|     { | ||||
|       if (!isdigit((unsigned char)*p) && *p != '.') | ||||
|         return 0; | ||||
|     } | ||||
|   if (family == AF_INET) | ||||
|     result = ((in.s_addr = inet_addr(name)) == INADDR_NONE ? 0 : 1); | ||||
|   else if (family == AF_INET6) | ||||
|     result = (ares_inet_pton(AF_INET6, name, &in6) < 1 ? 0 : 1); | ||||
|  | ||||
|   /* It also only looks like an IP address if it's non-zero-length and | ||||
|    * doesn't end with a dot. | ||||
|    */ | ||||
|   if (p == name || *(p - 1) == '.') | ||||
|   if (!result) | ||||
|     return 0; | ||||
|  | ||||
|   /* It looks like an IP address.  Figure out what IP address it is. */ | ||||
|   addr.s_addr = inet_addr(name); | ||||
|   if (addr.s_addr == INADDR_NONE) | ||||
|   if (family == AF_INET) | ||||
|     { | ||||
|       callback(arg, ARES_EBADNAME, NULL); | ||||
|       return 1; | ||||
|       hostent.h_length = sizeof(struct in_addr); | ||||
|       addrs[0] = (char *)∈ | ||||
|     } | ||||
|   else if (family == AF_INET6) | ||||
|     { | ||||
|       hostent.h_length = sizeof(struct in6_addr); | ||||
|       addrs[0] = (char *)&in6; | ||||
|     } | ||||
|  | ||||
|   /* Duplicate the name, to avoid a constness violation. */ | ||||
|   hostent.h_name = strdup(name); | ||||
|   if (!hostent.h_name) | ||||
| @@ -201,11 +231,9 @@ static int fake_hostent(const char *name, ares_host_callback callback, | ||||
|     } | ||||
|  | ||||
|   /* Fill in the rest of the host structure and terminate the query. */ | ||||
|   addrs[0] = (char *) &addr; | ||||
|   addrs[1] = NULL; | ||||
|   hostent.h_aliases = aliases; | ||||
|   hostent.h_addrtype = AF_INET; | ||||
|   hostent.h_length = sizeof(struct in_addr); | ||||
|   hostent.h_addrtype = family; | ||||
|   hostent.h_addr_list = addrs; | ||||
|   callback(arg, ARES_SUCCESS, &hostent); | ||||
|  | ||||
| @@ -213,7 +241,7 @@ static int fake_hostent(const char *name, ares_host_callback callback, | ||||
|   return 1; | ||||
| } | ||||
|  | ||||
| static int file_lookup(const char *name, struct hostent **host) | ||||
| static int file_lookup(const char *name, int family, struct hostent **host) | ||||
| { | ||||
|   FILE *fp; | ||||
|   char **alias; | ||||
| @@ -229,7 +257,7 @@ static int file_lookup(const char *name, struct hostent **host) | ||||
|         == ERROR_SUCCESS) | ||||
|     { | ||||
|       DWORD dwLength = MAX_PATH; | ||||
|                 RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, tmp, | ||||
|       RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, (LPBYTE)tmp, | ||||
|                       &dwLength); | ||||
|       ExpandEnvironmentStrings(tmp, PATH_HOSTS, MAX_PATH); | ||||
|       RegCloseKey(hkeyHosts); | ||||
| @@ -252,7 +280,7 @@ static int file_lookup(const char *name, struct hostent **host) | ||||
|   if (!fp) | ||||
|     return ARES_ENOTFOUND; | ||||
|  | ||||
|   while ((status = ares__get_hostent(fp, host)) == ARES_SUCCESS) | ||||
|   while ((status = ares__get_hostent(fp, family, host)) == ARES_SUCCESS) | ||||
|     { | ||||
|       if (strcasecmp((*host)->h_name, name) == 0) | ||||
|         break; | ||||
| @@ -310,8 +338,66 @@ static int get_address_index(struct in_addr *addr, struct apattern *sortlist, | ||||
|  | ||||
|   for (i = 0; i < nsort; i++) | ||||
|     { | ||||
|       if ((addr->s_addr & sortlist[i].mask.s_addr) == sortlist[i].addr.s_addr) | ||||
|       if (sortlist[i].family != AF_INET) | ||||
|         continue; | ||||
|       if (sortlist[i].type == PATTERN_MASK) | ||||
|         { | ||||
|           if ((addr->s_addr & sortlist[i].mask.addr.addr4.s_addr) | ||||
|               == sortlist[i].addr.addr4.s_addr) | ||||
|             break; | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           if (!ares_bitncmp(&addr->s_addr, &sortlist[i].addr.addr4.s_addr, | ||||
|                             sortlist[i].mask.bits)) | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
|   return i; | ||||
| } | ||||
|  | ||||
| static void sort6_addresses(struct hostent *host, struct apattern *sortlist, | ||||
|                            int nsort) | ||||
| { | ||||
|   struct in6_addr a1, a2; | ||||
|   int i1, i2, ind1, ind2; | ||||
|  | ||||
|   /* This is a simple insertion sort, not optimized at all.  i1 walks | ||||
|    * through the address list, with the loop invariant that everything | ||||
|    * to the left of i1 is sorted.  In the loop body, the value at i1 is moved | ||||
|    * back through the list (via i2) until it is in sorted order. | ||||
|    */ | ||||
|   for (i1 = 0; host->h_addr_list[i1]; i1++) | ||||
|     { | ||||
|       memcpy(&a1, host->h_addr_list[i1], sizeof(struct in6_addr)); | ||||
|       ind1 = get6_address_index(&a1, sortlist, nsort); | ||||
|       for (i2 = i1 - 1; i2 >= 0; i2--) | ||||
|         { | ||||
|           memcpy(&a2, host->h_addr_list[i2], sizeof(struct in6_addr)); | ||||
|           ind2 = get6_address_index(&a2, sortlist, nsort); | ||||
|           if (ind2 <= ind1) | ||||
|             break; | ||||
|           memcpy(host->h_addr_list[i2 + 1], &a2, sizeof(struct in6_addr)); | ||||
|         } | ||||
|       memcpy(host->h_addr_list[i2 + 1], &a1, sizeof(struct in6_addr)); | ||||
|     } | ||||
| } | ||||
|  | ||||
| /* Find the first entry in sortlist which matches addr.  Return nsort | ||||
|  * if none of them match. | ||||
|  */ | ||||
| static int get6_address_index(struct in6_addr *addr, struct apattern *sortlist, | ||||
|                              int nsort) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   for (i = 0; i < nsort; i++) | ||||
|     { | ||||
|       if (sortlist[i].family != AF_INET6) | ||||
|         continue; | ||||
|         if (!ares_bitncmp(&addr->s6_addr, &sortlist[i].addr.addr6.s6_addr, sortlist[i].mask.bits)) | ||||
|           break; | ||||
|     } | ||||
|   return i; | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										145
									
								
								ares/ares_getnameinfo.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										145
									
								
								ares/ares_getnameinfo.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,145 @@ | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .\" Copyright 2005 by Dominick Meglio. | ||||
| .\" | ||||
| .\" 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_GETNAMEINFO 3 "16 May 2005" | ||||
| .SH NAME | ||||
| ares_getnameinfo \- Address-to-nodename translation in protocol-independent manner | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <ares.h> | ||||
| .PP | ||||
| .B typedef void (*ares_nameinfo_callback)(void *\fIarg\fP, int \fIstatus\fP, | ||||
| .B	char *\fInode\fP, char *\fIservice\fP) | ||||
| .PP | ||||
| .B void ares_getnameinfo(ares_channel \fIchannel\fP, const struct sockaddr *\fIsa\fP, | ||||
| .B 	socklen_t \fIsalen\fP, int \fIflags\fP, ares_nameinfo_callback \fIcallback\fP, | ||||
| .B 	void *\fIarg\fP) | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_getnameinfo | ||||
| function is defined for protocol-independent address translation. The function | ||||
| is a combination of \fIares_gethostbyaddr(3)\fP and \fIgetservbyport(3)\fP. The function will | ||||
| translate the address either by executing a host query on the name service channel | ||||
| identified by | ||||
| .IR channel  | ||||
| or it will attempt to resolve it locally if possible. | ||||
| The parameters | ||||
| .I sa | ||||
| and | ||||
| .I len | ||||
| give the address as a sockaddr structure, and | ||||
| .I flags | ||||
| gives the options that the function will use.  Valid flags are listed below: | ||||
| .TP 19 | ||||
| .B ARES_NI_NOFQDN | ||||
| Only the nodename portion of the FQDN is returned for local hosts. | ||||
| .TP 19 | ||||
| .B ARES_NI_NUMERICHOST | ||||
| The numeric form of the hostname is returned rather than the name. | ||||
| .TP 19 | ||||
| .B ARES_NI_NAMEREQD | ||||
| An error is returned if the hostname cannot be found in the DNS. | ||||
| .TP 19 | ||||
| .B ARES_NI_NUMERICSERV | ||||
| The numeric form of the service is returned rather than the name. | ||||
| .TP 19 | ||||
| .B ARES_NI_TCP | ||||
| The service name is to be looked up for the TCP protocol. | ||||
| .TP 19 | ||||
| .B ARES_NI_UDP | ||||
| The service name is to be looked up for the UDP protocol. | ||||
| .TP 19 | ||||
| .B ARES_NI_SCTP | ||||
| The service name is to be looked up for the SCTP protocol. | ||||
| .TP 19 | ||||
| .B ARES_NI_DCCP | ||||
| The service name is to be looked up for the DCCP protocol. | ||||
| .TP 19 | ||||
| .B ARES_NI_NUMERICSCOPE | ||||
| The numeric form of the scope ID is returned rather than the name. | ||||
| .TP 19 | ||||
| .B ARES_NI_LOOKUPHOST | ||||
| A hostname lookup is being requested. | ||||
| .TP 19 | ||||
| .B ARES_NI_LOOKUPSERVICE | ||||
| A service name lookup is being requested. | ||||
| .PP | ||||
| When the query | ||||
| is complete or has  | ||||
| failed, the ares library will invoke \fIcallback\fP.  Completion or failure of  | ||||
| the query may happen immediately, or may happen during a later call to | ||||
| \fIares_process(3)\fP, \fIares_destroy(3)\fP or \fIares_cancel(3)\fP. | ||||
| .PP | ||||
| The callback argument | ||||
| .I arg | ||||
| is copied from the | ||||
| .B ares_getnameinfo | ||||
| argument | ||||
| .IR arg . | ||||
| The callback argument | ||||
| .I status | ||||
| indicates whether the query succeeded and, if not, how it failed.  It | ||||
| may have any of the following values: | ||||
| .TP 19 | ||||
| .B ARES_SUCCESS | ||||
| The host lookup completed successfully. | ||||
| .TP 19 | ||||
| .B ARES_ENOTIMP | ||||
| The ares library does not know how to look up addresses of type | ||||
| .IR family . | ||||
| .TP 19 | ||||
| .B ARES_ENOTFOUND | ||||
| The address | ||||
| .I addr | ||||
| was not found. | ||||
| .TP 19 | ||||
| .B ARES_ENOMEM | ||||
| Memory was exhausted. | ||||
| .TP 19 | ||||
| .B ARES_EDESTRUCTION | ||||
| The name service channel | ||||
| .I channel | ||||
| is being destroyed; the query will not be completed. | ||||
| .TP 19 | ||||
| .B ARES_EBADFLAGS | ||||
| The | ||||
| .I flags | ||||
| parameter contains an illegal value. | ||||
| .PP | ||||
| On successful completion of the query, the callback argument | ||||
| .I node | ||||
| contains a string representing the hostname (assuming  | ||||
| .B ARES_NI_LOOKUPHOST | ||||
| was specified). Additionally,  | ||||
| .I service | ||||
| contains a string representing the service name (assuming | ||||
| .B ARES_NI_LOOKUPSERVICE | ||||
| was specified). | ||||
| If the query did not complete successfully, or one of the values | ||||
| was not requested,  | ||||
| .I node | ||||
| or | ||||
| .I service | ||||
| will be  | ||||
| .BR NULL . | ||||
| .SH SEE ALSO | ||||
| .BR ares_process (3), | ||||
| .BR ares_getaddrinfo (3) | ||||
| .SH AUTHOR | ||||
| Dominick Meglio | ||||
| .br | ||||
| Copyright 2005 by Dominick Meglio. | ||||
							
								
								
									
										373
									
								
								ares/ares_getnameinfo.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										373
									
								
								ares/ares_getnameinfo.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,373 @@ | ||||
| /* Copyright 2005 by Dominick Meglio | ||||
|  * | ||||
|  * 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> | ||||
| #include <ctype.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_NET_IF_H | ||||
| #include <net/if.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
| #include "ares_ipv6.h" | ||||
| #include "inet_ntop.h" | ||||
|  | ||||
| #ifdef WATT32 | ||||
| #undef WIN32 | ||||
| #endif | ||||
|  | ||||
| struct nameinfo_query { | ||||
|   ares_nameinfo_callback callback; | ||||
|   void *arg; | ||||
|   union { | ||||
|     struct sockaddr_in addr4; | ||||
|     struct sockaddr_in6 addr6; | ||||
|   } addr; | ||||
|   int family; | ||||
|   int flags; | ||||
| }; | ||||
|  | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
| #define IPBUFSIZ 40+IF_NAMESIZE | ||||
| #else | ||||
| #define IPBUFSIZ 40 | ||||
| #endif | ||||
|  | ||||
| static void nameinfo_callback(void *arg, int status, struct hostent *host); | ||||
| static char *lookup_service(unsigned short port, int flags, char *buf); | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
| static char *append_scopeid(struct sockaddr_in6 *addr6, unsigned int scopeid, char *buf); | ||||
| #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 nameinfo_query *niquery; | ||||
|  | ||||
|   /* Verify the buffer size */ | ||||
|   if (salen == sizeof(struct sockaddr_in)) | ||||
|     addr = (struct sockaddr_in *)sa; | ||||
|   else if (salen == sizeof(struct sockaddr_in6)) | ||||
|     addr6 = (struct sockaddr_in6 *)sa; | ||||
|   else | ||||
|     { | ||||
|       callback(arg, ARES_ENOTIMP, NULL, NULL); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   /* If neither, assume they want a host */ | ||||
|   if (!(flags & ARES_NI_LOOKUPSERVICE) && !(flags & ARES_NI_LOOKUPHOST)) | ||||
|     flags |= ARES_NI_LOOKUPHOST; | ||||
|  | ||||
|   /* All they want is a service, no need for DNS */ | ||||
|   if ((flags & ARES_NI_LOOKUPSERVICE) && !(flags & ARES_NI_LOOKUPHOST)) | ||||
|     { | ||||
|       char buf[33], *service; | ||||
|       unsigned int port = 0; | ||||
|  | ||||
|       if (salen == sizeof(struct sockaddr_in)) | ||||
|         port = addr->sin_port; | ||||
|       else | ||||
|         port = addr6->sin6_port; | ||||
|       service = lookup_service(port, flags, buf); | ||||
|       callback(arg, ARES_SUCCESS, NULL, service); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   /* They want a host lookup */ | ||||
|   if ((flags & ARES_NI_LOOKUPHOST)) | ||||
|     { | ||||
|      /* A numeric host can be handled without DNS */ | ||||
|      if ((flags & ARES_NI_NUMERICHOST)) | ||||
|       { | ||||
|         unsigned int port = 0; | ||||
|         char ipbuf[IPBUFSIZ]; | ||||
|         char srvbuf[32]; | ||||
|         char *service = NULL; | ||||
|         ipbuf[0] = 0; | ||||
|  | ||||
|         /* Specifying not to lookup a host, but then saying a host | ||||
|          * is required has to be illegal. | ||||
|          */ | ||||
|         if (flags & ARES_NI_NAMEREQD) | ||||
|           { | ||||
|             callback(arg, ARES_EBADFLAGS, NULL, NULL); | ||||
|             return; | ||||
|           } | ||||
|         if (salen == sizeof(struct sockaddr_in6)) | ||||
|           { | ||||
|             ares_inet_ntop(AF_INET6, &addr6->sin6_addr, ipbuf, IPBUFSIZ); | ||||
|             port = addr6->sin6_port; | ||||
|             /* If the system supports scope IDs, use it */ | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
|             append_scopeid(addr6, flags, ipbuf); | ||||
| #endif | ||||
|           } | ||||
|         else | ||||
|           { | ||||
|             ares_inet_ntop(AF_INET, &addr->sin_addr, ipbuf, IPBUFSIZ); | ||||
|             port = addr->sin_port; | ||||
|           } | ||||
|         /* They also want a service */ | ||||
|         if (flags & ARES_NI_LOOKUPSERVICE) | ||||
|           service = lookup_service(port, flags, srvbuf); | ||||
|         callback(arg, ARES_SUCCESS, ipbuf, service); | ||||
|         return; | ||||
|       } | ||||
|     /* This is where a DNS lookup becomes necessary */ | ||||
|     else | ||||
|       { | ||||
|         niquery = malloc(sizeof(struct nameinfo_query)); | ||||
|         if (!niquery) | ||||
|           { | ||||
|             callback(arg, ARES_ENOMEM, NULL, NULL); | ||||
|             return; | ||||
|           } | ||||
|         niquery->callback = callback; | ||||
|         niquery->arg = arg; | ||||
|         niquery->flags = flags; | ||||
|         if (sa->sa_family == AF_INET) | ||||
|           { | ||||
|             niquery->family = AF_INET; | ||||
|             memcpy(&niquery->addr.addr4, addr, sizeof(addr)); | ||||
|             ares_gethostbyaddr(channel, &addr->sin_addr, sizeof(struct in_addr), AF_INET, | ||||
|                                nameinfo_callback, niquery); | ||||
|           } | ||||
|         else | ||||
|           { | ||||
|             niquery->family = AF_INET6; | ||||
|             memcpy(&niquery->addr.addr6, addr6, sizeof(addr6)); | ||||
|             ares_gethostbyaddr(channel, &addr6->sin6_addr, sizeof(struct in6_addr), AF_INET6, | ||||
|                                nameinfo_callback, niquery); | ||||
|           } | ||||
|       } | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void nameinfo_callback(void *arg, int status, struct hostent *host) | ||||
| { | ||||
|   struct nameinfo_query *niquery = (struct nameinfo_query *) arg; | ||||
|   char srvbuf[33]; | ||||
|   char *service = NULL; | ||||
|  | ||||
|  | ||||
|   if (status == ARES_SUCCESS) | ||||
|     { | ||||
|       /* They want a service too */ | ||||
|       if (niquery->flags & ARES_NI_LOOKUPSERVICE) | ||||
|         { | ||||
|           if (niquery->family == AF_INET) | ||||
|             service = lookup_service(niquery->addr.addr4.sin_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|           else | ||||
|             service = lookup_service(niquery->addr.addr6.sin6_port, | ||||
|                                      niquery->flags, 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 | ||||
|          for this domain name and removing it. | ||||
|        */ | ||||
|       if (niquery->flags & ARES_NI_NOFQDN) | ||||
|         { | ||||
|            char buf[255]; | ||||
|            char *domain; | ||||
|            gethostname(buf, 255); | ||||
|            if ((domain = strchr(buf, '.'))) | ||||
|              { | ||||
|                char *end = ares_striendstr(host->h_name, domain); | ||||
|                if (end) | ||||
|                  *end = 0; | ||||
|              } | ||||
|         } | ||||
|       niquery->callback(niquery->arg, ARES_SUCCESS, host->h_name, service); | ||||
|       return; | ||||
|     } | ||||
|   /* We couldn't find the host, but it's OK, we can use the IP */ | ||||
|   else if (status == ARES_ENOTFOUND && !(niquery->flags & ARES_NI_NAMEREQD)) | ||||
|     { | ||||
|       char ipbuf[IPBUFSIZ]; | ||||
|       if (niquery->family == AF_INET) | ||||
|         ares_inet_ntop(AF_INET, &niquery->addr.addr4.sin_addr, ipbuf, IPBUFSIZ); | ||||
|       else | ||||
|         { | ||||
|           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); | ||||
| #endif | ||||
|         } | ||||
|       /* They want a service too */ | ||||
|       if (niquery->flags & ARES_NI_LOOKUPSERVICE) | ||||
|         { | ||||
|           if (niquery->family == AF_INET) | ||||
|             service = lookup_service(niquery->addr.addr4.sin_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|           else | ||||
|             service = lookup_service(niquery->addr.addr6.sin6_port, | ||||
|                                      niquery->flags, srvbuf); | ||||
|         } | ||||
|       niquery->callback(niquery->arg, ARES_SUCCESS, ipbuf, service); | ||||
|       return; | ||||
|     } | ||||
|   niquery->callback(niquery->arg, status, NULL, NULL); | ||||
|   free(niquery); | ||||
| } | ||||
|  | ||||
| static char *lookup_service(unsigned short port, int flags, | ||||
|                             char *buf) /* 33 bytes buffer */ | ||||
| { | ||||
|   if (port) | ||||
|     { | ||||
|       /* Just return the port as a string */ | ||||
|       if (flags & ARES_NI_NUMERICSERV) | ||||
|         sprintf(buf, "%u", ntohs(port)); | ||||
|       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) | ||||
|             proto = "sctp"; | ||||
|           else if (flags & ARES_NI_DCCP) | ||||
|             proto = "dccp"; | ||||
|           else | ||||
|             proto = "tcp"; | ||||
| #ifdef HAVE_GETSERVBYPORT_R | ||||
| #if GETSERVBYPORT_R_ARGS == 6 | ||||
|           se = &ret; | ||||
|           if (getservbyport_r(port, proto, se, buf, len, &ret)) | ||||
|             se = NULL; | ||||
| #elif GETSERVBYPORT_R_ARGS == 5 | ||||
|           se = getservbyport_r(port, proto, se, buf, len); | ||||
| #elif GETSERVBYPORT_R_ARGS == 4 | ||||
|           se = &ret; | ||||
|           if (getservbyport_r(port, proto, se, &sed) == -1) | ||||
|             se = NULL; | ||||
| #else | ||||
|           /* Lets just hope the OS uses TLS! */ | ||||
|           se = getservbyport(port, proto); | ||||
| #endif | ||||
| #else | ||||
|           /* Lets just hope the OS uses TLS! */ | ||||
|           se = 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)); | ||||
|         } | ||||
|       return buf; | ||||
|     } | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| #ifdef HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID | ||||
| static char *append_scopeid(struct sockaddr_in6 *addr6, unsigned int flags, | ||||
|                             char *buf) | ||||
| { | ||||
|   char tmpbuf[IF_NAMESIZE + 1]; | ||||
|  | ||||
|   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); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       if (if_indextoname(addr6->sin6_scope_id, &tmpbuf[1]) == NULL) | ||||
|         sprintf(&tmpbuf[1], "%u", addr6->sin6_scope_id); | ||||
|     } | ||||
| #else | ||||
|   sprintf(&tmpbuf[1], "%u", addr6->sin6_scope_id); | ||||
| #endif | ||||
|   strcat(buf, tmpbuf); | ||||
|   return buf; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /* Determines if s1 ends with the string in s2 (case-insensitive) */ | ||||
| static char *ares_striendstr(const char *s1, const char *s2) | ||||
| { | ||||
|   const char *c1, *c2, *c1_begin; | ||||
|   size_t s1_len = strlen(s1), s2_len = strlen(s2); | ||||
|  | ||||
|   /* If the substr is longer than the full str, it can't match */ | ||||
|   if (s2_len > s1_len) | ||||
|     return NULL; | ||||
|  | ||||
|   /* Jump to the end of s1 minus the length of s2 */ | ||||
|   c1_begin = s1+s1_len-s2_len; | ||||
|   c1 = (const char *)c1_begin; | ||||
|   c2 = s2; | ||||
|   while (c2 < s2+s2_len) | ||||
|     { | ||||
|       if (tolower(*c1) != tolower(*c2)) | ||||
|         return NULL; | ||||
|       else | ||||
|         { | ||||
|           c1++; | ||||
|           c2++; | ||||
|         } | ||||
|     } | ||||
|   if (c2 == c1 && c2 == NULL) | ||||
|     return (char *)c1_begin; | ||||
|   return NULL; | ||||
| } | ||||
							
								
								
									
										129
									
								
								ares/ares_init.c
									
									
									
									
									
								
							
							
						
						
									
										129
									
								
								ares/ares_init.c
									
									
									
									
									
								
							| @@ -27,10 +27,17 @@ | ||||
| #include <sys/time.h> | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
|  | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| @@ -44,6 +51,7 @@ | ||||
| #include <errno.h> | ||||
| #include "ares.h" | ||||
| #include "ares_private.h" | ||||
| #include "inet_net_pton.h" | ||||
|  | ||||
| #ifdef WATT32 | ||||
| #undef WIN32  /* Redefined in MingW/MSVC headers */ | ||||
| @@ -54,19 +62,23 @@ static int init_by_options(ares_channel channel, struct ares_options *options, | ||||
| static int init_by_environment(ares_channel channel); | ||||
| static int init_by_resolv_conf(ares_channel channel); | ||||
| static int init_by_defaults(ares_channel channel); | ||||
|  | ||||
| static int config_nameserver(struct server_state **servers, int *nservers, | ||||
|                              char *str); | ||||
| static int set_search(ares_channel channel, const char *str); | ||||
| static int set_options(ares_channel channel, const char *str); | ||||
| static const char *try_option(const char *p, const char *q, const char *opt); | ||||
| #ifndef WIN32 | ||||
| static int sortlist_alloc(struct apattern **sortlist, int *nsort, struct apattern *pat); | ||||
| static int ip_addr(const char *s, int len, struct in_addr *addr); | ||||
| static void natural_mask(struct apattern *pat); | ||||
| static int config_domain(ares_channel channel, char *str); | ||||
| static int config_lookup(ares_channel channel, const char *str, | ||||
|                          const char *bindch, const char *filech); | ||||
| static int config_nameserver(struct server_state **servers, int *nservers, | ||||
|                              char *str); | ||||
| static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|                            const char *str); | ||||
| static int set_search(ares_channel channel, const char *str); | ||||
| static int set_options(ares_channel channel, const char *str); | ||||
| static char *try_config(char *s, const char *opt); | ||||
| static const char *try_option(const char *p, const char *q, const char *opt); | ||||
| static int ip_addr(const char *s, int len, struct in_addr *addr); | ||||
| static void natural_mask(struct apattern *pat); | ||||
| #endif | ||||
|  | ||||
| int ares_init(ares_channel *channelptr) | ||||
| { | ||||
| @@ -264,7 +276,8 @@ static int get_res_nt(HKEY hKey, const char *subkey, char **obuf) | ||||
|   if (!*obuf) | ||||
|     return 0; | ||||
|  | ||||
|   if (RegQueryValueEx(hKey, subkey, 0, NULL, *obuf, &size) != ERROR_SUCCESS) | ||||
|   if (RegQueryValueEx(hKey, subkey, 0, NULL, | ||||
|                       (LPBYTE)*obuf, &size) != ERROR_SUCCESS) | ||||
|   { | ||||
|     free(*obuf); | ||||
|     return 0; | ||||
| @@ -314,6 +327,7 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size) | ||||
|   size_t         ip_size = sizeof("255.255.255.255,")-1; | ||||
|   size_t         left = ret_size; | ||||
|   char          *ret = ret_buf; | ||||
|   HRESULT        res; | ||||
|  | ||||
|   if (!fi) | ||||
|      return (0); | ||||
| @@ -326,7 +340,8 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size) | ||||
|   if (!GetNetworkParams) | ||||
|      goto quit; | ||||
|  | ||||
|   if ((*GetNetworkParams) (fi, &size) != ERROR_BUFFER_OVERFLOW) | ||||
|   res = (*GetNetworkParams) (fi, &size); | ||||
|   if ((res != ERROR_BUFFER_OVERFLOW) && (res != ERROR_SUCCESS)) | ||||
|      goto quit; | ||||
|  | ||||
|   fi = alloca (size); | ||||
| @@ -709,6 +724,7 @@ static int init_by_defaults(ares_channel channel) | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|  | ||||
| #ifndef WIN32 | ||||
| static int config_domain(ares_channel channel, char *str) | ||||
| { | ||||
|   char *q; | ||||
| @@ -749,6 +765,8 @@ static int config_lookup(ares_channel channel, const char *str, | ||||
|   return (channel->lookups) ? ARES_SUCCESS : ARES_ENOMEM; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| static int config_nameserver(struct server_state **servers, int *nservers, | ||||
|                              char *str) | ||||
| { | ||||
| @@ -810,39 +828,74 @@ static int config_nameserver(struct server_state **servers, int *nservers, | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|  | ||||
| #ifndef WIN32 | ||||
| static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|                            const char *str) | ||||
| { | ||||
|   struct apattern pat, *newsort; | ||||
|   struct apattern pat; | ||||
|   const char *q; | ||||
|  | ||||
|   /* Add sortlist entries. */ | ||||
|   while (*str && *str != ';') | ||||
|     { | ||||
|       int bits; | ||||
|       char ipbuf[16], ipbufpfx[32]; | ||||
|       /* Find just the IP */ | ||||
|       q = str; | ||||
|       while (*q && *q != '/' && *q != ';' && !isspace((unsigned char)*q)) | ||||
|         q++; | ||||
|       if (ip_addr(str, (int)(q - str), &pat.addr) == 0) | ||||
|         { | ||||
|           /* We have a pattern address; now determine the mask. */ | ||||
|       memcpy(ipbuf, str, (int)(q-str)); | ||||
|       ipbuf[(int)(q-str)] = 0; | ||||
|       /* Find the prefix */ | ||||
|       if (*q == '/') | ||||
|         { | ||||
|               str = q + 1; | ||||
|           const char *str2 = q+1; | ||||
|           while (*q && *q != ';' && !isspace((unsigned char)*q)) | ||||
|             q++; | ||||
|               if (ip_addr(str, (int)(q - str), &pat.mask) != 0) | ||||
|           memcpy(ipbufpfx, str, (int)(q-str)); | ||||
|           ipbufpfx[(int)(q-str)] = 0; | ||||
|           str = str2; | ||||
|         } | ||||
|       else | ||||
|         ipbufpfx[0] = 0; | ||||
|       /* Lets see if it is CIDR */ | ||||
|       /* First we'll try IPv6 */ | ||||
|       if ((bits = ares_inet_net_pton(AF_INET6, ipbufpfx ? ipbufpfx : ipbuf, | ||||
|                                      &pat.addr.addr6, | ||||
|                                      sizeof(pat.addr.addr6))) > 0) | ||||
|         { | ||||
|           pat.type = PATTERN_CIDR; | ||||
|           pat.mask.bits = bits; | ||||
|           pat.family = AF_INET6; | ||||
|           if (!sortlist_alloc(sortlist, nsort, &pat)) | ||||
|             return ARES_ENOMEM; | ||||
|         } | ||||
|       if (ipbufpfx && | ||||
|           (bits = ares_inet_net_pton(AF_INET, ipbufpfx, &pat.addr.addr4, | ||||
|                                      sizeof(pat.addr.addr4))) > 0) | ||||
|         { | ||||
|           pat.type = PATTERN_CIDR; | ||||
|           pat.mask.bits = bits; | ||||
|           pat.family = AF_INET; | ||||
|           if (!sortlist_alloc(sortlist, nsort, &pat)) | ||||
|             return ARES_ENOMEM; | ||||
|         } | ||||
|       /* See if it is just a regular IP */ | ||||
|       else if (ip_addr(ipbuf, (int)(q-str), &pat.addr.addr4) == 0) | ||||
|         { | ||||
|           if (ipbufpfx) | ||||
|             { | ||||
|               memcpy(ipbuf, str, (int)(q-str)); | ||||
|               ipbuf[(int)(q-str)] = 0; | ||||
|               if (ip_addr(ipbuf, (int)(q - str), &pat.mask.addr.addr4) != 0) | ||||
|                 natural_mask(&pat); | ||||
|             } | ||||
|           else | ||||
|             natural_mask(&pat); | ||||
|  | ||||
|           /* Add this pattern to our list. */ | ||||
|           newsort = realloc(*sortlist, (*nsort + 1) * sizeof(struct apattern)); | ||||
|           if (!newsort) | ||||
|           pat.family = AF_INET; | ||||
|           pat.type = PATTERN_MASK; | ||||
|           if (!sortlist_alloc(sortlist, nsort, &pat)) | ||||
|             return ARES_ENOMEM; | ||||
|           newsort[*nsort] = pat; | ||||
|           *sortlist = newsort; | ||||
|           (*nsort)++; | ||||
|         } | ||||
|       else | ||||
|         { | ||||
| @@ -856,6 +909,7 @@ static int config_sortlist(struct apattern **sortlist, int *nsort, | ||||
|  | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| static int set_search(ares_channel channel, const char *str) | ||||
| { | ||||
| @@ -937,6 +991,7 @@ static int set_options(ares_channel channel, const char *str) | ||||
|   return ARES_SUCCESS; | ||||
| } | ||||
|  | ||||
| #ifndef WIN32 | ||||
| static char *try_config(char *s, const char *opt) | ||||
| { | ||||
|   size_t len; | ||||
| @@ -950,21 +1005,34 @@ static char *try_config(char *s, const char *opt) | ||||
|   return s; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| static const char *try_option(const char *p, const char *q, const char *opt) | ||||
| { | ||||
|   size_t len = strlen(opt); | ||||
|   return ((size_t)(q - p) > len && !strncmp(p, opt, len)) ? &p[len] : NULL; | ||||
| } | ||||
|  | ||||
| static int ip_addr(const char *s, int len, struct in_addr *addr) | ||||
| #ifndef WIN32 | ||||
| static int sortlist_alloc(struct apattern **sortlist, int *nsort, | ||||
|                           struct apattern *pat) | ||||
| { | ||||
|   struct apattern *newsort; | ||||
|   newsort = realloc(*sortlist, (*nsort + 1) * sizeof(struct apattern)); | ||||
|   if (!newsort) | ||||
|     return 0; | ||||
|   newsort[*nsort] = *pat; | ||||
|   *sortlist = newsort; | ||||
|   (*nsort)++; | ||||
|   return 1; | ||||
| } | ||||
|  | ||||
| static int ip_addr(const char *ipbuf, int len, struct in_addr *addr) | ||||
| { | ||||
|   char ipbuf[16]; | ||||
|  | ||||
|   /* Four octets and three periods yields at most 15 characters. */ | ||||
|   if (len > 15) | ||||
|     return -1; | ||||
|   memcpy(ipbuf, s, len); | ||||
|   ipbuf[len] = 0; | ||||
|  | ||||
|   addr->s_addr = inet_addr(ipbuf); | ||||
|   if (addr->s_addr == INADDR_NONE && strcmp(ipbuf, "255.255.255.255") != 0) | ||||
| @@ -979,15 +1047,16 @@ static void natural_mask(struct apattern *pat) | ||||
|   /* Store a host-byte-order copy of pat in a struct in_addr.  Icky, | ||||
|    * but portable. | ||||
|    */ | ||||
|   addr.s_addr = ntohl(pat->addr.s_addr); | ||||
|   addr.s_addr = ntohl(pat->addr.addr4.s_addr); | ||||
|  | ||||
|   /* This is out of date in the CIDR world, but some people might | ||||
|    * still rely on it. | ||||
|    */ | ||||
|   if (IN_CLASSA(addr.s_addr)) | ||||
|     pat->mask.s_addr = htonl(IN_CLASSA_NET); | ||||
|     pat->mask.addr.addr4.s_addr = htonl(IN_CLASSA_NET); | ||||
|   else if (IN_CLASSB(addr.s_addr)) | ||||
|     pat->mask.s_addr = htonl(IN_CLASSB_NET); | ||||
|     pat->mask.addr.addr4.s_addr = htonl(IN_CLASSB_NET); | ||||
|   else | ||||
|     pat->mask.s_addr = htonl(IN_CLASSC_NET); | ||||
|     pat->mask.addr.addr4.s_addr = htonl(IN_CLASSC_NET); | ||||
| } | ||||
| #endif | ||||
|   | ||||
							
								
								
									
										81
									
								
								ares/ares_ipv6.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								ares/ares_ipv6.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #ifndef ARES_IPV6_H | ||||
| #define ARES_IPV6_H | ||||
|  | ||||
| #ifndef HAVE_PF_INET6 | ||||
| #define PF_INET6 AF_INET6 | ||||
| #endif | ||||
|  | ||||
| #ifndef HAVE_STRUCT_IN6_ADDR | ||||
| struct in6_addr | ||||
| { | ||||
|   unsigned char s6_addr[16]; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| #ifndef HAVE_STRUCT_SOCKADDR_IN6 | ||||
| struct sockaddr_in6 | ||||
| { | ||||
|   unsigned short  sin6_family; | ||||
|   unsigned short  sin6_port; | ||||
|   unsigned long   sin6_flowinfo; | ||||
|   struct in6_addr sin6_addr; | ||||
|   unsigned int    sin6_scope_id; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| #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; | ||||
|   struct sockaddr *ai_addr; | ||||
|   struct addrinfo *ai_next; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| #ifndef NS_IN6ADDRSZ | ||||
| #if SIZEOF_STRUCT_IN6_ADDR == 0 | ||||
| /* We cannot have it set to zero, so we pick a fixed value here */ | ||||
| #define NS_IN6ADDRSZ 16 | ||||
| #else | ||||
| #define NS_IN6ADDRSZ SIZEOF_STRUCT_IN6_ADDR | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #ifndef NS_INADDRSZ | ||||
| #define NS_INADDRSZ SIZEOF_STRUCT_IN_ADDR | ||||
| #endif | ||||
|  | ||||
| #ifndef NS_INT16SZ | ||||
| #define NS_INT16SZ 2 | ||||
| #endif | ||||
|  | ||||
| #ifndef IF_NAMESIZE | ||||
| #ifdef IFNAMSIZ | ||||
| #define IF_NAMESIZE IFNAMSIZ | ||||
| #else | ||||
| #define IF_NAMESIZE 256 | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #endif /* ARES_IPV6_H */ | ||||
| @@ -21,6 +21,9 @@ | ||||
| #else | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
|   | ||||
| @@ -24,6 +24,9 @@ | ||||
| #include <arpa/inet.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
|   | ||||
							
								
								
									
										64
									
								
								ares/ares_parse_aaaa_reply.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								ares/ares_parse_aaaa_reply.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .\" Copyright 2005 by Dominick Meglio. | ||||
| .\" | ||||
| .\" Permission to use, copy, modify, and distribute this | ||||
| .\" software and its documentation for any purpose and without | ||||
| .\" fee is hereby granted, provided that the above copyright | ||||
| .\" notice appear in all copies and that both that copyright | ||||
| .\" notice and this permission notice appear in supporting | ||||
| .\" documentation, and that the name of M.I.T. not be used in | ||||
| .\" advertising or publicity pertaining to distribution of the | ||||
| .\" software without specific, written prior permission. | ||||
| .\" M.I.T. makes no representations about the suitability of | ||||
| .\" this software for any purpose.  It is provided "as is" | ||||
| .\" without express or implied warranty. | ||||
| .\" | ||||
| .TH ARES_PARSE_AAAA_REPLY 3 "10 March 2005" | ||||
| .SH NAME | ||||
| ares_parse_aaaa_reply \- Parse a reply to a DNS query of type AAAA into a hostent | ||||
| .SH SYNOPSIS | ||||
| .nf | ||||
| .B #include <ares.h> | ||||
| .PP | ||||
| .B int ares_parse_aaaa_reply(const unsigned char *\fIabuf\fP, int \fIalen\fP, | ||||
| .B 	struct hostent **\fIhost\fP); | ||||
| .fi | ||||
| .SH DESCRIPTION | ||||
| The | ||||
| .B ares_parse_aaaa_reply | ||||
| function parses the response to a query of type AAAA into a | ||||
| .BR "struct hostent" . | ||||
| The parameters | ||||
| .I abuf | ||||
| and | ||||
| .I alen | ||||
| give the contents of the response.  The result is stored in allocated | ||||
| memory and a pointer to it stored into the variable pointed to by | ||||
| .IR host . | ||||
| It is the caller's responsibility to free the resulting host structure | ||||
| using | ||||
| .BR ares_free_hostent (3) | ||||
| when it is no longer needed. | ||||
| .SH RETURN VALUES | ||||
| .B ares_parse_aaaa_reply | ||||
| can return any of the following values: | ||||
| .TP 15 | ||||
| .B ARES_SUCCESS | ||||
| The response was successfully parsed. | ||||
| .TP 15 | ||||
| .B ARES_EBADRESP | ||||
| The response was malformatted. | ||||
| .TP 15 | ||||
| .B ARES_ENODATA | ||||
| The response did not contain an answer to the query. | ||||
| .TP 15 | ||||
| .B ARES_ENOMEM | ||||
| Memory was exhausted. | ||||
| .SH SEE ALSO | ||||
| .BR ares_gethostbyname (3), | ||||
| .BR ares_free_hostent (3) | ||||
| .SH AUTHOR | ||||
| Dominick Meglio | ||||
| .br | ||||
| Copyright 2005 by Dominick Meglio. | ||||
							
								
								
									
										179
									
								
								ares/ares_parse_aaaa_reply.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										179
									
								
								ares/ares_parse_aaaa_reply.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,179 @@ | ||||
| /* Copyright 2005 Dominick Meglio | ||||
|  * | ||||
|  * 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> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/inet.h> | ||||
| #include <netdb.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_H | ||||
| #include <arpa/nameser.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "ares.h" | ||||
| #include "ares_dns.h" | ||||
| #include "inet_net_pton.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| int ares_parse_aaaa_reply(const unsigned char *abuf, int alen, | ||||
|                        struct hostent **host) | ||||
| { | ||||
|   unsigned int qdcount, ancount; | ||||
|   int status, i, rr_type, rr_class, rr_len, naddrs; | ||||
|   int naliases; | ||||
|   long len; | ||||
|   const unsigned char *aptr; | ||||
|   char *hostname, *rr_name, *rr_data, **aliases; | ||||
|   struct in6_addr *addrs; | ||||
|   struct hostent *hostent; | ||||
|  | ||||
|   /* Set *host to NULL for all failure cases. */ | ||||
|   *host = NULL; | ||||
|  | ||||
|   /* Give up if abuf doesn't have room for a header. */ | ||||
|   if (alen < HFIXEDSZ) | ||||
|     return ARES_EBADRESP; | ||||
|  | ||||
|   /* Fetch the question and answer count from the header. */ | ||||
|   qdcount = DNS_HEADER_QDCOUNT(abuf); | ||||
|   ancount = DNS_HEADER_ANCOUNT(abuf); | ||||
|   if (qdcount != 1) | ||||
|     return ARES_EBADRESP; | ||||
|  | ||||
|   /* Expand the name from the question, and skip past the question. */ | ||||
|   aptr = abuf + HFIXEDSZ; | ||||
|   status = ares_expand_name(aptr, abuf, alen, &hostname, &len); | ||||
|   if (status != ARES_SUCCESS) | ||||
|     return status; | ||||
|   if (aptr + len + QFIXEDSZ > abuf + alen) | ||||
|     { | ||||
|       free(hostname); | ||||
|       return ARES_EBADRESP; | ||||
|     } | ||||
|   aptr += len + QFIXEDSZ; | ||||
|  | ||||
|   /* Allocate addresses and aliases; ancount gives an upper bound for both. */ | ||||
|   addrs = malloc(ancount * sizeof(struct in6_addr)); | ||||
|   if (!addrs) | ||||
|     { | ||||
|       free(hostname); | ||||
|       return ARES_ENOMEM; | ||||
|     } | ||||
|   aliases = malloc((ancount + 1) * sizeof(char *)); | ||||
|   if (!aliases) | ||||
|     { | ||||
|       free(hostname); | ||||
|       free(addrs); | ||||
|       return ARES_ENOMEM; | ||||
|     } | ||||
|   naddrs = 0; | ||||
|   naliases = 0; | ||||
|  | ||||
|   /* Examine each answer resource record (RR) in turn. */ | ||||
|   for (i = 0; i < (int)ancount; i++) | ||||
|     { | ||||
|       /* Decode the RR up to the data field. */ | ||||
|       status = ares_expand_name(aptr, abuf, alen, &rr_name, &len); | ||||
|       if (status != ARES_SUCCESS) | ||||
|         break; | ||||
|       aptr += len; | ||||
|       if (aptr + RRFIXEDSZ > abuf + alen) | ||||
|         { | ||||
|           status = ARES_EBADRESP; | ||||
|           break; | ||||
|         } | ||||
|       rr_type = DNS_RR_TYPE(aptr); | ||||
|       rr_class = DNS_RR_CLASS(aptr); | ||||
|       rr_len = DNS_RR_LEN(aptr); | ||||
|       aptr += RRFIXEDSZ; | ||||
|  | ||||
|       if (rr_class == C_IN && rr_type == T_AAAA | ||||
|           && rr_len == sizeof(struct in6_addr) | ||||
|           && strcasecmp(rr_name, hostname) == 0) | ||||
|         { | ||||
|           memcpy(&addrs[naddrs], aptr, sizeof(struct in6_addr)); | ||||
|           naddrs++; | ||||
|           status = ARES_SUCCESS; | ||||
|         } | ||||
|  | ||||
|       if (rr_class == C_IN && rr_type == T_CNAME) | ||||
|         { | ||||
|           /* Record the RR name as an alias. */ | ||||
|           aliases[naliases] = rr_name; | ||||
|           naliases++; | ||||
|  | ||||
|           /* Decode the RR data and replace the hostname with it. */ | ||||
|           status = ares_expand_name(aptr, abuf, alen, &rr_data, &len); | ||||
|           if (status != ARES_SUCCESS) | ||||
|             break; | ||||
|           free(hostname); | ||||
|           hostname = rr_data; | ||||
|         } | ||||
|       else | ||||
|         free(rr_name); | ||||
|  | ||||
|       aptr += rr_len; | ||||
|       if (aptr > abuf + alen) | ||||
|         { | ||||
|           status = ARES_EBADRESP; | ||||
|           break; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   if (status == ARES_SUCCESS && naddrs == 0) | ||||
|     status = ARES_ENODATA; | ||||
|   if (status == ARES_SUCCESS) | ||||
|     { | ||||
|       /* We got our answer.  Allocate memory to build the host entry. */ | ||||
|       aliases[naliases] = NULL; | ||||
|       hostent = malloc(sizeof(struct hostent)); | ||||
|       if (hostent) | ||||
|         { | ||||
|           hostent->h_addr_list = malloc((naddrs + 1) * sizeof(char *)); | ||||
|           if (hostent->h_addr_list) | ||||
|             { | ||||
|               /* Fill in the hostent and return successfully. */ | ||||
|               hostent->h_name = hostname; | ||||
|               hostent->h_aliases = aliases; | ||||
|               hostent->h_addrtype = AF_INET6; | ||||
|               hostent->h_length = sizeof(struct in6_addr); | ||||
|               for (i = 0; i < naddrs; i++) | ||||
|                 hostent->h_addr_list[i] = (char *) &addrs[i]; | ||||
|               hostent->h_addr_list[naddrs] = NULL; | ||||
|               *host = hostent; | ||||
|               return ARES_SUCCESS; | ||||
|             } | ||||
|           free(hostent); | ||||
|         } | ||||
|       status = ARES_ENOMEM; | ||||
|     } | ||||
|   for (i = 0; i < naliases; i++) | ||||
|     free(aliases[i]); | ||||
|   free(aliases); | ||||
|   free(addrs); | ||||
|   free(hostname); | ||||
|   return status; | ||||
| } | ||||
| @@ -23,6 +23,9 @@ | ||||
| #include <netinet/in.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
|   | ||||
| @@ -33,6 +33,10 @@ | ||||
| #define writev(s,v,c)     writev_s(s,v,c) | ||||
| #endif | ||||
|  | ||||
| #ifdef NETWARE | ||||
| #include <time.h> | ||||
| #endif | ||||
|  | ||||
| #define DEFAULT_TIMEOUT         5 | ||||
| #define DEFAULT_TRIES           4 | ||||
| #ifndef INADDR_NONE | ||||
| @@ -69,6 +73,8 @@ | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #include "ares_ipv6.h" | ||||
|  | ||||
| struct send_request { | ||||
|   /* Remaining data to send */ | ||||
|   const unsigned char *data; | ||||
| @@ -124,9 +130,23 @@ struct query { | ||||
| }; | ||||
|  | ||||
| /* An IP address pattern; matches an IP address X if X & mask == addr */ | ||||
| #define PATTERN_MASK 0x1 | ||||
| #define PATTERN_CIDR 0x2 | ||||
|  | ||||
| union ares_addr { | ||||
|   struct in_addr addr4; | ||||
|   struct in6_addr addr6; | ||||
| }; | ||||
|  | ||||
| struct apattern { | ||||
|   struct in_addr addr; | ||||
|   struct in_addr mask; | ||||
|   union ares_addr addr; | ||||
|   union | ||||
|   { | ||||
|     union ares_addr addr; | ||||
|     unsigned short bits; | ||||
|   } mask; | ||||
|   int family; | ||||
|   unsigned short type; | ||||
| }; | ||||
|  | ||||
| struct ares_channeldata { | ||||
| @@ -156,7 +176,7 @@ struct ares_channeldata { | ||||
|  | ||||
| void ares__send_query(ares_channel channel, struct query *query, time_t now); | ||||
| void ares__close_sockets(struct server_state *server); | ||||
| int ares__get_hostent(FILE *fp, struct hostent **host); | ||||
| int ares__get_hostent(FILE *fp, int family, struct hostent **host); | ||||
| int ares__read_line(FILE *fp, char **buf, int *bufsize); | ||||
|  | ||||
| #ifdef CURLDEBUG | ||||
| @@ -164,9 +184,5 @@ int ares__read_line(FILE *fp, char **buf, int *bufsize); | ||||
|    libcurl lowlevel code from within library is ugly and only works when | ||||
|    c-ares is built and linked with a similarly debug-build libcurl, but we do | ||||
|    this anyway for convenience. */ | ||||
| #ifndef CURL_EXTERN | ||||
| /* ugly hack to make this compile */ | ||||
| #define CURL_EXTERN | ||||
| #endif | ||||
| #include "../lib/memdebug.h" | ||||
| #endif | ||||
|   | ||||
| @@ -27,9 +27,18 @@ | ||||
| #include <netinet/in.h> | ||||
| #include <netdb.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #ifdef HAVE_UNISTD_H | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| #ifdef HAVE_SYS_IOCTL_H | ||||
| #include <sys/ioctl.h> | ||||
| #endif | ||||
| #ifdef NETWARE | ||||
| #include <sys/filio.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <string.h> | ||||
| @@ -42,6 +51,11 @@ | ||||
| #include "ares_dns.h" | ||||
| #include "ares_private.h" | ||||
|  | ||||
| #ifndef TRUE | ||||
| /* at least Solaris 7 does not have TRUE at this point */ | ||||
| #define TRUE 1 | ||||
| #endif | ||||
|  | ||||
| #if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS) | ||||
| #define GET_ERRNO()  WSAGetLastError() | ||||
| #else | ||||
| @@ -463,10 +477,77 @@ void ares__send_query(ares_channel channel, struct query *query, time_t now) | ||||
|     } | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * nonblock() set the given socket to either blocking or non-blocking mode | ||||
|  * based on the 'nonblock' boolean argument. This function is highly portable. | ||||
|  */ | ||||
| static int nonblock(ares_socket_t sockfd,    /* operate on this */ | ||||
|                     int nonblock   /* TRUE or FALSE */) | ||||
| { | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 0 | ||||
| #ifdef HAVE_O_NONBLOCK | ||||
|   /* most recent unix versions */ | ||||
|   int flags; | ||||
|  | ||||
|   flags = fcntl(sockfd, F_GETFL, 0); | ||||
|   if (TRUE == nonblock) | ||||
|     return fcntl(sockfd, F_SETFL, flags | O_NONBLOCK); | ||||
|   else | ||||
|     return fcntl(sockfd, F_SETFL, flags & (~O_NONBLOCK)); | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 1 | ||||
| #endif | ||||
|  | ||||
| #if defined(HAVE_FIONBIO) && (SETBLOCK == 0) | ||||
|   /* older unix versions */ | ||||
|   int flags; | ||||
|  | ||||
|   flags = nonblock; | ||||
|   return ioctl(sockfd, FIONBIO, &flags); | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 2 | ||||
| #endif | ||||
|  | ||||
| #if defined(HAVE_IOCTLSOCKET) && (SETBLOCK == 0) | ||||
|   /* Windows? */ | ||||
|   unsigned long flags; | ||||
|   flags = nonblock; | ||||
|  | ||||
|   return ioctlsocket(sockfd, FIONBIO, &flags); | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 3 | ||||
| #endif | ||||
|  | ||||
| #if defined(HAVE_IOCTLSOCKET_CASE) && (SETBLOCK == 0) | ||||
|   /* presumably for Amiga */ | ||||
|   return IoctlSocket(sockfd, FIONBIO, (long)nonblock); | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 4 | ||||
| #endif | ||||
|  | ||||
| #if defined(HAVE_SO_NONBLOCK) && (SETBLOCK == 0) | ||||
|   /* BeOS */ | ||||
|   long b = nonblock ? 1 : 0; | ||||
|   return setsockopt(sockfd, SOL_SOCKET, SO_NONBLOCK, &b, sizeof(b)); | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 5 | ||||
| #endif | ||||
|  | ||||
| #ifdef HAVE_DISABLED_NONBLOCKING | ||||
|   return 0; /* returns success */ | ||||
| #undef SETBLOCK | ||||
| #define SETBLOCK 6 | ||||
| #endif | ||||
|  | ||||
| #if (SETBLOCK == 0) | ||||
| #error "no non-blocking method was found/used/set" | ||||
| #endif | ||||
| } | ||||
|  | ||||
| static int open_tcp_socket(ares_channel channel, struct server_state *server) | ||||
| { | ||||
|   ares_socket_t s; | ||||
|   int flags; | ||||
|   struct sockaddr_in sockin; | ||||
|  | ||||
|   /* Acquire a socket. */ | ||||
| @@ -475,25 +556,7 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) | ||||
|     return -1; | ||||
|  | ||||
|   /* Set the socket non-blocking. */ | ||||
|  | ||||
| #if defined(WIN32) || defined(WATT32) | ||||
|   flags = 1; | ||||
|   ioctlsocket(s, FIONBIO, &flags); | ||||
| #else | ||||
|   flags = fcntl(s, F_GETFL, 0); | ||||
|  | ||||
|   if (flags == -1) | ||||
|     { | ||||
|       closesocket(s); | ||||
|       return -1; | ||||
|     } | ||||
|   flags |= O_NONBLOCK; | ||||
|   if (fcntl(s, F_SETFL, flags) == -1) | ||||
|     { | ||||
|       closesocket(s); | ||||
|       return -1; | ||||
|     } | ||||
| #endif | ||||
|   nonblock(s, TRUE); | ||||
|  | ||||
|   /* Connect to the server. */ | ||||
|   memset(&sockin, 0, sizeof(sockin)); | ||||
| @@ -524,6 +587,9 @@ static int open_udp_socket(ares_channel channel, struct server_state *server) | ||||
|   if (s == ARES_SOCKET_BAD) | ||||
|     return -1; | ||||
|  | ||||
|   /* Set the socket non-blocking. */ | ||||
|   nonblock(s, TRUE); | ||||
|  | ||||
|   /* Connect to the server. */ | ||||
|   memset(&sockin, 0, sizeof(sockin)); | ||||
|   sockin.sin_family = AF_INET; | ||||
|   | ||||
| @@ -21,6 +21,9 @@ | ||||
| #else | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
|   | ||||
| @@ -21,6 +21,9 @@ | ||||
| #else | ||||
| #include <netinet/in.h> | ||||
| #include <arpa/nameser.h> | ||||
| #ifdef HAVE_ARPA_NAMESER_COMPAT_H | ||||
| #include <arpa/nameser_compat.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
|   | ||||
| @@ -38,7 +38,8 @@ const char *ares_strerror(int code) | ||||
|     "Error reading file", | ||||
|     "Out of memory", | ||||
|     "Channel is being destroyed", | ||||
|     "Misformatted string" | ||||
|     "Misformatted string", | ||||
|     "Illegal flags specified" | ||||
|   }; | ||||
|  | ||||
|   assert(code >= 0 && code < (int)(sizeof(errtext) / sizeof(*errtext))); | ||||
|   | ||||
| @@ -4,12 +4,12 @@ | ||||
| #define ARES__VERSION_H | ||||
|  | ||||
| #define ARES_VERSION_MAJOR 1 | ||||
| #define ARES_VERSION_MINOR 2 | ||||
| #define ARES_VERSION_MINOR 3 | ||||
| #define ARES_VERSION_PATCH 0 | ||||
| #define ARES_VERSION ((ARES_VERSION_MAJOR<<16)|\ | ||||
|                        (ARES_VERSION_MINOR<<8)|\ | ||||
|                        (ARES_VERSION_PATCH)) | ||||
| #define ARES_VERSION_STR "1.2.0" | ||||
| #define ARES_VERSION_STR "1.3.0" | ||||
|  | ||||
| const char *ares_version(int *version); | ||||
|  | ||||
|   | ||||
							
								
								
									
										60
									
								
								ares/bitncmp.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								ares/bitncmp.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| /* | ||||
|  * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") | ||||
|  * Copyright (c) 1996,1999 by Internet Software Consortium. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT | ||||
|  * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #ifndef HAVE_BITNCMP | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include "bitncmp.h" | ||||
|  | ||||
| /* | ||||
|  * int | ||||
|  * bitncmp(l, r, n) | ||||
|  *	compare bit masks l and r, for n bits. | ||||
|  * return: | ||||
|  *	-1, 1, or 0 in the libc tradition. | ||||
|  * note: | ||||
|  *	network byte order assumed.  this means 192.5.5.240/28 has | ||||
|  *	0x11110000 in its fourth octet. | ||||
|  * author: | ||||
|  *	Paul Vixie (ISC), June 1996 | ||||
|  */ | ||||
| int | ||||
| ares_bitncmp(const void *l, const void *r, int n) { | ||||
| 	unsigned int lb, rb; | ||||
| 	int x, b; | ||||
|  | ||||
| 	b = n / 8; | ||||
| 	x = memcmp(l, r, b); | ||||
| 	if (x) | ||||
| 		return (x); | ||||
|  | ||||
| 	lb = ((const unsigned char *)l)[b]; | ||||
| 	rb = ((const unsigned char *)r)[b]; | ||||
| 	for (b = n % 8; b > 0; b--) { | ||||
| 		if ((lb & 0x80) != (rb & 0x80)) { | ||||
| 			if (lb & 0x80) | ||||
| 				return (1); | ||||
| 			return (-1); | ||||
| 		} | ||||
| 		lb <<= 1; | ||||
| 		rb <<= 1; | ||||
| 	} | ||||
| 	return (0); | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										26
									
								
								ares/bitncmp.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								ares/bitncmp.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #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 */ | ||||
| @@ -1,7 +1,7 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| libtoolize --copy --automake --force | ||||
| aclocal | ||||
| autoheader | ||||
| autoconf | ||||
| automake --add-missing | ||||
| ${LIBTOOLIZE:-libtoolize} --copy --automake --force | ||||
| ${ACLOCAL:-aclocal} | ||||
| ${AUTOHEADER:-autoheader} | ||||
| ${AUTOCONF:-autoconf} | ||||
| ${AUTOMAKE:-automake} --add-missing | ||||
|   | ||||
| @@ -41,6 +41,10 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]), | ||||
|     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]) | ||||
|  | ||||
|     CPPFLAGS="$CPPFLAGS -DCURLDEBUG -I$srcdir/../include" | ||||
|     CFLAGS="$CFLAGS -g"  | ||||
|  | ||||
| @@ -61,6 +65,295 @@ AC_CHECK_HEADERS( | ||||
|        sys/time.h \ | ||||
|        sys/select.h \ | ||||
|        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, , , | ||||
| [ | ||||
| #ifdef HAVE_SYS_TYPES_H | ||||
| #include <sys/types.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. | ||||
| #ifdef HAVE_ARPA_NAMESER_H | ||||
| #include <arpa/nameser.h> | ||||
| #endif | ||||
|  | ||||
| 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> | ||||
| #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 check for AF_INET6 | ||||
| CARES_CHECK_CONSTANT( | ||||
|   [ | ||||
| #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.]) | ||||
| ) | ||||
|  | ||||
| dnl check for PF_INET6 | ||||
| CARES_CHECK_CONSTANT( | ||||
|   [ | ||||
| #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.]) | ||||
| ) | ||||
|  | ||||
|  | ||||
| dnl check for the in6_addr structure | ||||
| CARES_CHECK_STRUCT( | ||||
|   [ | ||||
| #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 | ||||
|   ], [in6_addr],  | ||||
|      AC_DEFINE_UNQUOTED(HAVE_STRUCT_IN6_ADDR,1,[Define to 1 if you have struct in6_addr.]) | ||||
| ) | ||||
|  | ||||
| dnl check for the sockaddr_in6 structure | ||||
| CARES_CHECK_STRUCT( | ||||
|   [ | ||||
| #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 | ||||
|   ], [sockaddr_in6],  | ||||
|      AC_DEFINE_UNQUOTED(HAVE_STRUCT_SOCKADDR_IN6,1, | ||||
|        [Define to 1 if you have struct sockaddr_in6.]) ac_have_sockaddr_in6=yes | ||||
| ) | ||||
|  | ||||
| AC_CHECK_MEMBER(struct sockaddr_in6.sin6_scope_id, | ||||
|     AC_DEFINE_UNQUOTED(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID,1, | ||||
|       [Define to 1 if your struct sockaddr_in6 has sin6_scope_id.]) | ||||
|    , , | ||||
|   [ | ||||
| #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 | ||||
|   ]) | ||||
|  | ||||
| dnl check for the addrinfo structure | ||||
| AC_CHECK_MEMBER(struct addrinfo.ai_flags, | ||||
|      AC_DEFINE_UNQUOTED(HAVE_STRUCT_ADDRINFO,1, | ||||
|        [Define to 1 if you have struct addrinfo.]),, | ||||
|   [ | ||||
| #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 | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETDB_H | ||||
| #include <netdb.h> | ||||
| #endif | ||||
|   ] | ||||
| ) | ||||
|  | ||||
| dnl check for inet_pton | ||||
| AC_CHECK_FUNCS(inet_pton) | ||||
| dnl Some systems have it, but not IPv6 | ||||
| if test "$ac_cv_func_inet_pton" = "yes" ; then | ||||
| AC_MSG_CHECKING(if inet_pton supports IPv6) | ||||
| AC_TRY_RUN( | ||||
|   [ | ||||
| #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 | ||||
| int main() | ||||
|   { | ||||
|     struct in6_addr addr6; | ||||
|     if (inet_pton(AF_INET6, "::1", &addr6) < 1) | ||||
|       exit(1); | ||||
|     else | ||||
|       exit(0); | ||||
|   } | ||||
|   ], [ | ||||
|        AC_MSG_RESULT(yes) | ||||
|        AC_DEFINE_UNQUOTED(HAVE_INET_PTON_IPV6,1,[Define to 1 if inet_pton supports IPv6.]) | ||||
|      ], AC_MSG_RESULT(no),AC_MSG_RESULT(no)) | ||||
| fi | ||||
| dnl Check for inet_net_pton | ||||
| AC_CHECK_FUNCS(inet_net_pton) | ||||
| dnl Again, some systems have it, but not IPv6 | ||||
| if test "$ac_cv_func_inet_net_pton" = "yes" ; then | ||||
| AC_MSG_CHECKING(if inet_net_pton supports IPv6) | ||||
| AC_TRY_RUN( | ||||
|   [ | ||||
| #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 | ||||
| int main() | ||||
|   { | ||||
|     struct in6_addr addr6; | ||||
|     if (inet_net_pton(AF_INET6, "::1", &addr6, sizeof(addr6)) < 1) | ||||
|       exit(1); | ||||
|     else | ||||
|       exit(0); | ||||
|   } | ||||
|   ], [ | ||||
|        AC_MSG_RESULT(yes) | ||||
|        AC_DEFINE_UNQUOTED(HAVE_INET_NET_PTON_IPV6,1,[Define to 1 if inet_net_pton supports IPv6.]) | ||||
|      ], AC_MSG_RESULT(no),AC_MSG_RESULT(no)) | ||||
| fi | ||||
|  | ||||
|  | ||||
| dnl Check for inet_ntop | ||||
| AC_CHECK_FUNCS(inet_ntop) | ||||
| dnl Again, some systems have it, but not IPv6 | ||||
| if test "$ac_cv_func_inet_ntop" = "yes" ; then | ||||
| AC_MSG_CHECKING(if inet_ntop supports IPv6) | ||||
| AC_TRY_RUN( | ||||
|   [ | ||||
| #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 | ||||
| #include <errno.h> | ||||
| int main() | ||||
|   { | ||||
|     struct in6_addr addr6; | ||||
|     char buf[128]; | ||||
|     if (inet_ntop(AF_INET6, &addr6, buf, 128) == 0 && errno == EAFNOSUPPORT) | ||||
|       exit(1); | ||||
|     else | ||||
|       exit(0); | ||||
|   } | ||||
|   ], [ | ||||
|        AC_MSG_RESULT(yes) | ||||
|        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, , | ||||
| [ | ||||
| #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 | ||||
| ] | ||||
| ) | ||||
| AC_CHECK_SIZEOF(struct in_addr, , | ||||
| [ | ||||
| #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 | ||||
| ] | ||||
| ) | ||||
|  | ||||
| AC_CHECK_FUNCS([bitncmp if_indextoname]) | ||||
|  | ||||
| dnl God bless non-standardized functions! We need to see which getservbyport_r variant is available | ||||
| CARES_CHECK_GETSERVBYPORT_R | ||||
|  | ||||
| CURL_CHECK_NONBLOCKING_SOCKET | ||||
|  | ||||
| AC_OUTPUT(Makefile) | ||||
|   | ||||
							
								
								
									
										439
									
								
								ares/inet_net_pton.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										439
									
								
								ares/inet_net_pton.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,439 @@ | ||||
| /* | ||||
|  * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") | ||||
|  * Copyright (c) 1996,1999 by Internet Software Consortium. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT | ||||
|  * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
|  | ||||
|  | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
|  | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_NAMESER_H | ||||
| #include <arpa/nameser.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| #include "ares_ipv6.h" | ||||
| #include "inet_net_pton.h" | ||||
|  | ||||
| #if !defined(HAVE_INET_NET_PTON) || !defined(HAVE_INET_NET_PTON_IPV6) || \ | ||||
|     !defined(HAVE_INET_PTON) || !defined(HAVE_INET_PTON_IPV6) | ||||
|  | ||||
| /* | ||||
|  * static int | ||||
|  * inet_net_pton_ipv4(src, dst, size) | ||||
|  *      convert IPv4 network number from presentation to network format. | ||||
|  *      accepts hex octets, hex strings, decimal octets, and /CIDR. | ||||
|  *      "size" is in bytes and describes "dst". | ||||
|  * return: | ||||
|  *      number of bits, either imputed classfully or specified with /CIDR, | ||||
|  *      or -1 if some failure occurred (check errno).  ENOENT means it was | ||||
|  *      not an IPv4 network specification. | ||||
|  * note: | ||||
|  *      network byte order assumed.  this means 192.5.5.240/28 has | ||||
|  *      0b11110000 in its fourth octet. | ||||
|  * author: | ||||
|  *      Paul Vixie (ISC), June 1996 | ||||
|  */ | ||||
| static int | ||||
| inet_net_pton_ipv4(const char *src, unsigned char *dst, size_t size) | ||||
| { | ||||
|   static const char xdigits[] = "0123456789abcdef"; | ||||
|   static const char digits[] = "0123456789"; | ||||
|   int n, ch, tmp = 0, dirty, bits; | ||||
|   const unsigned char *odst = dst; | ||||
|  | ||||
|   ch = *src++; | ||||
|   if (ch == '0' && (src[0] == 'x' || src[0] == 'X') | ||||
|       && isascii((unsigned char)(src[1])) | ||||
|       && isxdigit((unsigned char)(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)) { | ||||
|       if (isupper(ch)) | ||||
|         ch = tolower(ch); | ||||
|       n = (int)(strchr(xdigits, ch) - xdigits); | ||||
|       if (dirty == 0) | ||||
|         tmp = n; | ||||
|       else | ||||
|         tmp = (tmp << 4) | n; | ||||
|       if (++dirty == 2) { | ||||
|         if (size-- <= 0U) | ||||
|           goto emsgsize; | ||||
|         *dst++ = (unsigned char) tmp; | ||||
|         dirty = 0; | ||||
|       } | ||||
|     } | ||||
|     if (dirty) {  /* Odd trailing nybble? */ | ||||
|       if (size-- <= 0U) | ||||
|         goto emsgsize; | ||||
|       *dst++ = (unsigned char) (tmp << 4); | ||||
|     } | ||||
|   } else if (isascii(ch) && isdigit(ch)) { | ||||
|     /* Decimal: eat dotted digit string. */ | ||||
|     for (;;) { | ||||
|       tmp = 0; | ||||
|       do { | ||||
|         n = (int)(strchr(digits, ch) - digits); | ||||
|         tmp *= 10; | ||||
|         tmp += n; | ||||
|         if (tmp > 255) | ||||
|           goto enoent; | ||||
|       } while ((ch = *src++) != '\0' && | ||||
|                isascii(ch) && isdigit(ch)); | ||||
|       if (size-- <= 0U) | ||||
|         goto emsgsize; | ||||
|       *dst++ = (unsigned char) tmp; | ||||
|       if (ch == '\0' || ch == '/') | ||||
|         break; | ||||
|       if (ch != '.') | ||||
|         goto enoent; | ||||
|       ch = *src++; | ||||
|       if (!isascii(ch) || !isdigit(ch)) | ||||
|         goto enoent; | ||||
|     } | ||||
|   } else | ||||
|     goto enoent; | ||||
|  | ||||
|   bits = -1; | ||||
|   if (ch == '/' && isascii((unsigned char)(src[0])) && | ||||
|       isdigit((unsigned char)(src[0])) && dst > odst) { | ||||
|     /* CIDR width specifier.  Nothing can follow it. */ | ||||
|     ch = *src++;    /* Skip over the /. */ | ||||
|     bits = 0; | ||||
|     do { | ||||
|       n = (int)(strchr(digits, ch) - digits); | ||||
|       bits *= 10; | ||||
|       bits += n; | ||||
|     } while ((ch = *src++) != '\0' && isascii(ch) && isdigit(ch)); | ||||
|     if (ch != '\0') | ||||
|       goto enoent; | ||||
|     if (bits > 32) | ||||
|       goto emsgsize; | ||||
|   } | ||||
|  | ||||
|   /* Firey death and destruction unless we prefetched EOS. */ | ||||
|   if (ch != '\0') | ||||
|     goto enoent; | ||||
|  | ||||
|   /* If nothing was written to the destination, we found no address. */ | ||||
|   if (dst == odst) | ||||
|     goto enoent; | ||||
|   /* If no CIDR spec was given, infer width from net class. */ | ||||
|   if (bits == -1) { | ||||
|     if (*odst >= 240)       /* Class E */ | ||||
|       bits = 32; | ||||
|     else if (*odst >= 224)  /* Class D */ | ||||
|       bits = 8; | ||||
|     else if (*odst >= 192)  /* Class C */ | ||||
|       bits = 24; | ||||
|     else if (*odst >= 128)  /* Class B */ | ||||
|       bits = 16; | ||||
|     else                    /* Class A */ | ||||
|       bits = 8; | ||||
|     /* If imputed mask is narrower than specified octets, widen. */ | ||||
|     if (bits < ((dst - odst) * 8)) | ||||
|       bits = (int)(dst - odst) * 8; | ||||
|     /* | ||||
|      * If there are no additional bits specified for a class D | ||||
|      * address adjust bits to 4. | ||||
|      */ | ||||
|     if (bits == 8 && *odst == 224) | ||||
|       bits = 4; | ||||
|   } | ||||
|   /* Extend network to cover the actual mask. */ | ||||
|   while (bits > ((dst - odst) * 8)) { | ||||
|     if (size-- <= 0U) | ||||
|       goto emsgsize; | ||||
|     *dst++ = '\0'; | ||||
|   } | ||||
|   return (bits); | ||||
|  | ||||
|   enoent: | ||||
|   errno = ENOENT; | ||||
|   return (-1); | ||||
|  | ||||
|   emsgsize: | ||||
|   errno = EMSGSIZE; | ||||
|   return (-1); | ||||
| } | ||||
|  | ||||
| static int | ||||
| getbits(const char *src, int *bitsp) | ||||
| { | ||||
|   static const char digits[] = "0123456789"; | ||||
|   int n; | ||||
|   int val; | ||||
|   char ch; | ||||
|  | ||||
|   val = 0; | ||||
|   n = 0; | ||||
|   while ((ch = *src++) != '\0') { | ||||
|     const char *pch; | ||||
|  | ||||
|     pch = strchr(digits, ch); | ||||
|     if (pch != NULL) { | ||||
|       if (n++ != 0 && val == 0)       /* no leading zeros */ | ||||
|         return (0); | ||||
|       val *= 10; | ||||
|       val += (pch - digits); | ||||
|       if (val > 128)                  /* range */ | ||||
|         return (0); | ||||
|       continue; | ||||
|     } | ||||
|     return (0); | ||||
|   } | ||||
|   if (n == 0) | ||||
|     return (0); | ||||
|   *bitsp = val; | ||||
|   return (1); | ||||
| } | ||||
|  | ||||
| static int | ||||
| getv4(const char *src, unsigned char *dst, int *bitsp) | ||||
| { | ||||
|   static const char digits[] = "0123456789"; | ||||
|   unsigned char *odst = dst; | ||||
|   int n; | ||||
|   unsigned int val; | ||||
|   char ch; | ||||
|  | ||||
|   val = 0; | ||||
|   n = 0; | ||||
|   while ((ch = *src++) != '\0') { | ||||
|     const char *pch; | ||||
|  | ||||
|     pch = strchr(digits, ch); | ||||
|     if (pch != NULL) { | ||||
|       if (n++ != 0 && val == 0)       /* no leading zeros */ | ||||
|         return (0); | ||||
|       val *= 10; | ||||
|       val += (pch - digits); | ||||
|       if (val > 255)                  /* range */ | ||||
|         return (0); | ||||
|       continue; | ||||
|     } | ||||
|     if (ch == '.' || ch == '/') { | ||||
|       if (dst - odst > 3)             /* too many octets? */ | ||||
|         return (0); | ||||
|       *dst++ = val; | ||||
|       if (ch == '/') | ||||
|         return (getbits(src, bitsp)); | ||||
|       val = 0; | ||||
|       n = 0; | ||||
|       continue; | ||||
|     } | ||||
|     return (0); | ||||
|   } | ||||
|   if (n == 0) | ||||
|     return (0); | ||||
|   if (dst - odst > 3)             /* too many octets? */ | ||||
|     return (0); | ||||
|   *dst++ = val; | ||||
|   return (1); | ||||
| } | ||||
|  | ||||
| static int | ||||
| inet_net_pton_ipv6(const char *src, unsigned char *dst, size_t size) | ||||
| { | ||||
|   static const char xdigits_l[] = "0123456789abcdef", | ||||
|     xdigits_u[] = "0123456789ABCDEF"; | ||||
|   unsigned char tmp[NS_IN6ADDRSZ], *tp, *endp, *colonp; | ||||
|   const char *xdigits, *curtok; | ||||
|   int ch, saw_xdigit; | ||||
|   unsigned int val; | ||||
|   int digits; | ||||
|   int bits; | ||||
|   size_t bytes; | ||||
|   int words; | ||||
|   int ipv4; | ||||
|  | ||||
|   memset((tp = tmp), '\0', NS_IN6ADDRSZ); | ||||
|   endp = tp + NS_IN6ADDRSZ; | ||||
|   colonp = NULL; | ||||
|   /* Leading :: requires some special handling. */ | ||||
|   if (*src == ':') | ||||
|     if (*++src != ':') | ||||
|       goto enoent; | ||||
|   curtok = src; | ||||
|   saw_xdigit = 0; | ||||
|   val = 0; | ||||
|   digits = 0; | ||||
|   bits = -1; | ||||
|   ipv4 = 0; | ||||
|   while ((ch = *src++) != '\0') { | ||||
|     const char *pch; | ||||
|  | ||||
|     if ((pch = strchr((xdigits = xdigits_l), ch)) == NULL) | ||||
|       pch = strchr((xdigits = xdigits_u), ch); | ||||
|     if (pch != NULL) { | ||||
|       val <<= 4; | ||||
|       val |= (pch - xdigits); | ||||
|       if (++digits > 4) | ||||
|         goto enoent; | ||||
|       saw_xdigit = 1; | ||||
|       continue; | ||||
|     } | ||||
|     if (ch == ':') { | ||||
|       curtok = src; | ||||
|       if (!saw_xdigit) { | ||||
|         if (colonp) | ||||
|           goto enoent; | ||||
|         colonp = tp; | ||||
|         continue; | ||||
|       } else if (*src == '\0') | ||||
|         goto enoent; | ||||
|       if (tp + NS_INT16SZ > endp) | ||||
|         return (0); | ||||
|       *tp++ = (unsigned char) (val >> 8) & 0xff; | ||||
|       *tp++ = (unsigned char) val & 0xff; | ||||
|       saw_xdigit = 0; | ||||
|       digits = 0; | ||||
|       val = 0; | ||||
|       continue; | ||||
|     } | ||||
|     if (ch == '.' && ((tp + NS_INADDRSZ) <= endp) && | ||||
|         getv4(curtok, tp, &bits) > 0) { | ||||
|       tp += NS_INADDRSZ; | ||||
|       saw_xdigit = 0; | ||||
|       ipv4 = 1; | ||||
|       break;  /* '\0' was seen by inet_pton4(). */ | ||||
|     } | ||||
|     if (ch == '/' && getbits(src, &bits) > 0) | ||||
|       break; | ||||
|     goto enoent; | ||||
|   } | ||||
|   if (saw_xdigit) { | ||||
|     if (tp + NS_INT16SZ > endp) | ||||
|       goto enoent; | ||||
|     *tp++ = (unsigned char) (val >> 8) & 0xff; | ||||
|     *tp++ = (unsigned char) val & 0xff; | ||||
|   } | ||||
|   if (bits == -1) | ||||
|     bits = 128; | ||||
|  | ||||
|   words = (bits + 15) / 16; | ||||
|   if (words < 2) | ||||
|     words = 2; | ||||
|   if (ipv4) | ||||
|     words = 8; | ||||
|   endp =  tmp + 2 * words; | ||||
|  | ||||
|   if (colonp != NULL) { | ||||
|     /* | ||||
|      * Since some memmove()'s erroneously fail to handle | ||||
|      * overlapping regions, we'll do the shift by hand. | ||||
|      */ | ||||
|     const int n = (int)(tp - colonp); | ||||
|     int i; | ||||
|  | ||||
|     if (tp == endp) | ||||
|       goto enoent; | ||||
|     for (i = 1; i <= n; i++) { | ||||
|       endp[- i] = colonp[n - i]; | ||||
|       colonp[n - i] = 0; | ||||
|     } | ||||
|     tp = endp; | ||||
|   } | ||||
|   if (tp != endp) | ||||
|     goto enoent; | ||||
|  | ||||
|   bytes = (bits + 7) / 8; | ||||
|   if (bytes > size) | ||||
|     goto emsgsize; | ||||
|   memcpy(dst, tmp, bytes); | ||||
|   return (bits); | ||||
|  | ||||
|   enoent: | ||||
|   errno = ENOENT; | ||||
|   return (-1); | ||||
|  | ||||
|   emsgsize: | ||||
|   errno = EMSGSIZE; | ||||
|   return (-1); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * int | ||||
|  * inet_net_pton(af, src, dst, size) | ||||
|  *      convert network number from presentation to network format. | ||||
|  *      accepts hex octets, hex strings, decimal octets, and /CIDR. | ||||
|  *      "size" is in bytes and describes "dst". | ||||
|  * return: | ||||
|  *      number of bits, either imputed classfully or specified with /CIDR, | ||||
|  *      or -1 if some failure occurred (check errno).  ENOENT means it was | ||||
|  *      not a valid network specification. | ||||
|  * author: | ||||
|  *      Paul Vixie (ISC), June 1996 | ||||
|  */ | ||||
| int | ||||
| ares_inet_net_pton(int af, const char *src, void *dst, size_t size) | ||||
| { | ||||
|   switch (af) { | ||||
|   case AF_INET: | ||||
|     return (inet_net_pton_ipv4(src, dst, size)); | ||||
|   case AF_INET6: | ||||
|     return (inet_net_pton_ipv6(src, dst, size)); | ||||
|   default: | ||||
|     errno = EAFNOSUPPORT; | ||||
|     return (-1); | ||||
|   } | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #if !defined(HAVE_INET_PTON) || !defined(HAVE_INET_PTON_IPV6) | ||||
| int ares_inet_pton(int af, const char *src, void *dst) | ||||
| { | ||||
|   int size, result; | ||||
|  | ||||
|   if (af == AF_INET) | ||||
|     size = sizeof(struct in_addr); | ||||
|   else if (af == AF_INET6) | ||||
|     size = sizeof(struct in6_addr); | ||||
|   else | ||||
|   { | ||||
|     errno = EAFNOSUPPORT; | ||||
|     return -1; | ||||
|   } | ||||
|   result = ares_inet_net_pton(af, src, dst, size); | ||||
|   if (result == -1 && errno == ENOENT) | ||||
|     return 0; | ||||
|   return (result > -1 ? 1 : -1); | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										31
									
								
								ares/inet_net_pton.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								ares/inet_net_pton.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #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 | ||||
| int ares_inet_pton(int af, const char *src, void *dst); | ||||
| #endif | ||||
| #if defined(HAVE_INET_NET_PTON) && defined(HAVE_INET_NET_PTON_IPV6) | ||||
| #define ares_inet_net_pton(w,x,y,z) inet_net_pton(w,x,y,z) | ||||
| #else | ||||
| int ares_inet_net_pton(int af, const char *src, void *dst, size_t size); | ||||
| #endif | ||||
|  | ||||
| #endif /* INET_NET_PTON_H */ | ||||
							
								
								
									
										206
									
								
								ares/inet_ntop.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										206
									
								
								ares/inet_ntop.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,206 @@ | ||||
| /* Copyright (c) 1996 by Internet Software Consortium. | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SOFTWARE CONSORTIUM DISCLAIMS | ||||
|  * ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES | ||||
|  * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL INTERNET SOFTWARE | ||||
|  * CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL | ||||
|  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR | ||||
|  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS | ||||
|  * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS | ||||
|  * SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #include "setup.h" | ||||
|  | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #if defined(WIN32) && !defined(WATT32) | ||||
| #include "nameser.h" | ||||
| #else | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_NETINET_IN_H | ||||
| #include <netinet/in.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_NAMESER_H | ||||
| #include <arpa/nameser.h> | ||||
| #endif | ||||
| #ifdef HAVE_ARPA_INET_H | ||||
| #include <arpa/inet.h> | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| #include "ares_ipv6.h" | ||||
| #include "inet_ntop.h" | ||||
|  | ||||
|  | ||||
| #if !defined(HAVE_INET_NTOP) || !defined(HAVE_INET_NTOP_IPV6) | ||||
|  | ||||
| #ifdef SPRINTF_CHAR | ||||
| # define SPRINTF(x) strlen(sprintf/**/x) | ||||
| #else | ||||
| # define SPRINTF(x) ((size_t)sprintf x) | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * WARNING: Don't even consider trying to compile this on a system where | ||||
|  * sizeof(int) < 4.  sizeof(int) > 4 is fine; all the world's not a VAX. | ||||
|  */ | ||||
|  | ||||
| static const char *inet_ntop4(const unsigned char *src, char *dst, size_t size); | ||||
| 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. | ||||
|  * return: | ||||
|  *	pointer to presentation format address (`dst'), or NULL (see errno). | ||||
|  * author: | ||||
|  *	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 */ | ||||
| } | ||||
|  | ||||
| /* const char * | ||||
|  * inet_ntop4(src, dst, size) | ||||
|  *	format an IPv4 address, more or less like inet_ntoa() | ||||
|  * return: | ||||
|  *	`dst' (as a const) | ||||
|  * notes: | ||||
|  *	(1) uses no statics | ||||
|  *	(2) takes a unsigned char* not an in_addr as input | ||||
|  * author: | ||||
|  *	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"]; | ||||
|  | ||||
| 	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 | ||||
|  * author: | ||||
|  *	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; | ||||
|  | ||||
| 	/* | ||||
| 	 * 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; | ||||
|  | ||||
| 	/* | ||||
| 	 * 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'; | ||||
|  | ||||
| 	/* | ||||
| 	 * Check for overflow, copy, and we're done. | ||||
| 	 */ | ||||
| 	if ((size_t)(tp - tmp) > size) { | ||||
| 		errno = ENOSPC; | ||||
| 		return (NULL); | ||||
| 	} | ||||
| 	strcpy(dst, tmp); | ||||
| 	return (dst); | ||||
| } | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										26
									
								
								ares/inet_ntop.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								ares/inet_ntop.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* $Id$ */ | ||||
|  | ||||
| /* | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #ifndef INET_NTOP_H | ||||
| #define INET_NTOP_H | ||||
|  | ||||
| #ifdef HAVE_INET_NTOP | ||||
| #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 */ | ||||
| @@ -16,6 +16,8 @@ | ||||
|  | ||||
| #define EINPROGRESS WSAEINPROGRESS | ||||
| #define EWOULDBLOCK WSAEWOULDBLOCK | ||||
| #define EMSGSIZE WSAEMSGSIZE | ||||
| #define EAFNOSUPPORT WSAEAFNOSUPPORT | ||||
|  | ||||
| /* Structure for scatter/gather I/O.  */ | ||||
| struct iovec | ||||
| @@ -37,7 +39,9 @@ int ares_gettimeofday(struct timeval *tv, struct timezone *tz); | ||||
| #endif  /* !NETWARE */ | ||||
|  | ||||
| #define NS_CMPRSFLGS  0xc0 | ||||
|  | ||||
| #define NS_IN6ADDRSZ  16 | ||||
| #define NS_INT16SZ    2 | ||||
| #define NS_INADDRSZ   4 | ||||
|  | ||||
|   /* Flag bits indicating name compression. */ | ||||
| #define INDIR_MASK    NS_CMPRSFLGS | ||||
|   | ||||
							
								
								
									
										14
									
								
								ares/setup.h
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								ares/setup.h
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| #ifndef ARES_SETUP_H | ||||
| #define ARES_SETUP_H | ||||
|  | ||||
| /* Copyright (C) 2004 by Daniel Stenberg et al | ||||
| /* Copyright (C) 2004 - 2005 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 | ||||
| @@ -19,6 +19,7 @@ | ||||
| #else | ||||
| /* simple work-around for now, for systems without configure support */ | ||||
| #define ssize_t int | ||||
| #define socklen_t int | ||||
| #endif | ||||
|  | ||||
| /* Recent autoconf versions define these symbols in config.h. We don't want | ||||
| @@ -49,7 +50,7 @@ typedef int ares_socket_t; | ||||
| #endif | ||||
|  | ||||
| #if !defined(HAVE_UNISTD_H) && !defined(_MSC_VER) | ||||
| #define HAVE_UNISTD_H  | ||||
| #define HAVE_UNISTD_H 1 | ||||
| #endif | ||||
|  | ||||
| #if !defined(HAVE_SYS_UIO_H) && !defined(WIN32) && !defined(MSDOS) | ||||
| @@ -69,4 +70,13 @@ int ares_strcasecmp(const char *s1, const char *s2); | ||||
| #define strcasecmp(a,b) ares_strcasecmp(a,b) | ||||
| #endif | ||||
|  | ||||
| /* IPv6 compatibility */ | ||||
| #if !defined(HAVE_AF_INET6) | ||||
| #if defined(HAVE_PF_INET6) | ||||
| #define AF_INET6 PF_INET6 | ||||
| #else | ||||
| #define AF_INET6 AF_MAX+1 | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #endif /* ARES_SETUP_H */ | ||||
|   | ||||
| @@ -185,24 +185,24 @@ SOURCE=..\..\getopt.c | ||||
| !IF  "$(CFG)" == "adig - Win32 Release" | ||||
|  | ||||
| "areslib - Win32 Release" :  | ||||
|    cd "\ARES-1.1.1\vc\areslib" | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Release"  | ||||
|    cd "..\adig" | ||||
|  | ||||
| "areslib - Win32 ReleaseCLEAN" :  | ||||
|    cd "\ARES-1.1.1\vc\areslib" | ||||
|    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 "\ARES-1.1.1\vc\areslib" | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug"  | ||||
|    cd "..\adig" | ||||
|  | ||||
| "areslib - Win32 DebugCLEAN" :  | ||||
|    cd "\ARES-1.1.1\vc\areslib" | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug" RECURSE=1 CLEAN  | ||||
|    cd "..\adig" | ||||
|  | ||||
|   | ||||
| @@ -195,24 +195,24 @@ SOURCE=..\..\ahost.c | ||||
| !IF  "$(CFG)" == "ahost - Win32 Release" | ||||
|  | ||||
| "areslib - Win32 Release" :  | ||||
|    cd "\ARES-1.1.1\vc\areslib" | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Release"  | ||||
|    cd "..\ahost" | ||||
|  | ||||
| "areslib - Win32 ReleaseCLEAN" :  | ||||
|    cd "\ARES-1.1.1\vc\areslib" | ||||
|    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 "\ARES-1.1.1\vc\areslib" | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug"  | ||||
|    cd "..\ahost" | ||||
|  | ||||
| "areslib - Win32 DebugCLEAN" :  | ||||
|    cd "\ARES-1.1.1\vc\areslib" | ||||
|    cd "..\areslib" | ||||
|    $(MAKE) /$(MAKEFLAGS) /F ".\areslib.mak" CFG="areslib - Win32 Debug" RECURSE=1 CLEAN  | ||||
|    cd "..\ahost" | ||||
|  | ||||
|   | ||||
							
								
								
									
										48
									
								
								buildconf
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								buildconf
									
									
									
									
									
								
							| @@ -13,7 +13,7 @@ findtool(){ | ||||
|   IFS=":" | ||||
|   for path in $PATH | ||||
|   do | ||||
|     if test -r "$path/$file"; then | ||||
|     if test -f "$path/$file"; then | ||||
|       echo "$path/$file" | ||||
|       return | ||||
|     fi | ||||
| @@ -24,7 +24,7 @@ findtool(){ | ||||
| # autoconf 2.57 or newer | ||||
| # | ||||
| need_autoconf="2.57" | ||||
| ac_version=`${AUTOCONF:-autoconf} --version 2>/dev/null|head -1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||
| ac_version=`${AUTOCONF:-autoconf} --version 2>/dev/null|head -n 1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||
| if test -z "$ac_version"; then | ||||
|   echo "buildconf: autoconf not found." | ||||
|   echo "            You need autoconf version $need_autoconf or newer installed." | ||||
| @@ -45,7 +45,7 @@ echo "buildconf: autoconf version $ac_version (ok)" | ||||
| #-------------------------------------------------------------------------- | ||||
| # autoheader 2.50 or newer | ||||
| # | ||||
| ah_version=`${AUTOHEADER:-autoheader} --version 2>/dev/null|head -1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||
| ah_version=`${AUTOHEADER:-autoheader} --version 2>/dev/null|head -n 1| sed -e 's/^[^0-9]*//' -e 's/[a-z]* *$//'` | ||||
| if test -z "$ah_version"; then | ||||
|   echo "buildconf: autoheader not found." | ||||
|   echo "            You need autoheader version 2.50 or newer installed." | ||||
| @@ -67,7 +67,7 @@ echo "buildconf: autoheader version $ah_version (ok)" | ||||
| # automake 1.7 or newer | ||||
| # | ||||
| need_automake="1.7" | ||||
| am_version=`${AUTOMAKE:-automake} --version 2>/dev/null|head -1| sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//' -e 's/\(.*\)\(-p.*\)/\1/'` | ||||
| am_version=`${AUTOMAKE:-automake} --version 2>/dev/null|head -n 1| sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//' -e 's/\(.*\)\(-p.*\)/\1/'` | ||||
| if test -z "$am_version"; then | ||||
|   echo "buildconf: automake not found." | ||||
|   echo "            You need automake version $need_automake or newer installed." | ||||
| @@ -85,6 +85,14 @@ fi | ||||
|  | ||||
| echo "buildconf: automake version $am_version (ok)" | ||||
|  | ||||
| ac=`findtool aclocal` | ||||
|  | ||||
| if test -z "$ac"; then | ||||
|   echo "buildconf: aclocal not found. Weird automake installation!" | ||||
|   exit 1 | ||||
| else | ||||
|   echo "buildconf: aclocal found" | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # libtool check | ||||
| @@ -105,7 +113,7 @@ fi | ||||
| # set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found | ||||
| LIBTOOLIZE="${libtool}ize" | ||||
|  | ||||
| lt_pversion=`$libtool --version 2>/dev/null|head -1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` | ||||
| lt_pversion=`$libtool --version 2>/dev/null|head -n 1|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" | ||||
| @@ -142,10 +150,17 @@ fi | ||||
|  | ||||
| echo "buildconf: libtool version $lt_version (ok)" | ||||
|  | ||||
| if test -f "$LIBTOOLIZE"; then | ||||
|   echo "buildconf: libtoolize found" | ||||
| else | ||||
|   echo "buildconf: libtoolize not found. Weird libtool installation!" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # m4 check | ||||
| # | ||||
| m4=`${M4:-m4} --version 2>/dev/null|head -1`; | ||||
| m4=`${M4:-m4} --version 2>/dev/null|head -n 1`; | ||||
| m4_version=`echo $m4 | sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//'` | ||||
|  | ||||
| if { echo $m4 | grep "GNU" >/dev/null 2>&1; } then | ||||
| @@ -155,6 +170,10 @@ else | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| #-------------------------------------------------------------------------- | ||||
| # perl check | ||||
| # | ||||
| PERL=`findtool perl` | ||||
|  | ||||
| # ------------------------------------------------------------ | ||||
|  | ||||
| @@ -164,24 +183,33 @@ echo "buildconf: running libtoolize" | ||||
| ${LIBTOOLIZE:-libtoolize} --copy --automake --force || die "The libtool command failed" | ||||
| echo "buildconf: running aclocal" | ||||
| ${ACLOCAL:-aclocal} $ACLOCAL_FLAGS || die "The aclocal command line failed" | ||||
| if test -n "$PERL"; then | ||||
|   echo "buildconf: running aclocal hack to convert all mv to mv -f" | ||||
| perl -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4 | ||||
|   $PERL -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4 | ||||
| else | ||||
|   echo "buildconf: perl not found" | ||||
|   exit 1 | ||||
| fi | ||||
| echo "buildconf: running autoheader" | ||||
| ${AUTOHEADER:-autoheader} || die "The autoheader command failed" | ||||
| echo "buildconf: cp lib/config.h.in src/config.h.in" | ||||
| cp lib/config.h.in src/config.h.in | ||||
| echo "buildconf: running autoconf" | ||||
| ${AUTOCONF:-autoconf}     || die "The autoconf command failed" | ||||
|  | ||||
| if test -d ares; then | ||||
|   cd ares | ||||
|   echo "buildconf: running aclocal in the ares directory" | ||||
|   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 autoconf in the ares directory" | ||||
|   echo "buildconf: running ares/autoconf" | ||||
|   ${AUTOCONF:-autoconf}     || die "The ares autoconf command failed" | ||||
|   cd .. | ||||
| fi | ||||
|  | ||||
| echo "buildconf: running automake" | ||||
| ${AUTOMAKE:-automake} -a  || die "The automake command failed" | ||||
| ${AUTOMAKE:-automake} -a -c  || die "The automake command failed" | ||||
|  | ||||
| echo "buildconf: OK" | ||||
| exit 0 | ||||
|   | ||||
							
								
								
									
										580
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										580
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -7,7 +7,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 - 2004 Daniel Stenberg, <daniel@haxx.se> | ||||
| AC_COPYRIGHT([Copyright (c) 1998 - 2005 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]) | ||||
|  | ||||
| @@ -56,7 +56,7 @@ AC_SUBST(PKGADD_VENDOR) | ||||
|  | ||||
| dnl | ||||
| dnl initialize all the info variables | ||||
|     curl_ssl_msg="no      (--with-ssl)" | ||||
|     curl_ssl_msg="no      (--with-ssl / --with-gnutls)" | ||||
|    curl_zlib_msg="no      (--with-zlib)" | ||||
|    curl_krb4_msg="no      (--with-krb4*)" | ||||
|     curl_gss_msg="no      (--with-gssapi)" | ||||
| @@ -66,6 +66,7 @@ dnl initialize all the info variables | ||||
|     curl_idn_msg="no      (--with-libidn)" | ||||
|  curl_manual_msg="no      (--enable-manual)" | ||||
| curl_verbose_msg="enabled (--disable-verbose)" | ||||
|    curl_sspi_msg="no      (--enable-sspi)" | ||||
|  | ||||
| dnl | ||||
| dnl Detect the canonical host and target build environment | ||||
| @@ -116,6 +117,25 @@ esac | ||||
| AC_MSG_RESULT($mimpure) | ||||
| AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes) | ||||
|  | ||||
| AC_MSG_CHECKING([if we need BUILDING_LIBCURL]) | ||||
| case $host in | ||||
|   *-*-mingw*) | ||||
|     AC_DEFINE(BUILDING_LIBCURL, 1, [when building libcurl itself]) | ||||
|     AC_MSG_RESULT(yes) | ||||
|     AC_MSG_CHECKING([if we need CURL_STATICLIB]) | ||||
|     if test "X$enable_shared" = "Xno" | ||||
|     then | ||||
|       AC_DEFINE(CURL_STATICLIB, 1, [when not building a shared library]) | ||||
|       AC_MSG_RESULT(yes) | ||||
|     else | ||||
|       AC_MSG_RESULT(no) | ||||
|     fi | ||||
|     ;; | ||||
|   *) | ||||
|     AC_MSG_RESULT(no) | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| dnl The install stuff has already been taken care of by the automake stuff | ||||
| dnl AC_PROG_INSTALL | ||||
| AC_PROG_MAKE_SET | ||||
| @@ -133,8 +153,8 @@ AC_HELP_STRING([--disable-http],[Disable HTTP support]), | ||||
|        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_SUBST(CURL_DISABLE_HTTP) | ||||
|        AC_SUBST(CURL_DISABLE_GOPHER) | ||||
|        AC_SUBST(CURL_DISABLE_HTTP, [1]) | ||||
|        AC_SUBST(CURL_DISABLE_GOPHER, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -149,7 +169,7 @@ AC_HELP_STRING([--disable-ftp],[Disable FTP support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_FTP, 1, [to disable FTP]) | ||||
|        AC_SUBST(CURL_DISABLE_FTP) | ||||
|        AC_SUBST(CURL_DISABLE_FTP, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -164,7 +184,7 @@ AC_HELP_STRING([--disable-gopher],[Disable GOPHER support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable GOPHER]) | ||||
|        AC_SUBST(CURL_DISABLE_GOPHER) | ||||
|        AC_SUBST(CURL_DISABLE_GOPHER, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -179,7 +199,7 @@ AC_HELP_STRING([--disable-file],[Disable FILE support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_FILE, 1, [to disable FILE]) | ||||
|        AC_SUBST(CURL_DISABLE_FILE) | ||||
|        AC_SUBST(CURL_DISABLE_FILE, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -194,7 +214,7 @@ AC_HELP_STRING([--disable-ldap],[Disable LDAP support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP]) | ||||
|        AC_SUBST(CURL_DISABLE_LDAP) | ||||
|        AC_SUBST(CURL_DISABLE_LDAP, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -209,7 +229,7 @@ AC_HELP_STRING([--disable-dict],[Disable DICT support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_DICT, 1, [to disable DICT]) | ||||
|        AC_SUBST(CURL_DISABLE_DICT) | ||||
|        AC_SUBST(CURL_DISABLE_DICT, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -224,7 +244,22 @@ AC_HELP_STRING([--disable-telnet],[Disable TELNET support]), | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_TELNET, 1, [to disable TELNET]) | ||||
|        AC_SUBST(CURL_DISABLE_TELNET) | ||||
|        AC_SUBST(CURL_DISABLE_TELNET, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
| AC_MSG_CHECKING([whether to support tftp]) | ||||
| AC_ARG_ENABLE(tftp, | ||||
| AC_HELP_STRING([--enable-tftp],[Enable TFTP support]) | ||||
| AC_HELP_STRING([--disable-tftp],[Disable TFTP support]), | ||||
| [ case "$enableval" in | ||||
|   no) | ||||
|        AC_MSG_RESULT(no) | ||||
|        AC_DEFINE(CURL_DISABLE_TFTP, 1, [to disable TFTP]) | ||||
|        AC_SUBST(CURL_DISABLE_TFTP, [1]) | ||||
|        ;; | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|        ;; | ||||
| @@ -306,6 +341,7 @@ then | ||||
|   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 | ||||
| @@ -314,6 +350,16 @@ then | ||||
|              ) | ||||
| 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 | ||||
| @@ -350,6 +396,55 @@ AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]), | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the name of dynamic OpenLDAP libraries | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| LDAPLIBNAME="" | ||||
| AC_ARG_WITH(ldap-lib, | ||||
| AC_HELP_STRING([--with-ldap-lib=libname],[Specify name of dynamic ldap lib file]), | ||||
|  [LDAPLIBNAME="$withval"]) | ||||
|  | ||||
| LBERLIBNAME="" | ||||
| AC_ARG_WITH(lber-lib, | ||||
| AC_HELP_STRING([--with-lber-lib=libname],[Specify name of dynamic lber lib file]), | ||||
|  [LBERLIBNAME="$withval"]) | ||||
|  | ||||
| if test x$CURL_DISABLE_LDAP != x1 ; then | ||||
|  | ||||
|   if test -z "$LDAPLIBNAME" ; then | ||||
|     case $host in | ||||
|       *-*-cygwin | *-*-mingw* | *-*-pw32*) | ||||
|         dnl Windows uses a single and unique OpenLDAP DLL name | ||||
|         LDAPLIBNAME="wldap32.dll" | ||||
|         LBERLIBNAME="no" | ||||
|         ;; | ||||
|     esac | ||||
|   fi | ||||
|  | ||||
|   if test "$LDAPLIBNAME" ; then | ||||
|     AC_DEFINE_UNQUOTED(DL_LDAP_FILE, "$LDAPLIBNAME") | ||||
|     AC_MSG_CHECKING([name of dynamic library ldap]) | ||||
|     AC_MSG_RESULT($LDAPLIBNAME) | ||||
|   else | ||||
|     dnl Try to find the right ldap library name for this system | ||||
|     CURL_DLLIB_NAME(DL_LDAP_FILE, ldap) | ||||
|   fi | ||||
|  | ||||
|   if test "$LBERLIBNAME" ; then | ||||
|     dnl If name is "no" then don't define this variable at all | ||||
|     dnl (it's only needed if libldap.so's dependencies are broken). | ||||
|     if test "$LBERLIBNAME" != "no" ; then  | ||||
|       AC_DEFINE_UNQUOTED(DL_LBER_FILE, "$LBERLIBNAME") | ||||
|     fi | ||||
|     AC_MSG_CHECKING([name of dynamic library lber]) | ||||
|     AC_MSG_RESULT($LBERLIBNAME) | ||||
|   else | ||||
|     dnl Try to find the right lber library name for this system | ||||
|     CURL_DLLIB_NAME(DL_LBER_FILE, lber) | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the presence of the winmm library. | ||||
| dnl ********************************************************************** | ||||
| @@ -487,14 +582,15 @@ OPT_KRB4=off | ||||
| AC_ARG_WITH(krb4,dnl | ||||
| AC_HELP_STRING([--with-krb4=DIR],[where to look for Kerberos4]),[ | ||||
|   OPT_KRB4="$withval" | ||||
|   if test X"$OPT_KRB4" != Xyes | ||||
|   then | ||||
|   if test X"$OPT_KRB4" != Xno; then | ||||
|     want_krb4="yes" | ||||
|     if test X"$OPT_KRB4" != Xyes; then | ||||
|       LDFLAGS="$LDFLAGS -L$OPT_KRB4/lib$libsuff" | ||||
|       KRB4LIB="$OPT_KRB4/lib$libsuff" | ||||
|       CPPFLAGS="$CPPFLAGS -I$OPT_KRB4/include" | ||||
|       KRB4INC="$OPT_KRB4/include" | ||||
|     fi | ||||
|   want_krb4="yes" | ||||
|   fi | ||||
|  ]) | ||||
|  | ||||
| AC_MSG_CHECKING([if Kerberos4 support is requested]) | ||||
| @@ -563,10 +659,13 @@ dnl ********************************************************************** | ||||
|  | ||||
| AC_ARG_WITH(spnego, | ||||
|   AC_HELP_STRING([--with-spnego=DIR], | ||||
|                  [Specify location of SPNEGO library fbopenssl]), | ||||
|   [ SPNEGO_ROOT="$withval" | ||||
|     want_spnego="yes" ] | ||||
| ) | ||||
|                  [Specify location of SPNEGO library fbopenssl]), [ | ||||
|   SPNEGO_ROOT="$withval" | ||||
|   if test x"$SPNEGO_ROOT" != xno; then | ||||
|     want_spnego="yes" | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
| AC_MSG_CHECKING([if SPNEGO support is requested]) | ||||
| if test x"$want_spnego" = xyes; then | ||||
|  | ||||
| @@ -603,19 +702,24 @@ 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 -lgssapi" | ||||
|   [ GSSAPI_LIBS="-L$withval" | ||||
|     want_gss="yes" ] | ||||
| ) | ||||
|  | ||||
| AC_ARG_WITH(gssapi, | ||||
|   AC_HELP_STRING([--with-gssapi=DIR], | ||||
|                  [Where to look for GSSAPI]), | ||||
|   [ GSSAPI_ROOT="$withval" | ||||
|     want_gss="yes" ] | ||||
| ) | ||||
|                  [Where to look for GSSAPI]), [ | ||||
|   GSSAPI_ROOT="$withval" | ||||
|   if test x"$GSSAPI_ROOT" != xno; then | ||||
|     want_gss="yes"  | ||||
|   fi | ||||
| ]) | ||||
|  | ||||
| save_CPPFLAGS="$CPPFLAGS" | ||||
| AC_MSG_CHECKING([if GSSAPI support is requested]) | ||||
| if test x"$want_gss" = xyes; then | ||||
|   AC_MSG_RESULT(yes) | ||||
|  | ||||
|   if test -z "$GSSAPI_INCS"; then | ||||
|      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then | ||||
|         GSSAPI_INCS=`$GSSAPI_ROOT/bin/krb5-config --cflags gssapi` | ||||
| @@ -625,7 +729,48 @@ if test x"$want_gss" = xyes; then | ||||
|   fi | ||||
|   CPPFLAGS="$CPPFLAGS $GSSAPI_INCS" | ||||
|  | ||||
|   if test -z "$GSSAPI_LIB_DIR"; then | ||||
|   AC_CHECK_HEADER(gss.h, | ||||
|     [ | ||||
|       dnl found in the given dirs | ||||
|       AC_DEFINE(HAVE_GSSGNU, 1, [if you have the GNU gssapi libraries]) | ||||
|       gnu_gss=yes | ||||
|     ], | ||||
|     [ | ||||
|       dnl not found, check Heimdal | ||||
|       AC_CHECK_HEADER(gssapi.h, | ||||
|         [ | ||||
|           dnl found in the given dirs | ||||
|           AC_DEFINE(HAVE_GSSHEIMDAL, 1, [if you have the Heimdal gssapi libraries]) | ||||
|         ], | ||||
|         [ | ||||
|           dnl not found, check in gssapi/ subdir  | ||||
|           AC_CHECK_HEADER(gssapi/gssapi.h, | ||||
|             [ | ||||
|               dnl found  | ||||
|               AC_DEFINE(HAVE_GSSMIT, 1, [if you have the MIT gssapi libraries]) | ||||
|             ], | ||||
|             [ | ||||
|               dnl no header found, disabling GSS | ||||
|               want_gss=no | ||||
|               AC_MSG_WARN(disabling GSSAPI since no header files was found) | ||||
|             ] | ||||
|           ) | ||||
|         ] | ||||
|       )         | ||||
|     ] | ||||
|   ) | ||||
| else | ||||
|   AC_MSG_RESULT(no) | ||||
| fi | ||||
| if test x"$want_gss" = xyes; then | ||||
|   AC_DEFINE(HAVE_GSSAPI, 1, [if you have the gssapi libraries]) | ||||
|  | ||||
|   curl_gss_msg="enabled (MIT/Heimdal)" | ||||
|  | ||||
|   if test -n "$gnu_gss"; then | ||||
|     curl_gss_msg="enabled (GNU GSS)" | ||||
|     LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR -lgss" | ||||
|   elif test -z "$GSSAPI_LIB_DIR"; then | ||||
|      if test -f "$GSSAPI_ROOT/bin/krb5-config"; then | ||||
|         gss_ldflags=`$GSSAPI_ROOT/bin/krb5-config --libs gssapi` | ||||
| 	LDFLAGS="$LDFLAGS $gss_ldflags" | ||||
| @@ -635,31 +780,10 @@ if test x"$want_gss" = xyes; then | ||||
|         LDFLAGS="$LDFLAGS -lgssapi" | ||||
|      fi | ||||
|   else | ||||
|      LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR" | ||||
|      LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR -lgssapi" | ||||
|   fi | ||||
|  | ||||
|   AC_MSG_RESULT(yes) | ||||
|   AC_DEFINE(HAVE_GSSAPI, 1, [if you have the gssapi libraries]) | ||||
|  | ||||
|   curl_gss_msg="enabled" | ||||
|  | ||||
|   AC_CHECK_HEADER(gssapi.h, | ||||
|     [ | ||||
|        dnl found in the given dirs | ||||
|       AC_DEFINE(HAVE_GSSHEIMDAL, 1, [if you have the Heimdal gssapi libraries]) | ||||
|     ], | ||||
|     [ | ||||
|       dnl not found, check in gssapi/ subdir  | ||||
|       AC_CHECK_HEADER(gssapi/gssapi.h, | ||||
|         dnl found  | ||||
|         AC_DEFINE(HAVE_GSSMIT, 1, [if you have the MIT gssapi libraries]) | ||||
|       ) | ||||
|        | ||||
|     ] | ||||
|   ) | ||||
|  | ||||
| else | ||||
|   AC_MSG_RESULT(no) | ||||
|   CPPFLAGS="$save_CPPFLAGS" | ||||
| fi | ||||
|    | ||||
| dnl ********************************************************************** | ||||
| @@ -675,11 +799,7 @@ AC_HELP_STRING([--with-ssl=PATH],[where to look for SSL, PATH points to the SSL | ||||
| AC_HELP_STRING([--without-ssl], [disable SSL]), | ||||
|   OPT_SSL=$withval) | ||||
|  | ||||
| if test X"$OPT_SSL" = Xno | ||||
| then | ||||
|   AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more])   | ||||
| else | ||||
|  | ||||
| if test X"$OPT_SSL" != Xno; then | ||||
|   dnl backup the pre-ssl variables | ||||
|   CLEANLDFLAGS="$LDFLAGS" | ||||
|   CLEANCPPFLAGS="$CPPFLAGS" | ||||
| @@ -692,20 +812,24 @@ else | ||||
|       dnl only do pkg-config magic when not cross-compiling | ||||
|       PKGTEST="yes" | ||||
|     fi | ||||
|     EXTRA_SSL=/usr/local/ssl ;; | ||||
|     PREFIX_OPENSSL=/usr/local/ssl | ||||
|     LIB_OPENSSL="$PREFIX_OPENSSL/lib$libsuff" | ||||
|     ;; | ||||
|   off) | ||||
|     dnl no --with-ssl option given, just check default places | ||||
|     if test x$cross_compiling != xyes; then | ||||
|       dnl only do pkg-config magic when not cross-compiling | ||||
|       PKGTEST="yes" | ||||
|     fi | ||||
|     EXTRA_SSL= ;; | ||||
|     PREFIX_OPENSSL= | ||||
|     ;; | ||||
|   *) | ||||
|     dnl check the given --with-ssl spot | ||||
|     PKGTEST="no" | ||||
|     EXTRA_SSL=$OPT_SSL | ||||
|     LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib$libsuff" | ||||
|     CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" | ||||
|     PREFIX_OPENSSL=$OPT_SSL | ||||
|     LIB_OPENSSL="$PREFIX_OPENSSL/lib$libsuff" | ||||
|     LDFLAGS="$LDFLAGS -L$LIB_OPENSSL" | ||||
|     CPPFLAGS="$CPPFLAGS -I$PREFIX_OPENSSL/include/openssl -I$PREFIX_OPENSSL/include" | ||||
|     ;; | ||||
|   esac | ||||
|  | ||||
| @@ -727,6 +851,8 @@ else | ||||
|         SSL_LDFLAGS=`$PKGCONFIG --libs-only-L openssl 2>/dev/null` | ||||
|         SSL_CPPFLAGS=`$PKGCONFIG --cflags-only-I openssl 2>/dev/null` | ||||
|  | ||||
| 	LIB_OPENSSL=`echo $SSL_LDFLAGS | sed -e 's/-L//g'` | ||||
|  | ||||
|         dnl use the values pkg-config reported | ||||
|         LIBS="$LIBS $SSL_LIBS" | ||||
|         CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS" | ||||
| @@ -738,27 +864,6 @@ else | ||||
|     fi | ||||
|   fi | ||||
|  | ||||
|   AC_CHECK_LIB(crypto, CRYPTO_lock,[ | ||||
|      HAVECRYPTO="yes" | ||||
|      ],[ | ||||
|      LDFLAGS="$CLEANLDFLAGS -L$EXTRA_SSL/lib$libsuff" | ||||
|      CPPFLAGS="$CLEANCPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" | ||||
|      AC_CHECK_LIB(crypto, CRYPTO_add_lock,[ | ||||
|        HAVECRYPTO="yes" ], [ | ||||
|        LDFLAGS="$CLEANLDFLAGS" | ||||
|        CPPFLAGS="$CLEANCPPFLAGS" | ||||
|        LIBS="$CLEANLIBS" | ||||
|        ]) | ||||
|     ]) | ||||
|  | ||||
|  | ||||
|   if test X"$HAVECRYPTO" != X"yes"; then | ||||
|       AC_MSG_WARN([crypto lib was not found; SSL will be disabled]) | ||||
|  | ||||
|   else | ||||
|     dnl This is only reasonable to do if crypto actually is there: check for | ||||
|     dnl SSL libs NOTE: it is important to do this AFTER the crypto lib | ||||
|  | ||||
|   dnl This is for Msys/Mingw | ||||
|   AC_MSG_CHECKING([for gdi32]) | ||||
|   my_ac_save_LIBS=$LIBS | ||||
| @@ -773,7 +878,26 @@ else | ||||
|                AC_MSG_RESULT(no)] | ||||
|               ) | ||||
|  | ||||
|     AC_CHECK_LIB(crypto, CRYPTO_add_lock) | ||||
|   AC_CHECK_LIB(crypto, CRYPTO_lock,[ | ||||
|      HAVECRYPTO="yes" | ||||
|      LIBS="-lcrypto $LIBS" | ||||
|      ],[ | ||||
|      LDFLAGS="$CLEANLDFLAGS -L$LIB_OPENSSL" | ||||
|      CPPFLAGS="$CLEANCPPFLAGS -I$PREFIX_OPENSSL/include/openssl -I$PREFIX_OPENSSL/include" | ||||
|      AC_CHECK_LIB(crypto, CRYPTO_add_lock,[ | ||||
|        HAVECRYPTO="yes" | ||||
|        LIBS="-lcrypto $LIBS"], [ | ||||
|        LDFLAGS="$CLEANLDFLAGS" | ||||
|        CPPFLAGS="$CLEANCPPFLAGS" | ||||
|        LIBS="$CLEANLIBS" | ||||
|        ]) | ||||
|     ]) | ||||
|  | ||||
|  | ||||
|   if test X"$HAVECRYPTO" = X"yes"; then | ||||
|     dnl This is only reasonable to do if crypto actually is there: check for | ||||
|     dnl SSL libs NOTE: it is important to do this AFTER the crypto lib | ||||
|  | ||||
|     AC_CHECK_LIB(ssl, SSL_connect) | ||||
|  | ||||
|     if test "$ac_cv_lib_ssl_SSL_connect" != yes; then | ||||
| @@ -795,13 +919,13 @@ else | ||||
|       dnl Have the libraries--check for SSLeay/OpenSSL headers | ||||
|       AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \ | ||||
|                        openssl/pem.h openssl/ssl.h openssl/err.h, | ||||
|         curl_ssl_msg="enabled" | ||||
|         curl_ssl_msg="enabled (OpenSSL)" | ||||
|         OPENSSL_ENABLED=1 | ||||
|         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, | ||||
|           curl_ssl_msg="enabled" | ||||
|           curl_ssl_msg="enabled (OpenSSL)" | ||||
|           OPENSSL_ENABLED=1) | ||||
|       fi | ||||
|     fi | ||||
| @@ -811,7 +935,11 @@ else | ||||
|  | ||||
|        dnl is there a pkcs12.h header present? | ||||
|        AC_CHECK_HEADERS(openssl/pkcs12.h) | ||||
|     else | ||||
|        LIBS="$CLEANLIBS" | ||||
|     fi | ||||
|     dnl USE_SSLEAY is the historical name for what configure calls | ||||
|     dnl OPENSSL_ENABLED; the names should really be unified | ||||
|     USE_SSLEAY="$OPENSSL_ENABLED" | ||||
|     AC_SUBST(USE_SSLEAY) | ||||
|  | ||||
| @@ -821,40 +949,15 @@ else | ||||
|     fi | ||||
|   fi | ||||
|  | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the CA bundle | ||||
| dnl ********************************************************************** | ||||
|  | ||||
|   if test X"$OPENSSL_ENABLED" = X"1"; then | ||||
|     dnl If the ENGINE library seems to be around, check for the OpenSSL engine | ||||
|     dnl header, it is kind of "separated" from the main SSL check | ||||
|     AC_CHECK_FUNC(ENGINE_init, [ AC_CHECK_HEADERS(openssl/engine.h) ]) | ||||
|  | ||||
|     AC_MSG_CHECKING([CA cert bundle install path]) | ||||
|  | ||||
|     AC_ARG_WITH(ca-bundle, | ||||
| AC_HELP_STRING([--with-ca-bundle=FILE], [File name to install the CA bundle as]) | ||||
| AC_HELP_STRING([--without-ca-bundle], [Don't install the CA bundle]), | ||||
|     [ ca="$withval" ], | ||||
|     dnl stuff, it is kind of "separated" from the main SSL check | ||||
|     AC_CHECK_FUNC(ENGINE_init, | ||||
|               [ | ||||
|       if test "x$prefix" != xNONE; then | ||||
|         ca="\${prefix}/share/curl/curl-ca-bundle.crt" | ||||
|       else | ||||
|         ca="$ac_default_prefix/share/curl/curl-ca-bundle.crt" | ||||
|       fi | ||||
|                 AC_CHECK_HEADERS(openssl/engine.h) | ||||
|                 AC_CHECK_FUNCS( ENGINE_load_builtin_engines ) | ||||
|               ]) | ||||
|  | ||||
|     if test X"$OPT_SSL" = Xno; then | ||||
|       ca="no" | ||||
|     fi | ||||
|  | ||||
|     if test "x$ca" != "xno"; then | ||||
|       CURL_CA_BUNDLE='"'$ca'"' | ||||
|       AC_SUBST(CURL_CA_BUNDLE)   | ||||
|     fi | ||||
|     AC_MSG_RESULT([$ca]) | ||||
|  | ||||
|     dnl these can only exist if openssl exists | ||||
|  | ||||
|     AC_CHECK_FUNCS( RAND_status \ | ||||
| @@ -865,17 +968,19 @@ AC_HELP_STRING([--without-ca-bundle], [Don't install the CA bundle]), | ||||
|   fi | ||||
|  | ||||
|   if test "$OPENSSL_ENABLED" = "1"; then | ||||
|     dnl when the ssl shared libs were found in a path that the run-time linker | ||||
|     dnl doesn't search through, we need to add it to LD_LIBRARY_PATH to | ||||
|     dnl prevent further configure tests to fail due to this | ||||
|     LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$EXTRA_SSL/lib$libsuff" | ||||
|     if test -n "$LIB_OPENSSL"; then | ||||
|        dnl when the ssl shared libs were found in a path that the run-time | ||||
|        dnl linker doesn't search through, we need to add it to LD_LIBRARY_PATH | ||||
|        dnl to prevent further configure tests to fail due to this | ||||
|  | ||||
|        LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_OPENSSL" | ||||
|        export LD_LIBRARY_PATH | ||||
|        AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH]) | ||||
|     fi | ||||
|   fi | ||||
|  | ||||
| fi | ||||
|  | ||||
| AM_CONDITIONAL(CABUNDLE, test x$ca != xno) | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the random seed preferences  | ||||
| dnl ********************************************************************** | ||||
| @@ -908,6 +1013,116 @@ if test X"$OPENSSL_ENABLED" = X"1"; then | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| dnl ---------------------------------------------------- | ||||
| dnl FIX: only check for GnuTLS if OpenSSL is not enabled | ||||
| dnl ---------------------------------------------------- | ||||
|  | ||||
| dnl Default to compiler & linker defaults for GnuTLS files & libraries. | ||||
| OPT_GNUTLS=no | ||||
|  | ||||
| AC_ARG_WITH(gnutls,dnl | ||||
| AC_HELP_STRING([--with-gnutls=PATH],[where to look for GnuTLS, PATH points to the installation root (default: /usr/local/)]) | ||||
| AC_HELP_STRING([--without-gnutls], [disable GnuTLS detection]), | ||||
|   OPT_GNUTLS=$withval) | ||||
|  | ||||
| if test "$OPENSSL_ENABLED" != "1"; then | ||||
|  | ||||
|   if test X"$OPT_GNUTLS" != Xno; then | ||||
|     if test "x$OPT_GNUTLS" = "xyes"; then | ||||
|      check=`libgnutls-config --version 2>/dev/null` | ||||
|      if test -n "$check"; then | ||||
|        addlib=`libgnutls-config --libs` | ||||
|        addcflags=`libgnutls-config --cflags` | ||||
|        version=`libgnutls-config --version` | ||||
|        gtlsprefix=`libgnutls-config --prefix` | ||||
|      fi | ||||
|     else | ||||
|       addlib=`$OPT_GNUTLS/bin/libgnutls-config --libs` | ||||
|       addcflags=`$OPT_GNUTLS/bin/libgnutls-config --cflags` | ||||
|       version=`$OPT_GNUTLS/bin/libgnutls-config --version 2>/dev/null` | ||||
|       gtlsprefix=$OPT_GNUTLS | ||||
|       if test -z "$version"; then | ||||
|         version="unknown" | ||||
|       fi | ||||
|     fi | ||||
|     if test -n "$addlib"; then | ||||
|  | ||||
|       CLEANLDFLAGS="$LDFLAGS" | ||||
|       CLEANCPPFLAGS="$CPPFLAGS" | ||||
|    | ||||
|       LDFLAGS="$LDFLAGS $addlib" | ||||
|       if test "$addcflags" != "-I/usr/include"; then | ||||
|          CPPFLAGS="$CPPFLAGS $addcflags" | ||||
|       fi | ||||
|    | ||||
|       AC_CHECK_LIB(gnutls, gnutls_check_version, | ||||
|        [ | ||||
|        AC_DEFINE(USE_GNUTLS, 1, [if GnuTLS is enabled]) | ||||
|        AC_SUBST(USE_GNUTLS, [1]) | ||||
|        USE_GNUTLS="yes" | ||||
|        curl_ssl_msg="enabled (GnuTLS)" | ||||
|        ], | ||||
|        [ | ||||
|          LDFLAGS="$CLEANLDFLAGS" | ||||
|          CPPFLAGS="$CLEANCPPFLAGS" | ||||
|        ]) | ||||
|    | ||||
|       if test "x$USE_GNUTLS" = "xyes"; then | ||||
|         AC_MSG_NOTICE([detected GnuTLS version $version]) | ||||
|  | ||||
|         dnl when shared libs were found in a path that the run-time | ||||
|         dnl linker doesn't search through, we need to add it to | ||||
|         dnl LD_LIBRARY_PATH to prevent further configure tests to fail | ||||
|         dnl due to this | ||||
|  | ||||
|         LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlsprefix/lib$libsuff" | ||||
|         export LD_LIBRARY_PATH | ||||
|         AC_MSG_NOTICE([Added $gtlsprefix/lib$libsuff to LD_LIBRARY_PATH]) | ||||
|       fi | ||||
|  | ||||
|     fi | ||||
|  | ||||
|   fi dnl GNUTLS not disabled | ||||
|  | ||||
|   if test X"$USE_GNUTLS" != "Xyes"; then | ||||
|     AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.]) | ||||
|     AC_MSG_WARN([Use --with-ssl or --with-gnutls to address this.]) | ||||
|   fi | ||||
|  | ||||
| fi dnl OPENSSL != 1 | ||||
|  | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the CA bundle | ||||
| dnl ********************************************************************** | ||||
|  | ||||
| if test X"$USE_GNUTLS$OPENSSL_ENABLED" != "X"; then | ||||
|  | ||||
|   AC_MSG_CHECKING([CA cert bundle install path]) | ||||
|  | ||||
|   AC_ARG_WITH(ca-bundle, | ||||
| AC_HELP_STRING([--with-ca-bundle=FILE], [File name to install the CA bundle as]) | ||||
| AC_HELP_STRING([--without-ca-bundle], [Don't install the CA bundle]), | ||||
|     [ ca="$withval" ], | ||||
|     [ | ||||
|       if test "x$prefix" != xNONE; then | ||||
|         ca="\${prefix}/share/curl/curl-ca-bundle.crt" | ||||
|       else | ||||
|         ca="$ac_default_prefix/share/curl/curl-ca-bundle.crt" | ||||
|       fi | ||||
|     ] ) | ||||
|  | ||||
|     if test "x$ca" != "xno"; then | ||||
|       CURL_CA_BUNDLE='"'$ca'"' | ||||
|       AC_SUBST(CURL_CA_BUNDLE)   | ||||
|     fi | ||||
|     AC_MSG_RESULT([$ca]) | ||||
| fi dnl only done if some kind of SSL was enabled | ||||
|  | ||||
| AM_CONDITIONAL(CABUNDLE, test x$ca != xno) | ||||
|  | ||||
|  | ||||
|  | ||||
|    | ||||
| dnl ********************************************************************** | ||||
| dnl Check for the presence of ZLIB libraries and headers | ||||
| dnl ********************************************************************** | ||||
| @@ -916,27 +1131,35 @@ dnl Check for & handle argument to --with-zlib. | ||||
|  | ||||
| _cppflags=$CPPFLAGS | ||||
| _ldflags=$LDFLAGS | ||||
| OPT_ZLIB="/usr/local" | ||||
| AC_ARG_WITH(zlib, | ||||
| AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH]) | ||||
| AC_HELP_STRING([--without-zlib],[disable use of zlib]), | ||||
|                [OPT_ZLIB="$withval"]) | ||||
|  | ||||
| case "$OPT_ZLIB" in | ||||
|   no) | ||||
|     AC_MSG_WARN([zlib disabled]) ;; | ||||
|   *) | ||||
| if test "$OPT_ZLIB" = "no" ; then | ||||
|     AC_MSG_WARN([zlib disabled]) | ||||
| else | ||||
|   if test "$OPT_ZLIB" = "yes" ; then | ||||
|      OPT_ZLIB="" | ||||
|   fi | ||||
|  | ||||
|   if test -z "$OPT_ZLIB" ; then | ||||
|     dnl check for the lib first without setting any new path, since many | ||||
|     dnl people have it in the default path | ||||
|  | ||||
|     AC_CHECK_LIB(z, inflateEnd, | ||||
|                    dnl libz found, set the variable | ||||
|                    [HAVE_LIBZ="1"], | ||||
|                    dnl if no lib found, try to add the given library | ||||
|                    [if test -d "$OPT_ZLIB"; then | ||||
|                    dnl if no lib found, try /usr/local | ||||
|                    [OPT_ZLIB="/usr/local"]) | ||||
|  | ||||
|   fi | ||||
|  | ||||
|   dnl Add a nonempty path to the compiler flags | ||||
|   if test -n "$OPT_ZLIB"; then | ||||
|      CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include" | ||||
|      LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib$libsuff" | ||||
|                    fi]) | ||||
|   fi | ||||
|  | ||||
|   AC_CHECK_HEADER(zlib.h, | ||||
|     [ | ||||
| @@ -979,8 +1202,7 @@ case "$OPT_ZLIB" in | ||||
|     AC_MSG_NOTICE([found both libz and libz.h header]) | ||||
|     curl_zlib_msg="enabled" | ||||
|   fi | ||||
|     ;; | ||||
| esac | ||||
| fi | ||||
|  | ||||
| dnl set variable for use in automakefile(s) | ||||
| AM_CONDITIONAL(HAVE_LIBZ, test x"$AMFIXLIB" = x1) | ||||
| @@ -1001,7 +1223,6 @@ case "$LIBIDN" in | ||||
|        dnl if there is a given path, check that FIRST | ||||
|        if test -n "$LIBIDN"; then | ||||
|          if test "x$LIBIDN" != "xyes"; then | ||||
|             AC_MSG_WARN([moo moo $LIBIDN]) | ||||
|             oldLDFLAGS=$LDFLAGS | ||||
|             oldCPPFLAGS=$CPPFLAGS | ||||
|             LDFLAGS="$LDFLAGS -L$LIBIDN/lib" | ||||
| @@ -1023,6 +1244,7 @@ case "$LIBIDN" in | ||||
|  | ||||
|        if test "x$idn" = "xyes"; then | ||||
|          curl_idn_msg="enabled" | ||||
|          AC_SUBST(IDN_ENABLED, [1]) | ||||
|          dnl different versions of libidn have different setups of these: | ||||
|          AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror) | ||||
|          AC_CHECK_HEADERS( idn-free.h tld.h ) | ||||
| @@ -1086,7 +1308,7 @@ else | ||||
|   dnl is there a strerror_r() | ||||
|   CURL_CHECK_STRERROR_R() | ||||
|  | ||||
|   AC_CHECK_FUNCS( gmtime_r ) | ||||
|   checkfor_gmtime_r="yes" | ||||
| fi | ||||
|  | ||||
| dnl for recent AIX versions, we skip all the thread-safe checks above since | ||||
| @@ -1122,6 +1344,46 @@ if test "x$RECENTAIX" = "xyes"; then | ||||
|   dnl is there a strerror_r() | ||||
|   CURL_CHECK_STRERROR_R() | ||||
|  | ||||
|   checkfor_gmtime_r="yes" | ||||
| fi | ||||
|  | ||||
| if test x$cross_compiling != xyes; then | ||||
|  | ||||
|   if test x$checkfor_gmtime_r = xyes; then | ||||
|  | ||||
|     dnl if gmtime_r was found, verify that it actuall works, as (at least) HPUX | ||||
|     dnl 10.20 is known to have a buggy one. If it doesn't work, disable use of | ||||
|     dnl it. | ||||
|  | ||||
|     AC_MSG_CHECKING([if gmtime_r exists and works]) | ||||
|     AC_RUN_IFELSE([[ | ||||
|     #include <time.h> | ||||
|     int main(void) | ||||
|     { | ||||
|     time_t local = 1170352587; | ||||
|     struct tm *gmt; | ||||
|     struct tm keeper; | ||||
|     putenv("TZ=CST6CDT"); | ||||
|     tzset(); | ||||
|     gmt = gmtime_r(&local, &keeper); | ||||
|     if(gmt) { | ||||
|       return 0; | ||||
|     } | ||||
|     return 1; /* failure */ | ||||
|     } | ||||
|      ]], | ||||
|      dnl success, do nothing | ||||
|      AC_MSG_RESULT(yes) | ||||
|      AC_DEFINE(HAVE_GMTIME_R, 1, [if you have (a working) gmtime_r]) | ||||
|      , | ||||
|      dnl failure, now disable the function | ||||
|      AC_MSG_RESULT(no) | ||||
|     , | ||||
|     dnl not invoked when crosscompiling) | ||||
|     ]) | ||||
|   fi | ||||
| else | ||||
|   dnl and for crosscompilings | ||||
|   AC_CHECK_FUNCS(gmtime_r) | ||||
| fi | ||||
|  | ||||
| @@ -1171,6 +1433,9 @@ AC_CHECK_HEADERS( | ||||
|         sys/resource.h \ | ||||
|         libgen.h \ | ||||
|         locale.h \ | ||||
|         errno.h \ | ||||
|         arpa/tftp.h \ | ||||
|         sys/filio.h \ | ||||
|         setjmp.h, | ||||
| dnl to do if not found | ||||
| [], | ||||
| @@ -1231,6 +1496,8 @@ AC_CHECK_TYPE(ssize_t, , | ||||
| TYPE_SOCKLEN_T | ||||
| TYPE_IN_ADDR_T | ||||
|  | ||||
| TYPE_SOCKADDR_STORAGE | ||||
|  | ||||
| AC_FUNC_SELECT_ARGTYPES | ||||
|  | ||||
| dnl Checks for library functions. | ||||
| @@ -1243,7 +1510,6 @@ AC_CHECK_FUNCS( strtoll \ | ||||
|                 strdup \ | ||||
|                 strstr \ | ||||
|                 strtok_r \ | ||||
|                 strftime \ | ||||
|                 uname \ | ||||
|                 strcasecmp \ | ||||
|                 stricmp \ | ||||
| @@ -1253,8 +1519,6 @@ AC_CHECK_FUNCS( strtoll \ | ||||
|                 inet_addr \ | ||||
|                 inet_ntoa \ | ||||
|                 inet_pton \ | ||||
|                 tcsetattr \ | ||||
|                 tcgetattr \ | ||||
|                 perror \ | ||||
|                 closesocket \ | ||||
|                 siginterrupt \ | ||||
| @@ -1327,6 +1591,19 @@ AC_CHECK_DECL(basename, , | ||||
| #endif | ||||
| ) | ||||
|  | ||||
| AC_MSG_CHECKING([if we are Mac OS X (to disable poll)]) | ||||
| disable_poll=no | ||||
| case $host in | ||||
|   *-*-darwin*) | ||||
|     disable_poll="yes"; | ||||
|     ;; | ||||
|   *) | ||||
|     ;; | ||||
| esac | ||||
| AC_MSG_RESULT($disable_poll) | ||||
|  | ||||
| if test "$disable_poll" = "no"; then | ||||
|  | ||||
|   dnl poll() might be badly emulated, as in Mac OS X 10.3 (and other BSDs?) and | ||||
|   dnl to find out we make an extra check here! | ||||
|   if test "$ac_cv_func_poll" = "yes"; then | ||||
| @@ -1348,8 +1625,8 @@ if test "$ac_cv_func_poll" = "yes"; then | ||||
|     AC_MSG_RESULT(cross-compiling assumes yes) | ||||
|     AC_DEFINE(HAVE_POLL_FINE, 1, [If you have a fine poll]) | ||||
|     ) dnl end of AC_RUN_IFELSE | ||||
| fi | ||||
|  | ||||
|   fi dnl poll() was found | ||||
| fi dnl poll()-check is not disabled | ||||
|  | ||||
|  | ||||
| AC_PATH_PROG( PERL, perl, ,  | ||||
| @@ -1413,7 +1690,7 @@ AC_HELP_STRING([--disable-ares],[Disable ares for name lookups]), | ||||
|   *)   AC_MSG_RESULT(yes) | ||||
|  | ||||
|        if test "x$IPV6_ENABLED" = "x1"; then | ||||
|          AC_MSG_ERROR([ares doesn't work with ipv6, disable ipv6 to use ares]) | ||||
|          AC_MSG_NOTICE([ares may not work properly with ipv6]) | ||||
|        fi | ||||
|  | ||||
|        AC_DEFINE(USE_ARES, 1, [Define if you want to enable ares support]) | ||||
| @@ -1422,7 +1699,7 @@ AC_HELP_STRING([--disable-ares],[Disable ares for name lookups]), | ||||
|        AC_SUBST(HAVE_ARES) | ||||
|        curl_ares_msg="enabled" | ||||
|  | ||||
|        LIBS="$LIBS -lcares" | ||||
|        LIBS="-lcares $LIBS" | ||||
|  | ||||
|        dnl For backwards compatibility default to includes/lib in srcdir/ares | ||||
|        dnl If a value is specified it is assumed that the libs are in $val/lib | ||||
| @@ -1495,6 +1772,28 @@ AC_HELP_STRING([--disable-verbose],[Disable verbose strings]), | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl enable SSPI support | ||||
| dnl | ||||
| AC_MSG_CHECKING([whether to enable SSPI support (win32 builds only)]) | ||||
| AC_ARG_ENABLE(sspi, | ||||
| AC_HELP_STRING([--enable-sspi],[Enable SSPI]) | ||||
| AC_HELP_STRING([--disable-sspi],[Disable SSPI]), | ||||
| [ case "$enableval" in | ||||
|   yes) | ||||
|        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" | ||||
|        ;; | ||||
|   *) | ||||
|        AC_MSG_RESULT(no) | ||||
|        ;; | ||||
|   esac ], | ||||
|        AC_MSG_RESULT(no) | ||||
| ) | ||||
|  | ||||
| dnl ************************************************************ | ||||
| dnl lame option to switch on debug options | ||||
| dnl | ||||
| @@ -1558,6 +1857,17 @@ AC_HELP_STRING([--disable-cookies],[Disable cookies support]), | ||||
|        AC_MSG_RESULT(yes) | ||||
| ) | ||||
|  | ||||
| if test "x$ws2" = "xyes"; then | ||||
|  | ||||
|   dnl If ws2_32 is wanted, make sure it is the _last_ lib in LIBS (makes | ||||
|   dnl things work when built with c-ares). But we can't just move it last | ||||
|   dnl since then other stuff (SSL) won't build. So we simply append it to the | ||||
|   dnl end. | ||||
|  | ||||
|   LIBS="$LIBS -lws2_32" | ||||
|  | ||||
| fi | ||||
|  | ||||
| AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes) | ||||
|  | ||||
| AC_CONFIG_FILES([Makefile \ | ||||
| @@ -1606,4 +1916,6 @@ AC_MSG_NOTICE([Configured to build curl/libcurl: | ||||
|   Build libcurl:   Shared=${enable_shared}, Static=${enable_static}  | ||||
|   Built-in manual: ${curl_manual_msg} | ||||
|   Verbose errors:  ${curl_verbose_msg} | ||||
|   SSPI support:    ${curl_sspi_msg} | ||||
|   ca cert path:    ${ca} | ||||
| ]) | ||||
|   | ||||
| @@ -19,7 +19,8 @@ Available values for OPTION include: | ||||
|   --ca        ca bundle install path | ||||
|   --cc        compiler | ||||
|   --cflags    pre-processor and compiler flags | ||||
|   --feature   newline separated list of enabled features | ||||
|   --features  newline separated list of enabled features | ||||
|   --protocols newline separated list of enabled protocols | ||||
|   --help      display this help and exit | ||||
|   --libs      library linking information | ||||
|   --prefix    curl install prefix | ||||
| @@ -56,9 +57,12 @@ while test $# -gt 0; do | ||||
| 	echo "$prefix" | ||||
| 	;; | ||||
|  | ||||
|     --feature) | ||||
|     --feature|--features) | ||||
| 	if test "@USE_SSLEAY@" = "1"; then | ||||
|           echo "SSL" | ||||
|           NTLM=1 # OpenSSL implies NTLM | ||||
|         elif test -n "@USE_GNUTLS@"; then | ||||
|           echo "SSL" | ||||
|         fi | ||||
| 	if test "@KRB4_ENABLED@" = "1"; then | ||||
|           echo "KRB4" | ||||
| @@ -69,32 +73,53 @@ while test $# -gt 0; do | ||||
| 	if test "@HAVE_LIBZ@" = "1"; then | ||||
|           echo "libz" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_HTTP@" = "1"; then | ||||
|           echo "HTTP-disabled" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_FTP@" = "1"; then | ||||
|           echo "FTP-disabled" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_GOPHER@" = "1"; then | ||||
|           echo "GOPHER-disabled" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_FILE@" = "1"; then | ||||
|           echo "FILE-disabled" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_TELNET@" = "1"; then | ||||
|           echo "TELNET-disabled" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_LDAP@" = "1"; then | ||||
|           echo "LDAP-disabled" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_DICT@" = "1"; then | ||||
|           echo "DICT-disabled" | ||||
|         fi | ||||
| 	if test "@HAVE_ARES@" = "1"; then | ||||
|           echo "AsynchDNS" | ||||
|         fi | ||||
| 	if test "@IDN_ENABLED@" = "1"; then | ||||
|           echo "IDN" | ||||
|         fi | ||||
| 	if test "@USE_WINDOWS_SSPI@" = "1"; then | ||||
|           echo "SSPI" | ||||
|           NTLM=1 | ||||
|         fi | ||||
| 	if test "$NTLM" = "1"; then | ||||
|           echo "NTLM" | ||||
|         fi | ||||
| 	;; | ||||
|  | ||||
|     --protocols) | ||||
| 	if test "@CURL_DISABLE_HTTP@" != "1"; then | ||||
|           echo "HTTP" | ||||
| 	  if test "@USE_SSLEAY@" = "1"; then | ||||
|             echo "HTTPS" | ||||
|           fi | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_FTP@" != "1"; then | ||||
|           echo "FTP" | ||||
| 	  if test "@USE_SSLEAY@" = "1"; then | ||||
|             echo "FTPS" | ||||
|           fi | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_GOPHER@" != "1"; then | ||||
|           echo "GOPHER" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_FILE@" != "1"; then | ||||
|           echo "FILE" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_TELNET@" != "1"; then | ||||
|           echo "TELNET" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_LDAP@" != "1"; then | ||||
|           echo "LDAP" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_DICT@" != "1"; then | ||||
|           echo "DICT" | ||||
|         fi | ||||
| 	if test "@CURL_DISABLE_TFTP@" != "1"; then | ||||
|           echo "TFTP" | ||||
|         fi | ||||
| 	;; | ||||
|     --version) | ||||
| 	echo libcurl @VERSION@ | ||||
| 	exit 0 | ||||
| @@ -123,8 +148,7 @@ while test $# -gt 0; do | ||||
|  | ||||
|     *) | ||||
|         echo "unknown option: $1" | ||||
| 	usage | ||||
| 	exit 1 | ||||
| 	usage 1 | ||||
| 	;; | ||||
|     esac | ||||
|     shift | ||||
|   | ||||
| @@ -25,10 +25,14 @@ Basic | ||||
|   ScriptBasic bindings to libcurl. Writtten by Peter Verhas | ||||
|   http://scriptbasic.com/ | ||||
|  | ||||
| C | ||||
|   libcurl is a C library in itself! | ||||
|   http://curl.haxx.se/libcurl/ | ||||
|  | ||||
| C++ | ||||
|  | ||||
|   Written by Jean-Philippe Barrette-LaPierre | ||||
|   http://www.sourceforge.net/projects/curlpp | ||||
|   http://rrette.com/curlpp.html | ||||
|  | ||||
| Ch | ||||
|  | ||||
| @@ -68,24 +72,29 @@ glib/GTK+ | ||||
|  | ||||
| Java | ||||
|  | ||||
|   Written by Daniel Stenberg | ||||
|   Maintained by Vic Hanson | ||||
|   http://curl.haxx.se/libcurl/java/ | ||||
|  | ||||
| Lisp | ||||
|  | ||||
|   Written by Liam Healy | ||||
|   http://common-lisp.net/project/cl-curl/ | ||||
|  | ||||
| Lua | ||||
|  | ||||
|   Written by Steve Dekorte | ||||
|   http://curl.haxx.se/libcurl/lua/ | ||||
|  | ||||
| .NET | ||||
|  | ||||
|   Written by Jeffrey Phillips | ||||
|   http://www.seasideresearch.com/downloads.html | ||||
|   LuaCURL Written by Alexander Marinov | ||||
|   http://luacurl.luaforge.net/ | ||||
|  | ||||
| Mono | ||||
|  | ||||
|   Written by Jeffrey Phillips | ||||
|   http://forge.novell.com/modules/xfmod/project/?libcurl-mono | ||||
|  | ||||
| .NET | ||||
|  | ||||
|   libcurl-net Written by Jeffrey Phillips | ||||
|   http://sourceforge.net/projects/libcurl-net/ | ||||
|  | ||||
| Object-Pascal | ||||
|  | ||||
|   Free Pascal, Delphi and Kylix binding written by Christophe Espern. | ||||
| @@ -141,13 +150,23 @@ Scheme | ||||
|   Bigloo binding written by Kirill Lisovsky | ||||
|   http://curl.haxx.se/libcurl/scheme/ | ||||
|  | ||||
| S-Lang | ||||
|  | ||||
|   S-Lang binding written by John E Davis | ||||
|   http://www.jedsoft.org/slang/modules/curl.html | ||||
|  | ||||
| Tcl | ||||
|  | ||||
|   Tclcurl is written by Andr<64>s Garc<72>a | ||||
|   http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html | ||||
|  | ||||
| Q | ||||
| Visual Basic | ||||
|  | ||||
|   libcurl-vb is written by Jeffrey Phillips | ||||
|   http://sourceforge.net/projects/libcurl-vb/ | ||||
|  | ||||
| Q | ||||
|   The libcurl module is part of the default install | ||||
|   http://q-lang.sourceforge.net/ | ||||
|  | ||||
| wxWidgets | ||||
|   | ||||
							
								
								
									
										205
									
								
								docs/DISTRO-DILEMMA
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										205
									
								
								docs/DISTRO-DILEMMA
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,205 @@ | ||||
|   Date: September 30, 2005 | ||||
|   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. | ||||
|  | ||||
|  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. | ||||
|  | ||||
| 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. | ||||
|  | ||||
|  libcurl is MIT-style[4] licensed - how on earth did this dilemma fall onto | ||||
|  our plates? | ||||
|  | ||||
|  libcurl is only a little library. libcurl can be built to use OpenSSL for its | ||||
|  SSL/TLS capabilities. OpenSSL is basically Original BSD licensed[5]. | ||||
|  | ||||
|  If libcurl built to use OpenSSL is used by a GPL-licensed application and you | ||||
|  decide to distribute a binary version of it (Linux distros - for example - | ||||
|  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. | ||||
|  | ||||
| Part of the Operating System | ||||
|  | ||||
|  This would not be a problem if the used lib would be considered part of the | ||||
|  underlying operating system, as then the GPL license has an exception | ||||
|  clause[6] that allows applications to use such libs without having to be | ||||
|  allowed to distribute it or its sources. Possibly some distros will claim | ||||
|  that OpenSSL is part of their 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. | ||||
|  | ||||
|  I believe Debian is the first distro to provide libcurl/GnutTLS packages. | ||||
|  | ||||
| GnuTLS vs OpenSSL | ||||
|  | ||||
|  While these two libraries offer similar features, they are not equal. Both | ||||
|  libraries have features the other one lacks. libcurl does not (yet) offer a | ||||
|  standardized stable ABI if you decide to switch from using libcurl-openssl to | ||||
|  libcurl-gnutls or vice versa. The GnuTLS support is very recent in libcurl | ||||
|  and it has not been tested nor used very extensively, while the OpenSSL | ||||
|  equivalent code has been used and thus matured for more than seven (7) years. | ||||
|  | ||||
|  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. | ||||
|  | ||||
| The Better License, Original BSD or LGPL? | ||||
|  | ||||
|  It isn't obvious or without debate to any objective interested party that | ||||
|  either of these licenses are the "better" or even the "preferred" one in a | ||||
|  generic situation. | ||||
|  | ||||
|  Instead, I think we should accept the fact that the SSL/TLS libraries and | ||||
|  their different licenses will fit different applications and their authors | ||||
|  differently depending on the applications' licenses and their general usage | ||||
|  pattern (considering how LGPL libraries for example can be burdensome for | ||||
|  embedded systems usage). | ||||
|  | ||||
|  In Debian land, there seems to be a common opinion that LGPL is "maximally | ||||
|  compatible" with apps while Original BSD is not. Like this: | ||||
|  | ||||
|         http://lists.debian.org/debian-devel/2005/09/msg01417.html | ||||
|  | ||||
| More SSL Libraries | ||||
|  | ||||
|  In libcurl, there's no stopping us here. There are at least a few more Open | ||||
|  Source/Free SSL/TLS libraries and we would very much like to support them as | ||||
|  well, to offer application authors an even wider scope of choice. | ||||
|  | ||||
| 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. | ||||
|  | ||||
| Project cURL Angle of this Problem | ||||
|  | ||||
|  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: | ||||
|  | ||||
|  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 | ||||
|     functions. | ||||
|  | ||||
|  2. The CURLOPT_SSL_CTX_FUNCTION option is not possible to "emulate" on GnuTLS | ||||
|     but simply requires OpenSSL. | ||||
|  | ||||
| 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. | ||||
|  | ||||
| Fixing the Only Problem | ||||
|  | ||||
|  The only problem is thus for distributions that want to offer libcurl | ||||
|  versions built with more than one SSL/TLS library. | ||||
|  | ||||
|  Since multiple libcurl binaries using different names are ruled out, we need | ||||
|  to come up with a way to have one single libcurl that someone uses different | ||||
|  underlying libraries. The best(?) approach currently suggested involves this: | ||||
|  | ||||
|  A new intermediate library (named lib2 so far in the discussions) with the | ||||
|  single purpose of providing libcurl with SSL/TLS capabilities. It would have | ||||
|  a unified API and ABI no matter what underlying library it would use. | ||||
|  | ||||
|  There would be one lib2 binary provided for each supported SSL/TLS library. | ||||
|  For example: lib2-openssl, lib2-gnutls, lib2-yassl, lib2-matrixssl and | ||||
|  lib2-nossl. Yes, take note of the last one that provides the lib2 ABI but | ||||
|  that lacks the actual powers. | ||||
|  | ||||
|  When libcurl is built and linked, it will be linked against a lib2 with the | ||||
|  set ABI. | ||||
|  | ||||
|  When you link an app against libcurl, it would also need to provide one of | ||||
|  the (many) lib2 libs to decide what approach that fits the app. An app that | ||||
|  doesn't want SSL at all would still need to link with the lib2-nossl lib. | ||||
|  | ||||
|  GPL apps can pick the lib2-gnutls, others may pick the lib2-openssl. | ||||
|  | ||||
|  This concept works equally well both for shared and static libraries. | ||||
|  | ||||
|  A positive side effect of this approach could be a more generic "de facto" | ||||
|  standard API for SSL/TLS libraries. | ||||
|  | ||||
| When Will This Happen | ||||
|  | ||||
|  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. | ||||
|  | ||||
|  The suggestion that is outlined above is still only a suggestion. Feel free | ||||
|  to bring a better idea! | ||||
|  | ||||
|  Also, to keep in mind: I don't want this new concept to have too much of an | ||||
|  impact on the existing code. Preferably it should be possible to build the | ||||
|  code like today (without the use of lib2), should you decide to ignore the | ||||
|  problems outlined in this document. | ||||
|  | ||||
|  Update: Work on this has been initiated by Richard Atterer: | ||||
|  | ||||
|         http://curl.haxx.se/mail/lib-2005-09/0066.html | ||||
|  | ||||
| Footnotes | ||||
|  | ||||
|  [1] = http://www.xfree86.org/3.3.6/COPYRIGHT2.html#6 | ||||
|  [2] = http://www.fsf.org/licensing/essays/bsd.html | ||||
|  [3] = http://www.fsf.org/licensing/licenses/gpl.html | ||||
|  [4] = http://curl.haxx.se/docs/copyright.html | ||||
|  [5] = http://www.openssl.org/source/license.html | ||||
|  [6] = http://www.fsf.org/licensing/licenses/gpl.html end of section 3 | ||||
|  [7] = http://www.fsf.org/licensing/licenses/lgpl.html | ||||
|  [8] = http://en.wikipedia.org/wiki/OpenSSL_exception | ||||
|  | ||||
| Feedback/Updates provided by | ||||
|  | ||||
|  Eric Cooper | ||||
							
								
								
									
										157
									
								
								docs/FAQ
									
									
									
									
									
								
							
							
						
						
									
										157
									
								
								docs/FAQ
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| Updated: August 18, 2004 (http://curl.haxx.se/docs/faq.html) | ||||
| Updated: August 26, 2005 (http://curl.haxx.se/docs/faq.html) | ||||
|                                   _   _ ____  _ | ||||
|                               ___| | | |  _ \| | | ||||
|                              / __| | | | |_) | | | ||||
| @@ -42,6 +42,8 @@ FAQ | ||||
|   3.14 Does curl support javascript or pac (automated proxy config)? | ||||
|   3.15 Can I do recursive fetches with curl? | ||||
|   3.16 What certificates do I need when I use SSL? | ||||
|   3.17 How do I list the root dir of an FTP server? | ||||
|   3.18 Can I use curl to send a POST/PUT and not wait for a response? | ||||
|  | ||||
|  4. Running Problems | ||||
|   4.1 Problems connecting to SSL servers. | ||||
| @@ -62,6 +64,8 @@ FAQ | ||||
|   4.10 My HTTP request using HEAD, PUT or DELETE doesn't work! | ||||
|   4.11 Why does my HTTP range requests return the full document? | ||||
|   4.12 Why do I get "certificate verify failed" ? | ||||
|   4.13 Why is curl -R on Windows one hour off? | ||||
|   4.14 Redirects work in browser but not with curl! | ||||
|  | ||||
|  5. libcurl Issues | ||||
|   5.1 Is libcurl thread-safe? | ||||
| @@ -73,6 +77,9 @@ FAQ | ||||
|   5.7 Link errors when building libcurl on Windows! | ||||
|   5.8 libcurl.so.3: open failed: No such file or directory | ||||
|   5.9 How does libcurl resolve host names? | ||||
|   5.10 How do I prevent libcurl from writing the response to stdout? | ||||
|   5.11 How do I make libcurl not receive the whole HTTP response? | ||||
|   5.12 Can I make libcurl fake or hide my real IP address? | ||||
|  | ||||
|  6. License Issues | ||||
|   6.1 I have a GPL program, can I use the libcurl library? | ||||
| @@ -96,7 +103,7 @@ FAQ | ||||
|   cURL is the name of the project. The name is a play on 'Client for URLs', | ||||
|   originally with URL spelled in uppercase to make it obvious it deals with | ||||
|   URLs. The fact it can also be pronounced 'see URL' also helped, it works as | ||||
|   an abbrivation for "Client URL Request Library" or why not the recursive | ||||
|   an abbreviation for "Client URL Request Library" or why not the recursive | ||||
|   version: "Curl URL Request Library". | ||||
|  | ||||
|   The cURL project produces two products: | ||||
| @@ -127,11 +134,11 @@ FAQ | ||||
|  | ||||
|   We pronounce curl and cURL with an initial k sound: [kurl]. | ||||
|  | ||||
|   NOTE: there are numerous sub-projects and related projects that also use the | ||||
|   word curl in the project names in various combinations, but you should take | ||||
|   There are numerous sub-projects and related projects that also use the word | ||||
|   curl in the project names in various combinations, but you should take | ||||
|   notice that this FAQ is directed at the command-line tool named curl (and | ||||
|   libcurl the library), and may therefore not be valid for other curl-related | ||||
|   projects. | ||||
|   projects. (There is however a small section for the PHP/CURL in this FAQ.) | ||||
|  | ||||
|   1.2 What is libcurl? | ||||
|  | ||||
| @@ -192,15 +199,14 @@ FAQ | ||||
|  | ||||
|   1.5 Who makes curl? | ||||
|  | ||||
|   curl and libcurl are not made by any single individual. Sure, Daniel | ||||
|   Stenberg writes the major parts, but other persons' submissions are | ||||
|   curl and libcurl are not made by any single individual. Daniel Stenberg is | ||||
|   project leader and main developer, but other persons' submissions are | ||||
|   important and crucial. Anyone can contribute and post their changes and | ||||
|   improvements and have them inserted in the main sources (of course on the | ||||
|   condition that developers agree on that the fixes are good). | ||||
|  | ||||
|   The list of contributors in the docs/THANKS file is only a small part of all | ||||
|   the people that every day provide us with bug reports, suggestions, ideas | ||||
|   and source code. | ||||
|   The full list of the more than 400 contributors is found in the docs/THANKS | ||||
|   file. | ||||
|  | ||||
|   curl is developed by a community, with Daniel at the wheel. | ||||
|  | ||||
| @@ -215,12 +221,8 @@ FAQ | ||||
|   have sponsored certain parts of the development in the past and I hope some | ||||
|   will continue to do so in the future. | ||||
|  | ||||
|   If you want to support our project with a donation or similar, one way of | ||||
|   doing that would be to buy "gift certificates" at useful online shopping | ||||
|   sites, such as amazon.com or thinkgeek.com. Another way would be to sponsor | ||||
|   us through a banner-program or even better: by helping us coding, | ||||
|   documenting, testing etc. You're welcome to send us a buck using paypal, as | ||||
|   described here: http://curl.haxx.se/donation.html | ||||
|   If you want to support our project, consider a donation or a banner-program | ||||
|   or even better: by helping us coding, documenting, testing etc. | ||||
|  | ||||
|   1.7 What about CURL from curl.com? | ||||
|  | ||||
| @@ -251,6 +253,12 @@ FAQ | ||||
|   users thanks to the web based archives of the mailing lists), thus saving us | ||||
|   from having to repeat ourselves even more. Thanks for respecting this. | ||||
|  | ||||
|   If you have found or simply suspect a security problem in curl or libcurl, | ||||
|   mail curl-security at haxx.se (closed list of receivers, mails are not | ||||
|   disclosed) and tell. Then we can produce a fix in a timely manner before the | ||||
|   flaw is announced to the world, thus lessen the impact the problem will have | ||||
|   on existing users. | ||||
|  | ||||
|  | ||||
| 2. Install Related Problems | ||||
|  | ||||
| @@ -295,8 +303,8 @@ FAQ | ||||
|  | ||||
|   2.2 Does curl work/build with other SSL libraries? | ||||
|  | ||||
|   Curl has been written to use OpenSSL, although there should not be much | ||||
|   problems using a different library. If anyone does "port" curl to use a | ||||
|   Curl has been written to use OpenSSL or GnuTLS, although there should not be | ||||
|   many problems using a different library. If anyone does "port" curl to use a | ||||
|   different SSL library, we are of course very interested in getting the | ||||
|   patch! | ||||
|  | ||||
| @@ -391,6 +399,8 @@ FAQ | ||||
|  | ||||
|      curl -L http://redirector.com | ||||
|  | ||||
|   Not all redirects are HTTP ones, see 4.14 | ||||
|  | ||||
|   3.9 How do I use curl in my favorite programming language? | ||||
|  | ||||
|   There exist many language interfaces/bindings for curl that integrates it | ||||
| @@ -502,9 +512,9 @@ FAQ | ||||
|     If the server doesn't require this, you don't need a client certificate. | ||||
|  | ||||
|   - Server certificate. The server you communicate with has a server | ||||
|     certificate. You can and should verify this certficate to make sure that | ||||
|     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 verifaction process is made by using a | ||||
|     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 | ||||
| @@ -520,6 +530,22 @@ FAQ | ||||
|     that was signed by one of the authorities in the bundle. curl comes with a | ||||
|     default CA cert bundle. You can override the default. | ||||
|  | ||||
|   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 | ||||
|   in the first path part. List the "/tmp" dir like this: | ||||
|  | ||||
|      curl ftp://ftp.sunet.se/%2ftmp/ | ||||
|  | ||||
|   or the not-quite-kosher-but-more-readable way, by simply starting the path | ||||
|   section of the URL with a slash: | ||||
|  | ||||
|      curl ftp://ftp.sunet.se//tmp/ | ||||
|  | ||||
|   3.18 Can I use curl to send a POST/PUT and not wait for a response? | ||||
|   | ||||
|   No. | ||||
|  | ||||
|  | ||||
| 4. Running Problems | ||||
|  | ||||
| @@ -623,7 +649,10 @@ FAQ | ||||
|  | ||||
|   4.6 Can you tell me what error code 142 means? | ||||
|  | ||||
|   All error codes that are larger than the highest documented error code means | ||||
|   All curl error codes are described at the end of the man page, in the | ||||
|   section called "EXIT CODES". | ||||
|  | ||||
|   Error codes that are larger than the highest documented error code means | ||||
|   that curl has exited due to a crash. This is a serious error, and we | ||||
|   appreciate a detailed bug report from you that describes how we could go | ||||
|   ahead and repeat this! | ||||
| @@ -710,6 +739,28 @@ FAQ | ||||
|   Details are also in the SSLCERTS file in the release archives, found online | ||||
|   here: http://curl.haxx.se/docs/sslcerts.html | ||||
|  | ||||
|   4.13 Why is curl -R on Windows one hour off? | ||||
|  | ||||
|   During daylight savings time, when -R is used, curl will set a time that | ||||
|   appears one hour off. This happens due to a flaw in how Windows stores and | ||||
|   uses file modification times and it is not easily worked around. For details | ||||
|   on this problem, read this: http://www.codeproject.com/datetime/dstbugs.asp | ||||
|  | ||||
|   4.14 Redirects work in browser but not with curl! | ||||
|  | ||||
|   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. | ||||
|  | ||||
|     2 - 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 | ||||
|   parses the results and fetches the new URL. | ||||
|  | ||||
|  | ||||
| 5. libcurl Issues | ||||
|  | ||||
| @@ -717,12 +768,20 @@ FAQ | ||||
|  | ||||
|   Yes. | ||||
|  | ||||
|   We have written the libcurl code specificly adjusted for multi-threaded | ||||
|   We have written the libcurl code specifically adjusted for multi-threaded | ||||
|   programs. libcurl will use thread-safe functions instead of non-safe ones if | ||||
|   your system has such. | ||||
|  | ||||
|   We would appreciate some kind of report or README file from those who have | ||||
|   used libcurl in a threaded environment. | ||||
|   If you use a OpenSSL-powered libcurl in a multi-threaded environment, you | ||||
|   need to provide one or two locking functions: | ||||
|  | ||||
|     http://www.openssl.org/docs/crypto/threads.html#DESCRIPTION | ||||
|  | ||||
|   If you use a GnuTLS-powered libcurl in a multi-threaded environment, you | ||||
|   need to provide locking function(s) for libgcrypt (which is used by GnuTLS | ||||
|   for the crypto functions). | ||||
|  | ||||
|     http://www.gnu.org/software/gnutls/manual/html_node/Multi_002dthreaded-applications.html | ||||
|  | ||||
|   5.2 How can I receive all data into a large memory chunk? | ||||
|  | ||||
| @@ -806,13 +865,13 @@ FAQ | ||||
|   When building an application that uses the static libcurl library, you must | ||||
|   add -DCURL_STATICLIB to your CFLAGS. Otherwise the linker will look for | ||||
|   dynamic import symbols. If you get linker error like "unknown symbol | ||||
|   __imp__curl_easy_init ..." you have linked against the wrong (static) library. | ||||
|   If you want to use the curl.dll and import lib, you don't need any extra CFLAGS, | ||||
|   but use one of the import libraries below. These are the libraries produced by | ||||
|   the various lib/Makefile.* files: | ||||
|   __imp__curl_easy_init ..." you have linked against the wrong (static) | ||||
|   library.  If you want to use the libcurl.dll and import lib, you don't need | ||||
|   any extra CFLAGS, but use one of the import libraries below. These are the | ||||
|   libraries produced by the various lib/Makefile.* files: | ||||
|  | ||||
|   Target:          static lib.   import lib for curl*.dll. | ||||
|   -------------------------------------------------------- | ||||
|   Target:          static lib.   import lib for libcurl*.dll. | ||||
|   ----------------------------------------------------------- | ||||
|   MingW:           libcurl.a     libcurldll.a | ||||
|   MSVC (release):  libcurl.lib   libcurl_imp.lib | ||||
|   MSVC (debug):    libcurld.lib  libcurld_imp.lib | ||||
| @@ -861,6 +920,35 @@ FAQ | ||||
|     A - gethostbyname() on plain ipv4 windows hosts | ||||
|     B - getaddrinfo() on ipv6-enabled windows hosts | ||||
|  | ||||
|   Also note that libcurl never resolves or reverse-lookups addresses given as | ||||
|   pure numbers, such as 127.0.0.1 or ::1. | ||||
|  | ||||
|   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. | ||||
|  | ||||
|   5.11 How do I make libcurl not receive the whole HTTP response? | ||||
|  | ||||
|   You make the write callback (or progress callback) return an error and | ||||
|   libcurl will then abort the transfer. | ||||
|  | ||||
|   5.12 Can I make libcurl fake or hide my real IP address? | ||||
|  | ||||
|   No. libcurl operates on a higher level than so. Besides, faking IP address | ||||
|   would imply sending IP packages with a made-up source address, and then you | ||||
|   normally get a problem with intercepting the packages sent back as they | ||||
|   would then not be routed to you! | ||||
|  | ||||
|   If you use a proxy to access remote sites, the sites will not see your local | ||||
|   IP address but instead the address of the proxy. | ||||
|  | ||||
|   Also note that on many networks NATs or other IP-munging techniques are used | ||||
|   that makes you see and use a different IP address locally than what the | ||||
|   remote server will see you coming from. | ||||
|  | ||||
|  | ||||
| 6. License Issues | ||||
|  | ||||
|   Curl and libcurl are released under a MIT/X derivate license. The license is | ||||
| @@ -917,8 +1005,13 @@ FAQ | ||||
|   7.1 What is PHP/CURL? | ||||
|  | ||||
|   The module for PHP that makes it possible for PHP programs to access curl- | ||||
|   functions from within PHP. We often call it PHP/CURL to differentiate from | ||||
|   curl the command line tool and libcurl the library. | ||||
|   functions from within PHP. | ||||
|  | ||||
|   In the cURL project we call this module PHP/CURL to differentiate it from | ||||
|   curl the command line tool and libcurl the library. The PHP team however | ||||
|   does not refer to it like this (for unknown reasons). They call it plain | ||||
|   CURL (often using all caps) which causes much confusion to users which in | ||||
|   turn gives us a higher question load. | ||||
|  | ||||
|   7.2 Who write PHP/CURL? | ||||
|  | ||||
|   | ||||
| @@ -62,11 +62,11 @@ HTTP | ||||
|  | ||||
| HTTPS (*1) | ||||
|  - (all the HTTP features) | ||||
|  - using certificates | ||||
|  - using client certificates | ||||
|  - verify server certificate | ||||
|  - via http-proxy | ||||
|  - select desired encryption | ||||
|  - force usage of a specific SSL version (SSLv2, SSLv3 or TLSv1) | ||||
|  - force usage of a specific SSL version (SSLv2(*7), SSLv3 or TLSv1) | ||||
|  | ||||
| FTP | ||||
|  - download | ||||
| @@ -118,9 +118,10 @@ FILE | ||||
| FOOTNOTES | ||||
| ========= | ||||
|  | ||||
|   *1 = requires OpenSSL | ||||
|   *1 = requires OpenSSL or GnuTLS | ||||
|   *2 = requires OpenLDAP | ||||
|   *3 = requires a GSSAPI-compliant library, such as Heimdal or similar. | ||||
|   *4 = requires FBopenssl | ||||
|   *5 = requires a krb4 library, such as the MIT one or similar. | ||||
|   *6 = requires c-ares | ||||
|   *7 = requires OpenSSL specificly, as GnuTLS only supports SSLv3 and TLSv1 | ||||
|   | ||||
							
								
								
									
										12
									
								
								docs/HISTORY
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								docs/HISTORY
									
									
									
									
									
								
							| @@ -114,6 +114,8 @@ distributions and otherwise retrieved as part of other software. | ||||
| September 2002, with the release of curl 7.10 it is released under the MIT | ||||
| license only. | ||||
|  | ||||
| January 2003. Started working on the distributed curl tests. The autobuilds. | ||||
|  | ||||
| February 2003, the curl site averages at 20000 visits weekly. At any given | ||||
| moment, there's an average of 3 people browsing the curl.haxx.se site. | ||||
|  | ||||
| @@ -139,3 +141,13 @@ August 2004: | ||||
|  Number of public functions in libcurl:    36 | ||||
|  Amount of public web site mirrors:        12 | ||||
|  Number of known libcurl bindings:         26 | ||||
|  | ||||
| April 2005: | ||||
|  | ||||
| GnuTLS can now optionally be used for the secure layer when curl is built. | ||||
|  | ||||
| September 2005: | ||||
|  | ||||
| TFTP support was added. | ||||
|  | ||||
| More than 100,000 unique visitors of the curl web site. 25 mirrors. | ||||
|   | ||||
							
								
								
									
										39
									
								
								docs/INSTALL
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								docs/INSTALL
									
									
									
									
									
								
							| @@ -293,6 +293,13 @@ Win32 | ||||
|       - 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. | ||||
|  | ||||
|  | ||||
| IBM OS/2 | ||||
| ======== | ||||
|  | ||||
| @@ -455,21 +462,19 @@ NetWare | ||||
|    - 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/ | ||||
|    - optional OpenSSL sources (version 0.9.8 or later which builds with BSD); | ||||
|  | ||||
|    Set a search path to your compiler, linker and tools; if you want to have | ||||
|    zlib support then set the environment var ZLIB_PATH pointing to your zlib | ||||
|    sources, on Linux make sure the var OSTYPE contains the string 'linux'; | ||||
|    and finally type 'make netware' from the top source directory... | ||||
|    I found on some Linux systems (RH9) that OS detection didnlt work although | ||||
|    Set a search path to your compiler, linker and tools; on Linux make | ||||
|    sure that the var OSTYPE contains the string 'linux'; and then type | ||||
|    'make netware' from the top source directory; other tagets available | ||||
|    are 'netware-ssl', 'netware-ssl-zlib', 'netware-zlib' and 'netware-ares'; | ||||
|    if you need other combinations you can control the build with the | ||||
|    environment variables WITH_SSL, WITH_ZLIB, WITH_ARES and ENABLE_IPV6. | ||||
|    I found on some Linux systems (RH9) that OS detection didnt work although | ||||
|    a 'set | grep OSTYPE' shows the var present and set; I simply overwrote it | ||||
|    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked...; | ||||
|    other options are currently not supported, although partly prepared. | ||||
|    The Ares lib builds arlready fine, and both test tools work fine at least  | ||||
|    when build with CodeWarrior...; don't know yet why they fail when build with | ||||
|    gcc though; if you want to compile with Ares support then set an env var | ||||
|    WITH_ARES=1; I've not tested yet including libares into curl. | ||||
|    with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked... | ||||
|    Any help in testing appreciated! | ||||
|    Builds automatically created 4 times a day from current CVS are here: | ||||
|    Builds automatically created 8 times a day from current CVS are here: | ||||
|    http://www.gknw.com/mirror/curl/autobuilds/ | ||||
|    the status of these builds can be viewed at the autobuild table: | ||||
|    http://curl.haxx.se/auto/ | ||||
| @@ -571,17 +576,17 @@ PORTS | ||||
|         - MIPS IRIX 6.2, 6.5 | ||||
|         - MIPS Linux | ||||
|         - Pocket PC/Win CE 3.0 | ||||
|         - Power AIX 3.2.5, 4.2, 4.3.1, 4.3.2, 5.1 | ||||
|         - Power AIX 3.2.5, 4.2, 4.3.1, 4.3.2, 5.1, 5.2 | ||||
|         - PowerPC Darwin 1.0 | ||||
|         - PowerPC Linux | ||||
|         - PowerPC Mac OS 9 | ||||
|         - PowerPC Mac OS X | ||||
|         - SINIX-Z v5 | ||||
|         - Sparc Linux | ||||
|         - Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8 | ||||
|         - Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8, 9, 10 | ||||
|         - Sparc SunOS 4.1.X | ||||
|         - StrongARM (and other ARM) RISC OS 3.1, 4.02 | ||||
|         - StrongARM Linux 2.4 | ||||
|         - StrongARM/ARM7/ARM9 Linux 2.4, 2.6 | ||||
|         - StrongARM NetBSD 1.4.1 | ||||
|         - Ultrix 4.3a | ||||
|         - i386 BeOS | ||||
| @@ -589,14 +594,14 @@ PORTS | ||||
|         - i386 Esix 4.1 | ||||
|         - i386 FreeBSD | ||||
|         - i386 HURD | ||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4 | ||||
|         - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 | ||||
|         - i386 NetBSD | ||||
|         - i386 Novell NetWare | ||||
|         - i386 OS/2 | ||||
|         - i386 OpenBSD | ||||
|         - i386 SCO unix | ||||
|         - i386 Solaris 2.7 | ||||
|         - i386 Windows 95, 98, ME, NT, 2000 | ||||
|         - i386 Windows 95, 98, ME, NT, 2000, XP, 2003 | ||||
|         - i386 QNX 6 | ||||
|         - i486 ncr-sysv4.3.03 (NCR MP-RAS) | ||||
|         - ia64 Linux 2.3.99 | ||||
|   | ||||
| @@ -3,58 +3,107 @@ 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! | ||||
|  | ||||
| * Test case 165 might fail on system which has libidn present, but with an | ||||
| 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. | ||||
|  | ||||
| 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 | ||||
|   to VMS file structures and the perceived file sizes stat() returns. A | ||||
|   possible fix would involve sending a "STRU VMS" command. | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1156287 | ||||
|    | ||||
| 21. FTP ASCII transfers do not follow RFC959. They don't convert the data | ||||
|    accordingly (not for sending nor for receiving). RFC 959 section 3.1.1.1 | ||||
|    clearly describes how this should be done: | ||||
|  | ||||
|      The sender converts the data from an internal character representation to | ||||
|      the standard 8-bit NVT-ASCII representation (see the Telnet | ||||
|      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! | ||||
|  | ||||
| 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 | ||||
|   curl_unescape does not detect this, but instead returns a shortened C | ||||
|   string.  From a strict FTP protocol standpoint, NUL is a valid character | ||||
|   within RFC 959 <string>, so the way to handle this correctly in curl would | ||||
|   be to use a data structure other than a plain C string, one that can handle | ||||
|   embedded NUL characters.  From a practical standpoint, most FTP servers | ||||
|   would not meaningfully support NUL characters within RFC 959 <string>, | ||||
|   anyway (e.g., UNIX pathnames may not contain NUL). | ||||
|  | ||||
| 14. Test case 165 might fail on system which has libidn present, but with an | ||||
|   old iconv version (2.1.3 is a known bad version), since it doesn't recognize | ||||
|   the charset when named ISO8859-1. Changing the name to ISO-8859-1 makes the | ||||
|   test pass, but instead makes it fail on Solaris hosts that use its native | ||||
|   iconv. | ||||
|  | ||||
| * curl version 7.12.2 fails on AIX if compiled with --enable-ares. | ||||
| 13. curl version 7.12.2 fails on AIX if compiled with --enable-ares. | ||||
|   The workaround is to combine --enable-ares with --disable-shared | ||||
|  | ||||
| * When connecting to a SOCKS proxy, the (connect) timeout is not properly | ||||
| 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. | ||||
|  | ||||
| * Using configure --disable-[protocol] may cause 'make test' to fail for | ||||
| 11. Using configure --disable-[protocol] may cause 'make test' to fail for | ||||
|   tests using the disabled protocol(s). | ||||
|  | ||||
| * To get HTTP Negotiate authentication to work fine, you need to provide a | ||||
| 10. To get HTTP Negotiate authentication to work fine, you need to provide a | ||||
|   (fake) user name (this concerns both curl and the lib) because the code | ||||
|   wrongly only considers authentication if there's a user name provided. | ||||
|   Bug report #1004841. How? http://curl.haxx.se/mail/lib-2004-08/0182.html | ||||
|   http://curl.haxx.se/bug/view.cgi?id=1004841. How? | ||||
|   http://curl.haxx.se/mail/lib-2004-08/0182.html | ||||
|  | ||||
| * --limit-rate using -d or -F does not work. This is because the limit logic | ||||
| 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! Bug report #921395. | ||||
|   -d/-F the callbacks aren't used! http://curl.haxx.se/bug/view.cgi?id=921395 | ||||
|  | ||||
| * Doing resumed upload over HTTP does not work with '-C -', because curl | ||||
| 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]'. | ||||
|  | ||||
| * CURLOPT_USERPWD and CURLOPT_PROXYUSERPWD have no way of providing user names | ||||
| 7. CURLOPT_USERPWD and CURLOPT_PROXYUSERPWD have no way of providing user names | ||||
|   that contain a colon. This can't be fixed easily in a backwards compatible | ||||
|   way without adding new options (and then, they should most probably allow | ||||
|   setting user name and password separately). | ||||
|  | ||||
| * libcurl ignores empty path parts in FTP URLs, whereas RFC1738 states that | ||||
| 6. libcurl ignores empty path parts in FTP URLs, whereas RFC1738 states that | ||||
|   such parts should be sent to the server as 'CWD ' (without an argument). | ||||
|   The only exception to this rule, is that we knowingly break this if the | ||||
|   empty part is first in the path, as then we use the double slashes to | ||||
|   indicate that the user wants to reach the root dir (this exception SHALL | ||||
|   remain even when this bug is fixed). | ||||
|  | ||||
| * libcurl doesn't treat the content-length of compressed data properly, as | ||||
| 5. libcurl doesn't treat the content-length of compressed data properly, as | ||||
|   it seems HTTP servers send the *uncompressed* length in that header and | ||||
|   libcurl thinks of it as the *compressed* lenght. Some explanations are here: | ||||
|   libcurl thinks of it as the *compressed* length. Some explanations are here: | ||||
|   http://curl.haxx.se/mail/lib-2003-06/0146.html | ||||
|  | ||||
| * IPv6 support on AIX 4.3.3 doesn't work due to a missing sockaddr_storage | ||||
|   struct. It has been reported to work on AIX 5.1 though. | ||||
| 3. GOPHER transfers seem broken | ||||
|  | ||||
| * GOPHER transfers seem broken | ||||
|  | ||||
| * If a HTTP server responds to a HEAD request and includes a body (thus | ||||
| 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 | ||||
|   immediately made to the same server again, the connection will be re-used | ||||
|   | ||||
| @@ -12,12 +12,11 @@ I am not a lawyer and this is not legal advice! | ||||
|  | ||||
| One common dilemma is that GPL[1]-licensed code is not allowed to be linked | ||||
| with code licensed under the Original BSD license (with the announcement | ||||
| clause, unless there's a specified exception in the GPL-licensed module). You | ||||
| may still build your own copies that use them all, but distributing them as | ||||
| binaries would be to violate the GPL license - unless you accompany your | ||||
| license with an exception[2]. This particular problem was addressed when the | ||||
| Modified BSD license was created, which does not have the annoncement clause | ||||
| that collides with GPL. | ||||
| clause). You may still build your own copies that use them all, but | ||||
| distributing them as binaries would be to violate the GPL license - unless you | ||||
| accompany your license with an exception[2]. This particular problem was | ||||
| addressed when the Modified BSD license was created, which does not have the | ||||
| annoncement clause that collides with GPL. | ||||
|  | ||||
| libcurl http://curl.haxx.se/docs/copyright.html | ||||
|  | ||||
| @@ -28,21 +27,30 @@ libcurl http://curl.haxx.se/docs/copyright.html | ||||
|  | ||||
| OpenSSL http://www.openssl.org/source/license.html | ||||
|  | ||||
|         Uses an Original BSD-style license with an announement clause that | ||||
|         makes it "incompatible" with GPL. You are not allowed to ship binaries | ||||
|         that link with OpenSSL that includes GPL code (unless that specific | ||||
|         GPL code includes an exception for OpenSSL - a habit that is growing | ||||
|         more and more common). | ||||
|         (May be used for SSL/TLS support) Uses an Original BSD-style license | ||||
|         with an announement clause that makes it "incompatible" with GPL. You | ||||
|         are not allowed to ship binaries that link with OpenSSL that includes | ||||
|         GPL code (unless that specific GPL code includes an exception for | ||||
|         OpenSSL - a habit that is growing more and more common). If OpenSSL's | ||||
|         licensing is a problem for you, consider using GnuTLS instead. | ||||
|  | ||||
| GnuTLS  http://www.gnutls.org/ | ||||
|  | ||||
|         (May be used for SSL/TLS support) Uses the LGPL[3] license. If this is | ||||
|         a problem for you, consider using OpenSSL instead. Also note that | ||||
|         GnuTLS itself depends on and uses other libs (libgcrypt and | ||||
|         libgpg-error) and they too are LGPL- or GPL-licensed. | ||||
|  | ||||
| c-ares  http://daniel.haxx.se/projects/c-ares/license.html | ||||
|  | ||||
|         Uses an MIT license that is very liberal and imposes no restrictions | ||||
|         on any other library or part you may link with. | ||||
|         (Used for asynchronous name resolves) Uses an MIT license that is very | ||||
|         liberal and imposes no restrictions on any other library or part you | ||||
|         may link with. | ||||
|  | ||||
| zlib    http://www.gzip.org/zlib/zlib_license.html | ||||
|  | ||||
|         Uses an MIT-style license that shouldn't collide with any other | ||||
|         library. | ||||
|         (Used for compressed Transfer-Encoding support) Uses an MIT-style | ||||
|         license that shouldn't collide with any other library. | ||||
|  | ||||
| krb4 | ||||
|  | ||||
| @@ -52,35 +60,47 @@ krb4 | ||||
|         of the code in libcurl that is written to deal with Kerberos4 likewise | ||||
|         have such a license. | ||||
|  | ||||
| GSSAPI | ||||
| MIT Kerberos http://web.mit.edu/kerberos/www/dist/ | ||||
|  | ||||
|         While nothing in particular says that a GSS/Kerberos5 library must use | ||||
|         any particular license, the one I've used (Heimdal) is Original BSD- | ||||
|         licensed with the announcement clause. | ||||
|         (May be used for GSS support) MIT licensed, that shouldn't collide | ||||
|         with any other parts. | ||||
|  | ||||
| Heimdal http://www.pdc.kth.se/heimdal/ | ||||
|  | ||||
|         (May be used for GSS support) Heimdal is Original BSD licensed with | ||||
|         the announcement clause. | ||||
|  | ||||
| GNU GSS http://www.gnu.org/software/gss/ | ||||
|  | ||||
|         (May be used for GSS support) GNU GSS is GPL licensed. Note that you | ||||
|         may not distribute binary curl packages that uses this if you build | ||||
|         curl to also link and use any Original BSD licensed libraries! | ||||
|  | ||||
| fbopenssl | ||||
|  | ||||
|         Unclear license. Based on its name, I assume that it uses the OpenSSL | ||||
|         license and thus shares the same issues as described for OpenSSL | ||||
|         above. | ||||
|         (Used for SPNEGO support) Unclear license. Based on its name, I assume | ||||
|         that it uses the OpenSSL license and thus shares the same issues as | ||||
|         described for OpenSSL above. | ||||
|  | ||||
| libidn  http://www.gnu.org/licenses/lgpl.html | ||||
|  | ||||
|         Uses the GNU Lesser General Public License. LGPL is a variation of GPL | ||||
|         with slightly less aggressive "copyleft". This license requires more | ||||
|         requirements to be met when distributing binaries, see the license for | ||||
|         details. Also note that if you distribute a binary that includes this | ||||
|         library, you must also include the full LGPL license text. Please | ||||
|         properly point out what parts of the distributed package that the | ||||
|         license addresses. | ||||
|         (Used for IDNA support) Uses the GNU Lesser General Public | ||||
|         License. LGPL is a variation of GPL with slightly less aggressive | ||||
|         "copyleft". This license requires more requirements to be met when | ||||
|         distributing binaries, see the license for details. Also note that if | ||||
|         you distribute a binary that includes this library, you must also | ||||
|         include the full LGPL license text. Please properly point out what | ||||
|         parts of the distributed package that the license addresses. | ||||
|  | ||||
| OpenLDAP http://www.openldap.org/software/release/license.html | ||||
|  | ||||
|         Uses a Modified BSD-style license. Since libcurl uses OpenLDAP as a | ||||
|         shared library only, I have not heard of anyone that ships OpenLDAP | ||||
|         linked with libcurl in an app. | ||||
|         (Used for LDAP support) Uses a Modified BSD-style license. Since | ||||
|         libcurl uses OpenLDAP as a shared library only, I have not heard of | ||||
|         anyone that ships OpenLDAP linked with libcurl in an app. | ||||
|  | ||||
|  | ||||
| [1] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html | ||||
| [2] = http://www.fsf.org/licenses/gpl-faq.html#GPLIncompatibleLibs details on | ||||
|       how to write such an exception to the GPL | ||||
| [3] = LGPL - GNU Lesser General Public License: | ||||
|       http://www.gnu.org/licenses/lgpl.html | ||||
|   | ||||
| @@ -299,6 +299,13 @@ POST (HTTP) | ||||
|  | ||||
|         curl -F "docpicture=@dog.gif" -F "catpicture=@cat.gif"  | ||||
|  | ||||
|   To send a field value literally without interpreting a leading '@' | ||||
|   or '<', or an embedded ';type=', use --form-string instead of | ||||
|   -F. This is recommended when the value is obtained from a user or | ||||
|   some other unpredictable source. Under these circumstances, using | ||||
|   -F instead of --form-string would allow a user to trick curl into | ||||
|   uploading a file. | ||||
|  | ||||
| REFERRER | ||||
|  | ||||
|   A HTTP request has the option to include information about which address | ||||
|   | ||||
| @@ -17,7 +17,7 @@ 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 | ||||
|  $(PDFPAGES) LICENSE-MIXING README.netware DISTRO-DILEMMA | ||||
|  | ||||
| MAN2HTML= roffit < $< >$@ | ||||
|  | ||||
|   | ||||
							
								
								
									
										557
									
								
								docs/THANKS
									
									
									
									
									
								
							
							
						
						
									
										557
									
								
								docs/THANKS
									
									
									
									
									
								
							| @@ -1,110 +1,457 @@ | ||||
|  This project has been alive for several years. Countless people have provided | ||||
|  feedback that have improved curl. Here follows a (incomplete) list of people | ||||
|  that have contributed with non-trivial parts: | ||||
|  This project has been alive for many years. Countless people have provided | ||||
|  feedback that have improved curl. Here follows a list of people that have | ||||
|  contributed (a-z order). | ||||
|  | ||||
| Daniel Stenberg <daniel@haxx.se> | ||||
| Rafael Sagula <sagula@inf.ufrgs.br> | ||||
| Sampo Kellomaki <sampo@iki.fi> | ||||
| Linas Vepstas <linas@linas.org> | ||||
| Bjorn Reese <breese@mail1.stofanet.dk> | ||||
| Johan Anderson <johan@homemail.com> | ||||
| Kjell Ericson <Kjell.Ericson@haxx.se> | ||||
| Troy Engel <tengel@sonic.net> | ||||
| Ryan Nelson <ryan@inch.com> | ||||
| Bj<EFBFBD>rn Stenberg <bjorn@haxx.se> | ||||
| Angus Mackay <amackay@gus.ml.org> | ||||
| Eric Young <eay@cryptsoft.com> | ||||
| Simon Dick <simond@totally.irrelevant.org> | ||||
| Oren Tirosh <oren@monty.hishome.net> | ||||
| Steven G. Johnson <stevenj@alum.mit.edu> | ||||
| Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu> | ||||
| Andr<EFBFBD>s Garc<72>a <ornalux@redestb.es> | ||||
| Douglas E. Wegscheid <wegscd@whirlpool.com> | ||||
| Mark Butler <butlerm@xmission.com> | ||||
| Eric Thelin <eric@generation-i.com> | ||||
| Marc Boucher <marc@mbsi.ca> | ||||
| Greg Onufer <Greg.Onufer@Eng.Sun.COM> | ||||
| Doug Kaufman <dkaufman@rahul.net> | ||||
| David Eriksson <david@2good.com> | ||||
| Ralph Beckmann <rabe@uni-paderborn.de> | ||||
| T. Yamada <tai@imasy.or.jp> | ||||
| Lars J. Aas <larsa@sim.no> | ||||
| J<EFBFBD>rn Hartroth <Joern.Hartroth@computer.org> | ||||
| Matthew Clarke <clamat@van.maves.ca> | ||||
| Linus Nielsen Feltzing <linus@haxx.se> | ||||
| Felix von Leitner <felix@convergence.de> | ||||
| Dan Zitter <dzitter@zitter.net> | ||||
| Jongki Suwandi <Jongki.Suwandi@eng.sun.com> | ||||
| Chris Maltby <chris@aurema.com> | ||||
| Ron Zapp <rzapper@yahoo.com> | ||||
| Paul Marquis <pmarquis@iname.com> | ||||
| Ellis Pritchard <ellis@citria.com> | ||||
| Damien Adant <dams@usa.net> | ||||
| Chris <cbayliss@csc.come> | ||||
| Marco G. Salvagno <mgs@whiz.cjb.net> | ||||
| Paul Marquis <pmarquis@iname.com> | ||||
| David LeBlanc <dleblanc@qnx.com> | ||||
| Rich Gray at Plus Technologies | ||||
| Luong Dinh Dung <u8luong@lhsystems.hu> | ||||
| Torsten Foertsch <torsten.foertsch@gmx.net> | ||||
| Kristian K<>hntopp <kris@koehntopp.de> | ||||
| Fred Noz <FNoz@siac.com> | ||||
| Caolan McNamara <caolan@csn.ul.ie> | ||||
| Albert Chin-A-Young <china@thewrittenword.com> | ||||
| Stephen Kick <skick@epicrealm.com> | ||||
| Martin Hedenfalk <mhe@stacken.kth.se> | ||||
| Richard Prescott <rip at step.polymtl.ca> | ||||
| Jason S. Priebe <priebe@wral-tv.com> | ||||
| T. Bharath <TBharath@responsenetworks.com> | ||||
| Alexander Kourakos <awk@users.sourceforge.net> | ||||
| James Griffiths <griffiths_james@yahoo.com> | ||||
| Loic Dachary <loic@senga.org> | ||||
| Robert Weaver <robert.weaver@sabre.com> | ||||
| Ingo Ralf Blum <ingoralfblum@ingoralfblum.com> | ||||
| Jun-ichiro itojun Hagino <itojun@iijlab.net> | ||||
| Frederic Lepied <flepied@mandrakesoft.com> | ||||
| Georg Horn <horn@koblenz-net.de> | ||||
| Cris Bailiff <c.bailiff@awayweb.com> | ||||
| Sterling Hughes <sterling@designmultimedia.com> | ||||
| S. Moonesamy | ||||
| Ingo Wilken <iw@WWW.Ecce-Terram.DE> | ||||
| Pawel A. Gajda <mis@k2.net.pl> | ||||
| Patrick Bihan-Faou | ||||
| Nico Baggus <Nico.Baggus@mail.ing.nl> | ||||
| Sergio Ballestrero | ||||
| Andrew Francis <locust@familyhealth.com.au> | ||||
| Tomasz Lacki <Tomasz.Lacki@primark.pl> | ||||
| Georg Huettenegger <georg@ist.org> | ||||
| John Lask <johnlask@hotmail.com> | ||||
| Eric Lavigne <erlavigne@wanadoo.fr> | ||||
| Marcus Webster <marcus.webster@phocis.com> | ||||
| G<EFBFBD>tz Babin-Ebell <babin<69>ebell@trustcenter.de> | ||||
| Andreas Damm <andreas-sourceforge@radab.org> | ||||
| Jacky Lam <sylam@emsoftltd.com> | ||||
| James Gallagher <jgallagher@gso.uri.edu> | ||||
| Kjetil Jacobsen <kjetilja@cs.uit.no> | ||||
| Markus F.X.J. Oberhumer <markus@oberhumer.com> | ||||
| Miklos Nemeth <mnemeth@kfkisystems.com> | ||||
| Kevin Roth <kproth@users.sourceforge.net> | ||||
| Ralph Mitchell <rmitchell@eds.com> | ||||
| Dan Fandrich <dan@coneharvesters.com> | ||||
| Jean-Philippe Barrette-LaPierre <jpb@rrette.com> | ||||
| Richard Bramante <RBramante@on.com> | ||||
| Daniel Kouril <kouril@ics.muni.cz> | ||||
| Dirk Manske <dm@nettraffic.de> | ||||
| David Meyer <meyer@paracel.com> | ||||
| Dominick Meglio <codemstr@ptd.net> | ||||
| Gisle Vanem <gvanem@broadpark.no> | ||||
| Giuseppe Attardi <attardi@di.unipi.it> | ||||
| Tor Arntsen <tor@spacetec.no> | ||||
| David Byron <DByron@everdreamcorp.com> | ||||
| David Phillips | ||||
|  If you have contributed but are missing here, please let us know! | ||||
|  | ||||
| Adrian Schuur | ||||
| Alan Pinstein | ||||
| Albert Chin-A-Young | ||||
| Albert Choy | ||||
| Aleksandar Milivojevic | ||||
| Alex Neblett | ||||
| Alex Suykov | ||||
| Alex aka WindEagle | ||||
| Alexander Kourakos | ||||
| Alexander Krasnostavsky | ||||
| G<EFBFBD>nter Knauf | ||||
| Alexander Zhuravlev | ||||
| Alexis Carvalho | ||||
| Andi Jahja | ||||
| Andreas Damm | ||||
| Andreas Olsson | ||||
| Andreas Rieke | ||||
| Andres Garcia | ||||
| Andrew Bushnell | ||||
| Andrew Francis | ||||
| Andrew Fuller | ||||
| Andr<EFBFBD>s Garc<72>a | ||||
| Andy Cedilnik | ||||
| Andy Serpa | ||||
| Angus Mackay | ||||
| Antoine Calando | ||||
| Anton Kalmykov | ||||
| Arkadiusz Miskiewicz | ||||
| Augustus Saunders | ||||
| Avery Fay | ||||
| Ben Greear | ||||
| Benjamin Gerard | ||||
| Bertrand Demiddelaer | ||||
| Peter Sylvester | ||||
| Alexis S. L. Carvalho | ||||
| Bjorn Reese | ||||
| Bj<EFBFBD>rn Stenberg | ||||
| Bob Schader | ||||
| Brad Burdick | ||||
| Brent Beardsley | ||||
| Brian Akins | ||||
| Brian R Duffy | ||||
| Bruce Mitchener | ||||
| Bryan Henderson | ||||
| Bryan Henderson  | ||||
| Bryan Kemp | ||||
| Caolan McNamara | ||||
| Casey O'Donnell | ||||
| Marty Kuhrt | ||||
| James Bursa | ||||
| Chih-Chung Chang | ||||
| Chris "Bob Bob" | ||||
| Chris Combes | ||||
| Chris Gaukroger | ||||
| Chris Maltby | ||||
| Christian Kurz | ||||
| Christian Robottom Reis | ||||
| Christophe Demory | ||||
| Christophe Legry | ||||
| Christopher R. Palmer | ||||
| Clarence Gardner | ||||
| Clifford Wolf | ||||
| Cody Jones | ||||
| Colin Watson | ||||
| Colm Buckley | ||||
| Cory Nelson | ||||
| Craig Davison | ||||
| Craig Markwardt | ||||
| Cris Bailiff | ||||
| Cyrill Osterwalder | ||||
| Damien Adant | ||||
| Dan Becker | ||||
| Dan C | ||||
| Dan Fandrich | ||||
| Dan Torop | ||||
| Dan Zitter | ||||
| Daniel Stenberg | ||||
| Daniel at touchtunes | ||||
| Dave Dribin | ||||
| Dave Halbakken | ||||
| Dave Hamilton | ||||
| Dave May | ||||
| David Byron | ||||
| David Cohen | ||||
| David Eriksson | ||||
| David Houlder | ||||
| David Hull | ||||
| David J Meyer | ||||
| David James | ||||
| David Kimdon | ||||
| David LeBlanc | ||||
| David Odin | ||||
| David Phillips | ||||
| David Shaw | ||||
| David Tarendash | ||||
| David Thiel | ||||
| Detlef Schmier | ||||
| Diego Casorran | ||||
| Dimitris Sarris | ||||
| Dinar | ||||
| Dirk Eddelbuettel | ||||
| Dirk Manske | ||||
| Dolbneff A.V | ||||
| Domenico Andreoli | ||||
| Dominick Meglio | ||||
| Doug Kaufman | ||||
| Doug Porter | ||||
| Douglas E. Wegscheid | ||||
| Douglas R. Horner | ||||
| Dustin Boswell | ||||
| Dylan Ellicott | ||||
| Dylan Salisbury | ||||
| Early Ehlinger | ||||
| Edin Kadribasic | ||||
| Ellis Pritchard | ||||
| Emiliano Ida | ||||
| Enrico Scholz | ||||
| Enrik Berkhan | ||||
| Eric Cooper | ||||
| Eric Lavigne | ||||
| Eric Melville | ||||
| Eric Rautman | ||||
| Eric Thelin | ||||
| Eric Vergnaud | ||||
| Eric Young | ||||
| Erick Nuwendam | ||||
| Erwan Legrand | ||||
| Erwin Authried | ||||
| Evan Jordan | ||||
| Fabrizio Ammollo | ||||
| Fedor Karpelevitch | ||||
| Felix von Leitner | ||||
| Florian Schoppmann | ||||
| Forrest Cahoon | ||||
| Frank Keeney | ||||
| Frank Ticheler | ||||
| Fred New | ||||
| Fred Noz | ||||
| Frederic Lepied | ||||
| Gautam Mani | ||||
| Gaz Iqbal | ||||
| Georg Horn | ||||
| Georg Huettenegger | ||||
| Georg Wicherski | ||||
| Gerd v. Egidy | ||||
| Gerhard Herre | ||||
| Giaslas Georgios | ||||
| Gilad | ||||
| Gilbert Ramirez Jr. | ||||
| Gisle Vanem | ||||
| Giuseppe Attardi | ||||
| Giuseppe D'Ambrosio | ||||
| Glen Nakamura | ||||
| Glen Scott | ||||
| Greg Hewgill | ||||
| Greg Onufer | ||||
| Grigory Entin | ||||
| Guenole Bescon | ||||
| Guillaume Arluison | ||||
| Gustaf Hui | ||||
| Gwenole Beauchesne | ||||
| G<EFBFBD>tz Babin-Ebell | ||||
| G<EFBFBD>nter Knauf | ||||
| Hamish Mackenzie | ||||
| Hanno Kranzhoff | ||||
| Hans Steegers | ||||
| Hardeep Singh | ||||
| Harshal Pradhan | ||||
| Heikki Korpela | ||||
| Henrik Storner | ||||
| Hzhijun | ||||
| Ian Ford | ||||
| Ian Gulliver | ||||
| Ian Wilkes | ||||
| Ignacio Vazquez-Abrams | ||||
| Igor Polyakov | ||||
| Ilguiz Latypov | ||||
| Ingo Ralf Blum | ||||
| Ingo Wilken | ||||
| Jacky Lam | ||||
| Jacob Meuser | ||||
| James Bursa | ||||
| James Clancy | ||||
| James Cone | ||||
| James Gallagher | ||||
| James Griffiths | ||||
| James MacMillan | ||||
| Jamie Lokier | ||||
| Jamie Wilkinson | ||||
| Jason S. Priebe | ||||
| Jean-Claude Chauve | ||||
| Jean-Louis Lemaire | ||||
| Jean-Marc Ranger | ||||
| Jean-Philippe Barrette-LaPierre | ||||
| Jeff Lawson | ||||
| Jeff Phillips | ||||
| Jeff Pohlmeyer | ||||
| Jeffrey Pohlmeyer | ||||
| Jeremy Friesner | ||||
| Jesper Jensen | ||||
| Jesse Noller | ||||
| Jim Drash | ||||
| Joe Halpin | ||||
| Joel Chen | ||||
| Johan Anderson | ||||
| Johan Nilsson | ||||
| John Crow | ||||
| John Janssen | ||||
| John Lask | ||||
| John McGowan | ||||
| Jon Grubbs | ||||
| Jon Travis | ||||
| Jon Turner | ||||
| Jonas Forsman | ||||
| Jonatan Lander | ||||
| Jonathan Hseu | ||||
| Jongki Suwandi | ||||
| Josh Kapell | ||||
| Juan F. Codagnone | ||||
| Juan Ignacio Herv<72>s | ||||
| Juergen Wilke | ||||
| Jukka Pihl | ||||
| Julian Noble | ||||
| Jun-ichiro itojun Hagino | ||||
| Jurij Smakov | ||||
| J<EFBFBD>rg Mueller-Tolk | ||||
| J<EFBFBD>rn Hartroth | ||||
| Kai Sommerfeld | ||||
| Kai-Uwe Rommel | ||||
| Kang-Jin Lee | ||||
| Karol Pietrzak | ||||
| Keith MacDonald | ||||
| Keith McGuigan | ||||
| Ken Hirsch | ||||
| Ken Rastatter | ||||
| Kevin Fisk | ||||
| Kevin Lussier | ||||
| Kevin Roth | ||||
| Kimmo Kinnunen | ||||
| Kjell Ericson | ||||
| Kjetil Jacobsen | ||||
| Klevtsov Vadim | ||||
| Kris Kennaway | ||||
| Krishnendu Majumdar | ||||
| Kristian K<>hntopp | ||||
| Kyle Sallee | ||||
| Lachlan O'Dea | ||||
| Larry Campbell | ||||
| Larry Fahnoe | ||||
| Lars Gustafsson | ||||
| Lars J. Aas | ||||
| Lars Nilsson | ||||
| Lars Torben Wilson | ||||
| Legoff Vincent | ||||
| Lehel Bernadt | ||||
| Len Krause | ||||
| Linas Vepstas | ||||
| Ling Thio | ||||
| Linus Nielsen Feltzing | ||||
| Loic Dachary | ||||
| Loren Kirkby | ||||
| Luca Altea | ||||
| Luca Alteas | ||||
| Lucas Adamski | ||||
| Lukasz Czekierda | ||||
| Luke Call | ||||
| Luong Dinh Dung | ||||
| Maciej W. Rozycki | ||||
| Marc Boucher | ||||
| Marcelo Juchem  | ||||
| Marcin Konicki | ||||
| Marco G. Salvagno | ||||
| Marcus Webster | ||||
| Mario Schroeder | ||||
| Mark Butler | ||||
| Markus Moeller | ||||
| Markus Oberhumer | ||||
| Martijn Koster | ||||
| Martin C. Martin | ||||
| Martin Hedenfalk | ||||
| Marty Kuhrt | ||||
| Maruko | ||||
| Massimiliano Ziccardi | ||||
| Mathias Axelsson | ||||
| Mats Lidell | ||||
| Matt Veenstra | ||||
| Matthew Blain | ||||
| Matthew Clarke | ||||
| Maurice Barnum | ||||
| Mekonikum | ||||
| Mettgut Jamalla | ||||
| Michael Benedict | ||||
| Michael Curtis | ||||
| Michael Mealling | ||||
| Michal Bonino | ||||
| Mihai Ionescu | ||||
| Mike Bytnar | ||||
| Mike Dobbs | ||||
| Miklos Nemeth | ||||
| Mitz Wark | ||||
| Mohamed Lrhazi | ||||
| Mohun Biswas | ||||
| Moonesamy | ||||
| Nathan O'Sullivan | ||||
| Naveen Noel | ||||
| Neil Dunbar | ||||
| Neil Spring | ||||
| Nic Roets | ||||
| Nick Gimbrone | ||||
| Nick Humfrey | ||||
| Nico Baggus | ||||
| Nicolas Berloquin | ||||
| Nicolas Croiset | ||||
| Niels van Tongeren | ||||
| Nikita Schmidt | ||||
| Nodak Sodak | ||||
| Norbert Novotny | ||||
| Oren Tirosh | ||||
| P R Schaffner | ||||
| Patrick Bihan-Faou | ||||
| Patrick Smith | ||||
| Paul Harrington | ||||
| Paul Marquis | ||||
| Paul Moore | ||||
| Paul Nolan | ||||
| Pavel Cenek | ||||
| Pavel Orehov | ||||
| Pawel A. Gajda | ||||
| Pedro Neves | ||||
| Pete Su | ||||
| Peter Bray | ||||
| Peter Forret | ||||
| Peter Pentchev | ||||
| Peter Sylvester | ||||
| Peter Todd | ||||
| Peter Verhas | ||||
| Peter Wullinger | ||||
| Peteris Krumins | ||||
| Phil Karn | ||||
| Philip Gladstone | ||||
| Philippe Hameau | ||||
| Philippe Raoult | ||||
| Pierre | ||||
| Puneet Pawaia | ||||
| Rafael Sagula | ||||
| Ralph Beckmann | ||||
| Ralph Mitchell | ||||
| Ramana Mokkapati | ||||
| Randy McMurchy | ||||
| Reinout van Schouwen | ||||
| Renaud Chaillat | ||||
| Renaud Duhaut | ||||
| Rene Bernhardt | ||||
| Rene Rebe | ||||
| Ricardo Cadime | ||||
| Rich Gray | ||||
| Richard Archer | ||||
| Richard Atterer | ||||
| Richard Bramante | ||||
| Richard Clayton | ||||
| Richard Cooper | ||||
| Richard Gorton | ||||
| Richard Prescott | ||||
| Rick Jones | ||||
| Rick Richardson | ||||
| Rob Stanzel | ||||
| Robert D. Young | ||||
| Robert Olson | ||||
| Robert Weaver | ||||
| Robin Kay | ||||
| Rodney Simmons | ||||
| Roland Krikava | ||||
| Roland Zimmermann | ||||
| Roman Koifman | ||||
| Ron Zapp | ||||
| Rosimildo da Silva | ||||
| Roy Shan | ||||
| Rune Kleveland | ||||
| Ryan Nelson | ||||
| S. Moonesamy | ||||
| Salvador D<>vila | ||||
| Salvatore Sorrentino | ||||
| Sampo Kellomaki | ||||
| Samuel D<>az Garc<72>a | ||||
| Samuel Listopad | ||||
| Sander Gates | ||||
| Saul good | ||||
| Sebastien Willemijns | ||||
| Sergio Ballestrero | ||||
| Seshubabu Pasam | ||||
| Shard | ||||
| Shawn Poulson | ||||
| Siddhartha Prakash Jain | ||||
| Simon Dick | ||||
| Simon Josefsson | ||||
| Simon Liu | ||||
| Spiridonoff A.V | ||||
| Stadler Stephan | ||||
| Stefan Ulrich | ||||
| Stephan Bergmann | ||||
| Stephen Kick | ||||
| Stephen More | ||||
| Sterling Hughes | ||||
| Steve Green | ||||
| Steve Lhomme | ||||
| Steve Marx | ||||
| Steve Oliphant | ||||
| Steven Bazyl | ||||
| Steven G. Johnson | ||||
| Stoned Elipot | ||||
| Sven Neuhaus | ||||
| S<EFBFBD>bastien Willemijns | ||||
| T. Bharath | ||||
| T. Yamada | ||||
| Thomas Schwinge | ||||
| Thomas Tonino | ||||
| Tim Baker | ||||
| Tim Bartley | ||||
| Tim Costello | ||||
| Tim Sneddon | ||||
| Toby Peterson | ||||
| Todd Kulesza | ||||
| Tom Benoist | ||||
| Tom Lee | ||||
| Tom Mattison | ||||
| Tom Moers | ||||
| Tom Zerucha | ||||
| Tomas Pospisek | ||||
| Tomas Szepe | ||||
| Tomasz Lacki | ||||
| Tommy Tam | ||||
| Ton Voon | ||||
| Tor Arntsen | ||||
| Torsten Foertsch | ||||
| Toshiyuki Maezawa | ||||
| Traian Nicolescu | ||||
| Troels Walsted Hansen | ||||
| Troy Engel | ||||
| Tupone Alfredo | ||||
| Ulrich Zadow | ||||
| Vincent Bronner | ||||
| Vincent Penquerc'h | ||||
| Vincent Sanders | ||||
| Vojtech Janota | ||||
| Vojtech Minarik | ||||
| Walter J. Mack | ||||
| Wayne Haigh | ||||
| Werner Koch | ||||
| Wesley Laxton | ||||
| Wez Furlong | ||||
| Wilfredo Sanchez | ||||
| Wojciech Zwiefka | ||||
| Yarram Sunil | ||||
| Zvi Har'El  | ||||
| nk | ||||
| swalkaus at yahoo.com | ||||
|   | ||||
							
								
								
									
										84
									
								
								docs/TODO
									
									
									
									
									
								
							
							
						
						
									
										84
									
								
								docs/TODO
									
									
									
									
									
								
							| @@ -26,22 +26,27 @@ TODO | ||||
|  | ||||
|  * More data sharing. curl_share_* functions already exist and work, and they | ||||
|    can be extended to share more. For example, enable sharing of the ares | ||||
|    channel. | ||||
|    channel and the connection cache. | ||||
|  | ||||
|  * Introduce a new error code indicating authentication problems (for proxy | ||||
|    CONNECT error 407 for example). This cannot be an error code, we must not | ||||
|    return informational stuff as errors, consider a new info returned by | ||||
|    curl_easy_getinfo() #845941 | ||||
|    curl_easy_getinfo() http://curl.haxx.se/bug/view.cgi?id=845941 | ||||
|  | ||||
|  * Use 'struct lifreq' and SIOCGLIFADDR instead of 'struct ifreq' and | ||||
|    SIOCGIFADDR on newer Solaris versions as they claim the latter is obsolete. | ||||
|    To support ipv6 interface addresses properly. | ||||
|  | ||||
|  * Add the following to curl_easy_getinfo(): GET_HTTP_IP, GET_FTP_IP and | ||||
|    GET_FTP_DATA_IP. Return a string with the used IP. Suggested by Alan. | ||||
|  | ||||
|  * Add option that changes the interval in which the progress callback is | ||||
|    called at most. | ||||
|  | ||||
|  LIBCURL - multi interface | ||||
|  | ||||
|  * Add a curl_multi_fdset() alternative that returns only two arrays with file | ||||
|    desrciptors for reading and writing to allow the app to use whatever | ||||
|    function it prefers. Plus, this allows apps to avoid the FD_SETSIZE problem | ||||
|    with select(). | ||||
|  * 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. | ||||
|  | ||||
| @@ -56,12 +61,26 @@ 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 | ||||
|    return the easy handle's return code. This will thus make everything | ||||
|    internally use and assume the multi interface. The select()-loop should use | ||||
|    curl_multi_socket(). | ||||
|  | ||||
|  DOCUMENTATION | ||||
|  | ||||
|  * More and better | ||||
|  | ||||
|  FTP | ||||
|  | ||||
|  * Make the detection of (bad) %0d and %0a codes in FTP url parts earlier in | ||||
|    the process to avoid doing a resolve and connect in vain. | ||||
|  | ||||
|  * 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. | ||||
| @@ -96,6 +115,10 @@ TODO | ||||
|    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. | ||||
|  | ||||
|  TELNET | ||||
|  | ||||
|  * Reading input (to send to the remote server) on stdin is a crappy solution | ||||
| @@ -133,14 +156,31 @@ TODO | ||||
|    it be? There's so much that could be done if it were! (brought by Chris | ||||
|    Clark) | ||||
|  | ||||
|  * Make curl's SSL layer option capable of using other free SSL libraries. | ||||
|    Such as the Mozilla Security Services | ||||
|    (http://www.mozilla.org/projects/security/pki/nss/) and GnuTLS | ||||
|    (http://www.gnu.org/software/gnutls/) This subject has been brought up | ||||
|    again recently since GPL-licensed applications that link with libcurl MAY | ||||
|    NOT distribute binaries that use OpenSSL without adding an exception clause | ||||
|    to the GPL license. See the LICENSE-MIXING document and this: | ||||
|    http://www.gnome.org/~markmc/openssl-and-the-gpl.html | ||||
|  * Make curl's SSL layer capable of using other free SSL libraries.  Such as | ||||
|    Mozilla Security Services | ||||
|    (http://www.mozilla.org/projects/security/pki/nss/), MatrixSSL | ||||
|    (http://www.matrixssl.org/) or yaSSL (http://yassl.com/). At least the | ||||
|    latter two could be alternatives for those looking to reduce the footprint | ||||
|    of libcurl built with OpenSSL or GnuTLS. | ||||
|  | ||||
|  * Peter Sylvester's patch for SRP on the TLS layer. | ||||
|    Awaits OpenSSL support for this, no need to support this in libcurl before | ||||
|    there's an OpenSSL release that does it. | ||||
|  | ||||
|  * make the configure --with-ssl option first check for OpenSSL and then for | ||||
|    GnuTLS if OpenSSL wasn't detected. | ||||
|  | ||||
|  GnuTLS | ||||
|  | ||||
|  * Get NTLM working using the functions provided by libgcrypt, since GnuTLS | ||||
|    already depends on that to function. Not strictly SSL/TLS related, but | ||||
|    hey... Another option is to get available DES and MD4 source code from the | ||||
|    cryptopp library. They are fine license-wise, but are C++. | ||||
|  | ||||
|  * SSL engine stuff? | ||||
|  | ||||
|  * Work out a common method with Peter Sylvester's OpenSSL-patch for SRP | ||||
|    on the TLS to provide name and password | ||||
|  | ||||
|  LDAP | ||||
|  | ||||
| @@ -148,6 +188,22 @@ TODO | ||||
|    lib/ldap.c source file and get moved to the main network code so that the | ||||
|    multi interface and friends will work for LDAP as well. | ||||
|  | ||||
|  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. | ||||
|  | ||||
|  CLIENT | ||||
|  | ||||
|  * "curl --sync http://example.com/feed[1-100].rss" or | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| Online:  http://curl.haxx.se/docs/httpscripting.shtml | ||||
| Online:  http://curl.haxx.se/docs/httpscripting.html | ||||
| Date:    December 9, 2004 | ||||
|  | ||||
|                 The Art Of Scripting HTTP Requests Using Curl | ||||
|   | ||||
| @@ -20,7 +20,7 @@ Version Numbers and Releases | ||||
|    N is pre-release number | ||||
|  | ||||
|  One of these numbers will get bumped in each new release. The numbers to the | ||||
|  right of a bumped number will be reset to zero. If Z is zero, it is not | ||||
|  right of a bumped number will be reset to zero. If Z is zero, it may not be | ||||
|  included in the version number. The pre release number is only included in | ||||
|  pre releases (they're never used in public, official, releases). | ||||
|  | ||||
| @@ -49,7 +49,7 @@ Version Numbers and Releases | ||||
|  | ||||
|  As a service to any application that might want to support new libcurl | ||||
|  features while still being able to build with older versions, all releases | ||||
|  have the libcurl version stored in the curl/curl.h file using a static | ||||
|  have the libcurl version stored in the curl/curlver.h file using a static | ||||
|  numbering scheme that can be used for comparison. The version number is | ||||
|  defined as: | ||||
|          | ||||
| @@ -62,3 +62,6 @@ Version Numbers and Releases | ||||
|  This 6-digit hexadecimal number does not show pre-release number, and it is | ||||
|  always a greater number in a more recent release. It makes comparisons with | ||||
|  greater than and less than work. | ||||
|  | ||||
|  This number is also available as three separate defines: | ||||
|  LIBCURL_VERSION_MAJOR, LIBCURL_VERSION_MINOR and LIBCURL_VERSION_PATCH. | ||||
|   | ||||
| @@ -1,8 +1,27 @@ | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man curl-config.1 | ||||
| .\" Written by Daniel Stenberg | ||||
| .\" ************************************************************************** | ||||
| .\" *                                  _   _ ____  _ | ||||
| .\" *  Project                     ___| | | |  _ \| | | ||||
| .\" *                             / __| | | | |_) | | | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| .\" * are also available at http://curl.haxx.se/docs/copyright.html. | ||||
| .\" * | ||||
| .\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||
| .\" * copies of the Software, and permit persons to whom the Software is | ||||
| .\" * furnished to do so, under the terms of the COPYING file. | ||||
| .\" * | ||||
| .\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||
| .\" * KIND, either express or implied. | ||||
| .\" * | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl-config 1 "11 Dec 2004" "Curl 7.10" "curl-config manual" | ||||
| .TH curl-config 1 "25 Jan 2004" "Curl 7.13.0" "curl-config manual" | ||||
| .SH NAME | ||||
| curl-config \- Get information about a libcurl installation | ||||
| .SH SYNOPSIS | ||||
| @@ -32,6 +51,12 @@ to link your application with libcurl. | ||||
| This is the prefix used when libcurl was installed. Libcurl is then installed | ||||
| 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) | ||||
| .IP "--version" | ||||
| Outputs version information about the installed libcurl. | ||||
| .IP "--vernum" | ||||
|   | ||||
							
								
								
									
										161
									
								
								docs/curl.1
									
									
									
									
									
								
							
							
						
						
									
										161
									
								
								docs/curl.1
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2005, 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 "7 Dec 2004" "Curl 7.12.3" "Curl Manual" | ||||
| .TH curl 1 "4 Sep 2005" "Curl 7.14.2" "Curl Manual" | ||||
| .SH NAME | ||||
| curl \- transfer a URL | ||||
| .SH SYNOPSIS | ||||
| @@ -30,8 +30,8 @@ curl \- transfer a URL | ||||
| .SH DESCRIPTION | ||||
| .B curl | ||||
| is a tool to transfer data from or to a server, using one of the supported | ||||
| protocols (HTTP, HTTPS, FTP, FTPS, GOPHER, DICT, TELNET, LDAP or FILE). The | ||||
| command is designed to work without user interaction. | ||||
| protocols (HTTP, HTTPS, FTP, FTPS, TFTP, GOPHER, 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 | ||||
| @@ -64,6 +64,11 @@ 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. | ||||
|  | ||||
| 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 | ||||
| with "ftp." curl will assume you want to speak FTP. | ||||
|  | ||||
| Curl will attempt to re-use connections for multiple file transfers, so that | ||||
| getting many files from the same server will not do multiple connects / | ||||
| handshakes. This improves speed. Of course this is only done on files | ||||
| @@ -120,9 +125,9 @@ using \fI-D/--dump-header\fP! | ||||
| If this option is set more than once, the last one will be the one that's | ||||
| used. | ||||
| .IP "-B/--use-ascii" | ||||
| Use ASCII transfer when getting an FTP file or LDAP info. For FTP, this can | ||||
| also be enforced by using an URL that ends with ";type=A". This option causes | ||||
| data sent to stdout to be in text mode for win32 systems. | ||||
| Enable ASCII transfer when using FTP or LDAP. For FTP, this can also be | ||||
| enforced by using an URL that ends with ";type=A". This option causes data | ||||
| sent to stdout to be in text mode for win32 systems. | ||||
|  | ||||
| If this option is used twice, the second one will disable ASCII usage. | ||||
| .IP "--basic" | ||||
| @@ -267,7 +272,7 @@ If this option is used several times, the last one will be used. | ||||
| 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 | ||||
| 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>" | ||||
| @@ -330,6 +335,12 @@ document stating so (which often also describes why and more). This flag will | ||||
| prevent curl from outputting that and fail silently instead. | ||||
|  | ||||
| If this option is used twice, the second will again disable silent failure. | ||||
| .IP "--ftp-account [data]" | ||||
| (FTP) When an FTP server asks for "account data" after user name and password | ||||
| has been provided, this data is sent off using the ACCT command. (Added in | ||||
| 7.13.0) | ||||
|  | ||||
| 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 | ||||
| @@ -337,10 +348,19 @@ will instead attempt to create missing directories. (Added in 7.10.7) | ||||
|  | ||||
| If this option is used twice, the second will again disable silent failure. | ||||
| .IP "--ftp-pasv" | ||||
| (FTP) Use PASV when transfering. PASV is the internal default behavior, but | ||||
| (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. | ||||
| .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 | ||||
| will re-use the same IP address it already uses for the control | ||||
| 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. | ||||
| .IP "--ftp-ssl" | ||||
| (FTP) Make the FTP connection switch to use SSL/TLS. (Added in 7.11.0) | ||||
| @@ -374,9 +394,20 @@ or | ||||
|  | ||||
| \fBcurl\fP -F "name=daniel;type=text/foo" url.com | ||||
|  | ||||
| You can also explicitly change the name field of an file upload part by | ||||
| setting filename=, like this: | ||||
|  | ||||
| \fBcurl\fP -F "file=@localfile;filename=nameinpost" url.com | ||||
|  | ||||
| See further examples and details in the MANUAL. | ||||
|  | ||||
| This option can be used multiple times. | ||||
| .IP "--form-string <name=string>" | ||||
| (HTTP) Similar to \fI--form\fP except that the value string for the named | ||||
| parameter is used literally. Leading \&'@' and \&'<' characters, and the | ||||
| \&';type=' string in the value have no special meaning. Use this in preference | ||||
| to \fI--form\fP if there's any possibility that the string value may | ||||
| accidentally trigger the \&'@' or \&'<' features of \fI--form\fP. | ||||
| .IP "-g/--globoff" | ||||
| This option switches off the "URL globbing parser". When you set this option, | ||||
| you can specify URLs that contain the letters {}[] without having them being | ||||
| @@ -404,9 +435,19 @@ 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. | ||||
|  | ||||
| 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 | ||||
| content: do not add newlines or carriage returns they will only mess things up | ||||
| for you. | ||||
|  | ||||
| See also the \fI-A/--user-agent\fP and \fI-e/--referer\fP options. | ||||
|  | ||||
| This option can be used multiple times to add/replace/remove multiple headers. | ||||
| .IP "--ignore-content-length" | ||||
| (HTTP) | ||||
| Ignore the Content-Length header. This is particularly useful for servers | ||||
| running Apache 1.x, which will report incorrect Content-Length for files | ||||
| larger than 2 gigabytes. | ||||
| .IP "-i/--include" | ||||
| (HTTP) | ||||
| Include the HTTP-header in the output. The HTTP-header includes things | ||||
| @@ -480,6 +521,20 @@ line. So, it could look similar to this: | ||||
| url = "http://curl.haxx.se/docs/" | ||||
|  | ||||
| This option can be used multiple times. | ||||
|  | ||||
| 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 | ||||
| the following places in this order: | ||||
|  | ||||
| 1) curl tries to find the "home dir": It first checks for the CURL_HOME and | ||||
| then the HOME environment variables. Failing that, it uses getpwuid() on | ||||
| unix-like systems (which returns the home dir given the current user in your | ||||
| system). On Windows, it then checks for the APPDATA variable, or as a last | ||||
| 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 "--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 | ||||
| @@ -538,8 +593,7 @@ this given limit. This concerns both FTP and HTTP transfers. | ||||
| .IP "-m/--max-time <seconds>" | ||||
| Maximum time in seconds that you allow the whole operation to take.  This is | ||||
| useful for preventing your batch jobs from hanging for hours due to slow | ||||
| networks or links going down.  This doesn't work fully in win32 systems.  See | ||||
| also the \fI--connect-timeout\fP option. | ||||
| networks or links going down.  See also the \fI--connect-timeout\fP option. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-M/--manual" | ||||
| @@ -558,7 +612,7 @@ directory. | ||||
|  | ||||
| A quick and very simple example of how to setup a \fI.netrc\fP to allow curl | ||||
| to ftp to the machine host.domain.com with user name \&'myself' and password | ||||
| 'secret' should look similar to: | ||||
| \&'secret' should look similar to: | ||||
|  | ||||
| .B "machine host.domain.com login myself password secret" | ||||
|  | ||||
| @@ -622,11 +676,21 @@ 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 | ||||
|  | ||||
| You may use this option as many times as you have number of URLs. | ||||
| .IP "--pass <phrase>" | ||||
| (SSL) Pass phrase for the private key | ||||
|  | ||||
| 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. | ||||
|  | ||||
| If this option is used twice, the second will again disable the proxy use-any | ||||
| authentication. | ||||
| .IP "--proxy-basic" | ||||
| Tells curl to use HTTP Basic authentication when communicating with the given | ||||
| proxy. Use \fI--basic\fP for enabling HTTP Basic with a remote host. Basic is | ||||
| @@ -673,13 +737,16 @@ If this option is used several times, the last one will be used. Disable the | ||||
| use of PORT with \fI--ftp-pasv\fP. Disable the attempt to use the EPRT command | ||||
| instead of PORT by using \fI--disable-eprt\fP. EPRT is really PORT++. | ||||
| .IP "-q" | ||||
| If used as the first parameter on the command line, the \fI$HOME/.curlrc\fP | ||||
| file will not be read and used as a config file. | ||||
| .IP "-Q/--quote <comand>" | ||||
| If used as the first parameter on the command line, the \fIcurlrc\fP config | ||||
| file will not be read and used. See the \fI-K/--config\fP for details on the | ||||
| default config file search path. | ||||
| .IP "-Q/--quote <command>" | ||||
| (FTP) Send an arbitrary command to the remote FTP server. Quote commands are | ||||
| sent BEFORE the transfer is taking place. To make commands take place after a | ||||
| successful transfer, prefix them with a dash '-'. You may specify any amount | ||||
| of commands to be run before and after the transfer. If the server returns | ||||
| sent BEFORE the transfer is taking place (just after the initial PWD command | ||||
| to be exact). To make commands take place after a successful transfer, prefix | ||||
| them with a dash '-'. To make commands get sent after libcurl has changed | ||||
| working directory, just before the transfer command(s), prefix the command | ||||
| with '+'. You may specify any amount of commands. If the server returns | ||||
| failure for one of the commands, the entire operation will be aborted. You | ||||
| must send syntactically correct FTP commands as RFC959 defines. | ||||
|  | ||||
| @@ -841,8 +908,14 @@ to read for untrained humans. | ||||
|  | ||||
| If this option is used several times, the last one will be used. (Added in | ||||
| 7.9.7) | ||||
| .IP "--trace-time" | ||||
| Prepends a time stamp to each trace or verbose line that curl displays. | ||||
|  | ||||
| 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. | ||||
| Specify user and password to use for server authentication. Overrides | ||||
| \fI-n/--netrc\fP and \fI--netrc-optional\fP. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-U/--proxy-user <user:password>" | ||||
| @@ -857,9 +930,9 @@ This option may be used any number of times. To control where this URL is | ||||
| written, use the \fI-o/--output\fP or the \fI-O/--remote-name\fP options. | ||||
| .IP "-v/--verbose" | ||||
| Makes the fetching more verbose/talkative. Mostly usable for debugging. Lines | ||||
| starting with '>' means data sent by curl, '<' means data received by curl | ||||
| that is hidden in normal cases and lines starting with '*' means additional | ||||
| info provided by curl. | ||||
| starting with '>' means "header data" sent by curl, '<' means "header data" | ||||
| received by curl that is hidden in normal cases and lines starting with '*' | ||||
| means additional info provided by curl. | ||||
|  | ||||
| Note that if you only want HTTP headers in the output, \fI-i/--include\fP | ||||
| might be option you're looking for. | ||||
| @@ -903,13 +976,16 @@ SPNEGO Negotiate authentication is supported. | ||||
| This curl supports transfers of large files, files larger than 2GB. | ||||
| .IP "IDN" | ||||
| This curl supports IDN - international domain names. | ||||
| .IP "SSPI" | ||||
| SSPI is supported. If you use NTLM and set a blank user name, curl will | ||||
| authenticate with your current user and password. | ||||
| .RE | ||||
| .IP "-w/--write-out <format>" | ||||
| Defines what to display after a completed and successful operation. The format | ||||
| is a string that may contain plain text mixed with any number of variables. The | ||||
| string can be specified as "string", to get read from a particular file you | ||||
| specify it "@filename" and to tell curl to read the format from stdin you | ||||
| write "@-". | ||||
| Defines what to display on stdout after a completed and successful | ||||
| operation. The format is a string that may contain plain text mixed with any | ||||
| number of variables. The string can be specified as "string", to get read from | ||||
| a particular file you specify it "@filename" and to tell curl to read the | ||||
| format from stdin you write "@-". | ||||
|  | ||||
| The variables present in the output format will be substituted by the value or | ||||
| text that curl thinks fit, as described below. All variables are specified | ||||
| @@ -931,6 +1007,10 @@ to follow location: headers. | ||||
| .B http_code | ||||
| The numerical code that was found in the last retrieved HTTP(S) page. | ||||
| .TP | ||||
| .B http_connect | ||||
| The numerical code that was found in the last response (from a proxy) to a | ||||
| curl CONNECT request. (Added in 7.12.4) | ||||
| .TP | ||||
| .B time_total | ||||
| The total time, in seconds, that the full operation lasted. The time will be | ||||
| displayed with millisecond resolution. | ||||
| @@ -1001,12 +1081,16 @@ transparently be converted to HTTP. It means that certain protocol specific | ||||
| operations might not be available. This is not the case if you can tunnel | ||||
| through the proxy, as done with the \fI-p/--proxytunnel\fP option. | ||||
|  | ||||
| Starting with 7.14.1, the proxy host can be specified the exact same way as | ||||
| the proxy environment variables, include protocol prefix (http://) and | ||||
| embedded user + password. | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
| .IP "-X/--request <command>" | ||||
| (HTTP) | ||||
| Specifies a custom request to use when communicating with the HTTP server. | ||||
| The specified request will be used instead of the standard GET. Read the | ||||
| HTTP 1.1 specification for details and explanations. | ||||
| (HTTP) Specifies a custom request method to use when communicating with the | ||||
| HTTP server.  The specified request will be used instead of the method | ||||
| otherwise used (which defaults to GET). Read the HTTP 1.1 specification for | ||||
| details and explanations. | ||||
|  | ||||
| (FTP) | ||||
| Specifies a custom FTP command to use instead of LIST when doing file lists | ||||
| @@ -1058,6 +1142,17 @@ Forces curl to use SSL version 2 when negotiating with a remote SSL server. | ||||
| .IP "-3/--sslv3" | ||||
| (HTTPS) | ||||
| 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 | ||||
| @@ -1089,7 +1184,7 @@ Sets proxy server to use for GOPHER. | ||||
| Sets proxy server to use if no protocol-specific proxy is set. | ||||
| .IP "NO_PROXY <comma-separated list of hosts>" | ||||
| list of host names that shouldn't go through any proxy. If set to a asterisk | ||||
| '*' only, it matches all hosts. | ||||
| \&'*' only, it matches all hosts. | ||||
| .SH EXIT CODES | ||||
| There exists a bunch of different error codes and their corresponding error | ||||
| messages that may appear during bad conditions. At the time of this writing, | ||||
| @@ -1239,5 +1334,5 @@ http://curl.haxx.se | ||||
| ftp://ftp.sunet.se/pub/www/utilities/curl/ | ||||
| .SH "SEE ALSO" | ||||
| .BR ftp (1), | ||||
| .BR wget (1), | ||||
| .BR wget (1) | ||||
|  | ||||
|   | ||||
| @@ -10,7 +10,8 @@ EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c		\ | ||||
|  post-callback.c multi-app.c multi-double.c multi-single.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 | ||||
|  anyauthput.c htmltitle.cc htmltidy.c opensslthreadlock.c		\ | ||||
|  cookie_interface.c cacertinmem.c | ||||
|  | ||||
| all: | ||||
| 	@echo "done" | ||||
|   | ||||
| @@ -44,6 +44,8 @@ ftpgetresp.c   - get the response strings from the FTP server | ||||
| ftpupload.c    - upload a file to a FTP server | ||||
| getinfo.c      - get the Content-Type from the recent transfer | ||||
| getinmemory.c  - download a file to memory only | ||||
| htmltitle.cc   - download a HTML file and extract the <title> tag from a HTML | ||||
|                  page using libxml | ||||
| http-post.c    - HTTP POST | ||||
| httpput.c      - HTTP PUT a local file | ||||
| https.c        - simple HTTPS transfer | ||||
|   | ||||
							
								
								
									
										138
									
								
								docs/examples/cacertinmem.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								docs/examples/cacertinmem.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | ||||
| /***************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * Example using a "in core" PEM certificate to retrieve a https page. | ||||
|  * Written by Theo Borm | ||||
|  */ | ||||
|  | ||||
| /* on a netBSD system with OPENSSL& LIBCURL installed from | ||||
|  * pkgsrc (using default paths) this program can be compiled using: | ||||
|  * gcc -I/usr/pkg/include -L/usr/pkg/lib -lcurl -Wl,-R/usr/pkg/lib -lssl | ||||
|  * -lcrypto -lz -o curlcacerttest curlcacerttest.c | ||||
|  * on other operating systems you may want to change paths to headers | ||||
|  * and libraries | ||||
| */ | ||||
| #include <openssl/ssl.h> | ||||
| #include <curl/curl.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
| size_t writefunction( void *ptr, size_t size, size_t nmemb, void *stream) | ||||
| { | ||||
|   fwrite(ptr,size,nmemb,stream); | ||||
|   return(nmemb*size); | ||||
| } | ||||
|  | ||||
| static CURLcode sslctx_function(CURL * curl, void * sslctx, void * parm) | ||||
| { | ||||
|   X509_STORE * store; | ||||
|   X509 * cert=NULL; | ||||
|   BIO * bio; | ||||
|   char * mypem = /* www.cacert.org */ | ||||
|     "-----BEGIN CERTIFICATE-----\n"\ | ||||
|     "MIIHPTCCBSWgAwIBAgIBADANBgkqhkiG9w0BAQQFADB5MRAwDgYDVQQKEwdSb290\n"\ | ||||
|     "IENBMR4wHAYDVQQLExVodHRwOi8vd3d3LmNhY2VydC5vcmcxIjAgBgNVBAMTGUNB\n"\ | ||||
|     "IENlcnQgU2lnbmluZyBBdXRob3JpdHkxITAfBgkqhkiG9w0BCQEWEnN1cHBvcnRA\n"\ | ||||
|     "Y2FjZXJ0Lm9yZzAeFw0wMzAzMzAxMjI5NDlaFw0zMzAzMjkxMjI5NDlaMHkxEDAO\n"\ | ||||
|     "BgNVBAoTB1Jvb3QgQ0ExHjAcBgNVBAsTFWh0dHA6Ly93d3cuY2FjZXJ0Lm9yZzEi\n"\ | ||||
|     "MCAGA1UEAxMZQ0EgQ2VydCBTaWduaW5nIEF1dGhvcml0eTEhMB8GCSqGSIb3DQEJ\n"\ | ||||
|     "ARYSc3VwcG9ydEBjYWNlcnQub3JnMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC\n"\ | ||||
|     "CgKCAgEAziLA4kZ97DYoB1CW8qAzQIxL8TtmPzHlawI229Z89vGIj053NgVBlfkJ\n"\ | ||||
|     "8BLPRoZzYLdufujAWGSuzbCtRRcMY/pnCujW0r8+55jE8Ez64AO7NV1sId6eINm6\n"\ | ||||
|     "zWYyN3L69wj1x81YyY7nDl7qPv4coRQKFWyGhFtkZip6qUtTefWIonvuLwphK42y\n"\ | ||||
|     "fk1WpRPs6tqSnqxEQR5YYGUFZvjARL3LlPdCfgv3ZWiYUQXw8wWRBB0bF4LsyFe7\n"\ | ||||
|     "w2t6iPGwcswlWyCR7BYCEo8y6RcYSNDHBS4CMEK4JZwFaz+qOqfrU0j36NK2B5jc\n"\ | ||||
|     "G8Y0f3/JHIJ6BVgrCFvzOKKrF11myZjXnhCLotLddJr3cQxyYN/Nb5gznZY0dj4k\n"\ | ||||
|     "epKwDpUeb+agRThHqtdB7Uq3EvbXG4OKDy7YCbZZ16oE/9KTfWgu3YtLq1i6L43q\n"\ | ||||
|     "laegw1SJpfvbi1EinbLDvhG+LJGGi5Z4rSDTii8aP8bQUWWHIbEZAWV/RRyH9XzQ\n"\ | ||||
|     "QUxPKZgh/TMfdQwEUfoZd9vUFBzugcMd9Zi3aQaRIt0AUMyBMawSB3s42mhb5ivU\n"\ | ||||
|     "fslfrejrckzzAeVLIL+aplfKkQABi6F1ITe1Yw1nPkZPcCBnzsXWWdsC4PDSy826\n"\ | ||||
|     "YreQQejdIOQpvGQpQsgi3Hia/0PsmBsJUUtaWsJx8cTLc6nloQsCAwEAAaOCAc4w\n"\ | ||||
|     "ggHKMB0GA1UdDgQWBBQWtTIb1Mfz4OaO873SsDrusjkY0TCBowYDVR0jBIGbMIGY\n"\ | ||||
|     "gBQWtTIb1Mfz4OaO873SsDrusjkY0aF9pHsweTEQMA4GA1UEChMHUm9vdCBDQTEe\n"\ | ||||
|     "MBwGA1UECxMVaHR0cDovL3d3dy5jYWNlcnQub3JnMSIwIAYDVQQDExlDQSBDZXJ0\n"\ | ||||
|     "IFNpZ25pbmcgQXV0aG9yaXR5MSEwHwYJKoZIhvcNAQkBFhJzdXBwb3J0QGNhY2Vy\n"\ | ||||
|     "dC5vcmeCAQAwDwYDVR0TAQH/BAUwAwEB/zAyBgNVHR8EKzApMCegJaAjhiFodHRw\n"\ | ||||
|     "czovL3d3dy5jYWNlcnQub3JnL3Jldm9rZS5jcmwwMAYJYIZIAYb4QgEEBCMWIWh0\n"\ | ||||
|     "dHBzOi8vd3d3LmNhY2VydC5vcmcvcmV2b2tlLmNybDA0BglghkgBhvhCAQgEJxYl\n"\ | ||||
|     "aHR0cDovL3d3dy5jYWNlcnQub3JnL2luZGV4LnBocD9pZD0xMDBWBglghkgBhvhC\n"\ | ||||
|     "AQ0ESRZHVG8gZ2V0IHlvdXIgb3duIGNlcnRpZmljYXRlIGZvciBGUkVFIGhlYWQg\n"\ | ||||
|     "b3ZlciB0byBodHRwOi8vd3d3LmNhY2VydC5vcmcwDQYJKoZIhvcNAQEEBQADggIB\n"\ | ||||
|     "ACjH7pyCArpcgBLKNQodgW+JapnM8mgPf6fhjViVPr3yBsOQWqy1YPaZQwGjiHCc\n"\ | ||||
|     "nWKdpIevZ1gNMDY75q1I08t0AoZxPuIrA2jxNGJARjtT6ij0rPtmlVOKTV39O9lg\n"\ | ||||
|     "18p5aTuxZZKmxoGCXJzN600BiqXfEVWqFcofN8CCmHBh22p8lqOOLlQ+TyGpkO/c\n"\ | ||||
|     "gr/c6EWtTZBzCDyUZbAEmXZ/4rzCahWqlwQ3JNgelE5tDlG+1sSPypZt90Pf6DBl\n"\ | ||||
|     "Jzt7u0NDY8RD97LsaMzhGY4i+5jhe1o+ATc7iwiwovOVThrLm82asduycPAtStvY\n"\ | ||||
|     "sONvRUgzEv/+PDIqVPfE94rwiCPCR/5kenHA0R6mY7AHfqQv0wGP3J8rtsYIqQ+T\n"\ | ||||
|     "SCX8Ev2fQtzzxD72V7DX3WnRBnc0CkvSyqD/HMaMyRa+xMwyN2hzXwj7UfdJUzYF\n"\ | ||||
|     "CpUCTPJ5GhD22Dp1nPMd8aINcGeGG7MW9S/lpOt5hvk9C8JzC6WZrG/8Z7jlLwum\n"\ | ||||
|     "GCSNe9FINSkYQKyTYOGWhlC0elnYjyELn8+CkcY7v2vcB5G5l1YjqrZslMZIBjzk\n"\ | ||||
|     "zk6q5PYvCdxTby78dOs6Y5nCpqyJvKeyRKANihDjbPIky/qbn3BHLt4Ui9SyIAmW\n"\ | ||||
|     "omTxJBzcoTWcFbLUvFUufQb1nA5V9FrWk9p2rSVzTMVD\n"\ | ||||
|     "-----END CERTIFICATE-----\n"; | ||||
|   /* get a BIO */ | ||||
|   bio=BIO_new_mem_buf(mypem, -1); | ||||
|   /* use it to read the PEM formatted certificate from memory into an X509 | ||||
|    * structure that SSL can use | ||||
|    */ | ||||
|   PEM_read_bio_X509(bio, &cert, 0, NULL); | ||||
|   if (cert == NULL) | ||||
|     printf("PEM_read_bio_X509 failed...\n"); | ||||
|  | ||||
|   /* get a pointer to the X509 certificate store (which may be empty!) */ | ||||
|   store=SSL_CTX_get_cert_store((SSL_CTX *)sslctx); | ||||
|  | ||||
|   /* add our certificate to this store */ | ||||
|   if (X509_STORE_add_cert(store, cert)==0) | ||||
|     printf("error adding certificate\n"); | ||||
|  | ||||
|   /* all set to go */ | ||||
|   return CURLE_OK ; | ||||
| } | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL * ch; | ||||
|   CURLcode rv; | ||||
|  | ||||
|   rv=curl_global_init(CURL_GLOBAL_ALL); | ||||
|   ch=curl_easy_init(); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_VERBOSE, 0); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_HEADER, 0); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_NOPROGRESS, 1); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_NOSIGNAL, 1); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_WRITEFUNCTION, *writefunction); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_WRITEDATA, stdout); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_HEADERFUNCTION, *writefunction); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_WRITEHEADER, stderr); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_SSLCERTTYPE,"PEM"); | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_SSL_VERIFYPEER,1); | ||||
|   rv=curl_easy_setopt(ch, CURLOPT_URL, "https://www.cacert.org/"); | ||||
|  | ||||
|   /* first try: retrieve page without cacerts' certificate -> will fail | ||||
|    */ | ||||
|   rv=curl_easy_perform(ch); | ||||
|   if (rv==CURLE_OK) | ||||
|     printf("*** transfer succeeded ***\n"); | ||||
|   else | ||||
|     printf("*** transfer failed ***\n"); | ||||
|  | ||||
|   /* second try: retrieve page using cacerts' certificate -> will succeed | ||||
|    * load the certificate by installing a function doing the nescessary | ||||
|    * "modifications" to the SSL CONTEXT just before link init | ||||
|    */ | ||||
|   rv=curl_easy_setopt(ch,CURLOPT_SSL_CTX_FUNCTION, *sslctx_function); | ||||
|   rv=curl_easy_perform(ch); | ||||
|   if (rv==CURLE_OK) | ||||
|     printf("*** transfer succeeded ***\n"); | ||||
|   else | ||||
|     printf("*** transfer failed ***\n"); | ||||
|  | ||||
|   curl_easy_cleanup(ch); | ||||
|   curl_global_cleanup(); | ||||
| } | ||||
							
								
								
									
										110
									
								
								docs/examples/cookie_interface.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								docs/examples/cookie_interface.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,110 @@ | ||||
| /***************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  *  This example shows usage of simple cookie interface.  | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <errno.h> | ||||
| #include <time.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| static void | ||||
| print_cookies(CURL *curl) | ||||
| { | ||||
|   CURLcode res; | ||||
|   struct curl_slist *cookies; | ||||
|   struct curl_slist *nc; | ||||
|   int i; | ||||
|  | ||||
|   printf("Cookies, curl knows:\n"); | ||||
|   res = curl_easy_getinfo(curl, CURLINFO_COOKIELIST, &cookies); | ||||
|   if (res != CURLE_OK) { | ||||
|     fprintf(stderr, "Curl curl_easy_getinfo failed: %s\n", curl_easy_strerror(res)); | ||||
|     exit(1); | ||||
|   } | ||||
|   nc = cookies, i = 1; | ||||
|   while (nc) { | ||||
|     printf("[%d]: %s\n", i, nc->data); | ||||
|     nc = nc->next; | ||||
|     i++; | ||||
|   } | ||||
|   if (i == 1) { | ||||
|     printf("(none)\n"); | ||||
|   } | ||||
|   curl_slist_free_all(cookies); | ||||
| } | ||||
|  | ||||
| int | ||||
| main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res; | ||||
|  | ||||
|   curl_global_init(CURL_GLOBAL_ALL); | ||||
|   curl = curl_easy_init(); | ||||
|   if (curl) { | ||||
|     char nline[256]; | ||||
|  | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, "http://www.google.com/"); /* google.com sets "PREF" cookie */ | ||||
|     curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); | ||||
|     curl_easy_setopt(curl, CURLOPT_COOKIEFILE, ""); /* just to start the cookie engine */ | ||||
|     res = curl_easy_perform(curl); | ||||
|     if (res != CURLE_OK) { | ||||
|       fprintf(stderr, "Curl perform failed: %s\n", curl_easy_strerror(res)); | ||||
|       return 1; | ||||
|     } | ||||
|  | ||||
|     print_cookies(curl); | ||||
|  | ||||
|     printf("Erasing curl's knowledge of cookies!\n"); | ||||
|     curl_easy_setopt(curl, CURLOPT_COOKIELIST, "ALL"); | ||||
|  | ||||
|     print_cookies(curl); | ||||
|  | ||||
|     printf("-----------------------------------------------\n" | ||||
|            "Setting a cookie \"PREF\" via cookie interface:\n"); | ||||
| #ifdef WIN32 | ||||
| #define snprintf _snprintf | ||||
| #endif | ||||
|     /* Netscape format cookie */ | ||||
|     snprintf(nline, 256, "%s\t%s\t%s\t%s\t%u\t%s\t%s", | ||||
|       ".google.com", "TRUE", "/", "FALSE", time(NULL) + 31337, "PREF", "hello google, i like you very much!"); | ||||
|     res = curl_easy_setopt(curl, CURLOPT_COOKIELIST, nline); | ||||
|     if (res != CURLE_OK) { | ||||
|       fprintf(stderr, "Curl curl_easy_setopt failed: %s\n", curl_easy_strerror(res)); | ||||
|       return 1;             | ||||
|     } | ||||
|  | ||||
|     /* HTTP-header style cookie */ | ||||
|     snprintf(nline, 256, | ||||
|       "Set-Cookie: OLD_PREF=3d141414bf4209321; " | ||||
|       "expires=Sun, 17-Jan-2038 19:14:07 GMT; path=/; domain=.google.com"); | ||||
|     res = curl_easy_setopt(curl, CURLOPT_COOKIELIST, nline); | ||||
|     if (res != CURLE_OK) { | ||||
|       fprintf(stderr, "Curl curl_easy_setopt failed: %s\n", curl_easy_strerror(res)); | ||||
|       return 1;             | ||||
|     } | ||||
|  | ||||
|     print_cookies(curl); | ||||
|  | ||||
|     res = curl_easy_perform(curl); | ||||
|     if (res != CURLE_OK) { | ||||
|       fprintf(stderr, "Curl perform failed: %s\n", curl_easy_strerror(res)); | ||||
|       return 1; | ||||
|     } | ||||
|   } | ||||
|   else { | ||||
|     fprintf(stderr, "Curl init failed!\n"); | ||||
|     return 1; | ||||
|   } | ||||
|  | ||||
|   curl_global_cleanup(); | ||||
|   return 0; | ||||
| } | ||||
| @@ -16,18 +16,16 @@ | ||||
|  | ||||
| /* | ||||
|  * This is an example showing how to transfer a file between two remote hosts. | ||||
|  * 7.13.0 or later required. | ||||
|  */ | ||||
|  | ||||
|  | ||||
|  | ||||
| int main(void) | ||||
| { | ||||
|   CURL *curl; | ||||
|   CURLcode res; | ||||
|   char sourceFileName[] = "/tmp/file"; | ||||
|   char targetFileName[] = "/tmp/curlTargetTest.dat"; | ||||
|   char sourceHost[] = "source"; | ||||
|   char targetHost[] = "target"; | ||||
|   char source_url[] = "ftp://remotehost.com/path/to/source"; | ||||
|   char target_url[] = "ftp://aotherserver.com/path/to/dest"; | ||||
|  | ||||
|   char sourceUserPass[] = "user:pass"; | ||||
|   char targetUserPass[] = "user:pass"; | ||||
|   char url[100]; | ||||
| @@ -42,21 +40,22 @@ int main(void) | ||||
|  | ||||
|   curl = curl_easy_init(); | ||||
|   if (curl) { | ||||
|     sprintf(url, "ftp://%s@%s/%s", targetUserPass, targetHost, targetFileName); | ||||
|     printf("%s\n", url); | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, url); | ||||
|     /* The ordinary URL is the target when speaking 3rd party transfers */ | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, target_url); | ||||
|  | ||||
|     /* Set a proxy host */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SOURCE_HOST, sourceHost); | ||||
|     /* Set a source URL */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SOURCE_URL, source_url); | ||||
|  | ||||
|     /* Set a proxy user and password */ | ||||
|     /* Set target user and password */ | ||||
|     curl_easy_setopt(curl, CURLOPT_USERPWD, targetUserPass); | ||||
|  | ||||
|     /* Set source user and password */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SOURCE_USERPWD, sourceUserPass); | ||||
|  | ||||
|     /* Set a proxy full file name */ | ||||
|     curl_easy_setopt(curl, CURLOPT_SOURCE_PATH, sourceFileName); | ||||
|  | ||||
|     /* Set a proxy passive host */ | ||||
|     curl_easy_setopt(curl, CURLOPT_PASV_HOST, 0);   /* optional */ | ||||
| #if 0 | ||||
|     /* FTPPORT enables PORT on the target side, instead of PASV. */ | ||||
|     curl_easy_setopt(curl, CURLOPT_FTPPORT, "");   /* optional */ | ||||
| #endif | ||||
|  | ||||
|     /* build a list of commands to pass to libcurl */ | ||||
|     source_pre_cmd = curl_slist_append(source_pre_cmd, cmd); | ||||
|   | ||||
| @@ -78,8 +78,12 @@ int main(int argc, char **argv) | ||||
|        DLL may not use the variable's memory when passed in to it from an app | ||||
|        like this. */ | ||||
|  | ||||
|     /* and give the size of the upload (optional) */ | ||||
|     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, file_info.st_size); | ||||
|     /* Set the size of the file to upload (optional).  If you give a *_LARGE | ||||
|        option you MUST make sure that the type of the passed-in argument is a | ||||
|        curl_off_t. If you use CURLOPT_INFILESIZE (without _LARGE) you must | ||||
|        make sure that to pass in a type 'long' argument. */ | ||||
|     curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, | ||||
|                      (curl_off_t)file_info.st_size); | ||||
|  | ||||
|     /* Now run off and do what you've been told! */ | ||||
|     res = curl_easy_perform(curl); | ||||
|   | ||||
| @@ -14,6 +14,8 @@ | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #include <curl/curl.h> | ||||
| #include <curl/types.h> | ||||
| @@ -37,7 +39,7 @@ void *myrealloc(void *ptr, size_t size) | ||||
| size_t | ||||
| WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) | ||||
| { | ||||
|   register int realsize = size * nmemb; | ||||
|   size_t realsize = size * nmemb; | ||||
|   struct MemoryStruct *mem = (struct MemoryStruct *)data; | ||||
|  | ||||
|   mem->memory = (char *)myrealloc(mem->memory, mem->size + realsize + 1); | ||||
| @@ -93,5 +95,8 @@ int main(int argc, char **argv) | ||||
|    * you're done with it, you should free() it as a nice application. | ||||
|    */ | ||||
|  | ||||
|   if(chunk.memory) | ||||
|     free(chunk.memory); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|   | ||||
							
								
								
									
										118
									
								
								docs/examples/htmltidy.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								docs/examples/htmltidy.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,118 @@ | ||||
| /***************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * Download a document and use libtidy to parse the HTML. | ||||
|  * Written by Jeff Pohlmeyer | ||||
|  * | ||||
|  * LibTidy => http://tidy.sourceforge.net | ||||
|  * | ||||
|  * gcc -Wall -I/usr/local/include tidycurl.c -lcurl -ltidy -o tidycurl | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <tidy/tidy.h> | ||||
| #include <tidy/buffio.h> | ||||
| #include <curl/curl.h> | ||||
|  | ||||
| /* curl write callback, to fill tidy's input buffer...  */ | ||||
| uint write_cb(char *in, uint size, uint nmemb, TidyBuffer *out) | ||||
| { | ||||
|   uint r; | ||||
|   r = size * nmemb; | ||||
|   tidyBufAppend( out, in, r ); | ||||
|   return(r); | ||||
| } | ||||
|  | ||||
| /* Traverse the document tree */ | ||||
| void dumpNode(TidyDoc doc, TidyNode tnod, int indent ) | ||||
| { | ||||
|   TidyNode child; | ||||
|   for ( child = tidyGetChild(tnod); child; child = tidyGetNext(child) ) | ||||
|   { | ||||
|     ctmbstr name = tidyNodeGetName( child ); | ||||
|     if ( name ) | ||||
|     { | ||||
|       /* if it has a name, then it's an HTML tag ... */ | ||||
|       TidyAttr attr; | ||||
|       printf( "%*.*s%s ", indent, indent, "<", name); | ||||
|       /* walk the attribute list */ | ||||
|       for ( attr=tidyAttrFirst(child); attr; attr=tidyAttrNext(attr) ) { | ||||
|         printf(tidyAttrName(attr)); | ||||
|         tidyAttrValue(attr)?printf("=\"%s\" ", | ||||
|                                    tidyAttrValue(attr)):printf(" "); | ||||
|       } | ||||
|       printf( ">\n"); | ||||
|     } | ||||
|     else { | ||||
|       /* if it doesn't have a name, then it's probably text, cdata, etc... */ | ||||
|       TidyBuffer buf; | ||||
|       tidyBufInit(&buf); | ||||
|       tidyNodeGetText(doc, child, &buf); | ||||
|       printf("%*.*s\n", indent, indent, buf.bp?(char *)buf.bp:""); | ||||
|       tidyBufFree(&buf); | ||||
|     } | ||||
|     dumpNode( doc, child, indent + 4 ); /* recursive */ | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| int main(int argc, char **argv ) | ||||
| { | ||||
|   CURL *curl; | ||||
|   char curl_errbuf[CURL_ERROR_SIZE]; | ||||
|   TidyDoc tdoc; | ||||
|   TidyBuffer docbuf = {0}; | ||||
|   TidyBuffer tidy_errbuf = {0}; | ||||
|   int err; | ||||
|   if ( argc == 2) { | ||||
|     curl = curl_easy_init(); | ||||
|     curl_easy_setopt(curl, CURLOPT_URL, argv[1]); | ||||
|     curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, curl_errbuf); | ||||
|     curl_easy_setopt(curl, CURLOPT_NOPROGRESS, no); | ||||
|     curl_easy_setopt(curl, CURLOPT_VERBOSE, yes); | ||||
|     curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_cb); | ||||
|  | ||||
|     tdoc = tidyCreate(); | ||||
|     tidyOptSetBool(tdoc, TidyForceOutput, yes); /* try harder */ | ||||
|     tidyOptSetInt(tdoc, TidyWrapLen, 4096); | ||||
|     tidySetErrorBuffer( tdoc, &tidy_errbuf ); | ||||
|     tidyBufInit(&docbuf); | ||||
|  | ||||
|     curl_easy_setopt(curl, CURLOPT_WRITEDATA, &docbuf); | ||||
|     err=curl_easy_perform(curl); | ||||
|     if ( !err ) { | ||||
|       err = tidyParseBuffer(tdoc, &docbuf); /* parse the input */ | ||||
|       if ( err >= 0 ) { | ||||
|         err = tidyCleanAndRepair(tdoc); /* fix any problems */ | ||||
|         if ( err >= 0 ) { | ||||
|           err = tidyRunDiagnostics(tdoc); /* load tidy error buffer */ | ||||
|           if ( err >= 0 ) { | ||||
|             dumpNode( tdoc, tidyGetRoot(tdoc), 0 ); /* walk the tree */ | ||||
|             fprintf(stderr, "%s\n", tidy_errbuf.bp); /* show errors */ | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|       fprintf(stderr, "%s\n", curl_errbuf); | ||||
|  | ||||
|     /* clean-up */ | ||||
|     curl_easy_cleanup(curl); | ||||
|     tidyBufFree(&docbuf); | ||||
|     tidyBufFree(&tidy_errbuf); | ||||
|     tidyRelease(tdoc); | ||||
|     return(err); | ||||
|  | ||||
|   } | ||||
|   else | ||||
|     printf( "usage: %s <url>\n", argv[0] ); | ||||
|  | ||||
|   return(0); | ||||
| } | ||||
							
								
								
									
										301
									
								
								docs/examples/htmltitle.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										301
									
								
								docs/examples/htmltitle.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,301 @@ | ||||
| /***************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * $Id$ | ||||
|  */ | ||||
|  | ||||
| // Get a web page, parse it with libxml. | ||||
| // | ||||
| // Written by Lars Nilsson | ||||
| // | ||||
| // GNU C++ compile command line suggestion (edit paths accordingly): | ||||
| // | ||||
| // g++ -Wall -I/opt/curl/include -I/opt/libxml/include/libxml2 htmltitle.cc \ | ||||
| // -o htmltitle -L/opt/curl/lib -L/opt/libxml/lib -lcurl -lxml2 | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include <string> | ||||
| #include <curl/curl.h> | ||||
| #include <libxml/HTMLparser.h> | ||||
|  | ||||
| // | ||||
| //  Case-insensitive string comparison | ||||
| // | ||||
|  | ||||
| #ifdef _MSC_VER | ||||
| #define COMPARE(a, b) (!stricmp((a), (b))) | ||||
| #else | ||||
| #define COMPARE(a, b) (!strcasecmp((a), (b))) | ||||
| #endif | ||||
|  | ||||
| // | ||||
| //  libxml callback context structure | ||||
| // | ||||
|  | ||||
| struct Context | ||||
| { | ||||
|   Context(): addTitle(false) { } | ||||
|  | ||||
|   bool addTitle; | ||||
|   std::string title; | ||||
| }; | ||||
|  | ||||
| // | ||||
| //  libcurl variables for error strings and returned data | ||||
|  | ||||
| static char errorBuffer[CURL_ERROR_SIZE]; | ||||
| static std::string buffer; | ||||
|  | ||||
| // | ||||
| //  libcurl write callback function | ||||
| // | ||||
|  | ||||
| static int writer(char *data, size_t size, size_t nmemb, | ||||
|                   std::string *writerData) | ||||
| { | ||||
|   if (writerData == NULL) | ||||
|     return 0; | ||||
|  | ||||
|   writerData->append(data, size*nmemb); | ||||
|  | ||||
|   return size * nmemb; | ||||
| } | ||||
|  | ||||
| // | ||||
| //  libcurl connection initialization | ||||
| // | ||||
|  | ||||
| static bool init(CURL *&conn, char *url) | ||||
| { | ||||
|   CURLcode code; | ||||
|  | ||||
|   conn = curl_easy_init(); | ||||
|  | ||||
|   if (conn == NULL) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to create CURL connection\n"); | ||||
|  | ||||
|     exit(EXIT_FAILURE); | ||||
|   } | ||||
|  | ||||
|   code = curl_easy_setopt(conn, CURLOPT_ERRORBUFFER, errorBuffer); | ||||
|   if (code != CURLE_OK) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to set error buffer [%d]\n", code); | ||||
|  | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   code = curl_easy_setopt(conn, CURLOPT_URL, url); | ||||
|   if (code != CURLE_OK) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to set URL [%s]\n", errorBuffer); | ||||
|  | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   code = curl_easy_setopt(conn, CURLOPT_FOLLOWLOCATION, 1); | ||||
|   if (code != CURLE_OK) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to set redirect option [%s]\n", errorBuffer); | ||||
|  | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   code = curl_easy_setopt(conn, CURLOPT_WRITEFUNCTION, writer); | ||||
|   if (code != CURLE_OK) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to set writer [%s]\n", errorBuffer); | ||||
|  | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   code = curl_easy_setopt(conn, CURLOPT_WRITEDATA, &buffer); | ||||
|   if (code != CURLE_OK) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to set write data [%s]\n", errorBuffer); | ||||
|  | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| // | ||||
| //  libxml start element callback function | ||||
| // | ||||
|  | ||||
| static void StartElement(void *voidContext, | ||||
|                          const xmlChar *name, | ||||
|                          const xmlChar **attributes) | ||||
| { | ||||
|   Context *context = (Context *)voidContext; | ||||
|  | ||||
|   if (COMPARE((char *)name, "TITLE")) | ||||
|   { | ||||
|     context->title = ""; | ||||
|     context->addTitle = true; | ||||
|   } | ||||
| } | ||||
|  | ||||
| // | ||||
| //  libxml end element callback function | ||||
| // | ||||
|  | ||||
| static void EndElement(void *voidContext, | ||||
|                        const xmlChar *name) | ||||
| { | ||||
|   Context *context = (Context *)voidContext; | ||||
|  | ||||
|   if (COMPARE((char *)name, "TITLE")) | ||||
|     context->addTitle = false; | ||||
| } | ||||
|  | ||||
| // | ||||
| //  Text handling helper function | ||||
| // | ||||
|  | ||||
| static void handleCharacters(Context *context, | ||||
|                              const xmlChar *chars, | ||||
|                              int length) | ||||
| { | ||||
|   if (context->addTitle) | ||||
|     context->title.append((char *)chars, length); | ||||
| } | ||||
|  | ||||
| // | ||||
| //  libxml PCDATA callback function | ||||
| // | ||||
|  | ||||
| static void Characters(void *voidContext, | ||||
|                        const xmlChar *chars, | ||||
|                        int length) | ||||
| { | ||||
|   Context *context = (Context *)voidContext; | ||||
|  | ||||
|   handleCharacters(context, chars, length); | ||||
| } | ||||
|  | ||||
| // | ||||
| //  libxml CDATA callback function | ||||
| // | ||||
|  | ||||
| static void cdata(void *voidContext, | ||||
|                   const xmlChar *chars, | ||||
|                   int length) | ||||
| { | ||||
|   Context *context = (Context *)voidContext; | ||||
|  | ||||
|   handleCharacters(context, chars, length); | ||||
| } | ||||
|  | ||||
| // | ||||
| //  libxml SAX callback structure | ||||
| // | ||||
|  | ||||
| static htmlSAXHandler saxHandler = | ||||
| { | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   StartElement, | ||||
|   EndElement, | ||||
|   NULL, | ||||
|   Characters, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   NULL, | ||||
|   cdata, | ||||
|   NULL | ||||
| }; | ||||
|  | ||||
| // | ||||
| //  Parse given (assumed to be) HTML text and return the title | ||||
| // | ||||
|  | ||||
| static void parseHtml(const std::string &html, | ||||
|                       std::string &title) | ||||
| { | ||||
|   htmlParserCtxtPtr ctxt; | ||||
|   Context context; | ||||
|  | ||||
|   ctxt = htmlCreatePushParserCtxt(&saxHandler, &context, "", 0, "", | ||||
|                                   XML_CHAR_ENCODING_NONE); | ||||
|  | ||||
|   htmlParseChunk(ctxt, html.c_str(), html.size(), 0); | ||||
|   htmlParseChunk(ctxt, "", 0, 1); | ||||
|  | ||||
|   htmlFreeParserCtxt(ctxt); | ||||
|  | ||||
|   title = context.title; | ||||
| } | ||||
|  | ||||
| int main(int argc, char *argv[]) | ||||
| { | ||||
|   CURL *conn = NULL; | ||||
|   CURLcode code; | ||||
|   std::string title; | ||||
|  | ||||
|   // Ensure one argument is given | ||||
|  | ||||
|   if (argc != 2) | ||||
|   { | ||||
|     fprintf(stderr, "Usage: %s <url>\n", argv[0]); | ||||
|  | ||||
|     exit(EXIT_FAILURE); | ||||
|   } | ||||
|  | ||||
|   curl_global_init(CURL_GLOBAL_DEFAULT); | ||||
|  | ||||
|   // Initialize CURL connection | ||||
|  | ||||
|   if (!init(conn, argv[1])) | ||||
|   { | ||||
|     fprintf(stderr, "Connection initializion failed\n"); | ||||
|  | ||||
|     exit(EXIT_FAILURE); | ||||
|   } | ||||
|  | ||||
|   // Retrieve content for the URL | ||||
|  | ||||
|   code = curl_easy_perform(conn); | ||||
|   curl_easy_cleanup(conn); | ||||
|  | ||||
|   if (code != CURLE_OK) | ||||
|   { | ||||
|     fprintf(stderr, "Failed to get '%s' [%s]\n", argv[1], errorBuffer); | ||||
|  | ||||
|     exit(EXIT_FAILURE); | ||||
|   } | ||||
|  | ||||
|   // Parse the (assumed) HTML code | ||||
|  | ||||
|   parseHtml(buffer, title); | ||||
|  | ||||
|   // Display the extracted title | ||||
|  | ||||
|   printf("Title: %s\n", title.c_str()); | ||||
|  | ||||
|   return EXIT_SUCCESS; | ||||
| } | ||||
| @@ -19,6 +19,9 @@ | ||||
|  * line argument to the URL also given on the command line. | ||||
|  * | ||||
|  * This example also uses its own read callback. | ||||
|  * | ||||
|  * Here's an article on how to setup a PUT handler for Apache: | ||||
|  * http://www.apacheweek.com/features/put | ||||
|  */ | ||||
|  | ||||
| size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream) | ||||
|   | ||||
| @@ -20,7 +20,8 @@ PROGRAMS  = fopen.exe ftpget.exe ftpgetresp.exe ftpupload.exe \ | ||||
|             multi-double.exe multi-post.exe multi-single.exe \ | ||||
|             persistant.exe post-callback.exe postit2.exe \ | ||||
|             sepheaders.exe simple.exe simplessl.exe https.exe \ | ||||
|             ftp3rdparty.exe getinfo.exe anyauthput.exe | ||||
|             ftp3rdparty.exe getinfo.exe anyauthput.exe \ | ||||
|             cookie_interface.exe | ||||
|  | ||||
| all: $(PROGRAMS) | ||||
|  | ||||
|   | ||||
							
								
								
									
										77
									
								
								docs/examples/opensslthreadlock.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								docs/examples/opensslthreadlock.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | ||||
| /***************************************************************************** | ||||
|  *                                  _   _ ____  _ | ||||
|  *  Project                     ___| | | |  _ \| | | ||||
|  *                             / __| | | | |_) | | | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * $Id$ | ||||
|  * | ||||
|  * Example source code to show one way to set the necessary OpenSSL locking | ||||
|  * callbacks if you want to do multi-threaded transfers with HTTPS/FTPS with | ||||
|  * libcurl built to use OpenSSL. | ||||
|  * | ||||
|  * This is not a complete stand-alone example. | ||||
|  * | ||||
|  * Author: Jeremy Brown | ||||
|  */ | ||||
|  | ||||
| #define MUTEX_TYPE       pthread_mutex_t | ||||
| #define MUTEX_SETUP(x)   pthread_mutex_init(&(x), NULL) | ||||
| #define MUTEX_CLEANUP(x) pthread_mutex_destroy(&(x)) | ||||
| #define MUTEX_LOCK(x)    pthread_mutex_lock(&(x)) | ||||
| #define MUTEX_UNLOCK(x)  pthread_mutex_unlock(&(x)) | ||||
| #define THREAD_ID        pthread_self(  ) | ||||
|  | ||||
|  | ||||
| void handle_error(const char *file, int lineno, const char *msg){ | ||||
|      fprintf(stderr, ** %s:%i %s\n, file, lineno, msg); | ||||
|      ERR_print_errors_fp(stderr); | ||||
|      /* exit(-1); */ | ||||
|  } | ||||
|  | ||||
| /* This array will store all of the mutexes available to OpenSSL. */ | ||||
| static MUTEX_TYPE *mutex_buf= NULL; | ||||
|  | ||||
|  | ||||
| static void locking_function(int mode, int n, const char * file, int line) | ||||
| { | ||||
|   if (mode & CRYPTO_LOCK) | ||||
|     MUTEX_LOCK(mutex_buf[n]); | ||||
|   else | ||||
|     MUTEX_UNLOCK(mutex_buf[n]); | ||||
| } | ||||
|  | ||||
| static unsigned long id_function(void) | ||||
| { | ||||
|   return ((unsigned long)THREAD_ID); | ||||
| } | ||||
|  | ||||
| int thread_setup(void) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   mutex_buf = (MUTEX_TYPE *)malloc(CRYPTO_num_locks(  ) * sizeof(MUTEX_TYPE)); | ||||
|   if (!mutex_buf) | ||||
|     return 0; | ||||
|   for (i = 0;  i < CRYPTO_num_locks(  );  i++) | ||||
|     MUTEX_SETUP(mutex_buf[i]); | ||||
|   CRYPTO_set_id_callback(id_function); | ||||
|   CRYPTO_set_locking_callback(locking_function); | ||||
|   return 1; | ||||
| } | ||||
|  | ||||
| int thread_cleanup(void) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   if (!mutex_buf) | ||||
|     return 0; | ||||
|   CRYPTO_set_id_callback(NULL); | ||||
|   CRYPTO_set_locking_callback(NULL); | ||||
|   for (i = 0;  i < CRYPTO_num_locks(  );  i++) | ||||
|     MUTEX_CLEANUP(mutex_buf[i]); | ||||
|   free(mutex_buf); | ||||
|   mutex_buf = NULL; | ||||
|   return 1; | ||||
| } | ||||
| @@ -52,7 +52,7 @@ PDFPAGES = curl_easy_cleanup.pdf curl_easy_getinfo.pdf			\ | ||||
|  | ||||
| CLEANFILES = $(HTMLPAGES) $(PDFPAGES) | ||||
|  | ||||
| EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) | ||||
| EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) libcurl.m4 | ||||
|  | ||||
| MAN2HTML= roffit --mandir=. < $< >$@ | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_easy_getinfo 3 "14 Dec 2004" "libcurl 7.12.3" "libcurl Manual" | ||||
| .TH curl_easy_getinfo 3 "6 Oct 2005" "libcurl 7.12.3" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_easy_getinfo - extract information from a curl handle | ||||
| .SH SYNOPSIS | ||||
| @@ -15,9 +15,9 @@ Request internal information from the curl session with this function.  The | ||||
| third argument \fBMUST\fP be a pointer to a long, a pointer to a char *, a | ||||
| pointer to a struct curl_slist * or a pointer to a double (as this | ||||
| documentation describes further down).  The data pointed-to will be filled in | ||||
| accordingly and can be relied upon only if the function returns CURLE_OK. | ||||
| This function is intended to get used AFTER a performed transfer, all results | ||||
| from this function are undefined until the transfer is completed. | ||||
| accordingly and can be relied upon only if the function returns CURLE_OK.  Use | ||||
| this function AFTER a performed transfer if you want to get transfer- oriented | ||||
| data. | ||||
|  | ||||
| You should not free the memory returned by this function unless it is | ||||
| explictly mentioned below. | ||||
| @@ -27,14 +27,22 @@ The following information can be extracted: | ||||
| Pass a pointer to a 'char *' to receive the last used effective URL. | ||||
| .IP CURLINFO_RESPONSE_CODE | ||||
| Pass a pointer to a long to receive the last received HTTP or FTP code. This | ||||
| option was known as CURLINFO_HTTP_CODE in libcurl 7.10.7 and earlier. | ||||
| option was known as CURLINFO_HTTP_CODE in libcurl 7.10.7 and earlier. This | ||||
| will be zero if no server response code has been received. Note that a proxy's | ||||
| CONNECT response should be read with \fICURLINFO_HTTP_CONNECTCODE\fP and not | ||||
| this. | ||||
| .IP CURLINFO_HTTP_CONNECTCODE | ||||
| Pass a pointer to a long to receive the last received proxy response code to a | ||||
| CONNECT request. | ||||
| .IP CURLINFO_FILETIME | ||||
| Pass a pointer to a long to receive the remote time of the retrieved | ||||
| document. If you get -1, it can be because of many reasons (unknown, the | ||||
| server hides it or the server doesn't support the command that tells document | ||||
| time etc) and the time of the document is unknown. Note that you must tell the | ||||
| server to collect this information before the transfer is made, by using the | ||||
| CURLOPT_FILETIME option to \fIcurl_easy_setopt(3)\fP. (Added in 7.5) | ||||
| Pass a pointer to a long to receive the remote time of the retrieved document | ||||
| (in number of seconds since 1 jan 1970 in the GMT/UTC time zone). If you get | ||||
| -1, it can be because of many reasons (unknown, the server hides it or the | ||||
| server doesn't support the command that tells document time etc) and the time | ||||
| of the document is unknown. Note that you must tell the server to collect this | ||||
| information before the transfer is made, by using the CURLOPT_FILETIME option | ||||
| to \fIcurl_easy_setopt(3)\fP or you will unconditionally get a -1 back. (Added | ||||
| in 7.5) | ||||
| .IP CURLINFO_TOTAL_TIME | ||||
| Pass a pointer to a double to receive the total transaction time in seconds | ||||
| for the previous transfer. This time does not include the connect time, so if | ||||
| @@ -126,6 +134,47 @@ counted).  Combined with \fICURLINFO_REDIRECT_COUNT\fP you are able to know | ||||
| how many times libcurl successfully reused existing connection(s) or not.  See | ||||
| the Connection Options of \fIcurl_easy_setopt(3)\fP to see how libcurl tries | ||||
| to make persistent connections to save time.  (Added in 7.12.3) | ||||
| .IP CURLINFO_COOKIELIST | ||||
| Pass a pointer to a 'struct curl_slist *' to receive a linked-list of all | ||||
| cookies cURL knows (expired ones, too). Don't forget to | ||||
| \fIcurl_slist_free_all(3)\fP the list after it has been used.  If there are no | ||||
| cookies (cookies for the handle have not been enabled or simply none have been | ||||
| received) 'struct curl_slist *' will be set to point to NULL. (Added in | ||||
| 7.14.1) | ||||
| .SH TIMES | ||||
| .NF | ||||
| An overview of the six time values available from curl_easy_getinfo() | ||||
|  | ||||
| curk_easy_perform() | ||||
|     | | ||||
|     |--NT | ||||
|     |--|--CT | ||||
|     |--|--|--PT | ||||
|     |--|--|--|--ST | ||||
|           |--|--|--TT | ||||
|     |--|--|--|--|--RT | ||||
| .FI | ||||
| .IP NT | ||||
| \fICURLINFO_NAMELOOKUP_TIME\fP. The time it took from the start until the name | ||||
| resolving was completed. | ||||
| .IP CT | ||||
| \fICURLINFO_CONNECT_TIME\fP. The time it took from the start until the connect | ||||
| to the remote host (or proxy) was completed. | ||||
| .IP PT | ||||
| \fICURLINFO_PRETRANSFER_TIME\fP. The time it took from the start until the | ||||
| file transfer is just about to begin. This includes all pre-transfer commands | ||||
| and negotiations that are specific to the particular protocol(s) involved. | ||||
| .IP ST | ||||
| \fICURLINFO_STARTTRANSFER_TIME\fP. The time it took from the start until the | ||||
| first byte is just about to be transferred. | ||||
| .IP TT | ||||
| \fICURLINFO_TOTAL_TIME\fP. Time of the previous transfer. This time does not | ||||
| include the connect time (CT), so if you want the complete operation time, you | ||||
| should add that. | ||||
| .IP RT | ||||
| \fICURLINFO_REDIRECT_TIME\fP. The time it took for all redirection steps | ||||
| include name lookup, connect, pretransfer and transfer before final | ||||
| transaction was started. So, this is zero if no redirection took place. | ||||
| .SH RETURN VALUE | ||||
| If the operation was successful, CURLE_OK is returned. Otherwise an | ||||
| appropriate error code will be returned. | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -21,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH curl_easy_setopt 3 "29 Nov 2004" "libcurl 7.12.3" "libcurl Manual" | ||||
| .TH curl_easy_setopt 3 "22 Sep 2005" "libcurl 7.14.2" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_easy_setopt - set options for a curl easy handle | ||||
| .SH SYNOPSIS | ||||
| @@ -44,11 +44,11 @@ between transfers, so if you want subsequent transfers with different options, | ||||
| you must change them between the transfers. You can optionally reset all | ||||
| options back to internal default with \fIcurl_easy_reset(3)\fP. | ||||
|  | ||||
| \fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be | ||||
| copied by the library. Instead you should keep them available until libcurl no | ||||
| longer needs them. Failing to do so will cause very odd behavior or even | ||||
| crashes. libcurl will need them until you call \fIcurl_easy_cleanup(3)\fP or | ||||
| you set the same option again to use a different pointer. | ||||
| Strings passed to libcurl as 'char *' arguments, will not be copied by the | ||||
| library. Instead you should keep them available until libcurl no longer needs | ||||
| them. Failing to do so will cause very odd behavior or even crashes. libcurl | ||||
| will need them until you call \fIcurl_easy_cleanup(3)\fP or you set the same | ||||
| option again to use a different pointer. | ||||
|  | ||||
| The \fIhandle\fP is the return code from a \fIcurl_easy_init(3)\fP or | ||||
| \fIcurl_easy_duphandle(3)\fP call. | ||||
| @@ -70,8 +70,8 @@ preceding the data (like HTTP). | ||||
| A non-zero parameter tells the library to shut off the built-in progress meter | ||||
| completely. | ||||
|  | ||||
| \fBNOTE:\fP future versions of libcurl is likely to not have any built-in | ||||
| progress meter at all. | ||||
| Future versions of libcurl is likely to not have any built-in progress meter | ||||
| at all. | ||||
| .IP CURLOPT_NOSIGNAL | ||||
| Pass a long. If it is non-zero, libcurl will not use any functions that | ||||
| install signal handlers or any functions that cause signals to be sent to the | ||||
| @@ -96,19 +96,26 @@ transfer and return \fICURLE_WRITE_ERROR\fP. | ||||
| This function may be called with zero bytes data if the transfered file is | ||||
| empty. | ||||
|  | ||||
| Set this option to NULL to get the internal default function. The internal | ||||
| default function will write the data to the FILE * given with | ||||
| \fICURLOPT_WRITEDATA\fP. | ||||
|  | ||||
| Set the \fIstream\fP argument with the \fICURLOPT_WRITEDATA\fP option. | ||||
|  | ||||
| \fBNOTE:\fP you will be passed as much data as possible in all invokes, but | ||||
| you cannot possibly make any assumptions. It may be one byte, it may be | ||||
| The callback function will be passed as much data as possible in all invokes, | ||||
| but you cannot possibly make any assumptions. It may be one byte, it may be | ||||
| thousands. The maximum amount of data that can be passed to the write callback | ||||
| is defined in the curl.h header file: CURL_MAX_WRITE_SIZE. | ||||
| .IP CURLOPT_WRITEDATA | ||||
| Data pointer to pass to the file write function. Note that if you specify the | ||||
| \fICURLOPT_WRITEFUNCTION\fP, this is the pointer you'll get as input. If you | ||||
| don't use a callback, you must pass a 'FILE *' as libcurl will pass this to | ||||
| fwrite() when writing data. | ||||
| Data pointer to pass to the file write function. If you use the | ||||
| \fICURLOPT_WRITEFUNCTION\fP option, this is the pointer you'll get as | ||||
| input. If you don't use a callback, you must pass a 'FILE *' as libcurl will | ||||
| pass this to fwrite() when writing data. | ||||
|  | ||||
| \fBNOTE:\fP If you're using libcurl as a win32 DLL, you MUST use the | ||||
| The internal \fICURLOPT_WRITEFUNCTION\fP will write the data to the FILE * | ||||
| given with this option, or to stdout if this option hasn't been set. | ||||
|  | ||||
| If you're using libcurl as a win32 DLL, you \fBMUST\fP use the | ||||
| \fICURLOPT_WRITEFUNCTION\fP if you set this option or you will experience | ||||
| crashes. | ||||
|  | ||||
| @@ -129,15 +136,20 @@ server expected it, like when you've told you will upload N bytes and you | ||||
| upload less than N bytes), you may experience that the server "hangs" waiting | ||||
| for the rest of the data that won't come. | ||||
|  | ||||
| In libcurl 7.12.1 and later, the read callback may return | ||||
| \fICURL_READFUNC_ABORT\fP to stop the current operation at once, with a | ||||
| \fICURLE_ABORTED_BY_CALLBACK\fP error code from the transfer. | ||||
| .IP CURLOPT_READDATA | ||||
| Data pointer to pass to the file read function. Note that if you specify the | ||||
| \fICURLOPT_READFUNCTION\fP, this is the pointer you'll get as input. If you | ||||
| don't specify a read callback, this must be a valid FILE *. | ||||
| The read callback may return \fICURL_READFUNC_ABORT\fP to stop the current | ||||
| operation immediately, resulting in a \fICURLE_ABORTED_BY_CALLBACK\fP error | ||||
| code from the transfer (Added in 7.12.1) | ||||
|  | ||||
| \fBNOTE:\fP If you're using libcurl as a win32 DLL, you MUST use a | ||||
| If you set the callback pointer to NULL, or doesn't set it at all, the default | ||||
| internal read function will be used. It is simply doing an fread() on the FILE | ||||
| * stream set with \fICURLOPT_READDATA\fP. | ||||
| .IP CURLOPT_READDATA | ||||
| Data pointer to pass to the file read function. If you use the | ||||
| \fICURLOPT_READFUNCTION\fP option, this is the pointer you'll get as input. If | ||||
| you don't specify a read callback but instead rely on the default internal | ||||
| read function, this data must be a valid readable FILE *. | ||||
|  | ||||
| If you're using libcurl as a win32 DLL, you MUST use a | ||||
| \fICURLOPT_READFUNCTION\fP if you set this option. | ||||
|  | ||||
| This option is also known with the older name \fICURLOPT_INFILE\fP, the name | ||||
| @@ -163,28 +175,38 @@ data, the upload size will remain 0). Returning a non-zero value from this | ||||
| callback will cause libcurl to abort the transfer and return | ||||
| \fICURLE_ABORTED_BY_CALLBACK\fP. | ||||
|  | ||||
| Also note that \fICURLOPT_NOPROGRESS\fP must be set to FALSE to make this | ||||
| function actually get called. | ||||
| \fICURLOPT_NOPROGRESS\fP must be set to FALSE to make this function actually | ||||
| get called. | ||||
| .IP CURLOPT_PROGRESSDATA | ||||
| Pass a pointer that will be untouched by libcurl and passed as the first | ||||
| argument in the progress callback set with \fICURLOPT_PROGRESSFUNCTION\fP. | ||||
| .IP CURLOPT_HEADERFUNCTION | ||||
| Function pointer that should match the following prototype: \fIsize_t | ||||
| function( void *ptr, size_t size, size_t nmemb, void *stream);\fP. This | ||||
| function gets called by libcurl as soon as there is received header data that | ||||
| needs to be written down. The headers are guaranteed to be written one-by-one | ||||
| and only complete lines are written. Parsing headers should be easy enough | ||||
| function gets called by libcurl as soon as it has received header data. The | ||||
| header callback will be called once for each header and only complete header | ||||
| lines are passed on to the callback. Parsing headers should be easy enough | ||||
| using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP | ||||
| multiplied with \fInmemb\fP.  The pointer named \fIstream\fP will be the one | ||||
| you passed to libcurl with the \fICURLOPT_WRITEHEADER\fP option.  Return the | ||||
| number of bytes actually written or return -1 to signal error to the library | ||||
| multiplied with \fInmemb\fP. Do not assume that the header line is zero | ||||
| terminated! The pointer named \fIstream\fP is the one you set with the | ||||
| \fICURLOPT_WRITEHEADER\fP option. The callback function must return the number | ||||
| of bytes actually taken care of, or return -1 to signal error to the library | ||||
| (it will cause it to abort the transfer with a \fICURLE_WRITE_ERROR\fP return | ||||
| code). | ||||
|  | ||||
| Since 7.14.1: When a server sends a chunked encoded transfer, it may contain a | ||||
| trailer. That trailer is identical to a HTTP header and if such a trailer is | ||||
| received it is passed to the application using this callback as well. There | ||||
| are several ways to detect it being a trailer and not an ordinary header: 1) | ||||
| it comes after the response-body. 2) it comes after the final header line (CR | ||||
| LF) 3) a Trailer: header among the response-headers mention what header to | ||||
| expect in the trailer. | ||||
| .IP CURLOPT_WRITEHEADER | ||||
| Pass a pointer to be used to write the header part of the received data to. If | ||||
| you don't use your own callback to take care of the writing, this must be a | ||||
| valid FILE *. See also the \fICURLOPT_HEADERFUNCTION\fP option above on how to | ||||
| set a custom get-all-headers callback. | ||||
| (This option is also known as \fBCURLOPT_HEADERDATA\fP) Pass a pointer to be | ||||
| used to write the header part of the received data to. If you don't use your | ||||
| own callback to take care of the writing, this must be a valid FILE *. See | ||||
| also the \fICURLOPT_HEADERFUNCTION\fP option above on how to set a custom | ||||
| get-all-headers callback. | ||||
| .IP CURLOPT_DEBUGFUNCTION | ||||
| Function pointer that should match the following prototype: \fIint | ||||
| curl_debug_callback (CURL *, curl_infotype, char *, size_t, void *);\fP | ||||
| @@ -223,10 +245,13 @@ perform operation will return the error code from this callback function.  Set | ||||
| the \fIparm\fP argument with the \fICURLOPT_SSL_CTX_DATA\fP option. This | ||||
| option was introduced in 7.11.0. | ||||
|  | ||||
| \fBNOTE:\fP To use this properly, a non-trivial amount of knowledge of the | ||||
| openssl libraries is necessary. Using this function allows for example to use | ||||
| openssl callbacks to add additional validation code for certificates, and even | ||||
| to change the actual URI of an HTTPS request (example used in the lib509 test | ||||
| This function will get called on all new connections made to a server, during | ||||
| the SSL negotiation. The SSL_CTX pointer will be a new one every time. | ||||
|  | ||||
| To use this properly, a non-trivial amount of knowledge of the openssl | ||||
| libraries is necessary. Using this function allows for example to use openssl | ||||
| callbacks to add additional validation code for certificates, and even to | ||||
| change the actual URI of an HTTPS request (example used in the lib509 test | ||||
| case).  See also the example section for a replacement of the key, certificate | ||||
| and trust file settings. | ||||
| .IP CURLOPT_SSL_CTX_DATA | ||||
| @@ -236,14 +261,21 @@ parameter, otherwise \fBNULL\fP. (Added in 7.11.0) | ||||
| .SH ERROR OPTIONS | ||||
| .IP CURLOPT_ERRORBUFFER | ||||
| Pass a char * to a buffer that the libcurl may store human readable error | ||||
| messages in. This may be more helpful than just the return code from the | ||||
| library. The buffer must be at least CURL_ERROR_SIZE big. | ||||
| messages in. This may be more helpful than just the return code from | ||||
| \fIcurl_easy_perform\fP. The buffer must be at least CURL_ERROR_SIZE big. | ||||
|  | ||||
| Use \fICURLOPT_VERBOSE\fP and \fICURLOPT_DEBUGFUNCTION\fP to better | ||||
| debug/trace why errors happen. | ||||
|  | ||||
| \fBNote:\fP if the library does not return an error, the buffer may not have | ||||
| been touched. Do not rely on the contents in those cases. | ||||
| If the library does not return an error, the buffer may not have been | ||||
| touched. Do not rely on the contents in those cases. | ||||
|  | ||||
| In a few rare cases, there is no text string associated with the error in | ||||
| libcurl and then you may not get a string in the buffer even though it returns | ||||
| an error. This is considered a bug and we appreciate your reports about these | ||||
| cases. Anyway, you can avoid problems with these cases in your program by | ||||
| making sure to clear the first byte of the error buffer before you call | ||||
| curl_easy_perform(). | ||||
| .IP CURLOPT_STDERR | ||||
| Pass a FILE * as parameter. Tell libcurl to use this stream instead of stderr | ||||
| when showing the progress meter and displaying \fICURLOPT_VERBOSE\fP data. | ||||
| @@ -264,7 +296,7 @@ given protocol of the set URL is not supported, libcurl will return on error | ||||
| \fIcurl_multi_perform(3)\fP. Use \fIcurl_version_info(3)\fP for detailed info | ||||
| on which protocols that are supported. | ||||
|  | ||||
| \fBNOTE:\fP \fICURLOPT_URL\fP is the only option that must be set before | ||||
| \fICURLOPT_URL\fP is the only option that must be set before | ||||
| \fIcurl_easy_perform(3)\fP is called. | ||||
| .IP CURLOPT_PROXY | ||||
| Set HTTP proxy to use. The parameter should be a char * to a zero terminated | ||||
| @@ -274,15 +306,20 @@ be prefixed with [protocol]:// since any such prefix will be ignored. The | ||||
| proxy's port number may optionally be specified with the separate option | ||||
| \fICURLOPT_PROXYPORT\fP. | ||||
|  | ||||
| \fBNOTE:\fP when you tell the library to use an HTTP proxy, libcurl will | ||||
| transparently convert operations to HTTP even if you specify an FTP URL | ||||
| etc. This may have an impact on what other features of the library you can | ||||
| use, such as \fICURLOPT_QUOTE\fP and similar FTP specifics that don't work | ||||
| unless you tunnel through the HTTP proxy. Such tunneling is activated with | ||||
| When you tell the library to use an HTTP proxy, libcurl will transparently | ||||
| convert operations to HTTP even if you specify an FTP URL etc. This may have | ||||
| an impact on what other features of the library you can use, such as | ||||
| \fICURLOPT_QUOTE\fP and similar FTP specifics that don't work unless you | ||||
| tunnel through the HTTP proxy. Such tunneling is activated with | ||||
| \fICURLOPT_HTTPPROXYTUNNEL\fP. | ||||
|  | ||||
| \fBNOTE2:\fP libcurl respects the environment variables \fBhttp_proxy\fP, | ||||
| \fBftp_proxy\fP, \fBall_proxy\fP etc, if any of those is set. | ||||
| libcurl respects the environment variables \fBhttp_proxy\fP, \fBftp_proxy\fP, | ||||
| \fBall_proxy\fP etc, if any of those is set. The \fICURLOPT_PROXY\fP option | ||||
| does however override any possibly set environment variables. | ||||
|  | ||||
| Starting with 7.14.1, the proxy host string can be specified the exact same | ||||
| way as the proxy environment variables, include protocol prefix (http://) and | ||||
| embedded user + password. | ||||
| .IP CURLOPT_PROXYPORT | ||||
| Pass a long with this option to set the proxy port to connect to unless it is | ||||
| specified in the proxy string \fICURLOPT_PROXY\fP. | ||||
| @@ -292,9 +329,9 @@ this are \fICURLPROXY_HTTP\fP and \fICURLPROXY_SOCKS5\fP, with the HTTP one | ||||
| being default. (Added in 7.10) | ||||
| .IP CURLOPT_HTTPPROXYTUNNEL | ||||
| Set the parameter to non-zero to get the library to tunnel all operations | ||||
| through a given HTTP proxy. Note that there is a big difference between using | ||||
| a proxy and to tunnel through it. If you don't know what this means, you | ||||
| probably don't want this tunneling option. | ||||
| through a given HTTP proxy. There is a big difference between using a proxy | ||||
| and to tunnel through it. If you don't know what this means, you probably | ||||
| don't want this tunneling option. | ||||
| .IP CURLOPT_INTERFACE | ||||
| Pass a char * as parameter. This set the interface name to use as outgoing | ||||
| network interface. The name can be an interface name, an IP address or a host | ||||
| @@ -313,10 +350,14 @@ thread-safe and this will use a global variable. | ||||
| to using the share interface instead! See \fICURLOPT_SHARE\fP and | ||||
| \fIcurl_share_init(3)\fP. | ||||
| .IP CURLOPT_BUFFERSIZE | ||||
| Pass a long specifying your preferred size for the receive buffer in libcurl. | ||||
| The main point of this would be that the write callback gets called more often | ||||
| and with smaller chunks. This is just treated as a request, not an order. You | ||||
| cannot be guaranteed to actually get the given size. (Added in 7.10) | ||||
| Pass a long specifying your preferred size (in bytes) for the receive buffer | ||||
| in libcurl.  The main point of this would be that the write callback gets | ||||
| called more often and with smaller chunks. This is just treated as a request, | ||||
| not an order. You cannot be guaranteed to actually get the given size. (Added | ||||
| in 7.10) | ||||
|  | ||||
| This size is by default set as big as possible (CURL_MAX_WRITE_SIZE), so it | ||||
| only makse sense to use this option if you want it smaller. | ||||
| .IP CURLOPT_PORT | ||||
| Pass a long specifying what remote port number to connect to, instead of the | ||||
| one specified in the URL or the default port for the used protocol. | ||||
| @@ -342,9 +383,9 @@ This parameter controls the preference of libcurl between using user names and | ||||
| passwords from your \fI~/.netrc\fP file, relative to user names and passwords | ||||
| in the URL supplied with \fICURLOPT_URL\fP. | ||||
|  | ||||
| \fBNote:\fP libcurl uses a user name (and supplied or prompted password) | ||||
| supplied with \fICURLOPT_USERPWD\fP in preference to any of the options | ||||
| controlled by this parameter. | ||||
| libcurl uses a user name (and supplied or prompted password) supplied with | ||||
| \fICURLOPT_USERPWD\fP in preference to any of the options controlled by this | ||||
| parameter. | ||||
|  | ||||
| Pass a long, set to one of the values described below. | ||||
| .RS | ||||
| @@ -368,9 +409,8 @@ and to search the file with the host only. | ||||
| Only machine name, user name and password are taken into account | ||||
| (init macros and similar things aren't supported). | ||||
|  | ||||
| \fBNote:\fP libcurl does not verify that the file has the correct properties | ||||
| set (as the standard Unix ftp client does). It should only be readable by | ||||
| user. | ||||
| libcurl does not verify that the file has the correct properties set (as the | ||||
| standard Unix ftp client does). It should only be readable by user. | ||||
| .IP CURLOPT_NETRC_FILE | ||||
| Pass a char * as parameter, pointing to a zero terminated string containing | ||||
| the full path name to the file you want libcurl to use as .netrc file. If this | ||||
| @@ -395,9 +435,9 @@ Pass a long as parameter, which is set to a bitmask, to tell libcurl what | ||||
| authentication method(s) you want it to use. The available bits are listed | ||||
| below. If more than one bit is set, libcurl will first query the site to see | ||||
| what authentication methods it supports and then pick the best one you allow | ||||
| it to use. Note that for some methods, this will induce an extra network | ||||
| round-trip. Set the actual name and password with the \fICURLOPT_USERPWD\fP | ||||
| option. (Added in 7.10.6) | ||||
| it to use. For some methods, this will induce an extra network round-trip. Set | ||||
| the actual name and password with the \fICURLOPT_USERPWD\fP option. (Added in | ||||
| 7.10.6) | ||||
| .RS | ||||
| .IP CURLAUTH_BASIC | ||||
| HTTP Basic authentication. This is the default choice, and the only method | ||||
| @@ -410,20 +450,19 @@ is a more secure way to do authentication over public networks than the | ||||
| regular old-fashioned Basic method. | ||||
| .IP CURLAUTH_GSSNEGOTIATE | ||||
| HTTP GSS-Negotiate authentication. The GSS-Negotiate (also known as plain | ||||
| "Negotiate") method was designed by Microsoft and is used in their web | ||||
| \&"Negotiate") method was 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. | ||||
|  | ||||
| \fBNOTE\fP that you need to build libcurl with a suitable GSS-API library for | ||||
| this to work. | ||||
| You need to build libcurl with a suitable GSS-API library for this to work. | ||||
| .IP CURLAUTH_NTLM | ||||
| HTTP NTLM authentication. A proprietary protocol invented and used by | ||||
| Microsoft. It uses a challenge-response and hash concept similar to Digest, to | ||||
| prevent the password from being eavesdropped. | ||||
|  | ||||
| \fBNOTE\fP that you need to build libcurl with SSL support for this option to | ||||
| work. | ||||
| You need to build libcurl with OpenSSL support for this option to work, or | ||||
| build libcurl on Windows. | ||||
| .IP CURLAUTH_ANY | ||||
| This is a convenience macro that sets all bits and thus makes libcurl pick any | ||||
| it finds suitable. libcurl will automatically select the one it finds most | ||||
| @@ -438,11 +477,11 @@ Pass a long as parameter, which is set to a bitmask, to tell libcurl what | ||||
| authentication method(s) you want it to use for your proxy authentication.  If | ||||
| more than one bit is set, libcurl will first query the site to see what | ||||
| authentication methods it supports and then pick the best one you allow it to | ||||
| use. Note that for some methods, this will induce an extra network | ||||
| round-trip. Set the actual name and password with the | ||||
| \fICURLOPT_PROXYUSERPWD\fP option. The bitmask can be constructed by or'ing | ||||
| together the bits listed above for the \fICURLOPT_HTTPAUTH\fP option. As of | ||||
| this writing, only Basic and NTLM work. (Added in 7.10.7) | ||||
| use. For some methods, this will induce an extra network round-trip. Set the | ||||
| actual name and password with the \fICURLOPT_PROXYUSERPWD\fP option. The | ||||
| bitmask can be constructed by or'ing together the bits listed above for the | ||||
| \fICURLOPT_HTTPAUTH\fP option. As of this writing, only Basic, Digest and NTLM | ||||
| work. (Added in 7.10.7) | ||||
| .SH HTTP OPTIONS | ||||
| .IP CURLOPT_AUTOREFERER | ||||
| Pass a non-zero parameter to enable this. When enabled, libcurl will | ||||
| @@ -465,14 +504,14 @@ lib/README.encoding for details. | ||||
| A non-zero parameter tells the library to follow any Location: header that the | ||||
| server sends as part of an HTTP header. | ||||
|  | ||||
| \fBNOTE:\fP this means that the library will re-send the same request on the | ||||
| new location and follow new Location: headers all the way until no more such | ||||
| headers are returned. \fICURLOPT_MAXREDIRS\fP can be used to limit the number | ||||
| of redirects libcurl will follow. | ||||
| This means that the library will re-send the same request on the new location | ||||
| and follow new Location: headers all the way until no more such headers are | ||||
| returned. \fICURLOPT_MAXREDIRS\fP can be used to limit the number of redirects | ||||
| libcurl will follow. | ||||
| .IP CURLOPT_UNRESTRICTED_AUTH | ||||
| A non-zero parameter tells the library it can continue to send authentication | ||||
| (user+password) when following locations, even when hostname changed. Note | ||||
| that this is meaningful only when setting \fICURLOPT_FOLLOWLOCATION\fP. | ||||
| (user+password) when following locations, even when hostname changed. This | ||||
| option is meaningful only when setting \fICURLOPT_FOLLOWLOCATION\fP. | ||||
| .IP CURLOPT_MAXREDIRS | ||||
| Pass a long. The set number will be the redirection limit. If that many | ||||
| redirections have been followed, the next redirect will cause an error | ||||
| @@ -511,8 +550,11 @@ adding a header like "Transfer-Encoding: chunked" with | ||||
| \fICURLOPT_HTTPHEADER\fP. With HTTP 1.0 or without chunked transfer, you must | ||||
| specify the size in the request. | ||||
|  | ||||
| NOTE: if you have issued a POST request and want to make a HEAD or GET | ||||
| instead, you must explictly pick the new request type using | ||||
| When setting \fICURLOPT_POST\fP to a non-zero value, it will automatically set | ||||
| \fICURLOPT_NOBODY\fP to 0 (since 7.14.1). | ||||
|  | ||||
| If you issue a POST request and then want to make a HEAD or GET using the same | ||||
| re-used handle, you must explictly set the new request type using | ||||
| \fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar. | ||||
| .IP CURLOPT_POSTFIELDS | ||||
| Pass a char * as parameter, which should be the full data to post in an HTTP | ||||
| @@ -528,8 +570,8 @@ commonly used one by HTML forms. See also the \fICURLOPT_POST\fP. Using | ||||
| Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||
| You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | ||||
|  | ||||
| \fBNote:\fP to make multipart/formdata posts (aka rfc1867-posts), check out | ||||
| the \fICURLOPT_HTTPPOST\fP option. | ||||
| To make multipart/formdata posts (aka rfc1867-posts), check out the | ||||
| \fICURLOPT_HTTPPOST\fP option. | ||||
| .IP CURLOPT_POSTFIELDSIZE | ||||
| If you want to post data to the server without letting libcurl do a strlen() | ||||
| to measure the data size, this option must be used. When this option is used | ||||
| @@ -543,14 +585,16 @@ data to figure out the size. This is the large file version of the | ||||
| .IP CURLOPT_HTTPPOST | ||||
| Tells libcurl you want a multipart/formdata HTTP POST to be made and you | ||||
| instruct what data to pass on to the server.  Pass a pointer to a linked list | ||||
| of HTTP post structs as parameter.  The linked list should be a fully valid | ||||
| list of 'struct HttpPost' structs properly filled in. The best and most | ||||
| elegant way to do this, is to use \fIcurl_formadd(3)\fP as documented. The | ||||
| data in this list must remain intact until you close this curl handle again | ||||
| with \fIcurl_easy_cleanup(3)\fP. | ||||
| of curl_httppost structs as parameter. . The easiest way to create such a | ||||
| list, is to use \fIcurl_formadd(3)\fP as documented. The data in this list | ||||
| must remain intact until you close this curl handle again with | ||||
| \fIcurl_easy_cleanup(3)\fP. | ||||
|  | ||||
| Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header. | ||||
| You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual. | ||||
|  | ||||
| When setting \fICURLOPT_HTTPPOST\fP, it will automatically set | ||||
| \fICURLOPT_NOBODY\fP to 0 (since 7.14.1). | ||||
| .IP CURLOPT_REFERER | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used to | ||||
| set the Referer: header in the http request sent to the remote server. This | ||||
| @@ -582,7 +626,7 @@ request-line are headers. | ||||
|  | ||||
| Pass a NULL to this to reset back to no custom headers. | ||||
|  | ||||
| \fBNOTE:\fP The most commonly replaced headers have "shortcuts" in the options | ||||
| The most commonly replaced headers have "shortcuts" in the options | ||||
| \fICURLOPT_COOKIE\fP, \fICURLOPT_USERAGENT\fP and \fICURLOPT_REFERER\fP. | ||||
| .IP CURLOPT_HTTP200ALIASES | ||||
| Pass a pointer to a linked list of aliases to be treated as valid HTTP 200 | ||||
| @@ -595,9 +639,9 @@ The linked list should be a fully valid list of struct curl_slist structs, and | ||||
| be properly filled in.  Use \fIcurl_slist_append(3)\fP to create the list and | ||||
| \fIcurl_slist_free_all(3)\fP to clean up an entire list. | ||||
|  | ||||
| \fBNOTE:\fP The alias itself is not parsed for any version strings.  So if your | ||||
| alias is "MYHTTP/9.9", Libcurl will not treat the server as responding with | ||||
| HTTP version 9.9.  Instead Libcurl will use the value set by option | ||||
| The alias itself is not parsed for any version strings.  So if your alias is | ||||
| \&"MYHTTP/9.9", Libcurl will not treat the server as responding with HTTP | ||||
| version 9.9.  Instead Libcurl will use the value set by option | ||||
| \fICURLOPT_HTTP_VERSION\fP. | ||||
| .IP CURLOPT_COOKIE | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used to | ||||
| @@ -618,9 +662,12 @@ name of your file holding cookie data to read. The cookie data may be in | ||||
| Netscape / Mozilla cookie data format or just regular HTTP-style headers | ||||
| dumped to a file. | ||||
|  | ||||
| Given an empty or non-existing file, this option will enable cookies for this | ||||
| curl handle, making it understand and parse received cookies and then use | ||||
| matching cookies in future request. | ||||
| Given an empty or non-existing file or by passing the empty string (""), this | ||||
| option will enable cookies for this curl handle, making it understand and | ||||
| parse received cookies and then use matching cookies in future request. | ||||
|  | ||||
| If you use this option multiple times, you just add more files to read. | ||||
| Subsequent files will add more cookies. | ||||
| .IP CURLOPT_COOKIEJAR | ||||
| Pass a file name as char *, zero terminated. This will make libcurl write all | ||||
| internally known cookies to the specified file when \fIcurl_easy_cleanup(3)\fP | ||||
| @@ -629,7 +676,7 @@ instead have the cookies written to stdout. Using this option also enables | ||||
| cookies for this session, so if you for example follow a location it will make | ||||
| matching cookies get sent accordingly. | ||||
|  | ||||
| \fBNOTE:\fP If the cookie jar file can't be created or written to (when the | ||||
| If the cookie jar file can't be created or written to (when the | ||||
| \fIcurl_easy_cleanup(3)\fP is called), libcurl will not and cannot report an | ||||
| error for this. Using \fICURLOPT_VERBOSE\fP or \fICURLOPT_DEBUGFUNCTION\fP | ||||
| will get a warning to display, but that is the only visible feedback you get | ||||
| @@ -641,10 +688,18 @@ cookies" from the previous session. By default, libcurl always stores and | ||||
| loads all cookies, independent if they are session cookies are not. Session | ||||
| cookies are cookies without expiry date and they are meant to be alive and | ||||
| existing for this "session" only. | ||||
| .IP CURLOPT_COOKIELIST | ||||
| Pass a char * to a cookie string. Cookie can be either in Netscape / Mozilla | ||||
| format or just regular HTTP-style header (Set-Cookie: ...) format. If cURL | ||||
| cookie engine was not enabled it will enable its cookie engine.  Passing a | ||||
| magic string \&"ALL" will erase all cookies known by cURL. (Added in 7.14.1) | ||||
| .IP CURLOPT_HTTPGET | ||||
| Pass a long. If the long is non-zero, this forces the HTTP request to get back | ||||
| to GET. usable if a POST, HEAD, PUT or a custom request have been used | ||||
| previously using the same curl handle. | ||||
|  | ||||
| When setting \fICURLOPT_HTTPGET\fP to a non-zero value, it will automatically | ||||
| set \fICURLOPT_NOBODY\fP to 0 (since 7.14.1). | ||||
| .IP CURLOPT_HTTP_VERSION | ||||
| Pass a long, set to one of the values described below. They force libcurl to | ||||
| use the specific HTTP versions. This is not sensible to do unless you have a | ||||
| @@ -657,6 +712,12 @@ it thinks fit. | ||||
| Enforce HTTP 1.0 requests. | ||||
| .IP CURL_HTTP_VERSION_1_1 | ||||
| Enforce HTTP 1.1 requests. | ||||
| .IP CURLOPT_IGNORE_CONTENT_LENGTH | ||||
| Ignore the Content-Length header. This is useful for Apache 1.x (and similar | ||||
| servers) which will report incorrect content length for files over 2 | ||||
| gigabytes. If this option is used, curl will not be able to accurately report | ||||
| progress, and will simply stop the download when the server ends the | ||||
| connection. (added in 7.14.1) | ||||
| .RE | ||||
| .SH FTP OPTIONS | ||||
| .IP CURLOPT_FTPPORT | ||||
| @@ -722,11 +783,19 @@ directory. (Added in 7.10.7) | ||||
| .IP CURLOPT_FTP_RESPONSE_TIMEOUT | ||||
| Pass a long.  Causes curl to set a timeout period (in seconds) on the amount | ||||
| of time that the server is allowed to take in order to generate a response | ||||
| message for a command before the session is considered hung.  Note that while | ||||
| curl is waiting for a response, this value overrides \fICURLOPT_TIMEOUT\fP. It | ||||
| is recommended that if used in conjunction with \fICURLOPT_TIMEOUT\fP, you set | ||||
| message for a command before the session is considered hung.  While curl is | ||||
| waiting for a response, this value overrides \fICURLOPT_TIMEOUT\fP. It is | ||||
| recommended that if used in conjunction with \fICURLOPT_TIMEOUT\fP, you set | ||||
| \fICURLOPT_FTP_RESPONSE_TIMEOUT\fP to a value smaller than | ||||
| \fICURLOPT_TIMEOUT\fP.  (Added in 7.10.8) | ||||
| .IP CURLOPT_FTP_SKIP_PASV_IP | ||||
| Pass a long. If set to a non-zero value, it instructs libcurl to not use the | ||||
| IP address the server suggests in its 227-response to libcurl's PASV command | ||||
| when libcurl connects the data connection. Instead libcurl will re-use the | ||||
| same IP address it already uses for the control connection. But it will use | ||||
| the port number from the 227-response. (Added in 7.14.2) | ||||
|  | ||||
| This option has no effect if PORT, EPRT or EPSV is used instead of PASV. | ||||
| .IP CURLOPT_FTP_SSL | ||||
| Pass a long using one of the values from below, to make libcurl use your | ||||
| desired level of SSL for the ftp transfer. (Added in 7.11.0) | ||||
| @@ -752,14 +821,33 @@ Try "AUTH SSL" first, and only if that fails try "AUTH TLS" | ||||
| .IP CURLFTPAUTH_TLS | ||||
| Try "AUTH TLS" first, and only if that fails try "AUTH SSL" | ||||
| .RE | ||||
| .IP CURLOPT_SOURCE_URL | ||||
| When set, it enables a FTP third party transfer, using the set URL as source, | ||||
| while \fICURLOPT_URL\fP is the target. | ||||
| .IP CURLOPT_SOURCE_USERPWD | ||||
| Set "username:password" to use for the source connection when doing FTP third | ||||
| party transfers. | ||||
| .IP CURLOPT_SOURCE_QUOTE | ||||
| Exactly like \fICURLOPT_QUOTE\fP, but for the source host. | ||||
| .IP CURLOPT_SOURCE_PREQUOTE | ||||
| Exactly like \fICURLOPT_PREQUOTE\fP, but for the source host. | ||||
| .IP CURLOPT_SOURCE_POSTQUOTE | ||||
| Exactly like \fICURLOPT_POSTQUOTE\fP, but for the source host. | ||||
| .IP CURLOPT_FTP_ACCOUNT | ||||
| Pass a pointer to a zero-terminated string (or NULL to disable). When an FTP | ||||
| server asks for "account data" after user name and password has been provided, | ||||
| this data is sent off using the ACCT command. (Added in 7.13.0) | ||||
| .SH PROTOCOL OPTIONS | ||||
| .IP CURLOPT_TRANSFERTEXT | ||||
| A non-zero parameter tells the library to use ASCII mode for ftp transfers, | ||||
| instead of the default binary transfer. For LDAP transfers it gets the data in | ||||
| plain text instead of HTML and for win32 systems it does not set the stdout to | ||||
| binary mode. This option can be usable when transferring text data between | ||||
| systems with different views on certain characters, such as newlines or | ||||
| similar. | ||||
| instead of the default binary transfer. For win32 systems it does not set the | ||||
| stdout to binary mode. This option can be usable when transferring text data | ||||
| between systems with different views on certain characters, such as newlines | ||||
| or similar. | ||||
|  | ||||
| libcurl does not do a complete ASCII conversion when doing ASCII transfers | ||||
| over FTP. This is a known limitation/flaw that nobody has rectified. libcurl | ||||
| simply sets the mode to ascii and performs a standard transfer. | ||||
| .IP CURLOPT_CRLF | ||||
| Convert Unix newlines to CRLF newlines on transfers. | ||||
| .IP CURLOPT_RANGE | ||||
| @@ -785,11 +873,11 @@ server supports the command first. | ||||
|  | ||||
| Restore to the internal default by setting this to NULL. | ||||
|  | ||||
| \fBNOTE:\fP Many people have wrongly used this option to replace the entire | ||||
| request with their own, including multiple headers and POST contents. While | ||||
| that might work in many cases, it will cause libcurl to send invalid requests | ||||
| and it could possibly confuse the remote server badly. Use \fICURLOPT_POST\fP | ||||
| and \fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to | ||||
| Many people have wrongly used this option to replace the entire request with | ||||
| their own, including multiple headers and POST contents. While that might work | ||||
| in many cases, it will cause libcurl to send invalid requests and it could | ||||
| possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and | ||||
| \fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to | ||||
| replace or extend the set of headers sent by libcurl. Use | ||||
| \fICURLOPT_HTTP_VERSION\fP to change HTTP version. | ||||
| .IP CURLOPT_FILETIME | ||||
| @@ -803,9 +891,8 @@ A non-zero parameter tells the library to not include the body-part in the | ||||
| output. This is only relevant for protocols that have separate header and body | ||||
| parts. On HTTP(S) servers, this will make libcurl do a HEAD request. | ||||
|  | ||||
| To change back to GET, you should use \fICURLOPT_HTTPGET\fP. To change back to | ||||
| POST, you should use \fICURLOPT_POST\fP. Setting \fICURLOPT_NOBODY\fP to zero | ||||
| has no effect. | ||||
| To change request to GET, you should use \fICURLOPT_HTTPGET\fP. Change request | ||||
| to POST with \fICURLOPT_POST\fP etc. | ||||
| .IP CURLOPT_INFILESIZE | ||||
| When uploading a file to a remote site, this option should be used to tell | ||||
| libcurl what the expected size of the infile is. This value should be passed | ||||
| @@ -834,26 +921,26 @@ Pass a long as parameter. This allows you to specify the maximum size (in | ||||
| bytes) of a file to download. If the file requested is larger than this value, | ||||
| the transfer will not start and CURLE_FILESIZE_EXCEEDED will be returned. | ||||
|  | ||||
| \fBNOTE:\fP The file size is not always known prior to download, and for such | ||||
| files this option has no effect even if the file transfer ends up being larger | ||||
| than this given limit. This concerns both FTP and HTTP transfers. | ||||
| The file size is not always known prior to download, and for such files this | ||||
| option has no effect even if the file transfer ends up being larger than this | ||||
| given limit. This concerns both FTP and HTTP transfers. | ||||
| .IP CURLOPT_MAXFILESIZE_LARGE | ||||
| Pass a curl_off_t as parameter. This allows you to specify the maximum size | ||||
| (in bytes) of a file to download. If the file requested is larger than this | ||||
| value, the transfer will not start and \fICURLE_FILESIZE_EXCEEDED\fP will be | ||||
| returned. (Added in 7.11.0) | ||||
|  | ||||
| \fBNOTE:\fP The file size is not always known prior to download, and for such | ||||
| files this option has no effect even if the file transfer ends up being larger | ||||
| than this given limit. This concerns both FTP and HTTP transfers. | ||||
| The file size is not always known prior to download, and for such files this | ||||
| option has no effect even if the file transfer ends up being larger than this | ||||
| given limit. This concerns both FTP and HTTP transfers. | ||||
| .IP CURLOPT_TIMECONDITION | ||||
| Pass a long as parameter. This defines how the \fICURLOPT_TIMEVALUE\fP time | ||||
| value is treated. You can set this parameter to \fICURL_TIMECOND_IFMODSINCE\fP | ||||
| or \fICURL_TIMECOND_IFUNMODSINCE\fP. This feature applies to HTTP and FTP. | ||||
|  | ||||
| \fBNOTE:\fP The last modification time of a file is not always known and in such | ||||
| instances this feature will have no effect even if the given time condition | ||||
| would have not been met. | ||||
| The last modification time of a file is not always known and in such instances | ||||
| this feature will have no effect even if the given time condition would have | ||||
| not been met. | ||||
| .IP CURLOPT_TIMEVALUE | ||||
| Pass a long as parameter. This should be the time in seconds since 1 jan 1970, | ||||
| and the time will be used in a condition as specified with | ||||
| @@ -866,8 +953,8 @@ considerable time and limiting operations to less than a few minutes risk | ||||
| aborting perfectly normal operations. This option will cause curl to use the | ||||
| SIGALRM to enable time-outing system calls. | ||||
|  | ||||
| \fBNOTE:\fP this is not recommended to use in unix multi-threaded programs, as | ||||
| it uses signals unless \fICURLOPT_NOSIGNAL\fP (see above) is set. | ||||
| In unix-like systems, this might cause signals to be used unless | ||||
| \fICURLOPT_NOSIGNAL\fP is set. | ||||
| .IP CURLOPT_LOW_SPEED_LIMIT | ||||
| Pass a long as parameter. It contains the transfer speed in bytes per second | ||||
| that the transfer should be below during \fICURLOPT_LOW_SPEED_TIME\fP seconds | ||||
| @@ -888,9 +975,9 @@ When reaching the maximum limit, curl uses the \fICURLOPT_CLOSEPOLICY\fP to | ||||
| figure out which of the existing connections to close to prevent the number of | ||||
| open connections to increase. | ||||
|  | ||||
| \fBNOTE:\fP if you already have performed transfers with this curl handle, | ||||
| setting a smaller MAXCONNECTS than before may cause open connections to get | ||||
| closed unnecessarily. | ||||
| If you already have performed transfers with this curl handle, setting a | ||||
| smaller MAXCONNECTS than before may cause open connections to get closed | ||||
| unnecessarily. | ||||
| .IP CURLOPT_CLOSEPOLICY | ||||
| Pass a long. This option sets what policy libcurl should use when the | ||||
| connection cache is filled and one of the open connections has to be closed to | ||||
| @@ -922,8 +1009,8 @@ it has connected, this option is of no more use. Set to zero to disable | ||||
| connection timeout (it will then only timeout on the system's internal | ||||
| timeouts). See also the \fICURLOPT_TIMEOUT\fP option. | ||||
|  | ||||
| \fBNOTE:\fP this is not recommended to use in unix multi-threaded programs, as | ||||
| it uses signals unless \fICURLOPT_NOSIGNAL\fP (see above) is set. | ||||
| In unix-like systems, this might cause signals to be used unless | ||||
| \fICURLOPT_NOSIGNAL\fP is set. | ||||
| .IP CURLOPT_IPRESOLVE | ||||
| Allows an application to select what kind of IP addresses to use when | ||||
| resolving host names. This is only interesting when using host names that | ||||
| @@ -960,9 +1047,9 @@ changed with \fICURLOPT_SSLKEYTYPE\fP. | ||||
| Pass a pointer to a zero terminated string as parameter. The string should be | ||||
| the format of your private key. Supported formats are "PEM", "DER" and "ENG". | ||||
|  | ||||
| \fBNOTE:\fP The format "ENG" enables you to load the private key from a crypto | ||||
| engine. In this case \fICURLOPT_SSLKEY\fP is used as an identifier passed to | ||||
| the engine. You have to set the crypto engine with \fICURLOPT_SSLENGINE\fP. | ||||
| The format "ENG" enables you to load the private key from a crypto engine. In | ||||
| this case \fICURLOPT_SSLKEY\fP is used as an identifier passed to the | ||||
| engine. You have to set the crypto engine with \fICURLOPT_SSLENGINE\fP. | ||||
| \&"DER" format key file currently does not work because of a bug in OpenSSL. | ||||
| .IP CURLOPT_SSLKEYPASSWD | ||||
| Pass a pointer to a zero terminated string as parameter. It will be used as | ||||
| @@ -972,37 +1059,69 @@ Pass a pointer to a zero terminated string as parameter. It will be used as | ||||
| the identifier for the crypto engine you want to use for your private | ||||
| key. | ||||
|  | ||||
| \fBNOTE:\fP If the crypto device cannot be loaded, | ||||
| \fICURLE_SSL_ENGINE_NOTFOUND\fP is returned. | ||||
| If the crypto device cannot be loaded, \fICURLE_SSL_ENGINE_NOTFOUND\fP is | ||||
| returned. | ||||
| .IP CURLOPT_SSLENGINE_DEFAULT | ||||
| Sets the actual crypto engine as the default for (asymmetric) crypto | ||||
| operations. | ||||
|  | ||||
| \fBNOTE:\fP If the crypto device cannot be set, | ||||
| \fICURLE_SSL_ENGINE_SETFAILED\fP is returned. | ||||
| If the crypto device cannot be set, \fICURLE_SSL_ENGINE_SETFAILED\fP is | ||||
| returned. | ||||
| .IP CURLOPT_SSLVERSION | ||||
| Pass a long as parameter. Set what version of SSL to attempt to use, 2 or | ||||
| 3. By default, the SSL library will try to solve this by itself although some | ||||
| servers make this difficult why you at times may have to use this option. | ||||
| Pass a long as parameter to control what version of SSL/TLS to attempt to use. | ||||
| The available options are: | ||||
| .RS | ||||
| .IP CURL_SSLVERSION_DEFAULT | ||||
| The default action. When libcurl built with OpenSSL, this will attempt to | ||||
| figure out the remote SSL protocol version. Unfortunately there are a lot of | ||||
| ancient and broken servers in use which cannot handle this technique and will | ||||
| fail to connect. When libcurl is built with GnuTLS, this will mean SSLv3. | ||||
| .IP CURL_SSLVERSION_TLSv1 | ||||
| Force TLSv1 | ||||
| .IP CURL_SSLVERSION_SSLv2 | ||||
| Force SSLv2 | ||||
| .IP CURL_SSLVERSION_SSLv3 | ||||
| Force SSLv3 | ||||
| .RE | ||||
| .IP CURLOPT_SSL_VERIFYPEER | ||||
| Pass a long that is set to a zero value to stop curl from verifying the peer's | ||||
| certificate (7.10 starting setting this option to non-zero by default). | ||||
| Alternate certificates to verify against can be specified with the | ||||
| \fICURLOPT_CAINFO\fP option or a certificate directory can be specified with | ||||
| the \fICURLOPT_CAPATH\fP option.  As of 7.10, curl installs a default bundle. | ||||
| \fICURLOPT_SSL_VERIFYHOST\fP may also need to be set to 1 or 0 if | ||||
| \fICURLOPT_SSL_VERIFYPEER\fP is disabled (it defaults to 2). | ||||
| Pass a long as parameter. | ||||
|  | ||||
| This option determines whether curl verifies the authenticity of the | ||||
| peer's certificate.  A nonzero value means curl verifies; zero means it | ||||
| doesn't.  The default is nonzero, but before 7.10, it was zero. | ||||
|  | ||||
| When negotiating an SSL connection, the server sends a certificate | ||||
| indicating its identity.  Curl verifies whether the certificate is | ||||
| authentic, i.e. that you can trust that the server is who the | ||||
| certificate says it is.  This trust is based on a chain of digital | ||||
| signatures, rooted in certification authority (CA) certificates you | ||||
| supply.  As of 7.10, curl installs a default bundle of CA certificates | ||||
| and you can specify alternate certificates with the | ||||
| \fICURLOPT_CAINFO\fP option or the \fICURLOPT_CAPATH\fP option. | ||||
|  | ||||
| When \fICURLOPT_SSL_VERIFYPEER\fP is nonzero, and the verification | ||||
| fails to prove that the certificate is authentic, the connection | ||||
| fails.  When the option is zero, the connection succeeds regardless. | ||||
|  | ||||
| Authenticating the certificate is not by itself very useful.  You | ||||
| typically want to ensure that the server, as authentically identified | ||||
| by its certificate, is the server you mean to be talking to.  Use | ||||
| \fICURLOPT_SSL_VERIFYHOST\fP to control that. | ||||
| .IP CURLOPT_CAINFO | ||||
| Pass a char * to a zero terminated string naming a file holding one or more | ||||
| certificates to verify the peer with. This only makes sense when used in | ||||
| combination with the \fICURLOPT_SSL_VERIFYPEER\fP option. | ||||
| certificates to verify the peer with.  This makes sense only when used in | ||||
| combination with the \fICURLOPT_SSL_VERIFYPEER\fP option.  If | ||||
| \fICURLOPT_SSL_VERIFYPEER\fP is zero, \fICURLOPT_CAINFO\fP need not | ||||
| even indicate an accessible file. | ||||
| .IP CURLOPT_CAPATH | ||||
| Pass a char * to a zero terminated string naming a directory holding multiple | ||||
| CA certificates to verify the peer with. The certificate directory must be | ||||
| prepared using the openssl c_rehash utility. This only makes sense when used | ||||
| in combination with the \fICURLOPT_SSL_VERIFYPEER\fP option. The | ||||
| \fICURLOPT_CAPATH\fP function apparently does not work in Windows due to some | ||||
| limitation in openssl. (Added in 7.9.8) | ||||
| Pass a char * to a zero terminated string naming a directory holding | ||||
| multiple CA certificates to verify the peer with. The certificate | ||||
| directory must be prepared using the openssl c_rehash utility. This | ||||
| makes sense only when used in combination with the | ||||
| \fICURLOPT_SSL_VERIFYPEER\fP option.  If \fICURLOPT_SSL_VERIFYPEER\fP | ||||
| is zero, \fICURLOPT_CAPATH\fP need not even indicate an accessible | ||||
| path.  The \fICURLOPT_CAPATH\fP function apparently does not work in | ||||
| Windows due to some limitation in openssl. (Added in 7.9.8) | ||||
| .IP CURLOPT_RANDOM_FILE | ||||
| Pass a char * to a zero terminated file name. The file will be used to read | ||||
| from to seed the random engine for SSL. The more random the specified file is, | ||||
| @@ -1011,9 +1130,34 @@ the more secure the SSL connection will become. | ||||
| Pass a char * to the zero terminated path name to the Entropy Gathering Daemon | ||||
| socket. It will be used to seed the random engine for SSL. | ||||
| .IP CURLOPT_SSL_VERIFYHOST | ||||
| Pass a long. Set if we should verify the Common name from the peer certificate | ||||
| in the SSL handshake, set 1 to check existence, 2 to ensure that it matches | ||||
| the provided hostname. This is by default set to 2. (default changed in 7.10) | ||||
| Pass a long as parameter. | ||||
|  | ||||
| This option determines whether curl verifies that the server claims to be | ||||
| who you want it to be. | ||||
|  | ||||
| When negotiating an SSL connection, the server sends a certificate | ||||
| indicating its identity. | ||||
|  | ||||
| When \fICURLOPT_SSL_VERIFYHOST\fP is 2, that certificate must indicate | ||||
| that the server is the server to which you meant to connect, or the | ||||
| connection fails. | ||||
|  | ||||
| Curl considers the server the intended one when the Common Name field | ||||
| or a Subject Alternate Name field in the certificate matches the host | ||||
| name in the URL to which you told Curl to connect. | ||||
|  | ||||
| When the value is 1, the certificate must contain a Common Name field, | ||||
| but it doesn't matter what name it says.  (This is not ordinarily a | ||||
| useful setting). | ||||
|  | ||||
| When the value is 0, the connection succeeds regardless of the names in | ||||
| the certificate. | ||||
|  | ||||
| The default, since 7.10, is 2. | ||||
|  | ||||
| The checking this option controls is of the identity that the server | ||||
| \fIclaims\fP.  The server could be lying.  To control lying, see | ||||
| \fICURLOPT_SSL_VERIFYPEER\fP. | ||||
| .IP CURLOPT_SSL_CIPHER_LIST | ||||
| Pass a char *, pointing to a zero terminated string holding the list of | ||||
| ciphers to use for the SSL connection. The list must be syntactically correct, | ||||
|   | ||||
| @@ -23,4 +23,4 @@ You must curl_free() the returned string when you're done with it. | ||||
| .SH RETURN VALUE | ||||
| A pointer to a zero terminated string or NULL if it failed. | ||||
| .SH "SEE ALSO" | ||||
| .BR curl_unescape(3), curl_free(3), RFC 2396 | ||||
| .BR curl_unescape "(3), " curl_free "(3), " RFC 2396 | ||||
|   | ||||
| @@ -90,7 +90,7 @@ followed by a pointer to a string to a name, will make libcurl use the given | ||||
| name in the file upload part, instead of the actual file name given to | ||||
| \fICURLFORM_FILE\fP. | ||||
|  | ||||
| .IP BCURLFORM_BUFFER | ||||
| .IP CURLFORM_BUFFER | ||||
| followed by a string, tells libcurl that a buffer is to be used to upload data | ||||
| instead of using a file. The given string is used as the value of the file | ||||
| name field in the content header. | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual" | ||||
| .TH curl_getdate 3 "12 Aug 2005" "libcurl 7.0" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_getdate - Convert an date string to number of seconds since January 1, | ||||
| 1970 | ||||
| @@ -26,7 +26,7 @@ order of the items is immaterial.  A date string may contain many flavors of | ||||
| items: | ||||
| .TP 0.8i | ||||
| .B calendar date items | ||||
| Can be specified several ways. Month names can only be three-letter | ||||
| Can be specified several ways. Month names can only be three-letter english | ||||
| abbrivations, numbers can be zero-prefixed and the year may use 2 or 4 digits. | ||||
| Examples: 06 Nov 1994, 06-Nov-94 and Nov-94 6. | ||||
| .TP | ||||
| @@ -41,9 +41,9 @@ general you should instead use the specific relative time compared to | ||||
| UTC. Supported formats include: -1200, MST, +0100. | ||||
| .TP | ||||
| .B day of the week items | ||||
| Specifies a day of the week. Days of the week may be spelled out in full: | ||||
| `Sunday', `Monday', etc or they may be abbreviated to their first three | ||||
| letters. This is usually not info that adds anything. | ||||
| Specifies a day of the week. Days of the week may be spelled out in full | ||||
| (using english): `Sunday', `Monday', etc or they may be abbreviated to their | ||||
| first three letters. This is usually not info that adds anything. | ||||
| .TP | ||||
| .B pure numbers | ||||
| If a decimal number of the form YYYYMMDD appears, then YYYY is read as the | ||||
| @@ -85,11 +85,16 @@ This function returns -1 when it fails to parse the date string. Otherwise it | ||||
| returns the number of seconds as described. | ||||
|  | ||||
| If the year is larger than 2037 on systems with 32 bit time_t, this function | ||||
| will return 0x7fffffff (since that is the largest possible 31 bit number). | ||||
| will return 0x7fffffff (since that is the largest possible signed 32 bit | ||||
| number). | ||||
|  | ||||
| Having a 64 bit time_t is not a guarantee that dates beyond 03:14:07 UTC, | ||||
| January 19, 2038 will work fine. On systems with a 64 bit time_t but with a | ||||
| crippled mktime(), \fIcurl_getdate\fP will return -1 in this case. | ||||
| .SH REWRITE | ||||
| The former version of this function was built with yacc and was not only very | ||||
| large, it was also never quite understood and it wasn't possible to build with | ||||
| non-GNU tools since only Bison could make it thread-safe! | ||||
| non-GNU tools since only GNU Bison could make it thread-safe! | ||||
|  | ||||
| The rewrite was done for 7.12.2. The new one is much smaller and use simpler | ||||
| code. | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_multi_fdset 3 "15 Apr 2004" "libcurl 7.9.5" "libcurl Manual" | ||||
| .TH curl_multi_fdset 3 "25 Apr 2005" "libcurl 7.9.5" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_multi_fdset - extracts file descriptor information from a multi handle | ||||
| .SH SYNOPSIS | ||||
| @@ -15,19 +15,21 @@ CURLMcode curl_multi_fdset(CURLM *multi_handle, | ||||
| .ad | ||||
| .SH DESCRIPTION | ||||
| This function extracts file descriptor information from a given multi_handle. | ||||
| libcurl returns its fd_set sets. The application can use these to select() | ||||
| on. The \fIcurl_multi_perform(3)\fI function should be called as soon as one | ||||
| of them are ready to be read from or written to. | ||||
| libcurl returns its fd_set sets. The application can use these to select() on, | ||||
| but be sure to FD_ZERO them before calling this function as | ||||
| \fIcurl_multi_fdset(3)\fP only adds its own descriptors it doesn't zero or | ||||
| otherwise remove any other. The \fIcurl_multi_perform(3)\fP function should be | ||||
| called as soon as one of them are ready to be read from or written to. | ||||
|  | ||||
| NOTE that once this call is made, you must not remove the sets you point to, | ||||
| as libcurl will need to be able to read them. It needs them after select() | ||||
| calls, to know if certain sockets are readable or writable. | ||||
| If no file descriptors are set by libcurl, \fImax_fd\fP will contain -1 when | ||||
| this function returns. Otherwise it will contain the higher descriptor number | ||||
| libcurl set. | ||||
|  | ||||
| You should also be aware that when doing select(), you should consider using a | ||||
| rather small (single-digit number of seconds) timeout and call | ||||
| \fIcurl_multi_perform\fP regularly - even if no activity has been seen on the | ||||
| fd_sets - as otherwise libcurl-internal retries and timeouts may not work as | ||||
| you'd think. | ||||
| you'd think and want. | ||||
| .SH RETURN VALUE | ||||
| CURLMcode type, general libcurl multi interface error code. See | ||||
| \fIlibcurl-errors(3)\fP | ||||
|   | ||||
| @@ -1,8 +1,6 @@ | ||||
| .\" You can view this file with: | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH curl_version_info 3 "11 May 2004" "libcurl 7.12" "libcurl Manual" | ||||
| .TH curl_version_info 3 "11 Mar 2005" "libcurl 7.13.2" "libcurl Manual" | ||||
| .SH NAME | ||||
| curl_version_info - returns run-time libcurl version info | ||||
| .SH SYNOPSIS | ||||
| @@ -36,7 +34,7 @@ typedef struct { | ||||
|   const char *host;         /* human readable string */ | ||||
|   int features;             /* bitmask, see below */ | ||||
|   char *ssl_version;        /* human readable string */ | ||||
|   long ssl_version_num;     /* number */ | ||||
|   long ssl_version_num;     /* not used, always zero */ | ||||
|   const char *libz_version; /* human readable string */ | ||||
|   const char **protocols;   /* list of protocols */ | ||||
|  | ||||
| @@ -73,9 +71,9 @@ supports IPv6 | ||||
| .IP CURL_VERSION_KERBEROS4 | ||||
| supports kerberos4 (when using FTP) | ||||
| .IP CURL_VERSION_SSL | ||||
| supports SSL (HTTPS/FTPS) | ||||
| supports SSL (HTTPS/FTPS) (Added in 7.10) | ||||
| .IP CURL_VERSION_LIBZ | ||||
| supports HTTP deflate using libz | ||||
| supports HTTP deflate using libz (Added in 7.10) | ||||
| .IP CURL_VERSION_NTLM | ||||
| supports HTTP NTLM (added in 7.10.6) | ||||
| .IP CURL_VERSION_GSSNEGOTIATE | ||||
| @@ -91,10 +89,15 @@ interface. (added in 7.10.7) | ||||
| libcurl was built with support for SPNEGO authentication (Simple and Protected | ||||
| GSS-API Negotiation Mechanism, defined in RFC 2478.) (added in 7.10.8) | ||||
| .IP CURL_VERSION_LARGEFILE | ||||
| libcurl was built with support for large files. | ||||
| libcurl was built with support for large files. (Added in 7.11.1) | ||||
| .IP CURL_VERSION_IDN | ||||
| libcurl was built with support for IDNA, domain names with international | ||||
| letters. | ||||
| letters. (Added in 7.12.0) | ||||
| .IP CURL_VERSION_SSPI | ||||
| libcurl was built with support for SSPI. This is only available on Windows and | ||||
| makes libcurl use Windows-provided functions for NTLM authentication. It also | ||||
| allows libcurl to use the current user and the current user's password without | ||||
| the app having to pass them on. (Added in 7.13.2) | ||||
| .RE | ||||
| \fIssl_version\fP is an ascii string for the OpenSSL version used. If libcurl | ||||
| has no SSL support, this is NULL. | ||||
|   | ||||
							
								
								
									
										27
									
								
								docs/libcurl/getinfo-times
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								docs/libcurl/getinfo-times
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| An overview of the six time values available from curl_easy_getinfo() | ||||
|  | ||||
| curk_easy_perform() | ||||
|     | | ||||
|     |--NT | ||||
|     |--|--CT | ||||
|     |--|--|--PT | ||||
|     |--|--|--|--ST | ||||
|           |--|--|--TT | ||||
|     |--|--|--|--|--RT | ||||
|  | ||||
| NT = CURLINFO_NAMELOOKUP_TIME. The time it took from the start until the name | ||||
|      resolving was completed. | ||||
| CT = CURLINFO_CONNECT_TIME. The time it took from the start until the connect | ||||
|      to the remote host (or proxy) was completed. | ||||
| PT = CURLINFO_PRETRANSFER_TIME. The time it took from the start until the file | ||||
|      transfer is just about to begin. This includes all pre-transfer commands | ||||
|      and negotiations that are specific to the particular protocol(s) | ||||
|      involved. | ||||
| ST = CURLINFO_STARTTRANSFER_TIME. The time it took from the start until the | ||||
|      first byte is just about to be transferred. | ||||
| TT = CURLINFO_TOTAL_TIME. Time of the previous transfer. This time does not | ||||
|      include the connect time (CT), so if you want the complete operation | ||||
|      time, you should add that. | ||||
| RT = CURLINFO_REDIRECT_TIME. The time it took for all redirection steps | ||||
|      include name lookup, connect, pretransfer and transfer before final | ||||
|      transaction was started. So, this is zero if no redirection took place. | ||||
| @@ -2,7 +2,7 @@ | ||||
| .\" nroff -man [file] | ||||
| .\" $Id$ | ||||
| .\" | ||||
| .TH libcurl-errors 3 "27 Apr 2004" "libcurl 7.12" "libcurl errors" | ||||
| .TH libcurl-errors 3 "9 Feb 2005" "libcurl 7.13.1" "libcurl errors" | ||||
| .SH NAME | ||||
| libcurl-errors \- error codes in libcurl | ||||
| .SH DESCRIPTION | ||||
| @@ -187,10 +187,16 @@ Invalid LDAP URL | ||||
| Maximum file size exceeded | ||||
| .IP "CURLE_FTP_SSL_FAILED (64)" | ||||
| Requested FTP SSL level failed | ||||
| .IP "CURLE_SEND_FAIL_REWIND (65)" | ||||
| When doing a send operation curl had to rewind the data to retransmit, but the | ||||
| rewinding operation failed | ||||
| .IP "CURLE_SSL_ENGINE_INITFAILED (66)" | ||||
| Initiating the SSL Engine failed | ||||
| .IP "CURLE_LOGIN_DENIED (67)" | ||||
| The remote server denied curl to login (Added in 7.13.1) | ||||
| .SH "CURLMcode" | ||||
| This is the generic return code used by functions in the libcurl multi | ||||
| interface. Also consider \fIcurl_multi_strerror(3)\fI. | ||||
|  | ||||
| interface. Also consider \fIcurl_multi_strerror(3)\fP. | ||||
| .IP "CURLM_CALL_MULTI_PERFORM (-1)" | ||||
| This is not really an error. It means you should call | ||||
| \fIcurl_multi_perform(3)\fP again without doing select() or similar in between. | ||||
| @@ -206,9 +212,7 @@ You are doomed. | ||||
| This can only be returned if libcurl bugs. Please report it to us! | ||||
| .SH "CURLSHcode" | ||||
| The "share" interface will return a CURLSHcode to indicate when an error has | ||||
| occurred.  Also consider \fIcurl_share_strerror(3)\fI. | ||||
|  | ||||
| CURLSHcode is one of the following: | ||||
| occurred.  Also consider \fIcurl_share_strerror(3)\fP. | ||||
| .IP "CURLSHE_OK (0)" | ||||
| All fine. Proceed as usual. | ||||
| .IP "CURLSHE_BAD_OPTION (1)" | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| .\" *                            | (__| |_| |  _ <| |___ | ||||
| .\" *                             \___|\___/|_| \_\_____| | ||||
| .\" * | ||||
| .\" * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| .\" * | ||||
| .\" * This software is licensed as described in the file COPYING, which | ||||
| .\" * you should have received as part of this distribution. The terms | ||||
| @@ -21,7 +21,7 @@ | ||||
| .\" * $Id$ | ||||
| .\" ************************************************************************** | ||||
| .\" | ||||
| .TH libcurl-tutorial 3 "18 Jun 2004" "libcurl" "libcurl programming" | ||||
| .TH libcurl-tutorial 3 "9 May 2005" "libcurl" "libcurl programming" | ||||
| .SH NAME | ||||
| libcurl-tutorial \- libcurl programming tutorial | ||||
| .SH "Objective" | ||||
| @@ -76,6 +76,11 @@ possibly together with a few other features that can be on and off on | ||||
| different libcurls. | ||||
|  | ||||
| See also the "Features libcurl Provides" further down. | ||||
| .IP "autoconf macro" | ||||
| When you write your configure script to detect libcurl and setup variables | ||||
| accordingly, we offer a prewritten macro that probably does everything you | ||||
| need in this area. See docs/libcurl/libcurl.m4 file - it includes docs on how | ||||
| to use it. | ||||
|  | ||||
| .SH "Portable Code in a Portable World" | ||||
| The people behind libcurl have put a considerable effort to make libcurl work | ||||
| @@ -94,9 +99,9 @@ use the library. Once for your program's entire life time. This is done using | ||||
|  curl_global_init() | ||||
|  | ||||
| and it takes one parameter which is a bit pattern that tells libcurl what to | ||||
| initialize. Using CURL_GLOBAL_ALL will make it initialize all known internal | ||||
| sub modules, and might be a good default option. The current two bits that | ||||
| are specified are: | ||||
| initialize. Using \fICURL_GLOBAL_ALL\fP will make it initialize all known | ||||
| internal sub modules, and might be a good default option. The current two bits | ||||
| that are specified are: | ||||
| .RS | ||||
| .IP "CURL_GLOBAL_WIN32" | ||||
| which only does anything on Windows machines. When used on | ||||
| @@ -113,17 +118,19 @@ application so if your program or another library already does this, this | ||||
| bit should not be needed. | ||||
| .RE | ||||
|  | ||||
| libcurl has a default protection mechanism that detects if curl_global_init() | ||||
| hasn't been called by the time curl_easy_perform() is called and if that is | ||||
| the case, libcurl runs the function itself with a guessed bit pattern. Please | ||||
| note that depending solely on this is not considered nice nor very good. | ||||
| libcurl has a default protection mechanism that detects if | ||||
| \fIcurl_global_init(3)\fP hasn't been called by the time | ||||
| \fIcurl_easy_perform(3)\fP is called and if that is the case, libcurl runs the | ||||
| function itself with a guessed bit pattern. Please note that depending solely | ||||
| on this is not considered nice nor very good. | ||||
|  | ||||
| When the program no longer uses libcurl, it should call curl_global_cleanup(), | ||||
| which is the opposite of the init call. It will then do the reversed | ||||
| operations to cleanup the resources the curl_global_init() call initialized. | ||||
| When the program no longer uses libcurl, it should call | ||||
| \fIcurl_global_cleanup(3)\fP, which is the opposite of the init call. It will | ||||
| then do the reversed operations to cleanup the resources the | ||||
| \fIcurl_global_init(3)\fP call initialized. | ||||
|  | ||||
| Repeated calls to curl_global_init() and curl_global_cleanup() should be | ||||
| avoided. They should only be called once each. | ||||
| Repeated calls to \fIcurl_global_init(3)\fP and \fIcurl_global_cleanup(3)\fP | ||||
| should be avoided. They should only be called once each. | ||||
|  | ||||
| .SH "Features libcurl Provides" | ||||
| It is considered best-practice to determine libcurl features run-time rather | ||||
| @@ -153,17 +160,18 @@ It returns an easy handle. Using that you proceed to the next step: setting | ||||
| up your preferred actions. A handle is just a logic entity for the upcoming | ||||
| transfer or series of transfers. | ||||
|  | ||||
| You set properties and options for this handle using curl_easy_setopt(). They | ||||
| control how the subsequent transfer or transfers will be made. Options remain | ||||
| set in the handle until set again to something different. Alas, multiple | ||||
| requests using the same handle will use the same options. | ||||
| You set properties and options for this handle using | ||||
| \fIcurl_easy_setopt(3)\fP. They control how the subsequent transfer or | ||||
| transfers will be made. Options remain set in the handle until set again to | ||||
| something different. Alas, multiple requests using the same handle will use | ||||
| the same options. | ||||
|  | ||||
| Many of the options you set in libcurl are "strings", pointers to data | ||||
| terminated with a zero byte. Keep in mind that when you set strings with | ||||
| curl_easy_setopt(), libcurl will not copy the data. It will merely point to | ||||
| the data. You MUST make sure that the data remains available for libcurl to | ||||
| use until finished or until you use the same option again to point to | ||||
| something else. | ||||
| \fIcurl_easy_setopt(3)\fP, libcurl will not copy the data. It will merely | ||||
| point to the data. You MUST make sure that the data remains available for | ||||
| libcurl to use until finished or until you use the same option again to point | ||||
| to something else. | ||||
|  | ||||
| One of the most basic properties to set in the handle is the URL. You set | ||||
| your preferred URL to transfer with CURLOPT_URL in a manner similar to: | ||||
| @@ -192,37 +200,40 @@ another property: | ||||
|  | ||||
| Using that property, you can easily pass local data between your application | ||||
| and the function that gets invoked by libcurl. libcurl itself won't touch the | ||||
| data you pass with CURLOPT_WRITEDATA. | ||||
| data you pass with \fICURLOPT_WRITEDATA\fP. | ||||
|  | ||||
| libcurl offers its own default internal callback that'll take care of the data | ||||
| if you don't set the callback with CURLOPT_WRITEFUNCTION. It will then simply | ||||
| output the received data to stdout. You can have the default callback write | ||||
| the data to a different file handle by passing a 'FILE *' to a file opened for | ||||
| writing with the CURLOPT_WRITEDATA option. | ||||
| if you don't set the callback with \fICURLOPT_WRITEFUNCTION\fP. It will then | ||||
| simply output the received data to stdout. You can have the default callback | ||||
| write the data to a different file handle by passing a 'FILE *' to a file | ||||
| opened for writing with the \fICURLOPT_WRITEDATA\fP option. | ||||
|  | ||||
| Now, we need to take a step back and have a deep breath. Here's one of those | ||||
| rare platform-dependent nitpicks. Did you spot it? On some platforms[2], | ||||
| libcurl won't be able to operate on files opened by the program. Thus, if you | ||||
| use the default callback and pass in a an open file with CURLOPT_WRITEDATA, it | ||||
| will crash. You should therefore avoid this to make your program run fine | ||||
| virtually everywhere. | ||||
| use the default callback and pass in a an open file with | ||||
| \fICURLOPT_WRITEDATA\fP, it will crash. You should therefore avoid this to | ||||
| make your program run fine virtually everywhere. | ||||
|  | ||||
| (CURLOPT_WRITEDATA was formerly known as CURLOPT_FILE. Both names still work | ||||
| and do the same thing). | ||||
| (\fICURLOPT_WRITEDATA\fP was formerly known as \fICURLOPT_FILE\fP. Both names | ||||
| still work and do the same thing). | ||||
|  | ||||
| If you're using libcurl as a win32 DLL, you MUST use the | ||||
| \fICURLOPT_WRITEFUNCTION\fP if you set \fICURLOPT_WRITEDATA\fP - or you will | ||||
| experience crashes. | ||||
|  | ||||
| There are of course many more options you can set, and we'll get back to a few | ||||
| of them later. Let's instead continue to the actual transfer: | ||||
|  | ||||
|  success = curl_easy_perform(easyhandle); | ||||
|  | ||||
| The \fIcurl_easy_perform(3)\fP will connect to the remote site, do the | ||||
| necessary commands and receive the transfer. Whenever it receives data, it | ||||
| calls the callback function we previously set. The function may get one byte | ||||
| at a time, or it may get many kilobytes at once. libcurl delivers as much as | ||||
| possible as often as possible. Your callback function should return the number | ||||
| of bytes it "took care of". If that is not the exact same amount of bytes that | ||||
| was passed to it, libcurl will abort the operation and return with an error | ||||
| code. | ||||
| \fIcurl_easy_perform(3)\fP will connect to the remote site, do the necessary | ||||
| commands and receive the transfer. Whenever it receives data, it calls the | ||||
| callback function we previously set. The function may get one byte at a time, | ||||
| or it may get many kilobytes at once. libcurl delivers as much as possible as | ||||
| often as possible. Your callback function should return the number of bytes it | ||||
| \&"took care of". If that is not the exact same amount of bytes that was | ||||
| passed to it, libcurl will abort the operation and return with an error code. | ||||
|  | ||||
| When the transfer is complete, the function returns a return code that informs | ||||
| you if it succeeded in its mission or not. If a return code isn't enough for | ||||
| @@ -232,20 +243,30 @@ where it'll store a human readable error message as well. | ||||
| If you then want to transfer another file, the handle is ready to be used | ||||
| again. Mind you, it is even preferred that you re-use an existing handle if | ||||
| you intend to make another transfer. libcurl will then attempt to re-use the | ||||
| previous | ||||
| previous connection. | ||||
|  | ||||
| .SH "Multi-threading Issues" | ||||
| libcurl is completely thread safe, except for two issues: signals and alarm | ||||
| handlers. Signals are needed for a SIGPIPE handler, and the alarm() Bacall | ||||
| is used to catch timeouts (mostly during ENS lookup). | ||||
| The first basic rule is that you must \fBnever\fP share a libcurl handle (be | ||||
| it easy or multi or whatever) between multiple threads. Only use one handle in | ||||
| one thread at a time. | ||||
|  | ||||
| libcurl is completely thread safe, except for two issues: signals and SSL/TLS | ||||
| handlers. Signals are used timeouting name resolves (during DNS lookup) - when | ||||
| built without c-ares support and not on Windows.. | ||||
|  | ||||
| If you are accessing HTTPS or FTPS URLs in a multi-threaded manner, you are | ||||
| then of course using OpenSSL multi-threaded and it has itself a few | ||||
| requirements on this. Basilio, you need to provide one or two functions to | ||||
| allow it to function properly. For all details, see this: | ||||
| then of course using OpenSSL/GnuTLS multi-threaded and those libs have their | ||||
| own requirements on this issue. Basically, you need to provide one or two | ||||
| functions to allow it to function properly. For all details, see this: | ||||
|  | ||||
| OpenSSL | ||||
|  | ||||
|    http://www.openssl.org/docs/crypto/threads.html#DESCRIPTION | ||||
|  | ||||
| GnuTLS | ||||
|  | ||||
|  http://www.gnu.org/software/gnutls/manual/html_node/Multi_002dthreaded-applications.html | ||||
|  | ||||
| When using multiple threads you should set the CURLOPT_NOSIGNAL option to | ||||
| TRUE for all handles. Everything will work fine except that timeouts are not | ||||
| honored during the DNS lookup - which you can work around by building libcurl | ||||
| @@ -322,12 +343,12 @@ CURLOPT_INFILESIZE_LARGE for all known file sizes like this[1]: | ||||
|  curl_easy_setopt(easyhandle, CURLOPT_INFILESIZE_LARGE, file_size); | ||||
| .fi | ||||
|  | ||||
| When you call curl_easy_perform() this time, it'll perform all the necessary | ||||
| operations and when it has invoked the upload it'll call your supplied | ||||
| callback to get the data to upload. The program should return as much data as | ||||
| possible in every invoke, as that is likely to make the upload perform as | ||||
| fast as possible. The callback should return the number of bytes it wrote in | ||||
| the buffer. Returning 0 will signal the end of the upload. | ||||
| When you call \fIcurl_easy_perform(3)\fP this time, it'll perform all the | ||||
| necessary operations and when it has invoked the upload it'll call your | ||||
| supplied callback to get the data to upload. The program should return as much | ||||
| data as possible in every invoke, as that is likely to make the upload perform | ||||
| as fast as possible. The callback should return the number of bytes it wrote | ||||
| in the buffer. Returning 0 will signal the end of the upload. | ||||
|  | ||||
| .SH "Passwords" | ||||
| Many protocols use or even require that user name and password are provided | ||||
| @@ -466,15 +487,14 @@ then passing that list to libcurl. | ||||
|  | ||||
| While the simple examples above cover the majority of all cases where HTTP | ||||
| POST operations are required, they don't do multi-part formposts. Multi-part | ||||
| formposts were introduced as a better way to post (possibly large) binary | ||||
| data and was first documented in the RFC1867. They're called multi-part | ||||
| because they're built by a chain of parts, each being a single unit. Each | ||||
| part has its own name and contents. You can in fact create and post a | ||||
| multi-part formpost with the regular libcurl POST support described above, but | ||||
| that would require that you build a formpost yourself and provide to | ||||
| libcurl. To make that easier, libcurl provides curl_formadd(). Using this | ||||
| function, you add parts to the form. When you're done adding parts, you post | ||||
| the whole form. | ||||
| formposts were introduced as a better way to post (possibly large) binary data | ||||
| and was first documented in the RFC1867. They're called multi-part because | ||||
| they're built by a chain of parts, each being a single unit. Each part has its | ||||
| own name and contents. You can in fact create and post a multi-part formpost | ||||
| with the regular libcurl POST support described above, but that would require | ||||
| that you build a formpost yourself and provide to libcurl. To make that | ||||
| easier, libcurl provides \fIcurl_formadd(3)\fP. Using this function, you add | ||||
| parts to the form. When you're done adding parts, you post the whole form. | ||||
|  | ||||
| The following example sets two simple text parts with plain textual contents, | ||||
| and then a file with binary contents and upload the whole thing. | ||||
| @@ -527,10 +547,10 @@ post handle: | ||||
| .fi | ||||
|  | ||||
| Since all options on an easyhandle are "sticky", they remain the same until | ||||
| changed even if you do call curl_easy_perform(), you may need to tell curl to | ||||
| go back to a plain GET request if you intend to do such a one as your next | ||||
| request. You force an easyhandle to back to GET by using the CURLOPT_HTTPGET | ||||
| option: | ||||
| changed even if you do call \fIcurl_easy_perform(3)\fP, you may need to tell | ||||
| curl to go back to a plain GET request if you intend to do such a one as your | ||||
| next request. You force an easyhandle to back to GET by using the | ||||
| CURLOPT_HTTPGET option: | ||||
|  | ||||
|  curl_easy_setopt(easyhandle, CURLOPT_HTTPGET, TRUE); | ||||
|  | ||||
| @@ -719,7 +739,7 @@ Mozilla javascript engine in the past. | ||||
| Re-cycling the same easy handle several times when doing multiple requests is | ||||
| the way to go. | ||||
|  | ||||
| After each single curl_easy_perform() operation, libcurl will keep the | ||||
| After each single \fIcurl_easy_perform(3)\fP operation, libcurl will keep the | ||||
| connection alive and open. A subsequent request using the same easy handle to | ||||
| the same host might just be able to use the already open connection! This | ||||
| reduces network impact a lot. | ||||
| @@ -903,8 +923,8 @@ A little example that deletes a given file before an operation: | ||||
| .fi | ||||
|  | ||||
| If you would instead want this operation (or chain of operations) to happen | ||||
| _after_ the data transfer took place the option to curl_easy_setopt() would | ||||
| instead be called CURLOPT_POSTQUOTE and used the exact same way. | ||||
| _after_ the data transfer took place the option to \fIcurl_easy_setopt(3)\fP | ||||
| would instead be called CURLOPT_POSTQUOTE and used the exact same way. | ||||
|  | ||||
| The custom FTP command will be issued to the server in the same order they are | ||||
| added to the list, and if a command gets an error code returned back from the | ||||
| @@ -973,9 +993,9 @@ The perhaps most advanced cookie operation libcurl offers, is saving the | ||||
| entire internal cookie state back into a Netscape/Mozilla formatted cookie | ||||
| file. We call that the cookie-jar. When you set a file name with | ||||
| CURLOPT_COOKIEJAR, that file name will be created and all received cookies | ||||
| will be stored in it when curl_easy_cleanup() is called. This enabled cookies | ||||
| to get passed on properly between multiple handles without any information | ||||
| getting lost. | ||||
| will be stored in it when \fIcurl_easy_cleanup(3)\fP is called. This enabled | ||||
| cookies to get passed on properly between multiple handles without any | ||||
| information getting lost. | ||||
|  | ||||
| .SH "FTP Peculiarities We Need" | ||||
|  | ||||
| @@ -1103,46 +1123,47 @@ of how to use the easy interface. The multi interface is simply a way to make | ||||
| multiple transfers at the same time, by adding up multiple easy handles in to | ||||
| a "multi stack". | ||||
|  | ||||
| You create the easy handles you want and you set all the options just like | ||||
| you have been told above, and then you create a multi handle with | ||||
| curl_multi_init() and add all those easy handles to that multi handle with | ||||
| curl_multi_add_handle(). | ||||
| You create the easy handles you want and you set all the options just like you | ||||
| have been told above, and then you create a multi handle with | ||||
| \fIcurl_multi_init(3)\fP and add all those easy handles to that multi handle | ||||
| with \fIcurl_multi_add_handle(3)\fP. | ||||
|  | ||||
| When you've added the handles you have for the moment (you can still add new | ||||
| ones at any time), you start the transfers by call curl_multi_perform(). | ||||
| ones at any time), you start the transfers by call | ||||
| \fIcurl_multi_perform(3)\fP. | ||||
|  | ||||
| curl_multi_perform() is asynchronous. It will only execute as little as | ||||
| possible and then return back control to your program. It is designed to | ||||
| never block. If it returns CURLM_CALL_MULTI_PERFORM you better call it again | ||||
| soon, as that is a signal that it still has local data to send or remote data | ||||
| to receive. | ||||
| \fIcurl_multi_perform(3)\fP is asynchronous. It will only execute as little as | ||||
| possible and then return back control to your program. It is designed to never | ||||
| block. If it returns CURLM_CALL_MULTI_PERFORM you better call it again soon, | ||||
| as that is a signal that it still has local data to send or remote data to | ||||
| receive. | ||||
|  | ||||
| The best usage of this interface is when you do a select() on all possible | ||||
| file descriptors or sockets to know when to call libcurl again. This also | ||||
| makes it easy for you to wait and respond to actions on your own | ||||
| application's sockets/handles. You figure out what to select() for by using | ||||
| curl_multi_fdset(), that fills in a set of fd_set variables for you with the | ||||
| particular file descriptors libcurl uses for the moment. | ||||
| makes it easy for you to wait and respond to actions on your own application's | ||||
| sockets/handles. You figure out what to select() for by using | ||||
| \fIcurl_multi_fdset(3)\fP, that fills in a set of fd_set variables for you | ||||
| with the particular file descriptors libcurl uses for the moment. | ||||
|  | ||||
| When you then call select(), it'll return when one of the file handles signal | ||||
| action and you then call curl_multi_perform() to allow libcurl to do what it | ||||
| wants to do. Take note that libcurl does also feature some time-out code so | ||||
| we advice you to never use very long timeouts on select() before you call | ||||
| curl_multi_perform(), which thus should be called unconditionally every now | ||||
| and then even if none of its file descriptors have signaled ready. Another | ||||
| precaution you should use: always call curl_multi_fdset() immediately before | ||||
| the select() call since the current set of file descriptors may change when | ||||
| calling a curl function. | ||||
| action and you then call \fIcurl_multi_perform(3)\fP to allow libcurl to do | ||||
| what it wants to do. Take note that libcurl does also feature some time-out | ||||
| code so we advice you to never use very long timeouts on select() before you | ||||
| call \fIcurl_multi_perform(3)\fP, which thus should be called unconditionally | ||||
| every now and then even if none of its file descriptors have signaled | ||||
| ready. Another precaution you should use: always call | ||||
| \fIcurl_multi_fdset(3)\fP immediately before the select() call since the | ||||
| current set of file descriptors may change when calling a curl function. | ||||
|  | ||||
| If you want to stop the transfer of one of the easy handles in the stack, you | ||||
| can use curl_multi_remove_handle() to remove individual easy | ||||
| handles. Remember that easy handles should be curl_easy_cleanup()ed. | ||||
| can use \fIcurl_multi_remove_handle(3)\fP to remove individual easy | ||||
| handles. Remember that easy handles should be \fIcurl_easy_cleanup(3)\fPed. | ||||
|  | ||||
| When a transfer within the multi stack has finished, the counter of running | ||||
| transfers (as filled in by curl_multi_perform()) will decrease. When the | ||||
| number reaches zero, all transfers are done. | ||||
| transfers (as filled in by \fIcurl_multi_perform(3)\fP) will decrease. When | ||||
| the number reaches zero, all transfers are done. | ||||
|  | ||||
| curl_multi_info_read() can be used to get information about completed | ||||
| \fIcurl_multi_info_read(3)\fP can be used to get information about completed | ||||
| transfers. It then returns the CURLcode for each easy transfer, to allow you | ||||
| to figure out success on each individual transfer. | ||||
|  | ||||
|   | ||||
							
								
								
									
										230
									
								
								docs/libcurl/libcurl.m4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										230
									
								
								docs/libcurl/libcurl.m4
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,230 @@ | ||||
| # LIBCURL_CHECK_CONFIG ([DEFAULT-ACTION], [MINIMUM-VERSION], | ||||
| #                       [ACTION-IF-YES], [ACTION-IF-NO]) | ||||
| # ---------------------------------------------------------- | ||||
| #      David Shaw <dshaw@jabberwocky.com>   Jun-21-2005 | ||||
| # | ||||
| # Checks for libcurl.  DEFAULT-ACTION is the string yes or no to | ||||
| # specify whether to default to --with-libcurl or --without-libcurl. | ||||
| # If not supplied, DEFAULT-ACTION is yes.  MINIMUM-VERSION is the | ||||
| # minimum version of libcurl to accept.  Pass the version as a regular | ||||
| # version number like 7.10.1. If not supplied, any version is | ||||
| # accepted.  ACTION-IF-YES is a list of shell commands to run if | ||||
| # libcurl was successfully found and passed the various tests. | ||||
| # ACTION-IF-NO is a list of shell commands that are run otherwise. | ||||
| # Note that using --without-libcurl does run ACTION-IF-NO. | ||||
| # | ||||
| # This macro defines HAVE_LIBCURL if a working libcurl setup is found, | ||||
| # and sets @LIBCURL@ and @LIBCURL_CPPFLAGS@ to the necessary values. | ||||
| # Other useful defines are LIBCURL_FEATURE_xxx where xxx are the | ||||
| # various features supported by libcurl, and LIBCURL_PROTOCOL_yyy | ||||
| # where yyy are the various protocols supported by libcurl.  Both xxx | ||||
| # and yyy are capitalized.  See the list of AH_TEMPLATEs at the top of | ||||
| # the macro for the complete list of possible defines.  Shell | ||||
| # variables $libcurl_feature_xxx and $libcurl_protocol_yyy are also | ||||
| # defined to 'yes' for those features and protocols that were found. | ||||
| # Note that xxx and yyy keep the same capitalization as in the | ||||
| # curl-config list (e.g. it's "HTTP" and not "http"). | ||||
| # | ||||
| # Users may override the detected values by doing something like: | ||||
| # LIBCURL="-lcurl" LIBCURL_CPPFLAGS="-I/usr/myinclude" ./configure | ||||
| # | ||||
| # For the sake of sanity, this macro assumes that any libcurl that is | ||||
| # found is after version 7.7.2, the first version that included the | ||||
| # curl-config script.  Note that it is very important for people | ||||
| # packaging binary versions of libcurl to include this script! | ||||
| # Without curl-config, we can only guess what protocols are available. | ||||
|  | ||||
| AC_DEFUN([LIBCURL_CHECK_CONFIG], | ||||
| [ | ||||
|   AH_TEMPLATE([LIBCURL_FEATURE_SSL],[Defined if libcurl supports SSL]) | ||||
|   AH_TEMPLATE([LIBCURL_FEATURE_KRB4],[Defined if libcurl supports KRB4]) | ||||
|   AH_TEMPLATE([LIBCURL_FEATURE_IPV6],[Defined if libcurl supports IPv6]) | ||||
|   AH_TEMPLATE([LIBCURL_FEATURE_LIBZ],[Defined if libcurl supports libz]) | ||||
|   AH_TEMPLATE([LIBCURL_FEATURE_ASYNCHDNS],[Defined if libcurl supports AsynchDNS]) | ||||
|  | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_HTTP],[Defined if libcurl supports HTTP]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_HTTPS],[Defined if libcurl supports HTTPS]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_FTP],[Defined if libcurl supports FTP]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_FTPS],[Defined if libcurl supports FTPS]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_GOPHER],[Defined if libcurl supports GOPHER]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_FILE],[Defined if libcurl supports FILE]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_TELNET],[Defined if libcurl supports TELNET]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_LDAP],[Defined if libcurl supports LDAP]) | ||||
|   AH_TEMPLATE([LIBCURL_PROTOCOL_DICT],[Defined if libcurl supports DICT]) | ||||
|  | ||||
|   AC_ARG_WITH(libcurl, | ||||
|      AC_HELP_STRING([--with-libcurl=DIR],[look for the curl library in DIR]), | ||||
|      [_libcurl_with=$withval],[_libcurl_with=ifelse([$1],,[yes],[$1])]) | ||||
|  | ||||
|   if test "$_libcurl_with" != "no" ; then | ||||
|  | ||||
|      AC_PROG_AWK | ||||
|  | ||||
|      _libcurl_version_parse="eval $AWK '{split(\$NF,A,\".\"); X=256*256*A[[1]]+256*A[[2]]+A[[3]]; print X;}'" | ||||
|  | ||||
|      _libcurl_try_link=yes | ||||
|  | ||||
|      if test -d "$_libcurl_with" ; then | ||||
|         CPPFLAGS="${CPPFLAGS} -I$withval/include" | ||||
|         LDFLAGS="${LDFLAGS} -L$withval/lib" | ||||
|      fi | ||||
|  | ||||
|      AC_PATH_PROG([_libcurl_config],[curl-config]) | ||||
|  | ||||
|      if test x$_libcurl_config != "x" ; then | ||||
|         AC_CACHE_CHECK([for the version of libcurl], | ||||
| 	   [libcurl_cv_lib_curl_version], | ||||
|            [libcurl_cv_lib_curl_version=`$_libcurl_config --version | $AWK '{print $[]2}'`]) | ||||
|  | ||||
| 	_libcurl_version=`echo $libcurl_cv_lib_curl_version | $_libcurl_version_parse` | ||||
| 	_libcurl_wanted=`echo ifelse([$2],,[0],[$2]) | $_libcurl_version_parse` | ||||
|  | ||||
|         if test $_libcurl_wanted -gt 0 ; then | ||||
| 	   AC_CACHE_CHECK([for libcurl >= version $2], | ||||
| 	      [libcurl_cv_lib_version_ok], | ||||
|               [ | ||||
|    	      if test $_libcurl_version -ge $_libcurl_wanted ; then | ||||
| 	         libcurl_cv_lib_version_ok=yes | ||||
|       	      else | ||||
| 	         libcurl_cv_lib_version_ok=no | ||||
|   	      fi | ||||
|               ]) | ||||
|         fi | ||||
|  | ||||
| 	if test $_libcurl_wanted -eq 0 || test x$libcurl_cv_lib_version_ok = xyes ; then | ||||
|            if test x"$LIBCURL_CPPFLAGS" = "x" ; then | ||||
|               LIBCURL_CPPFLAGS=`$_libcurl_config --cflags` | ||||
|            fi | ||||
|            if test x"$LIBCURL" = "x" ; then | ||||
|               LIBCURL=`$_libcurl_config --libs` | ||||
|  | ||||
|               # This is so silly, but Apple actually has a bug in their | ||||
| 	      # curl-config script.  Fixed in Tiger, but there are still | ||||
| 	      # lots of Panther installs around. | ||||
|               case "${host}" in | ||||
|                  powerpc-apple-darwin7*) | ||||
|                     LIBCURL=`echo $LIBCURL | sed -e 's|-arch i386||g'` | ||||
|                  ;; | ||||
|               esac | ||||
|            fi | ||||
|  | ||||
| 	   # All curl-config scripts support --feature | ||||
| 	   _libcurl_features=`$_libcurl_config --feature` | ||||
|  | ||||
|            # Is it modern enough to have --protocols? (7.12.4) | ||||
| 	   if test $_libcurl_version -ge 461828 ; then | ||||
|               _libcurl_protocols=`$_libcurl_config --protocols` | ||||
|            fi | ||||
| 	else | ||||
|            _libcurl_try_link=no | ||||
| 	fi | ||||
|  | ||||
| 	unset _libcurl_wanted | ||||
|      fi | ||||
|  | ||||
|      if test $_libcurl_try_link = yes ; then | ||||
|  | ||||
|         # we didn't find curl-config, so let's see if the user-supplied | ||||
|         # link line (or failing that, "-lcurl") is enough. | ||||
|         LIBCURL=${LIBCURL-"-lcurl"} | ||||
|  | ||||
|         AC_CACHE_CHECK([whether libcurl is usable], | ||||
|            [libcurl_cv_lib_curl_usable], | ||||
|            [ | ||||
|            _libcurl_save_cppflags=$CPPFLAGS | ||||
|            CPPFLAGS="$CPPFLAGS $LIBCURL_CPPFLAGS" | ||||
|            _libcurl_save_libs=$LIBS | ||||
|            LIBS="$LIBS $LIBCURL" | ||||
|  | ||||
|            AC_LINK_IFELSE(AC_LANG_PROGRAM([#include <curl/curl.h>],[ | ||||
| /* Try and use a few common options to force a failure if we are | ||||
|    missing symbols or can't link. */ | ||||
| int x; | ||||
| curl_easy_setopt(NULL,CURLOPT_URL,NULL); | ||||
| x=CURL_ERROR_SIZE; | ||||
| x=CURLOPT_WRITEFUNCTION; | ||||
| x=CURLOPT_FILE; | ||||
| x=CURLOPT_ERRORBUFFER; | ||||
| x=CURLOPT_STDERR; | ||||
| x=CURLOPT_VERBOSE; | ||||
| ]),libcurl_cv_lib_curl_usable=yes,libcurl_cv_lib_curl_usable=no) | ||||
|  | ||||
|            CPPFLAGS=$_libcurl_save_cppflags | ||||
|            LIBS=$_libcurl_save_libs | ||||
|            unset _libcurl_save_cppflags | ||||
|            unset _libcurl_save_libs | ||||
|            ]) | ||||
|  | ||||
|         if test $libcurl_cv_lib_curl_usable = yes ; then | ||||
|  | ||||
| 	   # Does curl_free() exist in this version of libcurl? | ||||
| 	   # If not, fake it with free() | ||||
|  | ||||
|            _libcurl_save_cppflags=$CPPFLAGS | ||||
|            CPPFLAGS="$CPPFLAGS $LIBCURL_CPPFLAGS" | ||||
|            _libcurl_save_libs=$LIBS | ||||
|            LIBS="$LIBS $LIBCURL" | ||||
|  | ||||
|            AC_CHECK_FUNC(curl_free,, | ||||
|   	      AC_DEFINE(curl_free,free, | ||||
| 		[Define curl_free() as free() if our version of curl lacks curl_free.])) | ||||
|  | ||||
|            CPPFLAGS=$_libcurl_save_cppflags | ||||
|            LIBS=$_libcurl_save_libs | ||||
|            unset _libcurl_save_cppflags | ||||
|            unset _libcurl_save_libs | ||||
|  | ||||
|            AC_DEFINE(HAVE_LIBCURL,1, | ||||
|              [Define to 1 if you have a functional curl library.]) | ||||
|            AC_SUBST(LIBCURL_CPPFLAGS) | ||||
|            AC_SUBST(LIBCURL) | ||||
|  | ||||
|            for _libcurl_feature in $_libcurl_features ; do | ||||
| 	      AC_DEFINE_UNQUOTED(AS_TR_CPP(libcurl_feature_$_libcurl_feature),[1]) | ||||
| 	      eval AS_TR_SH(libcurl_feature_$_libcurl_feature)=yes | ||||
|            done | ||||
|  | ||||
| 	   if test "x$_libcurl_protocols" = "x" ; then | ||||
|  | ||||
| 	      # We don't have --protocols, so just assume that all | ||||
| 	      # protocols are available | ||||
| 	      _libcurl_protocols="HTTP FTP GOPHER FILE TELNET LDAP DICT" | ||||
|  | ||||
| 	      if test x$libcurl_feature_SSL = xyes ; then | ||||
| 	         _libcurl_protocols="$_libcurl_protocols HTTPS" | ||||
|  | ||||
| 		 # FTPS wasn't standards-compliant until version | ||||
| 		 # 7.11.0 | ||||
| 		 if test $_libcurl_version -ge 461568; then | ||||
| 		    _libcurl_protocols="$_libcurl_protocols FTPS" | ||||
| 		 fi | ||||
| 	      fi | ||||
| 	   fi | ||||
|  | ||||
| 	   for _libcurl_protocol in $_libcurl_protocols ; do | ||||
| 	      AC_DEFINE_UNQUOTED(AS_TR_CPP(libcurl_protocol_$_libcurl_protocol),[1]) | ||||
| 	      eval AS_TR_SH(libcurl_protocol_$_libcurl_protocol)=yes | ||||
|            done | ||||
|         fi | ||||
|      fi | ||||
|  | ||||
|      unset _libcurl_try_link | ||||
|      unset _libcurl_version_parse | ||||
|      unset _libcurl_config | ||||
|      unset _libcurl_feature | ||||
|      unset _libcurl_features | ||||
|      unset _libcurl_protocol | ||||
|      unset _libcurl_protocols | ||||
|      unset _libcurl_version | ||||
|   fi | ||||
|  | ||||
|   if test x$_libcurl_with = xno || test x$libcurl_cv_lib_curl_usable != xyes ; then | ||||
|      # This is the IF-NO path | ||||
|      ifelse([$4],,:,[$4]) | ||||
|   else | ||||
|      # This is the IF-YES path | ||||
|      ifelse([$3],,:,[$3]) | ||||
|   fi | ||||
|  | ||||
|   unset _libcurl_with | ||||
| ])dnl | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2005, 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 | ||||
| @@ -245,7 +245,9 @@ typedef enum { | ||||
|   CURLE_COULDNT_RESOLVE_HOST,    /* 6 */ | ||||
|   CURLE_COULDNT_CONNECT,         /* 7 */ | ||||
|   CURLE_FTP_WEIRD_SERVER_REPLY,  /* 8 */ | ||||
|   CURLE_FTP_ACCESS_DENIED,       /* 9 */ | ||||
|   CURLE_FTP_ACCESS_DENIED,       /* 9 a service was denied by the FTP server | ||||
|                                     due to lack of access - when login fails | ||||
|                                     this is not returned. */ | ||||
|   CURLE_FTP_USER_PASSWORD_INCORRECT, /* 10 */ | ||||
|   CURLE_FTP_WEIRD_PASS_REPLY,    /* 11 */ | ||||
|   CURLE_FTP_WEIRD_USER_REPLY,    /* 12 */ | ||||
| @@ -305,6 +307,15 @@ typedef enum { | ||||
|   CURLE_SEND_FAIL_REWIND,        /* 65 - Sending the data requires a rewind | ||||
|                                     that failed */ | ||||
|   CURLE_SSL_ENGINE_INITFAILED,   /* 66 - failed to initialise ENGINE */ | ||||
|   CURLE_LOGIN_DENIED,            /* 67 - user, password or similar was not | ||||
|                                     accepted and we failed to login */ | ||||
|   CURLE_TFTP_NOTFOUND,           /* 68 - file not found on server */ | ||||
|   CURLE_TFTP_PERM,               /* 69 - permission problem on server */ | ||||
|   CURLE_TFTP_DISKFULL,           /* 70 - out of disk space on server */ | ||||
|   CURLE_TFTP_ILLEGAL,            /* 71 - Illegal TFTP operation */ | ||||
|   CURLE_TFTP_UNKNOWNID,          /* 72 - Unknown transfer ID */ | ||||
|   CURLE_TFTP_EXISTS,             /* 73 - File already exists */ | ||||
|   CURLE_TFTP_NOSUCHUSER,         /* 74 - No such user */ | ||||
|   CURL_LAST /* never use! */ | ||||
| } CURLcode; | ||||
|  | ||||
| @@ -842,25 +853,15 @@ typedef enum { | ||||
|   /* Enable/disable the TCP Nagle algorithm */ | ||||
|   CINIT(TCP_NODELAY, LONG, 121), | ||||
|  | ||||
|   /* When doing 3rd party transfer, set the source host name with this */ | ||||
|   CINIT(SOURCE_HOST, OBJECTPOINT, 122), | ||||
|   /* 122 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||
|  | ||||
|   /* When doing 3rd party transfer, set the source user and password with | ||||
|      this */ | ||||
|   CINIT(SOURCE_USERPWD, OBJECTPOINT, 123), | ||||
|  | ||||
|   /* When doing 3rd party transfer, set the source file path with this */ | ||||
|   CINIT(SOURCE_PATH, OBJECTPOINT, 124), | ||||
|  | ||||
|   /* When doing 3rd party transfer, set the source server's port number | ||||
|      with this */ | ||||
|   CINIT(SOURCE_PORT, LONG, 125), | ||||
|  | ||||
|   /* When doing 3rd party transfer, decide which server that should get the | ||||
|      PASV command (and the other gets the PORT). | ||||
|      0 (default) - The target host issues PASV. | ||||
|      1           - The source host issues PASV */ | ||||
|   CINIT(PASV_HOST, LONG, 126), | ||||
|   /* 124 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||
|   /* 125 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||
|   /* 126 OBSOLETE, used in 7.12.3. Gone in 7.13.0 */ | ||||
|  | ||||
|   /* When doing 3rd party transfer, set the source pre-quote linked list | ||||
|      of commands with this */ | ||||
| @@ -885,6 +886,29 @@ typedef enum { | ||||
|   CINIT(IOCTLFUNCTION, FUNCTIONPOINT, 130), | ||||
|   CINIT(IOCTLDATA, OBJECTPOINT, 131), | ||||
|  | ||||
|   /* To make a 3rd party transfer, set the source URL with this */ | ||||
|   CINIT(SOURCE_URL, OBJECTPOINT, 132), | ||||
|  | ||||
|   /* When doing 3rd party transfer, set the source quote linked list of | ||||
|      commands with this */ | ||||
|   CINIT(SOURCE_QUOTE, OBJECTPOINT, 133), | ||||
|  | ||||
|   /* zero terminated string for pass on to the FTP server when asked for | ||||
|      "account" info */ | ||||
|   CINIT(FTP_ACCOUNT, OBJECTPOINT, 134), | ||||
|  | ||||
|   /* feed cookies into cookie engine */ | ||||
|   CINIT(COOKIELIST, OBJECTPOINT, 135), | ||||
|  | ||||
|   /* ignore Content-Length */ | ||||
|   CINIT(IGNORE_CONTENT_LENGTH, LONG, 136), | ||||
|  | ||||
|   /* Set to non-zero to skip the IP address received in a 227 PASV FTP server | ||||
|      response. Typically used for FTP-SSL purposes but is not restricted to | ||||
|      that. libcurl will then instead use the same IP address it used for the | ||||
|      control connection. */ | ||||
|   CINIT(FTP_SKIP_PASV_IP, LONG, 137), | ||||
|  | ||||
|   CURLOPT_LASTENTRY /* the last unused */ | ||||
| } CURLoption; | ||||
|  | ||||
| @@ -910,6 +934,11 @@ typedef enum { | ||||
| #define CURLOPT_PASSWDDATA     -4 | ||||
| #define CURLOPT_CLOSEFUNCTION  -5 | ||||
|  | ||||
| #define CURLOPT_SOURCE_HOST    -6 | ||||
| #define CURLOPT_SOURCE_PATH    -7 | ||||
| #define CURLOPT_SOURCE_PORT    -8 | ||||
| #define CURLOPT_PASV_HOST      -9 | ||||
|  | ||||
| #else | ||||
| /* This is set if CURL_NO_OLDIES is defined at compile-time */ | ||||
| #undef CURLOPT_DNS_USE_GLOBAL_CACHE /* soon obsolete */ | ||||
| @@ -1192,11 +1221,10 @@ CURL_EXTERN void curl_slist_free_all(struct curl_slist *); | ||||
|  * DESCRIPTION | ||||
|  * | ||||
|  * Returns the time, in seconds since 1 Jan 1970 of the time string given in | ||||
|  * the first argument. The time argument in the second parameter is for cases | ||||
|  * where the specified time is relative now, like 'two weeks' or 'tomorrow' | ||||
|  * etc. | ||||
|  * the first argument. The time argument in the second parameter is unused | ||||
|  * and should be set to NULL. | ||||
|  */ | ||||
| CURL_EXTERN time_t curl_getdate(const char *p, const time_t *now); | ||||
| CURL_EXTERN time_t curl_getdate(const char *p, const time_t *unused); | ||||
|  | ||||
| #define CURLINFO_STRING   0x100000 | ||||
| #define CURLINFO_LONG     0x200000 | ||||
| @@ -1234,6 +1262,7 @@ typedef enum { | ||||
|   CURLINFO_OS_ERRNO         = CURLINFO_LONG   + 25, | ||||
|   CURLINFO_NUM_CONNECTS     = CURLINFO_LONG   + 26, | ||||
|   CURLINFO_SSL_ENGINES      = CURLINFO_SLIST  + 27, | ||||
|   CURLINFO_COOKIELIST       = CURLINFO_SLIST  + 28, | ||||
|   /* Fill in new entries below here! */ | ||||
|  | ||||
|   CURLINFO_LASTONE          = 28 | ||||
| @@ -1337,7 +1366,7 @@ typedef enum { | ||||
| /* The 'CURLVERSION_NOW' is the symbolic name meant to be used by | ||||
|    basicly all programs ever, that want to get version information. It is | ||||
|    meant to be a built-in version number for what kind of struct the caller | ||||
|    expects. If the struct ever changes, we redfine the NOW to another enum | ||||
|    expects. If the struct ever changes, we redefine the NOW to another enum | ||||
|    from above. */ | ||||
| #define CURLVERSION_NOW CURLVERSION_THIRD | ||||
|  | ||||
| @@ -1347,11 +1376,11 @@ typedef struct { | ||||
|   unsigned int version_num; /* LIBCURL_VERSION_NUM */ | ||||
|   const char *host;         /* OS/host/cpu/machine when configured */ | ||||
|   int features;             /* bitmask, see defines below */ | ||||
|   char *ssl_version;        /* human readable string */ | ||||
|   long ssl_version_num;     /* number */ | ||||
|   const char *ssl_version;  /* human readable string */ | ||||
|   long ssl_version_num;     /* not used anymore, always 0 */ | ||||
|   const char *libz_version; /* human readable string */ | ||||
|   /* protocols is terminated by an entry with a NULL protoname */ | ||||
|   const char **protocols; | ||||
|   const char * const *protocols; | ||||
|  | ||||
|   /* The fields below this were added in CURLVERSION_SECOND */ | ||||
|   const char *ares; | ||||
| @@ -1372,6 +1401,7 @@ typedef struct { | ||||
| #define CURL_VERSION_SPNEGO    (1<<8)  /* SPNEGO auth */ | ||||
| #define CURL_VERSION_LARGEFILE (1<<9)  /* supports files bigger than 2GB */ | ||||
| #define CURL_VERSION_IDN       (1<<10) /* International Domain Names support */ | ||||
| #define CURL_VERSION_SSPI      (1<<11) /* SSPI is supported */ | ||||
|  | ||||
| /* | ||||
|  * NAME curl_version_info() | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2005, 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 | ||||
| @@ -28,7 +28,13 @@ | ||||
|  | ||||
| /* This is the version number of the libcurl package from which this header | ||||
|    file origins: */ | ||||
| #define LIBCURL_VERSION "7.12.3-CVS" | ||||
| #define LIBCURL_VERSION "7.15.0-CVS" | ||||
|  | ||||
| /* The numeric version number is also available "in parts" by using these | ||||
|    defines: */ | ||||
| #define LIBCURL_VERSION_MAJOR 7 | ||||
| #define LIBCURL_VERSION_MINOR 15 | ||||
| #define LIBCURL_VERSION_PATCH 0 | ||||
|  | ||||
| /* This is the numeric version of the libcurl version number, meant for easier | ||||
|    parsing and comparions by programs. The LIBCURL_VERSION_NUM define will | ||||
| @@ -37,19 +43,16 @@ | ||||
|          0xXXYYZZ | ||||
|  | ||||
|    Where XX, YY and ZZ are the main version, release and patch numbers in | ||||
|    hexadecimal. All three numbers are always represented using two digits.  1.2 | ||||
|    would appear as "0x010200" while version 9.11.7 appears as "0x090b07". | ||||
|    hexadecimal (using 8 bits each). All three numbers are always represented | ||||
|    using two digits.  1.2 would appear as "0x010200" while version 9.11.7 | ||||
|    appears as "0x090b07". | ||||
|  | ||||
|    This 6-digit hexadecimal number does not show pre-release number, and it is | ||||
|    always a greater number in a more recent release. It makes comparisons with | ||||
|    greater than and less than work. | ||||
|    This 6-digit (24 bits) hexadecimal number does not show pre-release number, | ||||
|    and it is always a greater number in a more recent release. It makes | ||||
|    comparisons with greater than and less than work. | ||||
| */ | ||||
| #define LIBCURL_VERSION_NUM 0x070c03 | ||||
|  | ||||
| /* The numeric version number is also available "in parts" by using these | ||||
|    defines: */ | ||||
| #define LIBCURL_VERSION_MAJOR 7 | ||||
| #define LIBCURL_VERSION_MINOR 12 | ||||
| #define LIBCURL_VERSION_PATCH 3 | ||||
| #define LIBCURL_VERSION_NUM ((LIBCURL_VERSION_MAJOR << 16) | \ | ||||
|                              (LIBCURL_VERSION_MINOR << 8) | \ | ||||
|                              LIBCURL_VERSION_PATCH) | ||||
|  | ||||
| #endif /* __CURL_CURLVER_H */ | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  *                            | (__| |_| |  _ <| |___ | ||||
|  *                             \___|\___/|_| \_\_____| | ||||
|  * | ||||
|  * Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
|  * | ||||
|  * This software is licensed as described in the file COPYING, which | ||||
|  * you should have received as part of this distribution. The terms | ||||
| @@ -23,16 +23,8 @@ | ||||
|  * $Id$ | ||||
|  ***************************************************************************/ | ||||
| /* | ||||
|   This is meant to be the "external" header file. Don't give away any | ||||
|   internals here! | ||||
|   This is an "external" header file. Don't give away any internals here! | ||||
|  | ||||
|   This document presents a mixture of ideas from at least: | ||||
|   - Daniel Stenberg | ||||
|   - Steve Dekorte | ||||
|   - Sterling Hughes | ||||
|   - Ben Greear | ||||
|  | ||||
|   ------------------------------------------- | ||||
|   GOALS | ||||
|  | ||||
|   o Enable a "pull" interface. The application that uses libcurl decides where | ||||
| @@ -67,7 +59,9 @@ | ||||
| #include <sys/select.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef _WIN32_WCE | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #include <sys/time.h> | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| @@ -80,6 +74,22 @@ extern "C" { | ||||
|  | ||||
| typedef void CURLM; | ||||
|  | ||||
| #ifdef HAVE_CURL_MULTI_SOCKET /* this is not set by anything yet */ | ||||
|  | ||||
| #ifndef curl_socket_typedef | ||||
| /* Public socket typedef */ | ||||
| #ifdef WIN32 | ||||
| typedef SOCKET curl_socket_t; | ||||
| #define CURL_SOCKET_BAD INVALID_SOCKET | ||||
| #else | ||||
| typedef int curl_socket_t; | ||||
| #define CURL_SOCKET_BAD -1 | ||||
| #endif | ||||
| #define curl_socket_typedef | ||||
| #endif /* curl_socket_typedef */ | ||||
|  | ||||
| #endif /* HAVE_CURL_MULTI_SOCKET */ | ||||
|  | ||||
| typedef enum { | ||||
|   CURLM_CALL_MULTI_PERFORM=-1, /* please call curl_multi_perform() soon */ | ||||
|   CURLM_OK, | ||||
| @@ -111,6 +121,7 @@ typedef struct CURLMsg CURLMsg; | ||||
|  * Name:    curl_multi_init() | ||||
|  * | ||||
|  * Desc:    inititalize multi-style curl usage | ||||
|  * | ||||
|  * Returns: a new CURLM handle to use in all 'curl_multi' functions. | ||||
|  */ | ||||
| CURL_EXTERN CURLM *curl_multi_init(void); | ||||
| @@ -119,6 +130,7 @@ CURL_EXTERN CURLM *curl_multi_init(void); | ||||
|  * Name:    curl_multi_add_handle() | ||||
|  * | ||||
|  * Desc:    add a standard curl handle to the multi stack | ||||
|  * | ||||
|  * Returns: CURLMcode type, general multi error code. | ||||
|  */ | ||||
| CURL_EXTERN CURLMcode curl_multi_add_handle(CURLM *multi_handle, | ||||
| @@ -128,6 +140,7 @@ CURL_EXTERN CURLMcode curl_multi_add_handle(CURLM *multi_handle, | ||||
|   * Name:    curl_multi_remove_handle() | ||||
|   * | ||||
|   * Desc:    removes a curl handle from the multi stack again | ||||
|   * | ||||
|   * Returns: CURLMcode type, general multi error code. | ||||
|   */ | ||||
| CURL_EXTERN CURLMcode curl_multi_remove_handle(CURLM *multi_handle, | ||||
| @@ -139,6 +152,7 @@ CURL_EXTERN CURLMcode curl_multi_remove_handle(CURLM *multi_handle, | ||||
|   * Desc:    Ask curl for its fd_set sets. The app can use these to select() or | ||||
|   *          poll() on. We want curl_multi_perform() called as soon as one of | ||||
|   *          them are ready. | ||||
|   * | ||||
|   * Returns: CURLMcode type, general multi error code. | ||||
|   */ | ||||
| CURL_EXTERN CURLMcode curl_multi_fdset(CURLM *multi_handle, | ||||
| @@ -173,6 +187,7 @@ CURL_EXTERN CURLMcode curl_multi_perform(CURLM *multi_handle, | ||||
|   *          touch any individual easy handles in any way. We need to define | ||||
|   *          in what state those handles will be if this function is called | ||||
|   *          in the middle of a transfer. | ||||
|   * | ||||
|   * Returns: CURLMcode type, general multi error code. | ||||
|   */ | ||||
| CURL_EXTERN CURLMcode curl_multi_cleanup(CURLM *multi_handle); | ||||
| @@ -209,16 +224,107 @@ CURL_EXTERN CURLMsg *curl_multi_info_read(CURLM *multi_handle, | ||||
|                                           int *msgs_in_queue); | ||||
|  | ||||
| /* | ||||
|  * NAME curl_multi_strerror() | ||||
|  * Name:    curl_multi_strerror() | ||||
|  * | ||||
|  * DESCRIPTION | ||||
|  * Desc:    The curl_multi_strerror function may be used to turn a CURLMcode | ||||
|  *          value into the equivalent human readable error string.  This is | ||||
|  *          useful for printing meaningful error messages. | ||||
|  * | ||||
|  * The curl_multi_strerror function may be used to turn a CURLMcode value | ||||
|  * into the equivalent human readable error string.  This is useful | ||||
|  * for printing meaningful error messages. | ||||
|  * Returns: A pointer to a zero-terminated error message. | ||||
|  */ | ||||
| CURL_EXTERN const char *curl_multi_strerror(CURLMcode); | ||||
|  | ||||
| #ifdef HAVE_CURL_MULTI_SOCKET | ||||
| /* | ||||
|  * Name:    curl_multi_socket() and | ||||
|  *          curl_multi_socket_all() | ||||
|  * | ||||
|  * Desc:    An alternative version of curl_multi_perform() that allows the | ||||
|  *          application to pass in one of the file descriptors that have been | ||||
|  *          detected to have "action" on them and let libcurl perform. This | ||||
|  *          allows libcurl to not have to scan through all possible file | ||||
|  *          descriptors to check for this. The app is recommended to pass in | ||||
|  *          the 'easy' argument (or set it to CURL_EASY_NONE) to make libcurl | ||||
|  *          figure out the internal structure even faster and easier.  If the | ||||
|  *          easy argument is set to something else than CURL_EASY_NONE, the | ||||
|  *          's' (socket) argument will be ignored by libcurl. | ||||
|  * | ||||
|  *          It also informs the application about updates in the socket (file | ||||
|  *          descriptor) status by doing none, one or multiple calls to the | ||||
|  *          curl_socket_callback. It thus updates the status with changes | ||||
|  *          since the previous time this function was used. If 'callback' is | ||||
|  *          NULL, no callback will be called. A status change may also be a | ||||
|  *          new timeout only, having the same IN/OUT status as before. | ||||
|  * | ||||
|  *          If a previous wait for socket action(s) timed out, you should call | ||||
|  *          this function with the socket argument set to | ||||
|  *          CURL_SOCKET_TIMEOUT. If you want to force libcurl to (re-)check | ||||
|  *          all its internal sockets, and call the callback with status for | ||||
|  *          all sockets no matter what the previous state is, you call | ||||
|  *          curl_multi_socket_all() instead. | ||||
|  * | ||||
|  *          curl_multi_perform() is thus the equivalent of calling | ||||
|  *          curl_multi_socket_all(handle, NULL, NULL); | ||||
|  * | ||||
|  *          IMPLEMENTATION: libcurl will need an internal hash table to map | ||||
|  *          socket numbers to internal easy handles for the cases when 'easy' | ||||
|  *          is set to CURL_EASY_NONE. | ||||
|  * | ||||
|  *          Regarding the timeout argument in the callback: it is the timeout | ||||
|  *          (in milliseconds) for waiting on action on this socket (and the | ||||
|  *          given time period starts when the callback is called) until you | ||||
|  *          should call curl_multi_socket() with the timeout stuff mentioned | ||||
|  *          above. If "actions" happens on the socket before the timeout | ||||
|  *          happens, remember that the timout timer keeps ticking until told | ||||
|  *          otherwise. | ||||
|  * | ||||
|  *          The "what" argument has one of five values: | ||||
|  * | ||||
|  *            0 CURL_POLL_NONE (0)   - register, not interested in readiness | ||||
|  *            1 CURL_POLL_IN         - register, interested in read readiness | ||||
|  *            2 CURL_POLL_OUT        - register, interested in write readiness | ||||
|  *            3 CURL_POLL_INOUT      - register, interested in both | ||||
|  *            4 CURL_POLL_REMOVE     - deregister | ||||
|  */ | ||||
| #define CURL_POLL_NONE   0 | ||||
| #define CURL_POLL_IN     1 | ||||
| #define CURL_POLL_OUT    2 | ||||
| #define CURL_POLL_INOUT  3 | ||||
| #define CURL_POLL_REMOVE 4 | ||||
|  | ||||
| #define CURL_EASY_NONE (CURL *)0 | ||||
| #define CURL_EASY_TIMEOUT (CURL *)0 | ||||
| #define CURL_SOCKET_TIMEOUT CURL_SOCKET_BAD | ||||
|  | ||||
| typedef int (*curl_socket_callback)(CURL *easy,      /* easy handle */ | ||||
|                                     curl_socket_t s, /* socket */ | ||||
|                                     int what,        /* see above */ | ||||
|                                     long ms,         /* timeout for wait */ | ||||
|                                     void *userp);    /* "private" pointer */ | ||||
|  | ||||
| CURLMcode curl_multi_socket(CURLM *multi_handle, | ||||
|                             curl_socket_t s, | ||||
|                             CURL *easy, | ||||
|                             curl_socket_callback callback, | ||||
|                             void *userp); /* passed to callback */ | ||||
|  | ||||
| CURLMcode curl_multi_socket_all(CURLM *multi_handle, | ||||
|                                 curl_socket_callback callback, | ||||
|                                 void *userp); /* passed to callback */ | ||||
|  | ||||
| /* | ||||
|  * Name:    curl_multi_timeout() | ||||
|  * | ||||
|  * Desc:    Returns the maximum number of milliseconds the app is allowed to | ||||
|  *          wait before curl_multi_socket() or curl_multi_perform() must be | ||||
|  *          called (to allow libcurl's timed events to take place). | ||||
|  * | ||||
|  * Returns: CURLM error code. | ||||
|  */ | ||||
| CURLMcode curl_multi_timeout(CURLM *multi_handle, long *milliseconds); | ||||
|  | ||||
| #endif /* HAVE_CURL_MULTI_SOCKET */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } /* end of extern "C" */ | ||||
| #endif | ||||
|   | ||||
							
								
								
									
										370
									
								
								lib/Makefile.Watcom
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										370
									
								
								lib/Makefile.Watcom
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,370 @@ | ||||
| # | ||||
| #  Watcom / OpenWatcom / Win32 makefile for libcurl. | ||||
| #  G. Vanem <giva@bgnett.no> | ||||
| # | ||||
| # $Id$ | ||||
|  | ||||
| TARGETS = libcurl_wc.lib libcurl_wc.dll libcurl_wc_imp.lib | ||||
|  | ||||
| CC = wcc386 | ||||
|  | ||||
| CFLAGS = -3r -mf -d3 -hc -zff -zgf -zq -zm -s -fr=con -w2 -fpi -oilrtfm -bt=nt -bd & | ||||
|          -d+ -dWIN32 -dHAVE_LONGLONG -dCURL_CA_BUNDLE=getenv("CURL_CA_BUNDLE") & | ||||
|          -dBUILDING_LIBCURL -dWITHOUT_MM_LIB -dHAVE_SPNEGO=1 -dENABLE_IPV6     & | ||||
|          -dDEBUG_THREADING_GETADDRINFO -dDEBUG=1 -dCURLDEBUG -I. -I..\include | ||||
|  | ||||
| OBJ_DIR  = Watcom_obj | ||||
| LIB_ARG  = $(OBJ_DIR)\wlib.arg | ||||
| LINK_ARG = $(OBJ_DIR)\wlink.arg | ||||
|  | ||||
| OBJS = $(OBJ_DIR)\transfer.obj         $(OBJ_DIR)\file.obj       & | ||||
|        $(OBJ_DIR)\strequal.obj         $(OBJ_DIR)\timeval.obj    & | ||||
|        $(OBJ_DIR)\easy.obj             $(OBJ_DIR)\base64.obj     & | ||||
|        $(OBJ_DIR)\security.obj         $(OBJ_DIR)\hostip.obj     & | ||||
|        $(OBJ_DIR)\krb4.obj             $(OBJ_DIR)\progress.obj   & | ||||
|        $(OBJ_DIR)\memdebug.obj         $(OBJ_DIR)\formdata.obj   & | ||||
|        $(OBJ_DIR)\http_chunks.obj      $(OBJ_DIR)\cookie.obj     & | ||||
|        $(OBJ_DIR)\strtok.obj           $(OBJ_DIR)\http.obj       & | ||||
|        $(OBJ_DIR)\connect.obj          $(OBJ_DIR)\sendf.obj      & | ||||
|        $(OBJ_DIR)\llist.obj            $(OBJ_DIR)\ftp.obj        & | ||||
|        $(OBJ_DIR)\hash.obj             $(OBJ_DIR)\url.obj        & | ||||
|        $(OBJ_DIR)\multi.obj            $(OBJ_DIR)\dict.obj       & | ||||
|        $(OBJ_DIR)\content_encoding.obj $(OBJ_DIR)\if2ip.obj      & | ||||
|        $(OBJ_DIR)\share.obj            $(OBJ_DIR)\speedcheck.obj & | ||||
|        $(OBJ_DIR)\http_digest.obj      $(OBJ_DIR)\ldap.obj       & | ||||
|        $(OBJ_DIR)\md5.obj              $(OBJ_DIR)\ssluse.obj     & | ||||
|        $(OBJ_DIR)\http_negotiate.obj   $(OBJ_DIR)\version.obj    & | ||||
|        $(OBJ_DIR)\http_ntlm.obj        $(OBJ_DIR)\getenv.obj     & | ||||
|        $(OBJ_DIR)\inet_pton.obj        $(OBJ_DIR)\escape.obj     & | ||||
|        $(OBJ_DIR)\strtoofft.obj        $(OBJ_DIR)\mprintf.obj    & | ||||
|        $(OBJ_DIR)\strerror.obj         $(OBJ_DIR)\telnet.obj     & | ||||
|        $(OBJ_DIR)\hostares.obj         $(OBJ_DIR)\netrc.obj      & | ||||
|        $(OBJ_DIR)\hostasyn.obj         $(OBJ_DIR)\getinfo.obj    & | ||||
|        $(OBJ_DIR)\hostip4.obj          $(OBJ_DIR)\hostthre.obj   & | ||||
|        $(OBJ_DIR)\hostip6.obj          $(OBJ_DIR)\inet_ntop.obj  & | ||||
|        $(OBJ_DIR)\hostsyn.obj          $(OBJ_DIR)\parsedate.obj  & | ||||
|        $(OBJ_DIR)\select.obj           $(OBJ_DIR)\sslgen.obj     & | ||||
|        $(OBJ_DIR)\gtls.obj             $(OBJ_DIR)\tftp.obj | ||||
|  | ||||
| RESOURCE = $(OBJ_DIR)\libcurl.res | ||||
|  | ||||
| all: $(OBJ_DIR) $(TARGETS) .SYMBOLIC | ||||
| 	@echo Welcome to libcurl | ||||
|  | ||||
| $(OBJ_DIR): | ||||
| 	mkdir $(OBJ_DIR) | ||||
|  | ||||
| libcurl_wc.lib: $(OBJS) $(LIB_ARG) | ||||
| 	wlib -q -b -c $@ @$(LIB_ARG) | ||||
|  | ||||
| libcurl_wc.dll: $(OBJS) $(RESOURCE) $(LINK_ARG) | ||||
| 	wlink name libcurl_wc.dll @$(LINK_ARG) | ||||
|  | ||||
| clean: .SYMBOLIC | ||||
| 	- rm -f $(OBJS) $(RESOURCE) | ||||
|  | ||||
| vclean realclean: clean .SYMBOLIC | ||||
| 	- rm -f $(TARGETS) $(LIB_ARG) $(LINK_ARG) libcurl_wc.map | ||||
| 	- rmdir $(OBJ_DIR) | ||||
|  | ||||
| .ERASE | ||||
| $(RESOURCE): libcurl.rc | ||||
|         wrc -dCURLDEBUG=1 -q -r -zm -I..\include -fo=$@ libcurl.rc | ||||
|  | ||||
| .ERASE | ||||
| .c{$(OBJ_DIR)}.obj: | ||||
| 	$(CC) $[@ $(CFLAGS) -fo=$@ | ||||
| 	@echo . | ||||
|  | ||||
| $(LIB_ARG): $(__MAKEFILES__) | ||||
| 	%create $^@ | ||||
| 	for %f in ($(OBJS)) do @%append $^@ +- %f | ||||
|  | ||||
| $(LINK_ARG): $(__MAKEFILES__) | ||||
| 	%create $^@ | ||||
| 	@%append $^@ system nt dll | ||||
| 	@%append $^@ file { $(OBJS) } | ||||
| 	@%append $^@ option quiet, map, caseexact, eliminate, implib=libcurl_wc_imp.lib, | ||||
| 	@%append $^@ res=$(RESOURCE) libpath $(%watcom)\lib386;$(%watcom)\lib386\nt | ||||
| 	@%append $^@ library clib3r.lib, ws2_32.lib | ||||
|  | ||||
| # | ||||
| # Dependencies based on "gcc -MM .." | ||||
| # | ||||
| $(OBJ_DIR)\file.obj: file.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h progress.h sendf.h escape.h file.h & | ||||
|   speedcheck.h getinfo.h transfer.h url.h memory.h ..\include\curl\mprintf.h & | ||||
|   memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\timeval.obj: timeval.c timeval.h setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\base64.obj: base64.c setup.h config-win32.h ..\include\curl\mprintf.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h base64.h memory.h ..\include\curl\curl.h & | ||||
|   memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hostip.obj: hostip.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   inet_ntop.h ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\progress.obj: progress.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & | ||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h http_chunks.h & | ||||
|   hostip.h hash.h llist.h sendf.h progress.h ..\include\curl\mprintf.h | ||||
|  | ||||
| $(OBJ_DIR)\formdata.obj: formdata.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h strequal.h & | ||||
|   memory.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\cookie.obj: cookie.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h strequal.h strtok.h sendf.h & | ||||
|   memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\http.obj: http.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h transfer.h sendf.h progress.h & | ||||
|   base64.h strequal.h ssluse.h http_digest.h http_ntlm.h http_negotiate.h & | ||||
|   url.h share.h http.h memory.h select.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\sendf.obj: sendf.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & | ||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h connect.h & | ||||
|   ..\include\curl\mprintf.h memory.h strerror.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\ftp.obj: ftp.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & | ||||
|   if2ip.h progress.h transfer.h escape.h http.h ftp.h strtoofft.h & | ||||
|   strequal.h ssluse.h connect.h strerror.h memory.h inet_ntop.h select.h & | ||||
|   ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\url.obj: url.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h netrc.h base64.h ssluse.h if2ip.h & | ||||
|   transfer.h sendf.h progress.h strequal.h strerror.h escape.h strtok.h & | ||||
|   share.h content_encoding.h http_digest.h http_negotiate.h select.h multiif.h & | ||||
|   ftp.h dict.h telnet.h http.h file.h ldap.h url.h connect.h inet_ntop.h & | ||||
|   ./ca-bundle.h ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\dict.obj: dict.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h transfer.h sendf.h progress.h & | ||||
|   strequal.h dict.h ..\include\curl\mprintf.h | ||||
|  | ||||
| $(OBJ_DIR)\if2ip.obj: if2ip.c setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\speedcheck.obj: speedcheck.c setup.h config-win32.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & | ||||
|   speedcheck.h | ||||
|  | ||||
| $(OBJ_DIR)\ldap.obj: ldap.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h escape.h transfer.h & | ||||
|   strequal.h strtok.h ldap.h memory.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\ssluse.obj: ssluse.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h url.h inet_pton.h & | ||||
|   ssluse.h connect.h strequal.h select.h ..\include\curl\mprintf.h | ||||
|  | ||||
| $(OBJ_DIR)\version.obj: version.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & | ||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h ..\include\curl\mprintf.h | ||||
|  | ||||
| $(OBJ_DIR)\getenv.obj: getenv.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\escape.obj: escape.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memory.h & | ||||
|   ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\mprintf.obj: mprintf.c setup.h config-win32.h ..\include\curl\mprintf.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h memory.h ..\include\curl\curl.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\telnet.obj: telnet.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h transfer.h sendf.h telnet.h & | ||||
|   ..\include\curl\mprintf.h arpa_telnet.h memory.h select.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\netrc.obj: netrc.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h netrc.h strequal.h & | ||||
|   strtok.h memory.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\getinfo.obj: getinfo.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||
|   getinfo.h memory.h ssluse.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\transfer.obj: transfer.c setup.h config-win32.h strtoofft.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h strequal.h urldata.h & | ||||
|   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||
|   netrc.h content_encoding.h transfer.h sendf.h speedcheck.h progress.h & | ||||
|   http.h url.h getinfo.h ssluse.h http_digest.h http_ntlm.h & | ||||
|   http_negotiate.h share.h memory.h select.h ..\include\curl\mprintf.h & | ||||
|   memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\strequal.obj: strequal.c setup.h config-win32.h strequal.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h | ||||
|  | ||||
| $(OBJ_DIR)\easy.obj: easy.c setup.h config-win32.h strequal.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||
|   transfer.h ssluse.h url.h getinfo.h share.h memory.h progress.h & | ||||
|   easyif.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\security.obj: security.c setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\krb4.obj: krb4.c setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\memdebug.obj: memdebug.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\mprintf.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\http_chunks.obj: http_chunks.c setup.h config-win32.h urldata.h & | ||||
|   cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||
|   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & | ||||
|   content_encoding.h http.h memory.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\strtok.obj: strtok.c setup.h config-win32.h strtok.h | ||||
|  | ||||
| $(OBJ_DIR)\connect.obj: connect.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h if2ip.h strerror.h connect.h & | ||||
|   memory.h select.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\llist.obj: llist.c setup.h config-win32.h llist.h memory.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hash.obj: hash.c setup.h config-win32.h hash.h llist.h memory.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\multi.obj: multi.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||
|   transfer.h url.h connect.h progress.h memory.h easyif.h multiif.h & | ||||
|   memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\content_encoding.obj: content_encoding.c setup.h config-win32.h urldata.h & | ||||
|   cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h & | ||||
|   ..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sendf.h & | ||||
|   content_encoding.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\share.obj: share.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h ..\include\curl\multi.h & | ||||
|   ..\include\curl\curl.h urldata.h cookie.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h share.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\http_digest.obj: http_digest.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h strequal.h base64.h md5.h & | ||||
|   http_digest.h strtok.h url.h memory.h ..\include\curl\mprintf.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\md5.obj: md5.c setup.h config-win32.h md5.h | ||||
|  | ||||
| $(OBJ_DIR)\http_negotiate.obj: http_negotiate.c setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\http_ntlm.obj: http_ntlm.c setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\inet_pton.obj: inet_pton.c setup.h config-win32.h inet_pton.h | ||||
|  | ||||
| $(OBJ_DIR)\strtoofft.obj: strtoofft.c setup.h config-win32.h strtoofft.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h | ||||
|  | ||||
| $(OBJ_DIR)\strerror.obj: strerror.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h strerror.h urldata.h & | ||||
|   cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h & | ||||
|   ..\include\curl\mprintf.h | ||||
|  | ||||
| $(OBJ_DIR)\hostares.obj: hostares.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hostasyn.obj: hostasyn.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hostip4.obj: hostip4.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hostip6.obj: hostip6.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hostsyn.obj: hostsyn.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   ..\include\curl\mprintf.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\hostthre.obj: hostthre.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h & | ||||
|   http_chunks.h hostip.h hash.h llist.h sendf.h share.h strerror.h url.h & | ||||
|   ..\include\curl\mprintf.h inet_ntop.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\inet_ntop.obj: inet_ntop.c setup.h config-win32.h ..\include\curl\mprintf.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h inet_ntop.h | ||||
|  | ||||
| $(OBJ_DIR)\parsedate.obj: parsedate.c setup.h config-win32.h ..\include\curl\curl.h & | ||||
|   ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h ..\include\curl\curl.h | ||||
|  | ||||
| $(OBJ_DIR)\select.obj: select.c setup.h config-win32.h select.h | ||||
|  | ||||
| $(OBJ_DIR)\gtls.obj: gtls.c setup.h config-win32.h | ||||
|  | ||||
| $(OBJ_DIR)\sslgen.obj: sslgen.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h sslgen.h & | ||||
|   ssluse.h gtls.h sendf.h strequal.h url.h memory.h memdebug.h | ||||
|  | ||||
| $(OBJ_DIR)\tftp.obj: tftp.c setup.h config-win32.h urldata.h cookie.h & | ||||
|   ..\include\curl\curl.h ..\include\curl\curlver.h ..\include\curl\easy.h & | ||||
|   ..\include\curl\multi.h formdata.h http_chunks.h hostip.h hash.h llist.h & | ||||
|   transfer.h sendf.h tftp.h progress.h ..\include\curl\mprintf.h memory.h & | ||||
|   select.h memdebug.h | ||||
| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___ | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 1998 - 2004, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 1998 - 2005, 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 | ||||
| @@ -25,12 +25,12 @@ AUTOMAKE_OPTIONS = foreign nostdinc | ||||
| DSP = curllib.dsp | ||||
|  | ||||
| EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos $(DSP)    \ | ||||
|  curllib.dsw config-vms.h config-win32.h config-win32ce.h config-riscos.h     \ | ||||
|  curllib.dsw config-win32.h config-win32ce.h config-riscos.h     \ | ||||
|  config-mac.h config.h.in ca-bundle.crt README.encoding README.memoryleak     \ | ||||
|  README.ares README.curlx makefile.dj config.dj libcurl.framework.make	      \ | ||||
|  libcurl.plist libcurl.rc config-amigaos.h amigaos.c amigaos.h makefile.amiga \ | ||||
|  Makefile.netware nwlib.c libcurl.imp msvcproj.head msvcproj.foot	      \ | ||||
|  config-win32ce.h README.httpauth | ||||
|  config-win32ce.h README.httpauth Makefile.Watcom README.hostip | ||||
|  | ||||
| CLEANFILES = $(DSP) | ||||
|  | ||||
|   | ||||
| @@ -8,13 +8,15 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c	\ | ||||
|   content_encoding.c share.c http_digest.c md5.c http_negotiate.c	\ | ||||
|   http_ntlm.c inet_pton.c strtoofft.c strerror.c hostares.c hostasyn.c	\ | ||||
|   hostip4.c hostip6.c hostsyn.c hostthre.c inet_ntop.c parsedate.c	\ | ||||
|   select.c | ||||
|   select.c gtls.c sslgen.c tftp.c | ||||
|  | ||||
| HHEADERS = arpa_telnet.h netrc.h file.h timeval.h base64.h hostip.h	\ | ||||
|   progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h	\ | ||||
|   if2ip.h speedcheck.h urldata.h ldap.h ssluse.h escape.h telnet.h	\ | ||||
|   getinfo.h strequal.h security.h krb4.h memdebug.h inet_ntoa_r.h	\ | ||||
|   getinfo.h strequal.h krb4.h memdebug.h inet_ntoa_r.h \ | ||||
|   http_chunks.h strtok.h connect.h llist.h hash.h content_encoding.h	\ | ||||
|   share.h md5.h http_digest.h http_negotiate.h http_ntlm.h ca-bundle.h	\ | ||||
|   inet_pton.h strtoofft.h strerror.h inet_ntop.h curlx.h memory.h	\ | ||||
|   setup.h transfer.h select.h | ||||
|   setup.h transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h   \ | ||||
|   gtls.h tftp.h | ||||
|  | ||||
|   | ||||
| @@ -13,21 +13,23 @@ NDKBASE	= c:/novell | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your Zlib sources. | ||||
| #ZLIB_PATH = ../../zlib-1.2.1 | ||||
| ifndef ZLIB_PATH | ||||
| ZLIB_PATH = ../../zlib-1.2.3 | ||||
| endif | ||||
|  | ||||
| # Edit the path below to point to the base of your OpenSSL package. | ||||
| ifndef OPENSSL_PATH | ||||
| OPENSSL_PATH = ../../openssl-0.9.7d | ||||
| OPENSSL_PATH = ../../openssl-0.9.8 | ||||
| endif | ||||
|  | ||||
| ifndef INSTDIR | ||||
| INSTDIR	= ../curl-$(LIBCURL_VERSION_STR)-bin-nw | ||||
| INSTDIR	= ..$(DS)curl-$(LIBCURL_VERSION_STR)-bin-nw | ||||
| endif | ||||
|  | ||||
| # Edit the vars below to change NLM target settings. | ||||
| TARGET  = libcurl | ||||
| VERSION	= $(LIBCURL_VERSION) | ||||
| COPYR	= Copyright (c) 1996 - 2004, Daniel Stenberg, <daniel@haxx.se> | ||||
| COPYR	= Copyright (C) 1996 - 2005, Daniel Stenberg, <daniel@haxx.se> | ||||
| DESCR	= cURL libcurl $(LIBCURL_VERSION_STR) - http://curl.haxx.se | ||||
| MTSAFE	= YES | ||||
| STACK	= 64000 | ||||
| @@ -103,8 +105,6 @@ else | ||||
| endif | ||||
| endif | ||||
|  | ||||
| LDLIBS	= | ||||
|  | ||||
| NDK_ROOT = $(NDKBASE)/ndk | ||||
| SDK_CLIB = $(NDK_ROOT)/nwsdk | ||||
| SDK_LIBC = $(NDK_ROOT)/libc | ||||
| @@ -114,21 +114,26 @@ INCLUDES = -I. -I../include | ||||
|  | ||||
| ifdef WITH_ARES | ||||
| 	INCLUDES += -I../ares | ||||
| 	LIBCARES = ../ares/libcares.lib | ||||
| 	LDLIBS = ../ares/libcares.lib | ||||
| endif | ||||
| ifdef ZLIB_PATH | ||||
| 	INCLUDES += -I$(ZLIB_PATH) | ||||
| 	IMPORTS = @$(ZLIB_PATH)/nw/zlib.imp | ||||
| 	MODULES = libz.nlm | ||||
| endif | ||||
| ifdef SSL | ||||
| ifdef WITH_SSL | ||||
| 	INCLUDES += -I$(OPENSSL_PATH)/outinc_nw_libc -I$(OPENSSL_PATH)/outinc_nw_libc/openssl | ||||
| 	LIBSSL = $(OPENSSL_PATH)/out_nw_libc/crypto.lib $(OPENSSL_PATH)/out_nw_libc/ssl.lib | ||||
| 	LDLIBS += $(OPENSSL_PATH)/out_nw_libc/crypto.lib $(OPENSSL_PATH)/out_nw_libc/ssl.lib | ||||
| 	IMPORTS += GetProcessSwitchCount RunningProcess | ||||
| endif | ||||
| ifdef WITH_ZLIB | ||||
| 	INCLUDES += -I$(ZLIB_PATH) | ||||
| ifdef LINK_STATIC | ||||
| 	LDLIBS += $(ZLIB_PATH)/nw/libz.lib | ||||
| else | ||||
| 	IMPORTS += @$(ZLIB_PATH)/nw/libz.imp | ||||
| 	MODULES += libz.nlm | ||||
| endif | ||||
| endif | ||||
|  | ||||
| ifeq ($(LIBARCH),LIBC) | ||||
| 	INCLUDES += -I$(SDK_LIBC)/include -I$(SDK_LIBC)/include/nks | ||||
| 	INCLUDES += -I$(SDK_LIBC)/include/winsock | ||||
| 	# INCLUDES += -I$(SDK_LIBC)/include/winsock | ||||
| 	# INCLUDES += -I$(SDK_LDAP)/libc/inc | ||||
| 	CFLAGS += -D_POSIX_SOURCE | ||||
| 	# CFLAGS += -D__ANSIC__ | ||||
| @@ -152,13 +157,16 @@ endif | ||||
|  | ||||
| ifeq ($(findstring linux,$(OSTYPE)),linux) | ||||
| DL	= ' | ||||
| DS	= / | ||||
| #-include $(NDKBASE)/nlmconv/ncpfs.inc | ||||
| else | ||||
| DS	= \\ | ||||
| endif | ||||
|  | ||||
| # Makefile.inc provides the CSOURCES and HHEADERS defines | ||||
| include Makefile.inc | ||||
|  | ||||
| OBJS	:= $(patsubst %.c,$(OBJDIR)/%.o,$(strip $(CSOURCES))) $(LIBCARES) $(LIBSSL) | ||||
| OBJS	:= $(patsubst %.c,$(OBJDIR)/%.o,$(strip $(CSOURCES))) $(LDLIBS) | ||||
|  | ||||
| OBJL	= $(OBJS) $(OBJDIR)/nwlib.o | ||||
|  | ||||
| @@ -189,6 +197,9 @@ install: $(INSTDIR) all | ||||
| 	@$(CP) ../COPYING $(INSTDIR) | ||||
| 	@$(CP) ../README $(INSTDIR) | ||||
| 	@$(CP) ../RELEASE-NOTES $(INSTDIR) | ||||
| ifdef WITH_SSL | ||||
| 	@$(CP) ca-bundle.crt $(INSTDIR) | ||||
| endif | ||||
|  | ||||
| clean: | ||||
| 	-$(RM) config.h ca-bundle.h | ||||
| @@ -274,11 +285,8 @@ ifdef IMPORTS | ||||
| 	@echo $(DL)import $(IMPORTS)$(DL) >> $@ | ||||
| endif | ||||
| ifeq ($(LD),nlmconv) | ||||
| ifdef WITH_ARES | ||||
| 	@echo $(DL)input $(LIBCARES)$(DL) >> $@ | ||||
| endif | ||||
| ifdef SSL | ||||
| 	@echo $(DL)input $(LIBSSL)$(DL) >> $@ | ||||
| ifdef LDLIBS | ||||
| 	@echo $(DL)input $(LDLIBS)$(DL) >> $@ | ||||
| endif | ||||
| 	@echo $(DL)input $(OBJL)$(DL) >> $@ | ||||
| 	@echo $(DL)input $(PRELUDE)$(DL) >> $@ | ||||
| @@ -293,7 +301,7 @@ config.h: Makefile.netware | ||||
| 	@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 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_ASSERT_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_DLFCN_H 1$(DL) >> $@ | ||||
| @@ -336,6 +344,21 @@ config.h: Makefile.netware | ||||
| 	@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_IN6_ADDR 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@ | ||||
| 	@echo $(DL)#define SIZEOF_STRUCT_IN_ADDR 4$(DL) >> $@ | ||||
| ifdef DISABLE_LDAP | ||||
| 	@echo $(DL)#define CURL_DISABLE_LDAP 1$(DL) >> $@ | ||||
| else | ||||
| 	@echo $(DL)#define DL_LDAP_FILE "lldapsdk.nlm"$(DL) >> $@ | ||||
| endif | ||||
| ifdef ENABLE_IPV6 | ||||
| 	@echo $(DL)#define ENABLE_IPV6 1$(DL) >> $@ | ||||
| endif | ||||
| ifdef NW_WINSOCK | ||||
| 	@echo $(DL)#define HAVE_CLOSESOCKET 1$(DL) >> $@ | ||||
| else | ||||
| @@ -347,11 +370,11 @@ endif | ||||
| ifdef WITH_ARES | ||||
| 	@echo $(DL)#define USE_ARES 1$(DL) >> $@ | ||||
| endif | ||||
| ifdef ZLIB_PATH | ||||
| ifdef WITH_ZLIB | ||||
| 	@echo $(DL)#define HAVE_ZLIB_H 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_LIBZ 1$(DL) >> $@ | ||||
| endif | ||||
| ifdef SSL | ||||
| ifdef WITH_SSL | ||||
| 	@echo $(DL)#define USE_SSLEAY 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define USE_OPENSSL 1$(DL) >> $@ | ||||
| 	@echo $(DL)#define HAVE_OPENSSL_X509_H 1$(DL) >> $@ | ||||
|   | ||||
| @@ -12,7 +12,7 @@ objs =	o.base64 o.connect o.cookie o.dict \ | ||||
| 	o.memdebug o.mprintf o.netrc o.parsedate o.progress \ | ||||
| 	o.security o.select o.sendf o.speedcheck o.ssluse \ | ||||
| 	o.strequal o.strtok o.telnet o.timeval \ | ||||
| 	o.transfer o.url o.version o.strtoofft | ||||
| 	o.transfer o.url o.version o.strtoofft o.sslgen o.gtls | ||||
|  | ||||
| # Compile options: | ||||
| linkopts	= -o libcurl | ||||
| @@ -119,6 +119,12 @@ o.sendf:	c.sendf | ||||
| o.speedcheck:	c.speedcheck | ||||
| 		gcc $(compileropts) -c -o speedcheck.o c.speedcheck | ||||
|  | ||||
| o.gtls:	c.gtls | ||||
| 		gcc $(compileropts) -c -o gtls.o c.gtls | ||||
|  | ||||
| o.sslgen:	c.sslgen | ||||
| 		gcc $(compileropts) -c -o sslgen.o c.sslgen | ||||
|  | ||||
| o.ssluse:	c.ssluse | ||||
| 		gcc $(compileropts) -c -o ssluse.o c.ssluse | ||||
|  | ||||
|   | ||||
							
								
								
									
										325
									
								
								lib/Makefile.vc6
									
									
									
									
									
								
							
							
						
						
									
										325
									
								
								lib/Makefile.vc6
									
									
									
									
									
								
							| @@ -35,13 +35,31 @@ IMPLIB_NAME       = libcurl_imp | ||||
| IMPLIB_NAME_DEBUG = libcurld_imp | ||||
|  | ||||
| !IFNDEF OPENSSL_PATH | ||||
| OPENSSL_PATH   = ../../openssl-0.9.7d | ||||
| OPENSSL_PATH   = ../../openssl-0.9.7e | ||||
| !ENDIF | ||||
|  | ||||
| !IFNDEF ZLIB_PATH | ||||
| ZLIB_PATH  = ../../zlib-1.2.1 | ||||
| !ENDIF | ||||
|  | ||||
| # USE_WINDOWS_SSPI uses windows libraries to allow NTLM authentication | ||||
| # without an openssl installation and offers the ability to authenticate | ||||
| # using the "current logged in user".  It does however require that the | ||||
| # Windows SDK be installed. | ||||
| # | ||||
| # If, for some reason the Windows SDK is installed but not installed | ||||
| # in the default location, you can specify WINDOWS_SDK_PATH. | ||||
| # It can be downloaded from: | ||||
| # http://www.microsoft.com/msdownload/platformsdk/sdkupdate/ | ||||
|  | ||||
| # USE_WINDOWS_SSPI = 1 | ||||
|  | ||||
| !IFDEF WINDOWS_SSPI | ||||
| !IFNDEF WINDOWS_SDK_PATH | ||||
| WINDOWS_SDK_PATH = "C:\Program Files\Microsoft SDK" | ||||
| !ENDIF | ||||
| !ENDIF | ||||
|  | ||||
| # Use the high resolution time by default.  Comment this out to use low | ||||
| # resolution time and not require winmm.lib | ||||
| USEMM_LIBS = YES | ||||
| @@ -54,10 +72,13 @@ CCDEBUG    = cl.exe /MDd /Od /Gm /Zi /D_DEBUG /GZ | ||||
| CFLAGSSSL  = /DUSE_SSLEAY /I "$(OPENSSL_PATH)/inc32" /I "$(OPENSSL_PATH)/inc32/openssl" | ||||
| CFLAGSZLIB = /DHAVE_ZLIB_H /DHAVE_ZLIB /DHAVE_LIBZ /I "$(ZLIB_PATH)" | ||||
| CFLAGS     = /I. /I../include /nologo /W3 /GX /DWIN32 /YX /FD /c /DBUILDING_LIBCURL | ||||
| CFLAGSLIB  = /DCURL_STATICLIB | ||||
| LNKDLL     = link.exe /DLL | ||||
| LNKLIB     = link.exe /lib | ||||
| LFLAGS     = /nologo | ||||
| SSLLIBS    = libeay32.lib ssleay32.lib | ||||
| ZLIBLIBSDLL= zdll.lib | ||||
| ZLIBLIBS   = zlib.lib | ||||
| !IFDEF USEMM_LIBS | ||||
| WINLIBS    = wsock32.lib winmm.lib | ||||
| !ELSE | ||||
| @@ -67,14 +88,19 @@ CFLAGS     = $(CFLAGS) /DWITHOUT_MM_LIB | ||||
| #  RSAglue.lib was formerly needed in the SSLLIBS | ||||
| CFGSET     = FALSE | ||||
|  | ||||
| !IFDEF WINDOWS_SSPI | ||||
| CFLAGS = $(CFLAGS) /DUSE_WINDOWS_SSPI /I$(WINDOWS_SDK_PATH)\include | ||||
| LFLAGS = $(LFLAGS) $(WINDOWS_SDK_PATH)\lib\secur32.lib | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release | ||||
|  | ||||
| !IF "$(CFG)" == "release" | ||||
| TARGET = $(LIB_NAME).lib | ||||
| DIROBJ = .\$(CFG) | ||||
| LNK    = $(LNKLIB) /out:$(TARGET) | ||||
| CC     = $(CCNODBG) | ||||
| DIROBJ = $(CFG) | ||||
| LNK    = $(LNKLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC     = $(CCNODBG) $(CFLAGSLIB) | ||||
| CFGSET = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| @@ -83,10 +109,10 @@ CFGSET = TRUE | ||||
|  | ||||
| !IF "$(CFG)" == "release-zlib" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = .\$(CFG) | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(LFLAGSZLIB) /out:$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSZLIB) | ||||
| LNK      = $(LNKLIB) $(ZLIBLIBS) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| @@ -95,8 +121,8 @@ CFGSET   = TRUE | ||||
|  | ||||
| !IF "$(CFG)" == "release-dll" | ||||
| TARGET = $(LIB_NAME).dll | ||||
| DIROBJ = .\$(CFG) | ||||
| LNK    = $(LNKDLL) $(WINLIBS) /out:$(TARGET) /IMPLIB:$(IMPLIB_NAME).lib | ||||
| DIROBJ = $(CFG) | ||||
| LNK    = $(LNKDLL) $(WINLIBS) /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | ||||
| CC     = $(CCNODBG) | ||||
| CFGSET = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| @@ -107,10 +133,10 @@ RESOURCE = $(DIROBJ)\libcurl.res | ||||
|  | ||||
| !IF "$(CFG)" == "release-ssl" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = .\$(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)/out32" | ||||
| LNK      = $(LNKLIB) $(LFLAGSSSL) /out:$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32" | ||||
| LNK      = $(LNKLIB) $(LFLAGSSSL) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| @@ -119,47 +145,173 @@ CFGSET   = TRUE | ||||
|  | ||||
| !IF "$(CFG)" == "release-ssl-dll" | ||||
| TARGET   = $(LIB_NAME).dll | ||||
| DIROBJ   = .\$(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)/out32dll" | ||||
| LNK      = $(LNKDLL) $(SSLLIBS) $(WINLIBS) $(LFLAGSSSL) /out:$(TARGET) /IMPLIB:$(IMPLIB_NAME).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKDLL) $(WINLIBS) /out:$(DIROBJ)\$(TARGET) $(SSLLIBS) $(LFLAGSSSL) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-ssl-zlib | ||||
|  | ||||
| !IF "$(CFG)" == "release-ssl-zlib" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = .\$(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)/out32" | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32" | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(LFLAGSSSL) $(LFLAGSZLIB) /out:$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) $(CFLAGSZLIB) | ||||
| LNK      = $(LNKLIB) $(LFLAGSSSL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-libcurl-ssl-dll | ||||
| !IF "$(CFG)" == "release-libcurl-ssl-dll" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = .\$(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)/out32dll" | ||||
| LNK      = $(LNKLIB) $(SSLLIBS) $(LFLAGSSSL) /out:$(TARGET) | ||||
| # release-dll-ssl-dll | ||||
|  | ||||
| !IF "$(CFG)" == "release-dll-ssl-dll" | ||||
| TARGET   = $(LIB_NAME).dll | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(SSLLIBS) $(LFLAGSSSL) /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "release-zlib-dll" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(WINLIBS) $(ZLIBLIBSDLL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-ssl-dll-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "release-ssl-dll-zlib-dll" | ||||
| TARGET   = $(LIB_NAME).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKLIB) $(WINLIBS) $(SSLLIBS) $(ZLIBLIBSDLL) $(LFLAGSSSL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-dll-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "release-dll-zlib-dll" | ||||
| TARGET   = $(LIB_NAME).dll | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(ZLIBLIBSDLL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | ||||
| CC       = $(CCNODBG) $(CFLAGSZLIB) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # release-dll-ssl-dll-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "release-dll-ssl-dll-zlib-dll" | ||||
| TARGET   = $(LIB_NAME).dll | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(SSLLIBS) $(ZLIBLIBSDLL) $(LFLAGSSSL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME).lib | ||||
| CC       = $(CCNODBG) $(CFLAGSSSL) $(CFLAGSZLIB) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug | ||||
|  | ||||
| !IF "$(CFG)" == "debug" | ||||
| TARGET = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ = .\$(CFG) | ||||
| LNK    = $(LNKLIB) /out:$(TARGET) | ||||
| CC     = $(CCDEBUG) | ||||
| DIROBJ = $(CFG) | ||||
| LNK    = $(LNKLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC     = $(CCDEBUG) $(CFLAGSLIB) | ||||
| CFGSET = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl | ||||
|  | ||||
| !IF "$(CFG)" == "debug-ssl" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32" | ||||
| LNK      = $(LNKLIB) $(SSLLIBS) $(LFLAGSSSL) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-zlib | ||||
|  | ||||
| !IF "$(CFG)" == "debug-zlib" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(ZLIBLIBS) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl-dll | ||||
|  | ||||
| !IF "$(CFG)" == "debug-ssl-dll" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = /LIBPATH:$(OPENSSL_PATH)\out32dll | ||||
| LNK      = $(LNKLIB) $(WINLIBS) $(SSLLIBS) $(LFLAGSSSL) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl-zlib | ||||
|  | ||||
| !IF "$(CFG)" == "debug-ssl-zlib" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32" | ||||
| LNK      = $(LNKLIB) $(SSLLIBS) $(ZLIBLIBS) $(LFLAGSSSL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "debug-zlib-dll" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(WINLIBS) $(ZLIBLIBSDLL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl-dll-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "debug-ssl-dll-zlib-dll" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKLIB) $(WINLIBS) $(SSLLIBS) $(ZLIBLIBSDLL) $(LFLAGSSSL) $(LFLAGSZLIB) /out:$(DIROBJ)\$(TARGET) | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) $(CFLAGSZLIB) $(CFLAGSLIB) | ||||
| CFGSET   = TRUE | ||||
| !ENDIF | ||||
|  | ||||
| @@ -168,44 +320,49 @@ CFGSET = TRUE | ||||
|  | ||||
| !IF "$(CFG)" == "debug-dll" | ||||
| TARGET = $(LIB_NAME_DEBUG).dll | ||||
| DIROBJ = .\$(CFG) | ||||
| LNK    = $(LNKDLL) $(WINLIBS) /DEBUG /out:$(TARGET) /IMPLIB:$(IMPLIB_NAME_DEBUG).lib /PDB:$(IMPLIB_NAME_DEBUG).pdb | ||||
| DIROBJ = $(CFG) | ||||
| LNK    = $(LNKDLL) $(WINLIBS) /DEBUG /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).lib /PDB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).pdb | ||||
| CC     = $(CCDEBUG) | ||||
| CFGSET = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl | ||||
| #todo | ||||
| !IF "$(CFG)" == "debug-ssl" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = .\$(CFG) | ||||
| LNK      = $(LNKLIB) $(LFLAGSSSL) /out:$(TARGET) | ||||
| # debug-dll-ssl-dll | ||||
|  | ||||
| !IF "$(CFG)" == "debug-dll-ssl-dll" | ||||
| TARGET   = $(LIB_NAME_DEBUG).dll | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(SSLLIBS) $(LFLAGSSSL) /DEBUG /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).lib /PDB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).pdb | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-zlib | ||||
| !IF "$(CFG)" == "debug-zlib" | ||||
| TARGET   = $(LIB_NAME_DEBUG).lib | ||||
| DIROBJ   = .\$(CFG) | ||||
| # debug-dll-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "debug-dll-zlib-dll" | ||||
| TARGET   = $(LIB_NAME_DEBUG).dll | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LNK      = $(LNKLIB) $(LFLAGSZLIB) /out:$(TARGET) | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(ZLIBLIBSDLL) $(LFLAGSZLIB) /DEBUG /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).lib /PDB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).pdb | ||||
| CC       = $(CCDEBUG) $(CFLAGSZLIB) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
|  | ||||
| ###################### | ||||
| # debug-ssl-dll | ||||
| # debug-dll-ssl-dll-zlib-dll | ||||
|  | ||||
| !IF "$(CFG)" == "debug-ssl-dll" | ||||
| !IF "$(CFG)" == "debug-dll-ssl-dll-zlib-dll" | ||||
| TARGET   = $(LIB_NAME_DEBUG).dll | ||||
| DIROBJ   = .\$(CFG) | ||||
| LFLAGSSSL = /LIBPATH:$(OPENSSL_PATH)/out32dll | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(LFLAGSSSL) /DEBUG /out:$(TARGET) /IMPLIB:$(IMPLIB_NAME_DEBUG).lib /PDB:$(IMPLIB_NAME_DEBUG).pdb | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) | ||||
| DIROBJ   = $(CFG) | ||||
| LFLAGSZLIB = "/LIBPATH:$(ZLIB_PATH)" | ||||
| LFLAGSSSL = "/LIBPATH:$(OPENSSL_PATH)\out32dll" | ||||
| LNK      = $(LNKDLL) $(WINLIBS) $(SSLLIBS) $(ZLIBLIBSDLL) $(LFLAGSSSL) $(LFLAGSZLIB) /DEBUG /out:$(DIROBJ)\$(TARGET) /IMPLIB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).lib /PDB:$(DIROBJ)\$(IMPLIB_NAME_DEBUG).pdb | ||||
| CC       = $(CCDEBUG) $(CFLAGSSSL) $(CFLAGSZLIB) | ||||
| CFGSET   = TRUE | ||||
| RESOURCE = $(DIROBJ)\libcurl.res | ||||
| !ENDIF | ||||
| @@ -213,26 +370,50 @@ RESOURCE = $(DIROBJ)\libcurl.res | ||||
| ####################### | ||||
| # Usage | ||||
| # | ||||
| !IF "$(CFGSET)" == "FALSE" | ||||
| !IF "$(CFGSET)" == "FALSE" && "$(CFG)" != "" | ||||
| !MESSAGE Usage: nmake /f makefile.vc6 CFG=<config> <target> | ||||
| !MESSAGE where <config> is one of: | ||||
| !MESSAGE   release                      - release static library | ||||
| !MESSAGE   release-dll      - release dll | ||||
| !MESSAGE   release-zlib     - release static library with zlib | ||||
| !MESSAGE   release-ssl                  - release static library with ssl | ||||
| !MESSAGE   release-zlib                 - release static library with zlib | ||||
| !MESSAGE   release-ssl-zlib             - release static library with ssl and zlib | ||||
| !MESSAGE   release-ssl-dll  - release dll library with ssl | ||||
| !MESSAGE   release-libcurl-ssl-dll - static libcurl with shared ssl | ||||
| !MESSAGE   release-ssl-dll              - release static library with dynamic ssl | ||||
| !MESSAGE   release-zlib-dll             - release static library with dynamic zlib | ||||
| !MESSAGE   release-ssl-dll-zlib-dll     - release static library with dynamic ssl and dynamic zlib | ||||
| !MESSAGE   release-dll                  - release dynamic library | ||||
| !MESSAGE   release-dll-ssl-dll          - release dynamic library with dynamic ssl | ||||
| !MESSAGE   release-dll-zlib-dll         - release dynamic library with dynamic zlib | ||||
| !MESSAGE   release-dll-ssl-dll-zlib-dll - release dynamic library with dynamic ssl and dynamic zlib | ||||
| !MESSAGE   debug                        - debug static library | ||||
| !MESSAGE   debug-dll        - debug dll | ||||
| !MESSAGE   debug-zlib       - debug static library with zlib | ||||
| !MESSAGE   debug-ssl                    - debug static library with ssl | ||||
| !MESSAGE   debug-ssl-dll    - debug dll library with ssl | ||||
| !MESSAGE   debug-zlib                   - debug static library with zlib | ||||
| !MESSAGE   debug-ssl-zlib               - debug static library with ssl and zlib | ||||
| !MESSAGE   debug-ssl-dll                - debug static library with dynamic ssl | ||||
| !MESSAGE   debug-zlib-dll               - debug static library with dynamic zlib | ||||
| !MESSAGE   debug-ssl-dll-zlib-dll       - debug static library with dynamic ssl and dynamic zlib | ||||
| !MESSAGE   debug-dll                    - debug dynamic library | ||||
| !MESSAGE   debug-dll-ssl-dll            - debug dynamic library with dynamic ssl | ||||
| !MESSAGE   debug-dll-zlib-dll           - debug dynamic library with dynamic zlib1 | ||||
| !MESSAGE   debug-dll-ssl-dll-zlib-dll   - debug dynamic library with dynamic ssl and dynamic zlib | ||||
| !MESSAGE <target> can be left blank in which case all is assumed | ||||
| !ERROR please choose a valid configuration "$(CFG)" | ||||
| !ENDIF | ||||
|  | ||||
| ####################### | ||||
| # Only the clean target can be used if a config was not provided. | ||||
| # | ||||
| !IF "$(CFGSET)" == "FALSE" | ||||
| clean: | ||||
| 	@-erase /s *.dll 2> NUL | ||||
| 	@-erase /s *.exp 2> NUL | ||||
| 	@-erase /s *.idb 2> NUL | ||||
| 	@-erase /s *.lib 2> NUL | ||||
| 	@-erase /s *.obj 2> NUL | ||||
| 	@-erase /s *.pch 2> NUL | ||||
| 	@-erase /s *.pdb 2> NUL | ||||
| 	@-erase /s *.res 2> NUL | ||||
| !ELSE | ||||
| # A config was provided, so the library can be built. | ||||
| # | ||||
| X_OBJS= \ | ||||
| 	$(DIROBJ)\base64.obj \ | ||||
| @@ -248,6 +429,7 @@ X_OBJS= \ | ||||
| 	$(DIROBJ)\telnet.obj \ | ||||
| 	$(DIROBJ)\parsedate.obj \ | ||||
| 	$(DIROBJ)\getenv.obj \ | ||||
| 	$(DIROBJ)\gtls.obj \ | ||||
| 	$(DIROBJ)\inet_pton.obj \ | ||||
| 	$(DIROBJ)\hostip.obj \ | ||||
| 	$(DIROBJ)\hostasyn.obj \ | ||||
| @@ -263,6 +445,7 @@ X_OBJS= \ | ||||
| 	$(DIROBJ)\progress.obj \ | ||||
| 	$(DIROBJ)\sendf.obj \ | ||||
| 	$(DIROBJ)\speedcheck.obj \ | ||||
| 	$(DIROBJ)\sslgen.obj \ | ||||
| 	$(DIROBJ)\ssluse.obj \ | ||||
| 	$(DIROBJ)\timeval.obj \ | ||||
| 	$(DIROBJ)\url.obj \ | ||||
| @@ -286,13 +469,21 @@ X_OBJS= \ | ||||
| 	$(DIROBJ)\strerror.obj \ | ||||
| 	$(DIROBJ)\select.obj \ | ||||
| 	$(DIROBJ)\content_encoding.obj \ | ||||
| 	$(DIROBJ)\tftp.obj \ | ||||
| 	$(RESOURCE) | ||||
|  | ||||
| all : $(TARGET) | ||||
|  | ||||
|  | ||||
| $(TARGET): $(X_OBJS) | ||||
| 	$(LNK) $(LFLAGS) $(X_OBJS) | ||||
| 	-xcopy $(DIROBJ)\$(LIB_NAME).dll       . /y | ||||
| 	-xcopy $(DIROBJ)\$(LIB_NAME).lib       . /y | ||||
| 	-xcopy $(DIROBJ)\$(LIB_NAME_DEBUG).dll . /y | ||||
| 	-xcopy $(DIROBJ)\$(LIB_NAME_DEBUG).lib . /y | ||||
| 	-xcopy $(DIROBJ)\$(IMPLIB_NAME).lib    . /y | ||||
| 	-xcopy $(DIROBJ)\$(IMPLIB_NAME_DEBUG).lib . /y | ||||
| 	-xcopy $(DIROBJ)\*.exp                 . /y | ||||
| 	-xcopy $(DIROBJ)\*.pdb                 . /y | ||||
|  | ||||
| $(X_OBJS): $(DIROBJ) | ||||
|  | ||||
| @@ -305,18 +496,14 @@ $(DIROBJ): | ||||
| 	$(CC) $(CFLAGS) /Fo"$@"  $< | ||||
|  | ||||
| debug-dll\libcurl.res \ | ||||
| debug-ssl-dll\libcurl.res \ | ||||
| release-libcurl-ssl-dll\libcurl.res: libcurl.rc | ||||
| debug-dll-ssl-dll\libcurl.res \ | ||||
| debug-dll-zlib-dll\libcurl.res \ | ||||
| debug-dll-ssl-dll-zlib-dll\libcurl.res: libcurl.rc | ||||
| 	rc /dCURLDEBUG=1 /Fo $@ libcurl.rc | ||||
|  | ||||
| release-dll\libcurl.res \ | ||||
| release-ssl-dll\libcurl.res \ | ||||
| release-libcurl-ssl-dll\libcurl.res: libcurl.rc | ||||
| release-dll-ssl-dll\libcurl.res \ | ||||
| release-dll-zlib-dll\libcurl.res \ | ||||
| release-dll-ssl-dll-zlib-dll\libcurl.res: libcurl.rc | ||||
| 	rc /dCURLDEBUG=0 /Fo $@ libcurl.rc | ||||
|  | ||||
| clean: | ||||
| 	-@erase $(DIROBJ)\*.obj | ||||
| 	-@erase $(DIROBJ)\*.res | ||||
| 	-@erase vc60.idb | ||||
| 	-@erase vc60.pch | ||||
|  | ||||
| !ENDIF  # End of case where a config was provided. | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user