Compare commits
1666 Commits
pre-host-c
...
curl-7_10_
Author | SHA1 | Date | |
---|---|---|---|
![]() |
5c2df3e1a4 | ||
![]() |
6fc55467f4 | ||
![]() |
a147a07956 | ||
![]() |
a10581d459 | ||
![]() |
cc2d6942bb | ||
![]() |
3974c02bb1 | ||
![]() |
09b5ddaea5 | ||
![]() |
acbcd68d89 | ||
![]() |
4281470fca | ||
![]() |
68a4aa6773 | ||
![]() |
905b160097 | ||
![]() |
52596c339b | ||
![]() |
73500267ee | ||
![]() |
e6011e33a6 | ||
![]() |
3454319c17 | ||
![]() |
02c78ecf81 | ||
![]() |
caca034302 | ||
![]() |
fb366ed35f | ||
![]() |
b352ffca15 | ||
![]() |
2d94856efd | ||
![]() |
ae66bd1284 | ||
![]() |
89d9d4e6c8 | ||
![]() |
fe60fc4730 | ||
![]() |
46690d5e1c | ||
![]() |
beaea8cb25 | ||
![]() |
409ec90c85 | ||
![]() |
4d423eeabe | ||
![]() |
019e612225 | ||
![]() |
6550d271f0 | ||
![]() |
c46da65263 | ||
![]() |
b46745759b | ||
![]() |
9687571a84 | ||
![]() |
c13236de25 | ||
![]() |
8ffbb6acd4 | ||
![]() |
a3e5d81765 | ||
![]() |
e2aecfe80f | ||
![]() |
a3c1248214 | ||
![]() |
b933639222 | ||
![]() |
27619fc450 | ||
![]() |
96fecba190 | ||
![]() |
50257d4f50 | ||
![]() |
3eb4ae031c | ||
![]() |
6a4ec3be81 | ||
![]() |
cc9ac6ad14 | ||
![]() |
644990a835 | ||
![]() |
d3b81ea3f7 | ||
![]() |
3660f67534 | ||
![]() |
203cc4a5c3 | ||
![]() |
c7be232fee | ||
![]() |
2617b379be | ||
![]() |
84ed5e755a | ||
![]() |
2f17615790 | ||
![]() |
acfa131c8c | ||
![]() |
793d0e27e1 | ||
![]() |
fdf0c443c3 | ||
![]() |
1b39b53321 | ||
![]() |
1679993e3b | ||
![]() |
4c831f8b68 | ||
![]() |
7a19923afa | ||
![]() |
3e122a765d | ||
![]() |
d873ba8c9f | ||
![]() |
8093338f39 | ||
![]() |
07660eea1e | ||
![]() |
a2b2d4cd5c | ||
![]() |
96e217b496 | ||
![]() |
2dd1518d63 | ||
![]() |
168703b7bf | ||
![]() |
0f2d680f1f | ||
![]() |
b7930b6ebd | ||
![]() |
8fa43b469a | ||
![]() |
894e52f61a | ||
![]() |
3c294691aa | ||
![]() |
acbf932861 | ||
![]() |
26f5c53be8 | ||
![]() |
8dd069604c | ||
![]() |
5dadbd094e | ||
![]() |
514a8739b6 | ||
![]() |
12e78a082e | ||
![]() |
9273096a8a | ||
![]() |
686c6133f8 | ||
![]() |
1d1276cc3a | ||
![]() |
d987676ef0 | ||
![]() |
6e4658c89d | ||
![]() |
b7cbcf7434 | ||
![]() |
e347d06a49 | ||
![]() |
2077e9365a | ||
![]() |
6e3adc9b14 | ||
![]() |
7954eee639 | ||
![]() |
f9f1f0e316 | ||
![]() |
a9afe6aa84 | ||
![]() |
6d36796135 | ||
![]() |
9e81fd5703 | ||
![]() |
609059b6ec | ||
![]() |
6af73f417a | ||
![]() |
32468a0072 | ||
![]() |
6800c45104 | ||
![]() |
0d8c754ffd | ||
![]() |
1b80276496 | ||
![]() |
bf9a138276 | ||
![]() |
b3f9c636b9 | ||
![]() |
18975d44a6 | ||
![]() |
b201db5cec | ||
![]() |
bbe23945e4 | ||
![]() |
bbdc0394ff | ||
![]() |
38a9b14965 | ||
![]() |
77ba0d3686 | ||
![]() |
065c8d7a95 | ||
![]() |
c704d1545c | ||
![]() |
62b65a5f20 | ||
![]() |
665a7a3848 | ||
![]() |
256b9f31e1 | ||
![]() |
a3037e1173 | ||
![]() |
f3e7a5d755 | ||
![]() |
5f0cba7775 | ||
![]() |
673759fe7e | ||
![]() |
b73612392d | ||
![]() |
f85935f0f9 | ||
![]() |
1e7e53c87e | ||
![]() |
b9fdf3cc3b | ||
![]() |
c462601362 | ||
![]() |
859877dcfc | ||
![]() |
c04ce95106 | ||
![]() |
98ee12bc35 | ||
![]() |
fdda786fa2 | ||
![]() |
831be4f4dd | ||
![]() |
41ae97e710 | ||
![]() |
f72ba7f79d | ||
![]() |
296046510b | ||
![]() |
db9f87f697 | ||
![]() |
3270ea55dd | ||
![]() |
a358ac24f4 | ||
![]() |
8bedd43b28 | ||
![]() |
9ea2087ede | ||
![]() |
9f7c634133 | ||
![]() |
da20d68a12 | ||
![]() |
d3e512c738 | ||
![]() |
339f84fe1f | ||
![]() |
2d41b735ec | ||
![]() |
e3b4dd08ff | ||
![]() |
6809a906bb | ||
![]() |
1c35cbcc07 | ||
![]() |
5f8989a436 | ||
![]() |
aa7b0648ff | ||
![]() |
2fbe61960f | ||
![]() |
bdb5e5a250 | ||
![]() |
48a580e609 | ||
![]() |
1361fc69b9 | ||
![]() |
93352e56d8 | ||
![]() |
d9246ff24d | ||
![]() |
9301bc3444 | ||
![]() |
76352c4e2d | ||
![]() |
428f41bd12 | ||
![]() |
99c32e460f | ||
![]() |
83f249cf65 | ||
![]() |
2c2baa93ea | ||
![]() |
f0278ca114 | ||
![]() |
297b1b5013 | ||
![]() |
e9f63bf4e8 | ||
![]() |
556ce1c6a1 | ||
![]() |
cc4ff62681 | ||
![]() |
0423fd9b55 | ||
![]() |
789ab20bf7 | ||
![]() |
b47462bd68 | ||
![]() |
1a94fee42d | ||
![]() |
a91ce6a5d6 | ||
![]() |
981ffd9fce | ||
![]() |
e76c960624 | ||
![]() |
416c92cc6f | ||
![]() |
fb731eb3e7 | ||
![]() |
6f2a4d290f | ||
![]() |
cefc8ba938 | ||
![]() |
d0bd644eef | ||
![]() |
071c95128e | ||
![]() |
1a192c489b | ||
![]() |
56014e74a0 | ||
![]() |
172271498d | ||
![]() |
f2882cb88c | ||
![]() |
152f1fee40 | ||
![]() |
968234e6ae | ||
![]() |
5e133e2dff | ||
![]() |
0049c09fc3 | ||
![]() |
a2a63c27f4 | ||
![]() |
c50a601f1a | ||
![]() |
bc0fd6db71 | ||
![]() |
52b631fade | ||
![]() |
2f0bc9d1f7 | ||
![]() |
5ef6520d4e | ||
![]() |
2c1925161e | ||
![]() |
0529b349d5 | ||
![]() |
b4620364a2 | ||
![]() |
634aef3895 | ||
![]() |
06c86d1a8c | ||
![]() |
79749f8eb4 | ||
![]() |
b036986b3e | ||
![]() |
938f1d1da7 | ||
![]() |
58b6b3df06 | ||
![]() |
f9c3347f7c | ||
![]() |
5b72eb0b03 | ||
![]() |
6dd4c13bc0 | ||
![]() |
e4e7db551f | ||
![]() |
ebfde8da56 | ||
![]() |
756bc0f4b7 | ||
![]() |
269d491b6a | ||
![]() |
449e5bc2ad | ||
![]() |
8736c11d84 | ||
![]() |
45fc760985 | ||
![]() |
7968e3c2de | ||
![]() |
964a41c75c | ||
![]() |
5931d53637 | ||
![]() |
3ed3ae5bcf | ||
![]() |
6519cc70c5 | ||
![]() |
505a4f27fa | ||
![]() |
79144eba99 | ||
![]() |
26e17d89c9 | ||
![]() |
4322c1106f | ||
![]() |
73071dfd4f | ||
![]() |
b7c14b3c27 | ||
![]() |
3130b44535 | ||
![]() |
a2bd73334f | ||
![]() |
1a393f5625 | ||
![]() |
d4951e837e | ||
![]() |
26f6365e93 | ||
![]() |
3a552b1e63 | ||
![]() |
69eb1790da | ||
![]() |
a1af6f3614 | ||
![]() |
3aced61465 | ||
![]() |
6f02ddfce8 | ||
![]() |
c2faa39b62 | ||
![]() |
2d3734b8b5 | ||
![]() |
ed908b7f89 | ||
![]() |
f7d795a364 | ||
![]() |
8919b39d54 | ||
![]() |
84cedc094e | ||
![]() |
3b2b2496d7 | ||
![]() |
445684c409 | ||
![]() |
898e067ccc | ||
![]() |
12859e345f | ||
![]() |
89f4af695e | ||
![]() |
308bc9d919 | ||
![]() |
db566c54ae | ||
![]() |
81d403e207 | ||
![]() |
2bd71d70ff | ||
![]() |
1eef6f44ba | ||
![]() |
204f03912f | ||
![]() |
f8c3b3aa18 | ||
![]() |
d4df981463 | ||
![]() |
497c6d516d | ||
![]() |
8288862b7e | ||
![]() |
9aae16c236 | ||
![]() |
80c194a70a | ||
![]() |
c832b2db5b | ||
![]() |
27018882ec | ||
![]() |
caf6e9c540 | ||
![]() |
e727fb82f2 | ||
![]() |
c78df56801 | ||
![]() |
d13202f43b | ||
![]() |
9d139a6b35 | ||
![]() |
d2abe44e6f | ||
![]() |
bc67228576 | ||
![]() |
ecf32c964a | ||
![]() |
e58f30b82a | ||
![]() |
654e3f1101 | ||
![]() |
86689dc524 | ||
![]() |
5f62a0c1ca | ||
![]() |
ad1bf0f389 | ||
![]() |
9c7703ace1 | ||
![]() |
4a8155b53c | ||
![]() |
80d6d5c5c4 | ||
![]() |
c624be8388 | ||
![]() |
09df1cd41e | ||
![]() |
52c5b57200 | ||
![]() |
5ea04a852e | ||
![]() |
a2eef05198 | ||
![]() |
55f75af353 | ||
![]() |
fb6a51b8fd | ||
![]() |
252cc2213e | ||
![]() |
73c5f24fa4 | ||
![]() |
4c80e103a0 | ||
![]() |
39ea557360 | ||
![]() |
d0cc92a01a | ||
![]() |
d7980c1a45 | ||
![]() |
e56ae1426c | ||
![]() |
696843c020 | ||
![]() |
6ff5621dd7 | ||
![]() |
e7fb72a732 | ||
![]() |
8d30d34e0c | ||
![]() |
bc7fe85f8a | ||
![]() |
89352d92c5 | ||
![]() |
c32390d84c | ||
![]() |
45ca866a2d | ||
![]() |
ceef206c21 | ||
![]() |
7c6424f0a9 | ||
![]() |
bc942de6f1 | ||
![]() |
06984df5cb | ||
![]() |
4f136a3a76 | ||
![]() |
363bf3ba30 | ||
![]() |
acb895956a | ||
![]() |
21e87b9bb3 | ||
![]() |
c896ebcf12 | ||
![]() |
d288222e80 | ||
![]() |
4eb2a6c9a3 | ||
![]() |
2563731c4d | ||
![]() |
4e410111db | ||
![]() |
5670563a26 | ||
![]() |
6caa656d01 | ||
![]() |
c12af7aed1 | ||
![]() |
dcb6d1c01d | ||
![]() |
18234cbdac | ||
![]() |
06bf988dc1 | ||
![]() |
55ff4c3f08 | ||
![]() |
4915002168 | ||
![]() |
5bd8d60e41 | ||
![]() |
fc872808c5 | ||
![]() |
0f4feda382 | ||
![]() |
90b0f38316 | ||
![]() |
18f630ab21 | ||
![]() |
e97fd44151 | ||
![]() |
b75679778f | ||
![]() |
35a84ad576 | ||
![]() |
4ed28be75a | ||
![]() |
e2f4656a86 | ||
![]() |
1e14da5c60 | ||
![]() |
b2ef79ef3d | ||
![]() |
f488874ff5 | ||
![]() |
23258648da | ||
![]() |
6b84ebe501 | ||
![]() |
07dd067f73 | ||
![]() |
420744d048 | ||
![]() |
01108e3a63 | ||
![]() |
8026b1e194 | ||
![]() |
a39d77227f | ||
![]() |
9f69deec7d | ||
![]() |
e912f772e0 | ||
![]() |
0102726aeb | ||
![]() |
1e7aa04040 | ||
![]() |
00a7c6fe6b | ||
![]() |
87f8c0d471 | ||
![]() |
334d78cd18 | ||
![]() |
2356325592 | ||
![]() |
d78ec593fa | ||
![]() |
d5043133e6 | ||
![]() |
509f69a457 | ||
![]() |
662c659220 | ||
![]() |
9a6566e774 | ||
![]() |
4da0428d9e | ||
![]() |
8ee1177206 | ||
![]() |
e9154b2549 | ||
![]() |
d398a0dd58 | ||
![]() |
7723a24297 | ||
![]() |
95a4b8db68 | ||
![]() |
663c1898a3 | ||
![]() |
465de793e8 | ||
![]() |
de9b76cef0 | ||
![]() |
1747a8d3d9 | ||
![]() |
1094e79749 | ||
![]() |
22569681bc | ||
![]() |
e615d117a0 | ||
![]() |
a51258b6bb | ||
![]() |
8894bd07b6 | ||
![]() |
ec45a9e825 | ||
![]() |
871358a6e5 | ||
![]() |
2e2e0fba60 | ||
![]() |
4a5139e3f4 | ||
![]() |
8f85933d7c | ||
![]() |
246f3a63f6 | ||
![]() |
e99eff4eb0 | ||
![]() |
c0197f19cf | ||
![]() |
3994d67eea | ||
![]() |
9ead79c9d4 | ||
![]() |
9371aed46c | ||
![]() |
940707ad66 | ||
![]() |
e6c267fb4c | ||
![]() |
93538fccd6 | ||
![]() |
83a7fad308 | ||
![]() |
3c7e33388e | ||
![]() |
7b0f35edb6 | ||
![]() |
94a157d0b0 | ||
![]() |
ca04620253 | ||
![]() |
073ef0b36a | ||
![]() |
c41c05d4f4 | ||
![]() |
f1ea54e07a | ||
![]() |
a139ce901a | ||
![]() |
7431957113 | ||
![]() |
1752d80915 | ||
![]() |
aa7420e109 | ||
![]() |
a290d4b9db | ||
![]() |
19a4314e7f | ||
![]() |
d166e85e0a | ||
![]() |
f213e857ab | ||
![]() |
eb6130baa7 | ||
![]() |
f69ea2c68a | ||
![]() |
078441d477 | ||
![]() |
95f6b15a67 | ||
![]() |
ee29dbdb8f | ||
![]() |
15f3f4c93f | ||
![]() |
6932e94e0e | ||
![]() |
3ef06d7efe | ||
![]() |
fb012b48e9 | ||
![]() |
bc77bf217f | ||
![]() |
37d1e9351e | ||
![]() |
4494c0dee0 | ||
![]() |
26afc604ac | ||
![]() |
9aefcada19 | ||
![]() |
69fc363760 | ||
![]() |
bea02ddebe | ||
![]() |
3fb257c39c | ||
![]() |
7c96c5a39b | ||
![]() |
efd836d971 | ||
![]() |
836aaa1647 | ||
![]() |
bf2b3dbf3e | ||
![]() |
b4fa2ff995 | ||
![]() |
2f9cabc30b | ||
![]() |
63593f5597 | ||
![]() |
c0acaa5d2c | ||
![]() |
2e46f8d0a6 | ||
![]() |
51da6aaa07 | ||
![]() |
c8b79e36db | ||
![]() |
208374bcc9 | ||
![]() |
7f0a6e7203 | ||
![]() |
54ebb9cfd4 | ||
![]() |
49e9c1495b | ||
![]() |
a84b0fbd52 | ||
![]() |
c95814c04d | ||
![]() |
9f8123f1b8 | ||
![]() |
8b23db4f4d | ||
![]() |
d77cc13374 | ||
![]() |
9a12db1aa2 | ||
![]() |
eb54d34bec | ||
![]() |
4b1203d4c9 | ||
![]() |
183a9c6244 | ||
![]() |
1f2294d585 | ||
![]() |
0b839c4f77 | ||
![]() |
1d4fd1fcae | ||
![]() |
b1d8d72c16 | ||
![]() |
bafb68b844 | ||
![]() |
21873b52e9 | ||
![]() |
0aa8b82871 | ||
![]() |
f9781afafd | ||
![]() |
fece361a55 | ||
![]() |
7b51b2f128 | ||
![]() |
22d88fb28e | ||
![]() |
f7c5b28e76 | ||
![]() |
5760f2a307 | ||
![]() |
ee46efb5a5 | ||
![]() |
eb6ffebfc7 | ||
![]() |
c06c44f286 | ||
![]() |
019c4088cf | ||
![]() |
0b0a88b78d | ||
![]() |
028e9cc56f | ||
![]() |
e0d8615ece | ||
![]() |
c8ecbda40b | ||
![]() |
2324c10d43 | ||
![]() |
89cfa76291 | ||
![]() |
072070a22c | ||
![]() |
3c3ad134ea | ||
![]() |
a4ffcfd4d5 | ||
![]() |
136670c58a | ||
![]() |
28169725fa | ||
![]() |
5b13106f54 | ||
![]() |
1a2db0dfb1 | ||
![]() |
696f95bb0a | ||
![]() |
acec588fe3 | ||
![]() |
6ed0da8e98 | ||
![]() |
7fd91d70bd | ||
![]() |
61788a0389 | ||
![]() |
0821447b5b | ||
![]() |
3cba274ba6 | ||
![]() |
df7bbcfd21 | ||
![]() |
021d406f0c | ||
![]() |
294569c502 | ||
![]() |
bfd00ac2ed | ||
![]() |
735a4714f4 | ||
![]() |
827fd47198 | ||
![]() |
e26b917661 | ||
![]() |
92872a2a3c | ||
![]() |
16ddb09cb4 | ||
![]() |
d37031f14e | ||
![]() |
b4e84ca7d2 | ||
![]() |
47970b9e6f | ||
![]() |
f65f120d50 | ||
![]() |
df00ec3c82 | ||
![]() |
ad6fca28f9 | ||
![]() |
fd33923496 | ||
![]() |
a55649dc82 | ||
![]() |
9558f229db | ||
![]() |
7917bfb1c9 | ||
![]() |
25f611ca42 | ||
![]() |
e6eb49e7e0 | ||
![]() |
9a075f53dc | ||
![]() |
4b3f800c03 | ||
![]() |
82bc76b243 | ||
![]() |
18b9b04907 | ||
![]() |
87f1f08b36 | ||
![]() |
7d7ebbe9f7 | ||
![]() |
5111ce782f | ||
![]() |
20b0e563ce | ||
![]() |
8b6cf239a3 | ||
![]() |
bcc285cffd | ||
![]() |
d5ba030942 | ||
![]() |
803f43592a | ||
![]() |
904b9ccaa3 | ||
![]() |
89721ff04a | ||
![]() |
6164823921 | ||
![]() |
f8b3c47f99 | ||
![]() |
56dd2da962 | ||
![]() |
68bb74d172 | ||
![]() |
bf5e12c8e0 | ||
![]() |
de11f5e53a | ||
![]() |
b125e8e23a | ||
![]() |
b28b616eb2 | ||
![]() |
4534ca238d | ||
![]() |
cee0e94294 | ||
![]() |
8319ea7078 | ||
![]() |
5334a58f9b | ||
![]() |
2616bdc4cd | ||
![]() |
c149b3f797 | ||
![]() |
d349eb3d43 | ||
![]() |
9b43ade1c0 | ||
![]() |
ad05d0a8d9 | ||
![]() |
e6bfbe9683 | ||
![]() |
c871efca4b | ||
![]() |
12c72b419c | ||
![]() |
a15b7691ca | ||
![]() |
01618d323b | ||
![]() |
bb6d0e37e3 | ||
![]() |
24a6100897 | ||
![]() |
0251563c98 | ||
![]() |
72673a351b | ||
![]() |
96b7131844 | ||
![]() |
dcc2f16416 | ||
![]() |
c2b8a04000 | ||
![]() |
d65587b06c | ||
![]() |
1ab0134522 | ||
![]() |
afffce80f0 | ||
![]() |
70b80b0160 | ||
![]() |
64067a04b5 | ||
![]() |
38cf0268c0 | ||
![]() |
2d2034703f | ||
![]() |
571ceeff90 | ||
![]() |
34c4ba4321 | ||
![]() |
babb372eb9 | ||
![]() |
5b9b82c1cd | ||
![]() |
075c534270 | ||
![]() |
f317f8b149 | ||
![]() |
f8d552dde5 | ||
![]() |
606f72bb13 | ||
![]() |
327e6a2b4f | ||
![]() |
be8f6c7f5c | ||
![]() |
073448e0ea | ||
![]() |
f136f435b5 | ||
![]() |
ebea6b487b | ||
![]() |
e5b7dc56e6 | ||
![]() |
c2d8025a0a | ||
![]() |
853e240e1d | ||
![]() |
8755a6d1ac | ||
![]() |
9f723061cb | ||
![]() |
652683fc04 | ||
![]() |
83a463891d | ||
![]() |
957b618fdc | ||
![]() |
ebe5191b63 | ||
![]() |
c426234df7 | ||
![]() |
8c3a10392e | ||
![]() |
d0e44946e9 | ||
![]() |
46a593d968 | ||
![]() |
eb0cc34951 | ||
![]() |
1c7dfda4bc | ||
![]() |
3c0e4a2fa1 | ||
![]() |
c753072ae1 | ||
![]() |
243942a7aa | ||
![]() |
8d5ac8b43c | ||
![]() |
17962b3d2e | ||
![]() |
f70acd5979 | ||
![]() |
ffe5c46224 | ||
![]() |
3242ea5f66 | ||
![]() |
39a282bffc | ||
![]() |
29583004ce | ||
![]() |
0a1a185874 | ||
![]() |
8f809e2a93 | ||
![]() |
f216059b49 | ||
![]() |
9121b1f41d | ||
![]() |
60e015d0c1 | ||
![]() |
7e049fca61 | ||
![]() |
0f0e4de6a4 | ||
![]() |
bc1102922b | ||
![]() |
a3d3642a30 | ||
![]() |
248eb47329 | ||
![]() |
52ebf50607 | ||
![]() |
d34a4b126e | ||
![]() |
de96719a45 | ||
![]() |
9876ed09fe | ||
![]() |
17cbbe3dc5 | ||
![]() |
b995af17eb | ||
![]() |
6589579850 | ||
![]() |
5ddc260fc2 | ||
![]() |
db5c9cd4c0 | ||
![]() |
9b6d010aef | ||
![]() |
065b87e949 | ||
![]() |
a6206a3aef | ||
![]() |
30639ed72b | ||
![]() |
9d02a39e13 | ||
![]() |
fc0af0d4d1 | ||
![]() |
a683416081 | ||
![]() |
9faf57ee8d | ||
![]() |
44b9ccb7e2 | ||
![]() |
de003d9cf8 | ||
![]() |
8a2a523c70 | ||
![]() |
c3dfe50aaf | ||
![]() |
9659d862c7 | ||
![]() |
69ab4cd391 | ||
![]() |
498f3985b3 | ||
![]() |
977175d4fd | ||
![]() |
3ddc7b9390 | ||
![]() |
10e9bf623f | ||
![]() |
48a5c64e94 | ||
![]() |
140606ccd5 | ||
![]() |
f56d006f93 | ||
![]() |
beb13a1d3e | ||
![]() |
fa47138327 | ||
![]() |
9421d4510a | ||
![]() |
ff8abfca85 | ||
![]() |
5c858965b8 | ||
![]() |
e3f83cb17a | ||
![]() |
de6008e01a | ||
![]() |
6417e696df | ||
![]() |
5d28f3781b | ||
![]() |
10026bb62e | ||
![]() |
21c16f923c | ||
![]() |
32cef52f0d | ||
![]() |
e7dd7c54ff | ||
![]() |
b0b50bd12a | ||
![]() |
f2c6057490 | ||
![]() |
169b2eeb94 | ||
![]() |
f81d027f60 | ||
![]() |
872eeb7339 | ||
![]() |
7f67a28c2a | ||
![]() |
30a46e1135 | ||
![]() |
3a01478ce8 | ||
![]() |
53d71fab60 | ||
![]() |
be891f112c | ||
![]() |
89934239d7 | ||
![]() |
8986037fdd | ||
![]() |
a7c72b7abf | ||
![]() |
409ac80710 | ||
![]() |
fc7bebdf55 | ||
![]() |
ca52549557 | ||
![]() |
8948a65654 | ||
![]() |
b4e33cfcc7 | ||
![]() |
86742e8334 | ||
![]() |
173b35eaf8 | ||
![]() |
2b054e5309 | ||
![]() |
a302ff1605 | ||
![]() |
f7bb4e6138 | ||
![]() |
5c5489916b | ||
![]() |
5627cf7167 | ||
![]() |
c05dae4a68 | ||
![]() |
57e61e3743 | ||
![]() |
a6c395c156 | ||
![]() |
543e0b1e0f | ||
![]() |
64b0ff875f | ||
![]() |
a034208a00 | ||
![]() |
5f1251586b | ||
![]() |
6f6cffdc32 | ||
![]() |
21a98ef264 | ||
![]() |
aa90436435 | ||
![]() |
61225052f9 | ||
![]() |
dee3163d95 | ||
![]() |
8b0668b99e | ||
![]() |
8471a82c85 | ||
![]() |
ed4dff63b9 | ||
![]() |
838e776542 | ||
![]() |
39c12790bc | ||
![]() |
126e6d6645 | ||
![]() |
5796a1b282 | ||
![]() |
90982529fc | ||
![]() |
aba51d6b60 | ||
![]() |
49bc4567bb | ||
![]() |
2ac52705c6 | ||
![]() |
d0eb56dd97 | ||
![]() |
b9c60df04b | ||
![]() |
8c236e4dfa | ||
![]() |
154a59f21f | ||
![]() |
9689e1c548 | ||
![]() |
5a83976c99 | ||
![]() |
b5276a9a69 | ||
![]() |
30377baa5e | ||
![]() |
aa8b7dd336 | ||
![]() |
f26a338a54 | ||
![]() |
c4383f1d99 | ||
![]() |
4527995e66 | ||
![]() |
b0fbb98f41 | ||
![]() |
63667dfd96 | ||
![]() |
77c388c928 | ||
![]() |
a69b814ded | ||
![]() |
c51ada766d | ||
![]() |
ef2709f97c | ||
![]() |
bf9b9ca29d | ||
![]() |
64f224bb22 | ||
![]() |
285a8fe4d0 | ||
![]() |
3773d76dfd | ||
![]() |
94c5c7bd6d | ||
![]() |
12cfc4c0b0 | ||
![]() |
9a2de6e6ee | ||
![]() |
2ede47b8c8 | ||
![]() |
76e107506f | ||
![]() |
6f35ed51dc | ||
![]() |
c94ba66310 | ||
![]() |
a15133f5cf | ||
![]() |
cc09e9d4c2 | ||
![]() |
16e0da2c4b | ||
![]() |
ed22f75241 | ||
![]() |
ba25cad6e2 | ||
![]() |
abb01123cb | ||
![]() |
e2d249f8c5 | ||
![]() |
4a2ac166fa | ||
![]() |
5fab55383d | ||
![]() |
f152f23a68 | ||
![]() |
24e78b3571 | ||
![]() |
9a239edb52 | ||
![]() |
abcc5c5a82 | ||
![]() |
cb5ba675a7 | ||
![]() |
2288086695 | ||
![]() |
61421b7a8f | ||
![]() |
6a7e53a7c7 | ||
![]() |
ca134d5522 | ||
![]() |
ec24efda74 | ||
![]() |
7f0f10e498 | ||
![]() |
aa5af100b4 | ||
![]() |
37ae32f688 | ||
![]() |
d0cffdec5d | ||
![]() |
0f34521612 | ||
![]() |
e69362df22 | ||
![]() |
3de8f6f38e | ||
![]() |
5359bc8083 | ||
![]() |
eb6a14fe10 | ||
![]() |
2912537533 | ||
![]() |
cfb32da198 | ||
![]() |
9b4f92130f | ||
![]() |
5a2ab686a6 | ||
![]() |
3b8583b014 | ||
![]() |
ed29552b1e | ||
![]() |
a2ada3cf96 | ||
![]() |
88825a1187 | ||
![]() |
264e7fc58b | ||
![]() |
1698015e3c | ||
![]() |
39dc14c002 | ||
![]() |
04c499a5fc | ||
![]() |
efbe930a69 | ||
![]() |
747f87f61e | ||
![]() |
5a4c56fc44 | ||
![]() |
81f45ba92a | ||
![]() |
a5dc4e32f2 | ||
![]() |
2b839853ec | ||
![]() |
66b6cd68ed | ||
![]() |
0ef3d90838 | ||
![]() |
5cc50f9b27 | ||
![]() |
e879e26a5b | ||
![]() |
96d84150e1 | ||
![]() |
2aa0c6c488 | ||
![]() |
811138386f | ||
![]() |
c433cf7459 | ||
![]() |
e0d6ebc2f2 | ||
![]() |
4938991ab8 | ||
![]() |
13722f536e | ||
![]() |
57f0e3292d | ||
![]() |
da5ae565ab | ||
![]() |
87c5066242 | ||
![]() |
b528bde470 | ||
![]() |
57572e550f | ||
![]() |
3aea0d3d68 | ||
![]() |
9ae920c1b6 | ||
![]() |
dff406a360 | ||
![]() |
d346ba5c3c | ||
![]() |
978541adc2 | ||
![]() |
637bce2707 | ||
![]() |
07e3dc2ee2 | ||
![]() |
ead065d803 | ||
![]() |
0150bff7b4 | ||
![]() |
0f493b6038 | ||
![]() |
f26b709c50 | ||
![]() |
ae10d9cf22 | ||
![]() |
81af9674ed | ||
![]() |
b63df7991a | ||
![]() |
a79990465c | ||
![]() |
ad6bd530ac | ||
![]() |
c1b369fd4c | ||
![]() |
01fcd3c2d5 | ||
![]() |
7196d784d3 | ||
![]() |
0f0aaf51e0 | ||
![]() |
b5f493c55a | ||
![]() |
0aa031beb9 | ||
![]() |
db6ff224f8 | ||
![]() |
b3c7cd61f3 | ||
![]() |
9ae05c4d91 | ||
![]() |
264e6f6efd | ||
![]() |
ec7bccf671 | ||
![]() |
49f75ee8ce | ||
![]() |
4bcc866c52 | ||
![]() |
c65e088caf | ||
![]() |
6ca4116555 | ||
![]() |
f6cdb820af | ||
![]() |
081e5a82ff | ||
![]() |
2ad2a4bd9f | ||
![]() |
645e700da3 | ||
![]() |
92aea29a30 | ||
![]() |
e1c01af929 | ||
![]() |
7ef749497d | ||
![]() |
d72aa49126 | ||
![]() |
e92bd312ec | ||
![]() |
b097c2cfb0 | ||
![]() |
a39cdc80b7 | ||
![]() |
a47250810e | ||
![]() |
1f50f3031f | ||
![]() |
75145dd753 | ||
![]() |
d0b97f7e1f | ||
![]() |
199a0311e2 | ||
![]() |
fa446f860f | ||
![]() |
7a74303f3c | ||
![]() |
7d9eabb981 | ||
![]() |
ff5308a5af | ||
![]() |
3f8ba3a986 | ||
![]() |
4a555de1b2 | ||
![]() |
d27e4a08f9 | ||
![]() |
bf678a1ca9 | ||
![]() |
13a903de28 | ||
![]() |
a3c14c031e | ||
![]() |
e90d528026 | ||
![]() |
d64dd77993 | ||
![]() |
113850a748 | ||
![]() |
1c49a00d64 | ||
![]() |
eef6c83503 | ||
![]() |
ceb5648eb7 | ||
![]() |
a0eadb76ea | ||
![]() |
065852e46c | ||
![]() |
e5e2fb8274 | ||
![]() |
0210b3c893 | ||
![]() |
7df5677b46 | ||
![]() |
2e71876b28 | ||
![]() |
11576b1142 | ||
![]() |
ce011b8a2d | ||
![]() |
12cfb4f7ee | ||
![]() |
9e1123debe | ||
![]() |
c7354142c0 | ||
![]() |
dee84f448f | ||
![]() |
1607711603 | ||
![]() |
8bca5e05b8 | ||
![]() |
f68505ee23 | ||
![]() |
d2174da641 | ||
![]() |
255b1e68d0 | ||
![]() |
fbee6b87f5 | ||
![]() |
3836a70f97 | ||
![]() |
e0ec9fa294 | ||
![]() |
80fe50590f | ||
![]() |
ae18d1c55a | ||
![]() |
75194373e0 | ||
![]() |
f3875048f6 | ||
![]() |
210af986ad | ||
![]() |
c03044f492 | ||
![]() |
522b85ae21 | ||
![]() |
208e56dbe9 | ||
![]() |
42acb00c81 | ||
![]() |
ca6e770837 | ||
![]() |
775968003c | ||
![]() |
323d3e9b5d | ||
![]() |
16f9755e73 | ||
![]() |
66eb98bb0a | ||
![]() |
299546f5c0 | ||
![]() |
7be9b4c418 | ||
![]() |
03c22b4576 | ||
![]() |
ef749fa9ce | ||
![]() |
a23c92596e | ||
![]() |
abb1497c98 | ||
![]() |
7a8594da43 | ||
![]() |
cbf28daed9 | ||
![]() |
0ff1ca30c3 | ||
![]() |
2cff251863 | ||
![]() |
73d996bf26 | ||
![]() |
5bc78cb724 | ||
![]() |
cdba92ac3c | ||
![]() |
6d28f92ffe | ||
![]() |
01387f42c5 | ||
![]() |
8f52b731f4 | ||
![]() |
d442088ed3 | ||
![]() |
22a323890a | ||
![]() |
163bba1410 | ||
![]() |
db1c618fcf | ||
![]() |
01bdfa7b6d | ||
![]() |
6a88c8d845 | ||
![]() |
b8a6913e09 | ||
![]() |
744d8c1006 | ||
![]() |
c2e2c98d81 | ||
![]() |
3fa353a2d3 | ||
![]() |
c27c9f80d2 | ||
![]() |
b5a74715cf | ||
![]() |
13ee2901f4 | ||
![]() |
32c03eadd6 | ||
![]() |
0fa512f26d | ||
![]() |
219d88518c | ||
![]() |
ecf3aee43a | ||
![]() |
7f08cab73e | ||
![]() |
c4e9ef199e | ||
![]() |
9e612b5550 | ||
![]() |
203633d34d | ||
![]() |
45bd009bb1 | ||
![]() |
ee656415c4 | ||
![]() |
156aad198f | ||
![]() |
b1ffb79a50 | ||
![]() |
d6654bfe00 | ||
![]() |
eefdd67d22 | ||
![]() |
86a86d7afd | ||
![]() |
b6dac2b484 | ||
![]() |
e6367abae9 | ||
![]() |
fc4d1d9a60 | ||
![]() |
94bae20776 | ||
![]() |
bb8c8d273c | ||
![]() |
ee600ace37 | ||
![]() |
da86e32eb4 | ||
![]() |
b5bbc04ad1 | ||
![]() |
265c58611f | ||
![]() |
25c973a39e | ||
![]() |
123c7b32db | ||
![]() |
e2d8e2c4ae | ||
![]() |
701509d322 | ||
![]() |
c3cc616264 | ||
![]() |
91b84b89e4 | ||
![]() |
017ec204a9 | ||
![]() |
8dbfecd153 | ||
![]() |
512db1bc54 | ||
![]() |
e157aabd4d | ||
![]() |
db2fea448c | ||
![]() |
dd82d69b8c | ||
![]() |
27328281b7 | ||
![]() |
51d205b267 | ||
![]() |
84800914f6 | ||
![]() |
9b296e65bd | ||
![]() |
5f649a1649 | ||
![]() |
daea056210 | ||
![]() |
30c0db06bd | ||
![]() |
91168c005c | ||
![]() |
cfa0054077 | ||
![]() |
3d5820648b | ||
![]() |
d08df97fe5 | ||
![]() |
fd6624a058 | ||
![]() |
8aa41dd04b | ||
![]() |
e890113fc6 | ||
![]() |
e2e64798b5 | ||
![]() |
b9b6a6566a | ||
![]() |
dc9e415602 | ||
![]() |
84fa12c885 | ||
![]() |
296b35fe9b | ||
![]() |
0ff89b9c3c | ||
![]() |
3b33540c99 | ||
![]() |
29d0174253 | ||
![]() |
cc7f2a0d08 | ||
![]() |
b1579aed2f | ||
![]() |
9247daf953 | ||
![]() |
9031e33b66 | ||
![]() |
1ee1f5f427 | ||
![]() |
a5874a5393 | ||
![]() |
969217c9d9 | ||
![]() |
e399502c7a | ||
![]() |
6883f0c49f | ||
![]() |
3fc2c813cc | ||
![]() |
9de4b99fc7 | ||
![]() |
24e7036822 | ||
![]() |
ec9acbcda7 | ||
![]() |
c0460660d5 | ||
![]() |
b03f4919fb | ||
![]() |
08620743b9 | ||
![]() |
41362f063a | ||
![]() |
5b3069e265 | ||
![]() |
b466924717 | ||
![]() |
cbc0f65fa3 | ||
![]() |
35089a4289 | ||
![]() |
aef3131e92 | ||
![]() |
342fce97af | ||
![]() |
fb5d267bd0 | ||
![]() |
c19844a0a3 | ||
![]() |
22cf05519a | ||
![]() |
511ce35631 | ||
![]() |
e9b7548dd6 | ||
![]() |
010cde0a4a | ||
![]() |
cac5251a98 | ||
![]() |
3b825bcbfb | ||
![]() |
31959fb24b | ||
![]() |
5e9675ad1e | ||
![]() |
084b7675b2 | ||
![]() |
ed8be5bc55 | ||
![]() |
efca2943a0 | ||
![]() |
371da7132f | ||
![]() |
9a3ff5c46a | ||
![]() |
b36c654a3d | ||
![]() |
ddeb2613ec | ||
![]() |
2d02d20911 | ||
![]() |
b2563b9f9f | ||
![]() |
fccf6925b1 | ||
![]() |
4a7cf65064 | ||
![]() |
56587e2821 | ||
![]() |
33b8e71583 | ||
![]() |
1c96128695 | ||
![]() |
ca516b1b26 | ||
![]() |
ba4e69bebc | ||
![]() |
de5e9f100c | ||
![]() |
955da86a3e | ||
![]() |
8d85be4c5e | ||
![]() |
93eadfb10f | ||
![]() |
f8e0b18439 | ||
![]() |
64bbe9dfaf | ||
![]() |
2e8a9416af | ||
![]() |
5dd40bd0bb | ||
![]() |
1822dd0549 | ||
![]() |
751e49fb0a | ||
![]() |
56c43604d0 | ||
![]() |
7438c378be | ||
![]() |
0e0caf7c06 | ||
![]() |
5644f4a295 | ||
![]() |
98e1605b17 | ||
![]() |
73f0e32d1a | ||
![]() |
713cb56fea | ||
![]() |
bd3bb70ee8 | ||
![]() |
8aa3f14303 | ||
![]() |
ac285b453e | ||
![]() |
daf55705e4 | ||
![]() |
7140baae72 | ||
![]() |
27a2e590cd | ||
![]() |
7172fa058a | ||
![]() |
c0790ccf08 | ||
![]() |
87c43517cd | ||
![]() |
6561ec524b | ||
![]() |
982c5460f0 | ||
![]() |
2a3a8848f3 | ||
![]() |
752520e428 | ||
![]() |
8095b776fe | ||
![]() |
e504103e2c | ||
![]() |
904183262a | ||
![]() |
2a0bc64226 | ||
![]() |
6b975c308c | ||
![]() |
74be55a477 | ||
![]() |
394832c2d6 | ||
![]() |
f636c12255 | ||
![]() |
03e4a8214c | ||
![]() |
6d7785a35b | ||
![]() |
904f579332 | ||
![]() |
a72d789b08 | ||
![]() |
87ad7ace18 | ||
![]() |
35153eb524 | ||
![]() |
c8ee1fa62e | ||
![]() |
5c1a6ed719 | ||
![]() |
9d68fde148 | ||
![]() |
c7d517f6d2 | ||
![]() |
183f1531d3 | ||
![]() |
6dfe0ec31e | ||
![]() |
8b3f1cebda | ||
![]() |
086daf913c | ||
![]() |
6a3e2272e9 | ||
![]() |
d0e0bf53a6 | ||
![]() |
0009e4dfb9 | ||
![]() |
30b7a9f172 | ||
![]() |
c74cb59e08 | ||
![]() |
c1f29a8e08 | ||
![]() |
cb895ec335 | ||
![]() |
2df4866cfa | ||
![]() |
423a1cf486 | ||
![]() |
7aeb63c817 | ||
![]() |
476fa1f4d2 | ||
![]() |
0bea215560 | ||
![]() |
3c20b98d99 | ||
![]() |
8bcdda29d4 | ||
![]() |
c88036405f | ||
![]() |
60cddab4f2 | ||
![]() |
411ca1c050 | ||
![]() |
d1be3a4a1d | ||
![]() |
b5dd257427 | ||
![]() |
4cf953678d | ||
![]() |
ca5678c8c1 | ||
![]() |
9e4594be53 | ||
![]() |
d16c757c28 | ||
![]() |
312bcafd05 | ||
![]() |
be24652d4d | ||
![]() |
6ab44d9439 | ||
![]() |
108cb14d1f | ||
![]() |
b98308b524 | ||
![]() |
215c445583 | ||
![]() |
20d8e32a58 | ||
![]() |
33306b2749 | ||
![]() |
94eeeba79a | ||
![]() |
ecd29a289a | ||
![]() |
e7d0af72e3 | ||
![]() |
fcb1d3521a | ||
![]() |
890bf3bd27 | ||
![]() |
dafd81178f | ||
![]() |
99dfdebc64 | ||
![]() |
c1cfdd6323 | ||
![]() |
264a9bc6ed | ||
![]() |
f79f5cbf82 | ||
![]() |
7313501e30 | ||
![]() |
d8b2c819e7 | ||
![]() |
69f6d14b81 | ||
![]() |
9f3856e646 | ||
![]() |
a46e2e9900 | ||
![]() |
14f0dd2dd0 | ||
![]() |
c051438fa1 | ||
![]() |
52e32ac1d3 | ||
![]() |
7f8ad34ba2 | ||
![]() |
a9c0302454 | ||
![]() |
a33e89b44a | ||
![]() |
e203ecebee | ||
![]() |
2f8e7f56b3 | ||
![]() |
2443e1f38c | ||
![]() |
eb164098b7 | ||
![]() |
62527fa98a | ||
![]() |
b9f8e80b14 | ||
![]() |
b79e250ed2 | ||
![]() |
fc5c9d8f17 | ||
![]() |
72d57a8ee6 | ||
![]() |
23262e30bc | ||
![]() |
8b4ad40ed6 | ||
![]() |
d7e9797365 | ||
![]() |
e54e0c7877 | ||
![]() |
5cb06d8fd6 | ||
![]() |
2b34d4e1f7 | ||
![]() |
c7aa095fac | ||
![]() |
93f1784526 | ||
![]() |
559dc503c2 | ||
![]() |
414afe0935 | ||
![]() |
4ad4f3fc70 | ||
![]() |
67273eed9b | ||
![]() |
3c63e1d8d9 | ||
![]() |
cae555c977 | ||
![]() |
407583e8e2 | ||
![]() |
131645dc31 | ||
![]() |
dafd644fe7 | ||
![]() |
73cc1742af | ||
![]() |
87afd7686f | ||
![]() |
8ce10b5dfa | ||
![]() |
943e31b35c | ||
![]() |
20f85b94df | ||
![]() |
17b784381e | ||
![]() |
e3031fddb9 | ||
![]() |
38c994a7ae | ||
![]() |
85e2e96fb6 | ||
![]() |
be35b3ad03 | ||
![]() |
dbbd871ea1 | ||
![]() |
813911db59 | ||
![]() |
3c49b405de | ||
![]() |
4cfffd6c4a | ||
![]() |
e9f1c12f0f | ||
![]() |
4fe252847c | ||
![]() |
109cbbe9c5 | ||
![]() |
fd3881eaa6 | ||
![]() |
08ef208fb7 | ||
![]() |
8c45e2a641 | ||
![]() |
25dc520163 | ||
![]() |
fc37ef9e4b | ||
![]() |
11ba367fc9 | ||
![]() |
78473f71eb | ||
![]() |
8b77f40f99 | ||
![]() |
d866716565 | ||
![]() |
307d0effe2 | ||
![]() |
b47b053e54 | ||
![]() |
b79f01caf3 | ||
![]() |
0db227f55e | ||
![]() |
ac48b38842 | ||
![]() |
0cbb9365c6 | ||
![]() |
798b8c522b | ||
![]() |
15bc7e19f9 | ||
![]() |
0be3f1a063 | ||
![]() |
c0257c6721 | ||
![]() |
9aec0fc7de | ||
![]() |
bce5e0d82c | ||
![]() |
62032ee248 | ||
![]() |
775645f29b | ||
![]() |
99c0456872 | ||
![]() |
0236bee5de | ||
![]() |
59c11b82d5 | ||
![]() |
98871d1e9e | ||
![]() |
b40dc5d742 | ||
![]() |
17b0723713 | ||
![]() |
ec585e8907 | ||
![]() |
0aeb25ff3b | ||
![]() |
a928f2c4aa | ||
![]() |
51fcee6f81 | ||
![]() |
654be65590 | ||
![]() |
105ec79b2b | ||
![]() |
c759d8427a | ||
![]() |
c7b03d6479 | ||
![]() |
2080738883 | ||
![]() |
48bc73c271 | ||
![]() |
3d0969d1d1 | ||
![]() |
323f195036 | ||
![]() |
c3c392fc98 | ||
![]() |
5d2944c211 | ||
![]() |
fe3ba1dd11 | ||
![]() |
0c00eb93a0 | ||
![]() |
baa77ec13b | ||
![]() |
9263652c6d | ||
![]() |
bc74375543 | ||
![]() |
edb1756050 | ||
![]() |
5215f6f654 | ||
![]() |
1913b4eeed | ||
![]() |
b44a4da5df | ||
![]() |
919878fbb2 | ||
![]() |
06bdf83419 | ||
![]() |
2ff2810a92 | ||
![]() |
20d9c1b30d | ||
![]() |
bbe10cb0cb | ||
![]() |
daba8f3a70 | ||
![]() |
1458c3668d | ||
![]() |
980a47b42b | ||
![]() |
f7ca561b06 | ||
![]() |
cacd756efd | ||
![]() |
8539e76cb9 | ||
![]() |
3bbf694d5a | ||
![]() |
44debdde62 | ||
![]() |
c6cf2b8e93 | ||
![]() |
69c5452b25 | ||
![]() |
d321056e8d | ||
![]() |
d9a1a59f22 | ||
![]() |
0b898b5a8a | ||
![]() |
a9e0885be0 | ||
![]() |
57ff28c9b7 | ||
![]() |
86cc34c0de | ||
![]() |
39028f1bd4 | ||
![]() |
71f4c05665 | ||
![]() |
9ef9797998 | ||
![]() |
ab9374de57 | ||
![]() |
913e997061 | ||
![]() |
8e50d6b6f3 | ||
![]() |
2db0744a7b | ||
![]() |
2de0028349 | ||
![]() |
35d04c5398 | ||
![]() |
b1becd0ed5 | ||
![]() |
bd9650bc81 | ||
![]() |
969a25d1b2 | ||
![]() |
f144f77ba7 | ||
![]() |
abea1f8910 | ||
![]() |
8eaa7fec76 | ||
![]() |
fdace647e8 | ||
![]() |
d7531c18fc | ||
![]() |
ef3f978784 | ||
![]() |
e410860e0e | ||
![]() |
c64fca1b0c | ||
![]() |
15b2a3af91 | ||
![]() |
8358505b6d | ||
![]() |
1c42779845 | ||
![]() |
32823f17e0 | ||
![]() |
e1c2e3f5e9 | ||
![]() |
044755b30f | ||
![]() |
9aa22399a8 | ||
![]() |
f564905ac4 | ||
![]() |
00e4f81446 | ||
![]() |
8927ddec16 | ||
![]() |
f6525ae200 | ||
![]() |
0be7944d66 | ||
![]() |
47819ea86e | ||
![]() |
96ce3461ad | ||
![]() |
8b6d555421 | ||
![]() |
3b9ef8dfc8 | ||
![]() |
db6d4bcf47 | ||
![]() |
471f1d694f | ||
![]() |
495f6f6bd3 | ||
![]() |
36e35b6f60 | ||
![]() |
192606bc4b | ||
![]() |
53a9fdf078 | ||
![]() |
ef436bdbe8 | ||
![]() |
72d722b07b | ||
![]() |
21fc402c01 | ||
![]() |
381f77756d | ||
![]() |
a386562d9a | ||
![]() |
2bc84fb163 | ||
![]() |
08f8917acb | ||
![]() |
62d205a2ec | ||
![]() |
29e873b12d | ||
![]() |
95f78080ab | ||
![]() |
9549cfde02 | ||
![]() |
2361aabbef | ||
![]() |
e0cc8d2ce9 | ||
![]() |
53c0e97117 | ||
![]() |
bb44791bf3 | ||
![]() |
9ebcfe9dff | ||
![]() |
f339bf613c | ||
![]() |
b00c59816d | ||
![]() |
a00918116d | ||
![]() |
d26c318321 | ||
![]() |
eb8770506f | ||
![]() |
c06171a802 | ||
![]() |
5528c1eaa5 | ||
![]() |
93516effe4 | ||
![]() |
38e518c710 | ||
![]() |
3f6133be27 | ||
![]() |
c3bfb355c5 | ||
![]() |
c69dd14cbc | ||
![]() |
7954652b80 | ||
![]() |
ca35b39900 | ||
![]() |
09df9b90c3 | ||
![]() |
308ae5cbf2 | ||
![]() |
1cd5cdfccb | ||
![]() |
606e7fd744 | ||
![]() |
e8109b09b1 | ||
![]() |
536ea60d73 | ||
![]() |
3390b6446c | ||
![]() |
bfc7f1e4ac | ||
![]() |
8ba410a56e | ||
![]() |
14d1da3ae0 | ||
![]() |
2a72641a0b | ||
![]() |
9c4e5dc3ee | ||
![]() |
540e5ffa90 | ||
![]() |
c1a57591ee | ||
![]() |
1a4f72dd4f | ||
![]() |
c3c8bbd3b2 | ||
![]() |
fb7d34cea8 | ||
![]() |
0866c1b52d | ||
![]() |
136f728b49 | ||
![]() |
5d28a857a4 | ||
![]() |
edbe0d166c | ||
![]() |
4db8c8b1a3 | ||
![]() |
2b16b8604a | ||
![]() |
f630929810 | ||
![]() |
016abdfef6 | ||
![]() |
fd915609cd | ||
![]() |
064697fde6 | ||
![]() |
a03fd7b81c | ||
![]() |
1cfcbc50a6 | ||
![]() |
ea1f138c08 | ||
![]() |
d560207ea1 | ||
![]() |
90b51831fd | ||
![]() |
38ed8938d8 | ||
![]() |
547e91dbf0 | ||
![]() |
04da96e044 | ||
![]() |
4a7def101b | ||
![]() |
541e5a3b82 | ||
![]() |
5af61716aa | ||
![]() |
6f3e0051c3 | ||
![]() |
703ecc3521 | ||
![]() |
67b0f9aacd | ||
![]() |
854277bae5 | ||
![]() |
ca9760756a | ||
![]() |
f1f993a25b | ||
![]() |
eb0f727818 | ||
![]() |
dc3d0289d6 | ||
![]() |
bd830c6f4d | ||
![]() |
51d602f973 | ||
![]() |
30d5401f31 | ||
![]() |
ab6b0f9843 | ||
![]() |
c560327f26 | ||
![]() |
28939dd45c | ||
![]() |
3853e3d6f3 | ||
![]() |
6062a1bd68 | ||
![]() |
8d94688fd1 | ||
![]() |
6b4532b592 | ||
![]() |
286fb6f645 | ||
![]() |
340caf5da3 | ||
![]() |
171c4fd49f | ||
![]() |
b8a0fb1dfe | ||
![]() |
e65993bccb | ||
![]() |
7ffb4660ec | ||
![]() |
974f314f57 | ||
![]() |
4cec22fa19 | ||
![]() |
069477d35c | ||
![]() |
eaff1a344e | ||
![]() |
1fe1e39a88 | ||
![]() |
33b06f56f0 | ||
![]() |
61a84abe2a | ||
![]() |
3d03100079 | ||
![]() |
5297a52bf0 | ||
![]() |
88631276e8 | ||
![]() |
2c0d9ad64c | ||
![]() |
5c691ed835 | ||
![]() |
f73864a045 | ||
![]() |
94da04fcac | ||
![]() |
5f758fbd11 | ||
![]() |
fb29529a52 | ||
![]() |
3cd2673077 | ||
![]() |
d242214e18 | ||
![]() |
468b787272 | ||
![]() |
cfdb6f851c | ||
![]() |
7886f120f3 | ||
![]() |
76fe69b133 | ||
![]() |
e1bae4fc7e | ||
![]() |
bc9705f758 | ||
![]() |
c819e234b8 | ||
![]() |
ce021b79a7 | ||
![]() |
805a2f6f99 | ||
![]() |
eb78400b53 | ||
![]() |
4852f9ffbd | ||
![]() |
c8d2ad2513 | ||
![]() |
9f374c2050 | ||
![]() |
5799852424 | ||
![]() |
6417fa95cf | ||
![]() |
61f6284a35 | ||
![]() |
6b1a1a62a3 | ||
![]() |
feacb4b481 | ||
![]() |
fe3c874001 | ||
![]() |
d9459b54d9 | ||
![]() |
017be8a882 | ||
![]() |
b86e543a13 | ||
![]() |
c2d4fd876c | ||
![]() |
58cad04bbb | ||
![]() |
9bb64d6827 | ||
![]() |
4441df90c1 | ||
![]() |
f51f2417c5 | ||
![]() |
aad617647d | ||
![]() |
49c0d62dda | ||
![]() |
f752098ba5 | ||
![]() |
a4477b9e4b | ||
![]() |
ad3cef0fc8 | ||
![]() |
d89dbe5bd6 | ||
![]() |
b0475dbdbc | ||
![]() |
60b2e74fa3 | ||
![]() |
cda16297d1 | ||
![]() |
d6c9a72e15 | ||
![]() |
4d7b1512c1 | ||
![]() |
d8a35d745e | ||
![]() |
e22657ea13 | ||
![]() |
d06d6b5534 | ||
![]() |
cec8ab1fde | ||
![]() |
9fc62a8dd0 | ||
![]() |
61540b98c2 | ||
![]() |
465ae39e86 | ||
![]() |
01f04b9a41 | ||
![]() |
34f9ab1046 | ||
![]() |
699876778b | ||
![]() |
8fc5a0d19e | ||
![]() |
62b5926d58 | ||
![]() |
4d1037f385 | ||
![]() |
e4addb3975 | ||
![]() |
2aef351980 | ||
![]() |
d88c153c7d | ||
![]() |
9e9883082e | ||
![]() |
71440df4c7 | ||
![]() |
80b004a57d | ||
![]() |
ea8476a2dc | ||
![]() |
cb85ca18ab | ||
![]() |
f1103b95cf | ||
![]() |
aa5ff53bcf | ||
![]() |
907dabed5d | ||
![]() |
0cacbc892c | ||
![]() |
6753c3c715 | ||
![]() |
36e1363e3d | ||
![]() |
d1a711eb6a | ||
![]() |
d8dea4dcc7 | ||
![]() |
ca161737bc | ||
![]() |
3612c3774e | ||
![]() |
e6a65bb3ef | ||
![]() |
ff291eee48 | ||
![]() |
66b8f48a88 | ||
![]() |
634760cbdc | ||
![]() |
a23a897ad2 | ||
![]() |
d9c244278d | ||
![]() |
b6c4185b27 | ||
![]() |
5896d35e72 | ||
![]() |
b4dfdd8bbc | ||
![]() |
e6ed3478ea | ||
![]() |
db08d9c6b9 | ||
![]() |
9490278ece | ||
![]() |
fd8bf5f171 | ||
![]() |
c9bc14a222 | ||
![]() |
63708cbfb0 | ||
![]() |
d9f307623c | ||
![]() |
540f77a627 | ||
![]() |
71bb2d0b8b | ||
![]() |
87dc44e434 | ||
![]() |
29e0fcd091 | ||
![]() |
2e9a798f09 | ||
![]() |
b32a39f44f | ||
![]() |
d86f9611b3 | ||
![]() |
6a62fc4a40 | ||
![]() |
7cdd6455d7 | ||
![]() |
e4fefd088d | ||
![]() |
95e601e2b1 | ||
![]() |
b1ffe7b74a | ||
![]() |
417c8fb602 | ||
![]() |
85efa64c31 | ||
![]() |
d8cb026e80 | ||
![]() |
41dd5121f0 | ||
![]() |
94482d7ca5 | ||
![]() |
4d0e51aead | ||
![]() |
ae8a8c8ba4 | ||
![]() |
7d043f46d5 | ||
![]() |
cbca19d6c2 | ||
![]() |
b40b9677b6 | ||
![]() |
c80ad865db | ||
![]() |
758eae49ab | ||
![]() |
721b05e343 | ||
![]() |
a333bddeeb | ||
![]() |
4c6a52fe90 | ||
![]() |
792d73a9cf | ||
![]() |
9a95a3f8c3 | ||
![]() |
485edb777f | ||
![]() |
a8c3431ae9 | ||
![]() |
6fe4a6fa9a | ||
![]() |
6d8c7356d6 | ||
![]() |
a782c96e81 | ||
![]() |
c795123cd5 | ||
![]() |
0ec370e6fb | ||
![]() |
3d5732d4e0 | ||
![]() |
b795929858 | ||
![]() |
535258ffe4 | ||
![]() |
cc161b96ac | ||
![]() |
5c4b422b18 | ||
![]() |
89bad584c3 | ||
![]() |
e21926f7f0 | ||
![]() |
e452f467d4 | ||
![]() |
dfda7ba456 | ||
![]() |
feb6b6445e | ||
![]() |
0b57fa9c51 | ||
![]() |
55c6f60c90 | ||
![]() |
9def011e8e | ||
![]() |
7cf6e8c9cc | ||
![]() |
cdee43aa59 | ||
![]() |
9c25b58b4c | ||
![]() |
83f35463f5 | ||
![]() |
818cdb879e | ||
![]() |
3eead2d6c4 | ||
![]() |
5cffe055ad | ||
![]() |
3d4511daf3 | ||
![]() |
4748b40ad9 | ||
![]() |
c40b4f6c39 | ||
![]() |
d3b96dd394 | ||
![]() |
f946df640b | ||
![]() |
fef78bd6f1 | ||
![]() |
9e6cc86bf7 | ||
![]() |
b544c5fa5c | ||
![]() |
afa64ee31f | ||
![]() |
e9bfef0eb1 | ||
![]() |
ddbcccd43d | ||
![]() |
5370d7a6eb | ||
![]() |
685b180ab6 | ||
![]() |
9dab850874 | ||
![]() |
0d5bfe883e | ||
![]() |
cc2f1d4894 | ||
![]() |
a8dd13db4c | ||
![]() |
325391aef9 | ||
![]() |
3474ec4ecb | ||
![]() |
ec1736d488 | ||
![]() |
4522579688 | ||
![]() |
907a6e0eed | ||
![]() |
d20186a7b8 | ||
![]() |
b28051881e | ||
![]() |
bdea56cd3f | ||
![]() |
8a3ec2c659 | ||
![]() |
14e9420d2c | ||
![]() |
5b58e61f28 | ||
![]() |
be2f3071b5 | ||
![]() |
85dbf82d93 | ||
![]() |
a9c4963cc0 | ||
![]() |
a4934387d5 | ||
![]() |
e88a2ec6fc | ||
![]() |
0666960173 | ||
![]() |
f114caca90 | ||
![]() |
9468c9c796 | ||
![]() |
76c53c690c | ||
![]() |
c341b11aaf | ||
![]() |
6212e6990a | ||
![]() |
28049a183c | ||
![]() |
5d3dd7911e | ||
![]() |
ae8375516b | ||
![]() |
e3f10eb825 | ||
![]() |
2b1f683239 | ||
![]() |
a2b19c9a63 | ||
![]() |
4146ce8267 | ||
![]() |
170bd6dafc | ||
![]() |
7e16ec8724 | ||
![]() |
8c459156f8 | ||
![]() |
2db894807b | ||
![]() |
95ceeb6e0b | ||
![]() |
c9c00d2a23 | ||
![]() |
1afe49864d | ||
![]() |
6924bee3a0 | ||
![]() |
39d4552dab | ||
![]() |
a23c63738f | ||
![]() |
e911945c55 | ||
![]() |
6d58d13710 | ||
![]() |
0b177cb165 | ||
![]() |
3e31b619de | ||
![]() |
f925979b2f | ||
![]() |
49f7fa82b9 | ||
![]() |
e4cd4cf3f3 | ||
![]() |
e74b20926d | ||
![]() |
a312127c91 | ||
![]() |
1dc5bf4f73 | ||
![]() |
01cfe670c5 | ||
![]() |
fd307bfe29 | ||
![]() |
a00de093a7 | ||
![]() |
7bfe853af3 | ||
![]() |
cbaecca8e9 | ||
![]() |
8edfb370a8 | ||
![]() |
4c08c8f7db | ||
![]() |
c174680a03 | ||
![]() |
cb5f6e18e6 | ||
![]() |
b798e7a5ae | ||
![]() |
5deab7ad27 | ||
![]() |
12cdfd282d | ||
![]() |
eba8035e12 | ||
![]() |
edcbf4350b | ||
![]() |
9289ea471f | ||
![]() |
7d06185aa6 | ||
![]() |
01ecb1d7e7 | ||
![]() |
e177f14595 | ||
![]() |
5c6eddcadd | ||
![]() |
b3b4786990 | ||
![]() |
fbe2907599 | ||
![]() |
343da8d4b3 | ||
![]() |
8d97792dbc | ||
![]() |
8d07c87be7 | ||
![]() |
ed21701df3 | ||
![]() |
df01507582 | ||
![]() |
f2bda5fd5b | ||
![]() |
cba9838e8f | ||
![]() |
b6dba9f5dd | ||
![]() |
6e9d1617c6 | ||
![]() |
ea811fee52 | ||
![]() |
7391fd8f6a | ||
![]() |
6c00c58f2a | ||
![]() |
4931fbce49 | ||
![]() |
fefc7ea600 | ||
![]() |
d220389647 | ||
![]() |
a1f910c159 | ||
![]() |
e4866563de | ||
![]() |
47f45aa229 | ||
![]() |
affe334675 | ||
![]() |
ee7e184e26 | ||
![]() |
bec0ebacf1 | ||
![]() |
5bd6d631c6 | ||
![]() |
fd1799f3bb | ||
![]() |
d84a0c51e0 | ||
![]() |
d9a7c7de51 | ||
![]() |
d57e09889a | ||
![]() |
eecb86bfb0 | ||
![]() |
0b1197936c | ||
![]() |
b545ac6391 | ||
![]() |
a922132e4a | ||
![]() |
9474e8d6d2 | ||
![]() |
6328428568 | ||
![]() |
ea9a88a9b8 | ||
![]() |
aec7358ca4 | ||
![]() |
3c334b2bb6 | ||
![]() |
75bba0da92 | ||
![]() |
c0bfe7be15 | ||
![]() |
22ac08e06d | ||
![]() |
87037136ef | ||
![]() |
2182e37433 | ||
![]() |
1de82b220d | ||
![]() |
bd878756fc | ||
![]() |
8d7f402efb | ||
![]() |
d3299beec7 | ||
![]() |
f9192db358 | ||
![]() |
c69c0c0446 | ||
![]() |
deb2911c0e | ||
![]() |
e31a306a38 | ||
![]() |
d9a7773011 | ||
![]() |
2b14916813 | ||
![]() |
1d1530e14c | ||
![]() |
b4fdc025a8 | ||
![]() |
f1c14fe0b4 | ||
![]() |
38306cda54 | ||
![]() |
5a0f0023cf | ||
![]() |
6dcdb8b821 | ||
![]() |
781f52a287 | ||
![]() |
f75ff58b4b | ||
![]() |
ae9bf16dee | ||
![]() |
17a8bf212f | ||
![]() |
4fc76afef4 | ||
![]() |
a31155a72a | ||
![]() |
75601f7924 | ||
![]() |
8b6314ccfb | ||
![]() |
6de7dc5879 |
14
.cvsignore
Normal file
14
.cvsignore
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
config.log
|
||||||
|
Makefile
|
||||||
|
libtool
|
||||||
|
Makefile.in
|
||||||
|
aclocal.m4
|
||||||
|
configure
|
||||||
|
config.h
|
||||||
|
config.status
|
||||||
|
curl-config
|
||||||
|
autom4te.cache
|
||||||
|
depcomp
|
||||||
|
config.guess
|
||||||
|
config.sub
|
||||||
|
ltmain.sh
|
1957
CHANGES.2001
Normal file
1957
CHANGES.2001
Normal file
File diff suppressed because it is too large
Load Diff
1504
CHANGES.2002
Normal file
1504
CHANGES.2002
Normal file
File diff suppressed because it is too large
Load Diff
21
COPYING
Normal file
21
COPYING
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
COPYRIGHT AND PERMISSION NOTICE
|
||||||
|
|
||||||
|
Copyright (c) 1996 - 2003, Daniel Stenberg, <daniel@haxx.se>.
|
||||||
|
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
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", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN
|
||||||
|
NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||||
|
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE
|
||||||
|
OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
Except as contained in this notice, the name of a copyright holder shall not
|
||||||
|
be used in advertising or otherwise to promote the sale, use or other dealings
|
||||||
|
in this Software without prior written authorization of the copyright holder.
|
39
CVS-INFO
39
CVS-INFO
@@ -15,8 +15,9 @@ Compile and build instructions follow below.
|
|||||||
CHANGES.0 contains ancient changes.
|
CHANGES.0 contains ancient changes.
|
||||||
CHANGES.$year contains changes for the particular year.
|
CHANGES.$year contains changes for the particular year.
|
||||||
|
|
||||||
memanalyze.pl is for analyzing the output generated by curl if -DMALLOCDEBUG
|
tests/memanalyze.pl
|
||||||
is used when compiling
|
is for analyzing the output generated by curl if -DCURLDEBUG
|
||||||
|
is used when compiling (run configure with --enable-debug)
|
||||||
|
|
||||||
buildconf builds the makefiles and configure stuff
|
buildconf builds the makefiles and configure stuff
|
||||||
|
|
||||||
@@ -30,25 +31,39 @@ To build after having extracted everything from CVS, do this:
|
|||||||
./configure
|
./configure
|
||||||
make
|
make
|
||||||
|
|
||||||
|
Daniel uses a ./configure line similar to this for easier development:
|
||||||
|
|
||||||
|
./configure --disable-shared --enable-debug --enable-maintainer-mode
|
||||||
|
|
||||||
|
|
||||||
REQUIREMENTS
|
REQUIREMENTS
|
||||||
|
|
||||||
You need the following software installed:
|
You need the following software installed:
|
||||||
|
|
||||||
o autoconf 2.50 (or later)
|
o autoconf 2.57 (or later)
|
||||||
o automake 1.5 (or later)
|
o automake 1.7 (or later)
|
||||||
o libtool 1.4 (or later)
|
o libtool 1.4.2 (or later)
|
||||||
o GNU m4 (required by autoconf)
|
o GNU m4 (required by autoconf)
|
||||||
|
|
||||||
o nroff + perl (if you don't have nroff and perl and you for some reason
|
o nroff + perl
|
||||||
don't want to install them, you can rename the source file
|
|
||||||
src/hugehelp.c.cvs to src/hugehelp.c and avoid having to generate this
|
If you don't have nroff and perl and you for some reason don't want to
|
||||||
file. This will of course give you an older version of the file that isn't
|
install them, you can rename the source file src/hugehelp.c.cvs to
|
||||||
up-to-date. That file was checked in once and won't be updated very
|
src/hugehelp.c and avoid having to generate this file. This will of course
|
||||||
regularly.)
|
give you an older version of the file that isn't up-to-date. That file was
|
||||||
|
checked in once and won't be updated very regularly.
|
||||||
|
|
||||||
|
o yacc/bison
|
||||||
|
|
||||||
|
If you don't have yacc or bison, you must rename the lib/getdate.c.cvs file
|
||||||
|
to lib/getdate.c to be able to build libcurl. yacc/bison is normally used
|
||||||
|
to generate the lib/getdate.c file from the lib/getdate.y source file.
|
||||||
|
|
||||||
MAC OS X
|
MAC OS X
|
||||||
|
|
||||||
For Mac OS X users, Guido Neitzer write down the following step-by-step guide:
|
With Mac OS X 10.2 and the associated Developer Tools, the installed versions
|
||||||
|
of the build tools are adequate. For Mac OS X 10.1 users, Guido Neitzer
|
||||||
|
wrote the following step-by-step guide:
|
||||||
|
|
||||||
1. Install fink (http://fink.sourceforge.net)
|
1. Install fink (http://fink.sourceforge.net)
|
||||||
2. Update fink to the newest version (with the installed fink)
|
2. Update fink to the newest version (with the installed fink)
|
||||||
|
25
LEGAL
25
LEGAL
@@ -1,25 +0,0 @@
|
|||||||
Copyright (C) 1998-2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
||||||
|
|
||||||
Everyone is permitted to copy and distribute verbatim copies of this license
|
|
||||||
document, but changing it is not allowed.
|
|
||||||
|
|
||||||
In order to be useful for every potential user, the curl and libcurl are
|
|
||||||
dual-licensed under the MPL and the MIT/X-derivate licenses.
|
|
||||||
|
|
||||||
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 MPL or the MIT/X-derivate licenses. You may
|
|
||||||
pick one of these licenses. The files MITX.txt and MPL-1.1.txt contain the
|
|
||||||
license texts.
|
|
||||||
|
|
||||||
As a courtesy to the open-source and free software community, we ask you to
|
|
||||||
dual-license any modifications that you make as well, under the terms of this
|
|
||||||
document.
|
|
||||||
|
|
||||||
Please remember to always keep the licensing information included in
|
|
||||||
individual source files up-to-date, so as to avoid misleading anyone as to
|
|
||||||
the status of these files.
|
|
||||||
|
|
||||||
I will use a submission policy according to which I will only enter
|
|
||||||
contributions into the CVS tree if the contributor agrees to both licenses
|
|
||||||
and this dual-license approach.
|
|
27
MITX.txt
27
MITX.txt
@@ -1,27 +0,0 @@
|
|||||||
COPYRIGHT AND PERMISSION NOTICE
|
|
||||||
|
|
||||||
Copyright (c) 1996 - 2001, Daniel Stenberg, <daniel@haxx.se>.
|
|
||||||
|
|
||||||
All rights reserved.
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, and/or sell copies of the
|
|
||||||
Software, and to permit persons to whom the Software is furnished to do so,
|
|
||||||
provided that the above copyright notice(s) and this permission notice appear
|
|
||||||
in all copies of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN
|
|
||||||
NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS NOTICE BE
|
|
||||||
LIABLE FOR ANY CLAIM, OR ANY SPECIAL 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.
|
|
||||||
|
|
||||||
Except as contained in this notice, the name of a copyright holder shall not
|
|
||||||
be used in advertising or otherwise to promote the sale, use or other dealings
|
|
||||||
in this Software without prior written authorization of the copyright holder.
|
|
||||||
|
|
470
MPL-1.1.txt
470
MPL-1.1.txt
@@ -1,470 +0,0 @@
|
|||||||
MOZILLA PUBLIC LICENSE
|
|
||||||
Version 1.1
|
|
||||||
|
|
||||||
---------------
|
|
||||||
|
|
||||||
1. Definitions.
|
|
||||||
|
|
||||||
1.0.1. "Commercial Use" means distribution or otherwise making the
|
|
||||||
Covered Code available to a third party.
|
|
||||||
|
|
||||||
1.1. "Contributor" means each entity that creates or contributes to
|
|
||||||
the creation of Modifications.
|
|
||||||
|
|
||||||
1.2. "Contributor Version" means the combination of the Original
|
|
||||||
Code, prior Modifications used by a Contributor, and the Modifications
|
|
||||||
made by that particular Contributor.
|
|
||||||
|
|
||||||
1.3. "Covered Code" means the Original Code or Modifications or the
|
|
||||||
combination of the Original Code and Modifications, in each case
|
|
||||||
including portions thereof.
|
|
||||||
|
|
||||||
1.4. "Electronic Distribution Mechanism" means a mechanism generally
|
|
||||||
accepted in the software development community for the electronic
|
|
||||||
transfer of data.
|
|
||||||
|
|
||||||
1.5. "Executable" means Covered Code in any form other than Source
|
|
||||||
Code.
|
|
||||||
|
|
||||||
1.6. "Initial Developer" means the individual or entity identified
|
|
||||||
as the Initial Developer in the Source Code notice required by Exhibit
|
|
||||||
A.
|
|
||||||
|
|
||||||
1.7. "Larger Work" means a work which combines Covered Code or
|
|
||||||
portions thereof with code not governed by the terms of this License.
|
|
||||||
|
|
||||||
1.8. "License" means this document.
|
|
||||||
|
|
||||||
1.8.1. "Licensable" means having the right to grant, to the maximum
|
|
||||||
extent possible, whether at the time of the initial grant or
|
|
||||||
subsequently acquired, any and all of the rights conveyed herein.
|
|
||||||
|
|
||||||
1.9. "Modifications" means any addition to or deletion from the
|
|
||||||
substance or structure of either the Original Code or any previous
|
|
||||||
Modifications. When Covered Code is released as a series of files, a
|
|
||||||
Modification is:
|
|
||||||
A. Any addition to or deletion from the contents of a file
|
|
||||||
containing Original Code or previous Modifications.
|
|
||||||
|
|
||||||
B. Any new file that contains any part of the Original Code or
|
|
||||||
previous Modifications.
|
|
||||||
|
|
||||||
1.10. "Original Code" means Source Code of computer software code
|
|
||||||
which is described in the Source Code notice required by Exhibit A as
|
|
||||||
Original Code, and which, at the time of its release under this
|
|
||||||
License is not already Covered Code governed by this License.
|
|
||||||
|
|
||||||
1.10.1. "Patent Claims" means any patent claim(s), now owned or
|
|
||||||
hereafter acquired, including without limitation, method, process,
|
|
||||||
and apparatus claims, in any patent Licensable by grantor.
|
|
||||||
|
|
||||||
1.11. "Source Code" means the preferred form of the Covered Code for
|
|
||||||
making modifications to it, including all modules it contains, plus
|
|
||||||
any associated interface definition files, scripts used to control
|
|
||||||
compilation and installation of an Executable, or source code
|
|
||||||
differential comparisons against either the Original Code or another
|
|
||||||
well known, available Covered Code of the Contributor's choice. The
|
|
||||||
Source Code can be in a compressed or archival form, provided the
|
|
||||||
appropriate decompression or de-archiving software is widely available
|
|
||||||
for no charge.
|
|
||||||
|
|
||||||
1.12. "You" (or "Your") means an individual or a legal entity
|
|
||||||
exercising rights under, and complying with all of the terms of, this
|
|
||||||
License or a future version of this License issued under Section 6.1.
|
|
||||||
For legal entities, "You" includes any entity which controls, is
|
|
||||||
controlled by, or is under common control with You. For purposes of
|
|
||||||
this definition, "control" means (a) the power, direct or indirect,
|
|
||||||
to cause the direction or management of such entity, whether by
|
|
||||||
contract or otherwise, or (b) ownership of more than fifty percent
|
|
||||||
(50%) of the outstanding shares or beneficial ownership of such
|
|
||||||
entity.
|
|
||||||
|
|
||||||
2. Source Code License.
|
|
||||||
|
|
||||||
2.1. The Initial Developer Grant.
|
|
||||||
The Initial Developer hereby grants You a world-wide, royalty-free,
|
|
||||||
non-exclusive license, subject to third party intellectual property
|
|
||||||
claims:
|
|
||||||
(a) under intellectual property rights (other than patent or
|
|
||||||
trademark) Licensable by Initial Developer to use, reproduce,
|
|
||||||
modify, display, perform, sublicense and distribute the Original
|
|
||||||
Code (or portions thereof) with or without Modifications, and/or
|
|
||||||
as part of a Larger Work; and
|
|
||||||
|
|
||||||
(b) under Patents Claims infringed by the making, using or
|
|
||||||
selling of Original Code, to make, have made, use, practice,
|
|
||||||
sell, and offer for sale, and/or otherwise dispose of the
|
|
||||||
Original Code (or portions thereof).
|
|
||||||
|
|
||||||
(c) the licenses granted in this Section 2.1(a) and (b) are
|
|
||||||
effective on the date Initial Developer first distributes
|
|
||||||
Original Code under the terms of this License.
|
|
||||||
|
|
||||||
(d) Notwithstanding Section 2.1(b) above, no patent license is
|
|
||||||
granted: 1) for code that You delete from the Original Code; 2)
|
|
||||||
separate from the Original Code; or 3) for infringements caused
|
|
||||||
by: i) the modification of the Original Code or ii) the
|
|
||||||
combination of the Original Code with other software or devices.
|
|
||||||
|
|
||||||
2.2. Contributor Grant.
|
|
||||||
Subject to third party intellectual property claims, each Contributor
|
|
||||||
hereby grants You a world-wide, royalty-free, non-exclusive license
|
|
||||||
|
|
||||||
(a) under intellectual property rights (other than patent or
|
|
||||||
trademark) Licensable by Contributor, to use, reproduce, modify,
|
|
||||||
display, perform, sublicense and distribute the Modifications
|
|
||||||
created by such Contributor (or portions thereof) either on an
|
|
||||||
unmodified basis, with other Modifications, as Covered Code
|
|
||||||
and/or as part of a Larger Work; and
|
|
||||||
|
|
||||||
(b) under Patent Claims infringed by the making, using, or
|
|
||||||
selling of Modifications made by that Contributor either alone
|
|
||||||
and/or in combination with its Contributor Version (or portions
|
|
||||||
of such combination), to make, use, sell, offer for sale, have
|
|
||||||
made, and/or otherwise dispose of: 1) Modifications made by that
|
|
||||||
Contributor (or portions thereof); and 2) the combination of
|
|
||||||
Modifications made by that Contributor with its Contributor
|
|
||||||
Version (or portions of such combination).
|
|
||||||
|
|
||||||
(c) the licenses granted in Sections 2.2(a) and 2.2(b) are
|
|
||||||
effective on the date Contributor first makes Commercial Use of
|
|
||||||
the Covered Code.
|
|
||||||
|
|
||||||
(d) Notwithstanding Section 2.2(b) above, no patent license is
|
|
||||||
granted: 1) for any code that Contributor has deleted from the
|
|
||||||
Contributor Version; 2) separate from the Contributor Version;
|
|
||||||
3) for infringements caused by: i) third party modifications of
|
|
||||||
Contributor Version or ii) the combination of Modifications made
|
|
||||||
by that Contributor with other software (except as part of the
|
|
||||||
Contributor Version) or other devices; or 4) under Patent Claims
|
|
||||||
infringed by Covered Code in the absence of Modifications made by
|
|
||||||
that Contributor.
|
|
||||||
|
|
||||||
3. Distribution Obligations.
|
|
||||||
|
|
||||||
3.1. Application of License.
|
|
||||||
The Modifications which You create or to which You contribute are
|
|
||||||
governed by the terms of this License, including without limitation
|
|
||||||
Section 2.2. The Source Code version of Covered Code may be
|
|
||||||
distributed only under the terms of this License or a future version
|
|
||||||
of this License released under Section 6.1, and You must include a
|
|
||||||
copy of this License with every copy of the Source Code You
|
|
||||||
distribute. You may not offer or impose any terms on any Source Code
|
|
||||||
version that alters or restricts the applicable version of this
|
|
||||||
License or the recipients' rights hereunder. However, You may include
|
|
||||||
an additional document offering the additional rights described in
|
|
||||||
Section 3.5.
|
|
||||||
|
|
||||||
3.2. Availability of Source Code.
|
|
||||||
Any Modification which You create or to which You contribute must be
|
|
||||||
made available in Source Code form under the terms of this License
|
|
||||||
either on the same media as an Executable version or via an accepted
|
|
||||||
Electronic Distribution Mechanism to anyone to whom you made an
|
|
||||||
Executable version available; and if made available via Electronic
|
|
||||||
Distribution Mechanism, must remain available for at least twelve (12)
|
|
||||||
months after the date it initially became available, or at least six
|
|
||||||
(6) months after a subsequent version of that particular Modification
|
|
||||||
has been made available to such recipients. You are responsible for
|
|
||||||
ensuring that the Source Code version remains available even if the
|
|
||||||
Electronic Distribution Mechanism is maintained by a third party.
|
|
||||||
|
|
||||||
3.3. Description of Modifications.
|
|
||||||
You must cause all Covered Code to which You contribute to contain a
|
|
||||||
file documenting the changes You made to create that Covered Code and
|
|
||||||
the date of any change. You must include a prominent statement that
|
|
||||||
the Modification is derived, directly or indirectly, from Original
|
|
||||||
Code provided by the Initial Developer and including the name of the
|
|
||||||
Initial Developer in (a) the Source Code, and (b) in any notice in an
|
|
||||||
Executable version or related documentation in which You describe the
|
|
||||||
origin or ownership of the Covered Code.
|
|
||||||
|
|
||||||
3.4. Intellectual Property Matters
|
|
||||||
(a) Third Party Claims.
|
|
||||||
If Contributor has knowledge that a license under a third party's
|
|
||||||
intellectual property rights is required to exercise the rights
|
|
||||||
granted by such Contributor under Sections 2.1 or 2.2,
|
|
||||||
Contributor must include a text file with the Source Code
|
|
||||||
distribution titled "LEGAL" which describes the claim and the
|
|
||||||
party making the claim in sufficient detail that a recipient will
|
|
||||||
know whom to contact. If Contributor obtains such knowledge after
|
|
||||||
the Modification is made available as described in Section 3.2,
|
|
||||||
Contributor shall promptly modify the LEGAL file in all copies
|
|
||||||
Contributor makes available thereafter and shall take other steps
|
|
||||||
(such as notifying appropriate mailing lists or newsgroups)
|
|
||||||
reasonably calculated to inform those who received the Covered
|
|
||||||
Code that new knowledge has been obtained.
|
|
||||||
|
|
||||||
(b) Contributor APIs.
|
|
||||||
If Contributor's Modifications include an application programming
|
|
||||||
interface and Contributor has knowledge of patent licenses which
|
|
||||||
are reasonably necessary to implement that API, Contributor must
|
|
||||||
also include this information in the LEGAL file.
|
|
||||||
|
|
||||||
(c) Representations.
|
|
||||||
Contributor represents that, except as disclosed pursuant to
|
|
||||||
Section 3.4(a) above, Contributor believes that Contributor's
|
|
||||||
Modifications are Contributor's original creation(s) and/or
|
|
||||||
Contributor has sufficient rights to grant the rights conveyed by
|
|
||||||
this License.
|
|
||||||
|
|
||||||
3.5. Required Notices.
|
|
||||||
You must duplicate the notice in Exhibit A in each file of the Source
|
|
||||||
Code. If it is not possible to put such notice in a particular Source
|
|
||||||
Code file due to its structure, then You must include such notice in a
|
|
||||||
location (such as a relevant directory) where a user would be likely
|
|
||||||
to look for such a notice. If You created one or more Modification(s)
|
|
||||||
You may add your name as a Contributor to the notice described in
|
|
||||||
Exhibit A. You must also duplicate this License in any documentation
|
|
||||||
for the Source Code where You describe recipients' rights or ownership
|
|
||||||
rights relating to Covered Code. You may choose to offer, and to
|
|
||||||
charge a fee for, warranty, support, indemnity or liability
|
|
||||||
obligations to one or more recipients of Covered Code. However, You
|
|
||||||
may do so only on Your own behalf, and not on behalf of the Initial
|
|
||||||
Developer or any Contributor. You must make it absolutely clear than
|
|
||||||
any such warranty, support, indemnity or liability obligation is
|
|
||||||
offered by You alone, and You hereby agree to indemnify the Initial
|
|
||||||
Developer and every Contributor for any liability incurred by the
|
|
||||||
Initial Developer or such Contributor as a result of warranty,
|
|
||||||
support, indemnity or liability terms You offer.
|
|
||||||
|
|
||||||
3.6. Distribution of Executable Versions.
|
|
||||||
You may distribute Covered Code in Executable form only if the
|
|
||||||
requirements of Section 3.1-3.5 have been met for that Covered Code,
|
|
||||||
and if You include a notice stating that the Source Code version of
|
|
||||||
the Covered Code is available under the terms of this License,
|
|
||||||
including a description of how and where You have fulfilled the
|
|
||||||
obligations of Section 3.2. The notice must be conspicuously included
|
|
||||||
in any notice in an Executable version, related documentation or
|
|
||||||
collateral in which You describe recipients' rights relating to the
|
|
||||||
Covered Code. You may distribute the Executable version of Covered
|
|
||||||
Code or ownership rights under a license of Your choice, which may
|
|
||||||
contain terms different from this License, provided that You are in
|
|
||||||
compliance with the terms of this License and that the license for the
|
|
||||||
Executable version does not attempt to limit or alter the recipient's
|
|
||||||
rights in the Source Code version from the rights set forth in this
|
|
||||||
License. If You distribute the Executable version under a different
|
|
||||||
license You must make it absolutely clear that any terms which differ
|
|
||||||
from this License are offered by You alone, not by the Initial
|
|
||||||
Developer or any Contributor. You hereby agree to indemnify the
|
|
||||||
Initial Developer and every Contributor for any liability incurred by
|
|
||||||
the Initial Developer or such Contributor as a result of any such
|
|
||||||
terms You offer.
|
|
||||||
|
|
||||||
3.7. Larger Works.
|
|
||||||
You may create a Larger Work by combining Covered Code with other code
|
|
||||||
not governed by the terms of this License and distribute the Larger
|
|
||||||
Work as a single product. In such a case, You must make sure the
|
|
||||||
requirements of this License are fulfilled for the Covered Code.
|
|
||||||
|
|
||||||
4. Inability to Comply Due to Statute or Regulation.
|
|
||||||
|
|
||||||
If it is impossible for You to comply with any of the terms of this
|
|
||||||
License with respect to some or all of the Covered Code due to
|
|
||||||
statute, judicial order, or regulation then You must: (a) comply with
|
|
||||||
the terms of this License to the maximum extent possible; and (b)
|
|
||||||
describe the limitations and the code they affect. Such description
|
|
||||||
must be included in the LEGAL file described in Section 3.4 and must
|
|
||||||
be included with all distributions of the Source Code. Except to the
|
|
||||||
extent prohibited by statute or regulation, such description must be
|
|
||||||
sufficiently detailed for a recipient of ordinary skill to be able to
|
|
||||||
understand it.
|
|
||||||
|
|
||||||
5. Application of this License.
|
|
||||||
|
|
||||||
This License applies to code to which the Initial Developer has
|
|
||||||
attached the notice in Exhibit A and to related Covered Code.
|
|
||||||
|
|
||||||
6. Versions of the License.
|
|
||||||
|
|
||||||
6.1. New Versions.
|
|
||||||
Netscape Communications Corporation ("Netscape") may publish revised
|
|
||||||
and/or new versions of the License from time to time. Each version
|
|
||||||
will be given a distinguishing version number.
|
|
||||||
|
|
||||||
6.2. Effect of New Versions.
|
|
||||||
Once Covered Code has been published under a particular version of the
|
|
||||||
License, You may always continue to use it under the terms of that
|
|
||||||
version. You may also choose to use such Covered Code under the terms
|
|
||||||
of any subsequent version of the License published by Netscape. No one
|
|
||||||
other than Netscape has the right to modify the terms applicable to
|
|
||||||
Covered Code created under this License.
|
|
||||||
|
|
||||||
6.3. Derivative Works.
|
|
||||||
If You create or use a modified version of this License (which you may
|
|
||||||
only do in order to apply it to code which is not already Covered Code
|
|
||||||
governed by this License), You must (a) rename Your license so that
|
|
||||||
the phrases "Mozilla", "MOZILLAPL", "MOZPL", "Netscape",
|
|
||||||
"MPL", "NPL" or any confusingly similar phrase do not appear in your
|
|
||||||
license (except to note that your license differs from this License)
|
|
||||||
and (b) otherwise make it clear that Your version of the license
|
|
||||||
contains terms which differ from the Mozilla Public License and
|
|
||||||
Netscape Public License. (Filling in the name of the Initial
|
|
||||||
Developer, Original Code or Contributor in the notice described in
|
|
||||||
Exhibit A shall not of themselves be deemed to be modifications of
|
|
||||||
this License.)
|
|
||||||
|
|
||||||
7. DISCLAIMER OF WARRANTY.
|
|
||||||
|
|
||||||
COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
||||||
WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE IS FREE OF
|
|
||||||
DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING.
|
|
||||||
THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE
|
|
||||||
IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT,
|
|
||||||
YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE
|
|
||||||
COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER
|
|
||||||
OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF
|
|
||||||
ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER.
|
|
||||||
|
|
||||||
8. TERMINATION.
|
|
||||||
|
|
||||||
8.1. This License and the rights granted hereunder will terminate
|
|
||||||
automatically if You fail to comply with terms herein and fail to cure
|
|
||||||
such breach within 30 days of becoming aware of the breach. All
|
|
||||||
sublicenses to the Covered Code which are properly granted shall
|
|
||||||
survive any termination of this License. Provisions which, by their
|
|
||||||
nature, must remain in effect beyond the termination of this License
|
|
||||||
shall survive.
|
|
||||||
|
|
||||||
8.2. If You initiate litigation by asserting a patent infringement
|
|
||||||
claim (excluding declatory judgment actions) against Initial Developer
|
|
||||||
or a Contributor (the Initial Developer or Contributor against whom
|
|
||||||
You file such action is referred to as "Participant") alleging that:
|
|
||||||
|
|
||||||
(a) such Participant's Contributor Version directly or indirectly
|
|
||||||
infringes any patent, then any and all rights granted by such
|
|
||||||
Participant to You under Sections 2.1 and/or 2.2 of this License
|
|
||||||
shall, upon 60 days notice from Participant terminate prospectively,
|
|
||||||
unless if within 60 days after receipt of notice You either: (i)
|
|
||||||
agree in writing to pay Participant a mutually agreeable reasonable
|
|
||||||
royalty for Your past and future use of Modifications made by such
|
|
||||||
Participant, or (ii) withdraw Your litigation claim with respect to
|
|
||||||
the Contributor Version against such Participant. If within 60 days
|
|
||||||
of notice, a reasonable royalty and payment arrangement are not
|
|
||||||
mutually agreed upon in writing by the parties or the litigation claim
|
|
||||||
is not withdrawn, the rights granted by Participant to You under
|
|
||||||
Sections 2.1 and/or 2.2 automatically terminate at the expiration of
|
|
||||||
the 60 day notice period specified above.
|
|
||||||
|
|
||||||
(b) any software, hardware, or device, other than such Participant's
|
|
||||||
Contributor Version, directly or indirectly infringes any patent, then
|
|
||||||
any rights granted to You by such Participant under Sections 2.1(b)
|
|
||||||
and 2.2(b) are revoked effective as of the date You first made, used,
|
|
||||||
sold, distributed, or had made, Modifications made by that
|
|
||||||
Participant.
|
|
||||||
|
|
||||||
8.3. If You assert a patent infringement claim against Participant
|
|
||||||
alleging that such Participant's Contributor Version directly or
|
|
||||||
indirectly infringes any patent where such claim is resolved (such as
|
|
||||||
by license or settlement) prior to the initiation of patent
|
|
||||||
infringement litigation, then the reasonable value of the licenses
|
|
||||||
granted by such Participant under Sections 2.1 or 2.2 shall be taken
|
|
||||||
into account in determining the amount or value of any payment or
|
|
||||||
license.
|
|
||||||
|
|
||||||
8.4. In the event of termination under Sections 8.1 or 8.2 above,
|
|
||||||
all end user license agreements (excluding distributors and resellers)
|
|
||||||
which have been validly granted by You or any distributor hereunder
|
|
||||||
prior to termination shall survive termination.
|
|
||||||
|
|
||||||
9. LIMITATION OF LIABILITY.
|
|
||||||
|
|
||||||
UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT
|
|
||||||
(INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL
|
|
||||||
DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED CODE,
|
|
||||||
OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR
|
|
||||||
ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY
|
|
||||||
CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL,
|
|
||||||
WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER
|
|
||||||
COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN
|
|
||||||
INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF
|
|
||||||
LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY
|
|
||||||
RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW
|
|
||||||
PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE
|
|
||||||
EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO
|
|
||||||
THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU.
|
|
||||||
|
|
||||||
10. U.S. GOVERNMENT END USERS.
|
|
||||||
|
|
||||||
The Covered Code is a "commercial item," as that term is defined in
|
|
||||||
48 C.F.R. 2.101 (Oct. 1995), consisting of "commercial computer
|
|
||||||
software" and "commercial computer software documentation," as such
|
|
||||||
terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48
|
|
||||||
C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995),
|
|
||||||
all U.S. Government End Users acquire Covered Code with only those
|
|
||||||
rights set forth herein.
|
|
||||||
|
|
||||||
11. MISCELLANEOUS.
|
|
||||||
|
|
||||||
This License represents the complete agreement concerning subject
|
|
||||||
matter hereof. If any provision of this License is held to be
|
|
||||||
unenforceable, such provision shall be reformed only to the extent
|
|
||||||
necessary to make it enforceable. This License shall be governed by
|
|
||||||
California law provisions (except to the extent applicable law, if
|
|
||||||
any, provides otherwise), excluding its conflict-of-law provisions.
|
|
||||||
With respect to disputes in which at least one party is a citizen of,
|
|
||||||
or an entity chartered or registered to do business in the United
|
|
||||||
States of America, any litigation relating to this License shall be
|
|
||||||
subject to the jurisdiction of the Federal Courts of the Northern
|
|
||||||
District of California, with venue lying in Santa Clara County,
|
|
||||||
California, with the losing party responsible for costs, including
|
|
||||||
without limitation, court costs and reasonable attorneys' fees and
|
|
||||||
expenses. The application of the United Nations Convention on
|
|
||||||
Contracts for the International Sale of Goods is expressly excluded.
|
|
||||||
Any law or regulation which provides that the language of a contract
|
|
||||||
shall be construed against the drafter shall not apply to this
|
|
||||||
License.
|
|
||||||
|
|
||||||
12. RESPONSIBILITY FOR CLAIMS.
|
|
||||||
|
|
||||||
As between Initial Developer and the Contributors, each party is
|
|
||||||
responsible for claims and damages arising, directly or indirectly,
|
|
||||||
out of its utilization of rights under this License and You agree to
|
|
||||||
work with Initial Developer and Contributors to distribute such
|
|
||||||
responsibility on an equitable basis. Nothing herein is intended or
|
|
||||||
shall be deemed to constitute any admission of liability.
|
|
||||||
|
|
||||||
13. MULTIPLE-LICENSED CODE.
|
|
||||||
|
|
||||||
Initial Developer may designate portions of the Covered Code as
|
|
||||||
"Multiple-Licensed". "Multiple-Licensed" means that the Initial
|
|
||||||
Developer permits you to utilize portions of the Covered Code under
|
|
||||||
Your choice of the NPL or the alternative licenses, if any, specified
|
|
||||||
by the Initial Developer in the file described in Exhibit A.
|
|
||||||
|
|
||||||
EXHIBIT A -Mozilla Public License.
|
|
||||||
|
|
||||||
``The contents of this file are subject to the Mozilla Public License
|
|
||||||
Version 1.1 (the "License"); you may not use this file except in
|
|
||||||
compliance with the License. You may obtain a copy of the License at
|
|
||||||
http://www.mozilla.org/MPL/
|
|
||||||
|
|
||||||
Software distributed under the License is distributed on an "AS IS"
|
|
||||||
basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
|
||||||
License for the specific language governing rights and limitations
|
|
||||||
under the License.
|
|
||||||
|
|
||||||
The Original Code is ______________________________________.
|
|
||||||
|
|
||||||
The Initial Developer of the Original Code is ________________________.
|
|
||||||
Portions created by ______________________ are Copyright (C) ______
|
|
||||||
_______________________. All Rights Reserved.
|
|
||||||
|
|
||||||
Contributor(s): ______________________________________.
|
|
||||||
|
|
||||||
Alternatively, the contents of this file may be used under the terms
|
|
||||||
of the _____ license (the "[___] License"), in which case the
|
|
||||||
provisions of [______] License are applicable instead of those
|
|
||||||
above. If you wish to allow use of your version of this file only
|
|
||||||
under the terms of the [____] License and not to allow others to use
|
|
||||||
your version of this file under the MPL, indicate your decision by
|
|
||||||
deleting the provisions above and replace them with the notice and
|
|
||||||
other provisions required by the [___] License. If you do not delete
|
|
||||||
the provisions above, a recipient may use your version of this file
|
|
||||||
under either the MPL or the [___] License."
|
|
||||||
|
|
||||||
[NOTE: The text of this Exhibit A may differ slightly from the text of
|
|
||||||
the notices in the Source Code files of the Original Code. You should
|
|
||||||
use the text of this Exhibit A rather than the text found in the
|
|
||||||
Original Code Source Code for Your Modifications.]
|
|
||||||
|
|
32
Makefile.am
32
Makefile.am
@@ -2,28 +2,34 @@
|
|||||||
# $Id$
|
# $Id$
|
||||||
#
|
#
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = CHANGES COPYING maketgz reconf Makefile.dist \
|
||||||
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
curl-config.in build_vms.com curl-style.el sample.emacs testcurl.sh
|
||||||
reconf Makefile.dist curl-config.in build_vms.com curl-mode.el \
|
|
||||||
config-vms.h config-win32.h config-riscos.h config-mac.h
|
|
||||||
|
|
||||||
bin_SCRIPTS = curl-config
|
bin_SCRIPTS = curl-config
|
||||||
|
|
||||||
SUBDIRS = docs lib src include tests packages
|
SUBDIRS = lib src
|
||||||
|
DIST_SUBDIRS = $(SUBDIRS) tests include packages docs
|
||||||
|
|
||||||
# create a root makefile in the distribution:
|
# create a root makefile in the distribution:
|
||||||
dist-hook:
|
dist-hook:
|
||||||
|
rm -rf $(top_builddir)/tests/log
|
||||||
cp $(srcdir)/Makefile.dist $(distdir)/Makefile
|
cp $(srcdir)/Makefile.dist $(distdir)/Makefile
|
||||||
|
|
||||||
html:
|
html:
|
||||||
cd docs; make html
|
cd docs; make html
|
||||||
|
|
||||||
|
pdf:
|
||||||
|
cd docs; make pdf
|
||||||
|
|
||||||
check: test
|
check: test
|
||||||
|
|
||||||
test:
|
test:
|
||||||
@(cd tests; $(MAKE) quiet-test)
|
@(cd tests; $(MAKE) all quiet-test)
|
||||||
|
|
||||||
|
test-full:
|
||||||
|
@(cd tests; $(MAKE) all full-test)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros
|
# Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros
|
||||||
@@ -64,7 +70,7 @@ rpm:
|
|||||||
pkgadd:
|
pkgadd:
|
||||||
umask 022 ; \
|
umask 022 ; \
|
||||||
make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \
|
make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \
|
||||||
cat LEGAL MITX.txt MPL-1.1.txt > $(srcdir)/packages/Solaris/copyright ; \
|
cat COPYING > $(srcdir)/packages/Solaris/copyright ; \
|
||||||
cd $(srcdir)/packages/Solaris && $(MAKE) package
|
cd $(srcdir)/packages/Solaris && $(MAKE) package
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -72,3 +78,13 @@ pkgadd:
|
|||||||
# resulting .tar.bz2 file will end up at packages/Win32/cygwin
|
# resulting .tar.bz2 file will end up at packages/Win32/cygwin
|
||||||
cygwinbin:
|
cygwinbin:
|
||||||
$(MAKE) -C packages/Win32/cygwin cygwinbin
|
$(MAKE) -C packages/Win32/cygwin cygwinbin
|
||||||
|
|
||||||
|
# We extend the standard install with a custom hook:
|
||||||
|
install-data-hook:
|
||||||
|
cd include && $(MAKE) install
|
||||||
|
cd docs && $(MAKE) install
|
||||||
|
|
||||||
|
# We extend the standard uninstall with a custom hook:
|
||||||
|
uninstall-hook:
|
||||||
|
cd include && $(MAKE) uninstall
|
||||||
|
cd docs && $(MAKE) uninstall
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 2002, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# In order to be useful for every potential user, curl and libcurl are
|
# In order to be useful for every potential user, curl and libcurl are
|
||||||
# dual-licensed under the MPL and the MIT/X-derivate licenses.
|
# dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
@@ -34,12 +34,12 @@ borland:
|
|||||||
cd src & make -f Makefile.b32
|
cd src & make -f Makefile.b32
|
||||||
|
|
||||||
mingw32:
|
mingw32:
|
||||||
cd lib & make -f Makefile.m32
|
cd lib & make -f Makefile.m32 ZLIB=1
|
||||||
cd src & make -f Makefile.m32
|
cd src & make -f Makefile.m32 ZLIB=1
|
||||||
|
|
||||||
mingw32-ssl:
|
mingw32-ssl:
|
||||||
cd lib & make -f Makefile.m32 SSL=1
|
cd lib & make -f Makefile.m32 SSL=1 ZLIB=1
|
||||||
cd src & make -f Makefile.m32 SSL=1
|
cd src & make -f Makefile.m32 SSL=1 ZLIB=1
|
||||||
|
|
||||||
vc:
|
vc:
|
||||||
cd lib
|
cd lib
|
||||||
@@ -51,8 +51,18 @@ vc-ssl:
|
|||||||
cd lib
|
cd lib
|
||||||
nmake -f Makefile.vc6 cfg=release-ssl
|
nmake -f Makefile.vc6 cfg=release-ssl
|
||||||
cd ..\src
|
cd ..\src
|
||||||
|
nmake -f Makefile.vc6 cfg=release-ssl
|
||||||
|
|
||||||
|
vc-ssl-dll:
|
||||||
|
cd lib
|
||||||
|
nmake -f Makefile.vc6 cfg=release-ssl-dll
|
||||||
|
cd ..\src
|
||||||
nmake -f Makefile.vc6
|
nmake -f Makefile.vc6
|
||||||
|
|
||||||
|
djgpp:
|
||||||
|
make -C lib -f Makefile.dj
|
||||||
|
make -C src -f Makefile.dj
|
||||||
|
|
||||||
cygwin:
|
cygwin:
|
||||||
./configure
|
./configure
|
||||||
make
|
make
|
||||||
|
40
README
40
README
@@ -11,38 +11,60 @@ README
|
|||||||
MANUAL document. Find out how to install Curl by reading the INSTALL
|
MANUAL document. Find out how to install Curl by reading the INSTALL
|
||||||
document.
|
document.
|
||||||
|
|
||||||
libcurl is a library that Curl is using to do its job. It is readily
|
libcurl is the library curl is using to do its job. It is readily
|
||||||
available to be used by your software. Read the libcurl.3 man page to
|
available to be used by your software. Read the libcurl.3 man page to
|
||||||
find out how!
|
learn how!
|
||||||
|
|
||||||
You find answers to the most frequent questions we get in the FAQ document.
|
You find answers to the most frequent questions we get in the FAQ document.
|
||||||
|
|
||||||
Study the LEGAL file for distribution terms and similar.
|
Study the COPYING file for distribution terms and similar.
|
||||||
|
|
||||||
Always try the Curl web site for the latest news:
|
CONTACT
|
||||||
|
|
||||||
http://curl.haxx.se
|
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.
|
||||||
|
|
||||||
|
WEB SITE
|
||||||
|
|
||||||
|
Visit the curl web site or mirrors for the latest news:
|
||||||
|
|
||||||
|
Sweden -- http://curl.haxx.se/
|
||||||
|
Russia -- http://curl.tsuren.net/
|
||||||
|
US -- http://curl.sf.net/
|
||||||
|
Australia -- http://curl.planetmirror.com/
|
||||||
|
|
||||||
|
DOWNLOAD
|
||||||
|
|
||||||
The official download mirror sites are:
|
The official download mirror sites are:
|
||||||
|
|
||||||
Sweden -- ftp://ftp.sunet.se/pub/www/utilities/curl/
|
Sweden -- ftp://ftp.sunet.se/pub/www/utilities/curl/
|
||||||
Sweden -- http://cool.haxx.se/curl/
|
Sweden -- http://cool.haxx.se/curl/
|
||||||
Germany -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/
|
Germany -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/
|
||||||
|
Australia -- http://curl.planetmirror.com/download/
|
||||||
|
US -- http://curl.sourceforge.net/download/
|
||||||
|
Hongkong -- http://www.execve.net/curl/
|
||||||
|
Russia -- http://curl.tsuren.net/download/
|
||||||
|
|
||||||
|
CVS
|
||||||
|
|
||||||
To download the very latest source off the CVS server do this:
|
To download the very latest source off the CVS server do this:
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl login
|
cvs -d :pserver:cvsread@cvs.php.net:/repository login
|
||||||
|
|
||||||
(just press enter when asked for password)
|
(enter "phpfi" when asked for password)
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl co curl
|
cvs -d :pserver:cvsread@cvs.php.net:/repository co curl
|
||||||
|
|
||||||
(you'll get a directory named curl created, filled with the source code)
|
(you'll get a directory named curl created, filled with the source code)
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl logout
|
cvs -d :pserver:cvsread@cvs.php.net:/repository logout
|
||||||
|
|
||||||
(you're off the hook!)
|
(you're off the hook!)
|
||||||
|
|
||||||
|
NOTICE
|
||||||
|
|
||||||
Curl contains pieces of source code that is Copyright (c) 1998, 1999
|
Curl contains pieces of source code that is Copyright (c) 1998, 1999
|
||||||
Kungliga Tekniska H<>gskolan. This notice is included here to comply with the
|
Kungliga Tekniska H<>gskolan. This notice is included here to comply with the
|
||||||
distribution terms.
|
distribution terms.
|
||||||
|
66
acconfig.h
66
acconfig.h
@@ -1,66 +0,0 @@
|
|||||||
/* Name of this package! */
|
|
||||||
#undef PACKAGE
|
|
||||||
|
|
||||||
/* Version number of this archive. */
|
|
||||||
#undef VERSION
|
|
||||||
|
|
||||||
/* Define if you have the getpass function. */
|
|
||||||
#undef HAVE_GETPASS
|
|
||||||
|
|
||||||
/* Define cpu-machine-OS */
|
|
||||||
#undef OS
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R_5
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 7 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R_7
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 8 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R_8
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r() function with 3 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R_3
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r() function with 5 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R_5
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r() function with 6 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R_6
|
|
||||||
|
|
||||||
/* Define if you have the inet_ntoa_r function declared. */
|
|
||||||
#undef HAVE_INET_NTOA_R_DECL
|
|
||||||
|
|
||||||
/* Define if you need the _REENTRANT define for some functions */
|
|
||||||
#undef NEED_REENTRANT
|
|
||||||
|
|
||||||
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
|
||||||
#undef KRB4
|
|
||||||
|
|
||||||
/* Define if you want to enable IPv6 support */
|
|
||||||
#undef ENABLE_IPV6
|
|
||||||
|
|
||||||
/* Define this to 'int' if ssize_t is not an available typedefed type */
|
|
||||||
#undef ssize_t
|
|
||||||
|
|
||||||
/* Define this to 'int' if socklen_t is not an available typedefed type */
|
|
||||||
#undef socklen_t
|
|
||||||
|
|
||||||
/* Define this as a suitable file to read random data from */
|
|
||||||
#undef RANDOM_FILE
|
|
||||||
|
|
||||||
/* Define this to your Entropy Gathering Daemon socket pathname */
|
|
||||||
#undef EGD_SOCKET
|
|
||||||
|
|
||||||
/* Define if you have a working OpenSSL installation */
|
|
||||||
#undef OPENSSL_ENABLED
|
|
||||||
|
|
||||||
/* Define the one correct non-blocking socket method below */
|
|
||||||
#undef HAVE_FIONBIO
|
|
||||||
#undef HAVE_IOCTLSOCKET
|
|
||||||
#undef HAVE_IOCTLSOCKET_CASE
|
|
||||||
#undef HAVE_O_NONBLOCK
|
|
||||||
#undef HAVE_DISABLED_NONBLOCKING
|
|
||||||
|
|
||||||
/* Define this to 'int' if in_addr_t is not an available typedefed type */
|
|
||||||
#undef in_addr_t
|
|
44
acinclude.m4
44
acinclude.m4
@@ -38,7 +38,7 @@ AC_DEFUN(CURL_CHECK_NONBLOCKING_SOCKET,
|
|||||||
],[
|
],[
|
||||||
dnl the O_NONBLOCK test was fine
|
dnl the O_NONBLOCK test was fine
|
||||||
nonblock="O_NONBLOCK"
|
nonblock="O_NONBLOCK"
|
||||||
AC_DEFINE(HAVE_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
|
dnl the code was bad, try a different program now, test 2
|
||||||
|
|
||||||
@@ -52,7 +52,7 @@ dnl the code was bad, try a different program now, test 2
|
|||||||
],[
|
],[
|
||||||
dnl FIONBIO test was good
|
dnl FIONBIO test was good
|
||||||
nonblock="FIONBIO"
|
nonblock="FIONBIO"
|
||||||
AC_DEFINE(HAVE_FIONBIO)
|
AC_DEFINE(HAVE_FIONBIO, 1, [use FIONBIO for non-blocking sockets])
|
||||||
],[
|
],[
|
||||||
dnl FIONBIO test was also bad
|
dnl FIONBIO test was also bad
|
||||||
dnl the code was bad, try a different program now, test 3
|
dnl the code was bad, try a different program now, test 3
|
||||||
@@ -66,7 +66,7 @@ dnl the code was bad, try a different program now, test 3
|
|||||||
],[
|
],[
|
||||||
dnl ioctlsocket test was good
|
dnl ioctlsocket test was good
|
||||||
nonblock="ioctlsocket"
|
nonblock="ioctlsocket"
|
||||||
AC_DEFINE(HAVE_IOCTLSOCKET)
|
AC_DEFINE(HAVE_IOCTLSOCKET, 1, [use ioctlsocket() for non-blocking sockets])
|
||||||
],[
|
],[
|
||||||
dnl ioctlsocket didnt compile!
|
dnl ioctlsocket didnt compile!
|
||||||
|
|
||||||
@@ -79,11 +79,11 @@ dnl ioctlsocket didnt compile!
|
|||||||
],[
|
],[
|
||||||
dnl ioctlsocket test was good
|
dnl ioctlsocket test was good
|
||||||
nonblock="IoctlSocket"
|
nonblock="IoctlSocket"
|
||||||
AC_DEFINE(HAVE_IOCTLSOCKET_CASE)
|
AC_DEFINE(HAVE_IOCTLSOCKET_CASE, 1, [use Ioctlsocket() for non-blocking sockets])
|
||||||
],[
|
],[
|
||||||
dnl ioctlsocket didnt compile!
|
dnl ioctlsocket didnt compile!
|
||||||
nonblock="nada"
|
nonblock="nada"
|
||||||
AC_DEFINE(HAVE_DISABLED_NONBLOCKING)
|
AC_DEFINE(HAVE_DISABLED_NONBLOCKING, 1, [disabled non-blocking sockets])
|
||||||
])
|
])
|
||||||
dnl end of forth test
|
dnl end of forth test
|
||||||
|
|
||||||
@@ -152,10 +152,8 @@ AC_DEFUN([TYPE_IN_ADDR_T],
|
|||||||
AC_MSG_CHECKING([for in_addr_t equivalent])
|
AC_MSG_CHECKING([for in_addr_t equivalent])
|
||||||
AC_CACHE_VAL([curl_cv_in_addr_t_equiv],
|
AC_CACHE_VAL([curl_cv_in_addr_t_equiv],
|
||||||
[
|
[
|
||||||
# Systems have either "struct sockaddr *" or
|
|
||||||
# "void *" as the second argument to getpeername
|
|
||||||
curl_cv_in_addr_t_equiv=
|
curl_cv_in_addr_t_equiv=
|
||||||
for t in int size_t unsigned long "unsigned long"; do
|
for t in "unsigned long" int size_t unsigned long; do
|
||||||
AC_TRY_COMPILE([
|
AC_TRY_COMPILE([
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
@@ -176,7 +174,7 @@ AC_DEFUN([TYPE_IN_ADDR_T],
|
|||||||
AC_DEFINE_UNQUOTED(in_addr_t, $curl_cv_in_addr_t_equiv,
|
AC_DEFINE_UNQUOTED(in_addr_t, $curl_cv_in_addr_t_equiv,
|
||||||
[type to use in place of in_addr_t if not defined])],
|
[type to use in place of in_addr_t if not defined])],
|
||||||
[#include <sys/types.h>
|
[#include <sys/types.h>
|
||||||
#include <sys/socket.h>,
|
#include <sys/socket.h>
|
||||||
#include <arpa/inet.h>])
|
#include <arpa/inet.h>])
|
||||||
])
|
])
|
||||||
|
|
||||||
@@ -272,15 +270,15 @@ AC_DEFUN(CURL_CHECK_INET_NTOA_R,
|
|||||||
AC_MSG_CHECKING(whether inet_ntoa_r is declared)
|
AC_MSG_CHECKING(whether inet_ntoa_r is declared)
|
||||||
AC_EGREP_CPP(inet_ntoa_r,[
|
AC_EGREP_CPP(inet_ntoa_r,[
|
||||||
#include <arpa/inet.h>],[
|
#include <arpa/inet.h>],[
|
||||||
AC_DEFINE(HAVE_INET_NTOA_R_DECL)
|
AC_DEFINE(HAVE_INET_NTOA_R_DECL, 1, [inet_ntoa_r() is declared])
|
||||||
AC_MSG_RESULT(yes)],[
|
AC_MSG_RESULT(yes)],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared)
|
AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared)
|
||||||
AC_EGREP_CPP(inet_ntoa_r,[
|
AC_EGREP_CPP(inet_ntoa_r,[
|
||||||
#define _REENTRANT
|
#define _REENTRANT
|
||||||
#include <arpa/inet.h>],[
|
#include <arpa/inet.h>],[
|
||||||
AC_DEFINE(HAVE_INET_NTOA_R_DECL)
|
AC_DEFINE(HAVE_INET_NTOA_R_DECL, 1, [inet_ntoa_r() is declared])
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
AC_DEFINE(NEED_REENTRANT, 1, [need REENTRANT defined])
|
||||||
AC_MSG_RESULT(yes)],
|
AC_MSG_RESULT(yes)],
|
||||||
AC_MSG_RESULT(no))])])
|
AC_MSG_RESULT(no))])])
|
||||||
])
|
])
|
||||||
@@ -302,7 +300,7 @@ struct hostent_data hdata;
|
|||||||
int rc;
|
int rc;
|
||||||
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5)
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5, 1, [gethostbyaddr_r() takes 5 args])
|
||||||
ac_cv_gethostbyaddr_args=5],[
|
ac_cv_gethostbyaddr_args=5],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments)
|
AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments)
|
||||||
@@ -318,8 +316,8 @@ struct hostent_data hdata;
|
|||||||
int rc;
|
int rc;
|
||||||
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5)
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5, 1, [gethostbyaddr_r() takes 5 args])
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
AC_DEFINE(NEED_REENTRANT, 1, [need REENTRANT])
|
||||||
ac_cv_gethostbyaddr_args=5],[
|
ac_cv_gethostbyaddr_args=5],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments)
|
AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments)
|
||||||
@@ -337,7 +335,7 @@ struct hostent * hp;
|
|||||||
hp = gethostbyaddr_r(address, length, type, &h,
|
hp = gethostbyaddr_r(address, length, type, &h,
|
||||||
buffer, 8192, &h_errnop);],[
|
buffer, 8192, &h_errnop);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_7)
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_7, 1, [gethostbyaddr_r() takes 7 args] )
|
||||||
ac_cv_gethostbyaddr_args=7],[
|
ac_cv_gethostbyaddr_args=7],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments)
|
AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments)
|
||||||
@@ -356,7 +354,7 @@ int rc;
|
|||||||
rc = gethostbyaddr_r(address, length, type, &h,
|
rc = gethostbyaddr_r(address, length, type, &h,
|
||||||
buffer, 8192, &hp, &h_errnop);],[
|
buffer, 8192, &hp, &h_errnop);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_8)
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_8, 1, [gethostbyaddr_r() takes 8 args])
|
||||||
ac_cv_gethostbyaddr_args=8],[
|
ac_cv_gethostbyaddr_args=8],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])])
|
have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])])
|
||||||
@@ -377,9 +375,10 @@ AC_DEFUN(CURL_CHECK_GETHOSTBYNAME_R,
|
|||||||
|
|
||||||
int
|
int
|
||||||
gethostbyname_r(const char *, struct hostent *, struct hostent_data *);],[
|
gethostbyname_r(const char *, struct hostent *, struct hostent_data *);],[
|
||||||
|
struct hostent_data data;
|
||||||
gethostbyname_r(NULL, NULL, NULL);],[
|
gethostbyname_r(NULL, NULL, NULL);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3)
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3, 1, [gethostbyname_r() takes 3 args])
|
||||||
ac_cv_gethostbyname_args=3],[
|
ac_cv_gethostbyname_args=3],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING([if gethostbyname_r with -D_REENTRANT takes 3 arguments])
|
AC_MSG_CHECKING([if gethostbyname_r with -D_REENTRANT takes 3 arguments])
|
||||||
@@ -394,10 +393,11 @@ gethostbyname_r(NULL, NULL, NULL);],[
|
|||||||
|
|
||||||
int
|
int
|
||||||
gethostbyname_r(const char *,struct hostent *, struct hostent_data *);],[
|
gethostbyname_r(const char *,struct hostent *, struct hostent_data *);],[
|
||||||
|
struct hostent_data data;
|
||||||
gethostbyname_r(NULL, NULL, NULL);],[
|
gethostbyname_r(NULL, NULL, NULL);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3)
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3, 1, [gethostbyname_r() takes 3 args])
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
AC_DEFINE(NEED_REENTRANT, 1, [needs REENTRANT])
|
||||||
ac_cv_gethostbyname_args=3],[
|
ac_cv_gethostbyname_args=3],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING([if gethostbyname_r takes 5 arguments])
|
AC_MSG_CHECKING([if gethostbyname_r takes 5 arguments])
|
||||||
@@ -411,7 +411,7 @@ struct hostent *
|
|||||||
gethostbyname_r(const char *, struct hostent *, char *, int, int *);],[
|
gethostbyname_r(const char *, struct hostent *, char *, int, int *);],[
|
||||||
gethostbyname_r(NULL, NULL, NULL, 0, NULL);],[
|
gethostbyname_r(NULL, NULL, NULL, 0, NULL);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_5)
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_5, 1, [gethostbyname_r() takes 5 args])
|
||||||
ac_cv_gethostbyname_args=5],[
|
ac_cv_gethostbyname_args=5],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING([if gethostbyname_r takes 6 arguments])
|
AC_MSG_CHECKING([if gethostbyname_r takes 6 arguments])
|
||||||
@@ -426,7 +426,7 @@ gethostbyname_r(const char *, struct hostent *, char *, size_t,
|
|||||||
struct hostent **, int *);],[
|
struct hostent **, int *);],[
|
||||||
gethostbyname_r(NULL, NULL, NULL, 0, NULL, NULL);],[
|
gethostbyname_r(NULL, NULL, NULL, 0, NULL, NULL);],[
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_6)
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_6, 1, [gethostbyname_r() takes 6 args])
|
||||||
ac_cv_gethostbyname_args=6],[
|
ac_cv_gethostbyname_args=6],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"],
|
have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"],
|
||||||
|
136
build_vms.com
136
build_vms.com
@@ -1,67 +1,69 @@
|
|||||||
$!
|
$!
|
||||||
$
|
$
|
||||||
$ on control_y then goto Common_Exit!
|
$ on control_y then goto Common_Exit!
|
||||||
$ orig = f$environment("DEFAULT")
|
$ orig = f$environment("DEFAULT")
|
||||||
$ loc = f$environment("PROCEDURE")
|
$ loc = f$environment("PROCEDURE")
|
||||||
$ def = f$parse("X.X;1",loc) - "X.X;1"
|
$ def = f$parse("X.X;1",loc) - "X.X;1"
|
||||||
$
|
$
|
||||||
$ set def 'def'
|
$ set def 'def'
|
||||||
$ cc_qual = "/define=HAVE_CONFIG_H=1/include=(""../include/"",""../"")"
|
$ cc_qual = "/define=HAVE_CONFIG_H=1/include=(""../include/"",""../"",""../../openssl-0_9_7/include/"")"
|
||||||
$ if p1 .eqs. "LISTING" then cc_qual = cc_qual + "/LIST/MACHINE"
|
$ if p1 .eqs. "LISTING" then cc_qual = cc_qual + "/LIST/MACHINE"
|
||||||
$ if p1 .eqs. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG"
|
$ if p1 .eqs. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG"
|
||||||
$ msg_qual = ""
|
$ msg_qual = ""
|
||||||
$ call build "[.lib]" "*.c"
|
$ call build "[.lib]" "*.c"
|
||||||
$ call build "[.src]" "*.c"
|
$ call build "[.src]" "*.c"
|
||||||
$ call build "[.src]" "*.msg"
|
$ call build "[.src]" "*.msg"
|
||||||
$ link /exe=curl.exe [.src]curl/lib/include=main,[.lib]curl/lib
|
$ link /exe=curl.exe [.src]curl/lib/include=main,[.lib]curl/lib, -
|
||||||
$
|
[-.openssl-0_9_7.axp.exe.ssl]libssl/lib, -
|
||||||
$
|
[-.openssl-0_9_7.axp.exe.crypto]libcrypto/lib
|
||||||
$ goto Common_Exit
|
$
|
||||||
$build: subroutine
|
$
|
||||||
$ set noon
|
$ goto Common_Exit
|
||||||
$ set default 'p1'
|
$build: subroutine
|
||||||
$ search = p2
|
$ set noon
|
||||||
$ reset = f$search("reset")
|
$ set default 'p1'
|
||||||
$ if f$search("CURL.OLB") .eqs. ""
|
$ search = p2
|
||||||
$ then
|
$ reset = f$search("reset")
|
||||||
$ LIB/CREATE/OBJECT CURL.OLB
|
$ if f$search("CURL.OLB") .eqs. ""
|
||||||
$ endif
|
$ then
|
||||||
$ reset = f$search("reset",1)
|
$ LIB/CREATE/OBJECT CURL.OLB
|
||||||
$Loop:
|
$ endif
|
||||||
$ file = f$search(search,1)
|
$ reset = f$search("reset",1)
|
||||||
$ if file .eqs. "" then goto EndLoop
|
$Loop:
|
||||||
$ obj = f$search(f$parse(".OBJ;",file),2)
|
$ file = f$search(search,1)
|
||||||
$ if (obj .nes. "")
|
$ if file .eqs. "" then goto EndLoop
|
||||||
$ then
|
$ obj = f$search(f$parse(".OBJ;",file),2)
|
||||||
$ if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt")))
|
$ if (obj .nes. "")
|
||||||
$ then
|
$ then
|
||||||
$ call compile 'file'
|
$ if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt")))
|
||||||
$ lib/object curl.OLB 'f$parse(".obj;",file)'
|
$ then
|
||||||
$ else
|
$ call compile 'file'
|
||||||
$! write sys$output "File: ''file' is up to date"
|
$ lib/object curl.OLB 'f$parse(".obj;",file)'
|
||||||
$ endif
|
$ else
|
||||||
$ else
|
$! write sys$output "File: ''file' is up to date"
|
||||||
$! write sys$output "Object for file: ''file' does not exist"
|
$ endif
|
||||||
$ call compile 'file'
|
$ else
|
||||||
$ lib/object curl.OLB 'f$parse(".obj;",file)'
|
$! write sys$output "Object for file: ''file' does not exist"
|
||||||
$ endif
|
$ call compile 'file'
|
||||||
$ goto Loop
|
$ lib/object curl.OLB 'f$parse(".obj;",file)'
|
||||||
$EndLoop:
|
$ endif
|
||||||
$ purge
|
$ goto Loop
|
||||||
$ set def 'def'
|
$EndLoop:
|
||||||
$ endsubroutine ! Build
|
$ purge
|
||||||
$
|
$ set def 'def'
|
||||||
$compile: subroutine
|
$ endsubroutine ! Build
|
||||||
$ set noon
|
$
|
||||||
$ file = p1
|
$compile: subroutine
|
||||||
$ qual = p2+p3+p4+p5+p6+p7+p8
|
$ set noon
|
||||||
$ typ = f$parse(file,,,"TYPE") - "."
|
$ file = p1
|
||||||
$ cmd_c = "CC "+cc_qual
|
$ qual = p2+p3+p4+p5+p6+p7+p8
|
||||||
$ cmd_msg = "MESSAGE "+msg_qual
|
$ typ = f$parse(file,,,"TYPE") - "."
|
||||||
$ x = cmd_'typ'
|
$ cmd_c = "CC "+cc_qual
|
||||||
$ 'x' 'file'
|
$ cmd_msg = "MESSAGE "+msg_qual
|
||||||
$ ENDSUBROUTINE ! Compile
|
$ x = cmd_'typ'
|
||||||
$
|
$ 'x' 'file'
|
||||||
$Common_Exit:
|
$ ENDSUBROUTINE ! Compile
|
||||||
$ set default 'orig'
|
$
|
||||||
$ exit
|
$Common_Exit:
|
||||||
|
$ set default 'orig'
|
||||||
|
$ exit
|
||||||
|
126
buildconf
126
buildconf
@@ -5,7 +5,125 @@ die(){
|
|||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
|
|
||||||
aclocal || die "The command 'aclocal' failed"
|
#--------------------------------------------------------------------------
|
||||||
autoheader || die "The command 'autoheader' failed"
|
# autoconf 2.57 or newer
|
||||||
autoconf || die "The command 'autoconf' failed"
|
#
|
||||||
automake || die "The command 'automake $MAKEFILES' failed"
|
need_autoconf="2.57"
|
||||||
|
ac_version=`${AUTOCONF:-autoconf} --version 2>/dev/null|head -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."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
IFS=.; set $ac_version; IFS=' '
|
||||||
|
if test "$1" = "2" -a "$2" -lt "57" || test "$1" -lt "2"; then
|
||||||
|
echo "buildconf: autoconf version $ac_version found."
|
||||||
|
echo " You need autoconf version $need_autoconf or newer installed."
|
||||||
|
echo " If you have a sufficient autoconf installed, but it"
|
||||||
|
echo " is not named 'autoconf', then try setting the"
|
||||||
|
echo " AUTOCONF environment variable."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
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]* *$//'`
|
||||||
|
if test -z "$ah_version"; then
|
||||||
|
echo "buildconf: autoheader not found."
|
||||||
|
echo " You need autoheader version 2.50 or newer installed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
IFS=.; set $ah_version; IFS=' '
|
||||||
|
if test "$1" = "2" -a "$2" -lt "50" || test "$1" -lt "2"; then
|
||||||
|
echo "buildconf: autoheader version $ah_version found."
|
||||||
|
echo " You need autoheader version 2.50 or newer installed."
|
||||||
|
echo " If you have a sufficient autoheader installed, but it"
|
||||||
|
echo " is not named 'autoheader', then try setting the"
|
||||||
|
echo " AUTOHEADER environment variable."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
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]* *$//'`
|
||||||
|
if test -z "$am_version"; then
|
||||||
|
echo "buildconf: automake not found."
|
||||||
|
echo " You need automake version $need_automake or newer installed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
IFS=.; set $am_version; IFS=' '
|
||||||
|
if test "$1" = "1" -a "$2" -lt "7" || test "$1" -lt "1"; then
|
||||||
|
echo "buildconf: automake version $am_version found."
|
||||||
|
echo " You need automake version $need_automake or newer installed."
|
||||||
|
echo " If you have a sufficient automake installed, but it"
|
||||||
|
echo " is not named 'autommake', then try setting the"
|
||||||
|
echo " AUTOMAKE environment variable."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "buildconf: automake version $am_version (ok)"
|
||||||
|
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------------
|
||||||
|
# libtool check
|
||||||
|
#
|
||||||
|
LIBTOOL_WANTED_MAJOR=1
|
||||||
|
LIBTOOL_WANTED_MINOR=4
|
||||||
|
LIBTOOL_WANTED_PATCH=2
|
||||||
|
LIBTOOL_WANTED_VERSION=1.4.2
|
||||||
|
|
||||||
|
libtool=`which glibtool 2>/dev/null`
|
||||||
|
if test ! -x "$libtool"; then
|
||||||
|
libtool=`which libtool`
|
||||||
|
fi
|
||||||
|
#lt_pversion=`${LIBTOOL:-$libtool} --version 2>/dev/null|head -1| sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//'`
|
||||||
|
lt_pversion=`$libtool --version 2>/dev/null|head -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"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
lt_version=`echo $lt_pversion` #|sed -e 's/\([a-z]*\)$/.\1/'`
|
||||||
|
IFS=.; set $lt_version; IFS=' '
|
||||||
|
lt_status="good"
|
||||||
|
if test "$1" = "$LIBTOOL_WANTED_MAJOR"; then
|
||||||
|
if test "$2" -lt "$LIBTOOL_WANTED_MINOR"; then
|
||||||
|
lt_status="bad"
|
||||||
|
elif test ! -z "$LIBTOOL_WANTED_PATCH"; then
|
||||||
|
if test -n "$3"; then
|
||||||
|
if test "$3" -lt "$LIBTOOL_WANTED_PATCH"; then
|
||||||
|
lt_status="bad"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if test $lt_status != "good"; then
|
||||||
|
echo "buildconf: libtool version $lt_pversion found."
|
||||||
|
echo " You need libtool version $LIBTOOL_WANTED_VERSION or newer installed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "buildconf: libtool version $lt_version (ok)"
|
||||||
|
|
||||||
|
# ------------------------------------------------------------
|
||||||
|
|
||||||
|
# run the correct scripts now
|
||||||
|
|
||||||
|
echo "buildconf: running libtoolize"
|
||||||
|
${LIBTOOLIZE:-libtoolize} --copy --automake || die "The command '${LIBTOOLIZE:-libtoolize} --copy --automake' failed"
|
||||||
|
echo "buildconf: running aclocal"
|
||||||
|
${ACLOCAL:-aclocal} || die "The command '${AUTOHEADER:-aclocal}' failed"
|
||||||
|
echo "buildconf: running autoheader"
|
||||||
|
${AUTOHEADER:-autoheader} || die "The command '${AUTOHEADER:-autoheader}' failed"
|
||||||
|
echo "buildconf: running autoconf"
|
||||||
|
${AUTOCONF:-autoconf} || die "The command '${AUTOCONF:-autoconf}' failed"
|
||||||
|
echo "buildconf: running automake"
|
||||||
|
${AUTOMAKE:-automake} -a || die "The command '${AUTOMAKE:-automake} -a' failed"
|
||||||
|
exit 0
|
||||||
|
@@ -1,25 +0,0 @@
|
|||||||
|
|
||||||
#define socklen_t int
|
|
||||||
|
|
||||||
#define HAVE_SYS_SOCKET_H
|
|
||||||
#define HAVE_ARPA_INET_H
|
|
||||||
#define HAVE_SYS_SELECT_H
|
|
||||||
#define HAVE_FCNTL_H
|
|
||||||
#define HAVE_GETTIMEOFDAY
|
|
||||||
|
|
||||||
#define HAVE_SELECT
|
|
||||||
#define HAVE_SOCKET
|
|
||||||
#define ifr_dstaddr ifr_addr
|
|
||||||
|
|
||||||
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#include <sys/if.h>
|
|
||||||
#include <sys/fcntl.h>
|
|
||||||
#include <sys/ioctl.h>
|
|
||||||
#include <netinet/in.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
|
|
||||||
#define ioctl(a,b,c,d) (ioctl(a,b,c) * (d==d))
|
|
||||||
|
|
||||||
|
|
||||||
#define OS "RISC OS"
|
|
1317
config.guess
vendored
1317
config.guess
vendored
File diff suppressed because it is too large
Load Diff
1411
config.sub
vendored
1411
config.sub
vendored
File diff suppressed because it is too large
Load Diff
1005
configure.ac
Normal file
1005
configure.ac
Normal file
File diff suppressed because it is too large
Load Diff
614
configure.in
614
configure.in
@@ -1,614 +0,0 @@
|
|||||||
dnl $Id$
|
|
||||||
dnl Process this file with autoconf to produce a configure script.
|
|
||||||
|
|
||||||
dnl Ensure that this file is processed with autoconf 2.50 or newer
|
|
||||||
dnl Don't even think about removing this check!
|
|
||||||
AC_PREREQ(2.50)
|
|
||||||
|
|
||||||
dnl First some basic init macros
|
|
||||||
AC_INIT
|
|
||||||
AC_CONFIG_SRCDIR([lib/urldata.h])
|
|
||||||
AM_CONFIG_HEADER(config.h src/config.h)
|
|
||||||
|
|
||||||
dnl figure out the libcurl version
|
|
||||||
VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h`
|
|
||||||
AM_INIT_AUTOMAKE(curl,$VERSION)
|
|
||||||
|
|
||||||
dnl
|
|
||||||
dnl we extract the numerical version for curl-config only
|
|
||||||
VERSIONNUM=`sed -ne 's/^#define LIBCURL_VERSION_NUM 0x\(.*\)/\1/p' ${srcdir}/include/curl/curl.h`
|
|
||||||
AC_SUBST(VERSIONNUM)
|
|
||||||
|
|
||||||
dnl Solaris pkgadd support definitions
|
|
||||||
PKGADD_PKG="HAXXcurl"
|
|
||||||
PKGADD_NAME="cURL - a client that groks URLs"
|
|
||||||
PKGADD_VENDOR="curl.haxx.se"
|
|
||||||
AC_SUBST(PKGADD_PKG)
|
|
||||||
AC_SUBST(PKGADD_NAME)
|
|
||||||
AC_SUBST(PKGADD_VENDOR)
|
|
||||||
|
|
||||||
|
|
||||||
dnl
|
|
||||||
dnl Detect the canonical host and target build environment
|
|
||||||
dnl
|
|
||||||
|
|
||||||
AC_CANONICAL_HOST
|
|
||||||
dnl Get system canonical name
|
|
||||||
AC_DEFINE_UNQUOTED(OS, "${host}")
|
|
||||||
|
|
||||||
dnl Check for AIX weirdos
|
|
||||||
AC_AIX
|
|
||||||
|
|
||||||
dnl Checks for programs.
|
|
||||||
AC_PROG_CC
|
|
||||||
|
|
||||||
dnl check for how to do large files
|
|
||||||
AC_SYS_LARGEFILE
|
|
||||||
|
|
||||||
dnl check for cygwin stuff
|
|
||||||
AC_LIBTOOL_WIN32_DLL
|
|
||||||
|
|
||||||
dnl libtool setup
|
|
||||||
AM_PROG_LIBTOOL
|
|
||||||
|
|
||||||
dnl The install stuff has already been taken care of by the automake stuff
|
|
||||||
dnl AC_PROG_INSTALL
|
|
||||||
AC_PROG_MAKE_SET
|
|
||||||
|
|
||||||
dnl ************************************************************
|
|
||||||
dnl lame option to switch on debug options
|
|
||||||
dnl
|
|
||||||
AC_MSG_CHECKING([whether to enable debug options])
|
|
||||||
AC_ARG_ENABLE(debug,
|
|
||||||
[ --enable-debug Enable pedantic debug options
|
|
||||||
--disable-debug Disable debug options],
|
|
||||||
[ case "$enableval" in
|
|
||||||
no)
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
;;
|
|
||||||
*) AC_MSG_RESULT(yes)
|
|
||||||
|
|
||||||
CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG"
|
|
||||||
CFLAGS="-W -Wall -Wwrite-strings -pedantic -g"
|
|
||||||
;;
|
|
||||||
esac ],
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
)
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Checks for IPv6
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
AC_MSG_CHECKING([whether to enable ipv6])
|
|
||||||
AC_ARG_ENABLE(ipv6,
|
|
||||||
[ --enable-ipv6 Enable ipv6 (with ipv4) support
|
|
||||||
--disable-ipv6 Disable ipv6 support],
|
|
||||||
[ case "$enableval" in
|
|
||||||
no)
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
ipv6=no
|
|
||||||
;;
|
|
||||||
*) AC_MSG_RESULT(yes)
|
|
||||||
ipv6=yes
|
|
||||||
;;
|
|
||||||
esac ],
|
|
||||||
|
|
||||||
AC_TRY_RUN([ /* is AF_INET6 available? */
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/socket.h>
|
|
||||||
main()
|
|
||||||
{
|
|
||||||
if (socket(AF_INET6, SOCK_STREAM, 0) < 0)
|
|
||||||
exit(1);
|
|
||||||
else
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
],
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
ipv6=yes,
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
ipv6=no,
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
ipv6=no
|
|
||||||
))
|
|
||||||
|
|
||||||
if test "$ipv6" = "yes"; then
|
|
||||||
CURL_CHECK_WORKING_GETADDRINFO
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Checks for libraries.
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
dnl gethostbyname in the nsl lib?
|
|
||||||
AC_CHECK_FUNC(gethostbyname, , AC_CHECK_LIB(nsl, gethostbyname))
|
|
||||||
|
|
||||||
if test "$ac_cv_lib_nsl_gethostbyname" != "yes" -a "$ac_cv_func_gethostbyname" != "yes"; then
|
|
||||||
dnl gethostbyname in the socket lib?
|
|
||||||
AC_CHECK_FUNC(gethostbyname, , AC_CHECK_LIB(socket, gethostbyname))
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl At least one system has been identified to require BOTH nsl and
|
|
||||||
dnl socket libs to link properly.
|
|
||||||
if test "$ac_cv_lib_nsl_gethostbyname" = "$ac_cv_func_gethostbyname"; then
|
|
||||||
AC_MSG_CHECKING([trying both nsl and socket libs])
|
|
||||||
my_ac_save_LIBS=$LIBS
|
|
||||||
LIBS="-lnsl -lsocket $LIBS"
|
|
||||||
AC_TRY_LINK( ,
|
|
||||||
[gethostbyname();],
|
|
||||||
my_ac_link_result=success,
|
|
||||||
my_ac_link_result=failure )
|
|
||||||
|
|
||||||
if test "$my_ac_link_result" = "failure"; then
|
|
||||||
AC_MSG_RESULT([no])
|
|
||||||
AC_MSG_ERROR([couldn't find libraries for gethostbyname()])
|
|
||||||
dnl restore LIBS
|
|
||||||
LIBS=$my_ac_save_LIBS
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT([yes])
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl resolve lib?
|
|
||||||
AC_CHECK_FUNC(strcasecmp, , AC_CHECK_LIB(resolve, strcasecmp))
|
|
||||||
|
|
||||||
if test "$ac_cv_lib_resolve_strcasecmp" = "$ac_cv_func_strcasecmp"; then
|
|
||||||
AC_CHECK_LIB(resolve, strcasecmp,
|
|
||||||
[LIBS="-lresolve $LIBS"],
|
|
||||||
,
|
|
||||||
-lnsl)
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl socket lib?
|
|
||||||
AC_CHECK_FUNC(connect, , AC_CHECK_LIB(socket, connect))
|
|
||||||
|
|
||||||
dnl ucb lib?
|
|
||||||
AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
|
||||||
|
|
||||||
dnl dl lib?
|
|
||||||
AC_CHECK_FUNC(dlclose, , AC_CHECK_LIB(dl, dlopen))
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Check how non-blocking sockets are set
|
|
||||||
dnl **********************************************************************
|
|
||||||
AC_ARG_ENABLE(nonblocking,
|
|
||||||
[ --enable-nonblocking Makes the script detect how to do it
|
|
||||||
--disable-nonblocking Makes the script disable non-blocking sockets],
|
|
||||||
[
|
|
||||||
if test "$enableval" = "no" ; then
|
|
||||||
AC_MSG_WARN([non-blocking sockets disabled])
|
|
||||||
AC_DEFINE(HAVE_DISABLED_NONBLOCKING)
|
|
||||||
else
|
|
||||||
CURL_CHECK_NONBLOCKING_SOCKET
|
|
||||||
fi
|
|
||||||
],
|
|
||||||
[
|
|
||||||
CURL_CHECK_NONBLOCKING_SOCKET
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Check for the random seed preferences
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
AC_ARG_WITH(egd-socket,
|
|
||||||
[ --with-egd-socket=FILE Entropy Gathering Daemon socket pathname],
|
|
||||||
[ EGD_SOCKET="$withval" ]
|
|
||||||
)
|
|
||||||
if test -n "$EGD_SOCKET" ; then
|
|
||||||
AC_DEFINE_UNQUOTED(EGD_SOCKET, "$EGD_SOCKET")
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl Check for user-specified random device
|
|
||||||
AC_ARG_WITH(random,
|
|
||||||
[ --with-random=FILE read randomness from FILE (default=/dev/urandom)],
|
|
||||||
[ RANDOM_FILE="$withval" ],
|
|
||||||
[
|
|
||||||
dnl Check for random device
|
|
||||||
AC_CHECK_FILE("/dev/urandom",
|
|
||||||
[
|
|
||||||
RANDOM_FILE="/dev/urandom";
|
|
||||||
]
|
|
||||||
)
|
|
||||||
]
|
|
||||||
)
|
|
||||||
if test -n "$RANDOM_FILE" ; then
|
|
||||||
AC_SUBST(RANDOM_FILE)
|
|
||||||
AC_DEFINE_UNQUOTED(RANDOM_FILE, "$RANDOM_FILE")
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Check for the presence of Kerberos4 libraries and headers
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
AC_ARG_WITH(krb4-includes,
|
|
||||||
[ --with-krb4-includes[=DIR] Specify location of kerberos4 headers],[
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$withval"
|
|
||||||
KRB4INC="$withval"
|
|
||||||
want_krb4=yes
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_ARG_WITH(krb4-libs,
|
|
||||||
[ --with-krb4-libs[=DIR] Specify location of kerberos4 libs],[
|
|
||||||
LDFLAGS="$LDFLAGS -L$withval"
|
|
||||||
KRB4LIB="$withval"
|
|
||||||
want_krb4=yes
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
OPT_KRB4=off
|
|
||||||
AC_ARG_WITH(krb4,dnl
|
|
||||||
[ --with-krb4[=DIR] where to look for Kerberos4],[
|
|
||||||
OPT_KRB4="$withval"
|
|
||||||
if test X"$OPT_KRB4" != Xyes
|
|
||||||
then
|
|
||||||
LDFLAGS="$LDFLAGS -L$OPT_KRB4/lib"
|
|
||||||
KRB4LIB="$OPT_KRB4/lib"
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$OPT_KRB4/include"
|
|
||||||
KRB4INC="$OPT_KRB4/include"
|
|
||||||
fi
|
|
||||||
want_krb4="yes"
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_MSG_CHECKING([if Kerberos4 support is requested])
|
|
||||||
|
|
||||||
if test "$want_krb4" = yes
|
|
||||||
then
|
|
||||||
if test "$ipv6" = "yes"; then
|
|
||||||
echo krb4 is not compatible with IPv6
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-krb4
|
|
||||||
|
|
||||||
AC_MSG_CHECKING(where to look for Kerberos4)
|
|
||||||
if test X"$OPT_KRB4" = Xyes
|
|
||||||
then
|
|
||||||
AC_MSG_RESULT([defaults])
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT([libs in $KRB4LIB, headers in $KRB4INC])
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl Check for DES library
|
|
||||||
AC_CHECK_LIB(des, des_pcbc_encrypt,
|
|
||||||
[
|
|
||||||
AC_CHECK_HEADERS(des.h)
|
|
||||||
|
|
||||||
dnl resolv lib?
|
|
||||||
AC_CHECK_FUNC(res_search, , AC_CHECK_LIB(resolv, res_search))
|
|
||||||
|
|
||||||
dnl Check for the Kerberos4 library
|
|
||||||
AC_CHECK_LIB(krb, krb_net_read,
|
|
||||||
[
|
|
||||||
dnl Check for header files
|
|
||||||
AC_CHECK_HEADERS(krb.h)
|
|
||||||
|
|
||||||
dnl we found the required libraries, add to LIBS
|
|
||||||
LIBS="-lkrb -ldes $LIBS"
|
|
||||||
|
|
||||||
dnl Check for function krb_get_our_ip_for_realm
|
|
||||||
dnl this is needed for NAT networks
|
|
||||||
AC_CHECK_FUNCS(krb_get_our_ip_for_realm)
|
|
||||||
|
|
||||||
dnl add define KRB4
|
|
||||||
AC_DEFINE(KRB4)
|
|
||||||
|
|
||||||
dnl substitute it too!
|
|
||||||
KRB4_ENABLED=1
|
|
||||||
AC_SUBST(KRB4_ENABLED)
|
|
||||||
|
|
||||||
dnl the krb4 stuff needs a strlcpy()
|
|
||||||
AC_CHECK_FUNCS(strlcpy)
|
|
||||||
|
|
||||||
])
|
|
||||||
])
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Check for the presence of SSL libraries and headers
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
dnl Default to compiler & linker defaults for SSL files & libraries.
|
|
||||||
OPT_SSL=off
|
|
||||||
AC_ARG_WITH(ssl,dnl
|
|
||||||
[ --with-ssl[=DIR] where to look for SSL [compiler/linker default paths]
|
|
||||||
DIR points to the SSL installation [/usr/local/ssl]],
|
|
||||||
OPT_SSL=$withval
|
|
||||||
)
|
|
||||||
|
|
||||||
if test X"$OPT_SSL" = Xno
|
|
||||||
then
|
|
||||||
AC_MSG_WARN(SSL/https support disabled)
|
|
||||||
else
|
|
||||||
|
|
||||||
dnl Check for and handle argument to --with-ssl.
|
|
||||||
|
|
||||||
dnl save the pre-ssl check flags for a while
|
|
||||||
CLEANLDFLAGS="$LDFLAGS"
|
|
||||||
CLEANCPPFLAGS="$CPPFLAGS"
|
|
||||||
|
|
||||||
case "$OPT_SSL" in
|
|
||||||
yes)
|
|
||||||
EXTRA_SSL=/usr/local/ssl ;;
|
|
||||||
off)
|
|
||||||
EXTRA_SSL= ;;
|
|
||||||
*)
|
|
||||||
dnl check the given spot right away!
|
|
||||||
EXTRA_SSL=$OPT_SSL
|
|
||||||
LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib"
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
AC_CHECK_LIB(crypto, CRYPTO_lock,[
|
|
||||||
HAVECRYPTO="yes"
|
|
||||||
],[
|
|
||||||
OLDLDFLAGS="$LDFLAGS"
|
|
||||||
OLDCPPFLAGS="$CPPFLAGS"
|
|
||||||
LDFLAGS="$CLEANLDFLAGS -L$EXTRA_SSL/lib"
|
|
||||||
CPPFLAGS="$CLEANCPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
|
|
||||||
AC_CHECK_LIB(crypto, CRYPTO_add_lock,[
|
|
||||||
HAVECRYPTO="yes" ], [
|
|
||||||
LDFLAGS="$OLDLDFLAGS"
|
|
||||||
CPPFLAGS="$OLDCPPFLAGS"
|
|
||||||
])
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
if test "$HAVECRYPTO" = "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(crypto, CRYPTO_add_lock)
|
|
||||||
AC_CHECK_LIB(ssl, SSL_connect)
|
|
||||||
|
|
||||||
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
|
||||||
dnl we didn't find the SSL lib, try the RSAglue/rsaref stuff
|
|
||||||
AC_MSG_CHECKING(for ssl with RSAglue/rsaref libs in use);
|
|
||||||
OLIBS=$LIBS
|
|
||||||
LIBS="$LIBS -lRSAglue -lrsaref"
|
|
||||||
AC_CHECK_LIB(ssl, SSL_connect)
|
|
||||||
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
|
||||||
dnl still no SSL_connect
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
LIBS=$OLIBS
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
dnl Check for SSLeay headers
|
|
||||||
AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \
|
|
||||||
openssl/pem.h openssl/ssl.h openssl/err.h,
|
|
||||||
OPENSSL_ENABLED=1)
|
|
||||||
|
|
||||||
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,
|
|
||||||
OPENSSL_ENABLED=1)
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl Check for the OpenSSL engine header, it is kind of "separated"
|
|
||||||
dnl from the main SSL check
|
|
||||||
AC_CHECK_HEADERS(openssl/engine.h)
|
|
||||||
|
|
||||||
AC_SUBST(OPENSSL_ENABLED)
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test X"$OPT_SSL" != Xoff &&
|
|
||||||
test "$OPENSSL_ENABLED" != "1"; then
|
|
||||||
AC_MSG_ERROR([OpenSSL libs and/or directories were not found where specified!])
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
dnl these can only exist if openssl exists
|
|
||||||
|
|
||||||
AC_CHECK_FUNCS( RAND_status \
|
|
||||||
RAND_screen \
|
|
||||||
RAND_egd )
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Check for the presence of ZLIB libraries and headers
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
dnl Default to compiler & linker defaults for files & libraries.
|
|
||||||
dnl OPT_ZLIB=no
|
|
||||||
dnl AC_ARG_WITH(zlib,dnl
|
|
||||||
dnl [ --with-zlib[=DIR] where to look for ZLIB [compiler/linker default paths]
|
|
||||||
dnl DIR points to the ZLIB installation prefix [/usr/local]],
|
|
||||||
dnl OPT_ZLIB=$withval,
|
|
||||||
dnl )
|
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-zlib.
|
|
||||||
dnl
|
|
||||||
dnl NOTE: We *always* look for ZLIB headers & libraries, all this option
|
|
||||||
dnl does is change where we look (by adjusting LIBS and CPPFLAGS.)
|
|
||||||
dnl
|
|
||||||
|
|
||||||
dnl AC_MSG_CHECKING(where to look for ZLIB)
|
|
||||||
dnl if test X"$OPT_ZLIB" = Xno
|
|
||||||
dnl then
|
|
||||||
dnl AC_MSG_RESULT([defaults (or given in environment)])
|
|
||||||
dnl else
|
|
||||||
dnl test X"$OPT_ZLIB" = Xyes && OPT_ZLIB=/usr/local
|
|
||||||
dnl LIBS="$LIBS -L$OPT_ZLIB/lib"
|
|
||||||
dnl CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include"
|
|
||||||
dnl AC_MSG_RESULT([$OPT_ZLIB])
|
|
||||||
dnl fi
|
|
||||||
|
|
||||||
dnl z lib?
|
|
||||||
dnl AC_CHECK_FUNC(gzread, , AC_CHECK_LIB(z, gzread))
|
|
||||||
|
|
||||||
|
|
||||||
dnl Default is to try the thread-safe versions of a few functions
|
|
||||||
OPT_THREAD=on
|
|
||||||
AC_ARG_ENABLE(thread,dnl
|
|
||||||
[ --disable-thread tell configure to not look for thread-safe functions],
|
|
||||||
OPT_THREAD=off
|
|
||||||
)
|
|
||||||
|
|
||||||
if test X"$OPT_THREAD" = Xoff
|
|
||||||
then
|
|
||||||
AC_MSG_WARN(libcurl will not get built using thread-safe functions)
|
|
||||||
AC_DEFINE(DISABLED_THREADSAFE, 1, \
|
|
||||||
Set to explicitly specify we don't want to use thread-safe functions)
|
|
||||||
else
|
|
||||||
|
|
||||||
dnl dig around for gethostbyname_r()
|
|
||||||
CURL_CHECK_GETHOSTBYNAME_R()
|
|
||||||
|
|
||||||
dnl dig around for gethostbyaddr_r()
|
|
||||||
CURL_CHECK_GETHOSTBYADDR_R()
|
|
||||||
|
|
||||||
dnl poke around for inet_ntoa_r()
|
|
||||||
CURL_CHECK_INET_NTOA_R()
|
|
||||||
|
|
||||||
dnl is there a localtime_r()
|
|
||||||
CURL_CHECK_LOCALTIME_R()
|
|
||||||
|
|
||||||
AC_CHECK_FUNCS( gmtime_r )
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Back to "normal" configuring
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
dnl Checks for header files.
|
|
||||||
AC_HEADER_STDC
|
|
||||||
AC_CHECK_HEADERS( \
|
|
||||||
unistd.h \
|
|
||||||
malloc.h \
|
|
||||||
stdlib.h \
|
|
||||||
arpa/inet.h \
|
|
||||||
net/if.h \
|
|
||||||
netinet/in.h \
|
|
||||||
netinet/if_ether.h \
|
|
||||||
netdb.h \
|
|
||||||
sys/select.h \
|
|
||||||
sys/socket.h \
|
|
||||||
sys/sockio.h \
|
|
||||||
sys/stat.h \
|
|
||||||
sys/types.h \
|
|
||||||
sys/time.h \
|
|
||||||
sys/param.h \
|
|
||||||
termios.h \
|
|
||||||
termio.h \
|
|
||||||
sgtty.h \
|
|
||||||
fcntl.h \
|
|
||||||
dlfcn.h \
|
|
||||||
alloca.h \
|
|
||||||
winsock.h \
|
|
||||||
time.h \
|
|
||||||
io.h \
|
|
||||||
pwd.h \
|
|
||||||
utime.h \
|
|
||||||
sys/utime.h
|
|
||||||
)
|
|
||||||
|
|
||||||
dnl Check for libz header
|
|
||||||
dnl AC_CHECK_HEADERS(zlib.h)
|
|
||||||
|
|
||||||
dnl Checks for typedefs, structures, and compiler characteristics.
|
|
||||||
AC_C_CONST
|
|
||||||
AC_TYPE_SIZE_T
|
|
||||||
AC_HEADER_TIME
|
|
||||||
|
|
||||||
# mprintf() checks:
|
|
||||||
|
|
||||||
# check for 'long double'
|
|
||||||
AC_CHECK_SIZEOF(long double, 8)
|
|
||||||
# check for 'long long'
|
|
||||||
AC_CHECK_SIZEOF(long long, 4)
|
|
||||||
|
|
||||||
# check for ssize_t
|
|
||||||
AC_CHECK_TYPE(ssize_t, int)
|
|
||||||
|
|
||||||
TYPE_SOCKLEN_T
|
|
||||||
TYPE_IN_ADDR_T
|
|
||||||
|
|
||||||
dnl Checks for library functions.
|
|
||||||
dnl AC_PROG_GCC_TRADITIONAL
|
|
||||||
AC_TYPE_SIGNAL
|
|
||||||
dnl AC_FUNC_VPRINTF
|
|
||||||
AC_CHECK_FUNCS( socket \
|
|
||||||
select \
|
|
||||||
strdup \
|
|
||||||
strstr \
|
|
||||||
strtok_r \
|
|
||||||
strftime \
|
|
||||||
uname \
|
|
||||||
strcasecmp \
|
|
||||||
stricmp \
|
|
||||||
strcmpi \
|
|
||||||
gethostname \
|
|
||||||
gethostbyaddr \
|
|
||||||
gettimeofday \
|
|
||||||
inet_addr \
|
|
||||||
inet_ntoa \
|
|
||||||
tcsetattr \
|
|
||||||
tcgetattr \
|
|
||||||
perror \
|
|
||||||
closesocket \
|
|
||||||
setvbuf \
|
|
||||||
sigaction \
|
|
||||||
signal \
|
|
||||||
getpass_r \
|
|
||||||
strlcat \
|
|
||||||
getpwuid \
|
|
||||||
geteuid \
|
|
||||||
dlopen \
|
|
||||||
utime
|
|
||||||
)
|
|
||||||
|
|
||||||
dnl removed 'getpass' check on October 26, 2000
|
|
||||||
|
|
||||||
if test "$ac_cv_func_select" != "yes"; then
|
|
||||||
AC_MSG_ERROR(Can't work without an existing select() function)
|
|
||||||
fi
|
|
||||||
if test "$ac_cv_func_socket" != "yes"; then
|
|
||||||
AC_MSG_ERROR(Can't work without an existing socket() function)
|
|
||||||
fi
|
|
||||||
|
|
||||||
AC_PATH_PROG( PERL, perl, ,
|
|
||||||
$PATH:/usr/local/bin/perl:/usr/bin/:/usr/local/bin )
|
|
||||||
AC_SUBST(PERL)
|
|
||||||
|
|
||||||
AC_PATH_PROGS( NROFF, gnroff nroff, ,
|
|
||||||
$PATH:/usr/bin/:/usr/local/bin )
|
|
||||||
AC_SUBST(NROFF)
|
|
||||||
|
|
||||||
AC_PROG_YACC
|
|
||||||
|
|
||||||
dnl AC_PATH_PROG( RANLIB, ranlib, /usr/bin/ranlib,
|
|
||||||
dnl $PATH:/usr/bin/:/usr/local/bin )
|
|
||||||
dnl AC_SUBST(RANLIB)
|
|
||||||
|
|
||||||
AC_CONFIG_FILES([Makefile \
|
|
||||||
docs/Makefile \
|
|
||||||
docs/examples/Makefile \
|
|
||||||
include/Makefile \
|
|
||||||
include/curl/Makefile \
|
|
||||||
src/Makefile \
|
|
||||||
lib/Makefile \
|
|
||||||
tests/Makefile \
|
|
||||||
tests/data/Makefile \
|
|
||||||
packages/Makefile \
|
|
||||||
packages/Win32/Makefile \
|
|
||||||
packages/Win32/cygwin/Makefile \
|
|
||||||
packages/Linux/Makefile \
|
|
||||||
packages/Linux/RPM/Makefile \
|
|
||||||
packages/Linux/RPM/curl.spec \
|
|
||||||
packages/Linux/RPM/curl-ssl.spec \
|
|
||||||
packages/Solaris/Makefile \
|
|
||||||
curl-config
|
|
||||||
])
|
|
||||||
AC_OUTPUT
|
|
||||||
|
|
@@ -16,6 +16,8 @@ Usage: curl-config [OPTION]
|
|||||||
|
|
||||||
Available values for OPTION include:
|
Available values for OPTION include:
|
||||||
|
|
||||||
|
--ca ca bundle install path
|
||||||
|
--cc compiler
|
||||||
--cflags pre-processor and compiler flags
|
--cflags pre-processor and compiler flags
|
||||||
--feature newline separated list of enabled features
|
--feature newline separated list of enabled features
|
||||||
--help display this help and exit
|
--help display this help and exit
|
||||||
@@ -42,6 +44,14 @@ while test $# -gt 0; do
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
|
--ca)
|
||||||
|
echo @CURL_CA_BUNDLE@
|
||||||
|
;;
|
||||||
|
|
||||||
|
--cc)
|
||||||
|
echo @CC@
|
||||||
|
;;
|
||||||
|
|
||||||
--prefix)
|
--prefix)
|
||||||
echo $prefix
|
echo $prefix
|
||||||
;;
|
;;
|
||||||
@@ -56,6 +66,30 @@ while test $# -gt 0; do
|
|||||||
if test "@IPV6_ENABLED@" = "1"; then
|
if test "@IPV6_ENABLED@" = "1"; then
|
||||||
echo "IPv6"
|
echo "IPv6"
|
||||||
fi
|
fi
|
||||||
|
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
|
||||||
;;
|
;;
|
||||||
|
|
||||||
--version)
|
--version)
|
||||||
@@ -73,7 +107,11 @@ while test $# -gt 0; do
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
--cflags)
|
--cflags)
|
||||||
echo -I@includedir@
|
if test "X@includedir@" = "X/usr/include"; then
|
||||||
|
echo ""
|
||||||
|
else
|
||||||
|
echo "-I@includedir@"
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
|
|
||||||
--libs)
|
--libs)
|
||||||
|
21
curl-mode.el
21
curl-mode.el
@@ -1,21 +0,0 @@
|
|||||||
;;;; Emacs Lisp help for writing curl code. ;;;;
|
|
||||||
|
|
||||||
;;; In C files, put something like this to load this file automatically:
|
|
||||||
;;
|
|
||||||
;; /* -----------------------------------------------------------------
|
|
||||||
;; * local variables:
|
|
||||||
;; * eval: (load-file "../curl-mode.el")
|
|
||||||
;; * end:
|
|
||||||
;; */
|
|
||||||
;;
|
|
||||||
;; (note: make sure to get the path right in the argument to load-file).
|
|
||||||
|
|
||||||
|
|
||||||
;;; The curl hacker's C conventions
|
|
||||||
|
|
||||||
;;; we use intent-level 2
|
|
||||||
(setq c-basic-offset 2)
|
|
||||||
;;; never ever use tabs to indent!
|
|
||||||
(setq indent-tabs-mode nil)
|
|
||||||
;;; I like this, stolen from Subversion! ;-)
|
|
||||||
(setq angry-mob-with-torches-and-pitchforks t)
|
|
50
curl-style.el
Normal file
50
curl-style.el
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
;;;; Emacs Lisp help for writing curl code. ;;;;
|
||||||
|
;;;; $Id$
|
||||||
|
|
||||||
|
;;; The curl hacker's C conventions.
|
||||||
|
|
||||||
|
;;; After loading this file and added the mode-hook you can in C
|
||||||
|
;;; files, put something like this to use the curl style
|
||||||
|
;;; automatically:
|
||||||
|
;;
|
||||||
|
;; /* -----------------------------------------------------------------
|
||||||
|
;; * local variables:
|
||||||
|
;; * eval: (set c-file-style "curl")
|
||||||
|
;; * end:
|
||||||
|
;; */
|
||||||
|
;;
|
||||||
|
|
||||||
|
(defconst curl-c-style
|
||||||
|
'((c-basic-offset . 2)
|
||||||
|
(c-comment-only-line-offset . 0)
|
||||||
|
(c-hanging-braces-alist . ((substatement-open before after)))
|
||||||
|
(c-offsets-alist . ((topmost-intro . 0)
|
||||||
|
(topmost-intro-cont . 0)
|
||||||
|
(substatement . +)
|
||||||
|
(substatement-open . 0)
|
||||||
|
(statement-case-intro . +)
|
||||||
|
(statement-case-open . 0)
|
||||||
|
(case-label . 0)
|
||||||
|
))
|
||||||
|
)
|
||||||
|
"Curl C Programming Style")
|
||||||
|
|
||||||
|
;; Customizations for all of c-mode, c++-mode, and objc-mode
|
||||||
|
(defun curl-c-mode-common-hook ()
|
||||||
|
"Curl C mode hook"
|
||||||
|
;; add curl style and set it for the current buffer
|
||||||
|
(c-add-style "curl" curl-c-style t)
|
||||||
|
(setq tab-width 8
|
||||||
|
indent-tabs-mode nil ; Use spaces. Not tabs.
|
||||||
|
comment-column 40
|
||||||
|
c-font-lock-extra-types (append '("bool" "CURL" "CURLcode" "ssize_t" "size_t" "socklen_t" "fd_set" "time_t"))
|
||||||
|
)
|
||||||
|
;; keybindings for C, C++, and Objective-C. We can put these in
|
||||||
|
;; c-mode-base-map because of inheritance ...
|
||||||
|
(define-key c-mode-base-map "\M-q" 'c-fill-paragraph)
|
||||||
|
(setq c-recognize-knr-p nil)
|
||||||
|
)
|
||||||
|
|
||||||
|
;; Set this is in your .emacs if you want to use the c-mode-hook as
|
||||||
|
;; defined here right out of the box.
|
||||||
|
; (add-hook 'c-mode-common-hook 'curl-c-mode-common-hook)
|
5
docs/.cvsignore
Normal file
5
docs/.cvsignore
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
*html
|
||||||
|
*ps
|
||||||
|
*pdf
|
96
docs/BINDINGS
Normal file
96
docs/BINDINGS
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
libcurl bindings
|
||||||
|
|
||||||
|
Creative people have written particular bindings or interfaces for various
|
||||||
|
environments and programming languages. Using one of these allows you to take
|
||||||
|
advantage of curl powers from within your favourite language or system.
|
||||||
|
|
||||||
|
This is a list of all known interfaces as of this writing.
|
||||||
|
|
||||||
|
The bindings listed below are not part of the curl/libcurl distribution
|
||||||
|
archives, but must be downloaded and installed separately.
|
||||||
|
|
||||||
|
Basic
|
||||||
|
|
||||||
|
ScriptBasic bindings to libcurl. Writtten by Peter Verhas.
|
||||||
|
http://scriptbasic.com/
|
||||||
|
|
||||||
|
C++
|
||||||
|
|
||||||
|
Maintained by Jean-Philippe Barrette-LaPierre.
|
||||||
|
http://curl.haxx.se/libcurl/cplusplus/
|
||||||
|
|
||||||
|
Cocoa
|
||||||
|
|
||||||
|
Written by Dan Wood.
|
||||||
|
http://curlhandle.sourceforge.net/
|
||||||
|
|
||||||
|
Dylan
|
||||||
|
|
||||||
|
Written by Chris Double.
|
||||||
|
http://dylanlibs.sourceforge.net/
|
||||||
|
|
||||||
|
Java
|
||||||
|
|
||||||
|
Written by Daniel Stenberg.
|
||||||
|
http://curl.haxx.se/libcurl/java/
|
||||||
|
|
||||||
|
Lua
|
||||||
|
|
||||||
|
Written by Steve Dekorte.
|
||||||
|
http://curl.haxx.se/libcurl/lua/
|
||||||
|
|
||||||
|
Object-Pascal
|
||||||
|
|
||||||
|
Free Pascal, Delphi and Kylix binding written by Christophe Espern.
|
||||||
|
http://www.tekool.com/opcurl
|
||||||
|
|
||||||
|
Pascal
|
||||||
|
|
||||||
|
Free Pascal, Delphi and Kylix binding written by Jeffrey Pohlmeyer.
|
||||||
|
http://houston.quik.com/jkp/curlpas/
|
||||||
|
|
||||||
|
Perl
|
||||||
|
|
||||||
|
Maintained by Cris Bailiff.
|
||||||
|
http://curl.haxx.se/libcurl/perl/
|
||||||
|
|
||||||
|
PHP
|
||||||
|
|
||||||
|
Written by Sterling Hughes.
|
||||||
|
http://curl.haxx.se/libcurl/php/
|
||||||
|
|
||||||
|
PostgreSQL
|
||||||
|
|
||||||
|
Written by Gian Paolo Ciceri.
|
||||||
|
http://gborg.postgresql.org/project/pgcurl/projdisplay.php
|
||||||
|
|
||||||
|
Python
|
||||||
|
|
||||||
|
Written by Kjetil Jacobsen.
|
||||||
|
http://pycurl.sourceforge.net/
|
||||||
|
|
||||||
|
Rexx
|
||||||
|
|
||||||
|
Written Mark Hessling.
|
||||||
|
http://rexxcurl.sourceforge.net/
|
||||||
|
|
||||||
|
Ruby
|
||||||
|
|
||||||
|
Written by Hirotaka Matsuyuki.
|
||||||
|
http://www.d1.dion.ne.jp/~matuyuki/ruby.html
|
||||||
|
|
||||||
|
Scheme
|
||||||
|
|
||||||
|
Bigloo binding written by Kirill Lisovsky.
|
||||||
|
http://curl.haxx.se/libcurl/scheme/
|
||||||
|
|
||||||
|
Tcl
|
||||||
|
|
||||||
|
Written by Andr<64>s Garc<72>a.
|
||||||
|
http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html
|
45
docs/BUGS
45
docs/BUGS
@@ -8,25 +8,49 @@ $Id$
|
|||||||
BUGS
|
BUGS
|
||||||
|
|
||||||
Curl and libcurl have grown substantially since the beginning. At the time
|
Curl and libcurl have grown substantially since the beginning. At the time
|
||||||
of writing (mid March 2001), there are 23000 lines of source code, and by
|
of writing (end of March 2003), there are 35000 lines of source code, and by
|
||||||
the time you read this it has probably grown even more.
|
the time you read this it has probably grown even more.
|
||||||
|
|
||||||
Of course there are lots of bugs left. And lots of misfeatures.
|
Of course there are lots of bugs left. And lots of misfeatures.
|
||||||
|
|
||||||
To help us make curl the stable and solid product we want it to be, we need
|
To help us make curl the stable and solid product we want it to be, we need
|
||||||
bug reports and bug fixes. If you can't fix a bug yourself and submit a fix
|
bug reports and bug fixes.
|
||||||
for it, try to report an as detailed report as possible to the curl mailing
|
|
||||||
list to allow one of us to have a go at a solution. You should also post
|
WHERE TO REPORT
|
||||||
your bug/problem at curl's bug tracking system over at
|
|
||||||
|
If you can't fix a bug yourself and submit a fix for it, try to report an as
|
||||||
|
detailed report as possible to a curl mailing list to allow one of us to
|
||||||
|
have a go at a solution. You should also post your bug/problem at curl's bug
|
||||||
|
tracking system over at
|
||||||
|
|
||||||
http://sourceforge.net/bugs/?group_id=976
|
http://sourceforge.net/bugs/?group_id=976
|
||||||
|
|
||||||
|
(but please read the sections below first before doing that)
|
||||||
|
|
||||||
|
If you feel you need to ask around first, find a suitable mailing list and
|
||||||
|
post there. The lists are available on http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
WHAT TO REPORT
|
||||||
|
|
||||||
When reporting a bug, you should include information that will help us
|
When reporting a bug, you should include information that will help us
|
||||||
understand what's wrong, what you expected to happen and how to repeat the
|
understand what's wrong, what you expected to happen and how to repeat the
|
||||||
bad behaviour. You therefore need to supply your operating system's name and
|
bad behavior. You therefore need to tell us:
|
||||||
version number (uname -a under a unix is fine), what version of curl you're
|
|
||||||
using (curl -V is fine), what URL you were working with and anything else
|
- your operating system's name and version number (uname -a under a unix
|
||||||
you think matters.
|
is fine)
|
||||||
|
- what version of curl you're using (curl -V is fine)
|
||||||
|
- what URL you were working with (if possible), at least which protocol
|
||||||
|
|
||||||
|
and anything and everything else you think matters. Tell us what you
|
||||||
|
expected to happen, tell use what did happen, tell us how you could make it
|
||||||
|
work another way. Dig around, try out, test. Then include all the tiny bits
|
||||||
|
and pieces in your report. You will benefit from this yourself, as it will
|
||||||
|
enable us to help you quicker and more accurately.
|
||||||
|
|
||||||
|
Since curl deals with networks, it often helps us if you include a protocol
|
||||||
|
debug dump with your bug report. The output you get by using the -v
|
||||||
|
flag. Usually, you also get more info by using -i so that is likely to be
|
||||||
|
useful when reporting bugs as well.
|
||||||
|
|
||||||
If curl crashed, causing a core dump (in unix), there is hardly any use to
|
If curl crashed, causing a core dump (in unix), there is hardly any use to
|
||||||
send that huge file to anyone of us. Unless we have an exact same system
|
send that huge file to anyone of us. Unless we have an exact same system
|
||||||
@@ -36,8 +60,7 @@ BUGS
|
|||||||
The address and how to subscribe to the mailing list is detailed in the
|
The address and how to subscribe to the mailing list is detailed in the
|
||||||
MANUAL file.
|
MANUAL file.
|
||||||
|
|
||||||
How To Get A Stack Trace
|
HOW TO GET A STACK TRACE
|
||||||
========================
|
|
||||||
|
|
||||||
First, you must make sure that you compile all sources with -g and that you
|
First, you must make sure that you compile all sources with -g and that you
|
||||||
don't 'strip' the final executable. Try to avoid optimizing the code as
|
don't 'strip' the final executable. Try to avoid optimizing the code as
|
||||||
|
@@ -6,15 +6,16 @@
|
|||||||
|
|
||||||
To Think About When Contributing Source Code
|
To Think About When Contributing Source Code
|
||||||
|
|
||||||
This document is intended to offer some guidelines that can be useful to keep
|
This document is intended to offer some simple guidelines that can be useful
|
||||||
in mind when you decide to write a contribution to the project. This concerns
|
to keep in mind when you decide to contribute to the project. This concerns
|
||||||
new features as well as corrections to existing flaws or bugs.
|
new features as well as corrections to existing flaws or bugs.
|
||||||
|
|
||||||
Join the Community
|
Join the Community
|
||||||
|
|
||||||
Skip over to http://curl.haxx.se/mail/ and join the appropriate mailing
|
Skip over to http://curl.haxx.se/mail/ and join the appropriate mailing
|
||||||
list(s). Read up on details before you post questions. Read this file before
|
list(s). Read up on details before you post questions. Read this file before
|
||||||
you start sending patches!
|
you start sending patches! We prefer patches and discussions being held on
|
||||||
|
the mailing list(s), not sent to individuals.
|
||||||
|
|
||||||
The License Issue
|
The License Issue
|
||||||
|
|
||||||
@@ -29,9 +30,9 @@ The License Issue
|
|||||||
|
|
||||||
What To Read
|
What To Read
|
||||||
|
|
||||||
Source code, the man pages, the INTERALS document, the TODO, the most recent
|
Source code, the man pages, the INTERNALS document, the TODO, the most recent
|
||||||
CHANGES. Just lurking on the libcurl mailing list is gonna give you a lot of
|
CHANGES. Just lurking on the libcurl mailing list is gonna give you a lot of
|
||||||
insights on what's going on right now.
|
insights on what's going on right now. Asking there is a good idea too.
|
||||||
|
|
||||||
Naming
|
Naming
|
||||||
|
|
||||||
@@ -39,26 +40,32 @@ Naming
|
|||||||
names. It doesn't necessarily have to mean that you should use the same as in
|
names. It doesn't necessarily have to mean that you should use the same as in
|
||||||
other places of the code, just that the names should be logical,
|
other places of the code, just that the names should be logical,
|
||||||
understandable and be named according to what they're used for. File-local
|
understandable and be named according to what they're used for. File-local
|
||||||
functions should be made static.
|
functions should be made static. We like lower case names.
|
||||||
|
|
||||||
|
See the INTERNALS document on how we name non-exported library-global
|
||||||
|
symbols.
|
||||||
|
|
||||||
Indenting
|
Indenting
|
||||||
|
|
||||||
Please try using the same indenting levels and bracing method as all the
|
Please try using the same indenting levels and bracing method as all the
|
||||||
other code already does. It makes the source code a lot easier to follow if
|
other code already does. It makes the source code a lot easier to follow if
|
||||||
all of it is written using the same style. We don't ask you to like it, we
|
all of it is written using the same style. We don't ask you to like it, we
|
||||||
just ask you to follow the tradition! ;-)
|
just ask you to follow the tradition! ;-) This mainly means: 2-level indents,
|
||||||
|
using spaces only (no tabs) and having the opening brace ({) on the same line
|
||||||
|
as the if() or while().
|
||||||
|
|
||||||
Commenting
|
Commenting
|
||||||
|
|
||||||
Comment your source code extensively. Commented code is quality code and
|
Comment your source code extensively using C comments (/* comment */), DO NOT
|
||||||
enables future modifications much more. Uncommented code much more risk being
|
use C++ comments (// this style). Commented code is quality code and enables
|
||||||
|
future modifications much more. Uncommented code much more risk being
|
||||||
completely replaced when someone wants to extend things, since other persons'
|
completely replaced when someone wants to extend things, since other persons'
|
||||||
source code can get quite hard to read.
|
source code can get quite hard to read.
|
||||||
|
|
||||||
General Style
|
General Style
|
||||||
|
|
||||||
Keep your functions small. If they're small you avoid a lot of mistakes and
|
Keep your functions small. If they're small you avoid a lot of mistakes and
|
||||||
you don't accidentally mix up variables.
|
you don't accidentally mix up variables etc.
|
||||||
|
|
||||||
Non-clobbering All Over
|
Non-clobbering All Over
|
||||||
|
|
||||||
@@ -69,7 +76,14 @@ Non-clobbering All Over
|
|||||||
functionality, try writing it in a new source file. If you fix bugs, try to
|
functionality, try writing it in a new source file. If you fix bugs, try to
|
||||||
fix one bug at a time and send them as separate patches.
|
fix one bug at a time and send them as separate patches.
|
||||||
|
|
||||||
Separate Patches Doing Different Things
|
Platform Dependent Code
|
||||||
|
|
||||||
|
Use #ifdef HAVE_FEATURE to do conditional code. We avoid checking for
|
||||||
|
particular operating systems or hardware in the #ifdef lines. The
|
||||||
|
HAVE_FEATURE shall be generated by the configure script for unix-like systems
|
||||||
|
and they are hard-coded in the config-[system].h files for the others.
|
||||||
|
|
||||||
|
Separate Patches
|
||||||
|
|
||||||
It is annoying when you get a huge patch from someone that is said to fix 511
|
It is annoying when you get a huge patch from someone that is said to fix 511
|
||||||
odd problems, but discussions and opinions don't agree with 510 of them - or
|
odd problems, but discussions and opinions don't agree with 510 of them - or
|
||||||
@@ -94,6 +108,10 @@ Document
|
|||||||
small description of your fix or your new features with every contribution so
|
small description of your fix or your new features with every contribution so
|
||||||
that it can be swiftly added to the package documentation.
|
that it can be swiftly added to the package documentation.
|
||||||
|
|
||||||
|
The documentation is always made in man pages (nroff formatted) or plain
|
||||||
|
ASCII files. All HTML files on the web site and in the release archives are
|
||||||
|
generated from the nroff/ASCII versions.
|
||||||
|
|
||||||
Write Access to CVS Repository
|
Write Access to CVS Repository
|
||||||
|
|
||||||
If you are a frequent contributor, or have another good reason, you can of
|
If you are a frequent contributor, or have another good reason, you can of
|
||||||
@@ -111,3 +129,31 @@ Test Cases
|
|||||||
in the test suite. Every feature that is added should get at least one valid
|
in the test suite. Every feature that is added should get at least one valid
|
||||||
test case that verifies that it works as documented. If every submitter also
|
test case that verifies that it works as documented. If every submitter also
|
||||||
post a few test cases, it won't end up as a heavy burden on a single person!
|
post a few test cases, it won't end up as a heavy burden on a single person!
|
||||||
|
|
||||||
|
How To Make a Patch
|
||||||
|
|
||||||
|
Keep a copy of the unmodified curl sources. Make your changes in a separate
|
||||||
|
source tree. When you think you have something that you want to offer the
|
||||||
|
curl community, use GNU diff to generate patches.
|
||||||
|
|
||||||
|
If you have modified a single file, try something like:
|
||||||
|
|
||||||
|
diff -u undmodified-file.c my-changed-one.c > my-fixes.diff
|
||||||
|
|
||||||
|
If you have modified several files, possibly in different directories, you
|
||||||
|
can use diff recursively:
|
||||||
|
|
||||||
|
diff -ur curl-original-dir curl-modfied-sources-dir > my-fixes.diff
|
||||||
|
|
||||||
|
The GNU diff and GNU patch tools exist for virtually all platforms, including
|
||||||
|
all kinds of unixes and Windows:
|
||||||
|
|
||||||
|
For unix-like operating systems:
|
||||||
|
|
||||||
|
http://www.fsf.org/software/patch/patch.html
|
||||||
|
http://www.gnu.org/directory/diffutils.html
|
||||||
|
|
||||||
|
For Windows:
|
||||||
|
|
||||||
|
http://gnuwin32.sourceforge.net/packages/patch.htm
|
||||||
|
http://gnuwin32.sourceforge.net/packages/diffutils.htm
|
||||||
|
274
docs/FAQ
274
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: December 21, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
Updated: June 17, 2003 (http://curl.haxx.se/docs/faq.html)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -15,6 +15,7 @@ FAQ
|
|||||||
1.5 Who makes cURL?
|
1.5 Who makes cURL?
|
||||||
1.6 What do you get for making cURL?
|
1.6 What do you get for making cURL?
|
||||||
1.7 What about CURL from curl.com?
|
1.7 What about CURL from curl.com?
|
||||||
|
1.8 I have a problem who do I mail?
|
||||||
|
|
||||||
2. Install Related Problems
|
2. Install Related Problems
|
||||||
2.1 configure doesn't find OpenSSL even when it is installed
|
2.1 configure doesn't find OpenSSL even when it is installed
|
||||||
@@ -30,13 +31,15 @@ FAQ
|
|||||||
3.3 Why doesn't my posting using -F work?
|
3.3 Why doesn't my posting using -F work?
|
||||||
3.4 How do I tell curl to run custom FTP commands?
|
3.4 How do I tell curl to run custom FTP commands?
|
||||||
3.5 How can I disable the Pragma: nocache header?
|
3.5 How can I disable the Pragma: nocache header?
|
||||||
3.6 Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
3.6 Does curl support ASP, XML, XHTML or HTML version Y?
|
||||||
3.7 Can I use curl to delete/rename a file through FTP?
|
3.7 Can I use curl to delete/rename a file through FTP?
|
||||||
3.8 How do I tell curl to follow HTTP redirects?
|
3.8 How do I tell curl to follow HTTP redirects?
|
||||||
3.9 How do I use curl in my favourite programming language?
|
3.9 How do I use curl in my favorite programming language?
|
||||||
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
3.11 How do I POST with a different Content-Type?
|
3.11 How do I POST with a different Content-Type?
|
||||||
3.12 Why do FTP specific features over HTTP proxy fail?
|
3.12 Why do FTP specific features over HTTP proxy fail?
|
||||||
|
3.13 Why does my single/double quotes fail?
|
||||||
|
3.14 Does curl support javascript or pac (automated proxy config)?
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
@@ -54,6 +57,9 @@ FAQ
|
|||||||
4.7 How do I keep user names and passwords secret in Curl command lines?
|
4.7 How do I keep user names and passwords secret in Curl command lines?
|
||||||
4.8 I found a bug!
|
4.8 I found a bug!
|
||||||
4.9 Curl can't authenticate to the server that requires NTLM?
|
4.9 Curl can't authenticate to the server that requires NTLM?
|
||||||
|
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" ?
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
5.1 Is libcurl thread-safe?
|
5.1 Is libcurl thread-safe?
|
||||||
@@ -62,6 +68,7 @@ FAQ
|
|||||||
5.4 Does libcurl do Winsock initing on win32 systems?
|
5.4 Does libcurl do Winsock initing on win32 systems?
|
||||||
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
5.6 What about Keep-Alive or persistent connections?
|
5.6 What about Keep-Alive or persistent connections?
|
||||||
|
5.7 Link errors when building libcurl on Windows!
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
6.1 I have a GPL program, can I use the libcurl library?
|
6.1 I have a GPL program, can I use the libcurl library?
|
||||||
@@ -80,7 +87,9 @@ FAQ
|
|||||||
cURL (or simply just 'curl') is a command line tool for getting or sending
|
cURL (or simply just 'curl') is a command line tool for getting or sending
|
||||||
files using URL syntax. The name is a play on 'Client for URLs', originally
|
files using URL syntax. The name is a play on 'Client for URLs', originally
|
||||||
with URL spelled in uppercase to make it obvious it deals with URLs. The
|
with URL spelled in uppercase to make it obvious it deals with URLs. The
|
||||||
fact it can also be pronounced 'see URL' also helped.
|
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
|
||||||
|
version: "Curl is a URL Request Library".
|
||||||
|
|
||||||
Curl supports a range of common Internet protocols, currently including
|
Curl supports a range of common Internet protocols, currently including
|
||||||
HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE.
|
HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE.
|
||||||
@@ -88,6 +97,12 @@ FAQ
|
|||||||
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
||||||
[kurl].
|
[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
|
||||||
|
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
|
||||||
|
projects.
|
||||||
|
|
||||||
1.2 What is libcurl?
|
1.2 What is libcurl?
|
||||||
|
|
||||||
libcurl is a reliable and portable library which provides you with an easy
|
libcurl is a reliable and portable library which provides you with an easy
|
||||||
@@ -123,11 +138,9 @@ FAQ
|
|||||||
better. We do however believe in a few rules when it comes to the future of
|
better. We do however believe in a few rules when it comes to the future of
|
||||||
curl:
|
curl:
|
||||||
|
|
||||||
* Curl is to remain a command line tool. If you want GUIs or fancy scripting
|
* Curl -- the command line tool -- is to remain a non-graphical command line
|
||||||
capabilities, you're free to write another tool that uses libcurl and that
|
tool. If you want GUIs or fancy scripting capabilities, you should look
|
||||||
offers this. There's no point in having a single tool that does every
|
for another tool that uses libcurl.
|
||||||
imaginable thing. That's also one of the great advantages of having the
|
|
||||||
core of curl as a library.
|
|
||||||
|
|
||||||
* We do not add things to curl that other small and available tools already
|
* We do not add things to curl that other small and available tools already
|
||||||
do very fine at the side. Curl's output is fine to pipe into another
|
do very fine at the side. Curl's output is fine to pipe into another
|
||||||
@@ -150,10 +163,10 @@ FAQ
|
|||||||
1.5 Who makes cURL?
|
1.5 Who makes cURL?
|
||||||
|
|
||||||
cURL and libcurl are not made by any single individual. Sure, Daniel
|
cURL and libcurl are not made by any single individual. Sure, Daniel
|
||||||
Stenberg writes the major parts, but various people's submissions are
|
Stenberg writes the major parts, but other persons' submissions are
|
||||||
important and crucial. Anyone can post their changes and improvements and
|
important and crucial. Anyone can contribute and post their changes and
|
||||||
have them inserted in the main sources (of course on the condition that
|
improvements and have them inserted in the main sources (of course on the
|
||||||
developers agree on that the fixes are good).
|
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 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
|
the people that every day provide us with bug reports, suggestions, ideas
|
||||||
@@ -163,24 +176,24 @@ FAQ
|
|||||||
|
|
||||||
1.6 What do you get for making cURL?
|
1.6 What do you get for making cURL?
|
||||||
|
|
||||||
Project cURL is entirely free and open, without any commercial interests or
|
Project cURL is entirely free and open. No person gets paid for developing
|
||||||
money involved. No person gets paid in any way for developing curl. We all
|
curl. We do this voluntarily on our spare time.
|
||||||
do this voluntarily on our spare time.
|
|
||||||
|
|
||||||
We get some help from companies. Contactor Data hosts the curl web site and
|
We get some help from companies. Contactor Data hosts the curl web site,
|
||||||
the main mailing list, Haxx owns the curl web site's domain and
|
Haxx owns the curl web site's domain and sourceforge.net hosts several
|
||||||
sourceforge.net hosts several project tools we take advantage from like the
|
project services we take advantage from, like the bug tracker, mailing lists
|
||||||
bug tracker, mailing lists and more.
|
and more.
|
||||||
|
|
||||||
If you want to support our project with a donation or similar, one way of
|
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
|
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
|
sites, such as amazon.com or thinkgeek.com. Another way would be to sponsor
|
||||||
us through a banner-program or by simply helping us coding, documenting,
|
us through a banner-program or even better: by helping us coding,
|
||||||
testing etc.
|
documenting, testing etc. You're welcome to send us a buck using paypal, as
|
||||||
|
described here: http://curl.haxx.se/donation.html
|
||||||
|
|
||||||
1.7 What about CURL from curl.com?
|
1.7 What about CURL from curl.com?
|
||||||
|
|
||||||
During the summer 2001, curl.com has been busy advertising their client-side
|
During the summer 2001, curl.com was busy advertising their client-side
|
||||||
programming language for the web, named CURL.
|
programming language for the web, named CURL.
|
||||||
|
|
||||||
We are in no way associated with curl.com or their CURL programming
|
We are in no way associated with curl.com or their CURL programming
|
||||||
@@ -193,6 +206,21 @@ FAQ
|
|||||||
We recognize that we will be living in parallel with curl.com and wish them
|
We recognize that we will be living in parallel with curl.com and wish them
|
||||||
every success.
|
every success.
|
||||||
|
|
||||||
|
1.8 I have a problem who do I mail?
|
||||||
|
|
||||||
|
Please do not mail any single individual unless you really need to. Keep
|
||||||
|
curl-related questions on a suitable mailing list. All available mailing
|
||||||
|
lists are listed in the MANUAL document and online at
|
||||||
|
http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
Keeping curl-related questions and discussions on mailing lists allows
|
||||||
|
others to join in and help, to share their ideas, contribute their
|
||||||
|
suggestions and spread their wisdom. Keeping discussions on public mailing
|
||||||
|
lists also allows for others to learn from this (both current and future
|
||||||
|
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.
|
||||||
|
|
||||||
|
|
||||||
2. Install Related Problems
|
2. Install Related Problems
|
||||||
|
|
||||||
2.1. configure doesn't find OpenSSL even when it is installed
|
2.1. configure doesn't find OpenSSL even when it is installed
|
||||||
@@ -252,8 +280,8 @@ FAQ
|
|||||||
|
|
||||||
2.4. Does cURL support Socks (RFC 1928) ?
|
2.4. Does cURL support Socks (RFC 1928) ?
|
||||||
|
|
||||||
No. Nobody has wanted it that badly yet. We appreciate patches that bring
|
There is limited support for SOCKS5 for curl built with IPv6 support
|
||||||
this functionality.
|
disabled.
|
||||||
|
|
||||||
|
|
||||||
3. Usage problems
|
3. Usage problems
|
||||||
@@ -308,16 +336,14 @@ FAQ
|
|||||||
the -H/--header option. By adding a header with empty contents you safely
|
the -H/--header option. By adding a header with empty contents you safely
|
||||||
disable that one. Use -H "Pragma:" to disable that specific header.
|
disable that one. Use -H "Pragma:" to disable that specific header.
|
||||||
|
|
||||||
3.6. Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
3.6. Does curl support ASP, XML, XHTML or HTML version Y?
|
||||||
|
|
||||||
To curl, all contents are alike. It doesn't matter how the page was
|
To curl, all contents are alike. It doesn't matter how the page was
|
||||||
generated. It may be ASP, PHP, Perl, shell-script, SSI or plain
|
generated. It may be ASP, PHP, Perl, shell-script, SSI or plain
|
||||||
HTML-files. There's no difference to curl and it doesn't even know what kind
|
HTML-files. There's no difference to curl and it doesn't even know what kind
|
||||||
of language that generated the page.
|
of language that generated the page.
|
||||||
|
|
||||||
Javascript is slightly different since that is code embedded in the HTML
|
See also item 3.14 regarding javascript.
|
||||||
that is sent for the client to interpret and curl has no javascript
|
|
||||||
interpreter.
|
|
||||||
|
|
||||||
3.7. Can I use curl to delete/rename a file through FTP?
|
3.7. Can I use curl to delete/rename a file through FTP?
|
||||||
|
|
||||||
@@ -335,25 +361,22 @@ FAQ
|
|||||||
|
|
||||||
curl -L http://redirector.com
|
curl -L http://redirector.com
|
||||||
|
|
||||||
3.9 How do I use curl in my favourite programming language?
|
3.9 How do I use curl in my favorite programming language?
|
||||||
|
|
||||||
There exist many language interfaces/bindings for curl that integrates it
|
There exist many language interfaces/bindings for curl that integrates it
|
||||||
better with various languages. If you are fluid in a script language, you
|
better with various languages. If you are fluid in a script language, you
|
||||||
may very well opt to use such an interface instead of using the command line
|
may very well opt to use such an interface instead of using the command line
|
||||||
tool.
|
tool.
|
||||||
|
|
||||||
At the time of writing, there are bindings for the five language mentioned
|
|
||||||
above, but chances are there are even more by the time you read this. Or you
|
|
||||||
may be able you write your own wrapper for a not-yet supported language!
|
|
||||||
|
|
||||||
Find out more about which languages that support curl directly, and how to
|
Find out more about which languages that support curl directly, and how to
|
||||||
install and use them, in the libcurl section of the curl web site:
|
install and use them, in the libcurl section of the curl web site:
|
||||||
|
|
||||||
http://curl.haxx.se/libcurl/
|
http://curl.haxx.se/libcurl/
|
||||||
|
|
||||||
In December 2001, there are interfaces available for the following
|
In February 2003, there are interfaces available for the following
|
||||||
languages: C/C++, Cocoa, Dylan, Java, Perl, PHP, Python, Rexx, Ruby, Scheme
|
languages: Basic, C, C++, Cocoa, Dylan, Euphoria, Java, Lua, Object-Pascal,
|
||||||
and Tcl. By the time you read this, additional ones may have appeared!
|
Pascal, Perl, PHP, PostgreSQL, Python, Rexx, Ruby, Scheme and Tcl. By the
|
||||||
|
time you read this, additional ones may have appeared!
|
||||||
|
|
||||||
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
|
|
||||||
@@ -362,8 +385,8 @@ FAQ
|
|||||||
XML-RPC are all such ones. You can use -X to set custom requests and -H to
|
XML-RPC are all such ones. You can use -X to set custom requests and -H to
|
||||||
set custom headers (or replace internally generated ones).
|
set custom headers (or replace internally generated ones).
|
||||||
|
|
||||||
Using libcurl or PHP's curl modules is just as fine and you'd just use the
|
Using libcurl is of course just as fine and you'd just use the proper
|
||||||
proper library options to do the same.
|
library options to do the same.
|
||||||
|
|
||||||
3.11 How do I POST with a different Content-Type?
|
3.11 How do I POST with a different Content-Type?
|
||||||
|
|
||||||
@@ -376,7 +399,7 @@ FAQ
|
|||||||
|
|
||||||
Because when you use a HTTP proxy, the protocol spoken on the network will
|
Because when you use a HTTP proxy, the protocol spoken on the network will
|
||||||
be HTTP, even if you specify a FTP URL. This effectively means that you
|
be HTTP, even if you specify a FTP URL. This effectively means that you
|
||||||
normally can't use FTP specific features such as ftp upload and ftp quote
|
normally can't use FTP specific features such as FTP upload and FTP quote
|
||||||
etc.
|
etc.
|
||||||
|
|
||||||
There is one exception to this rule, and that is if you can "tunnel through"
|
There is one exception to this rule, and that is if you can "tunnel through"
|
||||||
@@ -384,6 +407,54 @@ FAQ
|
|||||||
and is generally not available as proxy admins usually disable tunneling to
|
and is generally not available as proxy admins usually disable tunneling to
|
||||||
other ports than 443 (which is used for HTTPS access through proxies).
|
other ports than 443 (which is used for HTTPS access through proxies).
|
||||||
|
|
||||||
|
3.13 Why does my single/double quotes fail?
|
||||||
|
|
||||||
|
To specify a command line option that includes spaces, you might need to
|
||||||
|
put the entire option within quotes. Like in:
|
||||||
|
|
||||||
|
curl -d " with spaces " url.com
|
||||||
|
|
||||||
|
or perhaps
|
||||||
|
|
||||||
|
curl -d ' with spaces ' url.com
|
||||||
|
|
||||||
|
Exactly what kind of quotes and how to do this is entirely up to the shell
|
||||||
|
or command line interpreter that you are using. For most unix shells, you
|
||||||
|
can more or less pick either single (') or double (") quotes. For
|
||||||
|
Windows/DOS prompts I believe you're forced to use double (") quotes.
|
||||||
|
|
||||||
|
Please study the documentation for your particular environment. Examples in
|
||||||
|
the curl docs will use a mix of both these ones as shown above. You must
|
||||||
|
adjust them to work in your environment.
|
||||||
|
|
||||||
|
Remember that curl works and runs on more operating systems than most single
|
||||||
|
individuals have ever tried.
|
||||||
|
|
||||||
|
3.14 Does curl support javascript or pac (automated proxy config)?
|
||||||
|
|
||||||
|
Many web pages do magic stuff using embedded javascript. Curl and libcurl
|
||||||
|
have no built-in support for that, so it will be treated just like any other
|
||||||
|
contents.
|
||||||
|
|
||||||
|
.pac files are a netscape invention and are sometimes used by organizations
|
||||||
|
to allow them to differentiate which proxies to use. The .pac contents is
|
||||||
|
just a javascript program that gets invoked by the browser and that returns
|
||||||
|
the name of the proxy to connect to. Since curl doesn't support javascript,
|
||||||
|
it can't support .pac proxy configuration either.
|
||||||
|
|
||||||
|
Some work-arounds usually suggested to overcome this javascript dependency:
|
||||||
|
|
||||||
|
- Depending on the javascript complexity, write up a script that
|
||||||
|
translates it to another language and execute that.
|
||||||
|
|
||||||
|
- Read the javascript code and rewrite the same logic in another language.
|
||||||
|
|
||||||
|
- Implement a javascript interpreted, people have successfully used the
|
||||||
|
Mozilla javascript engine in the past.
|
||||||
|
|
||||||
|
- Ask your admins to stop this, for a static proxy setup or similar.
|
||||||
|
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
|
|
||||||
4.1. Problems connecting to SSL servers.
|
4.1. Problems connecting to SSL servers.
|
||||||
@@ -412,11 +483,12 @@ FAQ
|
|||||||
|
|
||||||
curl 'http://www.altavista.com/cgi-bin/query?text=yes&q=curl'
|
curl 'http://www.altavista.com/cgi-bin/query?text=yes&q=curl'
|
||||||
|
|
||||||
In win32, the standard DOS shell treats the %-letter specially and you may
|
In Windows, the standard DOS shell treats the %-letter specially and you
|
||||||
need to quote the string properly when % is used in it.
|
need to use TWO %-letters for each single one you want to use in the URL.
|
||||||
|
|
||||||
Also note that if you want the literal %-letter to be part of the data you
|
Also note that if you want the literal %-letter to be part of the data you
|
||||||
pass in a POST using -d/--data you must encode it as '%25'.
|
pass in a POST using -d/--data you must encode it as '%25' (which then also
|
||||||
|
needs the %-letter doubled on Windows machines).
|
||||||
|
|
||||||
4.3. How can I use {, }, [ or ] to specify multiple URLs?
|
4.3. How can I use {, }, [ or ] to specify multiple URLs?
|
||||||
|
|
||||||
@@ -428,8 +500,7 @@ FAQ
|
|||||||
curl '{curl,www}.haxx.se'
|
curl '{curl,www}.haxx.se'
|
||||||
|
|
||||||
To be able to use those letters as actual parts of the URL (without using
|
To be able to use those letters as actual parts of the URL (without using
|
||||||
them for the curl URL "globbing" system), use the -g/--globoff option (curl
|
them for the curl URL "globbing" system), use the -g/--globoff option:
|
||||||
7.6 and later):
|
|
||||||
|
|
||||||
curl -g 'www.site.com/weirdname[].html'
|
curl -g 'www.site.com/weirdname[].html'
|
||||||
|
|
||||||
@@ -475,7 +546,7 @@ FAQ
|
|||||||
|
|
||||||
4.5.6 "301 Moved Permanently"
|
4.5.6 "301 Moved Permanently"
|
||||||
|
|
||||||
If you get this return code and an HTML outpt similar to this:
|
If you get this return code and an HTML output similar to this:
|
||||||
|
|
||||||
<H1>Moved Permanently</H1> The document has moved <A
|
<H1>Moved Permanently</H1> The document has moved <A
|
||||||
HREF="http://same_url_now_with_a_trailing_slash/">here</A>.
|
HREF="http://same_url_now_with_a_trailing_slash/">here</A>.
|
||||||
@@ -517,18 +588,56 @@ FAQ
|
|||||||
particular platform, try contacting the person who built the package/archive
|
particular platform, try contacting the person who built the package/archive
|
||||||
you have.
|
you have.
|
||||||
|
|
||||||
If there is a bug, post a bug report in the Curl Bug Track System over at
|
If there is a bug, read the BUGS document first. Then report it as described
|
||||||
http://sourceforge.net/bugs/?group_id=976
|
in there.
|
||||||
|
|
||||||
Always include as many details you can think of, including curl version,
|
|
||||||
operating system name and version and complete instructions how to repeat
|
|
||||||
the bug.
|
|
||||||
|
|
||||||
4.9. Curl can't authenticate to the server that requires NTLM?
|
4.9. Curl can't authenticate to the server that requires NTLM?
|
||||||
|
|
||||||
NTLM is a Microsoft proprietary protocol. Unfortunately, curl does not
|
This is supported in curl 7.10.6 or later. No earlier curl version knows
|
||||||
currently support that. Proprietary formats are evil. You should not use
|
of this magic.
|
||||||
such ones.
|
|
||||||
|
NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You
|
||||||
|
should not use such ones.
|
||||||
|
|
||||||
|
4.10 My HTTP request using HEAD, PUT or DELETE doesn't work!
|
||||||
|
|
||||||
|
Many web servers allow or demand that the administrator configures the
|
||||||
|
server properly for these requests to work on the web server.
|
||||||
|
|
||||||
|
Some servers seem to support HEAD only on certain kinds of URLs.
|
||||||
|
|
||||||
|
To fully grasp this, try the documentation for the particular server
|
||||||
|
software you're trying to interact with. This is not anything curl can do
|
||||||
|
anything about.
|
||||||
|
|
||||||
|
4.11 Why does my HTTP range requests return the full document?
|
||||||
|
|
||||||
|
Because the range may not be supported by the server, or the server may
|
||||||
|
choose to ignore it and return the full document anyway.
|
||||||
|
|
||||||
|
4.12 Why do I get "certificate verify failed" ?
|
||||||
|
|
||||||
|
You invoke curl 7.10 or later to communicate on a https:// URL and get an
|
||||||
|
error back looking something similar to this:
|
||||||
|
|
||||||
|
curl: (35) SSL: error:14090086:SSL routines:
|
||||||
|
SSL3_GET_SERVER_CERTIFICATE:certificate verify failed
|
||||||
|
|
||||||
|
Then it means that curl couldn't verify that the server's certificate was
|
||||||
|
good. Curl verifies the certificate using the CA cert bundle that comes with
|
||||||
|
the curl installation.
|
||||||
|
|
||||||
|
To disable the verification (which makes it act like curl did before 7.10),
|
||||||
|
use -k. This does however enable man-in-the-middle attacks.
|
||||||
|
|
||||||
|
If you get this failure but are having a CA cert bundle installed and used,
|
||||||
|
the server's certificate is not signed by one of the CA's in the bundle. It
|
||||||
|
might for example be self-signed. You then correct this problem by obtaining
|
||||||
|
a valid CA cert for the server. Or again, decrease the security by disabling
|
||||||
|
this check.
|
||||||
|
|
||||||
|
Details are also in the SSLCERTS file in the release archives, found online
|
||||||
|
here: http://curl.haxx.se/docs/sslcerts.html
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
|
|
||||||
@@ -580,20 +689,15 @@ FAQ
|
|||||||
|
|
||||||
5.3 How do I fetch multiple files with libcurl?
|
5.3 How do I fetch multiple files with libcurl?
|
||||||
|
|
||||||
Starting with version 7.7, curl and libcurl will have excellent support for
|
libcurl has excellent support for transferring multiple files. You should
|
||||||
transferring multiple files. You should just repeatedly set new URLs with
|
just repeatedly set new URLs with curl_easy_setopt() and then transfer it
|
||||||
curl_easy_setopt() and then transfer it with curl_easy_perform(). The handle
|
with curl_easy_perform(). The handle you get from curl_easy_init() is not
|
||||||
you get from curl_easy_init() is not only reusable starting with libcurl
|
only reusable, but you're even encouraged to reuse it if you can, as that
|
||||||
7.7, but also you're encouraged to reuse it if you can, as that will enable
|
will enable libcurl to use persistent connections.
|
||||||
libcurl to use persistent connections.
|
|
||||||
|
|
||||||
For libcurl prior to 7.7, there was no multiple file support. The only
|
|
||||||
available way to do multiple requests was to init/perform/cleanup for each
|
|
||||||
transfer.
|
|
||||||
|
|
||||||
5.4 Does libcurl do Winsock initialization on win32 systems?
|
5.4 Does libcurl do Winsock initialization on win32 systems?
|
||||||
|
|
||||||
Yes (since 7.8.1) if told to in the curl_global_init() call.
|
Yes, if told to in the curl_global_init() call.
|
||||||
|
|
||||||
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
|
|
||||||
@@ -607,22 +711,31 @@ FAQ
|
|||||||
|
|
||||||
5.6 What about Keep-Alive or persistent connections?
|
5.6 What about Keep-Alive or persistent connections?
|
||||||
|
|
||||||
Starting with version 7.7, curl and libcurl will have excellent support for
|
curl and libcurl have excellent support for persistent connections when
|
||||||
persistent connections when transferring several files from the same server.
|
transferring several files from the same server. Curl will attempt to reuse
|
||||||
Curl will attempt to reuse connections for all URLs specified on the same
|
connections for all URLs specified on the same command line/config file, and
|
||||||
command line/config file, and libcurl will reuse connections for all
|
libcurl will reuse connections for all transfers that are made using the
|
||||||
transfers that are made using the same libcurl handle.
|
same libcurl handle.
|
||||||
|
|
||||||
|
5.7 Link errors when building libcurl on Windows!
|
||||||
|
|
||||||
|
You need to make sure that your project, and all the libraries (both static
|
||||||
|
and dynamic) that it links against, are compiled/linked against the same run
|
||||||
|
time library.
|
||||||
|
|
||||||
|
This is determined by the /MD, /ML, /MT (and their corresponding /M?d)
|
||||||
|
options to the command line compiler. /MD (linking against MSVCRT dll) seems
|
||||||
|
to be the most commonly used option.
|
||||||
|
|
||||||
|
(Provided by Andrew Francis)
|
||||||
|
|
||||||
Previous versions had no persistent connection support.
|
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
|
|
||||||
Curl and libcurl are released under a MIT/X derivate license *or* the MPL,
|
Curl and libcurl are released under a MIT/X derivate license. The license is
|
||||||
the Mozilla Public License. To get a really good answer to your license
|
very liberal and should not impose a problem for your project. This section
|
||||||
conflict questions, you should study the MPL and MIT/X licenses and the
|
is just a brief summary for the cases we get the most questions. (Parts of
|
||||||
license you are about to use and check for clashes yourself. This section is
|
this section was much enhanced by Bjorn Reese.)
|
||||||
just a brief summary for the cases we get the most questions. (Parts of this
|
|
||||||
section was much enhanced by Bjorn Reese.)
|
|
||||||
|
|
||||||
6.1. I have a GPL program, can I use the libcurl library?
|
6.1. I have a GPL program, can I use the libcurl library?
|
||||||
|
|
||||||
@@ -665,6 +778,5 @@ FAQ
|
|||||||
discussions and a large amount of people have contributed with source code
|
discussions and a large amount of people have contributed with source code
|
||||||
knowing that this is the license we use. This license puts the restrictions
|
knowing that this is the license we use. This license puts the restrictions
|
||||||
we want on curl/libcurl and it does not spread to other programs or
|
we want on curl/libcurl and it does not spread to other programs or
|
||||||
libraries that use it. The recent dual license modification should make it
|
libraries that use it. It should be possible for everyone to use libcurl or
|
||||||
possible for everyone to use libcurl or curl in their projects, no matter
|
curl in their projects, no matter what license they already have in use.
|
||||||
what license they already have in use.
|
|
||||||
|
@@ -17,27 +17,30 @@ Misc
|
|||||||
- progress bar/time specs while downloading
|
- progress bar/time specs while downloading
|
||||||
- "standard" proxy environment variables support
|
- "standard" proxy environment variables support
|
||||||
- config file support
|
- config file support
|
||||||
- compiles on win32 (reported built on 29 operating systems)
|
- compiles on win32 (reported builds on 40+ operating systems)
|
||||||
- redirectable stderr
|
- redirectable stderr
|
||||||
- use selected network interface for outgoing traffic
|
- selectable network interface for outgoing traffic
|
||||||
- IPv6 support
|
- IPv6 support
|
||||||
- persistant connections
|
- persistant connections
|
||||||
|
- socks5 support
|
||||||
|
- supports user name + password in proxy environment variables
|
||||||
|
- operations through proxy "tunnel" (using CONNECT)
|
||||||
|
|
||||||
HTTP
|
HTTP
|
||||||
- HTTP/1.1 compliant
|
- HTTP/1.1 compliant (optionally uses 1.0)
|
||||||
- GET
|
- GET
|
||||||
- PUT
|
- PUT
|
||||||
- HEAD
|
- HEAD
|
||||||
- POST
|
- POST
|
||||||
- multipart POST
|
- multipart formpost (RFC1867-style)
|
||||||
- authentication
|
- authentication (Basic, Digest, NTLM(*1), GSS-Negotiate(*3))
|
||||||
- resume (both GET and PUT)
|
- resume (both GET and PUT)
|
||||||
- follow redirects
|
- follow redirects
|
||||||
- maximum amount of redirects to follow
|
- maximum amount of redirects to follow
|
||||||
- custom HTTP request
|
- custom HTTP request
|
||||||
- cookie get/send fully parsed
|
- cookie get/send fully parsed
|
||||||
- understands the netscape cookie file format
|
- reads/writes the netscape cookie file format
|
||||||
- custom headers (that can replace/remove internally generated headers)
|
- custom headers (replace/remove internally generated headers)
|
||||||
- custom user-agent string
|
- custom user-agent string
|
||||||
- custom referer string
|
- custom referer string
|
||||||
- range
|
- range
|
||||||
@@ -45,12 +48,16 @@ HTTP
|
|||||||
- time conditions
|
- time conditions
|
||||||
- via http-proxy
|
- via http-proxy
|
||||||
- retrieve file modification date
|
- retrieve file modification date
|
||||||
|
- Content-Encoding support for deflate and gzip
|
||||||
|
- "Transfer-Encoding: chunked" support for "uploads"
|
||||||
|
|
||||||
HTTPS (*1)
|
HTTPS (*1)
|
||||||
- (all the HTTP features)
|
- (all the HTTP features)
|
||||||
- using certificates
|
- using certificates
|
||||||
- verify server certificate
|
- verify server certificate
|
||||||
- via http-proxy
|
- via http-proxy
|
||||||
|
- select desired encryption
|
||||||
|
- force usage of a specific SSL version (SSLv2, SSLv3 or TLSv1)
|
||||||
|
|
||||||
FTP
|
FTP
|
||||||
- download
|
- download
|
||||||
@@ -90,5 +97,6 @@ GOPHER
|
|||||||
FILE
|
FILE
|
||||||
- URL support
|
- URL support
|
||||||
|
|
||||||
*1 = requires OpenSSL
|
*1 = requires OpenSSL
|
||||||
*2 = requires OpenLDAP
|
*2 = requires OpenLDAP
|
||||||
|
*3 = requires a GSSAPI-compliant library, such as Heimdal or similar.
|
||||||
|
116
docs/HISTORY
Normal file
116
docs/HISTORY
Normal file
@@ -0,0 +1,116 @@
|
|||||||
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
How cURL Became Like This
|
||||||
|
|
||||||
|
|
||||||
|
In the second half of 1997, Daniel Stenberg came up with the idea to make
|
||||||
|
currency-exchange calculations available to Internet Relay Chat (IRC)
|
||||||
|
users. All the necessary data are published on the Web; he just needed to
|
||||||
|
automate their retrieval.
|
||||||
|
|
||||||
|
Daniel simply adopted an existing command-line open-source tool, httpget, that
|
||||||
|
Brazilian Rafael Sagula had written. After a few minor adjustments, it did
|
||||||
|
just what he needed.
|
||||||
|
|
||||||
|
Soon, he found currencies on a GOPHER site, so support for that had to go in,
|
||||||
|
and not before long FTP download support was added as well. The name of the
|
||||||
|
project was changed to urlget to better fit what it actually did now, since
|
||||||
|
the http-only days were already passed.
|
||||||
|
|
||||||
|
The project slowly grew bigger. When upload capabilities were added and the
|
||||||
|
name once again was misleading, a second name change was made and on March 20,
|
||||||
|
1998 curl 4 was released. (The version numbering from the previous names were
|
||||||
|
kept.)
|
||||||
|
|
||||||
|
(Unrelated to this project a company called Curl Corporation filed a US
|
||||||
|
trademark on the name "CURL" on May 18 1998. That company had then already
|
||||||
|
registered the curl.com domain back in November of the previous year. All this
|
||||||
|
was much later brought into the lights.)
|
||||||
|
|
||||||
|
SSL support was added, powered by the SSLeay library.
|
||||||
|
|
||||||
|
August 1998, added project curl to freshmeat.net.
|
||||||
|
|
||||||
|
October 1998, with the curl 4.9 release and the introduction of cookie
|
||||||
|
support, curl was no longer released under the GPL license. Now we're at 4000
|
||||||
|
lines of code, we switched over to the MPL license to restrict the effects of
|
||||||
|
"copyleft".
|
||||||
|
|
||||||
|
November 1998, configure script and reported successful compiles on several
|
||||||
|
major operating systems. The never-quite-understood -F option was added and
|
||||||
|
curl could now simulate quite a lot of a browser.
|
||||||
|
|
||||||
|
Curl 5 was released in December 1998 and introduced the first ever curl man
|
||||||
|
page. People started making Linux RPM packages out of it.
|
||||||
|
|
||||||
|
January 1999, DICT support added.
|
||||||
|
|
||||||
|
OpenSSL took over where SSLeay was abandoned.
|
||||||
|
|
||||||
|
May 1999, first Debian package.
|
||||||
|
|
||||||
|
August 1999, LDAP:// and FILE:// support added. The curl web site gets 1300
|
||||||
|
visits weekly.
|
||||||
|
|
||||||
|
Released curl 6.0 in September. 15000 lines of code.
|
||||||
|
|
||||||
|
December 28 1999, added the project on Sourceforge and started using its
|
||||||
|
services for managing the project.
|
||||||
|
|
||||||
|
Spring 2000, major internal overhaul to provide a suitable library interface.
|
||||||
|
The first non-beta release was named 7.1 and arrived in August. This offered
|
||||||
|
the easy interface and turned out to be the beginning of actually getting
|
||||||
|
other software and programs to get based on and powered by libcurl. Almost
|
||||||
|
20000 lines of code.
|
||||||
|
|
||||||
|
August 2000, the curl web site gets 4000 visits weekly.
|
||||||
|
|
||||||
|
The PHP guys adopted libcurl already the same month, when the first ever third
|
||||||
|
party libcurl binding showed up. CURL has been a supported module in PHP since
|
||||||
|
the release of PHP 4.0.2. This would soon get followers. More than 16
|
||||||
|
different bindings exist at the time of this writing.
|
||||||
|
|
||||||
|
September 2000, kerberos4 support was added.
|
||||||
|
|
||||||
|
In November 2000 started the work on a test suite for curl. It was later
|
||||||
|
re-written from scratch again.
|
||||||
|
|
||||||
|
January 2001, Daniel released curl 7.5.2 under a new license again: MIT (or
|
||||||
|
MPL). The MIT license is extremely liberal and can be used combined with GPL
|
||||||
|
in other projects. This would finally put an end to the "complaints" from
|
||||||
|
people involved in GPLed projects that previously were prohibited from using
|
||||||
|
libcurl while it was released under MPL only. (Due to the fact that MPL is
|
||||||
|
deemed "GPL incompatible".)
|
||||||
|
|
||||||
|
curl supports HTTP 1.1 starting with the release of 7.7, March 22 2001. This
|
||||||
|
also introduced libcurl's ability to do persistent connections. 24000 lines of
|
||||||
|
code.
|
||||||
|
|
||||||
|
August 2001. curl is bundled in Mac OS X, 10.1. It was already becoming more
|
||||||
|
and more of a standard utility of Linux distributions and a regular in the BSD
|
||||||
|
ports collections. The curl web site gets 8000 visits weekly. Curl Corporation
|
||||||
|
contacted Daniel to discuss "the name issue". After Daniel's reply, they have
|
||||||
|
never since got in touch again.
|
||||||
|
|
||||||
|
September 2001, libcurl 7.9 introduces cookie jar and curl_formadd(). During
|
||||||
|
the forthcoming 7.9.x releases, we introduced the multi interface slowly and
|
||||||
|
without much whistles.
|
||||||
|
|
||||||
|
June 2002, the curl web site gets 13000 visits weekly. curl and libcurl is
|
||||||
|
35000 lines of code. Reported successful compiles on more than 40 combinations
|
||||||
|
of CPUs and operating systems.
|
||||||
|
|
||||||
|
To estimate number of users of the curl tool or libcurl library is next to
|
||||||
|
impossible. Around 5000 downloaded packages each week from the main site gives
|
||||||
|
a hint, but the packages are mirrored extensively, bundled with numerous OS
|
||||||
|
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.
|
||||||
|
|
||||||
|
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.
|
25
docs/HOWTO-RELEASE
Normal file
25
docs/HOWTO-RELEASE
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
Steps To Perform When Building a Public Release
|
||||||
|
|
||||||
|
* "make distcheck"
|
||||||
|
|
||||||
|
* ./maketgz
|
||||||
|
then upload the 3 curl packages maketgz created
|
||||||
|
|
||||||
|
* update these files:
|
||||||
|
www/_download.html
|
||||||
|
www/_changes.html
|
||||||
|
www/_newslog.html
|
||||||
|
www/Makefile
|
||||||
|
|
||||||
|
* commit the web changes
|
||||||
|
|
||||||
|
* 'cvs commit'
|
||||||
|
|
||||||
|
* 'cvs tag'
|
||||||
|
|
||||||
|
* write the release announcement, including:
|
||||||
|
- changes / bugfixes
|
||||||
|
- other curl-related news
|
||||||
|
- contributors
|
||||||
|
|
||||||
|
* mail release-announcement to curl-announce and curl-users
|
153
docs/INSTALL
153
docs/INSTALL
@@ -28,11 +28,26 @@ UNIX
|
|||||||
|
|
||||||
You probably need to be root when doing the last command.
|
You probably need to be root when doing the last command.
|
||||||
|
|
||||||
|
If you have checked out the sources from the CVS repository, read the
|
||||||
|
CVS-INFO on how to proceed.
|
||||||
|
|
||||||
|
Get a full listing of all available configure options by invoking it like:
|
||||||
|
|
||||||
|
./configure --help
|
||||||
|
|
||||||
If you want to install curl in a different file hierarchy than /usr/local,
|
If you want to install curl in a different file hierarchy than /usr/local,
|
||||||
you need to specify that already when running configure:
|
you need to specify that already when running configure:
|
||||||
|
|
||||||
./configure --prefix=/path/to/curl/tree
|
./configure --prefix=/path/to/curl/tree
|
||||||
|
|
||||||
|
If you happen to have write permission in that directory, you can do 'make
|
||||||
|
install' without being root. An example of this would be to make a local
|
||||||
|
install in your own home directory:
|
||||||
|
|
||||||
|
./configure --prefix=$HOME
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
The configure script always tries to find a working SSL library unless
|
The configure script always tries to find a working SSL library unless
|
||||||
explicitly told not to. If you have OpenSSL installed in the default search
|
explicitly told not to. If you have OpenSSL installed in the default search
|
||||||
path for your compiler/linker, you don't need to do anything special. If
|
path for your compiler/linker, you don't need to do anything special. If
|
||||||
@@ -71,33 +86,6 @@ UNIX
|
|||||||
LIBS=-lRSAglue -lrsaref
|
LIBS=-lRSAglue -lrsaref
|
||||||
(as suggested by Doug Kaufman)
|
(as suggested by Doug Kaufman)
|
||||||
|
|
||||||
KNOWN PROBLEMS (these ones should not happen anymore)
|
|
||||||
|
|
||||||
If you happen to have autoconf installed, but a version older than 2.12
|
|
||||||
you will get into trouble. Then you can still build curl by issuing these
|
|
||||||
commands (note that this requires curl to be built staticly): (from Ralph
|
|
||||||
Beckmann)
|
|
||||||
|
|
||||||
./configure [...]
|
|
||||||
cd lib; make; cd ..
|
|
||||||
cd src; make; cd ..
|
|
||||||
cp src/curl elsewhere/bin/
|
|
||||||
|
|
||||||
As suggested by David West, you can make a faked version of autoconf and
|
|
||||||
autoheader:
|
|
||||||
|
|
||||||
----start of autoconf----
|
|
||||||
#!/bin/bash
|
|
||||||
#fake autoconf for building curl
|
|
||||||
if [ "$1" = "--version" ] then
|
|
||||||
echo "Autoconf version 2.13"
|
|
||||||
fi
|
|
||||||
----end of autoconf----
|
|
||||||
|
|
||||||
Then make autoheader a symbolic link to the same script and make sure
|
|
||||||
they're executable and set to appear in the path *BEFORE* the actual (but
|
|
||||||
obsolete) autoconf and autoheader scripts.
|
|
||||||
|
|
||||||
MORE OPTIONS
|
MORE OPTIONS
|
||||||
|
|
||||||
To force configure to use the standard cc compiler if both cc and gcc are
|
To force configure to use the standard cc compiler if both cc and gcc are
|
||||||
@@ -178,9 +166,9 @@ Win32
|
|||||||
For VC++ 6, there's an included Makefile.vc6 that should be possible
|
For VC++ 6, there's an included Makefile.vc6 that should be possible
|
||||||
to use out-of-the-box.
|
to use out-of-the-box.
|
||||||
|
|
||||||
Microsoft note: add /Zm200 to the compiler options to increase the
|
Microsoft note: add /Zm200 to the compiler options to increase the
|
||||||
compiler's memory allocation limit, as the hugehelp.c won't compile
|
compiler's memory allocation limit, as the hugehelp.c won't compile
|
||||||
due to "too long puts string".
|
due to "too long puts string".
|
||||||
|
|
||||||
|
|
||||||
With SSL:
|
With SSL:
|
||||||
@@ -201,17 +189,41 @@ Win32
|
|||||||
|
|
||||||
Microsoft command line style
|
Microsoft command line style
|
||||||
----------------------------
|
----------------------------
|
||||||
|
|
||||||
Please read the OpenSSL documentation on how to compile and install
|
Please read the OpenSSL documentation on how to compile and install
|
||||||
the OpenSSL library. This generates the libeay32.dll and ssleay32.dll
|
the OpenSSL libraries. The build process of OpenSSL generates the
|
||||||
files.
|
libeay32.dll and ssleay32.dll files in the out32dll subdirectory in
|
||||||
|
the OpenSSL home directory. OpenSSL static libraries (libeay32.lib,
|
||||||
|
ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory.
|
||||||
|
|
||||||
Run the 'vcvars32.bat' file to get the proper environment variables
|
Run the 'vcvars32.bat' file to get a proper environment. The
|
||||||
set. Edit the makefile.vc6 in the lib directory and define
|
vcvars32.bat file is part of the Microsoft development environment and
|
||||||
OPENSSL_PATH. Set the location of the OpenSSL library and run 'nmake
|
you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin'
|
||||||
vc-ssl' in the root directory.
|
provided that you installed Visual C/C++ 6 in the default directory.
|
||||||
|
|
||||||
The vcvars32.bat file is part of the Microsoft development
|
Before running nmake define the OPENSSL_PATH environment variable with
|
||||||
environment.
|
the root/base directory of OpenSSL, for example:
|
||||||
|
|
||||||
|
set OPENSSL_PATH=c:\openssl-0.9.7a
|
||||||
|
|
||||||
|
lib/Makefile.vc6 depends on zlib (http://www.gzip.org/zlib/) as well.
|
||||||
|
Please read the zlib documentation on how to compile zlib. Define the
|
||||||
|
ZLIB_PATH environment variable to the location of zlib.h and zlib.lib,
|
||||||
|
for example:
|
||||||
|
|
||||||
|
set ZLIB_PATH=c:\zlib-1.1.4
|
||||||
|
|
||||||
|
Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root
|
||||||
|
directory. 'nmake vc-ssl' will create a libcurl static and dynamic
|
||||||
|
libraries in the lib subdirectory, as well as a statically linked
|
||||||
|
version of curl.exe in the src subdirectory. This statically linked
|
||||||
|
version is a standalone executable not requiring any DLL at
|
||||||
|
runtime. This make method requires that you have the static OpenSSL
|
||||||
|
libraries available in OpenSSL's out32 subdirectory.
|
||||||
|
'nmake vc-ssl-dll' creates the libcurl dynamic library and
|
||||||
|
links curl.exe against libcurl and OpenSSL dynamically.
|
||||||
|
This executable requires libcurl.dll and the OpenSSL DLLs
|
||||||
|
at runtime.
|
||||||
|
|
||||||
Microsoft / Borland style
|
Microsoft / Borland style
|
||||||
-------------------------
|
-------------------------
|
||||||
@@ -219,6 +231,30 @@ Win32
|
|||||||
project properties to use the SSL include path, link with the SSL libs
|
project properties to use the SSL include path, link with the SSL libs
|
||||||
and define the USE_SSLEAY symbol.
|
and define the USE_SSLEAY symbol.
|
||||||
|
|
||||||
|
Disabling Specific Protocols:
|
||||||
|
|
||||||
|
The configure utility, unfortunately, is not available for the Windows
|
||||||
|
environment, therefore, you cannot use the various disable-protocol
|
||||||
|
options of the configure utility on this platform.
|
||||||
|
|
||||||
|
However, you can use the following defines to disable specific
|
||||||
|
protocols:
|
||||||
|
|
||||||
|
HTTP_ONLY disables all protocols except HTTP
|
||||||
|
CURL_DISABLE_FTP disables FTP
|
||||||
|
CURL_DISABLE_LDAP disables LDAP
|
||||||
|
CURL_DISABLE_TELNET disables TELNET
|
||||||
|
CURL_DISABLE_DICT disables DICT
|
||||||
|
CURL_DISABLE_FILE disables FILE
|
||||||
|
CURL_DISABLE_GOPHER disables GOPHER
|
||||||
|
|
||||||
|
If you want to set any of these defines you have the following
|
||||||
|
possibilities:
|
||||||
|
|
||||||
|
- Modify lib/setup.h
|
||||||
|
- Modify lib/Makefile.vc6
|
||||||
|
- Add defines to Project/Settings/C/C++/General/Preprocessor Definitions
|
||||||
|
in the curllib.dsw/curllib.dsp Visual C++ 6 IDE project.
|
||||||
|
|
||||||
IBM OS/2
|
IBM OS/2
|
||||||
========
|
========
|
||||||
@@ -322,6 +358,20 @@ VMS
|
|||||||
13-jul-2001
|
13-jul-2001
|
||||||
N. Baggus
|
N. Baggus
|
||||||
|
|
||||||
|
QNX
|
||||||
|
===
|
||||||
|
(This section was graciously brought to us by David Bentham)
|
||||||
|
|
||||||
|
As QNX is targetted for resource constrained environments, the QNX headers
|
||||||
|
set conservative limits. This includes the FD_SETSIZE macro, set by default
|
||||||
|
to 32. Socket descriptors returned within the CURL library may exceed this,
|
||||||
|
resulting in memory faults/SIGSEGV crashes when passed into select(..)
|
||||||
|
calls using fd_set macros.
|
||||||
|
|
||||||
|
A good all-round solution to this is to override the default when building
|
||||||
|
libcurl, by overriding CFLAGS during configure, example
|
||||||
|
# configure CFLAGS='-DFD_SETSIZE=64 -g -O2'
|
||||||
|
|
||||||
CROSS COMPILE
|
CROSS COMPILE
|
||||||
=============
|
=============
|
||||||
|
|
||||||
@@ -361,23 +411,37 @@ CROSS COMPILE
|
|||||||
The '--prefix' parameter specifies where cURL will be installed. If
|
The '--prefix' parameter specifies where cURL will be installed. If
|
||||||
'configure' completes successfully, do 'make' and 'make install' as usual.
|
'configure' completes successfully, do 'make' and 'make install' as usual.
|
||||||
|
|
||||||
|
RISC OS
|
||||||
|
=======
|
||||||
|
The library can be cross-compiled using gccsdk as follows:
|
||||||
|
|
||||||
|
CC=riscos-gcc AR=riscos-ar RANLIB='riscos-ar -s' ./configure \
|
||||||
|
--host=arm-riscos-aof --without-random --disable-shared
|
||||||
|
make
|
||||||
|
|
||||||
|
where riscos-gcc and riscos-ar are links to the gccsdk tools.
|
||||||
|
You can then link your program with curl/lib/.libs/libcurl.a
|
||||||
|
|
||||||
PORTS
|
PORTS
|
||||||
=====
|
=====
|
||||||
This is a probably incomplete list of known hardware and operating systems
|
This is a probably incomplete list of known hardware and operating systems
|
||||||
that curl has been compiled for. If you know one system curl compiles and
|
that curl has been compiled for. If you know a system curl compiles and
|
||||||
runs on, that isn't listed, please let us know!
|
runs on, that isn't listed, please let us know!
|
||||||
|
|
||||||
- Alpha DEC OSF 4
|
- Alpha DEC OSF 4
|
||||||
- Alpha Digital UNIX v3.2
|
- Alpha Digital UNIX v3.2
|
||||||
- Alpha FreeBSD 4.1
|
- Alpha FreeBSD 4.1, 4.5
|
||||||
- Alpha Linux 2.2.16
|
- Alpha Linux 2.2, 2.4
|
||||||
|
- Alpha NetBSD 1.5.2
|
||||||
|
- Alpha OpenBSD 3.0
|
||||||
- Alpha OpenVMS V7.1-1H2
|
- Alpha OpenVMS V7.1-1H2
|
||||||
- Alpha Tru64 v5.0 5.1
|
- Alpha Tru64 v5.0 5.1
|
||||||
- HP-PA HP-UX 9.X 10.X 11.X
|
- HP-PA HP-UX 9.X 10.X 11.X
|
||||||
- HP-PA Linux
|
- HP-PA Linux
|
||||||
- MIPS IRIX 6.2, 6.5
|
- MIPS IRIX 6.2, 6.5
|
||||||
- MIPS Linux
|
- MIPS Linux
|
||||||
- Power AIX 4.2, 4.3.1, 4.3.2
|
- Pocket PC/Win CE 3.0
|
||||||
|
- Power AIX 3.2.5, 4.2, 4.3.1, 4.3.2, 5.1
|
||||||
- PowerPC Darwin 1.0
|
- PowerPC Darwin 1.0
|
||||||
- PowerPC Linux
|
- PowerPC Linux
|
||||||
- PowerPC Mac OS 9
|
- PowerPC Mac OS 9
|
||||||
@@ -391,6 +455,7 @@ PORTS
|
|||||||
- StrongARM NetBSD 1.4.1
|
- StrongARM NetBSD 1.4.1
|
||||||
- Ultrix 4.3a
|
- Ultrix 4.3a
|
||||||
- i386 BeOS
|
- i386 BeOS
|
||||||
|
- i386 DOS
|
||||||
- i386 FreeBSD
|
- i386 FreeBSD
|
||||||
- i386 HURD
|
- 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
|
||||||
@@ -400,11 +465,15 @@ PORTS
|
|||||||
- i386 SCO unix
|
- i386 SCO unix
|
||||||
- i386 Solaris 2.7
|
- i386 Solaris 2.7
|
||||||
- i386 Windows 95, 98, ME, NT, 2000
|
- i386 Windows 95, 98, ME, NT, 2000
|
||||||
|
- i386 QNX 6
|
||||||
|
- i486 ncr-sysv4.3.03 (NCR MP-RAS)
|
||||||
- ia64 Linux 2.3.99
|
- ia64 Linux 2.3.99
|
||||||
- m68k AmigaOS 3
|
- m68k AmigaOS 3
|
||||||
- m68k Linux
|
- m68k Linux
|
||||||
- m68k OpenBSD
|
- m68k OpenBSD
|
||||||
|
- m88k dg-dgux5.4R3.00
|
||||||
- s390 Linux
|
- s390 Linux
|
||||||
|
- XScale/PXA250 Linux 2.4
|
||||||
|
|
||||||
OpenSSL
|
OpenSSL
|
||||||
=======
|
=======
|
||||||
|
@@ -54,7 +54,7 @@ Windows vs Unix
|
|||||||
Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All
|
Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All
|
||||||
conditionals that deal with features *should* instead be in the format
|
conditionals that deal with features *should* instead be in the format
|
||||||
'#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts,
|
'#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts,
|
||||||
we maintain two config-win32.h files (one in / and one in src/) that are
|
we maintain two config-win32.h files (one in lib/ and one in src/) that are
|
||||||
supposed to look exactly as a config.h file would have looked like on a
|
supposed to look exactly as a config.h file would have looked like on a
|
||||||
Windows machine!
|
Windows machine!
|
||||||
|
|
||||||
@@ -69,10 +69,10 @@ Library
|
|||||||
rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are
|
rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are
|
||||||
put in the lib/easy.c file.
|
put in the lib/easy.c file.
|
||||||
|
|
||||||
Starting with libcurl 7.8, curl_global_init_() and curl_global_cleanup() were
|
curl_global_init_() and curl_global_cleanup() should be called by the
|
||||||
introduced. They should be called by the application to initialize and clean
|
application to initialize and clean up global stuff in the library. As of
|
||||||
up global stuff in the library. As of today, they just do the global SSL
|
today, it can handle the global SSL initing if SSL is enabled and it can init
|
||||||
initing if SSL is enabled. libcurl itself has no "global" scope.
|
the socket layer on windows machines. libcurl itself has no "global" scope.
|
||||||
|
|
||||||
All printf()-style functions use the supplied clones in lib/mprintf.c. This
|
All printf()-style functions use the supplied clones in lib/mprintf.c. This
|
||||||
makes sure we stay absolutely platform independent.
|
makes sure we stay absolutely platform independent.
|
||||||
|
109
docs/KNOWN_BUGS
Normal file
109
docs/KNOWN_BUGS
Normal file
@@ -0,0 +1,109 @@
|
|||||||
|
These are problems known to exist at the time of this release. Feel free to
|
||||||
|
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!
|
||||||
|
|
||||||
|
* 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:
|
||||||
|
http://curl.haxx.se/mail/lib-2003-06/0146.html
|
||||||
|
|
||||||
|
* Downloading 0 (zero) bytes files over FTP will not create a zero byte file
|
||||||
|
locally, which is because libcurl doesn't call the write callback with zero
|
||||||
|
bytes. Explained here: http://curl.haxx.se/mail/archive-2003-04/0143.html
|
||||||
|
|
||||||
|
* Using CURLOPT_FAILONERROR (-f/--fail) will make authentication to stop
|
||||||
|
working if you use anything but plain Basic auth.
|
||||||
|
|
||||||
|
* LDAP output is garbled. Hardly anyone seems to care about LDAP functionality
|
||||||
|
in curl/libcurl why this report has been closed and set to be solved later.
|
||||||
|
If you feel this is something you want fixed, get in touch and we'll start
|
||||||
|
working.
|
||||||
|
http://sourceforge.net/tracker/index.php?func=detail&aid=735752&group_id=976&atid=100976
|
||||||
|
|
||||||
|
* 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.
|
||||||
|
|
||||||
|
* Running 'make test' on Mac OS X gives 4 errors. This seems to be related
|
||||||
|
to some kind of libtool problem:
|
||||||
|
http://curl.haxx.se/mail/archive-2002-03/0029.html and
|
||||||
|
http://curl.haxx.se/mail/archive-2002-03/0033.html
|
||||||
|
|
||||||
|
* libcurl does not deal nicely with files larger than 2GB
|
||||||
|
|
||||||
|
* GOPHER transfers seem broken
|
||||||
|
|
||||||
|
* configure --disable-http is not fully supported. All other protocols seem
|
||||||
|
to work to disable.
|
||||||
|
|
||||||
|
* The -m parameter does not work when using telnet with curl on Windows.
|
||||||
|
|
||||||
|
* 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
|
||||||
|
fine of course, and the second request will be sent off but when the
|
||||||
|
response is to get read, the previous response-body is what curl will read
|
||||||
|
and havoc is what happens.
|
||||||
|
More details on this is found in this libcurl mailing list thread:
|
||||||
|
http://curl.haxx.se/mail/lib-2002-08/0000.html
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Q: My program blows up when I run lots of curl_easy_perform() calls on a
|
||||||
|
single thread
|
||||||
|
Q: My program dies when a single thread re-enters the win32 select() call
|
||||||
|
via curl_easy_perform()
|
||||||
|
Q: --- add your own flavour here ---
|
||||||
|
|
||||||
|
Single Threaded Re-Entracy
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
There is a glitch / trick to using cURL on Win32 related to re-entrancy.
|
||||||
|
This experience was gained on verion 7.9.4 using Windows NT SP3 in a banking
|
||||||
|
environment (just in case you wanted to know).
|
||||||
|
|
||||||
|
If you have already called curl_easy_perform(), and *somehow* you cause your
|
||||||
|
single thread of execution to make another call to curl_easy_perform() - the
|
||||||
|
windows socket() call used to create a new socket for the second connection
|
||||||
|
can return with 10044 / 10043 error codes.
|
||||||
|
|
||||||
|
The WSA errors we experienced are:
|
||||||
|
WSAEPROTONOSUPPORT
|
||||||
|
(10043)
|
||||||
|
Protocol not supported.
|
||||||
|
The requested protocol has not been configured into the system, or no
|
||||||
|
implementation for it exists. For example, a socket call requests a
|
||||||
|
SOCK_DGRAM socket, but specifies a stream protocol.
|
||||||
|
|
||||||
|
WSAESOCKTNOSUPPORT
|
||||||
|
(10044)
|
||||||
|
Socket type not supported.
|
||||||
|
The support for the specified socket type does not exist in this address
|
||||||
|
family. For example, the optional type SOCK_RAW might be selected in a
|
||||||
|
socket call, and the implementation does not support SOCK_RAW sockets at
|
||||||
|
all.
|
||||||
|
|
||||||
|
We have experienced this by creating a timer that ticks every 20ms, and on
|
||||||
|
the tick making a curl_easy_perform() call. The call usually completed in
|
||||||
|
about 300ms. And we expected (before this test) that the timer would NOT be
|
||||||
|
fired during a call to curl_easy_perform(), howvever, while the first
|
||||||
|
curl_easy_perform() is running a tick *is* fired by the windows API somehow,
|
||||||
|
and we then call curl_easy_perform() again - thus single threaded
|
||||||
|
re-entrancy is achieved.
|
||||||
|
|
||||||
|
Notes:
|
||||||
|
* We made sure that a new CURL structure was being used for each
|
||||||
|
curl_easy_perform() request, and that the curl_global_init() had been called
|
||||||
|
beforehand.
|
||||||
|
* I'm happy to answer any questions about this problem to try to track it
|
||||||
|
down.
|
||||||
|
* Once the socket() call started failing, there is no hope - it never works
|
||||||
|
again.
|
||||||
|
* Slowing the timer down to give each request enough time to complete solves
|
||||||
|
this problem completely.
|
||||||
|
|
||||||
|
If anyone has the source code to the WinNT implementation of socket() and
|
||||||
|
can figure out WHY this can occur, more tracing can be performed.
|
||||||
|
|
||||||
|
John Clayton <John.Clayton at barclayscapital.com>
|
147
docs/MANUAL
147
docs/MANUAL
@@ -11,7 +11,7 @@ SIMPLE USAGE
|
|||||||
|
|
||||||
curl http://www.netscape.com/
|
curl http://www.netscape.com/
|
||||||
|
|
||||||
Get the root README file from funet's ftp-server:
|
Get the README file the user's home directory at funet's ftp-server:
|
||||||
|
|
||||||
curl ftp://ftp.funet.fi/README
|
curl ftp://ftp.funet.fi/README
|
||||||
|
|
||||||
@@ -19,7 +19,7 @@ SIMPLE USAGE
|
|||||||
|
|
||||||
curl http://www.weirdserver.com:8000/
|
curl http://www.weirdserver.com:8000/
|
||||||
|
|
||||||
Get a list of the root directory of an FTP site:
|
Get a list of a directory of an FTP site:
|
||||||
|
|
||||||
curl ftp://cool.haxx.se/
|
curl ftp://cool.haxx.se/
|
||||||
|
|
||||||
@@ -166,13 +166,21 @@ UPLOADING
|
|||||||
|
|
||||||
VERBOSE / DEBUG
|
VERBOSE / DEBUG
|
||||||
|
|
||||||
If curl fails where it isn't supposed to, if the servers don't let you
|
If curl fails where it isn't supposed to, if the servers don't let you in,
|
||||||
in, if you can't understand the responses: use the -v flag to get VERBOSE
|
if you can't understand the responses: use the -v flag to get verbose
|
||||||
fetching. Curl will output lots of info and all data it sends and
|
fetching. Curl will output lots of info and what it sends and receives in
|
||||||
receives in order to let the user see all client-server interaction.
|
order to let the user see all client-server interaction (but it won't show
|
||||||
|
you the actual data).
|
||||||
|
|
||||||
curl -v ftp://ftp.upload.com/
|
curl -v ftp://ftp.upload.com/
|
||||||
|
|
||||||
|
To get even more details and information on what curl does, try using the
|
||||||
|
--trace or --trace-ascii options with a given file name to log to, like
|
||||||
|
this:
|
||||||
|
|
||||||
|
curl --trace trace.txt www.haxx.se
|
||||||
|
|
||||||
|
|
||||||
DETAILED INFORMATION
|
DETAILED INFORMATION
|
||||||
|
|
||||||
Different protocols provide different ways of getting detailed information
|
Different protocols provide different ways of getting detailed information
|
||||||
@@ -235,7 +243,7 @@ POST (HTTP)
|
|||||||
|
|
||||||
To post to this, you enter a curl command line like:
|
To post to this, you enter a curl command line like:
|
||||||
|
|
||||||
curl -d "user=foobar&pass=12345&id=blablabla&dig=submit" (continues)
|
curl -d "user=foobar&pass=12345&id=blablabla&ding=submit" (continues)
|
||||||
http://www.formpost.com/getthis/post.cgi
|
http://www.formpost.com/getthis/post.cgi
|
||||||
|
|
||||||
|
|
||||||
@@ -246,25 +254,25 @@ POST (HTTP)
|
|||||||
-F accepts parameters like -F "name=contents". If you want the contents to
|
-F accepts parameters like -F "name=contents". If you want the contents to
|
||||||
be read from a file, use <@filename> as contents. When specifying a file,
|
be read from a file, use <@filename> as contents. When specifying a file,
|
||||||
you can also specify the file content type by appending ';type=<mime type>'
|
you can also specify the file content type by appending ';type=<mime type>'
|
||||||
to the file name. You can also post the contents of several files in one field.
|
to the file name. You can also post the contents of several files in one
|
||||||
For example, the field name 'coolfiles' is used to send three files, with
|
field. For example, the field name 'coolfiles' is used to send three files,
|
||||||
different content types using the following syntax:
|
with different content types using the following syntax:
|
||||||
|
|
||||||
curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \
|
curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \
|
||||||
http://www.post.com/postit.cgi
|
http://www.post.com/postit.cgi
|
||||||
|
|
||||||
If the content-type is not specified, curl will try to guess from the file
|
If the content-type is not specified, curl will try to guess from the file
|
||||||
extension (it only knows a few), or use the previously specified type
|
extension (it only knows a few), or use the previously specified type (from
|
||||||
(from an earlier file if several files are specified in a list) or else it
|
an earlier file if several files are specified in a list) or else it will
|
||||||
will using the default type 'text/plain'.
|
using the default type 'text/plain'.
|
||||||
|
|
||||||
Emulate a fill-in form with -F. Let's say you fill in three fields in a
|
Emulate a fill-in form with -F. Let's say you fill in three fields in a
|
||||||
form. One field is a file name which to post, one field is your name and one
|
form. One field is a file name which to post, one field is your name and one
|
||||||
field is a file description. We want to post the file we have written named
|
field is a file description. We want to post the file we have written named
|
||||||
"cooltext.txt". To let curl do the posting of this data instead of your
|
"cooltext.txt". To let curl do the posting of this data instead of your
|
||||||
favourite browser, you have to read the HTML source of the form page and find
|
favourite browser, you have to read the HTML source of the form page and
|
||||||
the names of the input fields. In our example, the input field names are
|
find the names of the input fields. In our example, the input field names
|
||||||
'file', 'yourname' and 'filedescription'.
|
are 'file', 'yourname' and 'filedescription'.
|
||||||
|
|
||||||
curl -F "file=@cooltext.txt" -F "yourname=Daniel" \
|
curl -F "file=@cooltext.txt" -F "yourname=Daniel" \
|
||||||
-F "filedescription=Cool text file with cool text inside" \
|
-F "filedescription=Cool text file with cool text inside" \
|
||||||
@@ -350,6 +358,13 @@ COOKIES
|
|||||||
|
|
||||||
curl -b headers www.example.com
|
curl -b headers www.example.com
|
||||||
|
|
||||||
|
While saving headers to a file is a working way to store cookies, it is
|
||||||
|
however error-prone and not the prefered way to do this. Instead, make curl
|
||||||
|
save the incoming cookies using the well-known netscape cookie format like
|
||||||
|
this:
|
||||||
|
|
||||||
|
curl -c cookies.txt www.example.com
|
||||||
|
|
||||||
Note that by specifying -b you enable the "cookie awareness" and with -L
|
Note that by specifying -b you enable the "cookie awareness" and with -L
|
||||||
you can make curl follow a location: (which often is used in combination
|
you can make curl follow a location: (which often is used in combination
|
||||||
with cookies). So that if a site sends cookies and a location, you can
|
with cookies). So that if a site sends cookies and a location, you can
|
||||||
@@ -363,7 +378,11 @@ COOKIES
|
|||||||
the cookies received from www.example.com. curl will send to the server the
|
the cookies received from www.example.com. curl will send to the server the
|
||||||
stored cookies which match the request as it follows the location. The
|
stored cookies which match the request as it follows the location. The
|
||||||
file "empty.txt" may be a non-existant file.
|
file "empty.txt" may be a non-existant file.
|
||||||
|
|
||||||
|
Alas, to both read and write cookies from a netscape cookie file, you can
|
||||||
|
set both -b and -c to use the same file:
|
||||||
|
|
||||||
|
curl -b cookies.txt -c cookies.txt www.example.com
|
||||||
|
|
||||||
PROGRESS METER
|
PROGRESS METER
|
||||||
|
|
||||||
@@ -404,12 +423,34 @@ SPEED LIMIT
|
|||||||
To have curl abort the download if the speed is slower than 3000 bytes per
|
To have curl abort the download if the speed is slower than 3000 bytes per
|
||||||
second for 1 minute, run:
|
second for 1 minute, run:
|
||||||
|
|
||||||
curl -y 3000 -Y 60 www.far-away-site.com
|
curl -Y 3000 -y 60 www.far-away-site.com
|
||||||
|
|
||||||
This can very well be used in combination with the overall time limit, so
|
This can very well be used in combination with the overall time limit, so
|
||||||
that the above operatioin must be completed in whole within 30 minutes:
|
that the above operatioin must be completed in whole within 30 minutes:
|
||||||
|
|
||||||
curl -m 1800 -y 3000 -Y 60 www.far-away-site.com
|
curl -m 1800 -Y 3000 -y 60 www.far-away-site.com
|
||||||
|
|
||||||
|
Forcing curl not to transfer data faster than a given rate is also possible,
|
||||||
|
which might be useful if you're using a limited bandwidth connection and you
|
||||||
|
don't want your transfer to use all of it (sometimes referred to as
|
||||||
|
"bandwith throttle").
|
||||||
|
|
||||||
|
Make curl transfer data no faster than 10 kilobytes per second:
|
||||||
|
|
||||||
|
curl --limit-rate 10K www.far-away-site.com
|
||||||
|
|
||||||
|
or
|
||||||
|
|
||||||
|
curl --limit-rate 10240 www.far-away-site.com
|
||||||
|
|
||||||
|
Or prevent curl from uploading data faster than 1 megabyte per second:
|
||||||
|
|
||||||
|
curl -T upload --limit-rate 1M ftp://uploadshereplease.com
|
||||||
|
|
||||||
|
When using the --limit-rate option, the transfer rate is regulated on a
|
||||||
|
per-second basis, which will cause the total transfer speed to become lower
|
||||||
|
than the given number. Sometimes of course substantially lower, if your
|
||||||
|
transfer stalls during periods.
|
||||||
|
|
||||||
CONFIG FILE
|
CONFIG FILE
|
||||||
|
|
||||||
@@ -548,7 +589,7 @@ HTTPS
|
|||||||
from sites that require valid certificates. The only drawback is that the
|
from sites that require valid certificates. The only drawback is that the
|
||||||
certificate needs to be in PEM-format. PEM is a standard and open format to
|
certificate needs to be in PEM-format. PEM is a standard and open format to
|
||||||
store certificates with, but it is not used by the most commonly used
|
store certificates with, but it is not used by the most commonly used
|
||||||
browsers (Netscape and MSEI both use the so called PKCS#12 format). If you
|
browsers (Netscape and MSIE both use the so called PKCS#12 format). If you
|
||||||
want curl to use the certificates you use with your (favourite) browser, you
|
want curl to use the certificates you use with your (favourite) browser, you
|
||||||
may need to download/compile a converter that can convert your browser's
|
may need to download/compile a converter that can convert your browser's
|
||||||
formatted certificates to PEM formatted ones. This kind of converter is
|
formatted certificates to PEM formatted ones. This kind of converter is
|
||||||
@@ -567,8 +608,8 @@ HTTPS
|
|||||||
|
|
||||||
Many older SSL-servers have problems with SSLv3 or TLS, that newer versions
|
Many older SSL-servers have problems with SSLv3 or TLS, that newer versions
|
||||||
of OpenSSL etc is using, therefore it is sometimes useful to specify what
|
of OpenSSL etc is using, therefore it is sometimes useful to specify what
|
||||||
SSL-version curl should use. Use -3 or -2 to specify that exact SSL version
|
SSL-version curl should use. Use -3, -2 or -1 to specify that exact SSL
|
||||||
to use:
|
version to use (for SSLv3, SSLv2 or TLSv1 respectively):
|
||||||
|
|
||||||
curl -2 https://secure.site.com/
|
curl -2 https://secure.site.com/
|
||||||
|
|
||||||
@@ -601,15 +642,15 @@ RESUMING FILE TRANSFERS
|
|||||||
|
|
||||||
Continue downloading a document:
|
Continue downloading a document:
|
||||||
|
|
||||||
curl -c -o file ftp://ftp.server.com/path/file
|
curl -C - -o file ftp://ftp.server.com/path/file
|
||||||
|
|
||||||
Continue uploading a document(*1):
|
Continue uploading a document(*1):
|
||||||
|
|
||||||
curl -c -T file ftp://ftp.server.com/path/file
|
curl -C - -T file ftp://ftp.server.com/path/file
|
||||||
|
|
||||||
Continue downloading a document from a web server(*2):
|
Continue downloading a document from a web server(*2):
|
||||||
|
|
||||||
curl -c -o file http://www.server.com/
|
curl -C - -o file http://www.server.com/
|
||||||
|
|
||||||
(*1) = This requires that the ftp server supports the non-standard command
|
(*1) = This requires that the ftp server supports the non-standard command
|
||||||
SIZE. If it doesn't, curl will say so.
|
SIZE. If it doesn't, curl will say so.
|
||||||
@@ -668,8 +709,14 @@ LDAP
|
|||||||
and offer ldap:// support.
|
and offer ldap:// support.
|
||||||
|
|
||||||
LDAP is a complex thing and writing an LDAP query is not an easy task. I do
|
LDAP is a complex thing and writing an LDAP query is not an easy task. I do
|
||||||
advice you to dig up the syntax description for that elsewhere, RFC 1959 if
|
advice you to dig up the syntax description for that elsewhere. Two places
|
||||||
no other place is better.
|
that might suit you are:
|
||||||
|
|
||||||
|
Netscape's "Netscape Directory SDK 3.0 for C Programmer's Guide Chapter 10:
|
||||||
|
Working with LDAP URLs":
|
||||||
|
http://developer.netscape.com/docs/manuals/dirsdk/csdk30/url.htm
|
||||||
|
|
||||||
|
RFC 2255, "The LDAP URL Format" http://www.rfc-editor.org/rfc/rfc2255.txt
|
||||||
|
|
||||||
To show you an example, this is now I can get all people from my local LDAP
|
To show you an example, this is now I can get all people from my local LDAP
|
||||||
server that has a certain sub-domain in their email address:
|
server that has a certain sub-domain in their email address:
|
||||||
@@ -683,7 +730,7 @@ ENVIRONMENT VARIABLES
|
|||||||
|
|
||||||
Curl reads and understands the following environment variables:
|
Curl reads and understands the following environment variables:
|
||||||
|
|
||||||
HTTP_PROXY, HTTPS_PROXY, FTP_PROXY, GOPHER_PROXY
|
http_proxy, HTTPS_PROXY, FTP_PROXY, GOPHER_PROXY
|
||||||
|
|
||||||
They should be set for protocol-specific proxies. General proxy should be
|
They should be set for protocol-specific proxies. General proxy should be
|
||||||
set with
|
set with
|
||||||
@@ -710,9 +757,9 @@ NETRC
|
|||||||
passwords, so therefor most unix programs won't read this file unless it is
|
passwords, so therefor most unix programs won't read this file unless it is
|
||||||
only readable by yourself (curl doesn't care though).
|
only readable by yourself (curl doesn't care though).
|
||||||
|
|
||||||
Curl supports .netrc files if told so (using the -n/--netrc option). This is
|
Curl supports .netrc files if told so (using the -n/--netrc and
|
||||||
not restricted to only ftp, but curl can use it for all protocols where
|
--netrc-optional options). This is not restricted to only ftp,
|
||||||
authentication is used.
|
but curl can use it for all protocols where authentication is used.
|
||||||
|
|
||||||
A very simple .netrc file could look something like:
|
A very simple .netrc file could look something like:
|
||||||
|
|
||||||
@@ -794,19 +841,39 @@ PERSISTANT CONNECTIONS
|
|||||||
MAILING LISTS
|
MAILING LISTS
|
||||||
|
|
||||||
For your convenience, we have several open mailing lists to discuss curl,
|
For your convenience, we have several open mailing lists to discuss curl,
|
||||||
its development and things relevant to this.
|
its development and things relevant to this. Get all info at
|
||||||
|
http://curl.haxx.se/mail/. The lists available are:
|
||||||
|
|
||||||
To subscribe to the main curl list, mail curl-request@contactor.se with
|
curl-users
|
||||||
"subscribe <fill in your email address>" in the body.
|
|
||||||
|
|
||||||
To subscribe to the curl-library users/deverlopers list, follow the
|
Users of the command line tool. How to use it, what doesn't work, new
|
||||||
instructions at http://curl.haxx.se/mail/
|
features, related tools, questions, news, installations, compilations,
|
||||||
|
running, porting etc.
|
||||||
|
|
||||||
To subscribe to the curl-announce list, to only get information about new
|
curl-library
|
||||||
releases, follow the instructions at http://curl.haxx.se/mail/
|
|
||||||
|
|
||||||
To subscribe to the curl-and-PHP list in which curl using with PHP is
|
Developers using or developing libcurl. Bugs, extensions, improvements.
|
||||||
discussed, follow the instructions at http://curl.haxx.se/mail/
|
|
||||||
|
curl-announce
|
||||||
|
|
||||||
|
Low-traffic. Only announcements of new public versions.
|
||||||
|
|
||||||
|
curl-and-PHP
|
||||||
|
|
||||||
|
Using the curl functions in PHP. Everything curl with a PHP angle. Or PHP
|
||||||
|
with a curl angle.
|
||||||
|
|
||||||
|
curl-commits
|
||||||
|
|
||||||
|
Receives notifications on all CVS commits done to the curl source module.
|
||||||
|
This can become quite a large amount of mails during intense development,
|
||||||
|
be aware. This is for us who like email...
|
||||||
|
|
||||||
|
curl-www-commits
|
||||||
|
|
||||||
|
Receives notifications on all CVS commits done to the curl www module
|
||||||
|
(basicly the web site). This can become quite a large amount of mails
|
||||||
|
during intense changing, be aware. This is for us who like email...
|
||||||
|
|
||||||
Please direct curl questions, feature requests and trouble reports to one of
|
Please direct curl questions, feature requests and trouble reports to one of
|
||||||
these mailing lists instead of mailing any individual.
|
these mailing lists instead of mailing any individual.
|
||||||
|
@@ -6,72 +6,43 @@ AUTOMAKE_OPTIONS = foreign no-dependencies
|
|||||||
|
|
||||||
man_MANS = \
|
man_MANS = \
|
||||||
curl.1 \
|
curl.1 \
|
||||||
curl-config.1 \
|
curl-config.1
|
||||||
curl_easy_cleanup.3 \
|
|
||||||
curl_easy_getinfo.3 \
|
|
||||||
curl_easy_init.3 \
|
|
||||||
curl_easy_perform.3 \
|
|
||||||
curl_easy_setopt.3 \
|
|
||||||
curl_easy_duphandle.3 \
|
|
||||||
curl_formparse.3 \
|
|
||||||
curl_formadd.3 \
|
|
||||||
curl_formfree.3 \
|
|
||||||
curl_getdate.3 \
|
|
||||||
curl_getenv.3 \
|
|
||||||
curl_slist_append.3 \
|
|
||||||
curl_slist_free_all.3 \
|
|
||||||
curl_version.3 \
|
|
||||||
curl_escape.3 \
|
|
||||||
curl_unescape.3 \
|
|
||||||
curl_strequal.3 \
|
|
||||||
curl_strnequal.3 \
|
|
||||||
curl_mprintf.3 \
|
|
||||||
curl_global_init.3 \
|
|
||||||
curl_global_cleanup.3 \
|
|
||||||
libcurl.3
|
|
||||||
|
|
||||||
SUBDIRS = examples
|
|
||||||
|
|
||||||
HTMLPAGES = \
|
HTMLPAGES = \
|
||||||
curl.html \
|
curl.html \
|
||||||
curl-config.html \
|
curl-config.html \
|
||||||
curl_easy_cleanup.html \
|
|
||||||
curl_easy_getinfo.html \
|
|
||||||
curl_easy_init.html \
|
|
||||||
curl_easy_perform.html \
|
|
||||||
curl_easy_setopt.html \
|
|
||||||
curl_easy_duphandle.html \
|
|
||||||
curl_formadd.html \
|
|
||||||
curl_formparse.html \
|
|
||||||
curl_formfree.html \
|
|
||||||
curl_getdate.html \
|
|
||||||
curl_getenv.html \
|
|
||||||
curl_slist_append.html \
|
|
||||||
curl_slist_free_all.html \
|
|
||||||
curl_version.html \
|
|
||||||
curl_escape.html \
|
|
||||||
curl_unescape.html \
|
|
||||||
curl_strequal.html \
|
|
||||||
curl_strnequal.html \
|
|
||||||
curl_mprintf.html \
|
|
||||||
curl_global_init.html \
|
|
||||||
curl_global_cleanup.html \
|
|
||||||
libcurl.html \
|
|
||||||
index.html
|
index.html
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS) \
|
PDFPAGES = \
|
||||||
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
curl.pdf \
|
||||||
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS \
|
curl-config.pdf
|
||||||
VERSIONS $(HTMLPAGES)
|
|
||||||
|
SUBDIRS = examples libcurl
|
||||||
|
|
||||||
|
EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS \
|
||||||
|
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS \
|
||||||
|
VERSIONS KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) \
|
||||||
|
HISTORY INSTALL libcurl-the-guide $(PDFPAGES)
|
||||||
|
|
||||||
MAN2HTML= gnroff -man $< | man2html >$@
|
MAN2HTML= gnroff -man $< | man2html >$@
|
||||||
|
|
||||||
SUFFIXES = .1 .3 .html
|
SUFFIXES = .1 .3 .html .pdf
|
||||||
|
|
||||||
html: $(HTMLPAGES)
|
html: $(HTMLPAGES)
|
||||||
|
cd libcurl; make html
|
||||||
|
|
||||||
.3.html:
|
.3.html:
|
||||||
$(MAN2HTML)
|
$(MAN2HTML)
|
||||||
|
|
||||||
.1.html:
|
.1.html:
|
||||||
$(MAN2HTML)
|
$(MAN2HTML)
|
||||||
|
|
||||||
|
MAN2PDF = groff -Tps -man curl.1 $< >$@
|
||||||
|
|
||||||
|
pdf:
|
||||||
|
for file in $(man_MANS); do \
|
||||||
|
foo=`echo $$file | sed -e 's/\.[0-9]$$//g'`; \
|
||||||
|
groff -Tps -man $$file >$$foo.ps; \
|
||||||
|
ps2pdf $$foo.ps $$foo.pdf; \
|
||||||
|
done
|
||||||
|
cd libcurl; make pdf
|
||||||
|
@@ -13,8 +13,8 @@ README.win32
|
|||||||
are win32-based.
|
are win32-based.
|
||||||
|
|
||||||
The unix-style man pages are tricky to read on windows, so therefore are all
|
The unix-style man pages are tricky to read on windows, so therefore are all
|
||||||
those pages also converted to HTML and those are also included in the
|
those pages converted to HTML as well as pdf, and included in the release
|
||||||
release archives.
|
archives.
|
||||||
|
|
||||||
The main curl.1 man page is also "built-in" in the command line tool. Use a
|
The main curl.1 man page is also "built-in" in the command line tool. Use a
|
||||||
command line similar to this in order to extract a separate text file:
|
command line similar to this in order to extract a separate text file:
|
||||||
|
@@ -5,10 +5,9 @@
|
|||||||
\___|\___/|_| \_\_____|
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
|
||||||
This document has been introduced in order to let you find documents that
|
This document lists documents that specify standards used by curl, software
|
||||||
specify standards used by curl, software that extends curl, web pages with
|
that extends curl, web pages with similar utilities and information pages that
|
||||||
"competing" utilities and information pages that describe some of the tools
|
describe some of the tools that we use to build/compile/develop curl.
|
||||||
that we use to build/compile/develop curl.
|
|
||||||
|
|
||||||
Standards
|
Standards
|
||||||
---------
|
---------
|
||||||
|
39
docs/SSLCERTS
Normal file
39
docs/SSLCERTS
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
Peer SSL Certificate Verification
|
||||||
|
=================================
|
||||||
|
|
||||||
|
Starting in 7.10, libcurl performs peer SSL certificate verification by
|
||||||
|
default. This is done by installing a default CA cert bundle on 'make install'
|
||||||
|
(or similar), that CA bundle package is used by default on operations against
|
||||||
|
SSL servers.
|
||||||
|
|
||||||
|
Alas, if you communicate with HTTPS servers using certificates that are signed
|
||||||
|
by CAs present in the bundle, you will not notice any changed behavior and you
|
||||||
|
will seamlessly get a higher security level on your SSL connections since you
|
||||||
|
can be sure that the remote server really is the one it claims to be.
|
||||||
|
|
||||||
|
If the remote server uses a self-signed certificate, or if you don't install
|
||||||
|
curl's CA cert bundle or if it uses a certificate signed by a CA that isn't
|
||||||
|
included in the bundle, then you need to do one of the following:
|
||||||
|
|
||||||
|
1. Tell libcurl to *not* verify the peer. With libcurl you disable with with
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, FALSE);
|
||||||
|
|
||||||
|
With the curl command tool, you disable this with -k/--insecure.
|
||||||
|
|
||||||
|
2. Get a CA certificate that can verify the remote server and use the proper
|
||||||
|
option to point out this CA cert for verification when connecting. For
|
||||||
|
libcurl hackers: curl_easy_setopt(curl, CURLOPT_CAPATH, capath);
|
||||||
|
|
||||||
|
With the curl command tool: --cacert [file]
|
||||||
|
|
||||||
|
Neglecting to use one of the above menthods when dealing with a server using a
|
||||||
|
certficate that isn't signed by one of the certficates in the installed CA
|
||||||
|
cert bundle, will cause SSL to report an error ("certificate verify failed")
|
||||||
|
during the handshake and SSL will then refuse further communication with that
|
||||||
|
server.
|
||||||
|
|
||||||
|
This procedure has been deemed The Right Thing even though it adds this extra
|
||||||
|
trouble for some users, since it adds security to a majority of the SSL
|
||||||
|
connections that previously weren't really secure. It turned out many people
|
||||||
|
were using previous versions of curl/libcurl without realizing the need for
|
||||||
|
the CA cert options to get truly secure SSL connections.
|
167
docs/THANKS
167
docs/THANKS
@@ -2,80 +2,93 @@ This project has been alive for several years. Countless people have provided
|
|||||||
feedback that have improved curl. Here follows a (incomplete) list of people
|
feedback that have improved curl. Here follows a (incomplete) list of people
|
||||||
that have contributed with non-trivial parts:
|
that have contributed with non-trivial parts:
|
||||||
|
|
||||||
- Daniel Stenberg <daniel@haxx.se>
|
Daniel Stenberg <daniel@haxx.se>
|
||||||
- Rafael Sagula <sagula@inf.ufrgs.br>
|
Rafael Sagula <sagula@inf.ufrgs.br>
|
||||||
- Sampo Kellomaki <sampo@iki.fi>
|
Sampo Kellomaki <sampo@iki.fi>
|
||||||
- Linas Vepstas <linas@linas.org>
|
Linas Vepstas <linas@linas.org>
|
||||||
- Bjorn Reese <breese@mail1.stofanet.dk>
|
Bjorn Reese <breese@mail1.stofanet.dk>
|
||||||
- Johan Anderson <johan@homemail.com>
|
Johan Anderson <johan@homemail.com>
|
||||||
- Kjell Ericson <Kjell.Ericson@haxx.se>
|
Kjell Ericson <Kjell.Ericson@haxx.se>
|
||||||
- Troy Engel <tengel@sonic.net>
|
Troy Engel <tengel@sonic.net>
|
||||||
- Ryan Nelson <ryan@inch.com>
|
Ryan Nelson <ryan@inch.com>
|
||||||
- Bj<EFBFBD>rn Stenberg <bjorn@haxx.se>
|
Bj<EFBFBD>rn Stenberg <bjorn@haxx.se>
|
||||||
- Angus Mackay <amackay@gus.ml.org>
|
Angus Mackay <amackay@gus.ml.org>
|
||||||
- Eric Young <eay@cryptsoft.com>
|
Eric Young <eay@cryptsoft.com>
|
||||||
- Simon Dick <simond@totally.irrelevant.org>
|
Simon Dick <simond@totally.irrelevant.org>
|
||||||
- Oren Tirosh <oren@monty.hishome.net>
|
Oren Tirosh <oren@monty.hishome.net>
|
||||||
- Steven G. Johnson <stevenj@alum.mit.edu>
|
Steven G. Johnson <stevenj@alum.mit.edu>
|
||||||
- Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu>
|
Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu>
|
||||||
- Andr<EFBFBD>s Garc<72>a <ornalux@redestb.es>
|
Andr<EFBFBD>s Garc<72>a <ornalux@redestb.es>
|
||||||
- Douglas E. Wegscheid <wegscd@whirlpool.com>
|
Douglas E. Wegscheid <wegscd@whirlpool.com>
|
||||||
- Mark Butler <butlerm@xmission.com>
|
Mark Butler <butlerm@xmission.com>
|
||||||
- Eric Thelin <eric@generation-i.com>
|
Eric Thelin <eric@generation-i.com>
|
||||||
- Marc Boucher <marc@mbsi.ca>
|
Marc Boucher <marc@mbsi.ca>
|
||||||
- Greg Onufer <Greg.Onufer@Eng.Sun.COM>
|
Greg Onufer <Greg.Onufer@Eng.Sun.COM>
|
||||||
- Doug Kaufman <dkaufman@rahul.net>
|
Doug Kaufman <dkaufman@rahul.net>
|
||||||
- David Eriksson <david@2good.com>
|
David Eriksson <david@2good.com>
|
||||||
- Ralph Beckmann <rabe@uni-paderborn.de>
|
Ralph Beckmann <rabe@uni-paderborn.de>
|
||||||
- T. Yamada <tai@imasy.or.jp>
|
T. Yamada <tai@imasy.or.jp>
|
||||||
- Lars J. Aas <larsa@sim.no>
|
Lars J. Aas <larsa@sim.no>
|
||||||
- J<EFBFBD>rn Hartroth <Joern.Hartroth@computer.org>
|
J<EFBFBD>rn Hartroth <Joern.Hartroth@computer.org>
|
||||||
- Matthew Clarke <clamat@van.maves.ca>
|
Matthew Clarke <clamat@van.maves.ca>
|
||||||
- Linus Nielsen Feltzing <linus@haxx.se>
|
Linus Nielsen Feltzing <linus@haxx.se>
|
||||||
- Felix von Leitner <felix@convergence.de>
|
Felix von Leitner <felix@convergence.de>
|
||||||
- Dan Zitter <dzitter@zitter.net>
|
Dan Zitter <dzitter@zitter.net>
|
||||||
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
||||||
- Chris Maltby <chris@aurema.com>
|
Chris Maltby <chris@aurema.com>
|
||||||
- Ron Zapp <rzapper@yahoo.com>
|
Ron Zapp <rzapper@yahoo.com>
|
||||||
- Paul Marquis <pmarquis@iname.com>
|
Paul Marquis <pmarquis@iname.com>
|
||||||
- Ellis Pritchard <ellis@citria.com>
|
Ellis Pritchard <ellis@citria.com>
|
||||||
- Damien Adant <dams@usa.net>
|
Damien Adant <dams@usa.net>
|
||||||
- Chris <cbayliss@csc.come>
|
Chris <cbayliss@csc.come>
|
||||||
- Marco G. Salvagno <mgs@whiz.cjb.net>
|
Marco G. Salvagno <mgs@whiz.cjb.net>
|
||||||
- Paul Marquis <pmarquis@iname.com>
|
Paul Marquis <pmarquis@iname.com>
|
||||||
- David LeBlanc <dleblanc@qnx.com>
|
David LeBlanc <dleblanc@qnx.com>
|
||||||
- Rich Gray at Plus Technologies
|
Rich Gray at Plus Technologies
|
||||||
- Luong Dinh Dung <u8luong@lhsystems.hu>
|
Luong Dinh Dung <u8luong@lhsystems.hu>
|
||||||
- Torsten Foertsch <torsten.foertsch@gmx.net>
|
Torsten Foertsch <torsten.foertsch@gmx.net>
|
||||||
- Kristian K<>hntopp <kris@koehntopp.de>
|
Kristian K<>hntopp <kris@koehntopp.de>
|
||||||
- Fred Noz <FNoz@siac.com>
|
Fred Noz <FNoz@siac.com>
|
||||||
- Caolan McNamara <caolan@csn.ul.ie>
|
Caolan McNamara <caolan@csn.ul.ie>
|
||||||
- Albert Chin-A-Young <china@thewrittenword.com>
|
Albert Chin-A-Young <china@thewrittenword.com>
|
||||||
- Stephen Kick <skick@epicrealm.com>
|
Stephen Kick <skick@epicrealm.com>
|
||||||
- Martin Hedenfalk <mhe@stacken.kth.se>
|
Martin Hedenfalk <mhe@stacken.kth.se>
|
||||||
- Richard Prescott <rip at step.polymtl.ca>
|
Richard Prescott <rip at step.polymtl.ca>
|
||||||
- Jason S. Priebe <priebe@wral-tv.com>
|
Jason S. Priebe <priebe@wral-tv.com>
|
||||||
- T. Bharath <TBharath@responsenetworks.com>
|
T. Bharath <TBharath@responsenetworks.com>
|
||||||
- Alexander Kourakos <awk@users.sourceforge.net>
|
Alexander Kourakos <awk@users.sourceforge.net>
|
||||||
- James Griffiths <griffiths_james@yahoo.com>
|
James Griffiths <griffiths_james@yahoo.com>
|
||||||
- Loic Dachary <loic@senga.org>
|
Loic Dachary <loic@senga.org>
|
||||||
- Robert Weaver <robert.weaver@sabre.com>
|
Robert Weaver <robert.weaver@sabre.com>
|
||||||
- Ingo Ralf Blum <ingoralfblum@ingoralfblum.com>
|
Ingo Ralf Blum <ingoralfblum@ingoralfblum.com>
|
||||||
- Jun-ichiro itojun Hagino <itojun@iijlab.net>
|
Jun-ichiro itojun Hagino <itojun@iijlab.net>
|
||||||
- Frederic Lepied <flepied@mandrakesoft.com>
|
Frederic Lepied <flepied@mandrakesoft.com>
|
||||||
- Georg Horn <horn@koblenz-net.de>
|
Georg Horn <horn@koblenz-net.de>
|
||||||
- Cris Bailiff <c.bailiff@awayweb.com>
|
Cris Bailiff <c.bailiff@awayweb.com>
|
||||||
- Sterling Hughes <sterling@designmultimedia.com>
|
Sterling Hughes <sterling@designmultimedia.com>
|
||||||
- S. Moonesamy
|
S. Moonesamy
|
||||||
- Ingo Wilken <iw@WWW.Ecce-Terram.DE>
|
Ingo Wilken <iw@WWW.Ecce-Terram.DE>
|
||||||
- Pawel A. Gajda <mis@k2.net.pl>
|
Pawel A. Gajda <mis@k2.net.pl>
|
||||||
- Patrick Bihan-Faou
|
Patrick Bihan-Faou
|
||||||
- Nico Baggus <Nico.Baggus@mail.ing.nl>
|
Nico Baggus <Nico.Baggus@mail.ing.nl>
|
||||||
- Sergio Ballestrero
|
Sergio Ballestrero
|
||||||
- Andrew Francis <locust@familyhealth.com.au>
|
Andrew Francis <locust@familyhealth.com.au>
|
||||||
- Tomasz Lacki <Tomasz.Lacki@primark.pl>
|
Tomasz Lacki <Tomasz.Lacki@primark.pl>
|
||||||
- Georg Huettenegger <georg@ist.org>
|
Georg Huettenegger <georg@ist.org>
|
||||||
- John Lask <johnlask@hotmail.com>
|
John Lask <johnlask@hotmail.com>
|
||||||
- Eric Lavigne <erlavigne@wanadoo.fr>
|
Eric Lavigne <erlavigne@wanadoo.fr>
|
||||||
- Marcus Webster <marcus.webster@phocis.com>
|
Marcus Webster <marcus.webster@phocis.com>
|
||||||
- G<EFBFBD>tz Babin-Ebell <babin<69>ebell@trustcenter.de>
|
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>
|
||||||
|
189
docs/TODO
189
docs/TODO
@@ -6,127 +6,169 @@
|
|||||||
|
|
||||||
TODO
|
TODO
|
||||||
|
|
||||||
Things to do in project cURL. Please tell me what you think, contribute and
|
Things to do in project cURL. Please tell us what you think, contribute and
|
||||||
send me patches that improve things! Also check the http://curl.haxx.se/dev
|
send us patches that improve things! Also check the http://curl.haxx.se/dev
|
||||||
web section for various development notes.
|
web section for various technical development notes.
|
||||||
|
|
||||||
|
All bugs documented in the KNOWN_BUGS document are subject for fixing!
|
||||||
|
|
||||||
LIBCURL
|
LIBCURL
|
||||||
|
|
||||||
* Consider an interface to libcurl that allows applications to easier get to
|
* Introduce an interface to libcurl that allows applications to easier get to
|
||||||
know what cookies that are sent back in the response headers.
|
know what cookies that are received. Pushing interface that calls a
|
||||||
|
callback on each received cookie? Querying interface that asks about
|
||||||
* Make content encoding/decoding internally be made using a filter system.
|
existing cookies? We probably need both. Enable applications to modify
|
||||||
|
existing cookies as well. http://curl.haxx.se/dev/COOKIES
|
||||||
* The new 'multi' interface is being designed. Work out the details, start
|
|
||||||
implementing and write test applications!
|
|
||||||
[http://curl.haxx.se/dev/multi.h]
|
|
||||||
|
|
||||||
* Add a name resolve cache to libcurl to make repeated fetches to the same
|
|
||||||
host name (when persitancy isn't available) faster.
|
|
||||||
|
|
||||||
* Introduce another callback interface for upload/download that makes one
|
* Introduce another callback interface for upload/download that makes one
|
||||||
less copy of data and thus a faster operation.
|
less copy of data and thus a faster operation.
|
||||||
[http://curl.haxx.se/dev/no_copy_callbacks.txt]
|
[http://curl.haxx.se/dev/no_copy_callbacks.txt]
|
||||||
|
|
||||||
* Add configure options that disables certain protocols in libcurl to
|
* More data sharing. curl_share_* functions already exist and work, and they
|
||||||
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
can be extended to share more.
|
||||||
telnet, ldap, dict or file.
|
|
||||||
|
|
||||||
* Add asynchronous name resolving. http://curl.haxx.se/dev/async-resolver.txt
|
* Set the SO_KEEPALIVE socket option to make libcurl notice and disconnect
|
||||||
|
very long time idle connections.
|
||||||
|
|
||||||
* Strip any trailing CR from the error message when Curl_failf() is used.
|
* Go through the code and verify that libcurl deals with big files >2GB and
|
||||||
|
>4GB all over. Bug reports (and source reviews) show that it doesn't
|
||||||
|
currently work.
|
||||||
|
|
||||||
|
* CURLOPT_MAXFILESIZE. Prevent downloads that are larger than the specified
|
||||||
|
size. CURLE_FILESIZE_EXCEEDED would then be returned. Gautam Mani
|
||||||
|
requested. That is, the download should not even begin but be aborted
|
||||||
|
immediately.
|
||||||
|
|
||||||
|
LIBCURL - multi interface
|
||||||
|
|
||||||
|
* Add curl_multi_timeout() to make libcurl's ares-functionality better.
|
||||||
|
|
||||||
|
* Make sure we don't ever loop because of non-blocking sockets return
|
||||||
|
EWOULDBLOCK or similar. This FTP command sending, the SSL connection etc.
|
||||||
|
|
||||||
|
* Make transfers treated more carefully. We need a way to tell libcurl we
|
||||||
|
have data to write, as the current system expects us to upload data each
|
||||||
|
time the socket is writable and there is no way to say that we want to
|
||||||
|
upload data soon just not right now, without that aborting the upload. The
|
||||||
|
opposite situation should be possible as well, that we tell libcurl we're
|
||||||
|
ready to accept read data. Today libcurl feeds the data as soon as it is
|
||||||
|
available for reading, no matter what.
|
||||||
|
|
||||||
DOCUMENTATION
|
DOCUMENTATION
|
||||||
|
|
||||||
* Document all CURLcode error codes, why they happen and what most likely
|
* More and better
|
||||||
will make them not happen again.
|
|
||||||
|
|
||||||
FTP
|
FTP
|
||||||
|
|
||||||
* FTP ASCII upload does not follow RFC959 section 3.1.1.1: "The sender
|
* Support the most common FTP proxies, Philip Newton provided a list
|
||||||
converts the data from an internal character representation to the standard
|
allegedly from ncftp:
|
||||||
8-bit NVT-ASCII representation (see the Telnet specification). The
|
http://curl.haxx.se/mail/archive-2003-04/0126.html
|
||||||
receiver will convert the data from the standard form to his own internal
|
|
||||||
form."
|
|
||||||
|
|
||||||
* An option to only download remote FTP files if they're newer than the local
|
* Make CURLOPT_FTPPORT support an additional port number on the IP/if/name,
|
||||||
one is a good idea, and it would fit right into the same syntax as the
|
like "blabla:[port]" or possibly even "blabla:[portfirst]-[portsecond]".
|
||||||
already working http dito works. It of course requires that 'MDTM' works,
|
|
||||||
and it isn't a standard FTP command.
|
|
||||||
|
|
||||||
* Suggested on the mailing list: CURLOPT_FTP_MKDIR...!
|
* FTP ASCII transfers do not follow RFC959. They don't convert the data
|
||||||
|
accordingly.
|
||||||
|
|
||||||
* Always use the FTP SIZE command before downloading, as that makes it more
|
* Since USERPWD always override the user and password specified in URLs, we
|
||||||
likely that we know the size when downloading. Some sites support SIZE but
|
might need another way to specify user+password for anonymous ftp logins.
|
||||||
don't show the size in the RETR response!
|
|
||||||
|
* Add FTPS support with SSL for the data connection too. This should be made
|
||||||
|
according to the specs written in draft-murray-auth-ftp-ssl-11.txt,
|
||||||
|
"Securing FTP with TLS", valid until September 27th 2003.
|
||||||
|
http://curl.haxx.se/rfc/draft-murray-auth-ftp-ssl-11.txt
|
||||||
|
|
||||||
HTTP
|
HTTP
|
||||||
|
|
||||||
* HTTP PUT for files passed on stdin *OR* when the --crlf option is
|
* Digest, NTLM and GSS-Negotiate support for HTTP proxies. They all work
|
||||||
used. Requires libcurl to send the file with chunked content
|
on direct-connections to the server.
|
||||||
encoding. [http://curl.haxx.se/dev/HTTP-PUT-stdin.txt] When the filter
|
|
||||||
system mentioned above gets real, it'll be a piece of cake to add.
|
|
||||||
|
|
||||||
* "Content-Encoding: compress/gzip/zlib" HTTP 1.1 clearly defines how to get
|
* Pipelining. Sending multiple requests before the previous one(s) are done.
|
||||||
and decode compressed documents. There is the zlib that is pretty good at
|
This could possibly be implemented using the multi interface to queue
|
||||||
decompressing stuff. This work was started in October 1999 but halted again
|
requests and the response data.
|
||||||
since it proved more work than we thought. It is still a good idea to
|
|
||||||
implement though. This requires the filter system mentioned above.
|
|
||||||
|
|
||||||
* Authentication: NTLM. Support for that MS crap called NTLM
|
|
||||||
authentication. MS proxies and servers sometime require that. Since that
|
|
||||||
protocol is a proprietary one, it involves reverse engineering and network
|
|
||||||
sniffing. This should however be a library-based functionality. There are a
|
|
||||||
few different efforts "out there" to make open source HTTP clients support
|
|
||||||
this and it should be possible to take advantage of other people's hard
|
|
||||||
work. http://modntlm.sourceforge.net/ is one. There's a web page at
|
|
||||||
http://www.innovation.ch/java/ntlm.html that contains detailed reverse-
|
|
||||||
engineered info.
|
|
||||||
|
|
||||||
* RFC2617 compliance, "Digest Access Authentication"
|
|
||||||
A valid test page seem to exist at:
|
|
||||||
http://hopf.math.nwu.edu/testpage/digest/
|
|
||||||
And some friendly person's server source code is available at
|
|
||||||
http://hopf.math.nwu.edu/digestauth/index.html
|
|
||||||
Then there's the Apache mod_digest source code too of course. It seems as
|
|
||||||
if Netscape doesn't support this, and not many servers do. Although this is
|
|
||||||
a lot better authentication method than the more common "Basic". Basic
|
|
||||||
sends the password in cleartext over the network, this "Digest" method uses
|
|
||||||
a challange-response protocol which increases security quite a lot.
|
|
||||||
|
|
||||||
TELNET
|
TELNET
|
||||||
|
|
||||||
* Make TELNET work on windows98!
|
* Make TELNET work on windows98!
|
||||||
|
|
||||||
|
* Reading input (to send to the remote server) on stdin is a crappy solution
|
||||||
|
for library purposes. We need to invent a good way for the application to
|
||||||
|
be able to provide the data to send.
|
||||||
|
|
||||||
|
* Move the telnet support's network select() loop go away and merge the code
|
||||||
|
into the main transfer loop. Until this is done, the multi interface won't
|
||||||
|
work for telnet.
|
||||||
|
|
||||||
SSL
|
SSL
|
||||||
|
|
||||||
|
* If you really want to improve the SSL situation, you should probably have a
|
||||||
|
look at SSL cafile loading as well - quick traces look to me like these are
|
||||||
|
done on every request as well, when they should only be necessary once per
|
||||||
|
ssl context (or once per handle). Even better would be to support the SSL
|
||||||
|
CAdir option - instead of loading all of the root CA certs for every
|
||||||
|
request, this option allows you to only read the CA chain that is actually
|
||||||
|
required (into the cache)...
|
||||||
|
|
||||||
* Add an interface to libcurl that enables "session IDs" to get
|
* Add an interface to libcurl that enables "session IDs" to get
|
||||||
exported/imported. Cris Bailiff said: "OpenSSL has functions which can
|
exported/imported. Cris Bailiff said: "OpenSSL has functions which can
|
||||||
serialise the current SSL state to a buffer of your choice, and
|
serialise the current SSL state to a buffer of your choice, and
|
||||||
recover/reset the state from such a buffer at a later date - this is used
|
recover/reset the state from such a buffer at a later date - this is used
|
||||||
by mod_ssl for apache to implement and SSL session ID cache"
|
by mod_ssl for apache to implement and SSL session ID cache". This whole
|
||||||
|
idea might become moot if we enable the 'data sharing' as mentioned in the
|
||||||
|
LIBCURL label above.
|
||||||
|
|
||||||
|
* OpenSSL supports a callback for customised verification of the peer
|
||||||
|
certificate, but this doesn't seem to be exposed in the libcurl APIs. Could
|
||||||
|
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.
|
* Make curl's SSL layer option capable of using other free SSL libraries.
|
||||||
Such as the Mozilla Security Services
|
Such as the Mozilla Security Services
|
||||||
(http://www.mozilla.org/projects/security/pki/nss/) and GNUTLS
|
(http://www.mozilla.org/projects/security/pki/nss/) and GNUTLS
|
||||||
(http://gnutls.hellug.gr/)
|
(http://gnutls.hellug.gr/)
|
||||||
|
|
||||||
|
LDAP
|
||||||
|
|
||||||
|
* Look over the implementation. The looping will have to "go away" from the
|
||||||
|
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.
|
||||||
|
|
||||||
CLIENT
|
CLIENT
|
||||||
|
|
||||||
|
* Add an option that prevents cURL from overwiting existing local files. When
|
||||||
|
used, and there already is an existing file with the target file name
|
||||||
|
(either -O or -o), a number should be appended (and increased if already
|
||||||
|
existing). So that index.html becomes first index.html.1 and then
|
||||||
|
index.html.2 etc. Jeff Pohlmeyer suggested.
|
||||||
|
|
||||||
* "curl ftp://site.com/*.txt"
|
* "curl ftp://site.com/*.txt"
|
||||||
|
|
||||||
* Several URLs can be specified to get downloaded. We should be able to use
|
* Several URLs can be specified to get downloaded. We should be able to use
|
||||||
the same syntax to specify several files to get uploaded (using the same
|
the same syntax to specify several files to get uploaded (using the same
|
||||||
persistant connection), using -T.
|
persistant connection), using -T.
|
||||||
|
|
||||||
* Say you have a list of FTP addresses to download in a file named
|
* When the multi interface has been implemented and proved to work, the
|
||||||
ftp-list.txt: "cat ftp-list.txt | xargs curl -O -O -O [...]". curl _needs_
|
client could be told to use maximum N simultaneous transfers and then just
|
||||||
an "-Oalways" flag -- all addresses on the command line use the base
|
make sure that happens. It should of course not make more than one
|
||||||
filename to store locally. Else a script must precount the # of URLs,
|
connection to the same remote host.
|
||||||
construct the proper number of "-O"s...
|
|
||||||
|
* Extending the capabilities of the multipart formposting. How about leaving
|
||||||
|
the ';type=foo' syntax as it is and adding an extra tag (headers) which
|
||||||
|
works like this: curl -F "coolfiles=@fil1.txt;headers=@fil1.hdr" where
|
||||||
|
fil1.hdr contains extra headers like
|
||||||
|
|
||||||
|
Content-Type: text/plain; charset=KOI8-R"
|
||||||
|
Content-Transfer-Encoding: base64
|
||||||
|
X-User-Comment: Please don't use browser specific HTML code
|
||||||
|
|
||||||
|
which should overwrite the program reasonable defaults (plain/text,
|
||||||
|
8bit...) (Idea brough to us by kromJx)
|
||||||
|
|
||||||
TEST SUITE
|
TEST SUITE
|
||||||
|
|
||||||
|
* If perl wasn't found by the configure script, don't attempt to run the
|
||||||
|
tests but explain something nice why it doesn't.
|
||||||
|
|
||||||
* Extend the test suite to include more protocols. The telnet could just do
|
* Extend the test suite to include more protocols. The telnet could just do
|
||||||
ftp or http operations (for which we have test servers).
|
ftp or http operations (for which we have test servers).
|
||||||
|
|
||||||
@@ -134,3 +176,10 @@ TODO
|
|||||||
fork()s and it should become even more portable.
|
fork()s and it should become even more portable.
|
||||||
|
|
||||||
* Introduce a test suite that tests libcurl better and more explicitly.
|
* Introduce a test suite that tests libcurl better and more explicitly.
|
||||||
|
|
||||||
|
NEXT MAJOR RELEASE
|
||||||
|
|
||||||
|
* curl_easy_cleanup() returns void, but curl_multi_cleanup() returns a
|
||||||
|
CURLMcode. These should be changed to be the same.
|
||||||
|
|
||||||
|
* curl_formparse() should be removed
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man curl-config.1
|
.\" nroff -man curl-config.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl-config 1 "16 August 2001" "Curl 7.8.1" "curl-config manual"
|
.TH curl-config 1 "8 Oct 2002" "Curl 7.10" "curl-config manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl-config \- Get information about a libcurl installation
|
curl-config \- Get information about a libcurl installation
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -11,6 +11,10 @@ curl-config \- Get information about a libcurl installation
|
|||||||
.B curl-config
|
.B curl-config
|
||||||
displays information about a previous curl and libcurl installation.
|
displays information about a previous curl and libcurl installation.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
|
.IP "--ca"
|
||||||
|
Displays the built-in path to the CA cert bundle this libcurl uses.
|
||||||
|
.IP "--cc"
|
||||||
|
Displays the compiler used to build libcurl.
|
||||||
.IP "--cflags"
|
.IP "--cflags"
|
||||||
Set of compiler options (CFLAGS) to use when compiling files that use
|
Set of compiler options (CFLAGS) to use when compiling files that use
|
||||||
libcurl. Currently that is only thw include path to the curl include files.
|
libcurl. Currently that is only thw include path to the curl include files.
|
||||||
@@ -38,18 +42,23 @@ major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl
|
|||||||
.SH "EXAMPLES"
|
.SH "EXAMPLES"
|
||||||
What linker options do I need when I link with libcurl?
|
What linker options do I need when I link with libcurl?
|
||||||
|
|
||||||
curl-config --libs
|
$ curl-config --libs
|
||||||
|
|
||||||
What compiler options do I need when I compile using libcurl functions?
|
What compiler options do I need when I compile using libcurl functions?
|
||||||
|
|
||||||
curl-config --cflags
|
$ curl-config --cflags
|
||||||
|
|
||||||
How do I know if libcurl was built with SSL support?
|
How do I know if libcurl was built with SSL support?
|
||||||
|
|
||||||
curl-config --feature | grep SSL
|
$ curl-config --feature | grep SSL
|
||||||
|
|
||||||
What's the installed libcurl version?
|
What's the installed libcurl version?
|
||||||
|
|
||||||
curl-config --version
|
$ curl-config --version
|
||||||
|
|
||||||
|
How do I build a single file with a one-line command?
|
||||||
|
|
||||||
|
$ `curl-config --cc --cflags --libs` -o example example.c
|
||||||
|
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl (1)
|
.BR curl (1)
|
||||||
|
379
docs/curl.1
379
docs/curl.1
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man curl.1
|
.\" nroff -man curl.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl 1 "30 Nov 2001" "Curl 7.9.2" "Curl Manual"
|
.TH curl 1 "8 Aug 2003" "Curl 7.10.7" "Curl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl \- transfer a URL
|
curl \- transfer a URL
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -10,14 +10,18 @@ curl \- transfer a URL
|
|||||||
.I [URL...]
|
.I [URL...]
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
.B curl
|
.B curl
|
||||||
is a client to get documents/files from or send documents to a server, using
|
is a tool to transfer data from or to a server, using one of the supported
|
||||||
any of the supported protocols (HTTP, HTTPS, FTP, GOPHER, DICT, TELNET, LDAP
|
protocols (HTTP, HTTPS, FTP, FTPS, GOPHER, DICT, TELNET, LDAP or FILE). The
|
||||||
or FILE). The command is designed to work without user interaction or any kind
|
command is designed to work without user interaction.
|
||||||
of interactivity.
|
|
||||||
|
|
||||||
curl offers a busload of useful tricks like proxy support, user
|
curl offers a busload of useful tricks like proxy support, user
|
||||||
authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file
|
authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file
|
||||||
transfer resume and more.
|
transfer resume and more. As you will see below, the amount of features will
|
||||||
|
make your head spin!
|
||||||
|
|
||||||
|
curl is powered by libcurl for all transfer-related features. See
|
||||||
|
.BR libcurl (3)
|
||||||
|
for details.
|
||||||
.SH URL
|
.SH URL
|
||||||
The URL syntax is protocol dependent. You'll find a detailed description in
|
The URL syntax is protocol dependent. You'll find a detailed description in
|
||||||
RFC 2396.
|
RFC 2396.
|
||||||
@@ -48,10 +52,8 @@ specified on a single command line and cannot be used between separate curl
|
|||||||
invokes.
|
invokes.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
.IP "-a/--append"
|
.IP "-a/--append"
|
||||||
(FTP)
|
(FTP) When used in an FTP upload, this will tell curl to append to the target
|
||||||
When used in a ftp upload, this will tell curl to append to the target
|
file instead of overwriting it. If the file doesn't exist, it will be created.
|
||||||
file instead of overwriting it. If the file doesn't exist, it will
|
|
||||||
be created.
|
|
||||||
|
|
||||||
If this option is used twice, the second one will disable append mode again.
|
If this option is used twice, the second one will disable append mode again.
|
||||||
.IP "-A/--user-agent <agent string>"
|
.IP "-A/--user-agent <agent string>"
|
||||||
@@ -63,6 +65,16 @@ surround the string with single quote marks. This can also be set with the
|
|||||||
|
|
||||||
If this option is set more than once, the last one will be the one that's
|
If this option is set more than once, the last one will be the one that's
|
||||||
used.
|
used.
|
||||||
|
.IP "--anyauth"
|
||||||
|
(HTTP) Tells curl to figure out authentication method by itself, and use the
|
||||||
|
most secure one the remote site claims it supports. This is done by first
|
||||||
|
doing a request and checking the response-headers, thus inducing an extra
|
||||||
|
network round-trip. This is used instead of setting a specific authentication
|
||||||
|
method, which you can do with \fI--digest\fP, \fI--ntlm\fP, and
|
||||||
|
\fI--negotiate\fP. (Added in 7.10.6)
|
||||||
|
|
||||||
|
If this option is used several times, the following occurrences make no
|
||||||
|
difference.
|
||||||
.IP "-b/--cookie <name=data>"
|
.IP "-b/--cookie <name=data>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Pass the data to the HTTP server as a cookie. It is supposedly the
|
Pass the data to the HTTP server as a cookie. It is supposedly the
|
||||||
@@ -90,19 +102,30 @@ 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.
|
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.
|
If this option is used twice, the second one will disable ASCII usage.
|
||||||
|
.IP "--basic"
|
||||||
|
(HTTP) Tells curl to use HTTP Basic authentication. This is the default and
|
||||||
|
this option is usually pointless, unless you use it to override a previously
|
||||||
|
set option that sets a different authentication method (such as \fI--ntlm\fP,
|
||||||
|
\fI--digest\fP and \fI--negotiate\fP). (Added in 7.10.6)
|
||||||
|
|
||||||
|
If this option is used several times, the following occurrences make no
|
||||||
|
difference.
|
||||||
.IP "--ciphers <list of ciphers>"
|
.IP "--ciphers <list of ciphers>"
|
||||||
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
|
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
|
||||||
must be using valid ciphers. Read up on SSL cipher list details on this URL:
|
must be using valid ciphers. Read up on SSL cipher list details on this URL:
|
||||||
.I http://www.openssl.org/docs/apps/ciphers.html (Option added in curl 7.9)
|
.I http://www.openssl.org/docs/apps/ciphers.html
|
||||||
|
|
||||||
If this option is used severl times, the last one will override the others.
|
If this option is used several times, the last one will override the others.
|
||||||
|
.IP "--compressed"
|
||||||
|
(HTTP) Request a compressed response using one of the algorithms libcurl
|
||||||
|
supports, and return the uncompressed document. If this option is used and
|
||||||
|
the server sends an unsupported encoding, Curl will report an error.
|
||||||
|
|
||||||
|
If this option is used several times, each occurrence will toggle it on/off.
|
||||||
.IP "--connect-timeout <seconds>"
|
.IP "--connect-timeout <seconds>"
|
||||||
Maximum time in seconds that you allow the connection to the server to take.
|
Maximum time in seconds that you allow the connection to the server to take.
|
||||||
This only limits the connection phase, once curl has connected this option is
|
This only limits the connection phase, once curl has connected this option is
|
||||||
of no more use. This option didn't work in win32 systems until 7.7.2. See
|
of no more use. See also the \fI--max-time\fP option.
|
||||||
also the
|
|
||||||
.I "--max-time"
|
|
||||||
option.
|
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-c/--cookie-jar <file name>"
|
.IP "-c/--cookie-jar <file name>"
|
||||||
@@ -111,7 +134,13 @@ operation. Curl writes all cookies previously read from a specified file as
|
|||||||
well as all cookies received from remote server(s). If no cookies are known,
|
well as all cookies received from remote server(s). If no cookies are known,
|
||||||
no file will be written. The file will be written using the Netscape cookie
|
no file will be written. The file will be written using the Netscape cookie
|
||||||
file format. If you set the file name to a single dash, "-", the cookies will
|
file format. If you set the file name to a single dash, "-", the cookies will
|
||||||
be written to stdout. (Option added in curl 7.9)
|
be written to stdout.
|
||||||
|
|
||||||
|
.B NOTE
|
||||||
|
If the cookie jar can't be created or written to, the whole curl operation
|
||||||
|
won't fail or even report an error clearly. Using -v will get a warning
|
||||||
|
displayed, but that is the only visible feedback you get about this possibly
|
||||||
|
lethal situation.
|
||||||
|
|
||||||
If this option is used several times, the last specfied file name will be
|
If this option is used several times, the last specfied file name will be
|
||||||
used.
|
used.
|
||||||
@@ -125,12 +154,19 @@ Use "-C -" to tell curl to automatically find out where/how to resume the
|
|||||||
transfer. It then uses the given output/input files to figure that out.
|
transfer. It then uses the given output/input files to figure that out.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "--create-dirs"
|
||||||
|
When used in conjunction with the -o option, curl will create the necessary
|
||||||
|
local directory hierarchy as needed.
|
||||||
|
.IP "--crlf"
|
||||||
|
(FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390).
|
||||||
|
|
||||||
|
If this option is used twice, the second will again disable crlf converting.
|
||||||
.IP "-d/--data <data>"
|
.IP "-d/--data <data>"
|
||||||
(HTTP) Sends the specified data in a POST request to the HTTP server, in a way
|
(HTTP) Sends the specified data in a POST request to the HTTP server, in a way
|
||||||
that can emulate as if a user has filled in a HTML form and pressed the submit
|
that can emulate as if a user has filled in a HTML form and pressed the submit
|
||||||
button. Note that the data is sent exactly as specified with no extra
|
button. Note that the data is sent exactly as specified with no extra
|
||||||
processing (with all newlines cut off). The data is expected to be
|
processing (with all newlines cut off). The data is expected to be
|
||||||
"url-encoded". This will cause curl to pass the data to the server using the
|
\&"url-encoded". This will cause curl to pass the data to the server using the
|
||||||
content-type application/x-www-form-urlencoded. Compare to -F. If more than
|
content-type application/x-www-form-urlencoded. Compare to -F. If more than
|
||||||
one -d/--data option is used on the same command line, the data pieces
|
one -d/--data option is used on the same command line, the data pieces
|
||||||
specified will be merged together with a separating &-letter. Thus, using '-d
|
specified will be merged together with a separating &-letter. Thus, using '-d
|
||||||
@@ -141,7 +177,7 @@ If you start the data with the letter @, the rest should be a file name to
|
|||||||
read the data from, or - if you want curl to read the data from stdin. The
|
read the data from, or - if you want curl to read the data from stdin. The
|
||||||
contents of the file must already be url-encoded. Multiple files can also be
|
contents of the file must already be url-encoded. Multiple files can also be
|
||||||
specified. Posting data from a file named 'foobar' would thus be done with
|
specified. Posting data from a file named 'foobar' would thus be done with
|
||||||
"--data @foobar".
|
\&"--data @foobar".
|
||||||
|
|
||||||
To post data purely binary, you should instead use the --data-binary option.
|
To post data purely binary, you should instead use the --data-binary option.
|
||||||
|
|
||||||
@@ -162,21 +198,40 @@ want to post a binary file without the strip-newlines feature of the
|
|||||||
|
|
||||||
If this option is used several times, the ones following the first will
|
If this option is used several times, the ones following the first will
|
||||||
append data.
|
append data.
|
||||||
|
.IP "--digest"
|
||||||
|
(HTTP) Enables HTTP Digest authentication. This is a authentication that
|
||||||
|
prevents the password from being sent over the wire in clear text. Use this in
|
||||||
|
combination with the normal -u/--user option to set user name and
|
||||||
|
password. See also \fI--ntlm\fP, \fP--negotiate\fI and \fI--anyauth\fP for
|
||||||
|
related options. (Added in curl 7.10.6)
|
||||||
|
|
||||||
|
If this option is used several times, the following occurrences make no
|
||||||
|
difference.
|
||||||
|
.IP "--disable-eprt"
|
||||||
|
(FTP) Tell curl to disable the use of the EPRT and LPRT commands when doing
|
||||||
|
active FTP transfers. Curl will normally always first attempt to use EPRT,
|
||||||
|
then LPRT before using PORT, but with this option, it will use PORT right
|
||||||
|
away. EPRT and LPRT are extensions to the original FTP protocol, may not work
|
||||||
|
on all servers but enable more functionality in a better way than the
|
||||||
|
traditional PORT command. (Aded in 7.10.5)
|
||||||
|
|
||||||
|
If this option is used several times, each occurrence will toggle this on/off.
|
||||||
.IP "--disable-epsv"
|
.IP "--disable-epsv"
|
||||||
(FTP) Tell curl to disable the use of the EPSV command when doing passive FTP
|
(FTP) Tell curl to disable the use of the EPSV command when doing passive FTP
|
||||||
downloads. Curl will normally always first attempt to use EPSV before PASV,
|
transfers. Curl will normally always first attempt to use EPSV before PASV,
|
||||||
but with this option, it will not try using EPSV.
|
but with this option, it will not try using EPSV.
|
||||||
|
|
||||||
IF this option is used several times, each occurrence will toggle this on/off.
|
If this option is used several times, each occurrence will toggle this on/off.
|
||||||
.IP "-D/--dump-header <file>"
|
.IP "-D/--dump-header <file>"
|
||||||
(HTTP/FTP)
|
Write the protocol headers to the specified file.
|
||||||
Write the HTTP headers to this file. Write the FTP file info to this
|
|
||||||
file if -I/--head is used.
|
|
||||||
|
|
||||||
This option is handy to use when you want to store the cookies that a HTTP
|
This option is handy to use when you want to store the cookies that a HTTP
|
||||||
site sends to you. The cookies could then be read in a second curl invoke by
|
site sends to you. The cookies could then be read in a second curl invoke by
|
||||||
using the -b/--cookie option!
|
using the -b/--cookie option!
|
||||||
|
|
||||||
|
When used on FTP, the ftp server response lines are considered being "headers"
|
||||||
|
and thus are saved there.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-e/--referer <URL>"
|
.IP "-e/--referer <URL>"
|
||||||
(HTTP) Sends the "Referer Page" information to the HTTP server. This can also
|
(HTTP) Sends the "Referer Page" information to the HTTP server. This can also
|
||||||
@@ -187,6 +242,12 @@ previous URL when it follows a Location: header. The ";auto" string can be
|
|||||||
used alone, even if you don't set an initial referer.
|
used alone, even if you don't set an initial referer.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "--environment"
|
||||||
|
(RISC OS ONLY) Sets a range of environment variables, using the names the -w
|
||||||
|
option supports, to easier allow extraction of useful information after having
|
||||||
|
run curl.
|
||||||
|
|
||||||
|
If this option is used several times, each occurrence will toggle this on/off.
|
||||||
.IP "--egd-file <file>"
|
.IP "--egd-file <file>"
|
||||||
(HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The
|
(HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The
|
||||||
socket is used to seed the random engine for SSL connections. See also the
|
socket is used to seed the random engine for SSL connections. See also the
|
||||||
@@ -203,17 +264,38 @@ certificate concatenated!
|
|||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--cacert <CA certificate>"
|
.IP "--cacert <CA certificate>"
|
||||||
(HTTPS) Tells curl to use the specified certificate file to verify the
|
(HTTPS) Tells curl to use the specified certificate file to verify the
|
||||||
peer. The certificate must be in PEM format.
|
peer. The file may contain multiple CA certificates. The certificate(s) must
|
||||||
|
be in PEM format.
|
||||||
|
|
||||||
|
curl recognizes the environment variable named 'CURL_CA_BUNDLE' if that is
|
||||||
|
set, and uses the given path as a path to a CA cert bundle. This option
|
||||||
|
overrides that variable.
|
||||||
|
|
||||||
|
The windows version of curl will automatically look for a CA certs file named
|
||||||
|
\'curl-ca-bundle.crt\', either in the same directory as curl.exe, or in the
|
||||||
|
Current Working Directory, or in any folder along your PATH.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "--capath <CA certificate directory>"
|
||||||
|
(HTTPS) Tells curl to use the specified certificate directory to verify the
|
||||||
|
peer. The certificates must be in PEM format, and the directory must have been
|
||||||
|
processed using the c_rehash utility supplied with openssl. Using --capath can
|
||||||
|
allow curl to make https connections much more efficiently than using --cacert
|
||||||
|
if the --cacert file contains many CA certificates.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-f/--fail"
|
.IP "-f/--fail"
|
||||||
(HTTP)
|
(HTTP) Fail silently (no output at all) on server errors. This is mostly done
|
||||||
Fail silently (no output at all) on server errors. This is mostly done
|
like this to better enable scripts etc to better deal with failed attempts. In
|
||||||
like this to better enable scripts etc to better deal with failed
|
normal cases when a HTTP server fails to deliver a document, it returns a HTML
|
||||||
attempts. In normal cases when a HTTP server fails to deliver a
|
document stating so (which often also describes why and more). This flag will
|
||||||
document, it returns a HTML document stating so (which often also
|
prevent curl from outputting that and fail silently instead.
|
||||||
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-create-dirs"
|
||||||
|
(FTP) When an FTP URL/operation uses a path that doesn't currently exist on
|
||||||
|
the server, the standard behaviour of curl is to fail. Using this option, curl
|
||||||
|
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.
|
If this option is used twice, the second will again disable silent failure.
|
||||||
.IP "-F/--form <name=content>"
|
.IP "-F/--form <name=content>"
|
||||||
@@ -230,24 +312,34 @@ Example, to send your password file to the server, where
|
|||||||
\&'password' is the name of the form-field to which /etc/passwd will be the
|
\&'password' is the name of the form-field to which /etc/passwd will be the
|
||||||
input:
|
input:
|
||||||
|
|
||||||
.B curl
|
\fBcurl\fP -F password=@/etc/passwd www.mypasswords.com
|
||||||
-F password=@/etc/passwd www.mypasswords.com
|
|
||||||
|
|
||||||
To read the file's content from stdin insted of a file, use - where the file
|
To read the file's content from stdin insted of a file, use - where the file
|
||||||
name should've been. This goes for both @ and < constructs.
|
name should've been. This goes for both @ and < constructs.
|
||||||
|
|
||||||
|
You can also tell curl what Content-Type to use for the file upload part, by
|
||||||
|
using 'type=', in a manner similar to:
|
||||||
|
|
||||||
|
\fBcurl\fP -F "web=@index.html;type=text/html" url.com
|
||||||
|
|
||||||
|
See further examples and details in the MANUAL.
|
||||||
|
|
||||||
This option can be used multiple times.
|
This option can be used multiple times.
|
||||||
.IP "-g/--globoff"
|
.IP "-g/--globoff"
|
||||||
This option switches off the "URL globbing parser". When you set this option,
|
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
|
you can specify URLs that contain the letters {}[] without having them being
|
||||||
interpreted by curl itself. Note that these letters are not normal legal URL
|
interpreted by curl itself. Note that these letters are not normal legal URL
|
||||||
contents but they should be encoded according to the URI standard. (Option
|
contents but they should be encoded according to the URI standard.
|
||||||
added in curl 7.6)
|
|
||||||
.IP "-G/--get"
|
.IP "-G/--get"
|
||||||
When used, this option will make all data specified with -d/--data or
|
When used, this option will make all data specified with -d/--data or
|
||||||
--data-binary to be used in a HTTP GET request instead of the POST request
|
--data-binary to be used in a HTTP GET request instead of the POST request
|
||||||
that otherwise would be used. The data will be appended to the URL with a '?'
|
that otherwise would be used. The data will be appended to the URL with a '?'
|
||||||
separator. (Option added in curl 7.9)
|
separator.
|
||||||
|
|
||||||
|
If used in combination with -I, the POST data will instead be appended to the
|
||||||
|
URL with a HEAD request.
|
||||||
|
|
||||||
|
If used multiple times, nothing special happens.
|
||||||
.IP "-h/--help"
|
.IP "-h/--help"
|
||||||
Usage help.
|
Usage help.
|
||||||
.IP "-H/--header <header>"
|
.IP "-H/--header <header>"
|
||||||
@@ -260,7 +352,7 @@ 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
|
internal header with one without content on the right side of the colon will
|
||||||
prevent that header from appearing.
|
prevent that header from appearing.
|
||||||
|
|
||||||
This option can be used multiple times.
|
This option can be used multiple times to add/replace/remove multiple headers.
|
||||||
.IP "-i/--include"
|
.IP "-i/--include"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Include the HTTP-header in the output. The HTTP-header includes things
|
Include the HTTP-header in the output. The HTTP-header includes things
|
||||||
@@ -281,6 +373,23 @@ which this uses to get nothing but the header of a document. When used
|
|||||||
on a FTP file, curl displays the file size only.
|
on a FTP file, curl displays the file size only.
|
||||||
|
|
||||||
If this option is used twice, the second will again disable header only.
|
If this option is used twice, the second will again disable header only.
|
||||||
|
.IP "-j/--junk-session-cookies"
|
||||||
|
(HTTP) When curl is told to read cookies from a given file, this option will
|
||||||
|
make it discard all "session cookies". This will basicly have the same effect
|
||||||
|
as if a new session is started. Typical browsers always discard session
|
||||||
|
cookies when they're closed down. (Added in 7.9.7)
|
||||||
|
|
||||||
|
If this option is used several times, each occurrence will toggle this on/off.
|
||||||
|
.IP "-k/--insecure"
|
||||||
|
(SSL) This option explicitly allows curl to perform "insecure" SSL connections
|
||||||
|
and transfers. Starting with curl 7.10, all SSL connections will be attempted
|
||||||
|
to be made secure by using the CA certificate bundle installed by
|
||||||
|
default. This makes all connections considered "insecure" to fail unless
|
||||||
|
-k/--insecure is used.
|
||||||
|
|
||||||
|
This option is ignored if --cacert or --capath is used!
|
||||||
|
|
||||||
|
If this option is used twice, the second time will again disable it.
|
||||||
.IP "--krb4 <level>"
|
.IP "--krb4 <level>"
|
||||||
(FTP) Enable kerberos4 authentication and use. The level must be entered and
|
(FTP) Enable kerberos4 authentication and use. The level must be entered and
|
||||||
should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use
|
should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use
|
||||||
@@ -298,7 +407,26 @@ treated as a comment.
|
|||||||
|
|
||||||
Specify the filename as '-' to make curl read the file from stdin.
|
Specify the filename as '-' to make curl read the file from stdin.
|
||||||
|
|
||||||
|
Note that to be able to specify a URL in the config file, you need to specify
|
||||||
|
it using the --url option, and not by simply writing the URL on its own
|
||||||
|
line. So, it could look similar to this:
|
||||||
|
|
||||||
|
url = "http://curl.haxx.se/docs/"
|
||||||
|
|
||||||
This option can be used multiple times.
|
This option can be used multiple times.
|
||||||
|
.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
|
||||||
|
bandwidth.
|
||||||
|
|
||||||
|
The given speed is measured in bytes/second, unless a suffix is
|
||||||
|
appended. Appending 'k' or 'K' will count the number as kilobytes, 'm' or M'
|
||||||
|
makes it megabytes while 'g' or 'G' makes it gigabytes. Examples: 200K, 3m and
|
||||||
|
1G.
|
||||||
|
|
||||||
|
This option was introduced in curl 7.10.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-l/--list-only"
|
.IP "-l/--list-only"
|
||||||
(FTP)
|
(FTP)
|
||||||
When listing an FTP directory, this switch forces a name-only view.
|
When listing an FTP directory, this switch forces a name-only view.
|
||||||
@@ -306,23 +434,34 @@ Especially useful if you want to machine-parse the contents of an FTP
|
|||||||
directory since the normal directory view doesn't use a standard look
|
directory since the normal directory view doesn't use a standard look
|
||||||
or format.
|
or format.
|
||||||
|
|
||||||
|
This option causes an FTP NLST command to be sent. Some FTP servers
|
||||||
|
list only files in their response to NLST; they do not include
|
||||||
|
subdirectories and symbolic links.
|
||||||
|
|
||||||
If this option is used twice, the second will again disable list only.
|
If this option is used twice, the second will again disable list only.
|
||||||
.IP "-L/--location"
|
.IP "-L/--location"
|
||||||
(HTTP/HTTPS) If the server reports that the requested page has a different
|
(HTTP/HTTPS) If the server reports that the requested page has a different
|
||||||
location (indicated with the header line Location:) this flag will let curl
|
location (indicated with the header line Location:) this flag will let curl
|
||||||
attempt to reattempt the get on the new place. If used together with -i or -I,
|
attempt to reattempt the get on the new place. If used together with -i or -I,
|
||||||
headers from all requested pages will be shown. If this flag is used when
|
headers from all requested pages will be shown. If authentication is used,
|
||||||
making a HTTP POST, curl will automatically switch to GET after the initial
|
curl will only send its credentials to the initial host, so if a redirect
|
||||||
POST has been done.
|
takes curl to a different host, it won't intercept the user+password. See also
|
||||||
|
\fI--location-trusted\fP on how to change this.
|
||||||
|
|
||||||
|
If this option is used twice, the second will again disable location following.
|
||||||
|
.IP "--location-trusted"
|
||||||
|
(HTTP/HTTPS) Like \fI--location\fP, but will allow sending the name + password
|
||||||
|
to all hosts that the site may redirect to. This may or may not introduce a
|
||||||
|
security breach if the site redirects you do a site to which you'll send your
|
||||||
|
authentication info (which is plaintext in the case of HTTP Basic
|
||||||
|
authentication).
|
||||||
|
|
||||||
If this option is used twice, the second will again disable location following.
|
If this option is used twice, the second will again disable location following.
|
||||||
.IP "-m/--max-time <seconds>"
|
.IP "-m/--max-time <seconds>"
|
||||||
Maximum time in seconds that you allow the whole operation to take. This is
|
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
|
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.
|
networks or links going down. This doesn't work fully in win32 systems. See
|
||||||
See also the
|
also the \fI--connect-timeout\fP option.
|
||||||
.I "--connect-timeout"
|
|
||||||
option.
|
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-M/--manual"
|
.IP "-M/--manual"
|
||||||
@@ -349,6 +488,19 @@ to allow curl to ftp to the machine host.domain.com with user name
|
|||||||
.B "machine host.domain.com login myself password secret"
|
.B "machine host.domain.com login myself password secret"
|
||||||
|
|
||||||
If this option is used twice, the second will again disable netrc usage.
|
If this option is used twice, the second will again disable netrc usage.
|
||||||
|
.IP "--negotiate"
|
||||||
|
(HTTP) Enables GSS-Negotiate authentication. The GSS-Negotiate method was
|
||||||
|
designed by Microsoft and is used in their web aplications. It is primarily
|
||||||
|
meant as a support for Kerberos5 authentication but may be also used along
|
||||||
|
with another authentication methods. For more information see IETF draft
|
||||||
|
draft-brezak-spnego-http-04.txt. (Added in 7.10.6)
|
||||||
|
|
||||||
|
\fBNOTE\fP that this option requiures that the library was built with GSSAPI
|
||||||
|
support. This is not very common. Use \fIcurl --version\fP to see if your
|
||||||
|
version supports GSS-Negotiate.
|
||||||
|
|
||||||
|
If this option is used several times, the following occurrences make no
|
||||||
|
difference.
|
||||||
.IP "-N/--no-buffer"
|
.IP "-N/--no-buffer"
|
||||||
Disables the buffering of the output stream. In normal work situations, curl
|
Disables the buffering of the output stream. In normal work situations, curl
|
||||||
will use a standard buffered output stream that will have the effect that it
|
will use a standard buffered output stream that will have the effect that it
|
||||||
@@ -356,6 +508,19 @@ will output the data in chunks, not necessarily exactly when the data arrives.
|
|||||||
Using this option will disable that buffering.
|
Using this option will disable that buffering.
|
||||||
|
|
||||||
If this option is used twice, the second will again switch on buffering.
|
If this option is used twice, the second will again switch on buffering.
|
||||||
|
.IP "--ntlm"
|
||||||
|
(HTTP) Enables NTLM authentication. The NTLM authentication method was
|
||||||
|
designed by Microsoft and is used by IIS web servers. It is a proprietary
|
||||||
|
protocol, reversed engineered by clever people and implemented in curl based
|
||||||
|
on their efforts. This kind of behavior should not be endorsed, you should
|
||||||
|
encourage everyone who uses NTLM to switch to a public and documented
|
||||||
|
authentication method instead. Such as Digest. (Added in 7.10.6)
|
||||||
|
|
||||||
|
\fBNOTE\fP that this option requiures that the library was built with SSL
|
||||||
|
support. Use \fIcurl --version\fP to see if your version supports NTLM.
|
||||||
|
|
||||||
|
If this option is used several times, the following occurrences make no
|
||||||
|
difference.
|
||||||
.IP "-o/--output <file>"
|
.IP "-o/--output <file>"
|
||||||
Write output to <file> instead of stdout. If you are using {} or [] to fetch
|
Write output to <file> instead of stdout. If you are using {} or [] to fetch
|
||||||
multiple documents, you can use '#' followed by a number in the <file>
|
multiple documents, you can use '#' followed by a number in the <file>
|
||||||
@@ -369,9 +534,11 @@ or use several variables like:
|
|||||||
curl http://{site,host}.host[1-5].com -o "#1_#2"
|
curl http://{site,host}.host[1-5].com -o "#1_#2"
|
||||||
|
|
||||||
You may use this option as many times as you have number of URLs.
|
You may use this option as many times as you have number of URLs.
|
||||||
|
|
||||||
|
See also the --create-dirs option to create the local directories dynamically.
|
||||||
.IP "-O/--remote-name"
|
.IP "-O/--remote-name"
|
||||||
Write output to a local file named like the remote file we get. (Only
|
Write output to a local file named like the remote file we get. (Only the file
|
||||||
the file part of the remote file is used, the path is cut off.)
|
part of the remote file is used, the path is cut off.)
|
||||||
|
|
||||||
You may use this option as many times as you have number of URLs.
|
You may use this option as many times as you have number of URLs.
|
||||||
.IP "-p/--proxytunnel"
|
.IP "-p/--proxytunnel"
|
||||||
@@ -479,6 +646,12 @@ If this option is used twice, the second will again disable mute.
|
|||||||
When used with -s it makes curl show error message if it fails.
|
When used with -s it makes curl show error message if it fails.
|
||||||
|
|
||||||
If this option is used twice, the second will again disable show error.
|
If this option is used twice, the second will again disable show error.
|
||||||
|
.IP "--stderr <file>"
|
||||||
|
Redirect all writes to stderr to the specified file instead. If the file name
|
||||||
|
is a plain '-', it is instead written to stdout. This option has no point when
|
||||||
|
you're using a shell with decent redirecting capabilities.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-t/--telnet-option <OPT=val>"
|
.IP "-t/--telnet-option <OPT=val>"
|
||||||
Pass options to the telnet protocol. Supported options are:
|
Pass options to the telnet protocol. Supported options are:
|
||||||
|
|
||||||
@@ -498,10 +671,31 @@ this is used on a http(s) server, the PUT command will be used.
|
|||||||
Use the file name "-" (a single dash) to use stdin instead of a given file.
|
Use the file name "-" (a single dash) to use stdin instead of a given file.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "--trace <file>"
|
||||||
|
Enables a full trace dump of all incoming and outgoing data, including
|
||||||
|
descriptive information, to the given output file. Use "-" as filename to have
|
||||||
|
the output sent to stdout.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used. (Added in
|
||||||
|
7.9.7)
|
||||||
|
.IP "--trace-ascii <file>"
|
||||||
|
Enables a full trace dump of all incoming and outgoing data, including
|
||||||
|
descriptive information, to the given output file. Use "-" as filename to have
|
||||||
|
the output sent to stdout.
|
||||||
|
|
||||||
|
This is very similar to --trace, but leaves out the hex part and only shows
|
||||||
|
the ASCII part of the dump. It makes smaller output that might be easier to
|
||||||
|
read for untrained humans.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used. (Added in
|
||||||
|
7.9.7)
|
||||||
.IP "-u/--user <user:password>"
|
.IP "-u/--user <user:password>"
|
||||||
Specify user and password to use when fetching. See README.curl for detailed
|
Specify user and password to use when fetching. Read the MANUAL for detailed
|
||||||
examples of how to use this. If no password is specified, curl will
|
examples of how to use this. If no password is specified, curl will ask for it
|
||||||
ask for it interactively.
|
interactively.
|
||||||
|
|
||||||
|
You can also use the --digest option to enable Digest authentication when
|
||||||
|
communicating with HTTP 1.1 servers.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-U/--proxy-user <user:password>"
|
.IP "-U/--proxy-user <user:password>"
|
||||||
@@ -510,7 +704,7 @@ password is specified, curl will ask for it interactively.
|
|||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--url <URL>"
|
.IP "--url <URL>"
|
||||||
Specify a URL to fetch. This option is mostly handy when you wanna specify
|
Specify a URL to fetch. This option is mostly handy when you want to specify
|
||||||
URL(s) in a config file.
|
URL(s) in a config file.
|
||||||
|
|
||||||
This option may be used any number of times. To control where this URL is written, use the
|
This option may be used any number of times. To control where this URL is written, use the
|
||||||
@@ -519,15 +713,30 @@ or the
|
|||||||
.I -O
|
.I -O
|
||||||
options.
|
options.
|
||||||
.IP "-v/--verbose"
|
.IP "-v/--verbose"
|
||||||
Makes the fetching more verbose/talkative. Mostly usable for
|
Makes the fetching more verbose/talkative. Mostly usable for debugging. Lines
|
||||||
debugging. Lines starting with '>' means data sent by curl, '<'
|
starting with '>' means data sent by curl, '<' means data received by curl
|
||||||
means data received by curl that is hidden in normal cases and lines
|
that is hidden in normal cases and lines starting with '*' means additional
|
||||||
starting with '*' means additional info provided by curl.
|
info provided by curl.
|
||||||
|
|
||||||
|
Note that if you want to see HTTP headers in the output, \fI-i/--include\fP
|
||||||
|
might be option you're looking for.
|
||||||
|
|
||||||
|
If you think this option still doesn't give you enough details, consider using
|
||||||
|
\fI--trace\fP or \fI--trace-ascii\fP instead.
|
||||||
|
|
||||||
If this option is used twice, the second will again disable verbose.
|
If this option is used twice, the second will again disable verbose.
|
||||||
.IP "-V/--version"
|
.IP "-V/--version"
|
||||||
Displays the full version of curl, libcurl and other 3rd party libraries
|
Displays information about curl and the libcurl version it uses.
|
||||||
linked with the executable.
|
|
||||||
|
The first line includes the full version of curl, libcurl and other 3rd party
|
||||||
|
libraries linked with the executable.
|
||||||
|
|
||||||
|
The second line (starts with "Protocols:") shows all protocols that libcurl
|
||||||
|
reports to support.
|
||||||
|
|
||||||
|
The third line (starts with "Features:") shows specific features libcurl
|
||||||
|
reports to offer.
|
||||||
|
|
||||||
.IP "-w/--write-out <format>"
|
.IP "-w/--write-out <format>"
|
||||||
Defines what to display after a completed and successful operation. The 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
|
is a string that may contain plain text mixed with any number of variables. The
|
||||||
@@ -538,7 +747,7 @@ write "@-".
|
|||||||
The variables present in the output format will be substituted by the value or
|
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
|
text that curl thinks fit, as described below. All variables are specified
|
||||||
like %{variable_name} and to output a normal % you just write them like
|
like %{variable_name} and to output a normal % you just write them like
|
||||||
%%. You can output a newline by using \\n, a carrige return with \\r and a tab
|
%%. You can output a newline by using \\n, a carriage return with \\r and a tab
|
||||||
space with \\t.
|
space with \\t.
|
||||||
|
|
||||||
.B NOTE:
|
.B NOTE:
|
||||||
@@ -594,6 +803,9 @@ The average download speed that curl measured for the complete download.
|
|||||||
.TP
|
.TP
|
||||||
.B speed_upload
|
.B speed_upload
|
||||||
The average upload speed that curl measured for the complete upload.
|
The average upload speed that curl measured for the complete upload.
|
||||||
|
.TP
|
||||||
|
.B content_type
|
||||||
|
The Content-Type of the requested document, if there was any. (Added in 7.9.5)
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
@@ -601,6 +813,10 @@ If this option is used several times, the last one will be used.
|
|||||||
Use specified HTTP proxy. If the port number is not specified, it is assumed
|
Use specified HTTP proxy. If the port number is not specified, it is assumed
|
||||||
at port 1080.
|
at port 1080.
|
||||||
|
|
||||||
|
This option overrides existing environment variables that sets proxy to
|
||||||
|
use. If there's an environment variable setting a proxy, you can set proxy to
|
||||||
|
\&"" to override it.
|
||||||
|
|
||||||
\fBNote\fP that all operations that are performed over a HTTP proxy will
|
\fBNote\fP that all operations that are performed over a HTTP proxy will
|
||||||
transparantly be converted to HTTP. It means that certain protocol specific
|
transparantly be converted to HTTP. It means that certain protocol specific
|
||||||
operations might not be available. This is not the case if you can tunnel
|
operations might not be available. This is not the case if you can tunnel
|
||||||
@@ -623,6 +839,9 @@ If a download is slower than speed-limit bytes per second during a speed-time
|
|||||||
period, the download gets aborted. If speed-time is used, the default
|
period, the download gets aborted. If speed-time is used, the default
|
||||||
speed-limit will be 1 unless set with -y.
|
speed-limit will be 1 unless set with -y.
|
||||||
|
|
||||||
|
This option controls transfers and thus will not affect slow connects etc. If
|
||||||
|
this is a concern for you, try the \fI--connect-timeout\fP option.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-Y/--speed-limit <speed>"
|
.IP "-Y/--speed-limit <speed>"
|
||||||
If a download is slower than this given speed, in bytes per second, for
|
If a download is slower than this given speed, in bytes per second, for
|
||||||
@@ -645,6 +864,12 @@ Start the date expression with a dash (-) to make it request for a document
|
|||||||
that is older than the given date/time, default is a document that is newer
|
that is older than the given date/time, default is a document that is newer
|
||||||
than the specified date/time.
|
than the specified date/time.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "-Z/--max-redirs <num>"
|
||||||
|
Set maximum number of redirection-followings allowed. If -L/--location is
|
||||||
|
used, this option can be used to prevent curl from following redirections "in
|
||||||
|
absurdum".
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-3/--sslv3"
|
.IP "-3/--sslv3"
|
||||||
(HTTPS)
|
(HTTPS)
|
||||||
@@ -660,16 +885,6 @@ Make curl display progress information as a progress bar instead of the
|
|||||||
default statistics.
|
default statistics.
|
||||||
|
|
||||||
If this option is used twice, the second will again disable the progress bar.
|
If this option is used twice, the second will again disable the progress bar.
|
||||||
.IP "--crlf"
|
|
||||||
(FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390).
|
|
||||||
|
|
||||||
If this option is used twice, the second will again disable crlf converting.
|
|
||||||
.IP "--stderr <file>"
|
|
||||||
Redirect all writes to stderr to the specified file instead. If the file name
|
|
||||||
is a plain '-', it is instead written to stdout. This option has no point when
|
|
||||||
you're using a shell with decent redirecting capabilities.
|
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
|
||||||
.SH FILES
|
.SH FILES
|
||||||
.I ~/.curlrc
|
.I ~/.curlrc
|
||||||
.RS
|
.RS
|
||||||
@@ -731,13 +946,15 @@ FTP couldn't set binary. Couldn't change transfer method to binary.
|
|||||||
.IP 18
|
.IP 18
|
||||||
Partial file. Only a part of the file was transfered.
|
Partial file. Only a part of the file was transfered.
|
||||||
.IP 19
|
.IP 19
|
||||||
FTP couldn't RETR file. The RETR command failed.
|
FTP couldn't download/access the given file, the RETR (or similar) command
|
||||||
|
failed.
|
||||||
.IP 20
|
.IP 20
|
||||||
FTP write error. The transfer was reported bad by the server.
|
FTP write error. The transfer was reported bad by the server.
|
||||||
.IP 21
|
.IP 21
|
||||||
FTP quote error. A quote command returned error from the server.
|
FTP quote error. A quote command returned error from the server.
|
||||||
.IP 22
|
.IP 22
|
||||||
HTTP not found. The requested page was not found. This return code only
|
HTTP page not retrieved. The requested url was not found or returned another
|
||||||
|
error with the HTTP error code being 400 or above. This return code only
|
||||||
appears if --fail is used.
|
appears if --fail is used.
|
||||||
.IP 23
|
.IP 23
|
||||||
Write error. Curl couldn't write data to a local filesystem or similar.
|
Write error. Curl couldn't write data to a local filesystem or similar.
|
||||||
@@ -788,7 +1005,7 @@ Internal error. A function was called in a bad order.
|
|||||||
.IP 45
|
.IP 45
|
||||||
Interface error. A specified outgoing interface could not be used.
|
Interface error. A specified outgoing interface could not be used.
|
||||||
.IP 46
|
.IP 46
|
||||||
Bad password entered. An error was signalled when the password was entered.
|
Bad password entered. An error was signaled when the password was entered.
|
||||||
.IP 47
|
.IP 47
|
||||||
Too many redirects. When following redirects, curl hit the maximum amount.
|
Too many redirects. When following redirects, curl hit the maximum amount.
|
||||||
.IP 48
|
.IP 48
|
||||||
@@ -799,11 +1016,27 @@ Malformed telnet option.
|
|||||||
The remote peer's SSL certificate wasn't ok
|
The remote peer's SSL certificate wasn't ok
|
||||||
.IP 52
|
.IP 52
|
||||||
The server didn't reply anything, which here is considered an error.
|
The server didn't reply anything, which here is considered an error.
|
||||||
|
.IP 53
|
||||||
|
SSL crypto engine not found
|
||||||
|
.IP 54
|
||||||
|
Cannot set SSL crypto engine as default
|
||||||
|
.IP 55
|
||||||
|
Failed sending network data
|
||||||
|
.IP 56
|
||||||
|
Failure in receiving network data
|
||||||
|
.IP 57
|
||||||
|
Share is in use (internal error)
|
||||||
|
.IP 58
|
||||||
|
Problem with the local certificate
|
||||||
|
.IP 59
|
||||||
|
Couldn't use specified SSL cipher
|
||||||
|
.IP 60
|
||||||
|
Problem with the CA cert (path? permission?)
|
||||||
|
.IP 61
|
||||||
|
Unrecognized transfer encoding
|
||||||
.IP XX
|
.IP XX
|
||||||
There will appear more error codes here in future releases. The existing ones
|
There will appear more error codes here in future releases. The existing ones
|
||||||
are meant to never change.
|
are meant to never change.
|
||||||
.SH BUGS
|
|
||||||
If you do find bugs, mail them to curl-bug@haxx.se.
|
|
||||||
.SH AUTHORS / CONTRIBUTORS
|
.SH AUTHORS / CONTRIBUTORS
|
||||||
Daniel Stenberg is the main author, but the whole list of contributors is
|
Daniel Stenberg is the main author, but the whole list of contributors is
|
||||||
found in the separate THANKS file.
|
found in the separate THANKS file.
|
||||||
|
@@ -1,29 +0,0 @@
|
|||||||
.\" You can view this file with:
|
|
||||||
.\" nroff -man [file]
|
|
||||||
.\" $Id$
|
|
||||||
.\"
|
|
||||||
.TH curl_easy_cleanup 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
|
||||||
.SH NAME
|
|
||||||
curl_easy_cleanup - End a libcurl session
|
|
||||||
.SH SYNOPSIS
|
|
||||||
.B #include <curl/curl.h>
|
|
||||||
.sp
|
|
||||||
.BI "void curl_easy_cleanup(CURL *" handle ");"
|
|
||||||
.ad
|
|
||||||
.SH DESCRIPTION
|
|
||||||
This function must be the last function to call for a curl session. It is the
|
|
||||||
opposite of the
|
|
||||||
.I curl_easy_init
|
|
||||||
function and must be called with the same
|
|
||||||
.I handle
|
|
||||||
as input as the curl_easy_init call returned.
|
|
||||||
|
|
||||||
This will effectively close all connections libcurl has been used and possibly
|
|
||||||
has kept open until now. Don't call this function if you intend to transfer
|
|
||||||
more files (libcurl 7.7 or later).
|
|
||||||
.SH RETURN VALUE
|
|
||||||
None
|
|
||||||
.SH "SEE ALSO"
|
|
||||||
.BR curl_easy_init "(3), "
|
|
||||||
.SH BUGS
|
|
||||||
Surely there are some, you tell me!
|
|
@@ -1,34 +0,0 @@
|
|||||||
.\" You can view this file with:
|
|
||||||
.\" nroff -man [file]
|
|
||||||
.\" $Id$
|
|
||||||
.\"
|
|
||||||
.TH curl_easy_init 3 "14 August 2001" "libcurl 7.8.1" "libcurl Manual"
|
|
||||||
.SH NAME
|
|
||||||
curl_easy_init - Start a libcurl session
|
|
||||||
.SH SYNOPSIS
|
|
||||||
.B #include <curl/curl.h>
|
|
||||||
.sp
|
|
||||||
.BI "CURL *curl_easy_init( );"
|
|
||||||
.ad
|
|
||||||
.SH DESCRIPTION
|
|
||||||
This function must be the first function to call, and it returns a CURL handle
|
|
||||||
that you shall use as input to the other easy-functions. The init calls
|
|
||||||
intializes curl and this call MUST have a corresponding call to
|
|
||||||
.I curl_easy_cleanup
|
|
||||||
when the operation is complete.
|
|
||||||
|
|
||||||
On win32 systems, if you want to init the winsock stuff manually, libcurl will
|
|
||||||
not do that for you. WSAStartup() and WSACleanup() should then be called
|
|
||||||
accordingly. If you want libcurl to handle this, use the CURL_GLOBAL_WIN32
|
|
||||||
flag in the initial curl_global_init() call.
|
|
||||||
|
|
||||||
Using libcurl 7.7 and later, you should perform all your sequential file
|
|
||||||
transfers using the same curl handle. This enables libcurl to use persistant
|
|
||||||
connections where possible.
|
|
||||||
.SH RETURN VALUE
|
|
||||||
If this function returns NULL, something went wrong and you cannot use the
|
|
||||||
other curl functions.
|
|
||||||
.SH "SEE ALSO"
|
|
||||||
.BR curl_easy_cleanup "(3), " curl_global_init "(3)
|
|
||||||
.SH BUGS
|
|
||||||
Surely there are some, you tell me!
|
|
@@ -1,165 +0,0 @@
|
|||||||
.\" You can view this file with:
|
|
||||||
.\" nroff -man [file]
|
|
||||||
.\" $Id$
|
|
||||||
.\"
|
|
||||||
.TH curl_formadd 3 "29 October 2001" "libcurl 7.9.1" "libcurl Manual"
|
|
||||||
.SH NAME
|
|
||||||
curl_formadd - add a section to a multipart/formdata HTTP POST
|
|
||||||
.SH SYNOPSIS
|
|
||||||
.B #include <curl/curl.h>
|
|
||||||
.sp
|
|
||||||
.BI "int curl_formadd(struct HttpPost ** " firstitem,
|
|
||||||
.BI "struct HttpPost ** " lastitem, " ...);"
|
|
||||||
.ad
|
|
||||||
.SH DESCRIPTION
|
|
||||||
curl_formadd() is used to append sections when building a multipart/formdata
|
|
||||||
HTTP POST (sometimes refered to as rfc1867-style posts). Append one section at
|
|
||||||
a time until you've added all the sections you want included and then you pass
|
|
||||||
the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP.
|
|
||||||
\fIlastitem\fP is set after each call and on repeated invokes it should be
|
|
||||||
left as set to allow repeated invokes to find the end of the list faster.
|
|
||||||
|
|
||||||
After the \fIlastitem\fP pointer follow the real arguments. (If the following
|
|
||||||
description confuses you, jump directly to the examples):
|
|
||||||
|
|
||||||
\fBCURLFORM_COPYNAME\fP or \fBCURLFORM_PTRNAME\fP followed by a string is used
|
|
||||||
for the name of the section. Optionally one may use \fBCURLFORM_NAMELENGTH\fP
|
|
||||||
to specify the length of the name (allowing null characters within the
|
|
||||||
name). All options that use the word COPY in their names copy the given
|
|
||||||
contents, while the ones with PTR in their names simply points to the (static)
|
|
||||||
data you must make sure remain until curl no longer needs it.
|
|
||||||
|
|
||||||
The four options for providing values are: \fBCURLFORM_COPYCONTENTS\fP,
|
|
||||||
\fBCURLFORM_PTRCONTENTS\fP, \fBCURLFORM_FILE\fP, or \fBCURLFORM_FILECONTENT\fP
|
|
||||||
followed by a char or void pointer (allowed for PTRCONTENTS).
|
|
||||||
|
|
||||||
\fBCURLFORM_FILECONTENT\fP does a normal post like \fBCURLFORM_COPYCONTENTS\fP
|
|
||||||
but the actual value is read from the filename given as a string.
|
|
||||||
|
|
||||||
Other arguments may be \fBCURLFORM_CONTENTTYPE\fP if the user wishes to
|
|
||||||
specify one (for FILE if no type is given the library tries to provide the
|
|
||||||
correct one; for CONTENTS no Content-Type is sent in this case).
|
|
||||||
|
|
||||||
For \fBCURLFORM_PTRCONTENTS\fP or \fBCURLFORM_COPYNAME\fP the user may also
|
|
||||||
add \fBCURLFORM_CONTENTSLENGTH\fP followed by the length as a long (if not
|
|
||||||
given the library will use strlen to determine the length).
|
|
||||||
|
|
||||||
For \fBCURLFORM_FILE\fP the user may send multiple files in one section by
|
|
||||||
providing multiple \fBCURLFORM_FILE\fP arguments each followed by the filename
|
|
||||||
(and each FILE is allowed to have a CONTENTTYPE).
|
|
||||||
|
|
||||||
Another possibility to send single or multiple files in one section is to use
|
|
||||||
\fBCURLFORM_ARRAY\fP that gets a struct curl_forms array pointer as its
|
|
||||||
value. Each structure element has a CURLformoption and a char pointer. For the
|
|
||||||
options only \fBCURLFORM_FILE\fP, \fBCURLFORM_CONTENTTYPE\fP, and
|
|
||||||
\fBCURLFORM_END\fP (that is used to determine the end of the array and thus
|
|
||||||
must be the option of the last and no other element of the curl_forms array)
|
|
||||||
are allowed. The effect of this parameter is the same as giving multiple
|
|
||||||
\fBCURLFORM_FILE\fP options possibly with \fBCURLFORM_CONTENTTYPE\fP after or
|
|
||||||
before each \fBCURLFORM_FILE\fP option.
|
|
||||||
|
|
||||||
Should you need to specify extra headers for the form POST section, use
|
|
||||||
\fBCURLFORM_CONTENTHEADER\fP. This takes a curl_slist prepared in the usual way
|
|
||||||
using \fBcurl_slist_append\fP and appends the list of headers to those Curl
|
|
||||||
automatically generates for \fBCURLFORM_CONTENTTYPE\fP and the content
|
|
||||||
disposition. The list must exist while the POST occurs, if you free it before
|
|
||||||
the post completes you may experience problems.
|
|
||||||
|
|
||||||
The last argument in such an array must always be \fBCURLFORM_END\fP.
|
|
||||||
|
|
||||||
The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to
|
|
||||||
NULL in the first call to this function. All list-data will be allocated by
|
|
||||||
the function itself. You must call \fIcurl_formfree\fP after the form post has
|
|
||||||
been done to free the resources again.
|
|
||||||
|
|
||||||
This function will copy all input data except the data pointed to by the
|
|
||||||
arguments after \fBCURLFORM_PTRNAME\fP and \fBCURLFORM_PTRCONTENTS\fP and keep
|
|
||||||
its own version of it allocated until you call \fIcurl_formfree\fP. When
|
|
||||||
you've passed the pointer to \fIcurl_easy_setopt\fP, you must not free the
|
|
||||||
list until after you've called \fIcurl_easy_cleanup\fP for the curl handle. If
|
|
||||||
you provide a pointer as an arguments after \fBCURLFORM_PTRNAME\fP or
|
|
||||||
\fBCURLFORM_PTRCONTENTS\fP you must ensure that the pointer stays valid until
|
|
||||||
you call \fIcurl_form_free\fP and \fIcurl_easy_cleanup\fP.
|
|
||||||
|
|
||||||
See example below.
|
|
||||||
.SH RETURN VALUE
|
|
||||||
Returns non-zero if an error occurs.
|
|
||||||
.SH EXAMPLE
|
|
||||||
.nf
|
|
||||||
|
|
||||||
HttpPost* post = NULL;
|
|
||||||
HttpPost* last = NULL;
|
|
||||||
char namebuffer[] = "name buffer";
|
|
||||||
long namelength = strlen(namebuffer);
|
|
||||||
char buffer[] = "test buffer";
|
|
||||||
char htmlbuffer[] = "<HTML>test buffer</HTML>";
|
|
||||||
long htmlbufferlength = strlen(htmlbuffer);
|
|
||||||
struct curl_forms forms[3];
|
|
||||||
char file1[] = "my-face.jpg";
|
|
||||||
char file2[] = "your-face.jpg";
|
|
||||||
/* add null character into htmlbuffer, to demonstrate that
|
|
||||||
transfers of buffers containing null characters actually work
|
|
||||||
*/
|
|
||||||
htmlbuffer[8] = '\\0';
|
|
||||||
|
|
||||||
/* Add simple name/content section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "name",
|
|
||||||
CURLFORM_COPYCONTENTS, "content", CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add simple name/content/contenttype section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "htmlcode",
|
|
||||||
CURLFORM_COPYCONTENTS, "<HTML></HTML>",
|
|
||||||
CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add name/ptrcontent section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "name_for_ptrcontent",
|
|
||||||
CURLFORM_PTRCONTENTS, buffer, CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add ptrname/ptrcontent section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_PTRNAME, namebuffer,
|
|
||||||
CURLFORM_PTRCONTENTS, buffer, CURLFORM_NAMELENGTH,
|
|
||||||
namelength, CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add name/ptrcontent/contenttype section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "html_code_with_hole",
|
|
||||||
CURLFORM_PTRCONTENTS, htmlbuffer,
|
|
||||||
CURLFORM_CONTENTSLENGTH, htmlbufferlength,
|
|
||||||
CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add simple file section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture",
|
|
||||||
CURLFORM_FILE, "my-face.jpg", CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add file/contenttype section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture",
|
|
||||||
CURLFORM_FILE, "my-face.jpg",
|
|
||||||
CURLFORM_CONTENTTYPE, "image/jpeg", CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add two file section */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
|
|
||||||
CURLFORM_FILE, "my-face.jpg",
|
|
||||||
CURLFORM_FILE, "your-face.jpg", CURLFORM_END);
|
|
||||||
|
|
||||||
/* Add two file section using CURLFORM_ARRAY */
|
|
||||||
forms[0].option = CURLFORM_FILE;
|
|
||||||
forms[0].value = file1;
|
|
||||||
forms[1].option = CURLFORM_FILE;
|
|
||||||
forms[1].value = file2;
|
|
||||||
forms[2].option = CURLFORM_END;
|
|
||||||
|
|
||||||
/* no option needed for the end marker */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
|
|
||||||
CURLFORM_ARRAY, forms, CURLFORM_END);
|
|
||||||
/* Add the content of a file as a normal post text value */
|
|
||||||
curl_formadd(&post, &last, CURLFORM_COPYNAME, "filecontent",
|
|
||||||
CURLFORM_FILECONTENT, ".bashrc", CURLFORM_END);
|
|
||||||
/* Set the form info */
|
|
||||||
curl_easy_setopt(curl, CURLOPT_HTTPPOST, post);
|
|
||||||
|
|
||||||
.SH "SEE ALSO"
|
|
||||||
.BR curl_easy_setopt "(3), "
|
|
||||||
.BR curl_formparse "(3) [deprecated], "
|
|
||||||
.BR curl_formfree "(3)"
|
|
||||||
.SH BUGS
|
|
||||||
Surely there are some, you tell me!
|
|
||||||
|
|
@@ -1,29 +0,0 @@
|
|||||||
.\" You can view this file with:
|
|
||||||
.\" nroff -man [file]
|
|
||||||
.\" $Id$
|
|
||||||
.\"
|
|
||||||
.TH curl_slist_append 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
|
||||||
.SH NAME
|
|
||||||
curl_slist_append - add a string to an slist
|
|
||||||
.SH SYNOPSIS
|
|
||||||
.B #include <curl/curl.h>
|
|
||||||
.sp
|
|
||||||
.BI "struct curl_slist *curl_slist_append(struct curl_slist *" list,
|
|
||||||
.BI "const char * "string ");"
|
|
||||||
.ad
|
|
||||||
.SH DESCRIPTION
|
|
||||||
curl_slist_append() appends a specified string to a linked list of
|
|
||||||
strings. The existing
|
|
||||||
.I list
|
|
||||||
should be passed as the first argument while the new list is returned from
|
|
||||||
this function. The specified
|
|
||||||
.I string
|
|
||||||
has been appended when this function returns.
|
|
||||||
.SH RETURN VALUE
|
|
||||||
A null pointer is returned if anything went wrong, otherwise the new list
|
|
||||||
pointer is returned.
|
|
||||||
.SH "SEE ALSO"
|
|
||||||
.BR curl_slist_free_all "(3), "
|
|
||||||
.SH BUGS
|
|
||||||
Surely there are some, you tell me!
|
|
||||||
|
|
2
docs/examples/.cvsignore
Normal file
2
docs/examples/.cvsignore
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Makefile
|
||||||
|
Makefile.in
|
@@ -4,10 +4,12 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit.c postit2.c \
|
EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c \
|
||||||
win32sockets.c persistant.c ftpget.c Makefile.example \
|
persistant.c ftpget.c Makefile.example \
|
||||||
multithread.c getinmemory.c ftpupload.c httpput.c \
|
multithread.c getinmemory.c ftpupload.c httpput.c \
|
||||||
simplessl.c
|
simplessl.c ftpgetresp.c http-post.c post-callback.c \
|
||||||
|
multi-app.c multi-double.c multi-single.c multi-post.c \
|
||||||
|
fopen.c simplepost.c makefile.dj
|
||||||
|
|
||||||
all:
|
all:
|
||||||
@echo "done"
|
@echo "done"
|
||||||
|
@@ -35,7 +35,7 @@ LIBS = -lcurl -lsocket -lnsl -lssl -lcrypto -dl
|
|||||||
|
|
||||||
# Link the target with all objects and libraries
|
# Link the target with all objects and libraries
|
||||||
$(TARGET) : $(OBJS)
|
$(TARGET) : $(OBJS)
|
||||||
$(CC) $(LDFLAGS) $(LIBS) -o $(TARGET) $(OBJS)
|
$(CC) -o $(TARGET) $(OBJS) $(LDFLAGS) $(LIBS)
|
||||||
|
|
||||||
# Compile the source files into object files
|
# Compile the source files into object files
|
||||||
ftpget.o : ftpget.c
|
ftpget.o : ftpget.c
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
EXAMPLES
|
EXAMPLES
|
||||||
|
|
||||||
This directory is for tiny libcurl programming examples. They are meant to
|
This directory is for libcurl programming examples. They are meant to show
|
||||||
show some simple steps on how you can build your own application to take full
|
some simple steps on how you can build your own application to take full
|
||||||
advantage of libcurl.
|
advantage of libcurl.
|
||||||
|
|
||||||
If you end up with other small but still useful example sources, please mail
|
If you end up with other small but still useful example sources, please mail
|
||||||
@@ -10,9 +10,16 @@ them for submission in future packages and on the web site.
|
|||||||
The Makefile.example is an example makefile that could be used to build these
|
The Makefile.example is an example makefile that could be used to build these
|
||||||
examples. Just edit the file according to your system and requirements first.
|
examples. Just edit the file according to your system and requirements first.
|
||||||
|
|
||||||
Try the php/examples/ directory for PHP programming snippets!
|
Most examples should build fine using a command line like this:
|
||||||
|
|
||||||
*PLEASE* do not use the curl.haxx.se site as a test target for your libcurl
|
$ `curl-config --cc --cflags --libs` -o example example.c
|
||||||
applications/experiments. Even if the examples in this directory use that
|
|
||||||
site as an example URL at some places, it doesn't mean that the URLs work or
|
Some compilers don't like having the arguments in this order but instead
|
||||||
that we expect you to actually torture our web site with your tests! Thanks.
|
want you do reorganize them like:
|
||||||
|
|
||||||
|
$ `curl-config --cc` -o example example.c `curl-config --cflags --libs`
|
||||||
|
|
||||||
|
*PLEASE* do not use the curl.haxx.se site as a test target for your libcurl
|
||||||
|
applications/experiments. Even if the examples in this directory use that site
|
||||||
|
as an example URL at some places, it doesn't mean that the URLs work or that
|
||||||
|
we expect you to actually torture our web site with your tests! Thanks.
|
||||||
|
@@ -26,7 +26,11 @@ size_t my_read_func(void *ptr, size_t size, size_t nmemb, FILE *stream)
|
|||||||
return fread(ptr, size, nmemb, stream);
|
return fread(ptr, size, nmemb, stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
int my_progress_func(GtkWidget *Bar, int t, int d)
|
int my_progress_func(GtkWidget *Bar,
|
||||||
|
double t, /* dltotal */
|
||||||
|
double d, /* dlnow */
|
||||||
|
double ultotal,
|
||||||
|
double ulnow)
|
||||||
{
|
{
|
||||||
/* printf("%d / %d (%g %%)\n", d, t, d*100.0/t);*/
|
/* printf("%d / %d (%g %%)\n", d, t, d*100.0/t);*/
|
||||||
gdk_threads_enter();
|
gdk_threads_enter();
|
||||||
@@ -50,6 +54,7 @@ void *curl_thread(void *ptr)
|
|||||||
curl_easy_setopt(curl, CURLOPT_URL, url);
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
curl_easy_setopt(curl, CURLOPT_FILE, outfile);
|
curl_easy_setopt(curl, CURLOPT_FILE, outfile);
|
||||||
curl_easy_setopt(curl, CURLOPT_READFUNCTION, my_read_func);
|
curl_easy_setopt(curl, CURLOPT_READFUNCTION, my_read_func);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_NOPROGRESS, FALSE);
|
||||||
curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, my_progress_func);
|
curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, my_progress_func);
|
||||||
curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, Bar);
|
curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, Bar);
|
||||||
|
|
||||||
|
565
docs/examples/fopen.c
Normal file
565
docs/examples/fopen.c
Normal file
@@ -0,0 +1,565 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
*
|
||||||
|
* This example source code introduces a c library buffered I/O interface to
|
||||||
|
* URL reads it supports fopen(), fread(), fgets(), feof(), fclose(),
|
||||||
|
* rewind(). Supported functions have identical prototypes to their normal c
|
||||||
|
* lib namesakes and are preceaded by url_ .
|
||||||
|
*
|
||||||
|
* Using this code you can replace your program's fopen() with url_fopen()
|
||||||
|
* and fread() with url_fread() and it become possible to read remote streams
|
||||||
|
* instead of (only) local files. Local files (ie those that can be directly
|
||||||
|
* fopened) will drop back to using the underlying clib implementations
|
||||||
|
*
|
||||||
|
* See the main() function at the bottom that shows an app that retrives from a
|
||||||
|
* specified url using fgets() and fread() and saves as two output files.
|
||||||
|
*
|
||||||
|
* Coyright (c)2003 Simtec Electronics
|
||||||
|
*
|
||||||
|
* Re-implemented by Vincent Sanders <vince@kyllikki.org> with extensive
|
||||||
|
* reference to original curl example code
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||||||
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||||
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||||
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||||
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||||
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This example requires libcurl 7.9.7 or later.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
#if (LIBCURL_VERSION_NUM < 0x070907)
|
||||||
|
#error "too old libcurl version, get the latest!"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
enum fcurl_type_e { CFTYPE_NONE=0, CFTYPE_FILE=1, CFTYPE_CURL=2 };
|
||||||
|
|
||||||
|
struct fcurl_data
|
||||||
|
{
|
||||||
|
enum fcurl_type_e type; /* type of handle */
|
||||||
|
union {
|
||||||
|
CURL *curl;
|
||||||
|
FILE *file;
|
||||||
|
} handle; /* handle */
|
||||||
|
|
||||||
|
char *buffer; /* buffer to store cached data*/
|
||||||
|
int buffer_len; /* currently allocated buffers length */
|
||||||
|
int buffer_pos; /* end of data in buffer*/
|
||||||
|
int still_running; /* Is background url fetch still in progress */
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct fcurl_data URL_FILE;
|
||||||
|
|
||||||
|
/* exported functions */
|
||||||
|
URL_FILE *url_fopen(char *url,const char *operation);
|
||||||
|
int url_fclose(URL_FILE *file);
|
||||||
|
int url_feof(URL_FILE *file);
|
||||||
|
size_t url_fread(void *ptr, size_t size, size_t nmemb, URL_FILE *file);
|
||||||
|
char * url_fgets(char *ptr, int size, URL_FILE *file);
|
||||||
|
void url_rewind(URL_FILE *file);
|
||||||
|
|
||||||
|
/* we use a global one for convenience */
|
||||||
|
CURLM *multi_handle;
|
||||||
|
|
||||||
|
/* curl calls this routine to get more data */
|
||||||
|
static size_t
|
||||||
|
write_callback(char *buffer,
|
||||||
|
size_t size,
|
||||||
|
size_t nitems,
|
||||||
|
void *userp)
|
||||||
|
{
|
||||||
|
char *newbuff;
|
||||||
|
int rembuff;
|
||||||
|
|
||||||
|
URL_FILE *url = (URL_FILE *)userp;
|
||||||
|
size *= nitems;
|
||||||
|
|
||||||
|
rembuff=url->buffer_len - url->buffer_pos;//remaining space in buffer
|
||||||
|
|
||||||
|
if(size > rembuff)
|
||||||
|
{
|
||||||
|
//not enuf space in buffer
|
||||||
|
newbuff=realloc(url->buffer,url->buffer_len + (size - rembuff));
|
||||||
|
if(newbuff==NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr,"callback buffer grow failed\n");
|
||||||
|
size=rembuff;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* realloc suceeded increase buffer size*/
|
||||||
|
url->buffer_len+=size - rembuff;
|
||||||
|
url->buffer=newbuff;
|
||||||
|
|
||||||
|
/*printf("Callback buffer grown to %d bytes\n",url->buffer_len);*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(&url->buffer[url->buffer_pos], buffer, size);
|
||||||
|
url->buffer_pos += size;
|
||||||
|
|
||||||
|
/*fprintf(stderr, "callback %d size bytes\n", size);*/
|
||||||
|
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* use to attempt to fill the read buffer up to requested number of bytes */
|
||||||
|
static int
|
||||||
|
curl_fill_buffer(URL_FILE *file,int want,int waittime)
|
||||||
|
{
|
||||||
|
fd_set fdread;
|
||||||
|
fd_set fdwrite;
|
||||||
|
fd_set fdexcep;
|
||||||
|
int maxfd;
|
||||||
|
struct timeval timeout;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
/* only attempt to fill buffer if transactions still running and buffer
|
||||||
|
* doesnt exceed required size already
|
||||||
|
*/
|
||||||
|
if((!file->still_running) || (file->buffer_pos > want))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* attempt to fill buffer */
|
||||||
|
do
|
||||||
|
{
|
||||||
|
FD_ZERO(&fdread);
|
||||||
|
FD_ZERO(&fdwrite);
|
||||||
|
FD_ZERO(&fdexcep);
|
||||||
|
|
||||||
|
/* set a suitable timeout to fail on */
|
||||||
|
timeout.tv_sec = 60; /* 1 minute */
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
/* get file descriptors from the transfers */
|
||||||
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
|
switch(rc) {
|
||||||
|
case -1:
|
||||||
|
/* select error */
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
/* timeout or readable/writable sockets */
|
||||||
|
/* note we *could* be more efficient and not wait for
|
||||||
|
* CURLM_CALL_MULTI_PERFORM to clear here and check it on re-entry
|
||||||
|
* but that gets messy */
|
||||||
|
while(curl_multi_perform(multi_handle, &file->still_running) ==
|
||||||
|
CURLM_CALL_MULTI_PERFORM);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} while(file->still_running && (file->buffer_pos < want));
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* use to remove want bytes from the front of a files buffer */
|
||||||
|
static int
|
||||||
|
curl_use_buffer(URL_FILE *file,int want)
|
||||||
|
{
|
||||||
|
/* sort out buffer */
|
||||||
|
if((file->buffer_pos - want) <=0)
|
||||||
|
{
|
||||||
|
/* ditch buffer - write will recreate */
|
||||||
|
if(file->buffer)
|
||||||
|
free(file->buffer);
|
||||||
|
|
||||||
|
file->buffer=NULL;
|
||||||
|
file->buffer_pos=0;
|
||||||
|
file->buffer_len=0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* move rest down make it available for later */
|
||||||
|
memmove(file->buffer,
|
||||||
|
&file->buffer[want],
|
||||||
|
(file->buffer_pos - want));
|
||||||
|
|
||||||
|
file->buffer_pos -= want;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
URL_FILE *
|
||||||
|
url_fopen(char *url,const char *operation)
|
||||||
|
{
|
||||||
|
/* this code could check for URLs or types in the 'url' and
|
||||||
|
basicly use the real fopen() for standard files */
|
||||||
|
|
||||||
|
URL_FILE *file;
|
||||||
|
(void)operation;
|
||||||
|
|
||||||
|
file = (URL_FILE *)malloc(sizeof(URL_FILE));
|
||||||
|
if(!file)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
memset(file, 0, sizeof(URL_FILE));
|
||||||
|
|
||||||
|
if((file->handle.file=fopen(url,operation)))
|
||||||
|
{
|
||||||
|
file->type = CFTYPE_FILE; /* marked as URL */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
file->type = CFTYPE_CURL; /* marked as URL */
|
||||||
|
file->handle.curl = curl_easy_init();
|
||||||
|
|
||||||
|
curl_easy_setopt(file->handle.curl, CURLOPT_URL, url);
|
||||||
|
curl_easy_setopt(file->handle.curl, CURLOPT_FILE, file);
|
||||||
|
curl_easy_setopt(file->handle.curl, CURLOPT_VERBOSE, FALSE);
|
||||||
|
curl_easy_setopt(file->handle.curl, CURLOPT_WRITEFUNCTION, write_callback);
|
||||||
|
|
||||||
|
if(!multi_handle)
|
||||||
|
multi_handle = curl_multi_init();
|
||||||
|
|
||||||
|
curl_multi_add_handle(multi_handle, file->handle.curl);
|
||||||
|
|
||||||
|
/* lets start the fetch */
|
||||||
|
while(curl_multi_perform(multi_handle, &file->still_running) ==
|
||||||
|
CURLM_CALL_MULTI_PERFORM );
|
||||||
|
|
||||||
|
if((file->buffer_pos == 0) && (!file->still_running))
|
||||||
|
{
|
||||||
|
/* if still_running is 0 now, we should return NULL */
|
||||||
|
|
||||||
|
/* make sure the easy handle is not in the multi handle anymore */
|
||||||
|
curl_multi_remove_handle(multi_handle, file->handle.curl);
|
||||||
|
|
||||||
|
/* cleanup */
|
||||||
|
curl_easy_cleanup(file->handle.curl);
|
||||||
|
|
||||||
|
free(file);
|
||||||
|
|
||||||
|
file = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
url_fclose(URL_FILE *file)
|
||||||
|
{
|
||||||
|
int ret=0;/* default is good return */
|
||||||
|
|
||||||
|
switch(file->type)
|
||||||
|
{
|
||||||
|
case CFTYPE_FILE:
|
||||||
|
ret=fclose(file->handle.file); /* passthrough */
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CFTYPE_CURL:
|
||||||
|
/* make sure the easy handle is not in the multi handle anymore */
|
||||||
|
curl_multi_remove_handle(multi_handle, file->handle.curl);
|
||||||
|
|
||||||
|
/* cleanup */
|
||||||
|
curl_easy_cleanup(file->handle.curl);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: /* unknown or supported type - oh dear */
|
||||||
|
ret=EOF;
|
||||||
|
errno=EBADF;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(file->buffer)
|
||||||
|
free(file->buffer);/* free any allocated buffer space */
|
||||||
|
|
||||||
|
free(file);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
url_feof(URL_FILE *file)
|
||||||
|
{
|
||||||
|
int ret=0;
|
||||||
|
|
||||||
|
switch(file->type)
|
||||||
|
{
|
||||||
|
case CFTYPE_FILE:
|
||||||
|
ret=feof(file->handle.file);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CFTYPE_CURL:
|
||||||
|
if((file->buffer_pos == 0) && (!file->still_running))
|
||||||
|
ret = 1;
|
||||||
|
break;
|
||||||
|
default: /* unknown or supported type - oh dear */
|
||||||
|
ret=-1;
|
||||||
|
errno=EBADF;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t
|
||||||
|
url_fread(void *ptr, size_t size, size_t nmemb, URL_FILE *file)
|
||||||
|
{
|
||||||
|
size_t want;
|
||||||
|
|
||||||
|
switch(file->type)
|
||||||
|
{
|
||||||
|
case CFTYPE_FILE:
|
||||||
|
want=fread(ptr,size,nmemb,file->handle.file);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CFTYPE_CURL:
|
||||||
|
want = nmemb * size;
|
||||||
|
|
||||||
|
curl_fill_buffer(file,want,1);
|
||||||
|
|
||||||
|
/* check if theres data in the buffer - if not curl_fill_buffer()
|
||||||
|
* either errored or EOF */
|
||||||
|
if(!file->buffer_pos)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* ensure only available data is considered */
|
||||||
|
if(file->buffer_pos < want)
|
||||||
|
want = file->buffer_pos;
|
||||||
|
|
||||||
|
/* xfer data to caller */
|
||||||
|
memcpy(ptr, file->buffer, want);
|
||||||
|
|
||||||
|
curl_use_buffer(file,want);
|
||||||
|
|
||||||
|
want = want / size; /* number of items - nb correct op - checked
|
||||||
|
* with glibc code*/
|
||||||
|
|
||||||
|
/*printf("(fread) return %d bytes %d left\n", want,file->buffer_pos);*/
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: /* unknown or supported type - oh dear */
|
||||||
|
want=0;
|
||||||
|
errno=EBADF;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
return want;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
url_fgets(char *ptr, int size, URL_FILE *file)
|
||||||
|
{
|
||||||
|
int want = size - 1;/* always need to leave room for zero termination */
|
||||||
|
int loop;
|
||||||
|
|
||||||
|
switch(file->type)
|
||||||
|
{
|
||||||
|
case CFTYPE_FILE:
|
||||||
|
ptr = fgets(ptr,size,file->handle.file);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CFTYPE_CURL:
|
||||||
|
curl_fill_buffer(file,want,1);
|
||||||
|
|
||||||
|
/* check if theres data in the buffer - if not fill either errored or
|
||||||
|
* EOF */
|
||||||
|
if(!file->buffer_pos)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
/* ensure only available data is considered */
|
||||||
|
if(file->buffer_pos < want)
|
||||||
|
want = file->buffer_pos;
|
||||||
|
|
||||||
|
/*buffer contains data */
|
||||||
|
/* look for newline or eof */
|
||||||
|
for(loop=0;loop < want;loop++)
|
||||||
|
{
|
||||||
|
if(file->buffer[loop] == '\n')
|
||||||
|
{
|
||||||
|
want=loop+1;/* include newline */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* xfer data to caller */
|
||||||
|
memcpy(ptr, file->buffer, want);
|
||||||
|
ptr[want]=0;/* allways null terminate */
|
||||||
|
|
||||||
|
curl_use_buffer(file,want);
|
||||||
|
|
||||||
|
/*printf("(fgets) return %d bytes %d left\n", want,file->buffer_pos);*/
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: /* unknown or supported type - oh dear */
|
||||||
|
ptr=NULL;
|
||||||
|
errno=EBADF;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ptr;/*success */
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
url_rewind(URL_FILE *file)
|
||||||
|
{
|
||||||
|
switch(file->type)
|
||||||
|
{
|
||||||
|
case CFTYPE_FILE:
|
||||||
|
rewind(file->handle.file); /* passthrough */
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CFTYPE_CURL:
|
||||||
|
/* halt transaction */
|
||||||
|
curl_multi_remove_handle(multi_handle, file->handle.curl);
|
||||||
|
|
||||||
|
/* restart */
|
||||||
|
curl_multi_add_handle(multi_handle, file->handle.curl);
|
||||||
|
|
||||||
|
/* ditch buffer - write will recreate - resets stream pos*/
|
||||||
|
if(file->buffer)
|
||||||
|
free(file->buffer);
|
||||||
|
|
||||||
|
file->buffer=NULL;
|
||||||
|
file->buffer_pos=0;
|
||||||
|
file->buffer_len=0;
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: /* unknown or supported type - oh dear */
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Small main program to retrive from a url using fgets and fread saving the
|
||||||
|
* output to two test files (note the fgets method will corrupt binary files if
|
||||||
|
* they contain 0 chars */
|
||||||
|
int
|
||||||
|
main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
URL_FILE *handle;
|
||||||
|
FILE *outf;
|
||||||
|
|
||||||
|
int nread;
|
||||||
|
char buffer[256];
|
||||||
|
char *url;
|
||||||
|
|
||||||
|
if(argc < 2)
|
||||||
|
{
|
||||||
|
url="http://192.168.7.3/testfile";/* default to testurl */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
url=argv[1];/* use passed url */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* copy from url line by line with fgets */
|
||||||
|
outf=fopen("fgets.test","w+");
|
||||||
|
if(!outf)
|
||||||
|
{
|
||||||
|
perror("couldnt open fgets output file\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
handle = url_fopen(url, "r");
|
||||||
|
if(!handle)
|
||||||
|
{
|
||||||
|
printf("couldn't url_fopen()\n");
|
||||||
|
fclose(outf);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
while(!url_feof(handle))
|
||||||
|
{
|
||||||
|
url_fgets(buffer,sizeof(buffer),handle);
|
||||||
|
fwrite(buffer,1,strlen(buffer),outf);
|
||||||
|
}
|
||||||
|
|
||||||
|
url_fclose(handle);
|
||||||
|
|
||||||
|
fclose(outf);
|
||||||
|
|
||||||
|
|
||||||
|
/* Copy from url with fread */
|
||||||
|
outf=fopen("fread.test","w+");
|
||||||
|
if(!outf)
|
||||||
|
{
|
||||||
|
perror("couldnt open fread output file\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
handle = url_fopen("testfile", "r");
|
||||||
|
if(!handle) {
|
||||||
|
printf("couldn't url_fopen()\n");
|
||||||
|
fclose(outf);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
do {
|
||||||
|
nread = url_fread(buffer, 1,sizeof(buffer), handle);
|
||||||
|
fwrite(buffer,1,nread,outf);
|
||||||
|
} while(nread);
|
||||||
|
|
||||||
|
url_fclose(handle);
|
||||||
|
|
||||||
|
fclose(outf);
|
||||||
|
|
||||||
|
|
||||||
|
/* Test rewind */
|
||||||
|
outf=fopen("rewind.test","w+");
|
||||||
|
if(!outf)
|
||||||
|
{
|
||||||
|
perror("couldnt open fread output file\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
handle = url_fopen("testfile", "r");
|
||||||
|
if(!handle) {
|
||||||
|
printf("couldn't url_fopen()\n");
|
||||||
|
fclose(outf);
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
nread = url_fread(buffer, 1,sizeof(buffer), handle);
|
||||||
|
fwrite(buffer,1,nread,outf);
|
||||||
|
url_rewind(handle);
|
||||||
|
|
||||||
|
buffer[0]='\n';
|
||||||
|
fwrite(buffer,1,1,outf);
|
||||||
|
|
||||||
|
nread = url_fread(buffer, 1,sizeof(buffer), handle);
|
||||||
|
fwrite(buffer,1,nread,outf);
|
||||||
|
|
||||||
|
|
||||||
|
url_fclose(handle);
|
||||||
|
|
||||||
|
fclose(outf);
|
||||||
|
|
||||||
|
|
||||||
|
return 0;/* all done */
|
||||||
|
}
|
@@ -14,31 +14,70 @@
|
|||||||
#include <curl/types.h>
|
#include <curl/types.h>
|
||||||
#include <curl/easy.h>
|
#include <curl/easy.h>
|
||||||
|
|
||||||
/* to make this work under windows, use the win32-functions from the
|
/*
|
||||||
win32socket.c file as well */
|
* This is an example showing how to get a single file from an FTP server.
|
||||||
|
* It delays the actual destination file creation until the first write
|
||||||
|
* callback so that it won't create an empty file in case the remote file
|
||||||
|
* doesn't exist or something else fails.
|
||||||
|
*/
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
struct FtpFile {
|
||||||
|
char *filename;
|
||||||
|
FILE *stream;
|
||||||
|
};
|
||||||
|
|
||||||
|
int my_fwrite(void *buffer, size_t size, size_t nmemb, void *stream)
|
||||||
|
{
|
||||||
|
struct FtpFile *out=(struct FtpFile *)stream;
|
||||||
|
if(out && !out->stream) {
|
||||||
|
/* open file for writing */
|
||||||
|
out->stream=fopen(out->filename, "wb");
|
||||||
|
if(!out->stream)
|
||||||
|
return -1; /* failure, can't open file to write */
|
||||||
|
}
|
||||||
|
return fwrite(buffer, size, nmemb, out->stream);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(void)
|
||||||
{
|
{
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
FILE *ftpfile;
|
struct FtpFile ftpfile={
|
||||||
|
"curl.tar.gz", /* name to store the file as if succesful */
|
||||||
/* local file name to store the file as */
|
NULL
|
||||||
ftpfile = fopen("curl.tar.gz", "wb"); /* b is binary for win */
|
};
|
||||||
|
|
||||||
|
curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* Get curl 7.7 from sunet.se's FTP site: */
|
/* Get curl 7.9.2 from sunet.se's FTP site: */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL,
|
curl_easy_setopt(curl, CURLOPT_URL,
|
||||||
"ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.7.tar.gz");
|
"ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz");
|
||||||
curl_easy_setopt(curl, CURLOPT_FILE, ftpfile);
|
/* Define our callback to get called when there's data to be written */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, my_fwrite);
|
||||||
|
/* Set a pointer to our struct to pass to the callback */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FILE, &ftpfile);
|
||||||
|
|
||||||
|
/* Switch on full protocol/debug output */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, TRUE);
|
||||||
|
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
curl_easy_cleanup(curl);
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
if(CURLE_OK != res) {
|
||||||
|
/* we failed */
|
||||||
|
fprintf(stderr, "curl told us %d\n", res);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fclose(ftpfile); /* close the local file */
|
if(ftpfile.stream)
|
||||||
|
fclose(ftpfile.stream); /* close the local file */
|
||||||
|
|
||||||
|
curl_global_cleanup();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
61
docs/examples/ftpgetresp.c
Normal file
61
docs/examples/ftpgetresp.c
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Similar to ftpget.c but this also stores the received response-lines
|
||||||
|
* in a separate file using our own callback!
|
||||||
|
*
|
||||||
|
* This functionality was introduced in libcurl 7.9.3.
|
||||||
|
*/
|
||||||
|
|
||||||
|
size_t
|
||||||
|
write_response(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
|
{
|
||||||
|
FILE *writehere = (FILE *)data;
|
||||||
|
return fwrite(ptr, size, nmemb, writehere);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
FILE *ftpfile;
|
||||||
|
FILE *respfile;
|
||||||
|
|
||||||
|
/* local file name to store the file as */
|
||||||
|
ftpfile = fopen("ftp-list", "wb"); /* b is binary, needed on win32 */
|
||||||
|
|
||||||
|
/* local file name to store the FTP server's response lines in */
|
||||||
|
respfile = fopen("ftp-responses", "wb"); /* b is binary, needed on win32 */
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* Get a file listing from sunet */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "ftp://ftp.sunet.se/");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FILE, ftpfile);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, write_response);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, respfile);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose(ftpfile); /* close the local file */
|
||||||
|
fclose(respfile); /* close the response file */
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -11,6 +11,9 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This example shows an FTP upload, with a rename of the file just after
|
* This example shows an FTP upload, with a rename of the file just after
|
||||||
|
@@ -74,6 +74,10 @@ int main(int argc, char **argv)
|
|||||||
* bytes big and contains the remote file.
|
* bytes big and contains the remote file.
|
||||||
*
|
*
|
||||||
* Do something nice with it!
|
* Do something nice with it!
|
||||||
|
*
|
||||||
|
* You should be aware of the fact that at this point we might have an
|
||||||
|
* allocated data block, and nothing has yet deallocated that data. So when
|
||||||
|
* you're done with it, you should free() it as a nice application.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
35
docs/examples/http-post.c
Normal file
35
docs/examples/http-post.c
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* First set the URL that is about to receive our POST. This URL can
|
||||||
|
just as well be a https:// URL if that is what should receive the
|
||||||
|
data. */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://postit.example.com/moo.cgi");
|
||||||
|
/* Now specify the POST data */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, "name=daniel&project=curl");
|
||||||
|
|
||||||
|
/* Perform the request, res will get the return code */
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
31
docs/examples/makefile.dj
Normal file
31
docs/examples/makefile.dj
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
#
|
||||||
|
# Adapted for djgpp / Watt-32 / DOS by
|
||||||
|
# Gisle Vanem <giva@bgnett.no>
|
||||||
|
#
|
||||||
|
|
||||||
|
include ../../packages/DOS/common.dj
|
||||||
|
|
||||||
|
CFLAGS += -I../../include
|
||||||
|
|
||||||
|
LIBS = ../../lib/libcurl.a
|
||||||
|
|
||||||
|
ifeq ($(USE_SSL),1)
|
||||||
|
LIBS += $(OPENSSL_ROOT)/lib/libssl.a $(OPENSSL_ROOT)/lib/libcrypt.a
|
||||||
|
endif
|
||||||
|
|
||||||
|
LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a
|
||||||
|
|
||||||
|
PROGRAMS = fopen.exe ftpget.exe ftpgetre.exe ftpuploa.exe getinmem.exe \
|
||||||
|
http-pos.exe httpput.exe multi-ap.exe multi-do.exe \
|
||||||
|
multi-po.exe multi-si.exe persista.exe post-cal.exe \
|
||||||
|
postit2.exe sepheade.exe simple.exe simpless.exe
|
||||||
|
|
||||||
|
all: $(PROGRAMS)
|
||||||
|
|
||||||
|
.c.exe:
|
||||||
|
$(CC) $(CFLAGS) -o $@ $^ $(LIBS)
|
||||||
|
@echo
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f $(PROGRAMS)
|
||||||
|
|
99
docs/examples/multi-app.c
Normal file
99
docs/examples/multi-app.c
Normal file
@@ -0,0 +1,99 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* This is an example application source code using the multi interface.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* somewhat unix-specific */
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
/* curl stuff */
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Download a HTTP file and upload an FTP file simultaneously.
|
||||||
|
*/
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *http_handle;
|
||||||
|
CURL *ftp_handle;
|
||||||
|
CURLM *multi_handle;
|
||||||
|
|
||||||
|
int still_running; /* keep number of running handles */
|
||||||
|
|
||||||
|
http_handle = curl_easy_init();
|
||||||
|
ftp_handle = curl_easy_init();
|
||||||
|
|
||||||
|
/* set the options (I left out a few, you'll get the point anyway) */
|
||||||
|
curl_easy_setopt(http_handle, CURLOPT_URL, "http://website.com");
|
||||||
|
|
||||||
|
curl_easy_setopt(ftp_handle, CURLOPT_URL, "ftp://ftpsite.com");
|
||||||
|
curl_easy_setopt(ftp_handle, CURLOPT_UPLOAD, TRUE);
|
||||||
|
|
||||||
|
/* init a multi stack */
|
||||||
|
multi_handle = curl_multi_init();
|
||||||
|
|
||||||
|
/* add the individual transfers */
|
||||||
|
curl_multi_add_handle(multi_handle, http_handle);
|
||||||
|
curl_multi_add_handle(multi_handle, ftp_handle);
|
||||||
|
|
||||||
|
/* we start some action by calling perform right away */
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
|
||||||
|
while(still_running) {
|
||||||
|
struct timeval timeout;
|
||||||
|
int rc; /* select() return code */
|
||||||
|
|
||||||
|
fd_set fdread;
|
||||||
|
fd_set fdwrite;
|
||||||
|
fd_set fdexcep;
|
||||||
|
int maxfd;
|
||||||
|
|
||||||
|
FD_ZERO(&fdread);
|
||||||
|
FD_ZERO(&fdwrite);
|
||||||
|
FD_ZERO(&fdexcep);
|
||||||
|
|
||||||
|
/* set a suitable timeout to play around with */
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
/* get file descriptors from the transfers */
|
||||||
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
|
switch(rc) {
|
||||||
|
case -1:
|
||||||
|
/* select error */
|
||||||
|
break;
|
||||||
|
case 0:
|
||||||
|
/* timeout, do something else */
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* one or more of curl's file descriptors say there's data to read
|
||||||
|
or write */
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_multi_cleanup(multi_handle);
|
||||||
|
|
||||||
|
curl_easy_cleanup(http_handle);
|
||||||
|
curl_easy_cleanup(ftp_handle);
|
||||||
|
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
95
docs/examples/multi-double.c
Normal file
95
docs/examples/multi-double.c
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* This is a very simple example using the multi interface.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* somewhat unix-specific */
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
/* curl stuff */
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Simply download two HTTP files!
|
||||||
|
*/
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *http_handle;
|
||||||
|
CURL *http_handle2;
|
||||||
|
CURLM *multi_handle;
|
||||||
|
|
||||||
|
int still_running; /* keep number of running handles */
|
||||||
|
|
||||||
|
http_handle = curl_easy_init();
|
||||||
|
http_handle2 = curl_easy_init();
|
||||||
|
|
||||||
|
/* set options */
|
||||||
|
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.haxx.se/");
|
||||||
|
|
||||||
|
/* set options */
|
||||||
|
curl_easy_setopt(http_handle2, CURLOPT_URL, "http://localhost/");
|
||||||
|
|
||||||
|
/* init a multi stack */
|
||||||
|
multi_handle = curl_multi_init();
|
||||||
|
|
||||||
|
/* add the individual transfers */
|
||||||
|
curl_multi_add_handle(multi_handle, http_handle);
|
||||||
|
curl_multi_add_handle(multi_handle, http_handle2);
|
||||||
|
|
||||||
|
/* we start some action by calling perform right away */
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
|
||||||
|
while(still_running) {
|
||||||
|
struct timeval timeout;
|
||||||
|
int rc; /* select() return code */
|
||||||
|
|
||||||
|
fd_set fdread;
|
||||||
|
fd_set fdwrite;
|
||||||
|
fd_set fdexcep;
|
||||||
|
int maxfd;
|
||||||
|
|
||||||
|
FD_ZERO(&fdread);
|
||||||
|
FD_ZERO(&fdwrite);
|
||||||
|
FD_ZERO(&fdexcep);
|
||||||
|
|
||||||
|
/* set a suitable timeout to play around with */
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
/* get file descriptors from the transfers */
|
||||||
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
|
switch(rc) {
|
||||||
|
case -1:
|
||||||
|
/* select error */
|
||||||
|
break;
|
||||||
|
case 0:
|
||||||
|
default:
|
||||||
|
/* timeout or readable/writable sockets */
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_multi_cleanup(multi_handle);
|
||||||
|
|
||||||
|
curl_easy_cleanup(http_handle);
|
||||||
|
curl_easy_cleanup(http_handle2);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
126
docs/examples/multi-post.c
Normal file
126
docs/examples/multi-post.c
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* This is an example application source code using the multi interface
|
||||||
|
* to do a multipart formpost without "blocking".
|
||||||
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
CURLM *multi_handle;
|
||||||
|
int still_running;
|
||||||
|
|
||||||
|
struct HttpPost *formpost=NULL;
|
||||||
|
struct HttpPost *lastptr=NULL;
|
||||||
|
struct curl_slist *headerlist=NULL;
|
||||||
|
char buf[] = "Expect:";
|
||||||
|
|
||||||
|
/* Fill in the file upload field */
|
||||||
|
curl_formadd(&formpost,
|
||||||
|
&lastptr,
|
||||||
|
CURLFORM_COPYNAME, "sendfile",
|
||||||
|
CURLFORM_FILE, "postit2.c",
|
||||||
|
CURLFORM_END);
|
||||||
|
|
||||||
|
/* Fill in the filename field */
|
||||||
|
curl_formadd(&formpost,
|
||||||
|
&lastptr,
|
||||||
|
CURLFORM_COPYNAME, "filename",
|
||||||
|
CURLFORM_COPYCONTENTS, "postit2.c",
|
||||||
|
CURLFORM_END);
|
||||||
|
|
||||||
|
|
||||||
|
/* Fill in the submit field too, even if this is rarely needed */
|
||||||
|
curl_formadd(&formpost,
|
||||||
|
&lastptr,
|
||||||
|
CURLFORM_COPYNAME, "submit",
|
||||||
|
CURLFORM_COPYCONTENTS, "send",
|
||||||
|
CURLFORM_END);
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
multi_handle = curl_multi_init();
|
||||||
|
|
||||||
|
/* initalize custom header list (stating that Expect: 100-continue is not
|
||||||
|
wanted */
|
||||||
|
headerlist = curl_slist_append(headerlist, buf);
|
||||||
|
if(curl && multi_handle) {
|
||||||
|
int perform=0;
|
||||||
|
|
||||||
|
/* what URL that receives this POST */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL,
|
||||||
|
"http://www.fillinyoururl.com/upload.cgi");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost);
|
||||||
|
|
||||||
|
curl_multi_add_handle(multi_handle, curl);
|
||||||
|
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
|
||||||
|
while(still_running) {
|
||||||
|
struct timeval timeout;
|
||||||
|
int rc; /* select() return code */
|
||||||
|
|
||||||
|
fd_set fdread;
|
||||||
|
fd_set fdwrite;
|
||||||
|
fd_set fdexcep;
|
||||||
|
int maxfd;
|
||||||
|
|
||||||
|
FD_ZERO(&fdread);
|
||||||
|
FD_ZERO(&fdwrite);
|
||||||
|
FD_ZERO(&fdexcep);
|
||||||
|
|
||||||
|
/* set a suitable timeout to play around with */
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
/* get file descriptors from the transfers */
|
||||||
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
|
switch(rc) {
|
||||||
|
case -1:
|
||||||
|
/* select error */
|
||||||
|
break;
|
||||||
|
case 0:
|
||||||
|
printf("timeout!\n");
|
||||||
|
default:
|
||||||
|
/* timeout or readable/writable sockets */
|
||||||
|
printf("perform!\n");
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
printf("running: %d!\n", still_running);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_multi_cleanup(multi_handle);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
/* then cleanup the formpost chain */
|
||||||
|
curl_formfree(formpost);
|
||||||
|
|
||||||
|
/* free slist */
|
||||||
|
curl_slist_free_all (headerlist);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
88
docs/examples/multi-single.c
Normal file
88
docs/examples/multi-single.c
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* This is a very simple example using the multi interface.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* somewhat unix-specific */
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
/* curl stuff */
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Simply download a HTTP file.
|
||||||
|
*/
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *http_handle;
|
||||||
|
CURLM *multi_handle;
|
||||||
|
|
||||||
|
int still_running; /* keep number of running handles */
|
||||||
|
|
||||||
|
http_handle = curl_easy_init();
|
||||||
|
|
||||||
|
/* set the options (I left out a few, you'll get the point anyway) */
|
||||||
|
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.haxx.se/");
|
||||||
|
|
||||||
|
/* init a multi stack */
|
||||||
|
multi_handle = curl_multi_init();
|
||||||
|
|
||||||
|
/* add the individual transfers */
|
||||||
|
curl_multi_add_handle(multi_handle, http_handle);
|
||||||
|
|
||||||
|
/* we start some action by calling perform right away */
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
|
||||||
|
while(still_running) {
|
||||||
|
struct timeval timeout;
|
||||||
|
int rc; /* select() return code */
|
||||||
|
|
||||||
|
fd_set fdread;
|
||||||
|
fd_set fdwrite;
|
||||||
|
fd_set fdexcep;
|
||||||
|
int maxfd;
|
||||||
|
|
||||||
|
FD_ZERO(&fdread);
|
||||||
|
FD_ZERO(&fdwrite);
|
||||||
|
FD_ZERO(&fdexcep);
|
||||||
|
|
||||||
|
/* set a suitable timeout to play around with */
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
/* get file descriptors from the transfers */
|
||||||
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
|
switch(rc) {
|
||||||
|
case -1:
|
||||||
|
/* select error */
|
||||||
|
break;
|
||||||
|
case 0:
|
||||||
|
default:
|
||||||
|
/* timeout or readable/writable sockets */
|
||||||
|
while(CURLM_CALL_MULTI_PERFORM ==
|
||||||
|
curl_multi_perform(multi_handle, &still_running));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_multi_cleanup(multi_handle);
|
||||||
|
|
||||||
|
curl_easy_cleanup(http_handle);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
89
docs/examples/post-callback.c
Normal file
89
docs/examples/post-callback.c
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* An example source code that issues a HTTP POST and we provide the actual
|
||||||
|
* data through a read callback.
|
||||||
|
*
|
||||||
|
* Please be aware of the fact that the size of the posted data MUST be
|
||||||
|
* specified before the transfer is being made (with CURLOPT_POSTFIELDSIZE).
|
||||||
|
* This requirement will change when libcurl starts supporting chunked-encoded
|
||||||
|
* sends.
|
||||||
|
*
|
||||||
|
* This example requires libcurl 7.9.6 or later.
|
||||||
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
#if LIBCURL_VERSION_NUM < 0x070906
|
||||||
|
#error this example source requires libcurl 7.9.6 or newer
|
||||||
|
#endif
|
||||||
|
|
||||||
|
char data[]="this is what we post to the silly web server";
|
||||||
|
|
||||||
|
struct WriteThis {
|
||||||
|
char *readptr;
|
||||||
|
int sizeleft;
|
||||||
|
};
|
||||||
|
|
||||||
|
size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp)
|
||||||
|
{
|
||||||
|
struct WriteThis *pooh = (struct WriteThis *)userp;
|
||||||
|
|
||||||
|
if(size*nmemb < 1)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if(pooh->sizeleft) {
|
||||||
|
*(char *)ptr = pooh->readptr[0]; /* copy one single byte */
|
||||||
|
pooh->readptr++; /* advance pointer */
|
||||||
|
pooh->sizeleft--; /* less data left */
|
||||||
|
return 1; /* we return 1 byte at a time! */
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1; /* no more data left to deliver */
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
struct WriteThis pooh;
|
||||||
|
|
||||||
|
pooh.readptr = data;
|
||||||
|
pooh.sizeleft = strlen(data);
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* First set the URL that is about to receive our POST. */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL,
|
||||||
|
"http://receivingsite.com.pooh/index.cgi");
|
||||||
|
/* Now specify we want to POST data */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POST, TRUE);
|
||||||
|
|
||||||
|
/* Set the expected POST size */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft);
|
||||||
|
|
||||||
|
/* we want to use our own read function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback);
|
||||||
|
|
||||||
|
/* pointer to pass to our read function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_INFILE, &pooh);
|
||||||
|
|
||||||
|
/* get verbose debug output please */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
|
||||||
|
/* Perform the request, res will get the return code */
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -1,71 +0,0 @@
|
|||||||
/*****************************************************************************
|
|
||||||
* _ _ ____ _
|
|
||||||
* Project ___| | | | _ \| |
|
|
||||||
* / __| | | | |_) | |
|
|
||||||
* | (__| |_| | _ <| |___
|
|
||||||
* \___|\___/|_| \_\_____|
|
|
||||||
*
|
|
||||||
* $Id$
|
|
||||||
*
|
|
||||||
* Example code that uploads a file name 'foo' to a remote script that accepts
|
|
||||||
* "HTML form based" (as described in RFC1738) uploads using HTTP POST.
|
|
||||||
*
|
|
||||||
* The imaginary form we'll fill in looks like:
|
|
||||||
*
|
|
||||||
* <form method="post" enctype="multipart/form-data" action="examplepost.cgi">
|
|
||||||
* Enter file: <input type="file" name="sendfile" size="40">
|
|
||||||
* Enter file name: <input type="text" name="filename" size="30">
|
|
||||||
* <input type="submit" value="send" name="submit">
|
|
||||||
* </form>
|
|
||||||
*
|
|
||||||
* This exact source code has not been verified to work.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* to make this work under windows, use the win32-functions from the
|
|
||||||
win32socket.c file as well */
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include <curl/curl.h>
|
|
||||||
#include <curl/types.h>
|
|
||||||
#include <curl/easy.h>
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
CURL *curl;
|
|
||||||
CURLcode res;
|
|
||||||
|
|
||||||
struct HttpPost *formpost=NULL;
|
|
||||||
struct HttpPost *lastptr=NULL;
|
|
||||||
|
|
||||||
/* Fill in the file upload field */
|
|
||||||
curl_formparse("sendfile=@foo",
|
|
||||||
&formpost,
|
|
||||||
&lastptr);
|
|
||||||
|
|
||||||
/* Fill in the filename field */
|
|
||||||
curl_formparse("filename=foo",
|
|
||||||
&formpost,
|
|
||||||
&lastptr);
|
|
||||||
|
|
||||||
|
|
||||||
/* Fill in the submit field too, even if this is rarely needed */
|
|
||||||
curl_formparse("submit=send",
|
|
||||||
&formpost,
|
|
||||||
&lastptr);
|
|
||||||
|
|
||||||
curl = curl_easy_init();
|
|
||||||
if(curl) {
|
|
||||||
/* what URL that receives this POST */
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/examplepost.cgi");
|
|
||||||
curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost);
|
|
||||||
res = curl_easy_perform(curl);
|
|
||||||
|
|
||||||
/* always cleanup */
|
|
||||||
curl_easy_cleanup(curl);
|
|
||||||
|
|
||||||
/* then cleanup the formpost chain */
|
|
||||||
curl_formfree(formpost);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
@@ -21,7 +21,7 @@
|
|||||||
|
|
||||||
size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
int written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
||||||
return written;
|
return written;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -63,6 +63,10 @@ int main(int argc, char **argv)
|
|||||||
/* we want the headers to this file handle */
|
/* we want the headers to this file handle */
|
||||||
curl_easy_setopt(curl_handle, CURLOPT_WRITEHEADER ,headerfile);
|
curl_easy_setopt(curl_handle, CURLOPT_WRITEHEADER ,headerfile);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Notice here that if you want the actual data sent anywhere else but
|
||||||
|
* stdout, you should consider using the CURLOPT_WRITEDATA option. */
|
||||||
|
|
||||||
/* get it! */
|
/* get it! */
|
||||||
curl_easy_perform(curl_handle);
|
curl_easy_perform(curl_handle);
|
||||||
|
|
||||||
|
@@ -9,27 +9,16 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <curl/types.h>
|
|
||||||
#include <curl/easy.h>
|
|
||||||
|
|
||||||
/* to make this work under windows, use the win32-functions from the
|
int main(void)
|
||||||
win32socket.c file as well */
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
{
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
FILE *headerfile;
|
|
||||||
|
|
||||||
headerfile = fopen("dumpit", "w");
|
|
||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* what call to write: */
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
||||||
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
|
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
|
36
docs/examples/simplepost.c
Normal file
36
docs/examples/simplepost.c
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
char *postthis="moo mooo moo moo";
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://posthere.com");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postthis);
|
||||||
|
|
||||||
|
/* if we don't provide POSTFIELDSIZE, libcurl will strlen() by
|
||||||
|
itself */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, strlen(postthis));
|
||||||
|
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -28,6 +28,9 @@
|
|||||||
4.2. if the format of the key file is DER, set pKeyType to "DER"
|
4.2. if the format of the key file is DER, set pKeyType to "DER"
|
||||||
|
|
||||||
!! verify of the server certificate is not implemented here !!
|
!! verify of the server certificate is not implemented here !!
|
||||||
|
|
||||||
|
**** This example only works with libcurl 7.9.3 and later! ****
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
@@ -37,6 +40,7 @@ int main(int argc, char **argv)
|
|||||||
FILE *headerfile;
|
FILE *headerfile;
|
||||||
|
|
||||||
const char *pCertFile = "testcert.pem";
|
const char *pCertFile = "testcert.pem";
|
||||||
|
const char *pCACertFile="cacert.pem";
|
||||||
|
|
||||||
const char *pKeyName;
|
const char *pKeyName;
|
||||||
const char *pKeyType;
|
const char *pKeyType;
|
||||||
@@ -62,7 +66,7 @@ int main(int argc, char **argv)
|
|||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* what call to write: */
|
/* what call to write: */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://your.favourite.ssl.site");
|
||||||
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
|
||||||
|
|
||||||
while(1) /* do some ugly short cut... */
|
while(1) /* do some ugly short cut... */
|
||||||
@@ -96,6 +100,10 @@ int main(int argc, char **argv)
|
|||||||
curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType);
|
curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType);
|
||||||
/* set the private key (file or ID in engine) */
|
/* set the private key (file or ID in engine) */
|
||||||
curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName);
|
curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName);
|
||||||
|
/* set the file with the certs vaildating the server */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_CAINFO,pCACertFile);
|
||||||
|
/* disconnect if we can't validate server's cert */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1);
|
||||||
|
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
break; /* we are done... */
|
break; /* we are done... */
|
||||||
|
@@ -1,49 +0,0 @@
|
|||||||
|
|
||||||
/*
|
|
||||||
* Note: This is only required if you use curl 7.8 or lower, later
|
|
||||||
* versions provide an option to curl_global_init() that does the
|
|
||||||
* win32 initialization for you.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* These are example functions doing socket init that Windows
|
|
||||||
* require. If you don't use windows, you can safely ignore this crap.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <windows.h>
|
|
||||||
|
|
||||||
void win32_cleanup(void)
|
|
||||||
{
|
|
||||||
WSACleanup();
|
|
||||||
}
|
|
||||||
|
|
||||||
int win32_init(void)
|
|
||||||
{
|
|
||||||
WORD wVersionRequested;
|
|
||||||
WSADATA wsaData;
|
|
||||||
int err;
|
|
||||||
wVersionRequested = MAKEWORD(1, 1);
|
|
||||||
|
|
||||||
err = WSAStartup(wVersionRequested, &wsaData);
|
|
||||||
|
|
||||||
if (err != 0)
|
|
||||||
/* Tell the user that we couldn't find a useable */
|
|
||||||
/* winsock.dll. */
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
/* Confirm that the Windows Sockets DLL supports 1.1.*/
|
|
||||||
/* Note that if the DLL supports versions greater */
|
|
||||||
/* than 1.1 in addition to 1.1, it will still return */
|
|
||||||
/* 1.1 in wVersion since that is the version we */
|
|
||||||
/* requested. */
|
|
||||||
|
|
||||||
if ( LOBYTE( wsaData.wVersion ) != 1 ||
|
|
||||||
HIBYTE( wsaData.wVersion ) != 1 ) {
|
|
||||||
/* Tell the user that we couldn't find a useable */
|
|
||||||
|
|
||||||
/* winsock.dll. */
|
|
||||||
WSACleanup();
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
return 0; /* 0 is ok */
|
|
||||||
}
|
|
@@ -1,4 +1,4 @@
|
|||||||
HTML>
|
<HTML>
|
||||||
<HEAD>
|
<HEAD>
|
||||||
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
|
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
|
||||||
<TITLE>Index to Curl documentation</TITLE>
|
<TITLE>Index to Curl documentation</TITLE>
|
||||||
@@ -8,31 +8,14 @@ HTML>
|
|||||||
<H1 ALIGN="CENTER">Index to Curl documentation</H1>
|
<H1 ALIGN="CENTER">Index to Curl documentation</H1>
|
||||||
|
|
||||||
<H2>Programs</H2>
|
<H2>Programs</H2>
|
||||||
<P><A HREF="curl-config.html">curl-config.html</A>
|
<a href="curl-config.html">curl-config</A>
|
||||||
<P><A HREF="curl.html">curl.html</A>
|
<br><a href="curl.html">curl</A>
|
||||||
|
|
||||||
|
<h2>Tutorial</h2>
|
||||||
|
<a href="TheArtOfHttpScripting">The Art Of Scripting HTTP Requests Using Curl</a> (plain text)
|
||||||
|
|
||||||
|
<h2>libcurl</h2>
|
||||||
|
See the <a href="libcurl/index.html">libcurl section</a>
|
||||||
|
|
||||||
<H2>Library routines</H2>
|
|
||||||
<P><A HREF="libcurl.html">libcurl.html</A>
|
|
||||||
<P><A HREF="curl_easy_cleanup.html">curl_easy_cleanup.html</A>
|
|
||||||
<P><A HREF="curl_easy_duphandle.html">curl_easy_duphandle.html</A>
|
|
||||||
<P><A HREF="curl_easy_getinfo.html">curl_easy_getinfo.html</A>
|
|
||||||
<P><A HREF="curl_easy_init.html">curl_easy_init.html</A>
|
|
||||||
<P><A HREF="curl_easy_perform.html">curl_easy_perform.html</A>
|
|
||||||
<P><A HREF="curl_easy_setopt.html">curl_easy_setopt.html</A>
|
|
||||||
<P><A HREF="curl_escape.html">curl_escape.html</A>
|
|
||||||
<P><A HREF="curl_formadd.html">curl_formadd.html</A>
|
|
||||||
<P><A HREF="curl_formfree.html">curl_formfree.html</A>
|
|
||||||
<P><A HREF="curl_formparse.html">curl_formparse.html</A>
|
|
||||||
<P><A HREF="curl_getdate.html">curl_getdate.html</A>
|
|
||||||
<P><A HREF="curl_getenv.html">curl_getenv.html</A>
|
|
||||||
<P><A HREF="curl_global_cleanup.html">curl_global_cleanup.html</A>
|
|
||||||
<P><A HREF="curl_global_init.html">curl_global_init.html</A>
|
|
||||||
<P><A HREF="curl_mprintf.html">curl_mprintf.html</A>
|
|
||||||
<P><A HREF="curl_slist_append.html">curl_slist_append.html</A>
|
|
||||||
<P><A HREF="curl_slist_free_all.html">curl_slist_free_all.html</A>
|
|
||||||
<P><A HREF="curl_strequal.html">curl_strequal.html</A>
|
|
||||||
<P><A HREF="curl_strnequal.html">curl_strnequal.html</A>
|
|
||||||
<P><A HREF="curl_unescape.html">curl_unescape.html</A>
|
|
||||||
<P><A HREF="curl_version.html">curl_version.html</A>
|
|
||||||
</BODY>
|
</BODY>
|
||||||
</HTML>
|
</HTML>
|
||||||
|
1102
docs/libcurl-the-guide
Normal file
1102
docs/libcurl-the-guide
Normal file
File diff suppressed because it is too large
Load Diff
133
docs/libcurl.3
133
docs/libcurl.3
@@ -1,133 +0,0 @@
|
|||||||
.\" You can view this file with:
|
|
||||||
.\" nroff -man [file]
|
|
||||||
.\" $Id$
|
|
||||||
.\"
|
|
||||||
.TH libcurl 5 "14 August 2001" "libcurl 7.8.1" "libcurl overview"
|
|
||||||
.SH NAME
|
|
||||||
libcurl \- client-side URL transfers
|
|
||||||
.SH DESCRIPTION
|
|
||||||
This is an overview on how to use libcurl in your c/c++ programs. There are
|
|
||||||
specific man pages for each function mentioned in here.
|
|
||||||
|
|
||||||
libcurl can also be used directly from within your Java, PHP, Perl, Ruby or
|
|
||||||
Tcl programs as well, look elsewhere for documentation on this!
|
|
||||||
|
|
||||||
All applications that use libcurl should call \fIcurl_global_init()\fP exactly
|
|
||||||
once before any libcurl function can be used. After all usage of libcurl is
|
|
||||||
complete, it \fBmust\fP call \fIcurl_global_cleanup()\fP. In between those two
|
|
||||||
calls, you can use libcurl as described below.
|
|
||||||
|
|
||||||
When using libcurl you init your session and get a handle, which you use as
|
|
||||||
input to the following interface functions you use. Use \fIcurl_easy_init()\fP
|
|
||||||
to get the handle.
|
|
||||||
|
|
||||||
You continue by setting all the options you want in the upcoming transfer,
|
|
||||||
most important among them is the URL itself (you can't transfer anything
|
|
||||||
without a specified URL as you may have figured out yourself). You might want
|
|
||||||
to set some callbacks as well that will be called from the library when data
|
|
||||||
is available etc. \fIcurl_easy_setopt()\fP is there for this.
|
|
||||||
|
|
||||||
When all is setup, you tell libcurl to perform the transfer using
|
|
||||||
\fIcurl_easy_perform()\fP. It will then do the entire operation and won't
|
|
||||||
return until it is done (successfully or not).
|
|
||||||
|
|
||||||
After the transfer has been made, you can set new options and make another
|
|
||||||
transfer, or if you're done, cleanup the session by calling
|
|
||||||
\fIcurl_easy_cleanup()\fP. If you want persistant connections, you don't
|
|
||||||
cleanup immediately, but instead run ahead and perform other transfers using
|
|
||||||
the same handle. See the chapter below for Persistant Connections.
|
|
||||||
|
|
||||||
There is also a series of other helpful functions to use. They are:
|
|
||||||
|
|
||||||
.RS
|
|
||||||
.TP 10
|
|
||||||
.B curl_version()
|
|
||||||
displays the libcurl version
|
|
||||||
.TP
|
|
||||||
.B curl_getdate()
|
|
||||||
converts a date string to time_t
|
|
||||||
.TP
|
|
||||||
.B curl_getenv()
|
|
||||||
portable environment variable reader
|
|
||||||
.TP
|
|
||||||
.B curl_easy_getinfo()
|
|
||||||
get information about a performed transfer
|
|
||||||
.TP
|
|
||||||
.B curl_formadd()
|
|
||||||
helps building a HTTP form POST
|
|
||||||
.TP
|
|
||||||
.B curl_formparse()
|
|
||||||
helps building a HTTP form POST (deprecated since 7.9 use curl_formadd()!)
|
|
||||||
.TP
|
|
||||||
.B curl_formfree()
|
|
||||||
free a list built with curl_formparse()/curl_formadd()
|
|
||||||
.TP
|
|
||||||
.B curl_slist_append()
|
|
||||||
builds a linked list
|
|
||||||
.TP
|
|
||||||
.B curl_slist_free_all()
|
|
||||||
frees a whole curl_slist
|
|
||||||
.TP
|
|
||||||
.B curl_mprintf()
|
|
||||||
portable printf() functions
|
|
||||||
.TP
|
|
||||||
.B curl_strequal()
|
|
||||||
portable case insensitive string comparisons
|
|
||||||
.RE
|
|
||||||
|
|
||||||
.SH "LINKING WITH LIBCURL"
|
|
||||||
Starting with 7.7.2 (on unix-like machines), there's a tool named curl-config
|
|
||||||
that gets installed with the rest of the curl stuff when 'make install' is
|
|
||||||
performed.
|
|
||||||
|
|
||||||
curl-config is added to make it easier for applications to link with libcurl
|
|
||||||
and developers to learn about libcurl and how to use it.
|
|
||||||
|
|
||||||
Run 'curl-config --libs' to get the (additional) linker options you need to
|
|
||||||
link with the particular version of libcurl you've installed.
|
|
||||||
|
|
||||||
For details, see the curl-config.1 man page.
|
|
||||||
.SH "LIBCURL SYMBOL NAMES"
|
|
||||||
All public functions in the libcurl interface are prefixed with 'curl_' (with
|
|
||||||
a lowercase c). You can find other functions in the library source code, but
|
|
||||||
other prefixes indicate the functions are private and may change without
|
|
||||||
further notice in the next release.
|
|
||||||
|
|
||||||
Only use documented functions and functionality!
|
|
||||||
.SH "PORTABILITY"
|
|
||||||
libcurl works
|
|
||||||
.B exactly
|
|
||||||
the same, on any of the platforms it compiles and builds on.
|
|
||||||
|
|
||||||
There's only one caution, and that is the win32 platform that may(*) require
|
|
||||||
you to init the winsock stuff before you use the libcurl functions. Details on
|
|
||||||
this are noted on the curl_easy_init() man page.
|
|
||||||
|
|
||||||
(*) = it appears as if users of the cygwin environment get this done
|
|
||||||
automatically, also libcurl 7.8.1 and later can handle this for you.
|
|
||||||
.SH "THREADS"
|
|
||||||
Never ever call curl-functions simultaneously using the same handle from
|
|
||||||
several threads. libcurl is thread-safe and can be used in any number of
|
|
||||||
threads, but you must use separate curl handles if you want to use libcurl in
|
|
||||||
more than one thread simultaneously.
|
|
||||||
.SH "PERSISTANT CONNECTIONS"
|
|
||||||
With libcurl 7.7, persistant connections were added. Persistant connections
|
|
||||||
means that libcurl can re-use the same connection for several transfers, if
|
|
||||||
the conditions are right.
|
|
||||||
|
|
||||||
libcurl will *always* attempt to use persistant connections. Whenever you use
|
|
||||||
curl_easy_perform(), libcurl will attempt to use an existing connection to do
|
|
||||||
the transfer, and if none exists it'll open a new one that will be subject
|
|
||||||
for re-use on a possible following call to curl_easy_perform().
|
|
||||||
|
|
||||||
To allow libcurl to take full advantage of persistant connections, you should
|
|
||||||
do as many of your file transfers as possible using the same curl
|
|
||||||
handle. When you call curl_easy_cleanup(), all the possibly open connections
|
|
||||||
held by libcurl will be closed and forgotten.
|
|
||||||
|
|
||||||
Note that the options set with curl_easy_setopt() will be used in on every
|
|
||||||
repeat curl_easy_perform() call
|
|
||||||
.SH "COMPATIBILITY WITH OLDER LIBCURLS"
|
|
||||||
Repeated curl_easy_perform() calls on the same handle were not supported in
|
|
||||||
pre-7.7 versions, and caused confusion and undefined behaviour.
|
|
||||||
|
|
5
docs/libcurl/.cvsignore
Normal file
5
docs/libcurl/.cvsignore
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
*html
|
||||||
|
*ps
|
||||||
|
*pdf
|
141
docs/libcurl/Makefile.am
Normal file
141
docs/libcurl/Makefile.am
Normal file
@@ -0,0 +1,141 @@
|
|||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
|
||||||
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
|
man_MANS = \
|
||||||
|
curl_easy_cleanup.3 \
|
||||||
|
curl_easy_getinfo.3 \
|
||||||
|
curl_easy_init.3 \
|
||||||
|
curl_easy_perform.3 \
|
||||||
|
curl_easy_setopt.3 \
|
||||||
|
curl_easy_duphandle.3 \
|
||||||
|
curl_formparse.3 \
|
||||||
|
curl_formadd.3 \
|
||||||
|
curl_formfree.3 \
|
||||||
|
curl_getdate.3 \
|
||||||
|
curl_getenv.3 \
|
||||||
|
curl_slist_append.3 \
|
||||||
|
curl_slist_free_all.3 \
|
||||||
|
curl_version.3 \
|
||||||
|
curl_version_info.3 \
|
||||||
|
curl_escape.3 \
|
||||||
|
curl_unescape.3 \
|
||||||
|
curl_free.3 \
|
||||||
|
curl_strequal.3 \
|
||||||
|
curl_strnequal.3 \
|
||||||
|
curl_mprintf.3 \
|
||||||
|
curl_global_init.3 \
|
||||||
|
curl_global_cleanup.3 \
|
||||||
|
curl_multi_add_handle.3 \
|
||||||
|
curl_multi_cleanup.3 \
|
||||||
|
curl_multi_fdset.3 \
|
||||||
|
curl_multi_info_read.3 \
|
||||||
|
curl_multi_init.3 \
|
||||||
|
curl_multi_perform.3 \
|
||||||
|
curl_multi_remove_handle.3 \
|
||||||
|
curl_share_cleanup.3 curl_share_init.3 curl_share_setopt.3 \
|
||||||
|
libcurl.3 \
|
||||||
|
libcurl-easy.3 \
|
||||||
|
libcurl-multi.3 \
|
||||||
|
libcurl-share.3 \
|
||||||
|
libcurl-errors.3
|
||||||
|
|
||||||
|
HTMLPAGES = \
|
||||||
|
curl_easy_cleanup.html \
|
||||||
|
curl_easy_getinfo.html \
|
||||||
|
curl_easy_init.html \
|
||||||
|
curl_easy_perform.html \
|
||||||
|
curl_easy_setopt.html \
|
||||||
|
curl_easy_duphandle.html \
|
||||||
|
curl_formadd.html \
|
||||||
|
curl_formparse.html \
|
||||||
|
curl_formfree.html \
|
||||||
|
curl_getdate.html \
|
||||||
|
curl_getenv.html \
|
||||||
|
curl_slist_append.html \
|
||||||
|
curl_slist_free_all.html \
|
||||||
|
curl_version.html \
|
||||||
|
curl_version_info.html \
|
||||||
|
curl_escape.html \
|
||||||
|
curl_unescape.html \
|
||||||
|
curl_free.html \
|
||||||
|
curl_strequal.html \
|
||||||
|
curl_strnequal.html \
|
||||||
|
curl_mprintf.html \
|
||||||
|
curl_global_init.html \
|
||||||
|
curl_global_cleanup.html \
|
||||||
|
curl_multi_add_handle.html \
|
||||||
|
curl_multi_cleanup.html \
|
||||||
|
curl_multi_fdset.html \
|
||||||
|
curl_multi_info_read.html \
|
||||||
|
curl_multi_init.html \
|
||||||
|
curl_multi_perform.html \
|
||||||
|
curl_multi_remove_handle.html \
|
||||||
|
curl_share_cleanup.html curl_share_init.html curl_share_setopt.html \
|
||||||
|
libcurl.html \
|
||||||
|
libcurl-multi.html \
|
||||||
|
libcurl-easy.html \
|
||||||
|
libcurl-share.html \
|
||||||
|
libcurl-errors.html
|
||||||
|
|
||||||
|
PDFPAGES = \
|
||||||
|
curl_easy_cleanup.pdf \
|
||||||
|
curl_easy_getinfo.pdf \
|
||||||
|
curl_easy_init.pdf \
|
||||||
|
curl_easy_perform.pdf \
|
||||||
|
curl_easy_setopt.pdf \
|
||||||
|
curl_easy_duphandle.pdf \
|
||||||
|
curl_formadd.pdf \
|
||||||
|
curl_formparse.pdf \
|
||||||
|
curl_formfree.pdf \
|
||||||
|
curl_getdate.pdf \
|
||||||
|
curl_getenv.pdf \
|
||||||
|
curl_slist_append.pdf \
|
||||||
|
curl_slist_free_all.pdf \
|
||||||
|
curl_version.pdf \
|
||||||
|
curl_version_info.pdf \
|
||||||
|
curl_escape.pdf \
|
||||||
|
curl_unescape.pdf \
|
||||||
|
curl_free.pdf \
|
||||||
|
curl_strequal.pdf \
|
||||||
|
curl_strnequal.pdf \
|
||||||
|
curl_mprintf.pdf \
|
||||||
|
curl_global_init.pdf \
|
||||||
|
curl_global_cleanup.pdf \
|
||||||
|
curl_multi_add_handle.pdf \
|
||||||
|
curl_multi_cleanup.pdf \
|
||||||
|
curl_multi_fdset.pdf \
|
||||||
|
curl_multi_info_read.pdf \
|
||||||
|
curl_multi_init.pdf \
|
||||||
|
curl_multi_perform.pdf \
|
||||||
|
curl_multi_remove_handle.pdf \
|
||||||
|
curl_share_cleanup.pdf curl_share_init.pdf curl_share_setopt.pdf \
|
||||||
|
libcurl.pdf \
|
||||||
|
libcurl-multi.pdf \
|
||||||
|
libcurl-easy.pdf \
|
||||||
|
libcurl-share.pdf \
|
||||||
|
libcurl-errors.pdf
|
||||||
|
|
||||||
|
CLEANFILES = $(HTMLPAGES) $(PDFPAGES)
|
||||||
|
|
||||||
|
EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES)
|
||||||
|
|
||||||
|
MAN2HTML= gnroff -man $< | man2html >$@
|
||||||
|
|
||||||
|
SUFFIXES = .3 .html
|
||||||
|
|
||||||
|
html: $(HTMLPAGES)
|
||||||
|
|
||||||
|
.3.html:
|
||||||
|
$(MAN2HTML)
|
||||||
|
|
||||||
|
pdf: $(PDFPAGES)
|
||||||
|
|
||||||
|
.3.pdf:
|
||||||
|
@(foo=`echo $@ | sed -e 's/\.[0-9]$$//g'`; \
|
||||||
|
groff -Tps -man $< >$$foo.ps; \
|
||||||
|
ps2pdf $$foo.ps $@; \
|
||||||
|
rm $$foo.ps; \
|
||||||
|
echo "converted $< to $@")
|
28
docs/libcurl/curl_easy_cleanup.3
Normal file
28
docs/libcurl/curl_easy_cleanup.3
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_easy_cleanup 3 "13 Nov 2002" "libcurl 7.7" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_easy_cleanup - End a libcurl easy session
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "void curl_easy_cleanup(CURL *" handle ");"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function must be the last function to call for an easy session. It is the
|
||||||
|
opposite of the \fIcurl_easy_init\fP function and must be called with the same
|
||||||
|
\fIhandle\fP as input that the curl_easy_init call returned.
|
||||||
|
|
||||||
|
This will effectively close all connections this handle has used and possibly
|
||||||
|
has kept open until now. Don't call this function if you intend to transfer
|
||||||
|
more files.
|
||||||
|
|
||||||
|
When you've called this, you can safely remove all the strings you've
|
||||||
|
previously told libcurl to use, as it won't use them anymore now.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
None
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_easy_init "(3), "
|
||||||
|
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.6.1" "libcurl Manual"
|
.TH curl_easy_getinfo 3 "25 Apr 2002" "libcurl 7.9.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_getinfo - Extract information from a curl session (added in 7.4)
|
curl_easy_getinfo - Extract information from a curl session (added in 7.4)
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -30,13 +30,17 @@ Pass a pointer to a long to receive the last received HTTP code.
|
|||||||
.TP
|
.TP
|
||||||
.B CURLINFO_FILETIME
|
.B CURLINFO_FILETIME
|
||||||
Pass a pointer to a long to receive the remote time of the retrieved
|
Pass a pointer to a long to receive the remote time of the retrieved
|
||||||
document. If you get 0, it can be because of many reasons (unknown, the server
|
document. If you get -1, it can be because of many reasons (unknown, the
|
||||||
hides it or the server doesn't support the command that tells document time
|
server hides it or the server doesn't support the command that tells document
|
||||||
etc) and the time of the document is unknown. (Added in 7.5)
|
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)
|
||||||
.TP
|
.TP
|
||||||
.B CURLINFO_TOTAL_TIME
|
.B CURLINFO_TOTAL_TIME
|
||||||
Pass a pointer to a double to receive the total transaction time in seconds
|
Pass a pointer to a double to receive the total transaction time in seconds
|
||||||
for the previous transfer.
|
for the previous transfer. This time does not include the connect time, so if
|
||||||
|
you want the complete operation time, you should add the
|
||||||
|
CURLINFO_CONNECT_TIME.
|
||||||
.TP
|
.TP
|
||||||
.B CURLINFO_NAMELOOKUP_TIME
|
.B CURLINFO_NAMELOOKUP_TIME
|
||||||
Pass a pointer to a double to receive the time, in seconds, it took from the
|
Pass a pointer to a double to receive the time, in seconds, it took from the
|
||||||
@@ -58,13 +62,24 @@ start until the first byte is just about to be transfered. This includes
|
|||||||
CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate
|
CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate
|
||||||
the result.
|
the result.
|
||||||
.TP
|
.TP
|
||||||
|
.B CURLINFO_REDIRECT_TIME
|
||||||
|
Pass a pointer to a double to receive the total time, in seconds, it took for
|
||||||
|
all redirection steps include name lookup, connect, pretransfer and transfer
|
||||||
|
before final transaction was started. CURLINFO_REDIRECT_TIME contains the
|
||||||
|
complete execution time for multiple redirections. (Added in 7.9.7)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_REDIRECT_COUNT
|
||||||
|
Pass a pointer to a long to receive the total number of redirections that were
|
||||||
|
actually followed. (Added in 7.9.7)
|
||||||
|
.TP
|
||||||
.B CURLINFO_SIZE_UPLOAD
|
.B CURLINFO_SIZE_UPLOAD
|
||||||
Pass a pointer to a double to receive the total amount of bytes that were
|
Pass a pointer to a double to receive the total amount of bytes that were
|
||||||
uploaded.
|
uploaded.
|
||||||
.TP
|
.TP
|
||||||
.B CURLINFO_SIZE_DOWNLOAD
|
.B CURLINFO_SIZE_DOWNLOAD
|
||||||
Pass a pointer to a double to receive the total amount of bytes that were
|
Pass a pointer to a double to receive the total amount of bytes that were
|
||||||
downloaded.
|
downloaded. The amount is only for the latest transfer and will be reset again
|
||||||
|
for each new transfer.
|
||||||
.TP
|
.TP
|
||||||
.B CURLINFO_SPEED_DOWNLOAD
|
.B CURLINFO_SPEED_DOWNLOAD
|
||||||
Pass a pointer to a double to receive the average download speed that curl
|
Pass a pointer to a double to receive the average download speed that curl
|
||||||
@@ -95,8 +110,18 @@ is the value read from the Content-Length: field. (Added in 7.6.1)
|
|||||||
.B CURLINFO_CONTENT_LENGTH_UPLOAD
|
.B CURLINFO_CONTENT_LENGTH_UPLOAD
|
||||||
Pass a pointer to a double to receive the specified size of the upload.
|
Pass a pointer to a double to receive the specified size of the upload.
|
||||||
(Added in 7.6.1)
|
(Added in 7.6.1)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_CONTENT_TYPE
|
||||||
|
Pass a pointer to a 'char *' to receive the content-type of the downloaded
|
||||||
|
object. This is the value read from the Content-Type: field. If you get NULL,
|
||||||
|
it means that the server didn't send a valid Content-Type header or that the
|
||||||
|
protocol used doesn't support this. (Added in 7.9.4)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_PRIVATE
|
||||||
|
Pass a pointer to a 'char *' to receive the pointer to the private data
|
||||||
|
associated with the curl handle (set with the CURLOPT_PRIVATE option to curl_easy_setopt).
|
||||||
|
(Added in 7.10.3)
|
||||||
.PP
|
.PP
|
||||||
|
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
If the operation was successful, CURLE_OK is returned. Otherwise an
|
If the operation was successful, CURLE_OK is returned. Otherwise an
|
||||||
appropriate error code will be returned.
|
appropriate error code will be returned.
|
25
docs/libcurl/curl_easy_init.3
Normal file
25
docs/libcurl/curl_easy_init.3
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_easy_init 3 "4 March 2002" "libcurl 7.8.1" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_easy_init - Start a libcurl easy session
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURL *curl_easy_init( );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function must be the first function to call, and it returns a CURL easy
|
||||||
|
handle that you must use as input to other easy-functions. curl_easy_init
|
||||||
|
intializes curl and this call MUST have a corresponding call to
|
||||||
|
\fIcurl_easy_cleanup\fP when the operation is complete.
|
||||||
|
|
||||||
|
.SH RETURN VALUE
|
||||||
|
If this function returns NULL, something went wrong and you cannot use the
|
||||||
|
other curl functions.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_easy_cleanup "(3), " curl_global_init "(3)
|
||||||
|
.SH BUGS
|
||||||
|
Surely there are some, you tell me!
|
File diff suppressed because it is too large
Load Diff
@@ -1,28 +1,26 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_escape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_escape 3 "6 March 2002" "libcurl 7.9" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_escape - URL encodes the given string
|
curl_escape - URL encodes the given string
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "char *curl_escape( char *" url ", int "length " );"
|
.BI "char *curl_escape( char *" url ", int "length " );"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
This function will convert the given input string to an URL encoded string and
|
This function will convert the given input string to an URL encoded string and
|
||||||
return that as a new allocated string. All input characters that are not a-z,
|
return that as a new allocated string. All input characters that are not a-z,
|
||||||
A-Z or 0-9 will be converted to their "URL escaped" version. If a sequence of
|
A-Z or 0-9 will be converted to their "URL escaped" version (%NN where NN is a
|
||||||
%NN (where NN is a two-digit hexadecimal number) is found in the string to
|
two-digit hexadecimal number).
|
||||||
encode, that 3-letter combination will be copied to the output unmodifed,
|
|
||||||
assuming that it is an already encoded piece of data.
|
If the 'length' argument is set to 0, curl_escape() will use strlen() on the
|
||||||
|
input 'url' string to find out the size.
|
||||||
If the 'length' argument is set to 0, curl_escape() will use strlen() on the
|
|
||||||
input 'url' string to find out the size.
|
You must curl_free() the returned string when you're done with it.
|
||||||
|
.SH RETURN VALUE
|
||||||
You must free() the returned string when you're done with it.
|
A pointer to a zero terminated string or NULL if it failed.
|
||||||
.SH RETURN VALUE
|
.SH "SEE ALSO"
|
||||||
A pointer to a zero terminated string or NULL if it failed.
|
.I curl_unescape(), curl_free(), RFC 2396
|
||||||
.SH "SEE ALSO"
|
|
||||||
.I curl_unescape(), RFC 2396
|
|
212
docs/libcurl/curl_formadd.3
Normal file
212
docs/libcurl/curl_formadd.3
Normal file
@@ -0,0 +1,212 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_formadd 3 "24 June 2002" "libcurl 7.9.8" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_formadd - add a section to a multipart/formdata HTTP POST
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURLFORMcode curl_formadd(struct HttpPost ** " firstitem,
|
||||||
|
.BI "struct HttpPost ** " lastitem, " ...);"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
curl_formadd() is used to append sections when building a multipart/formdata
|
||||||
|
HTTP POST (sometimes refered to as rfc1867-style posts). Append one section at
|
||||||
|
a time until you've added all the sections you want included and then you pass
|
||||||
|
the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP.
|
||||||
|
\fIlastitem\fP is set after each call and on repeated invokes it should be
|
||||||
|
left as set to allow repeated invokes to find the end of the list faster.
|
||||||
|
|
||||||
|
After the \fIlastitem\fP pointer follow the real arguments.
|
||||||
|
|
||||||
|
The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to
|
||||||
|
NULL in the first call to this function. All list-data will be allocated by
|
||||||
|
the function itself. You must call \fIcurl_formfree\fP after the form post has
|
||||||
|
been done to free the resources again.
|
||||||
|
|
||||||
|
First, there are some basics you need to understand about multipart/formdata
|
||||||
|
posts. Each part consists of at least a NAME and a CONTENTS part. If the part
|
||||||
|
is made for file upload, there are also a stored CONTENT-TYPE and a
|
||||||
|
FILENAME. Below here, we'll discuss on what options you use to set these
|
||||||
|
properties in the parts you want to add to your post.
|
||||||
|
.SH OPTIONS
|
||||||
|
.B CURLFORM_COPYNAME
|
||||||
|
followed by string is used to set the name of this part. libcurl copies the
|
||||||
|
given data, so your application doesn't need to keep it around after this
|
||||||
|
function call. If the name isn't zero terminated properly, or if you'd like it
|
||||||
|
to contain zero bytes, you need to set the length of the name with
|
||||||
|
\fBCURLFORM_NAMELENGTH\fP.
|
||||||
|
|
||||||
|
.B CURLFORM_PTRNAME
|
||||||
|
followed by a string is used for the name of this part. libcurl will use the
|
||||||
|
pointer and refer to the data in your application, you must make sure it
|
||||||
|
remains until curl no longer needs it. If the name isn't zero terminated
|
||||||
|
properly, or if you'd like it to contain zero bytes, you need to set the
|
||||||
|
length of the name with \fBCURLFORM_NAMELENGTH\fP.
|
||||||
|
|
||||||
|
.B CURLFORM_COPYCONTENTS
|
||||||
|
followed by a string is used for the contents of this part, the actual data to
|
||||||
|
send away. libcurl copies the given data, so your application doesn't need to
|
||||||
|
keep it around after this function call. If the data isn't zero terminated
|
||||||
|
properly, or if you'd like it to contain zero bytes, you need to set the
|
||||||
|
length of the name with \fBCURLFORM_CONTENTSLENGTH\fP.
|
||||||
|
|
||||||
|
.B CURLFORM_PTRCONTENTS
|
||||||
|
followed by a string is used for the contents of this part, the actual data to
|
||||||
|
send away. libcurl will use the pointer and refer to the data in your
|
||||||
|
application, you must make sure it remains until curl no longer needs it. If
|
||||||
|
the data isn't zero terminated properly, or if you'd like it to contain zero
|
||||||
|
bytes, you need to set the length of the name with
|
||||||
|
\fBCURLFORM_CONTENTSLENGTH\fP.
|
||||||
|
|
||||||
|
.B CURLFORM_FILECONTENT
|
||||||
|
followed by a file name, makes that file read and the contents will be used in
|
||||||
|
as data in this part.
|
||||||
|
|
||||||
|
.B CURLFORM_FILE
|
||||||
|
followed by a file name, makes this part a file upload part. It sets the file
|
||||||
|
name field to the actual file name used here, it gets the contents of the file
|
||||||
|
and passes as data and sets the content-type if the given file match one of
|
||||||
|
the new internally known file extension. For \fBCURLFORM_FILE\fP the user may
|
||||||
|
send one or more files in one part by providing multiple \fBCURLFORM_FILE\fP
|
||||||
|
arguments each followed by the filename (and each CURLFORM_FILE is allowed to
|
||||||
|
have a CURLFORM_CONTENTTYPE).
|
||||||
|
|
||||||
|
.B CURLFORM_CONTENTTYPE
|
||||||
|
followed by a pointer to a string with a content-type will make curl use this
|
||||||
|
given content-type for this file upload part, possibly instead of an
|
||||||
|
internally chosen one.
|
||||||
|
|
||||||
|
.B CURLFORM_FILENAME
|
||||||
|
followed by a pointer to a string to a name, will make libcurl use the given
|
||||||
|
name in the file upload part, intead of the actual file name given to
|
||||||
|
\fICURLFORM_FILE\fP.
|
||||||
|
|
||||||
|
.B BCURLFORM_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.
|
||||||
|
|
||||||
|
.B CURLFORM_BUFFERPTR
|
||||||
|
followed by a pointer to a data area, tells libcurl the address of the buffer
|
||||||
|
containing data to upload (as indicated with \fICURLFORM_BUFFER\fP). The
|
||||||
|
buffer containing this data must not be freed until after curl_easy_cleanup is
|
||||||
|
called.
|
||||||
|
|
||||||
|
.B CURLFORM_BUFFERLENGTH
|
||||||
|
followed by a long with the size of the \fICURLFORM_BUFFERPTR\fP data area,
|
||||||
|
tells libcurl the length of the buffer to upload.
|
||||||
|
|
||||||
|
.B CURLFORM_ARRAY
|
||||||
|
Another possibility to send options to curl_formadd() is the
|
||||||
|
\fBCURLFORM_ARRAY\fP option, that passes a struct curl_forms array pointer as
|
||||||
|
its value. Each curl_forms structure element has a CURLformoption and a char
|
||||||
|
pointer. The final element in the array must be a CURLFORM_END. All available
|
||||||
|
options can be used in an array, except the CURLFORM_ARRAY option itself! The
|
||||||
|
last argument in such an array must always be \fBCURLFORM_END\fP.
|
||||||
|
|
||||||
|
.B CURLFORM_CONTENTHEADER
|
||||||
|
specifies extra headers for the form POST section. This takes a curl_slist
|
||||||
|
prepared in the usual way using \fBcurl_slist_append\fP and appends the list
|
||||||
|
of headers to those libcurl automatically generates. The list must exist while
|
||||||
|
the POST occurs, if you free it before the post completes you may experience
|
||||||
|
problems.
|
||||||
|
|
||||||
|
When you've passed the HttpPost pointer to \fIcurl_easy_setopt\fP (using the
|
||||||
|
\fICURLOPT_HTTPPOST\fP option), you must not free the list until after you've
|
||||||
|
called \fIcurl_easy_cleanup\fP for the curl handle.
|
||||||
|
|
||||||
|
See example below.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
0 means everything was ok, non-zero means an error occurred as
|
||||||
|
.I <curl/curl.h>
|
||||||
|
defines.
|
||||||
|
.SH EXAMPLE
|
||||||
|
.nf
|
||||||
|
|
||||||
|
struct HttpPost* post = NULL;
|
||||||
|
struct HttpPost* last = NULL;
|
||||||
|
char namebuffer[] = "name buffer";
|
||||||
|
long namelength = strlen(namebuffer);
|
||||||
|
char buffer[] = "test buffer";
|
||||||
|
char htmlbuffer[] = "<HTML>test buffer</HTML>";
|
||||||
|
long htmlbufferlength = strlen(htmlbuffer);
|
||||||
|
struct curl_forms forms[3];
|
||||||
|
char file1[] = "my-face.jpg";
|
||||||
|
char file2[] = "your-face.jpg";
|
||||||
|
/* add null character into htmlbuffer, to demonstrate that
|
||||||
|
transfers of buffers containing null characters actually work
|
||||||
|
*/
|
||||||
|
htmlbuffer[8] = '\\0';
|
||||||
|
|
||||||
|
/* Add simple name/content section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "name",
|
||||||
|
CURLFORM_COPYCONTENTS, "content", CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add simple name/content/contenttype section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "htmlcode",
|
||||||
|
CURLFORM_COPYCONTENTS, "<HTML></HTML>",
|
||||||
|
CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add name/ptrcontent section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "name_for_ptrcontent",
|
||||||
|
CURLFORM_PTRCONTENTS, buffer, CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add ptrname/ptrcontent section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_PTRNAME, namebuffer,
|
||||||
|
CURLFORM_PTRCONTENTS, buffer, CURLFORM_NAMELENGTH,
|
||||||
|
namelength, CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add name/ptrcontent/contenttype section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "html_code_with_hole",
|
||||||
|
CURLFORM_PTRCONTENTS, htmlbuffer,
|
||||||
|
CURLFORM_CONTENTSLENGTH, htmlbufferlength,
|
||||||
|
CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add simple file section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture",
|
||||||
|
CURLFORM_FILE, "my-face.jpg", CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add file/contenttype section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture",
|
||||||
|
CURLFORM_FILE, "my-face.jpg",
|
||||||
|
CURLFORM_CONTENTTYPE, "image/jpeg", CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add two file section */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
|
||||||
|
CURLFORM_FILE, "my-face.jpg",
|
||||||
|
CURLFORM_FILE, "your-face.jpg", CURLFORM_END);
|
||||||
|
|
||||||
|
/* Add two file section using CURLFORM_ARRAY */
|
||||||
|
forms[0].option = CURLFORM_FILE;
|
||||||
|
forms[0].value = file1;
|
||||||
|
forms[1].option = CURLFORM_FILE;
|
||||||
|
forms[1].value = file2;
|
||||||
|
forms[2].option = CURLFORM_END;
|
||||||
|
|
||||||
|
/* Add a buffer to upload */
|
||||||
|
curl_formadd(&post, &last,
|
||||||
|
CURLFORM_COPYNAME, "name",
|
||||||
|
CURLFORM_BUFFER, "data",
|
||||||
|
CURLFORM_BUFFERPTR, record,
|
||||||
|
CURLFORM_BUFFERLENGTH, record_length,
|
||||||
|
CURLFORM_END);
|
||||||
|
|
||||||
|
/* no option needed for the end marker */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
|
||||||
|
CURLFORM_ARRAY, forms, CURLFORM_END);
|
||||||
|
/* Add the content of a file as a normal post text value */
|
||||||
|
curl_formadd(&post, &last, CURLFORM_COPYNAME, "filecontent",
|
||||||
|
CURLFORM_FILECONTENT, ".bashrc", CURLFORM_END);
|
||||||
|
/* Set the form info */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPPOST, post);
|
||||||
|
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_easy_setopt "(3), "
|
||||||
|
.BR curl_formparse "(3) [deprecated], "
|
||||||
|
.BR curl_formfree "(3)"
|
||||||
|
.SH BUGS
|
||||||
|
Surely there are some, you tell me!
|
||||||
|
|
17
docs/libcurl/curl_free.3
Normal file
17
docs/libcurl/curl_free.3
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id:
|
||||||
|
.\"
|
||||||
|
.TH curl_free 3 "12 Aug 2003" "libcurl 7.10" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_free - reclaim memory that has been obtained through a libcurl call
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "void curl_free( char *" ptr " );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
curl_free reclaims memory that has been obtained through a libcurl call.
|
||||||
|
Use curl_free() instead of free() to avoid anomalies that can result from differences in memory management between your application and libcurl.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.I curl_unescape()
|
20
docs/libcurl/curl_multi_add_handle.3
Normal file
20
docs/libcurl/curl_multi_add_handle.3
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_add_handle 3 "4 March 2002" "libcurl 7.9.5" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_add_handle - add an easy handle to a multi session
|
||||||
|
.SH SYNOPSIS
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
CURLMcode curl_multi_add_handle(CURLM *multi_handle, CURL *easy_handle);
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
Adds a standard easy handle to the multi stack. This will make this multi
|
||||||
|
handle control the specified easy handle.
|
||||||
|
|
||||||
|
When an easy handle has been added to a multi stack, you can not and you must
|
||||||
|
not use curl_easy_perform() on that handle!
|
||||||
|
.SH RETURN VALUE
|
||||||
|
CURLMcode type, general libcurl multi interface error code.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_cleanup "(3)," curl_multi_init "(3)"
|
18
docs/libcurl/curl_multi_cleanup.3
Normal file
18
docs/libcurl/curl_multi_cleanup.3
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_cleanup 3 "1 March 2002" "libcurl 7.9.5" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_cleanup - close down a multi session
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURLMcode curl_multi_cleanup( CURLM *multi_handle );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
Cleans up and removes a whole multi stack. It does not free or touch any
|
||||||
|
individual easy handles in any way - they still need to be closed
|
||||||
|
individually, using the usual curl_easy_cleanup() way.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
CURLMcode type, general libcurl multi interface error code.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_init "(3)," curl_easy_cleanup "(3)," curl_easy_init "(3)"
|
27
docs/libcurl/curl_multi_fdset.3
Normal file
27
docs/libcurl/curl_multi_fdset.3
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_fdset 3 "3 May 2002" "libcurl 7.9.5" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_fdset - extracts file descriptor information from a multi handle
|
||||||
|
.SH SYNOPSIS
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
CURLMcode curl_multi_fdset(CURLM *multi_handle,
|
||||||
|
fd_set *read_fd_set,
|
||||||
|
fd_set *write_fd_set,
|
||||||
|
fd_set *exc_fd_set,
|
||||||
|
int *max_fd);
|
||||||
|
.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() or
|
||||||
|
poll() on. The curl_multi_perform() 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.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
CURLMcode type, general libcurl multi interface error code.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_cleanup "(3)," curl_multi_init "(3)"
|
44
docs/libcurl/curl_multi_info_read.3
Normal file
44
docs/libcurl/curl_multi_info_read.3
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_info_read 3 "27 Feb 2002" "libcurl 7.10.3" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_info_read - read multi stack informationals
|
||||||
|
.SH SYNOPSIS
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
CURLMsg *curl_multi_info_read( CURLM *multi_handle,
|
||||||
|
int *msgs_in_queue);
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
Ask the multi handle if there are any messages/informationals from the
|
||||||
|
individual transfers. Messages may include informationals such as an error
|
||||||
|
code from the transfer or just the fact that a transfer is completed. More
|
||||||
|
details on these should be written down as well.
|
||||||
|
|
||||||
|
Repeated calls to this function will return a new struct each time, until a
|
||||||
|
NULL is returned as a signal that there is no more to get at this point. The
|
||||||
|
integer pointed to with \fImsgs_in_queue\fP will contain the number of
|
||||||
|
remaining messages after this function was called.
|
||||||
|
|
||||||
|
The data the returned pointer points to will not survive calling
|
||||||
|
curl_multi_cleanup().
|
||||||
|
|
||||||
|
The 'CURLMsg' struct is very simple and only contain very basic informations.
|
||||||
|
If more involved information is wanted, the particular "easy handle" in
|
||||||
|
present in that struct and can thus be used in subsequent regular
|
||||||
|
curl_easy_getinfo() calls (or similar):
|
||||||
|
|
||||||
|
struct CURLMsg {
|
||||||
|
CURLMSG msg; /* what this message means */
|
||||||
|
CURL *easy_handle; /* the handle it concerns */
|
||||||
|
union {
|
||||||
|
void *whatever; /* message-specific data */
|
||||||
|
CURLcode result; /* return code for transfer */
|
||||||
|
} data;
|
||||||
|
};
|
||||||
|
.SH "RETURN VALUE"
|
||||||
|
A pointer to a filled-in struct, or NULL if it failed or ran out of
|
||||||
|
structs. It also writes the number of messages left in the queue (after this
|
||||||
|
read) in the integer the second argument points to.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_cleanup "(3), " curl_multi_init "(3), " curl_multi_perform "(3)"
|
22
docs/libcurl/curl_multi_init.3
Normal file
22
docs/libcurl/curl_multi_init.3
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_init 3 "1 March 2002" "libcurl 7.9.5" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_init - Start a multi session
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURLM *curl_multi_init( );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function returns a CURLM handle to be used as input to all the other
|
||||||
|
multi-functions, sometimes refered to as a multi handle on some places in the
|
||||||
|
documentation. This init call MUST have a corresponding call to
|
||||||
|
\fIcurl_multi_cleanup\fP when the operation is complete.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
If this function returns NULL, something went wrong and you cannot use the
|
||||||
|
other curl functions.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_cleanup "(3)," curl_global_init "(3)," curl_easy_init "(3)"
|
||||||
|
.SH BUGS
|
||||||
|
Surely there are some, you tell me!
|
36
docs/libcurl/curl_multi_perform.3
Normal file
36
docs/libcurl/curl_multi_perform.3
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_perform 3 "1 March 2002" "libcurl 7.9.5" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_perform - reads/writes available data from each easy handle
|
||||||
|
.SH SYNOPSIS
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
CURLMcode curl_multi_perform(CURLM *multi_handle, int *running_handles);
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
When the app thinks there's data available for the multi_handle, it should
|
||||||
|
call this function to read/write whatever there is to read or write right
|
||||||
|
now. curl_multi_perform() returns as soon as the reads/writes are done. This
|
||||||
|
function does not require that there actually is any data available for
|
||||||
|
reading or that data can be written, it can be called just in case. It will
|
||||||
|
write the number of handles that still transfer data in the second argument's
|
||||||
|
integer-pointer.
|
||||||
|
.SH "RETURN VALUE"
|
||||||
|
CURLMcode type, general libcurl multi interface error code.
|
||||||
|
|
||||||
|
If you receive \fICURLM_CALL_MULTI_PERFORM\fP, this basicly means that you
|
||||||
|
should call \fIcurl_multi_perform\fP again, before you select() on more
|
||||||
|
actions. You don't have to do it immediately, but the return code means that
|
||||||
|
libcurl may have more data available to return or that there may be more data
|
||||||
|
to send off before it is "satisfied".
|
||||||
|
|
||||||
|
NOTE that this only returns errors etc regarding the whole multi stack. There
|
||||||
|
might still have occurred problems on invidual transfers even when this
|
||||||
|
function returns OK.
|
||||||
|
.SH "TYPICAL USAGE"
|
||||||
|
Most application will use \fIcurl_multi_fdset\fP to get the multi_handle's
|
||||||
|
file descriptors, then it'll wait for action on them using select() and as
|
||||||
|
soon as one or more of them are ready, \fIcurl_multi_perform\fP gets called.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_cleanup "(3)," curl_multi_init "(3)"
|
23
docs/libcurl/curl_multi_remove_handle.3
Normal file
23
docs/libcurl/curl_multi_remove_handle.3
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_multi_remove_handle 3 "6 March 2002" "libcurl 7.9.5" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_multi_remove_handle - remove an easy handle from a multi session
|
||||||
|
.SH SYNOPSIS
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
CURLMcode curl_multi_remove_handle(CURLM *multi_handle, CURL *easy_handle);
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
Removes a given easy_handle from the multi_handle. This will make the
|
||||||
|
specified easy handle be removed from this multi handle's control.
|
||||||
|
|
||||||
|
When the easy handle has been removed from a multi stack, it is again
|
||||||
|
perfectly legal to invoke \fIcurl_easy_perform()\fP on this easy handle.
|
||||||
|
|
||||||
|
Removing a handle while being used, will effectively halt all transfers in
|
||||||
|
progress.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
CURLMcode type, general libcurl multi interface error code.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_multi_cleanup "(3)," curl_multi_init "(3)"
|
19
docs/libcurl/curl_share_cleanup.3
Normal file
19
docs/libcurl/curl_share_cleanup.3
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_share_cleanup 3 "8 Aug 2003" "libcurl 7.10.7" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_share_cleanup - Clean up a shared object
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURLSHcode curl_share_cleanup( );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function deletes a shared object. The share handle cannot be used anymore
|
||||||
|
when this function has been called.
|
||||||
|
|
||||||
|
.SH RETURN VALUE
|
||||||
|
If this function returns non-zero, the object was not properly deleted and it
|
||||||
|
still remains!
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_share_init "(3), " curl_share_setopt "(3)"
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user