Compare commits
1427 Commits
pre-header
...
curl-7_9_3
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
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 | ||
|
|
6aaee5f23b | ||
|
|
dd06dcebe1 | ||
|
|
b35c26b751 | ||
|
|
128f341635 | ||
|
|
e48bc1be48 | ||
|
|
0077b9c0a2 | ||
|
|
fe37fb5921 | ||
|
|
221ecd0a30 | ||
|
|
560492707d | ||
|
|
dfdf4916fa | ||
|
|
97a8c98886 | ||
|
|
62fb70e9d1 | ||
|
|
8a9098a36c | ||
|
|
28027c2aa2 | ||
|
|
d60029d66e | ||
|
|
226fe8bdf9 | ||
|
|
33237b4502 | ||
|
|
af6c394785 | ||
|
|
558d12d7f6 | ||
|
|
bfa8a6da26 | ||
|
|
aa6b3d22a2 | ||
|
|
2eb355733f | ||
|
|
e66cdacb93 | ||
|
|
c67f2da283 | ||
|
|
e192261788 | ||
|
|
c63ca99c1c | ||
|
|
1c99c4ad11 | ||
|
|
bbcfc10677 | ||
|
|
47e67eab26 | ||
|
|
650b95045d | ||
|
|
5603134e58 | ||
|
|
d12fd897cb | ||
|
|
5e95203a5d | ||
|
|
cad4a571ce | ||
|
|
139ab3740a | ||
|
|
7b832e1745 | ||
|
|
914b9e441b | ||
|
|
f0f6ab49f5 | ||
|
|
436d147925 | ||
|
|
4bd78a7df4 | ||
|
|
7ee6a9dc25 | ||
|
|
1b56ae8478 | ||
|
|
d52c0b6f05 | ||
|
|
3ff2bfa0e4 | ||
|
|
aa21a3d5c3 | ||
|
|
fc33ad8cf2 | ||
|
|
779043f7a3 | ||
|
|
265bb99382 | ||
|
|
7493db2338 | ||
|
|
c3ad019c99 | ||
|
|
05b84bfe91 | ||
|
|
dbfa1e55b6 | ||
|
|
a0fd63f611 | ||
|
|
4ec0401529 | ||
|
|
61e6554b7f | ||
|
|
f6f3f79aa8 | ||
|
|
c16c017f8b | ||
|
|
2f03ef39d1 | ||
|
|
db33926432 | ||
|
|
946090b9cd | ||
|
|
1f7f0fda71 | ||
|
|
b84d947be4 | ||
|
|
07c67138c9 | ||
|
|
10717bd39b | ||
|
|
302bb4a4b3 | ||
|
|
81b5af2d1b | ||
|
|
87c562845c | ||
|
|
6c81d74626 | ||
|
|
533c24a471 | ||
|
|
6a9697387a | ||
|
|
85c8981b3d | ||
|
|
6c5b8e1d59 | ||
|
|
2cc16d89e6 | ||
|
|
42eb74922d | ||
|
|
c528a7ee33 | ||
|
|
eb2da7ec2b | ||
|
|
01ed950bbe | ||
|
|
b1076e0a9e | ||
|
|
332eb7651a | ||
|
|
cfdcf5c933 | ||
|
|
820de919b6 | ||
|
|
a32cd520bd | ||
|
|
b93a60daf9 | ||
|
|
e2844f5e04 | ||
|
|
cabb46db3d | ||
|
|
d09b436937 | ||
|
|
10fdb1d743 | ||
|
|
f0d3fccd4b | ||
|
|
aff19f64b5 | ||
|
|
15a56b42d6 | ||
|
|
d3706814e9 | ||
|
|
6513dcef68 | ||
|
|
81f22465ba | ||
|
|
dccc77a325 | ||
|
|
13ac89af24 | ||
|
|
ffefcab1bc | ||
|
|
0226b53b75 | ||
|
|
bbf80d0f93 | ||
|
|
6003f24f78 | ||
|
|
4382a80b9a | ||
|
|
9fe920cd90 | ||
|
|
f0ee7115d3 | ||
|
|
5986c653ef | ||
|
|
0e7203be89 | ||
|
|
52dbc96c32 | ||
|
|
1c8da21083 | ||
|
|
8f304d8167 | ||
|
|
30a0bd9cf5 | ||
|
|
ae40cdf92f | ||
|
|
b342fbdcda | ||
|
|
d1ea596f88 | ||
|
|
064cf971ef | ||
|
|
91b1598756 | ||
|
|
17b18bca3c | ||
|
|
be3d601217 | ||
|
|
ca0fd33d2d | ||
|
|
271f96f78f | ||
|
|
b0130e6b3b | ||
|
|
d0c1f3e25b | ||
|
|
b244710ddb | ||
|
|
d465291ded | ||
|
|
84e462d5f6 | ||
|
|
508466a175 | ||
|
|
e6dd4a6456 | ||
|
|
8d62e21072 | ||
|
|
25fe47f262 | ||
|
|
fe8365d214 | ||
|
|
2519a8cc9f | ||
|
|
b8ff21124a | ||
|
|
6aafc2dfd2 | ||
|
|
65b22480f4 | ||
|
|
60f19269d0 | ||
|
|
5121499082 | ||
|
|
3e049a90b7 | ||
|
|
c5d97df7f1 | ||
|
|
c2479ccb7a | ||
|
|
fc07eb45f4 | ||
|
|
c7cdb0f266 | ||
|
|
92aedf850e | ||
|
|
dd157fc349 | ||
|
|
05f3ca880f | ||
|
|
a18d41a463 | ||
|
|
1affbff8f9 | ||
|
|
c55d0bb804 | ||
|
|
0ffec712e1 | ||
|
|
6ebac3dc76 | ||
|
|
3b976ea9f1 | ||
|
|
2c16dfb526 | ||
|
|
fe3a78ab19 | ||
|
|
1a984ea847 | ||
|
|
2a0cde3041 | ||
|
|
3552775b52 | ||
|
|
818a632e80 | ||
|
|
00afb0f638 | ||
|
|
2e32d415c0 | ||
|
|
3dfc509d33 | ||
|
|
4379142af7 | ||
|
|
8a6dc57212 | ||
|
|
af636c535c | ||
|
|
2f77b0a4c6 | ||
|
|
08ad385e0e | ||
|
|
5623e0bb0e | ||
|
|
3d438d8d64 | ||
|
|
d89c495782 | ||
|
|
f5ba174f4d | ||
|
|
329bcf3a71 | ||
|
|
0cb12d7e78 | ||
|
|
3bfa06c9a2 | ||
|
|
f34573c8e2 | ||
|
|
4163b86cd2 | ||
|
|
5b948512f9 | ||
|
|
2297a7a70c | ||
|
|
dc82f9e6df | ||
|
|
e60e7414b9 | ||
|
|
c6caa9fd60 | ||
|
|
c84ad40ccd | ||
|
|
ab7f25ab41 | ||
|
|
6d213e207d | ||
|
|
9b6545c479 | ||
|
|
96fb118251 | ||
|
|
617d6eb7ce | ||
|
|
99888388dc | ||
|
|
7d24ce9651 | ||
|
|
cbc35b1fb8 | ||
|
|
027fc719cc | ||
|
|
f6b2e9e8a4 | ||
|
|
c4f1a9f690 | ||
|
|
542055074b | ||
|
|
7b93348aae | ||
|
|
eaf475b538 | ||
|
|
4118c68df1 | ||
|
|
69d5d88259 | ||
|
|
7e6a36ea7b | ||
|
|
6878c0b88f | ||
|
|
bbdc9f15e7 | ||
|
|
ae4f8243a9 | ||
|
|
1c83dee948 | ||
|
|
b66dedc017 | ||
|
|
b07e2a08f9 | ||
|
|
64543e09ec | ||
|
|
58936efff6 | ||
|
|
dbd32278f8 | ||
|
|
6d35984286 | ||
|
|
c046dc904c | ||
|
|
bc8375a1e8 | ||
|
|
83877d5ec6 | ||
|
|
3f248dd163 | ||
|
|
c9954d1941 | ||
|
|
e165332211 | ||
|
|
d25310cb6f | ||
|
|
fbb9d23a25 | ||
|
|
2d32e8831b | ||
|
|
42a9d96fae | ||
|
|
3edd9b4dfc | ||
|
|
1a8cf79ae0 | ||
|
|
b736bdc8e5 | ||
|
|
babb985f1a | ||
|
|
b22a5f756c | ||
|
|
d733061873 | ||
|
|
bca0c8d253 | ||
|
|
53ac8004e7 | ||
|
|
7b76499e82 | ||
|
|
9f45190fa1 | ||
|
|
f933cb3b75 | ||
|
|
c6822f5a7f | ||
|
|
4e276b1b68 | ||
|
|
50e9f8ffd3 | ||
|
|
7d3daa598f | ||
|
|
7349940bdb | ||
|
|
78000dbd5d | ||
|
|
b585f411cd | ||
|
|
5ccd6bb842 | ||
|
|
5193894603 | ||
|
|
29b76a52fb | ||
|
|
0436bc22f2 | ||
|
|
cd16efa2f2 | ||
|
|
56562bad59 | ||
|
|
a26081b555 | ||
|
|
aa9c01ad3e | ||
|
|
4e37187e44 | ||
|
|
74d5a6fb3b | ||
|
|
83da58ce91 | ||
|
|
45cc78fdbc | ||
|
|
010044e03c | ||
|
|
db0e3cc60c | ||
|
|
8dd6a4e369 | ||
|
|
92abbcef4c | ||
|
|
1e8f0c5771 | ||
|
|
532bca41e5 | ||
|
|
b438c46764 | ||
|
|
ef48c73783 | ||
|
|
2c5e416591 | ||
|
|
8e91d5de8e | ||
|
|
2f85f3b147 | ||
|
|
20a47acb3a | ||
|
|
6bc85a94f9 | ||
|
|
71bf8a6985 | ||
|
|
59a76e4010 | ||
|
|
65b9c0d44d | ||
|
|
f2a25966cf | ||
|
|
51afc3d8c5 | ||
|
|
0c2f60036a | ||
|
|
3dcdcfc572 | ||
|
|
9f8c51cbd8 | ||
|
|
de79348a90 | ||
|
|
56bc31e9f9 | ||
|
|
a9181f8f00 | ||
|
|
3685f792cb | ||
|
|
e227a276ce | ||
|
|
7b5b60d275 | ||
|
|
e719f4169c | ||
|
|
d8fb2b2e63 | ||
|
|
fdeaae678d | ||
|
|
f30102f038 | ||
|
|
a27ac6f394 | ||
|
|
093c0a098e | ||
|
|
c3363f833c | ||
|
|
47def8091c | ||
|
|
cfb32ec0cd | ||
|
|
5d9ae88f58 | ||
|
|
9d066935e5 | ||
|
|
bc40063e07 | ||
|
|
3c92d45386 | ||
|
|
fcf4fccfa4 | ||
|
|
eafd2c6bd5 | ||
|
|
64f00454e5 | ||
|
|
d678727430 | ||
|
|
efc15fb128 | ||
|
|
3d4cd8c9aa | ||
|
|
420259993e | ||
|
|
66087bdac6 | ||
|
|
ac70a43452 | ||
|
|
72dbe9da72 | ||
|
|
dd02881788 | ||
|
|
ced8955325 | ||
|
|
51ca5fcbe0 | ||
|
|
56ff2aa059 | ||
|
|
9f77771ff9 | ||
|
|
f0fa858885 | ||
|
|
3298630500 | ||
|
|
dc27488c47 | ||
|
|
375e615a6d | ||
|
|
6918427fae | ||
|
|
9d342bbf07 | ||
|
|
afc81ada0c | ||
|
|
5cd267b2be | ||
|
|
09da90076f | ||
|
|
d0079d9054 | ||
|
|
ede5b54edc | ||
|
|
c5fdeef41d | ||
|
|
6ca45beaed | ||
|
|
2a07626aa8 | ||
|
|
9127554852 | ||
|
|
9ff28a8237 | ||
|
|
e9aa07f660 | ||
|
|
88e21894c7 | ||
|
|
09da2c1767 | ||
|
|
ae2ecfc5cb | ||
|
|
cc610f0d1f | ||
|
|
8333644c84 | ||
|
|
4d13b2cc64 | ||
|
|
48dc74aecc | ||
|
|
888d39e083 | ||
|
|
7239ecd456 | ||
|
|
598e8dfbfb | ||
|
|
9efdb68035 | ||
|
|
14b898cb05 | ||
|
|
8d16b2b119 | ||
|
|
4d2cb8b32a | ||
|
|
d5001a3f0b | ||
|
|
91f5ac4d5c | ||
|
|
f9977df50d | ||
|
|
711650b178 | ||
|
|
c9adbc9f1c | ||
|
|
611fbfa917 | ||
|
|
ecfacfb334 | ||
|
|
645413f5ef | ||
|
|
5becdc38b3 | ||
|
|
f36cea67fe | ||
|
|
b556d6caee | ||
|
|
a17a78c477 | ||
|
|
146413a53c | ||
|
|
437fd064c9 | ||
|
|
28dd4e4f1f | ||
|
|
f92dc70beb | ||
|
|
6d8f1328bf | ||
|
|
8d1d93d56d | ||
|
|
f8e102c485 | ||
|
|
d816fcc965 | ||
|
|
e30dcd0501 | ||
|
|
24dc7cffbd | ||
|
|
3bc83926ce | ||
|
|
c5cca4d059 | ||
|
|
0db04c4f56 | ||
|
|
5c566c9aa3 | ||
|
|
822f02313d | ||
|
|
d934890c1e | ||
|
|
0e25cf41c4 | ||
|
|
5214dbbd02 | ||
|
|
0c716d51ad | ||
|
|
86367d675a | ||
|
|
bd8cef5a70 | ||
|
|
708431e2ea | ||
|
|
db5c1c61e5 | ||
|
|
aa4ff6d8b9 | ||
|
|
6d5b8b50e1 | ||
|
|
600d7b11e6 | ||
|
|
afa7648be6 | ||
|
|
5c344fc23a | ||
|
|
5a905e0bb8 | ||
|
|
c31216949d | ||
|
|
2cb893575d | ||
|
|
63f1f58077 | ||
|
|
36e9507e29 | ||
|
|
1fde1431c9 | ||
|
|
bec97a0999 | ||
|
|
07de3c9df0 | ||
|
|
8950a2dfa1 | ||
|
|
be47d83555 | ||
|
|
d5054ad52d | ||
|
|
051fad8d88 | ||
|
|
c4532b9a07 | ||
|
|
0e7824d1a9 | ||
|
|
a2c78607a6 | ||
|
|
cc1a4edf3d | ||
|
|
db7bde1d7a | ||
|
|
719008596a | ||
|
|
377e78d917 | ||
|
|
894b47da9b | ||
|
|
54e7246342 | ||
|
|
9b3b050640 | ||
|
|
a0e389caa2 | ||
|
|
b747408f9e | ||
|
|
d3e55d8155 | ||
|
|
96c7253cea | ||
|
|
3f5227dfc7 | ||
|
|
b91103099a | ||
|
|
82d3ded922 | ||
|
|
5a8d1c4cd1 | ||
|
|
46372c04ee | ||
|
|
6147879837 | ||
|
|
e2e3c95d3b | ||
|
|
c3b448dcea | ||
|
|
86da31e031 | ||
|
|
1d7075e339 | ||
|
|
610ec27d93 | ||
|
|
70f2717c11 | ||
|
|
b31a54c46a | ||
|
|
08238f4320 | ||
|
|
06993556f3 | ||
|
|
144459d364 | ||
|
|
0fa61eff77 | ||
|
|
a0be515d2d | ||
|
|
5900c0f767 | ||
|
|
d10cf2ba94 | ||
|
|
bae1a75731 | ||
|
|
f5adc8e53f | ||
|
|
67df4c9e6c | ||
|
|
50adfe3be9 | ||
|
|
71794da389 | ||
|
|
6ef11f0b13 | ||
|
|
a5705acc9c | ||
|
|
47e7a3e678 | ||
|
|
0ece1b5c34 | ||
|
|
315954c175 | ||
|
|
27ce46a85d | ||
|
|
ea3cc81487 | ||
|
|
a9b139b25c | ||
|
|
bbdd5adf6e | ||
|
|
d425f5389d | ||
|
|
26983053c4 | ||
|
|
8e0043165a | ||
|
|
c13dbf7bae | ||
|
|
a2b6ef3478 | ||
|
|
b6526af442 | ||
|
|
4edba42c7c | ||
|
|
1180ef4b31 | ||
|
|
94bf462473 | ||
|
|
233b3f718f | ||
|
|
0452fd8657 | ||
|
|
613eafaf02 | ||
|
|
725bd1dddf | ||
|
|
9835629801 | ||
|
|
3c52c53ddd | ||
|
|
321ba15a82 | ||
|
|
9e5dfc15ac | ||
|
|
8d52681e1d | ||
|
|
56f6815d3d | ||
|
|
ce07e79f3c | ||
|
|
723ced9336 | ||
|
|
73417b59c7 | ||
|
|
f4e2774ab8 | ||
|
|
d5112c0dec | ||
|
|
aace68c91b | ||
|
|
4034f31823 | ||
|
|
5323340cae | ||
|
|
3aae2ec511 | ||
|
|
df09214c62 | ||
|
|
12acab9b86 | ||
|
|
c9c2115088 | ||
|
|
d73d28a75b | ||
|
|
13bf964b78 | ||
|
|
3fb9c5727c | ||
|
|
b69f33ed44 | ||
|
|
56e8d073bf | ||
|
|
83a8786fe1 | ||
|
|
e3d7cc895b | ||
|
|
0f425b01aa | ||
|
|
c5a4b52d83 | ||
|
|
fc2d24105c | ||
|
|
6704d44dd4 | ||
|
|
3d9aeccc90 | ||
|
|
08655d8d5d | ||
|
|
3e5dbac7a2 | ||
|
|
05d9c9b849 | ||
|
|
4c2fb64e21 | ||
|
|
46a897f604 | ||
|
|
d4b23198fa | ||
|
|
6581663687 | ||
|
|
4398151fd5 | ||
|
|
d5fbfa3d0b | ||
|
|
3a588fc9e7 | ||
|
|
7dbad3c382 | ||
|
|
8f55c3d47d | ||
|
|
732d80a770 | ||
|
|
bd277e3daa | ||
|
|
a1cec0e49a | ||
|
|
9027005411 | ||
|
|
1d3542a38f | ||
|
|
429b09ee04 | ||
|
|
6c2a9009e9 | ||
|
|
1b00298b52 | ||
|
|
5ad4a52281 | ||
|
|
db5e67e34a | ||
|
|
a2688b6ca1 | ||
|
|
ceb8f1cb22 | ||
|
|
a7a3d49996 | ||
|
|
c36fc521bd | ||
|
|
ca43cd46a7 | ||
|
|
47ff6f29f4 | ||
|
|
861ca06f11 | ||
|
|
d9e54a3cdf | ||
|
|
32eaf9e83a | ||
|
|
9ce94207e2 | ||
|
|
9518e06413 | ||
|
|
aa21e42d5b | ||
|
|
16215e80d2 | ||
|
|
658c7e8afc | ||
|
|
666d0b67d1 | ||
|
|
97f3099ff6 | ||
|
|
5a0a51a7ac | ||
|
|
38783506fe | ||
|
|
70ad8a0b2b | ||
|
|
cec8a3afb2 | ||
|
|
f78de2d8c1 | ||
|
|
7d17713d62 | ||
|
|
546f4dca52 | ||
|
|
09a9b57bae | ||
|
|
10ab082188 | ||
|
|
4999087879 | ||
|
|
bff5f1b944 | ||
|
|
6e22b74253 | ||
|
|
a547f3a21e | ||
|
|
db9bb9221f | ||
|
|
7994817185 | ||
|
|
5ce97dbf0a | ||
|
|
0879515d4c | ||
|
|
2a6e1ea83c | ||
|
|
ea6d35d973 | ||
|
|
a80f65c578 | ||
|
|
7751756636 | ||
|
|
2de6d8baf6 | ||
|
|
b8c69928db | ||
|
|
b73746ae43 | ||
|
|
ca06bbe583 | ||
|
|
a9665b092b | ||
|
|
1ad7023758 | ||
|
|
1a7e13e166 | ||
|
|
3a37c0ae23 | ||
|
|
ccb3a13ce6 | ||
|
|
94a3886455 | ||
|
|
616d8eda41 | ||
|
|
85bb25e628 | ||
|
|
83a5e39065 | ||
|
|
bd0afd8db4 | ||
|
|
2d68ea45d8 | ||
|
|
5f42ef8f5b | ||
|
|
dff0145447 | ||
|
|
8e1f95ac7d | ||
|
|
95e7e551f6 | ||
|
|
5afc694879 | ||
|
|
b1c57788f3 | ||
|
|
3d4bb3be22 | ||
|
|
0c063f85fc | ||
|
|
c11a1bf72a | ||
|
|
f195502064 | ||
|
|
4df9d94414 | ||
|
|
9a7fc9ce3a | ||
|
|
9fa464aa94 | ||
|
|
d95ed06aa9 | ||
|
|
5abe5f664a | ||
|
|
e9e5197cea | ||
|
|
7b4b166718 | ||
|
|
e32641d412 | ||
|
|
1603f64771 | ||
|
|
c8926138d1 | ||
|
|
ab6c8a06e0 | ||
|
|
f35b6e90f5 | ||
|
|
b49565308f | ||
|
|
f8c357e4ff | ||
|
|
4b6c240832 | ||
|
|
022ea42265 | ||
|
|
b54b68ac7b | ||
|
|
1ddf2907c7 | ||
|
|
33dc9c1f95 | ||
|
|
f112cc14b9 | ||
|
|
5de39884c3 | ||
|
|
e840c109e7 | ||
|
|
f1ce203686 | ||
|
|
d6ccc33dec | ||
|
|
1b2f4031e1 | ||
|
|
64822958e6 | ||
|
|
af59b9b94c | ||
|
|
59ab21ed07 | ||
|
|
edec65246a | ||
|
|
95837043e2 | ||
|
|
dcfb10fb31 | ||
|
|
0553ab8181 | ||
|
|
410dd54da7 | ||
|
|
7b9ec9507f | ||
|
|
4045cd5ec0 | ||
|
|
81b6ebc0f4 | ||
|
|
56da5a05be | ||
|
|
c528dc53c9 | ||
|
|
ed786290e2 | ||
|
|
8b2861da85 | ||
|
|
2a70465434 | ||
|
|
d60cd937b7 | ||
|
|
76125e196c | ||
|
|
8219990012 | ||
|
|
f8d09660cd | ||
|
|
823fa6d273 | ||
|
|
2cf45f68b0 | ||
|
|
7950a95401 | ||
|
|
24805e17d7 | ||
|
|
490d46affb | ||
|
|
d30c478378 | ||
|
|
5b6640960a | ||
|
|
6f543f3ede | ||
|
|
93bcfd4e65 | ||
|
|
1400561a5a | ||
|
|
8dc4ac2147 | ||
|
|
7948b0becc | ||
|
|
72e67d3b9d | ||
|
|
711a3a79e3 | ||
|
|
a6a3673804 | ||
|
|
944f9a73f4 | ||
|
|
5ab1a10e9c | ||
|
|
1813d2ddf7 | ||
|
|
2827f5327a | ||
|
|
47bb09e908 | ||
|
|
7f21669ef2 | ||
|
|
3a145180cc | ||
|
|
f24d54a9c4 | ||
|
|
9478d796a3 | ||
|
|
00b00c6931 | ||
|
|
e791f6ec58 | ||
|
|
8987244758 | ||
|
|
9b69f6faab | ||
|
|
e7b966b9eb | ||
|
|
e7801afed1 | ||
|
|
929366b5ae | ||
|
|
e1d8c5daa7 | ||
|
|
2b44fdab2e | ||
|
|
3e0a95bb78 | ||
|
|
f0efa89484 | ||
|
|
45037a39aa | ||
|
|
31336d63ae | ||
|
|
2c39a4381a | ||
|
|
532624bafe | ||
|
|
8469918306 | ||
|
|
9646a8b346 | ||
|
|
5e2a74fcc4 | ||
|
|
813d7585c7 | ||
|
|
ae55c1c144 | ||
|
|
1a6143feba | ||
|
|
b70a4227b3 | ||
|
|
7d82bc81a2 | ||
|
|
be449bdea1 | ||
|
|
798aaf0c0a | ||
|
|
6f2fca53ad | ||
|
|
cd4aed6690 | ||
|
|
fa601af722 | ||
|
|
303b3cf41c | ||
|
|
fc535aa086 | ||
|
|
cd33795903 | ||
|
|
c9d233d34a | ||
|
|
bd192d5387 | ||
|
|
4ac7a087c6 | ||
|
|
2d5039184e | ||
|
|
b1bbaebb17 | ||
|
|
8f6997cbde | ||
|
|
e18ecaf108 | ||
|
|
fe67ba6d2b | ||
|
|
e39e6c537e | ||
|
|
4e4a899306 | ||
|
|
9a78db6e59 | ||
|
|
6475600afa | ||
|
|
e450888b15 | ||
|
|
23522a66d1 | ||
|
|
116462a512 | ||
|
|
217e033120 | ||
|
|
259ac2dd77 | ||
|
|
4ebf001d37 | ||
|
|
5e326014cd | ||
|
|
0b0bbffa35 | ||
|
|
2b35432fcc | ||
|
|
ef8a2bc4fc | ||
|
|
96d235d9a3 | ||
|
|
eaf51b62b9 | ||
|
|
80994a123e | ||
|
|
b1cd033c27 | ||
|
|
268867311e | ||
|
|
6840f80d21 | ||
|
|
cac6876734 | ||
|
|
753011c8db | ||
|
|
2774dc390a | ||
|
|
eb4534f735 | ||
|
|
efb957039d | ||
|
|
fe82ddda46 | ||
|
|
94af496ac4 | ||
|
|
6f17c2f140 | ||
|
|
490c00fb30 | ||
|
|
2d0dbd87c3 | ||
|
|
13a5e16f35 | ||
|
|
3d54ba1b9e | ||
|
|
e051f904f2 | ||
|
|
f8d94a3849 | ||
|
|
ac691cae88 | ||
|
|
43d0d75688 | ||
|
|
77f34915ce | ||
|
|
72b8993164 | ||
|
|
6b9bd96c06 | ||
|
|
6532f737eb | ||
|
|
928ff54388 | ||
|
|
95c94bf658 | ||
|
|
7f295939d0 | ||
|
|
aa27db6986 | ||
|
|
4ce5fa3ea9 | ||
|
|
ffa7c13117 | ||
|
|
fbca7a83fc | ||
|
|
870bacd689 | ||
|
|
d9f39cc99b | ||
|
|
f2e6d235f2 | ||
|
|
baa220c1af | ||
|
|
cabef4732d | ||
|
|
cab90bf98a | ||
|
|
ab449cce73 | ||
|
|
b541537c66 | ||
|
|
285e998fae | ||
|
|
c503930b8d | ||
|
|
5c6859e537 | ||
|
|
4e376a2f1a | ||
|
|
edd608aa76 | ||
|
|
88d536eb3b | ||
|
|
d567659bf4 | ||
|
|
e0558ae541 | ||
|
|
034f6378da | ||
|
|
af129c499e | ||
|
|
8b4809a898 | ||
|
|
88d14e96ca | ||
|
|
04d1491a6b | ||
|
|
de16ddd5b4 | ||
|
|
27751df6ec | ||
|
|
cf02eb11f6 | ||
|
|
22b8d387bc | ||
|
|
bfd89c8078 | ||
|
|
223c48e6b5 | ||
|
|
7bb7550e23 | ||
|
|
adf00f5b2e | ||
|
|
0844c4fdb2 | ||
|
|
38cabc4fdb | ||
|
|
ec340e3e33 | ||
|
|
f44f512f24 | ||
|
|
ce0e2cc017 | ||
|
|
b082832220 | ||
|
|
1e5e0f9a26 | ||
|
|
ac3ae8f775 | ||
|
|
a51fd91db2 | ||
|
|
d300cf4d84 | ||
|
|
a9d0a85842 | ||
|
|
81da4fc995 | ||
|
|
b6ca1be1cd | ||
|
|
20d67917c4 | ||
|
|
915b10052c | ||
|
|
d3516810a7 | ||
|
|
68af9a222e | ||
|
|
58c3bdc1a4 | ||
|
|
72dec6cfec | ||
|
|
8dc9f4330c | ||
|
|
c77f77a1ce | ||
|
|
2966ef6661 | ||
|
|
93c53424c8 | ||
|
|
4a2812c5e8 | ||
|
|
4852a4930c | ||
|
|
b555ca5baa | ||
|
|
4a6eaf1b95 | ||
|
|
a8bc40fe4e | ||
|
|
1b9e26a287 | ||
|
|
9f24645a5b | ||
|
|
441a957d57 | ||
|
|
adc0edc44b | ||
|
|
4836154cef | ||
|
|
0058e87ed5 | ||
|
|
23903306a7 | ||
|
|
49b9926d5a | ||
|
|
6c50d2ee7d | ||
|
|
9e8615ae1d | ||
|
|
bb51c20c8b | ||
|
|
a84af986fd | ||
|
|
3ab3be1b6e | ||
|
|
3ceb2bcbb9 | ||
|
|
2457a31948 | ||
|
|
9e1e318691 | ||
|
|
e1132ecbe6 | ||
|
|
ccb92f1a8a | ||
|
|
8526fa97ce | ||
|
|
f85c29aad8 | ||
|
|
4677f733b2 | ||
|
|
e82d2dc634 | ||
|
|
b56f1e5185 | ||
|
|
c7c942861a | ||
|
|
a50fac0e63 | ||
|
|
e0f56897d5 | ||
|
|
c7dbde9f3f | ||
|
|
8fd89d6b93 | ||
|
|
632e951e14 | ||
|
|
a3a2d200fa | ||
|
|
4c2ca97d6d | ||
|
|
11f2464a22 | ||
|
|
291075b12f | ||
|
|
282939c6fe | ||
|
|
fef1fc0d32 | ||
|
|
dc6da007ad | ||
|
|
7be8993f94 | ||
|
|
bad4c8967b | ||
|
|
4dbac041f1 | ||
|
|
dd344b65f2 | ||
|
|
5c25c7bbfa | ||
|
|
a6d9ccf66b | ||
|
|
89ba66e071 | ||
|
|
85631150ce | ||
|
|
3654bd1b56 | ||
|
|
237edbc9d8 | ||
|
|
4127903183 | ||
|
|
2ffc20dc7c | ||
|
|
a2a446cb2f | ||
|
|
9304055df5 | ||
|
|
53e0c1b1a6 | ||
|
|
4efa1e8e4c | ||
|
|
ecba113125 | ||
|
|
350c536f6c | ||
|
|
a33eb9881c | ||
|
|
bbe8aa073e | ||
|
|
14521b418e | ||
|
|
73982c65d2 | ||
|
|
2eb94acb95 | ||
|
|
6a80fb3482 | ||
|
|
26d4c80049 | ||
|
|
3974f30ed4 | ||
|
|
44c246dbf2 | ||
|
|
ef07903a51 | ||
|
|
a7dc45997f | ||
|
|
583c2e2f09 | ||
|
|
90cce2ae3a | ||
|
|
775dc07eb5 | ||
|
|
a652db18bd | ||
|
|
48f3feed59 | ||
|
|
4ddb3fbbf4 | ||
|
|
cc872ebc19 | ||
|
|
ba46006896 | ||
|
|
0b7e0638a9 | ||
|
|
be49b01952 | ||
|
|
8d0c1d5495 | ||
|
|
2769a9ab0b | ||
|
|
8ea5b5bbd0 | ||
|
|
0ce49cb7ed | ||
|
|
d802dfe86a | ||
|
|
aabc0c08a1 | ||
|
|
476addb9c1 | ||
|
|
37d7a198d5 | ||
|
|
16fe0c9be3 | ||
|
|
f88ff705a4 | ||
|
|
e83550f511 | ||
|
|
fde31f0988 | ||
|
|
d3090ac3f9 | ||
|
|
2cf26d4fb7 | ||
|
|
f470a131a6 | ||
|
|
04b20b7ed2 | ||
|
|
ff4f4abe4b | ||
|
|
f4703aee2f | ||
|
|
4c485994db | ||
|
|
a921ee7b52 | ||
|
|
f6d4a25f68 | ||
|
|
2dfd2c642d | ||
|
|
a2072a1fd0 | ||
|
|
03fea9722c | ||
|
|
a44a8cef99 | ||
|
|
97ad165a63 | ||
|
|
a508e73a8d | ||
|
|
32f966b239 | ||
|
|
60a43561e2 | ||
|
|
a91b7d461d | ||
|
|
8755c44d40 | ||
|
|
5dd1cb0614 | ||
|
|
b34bee45ca | ||
|
|
e22fb3e7bc | ||
|
|
6ea51f3cd7 | ||
|
|
8e9f0a73d0 | ||
|
|
80fbcdf2f2 | ||
|
|
0fd9f64287 | ||
|
|
b6175ec792 | ||
|
|
1ee7f92ce4 | ||
|
|
3fd65fb7d8 | ||
|
|
ebcafe73b3 | ||
|
|
8274bee963 | ||
|
|
60aa975610 | ||
|
|
28a9108257 | ||
|
|
d1b0b08ba0 | ||
|
|
cc7fc20251 | ||
|
|
5ab751f5d0 | ||
|
|
fb1ce5fd5b | ||
|
|
fd8ea204c0 | ||
|
|
b86674174a | ||
|
|
69994f0114 | ||
|
|
879c6c5711 | ||
|
|
18f044f19d | ||
|
|
d7b54eb835 | ||
|
|
5eafb69bdb | ||
|
|
a086e99bae | ||
|
|
62056a644f | ||
|
|
b2362bf51c | ||
|
|
022099266e | ||
|
|
870cea2aea | ||
|
|
04c10e021c | ||
|
|
d712a4e800 | ||
|
|
d9f989c8c8 | ||
|
|
90bb87b40e | ||
|
|
025fa762f6 | ||
|
|
ac510ab6a4 | ||
|
|
65b286ca35 | ||
|
|
cc5c53454a | ||
|
|
f7874cad29 | ||
|
|
84e71e1c50 | ||
|
|
88bb054e1d | ||
|
|
b054fbaebd | ||
|
|
53e3c225ee | ||
|
|
50a53d4eec | ||
|
|
6bd1ed034a | ||
|
|
fa491ed910 | ||
|
|
66a1e3df69 | ||
|
|
28497e7ee4 | ||
|
|
87c7f403a9 | ||
|
|
1a2c3acb3b | ||
|
|
b54d752783 | ||
|
|
b1328430c9 | ||
|
|
34efa74a59 | ||
|
|
794d08a728 | ||
|
|
0abc999c4d | ||
|
|
3e65062be2 | ||
|
|
45ffb16c2a | ||
|
|
0b8b0b7c86 | ||
|
|
053bf49bd2 | ||
|
|
8b08dfed38 | ||
|
|
ba3a3553dc | ||
|
|
6a26104724 | ||
|
|
8b35b89f4d | ||
|
|
31f9d4016d | ||
|
|
bb601731ea | ||
|
|
9a85172896 | ||
|
|
a0eb52bee1 | ||
|
|
6235a8d969 | ||
|
|
0d6a87ed7a | ||
|
|
b6241b3c89 | ||
|
|
1e14f8d4c7 | ||
|
|
bc5954fe2d | ||
|
|
02f6894af5 | ||
|
|
76576cd1e2 | ||
|
|
997672ba9a | ||
|
|
ec1f42a154 | ||
|
|
aa1c3bb46d | ||
|
|
95f0714ff8 | ||
|
|
c050619b36 | ||
|
|
58085dbbf6 | ||
|
|
546572da04 | ||
|
|
005536cc28 | ||
|
|
3d5b6aa3b0 | ||
|
|
f8d883355d | ||
|
|
c23df41d83 | ||
|
|
8e7b261984 | ||
|
|
08e3d034ef | ||
|
|
2f869f89ff | ||
|
|
0f310a5001 | ||
|
|
ad1abee441 | ||
|
|
669709f80e | ||
|
|
ea409d0374 | ||
|
|
eaaa1a1fd4 | ||
|
|
78b4851da1 | ||
|
|
38c47803dd | ||
|
|
455663ba5e | ||
|
|
efb5d9a403 | ||
|
|
b1a5208e6b | ||
|
|
e6dacd92ec | ||
|
|
952b3a2c0f | ||
|
|
721f9bca84 | ||
|
|
ad4d5fabf8 | ||
|
|
aa860990ad | ||
|
|
0fa9135d9f | ||
|
|
8f0114a4dd | ||
|
|
5980c2977b | ||
|
|
19f8d71508 | ||
|
|
6f3bccd911 | ||
|
|
96f81a5c4a | ||
|
|
ca05d1b59c | ||
|
|
895dc5e530 | ||
|
|
bcc6ca6fd1 | ||
|
|
d538241a58 | ||
|
|
71b4b2ffa9 | ||
|
|
65b4a63f56 | ||
|
|
ecbee01f4b | ||
|
|
34fed76a35 | ||
|
|
0adf0cfde7 | ||
|
|
d6c456db85 | ||
|
|
36c88343d3 | ||
|
|
2360e5ce12 | ||
|
|
d445eac162 | ||
|
|
e0a6d20e20 | ||
|
|
3bb979b897 | ||
|
|
010daec776 | ||
|
|
e2b0ad8429 | ||
|
|
6eed95103a | ||
|
|
4eb2a165e8 | ||
|
|
b7fc1e45b5 | ||
|
|
3395a2fa9e | ||
|
|
a564a54e21 | ||
|
|
92186dc3d3 | ||
|
|
7bd6507eec | ||
|
|
d4cc810de3 | ||
|
|
bea7bbee1b | ||
|
|
fe64570d5d | ||
|
|
df6ad8d8d6 | ||
|
|
f8e1fc32de | ||
|
|
8c6d56f1f9 | ||
|
|
1841c8ee6a | ||
|
|
70793595fe | ||
|
|
28a8e1602d | ||
|
|
cce05b9138 | ||
|
|
72a7fd4dc7 | ||
|
|
9a6a476cf5 | ||
|
|
5d0efedd2d | ||
|
|
a426818a78 | ||
|
|
bfe413d8bd | ||
|
|
dbbd20646f | ||
|
|
b8fe4deb13 | ||
|
|
332a016e3c | ||
|
|
3738e4bdc0 | ||
|
|
3201d2dafa | ||
|
|
0a1e002ca4 | ||
|
|
9195bb64d4 | ||
|
|
11ee547a0e | ||
|
|
147de35d41 | ||
|
|
e16e9b91ae | ||
|
|
f9cde0646f | ||
|
|
195233ed5c | ||
|
|
048e654514 | ||
|
|
dfbd45142d | ||
|
|
ff681f7bfd | ||
|
|
60bbb64a81 | ||
|
|
c622f2bb4e | ||
|
|
cd59f13da6 | ||
|
|
11d718bf52 | ||
|
|
8e8846d876 | ||
|
|
7d562bb685 | ||
|
|
20ddd35669 | ||
|
|
063f88cd14 | ||
|
|
87b0b7cab9 | ||
|
|
70d0d9d4da | ||
|
|
4ae3bd71ea | ||
|
|
a9390665b8 | ||
|
|
fb7a6e3423 | ||
|
|
cc99e3f7de | ||
|
|
e6b40bb6ac | ||
|
|
f2fd1b8856 | ||
|
|
cb4efcf275 | ||
|
|
56a27d608a | ||
|
|
46c9075eab | ||
|
|
d95fa648e9 | ||
|
|
563ad213dc | ||
|
|
0121d7d731 | ||
|
|
8495fac1c5 | ||
|
|
38c349f751 | ||
|
|
542df800ab | ||
|
|
3e88b1cac5 | ||
|
|
d774b10afb | ||
|
|
b449b94393 | ||
|
|
a6cb9b08b2 | ||
|
|
440a3101d0 | ||
|
|
9778a5356b | ||
|
|
de7dcdbc54 | ||
|
|
070968abbc | ||
|
|
e97fc2aab5 | ||
|
|
a23ac24192 | ||
|
|
9ee14644a7 | ||
|
|
c576e114b9 | ||
|
|
639a7982ba | ||
|
|
5bbe189420 | ||
|
|
93ff159e32 | ||
|
|
8eb8a0a8e4 | ||
|
|
a4af638867 | ||
|
|
75a9a87ec2 | ||
|
|
b5ba011110 | ||
|
|
e9b763ff05 | ||
|
|
ac0bad2433 | ||
|
|
67d5c0a970 | ||
|
|
580896d615 | ||
|
|
11693c0faa | ||
|
|
26cd8eda4a | ||
|
|
8cd3f44040 | ||
|
|
2b30bfc349 | ||
|
|
8ec4dba599 | ||
|
|
1efec6572e | ||
|
|
781dd7a9bf | ||
|
|
beb8761b22 | ||
|
|
071c7de9fe | ||
|
|
3e7ebcd051 | ||
|
|
c67952fc5c | ||
|
|
7d7c24f915 | ||
|
|
0dc8c4d451 | ||
|
|
9cf4434ae2 | ||
|
|
8ccd8b6dbc | ||
|
|
b4f70aa2c8 | ||
|
|
f54a282ccc | ||
|
|
2a11bdc216 | ||
|
|
5cd4c3ed24 | ||
|
|
147a673063 | ||
|
|
9ce5827fc1 | ||
|
|
97f1c93674 | ||
|
|
e61ceaf1bd | ||
|
|
1118612249 | ||
|
|
a23db7b7c7 | ||
|
|
f6b6dff46a | ||
|
|
55b8ceac18 | ||
|
|
bcf448ee32 | ||
|
|
91e4da7ddb | ||
|
|
2873c18132 | ||
|
|
5dd0a8a63e | ||
|
|
2103dc41f5 | ||
|
|
2ef13230cb | ||
|
|
9479ac6dda | ||
|
|
4e878eae79 | ||
|
|
1e8e90a220 | ||
|
|
fe95c7dc34 | ||
|
|
6dae34d5da | ||
|
|
36c621c9df | ||
|
|
1717963e3d | ||
|
|
4646a1ffa9 | ||
|
|
0cb4eba002 | ||
|
|
5eba359b5d | ||
|
|
07ce7539a8 | ||
|
|
c21f848c1c | ||
|
|
84e94fda8b | ||
|
|
ebd6897b10 | ||
|
|
5ab8a9d32f | ||
|
|
cf8704ccdf | ||
|
|
5543c2f11f | ||
|
|
90ac37a683 | ||
|
|
dd893fd8a4 | ||
|
|
834f079918 | ||
|
|
2665c763df | ||
|
|
d1cfbd51b5 | ||
|
|
a3ba6b7a6a | ||
|
|
415d2e7cb7 | ||
|
|
af4451ec26 | ||
|
|
7c6562683a | ||
|
|
b6fa2f882c | ||
|
|
b6c5da337a | ||
|
|
9bc24e4876 | ||
|
|
4af55809e4 | ||
|
|
9c63fcf210 | ||
|
|
1f17fb5f89 | ||
|
|
584dbffe60 | ||
|
|
1c6f6f6972 | ||
|
|
da06a6e7e3 | ||
|
|
46e0937263 | ||
|
|
a1d6ad2610 | ||
|
|
5f3d63ed5b | ||
|
|
63b5748eb6 | ||
|
|
e2590430c5 | ||
|
|
ada9bc2b24 | ||
|
|
43da41e73e | ||
|
|
720fa45b56 | ||
|
|
7de874c438 | ||
|
|
2078c1a01a | ||
|
|
f7a8909372 | ||
|
|
250df30e64 | ||
|
|
b887cf7521 | ||
|
|
630e932091 | ||
|
|
cdabd67aa9 | ||
|
|
42e4f9d776 | ||
|
|
c111033595 | ||
|
|
26d1aaccdf | ||
|
|
ce95d2020f | ||
|
|
948c3b3aa9 | ||
|
|
a140e5311d | ||
|
|
7686ac3f2c | ||
|
|
54778134e4 | ||
|
|
c59baa06f0 | ||
|
|
c107303ade | ||
|
|
21b05afc99 | ||
|
|
eebcf7d4f5 | ||
|
|
8d169dfadd | ||
|
|
b12e334d83 | ||
|
|
7e36c4437e | ||
|
|
3c7a80a275 | ||
|
|
61e2a8108b | ||
|
|
abb14de7e0 | ||
|
|
ccd57e58f6 | ||
|
|
58d70db92e | ||
|
|
09f6fc22ed | ||
|
|
833ce37cb9 | ||
|
|
07e7018564 | ||
|
|
db70cd28b3 | ||
|
|
f6e2bfd464 | ||
|
|
1ae5dab8fb | ||
|
|
c6355e6a43 | ||
|
|
7d26eb61fe | ||
|
|
8613ce377f | ||
|
|
d6b94488a1 | ||
|
|
5d7b32d09f | ||
|
|
ed16d30ea8 | ||
|
|
6f7c70fbbc | ||
|
|
9ab5d30e3b | ||
|
|
3b44a3df76 | ||
|
|
572c29a4a3 | ||
|
|
9464c5430d | ||
|
|
a14aaaf23f | ||
|
|
c41c5a0ef2 | ||
|
|
c0c0283356 | ||
|
|
1bcd3e601a | ||
|
|
e721f85c83 | ||
|
|
7015c61b86 | ||
|
|
30ec0af109 | ||
|
|
f585b66af7 | ||
|
|
1b77c18430 | ||
|
|
bd0bd35771 | ||
|
|
368e3526ea | ||
|
|
1bbe407a4d | ||
|
|
513bc44421 | ||
|
|
4cc76d1576 | ||
|
|
6dc5c6ffc7 | ||
|
|
c69c79dd04 | ||
|
|
7fca24b14b | ||
|
|
2fa0d3dd5f | ||
|
|
3a8210c975 | ||
|
|
d69302202d | ||
|
|
227662d2ed | ||
|
|
3cb3d43913 | ||
|
|
c8a546c941 | ||
|
|
62fec1d28d | ||
|
|
ac98c73b04 | ||
|
|
a145654394 | ||
|
|
e8382ba290 | ||
|
|
fcb347d124 | ||
|
|
c331ef02f9 | ||
|
|
3a3f632bf0 | ||
|
|
68d7b6f871 | ||
|
|
c43a9d9068 | ||
|
|
64e80091db | ||
|
|
4f255ffbeb | ||
|
|
80d75b0eaf | ||
|
|
808c4020e6 | ||
|
|
149d6363b3 | ||
|
|
30eab8ca51 | ||
|
|
e49a82b06c | ||
|
|
45fdb48189 | ||
|
|
3fcc9677c4 | ||
|
|
1552bd9c8c | ||
|
|
939c0c5521 | ||
|
|
f0b9aefd2e | ||
|
|
11f3c51e8f | ||
|
|
1a329b98a3 | ||
|
|
29bcba9a90 | ||
|
|
1716dbb68a | ||
|
|
16ecfcf62c | ||
|
|
8bafc3692d | ||
|
|
8a75120568 | ||
|
|
3d96ee7423 | ||
|
|
b3dbdfa306 | ||
|
|
25bad589ba | ||
|
|
0b6cd75004 | ||
|
|
7872cc131a | ||
|
|
210aa4371c | ||
|
|
6f438bc8fb | ||
|
|
65840f1fd1 | ||
|
|
5fc492e5c6 | ||
|
|
abcd1e7d5a | ||
|
|
6429c378a2 | ||
|
|
d830f10417 | ||
|
|
3d6fcbf97b | ||
|
|
609be218c2 | ||
|
|
41084e57ca | ||
|
|
9afab85105 | ||
|
|
7822233964 | ||
|
|
022315089b | ||
|
|
faa5c14aee | ||
|
|
3dd886955b | ||
|
|
c2dbf21459 | ||
|
|
133eb220b9 | ||
|
|
c5796d9e39 | ||
|
|
d80f87554c | ||
|
|
c1d37470f6 | ||
|
|
9c695393b2 | ||
|
|
444024ea14 | ||
|
|
afcd933b4c | ||
|
|
ae0a6835bd | ||
|
|
f2f11be8ba | ||
|
|
e09eda9c7c | ||
|
|
c6877a414e | ||
|
|
a3eb91ffb1 | ||
|
|
12708473a6 | ||
|
|
9012f8cdb3 | ||
|
|
e26ee09586 | ||
|
|
7d09e51162 | ||
|
|
18ebde6960 | ||
|
|
b0c0e8d815 | ||
|
|
16502d7d15 | ||
|
|
ce05deece8 | ||
|
|
b77e2528e7 | ||
|
|
27f8cf6dfc | ||
|
|
f5aa7f64bd | ||
|
|
44254c4945 | ||
|
|
a9ea507c6a | ||
|
|
b137d5ec23 | ||
|
|
4792eee5d0 | ||
|
|
a84625eca6 | ||
|
|
19d3fd1185 | ||
|
|
a9be9bc7f5 | ||
|
|
e8b99d21e5 | ||
|
|
f6c57990ee | ||
|
|
370d7f7527 | ||
|
|
7d38692c4f | ||
|
|
a997d60304 | ||
|
|
ff8fb8cdb0 | ||
|
|
b915ca68f9 | ||
|
|
703fc264f0 | ||
|
|
19d92834ed | ||
|
|
9ade752fa7 | ||
|
|
e8a5f3026f | ||
|
|
2cac4a9c72 | ||
|
|
39e939a507 | ||
|
|
803005892c | ||
|
|
08cfdf909e | ||
|
|
434ce48016 | ||
|
|
10051e6916 | ||
|
|
d54cdf294b | ||
|
|
2e342d5d9b | ||
|
|
fe84071e80 | ||
|
|
044ca343ad | ||
|
|
f59ea9adb3 | ||
|
|
0cec4ba6bf | ||
|
|
14ca732a8f | ||
|
|
53c27c7722 | ||
|
|
c2f5b71dc9 | ||
|
|
6403257886 | ||
|
|
4031104404 | ||
|
|
9f9cac7402 | ||
|
|
06730bc905 | ||
|
|
0d181b596b | ||
|
|
b60f1b1d17 | ||
|
|
4d1706798f | ||
|
|
4ac48317cf | ||
|
|
ed8dbf4ac2 | ||
|
|
97f43e98e7 | ||
|
|
f76ef1fb67 | ||
|
|
3bcdfd5cb4 | ||
|
|
7ce518701b | ||
|
|
10272550b6 | ||
|
|
784f57f9eb | ||
|
|
24dee483e9 |
786
CHANGES.0
Normal file
786
CHANGES.0
Normal file
@@ -0,0 +1,786 @@
|
|||||||
|
Version 5.3a (win32 only)
|
||||||
|
|
||||||
|
Troy Engel
|
||||||
|
- Corrected a win32 bug in the environment variable part.
|
||||||
|
|
||||||
|
Version 5.3
|
||||||
|
|
||||||
|
Gilbert Ramirez Jr. (21 Dec 1998)
|
||||||
|
- I have implemented the "quote" function of FTP clients. It allows you to
|
||||||
|
send arbitrary commands to the remote FTP server. I chose the -Q/--quote
|
||||||
|
command-line arguments.
|
||||||
|
|
||||||
|
You can have more than one quoted string, and curl will apply them in
|
||||||
|
order. This is what I use for my MVS upload:
|
||||||
|
|
||||||
|
curl -B --crlf -Q "site lrecl=80" -Q "site blk=8000" -T file ftp://os390/test
|
||||||
|
|
||||||
|
Curl will send the two quoted "site" commands in the proper order.
|
||||||
|
|
||||||
|
- Made it compile smoothly on AIX.
|
||||||
|
|
||||||
|
Gilbert Ramirez Jr. (18 Dec 1998)
|
||||||
|
- Brought an MVS patch: -3/--mvs, for ftp upload to the MVS ftp server.
|
||||||
|
|
||||||
|
Troy Engel (17 Dec 1998)
|
||||||
|
- Brought a correction that fixes the win32 curl bug.
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- A bug, pointed out to me by Dr H. T. Leung, caused curl to crash on the -A
|
||||||
|
flag on certain systems. Actually, all systems should've!
|
||||||
|
|
||||||
|
- Added a few defines to make directories/file names get build nicer (with _
|
||||||
|
instead of . and \ instead of / in win32).
|
||||||
|
|
||||||
|
- steve <fisk at polar.bowdoin.edu> reported a weird bug that occured if the
|
||||||
|
ftp server response line had a parenthesis on the line before the (size)
|
||||||
|
info. I hope it works better now!
|
||||||
|
|
||||||
|
Version 5.2.1
|
||||||
|
|
||||||
|
Steven G. Johnson (Dec 14, 1998)
|
||||||
|
- Brought a fix that corrected a crash in 5.2 due to bad treatment of the
|
||||||
|
environment variables.
|
||||||
|
|
||||||
|
Version 5.2
|
||||||
|
|
||||||
|
Daniel Stenberg (Dec 14, 1998)
|
||||||
|
- Rewrote the mkhelp script and now, the mkhelp.pl script generates the
|
||||||
|
hugehelp.c file from the README *and* the man page file curl.1. By using
|
||||||
|
both files, I no longer need to have double information in both the man
|
||||||
|
page and the README as well. So, win32-users will only have the hugehelp.c
|
||||||
|
file for all info, but then, they download the plain binary most times
|
||||||
|
anyway.
|
||||||
|
|
||||||
|
- gcc2.8.1 with the -Wall flag complaints a lot on subscript has type `char'
|
||||||
|
if I don't explicitly typecast the argument to isdigit() or isspace() to
|
||||||
|
int. So I did to compile warning free with that too.
|
||||||
|
|
||||||
|
- Added checks for 'long double' and 'long long' in the configure script. I
|
||||||
|
need those for the mprintf.c source to compile well on non long long
|
||||||
|
comforming systems!
|
||||||
|
|
||||||
|
Version 5.1 (not publicly released)
|
||||||
|
|
||||||
|
Daniel Stenberg (Dec 10, 1998)
|
||||||
|
- I got a request for a pre-compiled NT Alpha version. Anyone?
|
||||||
|
|
||||||
|
- Added Lynx/CERN www lib proxy environment variable support. That means curl
|
||||||
|
now reads and understands the following environment variables:
|
||||||
|
|
||||||
|
HTTP_PROXY, HTTPS_PROXY, FTP_PROXY, GOPHER_PROXY
|
||||||
|
|
||||||
|
They should be set for protocol-specific proxies. General proxy should be
|
||||||
|
set with
|
||||||
|
|
||||||
|
ALL_PROXY
|
||||||
|
|
||||||
|
And a comma-separated list of host names that shouldn't go through any
|
||||||
|
proxy is set in (only an asterisk, '*' matches all hosts).
|
||||||
|
|
||||||
|
NO_PROXY
|
||||||
|
|
||||||
|
The usage of the -x/--proxy flag overrides the environment variables.
|
||||||
|
|
||||||
|
- Proxy can now be specified with a procotol:// prefix.
|
||||||
|
|
||||||
|
- Wrote the curl.1 man page.
|
||||||
|
|
||||||
|
- Introduced a whole new dynamic buffer system for all sprintf()s. It is
|
||||||
|
based on the *printf() package by yours truly and Bjorn Reese. Hopefully,
|
||||||
|
there aren't that many buffer overflow risks left now.
|
||||||
|
|
||||||
|
- Ah, I should mention I've compiled and built curl successfully under
|
||||||
|
solaris 2.6 with gcc now, gcc 2.7.2 won't work but 2.8.1 did ok.
|
||||||
|
|
||||||
|
Oren Tirosh (Dec 3, 1998)
|
||||||
|
- Brought two .spec files, to use when creating (Linux) Redhat style RPM
|
||||||
|
packages. They're named curl.spec and curl-ssl.spec.
|
||||||
|
|
||||||
|
Troy Engel
|
||||||
|
- Supplied the src/Makefile.vc6 for easy compiling with VC++ under Win32.
|
||||||
|
|
||||||
|
Version 5.0
|
||||||
|
|
||||||
|
Daniel Stenberg (Dec 1, 1998)
|
||||||
|
- Not a single bug report in ages.
|
||||||
|
- Corrected getpass.c and main.c to compile warning and error free with the
|
||||||
|
Win32 VC++ crap.
|
||||||
|
|
||||||
|
Version 5.0 beta 24
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 20, 1998)
|
||||||
|
|
||||||
|
HOW TO BUILD A RELEASE ARCHIVE:
|
||||||
|
|
||||||
|
* Pre-requisite software:
|
||||||
|
What To build what Reads data from
|
||||||
|
==== ============= ===============
|
||||||
|
GNU automake Makefile.in, aclocal.m4 configure.in
|
||||||
|
GNU make(1) - " -
|
||||||
|
GNU gcc(1) - " -
|
||||||
|
GNU autoconf configure configure.in
|
||||||
|
GNU autoheader(2) config.h.in configure.in, acconfig.h
|
||||||
|
|
||||||
|
* Make sure all files that should be part of the archive are put in FILES.
|
||||||
|
|
||||||
|
* Run './maketgz' and enter version number of the new to become archive.
|
||||||
|
|
||||||
|
maketgz does:
|
||||||
|
|
||||||
|
- Enters the newly created version number in url.h.
|
||||||
|
- (If you don't have automake, this script will warn about that, but unless
|
||||||
|
you have changed the Makefile.am files, that is nothing to care about.)
|
||||||
|
If you have it, it'll run it.
|
||||||
|
- If you have autoconf, the configure.in will be edited to get the newly
|
||||||
|
created version number and autoconf will be run.
|
||||||
|
- Creates a new directory named curl-<version>. (Actually, it uses the base
|
||||||
|
name of the current directory up to the first '-'.)
|
||||||
|
- Copies all files mentioned in FILES to the new directory. Saving
|
||||||
|
permissions and directory structure.
|
||||||
|
- Uses tar to create an archive of it all, named curl-<version>.tar.gz
|
||||||
|
- gzips the archive
|
||||||
|
- Removes the new directory and all its contents.
|
||||||
|
|
||||||
|
* When done, you have an archive stored in your directory named
|
||||||
|
curl-<version>.tar.gz.
|
||||||
|
|
||||||
|
Done!
|
||||||
|
|
||||||
|
(1) They're required to make automake run properly.
|
||||||
|
(2) It is distributed as a part of the GNU autoconf archive.
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 18, 1998)
|
||||||
|
- I changed the TAG-system. If you ever used urlget() from this package in
|
||||||
|
another product, you need to recompile with the new headers. I did this
|
||||||
|
new stuff to better deal with different compilers and system with different
|
||||||
|
variable sizes. I think it makes it a little more portable. This proves
|
||||||
|
to compile warning free with the problematic IRIX compiler!
|
||||||
|
- Win32 compiled with a silly error. Corrected now.
|
||||||
|
- Brian Chaplin reported yet another problem in
|
||||||
|
multiline FTP responses. I've tried to correct it. I mailed him a new
|
||||||
|
version and I hope he gets back soon with positive feedback!
|
||||||
|
- Improved the 'maketgz' to create a temporary directory tree which it makes
|
||||||
|
an archive from instead of the previous renaming of the current one.
|
||||||
|
- Mailing list opened (see README).
|
||||||
|
- Made -v more verbose on the PASV section of ftp transfers. Now it tells
|
||||||
|
host name and IP of the new host (and port number). I also added a section
|
||||||
|
about PORT vs PASV in the README.
|
||||||
|
|
||||||
|
Version 5.0 beta 21
|
||||||
|
|
||||||
|
Angus Mackay (Nov 15, 1998)
|
||||||
|
- Introduced automake stuff.
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 13, 1998)
|
||||||
|
- Just made a successful GET of a document from an SSL-server using my own
|
||||||
|
private certificate for authentication! The certificate has to be in PEM
|
||||||
|
format. You do that the easiest way (although not *that* easy) by
|
||||||
|
downloading the SSLyeay PKCS#12-patch by Dr Stephen N. Henson from his site
|
||||||
|
at: http://www.drh-consultancy.demon.co.uk/. Using his tool, you can
|
||||||
|
convert any modern Netscape or (even) MSIE certificate to PEM-format. Use
|
||||||
|
it with 'curl -E <certificate:password> https://site.com'. If this isn't a
|
||||||
|
cool feature, then I don't know what cool features look like! ;-)
|
||||||
|
- Working slowly on telnet connections. #define TRY_TELNET to try it out.
|
||||||
|
(curl -u user:passwd "telnet://host.com/cat .login" is one example) I do
|
||||||
|
have problem to define how it should work. The prime purpose for this must
|
||||||
|
be to get (8bit clean) files via telnet, and it really isn't that easy to
|
||||||
|
get files this way. Still having problems with \n being converted to \r\n.
|
||||||
|
|
||||||
|
Angus Mackay (Nov 12, 1998)
|
||||||
|
- Corrected another bug in the long parameter name parser.
|
||||||
|
- Modified getpass.c (NOTE: see the special licensing in the top of that
|
||||||
|
source file).
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 12, 1998)
|
||||||
|
- We may have removed the silly warnings from url.c when compiled under IRIX.
|
||||||
|
Thanks again to Bjorn Reese and Martin Staael.
|
||||||
|
- Wrote formfind.pl which is a new perl script intended to help you find out
|
||||||
|
how a FORM submission should be done. This needs a little more work to get
|
||||||
|
really good.
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 11, 1998)
|
||||||
|
- Made the HTTP header-checker accept white spaces before the HTTP/1.? line.
|
||||||
|
Appearantly some proxies/sites add such at times (my test proxy did when I
|
||||||
|
downloaded a gopher page with it)!
|
||||||
|
- Moved the former -h to -M and made -h show the short help text instead. I
|
||||||
|
had to enable a forced help text option. Now an even shorter help text will
|
||||||
|
be presented when an unknown option and similar, is used.
|
||||||
|
- stdcheaders.h didn't work with IRIX 6.4 native cc compiler. I hope my
|
||||||
|
changes don't make other versions go nuts instead.
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 10, 1998)
|
||||||
|
- Added a weird check in the configure script to check for the silly AIX
|
||||||
|
warnings about my #define strcasecmp() stuff. I do that define to prevent
|
||||||
|
me and other contributors to accidentaly use that function name instead
|
||||||
|
of strequal()...
|
||||||
|
- I bugfixed Angus's getpass.c very little.
|
||||||
|
- Fixed the verbose flag names to getopt-style, i.e 'curl --loc' will be
|
||||||
|
sufficient instead of --location as "loc" is a unique prefix. Also, anything
|
||||||
|
after a '--' is treated as an URL. So if you do have a host with a weeeird
|
||||||
|
name you can do 'curl -- -host.com'.
|
||||||
|
- Another getopt-adjust; curl now accepts flags after the URL on the command
|
||||||
|
line. 'curl www.foo.com -O' is perfectly valid.
|
||||||
|
- Corrected the .curlrc parser so that strtok() is no longer used and I
|
||||||
|
believe it works better. Even URLs can be specified in it now.
|
||||||
|
|
||||||
|
Angus Mackay (Nov 9, 1998)
|
||||||
|
- Replaced getpass.c with a newly written one, not under GPL license
|
||||||
|
- Changed OS to a #define in config.h instead of compiler flag
|
||||||
|
- Makefile now uses -DHAVE_CONFIG_H
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 9, 1998)
|
||||||
|
- Ok, I expanded the tgz-target to update the version string on each occation
|
||||||
|
I build a release archive!
|
||||||
|
- I reacted on Angus Mackay's initiative and remade the parameter parser to
|
||||||
|
be more getopt compliant. Curl now supports "merged" flags as in
|
||||||
|
curl -lsv ftp.site.com
|
||||||
|
Do note that I had to move three short-names of the options. Parameters
|
||||||
|
that needs an additional string such as -x must be stand-alone or the
|
||||||
|
last in a merged sequence:
|
||||||
|
curl -lsx my-proxy ftp.site.com
|
||||||
|
is ok, but using the flags in a different order like '-lxs' would cause
|
||||||
|
unexpected results (as the 's' option would be skipped).
|
||||||
|
- I've changed the headers in all files that are subject to the MozPL
|
||||||
|
license, as they are supposed to look like when conforming.
|
||||||
|
- Made the configure script make the config.h. The former config.h is now
|
||||||
|
setup.h.
|
||||||
|
- The RESOURCES and TODO files have been added to the archive.
|
||||||
|
|
||||||
|
Angus Mackay (Nov 5, 1998)
|
||||||
|
- Fixed getpass.c and various configure stuff
|
||||||
|
|
||||||
|
Daniel Stenberg (Nov 3, 1998)
|
||||||
|
- Use -H/--header for custom HTTP-headers. Lets you pass on your own
|
||||||
|
specified headers to the remote server. I wouldn't recommend trying to use
|
||||||
|
a header with a defined usage according to standards. Use this flag once
|
||||||
|
for every custom header you want to add.
|
||||||
|
- Use -B/--ftp-ascii to force ftp to use ASCII mode when transfering files.
|
||||||
|
- Corrected the 'getlinks.pl' script, I accidentally left my silly proxy
|
||||||
|
usage in there! Since the introduction of the .curlrc file, it is easier to
|
||||||
|
write scripts that use curl since proxies and stuff should be in the
|
||||||
|
.curlrc file anyway.
|
||||||
|
- Introducing the new -F flag for HTTP POST. It supports multipart/form-data
|
||||||
|
which means it is gonna be possible to upload files etc through HTTP POST.
|
||||||
|
Shiraz Kanga asked for the feature and my brother,
|
||||||
|
Bj<42>rn Stenberg helped me design the user
|
||||||
|
interface for this beast. This feature requires quite some docs,
|
||||||
|
since it has turned out not only quite capable, but also complicated! :-)
|
||||||
|
- A note here, since I've received mail about it. SSLeay versions prior to
|
||||||
|
0.8 will *not* work with curl!
|
||||||
|
- Wil Langford reported a bug that occurred since curl
|
||||||
|
did not properly use CRLF when issuing ftp commands. I fixed it.
|
||||||
|
- Rearranged the order config files are read. .curlrc is now *always* read
|
||||||
|
first and before the command line flags. -K config files then act as
|
||||||
|
additional config items.
|
||||||
|
- Use -q AS THE FIRST OPTION specified to prevent .curlrc from being read.
|
||||||
|
- You can now disable a proxy by using -x "". Useful if the .curlrc file
|
||||||
|
specifies a proxy and you wanna fetch something without going through
|
||||||
|
that.
|
||||||
|
- I'm thinking of dropping the -p support. Its really not useful since ports
|
||||||
|
could (and should?) be specified as :<port> appended on the host name
|
||||||
|
instead, both in URLs and to proxy host names.
|
||||||
|
- Martin Staael reports curl -L bugs under Windows NT
|
||||||
|
(test with URL http://come.to/scsde). This bug is not present in this
|
||||||
|
version anymore.
|
||||||
|
- Added support for the weird FTP URL type= thing. You can download a file
|
||||||
|
using ASCII transfer by appending ";type=A" to the right of it. Other
|
||||||
|
available types are type=D for dir-list (NLST) and type=I for binary
|
||||||
|
transfer. I can't say I've ever seen anyone use this kind of URL though!
|
||||||
|
:-)
|
||||||
|
- Troy Engel pointed out a bug in my getenv("HOME")
|
||||||
|
usage for win32 systems. I introduce getenv.c to better cope with
|
||||||
|
this. Mr Engel helps me with the details around that...
|
||||||
|
- A little note to myself and others, I should make the win32-binary built
|
||||||
|
with SSL support...
|
||||||
|
- Ryan Nelson sent me comments about building curl
|
||||||
|
with SSL under FreeBSD. See the Makefile for details. Using the configure
|
||||||
|
script, it should work better and automatically now...
|
||||||
|
- Cleaned up in the port number mess in the source. No longer stores and uses
|
||||||
|
proxy port number separate from normal port number.
|
||||||
|
- 'configure' script working. Confirmed compiles on:
|
||||||
|
Host SSL Compiler
|
||||||
|
SunOS 5.5 no gcc
|
||||||
|
SunOS 5.5.1 yes gcc
|
||||||
|
SunOS 5.6 no cc (with gcc, it has the "gcc include files" problem)
|
||||||
|
SunOS 4.1.3 no gcc (without ANSI C headers)
|
||||||
|
SunOS 4.1.2 no gcc (native compiler failed)
|
||||||
|
Linux 2.0.18 no gcc
|
||||||
|
Linux 2.0.32 yes gcc
|
||||||
|
Linux 2.0.35 no gcc (with glibc)
|
||||||
|
IRIX 6.2 no gcc (cc compiles generate a few warnings)
|
||||||
|
IRIX 6.4 no cc (generated warnings though)
|
||||||
|
Win32 no Borland
|
||||||
|
OSF4.0 no ?
|
||||||
|
|
||||||
|
- Ooops. The 5beta (and 4.10) under win32 failed if the HOME variable wasn't
|
||||||
|
set.
|
||||||
|
- When using a proxy, curl now guesses and uses the protocol part in cases
|
||||||
|
like:
|
||||||
|
curl -x proxy:80 www.site.com
|
||||||
|
Proxies normally go nuts unless http:// is prepended to the host name, so
|
||||||
|
if curl is used like this, it guesses protocol and appends the protocol
|
||||||
|
string before passing it to the proxy. It already did this when used
|
||||||
|
without proxy.
|
||||||
|
- Better port usage with SSL through proxy now. If you specified a different
|
||||||
|
https-port when accessing through a proxy, it didn't use that number
|
||||||
|
correctly. I also rewrote the code that parses the stuff read from the
|
||||||
|
proxy when you wanna connect through it with SSL.
|
||||||
|
- Bjorn Reese helped me work around one of the compiler
|
||||||
|
warnings on IRIX native cc compiles.
|
||||||
|
|
||||||
|
Version 4.10 (Oct 26, 1998)
|
||||||
|
Daniel Stenberg
|
||||||
|
- John A. Bristor suggested a config file switch,
|
||||||
|
and since I've been having that idea kind of in the background for a long
|
||||||
|
time I rewrote the parameter parsing function a little and now I introduce
|
||||||
|
the -K/--config flag. I also made curl *always* (unless -K is used) try to
|
||||||
|
load the .curlrc file for command line parameters. The syntax for the
|
||||||
|
config file is the standard command line argument style. Details in 'curl
|
||||||
|
-h' or the README.
|
||||||
|
- I removed the -k option. Keep-alive isn't really anything anyone would
|
||||||
|
want to enable with curl anyway.
|
||||||
|
- Martin Staael helped me add the 'irix' target. Now
|
||||||
|
"make irix" should build curl successfully on non-gcc SGI machines.
|
||||||
|
- Single switches now toggle behaviours. I.e if you use -v -v the second
|
||||||
|
will switch off the verbose mode the first one enabled. This is so that
|
||||||
|
you can disable a default setting a .curlrc file enables etc.
|
||||||
|
|
||||||
|
Version 4.9 (Oct 7, 1998)
|
||||||
|
Daniel Stenberg
|
||||||
|
- Martin Staael suggested curl would support cookies.
|
||||||
|
I added -b/--cookie to enable free-text cookie data to be passed. There's
|
||||||
|
also a little blurb about general cookie stuff in the README/help text.
|
||||||
|
- dmh <dmh at jet.es> suggested HTTP resume capabilities. Although you could
|
||||||
|
manually get curl to resume HTTP documents, I made the -c resume flag work
|
||||||
|
for HTTP too (unless -r is used too, which would be very odd anyway).
|
||||||
|
- Added checklinks.pl to the archive. It is a still experimental perl script
|
||||||
|
that checks all links of a web page by using curl.
|
||||||
|
- Rearranged the archive hierarchy a little. Build the executable in the
|
||||||
|
src/ dir from now on!
|
||||||
|
- Version 4.9 and hereafter, is no longer released under the GPL license.
|
||||||
|
I have now updated the LEGAL file etc and now this is released using the
|
||||||
|
Mozilla Public License to avoid the plague known as "the GPL virus". You
|
||||||
|
must make the source available if you decide to change and/or redistribute
|
||||||
|
curl, but if you decide to use curl within something else you do not need
|
||||||
|
to offer the world the source to that too.
|
||||||
|
- Curl did not like HTTP servers that sent no headers at all on a GET
|
||||||
|
request. It is a violation of RFC2068 but appearantly some servers do
|
||||||
|
that anyway. Thanks to Gordon Beaton for the report!
|
||||||
|
- -L/--location was added after a suggestion from Martin Staael. This makes
|
||||||
|
curl ATTEMPT to follow the Location: redirect if one is present in the HTTP
|
||||||
|
headers. If -i or -I is used with this flag, you will see headers from all
|
||||||
|
sites the Location: points to. Do note that the first server can point to a
|
||||||
|
second that points to a third etc. It seems the Location: parameter (said
|
||||||
|
to be an AbsoluteURI in RFC2068) isn't always absolute.. :-/ Anyway, I've
|
||||||
|
made curl ATTEMPT to do the best it can to deal with the reality.
|
||||||
|
- Added getlinks.pl to the archive. getlinks.pl selectively downloads
|
||||||
|
files that a web page links to.
|
||||||
|
|
||||||
|
Version 4.8.4
|
||||||
|
Daniel Stenberg
|
||||||
|
- As Julian Romero Nieto reported, curl reported wrong version number.
|
||||||
|
- As Teemu Yli-Elsila pointed out, the win32 version of 4.8 (and probably all
|
||||||
|
other versions for win32) didn't work with binary files since I'm too used
|
||||||
|
to the UNIX style fopen() where binary and text don't differ...
|
||||||
|
- Ralph Beckmann brought me some changes that lets curl compile error and
|
||||||
|
warning free with -Wall -pedantic with g++. I also took the opportunity to
|
||||||
|
clean off some unused variables and similar.
|
||||||
|
- Ralph Beckmann made me aware of a really odd bug now corrected. When curl
|
||||||
|
read a set of headers from a HTTP server, divided into more than one read
|
||||||
|
and the first read showed a full line *exactly* (i.e ending with a
|
||||||
|
newline), curl did not behave well.
|
||||||
|
|
||||||
|
Version 4.8.3
|
||||||
|
Daniel Stenberg
|
||||||
|
- I was too quick to release 4.8.2 with too little testing. One of the
|
||||||
|
changes is now reverted slightly to the 4.8.1 way since 4.8.2 couldn't
|
||||||
|
upload files. I still think both problems corrected in 4.8.2 remain
|
||||||
|
corrected. Reported by Julian Romero Nieto.
|
||||||
|
|
||||||
|
Version 4.8.2
|
||||||
|
Daniel Stenberg
|
||||||
|
- Bernhard Iselborn reported two FTP protocol errors curl did. They're now
|
||||||
|
corrected. Both appeared when getting files from a MS FTP server! :-)
|
||||||
|
|
||||||
|
Version 4.8.1
|
||||||
|
Daniel Stenberg
|
||||||
|
- Added a last update of the progress meter when the transfer is done. The
|
||||||
|
final output on the screen didn't have to be the final size transfered
|
||||||
|
which made it sometimes look odd.
|
||||||
|
- Thanks to David Long I got rid of a silly bug that happened if a HTTP-page
|
||||||
|
had nothing but header. Appearantly Solaris deals with negative sizes in
|
||||||
|
fwrite() calls a lot better than Linux does... =B-]
|
||||||
|
|
||||||
|
Version 4.8
|
||||||
|
Daniel Stenberg
|
||||||
|
- Continue FTP file transfer. -c is the switch. Note that you need to
|
||||||
|
specify a file name if you wanna resume a download (you can't resume a
|
||||||
|
download sent to stdout). Resuming upload may be limited by the server
|
||||||
|
since curl is then using the non-RFC959 command SIZE to get the size of
|
||||||
|
the target file before upload begins (to figure out which offset to
|
||||||
|
use). Use -C to specify the offset yourself! -C is handy if you're doing
|
||||||
|
the output to something else but a plain file or when you just want to get
|
||||||
|
the end of a file.
|
||||||
|
- recursiveftpget.pl now features a maximum recursive level argument.
|
||||||
|
|
||||||
|
Version 4.7
|
||||||
|
Daniel Stenberg
|
||||||
|
- Added support to abort a download if the speed is below a certain amount
|
||||||
|
(speed-limit) bytes per second for a certain (speed-time) time.
|
||||||
|
- Wrote a perl script 'recursiveftpget.pl' to recursively use curl to get a
|
||||||
|
whole ftp directory tree. It is meant as an example of how curl can be
|
||||||
|
used. I agree it isn't the wisest thing to do to make a separate new
|
||||||
|
connection for each file and directory for this.
|
||||||
|
|
||||||
|
Version 4.6
|
||||||
|
Daniel Stenberg
|
||||||
|
- Added a first attempt to optionally parse the .netrc file for login user
|
||||||
|
and password. If used with http, it enables user authentication. -n is
|
||||||
|
the new switch.
|
||||||
|
- Removed the extra newlines on the default user-agent string.
|
||||||
|
- Corrected the missing ftp upload error messages when it failed without the
|
||||||
|
verbose flag set. Gary W. Swearingen found it.
|
||||||
|
- Now using alarm() to enable second-precision timeout even on the name
|
||||||
|
resolving/connecting phase. The timeout is although reset after that first
|
||||||
|
sequence. (This should be corrected.) Gary W. Swearingen reported.
|
||||||
|
- Now spells "Unknown" properly, as in "Unknown option 'z'"... :-)
|
||||||
|
- Added bug report email address in the README.
|
||||||
|
- Added a "current speed" field to the progress meter. It shows the average
|
||||||
|
speed the last 5 seconds. The other speed field shows the average speed of
|
||||||
|
the entire transfer so far.
|
||||||
|
|
||||||
|
Version 4.5.1
|
||||||
|
Linas Vepstas
|
||||||
|
- SSL through proxy fix
|
||||||
|
- Added -A to allow User-Agent: changes
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Made the -A work when SSL-through-proxy.
|
||||||
|
|
||||||
|
Version 4.5
|
||||||
|
Linas Vepstas
|
||||||
|
- More SSL corrections
|
||||||
|
- I've added a port to AIX.
|
||||||
|
- running SSL through a proxy causes a chunk of code to be executred twice.
|
||||||
|
one of those blocks needs to be deleted.
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Made -i and -I work again
|
||||||
|
|
||||||
|
Version 4.4
|
||||||
|
Linas Vepstas
|
||||||
|
- -x can now also specify proxyport when used as in 'proxyhost:proxyport'
|
||||||
|
- SSL fixes
|
||||||
|
|
||||||
|
Version 4.3
|
||||||
|
Daniel Stenberg
|
||||||
|
- Adjusted to compile under win32 (VisualC++ 5). The -P switch does not
|
||||||
|
support network interface names in win32. I couldn't figure out how!
|
||||||
|
|
||||||
|
Version 4.2
|
||||||
|
Linas Vepstas / Sampo Kellomaki
|
||||||
|
- Added SSL / SSLeay support (https://)
|
||||||
|
- Added the -T usage for HTTP POST.
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Bugfixed the SSL implementation.
|
||||||
|
- Made -P a lot better to use other IP addresses. It now accepts a following
|
||||||
|
parameter that can be either
|
||||||
|
interface - i.e "eth0" to specify which interface's IP address you
|
||||||
|
want to use
|
||||||
|
IP address - i.e "192.168.10.1" to specify exact IP number
|
||||||
|
host name - i.e "my.host.domain" to specify machine
|
||||||
|
"-" - (any single-letter string) to make it pick the machine's
|
||||||
|
default
|
||||||
|
- The Makefile is now ready to compile for solaris, sunos4 and linux right
|
||||||
|
out of the box.
|
||||||
|
- Better generated version string seen with 'curl -V'
|
||||||
|
|
||||||
|
Version 4.1
|
||||||
|
Daniel Stenberg
|
||||||
|
- The IP number returned by the ftp server as a reply to PASV does no longer
|
||||||
|
have to DNS resolve. In fact, no IP-number-only addresses have to anymore.
|
||||||
|
- Binds better to available port when -P is used.
|
||||||
|
- Now LISTs ./ instead of / when used as in ftp://ftp.funet.fi/. The reason
|
||||||
|
for this is that exactly that site, ftp.funet.fi, does not allow LIST /
|
||||||
|
while LIST ./ is fine. Any objections?
|
||||||
|
|
||||||
|
Version 4 (1998-03-20)
|
||||||
|
Daniel Stenberg
|
||||||
|
- I took another huge step and changed both version number and project name!
|
||||||
|
The reason for the new name is that there are just one too many programs
|
||||||
|
named urlget already and this program already can a lot more than merely
|
||||||
|
getting URLs, and the reason for the version number is that I did add the
|
||||||
|
pretty big change in -P and since I changed name I wanted to start with
|
||||||
|
something fresh!
|
||||||
|
- The --style flags are working better now.
|
||||||
|
- Listing directories with FTP often reported that the file transfer was
|
||||||
|
incomplete. Wrong assumptions were too common for directories, why no
|
||||||
|
size will be attempted to get compared on them from now on.
|
||||||
|
- Implemented the -P flag that let's the ftp control issue a PORT command
|
||||||
|
instead of the standard PASV.
|
||||||
|
- -a for appending FTP uploads works.
|
||||||
|
|
||||||
|
***************************************************************************
|
||||||
|
|
||||||
|
Version 3.12 (14 March 1998)
|
||||||
|
Daniel Stenberg
|
||||||
|
- End-of-header tracking still lacked support for \r\n or just \n at the
|
||||||
|
end of the last header line.
|
||||||
|
Sergio Barresi
|
||||||
|
- Added PROXY authentication.
|
||||||
|
Rafael Sagula
|
||||||
|
- Fixed some little bugs.
|
||||||
|
|
||||||
|
Version 3.11
|
||||||
|
Daniel Stenberg
|
||||||
|
- The header parsing was still not correct since the 3.2 modification...
|
||||||
|
|
||||||
|
Version 3.10
|
||||||
|
Daniel Stenberg
|
||||||
|
- 3.7 and 3.9 were simultaneously developed and merged into this version.
|
||||||
|
- FTP upload did not work correctly since 3.2.
|
||||||
|
|
||||||
|
Version 3.9
|
||||||
|
Rafael Sagula
|
||||||
|
- Added the "-e <url> / --referer <url>" option where we can specify
|
||||||
|
the referer page. Obviously, this is necessary only to fool the
|
||||||
|
server, but...
|
||||||
|
|
||||||
|
Version 3.7
|
||||||
|
Daniel Stenberg
|
||||||
|
- Now checks the last error code sent from the ftp server after a file has
|
||||||
|
been received or uploaded. Wasn't done previously.
|
||||||
|
- When 'urlget <host>' is used without a 'protocol://' first in the host part,
|
||||||
|
it now checks for host names starting with ftp or gopher and if it does,
|
||||||
|
it uses that protocol by default instead of http.
|
||||||
|
|
||||||
|
Version 3.6
|
||||||
|
Daniel Stenberg
|
||||||
|
- Silly mistake made the POST bug. This has now also been tested to work with
|
||||||
|
proxy.
|
||||||
|
|
||||||
|
Version 3.5
|
||||||
|
Daniel Stenberg
|
||||||
|
- Highly inspired by Rafael Sagula's changes to the 3.1 that added an almost
|
||||||
|
functional POST, I applied his changes into this version and made them work.
|
||||||
|
(It seems POST requires the Content-Type and Content-Length headers.) It is
|
||||||
|
now usable with the -d switch.
|
||||||
|
|
||||||
|
Version 3.3 - 3.4
|
||||||
|
Passed to avoid confusions
|
||||||
|
|
||||||
|
Version 3.2
|
||||||
|
Daniel Stenberg
|
||||||
|
- Major rewrite of two crucial parts of this code: upload and download.
|
||||||
|
They are both now using a select() switch, that allows much better
|
||||||
|
progress meter and time control.
|
||||||
|
- alarm() usage removed completely
|
||||||
|
- FTP get can now list directory contents if the path ends with a slash '/'.
|
||||||
|
Urlget on a ftp-path that doesn't end with a slash means urlget will
|
||||||
|
attempt getting it as a file name.
|
||||||
|
- FTP directory view supports -l for "list-only" which lists the file names
|
||||||
|
only.
|
||||||
|
- All operations support -m for max time usage in seconds allowed.
|
||||||
|
- FTP upload now allows the size of the uploaded file to be provided, and
|
||||||
|
thus it can better check it actually uploaded the whole file. It also
|
||||||
|
makes the progress meter for uploads much better!
|
||||||
|
- Made the parameter parsing fail in cases like 'urlget -r 900' which
|
||||||
|
previously tried to connect to the host named '900'.
|
||||||
|
|
||||||
|
Version 3.1
|
||||||
|
Kjell Ericson
|
||||||
|
- Pointed out how to correct the 3 warnings in win32-compiles.
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Removed all calls to exit().
|
||||||
|
- Made the short help text get written to stdout instead of stderr.
|
||||||
|
- Made this file instead of keeping these comments in the source.
|
||||||
|
- Made two callback hooks, that enable external programs to use urlget()
|
||||||
|
easier and to grab the output/offer the input easier.
|
||||||
|
- It is evident that Win32-compiles are painful. I watched the output from
|
||||||
|
the Borland C++ v5 and it was awful. Just ignore all those warnings.
|
||||||
|
|
||||||
|
Version 3.0
|
||||||
|
Daniel Stenberg
|
||||||
|
- Added FTP upload capabilities. The name urlget gets a bit silly now
|
||||||
|
when we can put too... =)
|
||||||
|
- Restructured the source quite a lot.
|
||||||
|
Changed the urlget() interface. This way, we will survive changes much
|
||||||
|
better. New features can come and old can be removed without us needing
|
||||||
|
to change the interface. I've written a small explanation in urlget.h
|
||||||
|
that explains it.
|
||||||
|
- New flags include -t, -T, -O and -h. The -h text is generated by the new
|
||||||
|
mkhelp script.
|
||||||
|
|
||||||
|
Version 2.9
|
||||||
|
Remco van Hooff
|
||||||
|
- Added a fix to make it compile smoothly on Amiga using the SAS/C
|
||||||
|
compiler.
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Believe it or not, but the STUPID Novell web server seems to require
|
||||||
|
that the Host: keyword is used, so well I use it and I (re-introduce) the
|
||||||
|
urlget User-Agent:. I still have to check that this Host: usage works with
|
||||||
|
proxies... 'Host:' is required for HTTP/1.1 GET according to RFC2068.
|
||||||
|
|
||||||
|
Version 2.8
|
||||||
|
Rafael Sagula
|
||||||
|
- some little modifications
|
||||||
|
|
||||||
|
Version 2.7
|
||||||
|
Daniel Stenberg
|
||||||
|
- Removed the -l option and introduced the -f option instead. Now I'll
|
||||||
|
rewrite the former -l kludge in an external script that'll use urlget to
|
||||||
|
fetch multipart files like that.
|
||||||
|
- '-f' is introduced, it means Fail without output in case of HTTP server
|
||||||
|
errors (return code >=300).
|
||||||
|
- Added support for -r, ranges. Specify which part of a document you
|
||||||
|
want, and only that part is returned. Only with HTTP/1.1-servers.
|
||||||
|
- Split up the source in 3 parts. Now all pure URL functions are in
|
||||||
|
urlget.c and stuff that deals with the stand-alone program is in main.c.
|
||||||
|
- I took a few minutes and wrote an embryo of a README file to explain
|
||||||
|
a few things.
|
||||||
|
|
||||||
|
Version 2.6
|
||||||
|
Daniel Stenberg
|
||||||
|
- Made the -l (loop) thing use the new CONF_FAILONERROR which makes
|
||||||
|
urlget() return error code if non-successful. It also won't output anything
|
||||||
|
then. Now finally removed the HTTP 1.0 and error 404 dependencies.
|
||||||
|
- Added -I which uses the HEAD request to get the header only from a
|
||||||
|
http-server.
|
||||||
|
|
||||||
|
Version 2.5
|
||||||
|
Rafael Sagula
|
||||||
|
- Made the progress meter use HHH:MM:SS instead of only seconds.
|
||||||
|
|
||||||
|
Version 2.4
|
||||||
|
Daniel Stenberg
|
||||||
|
- Added progress meter. It appears when downloading > BUFFER SIZE and
|
||||||
|
mute is not selected. I found out that when downloading large files from
|
||||||
|
really really slow sites, it is desirable to know the status of the
|
||||||
|
download. Do note that some downloads are done unawaring of the size, which
|
||||||
|
makes the progress meter less thrilling ;) If the output is sent to a tty,
|
||||||
|
the progress meter is shut off.
|
||||||
|
- Increased buffer size used for reading.
|
||||||
|
- Added length checks in the user+passwd parsing.
|
||||||
|
- Made it grok user+passwd for HTTP fetches. The trick is to base64
|
||||||
|
encode the user+passwd and send an extra header line. Read chapter 11.1 in
|
||||||
|
RFC2068 for details. I added it to be used just like the ftp one. To get a
|
||||||
|
http document from a place that requires user and password, use an URL
|
||||||
|
like:
|
||||||
|
|
||||||
|
http://user:passwd@www.site.to.leach/doc.html
|
||||||
|
|
||||||
|
I also added the -u flag, since WHEN USING A PROXY YOU CAN'T SPECIFY THE
|
||||||
|
USER AND PASSWORD WITH HTTP LIKE THAT. The -u flag works for ftp too, but
|
||||||
|
not if used with proxy. To do the same as the above one, you can invoke:
|
||||||
|
|
||||||
|
urlget -u user:passwd http://www.site.to.leach/doc.html
|
||||||
|
|
||||||
|
Version 2.3
|
||||||
|
Rafael Sagula
|
||||||
|
- Added "-o" option (output file)
|
||||||
|
- Added URG_HTTP_NOT_FOUND return code.
|
||||||
|
(Daniel's note:)
|
||||||
|
Perhaps we should detect all kinds of errors and instead of writing that
|
||||||
|
custom string for the particular 404-error, use the error text we actually
|
||||||
|
get from the server. See further details in RFC2068 (HTTP 1.1
|
||||||
|
definition). The current way also relies on a HTTP/1.0 reply, which newer
|
||||||
|
servers might not do.
|
||||||
|
- Looping mode ("-l" option). It's easier to get various split files.
|
||||||
|
(Daniel's note:)
|
||||||
|
Use it like 'urlget -l 1 http://from.this.site/file%d.html', which will
|
||||||
|
make urlget to attempt to fetch all files named file1.html, file2.html etc
|
||||||
|
until no more files are found. This is only a modification of the
|
||||||
|
STAND_ALONE part, nothing in the urlget() function was modfified for this.
|
||||||
|
Daniel Stenberg
|
||||||
|
- Changed the -h to be -i instead. -h should be preserved to help use.
|
||||||
|
- Bjorn Reese indicated that Borland _might_ use '_WIN32' instead of the
|
||||||
|
VC++ WIN32 define and therefore I added a little fix for that.
|
||||||
|
|
||||||
|
Version 2.2
|
||||||
|
Johan Andersson
|
||||||
|
- The urlget function didn't set the path to url when using proxy.
|
||||||
|
- Fixed bug with IMC proxy. Now using (almost) complete GET command.
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Made it compile on Solaris. Had to reorganize the includes a bit.
|
||||||
|
(so Win32, Linux, SunOS 4 and Solaris 2 compile fine.)
|
||||||
|
- Made Johan's keepalive keyword optional with the -k flag (since it
|
||||||
|
makes a lot of urlgets take a lot longer time).
|
||||||
|
- Made a '-h' switch in case you want the HTTP-header in the output.
|
||||||
|
|
||||||
|
Version 2.1
|
||||||
|
Daniel Stenberg and Kjell Ericson
|
||||||
|
- Win32-compilable
|
||||||
|
- No more global variables
|
||||||
|
- Mute option (no output at all to stderr)
|
||||||
|
- Full range of return codes from urlget(), which is now written to be a
|
||||||
|
function for easy-to-use in [other] programs.
|
||||||
|
- Define STAND_ALONE to compile the stand alone urlget program
|
||||||
|
- Now compiles with gcc options -ansi -Wall -pedantic ;)
|
||||||
|
|
||||||
|
Version 2.0
|
||||||
|
- Introducing ftp GET support. The FTP URL type is recognized and used.
|
||||||
|
- Renamed the project to 'urlget'.
|
||||||
|
- Supports the user+passwd in the FTP URL (otherwise it tries anonymous
|
||||||
|
login with a weird email address as password).
|
||||||
|
|
||||||
|
Version 1.5
|
||||||
|
Daniel Stenberg
|
||||||
|
- The skip_header() crap messed it up big-time. By simply removing that
|
||||||
|
one we can all of a sudden download anything ;)
|
||||||
|
- No longer requires a trailing slash on the URLs.
|
||||||
|
- If the given URL isn't prefixed with 'http://', HTTP is assumed and
|
||||||
|
given a try!
|
||||||
|
- 'void main()' is history.
|
||||||
|
|
||||||
|
Version 1.4
|
||||||
|
Daniel Stenberg
|
||||||
|
- The gopher source used the ppath variable instead of path which could
|
||||||
|
lead to disaster.
|
||||||
|
|
||||||
|
Version 1.3
|
||||||
|
Daniel Stenberg
|
||||||
|
- Well, I added a lame text about the time it took to get the data. I also
|
||||||
|
fought against Johan to prevent his -f option (to specify a file name
|
||||||
|
that should be written instead of stdout)! =)
|
||||||
|
- Made it write 'connection refused' for that particular connect()
|
||||||
|
problem.
|
||||||
|
- Renumbered the version. Let's not make silly 1.0.X versions, this is
|
||||||
|
a plain 1.3 instead.
|
||||||
|
|
||||||
|
Version 1.2
|
||||||
|
Johan Andersson
|
||||||
|
- Discovered and fixed the problem with getting binary files. puts() is
|
||||||
|
now replaced with fwrite(). (Daniel's note: this also fixed the buffer
|
||||||
|
overwrite problem I found in the previous version.)
|
||||||
|
|
||||||
|
Rafael Sagula
|
||||||
|
- Let "-p" before "-x".
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
- Bugfixed the proxy usage. It should *NOT* use nor strip the port number
|
||||||
|
from the URL but simply pass that information to the proxy. This also
|
||||||
|
made the user/password fields possible to use in proxy [ftp-] URLs.
|
||||||
|
(like in ftp://user:password@ftp.my.site:8021/README)
|
||||||
|
|
||||||
|
Johan Andersson
|
||||||
|
- Implemented HTTP proxy support.
|
||||||
|
- Receive byte counter added.
|
||||||
|
|
||||||
|
Bjorn Reese
|
||||||
|
- Implemented URLs (and skipped the old syntax).
|
||||||
|
- Output is written to stdout, so to achieve the above example, do:
|
||||||
|
httpget http://143.54.10.6/info_logo.gif > test.gif
|
||||||
|
|
||||||
|
Version 1.1
|
||||||
|
Daniel Stenberg
|
||||||
|
- Adjusted it slightly to accept named hosts on the command line. We
|
||||||
|
wouldn't wanna use IP numbers for the rest of our lifes, would we?
|
||||||
|
|
||||||
|
Version 1.0
|
||||||
|
Rafael Sagula
|
||||||
|
- Wrote the initial httpget, which started all this!
|
||||||
835
CHANGES.1999
Normal file
835
CHANGES.1999
Normal file
@@ -0,0 +1,835 @@
|
|||||||
|
Daniel (28 December 1999):
|
||||||
|
- Tim Verhoeven correctly identified that curl
|
||||||
|
doesn't support URL formatted file names when getting ftp. Now, there's a
|
||||||
|
problem with getting very weird file names off FTP servers. RFC 959 defines
|
||||||
|
that the file name syntax to use should be the same as in the native OS of
|
||||||
|
the server. Since we don't know the peer server system we currently just
|
||||||
|
translate the URL syntax into plain letters. It is still better and with
|
||||||
|
the solaris 2.6-supplied ftp server it works with spaces in the file names.
|
||||||
|
|
||||||
|
Daniel (27 December 1999):
|
||||||
|
- When curl parsed cookies straight off a remote site, it corrupted the input
|
||||||
|
data, which, if the downloaded headers were stored made very odd characters
|
||||||
|
in the saved data. Correctly identified and reported by Paul Harrington.
|
||||||
|
|
||||||
|
Daniel (13 December 1999):
|
||||||
|
- General cleanups in the library interface. There had been some bad kludges
|
||||||
|
added during times of stress and I did my best to clean them off. It was
|
||||||
|
both regarding the lib API as well as include file confusions.
|
||||||
|
|
||||||
|
Daniel (3 December 1999):
|
||||||
|
- A small --stderr bug was reported by Eetu Ojanen...
|
||||||
|
|
||||||
|
- who also brought the suggestion of extending the -X flag to ftp list as
|
||||||
|
well. So, now it is and the long option is now --request instead. It is
|
||||||
|
only for ftp list for now (and the former http stuff too of course).
|
||||||
|
|
||||||
|
Lars J. Aas (24 November 1999):
|
||||||
|
- Patched curl to compile and build under BeOS. Doesn't work yet though!
|
||||||
|
|
||||||
|
- Corrected the Makefile.am files to allow putting object files in
|
||||||
|
different directories than the sources.
|
||||||
|
|
||||||
|
Version 6.3.1
|
||||||
|
|
||||||
|
Daniel (23 November 1999):
|
||||||
|
- I've had this major disk crash. My good old trust-worthy source disk died
|
||||||
|
along with the machine that hosted it. Thank goodness most of all the
|
||||||
|
things I've done are either backed up elsewhere or stored in this CVS
|
||||||
|
server!
|
||||||
|
|
||||||
|
- Michael S. Steuer pointed out a bug in the -F handling
|
||||||
|
that made curl hang if you posted an empty variable such as '-F name='. It
|
||||||
|
was one of those old bugs that never have worked properly...
|
||||||
|
|
||||||
|
- Jason Baietto pointed out a general flaw in the HTTP
|
||||||
|
download. Curl didn't complain if it was prematurely aborted before the
|
||||||
|
entire download was completed. It does now.
|
||||||
|
|
||||||
|
Daniel (19 November 1999):
|
||||||
|
- Chris Maltby very accurately criticized the lack of
|
||||||
|
return code checks on the fwrite() calls. I did a thorough check for all
|
||||||
|
occurrences and corrected this.
|
||||||
|
|
||||||
|
Daniel (17 November 1999):
|
||||||
|
- Paul Harrington pointed out that the -m/--max-time option
|
||||||
|
doesn't work for the slow system calls like gethostbyname()... I don't have
|
||||||
|
any good fix yet, just a slightly less bad one that makes curl exit hard
|
||||||
|
when the timeout is reached.
|
||||||
|
|
||||||
|
- Bjorn Reese helped me point out a possible problem that might be the reason
|
||||||
|
why Thomas Hurst experience problems in his Amiga version.
|
||||||
|
|
||||||
|
Daniel (12 November 1999):
|
||||||
|
- I found a crash in the new cookie file parser. It crashed when you gave
|
||||||
|
a plain http header file as input...
|
||||||
|
|
||||||
|
Version 6.3
|
||||||
|
|
||||||
|
Daniel (10 November 1999):
|
||||||
|
- I kind of found out that the HTTP time-conditional GETs (-z) aren't always
|
||||||
|
respected by the web server and the document is therefore sent in whole
|
||||||
|
again, even though it doesn't match the requested condition. After reading
|
||||||
|
section 13.3.4 of RFC 2616, I think I'm doing the right thing now when I do
|
||||||
|
my own check as well. If curl thinks the condition isn't met, the transfer
|
||||||
|
is aborted prematurely (after all the headers have been received).
|
||||||
|
|
||||||
|
- After comments from Robert Linden I also rewrote some parts of the man page
|
||||||
|
to better describe how the -F works.
|
||||||
|
|
||||||
|
- Michael Anti put up a new curl download mirror in
|
||||||
|
China: http://www.pshowing.com/curl/
|
||||||
|
|
||||||
|
- I added the list of download mirrors to the README file
|
||||||
|
|
||||||
|
- I did add more explanations to the man page
|
||||||
|
|
||||||
|
Daniel (8 November 1999):
|
||||||
|
- I made the -b/--cookie option capable of reading netscape formatted cookie
|
||||||
|
files as well as normal http-header files. It should be able to
|
||||||
|
transparently figure out what kind of file it got as input.
|
||||||
|
|
||||||
|
Daniel (29 October 1999):
|
||||||
|
- Another one of Sebastiaan van Erk's ideas (that has been requested before
|
||||||
|
but I seem to have forgotten who it was), is to add support for ranges in
|
||||||
|
FTP downloads. As usual, one request is just a request, when they're two
|
||||||
|
it is a demand. I've added simple support for X-Y style fetches. X has to
|
||||||
|
be the lower number, though you may omit one of the numbers. Use the -r/
|
||||||
|
--range switch (previously HTTP-only).
|
||||||
|
|
||||||
|
- Sebastiaan van Erk suggested that curl should be
|
||||||
|
able to show the file size of a specified file. I think this is a splendid
|
||||||
|
idea and the -I flag is now working for FTP. It displays the file size in
|
||||||
|
this manner:
|
||||||
|
Content-Length: XXXX
|
||||||
|
As it resembles normal headers, and leaves us the opportunity to add more
|
||||||
|
info in that display if we can come up with more in the future! It also
|
||||||
|
makes sense since if you access ftp through a HTTP proxy, you'd get the
|
||||||
|
file size the same way.
|
||||||
|
|
||||||
|
I changed the order of the QUOTE command executions. They're now executed
|
||||||
|
just after the login and before any other command. I made this to enable
|
||||||
|
quote commands to run before the -I stuff is done too.
|
||||||
|
|
||||||
|
- I found out that -D/--dump-header and -V/--version weren't documented in
|
||||||
|
the man page.
|
||||||
|
|
||||||
|
- Many HTTP/1.1 servers do not support ranges. Don't ask me why. I did add
|
||||||
|
some text about this in the man page for the range option. The thread in
|
||||||
|
the mailing list that started this was initiated by Michael Anti.
|
||||||
|
|
||||||
|
- I get reports about nroff crashes on solaris 2.6+ when displaying the curl
|
||||||
|
man page. Switch to gnroff instead, it is reported to work(!). Adam Barclay
|
||||||
|
reported and brought the suggestion.
|
||||||
|
|
||||||
|
- In a dialogue with Johannes G. Kristinsson we came
|
||||||
|
up with the idea to let -H/--header specified headers replace the
|
||||||
|
internally generated headers, if you happened to select to add a header
|
||||||
|
that curl normally uses by itself. The advantage with this is not entirely
|
||||||
|
obvious, but in Johannes' case it means that he can use another Host: than
|
||||||
|
the one curl would set.
|
||||||
|
|
||||||
|
Daniel (27 October 1999):
|
||||||
|
- Jongki Suwandi brought a nice patch for (yet another) crash when following
|
||||||
|
a location:. This time you had to follow a https:// server's redirect to
|
||||||
|
get the core.
|
||||||
|
|
||||||
|
Version 6.2
|
||||||
|
|
||||||
|
Daniel (21 October 1999):
|
||||||
|
- I think I managed to remove the suspicious (nil) that has been seen just
|
||||||
|
before the "Host:" in HTTP requests when -v was used.
|
||||||
|
- I found out that if you followed a location: when using a proxy, without
|
||||||
|
having specified http:// in the URL, the protocol part was added once again
|
||||||
|
when moving to the next URL! (The protocol part has to be added to the
|
||||||
|
URL when going through a proxy since it has no protocol-guessing system
|
||||||
|
such as curl has.)
|
||||||
|
- Benjamin Ritcey reported a core dump under solaris 2.6
|
||||||
|
with OpenSSL 0.9.4. It turned out this was due to a bad free() in main.c
|
||||||
|
that occurred after the download was done and completed.
|
||||||
|
- Benjamin found ftp downloads to show the first line of the download meter
|
||||||
|
to get written twice, and I removed that problem. It was introduced with
|
||||||
|
the multiple URL support.
|
||||||
|
- Dan Zitter correctly pointed out that curl 6.1 and earlier versions didn't
|
||||||
|
honor RFC 2616 chapter 4 section 2, "Message Headers": "...Field names are
|
||||||
|
case-insensitive..." HTTP header parsing assumed a certain casing. Dan
|
||||||
|
also provided me with a patch that corrected this, which I took the liberty
|
||||||
|
of editing slightly.
|
||||||
|
- Dan Zitter also provided a nice patch for config.guess to better recognize
|
||||||
|
the Mac OS X
|
||||||
|
- Dan also corrected a minor problem in the lib/Makefile that caused linking
|
||||||
|
to fail on OS X.
|
||||||
|
|
||||||
|
Daniel (19 October 1999):
|
||||||
|
- Len Marinaccio came up with some problems with curl. Since Windows has a
|
||||||
|
crippled shell, it can't redirect stderr and that causes trouble. I added
|
||||||
|
--stderr today which allows the user to redirect the stderr stream to a
|
||||||
|
file or stdout.
|
||||||
|
|
||||||
|
Daniel (18 October 1999):
|
||||||
|
- The configure script now understands the '--without-ssl' flag, which now
|
||||||
|
totally disable SSL/https support. Previously it wasn't possible to force
|
||||||
|
the configure script to leave SSL alone. The previous functionality has
|
||||||
|
been retained. Troy Engel helped test this new one.
|
||||||
|
|
||||||
|
Version 6.1
|
||||||
|
|
||||||
|
Daniel (17 October 1999):
|
||||||
|
- I ifdef'ed or commented all the zlib stuff in the sources and configure
|
||||||
|
script. It turned out we needed to mock more with zlib than I initially
|
||||||
|
thought, to make it capable of downloading compressed HTTP documents and
|
||||||
|
uncompress them on the fly. I didn't mean the zlib parts of curl to become
|
||||||
|
more than minor so this means I halt the zlib expedition for now and wait
|
||||||
|
until someone either writes the code or zlib gets updated and better
|
||||||
|
adjusted for this kind of usage. I won't get into details here, but a
|
||||||
|
short a summary is suitable:
|
||||||
|
- zlib can't automatically detect whether to use zlib or gzip
|
||||||
|
decompression methods.
|
||||||
|
- zlib is very neat for reading gzipped files from a file descriptor,
|
||||||
|
although not as nice for reading buffer-based data such as we would
|
||||||
|
want it.
|
||||||
|
- there are still some problems with the win32 version when reading from
|
||||||
|
a file descriptor if that is a socket
|
||||||
|
|
||||||
|
Daniel (14 October 1999):
|
||||||
|
- Moved the (external) include files for libcurl into a subdirectory named
|
||||||
|
curl and adjusted all #include lines to use <curl/XXXX> to maintain a
|
||||||
|
better name space and control of the headers. This has been requested.
|
||||||
|
|
||||||
|
Daniel (12 October 1999):
|
||||||
|
- I modified the 'maketgz' script to perform a 'make' too before a release
|
||||||
|
archive is put together in an attempt to make the time stamps better and
|
||||||
|
hopefully avoid the double configure-running that use to occur.
|
||||||
|
|
||||||
|
Daniel (11 October 1999):
|
||||||
|
- Applied J<>rn's patches that fixes zlib for mingw32 compiles as well as
|
||||||
|
some other missing zlib #ifdef and more text on the multiple URL docs in
|
||||||
|
the man page.
|
||||||
|
|
||||||
|
Version 6.1beta
|
||||||
|
|
||||||
|
Daniel (6 October 1999):
|
||||||
|
- Douglas E. Wegscheid sent me a patch that made the exact same thing as I
|
||||||
|
just made: the -d switch is now capable of reading post data from a named
|
||||||
|
file or stdin. Use it similarly to the -F. To read the post data from a
|
||||||
|
given file:
|
||||||
|
|
||||||
|
curl -d @path/to/filename www.postsite.com
|
||||||
|
|
||||||
|
or let curl read it out from stdin:
|
||||||
|
|
||||||
|
curl -d @- www.postit.com
|
||||||
|
|
||||||
|
J<>rn Hartroth (3 October 1999):
|
||||||
|
- Brought some more patches for multiple URL functionality. The MIME
|
||||||
|
separation ideas are almost scrapped now, and a custom separator is being
|
||||||
|
used instead. This is still compile-time "flagged".
|
||||||
|
|
||||||
|
Daniel
|
||||||
|
- Updated curl.1 with multiple URL info.
|
||||||
|
|
||||||
|
Daniel (30 September 1999):
|
||||||
|
- Felix von Leitner brought openssl-check fixes for configure.in to work
|
||||||
|
out-of-the-box when the openssl files are installed in the system default
|
||||||
|
dirs.
|
||||||
|
|
||||||
|
Daniel (28 September 1999)
|
||||||
|
- Added libz functionality. This should enable decompressing gzip, compress
|
||||||
|
or deflate encoding HTTP documents. It also makes curl send an accept that
|
||||||
|
it accepts that kind of encoding. Compressed contents usually shortens
|
||||||
|
download time. I *need* someone to tell me a site that uses compressed HTTP
|
||||||
|
documents so that I can test this out properly.
|
||||||
|
|
||||||
|
- As a result of the adding of zlib awareness, I changed the version string
|
||||||
|
a little. I plan to add openldap version reporting in there too.
|
||||||
|
|
||||||
|
Daniel (17 September 1999)
|
||||||
|
- Made the -F option allow stdin when specifying files. By using '-' instead
|
||||||
|
of file name, the data will be read from stdin.
|
||||||
|
|
||||||
|
Version 6.0
|
||||||
|
|
||||||
|
Daniel (13 September 1999)
|
||||||
|
- Added -X/--http-request <request> to enable any HTTP command to be sent.
|
||||||
|
Do not that your server has to support the exact string you enter. This
|
||||||
|
should possibly a string like DELETE or TRACE.
|
||||||
|
|
||||||
|
- Applied Douglas' mingw32-fixes for the makefiles.
|
||||||
|
|
||||||
|
Daniel (10 September 1999)
|
||||||
|
- Douglas E. Wegscheid pointed out a problem. Curl didn't check the FTP
|
||||||
|
servers return code properly after the --quote commands were issued. It
|
||||||
|
took anything non 200 as an error, when all 2XX codes should be accepted as
|
||||||
|
OK.
|
||||||
|
|
||||||
|
- Sending cookies to the same site in multiple lines like curl used to do
|
||||||
|
turned out to be bad and breaking the cookie specs. Curl now sends all
|
||||||
|
cookies on a single Cookie: line. Curl is not yet RFC 2109 compliant, but I
|
||||||
|
doubt that many servers do use that syntax (yet).
|
||||||
|
|
||||||
|
Daniel (8 September 1999)
|
||||||
|
- J<>rn helped me make sure it still compiles nicely with mingw32 under win32.
|
||||||
|
|
||||||
|
Daniel (7 September 1999)
|
||||||
|
- FTP upload through proxy is now turned into a HTTP PUT. Requested by
|
||||||
|
Stefan Kanthak.
|
||||||
|
|
||||||
|
- Added the ldap files to the .m32 makefile.
|
||||||
|
|
||||||
|
Daniel (3 September 1999)
|
||||||
|
- Made cookie matching work while using HTTP proxy.
|
||||||
|
|
||||||
|
Bjorn Reese (31 August 1999)
|
||||||
|
- Passed his ldap:// patch. Note that this requires the openldap shared
|
||||||
|
library to be installed and that LD_LIBRARY_PATH points to the
|
||||||
|
directory where the lib will be found when curl is run with a
|
||||||
|
ldap:// URL.
|
||||||
|
|
||||||
|
J<>rn Hartroth (31 August 1999)
|
||||||
|
- Made the Mingw32 makefiles into single files.
|
||||||
|
- Made file:// work for Win32. The same code is now used for unix as well for
|
||||||
|
performance reasons.
|
||||||
|
|
||||||
|
Douglas E. Wegscheid (30 August 1999)
|
||||||
|
- Patched the Mingw32 makefiles for SSL builds.
|
||||||
|
|
||||||
|
Matthew Clarke (30 August 1999)
|
||||||
|
- Made a cool patch for configure.in to allow --with-ssl to specify the
|
||||||
|
root dir of the openssl installation, as in
|
||||||
|
|
||||||
|
./configure --with-ssl=/usr/ssl_here
|
||||||
|
|
||||||
|
- Corrected the 'reconf' script to work better with some shells.
|
||||||
|
|
||||||
|
J<>rn Hartroth (26 August 1999)
|
||||||
|
- Fixed the Mingw32 makefiles in lib/ and corrected the file.c for win32
|
||||||
|
compiles.
|
||||||
|
|
||||||
|
Version 5.11
|
||||||
|
|
||||||
|
Daniel (25 August 1999)
|
||||||
|
- John Weismiller pointed out a bug in the header-line
|
||||||
|
realloc() system in download.c.
|
||||||
|
|
||||||
|
- I added lib/file.[ch] to offer a first, simple, file:// support. It
|
||||||
|
probably won't do much good on win32 system at this point, but I see it
|
||||||
|
as a start.
|
||||||
|
|
||||||
|
- Made the release archives get a Makefile in the root dir, which can be
|
||||||
|
used to start the compiling/building process easier. I haven't really
|
||||||
|
changed any INSTALL text yet, I wanted to get some feed-back on this
|
||||||
|
first.
|
||||||
|
|
||||||
|
Daniel (17 August 1999)
|
||||||
|
- Another Location: bug. Curl didn't do proper relative locations if the
|
||||||
|
original URL had cgi-parameters that contained a slash. Nusu's page
|
||||||
|
again.
|
||||||
|
|
||||||
|
- Corrected the NO_PROXY usage. It is a list of substrings that if one of
|
||||||
|
them matches the tail of the host name it should connect to, curl should
|
||||||
|
not use a proxy to connect there. Pointed out to me by Douglas
|
||||||
|
E. Wegscheid. I also changed the README text a little regarding this.
|
||||||
|
|
||||||
|
Daniel (16 August 1999)
|
||||||
|
- Fixed a memory bug with http-servers that sent Location: to a Location:
|
||||||
|
page. Nusu's page showed this too.
|
||||||
|
|
||||||
|
- Made cookies work a lot better. Setting the same cookie name several times
|
||||||
|
used to add more cookies instead of replacing the former one which it
|
||||||
|
should've. Nusu <nus at intergorj.ro> brought me an URL that made this
|
||||||
|
painfully visible...
|
||||||
|
|
||||||
|
Troy (15 August 1999)
|
||||||
|
- Brought new .spec files as well as a patch for configure.in that lets the
|
||||||
|
configure script find the openssl files better, even when the include
|
||||||
|
files are in /usr/include/openssl
|
||||||
|
|
||||||
|
Version 5.10
|
||||||
|
|
||||||
|
Daniel (13 August 1999)
|
||||||
|
- SSL_CTX_set_default_passwd_cb() has been modified in the 0.9.4 version of
|
||||||
|
OpenSSL. Now why couldn't they simply add a *new* function instead of
|
||||||
|
modifying the parameters of an already existing function? This way, we get
|
||||||
|
a compiler warning if compiling with 0.9.4 but not with earlier. So, I had
|
||||||
|
to come up with a #if construction that deals with this...
|
||||||
|
|
||||||
|
- Made curl output the SSL version number get displayed properly with 0.9.4.
|
||||||
|
|
||||||
|
Troy (12 August 1999)
|
||||||
|
- Added MingW32 (GCC-2.95) support under Win32. The INSTALL file was also
|
||||||
|
a bit rearranged.
|
||||||
|
|
||||||
|
Daniel (12 August 1999)
|
||||||
|
- I had to copy a good <arpa/telnet.h> include file into the curl source
|
||||||
|
tree to enable the silly win32 systems to compile. The distribution rights
|
||||||
|
allows us to do that as long as the file remains unmodified.
|
||||||
|
|
||||||
|
- I corrected a few minor things that made the compiler complain when
|
||||||
|
-Wall -pedantic was used.
|
||||||
|
|
||||||
|
- I'm moving the official curl web page to http://curl.haxx.nu. I think it
|
||||||
|
will make it easier to remember as it is a lot shorter and less cryptic.
|
||||||
|
The old one still works and shows the same info.
|
||||||
|
|
||||||
|
Daniel (11 August 1999)
|
||||||
|
- Albert Chin-A-Young mailed me another correction for NROFF in the
|
||||||
|
configure.in that is supposed to be better for IRIX users.
|
||||||
|
|
||||||
|
Daniel (10 August 1999)
|
||||||
|
- Albert Chin-A-Young helped me with some stupid Makefile things, as well as
|
||||||
|
some fiddling with the getdate.c stuff that he had problems with under
|
||||||
|
HP-UX v10. getdate.y will now be compiled into getdate.c if the appropriate
|
||||||
|
yacc or bison is found by the configure script. Since this is slightly new,
|
||||||
|
we need to test the output getdate.c with win32 systems to make sure it
|
||||||
|
still compiles there.
|
||||||
|
|
||||||
|
Daniel (5 August 1999)
|
||||||
|
- I've just setup a new mailing list with the intention to keep discussions
|
||||||
|
around libcurl development in it. I mainly expect it to be for thoughts and
|
||||||
|
brainstorming around a "next generation" library, rather than nitpicking
|
||||||
|
about the current implementation or details in the current libcurl.
|
||||||
|
|
||||||
|
To join our happy bunch of future-looking geeks, enter 'subscribe
|
||||||
|
<address>' in the body of a mail and send it to
|
||||||
|
libcurl-request@listserv.fts.frontec.se. Curl bug reports, the usual curl
|
||||||
|
talk and everything else should still be kept in this mailing list. I've
|
||||||
|
started to archive this mailing list and have put the libcurl web page at
|
||||||
|
www.fts.frontec.se/~dast/libcurl/.
|
||||||
|
|
||||||
|
- Stefan Kanthak contacted me regarding a few problems in the configure
|
||||||
|
script which he discovered when trying to make curl compile and build under
|
||||||
|
Siemens SINIX-Z V5.42B2004!
|
||||||
|
|
||||||
|
- Marcus Klein very accurately informed me that src/version.h was not present
|
||||||
|
in the CVS repository. Oh, how silly...
|
||||||
|
|
||||||
|
- Linus Nielsen rewrote the telnet:// part and now curl offers limited telnet
|
||||||
|
support. If you run curl like 'curl telnet://host' you'll get all output on
|
||||||
|
the screen and curl will read input from stdin. You'll be able to login and
|
||||||
|
run commands etc, but since the output is buffered, expect to get a little
|
||||||
|
weird output.
|
||||||
|
|
||||||
|
This is still in its infancy and it might get changed. We need your
|
||||||
|
feed-back and input in how this is best done.
|
||||||
|
|
||||||
|
WIN32 NOTE: I bet we'll get problems when trying to compile the current
|
||||||
|
lib/telnet.c on win32, but I think we can sort them out in time.
|
||||||
|
|
||||||
|
- David Sanderson reported that FORCE_ALLOCA_H or HAVE_ALLOCA_H must be
|
||||||
|
defined for getdate.c to compile properly on HP-UX 11.0. I updated the
|
||||||
|
configure script to check for alloca.h which should make it.
|
||||||
|
|
||||||
|
Daniel (4 August 1999)
|
||||||
|
- I finally got to understand Marcus Klein's ftp download resume problem,
|
||||||
|
which turns out to be due to different outputs from different ftp
|
||||||
|
servers. It makes ftp download resuming a little trickier, but I've made
|
||||||
|
some modifications I really believe will work for most ftp servers and I do
|
||||||
|
hope you report if you have problems with this!
|
||||||
|
|
||||||
|
- Added text about file transfer resuming to README.curl.
|
||||||
|
|
||||||
|
Daniel (2 August 1999)
|
||||||
|
- Applied a progress-bar patch from Lars J. Aas. It offers
|
||||||
|
a new styled progress bar enabled with -#/--progress-bar.
|
||||||
|
|
||||||
|
T. Yamada <tai at imasy.or.jp> (30 July 1999)
|
||||||
|
- It breaks with segfault when 1) curl is using .netrc to obtain
|
||||||
|
username/password (option '-n'), and 2) is automatically redirected to
|
||||||
|
another location (option '-L').
|
||||||
|
|
||||||
|
There is a small bug in lib/url.c (block starting from line 641), which
|
||||||
|
tries to take out username/password from user- supplied command-line
|
||||||
|
argument ('-u' option). This block is never executed on first attempt since
|
||||||
|
CONF_USERPWD bit isn't set at first, but curl later turns it on when it
|
||||||
|
checks for CONF_NETRC bit. So when curl tries to redo everything due to
|
||||||
|
redirection, it segfaults trying to access *data->userpwd.
|
||||||
|
|
||||||
|
Version 5.9.1
|
||||||
|
|
||||||
|
Daniel (30 July 1999)
|
||||||
|
- Steve Walch pointed out that there is a memory leak in the formdata
|
||||||
|
functions. I added a FormFree() function that is now used and supposed to
|
||||||
|
correct this flaw.
|
||||||
|
|
||||||
|
- Mark Wotton reported:
|
||||||
|
'curl -L https://www.cwa.com.au/' core dumps. I managed to cure this by
|
||||||
|
correcting the cleanup procedure. The bug seems to be gone with my OpenSSL
|
||||||
|
0.9.2b, although still occurs when I run the ~100 years old SSLeay 0.8.0. I
|
||||||
|
don't know whether it is curl or SSLeay that is to blame for that.
|
||||||
|
|
||||||
|
- Marcus Klein:
|
||||||
|
Reported an FTP upload resume bug that I really can't repeat nor understand.
|
||||||
|
I leave it here so that it won't be forgotten.
|
||||||
|
|
||||||
|
Daniel (29 July 1999)
|
||||||
|
- Costya Shulyupin suggested support for longer URLs when following Location:
|
||||||
|
and I could only agree and fix it!
|
||||||
|
|
||||||
|
- Leigh Purdie found a problem in the upload/POST department. It turned out
|
||||||
|
that http.c accidentaly cleared the pointer instead of the byte counter
|
||||||
|
when supposed to.
|
||||||
|
|
||||||
|
- Costya Shulyupin pointed out a problem with port numbers and Location:. If
|
||||||
|
you had a server at a non-standard port that redirected to an URL using a
|
||||||
|
standard port number, curl still used that first port number.
|
||||||
|
|
||||||
|
- Ralph Beckmann pointed out a problem when using both CONF_FOLLOWLOCATION
|
||||||
|
and CONF_FAILONERROR simultaneously. Since the CONF_FAILONERROR exits on
|
||||||
|
the 302-code that the follow location header outputs it will never show any
|
||||||
|
html on location: pages. I have now made it look for >=400 codes if
|
||||||
|
CONF_FOLLOWLOCATION is set.
|
||||||
|
|
||||||
|
- 'struct slist' is now renamed to 'struct curl_slist' (as suggested by Ralph
|
||||||
|
Beckmann).
|
||||||
|
|
||||||
|
- Joshua Swink and Rick Welykochy were the first to point out to me that the
|
||||||
|
latest OpenSSL package now have moved the standard include path. It is now
|
||||||
|
in /usr/local/ssl/include/openssl and I have now modified the --enable-ssl
|
||||||
|
option for the configure script to use that as the primary path, and I
|
||||||
|
leave the former path too to work with older packages of OpenSSL too.
|
||||||
|
|
||||||
|
Daniel (9 June 1999)
|
||||||
|
- I finally understood the IRIX problem and now it seem to compile on it!
|
||||||
|
I am gonna remove those #define strcasecmp() things once and for all now.
|
||||||
|
|
||||||
|
Daniel (4 June 1999)
|
||||||
|
- I adjusted the FTP reply 227 parser to make the PASV command work better
|
||||||
|
with more ftp servers. Appearantly the Roxen Challanger server replied
|
||||||
|
something curl 5.9 could deal with! :-( Reported by Ashley Reid-Montanaro
|
||||||
|
and Mark Butler brought a solution for it.
|
||||||
|
|
||||||
|
Daniel (26 May 1999)
|
||||||
|
- Rearranged. README is new, the old one is now README.curl and I added a
|
||||||
|
README.libcurl with text I got from Ralph Beckmann.
|
||||||
|
|
||||||
|
- I also updated the INSTALL text.
|
||||||
|
|
||||||
|
Daniel (25 May 1999)
|
||||||
|
- David Jonathan Lowsky correctly pointed out that curl didn't properly deal
|
||||||
|
with form posting where the variable shouldn't have any content, as in curl
|
||||||
|
-F "form=" www.site.com. It was now fixed.
|
||||||
|
|
||||||
|
Version 5.9
|
||||||
|
|
||||||
|
Daniel (22 May 1999)
|
||||||
|
- I've got a bug report from Aaron Scarisbrick in which he states he has some
|
||||||
|
problems with -L under FreeBSD 3.0. I have previously got another bug
|
||||||
|
report from Stefan Grether which points at an error with similar sympthoms
|
||||||
|
when using win32. I made the allocation of the new url string a bit faster
|
||||||
|
and different, don't know if it actually improves anything though...
|
||||||
|
|
||||||
|
Daniel (20 May 1999)
|
||||||
|
- Made the cookie parser deal with CRLF newlines too.
|
||||||
|
|
||||||
|
Daniel (19 May 1999)
|
||||||
|
- Download() didn't properly deal with failing return codes from the sread()
|
||||||
|
function. Adam Coyne found the problem in the win32 version, and Troy Engel
|
||||||
|
helped me out isolating it.
|
||||||
|
|
||||||
|
Daniel (16 May 1999)
|
||||||
|
- Richard Adams pointed out a bug I introduced in 5.8. --dump-header doesn't
|
||||||
|
work anymore! :-/ I fixed it now.
|
||||||
|
|
||||||
|
- After a suggestion by Joshua Swink I added -S / --show-error to force curl
|
||||||
|
to display the error message in case of an error, even if -s/--silent was
|
||||||
|
used.
|
||||||
|
|
||||||
|
Daniel (10 May 1999)
|
||||||
|
- I moved the stuff concerning HTTP, DICT and TELNET it their own source
|
||||||
|
files now. It is a beginning on my clean-up of the sources to make them
|
||||||
|
layer all those protocols better to enable more to be added easier in the
|
||||||
|
future!
|
||||||
|
|
||||||
|
- Leon Breedt sent me some files I've not put into the main curl
|
||||||
|
archive. They're for creating the Debian package thingie. He also sent me a
|
||||||
|
debian package that I've made available for download at the web page
|
||||||
|
|
||||||
|
Daniel (9 May 1999)
|
||||||
|
- Made it compile on cygwin too.
|
||||||
|
|
||||||
|
Troy Engel (7 May 1999)
|
||||||
|
- Brought a series of patches to allow curl to compile smoothly on MSVC++ 6
|
||||||
|
again!
|
||||||
|
|
||||||
|
Daniel (6 May 1999)
|
||||||
|
- I changed the #ifdef HAVE_STRFTIME placement for the -z code so that it
|
||||||
|
will be easier to discover systems that don't have that function and thus
|
||||||
|
can't use -z successfully. Made the strftime() get used if WIN32 is defined
|
||||||
|
too.
|
||||||
|
|
||||||
|
Version 5.8
|
||||||
|
|
||||||
|
Daniel (5 May 1999)
|
||||||
|
- I've had it with this autoconf/automake mess. It seems to work allright
|
||||||
|
for most people who don't have automake installed, but for those who have
|
||||||
|
there are problems all over.
|
||||||
|
|
||||||
|
I've got like five different bug reports on this only the last
|
||||||
|
week... Claudio Neves and Federico Bianchi and root <duggerj001 at
|
||||||
|
hawaii.rr.com> are some of them reporting this.
|
||||||
|
|
||||||
|
Currently, I have no really good fix since I want to use automake myself to
|
||||||
|
generate the Makefile.in files. I've found out that the @SHELL@-problems
|
||||||
|
can often be fixed by manually invoking 'automake' in the archive root
|
||||||
|
before you run ./configure... I've hacked my maketgz script now to fiddle
|
||||||
|
a bit with this and my tests seem to work better than before at least!
|
||||||
|
|
||||||
|
Daniel (4 May 1999)
|
||||||
|
- mkhelp.pl has been doing badly lately. I corrected a case problem in
|
||||||
|
the regexes.
|
||||||
|
|
||||||
|
- I've now remade the -o option to not touch the file unless it needs to.
|
||||||
|
I had to do this to make -z option really fine, since now you can make a
|
||||||
|
curl fetch and use a local copy's time when downloading to that file, as
|
||||||
|
in:
|
||||||
|
|
||||||
|
curl -z dump -o dump remote.site.com/file.html
|
||||||
|
|
||||||
|
This will only get the file if the remote one is newer than the local.
|
||||||
|
I'm aware that this alters previous behaviour a little. Some scripts out
|
||||||
|
there may depend on that the file is always touched...
|
||||||
|
|
||||||
|
- Corrected a bug in the SSLv2/v3 selection.
|
||||||
|
|
||||||
|
- Felix von Leitner requested that curl should be able to send
|
||||||
|
"If-Modified-Since" headers, which indeed is a fair idea. I implemented it
|
||||||
|
right away! Try -z <expression> where expression is a full GNU date
|
||||||
|
expression or a file name to get the date from!
|
||||||
|
|
||||||
|
Stephan Lagerholm (30 Apr 1999)
|
||||||
|
- Pointed out a problem with the src/Makefile for FreeBSD. The RM variable
|
||||||
|
isn't set and causes the make to fail.
|
||||||
|
|
||||||
|
Daniel (26 April 1999)
|
||||||
|
- Am I silly or what? Irving Wolfe pointed out to me that the curl version
|
||||||
|
number was not set properly. Hasn't been since 5.6. This was due to a bug
|
||||||
|
in my maketgz script!
|
||||||
|
|
||||||
|
David Eriksson (25 Apr 1999)
|
||||||
|
- Found a bug in cookies.c that made it crash at times.
|
||||||
|
|
||||||
|
Version 5.7.1
|
||||||
|
|
||||||
|
Doug Kaufman (23 Apr 1999)
|
||||||
|
- Brought two sunos 4 fixes. One of them being the hostip.c fix mentioned
|
||||||
|
below and the other one a correction in include/stdcheaders.h
|
||||||
|
|
||||||
|
- Added a paragraph about compiling with the US-version of openssl to the
|
||||||
|
INSTALL file.
|
||||||
|
|
||||||
|
Daniel
|
||||||
|
- New mailing list address. Info updated on the web page as well as in the
|
||||||
|
README file
|
||||||
|
|
||||||
|
Greg Onufer (20 Apr 1999)
|
||||||
|
- hostip.c didn't compile properly on SunOS 5.5.1.
|
||||||
|
It needs an #include <sys/types.h>
|
||||||
|
|
||||||
|
Version 5.7
|
||||||
|
|
||||||
|
Daniel (Apr 20 1999)
|
||||||
|
- Decided to upload a non-beta version right now!
|
||||||
|
|
||||||
|
- Made curl support any-length HTTP headers. The destination buffer is now
|
||||||
|
simply enlarged every time it turns out to be too small!
|
||||||
|
|
||||||
|
- Added the FAQ file to the archive. Still a bit smallish, but it is a
|
||||||
|
start.
|
||||||
|
|
||||||
|
Eric Thelin (15 Apr 1999)
|
||||||
|
- Made -D accept '-' instead of filename to write to stdout.
|
||||||
|
|
||||||
|
Version 5.6.3beta
|
||||||
|
|
||||||
|
Daniel (Apr 12 1999)
|
||||||
|
|
||||||
|
- Changed two #ifdef WIN32 to better #ifdef <errorcode> when connect()ing
|
||||||
|
in url.c and ftp.c. Makes cygwin32 deal with them better too. We should
|
||||||
|
try to get some decent win32-replacement there. Anyone?
|
||||||
|
|
||||||
|
- The old -3/--crlf option is now ONLY --crlf!
|
||||||
|
|
||||||
|
- I changed the "SSL fix" to a more lame one, but that doesn't remove as
|
||||||
|
much functionality. Now I've enabled the lib to select what SSL version it
|
||||||
|
should try first. Appearantly some older SSL-servers don't like when you
|
||||||
|
talk v3 with them so you need to be able to force curl to talk v2 from the
|
||||||
|
start. The fix dated April 6 and posted on the mailing list forced curl to
|
||||||
|
use v2 at all times using a modern OpenSSL version, but we don't really
|
||||||
|
want such a crippled solution.
|
||||||
|
|
||||||
|
- Marc Boucher sent me a patch that corrected a math error for the
|
||||||
|
"Curr.Speed" progress meter.
|
||||||
|
|
||||||
|
- Eric Thelin sent me a patch that enables '-K -' to read a config file from
|
||||||
|
stdin.
|
||||||
|
|
||||||
|
- I found out we didn't close the file properly before so I added it!
|
||||||
|
|
||||||
|
Daniel (Apr 9 1999)
|
||||||
|
- Yu Xin pointed out a problem with ftp download resume. It didn't work at
|
||||||
|
all! ;-O
|
||||||
|
|
||||||
|
Daniel (Apr 6 1999)
|
||||||
|
- Corrected the version string part generated for the SSL version.
|
||||||
|
|
||||||
|
- I found a way to make some other SSL page work with openssl 0.9.1+ that
|
||||||
|
previously didn't (ssleay 0.8.0 works with it though!). Trying to get
|
||||||
|
some real info from the OpenSSL guys to see how I should do to behave the
|
||||||
|
best way. SSLeay 0.8.0 shouldn't be that much in use anyway these days!
|
||||||
|
|
||||||
|
Version 5.6.2beta
|
||||||
|
|
||||||
|
Daniel (Apr 4 1999)
|
||||||
|
- Finally have curl more cookie "aware". Now read carefully. This is how
|
||||||
|
it works.
|
||||||
|
To make curl read cookies from an already existing file, in plain header-
|
||||||
|
format (like from the headers of a previous fetch) invoke curl with the
|
||||||
|
-b flag like:
|
||||||
|
|
||||||
|
curl -b file http://site/foo.html
|
||||||
|
|
||||||
|
Curl will then use all cookies it finds matching. The old style that sets
|
||||||
|
a single cookie with -b is still supported and is used if the string
|
||||||
|
following -b includes a '=' letter, as in "-b name=daniel".
|
||||||
|
|
||||||
|
To make curl read the cookies sent in combination with a location: (which
|
||||||
|
sites often do) point curl to read a non-existing file at first (i.e
|
||||||
|
to start with no existing cookies), like:
|
||||||
|
|
||||||
|
curl -b nowhere http://site/setcookieandrelocate.html
|
||||||
|
|
||||||
|
- Added a paragraph in the TODO file about the SSL problems recently
|
||||||
|
reported. Evidently, some kind of SSL-problem curl may need to address.
|
||||||
|
|
||||||
|
- Better "Location:" following.
|
||||||
|
|
||||||
|
Douglas E. Wegscheid (Tue, 30 Mar 1999)
|
||||||
|
- A subsecond display patch.
|
||||||
|
|
||||||
|
Daniel (Mar 14 1999)
|
||||||
|
- I've separated the version number of libcurl and curl now. To make
|
||||||
|
things a little easier, I decided to start the curl numbering from
|
||||||
|
5.6 and the former version number known as "curl" is now the one
|
||||||
|
set for libcurl.
|
||||||
|
|
||||||
|
- Removed the 'enable-no-pass' from configure, I doubt anyone wanted
|
||||||
|
that.
|
||||||
|
|
||||||
|
- Made lots of tiny adjustments to compile smoothly with cygwin under
|
||||||
|
win32. It's a killer for porting this to win32, bye bye VC++! ;-)
|
||||||
|
Compiles and builds out-of-the-box now. See the new wordings in
|
||||||
|
INSTALL for details.
|
||||||
|
|
||||||
|
- Beginning experiments with downloading multiple document from a http
|
||||||
|
server while remaining connected.
|
||||||
|
|
||||||
|
Version 5.6beta
|
||||||
|
|
||||||
|
Daniel (Mar 13 1999)
|
||||||
|
- Since I've changed so much, I thought I'd just go ahead and implement the
|
||||||
|
suggestion from Douglas E. Wegscheid. -D or --dump-header is now storing
|
||||||
|
HTTP headers separately in the specified file.
|
||||||
|
|
||||||
|
- Added new text to INSTALL on what to do to build this on win32 now.
|
||||||
|
|
||||||
|
- Aaargh. I had to take a step back and prefix the shared #include files
|
||||||
|
in the sources with "../include/" to please VC++...
|
||||||
|
|
||||||
|
Daniel (Mar 12 1999)
|
||||||
|
- Split the url.c source into many tiny sources for better readability
|
||||||
|
and smaller size.
|
||||||
|
|
||||||
|
Daniel (Mar 11 1999)
|
||||||
|
- Started to change stuff for a move to make libcurl and a more separate
|
||||||
|
curl application that uses the libcurl. Made the libcurl sources into
|
||||||
|
the new lib directory while the curl application will remain in src as
|
||||||
|
before. New makefiles, adjusted configure script and so.
|
||||||
|
|
||||||
|
libcurl.a built quickly and easily. I better make a better interface to
|
||||||
|
the lib functions though.
|
||||||
|
|
||||||
|
The new root dir include/ is supposed to contain the public information
|
||||||
|
about the new libcurl. It is a little ugly so far :-)
|
||||||
|
|
||||||
|
|
||||||
|
Daniel (Mar 1 1999)
|
||||||
|
- Todd Kaufmann sent me a good link to Netscape's cookie spec as well as the
|
||||||
|
info that RFC 2109 specifies how to use them. The link is now in the
|
||||||
|
README and the RFC in the RESOURCES.
|
||||||
|
|
||||||
|
Daniel (Feb 23 1999)
|
||||||
|
- Finally made configure accept --with-ssl to look for SSL libs and includes
|
||||||
|
in the "standard" place /usr/local/ssl...
|
||||||
|
|
||||||
|
Daniel (Feb 22 1999)
|
||||||
|
- Verified that curl linked fine with OpenSSL 0.9.1c which seems to be
|
||||||
|
the most recent.
|
||||||
|
|
||||||
|
Henri Gomez (Fri Feb 5 1999)
|
||||||
|
- Sent in an updated curl-ssl.spec. I still miss the script that builds an
|
||||||
|
RPM automatically...
|
||||||
|
|
||||||
|
Version 5.5.1
|
||||||
|
|
||||||
|
Mark Butler (27 Jan 1999)
|
||||||
|
- Corrected problems in Download().
|
||||||
|
|
||||||
|
Danitel Stenberg (25 Jan 1999)
|
||||||
|
- Jeremie Petit pointed out a few flaws in the source that prevented it from
|
||||||
|
compile warning free with the native compiler under Digital Unix v4.0d.
|
||||||
|
|
||||||
|
Version 5.5
|
||||||
|
|
||||||
|
Daniel Stenberg (15 Jan 1999)
|
||||||
|
- Added Bjorns small text to the README about the DICT protocol.
|
||||||
|
|
||||||
|
Daniel Stenberg (11 Jan 1999)
|
||||||
|
- <jswink at softcom.net> reported about the win32-versioin: "Doesn't use
|
||||||
|
ALL_PROXY environment variable". Turned out to be because of the static-
|
||||||
|
buffer nature of the win32 environment variable calls!
|
||||||
|
|
||||||
|
Bjorn Reese (10 Jan 1999)
|
||||||
|
- I have attached a simple addition for the DICT protocol (RFC 2229).
|
||||||
|
It performs dictionary lookups. The output still needs to be better
|
||||||
|
formatted.
|
||||||
|
|
||||||
|
To test it try (the exact format, and more examples are described in
|
||||||
|
the RFC)
|
||||||
|
|
||||||
|
dict://dict.org/m:hello
|
||||||
|
dict://dict.org/m:hello::soundex
|
||||||
|
|
||||||
|
|
||||||
|
Vicente Garcia (10 Jan 1999)
|
||||||
|
- Corrected the progress meter for files larger than 20MB.
|
||||||
|
|
||||||
|
Daniel Stenberg (7 Jan 1999)
|
||||||
|
- Corrected the -t and -T help texts. They claimed to be FTP only.
|
||||||
|
|
||||||
|
Version 5.4
|
||||||
|
|
||||||
|
Daniel Stenberg
|
||||||
|
(7 Jan 1999)
|
||||||
|
- Irving Wolfe reported that curl -s didn't always supress the progress
|
||||||
|
reporting. It was the form post that autoamtically always switched it on
|
||||||
|
again. This is now corrected!
|
||||||
|
|
||||||
|
(4 Jan 1999)
|
||||||
|
- Andreas Kostyrka suggested I'd add PUT and he helped me out to test it. If
|
||||||
|
you use -t or -T now on a http or https server, PUT will be used for file
|
||||||
|
upload.
|
||||||
|
|
||||||
|
I removed the former use of -T with HTTP. I doubt anyone ever really used
|
||||||
|
that.
|
||||||
|
|
||||||
|
(4 Jan 1999)
|
||||||
|
- Erik Jacobsen found a width bug in the mprintf() function. I corrected it
|
||||||
|
now.
|
||||||
|
|
||||||
|
(4 Jan 1999)
|
||||||
|
- As John V. Chow pointed out to me, curl accepted very limited URL sizes. It
|
||||||
|
should now accept path parts that are up to at least 4096 bytes.
|
||||||
|
|
||||||
|
- Somehow I screwed up when applying the AIX fix from Gilbert Ramirez, so
|
||||||
|
I redid that now.
|
||||||
|
|
||||||
1381
CHANGES.2000
Normal file
1381
CHANGES.2000
Normal file
File diff suppressed because it is too large
Load Diff
59
CVS-INFO
Normal file
59
CVS-INFO
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
CVS-INFO
|
||||||
|
|
||||||
|
This file is only present in the CVS - never in release archives. It contains
|
||||||
|
information about other files and things that the CVS repository keeps in its
|
||||||
|
inner sanctum.
|
||||||
|
|
||||||
|
Compile and build instructions follow below.
|
||||||
|
|
||||||
|
CHANGES.0 contains ancient changes.
|
||||||
|
CHANGES.$year contains changes for the particular year.
|
||||||
|
|
||||||
|
memanalyze.pl is for analyzing the output generated by curl if -DMALLOCDEBUG
|
||||||
|
is used when compiling
|
||||||
|
|
||||||
|
buildconf builds the makefiles and configure stuff
|
||||||
|
|
||||||
|
Makefile.dist is included as the root Makefile in distribution archives
|
||||||
|
|
||||||
|
perl/ is a subdirectory with various perl scripts
|
||||||
|
|
||||||
|
To build after having extracted everything from CVS, do this:
|
||||||
|
|
||||||
|
./buildconf
|
||||||
|
./configure
|
||||||
|
make
|
||||||
|
|
||||||
|
REQUIREMENTS
|
||||||
|
|
||||||
|
You need the following software installed:
|
||||||
|
|
||||||
|
o autoconf 2.50 (or later)
|
||||||
|
o automake 1.5 (or later)
|
||||||
|
o libtool 1.4 (or later)
|
||||||
|
o GNU m4 (required by autoconf)
|
||||||
|
|
||||||
|
o nroff + perl (if you don't have nroff and perl and you for some reason
|
||||||
|
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
|
||||||
|
file. This will of course 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.)
|
||||||
|
|
||||||
|
MAC OS X
|
||||||
|
|
||||||
|
For Mac OS X users, Guido Neitzer write down the following step-by-step guide:
|
||||||
|
|
||||||
|
1. Install fink (http://fink.sourceforge.net)
|
||||||
|
2. Update fink to the newest version (with the installed fink)
|
||||||
|
3. Install the latest version of autoconf, automake and m4 with fink
|
||||||
|
4. Install version 1.4.1 of libtool - you find it in the "unstable" section
|
||||||
|
(read the manual to see how to get unstable versions)
|
||||||
|
5. Get cURL from the cvs
|
||||||
|
6. Build cURL with "./buildconf", "./configure", "make", "sudo make install"
|
||||||
85
FILES
85
FILES
@@ -1,85 +0,0 @@
|
|||||||
CHANGES
|
|
||||||
FILES
|
|
||||||
LEGAL
|
|
||||||
MPL-1.0.txt
|
|
||||||
README
|
|
||||||
docs/BUGS
|
|
||||||
docs/CONTRIBUTE
|
|
||||||
docs/FAQ
|
|
||||||
docs/FEATURES
|
|
||||||
docs/INSTALL
|
|
||||||
docs/INTERNALS
|
|
||||||
docs/MANUAL
|
|
||||||
docs/README.win32
|
|
||||||
docs/README.libcurl
|
|
||||||
docs/RESOURCES
|
|
||||||
docs/TODO
|
|
||||||
docs/curl.1
|
|
||||||
docs/Makefile.in
|
|
||||||
docs/Makefile.am
|
|
||||||
docs/TheArtOfHttpScripting
|
|
||||||
docs/*.3
|
|
||||||
docs/examples/README
|
|
||||||
docs/examples/*.c
|
|
||||||
maketgz
|
|
||||||
Makefile.in
|
|
||||||
Makefile.am
|
|
||||||
acconfig.h
|
|
||||||
acinclude.m4
|
|
||||||
aclocal.m4
|
|
||||||
config.guess
|
|
||||||
config.h.in
|
|
||||||
config-win32.h
|
|
||||||
config.sub
|
|
||||||
configure
|
|
||||||
configure.in
|
|
||||||
install-sh
|
|
||||||
missing
|
|
||||||
mkinstalldirs
|
|
||||||
reconf
|
|
||||||
stamp-h.in
|
|
||||||
ltconfig
|
|
||||||
ltmain.sh
|
|
||||||
src/config-win32.h
|
|
||||||
src/hugehelp.c
|
|
||||||
src/main.c
|
|
||||||
src/setup.h
|
|
||||||
src/urlglob.c
|
|
||||||
src/urlglob.h
|
|
||||||
src/version.h
|
|
||||||
src/writeout.c
|
|
||||||
src/writeout.h
|
|
||||||
src/*.in
|
|
||||||
src/*.am
|
|
||||||
src/mkhelp.pl
|
|
||||||
src/Makefile.vc6
|
|
||||||
src/Makefile.b32
|
|
||||||
src/*m32
|
|
||||||
lib/getdate.y
|
|
||||||
lib/*.[ch]
|
|
||||||
lib/*in
|
|
||||||
lib/*am
|
|
||||||
lib/Makefile.vc6
|
|
||||||
lib/*m32
|
|
||||||
lib/Makefile.b32
|
|
||||||
lib/Makefile.b32.resp
|
|
||||||
lib/libcurl.def
|
|
||||||
include/README
|
|
||||||
include/Makefile.in
|
|
||||||
include/Makefile.am
|
|
||||||
include/curl/*.h
|
|
||||||
include/curl/Makefile.in
|
|
||||||
include/curl/Makefile.am
|
|
||||||
packages/Linux/RPM/curl-ssl.spec
|
|
||||||
packages/Linux/RPM/curl.spec
|
|
||||||
packages/Linux/RPM/make_curl_rpm
|
|
||||||
packages/Linux/RPM/README
|
|
||||||
packages/Win32/README
|
|
||||||
packages/README
|
|
||||||
tests/Makefile.am
|
|
||||||
tests/Makefile.in
|
|
||||||
tests/runtests.pl
|
|
||||||
tests/README
|
|
||||||
tests/httpserver.pl
|
|
||||||
tests/ftpserver.pl
|
|
||||||
tests/data/*.txt
|
|
||||||
34
LEGAL
34
LEGAL
@@ -1,21 +1,25 @@
|
|||||||
Part of this software is distributed under the Mozilla Public License
|
Copyright (C) 1998-2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
version 1.0, which is part of this distribution (MPL-1.0.txt) and
|
|
||||||
available on-line at http://www.mozilla.org/MPL/
|
|
||||||
|
|
||||||
The terminology used here is described in the Mozilla Public License.
|
Everyone is permitted to copy and distribute verbatim copies of this license
|
||||||
|
document, but changing it is not allowed.
|
||||||
|
|
||||||
In accordance with section "4. Inability to Comply Due to Statute or
|
In order to be useful for every potential user, the curl and libcurl are
|
||||||
Regulation" the following exemptions apply to this software:
|
dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
|
||||||
* The Initial Developer has the right, regardless of the citizenship
|
You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
of any involved party, to choose the location for settling disputes
|
copies of the Software, and permit persons to whom the Software is furnished
|
||||||
as refered to under section "11. Miscellaneous" of the Mozilla Public
|
to do so, under the terms of the MPL or the MIT/X-derivate licenses. You may
|
||||||
License.
|
pick one of these licenses. The files MITX.txt and MPL-1.1.txt contain the
|
||||||
|
license texts.
|
||||||
|
|
||||||
Initial Developers of this software are:
|
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
|
||||||
Daniel Stenberg <daniel@haxx.se>
|
document.
|
||||||
|
|
||||||
Curl is Copyright (C) 1996-2000 Daniel Stenberg
|
|
||||||
|
|
||||||
|
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
Normal file
27
MITX.txt
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
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.
|
||||||
|
|
||||||
360
MPL-1.0.txt
360
MPL-1.0.txt
@@ -1,360 +0,0 @@
|
|||||||
MOZILLA PUBLIC LICENSE
|
|
||||||
Version 1.0
|
|
||||||
|
|
||||||
----------------
|
|
||||||
|
|
||||||
1. Definitions.
|
|
||||||
|
|
||||||
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.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.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 a list of 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'' 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 fifty percent (50%) or more 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) to use, reproduce, modify, display, perform, sublicense and
|
|
||||||
distribute the Original Code (or portions thereof) with or without
|
|
||||||
Modifications, or as part of a Larger Work; and
|
|
||||||
|
|
||||||
(b) under patents now or hereafter owned or controlled by Initial
|
|
||||||
Developer, to make, have made, use and sell (``Utilize'') the
|
|
||||||
Original Code (or portions thereof), but solely to the extent that
|
|
||||||
any such patent is reasonably necessary to enable You to Utilize
|
|
||||||
the Original Code (or portions thereof) and not to any greater
|
|
||||||
extent that may be necessary to Utilize further Modifications or
|
|
||||||
combinations.
|
|
||||||
|
|
||||||
2.2. Contributor Grant.
|
|
||||||
Each Contributor hereby grants You a world-wide, royalty-free,
|
|
||||||
non-exclusive license, subject to third party intellectual property
|
|
||||||
claims:
|
|
||||||
|
|
||||||
(a) 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 or as part of a Larger Work; and
|
|
||||||
|
|
||||||
(b) under patents now or hereafter owned or controlled by
|
|
||||||
Contributor, to Utilize the Contributor Version (or portions
|
|
||||||
thereof), but solely to the extent that any such patent is
|
|
||||||
reasonably necessary to enable You to Utilize the Contributor
|
|
||||||
Version (or portions thereof), and not to any greater extent that
|
|
||||||
may be necessary to Utilize further Modifications or combinations.
|
|
||||||
|
|
||||||
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 You have knowledge that a party claims an intellectual property
|
|
||||||
right in particular functionality or code (or its utilization
|
|
||||||
under this License), you 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 you obtain such knowledge after You
|
|
||||||
make Your Modification available as described in Section 3.2, You
|
|
||||||
shall promptly modify the LEGAL file in all copies You make
|
|
||||||
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 Your Modification is an application programming interface and
|
|
||||||
You own or control patents which are reasonably necessary to
|
|
||||||
implement that API, you must also include this information in the
|
|
||||||
LEGAL file.
|
|
||||||
|
|
||||||
3.5. Required Notices.
|
|
||||||
You must duplicate the notice in Exhibit A in each file of the Source
|
|
||||||
Code, and this License in any documentation for the Source Code, where
|
|
||||||
You describe recipients' rights relating to Covered Code. If You
|
|
||||||
created one or more Modification(s), You may add your name as a
|
|
||||||
Contributor to the notice described in Exhibit A. 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 file) where a user would be likely to look for such
|
|
||||||
a notice. 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 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
|
|
||||||
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'', ``NPL'' or
|
|
||||||
any confusingly similar phrase do not appear anywhere in your 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.
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
||||||
9. LIMITATION OF LIABILITY.
|
|
||||||
|
|
||||||
UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT
|
|
||||||
(INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL THE INITIAL
|
|
||||||
DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED CODE,
|
|
||||||
OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO YOU OR ANY OTHER
|
|
||||||
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 THAT
|
|
||||||
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: (a) unless otherwise agreed in writing, all disputes relating
|
|
||||||
to this License (excepting any dispute relating to intellectual
|
|
||||||
property rights) shall be subject to final and binding arbitration,
|
|
||||||
with the losing party paying all costs of arbitration; (b) any
|
|
||||||
arbitration relating to this Agreement shall be held in Santa Clara
|
|
||||||
County, California, under the auspices of JAMS/EndDispute; and (c) any
|
|
||||||
litigation relating to this Agreement 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.
|
|
||||||
|
|
||||||
Except in cases where another Contributor has failed to comply with
|
|
||||||
Section 3.4, You are responsible for damages arising, directly or
|
|
||||||
indirectly, out of Your utilization of rights under this License, based
|
|
||||||
on the number of copies of Covered Code you made available, the
|
|
||||||
revenues you received from utilizing such rights, and other relevant
|
|
||||||
factors. You agree to work with affected parties to distribute
|
|
||||||
responsibility on an equitable basis.
|
|
||||||
|
|
||||||
EXHIBIT A.
|
|
||||||
|
|
||||||
``The contents of this file are subject to the Mozilla Public License
|
|
||||||
Version 1.0 (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): ______________________________________.''
|
|
||||||
470
MPL-1.1.txt
Normal file
470
MPL-1.1.txt
Normal file
@@ -0,0 +1,470 @@
|
|||||||
|
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.]
|
||||||
|
|
||||||
68
Makefile.am
68
Makefile.am
@@ -4,9 +4,71 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
EXTRA_DIST = curl.spec curl-ssl.spec
|
EXTRA_DIST = \
|
||||||
|
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
||||||
|
reconf Makefile.dist curl-config.in build_vms.com curl-mode.el \
|
||||||
|
config-vms.h config-win32.h config-riscos.h config-mac.h
|
||||||
|
|
||||||
SUBDIRS = docs lib src include tests
|
bin_SCRIPTS = curl-config
|
||||||
|
|
||||||
|
SUBDIRS = docs lib src include tests packages multi
|
||||||
|
|
||||||
|
# create a root makefile in the distribution:
|
||||||
|
dist-hook:
|
||||||
|
cp $(srcdir)/Makefile.dist $(distdir)/Makefile
|
||||||
|
|
||||||
|
html:
|
||||||
|
cd docs; make html
|
||||||
|
|
||||||
|
check: test
|
||||||
|
|
||||||
test:
|
test:
|
||||||
@(cd tests; make quiet-test)
|
@(cd tests; $(MAKE) quiet-test)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros
|
||||||
|
# must contain the following line:
|
||||||
|
# %_topdir /home/loic/local/rpm
|
||||||
|
# and that /home/loic/local/rpm contains the directory SOURCES, BUILD etc.
|
||||||
|
#
|
||||||
|
# cd /home/loic/local/rpm ; mkdir -p SOURCES BUILD RPMS/i386 SPECS SRPMS
|
||||||
|
#
|
||||||
|
# If additional configure flags are needed to build the package, add the
|
||||||
|
# following in ~/.rpmmacros
|
||||||
|
# %configure CFLAGS="%{optflags}" ./configure %{_target_platform} --prefix=%{_prefix} ${AM_CONFIGFLAGS}
|
||||||
|
# and run make rpm in the following way:
|
||||||
|
# AM_CONFIGFLAGS='--with-uri=/home/users/loic/local/RedHat-6.2' make rpm
|
||||||
|
#
|
||||||
|
|
||||||
|
rpms:
|
||||||
|
$(MAKE) RPMDIST=curl rpm
|
||||||
|
$(MAKE) RPMDIST=curl-ssl rpm
|
||||||
|
|
||||||
|
rpm:
|
||||||
|
RPM_TOPDIR=`rpm --showrc | $(PERL) -n -e 'print if(s/.*_topdir\s+(.*)/$$1/)'` ; \
|
||||||
|
cp $(srcdir)/packages/Linux/RPM/$(RPMDIST).spec $$RPM_TOPDIR/SPECS ; \
|
||||||
|
cp $(PACKAGE)-$(VERSION).tar.gz $$RPM_TOPDIR/SOURCES ; \
|
||||||
|
rpm -ba --clean --rmsource $$RPM_TOPDIR/SPECS/$(RPMDIST).spec ; \
|
||||||
|
mv $$RPM_TOPDIR/RPMS/i386/$(RPMDIST)-*.rpm . ; \
|
||||||
|
mv $$RPM_TOPDIR/SRPMS/$(RPMDIST)-*.src.rpm .
|
||||||
|
|
||||||
|
#
|
||||||
|
# Build a Solaris pkkgadd format file
|
||||||
|
# run 'make pkgadd' once you've done './configure' and 'make' to make a Solaris pkgadd format
|
||||||
|
# file (which ends up back in this directory).
|
||||||
|
# The pkgadd file is in 'pkgtrans' format, so to install on Solaris, do
|
||||||
|
# pkgadd -d ./HAXXcurl-*
|
||||||
|
#
|
||||||
|
|
||||||
|
# gak - libtool requires an absoulte directory, hence the pwd below...
|
||||||
|
pkgadd:
|
||||||
|
umask 022 ; \
|
||||||
|
make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \
|
||||||
|
cat LEGAL MITX.txt MPL-1.1.txt > $(srcdir)/packages/Solaris/copyright ; \
|
||||||
|
cd $(srcdir)/packages/Solaris && $(MAKE) package
|
||||||
|
|
||||||
|
#
|
||||||
|
# Build a cygwin binary tarball installation file
|
||||||
|
# resulting .tar.bz2 file will end up at packages/Win32/cygwin
|
||||||
|
cygwinbin:
|
||||||
|
$(MAKE) -C packages/Win32/cygwin cygwinbin
|
||||||
|
|||||||
@@ -1,45 +1,25 @@
|
|||||||
############################################################################
|
#############################################################################
|
||||||
# _ _ ____ _
|
# _ _ ____ _
|
||||||
# Project ___| | | | _ \| |
|
# Project ___| | | | _ \| |
|
||||||
# / __| | | | |_) | |
|
# / __| | | | |_) | |
|
||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# The contents of this file are subject to the Mozilla Public License
|
# Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
# Version 1.0 (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"
|
# In order to be useful for every potential user, curl and libcurl are
|
||||||
# basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
# dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
# License for the specific language governing rights and limitations
|
|
||||||
# under the License.
|
|
||||||
#
|
#
|
||||||
# The Original Code is Curl.
|
# 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 Initial Developer of the Original Code is Daniel Stenberg.
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
# KIND, either express or implied.
|
||||||
#
|
#
|
||||||
# Portions created by the Initial Developer are Copyright (C) 1999.
|
# $Id$
|
||||||
# All Rights Reserved.
|
#############################################################################
|
||||||
#
|
|
||||||
# ------------------------------------------------------------
|
|
||||||
# Main author:
|
|
||||||
# - Daniel Stenberg <daniel@haxx.se>
|
|
||||||
#
|
|
||||||
# http://curl.haxx.se
|
|
||||||
#
|
|
||||||
# $Source$
|
|
||||||
# $Revision$
|
|
||||||
# $Date$
|
|
||||||
# $Author$
|
|
||||||
# $State$
|
|
||||||
# $Locker$
|
|
||||||
#
|
|
||||||
# ------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# In a normal unix-setup, this file will become overwritten.
|
|
||||||
#
|
|
||||||
############################################################################
|
|
||||||
|
|
||||||
all:
|
all:
|
||||||
./configure
|
./configure
|
||||||
@@ -50,26 +30,26 @@ ssl:
|
|||||||
make
|
make
|
||||||
|
|
||||||
borland:
|
borland:
|
||||||
cd lib; make -f Makefile.b32
|
cd lib & make -f Makefile.b32
|
||||||
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
|
||||||
cd src; make -f Makefile.m32
|
cd src & make -f Makefile.m32
|
||||||
|
|
||||||
mingw32-ssl:
|
mingw32-ssl:
|
||||||
cd lib; make -f Makefile.m32 SSL=1
|
cd lib & make -f Makefile.m32 SSL=1
|
||||||
cd src; make -f Makefile.m32 SSL=1
|
cd src & make -f Makefile.m32 SSL=1
|
||||||
|
|
||||||
vc:
|
vc:
|
||||||
cd lib
|
cd lib
|
||||||
nmake -f Makefile.vc6
|
nmake -f Makefile.vc6 cfg=release
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake -f Makefile.vc6
|
nmake -f Makefile.vc6
|
||||||
|
|
||||||
vc-ssl:
|
vc-ssl:
|
||||||
cd lib
|
cd lib
|
||||||
nmake -f Makefile.vc6 release-ssl
|
nmake -f Makefile.vc6 cfg=release-ssl
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake -f Makefile.vc6
|
nmake -f Makefile.vc6
|
||||||
|
|
||||||
|
|||||||
19
README
19
README
@@ -12,11 +12,13 @@ README
|
|||||||
document.
|
document.
|
||||||
|
|
||||||
libcurl is a library that Curl is using to do its job. It is readily
|
libcurl is a library that Curl is using to do its job. It is readily
|
||||||
available to be used by your software. Read the README.libcurl document to
|
available to be used by your software. Read the libcurl.3 man page to
|
||||||
find out how!
|
find out 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.
|
||||||
|
|
||||||
Always try the Curl web site for the latest news:
|
Always try the Curl web site for the latest news:
|
||||||
|
|
||||||
http://curl.haxx.se
|
http://curl.haxx.se
|
||||||
@@ -24,23 +26,22 @@ README
|
|||||||
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/
|
||||||
Germany -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/
|
Germany -- ftp://ftp.fu-berlin.de/pub/unix/network/curl/
|
||||||
|
|
||||||
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:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl login
|
||||||
|
|
||||||
(just press enter when asked for password)
|
(just press enter when asked for password)
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl co .
|
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl co curl
|
||||||
|
|
||||||
(now, you'll get all the latest sources downloaded into your current
|
(you'll get a directory named curl created, filled with the source code)
|
||||||
directory. Note that this does NOT create a directory named curl or
|
|
||||||
anything)
|
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl logout
|
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl logout
|
||||||
|
|
||||||
(you're off the hook!)
|
(you're off the hook!)
|
||||||
|
|
||||||
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
|
||||||
|
|||||||
28
acconfig.h
28
acconfig.h
@@ -36,3 +36,31 @@
|
|||||||
|
|
||||||
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
||||||
#undef KRB4
|
#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
|
||||||
|
|||||||
506
acinclude.m4
506
acinclude.m4
@@ -1,75 +1,445 @@
|
|||||||
#serial 12
|
dnl Check for how to set a socket to non-blocking state. There seems to exist
|
||||||
|
dnl four known different ways, with the one used almost everywhere being POSIX
|
||||||
|
dnl and XPG3, while the other different ways for different systems (old BSD,
|
||||||
|
dnl Windows and Amiga).
|
||||||
|
dnl
|
||||||
|
dnl There are two known platforms (AIX 3.x and SunOS 4.1.x) where the
|
||||||
|
dnl O_NONBLOCK define is found but does not work. This condition is attempted
|
||||||
|
dnl to get caught in this script by using an excessive number of #ifdefs...
|
||||||
|
dnl
|
||||||
|
AC_DEFUN(CURL_CHECK_NONBLOCKING_SOCKET,
|
||||||
|
[
|
||||||
|
AC_MSG_CHECKING([non-blocking sockets style])
|
||||||
|
|
||||||
dnl By default, many hosts won't let programs access large files;
|
AC_TRY_COMPILE([
|
||||||
dnl one must use special compiler options to get large-file access to work.
|
/* headers for O_NONBLOCK test */
|
||||||
dnl For more details about this brain damage please see:
|
#include <sys/types.h>
|
||||||
dnl http://www.sas.com/standards/large.file/x_open.20Mar96.html
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
],[
|
||||||
|
/* try to compile O_NONBLOCK */
|
||||||
|
|
||||||
dnl Written by Paul Eggert <eggert@twinsun.com>.
|
#if defined(sun) || defined(__sun__) || defined(__SUNPRO_C) || defined(__SUNPRO_CC)
|
||||||
|
# if defined(__SVR4) || defined(__srv4__)
|
||||||
|
# define PLATFORM_SOLARIS
|
||||||
|
# else
|
||||||
|
# define PLATFORM_SUNOS4
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#if (defined(_AIX) || defined(__xlC__)) && !defined(_AIX4)
|
||||||
|
# define PLATFORM_AIX_V3
|
||||||
|
#endif
|
||||||
|
|
||||||
dnl Internal subroutine of AC_SYS_LARGEFILE.
|
#if defined(PLATFORM_SUNOS4) || defined(PLATFORM_AIX_V3)
|
||||||
dnl AC_SYS_LARGEFILE_TEST_INCLUDES
|
#error "O_NONBLOCK does not work on this platform"
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE_TEST_INCLUDES,
|
#endif
|
||||||
[[#include <sys/types.h>
|
int socket;
|
||||||
int a[(off_t) 9223372036854775807 == 9223372036854775807 ? 1 : -1];
|
int flags = fcntl(socket, F_SETFL, flags | O_NONBLOCK);
|
||||||
]])
|
],[
|
||||||
|
dnl the O_NONBLOCK test was fine
|
||||||
|
nonblock="O_NONBLOCK"
|
||||||
|
AC_DEFINE(HAVE_O_NONBLOCK)
|
||||||
|
],[
|
||||||
|
dnl the code was bad, try a different program now, test 2
|
||||||
|
|
||||||
dnl Internal subroutine of AC_SYS_LARGEFILE.
|
AC_TRY_COMPILE([
|
||||||
dnl AC_SYS_LARGEFILE_MACRO_VALUE(C-MACRO, VALUE, CACHE-VAR, COMMENT, INCLUDES, FUNCTION-BODY)
|
/* headers for FIONBIO test */
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE_MACRO_VALUE,
|
#include <unistd.h>
|
||||||
[AC_CACHE_CHECK([for $1 value needed for large files], $3,
|
#include <stropts.h>
|
||||||
[$3=no
|
],[
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES
|
/* FIONBIO source test */
|
||||||
$5
|
int flags = ioctl(socket, FIONBIO, &flags);
|
||||||
,
|
],[
|
||||||
[$6],
|
dnl FIONBIO test was good
|
||||||
,
|
nonblock="FIONBIO"
|
||||||
[AC_TRY_COMPILE([#define $1 $2]
|
AC_DEFINE(HAVE_FIONBIO)
|
||||||
AC_SYS_LARGEFILE_TEST_INCLUDES
|
],[
|
||||||
$5
|
dnl FIONBIO test was also bad
|
||||||
,
|
dnl the code was bad, try a different program now, test 3
|
||||||
[$6],
|
|
||||||
[$3=$2])])])
|
|
||||||
if test "[$]$3" != no; then
|
|
||||||
AC_DEFINE_UNQUOTED([$1], [$]$3, [$4])
|
|
||||||
fi])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE,
|
AC_TRY_COMPILE([
|
||||||
[AC_ARG_ENABLE(largefile,
|
/* headers for ioctlsocket test (cygwin?) */
|
||||||
[ --disable-largefile omit support for large files])
|
#include <windows.h>
|
||||||
if test "$enable_largefile" != no; then
|
],[
|
||||||
|
/* ioctlsocket source code */
|
||||||
|
int flags = ioctlsocket(socket, FIONBIO, &flags);
|
||||||
|
],[
|
||||||
|
dnl ioctlsocket test was good
|
||||||
|
nonblock="ioctlsocket"
|
||||||
|
AC_DEFINE(HAVE_IOCTLSOCKET)
|
||||||
|
],[
|
||||||
|
dnl ioctlsocket didnt compile!
|
||||||
|
|
||||||
AC_CACHE_CHECK([for special C compiler options needed for large files],
|
AC_TRY_COMPILE([
|
||||||
ac_cv_sys_largefile_CC,
|
/* headers for IoctlSocket test (Amiga?) */
|
||||||
[ac_cv_sys_largefile_CC=no
|
#include <sys/ioctl.h>
|
||||||
if test "$GCC" != yes; then
|
],[
|
||||||
# IRIX 6.2 and later do not support large files by default,
|
/* IoctlSocket source code */
|
||||||
# so use the C compiler's -n32 option if that helps.
|
int flags = IoctlSocket(socket, FIONBIO, (long)1);
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES, , ,
|
],[
|
||||||
[ac_save_CC="$CC"
|
dnl ioctlsocket test was good
|
||||||
CC="$CC -n32"
|
nonblock="IoctlSocket"
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES, ,
|
AC_DEFINE(HAVE_IOCTLSOCKET_CASE)
|
||||||
ac_cv_sys_largefile_CC=' -n32')
|
],[
|
||||||
CC="$ac_save_CC"])
|
dnl ioctlsocket didnt compile!
|
||||||
fi])
|
nonblock="nada"
|
||||||
if test "$ac_cv_sys_largefile_CC" != no; then
|
AC_DEFINE(HAVE_DISABLED_NONBLOCKING)
|
||||||
CC="$CC$ac_cv_sys_largefile_CC"
|
])
|
||||||
fi
|
dnl end of forth test
|
||||||
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_FILE_OFFSET_BITS, 64,
|
])
|
||||||
ac_cv_sys_file_offset_bits,
|
dnl end of third test
|
||||||
[Number of bits in a file offset, on hosts where this is settable.])
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_LARGEFILE_SOURCE, 1,
|
])
|
||||||
ac_cv_sys_largefile_source,
|
dnl end of second test
|
||||||
[Define to make ftello visible on some hosts (e.g. HP-UX 10.20).],
|
|
||||||
[#include <stdio.h>], [return !ftello;])
|
])
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_LARGE_FILES, 1,
|
dnl end of non-blocking try-compile test
|
||||||
ac_cv_sys_large_files,
|
AC_MSG_RESULT($nonblock)
|
||||||
[Define for large files, on AIX-style hosts.])
|
|
||||||
dnl lftp does not need ftello, and _XOPEN_SOURCE=500 makes resolv.h fail.
|
if test "$nonblock" = "nada"; then
|
||||||
dnl AC_SYS_LARGEFILE_MACRO_VALUE(_XOPEN_SOURCE, 500,
|
AC_MSG_WARN([non-block sockets disabled])
|
||||||
dnl ac_cv_sys_xopen_source,
|
fi
|
||||||
dnl [Define to make ftello visible on some hosts (e.g. glibc 2.1.3).],
|
])
|
||||||
dnl [#include <stdio.h>], [return !ftello;])
|
|
||||||
fi
|
dnl Check for socklen_t: historically on BSD it is an int, and in
|
||||||
])
|
dnl POSIX 1g it is a type of its own, but some platforms use different
|
||||||
|
dnl types for the argument to getsockopt, getpeername, etc. So we
|
||||||
|
dnl have to test to find something that will work.
|
||||||
|
AC_DEFUN([TYPE_SOCKLEN_T],
|
||||||
|
[
|
||||||
|
AC_CHECK_TYPE([socklen_t], ,[
|
||||||
|
AC_MSG_CHECKING([for socklen_t equivalent])
|
||||||
|
AC_CACHE_VAL([curl_cv_socklen_t_equiv],
|
||||||
|
[
|
||||||
|
# Systems have either "struct sockaddr *" or
|
||||||
|
# "void *" as the second argument to getpeername
|
||||||
|
curl_cv_socklen_t_equiv=
|
||||||
|
for arg2 in "struct sockaddr" void; do
|
||||||
|
for t in int size_t unsigned long "unsigned long"; do
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
|
||||||
|
int getpeername (int, $arg2 *, $t *);
|
||||||
|
],[
|
||||||
|
$t len;
|
||||||
|
getpeername(0,0,&len);
|
||||||
|
],[
|
||||||
|
curl_cv_socklen_t_equiv="$t"
|
||||||
|
break
|
||||||
|
])
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
if test "x$curl_cv_socklen_t_equiv" = x; then
|
||||||
|
AC_MSG_ERROR([Cannot find a type to use in place of socklen_t])
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
AC_MSG_RESULT($curl_cv_socklen_t_equiv)
|
||||||
|
AC_DEFINE_UNQUOTED(socklen_t, $curl_cv_socklen_t_equiv,
|
||||||
|
[type to use in place of socklen_t if not defined])],
|
||||||
|
[#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl Check for in_addr_t: it is used to receive the return code of inet_addr()
|
||||||
|
dnl and a few other things. If not found, we set it to unsigned int, as even
|
||||||
|
dnl 64-bit implementations use to set it to a 32-bit type.
|
||||||
|
AC_DEFUN([TYPE_IN_ADDR_T],
|
||||||
|
[
|
||||||
|
AC_CHECK_TYPE([in_addr_t], ,[
|
||||||
|
AC_MSG_CHECKING([for in_addr_t equivalent])
|
||||||
|
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=
|
||||||
|
for t in int size_t unsigned long "unsigned long"; do
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
],[
|
||||||
|
$t data = inet_addr ("1.2.3.4");
|
||||||
|
],[
|
||||||
|
curl_cv_in_addr_t_equiv="$t"
|
||||||
|
break
|
||||||
|
])
|
||||||
|
done
|
||||||
|
|
||||||
|
if test "x$curl_cv_in_addr_t_equiv" = x; then
|
||||||
|
AC_MSG_ERROR([Cannot find a type to use in place of in_addr_t])
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
AC_MSG_RESULT($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])],
|
||||||
|
[#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <arpa/inet.h>])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl ************************************************************
|
||||||
|
dnl check for "localhost", if it doesn't exist, we can't do the
|
||||||
|
dnl gethostbyname_r tests!
|
||||||
|
dnl
|
||||||
|
|
||||||
|
AC_DEFUN(CURL_CHECK_WORKING_RESOLVER,[
|
||||||
|
AC_MSG_CHECKING([if "localhost" resolves])
|
||||||
|
AC_TRY_RUN([
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main () {
|
||||||
|
struct hostent *h;
|
||||||
|
h = gethostbyname("localhost");
|
||||||
|
exit (h == NULL ? 1 : 0); }],[
|
||||||
|
AC_MSG_RESULT(yes)],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_ERROR([can't figure out gethostbyname_r() since localhost doesn't resolve])
|
||||||
|
|
||||||
|
]
|
||||||
|
)
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl ************************************************************
|
||||||
|
dnl check for working getaddrinfo()
|
||||||
|
dnl
|
||||||
|
AC_DEFUN(CURL_CHECK_WORKING_GETADDRINFO,[
|
||||||
|
AC_CACHE_CHECK(for working getaddrinfo, ac_cv_working_getaddrinfo,[
|
||||||
|
AC_TRY_RUN( [
|
||||||
|
#include <netdb.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
|
||||||
|
void main(void) {
|
||||||
|
struct addrinfo hints, *ai;
|
||||||
|
int error;
|
||||||
|
|
||||||
|
memset(&hints, 0, sizeof(hints));
|
||||||
|
hints.ai_family = AF_UNSPEC;
|
||||||
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
|
error = getaddrinfo("127.0.0.1", "8080", &hints, &ai);
|
||||||
|
if (error) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],[
|
||||||
|
ac_cv_working_getaddrinfo="yes"
|
||||||
|
],[
|
||||||
|
ac_cv_working_getaddrinfo="no"
|
||||||
|
],[
|
||||||
|
ac_cv_working_getaddrinfo="yes"
|
||||||
|
])])
|
||||||
|
if test "$ac_cv_working_getaddrinfo" = "yes"; then
|
||||||
|
AC_DEFINE(HAVE_GETADDRINFO, 1, [Define if getaddrinfo exists and works])
|
||||||
|
AC_DEFINE(ENABLE_IPV6, 1, [Define if you want to enable IPv6 support])
|
||||||
|
|
||||||
|
IPV6_ENABLED=1
|
||||||
|
AC_SUBST(IPV6_ENABLED)
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
AC_DEFUN(CURL_CHECK_LOCALTIME_R,
|
||||||
|
[
|
||||||
|
dnl check for a few thread-safe functions
|
||||||
|
AC_CHECK_FUNCS(localtime_r,[
|
||||||
|
AC_MSG_CHECKING(whether localtime_r is declared)
|
||||||
|
AC_EGREP_CPP(localtime_r,[
|
||||||
|
#include <time.h>],[
|
||||||
|
AC_MSG_RESULT(yes)],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING(whether localtime_r with -D_REENTRANT is declared)
|
||||||
|
AC_EGREP_CPP(localtime_r,[
|
||||||
|
#define _REENTRANT
|
||||||
|
#include <time.h>],[
|
||||||
|
AC_DEFINE(NEED_REENTRANT)
|
||||||
|
AC_MSG_RESULT(yes)],
|
||||||
|
AC_MSG_RESULT(no))])])
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN(CURL_CHECK_INET_NTOA_R,
|
||||||
|
[
|
||||||
|
dnl determine if function definition for inet_ntoa_r exists.
|
||||||
|
AC_CHECK_FUNCS(inet_ntoa_r,[
|
||||||
|
AC_MSG_CHECKING(whether inet_ntoa_r is declared)
|
||||||
|
AC_EGREP_CPP(inet_ntoa_r,[
|
||||||
|
#include <arpa/inet.h>],[
|
||||||
|
AC_DEFINE(HAVE_INET_NTOA_R_DECL)
|
||||||
|
AC_MSG_RESULT(yes)],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared)
|
||||||
|
AC_EGREP_CPP(inet_ntoa_r,[
|
||||||
|
#define _REENTRANT
|
||||||
|
#include <arpa/inet.h>],[
|
||||||
|
AC_DEFINE(HAVE_INET_NTOA_R_DECL)
|
||||||
|
AC_DEFINE(NEED_REENTRANT)
|
||||||
|
AC_MSG_RESULT(yes)],
|
||||||
|
AC_MSG_RESULT(no))])])
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN(CURL_CHECK_GETHOSTBYADDR_R,
|
||||||
|
[
|
||||||
|
dnl check for number of arguments to gethostbyaddr_r. it might take
|
||||||
|
dnl either 5, 7, or 8 arguments.
|
||||||
|
AC_CHECK_FUNCS(gethostbyaddr_r,[
|
||||||
|
AC_MSG_CHECKING(if gethostbyaddr_r takes 5 arguments)
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>],[
|
||||||
|
char * address;
|
||||||
|
int length;
|
||||||
|
int type;
|
||||||
|
struct hostent h;
|
||||||
|
struct hostent_data hdata;
|
||||||
|
int rc;
|
||||||
|
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5)
|
||||||
|
ac_cv_gethostbyaddr_args=5],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments)
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#define _REENTRANT
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>],[
|
||||||
|
char * address;
|
||||||
|
int length;
|
||||||
|
int type;
|
||||||
|
struct hostent h;
|
||||||
|
struct hostent_data hdata;
|
||||||
|
int rc;
|
||||||
|
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5)
|
||||||
|
AC_DEFINE(NEED_REENTRANT)
|
||||||
|
ac_cv_gethostbyaddr_args=5],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments)
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>],[
|
||||||
|
char * address;
|
||||||
|
int length;
|
||||||
|
int type;
|
||||||
|
struct hostent h;
|
||||||
|
char buffer[8192];
|
||||||
|
int h_errnop;
|
||||||
|
struct hostent * hp;
|
||||||
|
|
||||||
|
hp = gethostbyaddr_r(address, length, type, &h,
|
||||||
|
buffer, 8192, &h_errnop);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_7)
|
||||||
|
ac_cv_gethostbyaddr_args=7],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments)
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>],[
|
||||||
|
char * address;
|
||||||
|
int length;
|
||||||
|
int type;
|
||||||
|
struct hostent h;
|
||||||
|
char buffer[8192];
|
||||||
|
int h_errnop;
|
||||||
|
struct hostent * hp;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
rc = gethostbyaddr_r(address, length, type, &h,
|
||||||
|
buffer, 8192, &hp, &h_errnop);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYADDR_R_8)
|
||||||
|
ac_cv_gethostbyaddr_args=8],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])])
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN(CURL_CHECK_GETHOSTBYNAME_R,
|
||||||
|
[
|
||||||
|
dnl check for number of arguments to gethostbyname_r. it might take
|
||||||
|
dnl either 3, 5, or 6 arguments.
|
||||||
|
AC_CHECK_FUNCS(gethostbyname_r,[
|
||||||
|
AC_MSG_CHECKING([if gethostbyname_r takes 3 arguments])
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#undef NULL
|
||||||
|
#define NULL (void *)0
|
||||||
|
|
||||||
|
int
|
||||||
|
gethostbyname_r(const char *, struct hostent *, struct hostent_data *);],[
|
||||||
|
gethostbyname_r(NULL, NULL, NULL);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3)
|
||||||
|
ac_cv_gethostbyname_args=3],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING([if gethostbyname_r with -D_REENTRANT takes 3 arguments])
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#define _REENTRANT
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#undef NULL
|
||||||
|
#define NULL (void *)0
|
||||||
|
|
||||||
|
int
|
||||||
|
gethostbyname_r(const char *,struct hostent *, struct hostent_data *);],[
|
||||||
|
gethostbyname_r(NULL, NULL, NULL);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3)
|
||||||
|
AC_DEFINE(NEED_REENTRANT)
|
||||||
|
ac_cv_gethostbyname_args=3],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING([if gethostbyname_r takes 5 arguments])
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#undef NULL
|
||||||
|
#define NULL (void *)0
|
||||||
|
|
||||||
|
struct hostent *
|
||||||
|
gethostbyname_r(const char *, struct hostent *, char *, int, int *);],[
|
||||||
|
gethostbyname_r(NULL, NULL, NULL, 0, NULL);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_5)
|
||||||
|
ac_cv_gethostbyname_args=5],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_CHECKING([if gethostbyname_r takes 6 arguments])
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#undef NULL
|
||||||
|
#define NULL (void *)0
|
||||||
|
|
||||||
|
int
|
||||||
|
gethostbyname_r(const char *, struct hostent *, char *, size_t,
|
||||||
|
struct hostent **, int *);],[
|
||||||
|
gethostbyname_r(NULL, NULL, NULL, 0, NULL, NULL);],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_GETHOSTBYNAME_R_6)
|
||||||
|
ac_cv_gethostbyname_args=6],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"],
|
||||||
|
[ac_cv_gethostbyname_args=0])],
|
||||||
|
[ac_cv_gethostbyname_args=0])],
|
||||||
|
[ac_cv_gethostbyname_args=0])],
|
||||||
|
[ac_cv_gethostbyname_args=0])])
|
||||||
|
|
||||||
|
if test "$ac_cv_func_gethostbyname_r" = "yes"; then
|
||||||
|
if test "$ac_cv_gethostbyname_args" = "0"; then
|
||||||
|
dnl there's a gethostbyname_r() function, but we don't know how
|
||||||
|
dnl many arguments it wants!
|
||||||
|
AC_MSG_ERROR([couldn't figure out how to use gethostbyname_r()])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|||||||
616
aclocal.m4
vendored
616
aclocal.m4
vendored
@@ -1,616 +0,0 @@
|
|||||||
dnl aclocal.m4 generated automatically by aclocal 1.4
|
|
||||||
|
|
||||||
dnl Copyright (C) 1994, 1995-8, 1999 Free Software Foundation, Inc.
|
|
||||||
dnl This file is free software; the Free Software Foundation
|
|
||||||
dnl gives unlimited permission to copy and/or distribute it,
|
|
||||||
dnl with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
dnl This program is distributed in the hope that it will be useful,
|
|
||||||
dnl but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
dnl even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
dnl PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
#serial 12
|
|
||||||
|
|
||||||
dnl By default, many hosts won't let programs access large files;
|
|
||||||
dnl one must use special compiler options to get large-file access to work.
|
|
||||||
dnl For more details about this brain damage please see:
|
|
||||||
dnl http://www.sas.com/standards/large.file/x_open.20Mar96.html
|
|
||||||
|
|
||||||
dnl Written by Paul Eggert <eggert@twinsun.com>.
|
|
||||||
|
|
||||||
dnl Internal subroutine of AC_SYS_LARGEFILE.
|
|
||||||
dnl AC_SYS_LARGEFILE_TEST_INCLUDES
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE_TEST_INCLUDES,
|
|
||||||
[[#include <sys/types.h>
|
|
||||||
int a[(off_t) 9223372036854775807 == 9223372036854775807 ? 1 : -1];
|
|
||||||
]])
|
|
||||||
|
|
||||||
dnl Internal subroutine of AC_SYS_LARGEFILE.
|
|
||||||
dnl AC_SYS_LARGEFILE_MACRO_VALUE(C-MACRO, VALUE, CACHE-VAR, COMMENT, INCLUDES, FUNCTION-BODY)
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE_MACRO_VALUE,
|
|
||||||
[AC_CACHE_CHECK([for $1 value needed for large files], $3,
|
|
||||||
[$3=no
|
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES
|
|
||||||
$5
|
|
||||||
,
|
|
||||||
[$6],
|
|
||||||
,
|
|
||||||
[AC_TRY_COMPILE([#define $1 $2]
|
|
||||||
AC_SYS_LARGEFILE_TEST_INCLUDES
|
|
||||||
$5
|
|
||||||
,
|
|
||||||
[$6],
|
|
||||||
[$3=$2])])])
|
|
||||||
if test "[$]$3" != no; then
|
|
||||||
AC_DEFINE_UNQUOTED([$1], [$]$3, [$4])
|
|
||||||
fi])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE,
|
|
||||||
[AC_ARG_ENABLE(largefile,
|
|
||||||
[ --disable-largefile omit support for large files])
|
|
||||||
if test "$enable_largefile" != no; then
|
|
||||||
|
|
||||||
AC_CACHE_CHECK([for special C compiler options needed for large files],
|
|
||||||
ac_cv_sys_largefile_CC,
|
|
||||||
[ac_cv_sys_largefile_CC=no
|
|
||||||
if test "$GCC" != yes; then
|
|
||||||
# IRIX 6.2 and later do not support large files by default,
|
|
||||||
# so use the C compiler's -n32 option if that helps.
|
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES, , ,
|
|
||||||
[ac_save_CC="$CC"
|
|
||||||
CC="$CC -n32"
|
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES, ,
|
|
||||||
ac_cv_sys_largefile_CC=' -n32')
|
|
||||||
CC="$ac_save_CC"])
|
|
||||||
fi])
|
|
||||||
if test "$ac_cv_sys_largefile_CC" != no; then
|
|
||||||
CC="$CC$ac_cv_sys_largefile_CC"
|
|
||||||
fi
|
|
||||||
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_FILE_OFFSET_BITS, 64,
|
|
||||||
ac_cv_sys_file_offset_bits,
|
|
||||||
[Number of bits in a file offset, on hosts where this is settable.])
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_LARGEFILE_SOURCE, 1,
|
|
||||||
ac_cv_sys_largefile_source,
|
|
||||||
[Define to make ftello visible on some hosts (e.g. HP-UX 10.20).],
|
|
||||||
[#include <stdio.h>], [return !ftello;])
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_LARGE_FILES, 1,
|
|
||||||
ac_cv_sys_large_files,
|
|
||||||
[Define for large files, on AIX-style hosts.])
|
|
||||||
dnl lftp does not need ftello, and _XOPEN_SOURCE=500 makes resolv.h fail.
|
|
||||||
dnl AC_SYS_LARGEFILE_MACRO_VALUE(_XOPEN_SOURCE, 500,
|
|
||||||
dnl ac_cv_sys_xopen_source,
|
|
||||||
dnl [Define to make ftello visible on some hosts (e.g. glibc 2.1.3).],
|
|
||||||
dnl [#include <stdio.h>], [return !ftello;])
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
# Like AC_CONFIG_HEADER, but automatically create stamp file.
|
|
||||||
|
|
||||||
AC_DEFUN(AM_CONFIG_HEADER,
|
|
||||||
[AC_PREREQ([2.12])
|
|
||||||
AC_CONFIG_HEADER([$1])
|
|
||||||
dnl When config.status generates a header, we must update the stamp-h file.
|
|
||||||
dnl This file resides in the same directory as the config header
|
|
||||||
dnl that is generated. We must strip everything past the first ":",
|
|
||||||
dnl and everything past the last "/".
|
|
||||||
AC_OUTPUT_COMMANDS(changequote(<<,>>)dnl
|
|
||||||
ifelse(patsubst(<<$1>>, <<[^ ]>>, <<>>), <<>>,
|
|
||||||
<<test -z "<<$>>CONFIG_HEADERS" || echo timestamp > patsubst(<<$1>>, <<^\([^:]*/\)?.*>>, <<\1>>)stamp-h<<>>dnl>>,
|
|
||||||
<<am_indx=1
|
|
||||||
for am_file in <<$1>>; do
|
|
||||||
case " <<$>>CONFIG_HEADERS " in
|
|
||||||
*" <<$>>am_file "*<<)>>
|
|
||||||
echo timestamp > `echo <<$>>am_file | sed -e 's%:.*%%' -e 's%[^/]*$%%'`stamp-h$am_indx
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
am_indx=`expr "<<$>>am_indx" + 1`
|
|
||||||
done<<>>dnl>>)
|
|
||||||
changequote([,]))])
|
|
||||||
|
|
||||||
# Do all the work for Automake. This macro actually does too much --
|
|
||||||
# some checks are only needed if your package does certain things.
|
|
||||||
# But this isn't really a big deal.
|
|
||||||
|
|
||||||
# serial 1
|
|
||||||
|
|
||||||
dnl Usage:
|
|
||||||
dnl AM_INIT_AUTOMAKE(package,version, [no-define])
|
|
||||||
|
|
||||||
AC_DEFUN(AM_INIT_AUTOMAKE,
|
|
||||||
[AC_REQUIRE([AC_PROG_INSTALL])
|
|
||||||
PACKAGE=[$1]
|
|
||||||
AC_SUBST(PACKAGE)
|
|
||||||
VERSION=[$2]
|
|
||||||
AC_SUBST(VERSION)
|
|
||||||
dnl test to see if srcdir already configured
|
|
||||||
if test "`cd $srcdir && pwd`" != "`pwd`" && test -f $srcdir/config.status; then
|
|
||||||
AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
|
|
||||||
fi
|
|
||||||
ifelse([$3],,
|
|
||||||
AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
|
|
||||||
AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package]))
|
|
||||||
AC_REQUIRE([AM_SANITY_CHECK])
|
|
||||||
AC_REQUIRE([AC_ARG_PROGRAM])
|
|
||||||
dnl FIXME This is truly gross.
|
|
||||||
missing_dir=`cd $ac_aux_dir && pwd`
|
|
||||||
AM_MISSING_PROG(ACLOCAL, aclocal, $missing_dir)
|
|
||||||
AM_MISSING_PROG(AUTOCONF, autoconf, $missing_dir)
|
|
||||||
AM_MISSING_PROG(AUTOMAKE, automake, $missing_dir)
|
|
||||||
AM_MISSING_PROG(AUTOHEADER, autoheader, $missing_dir)
|
|
||||||
AM_MISSING_PROG(MAKEINFO, makeinfo, $missing_dir)
|
|
||||||
AC_REQUIRE([AC_PROG_MAKE_SET])])
|
|
||||||
|
|
||||||
#
|
|
||||||
# Check to make sure that the build environment is sane.
|
|
||||||
#
|
|
||||||
|
|
||||||
AC_DEFUN(AM_SANITY_CHECK,
|
|
||||||
[AC_MSG_CHECKING([whether build environment is sane])
|
|
||||||
# Just in case
|
|
||||||
sleep 1
|
|
||||||
echo timestamp > conftestfile
|
|
||||||
# Do `set' in a subshell so we don't clobber the current shell's
|
|
||||||
# arguments. Must try -L first in case configure is actually a
|
|
||||||
# symlink; some systems play weird games with the mod time of symlinks
|
|
||||||
# (eg FreeBSD returns the mod time of the symlink's containing
|
|
||||||
# directory).
|
|
||||||
if (
|
|
||||||
set X `ls -Lt $srcdir/configure conftestfile 2> /dev/null`
|
|
||||||
if test "[$]*" = "X"; then
|
|
||||||
# -L didn't work.
|
|
||||||
set X `ls -t $srcdir/configure conftestfile`
|
|
||||||
fi
|
|
||||||
if test "[$]*" != "X $srcdir/configure conftestfile" \
|
|
||||||
&& test "[$]*" != "X conftestfile $srcdir/configure"; then
|
|
||||||
|
|
||||||
# If neither matched, then we have a broken ls. This can happen
|
|
||||||
# if, for instance, CONFIG_SHELL is bash and it inherits a
|
|
||||||
# broken ls alias from the environment. This has actually
|
|
||||||
# happened. Such a system could not be considered "sane".
|
|
||||||
AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
|
|
||||||
alias in your environment])
|
|
||||||
fi
|
|
||||||
|
|
||||||
test "[$]2" = conftestfile
|
|
||||||
)
|
|
||||||
then
|
|
||||||
# Ok.
|
|
||||||
:
|
|
||||||
else
|
|
||||||
AC_MSG_ERROR([newly created file is older than distributed files!
|
|
||||||
Check your system clock])
|
|
||||||
fi
|
|
||||||
rm -f conftest*
|
|
||||||
AC_MSG_RESULT(yes)])
|
|
||||||
|
|
||||||
dnl AM_MISSING_PROG(NAME, PROGRAM, DIRECTORY)
|
|
||||||
dnl The program must properly implement --version.
|
|
||||||
AC_DEFUN(AM_MISSING_PROG,
|
|
||||||
[AC_MSG_CHECKING(for working $2)
|
|
||||||
# Run test in a subshell; some versions of sh will print an error if
|
|
||||||
# an executable is not found, even if stderr is redirected.
|
|
||||||
# Redirect stdin to placate older versions of autoconf. Sigh.
|
|
||||||
if ($2 --version) < /dev/null > /dev/null 2>&1; then
|
|
||||||
$1=$2
|
|
||||||
AC_MSG_RESULT(found)
|
|
||||||
else
|
|
||||||
$1="$3/missing $2"
|
|
||||||
AC_MSG_RESULT(missing)
|
|
||||||
fi
|
|
||||||
AC_SUBST($1)])
|
|
||||||
|
|
||||||
|
|
||||||
# serial 40 AC_PROG_LIBTOOL
|
|
||||||
AC_DEFUN(AC_PROG_LIBTOOL,
|
|
||||||
[AC_REQUIRE([AC_LIBTOOL_SETUP])dnl
|
|
||||||
|
|
||||||
# Save cache, so that ltconfig can load it
|
|
||||||
AC_CACHE_SAVE
|
|
||||||
|
|
||||||
# Actually configure libtool. ac_aux_dir is where install-sh is found.
|
|
||||||
CC="$CC" CFLAGS="$CFLAGS" CPPFLAGS="$CPPFLAGS" \
|
|
||||||
LD="$LD" LDFLAGS="$LDFLAGS" LIBS="$LIBS" \
|
|
||||||
LN_S="$LN_S" NM="$NM" RANLIB="$RANLIB" \
|
|
||||||
DLLTOOL="$DLLTOOL" AS="$AS" OBJDUMP="$OBJDUMP" \
|
|
||||||
${CONFIG_SHELL-/bin/sh} $ac_aux_dir/ltconfig --no-reexec \
|
|
||||||
$libtool_flags --no-verify $ac_aux_dir/ltmain.sh $lt_target \
|
|
||||||
|| AC_MSG_ERROR([libtool configure failed])
|
|
||||||
|
|
||||||
# Reload cache, that may have been modified by ltconfig
|
|
||||||
AC_CACHE_LOAD
|
|
||||||
|
|
||||||
# This can be used to rebuild libtool when needed
|
|
||||||
LIBTOOL_DEPS="$ac_aux_dir/ltconfig $ac_aux_dir/ltmain.sh"
|
|
||||||
|
|
||||||
# Always use our own libtool.
|
|
||||||
LIBTOOL='$(SHELL) $(top_builddir)/libtool'
|
|
||||||
AC_SUBST(LIBTOOL)dnl
|
|
||||||
|
|
||||||
# Redirect the config.log output again, so that the ltconfig log is not
|
|
||||||
# clobbered by the next message.
|
|
||||||
exec 5>>./config.log
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_LIBTOOL_SETUP,
|
|
||||||
[AC_PREREQ(2.13)dnl
|
|
||||||
AC_REQUIRE([AC_ENABLE_SHARED])dnl
|
|
||||||
AC_REQUIRE([AC_ENABLE_STATIC])dnl
|
|
||||||
AC_REQUIRE([AC_ENABLE_FAST_INSTALL])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_BUILD])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_RANLIB])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_CC])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_LD])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_NM])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_LN_S])dnl
|
|
||||||
dnl
|
|
||||||
|
|
||||||
case "$target" in
|
|
||||||
NONE) lt_target="$host" ;;
|
|
||||||
*) lt_target="$target" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Check for any special flags to pass to ltconfig.
|
|
||||||
libtool_flags="--cache-file=$cache_file"
|
|
||||||
test "$enable_shared" = no && libtool_flags="$libtool_flags --disable-shared"
|
|
||||||
test "$enable_static" = no && libtool_flags="$libtool_flags --disable-static"
|
|
||||||
test "$enable_fast_install" = no && libtool_flags="$libtool_flags --disable-fast-install"
|
|
||||||
test "$ac_cv_prog_gcc" = yes && libtool_flags="$libtool_flags --with-gcc"
|
|
||||||
test "$ac_cv_prog_gnu_ld" = yes && libtool_flags="$libtool_flags --with-gnu-ld"
|
|
||||||
ifdef([AC_PROVIDE_AC_LIBTOOL_DLOPEN],
|
|
||||||
[libtool_flags="$libtool_flags --enable-dlopen"])
|
|
||||||
ifdef([AC_PROVIDE_AC_LIBTOOL_WIN32_DLL],
|
|
||||||
[libtool_flags="$libtool_flags --enable-win32-dll"])
|
|
||||||
AC_ARG_ENABLE(libtool-lock,
|
|
||||||
[ --disable-libtool-lock avoid locking (might break parallel builds)])
|
|
||||||
test "x$enable_libtool_lock" = xno && libtool_flags="$libtool_flags --disable-lock"
|
|
||||||
test x"$silent" = xyes && libtool_flags="$libtool_flags --silent"
|
|
||||||
|
|
||||||
# Some flags need to be propagated to the compiler or linker for good
|
|
||||||
# libtool support.
|
|
||||||
case "$lt_target" in
|
|
||||||
*-*-irix6*)
|
|
||||||
# Find out which ABI we are using.
|
|
||||||
echo '[#]line __oline__ "configure"' > conftest.$ac_ext
|
|
||||||
if AC_TRY_EVAL(ac_compile); then
|
|
||||||
case "`/usr/bin/file conftest.o`" in
|
|
||||||
*32-bit*)
|
|
||||||
LD="${LD-ld} -32"
|
|
||||||
;;
|
|
||||||
*N32*)
|
|
||||||
LD="${LD-ld} -n32"
|
|
||||||
;;
|
|
||||||
*64-bit*)
|
|
||||||
LD="${LD-ld} -64"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
rm -rf conftest*
|
|
||||||
;;
|
|
||||||
|
|
||||||
*-*-sco3.2v5*)
|
|
||||||
# On SCO OpenServer 5, we need -belf to get full-featured binaries.
|
|
||||||
SAVE_CFLAGS="$CFLAGS"
|
|
||||||
CFLAGS="$CFLAGS -belf"
|
|
||||||
AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf,
|
|
||||||
[AC_TRY_LINK([],[],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no])])
|
|
||||||
if test x"$lt_cv_cc_needs_belf" != x"yes"; then
|
|
||||||
# this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
|
|
||||||
CFLAGS="$SAVE_CFLAGS"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
ifdef([AC_PROVIDE_AC_LIBTOOL_WIN32_DLL],
|
|
||||||
[*-*-cygwin* | *-*-mingw*)
|
|
||||||
AC_CHECK_TOOL(DLLTOOL, dlltool, false)
|
|
||||||
AC_CHECK_TOOL(AS, as, false)
|
|
||||||
AC_CHECK_TOOL(OBJDUMP, objdump, false)
|
|
||||||
;;
|
|
||||||
])
|
|
||||||
esac
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_LIBTOOL_DLOPEN - enable checks for dlopen support
|
|
||||||
AC_DEFUN(AC_LIBTOOL_DLOPEN, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])])
|
|
||||||
|
|
||||||
# AC_LIBTOOL_WIN32_DLL - declare package support for building win32 dll's
|
|
||||||
AC_DEFUN(AC_LIBTOOL_WIN32_DLL, [AC_BEFORE([$0], [AC_LIBTOOL_SETUP])])
|
|
||||||
|
|
||||||
# AC_ENABLE_SHARED - implement the --enable-shared flag
|
|
||||||
# Usage: AC_ENABLE_SHARED[(DEFAULT)]
|
|
||||||
# Where DEFAULT is either `yes' or `no'. If omitted, it defaults to
|
|
||||||
# `yes'.
|
|
||||||
AC_DEFUN(AC_ENABLE_SHARED, [dnl
|
|
||||||
define([AC_ENABLE_SHARED_DEFAULT], ifelse($1, no, no, yes))dnl
|
|
||||||
AC_ARG_ENABLE(shared,
|
|
||||||
changequote(<<, >>)dnl
|
|
||||||
<< --enable-shared[=PKGS] build shared libraries [default=>>AC_ENABLE_SHARED_DEFAULT],
|
|
||||||
changequote([, ])dnl
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case "$enableval" in
|
|
||||||
yes) enable_shared=yes ;;
|
|
||||||
no) enable_shared=no ;;
|
|
||||||
*)
|
|
||||||
enable_shared=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_shared=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
enable_shared=AC_ENABLE_SHARED_DEFAULT)dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_DISABLE_SHARED - set the default shared flag to --disable-shared
|
|
||||||
AC_DEFUN(AC_DISABLE_SHARED, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_ENABLE_SHARED(no)])
|
|
||||||
|
|
||||||
# AC_ENABLE_STATIC - implement the --enable-static flag
|
|
||||||
# Usage: AC_ENABLE_STATIC[(DEFAULT)]
|
|
||||||
# Where DEFAULT is either `yes' or `no'. If omitted, it defaults to
|
|
||||||
# `yes'.
|
|
||||||
AC_DEFUN(AC_ENABLE_STATIC, [dnl
|
|
||||||
define([AC_ENABLE_STATIC_DEFAULT], ifelse($1, no, no, yes))dnl
|
|
||||||
AC_ARG_ENABLE(static,
|
|
||||||
changequote(<<, >>)dnl
|
|
||||||
<< --enable-static[=PKGS] build static libraries [default=>>AC_ENABLE_STATIC_DEFAULT],
|
|
||||||
changequote([, ])dnl
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case "$enableval" in
|
|
||||||
yes) enable_static=yes ;;
|
|
||||||
no) enable_static=no ;;
|
|
||||||
*)
|
|
||||||
enable_static=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_static=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
enable_static=AC_ENABLE_STATIC_DEFAULT)dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_DISABLE_STATIC - set the default static flag to --disable-static
|
|
||||||
AC_DEFUN(AC_DISABLE_STATIC, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_ENABLE_STATIC(no)])
|
|
||||||
|
|
||||||
|
|
||||||
# AC_ENABLE_FAST_INSTALL - implement the --enable-fast-install flag
|
|
||||||
# Usage: AC_ENABLE_FAST_INSTALL[(DEFAULT)]
|
|
||||||
# Where DEFAULT is either `yes' or `no'. If omitted, it defaults to
|
|
||||||
# `yes'.
|
|
||||||
AC_DEFUN(AC_ENABLE_FAST_INSTALL, [dnl
|
|
||||||
define([AC_ENABLE_FAST_INSTALL_DEFAULT], ifelse($1, no, no, yes))dnl
|
|
||||||
AC_ARG_ENABLE(fast-install,
|
|
||||||
changequote(<<, >>)dnl
|
|
||||||
<< --enable-fast-install[=PKGS] optimize for fast installation [default=>>AC_ENABLE_FAST_INSTALL_DEFAULT],
|
|
||||||
changequote([, ])dnl
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case "$enableval" in
|
|
||||||
yes) enable_fast_install=yes ;;
|
|
||||||
no) enable_fast_install=no ;;
|
|
||||||
*)
|
|
||||||
enable_fast_install=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_fast_install=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
enable_fast_install=AC_ENABLE_FAST_INSTALL_DEFAULT)dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_ENABLE_FAST_INSTALL - set the default to --disable-fast-install
|
|
||||||
AC_DEFUN(AC_DISABLE_FAST_INSTALL, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_ENABLE_FAST_INSTALL(no)])
|
|
||||||
|
|
||||||
# AC_PROG_LD - find the path to the GNU or non-GNU linker
|
|
||||||
AC_DEFUN(AC_PROG_LD,
|
|
||||||
[AC_ARG_WITH(gnu-ld,
|
|
||||||
[ --with-gnu-ld assume the C compiler uses GNU ld [default=no]],
|
|
||||||
test "$withval" = no || with_gnu_ld=yes, with_gnu_ld=no)
|
|
||||||
AC_REQUIRE([AC_PROG_CC])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_BUILD])dnl
|
|
||||||
ac_prog=ld
|
|
||||||
if test "$ac_cv_prog_gcc" = yes; then
|
|
||||||
# Check if gcc -print-prog-name=ld gives a path.
|
|
||||||
AC_MSG_CHECKING([for ld used by GCC])
|
|
||||||
ac_prog=`($CC -print-prog-name=ld) 2>&5`
|
|
||||||
case "$ac_prog" in
|
|
||||||
# Accept absolute paths.
|
|
||||||
changequote(,)dnl
|
|
||||||
[\\/]* | [A-Za-z]:[\\/]*)
|
|
||||||
re_direlt='/[^/][^/]*/\.\./'
|
|
||||||
changequote([,])dnl
|
|
||||||
# Canonicalize the path of ld
|
|
||||||
ac_prog=`echo $ac_prog| sed 's%\\\\%/%g'`
|
|
||||||
while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do
|
|
||||||
ac_prog=`echo $ac_prog| sed "s%$re_direlt%/%"`
|
|
||||||
done
|
|
||||||
test -z "$LD" && LD="$ac_prog"
|
|
||||||
;;
|
|
||||||
"")
|
|
||||||
# If it fails, then pretend we aren't using GCC.
|
|
||||||
ac_prog=ld
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
# If it is relative, then search for the first ld in PATH.
|
|
||||||
with_gnu_ld=unknown
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
elif test "$with_gnu_ld" = yes; then
|
|
||||||
AC_MSG_CHECKING([for GNU ld])
|
|
||||||
else
|
|
||||||
AC_MSG_CHECKING([for non-GNU ld])
|
|
||||||
fi
|
|
||||||
AC_CACHE_VAL(ac_cv_path_LD,
|
|
||||||
[if test -z "$LD"; then
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR-:}"
|
|
||||||
for ac_dir in $PATH; do
|
|
||||||
test -z "$ac_dir" && ac_dir=.
|
|
||||||
if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
|
|
||||||
ac_cv_path_LD="$ac_dir/$ac_prog"
|
|
||||||
# Check to see if the program is GNU ld. I'd rather use --version,
|
|
||||||
# but apparently some GNU ld's only accept -v.
|
|
||||||
# Break only if it was the GNU/non-GNU ld that we prefer.
|
|
||||||
if "$ac_cv_path_LD" -v 2>&1 < /dev/null | egrep '(GNU|with BFD)' > /dev/null; then
|
|
||||||
test "$with_gnu_ld" != no && break
|
|
||||||
else
|
|
||||||
test "$with_gnu_ld" != yes && break
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
else
|
|
||||||
ac_cv_path_LD="$LD" # Let the user override the test with a path.
|
|
||||||
fi])
|
|
||||||
LD="$ac_cv_path_LD"
|
|
||||||
if test -n "$LD"; then
|
|
||||||
AC_MSG_RESULT($LD)
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
fi
|
|
||||||
test -z "$LD" && AC_MSG_ERROR([no acceptable ld found in \$PATH])
|
|
||||||
AC_PROG_LD_GNU
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_PROG_LD_GNU,
|
|
||||||
[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], ac_cv_prog_gnu_ld,
|
|
||||||
[# I'd rather use --version here, but apparently some GNU ld's only accept -v.
|
|
||||||
if $LD -v 2>&1 </dev/null | egrep '(GNU|with BFD)' 1>&5; then
|
|
||||||
ac_cv_prog_gnu_ld=yes
|
|
||||||
else
|
|
||||||
ac_cv_prog_gnu_ld=no
|
|
||||||
fi])
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_PROG_NM - find the path to a BSD-compatible name lister
|
|
||||||
AC_DEFUN(AC_PROG_NM,
|
|
||||||
[AC_MSG_CHECKING([for BSD-compatible nm])
|
|
||||||
AC_CACHE_VAL(ac_cv_path_NM,
|
|
||||||
[if test -n "$NM"; then
|
|
||||||
# Let the user override the test.
|
|
||||||
ac_cv_path_NM="$NM"
|
|
||||||
else
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR-:}"
|
|
||||||
for ac_dir in $PATH /usr/ccs/bin /usr/ucb /bin; do
|
|
||||||
test -z "$ac_dir" && ac_dir=.
|
|
||||||
if test -f $ac_dir/nm || test -f $ac_dir/nm$ac_exeext ; then
|
|
||||||
# Check to see if the nm accepts a BSD-compat flag.
|
|
||||||
# Adding the `sed 1q' prevents false positives on HP-UX, which says:
|
|
||||||
# nm: unknown option "B" ignored
|
|
||||||
if ($ac_dir/nm -B /dev/null 2>&1 | sed '1q'; exit 0) | egrep /dev/null >/dev/null; then
|
|
||||||
ac_cv_path_NM="$ac_dir/nm -B"
|
|
||||||
break
|
|
||||||
elif ($ac_dir/nm -p /dev/null 2>&1 | sed '1q'; exit 0) | egrep /dev/null >/dev/null; then
|
|
||||||
ac_cv_path_NM="$ac_dir/nm -p"
|
|
||||||
break
|
|
||||||
else
|
|
||||||
ac_cv_path_NM=${ac_cv_path_NM="$ac_dir/nm"} # keep the first match, but
|
|
||||||
continue # so that we can try to find one that supports BSD flags
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
test -z "$ac_cv_path_NM" && ac_cv_path_NM=nm
|
|
||||||
fi])
|
|
||||||
NM="$ac_cv_path_NM"
|
|
||||||
AC_MSG_RESULT([$NM])
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_CHECK_LIBM - check for math library
|
|
||||||
AC_DEFUN(AC_CHECK_LIBM,
|
|
||||||
[AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
LIBM=
|
|
||||||
case "$lt_target" in
|
|
||||||
*-*-beos* | *-*-cygwin*)
|
|
||||||
# These system don't have libm
|
|
||||||
;;
|
|
||||||
*-ncr-sysv4.3*)
|
|
||||||
AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw")
|
|
||||||
AC_CHECK_LIB(m, main, LIBM="$LIBM -lm")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
AC_CHECK_LIB(m, main, LIBM="-lm")
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_LIBLTDL_CONVENIENCE[(dir)] - sets LIBLTDL to the link flags for
|
|
||||||
# the libltdl convenience library and INCLTDL to the include flags for
|
|
||||||
# the libltdl header and adds --enable-ltdl-convenience to the
|
|
||||||
# configure arguments. Note that LIBLTDL and INCLTDL are not
|
|
||||||
# AC_SUBSTed, nor is AC_CONFIG_SUBDIRS called. If DIR is not
|
|
||||||
# provided, it is assumed to be `libltdl'. LIBLTDL will be prefixed
|
|
||||||
# with '${top_builddir}/' and INCLTDL will be prefixed with
|
|
||||||
# '${top_srcdir}/' (note the single quotes!). If your package is not
|
|
||||||
# flat and you're not using automake, define top_builddir and
|
|
||||||
# top_srcdir appropriately in the Makefiles.
|
|
||||||
AC_DEFUN(AC_LIBLTDL_CONVENIENCE, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
case "$enable_ltdl_convenience" in
|
|
||||||
no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;;
|
|
||||||
"") enable_ltdl_convenience=yes
|
|
||||||
ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;;
|
|
||||||
esac
|
|
||||||
LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdlc.la
|
|
||||||
INCLTDL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl'])
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_LIBLTDL_INSTALLABLE[(dir)] - sets LIBLTDL to the link flags for
|
|
||||||
# the libltdl installable library and INCLTDL to the include flags for
|
|
||||||
# the libltdl header and adds --enable-ltdl-install to the configure
|
|
||||||
# arguments. Note that LIBLTDL and INCLTDL are not AC_SUBSTed, nor is
|
|
||||||
# AC_CONFIG_SUBDIRS called. If DIR is not provided and an installed
|
|
||||||
# libltdl is not found, it is assumed to be `libltdl'. LIBLTDL will
|
|
||||||
# be prefixed with '${top_builddir}/' and INCLTDL will be prefixed
|
|
||||||
# with '${top_srcdir}/' (note the single quotes!). If your package is
|
|
||||||
# not flat and you're not using automake, define top_builddir and
|
|
||||||
# top_srcdir appropriately in the Makefiles.
|
|
||||||
# In the future, this macro may have to be called after AC_PROG_LIBTOOL.
|
|
||||||
AC_DEFUN(AC_LIBLTDL_INSTALLABLE, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_CHECK_LIB(ltdl, main,
|
|
||||||
[test x"$enable_ltdl_install" != xyes && enable_ltdl_install=no],
|
|
||||||
[if test x"$enable_ltdl_install" = xno; then
|
|
||||||
AC_MSG_WARN([libltdl not installed, but installation disabled])
|
|
||||||
else
|
|
||||||
enable_ltdl_install=yes
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
if test x"$enable_ltdl_install" = x"yes"; then
|
|
||||||
ac_configure_args="$ac_configure_args --enable-ltdl-install"
|
|
||||||
LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdl.la
|
|
||||||
INCLTDL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl'])
|
|
||||||
else
|
|
||||||
ac_configure_args="$ac_configure_args --enable-ltdl-install=no"
|
|
||||||
LIBLTDL="-lltdl"
|
|
||||||
INCLTDL=
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl old names
|
|
||||||
AC_DEFUN(AM_PROG_LIBTOOL, [indir([AC_PROG_LIBTOOL])])dnl
|
|
||||||
AC_DEFUN(AM_ENABLE_SHARED, [indir([AC_ENABLE_SHARED], $@)])dnl
|
|
||||||
AC_DEFUN(AM_ENABLE_STATIC, [indir([AC_ENABLE_STATIC], $@)])dnl
|
|
||||||
AC_DEFUN(AM_DISABLE_SHARED, [indir([AC_DISABLE_SHARED], $@)])dnl
|
|
||||||
AC_DEFUN(AM_DISABLE_STATIC, [indir([AC_DISABLE_STATIC], $@)])dnl
|
|
||||||
AC_DEFUN(AM_PROG_LD, [indir([AC_PROG_LD])])dnl
|
|
||||||
AC_DEFUN(AM_PROG_NM, [indir([AC_PROG_NM])])dnl
|
|
||||||
|
|
||||||
dnl This is just to silence aclocal about the macro not being used
|
|
||||||
ifelse([AC_DISABLE_FAST_INSTALL])dnl
|
|
||||||
|
|
||||||
67
build_vms.com
Executable file
67
build_vms.com
Executable file
@@ -0,0 +1,67 @@
|
|||||||
|
$!
|
||||||
|
$
|
||||||
|
$ on control_y then goto Common_Exit!
|
||||||
|
$ orig = f$environment("DEFAULT")
|
||||||
|
$ loc = f$environment("PROCEDURE")
|
||||||
|
$ def = f$parse("X.X;1",loc) - "X.X;1"
|
||||||
|
$
|
||||||
|
$ set def 'def'
|
||||||
|
$ cc_qual = "/define=HAVE_CONFIG_H=1/include=(""../include/"",""../"")"
|
||||||
|
$ if p1 .eqs. "LISTING" then cc_qual = cc_qual + "/LIST/MACHINE"
|
||||||
|
$ if p1 .eqs. "DEBUG" then cc_qual = cc_qual + "/LIST/MACHINE/DEBUG"
|
||||||
|
$ msg_qual = ""
|
||||||
|
$ call build "[.lib]" "*.c"
|
||||||
|
$ call build "[.src]" "*.c"
|
||||||
|
$ call build "[.src]" "*.msg"
|
||||||
|
$ link /exe=curl.exe [.src]curl/lib/include=main,[.lib]curl/lib
|
||||||
|
$
|
||||||
|
$
|
||||||
|
$ goto Common_Exit
|
||||||
|
$build: subroutine
|
||||||
|
$ set noon
|
||||||
|
$ set default 'p1'
|
||||||
|
$ search = p2
|
||||||
|
$ reset = f$search("reset")
|
||||||
|
$ if f$search("CURL.OLB") .eqs. ""
|
||||||
|
$ then
|
||||||
|
$ LIB/CREATE/OBJECT CURL.OLB
|
||||||
|
$ endif
|
||||||
|
$ reset = f$search("reset",1)
|
||||||
|
$Loop:
|
||||||
|
$ file = f$search(search,1)
|
||||||
|
$ if file .eqs. "" then goto EndLoop
|
||||||
|
$ obj = f$search(f$parse(".OBJ;",file),2)
|
||||||
|
$ if (obj .nes. "")
|
||||||
|
$ then
|
||||||
|
$ if (f$cvtime(f$file(file,"rdt")) .gts. f$cvtime(f$file(obj,"rdt")))
|
||||||
|
$ then
|
||||||
|
$ call compile 'file'
|
||||||
|
$ lib/object curl.OLB 'f$parse(".obj;",file)'
|
||||||
|
$ else
|
||||||
|
$! write sys$output "File: ''file' is up to date"
|
||||||
|
$ endif
|
||||||
|
$ else
|
||||||
|
$! write sys$output "Object for file: ''file' does not exist"
|
||||||
|
$ call compile 'file'
|
||||||
|
$ lib/object curl.OLB 'f$parse(".obj;",file)'
|
||||||
|
$ endif
|
||||||
|
$ goto Loop
|
||||||
|
$EndLoop:
|
||||||
|
$ purge
|
||||||
|
$ set def 'def'
|
||||||
|
$ endsubroutine ! Build
|
||||||
|
$
|
||||||
|
$compile: subroutine
|
||||||
|
$ set noon
|
||||||
|
$ file = p1
|
||||||
|
$ qual = p2+p3+p4+p5+p6+p7+p8
|
||||||
|
$ typ = f$parse(file,,,"TYPE") - "."
|
||||||
|
$ cmd_c = "CC "+cc_qual
|
||||||
|
$ cmd_msg = "MESSAGE "+msg_qual
|
||||||
|
$ x = cmd_'typ'
|
||||||
|
$ 'x' 'file'
|
||||||
|
$ ENDSUBROUTINE ! Compile
|
||||||
|
$
|
||||||
|
$Common_Exit:
|
||||||
|
$ set default 'orig'
|
||||||
|
$ exit
|
||||||
11
buildconf
Executable file
11
buildconf
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
die(){
|
||||||
|
echo "$@"
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
aclocal || die "The command 'aclocal' failed"
|
||||||
|
autoheader || die "The command 'autoheader' failed"
|
||||||
|
autoconf || die "The command 'autoconf' failed"
|
||||||
|
automake || die "The command 'automake $MAKEFILES' failed"
|
||||||
45
config-mac.h
Normal file
45
config-mac.h
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
#define OS "mac"
|
||||||
|
|
||||||
|
#define HAVE_NETINET_IN_H 1
|
||||||
|
#define HAVE_SYS_SOCKET_H 1
|
||||||
|
#define HAVE_SYS_SELECT_H 1
|
||||||
|
#define HAVE_NETDB_H 1
|
||||||
|
#define HAVE_ARPA_INET_H 1
|
||||||
|
#define HAVE_UNISTD_H 1
|
||||||
|
#define HAVE_NET_IF_H 1
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
#define HAVE_GETTIMEOFDAY 1
|
||||||
|
#define HAVE_FCNTL_H 1
|
||||||
|
#define HAVE_SYS_STAT_H 1
|
||||||
|
#define HAVE_ALLOCA_H 1
|
||||||
|
#define HAVE_TIME_H 1
|
||||||
|
#define HAVE_STDLIB_H 1
|
||||||
|
#define HAVE_UTIME_H 1
|
||||||
|
|
||||||
|
#define TIME_WITH_SYS_TIME 1
|
||||||
|
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
#define HAVE_UTIME 1
|
||||||
|
#define HAVE_INET_NTOA 1
|
||||||
|
#define HAVE_SETVBUF 1
|
||||||
|
#define HAVE_STRFTIME 1
|
||||||
|
#define HAVE_INET_ADDR 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_SELECT 1
|
||||||
|
#define HAVE_SOCKET 1
|
||||||
|
|
||||||
|
//#define HAVE_STRICMP 1
|
||||||
|
#define HAVE_SIGACTION 1
|
||||||
|
|
||||||
|
#ifdef MACOS_SSL_SUPPORT
|
||||||
|
# define USE_SSLEAY 1
|
||||||
|
# define USE_OPENSSL 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define HAVE_RAND_STATUS 1
|
||||||
|
#define HAVE_RAND_EGD 1
|
||||||
|
|
||||||
|
#define HAVE_FIONBIO 1
|
||||||
|
|
||||||
|
#include <extra/stricmp.h>
|
||||||
|
#include <extra/strdup.h>
|
||||||
25
config-riscos.h
Normal file
25
config-riscos.h
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
|
||||||
|
#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"
|
||||||
157
config.h.in → config-vms.h
Normal file → Executable file
157
config.h.in → config-vms.h
Normal file → Executable file
@@ -17,13 +17,13 @@
|
|||||||
#undef size_t
|
#undef size_t
|
||||||
|
|
||||||
/* Define if you have the ANSI C header files. */
|
/* Define if you have the ANSI C header files. */
|
||||||
#undef STDC_HEADERS
|
#define STDC_HEADERS 1
|
||||||
|
|
||||||
/* Define if you can safely include both <sys/time.h> and <time.h>. */
|
/* Define if you can safely include both <sys/time.h> and <time.h>. */
|
||||||
#undef TIME_WITH_SYS_TIME
|
#define TIME_WITH_SYS_TIME 1
|
||||||
|
|
||||||
/* Define cpu-machine-OS */
|
/* Define cpu-machine-OS */
|
||||||
#undef OS
|
#define OS "ALPHA-COMPAQ-VMS"
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
||||||
#undef HAVE_GETHOSTBYADDR_R_5
|
#undef HAVE_GETHOSTBYADDR_R_5
|
||||||
@@ -52,11 +52,26 @@
|
|||||||
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
||||||
#undef KRB4
|
#undef KRB4
|
||||||
|
|
||||||
|
/* 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 */
|
||||||
|
#define socklen_t size_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
|
||||||
|
|
||||||
/* The number of bytes in a long double. */
|
/* The number of bytes in a long double. */
|
||||||
#undef SIZEOF_LONG_DOUBLE
|
#define SIZEOF_LONG_DOUBLE 8
|
||||||
|
|
||||||
/* The number of bytes in a long long. */
|
/* The number of bytes in a long long. */
|
||||||
#undef SIZEOF_LONG_LONG
|
#define SIZEOF_LONG_LONG 8
|
||||||
|
|
||||||
|
/* Define if you have the RAND_egd function. */
|
||||||
|
#undef HAVE_RAND_EGD
|
||||||
|
|
||||||
/* Define if you have the RAND_screen function. */
|
/* Define if you have the RAND_screen function. */
|
||||||
#undef HAVE_RAND_SCREEN
|
#undef HAVE_RAND_SCREEN
|
||||||
@@ -67,8 +82,11 @@
|
|||||||
/* Define if you have the closesocket function. */
|
/* Define if you have the closesocket function. */
|
||||||
#undef HAVE_CLOSESOCKET
|
#undef HAVE_CLOSESOCKET
|
||||||
|
|
||||||
|
/* Define if you have the geteuid function. */
|
||||||
|
#define HAVE_GETEUID 1
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr function. */
|
/* Define if you have the gethostbyaddr function. */
|
||||||
#undef HAVE_GETHOSTBYADDR
|
#define HAVE_GETHOSTBYADDR 1
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r function. */
|
/* Define if you have the gethostbyaddr_r function. */
|
||||||
#undef HAVE_GETHOSTBYADDR_R
|
#undef HAVE_GETHOSTBYADDR_R
|
||||||
@@ -77,22 +95,25 @@
|
|||||||
#undef HAVE_GETHOSTBYNAME_R
|
#undef HAVE_GETHOSTBYNAME_R
|
||||||
|
|
||||||
/* Define if you have the gethostname function. */
|
/* Define if you have the gethostname function. */
|
||||||
#undef HAVE_GETHOSTNAME
|
#define HAVE_GETHOSTNAME 1
|
||||||
|
|
||||||
/* Define if you have the getpass_r function. */
|
/* Define if you have the getpass_r function. */
|
||||||
#undef HAVE_GETPASS_R
|
#undef HAVE_GETPASS_R
|
||||||
|
|
||||||
|
/* Define if you have the getpwuid function. */
|
||||||
|
#define HAVE_GETPWUID 1
|
||||||
|
|
||||||
/* Define if you have the getservbyname function. */
|
/* Define if you have the getservbyname function. */
|
||||||
#undef HAVE_GETSERVBYNAME
|
#define HAVE_GETSERVBYNAME 1
|
||||||
|
|
||||||
/* Define if you have the gettimeofday function. */
|
/* Define if you have the gettimeofday function. */
|
||||||
#undef HAVE_GETTIMEOFDAY
|
#define HAVE_GETTIMEOFDAY 1
|
||||||
|
|
||||||
/* Define if you have the inet_addr function. */
|
/* Define if you have the inet_addr function. */
|
||||||
#undef HAVE_INET_ADDR
|
#define HAVE_INET_ADDR 1
|
||||||
|
|
||||||
/* Define if you have the inet_ntoa function. */
|
/* Define if you have the inet_ntoa function. */
|
||||||
#undef HAVE_INET_NTOA
|
#define HAVE_INET_NTOA 1
|
||||||
|
|
||||||
/* Define if you have the inet_ntoa_r function. */
|
/* Define if you have the inet_ntoa_r function. */
|
||||||
#undef HAVE_INET_NTOA_R
|
#undef HAVE_INET_NTOA_R
|
||||||
@@ -104,43 +125,46 @@
|
|||||||
#undef HAVE_LOCALTIME_R
|
#undef HAVE_LOCALTIME_R
|
||||||
|
|
||||||
/* Define if you have the perror function. */
|
/* Define if you have the perror function. */
|
||||||
#undef HAVE_PERROR
|
#define HAVE_PERROR 1
|
||||||
|
|
||||||
/* Define if you have the select function. */
|
/* Define if you have the select function. */
|
||||||
#undef HAVE_SELECT
|
#define HAVE_SELECT 1
|
||||||
|
|
||||||
/* Define if you have the setvbuf function. */
|
/* Define if you have the setvbuf function. */
|
||||||
#undef HAVE_SETVBUF
|
#undef HAVE_SETVBUF
|
||||||
|
|
||||||
/* Define if you have the sigaction function. */
|
/* Define if you have the sigaction function. */
|
||||||
#undef HAVE_SIGACTION
|
#define HAVE_SIGACTION 1
|
||||||
|
|
||||||
/* Define if you have the signal function. */
|
/* Define if you have the signal function. */
|
||||||
#undef HAVE_SIGNAL
|
#define HAVE_SIGNAL 1
|
||||||
|
|
||||||
/* Define if you have the socket function. */
|
/* Define if you have the socket function. */
|
||||||
#undef HAVE_SOCKET
|
#define HAVE_SOCKET 1
|
||||||
|
|
||||||
/* Define if you have the strcasecmp function. */
|
/* Define if you have the strcasecmp function. */
|
||||||
#undef HAVE_STRCASECMP
|
#define HAVE_STRCASECMP 1
|
||||||
|
|
||||||
/* Define if you have the strcmpi function. */
|
/* Define if you have the strcmpi function. */
|
||||||
#undef HAVE_STRCMPI
|
#define HAVE_STRCMPI 1
|
||||||
|
|
||||||
/* Define if you have the strdup function. */
|
/* Define if you have the strdup function. */
|
||||||
#undef HAVE_STRDUP
|
#define HAVE_STRDUP 1
|
||||||
|
|
||||||
/* Define if you have the strftime function. */
|
/* Define if you have the strftime function. */
|
||||||
#undef HAVE_STRFTIME
|
#define HAVE_STRFTIME 1
|
||||||
|
|
||||||
/* Define if you have the stricmp function. */
|
/* Define if you have the stricmp function. */
|
||||||
#undef HAVE_STRICMP
|
#define HAVE_STRICMP 1
|
||||||
|
|
||||||
|
/* Define if you have the strlcat function. */
|
||||||
|
#undef HAVE_STRLCAT
|
||||||
|
|
||||||
/* Define if you have the strlcpy function. */
|
/* Define if you have the strlcpy function. */
|
||||||
#undef HAVE_STRLCPY
|
#undef HAVE_STRLCPY
|
||||||
|
|
||||||
/* Define if you have the strstr function. */
|
/* Define if you have the strstr function. */
|
||||||
#undef HAVE_STRSTR
|
#define HAVE_STRSTR 1
|
||||||
|
|
||||||
/* Define if you have the tcgetattr function. */
|
/* Define if you have the tcgetattr function. */
|
||||||
#undef HAVE_TCGETATTR
|
#undef HAVE_TCGETATTR
|
||||||
@@ -149,7 +173,7 @@
|
|||||||
#undef HAVE_TCSETATTR
|
#undef HAVE_TCSETATTR
|
||||||
|
|
||||||
/* Define if you have the uname function. */
|
/* Define if you have the uname function. */
|
||||||
#undef HAVE_UNAME
|
#define HAVE_UNAME 1
|
||||||
|
|
||||||
/* Define if you have the <alloca.h> header file. */
|
/* Define if you have the <alloca.h> header file. */
|
||||||
#undef HAVE_ALLOCA_H
|
#undef HAVE_ALLOCA_H
|
||||||
@@ -167,13 +191,13 @@
|
|||||||
#undef HAVE_DLFCN_H
|
#undef HAVE_DLFCN_H
|
||||||
|
|
||||||
/* Define if you have the <err.h> header file. */
|
/* Define if you have the <err.h> header file. */
|
||||||
#undef HAVE_ERR_H
|
#define HAVE_ERR_H 1
|
||||||
|
|
||||||
/* Define if you have the <fcntl.h> header file. */
|
/* Define if you have the <fcntl.h> header file. */
|
||||||
#undef HAVE_FCNTL_H
|
#define HAVE_FCNTL_H 1
|
||||||
|
|
||||||
/* Define if you have the <getopt.h> header file. */
|
/* Define if you have the <getopt.h> header file. */
|
||||||
#undef HAVE_GETOPT_H
|
#define HAVE_GETOPT_H 1
|
||||||
|
|
||||||
/* Define if you have the <io.h> header file. */
|
/* Define if you have the <io.h> header file. */
|
||||||
#undef HAVE_IO_H
|
#undef HAVE_IO_H
|
||||||
@@ -182,19 +206,19 @@
|
|||||||
#undef HAVE_KRB_H
|
#undef HAVE_KRB_H
|
||||||
|
|
||||||
/* Define if you have the <malloc.h> header file. */
|
/* Define if you have the <malloc.h> header file. */
|
||||||
#undef HAVE_MALLOC_H
|
#define HAVE_MALLOC_H 1
|
||||||
|
|
||||||
/* Define if you have the <net/if.h> header file. */
|
/* Define if you have the <net/if.h> header file. */
|
||||||
#undef HAVE_NET_IF_H
|
#define HAVE_NET_IF_H 1
|
||||||
|
|
||||||
/* Define if you have the <netdb.h> header file. */
|
/* Define if you have the <netdb.h> header file. */
|
||||||
#undef HAVE_NETDB_H
|
#define HAVE_NETDB_H 1
|
||||||
|
|
||||||
/* Define if you have the <netinet/if_ether.h> header file. */
|
/* Define if you have the <netinet/if_ether.h> header file. */
|
||||||
#undef HAVE_NETINET_IF_ETHER_H
|
#define HAVE_NETINET_IF_ETHER_H 1
|
||||||
|
|
||||||
/* Define if you have the <netinet/in.h> header file. */
|
/* Define if you have the <netinet/in.h> header file. */
|
||||||
#undef HAVE_NETINET_IN_H
|
#define HAVE_NETINET_IN_H 1
|
||||||
|
|
||||||
/* Define if you have the <openssl/crypto.h> header file. */
|
/* Define if you have the <openssl/crypto.h> header file. */
|
||||||
#undef HAVE_OPENSSL_CRYPTO_H
|
#undef HAVE_OPENSSL_CRYPTO_H
|
||||||
@@ -217,17 +241,20 @@
|
|||||||
/* Define if you have the <pem.h> header file. */
|
/* Define if you have the <pem.h> header file. */
|
||||||
#undef HAVE_PEM_H
|
#undef HAVE_PEM_H
|
||||||
|
|
||||||
|
/* Define if you have the <pwd.h> header file. */
|
||||||
|
#define HAVE_PWD_H 1
|
||||||
|
|
||||||
/* Define if you have the <rsa.h> header file. */
|
/* Define if you have the <rsa.h> header file. */
|
||||||
#undef HAVE_RSA_H
|
#undef HAVE_RSA_H
|
||||||
|
|
||||||
/* Define if you have the <sgtty.h> header file. */
|
/* Define if you have the <sgtty.h> header file. */
|
||||||
#undef HAVE_SGTTY_H
|
#define HAVE_SGTTY_H 1
|
||||||
|
|
||||||
/* Define if you have the <ssl.h> header file. */
|
/* Define if you have the <ssl.h> header file. */
|
||||||
#undef HAVE_SSL_H
|
#undef HAVE_SSL_H
|
||||||
|
|
||||||
/* Define if you have the <stdlib.h> header file. */
|
/* Define if you have the <stdlib.h> header file. */
|
||||||
#undef HAVE_STDLIB_H
|
#define HAVE_STDLIB_H 1
|
||||||
|
|
||||||
/* Define if you have the <sys/param.h> header file. */
|
/* Define if you have the <sys/param.h> header file. */
|
||||||
#undef HAVE_SYS_PARAM_H
|
#undef HAVE_SYS_PARAM_H
|
||||||
@@ -236,31 +263,31 @@
|
|||||||
#undef HAVE_SYS_SELECT_H
|
#undef HAVE_SYS_SELECT_H
|
||||||
|
|
||||||
/* Define if you have the <sys/socket.h> header file. */
|
/* Define if you have the <sys/socket.h> header file. */
|
||||||
#undef HAVE_SYS_SOCKET_H
|
#define HAVE_SYS_SOCKET_H 1
|
||||||
|
|
||||||
/* Define if you have the <sys/sockio.h> header file. */
|
/* Define if you have the <sys/sockio.h> header file. */
|
||||||
#undef HAVE_SYS_SOCKIO_H
|
#undef HAVE_SYS_SOCKIO_H
|
||||||
|
|
||||||
/* Define if you have the <sys/stat.h> header file. */
|
/* Define if you have the <sys/stat.h> header file. */
|
||||||
#undef HAVE_SYS_STAT_H
|
#define HAVE_SYS_STAT_H 1
|
||||||
|
|
||||||
/* Define if you have the <sys/time.h> header file. */
|
/* Define if you have the <sys/time.h> header file. */
|
||||||
#undef HAVE_SYS_TIME_H
|
#define HAVE_SYS_TIME_H 1
|
||||||
|
|
||||||
/* Define if you have the <sys/types.h> header file. */
|
/* Define if you have the <sys/types.h> header file. */
|
||||||
#undef HAVE_SYS_TYPES_H
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
|
||||||
/* Define if you have the <termio.h> header file. */
|
/* Define if you have the <termio.h> header file. */
|
||||||
#undef HAVE_TERMIO_H
|
#undef HAVE_TERMIO_H
|
||||||
|
|
||||||
/* Define if you have the <termios.h> header file. */
|
/* Define if you have the <termios.h> header file. */
|
||||||
#undef HAVE_TERMIOS_H
|
#define HAVE_TERMIOS_H 1
|
||||||
|
|
||||||
/* Define if you have the <time.h> header file. */
|
/* Define if you have the <time.h> header file. */
|
||||||
#undef HAVE_TIME_H
|
#define HAVE_TIME_H 1
|
||||||
|
|
||||||
/* Define if you have the <unistd.h> header file. */
|
/* Define if you have the <unistd.h> header file. */
|
||||||
#undef HAVE_UNISTD_H
|
#define HAVE_UNISTD_H 1
|
||||||
|
|
||||||
/* Define if you have the <winsock.h> header file. */
|
/* Define if you have the <winsock.h> header file. */
|
||||||
#undef HAVE_WINSOCK_H
|
#undef HAVE_WINSOCK_H
|
||||||
@@ -278,13 +305,13 @@
|
|||||||
#undef HAVE_LIBNSL
|
#undef HAVE_LIBNSL
|
||||||
|
|
||||||
/* Define if you have the resolv library (-lresolv). */
|
/* Define if you have the resolv library (-lresolv). */
|
||||||
#undef HAVE_LIBRESOLV
|
#define HAVE_LIBRESOLV 1
|
||||||
|
|
||||||
/* Define if you have the resolve library (-lresolve). */
|
/* Define if you have the resolve library (-lresolve). */
|
||||||
#undef HAVE_LIBRESOLVE
|
#undef HAVE_LIBRESOLVE
|
||||||
|
|
||||||
/* Define if you have the socket library (-lsocket). */
|
/* Define if you have the socket library (-lsocket). */
|
||||||
#undef HAVE_LIBSOCKET
|
#define HAVE_LIBSOCKET 1
|
||||||
|
|
||||||
/* Define if you have the ssl library (-lssl). */
|
/* Define if you have the ssl library (-lssl). */
|
||||||
#undef HAVE_LIBSSL
|
#undef HAVE_LIBSSL
|
||||||
@@ -292,21 +319,49 @@
|
|||||||
/* Define if you have the ucb library (-lucb). */
|
/* Define if you have the ucb library (-lucb). */
|
||||||
#undef HAVE_LIBUCB
|
#undef HAVE_LIBUCB
|
||||||
|
|
||||||
/* Name of package */
|
|
||||||
#undef PACKAGE
|
|
||||||
|
|
||||||
/* Version number of package */
|
|
||||||
#undef VERSION
|
|
||||||
|
|
||||||
/* Number of bits in a file offset, on hosts where this is settable. */
|
/* Number of bits in a file offset, on hosts where this is settable. */
|
||||||
#undef _FILE_OFFSET_BITS
|
#undef _FILE_OFFSET_BITS
|
||||||
|
|
||||||
/* Define to make ftello visible on some hosts (e.g. HP-UX 10.20). */
|
|
||||||
#undef _LARGEFILE_SOURCE
|
|
||||||
|
|
||||||
/* Define for large files, on AIX-style hosts. */
|
/* Define for large files, on AIX-style hosts. */
|
||||||
#undef _LARGE_FILES
|
#undef _LARGE_FILES
|
||||||
|
|
||||||
|
/* Define if getaddrinfo exists and works */
|
||||||
|
#define HAVE_GETADDRINFO 1
|
||||||
|
|
||||||
|
/* Define if you want to enable IPv6 support */
|
||||||
|
#undef ENABLE_IPV6
|
||||||
|
|
||||||
/* Set to explicitly specify we don't want to use thread-safe functions */
|
/* Set to explicitly specify we don't want to use thread-safe functions */
|
||||||
#undef DISABLED_THREADSAFE
|
#undef DISABLED_THREADSAFE
|
||||||
|
|
||||||
|
#define HAVE_TIMEVAL_H 1
|
||||||
|
|
||||||
|
/* Name of this package! */
|
||||||
|
#define PACKAGE "not-used"
|
||||||
|
|
||||||
|
/* Version number of this archive. */
|
||||||
|
#define VERSION "not-used"
|
||||||
|
|
||||||
|
/* Define if you have the getpass function. */
|
||||||
|
#undef HAVE_GETPASS
|
||||||
|
|
||||||
|
/* Define if you have a working OpenSSL installation */
|
||||||
|
#undef OPENSSL_ENABLED
|
||||||
|
|
||||||
|
/* Define if you have the `dlopen' function. */
|
||||||
|
#undef HAVE_DLOPEN
|
||||||
|
|
||||||
|
/* Define if you have the <inttypes.h> header file. */
|
||||||
|
#undef HAVE_INTTYPES_H
|
||||||
|
|
||||||
|
/* Define if you have the <strings.h> header file. */
|
||||||
|
#define HAVE_STRINGS_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <string.h> header file. */
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
|
||||||
|
/* Define if you have the `strtok_r' function. */
|
||||||
|
#undef HAVE_STRTOK_R
|
||||||
|
|
||||||
|
#define HAVE_MEMORY_H 1
|
||||||
|
|
||||||
@@ -23,6 +23,12 @@
|
|||||||
/* Define to `unsigned' if <sys/types.h> doesn't define. */
|
/* Define to `unsigned' if <sys/types.h> doesn't define. */
|
||||||
/* #undef size_t */
|
/* #undef size_t */
|
||||||
|
|
||||||
|
/* Define this to 'int' if ssize_t is not an available typedefed type */
|
||||||
|
#define ssize_t int
|
||||||
|
|
||||||
|
/* Define this to 'int' if socklen_t is not an available typedefed type */
|
||||||
|
#define socklen_t int
|
||||||
|
|
||||||
/* Define if you have the ANSI C header files. */
|
/* Define if you have the ANSI C header files. */
|
||||||
#define STDC_HEADERS 1
|
#define STDC_HEADERS 1
|
||||||
|
|
||||||
@@ -36,7 +42,7 @@
|
|||||||
#define SIZEOF_LONG_DOUBLE 16
|
#define SIZEOF_LONG_DOUBLE 16
|
||||||
|
|
||||||
/* The number of bytes in a long long. */
|
/* The number of bytes in a long long. */
|
||||||
#define SIZEOF_LONG_LONG 8
|
/* #define SIZEOF_LONG_LONG 8 */
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr function. */
|
/* Define if you have the gethostbyaddr function. */
|
||||||
#define HAVE_GETHOSTBYADDR 1
|
#define HAVE_GETHOSTBYADDR 1
|
||||||
@@ -95,6 +101,9 @@
|
|||||||
/* Define if you have the <alloca.h> header file. */
|
/* Define if you have the <alloca.h> header file. */
|
||||||
/*#define HAVE_ALLOCA_H 1*/
|
/*#define HAVE_ALLOCA_H 1*/
|
||||||
|
|
||||||
|
/* Define if you have the malloc.h file. */
|
||||||
|
#define HAVE_MALLOC_H 1
|
||||||
|
|
||||||
/* Define if you have the <arpa/inet.h> header file. */
|
/* Define if you have the <arpa/inet.h> header file. */
|
||||||
#define HAVE_ARPA_INET_H 1
|
#define HAVE_ARPA_INET_H 1
|
||||||
|
|
||||||
@@ -170,6 +179,9 @@
|
|||||||
/* Define if you have the RAND_screen function when using SSL */
|
/* Define if you have the RAND_screen function when using SSL */
|
||||||
#define HAVE_RAND_SCREEN 1
|
#define HAVE_RAND_SCREEN 1
|
||||||
|
|
||||||
|
/* Define this to if in_addr_t is not an available typedefed type */
|
||||||
|
#define in_addr_t unsigned long
|
||||||
|
|
||||||
/*************************************************
|
/*************************************************
|
||||||
* This section is for compiler specific defines.*
|
* This section is for compiler specific defines.*
|
||||||
*************************************************/
|
*************************************************/
|
||||||
@@ -179,3 +191,28 @@
|
|||||||
#define HAVE_UNISTD_H 1
|
#define HAVE_UNISTD_H 1
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**************************************************
|
||||||
|
*This is to eliminate the warnings when compiled *
|
||||||
|
* using MS VC++ compiler *
|
||||||
|
**************************************************/
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
|
||||||
|
#pragma warning (disable: 4244) /* truncation from 'const int' to 'char' */
|
||||||
|
#pragma warning (disable: 4127) /* conditional expression is constant */
|
||||||
|
#pragma warning (disable: 4706) /* assignment within conditional expression */
|
||||||
|
#pragma warning (disable: 4761) /* integral size mismatch in argument */
|
||||||
|
#pragma warning (disable: 4101) /* unreferenced local variable */
|
||||||
|
#pragma warning (disable: 4131) /* uses old-style declarator */
|
||||||
|
#pragma warning (disable: 4057) /* const char *' differs in indirection to
|
||||||
|
slightly different base types from
|
||||||
|
'unsigned char [x] */
|
||||||
|
#pragma warning (disable: 4100) /* unreferenced formal parameter */
|
||||||
|
#pragma warning (disable: 4055) /* type cast' : from data pointer 'void *' to
|
||||||
|
function pointer
|
||||||
|
'void *(__cdecl *)(char *,int ) */
|
||||||
|
#pragma warning (disable: 4701) /* local variable may be used without having
|
||||||
|
been initialized */
|
||||||
|
#pragma warning (disable: 4715) /* ToHour' : not all control paths return a
|
||||||
|
value */
|
||||||
|
#endif
|
||||||
|
|||||||
664
config.guess
vendored
664
config.guess
vendored
@@ -1,8 +1,10 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Attempt to guess a canonical system name.
|
# Attempt to guess a canonical system name.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
# Free Software Foundation, Inc.
|
# Free Software Foundation, Inc.
|
||||||
#
|
|
||||||
|
timestamp='2001-09-04'
|
||||||
|
|
||||||
# This file is free software; you can redistribute it and/or modify it
|
# This file is free software; you can redistribute it and/or modify it
|
||||||
# under the terms of the GNU General Public License as published by
|
# under the terms of the GNU General Public License as published by
|
||||||
# the Free Software Foundation; either version 2 of the License, or
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
@@ -30,40 +32,97 @@
|
|||||||
# exits with 0. Otherwise, it exits with 1.
|
# exits with 0. Otherwise, it exits with 1.
|
||||||
#
|
#
|
||||||
# The plan is that this can be called by configure scripts if you
|
# The plan is that this can be called by configure scripts if you
|
||||||
# don't specify an explicit system type (host/target name).
|
# don't specify an explicit build system type.
|
||||||
#
|
|
||||||
# Only a few systems have been added to this list; please add others
|
|
||||||
# (but try to keep the structure clean).
|
|
||||||
#
|
|
||||||
|
|
||||||
# Use $HOST_CC if defined. $CC may point to a cross-compiler
|
me=`echo "$0" | sed -e 's,.*/,,'`
|
||||||
if test x"$CC_FOR_BUILD" = x; then
|
|
||||||
if test x"$HOST_CC" != x; then
|
usage="\
|
||||||
CC_FOR_BUILD="$HOST_CC"
|
Usage: $0 [OPTION]
|
||||||
else
|
|
||||||
if test x"$CC" != x; then
|
Output the configuration name of the system \`$me' is run on.
|
||||||
CC_FOR_BUILD="$CC"
|
|
||||||
else
|
Operation modes:
|
||||||
CC_FOR_BUILD=cc
|
-h, --help print this help, then exit
|
||||||
fi
|
-t, --time-stamp print date of last modification, then exit
|
||||||
fi
|
-v, --version print version number, then exit
|
||||||
|
|
||||||
|
Report bugs and patches to <config-patches@gnu.org>."
|
||||||
|
|
||||||
|
version="\
|
||||||
|
GNU config.guess ($timestamp)
|
||||||
|
|
||||||
|
Originally written by Per Bothner.
|
||||||
|
Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
|
Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This is free software; see the source for copying conditions. There is NO
|
||||||
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
|
||||||
|
help="
|
||||||
|
Try \`$me --help' for more information."
|
||||||
|
|
||||||
|
# Parse command line
|
||||||
|
while test $# -gt 0 ; do
|
||||||
|
case $1 in
|
||||||
|
--time-stamp | --time* | -t )
|
||||||
|
echo "$timestamp" ; exit 0 ;;
|
||||||
|
--version | -v )
|
||||||
|
echo "$version" ; exit 0 ;;
|
||||||
|
--help | --h* | -h )
|
||||||
|
echo "$usage"; exit 0 ;;
|
||||||
|
-- ) # Stop option processing
|
||||||
|
shift; break ;;
|
||||||
|
- ) # Use stdin as input.
|
||||||
|
break ;;
|
||||||
|
-* )
|
||||||
|
echo "$me: invalid option $1$help" >&2
|
||||||
|
exit 1 ;;
|
||||||
|
* )
|
||||||
|
break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if test $# != 0; then
|
||||||
|
echo "$me: too many arguments$help" >&2
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
dummy=dummy-$$
|
||||||
|
trap 'rm -f $dummy.c $dummy.o $dummy.rel $dummy; exit 1' 1 2 15
|
||||||
|
|
||||||
|
# CC_FOR_BUILD -- compiler used by this script.
|
||||||
|
# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
|
||||||
|
# use `HOST_CC' if defined, but it is deprecated.
|
||||||
|
|
||||||
|
set_cc_for_build='case $CC_FOR_BUILD,$HOST_CC,$CC in
|
||||||
|
,,) echo "int dummy(){}" > $dummy.c ;
|
||||||
|
for c in cc gcc c89 ; do
|
||||||
|
($c $dummy.c -c -o $dummy.o) >/dev/null 2>&1 ;
|
||||||
|
if test $? = 0 ; then
|
||||||
|
CC_FOR_BUILD="$c"; break ;
|
||||||
|
fi ;
|
||||||
|
done ;
|
||||||
|
rm -f $dummy.c $dummy.o $dummy.rel ;
|
||||||
|
if test x"$CC_FOR_BUILD" = x ; then
|
||||||
|
CC_FOR_BUILD=no_compiler_found ;
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
,,*) CC_FOR_BUILD=$CC ;;
|
||||||
|
,*,*) CC_FOR_BUILD=$HOST_CC ;;
|
||||||
|
esac'
|
||||||
|
|
||||||
# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
|
# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
|
||||||
# (ghazi@noc.rutgers.edu 8/24/94.)
|
# (ghazi@noc.rutgers.edu 1994-08-24)
|
||||||
if (test -f /.attbin/uname) >/dev/null 2>&1 ; then
|
if (test -f /.attbin/uname) >/dev/null 2>&1 ; then
|
||||||
PATH=$PATH:/.attbin ; export PATH
|
PATH=$PATH:/.attbin ; export PATH
|
||||||
fi
|
fi
|
||||||
|
|
||||||
UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
|
UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
|
||||||
UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
|
UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
|
||||||
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
|
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
|
||||||
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
|
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
|
||||||
|
|
||||||
dummy=dummy-$$
|
|
||||||
trap 'rm -f $dummy.c $dummy.o $dummy; exit 1' 1 2 15
|
|
||||||
|
|
||||||
# Note: order is significant - the case branches are not exclusive.
|
# Note: order is significant - the case branches are not exclusive.
|
||||||
|
|
||||||
case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
||||||
@@ -77,7 +136,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
|||||||
# object file format.
|
# object file format.
|
||||||
# Determine the machine/vendor (is the vendor relevant).
|
# Determine the machine/vendor (is the vendor relevant).
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
amiga) machine=m68k-cbm ;;
|
amiga) machine=m68k-unknown ;;
|
||||||
arm32) machine=arm-unknown ;;
|
arm32) machine=arm-unknown ;;
|
||||||
atari*) machine=m68k-atari ;;
|
atari*) machine=m68k-atari ;;
|
||||||
sun3*) machine=m68k-sun ;;
|
sun3*) machine=m68k-sun ;;
|
||||||
@@ -87,16 +146,25 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
|||||||
ibmrt|romp-ibm) machine=romp-ibm ;;
|
ibmrt|romp-ibm) machine=romp-ibm ;;
|
||||||
*) machine=${UNAME_MACHINE}-unknown ;;
|
*) machine=${UNAME_MACHINE}-unknown ;;
|
||||||
esac
|
esac
|
||||||
# The Operating System including object format.
|
# The Operating System including object format, if it has switched
|
||||||
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
# to ELF recently, or will in the future.
|
||||||
| grep __ELF__ >/dev/null
|
case "${UNAME_MACHINE}" in
|
||||||
then
|
i386|sparc|amiga|arm*|hp300|mvme68k|vax|atari|luna68k|mac68k|news68k|next68k|pc532|sun3*|x68k)
|
||||||
# Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
|
eval $set_cc_for_build
|
||||||
# Return netbsd for either. FIX?
|
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
||||||
os=netbsd
|
| grep __ELF__ >/dev/null
|
||||||
else
|
then
|
||||||
os=netbsdelf
|
# Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
|
||||||
fi
|
# Return netbsd for either. FIX?
|
||||||
|
os=netbsd
|
||||||
|
else
|
||||||
|
os=netbsdelf
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
os=netbsd
|
||||||
|
;;
|
||||||
|
esac
|
||||||
# The OS release
|
# The OS release
|
||||||
release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
|
release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
|
||||||
# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
|
# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
|
||||||
@@ -137,6 +205,7 @@ main:
|
|||||||
jsr \$26,exit
|
jsr \$26,exit
|
||||||
.end main
|
.end main
|
||||||
EOF
|
EOF
|
||||||
|
eval $set_cc_for_build
|
||||||
$CC_FOR_BUILD $dummy.s -o $dummy 2>/dev/null
|
$CC_FOR_BUILD $dummy.s -o $dummy 2>/dev/null
|
||||||
if test "$?" = 0 ; then
|
if test "$?" = 0 ; then
|
||||||
case `./$dummy` in
|
case `./$dummy` in
|
||||||
@@ -158,6 +227,9 @@ EOF
|
|||||||
2-307)
|
2-307)
|
||||||
UNAME_MACHINE="alphaev67"
|
UNAME_MACHINE="alphaev67"
|
||||||
;;
|
;;
|
||||||
|
2-1307)
|
||||||
|
UNAME_MACHINE="alphaev68"
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
rm -f $dummy.s $dummy
|
rm -f $dummy.s $dummy
|
||||||
@@ -173,7 +245,7 @@ EOF
|
|||||||
echo alpha-dec-winnt3.5
|
echo alpha-dec-winnt3.5
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
Amiga*:UNIX_System_V:4.0:*)
|
Amiga*:UNIX_System_V:4.0:*)
|
||||||
echo m68k-cbm-sysv4
|
echo m68k-unknown-sysv4
|
||||||
exit 0;;
|
exit 0;;
|
||||||
amiga:OpenBSD:*:*)
|
amiga:OpenBSD:*:*)
|
||||||
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
||||||
@@ -205,7 +277,7 @@ EOF
|
|||||||
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
|
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
|
||||||
echo arm-acorn-riscix${UNAME_RELEASE}
|
echo arm-acorn-riscix${UNAME_RELEASE}
|
||||||
exit 0;;
|
exit 0;;
|
||||||
SR2?01:HI-UX/MPP:*:*)
|
SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
|
||||||
echo hppa1.1-hitachi-hiuxmpp
|
echo hppa1.1-hitachi-hiuxmpp
|
||||||
exit 0;;
|
exit 0;;
|
||||||
Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
|
Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
|
||||||
@@ -261,6 +333,9 @@ EOF
|
|||||||
aushp:SunOS:*:*)
|
aushp:SunOS:*:*)
|
||||||
echo sparc-auspex-sunos${UNAME_RELEASE}
|
echo sparc-auspex-sunos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
sparc*:NetBSD:*)
|
||||||
|
echo `uname -p`-unknown-netbsd${UNAME_RELEASE}
|
||||||
|
exit 0 ;;
|
||||||
atari*:OpenBSD:*:*)
|
atari*:OpenBSD:*:*)
|
||||||
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -318,6 +393,7 @@ EOF
|
|||||||
echo clipper-intergraph-clix${UNAME_RELEASE}
|
echo clipper-intergraph-clix${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
mips:*:*:UMIPS | mips:*:*:RISCos)
|
mips:*:*:UMIPS | mips:*:*:RISCos)
|
||||||
|
eval $set_cc_for_build
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
#include <stdio.h> /* for printf() prototype */
|
#include <stdio.h> /* for printf() prototype */
|
||||||
@@ -341,10 +417,13 @@ EOF
|
|||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy \
|
$CC_FOR_BUILD $dummy.c -o $dummy \
|
||||||
&& ./$dummy `echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` \
|
&& ./$dummy `echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` \
|
||||||
&& rm $dummy.c $dummy && exit 0
|
&& rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo mips-mips-riscos${UNAME_RELEASE}
|
echo mips-mips-riscos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
Motorola:PowerMAX_OS:*:*)
|
||||||
|
echo powerpc-motorola-powermax
|
||||||
|
exit 0 ;;
|
||||||
Night_Hawk:Power_UNIX:*:*)
|
Night_Hawk:Power_UNIX:*:*)
|
||||||
echo powerpc-harris-powerunix
|
echo powerpc-harris-powerunix
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -392,11 +471,20 @@ EOF
|
|||||||
????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
|
????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
|
||||||
echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
|
echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
|
||||||
exit 0 ;; # Note that: echo "'`uname -s`'" gives 'AIX '
|
exit 0 ;; # Note that: echo "'`uname -s`'" gives 'AIX '
|
||||||
i?86:AIX:*:*)
|
i*86:AIX:*:*)
|
||||||
echo i386-ibm-aix
|
echo i386-ibm-aix
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
ia64:AIX:*:*)
|
||||||
|
if [ -x /usr/bin/oslevel ] ; then
|
||||||
|
IBM_REV=`/usr/bin/oslevel`
|
||||||
|
else
|
||||||
|
IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
|
||||||
|
fi
|
||||||
|
echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
|
||||||
|
exit 0 ;;
|
||||||
*:AIX:2:3)
|
*:AIX:2:3)
|
||||||
if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
|
if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
|
||||||
|
eval $set_cc_for_build
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
#include <sys/systemcfg.h>
|
#include <sys/systemcfg.h>
|
||||||
|
|
||||||
@@ -408,7 +496,7 @@ EOF
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo rs6000-ibm-aix3.2.5
|
echo rs6000-ibm-aix3.2.5
|
||||||
elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
|
elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
|
||||||
@@ -417,9 +505,9 @@ EOF
|
|||||||
echo rs6000-ibm-aix3.2
|
echo rs6000-ibm-aix3.2
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
*:AIX:*:4)
|
*:AIX:*:[45])
|
||||||
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | head -1 | awk '{ print $1 }'`
|
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | head -1 | awk '{ print $1 }'`
|
||||||
if /usr/sbin/lsattr -EHl ${IBM_CPU_ID} | grep POWER >/dev/null 2>&1; then
|
if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
|
||||||
IBM_ARCH=rs6000
|
IBM_ARCH=rs6000
|
||||||
else
|
else
|
||||||
IBM_ARCH=powerpc
|
IBM_ARCH=powerpc
|
||||||
@@ -427,7 +515,7 @@ EOF
|
|||||||
if [ -x /usr/bin/oslevel ] ; then
|
if [ -x /usr/bin/oslevel ] ; then
|
||||||
IBM_REV=`/usr/bin/oslevel`
|
IBM_REV=`/usr/bin/oslevel`
|
||||||
else
|
else
|
||||||
IBM_REV=4.${UNAME_RELEASE}
|
IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
|
||||||
fi
|
fi
|
||||||
echo ${IBM_ARCH}-ibm-aix${IBM_REV}
|
echo ${IBM_ARCH}-ibm-aix${IBM_REV}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -453,10 +541,29 @@ EOF
|
|||||||
echo m68k-hp-bsd4.4
|
echo m68k-hp-bsd4.4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
9000/[34678]??:HP-UX:*:*)
|
9000/[34678]??:HP-UX:*:*)
|
||||||
|
HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
9000/31? ) HP_ARCH=m68000 ;;
|
9000/31? ) HP_ARCH=m68000 ;;
|
||||||
9000/[34]?? ) HP_ARCH=m68k ;;
|
9000/[34]?? ) HP_ARCH=m68k ;;
|
||||||
9000/[678][0-9][0-9])
|
9000/[678][0-9][0-9])
|
||||||
|
case "${HPUX_REV}" in
|
||||||
|
11.[0-9][0-9])
|
||||||
|
if [ -x /usr/bin/getconf ]; then
|
||||||
|
sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
|
||||||
|
sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
|
||||||
|
case "${sc_cpu_version}" in
|
||||||
|
523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
|
||||||
|
528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
|
||||||
|
532) # CPU_PA_RISC2_0
|
||||||
|
case "${sc_kernel_bits}" in
|
||||||
|
32) HP_ARCH="hppa2.0n" ;;
|
||||||
|
64) HP_ARCH="hppa2.0w" ;;
|
||||||
|
esac ;;
|
||||||
|
esac
|
||||||
|
fi ;;
|
||||||
|
esac
|
||||||
|
if [ "${HP_ARCH}" = "" ]; then
|
||||||
|
eval $set_cc_for_build
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
|
|
||||||
#define _HPUX_SOURCE
|
#define _HPUX_SOURCE
|
||||||
@@ -490,13 +597,19 @@ EOF
|
|||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
(CCOPTS= $CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null ) && HP_ARCH=`./$dummy`
|
(CCOPTS= $CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null ) && HP_ARCH=`./$dummy`
|
||||||
rm -f $dummy.c $dummy
|
if test -z "$HP_ARCH"; then HP_ARCH=hppa; fi
|
||||||
|
rm -f $dummy.c $dummy
|
||||||
|
fi ;;
|
||||||
esac
|
esac
|
||||||
HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
|
|
||||||
echo ${HP_ARCH}-hp-hpux${HPUX_REV}
|
echo ${HP_ARCH}-hp-hpux${HPUX_REV}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
ia64:HP-UX:*:*)
|
||||||
|
HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
|
||||||
|
echo ia64-hp-hpux${HPUX_REV}
|
||||||
|
exit 0 ;;
|
||||||
3050*:HI-UX:*:*)
|
3050*:HI-UX:*:*)
|
||||||
|
eval $set_cc_for_build
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
int
|
int
|
||||||
@@ -522,7 +635,7 @@ EOF
|
|||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo unknown-hitachi-hiuxwe2
|
echo unknown-hitachi-hiuxwe2
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -532,7 +645,7 @@ EOF
|
|||||||
9000/8??:4.3bsd:*:*)
|
9000/8??:4.3bsd:*:*)
|
||||||
echo hppa1.0-hp-bsd
|
echo hppa1.0-hp-bsd
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
*9??*:MPE/iX:*:*)
|
*9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
|
||||||
echo hppa1.0-hp-mpeix
|
echo hppa1.0-hp-mpeix
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
|
hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
|
||||||
@@ -541,7 +654,7 @@ EOF
|
|||||||
hp8??:OSF1:*:*)
|
hp8??:OSF1:*:*)
|
||||||
echo hppa1.0-hp-osf
|
echo hppa1.0-hp-osf
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:OSF1:*:*)
|
i*86:OSF1:*:*)
|
||||||
if [ -x /usr/sbin/sysversion ] ; then
|
if [ -x /usr/sbin/sysversion ] ; then
|
||||||
echo ${UNAME_MACHINE}-unknown-osf1mk
|
echo ${UNAME_MACHINE}-unknown-osf1mk
|
||||||
else
|
else
|
||||||
@@ -576,37 +689,39 @@ EOF
|
|||||||
echo xmp-cray-unicos
|
echo xmp-cray-unicos
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY*Y-MP:*:*:*)
|
CRAY*Y-MP:*:*:*)
|
||||||
echo ymp-cray-unicos${UNAME_RELEASE}
|
echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY*[A-Z]90:*:*:*)
|
CRAY*[A-Z]90:*:*:*)
|
||||||
echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
|
echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
|
||||||
| sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
|
| sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
|
||||||
-e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
|
-e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
|
||||||
|
-e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY*TS:*:*:*)
|
CRAY*TS:*:*:*)
|
||||||
echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY*T3E:*:*:*)
|
CRAY*T3D:*:*:*)
|
||||||
echo alpha-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
echo alpha-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
CRAY*T3E:*:*:*)
|
||||||
|
echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
|
exit 0 ;;
|
||||||
CRAY*SV1:*:*:*)
|
CRAY*SV1:*:*:*)
|
||||||
echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY-2:*:*:*)
|
CRAY-2:*:*:*)
|
||||||
echo cray2-cray-unicos
|
echo cray2-cray-unicos
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
F300:UNIX_System_V:*:*)
|
F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
|
||||||
|
FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
||||||
FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
|
FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
|
||||||
FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
|
FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
|
||||||
echo "f300-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
|
echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
F301:UNIX_System_V:*:*)
|
|
||||||
echo f301-fujitsu-uxpv`echo $UNAME_RELEASE | sed 's/ .*//'`
|
|
||||||
exit 0 ;;
|
|
||||||
hp300:OpenBSD:*:*)
|
hp300:OpenBSD:*:*)
|
||||||
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:BSD/386:*:* | i?86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
|
i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
sparc*:BSD/OS:*:*)
|
sparc*:BSD/OS:*:*)
|
||||||
@@ -627,6 +742,9 @@ EOF
|
|||||||
i*:MINGW*:*)
|
i*:MINGW*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-mingw32
|
echo ${UNAME_MACHINE}-pc-mingw32
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
i*:PW*:*)
|
||||||
|
echo ${UNAME_MACHINE}-pc-pw32
|
||||||
|
exit 0 ;;
|
||||||
i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
|
i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
|
||||||
# How do we know it's Interix rather than the generic POSIX subsystem?
|
# How do we know it's Interix rather than the generic POSIX subsystem?
|
||||||
# It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
|
# It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
|
||||||
@@ -645,187 +763,96 @@ EOF
|
|||||||
*:GNU:*:*)
|
*:GNU:*:*)
|
||||||
echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
|
echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
*:Linux:*:*)
|
i*86:Minix:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-pc-minix
|
||||||
|
exit 0 ;;
|
||||||
|
arm*:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
ia64:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-linux
|
||||||
|
exit 0 ;;
|
||||||
|
m68*:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
mips:Linux:*:*)
|
||||||
|
case `sed -n '/^byte/s/^.*: \(.*\) endian/\1/p' < /proc/cpuinfo` in
|
||||||
|
big) echo mips-unknown-linux-gnu && exit 0 ;;
|
||||||
|
little) echo mipsel-unknown-linux-gnu && exit 0 ;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
ppc:Linux:*:*)
|
||||||
|
echo powerpc-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
ppc64:Linux:*:*)
|
||||||
|
echo powerpc64-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
alpha:Linux:*:*)
|
||||||
|
case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
|
||||||
|
EV5) UNAME_MACHINE=alphaev5 ;;
|
||||||
|
EV56) UNAME_MACHINE=alphaev56 ;;
|
||||||
|
PCA56) UNAME_MACHINE=alphapca56 ;;
|
||||||
|
PCA57) UNAME_MACHINE=alphapca56 ;;
|
||||||
|
EV6) UNAME_MACHINE=alphaev6 ;;
|
||||||
|
EV67) UNAME_MACHINE=alphaev67 ;;
|
||||||
|
EV68*) UNAME_MACHINE=alphaev68 ;;
|
||||||
|
esac
|
||||||
|
objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null
|
||||||
|
if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi
|
||||||
|
echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
|
||||||
|
exit 0 ;;
|
||||||
|
parisc:Linux:*:* | hppa:Linux:*:*)
|
||||||
|
# Look for CPU level
|
||||||
|
case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
|
||||||
|
PA7*) echo hppa1.1-unknown-linux-gnu ;;
|
||||||
|
PA8*) echo hppa2.0-unknown-linux-gnu ;;
|
||||||
|
*) echo hppa-unknown-linux-gnu ;;
|
||||||
|
esac
|
||||||
|
exit 0 ;;
|
||||||
|
parisc64:Linux:*:* | hppa64:Linux:*:*)
|
||||||
|
echo hppa64-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
s390:Linux:*:* | s390x:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-ibm-linux
|
||||||
|
exit 0 ;;
|
||||||
|
sh*:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
sparc:Linux:*:* | sparc64:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
x86_64:Linux:*:*)
|
||||||
|
echo x86_64-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
i*86:Linux:*:*)
|
||||||
# The BFD linker knows what the default object file format is, so
|
# The BFD linker knows what the default object file format is, so
|
||||||
# first see if it will tell us. cd to the root directory to prevent
|
# first see if it will tell us. cd to the root directory to prevent
|
||||||
# problems with other programs or directories called `ld' in the path.
|
# problems with other programs or directories called `ld' in the path.
|
||||||
ld_help_string=`cd /; ld --help 2>&1`
|
ld_supported_targets=`cd /; ld --help 2>&1 \
|
||||||
ld_supported_emulations=`echo $ld_help_string \
|
| sed -ne '/supported targets:/!d
|
||||||
| sed -ne '/supported emulations:/!d
|
|
||||||
s/[ ][ ]*/ /g
|
s/[ ][ ]*/ /g
|
||||||
s/.*supported emulations: *//
|
s/.*supported targets: *//
|
||||||
s/ .*//
|
s/ .*//
|
||||||
p'`
|
p'`
|
||||||
case "$ld_supported_emulations" in
|
case "$ld_supported_targets" in
|
||||||
*ia64)
|
elf32-i386)
|
||||||
echo "${UNAME_MACHINE}-unknown-linux"
|
TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
|
||||||
exit 0
|
|
||||||
;;
|
;;
|
||||||
i?86linux)
|
a.out-i386-linux)
|
||||||
echo "${UNAME_MACHINE}-pc-linux-gnuaout"
|
echo "${UNAME_MACHINE}-pc-linux-gnuaout"
|
||||||
exit 0
|
exit 0 ;;
|
||||||
;;
|
coff-i386)
|
||||||
elf_i?86)
|
|
||||||
echo "${UNAME_MACHINE}-pc-linux"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
i?86coff)
|
|
||||||
echo "${UNAME_MACHINE}-pc-linux-gnucoff"
|
echo "${UNAME_MACHINE}-pc-linux-gnucoff"
|
||||||
exit 0
|
exit 0 ;;
|
||||||
;;
|
"")
|
||||||
sparclinux)
|
# Either a pre-BFD a.out linker (linux-gnuoldld) or
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuaout"
|
# one that does not give us useful --help.
|
||||||
exit 0
|
echo "${UNAME_MACHINE}-pc-linux-gnuoldld"
|
||||||
;;
|
exit 0 ;;
|
||||||
armlinux)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
elf32arm*)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuoldld"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
armelf_linux*)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnu"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
m68klinux)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
elf32ppc | elf32ppclinux)
|
|
||||||
# Determine Lib Version
|
|
||||||
cat >$dummy.c <<EOF
|
|
||||||
#include <features.h>
|
|
||||||
#if defined(__GLIBC__)
|
|
||||||
extern char __libc_version[];
|
|
||||||
extern char __libc_release[];
|
|
||||||
#endif
|
|
||||||
main(argc, argv)
|
|
||||||
int argc;
|
|
||||||
char *argv[];
|
|
||||||
{
|
|
||||||
#if defined(__GLIBC__)
|
|
||||||
printf("%s %s\n", __libc_version, __libc_release);
|
|
||||||
#else
|
|
||||||
printf("unkown\n");
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
LIBC=""
|
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null
|
|
||||||
if test "$?" = 0 ; then
|
|
||||||
./$dummy | grep 1\.99 > /dev/null
|
|
||||||
if test "$?" = 0 ; then
|
|
||||||
LIBC="libc1"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
rm -f $dummy.c $dummy
|
|
||||||
echo powerpc-unknown-linux-gnu${LIBC}
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
|
# Determine whether the default compiler is a.out or elf
|
||||||
if test "${UNAME_MACHINE}" = "alpha" ; then
|
eval $set_cc_for_build
|
||||||
cat <<EOF >$dummy.s
|
cat >$dummy.c <<EOF
|
||||||
.data
|
|
||||||
\$Lformat:
|
|
||||||
.byte 37,100,45,37,120,10,0 # "%d-%x\n"
|
|
||||||
|
|
||||||
.text
|
|
||||||
.globl main
|
|
||||||
.align 4
|
|
||||||
.ent main
|
|
||||||
main:
|
|
||||||
.frame \$30,16,\$26,0
|
|
||||||
ldgp \$29,0(\$27)
|
|
||||||
.prologue 1
|
|
||||||
.long 0x47e03d80 # implver \$0
|
|
||||||
lda \$2,-1
|
|
||||||
.long 0x47e20c21 # amask \$2,\$1
|
|
||||||
lda \$16,\$Lformat
|
|
||||||
mov \$0,\$17
|
|
||||||
not \$1,\$18
|
|
||||||
jsr \$26,printf
|
|
||||||
ldgp \$29,0(\$26)
|
|
||||||
mov 0,\$16
|
|
||||||
jsr \$26,exit
|
|
||||||
.end main
|
|
||||||
EOF
|
|
||||||
LIBC=""
|
|
||||||
$CC_FOR_BUILD $dummy.s -o $dummy 2>/dev/null
|
|
||||||
if test "$?" = 0 ; then
|
|
||||||
case `./$dummy` in
|
|
||||||
0-0)
|
|
||||||
UNAME_MACHINE="alpha"
|
|
||||||
;;
|
|
||||||
1-0)
|
|
||||||
UNAME_MACHINE="alphaev5"
|
|
||||||
;;
|
|
||||||
1-1)
|
|
||||||
UNAME_MACHINE="alphaev56"
|
|
||||||
;;
|
|
||||||
1-101)
|
|
||||||
UNAME_MACHINE="alphapca56"
|
|
||||||
;;
|
|
||||||
2-303)
|
|
||||||
UNAME_MACHINE="alphaev6"
|
|
||||||
;;
|
|
||||||
2-307)
|
|
||||||
UNAME_MACHINE="alphaev67"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
objdump --private-headers $dummy | \
|
|
||||||
grep ld.so.1 > /dev/null
|
|
||||||
if test "$?" = 0 ; then
|
|
||||||
LIBC="libc1"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
rm -f $dummy.s $dummy
|
|
||||||
echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} ; exit 0
|
|
||||||
elif test "${UNAME_MACHINE}" = "mips" ; then
|
|
||||||
cat >$dummy.c <<EOF
|
|
||||||
#ifdef __cplusplus
|
|
||||||
#include <stdio.h> /* for printf() prototype */
|
|
||||||
int main (int argc, char *argv[]) {
|
|
||||||
#else
|
|
||||||
int main (argc, argv) int argc; char *argv[]; {
|
|
||||||
#endif
|
|
||||||
#ifdef __MIPSEB__
|
|
||||||
printf ("%s-unknown-linux-gnu\n", argv[1]);
|
|
||||||
#endif
|
|
||||||
#ifdef __MIPSEL__
|
|
||||||
printf ("%sel-unknown-linux-gnu\n", argv[1]);
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm $dummy.c $dummy && exit 0
|
|
||||||
rm -f $dummy.c $dummy
|
|
||||||
elif test "${UNAME_MACHINE}" = "s390"; then
|
|
||||||
echo s390-ibm-linux && exit 0
|
|
||||||
else
|
|
||||||
# Either a pre-BFD a.out linker (linux-gnuoldld)
|
|
||||||
# or one that does not give us useful --help.
|
|
||||||
# GCC wants to distinguish between linux-gnuoldld and linux-gnuaout.
|
|
||||||
# If ld does not provide *any* "supported emulations:"
|
|
||||||
# that means it is gnuoldld.
|
|
||||||
echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations:"
|
|
||||||
test $? != 0 && echo "${UNAME_MACHINE}-pc-linux-gnuoldld" && exit 0
|
|
||||||
|
|
||||||
case "${UNAME_MACHINE}" in
|
|
||||||
i?86)
|
|
||||||
VENDOR=pc;
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
VENDOR=unknown;
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
# Determine whether the default compiler is a.out or elf
|
|
||||||
cat >$dummy.c <<EOF
|
|
||||||
#include <features.h>
|
#include <features.h>
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
#include <stdio.h> /* for printf() prototype */
|
#include <stdio.h> /* for printf() prototype */
|
||||||
@@ -836,28 +863,30 @@ EOF
|
|||||||
#ifdef __ELF__
|
#ifdef __ELF__
|
||||||
# ifdef __GLIBC__
|
# ifdef __GLIBC__
|
||||||
# if __GLIBC__ >= 2
|
# if __GLIBC__ >= 2
|
||||||
printf ("%s-${VENDOR}-linux-gnu\n", argv[1]);
|
printf ("%s-pc-linux-gnu\n", argv[1]);
|
||||||
# else
|
# else
|
||||||
printf ("%s-${VENDOR}-linux-gnulibc1\n", argv[1]);
|
printf ("%s-pc-linux-gnulibc1\n", argv[1]);
|
||||||
# endif
|
# endif
|
||||||
# else
|
# else
|
||||||
printf ("%s-${VENDOR}-linux-gnulibc1\n", argv[1]);
|
printf ("%s-pc-linux-gnulibc1\n", argv[1]);
|
||||||
# endif
|
# endif
|
||||||
#else
|
#else
|
||||||
printf ("%s-${VENDOR}-linux-gnuaout\n", argv[1]);
|
printf ("%s-pc-linux-gnuaout\n", argv[1]);
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
fi ;;
|
test x"${TENTATIVE}" != x && echo "${TENTATIVE}" && exit 0
|
||||||
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. earlier versions
|
;;
|
||||||
# are messed up and put the nodename in both sysname and nodename.
|
i*86:DYNIX/ptx:4*:*)
|
||||||
i?86:DYNIX/ptx:4*:*)
|
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
|
||||||
|
# earlier versions are messed up and put the nodename in both
|
||||||
|
# sysname and nodename.
|
||||||
echo i386-sequent-sysv4
|
echo i386-sequent-sysv4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:UNIX_SV:4.2MP:2.*)
|
i*86:UNIX_SV:4.2MP:2.*)
|
||||||
# Unixware is an offshoot of SVR4, but it has its own version
|
# Unixware is an offshoot of SVR4, but it has its own version
|
||||||
# number series starting with 2...
|
# number series starting with 2...
|
||||||
# I am not positive that other SVR4 systems won't match this,
|
# I am not positive that other SVR4 systems won't match this,
|
||||||
@@ -865,7 +894,7 @@ EOF
|
|||||||
# Use sysv4.2uw... so that sysv4* matches it.
|
# Use sysv4.2uw... so that sysv4* matches it.
|
||||||
echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
|
echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*:4.*:* | i?86:SYSTEM_V:4.*:*)
|
i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
|
||||||
UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
|
UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
|
||||||
if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
|
if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
|
||||||
echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
|
echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
|
||||||
@@ -873,16 +902,15 @@ EOF
|
|||||||
echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
|
echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*:5:7*)
|
i*86:*:5:[78]*)
|
||||||
# Fixed at (any) Pentium or better
|
case `/bin/uname -X | grep "^Machine"` in
|
||||||
UNAME_MACHINE=i586
|
*486*) UNAME_MACHINE=i486 ;;
|
||||||
if [ ${UNAME_SYSTEM} = "UnixWare" ] ; then
|
*Pentium) UNAME_MACHINE=i586 ;;
|
||||||
echo ${UNAME_MACHINE}-sco-sysv${UNAME_RELEASE}uw${UNAME_VERSION}
|
*Pent*|*Celeron) UNAME_MACHINE=i686 ;;
|
||||||
else
|
esac
|
||||||
echo ${UNAME_MACHINE}-pc-sysv${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
|
||||||
fi
|
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*:3.2:*)
|
i*86:*:3.2:*)
|
||||||
if test -f /usr/options/cb.name; then
|
if test -f /usr/options/cb.name; then
|
||||||
UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
|
UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
|
||||||
echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
|
echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
|
||||||
@@ -900,7 +928,7 @@ EOF
|
|||||||
echo ${UNAME_MACHINE}-pc-sysv32
|
echo ${UNAME_MACHINE}-pc-sysv32
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*DOS:*:*)
|
i*86:*DOS:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-msdosdjgpp
|
echo ${UNAME_MACHINE}-pc-msdosdjgpp
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
pc:*:*:*)
|
pc:*:*:*)
|
||||||
@@ -928,7 +956,7 @@ EOF
|
|||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
M68*:*:R3V[567]*:*)
|
M68*:*:R3V[567]*:*)
|
||||||
test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;;
|
test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;;
|
||||||
3[34]??:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 4850:*:4.0:3.0)
|
3[34]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 4850:*:4.0:3.0)
|
||||||
OS_REL=''
|
OS_REL=''
|
||||||
test -r /etc/.relid \
|
test -r /etc/.relid \
|
||||||
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
|
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
|
||||||
@@ -939,21 +967,24 @@ EOF
|
|||||||
3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
|
3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
|
||||||
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
|
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
|
||||||
&& echo i486-ncr-sysv4 && exit 0 ;;
|
&& echo i486-ncr-sysv4 && exit 0 ;;
|
||||||
m68*:LynxOS:2.*:*)
|
m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
|
||||||
echo m68k-unknown-lynxos${UNAME_RELEASE}
|
echo m68k-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
mc68030:UNIX_System_V:4.*:*)
|
mc68030:UNIX_System_V:4.*:*)
|
||||||
echo m68k-atari-sysv4
|
echo m68k-atari-sysv4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:LynxOS:2.*:* | i?86:LynxOS:3.[01]*:*)
|
i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*)
|
||||||
echo i386-unknown-lynxos${UNAME_RELEASE}
|
echo i386-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
TSUNAMI:LynxOS:2.*:*)
|
TSUNAMI:LynxOS:2.*:*)
|
||||||
echo sparc-unknown-lynxos${UNAME_RELEASE}
|
echo sparc-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
rs6000:LynxOS:2.*:* | PowerPC:LynxOS:2.*:*)
|
rs6000:LynxOS:2.*:*)
|
||||||
echo rs6000-unknown-lynxos${UNAME_RELEASE}
|
echo rs6000-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*)
|
||||||
|
echo powerpc-unknown-lynxos${UNAME_RELEASE}
|
||||||
|
exit 0 ;;
|
||||||
SM[BE]S:UNIX_SV:*:*)
|
SM[BE]S:UNIX_SV:*:*)
|
||||||
echo mips-dde-sysv${UNAME_RELEASE}
|
echo mips-dde-sysv${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -971,8 +1002,8 @@ EOF
|
|||||||
echo ns32k-sni-sysv
|
echo ns32k-sni-sysv
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
PENTIUM:CPunix:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
|
PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
|
||||||
# says <Richard.M.Bartel@ccMail.Census.GOV>
|
# says <Richard.M.Bartel@ccMail.Census.GOV>
|
||||||
echo i586-unisys-sysv4
|
echo i586-unisys-sysv4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
*:UNIX_System_V:4*:FTX*)
|
*:UNIX_System_V:4*:FTX*)
|
||||||
@@ -984,10 +1015,14 @@ EOF
|
|||||||
# From seanf@swdc.stratus.com.
|
# From seanf@swdc.stratus.com.
|
||||||
echo i860-stratus-sysv4
|
echo i860-stratus-sysv4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
*:VOS:*:*)
|
||||||
|
# From Paul.Green@stratus.com.
|
||||||
|
echo hppa1.1-stratus-vos
|
||||||
|
exit 0 ;;
|
||||||
mc68*:A/UX:*:*)
|
mc68*:A/UX:*:*)
|
||||||
echo m68k-apple-aux${UNAME_RELEASE}
|
echo m68k-apple-aux${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
news*:NEWS-OS:*:6*)
|
news*:NEWS-OS:6*:*)
|
||||||
echo mips-sony-newsos6
|
echo mips-sony-newsos6
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
|
R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
|
||||||
@@ -1030,20 +1065,64 @@ EOF
|
|||||||
*:QNX:*:4*)
|
*:QNX:*:4*)
|
||||||
echo i386-pc-qnx
|
echo i386-pc-qnx
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
NSR-W:NONSTOP_KERNEL:*:*)
|
NSR-[KW]:NONSTOP_KERNEL:*:*)
|
||||||
echo nsr-tandem-nsk${UNAME_RELEASE}
|
echo nsr-tandem-nsk${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
*:NonStop-UX:*:*)
|
||||||
|
echo mips-compaq-nonstopux
|
||||||
|
exit 0 ;;
|
||||||
BS2000:POSIX*:*:*)
|
BS2000:POSIX*:*:*)
|
||||||
echo bs2000-siemens-sysv
|
echo bs2000-siemens-sysv
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
DS/*:UNIX_System_V:*:*)
|
DS/*:UNIX_System_V:*:*)
|
||||||
echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
*:Plan9:*:*)
|
||||||
|
# "uname -m" is not consistent, so use $cputype instead. 386
|
||||||
|
# is converted to i386 for consistency with other x86
|
||||||
|
# operating systems.
|
||||||
|
if test "$cputype" = "386"; then
|
||||||
|
UNAME_MACHINE=i386
|
||||||
|
else
|
||||||
|
UNAME_MACHINE="$cputype"
|
||||||
|
fi
|
||||||
|
echo ${UNAME_MACHINE}-unknown-plan9
|
||||||
|
exit 0 ;;
|
||||||
|
i*86:OS/2:*:*)
|
||||||
|
# If we were able to find `uname', then EMX Unix compatibility
|
||||||
|
# is probably installed.
|
||||||
|
echo ${UNAME_MACHINE}-pc-os2-emx
|
||||||
|
exit 0 ;;
|
||||||
|
*:TOPS-10:*:*)
|
||||||
|
echo pdp10-unknown-tops10
|
||||||
|
exit 0 ;;
|
||||||
|
*:TENEX:*:*)
|
||||||
|
echo pdp10-unknown-tenex
|
||||||
|
exit 0 ;;
|
||||||
|
KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
|
||||||
|
echo pdp10-dec-tops20
|
||||||
|
exit 0 ;;
|
||||||
|
XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
|
||||||
|
echo pdp10-xkl-tops20
|
||||||
|
exit 0 ;;
|
||||||
|
*:TOPS-20:*:*)
|
||||||
|
echo pdp10-unknown-tops20
|
||||||
|
exit 0 ;;
|
||||||
|
*:ITS:*:*)
|
||||||
|
echo pdp10-unknown-its
|
||||||
|
exit 0 ;;
|
||||||
|
i*86:XTS-300:*:STOP)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-stop
|
||||||
|
exit 0 ;;
|
||||||
|
i*86:atheos:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-unknown-atheos
|
||||||
|
exit 0 ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
#echo '(No uname command or uname output not recognized.)' 1>&2
|
#echo '(No uname command or uname output not recognized.)' 1>&2
|
||||||
#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2
|
#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2
|
||||||
|
|
||||||
|
eval $set_cc_for_build
|
||||||
cat >$dummy.c <<EOF
|
cat >$dummy.c <<EOF
|
||||||
#ifdef _SEQUENT_
|
#ifdef _SEQUENT_
|
||||||
# include <sys/types.h>
|
# include <sys/types.h>
|
||||||
@@ -1130,11 +1209,24 @@ main ()
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined (vax)
|
#if defined (vax)
|
||||||
#if !defined (ultrix)
|
# if !defined (ultrix)
|
||||||
printf ("vax-dec-bsd\n"); exit (0);
|
# include <sys/param.h>
|
||||||
#else
|
# if defined (BSD)
|
||||||
printf ("vax-dec-ultrix\n"); exit (0);
|
# if BSD == 43
|
||||||
#endif
|
printf ("vax-dec-bsd4.3\n"); exit (0);
|
||||||
|
# else
|
||||||
|
# if BSD == 199006
|
||||||
|
printf ("vax-dec-bsd4.3reno\n"); exit (0);
|
||||||
|
# else
|
||||||
|
printf ("vax-dec-bsd\n"); exit (0);
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
printf ("vax-dec-bsd\n"); exit (0);
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
printf ("vax-dec-ultrix\n"); exit (0);
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined (alliant) && defined (i860)
|
#if defined (alliant) && defined (i860)
|
||||||
@@ -1145,7 +1237,7 @@ main ()
|
|||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
|
|
||||||
# Apollos put the system type in the environment.
|
# Apollos put the system type in the environment.
|
||||||
@@ -1178,6 +1270,48 @@ then
|
|||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#echo '(Unable to guess system type)' 1>&2
|
cat >&2 <<EOF
|
||||||
|
$0: unable to guess system type
|
||||||
|
|
||||||
|
This script, last modified $timestamp, has failed to recognize
|
||||||
|
the operating system you are using. It is advised that you
|
||||||
|
download the most up to date version of the config scripts from
|
||||||
|
|
||||||
|
ftp://ftp.gnu.org/pub/gnu/config/
|
||||||
|
|
||||||
|
If the version you run ($0) is already up to date, please
|
||||||
|
send the following data and any information you think might be
|
||||||
|
pertinent to <config-patches@gnu.org> in order to provide the needed
|
||||||
|
information to handle your system.
|
||||||
|
|
||||||
|
config.guess timestamp = $timestamp
|
||||||
|
|
||||||
|
uname -m = `(uname -m) 2>/dev/null || echo unknown`
|
||||||
|
uname -r = `(uname -r) 2>/dev/null || echo unknown`
|
||||||
|
uname -s = `(uname -s) 2>/dev/null || echo unknown`
|
||||||
|
uname -v = `(uname -v) 2>/dev/null || echo unknown`
|
||||||
|
|
||||||
|
/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
|
||||||
|
/bin/uname -X = `(/bin/uname -X) 2>/dev/null`
|
||||||
|
|
||||||
|
hostinfo = `(hostinfo) 2>/dev/null`
|
||||||
|
/bin/universe = `(/bin/universe) 2>/dev/null`
|
||||||
|
/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null`
|
||||||
|
/bin/arch = `(/bin/arch) 2>/dev/null`
|
||||||
|
/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
|
||||||
|
/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
|
||||||
|
|
||||||
|
UNAME_MACHINE = ${UNAME_MACHINE}
|
||||||
|
UNAME_RELEASE = ${UNAME_RELEASE}
|
||||||
|
UNAME_SYSTEM = ${UNAME_SYSTEM}
|
||||||
|
UNAME_VERSION = ${UNAME_VERSION}
|
||||||
|
EOF
|
||||||
|
|
||||||
exit 1
|
exit 1
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "timestamp='"
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d"
|
||||||
|
# time-stamp-end: "'"
|
||||||
|
# End:
|
||||||
|
|||||||
329
config.sub
vendored
329
config.sub
vendored
@@ -1,8 +1,10 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Configuration validation subroutine script, version 1.1.
|
# Configuration validation subroutine script.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
# Free Software Foundation, Inc.
|
# Free Software Foundation, Inc.
|
||||||
#
|
|
||||||
|
timestamp='2001-09-07'
|
||||||
|
|
||||||
# This file is (in principle) common to ALL GNU software.
|
# This file is (in principle) common to ALL GNU software.
|
||||||
# The presence of a machine in this file suggests that SOME GNU software
|
# The presence of a machine in this file suggests that SOME GNU software
|
||||||
# can handle that machine. It does not imply ALL GNU software can.
|
# can handle that machine. It does not imply ALL GNU software can.
|
||||||
@@ -27,7 +29,6 @@
|
|||||||
# configuration script generated by Autoconf, you may include it under
|
# configuration script generated by Autoconf, you may include it under
|
||||||
# the same distribution terms that you use for the rest of that program.
|
# the same distribution terms that you use for the rest of that program.
|
||||||
|
|
||||||
# Written by Per Bothner <bothner@cygnus.com>.
|
|
||||||
# Please send patches to <config-patches@gnu.org>.
|
# Please send patches to <config-patches@gnu.org>.
|
||||||
#
|
#
|
||||||
# Configuration subroutine to validate and canonicalize a configuration type.
|
# Configuration subroutine to validate and canonicalize a configuration type.
|
||||||
@@ -50,30 +51,73 @@
|
|||||||
# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
|
# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
|
||||||
# It is wrong to echo any other type of specification.
|
# It is wrong to echo any other type of specification.
|
||||||
|
|
||||||
if [ x$1 = x ]
|
me=`echo "$0" | sed -e 's,.*/,,'`
|
||||||
then
|
|
||||||
echo Configuration name missing. 1>&2
|
|
||||||
echo "Usage: $0 CPU-MFR-OPSYS" 1>&2
|
|
||||||
echo "or $0 ALIAS" 1>&2
|
|
||||||
echo where ALIAS is a recognized configuration type. 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# First pass through any local machine types.
|
usage="\
|
||||||
case $1 in
|
Usage: $0 [OPTION] CPU-MFR-OPSYS
|
||||||
*local*)
|
$0 [OPTION] ALIAS
|
||||||
echo $1
|
|
||||||
exit 0
|
Canonicalize a configuration name.
|
||||||
;;
|
|
||||||
*)
|
Operation modes:
|
||||||
;;
|
-h, --help print this help, then exit
|
||||||
|
-t, --time-stamp print date of last modification, then exit
|
||||||
|
-v, --version print version number, then exit
|
||||||
|
|
||||||
|
Report bugs and patches to <config-patches@gnu.org>."
|
||||||
|
|
||||||
|
version="\
|
||||||
|
GNU config.sub ($timestamp)
|
||||||
|
|
||||||
|
Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
|
Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This is free software; see the source for copying conditions. There is NO
|
||||||
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
|
||||||
|
help="
|
||||||
|
Try \`$me --help' for more information."
|
||||||
|
|
||||||
|
# Parse command line
|
||||||
|
while test $# -gt 0 ; do
|
||||||
|
case $1 in
|
||||||
|
--time-stamp | --time* | -t )
|
||||||
|
echo "$timestamp" ; exit 0 ;;
|
||||||
|
--version | -v )
|
||||||
|
echo "$version" ; exit 0 ;;
|
||||||
|
--help | --h* | -h )
|
||||||
|
echo "$usage"; exit 0 ;;
|
||||||
|
-- ) # Stop option processing
|
||||||
|
shift; break ;;
|
||||||
|
- ) # Use stdin as input.
|
||||||
|
break ;;
|
||||||
|
-* )
|
||||||
|
echo "$me: invalid option $1$help"
|
||||||
|
exit 1 ;;
|
||||||
|
|
||||||
|
*local*)
|
||||||
|
# First pass through any local machine types.
|
||||||
|
echo $1
|
||||||
|
exit 0;;
|
||||||
|
|
||||||
|
* )
|
||||||
|
break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
case $# in
|
||||||
|
0) echo "$me: missing argument$help" >&2
|
||||||
|
exit 1;;
|
||||||
|
1) ;;
|
||||||
|
*) echo "$me: too many arguments$help" >&2
|
||||||
|
exit 1;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
|
# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
|
||||||
# Here we must recognize all the valid KERNEL-OS combinations.
|
# Here we must recognize all the valid KERNEL-OS combinations.
|
||||||
maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
|
maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
|
||||||
case $maybe_os in
|
case $maybe_os in
|
||||||
nto-qnx* | linux-gnu*)
|
nto-qnx* | linux-gnu* | storm-chaos* | os2-emx* | windows32-*)
|
||||||
os=-$maybe_os
|
os=-$maybe_os
|
||||||
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
|
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
|
||||||
;;
|
;;
|
||||||
@@ -99,7 +143,7 @@ case $os in
|
|||||||
-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
|
-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
|
||||||
-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
|
-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
|
||||||
-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
|
-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
|
||||||
-apple)
|
-apple | -axis)
|
||||||
os=
|
os=
|
||||||
basic_machine=$1
|
basic_machine=$1
|
||||||
;;
|
;;
|
||||||
@@ -113,6 +157,14 @@ case $os in
|
|||||||
os=-vxworks
|
os=-vxworks
|
||||||
basic_machine=$1
|
basic_machine=$1
|
||||||
;;
|
;;
|
||||||
|
-chorusos*)
|
||||||
|
os=-chorusos
|
||||||
|
basic_machine=$1
|
||||||
|
;;
|
||||||
|
-chorusrdb)
|
||||||
|
os=-chorusrdb
|
||||||
|
basic_machine=$1
|
||||||
|
;;
|
||||||
-hiux*)
|
-hiux*)
|
||||||
os=-hiuxwe2
|
os=-hiuxwe2
|
||||||
;;
|
;;
|
||||||
@@ -171,30 +223,50 @@ esac
|
|||||||
case $basic_machine in
|
case $basic_machine in
|
||||||
# Recognize the basic CPU types without company name.
|
# Recognize the basic CPU types without company name.
|
||||||
# Some are omitted here because they have special meanings below.
|
# Some are omitted here because they have special meanings below.
|
||||||
tahoe | i860 | ia64 | m32r | m68k | m68000 | m88k | ns32k | arc | arm \
|
1750a | 580 \
|
||||||
| arme[lb] | pyramid | mn10200 | mn10300 | tron | a29k \
|
| a29k \
|
||||||
| 580 | i960 | h8300 \
|
| alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
|
||||||
| x86 | ppcbe | mipsbe | mipsle | shbe | shle | armbe | armle \
|
| arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr \
|
||||||
| hppa | hppa1.0 | hppa1.1 | hppa2.0 | hppa2.0w | hppa2.0n \
|
| c4x | clipper \
|
||||||
| hppa64 \
|
| d10v | d30v | dsp16xx \
|
||||||
| alpha | alphaev[4-8] | alphaev56 | alphapca5[67] \
|
| fr30 \
|
||||||
| alphaev6[78] \
|
| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
|
||||||
| we32k | ns16k | clipper | i370 | sh | powerpc | powerpcle \
|
| i370 | i860 | i960 | ia64 \
|
||||||
| 1750a | dsp16xx | pdp11 | mips16 | mips64 | mipsel | mips64el \
|
| m32r | m68000 | m68k | m88k | mcore \
|
||||||
| mips64orion | mips64orionel | mipstx39 | mipstx39el \
|
| mips16 | mips64 | mips64el | mips64orion | mips64orionel \
|
||||||
| mips64vr4300 | mips64vr4300el | mips64vr4100 | mips64vr4100el \
|
| mips64vr4100 | mips64vr4100el | mips64vr4300 \
|
||||||
| mips64vr5000 | miprs64vr5000el | mcore \
|
| mips64vr4300el | mips64vr5000 | mips64vr5000el \
|
||||||
| sparc | sparclet | sparclite | sparc64 | sparcv9 | v850 | c4x \
|
| mipsbe | mipseb | mipsel | mipsle | mipstx39 | mipstx39el \
|
||||||
| thumb | d10v | fr30 | avr)
|
| mipsisa32 \
|
||||||
|
| mn10200 | mn10300 \
|
||||||
|
| ns16k | ns32k \
|
||||||
|
| openrisc \
|
||||||
|
| pdp10 | pdp11 | pj | pjl \
|
||||||
|
| powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \
|
||||||
|
| pyramid \
|
||||||
|
| s390 | s390x \
|
||||||
|
| sh | sh[34] | sh[34]eb | shbe | shle \
|
||||||
|
| sparc | sparc64 | sparclet | sparclite | sparcv9 | sparcv9b \
|
||||||
|
| stormy16 | strongarm \
|
||||||
|
| tahoe | thumb | tic80 | tron \
|
||||||
|
| v850 \
|
||||||
|
| we32k \
|
||||||
|
| x86 | xscale \
|
||||||
|
| z8k)
|
||||||
basic_machine=$basic_machine-unknown
|
basic_machine=$basic_machine-unknown
|
||||||
;;
|
;;
|
||||||
m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | z8k | v70 | h8500 | w65 | pj | pjl)
|
m6811 | m68hc11 | m6812 | m68hc12)
|
||||||
|
# Motorola 68HC11/12.
|
||||||
|
basic_machine=$basic_machine-unknown
|
||||||
|
os=-none
|
||||||
|
;;
|
||||||
|
m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
|
||||||
;;
|
;;
|
||||||
|
|
||||||
# We use `pc' rather than `unknown'
|
# We use `pc' rather than `unknown'
|
||||||
# because (1) that's what they normally are, and
|
# because (1) that's what they normally are, and
|
||||||
# (2) the word "unknown" tends to confuse beginning users.
|
# (2) the word "unknown" tends to confuse beginning users.
|
||||||
i[34567]86)
|
i*86 | x86_64)
|
||||||
basic_machine=$basic_machine-pc
|
basic_machine=$basic_machine-pc
|
||||||
;;
|
;;
|
||||||
# Object if more than one company name word.
|
# Object if more than one company name word.
|
||||||
@@ -203,28 +275,43 @@ case $basic_machine in
|
|||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
# Recognize the basic CPU types with company name.
|
# Recognize the basic CPU types with company name.
|
||||||
# FIXME: clean up the formatting here.
|
580-* \
|
||||||
vax-* | tahoe-* | i[34567]86-* | i860-* | ia64-* | m32r-* | m68k-* | m68000-* \
|
| a29k-* \
|
||||||
| m88k-* | sparc-* | ns32k-* | fx80-* | arc-* | arm-* | c[123]* \
|
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
|
||||||
| mips-* | pyramid-* | tron-* | a29k-* | romp-* | rs6000-* \
|
| alphapca5[67]-* | arc-* \
|
||||||
| power-* | none-* | 580-* | cray2-* | h8300-* | h8500-* | i960-* \
|
| arm-* | armbe-* | armle-* | armv*-* \
|
||||||
| xmp-* | ymp-* \
|
| bs2000-* \
|
||||||
| x86-* | ppcbe-* | mipsbe-* | mipsle-* | shbe-* | shle-* | armbe-* | armle-* \
|
| c[123]* | c30-* | [cjt]90-* | c54x-* \
|
||||||
| hppa-* | hppa1.0-* | hppa1.1-* | hppa2.0-* | hppa2.0w-* \
|
| clipper-* | cray2-* | cydra-* \
|
||||||
| hppa2.0n-* | hppa64-* \
|
| d10v-* | d30v-* \
|
||||||
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphapca5[67]-* \
|
| elxsi-* \
|
||||||
| alphaev6[78]-* \
|
| f30[01]-* | f700-* | fr30-* | fx80-* \
|
||||||
| we32k-* | cydra-* | ns16k-* | pn-* | np1-* | xps100-* \
|
| h8300-* | h8500-* \
|
||||||
| clipper-* | orion-* \
|
| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
|
||||||
| sparclite-* | pdp11-* | sh-* | powerpc-* | powerpcle-* \
|
| i*86-* | i860-* | i960-* | ia64-* \
|
||||||
| sparc64-* | sparcv9-* | sparc86x-* | mips16-* | mips64-* | mipsel-* \
|
| m32r-* \
|
||||||
| mips64el-* | mips64orion-* | mips64orionel-* \
|
| m68000-* | m680[01234]0-* | m68360-* | m683?2-* | m68k-* \
|
||||||
| mips64vr4100-* | mips64vr4100el-* | mips64vr4300-* | mips64vr4300el-* \
|
| m88110-* | m88k-* | mcore-* \
|
||||||
| mipstx39-* | mipstx39el-* | mcore-* \
|
| mips-* | mips16-* | mips64-* | mips64el-* | mips64orion-* \
|
||||||
| f301-* | armv*-* | s390-* | sv1-* | t3e-* \
|
| mips64orionel-* | mips64vr4100-* | mips64vr4100el-* \
|
||||||
| m88110-* | m680[01234]0-* | m683?2-* | m68360-* | z8k-* | d10v-* \
|
| mips64vr4300-* | mips64vr4300el-* | mipsbe-* | mipseb-* \
|
||||||
| thumb-* | v850-* | d30v-* | tic30-* | c30-* | fr30-* \
|
| mipsle-* | mipsel-* | mipstx39-* | mipstx39el-* \
|
||||||
| bs2000-*)
|
| none-* | np1-* | ns16k-* | ns32k-* \
|
||||||
|
| orion-* \
|
||||||
|
| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
|
||||||
|
| powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \
|
||||||
|
| pyramid-* \
|
||||||
|
| romp-* | rs6000-* \
|
||||||
|
| s390-* | s390x-* \
|
||||||
|
| sh-* | sh[34]-* | sh[34]eb-* | shbe-* | shle-* \
|
||||||
|
| sparc-* | sparc64-* | sparc86x-* | sparclite-* \
|
||||||
|
| sparcv9-* | sparcv9b-* | stormy16-* | strongarm-* | sv1-* \
|
||||||
|
| t3e-* | tahoe-* | thumb-* | tic30-* | tic54x-* | tic80-* | tron-* \
|
||||||
|
| v850-* | vax-* \
|
||||||
|
| we32k-* \
|
||||||
|
| x86-* | x86_64-* | xmp-* | xps100-* | xscale-* \
|
||||||
|
| ymp-* \
|
||||||
|
| z8k-*)
|
||||||
;;
|
;;
|
||||||
# Recognize the various machine names and aliases which stand
|
# Recognize the various machine names and aliases which stand
|
||||||
# for a CPU type and a company and sometimes even an OS.
|
# for a CPU type and a company and sometimes even an OS.
|
||||||
@@ -261,14 +348,14 @@ case $basic_machine in
|
|||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
amiga | amiga-*)
|
amiga | amiga-*)
|
||||||
basic_machine=m68k-cbm
|
basic_machine=m68k-unknown
|
||||||
;;
|
;;
|
||||||
amigaos | amigados)
|
amigaos | amigados)
|
||||||
basic_machine=m68k-cbm
|
basic_machine=m68k-unknown
|
||||||
os=-amigaos
|
os=-amigaos
|
||||||
;;
|
;;
|
||||||
amigaunix | amix)
|
amigaunix | amix)
|
||||||
basic_machine=m68k-cbm
|
basic_machine=m68k-unknown
|
||||||
os=-sysv4
|
os=-sysv4
|
||||||
;;
|
;;
|
||||||
apollo68)
|
apollo68)
|
||||||
@@ -315,13 +402,16 @@ case $basic_machine in
|
|||||||
basic_machine=cray2-cray
|
basic_machine=cray2-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
[ctj]90-cray)
|
[cjt]90)
|
||||||
basic_machine=c90-cray
|
basic_machine=${basic_machine}-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
crds | unos)
|
crds | unos)
|
||||||
basic_machine=m68k-crds
|
basic_machine=m68k-crds
|
||||||
;;
|
;;
|
||||||
|
cris | cris-* | etrax*)
|
||||||
|
basic_machine=cris-axis
|
||||||
|
;;
|
||||||
da30 | da30-*)
|
da30 | da30-*)
|
||||||
basic_machine=m68k-da30
|
basic_machine=m68k-da30
|
||||||
;;
|
;;
|
||||||
@@ -369,6 +459,10 @@ case $basic_machine in
|
|||||||
basic_machine=tron-gmicro
|
basic_machine=tron-gmicro
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
|
go32)
|
||||||
|
basic_machine=i386-pc
|
||||||
|
os=-go32
|
||||||
|
;;
|
||||||
h3050r* | hiux*)
|
h3050r* | hiux*)
|
||||||
basic_machine=hppa1.1-hitachi
|
basic_machine=hppa1.1-hitachi
|
||||||
os=-hiuxwe2
|
os=-hiuxwe2
|
||||||
@@ -444,19 +538,19 @@ case $basic_machine in
|
|||||||
basic_machine=i370-ibm
|
basic_machine=i370-ibm
|
||||||
;;
|
;;
|
||||||
# I'm not sure what "Sysv32" means. Should this be sysv3.2?
|
# I'm not sure what "Sysv32" means. Should this be sysv3.2?
|
||||||
i[34567]86v32)
|
i*86v32)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv32
|
os=-sysv32
|
||||||
;;
|
;;
|
||||||
i[34567]86v4*)
|
i*86v4*)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv4
|
os=-sysv4
|
||||||
;;
|
;;
|
||||||
i[34567]86v)
|
i*86v)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
i[34567]86sol2)
|
i*86sol2)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-solaris2
|
os=-solaris2
|
||||||
;;
|
;;
|
||||||
@@ -468,14 +562,6 @@ case $basic_machine in
|
|||||||
basic_machine=i386-unknown
|
basic_machine=i386-unknown
|
||||||
os=-vsta
|
os=-vsta
|
||||||
;;
|
;;
|
||||||
i386-go32 | go32)
|
|
||||||
basic_machine=i386-unknown
|
|
||||||
os=-go32
|
|
||||||
;;
|
|
||||||
i386-mingw32 | mingw32)
|
|
||||||
basic_machine=i386-unknown
|
|
||||||
os=-mingw32
|
|
||||||
;;
|
|
||||||
iris | iris4d)
|
iris | iris4d)
|
||||||
basic_machine=mips-sgi
|
basic_machine=mips-sgi
|
||||||
case $os in
|
case $os in
|
||||||
@@ -501,6 +587,10 @@ case $basic_machine in
|
|||||||
basic_machine=ns32k-utek
|
basic_machine=ns32k-utek
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
|
mingw32)
|
||||||
|
basic_machine=i386-pc
|
||||||
|
os=-mingw32
|
||||||
|
;;
|
||||||
miniframe)
|
miniframe)
|
||||||
basic_machine=m68000-convergent
|
basic_machine=m68000-convergent
|
||||||
;;
|
;;
|
||||||
@@ -531,7 +621,7 @@ case $basic_machine in
|
|||||||
os=-coff
|
os=-coff
|
||||||
;;
|
;;
|
||||||
msdos)
|
msdos)
|
||||||
basic_machine=i386-unknown
|
basic_machine=i386-pc
|
||||||
os=-msdos
|
os=-msdos
|
||||||
;;
|
;;
|
||||||
mvs)
|
mvs)
|
||||||
@@ -595,6 +685,10 @@ case $basic_machine in
|
|||||||
basic_machine=i960-intel
|
basic_machine=i960-intel
|
||||||
os=-mon960
|
os=-mon960
|
||||||
;;
|
;;
|
||||||
|
nonstopux)
|
||||||
|
basic_machine=mips-compaq
|
||||||
|
os=-nonstopux
|
||||||
|
;;
|
||||||
np1)
|
np1)
|
||||||
basic_machine=np1-gould
|
basic_machine=np1-gould
|
||||||
;;
|
;;
|
||||||
@@ -630,28 +724,28 @@ case $basic_machine in
|
|||||||
pc532 | pc532-*)
|
pc532 | pc532-*)
|
||||||
basic_machine=ns32k-pc532
|
basic_machine=ns32k-pc532
|
||||||
;;
|
;;
|
||||||
pentium | p5 | k5 | k6 | nexen)
|
pentium | p5 | k5 | k6 | nexgen)
|
||||||
basic_machine=i586-pc
|
basic_machine=i586-pc
|
||||||
;;
|
;;
|
||||||
pentiumpro | p6 | 6x86)
|
pentiumpro | p6 | 6x86 | athlon)
|
||||||
basic_machine=i686-pc
|
basic_machine=i686-pc
|
||||||
;;
|
;;
|
||||||
pentiumii | pentium2)
|
pentiumii | pentium2)
|
||||||
basic_machine=i786-pc
|
basic_machine=i686-pc
|
||||||
;;
|
;;
|
||||||
pentium-* | p5-* | k5-* | k6-* | nexen-*)
|
pentium-* | p5-* | k5-* | k6-* | nexgen-*)
|
||||||
basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
pentiumpro-* | p6-* | 6x86-*)
|
pentiumpro-* | p6-* | 6x86-* | athlon-*)
|
||||||
basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
pentiumii-* | pentium2-*)
|
pentiumii-* | pentium2-*)
|
||||||
basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
pn)
|
pn)
|
||||||
basic_machine=pn-gould
|
basic_machine=pn-gould
|
||||||
;;
|
;;
|
||||||
power) basic_machine=rs6000-ibm
|
power) basic_machine=power-ibm
|
||||||
;;
|
;;
|
||||||
ppc) basic_machine=powerpc-unknown
|
ppc) basic_machine=powerpc-unknown
|
||||||
;;
|
;;
|
||||||
@@ -663,9 +757,23 @@ case $basic_machine in
|
|||||||
ppcle-* | powerpclittle-*)
|
ppcle-* | powerpclittle-*)
|
||||||
basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
|
ppc64) basic_machine=powerpc64-unknown
|
||||||
|
;;
|
||||||
|
ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
|
;;
|
||||||
|
ppc64le | powerpc64little | ppc64-le | powerpc64-little)
|
||||||
|
basic_machine=powerpc64le-unknown
|
||||||
|
;;
|
||||||
|
ppc64le-* | powerpc64little-*)
|
||||||
|
basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
|
;;
|
||||||
ps2)
|
ps2)
|
||||||
basic_machine=i386-ibm
|
basic_machine=i386-ibm
|
||||||
;;
|
;;
|
||||||
|
pw32)
|
||||||
|
basic_machine=i586-unknown
|
||||||
|
os=-pw32
|
||||||
|
;;
|
||||||
rom68k)
|
rom68k)
|
||||||
basic_machine=m68k-rom68k
|
basic_machine=m68k-rom68k
|
||||||
os=-coff
|
os=-coff
|
||||||
@@ -757,6 +865,10 @@ case $basic_machine in
|
|||||||
basic_machine=t3e-cray
|
basic_machine=t3e-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
|
tic54x | c54x*)
|
||||||
|
basic_machine=tic54x-unknown
|
||||||
|
os=-coff
|
||||||
|
;;
|
||||||
tx39)
|
tx39)
|
||||||
basic_machine=mipstx39-unknown
|
basic_machine=mipstx39-unknown
|
||||||
;;
|
;;
|
||||||
@@ -809,6 +921,10 @@ case $basic_machine in
|
|||||||
basic_machine=hppa1.1-winbond
|
basic_machine=hppa1.1-winbond
|
||||||
os=-proelf
|
os=-proelf
|
||||||
;;
|
;;
|
||||||
|
windows32)
|
||||||
|
basic_machine=i386-pc
|
||||||
|
os=-windows32-msvcrt
|
||||||
|
;;
|
||||||
xmp)
|
xmp)
|
||||||
basic_machine=xmp-cray
|
basic_machine=xmp-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
@@ -852,13 +968,20 @@ case $basic_machine in
|
|||||||
vax)
|
vax)
|
||||||
basic_machine=vax-dec
|
basic_machine=vax-dec
|
||||||
;;
|
;;
|
||||||
|
pdp10)
|
||||||
|
# there are many clones, so DEC is not a safe bet
|
||||||
|
basic_machine=pdp10-unknown
|
||||||
|
;;
|
||||||
pdp11)
|
pdp11)
|
||||||
basic_machine=pdp11-dec
|
basic_machine=pdp11-dec
|
||||||
;;
|
;;
|
||||||
we32k)
|
we32k)
|
||||||
basic_machine=we32k-att
|
basic_machine=we32k-att
|
||||||
;;
|
;;
|
||||||
sparc | sparcv9)
|
sh3 | sh4 | sh3eb | sh4eb)
|
||||||
|
basic_machine=sh-unknown
|
||||||
|
;;
|
||||||
|
sparc | sparcv9 | sparcv9b)
|
||||||
basic_machine=sparc-sun
|
basic_machine=sparc-sun
|
||||||
;;
|
;;
|
||||||
cydra)
|
cydra)
|
||||||
@@ -880,6 +1003,9 @@ case $basic_machine in
|
|||||||
basic_machine=c4x-none
|
basic_machine=c4x-none
|
||||||
os=-coff
|
os=-coff
|
||||||
;;
|
;;
|
||||||
|
*-unknown)
|
||||||
|
# Make sure to match an already-canonicalized machine name.
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
|
echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
@@ -936,15 +1062,18 @@ case $os in
|
|||||||
| -lynxos* | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
|
| -lynxos* | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
|
||||||
| -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
|
| -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
|
||||||
| -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
|
| -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
|
||||||
|
| -chorusos* | -chorusrdb* \
|
||||||
| -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
|
| -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
|
||||||
| -mingw32* | -linux-gnu* | -uxpv* | -beos* | -mpeix* | -udk* \
|
| -mingw32* | -linux-gnu* | -uxpv* | -beos* | -mpeix* | -udk* \
|
||||||
| -interix* | -uwin* | -rhapsody* | -darwin* | -opened* \
|
| -interix* | -uwin* | -rhapsody* | -darwin* | -opened* \
|
||||||
| -openstep* | -oskit*)
|
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
|
||||||
|
| -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \
|
||||||
|
| -os2* | -vos*)
|
||||||
# Remember, each alternative MUST END IN *, to match a version number.
|
# Remember, each alternative MUST END IN *, to match a version number.
|
||||||
;;
|
;;
|
||||||
-qnx*)
|
-qnx*)
|
||||||
case $basic_machine in
|
case $basic_machine in
|
||||||
x86-* | i[34567]86-*)
|
x86-* | i*86-*)
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
os=-nto$os
|
os=-nto$os
|
||||||
@@ -1000,7 +1129,7 @@ case $os in
|
|||||||
-ns2 )
|
-ns2 )
|
||||||
os=-nextstep2
|
os=-nextstep2
|
||||||
;;
|
;;
|
||||||
-nsk)
|
-nsk*)
|
||||||
os=-nsk
|
os=-nsk
|
||||||
;;
|
;;
|
||||||
# Preserve the version number of sinix5.
|
# Preserve the version number of sinix5.
|
||||||
@@ -1037,7 +1166,7 @@ case $os in
|
|||||||
-xenix)
|
-xenix)
|
||||||
os=-xenix
|
os=-xenix
|
||||||
;;
|
;;
|
||||||
-*mint | -*MiNT)
|
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
|
||||||
os=-mint
|
os=-mint
|
||||||
;;
|
;;
|
||||||
-none)
|
-none)
|
||||||
@@ -1071,6 +1200,9 @@ case $basic_machine in
|
|||||||
arm*-semi)
|
arm*-semi)
|
||||||
os=-aout
|
os=-aout
|
||||||
;;
|
;;
|
||||||
|
pdp10-*)
|
||||||
|
os=-tops20
|
||||||
|
;;
|
||||||
pdp11-*)
|
pdp11-*)
|
||||||
os=-none
|
os=-none
|
||||||
;;
|
;;
|
||||||
@@ -1179,7 +1311,7 @@ case $basic_machine in
|
|||||||
*-masscomp)
|
*-masscomp)
|
||||||
os=-rtu
|
os=-rtu
|
||||||
;;
|
;;
|
||||||
f301-fujitsu)
|
f30[01]-fujitsu | f700-fujitsu)
|
||||||
os=-uxpv
|
os=-uxpv
|
||||||
;;
|
;;
|
||||||
*-rom68k)
|
*-rom68k)
|
||||||
@@ -1257,12 +1389,23 @@ case $basic_machine in
|
|||||||
-mpw* | -macos*)
|
-mpw* | -macos*)
|
||||||
vendor=apple
|
vendor=apple
|
||||||
;;
|
;;
|
||||||
-*mint | -*MiNT)
|
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
|
||||||
vendor=atari
|
vendor=atari
|
||||||
;;
|
;;
|
||||||
|
-vos*)
|
||||||
|
vendor=stratus
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
|
basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
echo $basic_machine$os
|
echo $basic_machine$os
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "timestamp='"
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d"
|
||||||
|
# time-stamp-end: "'"
|
||||||
|
# End:
|
||||||
|
|||||||
483
configure.in
483
configure.in
@@ -1,241 +1,120 @@
|
|||||||
dnl $Id$
|
dnl $Id$
|
||||||
dnl Process this file with autoconf to produce a configure script.
|
dnl Process this file with autoconf to produce a configure script.
|
||||||
AC_INIT(lib/urldata.h)
|
|
||||||
|
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)
|
AM_CONFIG_HEADER(config.h src/config.h)
|
||||||
|
|
||||||
VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' include/curl/curl.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)
|
AM_INIT_AUTOMAKE(curl,$VERSION)
|
||||||
AM_PROG_LIBTOOL
|
|
||||||
|
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
|
||||||
dnl Detect the canonical host and target build environment
|
dnl Detect the canonical host and target build environment
|
||||||
dnl
|
dnl
|
||||||
AC_CANONICAL_HOST
|
|
||||||
AC_CANONICAL_TARGET
|
|
||||||
|
|
||||||
dnl Checks for programs.
|
AC_CANONICAL_HOST
|
||||||
AC_PROG_CC
|
dnl Get system canonical name
|
||||||
|
AC_DEFINE_UNQUOTED(OS, "${host}")
|
||||||
|
|
||||||
dnl Check for AIX weirdos
|
dnl Check for AIX weirdos
|
||||||
AC_AIX
|
AC_AIX
|
||||||
|
|
||||||
|
dnl Checks for programs.
|
||||||
|
AC_PROG_CC
|
||||||
|
|
||||||
dnl check for how to do large files
|
dnl check for how to do large files
|
||||||
AC_SYS_LARGEFILE
|
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 The install stuff has already been taken care of by the automake stuff
|
||||||
dnl AC_PROG_INSTALL
|
dnl AC_PROG_INSTALL
|
||||||
AC_PROG_MAKE_SET
|
AC_PROG_MAKE_SET
|
||||||
|
|
||||||
AC_DEFUN(CURL_CHECK_LOCALTIME_R,
|
dnl ************************************************************
|
||||||
[
|
dnl lame option to switch on debug options
|
||||||
dnl check for a few thread-safe functions
|
dnl
|
||||||
AC_CHECK_FUNCS(localtime_r,[
|
AC_MSG_CHECKING([whether to enable debug options])
|
||||||
AC_MSG_CHECKING(whether localtime_r is declared)
|
AC_ARG_ENABLE(debug,
|
||||||
AC_EGREP_CPP(localtime_r,[
|
[ --enable-debug Enable pedantic debug options
|
||||||
#include <time.h>],[
|
--disable-debug Disable debug options],
|
||||||
AC_MSG_RESULT(yes)],[
|
[ case "$enableval" in
|
||||||
AC_MSG_RESULT(no)
|
no)
|
||||||
AC_MSG_CHECKING(whether localtime_r with -D_REENTRANT is declared)
|
AC_MSG_RESULT(no)
|
||||||
AC_EGREP_CPP(localtime_r,[
|
;;
|
||||||
#define _REENTRANT
|
*) AC_MSG_RESULT(yes)
|
||||||
#include <time.h>],[
|
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
|
||||||
AC_MSG_RESULT(yes)],
|
|
||||||
AC_MSG_RESULT(no))])])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN(CURL_CHECK_INET_NTOA_R,
|
CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG"
|
||||||
[
|
CFLAGS="-W -Wall -Wwrite-strings -pedantic -g"
|
||||||
dnl determine if function definition for inet_ntoa_r exists.
|
;;
|
||||||
AC_CHECK_FUNCS(inet_ntoa_r,[
|
esac ],
|
||||||
AC_MSG_CHECKING(whether inet_ntoa_r is declared)
|
AC_MSG_RESULT(no)
|
||||||
AC_EGREP_CPP(inet_ntoa_r,[
|
)
|
||||||
#include <arpa/inet.h>],[
|
|
||||||
AC_DEFINE(HAVE_INET_NTOA_R_DECL)
|
|
||||||
AC_MSG_RESULT(yes)],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
AC_MSG_CHECKING(whether inet_ntoa_r with -D_REENTRANT is declared)
|
|
||||||
AC_EGREP_CPP(inet_ntoa_r,[
|
|
||||||
#define _REENTRANT
|
|
||||||
#include <arpa/inet.h>],[
|
|
||||||
AC_DEFINE(HAVE_INET_NTOA_R_DECL)
|
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
|
||||||
AC_MSG_RESULT(yes)],
|
|
||||||
AC_MSG_RESULT(no))])])
|
|
||||||
|
|
||||||
])
|
dnl **********************************************************************
|
||||||
|
dnl Checks for IPv6
|
||||||
|
dnl **********************************************************************
|
||||||
|
|
||||||
AC_DEFUN(CURL_CHECK_GETHOSTBYADDR_R,
|
AC_MSG_CHECKING([whether to enable ipv6])
|
||||||
[
|
AC_ARG_ENABLE(ipv6,
|
||||||
dnl check for number of arguments to gethostbyaddr_r. it might take
|
[ --enable-ipv6 Enable ipv6 (with ipv4) support
|
||||||
dnl either 5, 7, or 8 arguments.
|
--disable-ipv6 Disable ipv6 support],
|
||||||
AC_CHECK_FUNCS(gethostbyaddr_r,[
|
[ case "$enableval" in
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r takes 5 arguments)
|
no)
|
||||||
AC_TRY_COMPILE([
|
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/types.h>
|
||||||
#include <netdb.h>],[
|
#include <sys/socket.h>
|
||||||
char * address;
|
main()
|
||||||
int length;
|
{
|
||||||
int type;
|
if (socket(AF_INET6, SOCK_STREAM, 0) < 0)
|
||||||
struct hostent h;
|
exit(1);
|
||||||
struct hostent_data hdata;
|
else
|
||||||
int rc;
|
exit(0);
|
||||||
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
}
|
||||||
AC_MSG_RESULT(yes)
|
],
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5)
|
AC_MSG_RESULT(yes)
|
||||||
ac_cv_gethostbyaddr_args=5],[
|
ipv6=yes,
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r with -D_REENTRANT takes 5 arguments)
|
ipv6=no,
|
||||||
AC_TRY_COMPILE([
|
AC_MSG_RESULT(no)
|
||||||
#define _REENTRANT
|
ipv6=no
|
||||||
#include <sys/types.h>
|
))
|
||||||
#include <netdb.h>],[
|
|
||||||
char * address;
|
|
||||||
int length;
|
|
||||||
int type;
|
|
||||||
struct hostent h;
|
|
||||||
struct hostent_data hdata;
|
|
||||||
int rc;
|
|
||||||
rc = gethostbyaddr_r(address, length, type, &h, &hdata);],[
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_5)
|
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
|
||||||
ac_cv_gethostbyaddr_args=5],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r takes 7 arguments)
|
|
||||||
AC_TRY_COMPILE([
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netdb.h>],[
|
|
||||||
char * address;
|
|
||||||
int length;
|
|
||||||
int type;
|
|
||||||
struct hostent h;
|
|
||||||
char buffer[8192];
|
|
||||||
int h_errnop;
|
|
||||||
struct hostent * hp;
|
|
||||||
|
|
||||||
hp = gethostbyaddr_r(address, length, type, &h,
|
if test "$ipv6" = "yes"; then
|
||||||
buffer, 8192, &h_errnop);],[
|
CURL_CHECK_WORKING_GETADDRINFO
|
||||||
AC_MSG_RESULT(yes)
|
fi
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_7)
|
|
||||||
ac_cv_gethostbyaddr_args=7],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
AC_MSG_CHECKING(if gethostbyaddr_r takes 8 arguments)
|
|
||||||
AC_TRY_COMPILE([
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netdb.h>],[
|
|
||||||
char * address;
|
|
||||||
int length;
|
|
||||||
int type;
|
|
||||||
struct hostent h;
|
|
||||||
char buffer[8192];
|
|
||||||
int h_errnop;
|
|
||||||
struct hostent * hp;
|
|
||||||
int rc;
|
|
||||||
|
|
||||||
rc = gethostbyaddr_r(address, length, type, &h,
|
|
||||||
buffer, 8192, &hp, &h_errnop);],[
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_GETHOSTBYADDR_R_8)
|
|
||||||
ac_cv_gethostbyaddr_args=8],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
have_missing_r_funcs="$have_missing_r_funcs gethostbyaddr_r"])])])])])
|
|
||||||
|
|
||||||
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN(CURL_CHECK_GETHOSTBYNAME_R,
|
|
||||||
[
|
|
||||||
dnl check for number of arguments to gethostbyname_r. it might take
|
|
||||||
dnl either 3, 5, or 6 arguments.
|
|
||||||
AC_CHECK_FUNCS(gethostbyname_r,[
|
|
||||||
AC_MSG_CHECKING(if gethostbyname_r takes 3 arguments)
|
|
||||||
AC_TRY_RUN([
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
|
|
||||||
int
|
|
||||||
main () {
|
|
||||||
struct hostent h;
|
|
||||||
struct hostent_data hdata;
|
|
||||||
char *name = "localhost";
|
|
||||||
int rc;
|
|
||||||
memset(&h, 0, sizeof(struct hostent));
|
|
||||||
memset(&hdata, 0, sizeof(struct hostent_data));
|
|
||||||
rc = gethostbyname_r(name, &h, &hdata);
|
|
||||||
exit (rc != 0 ? 1 : 0); }],[
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3)
|
|
||||||
ac_cv_gethostbyname_args=3],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
AC_MSG_CHECKING(if gethostbyname_r with -D_REENTRANT takes 3 arguments)
|
|
||||||
AC_TRY_RUN([
|
|
||||||
#define _REENTRANT
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
|
|
||||||
int
|
|
||||||
main () {
|
|
||||||
struct hostent h;
|
|
||||||
struct hostent_data hdata;
|
|
||||||
char *name = "localhost";
|
|
||||||
int rc;
|
|
||||||
memset(&h, 0, sizeof(struct hostent));
|
|
||||||
memset(&hdata, 0, sizeof(struct hostent_data));
|
|
||||||
rc = gethostbyname_r(name, &h, &hdata);
|
|
||||||
exit (rc != 0 ? 1 : 0); }],[
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_3)
|
|
||||||
AC_DEFINE(NEED_REENTRANT)
|
|
||||||
ac_cv_gethostbyname_args=3],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
AC_MSG_CHECKING(if gethostbyname_r takes 5 arguments)
|
|
||||||
AC_TRY_RUN([
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
|
|
||||||
int
|
|
||||||
main () {
|
|
||||||
struct hostent *hp;
|
|
||||||
struct hostent h;
|
|
||||||
char *name = "localhost";
|
|
||||||
char buffer[8192];
|
|
||||||
int h_errno;
|
|
||||||
hp = gethostbyname_r(name, &h, buffer, 8192, &h_errno);
|
|
||||||
exit (hp == NULL ? 1 : 0); }],[
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_5)
|
|
||||||
ac_cv_gethostbyname_args=5],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
AC_MSG_CHECKING(if gethostbyname_r takes 6 arguments)
|
|
||||||
AC_TRY_RUN([
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
|
|
||||||
int
|
|
||||||
main () {
|
|
||||||
struct hostent h;
|
|
||||||
struct hostent *hp;
|
|
||||||
char *name = "localhost";
|
|
||||||
char buf[8192];
|
|
||||||
int rc;
|
|
||||||
int h_errno;
|
|
||||||
rc = gethostbyname_r(name, &h, buf, 8192, &hp, &h_errno);
|
|
||||||
exit (rc != 0 ? 1 : 0); }],[
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_GETHOSTBYNAME_R_6)
|
|
||||||
ac_cv_gethostbyname_args=6],[
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
have_missing_r_funcs="$have_missing_r_funcs gethostbyname_r"],
|
|
||||||
[ac_cv_gethostbyname_args=0])],
|
|
||||||
[ac_cv_gethostbyname_args=0])],
|
|
||||||
[ac_cv_gethostbyname_args=0])],
|
|
||||||
[ac_cv_gethostbyname_args=0])])
|
|
||||||
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -288,7 +167,55 @@ dnl ucb lib?
|
|||||||
AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
||||||
|
|
||||||
dnl dl lib?
|
dnl dl lib?
|
||||||
AC_CHECK_FUNC(dlopen, , AC_CHECK_LIB(dl, dlopen))
|
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 **********************************************************************
|
||||||
dnl Check for the presence of Kerberos4 libraries and headers
|
dnl Check for the presence of Kerberos4 libraries and headers
|
||||||
@@ -327,6 +254,10 @@ AC_MSG_CHECKING([if Kerberos4 support is requested])
|
|||||||
|
|
||||||
if test "$want_krb4" = yes
|
if test "$want_krb4" = yes
|
||||||
then
|
then
|
||||||
|
if test "$ipv6" = "yes"; then
|
||||||
|
echo krb4 is not compatible with IPv6
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-krb4
|
dnl Check for & handle argument to --with-krb4
|
||||||
@@ -363,6 +294,10 @@ then
|
|||||||
dnl add define KRB4
|
dnl add define KRB4
|
||||||
AC_DEFINE(KRB4)
|
AC_DEFINE(KRB4)
|
||||||
|
|
||||||
|
dnl substitute it too!
|
||||||
|
KRB4_ENABLED=1
|
||||||
|
AC_SUBST(KRB4_ENABLED)
|
||||||
|
|
||||||
dnl the krb4 stuff needs a strlcpy()
|
dnl the krb4 stuff needs a strlcpy()
|
||||||
AC_CHECK_FUNCS(strlcpy)
|
AC_CHECK_FUNCS(strlcpy)
|
||||||
|
|
||||||
@@ -372,6 +307,7 @@ else
|
|||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the presence of SSL libraries and headers
|
dnl Check for the presence of SSL libraries and headers
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -389,26 +325,45 @@ then
|
|||||||
AC_MSG_WARN(SSL/https support disabled)
|
AC_MSG_WARN(SSL/https support disabled)
|
||||||
else
|
else
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-ssl.
|
dnl Check for and handle argument to --with-ssl.
|
||||||
|
|
||||||
AC_MSG_CHECKING(where to look for SSL)
|
dnl save the pre-ssl check flags for a while
|
||||||
if test X"$OPT_SSL" = Xoff
|
CLEANLDFLAGS="$LDFLAGS"
|
||||||
then
|
CLEANCPPFLAGS="$CPPFLAGS"
|
||||||
AC_MSG_RESULT([defaults (or given in environment)])
|
|
||||||
else
|
|
||||||
test X"$OPT_SSL" = Xyes && OPT_SSL=/usr/local/ssl
|
|
||||||
dnl LIBS="$LIBS -L$OPT_SSL/lib"
|
|
||||||
LDFLAGS="$LDFLAGS -L$OPT_SSL/lib"
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$OPT_SSL/include/openssl -I$OPT_SSL/include"
|
|
||||||
AC_MSG_RESULT([$OPT_SSL])
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl check for crypto libs (part of SSLeay)
|
case "$OPT_SSL" in
|
||||||
AC_CHECK_LIB(crypto, CRYPTO_lock)
|
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
|
||||||
|
|
||||||
if test $ac_cv_lib_crypto_CRYPTO_lock = yes; then
|
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 This is only reasonable to do if crypto actually is there: check for
|
||||||
dnl SSL libs NOTE: it is important to do this AFTER the crypto lib
|
dnl 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)
|
AC_CHECK_LIB(ssl, SSL_connect)
|
||||||
|
|
||||||
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
||||||
@@ -427,20 +382,35 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
dnl Check for SSLeay headers
|
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)
|
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
|
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)
|
AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h,
|
||||||
|
OPENSSL_ENABLED=1)
|
||||||
fi
|
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
|
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
|
dnl these can only exist if openssl exists
|
||||||
|
|
||||||
AC_CHECK_FUNCS( RAND_status \
|
AC_CHECK_FUNCS( RAND_status \
|
||||||
RAND_screen )
|
RAND_screen \
|
||||||
|
RAND_egd )
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -503,6 +473,8 @@ else
|
|||||||
dnl is there a localtime_r()
|
dnl is there a localtime_r()
|
||||||
CURL_CHECK_LOCALTIME_R()
|
CURL_CHECK_LOCALTIME_R()
|
||||||
|
|
||||||
|
AC_CHECK_FUNCS( gmtime_r )
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -526,7 +498,6 @@ AC_CHECK_HEADERS( \
|
|||||||
sys/stat.h \
|
sys/stat.h \
|
||||||
sys/types.h \
|
sys/types.h \
|
||||||
sys/time.h \
|
sys/time.h \
|
||||||
getopt.h \
|
|
||||||
sys/param.h \
|
sys/param.h \
|
||||||
termios.h \
|
termios.h \
|
||||||
termio.h \
|
termio.h \
|
||||||
@@ -537,6 +508,9 @@ AC_CHECK_HEADERS( \
|
|||||||
winsock.h \
|
winsock.h \
|
||||||
time.h \
|
time.h \
|
||||||
io.h \
|
io.h \
|
||||||
|
pwd.h \
|
||||||
|
utime.h \
|
||||||
|
sys/utime.h
|
||||||
)
|
)
|
||||||
|
|
||||||
dnl Check for libz header
|
dnl Check for libz header
|
||||||
@@ -554,9 +528,11 @@ AC_CHECK_SIZEOF(long double, 8)
|
|||||||
# check for 'long long'
|
# check for 'long long'
|
||||||
AC_CHECK_SIZEOF(long long, 4)
|
AC_CHECK_SIZEOF(long long, 4)
|
||||||
|
|
||||||
dnl Get system canonical name
|
# check for ssize_t
|
||||||
AC_CANONICAL_HOST
|
AC_CHECK_TYPE(ssize_t, int)
|
||||||
AC_DEFINE_UNQUOTED(OS, "${host}")
|
|
||||||
|
TYPE_SOCKLEN_T
|
||||||
|
TYPE_IN_ADDR_T
|
||||||
|
|
||||||
dnl Checks for library functions.
|
dnl Checks for library functions.
|
||||||
dnl AC_PROG_GCC_TRADITIONAL
|
dnl AC_PROG_GCC_TRADITIONAL
|
||||||
@@ -566,6 +542,7 @@ AC_CHECK_FUNCS( socket \
|
|||||||
select \
|
select \
|
||||||
strdup \
|
strdup \
|
||||||
strstr \
|
strstr \
|
||||||
|
strtok_r \
|
||||||
strftime \
|
strftime \
|
||||||
uname \
|
uname \
|
||||||
strcasecmp \
|
strcasecmp \
|
||||||
@@ -573,7 +550,6 @@ AC_CHECK_FUNCS( socket \
|
|||||||
strcmpi \
|
strcmpi \
|
||||||
gethostname \
|
gethostname \
|
||||||
gethostbyaddr \
|
gethostbyaddr \
|
||||||
getservbyname \
|
|
||||||
gettimeofday \
|
gettimeofday \
|
||||||
inet_addr \
|
inet_addr \
|
||||||
inet_ntoa \
|
inet_ntoa \
|
||||||
@@ -584,12 +560,20 @@ AC_CHECK_FUNCS( socket \
|
|||||||
setvbuf \
|
setvbuf \
|
||||||
sigaction \
|
sigaction \
|
||||||
signal \
|
signal \
|
||||||
getpass_r
|
getpass_r \
|
||||||
|
strlcat \
|
||||||
|
getpwuid \
|
||||||
|
geteuid \
|
||||||
|
dlopen \
|
||||||
|
utime
|
||||||
)
|
)
|
||||||
|
|
||||||
dnl removed 'getpass' check on October 26, 2000
|
dnl removed 'getpass' check on October 26, 2000
|
||||||
|
|
||||||
if test "$ac_cv_func_select" != "yes"; then
|
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)
|
AC_MSG_ERROR(Can't work without an existing socket() function)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -607,14 +591,25 @@ dnl AC_PATH_PROG( RANLIB, ranlib, /usr/bin/ranlib,
|
|||||||
dnl $PATH:/usr/bin/:/usr/local/bin )
|
dnl $PATH:/usr/bin/:/usr/local/bin )
|
||||||
dnl AC_SUBST(RANLIB)
|
dnl AC_SUBST(RANLIB)
|
||||||
|
|
||||||
AC_OUTPUT( Makefile \
|
AC_CONFIG_FILES([Makefile \
|
||||||
docs/Makefile \
|
docs/Makefile \
|
||||||
|
docs/examples/Makefile \
|
||||||
include/Makefile \
|
include/Makefile \
|
||||||
include/curl/Makefile \
|
include/curl/Makefile \
|
||||||
src/Makefile \
|
src/Makefile \
|
||||||
|
multi/Makefile \
|
||||||
lib/Makefile \
|
lib/Makefile \
|
||||||
tests/Makefile)
|
tests/Makefile \
|
||||||
dnl perl/checklinks.pl \
|
tests/data/Makefile \
|
||||||
dnl perl/getlinks.pl \
|
packages/Makefile \
|
||||||
dnl perl/formfind.pl \
|
packages/Win32/Makefile \
|
||||||
dnl perl/recursiveftpget.pl )
|
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
|
||||||
|
|
||||||
|
|||||||
97
curl-config.in
Normal file
97
curl-config.in
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
#
|
||||||
|
# The idea to this kind of setup info script was stolen from numerous
|
||||||
|
# other packages, such as neon, libxml and gnome.
|
||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
prefix=@prefix@
|
||||||
|
exec_prefix=@exec_prefix@
|
||||||
|
includedir=@includedir@
|
||||||
|
|
||||||
|
usage()
|
||||||
|
{
|
||||||
|
cat <<EOF
|
||||||
|
Usage: curl-config [OPTION]
|
||||||
|
|
||||||
|
Available values for OPTION include:
|
||||||
|
|
||||||
|
--cc compiler
|
||||||
|
--cflags pre-processor and compiler flags
|
||||||
|
--feature newline separated list of enabled features
|
||||||
|
--help display this help and exit
|
||||||
|
--libs library linking information
|
||||||
|
--prefix curl install prefix
|
||||||
|
--version output version information
|
||||||
|
--vernum output the version information as a number (hexadecimal)
|
||||||
|
EOF
|
||||||
|
|
||||||
|
exit $1
|
||||||
|
}
|
||||||
|
|
||||||
|
if test $# -eq 0; then
|
||||||
|
usage 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
while test $# -gt 0; do
|
||||||
|
case "$1" in
|
||||||
|
# this deals with options in the style
|
||||||
|
# --option=value and extracts the value part
|
||||||
|
# [not currently used]
|
||||||
|
-*=*) value=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
|
||||||
|
*) value= ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
--cc)
|
||||||
|
echo @CC@
|
||||||
|
;;
|
||||||
|
|
||||||
|
--prefix)
|
||||||
|
echo $prefix
|
||||||
|
;;
|
||||||
|
|
||||||
|
--feature)
|
||||||
|
if test "@OPENSSL_ENABLED@" = "1"; then
|
||||||
|
echo "SSL"
|
||||||
|
fi
|
||||||
|
if test "@KRB4_ENABLED@" = "1"; then
|
||||||
|
echo "KRB4"
|
||||||
|
fi
|
||||||
|
if test "@IPV6_ENABLED@" = "1"; then
|
||||||
|
echo "IPv6"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
--version)
|
||||||
|
echo libcurl @VERSION@
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--vernum)
|
||||||
|
echo @VERSIONNUM@
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--help)
|
||||||
|
usage 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--cflags)
|
||||||
|
echo -I@includedir@
|
||||||
|
;;
|
||||||
|
|
||||||
|
--libs)
|
||||||
|
echo -L@libdir@ -lcurl @LDFLAGS@ @LIBS@
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "unknown option: $1"
|
||||||
|
usage
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 0
|
||||||
21
curl-mode.el
Normal file
21
curl-mode.el
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
;;;; 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)
|
||||||
37
docs/BUGS
37
docs/BUGS
@@ -1,3 +1,4 @@
|
|||||||
|
$Id$
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -6,9 +7,9 @@
|
|||||||
|
|
||||||
BUGS
|
BUGS
|
||||||
|
|
||||||
Curl has grown substantially from that day, several years ago, when I
|
Curl and libcurl have grown substantially since the beginning. At the time
|
||||||
started fiddling with it. When I write this, there are 16500 lines of source
|
of writing (mid March 2001), there are 23000 lines of source code, and by
|
||||||
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.
|
||||||
|
|
||||||
@@ -21,10 +22,16 @@ BUGS
|
|||||||
http://sourceforge.net/bugs/?group_id=976
|
http://sourceforge.net/bugs/?group_id=976
|
||||||
|
|
||||||
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's expected and how to repeat it. You therefore
|
understand what's wrong, what you expected to happen and how to repeat the
|
||||||
need to supply your operating system's name and version number (uname -a
|
bad behavior. You therefore need to supply your operating system's name and
|
||||||
under a unix is fine), what version of curl you're using (curl -v is fine),
|
version number (uname -a under a unix is fine), what version of curl you're
|
||||||
what URL you were working with and anything else you think matters.
|
using (curl -V is fine), what URL you were working with and anything else
|
||||||
|
you think matters.
|
||||||
|
|
||||||
|
Since curl deals with networks, it often helps us a lot 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
|
||||||
@@ -32,25 +39,25 @@ BUGS
|
|||||||
a stack trace and send that (much smaller) output to us instead!
|
a stack trace and send that (much smaller) output to us instead!
|
||||||
|
|
||||||
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
|
||||||
README.curl file.
|
MANUAL file.
|
||||||
|
|
||||||
HOW TO GET A STACK TRACE with a common unix debugger
|
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.
|
don't 'strip' the final executable. Try to avoid optimizing the code as
|
||||||
|
well, remove -O, -O2 etc from the compiler options.
|
||||||
|
|
||||||
Run the program until it bangs.
|
Run the program until it dumps core.
|
||||||
|
|
||||||
Run your debugger on the core file, like '<debugger> curl core'. <debugger>
|
Run your debugger on the core file, like '<debugger> curl core'. <debugger>
|
||||||
should be replaced with the name of your debugger, in most cases that will
|
should be replaced with the name of your debugger, in most cases that will
|
||||||
be 'gdb', but 'dbx' and others also occur.
|
be 'gdb', but 'dbx' and others also occur.
|
||||||
|
|
||||||
When the debugger has finished loading the core file and presents you a
|
When the debugger has finished loading the core file and presents you a
|
||||||
prompt, you can give the compiler instructions. Enter 'where' (without the
|
prompt, enter 'where' (without the quotes) and press return.
|
||||||
quotes) and press return.
|
|
||||||
|
|
||||||
The list that is presented is the stack trace. If everything worked, it is
|
The list that is presented is the stack trace. If everything worked, it is
|
||||||
supposed to contain the chain of functions that were called when curl
|
supposed to contain the chain of functions that were called when curl
|
||||||
crashed.
|
crashed. Include the stack trace with your detailed bug report. It'll help a
|
||||||
|
lot.
|
||||||
|
|
||||||
|
|||||||
@@ -4,45 +4,53 @@
|
|||||||
| (__| |_| | _ <| |___
|
| (__| |_| | _ <| |___
|
||||||
\___|\___/|_| \_\_____|
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
CONTRIBUTE
|
|
||||||
|
|
||||||
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 guidelines that can be useful to keep
|
||||||
in mind when you decide to write a contribution to the project. This concerns
|
in mind when you decide to write a contribution 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
|
||||||
|
|
||||||
|
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
|
||||||
|
you start sending patches!
|
||||||
|
|
||||||
The License Issue
|
The License Issue
|
||||||
|
|
||||||
When contributing with code, you agree to put your changes and new code under
|
When contributing with code, you agree to put your changes and new code under
|
||||||
the same license curl and libcurl is already using. Curl uses the MozPL, the
|
the same license curl and libcurl is already using unless stated otherwise.
|
||||||
Mozilla Public License, which is *NOT* compatible with the well known GPL,
|
|
||||||
GNU Public License. We can never re-use sources from a GPL program in curl.
|
|
||||||
If you add a larger piece of code, you can opt to make that file or set of
|
|
||||||
files to use a different license as long as they don't enfore any changes to
|
|
||||||
the rest of the package and they make sense. Such "separate parts" can not be
|
|
||||||
GPL either (although they should use "GPL compatible" licenses).
|
|
||||||
|
|
||||||
Curl and libcurl will soon become dual licensed, MozPL/MITX!
|
If you add a larger piece of code, you can opt to make that file or set of
|
||||||
|
files to use a different license as long as they don't enforce any changes to
|
||||||
|
the rest of the package and they make sense. Such "separate parts" can not be
|
||||||
|
GPL (as we don't want the GPL virus to attack users of libcurl) but they must
|
||||||
|
use "GPL compatible" licenses.
|
||||||
|
|
||||||
|
What To Read
|
||||||
|
|
||||||
|
Source code, the man pages, the INTERALS document, the TODO, the most recent
|
||||||
|
CHANGES. Just lurking on the libcurl mailing list is gonna give you a lot of
|
||||||
|
insights on what's going on right now.
|
||||||
|
|
||||||
Naming
|
Naming
|
||||||
|
|
||||||
Try using a non-confusing naming scheme for your new functions and variable
|
Try using a non-confusing naming scheme for your new functions and variable
|
||||||
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.
|
understandable and be named according to what they're used for. File-local
|
||||||
|
functions should be made static.
|
||||||
|
|
||||||
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. I don't ask you to like it, I just
|
all of it is written using the same style. We don't ask you to like it, we
|
||||||
ask you to follow the tradition! ;-)
|
just ask you to follow the tradition! ;-)
|
||||||
|
|
||||||
Commenting
|
Commenting
|
||||||
|
|
||||||
Comment your source code extensively. I don't see myself as a very good
|
Comment your source code extensively. Commented code is quality code and
|
||||||
source commenter, but I try to become one. Commented code is quality code and
|
|
||||||
enables future modifications much more. Uncommented code much more risk being
|
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.
|
||||||
@@ -72,6 +80,13 @@ Separate Patches Doing Different Things
|
|||||||
description exactly what they correct so that all patches can be selectively
|
description exactly what they correct so that all patches can be selectively
|
||||||
applied by the maintainer or other interested parties.
|
applied by the maintainer or other interested parties.
|
||||||
|
|
||||||
|
Patch Against Recent Sources
|
||||||
|
|
||||||
|
Please try to get the latest available sources to make your patches
|
||||||
|
against. It makes the life of the developers so much easier. The very best is
|
||||||
|
if you get the most up-to-date sources from the CVS repository, but the
|
||||||
|
latest release archive is quite OK as well!
|
||||||
|
|
||||||
Document
|
Document
|
||||||
|
|
||||||
Writing docs is dead boring and one of the big problems with many open source
|
Writing docs is dead boring and one of the big problems with many open source
|
||||||
@@ -84,13 +99,15 @@ 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
|
||||||
course get write access to the CVS repository and then you'll be able to
|
course get write access to the CVS repository and then you'll be able to
|
||||||
check-in all your changes straight into the CVS tree instead of sending all
|
check-in all your changes straight into the CVS tree instead of sending all
|
||||||
changes by mail as patches. Just ask if this is what you'd want.
|
changes by mail as patches. Just ask if this is what you'd want. You will be
|
||||||
|
required to have posted a few quality patches first, before you can be
|
||||||
|
granted write access.
|
||||||
|
|
||||||
Test Cases
|
Test Cases
|
||||||
|
|
||||||
Since the introduction of the test suite, we will get the possibility to
|
Since the introduction of the test suite, we can quickly verify that the main
|
||||||
quickly verify that the main features are working as supposed to. To maintain
|
features are working as they're supposed to. To maintain this situation and
|
||||||
this situation and improve it, all new features and functions that are added
|
improve it, all new features and functions that are added need to be tested
|
||||||
need tro be tested. 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!
|
||||||
|
|||||||
414
docs/FAQ
414
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: January 2, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
Updated: December 21, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -12,6 +12,9 @@ FAQ
|
|||||||
1.2 What is libcurl?
|
1.2 What is libcurl?
|
||||||
1.3 What is cURL not?
|
1.3 What is cURL not?
|
||||||
1.4 When will you make curl do XXXX ?
|
1.4 When will you make curl do XXXX ?
|
||||||
|
1.5 Who makes cURL?
|
||||||
|
1.6 What do you get for making cURL?
|
||||||
|
1.7 What about CURL from curl.com?
|
||||||
|
|
||||||
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,10 +33,14 @@ FAQ
|
|||||||
3.6 Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
3.6 Does curl support javascript, 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.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
|
3.11 How do I POST with a different Content-Type?
|
||||||
|
3.12 Why do FTP specific features over HTTP proxy fail?
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
4.2 Why do I get problems when I use & in the URL?
|
4.2 Why do I get problems when I use & or % in the URL?
|
||||||
4.3 How can I use {, }, [ or ] to specify multiple URLs?
|
4.3 How can I use {, }, [ or ] to specify multiple URLs?
|
||||||
4.4 Why do I get downloaded data even though the web page doesn't exist?
|
4.4 Why do I get downloaded data even though the web page doesn't exist?
|
||||||
4.5 Why do I get return code XXX from a HTTP server?
|
4.5 Why do I get return code XXX from a HTTP server?
|
||||||
@@ -42,16 +49,19 @@ FAQ
|
|||||||
4.5.3 "403 Forbidden"
|
4.5.3 "403 Forbidden"
|
||||||
4.5.4 "404 Not Found"
|
4.5.4 "404 Not Found"
|
||||||
4.5.5 "405 Method Not Allowed"
|
4.5.5 "405 Method Not Allowed"
|
||||||
|
4.5.6 "301 Moved Permanently"
|
||||||
4.6 Can you tell me what error code 142 means?
|
4.6 Can you tell me what error code 142 means?
|
||||||
4.7 How do I keep usernames 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?
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
5.1 Is libcurl thread safe?
|
5.1 Is libcurl thread-safe?
|
||||||
5.2 How can I receive all data into a large memory chunk?
|
5.2 How can I receive all data into a large memory chunk?
|
||||||
5.3 How do I fetch multiple files with libcurl?
|
5.3 How do I fetch multiple files with libcurl?
|
||||||
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.6 What about Keep-Alive or persistent connections?
|
||||||
|
|
||||||
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?
|
||||||
@@ -72,72 +82,117 @@ FAQ
|
|||||||
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.
|
||||||
|
|
||||||
Curl supports a range of common internet protocols, currently including
|
Curl supports a range of common Internet protocols, currently including
|
||||||
HTTP, HTTPS, FTP, GOPHER, LDAP, DICT and FILE.
|
HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE.
|
||||||
|
|
||||||
Please spell it cURL or just curl.
|
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
||||||
|
[kurl].
|
||||||
|
|
||||||
1.2 What is libcurl?
|
1.2 What is libcurl?
|
||||||
|
|
||||||
libcurl is the engine inside curl that does all the work. curl is more or
|
libcurl is a reliable and portable library which provides you with an easy
|
||||||
less the command line interface that converts the given options into libcurl
|
interface to a range of common Internet protocols.
|
||||||
function invokes. libcurl is a reliable, higly portable multiprotocol file
|
|
||||||
transfer library.
|
|
||||||
|
|
||||||
Any application is free to use libcurl, even commercial or closed-source
|
You can use libcurl for free in your application even if it is commercial
|
||||||
ones. Just make sure changes to the lib itself are made public.
|
or closed-source.
|
||||||
|
|
||||||
1.3 What is cURL not?
|
1.3 What is cURL not?
|
||||||
|
|
||||||
Curl is *not*, I repeat, *not* a wget clone even though that is a very
|
Curl is *not* a wget clone even though that is a very common misconception.
|
||||||
common misconception. Never, during curl's development, have I intended curl
|
Never, during curl's development, have we intended curl to replace wget or
|
||||||
to replace wget or compete on its market. Curl is targeted at single-shot
|
compete on its market. Curl is targeted at single-shot file transfers.
|
||||||
file transfers.
|
|
||||||
|
|
||||||
Curl is not a web site mirroring program. If you wanna use curl to mirror
|
Curl is not a web site mirroring program. If you wanna use curl to mirror
|
||||||
something: fine, go ahead and write a script that wraps around curl to make
|
something: fine, go ahead and write a script that wraps around curl to make
|
||||||
it reality (like curlmirror.pl does).
|
it reality (like curlmirror.pl does).
|
||||||
|
|
||||||
Curl is not an ftp site mirroring program. Sure, get and send ftp with curl
|
Curl is not an FTP site mirroring program. Sure, get and send FTP with curl
|
||||||
but if you want systematic and sequential behaviour you should write a
|
but if you want systematic and sequential behavior you should write a
|
||||||
script (or write a new program that interfaces libcurl) and do it.
|
script (or write a new program that interfaces libcurl) and do it.
|
||||||
|
|
||||||
Curl is not a PHP tool, even though it works perfectly well when used from
|
Curl is not a PHP tool, even though it works perfectly well when used from
|
||||||
or with PHP.
|
or with PHP.
|
||||||
|
|
||||||
Curl is not a single-OS program. Curl exists, compiles, builds and runs
|
Curl is not a single-OS program. Curl exists, compiles, builds and runs
|
||||||
under a wide range of operating systems, including all modern Unixes,
|
under a wide range of operating systems, including all modern Unixes (and a
|
||||||
Windows, Amiga, BeOS, OS/2, OS X, QNX etc.
|
bunch of older ones too), Windows, Amiga, BeOS, OS/2, OS X, QNX etc.
|
||||||
|
|
||||||
1.4 When will you make curl do XXXX ?
|
1.4 When will you make curl do XXXX ?
|
||||||
|
|
||||||
I love suggestions of what to change in order to make curl and libcurl
|
We love suggestions of what to change in order to make curl and libcurl
|
||||||
better. I 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:
|
||||||
|
|
||||||
* It is to remain a command line tool. If you want GUIs or fancy scripting
|
* Curl is to remain a command line tool. If you want GUIs or fancy scripting
|
||||||
capabilities, you're free to write another tool that uses libcurl and that
|
capabilities, you're free to write another tool that uses libcurl and that
|
||||||
offers this. There's no point in having one single tool that does every
|
offers this. There's no point in having a single tool that does every
|
||||||
imaginable thing. That's also one of the great advantages of having the
|
imaginable thing. That's also one of the great advantages of having the
|
||||||
core of curl as a library: libcurl.
|
core of curl as a library.
|
||||||
|
|
||||||
* I 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
|
||||||
program or redirect to another file for the next program to interpret.
|
program or redirect to another file for the next program to interpret.
|
||||||
|
|
||||||
* I focus on protocol related issues and improvements. If you wanna do more
|
* We focus on protocol related issues and improvements. If you wanna do more
|
||||||
magic with the supported protocols than curl currently does, chances are
|
magic with the supported protocols than curl currently does, chances are
|
||||||
big I will agree. If you wanna add more protocols, I may very well
|
big we will agree. If you wanna add more protocols, we may very well
|
||||||
agree.
|
agree.
|
||||||
|
|
||||||
* If you want me to make all the work while you wait for me to implement it
|
* If you want someone else to make all the work while you wait for us to
|
||||||
for you, that is not a very friendly attitude. I spend a considerable time
|
implement it for you, that is not a very friendly attitude. We spend a
|
||||||
already on maintaining and developing curl. In order to get more out of
|
considerable time already on maintaining and developing curl. In order to
|
||||||
me, I trust you will offer some of your time and efforts in return.
|
get more out of us, you should consider trading in some of your time and
|
||||||
|
efforts in return.
|
||||||
|
|
||||||
* If you write the code, chances are bigger that it will get into curl
|
* If you write the code, chances are bigger that it will get into curl
|
||||||
faster.
|
faster.
|
||||||
|
|
||||||
|
1.5 Who makes cURL?
|
||||||
|
|
||||||
|
cURL and libcurl are not made by any single individual. Sure, Daniel
|
||||||
|
Stenberg writes the major parts, but various people's submissions are
|
||||||
|
important and crucial. Anyone can post their changes and improvements and
|
||||||
|
have them inserted in the main sources (of course on the condition that
|
||||||
|
developers agree on that the fixes are good).
|
||||||
|
|
||||||
|
The list of contributors in the docs/THANKS file is only a small part of all
|
||||||
|
the people that every day provide us with bug reports, suggestions, ideas
|
||||||
|
and source code.
|
||||||
|
|
||||||
|
curl is developed by a community, with Daniel at the wheel.
|
||||||
|
|
||||||
|
1.6 What do you get for making cURL?
|
||||||
|
|
||||||
|
Project cURL is entirely free and open, without any commercial interests or
|
||||||
|
money involved. No person gets paid in any way for developing curl. We all
|
||||||
|
do this voluntarily on our spare time.
|
||||||
|
|
||||||
|
We get some help from companies. Contactor Data hosts the curl web site and
|
||||||
|
the main mailing list, Haxx owns the curl web site's domain and
|
||||||
|
sourceforge.net hosts several project tools we take advantage from like the
|
||||||
|
bug tracker, mailing lists and more.
|
||||||
|
|
||||||
|
If you want to support our project with a donation or similar, one way of
|
||||||
|
doing that would be to buy "gift certificates" at useful online shopping
|
||||||
|
sites, such as amazon.com or thinkgeek.com. Another way would be to sponsor
|
||||||
|
us through a banner-program or by simply helping us coding, documenting,
|
||||||
|
testing etc.
|
||||||
|
|
||||||
|
1.7 What about CURL from curl.com?
|
||||||
|
|
||||||
|
During the summer 2001, curl.com has been busy advertising their client-side
|
||||||
|
programming language for the web, named CURL.
|
||||||
|
|
||||||
|
We are in no way associated with curl.com or their CURL programming
|
||||||
|
language.
|
||||||
|
|
||||||
|
Our project name curl has been in effective use since 1998. We were not the
|
||||||
|
first computer related project to use the name "curl" and do not claim any
|
||||||
|
first-hand rights to the name.
|
||||||
|
|
||||||
|
We recognize that we will be living in parallel with curl.com and wish them
|
||||||
|
every success.
|
||||||
|
|
||||||
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
|
||||||
@@ -173,7 +228,7 @@ FAQ
|
|||||||
a few functions are left out from the libssl.
|
a few functions are left out from the libssl.
|
||||||
|
|
||||||
If the function names missing include RSA or RSAREF you can be certain
|
If the function names missing include RSA or RSAREF you can be certain
|
||||||
that this is because libssl requires the RSA and RSASEF libs to build.
|
that this is because libssl requires the RSA and RSAREF libs to build.
|
||||||
|
|
||||||
See the INSTALL file section that explains how to add those libs to
|
See the INSTALL file section that explains how to add those libs to
|
||||||
configure. Make sure that you remove the config.cache file before you
|
configure. Make sure that you remove the config.cache file before you
|
||||||
@@ -181,26 +236,24 @@ FAQ
|
|||||||
|
|
||||||
2.2. Does curl work/build with other SSL libraries?
|
2.2. Does curl work/build with other SSL libraries?
|
||||||
|
|
||||||
Curl has been written to use OpenSSL, although I doubt there would be much
|
Curl has been written to use OpenSSL, although there should not be much
|
||||||
problems using a different library. I just don't know any other free one and
|
problems using a different library. If anyone does "port" curl to use a
|
||||||
that has limited my possibilities to develop against anything else.
|
different SSL library, we are of course very interested in getting the
|
||||||
|
patch!
|
||||||
If anyone does "port" curl to use a commercial SSL library, I am of course
|
|
||||||
very interested in getting the patch!
|
|
||||||
|
|
||||||
2.3. Where can I find a copy of LIBEAY32.DLL?
|
2.3. Where can I find a copy of LIBEAY32.DLL?
|
||||||
|
|
||||||
That is an OpenSSL binary built for Windows.
|
That is an OpenSSL binary built for Windows.
|
||||||
|
|
||||||
Curl uses OpenSSL to do the SSL stuff. The LIBEAY32.DLL is what curl needs
|
Curl uses OpenSSL to do the SSL stuff. The LIBEAY32.DLL is what curl needs
|
||||||
on a windows machine to do https://. Check out the curl web page to find
|
on a windows machine to do https://. Check out the curl web site to find
|
||||||
accurate and up-to-date pointers to recent OpenSSL DDLs and other binary
|
accurate and up-to-date pointers to recent OpenSSL DLLs and other binary
|
||||||
packages.
|
packages.
|
||||||
|
|
||||||
2.4. Does cURL support Socks (RFC 1928) ?
|
2.4. Does cURL support Socks (RFC 1928) ?
|
||||||
|
|
||||||
No. Nobody has wanted it that badly yet. I would appriciate patches that
|
No. Nobody has wanted it that badly yet. We appreciate patches that bring
|
||||||
brings this functionality.
|
this functionality.
|
||||||
|
|
||||||
|
|
||||||
3. Usage problems
|
3. Usage problems
|
||||||
@@ -222,7 +275,7 @@ FAQ
|
|||||||
|
|
||||||
3.2. How do I tell curl to resume a transfer?
|
3.2. How do I tell curl to resume a transfer?
|
||||||
|
|
||||||
Curl supports resume both ways on FTP, download ways on HTTP.
|
Curl supports resumed transfers both ways on both FTP and HTTP.
|
||||||
|
|
||||||
Try the -C option.
|
Try the -C option.
|
||||||
|
|
||||||
@@ -230,14 +283,15 @@ FAQ
|
|||||||
|
|
||||||
You can't simply use -F or -d at your choice. The web server that will
|
You can't simply use -F or -d at your choice. The web server that will
|
||||||
receive your post assumes one of the formats. If the form you're trying to
|
receive your post assumes one of the formats. If the form you're trying to
|
||||||
"fake" sets the type to 'multipart/form-data', than and only then you must
|
"fake" sets the type to 'multipart/form-data', then and only then you must
|
||||||
use the -F type. In all the most common cases, you should use -d which then
|
use the -F type. In all the most common cases, you should use -d which then
|
||||||
causes a posting with the type 'application/x-www-form-urlencoded'.
|
causes a posting with the type 'application/x-www-form-urlencoded'.
|
||||||
|
|
||||||
I have described this in some detail in the README.curl file, and if you
|
This is described in some detail in the MANUAL and TheArtOfHttpScripting
|
||||||
don't understand it the first time, read it again before you post questions
|
documents, and if you don't understand it the first time, read it again
|
||||||
about this to the mailing list. I would also suggest that you read through
|
before you post questions about this to the mailing list. Also, try reading
|
||||||
the mailing list archives for old postings and questions regarding this.
|
through the mailing list archives for old postings and questions regarding
|
||||||
|
this.
|
||||||
|
|
||||||
3.4. How do I tell curl to run custom FTP commands?
|
3.4. How do I tell curl to run custom FTP commands?
|
||||||
|
|
||||||
@@ -245,7 +299,7 @@ FAQ
|
|||||||
file transfer. Study the -Q/--quote option.
|
file transfer. Study the -Q/--quote option.
|
||||||
|
|
||||||
Since curl is used for file transfers, you don't use curl to just perform
|
Since curl is used for file transfers, you don't use curl to just perform
|
||||||
ftp commands without transfering anything. Therefore you must always specify
|
FTP commands without transferring anything. Therefore you must always specify
|
||||||
a URL to transfer to/from even when doing custom FTP commands.
|
a URL to transfer to/from even when doing custom FTP commands.
|
||||||
|
|
||||||
3.5. How can I disable the Pragma: nocache header?
|
3.5. How can I disable the Pragma: nocache header?
|
||||||
@@ -257,7 +311,7 @@ FAQ
|
|||||||
3.6. Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
3.6. Does curl support javascript, 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.
|
||||||
|
|
||||||
@@ -267,7 +321,7 @@ FAQ
|
|||||||
|
|
||||||
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?
|
||||||
|
|
||||||
Yes. You specify custom ftp commands with -Q/--quote.
|
Yes. You specify custom FTP commands with -Q/--quote.
|
||||||
|
|
||||||
One example would be to delete a file after you have downloaded it:
|
One example would be to delete a file after you have downloaded it:
|
||||||
|
|
||||||
@@ -281,13 +335,62 @@ FAQ
|
|||||||
|
|
||||||
curl -L http://redirector.com
|
curl -L http://redirector.com
|
||||||
|
|
||||||
|
3.9 How do I use curl in my favourite programming language?
|
||||||
|
|
||||||
|
There exist many language interfaces/bindings for curl that integrates it
|
||||||
|
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
|
||||||
|
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
|
||||||
|
install and use them, in the libcurl section of the curl web site:
|
||||||
|
|
||||||
|
http://curl.haxx.se/libcurl/
|
||||||
|
|
||||||
|
In December 2001, there are interfaces available for the following
|
||||||
|
languages: C/C++, Cocoa, Dylan, Java, Perl, PHP, 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?
|
||||||
|
|
||||||
|
Curl adheres to the HTTP spec, which basically means you can play with *any*
|
||||||
|
protocol that is built on top of HTTP. Protocols such as SOAP, WEBDAV and
|
||||||
|
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).
|
||||||
|
|
||||||
|
Using libcurl or PHP's curl modules is just as fine and you'd just use the
|
||||||
|
proper library options to do the same.
|
||||||
|
|
||||||
|
3.11 How do I POST with a different Content-Type?
|
||||||
|
|
||||||
|
You can always replace the internally generated headers with -H/--header.
|
||||||
|
To make a simple HTTP POST with text/xml as content-type, do something like:
|
||||||
|
|
||||||
|
curl -d "datatopost" -H "Content-Type: text/xml" [URL]
|
||||||
|
|
||||||
|
3.12 Why do FTP specific features over HTTP proxy fail?
|
||||||
|
|
||||||
|
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
|
||||||
|
normally can't use FTP specific features such as ftp upload and ftp quote
|
||||||
|
etc.
|
||||||
|
|
||||||
|
There is one exception to this rule, and that is if you can "tunnel through"
|
||||||
|
the given HTTP proxy. Proxy tunneling is enabled with a special option (-p)
|
||||||
|
and is generally not available as proxy admins usually disable tunneling to
|
||||||
|
other ports than 443 (which is used for HTTPS access through proxies).
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
|
|
||||||
4.1. Problems connecting to SSL servers.
|
4.1. Problems connecting to SSL servers.
|
||||||
|
|
||||||
It took a very long time before I could sort out why curl had problems
|
It took a very long time before we could sort out why curl had problems to
|
||||||
to connect to certain SSL servers when using SSLeay or OpenSSL v0.9+.
|
connect to certain SSL servers when using SSLeay or OpenSSL v0.9+. The
|
||||||
The error sometimes showed up similar to:
|
error sometimes showed up similar to:
|
||||||
|
|
||||||
16570:error:1407D071:SSL routines:SSL2_READ:bad mac decode:s2_pkt.c:233:
|
16570:error:1407D071:SSL routines:SSL2_READ:bad mac decode:s2_pkt.c:233:
|
||||||
|
|
||||||
@@ -295,20 +398,26 @@ FAQ
|
|||||||
requests properly. To correct this problem, tell curl to select SSLv2 from
|
requests properly. To correct this problem, tell curl to select SSLv2 from
|
||||||
the command line (-2/--sslv2).
|
the command line (-2/--sslv2).
|
||||||
|
|
||||||
I have also seen examples where the remote server didn't like the SSLv2
|
There has also been examples where the remote server didn't like the SSLv2
|
||||||
request and instead you had to force curl to use SSLv3 with -3/--sslv3.
|
request and instead you had to force curl to use SSLv3 with -3/--sslv3.
|
||||||
|
|
||||||
4.2. Why do I get problems when I use & in the URL?
|
4.2. Why do I get problems when I use & or % in the URL?
|
||||||
|
|
||||||
In general unix shells, the & letter is treated special and when used it
|
In general unix shells, the & letter is treated special and when used, it
|
||||||
runs the specified command in the background. To safely send the & as a part
|
runs the specified command in the background. To safely send the & as a part
|
||||||
of a URL, you should qoute the entire URL by using single (') or double (")
|
of a URL, you should quote the entire URL by using single (') or double (")
|
||||||
quotes around it.
|
quotes around it.
|
||||||
|
|
||||||
An example that would invoke a remote CGI that uses &-letters could be:
|
An example that would invoke a remote CGI that uses &-letters could be:
|
||||||
|
|
||||||
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
|
||||||
|
need to quote the string properly when % is used in it.
|
||||||
|
|
||||||
|
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'.
|
||||||
|
|
||||||
4.3. How can I use {, }, [ or ] to specify multiple URLs?
|
4.3. How can I use {, }, [ or ] to specify multiple URLs?
|
||||||
|
|
||||||
Because those letters have a special meaning to the shell, and to be used in
|
Because those letters have a special meaning to the shell, and to be used in
|
||||||
@@ -318,6 +427,12 @@ 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
|
||||||
|
them for the curl URL "globbing" system), use the -g/--globoff option (curl
|
||||||
|
7.6 and later):
|
||||||
|
|
||||||
|
curl -g 'www.site.com/weirdname[].html'
|
||||||
|
|
||||||
4.4. Why do I get downloaded data even though the web page doesn't exist?
|
4.4. Why do I get downloaded data even though the web page doesn't exist?
|
||||||
|
|
||||||
Curl asks remote servers for the page you specify. If the page doesn't exist
|
Curl asks remote servers for the page you specify. If the page doesn't exist
|
||||||
@@ -330,8 +445,8 @@ FAQ
|
|||||||
|
|
||||||
4.5 Why do I get return code XXX from a HTTP server?
|
4.5 Why do I get return code XXX from a HTTP server?
|
||||||
|
|
||||||
RFC2616 clearly explains the return codes. I'll make a short transcript
|
RFC2616 clearly explains the return codes. This is a short transcript. Go
|
||||||
here. Go read the RFC for exact details:
|
read the RFC for exact details:
|
||||||
|
|
||||||
4.5.1 "400 Bad Request"
|
4.5.1 "400 Bad Request"
|
||||||
|
|
||||||
@@ -358,20 +473,31 @@ FAQ
|
|||||||
identified by the Request-URI. The response MUST include an Allow header
|
identified by the Request-URI. The response MUST include an Allow header
|
||||||
containing a list of valid methods for the requested resource.
|
containing a list of valid methods for the requested resource.
|
||||||
|
|
||||||
|
4.5.6 "301 Moved Permanently"
|
||||||
|
|
||||||
|
If you get this return code and an HTML outpt similar to this:
|
||||||
|
|
||||||
|
<H1>Moved Permanently</H1> The document has moved <A
|
||||||
|
HREF="http://same_url_now_with_a_trailing_slash/">here</A>.
|
||||||
|
|
||||||
|
it might be because you request a directory URL but without the trailing
|
||||||
|
slash. Try the same operation again _with_ the trailing URL, or use the
|
||||||
|
-L/--location option to follow the redirection.
|
||||||
|
|
||||||
4.6. Can you tell me what error code 142 means?
|
4.6. Can you tell me what error code 142 means?
|
||||||
|
|
||||||
All error codes that are larger than the highest documented error code means
|
All error codes that are larger than the highest documented error code means
|
||||||
that curl has existed due to a timeout. There was no nice way for curl to
|
that curl has exited due to a crash. This is a serious error, and we
|
||||||
abort from such a condition and that's why it got this undocumented
|
appreciate a detailed bug report from you that describes how we could go
|
||||||
error. This should not occur in releases after 7.4.1.
|
ahead and repeat this!
|
||||||
|
|
||||||
4.7. How do I keep usernames and passwords secret in Curl command lines?
|
4.7. How do I keep user names and passwords secret in Curl command lines?
|
||||||
|
|
||||||
I see this problem as two parts:
|
This problem has two sides:
|
||||||
|
|
||||||
The first part is to avoid having clear-text passwords in the command line
|
The first part is to avoid having clear-text passwords in the command line
|
||||||
so that they don't appear in 'ps' outputs and similar. That is easily
|
so that they don't appear in 'ps' outputs and similar. That is easily
|
||||||
avoided by using the "-K" option tho tell curl to read parameters from a
|
avoided by using the "-K" option to tell curl to read parameters from a
|
||||||
file or stdin to which you can pass the secret info.
|
file or stdin to which you can pass the secret info.
|
||||||
|
|
||||||
To keep the passwords in your account secret from the rest of the world is
|
To keep the passwords in your account secret from the rest of the world is
|
||||||
@@ -381,19 +507,18 @@ FAQ
|
|||||||
|
|
||||||
Also note that regular HTTP and FTP passwords are sent in clear across the
|
Also note that regular HTTP and FTP passwords are sent in clear across the
|
||||||
network. All it takes for anyone to fetch them is to listen on the network.
|
network. All it takes for anyone to fetch them is to listen on the network.
|
||||||
Evesdropping is very easy.
|
Eavesdropping is very easy.
|
||||||
|
|
||||||
4.8 I found a bug!
|
4.8 I found a bug!
|
||||||
|
|
||||||
It is not a bug if the behaviour is documented. Read the docs first.
|
It is not a bug if the behavior is documented. Read the docs first.
|
||||||
|
|
||||||
If it is a problem with a binary you've downloaded or a package for your
|
If it is a problem with a binary you've downloaded or a package for your
|
||||||
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, post a bug report in the Curl Bug Track System over at
|
||||||
http://sourceforge.net/bugs/?group_id=976 or mail a detailed bug description
|
http://sourceforge.net/bugs/?group_id=976
|
||||||
to curl-bug@haxx.se.
|
|
||||||
|
|
||||||
Always include as many details you can think of, including curl version,
|
Always include as many details you can think of, including curl version,
|
||||||
operating system name and version and complete instructions how to repeat
|
operating system name and version and complete instructions how to repeat
|
||||||
@@ -402,25 +527,29 @@ FAQ
|
|||||||
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
|
NTLM is a Microsoft proprietary protocol. Unfortunately, curl does not
|
||||||
currently support that.
|
currently support that. Proprietary formats are evil. You should not use
|
||||||
|
such ones.
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
|
|
||||||
5.1. Is libcurl thread safe?
|
5.1. Is libcurl thread-safe?
|
||||||
|
|
||||||
We have attempted to write the entire code adjusted for multi-threaded
|
Yes.
|
||||||
programs. If your system has such, curl will attempt to use threadsafe
|
|
||||||
functions instead of non-safe ones.
|
|
||||||
|
|
||||||
I am very interested in once and for all getting some kind of report or
|
We have written the libcurl code specificly adjusted for multi-threaded
|
||||||
README file from those who have used libcurl in a threaded environment,
|
programs. libcurl will use thread-safe functions instead of non-safe ones if
|
||||||
since I haven't and I get this question more and more frequently!
|
your system has such.
|
||||||
|
|
||||||
|
We would appreciate some kind of report or README file from those who have
|
||||||
|
used libcurl in a threaded environment.
|
||||||
|
|
||||||
5.2 How can I receive all data into a large memory chunk?
|
5.2 How can I receive all data into a large memory chunk?
|
||||||
|
|
||||||
|
[ See also the examples/getinmemory.c source ]
|
||||||
|
|
||||||
You are in full control of the callback function that gets called every time
|
You are in full control of the callback function that gets called every time
|
||||||
there is data received from the remote server. You can make that callback do
|
there is data received from the remote server. You can make that callback do
|
||||||
whatever you want. You do not have to write the receivied data to a file.
|
whatever you want. You do not have to write the received data to a file.
|
||||||
|
|
||||||
One solution to this problem could be to have a pointer to a struct that you
|
One solution to this problem could be to have a pointer to a struct that you
|
||||||
pass to the callback function. You set the pointer using the
|
pass to the callback function. You set the pointer using the
|
||||||
@@ -451,90 +580,91 @@ FAQ
|
|||||||
|
|
||||||
5.3 How do I fetch multiple files with libcurl?
|
5.3 How do I fetch multiple files with libcurl?
|
||||||
|
|
||||||
The easy interface of libcurl does not support multiple requests using the
|
Starting with version 7.7, curl and libcurl will have excellent support for
|
||||||
same connection. The only available way to do multiple requests is to
|
transferring multiple files. You should just repeatedly set new URLs with
|
||||||
init/perform/cleanup for each request.
|
curl_easy_setopt() and then transfer it with curl_easy_perform(). The handle
|
||||||
|
you get from curl_easy_init() is not only reusable starting with libcurl
|
||||||
|
7.7, but also you're encouraged to reuse it if you can, as that will enable
|
||||||
|
libcurl to use persistent connections.
|
||||||
|
|
||||||
5.4 Does libcurl do Winsock initing on win32 systems?
|
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.
|
||||||
|
|
||||||
No.
|
5.4 Does libcurl do Winsock initialization on win32 systems?
|
||||||
|
|
||||||
On win32 systems, you need to init the winsock stuff manually, libcurl will
|
Yes (since 7.8.1) if told to in the curl_global_init() call.
|
||||||
not do that for you. WSAStartup() and WSACleanup() should be used
|
|
||||||
accordingly. The reason for this is of course that a single application may
|
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
use several different libraries and parts, and there's no reason for every
|
|
||||||
single library to do this.
|
Yes, but you cannot open a FILE * and pass the pointer to a DLL and have
|
||||||
|
that DLL use the FILE *. If you set CURLOPT_FILE you must also use
|
||||||
|
CURLOPT_WRITEFUNCTION as well to set a function that writes the file, even
|
||||||
|
if that simply writes the data to the specified FILE*. Similarly, if you use
|
||||||
|
CURLOPT_INFILE you must also specify CURLOPT_READFUNCTION.
|
||||||
|
|
||||||
|
(Provided by Joel DeYoung and Bob Schader)
|
||||||
|
|
||||||
|
5.6 What about Keep-Alive or persistent connections?
|
||||||
|
|
||||||
|
Starting with version 7.7, curl and libcurl will have excellent support for
|
||||||
|
persistent connections when transferring several files from the same server.
|
||||||
|
Curl will attempt to reuse connections for all URLs specified on the same
|
||||||
|
command line/config file, and libcurl will reuse connections for all
|
||||||
|
transfers that are made using the same libcurl handle.
|
||||||
|
|
||||||
|
Previous versions had no persistent connection support.
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
|
|
||||||
Curl and libcurl are released under the MPL, the Mozilla Public License. To
|
Curl and libcurl are released under a MIT/X derivate license *or* the MPL,
|
||||||
get a really good answer to your license conflict questions, you should
|
the Mozilla Public License. To get a really good answer to your license
|
||||||
study the MPL license and the license you are about to use and check for
|
conflict questions, you should study the MPL and MIT/X licenses and the
|
||||||
clashes yourself. This section is just a brief summary for the cases we get
|
license you are about to use and check for clashes yourself. This section is
|
||||||
the most questions. (Parts of this section was much enhanced by Bjorn
|
just a brief summary for the cases we get the most questions. (Parts of this
|
||||||
Reese.)
|
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?
|
||||||
|
|
||||||
No, unfortunately you cannot distribute the (lib)curl code with your code.
|
Yes!
|
||||||
According to both the Free Software Foundation and the Mozilla
|
|
||||||
Organization, MPL and GPL are not compatible, because GPL requires of
|
|
||||||
other licenses that they do "not impose any further restrictions on the
|
|
||||||
recipients' exercise of the rights granted herein" [GPL paragraph 6] (One
|
|
||||||
could argue about which license that actually imposes restrictions, but
|
|
||||||
that'll be left for you to ponder about.)
|
|
||||||
|
|
||||||
However, you have two alternative options:
|
Since libcurl may be distributed under the MIT/X derivate license, it can be
|
||||||
|
used together with GPL in any software.
|
||||||
1) Nothing prevents you from distributing your program separately from
|
|
||||||
curl and libcurl, and request that the user receives it separately.
|
|
||||||
The incompability issues between MPL and GPL only applies to the
|
|
||||||
distribution.
|
|
||||||
|
|
||||||
2) Add the following exception to your distribution (you must have the
|
|
||||||
consent of all the copyright holders of the source code in your
|
|
||||||
project in order to do this)
|
|
||||||
|
|
||||||
As a special exception, you have permission to link this program
|
|
||||||
with the curl library and distribute executables, as long as you
|
|
||||||
follow the requirements of the GNU GPL in regard to all of the
|
|
||||||
software in the executable aside from curl.
|
|
||||||
|
|
||||||
This exception must be added to your GPL covered source code files
|
|
||||||
immediately after the notification mentioned in the appendix of GPL.
|
|
||||||
The wording was originally suggested by the Free Software Foundation
|
|
||||||
in relationship with the Qt library. We have changed the wording to
|
|
||||||
apply to curl.
|
|
||||||
|
|
||||||
6.2. I have a closed-source program, can I use the libcurl library?
|
6.2. I have a closed-source program, can I use the libcurl library?
|
||||||
|
|
||||||
Yes, libcurl does not put any restrictions on the program that uses the
|
Yes!
|
||||||
library. If you end up doing changes to the library, only those changes must
|
|
||||||
be made available, not the ones to your program.
|
libcurl does not put any restrictions on the program that uses the library.
|
||||||
|
|
||||||
6.3. I have a BSD licensed program, can I use the libcurl library?
|
6.3. I have a BSD licensed program, can I use the libcurl library?
|
||||||
|
|
||||||
Yes, libcurl does not put any restrictions on the program that uses the
|
Yes!
|
||||||
library. If you end up doing changes to the library, only those changes must
|
|
||||||
be made available, not the ones to your program.
|
libcurl does not put any restrictions on the program that uses the library.
|
||||||
|
|
||||||
6.4. I have a program that uses LGPL libraries, can I use libcurl?
|
6.4. I have a program that uses LGPL libraries, can I use libcurl?
|
||||||
|
|
||||||
Yes you can. LGPL libraries don't spread to other libraries the same way GPL
|
Yes!
|
||||||
ones do.
|
|
||||||
|
|
||||||
However, when you read paragraph (3) of the LGPL license, you'll see that
|
The LGPL license doesn't clash with other licenses.
|
||||||
anyone - at will - may at any time convert that LGPL program into GPL. And
|
|
||||||
GPL programs can't be distributed together with MPL programs, neither with
|
|
||||||
(lib)curl source code and not as a binary.
|
|
||||||
|
|
||||||
6.5. Can I modify curl/libcurl for my program and keep the changes secret?
|
6.5. Can I modify curl/libcurl for my program and keep the changes secret?
|
||||||
|
|
||||||
No, you're not allowed to do that.
|
Yes!
|
||||||
|
|
||||||
|
The MIT/X derivate license practically allows you to do almost anything with
|
||||||
|
the sources, on the condition that the copyright texts in the sources are
|
||||||
|
left intact.
|
||||||
|
|
||||||
6.6. Can you please change the curl/libcurl license to XXXX?
|
6.6. Can you please change the curl/libcurl license to XXXX?
|
||||||
|
|
||||||
No. We carefully picked this license years ago and a large amount of people
|
No.
|
||||||
have contributed with source code knowing that this is the license we
|
|
||||||
use. This license puts the restrictions we want on curl/libcurl and it does
|
We have carefully picked this license after years of development and
|
||||||
not spread to other programs or libraries that use it.
|
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
|
||||||
|
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
|
||||||
|
possible for everyone to use libcurl or curl in their projects, no matter
|
||||||
|
what license they already have in use.
|
||||||
|
|||||||
@@ -17,18 +17,21 @@ 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
|
- compiles on win32 (reported built on 29 operating systems)
|
||||||
- redirectable stderr
|
- redirectable stderr
|
||||||
- use selected network interface for outgoing traffic
|
- use selected network interface for outgoing traffic
|
||||||
|
- IPv6 support
|
||||||
|
- persistant connections
|
||||||
|
|
||||||
HTTP
|
HTTP
|
||||||
|
- HTTP/1.1 compliant
|
||||||
- GET
|
- GET
|
||||||
- PUT
|
- PUT
|
||||||
- HEAD
|
- HEAD
|
||||||
- POST
|
- POST
|
||||||
- multipart POST
|
- multipart POST
|
||||||
- authentication
|
- authentication
|
||||||
- resume
|
- 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
|
||||||
@@ -53,7 +56,7 @@ FTP
|
|||||||
- download
|
- download
|
||||||
- authentication
|
- authentication
|
||||||
- kerberos security
|
- kerberos security
|
||||||
- PORT or PASV
|
- active/passive using PORT, EPRT, PASV or EPSV
|
||||||
- single file size information (compare to HTTP HEAD)
|
- single file size information (compare to HTTP HEAD)
|
||||||
- 'type=' URL support
|
- 'type=' URL support
|
||||||
- dir listing
|
- dir listing
|
||||||
@@ -71,6 +74,7 @@ FTP
|
|||||||
|
|
||||||
TELNET
|
TELNET
|
||||||
- connection negotiation
|
- connection negotiation
|
||||||
|
- custom telnet options
|
||||||
- stdin/stdout I/O
|
- stdin/stdout I/O
|
||||||
|
|
||||||
LDAP (*2)
|
LDAP (*2)
|
||||||
|
|||||||
305
docs/INSTALL
305
docs/INSTALL
@@ -6,26 +6,37 @@
|
|||||||
|
|
||||||
How To Compile
|
How To Compile
|
||||||
|
|
||||||
Curl has been compiled and built on numerous different operating systems. The
|
Curl has been compiled and built on numerous different operating systems.
|
||||||
way to proceed is mainly divided in two different ways: the unix way or the
|
|
||||||
windows way.
|
|
||||||
|
|
||||||
If you're using Windows (95, 98, NT) or OS/2, you should continue reading from
|
Most systems build curl the same way (unix-style). Continue reading below for
|
||||||
the Win32 or OS/2 headers further down. All other systems should be capable of
|
more details if you're one of them.
|
||||||
being installed as described below.
|
|
||||||
|
If you're using Windows (95/98/NT/ME/2000/XP or similar), VMS, RISC OS or OS/2
|
||||||
|
or cross-compile, you should continue reading from one the paragraphs further
|
||||||
|
down.
|
||||||
|
|
||||||
UNIX
|
UNIX
|
||||||
====
|
====
|
||||||
|
|
||||||
The configure script *always* tries to find a working SSL library unless
|
A normal unix installation is made in three or four steps (after you've
|
||||||
explicitly told not to. If you have OpenSSL installed in the default
|
unpacked the source archive):
|
||||||
search path for your compiler/linker, you don't need to do anything
|
|
||||||
special:
|
|
||||||
|
|
||||||
./configure
|
./configure
|
||||||
|
make
|
||||||
|
make test (optional)
|
||||||
|
make install
|
||||||
|
|
||||||
If you have OpenSSL installed in /usr/local/ssl, you can run configure
|
You probably need to be root when doing the last command.
|
||||||
like:
|
|
||||||
|
If you want to install curl in a different file hierarchy than /usr/local,
|
||||||
|
you need to specify that already when running configure:
|
||||||
|
|
||||||
|
./configure --prefix=/path/to/curl/tree
|
||||||
|
|
||||||
|
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
|
||||||
|
path for your compiler/linker, you don't need to do anything special. If
|
||||||
|
you have OpenSSL installed in /usr/local/ssl, you can run configure like:
|
||||||
|
|
||||||
./configure --with-ssl
|
./configure --with-ssl
|
||||||
|
|
||||||
@@ -34,13 +45,13 @@ UNIX
|
|||||||
|
|
||||||
./configure --with-ssl=/opt/OpenSSL
|
./configure --with-ssl=/opt/OpenSSL
|
||||||
|
|
||||||
If you insist on forcing a build *without* SSL support, even though you may
|
If you insist on forcing a build without SSL support, even though you may
|
||||||
have it installed in your system, you can run configure like this:
|
have OpenSSL installed in your system, you can run configure like this:
|
||||||
|
|
||||||
./configure --without-ssl
|
./configure --without-ssl
|
||||||
|
|
||||||
If you have OpenSSL installed, but with the libraries in one place and the
|
If you have OpenSSL installed, but with the libraries in one place and the
|
||||||
header files somewhere else, you'll have to set the LDFLAGS and CPPFLAGS
|
header files somewhere else, you have to set the LDFLAGS and CPPFLAGS
|
||||||
environment variables prior to running configure. Something like this
|
environment variables prior to running configure. Something like this
|
||||||
should work:
|
should work:
|
||||||
|
|
||||||
@@ -54,49 +65,43 @@ UNIX
|
|||||||
env CPPFLAGS="-I/path/to/ssl/include" LDFLAGS="-L/path/to/ssl/lib" \
|
env CPPFLAGS="-I/path/to/ssl/include" LDFLAGS="-L/path/to/ssl/lib" \
|
||||||
./configure
|
./configure
|
||||||
|
|
||||||
If your SSL library was compiled with rsaref (usually for use in
|
If your SSL library was compiled with rsaref (usually for use in the United
|
||||||
the United States), you may also need to set:
|
States), you may also need to set:
|
||||||
|
|
||||||
LIBS=-lRSAglue -lrsaref
|
LIBS=-lRSAglue -lrsaref
|
||||||
(from Doug Kaufman <dkaufman@rahul.net>)
|
(as suggested by Doug Kaufman)
|
||||||
|
|
||||||
Without SSL support, just run:
|
KNOWN PROBLEMS (these ones should not happen anymore)
|
||||||
|
|
||||||
./configure
|
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
|
||||||
Then run:
|
commands (note that this requires curl to be built staticly): (from Ralph
|
||||||
|
Beckmann)
|
||||||
make
|
|
||||||
|
|
||||||
Use the executable `curl` in src/ directory.
|
|
||||||
|
|
||||||
To install curl on your system, run
|
|
||||||
|
|
||||||
make install
|
|
||||||
|
|
||||||
This will copy curl to /usr/local/bin/ (or $prefix/bin if you used the
|
|
||||||
--prefix option to configure) and it copies the man pages, the lib and the
|
|
||||||
include files to suitable places.
|
|
||||||
|
|
||||||
To make sure everything runs as supposed, run the test suite:
|
|
||||||
|
|
||||||
make test
|
|
||||||
|
|
||||||
KNOWN PROBLEMS
|
|
||||||
|
|
||||||
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: (from Ralph Beckmann <rabe@uni-paderborn.de>)
|
|
||||||
|
|
||||||
./configure [...]
|
./configure [...]
|
||||||
cd lib; make; cd ..
|
cd lib; make; cd ..
|
||||||
cd src; make; cd ..
|
cd src; make; cd ..
|
||||||
cp src/curl elsewhere/bin/
|
cp src/curl elsewhere/bin/
|
||||||
|
|
||||||
OPTIONS
|
As suggested by David West, you can make a faked version of autoconf and
|
||||||
|
autoheader:
|
||||||
|
|
||||||
Remember, to force configure to use the standard cc compiler if both
|
----start of autoconf----
|
||||||
cc and gcc are present, run configure like
|
#!/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
|
||||||
|
|
||||||
|
To force configure to use the standard cc compiler if both cc and gcc are
|
||||||
|
present, run configure like
|
||||||
|
|
||||||
CC=cc ./configure
|
CC=cc ./configure
|
||||||
or
|
or
|
||||||
@@ -124,6 +129,9 @@ UNIX
|
|||||||
|
|
||||||
./configure --with-krb4=/usr/athena
|
./configure --with-krb4=/usr/athena
|
||||||
|
|
||||||
|
If you're a curl developer and use gcc, you might want to enable more
|
||||||
|
debug options with the --enable-debug option.
|
||||||
|
|
||||||
Win32
|
Win32
|
||||||
=====
|
=====
|
||||||
|
|
||||||
@@ -132,27 +140,27 @@ Win32
|
|||||||
MingW32 (GCC-2.95) style
|
MingW32 (GCC-2.95) style
|
||||||
------------------------
|
------------------------
|
||||||
Run the 'mingw32.bat' file to get the proper environment variables
|
Run the 'mingw32.bat' file to get the proper environment variables
|
||||||
set, then run 'make -f Makefile.m32' in the lib/ dir and then
|
set, then run 'make mingw32' in the root dir.
|
||||||
'make -f Makefile.m32' in the src/ dir.
|
|
||||||
|
|
||||||
If you have any problems linking libraries or finding header files,
|
If you have any problems linking libraries or finding header files, be
|
||||||
be sure to look at the provided "Makefile.m32" files for the proper
|
sure to verify that the provided "Makefile.m32" files use the proper
|
||||||
paths, and adjust as necessary.
|
paths, and adjust as necessary.
|
||||||
|
|
||||||
Cygwin style
|
Cygwin style
|
||||||
------------
|
------------
|
||||||
Almost identical to the unix installation. Run the configure script
|
Almost identical to the unix installation. Run the configure script in
|
||||||
in the curl root with 'sh configure'. Make sure you have the sh
|
the curl root with 'sh configure'. Make sure you have the sh
|
||||||
executable in /bin/ or you'll see the configure fail towards the
|
executable in /bin/ or you'll see the configure fail towards the end.
|
||||||
end.
|
|
||||||
|
|
||||||
Run 'make'
|
Run 'make'
|
||||||
|
|
||||||
Microsoft command line style
|
Microsoft command line style
|
||||||
----------------------------
|
----------------------------
|
||||||
Run the 'vcvars32.bat' file to get the proper environment variables
|
Run the 'vcvars32.bat' file to get the proper environment variables
|
||||||
set, then run 'nmake -f Makefile.vc6' in the lib/ dir and then
|
set, then run 'nmake vc' in the root dir.
|
||||||
'nmake -f Makefile.vc6' in the src/ dir.
|
|
||||||
|
The vcvars32.bat file is part of the Microsoft development
|
||||||
|
environment.
|
||||||
|
|
||||||
IDE-style
|
IDE-style
|
||||||
-------------------------
|
-------------------------
|
||||||
@@ -163,16 +171,16 @@ Win32
|
|||||||
Make the sources in the src/ drawer be a "win32 console application"
|
Make the sources in the src/ drawer be a "win32 console application"
|
||||||
project. Name it curl.
|
project. Name it curl.
|
||||||
|
|
||||||
With VC++, add 'wsock32.lib' to the link libs when you build curl!
|
With VC++, add 'ws2_32.lib' to the link libs when you build curl!
|
||||||
Borland seems to do that itself magically. Of course you have to
|
Borland seems to do that itself magically. Of course you have to make
|
||||||
make sure it links with the libcurl too!
|
sure it links with the libcurl too!
|
||||||
|
|
||||||
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, as the hugehelp.c
|
Microsoft note: add /Zm200 to the compiler options to increase the
|
||||||
won't compile otherwise due to "too long puts string" or something
|
compiler's memory allocation limit, as the hugehelp.c won't compile
|
||||||
like that!
|
due to "too long puts string".
|
||||||
|
|
||||||
|
|
||||||
With SSL:
|
With SSL:
|
||||||
@@ -180,24 +188,30 @@ Win32
|
|||||||
MingW32 (GCC-2.95) style
|
MingW32 (GCC-2.95) style
|
||||||
------------------------
|
------------------------
|
||||||
Run the 'mingw32.bat' file to get the proper environment variables
|
Run the 'mingw32.bat' file to get the proper environment variables
|
||||||
set, then run 'make -f Makefile.m32 SSL=1' in the lib/ dir and then
|
set, then run 'make mingw32-ssl' in the root dir.
|
||||||
'make -f Makefile.m32 SSL=1' in the src/ dir.
|
|
||||||
|
|
||||||
If you have any problems linking libraries or finding header files,
|
If you have any problems linking libraries or finding header files, be
|
||||||
be sure to look at the provided "Makefile.m32" files for the proper
|
sure to look at the provided "Makefile.m32" files for the proper
|
||||||
paths, and adjust as necessary.
|
paths, and adjust as necessary.
|
||||||
|
|
||||||
Cygwin style
|
Cygwin style
|
||||||
------------
|
------------
|
||||||
|
|
||||||
Haven't done, nor got any reports on how to do. It should although be
|
Haven't done, nor got any reports on how to do. It should although be
|
||||||
identical to the unix setup for the same purpose. See above.
|
identical to the unix setup for the same purpose. See above.
|
||||||
|
|
||||||
Microsoft command line style
|
Microsoft command line style
|
||||||
----------------------------
|
----------------------------
|
||||||
|
Please read the OpenSSL documentation on how to compile and install
|
||||||
|
the OpenSSL library. This generates the libeay32.dll and ssleay32.dll
|
||||||
|
files.
|
||||||
|
|
||||||
Run the 'vcvars32.bat' file to get the proper environment variables
|
Run the 'vcvars32.bat' file to get the proper environment variables
|
||||||
set, then run 'nmake -f Makefile.vc6 release-ssl' in the lib/ dir and
|
set. Edit the makefile.vc6 in the lib directory and define
|
||||||
then 'nmake -f Makefile.vc6' in the src/ dir.
|
OPENSSL_PATH. Set the location of the OpenSSL library and run 'nmake
|
||||||
|
vc-ssl' in the root directory.
|
||||||
|
|
||||||
|
The vcvars32.bat file is part of the Microsoft development
|
||||||
|
environment.
|
||||||
|
|
||||||
Microsoft / Borland style
|
Microsoft / Borland style
|
||||||
-------------------------
|
-------------------------
|
||||||
@@ -224,7 +238,7 @@ IBM OS/2
|
|||||||
If you want to build with OpenSSL or OpenLDAP support, you'll need to
|
If you want to build with OpenSSL or OpenLDAP support, you'll need to
|
||||||
download those libraries, too. Dirk Ohme has done some work to port SSL
|
download those libraries, too. Dirk Ohme has done some work to port SSL
|
||||||
libraries under OS/2, but it looks like he doesn't care about emx. You'll
|
libraries under OS/2, but it looks like he doesn't care about emx. You'll
|
||||||
find his patches on: http://come.to/Dirk.Ohme
|
find his patches on: http://come.to/Dirk_Ohme
|
||||||
|
|
||||||
If during the linking you get an error about _errno being an undefined
|
If during the linking you get an error about _errno being an undefined
|
||||||
symbol referenced from the text segment, you need to add -D__ST_MT_ERRNO__
|
symbol referenced from the text segment, you need to add -D__ST_MT_ERRNO__
|
||||||
@@ -236,38 +250,175 @@ IBM OS/2
|
|||||||
If you're getting huge binaries, probably your makefiles have the -g in
|
If you're getting huge binaries, probably your makefiles have the -g in
|
||||||
CFLAGS.
|
CFLAGS.
|
||||||
|
|
||||||
|
VMS
|
||||||
|
===
|
||||||
|
(The VMS section is in whole contributed by the friendly Nico Baggus)
|
||||||
|
|
||||||
|
This is the first attempt at porting cURL to VMS.
|
||||||
|
|
||||||
|
Curl seems to work with FTP & HTTP other protocols are not tested. (the
|
||||||
|
perl http/ftp testing server supplied as testing too cannot work on VMS
|
||||||
|
because vms has no concept of fork(). [ I tried to give it a whack, but
|
||||||
|
thats of no use.
|
||||||
|
|
||||||
|
SSL stuff has not been ported.
|
||||||
|
|
||||||
|
Telnet has about the same issues as for Win32. When the changes for Win32
|
||||||
|
are clear maybe they'l work for VMS too. The basic problem is that select
|
||||||
|
ONLY works for sockets.
|
||||||
|
|
||||||
|
Marked instances of fopen/[f]stat that might become a problem, especially
|
||||||
|
for non stream files. In this regard, the files opened for writing will be
|
||||||
|
created stream/lf and will thus be safe. Just keep in mind that non-binary
|
||||||
|
read/wring from/to files will have a records size limit of 32767 bytes
|
||||||
|
imposed.
|
||||||
|
|
||||||
|
Stat to get the size of the files is again only safe for stream files &
|
||||||
|
fixed record files without implied CC.
|
||||||
|
|
||||||
|
-- My guess is that only allowing access to stream files is the quickest
|
||||||
|
way to get around the most issues. Therefore all files need to to be
|
||||||
|
checked to be sure they will be stream/lf before processing them. This is
|
||||||
|
the easiest way out, I know. The reason for this is that code that needs to
|
||||||
|
report the filesize will become a pain in the ass otherwise.
|
||||||
|
|
||||||
|
Exit status.... Well we needed something done here,
|
||||||
|
|
||||||
|
VMS has a structured exist status:
|
||||||
|
| 3 | 2 | 1 | 0|
|
||||||
|
|1098|765432109876|5432109876543|210|
|
||||||
|
+----+------------+-------------+---+
|
||||||
|
|Ctrl| Facility | Error code |sev|
|
||||||
|
+----+------------+-------------+---+
|
||||||
|
|
||||||
|
With the Ctrl-bits an application can tell if part or the whole message has
|
||||||
|
allready been printed from the program, DCL doesn't need to print it again.
|
||||||
|
|
||||||
|
Facility - basicaly the program ID. A code assigned to the program
|
||||||
|
the name can be fetched from external or internal message libraries
|
||||||
|
Errorcode - the errodes assigned by the application
|
||||||
|
Sev. - severity: Even = error, off = non error
|
||||||
|
0 = Warning
|
||||||
|
1 = Success
|
||||||
|
2 = Error
|
||||||
|
3 = Information
|
||||||
|
4 = Fatal
|
||||||
|
<5-7> reserved.
|
||||||
|
|
||||||
|
This all presents itself with:
|
||||||
|
%<FACILITY>-<SeV>-<Errorname>, <Error message>
|
||||||
|
|
||||||
|
See also the src/curlmsg.msg file, it has the source for the messages In
|
||||||
|
src/main.c a section is devoted to message status values, the globalvalues
|
||||||
|
create symbols with certain values, referenced from a compiled message
|
||||||
|
file. Have all exit function use a exit status derived from a translation
|
||||||
|
table with the compiled message codes.
|
||||||
|
|
||||||
|
This was all compiled with:
|
||||||
|
|
||||||
|
Compaq C V6.2-003 on OpenVMS Alpha V7.1-1H2
|
||||||
|
|
||||||
|
So far for porting notes as of:
|
||||||
|
13-jul-2001
|
||||||
|
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
|
||||||
|
=============
|
||||||
|
|
||||||
|
(This section was graciously brought to us by Jim Duey, 23-oct-2001)
|
||||||
|
|
||||||
|
Download and unpack the cURL package. Version should be 7.9.1 or later.
|
||||||
|
|
||||||
|
'cd' to the new directory. (ie. curl-7.9.1-pre4)
|
||||||
|
|
||||||
|
Set environment variables to point to the cross-compile toolchain and call
|
||||||
|
configure with any options you need. Be sure and specify the '--host' and
|
||||||
|
'--build' parameters at configuration time. The following script is an
|
||||||
|
example of cross-compiling for the IBM 405GP PowerPC processor using the
|
||||||
|
toolchain from MonteVista for Hardhat Linux.
|
||||||
|
|
||||||
|
(begin script)
|
||||||
|
|
||||||
|
#! /bin/sh
|
||||||
|
|
||||||
|
export PATH=$PATH:/opt/hardhat/devkit/ppc/405/bin
|
||||||
|
export CPPFLAGS="-I/opt/hardhat/devkit/ppc/405/target/usr/include"
|
||||||
|
export AR=ppc_405-ar
|
||||||
|
export AS=ppc_405-as
|
||||||
|
export LD=ppc_405-ld
|
||||||
|
export RANLIB=ppc_405-ranlib
|
||||||
|
export CC=ppc_405-gcc
|
||||||
|
export NM=ppc_405-nm
|
||||||
|
|
||||||
|
configure --target=powerpc-hardhat-linux \
|
||||||
|
--host=powerpc-hardhat-linux \
|
||||||
|
--build=i586-pc-linux-gnu \
|
||||||
|
--prefix=/opt/hardhat/devkit/ppc/405/target/usr/local \
|
||||||
|
--exec-prefix=/usr/local
|
||||||
|
|
||||||
|
(end script)
|
||||||
|
|
||||||
|
The '--prefix' parameter specifies where cURL will be installed. If
|
||||||
|
'configure' completes successfully, do 'make' and 'make install' as usual.
|
||||||
|
|
||||||
PORTS
|
PORTS
|
||||||
=====
|
=====
|
||||||
Just to show off, this is a probably incomplete list of known hardware and
|
This is a probably incomplete list of known hardware and operating systems
|
||||||
operating systems that curl has been compiled for:
|
that curl has been compiled for. If you know one system curl compiles and
|
||||||
|
runs on, that isn't listed, please let us know!
|
||||||
|
|
||||||
- Ultrix
|
|
||||||
- SINIX-Z v5
|
|
||||||
- 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
|
||||||
- Alpha Linux 2.2.16
|
- Alpha Linux 2.2.16
|
||||||
|
- 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
|
||||||
- MIPS IRIX 6.2, 6.5
|
- MIPS IRIX 6.2, 6.5
|
||||||
|
- MIPS Linux
|
||||||
- Power AIX 4.2, 4.3.1, 4.3.2
|
- Power AIX 4.2, 4.3.1, 4.3.2
|
||||||
- PowerPC Darwin 1.0
|
- PowerPC Darwin 1.0
|
||||||
- PowerPC Linux
|
- PowerPC Linux
|
||||||
|
- PowerPC Mac OS 9
|
||||||
- PowerPC Mac OS X
|
- PowerPC Mac OS X
|
||||||
|
- SINIX-Z v5
|
||||||
- Sparc Linux
|
- Sparc Linux
|
||||||
- Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8
|
- Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8
|
||||||
- Sparc SunOS 4.1.*
|
- Sparc SunOS 4.1.X
|
||||||
|
- StrongARM (and other ARM) RISC OS 3.1, 4.02
|
||||||
|
- StrongARM Linux 2.4
|
||||||
|
- StrongARM NetBSD 1.4.1
|
||||||
|
- Ultrix 4.3a
|
||||||
- i386 BeOS
|
- i386 BeOS
|
||||||
- i386 FreeBSD
|
- i386 FreeBSD
|
||||||
|
- i386 HURD
|
||||||
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4
|
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4
|
||||||
- i386 NetBSD
|
- i386 NetBSD
|
||||||
- i386 OS/2
|
- i386 OS/2
|
||||||
- i386 OpenBSD
|
- i386 OpenBSD
|
||||||
|
- i386 SCO unix
|
||||||
- i386 Solaris 2.7
|
- i386 Solaris 2.7
|
||||||
- i386 Windows 95, 98, NT, 2000
|
- i386 Windows 95, 98, ME, NT, 2000
|
||||||
- ia64 Linux 2.3.99
|
- ia64 Linux 2.3.99
|
||||||
- m68k AmigaOS 3
|
- m68k AmigaOS 3
|
||||||
|
- m68k Linux
|
||||||
- m68k OpenBSD
|
- m68k OpenBSD
|
||||||
|
- s390 Linux
|
||||||
|
|
||||||
OpenSSL
|
OpenSSL
|
||||||
=======
|
=======
|
||||||
|
|||||||
319
docs/INTERNALS
319
docs/INTERNALS
@@ -1,3 +1,4 @@
|
|||||||
|
Updated for curl 7.9.1 on November 2, 2001
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -6,15 +7,14 @@
|
|||||||
|
|
||||||
INTERNALS
|
INTERNALS
|
||||||
|
|
||||||
The project is kind of split in two. The library and the client. The client
|
The project is split in two. The library and the client. The client part uses
|
||||||
part uses the library, but the library is meant to be designed to allow other
|
the library, but the library is designed to allow other applications to use
|
||||||
applications to use it.
|
it.
|
||||||
|
|
||||||
Thus, the largest amount of code and complexity is in the library part.
|
The largest amount of code and complexity is in the library part.
|
||||||
|
|
||||||
CVS
|
CVS
|
||||||
===
|
===
|
||||||
|
|
||||||
All changes to the sources are committed to the CVS repository as soon as
|
All changes to the sources are committed to the CVS repository as soon as
|
||||||
they're somewhat verified to work. Changes shall be commited as independently
|
they're somewhat verified to work. Changes shall be commited as independently
|
||||||
as possible so that individual changes can be easier spotted and tracked
|
as possible so that individual changes can be easier spotted and tracked
|
||||||
@@ -27,78 +27,161 @@ Windows vs Unix
|
|||||||
===============
|
===============
|
||||||
|
|
||||||
There are a few differences in how to program curl the unix way compared to
|
There are a few differences in how to program curl the unix way compared to
|
||||||
the Windows way. The four most notable details are:
|
the Windows way. The four perhaps most notable details are:
|
||||||
|
|
||||||
|
1. Different function names for socket operations.
|
||||||
|
|
||||||
|
In curl, this is solved with defines and macros, so that the source looks
|
||||||
|
the same at all places except for the header file that defines them. The
|
||||||
|
macros in use are sclose(), sread() and swrite().
|
||||||
|
|
||||||
|
2. Windows requires a couple of init calls for the socket stuff.
|
||||||
|
|
||||||
|
Those must be made by the application that uses libcurl, in curl that means
|
||||||
|
src/main.c has some code #ifdef'ed to do just that.
|
||||||
|
|
||||||
1. Different function names for close(), read(), write()
|
|
||||||
2. Windows requires a couple of init calls for the socket stuff
|
|
||||||
3. The file descriptors for network communication and file operations are
|
3. The file descriptors for network communication and file operations are
|
||||||
not easily interchangable as in unix
|
not easily interchangable as in unix.
|
||||||
|
|
||||||
|
We avoid this by not trying any funny tricks on file descriptors.
|
||||||
|
|
||||||
4. When writing data to stdout, Windows makes end-of-lines the DOS way, thus
|
4. When writing data to stdout, Windows makes end-of-lines the DOS way, thus
|
||||||
destroying binary data, although you do want that conversion if it is
|
destroying binary data, although you do want that conversion if it is
|
||||||
text coming through... (sigh)
|
text coming through... (sigh)
|
||||||
|
|
||||||
In curl, (1) is made with defines and macros, so that the source looks the
|
We set stdout to binary under windows
|
||||||
same at all places except for the header file that defines them.
|
|
||||||
|
|
||||||
(2) must be made by the application that uses libcurl, in curl that means
|
Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All
|
||||||
src/main.c has some code #ifdef'ed to do just that.
|
|
||||||
|
|
||||||
(3) is simply avoided by not trying any funny tricks on file descriptors.
|
|
||||||
|
|
||||||
(4) we set stdout to binary under windows
|
|
||||||
|
|
||||||
Inside the source code, I do make an effort to avoid '#ifdef WIN32'. 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,
|
||||||
I maintain two config-win32.h files (one in / and one in src/) that are
|
we maintain two config-win32.h files (one in / 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!
|
||||||
|
|
||||||
|
Generally speaking: always remember that this will be compiled on dozens of
|
||||||
|
operating systems. Don't walk on the edge.
|
||||||
|
|
||||||
Library
|
Library
|
||||||
=======
|
=======
|
||||||
|
|
||||||
As described elsewhere, libcurl is meant to get two different "layers" of
|
|
||||||
interfaces. At the present point only the high-level, the "easy", interface
|
|
||||||
has been fully implemented and documented. We assume the easy-interface in
|
|
||||||
this description, the low-level interface will be documented when fully
|
|
||||||
implemented.
|
|
||||||
|
|
||||||
There are plenty of entry points to the library, namely each publicly defined
|
There are plenty of entry points to the library, namely each publicly defined
|
||||||
function that libcurl offers to applications. All of those functions are
|
function that libcurl offers to applications. All of those functions are
|
||||||
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.
|
||||||
|
|
||||||
curl_easy_init() allocates an internal struct and makes some initializations.
|
Starting with libcurl 7.8, curl_global_init_() and curl_global_cleanup() were
|
||||||
The returned handle does not revail internals.
|
introduced. They should be called by the application to initialize and clean
|
||||||
|
up global stuff in the library. As of today, they just do the global SSL
|
||||||
|
initing if SSL is enabled. libcurl itself has no "global" scope.
|
||||||
|
|
||||||
curl_easy_setopt() takes a three arguments, where the option stuff must be
|
All printf()-style functions use the supplied clones in lib/mprintf.c. This
|
||||||
passed in pairs, the parameter-ID and the parameter-value. The list of
|
makes sure we stay absolutely platform independent.
|
||||||
options is documented in the man page.
|
|
||||||
|
curl_easy_init() allocates an internal struct and makes some initializations.
|
||||||
|
The returned handle does not reveal internals. This is the 'SessionHandle'
|
||||||
|
struct which works as an "anchor" struct for all curl_easy functions. All
|
||||||
|
connections performed will get connect-specific data allocated that should be
|
||||||
|
used for things related to particular connections/requests.
|
||||||
|
|
||||||
|
curl_easy_setopt() takes three arguments, where the option stuff must be
|
||||||
|
passed in pairs: the parameter-ID and the parameter-value. The list of
|
||||||
|
options is documented in the man page. This function mainly sets things in
|
||||||
|
the 'SessionHandle' struct.
|
||||||
|
|
||||||
curl_easy_perform() does a whole lot of things:
|
curl_easy_perform() does a whole lot of things:
|
||||||
|
|
||||||
The function analyzes the URL, get the different components and connects to
|
It starts off in the lib/easy.c file by calling Curl_perform() and the main
|
||||||
the remote host. This may involve using a proxy and/or using SSL. The
|
work then continues in lib/url.c. The flow continues with a call to
|
||||||
GetHost() function in lib/hostip.c is used for looking up host names.
|
Curl_connect() to connect to the remote site.
|
||||||
|
|
||||||
When connected, the proper function is called. The functions are named after
|
o Curl_connect()
|
||||||
the protocols they handle. ftp(), http(), dict(), etc. They all reside in
|
|
||||||
their respective files (ftp.c, http.c and dict.c).
|
|
||||||
|
|
||||||
The protocol-specific functions deal with protocol-specific negotiations and
|
... analyzes the URL, it separates the different components and connects to
|
||||||
setup. They have access to the sendf() (from lib/sendf.c) function to send
|
the remote host. This may involve using a proxy and/or using SSL. The
|
||||||
printf-style formatted data to the remote host and when they're ready to make
|
Curl_gethost() function in lib/hostip.c is used for looking up host names.
|
||||||
the actual file transfer they call the Transfer() function (in
|
|
||||||
lib/download.c) to do the transfer. All printf()-style functions use the
|
|
||||||
supplied clones in lib/mprintf.c.
|
|
||||||
|
|
||||||
While transfering, the progress functions in lib/progress.c are called at a
|
When Curl_connect is done, we are connected to the remote site. Then it is
|
||||||
frequent interval (or at the user's choice, a specified callback might get
|
time to tell the server to get a document/file. Curl_do() arranges this.
|
||||||
called). The speedcheck functions in lib/speedcheck.c are also used to verify
|
|
||||||
that the transfer is as fast as required.
|
|
||||||
|
|
||||||
When completed curl_easy_cleanup() should be called to free up used
|
This function makes sure there's an allocated and initiated 'connectdata'
|
||||||
resources.
|
struct that is used for this particular connection only (although there may
|
||||||
|
be several requests performed on the same connect). A bunch of things are
|
||||||
|
inited/inherited from the SessionHandle struct.
|
||||||
|
|
||||||
|
o Curl_do()
|
||||||
|
|
||||||
|
Curl_do() makes sure the proper protocol-specific function is called. The
|
||||||
|
functions are named after the protocols they handle. Curl_ftp(),
|
||||||
|
Curl_http(), Curl_dict(), etc. They all reside in their respective files
|
||||||
|
(ftp.c, http.c and dict.c). HTTPS is handled by Curl_http() and FTPS by
|
||||||
|
Curl_ftp().
|
||||||
|
|
||||||
|
The protocol-specific functions of course deal with protocol-specific
|
||||||
|
negotiations and setup. They have access to the Curl_sendf() (from
|
||||||
|
lib/sendf.c) function to send printf-style formatted data to the remote
|
||||||
|
host and when they're ready to make the actual file transfer they call the
|
||||||
|
Curl_Transfer() function (in lib/transfer.c) to setup the transfer and
|
||||||
|
returns.
|
||||||
|
|
||||||
|
Starting in 7.9.1, if this DO function fails and the connection is being
|
||||||
|
re-used, libcurl will then close this connection, setup a new connection
|
||||||
|
and re-issue the DO request on that. This is because there is no way to be
|
||||||
|
perfectly sure that we have discovered a dead connection before the DO
|
||||||
|
function and thus we might wrongly be re-using a connection that was closed
|
||||||
|
by the remote peer.
|
||||||
|
|
||||||
|
o Transfer()
|
||||||
|
|
||||||
|
Curl_perform() then calls Transfer() in lib/transfer.c that performs
|
||||||
|
the entire file transfer.
|
||||||
|
|
||||||
|
During transfer, the progress functions in lib/progress.c are called at a
|
||||||
|
frequent interval (or at the user's choice, a specified callback might get
|
||||||
|
called). The speedcheck functions in lib/speedcheck.c are also used to
|
||||||
|
verify that the transfer is as fast as required.
|
||||||
|
|
||||||
|
o Curl_done()
|
||||||
|
|
||||||
|
Called after a transfer is done. This function takes care of everything
|
||||||
|
that has to be done after a transfer. This function attempts to leave
|
||||||
|
matters in a state so that Curl_do() should be possible to call again on
|
||||||
|
the same connection (in a persistent connection case). It might also soon
|
||||||
|
be closed with Curl_disconnect().
|
||||||
|
|
||||||
|
o Curl_disconnect()
|
||||||
|
|
||||||
|
When doing normal connections and transfers, no one ever tries to close any
|
||||||
|
connections so this is not normally called when curl_easy_perform() is
|
||||||
|
used. This function is only used when we are certain that no more transfers
|
||||||
|
is going to be made on the connection. It can be also closed by force, or
|
||||||
|
it can be called to make sure that libcurl doesn't keep too many
|
||||||
|
connections alive at the same time (there's a default amount of 5 but that
|
||||||
|
can be changed with the CURLOPT_MAXCONNECTS option).
|
||||||
|
|
||||||
|
This function cleans up all resources that are associated with a single
|
||||||
|
connection.
|
||||||
|
|
||||||
|
Curl_perform() is the function that does the main "connect - do - transfer -
|
||||||
|
done" loop. It loops if there's a Location: to follow.
|
||||||
|
|
||||||
|
When completed, the curl_easy_cleanup() should be called to free up used
|
||||||
|
resources. It runs Curl_disconnect() on all open connectons.
|
||||||
|
|
||||||
|
A quick roundup on internal function sequences (many of these call
|
||||||
|
protocol-specific function-pointers):
|
||||||
|
|
||||||
|
curl_connect - connects to a remote site and does initial connect fluff
|
||||||
|
This also checks for an existing connection to the requested site and uses
|
||||||
|
that one if it is possible.
|
||||||
|
|
||||||
|
curl_do - starts a transfer
|
||||||
|
curl_transfer() - transfers data
|
||||||
|
curl_done - ends a transfer
|
||||||
|
|
||||||
|
curl_disconnect - disconnects from a remote site. This is called when the
|
||||||
|
disconnect is really requested, which doesn't necessarily have to be
|
||||||
|
exactly after curl_done in case we want to keep the connection open for
|
||||||
|
a while.
|
||||||
|
|
||||||
HTTP(S)
|
HTTP(S)
|
||||||
|
|
||||||
@@ -106,9 +189,8 @@ Library
|
|||||||
code. There is a special file (lib/formdata.c) that offers all the multipart
|
code. There is a special file (lib/formdata.c) that offers all the multipart
|
||||||
post functions.
|
post functions.
|
||||||
|
|
||||||
base64-functions for user+password stuff is in (lib/base64.c) and all
|
base64-functions for user+password stuff (and more) is in (lib/base64.c) and
|
||||||
functions for parsing and sending cookies are found in
|
all functions for parsing and sending cookies are found in (lib/cookie.c).
|
||||||
(lib/cookie.c).
|
|
||||||
|
|
||||||
HTTPS uses in almost every means the same procedure as HTTP, with only two
|
HTTPS uses in almost every means the same procedure as HTTP, with only two
|
||||||
exceptions: the connect procedure is different and the function used to read
|
exceptions: the connect procedure is different and the function used to read
|
||||||
@@ -116,11 +198,27 @@ Library
|
|||||||
the source by the use of curl_read() for reading and curl_write() for writing
|
the source by the use of curl_read() for reading and curl_write() for writing
|
||||||
data to the remote server.
|
data to the remote server.
|
||||||
|
|
||||||
|
http_chunks.c contains functions that understands HTTP 1.1 chunked transfer
|
||||||
|
encoding.
|
||||||
|
|
||||||
|
An interesting detail with the HTTP(S) request, is the add_buffer() series of
|
||||||
|
functions we use. They append data to one single buffer, and when the
|
||||||
|
building is done the entire request is sent off in one single write. This is
|
||||||
|
done this way to overcome problems with flawed firewalls and lame servers.
|
||||||
|
|
||||||
FTP
|
FTP
|
||||||
|
|
||||||
The if2ip() function can be used for getting the IP number of a specified
|
The Curl_if2ip() function can be used for getting the IP number of a
|
||||||
network interface, and it resides in lib/if2ip.c. It is only used for the FTP
|
specified network interface, and it resides in lib/if2ip.c.
|
||||||
PORT command.
|
|
||||||
|
Curl_ftpsendf() is used for sending FTP commands to the remote server. It was
|
||||||
|
made a separate function to prevent us programmers from forgetting that they
|
||||||
|
must be CRLF terminated. They must also be sent in one single write() to make
|
||||||
|
firewalls and similar happy.
|
||||||
|
|
||||||
|
Kerberos
|
||||||
|
|
||||||
|
The kerberos support is mainly in lib/krb4.c and lib/security.c.
|
||||||
|
|
||||||
TELNET
|
TELNET
|
||||||
|
|
||||||
@@ -145,26 +243,85 @@ Library
|
|||||||
|
|
||||||
lib/getenv.c offers curl_getenv() which is for reading environment variables
|
lib/getenv.c offers curl_getenv() which is for reading environment variables
|
||||||
in a neat platform independent way. That's used in the client, but also in
|
in a neat platform independent way. That's used in the client, but also in
|
||||||
lib/url.c when checking the proxy environment variables.
|
lib/url.c when checking the proxy environment variables. Note that contrary
|
||||||
|
to the normal unix getenv(), this returns an allocated buffer that must be
|
||||||
|
free()ed after use.
|
||||||
|
|
||||||
lib/netrc.c holds the .netrc parser
|
lib/netrc.c holds the .netrc parser
|
||||||
|
|
||||||
lib/timeval.c features replacement functions for systems that don't have
|
lib/timeval.c features replacement functions for systems that don't have
|
||||||
gettimeofday().
|
gettimeofday() and a few support functions for timeval convertions.
|
||||||
|
|
||||||
A function named curl_version() that returns the full curl version string is
|
A function named curl_version() that returns the full curl version string is
|
||||||
found in lib/version.c.
|
found in lib/version.c.
|
||||||
|
|
||||||
|
If authentication is requested but no password is given, a getpass_r() clone
|
||||||
|
exists in lib/getpass.c. libcurl offers a custom callback that can be used
|
||||||
|
instead of this, but it doesn't change much to us.
|
||||||
|
|
||||||
|
Persistent Connections
|
||||||
|
======================
|
||||||
|
|
||||||
|
The persistent connection support in libcurl requires some considerations on
|
||||||
|
how to do things inside of the library.
|
||||||
|
|
||||||
|
o The 'SessionHandle' struct returned in the curl_easy_init() call must never
|
||||||
|
hold connection-oriented data. It is meant to hold the root data as well as
|
||||||
|
all the options etc that the library-user may choose.
|
||||||
|
o The 'SessionHandle' struct holds the "connection cache" (an array of
|
||||||
|
pointers to 'connectdata' structs). There's one connectdata struct
|
||||||
|
allocated for each connection that libcurl knows about.
|
||||||
|
o This also enables the 'curl handle' to be reused on subsequent transfers,
|
||||||
|
something that was illegal before libcurl 7.7.
|
||||||
|
o When we are about to perform a transfer with curl_easy_perform(), we first
|
||||||
|
check for an already existing connection in the cache that we can use,
|
||||||
|
otherwise we create a new one and add to the cache. If the cache is full
|
||||||
|
already when we add a new connection, we close one of the present ones. We
|
||||||
|
select which one to close dependent on the close policy that may have been
|
||||||
|
previously set.
|
||||||
|
o When the transfer operation is complete, we try to leave the connection
|
||||||
|
open. Particular options may tell us not to, and protocols may signal
|
||||||
|
closure on connections and then we don't keep it open of course.
|
||||||
|
o When curl_easy_cleanup() is called, we close all still opened connections.
|
||||||
|
|
||||||
|
You do realize that the curl handle must be re-used in order for the
|
||||||
|
persistent connections to work.
|
||||||
|
|
||||||
|
Library Symbols
|
||||||
|
===============
|
||||||
|
|
||||||
|
All symbols used internally in libcurl must use a 'Curl_' prefix if they're
|
||||||
|
used in more than a single file. Single-file symbols must be made static.
|
||||||
|
Public ("exported") symbols must use a 'curl_' prefix. (There are exceptions,
|
||||||
|
but they are to be changed to follow this pattern in future versions.)
|
||||||
|
|
||||||
|
Return Codes and Informationals
|
||||||
|
===============================
|
||||||
|
|
||||||
|
I've made things simple. Almost every function in libcurl returns a CURLcode,
|
||||||
|
that must be CURLE_OK if everything is OK or otherwise a suitable error code
|
||||||
|
as the curl/curl.h include file defines. The very spot that detects an error
|
||||||
|
must use the Curl_failf() function to set the human-readable error
|
||||||
|
description.
|
||||||
|
|
||||||
|
In aiding the user to understand what's happening and to debug curl usage, we
|
||||||
|
must supply a fair amount of informational messages by using the Curl_infof()
|
||||||
|
function. Those messages are only displayed when the user explicitly asks for
|
||||||
|
them. They are best used when revealing information that isn't otherwise
|
||||||
|
obvious.
|
||||||
|
|
||||||
Client
|
Client
|
||||||
======
|
======
|
||||||
|
|
||||||
main() resides in src/main.c together with most of the client code.
|
main() resides in src/main.c together with most of the client code.
|
||||||
|
|
||||||
src/hugehelp.c is automatically generated by the mkhelp.pl perl script to
|
src/hugehelp.c is automatically generated by the mkhelp.pl perl script to
|
||||||
display the complete "manual" and the src/urlglob.c file holds the functions
|
display the complete "manual" and the src/urlglob.c file holds the functions
|
||||||
used for the multiple-URL support.
|
used for the URL-"globbing" support. Globbing in the sense that the {} and []
|
||||||
|
expansion stuff is there.
|
||||||
|
|
||||||
The client mostly mess around to setup its config struct properly, then it
|
The client mostly messes around to setup its 'config' struct properly, then
|
||||||
calls the curl_easy_*() functions of the library and when it gets back
|
it calls the curl_easy_*() functions of the library and when it gets back
|
||||||
control after the curl_easy_perform() it cleans up the library, checks status
|
control after the curl_easy_perform() it cleans up the library, checks status
|
||||||
and exits.
|
and exits.
|
||||||
|
|
||||||
@@ -173,10 +330,31 @@ Client
|
|||||||
curl_easy_getinfo() function to extract useful information from the curl
|
curl_easy_getinfo() function to extract useful information from the curl
|
||||||
session.
|
session.
|
||||||
|
|
||||||
|
Recent versions may loop and do all this several times if many URLs were
|
||||||
|
specified on the command line or config file.
|
||||||
|
|
||||||
|
Memory Debugging
|
||||||
|
================
|
||||||
|
|
||||||
|
The file lib/memdebug.c contains debug-versions of a few functions. Functions
|
||||||
|
such as malloc, free, fopen, fclose, etc that somehow deal with resources
|
||||||
|
that might give us problems if we "leak" them. The functions in the memdebug
|
||||||
|
system do nothing fancy, they do their normal function and then log
|
||||||
|
information about what they just did. The logged data can then be analyzed
|
||||||
|
after a complete session,
|
||||||
|
|
||||||
|
memanalyze.pl is the perl script present only present in CVS (not part of the
|
||||||
|
release archives) that analyzes a log file generated by the memdebug
|
||||||
|
system. It detects if resources are allocated but never freed and other kinds
|
||||||
|
of errors related to resource management.
|
||||||
|
|
||||||
|
Use -DMALLOCDEBUG when compiling to enable memory debugging, this is also
|
||||||
|
switched on by running configure with --enable-debug.
|
||||||
|
|
||||||
Test Suite
|
Test Suite
|
||||||
==========
|
==========
|
||||||
|
|
||||||
During November 2000, a test suite has evolved. It is placed in its own
|
Since November 2000, a test suite has evolved. It is placed in its own
|
||||||
subdirectory directly off the root in the curl archive tree, and it contains
|
subdirectory directly off the root in the curl archive tree, and it contains
|
||||||
a bunch of scripts and a lot of test case data.
|
a bunch of scripts and a lot of test case data.
|
||||||
|
|
||||||
@@ -184,5 +362,20 @@ Test Suite
|
|||||||
httpserver.pl and ftpserver.pl before all the test cases are performed. The
|
httpserver.pl and ftpserver.pl before all the test cases are performed. The
|
||||||
test suite currently only runs on unix-like platforms.
|
test suite currently only runs on unix-like platforms.
|
||||||
|
|
||||||
You'll find a complete description of the test case data files in the README
|
You'll find a complete description of the test case data files in the
|
||||||
file in the test directory.
|
tests/README file.
|
||||||
|
|
||||||
|
The test suite automatically detects if curl was built with the memory
|
||||||
|
debugging enabled, and if it was it will detect memory leaks too.
|
||||||
|
|
||||||
|
Building Releases
|
||||||
|
=================
|
||||||
|
|
||||||
|
There's no magic to this. When you consider everything stable enough to be
|
||||||
|
released, run the 'maketgz' script (using 'make distcheck' will give you a
|
||||||
|
pretty good view on the status of the current sources). maketgz prompts for
|
||||||
|
version number of the client and the library before it creates a release
|
||||||
|
archive. maketgz uses 'make dist' for the actual archive building, why you
|
||||||
|
need to fill in the Makefile.am files properly for which files that should
|
||||||
|
be included in the release archives.
|
||||||
|
|
||||||
|
|||||||
163
docs/MANUAL
163
docs/MANUAL
@@ -15,22 +15,26 @@ SIMPLE USAGE
|
|||||||
|
|
||||||
curl ftp://ftp.funet.fi/README
|
curl ftp://ftp.funet.fi/README
|
||||||
|
|
||||||
Get a gopher document from funet's gopher server:
|
|
||||||
|
|
||||||
curl gopher://gopher.funet.fi
|
|
||||||
|
|
||||||
Get a web page from a server using port 8000:
|
Get a web page from a server using port 8000:
|
||||||
|
|
||||||
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 the root directory of an FTP site:
|
||||||
|
|
||||||
curl ftp://ftp.fts.frontec.se/
|
curl ftp://cool.haxx.se/
|
||||||
|
|
||||||
|
Get a gopher document from funet's gopher server:
|
||||||
|
|
||||||
|
curl gopher://gopher.funet.fi
|
||||||
|
|
||||||
Get the definition of curl from a dictionary:
|
Get the definition of curl from a dictionary:
|
||||||
|
|
||||||
curl dict://dict.org/m:curl
|
curl dict://dict.org/m:curl
|
||||||
|
|
||||||
|
Fetch two documents at once:
|
||||||
|
|
||||||
|
curl ftp://cool.haxx.se/ http://www.weirdserver.com:8000/
|
||||||
|
|
||||||
DOWNLOAD TO A FILE
|
DOWNLOAD TO A FILE
|
||||||
|
|
||||||
Get a web page and store in a local file:
|
Get a web page and store in a local file:
|
||||||
@@ -43,6 +47,10 @@ DOWNLOAD TO A FILE
|
|||||||
|
|
||||||
curl -O http://www.netscape.com/index.html
|
curl -O http://www.netscape.com/index.html
|
||||||
|
|
||||||
|
Fetch two files and store them with their remote names:
|
||||||
|
|
||||||
|
curl -O www.haxx.se/index.html -O curl.haxx.se/download.html
|
||||||
|
|
||||||
USING PASSWORDS
|
USING PASSWORDS
|
||||||
|
|
||||||
FTP
|
FTP
|
||||||
@@ -124,7 +132,7 @@ UPLOADING
|
|||||||
|
|
||||||
Upload all data on stdin to a specified ftp site:
|
Upload all data on stdin to a specified ftp site:
|
||||||
|
|
||||||
curl -t ftp://ftp.upload.com/myfile
|
curl -T - ftp://ftp.upload.com/myfile
|
||||||
|
|
||||||
Upload data from a specified file, login with user and password:
|
Upload data from a specified file, login with user and password:
|
||||||
|
|
||||||
@@ -149,7 +157,7 @@ UPLOADING
|
|||||||
|
|
||||||
Upload all data on stdin to a specified http site:
|
Upload all data on stdin to a specified http site:
|
||||||
|
|
||||||
curl -t http://www.upload.com/myfile
|
curl -T - http://www.upload.com/myfile
|
||||||
|
|
||||||
Note that the http server must've been configured to accept PUT before this
|
Note that the http server must've been configured to accept PUT before this
|
||||||
can be done successfully.
|
can be done successfully.
|
||||||
@@ -178,7 +186,7 @@ DETAILED INFORMATION
|
|||||||
-D/--dump-header option when getting files from both FTP and HTTP, and it
|
-D/--dump-header option when getting files from both FTP and HTTP, and it
|
||||||
will then store the headers in the specified file.
|
will then store the headers in the specified file.
|
||||||
|
|
||||||
Store the HTTP headers in a separate file:
|
Store the HTTP headers in a separate file (headers.txt in the example):
|
||||||
|
|
||||||
curl --dump-header headers.txt curl.haxx.se
|
curl --dump-header headers.txt curl.haxx.se
|
||||||
|
|
||||||
@@ -237,32 +245,32 @@ 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 which content type the file is, by appending
|
you can also specify the file content type by appending ';type=<mime type>'
|
||||||
';type=<mime type>' to the file name. You can also post contents of several
|
to the file name. You can also post the contents of several files in one field.
|
||||||
files in one field. So that the field name 'coolfiles' can be sent three
|
For example, the field name 'coolfiles' is used to send three files, with
|
||||||
files with different content types in a manner similar to:
|
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 content-type is not specified, curl will try to guess from the extension
|
If the content-type is not specified, curl will try to guess from the file
|
||||||
(it only knows a few), or use the previously specified type (from an earlier
|
extension (it only knows a few), or use the previously specified type
|
||||||
file if several files are specified in a list) or finally using the default
|
(from an earlier file if several files are specified in a list) or else it
|
||||||
type 'text/plain'.
|
will 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 check out the HTML of the form page to get to
|
favourite browser, you have to read the HTML source of the form page and find
|
||||||
know the names of the input fields. In our example, the input field names are
|
the names of the input fields. In our example, the input field names are
|
||||||
'file', 'yourname' and 'filedescription'.
|
'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" \
|
||||||
http://www.post.com/postit.cgi
|
http://www.post.com/postit.cgi
|
||||||
|
|
||||||
So, to send two files in one post you can do it in two ways:
|
To send two files in one post you can do it in two ways:
|
||||||
|
|
||||||
1. Send multiple files in a single "field" with a single field name:
|
1. Send multiple files in a single "field" with a single field name:
|
||||||
|
|
||||||
@@ -272,11 +280,11 @@ POST (HTTP)
|
|||||||
|
|
||||||
curl -F "docpicture=@dog.gif" -F "catpicture=@cat.gif"
|
curl -F "docpicture=@dog.gif" -F "catpicture=@cat.gif"
|
||||||
|
|
||||||
REFERER
|
REFERRER
|
||||||
|
|
||||||
A HTTP request has the option to include information about which address
|
A HTTP request has the option to include information about which address
|
||||||
that referred to actual page, and curl allows the user to specify that
|
that referred to actual page. Curl allows you to specify the
|
||||||
referrer to get specified on the command line. It is especially useful to
|
referrer to be used on the command line. It is especially useful to
|
||||||
fool or trick stupid servers or CGI scripts that rely on that information
|
fool or trick stupid servers or CGI scripts that rely on that information
|
||||||
being available or contain certain data.
|
being available or contain certain data.
|
||||||
|
|
||||||
@@ -345,13 +353,17 @@ COOKIES
|
|||||||
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
|
||||||
use a non-existing file to trig the cookie awareness like:
|
use a non-existing file to trigger the cookie awareness like:
|
||||||
|
|
||||||
curl -L -b empty-file www.example.com
|
curl -L -b empty.txt www.example.com
|
||||||
|
|
||||||
The file to read cookies from must be formatted using plain HTTP headers OR
|
The file to read cookies from must be formatted using plain HTTP headers OR
|
||||||
as netscape's cookie file. Curl will determine what kind it is based on the
|
as netscape's cookie file. Curl will determine what kind it is based on the
|
||||||
file contents.
|
file contents. In the above command, curl will parse the header and store
|
||||||
|
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
|
||||||
|
file "empty.txt" may be a non-existant file.
|
||||||
|
|
||||||
|
|
||||||
PROGRESS METER
|
PROGRESS METER
|
||||||
|
|
||||||
@@ -384,12 +396,12 @@ PROGRESS METER
|
|||||||
|
|
||||||
SPEED LIMIT
|
SPEED LIMIT
|
||||||
|
|
||||||
Curl offers the user to set conditions regarding transfer speed that must
|
Curl allows the user to set the transfer speed conditions that must be met
|
||||||
be met to let the transfer keep going. By using the switch -y and -Y you
|
to let the transfer keep going. By using the switch -y and -Y you
|
||||||
can make curl abort transfers if the transfer speed doesn't exceed your
|
can make curl abort transfers if the transfer speed is below the specified
|
||||||
given lowest limit for a specified time.
|
lowest limit for a specified time.
|
||||||
|
|
||||||
To let curl abandon downloading this page if its 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
|
||||||
@@ -455,9 +467,13 @@ EXTRA HEADERS
|
|||||||
|
|
||||||
curl -H "X-you-and-me: yes" www.love.com
|
curl -H "X-you-and-me: yes" www.love.com
|
||||||
|
|
||||||
This can also be useful in case you want curl to send a different text in
|
This can also be useful in case you want curl to send a different text in a
|
||||||
a header than it normally does. The -H header you specify then replaces the
|
header than it normally does. The -H header you specify then replaces the
|
||||||
header curl would normally send.
|
header curl would normally send. If you replace an internal header with an
|
||||||
|
empty one, you prevent that header from being sent. To prevent the Host:
|
||||||
|
header from being used:
|
||||||
|
|
||||||
|
curl -H "Host:" www.server.com
|
||||||
|
|
||||||
FTP and PATH NAMES
|
FTP and PATH NAMES
|
||||||
|
|
||||||
@@ -575,7 +591,7 @@ HTTPS
|
|||||||
Run the 'openssl' application to convert the certificate. If you cd to the
|
Run the 'openssl' application to convert the certificate. If you cd to the
|
||||||
openssl installation, you can do it like:
|
openssl installation, you can do it like:
|
||||||
|
|
||||||
# ./apps/openssl pkcs12 -certfile [file you saved] -out [PEMfile]
|
# ./apps/openssl pkcs12 -in [file you saved] -clcerts -out [PEMfile]
|
||||||
|
|
||||||
|
|
||||||
RESUMING FILE TRANSFERS
|
RESUMING FILE TRANSFERS
|
||||||
@@ -585,20 +601,20 @@ 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.
|
||||||
|
|
||||||
(*2) = This requires that the wb server supports at least HTTP/1.1. If it
|
(*2) = This requires that the web server supports at least HTTP/1.1. If it
|
||||||
doesn't, curl will say so.
|
doesn't, curl will say so.
|
||||||
|
|
||||||
TIME CONDITIONS
|
TIME CONDITIONS
|
||||||
@@ -726,16 +742,71 @@ KERBEROS4 FTP TRANSFER
|
|||||||
There's no use for a password on the -u switch, but a blank one will make
|
There's no use for a password on the -u switch, but a blank one will make
|
||||||
curl ask for one and you already entered the real password to kauth.
|
curl ask for one and you already entered the real password to kauth.
|
||||||
|
|
||||||
MAILING LIST
|
TELNET
|
||||||
|
|
||||||
We have an open mailing list to discuss curl, its development and things
|
The curl telnet support is basic and very easy to use. Curl passes all data
|
||||||
relevant to this.
|
passed to it on stdin to the remote server. Connect to a remote telnet
|
||||||
|
server using a command line similar to:
|
||||||
|
|
||||||
To subscribe, mail curl-request@contactor.se with "subscribe <fill in your
|
curl telnet://remote.server.com
|
||||||
email address>" in the body.
|
|
||||||
|
|
||||||
To post to the list, mail curl@contactor.se.
|
And enter the data to pass to the server on stdin. The result will be sent
|
||||||
|
to stdout or to the file you specify with -o.
|
||||||
|
|
||||||
To unsubcribe, mail curl-request@contactor.se with "unsubscribe <your
|
You might want the -N/--no-buffer option to switch off the buffered output
|
||||||
subscribed email address>" in the body.
|
for slow connections or similar.
|
||||||
|
|
||||||
|
Pass options to the telnet protocol negotiation, by using the -t option. To
|
||||||
|
tell the server we use a vt100 terminal, try something like:
|
||||||
|
|
||||||
|
curl -tTTYPE=vt100 telnet://remote.server.com
|
||||||
|
|
||||||
|
Other interesting options for it -t include:
|
||||||
|
|
||||||
|
- XDISPLOC=<X display> Sets the X display location.
|
||||||
|
|
||||||
|
- NEW_ENV=<var,val> Sets an environment variable.
|
||||||
|
|
||||||
|
NOTE: the telnet protocol does not specify any way to login with a specified
|
||||||
|
user and password so curl can't do that automatically. To do that, you need
|
||||||
|
to track when the login prompt is received and send the username and
|
||||||
|
password accordingly.
|
||||||
|
|
||||||
|
PERSISTANT CONNECTIONS
|
||||||
|
|
||||||
|
Specifying multiple files on a single command line will make curl transfer
|
||||||
|
all of them, one after the other in the specified order.
|
||||||
|
|
||||||
|
libcurl will attempt to use persistant connections for the transfers so that
|
||||||
|
the second transfer to the same host can use the same connection that was
|
||||||
|
already initiated and was left open in the previous transfer. This greatly
|
||||||
|
decreases connection time for all but the first transfer and it makes a far
|
||||||
|
better use of the network.
|
||||||
|
|
||||||
|
Note that curl cannot use persistant connections for transfers that are used
|
||||||
|
in subsequence curl invokes. Try to stuff as many URLs as possible on the
|
||||||
|
same command line if they are using the same host, as that'll make the
|
||||||
|
transfers faster. If you use a http proxy for file transfers, practicly
|
||||||
|
all transfers will be persistant.
|
||||||
|
|
||||||
|
Persistant connections were introduced in curl 7.7.
|
||||||
|
|
||||||
|
MAILING LISTS
|
||||||
|
|
||||||
|
For your convenience, we have several open mailing lists to discuss curl,
|
||||||
|
its development and things relevant to this.
|
||||||
|
|
||||||
|
To subscribe to the main curl list, mail curl-request@contactor.se with
|
||||||
|
"subscribe <fill in your email address>" in the body.
|
||||||
|
|
||||||
|
To subscribe to the curl-library users/deverlopers list, follow the
|
||||||
|
instructions at http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
To subscribe to the curl-announce list, to only get information about new
|
||||||
|
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
|
||||||
|
discussed, follow the instructions at http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
Please direct curl questions, feature requests and trouble reports to one of
|
||||||
|
these mailing lists instead of mailing any individual.
|
||||||
|
|||||||
@@ -6,17 +6,72 @@ AUTOMAKE_OPTIONS = foreign no-dependencies
|
|||||||
|
|
||||||
man_MANS = \
|
man_MANS = \
|
||||||
curl.1 \
|
curl.1 \
|
||||||
|
curl-config.1 \
|
||||||
curl_easy_cleanup.3 \
|
curl_easy_cleanup.3 \
|
||||||
curl_easy_getinfo.3 \
|
curl_easy_getinfo.3 \
|
||||||
curl_easy_init.3 \
|
curl_easy_init.3 \
|
||||||
curl_easy_perform.3 \
|
curl_easy_perform.3 \
|
||||||
curl_easy_setopt.3 \
|
curl_easy_setopt.3 \
|
||||||
|
curl_easy_duphandle.3 \
|
||||||
curl_formparse.3 \
|
curl_formparse.3 \
|
||||||
|
curl_formadd.3 \
|
||||||
|
curl_formfree.3 \
|
||||||
curl_getdate.3 \
|
curl_getdate.3 \
|
||||||
curl_getenv.3 \
|
curl_getenv.3 \
|
||||||
curl_slist_append.3 \
|
curl_slist_append.3 \
|
||||||
curl_slist_free_all.3 \
|
curl_slist_free_all.3 \
|
||||||
curl_version.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
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS)
|
SUBDIRS = examples
|
||||||
|
|
||||||
|
HTMLPAGES = \
|
||||||
|
curl.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
|
||||||
|
|
||||||
|
EXTRA_DIST = $(man_MANS) \
|
||||||
|
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
||||||
|
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS \
|
||||||
|
VERSIONS $(HTMLPAGES)
|
||||||
|
|
||||||
|
MAN2HTML= gnroff -man $< | man2html >$@
|
||||||
|
|
||||||
|
SUFFIXES = .1 .3 .html
|
||||||
|
|
||||||
|
html: $(HTMLPAGES)
|
||||||
|
|
||||||
|
.3.html:
|
||||||
|
$(MAN2HTML)
|
||||||
|
|
||||||
|
.1.html:
|
||||||
|
$(MAN2HTML)
|
||||||
|
|||||||
@@ -1,61 +0,0 @@
|
|||||||
_ _ _ _
|
|
||||||
| (_) |__ ___ _ _ _ __| |
|
|
||||||
| | | '_ \ / __| | | | '__| |
|
|
||||||
| | | |_) | (__| |_| | | | |
|
|
||||||
|_|_|_.__/ \___|\__,_|_| |_|
|
|
||||||
|
|
||||||
|
|
||||||
How To Use Libcurl In Your Program
|
|
||||||
|
|
||||||
Interfaces
|
|
||||||
|
|
||||||
libcurl currently offers two different interfaces to the URL transfer
|
|
||||||
engine. They can be seen as one low-level and one high-level, in the sense
|
|
||||||
that the low-level one will allow you to deal with a lot more details but on
|
|
||||||
the other hand not offer as many fancy features (such as Location:
|
|
||||||
following). The high-level interface is supposed to be a built-in
|
|
||||||
implementation of the low-level interface. You will not be able to mix
|
|
||||||
function calls from the different layers.
|
|
||||||
|
|
||||||
As we currently ONLY support the high-level interface, the so called easy
|
|
||||||
interface, I will not attempt to describe any low-level functions at this
|
|
||||||
point.
|
|
||||||
|
|
||||||
Function descriptions
|
|
||||||
|
|
||||||
The interface is meant to be very simple for very simple
|
|
||||||
implementations. Thus, we have minimized the number of entries.
|
|
||||||
|
|
||||||
The Easy Interface
|
|
||||||
|
|
||||||
When using the easy interface, you init your easy-session and get a handle,
|
|
||||||
which you use as input to the following interface functions you use.
|
|
||||||
|
|
||||||
You continue by setting all the options you want in the upcoming transfer,
|
|
||||||
most important among them is the URL itself. You might want to set some
|
|
||||||
callbacks as well that will be called from the library when data is available
|
|
||||||
etc.
|
|
||||||
|
|
||||||
When all is setup, you tell libcurl to perform the transfer. It will then do
|
|
||||||
the entire operation and won't return until it is done or failed.
|
|
||||||
|
|
||||||
After the transfer has been made, you cleanup the easy-session's handle and
|
|
||||||
libcurl is entirely off the hook!
|
|
||||||
|
|
||||||
curl_easy_init()
|
|
||||||
curl_easy_setopt()
|
|
||||||
curl_easy_perform()
|
|
||||||
curl_easy_cleanup()
|
|
||||||
|
|
||||||
While the above four functions are the main functions to use in the easy
|
|
||||||
interface, there is a series of helpful functions to use. They are:
|
|
||||||
|
|
||||||
curl_version() - displays the libcurl version
|
|
||||||
curl_getdate() - converts a date string to time_t
|
|
||||||
curl_getenv() - portable environment variable reader
|
|
||||||
curl_formparse() - helps building a HTTP form POST
|
|
||||||
curl_slist_append() - builds a linked list
|
|
||||||
curl_slist_free_all() - frees a whole curl_slist
|
|
||||||
|
|
||||||
Read the separate man pages for these functions for details!
|
|
||||||
|
|
||||||
@@ -12,13 +12,11 @@ README.win32
|
|||||||
systems. While not being the main develop target, a fair share of curl users
|
systems. While not being the main develop target, a fair share of curl users
|
||||||
are win32-based.
|
are win32-based.
|
||||||
|
|
||||||
Some documentation in this archive will be tricky to read for Windows
|
The unix-style man pages are tricky to read on windows, so therefore are all
|
||||||
people, as they come in unix-style man pages. You can either download a
|
those pages also converted to HTML and those are also included in the
|
||||||
freely available nroff binary for win32 (*pointers appriciated*), convert
|
release archives.
|
||||||
the files into plain-text on your neighbor's unix machine or run over to the
|
|
||||||
curl web site and view them as plain HTML.
|
|
||||||
|
|
||||||
The main curl.1 man page is "built-in". Use a command line similar to this
|
The main curl.1 man page is also "built-in" in the command line tool. Use a
|
||||||
in order to extract a separate text file:
|
command line similar to this in order to extract a separate text file:
|
||||||
|
|
||||||
curl -M >manual.txt
|
curl -M >manual.txt
|
||||||
|
|||||||
@@ -100,7 +100,13 @@ Similar Tools
|
|||||||
|
|
||||||
swebget - http://www.uni-hildesheim.de/~smol0075/swebget/
|
swebget - http://www.uni-hildesheim.de/~smol0075/swebget/
|
||||||
|
|
||||||
Kermit - http://www.columbia.edu/kermit/ftpclient/
|
Kermit - http://www.columbia.edu/kermit/ftpclient
|
||||||
|
|
||||||
|
Pavuk - http://www.idata.sk/~ondrej/pavuk/
|
||||||
|
|
||||||
|
httpr - http://zwolak.dhs.org/httpr/
|
||||||
|
|
||||||
|
puf - http://www.inf.tu-dresden.de/~ob6/sw/puf.html
|
||||||
|
|
||||||
Related Software
|
Related Software
|
||||||
----------------
|
----------------
|
||||||
|
|||||||
81
docs/THANKS
Normal file
81
docs/THANKS
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
This project has been alive for several years. Countless people have provided
|
||||||
|
feedback that have improved curl. Here follows a (incomplete) list of people
|
||||||
|
that have contributed with non-trivial parts:
|
||||||
|
|
||||||
|
- Daniel Stenberg <daniel@haxx.se>
|
||||||
|
- Rafael Sagula <sagula@inf.ufrgs.br>
|
||||||
|
- Sampo Kellomaki <sampo@iki.fi>
|
||||||
|
- Linas Vepstas <linas@linas.org>
|
||||||
|
- Bjorn Reese <breese@mail1.stofanet.dk>
|
||||||
|
- Johan Anderson <johan@homemail.com>
|
||||||
|
- Kjell Ericson <Kjell.Ericson@haxx.se>
|
||||||
|
- Troy Engel <tengel@sonic.net>
|
||||||
|
- Ryan Nelson <ryan@inch.com>
|
||||||
|
- Bj<42>rn Stenberg <bjorn@haxx.se>
|
||||||
|
- Angus Mackay <amackay@gus.ml.org>
|
||||||
|
- Eric Young <eay@cryptsoft.com>
|
||||||
|
- Simon Dick <simond@totally.irrelevant.org>
|
||||||
|
- Oren Tirosh <oren@monty.hishome.net>
|
||||||
|
- Steven G. Johnson <stevenj@alum.mit.edu>
|
||||||
|
- Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu>
|
||||||
|
- Andr<64>s Garc<72>a <ornalux@redestb.es>
|
||||||
|
- Douglas E. Wegscheid <wegscd@whirlpool.com>
|
||||||
|
- Mark Butler <butlerm@xmission.com>
|
||||||
|
- Eric Thelin <eric@generation-i.com>
|
||||||
|
- Marc Boucher <marc@mbsi.ca>
|
||||||
|
- Greg Onufer <Greg.Onufer@Eng.Sun.COM>
|
||||||
|
- Doug Kaufman <dkaufman@rahul.net>
|
||||||
|
- David Eriksson <david@2good.com>
|
||||||
|
- Ralph Beckmann <rabe@uni-paderborn.de>
|
||||||
|
- T. Yamada <tai@imasy.or.jp>
|
||||||
|
- Lars J. Aas <larsa@sim.no>
|
||||||
|
- J<>rn Hartroth <Joern.Hartroth@computer.org>
|
||||||
|
- Matthew Clarke <clamat@van.maves.ca>
|
||||||
|
- Linus Nielsen Feltzing <linus@haxx.se>
|
||||||
|
- Felix von Leitner <felix@convergence.de>
|
||||||
|
- Dan Zitter <dzitter@zitter.net>
|
||||||
|
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
||||||
|
- Chris Maltby <chris@aurema.com>
|
||||||
|
- Ron Zapp <rzapper@yahoo.com>
|
||||||
|
- Paul Marquis <pmarquis@iname.com>
|
||||||
|
- Ellis Pritchard <ellis@citria.com>
|
||||||
|
- Damien Adant <dams@usa.net>
|
||||||
|
- Chris <cbayliss@csc.come>
|
||||||
|
- Marco G. Salvagno <mgs@whiz.cjb.net>
|
||||||
|
- Paul Marquis <pmarquis@iname.com>
|
||||||
|
- David LeBlanc <dleblanc@qnx.com>
|
||||||
|
- Rich Gray at Plus Technologies
|
||||||
|
- Luong Dinh Dung <u8luong@lhsystems.hu>
|
||||||
|
- Torsten Foertsch <torsten.foertsch@gmx.net>
|
||||||
|
- Kristian K<>hntopp <kris@koehntopp.de>
|
||||||
|
- Fred Noz <FNoz@siac.com>
|
||||||
|
- Caolan McNamara <caolan@csn.ul.ie>
|
||||||
|
- Albert Chin-A-Young <china@thewrittenword.com>
|
||||||
|
- Stephen Kick <skick@epicrealm.com>
|
||||||
|
- Martin Hedenfalk <mhe@stacken.kth.se>
|
||||||
|
- Richard Prescott <rip at step.polymtl.ca>
|
||||||
|
- Jason S. Priebe <priebe@wral-tv.com>
|
||||||
|
- T. Bharath <TBharath@responsenetworks.com>
|
||||||
|
- Alexander Kourakos <awk@users.sourceforge.net>
|
||||||
|
- James Griffiths <griffiths_james@yahoo.com>
|
||||||
|
- Loic Dachary <loic@senga.org>
|
||||||
|
- Robert Weaver <robert.weaver@sabre.com>
|
||||||
|
- Ingo Ralf Blum <ingoralfblum@ingoralfblum.com>
|
||||||
|
- Jun-ichiro itojun Hagino <itojun@iijlab.net>
|
||||||
|
- Frederic Lepied <flepied@mandrakesoft.com>
|
||||||
|
- Georg Horn <horn@koblenz-net.de>
|
||||||
|
- Cris Bailiff <c.bailiff@awayweb.com>
|
||||||
|
- Sterling Hughes <sterling@designmultimedia.com>
|
||||||
|
- S. Moonesamy
|
||||||
|
- Ingo Wilken <iw@WWW.Ecce-Terram.DE>
|
||||||
|
- Pawel A. Gajda <mis@k2.net.pl>
|
||||||
|
- Patrick Bihan-Faou
|
||||||
|
- Nico Baggus <Nico.Baggus@mail.ing.nl>
|
||||||
|
- Sergio Ballestrero
|
||||||
|
- Andrew Francis <locust@familyhealth.com.au>
|
||||||
|
- Tomasz Lacki <Tomasz.Lacki@primark.pl>
|
||||||
|
- Georg Huettenegger <georg@ist.org>
|
||||||
|
- John Lask <johnlask@hotmail.com>
|
||||||
|
- Eric Lavigne <erlavigne@wanadoo.fr>
|
||||||
|
- Marcus Webster <marcus.webster@phocis.com>
|
||||||
|
- G<>tz Babin-Ebell <babin<69>ebell@trustcenter.de>
|
||||||
155
docs/TODO
155
docs/TODO
@@ -6,102 +6,131 @@
|
|||||||
|
|
||||||
TODO
|
TODO
|
||||||
|
|
||||||
For the future
|
Things to do in project cURL. Please tell me what you think, contribute and
|
||||||
|
send me patches that improve things! Also check the http://curl.haxx.se/dev
|
||||||
|
web section for various development notes.
|
||||||
|
|
||||||
Ok, this is what I wanna do with Curl. Please tell me what you think, and
|
LIBCURL
|
||||||
please don't hesitate to contribute and send me patches that improve this
|
|
||||||
product! (Yes, you may add things not mentioned here, these are just a
|
|
||||||
few teasers...)
|
|
||||||
|
|
||||||
* Make SSL session ids get used if multiple HTTPS documents from the same
|
* Consider an interface to libcurl that allows applications to easier get to
|
||||||
host is requested.
|
know what cookies that are sent back in the response headers.
|
||||||
|
|
||||||
* Improve the command line option parser to accept '-m300' as well as the '-m
|
* Make content encoding/decoding internally be made using a filter system.
|
||||||
300' convention. It should be able to work if '-m300' is considered to be
|
|
||||||
space separated to the next option.
|
|
||||||
|
|
||||||
* Make the curl tool support URLs that start with @ that would then mean that
|
* The new 'multi' interface is being designed. Work out the details, start
|
||||||
the following is a plain list with URLs to download. Thus @filename.txt
|
implementing and write test applications!
|
||||||
reads a list of URLs from a local file. A fancy option would then be to
|
[http://curl.haxx.se/dev/multi.h]
|
||||||
support @http://whatever.com that would first load a list and then get the
|
|
||||||
URLs mentioned in the list. I figure -O or something would have to be
|
|
||||||
implied by such an action.
|
|
||||||
|
|
||||||
* Make curl with multiple URLs, even outside of {}-letters. I could also
|
* Add a name resolve cache to libcurl to make repeated fetches to the same
|
||||||
imagine an optional fork()ed system that downloads each URL in its own
|
host name (when persitancy isn't available) faster.
|
||||||
thread. It should of course have a maximum amount of simultaneous fork()s.
|
|
||||||
|
|
||||||
* Improve the regular progress meter with --continue is used. It should be
|
* Introduce another callback interface for upload/download that makes one
|
||||||
noticable when there's a resume going on.
|
less copy of data and thus a faster operation.
|
||||||
|
[http://curl.haxx.se/dev/no_copy_callbacks.txt]
|
||||||
|
|
||||||
* Add a command line option that allows the output file to get the same time
|
* Add configure options that disables certain protocols in libcurl to
|
||||||
stamp as the remote file. This requires some fiddling on FTP but comes
|
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
||||||
almost free for HTTP.
|
telnet, ldap, dict or file.
|
||||||
|
|
||||||
* Make the SSL layer option capable of using the Mozilla Security Services as
|
* Add asynchronous name resolving. http://curl.haxx.se/dev/async-resolver.txt
|
||||||
an alternative to OpenSSL:
|
|
||||||
http://www.mozilla.org/projects/security/pki/nss/
|
|
||||||
|
|
||||||
* Make sure the low-level interface works. highlevel.c should basically be
|
* Strip any trailing CR from the error message when Curl_failf() is used.
|
||||||
possible to write using that interface. Document the low-level interface
|
|
||||||
|
|
||||||
* Make the easy-interface support multiple file transfers. If they're done
|
DOCUMENTATION
|
||||||
to the same host, they should use persistant connections or similar.
|
|
||||||
|
|
||||||
* Add asynchronous name resolving, as this enables full timeout support for
|
* Document all CURLcode error codes, why they happen and what most likely
|
||||||
fork() systems.
|
will make them not happen again.
|
||||||
|
|
||||||
* Move non-URL related functions that are used by both the lib and the curl
|
FTP
|
||||||
application to a separate "portability lib".
|
|
||||||
|
|
||||||
* Add support for other languages than C. C++ (rumours have been heard about
|
* FTP ASCII upload does not follow RFC959 section 3.1.1.1: "The sender
|
||||||
something being worked on in this area) and perl (we have seen the first
|
converts the data from an internal character representation to the standard
|
||||||
versions of this!) comes to mind. Python anyone?
|
8-bit NVT-ASCII representation (see the Telnet specification). The
|
||||||
|
receiver will convert the data from the standard form to his own internal
|
||||||
|
form."
|
||||||
|
|
||||||
* "Content-Encoding: compress/gzip/zlib"
|
* An option to only download remote FTP files if they're newer than the local
|
||||||
|
one is a good idea, and it would fit right into the same syntax as the
|
||||||
|
already working http dito works. It of course requires that 'MDTM' works,
|
||||||
|
and it isn't a standard FTP command.
|
||||||
|
|
||||||
HTTP 1.1 clearly defines how to get and decode compressed documents. There
|
* Suggested on the mailing list: CURLOPT_FTP_MKDIR...!
|
||||||
is the zlib that is pretty good at decompressing stuff. This work was
|
|
||||||
started in October 1999 but halted again since it proved more work than we
|
|
||||||
thought. It is still a good idea to implement though.
|
|
||||||
|
|
||||||
* Authentication: NTLM. It would be cool to support that MS crap called NTLM
|
* Always use the FTP SIZE command before downloading, as that makes it more
|
||||||
|
likely that we know the size when downloading. Some sites support SIZE but
|
||||||
|
don't show the size in the RETR response!
|
||||||
|
|
||||||
|
HTTP
|
||||||
|
|
||||||
|
* HTTP PUT for files passed on stdin *OR* when the --crlf option is
|
||||||
|
used. Requires libcurl to send the file with chunked content
|
||||||
|
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
|
||||||
|
and decode compressed documents. There is the zlib that is pretty good at
|
||||||
|
decompressing stuff. This work was started in October 1999 but halted again
|
||||||
|
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
|
authentication. MS proxies and servers sometime require that. Since that
|
||||||
protocol is a proprietary one, it involves reverse engineering and network
|
protocol is a proprietary one, it involves reverse engineering and network
|
||||||
sniffing. This should however be a library-based functionality. There are a
|
sniffing. This should however be a library-based functionality. There are a
|
||||||
few different efforts "out there" to make open source HTTP clients support
|
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
|
this and it should be possible to take advantage of other people's hard
|
||||||
work. http://modntlm.sourceforge.net/ is one.
|
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"
|
* RFC2617 compliance, "Digest Access Authentication"
|
||||||
A valid test page seem to exist at:
|
A valid test page seem to exist at:
|
||||||
http://hopf.math.nwu.edu/testpage/digest/
|
http://hopf.math.nwu.edu/testpage/digest/
|
||||||
And some friendly person's server source code is available at
|
And some friendly person's server source code is available at
|
||||||
http://hopf.math.nwu.edu/digestauth/index.html
|
http://hopf.math.nwu.edu/digestauth/index.html
|
||||||
|
|
||||||
Then there's the Apache mod_digest source code too of course. It seems as
|
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
|
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
|
a lot better authentication method than the more common "Basic". Basic
|
||||||
sends the password in cleartext over the network, this "Digest" method uses
|
sends the password in cleartext over the network, this "Digest" method uses
|
||||||
a challange-response protocol which increases security quite a lot.
|
a challange-response protocol which increases security quite a lot.
|
||||||
|
|
||||||
* Multiple Proxies?
|
TELNET
|
||||||
Is there anyone that actually uses serial-proxies? I mean, send CONNECT to
|
|
||||||
the first proxy to connect to the second proxy to which you send CONNECT to
|
|
||||||
connect to the remote host (or even more iterations). Is there anyone
|
|
||||||
wanting curl to support it? (Not that it would be hard, just confusing...)
|
|
||||||
|
|
||||||
* Other proxies
|
* Make TELNET work on windows98!
|
||||||
Ftp-kind proxy, Socks5, whatever kind of proxies are there?
|
|
||||||
|
|
||||||
* IPv6 Awareness and support
|
SSL
|
||||||
Where ever it would fit. configure search for v6-versions of a few
|
|
||||||
functions and then use them instead is of course the first thing to do...
|
|
||||||
RFC 2428 "FTP Extensions for IPv6 and NATs" will be interesting. PORT
|
|
||||||
should be replaced with EPRT for IPv6, and EPSV instead of PASV.
|
|
||||||
|
|
||||||
* SSL for more protocols, like SSL-FTP...
|
* Add an interface to libcurl that enables "session IDs" to get
|
||||||
(http://search.ietf.org/internet-drafts/draft-murray-auth-ftp-ssl-05.txt)
|
exported/imported. Cris Bailiff said: "OpenSSL has functions which can
|
||||||
|
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
|
||||||
|
by mod_ssl for apache to implement and SSL session ID cache"
|
||||||
|
|
||||||
* HTTP POST resume using Range:
|
* Make curl's SSL layer option capable of using other free SSL libraries.
|
||||||
|
Such as the Mozilla Security Services
|
||||||
|
(http://www.mozilla.org/projects/security/pki/nss/) and GNUTLS
|
||||||
|
(http://gnutls.hellug.gr/)
|
||||||
|
|
||||||
|
CLIENT
|
||||||
|
|
||||||
|
* "curl ftp://site.com/*.txt"
|
||||||
|
|
||||||
|
* 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
|
||||||
|
persistant connection), using -T.
|
||||||
|
|
||||||
|
* Say you have a list of FTP addresses to download in a file named
|
||||||
|
ftp-list.txt: "cat ftp-list.txt | xargs curl -O -O -O [...]". curl _needs_
|
||||||
|
an "-Oalways" flag -- all addresses on the command line use the base
|
||||||
|
filename to store locally. Else a script must precount the # of URLs,
|
||||||
|
construct the proper number of "-O"s...
|
||||||
|
|
||||||
|
TEST SUITE
|
||||||
|
|
||||||
|
* Extend the test suite to include more protocols. The telnet could just do
|
||||||
|
ftp or http operations (for which we have test servers).
|
||||||
|
|
||||||
|
* Make the test suite work on more platforms. OpenBSD and Mac OS. Remove
|
||||||
|
fork()s and it should become even more portable.
|
||||||
|
|
||||||
|
* Introduce a test suite that tests libcurl better and more explicitly.
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
|
Online: http://curl.haxx.se/docs/httpscripting.shtml
|
||||||
Author: Daniel Stenberg <daniel@haxx.se>
|
Author: Daniel Stenberg <daniel@haxx.se>
|
||||||
Date: September 15, 2000
|
Date: October 31, 2001
|
||||||
Version: 0.3
|
Version: 0.5
|
||||||
|
|
||||||
The Art Of Scripting HTTP Requests Using Curl
|
The Art Of Scripting HTTP Requests Using Curl
|
||||||
=============================================
|
=============================================
|
||||||
@@ -47,7 +48,7 @@ Version: 0.3
|
|||||||
2. URL
|
2. URL
|
||||||
|
|
||||||
The Uniform Resource Locator format is how you specify the address of a
|
The Uniform Resource Locator format is how you specify the address of a
|
||||||
particular resource on the internet. You know these, you've seen URLs like
|
particular resource on the Internet. You know these, you've seen URLs like
|
||||||
http://curl.haxx.se or https://yourbank.com a million times.
|
http://curl.haxx.se or https://yourbank.com a million times.
|
||||||
|
|
||||||
3. GET a page
|
3. GET a page
|
||||||
@@ -55,7 +56,7 @@ Version: 0.3
|
|||||||
The simplest and most common request/operation made using HTTP is to get a
|
The simplest and most common request/operation made using HTTP is to get a
|
||||||
URL. The URL could itself refer to a web page, an image or a file. The client
|
URL. The URL could itself refer to a web page, an image or a file. The client
|
||||||
issues a GET request to the server and receives the document it asked for.
|
issues a GET request to the server and receives the document it asked for.
|
||||||
If you isse the command line
|
If you issue the command line
|
||||||
|
|
||||||
curl http://curl.haxx.se
|
curl http://curl.haxx.se
|
||||||
|
|
||||||
@@ -88,7 +89,7 @@ Version: 0.3
|
|||||||
<input type=submit name=press value="OK">
|
<input type=submit name=press value="OK">
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
In your favourite browser, this form will appear with a text box to fill in
|
In your favorite browser, this form will appear with a text box to fill in
|
||||||
and a press-button labeled "OK". If you fill in '1905' and press the OK
|
and a press-button labeled "OK". If you fill in '1905' and press the OK
|
||||||
button, your browser will then create a new URL to get for you. The URL will
|
button, your browser will then create a new URL to get for you. The URL will
|
||||||
get "junk.cgi?birthyear=1905&press=OK" appended to the path part of the
|
get "junk.cgi?birthyear=1905&press=OK" appended to the path part of the
|
||||||
@@ -135,8 +136,8 @@ Version: 0.3
|
|||||||
4.3 FILE UPLOAD POST
|
4.3 FILE UPLOAD POST
|
||||||
|
|
||||||
Back in late 1995 they defined a new way to post data over HTTP. It was
|
Back in late 1995 they defined a new way to post data over HTTP. It was
|
||||||
documented in the RFC 1867, why this method sometimes is refered to as
|
documented in the RFC 1867, why this method sometimes is referred to as
|
||||||
a rfc1867-posting.
|
a RFC1867-posting.
|
||||||
|
|
||||||
This method is mainly designed to better support file uploads. A form that
|
This method is mainly designed to better support file uploads. A form that
|
||||||
allows a user to upload a file could be written like this in HTML:
|
allows a user to upload a file could be written like this in HTML:
|
||||||
@@ -174,6 +175,19 @@ Version: 0.3
|
|||||||
|
|
||||||
curl -d "birthyear=1905&press=OK&person=daniel" [URL]
|
curl -d "birthyear=1905&press=OK&person=daniel" [URL]
|
||||||
|
|
||||||
|
4.5 FIGURE OUT WHAT A POST LOOKS LIKE
|
||||||
|
|
||||||
|
When you're about fill in a form and send to a server by using curl instead
|
||||||
|
of a browser, you're of course very interested in sending a POST exactly the
|
||||||
|
way your browser does.
|
||||||
|
|
||||||
|
An easy way to get to see this, is to save the HTML page with the form on
|
||||||
|
your local disk, modify the 'method' to a GET, and press the submit button
|
||||||
|
(you could also change the action URL if you want to).
|
||||||
|
|
||||||
|
You will then clearly see the data get appended to the URL, separated with a
|
||||||
|
'?'-letter as GET forms are supposed to.
|
||||||
|
|
||||||
5. PUT
|
5. PUT
|
||||||
|
|
||||||
The perhaps best way to upload data to a HTTP server is to use PUT. Then
|
The perhaps best way to upload data to a HTTP server is to use PUT. Then
|
||||||
@@ -182,7 +196,7 @@ Version: 0.3
|
|||||||
|
|
||||||
Put a file to a HTTP server with curl:
|
Put a file to a HTTP server with curl:
|
||||||
|
|
||||||
curl -t uploadfile www.uploadhttp.com/receive.cgi
|
curl -T uploadfile www.uploadhttp.com/receive.cgi
|
||||||
|
|
||||||
6. AUTHENTICATION
|
6. AUTHENTICATION
|
||||||
|
|
||||||
@@ -200,7 +214,7 @@ Version: 0.3
|
|||||||
Sometimes your HTTP access is only available through the use of a HTTP
|
Sometimes your HTTP access is only available through the use of a HTTP
|
||||||
proxy. This seems to be especially common at various companies. A HTTP proxy
|
proxy. This seems to be especially common at various companies. A HTTP proxy
|
||||||
may require its own user and password to allow the client to get through to
|
may require its own user and password to allow the client to get through to
|
||||||
the internet. To specify those with curl, run something like:
|
the Internet. To specify those with curl, run something like:
|
||||||
|
|
||||||
curl -U proxyuser:proxypassword curl.haxx.se
|
curl -U proxyuser:proxypassword curl.haxx.se
|
||||||
|
|
||||||
@@ -280,7 +294,7 @@ Version: 0.3
|
|||||||
contents to the server, unless of course they are expired.
|
contents to the server, unless of course they are expired.
|
||||||
|
|
||||||
Many applications and servers use this method to connect a series of requests
|
Many applications and servers use this method to connect a series of requests
|
||||||
into a single logical session. To be able to use curl in such occations, we
|
into a single logical session. To be able to use curl in such occasions, we
|
||||||
must be able to record and send back cookies the way the web application
|
must be able to record and send back cookies the way the web application
|
||||||
expects them. The same way browsers deal with them.
|
expects them. The same way browsers deal with them.
|
||||||
|
|
||||||
@@ -289,7 +303,6 @@ Version: 0.3
|
|||||||
|
|
||||||
curl -b "name=Daniel" www.cookiesite.com
|
curl -b "name=Daniel" www.cookiesite.com
|
||||||
|
|
||||||
|
|
||||||
Cookies are sent as common HTTP headers. This is practical as it allows curl
|
Cookies are sent as common HTTP headers. This is practical as it allows curl
|
||||||
to record cookies simply by recording headers. Record cookies with curl by
|
to record cookies simply by recording headers. Record cookies with curl by
|
||||||
using the -D option like:
|
using the -D option like:
|
||||||
@@ -304,6 +317,23 @@ Version: 0.3
|
|||||||
|
|
||||||
curl -b stored_cookies_in_file www.cookiesite.com
|
curl -b stored_cookies_in_file www.cookiesite.com
|
||||||
|
|
||||||
|
Curl's "cookie engine" gets enabled when you use the -b option. If you only
|
||||||
|
want curl to understand received cookies, use -b with a file that doesn't
|
||||||
|
exist. Example, if you want to let curl understand cookies from a page and
|
||||||
|
follow a location (and thus possibly send back cookies it received), you can
|
||||||
|
invoke it like:
|
||||||
|
|
||||||
|
curl -b nada -L www.cookiesite.com
|
||||||
|
|
||||||
|
Curl has the ability to read and write cookie files that use the same file
|
||||||
|
format that Netscape and Mozilla do. It is a convenient way to share cookies
|
||||||
|
between browsers and automatic scripts. The -b switch automatically detects
|
||||||
|
if a given file is such a cookie file and parses it, and by using the
|
||||||
|
-c/--cookie-jar option you'll make curl write a new cookie file at the end of
|
||||||
|
an operation:
|
||||||
|
|
||||||
|
curl -b cookies.txt -c newcookies.txt www.cookiesite.com
|
||||||
|
|
||||||
11. HTTPS
|
11. HTTPS
|
||||||
|
|
||||||
There are a few ways to do secure HTTP transfers. The by far most common
|
There are a few ways to do secure HTTP transfers. The by far most common
|
||||||
@@ -328,7 +358,7 @@ Version: 0.3
|
|||||||
you need to enter the unlock-code before the certificate can be used by
|
you need to enter the unlock-code before the certificate can be used by
|
||||||
curl. The PIN-code can be specified on the command line or if not, entered
|
curl. The PIN-code can be specified on the command line or if not, entered
|
||||||
interactively when curl queries for it. Use a certificate with curl on a
|
interactively when curl queries for it. Use a certificate with curl on a
|
||||||
https server like:
|
HTTPS server like:
|
||||||
|
|
||||||
curl -E mycert.pem https://that.secure.server.com
|
curl -E mycert.pem https://that.secure.server.com
|
||||||
|
|
||||||
@@ -337,10 +367,12 @@ Version: 0.3
|
|||||||
RFC 2616 is a must to read if you want in-depth understanding of the HTTP
|
RFC 2616 is a must to read if you want in-depth understanding of the HTTP
|
||||||
protocol.
|
protocol.
|
||||||
|
|
||||||
RFC 2396 explains the URL syntax
|
RFC 2396 explains the URL syntax.
|
||||||
|
|
||||||
RFC 2109 defines how cookies are supposed to work.
|
RFC 2109 defines how cookies are supposed to work.
|
||||||
|
|
||||||
|
RFC 1867 defines the HTTP post upload format.
|
||||||
|
|
||||||
http://www.openssl.org is the home of the OpenSSL project
|
http://www.openssl.org is the home of the OpenSSL project
|
||||||
|
|
||||||
http://curl.haxx.se is the home of the cURL project
|
http://curl.haxx.se is the home of the cURL project
|
||||||
|
|||||||
64
docs/VERSIONS
Normal file
64
docs/VERSIONS
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
Version Numbers and Releases
|
||||||
|
|
||||||
|
Curl is not only curl. Curl is also libcurl. They're actually individually
|
||||||
|
versioned, but they mostly follow each other rather closely.
|
||||||
|
|
||||||
|
The version numbering is always built up using the same system:
|
||||||
|
|
||||||
|
X.Y[.Z][-preN]
|
||||||
|
|
||||||
|
Where
|
||||||
|
X is main version number
|
||||||
|
Y is release number
|
||||||
|
Z is patch number
|
||||||
|
N is pre-release number
|
||||||
|
|
||||||
|
One of these numbers will get bumped in each new release. The numbers to the
|
||||||
|
right of a bumped number will be reset to zero. If Z is zero, it is not
|
||||||
|
included in the version number. The pre release number is only included in
|
||||||
|
pre releases (they're never used in public, official, releases).
|
||||||
|
|
||||||
|
The main version number will get bumped when *really* big, world colliding
|
||||||
|
changes are made. The release number is bumped when big changes are
|
||||||
|
performed. The patch number is bumped when the changes are mere bugfixes and
|
||||||
|
only minor feature changes. The pre-release is a counter, to identify which
|
||||||
|
pre-release a certain release is.
|
||||||
|
|
||||||
|
When reaching the end of a pre-release period, the version without the
|
||||||
|
pre-release part will be released as a public release.
|
||||||
|
|
||||||
|
It means that after release 1.2.3, we can release 2.0 if something really big
|
||||||
|
has been made, 1.3 if not that big changes were made or 1.2.4 if mostly bugs
|
||||||
|
were fixed. Before 1.2.4 is released, we might release a 1.2.4-pre1 release
|
||||||
|
for the brave people to try before the actual release.
|
||||||
|
|
||||||
|
Bumping, as in increasing the number with 1, is unconditionally only
|
||||||
|
affecting one of the numbers (except the ones to the right of it, that may be
|
||||||
|
set to zero). 1 becomes 2, 3 becomes 4, 9 becomes 10, 88 becomes 89 and 99
|
||||||
|
becomes 100. So, after 1.2.9 comes 1.2.10. After 3.99.3, 3.100 might come.
|
||||||
|
|
||||||
|
All original curl source release archives are named according to the libcurl
|
||||||
|
version (not according to the curl client version that, as said before, might
|
||||||
|
differ).
|
||||||
|
|
||||||
|
As a service to any application that might want to support new libcurl
|
||||||
|
features while still being able to build with older versions, all releases
|
||||||
|
have the libcurl version stored in the curl/curl.h file using a static
|
||||||
|
numbering scheme that can be used for comparison. The version number is
|
||||||
|
defined as:
|
||||||
|
|
||||||
|
#define LIBCURL_VERSION_NUM 0xXXYYZZ
|
||||||
|
|
||||||
|
Where XX, YY and ZZ are the main version, release and patch numbers in
|
||||||
|
hexadecimal. All three numbers are always represented using two digits. 1.2
|
||||||
|
would appear as "0x010200" while version 9.11.7 appears as "0x090b07".
|
||||||
|
|
||||||
|
This 6-digit hexadecimal number does not show pre-release number, and it is
|
||||||
|
always a greater number in a more recent release. It makes comparisons with
|
||||||
|
greater than and less than work.
|
||||||
55
docs/curl-config.1
Normal file
55
docs/curl-config.1
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man curl-config.1
|
||||||
|
.\" Written by Daniel Stenberg
|
||||||
|
.\"
|
||||||
|
.TH curl-config 1 "16 August 2001" "Curl 7.8.1" "curl-config manual"
|
||||||
|
.SH NAME
|
||||||
|
curl-config \- Get information about a libcurl installation
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B curl-config [options]
|
||||||
|
.SH DESCRIPTION
|
||||||
|
.B curl-config
|
||||||
|
displays information about a previous curl and libcurl installation.
|
||||||
|
.SH OPTIONS
|
||||||
|
.IP "--cflags"
|
||||||
|
Set of compiler options (CFLAGS) to use when compiling files that use
|
||||||
|
libcurl. Currently that is only thw include path to the curl include files.
|
||||||
|
.IP "--feature"
|
||||||
|
Lists what particular main features the installed libcurl was built with. At
|
||||||
|
the time of writing, this list may include SSL, KRB4 or IPv6. Do not assume
|
||||||
|
any particular order. The keywords will be separated by newlines. There may be
|
||||||
|
none, one or several keywords in the list.
|
||||||
|
.IP "--help"
|
||||||
|
Displays the available options.
|
||||||
|
.IP "--libs"
|
||||||
|
Shows the complete set of libs and other linker options you will need in order
|
||||||
|
to link your application with libcurl.
|
||||||
|
.IP "--prefix"
|
||||||
|
This is the prefix used when libcurl was installed. Libcurl is then installed
|
||||||
|
in $prefix/lib and its header files are installed in $prefix/include and so
|
||||||
|
on. The prefix is set with "configure --prefix".
|
||||||
|
.IP "--version"
|
||||||
|
Outputs version information about the installed libcurl.
|
||||||
|
.IP "--vernum"
|
||||||
|
Outputs version information about the installed libcurl, in numerical mode.
|
||||||
|
This outputs the version number, in hexadecimal, with 8 bits for each part;
|
||||||
|
major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl
|
||||||
|
12.13.14 would appear as 0c0d0e...
|
||||||
|
.SH "EXAMPLES"
|
||||||
|
What linker options do I need when I link with libcurl?
|
||||||
|
|
||||||
|
curl-config --libs
|
||||||
|
|
||||||
|
What compiler options do I need when I compile using libcurl functions?
|
||||||
|
|
||||||
|
curl-config --cflags
|
||||||
|
|
||||||
|
How do I know if libcurl was built with SSL support?
|
||||||
|
|
||||||
|
curl-config --feature | grep SSL
|
||||||
|
|
||||||
|
What's the installed libcurl version?
|
||||||
|
|
||||||
|
curl-config --version
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl (1)
|
||||||
384
docs/curl.1
384
docs/curl.1
@@ -2,18 +2,18 @@
|
|||||||
.\" nroff -man curl.1
|
.\" nroff -man curl.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl 1 "22 November 2000" "Curl 7.5" "Curl Manual"
|
.TH curl 1 "30 Nov 2001" "Curl 7.9.2" "Curl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl \- get a URL with FTP, TELNET, LDAP, GOPHER, DICT, FILE, HTTP or
|
curl \- transfer a URL
|
||||||
HTTPS syntax.
|
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B curl [options]
|
.B curl [options]
|
||||||
.I url
|
.I [URL...]
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
.B curl
|
.B curl
|
||||||
is a client to get documents/files from servers, using any of the
|
is a client to get documents/files from or send documents to a server, using
|
||||||
supported protocols. The command is designed to work without user
|
any of the supported protocols (HTTP, HTTPS, FTP, GOPHER, DICT, TELNET, LDAP
|
||||||
interaction or any kind of interactivity.
|
or FILE). The command is designed to work without user interaction or any kind
|
||||||
|
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
|
||||||
@@ -37,18 +37,32 @@ It is possible to specify up to 9 sets or series for a URL, but no nesting is
|
|||||||
supported at the moment:
|
supported at the moment:
|
||||||
|
|
||||||
http://www.any.org/archive[1996-1999]/volume[1-4]part{a,b,c,index}.html
|
http://www.any.org/archive[1996-1999]/volume[1-4]part{a,b,c,index}.html
|
||||||
|
|
||||||
|
You can specify any amount of URLs on the command line. They will be fetched
|
||||||
|
in a sequential manner in the specified order.
|
||||||
|
|
||||||
|
Curl will attempt to re-use connections for multiple file transfers, so that
|
||||||
|
getting many files from the same server will not do multiple connects /
|
||||||
|
handshakes. This improves speed. Of course this is only done on files
|
||||||
|
specified on a single command line and cannot be used between separate curl
|
||||||
|
invokes.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
.IP "-a/--append"
|
.IP "-a/--append"
|
||||||
(FTP)
|
(FTP)
|
||||||
When used in a 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
|
file instead of overwriting it. If the file doesn't exist, it will
|
||||||
be created.
|
be created.
|
||||||
|
|
||||||
|
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>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Specify the User-Agent string to send to the HTTP server. Some badly done CGIs
|
Specify the User-Agent string to send to the HTTP server. Some badly done CGIs
|
||||||
fail if its not set to "Mozilla/4.0". To encode blanks in the string,
|
fail if its not set to "Mozilla/4.0". To encode blanks in the string,
|
||||||
surround the string with single quote marks. This can also be set with the
|
surround the string with single quote marks. This can also be set with the
|
||||||
-H/--header flag of course.
|
-H/--header flag of course.
|
||||||
|
|
||||||
|
If this option is set more than once, the last one will be the one that's
|
||||||
|
used.
|
||||||
.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
|
||||||
@@ -57,63 +71,103 @@ The data should be in the format "NAME1=VALUE1; NAME2=VALUE2".
|
|||||||
|
|
||||||
If no '=' letter is used in the line, it is treated as a filename to use to
|
If no '=' letter is used in the line, it is treated as a filename to use to
|
||||||
read previously stored cookie lines from, which should be used in this session
|
read previously stored cookie lines from, which should be used in this session
|
||||||
if they match. Using this method also activates the "cookie parser" which
|
if they match. Using this method also activates the "cookie parser" which will
|
||||||
will make curl record incoming cookies too, which may be handy if you're using
|
make curl record incoming cookies too, which may be handy if you're using this
|
||||||
this in combination with the -L/--location option. The file format of the file
|
in combination with the -L/--location option. The file format of the file to
|
||||||
to read cookies from should be plain HTTP headers or the netscape cookie file
|
read cookies from should be plain HTTP headers or the Netscape/Mozilla cookie
|
||||||
format.
|
file format.
|
||||||
|
|
||||||
.B NOTE
|
.B NOTE
|
||||||
that the file specified with -b/--cookie is only used as input. No cookies
|
that the file specified with -b/--cookie is only used as input. No cookies
|
||||||
will be stored in the file. To store cookies, save the HTTP headers to a file
|
will be stored in the file. To store cookies, save the HTTP headers to a file
|
||||||
using -D/--dump-header!
|
using -D/--dump-header!
|
||||||
|
|
||||||
|
If this option is set more than once, the last one will be the one that's
|
||||||
|
used.
|
||||||
.IP "-B/--use-ascii"
|
.IP "-B/--use-ascii"
|
||||||
Use ASCII transfer when getting an FTP file or LDAP info. For FTP, this can
|
Use ASCII transfer when getting an FTP file or LDAP info. For FTP, this can
|
||||||
also be enforced by using an URL that ends with ";type=A". This option causes
|
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.
|
||||||
.IP "-c/--continue"
|
|
||||||
.B Deprecated. Use '-C -' instead.
|
If this option is used twice, the second one will disable ASCII usage.
|
||||||
Continue/Resume a previous file transfer. This instructs curl to
|
.IP "--ciphers <list of ciphers>"
|
||||||
continue appending data on the file where it was previously left,
|
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
|
||||||
possibly because of a broken connection to the server. There must be
|
must be using valid ciphers. Read up on SSL cipher list details on this URL:
|
||||||
a named physical file to append to for this to work.
|
.I http://www.openssl.org/docs/apps/ciphers.html (Option added in curl 7.9)
|
||||||
Note: Upload resume is depening on a command named SIZE not always
|
|
||||||
present in all ftp servers! Upload resume is for FTP only.
|
If this option is used severl times, the last one will override the others.
|
||||||
HTTP resume is only possible with HTTP/1.1 or later servers.
|
.IP "--connect-timeout <seconds>"
|
||||||
|
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
|
||||||
|
of no more use. This option didn't work in win32 systems until 7.7.2. See
|
||||||
|
also the
|
||||||
|
.I "--max-time"
|
||||||
|
option.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "-c/--cookie-jar <file name>"
|
||||||
|
Specify to which file you want curl to write all cookies after a completed
|
||||||
|
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,
|
||||||
|
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
|
||||||
|
be written to stdout. (Option added in curl 7.9)
|
||||||
|
|
||||||
|
If this option is used several times, the last specfied file name will be
|
||||||
|
used.
|
||||||
.IP "-C/--continue-at <offset>"
|
.IP "-C/--continue-at <offset>"
|
||||||
Continue/Resume a previous file transfer at the given offset. The
|
Continue/Resume a previous file transfer at the given offset. The given offset
|
||||||
given offset is the exact number of bytes that will be skipped
|
is the exact number of bytes that will be skipped counted from the beginning
|
||||||
counted from the beginning of the source file before it is transfered
|
of the source file before it is transfered to the destination. If used with
|
||||||
to the destination.
|
uploads, the ftp server command SIZE will not be used by curl.
|
||||||
If used with uploads, the ftp server command SIZE will not be used by
|
|
||||||
curl. Upload resume is for FTP only.
|
Use "-C -" to tell curl to automatically find out where/how to resume the
|
||||||
HTTP resume is only possible with HTTP/1.1 or later servers.
|
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.
|
||||||
.IP "-d/--data <data>"
|
.IP "-d/--data <data>"
|
||||||
(HTTP) Sends the specified data in a POST request to the HTTP server. Note
|
(HTTP) Sends the specified data in a POST request to the HTTP server, in a way
|
||||||
that the data is sent exactly as specified with no extra processing (with all
|
that can emulate as if a user has filled in a HTML form and pressed the submit
|
||||||
newlines cut off). The data is expected to be "url-encoded". This will cause
|
button. Note that the data is sent exactly as specified with no extra
|
||||||
curl to pass the data to the server using the content-type
|
processing (with all newlines cut off). The data is expected to be
|
||||||
application/x-www-form-urlencoded. Compare to -F. If more than one -d/--data
|
"url-encoded". This will cause curl to pass the data to the server using the
|
||||||
option is used on the same command line, the data pieces specified will be
|
content-type application/x-www-form-urlencoded. Compare to -F. If more than
|
||||||
merged together with a separating &-letter. Thus, using '-d name=daniel -d
|
one -d/--data option is used on the same command line, the data pieces
|
||||||
skill=lousy' would generate a post chunk that looks like
|
specified will be merged together with a separating &-letter. Thus, using '-d
|
||||||
'name=daniel&skill=lousy'.
|
name=daniel -d skill=lousy' would generate a post chunk that looks like
|
||||||
|
\&'name=daniel&skill=lousy'.
|
||||||
|
|
||||||
If you start the data with the letter @, the rest should be a file name to
|
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.
|
specified. Posting data from a file named 'foobar' would thus be done with
|
||||||
|
"--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.
|
||||||
|
|
||||||
-d/--data is the same as --data-ascii.
|
-d/--data is the same as --data-ascii.
|
||||||
|
|
||||||
|
If this option is used several times, the ones following the first will
|
||||||
|
append data.
|
||||||
.IP "--data-ascii <data>"
|
.IP "--data-ascii <data>"
|
||||||
(HTTP) This is an alias for the -d/--data option.
|
(HTTP) This is an alias for the -d/--data option.
|
||||||
|
|
||||||
|
If this option is used several times, the ones following the first will
|
||||||
|
append data.
|
||||||
.IP "--data-binary <data>"
|
.IP "--data-binary <data>"
|
||||||
(HTTP) This posts data in a similar manner as --data-ascii does, although when
|
(HTTP) This posts data in a similar manner as --data-ascii does, although when
|
||||||
using this option the entire context of the posted data is kept as-is. If you
|
using this option the entire context of the posted data is kept as-is. If you
|
||||||
want to post a binary file without the strip-newlines feature of the
|
want to post a binary file without the strip-newlines feature of the
|
||||||
--data-ascii option, this is for you.
|
--data-ascii option, this is for you.
|
||||||
|
|
||||||
|
If this option is used several times, the ones following the first will
|
||||||
|
append data.
|
||||||
|
.IP "--disable-epsv"
|
||||||
|
(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,
|
||||||
|
but with this option, it will not try using EPSV.
|
||||||
|
|
||||||
|
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)
|
(HTTP/FTP)
|
||||||
Write the HTTP headers to this file. Write the FTP file info to this
|
Write the HTTP headers to this file. Write the FTP file info to this
|
||||||
@@ -122,6 +176,8 @@ 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!
|
||||||
|
|
||||||
|
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
|
||||||
be set with the -H/--header flag of course. When used with
|
be set with the -H/--header flag of course. When used with
|
||||||
@@ -129,6 +185,13 @@ be set with the -H/--header flag of course. When used with
|
|||||||
you can append ";auto" to the referer URL to make curl automatically set the
|
you can append ";auto" to the referer URL to make curl automatically set the
|
||||||
previous URL when it follows a Location: header. The ";auto" string can be
|
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.
|
||||||
|
.IP "--egd-file <file>"
|
||||||
|
(HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The
|
||||||
|
socket is used to seed the random engine for SSL connections. See also the
|
||||||
|
.I "--random-file"
|
||||||
|
option.
|
||||||
.IP "-E/--cert <certificate[:password]>"
|
.IP "-E/--cert <certificate[:password]>"
|
||||||
(HTTPS)
|
(HTTPS)
|
||||||
Tells curl to use the specified certificate file when getting a file
|
Tells curl to use the specified certificate file when getting a file
|
||||||
@@ -136,9 +199,13 @@ with HTTPS. The certificate must be in PEM format.
|
|||||||
If the optional password isn't specified, it will be queried for on
|
If the optional password isn't specified, it will be queried for on
|
||||||
the terminal. Note that this certificate is the private key and the private
|
the terminal. Note that this certificate is the private key and the private
|
||||||
certificate concatenated!
|
certificate concatenated!
|
||||||
|
|
||||||
|
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 certificate must be in PEM format.
|
||||||
|
|
||||||
|
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
|
||||||
@@ -147,6 +214,8 @@ attempts. In normal cases when a HTTP server fails to deliver a
|
|||||||
document, it returns a HTML document stating so (which often also
|
document, it returns a HTML document stating so (which often also
|
||||||
describes why and more). This flag will prevent curl from
|
describes why and more). This flag will prevent curl from
|
||||||
outputting that and fail silently instead.
|
outputting that and fail silently instead.
|
||||||
|
|
||||||
|
If this option is used twice, the second will again disable silent failure.
|
||||||
.IP "-F/--form <name=content>"
|
.IP "-F/--form <name=content>"
|
||||||
(HTTP) This lets curl emulate a filled in form in which a user has pressed the
|
(HTTP) This lets curl emulate a filled in form in which a user has pressed the
|
||||||
submit button. This causes curl to POST data using the content-type
|
submit button. This causes curl to POST data using the content-type
|
||||||
@@ -158,7 +227,7 @@ get attached in the post as a file upload, while the < makes a text field and
|
|||||||
just get the contents for that text field from a file.
|
just get the contents for that text field from a file.
|
||||||
|
|
||||||
Example, to send your password file to the server, where
|
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
|
.B curl
|
||||||
@@ -166,6 +235,19 @@ input:
|
|||||||
|
|
||||||
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.
|
||||||
|
|
||||||
|
This option can be used multiple times.
|
||||||
|
.IP "-g/--globoff"
|
||||||
|
This option switches off the "URL globbing parser". When you set this option,
|
||||||
|
you can specify URLs that contain the letters {}[] without having them being
|
||||||
|
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
|
||||||
|
added in curl 7.6)
|
||||||
|
.IP "-G/--get"
|
||||||
|
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
|
||||||
|
that otherwise would be used. The data will be appended to the URL with a '?'
|
||||||
|
separator. (Option added in curl 7.9)
|
||||||
.IP "-h/--help"
|
.IP "-h/--help"
|
||||||
Usage help.
|
Usage help.
|
||||||
.IP "-H/--header <header>"
|
.IP "-H/--header <header>"
|
||||||
@@ -177,38 +259,54 @@ trickier stuff than curl would normally do. You should not replace internally
|
|||||||
set headers without knowing perfectly well what you're doing. Replacing an
|
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.
|
||||||
.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
|
||||||
like server-name, date of the document, HTTP-version and more...
|
like server-name, date of the document, HTTP-version and more...
|
||||||
|
|
||||||
|
If this option is used twice, the second will again disable header include.
|
||||||
.IP "--interface <name>"
|
.IP "--interface <name>"
|
||||||
Perform an operation using a specified interface. You can enter interface
|
Perform an operation using a specified interface. You can enter interface
|
||||||
name, IP address or host name. An example could look like:
|
name, IP address or host name. An example could look like:
|
||||||
|
|
||||||
.B "curl --interface eth0:1 http://www.netscape.com/"
|
.B "curl --interface eth0:1 http://www.netscape.com/"
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-I/--head"
|
.IP "-I/--head"
|
||||||
(HTTP/FTP)
|
(HTTP/FTP)
|
||||||
Fetch the HTTP-header only! HTTP-servers feature the command HEAD
|
Fetch the HTTP-header only! HTTP-servers feature the command HEAD
|
||||||
which this uses to get nothing but the header of a document. When used
|
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.
|
||||||
.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
|
||||||
a level that is not one of these, 'private' will instead be used.
|
a level that is not one of these, 'private' will instead be used.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-K/--config <config file>"
|
.IP "-K/--config <config file>"
|
||||||
Specify which config file to read curl arguments from. The config
|
Specify which config file to read curl arguments from. The config file is a
|
||||||
file is a text file in which command line arguments can be written
|
text file in which command line arguments can be written which then will be
|
||||||
which then will be used as if they were written on the actual command
|
used as if they were written on the actual command line. Options and their
|
||||||
line. If the first column of a config line is a '#' character, the
|
parameters must be specified on the same config file line. If the parameter is
|
||||||
rest of the line will be treated as a comment.
|
to contain white spaces, the parameter must be inclosed within quotes. If the
|
||||||
|
first column of a config line is a '#' character, the rest of the line will be
|
||||||
|
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.
|
||||||
|
|
||||||
|
This option can be used multiple times.
|
||||||
.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.
|
||||||
Especially useful if you want to machine-parse the contents of an FTP
|
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.
|
||||||
|
|
||||||
|
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
|
||||||
@@ -216,10 +314,17 @@ 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 this flag is used when
|
||||||
making a HTTP POST, curl will automatically switch to GET after the initial
|
making a HTTP POST, curl will automatically switch to GET after the initial
|
||||||
POST has been done.
|
POST has been done.
|
||||||
|
|
||||||
|
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 also the
|
||||||
|
.I "--connect-timeout"
|
||||||
|
option.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-M/--manual"
|
.IP "-M/--manual"
|
||||||
Manual. Display the huge help text.
|
Manual. Display the huge help text.
|
||||||
.IP "-n/--netrc"
|
.IP "-n/--netrc"
|
||||||
@@ -229,6 +334,8 @@ file in the user's home directory for login name and password. This is
|
|||||||
typically used for ftp on unix. If used with http, curl will enable user
|
typically used for ftp on unix. If used with http, curl will enable user
|
||||||
authentication. See
|
authentication. See
|
||||||
.BR netrc(4)
|
.BR netrc(4)
|
||||||
|
or
|
||||||
|
.BR ftp(1)
|
||||||
for details on the file format. Curl will not complain if that file
|
for details on the file format. Curl will not complain if that file
|
||||||
hasn't the right permissions (it should not be world nor group
|
hasn't the right permissions (it should not be world nor group
|
||||||
readable). The environment variable "HOME" is used to find the home
|
readable). The environment variable "HOME" is used to find the home
|
||||||
@@ -237,14 +344,18 @@ directory.
|
|||||||
A quick and very simple example of how to setup a
|
A quick and very simple example of how to setup a
|
||||||
.I .netrc
|
.I .netrc
|
||||||
to allow curl to ftp to the machine host.domain.com with user name
|
to allow curl to ftp to the machine host.domain.com with user name
|
||||||
'myself' and password 'secret' should look similar to:
|
\&'myself' and password 'secret' should look similar to:
|
||||||
|
|
||||||
.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.
|
||||||
.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
|
||||||
will output the data in chunks, not necessarily exactly when the data arrives.
|
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.
|
||||||
.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>
|
||||||
@@ -256,15 +367,21 @@ being fetched. Like in:
|
|||||||
or use several variables like:
|
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.
|
||||||
.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 part of the remote file is used, the path is cut off.)
|
the file 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.
|
||||||
.IP "-p/--proxytunnel"
|
.IP "-p/--proxytunnel"
|
||||||
When an HTTP proxy is used, this option will cause non-HTTP protocols to
|
When an HTTP proxy is used, this option will cause non-HTTP protocols to
|
||||||
attempt to tunnel through the proxy instead of merely using it to do HTTP-like
|
attempt to tunnel through the proxy instead of merely using it to do HTTP-like
|
||||||
operations. The tunnel approach is made with the HTTP proxy CONNECT request
|
operations. The tunnel approach is made with the HTTP proxy CONNECT request
|
||||||
and requires that the proxy allows direct connect to the remote port number
|
and requires that the proxy allows direct connect to the remote port number
|
||||||
curl wants to tunnel through to.
|
curl wants to tunnel through to.
|
||||||
|
|
||||||
|
If this option is used twice, the second will again disable proxy tunnel.
|
||||||
.IP "-P/--ftpport <address>"
|
.IP "-P/--ftpport <address>"
|
||||||
(FTP)
|
(FTP)
|
||||||
Reverses the initiator/listener roles when connecting with ftp. This
|
Reverses the initiator/listener roles when connecting with ftp. This
|
||||||
@@ -286,6 +403,8 @@ i.e "my.host.domain" to specify machine
|
|||||||
.B "-"
|
.B "-"
|
||||||
(any single-letter string) to make it pick the machine's default
|
(any single-letter string) to make it pick the machine's default
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-q"
|
.IP "-q"
|
||||||
If used as the first parameter on the command line, the
|
If used as the first parameter on the command line, the
|
||||||
.I $HOME/.curlrc
|
.I $HOME/.curlrc
|
||||||
@@ -298,6 +417,14 @@ transfer is taking place. To make commands take place after a successful
|
|||||||
transfer, prefix them with a dash '-'. You may specify any amount of commands
|
transfer, prefix them with a dash '-'. You may specify any amount of commands
|
||||||
to be run before and after the transfer. If the server returns failure for one
|
to be run before and after the transfer. If the server returns failure for one
|
||||||
of the commands, the entire operation will be aborted.
|
of the commands, the entire operation will be aborted.
|
||||||
|
|
||||||
|
This option can be used multiple times.
|
||||||
|
.IP "--random-file <file>"
|
||||||
|
(HTTPS) Specify the path name to file containing what will be considered as
|
||||||
|
random data. The data is used to seed the random engine for SSL connections.
|
||||||
|
See also the
|
||||||
|
.I "--edg-file"
|
||||||
|
option.
|
||||||
.IP "-r/--range <range>"
|
.IP "-r/--range <range>"
|
||||||
(HTTP/FTP)
|
(HTTP/FTP)
|
||||||
Retrieve a byte range (i.e a partial document) from a HTTP/1.1 or FTP
|
Retrieve a byte range (i.e a partial document) from a HTTP/1.1 or FTP
|
||||||
@@ -335,39 +462,69 @@ document.
|
|||||||
|
|
||||||
FTP range downloads only support the simple syntax 'start-stop' (optionally
|
FTP range downloads only support the simple syntax 'start-stop' (optionally
|
||||||
with one of the numbers omitted). It depends on the non-RFC command SIZE.
|
with one of the numbers omitted). It depends on the non-RFC command SIZE.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
|
.IP "-R/--remote-time"
|
||||||
|
When used, this will make libcurl attempt to figure out the timestamp of the
|
||||||
|
remote file, and if that is available make the local file get that same
|
||||||
|
timestamp.
|
||||||
|
|
||||||
|
If this option is used twice, the second time disables this again.
|
||||||
.IP "-s/--silent"
|
.IP "-s/--silent"
|
||||||
Silent mode. Don't show progress meter or error messages. Makes
|
Silent mode. Don't show progress meter or error messages. Makes
|
||||||
Curl mute.
|
Curl mute.
|
||||||
|
|
||||||
|
If this option is used twice, the second will again disable mute.
|
||||||
.IP "-S/--show-error"
|
.IP "-S/--show-error"
|
||||||
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.
|
||||||
.IP "-t/--upload"
|
|
||||||
.B Deprecated. Use '-T -' instead.
|
If this option is used twice, the second will again disable show error.
|
||||||
Transfer the stdin data to the specified file. Curl will read
|
.IP "-t/--telnet-option <OPT=val>"
|
||||||
everything from stdin until EOF and store with the supplied name. If
|
Pass options to the telnet protocol. Supported options are:
|
||||||
this is used on a http(s) server, the PUT command will be used.
|
|
||||||
|
TTYPE=<term> Sets the terminal type.
|
||||||
|
|
||||||
|
XDISPLOC=<X display> Sets the X display location.
|
||||||
|
|
||||||
|
NEW_ENV=<var,val> Sets an environment variable.
|
||||||
.IP "-T/--upload-file <file>"
|
.IP "-T/--upload-file <file>"
|
||||||
Like -t, but this transfers the specified local file. If there is no
|
This transfers the specified local file to the remote URL. If there is no file
|
||||||
file part in the specified URL, Curl will append the local file
|
part in the specified URL, Curl will append the local file name. NOTE that you
|
||||||
name. NOTE that you must use a trailing / on the last directory to
|
must use a trailing / on the last directory to really prove to Curl that there
|
||||||
really prove to Curl that there is no file name or curl will
|
is no file name or curl will think that your last directory name is the remote
|
||||||
think that your last directory name is the remote file name to
|
file name to use. That will most likely cause the upload operation to fail. If
|
||||||
use. That will most likely cause the upload operation to fail. If
|
|
||||||
this is used on a http(s) server, the PUT command will be used.
|
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.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.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. See README.curl 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 interactively.
|
ask for it interactively.
|
||||||
|
|
||||||
|
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>"
|
||||||
Specify user and password to use for Proxy authentication. If no
|
Specify user and password to use for Proxy authentication. If no
|
||||||
password is specified, curl will ask for it interactively.
|
password is specified, curl will ask for it interactively.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--url <URL>"
|
.IP "--url <URL>"
|
||||||
Set the URL to fetch. This option is mostly handy when you wanna specify URL
|
Specify a URL to fetch. This option is mostly handy when you wanna specify
|
||||||
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
|
||||||
|
.I -o
|
||||||
|
or the
|
||||||
|
.I -O
|
||||||
|
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 starting with '>' means data sent by curl, '<'
|
debugging. Lines starting with '>' means data sent by curl, '<'
|
||||||
means data received by curl that is hidden in normal cases and lines
|
means data received by curl that is hidden in normal cases and lines
|
||||||
starting with '*' means additional info provided by curl.
|
starting with '*' means additional info provided by curl.
|
||||||
|
|
||||||
|
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 the full version of curl, libcurl and other 3rd party libraries
|
||||||
linked with the executable.
|
linked with the executable.
|
||||||
@@ -415,6 +572,11 @@ The time, in seconds, it took from the start until the file transfer is just
|
|||||||
about to begin. This includes all pre-transfer commands and negotiations that
|
about to begin. This includes all pre-transfer commands and negotiations that
|
||||||
are specific to the particular protocol(s) involved.
|
are specific to the particular protocol(s) involved.
|
||||||
.TP
|
.TP
|
||||||
|
.B time_starttransfer
|
||||||
|
The time, in seconds, it took from the start until the first byte is just about
|
||||||
|
to be transfered. This includes time_pretransfer and also the time the
|
||||||
|
server needs to calculate the result.
|
||||||
|
.TP
|
||||||
.B size_download
|
.B size_download
|
||||||
The total amount of bytes that were downloaded.
|
The total amount of bytes that were downloaded.
|
||||||
.TP
|
.TP
|
||||||
@@ -433,9 +595,18 @@ The average download speed that curl measured for the complete download.
|
|||||||
.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.
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-x/--proxy <proxyhost[:port]>"
|
.IP "-x/--proxy <proxyhost[:port]>"
|
||||||
Use specified proxy. If the port number is not specified, it is assumed at
|
Use specified HTTP proxy. If the port number is not specified, it is assumed
|
||||||
port 1080.
|
at port 1080.
|
||||||
|
|
||||||
|
\fBNote\fP that all operations that are performed over a HTTP proxy will
|
||||||
|
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
|
||||||
|
through the proxy, as done with the \fI-p/--proxytunnel\fP option.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-X/--request <command>"
|
.IP "-X/--request <command>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Specifies a custom request to use when communicating with the HTTP server.
|
Specifies a custom request to use when communicating with the HTTP server.
|
||||||
@@ -445,14 +616,20 @@ HTTP 1.1 specification for details and explanations.
|
|||||||
(FTP)
|
(FTP)
|
||||||
Specifies a custom FTP command to use instead of LIST when doing file lists
|
Specifies a custom FTP command to use instead of LIST when doing file lists
|
||||||
with ftp.
|
with ftp.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-y/--speed-time <time>"
|
.IP "-y/--speed-time <time>"
|
||||||
If a download is slower than speed-limit bytes per second during a speed-time
|
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.
|
||||||
|
|
||||||
|
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
|
||||||
speed-time seconds it gets aborted. speed-time is set with -Y and is 30 if
|
speed-time seconds it gets aborted. speed-time is set with -Y and is 30 if
|
||||||
not set.
|
not set.
|
||||||
|
|
||||||
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-z/--time-cond <date expression>"
|
.IP "-z/--time-cond <date expression>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Request to get a file that has been modified later than the given time and
|
Request to get a file that has been modified later than the given time and
|
||||||
@@ -467,28 +644,39 @@ man pages for date expression details.
|
|||||||
Start the date expression with a dash (-) to make it request for a document
|
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 "-3/--sslv3"
|
.IP "-3/--sslv3"
|
||||||
(HTTPS)
|
(HTTPS)
|
||||||
Forces curl to use SSL version 3 when negotiating with a remote SSL server.
|
Forces curl to use SSL version 3 when negotiating with a remote SSL server.
|
||||||
.IP "-2/--sslv2"
|
.IP "-2/--sslv2"
|
||||||
(HTTPS)
|
(HTTPS)
|
||||||
Forces curl to use SSL version 2 when negotiating with a remote SSL server.
|
Forces curl to use SSL version 2 when negotiating with a remote SSL server.
|
||||||
|
.IP "-0/--http1.0"
|
||||||
|
(HTTP) Forces curl to issue its requests using HTTP 1.0 instead of using its
|
||||||
|
internally preferred: HTTP 1.1.
|
||||||
.IP "-#/--progress-bar"
|
.IP "-#/--progress-bar"
|
||||||
Make curl display progress information as a progress bar instead of the
|
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.
|
||||||
.IP "--crlf"
|
.IP "--crlf"
|
||||||
(FTP) Convert LF to CRLF in upload. Useful for MVS (OS/390).
|
(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>"
|
.IP "--stderr <file>"
|
||||||
Redirect all writes to stderr to the specified file instead. If the file name
|
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
|
is a plain '-', it is instead written to stdout. This option has no point when
|
||||||
you're using a shell with decent redirecting capabilities.
|
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
|
||||||
Default config file.
|
Default config file.
|
||||||
|
|
||||||
.SH ENVIRONMENT
|
.SH ENVIRONMENT
|
||||||
.IP "HTTP_PROXY [protocol://]<host>[:port]"
|
.IP "http_proxy [protocol://]<host>[:port]"
|
||||||
Sets proxy server to use for HTTP.
|
Sets proxy server to use for HTTP.
|
||||||
.IP "HTTPS_PROXY [protocol://]<host>[:port]"
|
.IP "HTTPS_PROXY [protocol://]<host>[:port]"
|
||||||
Sets proxy server to use for HTTPS.
|
Sets proxy server to use for HTTPS.
|
||||||
@@ -499,11 +687,8 @@ Sets proxy server to use for GOPHER.
|
|||||||
.IP "ALL_PROXY [protocol://]<host>[:port]"
|
.IP "ALL_PROXY [protocol://]<host>[:port]"
|
||||||
Sets proxy server to use if no protocol-specific proxy is set.
|
Sets proxy server to use if no protocol-specific proxy is set.
|
||||||
.IP "NO_PROXY <comma-separated list of hosts>"
|
.IP "NO_PROXY <comma-separated list of hosts>"
|
||||||
list of host names that shouldn't go through any proxy. If set to a
|
list of host names that shouldn't go through any proxy. If set to a asterisk
|
||||||
asterisk '*' only, it matches all hosts.
|
'*' only, it matches all hosts.
|
||||||
.IP "COLUMNS <integer>"
|
|
||||||
The width of the terminal. This variable only affects curl when the
|
|
||||||
--progress-bar option is used.
|
|
||||||
.SH EXIT CODES
|
.SH EXIT CODES
|
||||||
There exists a bunch of different error codes and their corresponding error
|
There exists a bunch of different error codes and their corresponding error
|
||||||
messages that may appear during bad conditions. At the time of this writing,
|
messages that may appear during bad conditions. At the time of this writing,
|
||||||
@@ -606,69 +791,22 @@ Interface error. A specified outgoing interface could not be used.
|
|||||||
Bad password entered. An error was signalled when the password was entered.
|
Bad password entered. An error was signalled 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
|
||||||
|
Unknown TELNET option specified.
|
||||||
|
.IP 49
|
||||||
|
Malformed telnet option.
|
||||||
|
.IP 51
|
||||||
|
The remote peer's SSL certificate wasn't ok
|
||||||
|
.IP 52
|
||||||
|
The server didn't reply anything, which here is considered an error.
|
||||||
.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
|
.SH BUGS
|
||||||
If you do find bugs, mail them to curl-bug@haxx.se.
|
If you do find bugs, mail them to curl-bug@haxx.se.
|
||||||
.SH AUTHORS / CONTRIBUTORS
|
.SH AUTHORS / CONTRIBUTORS
|
||||||
- Daniel Stenberg <Daniel.Stenberg@haxx.se>
|
Daniel Stenberg is the main author, but the whole list of contributors is
|
||||||
- Rafael Sagula <sagula@inf.ufrgs.br>
|
found in the separate THANKS file.
|
||||||
- Sampo Kellomaki <sampo@iki.fi>
|
|
||||||
- Linas Vepstas <linas@linas.org>
|
|
||||||
- Bjorn Reese <breese@mail1.stofanet.dk>
|
|
||||||
- Johan Anderson <johan@homemail.com>
|
|
||||||
- Kjell Ericson <Kjell.Ericson@haxx.se>
|
|
||||||
- Troy Engel <tengel@sonic.net>
|
|
||||||
- Ryan Nelson <ryan@inch.com>
|
|
||||||
- Bj<42>rn Stenberg <Bjorn.Stenberg@haxx.se>
|
|
||||||
- Angus Mackay <amackay@gus.ml.org>
|
|
||||||
- Eric Young <eay@cryptsoft.com>
|
|
||||||
- Simon Dick <simond@totally.irrelevant.org>
|
|
||||||
- Oren Tirosh <oren@monty.hishome.net>
|
|
||||||
- Steven G. Johnson <stevenj@alum.mit.edu>
|
|
||||||
- Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu>
|
|
||||||
- Andr<64>s Garc<72>a <ornalux@redestb.es>
|
|
||||||
- Douglas E. Wegscheid <wegscd@whirlpool.com>
|
|
||||||
- Mark Butler <butlerm@xmission.com>
|
|
||||||
- Eric Thelin <eric@generation-i.com>
|
|
||||||
- Marc Boucher <marc@mbsi.ca>
|
|
||||||
- Greg Onufer <Greg.Onufer@Eng.Sun.COM>
|
|
||||||
- Doug Kaufman <dkaufman@rahul.net>
|
|
||||||
- David Eriksson <david@2good.com>
|
|
||||||
- Ralph Beckmann <rabe@uni-paderborn.de>
|
|
||||||
- T. Yamada <tai@imasy.or.jp>
|
|
||||||
- Lars J. Aas <larsa@sim.no>
|
|
||||||
- J<>rn Hartroth <Joern.Hartroth@computer.org>
|
|
||||||
- Matthew Clarke <clamat@van.maves.ca>
|
|
||||||
- Linus Nielsen <Linus.Nielsen@haxx.se>
|
|
||||||
- Felix von Leitner <felix@convergence.de>
|
|
||||||
- Dan Zitter <dzitter@zitter.net>
|
|
||||||
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
|
||||||
- Chris Maltby <chris@aurema.com>
|
|
||||||
- Ron Zapp <rzapper@yahoo.com>
|
|
||||||
- Paul Marquis <pmarquis@iname.com>
|
|
||||||
- Ellis Pritchard <ellis@citria.com>
|
|
||||||
- Damien Adant <dams@usa.net>
|
|
||||||
- Chris <cbayliss@csc.come>
|
|
||||||
- Marco G. Salvagno <mgs@whiz.cjb.net>
|
|
||||||
- Paul Marquis <pmarquis@iname.com>
|
|
||||||
- David LeBlanc <dleblanc@qnx.com>
|
|
||||||
- Rich Gray at Plus Technologies
|
|
||||||
- Luong Dinh Dung <u8luong@lhsystems.hu>
|
|
||||||
- Torsten Foertsch <torsten.foertsch@gmx.net>
|
|
||||||
- Kristian K<>hntopp <kris@koehntopp.de>
|
|
||||||
- Fred Noz <FNoz@siac.com>
|
|
||||||
- Caolan McNamara <caolan@csn.ul.ie>
|
|
||||||
- Albert Chin-A-Young <china@thewrittenword.com>
|
|
||||||
- Stephen Kick <skick@epicrealm.com>
|
|
||||||
- Martin Hedenfalk <mhe@stacken.kth.se>
|
|
||||||
- Richard Prescott
|
|
||||||
- Jason S. Priebe <priebe@wral-tv.com>
|
|
||||||
- T. Bharath <TBharath@responsenetworks.com>
|
|
||||||
- Alexander Kourakos <awk@users.sourceforge.net>
|
|
||||||
- James Griffiths <griffiths_james@yahoo.com>
|
|
||||||
|
|
||||||
.SH WWW
|
.SH WWW
|
||||||
http://curl.haxx.se
|
http://curl.haxx.se
|
||||||
.SH FTP
|
.SH FTP
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_cleanup 3 "22 May 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_easy_cleanup 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_cleanup - End a libcurl "easy" session
|
curl_easy_cleanup - End a libcurl session
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "curl_easy_cleanup(CURL *" handle ");
|
.BI "void curl_easy_cleanup(CURL *" handle ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
This function must be the last function to call for a curl session. It is the
|
This function must be the last function to call for a curl session. It is the
|
||||||
@@ -17,6 +17,10 @@ opposite of the
|
|||||||
function and must be called with the same
|
function and must be called with the same
|
||||||
.I handle
|
.I handle
|
||||||
as input as the curl_easy_init call returned.
|
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
|
.SH RETURN VALUE
|
||||||
None
|
None
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
|||||||
37
docs/curl_easy_duphandle.3
Normal file
37
docs/curl_easy_duphandle.3
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_easy_duphandle 3 "18 September 2001" "libcurl 7.9" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_easy_duphandle - Clone a libcurl session handle
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURL *curl_easy_duphandle(CURL *"handle ");"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function will return a new curl handle, a duplicate, using all the
|
||||||
|
options previously set in the input curl \fIhandle\fP. Both handles can
|
||||||
|
subsequently be used independently and they must both be freed with
|
||||||
|
\fIcurl_easy_cleanup()\fP.
|
||||||
|
|
||||||
|
All strings that the input handle has been told to point to (as opposed to
|
||||||
|
copy) with previous calls to \fIcurl_easy_setopt\fP using char * inputs, will
|
||||||
|
be pointed to by the new handle as well. You must therefore make sure to keep
|
||||||
|
the data around until both handles have been cleaned up.
|
||||||
|
|
||||||
|
The new handle will \fBnot\fP inherit any state information, no connections,
|
||||||
|
no SSL sessions and no cookies.
|
||||||
|
|
||||||
|
\fBNote\fP that even in multi-threaded programs, this function must be called
|
||||||
|
in a synchronous way, the input handle may not be in use when cloned.
|
||||||
|
|
||||||
|
This function was added in libcurl 7.9.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
If this function returns NULL, something went wrong and no valid handle was
|
||||||
|
returned.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_easy_init "(3)," curl_easy_cleanup "(3)," curl_global_init "(3)
|
||||||
|
.SH BUGS
|
||||||
|
Surely there are some, you tell me!
|
||||||
@@ -1,12 +1,12 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "22 November 2000" "Curl 7.5" "libcurl Manual"
|
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.6.1" "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
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ... );"
|
.BI "CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ... );"
|
||||||
.ad
|
.ad
|
||||||
@@ -52,6 +52,12 @@ start until the file transfer is just about to begin. This includes all
|
|||||||
pre-transfer commands and negotiations that are specific to the particular
|
pre-transfer commands and negotiations that are specific to the particular
|
||||||
protocol(s) involved.
|
protocol(s) involved.
|
||||||
.TP
|
.TP
|
||||||
|
.B CURLINFO_STARTTRANSFER_TIME
|
||||||
|
Pass a pointer to a double to receive the time, in seconds, it took from the
|
||||||
|
start until the first byte is just about to be transfered. This includes
|
||||||
|
CURLINFO_PRETRANSFER_TIME and also the time the server needs to calculate
|
||||||
|
the result.
|
||||||
|
.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.
|
||||||
@@ -81,6 +87,14 @@ than one request if FOLLOWLOCATION is true.
|
|||||||
Pass a pointer to a long to receive the result of the certification
|
Pass a pointer to a long to receive the result of the certification
|
||||||
verification that was requested (using the CURLOPT_SSL_VERIFYPEER option to
|
verification that was requested (using the CURLOPT_SSL_VERIFYPEER option to
|
||||||
curl_easy_setopt). (Added in 7.4.2)
|
curl_easy_setopt). (Added in 7.4.2)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_CONTENT_LENGTH_DOWNLOAD
|
||||||
|
Pass a pointer to a double to receive the content-length of the download. This
|
||||||
|
is the value read from the Content-Length: field. (Added in 7.6.1)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_CONTENT_LENGTH_UPLOAD
|
||||||
|
Pass a pointer to a double to receive the specified size of the upload.
|
||||||
|
(Added in 7.6.1)
|
||||||
.PP
|
.PP
|
||||||
|
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "26 September 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_easy_init 3 "14 August 2001" "libcurl 7.8.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_init - Start a libcurl "easy" session
|
curl_easy_init - Start a libcurl session
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURL *curl_easy_init( );"
|
.BI "CURL *curl_easy_init( );"
|
||||||
.ad
|
.ad
|
||||||
@@ -17,12 +17,18 @@ intializes curl and this call MUST have a corresponding call to
|
|||||||
.I curl_easy_cleanup
|
.I curl_easy_cleanup
|
||||||
when the operation is complete.
|
when the operation is complete.
|
||||||
|
|
||||||
On win32 systems, you need to init the winsock stuff manually, libcurl will
|
On win32 systems, if you want to init the winsock stuff manually, libcurl will
|
||||||
not do that for you. WSAStartup() and WSACleanup() should be used accordingly.
|
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
|
.SH RETURN VALUE
|
||||||
If this function returns NULL, something went wrong and you cannot use the
|
If this function returns NULL, something went wrong and you cannot use the
|
||||||
other curl functions.
|
other curl functions.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_cleanup "(3), "
|
.BR curl_easy_cleanup "(3), " curl_global_init "(3)
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
Surely there are some, you tell me!
|
Surely there are some, you tell me!
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_perform 3 "26 May 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_easy_perform 3 "5 Mar 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_perform - Do the actual transfer in a "easy" session
|
curl_easy_perform - Perform a file transfer
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode curl_easy_perform(CURL *" handle ");
|
.BI "CURLcode curl_easy_perform(CURL *" handle ");
|
||||||
.ad
|
.ad
|
||||||
@@ -16,12 +16,29 @@ are made, and will perform the transfer as described in the options.
|
|||||||
It must be called with the same
|
It must be called with the same
|
||||||
.I handle
|
.I handle
|
||||||
as input as the curl_easy_init call returned.
|
as input as the curl_easy_init call returned.
|
||||||
|
|
||||||
|
libcurl version 7.7 or later (for older versions see below): You can do any
|
||||||
|
amount of calls to curl_easy_perform() while using the same handle. If you
|
||||||
|
intend to transfer more than one file, you are even encouraged to do
|
||||||
|
so. libcurl will then attempt to re-use the same connection for the following
|
||||||
|
transfers, thus making the operations faster, less CPU intense and using less
|
||||||
|
network resources. Just note that you will have to use
|
||||||
|
.I curl_easy_setopt
|
||||||
|
between the invokes to set options for the following curl_easy_perform.
|
||||||
|
|
||||||
|
You must never call this function simultaneously from two places using the
|
||||||
|
same handle. Let the function return first before invoking it another time. If
|
||||||
|
you want parallel transfers, you must use several curl handles.
|
||||||
|
|
||||||
|
Before libcurl version 7.7: You are only allowed to call this function once
|
||||||
|
using the same handle. If you want to do repeated calls, you must call
|
||||||
|
curl_easy_cleanup and curl_easy_init again first.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
0 means everything was ok, non-zero means an error occurred as
|
0 means everything was ok, non-zero means an error occurred as
|
||||||
.I <curl/curl.h>
|
.I <curl/curl.h>
|
||||||
defines. If the CURLOPT_ERRORBUFFER was set with
|
defines. If the CURLOPT_ERRORBUFFER was set with
|
||||||
.I curl_easy_setopt
|
.I curl_easy_setopt
|
||||||
there willo be a readable error message in the error buffer when non-zero is
|
there will be a readable error message in the error buffer when non-zero is
|
||||||
returned.
|
returned.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_init "(3), " curl_easy_setopt "(3), "
|
.BR curl_easy_init "(3), " curl_easy_setopt "(3), "
|
||||||
|
|||||||
@@ -1,72 +1,84 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_setopt 3 "28 November 2000" "Curl 7.5" "libcurl Manual"
|
.TH curl_easy_setopt 3 "10 Dec 2001" "libcurl 7.9.2" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_setopt - Set curl easy-session options
|
curl_easy_setopt - Set curl easy-session options
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
#include <curl/curl.h>
|
||||||
.sp
|
|
||||||
.BI "CURLcode curl_easy_setopt(CURL *" handle ", CURLoption "option ", ...);
|
CURLcode curl_easy_setopt(CURL *handle, CURLoption option, parameter);
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_easy_setopt() is called to tell libcurl how to behave in a number of
|
curl_easy_setopt() is used to tell libcurl how to behave. Most operations in
|
||||||
ways. Most operations in libcurl have default actions, and by using the
|
libcurl have default actions, and by using the appropriate options to
|
||||||
appropriate options you can make them behave differently (as documented). All
|
\fIcurl_easy_setopt\fP, you can change them. All options are set with the
|
||||||
options are set with the
|
\fIoption\fP followed by a \fIparameter\fP. That parameter can be a long, a
|
||||||
.I option
|
function pointer or an object pointer, all depending on what the specific
|
||||||
followed by a parameter. That parameter can be a long, a function pointer or
|
option expects. Read this manual carefully as bad input values may cause
|
||||||
an object pointer, all depending on what the option in question expects. Read
|
libcurl to behave badly! You can only set one option in each function call. A
|
||||||
this manual carefully as bad input values may cause libcurl to behave badly!
|
typical application uses many curl_easy_setopt() calls in the setup phase.
|
||||||
You can only set one option in each function call. A typical application uses
|
|
||||||
many calls in the setup phase.
|
|
||||||
|
|
||||||
The
|
\fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be
|
||||||
.I "handle"
|
copied by the library. Instead you should keep them available until libcurl no
|
||||||
is the return code from the
|
longer needs them. Failing to do so will cause very odd behavior or even
|
||||||
.I "curl_easy_init"
|
crashes.
|
||||||
call.
|
|
||||||
|
\fBNOTE2:\fP options set with this function call are valid for the forthcoming
|
||||||
|
data transfers that are performed when you invoke \fIcurl_easy_perform\fP.
|
||||||
|
The options are not in any way reset between transfers, so if you want
|
||||||
|
subsequent transfers with different options, you must change them between the
|
||||||
|
transfers.
|
||||||
|
|
||||||
|
The \fIhandle\fP is the return code from a \fIcurl_easy_init(3)\fP or
|
||||||
|
\fIcurl_easy_duphandle(3)\fP call.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
These options are in a bit of random order, but you'll figure it out!
|
The options are listed in a sort of random order, but you'll figure it out!
|
||||||
.TP 0.8i
|
.TP 0.8i
|
||||||
.B CURLOPT_FILE
|
.B CURLOPT_FILE
|
||||||
Data pointer to pass instead of FILE * to the file write function. Note that
|
Data pointer to pass to the file write function. Note that if you specify the
|
||||||
if you specify the
|
\fICURLOPT_WRITEFUNCTION\fP, this is the pointer you'll get as input. If you
|
||||||
.I CURLOPT_WRITEFUNCTION
|
don't use a callback, you must pass a 'FILE *' as libcurl will pass this to
|
||||||
, this is the pointer you'll get as input.
|
fwrite() when writing data.
|
||||||
|
|
||||||
|
\fBNOTE:\fP If you're using libcurl as a win32 DLL, you MUST use the
|
||||||
|
\fICURLOPT_WRITEFUNCTION\fP if you set this option or you will experience
|
||||||
|
crashes.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_WRITEFUNCTION
|
.B CURLOPT_WRITEFUNCTION
|
||||||
Function pointer that should use match the following prototype:
|
Function pointer that should match the following prototype: \fBsize_t
|
||||||
.BI "size_t function( void *ptr, size_t size, size_t nmemb, FILE *stream);"
|
function( void *ptr, size_t size, size_t nmemb, void *stream);\fP This
|
||||||
This function gets called by libcurl as soon as there is received data that
|
function gets called by libcurl as soon as there is data available to pass
|
||||||
needs to be written down. The size of the data pointed to by
|
available that needs to be saved. The size of the data pointed to by \fIptr\fP
|
||||||
.I ptr
|
is \fIsize\fP multiplied with \fInmemb\fP. Return the number of bytes
|
||||||
is
|
actually taken care of. If that amount differs from the amount passed to your
|
||||||
.I size
|
function, it'll signal an error to the library and it will abort the transfer
|
||||||
multiplied with
|
and return \fICURLE_WRITE_ERROR\fP.
|
||||||
.I nmemb.
|
|
||||||
Return the number of bytes actually written or return -1 to signal error to the library (it will cause it to abort the transfer).
|
Set the \fIstream\fP argument with the \fBCURLOPT_FILE\fP option.
|
||||||
|
|
||||||
|
\fBNOTE:\fP you will be passed as much data as possible in all invokes, but
|
||||||
|
you cannot possibly make any assumptions. It may be one byte, it may be
|
||||||
|
thousands.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_INFILE
|
.B CURLOPT_INFILE
|
||||||
Data pointer to pass instead of FILE * to the file read function. Note that if
|
Data pointer to pass to the file read function. Note that if you specify the
|
||||||
you specify the
|
\fICURLOPT_READFUNCTION\fP, this is the pointer you'll get as input. If you
|
||||||
.I CURLOPT_READFUNCTION
|
don't specify a read callback, this must be a valid FILE *.
|
||||||
, this is the pointer you'll get as input.
|
|
||||||
|
\fBNOTE:\fP If you're using libcurl as a win32 DLL, you MUST use a
|
||||||
|
\fICURLOPT_READFUNCTION\fP if you set this option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_READFUNCTION
|
.B CURLOPT_READFUNCTION
|
||||||
Function pointer that should use match the following prototype:
|
Function pointer that should match the following prototype: \fBsize_t
|
||||||
.BI "size_t function( void *ptr, size_t size, size_t nmemb, FILE *stream);"
|
function( void *ptr, size_t size, size_t nmemb, void *stream);\fP This
|
||||||
This function gets called by libcurl as soon as it needs to read data in order
|
function gets called by libcurl as soon as it needs to read data in order to
|
||||||
to send it to the peer. The data area pointed at by the pointer
|
send it to the peer. The data area pointed at by the pointer \fIptr\fP may be
|
||||||
.I ptr
|
filled with at most \fIsize\fP multiplied with \fInmemb\fP number of
|
||||||
may be filled with at most
|
bytes. Your function must return the actual number of bytes that you stored in
|
||||||
.I size
|
that memory area. Returning 0 will signal end-of-file to the library and cause
|
||||||
multiplied with
|
it to stop the current transfer.
|
||||||
.I nmemb
|
|
||||||
number of bytes. Your function must return the actual number of bytes that you
|
|
||||||
stored in that memory area. Returning -1 will signal an error to the library
|
|
||||||
and cause it to abort the current transfer immediately.
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_INFILESIZE
|
.B CURLOPT_INFILESIZE
|
||||||
When uploading a file to a remote site, this option should be used to tell
|
When uploading a file to a remote site, this option should be used to tell
|
||||||
@@ -74,47 +86,68 @@ libcurl what the expected size of the infile is.
|
|||||||
.TP
|
.TP
|
||||||
.B CURLOPT_URL
|
.B CURLOPT_URL
|
||||||
The actual URL to deal with. The parameter should be a char * to a zero
|
The actual URL to deal with. The parameter should be a char * to a zero
|
||||||
terminated string. NOTE: this option is currently required!
|
terminated string. The string must remain present until curl no longer needs
|
||||||
|
it, as it doesn't copy the string.
|
||||||
|
|
||||||
|
\fBNOTE:\fP this option is (the only one) required to be set before
|
||||||
|
\fIcurl_easy_perform(3)\fP is called.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PROXY
|
.B CURLOPT_PROXY
|
||||||
If you need libcurl to use a http proxy to access the outside world, set the
|
Set HTTP proxy to use. The parameter should be a char * to a zero terminated
|
||||||
proxy string with this option. The parameter should be a char * to a zero
|
string holding the host name or dotted IP address. To specify port number in
|
||||||
terminated string. To specify port number in this string, append":[port]" to
|
this string, append :[port] to the end of the host name. The proxy string may
|
||||||
the end of the host name. The proxy string may be prefixed with
|
be prefixed with [protocol]:// since any such prefix will be ignored. The
|
||||||
"[protocol]://" since any such prefix will be ignored.
|
proxy's port number may optionally be specified with the separate option
|
||||||
|
\fICURLOPT_PROXYPORT\fP.
|
||||||
|
|
||||||
|
\fBNOTE:\fP when you tell the library to use a HTTP proxy, libcurl will
|
||||||
|
transparently convert operations to HTTP even if you specify a FTP URL
|
||||||
|
etc. This may have an impact on what other features of the library you can
|
||||||
|
use, such as CURLOPT_QUOTE and similar FTP specifics that don't work unless
|
||||||
|
you tunnel through the HTTP proxy. Such tunneling is activated with
|
||||||
|
\fICURLOPT_HTTPPROXYTUNNEL\fP.
|
||||||
|
|
||||||
|
\fBNOTE2:\fP libcurl respects the environment variables \fBhttp_proxy\fP,
|
||||||
|
\fBftp_proxy\fP, \fBall_proxy\fP etc, if any of those is set.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PROXYPORT
|
.B CURLOPT_PROXYPORT
|
||||||
Set this long with this option to set the proxy port to use unless it is
|
Pass a long with this option to set the proxy port to connect to unless it is
|
||||||
specified in the proxy string CURLOPT_PROXY.
|
specified in the proxy string \fICURLOPT_PROXY\fP.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HTTPPROXYTUNNEL
|
.B CURLOPT_HTTPPROXYTUNNEL
|
||||||
Set the parameter to non-zero to get the library to tunnel all non-HTTP
|
Set the parameter to non-zero to get the library to tunnel all operations
|
||||||
operations through the given HTTP proxy. Do note that there is a big
|
through a given HTTP proxy. Note that there is a big difference between using
|
||||||
difference to use a proxy and to tunnel through it. If you don't know what
|
a proxy and to tunnel through it. If you don't know what this means, you
|
||||||
this means, you probably don't want this tunnel option. (Added in libcurl 7.3)
|
probably don't want this tunneling option. (Added in libcurl 7.3)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_VERBOSE
|
.B CURLOPT_VERBOSE
|
||||||
Set the parameter to non-zero to get the library to display a lot of verbose
|
Set the parameter to non-zero to get the library to display a lot of verbose
|
||||||
information about its operations.
|
information about its operations. Very useful for libcurl and/or protocol
|
||||||
|
debugging and understanding.
|
||||||
|
|
||||||
|
You hardly ever want this set in production use, you will almost always want
|
||||||
|
this when you debug/report problems.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HEADER
|
.B CURLOPT_HEADER
|
||||||
A non-zero parameter tells the library to include the header in the
|
A non-zero parameter tells the library to include the header in the body
|
||||||
output. This is only relevant for protocols that actually has a header
|
output. This is only relevant for protocols that actually have headers
|
||||||
preceeding the data (like HTTP).
|
preceding the data (like HTTP).
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_NOPROGRESS
|
.B CURLOPT_NOPROGRESS
|
||||||
A non-zero parameter tells the library to shut of the built-in progress meter
|
A non-zero parameter tells the library to shut of the built-in progress meter
|
||||||
completely. (NOTE: future versions of the lib is likely to not have any
|
completely.
|
||||||
built-in progress meter at all).
|
|
||||||
|
\fBNOTE:\fP future versions of libcurl is likely to not have any built-in
|
||||||
|
progress meter at all.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_NOBODY
|
.B CURLOPT_NOBODY
|
||||||
A non-zero parameter tells the library to not include the body-part in the
|
A non-zero parameter tells the library to not include the body-part in the
|
||||||
output. This is only relevant for protocols that have a separate header and
|
output. This is only relevant for protocols that have separate header and body
|
||||||
body part.
|
parts.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FAILONERROR
|
.B CURLOPT_FAILONERROR
|
||||||
A non-zero parameter tells the library to fail silently if the HTTP code
|
A non-zero parameter tells the library to fail silently if the HTTP code
|
||||||
returned is equal or larger than 300. The default action would be to return
|
returned is equal to or larger than 300. The default action would be to return
|
||||||
the page normally, ignoring that code.
|
the page normally, ignoring that code.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_UPLOAD
|
.B CURLOPT_UPLOAD
|
||||||
@@ -125,11 +158,13 @@ CURLOPT_INFILE and CURLOPT_INFILESIZE are also interesting for uploads.
|
|||||||
A non-zero parameter tells the library to do a regular HTTP post. This is a
|
A non-zero parameter tells the library to do a regular HTTP post. This is a
|
||||||
normal application/x-www-form-urlencoded kind, which is the most commonly used
|
normal application/x-www-form-urlencoded kind, which is the most commonly used
|
||||||
one by HTML forms. See the CURLOPT_POSTFIELDS option for how to specify the
|
one by HTML forms. See the CURLOPT_POSTFIELDS option for how to specify the
|
||||||
data to post and CURLOPT_POSTFIELDSIZE in how to set the data size.
|
data to post and CURLOPT_POSTFIELDSIZE in how to set the data size. Starting
|
||||||
|
with libcurl 7.8, this option is obsolete. Using the CURLOPT_POSTFIELDS option
|
||||||
|
will imply this option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FTPLISTONLY
|
.B CURLOPT_FTPLISTONLY
|
||||||
A non-zero parameter tells the library to just list the names of an ftp
|
A non-zero parameter tells the library to just list the names of an ftp
|
||||||
directory, instead of doing a full directory listin that would include file
|
directory, instead of doing a full directory listing that would include file
|
||||||
sizes, dates etc.
|
sizes, dates etc.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FTPAPPEND
|
.B CURLOPT_FTPAPPEND
|
||||||
@@ -137,88 +172,108 @@ A non-zero parameter tells the library to append to the remote file instead of
|
|||||||
overwrite it. This is only useful when uploading to a ftp site.
|
overwrite it. This is only useful when uploading to a ftp site.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_NETRC
|
.B CURLOPT_NETRC
|
||||||
A non-zero parameter tells the library to scan your
|
A non-zero parameter tells the library to scan your \fI~/.netrc\fP file to
|
||||||
.I ~/.netrc
|
find user name and password for the remote site you are about to access. Only
|
||||||
file to find user name and password for the remote site you are about to
|
machine name, user name and password is taken into account (init macros and
|
||||||
access. Do note that curl does not verify that the file has the correct
|
similar things aren't supported).
|
||||||
properties set (as the standard unix ftp client does), and that only machine
|
|
||||||
name, user name and password is taken into account (init macros and similar
|
\fBNote:\fP libcurl does not verify that the file has the correct properties
|
||||||
things aren't supported).
|
set (as the standard Unix ftp client does). It should only be readable by
|
||||||
|
user.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FOLLOWLOCATION
|
.B CURLOPT_FOLLOWLOCATION
|
||||||
A non-zero parameter tells the library to follow any Location: header that the
|
A non-zero parameter tells the library to follow any Location: header that the
|
||||||
server sends as part of a HTTP header. NOTE that this means that the library
|
server sends as part of a HTTP header.
|
||||||
will resend the same request on the new location and follow new Location:
|
|
||||||
headers all the way until no more such headers are returned.
|
\fBNOTE:\fP this means that the library will re-send the same request on the
|
||||||
|
new location and follow new Location: headers all the way until no more such
|
||||||
|
headers are returned. \fICURLOPT_MAXREDIRS\fP can be used to limit the number
|
||||||
|
of redirects libcurl will follow.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_TRANSFERTEXT
|
.B CURLOPT_TRANSFERTEXT
|
||||||
A non-zero parameter tells the library to use ASCII mode for ftp transfers,
|
A non-zero parameter tells the library to use ASCII mode for ftp transfers,
|
||||||
instead of the default binary transfer. For LDAP transfers it gets the data in
|
instead of the default binary transfer. For LDAP transfers it gets the data in
|
||||||
plain text instead of HTML and for win32 systems it does not set the stdout to
|
plain text instead of HTML and for win32 systems it does not set the stdout to
|
||||||
binary mode. This option can be useable when transfering text data between
|
binary mode. This option can be usable when transferring text data between
|
||||||
system with different views on certain characters, such as newlines or
|
systems with different views on certain characters, such as newlines or
|
||||||
similar.
|
similar.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PUT
|
.B CURLOPT_PUT
|
||||||
A non-zero parameter tells the library to use HTTP PUT a file. The file to put
|
A non-zero parameter tells the library to use HTTP PUT to transfer data. The
|
||||||
must be set with CURLOPT_INFILE and CURLOPT_INFILESIZE.
|
data should be set with CURLOPT_INFILE and CURLOPT_INFILESIZE.
|
||||||
.TP
|
|
||||||
.B CURLOPT_MUTE
|
|
||||||
A non-zero parameter tells the library to be completely quiet.
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_USERPWD
|
.B CURLOPT_USERPWD
|
||||||
Pass a char * as parameter, which should be [username]:[password] to use for
|
Pass a char * as parameter, which should be [user name]:[password] to use for
|
||||||
the connection. If the password is left out, you will be prompted for it.
|
the connection. If the password is left out, you will be prompted for it.
|
||||||
|
\fICURLOPT_PASSWDFUNCTION\fP can be used to set your own prompt function.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PROXYUSERPWD
|
.B CURLOPT_PROXYUSERPWD
|
||||||
Pass a char * as parameter, which should be [username]:[password] to use for
|
Pass a char * as parameter, which should be [user name]:[password] to use for
|
||||||
the connection to the HTTP proxy. If the password is left out, you will be
|
the connection to the HTTP proxy. If the password is left out, you will be
|
||||||
prompted for it.
|
prompted for it. \fICURLOPT_PASSWDFUNCTION\fP can be used to set your own
|
||||||
|
prompt function.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_RANGE
|
.B CURLOPT_RANGE
|
||||||
Pass a char * as parameter, which should contain the specified range you
|
Pass a char * as parameter, which should contain the specified range you
|
||||||
want. It should be in the format "X-Y", where X or Y may be left out. The HTTP
|
want. It should be in the format "X-Y", where X or Y may be left out. HTTP
|
||||||
transfers also support several intervals, separated with commas as in
|
transfers also support several intervals, separated with commas as in
|
||||||
.I "X-Y,N-M".
|
\fI"X-Y,N-M"\fP. Using this kind of multiple intervals will cause the HTTP
|
||||||
|
server to send the response document in pieces (using standard MIME separation
|
||||||
|
techniques).
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_ERRORBUFFER
|
.B CURLOPT_ERRORBUFFER
|
||||||
Pass a char * to a buffer that the libcurl may store human readable error
|
Pass a char * to a buffer that the libcurl may store human readable error
|
||||||
messages in. This may be more helpful than just the return code from the
|
messages in. This may be more helpful than just the return code from the
|
||||||
library. The buffer must be at least CURL_ERROR_SIZE big.
|
library. The buffer must be at least CURL_ERROR_SIZE big.
|
||||||
|
|
||||||
|
\fBNote:\fP if the library does not return an error, the buffer may not have
|
||||||
|
been touched. Do not rely on the contents in those cases.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_TIMEOUT
|
.B CURLOPT_TIMEOUT
|
||||||
Pass a long as parameter containing the maximum time in seconds that you allow
|
Pass a long as parameter containing the maximum time in seconds that you allow
|
||||||
the libcurl transfer operation to take. Do note that normally, name lookups
|
the libcurl transfer operation to take. Normally, name lookups can take a
|
||||||
maky take a considerable time and that limiting the operation to less than a
|
considerable time and limiting operations to less than a few minutes risk
|
||||||
few minutes risk aborting perfectly normal operations.
|
aborting perfectly normal operations. This option will cause curl to use the
|
||||||
|
SIGALRM to enable time-outing system calls.
|
||||||
|
|
||||||
|
\fBNOTE:\fP this does not work in Unix multi-threaded programs, as it uses
|
||||||
|
signals.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_POSTFIELDS
|
.B CURLOPT_POSTFIELDS
|
||||||
Pass a char * as parameter, which should be the full data to post in a HTTP
|
Pass a char * as parameter, which should be the full data to post in a HTTP
|
||||||
post operation. See also the CURLOPT_POST.
|
post operation. This is a normal application/x-www-form-urlencoded kind, which
|
||||||
|
is the most commonly used one by HTML forms. See also the CURLOPT_POST. Since
|
||||||
|
7.8, using CURLOPT_POSTFIELDS implies CURLOPT_POST.
|
||||||
|
|
||||||
|
\fBNote:\fP to make multipart/formdata posts (aka rfc1867-posts), check out
|
||||||
|
the \fICURLOPT_HTTPPOST\fP option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_POSTFIELDSIZE
|
.B CURLOPT_POSTFIELDSIZE
|
||||||
If you want to post data to the server without letting libcurl do a strlen()
|
If you want to post data to the server without letting libcurl do a strlen()
|
||||||
to measure the data size, this option must be used. Also, when this option is
|
to measure the data size, this option must be used. When this option is used
|
||||||
used, you can post fully binary data which otherwise is likely to fail. If
|
you can post fully binary data, which otherwise is likely to fail. If this
|
||||||
this size is set to zero, the library will use strlen() to get the data
|
size is set to zero, the library will use strlen() to get the size. (Added in
|
||||||
size. (Added in libcurl 7.2)
|
libcurl 7.2)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_REFERER
|
.B CURLOPT_REFERER
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used to
|
Pass a pointer to a zero terminated string as parameter. It will be used to
|
||||||
set the referer: header in the http request sent to the remote server. This
|
set the Referer: header in the http request sent to the remote server. This
|
||||||
can be used to fool servers or scripts.
|
can be used to fool servers or scripts. You can also set any custom header
|
||||||
|
with \fICURLOPT_HTTPHEADER\fP.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_USERAGENT
|
.B CURLOPT_USERAGENT
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used to
|
Pass a pointer to a zero terminated string as parameter. It will be used to
|
||||||
set the user-agent: header in the http request sent to the remote server. This
|
set the User-Agent: header in the http request sent to the remote server. This
|
||||||
can be used to fool servers or scripts.
|
can be used to fool servers or scripts. You can also set any custom header
|
||||||
|
with \fICURLOPT_HTTPHEADER\fP.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FTPPORT
|
.B CURLOPT_FTPPORT
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used to
|
Pass a pointer to a zero terminated string as parameter. It will be used to
|
||||||
get the IP address to use for the ftp PORT instruction. The PORT instruction
|
get the IP address to use for the ftp PORT instruction. The PORT instruction
|
||||||
tells the remote server to connect to our specified IP address. The string may
|
tells the remote server to connect to our specified IP address. The string may
|
||||||
be a plain IP address, a host name, an network interface name (under unix) or
|
be a plain IP address, a host name, an network interface name (under Unix) or
|
||||||
just a '-' letter to let the library use your systems default IP address.
|
just a '-' letter to let the library use your systems default IP
|
||||||
|
address. Default FTP operations are passive, and thus won't use PORT.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_LOW_SPEED_LIMIT
|
.B CURLOPT_LOW_SPEED_LIMIT
|
||||||
Pass a long as parameter. It contains the transfer speed in bytes per second
|
Pass a long as parameter. It contains the transfer speed in bytes per second
|
||||||
@@ -241,66 +296,130 @@ set a cookie in the http request. The format of the string should be
|
|||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HTTPHEADER
|
.B CURLOPT_HTTPHEADER
|
||||||
Pass a pointer to a linked list of HTTP headers to pass to the server in your
|
Pass a pointer to a linked list of HTTP headers to pass to the server in your
|
||||||
HTTP request. The linked list should be a fully valid list of 'struct
|
HTTP request. The linked list should be a fully valid list of \fBstruct
|
||||||
curl_slist' structs properly filled in. Use
|
curl_slist\fP structs properly filled in. Use \fIcurl_slist_append(3)\fP to
|
||||||
.I curl_slist_append(3)
|
create the list and \fIcurl_slist_free_all(3)\fP to clean up an entire
|
||||||
to create the list and
|
list. If you add a header that is otherwise generated and used by libcurl
|
||||||
.I curl_slist_free_all(3)
|
internally, your added one will be used instead. If you add a header with no
|
||||||
to clean up an entire list.
|
contents as in 'Accept:' (no data on the right side of the colon), the
|
||||||
|
internally used header will get disabled. Thus, using this option you can add
|
||||||
|
new headers, replace internal headers and remove internal headers.
|
||||||
|
|
||||||
|
\fBNOTE:\fPThe most commonly replaced headers have "shortcuts" in the options
|
||||||
|
CURLOPT_COOKIE, CURLOPT_USERAGENT and CURLOPT_REFERER.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HTTPPOST
|
.B CURLOPT_HTTPPOST
|
||||||
Tells libcurl you want a multipart/formdata HTTP POST to be made and you
|
Tells libcurl you want a multipart/formdata HTTP POST to be made and you
|
||||||
instruct what data to pass on to the server. Pass a pointer to a linked list
|
instruct what data to pass on to the server. Pass a pointer to a linked list
|
||||||
of HTTP post structs as parameter. The linked list should be a fully valid
|
of HTTP post structs as parameter. The linked list should be a fully valid
|
||||||
list of 'struct HttpPost' structs properly filled in. The best and most
|
list of 'struct HttpPost' structs properly filled in. The best and most
|
||||||
elegant way to do this, is to use
|
elegant way to do this, is to use \fIcurl_formadd(3)\fP as documented. The
|
||||||
.I curl_formparse(3)
|
data in this list must remained intact until you close this curl handle again
|
||||||
as documented.
|
with \fIcurl_easy_cleanup(3)\fP.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_SSLCERT
|
.B CURLOPT_SSLCERT
|
||||||
Pass a pointer to a zero terminated string as parameter. The string should be
|
Pass a pointer to a zero terminated string as parameter. The string should be
|
||||||
the file name of your certficicate in PEM format.
|
the file name of your certificate. The default format is "PEM" and can be
|
||||||
|
changed with \fICURLOPT_SSLCERTTYPE\fP.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSLCERTTYPE
|
||||||
|
Pass a pointer to a zero terminated string as parameter. The string should be
|
||||||
|
the format of your certificate. Supported formats are "PEM" and "DER".
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_SSLCERTPASSWD
|
.B CURLOPT_SSLCERTPASSWD
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used as
|
Pass a pointer to a zero terminated string as parameter. It will be used as
|
||||||
the password required to use the CURLOPT_SSLCERT certificate. If the password
|
the password required to use the CURLOPT_SSLCERT certificate. If the password
|
||||||
is not supplied, you will be prompted for it.
|
is not supplied, you will be prompted for it. \fICURLOPT_PASSWDFUNCTION\fP can
|
||||||
|
be used to set your own prompt function.
|
||||||
|
|
||||||
|
\fBNOTE:\fPThis option is replaced by \fICURLOPT_SSLKEYPASSWD\fP and only
|
||||||
|
cept for backward compatibility. You never needed a pass phrase to load
|
||||||
|
a certificate but you need one to load your private key.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSLKEY
|
||||||
|
Pass a pointer to a zero terminated string as parameter. The string should be
|
||||||
|
the file name of your private key. The default format is "PEM" and can be
|
||||||
|
changed with \fICURLOPT_SSLKEYTYPE\fP.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSLKEYTYPE
|
||||||
|
Pass a pointer to a zero terminated string as parameter. The string should be
|
||||||
|
the format of your private key. Supported formats are "PEM", "DER" and "ENG".
|
||||||
|
|
||||||
|
\fBNOTE:\fPThe format "ENG" enables you to load the private key from a crypto
|
||||||
|
engine. in this case \fICURLOPT_SSLKEY\fP is used as an identifier passed to
|
||||||
|
the engine. You have to set the crypto engine with \fICURLOPT_SSL_ENGINE\fP.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSLKEYASSWD
|
||||||
|
Pass a pointer to a zero terminated string as parameter. It will be used as
|
||||||
|
the password required to use the \fICURLOPT_SSLKEY\fP private key. If the password
|
||||||
|
is not supplied, you will be prompted for it. \fICURLOPT_PASSWDFUNCTION\fP can
|
||||||
|
be used to set your own prompt function.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSL_ENGINE
|
||||||
|
Pass a pointer to a zero terminated string as parameter. It will be used as
|
||||||
|
the identifier for the crypto engine you want to use for your private key.
|
||||||
|
|
||||||
|
\fBNOTE:\fPIf the crypto device cannot be loaded, \fICURLE_SSL_ENGINE_NOTFOUND\fP
|
||||||
|
is returned.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSL_ENGINEDEFAULT
|
||||||
|
Sets the actual crypto engine as the default for (asymetric) crypto operations.
|
||||||
|
|
||||||
|
\fBNOTE:\fPIf the crypto device cannot be set, \fICURLE_SSL_ENGINE_SETFAILED\fP
|
||||||
|
is returned.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_CRLF
|
.B CURLOPT_CRLF
|
||||||
Convert unix newlines to CRLF newlines on FTP uploads.
|
Convert Unix newlines to CRLF newlines on FTP uploads.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_QUOTE
|
.B CURLOPT_QUOTE
|
||||||
Pass a pointer to a linked list of FTP commands to pass to the server prior to
|
Pass a pointer to a linked list of FTP commands to pass to the server prior to
|
||||||
your ftp request. The linked list should be a fully valid list of 'struct
|
your ftp request. The linked list should be a fully valid list of 'struct
|
||||||
curl_slist' structs properly filled in. Use
|
curl_slist' structs properly filled in. Use \fIcurl_slist_append(3)\fP to
|
||||||
.I curl_slist_append(3)
|
append strings (commands) to the list, and clear the entire list afterwards
|
||||||
to append strings (commands) to the list, and clear the entire list afterwards
|
with \fIcurl_slist_free_all(3)\fP. Disable this operation again by setting a
|
||||||
with
|
NULL to this option.
|
||||||
.I curl_slist_free_all(3)
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_POSTQUOTE
|
.B CURLOPT_POSTQUOTE
|
||||||
Pass a pointer to a linked list of FTP commands to pass to the server after
|
Pass a pointer to a linked list of FTP commands to pass to the server after
|
||||||
your ftp transfer request. The linked list should be a fully valid list of
|
your ftp transfer request. The linked list should be a fully valid list of
|
||||||
struct curl_slist structs properly filled in as described for
|
struct curl_slist structs properly filled in as described for
|
||||||
.I "CURLOPT_QUOTE"
|
\fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this
|
||||||
|
option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_WRITEHEADER
|
.B CURLOPT_WRITEHEADER
|
||||||
Pass a FILE * to be used to write the header part of the received data to.
|
Pass a pointer to be used to write the header part of the received data to. If
|
||||||
|
you don't use your own callback to take care of the writing, this must be a
|
||||||
|
valid FILE *. See also the \fICURLOPT_HEADERFUNCTION\fP option below on how to set a
|
||||||
|
custom get-all-headers callback.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_HEADERFUNCTION
|
||||||
|
Function pointer that should match the following prototype: \fIsize_t
|
||||||
|
function( void *ptr, size_t size, size_t nmemb, void *stream);\fP. This
|
||||||
|
function gets called by libcurl as soon as there is received header data that
|
||||||
|
needs to be written down. The headers are guaranteed to be written one-by-one
|
||||||
|
and only complete lines are written. Parsing headers should be easy enough
|
||||||
|
using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP
|
||||||
|
multiplied with \fInmemb\fP. The pointer named \fIstream\fP will be the one
|
||||||
|
you passed to libcurl with the \fICURLOPT_WRITEHEADER\fP option. Return the
|
||||||
|
number of bytes actually written or return -1 to signal error to the library
|
||||||
|
(it will cause it to abort the transfer with a \fICURLE_WRITE_ERROR\fP return
|
||||||
|
code). (Added in libcurl 7.7.2)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_COOKIEFILE
|
.B CURLOPT_COOKIEFILE
|
||||||
Pass a pointer to a zero terminated string as parameter. It should contain the
|
Pass a pointer to a zero terminated string as parameter. It should contain the
|
||||||
name of your file holding cookie data. The cookie data may be in netscape
|
name of your file holding cookie data. The cookie data may be in Netscape /
|
||||||
cookie data format or just regular HTTP-style headers dumped to a file.
|
Mozilla cookie data format or just regular HTTP-style headers dumped to a
|
||||||
|
file.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_SSLVERSION
|
.B CURLOPT_SSLVERSION
|
||||||
Pass a long as parameter. Set what version of SSL to attempt to use, 2 or
|
Pass a long as parameter. Set what version of SSL to attempt to use, 2 or
|
||||||
3. By default, the SSL library will try to solve this by itself although some
|
3. By default, the SSL library will try to solve this by itself although some
|
||||||
servers make this difficult why you at times will have to use this option.
|
servers make this difficult why you at times may have to use this option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_TIMECONDITION
|
.B CURLOPT_TIMECONDITION
|
||||||
Pass a long as parameter. This defines how the CURLOPT_TIMEVALUE time value is
|
Pass a long as parameter. This defines how the CURLOPT_TIMEVALUE time value is
|
||||||
treated. You can set this parameter to TIMECOND_IFMODSINCE or
|
treated. You can set this parameter to TIMECOND_IFMODSINCE or
|
||||||
TIMECOND_IFUNMODSINCE. This is aa HTTP-only feature. (TBD)
|
TIMECOND_IFUNMODSINCE. This is a HTTP-only feature. (TBD)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_TIMEVALUE
|
.B CURLOPT_TIMEVALUE
|
||||||
Pass a long as parameter. This should be the time in seconds since 1 jan 1970,
|
Pass a long as parameter. This should be the time in seconds since 1 jan 1970,
|
||||||
@@ -310,8 +429,8 @@ isn't used, it will be TIMECOND_IFMODSINCE by default.
|
|||||||
.B CURLOPT_CUSTOMREQUEST
|
.B CURLOPT_CUSTOMREQUEST
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be user
|
Pass a pointer to a zero terminated string as parameter. It will be user
|
||||||
instead of GET or HEAD when doing the HTTP request. This is useful for doing
|
instead of GET or HEAD when doing the HTTP request. This is useful for doing
|
||||||
DELETE or other more obscure HTTP requests. Don't do this at will, make sure
|
DELETE or other more or less obscure HTTP requests. Don't do this at will,
|
||||||
your server supports the command first.
|
make sure your server supports the command first.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_STDERR
|
.B CURLOPT_STDERR
|
||||||
Pass a FILE * as parameter. This is the stream to use instead of stderr
|
Pass a FILE * as parameter. This is the stream to use instead of stderr
|
||||||
@@ -325,33 +444,22 @@ name. (Added in libcurl 7.3)
|
|||||||
.B CURLOPT_KRB4LEVEL
|
.B CURLOPT_KRB4LEVEL
|
||||||
Pass a char * as parameter. Set the krb4 security level, this also enables
|
Pass a char * as parameter. Set the krb4 security level, this also enables
|
||||||
krb4 awareness. This is a string, 'clear', 'safe', 'confidential' or
|
krb4 awareness. This is a string, 'clear', 'safe', 'confidential' or
|
||||||
'private'. If the string is set but doesn't match one of these, 'private'
|
\&'private'. If the string is set but doesn't match one of these, 'private'
|
||||||
will be used. Set the string to NULL to disable kerberos4. The kerberos
|
will be used. Set the string to NULL to disable kerberos4. The kerberos
|
||||||
support only works for FTP. (Added in libcurl 7.3)
|
support only works for FTP. (Added in libcurl 7.3)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_WRITEINFO
|
|
||||||
(NOT PRESENT IN 7.4 or later!)
|
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used to
|
|
||||||
report information after a successful request. This string may contain
|
|
||||||
variables that will be substituted by their contents when output. Described
|
|
||||||
elsewhere.
|
|
||||||
.TP
|
|
||||||
.B CURLOPT_PROGRESSFUNCTION
|
.B CURLOPT_PROGRESSFUNCTION
|
||||||
Function pointer that should match the
|
Function pointer that should match the \fIcurl_progress_callback\fP prototype
|
||||||
.BI curl_progress_callback
|
found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of
|
||||||
prototype found in
|
its internal equivalent with a frequent interval during data transfer.
|
||||||
.I <curl/curl.h>
|
Unknown/unused argument values will be set to zero (like if you only download
|
||||||
This function gets called by libcurl instead of its internal
|
data, the upload size will remain 0). Returning a non-zero value from this
|
||||||
equivalent. Unknown/unused argument values will be set to zero (like if you
|
callback will cause libcurl to abort the transfer and return
|
||||||
only download data, the upload size will remain 0). Returning a non-zero value
|
\fICURLE_ABORTED_BY_CALLBACK\fP.
|
||||||
from this callback will cause libcurl to abort the transfer and return
|
|
||||||
CURLE_ABORTED_BY_CALLBACK.
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PROGRESSDATA
|
.B CURLOPT_PROGRESSDATA
|
||||||
Pass a pointer that will be untouched by libcurl and passed as the first
|
Pass a pointer that will be untouched by libcurl and passed as the first
|
||||||
argument in the progress callback set with
|
argument in the progress callback set with \fICURLOPT_PROGRESSFUNCTION\fP.
|
||||||
.I CURLOPT_PROGRESSFUNCTION
|
|
||||||
.
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_SSL_VERIFYPEER
|
.B CURLOPT_SSL_VERIFYPEER
|
||||||
Pass a long that is set to a non-zero value to make curl verify the peer's
|
Pass a long that is set to a non-zero value to make curl verify the peer's
|
||||||
@@ -364,46 +472,151 @@ verify the peer with. This only makes sense when used in combination with the
|
|||||||
CURLOPT_SSL_VERIFYPEER option. (Added in 7.4.2)
|
CURLOPT_SSL_VERIFYPEER option. (Added in 7.4.2)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PASSWDFUNCTION
|
.B CURLOPT_PASSWDFUNCTION
|
||||||
Pass a pointer to a curl_passwd_callback function that will then be called
|
Pass a pointer to a \fIcurl_passwd_callback\fP function that will be called
|
||||||
instead of the internal one if libcurl requests a password. The function must
|
instead of the internal one if libcurl requests a password. The function must
|
||||||
match this prototype:
|
match this prototype: \fBint my_getpass(void *client, char *prompt, char*
|
||||||
.BI "int my_getpass(void *client, char *prompt, char* buffer, int buflen );"
|
buffer, int buflen );\fP. If set to NULL, it equals to making the function
|
||||||
If set to NULL, it equals to making the function always fail. If the function
|
always fail. If the function returns a non-zero value, it will abort the
|
||||||
returns a non-zero value, it will abort the operation and an error
|
operation and an error (CURLE_BAD_PASSWORD_ENTERED) will be returned.
|
||||||
(CURLE_BAD_PASSWORD_ENTERED) will be returned.
|
\fIclient\fP is a generic pointer, see \fICURLOPT_PASSWDDATA\fP. \fIprompt\fP
|
||||||
.I client
|
|
||||||
is a generic pointer, see CURLOPT_PASSWDDATA.
|
|
||||||
.I prompt
|
|
||||||
is a zero-terminated string that is text that prefixes the input request.
|
is a zero-terminated string that is text that prefixes the input request.
|
||||||
.I buffer
|
\fIbuffer\fP is a pointer to data where the entered password should be stored
|
||||||
is a pointer to data where the entered password should be stored and
|
and \fIbuflen\fP is the maximum number of bytes that may be written in the
|
||||||
.I buflen
|
buffer. (Added in 7.4.2)
|
||||||
is the maximum number of bytes that may be written in the buffer.
|
|
||||||
(Added in 7.4.2)
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PASSWDDATA
|
.B CURLOPT_PASSWDDATA
|
||||||
Pass a void * to whatever data you want. The passed pointer will be the first
|
Pass a void * to whatever data you want. The passed pointer will be the first
|
||||||
argument sent to the specifed CURLOPT_PASSWDFUNCTION function. (Added in
|
argument sent to the specifed \fICURLOPT_PASSWDFUNCTION\fP function. (Added in
|
||||||
7.4.2)
|
7.4.2)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FILETIME
|
.B CURLOPT_FILETIME
|
||||||
Pass a long. If it is a non-zero value, libcurl will attempt to get the
|
Pass a long. If it is a non-zero value, libcurl will attempt to get the
|
||||||
modification date of the remote document in this operation. This requires that
|
modification date of the remote document in this operation. This requires that
|
||||||
the remote server sends the time or replies to a time querying command. The
|
the remote server sends the time or replies to a time querying command. The
|
||||||
curl_easy_getinfo() function with the CURLINFO_FILETIME argument can be used
|
\fIcurl_easy_getinfo(3)\fP function with the \fICURLINFO_FILETIME\fP argument
|
||||||
after a transfer to extract the received time (if any). (Added in 7.5)
|
can be used after a transfer to extract the received time (if any). (Added in
|
||||||
|
7.5)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_MAXREDIRS
|
.B CURLOPT_MAXREDIRS
|
||||||
Pass a long. The set number will be the redirection limit. If that many
|
Pass a long. The set number will be the redirection limit. If that many
|
||||||
redirections have been followed, the next redirect will cause an error. This
|
redirections have been followed, the next redirect will cause an error
|
||||||
option only makes sense if the CURLOPT_FOLLOWLOCATION is used at the same
|
(\fICURLE_TOO_MANY_REDIRECTS\fP). This option only makes sense if the
|
||||||
time. (Added in 7.5)
|
\fICURLOPT_FOLLOWLOCATION\fP is used at the same time. (Added in 7.5)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_MAXCONNECTS
|
||||||
|
Pass a long. The set number will be the persistant connection cache size. The
|
||||||
|
set amount will be the maximum amount of simultaneous connections that libcurl
|
||||||
|
may cache between file transfers. Default is 5, and there isn't much point in
|
||||||
|
changing this value unless you are perfectly aware of how this work and
|
||||||
|
changes libcurl's behaviour.
|
||||||
|
|
||||||
|
\fBNOTE:\fP if you already have performed transfers with this curl handle,
|
||||||
|
setting a smaller MAXCONNECTS than before may cause open connections to get
|
||||||
|
closed unnecessarily. (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_CLOSEPOLICY
|
||||||
|
Pass a long. This option sets what policy libcurl should use when the
|
||||||
|
connection cache is filled and one of the open connections has to be closed to
|
||||||
|
make room for a new connection. This must be one of the CURLCLOSEPOLICY_*
|
||||||
|
defines. Use \fICURLCLOSEPOLICY_LEAST_RECENTLY_USED\fP to make libcurl close
|
||||||
|
the connection that was least recently used, that connection is also least
|
||||||
|
likely to be capable of re-use. Use \fICURLCLOSEPOLICY_OLDEST\fP to make
|
||||||
|
libcurl close the oldest connection, the one that was created first among the
|
||||||
|
ones in the connection cache. The other close policies are not support
|
||||||
|
yet. (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_FRESH_CONNECT
|
||||||
|
Pass a long. Set to non-zero to make the next transfer use a new (fresh)
|
||||||
|
connection by force. If the connection cache is full before this connection,
|
||||||
|
one of the existing connections will be closed as according to the selected or
|
||||||
|
default policy. This option should be used with caution and only if you
|
||||||
|
understand what it does. Set this to 0 to have libcurl attempt re-using an
|
||||||
|
existing connection (default behavior). (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_FORBID_REUSE
|
||||||
|
Pass a long. Set to non-zero to make the next transfer explicitly close the
|
||||||
|
connection when done. Normally, libcurl keep all connections alive when done
|
||||||
|
with one transfer in case there comes a succeeding one that can re-use them.
|
||||||
|
This option should be used with caution and only if you understand what it
|
||||||
|
does. Set to 0 to have libcurl keep the connection open for possibly later
|
||||||
|
re-use (default behavior). (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_RANDOM_FILE
|
||||||
|
Pass a char * to a zero terminated file name. The file will be used to read
|
||||||
|
from to seed the random engine for SSL. The more random the specified file is,
|
||||||
|
the more secure will the SSL connection become.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_EGDSOCKET
|
||||||
|
Pass a char * to the zero terminated path name to the Entropy Gathering Daemon
|
||||||
|
socket. It will be used to seed the random engine for SSL.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_CONNECTTIMEOUT
|
||||||
|
Pass a long. It should contain the maximum time in seconds that you allow the
|
||||||
|
connection to the server to take. This only limits the connection phase, once
|
||||||
|
it has connected, this option is of no more use. Set to zero to disable
|
||||||
|
connection timeout (it will then only timeout on the system's internal
|
||||||
|
timeouts). See also the \fICURLOPT_TIMEOUT\fP option.
|
||||||
|
|
||||||
|
\fBNOTE:\fP this does not work in unix multi-threaded programs, as it uses
|
||||||
|
signals.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_HTTPGET
|
||||||
|
Pass a long. If the long is non-zero, this forces the HTTP request to get back
|
||||||
|
to GET. Only really usable if POST, PUT or a custom request have been used
|
||||||
|
previously using the same curl handle. (Added in 7.8.1)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSL_VERIFYHOST
|
||||||
|
Pass a long. Set if we should verify the Common name from the peer certificate
|
||||||
|
in the SSL handshake, set 1 to check existence, 2 to ensure that it matches
|
||||||
|
the provided hostname. (Added in 7.8.1)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_COOKIEJAR
|
||||||
|
Pass a file name as char *, zero terminated. This will make libcurl dump all
|
||||||
|
internally known cookies to the specified file when \fIcurl_easy_cleanup(3)\fP
|
||||||
|
is called. If no cookies are known, no file will be created. Specify "-" to
|
||||||
|
instead have the cookies written to stdout.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_SSL_CIPHER_LIST
|
||||||
|
Pass a char *, pointing to a zero terminated string holding the list of
|
||||||
|
ciphers to use for the SSL connection. The list must be syntactly correct, it
|
||||||
|
consists of one or more cipher strings separated by colons. Commas or spaces
|
||||||
|
are also acceptable separators but colons are normally used, \!, \- and \+ can
|
||||||
|
be used as operators. Valid examples of cipher lists include 'RC4-SHA',
|
||||||
|
\'SHA1+DES\', 'TLSv1' and 'DEFAULT'. The default list is normally set when you
|
||||||
|
compile OpenSSL.
|
||||||
|
|
||||||
|
You'll find more details about cipher lists on this URL:
|
||||||
|
\fIhttp://www.openssl.org/docs/apps/ciphers.html\fP
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_HTTP_VERSION
|
||||||
|
Pass a long, set to one of the values described below. They force libcurl to
|
||||||
|
use the specific HTTP versions. This is not sensible to do unless you have a
|
||||||
|
good reason.
|
||||||
|
.RS
|
||||||
|
.TP 5
|
||||||
|
.B CURL_HTTP_VERSION_NONE
|
||||||
|
We don't care about what version the library uses. libcurl will use whatever
|
||||||
|
it thinks fit.
|
||||||
|
.TP
|
||||||
|
.B CURL_HTTP_VERSION_1_0
|
||||||
|
Enforce HTTP 1.0 requests.
|
||||||
|
.TP
|
||||||
|
.B CURL_HTTP_VERSION_1_1
|
||||||
|
Enforce HTTP 1.1 requests.
|
||||||
|
.RE
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_FTP_USE_EPSV
|
||||||
|
Pass a long. If the value is non-zero, it tells curl to use the EPSV command
|
||||||
|
when doing passive FTP downloads (which is always does by default). Using EPSV
|
||||||
|
means that it will first attempt to use EPSV before using PASV, but if you
|
||||||
|
pass FALSE (zero) to this option, it will not try using EPSV, only plain PASV.
|
||||||
.PP
|
.PP
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
0 means the option was set properly, non-zero means an error as
|
CURLE_OK (zero) means that the option was set properly, non-zero means an
|
||||||
.I <curl/curl.h>
|
error occurred as \fI<curl/curl.h>\fP defines.
|
||||||
defines
|
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_init "(3), " curl_easy_cleanup "(3), "
|
.BR curl_easy_init "(3), " curl_easy_cleanup "(3), "
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
Surely there are some, you tell me!
|
If you find any bugs, or just have questions, subscribe to one of the mailing
|
||||||
|
lists and post. We won't bite.
|
||||||
|
|
||||||
|
|||||||
28
docs/curl_escape.3
Normal file
28
docs/curl_escape.3
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_escape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_escape - URL encodes the given string
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "char *curl_escape( char *" url ", int "length " );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
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,
|
||||||
|
A-Z or 0-9 will be converted to their "URL escaped" version. If a sequence of
|
||||||
|
%NN (where NN is a two-digit hexadecimal number) is found in the string to
|
||||||
|
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.
|
||||||
|
|
||||||
|
You must free() the returned string when you're done with it.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
A pointer to a zero terminated string or NULL if it failed.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.I curl_unescape(), RFC 2396
|
||||||
165
docs/curl_formadd.3
Normal file
165
docs/curl_formadd.3
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
.\" 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,8 +1,8 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_formfree 3 "17 November 2000" "Curl 7.5" "libcurl Manual"
|
.TH curl_formfree 3 "6 April 2001" "libcurl 7.7.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -12,12 +12,16 @@ curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
|||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_formfree() is used to clean up data previously built/appended with
|
curl_formfree() is used to clean up data previously built/appended with
|
||||||
curl_formparse(). This must be called when the data has been used, which
|
curl_formadd()/curl_formparse(). This must be called when the data has
|
||||||
typically means after the curl_easy_perform() has been called.
|
been used, which typically means after the curl_easy_perform() has
|
||||||
|
been called.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
None
|
None
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_formparse "(3) "
|
.BR curl_formparse "(3) [deprecated], "
|
||||||
|
.BR curl_formadd "(3) "
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
Surely there are some, you tell me!
|
libcurl 7.7.1 and earlier versions does not allow a NULL pointer to be used as
|
||||||
|
argument.
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,62 +1,18 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_formparse 3 "6 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_formparse 3 "17 Dec 2001" "libcurl 7.9.2" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_formparse - add a section to a multipart/formdata HTTP POST
|
curl_formparse - add a section to a multipart/formdata HTTP POST:
|
||||||
|
deprecated (use curl_formadd instead)
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode *curl_formparse(char *" string, "struct HttpPost **" firstitem,
|
.BI "CURLcode curl_formparse(char * " string, " struct HttpPost ** " firstitem,
|
||||||
.BI "struct HttpPost ** "lastitem ");"
|
.BI "struct HttpPost ** " lastitem ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_formparse() is used to append sections when building a multipart/formdata
|
This has been removed deliberately. The \fBcurl_formadd\fP has been introduced
|
||||||
HTTP POST. Append one section at a time until you've added all the sections
|
to replace this function. Do not use this. Convert to the new function
|
||||||
you want included and then you pass the
|
now. curl_formparse() will be removed from a future version of libcurl.
|
||||||
.I firstitem
|
|
||||||
pointer as parameter to CURLOPT_HTTPPOST.
|
|
||||||
.I lastitem
|
|
||||||
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 in a faster way.
|
|
||||||
.I string
|
|
||||||
must be a zero terminated string following the following syntax.
|
|
||||||
.SH "FORM PARSE STRINGS"
|
|
||||||
The
|
|
||||||
.I string
|
|
||||||
parameter must be using one of the following patterns. Note that the []
|
|
||||||
letters should not be included in the real-life string.
|
|
||||||
.TP 0.8i
|
|
||||||
.B [name]=[contents]
|
|
||||||
Add a form field named 'name' with the contents 'contents'. This is the
|
|
||||||
typcial contents of the HTML tag <input type=text>.
|
|
||||||
.TP
|
|
||||||
.B [name]=@[filename]
|
|
||||||
Add a form field named 'name' with the contents as read from the local file
|
|
||||||
named 'filename'. This is the typcial contents of the HTML tag <input
|
|
||||||
type=file>.
|
|
||||||
.TP
|
|
||||||
.B [name]=@[filename1,filename2,...]
|
|
||||||
Add a form field named 'name' with the contents as read from the local files
|
|
||||||
named 'filename1' and 'filename2'. This is identical to the upper, except that
|
|
||||||
you get the contents of several files in one section.
|
|
||||||
.TP
|
|
||||||
.B [name]=@[filename];[content-type]
|
|
||||||
Whenever you specify a file to read from, you can optionally specify the
|
|
||||||
content-type as well. The content-type is passed to the server together with
|
|
||||||
the contents of the file. curl_formparse() will guess content-type for a
|
|
||||||
number of well-known extensions and otherwise it will set it to binary. You
|
|
||||||
can override the internal decision by using this option.
|
|
||||||
.TP
|
|
||||||
.B [name]=@[filename1,filename2,...];[content-type]
|
|
||||||
When you specify several files to read the contents from, you can set the
|
|
||||||
content-type for all of them in the same way as with a single file.
|
|
||||||
.PP
|
|
||||||
.SH RETURN VALUE
|
|
||||||
Returns non-zero if an error occurs.
|
|
||||||
.SH "SEE ALSO"
|
|
||||||
.BR curl_easy_setopt "(3) "
|
|
||||||
.SH BUGS
|
|
||||||
Surely there are some, you tell me!
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getdate 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_getdate - Convert an date in a ASCII string to number of seconds since
|
curl_getdate - Convert an date in a ASCII string to number of seconds since
|
||||||
January 1, 1970
|
January 1, 1970
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getenv 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_getenv 3 "15 August 2001" "libcurl 7.8.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_getenv - return value for environment name
|
curl_getenv - return value for environment name
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "char *curl_getenv(char *" name ");
|
.BI "char *curl_getenv(const char *" name ");
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_getenv() is a portable wrapper for the getenv() function, meant to
|
curl_getenv() is a portable wrapper for the getenv() function, meant to
|
||||||
|
|||||||
27
docs/curl_global_cleanup.3
Normal file
27
docs/curl_global_cleanup.3
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_global_cleanup 3 "28 May 2001" "libcurl 7.8" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_global_cleanup - Global libcurl cleanup
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "void curl_global_cleanup(void);"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
curl_global_cleanup must be called once (no matter how many threads or libcurl
|
||||||
|
sessions that'll be used) by every application that uses libcurl, after all
|
||||||
|
uses of libcurl is complete.
|
||||||
|
|
||||||
|
This is the opposite of \fIcurl_global_init\fP.
|
||||||
|
|
||||||
|
Not calling this function may result in memory leaks.
|
||||||
|
|
||||||
|
This function was added in libcurl 7.8.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_global_init "(3), "
|
||||||
|
.SH BUGS
|
||||||
|
None?
|
||||||
|
|
||||||
49
docs/curl_global_init.3
Normal file
49
docs/curl_global_init.3
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_global_init 3 "13 Nov 2001" "libcurl 7.9.1" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_global_init - Global libcurl initialisation
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURLcode curl_global_init(long " flags ");"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function should only be called once (no matter how many threads or
|
||||||
|
libcurl sessions that'll be used) by every application that uses libcurl.
|
||||||
|
|
||||||
|
If this function hasn't been invoked when \fIcurl_easy_init\fP is called, it
|
||||||
|
will be done automatically by libcurl.
|
||||||
|
|
||||||
|
The flags option is a bit pattern that tells libcurl exact what features to
|
||||||
|
init, as described below. Set the desired bits by ORing the values together.
|
||||||
|
|
||||||
|
You must however \fBalways\fP use the \fIcurl_global_cleanup\fP function, as
|
||||||
|
that cannot be called automatically for you by libcurl.
|
||||||
|
|
||||||
|
Calling this function more than once will cause unpredictable results.
|
||||||
|
|
||||||
|
This function was added in libcurl 7.8.
|
||||||
|
.SH FLAGS
|
||||||
|
.TP 5
|
||||||
|
.B CURL_GLOBAL_ALL
|
||||||
|
Initialize everything possible. This sets all known bits.
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_SSL
|
||||||
|
Initialize SSL
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_WIN32
|
||||||
|
Initialize the Win32 socket libraries. (added in libcurl 7.8.1)
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_NOTHING
|
||||||
|
Initialise nothing extra. This sets no bit.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
If this function returns non-zero, something went wrong and you cannot use the
|
||||||
|
other curl functions.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_global_cleanup "(3), "
|
||||||
|
.SH BUGS
|
||||||
|
None.
|
||||||
|
|
||||||
88
docs/curl_mprintf.3
Normal file
88
docs/curl_mprintf.3
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_printf 3 "20 April 2001" "libcurl 7.7.2" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_maprintf, curl_mfprintf, curl_mprintf, curl_msnprintf, curl_msprintf
|
||||||
|
curl_mvaprintf, curl_mvfprintf, curl_mvprintf, curl_mvsnprintf,
|
||||||
|
curl_mvsprintf - formatted output conversion
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/mprintf.h>
|
||||||
|
.sp
|
||||||
|
.BI "int curl_mprintf(const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mfprintf(FILE *" fd ", const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_msprintf(char *" buffer ", const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_msnprintf(char *" buffer ", size_t " maxlength ", const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvprintf(const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvfprintf(FILE *" fd ", const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvsprintf(char *" buffer ", const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvsnprintf(char *" buffer ", size_t " maxlength ", const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "char *curl_maprintf(const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "char *curl_mvaprintf(const char *" format ", va_list " args ");"
|
||||||
|
.SH DESCRIPTION
|
||||||
|
These are all functions that produces output according to a format string and
|
||||||
|
given arguments. These are mostly clones of the well-known C-style functions
|
||||||
|
and there will be no detailed explanation of all available formatting rules
|
||||||
|
and usage here.
|
||||||
|
|
||||||
|
See this table for notable exceptions.
|
||||||
|
.RS
|
||||||
|
.TP
|
||||||
|
.B curl_mprintf()
|
||||||
|
Normal printf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mfprintf()
|
||||||
|
Normal fprinf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_msprintf()
|
||||||
|
Normal sprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_msnprintf()
|
||||||
|
snprintf() clone. Many systems don't have this. It is just like \fBsprintf\fP
|
||||||
|
but with an extra argument after the buffer that specifies the length of the
|
||||||
|
target buffer.
|
||||||
|
.TP
|
||||||
|
.B curl_mvprintf()
|
||||||
|
Normal vprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mvfprintf()
|
||||||
|
Normal vfprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mvsprintf()
|
||||||
|
Normal vsprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mvsnprintf()
|
||||||
|
vsnprintf() clone. Many systems don't have this. It is just like
|
||||||
|
\fBvsprintf\fP but with an extra argument after the buffer that specifies the
|
||||||
|
length of the target buffer.
|
||||||
|
.TP
|
||||||
|
.B curl_maprintf()
|
||||||
|
Like printf() but returns the output string as a malloc()ed string. The
|
||||||
|
returned string must be free()ed by the receiver.
|
||||||
|
.TP
|
||||||
|
.B curl_mvaprintf()
|
||||||
|
Like curl_maprintf() but takes a va_list pointer argument instead of a
|
||||||
|
variable amount of arguments.
|
||||||
|
.RE
|
||||||
|
|
||||||
|
To easily use all these cloned functions instead of the normal ones, #define
|
||||||
|
_MPRINTF_REPLACE before you include the <curl/mprintf.h> file. Then all the
|
||||||
|
normal names like printf, fprintf, sprintf etc will use the curl-functions
|
||||||
|
instead.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
The \fBcurl_maprintf\fP and \fBcurl_mvaprintf\fP functions return a pointer to
|
||||||
|
a newly allocated string, or NULL it it failed.
|
||||||
|
|
||||||
|
All other functions return the number of character they actually outputed.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR printf "(3), " sprintf "(3), " fprintf "(3), " vprintf "(3) "
|
||||||
@@ -1,15 +1,15 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_slist_append 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_slist_append 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_slist_append - add a string to an slist
|
curl_slist_append - add a string to an slist
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "struct curl_slist *curl_slist_append(struct curl_slit *" list,
|
.BI "struct curl_slist *curl_slist_append(struct curl_slist *" list,
|
||||||
.BI "char * "string ");"
|
.BI "const char * "string ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_slist_append() appends a specified string to a linked list of
|
curl_slist_append() appends a specified string to a linked list of
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_slist_free_all 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_slist_free_all 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_slist_free_all - free an entire curl_slist list
|
curl_slist_free_all - free an entire curl_slist list
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "void curl_slist_free_all(struct curl_slit *" list);
|
.BI "void curl_slist_free_all(struct curl_slist *" list);
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_slist_free_all() removes all traces of a previously built curl_slist
|
curl_slist_free_all() removes all traces of a previously built curl_slist
|
||||||
|
|||||||
30
docs/curl_strequal.3
Normal file
30
docs/curl_strequal.3
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_strequal 3 "20 April 2001" "libcurl 7.7.2" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_strequal, curl_strnequal - case insensitive string comparisons
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "int curl_strequal(char *" str1 ", char *" str2 ");"
|
||||||
|
.sp
|
||||||
|
.BI "int curl_strenqual(char *" str1 ", char *" str2 ", size_t " len ");"
|
||||||
|
.SH DESCRIPTION
|
||||||
|
The
|
||||||
|
.B curl_strequal()
|
||||||
|
function compares the two strings \fIstr1\fP and \fIstr2\fP, ignoring the case
|
||||||
|
of the characters. It returns a non-zero (TRUE) integer if the strings are
|
||||||
|
identical.
|
||||||
|
.sp
|
||||||
|
The \fBcurl_strnequal()\fP function is similar, except it only compares the
|
||||||
|
first \fIlen\fP characters of \fIstr1\fP.
|
||||||
|
.sp
|
||||||
|
These functions are provided by libcurl to enable applications to compare
|
||||||
|
strings in a truly portable manner. There are no standard portable case
|
||||||
|
insensitive string comparison functions. These two works on all platforms.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
Non-zero if the strings are identical. Zero if they're not.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR strcmp "(3), " strcasecmp "(3)"
|
||||||
1
docs/curl_strnequal.3
Normal file
1
docs/curl_strnequal.3
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so curl_strequal.3
|
||||||
27
docs/curl_unescape.3
Normal file
27
docs/curl_unescape.3
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_unescape - URL decodes the given string
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "char *curl_unescape( char *" url ", int "length " );"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function will convert the given URL encoded input string to a "plain
|
||||||
|
string" and return that as a new allocated string. All input characters that
|
||||||
|
are URL encoded (%XX where XX is a two-digit hexadecimal number, or +) will be
|
||||||
|
converted to their plain text versions (up to a ? letter, no letters to the
|
||||||
|
right of a ? letter will be converted).
|
||||||
|
|
||||||
|
If the 'length' argument is set to 0, curl_unescape() will use strlen() on the
|
||||||
|
input 'url' string to find out the size.
|
||||||
|
|
||||||
|
You must free() the returned string when you're done with it.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
A pointer to a zero terminated string or NULL if it failed.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.I curl_escape(), RFC 2396
|
||||||
@@ -1,12 +1,12 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_version 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_version 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_version - returns the libcurl version string
|
curl_version - returns the libcurl version string
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "char *curl_version( );"
|
.BI "char *curl_version( );"
|
||||||
.ad
|
.ad
|
||||||
@@ -14,9 +14,9 @@ curl_version - returns the libcurl version string
|
|||||||
Returns a human readable string with the version number of libcurl and some of
|
Returns a human readable string with the version number of libcurl and some of
|
||||||
its important components (like OpenSSL version).
|
its important components (like OpenSSL version).
|
||||||
|
|
||||||
Do note that this returns the actual running lib's version, you might have
|
Note: this returns the actual running lib's version, you might have installed
|
||||||
installed a newer lib's include files in your system which may turn your
|
a newer lib's include files in your system which may turn your LIBCURL_VERSION
|
||||||
LIBCURL_VERSION #define value to differ from this result.
|
#define value to differ from this result.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
A pointer to a zero terminated string.
|
A pointer to a zero terminated string.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
|||||||
13
docs/examples/Makefile.am
Normal file
13
docs/examples/Makefile.am
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
|
||||||
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
|
EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit.c postit2.c \
|
||||||
|
win32sockets.c persistant.c ftpget.c Makefile.example \
|
||||||
|
multithread.c getinmemory.c ftpupload.c httpput.c \
|
||||||
|
simplessl.c ftpgetresp.c http-post.c
|
||||||
|
|
||||||
|
all:
|
||||||
|
@echo "done"
|
||||||
42
docs/examples/Makefile.example
Normal file
42
docs/examples/Makefile.example
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
#############################################################################
|
||||||
|
# _ _ ____ _
|
||||||
|
# Project ___| | | | _ \| |
|
||||||
|
# / __| | | | |_) | |
|
||||||
|
# | (__| |_| | _ <| |___
|
||||||
|
# \___|\___/|_| \_\_____|
|
||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
|
||||||
|
# What to call the final executable
|
||||||
|
TARGET = example
|
||||||
|
|
||||||
|
# Which object files that the executable consists of
|
||||||
|
OBJS= ftpget.o
|
||||||
|
|
||||||
|
# What compiler to use
|
||||||
|
CC = gcc
|
||||||
|
|
||||||
|
# Compiler flags, -g for debug, -c to make an object file
|
||||||
|
CFLAGS = -c -g
|
||||||
|
|
||||||
|
# This should point to a directory that holds libcurl, if it isn't
|
||||||
|
# in the system's standard lib dir
|
||||||
|
# We also set a -L to include the directory where we have the openssl
|
||||||
|
# libraries
|
||||||
|
LDFLAGS = -L/home/dast/lib -L/usr/local/ssl/lib
|
||||||
|
|
||||||
|
# We need -lcurl for the curl stuff
|
||||||
|
# We need -lsocket and -lnsl when on Solaris
|
||||||
|
# We need -lssl and -lcrypto when using libcurl with SSL support
|
||||||
|
# We need -ldl for dlopen() if that is in libdl
|
||||||
|
# We need -lpthread for the pthread example
|
||||||
|
LIBS = -lcurl -lsocket -lnsl -lssl -lcrypto -dl
|
||||||
|
|
||||||
|
# Link the target with all objects and libraries
|
||||||
|
$(TARGET) : $(OBJS)
|
||||||
|
$(CC) $(LDFLAGS) $(LIBS) -o $(TARGET) $(OBJS)
|
||||||
|
|
||||||
|
# Compile the source files into object files
|
||||||
|
ftpget.o : ftpget.c
|
||||||
|
$(CC) $(CFLAGS) $<
|
||||||
@@ -6,3 +6,17 @@ 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
|
||||||
them for submission in future packages and on the web site.
|
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
|
||||||
|
examples. Just edit the file according to your system and requirements first.
|
||||||
|
|
||||||
|
Most examples should build fine using a command line like this:
|
||||||
|
|
||||||
|
$ gcc `curl-config --cflags` `curl-config --libs` -o example example.c
|
||||||
|
|
||||||
|
Try the php/examples/ directory for PHP programming snippets!
|
||||||
|
|
||||||
|
*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.
|
||||||
|
|||||||
@@ -1,4 +1,12 @@
|
|||||||
/* curlgtk.c */
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
/* Copyright (c) 2000 David Odin (aka DindinX) for MandrakeSoft */
|
/* Copyright (c) 2000 David Odin (aka DindinX) for MandrakeSoft */
|
||||||
/* an attempt to use the curl library in concert with a gtk-threaded application */
|
/* an attempt to use the curl library in concert with a gtk-threaded application */
|
||||||
|
|
||||||
|
|||||||
83
docs/examples/ftpget.c
Normal file
83
docs/examples/ftpget.c
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is an example showing how to get a single file from an FTP server.
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
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;
|
||||||
|
CURLcode res;
|
||||||
|
struct FtpFile ftpfile={
|
||||||
|
"curl.tar.gz", /* name to store the file as if succesful */
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|
||||||
|
curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* Get curl 7.9.2 from sunet.se's FTP site: */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL,
|
||||||
|
"ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz");
|
||||||
|
/* 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);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
if(CURLE_OK != res) {
|
||||||
|
/* we failed */
|
||||||
|
fprintf(stderr, "curl told us %d\n", res);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(ftpfile.stream)
|
||||||
|
fclose(ftpfile.stream); /* close the local file */
|
||||||
|
|
||||||
|
curl_global_cleanup();
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
88
docs/examples/ftpupload.c
Normal file
88
docs/examples/ftpupload.c
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This example shows an FTP upload, with a rename of the file just after
|
||||||
|
* a successful upload.
|
||||||
|
*
|
||||||
|
* Example based on source code provided by Erick Nuwendam. Thanks!
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define LOCAL_FILE "/tmp/uploadthis.txt"
|
||||||
|
#define UPLOAD_FILE_AS "while-uploading.txt"
|
||||||
|
#define REMOTE_URL "ftp://localhost/" UPLOAD_FILE_AS
|
||||||
|
#define RENAME_FILE_TO "renamed-and-fine.txt"
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
FILE *ftpfile;
|
||||||
|
FILE * hd_src ;
|
||||||
|
int hd ;
|
||||||
|
struct stat file_info;
|
||||||
|
|
||||||
|
struct curl_slist *headerlist=NULL;
|
||||||
|
char buf_1 [] = "RNFR " UPLOAD_FILE_AS;
|
||||||
|
char buf_2 [] = "RNTO " RENAME_FILE_TO;
|
||||||
|
|
||||||
|
/* get the file size of the local file */
|
||||||
|
hd = open(LOCAL_FILE, O_RDONLY) ;
|
||||||
|
fstat(hd, &file_info);
|
||||||
|
close(hd) ;
|
||||||
|
|
||||||
|
/* get a FILE * of the same file, could also be made with
|
||||||
|
fdopen() from the previous descriptor, but hey this is just
|
||||||
|
an example! */
|
||||||
|
hd_src = fopen(LOCAL_FILE, "rb");
|
||||||
|
|
||||||
|
/* In windows, this will init the winsock stuff */
|
||||||
|
curl_global_init(CURL_GLOBAL_ALL);
|
||||||
|
|
||||||
|
/* get a curl handle */
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* build a list of commands to pass to libcurl */
|
||||||
|
headerlist = curl_slist_append(headerlist, buf_1);
|
||||||
|
headerlist = curl_slist_append(headerlist, buf_2);
|
||||||
|
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UPLOAD, TRUE) ;
|
||||||
|
|
||||||
|
/* specify target */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_URL, REMOTE_URL);
|
||||||
|
|
||||||
|
/* pass in that last of FTP commands to run after the transfer */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTQUOTE, headerlist);
|
||||||
|
|
||||||
|
/* now specify which file to upload */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_INFILE, hd_src);
|
||||||
|
|
||||||
|
/* and give the size of the upload (optional) */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_INFILESIZE, file_info.st_size);
|
||||||
|
|
||||||
|
/* Now run off and do what you've been told! */
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* clean up the FTP commands list */
|
||||||
|
curl_slist_free_all (headerlist);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
fclose(hd_src); /* close the local file */
|
||||||
|
|
||||||
|
curl_global_cleanup();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
80
docs/examples/getinmemory.c
Normal file
80
docs/examples/getinmemory.c
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* Example source code to show how the callback function can be used to
|
||||||
|
* download data into a chunk of memory instead of storing it in a file.
|
||||||
|
*
|
||||||
|
* 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>
|
||||||
|
|
||||||
|
struct MemoryStruct {
|
||||||
|
char *memory;
|
||||||
|
size_t size;
|
||||||
|
};
|
||||||
|
|
||||||
|
size_t
|
||||||
|
WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
|
{
|
||||||
|
register int realsize = size * nmemb;
|
||||||
|
struct MemoryStruct *mem = (struct MemoryStruct *)data;
|
||||||
|
|
||||||
|
mem->memory = (char *)realloc(mem->memory, mem->size + realsize + 1);
|
||||||
|
if (mem->memory) {
|
||||||
|
memcpy(&(mem->memory[mem->size]), ptr, realsize);
|
||||||
|
mem->size += realsize;
|
||||||
|
mem->memory[mem->size] = 0;
|
||||||
|
}
|
||||||
|
return realsize;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl_handle;
|
||||||
|
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
|
||||||
|
chunk.memory=NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
|
||||||
|
/* init the curl session */
|
||||||
|
curl_handle = curl_easy_init();
|
||||||
|
|
||||||
|
/* specify URL to get */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_URL, "http://cool.haxx.se/");
|
||||||
|
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_FILE, (void *)&chunk);
|
||||||
|
|
||||||
|
/* get it! */
|
||||||
|
curl_easy_perform(curl_handle);
|
||||||
|
|
||||||
|
/* cleanup curl stuff */
|
||||||
|
curl_easy_cleanup(curl_handle);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Now, our chunk.memory points to a memory block that is chunk.size
|
||||||
|
* bytes big and contains the remote file.
|
||||||
|
*
|
||||||
|
* Do something nice with it!
|
||||||
|
*/
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
100
docs/examples/httpput.c
Normal file
100
docs/examples/httpput.c
Normal file
@@ -0,0 +1,100 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This example shows a HTTP PUT operation. PUTs a file given as a command
|
||||||
|
* line argument to the URL also given on the command line.
|
||||||
|
*
|
||||||
|
* This example also uses its own read callback.
|
||||||
|
*/
|
||||||
|
|
||||||
|
size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
|
{
|
||||||
|
size_t retcode;
|
||||||
|
|
||||||
|
/* in real-world cases, this would probably get this data differently
|
||||||
|
as this fread() stuff is exactly what the library already would do
|
||||||
|
by default internally */
|
||||||
|
retcode = fread(ptr, size, nmemb, stream);
|
||||||
|
|
||||||
|
fprintf(stderr, "*** We read %d bytes from file\n", retcode);
|
||||||
|
|
||||||
|
return retcode;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
FILE *ftpfile;
|
||||||
|
FILE * hd_src ;
|
||||||
|
int hd ;
|
||||||
|
struct stat file_info;
|
||||||
|
|
||||||
|
char *file;
|
||||||
|
char *url;
|
||||||
|
|
||||||
|
if(argc < 3)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
file= argv[1];
|
||||||
|
url = argv[2];
|
||||||
|
|
||||||
|
/* get the file size of the local file */
|
||||||
|
hd = open(file, O_RDONLY) ;
|
||||||
|
fstat(hd, &file_info);
|
||||||
|
close(hd) ;
|
||||||
|
|
||||||
|
/* get a FILE * of the same file, could also be made with
|
||||||
|
fdopen() from the previous descriptor, but hey this is just
|
||||||
|
an example! */
|
||||||
|
hd_src = fopen(file, "rb");
|
||||||
|
|
||||||
|
/* In windows, this will init the winsock stuff */
|
||||||
|
curl_global_init(CURL_GLOBAL_ALL);
|
||||||
|
|
||||||
|
/* get a curl handle */
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* we want to use our own read function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback);
|
||||||
|
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UPLOAD, TRUE) ;
|
||||||
|
|
||||||
|
/* HTTP PUT please */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_PUT, TRUE);
|
||||||
|
|
||||||
|
/* specify target */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_URL, url);
|
||||||
|
|
||||||
|
/* now specify which file to upload */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_INFILE, hd_src);
|
||||||
|
|
||||||
|
/* and give the size of the upload (optional) */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_INFILESIZE, file_info.st_size);
|
||||||
|
|
||||||
|
/* Now run off and do what you've been told! */
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
fclose(hd_src); /* close the local file */
|
||||||
|
|
||||||
|
curl_global_cleanup();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
70
docs/examples/multithread.c
Normal file
70
docs/examples/multithread.c
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* A multi-threaded example that uses pthreads extensively to fetch
|
||||||
|
* X remote files at once */
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/* silly list of test-URLs */
|
||||||
|
char *urls[]= {
|
||||||
|
"http://curl.haxx.se/",
|
||||||
|
"ftp://cool.haxx.se/",
|
||||||
|
"http://www.contactor.se/",
|
||||||
|
"www.haxx.se"
|
||||||
|
};
|
||||||
|
|
||||||
|
void *pull_one_url(void *url)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
|
curl_easy_perform(curl);
|
||||||
|
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
int pthread_create(pthread_t *new_thread_ID,
|
||||||
|
const pthread_attr_t *attr,
|
||||||
|
void * (*start_func)(void *), void *arg);
|
||||||
|
*/
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
pthread_t tid[4];
|
||||||
|
int i;
|
||||||
|
int error;
|
||||||
|
for(i=0; i< 4; i++) {
|
||||||
|
error = pthread_create(&tid[i],
|
||||||
|
NULL, /* default attributes please */
|
||||||
|
pull_one_url,
|
||||||
|
urls[i]);
|
||||||
|
if(0 != error)
|
||||||
|
fprintf(stderr, "Couldn't run thread number %d, errno %d\n", i, error);
|
||||||
|
else
|
||||||
|
fprintf(stderr, "Thread %d, gets %s\n", i, urls[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* now wait for all threads to terminate */
|
||||||
|
for(i=0; i< 4; i++) {
|
||||||
|
error = pthread_join(tid[i], NULL);
|
||||||
|
fprintf(stderr, "Thread %d terminated\n", i);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
53
docs/examples/persistant.c
Normal file
53
docs/examples/persistant.c
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
docs/examples/win32socket.c file as well */
|
||||||
|
|
||||||
|
/* This example REQUIRES libcurl 7.7 or later */
|
||||||
|
#if (LIBCURL_VERSION_NUM < 0x070700)
|
||||||
|
#error Too old libcurl version, upgrade or stay away.
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
/* this sends all memory debug messages to a specified logfile */
|
||||||
|
curl_memdebug("memdump");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADER, 1);
|
||||||
|
|
||||||
|
/* get the first document */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/");
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* get another document from the same server using the same
|
||||||
|
connection */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/docs/");
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
71
docs/examples/postit.c
Normal file
71
docs/examples/postit.c
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* 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;
|
||||||
|
}
|
||||||
92
docs/examples/postit2.c
Normal file
92
docs/examples/postit2.c
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* 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 <string.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
#if LIBCURL_VERSION_NUM < 0x070900
|
||||||
|
#error "curl_formadd() is not introduced until libcurl 7.9 and later"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
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();
|
||||||
|
/* initalize custom header list (stating that Expect: 100-continue is not
|
||||||
|
wanted */
|
||||||
|
headerlist = curl_slist_append(headerlist, buf);
|
||||||
|
if(curl) {
|
||||||
|
/* what URL that receives this POST */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/examplepost.cgi");
|
||||||
|
if ( (argc == 2) && (!strcmp(argv[1], "noexpectheader")) )
|
||||||
|
/* only disable 100-continue header if explicitly requested */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
|
||||||
|
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);
|
||||||
|
/* free slist */
|
||||||
|
curl_slist_free_all (headerlist);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -1,3 +1,16 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
win32socket.c file as well */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@@ -6,9 +19,9 @@
|
|||||||
#include <curl/types.h>
|
#include <curl/types.h>
|
||||||
#include <curl/easy.h>
|
#include <curl/easy.h>
|
||||||
|
|
||||||
size_t write_data(void *ptr, size_t size, size_t nmemb, FILE *stream)
|
size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
written = fwrite(ptr,size,nmemb,outfile);
|
written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
||||||
return written;
|
return written;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,22 +1,24 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <curl/types.h>
|
|
||||||
#include <curl/easy.h>
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(void)
|
||||||
{
|
{
|
||||||
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 */
|
||||||
|
|||||||
118
docs/examples/simplessl.c
Normal file
118
docs/examples/simplessl.c
Normal file
@@ -0,0 +1,118 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* some requirements for this to work:
|
||||||
|
1. set pCertFile to the file with the client certificate
|
||||||
|
2. if the key is passphrase protected, set pPassphrase to the
|
||||||
|
passphrase you use
|
||||||
|
3. if you are using a crypto engine:
|
||||||
|
3.1. set a #define USE_ENGINE
|
||||||
|
3.2. set pEngine to the name of the crypto engine you use
|
||||||
|
3.3. set pKeyName to the key identifier you want to use
|
||||||
|
4. if you don't use a crypto engine:
|
||||||
|
4.1. set pKeyName to the file name of your client key
|
||||||
|
4.2. if the format of the key file is DER, set pKeyType to "DER"
|
||||||
|
|
||||||
|
!! 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)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
FILE *headerfile;
|
||||||
|
|
||||||
|
const char *pCertFile = "testcert.pem";
|
||||||
|
const char *pCACertFile="cacert.pem"
|
||||||
|
|
||||||
|
const char *pKeyName;
|
||||||
|
const char *pKeyType;
|
||||||
|
|
||||||
|
const char *pEngine;
|
||||||
|
|
||||||
|
#if USE_ENGINE
|
||||||
|
pKeyName = "rsa_test";
|
||||||
|
pKeyType = "ENG";
|
||||||
|
pEngine = "chil"; /* for nChiper HSM... */
|
||||||
|
#else
|
||||||
|
pKeyName = "testkey.pem";
|
||||||
|
pKeyType = "PEM";
|
||||||
|
pEngine = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char *pPassphrase = NULL;
|
||||||
|
|
||||||
|
headerfile = fopen("dumpit", "w");
|
||||||
|
|
||||||
|
curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* what call to write: */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://curl.haxx.se");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
|
||||||
|
|
||||||
|
while(1) /* do some ugly short cut... */
|
||||||
|
{
|
||||||
|
if (pEngine) /* use crypto engine */
|
||||||
|
{
|
||||||
|
if (curl_easy_setopt(curl, CURLOPT_SSLENGINE,pEngine) != CURLE_OK)
|
||||||
|
{ /* load the crypto engine */
|
||||||
|
fprintf(stderr,"can't set crypto engine\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (curl_easy_setopt(curl, CURLOPT_SSLENGINE_DEFAULT,1) != CURLE_OK)
|
||||||
|
{ /* set the crypto engine as default */
|
||||||
|
/* only needed for the first time you load
|
||||||
|
a engine in a curl object... */
|
||||||
|
fprintf(stderr,"can't set crypto engine as default\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* cert is stored PEM coded in file... */
|
||||||
|
/* since PEM is default, we needn't set it for PEM */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM");
|
||||||
|
/* set the cert for client authentication */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_SSLCERT,pCertFile);
|
||||||
|
/* sorry, for engine we must set the passphrase
|
||||||
|
(if the key has one...) */
|
||||||
|
if (pPassphrase)
|
||||||
|
curl_easy_setopt(curl,CURLOPT_SSLKEYPASSWD,pPassphrase);
|
||||||
|
/* if we use a key stored in a crypto engine,
|
||||||
|
we must set the key type to "ENG" */
|
||||||
|
curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType);
|
||||||
|
/* set the private key (file or ID in engine) */
|
||||||
|
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);
|
||||||
|
break; /* we are done... */
|
||||||
|
}
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_global_cleanup();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
49
docs/examples/win32sockets.c
Normal file
49
docs/examples/win32sockets.c
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
|
||||||
|
/*
|
||||||
|
* 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 */
|
||||||
|
}
|
||||||
38
docs/index.html
Normal file
38
docs/index.html
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
HTML>
|
||||||
|
<HEAD>
|
||||||
|
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
|
||||||
|
<TITLE>Index to Curl documentation</TITLE>
|
||||||
|
</HEAD>
|
||||||
|
|
||||||
|
<BODY>
|
||||||
|
<H1 ALIGN="CENTER">Index to Curl documentation</H1>
|
||||||
|
|
||||||
|
<H2>Programs</H2>
|
||||||
|
<P><A HREF="curl-config.html">curl-config.html</A>
|
||||||
|
<P><A HREF="curl.html">curl.html</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>
|
||||||
|
</HTML>
|
||||||
328
docs/libcurl-the-guide
Normal file
328
docs/libcurl-the-guide
Normal file
@@ -0,0 +1,328 @@
|
|||||||
|
$Id$
|
||||||
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
PROGRAMMING WITH LIBCURL
|
||||||
|
|
||||||
|
About this Document
|
||||||
|
|
||||||
|
This document will attempt to describe the general principle and some basic
|
||||||
|
approaches to consider when programming with libcurl. The text will focus
|
||||||
|
mainly on the C/C++ interface but might apply fairly well on other interfaces
|
||||||
|
as well as they usually follow the C one pretty closely.
|
||||||
|
|
||||||
|
This document will refer to 'the user' as the person writing the source code
|
||||||
|
that uses libcurl. That would probably be you or someone in your position.
|
||||||
|
What will be generally refered to as 'the program' will be the collected
|
||||||
|
source code that you write that is using libcurl for transfers. The program
|
||||||
|
is outside libcurl and libcurl is outside of the program.
|
||||||
|
|
||||||
|
|
||||||
|
Building
|
||||||
|
|
||||||
|
There are many different ways to build C programs. This chapter will assume
|
||||||
|
a unix-style build process. If you use a different build system, you can
|
||||||
|
still read this to get general information that may apply to your
|
||||||
|
environment as well.
|
||||||
|
|
||||||
|
Compiling the Program
|
||||||
|
|
||||||
|
Your compiler needs to know where the libcurl headers are
|
||||||
|
located. Therefore you must set your compiler's include path to point to
|
||||||
|
the directory where you installed them. The 'curl-config'[3] tool can be
|
||||||
|
used to get this information:
|
||||||
|
|
||||||
|
$ curl-config --cflags
|
||||||
|
|
||||||
|
Linking the Program with libcurl
|
||||||
|
|
||||||
|
When having compiled the program, you need to link your object files to
|
||||||
|
create a single executable. For that to succeed, you need to link with
|
||||||
|
libcurl and possibly also with other libraries that libcurl itself depends
|
||||||
|
on. Like OpenSSL librararies, but even some standard OS libraries may be
|
||||||
|
needed on the command line. To figure out which flags to use, once again
|
||||||
|
the 'curl-config' tool comes to the rescue:
|
||||||
|
|
||||||
|
$ curl-config --libs
|
||||||
|
|
||||||
|
SSL or Not
|
||||||
|
|
||||||
|
libcurl can be built and customized in many ways. One of the things that
|
||||||
|
varies from different libraries and builds is the support for SSL-based
|
||||||
|
transfers, like HTTPS and FTPS. If OpenSSL was detected properly at
|
||||||
|
build-time, libcurl will be built with SSL support. To figure out if an
|
||||||
|
installed libcurl has been built with SSL support enabled, use
|
||||||
|
'curl-config' like this:
|
||||||
|
|
||||||
|
$ curl-config --feature
|
||||||
|
|
||||||
|
And if SSL is supported, the keyword 'SSL' will be written to stdout,
|
||||||
|
possibly together with a few other features that can be on and off on
|
||||||
|
different libcurls.
|
||||||
|
|
||||||
|
|
||||||
|
Portable Code in a Portable World
|
||||||
|
|
||||||
|
The people behind libcurl have put a considerable effort to make libcurl work
|
||||||
|
on a large amount of different operating systems and environments.
|
||||||
|
|
||||||
|
You program libcurl the same way on all platforms that libcurl runs on. There
|
||||||
|
are only very few minor considerations that differs. If you just make sure to
|
||||||
|
write your code portable enough, you may very well create yourself a very
|
||||||
|
portable program. libcurl shouldn't stop you from that.
|
||||||
|
|
||||||
|
|
||||||
|
Global Preparation
|
||||||
|
|
||||||
|
The program must initialize some of the libcurl functionality globally. That
|
||||||
|
means it should be done exactly once, no matter how many times you intend to
|
||||||
|
use the library. Once for your program's entire life time. This is done using
|
||||||
|
|
||||||
|
curl_global_init()
|
||||||
|
|
||||||
|
and it takes one parameter which is a bit pattern that tells libcurl what to
|
||||||
|
intialize. Using CURL_GLOBAL_ALL will make it initialize all known internal
|
||||||
|
sub modules, and might be a good default option. The current two bits that
|
||||||
|
are specified are:
|
||||||
|
|
||||||
|
CURL_GLOBAL_WIN32 which only does anything on Windows machines. When used on
|
||||||
|
a Windows machine, it'll make libcurl intialize the win32 socket
|
||||||
|
stuff. Without having that initialized properly, your program cannot use
|
||||||
|
sockets properly. You should only do this once for each application, so if
|
||||||
|
your program already does this or of another library in use does it, you
|
||||||
|
should not tell libcurl to do this as well.
|
||||||
|
|
||||||
|
CURL_GLOBAL_SSL which only does anything on libcurls compiled and built
|
||||||
|
SSL-enabled. On these systems, this will make libcurl init OpenSSL properly
|
||||||
|
for this application. This is only needed to do once for each application so
|
||||||
|
if your program or another library already does this, this bit should not be
|
||||||
|
needed.
|
||||||
|
|
||||||
|
libcurl has a default protection mechanism that detects if curl_global_init()
|
||||||
|
hasn't been called by the time curl_easy_perform() is called and if that is
|
||||||
|
the case, libcurl runs the function itself with a guessed bit pattern. Please
|
||||||
|
note that depending solely on this is not considered nice nor very good.
|
||||||
|
|
||||||
|
When the program no longer uses libcurl, it should call
|
||||||
|
curl_global_cleanup(), which is the opposite of the init call. It will then
|
||||||
|
do the reversed operations to cleanup the resources the curl_global_init()
|
||||||
|
call initialized.
|
||||||
|
|
||||||
|
Repeated calls to curl_global_init() and curl_global_cleanup() should be
|
||||||
|
avoided. They should be called once each.
|
||||||
|
|
||||||
|
Handle the easy libcurl
|
||||||
|
|
||||||
|
libcurl version 7 is oriented around the so called easy interface. All
|
||||||
|
operations in the easy interface are prefixed with 'curl_easy'.
|
||||||
|
|
||||||
|
Future libcurls will also offer the multi interface. More about that
|
||||||
|
interface, what it is targeted for and how to use it is still only debated on
|
||||||
|
the libcurl mailing list and developer web pages. Join up to discuss and
|
||||||
|
figure out!
|
||||||
|
|
||||||
|
To use the easy interface, you must first create yourself an easy handle. You
|
||||||
|
need one handle for each easy session you want to perform. Basicly, you
|
||||||
|
should use one handle for every thread you plan to use for transferring. You
|
||||||
|
must never share the same handle in multiple threads.
|
||||||
|
|
||||||
|
Get an easy handle with
|
||||||
|
|
||||||
|
easyhandle = curl_easy_init();
|
||||||
|
|
||||||
|
It returns an easy handle. Using that you proceed to the next step: setting
|
||||||
|
up your preferred actions. A handle is just a logic entity for the upcoming
|
||||||
|
transfer or series of transfers. One of the most basic properties to set in
|
||||||
|
the handle is the URL. You set your preferred URL to transfer with
|
||||||
|
CURLOPT_URL in a manner similar to:
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_URL, "http://curl.haxx.se/");
|
||||||
|
|
||||||
|
Let's assume for a while that you want to receive data as the URL indentifies
|
||||||
|
a remote resource you want to get here. Since you write a sort of application
|
||||||
|
that needs this transfer, I assume that you would like to get the data passed
|
||||||
|
to you directly instead of simply getting it passed to stdout. So, you write
|
||||||
|
your own function that matches this prototype:
|
||||||
|
|
||||||
|
size_t write_data(void *buffer, size_t size, size_t nmemb, void *userp);
|
||||||
|
|
||||||
|
You tell libcurl to pass all data to this function by issuing a function
|
||||||
|
similar to this:
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_WRITEFUNCTION, write_data);
|
||||||
|
|
||||||
|
You can control what data your function get in the forth argument by setting
|
||||||
|
another property:
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_FILE, &internal_struct);
|
||||||
|
|
||||||
|
Using that property, you can easily pass local data between your application
|
||||||
|
and the function that gets invoked by libcurl. libcurl itself won't touch the
|
||||||
|
data you pass with CURLOPT_FILE.
|
||||||
|
|
||||||
|
libcurl offers its own default internal callback that'll take care of the
|
||||||
|
data if you don't set the callback with CURLOPT_WRITEFUNCTION. It will then
|
||||||
|
simply output the received data to stdout. You can have the default callback
|
||||||
|
write the data to a different file handle by passing a 'FILE *' to a file
|
||||||
|
opened for writing with the CURLOPT_FILE option.
|
||||||
|
|
||||||
|
Now, we need to take a step back and have a deep breath. Here's one of those
|
||||||
|
rare platform-dependent nitpicks. Did you spot it? On some platforms[2],
|
||||||
|
libcurl won't be able to operate on files opened by the program. Thus, if you
|
||||||
|
use the default callback and pass in a an open file with CURLOPT_FILE, it
|
||||||
|
will crash. You should therefore avoid this to make your program run fine
|
||||||
|
virtually everywhere.
|
||||||
|
|
||||||
|
There are of course many more options you can set, and we'll get back to a
|
||||||
|
few of them later. Let's instead continue to the actual transfer:
|
||||||
|
|
||||||
|
success = curl_easy_perform(easyhandle);
|
||||||
|
|
||||||
|
The curl_easy_perform() will connect to the remote site, do the necessary
|
||||||
|
commands and receive the transfer. Whenever it receives data, it calls the
|
||||||
|
callback function we previously set. The function may get one byte at a time,
|
||||||
|
or it may get many kilobytes at once. libcurl delivers as much as possible as
|
||||||
|
often as possible. Your callback function should return the number of bytes
|
||||||
|
it "took care of". If that is not the exact same amount of bytes that was
|
||||||
|
passed to it, libcurl will abort the operation and return with an error code.
|
||||||
|
|
||||||
|
When the transfer is complete, the function returns a return code that
|
||||||
|
informs you if it succeeded in its mission or not. If a return code isn't
|
||||||
|
enough for you, you can use the CURLOPT_ERRORBUFFER to point libcurl to a
|
||||||
|
buffer of yours where it'll store a human readable error message as well.
|
||||||
|
|
||||||
|
If you then want to transfer another file, the handle is ready to be used
|
||||||
|
again. Mind you, it is even preferred that you re-use an existing handle if
|
||||||
|
you intend to make another transfer. libcurl will then attempt to re-use the
|
||||||
|
previous
|
||||||
|
|
||||||
|
|
||||||
|
When It Doesn't Work
|
||||||
|
|
||||||
|
There will always be times when the transfer fails for some reason. You might
|
||||||
|
have set the wrong libcurl option or misunderstood what the libcurl option
|
||||||
|
actually does, or the remote server might return non-standard replies that
|
||||||
|
confuse the library which then confuses your program.
|
||||||
|
|
||||||
|
There's one golden rule when these things occur: set the CURLOPT_VERBOSE
|
||||||
|
option to TRUE. It'll cause the library to spew out the entire protocol
|
||||||
|
details it sends, some internal info and some received protcol data as well
|
||||||
|
(especially when using FTP). If you're using HTTP, adding the headers in the
|
||||||
|
received output to study is also a clever way to get a better understanding
|
||||||
|
wht the server behaves the way it does. Include headers in the normal body
|
||||||
|
output with CURLOPT_HEADER set TRUE.
|
||||||
|
|
||||||
|
Of course there are bugs left. We need to get to know about them to be able
|
||||||
|
to fix them, so we're quite dependent on your bug reports! When you do report
|
||||||
|
suspected bugs in libcurl, please include as much details you possibly can: a
|
||||||
|
protocol dump that CURLOPT_VERBOSE produces, library version, as much as
|
||||||
|
possible of your code that uses libcurl, operating system name and version,
|
||||||
|
compiler name and version etc.
|
||||||
|
|
||||||
|
|
||||||
|
Upload Data to a Remote Site
|
||||||
|
|
||||||
|
libcurl tries to keep a protocol independent approach to most transfers, thus
|
||||||
|
uploading to a remote FTP site is very similar to uploading data to a HTTP
|
||||||
|
server with a PUT request.
|
||||||
|
|
||||||
|
Of course, first you either create an easy handle or you re-use one existing
|
||||||
|
one. Then you set the URL to operate on just like before. This is the remote
|
||||||
|
URL, that we now will upload.
|
||||||
|
|
||||||
|
Since we write an application, we most likely want libcurl to get the upload
|
||||||
|
data by asking us for it. To make it do that, we set the read callback and
|
||||||
|
the custom pointer libcurl will pass to our read callback. The read callback
|
||||||
|
should have a prototype similar to:
|
||||||
|
|
||||||
|
size_t function(char *buffer, size_t size, size_t nitems, void *userp);
|
||||||
|
|
||||||
|
Where buffer is the pointer to a buffer we fill in with data to upload and
|
||||||
|
size*nitems is the size of the buffer. The 'userp' pointer is the custom
|
||||||
|
pointer we set to point to a struct of ours to pass private data between the
|
||||||
|
application and the callback.
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_READFUNCTION, read_function);
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_INFILE, &filedata);
|
||||||
|
|
||||||
|
Tell libcurl that we want to upload:
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_UPLOAD, TRUE);
|
||||||
|
|
||||||
|
A few protocols won't behave properly when uploads are done without any prior
|
||||||
|
knowledge of the expected file size. HTTP PUT is one example [1]. So, set the
|
||||||
|
upload file size using the CURLOPT_INFILESIZE like this:
|
||||||
|
|
||||||
|
curl_easy_setopt(easyhandle, CURLOPT_INFILESIZE, file_size);
|
||||||
|
|
||||||
|
So, then you call curl_easy_perform() this time, it'll perform all necessary
|
||||||
|
operations and when it has invoked the upload it'll call your supplied
|
||||||
|
callback to get the data to upload. The program should return as much data as
|
||||||
|
possible in every invoke, as that is likely to make the upload perform as
|
||||||
|
fast as possible. The callback should return the number of bytes it wrote in
|
||||||
|
the buffer. Returning 0 will signal the end of the upload.
|
||||||
|
|
||||||
|
|
||||||
|
Passwords
|
||||||
|
|
||||||
|
Many protocols use or even require that user name and password are provided
|
||||||
|
to be able to download or upload the data of your choice. libcurl offers
|
||||||
|
several ways to specify them.
|
||||||
|
|
||||||
|
[ URL, options, callback ]
|
||||||
|
|
||||||
|
|
||||||
|
Showing Progress
|
||||||
|
|
||||||
|
|
||||||
|
libcurl with C++
|
||||||
|
|
||||||
|
There's basicly only one thing to keep in mind when using C++ instead of C
|
||||||
|
when interfacing libcurl:
|
||||||
|
|
||||||
|
"The Callbacks Must Be Plain C"
|
||||||
|
|
||||||
|
So if you want a write callback set in libcurl, you should put it within
|
||||||
|
'extern'. Similar to this:
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
size_t write_data(void *ptr, size_t size, size_t nmemb,
|
||||||
|
void *ourpointer)
|
||||||
|
{
|
||||||
|
/* do what you want with the data */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
This will of course effectively turn the callback code into C. There won't be
|
||||||
|
any "this" pointer available etc.
|
||||||
|
|
||||||
|
|
||||||
|
Security Considerations
|
||||||
|
|
||||||
|
|
||||||
|
Certificates and Other SSL Tricks
|
||||||
|
|
||||||
|
|
||||||
|
Future
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-----
|
||||||
|
Footnotes:
|
||||||
|
|
||||||
|
[1] = HTTP PUT without knowing the size prior to transfer is indeed possible,
|
||||||
|
but libcurl does not support the chunked transfers on uploading that is
|
||||||
|
necessary for this feature to work. We'd gratefully appreciate patches
|
||||||
|
that bring this functionality...
|
||||||
|
|
||||||
|
[2] = This happens on Windows machines when libcurl is built and used as a
|
||||||
|
DLL. However, you can still do this on Windows if you link with a static
|
||||||
|
library.
|
||||||
|
|
||||||
|
[3] = The curl-config tool is generated at build-time (on unix-like systems)
|
||||||
|
and should be installed with the 'make install' or similar instruction
|
||||||
|
that installs the library, header files, man pages etc.
|
||||||
133
docs/libcurl.3
Normal file
133
docs/libcurl.3
Normal file
@@ -0,0 +1,133 @@
|
|||||||
|
.\" 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.
|
||||||
|
|
||||||
@@ -7,38 +7,21 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* The contents of this file are subject to the Mozilla Public License
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
* Version 1.0 (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"
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
* License for the specific language governing rights and limitations
|
|
||||||
* under the License.
|
|
||||||
*
|
*
|
||||||
* The Original Code is Curl.
|
* 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 Initial Developer of the Original Code is Daniel Stenberg.
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
* Portions created by the Initial Developer are Copyright (C) 1998.
|
* $Id$
|
||||||
* All Rights Reserved.
|
*****************************************************************************/
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
* Main author:
|
|
||||||
* - Daniel Stenberg <daniel@haxx.se>
|
|
||||||
*
|
|
||||||
* http://curl.haxx.se
|
|
||||||
*
|
|
||||||
* $Source$
|
|
||||||
* $Revision$
|
|
||||||
* $Date$
|
|
||||||
* $Author$
|
|
||||||
* $State$
|
|
||||||
* $Locker$
|
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
/* The include stuff here is mainly for time_t! */
|
/* The include stuff here is mainly for time_t! */
|
||||||
@@ -75,13 +58,20 @@ extern "C" {
|
|||||||
struct HttpPost {
|
struct HttpPost {
|
||||||
struct HttpPost *next; /* next entry in the list */
|
struct HttpPost *next; /* next entry in the list */
|
||||||
char *name; /* pointer to allocated name */
|
char *name; /* pointer to allocated name */
|
||||||
|
long namelength; /* length of name length */
|
||||||
char *contents; /* pointer to allocated data contents */
|
char *contents; /* pointer to allocated data contents */
|
||||||
|
long contentslength; /* length of contents field */
|
||||||
char *contenttype; /* Content-Type */
|
char *contenttype; /* Content-Type */
|
||||||
|
struct curl_slist* contentheader; /* list of extra headers for this form */
|
||||||
struct HttpPost *more; /* if one field name has more than one file, this
|
struct HttpPost *more; /* if one field name has more than one file, this
|
||||||
link should link to following files */
|
link should link to following files */
|
||||||
long flags; /* as defined below */
|
long flags; /* as defined below */
|
||||||
#define HTTPPOST_FILENAME (1<<0) /* specified content is a file name */
|
#define HTTPPOST_FILENAME (1<<0) /* specified content is a file name */
|
||||||
#define HTTPPOST_READFILE (1<<1) /* specified content is a file name */
|
#define HTTPPOST_READFILE (1<<1) /* specified content is a file name */
|
||||||
|
#define HTTPPOST_PTRNAME (1<<2) /* name is only stored pointer
|
||||||
|
do not free in formfree */
|
||||||
|
#define HTTPPOST_PTRCONTENTS (1<<3) /* contents is only stored pointer
|
||||||
|
do not free in formfree */
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef int (*curl_progress_callback)(void *clientp,
|
typedef int (*curl_progress_callback)(void *clientp,
|
||||||
@@ -93,15 +83,15 @@ typedef int (*curl_progress_callback)(void *clientp,
|
|||||||
typedef size_t (*curl_write_callback)(char *buffer,
|
typedef size_t (*curl_write_callback)(char *buffer,
|
||||||
size_t size,
|
size_t size,
|
||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *outstream);
|
void *outstream);
|
||||||
|
|
||||||
typedef size_t (*curl_read_callback)(char *buffer,
|
typedef size_t (*curl_read_callback)(char *buffer,
|
||||||
size_t size,
|
size_t size,
|
||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *instream);
|
void *instream);
|
||||||
|
|
||||||
typedef int (*curl_passwd_callback)(void *clientp,
|
typedef int (*curl_passwd_callback)(void *clientp,
|
||||||
char *prompt,
|
const char *prompt,
|
||||||
char *buffer,
|
char *buffer,
|
||||||
int buflen);
|
int buflen);
|
||||||
|
|
||||||
@@ -114,79 +104,74 @@ typedef int (*curl_passwd_callback)(void *clientp,
|
|||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
CURLE_OK = 0,
|
CURLE_OK = 0,
|
||||||
CURLE_UNSUPPORTED_PROTOCOL,
|
CURLE_UNSUPPORTED_PROTOCOL, /* 1 */
|
||||||
CURLE_FAILED_INIT,
|
CURLE_FAILED_INIT, /* 2 */
|
||||||
CURLE_URL_MALFORMAT,
|
CURLE_URL_MALFORMAT, /* 3 */
|
||||||
CURLE_URL_MALFORMAT_USER,
|
CURLE_URL_MALFORMAT_USER, /* 4 */
|
||||||
CURLE_COULDNT_RESOLVE_PROXY,
|
CURLE_COULDNT_RESOLVE_PROXY, /* 5 */
|
||||||
CURLE_COULDNT_RESOLVE_HOST,
|
CURLE_COULDNT_RESOLVE_HOST, /* 6 */
|
||||||
CURLE_COULDNT_CONNECT,
|
CURLE_COULDNT_CONNECT, /* 7 */
|
||||||
CURLE_FTP_WEIRD_SERVER_REPLY,
|
CURLE_FTP_WEIRD_SERVER_REPLY, /* 8 */
|
||||||
CURLE_FTP_ACCESS_DENIED,
|
CURLE_FTP_ACCESS_DENIED, /* 9 */
|
||||||
CURLE_FTP_USER_PASSWORD_INCORRECT,
|
CURLE_FTP_USER_PASSWORD_INCORRECT, /* 10 */
|
||||||
CURLE_FTP_WEIRD_PASS_REPLY,
|
CURLE_FTP_WEIRD_PASS_REPLY, /* 11 */
|
||||||
CURLE_FTP_WEIRD_USER_REPLY,
|
CURLE_FTP_WEIRD_USER_REPLY, /* 12 */
|
||||||
CURLE_FTP_WEIRD_PASV_REPLY,
|
CURLE_FTP_WEIRD_PASV_REPLY, /* 13 */
|
||||||
CURLE_FTP_WEIRD_227_FORMAT,
|
CURLE_FTP_WEIRD_227_FORMAT, /* 14 */
|
||||||
CURLE_FTP_CANT_GET_HOST,
|
CURLE_FTP_CANT_GET_HOST, /* 15 */
|
||||||
CURLE_FTP_CANT_RECONNECT,
|
CURLE_FTP_CANT_RECONNECT, /* 16 */
|
||||||
CURLE_FTP_COULDNT_SET_BINARY,
|
CURLE_FTP_COULDNT_SET_BINARY, /* 17 */
|
||||||
CURLE_PARTIAL_FILE,
|
CURLE_PARTIAL_FILE, /* 18 */
|
||||||
CURLE_FTP_COULDNT_RETR_FILE,
|
CURLE_FTP_COULDNT_RETR_FILE, /* 19 */
|
||||||
CURLE_FTP_WRITE_ERROR,
|
CURLE_FTP_WRITE_ERROR, /* 20 */
|
||||||
CURLE_FTP_QUOTE_ERROR,
|
CURLE_FTP_QUOTE_ERROR, /* 21 */
|
||||||
CURLE_HTTP_NOT_FOUND,
|
CURLE_HTTP_NOT_FOUND, /* 22 */
|
||||||
CURLE_WRITE_ERROR,
|
CURLE_WRITE_ERROR, /* 23 */
|
||||||
|
CURLE_MALFORMAT_USER, /* 24 - user name is illegally specified */
|
||||||
|
CURLE_FTP_COULDNT_STOR_FILE, /* 25 - failed FTP upload */
|
||||||
|
CURLE_READ_ERROR, /* 26 - could open/read from file */
|
||||||
|
CURLE_OUT_OF_MEMORY, /* 27 */
|
||||||
|
CURLE_OPERATION_TIMEOUTED, /* 28 - the timeout time was reached */
|
||||||
|
CURLE_FTP_COULDNT_SET_ASCII, /* 29 - TYPE A failed */
|
||||||
|
CURLE_FTP_PORT_FAILED, /* 30 - FTP PORT operation failed */
|
||||||
|
CURLE_FTP_COULDNT_USE_REST, /* 31 - the REST command failed */
|
||||||
|
CURLE_FTP_COULDNT_GET_SIZE, /* 32 - the SIZE command failed */
|
||||||
|
CURLE_HTTP_RANGE_ERROR, /* 33 - RANGE "command" didn't work */
|
||||||
|
CURLE_HTTP_POST_ERROR, /* 34 */
|
||||||
|
CURLE_SSL_CONNECT_ERROR, /* 35 - wrong when connecting with SSL */
|
||||||
|
CURLE_FTP_BAD_DOWNLOAD_RESUME, /* 36 - couldn't resume download */
|
||||||
|
CURLE_FILE_COULDNT_READ_FILE, /* 37 */
|
||||||
|
CURLE_LDAP_CANNOT_BIND, /* 38 */
|
||||||
|
CURLE_LDAP_SEARCH_FAILED, /* 39 */
|
||||||
|
CURLE_LIBRARY_NOT_FOUND, /* 40 */
|
||||||
|
CURLE_FUNCTION_NOT_FOUND, /* 41 */
|
||||||
|
CURLE_ABORTED_BY_CALLBACK, /* 42 */
|
||||||
|
CURLE_BAD_FUNCTION_ARGUMENT, /* 43 */
|
||||||
|
CURLE_BAD_CALLING_ORDER, /* 44 */
|
||||||
|
CURLE_HTTP_PORT_FAILED, /* 45 - HTTP Interface operation failed */
|
||||||
|
CURLE_BAD_PASSWORD_ENTERED, /* 46 - my_getpass() returns fail */
|
||||||
|
CURLE_TOO_MANY_REDIRECTS , /* 47 - catch endless re-direct loops */
|
||||||
|
CURLE_UNKNOWN_TELNET_OPTION, /* 48 - User specified an unknown option */
|
||||||
|
CURLE_TELNET_OPTION_SYNTAX , /* 49 - Malformed telnet option */
|
||||||
|
CURLE_OBSOLETE, /* 50 - removed after 7.7.3 */
|
||||||
|
CURLE_SSL_PEER_CERTIFICATE, /* 51 - peer's certificate wasn't ok */
|
||||||
|
CURLE_GOT_NOTHING, /* 52 - when this is a specific error */
|
||||||
|
CURLE_SSL_ENGINE_NOTFOUND, /* 53 - SSL crypto engine not found */
|
||||||
|
CURLE_SSL_ENGINE_SETFAILED, /* 54 - can not set SSL crypto engine as default */
|
||||||
|
|
||||||
CURLE_MALFORMAT_USER, /* the user name is illegally specified */
|
CURL_LAST /* never use! */
|
||||||
CURLE_FTP_COULDNT_STOR_FILE, /* failed FTP upload */
|
|
||||||
CURLE_READ_ERROR, /* could open/read from file */
|
|
||||||
|
|
||||||
CURLE_OUT_OF_MEMORY,
|
|
||||||
CURLE_OPERATION_TIMEOUTED, /* the timeout time was reached */
|
|
||||||
CURLE_FTP_COULDNT_SET_ASCII, /* TYPE A failed */
|
|
||||||
|
|
||||||
CURLE_FTP_PORT_FAILED, /* FTP PORT operation failed */
|
|
||||||
|
|
||||||
CURLE_FTP_COULDNT_USE_REST, /* the REST command failed */
|
|
||||||
CURLE_FTP_COULDNT_GET_SIZE, /* the SIZE command failed */
|
|
||||||
|
|
||||||
CURLE_HTTP_RANGE_ERROR, /* The RANGE "command" didn't seem to work */
|
|
||||||
|
|
||||||
CURLE_HTTP_POST_ERROR,
|
|
||||||
|
|
||||||
CURLE_SSL_CONNECT_ERROR, /* something was wrong when connecting with SSL */
|
|
||||||
|
|
||||||
CURLE_FTP_BAD_DOWNLOAD_RESUME, /* couldn't resume download */
|
|
||||||
|
|
||||||
CURLE_FILE_COULDNT_READ_FILE,
|
|
||||||
|
|
||||||
CURLE_LDAP_CANNOT_BIND,
|
|
||||||
CURLE_LDAP_SEARCH_FAILED,
|
|
||||||
CURLE_LIBRARY_NOT_FOUND,
|
|
||||||
CURLE_FUNCTION_NOT_FOUND,
|
|
||||||
|
|
||||||
CURLE_ABORTED_BY_CALLBACK,
|
|
||||||
CURLE_BAD_FUNCTION_ARGUMENT,
|
|
||||||
CURLE_BAD_CALLING_ORDER,
|
|
||||||
|
|
||||||
CURLE_HTTP_PORT_FAILED, /* HTTP Interface operation failed */
|
|
||||||
|
|
||||||
CURLE_BAD_PASSWORD_ENTERED, /* when the my_getpass() returns fail */
|
|
||||||
CURLE_TOO_MANY_REDIRECTS , /* catch endless re-direct loops */
|
|
||||||
|
|
||||||
CURL_LAST
|
|
||||||
} CURLcode;
|
} CURLcode;
|
||||||
|
|
||||||
|
/* this was the error code 50 in 7.7.3 and a few earlier versions, this
|
||||||
|
is no longer used by libcurl but is instead #defined here only to not
|
||||||
|
make programs break */
|
||||||
|
#define CURLE_ALREADY_COMPLETE 99999
|
||||||
|
|
||||||
/* This is just to make older programs not break: */
|
/* This is just to make older programs not break: */
|
||||||
#define CURLE_FTP_PARTIAL_FILE CURLE_PARTIAL_FILE
|
#define CURLE_FTP_PARTIAL_FILE CURLE_PARTIAL_FILE
|
||||||
|
|
||||||
#define CURL_ERROR_SIZE 256
|
#define CURL_ERROR_SIZE 256
|
||||||
|
|
||||||
/* maximum URL length we deal with in headers */
|
|
||||||
#define URL_MAX_LENGTH 4096
|
|
||||||
#define URL_MAX_LENGTH_TXT "4095"
|
|
||||||
|
|
||||||
/* name is uppercase CURLOPT_<name>,
|
/* name is uppercase CURLOPT_<name>,
|
||||||
type is one of the defined CURLOPTTYPE_<type>
|
type is one of the defined CURLOPTTYPE_<type>
|
||||||
number is unique identifier */
|
number is unique identifier */
|
||||||
@@ -204,7 +189,7 @@ typedef enum {
|
|||||||
typedef enum {
|
typedef enum {
|
||||||
CINIT(NOTHING, LONG, 0), /********* the first one is unused ************/
|
CINIT(NOTHING, LONG, 0), /********* the first one is unused ************/
|
||||||
|
|
||||||
/* This is the FILE * the regular output should be written to. */
|
/* This is the FILE * or void * the regular output should be written to. */
|
||||||
CINIT(FILE, OBJECTPOINT, 1),
|
CINIT(FILE, OBJECTPOINT, 1),
|
||||||
|
|
||||||
/* The full URL to get/put */
|
/* The full URL to get/put */
|
||||||
@@ -230,10 +215,8 @@ typedef enum {
|
|||||||
in the CURLOPT_FLAGS to activate this */
|
in the CURLOPT_FLAGS to activate this */
|
||||||
CINIT(RANGE, OBJECTPOINT, 7),
|
CINIT(RANGE, OBJECTPOINT, 7),
|
||||||
|
|
||||||
#if 0
|
/* not used */
|
||||||
/* Configuration flags */
|
|
||||||
CINIT(FLAGS, LONG, 8),
|
|
||||||
#endif
|
|
||||||
/* Specified file stream to upload from (use as input): */
|
/* Specified file stream to upload from (use as input): */
|
||||||
CINIT(INFILE, OBJECTPOINT, 9),
|
CINIT(INFILE, OBJECTPOINT, 9),
|
||||||
|
|
||||||
@@ -298,8 +281,10 @@ typedef enum {
|
|||||||
/* name of the file keeping your private SSL-certificate */
|
/* name of the file keeping your private SSL-certificate */
|
||||||
CINIT(SSLCERT, OBJECTPOINT, 25),
|
CINIT(SSLCERT, OBJECTPOINT, 25),
|
||||||
|
|
||||||
/* password for the SSL-certificate */
|
/* password for the SSL-private key, keep this for compatibility */
|
||||||
CINIT(SSLCERTPASSWD, OBJECTPOINT, 26),
|
CINIT(SSLCERTPASSWD, OBJECTPOINT, 26),
|
||||||
|
/* password for the SSL private key */
|
||||||
|
CINIT(SSLKEYPASSWD, OBJECTPOINT, 26),
|
||||||
|
|
||||||
/* send TYPE parameter? */
|
/* send TYPE parameter? */
|
||||||
CINIT(CRLF, LONG, 27),
|
CINIT(CRLF, LONG, 27),
|
||||||
@@ -307,20 +292,16 @@ typedef enum {
|
|||||||
/* send linked-list of QUOTE commands */
|
/* send linked-list of QUOTE commands */
|
||||||
CINIT(QUOTE, OBJECTPOINT, 28),
|
CINIT(QUOTE, OBJECTPOINT, 28),
|
||||||
|
|
||||||
/* send FILE * to store headers to */
|
/* send FILE * or void * to store headers to, if you use a callback it
|
||||||
|
is simply passed to the callback unmodified */
|
||||||
CINIT(WRITEHEADER, OBJECTPOINT, 29),
|
CINIT(WRITEHEADER, OBJECTPOINT, 29),
|
||||||
|
|
||||||
#ifdef MULTIDOC
|
|
||||||
/* send linked list of MoreDoc structs */
|
|
||||||
CINIT(MOREDOCS, OBJECTPOINT, 30),
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* point to a file to read the initial cookies from, also enables
|
/* point to a file to read the initial cookies from, also enables
|
||||||
"cookie awareness" */
|
"cookie awareness" */
|
||||||
CINIT(COOKIEFILE, OBJECTPOINT, 31),
|
CINIT(COOKIEFILE, OBJECTPOINT, 31),
|
||||||
|
|
||||||
/* What version to specifly try to use.
|
/* What version to specifly try to use.
|
||||||
3 = SSLv3, 2 = SSLv2, all else makes it try v3 first then v2 */
|
See CURL_SSLVERSION defines below. */
|
||||||
CINIT(SSLVERSION, LONG, 32),
|
CINIT(SSLVERSION, LONG, 32),
|
||||||
|
|
||||||
/* What kind of HTTP time condition to use, see defines */
|
/* What kind of HTTP time condition to use, see defines */
|
||||||
@@ -343,11 +324,8 @@ typedef enum {
|
|||||||
/* HTTP request, for odd commands like DELETE, TRACE and others */
|
/* HTTP request, for odd commands like DELETE, TRACE and others */
|
||||||
CINIT(STDERR, OBJECTPOINT, 37),
|
CINIT(STDERR, OBJECTPOINT, 37),
|
||||||
|
|
||||||
#if 0
|
/* 38 is not used */
|
||||||
/* Progress mode set alternative progress mode displays. Alternative
|
|
||||||
ones should now be made by the client, not the lib! */
|
|
||||||
CINIT(PROGRESSMODE, LONG, 38),
|
|
||||||
#endif
|
|
||||||
/* send linked-list of post-transfer QUOTE commands */
|
/* send linked-list of post-transfer QUOTE commands */
|
||||||
CINIT(POSTQUOTE, OBJECTPOINT, 39),
|
CINIT(POSTQUOTE, OBJECTPOINT, 39),
|
||||||
|
|
||||||
@@ -375,7 +353,8 @@ typedef enum {
|
|||||||
|
|
||||||
CINIT(TRANSFERTEXT, LONG, 53), /* transfer data in text/ASCII format */
|
CINIT(TRANSFERTEXT, LONG, 53), /* transfer data in text/ASCII format */
|
||||||
CINIT(PUT, LONG, 54), /* PUT the input file */
|
CINIT(PUT, LONG, 54), /* PUT the input file */
|
||||||
CINIT(MUTE, LONG, 55), /* force NOPROGRESS */
|
|
||||||
|
CINIT(MUTE, LONG, 55), /* OBSOLETE OPTION, removed in 7.8 */
|
||||||
|
|
||||||
/* Function that will be called instead of the internal progress display
|
/* Function that will be called instead of the internal progress display
|
||||||
* function. This function should be defined as the curl_progress_callback
|
* function. This function should be defined as the curl_progress_callback
|
||||||
@@ -427,9 +406,118 @@ typedef enum {
|
|||||||
document! Pass a NULL to shut it off. */
|
document! Pass a NULL to shut it off. */
|
||||||
CINIT(FILETIME, OBJECTPOINT, 69),
|
CINIT(FILETIME, OBJECTPOINT, 69),
|
||||||
|
|
||||||
|
/* This points to a linked list of telnet options */
|
||||||
|
CINIT(TELNETOPTIONS, OBJECTPOINT, 70),
|
||||||
|
|
||||||
|
/* Max amount of cached alive connections */
|
||||||
|
CINIT(MAXCONNECTS, LONG, 71),
|
||||||
|
|
||||||
|
/* What policy to use when closing connections when the cache is filled
|
||||||
|
up */
|
||||||
|
CINIT(CLOSEPOLICY, LONG, 72),
|
||||||
|
|
||||||
|
/* Callback to use when CURLCLOSEPOLICY_CALLBACK is set */
|
||||||
|
CINIT(CLOSEFUNCTION, FUNCTIONPOINT, 73),
|
||||||
|
|
||||||
|
/* Set to explicitly use a new connection for the upcoming transfer.
|
||||||
|
Do not use this unless you're absolutely sure of this, as it makes the
|
||||||
|
operation slower and is less friendly for the network. */
|
||||||
|
CINIT(FRESH_CONNECT, LONG, 74),
|
||||||
|
|
||||||
|
/* Set to explicitly forbid the upcoming transfer's connection to be re-used
|
||||||
|
when done. Do not use this unless you're absolutely sure of this, as it
|
||||||
|
makes the operation slower and is less friendly for the network. */
|
||||||
|
CINIT(FORBID_REUSE, LONG, 75),
|
||||||
|
|
||||||
|
/* Set to a file name that contains random data for libcurl to use to
|
||||||
|
seed the random engine when doing SSL connects. */
|
||||||
|
CINIT(RANDOM_FILE, OBJECTPOINT, 76),
|
||||||
|
|
||||||
|
/* Set to the Entropy Gathering Daemon socket pathname */
|
||||||
|
CINIT(EGDSOCKET, OBJECTPOINT, 77),
|
||||||
|
|
||||||
|
/* Time-out connect operations after this amount of seconds, if connects
|
||||||
|
are OK within this time, then fine... This only aborts the connect
|
||||||
|
phase. [Only works on unix-style/SIGALRM operating systems] */
|
||||||
|
CINIT(CONNECTTIMEOUT, LONG, 78),
|
||||||
|
|
||||||
|
/* Function that will be called to store headers (instead of fwrite). The
|
||||||
|
* parameters will use fwrite() syntax, make sure to follow them. */
|
||||||
|
CINIT(HEADERFUNCTION, FUNCTIONPOINT, 79),
|
||||||
|
|
||||||
|
/* Set this to force the HTTP request to get back to GET. Only really usable
|
||||||
|
if POST, PUT or a custom request have been used first.
|
||||||
|
*/
|
||||||
|
CINIT(HTTPGET, LONG, 80),
|
||||||
|
|
||||||
|
/* Set if we should verify the Common name from the peer certificate in ssl
|
||||||
|
* handshake, set 1 to check existence, 2 to ensure that it matches the
|
||||||
|
* provided hostname. */
|
||||||
|
CINIT(SSL_VERIFYHOST, LONG, 81),
|
||||||
|
|
||||||
|
/* Specify which file name to write all known cookies in after completed
|
||||||
|
operation. Set file name to "-" (dash) to make it go to stdout. */
|
||||||
|
CINIT(COOKIEJAR, OBJECTPOINT, 82),
|
||||||
|
|
||||||
|
/* Specify which SSL ciphers to use */
|
||||||
|
CINIT(SSL_CIPHER_LIST, OBJECTPOINT, 83),
|
||||||
|
|
||||||
|
/* Specify which HTTP version to use! This must be set to one of the
|
||||||
|
CURL_HTTP_VERSION* enums set below. */
|
||||||
|
CINIT(HTTP_VERSION, LONG, 84),
|
||||||
|
|
||||||
|
/* Specificly switch on or off the FTP engine's use of the EPSV command. By
|
||||||
|
default, that one will always be attempted before the more traditional
|
||||||
|
PASV command. */
|
||||||
|
CINIT(FTP_USE_EPSV, LONG, 85),
|
||||||
|
|
||||||
|
/* type of the file keeping your SSL-certificate ("DER", "PEM", "ENG") */
|
||||||
|
CINIT(SSLCERTTYPE, OBJECTPOINT, 86),
|
||||||
|
|
||||||
|
/* name of the file keeping your private SSL-key */
|
||||||
|
CINIT(SSLKEY, OBJECTPOINT, 87),
|
||||||
|
|
||||||
|
/* type of the file keeping your private SSL-key ("DER", "PEM", "ENG") */
|
||||||
|
CINIT(SSLKEYTYPE, OBJECTPOINT, 88),
|
||||||
|
|
||||||
|
/* crypto engine for the SSL-sub system */
|
||||||
|
CINIT(SSLENGINE, OBJECTPOINT, 89),
|
||||||
|
|
||||||
|
/* set the crypto engine for the SSL-sub system as default
|
||||||
|
the param has no meaning...
|
||||||
|
*/
|
||||||
|
CINIT(SSLENGINE_DEFAULT, LONG, 90),
|
||||||
|
|
||||||
|
/* Non-zero value means to use the global dns cache */
|
||||||
|
CINIT(DNS_USE_GLOBAL_CACHE, LONG, 91),
|
||||||
|
|
||||||
|
/* DNS cache timeout */
|
||||||
|
CINIT(DNS_CACHE_TIMEOUT, LONG, 92),
|
||||||
|
|
||||||
CURLOPT_LASTENTRY /* the last unusued */
|
CURLOPT_LASTENTRY /* the last unusued */
|
||||||
} CURLoption;
|
} CURLoption;
|
||||||
|
|
||||||
|
/* These enums are for use with the CURLOPT_HTTP_VERSION option. */
|
||||||
|
enum {
|
||||||
|
CURL_HTTP_VERSION_NONE, /* setting this means we don't care, and that we'd
|
||||||
|
like the library to choose the best possible
|
||||||
|
for us! */
|
||||||
|
CURL_HTTP_VERSION_1_0, /* please use HTTP 1.0 in the request */
|
||||||
|
CURL_HTTP_VERSION_1_1, /* please use HTTP 1.1 in the request */
|
||||||
|
|
||||||
|
CURL_HTTP_VERSION_LAST /* *ILLEGAL* http version */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
CURL_SSLVERSION_DEFAULT,
|
||||||
|
CURL_SSLVERSION_TLSv1,
|
||||||
|
CURL_SSLVERSION_SSLv2,
|
||||||
|
CURL_SSLVERSION_SSLv3,
|
||||||
|
|
||||||
|
CURL_SSLVERSION_LAST /* never use, keep last */
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
TIMECOND_NONE,
|
TIMECOND_NONE,
|
||||||
|
|
||||||
@@ -438,7 +526,7 @@ typedef enum {
|
|||||||
TIMECOND_LASTMOD,
|
TIMECOND_LASTMOD,
|
||||||
|
|
||||||
TIMECOND_LAST
|
TIMECOND_LAST
|
||||||
} TimeCond;
|
} curl_TimeCond;
|
||||||
|
|
||||||
#ifdef __BEOS__
|
#ifdef __BEOS__
|
||||||
#include <support/SupportDefs.h>
|
#include <support/SupportDefs.h>
|
||||||
@@ -452,27 +540,81 @@ typedef enum {
|
|||||||
|
|
||||||
NOTE: they return TRUE if the strings match *case insensitively*.
|
NOTE: they return TRUE if the strings match *case insensitively*.
|
||||||
*/
|
*/
|
||||||
extern int (strequal)(const char *s1, const char *s2);
|
extern int (curl_strequal)(const char *s1, const char *s2);
|
||||||
extern int (strnequal)(const char *s1, const char *s2, size_t n);
|
extern int (curl_strnequal)(const char *s1, const char *s2, size_t n);
|
||||||
|
#define strequal(a,b) curl_strequal(a,b)
|
||||||
|
#define strnequal(a,b,c) curl_strnequal(a,b,c)
|
||||||
|
|
||||||
/* external form function */
|
/* external form function */
|
||||||
int curl_formparse(char *string,
|
int curl_formparse(char *string,
|
||||||
struct HttpPost **httppost,
|
struct HttpPost **httppost,
|
||||||
struct HttpPost **last_post);
|
struct HttpPost **last_post);
|
||||||
|
|
||||||
|
/* name is uppercase CURLFORM_<name> */
|
||||||
|
#ifdef CFINIT
|
||||||
|
#undef CFINIT
|
||||||
|
#endif
|
||||||
|
#define CFINIT(name) CURLFORM_ ## name
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CFINIT(NOTHING), /********* the first one is unused ************/
|
||||||
|
|
||||||
|
/* */
|
||||||
|
CFINIT(COPYNAME),
|
||||||
|
CFINIT(PTRNAME),
|
||||||
|
CFINIT(NAMELENGTH),
|
||||||
|
CFINIT(COPYCONTENTS),
|
||||||
|
CFINIT(PTRCONTENTS),
|
||||||
|
CFINIT(CONTENTSLENGTH),
|
||||||
|
CFINIT(FILECONTENT),
|
||||||
|
CFINIT(ARRAY),
|
||||||
|
CFINIT(ARRAY_START), /* below are the options allowed within a array */
|
||||||
|
CFINIT(FILE),
|
||||||
|
CFINIT(CONTENTTYPE),
|
||||||
|
CFINIT(CONTENTHEADER),
|
||||||
|
CFINIT(END),
|
||||||
|
CFINIT(ARRAY_END), /* up are the options allowed within a array */
|
||||||
|
|
||||||
|
CURLFORM_LASTENTRY /* the last unusued */
|
||||||
|
} CURLformoption;
|
||||||
|
|
||||||
|
/* structure to be used as parameter for CURLFORM_ARRAY */
|
||||||
|
struct curl_forms {
|
||||||
|
CURLformoption option;
|
||||||
|
const char *value;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* new external form function */
|
||||||
|
int curl_formadd(struct HttpPost **httppost,
|
||||||
|
struct HttpPost **last_post,
|
||||||
|
...);
|
||||||
|
|
||||||
/* cleanup a form: */
|
/* cleanup a form: */
|
||||||
void curl_formfree(struct HttpPost *form);
|
void curl_formfree(struct HttpPost *form);
|
||||||
|
|
||||||
/* Unix and Win32 getenv function call, this returns a malloc()'ed string that
|
/* Unix and Win32 getenv function call, this returns a malloc()'ed string that
|
||||||
MUST be free()ed after usage is complete. */
|
MUST be free()ed after usage is complete. */
|
||||||
char *curl_getenv(char *variable);
|
char *curl_getenv(const char *variable);
|
||||||
|
|
||||||
/* Returns a static ascii string of the libcurl version. */
|
/* Returns a static ascii string of the libcurl version. */
|
||||||
char *curl_version(void);
|
char *curl_version(void);
|
||||||
|
|
||||||
|
/* Escape and unescape URL encoding in strings. The functions return a new
|
||||||
|
* allocated string or NULL if an error occurred. */
|
||||||
|
char *curl_escape(const char *string, int length);
|
||||||
|
char *curl_unescape(const char *string, int length);
|
||||||
|
|
||||||
|
/* curl_global_init() should be invoked exactly once for each application that
|
||||||
|
uses libcurl */
|
||||||
|
CURLcode curl_global_init(long flags);
|
||||||
|
|
||||||
|
/* curl_global_cleanup() should be invoked exactly once for each application
|
||||||
|
that uses libcurl */
|
||||||
|
void curl_global_cleanup(void);
|
||||||
|
|
||||||
/* This is the version number */
|
/* This is the version number */
|
||||||
#define LIBCURL_VERSION "7.5.2-pre1"
|
#define LIBCURL_VERSION "7.9.3-pre3"
|
||||||
#define LIBCURL_VERSION_NUM 0x070502
|
#define LIBCURL_VERSION_NUM 0x070903
|
||||||
|
|
||||||
/* linked-list structure for the CURLOPT_QUOTE option (and other) */
|
/* linked-list structure for the CURLOPT_QUOTE option (and other) */
|
||||||
struct curl_slist {
|
struct curl_slist {
|
||||||
@@ -480,184 +622,8 @@ struct curl_slist {
|
|||||||
struct curl_slist *next;
|
struct curl_slist *next;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct curl_slist *curl_slist_append(struct curl_slist *list, char *data);
|
struct curl_slist *curl_slist_append(struct curl_slist *, const char *);
|
||||||
void curl_slist_free_all(struct curl_slist *list);
|
void curl_slist_free_all(struct curl_slist *);
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_init()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Inits libcurl globally. This must be used before any libcurl calls can
|
|
||||||
* be used. This may install global plug-ins or whatever. (This does not
|
|
||||||
* do winsock inits in Windows.)
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* curl_init();
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
CURLcode curl_init(void);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_init()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Frees libcurl globally. This must be used after all libcurl calls have
|
|
||||||
* been used. This may remove global plug-ins or whatever. (This does not
|
|
||||||
* do winsock cleanups in Windows.)
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* curl_free(curl);
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
void curl_free(void);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_open()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Opens a general curl session. It does not try to connect or do anything
|
|
||||||
* on the network because of this call. The specified URL is only required
|
|
||||||
* to enable curl to figure out what protocol to "activate".
|
|
||||||
*
|
|
||||||
* A session should be looked upon as a series of requests to a single host. A
|
|
||||||
* session interacts with one host only, using one single protocol.
|
|
||||||
*
|
|
||||||
* The URL is not required. If set to "" or NULL, it can still be set later
|
|
||||||
* using the curl_setopt() function. If the curl_connect() function is called
|
|
||||||
* without the URL being known, it will return error.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLcode result;
|
|
||||||
* CURL *curl;
|
|
||||||
* result = curl_open(&curl, "http://curl.haxx.nu/libcurl/");
|
|
||||||
* if(result != CURL_OK) {
|
|
||||||
* return result;
|
|
||||||
* }
|
|
||||||
* */
|
|
||||||
CURLcode curl_open(CURL **curl, char *url);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_setopt()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Sets a particular option to the specified value.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURL curl;
|
|
||||||
* curl_setopt(curl, CURL_HTTP_FOLLOW_LOCATION, TRUE);
|
|
||||||
*/
|
|
||||||
CURLcode curl_setopt(CURL *handle, CURLoption option, ...);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_close()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Closes a session previously opened with curl_open()
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURL *curl;
|
|
||||||
* CURLcode result;
|
|
||||||
*
|
|
||||||
* result = curl_close(curl);
|
|
||||||
*/
|
|
||||||
CURLcode curl_close(CURL *curl); /* the opposite of curl_open() */
|
|
||||||
|
|
||||||
CURLcode curl_read(CURLconnect *c_conn, char *buf, size_t buffersize,
|
|
||||||
size_t *n);
|
|
||||||
CURLcode curl_write(CURLconnect *c_conn, char *buf, size_t amount,
|
|
||||||
size_t *n);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_connect()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Connects to the peer server and performs the initial setup. This function
|
|
||||||
* writes a connect handle to its second argument that is a unique handle for
|
|
||||||
* this connect. This allows multiple connects from the same handle returned
|
|
||||||
* by curl_open().
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLCode result;
|
|
||||||
* CURL curl;
|
|
||||||
* CURLconnect connect;
|
|
||||||
* result = curl_connect(curl, &connect);
|
|
||||||
*/
|
|
||||||
|
|
||||||
CURLcode curl_connect(CURL *curl, CURLconnect **in_connect);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_do()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* (Note: May 3rd 2000: this function does not currently allow you to
|
|
||||||
* specify a document, it will use the one set previously)
|
|
||||||
*
|
|
||||||
* This function asks for the particular document, file or resource that
|
|
||||||
* resides on the server we have connected to. You may specify a full URL,
|
|
||||||
* just an absolute path or even a relative path. That means, if you're just
|
|
||||||
* getting one file from the remote site, you can use the same URL as input
|
|
||||||
* for both curl_open() as well as for this function.
|
|
||||||
*
|
|
||||||
* In the even there is a host name, port number, user name or password parts
|
|
||||||
* in the URL, you can use the 'flags' argument to ignore them completely, or
|
|
||||||
* at your choice, make the function fail if you're trying to get a URL from
|
|
||||||
* different host than you connected to with curl_connect().
|
|
||||||
*
|
|
||||||
* You can only get one document at a time using the same connection. When one
|
|
||||||
* document has been received you can although request again.
|
|
||||||
*
|
|
||||||
* When the transfer is done, curl_done() MUST be called.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLCode result;
|
|
||||||
* char *url;
|
|
||||||
* CURLconnect *connect;
|
|
||||||
* result = curl_do(connect, url, CURL_DO_NONE); */
|
|
||||||
CURLcode curl_do(CURLconnect *in_conn);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_done()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* When the transfer following a curl_do() call is done, this function should
|
|
||||||
* get called.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLCode result;
|
|
||||||
* char *url;
|
|
||||||
* CURLconnect *connect;
|
|
||||||
* result = curl_done(connect); */
|
|
||||||
CURLcode curl_done(CURLconnect *connect);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_disconnect()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Disconnects from the peer server and performs connection cleanup.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLcode result;
|
|
||||||
* CURLconnect *connect;
|
|
||||||
* result = curl_disconnect(connect); */
|
|
||||||
CURLcode curl_disconnect(CURLconnect *connect);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* NAME curl_getdate()
|
* NAME curl_getdate()
|
||||||
@@ -695,22 +661,35 @@ typedef enum {
|
|||||||
CURLINFO_SSL_VERIFYRESULT = CURLINFO_LONG + 13,
|
CURLINFO_SSL_VERIFYRESULT = CURLINFO_LONG + 13,
|
||||||
CURLINFO_FILETIME = CURLINFO_LONG + 14,
|
CURLINFO_FILETIME = CURLINFO_LONG + 14,
|
||||||
|
|
||||||
CURLINFO_LASTONE = 15
|
CURLINFO_CONTENT_LENGTH_DOWNLOAD = CURLINFO_DOUBLE + 15,
|
||||||
|
CURLINFO_CONTENT_LENGTH_UPLOAD = CURLINFO_DOUBLE + 16,
|
||||||
|
|
||||||
|
CURLINFO_STARTTRANSFER_TIME = CURLINFO_DOUBLE + 17,
|
||||||
|
|
||||||
|
CURLINFO_LASTONE = 18
|
||||||
} CURLINFO;
|
} CURLINFO;
|
||||||
|
|
||||||
/*
|
/* unfortunately, the easy.h include file needs the options and info stuff
|
||||||
* NAME curl_getinfo()
|
before it can be included! */
|
||||||
*
|
#include <curl/easy.h> /* nothing in curl is fun without the easy stuff */
|
||||||
* DESCRIPTION
|
|
||||||
*
|
typedef enum {
|
||||||
* Request internal information from the curl session with this function.
|
CURLCLOSEPOLICY_NONE, /* first, never use this */
|
||||||
* The third argument MUST be a pointer to a long or a pointer to a char *.
|
|
||||||
* The data pointed to will be filled in accordingly and can be relied upon
|
CURLCLOSEPOLICY_OLDEST,
|
||||||
* only if the function returns CURLE_OK.
|
CURLCLOSEPOLICY_LEAST_RECENTLY_USED,
|
||||||
* This function is intended to get used *AFTER* a performed transfer, all
|
CURLCLOSEPOLICY_LEAST_TRAFFIC,
|
||||||
* results are undefined before the transfer is completed.
|
CURLCLOSEPOLICY_SLOWEST,
|
||||||
*/
|
CURLCLOSEPOLICY_CALLBACK,
|
||||||
CURLcode curl_getinfo(CURL *curl, CURLINFO info, ...);
|
|
||||||
|
CURLCLOSEPOLICY_LAST /* last, never use this */
|
||||||
|
} curl_closepolicy;
|
||||||
|
|
||||||
|
#define CURL_GLOBAL_SSL (1<<0)
|
||||||
|
#define CURL_GLOBAL_WIN32 (1<<1)
|
||||||
|
#define CURL_GLOBAL_ALL (CURL_GLOBAL_SSL|CURL_GLOBAL_WIN32)
|
||||||
|
#define CURL_GLOBAL_NOTHING 0
|
||||||
|
#define CURL_GLOBAL_DEFAULT CURL_GLOBAL_ALL
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,38 +7,21 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* The contents of this file are subject to the Mozilla Public License
|
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
* Version 1.0 (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"
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
* License for the specific language governing rights and limitations
|
|
||||||
* under the License.
|
|
||||||
*
|
*
|
||||||
* The Original Code is Curl.
|
* 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 Initial Developer of the Original Code is Daniel Stenberg.
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
* Portions created by the Initial Developer are Copyright (C) 1998.
|
* $Id$
|
||||||
* All Rights Reserved.
|
*****************************************************************************/
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
* Main author:
|
|
||||||
* - Daniel Stenberg <Daniel.Stenberg@haxx.nu>
|
|
||||||
*
|
|
||||||
* http://curl.haxx.nu
|
|
||||||
*
|
|
||||||
* $Source$
|
|
||||||
* $Revision$
|
|
||||||
* $Date$
|
|
||||||
* $Author$
|
|
||||||
* $State$
|
|
||||||
* $Locker$
|
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
****************************************************************************/
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
@@ -63,6 +46,21 @@ void curl_easy_cleanup(CURL *curl);
|
|||||||
*/
|
*/
|
||||||
CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...);
|
CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* NAME curl_easy_duphandle()
|
||||||
|
*
|
||||||
|
* DESCRIPTION
|
||||||
|
*
|
||||||
|
* Creates a new curl session handle with the same options set for the handle
|
||||||
|
* passed in. Duplicating a handle could only be a matter of cloning data and
|
||||||
|
* options, internal state info and things like persistant connections cannot
|
||||||
|
* be transfered. It is useful in multithreaded applications when you can run
|
||||||
|
* curl_easy_duphandle() for each new thread to avoid a series of identical
|
||||||
|
* curl_easy_setopt() invokes in every thread.
|
||||||
|
*/
|
||||||
|
CURL* curl_easy_duphandle(CURL *curl);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -2,27 +2,14 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*
|
*
|
||||||
* The contents of this file are subject to the Mozilla Public License
|
* Permission to use, copy, modify, and distribute this software for any
|
||||||
* Version 1.0 (the "License"); you may not use this file except in
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
* compliance with the License. You may obtain a copy of the License at
|
* copyright notice and this permission notice appear in all copies.
|
||||||
* http://www.mozilla.org/MPL/
|
|
||||||
*
|
*
|
||||||
* Software distributed under the License is distributed on an "AS IS"
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
|
||||||
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
|
* WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
|
||||||
* the License for the specific language governing rights and limitations
|
* MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE AUTHORS AND
|
||||||
* under the License.
|
* CONTRIBUTORS ACCEPT NO RESPONSIBILITY IN ANY CONCEIVABLE MANNER.
|
||||||
*
|
|
||||||
* The Original Code is Triacle.
|
|
||||||
*
|
|
||||||
* The Initial Developers of the Original Code are Bjorn Reese and
|
|
||||||
* Daniel Stenberg.
|
|
||||||
*
|
|
||||||
* Portions created by Initial Developers are
|
|
||||||
*
|
|
||||||
* Copyright (C) 1998 Bjorn Reese and Daniel Stenberg.
|
|
||||||
* All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Contributor(s):
|
|
||||||
*
|
*
|
||||||
*************************************************************************
|
*************************************************************************
|
||||||
*
|
*
|
||||||
@@ -67,27 +54,30 @@
|
|||||||
#define H_MPRINTF
|
#define H_MPRINTF
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#include <stdio.h> /* needed for FILE */
|
||||||
|
|
||||||
int mprintf(const char *format, ...);
|
int curl_mprintf(const char *format, ...);
|
||||||
int mfprintf(FILE *fd, const char *format, ...);
|
int curl_mfprintf(FILE *fd, const char *format, ...);
|
||||||
int msprintf(char *buffer, const char *format, ...);
|
int curl_msprintf(char *buffer, const char *format, ...);
|
||||||
int msnprintf(char *buffer, size_t maxlength, const char *format, ...);
|
int curl_msnprintf(char *buffer, size_t maxlength, const char *format, ...);
|
||||||
int mvprintf(const char *format, va_list args);
|
int curl_mvprintf(const char *format, va_list args);
|
||||||
int mvfprintf(FILE *fd, const char *format, va_list args);
|
int curl_mvfprintf(FILE *fd, const char *format, va_list args);
|
||||||
int mvsprintf(char *buffer, const char *format, va_list args);
|
int curl_mvsprintf(char *buffer, const char *format, va_list args);
|
||||||
int mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list args);
|
int curl_mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list args);
|
||||||
char *maprintf(const char *format, ...);
|
char *curl_maprintf(const char *format, ...);
|
||||||
char *mvaprintf(const char *format, va_list args);
|
char *curl_mvaprintf(const char *format, va_list args);
|
||||||
|
|
||||||
#ifdef _MPRINTF_REPLACE
|
#ifdef _MPRINTF_REPLACE
|
||||||
# define printf mprintf
|
# define printf curl_mprintf
|
||||||
# define fprintf mfprintf
|
# define fprintf curl_mfprintf
|
||||||
# define sprintf msprintf
|
# define sprintf curl_msprintf
|
||||||
# define snprintf msnprintf
|
# define snprintf curl_msnprintf
|
||||||
# define vprintf mvprintf
|
# define vprintf curl_mvprintf
|
||||||
# define vfprintf mvfprintf
|
# define vfprintf curl_mvfprintf
|
||||||
# define vsprintf mvsprintf
|
# define vsprintf curl_mvsprintf
|
||||||
# define vsnprintf mvsnprintf
|
# define vsnprintf curl_mvsnprintf
|
||||||
|
# define aprintf curl_maprintf
|
||||||
|
# define vaprintf curl_mvaprintf
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* H_MPRINTF */
|
#endif /* H_MPRINTF */
|
||||||
|
|||||||
@@ -7,38 +7,21 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* The contents of this file are subject to the Mozilla Public License
|
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
* Version 1.0 (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"
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
* License for the specific language governing rights and limitations
|
|
||||||
* under the License.
|
|
||||||
*
|
*
|
||||||
* The Original Code is Curl.
|
* 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 Initial Developer of the Original Code is Daniel Stenberg.
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
* Portions created by the Initial Developer are Copyright (C) 1998.
|
* $Id$
|
||||||
* All Rights Reserved.
|
*****************************************************************************/
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
* Main author:
|
|
||||||
* - Daniel Stenberg <Daniel.Stenberg@haxx.nu>
|
|
||||||
*
|
|
||||||
* http://curl.haxx.nu
|
|
||||||
*
|
|
||||||
* $Source$
|
|
||||||
* $Revision$
|
|
||||||
* $Date$
|
|
||||||
* $Author$
|
|
||||||
* $State$
|
|
||||||
* $Locker$
|
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
#ifdef HAVE_SYS_TYPES_H
|
#ifdef HAVE_SYS_TYPES_H
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|||||||
@@ -7,38 +7,21 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* The contents of this file are subject to the Mozilla Public License
|
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
* Version 1.0 (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"
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
* License for the specific language governing rights and limitations
|
|
||||||
* under the License.
|
|
||||||
*
|
*
|
||||||
* The Original Code is Curl.
|
* 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 Initial Developer of the Original Code is Daniel Stenberg.
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
* Portions created by the Initial Developer are Copyright (C) 1998.
|
* $Id$
|
||||||
* All Rights Reserved.
|
*****************************************************************************/
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
* Main author:
|
|
||||||
* - Daniel Stenberg <daniel@haxx.se>
|
|
||||||
*
|
|
||||||
* http://curl.haxx.se
|
|
||||||
*
|
|
||||||
* $Source$
|
|
||||||
* $Revision$
|
|
||||||
* $Date$
|
|
||||||
* $Author$
|
|
||||||
* $State$
|
|
||||||
* $Locker$
|
|
||||||
*
|
|
||||||
* ------------------------------------------------------------
|
|
||||||
****************************************************************************/
|
|
||||||
typedef void CURL;
|
typedef void CURL;
|
||||||
typedef void CURLconnect;
|
typedef void CURLconnect;
|
||||||
|
|
||||||
|
|||||||
6
lib/.cvsignore
Normal file
6
lib/.cvsignore
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
*.la
|
||||||
|
*.lo
|
||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
.deps
|
||||||
|
.libs
|
||||||
@@ -2,17 +2,18 @@
|
|||||||
# $Id$
|
# $Id$
|
||||||
#
|
#
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
|
EXTRA_DIST = getdate.y \
|
||||||
|
Makefile.b32 Makefile.b32.resp Makefile.m32 Makefile.vc6 \
|
||||||
|
libcurl.def dllinit.c curllib.dsp curllib.dsw
|
||||||
|
|
||||||
lib_LTLIBRARIES = libcurl.la
|
lib_LTLIBRARIES = libcurl.la
|
||||||
|
|
||||||
# Some flags needed when trying to cause warnings ;-)
|
|
||||||
# CFLAGS = -DMALLOCDEBUG -g # -Wall #-pedantic
|
|
||||||
|
|
||||||
INCLUDES = -I$(top_srcdir)/include
|
INCLUDES = -I$(top_srcdir)/include
|
||||||
|
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = -version-info 1:0:0
|
libcurl_la_LDFLAGS = -no-undefined -version-info 2:2:0
|
||||||
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
||||||
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
|
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
|
||||||
# 1.
|
# 1.
|
||||||
@@ -49,12 +50,17 @@ cookie.c formdata.h http.c sendf.c \
|
|||||||
cookie.h ftp.c http.h sendf.h url.c \
|
cookie.h ftp.c http.h sendf.h url.c \
|
||||||
dict.c ftp.h if2ip.c speedcheck.c url.h \
|
dict.c ftp.h if2ip.c speedcheck.c url.h \
|
||||||
dict.h getdate.c if2ip.h speedcheck.h urldata.h \
|
dict.h getdate.c if2ip.h speedcheck.h urldata.h \
|
||||||
download.c getdate.h ldap.c ssluse.c version.c \
|
getdate.h ldap.c ssluse.c version.c \
|
||||||
download.h getenv.c ldap.h ssluse.h \
|
getenv.c ldap.h ssluse.h \
|
||||||
escape.c getenv.h mprintf.c telnet.c \
|
escape.c mprintf.c telnet.c \
|
||||||
escape.h getpass.c netrc.c telnet.h \
|
escape.h getpass.c netrc.c telnet.h \
|
||||||
getinfo.c highlevel.c strequal.c strequal.h easy.c \
|
getinfo.c getinfo.h transfer.c strequal.c strequal.h easy.c \
|
||||||
security.h security.c krb4.c memdebug.c memdebug.h
|
security.h security.c krb4.c krb4.h memdebug.c memdebug.h inet_ntoa_r.h \
|
||||||
|
http_chunks.c http_chunks.h strtok.c strtok.h connect.c connect.h \
|
||||||
|
llist.c llist.h hash.c hash.h multi.c multi.h
|
||||||
|
|
||||||
|
|
||||||
|
noinst_HEADERS = setup.h transfer.h
|
||||||
|
|
||||||
# Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule.
|
# Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule.
|
||||||
$(srcdir)/getdate.c: getdate.y
|
$(srcdir)/getdate.c: getdate.y
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
############################################################
|
############################################################
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
# Makefile.b32 - Borland's C++ Compiler 5.X
|
# Makefile.b32 - Borland's C++ Compiler 5.X
|
||||||
#
|
#
|
||||||
# 'lib' directory
|
# 'lib' directory
|
||||||
@@ -14,14 +16,14 @@ RM = del
|
|||||||
LIB = tlib
|
LIB = tlib
|
||||||
TOPDIR = ..
|
TOPDIR = ..
|
||||||
CURNTDIR = .
|
CURNTDIR = .
|
||||||
CXXFLAGS = -5 -O2 -w-aus -w-ccc -w-csu -w-par -w-pia -w-rch -w-inl -w-ngu -w-pro
|
CXXFLAGS = -5 -O2 -w-aus -w-ccc -w-csu -w-par -w-pia -w-rch -w-inl -w-ngu -w-pro -tWM
|
||||||
DEFINES = -DLIBCURL_BIGENDIAN=0 -DNDEBUG -DWIN32 -DCONSOLE -DMBCS
|
DEFINES = -DLIBCURL_BIGENDIAN=0 -DNDEBUG -DWIN32 -DCONSOLE -DMBCS
|
||||||
INCDIRS = -I$(CURNTDIR);$(TOPDIR)/include/
|
INCDIRS = -I$(CURNTDIR);$(TOPDIR)/include/
|
||||||
|
|
||||||
# 'BCCDIR' has to be set up in your c:\autoexec.bat
|
# 'BCCDIR' has to be set up in your c:\autoexec.bat
|
||||||
# i.e. SET BCCDIR = c:\Borland\BCC55
|
# i.e. SET BCCDIR = c:\Borland\BCC55
|
||||||
# where c:\Borland\BCC55 is the compiler is installed
|
# where c:\Borland\BCC55 is the compiler is installed
|
||||||
LINKLIB = $(BCCDIR)/lib/psdk/wsock32.lib
|
LINKLIB = $(BCCDIR)/lib/psdk/ws2_32.lib
|
||||||
LIBCURLLIB = libcurl.lib
|
LIBCURLLIB = libcurl.lib
|
||||||
|
|
||||||
.SUFFIXES: .c
|
.SUFFIXES: .c
|
||||||
@@ -29,11 +31,12 @@ LIBCURLLIB = libcurl.lib
|
|||||||
SOURCES = \
|
SOURCES = \
|
||||||
base64.c \
|
base64.c \
|
||||||
cookie.c \
|
cookie.c \
|
||||||
download.c \
|
transfer.c \
|
||||||
escape.c \
|
escape.c \
|
||||||
formdata.c \
|
formdata.c \
|
||||||
ftp.c \
|
ftp.c \
|
||||||
http.c \
|
http.c \
|
||||||
|
http_chunks.c \
|
||||||
ldap.c \
|
ldap.c \
|
||||||
dict.c \
|
dict.c \
|
||||||
telnet.c \
|
telnet.c \
|
||||||
@@ -54,8 +57,9 @@ SOURCES = \
|
|||||||
getinfo.c \
|
getinfo.c \
|
||||||
version.c \
|
version.c \
|
||||||
easy.c \
|
easy.c \
|
||||||
highlevel.c \
|
strequal.c \
|
||||||
strequal.c
|
strtok.c \
|
||||||
|
connect.c
|
||||||
|
|
||||||
OBJECTS = $(SOURCES:.c=.obj)
|
OBJECTS = $(SOURCES:.c=.obj)
|
||||||
|
|
||||||
@@ -65,11 +69,11 @@ OBJECTS = $(SOURCES:.c=.obj)
|
|||||||
all: $(LIBCURLLIB)
|
all: $(LIBCURLLIB)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
$(RM) $(LIBCURLLIB)
|
-$(RM) $(LIBCURLLIB)
|
||||||
$(RM) *.obj
|
-$(RM) *.obj
|
||||||
|
|
||||||
$(LIBCURLLIB): $(LINKLIB) $(OBJECTS) Makefile.b32.resp
|
$(LIBCURLLIB): $(LINKLIB) $(OBJECTS) Makefile.b32.resp
|
||||||
$(RM) $(LIBCURLLIB)
|
-$(RM) $(LIBCURLLIB)
|
||||||
$(LIB) $(LIBCURLLIB) @Makefile.b32.resp
|
$(LIB) $(LIBCURLLIB) @Makefile.b32.resp
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
+base64.obj &
|
+base64.obj &
|
||||||
+cookie.obj &
|
+cookie.obj &
|
||||||
+download.obj &
|
+transfer.obj &
|
||||||
+escape.obj &
|
+escape.obj &
|
||||||
+formdata.obj &
|
+formdata.obj &
|
||||||
+ftp.obj &
|
+ftp.obj &
|
||||||
+http.obj &
|
+http.obj &
|
||||||
|
+http_chunks.obj &
|
||||||
+ldap.obj &
|
+ldap.obj &
|
||||||
+dict.obj &
|
+dict.obj &
|
||||||
+telnet.obj &
|
+telnet.obj &
|
||||||
@@ -25,5 +26,6 @@
|
|||||||
+getinfo.obj &
|
+getinfo.obj &
|
||||||
+version.obj &
|
+version.obj &
|
||||||
+easy.obj &
|
+easy.obj &
|
||||||
+highlevel.obj &
|
+strequal.obj &
|
||||||
+strequal.obj
|
+strtok.obj &
|
||||||
|
+connect.obj
|
||||||
|
|||||||
357
lib/Makefile.in
357
lib/Makefile.in
@@ -1,357 +0,0 @@
|
|||||||
# Makefile.in generated automatically by automake 1.4 from Makefile.am
|
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995-8, 1999 Free Software Foundation, Inc.
|
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
#
|
|
||||||
# $Id$
|
|
||||||
#
|
|
||||||
|
|
||||||
|
|
||||||
SHELL = @SHELL@
|
|
||||||
|
|
||||||
srcdir = @srcdir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
VPATH = @srcdir@
|
|
||||||
prefix = @prefix@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
|
|
||||||
bindir = @bindir@
|
|
||||||
sbindir = @sbindir@
|
|
||||||
libexecdir = @libexecdir@
|
|
||||||
datadir = @datadir@
|
|
||||||
sysconfdir = @sysconfdir@
|
|
||||||
sharedstatedir = @sharedstatedir@
|
|
||||||
localstatedir = @localstatedir@
|
|
||||||
libdir = @libdir@
|
|
||||||
infodir = @infodir@
|
|
||||||
mandir = @mandir@
|
|
||||||
includedir = @includedir@
|
|
||||||
oldincludedir = /usr/include
|
|
||||||
|
|
||||||
DESTDIR =
|
|
||||||
|
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
|
||||||
|
|
||||||
top_builddir = ..
|
|
||||||
|
|
||||||
ACLOCAL = @ACLOCAL@
|
|
||||||
AUTOCONF = @AUTOCONF@
|
|
||||||
AUTOMAKE = @AUTOMAKE@
|
|
||||||
AUTOHEADER = @AUTOHEADER@
|
|
||||||
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@ $(AM_INSTALL_PROGRAM_FLAGS)
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
|
||||||
transform = @program_transform_name@
|
|
||||||
|
|
||||||
NORMAL_INSTALL = :
|
|
||||||
PRE_INSTALL = :
|
|
||||||
POST_INSTALL = :
|
|
||||||
NORMAL_UNINSTALL = :
|
|
||||||
PRE_UNINSTALL = :
|
|
||||||
POST_UNINSTALL = :
|
|
||||||
host_alias = @host_alias@
|
|
||||||
host_triplet = @host@
|
|
||||||
AS = @AS@
|
|
||||||
CC = @CC@
|
|
||||||
DLLTOOL = @DLLTOOL@
|
|
||||||
LIBTOOL = @LIBTOOL@
|
|
||||||
LN_S = @LN_S@
|
|
||||||
MAKEINFO = @MAKEINFO@
|
|
||||||
NROFF = @NROFF@
|
|
||||||
OBJDUMP = @OBJDUMP@
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
PERL = @PERL@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
YACC = @YACC@
|
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign
|
|
||||||
|
|
||||||
lib_LTLIBRARIES = libcurl.la
|
|
||||||
|
|
||||||
# Some flags needed when trying to cause warnings ;-)
|
|
||||||
# CFLAGS = -DMALLOCDEBUG -g # -Wall #-pedantic
|
|
||||||
|
|
||||||
INCLUDES = -I$(top_srcdir)/include
|
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = -version-info 1:0:0
|
|
||||||
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
|
||||||
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
|
|
||||||
# 1.
|
|
||||||
#
|
|
||||||
# If either revision or age are omitted, they default to 0. Also note that age
|
|
||||||
# must be less than or equal to the current interface number.
|
|
||||||
#
|
|
||||||
# Here are a set of rules to help you update your library version information:
|
|
||||||
#
|
|
||||||
# 1.Start with version information of 0:0:0 for each libtool library.
|
|
||||||
#
|
|
||||||
# 2.Update the version information only immediately before a public release of
|
|
||||||
# your software. More frequent updates are unnecessary, and only guarantee
|
|
||||||
# that the current interface number gets larger faster.
|
|
||||||
#
|
|
||||||
# 3.If the library source code has changed at all since the last update, then
|
|
||||||
# increment revision (c:r:a becomes c:r+1:a).
|
|
||||||
#
|
|
||||||
# 4.If any interfaces have been added, removed, or changed since the last
|
|
||||||
# update, increment current, and set revision to 0.
|
|
||||||
#
|
|
||||||
# 5.If any interfaces have been added since the last public release, then
|
|
||||||
# increment age.
|
|
||||||
#
|
|
||||||
# 6.If any interfaces have been removed since the last public release, then
|
|
||||||
# set age to 0.
|
|
||||||
#
|
|
||||||
|
|
||||||
libcurl_la_SOURCES = arpa_telnet.h file.c getpass.h netrc.h timeval.c base64.c file.h hostip.c progress.c timeval.h base64.h formdata.c hostip.h progress.h cookie.c formdata.h http.c sendf.c cookie.h ftp.c http.h sendf.h url.c dict.c ftp.h if2ip.c speedcheck.c url.h dict.h getdate.c if2ip.h speedcheck.h urldata.h download.c getdate.h ldap.c ssluse.c version.c download.h getenv.c ldap.h ssluse.h escape.c getenv.h mprintf.c telnet.c escape.h getpass.c netrc.c telnet.h getinfo.c highlevel.c strequal.c strequal.h easy.c security.h security.c krb4.c memdebug.c memdebug.h
|
|
||||||
|
|
||||||
mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
|
|
||||||
CONFIG_HEADER = ../config.h ../src/config.h
|
|
||||||
CONFIG_CLEAN_FILES =
|
|
||||||
LTLIBRARIES = $(lib_LTLIBRARIES)
|
|
||||||
|
|
||||||
|
|
||||||
DEFS = @DEFS@ -I. -I$(srcdir) -I.. -I../src
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
libcurl_la_LIBADD =
|
|
||||||
libcurl_la_OBJECTS = file.lo timeval.lo base64.lo hostip.lo progress.lo \
|
|
||||||
formdata.lo cookie.lo http.lo sendf.lo ftp.lo url.lo dict.lo if2ip.lo \
|
|
||||||
speedcheck.lo getdate.lo download.lo ldap.lo ssluse.lo version.lo \
|
|
||||||
getenv.lo escape.lo mprintf.lo telnet.lo getpass.lo netrc.lo getinfo.lo \
|
|
||||||
highlevel.lo strequal.lo easy.lo security.lo krb4.lo memdebug.lo
|
|
||||||
CFLAGS = @CFLAGS@
|
|
||||||
COMPILE = $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
|
||||||
LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
|
||||||
CCLD = $(CC)
|
|
||||||
LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(LDFLAGS) -o $@
|
|
||||||
DIST_COMMON = Makefile.am Makefile.in
|
|
||||||
|
|
||||||
|
|
||||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
|
||||||
|
|
||||||
TAR = gtar
|
|
||||||
GZIP_ENV = --best
|
|
||||||
SOURCES = $(libcurl_la_SOURCES)
|
|
||||||
OBJECTS = $(libcurl_la_OBJECTS)
|
|
||||||
|
|
||||||
all: all-redirect
|
|
||||||
.SUFFIXES:
|
|
||||||
.SUFFIXES: .S .c .lo .o .s
|
|
||||||
$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4)
|
|
||||||
cd $(top_srcdir) && $(AUTOMAKE) --foreign --include-deps lib/Makefile
|
|
||||||
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
cd $(top_builddir) \
|
|
||||||
&& CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status
|
|
||||||
|
|
||||||
|
|
||||||
mostlyclean-libLTLIBRARIES:
|
|
||||||
|
|
||||||
clean-libLTLIBRARIES:
|
|
||||||
-test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
|
|
||||||
|
|
||||||
distclean-libLTLIBRARIES:
|
|
||||||
|
|
||||||
maintainer-clean-libLTLIBRARIES:
|
|
||||||
|
|
||||||
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
|
|
||||||
@$(NORMAL_INSTALL)
|
|
||||||
$(mkinstalldirs) $(DESTDIR)$(libdir)
|
|
||||||
@list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
|
||||||
if test -f $$p; then \
|
|
||||||
echo "$(LIBTOOL) --mode=install $(INSTALL) $$p $(DESTDIR)$(libdir)/$$p"; \
|
|
||||||
$(LIBTOOL) --mode=install $(INSTALL) $$p $(DESTDIR)$(libdir)/$$p; \
|
|
||||||
else :; fi; \
|
|
||||||
done
|
|
||||||
|
|
||||||
uninstall-libLTLIBRARIES:
|
|
||||||
@$(NORMAL_UNINSTALL)
|
|
||||||
list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
|
||||||
$(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.c.o:
|
|
||||||
$(COMPILE) -c $<
|
|
||||||
|
|
||||||
.s.o:
|
|
||||||
$(COMPILE) -c $<
|
|
||||||
|
|
||||||
.S.o:
|
|
||||||
$(COMPILE) -c $<
|
|
||||||
|
|
||||||
mostlyclean-compile:
|
|
||||||
-rm -f *.o core *.core
|
|
||||||
|
|
||||||
clean-compile:
|
|
||||||
|
|
||||||
distclean-compile:
|
|
||||||
-rm -f *.tab.c
|
|
||||||
|
|
||||||
maintainer-clean-compile:
|
|
||||||
|
|
||||||
.c.lo:
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
|
||||||
|
|
||||||
.s.lo:
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
|
||||||
|
|
||||||
.S.lo:
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
|
||||||
|
|
||||||
mostlyclean-libtool:
|
|
||||||
-rm -f *.lo
|
|
||||||
|
|
||||||
clean-libtool:
|
|
||||||
-rm -rf .libs _libs
|
|
||||||
|
|
||||||
distclean-libtool:
|
|
||||||
|
|
||||||
maintainer-clean-libtool:
|
|
||||||
|
|
||||||
libcurl.la: $(libcurl_la_OBJECTS) $(libcurl_la_DEPENDENCIES)
|
|
||||||
$(LINK) -rpath $(libdir) $(libcurl_la_LDFLAGS) $(libcurl_la_OBJECTS) $(libcurl_la_LIBADD) $(LIBS)
|
|
||||||
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP)
|
|
||||||
list='$(SOURCES) $(HEADERS)'; \
|
|
||||||
unique=`for i in $$list; do echo $$i; done | \
|
|
||||||
awk ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
here=`pwd` && cd $(srcdir) \
|
|
||||||
&& mkid -f$$here/ID $$unique $(LISP)
|
|
||||||
|
|
||||||
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS)'; \
|
|
||||||
unique=`for i in $$list; do echo $$i; done | \
|
|
||||||
awk ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
test -z "$(ETAGS_ARGS)$$unique$(LISP)$$tags" \
|
|
||||||
|| (cd $(srcdir) && etags $(ETAGS_ARGS) $$tags $$unique $(LISP) -o $$here/TAGS)
|
|
||||||
|
|
||||||
mostlyclean-tags:
|
|
||||||
|
|
||||||
clean-tags:
|
|
||||||
|
|
||||||
distclean-tags:
|
|
||||||
-rm -f TAGS ID
|
|
||||||
|
|
||||||
maintainer-clean-tags:
|
|
||||||
|
|
||||||
distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir)
|
|
||||||
|
|
||||||
subdir = lib
|
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
|
||||||
@for file in $(DISTFILES); do \
|
|
||||||
d=$(srcdir); \
|
|
||||||
if test -d $$d/$$file; then \
|
|
||||||
cp -pr $$/$$file $(distdir)/$$file; \
|
|
||||||
else \
|
|
||||||
test -f $(distdir)/$$file \
|
|
||||||
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
|
||||||
|| cp -p $$d/$$file $(distdir)/$$file || :; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
info-am:
|
|
||||||
info: info-am
|
|
||||||
dvi-am:
|
|
||||||
dvi: dvi-am
|
|
||||||
check-am: all-am
|
|
||||||
check: check-am
|
|
||||||
installcheck-am:
|
|
||||||
installcheck: installcheck-am
|
|
||||||
install-exec-am: install-libLTLIBRARIES
|
|
||||||
install-exec: install-exec-am
|
|
||||||
|
|
||||||
install-data-am:
|
|
||||||
install-data: install-data-am
|
|
||||||
|
|
||||||
install-am: all-am
|
|
||||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
|
||||||
install: install-am
|
|
||||||
uninstall-am: uninstall-libLTLIBRARIES
|
|
||||||
uninstall: uninstall-am
|
|
||||||
all-am: Makefile $(LTLIBRARIES)
|
|
||||||
all-redirect: all-am
|
|
||||||
install-strip:
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) AM_INSTALL_PROGRAM_FLAGS=-s install
|
|
||||||
installdirs:
|
|
||||||
$(mkinstalldirs) $(DESTDIR)$(libdir)
|
|
||||||
|
|
||||||
|
|
||||||
mostlyclean-generic:
|
|
||||||
|
|
||||||
clean-generic:
|
|
||||||
|
|
||||||
distclean-generic:
|
|
||||||
-rm -f Makefile $(CONFIG_CLEAN_FILES)
|
|
||||||
-rm -f config.cache config.log stamp-h stamp-h[0-9]*
|
|
||||||
|
|
||||||
maintainer-clean-generic:
|
|
||||||
mostlyclean-am: mostlyclean-libLTLIBRARIES mostlyclean-compile \
|
|
||||||
mostlyclean-libtool mostlyclean-tags \
|
|
||||||
mostlyclean-generic
|
|
||||||
|
|
||||||
mostlyclean: mostlyclean-am
|
|
||||||
|
|
||||||
clean-am: clean-libLTLIBRARIES clean-compile clean-libtool clean-tags \
|
|
||||||
clean-generic mostlyclean-am
|
|
||||||
|
|
||||||
clean: clean-am
|
|
||||||
|
|
||||||
distclean-am: distclean-libLTLIBRARIES distclean-compile \
|
|
||||||
distclean-libtool distclean-tags distclean-generic \
|
|
||||||
clean-am
|
|
||||||
-rm -f libtool
|
|
||||||
|
|
||||||
distclean: distclean-am
|
|
||||||
|
|
||||||
maintainer-clean-am: maintainer-clean-libLTLIBRARIES \
|
|
||||||
maintainer-clean-compile maintainer-clean-libtool \
|
|
||||||
maintainer-clean-tags maintainer-clean-generic \
|
|
||||||
distclean-am
|
|
||||||
@echo "This command is intended for maintainers to use;"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-am
|
|
||||||
|
|
||||||
.PHONY: mostlyclean-libLTLIBRARIES distclean-libLTLIBRARIES \
|
|
||||||
clean-libLTLIBRARIES maintainer-clean-libLTLIBRARIES \
|
|
||||||
uninstall-libLTLIBRARIES install-libLTLIBRARIES mostlyclean-compile \
|
|
||||||
distclean-compile clean-compile maintainer-clean-compile \
|
|
||||||
mostlyclean-libtool distclean-libtool clean-libtool \
|
|
||||||
maintainer-clean-libtool tags mostlyclean-tags distclean-tags \
|
|
||||||
clean-tags maintainer-clean-tags distdir info-am info dvi-am dvi check \
|
|
||||||
check-am installcheck-am installcheck install-exec-am install-exec \
|
|
||||||
install-data-am install-data install-am install uninstall-am uninstall \
|
|
||||||
all-redirect all-am all installdirs mostlyclean-generic \
|
|
||||||
distclean-generic clean-generic maintainer-clean-generic clean \
|
|
||||||
mostlyclean distclean maintainer-clean
|
|
||||||
|
|
||||||
|
|
||||||
# Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule.
|
|
||||||
$(srcdir)/getdate.c: getdate.y
|
|
||||||
cd $(srcdir) && \
|
|
||||||
$(YACC) $(YFLAGS) getdate.y; \
|
|
||||||
mv -f y.tab.c getdate.c
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
#############################################################
|
#############################################################
|
||||||
|
#
|
||||||
## Makefile for building libcurl.a with MingW32 (GCC-2.95) and
|
## Makefile for building libcurl.a with MingW32 (GCC-2.95) and
|
||||||
## optionally OpenSSL (0.9.6)
|
## optionally OpenSSL (0.9.6)
|
||||||
## Use: make -f Makefile.m32
|
## Use: make -f Makefile.m32
|
||||||
@@ -10,7 +11,7 @@ CC = gcc
|
|||||||
AR = ar
|
AR = ar
|
||||||
RANLIB = ranlib
|
RANLIB = ranlib
|
||||||
STRIP = strip -g
|
STRIP = strip -g
|
||||||
OPENSSL_PATH = ../../openssl-0.9.6
|
OPENSSL_PATH = ../../openssl-0.9.6b
|
||||||
|
|
||||||
########################################################
|
########################################################
|
||||||
## Nothing more to do below this line!
|
## Nothing more to do below this line!
|
||||||
@@ -30,16 +31,18 @@ libcurl_a_SOURCES = arpa_telnet.h file.c getpass.h netrc.h timeval.c base64.c \
|
|||||||
file.h hostip.c progress.c timeval.h base64.h formdata.c hostip.h progress.h \
|
file.h hostip.c progress.c timeval.h base64.h formdata.c hostip.h progress.h \
|
||||||
cookie.c formdata.h http.c sendf.c cookie.h ftp.c http.h sendf.h url.c dict.c \
|
cookie.c formdata.h http.c sendf.c cookie.h ftp.c http.h sendf.h url.c dict.c \
|
||||||
ftp.h if2ip.c speedcheck.c url.h dict.h getdate.c if2ip.h speedcheck.h \
|
ftp.h if2ip.c speedcheck.c url.h dict.h getdate.c if2ip.h speedcheck.h \
|
||||||
urldata.h download.c getdate.h ldap.c ssluse.c version.c download.h getenv.c \
|
urldata.h transfer.c getdate.h ldap.c ssluse.c version.c transfer.h getenv.c \
|
||||||
ldap.h ssluse.h escape.c getenv.h mprintf.c telnet.c escape.h getpass.c netrc.c \
|
ldap.h ssluse.h escape.c getenv.h mprintf.c telnet.c escape.h getpass.c netrc.c \
|
||||||
telnet.h getinfo.c highlevel.c strequal.c strequal.h easy.c security.h \
|
telnet.h getinfo.c strequal.c strequal.h easy.c security.h \
|
||||||
security.c krb4.c
|
security.c krb4.h krb4.c memdebug.h memdebug.c inet_ntoa_r.h http_chunks.h http_chunks.c \
|
||||||
|
strtok.c connect.c
|
||||||
|
|
||||||
libcurl_a_OBJECTS = file.o timeval.o base64.o hostip.o progress.o \
|
libcurl_a_OBJECTS = file.o timeval.o base64.o hostip.o progress.o \
|
||||||
formdata.o cookie.o http.o sendf.o ftp.o url.o dict.o if2ip.o \
|
formdata.o cookie.o http.o sendf.o ftp.o url.o dict.o if2ip.o \
|
||||||
speedcheck.o getdate.o download.o ldap.o ssluse.o version.o \
|
speedcheck.o getdate.o transfer.o ldap.o ssluse.o version.o \
|
||||||
getenv.o escape.o mprintf.o telnet.o getpass.o netrc.o getinfo.o \
|
getenv.o escape.o mprintf.o telnet.o getpass.o netrc.o getinfo.o \
|
||||||
highlevel.o strequal.o easy.o security.o krb4.o
|
strequal.o easy.o security.o krb4.o memdebug.o http_chunks.o \
|
||||||
|
strtok.o connect.o
|
||||||
|
|
||||||
LIBRARIES = $(libcurl_a_LIBRARIES)
|
LIBRARIES = $(libcurl_a_LIBRARIES)
|
||||||
SOURCES = $(libcurl_a_SOURCES)
|
SOURCES = $(libcurl_a_SOURCES)
|
||||||
@@ -58,7 +61,7 @@ libcurl.a: $(libcurl_a_OBJECTS) $(libcurl_a_DEPENDENCIES)
|
|||||||
|
|
||||||
libcurl.dll libcurldll.a: libcurl.a libcurl.def dllinit.o
|
libcurl.dll libcurldll.a: libcurl.a libcurl.def dllinit.o
|
||||||
-@erase $@
|
-@erase $@
|
||||||
dllwrap --dllname $@ --output-lib libcurldll.a --export-all --def libcurl.def $(libcurl_a_LIBRARIES) dllinit.o -L$(OPENSSL_PATH)/out $(DLL_LIBS) -lwsock32
|
dllwrap --dllname $@ --output-lib libcurldll.a --export-all --def libcurl.def $(libcurl_a_LIBRARIES) dllinit.o -L$(OPENSSL_PATH)/out $(DLL_LIBS) -lwsock32 -lws2_32
|
||||||
$(STRIP) $@
|
$(STRIP) $@
|
||||||
|
|
||||||
# remove the last line above to keep debug info
|
# remove the last line above to keep debug info
|
||||||
|
|||||||
532
lib/Makefile.vc6
532
lib/Makefile.vc6
@@ -1,357 +1,219 @@
|
|||||||
#############################################################
|
#############################################################
|
||||||
## Makefile for building libcurl.lib with MSVC6
|
#
|
||||||
## Use: nmake -f makefile.vc6 [release | release-ssl | debug]
|
# Makefile for building libcurl with MSVC6
|
||||||
## (default is release)
|
#
|
||||||
##
|
# Usage: see usage message below
|
||||||
## Comments to: Troy Engel <tengel@sonic.net>
|
# Should be invoked from \lib directory
|
||||||
## Updated by: Craig Davison <cd@securityfocus.com>
|
# Edit the paths and desired library name
|
||||||
|
# SSL path is only required if you intend compiling
|
||||||
|
# with SSL.
|
||||||
|
#
|
||||||
|
# This make file leaves the result either a .lib or .dll file
|
||||||
|
# in the \lib directory. It should be called from the \lib
|
||||||
|
# directory.
|
||||||
|
#
|
||||||
|
# An option would have been to allow the source directory to
|
||||||
|
# be specified, but I saw no requirement.
|
||||||
|
#
|
||||||
|
# Another option would have been to leave the .lib and .dll
|
||||||
|
# files in the "cfg" directory, but then the make file
|
||||||
|
# in \src would need to be changed.
|
||||||
|
#
|
||||||
|
##############################################################
|
||||||
|
# CHANGE LOG
|
||||||
|
# ------------------------------------------------------------
|
||||||
|
# 05.11.2001 John Lask Initial Release
|
||||||
|
#
|
||||||
|
#
|
||||||
|
##############################################################
|
||||||
|
|
||||||
PROGRAM_NAME = libcurl.lib
|
LIB_NAME = libcurl
|
||||||
PROGRAM_NAME_DEBUG = libcurld.lib
|
LIB_NAME_DEBUG = libcurld
|
||||||
OPENSSL_PATH = ../../openssl-0.9.6
|
OPENSSL_PATH = ../../openssl-0.9.6
|
||||||
|
|
||||||
########################################################
|
#############################################################
|
||||||
## Nothing more to do below this line!
|
## Nothing more to do below this line!
|
||||||
|
|
||||||
## Release
|
CCNODBG = cl.exe /MD /O2 /D "NDEBUG"
|
||||||
CCR = cl.exe /MD /O2 /D "NDEBUG"
|
CCDEBUG = cl.exe /MDd /Od /Gm /Zi /D "_DEBUG" /GZ
|
||||||
LINKR = link.exe -lib /out:$(PROGRAM_NAME)
|
CFLAGSSSL = /D "USE_SSLEAY" /I "$(OPENSSL_PATH)/inc32" /I "$(OPENSSL_PATH)/inc32/openssl"
|
||||||
|
|
||||||
## Debug
|
|
||||||
CCD = cl.exe /MDd /Gm /ZI /Od /D "_DEBUG" /GZ
|
|
||||||
LINKD = link.exe -lib /out:$(PROGRAM_NAME_DEBUG)
|
|
||||||
|
|
||||||
## SSL Release
|
|
||||||
CCRS = cl.exe /MD /O2 /D "NDEBUG" /D "USE_SSLEAY" /I "$(OPENSSL_PATH)/include" /I "$(OPENSSL_PATH)/include/openssl"
|
|
||||||
LINKRS = link.exe -lib /out:$(PROGRAM_NAME) /LIBPATH:$(OPENSSL_PATH)/out32dll
|
|
||||||
|
|
||||||
CFLAGS = /I "../include" /nologo /W3 /GX /D "WIN32" /D "VC6" /D "_MBCS" /D "_LIB" /YX /FD /c /D "MSDOS"
|
CFLAGS = /I "../include" /nologo /W3 /GX /D "WIN32" /D "VC6" /D "_MBCS" /D "_LIB" /YX /FD /c /D "MSDOS"
|
||||||
LFLAGS = /nologo
|
|
||||||
LINKLIBS = wsock32.lib
|
|
||||||
LINKSLIBS = libeay32.lib ssleay32.lib RSAglue.lib
|
|
||||||
|
|
||||||
RELEASE_OBJS= \
|
LNKDLL = link.exe /DLL /def:libcurl.def
|
||||||
base64r.obj \
|
LNKLIB = link.exe -lib
|
||||||
cookier.obj \
|
LFLAGS = /nologo
|
||||||
downloadr.obj \
|
LFLAGSSSL = /LIBPATH:$(OPENSSL_PATH)/out32dll
|
||||||
escaper.obj \
|
LINKLIBS = ws2_32.lib
|
||||||
formdatar.obj \
|
SSLLIBS = libeay32.lib ssleay32.lib RSAglue.lib
|
||||||
ftpr.obj \
|
CFGSET = FALSE
|
||||||
httpr.obj \
|
|
||||||
ldapr.obj \
|
|
||||||
dictr.obj \
|
|
||||||
telnetr.obj \
|
|
||||||
getdater.obj \
|
|
||||||
getenvr.obj \
|
|
||||||
getpassr.obj \
|
|
||||||
hostipr.obj \
|
|
||||||
if2ipr.obj \
|
|
||||||
mprintfr.obj \
|
|
||||||
netrcr.obj \
|
|
||||||
progressr.obj \
|
|
||||||
sendfr.obj \
|
|
||||||
speedcheckr.obj \
|
|
||||||
ssluser.obj \
|
|
||||||
timevalr.obj \
|
|
||||||
urlr.obj \
|
|
||||||
filer.obj \
|
|
||||||
getinfor.obj \
|
|
||||||
versionr.obj \
|
|
||||||
easyr.obj \
|
|
||||||
highlevelr.obj \
|
|
||||||
strequalr.obj
|
|
||||||
|
|
||||||
DEBUG_OBJS= \
|
######################
|
||||||
base64d.obj \
|
# release
|
||||||
cookied.obj \
|
|
||||||
downloadd.obj \
|
|
||||||
escaped.obj \
|
|
||||||
formdatad.obj \
|
|
||||||
ftpd.obj \
|
|
||||||
httpd.obj \
|
|
||||||
ldapd.obj \
|
|
||||||
dictd.obj \
|
|
||||||
telnetd.obj \
|
|
||||||
getdated.obj \
|
|
||||||
getenvd.obj \
|
|
||||||
getpassd.obj \
|
|
||||||
hostipd.obj \
|
|
||||||
if2ipd.obj \
|
|
||||||
mprintfd.obj \
|
|
||||||
netrcd.obj \
|
|
||||||
progressd.obj \
|
|
||||||
sendfd.obj \
|
|
||||||
speedcheckd.obj \
|
|
||||||
sslused.obj \
|
|
||||||
timevald.obj \
|
|
||||||
urld.obj \
|
|
||||||
filed.obj \
|
|
||||||
getinfod.obj \
|
|
||||||
versiond.obj \
|
|
||||||
easyd.obj \
|
|
||||||
highleveld.obj \
|
|
||||||
strequald.obj
|
|
||||||
|
|
||||||
RELEASE_SSL_OBJS= \
|
!IF "$(CFG)" == "release"
|
||||||
base64rs.obj \
|
TARGET =$(LIB_NAME).lib
|
||||||
cookiers.obj \
|
DIROBJ =.\$(CFG)
|
||||||
downloadrs.obj \
|
LNK = $(LNKLIB) /out:$(TARGET)
|
||||||
escapers.obj \
|
CC = $(CCNODBG)
|
||||||
formdatars.obj \
|
CFGSET = TRUE
|
||||||
ftprs.obj \
|
!ENDIF
|
||||||
httprs.obj \
|
|
||||||
ldaprs.obj \
|
|
||||||
dictrs.obj \
|
|
||||||
telnetrs.obj \
|
|
||||||
getdaters.obj \
|
|
||||||
getenvrs.obj \
|
|
||||||
getpassrs.obj \
|
|
||||||
hostiprs.obj \
|
|
||||||
if2iprs.obj \
|
|
||||||
mprintfrs.obj \
|
|
||||||
netrcrs.obj \
|
|
||||||
progressrs.obj \
|
|
||||||
sendfrs.obj \
|
|
||||||
speedcheckrs.obj \
|
|
||||||
sslusers.obj \
|
|
||||||
timevalrs.obj \
|
|
||||||
urlrs.obj \
|
|
||||||
filers.obj \
|
|
||||||
getinfors.obj \
|
|
||||||
versionrs.obj \
|
|
||||||
easyrs.obj \
|
|
||||||
highlevelrs.obj \
|
|
||||||
strequalrs.obj
|
|
||||||
|
|
||||||
LINK_OBJS= \
|
######################
|
||||||
base64.obj \
|
# release-dll
|
||||||
cookie.obj \
|
|
||||||
download.obj \
|
|
||||||
escape.obj \
|
|
||||||
formdata.obj \
|
|
||||||
ftp.obj \
|
|
||||||
http.obj \
|
|
||||||
ldap.obj \
|
|
||||||
dict.obj \
|
|
||||||
telnet.obj \
|
|
||||||
getdate.obj \
|
|
||||||
getenv.obj \
|
|
||||||
getpass.obj \
|
|
||||||
hostip.obj \
|
|
||||||
if2ip.obj \
|
|
||||||
mprintf.obj \
|
|
||||||
netrc.obj \
|
|
||||||
progress.obj \
|
|
||||||
sendf.obj \
|
|
||||||
speedcheck.obj \
|
|
||||||
ssluse.obj \
|
|
||||||
timeval.obj \
|
|
||||||
url.obj \
|
|
||||||
file.obj \
|
|
||||||
getinfo.obj \
|
|
||||||
version.obj \
|
|
||||||
easy.obj \
|
|
||||||
highlevel.obj \
|
|
||||||
strequal.obj
|
|
||||||
|
|
||||||
all : release
|
!IF "$(CFG)" == "release-dll"
|
||||||
|
TARGET =$(LIB_NAME).dll
|
||||||
|
DIROBJ =.\$(CFG)
|
||||||
|
LNK = $(LNKDLL) /out:$(TARGET) /IMPLIB:"$(LIB_NAME).lib"
|
||||||
|
CC = $(CCNODBG)
|
||||||
|
CFGSET = TRUE
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
release: $(RELEASE_OBJS)
|
######################
|
||||||
$(LINKR) $(LFLAGS) $(LINKLIBS) $(LINK_OBJS)
|
# release-ssl
|
||||||
|
|
||||||
debug: $(DEBUG_OBJS)
|
!IF "$(CFG)" == "release-ssl"
|
||||||
$(LINKD) $(LFLAGS) $(LINKLIBS) $(LINK_OBJS)
|
TARGET =$(LIB_NAME).lib
|
||||||
|
DIROBJ =.\$(CFG)
|
||||||
|
LNK = $(LNKLIB) $(LFLAGSSSL) /out:$(TARGET)
|
||||||
|
LINKLIBS = $(LINKLIBS) $(SSLLIBS)
|
||||||
|
CC = $(CCNODBG) $(CFLAGSSSL)
|
||||||
|
CFGSET = TRUE
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
release-ssl: $(RELEASE_SSL_OBJS)
|
######################
|
||||||
$(LINKRS) $(LFLAGS) $(LINKLIBS) $(LINKSLIBS) $(LINK_OBJS)
|
# release-ssl-dll
|
||||||
|
|
||||||
## Release
|
!IF "$(CFG)" == "release-ssl-dll"
|
||||||
base64r.obj: base64.c
|
TARGET =$(LIB_NAME).dll
|
||||||
$(CCR) $(CFLAGS) base64.c
|
DIROBJ =.\$(CFG)
|
||||||
cookier.obj: cookie.c
|
LNK = $(LNKDLL) $(LFLAGSSSL) /out:$(TARGET) /IMPLIB:"$(LIB_NAME).lib"
|
||||||
$(CCR) $(CFLAGS) cookie.c
|
LINKLIBS = $(LINKLIBS) $(SSLLIBS)
|
||||||
downloadr.obj: download.c
|
CC = $(CCNODBG) $(CFLAGSSSL)
|
||||||
$(CCR) $(CFLAGS) download.c
|
CFGSET = TRUE
|
||||||
escaper.obj: escape.c
|
!ENDIF
|
||||||
$(CCR) $(CFLAGS) escape.c
|
|
||||||
formdatar.obj: formdata.c
|
|
||||||
$(CCR) $(CFLAGS) formdata.c
|
|
||||||
ftpr.obj: ftp.c
|
|
||||||
$(CCR) $(CFLAGS) ftp.c
|
|
||||||
httpr.obj: http.c
|
|
||||||
$(CCR) $(CFLAGS) http.c
|
|
||||||
ldapr.obj: ldap.c
|
|
||||||
$(CCR) $(CFLAGS) ldap.c
|
|
||||||
dictr.obj: dict.c
|
|
||||||
$(CCR) $(CFLAGS) dict.c
|
|
||||||
telnetr.obj: telnet.c
|
|
||||||
$(CCR) $(CFLAGS) telnet.c
|
|
||||||
getdater.obj: getdate.c
|
|
||||||
$(CCR) $(CFLAGS) getdate.c
|
|
||||||
getenvr.obj: getenv.c
|
|
||||||
$(CCR) $(CFLAGS) getenv.c
|
|
||||||
getpassr.obj: getpass.c
|
|
||||||
$(CCR) $(CFLAGS) getpass.c
|
|
||||||
hostipr.obj: hostip.c
|
|
||||||
$(CCR) $(CFLAGS) hostip.c
|
|
||||||
if2ipr.obj: if2ip.c
|
|
||||||
$(CCR) $(CFLAGS) if2ip.c
|
|
||||||
mprintfr.obj: mprintf.c
|
|
||||||
$(CCR) $(CFLAGS) mprintf.c
|
|
||||||
netrcr.obj: netrc.c
|
|
||||||
$(CCR) $(CFLAGS) netrc.c
|
|
||||||
progressr.obj: progress.c
|
|
||||||
$(CCR) $(CFLAGS) progress.c
|
|
||||||
sendfr.obj: sendf.c
|
|
||||||
$(CCR) $(CFLAGS) sendf.c
|
|
||||||
speedcheckr.obj: speedcheck.c
|
|
||||||
$(CCR) $(CFLAGS) speedcheck.c
|
|
||||||
ssluser.obj: ssluse.c
|
|
||||||
$(CCR) $(CFLAGS) ssluse.c
|
|
||||||
timevalr.obj: timeval.c
|
|
||||||
$(CCR) $(CFLAGS) timeval.c
|
|
||||||
urlr.obj: url.c
|
|
||||||
$(CCR) $(CFLAGS) url.c
|
|
||||||
filer.obj: file.c
|
|
||||||
$(CCR) $(CFLAGS) file.c
|
|
||||||
getinfor.obj: getinfo.c
|
|
||||||
$(CCR) $(CFLAGS) getinfo.c
|
|
||||||
versionr.obj: version.c
|
|
||||||
$(CCR) $(CFLAGS) version.c
|
|
||||||
easyr.obj: easy.c
|
|
||||||
$(CCR) $(CFLAGS) easy.c
|
|
||||||
highlevelr.obj: highlevel.c
|
|
||||||
$(CCR) $(CFLAGS) highlevel.c
|
|
||||||
strequalr.obj: strequal.c
|
|
||||||
$(CCR) $(CFLAGS) strequal.c
|
|
||||||
|
|
||||||
## Debug
|
|
||||||
base64d.obj: base64.c
|
|
||||||
$(CCD) $(CFLAGS) base64.c
|
|
||||||
cookied.obj: cookie.c
|
|
||||||
$(CCD) $(CFLAGS) cookie.c
|
|
||||||
downloadd.obj: download.c
|
|
||||||
$(CCD) $(CFLAGS) download.c
|
|
||||||
escaped.obj: escape.c
|
|
||||||
$(CCD) $(CFLAGS) escape.c
|
|
||||||
formdatad.obj: formdata.c
|
|
||||||
$(CCD) $(CFLAGS) formdata.c
|
|
||||||
ftpd.obj: ftp.c
|
|
||||||
$(CCD) $(CFLAGS) ftp.c
|
|
||||||
httpd.obj: http.c
|
|
||||||
$(CCD) $(CFLAGS) http.c
|
|
||||||
ldapd.obj: ldap.c
|
|
||||||
$(CCD) $(CFLAGS) ldap.c
|
|
||||||
dictd.obj: dict.c
|
|
||||||
$(CCD) $(CFLAGS) dict.c
|
|
||||||
telnetd.obj: telnet.c
|
|
||||||
$(CCD) $(CFLAGS) telnet.c
|
|
||||||
getdated.obj: getdate.c
|
|
||||||
$(CCD) $(CFLAGS) getdate.c
|
|
||||||
getenvd.obj: getenv.c
|
|
||||||
$(CCD) $(CFLAGS) getenv.c
|
|
||||||
getpassd.obj: getpass.c
|
|
||||||
$(CCD) $(CFLAGS) getpass.c
|
|
||||||
hostipd.obj: hostip.c
|
|
||||||
$(CCD) $(CFLAGS) hostip.c
|
|
||||||
if2ipd.obj: if2ip.c
|
|
||||||
$(CCD) $(CFLAGS) if2ip.c
|
|
||||||
mprintfd.obj: mprintf.c
|
|
||||||
$(CCD) $(CFLAGS) mprintf.c
|
|
||||||
netrcd.obj: netrc.c
|
|
||||||
$(CCD) $(CFLAGS) netrc.c
|
|
||||||
progressd.obj: progress.c
|
|
||||||
$(CCD) $(CFLAGS) progress.c
|
|
||||||
sendfd.obj: sendf.c
|
|
||||||
$(CCD) $(CFLAGS) sendf.c
|
|
||||||
speedcheckd.obj: speedcheck.c
|
|
||||||
$(CCD) $(CFLAGS) speedcheck.c
|
|
||||||
sslused.obj: ssluse.c
|
|
||||||
$(CCD) $(CFLAGS) ssluse.c
|
|
||||||
timevald.obj: timeval.c
|
|
||||||
$(CCD) $(CFLAGS) timeval.c
|
|
||||||
urld.obj: url.c
|
|
||||||
$(CCD) $(CFLAGS) url.c
|
|
||||||
filed.obj: file.c
|
|
||||||
$(CCD) $(CFLAGS) file.c
|
|
||||||
getinfod.obj: getinfo.c
|
|
||||||
$(CCD) $(CFLAGS) getinfo.c
|
|
||||||
versiond.obj: version.c
|
|
||||||
$(CCD) $(CFLAGS) version.c
|
|
||||||
easyd.obj: easy.c
|
|
||||||
$(CCD) $(CFLAGS) easy.c
|
|
||||||
highleveld.obj: highlevel.c
|
|
||||||
$(CCD) $(CFLAGS) highlevel.c
|
|
||||||
strequald.obj: strequal.c
|
|
||||||
$(CCD) $(CFLAGS) strequal.c
|
|
||||||
|
|
||||||
|
|
||||||
## Release SSL
|
|
||||||
base64rs.obj: base64.c
|
|
||||||
$(CCRS) $(CFLAGS) base64.c
|
|
||||||
cookiers.obj: cookie.c
|
|
||||||
$(CCRS) $(CFLAGS) cookie.c
|
|
||||||
downloadrs.obj: download.c
|
|
||||||
$(CCRS) $(CFLAGS) download.c
|
|
||||||
escapers.obj: escape.c
|
|
||||||
$(CCRS) $(CFLAGS) escape.c
|
|
||||||
formdatars.obj: formdata.c
|
|
||||||
$(CCRS) $(CFLAGS) formdata.c
|
|
||||||
ftprs.obj: ftp.c
|
|
||||||
$(CCRS) $(CFLAGS) ftp.c
|
|
||||||
httprs.obj: http.c
|
|
||||||
$(CCRS) $(CFLAGS) http.c
|
|
||||||
ldaprs.obj: ldap.c
|
|
||||||
$(CCRS) $(CFLAGS) ldap.c
|
|
||||||
dictrs.obj: dict.c
|
|
||||||
$(CCRS) $(CFLAGS) dict.c
|
|
||||||
telnetrs.obj: telnet.c
|
|
||||||
$(CCRS) $(CFLAGS) telnet.c
|
|
||||||
getdaters.obj: getdate.c
|
|
||||||
$(CCRS) $(CFLAGS) getdate.c
|
|
||||||
getenvrs.obj: getenv.c
|
|
||||||
$(CCRS) $(CFLAGS) getenv.c
|
|
||||||
getpassrs.obj: getpass.c
|
|
||||||
$(CCRS) $(CFLAGS) getpass.c
|
|
||||||
hostiprs.obj: hostip.c
|
|
||||||
$(CCRS) $(CFLAGS) hostip.c
|
|
||||||
if2iprs.obj: if2ip.c
|
|
||||||
$(CCRS) $(CFLAGS) if2ip.c
|
|
||||||
mprintfrs.obj: mprintf.c
|
|
||||||
$(CCRS) $(CFLAGS) mprintf.c
|
|
||||||
netrcrs.obj: netrc.c
|
|
||||||
$(CCRS) $(CFLAGS) netrc.c
|
|
||||||
progressrs.obj: progress.c
|
|
||||||
$(CCRS) $(CFLAGS) progress.c
|
|
||||||
sendfrs.obj: sendf.c
|
|
||||||
$(CCRS) $(CFLAGS) sendf.c
|
|
||||||
speedcheckrs.obj: speedcheck.c
|
|
||||||
$(CCRS) $(CFLAGS) speedcheck.c
|
|
||||||
sslusers.obj: ssluse.c
|
|
||||||
$(CCRS) $(CFLAGS) ssluse.c
|
|
||||||
timevalrs.obj: timeval.c
|
|
||||||
$(CCRS) $(CFLAGS) timeval.c
|
|
||||||
urlrs.obj: url.c
|
|
||||||
$(CCRS) $(CFLAGS) url.c
|
|
||||||
filers.obj: file.c
|
|
||||||
$(CCRS) $(CFLAGS) file.c
|
|
||||||
getinfors.obj: getinfo.c
|
|
||||||
$(CCRS) $(CFLAGS) getinfo.c
|
|
||||||
versionrs.obj: version.c
|
|
||||||
$(CCRS) $(CFLAGS) version.c
|
|
||||||
easyrs.obj: easy.c
|
|
||||||
$(CCRS) $(CFLAGS) easy.c
|
|
||||||
highlevelrs.obj: highlevel.c
|
|
||||||
$(CCRS) $(CFLAGS) highlevel.c
|
|
||||||
strequalrs.obj: strequal.c
|
|
||||||
$(CCRS) $(CFLAGS) strequal.c
|
|
||||||
|
|
||||||
|
|
||||||
|
######################
|
||||||
|
# debug
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "debug"
|
||||||
|
TARGET =$(LIB_NAME_DEBUG).lib
|
||||||
|
DIROBJ =.\$(CFG)
|
||||||
|
LNK = $(LNKLIB) /out:$(TARGET)
|
||||||
|
CC = $(CCDEBUG)
|
||||||
|
CFGSET = TRUE
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
######################
|
||||||
|
# debug-dll
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "debug-dll"
|
||||||
|
TARGET =$(LIB_NAME_DEBUG).dll
|
||||||
|
DIROBJ =.\$(CFG)
|
||||||
|
LNK = $(LNKDLL) /out:$(TARGET) /IMPLIB:"$(LIB_NAME_DEBUG).lib"
|
||||||
|
CC = $(CCDEBUG)
|
||||||
|
CFGSET = TRUE
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
######################
|
||||||
|
# debug-ssl
|
||||||
|
#todo
|
||||||
|
!IF "$(CFG)" == "debug-ssl"
|
||||||
|
TARGET = $(LIB_NAME_DEBUG).lib
|
||||||
|
DIROBJ =.\$(CFG)
|
||||||
|
LNK = $(LNKLIB) $(LFLAGSSSL) /out:$(TARGET)
|
||||||
|
LINKLIBS = $(LINKLIBS) $(SSLLIBS)
|
||||||
|
CC = $(CCDEBUG) $(CFLAGSSSL)
|
||||||
|
CFGSET = TRUE
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
######################
|
||||||
|
# debug-ssl-dll
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "debug-ssl-dll"
|
||||||
|
TARGET =$(LIB_NAME_DEBUG).dll
|
||||||
|
DIROBJ =.\$(CFG)
|
||||||
|
LNK = $(LNKDLL) $(LFLAGSSSL) /out:$(TARGET) /IMPLIB:"$(LIB_NAME_DEBUG).lib"
|
||||||
|
LINKLIBS = $(LINKLIBS) $(SSLLIBS)
|
||||||
|
CC = $(CCDEBUG) $(CFLAGSSSL)
|
||||||
|
CFGSET = TRUE
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
#######################
|
||||||
|
# Usage
|
||||||
|
#
|
||||||
|
!IF "$(CFGSET)" == "FALSE"
|
||||||
|
!MESSAGE Usage: nmake -f makefile.vc6 CFG=<config> <target>
|
||||||
|
!MESSAGE where <config> is one of:
|
||||||
|
!MESSAGE release - release static library
|
||||||
|
!MESSAGE release-dll - release dll
|
||||||
|
!MESSAGE release-ssl - release static library with ssl
|
||||||
|
!MESSAGE release-ssl-dll - release dll library with ssl
|
||||||
|
!MESSAGE debug - debug static library
|
||||||
|
!MESSAGE debug-dll - debug dll
|
||||||
|
!MESSAGE debug-ssl - debug static library with ssl
|
||||||
|
!MESSAGE debug-ssl-dll - debug dll library with ssl
|
||||||
|
!MESSAGE <target> can be left blank in which case all is assumed
|
||||||
|
!ERROR please choose a valid configuration "$(CFG)"
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
#######################
|
||||||
|
#
|
||||||
|
X_OBJS= \
|
||||||
|
$(DIROBJ)\base64.obj \
|
||||||
|
$(DIROBJ)\cookie.obj \
|
||||||
|
$(DIROBJ)\transfer.obj \
|
||||||
|
$(DIROBJ)\escape.obj \
|
||||||
|
$(DIROBJ)\formdata.obj \
|
||||||
|
$(DIROBJ)\ftp.obj \
|
||||||
|
$(DIROBJ)\http.obj \
|
||||||
|
$(DIROBJ)\http_chunks.obj \
|
||||||
|
$(DIROBJ)\ldap.obj \
|
||||||
|
$(DIROBJ)\dict.obj \
|
||||||
|
$(DIROBJ)\telnet.obj \
|
||||||
|
$(DIROBJ)\getdate.obj \
|
||||||
|
$(DIROBJ)\getenv.obj \
|
||||||
|
$(DIROBJ)\getpass.obj \
|
||||||
|
$(DIROBJ)\hostip.obj \
|
||||||
|
$(DIROBJ)\if2ip.obj \
|
||||||
|
$(DIROBJ)\mprintf.obj \
|
||||||
|
$(DIROBJ)\netrc.obj \
|
||||||
|
$(DIROBJ)\progress.obj \
|
||||||
|
$(DIROBJ)\sendf.obj \
|
||||||
|
$(DIROBJ)\speedcheck.obj \
|
||||||
|
$(DIROBJ)\ssluse.obj \
|
||||||
|
$(DIROBJ)\timeval.obj \
|
||||||
|
$(DIROBJ)\url.obj \
|
||||||
|
$(DIROBJ)\file.obj \
|
||||||
|
$(DIROBJ)\getinfo.obj \
|
||||||
|
$(DIROBJ)\version.obj \
|
||||||
|
$(DIROBJ)\easy.obj \
|
||||||
|
$(DIROBJ)\strequal.obj \
|
||||||
|
$(DIROBJ)\strtok.obj \
|
||||||
|
$(DIROBJ)\connect.obj \
|
||||||
|
$(DIROBJ)\hash.obj \
|
||||||
|
$(DIROBJ)\llist.obj
|
||||||
|
|
||||||
|
all : $(TARGET)
|
||||||
|
|
||||||
|
|
||||||
|
$(TARGET): $(X_OBJS)
|
||||||
|
$(LNK) $(LFLAGS) $(LINKLIBS) $(X_OBJS)
|
||||||
|
|
||||||
|
$(X_OBJS): $(DIROBJ)
|
||||||
|
|
||||||
|
$(DIROBJ):
|
||||||
|
@if not exist "$(DIROBJ)" mkdir $(DIROBJ)
|
||||||
|
|
||||||
|
.SUFFIXES: .c .obj
|
||||||
|
|
||||||
|
{.\}.c{$(DIROBJ)\}.obj:
|
||||||
|
$(CC) $(CFLAGS) /Fo"$@" $<
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
-@erase *.obj
|
-@erase $(DIROBJ)\*.obj
|
||||||
-@erase vc60.idb
|
-@erase vc60.idb
|
||||||
-@erase vc60.pch
|
-@erase vc60.pch
|
||||||
|
|
||||||
distrib: clean
|
|
||||||
-@erase $(PROGRAM_NAME)
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,319 +1,101 @@
|
|||||||
/*
|
#ifndef __ARPA_TELNET_H
|
||||||
* Copyright (c) 1983, 1993
|
#define __ARPA_TELNET_H
|
||||||
* The Regents of the University of California. All rights reserved.
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
* 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. All advertising materials mentioning features or use of this software
|
|
||||||
* must display the following acknowledgement:
|
|
||||||
* This product includes software developed by the University of
|
|
||||||
* California, Berkeley and its contributors.
|
|
||||||
* 4. Neither the name of the University nor the names of its contributors
|
|
||||||
* may be used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*
|
*
|
||||||
* @(#)telnet.h 8.2 (Berkeley) 12/15/93
|
* 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
|
||||||
#ifndef _ARPA_TELNET_H
|
* licenses. You may pick one of these licenses.
|
||||||
#define _ARPA_TELNET_H
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Definitions for the TELNET protocol.
|
* Telnet option defines. Add more here if in need.
|
||||||
*/
|
*/
|
||||||
#define IAC 255 /* interpret as command: */
|
#define TELOPT_BINARY 0 /* binary 8bit data */
|
||||||
#define DONT 254 /* you are not to use option */
|
#define TELOPT_SGA 3 /* Supress Go Ahead */
|
||||||
#define DO 253 /* please, you use option */
|
#define TELOPT_EXOPL 255 /* EXtended OPtions List */
|
||||||
#define WONT 252 /* I won't use option */
|
#define TELOPT_TTYPE 24 /* Terminal TYPE */
|
||||||
#define WILL 251 /* I will use option */
|
#define TELOPT_XDISPLOC 35 /* X DISPlay LOCation */
|
||||||
#define SB 250 /* interpret as subnegotiation */
|
|
||||||
#define GA 249 /* you may reverse the line */
|
|
||||||
#define EL 248 /* erase the current line */
|
|
||||||
#define EC 247 /* erase the current character */
|
|
||||||
#define AYT 246 /* are you there */
|
|
||||||
#define AO 245 /* abort output--but let prog finish */
|
|
||||||
#define IP 244 /* interrupt process--permanently */
|
|
||||||
#define BREAK 243 /* break */
|
|
||||||
#define DM 242 /* data mark--for connect. cleaning */
|
|
||||||
#define NOP 241 /* nop */
|
|
||||||
#define SE 240 /* end sub negotiation */
|
|
||||||
#define EOR 239 /* end of record (transparent mode) */
|
|
||||||
#define ABORT 238 /* Abort process */
|
|
||||||
#define SUSP 237 /* Suspend process */
|
|
||||||
#define xEOF 236 /* End of file: EOF is already used... */
|
|
||||||
|
|
||||||
#define SYNCH 242 /* for telfunc calls */
|
#define TELOPT_NEW_ENVIRON 39 /* NEW ENVIRONment variables */
|
||||||
|
#define NEW_ENV_VAR 0
|
||||||
|
#define NEW_ENV_VALUE 1
|
||||||
|
|
||||||
#ifdef TELCMDS
|
/*
|
||||||
char *telcmds[] = {
|
* The telnet options represented as strings
|
||||||
"EOF", "SUSP", "ABORT", "EOR",
|
*/
|
||||||
"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC",
|
static const char *telnetoptions[]=
|
||||||
"EL", "GA", "SB", "WILL", "WONT", "DO", "DONT", "IAC", 0,
|
{
|
||||||
|
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD",
|
||||||
|
"NAME", "STATUS", "TIMING MARK", "RCTE",
|
||||||
|
"NAOL", "NAOP", "NAOCRD", "NAOHTS",
|
||||||
|
"NAOHTD", "NAOFFD", "NAOVTS", "NAOVTD",
|
||||||
|
"NAOLFD", "EXTEND ASCII", "LOGOUT", "BYTE MACRO",
|
||||||
|
"DE TERMINAL", "SUPDUP", "SUPDUP OUTPUT", "SEND LOCATION",
|
||||||
|
"TERM TYPE", "END OF RECORD", "TACACS UID", "OUTPUT MARKING",
|
||||||
|
"TTYLOC", "3270 REGIME", "X3 PAD", "NAWS",
|
||||||
|
"TERM SPEED", "LFLOW", "LINEMODE", "XDISPLOC",
|
||||||
|
"OLD-ENVIRON", "AUTHENTICATION", "ENCRYPT", "NEW-ENVIRON"
|
||||||
};
|
};
|
||||||
#else
|
|
||||||
extern char *telcmds[];
|
#define TELOPT_MAXIMUM TELOPT_NEW_ENVIRON
|
||||||
|
|
||||||
|
#define TELOPT_OK(x) ((x) <= TELOPT_MAXIMUM)
|
||||||
|
#define TELOPT(x) telnetoptions[x]
|
||||||
|
|
||||||
|
#define NTELOPTS 40
|
||||||
|
|
||||||
|
/*
|
||||||
|
* First some defines
|
||||||
|
*/
|
||||||
|
#define xEOF 236 /* End Of File */
|
||||||
|
#define SE 240 /* Sub negotiation End */
|
||||||
|
#define NOP 241 /* No OPeration */
|
||||||
|
#define DM 242 /* Data Mark */
|
||||||
|
#define GA 249 /* Go Ahead, reverse the line */
|
||||||
|
#define SB 250 /* SuBnegotiation */
|
||||||
|
#define WILL 251 /* Our side WILL use this option */
|
||||||
|
#define WONT 252 /* Our side WON'T use this option */
|
||||||
|
#define DO 253 /* DO use this option! */
|
||||||
|
#define DONT 254 /* DON'T use this option! */
|
||||||
|
#define IAC 255 /* Interpret As Command */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Then those numbers represented as strings:
|
||||||
|
*/
|
||||||
|
static const char *telnetcmds[]=
|
||||||
|
{
|
||||||
|
"EOF", "SUSP", "ABORT", "EOR", "SE",
|
||||||
|
"NOP", "DMARK", "BRK", "IP", "AO",
|
||||||
|
"AYT", "EC", "EL", "GA", "SB",
|
||||||
|
"WILL", "WONT", "DO", "DONT", "IAC"
|
||||||
|
};
|
||||||
|
|
||||||
|
#define TELCMD_MINIMUM xEOF /* the first one */
|
||||||
|
#define TELCMD_MAXIMUM IAC /* surprise, 255 is the last one! ;-) */
|
||||||
|
|
||||||
|
#define TELQUAL_IS 0
|
||||||
|
#define TELQUAL_SEND 1
|
||||||
|
#define TELQUAL_INFO 2
|
||||||
|
#define TELQUAL_NAME 3
|
||||||
|
|
||||||
|
#define TELCMD_OK(x) ( ((unsigned int)(x) >= TELCMD_MINIMUM) && \
|
||||||
|
((unsigned int)(x) <= TELCMD_MAXIMUM) )
|
||||||
|
#define TELCMD(x) telnetcmds[(x)-TELCMD_MINIMUM]
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define TELCMD_FIRST xEOF
|
|
||||||
#define TELCMD_LAST IAC
|
|
||||||
#define TELCMD_OK(x) ((unsigned int)(x) <= TELCMD_LAST && \
|
|
||||||
(unsigned int)(x) >= TELCMD_FIRST)
|
|
||||||
#define TELCMD(x) telcmds[(x)-TELCMD_FIRST]
|
|
||||||
|
|
||||||
/* telnet options */
|
|
||||||
#define TELOPT_BINARY 0 /* 8-bit data path */
|
|
||||||
#define TELOPT_ECHO 1 /* echo */
|
|
||||||
#define TELOPT_RCP 2 /* prepare to reconnect */
|
|
||||||
#define TELOPT_SGA 3 /* suppress go ahead */
|
|
||||||
#define TELOPT_NAMS 4 /* approximate message size */
|
|
||||||
#define TELOPT_STATUS 5 /* give status */
|
|
||||||
#define TELOPT_TM 6 /* timing mark */
|
|
||||||
#define TELOPT_RCTE 7 /* remote controlled transmission and echo */
|
|
||||||
#define TELOPT_NAOL 8 /* negotiate about output line width */
|
|
||||||
#define TELOPT_NAOP 9 /* negotiate about output page size */
|
|
||||||
#define TELOPT_NAOCRD 10 /* negotiate about CR disposition */
|
|
||||||
#define TELOPT_NAOHTS 11 /* negotiate about horizontal tabstops */
|
|
||||||
#define TELOPT_NAOHTD 12 /* negotiate about horizontal tab disposition */
|
|
||||||
#define TELOPT_NAOFFD 13 /* negotiate about formfeed disposition */
|
|
||||||
#define TELOPT_NAOVTS 14 /* negotiate about vertical tab stops */
|
|
||||||
#define TELOPT_NAOVTD 15 /* negotiate about vertical tab disposition */
|
|
||||||
#define TELOPT_NAOLFD 16 /* negotiate about output LF disposition */
|
|
||||||
#define TELOPT_XASCII 17 /* extended ascic character set */
|
|
||||||
#define TELOPT_LOGOUT 18 /* force logout */
|
|
||||||
#define TELOPT_BM 19 /* byte macro */
|
|
||||||
#define TELOPT_DET 20 /* data entry terminal */
|
|
||||||
#define TELOPT_SUPDUP 21 /* supdup protocol */
|
|
||||||
#define TELOPT_SUPDUPOUTPUT 22 /* supdup output */
|
|
||||||
#define TELOPT_SNDLOC 23 /* send location */
|
|
||||||
#define TELOPT_TTYPE 24 /* terminal type */
|
|
||||||
#define TELOPT_EOR 25 /* end or record */
|
|
||||||
#define TELOPT_TUID 26 /* TACACS user identification */
|
|
||||||
#define TELOPT_OUTMRK 27 /* output marking */
|
|
||||||
#define TELOPT_TTYLOC 28 /* terminal location number */
|
|
||||||
#define TELOPT_3270REGIME 29 /* 3270 regime */
|
|
||||||
#define TELOPT_X3PAD 30 /* X.3 PAD */
|
|
||||||
#define TELOPT_NAWS 31 /* window size */
|
|
||||||
#define TELOPT_TSPEED 32 /* terminal speed */
|
|
||||||
#define TELOPT_LFLOW 33 /* remote flow control */
|
|
||||||
#define TELOPT_LINEMODE 34 /* Linemode option */
|
|
||||||
#define TELOPT_XDISPLOC 35 /* X Display Location */
|
|
||||||
#define TELOPT_OLD_ENVIRON 36 /* Old - Environment variables */
|
|
||||||
#define TELOPT_AUTHENTICATION 37/* Authenticate */
|
|
||||||
#define TELOPT_ENCRYPT 38 /* Encryption option */
|
|
||||||
#define TELOPT_NEW_ENVIRON 39 /* New - Environment variables */
|
|
||||||
#define TELOPT_EXOPL 255 /* extended-options-list */
|
|
||||||
|
|
||||||
|
|
||||||
#define NTELOPTS (1+TELOPT_NEW_ENVIRON)
|
|
||||||
#ifdef TELOPTS
|
|
||||||
char *telopts[NTELOPTS+1] = {
|
|
||||||
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD", "NAME",
|
|
||||||
"STATUS", "TIMING MARK", "RCTE", "NAOL", "NAOP",
|
|
||||||
"NAOCRD", "NAOHTS", "NAOHTD", "NAOFFD", "NAOVTS",
|
|
||||||
"NAOVTD", "NAOLFD", "EXTEND ASCII", "LOGOUT", "BYTE MACRO",
|
|
||||||
"DATA ENTRY TERMINAL", "SUPDUP", "SUPDUP OUTPUT",
|
|
||||||
"SEND LOCATION", "TERMINAL TYPE", "END OF RECORD",
|
|
||||||
"TACACS UID", "OUTPUT MARKING", "TTYLOC",
|
|
||||||
"3270 REGIME", "X.3 PAD", "NAWS", "TSPEED", "LFLOW",
|
|
||||||
"LINEMODE", "XDISPLOC", "OLD-ENVIRON", "AUTHENTICATION",
|
|
||||||
"ENCRYPT", "NEW-ENVIRON",
|
|
||||||
0,
|
|
||||||
};
|
|
||||||
#define TELOPT_FIRST TELOPT_BINARY
|
|
||||||
#define TELOPT_LAST TELOPT_NEW_ENVIRON
|
|
||||||
#define TELOPT_OK(x) ((unsigned int)(x) <= TELOPT_LAST)
|
|
||||||
#define TELOPT(x) telopts[(x)-TELOPT_FIRST]
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* sub-option qualifiers */
|
|
||||||
#define TELQUAL_IS 0 /* option is... */
|
|
||||||
#define TELQUAL_SEND 1 /* send option */
|
|
||||||
#define TELQUAL_INFO 2 /* ENVIRON: informational version of IS */
|
|
||||||
#define TELQUAL_REPLY 2 /* AUTHENTICATION: client version of IS */
|
|
||||||
#define TELQUAL_NAME 3 /* AUTHENTICATION: client version of IS */
|
|
||||||
|
|
||||||
#define LFLOW_OFF 0 /* Disable remote flow control */
|
|
||||||
#define LFLOW_ON 1 /* Enable remote flow control */
|
|
||||||
#define LFLOW_RESTART_ANY 2 /* Restart output on any char */
|
|
||||||
#define LFLOW_RESTART_XON 3 /* Restart output only on XON */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* LINEMODE suboptions
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define LM_MODE 1
|
|
||||||
#define LM_FORWARDMASK 2
|
|
||||||
#define LM_SLC 3
|
|
||||||
|
|
||||||
#define MODE_EDIT 0x01
|
|
||||||
#define MODE_TRAPSIG 0x02
|
|
||||||
#define MODE_ACK 0x04
|
|
||||||
#define MODE_SOFT_TAB 0x08
|
|
||||||
#define MODE_LIT_ECHO 0x10
|
|
||||||
|
|
||||||
#define MODE_MASK 0x1f
|
|
||||||
|
|
||||||
/* Not part of protocol, but needed to simplify things... */
|
|
||||||
#define MODE_FLOW 0x0100
|
|
||||||
#define MODE_ECHO 0x0200
|
|
||||||
#define MODE_INBIN 0x0400
|
|
||||||
#define MODE_OUTBIN 0x0800
|
|
||||||
#define MODE_FORCE 0x1000
|
|
||||||
|
|
||||||
#define SLC_SYNCH 1
|
|
||||||
#define SLC_BRK 2
|
|
||||||
#define SLC_IP 3
|
|
||||||
#define SLC_AO 4
|
|
||||||
#define SLC_AYT 5
|
|
||||||
#define SLC_EOR 6
|
|
||||||
#define SLC_ABORT 7
|
|
||||||
#define SLC_EOF 8
|
|
||||||
#define SLC_SUSP 9
|
|
||||||
#define SLC_EC 10
|
|
||||||
#define SLC_EL 11
|
|
||||||
#define SLC_EW 12
|
|
||||||
#define SLC_RP 13
|
|
||||||
#define SLC_LNEXT 14
|
|
||||||
#define SLC_XON 15
|
|
||||||
#define SLC_XOFF 16
|
|
||||||
#define SLC_FORW1 17
|
|
||||||
#define SLC_FORW2 18
|
|
||||||
|
|
||||||
#define NSLC 18
|
|
||||||
|
|
||||||
/*
|
|
||||||
* For backwards compatability, we define SLC_NAMES to be the
|
|
||||||
* list of names if SLC_NAMES is not defined.
|
|
||||||
*/
|
|
||||||
#define SLC_NAMELIST "0", "SYNCH", "BRK", "IP", "AO", "AYT", "EOR", \
|
|
||||||
"ABORT", "EOF", "SUSP", "EC", "EL", "EW", "RP", \
|
|
||||||
"LNEXT", "XON", "XOFF", "FORW1", "FORW2", 0,
|
|
||||||
#ifdef SLC_NAMES
|
|
||||||
char *slc_names[] = {
|
|
||||||
SLC_NAMELIST
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *slc_names[];
|
|
||||||
#define SLC_NAMES SLC_NAMELIST
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SLC_NAME_OK(x) ((unsigned int)(x) <= NSLC)
|
|
||||||
#define SLC_NAME(x) slc_names[x]
|
|
||||||
|
|
||||||
#define SLC_NOSUPPORT 0
|
|
||||||
#define SLC_CANTCHANGE 1
|
|
||||||
#define SLC_VARIABLE 2
|
|
||||||
#define SLC_DEFAULT 3
|
|
||||||
#define SLC_LEVELBITS 0x03
|
|
||||||
|
|
||||||
#define SLC_FUNC 0
|
|
||||||
#define SLC_FLAGS 1
|
|
||||||
#define SLC_VALUE 2
|
|
||||||
|
|
||||||
#define SLC_ACK 0x80
|
|
||||||
#define SLC_FLUSHIN 0x40
|
|
||||||
#define SLC_FLUSHOUT 0x20
|
|
||||||
|
|
||||||
#define OLD_ENV_VAR 1
|
|
||||||
#define OLD_ENV_VALUE 0
|
|
||||||
#define NEW_ENV_VAR 0
|
|
||||||
#define NEW_ENV_VALUE 1
|
|
||||||
#define ENV_ESC 2
|
|
||||||
#define ENV_USERVAR 3
|
|
||||||
|
|
||||||
/*
|
|
||||||
* AUTHENTICATION suboptions
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Who is authenticating who ...
|
|
||||||
*/
|
|
||||||
#define AUTH_WHO_CLIENT 0 /* Client authenticating server */
|
|
||||||
#define AUTH_WHO_SERVER 1 /* Server authenticating client */
|
|
||||||
#define AUTH_WHO_MASK 1
|
|
||||||
|
|
||||||
/*
|
|
||||||
* amount of authentication done
|
|
||||||
*/
|
|
||||||
#define AUTH_HOW_ONE_WAY 0
|
|
||||||
#define AUTH_HOW_MUTUAL 2
|
|
||||||
#define AUTH_HOW_MASK 2
|
|
||||||
|
|
||||||
#define AUTHTYPE_NULL 0
|
|
||||||
#define AUTHTYPE_KERBEROS_V4 1
|
|
||||||
#define AUTHTYPE_KERBEROS_V5 2
|
|
||||||
#define AUTHTYPE_SPX 3
|
|
||||||
#define AUTHTYPE_MINK 4
|
|
||||||
#define AUTHTYPE_CNT 5
|
|
||||||
|
|
||||||
#define AUTHTYPE_TEST 99
|
|
||||||
|
|
||||||
#ifdef AUTH_NAMES
|
|
||||||
char *authtype_names[] = {
|
|
||||||
"NULL", "KERBEROS_V4", "KERBEROS_V5", "SPX", "MINK", 0,
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *authtype_names[];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define AUTHTYPE_NAME_OK(x) ((unsigned int)(x) < AUTHTYPE_CNT)
|
|
||||||
#define AUTHTYPE_NAME(x) authtype_names[x]
|
|
||||||
|
|
||||||
/*
|
|
||||||
* ENCRYPTion suboptions
|
|
||||||
*/
|
|
||||||
#define ENCRYPT_IS 0 /* I pick encryption type ... */
|
|
||||||
#define ENCRYPT_SUPPORT 1 /* I support encryption types ... */
|
|
||||||
#define ENCRYPT_REPLY 2 /* Initial setup response */
|
|
||||||
#define ENCRYPT_START 3 /* Am starting to send encrypted */
|
|
||||||
#define ENCRYPT_END 4 /* Am ending encrypted */
|
|
||||||
#define ENCRYPT_REQSTART 5 /* Request you start encrypting */
|
|
||||||
#define ENCRYPT_REQEND 6 /* Request you send encrypting */
|
|
||||||
#define ENCRYPT_ENC_KEYID 7
|
|
||||||
#define ENCRYPT_DEC_KEYID 8
|
|
||||||
#define ENCRYPT_CNT 9
|
|
||||||
|
|
||||||
#define ENCTYPE_ANY 0
|
|
||||||
#define ENCTYPE_DES_CFB64 1
|
|
||||||
#define ENCTYPE_DES_OFB64 2
|
|
||||||
#define ENCTYPE_CNT 3
|
|
||||||
|
|
||||||
#ifdef ENCRYPT_NAMES
|
|
||||||
char *encrypt_names[] = {
|
|
||||||
"IS", "SUPPORT", "REPLY", "START", "END",
|
|
||||||
"REQUEST-START", "REQUEST-END", "ENC-KEYID", "DEC-KEYID",
|
|
||||||
0,
|
|
||||||
};
|
|
||||||
char *enctype_names[] = {
|
|
||||||
"ANY", "DES_CFB64", "DES_OFB64", 0,
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *encrypt_names[];
|
|
||||||
extern char *enctype_names[];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#define ENCRYPT_NAME_OK(x) ((unsigned int)(x) < ENCRYPT_CNT)
|
|
||||||
#define ENCRYPT_NAME(x) encrypt_names[x]
|
|
||||||
|
|
||||||
#define ENCTYPE_NAME_OK(x) ((unsigned int)(x) < ENCTYPE_CNT)
|
|
||||||
#define ENCTYPE_NAME(x) enctype_names[x]
|
|
||||||
#endif /* _ARPA_TELNET_H */
|
|
||||||
|
|||||||
362
lib/base64.c
362
lib/base64.c
@@ -1,152 +1,270 @@
|
|||||||
/*
|
/*****************************************************************************
|
||||||
* Copyright (c) 1995 - 1999 Kungliga Tekniska H<>gskolan
|
* _ _ ____ _
|
||||||
* (Royal Institute of Technology, Stockholm, Sweden).
|
* Project ___| | | | _ \| |
|
||||||
* All rights reserved.
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Copyright (C) 2001, Andrew Francis and Daniel Stenberg
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
*
|
*
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* notice, this list of conditions and the following disclaimer.
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
*
|
*
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
* documentation and/or other materials provided with the distribution.
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
*
|
*
|
||||||
* 3. Neither the name of the Institute nor the names of its contributors
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
* may be used to endorse or promote products derived from this software
|
* KIND, either express or implied.
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
* $Id$
|
||||||
* 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 INSTITUTE OR CONTRIBUTORS BE LIABLE
|
/* Base64 encoding/decoding
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
*
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
* Test harnesses down the bottom - compile with -DTEST_ENCODE for
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
* a program that will read in raw data from stdin and write out
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
* a base64-encoded version to stdout, and the length returned by the
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
* encoding function to stderr. Compile with -DTEST_DECODE for a program that
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* will go the other way.
|
||||||
* SUCH DAMAGE.
|
*
|
||||||
|
* This code will break if int is smaller than 32 bits
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#include "setup.h"
|
||||||
#include <config.h>
|
|
||||||
#endif
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
#include "base64.h"
|
#include "base64.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static char base64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
static void decodeQuantum(unsigned char *dest, char *src)
|
||||||
|
|
||||||
static int pos(char c)
|
|
||||||
{
|
{
|
||||||
char *p;
|
unsigned int x = 0;
|
||||||
for(p = base64; *p; p++)
|
int i;
|
||||||
if(*p == c)
|
for(i = 0; i < 4; i++) {
|
||||||
return p - base64;
|
if(src[i] >= 'A' && src[i] <= 'Z')
|
||||||
return -1;
|
x = (x << 6) + (unsigned int)(src[i] - 'A' + 0);
|
||||||
|
else if(src[i] >= 'a' && src[i] <= 'z')
|
||||||
|
x = (x << 6) + (unsigned int)(src[i] - 'a' + 26);
|
||||||
|
else if(src[i] >= '0' && src[i] <= '9')
|
||||||
|
x = (x << 6) + (unsigned int)(src[i] - '0' + 52);
|
||||||
|
else if(src[i] == '+')
|
||||||
|
x = (x << 6) + 62;
|
||||||
|
else if(src[i] == '/')
|
||||||
|
x = (x << 6) + 63;
|
||||||
|
}
|
||||||
|
|
||||||
|
dest[2] = (unsigned char)(x & 255); x >>= 8;
|
||||||
|
dest[1] = (unsigned char)(x & 255); x >>= 8;
|
||||||
|
dest[0] = (unsigned char)(x & 255); x >>= 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 1
|
/* base64Decode
|
||||||
int base64_encode(const void *data, int size, char **str)
|
* Given a base64 string at src, decode it into the memory pointed
|
||||||
|
* to by dest. If rawLength points to a valid address (ie not NULL),
|
||||||
|
* store the length of the decoded data to it.
|
||||||
|
*/
|
||||||
|
static void base64Decode(unsigned char *dest, char *src, int *rawLength)
|
||||||
{
|
{
|
||||||
char *s, *p;
|
int length = 0;
|
||||||
|
int equalsTerm = 0;
|
||||||
int i;
|
int i;
|
||||||
int c;
|
unsigned char lastQuantum[3];
|
||||||
const unsigned char *q;
|
|
||||||
|
|
||||||
p = s = (char*)malloc(size*4/3+4);
|
while((src[length] != '=') && src[length])
|
||||||
if (p == NULL)
|
length++;
|
||||||
return -1;
|
while(src[length+equalsTerm] == '=')
|
||||||
q = (const unsigned char*)data;
|
equalsTerm++;
|
||||||
i=0;
|
|
||||||
for(i = 0; i < size;){
|
if(rawLength)
|
||||||
c=q[i++];
|
*rawLength = (length * 3 / 4) - equalsTerm;
|
||||||
c*=256;
|
|
||||||
if(i < size)
|
for(i = 0; i < length/4 - 1; i++) {
|
||||||
c+=q[i];
|
decodeQuantum(dest, src);
|
||||||
i++;
|
dest += 3; src += 4;
|
||||||
c*=256;
|
|
||||||
if(i < size)
|
|
||||||
c+=q[i];
|
|
||||||
i++;
|
|
||||||
p[0]=base64[(c&0x00fc0000) >> 18];
|
|
||||||
p[1]=base64[(c&0x0003f000) >> 12];
|
|
||||||
p[2]=base64[(c&0x00000fc0) >> 6];
|
|
||||||
p[3]=base64[(c&0x0000003f) >> 0];
|
|
||||||
if(i > size)
|
|
||||||
p[3]='=';
|
|
||||||
if(i > size+1)
|
|
||||||
p[2]='=';
|
|
||||||
p+=4;
|
|
||||||
}
|
}
|
||||||
*p=0;
|
|
||||||
*str = s;
|
decodeQuantum(lastQuantum, src);
|
||||||
return strlen(s);
|
for(i = 0; i < 3 - equalsTerm; i++) dest[i] = lastQuantum[i];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ---- Base64 Encoding --- */
|
||||||
|
static char table64[]=
|
||||||
|
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Curl_base64_encode()
|
||||||
|
*
|
||||||
|
* Returns the length of the newly created base64 string. The third argument
|
||||||
|
* is a pointer to an allocated area holding the base64 data. If something
|
||||||
|
* went wrong, -1 is returned.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
int Curl_base64_encode(const void *inp, int insize, char **outptr)
|
||||||
|
{
|
||||||
|
unsigned char ibuf[3];
|
||||||
|
unsigned char obuf[4];
|
||||||
|
int i;
|
||||||
|
int inputparts;
|
||||||
|
char *output;
|
||||||
|
char *base64data;
|
||||||
|
|
||||||
|
char *indata = (char *)inp;
|
||||||
|
|
||||||
|
if(0 == insize)
|
||||||
|
insize = strlen(indata);
|
||||||
|
|
||||||
|
base64data = output = (char*)malloc(insize*4/3+4);
|
||||||
|
if(NULL == output)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
while(insize > 0) {
|
||||||
|
for (i = inputparts = 0; i < 3; i++) {
|
||||||
|
if(*indata) {
|
||||||
|
inputparts++;
|
||||||
|
ibuf[i] = *indata;
|
||||||
|
indata++;
|
||||||
|
insize--;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ibuf[i] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
obuf [0] = (ibuf [0] & 0xFC) >> 2;
|
||||||
|
obuf [1] = ((ibuf [0] & 0x03) << 4) | ((ibuf [1] & 0xF0) >> 4);
|
||||||
|
obuf [2] = ((ibuf [1] & 0x0F) << 2) | ((ibuf [2] & 0xC0) >> 6);
|
||||||
|
obuf [3] = ibuf [2] & 0x3F;
|
||||||
|
|
||||||
|
switch(inputparts) {
|
||||||
|
case 1: /* only one byte read */
|
||||||
|
sprintf(output, "%c%c==",
|
||||||
|
table64[obuf[0]],
|
||||||
|
table64[obuf[1]]);
|
||||||
|
break;
|
||||||
|
case 2: /* two bytes read */
|
||||||
|
sprintf(output, "%c%c%c=",
|
||||||
|
table64[obuf[0]],
|
||||||
|
table64[obuf[1]],
|
||||||
|
table64[obuf[2]]);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
sprintf(output, "%c%c%c%c",
|
||||||
|
table64[obuf[0]],
|
||||||
|
table64[obuf[1]],
|
||||||
|
table64[obuf[2]],
|
||||||
|
table64[obuf[3]] );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
output += 4;
|
||||||
|
}
|
||||||
|
*output=0;
|
||||||
|
*outptr = base64data; /* make it return the actual data memory */
|
||||||
|
|
||||||
|
return strlen(base64data); /* return the length of the new data */
|
||||||
|
}
|
||||||
|
/* ---- End of Base64 Encoding ---- */
|
||||||
|
|
||||||
|
int Curl_base64_decode(const char *str, void *data)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
base64Decode((unsigned char *)data, (char *)str, &ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/************* TEST HARNESS STUFF ****************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef TEST_ENCODE
|
||||||
|
/* encoding test harness. Read in standard input and write out the length
|
||||||
|
* returned by Curl_base64_encode, followed by the base64'd data itself
|
||||||
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#define TEST_NEED_SUCK
|
||||||
|
void *suck(int *);
|
||||||
|
|
||||||
|
int main(int argc, char **argv, char **envp) {
|
||||||
|
char *base64;
|
||||||
|
int base64Len;
|
||||||
|
unsigned char *data;
|
||||||
|
int dataLen;
|
||||||
|
|
||||||
|
data = (unsigned char *)suck(&dataLen);
|
||||||
|
base64Len = Curl_base64_encode(data, dataLen, &base64);
|
||||||
|
|
||||||
|
fprintf(stderr, "%d\n", base64Len);
|
||||||
|
fprintf(stdout, "%s", base64);
|
||||||
|
|
||||||
|
free(base64); free(data);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int base64_decode(const char *str, void *data)
|
#ifdef TEST_DECODE
|
||||||
{
|
/* decoding test harness. Read in a base64 string from stdin and write out the
|
||||||
const char *p;
|
* length returned by Curl_base64_decode, followed by the decoded data itself
|
||||||
unsigned char *q;
|
*/
|
||||||
int c;
|
#include <stdio.h>
|
||||||
int x;
|
|
||||||
int done = 0;
|
|
||||||
q=(unsigned char*)data;
|
|
||||||
for(p=str; *p && !done; p+=4){
|
|
||||||
x = pos(p[0]);
|
|
||||||
if(x >= 0)
|
|
||||||
c = x;
|
|
||||||
else{
|
|
||||||
done = 3;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
x = pos(p[1]);
|
#define TEST_NEED_SUCK
|
||||||
if(x >= 0)
|
void *suck(int *);
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
if(p[2] == '=')
|
int main(int argc, char **argv, char **envp) {
|
||||||
done++;
|
char *base64;
|
||||||
else{
|
int base64Len;
|
||||||
x = pos(p[2]);
|
unsigned char *data;
|
||||||
if(x >= 0)
|
int dataLen;
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
if(p[3] == '=')
|
base64 = (char *)suck(&base64Len);
|
||||||
done++;
|
data = (unsigned char *)malloc(base64Len * 3/4 + 8);
|
||||||
else{
|
dataLen = Curl_base64_decode(base64, data);
|
||||||
if(done)
|
|
||||||
return -1;
|
|
||||||
x = pos(p[3]);
|
|
||||||
if(x >= 0)
|
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
if(done < 3)
|
|
||||||
*q++=(c&0x00ff0000)>>16;
|
|
||||||
|
|
||||||
if(done < 2)
|
fprintf(stderr, "%d\n", dataLen);
|
||||||
*q++=(c&0x0000ff00)>>8;
|
fwrite(data,1,dataLen,stdout);
|
||||||
if(done < 1)
|
|
||||||
*q++=(c&0x000000ff)>>0;
|
|
||||||
}
|
free(base64); free(data);
|
||||||
return q - (unsigned char*)data;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef TEST_NEED_SUCK
|
||||||
|
/* this function 'sucks' in as much as possible from stdin */
|
||||||
|
void *suck(int *lenptr) {
|
||||||
|
int cursize = 8192;
|
||||||
|
unsigned char *buf = NULL;
|
||||||
|
int lastread;
|
||||||
|
int len = 0;
|
||||||
|
|
||||||
|
do {
|
||||||
|
cursize *= 2;
|
||||||
|
buf = (unsigned char *)realloc(buf, cursize);
|
||||||
|
memset(buf + len, 0, cursize - len);
|
||||||
|
lastread = fread(buf + len, 1, cursize - len, stdin);
|
||||||
|
len += lastread;
|
||||||
|
} while(!feof(stdin));
|
||||||
|
|
||||||
|
lenptr[0] = len;
|
||||||
|
return (void *)buf;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user