Compare commits
507 Commits
curl-7_8
...
curl-7_9_1
Author | SHA1 | Date | |
---|---|---|---|
![]() |
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 |
1381
CHANGES.2000
Normal file
1381
CHANGES.2000
Normal file
File diff suppressed because it is too large
Load Diff
4
CVS-INFO
4
CVS-INFO
@@ -10,8 +10,8 @@ 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
|
information about other files and things that the CVS repository keeps in its
|
||||||
inner sanctum.
|
inner sanctum.
|
||||||
|
|
||||||
Use autoconf 2.50 and no earlier. Also, try having automake 1.4 and libtool
|
Use autoconf 2.50 and no earlier. Also, try having automake 1.5 and libtool
|
||||||
1.4 at least.
|
1.4.1 at least.
|
||||||
|
|
||||||
You will need perl to generate the src/hugehelp.c file. The file
|
You will need perl to generate the src/hugehelp.c file. The file
|
||||||
src/hugehelp.c.cvs is a one-shot file that you can rename to src/hugehelp.c if
|
src/hugehelp.c.cvs is a one-shot file that you can rename to src/hugehelp.c if
|
||||||
|
5
MITX.txt
5
MITX.txt
@@ -1,6 +1,6 @@
|
|||||||
COPYRIGHT AND PERMISSION NOTICE
|
COPYRIGHT AND PERMISSION NOTICE
|
||||||
|
|
||||||
Copyright (c) 2000, Daniel Stenberg, <daniel@haxx.se>.
|
Copyright (c) 1996 - 2001, Daniel Stenberg, <daniel@haxx.se>.
|
||||||
|
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
@@ -10,8 +10,7 @@ in the Software without restriction, including without limitation the rights
|
|||||||
to use, copy, modify, merge, publish, distribute, and/or sell copies of the
|
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,
|
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
|
provided that the above copyright notice(s) and this permission notice appear
|
||||||
in all copies of the Software and that both the above copyright notice(s) and
|
in all copies of the Software.
|
||||||
this permission notice appear in supporting documentation.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
16
Makefile.am
16
Makefile.am
@@ -6,17 +6,21 @@ AUTOMAKE_OPTIONS = foreign no-dependencies
|
|||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
||||||
config-win32.h reconf packages/README Makefile.dist \
|
config-win32.h reconf Makefile.dist \
|
||||||
curl-config.in libtool
|
curl-config.in build_vms.com config-riscos.h \
|
||||||
|
config-vms.h curl-mode.el
|
||||||
|
|
||||||
bin_SCRIPTS = curl-config
|
bin_SCRIPTS = curl-config
|
||||||
|
|
||||||
SUBDIRS = docs lib src include tests packages perl php
|
SUBDIRS = docs lib src include tests packages
|
||||||
|
|
||||||
# create a root makefile in the distribution:
|
# create a root makefile in the distribution:
|
||||||
dist-hook:
|
dist-hook:
|
||||||
cp $(srcdir)/Makefile.dist $(distdir)/Makefile
|
cp $(srcdir)/Makefile.dist $(distdir)/Makefile
|
||||||
|
|
||||||
|
html:
|
||||||
|
cd docs; make html
|
||||||
|
|
||||||
check: test
|
check: test
|
||||||
|
|
||||||
test:
|
test:
|
||||||
@@ -63,3 +67,9 @@ pkgadd:
|
|||||||
make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \
|
make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \
|
||||||
cat LEGAL MITX.txt MPL-1.1.txt > $(srcdir)/packages/Solaris/copyright ; \
|
cat LEGAL MITX.txt MPL-1.1.txt > $(srcdir)/packages/Solaris/copyright ; \
|
||||||
cd $(srcdir)/packages/Solaris && $(MAKE) package
|
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
|
||||||
|
3
README
3
README
@@ -12,7 +12,7 @@ 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 libcurl.5 man page 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.
|
||||||
@@ -26,6 +26,7 @@ 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 -- ftp://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:
|
||||||
|
@@ -54,3 +54,11 @@
|
|||||||
|
|
||||||
/* Define if you have a working OpenSSL installation */
|
/* Define if you have a working OpenSSL installation */
|
||||||
#undef OPENSSL_ENABLED
|
#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
|
||||||
|
|
||||||
|
400
acinclude.m4
Normal file
400
acinclude.m4
Normal file
@@ -0,0 +1,400 @@
|
|||||||
|
dnl Check for how to set a socket to non-blocking state. There seems to exist
|
||||||
|
dnl four known different ways, with the one used almost everywhere being POSIX
|
||||||
|
dnl and XPG3, while the other different ways for different systems (old BSD,
|
||||||
|
dnl Windows and Amiga).
|
||||||
|
dnl
|
||||||
|
dnl There are two known platforms (AIX 3.x and SunOS 4.1.x) where the
|
||||||
|
dnl O_NONBLOCK define is found but does not work. This condition is attempted
|
||||||
|
dnl to get caught in this script by using an excessive number of #ifdefs...
|
||||||
|
dnl
|
||||||
|
AC_DEFUN(CURL_CHECK_NONBLOCKING_SOCKET,
|
||||||
|
[
|
||||||
|
AC_MSG_CHECKING([non-blocking sockets style])
|
||||||
|
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
/* headers for O_NONBLOCK test */
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
],[
|
||||||
|
/* try to compile O_NONBLOCK */
|
||||||
|
|
||||||
|
#if defined(sun) || defined(__sun__) || defined(__SUNPRO_C) || defined(__SUNPRO_CC)
|
||||||
|
# if defined(__SVR4) || defined(__srv4__)
|
||||||
|
# define PLATFORM_SOLARIS
|
||||||
|
# else
|
||||||
|
# define PLATFORM_SUNOS4
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#if (defined(_AIX) || defined(__xlC__)) && !defined(_AIX4)
|
||||||
|
# define PLATFORM_AIX_V3
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(PLATFORM_SUNOS4) || defined(PLATFORM_AIX_V3)
|
||||||
|
#error "O_NONBLOCK does not work on this platform"
|
||||||
|
#endif
|
||||||
|
int socket;
|
||||||
|
int flags = fcntl(socket, F_SETFL, flags | O_NONBLOCK);
|
||||||
|
],[
|
||||||
|
dnl the O_NONBLOCK test was fine
|
||||||
|
nonblock="O_NONBLOCK"
|
||||||
|
AC_DEFINE(HAVE_O_NONBLOCK)
|
||||||
|
],[
|
||||||
|
dnl the code was bad, try a different program now, test 2
|
||||||
|
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
/* headers for FIONBIO test */
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stropts.h>
|
||||||
|
],[
|
||||||
|
/* FIONBIO source test */
|
||||||
|
int flags = ioctl(socket, FIONBIO, &flags);
|
||||||
|
],[
|
||||||
|
dnl FIONBIO test was good
|
||||||
|
nonblock="FIONBIO"
|
||||||
|
AC_DEFINE(HAVE_FIONBIO)
|
||||||
|
],[
|
||||||
|
dnl FIONBIO test was also bad
|
||||||
|
dnl the code was bad, try a different program now, test 3
|
||||||
|
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
/* headers for ioctlsocket test (cygwin?) */
|
||||||
|
#include <windows.h>
|
||||||
|
],[
|
||||||
|
/* ioctlsocket source code */
|
||||||
|
int flags = ioctlsocket(socket, FIONBIO, &flags);
|
||||||
|
],[
|
||||||
|
dnl ioctlsocket test was good
|
||||||
|
nonblock="ioctlsocket"
|
||||||
|
AC_DEFINE(HAVE_IOCTLSOCKET)
|
||||||
|
],[
|
||||||
|
dnl ioctlsocket didnt compile!
|
||||||
|
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
/* headers for IoctlSocket test (Amiga?) */
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
],[
|
||||||
|
/* IoctlSocket source code */
|
||||||
|
int flags = IoctlSocket(socket, FIONBIO, (long)1);
|
||||||
|
],[
|
||||||
|
dnl ioctlsocket test was good
|
||||||
|
nonblock="IoctlSocket"
|
||||||
|
AC_DEFINE(HAVE_IOCTLSOCKET_CASE)
|
||||||
|
],[
|
||||||
|
dnl ioctlsocket didnt compile!
|
||||||
|
nonblock="nada"
|
||||||
|
AC_DEFINE(HAVE_DISABLED_NONBLOCKING)
|
||||||
|
])
|
||||||
|
dnl end of forth test
|
||||||
|
|
||||||
|
])
|
||||||
|
dnl end of third test
|
||||||
|
|
||||||
|
])
|
||||||
|
dnl end of second test
|
||||||
|
|
||||||
|
])
|
||||||
|
dnl end of non-blocking try-compile test
|
||||||
|
AC_MSG_RESULT($nonblock)
|
||||||
|
|
||||||
|
if test "$nonblock" = "nada"; then
|
||||||
|
AC_MSG_WARN([non-block sockets disabled])
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl 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 ************************************************************
|
||||||
|
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>
|
||||||
|
|
||||||
|
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>
|
||||||
|
|
||||||
|
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>
|
||||||
|
|
||||||
|
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>
|
||||||
|
|
||||||
|
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
|
||||||
|
])
|
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
|
@@ -5,9 +5,7 @@ die(){
|
|||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
|
|
||||||
MAKEFILES=`find . -name Makefile.am | sed 's/\.am$//'`
|
automake || die "The command 'automake $MAKEFILES' failed"
|
||||||
|
|
||||||
automake $MAKEFILES || die "The command 'automake $MAKEFILES' failed"
|
|
||||||
aclocal || die "The command 'aclocal' failed"
|
aclocal || die "The command 'aclocal' failed"
|
||||||
autoheader || die "The command 'autoheader' failed"
|
autoheader || die "The command 'autoheader' failed"
|
||||||
autoconf || die "The command 'autoconf' failed"
|
autoconf || die "The command 'autoconf' failed"
|
||||||
|
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"
|
367
config-vms.h
Executable file
367
config-vms.h
Executable file
@@ -0,0 +1,367 @@
|
|||||||
|
/* config.h.in. Generated automatically from configure.in by autoheader. */
|
||||||
|
|
||||||
|
/* Define if on AIX 3.
|
||||||
|
System headers sometimes define this.
|
||||||
|
We just want to avoid a redefinition error message. */
|
||||||
|
#ifndef _ALL_SOURCE
|
||||||
|
#undef _ALL_SOURCE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Define to empty if the keyword does not work. */
|
||||||
|
#undef const
|
||||||
|
|
||||||
|
/* Define as the return type of signal handlers (int or void). */
|
||||||
|
#undef RETSIGTYPE
|
||||||
|
|
||||||
|
/* Define to `unsigned' if <sys/types.h> doesn't define. */
|
||||||
|
#undef size_t
|
||||||
|
|
||||||
|
/* Define if you have the ANSI C header files. */
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
|
||||||
|
/* Define if you can safely include both <sys/time.h> and <time.h>. */
|
||||||
|
#define TIME_WITH_SYS_TIME 1
|
||||||
|
|
||||||
|
/* Define cpu-machine-OS */
|
||||||
|
#define OS "ALPHA-COMPAQ-VMS"
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
||||||
|
#undef HAVE_GETHOSTBYADDR_R_5
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyaddr_r() function with 7 arguments */
|
||||||
|
#undef HAVE_GETHOSTBYADDR_R_7
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyaddr_r() function with 8 arguments */
|
||||||
|
#undef HAVE_GETHOSTBYADDR_R_8
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyname_r() function with 3 arguments */
|
||||||
|
#undef HAVE_GETHOSTBYNAME_R_3
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyname_r() function with 5 arguments */
|
||||||
|
#undef HAVE_GETHOSTBYNAME_R_5
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyname_r() function with 6 arguments */
|
||||||
|
#undef HAVE_GETHOSTBYNAME_R_6
|
||||||
|
|
||||||
|
/* Define if you have the inet_ntoa_r function declared. */
|
||||||
|
#undef HAVE_INET_NTOA_R_DECL
|
||||||
|
|
||||||
|
/* Define if you need the _REENTRANT define for some functions */
|
||||||
|
#undef NEED_REENTRANT
|
||||||
|
|
||||||
|
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
||||||
|
#undef KRB4
|
||||||
|
|
||||||
|
/* Define 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. */
|
||||||
|
#define SIZEOF_LONG_DOUBLE 8
|
||||||
|
|
||||||
|
/* The number of bytes in a 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. */
|
||||||
|
#undef HAVE_RAND_SCREEN
|
||||||
|
|
||||||
|
/* Define if you have the RAND_status function. */
|
||||||
|
#undef HAVE_RAND_STATUS
|
||||||
|
|
||||||
|
/* Define if you have the closesocket function. */
|
||||||
|
#undef HAVE_CLOSESOCKET
|
||||||
|
|
||||||
|
/* Define if you have the geteuid function. */
|
||||||
|
#define HAVE_GETEUID 1
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyaddr function. */
|
||||||
|
#define HAVE_GETHOSTBYADDR 1
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyaddr_r function. */
|
||||||
|
#undef HAVE_GETHOSTBYADDR_R
|
||||||
|
|
||||||
|
/* Define if you have the gethostbyname_r function. */
|
||||||
|
#undef HAVE_GETHOSTBYNAME_R
|
||||||
|
|
||||||
|
/* Define if you have the gethostname function. */
|
||||||
|
#define HAVE_GETHOSTNAME 1
|
||||||
|
|
||||||
|
/* Define if you have the getpass_r function. */
|
||||||
|
#undef HAVE_GETPASS_R
|
||||||
|
|
||||||
|
/* Define if you have the getpwuid function. */
|
||||||
|
#define HAVE_GETPWUID 1
|
||||||
|
|
||||||
|
/* Define if you have the getservbyname function. */
|
||||||
|
#define HAVE_GETSERVBYNAME 1
|
||||||
|
|
||||||
|
/* Define if you have the gettimeofday function. */
|
||||||
|
#define HAVE_GETTIMEOFDAY 1
|
||||||
|
|
||||||
|
/* Define if you have the inet_addr function. */
|
||||||
|
#define HAVE_INET_ADDR 1
|
||||||
|
|
||||||
|
/* Define if you have the inet_ntoa function. */
|
||||||
|
#define HAVE_INET_NTOA 1
|
||||||
|
|
||||||
|
/* Define if you have the inet_ntoa_r function. */
|
||||||
|
#undef HAVE_INET_NTOA_R
|
||||||
|
|
||||||
|
/* Define if you have the krb_get_our_ip_for_realm function. */
|
||||||
|
#undef HAVE_KRB_GET_OUR_IP_FOR_REALM
|
||||||
|
|
||||||
|
/* Define if you have the localtime_r function. */
|
||||||
|
#undef HAVE_LOCALTIME_R
|
||||||
|
|
||||||
|
/* Define if you have the perror function. */
|
||||||
|
#define HAVE_PERROR 1
|
||||||
|
|
||||||
|
/* Define if you have the select function. */
|
||||||
|
#define HAVE_SELECT 1
|
||||||
|
|
||||||
|
/* Define if you have the setvbuf function. */
|
||||||
|
#undef HAVE_SETVBUF
|
||||||
|
|
||||||
|
/* Define if you have the sigaction function. */
|
||||||
|
#define HAVE_SIGACTION 1
|
||||||
|
|
||||||
|
/* Define if you have the signal function. */
|
||||||
|
#define HAVE_SIGNAL 1
|
||||||
|
|
||||||
|
/* Define if you have the socket function. */
|
||||||
|
#define HAVE_SOCKET 1
|
||||||
|
|
||||||
|
/* Define if you have the strcasecmp function. */
|
||||||
|
#define HAVE_STRCASECMP 1
|
||||||
|
|
||||||
|
/* Define if you have the strcmpi function. */
|
||||||
|
#define HAVE_STRCMPI 1
|
||||||
|
|
||||||
|
/* Define if you have the strdup function. */
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
|
||||||
|
/* Define if you have the strftime function. */
|
||||||
|
#define HAVE_STRFTIME 1
|
||||||
|
|
||||||
|
/* Define if you have the stricmp function. */
|
||||||
|
#define HAVE_STRICMP 1
|
||||||
|
|
||||||
|
/* Define if you have the strlcat function. */
|
||||||
|
#undef HAVE_STRLCAT
|
||||||
|
|
||||||
|
/* Define if you have the strlcpy function. */
|
||||||
|
#undef HAVE_STRLCPY
|
||||||
|
|
||||||
|
/* Define if you have the strstr function. */
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
|
||||||
|
/* Define if you have the tcgetattr function. */
|
||||||
|
#undef HAVE_TCGETATTR
|
||||||
|
|
||||||
|
/* Define if you have the tcsetattr function. */
|
||||||
|
#undef HAVE_TCSETATTR
|
||||||
|
|
||||||
|
/* Define if you have the uname function. */
|
||||||
|
#define HAVE_UNAME 1
|
||||||
|
|
||||||
|
/* Define if you have the <alloca.h> header file. */
|
||||||
|
#undef HAVE_ALLOCA_H
|
||||||
|
|
||||||
|
/* Define if you have the <arpa/inet.h> header file. */
|
||||||
|
#undef HAVE_ARPA_INET_H
|
||||||
|
|
||||||
|
/* Define if you have the <crypto.h> header file. */
|
||||||
|
#undef HAVE_CRYPTO_H
|
||||||
|
|
||||||
|
/* Define if you have the <des.h> header file. */
|
||||||
|
#undef HAVE_DES_H
|
||||||
|
|
||||||
|
/* Define if you have the <dlfcn.h> header file. */
|
||||||
|
#undef HAVE_DLFCN_H
|
||||||
|
|
||||||
|
/* Define if you have the <err.h> header file. */
|
||||||
|
#define HAVE_ERR_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <fcntl.h> header file. */
|
||||||
|
#define HAVE_FCNTL_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <getopt.h> header file. */
|
||||||
|
#define HAVE_GETOPT_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <io.h> header file. */
|
||||||
|
#undef HAVE_IO_H
|
||||||
|
|
||||||
|
/* Define if you have the <krb.h> header file. */
|
||||||
|
#undef HAVE_KRB_H
|
||||||
|
|
||||||
|
/* Define if you have the <malloc.h> header file. */
|
||||||
|
#define HAVE_MALLOC_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <net/if.h> header file. */
|
||||||
|
#define HAVE_NET_IF_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <netdb.h> header file. */
|
||||||
|
#define HAVE_NETDB_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <netinet/if_ether.h> header file. */
|
||||||
|
#define HAVE_NETINET_IF_ETHER_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <netinet/in.h> header file. */
|
||||||
|
#define HAVE_NETINET_IN_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <openssl/crypto.h> header file. */
|
||||||
|
#undef HAVE_OPENSSL_CRYPTO_H
|
||||||
|
|
||||||
|
/* Define if you have the <openssl/err.h> header file. */
|
||||||
|
#undef HAVE_OPENSSL_ERR_H
|
||||||
|
|
||||||
|
/* Define if you have the <openssl/pem.h> header file. */
|
||||||
|
#undef HAVE_OPENSSL_PEM_H
|
||||||
|
|
||||||
|
/* Define if you have the <openssl/rsa.h> header file. */
|
||||||
|
#undef HAVE_OPENSSL_RSA_H
|
||||||
|
|
||||||
|
/* Define if you have the <openssl/ssl.h> header file. */
|
||||||
|
#undef HAVE_OPENSSL_SSL_H
|
||||||
|
|
||||||
|
/* Define if you have the <openssl/x509.h> header file. */
|
||||||
|
#undef HAVE_OPENSSL_X509_H
|
||||||
|
|
||||||
|
/* Define if you have the <pem.h> header file. */
|
||||||
|
#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. */
|
||||||
|
#undef HAVE_RSA_H
|
||||||
|
|
||||||
|
/* Define if you have the <sgtty.h> header file. */
|
||||||
|
#define HAVE_SGTTY_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <ssl.h> header file. */
|
||||||
|
#undef HAVE_SSL_H
|
||||||
|
|
||||||
|
/* Define if you have the <stdlib.h> header file. */
|
||||||
|
#define HAVE_STDLIB_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <sys/param.h> header file. */
|
||||||
|
#undef HAVE_SYS_PARAM_H
|
||||||
|
|
||||||
|
/* Define if you have the <sys/select.h> header file. */
|
||||||
|
#undef HAVE_SYS_SELECT_H
|
||||||
|
|
||||||
|
/* Define if you have the <sys/socket.h> header file. */
|
||||||
|
#define HAVE_SYS_SOCKET_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <sys/sockio.h> header file. */
|
||||||
|
#undef HAVE_SYS_SOCKIO_H
|
||||||
|
|
||||||
|
/* Define if you have the <sys/stat.h> header file. */
|
||||||
|
#define HAVE_SYS_STAT_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <sys/time.h> header file. */
|
||||||
|
#define HAVE_SYS_TIME_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <sys/types.h> header file. */
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <termio.h> header file. */
|
||||||
|
#undef HAVE_TERMIO_H
|
||||||
|
|
||||||
|
/* Define if you have the <termios.h> header file. */
|
||||||
|
#define HAVE_TERMIOS_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <time.h> header file. */
|
||||||
|
#define HAVE_TIME_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <unistd.h> header file. */
|
||||||
|
#define HAVE_UNISTD_H 1
|
||||||
|
|
||||||
|
/* Define if you have the <winsock.h> header file. */
|
||||||
|
#undef HAVE_WINSOCK_H
|
||||||
|
|
||||||
|
/* Define if you have the <x509.h> header file. */
|
||||||
|
#undef HAVE_X509_H
|
||||||
|
|
||||||
|
/* Define if you have the crypto library (-lcrypto). */
|
||||||
|
#undef HAVE_LIBCRYPTO
|
||||||
|
|
||||||
|
/* Define if you have the dl library (-ldl). */
|
||||||
|
#undef HAVE_LIBDL
|
||||||
|
|
||||||
|
/* Define if you have the nsl library (-lnsl). */
|
||||||
|
#undef HAVE_LIBNSL
|
||||||
|
|
||||||
|
/* Define if you have the resolv library (-lresolv). */
|
||||||
|
#define HAVE_LIBRESOLV 1
|
||||||
|
|
||||||
|
/* Define if you have the resolve library (-lresolve). */
|
||||||
|
#undef HAVE_LIBRESOLVE
|
||||||
|
|
||||||
|
/* Define if you have the socket library (-lsocket). */
|
||||||
|
#define HAVE_LIBSOCKET 1
|
||||||
|
|
||||||
|
/* Define if you have the ssl library (-lssl). */
|
||||||
|
#undef HAVE_LIBSSL
|
||||||
|
|
||||||
|
/* Define if you have the ucb library (-lucb). */
|
||||||
|
#undef HAVE_LIBUCB
|
||||||
|
|
||||||
|
/* Number of bits in a file offset, on hosts where this is settable. */
|
||||||
|
#undef _FILE_OFFSET_BITS
|
||||||
|
|
||||||
|
/* Define for large files, on AIX-style hosts. */
|
||||||
|
#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 */
|
||||||
|
#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
|
||||||
|
|
@@ -101,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
|
||||||
|
|
||||||
@@ -185,3 +188,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
|
||||||
|
230
config.guess
vendored
230
config.guess
vendored
@@ -3,7 +3,7 @@
|
|||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
# Free Software Foundation, Inc.
|
# Free Software Foundation, Inc.
|
||||||
|
|
||||||
timestamp='2001-04-20'
|
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
|
||||||
@@ -52,7 +52,7 @@ version="\
|
|||||||
GNU config.guess ($timestamp)
|
GNU config.guess ($timestamp)
|
||||||
|
|
||||||
Originally written by Per Bothner.
|
Originally written by Per Bothner.
|
||||||
Copyright (C) 1992, 93, 94, 95, 96, 97, 98, 99, 2000
|
Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
Free Software Foundation, Inc.
|
Free Software Foundation, Inc.
|
||||||
|
|
||||||
This is free software; see the source for copying conditions. There is NO
|
This is free software; see the source for copying conditions. There is NO
|
||||||
@@ -95,25 +95,25 @@ trap 'rm -f $dummy.c $dummy.o $dummy.rel $dummy; exit 1' 1 2 15
|
|||||||
# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
|
# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
|
||||||
# use `HOST_CC' if defined, but it is deprecated.
|
# use `HOST_CC' if defined, but it is deprecated.
|
||||||
|
|
||||||
case $CC_FOR_BUILD,$HOST_CC,$CC in
|
set_cc_for_build='case $CC_FOR_BUILD,$HOST_CC,$CC in
|
||||||
,,) echo "int dummy(){}" > $dummy.c
|
,,) echo "int dummy(){}" > $dummy.c ;
|
||||||
for c in cc gcc c89 ; do
|
for c in cc gcc c89 ; do
|
||||||
($c $dummy.c -c -o $dummy.o) >/dev/null 2>&1
|
($c $dummy.c -c -o $dummy.o) >/dev/null 2>&1 ;
|
||||||
if test $? = 0 ; then
|
if test $? = 0 ; then
|
||||||
CC_FOR_BUILD="$c"; break
|
CC_FOR_BUILD="$c"; break ;
|
||||||
fi
|
fi ;
|
||||||
done
|
done ;
|
||||||
rm -f $dummy.c $dummy.o $dummy.rel
|
rm -f $dummy.c $dummy.o $dummy.rel ;
|
||||||
if test x"$CC_FOR_BUILD" = x ; then
|
if test x"$CC_FOR_BUILD" = x ; then
|
||||||
CC_FOR_BUILD=no_compiler_found
|
CC_FOR_BUILD=no_compiler_found ;
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
,,*) CC_FOR_BUILD=$CC ;;
|
,,*) CC_FOR_BUILD=$CC ;;
|
||||||
,*,*) CC_FOR_BUILD=$HOST_CC ;;
|
,*,*) CC_FOR_BUILD=$HOST_CC ;;
|
||||||
esac
|
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
|
||||||
@@ -150,6 +150,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
|||||||
# to ELF recently, or will in the future.
|
# to ELF recently, or will in the future.
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
i386|sparc|amiga|arm*|hp300|mvme68k|vax|atari|luna68k|mac68k|news68k|next68k|pc532|sun3*|x68k)
|
i386|sparc|amiga|arm*|hp300|mvme68k|vax|atari|luna68k|mac68k|news68k|next68k|pc532|sun3*|x68k)
|
||||||
|
eval $set_cc_for_build
|
||||||
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
||||||
| grep __ELF__ >/dev/null
|
| grep __ELF__ >/dev/null
|
||||||
then
|
then
|
||||||
@@ -204,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
|
||||||
@@ -225,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
|
||||||
@@ -328,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 ;;
|
||||||
@@ -385,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 */
|
||||||
@@ -475,6 +484,7 @@ EOF
|
|||||||
exit 0 ;;
|
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>
|
||||||
|
|
||||||
@@ -553,6 +563,7 @@ EOF
|
|||||||
fi ;;
|
fi ;;
|
||||||
esac
|
esac
|
||||||
if [ "${HP_ARCH}" = "" ]; then
|
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
|
||||||
@@ -598,6 +609,7 @@ EOF
|
|||||||
echo ia64-hp-hpux${HPUX_REV}
|
echo ia64-hp-hpux${HPUX_REV}
|
||||||
exit 0 ;;
|
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
|
||||||
@@ -633,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:*:* )
|
||||||
@@ -677,12 +689,13 @@ 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/'
|
||||||
@@ -763,97 +776,29 @@ EOF
|
|||||||
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
mips:Linux:*:*)
|
mips:Linux:*:*)
|
||||||
cat >$dummy.c <<EOF
|
case `sed -n '/^byte/s/^.*: \(.*\) endian/\1/p' < /proc/cpuinfo` in
|
||||||
#ifdef __cplusplus
|
big) echo mips-unknown-linux-gnu && exit 0 ;;
|
||||||
#include <stdio.h> /* for printf() prototype */
|
little) echo mipsel-unknown-linux-gnu && exit 0 ;;
|
||||||
int main (int argc, char *argv[]) {
|
esac
|
||||||
#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 -f $dummy.c $dummy && exit 0
|
|
||||||
rm -f $dummy.c $dummy
|
|
||||||
;;
|
;;
|
||||||
ppc:Linux:*:*)
|
ppc:Linux:*:*)
|
||||||
# Determine Lib Version
|
echo powerpc-unknown-linux-gnu
|
||||||
cat >$dummy.c <<EOF
|
exit 0 ;;
|
||||||
#include <features.h>
|
ppc64:Linux:*:*)
|
||||||
#if defined(__GLIBC__)
|
echo powerpc64-unknown-linux-gnu
|
||||||
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("unknown\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 ;;
|
exit 0 ;;
|
||||||
alpha:Linux:*:*)
|
alpha:Linux:*:*)
|
||||||
cat <<EOF >$dummy.s
|
case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
|
||||||
.data
|
EV5) UNAME_MACHINE=alphaev5 ;;
|
||||||
\$Lformat:
|
EV56) UNAME_MACHINE=alphaev56 ;;
|
||||||
.byte 37,100,45,37,120,10,0 # "%d-%x\n"
|
PCA56) UNAME_MACHINE=alphapca56 ;;
|
||||||
.text
|
PCA57) UNAME_MACHINE=alphapca56 ;;
|
||||||
.globl main
|
EV6) UNAME_MACHINE=alphaev6 ;;
|
||||||
.align 4
|
EV67) UNAME_MACHINE=alphaev67 ;;
|
||||||
.ent main
|
EV68*) UNAME_MACHINE=alphaev68 ;;
|
||||||
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
|
esac
|
||||||
objdump --private-headers $dummy | \
|
objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null
|
||||||
grep ld.so.1 > /dev/null
|
if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi
|
||||||
if test "$?" = 0 ; then
|
|
||||||
LIBC="libc1"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
rm -f $dummy.s $dummy
|
|
||||||
echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
|
echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
parisc:Linux:*:* | hppa:Linux:*:*)
|
parisc:Linux:*:* | hppa:Linux:*:*)
|
||||||
@@ -883,40 +828,30 @@ EOF
|
|||||||
# 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_supported_emulations=`cd /; ld --help 2>&1 \
|
ld_supported_targets=`cd /; ld --help 2>&1 \
|
||||||
| sed -ne '/supported emulations:/!d
|
| sed -ne '/supported targets:/!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
|
||||||
i*86linux)
|
elf32-i386)
|
||||||
echo "${UNAME_MACHINE}-pc-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
elf_i*86)
|
|
||||||
TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
|
TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
|
||||||
;;
|
;;
|
||||||
i*86coff)
|
a.out-i386-linux)
|
||||||
|
echo "${UNAME_MACHINE}-pc-linux-gnuaout"
|
||||||
|
exit 0 ;;
|
||||||
|
coff-i386)
|
||||||
echo "${UNAME_MACHINE}-pc-linux-gnucoff"
|
echo "${UNAME_MACHINE}-pc-linux-gnucoff"
|
||||||
exit 0
|
exit 0 ;;
|
||||||
;;
|
"")
|
||||||
esac
|
# Either a pre-BFD a.out linker (linux-gnuoldld) or
|
||||||
# Either a pre-BFD a.out linker (linux-gnuoldld)
|
# one that does not give us useful --help.
|
||||||
# or one that does not give us useful --help.
|
echo "${UNAME_MACHINE}-pc-linux-gnuoldld"
|
||||||
# GCC wants to distinguish between linux-gnuoldld and linux-gnuaout.
|
exit 0 ;;
|
||||||
# If ld does not provide *any* "supported emulations:"
|
|
||||||
# that means it is gnuoldld.
|
|
||||||
test -z "$ld_supported_emulations" && echo "${UNAME_MACHINE}-pc-linux-gnuoldld" && exit 0
|
|
||||||
case "${UNAME_MACHINE}" in
|
|
||||||
i*86)
|
|
||||||
VENDOR=pc;
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
VENDOR=unknown;
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
# Determine whether the default compiler is a.out or elf
|
# Determine whether the default compiler is a.out or elf
|
||||||
|
eval $set_cc_for_build
|
||||||
cat >$dummy.c <<EOF
|
cat >$dummy.c <<EOF
|
||||||
#include <features.h>
|
#include <features.h>
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
@@ -928,15 +863,15 @@ 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;
|
||||||
}
|
}
|
||||||
@@ -945,9 +880,10 @@ EOF
|
|||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
test x"${TENTATIVE}" != x && echo "${TENTATIVE}" && exit 0
|
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.*)
|
||||||
@@ -966,14 +902,13 @@ 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
|
||||||
@@ -1067,7 +1002,7 @@ 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 ;;
|
||||||
@@ -1080,6 +1015,10 @@ 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 ;;
|
||||||
@@ -1172,11 +1111,18 @@ EOF
|
|||||||
*:ITS:*:*)
|
*:ITS:*:*)
|
||||||
echo pdp10-unknown-its
|
echo pdp10-unknown-its
|
||||||
exit 0 ;;
|
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>
|
||||||
|
149
config.sub
vendored
149
config.sub
vendored
@@ -3,7 +3,7 @@
|
|||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
# Free Software Foundation, Inc.
|
# Free Software Foundation, Inc.
|
||||||
|
|
||||||
timestamp='2001-04-20'
|
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
|
||||||
@@ -117,7 +117,7 @@ esac
|
|||||||
# 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* | storm-chaos* | os2-emx*)
|
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/'`
|
||||||
;;
|
;;
|
||||||
@@ -157,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
|
||||||
;;
|
;;
|
||||||
@@ -215,26 +223,36 @@ 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 \
|
1750a | 580 \
|
||||||
| arm | arme[lb] | arm[bl]e | armv[2345] | armv[345][lb] | strongarm | xscale \
|
| a29k \
|
||||||
| pyramid | mn10200 | mn10300 | tron | a29k \
|
| alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
|
||||||
| 580 | i960 | h8300 \
|
| arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr \
|
||||||
| x86 | ppcbe | mipsbe | mipsle | shbe | shle \
|
| c4x | clipper \
|
||||||
| hppa | hppa1.0 | hppa1.1 | hppa2.0 | hppa2.0w | hppa2.0n \
|
| d10v | d30v | dsp16xx \
|
||||||
| hppa64 \
|
| fr30 \
|
||||||
| alpha | alphaev[4-8] | alphaev56 | alphapca5[67] \
|
| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
|
||||||
| alphaev6[78] \
|
| i370 | i860 | i960 | ia64 \
|
||||||
| we32k | ns16k | clipper | i370 | sh | sh[34] \
|
| m32r | m68000 | m68k | m88k | mcore \
|
||||||
| powerpc | powerpcle \
|
| mips16 | mips64 | mips64el | mips64orion | mips64orionel \
|
||||||
| 1750a | dsp16xx | pdp10 | pdp11 \
|
| mips64vr4100 | mips64vr4100el | mips64vr4300 \
|
||||||
| mips16 | mips64 | mipsel | mips64el \
|
| mips64vr4300el | mips64vr5000 | mips64vr5000el \
|
||||||
| mips64orion | mips64orionel | mipstx39 | mipstx39el \
|
| mipsbe | mipseb | mipsel | mipsle | mipstx39 | mipstx39el \
|
||||||
| mips64vr4300 | mips64vr4300el | mips64vr4100 | mips64vr4100el \
|
| mipsisa32 \
|
||||||
| mips64vr5000 | miprs64vr5000el | mcore | s390 | s390x \
|
| mn10200 | mn10300 \
|
||||||
| sparc | sparclet | sparclite | sparc64 | sparcv9 | sparcv9b \
|
| ns16k | ns32k \
|
||||||
| v850 | c4x \
|
| openrisc \
|
||||||
| thumb | d10v | d30v | fr30 | avr | openrisc | tic80 \
|
| pdp10 | pdp11 | pj | pjl \
|
||||||
| pj | pjl | h8500)
|
| 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
|
||||||
;;
|
;;
|
||||||
m6811 | m68hc11 | m6812 | m68hc12)
|
m6811 | m68hc11 | m6812 | m68hc12)
|
||||||
@@ -242,7 +260,7 @@ case $basic_machine in
|
|||||||
basic_machine=$basic_machine-unknown
|
basic_machine=$basic_machine-unknown
|
||||||
os=-none
|
os=-none
|
||||||
;;
|
;;
|
||||||
m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | z8k | v70 | w65)
|
m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
|
||||||
;;
|
;;
|
||||||
|
|
||||||
# We use `pc' rather than `unknown'
|
# We use `pc' rather than `unknown'
|
||||||
@@ -257,31 +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*86-* | i860-* | ia64-* | m32r-* | m68k-* | m68000-* \
|
| a29k-* \
|
||||||
| m88k-* | sparc-* | ns32k-* | fx80-* | arc-* | c[123]* \
|
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
|
||||||
| arm-* | armbe-* | armle-* | armv*-* | strongarm-* | xscale-* \
|
| alphapca5[67]-* | arc-* \
|
||||||
| mips-* | pyramid-* | tron-* | a29k-* | romp-* | rs6000-* \
|
| arm-* | armbe-* | armle-* | armv*-* \
|
||||||
| power-* | none-* | 580-* | cray2-* | h8300-* | h8500-* | i960-* \
|
| bs2000-* \
|
||||||
| xmp-* | ymp-* \
|
| c[123]* | c30-* | [cjt]90-* | c54x-* \
|
||||||
| x86-* | ppcbe-* | mipsbe-* | mipsle-* | shbe-* | shle-* \
|
| clipper-* | cray2-* | cydra-* \
|
||||||
| hppa-* | hppa1.0-* | hppa1.1-* | hppa2.0-* | hppa2.0w-* \
|
| d10v-* | d30v-* \
|
||||||
| hppa2.0n-* | hppa64-* \
|
| elxsi-* \
|
||||||
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphapca5[67]-* \
|
| f30[01]-* | f700-* | fr30-* | fx80-* \
|
||||||
| alphaev6[78]-* \
|
| h8300-* | h8500-* \
|
||||||
| we32k-* | cydra-* | ns16k-* | pn-* | np1-* | xps100-* \
|
| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
|
||||||
| clipper-* | orion-* \
|
| i*86-* | i860-* | i960-* | ia64-* \
|
||||||
| sparclite-* | pdp10-* | pdp11-* | sh-* | powerpc-* | powerpcle-* \
|
| m32r-* \
|
||||||
| sparc64-* | sparcv9-* | sparcv9b-* | sparc86x-* \
|
| m68000-* | m680[01234]0-* | m68360-* | m683?2-* | m68k-* \
|
||||||
| mips16-* | mips64-* | mipsel-* \
|
| m88110-* | m88k-* | mcore-* \
|
||||||
| mips64el-* | mips64orion-* | mips64orionel-* \
|
| mips-* | mips16-* | mips64-* | mips64el-* | mips64orion-* \
|
||||||
| mips64vr4100-* | mips64vr4100el-* | mips64vr4300-* | mips64vr4300el-* \
|
| mips64orionel-* | mips64vr4100-* | mips64vr4100el-* \
|
||||||
| mipstx39-* | mipstx39el-* | mcore-* \
|
| mips64vr4300-* | mips64vr4300el-* | mipsbe-* | mipseb-* \
|
||||||
| f30[01]-* | f700-* | s390-* | s390x-* | sv1-* | t3e-* \
|
| mipsle-* | mipsel-* | mipstx39-* | mipstx39el-* \
|
||||||
| [cjt]90-* \
|
| none-* | np1-* | ns16k-* | ns32k-* \
|
||||||
| m88110-* | m680[01234]0-* | m683?2-* | m68360-* | z8k-* | d10v-* \
|
| orion-* \
|
||||||
| thumb-* | v850-* | d30v-* | tic30-* | tic80-* | c30-* | fr30-* \
|
| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
|
||||||
| bs2000-* | tic54x-* | c54x-* | x86_64-* | pj-* | pjl-*)
|
| 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.
|
||||||
@@ -727,6 +757,16 @@ 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
|
||||||
;;
|
;;
|
||||||
@@ -881,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
|
||||||
@@ -934,7 +978,7 @@ case $basic_machine in
|
|||||||
we32k)
|
we32k)
|
||||||
basic_machine=we32k-att
|
basic_machine=we32k-att
|
||||||
;;
|
;;
|
||||||
sh3 | sh4)
|
sh3 | sh4 | sh3eb | sh4eb)
|
||||||
basic_machine=sh-unknown
|
basic_machine=sh-unknown
|
||||||
;;
|
;;
|
||||||
sparc | sparcv9 | sparcv9b)
|
sparc | sparcv9 | sparcv9b)
|
||||||
@@ -1018,11 +1062,13 @@ 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* | -conix* | -pw32* | -nonstopux* \
|
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
|
||||||
| -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* | -os2*)
|
| -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*)
|
||||||
@@ -1346,6 +1392,9 @@ case $basic_machine in
|
|||||||
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
|
-*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/"`
|
||||||
;;
|
;;
|
||||||
|
344
configure.in
344
configure.in
@@ -1,9 +1,16 @@
|
|||||||
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.
|
||||||
|
|
||||||
|
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_INIT
|
||||||
AC_CONFIG_SRCDIR([lib/urldata.h])
|
AC_CONFIG_SRCDIR([lib/urldata.h])
|
||||||
AM_CONFIG_HEADER(config.h src/config.h)
|
AM_CONFIG_HEADER(config.h src/config.h)
|
||||||
|
|
||||||
|
dnl figure out the libcurl version
|
||||||
VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h`
|
VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h`
|
||||||
AM_INIT_AUTOMAKE(curl,$VERSION)
|
AM_INIT_AUTOMAKE(curl,$VERSION)
|
||||||
|
|
||||||
@@ -38,6 +45,10 @@ 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
|
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
|
||||||
@@ -58,274 +69,12 @@ AC_ARG_ENABLE(debug,
|
|||||||
*) AC_MSG_RESULT(yes)
|
*) AC_MSG_RESULT(yes)
|
||||||
|
|
||||||
CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG"
|
CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG"
|
||||||
CFLAGS="-Wall -pedantic -g"
|
CFLAGS="-W -Wall -Wwrite-strings -pedantic -g"
|
||||||
;;
|
;;
|
||||||
esac ],
|
esac ],
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
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_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])])
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Checks for IPv6
|
dnl Checks for IPv6
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -420,6 +169,24 @@ AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
|||||||
dnl dl lib?
|
dnl dl lib?
|
||||||
AC_CHECK_FUNC(dlclose, , 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 **********************************************************************
|
||||||
dnl Check for the random seed preferences
|
dnl Check for the random seed preferences
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -559,13 +326,22 @@ then
|
|||||||
else
|
else
|
||||||
|
|
||||||
dnl Check for and handle argument to --with-ssl.
|
dnl Check for and handle argument to --with-ssl.
|
||||||
EXTRA_SSL=
|
|
||||||
|
dnl save the pre-ssl check flags for a while
|
||||||
|
CLEANLDFLAGS="$LDFLAGS"
|
||||||
|
CLEANCPPFLAGS="$CPPFLAGS"
|
||||||
|
|
||||||
case "$OPT_SSL" in
|
case "$OPT_SSL" in
|
||||||
yes)
|
yes)
|
||||||
EXTRA_SSL=/usr/local/ssl ;;
|
EXTRA_SSL=/usr/local/ssl ;;
|
||||||
|
off)
|
||||||
|
EXTRA_SSL= ;;
|
||||||
*)
|
*)
|
||||||
EXTRA_SSL=$OPT_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
|
esac
|
||||||
|
|
||||||
AC_CHECK_LIB(crypto, CRYPTO_lock,[
|
AC_CHECK_LIB(crypto, CRYPTO_lock,[
|
||||||
@@ -573,8 +349,8 @@ else
|
|||||||
],[
|
],[
|
||||||
OLDLDFLAGS="$LDFLAGS"
|
OLDLDFLAGS="$LDFLAGS"
|
||||||
OLDCPPFLAGS="$CPPFLAGS"
|
OLDCPPFLAGS="$CPPFLAGS"
|
||||||
LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib"
|
LDFLAGS="$CLEANLDFLAGS -L$EXTRA_SSL/lib"
|
||||||
CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
|
CPPFLAGS="$CLEANCPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
|
||||||
AC_CHECK_LIB(crypto, CRYPTO_add_lock,[
|
AC_CHECK_LIB(crypto, CRYPTO_add_lock,[
|
||||||
HAVECRYPTO="yes" ], [
|
HAVECRYPTO="yes" ], [
|
||||||
LDFLAGS="$OLDLDFLAGS"
|
LDFLAGS="$OLDLDFLAGS"
|
||||||
@@ -727,7 +503,9 @@ AC_CHECK_HEADERS( \
|
|||||||
winsock.h \
|
winsock.h \
|
||||||
time.h \
|
time.h \
|
||||||
io.h \
|
io.h \
|
||||||
pwd.h
|
pwd.h \
|
||||||
|
utime.h \
|
||||||
|
sys/utime.h
|
||||||
)
|
)
|
||||||
|
|
||||||
dnl Check for libz header
|
dnl Check for libz header
|
||||||
@@ -748,26 +526,7 @@ AC_CHECK_SIZEOF(long long, 4)
|
|||||||
# check for ssize_t
|
# check for ssize_t
|
||||||
AC_CHECK_TYPE(ssize_t, int)
|
AC_CHECK_TYPE(ssize_t, int)
|
||||||
|
|
||||||
dnl
|
TYPE_SOCKLEN_T
|
||||||
dnl We can't just AC_CHECK_TYPE() for socklen_t since it doesn't appear
|
|
||||||
dnl in the standard headers. We egrep for it in the socket headers and
|
|
||||||
dnl if it is used there we assume we have the type defined, otherwise
|
|
||||||
dnl we search for it with AC_CHECK_TYPE() the "normal" way
|
|
||||||
dnl
|
|
||||||
|
|
||||||
if test "$ac_cv_header_sys_socket_h" = "yes"; then
|
|
||||||
AC_MSG_CHECKING(for socklen_t in sys/socket.h)
|
|
||||||
AC_EGREP_HEADER(socklen_t,
|
|
||||||
sys/socket.h,
|
|
||||||
socklen_t=yes
|
|
||||||
AC_MSG_RESULT(yes),
|
|
||||||
AC_MSG_RESULT(no))
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$socklen_t" != "yes"; then
|
|
||||||
# check for socklen_t the standard way if it wasn't found before
|
|
||||||
AC_CHECK_TYPE(socklen_t, int)
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl Checks for library functions.
|
dnl Checks for library functions.
|
||||||
dnl AC_PROG_GCC_TRADITIONAL
|
dnl AC_PROG_GCC_TRADITIONAL
|
||||||
@@ -785,7 +544,6 @@ AC_CHECK_FUNCS( socket \
|
|||||||
strcmpi \
|
strcmpi \
|
||||||
gethostname \
|
gethostname \
|
||||||
gethostbyaddr \
|
gethostbyaddr \
|
||||||
getservbyname \
|
|
||||||
gettimeofday \
|
gettimeofday \
|
||||||
inet_addr \
|
inet_addr \
|
||||||
inet_ntoa \
|
inet_ntoa \
|
||||||
@@ -800,7 +558,8 @@ AC_CHECK_FUNCS( socket \
|
|||||||
strlcat \
|
strlcat \
|
||||||
getpwuid \
|
getpwuid \
|
||||||
geteuid \
|
geteuid \
|
||||||
dlopen
|
dlopen \
|
||||||
|
utime
|
||||||
)
|
)
|
||||||
|
|
||||||
dnl removed 'getpass' check on October 26, 2000
|
dnl removed 'getpass' check on October 26, 2000
|
||||||
@@ -837,15 +596,12 @@ AC_CONFIG_FILES([Makefile \
|
|||||||
tests/data/Makefile \
|
tests/data/Makefile \
|
||||||
packages/Makefile \
|
packages/Makefile \
|
||||||
packages/Win32/Makefile \
|
packages/Win32/Makefile \
|
||||||
|
packages/Win32/cygwin/Makefile \
|
||||||
packages/Linux/Makefile \
|
packages/Linux/Makefile \
|
||||||
packages/Linux/RPM/Makefile \
|
packages/Linux/RPM/Makefile \
|
||||||
packages/Linux/RPM/curl.spec \
|
packages/Linux/RPM/curl.spec \
|
||||||
packages/Linux/RPM/curl-ssl.spec \
|
packages/Linux/RPM/curl-ssl.spec \
|
||||||
packages/Solaris/Makefile \
|
packages/Solaris/Makefile \
|
||||||
perl/Makefile \
|
|
||||||
perl/Curl_easy/Makefile \
|
|
||||||
php/Makefile \
|
|
||||||
php/examples/Makefile \
|
|
||||||
curl-config
|
curl-config
|
||||||
])
|
])
|
||||||
AC_OUTPUT
|
AC_OUTPUT
|
||||||
|
@@ -73,14 +73,15 @@ while test $# -gt 0; do
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
--cflags)
|
--cflags)
|
||||||
echo @CPPFLAGS@
|
echo -I@includedir@
|
||||||
;;
|
;;
|
||||||
|
|
||||||
--libs)
|
--libs)
|
||||||
echo @LDFLAGS@ @LIBS@
|
echo -L@libdir@ -lcurl @LDFLAGS@ @LIBS@
|
||||||
;;
|
;;
|
||||||
|
|
||||||
*)
|
*)
|
||||||
|
echo "unknown option: $1"
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
|
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)
|
@@ -10,6 +10,12 @@ To Think About When Contributing Source Code
|
|||||||
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
|
||||||
@@ -21,6 +27,12 @@ The License Issue
|
|||||||
GPL (as we don't want the GPL virus to attack users of libcurl) but they must
|
GPL (as we don't want the GPL virus to attack users of libcurl) but they must
|
||||||
use "GPL compatible" licenses.
|
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
|
||||||
@@ -87,7 +99,9 @@ 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
|
||||||
|
|
||||||
|
60
docs/FAQ
60
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: May 29, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
Updated: November 1, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -14,6 +14,7 @@ FAQ
|
|||||||
1.4 When will you make curl do XXXX ?
|
1.4 When will you make curl do XXXX ?
|
||||||
1.5 Who makes cURL?
|
1.5 Who makes cURL?
|
||||||
1.6 What do you get for making cURL?
|
1.6 What do you get for making cURL?
|
||||||
|
1.7 What about CURL from curl.com?
|
||||||
|
|
||||||
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
|
||||||
@@ -35,6 +36,7 @@ FAQ
|
|||||||
3.9 How do I use curl in PHP, Perl, Tcl, Ruby or Java?
|
3.9 How do I use curl in PHP, Perl, Tcl, Ruby or Java?
|
||||||
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
3.11 How do I POST with a different Content-Type?
|
3.11 How do I POST with a different Content-Type?
|
||||||
|
3.12 Why do FTP specific features over HTTP proxy fails?
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
@@ -80,7 +82,7 @@ FAQ
|
|||||||
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, TELNET and FILE.
|
HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE.
|
||||||
|
|
||||||
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
||||||
[kurl].
|
[kurl].
|
||||||
@@ -95,10 +97,9 @@ FAQ
|
|||||||
|
|
||||||
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
|
||||||
@@ -133,7 +134,7 @@ FAQ
|
|||||||
|
|
||||||
* We 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 someone else to make all the work while you wait for us to
|
* If you want someone else to make all the work while you wait for us to
|
||||||
@@ -170,6 +171,25 @@ FAQ
|
|||||||
sourceforge.net hosts several project tools we take advantage from like the
|
sourceforge.net hosts several project tools we take advantage from like the
|
||||||
bug tracker, mailing lists and more.
|
bug tracker, mailing lists and more.
|
||||||
|
|
||||||
|
If you feel you want to show support our project with a donation, a very
|
||||||
|
nice way of doing that would be to buy "gift certificates" at useful online
|
||||||
|
shopping sites, such as amazon.com or thinkgeek.com.
|
||||||
|
|
||||||
|
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
|
||||||
@@ -355,6 +375,18 @@ FAQ
|
|||||||
|
|
||||||
curl -d "datatopost" -H "Content-Type: text/xml" [URL]
|
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 usuable 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.
|
||||||
@@ -447,9 +479,9 @@ FAQ
|
|||||||
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
|
appriciate 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 user names and passwords secret in Curl command lines?
|
4.7. How do I keep user names and passwords secret in Curl command lines?
|
||||||
|
|
||||||
@@ -553,13 +585,7 @@ FAQ
|
|||||||
|
|
||||||
5.4 Does libcurl do Winsock initialization on win32 systems?
|
5.4 Does libcurl do Winsock initialization on win32 systems?
|
||||||
|
|
||||||
No.
|
Yes (since 7.8.1) if told to in the curl_global_init() call.
|
||||||
|
|
||||||
On win32 systems, you need to init the winsock stuff manually, libcurl will
|
|
||||||
not do that for you. WSAStartup() and WSACleanup() should be used
|
|
||||||
accordingly. The reason for this is of course that a single application may
|
|
||||||
use several different libraries and parts, and there's no reason for every
|
|
||||||
single library to do this.
|
|
||||||
|
|
||||||
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
|
|
||||||
|
138
docs/INSTALL
138
docs/INSTALL
@@ -6,13 +6,14 @@
|
|||||||
|
|
||||||
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/ME/2000 or whatever) or OS/2, you should
|
Most systems build curl the same way (unix-style). Continue reading below for
|
||||||
continue reading from the Win32 or OS/2 headers further down. All other
|
more details if you're one of them.
|
||||||
systems should be capable of 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
|
||||||
====
|
====
|
||||||
@@ -255,17 +256,127 @@ 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
|
||||||
|
|
||||||
|
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
|
||||||
=====
|
=====
|
||||||
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:
|
||||||
|
|
||||||
- Ultrix 4.3a
|
|
||||||
- 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
|
||||||
- MIPS IRIX 6.2, 6.5
|
- MIPS IRIX 6.2, 6.5
|
||||||
@@ -273,9 +384,14 @@ PORTS
|
|||||||
- PowerPC Darwin 1.0
|
- PowerPC Darwin 1.0
|
||||||
- PowerPC Linux
|
- PowerPC Linux
|
||||||
- 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.X
|
- 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 Linux 1.3, 2.0, 2.2, 2.3, 2.4
|
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4
|
||||||
@@ -288,7 +404,7 @@ PORTS
|
|||||||
- ia64 Linux 2.3.99
|
- ia64 Linux 2.3.99
|
||||||
- m68k AmigaOS 3
|
- m68k AmigaOS 3
|
||||||
- m68k OpenBSD
|
- m68k OpenBSD
|
||||||
- StrongARM NetBSD 1.4.1
|
- s390 Linux
|
||||||
|
|
||||||
OpenSSL
|
OpenSSL
|
||||||
=======
|
=======
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
Updated for curl 7.8 on May 29, 2001
|
Updated for curl 7.9.1 on November 2, 2001
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -78,15 +78,15 @@ Library
|
|||||||
makes sure we stay absolutely platform independent.
|
makes sure we stay absolutely platform independent.
|
||||||
|
|
||||||
curl_easy_init() allocates an internal struct and makes some initializations.
|
curl_easy_init() allocates an internal struct and makes some initializations.
|
||||||
The returned handle does not reveal internals. This is the 'UrlData' struct
|
The returned handle does not reveal internals. This is the 'SessionHandle'
|
||||||
which works as a global "anchor" struct. All connections performed will get
|
struct which works as an "anchor" struct for all curl_easy functions. All
|
||||||
connect-specific data allocated that should be used for things related to
|
connections performed will get connect-specific data allocated that should be
|
||||||
particular connections/requests.
|
used for things related to particular connections/requests.
|
||||||
|
|
||||||
curl_easy_setopt() takes three arguments, where the option stuff must be
|
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
|
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
|
options is documented in the man page. This function mainly sets things in
|
||||||
the 'UrlData' struct.
|
the 'SessionHandle' struct.
|
||||||
|
|
||||||
curl_easy_perform() does a whole lot of things:
|
curl_easy_perform() does a whole lot of things:
|
||||||
|
|
||||||
@@ -106,7 +106,7 @@ Library
|
|||||||
This function makes sure there's an allocated and initiated 'connectdata'
|
This function makes sure there's an allocated and initiated 'connectdata'
|
||||||
struct that is used for this particular connection only (although there may
|
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
|
be several requests performed on the same connect). A bunch of things are
|
||||||
inited/inherited from the UrlData struct.
|
inited/inherited from the SessionHandle struct.
|
||||||
|
|
||||||
o Curl_do()
|
o Curl_do()
|
||||||
|
|
||||||
@@ -123,6 +123,13 @@ Library
|
|||||||
Curl_Transfer() function (in lib/transfer.c) to setup the transfer and
|
Curl_Transfer() function (in lib/transfer.c) to setup the transfer and
|
||||||
returns.
|
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()
|
o Transfer()
|
||||||
|
|
||||||
Curl_perform() then calls Transfer() in lib/transfer.c that performs
|
Curl_perform() then calls Transfer() in lib/transfer.c that performs
|
||||||
@@ -144,7 +151,7 @@ Library
|
|||||||
o Curl_disconnect()
|
o Curl_disconnect()
|
||||||
|
|
||||||
When doing normal connections and transfers, no one ever tries to close any
|
When doing normal connections and transfers, no one ever tries to close any
|
||||||
connection so this is not normally called when curl_easy_perform() is
|
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
|
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
|
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
|
it can be called to make sure that libcurl doesn't keep too many
|
||||||
@@ -258,12 +265,12 @@ Persistent Connections
|
|||||||
The persistent connection support in libcurl requires some considerations on
|
The persistent connection support in libcurl requires some considerations on
|
||||||
how to do things inside of the library.
|
how to do things inside of the library.
|
||||||
|
|
||||||
o The 'UrlData' struct returned in the curl_easy_init() call must never
|
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
|
hold connection-oriented data. It is meant to hold the root data as well as
|
||||||
as all the options etc that the library-user may choose.
|
all the options etc that the library-user may choose.
|
||||||
o The 'UrlData' struct holds the "connection cache" (an array of pointers to
|
o The 'SessionHandle' struct holds the "connection cache" (an array of
|
||||||
'connectdata' structs). There's one connectdata struct allocated for each
|
pointers to 'connectdata' structs). There's one connectdata struct
|
||||||
connection that libcurl knows about.
|
allocated for each connection that libcurl knows about.
|
||||||
o This also enables the 'curl handle' to be reused on subsequent transfers,
|
o This also enables the 'curl handle' to be reused on subsequent transfers,
|
||||||
something that was illegal before libcurl 7.7.
|
something that was illegal before libcurl 7.7.
|
||||||
o When we are about to perform a transfer with curl_easy_perform(), we first
|
o When we are about to perform a transfer with curl_easy_perform(), we first
|
||||||
|
117
docs/LIBCURL
117
docs/LIBCURL
@@ -1,117 +0,0 @@
|
|||||||
_ _ _ _
|
|
||||||
| (_) |__ ___ _ _ _ __| |
|
|
||||||
| | | '_ \ / __| | | | '__| |
|
|
||||||
| | | |_) | (__| |_| | | | |
|
|
||||||
|_|_|_.__/ \___|\__,_|_| |_|
|
|
||||||
|
|
||||||
How To Use Libcurl In Your C/C++ Program
|
|
||||||
|
|
||||||
[ libcurl can be used directly from within your Java, PHP, Perl, Ruby or Tcl
|
|
||||||
programs as well, look elsewhere for documentation on this ]
|
|
||||||
|
|
||||||
The interface is meant to be very simple for applictions/programmers, hence
|
|
||||||
the name "easy". We have therefore minimized the number of entries.
|
|
||||||
|
|
||||||
The Easy Interface
|
|
||||||
|
|
||||||
When using the easy interface, you init your session and get a handle, which
|
|
||||||
you use as input to the following interface functions you use. Use
|
|
||||||
curl_easy_init() 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. curl_easy_setopt() is there for this.
|
|
||||||
|
|
||||||
When all is setup, you tell libcurl to perform the transfer using
|
|
||||||
curl_easy_perform(). 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 session with
|
|
||||||
curl_easy_cleanup() and libcurl is entirely off the hook! If you want
|
|
||||||
persistant connections, you don't cleanup immediately, but instead run ahead
|
|
||||||
and perform other transfers. See the chapter below for Persistant
|
|
||||||
Connections.
|
|
||||||
|
|
||||||
While the above mentioned four functions are the main functions to use in the
|
|
||||||
easy interface, there is a series of other 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_easy_getinfo() - get information about a performed transfer
|
|
||||||
curl_formparse() - helps building a HTTP form POST
|
|
||||||
curl_formfree() - free a list built with curl_formparse()
|
|
||||||
curl_slist_append() - builds a linked list
|
|
||||||
curl_slist_free_all() - frees a whole curl_slist
|
|
||||||
|
|
||||||
For details on these, read the separate man pages.
|
|
||||||
|
|
||||||
Linking with libcurl
|
|
||||||
|
|
||||||
Staring 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.
|
|
||||||
|
|
||||||
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!
|
|
||||||
|
|
||||||
Portability
|
|
||||||
|
|
||||||
libcurl works *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.
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
||||||
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
|
|
||||||
|
|
||||||
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 defined behaviour.
|
|
||||||
|
|
17
docs/MANUAL
17
docs/MANUAL
@@ -132,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:
|
||||||
|
|
||||||
@@ -157,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.
|
||||||
@@ -591,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
|
||||||
@@ -756,6 +756,17 @@ TELNET
|
|||||||
You might want the -N/--no-buffer option to switch off the buffered output
|
You might want the -N/--no-buffer option to switch off the buffered output
|
||||||
for slow connections or similar.
|
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
|
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
|
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
|
to track when the login prompt is received and send the username and
|
||||||
|
@@ -12,7 +12,9 @@ man_MANS = \
|
|||||||
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_formfree.3 \
|
||||||
curl_getdate.3 \
|
curl_getdate.3 \
|
||||||
curl_getenv.3 \
|
curl_getenv.3 \
|
||||||
@@ -26,10 +28,49 @@ man_MANS = \
|
|||||||
curl_mprintf.3 \
|
curl_mprintf.3 \
|
||||||
curl_global_init.3 \
|
curl_global_init.3 \
|
||||||
curl_global_cleanup.3 \
|
curl_global_cleanup.3 \
|
||||||
libcurl.5
|
libcurl.3
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS) \
|
EXTRA_DIST = $(man_MANS) \
|
||||||
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
||||||
LIBCURL README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS
|
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS \
|
||||||
|
$(HTMLPAGES)
|
||||||
|
|
||||||
SUBDIRS = examples
|
MAN2HTML= gnroff -man $< | man2html >$@
|
||||||
|
|
||||||
|
SUFFIXES = .1 .3 .html
|
||||||
|
|
||||||
|
html: $(HTMLPAGES)
|
||||||
|
|
||||||
|
.3.html:
|
||||||
|
$(MAN2HTML)
|
||||||
|
|
||||||
|
.1.html:
|
||||||
|
$(MAN2HTML)
|
||||||
|
@@ -69,3 +69,9 @@ that have contributed with non-trivial parts:
|
|||||||
- S. Moonesamy
|
- S. Moonesamy
|
||||||
- Ingo Wilken <iw@WWW.Ecce-Terram.DE>
|
- Ingo Wilken <iw@WWW.Ecce-Terram.DE>
|
||||||
- Pawel A. Gajda <mis@k2.net.pl>
|
- Pawel A. Gajda <mis@k2.net.pl>
|
||||||
|
- Patrick Bihan-Faou
|
||||||
|
- 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>
|
||||||
|
100
docs/TODO
100
docs/TODO
@@ -7,51 +7,72 @@
|
|||||||
TODO
|
TODO
|
||||||
|
|
||||||
Things to do in project cURL. Please tell me what you think, contribute and
|
Things to do in project cURL. Please tell me what you think, contribute and
|
||||||
send me patches that improve things!
|
send me patches that improve things! Also check the http://curl.haxx.se/dev
|
||||||
|
web section for various development notes.
|
||||||
|
|
||||||
To do in a future release (random order):
|
LIBCURL
|
||||||
|
|
||||||
* 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. Note: is this really prioritized now with the persistent
|
know what cookies that are sent back in the response headers.
|
||||||
connections?
|
|
||||||
|
|
||||||
* Suggested on the mailing list: CURLOPT_FTP_MKDIR...!
|
* Make content encoding/decoding internally be made using a filter system.
|
||||||
|
|
||||||
* Rewrite parts of the test suite. Make a (XML?) format to store all
|
* The new 'multi' interface is being designed. Work out the details, start
|
||||||
test-data in a single for a single test case. The current system makes far
|
implementing and write test applications!
|
||||||
too many separate files. We also need to have the test suite support
|
[http://curl.haxx.se/dev/multi.h]
|
||||||
different behaviors, like when libcurl is compiled for IPv6 support and
|
|
||||||
thus performs a different set of FTP commands.
|
* Add a name resolve cache to libcurl to make repeated fetches to the same
|
||||||
|
host name (when persitancy isn't available) faster.
|
||||||
|
|
||||||
|
* Introduce another callback interface for upload/download that makes one
|
||||||
|
less copy of data and thus a faster operation.
|
||||||
|
[http://curl.haxx.se/dev/no_copy_callbacks.txt]
|
||||||
|
|
||||||
* Add configure options that disables certain protocols in libcurl to
|
* Add configure options that disables certain protocols in libcurl to
|
||||||
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
||||||
telnet, ldap, dict or file.
|
telnet, ldap, dict or file.
|
||||||
|
|
||||||
* Extend the test suite to include telnet. The telnet could just do ftp or
|
* Add asynchronous name resolving. http://curl.haxx.se/dev/async-resolver.txt
|
||||||
http operations (for which we have test servers).
|
|
||||||
|
|
||||||
* Add a command line option that allows the output file to get the same time
|
DOCUMENTATION
|
||||||
stamp as the remote file. libcurl already is capable of fetching the remote
|
|
||||||
file's date.
|
|
||||||
|
|
||||||
* Make curl's SSL layer option capable of using other free SSL libraries.
|
* Document all CURLcode error codes, why they happen and what most likely
|
||||||
Such as the Mozilla Security Services
|
will make them not happen again.
|
||||||
(http://www.mozilla.org/projects/security/pki/nss/) and GNUTLS
|
|
||||||
(http://gnutls.hellug.gr/)
|
|
||||||
|
|
||||||
* Add asynchronous name resolving, as this enables full timeout support for
|
FTP
|
||||||
fork() systems.
|
|
||||||
|
|
||||||
* Move non-URL related functions that are used by both the lib and the curl
|
* FTP ASCII upload does not follow RFC959 section 3.1.1.1: "The sender
|
||||||
application to a separate "portability lib".
|
converts the data from an internal character representation to the standard
|
||||||
|
8-bit NVT-ASCII representation (see the Telnet specification). The
|
||||||
|
receiver will convert the data from the standard form to his own internal
|
||||||
|
form."
|
||||||
|
|
||||||
* Add libcurl support/interfaces for more languages. C++ wrapper perhaps?
|
* 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.
|
||||||
|
|
||||||
|
* Suggested on the mailing list: CURLOPT_FTP_MKDIR...!
|
||||||
|
|
||||||
|
* 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!
|
||||||
|
|
||||||
|
* Make FTP PASV work with IPv6 support. RFC 2428 "FTP Extensions for IPv6 and
|
||||||
|
NATs" is interesting.
|
||||||
|
|
||||||
|
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
|
* "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
|
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
|
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
|
since it proved more work than we thought. It is still a good idea to
|
||||||
implement though.
|
implement though. This requires the filter system mentioned above.
|
||||||
|
|
||||||
* Authentication: NTLM. Support for that MS crap called NTLM
|
* 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
|
||||||
@@ -74,10 +95,27 @@ To do in a future release (random order):
|
|||||||
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.
|
||||||
|
|
||||||
* Other proxies
|
TELNET
|
||||||
Ftp-kind proxy, Socks5, whatever kind of proxies are there?
|
|
||||||
|
|
||||||
* Full IPv6 Awareness and support. (This is partly done.) RFC 2428 "FTP
|
* Make TELNET work on windows98!
|
||||||
Extensions for IPv6 and NATs" is interesting. PORT should be replaced with
|
|
||||||
EPRT for IPv6 (done), and EPSV instead of PASV.
|
|
||||||
|
|
||||||
|
SSL
|
||||||
|
|
||||||
|
* 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/)
|
||||||
|
|
||||||
|
LDAP
|
||||||
|
|
||||||
|
* Multiple URL requests don't work. [http://sourceforge.net/tracker/index.php?func=detail&aid=475407&group_id=976&atid=100976]
|
||||||
|
|
||||||
|
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
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man curl-config.1
|
.\" nroff -man curl-config.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl-config 1 "28 May 2001" "Curl 7.8" "curl-config manual"
|
.TH curl-config 1 "16 August 2001" "Curl 7.8.1" "curl-config manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl-config \- Get information about a libcurl installation
|
curl-config \- Get information about a libcurl installation
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -12,8 +12,8 @@ curl-config \- Get information about a libcurl installation
|
|||||||
displays information about a previous curl and libcurl installation.
|
displays information about a previous curl and libcurl installation.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
.IP "--cflags"
|
.IP "--cflags"
|
||||||
What set of CFLAGS that was used when libcurl was built. This is mostly a
|
Set of compiler options (CFLAGS) to use when compiling files that use
|
||||||
debug option that serves no particular use to most people.
|
libcurl. Currently that is only thw include path to the curl include files.
|
||||||
.IP "--feature"
|
.IP "--feature"
|
||||||
Lists what particular main features the installed libcurl was built with. At
|
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
|
the time of writing, this list may include SSL, KRB4 or IPv6. Do not assume
|
||||||
@@ -36,18 +36,14 @@ 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
|
major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl
|
||||||
12.13.14 would appear as 0c0d0e...
|
12.13.14 would appear as 0c0d0e...
|
||||||
.SH "EXAMPLES"
|
.SH "EXAMPLES"
|
||||||
What is the path to the curl header files?
|
What linker options do I need when I link with libcurl?
|
||||||
|
|
||||||
echo `curl-config --prefix`/include
|
|
||||||
|
|
||||||
What is the path to libcurl?
|
|
||||||
|
|
||||||
echo `curl-config --prefix`/lib
|
|
||||||
|
|
||||||
What other linker options do I need when I link with libcurl?
|
|
||||||
|
|
||||||
curl-config --libs
|
curl-config --libs
|
||||||
|
|
||||||
|
What compiler options do I need when I compile using libcurl functions?
|
||||||
|
|
||||||
|
curl-config --cflags
|
||||||
|
|
||||||
How do I know if libcurl was built with SSL support?
|
How do I know if libcurl was built with SSL support?
|
||||||
|
|
||||||
curl-config --feature | grep SSL
|
curl-config --feature | grep SSL
|
||||||
|
68
docs/curl.1
68
docs/curl.1
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man curl.1
|
.\" nroff -man curl.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl 1 "8 May 2001" "Curl 7.7.3" "Curl Manual"
|
.TH curl 1 "30 Oct 2001" "Curl 7.9.1" "Curl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl \- get a URL with FTP, TELNET, LDAP, GOPHER, DICT, FILE, HTTP or
|
curl \- get a URL with FTP, TELNET, LDAP, GOPHER, DICT, FILE, HTTP or
|
||||||
HTTPS syntax.
|
HTTPS syntax.
|
||||||
@@ -91,6 +91,12 @@ also be enforced by using an URL that ends with ";type=A". This option causes
|
|||||||
data sent to stdout to be in text mode for win32 systems.
|
data sent to stdout to be in text mode for win32 systems.
|
||||||
|
|
||||||
If this option is used twice, the second one will disable ASCII usage.
|
If this option is used twice, the second one will disable ASCII usage.
|
||||||
|
.IP "--ciphers <list of ciphers>"
|
||||||
|
(SSL) Specifies which ciphers to use in the connection. The list of ciphers
|
||||||
|
must be using valid ciphers. Read up on SSL cipher list details on this URL:
|
||||||
|
.I http://www.openssl.org/docs/apps/ciphers.html (Option added in curl 7.9)
|
||||||
|
|
||||||
|
If this option is used severl times, the last one will override the others.
|
||||||
.IP "--connect-timeout <seconds>"
|
.IP "--connect-timeout <seconds>"
|
||||||
Maximum time in seconds that you allow the connection to the server to take.
|
Maximum time in seconds that you allow the connection to the server to take.
|
||||||
This only limits the connection phase, once curl has connected this option is
|
This only limits the connection phase, once curl has connected this option is
|
||||||
@@ -100,15 +106,16 @@ also the
|
|||||||
option.
|
option.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-c/--continue"
|
.IP "-c/--cookie-jar <file name>"
|
||||||
.B Deprecated. Use '-C -' instead.
|
Specify to which file you want curl to write all cookies after a completed
|
||||||
Continue/Resume a previous file transfer. This instructs curl to
|
operation. Curl writes all cookies previously read from a specified file as
|
||||||
continue appending data on the file where it was previously left,
|
well as all cookies received from remote server(s). If no cookies are known,
|
||||||
possibly because of a broken connection to the server. There must be
|
no file will be written. The file will be written using the Netscape cookie
|
||||||
a named physical file to append to for this to work.
|
file format. If you set the file name to a single dash, "-", the cookies will
|
||||||
Note: Upload resume is depening on a command named SIZE not always
|
be written to stdout. (Option added in curl 7.9)
|
||||||
present in all ftp servers! Upload resume is for FTP only.
|
|
||||||
HTTP resume is only possible with HTTP/1.1 or later servers.
|
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 is the exact number of bytes that will be skipped
|
given offset is the exact number of bytes that will be skipped
|
||||||
@@ -134,7 +141,8 @@ name=daniel -d skill=lousy' would generate a post chunk that looks like
|
|||||||
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.
|
||||||
|
|
||||||
@@ -232,6 +240,11 @@ you can specify URLs that contain the letters {}[] without having them being
|
|||||||
interpreted by curl itself. Note that these letters are not normal legal URL
|
interpreted by curl itself. Note that these letters are not normal legal URL
|
||||||
contents but they should be encoded according to the URI standard. (Option
|
contents but they should be encoded according to the URI standard. (Option
|
||||||
added in curl 7.6)
|
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>"
|
||||||
@@ -318,6 +331,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
|
||||||
@@ -446,6 +461,12 @@ 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.
|
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.
|
||||||
@@ -464,14 +485,15 @@ XDISPLOC=<X display> Sets the X display location.
|
|||||||
|
|
||||||
NEW_ENV=<var,val> Sets an environment variable.
|
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.
|
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
|
||||||
@@ -568,8 +590,13 @@ The average upload speed that curl measured for the complete upload.
|
|||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-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.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-X/--request <command>"
|
.IP "-X/--request <command>"
|
||||||
@@ -617,6 +644,9 @@ 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.
|
||||||
|
@@ -8,7 +8,7 @@ curl_easy_cleanup - End a libcurl session
|
|||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.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
|
||||||
|
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!
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.7" "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 session
|
curl_easy_init - Start a libcurl session
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -17,8 +17,10 @@ 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
|
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
|
transfers using the same curl handle. This enables libcurl to use persistant
|
||||||
@@ -27,6 +29,6 @@ connections where possible.
|
|||||||
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!
|
||||||
|
@@ -2,83 +2,84 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_setopt 3 "1 June 2001" "libcurl 7.8" "libcurl Manual"
|
.TH curl_easy_setopt 3 "11 Oct 2001" "libcurl 7.9.1" "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/curl.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 curl_easy_setopt() calls in the setup phase.
|
|
||||||
|
|
||||||
NOTE: strings passed to libcurl as 'char *' arguments, will not be copied by
|
\fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be
|
||||||
the library. Instead you should keep them available until libcurl no longer
|
copied by the library. Instead you should keep them available until libcurl no
|
||||||
needs them. Failing to do so will cause very odd behaviour or even crashes.
|
longer needs them. Failing to do so will cause very odd behavior or even
|
||||||
|
crashes.
|
||||||
|
|
||||||
More note: the options set with this function call are valid for the
|
\fBNOTE2:\fP options set with this function call are valid for the forthcoming
|
||||||
forthcoming data transfers that are performed when you invoke
|
data transfers that are performed when you invoke \fIcurl_easy_perform\fP.
|
||||||
.I curl_easy_perform .
|
|
||||||
The options are not in any way reset between transfers, so if you want
|
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
|
subsequent transfers with different options, you must change them between the
|
||||||
transfers.
|
transfers.
|
||||||
|
|
||||||
The
|
The \fIhandle\fP is the return code from a \fIcurl_easy_init(3)\fP or
|
||||||
.I "handle"
|
\fIcurl_easy_duphandle(3)\fP call.
|
||||||
is the return code from the
|
|
||||||
.I "curl_easy_init"
|
|
||||||
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 to file write function. Note that if you specify the
|
Data pointer to pass to the file write function. Note that if you specify the
|
||||||
.I CURLOPT_WRITEFUNCTION
|
\fICURLOPT_WRITEFUNCTION\fP, this is the pointer you'll get as input. If you
|
||||||
, this is the pointer you'll get as input. If you don't use a callback, you
|
don't use a callback, you must pass a 'FILE *' as libcurl will pass this to
|
||||||
must pass a 'FILE *' as libcurl passes it to fwrite() when writing data.
|
fwrite() when writing data.
|
||||||
|
|
||||||
NOTE: If you're using libcurl as a win32 DLL, you MUST use the
|
\fBNOTE:\fP If you're using libcurl as a win32 DLL, you MUST use the
|
||||||
\fICURLOPT_WRITEFUNCTION\fP if you set this option.
|
\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 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, void *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 \fIptr\fP is
|
available that needs to be saved. The size of the data pointed to by \fIptr\fP
|
||||||
\fIsize\fP multiplied with \fInmemb\fP. Return the number of bytes actually
|
is \fIsize\fP multiplied with \fInmemb\fP. Return the number of bytes
|
||||||
written or return -1 to signal error to the library (it will cause it to abort
|
actually taken care of. If that amount differs from the amount passed to your
|
||||||
the transfer with CURLE_WRITE_ERROR).
|
function, it'll signal an error to the library and it will abort the transfer
|
||||||
|
and return \fICURLE_WRITE_ERROR\fP.
|
||||||
|
|
||||||
Set the \fIstream\fP argument with the \fBCURLOPT_FILE\fP option.
|
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 to the file read function. Note that if you specify the
|
Data pointer to pass to the file read function. Note that if you specify the
|
||||||
\fICURLOPT_READFUNCTION\fP, this is the pointer you'll get as input. If you
|
\fICURLOPT_READFUNCTION\fP, this is the pointer you'll get as input. If you
|
||||||
don't specify a read callback, this must be a valid FILE *.
|
don't specify a read callback, this must be a valid FILE *.
|
||||||
|
|
||||||
NOTE: If you're using libcurl as a win32 DLL, you MUST use a
|
\fBNOTE:\fP If you're using libcurl as a win32 DLL, you MUST use a
|
||||||
\fICURLOPT_READFUNCTION\fP if you set this option.
|
\fICURLOPT_READFUNCTION\fP if you set this option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_READFUNCTION
|
.B CURLOPT_READFUNCTION
|
||||||
Function pointer that should 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, void *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 \fIptr\fP may
|
send it to the peer. The data area pointed at by the pointer \fIptr\fP may be
|
||||||
be filled with at most \fIsize\fP multiplied with \fInmemb\fP number of
|
filled with at most \fIsize\fP multiplied with \fInmemb\fP number of
|
||||||
bytes. Your function must return the actual number of bytes that you stored in
|
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
|
that memory area. Returning -1 will signal an error to the library and cause
|
||||||
it to abort the current transfer immediately (with a CURLE_READ_ERROR return
|
it to abort the current transfer immediately (with a \fICURLE_READ_ERROR\fP
|
||||||
code).
|
return code).
|
||||||
.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
|
||||||
@@ -87,49 +88,67 @@ libcurl what the expected size of the infile is.
|
|||||||
.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. The string must remain present until curl no longer needs
|
terminated string. The string must remain present until curl no longer needs
|
||||||
it, as it doesn't copy the string. NOTE: this option is required to be set
|
it, as it doesn't copy the string.
|
||||||
before curl_easy_perform() is called.
|
|
||||||
|
\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. Very useful for libcurl and/or protocl
|
information about its operations. Very useful for libcurl and/or protocol
|
||||||
debugging and understanding.
|
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
|
||||||
@@ -140,11 +159,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
|
||||||
@@ -152,88 +173,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
|
.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. 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
|
||||||
. Using this kind of multiple intervals will cause the HTTP server to send the
|
server to send the response document in pieces (using standard MIME separation
|
||||||
response document in pieces.
|
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. This option will cause
|
aborting perfectly normal operations. This option will cause curl to use the
|
||||||
curl to use the SIGALRM to enable timeouting system calls.
|
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
|
||||||
@@ -256,82 +297,71 @@ 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. If you add a header that is otherwise generated
|
contents as in 'Accept:' (no data on the right side of the colon), the
|
||||||
and used by libcurl internally, your added one will be used instead. If you
|
internally used header will get disabled. Thus, using this option you can add
|
||||||
add a header with no contents as in 'Accept:', the internally used header will
|
new headers, replace internal headers and remove internal headers.
|
||||||
just 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. The data in this list must remained intact until you close this
|
with \fIcurl_easy_cleanup(3)\fP.
|
||||||
curl handle again with curl_easy_cleanup().
|
|
||||||
.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 in PEM format.
|
||||||
.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.
|
||||||
.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.
|
||||||
with
|
|
||||||
.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.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_WRITEHEADER
|
.B CURLOPT_WRITEHEADER
|
||||||
Pass a pointer to be used to write the header part of the received data to. If
|
Pass a pointer to be used to write the header part of the received data to. If
|
||||||
you don't use a callback to take care of the writing, this must be a FILE
|
you don't use your own callback to take care of the writing, this must be a
|
||||||
*. The headers are guaranteed to be written one-by-one and only complete lines
|
valid FILE *. See also the \fICURLOPT_HEADERFUNCTION\fP option below on how to set a
|
||||||
are written. Parsing headers should be easy enough using this. See also the
|
custom get-all-headers callback.
|
||||||
\fICURLOPT_HEADERFUNCTION\fP option.
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HEADERFUNCTION
|
.B CURLOPT_HEADERFUNCTION
|
||||||
Function pointer that should match the following prototype:
|
Function pointer that should match the following prototype: \fIsize_t
|
||||||
.BI "size_t function( void *ptr, size_t size, size_t nmemb, void *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 header data
|
function gets called by libcurl as soon as there is received header data that
|
||||||
that needs to be written down. The function will be called once for each
|
needs to be written down. The headers are guaranteed to be written one-by-one
|
||||||
header with a complete header line in each invoke. The size of the data
|
and only complete lines are written. Parsing headers should be easy enough
|
||||||
pointed to by
|
using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP
|
||||||
.I ptr
|
multiplied with \fInmemb\fP. The pointer named \fIstream\fP will be the one
|
||||||
is
|
you passed to libcurl with the \fICURLOPT_WRITEHEADER\fP option. Return the
|
||||||
.I size
|
number of bytes actually written or return -1 to signal error to the library
|
||||||
multiplied with
|
(it will cause it to abort the transfer with a \fICURLE_WRITE_ERROR\fP return
|
||||||
.I nmemb.
|
code). (Added in libcurl 7.7.2)
|
||||||
The pointer named
|
|
||||||
.I stream
|
|
||||||
will be the one you passed to libcurl with the
|
|
||||||
.I CURLOPT_WRITEHEADER
|
|
||||||
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
|
|
||||||
.I CURLE_WRITE_ERROR
|
|
||||||
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
|
||||||
@@ -342,12 +372,12 @@ file.
|
|||||||
.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,
|
||||||
@@ -357,8 +387,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
|
||||||
@@ -376,29 +406,18 @@ krb4 awareness. This is a string, 'clear', 'safe', 'confidential' or
|
|||||||
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
|
||||||
@@ -411,67 +430,66 @@ 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
|
.TP
|
||||||
.B CURLOPT_MAXCONNECTS
|
.B CURLOPT_MAXCONNECTS
|
||||||
Pass a long. The set number will be the persistant connection cache size. The
|
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
|
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
|
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
|
changing this value unless you are perfectly aware of how this work and
|
||||||
changes libcurl's behaviour. Note: if you have already performed transfers
|
changes libcurl's behaviour.
|
||||||
with this curl handle, setting a smaller MAXCONNECTS than before may cause
|
|
||||||
open connections to unnecessarily get closed. (Added in 7.7)
|
\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
|
.TP
|
||||||
.B CURLOPT_CLOSEPOLICY
|
.B CURLOPT_CLOSEPOLICY
|
||||||
Pass a long. This option sets what policy libcurl should use when the
|
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
|
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_*
|
make room for a new connection. This must be one of the CURLCLOSEPOLICY_*
|
||||||
defines. Use CURLCLOSEPOLICY_LEAST_RECENTLY_USED to make libcurl close the
|
defines. Use \fICURLCLOSEPOLICY_LEAST_RECENTLY_USED\fP to make libcurl close
|
||||||
connection that was least recently used, that connection is also least likely
|
the connection that was least recently used, that connection is also least
|
||||||
to be capable of re-use. Use CURLCLOSEPOLICY_OLDEST to make libcurl close the
|
likely to be capable of re-use. Use \fICURLCLOSEPOLICY_OLDEST\fP to make
|
||||||
oldest connection, the one that was created first among the ones in the
|
libcurl close the oldest connection, the one that was created first among the
|
||||||
connection cache. The other close policies are not support yet. (Added in 7.7)
|
ones in the connection cache. The other close policies are not support
|
||||||
|
yet. (Added in 7.7)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FRESH_CONNECT
|
.B CURLOPT_FRESH_CONNECT
|
||||||
Pass a long. Set to non-zero to make the next transfer use a new connection by
|
Pass a long. Set to non-zero to make the next transfer use a new (fresh)
|
||||||
force. If the connection cache is full before this connection, one of the
|
connection by force. If the connection cache is full before this connection,
|
||||||
existinf connections will be closed as according to the set policy. This
|
one of the existing connections will be closed as according to the selected or
|
||||||
option should be used with caution and only if you understand what it
|
default policy. This option should be used with caution and only if you
|
||||||
does. Set to 0 to have libcurl attempt re-use of an existing connection.
|
understand what it does. Set this to 0 to have libcurl attempt re-using an
|
||||||
(Added in 7.7)
|
existing connection (default behavior). (Added in 7.7)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FORBID_REUSE
|
.B CURLOPT_FORBID_REUSE
|
||||||
Pass a long. Set to non-zero to make the next transfer explicitly close the
|
Pass a long. Set to non-zero to make the next transfer explicitly close the
|
||||||
@@ -479,7 +497,7 @@ 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.
|
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
|
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
|
does. Set to 0 to have libcurl keep the connection open for possibly later
|
||||||
re-use. (Added in 7.7)
|
re-use (default behavior). (Added in 7.7)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_RANDOM_FILE
|
.B CURLOPT_RANDOM_FILE
|
||||||
Pass a char * to a zero terminated file name. The file will be used to read
|
Pass a char * to a zero terminated file name. The file will be used to read
|
||||||
@@ -495,15 +513,45 @@ 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
|
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
|
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
|
connection timeout (it will then only timeout on the system's internal
|
||||||
timeouts). See also the
|
timeouts). See also the \fICURLOPT_TIMEOUT\fP option.
|
||||||
.I CURLOPT_TIMEOUT
|
|
||||||
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
|
||||||
.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.
|
||||||
|
|
||||||
|
158
docs/curl_formadd.3
Normal file
158
docs/curl_formadd.3
Normal file
@@ -0,0 +1,158 @@
|
|||||||
|
.\" 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.
|
||||||
|
|
||||||
|
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!
|
||||||
|
|
@@ -12,12 +12,14 @@ 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
|
||||||
libcurl 7.7.1 and earlier versions does not allow a NULL pointer to be used as
|
libcurl 7.7.1 and earlier versions does not allow a NULL pointer to be used as
|
||||||
argument.
|
argument.
|
||||||
|
@@ -4,7 +4,8 @@
|
|||||||
.\"
|
.\"
|
||||||
.TH curl_formparse 3 "21 May 2001" "libcurl 7.7.4" "libcurl Manual"
|
.TH curl_formparse 3 "21 May 2001" "libcurl 7.7.4" "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
|
||||||
@@ -79,6 +80,7 @@ Returns non-zero if an error occurs.
|
|||||||
|
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_setopt "(3), "
|
.BR curl_easy_setopt "(3), "
|
||||||
|
.BR curl_formadd "(3), "
|
||||||
.BR curl_formfree "(3)
|
.BR curl_formfree "(3)
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
Surely there are some, you tell me!
|
Surely there are some, you tell me!
|
||||||
|
@@ -2,13 +2,13 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getenv 3 "5 March 2001" "libcurl 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
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_global_init 3 "31 May 2001" "libcurl 7.8" "libcurl Manual"
|
.TH curl_global_init 3 "14 August 2001" "libcurl 7.8.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_global_init - Global libcurl initialisation
|
curl_global_init - Global libcurl initialisation
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -27,10 +27,13 @@ This function was added in libcurl 7.8.
|
|||||||
.SH FLAGS
|
.SH FLAGS
|
||||||
.TP 5
|
.TP 5
|
||||||
.B CURL_GLOBAL_ALL
|
.B CURL_GLOBAL_ALL
|
||||||
Initialise everyting possible. This sets all known bits.
|
Initialize everything possible. This sets all known bits.
|
||||||
.TP
|
.TP
|
||||||
.B CURL_GLOBAL_SSL
|
.B CURL_GLOBAL_SSL
|
||||||
Initialise SSL
|
Initialize SSL
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_WIN32
|
||||||
|
Initialize the Win32 socket libraries. (added in libcurl 7.8.1)
|
||||||
.TP
|
.TP
|
||||||
.B CURL_GLOBAL_NOTHING
|
.B CURL_GLOBAL_NOTHING
|
||||||
Initialise nothing extra. This sets no bit.
|
Initialise nothing extra. This sets no bit.
|
||||||
|
@@ -8,7 +8,7 @@ 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 "const char * "string ");"
|
.BI "const char * "string ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
|
@@ -25,6 +25,6 @@ These functions are provided by libcurl to enable applications to compare
|
|||||||
strings in a truly portable manner. There are no standard portable case
|
strings in a truly portable manner. There are no standard portable case
|
||||||
insensitive string comparison functions. These two works on all platforms.
|
insensitive string comparison functions. These two works on all platforms.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
A pointer to a zero terminated string.
|
Non-zero if the strings are identical. Zero if they're not.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR strcmp "(3), " strcasecmp "(3)"
|
.BR strcmp "(3), " strcasecmp "(3)"
|
||||||
|
@@ -4,9 +4,9 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit.c \
|
EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit.c postit2.c \
|
||||||
win32sockets.c persistant.c ftpget.c Makefile.example \
|
win32sockets.c persistant.c ftpget.c Makefile.example \
|
||||||
multithread.c getinmemory.c
|
multithread.c getinmemory.c ftpupload.c httpput.c
|
||||||
|
|
||||||
all:
|
all:
|
||||||
@echo "done"
|
@echo "done"
|
||||||
|
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;
|
||||||
|
}
|
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;
|
||||||
|
}
|
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,14 +1,23 @@
|
|||||||
|
|
||||||
|
/*
|
||||||
|
* 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
|
* These are example functions doing socket init that Windows
|
||||||
* require. If you don't use windows, you can safely ignore this crap.
|
* require. If you don't use windows, you can safely ignore this crap.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void win32_cleanup(void)
|
#include <windows.h>
|
||||||
|
|
||||||
|
void win32_cleanup(void)
|
||||||
{
|
{
|
||||||
WSACleanup();
|
WSACleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
static CURLcode win32_init(void)
|
int win32_init(void)
|
||||||
{
|
{
|
||||||
WORD wVersionRequested;
|
WORD wVersionRequested;
|
||||||
WSADATA wsaData;
|
WSADATA wsaData;
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" $Id$
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH libcurl 5 "28 May 2001" "libcurl 7.8" "libcurl overview"
|
.TH libcurl 5 "14 August 2001" "libcurl 7.8.1" "libcurl overview"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
libcurl \- client-side URL transfers
|
libcurl \- client-side URL transfers
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
@@ -53,11 +53,14 @@ portable environment variable reader
|
|||||||
.B curl_easy_getinfo()
|
.B curl_easy_getinfo()
|
||||||
get information about a performed transfer
|
get information about a performed transfer
|
||||||
.TP
|
.TP
|
||||||
.B curl_formparse()
|
.B curl_formadd()
|
||||||
helps building a HTTP form POST
|
helps building a HTTP form POST
|
||||||
.TP
|
.TP
|
||||||
|
.B curl_formparse()
|
||||||
|
helps building a HTTP form POST (deprecated since 7.9 use curl_formadd()!)
|
||||||
|
.TP
|
||||||
.B curl_formfree()
|
.B curl_formfree()
|
||||||
free a list built with curl_formparse()
|
free a list built with curl_formparse()/curl_formadd()
|
||||||
.TP
|
.TP
|
||||||
.B curl_slist_append()
|
.B curl_slist_append()
|
||||||
builds a linked list
|
builds a linked list
|
||||||
@@ -101,7 +104,7 @@ you to init the winsock stuff before you use the libcurl functions. Details on
|
|||||||
this are noted on the curl_easy_init() man page.
|
this are noted on the curl_easy_init() man page.
|
||||||
|
|
||||||
(*) = it appears as if users of the cygwin environment get this done
|
(*) = it appears as if users of the cygwin environment get this done
|
||||||
automatically.
|
automatically, also libcurl 7.8.1 and later can handle this for you.
|
||||||
.SH "THREADS"
|
.SH "THREADS"
|
||||||
Never ever call curl-functions simultaneously using the same handle from
|
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
|
several threads. libcurl is thread-safe and can be used in any number of
|
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* In order to be useful for every potential user, curl and libcurl are
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
@@ -58,13 +58,19 @@ 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 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,
|
||||||
@@ -84,7 +90,7 @@ typedef size_t (*curl_read_callback)(char *buffer,
|
|||||||
void *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);
|
||||||
|
|
||||||
@@ -148,6 +154,7 @@ typedef enum {
|
|||||||
CURLE_TELNET_OPTION_SYNTAX , /* 49 - Malformed telnet option */
|
CURLE_TELNET_OPTION_SYNTAX , /* 49 - Malformed telnet option */
|
||||||
CURLE_OBSOLETE, /* 50 - removed after 7.7.3 */
|
CURLE_OBSOLETE, /* 50 - removed after 7.7.3 */
|
||||||
CURLE_SSL_PEER_CERTIFICATE, /* 51 - peer's certificate wasn't ok */
|
CURLE_SSL_PEER_CERTIFICATE, /* 51 - peer's certificate wasn't ok */
|
||||||
|
CURLE_GOT_NOTHING, /* 52 - when this is a specific error */
|
||||||
|
|
||||||
CURL_LAST /* never use! */
|
CURL_LAST /* never use! */
|
||||||
} CURLcode;
|
} CURLcode;
|
||||||
@@ -286,11 +293,6 @@ typedef enum {
|
|||||||
is simply passed to the callback unmodified */
|
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),
|
||||||
@@ -443,9 +445,42 @@ typedef enum {
|
|||||||
* parameters will use fwrite() syntax, make sure to follow them. */
|
* parameters will use fwrite() syntax, make sure to follow them. */
|
||||||
CINIT(HEADERFUNCTION, FUNCTIONPOINT, 79),
|
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),
|
||||||
|
|
||||||
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 */
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
TIMECOND_NONE,
|
TIMECOND_NONE,
|
||||||
|
|
||||||
@@ -454,7 +489,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>
|
||||||
@@ -478,20 +513,58 @@ 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(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
|
/* Escape and unescape URL encoding in strings. The functions return a new
|
||||||
* allocated string or NULL if an error occurred. */
|
* allocated string or NULL if an error occurred. */
|
||||||
char *curl_escape(char *string, int length);
|
char *curl_escape(const char *string, int length);
|
||||||
char *curl_unescape(char *string, int length);
|
char *curl_unescape(const char *string, int length);
|
||||||
|
|
||||||
/* curl_global_init() should be invoked exactly once for each application that
|
/* curl_global_init() should be invoked exactly once for each application that
|
||||||
uses libcurl */
|
uses libcurl */
|
||||||
@@ -501,11 +574,9 @@ CURLcode curl_global_init(long flags);
|
|||||||
that uses libcurl */
|
that uses libcurl */
|
||||||
void curl_global_cleanup(void);
|
void curl_global_cleanup(void);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* This is the version number */
|
/* This is the version number */
|
||||||
#define LIBCURL_VERSION "7.8"
|
#define LIBCURL_VERSION "7.9.1"
|
||||||
#define LIBCURL_VERSION_NUM 0x070800
|
#define LIBCURL_VERSION_NUM 0x070901
|
||||||
|
|
||||||
/* 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 {
|
||||||
@@ -575,7 +646,8 @@ typedef enum {
|
|||||||
} curl_closepolicy;
|
} curl_closepolicy;
|
||||||
|
|
||||||
#define CURL_GLOBAL_SSL (1<<0)
|
#define CURL_GLOBAL_SSL (1<<0)
|
||||||
#define CURL_GLOBAL_ALL (CURL_GLOBAL_SSL)
|
#define CURL_GLOBAL_WIN32 (1<<1)
|
||||||
|
#define CURL_GLOBAL_ALL (CURL_GLOBAL_SSL|CURL_GLOBAL_WIN32)
|
||||||
#define CURL_GLOBAL_NOTHING 0
|
#define CURL_GLOBAL_NOTHING 0
|
||||||
#define CURL_GLOBAL_DEFAULT CURL_GLOBAL_ALL
|
#define CURL_GLOBAL_DEFAULT CURL_GLOBAL_ALL
|
||||||
|
|
||||||
|
@@ -46,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
|
||||||
|
@@ -54,6 +54,7 @@
|
|||||||
#define H_MPRINTF
|
#define H_MPRINTF
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#include <stdio.h> /* needed for FILE */
|
||||||
|
|
||||||
int curl_mprintf(const char *format, ...);
|
int curl_mprintf(const char *format, ...);
|
||||||
int curl_mfprintf(FILE *fd, const char *format, ...);
|
int curl_mfprintf(FILE *fd, const char *format, ...);
|
||||||
|
@@ -1,134 +0,0 @@
|
|||||||
/**
|
|
||||||
* The curl class is a JNI wrapper for libcurl. Please bear with me, I'm no
|
|
||||||
* true java dude (yet). Improve what you think is bad and send me the
|
|
||||||
* updates!
|
|
||||||
* daniel@haxx.se
|
|
||||||
*
|
|
||||||
* This is meant as a raw, crude and low-level interface to libcurl. If you
|
|
||||||
* want fancy stuff, build upon this.
|
|
||||||
*/
|
|
||||||
|
|
||||||
public class CurlGlue
|
|
||||||
{
|
|
||||||
// start of imported generated list, make a new list with
|
|
||||||
// define2java.pl on demand
|
|
||||||
public static final int CURLOPT_NOTHING = 0;
|
|
||||||
public static final int CURLOPT_FILE = 10001;
|
|
||||||
public static final int CURLOPT_URL = 10002;
|
|
||||||
public static final int CURLOPT_PORT = 3;
|
|
||||||
public static final int CURLOPT_PROXY = 10004;
|
|
||||||
public static final int CURLOPT_USERPWD = 10005;
|
|
||||||
public static final int CURLOPT_PROXYUSERPWD = 10006;
|
|
||||||
public static final int CURLOPT_RANGE = 10007;
|
|
||||||
public static final int CURLOPT_INFILE = 10009;
|
|
||||||
public static final int CURLOPT_ERRORBUFFER = 10010;
|
|
||||||
public static final int CURLOPT_WRITEFUNCTION = 20011;
|
|
||||||
public static final int CURLOPT_READFUNCTION = 20012;
|
|
||||||
public static final int CURLOPT_TIMEOUT = 13;
|
|
||||||
public static final int CURLOPT_INFILESIZE = 14;
|
|
||||||
public static final int CURLOPT_POSTFIELDS = 10015;
|
|
||||||
public static final int CURLOPT_REFERER = 10016;
|
|
||||||
public static final int CURLOPT_FTPPORT = 10017;
|
|
||||||
public static final int CURLOPT_USERAGENT = 10018;
|
|
||||||
public static final int CURLOPT_LOW_SPEED_LIMIT = 19;
|
|
||||||
public static final int CURLOPT_LOW_SPEED_TIME = 20;
|
|
||||||
public static final int CURLOPT_RESUME_FROM = 21;
|
|
||||||
public static final int CURLOPT_COOKIE = 10022;
|
|
||||||
public static final int CURLOPT_HTTPHEADER = 10023;
|
|
||||||
public static final int CURLOPT_HTTPPOST = 10024;
|
|
||||||
public static final int CURLOPT_SSLCERT = 10025;
|
|
||||||
public static final int CURLOPT_SSLCERTPASSWD = 10026;
|
|
||||||
public static final int CURLOPT_CRLF = 27;
|
|
||||||
public static final int CURLOPT_QUOTE = 10028;
|
|
||||||
public static final int CURLOPT_WRITEHEADER = 10029;
|
|
||||||
public static final int CURLOPT_COOKIEFILE = 10031;
|
|
||||||
public static final int CURLOPT_SSLVERSION = 32;
|
|
||||||
public static final int CURLOPT_TIMECONDITION = 33;
|
|
||||||
public static final int CURLOPT_TIMEVALUE = 34;
|
|
||||||
public static final int CURLOPT_HTTPREQUEST = 10035;
|
|
||||||
public static final int CURLOPT_CUSTOMREQUEST = 10036;
|
|
||||||
public static final int CURLOPT_STDERR = 10037;
|
|
||||||
public static final int CURLOPT_POSTQUOTE = 10039;
|
|
||||||
public static final int CURLOPT_WRITEINFO = 10040;
|
|
||||||
public static final int CURLOPT_VERBOSE = 41;
|
|
||||||
public static final int CURLOPT_HEADER = 42;
|
|
||||||
public static final int CURLOPT_NOPROGRESS = 43;
|
|
||||||
public static final int CURLOPT_NOBODY = 44;
|
|
||||||
public static final int CURLOPT_FAILONERROR = 45;
|
|
||||||
public static final int CURLOPT_UPLOAD = 46;
|
|
||||||
public static final int CURLOPT_POST = 47;
|
|
||||||
public static final int CURLOPT_FTPLISTONLY = 48;
|
|
||||||
public static final int CURLOPT_FTPAPPEND = 50;
|
|
||||||
public static final int CURLOPT_NETRC = 51;
|
|
||||||
public static final int CURLOPT_FOLLOWLOCATION = 52;
|
|
||||||
public static final int CURLOPT_FTPASCII = 53;
|
|
||||||
public static final int CURLOPT_TRANSFERTEXT = 53;
|
|
||||||
public static final int CURLOPT_PUT = 54;
|
|
||||||
public static final int CURLOPT_MUTE = 55;
|
|
||||||
public static final int CURLOPT_PROGRESSFUNCTION = 20056;
|
|
||||||
public static final int CURLOPT_PROGRESSDATA = 10057;
|
|
||||||
public static final int CURLOPT_AUTOREFERER = 58;
|
|
||||||
public static final int CURLOPT_PROXYPORT = 59;
|
|
||||||
public static final int CURLOPT_POSTFIELDSIZE = 60;
|
|
||||||
public static final int CURLOPT_HTTPPROXYTUNNEL = 61;
|
|
||||||
public static final int CURLOPT_INTERFACE = 10062;
|
|
||||||
public static final int CURLOPT_KRB4LEVEL = 10063;
|
|
||||||
public static final int CURLOPT_SSL_VERIFYPEER = 64;
|
|
||||||
public static final int CURLOPT_CAINFO = 10065;
|
|
||||||
public static final int CURLOPT_PASSWDFUNCTION = 20066;
|
|
||||||
public static final int CURLOPT_PASSWDDATA = 10067;
|
|
||||||
public static final int CURLOPT_MAXREDIRS = 68;
|
|
||||||
public static final int CURLOPT_FILETIME = 10069;
|
|
||||||
public static final int CURLOPT_TELNETOPTIONS = 10070;
|
|
||||||
public static final int CURLOPT_MAXCONNECTS = 71;
|
|
||||||
public static final int CURLOPT_CLOSEPOLICY = 72;
|
|
||||||
public static final int CURLOPT_CLOSEFUNCTION = 20073;
|
|
||||||
public static final int CURLOPT_FRESH_CONNECT = 74;
|
|
||||||
public static final int CURLOPT_FORBID_REUSE = 75;
|
|
||||||
public static final int CURLOPT_RANDOM_FILE = 10076;
|
|
||||||
public static final int CURLOPT_EGDSOCKET = 10077;
|
|
||||||
public static final int CURLOPT_CONNECTTIMEOUT = 78;
|
|
||||||
public static final int CURLOPT_HEADERFUNCTION = 20079;
|
|
||||||
// end of generated list
|
|
||||||
|
|
||||||
public CurlGlue() {
|
|
||||||
javacurl_handle = jni_init();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void finalize() {
|
|
||||||
jni_cleanup(javacurl_handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
private int javacurl_handle;
|
|
||||||
|
|
||||||
/* constructor and destructor for the libcurl handle */
|
|
||||||
private native int jni_init();
|
|
||||||
private native void jni_cleanup(int javacurl_handle);
|
|
||||||
private native synchronized int jni_perform(int javacurl_handle);
|
|
||||||
|
|
||||||
// Instead of varargs, we have different functions for each
|
|
||||||
// kind of type setopt() can take
|
|
||||||
private native int jni_setopt(int libcurl, int option, String value);
|
|
||||||
private native int jni_setopt(int libcurl, int option, int value);
|
|
||||||
private native int jni_setopt(int libcurl, int option, CurlWrite value);
|
|
||||||
|
|
||||||
public native int getinfo();
|
|
||||||
|
|
||||||
public int perform() {
|
|
||||||
return jni_perform(javacurl_handle);
|
|
||||||
}
|
|
||||||
public int setopt(int option, int value) {
|
|
||||||
return jni_setopt(javacurl_handle, option, value);
|
|
||||||
}
|
|
||||||
public int setopt(int option, String value) {
|
|
||||||
return jni_setopt(javacurl_handle, option, value);
|
|
||||||
}
|
|
||||||
public int setopt(int option, CurlWrite value) {
|
|
||||||
return jni_setopt(javacurl_handle, option, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
static {
|
|
||||||
System.loadLibrary("javacurl");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,9 +0,0 @@
|
|||||||
public interface CurlWrite
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* handleString gets called by libcurl on each chunk of data
|
|
||||||
* we receive from the remote server
|
|
||||||
*/
|
|
||||||
public int handleString(byte s[]);
|
|
||||||
}
|
|
||||||
|
|
@@ -1,35 +0,0 @@
|
|||||||
|
|
||||||
TARGET = libjavacurl.so
|
|
||||||
|
|
||||||
OBJS = javacurl.o
|
|
||||||
|
|
||||||
CC = gcc
|
|
||||||
CFLAGS = -c
|
|
||||||
CPPFLAGS = -I/usr/j2se/include -I/usr/local/include -I/usr/j2se/include/solaris
|
|
||||||
|
|
||||||
# Linux might use -shared -Wl,-soname,libnative.so instead of -G
|
|
||||||
LDFLAGS = -G -lcurl -ldl -L/usr/local/ssl/lib -lssl -lcrypto
|
|
||||||
|
|
||||||
all: CurlGlue.h CurlGlue.class javacurl.o $(TARGET) test.class
|
|
||||||
|
|
||||||
test:
|
|
||||||
java test
|
|
||||||
|
|
||||||
javacurl.o: javacurl.c CurlGlue.h
|
|
||||||
$(CC) $(CPPFLAGS) $(CFLAGS) $<
|
|
||||||
|
|
||||||
CurlGlue.h: CurlGlue.java CurlGlue.class
|
|
||||||
javah CurlGlue
|
|
||||||
touch CurlGlue.h
|
|
||||||
|
|
||||||
test.class: CurlGlue.class javacurl.o
|
|
||||||
javac test.java
|
|
||||||
|
|
||||||
CurlGlue.class: CurlGlue.java
|
|
||||||
javac $<
|
|
||||||
|
|
||||||
$(TARGET): $(OBJS)
|
|
||||||
$(CC) -o $(TARGET) $(LDFLAGS) $(OBJS)
|
|
||||||
|
|
||||||
clean:
|
|
||||||
rm -f javacurl.o CurlGlue.h CurlGlue.class
|
|
15
java/README
15
java/README
@@ -1,15 +0,0 @@
|
|||||||
_ _ ____ _
|
|
||||||
___| | | | _ \| |
|
|
||||||
/ __| | | | |_) | |
|
|
||||||
| (__| |_| | _ <| |___
|
|
||||||
\___|\___/|_| \_\_____|
|
|
||||||
|
|
||||||
Java Interface
|
|
||||||
|
|
||||||
This is not a complete implementation of a libcurl interface. I've made the
|
|
||||||
core work and it needs additional code to be added to get the rest of the
|
|
||||||
stuff supported.
|
|
||||||
|
|
||||||
The interface is not set yet, bring your suggestions!
|
|
||||||
|
|
||||||
Feel free to grab the source files in here and help out!
|
|
@@ -1,22 +0,0 @@
|
|||||||
#!/usr/bin/perl
|
|
||||||
|
|
||||||
open(GCC, "gcc -E ../include/curl/curl.h|");
|
|
||||||
|
|
||||||
while(<GCC>) {
|
|
||||||
if($_ =~ /(CURLOPT_(.*)) += (.*)/) {
|
|
||||||
$var= $1;
|
|
||||||
$expr = $3;
|
|
||||||
$f=$3;
|
|
||||||
if($expr =~ / *(\d+) *\+ *(\d+)/) {
|
|
||||||
$expr = $1+$2;
|
|
||||||
}
|
|
||||||
|
|
||||||
# nah, keep the CURL prefix to make them look like other
|
|
||||||
# languages' defines
|
|
||||||
# $var =~ s/^CURL//g;
|
|
||||||
|
|
||||||
print " public static final int $var = $expr;\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
close(GCC);
|
|
196
java/javacurl.c
196
java/javacurl.c
@@ -1,196 +0,0 @@
|
|||||||
|
|
||||||
#include <curl/curl.h> /* libcurl header */
|
|
||||||
#include "CurlGlue.h" /* the JNI-generated glue header file */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This is a private struct allocated for every 'CurlGlue' object.
|
|
||||||
*/
|
|
||||||
struct javacurl {
|
|
||||||
void *libcurl;
|
|
||||||
void *whatever;
|
|
||||||
struct writecallback {
|
|
||||||
jmethodID mid;
|
|
||||||
JNIEnv *java;
|
|
||||||
jclass cls; /* global reference */
|
|
||||||
jobject object;
|
|
||||||
} write;
|
|
||||||
};
|
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1init(JNIEnv *java,
|
|
||||||
jobject myself)
|
|
||||||
{
|
|
||||||
void *libhandle;
|
|
||||||
struct javacurl *jcurl=NULL;
|
|
||||||
|
|
||||||
libhandle = curl_easy_init();
|
|
||||||
|
|
||||||
if(libhandle) {
|
|
||||||
jcurl=(struct javacurl *)malloc(sizeof(struct javacurl));
|
|
||||||
if(jcurl) {
|
|
||||||
memset(jcurl, 0, sizeof(struct javacurl));
|
|
||||||
jcurl->libcurl = libhandle;
|
|
||||||
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
curl_easy_cleanup(libhandle);
|
|
||||||
return (jint)0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return (jint) jcurl; /* nasty typecast */
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_CurlGlue_jni_1cleanup(JNIEnv *java,
|
|
||||||
jobject myself,
|
|
||||||
jint jcurl)
|
|
||||||
{
|
|
||||||
|
|
||||||
struct javacurl *curl = (struct javacurl*)jcurl;
|
|
||||||
|
|
||||||
if(curl->write.cls) {
|
|
||||||
/* a global reference we must delete */
|
|
||||||
(*java)->DeleteGlobalRef(java, curl->write.cls);
|
|
||||||
(*java)->DeleteGlobalRef(java, curl->write.object);
|
|
||||||
}
|
|
||||||
|
|
||||||
curl_easy_cleanup(curl->libcurl); /* cleanup libcurl stuff */
|
|
||||||
|
|
||||||
free((void *)curl); /* free the struct too */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* setopt() int + string
|
|
||||||
*/
|
|
||||||
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1setopt__IILjava_lang_String_2
|
|
||||||
(JNIEnv *java, jobject myself, jint jcurl, jint option, jstring value)
|
|
||||||
{
|
|
||||||
/* get the actual string C-style */
|
|
||||||
const char *str = (*java)->GetStringUTFChars(java, value, 0);
|
|
||||||
|
|
||||||
void *handle = (void *)((struct javacurl*)jcurl)->libcurl;
|
|
||||||
|
|
||||||
puts("setopt int + string");
|
|
||||||
|
|
||||||
return (jint)curl_easy_setopt(handle, (CURLoption)option, str);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* setopt() int + int
|
|
||||||
*/
|
|
||||||
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1setopt__III
|
|
||||||
(JNIEnv *java, jobject myself, jint jcurl, jint option, jint value)
|
|
||||||
{
|
|
||||||
void *handle = (void *)((struct javacurl*)jcurl)->libcurl;
|
|
||||||
CURLoption opt = (CURLoption)option;
|
|
||||||
|
|
||||||
puts("setopt int + int");
|
|
||||||
|
|
||||||
switch(opt) {
|
|
||||||
case CURLOPT_FILE:
|
|
||||||
/* silently ignored, we don't need user-specified callback data when
|
|
||||||
we have an object, and besides the CURLOPT_FILE is not exported
|
|
||||||
to the java interface */
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (jint)curl_easy_setopt(handle, (CURLoption)option, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int javacurl_write_callback(void *ptr,
|
|
||||||
size_t size,
|
|
||||||
size_t nmemb,
|
|
||||||
FILE *stream)
|
|
||||||
{
|
|
||||||
struct javacurl *curl = (struct javacurl *)stream;
|
|
||||||
size_t realsize = size * nmemb;
|
|
||||||
JNIEnv *java = curl->write.java;
|
|
||||||
jbyteArray jb=NULL;
|
|
||||||
int ret=0;
|
|
||||||
|
|
||||||
fprintf(stderr, "%d bytes data received in callback:\n"
|
|
||||||
"ptr=%p, java=%p cls=%p\n",
|
|
||||||
realsize, curl, java, curl->write.cls);
|
|
||||||
|
|
||||||
jb=(*java)->NewByteArray(java, realsize);
|
|
||||||
(*java)->SetByteArrayRegion(java, jb, 0,
|
|
||||||
realsize, (jbyte *)ptr);
|
|
||||||
|
|
||||||
fprintf(stderr, "created byte-array\n");
|
|
||||||
|
|
||||||
ret = (*java)->CallIntMethod(java,
|
|
||||||
curl->write.object,
|
|
||||||
curl->write.mid,
|
|
||||||
jb);
|
|
||||||
|
|
||||||
fprintf(stderr, "java-method returned %d\n", ret);
|
|
||||||
|
|
||||||
return realsize;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* setopt() int + object
|
|
||||||
*/
|
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1setopt__IILCurlWrite_2
|
|
||||||
(JNIEnv *java, jobject myself, jint jcurl, jint option, jobject object)
|
|
||||||
{
|
|
||||||
jclass cls_local = (*java)->GetObjectClass(java, object);
|
|
||||||
jmethodID mid;
|
|
||||||
struct javacurl *curl = (struct javacurl *)jcurl;
|
|
||||||
jclass cls;
|
|
||||||
jobject obj_global;
|
|
||||||
|
|
||||||
switch(option) {
|
|
||||||
case CURLOPT_WRITEFUNCTION:
|
|
||||||
/* this makes a reference that'll be alive until we kill it! */
|
|
||||||
cls = (*java)->NewGlobalRef(java, cls_local);
|
|
||||||
|
|
||||||
printf("setopt int + object, option = %d cls= %p\n",
|
|
||||||
option, cls);
|
|
||||||
|
|
||||||
if(!cls) {
|
|
||||||
puts("couldn't make local reference global");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* this is the write callback */
|
|
||||||
mid = (*java)->GetMethodID(java, cls, "handleString", "([B)I");
|
|
||||||
if(!mid) {
|
|
||||||
puts("no callback method found");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
obj_global = (*java)->NewGlobalRef(java, object);
|
|
||||||
|
|
||||||
curl->write.mid = mid;
|
|
||||||
curl->write.cls = cls;
|
|
||||||
curl->write.object = obj_global;
|
|
||||||
/*curl->write.java = java; stored on perform */
|
|
||||||
|
|
||||||
fprintf(stderr, "setopt write callback and write file pointer %p, java = %p\n",
|
|
||||||
curl, java);
|
|
||||||
|
|
||||||
curl_easy_setopt(curl->libcurl, CURLOPT_WRITEFUNCTION,
|
|
||||||
javacurl_write_callback);
|
|
||||||
curl_easy_setopt(curl->libcurl, CURLOPT_FILE,
|
|
||||||
curl);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL Java_CurlGlue_getinfo
|
|
||||||
(JNIEnv *java, jobject value)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1perform
|
|
||||||
(JNIEnv *java, jobject myself, jint jcurl)
|
|
||||||
{
|
|
||||||
struct javacurl *curl=(struct javacurl*)jcurl;
|
|
||||||
curl->write.java = java;
|
|
||||||
return (jint)curl_easy_perform(curl->libcurl);
|
|
||||||
}
|
|
@@ -1,27 +0,0 @@
|
|||||||
import CurlGlue;
|
|
||||||
import CurlWrite;
|
|
||||||
|
|
||||||
class test implements CurlWrite {
|
|
||||||
public int handleString(byte s[])
|
|
||||||
{
|
|
||||||
/* output everything */
|
|
||||||
System.out.println("IIIIIIIIIII -------------- OOOOOOOOOOOOOOOOOOO");
|
|
||||||
try {
|
|
||||||
System.out.write(s);
|
|
||||||
}
|
|
||||||
catch (java.io.IOException moo) {
|
|
||||||
// nothing
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void main(String[] args)
|
|
||||||
{
|
|
||||||
CurlGlue cg = new CurlGlue();
|
|
||||||
test cw = new test();
|
|
||||||
cg.setopt(CurlGlue.CURLOPT_URL, "http://www.contactor.se/");
|
|
||||||
cg.setopt(CurlGlue.CURLOPT_WRITEFUNCTION, cw);
|
|
||||||
cg.perform();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
6
lib/.cvsignore
Normal file
6
lib/.cvsignore
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
*.la
|
||||||
|
*.lo
|
||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
.deps
|
||||||
|
.libs
|
@@ -2,7 +2,7 @@
|
|||||||
# $Id$
|
# $Id$
|
||||||
#
|
#
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
EXTRA_DIST = getdate.y \
|
EXTRA_DIST = getdate.y \
|
||||||
Makefile.b32 Makefile.b32.resp Makefile.m32 Makefile.vc6 \
|
Makefile.b32 Makefile.b32.resp Makefile.m32 Makefile.vc6 \
|
||||||
@@ -16,7 +16,7 @@ lib_LTLIBRARIES = libcurl.la
|
|||||||
INCLUDES = -I$(top_srcdir)/include
|
INCLUDES = -I$(top_srcdir)/include
|
||||||
|
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = -version-info 2:0:1
|
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.
|
||||||
@@ -57,9 +57,9 @@ getdate.h ldap.c ssluse.c version.c \
|
|||||||
getenv.c ldap.h ssluse.h \
|
getenv.c ldap.h ssluse.h \
|
||||||
escape.c 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 transfer.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 krb4.h memdebug.c memdebug.h inet_ntoa_r.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
|
http_chunks.c http_chunks.h strtok.c strtok.h connect.c connect.h
|
||||||
|
|
||||||
noinst_HEADERS = setup.h transfer.h
|
noinst_HEADERS = setup.h transfer.h
|
||||||
|
|
||||||
|
@@ -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
|
||||||
@@ -55,7 +57,9 @@ SOURCES = \
|
|||||||
getinfo.c \
|
getinfo.c \
|
||||||
version.c \
|
version.c \
|
||||||
easy.c \
|
easy.c \
|
||||||
strequal.c
|
strequal.c \
|
||||||
|
strtok.c \
|
||||||
|
connect.c
|
||||||
|
|
||||||
OBJECTS = $(SOURCES:.c=.obj)
|
OBJECTS = $(SOURCES:.c=.obj)
|
||||||
|
|
||||||
|
@@ -26,4 +26,6 @@
|
|||||||
+getinfo.obj &
|
+getinfo.obj &
|
||||||
+version.obj &
|
+version.obj &
|
||||||
+easy.obj &
|
+easy.obj &
|
||||||
+strequal.obj
|
+strequal.obj &
|
||||||
|
+strtok.obj
|
||||||
|
|
||||||
|
@@ -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!
|
||||||
@@ -34,14 +35,14 @@ libcurl_a_SOURCES = arpa_telnet.h file.c getpass.h netrc.h timeval.c base64.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 strequal.c strequal.h easy.c security.h \
|
telnet.h getinfo.c strequal.c strequal.h easy.c security.h \
|
||||||
security.c krb4.h krb4.c memdebug.h memdebug.c inet_ntoa_r.h http_chunks.h http_chunks.c \
|
security.c krb4.h krb4.c memdebug.h memdebug.c inet_ntoa_r.h http_chunks.h http_chunks.c \
|
||||||
strtok.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 transfer.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 \
|
||||||
strequal.o easy.o security.o krb4.o memdebug.o http_chunks.o \
|
strequal.o easy.o security.o krb4.o memdebug.o http_chunks.o \
|
||||||
strtok.o
|
strtok.o connect.o
|
||||||
|
|
||||||
LIBRARIES = $(libcurl_a_LIBRARIES)
|
LIBRARIES = $(libcurl_a_LIBRARIES)
|
||||||
SOURCES = $(libcurl_a_SOURCES)
|
SOURCES = $(libcurl_a_SOURCES)
|
||||||
@@ -60,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
|
||||||
|
@@ -1,15 +1,16 @@
|
|||||||
#############################################################
|
#############################################################
|
||||||
|
#
|
||||||
## Makefile for building libcurl.lib with MSVC6
|
## Makefile for building libcurl.lib with MSVC6
|
||||||
## Use: nmake -f makefile.vc6 [release | release-ssl | debug]
|
## Use: nmake -f makefile.vc6 [release | release-ssl | debug]
|
||||||
## (default is release)
|
## (default is release)
|
||||||
##
|
##
|
||||||
## Comments to: Troy Engel <tengel@sonic.net>
|
## Originally written by: Troy Engel <tengel@sonic.net>
|
||||||
## Updated by: Craig Davison <cd@securityfocus.com>
|
## Updated by: Craig Davison <cd@securityfocus.com>
|
||||||
## Updated by: SM <sm@technologist.com>
|
## Updated by: SM <sm@technologist.com>
|
||||||
|
|
||||||
PROGRAM_NAME = libcurl.lib
|
PROGRAM_NAME = libcurl.lib
|
||||||
PROGRAM_NAME_DEBUG = libcurld.lib
|
PROGRAM_NAME_DEBUG = libcurld.lib
|
||||||
#OPENSSL_PATH = ../../openssl-0.9.6a
|
#OPENSSL_PATH = ../../openssl-0.9.6b
|
||||||
|
|
||||||
########################################################
|
########################################################
|
||||||
## Nothing more to do below this line!
|
## Nothing more to do below this line!
|
||||||
@@ -28,7 +29,7 @@ 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
|
LFLAGS = /nologo
|
||||||
LINKLIBS = wsock32.lib
|
LINKLIBS = ws2_32.lib
|
||||||
LINKSLIBS = libeay32.lib ssleay32.lib RSAglue.lib
|
LINKSLIBS = libeay32.lib ssleay32.lib RSAglue.lib
|
||||||
|
|
||||||
RELEASE_OBJS= \
|
RELEASE_OBJS= \
|
||||||
@@ -61,7 +62,8 @@ RELEASE_OBJS= \
|
|||||||
versionr.obj \
|
versionr.obj \
|
||||||
easyr.obj \
|
easyr.obj \
|
||||||
strequalr.obj \
|
strequalr.obj \
|
||||||
strtokr.obj
|
strtokr.obj \
|
||||||
|
connectr.obj
|
||||||
|
|
||||||
DEBUG_OBJS= \
|
DEBUG_OBJS= \
|
||||||
base64d.obj \
|
base64d.obj \
|
||||||
@@ -93,7 +95,8 @@ DEBUG_OBJS= \
|
|||||||
versiond.obj \
|
versiond.obj \
|
||||||
easyd.obj \
|
easyd.obj \
|
||||||
strequald.obj \
|
strequald.obj \
|
||||||
strtokd.obj
|
strtokd.obj \
|
||||||
|
connectd.obj
|
||||||
|
|
||||||
RELEASE_SSL_OBJS= \
|
RELEASE_SSL_OBJS= \
|
||||||
base64rs.obj \
|
base64rs.obj \
|
||||||
@@ -125,7 +128,8 @@ RELEASE_SSL_OBJS= \
|
|||||||
versionrs.obj \
|
versionrs.obj \
|
||||||
easyrs.obj \
|
easyrs.obj \
|
||||||
strequalrs.obj \
|
strequalrs.obj \
|
||||||
strtokd.obj
|
strtokrs.obj \
|
||||||
|
connectrs.obj
|
||||||
|
|
||||||
LINK_OBJS= \
|
LINK_OBJS= \
|
||||||
base64.obj \
|
base64.obj \
|
||||||
@@ -157,7 +161,8 @@ LINK_OBJS= \
|
|||||||
version.obj \
|
version.obj \
|
||||||
easy.obj \
|
easy.obj \
|
||||||
strequal.obj \
|
strequal.obj \
|
||||||
strtok.obj
|
strtok.obj \
|
||||||
|
connect.obj
|
||||||
|
|
||||||
all : release
|
all : release
|
||||||
|
|
||||||
@@ -231,6 +236,8 @@ strequalr.obj: strequal.c
|
|||||||
$(CCR) $(CFLAGS) strequal.c
|
$(CCR) $(CFLAGS) strequal.c
|
||||||
strtokr.obj:strtok.c
|
strtokr.obj:strtok.c
|
||||||
$(CCR) $(CFLAGS) strtok.c
|
$(CCR) $(CFLAGS) strtok.c
|
||||||
|
connectr.obj:connect.c
|
||||||
|
$(CCR) $(CFLAGS) connect.c
|
||||||
|
|
||||||
## Debug
|
## Debug
|
||||||
base64d.obj: base64.c
|
base64d.obj: base64.c
|
||||||
@@ -292,7 +299,9 @@ easyd.obj: easy.c
|
|||||||
strequald.obj: strequal.c
|
strequald.obj: strequal.c
|
||||||
$(CCD) $(CFLAGS) strequal.c
|
$(CCD) $(CFLAGS) strequal.c
|
||||||
strtokd.obj:strtok.c
|
strtokd.obj:strtok.c
|
||||||
$(CCR) $(CFLAGS) strtok.c
|
$(CCD) $(CFLAGS) strtok.c
|
||||||
|
connectd.obj:connect.c
|
||||||
|
$(CCR) $(CFLAGS) connect.c
|
||||||
|
|
||||||
## Release SSL
|
## Release SSL
|
||||||
base64rs.obj: base64.c
|
base64rs.obj: base64.c
|
||||||
@@ -308,7 +317,7 @@ formdatars.obj: formdata.c
|
|||||||
ftprs.obj: ftp.c
|
ftprs.obj: ftp.c
|
||||||
$(CCRS) $(CFLAGS) ftp.c
|
$(CCRS) $(CFLAGS) ftp.c
|
||||||
httprs.obj: http.c
|
httprs.obj: http.c
|
||||||
$(CCR) $(CFLAGS) http.c
|
$(CCRS) $(CFLAGS) http.c
|
||||||
http_chunksrs.obj: http_chunks.c
|
http_chunksrs.obj: http_chunks.c
|
||||||
$(CCRS) $(CFLAGS) http_chunks.c
|
$(CCRS) $(CFLAGS) http_chunks.c
|
||||||
ldaprs.obj: ldap.c
|
ldaprs.obj: ldap.c
|
||||||
@@ -354,8 +363,9 @@ easyrs.obj: easy.c
|
|||||||
strequalrs.obj: strequal.c
|
strequalrs.obj: strequal.c
|
||||||
$(CCRS) $(CFLAGS) strequal.c
|
$(CCRS) $(CFLAGS) strequal.c
|
||||||
strtokrs.obj:strtok.c
|
strtokrs.obj:strtok.c
|
||||||
$(CCR) $(CFLAGS) strtok.c
|
$(CCRS) $(CFLAGS) strtok.c
|
||||||
|
connectrs.obj:connect.c
|
||||||
|
$(CCR) $(CFLAGS) connect.c
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
-@erase *.obj
|
-@erase *.obj
|
||||||
|
@@ -1,321 +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 */
|
||||||
|
|
||||||
#ifdef TELCMDS
|
|
||||||
static
|
|
||||||
char *telcmds[] = {
|
|
||||||
"EOF", "SUSP", "ABORT", "EOR",
|
|
||||||
"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC",
|
|
||||||
"EL", "GA", "SB", "WILL", "WONT", "DO", "DONT", "IAC", 0,
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *telcmds[];
|
|
||||||
#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
|
|
||||||
static
|
|
||||||
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_VAR 0
|
||||||
#define NEW_ENV_VALUE 1
|
#define NEW_ENV_VALUE 1
|
||||||
#define ENV_ESC 2
|
|
||||||
#define ENV_USERVAR 3
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* AUTHENTICATION suboptions
|
* The telnet options represented as strings
|
||||||
*/
|
*/
|
||||||
|
static const char *telnetoptions[]=
|
||||||
/*
|
{
|
||||||
* Who is authenticating who ...
|
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD",
|
||||||
*/
|
"NAME", "STATUS" "TIMING MARK", "RCTE",
|
||||||
#define AUTH_WHO_CLIENT 0 /* Client authenticating server */
|
"NAOL", "NAOP", "NAOCRD", "NAOHTS",
|
||||||
#define AUTH_WHO_SERVER 1 /* Server authenticating client */
|
"NAOHTD", "NAOFFD", "NAOVTS", "NAOVTD",
|
||||||
#define AUTH_WHO_MASK 1
|
"NAOLFD", "EXTEND ASCII", "LOGOUT", "BYTE MACRO",
|
||||||
|
"DE TERMINAL", "SUPDUP", "SUPDUP OUTPUT", "SEND LOCATION",
|
||||||
/*
|
"TERM TYPE", "END OF RECORD", "TACACS UID", "OUTPUT MARKING",
|
||||||
* amount of authentication done
|
"TTYLOC", "3270 REGIME", "X3 PAD", "NAWS",
|
||||||
*/
|
"TERM SPEED", "LFLOW", "LINEMODE", "XDISPLOC",
|
||||||
#define AUTH_HOW_ONE_WAY 0
|
"OLD-ENVIRON", "AUTHENTICATION", "ENCRYPT", "NEW-ENVIRON"
|
||||||
#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[];
|
#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 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 */
|
|
||||||
|
374
lib/base64.c
374
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++)
|
|
||||||
if(*p == c)
|
|
||||||
return p - base64;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 1
|
|
||||||
int Curl_base64_encode(const void *data, int size, char **str)
|
|
||||||
{
|
|
||||||
char *s, *p;
|
|
||||||
int i;
|
int i;
|
||||||
int c;
|
for(i = 0; i < 4; i++) {
|
||||||
const unsigned char *q;
|
if(src[i] >= 'A' && src[i] <= 'Z')
|
||||||
|
x = (x << 6) + (unsigned int)(src[i] - 'A' + 0);
|
||||||
p = s = (char*)malloc(size*4/3+4);
|
else if(src[i] >= 'a' && src[i] <= 'z')
|
||||||
if (p == NULL)
|
x = (x << 6) + (unsigned int)(src[i] - 'a' + 26);
|
||||||
return -1;
|
else if(src[i] >= '0' && src[i] <= '9')
|
||||||
q = (const unsigned char*)data;
|
x = (x << 6) + (unsigned int)(src[i] - '0' + 52);
|
||||||
i=0;
|
else if(src[i] == '+')
|
||||||
for(i = 0; i < size;){
|
x = (x << 6) + 62;
|
||||||
c=q[i++];
|
else if(src[i] == '/')
|
||||||
c*=256;
|
x = (x << 6) + 63;
|
||||||
if(i < size)
|
|
||||||
c+=q[i];
|
|
||||||
i++;
|
|
||||||
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;
|
dest[2] = (unsigned char)(x & 255); x >>= 8;
|
||||||
return strlen(s);
|
dest[1] = (unsigned char)(x & 255); x >>= 8;
|
||||||
|
dest[0] = (unsigned char)(x & 255); x >>= 8;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
/* base64Decode
|
||||||
|
* 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)
|
||||||
|
{
|
||||||
|
int length = 0;
|
||||||
|
int equalsTerm = 0;
|
||||||
|
int i;
|
||||||
|
unsigned char lastQuantum[3];
|
||||||
|
|
||||||
|
while((src[length] != '=') && src[length])
|
||||||
|
length++;
|
||||||
|
while(src[length+equalsTerm] == '=')
|
||||||
|
equalsTerm++;
|
||||||
|
|
||||||
|
if(rawLength)
|
||||||
|
*rawLength = (length * 3 / 4) - equalsTerm;
|
||||||
|
|
||||||
|
for(i = 0; i < length/4 - 1; i++) {
|
||||||
|
decodeQuantum(dest, src);
|
||||||
|
dest += 3; src += 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
decodeQuantum(lastQuantum, src);
|
||||||
|
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 Curl_base64_decode(const char *str, void *data)
|
||||||
{
|
{
|
||||||
const char *p;
|
int ret;
|
||||||
unsigned char *q;
|
|
||||||
int c;
|
|
||||||
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]);
|
base64Decode((unsigned char *)data, (char *)str, &ret);
|
||||||
if(x >= 0)
|
return ret;
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
if(p[2] == '=')
|
|
||||||
done++;
|
|
||||||
else{
|
|
||||||
x = pos(p[2]);
|
|
||||||
if(x >= 0)
|
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
if(p[3] == '=')
|
|
||||||
done++;
|
|
||||||
else{
|
|
||||||
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)
|
|
||||||
*q++=(c&0x0000ff00)>>8;
|
|
||||||
if(done < 1)
|
|
||||||
*q++=(c&0x000000ff)>>0;
|
|
||||||
}
|
|
||||||
return q - (unsigned char*)data;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/************* 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
|
||||||
|
|
||||||
|
#ifdef TEST_DECODE
|
||||||
|
/* decoding test harness. Read in a base64 string from stdin and write out the
|
||||||
|
* length returned by Curl_base64_decode, followed by the decoded 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;
|
||||||
|
|
||||||
|
base64 = (char *)suck(&base64Len);
|
||||||
|
data = (unsigned char *)malloc(base64Len * 3/4 + 8);
|
||||||
|
dataLen = Curl_base64_decode(base64, data);
|
||||||
|
|
||||||
|
fprintf(stderr, "%d\n", dataLen);
|
||||||
|
fwrite(data,1,dataLen,stdout);
|
||||||
|
|
||||||
|
|
||||||
|
free(base64); free(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
|
||||||
|
*/
|
||||||
|
57
lib/base64.h
57
lib/base64.h
@@ -1,40 +1,27 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 1995, 1996, 1997 Kungliga Tekniska H<>gskolan
|
|
||||||
* (Royal Institute of Technology, Stockholm, Sweden).
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
*
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* 3. Neither the name of the Institute 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 INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __BASE64_H
|
#ifndef __BASE64_H
|
||||||
#define __BASE64_H
|
#define __BASE64_H
|
||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
int Curl_base64_encode(const void *data, int size, char **str);
|
int Curl_base64_encode(const void *data, int size, char **str);
|
||||||
int Curl_base64_decode(const char *str, void *data);
|
int Curl_base64_decode(const char *str, void *data);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
562
lib/connect.c
Normal file
562
lib/connect.c
Normal file
@@ -0,0 +1,562 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
|
#ifndef WIN32
|
||||||
|
/* headers for non-win32 */
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_NETDB_H
|
||||||
|
#include <netdb.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_FCNTL_H
|
||||||
|
#include <fcntl.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_NETINET_IN_H
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_ARPA_INET_H
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#ifndef TRUE
|
||||||
|
#define TRUE 1
|
||||||
|
#define FALSE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
#define HAVE_IOCTLSOCKET
|
||||||
|
#include <windows.h>
|
||||||
|
#include <winsock.h>
|
||||||
|
#define EINPROGRESS WSAEINPROGRESS
|
||||||
|
#define EWOULDBLOCK WSAEWOULDBLOCK
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "urldata.h"
|
||||||
|
#include "sendf.h"
|
||||||
|
#include "if2ip.h"
|
||||||
|
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
#include "memdebug.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static
|
||||||
|
int geterrno(void)
|
||||||
|
{
|
||||||
|
#ifdef WIN32
|
||||||
|
return (int)GetLastError();
|
||||||
|
#else
|
||||||
|
return errno;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*************************************************************************
|
||||||
|
* Curl_nonblock
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Set the socket to either blocking or non-blocking mode.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int Curl_nonblock(int socket, /* operate on this */
|
||||||
|
int nonblock /* TRUE or FALSE */)
|
||||||
|
{
|
||||||
|
#undef SETBLOCK
|
||||||
|
#ifdef HAVE_O_NONBLOCK
|
||||||
|
int flags;
|
||||||
|
|
||||||
|
flags = fcntl(socket, F_GETFL, 0);
|
||||||
|
if (TRUE == nonblock)
|
||||||
|
return fcntl(socket, F_SETFL, flags | O_NONBLOCK);
|
||||||
|
else
|
||||||
|
return fcntl(socket, F_SETFL, flags & (~O_NONBLOCK));
|
||||||
|
#define SETBLOCK 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_FIONBIO
|
||||||
|
int flags;
|
||||||
|
|
||||||
|
flags = nonblock;
|
||||||
|
return ioctl(socket, FIONBIO, &flags);
|
||||||
|
#define SETBLOCK 2
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_IOCTLSOCKET
|
||||||
|
int flags;
|
||||||
|
flags = nonblock;
|
||||||
|
return ioctlsocket(socket, FIONBIO, &flags);
|
||||||
|
#define SETBLOCK 3
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_IOCTLSOCKET_CASE
|
||||||
|
return IoctlSocket(socket, FIONBIO, (long)nonblock);
|
||||||
|
#define SETBLOCK 4
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_DISABLED_NONBLOCKING
|
||||||
|
return 0; /* returns success */
|
||||||
|
#define SETBLOCK 5
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef SETBLOCK
|
||||||
|
#error "no non-blocking method was found/used/set"
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return 0 on fine connect, -1 on error and 1 on timeout.
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
int waitconnect(int sockfd, /* socket */
|
||||||
|
int timeout_msec)
|
||||||
|
{
|
||||||
|
fd_set fd;
|
||||||
|
fd_set errfd;
|
||||||
|
struct timeval interval;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
/* now select() until we get connect or timeout */
|
||||||
|
FD_ZERO(&fd);
|
||||||
|
FD_SET(sockfd, &fd);
|
||||||
|
|
||||||
|
FD_ZERO(&errfd);
|
||||||
|
FD_SET(sockfd, &errfd);
|
||||||
|
|
||||||
|
interval.tv_sec = timeout_msec/1000;
|
||||||
|
timeout_msec -= interval.tv_sec*1000;
|
||||||
|
|
||||||
|
interval.tv_usec = timeout_msec*1000;
|
||||||
|
|
||||||
|
rc = select(sockfd+1, NULL, &fd, &errfd, &interval);
|
||||||
|
if(-1 == rc)
|
||||||
|
/* error, no connect here, try next */
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
else if(0 == rc)
|
||||||
|
/* timeout, no connect today */
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
if(FD_ISSET(sockfd, &errfd)) {
|
||||||
|
/* error condition caught */
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* we have a connect! */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ENABLE_IPV6
|
||||||
|
static CURLcode bindlocal(struct connectdata *conn,
|
||||||
|
int sockfd)
|
||||||
|
{
|
||||||
|
#if !defined(WIN32)||defined(__CYGWIN32__)
|
||||||
|
/* We don't generally like checking for OS-versions, we should make this
|
||||||
|
HAVE_XXXX based, although at the moment I don't have a decent test for
|
||||||
|
this! */
|
||||||
|
|
||||||
|
#ifdef HAVE_INET_NTOA
|
||||||
|
|
||||||
|
#ifndef INADDR_NONE
|
||||||
|
#define INADDR_NONE (unsigned long) ~0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
|
||||||
|
/*************************************************************
|
||||||
|
* Select device to bind socket to
|
||||||
|
*************************************************************/
|
||||||
|
if (strlen(data->set.device)<255) {
|
||||||
|
struct sockaddr_in sa;
|
||||||
|
struct hostent *h=NULL;
|
||||||
|
char *hostdataptr=NULL;
|
||||||
|
size_t size;
|
||||||
|
char myhost[256] = "";
|
||||||
|
unsigned long in;
|
||||||
|
|
||||||
|
if(Curl_if2ip(data->set.device, myhost, sizeof(myhost))) {
|
||||||
|
h = Curl_getaddrinfo(data, myhost, 0, &hostdataptr);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(strlen(data->set.device)>1) {
|
||||||
|
h = Curl_getaddrinfo(data, data->set.device, 0, &hostdataptr);
|
||||||
|
}
|
||||||
|
if(h) {
|
||||||
|
/* we know data->set.device is shorter than the myhost array */
|
||||||
|
strcpy(myhost, data->set.device);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(! *myhost) {
|
||||||
|
/* need to fix this
|
||||||
|
h=Curl_gethost(data,
|
||||||
|
getmyhost(*myhost,sizeof(myhost)),
|
||||||
|
hostent_buf,
|
||||||
|
sizeof(hostent_buf));
|
||||||
|
*/
|
||||||
|
if(hostdataptr)
|
||||||
|
free(hostdataptr); /* allocated by Curl_getaddrinfo() */
|
||||||
|
return CURLE_HTTP_PORT_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
infof(data, "We bind local end to %s\n", myhost);
|
||||||
|
|
||||||
|
if ( (in=inet_addr(myhost)) != INADDR_NONE ) {
|
||||||
|
|
||||||
|
if ( h ) {
|
||||||
|
memset((char *)&sa, 0, sizeof(sa));
|
||||||
|
memcpy((char *)&sa.sin_addr,
|
||||||
|
h->h_addr,
|
||||||
|
h->h_length);
|
||||||
|
sa.sin_family = AF_INET;
|
||||||
|
sa.sin_addr.s_addr = in;
|
||||||
|
sa.sin_port = 0; /* get any port */
|
||||||
|
|
||||||
|
if( bind(sockfd, (struct sockaddr *)&sa, sizeof(sa)) >= 0) {
|
||||||
|
/* we succeeded to bind */
|
||||||
|
struct sockaddr_in add;
|
||||||
|
|
||||||
|
size = sizeof(add);
|
||||||
|
if(getsockname(sockfd, (struct sockaddr *) &add,
|
||||||
|
(socklen_t *)&size)<0) {
|
||||||
|
failf(data, "getsockname() failed");
|
||||||
|
return CURLE_HTTP_PORT_FAILED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
switch(errno) {
|
||||||
|
case EBADF:
|
||||||
|
failf(data, "Invalid descriptor: %d", errno);
|
||||||
|
break;
|
||||||
|
case EINVAL:
|
||||||
|
failf(data, "Invalid request: %d", errno);
|
||||||
|
break;
|
||||||
|
case EACCES:
|
||||||
|
failf(data, "Address is protected, user not superuser: %d", errno);
|
||||||
|
break;
|
||||||
|
case ENOTSOCK:
|
||||||
|
failf(data,
|
||||||
|
"Argument is a descriptor for a file, not a socket: %d",
|
||||||
|
errno);
|
||||||
|
break;
|
||||||
|
case EFAULT:
|
||||||
|
failf(data, "Inaccessable memory error: %d", errno);
|
||||||
|
break;
|
||||||
|
case ENAMETOOLONG:
|
||||||
|
failf(data, "Address too long: %d", errno);
|
||||||
|
break;
|
||||||
|
case ENOMEM:
|
||||||
|
failf(data, "Insufficient kernel memory was available: %d", errno);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
failf(data, "errno %d\n", errno);
|
||||||
|
break;
|
||||||
|
} /* end of switch(errno) */
|
||||||
|
|
||||||
|
return CURLE_HTTP_PORT_FAILED;
|
||||||
|
} /* end of else */
|
||||||
|
|
||||||
|
} /* end of if h */
|
||||||
|
else {
|
||||||
|
failf(data,"could't find my own IP address (%s)", myhost);
|
||||||
|
return CURLE_HTTP_PORT_FAILED;
|
||||||
|
}
|
||||||
|
} /* end of inet_addr */
|
||||||
|
|
||||||
|
else {
|
||||||
|
failf(data, "could't find my own IP address (%s)", myhost);
|
||||||
|
return CURLE_HTTP_PORT_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(hostdataptr)
|
||||||
|
free(hostdataptr); /* allocated by Curl_getaddrinfo() */
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
|
||||||
|
} /* end of device selection support */
|
||||||
|
#endif /* end of HAVE_INET_NTOA */
|
||||||
|
#endif /* end of not WIN32 */
|
||||||
|
|
||||||
|
return CURLE_HTTP_PORT_FAILED;
|
||||||
|
}
|
||||||
|
#else /* end of ipv4-specific section */
|
||||||
|
|
||||||
|
/* we only use socketerror() on IPv6-enabled machines */
|
||||||
|
static
|
||||||
|
int socketerror(int sockfd)
|
||||||
|
{
|
||||||
|
int err = 0;
|
||||||
|
socklen_t errSize = sizeof(err);
|
||||||
|
|
||||||
|
if( -1 == getsockopt(sockfd, SOL_SOCKET, SO_ERROR,
|
||||||
|
(void *)&err, &errSize))
|
||||||
|
err = geterrno();
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* TCP connect to the given host with timeout, proxy or remote doesn't matter.
|
||||||
|
* There might be more than one IP address to try out. Fill in the passed
|
||||||
|
* pointer with the connected socket.
|
||||||
|
*/
|
||||||
|
|
||||||
|
CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
||||||
|
Curl_addrinfo *remotehost, /* use one in here */
|
||||||
|
int port, /* connect to this */
|
||||||
|
int *sockconn, /* the connected socket */
|
||||||
|
Curl_ipconnect **addr) /* the one we used */
|
||||||
|
{
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
int rc;
|
||||||
|
int sockfd=-1;
|
||||||
|
int aliasindex=0;
|
||||||
|
|
||||||
|
struct timeval after;
|
||||||
|
struct timeval before = Curl_tvnow();
|
||||||
|
|
||||||
|
/*************************************************************
|
||||||
|
* Figure out what maximum time we have left
|
||||||
|
*************************************************************/
|
||||||
|
long timeout_ms=300000; /* milliseconds, default to five minutes */
|
||||||
|
if(data->set.timeout || data->set.connecttimeout) {
|
||||||
|
double has_passed;
|
||||||
|
|
||||||
|
/* Evaluate in milliseconds how much time that has passed */
|
||||||
|
has_passed = Curl_tvdiff(Curl_tvnow(), data->progress.start);
|
||||||
|
|
||||||
|
#ifndef min
|
||||||
|
#define min(a, b) ((a) < (b) ? (a) : (b))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* get the most strict timeout of the ones converted to milliseconds */
|
||||||
|
if(data->set.timeout &&
|
||||||
|
(data->set.timeout>data->set.connecttimeout))
|
||||||
|
timeout_ms = data->set.timeout*1000;
|
||||||
|
else
|
||||||
|
timeout_ms = data->set.connecttimeout*1000;
|
||||||
|
|
||||||
|
/* subtract the passed time */
|
||||||
|
timeout_ms -= (long)has_passed;
|
||||||
|
|
||||||
|
if(timeout_ms < 0)
|
||||||
|
/* a precaution, no need to continue if time already is up */
|
||||||
|
return CURLE_OPERATION_TIMEOUTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
/*
|
||||||
|
* Connecting with IPv6 support is so much easier and cleanly done
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
struct addrinfo *ai;
|
||||||
|
port =0; /* prevent compiler warning */
|
||||||
|
|
||||||
|
for (ai = remotehost; ai; ai = ai->ai_next, aliasindex++) {
|
||||||
|
sockfd = socket(ai->ai_family, ai->ai_socktype, ai->ai_protocol);
|
||||||
|
if (sockfd < 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* set socket non-blocking */
|
||||||
|
Curl_nonblock(sockfd, TRUE);
|
||||||
|
|
||||||
|
rc = connect(sockfd, ai->ai_addr, ai->ai_addrlen);
|
||||||
|
|
||||||
|
if(-1 == rc) {
|
||||||
|
int error=geterrno();
|
||||||
|
|
||||||
|
switch (error) {
|
||||||
|
case EINPROGRESS:
|
||||||
|
case EWOULDBLOCK:
|
||||||
|
#if defined(EAGAIN) && EAGAIN != EWOULDBLOCK
|
||||||
|
/* On some platforms EAGAIN and EWOULDBLOCK are the
|
||||||
|
* same value, and on others they are different, hence
|
||||||
|
* the odd #if
|
||||||
|
*/
|
||||||
|
case EAGAIN:
|
||||||
|
#endif
|
||||||
|
case EINTR:
|
||||||
|
|
||||||
|
/* asynchronous connect, wait for connect or timeout */
|
||||||
|
rc = waitconnect(sockfd, timeout_ms);
|
||||||
|
break;
|
||||||
|
case ECONNREFUSED: /* no one listening */
|
||||||
|
default:
|
||||||
|
/* unknown error, fallthrough and try another address! */
|
||||||
|
failf(data, "Failed to connect");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(0 == rc) {
|
||||||
|
/* we might be connected, if the socket says it is OK! Ask it! */
|
||||||
|
int err;
|
||||||
|
|
||||||
|
err = socketerror(sockfd);
|
||||||
|
if ((0 == err) || (EISCONN == err)) {
|
||||||
|
/* we are connected, awesome! */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/* we are _not_ connected, it was a false alert, continue please */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* connect failed or timed out */
|
||||||
|
sclose(sockfd);
|
||||||
|
sockfd = -1;
|
||||||
|
|
||||||
|
/* get a new timeout for next attempt */
|
||||||
|
after = Curl_tvnow();
|
||||||
|
timeout_ms -= Curl_tvdiff(after, before);
|
||||||
|
if(timeout_ms < 0) {
|
||||||
|
failf(data, "connect() timed out!");
|
||||||
|
return CURLE_OPERATION_TIMEOUTED;
|
||||||
|
}
|
||||||
|
before = after;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (sockfd < 0) {
|
||||||
|
failf(data, "connect() failed");
|
||||||
|
return CURLE_COULDNT_CONNECT;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* now disable the non-blocking mode again */
|
||||||
|
Curl_nonblock(sockfd, FALSE);
|
||||||
|
|
||||||
|
if(addr)
|
||||||
|
*addr = ai; /* the address we ended up connected to */
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
/*
|
||||||
|
* Connecting with IPv4-only support
|
||||||
|
*/
|
||||||
|
if(!remotehost->h_addr_list[0]) {
|
||||||
|
/* If there is no addresses in the address list, then we return
|
||||||
|
error right away */
|
||||||
|
failf(data, "no address available");
|
||||||
|
return CURLE_COULDNT_CONNECT;
|
||||||
|
}
|
||||||
|
/* create an IPv4 TCP socket */
|
||||||
|
sockfd = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
|
if(-1 == sockfd) {
|
||||||
|
failf(data, "couldn't create socket");
|
||||||
|
return CURLE_COULDNT_CONNECT; /* big time error */
|
||||||
|
}
|
||||||
|
|
||||||
|
if(conn->data->set.device) {
|
||||||
|
/* user selected to bind the outgoing socket to a specified "device"
|
||||||
|
before doing connect */
|
||||||
|
CURLcode res = bindlocal(conn, sockfd);
|
||||||
|
if(res)
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Convert socket to non-blocking type */
|
||||||
|
Curl_nonblock(sockfd, TRUE);
|
||||||
|
|
||||||
|
/* This is the loop that attempts to connect to all IP-addresses we
|
||||||
|
know for the given host. One by one. */
|
||||||
|
for(rc=-1, aliasindex=0;
|
||||||
|
rc && (struct in_addr *)remotehost->h_addr_list[aliasindex];
|
||||||
|
aliasindex++) {
|
||||||
|
struct sockaddr_in serv_addr;
|
||||||
|
|
||||||
|
/* do this nasty work to do the connect */
|
||||||
|
memset((char *) &serv_addr, '\0', sizeof(serv_addr));
|
||||||
|
memcpy((char *)&(serv_addr.sin_addr),
|
||||||
|
(struct in_addr *)remotehost->h_addr_list[aliasindex],
|
||||||
|
sizeof(struct in_addr));
|
||||||
|
serv_addr.sin_family = remotehost->h_addrtype;
|
||||||
|
serv_addr.sin_port = htons(port);
|
||||||
|
|
||||||
|
rc = connect(sockfd, (struct sockaddr *)&serv_addr,
|
||||||
|
sizeof(serv_addr));
|
||||||
|
|
||||||
|
if(-1 == rc) {
|
||||||
|
int error=geterrno();
|
||||||
|
|
||||||
|
switch (error) {
|
||||||
|
case EINPROGRESS:
|
||||||
|
case EWOULDBLOCK:
|
||||||
|
#if defined(EAGAIN) && EAGAIN != EWOULDBLOCK
|
||||||
|
/* On some platforms EAGAIN and EWOULDBLOCK are the
|
||||||
|
* same value, and on others they are different, hence
|
||||||
|
* the odd #if
|
||||||
|
*/
|
||||||
|
case EAGAIN:
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* asynchronous connect, wait for connect or timeout */
|
||||||
|
rc = waitconnect(sockfd, timeout_ms);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* unknown error, fallthrough and try another address! */
|
||||||
|
failf(data, "Failed to connect to IP number %d", aliasindex+1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(0 != rc) {
|
||||||
|
/* get a new timeout for next attempt */
|
||||||
|
after = Curl_tvnow();
|
||||||
|
timeout_ms -= Curl_tvdiff(after, before);
|
||||||
|
if(timeout_ms < 0) {
|
||||||
|
failf(data, "Connect timeout on IP number %d", aliasindex+1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
before = after;
|
||||||
|
continue; /* try next address */
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(0 != rc) {
|
||||||
|
/* no good connect was made */
|
||||||
|
sclose(sockfd);
|
||||||
|
*sockconn = -1;
|
||||||
|
return CURLE_COULDNT_CONNECT;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* now disable the non-blocking mode again */
|
||||||
|
Curl_nonblock(sockfd, FALSE);
|
||||||
|
|
||||||
|
if(addr)
|
||||||
|
/* this is the address we've connected to */
|
||||||
|
*addr = (struct in_addr *)remotehost->h_addr_list[aliasindex];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* allow NULL-pointers to get passed in */
|
||||||
|
if(sockconn)
|
||||||
|
*sockconn = sockfd; /* the socket descriptor we've connected */
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
35
lib/connect.h
Normal file
35
lib/connect.h
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
#ifndef __CONNECT_H
|
||||||
|
#define __CONNECT_H
|
||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
int Curl_nonblock(int socket, /* operate on this */
|
||||||
|
int nonblock /* TRUE or FALSE */);
|
||||||
|
|
||||||
|
CURLcode Curl_connecthost(struct connectdata *conn,
|
||||||
|
Curl_addrinfo *host, /* connect to this */
|
||||||
|
long port, /* connect to this port number */
|
||||||
|
int *sockconn, /* not set if error is returned */
|
||||||
|
Curl_ipconnect **addr /* the one we used */
|
||||||
|
); /* index we used */
|
||||||
|
#endif
|
205
lib/cookie.c
205
lib/cookie.c
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* In order to be useful for every potential user, curl and libcurl are
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
@@ -95,7 +95,7 @@ Example set of cookies:
|
|||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
*
|
*
|
||||||
* cookie_add()
|
* Curl_cookie_add()
|
||||||
*
|
*
|
||||||
* Add a single cookie line to the cookie keeping object.
|
* Add a single cookie line to the cookie keeping object.
|
||||||
*
|
*
|
||||||
@@ -104,7 +104,8 @@ Example set of cookies:
|
|||||||
struct Cookie *
|
struct Cookie *
|
||||||
Curl_cookie_add(struct CookieInfo *c,
|
Curl_cookie_add(struct CookieInfo *c,
|
||||||
bool httpheader, /* TRUE if HTTP header-style line */
|
bool httpheader, /* TRUE if HTTP header-style line */
|
||||||
char *lineptr) /* first non-space of the line */
|
char *lineptr, /* first non-space of the line */
|
||||||
|
char *domain) /* default domain */
|
||||||
{
|
{
|
||||||
struct Cookie *clist;
|
struct Cookie *clist;
|
||||||
char what[MAX_COOKIE_LINE];
|
char what[MAX_COOKIE_LINE];
|
||||||
@@ -112,6 +113,7 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
char *ptr;
|
char *ptr;
|
||||||
char *semiptr;
|
char *semiptr;
|
||||||
struct Cookie *co;
|
struct Cookie *co;
|
||||||
|
struct Cookie *lastc=NULL;
|
||||||
time_t now = time(NULL);
|
time_t now = time(NULL);
|
||||||
bool replace_old = FALSE;
|
bool replace_old = FALSE;
|
||||||
|
|
||||||
@@ -129,13 +131,11 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
semiptr=strchr(lineptr, ';'); /* first, find a semicolon */
|
semiptr=strchr(lineptr, ';'); /* first, find a semicolon */
|
||||||
ptr = lineptr;
|
ptr = lineptr;
|
||||||
do {
|
do {
|
||||||
if(semiptr)
|
|
||||||
*semiptr='\0'; /* zero terminate for a while */
|
|
||||||
/* we have a <what>=<this> pair or a 'secure' word here */
|
/* we have a <what>=<this> pair or a 'secure' word here */
|
||||||
if(strchr(ptr, '=')) {
|
if(strchr(ptr, '=')) {
|
||||||
name[0]=what[0]=0; /* init the buffers */
|
name[0]=what[0]=0; /* init the buffers */
|
||||||
if(1 <= sscanf(ptr, "%" MAX_NAME_TXT "[^=]=%"
|
if(1 <= sscanf(ptr, "%" MAX_NAME_TXT "[^=]=%"
|
||||||
MAX_COOKIE_LINE_TXT "[^\r\n]",
|
MAX_COOKIE_LINE_TXT "[^;\r\n]",
|
||||||
name, what)) {
|
name, what)) {
|
||||||
/* this is a legal <what>=<this> pair */
|
/* this is a legal <what>=<this> pair */
|
||||||
if(strequal("path", name)) {
|
if(strequal("path", name)) {
|
||||||
@@ -169,8 +169,8 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
co->name = strdup(name);
|
co->name = strdup(name);
|
||||||
co->value = strdup(what);
|
co->value = strdup(what);
|
||||||
}
|
}
|
||||||
else
|
/*
|
||||||
;/* this is the second (or more) name we don't know
|
else this is the second (or more) name we don't know
|
||||||
about! */
|
about! */
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@@ -178,23 +178,27 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(sscanf(ptr, "%" MAX_COOKIE_LINE_TXT "[^\r\n]",
|
if(sscanf(ptr, "%" MAX_COOKIE_LINE_TXT "[^;\r\n]",
|
||||||
what)) {
|
what)) {
|
||||||
if(strequal("secure", what))
|
if(strequal("secure", what))
|
||||||
co->secure = TRUE;
|
co->secure = TRUE;
|
||||||
else
|
/* else,
|
||||||
; /* unsupported keyword without assign! */
|
unsupported keyword without assign! */
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!semiptr)
|
if(!semiptr)
|
||||||
continue; /* we already know there are no more cookies */
|
continue; /* we already know there are no more cookies */
|
||||||
|
|
||||||
*semiptr=';'; /* put the semicolon back */
|
|
||||||
ptr=semiptr+1;
|
ptr=semiptr+1;
|
||||||
while(ptr && *ptr && isspace((int)*ptr))
|
while(ptr && *ptr && isspace((int)*ptr))
|
||||||
ptr++;
|
ptr++;
|
||||||
semiptr=strchr(ptr, ';'); /* now, find the next semicolon */
|
semiptr=strchr(ptr, ';'); /* now, find the next semicolon */
|
||||||
} while(semiptr);
|
} while(semiptr);
|
||||||
|
|
||||||
|
if(NULL == co->domain)
|
||||||
|
/* no domain given in the header line, set the default now */
|
||||||
|
co->domain=domain?strdup(domain):NULL;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* This line is NOT a HTTP header style line, we do offer support for
|
/* This line is NOT a HTTP header style line, we do offer support for
|
||||||
@@ -244,6 +248,7 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
|
|
||||||
We don't currently take advantage of this knowledge.
|
We don't currently take advantage of this knowledge.
|
||||||
*/
|
*/
|
||||||
|
co->field1=strequal(ptr, "TRUE")+1; /* store information */
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
/* It turns out, that sometimes the file format allows the path
|
/* It turns out, that sometimes the file format allows the path
|
||||||
@@ -292,6 +297,8 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
co->livecookie = c->running;
|
||||||
|
|
||||||
/* now, we have parsed the incoming line, we must now check if this
|
/* now, we have parsed the incoming line, we must now check if this
|
||||||
superceeds an already existing cookie, which it may if the previous have
|
superceeds an already existing cookie, which it may if the previous have
|
||||||
the same domain and path as this */
|
the same domain and path as this */
|
||||||
@@ -326,6 +333,26 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(replace_old && !co->livecookie && clist->livecookie) {
|
||||||
|
/* Both cookies matched fine, except that the already present
|
||||||
|
cookie is "live", which means it was set from a header, while
|
||||||
|
the new one isn't "live" and thus only read from a file. We let
|
||||||
|
live cookies stay alive */
|
||||||
|
|
||||||
|
/* Free the newcomer and get out of here! */
|
||||||
|
if(co->domain)
|
||||||
|
free(co->domain);
|
||||||
|
if(co->path)
|
||||||
|
free(co->path);
|
||||||
|
if(co->name)
|
||||||
|
free(co->name);
|
||||||
|
if(co->value)
|
||||||
|
free(co->value);
|
||||||
|
|
||||||
|
free(co);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if(replace_old) {
|
if(replace_old) {
|
||||||
co->next = clist->next; /* get the next-pointer first */
|
co->next = clist->next; /* get the next-pointer first */
|
||||||
|
|
||||||
@@ -347,44 +374,59 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
free(clist->maxage);
|
free(clist->maxage);
|
||||||
|
|
||||||
*clist = *co; /* then store all the new data */
|
*clist = *co; /* then store all the new data */
|
||||||
|
|
||||||
|
free(co); /* free the newly alloced memory */
|
||||||
|
co = clist; /* point to the previous struct instead */
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
lastc = clist;
|
||||||
clist = clist->next;
|
clist = clist->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!replace_old) {
|
if(!replace_old) {
|
||||||
|
/* then make the last item point on this new one */
|
||||||
/* first, point to our "next" */
|
if(lastc)
|
||||||
co->next = c->cookies;
|
lastc->next = co;
|
||||||
/* then make ourselves first in the list */
|
else
|
||||||
c->cookies = co;
|
c->cookies = co;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c->numcookies++; /* one more cookie in the jar */
|
||||||
|
|
||||||
return co;
|
return co;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
*
|
*
|
||||||
* cookie_init()
|
* Curl_cookie_init()
|
||||||
*
|
*
|
||||||
* Inits a cookie struct to read data from a local file. This is always
|
* Inits a cookie struct to read data from a local file. This is always
|
||||||
* called before any cookies are set. File may be NULL.
|
* called before any cookies are set. File may be NULL.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
struct CookieInfo *Curl_cookie_init(char *file)
|
struct CookieInfo *Curl_cookie_init(char *file, struct CookieInfo *inc)
|
||||||
{
|
{
|
||||||
char line[MAX_COOKIE_LINE];
|
char line[MAX_COOKIE_LINE];
|
||||||
struct CookieInfo *c;
|
struct CookieInfo *c;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
bool fromfile=TRUE;
|
bool fromfile=TRUE;
|
||||||
|
|
||||||
|
if(NULL == inc) {
|
||||||
|
/* we didn't get a struct, create one */
|
||||||
c = (struct CookieInfo *)malloc(sizeof(struct CookieInfo));
|
c = (struct CookieInfo *)malloc(sizeof(struct CookieInfo));
|
||||||
if(!c)
|
if(!c)
|
||||||
return NULL; /* failed to get memory */
|
return NULL; /* failed to get memory */
|
||||||
memset(c, 0, sizeof(struct CookieInfo));
|
memset(c, 0, sizeof(struct CookieInfo));
|
||||||
c->filename = strdup(file?file:"none"); /* copy the name just in case */
|
c->filename = strdup(file?file:"none"); /* copy the name just in case */
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* we got an already existing one, use that */
|
||||||
|
c = inc;
|
||||||
|
}
|
||||||
|
c->running = FALSE; /* this is not running, this is init */
|
||||||
|
|
||||||
if(strequal(file, "-")) {
|
if(file && strequal(file, "-")) {
|
||||||
fp = stdin;
|
fp = stdin;
|
||||||
fromfile=FALSE;
|
fromfile=FALSE;
|
||||||
}
|
}
|
||||||
@@ -392,34 +434,35 @@ struct CookieInfo *Curl_cookie_init(char *file)
|
|||||||
fp = file?fopen(file, "r"):NULL;
|
fp = file?fopen(file, "r"):NULL;
|
||||||
|
|
||||||
if(fp) {
|
if(fp) {
|
||||||
|
char *lineptr;
|
||||||
|
bool headerline;
|
||||||
while(fgets(line, MAX_COOKIE_LINE, fp)) {
|
while(fgets(line, MAX_COOKIE_LINE, fp)) {
|
||||||
if(strnequal("Set-Cookie:", line, 11)) {
|
if(strnequal("Set-Cookie:", line, 11)) {
|
||||||
/* This is a cookie line, get it! */
|
/* This is a cookie line, get it! */
|
||||||
char *lineptr=&line[11];
|
lineptr=&line[11];
|
||||||
while(*lineptr && isspace((int)*lineptr))
|
headerline=TRUE;
|
||||||
lineptr++;
|
|
||||||
|
|
||||||
Curl_cookie_add(c, TRUE, lineptr);
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* This might be a netscape cookie-file line, get it! */
|
lineptr=line;
|
||||||
char *lineptr=line;
|
headerline=FALSE;
|
||||||
|
}
|
||||||
while(*lineptr && isspace((int)*lineptr))
|
while(*lineptr && isspace((int)*lineptr))
|
||||||
lineptr++;
|
lineptr++;
|
||||||
|
|
||||||
Curl_cookie_add(c, FALSE, lineptr);
|
Curl_cookie_add(c, headerline, lineptr, NULL);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if(fromfile)
|
if(fromfile)
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c->running = TRUE; /* now, we're running */
|
||||||
|
|
||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
*
|
*
|
||||||
* cookie_getlist()
|
* Curl_cookie_getlist()
|
||||||
*
|
*
|
||||||
* For a given host and path, return a linked list of cookies that the
|
* For a given host and path, return a linked list of cookies that the
|
||||||
* client should send to the server if used now. The secure boolean informs
|
* client should send to the server if used now. The secure boolean informs
|
||||||
@@ -491,9 +534,9 @@ struct Cookie *Curl_cookie_getlist(struct CookieInfo *c,
|
|||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
*
|
*
|
||||||
* cookie_freelist()
|
* Curl_cookie_freelist()
|
||||||
*
|
*
|
||||||
* Free a list previously returned by cookie_getlist();
|
* Free a list of cookies previously returned by Curl_cookie_getlist();
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
@@ -512,7 +555,7 @@ void Curl_cookie_freelist(struct Cookie *co)
|
|||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
*
|
*
|
||||||
* cookie_cleanup()
|
* Curl_cookie_cleanup()
|
||||||
*
|
*
|
||||||
* Free a "cookie object" previous created with cookie_init().
|
* Free a "cookie object" previous created with cookie_init().
|
||||||
*
|
*
|
||||||
@@ -551,3 +594,101 @@ void Curl_cookie_cleanup(struct CookieInfo *c)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Curl_cookie_output()
|
||||||
|
*
|
||||||
|
* Writes all internally known cookies to the specified file. Specify
|
||||||
|
* "-" as file name to write to stdout.
|
||||||
|
*
|
||||||
|
* The function returns non-zero on write failure.
|
||||||
|
*/
|
||||||
|
int Curl_cookie_output(struct CookieInfo *c, char *dumphere)
|
||||||
|
{
|
||||||
|
struct Cookie *co;
|
||||||
|
FILE *out;
|
||||||
|
bool use_stdout=FALSE;
|
||||||
|
|
||||||
|
if((NULL == c) || (0 == c->numcookies))
|
||||||
|
/* If there are no known cookies, we don't write or even create any
|
||||||
|
destination file */
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if(strequal("-", dumphere)) {
|
||||||
|
/* use stdout */
|
||||||
|
out = stdout;
|
||||||
|
use_stdout=TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
out = fopen(dumphere, "w");
|
||||||
|
if(!out)
|
||||||
|
return 1; /* failure */
|
||||||
|
}
|
||||||
|
|
||||||
|
if(c) {
|
||||||
|
fputs("# Netscape HTTP Cookie File\n"
|
||||||
|
"# http://www.netscape.com/newsref/std/cookie_spec.html\n"
|
||||||
|
"# This file was generated by libcurl! Edit at your own risk.\n\n",
|
||||||
|
out);
|
||||||
|
co = c->cookies;
|
||||||
|
|
||||||
|
while(co) {
|
||||||
|
fprintf(out,
|
||||||
|
"%s\t" /* domain */
|
||||||
|
"%s\t" /* field1 */
|
||||||
|
"%s\t" /* path */
|
||||||
|
"%s\t" /* secure */
|
||||||
|
"%u\t" /* expires */
|
||||||
|
"%s\t" /* name */
|
||||||
|
"%s\n", /* value */
|
||||||
|
co->domain?co->domain:"unknown",
|
||||||
|
co->field1==2?"TRUE":"FALSE",
|
||||||
|
co->path?co->path:"/",
|
||||||
|
co->secure?"TRUE":"FALSE",
|
||||||
|
(unsigned int)co->expires,
|
||||||
|
co->name,
|
||||||
|
co->value?co->value:"");
|
||||||
|
|
||||||
|
co=co->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!use_stdout)
|
||||||
|
fclose(out);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CURL_COOKIE_DEBUG
|
||||||
|
|
||||||
|
/*
|
||||||
|
* On my Solaris box, this command line builds this test program:
|
||||||
|
*
|
||||||
|
* gcc -g -o cooktest -DCURL_COOKIE_DEBUG -DHAVE_CONFIG_H -I.. -I../include cookie.c strequal.o getdate.o memdebug.o mprintf.o strtok.o -lnsl -lsocket
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
struct CookieInfo *c=NULL;
|
||||||
|
if(argc>1) {
|
||||||
|
c = Curl_cookie_init(argv[1], c);
|
||||||
|
Curl_cookie_add(c, TRUE, "PERSONALIZE=none;expires=Monday, 13-Jun-1988 03:04:55 GMT; domain=.fidelity.com; path=/ftgw; secure");
|
||||||
|
Curl_cookie_add(c, TRUE, "foobar=yes; domain=.haxx.se; path=/looser;");
|
||||||
|
c = Curl_cookie_init(argv[1], c);
|
||||||
|
|
||||||
|
Curl_cookie_output(c);
|
||||||
|
Curl_cookie_cleanup(c);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
16
lib/cookie.h
16
lib/cookie.h
@@ -41,11 +41,14 @@ struct Cookie {
|
|||||||
time_t expires; /* expires = <this> */
|
time_t expires; /* expires = <this> */
|
||||||
char *expirestr; /* the plain text version */
|
char *expirestr; /* the plain text version */
|
||||||
|
|
||||||
|
char field1; /* read from a cookie file, 1 => FALSE, 2=> TRUE */
|
||||||
|
|
||||||
/* RFC 2109 keywords. Version=1 means 2109-compliant cookie sending */
|
/* RFC 2109 keywords. Version=1 means 2109-compliant cookie sending */
|
||||||
char *version; /* Version = <value> */
|
char *version; /* Version = <value> */
|
||||||
char *maxage; /* Max-Age = <value> */
|
char *maxage; /* Max-Age = <value> */
|
||||||
|
|
||||||
bool secure; /* whether the 'secure' keyword was used */
|
bool secure; /* whether the 'secure' keyword was used */
|
||||||
|
bool livecookie; /* updated from a server, not a stored file */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct CookieInfo {
|
struct CookieInfo {
|
||||||
@@ -53,6 +56,8 @@ struct CookieInfo {
|
|||||||
struct Cookie *cookies;
|
struct Cookie *cookies;
|
||||||
|
|
||||||
char *filename; /* file we read from/write to */
|
char *filename; /* file we read from/write to */
|
||||||
|
bool running; /* state info, for cookie adding information */
|
||||||
|
long numcookies; /* number of cookies in the "jar" */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* This is the maximum line length we accept for a cookie line */
|
/* This is the maximum line length we accept for a cookie line */
|
||||||
@@ -63,10 +68,17 @@ struct CookieInfo {
|
|||||||
#define MAX_NAME 256
|
#define MAX_NAME 256
|
||||||
#define MAX_NAME_TXT "255"
|
#define MAX_NAME_TXT "255"
|
||||||
|
|
||||||
struct Cookie *Curl_cookie_add(struct CookieInfo *, bool, char *);
|
/*
|
||||||
struct CookieInfo *Curl_cookie_init(char *);
|
* Add a cookie to the internal list of cookies. The domain argument is only
|
||||||
|
* used if the header boolean is TRUE.
|
||||||
|
*/
|
||||||
|
struct Cookie *Curl_cookie_add(struct CookieInfo *, bool header, char *line,
|
||||||
|
char *domain);
|
||||||
|
|
||||||
|
struct CookieInfo *Curl_cookie_init(char *, struct CookieInfo *);
|
||||||
struct Cookie *Curl_cookie_getlist(struct CookieInfo *, char *, char *, bool);
|
struct Cookie *Curl_cookie_getlist(struct CookieInfo *, char *, char *, bool);
|
||||||
void Curl_cookie_freelist(struct Cookie *);
|
void Curl_cookie_freelist(struct Cookie *);
|
||||||
void Curl_cookie_cleanup(struct CookieInfo *);
|
void Curl_cookie_cleanup(struct CookieInfo *);
|
||||||
|
int Curl_cookie_output(struct CookieInfo *, char *);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -43,7 +43,8 @@ RSC=rc.exe
|
|||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
||||||
# ADD CPP /nologo /MT /W3 /GX /O2 /I "..\include" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
# ADD CPP /nologo /MD /W3 /GX /Zi /O2 /I "..\include" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /FR /FD /c
|
||||||
|
# SUBTRACT CPP /YX
|
||||||
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
@@ -53,7 +54,7 @@ BSC32=bscmake.exe
|
|||||||
# ADD BSC32 /nologo
|
# ADD BSC32 /nologo
|
||||||
LINK32=link.exe
|
LINK32=link.exe
|
||||||
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
||||||
# ADD LINK32 kernel32.lib wsock32.lib /nologo /dll /machine:I386 /out:"Release/curl.dll"
|
# ADD LINK32 kernel32.lib ws2_32.lib /nologo /dll /map /debug /machine:I386 /out:"Release/libcurl.dll"
|
||||||
|
|
||||||
!ELSEIF "$(CFG)" == "curllib - Win32 Debug"
|
!ELSEIF "$(CFG)" == "curllib - Win32 Debug"
|
||||||
|
|
||||||
@@ -69,7 +70,8 @@ LINK32=link.exe
|
|||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
||||||
# ADD CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I "..\include" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
# ADD CPP /nologo /MDd /W3 /Gm /GX /Zi /Od /I "..\include" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /FR /FD /GZ /c
|
||||||
|
# SUBTRACT CPP /WX /YX
|
||||||
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
@@ -79,7 +81,7 @@ BSC32=bscmake.exe
|
|||||||
# ADD BSC32 /nologo
|
# ADD BSC32 /nologo
|
||||||
LINK32=link.exe
|
LINK32=link.exe
|
||||||
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
||||||
# ADD LINK32 kernel32.lib wsock32.lib /nologo /dll /debug /machine:I386 /out:"Debug/curl.dll" /pdbtype:sept
|
# ADD LINK32 kernel32.lib ws2_32.lib /nologo /dll /incremental:no /map /debug /machine:I386 /out:"Debug/libcurl.dll" /pdbtype:sept
|
||||||
# SUBTRACT LINK32 /nodefaultlib
|
# SUBTRACT LINK32 /nodefaultlib
|
||||||
|
|
||||||
!ENDIF
|
!ENDIF
|
||||||
@@ -97,6 +99,10 @@ SOURCE=.\base64.c
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\connect.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\cookie.c
|
SOURCE=.\cookie.c
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -245,6 +251,10 @@ SOURCE=.\base64.h
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\connect.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\cookie.h
|
SOURCE=.\cookie.h
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
50
lib/dict.c
50
lib/dict.c
@@ -80,11 +80,6 @@
|
|||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
CURLcode Curl_dict_done(struct connectdata *conn)
|
|
||||||
{
|
|
||||||
return CURLE_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
CURLcode Curl_dict(struct connectdata *conn)
|
CURLcode Curl_dict(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
int nth;
|
int nth;
|
||||||
@@ -95,7 +90,7 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
char *nthdef = NULL; /* This is not part of the protocol, but required
|
char *nthdef = NULL; /* This is not part of the protocol, but required
|
||||||
by RFC 2229 */
|
by RFC 2229 */
|
||||||
CURLcode result=CURLE_OK;
|
CURLcode result=CURLE_OK;
|
||||||
struct UrlData *data=conn->data;
|
struct SessionHandle *data=conn->data;
|
||||||
|
|
||||||
char *path = conn->path;
|
char *path = conn->path;
|
||||||
long *bytecount = &conn->bytecount;
|
long *bytecount = &conn->bytecount;
|
||||||
@@ -129,10 +124,10 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
failf(data, "lookup word is missing\n");
|
failf(data, "lookup word is missing\n");
|
||||||
}
|
}
|
||||||
if ((database == NULL) || (*database == (char)0)) {
|
if ((database == NULL) || (*database == (char)0)) {
|
||||||
database = "!";
|
database = (char *)"!";
|
||||||
}
|
}
|
||||||
if ((strategy == NULL) || (*strategy == (char)0)) {
|
if ((strategy == NULL) || (*strategy == (char)0)) {
|
||||||
strategy = ".";
|
strategy = (char *)".";
|
||||||
}
|
}
|
||||||
if ((nthdef == NULL) || (*nthdef == (char)0)) {
|
if ((nthdef == NULL) || (*nthdef == (char)0)) {
|
||||||
nth = 0;
|
nth = 0;
|
||||||
@@ -141,7 +136,7 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
nth = atoi(nthdef);
|
nth = atoi(nthdef);
|
||||||
}
|
}
|
||||||
|
|
||||||
Curl_sendf(conn->firstsocket, conn,
|
result = Curl_sendf(conn->firstsocket, conn,
|
||||||
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
||||||
"MATCH "
|
"MATCH "
|
||||||
"%s " /* database */
|
"%s " /* database */
|
||||||
@@ -153,13 +148,13 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
strategy,
|
strategy,
|
||||||
word
|
word
|
||||||
);
|
);
|
||||||
|
if(result)
|
||||||
|
failf(data, "Failed sending DICT request");
|
||||||
|
else
|
||||||
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
||||||
-1, NULL); /* no upload */
|
-1, NULL); /* no upload */
|
||||||
|
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (strnequal(path, DICT_DEFINE, sizeof(DICT_DEFINE)-1) ||
|
else if (strnequal(path, DICT_DEFINE, sizeof(DICT_DEFINE)-1) ||
|
||||||
strnequal(path, DICT_DEFINE2, sizeof(DICT_DEFINE2)-1) ||
|
strnequal(path, DICT_DEFINE2, sizeof(DICT_DEFINE2)-1) ||
|
||||||
@@ -182,7 +177,7 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
failf(data, "lookup word is missing\n");
|
failf(data, "lookup word is missing\n");
|
||||||
}
|
}
|
||||||
if ((database == NULL) || (*database == (char)0)) {
|
if ((database == NULL) || (*database == (char)0)) {
|
||||||
database = "!";
|
database = (char *)"!";
|
||||||
}
|
}
|
||||||
if ((nthdef == NULL) || (*nthdef == (char)0)) {
|
if ((nthdef == NULL) || (*nthdef == (char)0)) {
|
||||||
nth = 0;
|
nth = 0;
|
||||||
@@ -191,17 +186,17 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
nth = atoi(nthdef);
|
nth = atoi(nthdef);
|
||||||
}
|
}
|
||||||
|
|
||||||
Curl_sendf(conn->firstsocket, conn,
|
result = Curl_sendf(conn->firstsocket, conn,
|
||||||
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
||||||
"DEFINE "
|
"DEFINE "
|
||||||
"%s " /* database */
|
"%s " /* database */
|
||||||
"%s\n" /* word */
|
"%s\n" /* word */
|
||||||
"QUIT\n",
|
"QUIT\n",
|
||||||
|
|
||||||
database,
|
database,
|
||||||
word
|
word);
|
||||||
);
|
if(result)
|
||||||
|
failf(data, "Failed sending DICT request");
|
||||||
|
else
|
||||||
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
||||||
-1, NULL); /* no upload */
|
-1, NULL); /* no upload */
|
||||||
|
|
||||||
@@ -220,20 +215,27 @@ CURLcode Curl_dict(struct connectdata *conn)
|
|||||||
if (ppath[i] == ':')
|
if (ppath[i] == ':')
|
||||||
ppath[i] = ' ';
|
ppath[i] = ' ';
|
||||||
}
|
}
|
||||||
Curl_sendf(conn->firstsocket, conn,
|
result = Curl_sendf(conn->firstsocket, conn,
|
||||||
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
||||||
"%s\n"
|
"%s\n"
|
||||||
"QUIT\n",
|
"QUIT\n", ppath);
|
||||||
ppath);
|
if(result)
|
||||||
|
failf(data, "Failed sending DICT request");
|
||||||
|
else
|
||||||
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
||||||
-1, NULL);
|
-1, NULL);
|
||||||
|
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
#ifdef WIN32
|
||||||
/* dllinit.c -- Portable DLL initialization.
|
/* dllinit.c -- Portable DLL initialization.
|
||||||
Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
||||||
Contributed by Mumit Khan (khan@xraylith.wisc.edu).
|
Contributed by Mumit Khan (khan@xraylith.wisc.edu).
|
||||||
@@ -80,3 +81,12 @@ DllMain (
|
|||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
168
lib/easy.c
168
lib/easy.c
@@ -74,50 +74,118 @@
|
|||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "transfer.h"
|
#include "transfer.h"
|
||||||
#include "ssluse.h"
|
#include "ssluse.h"
|
||||||
|
#include "url.h"
|
||||||
|
#include "getinfo.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
/* true globals */
|
|
||||||
|
/* Silly win32 socket initialization functions */
|
||||||
|
|
||||||
|
#if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__)
|
||||||
|
static void win32_cleanup(void)
|
||||||
|
{
|
||||||
|
WSACleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode win32_init(void)
|
||||||
|
{
|
||||||
|
WORD wVersionRequested;
|
||||||
|
WSADATA wsaData;
|
||||||
|
int err;
|
||||||
|
wVersionRequested = MAKEWORD(2, 0);
|
||||||
|
|
||||||
|
err = WSAStartup(wVersionRequested, &wsaData);
|
||||||
|
|
||||||
|
if (err != 0)
|
||||||
|
/* Tell the user that we couldn't find a useable */
|
||||||
|
/* winsock.dll. */
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
|
||||||
|
/* Confirm that the Windows Sockets DLL supports 2.0.*/
|
||||||
|
/* Note that if the DLL supports versions greater */
|
||||||
|
/* than 2.0 in addition to 2.0, it will still return */
|
||||||
|
/* 2.0 in wVersion since that is the version we */
|
||||||
|
/* requested. */
|
||||||
|
|
||||||
|
if ( LOBYTE( wsaData.wVersion ) != 2 ||
|
||||||
|
HIBYTE( wsaData.wVersion ) != 0 ) {
|
||||||
|
/* Tell the user that we couldn't find a useable */
|
||||||
|
|
||||||
|
/* winsock.dll. */
|
||||||
|
WSACleanup();
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
}
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
/* The Windows Sockets DLL is acceptable. Proceed. */
|
||||||
|
#else
|
||||||
|
/* These functions exist merely to prevent compiler warnings */
|
||||||
|
static CURLcode win32_init(void) { return CURLE_OK; }
|
||||||
|
static void win32_cleanup(void) { }
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* true globals -- for curl_global_init() and curl_global_cleanup() */
|
||||||
static unsigned int initialized = 0;
|
static unsigned int initialized = 0;
|
||||||
static long init_flags = 0;
|
static long init_flags = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Globally initializes cURL given a bitwise set of
|
||||||
|
* the different features to initialize.
|
||||||
|
*/
|
||||||
CURLcode curl_global_init(long flags)
|
CURLcode curl_global_init(long flags)
|
||||||
{
|
{
|
||||||
if(flags & CURL_GLOBAL_SSL)
|
if (initialized)
|
||||||
|
return CURLE_OK;
|
||||||
|
|
||||||
|
if (flags & CURL_GLOBAL_SSL)
|
||||||
Curl_SSL_init();
|
Curl_SSL_init();
|
||||||
|
|
||||||
|
if (flags & CURL_GLOBAL_WIN32)
|
||||||
|
if (win32_init() != CURLE_OK)
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
|
||||||
initialized = 1;
|
initialized = 1;
|
||||||
init_flags = flags;
|
init_flags = flags;
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Globally cleanup cURL, uses the value of "init_flags" to determine
|
||||||
|
* what needs to be cleaned up and what doesn't
|
||||||
|
*/
|
||||||
void curl_global_cleanup(void)
|
void curl_global_cleanup(void)
|
||||||
{
|
{
|
||||||
|
if (!initialized)
|
||||||
|
return;
|
||||||
|
|
||||||
if (init_flags & CURL_GLOBAL_SSL)
|
if (init_flags & CURL_GLOBAL_SSL)
|
||||||
Curl_SSL_cleanup();
|
Curl_SSL_cleanup();
|
||||||
|
|
||||||
|
if (init_flags & CURL_GLOBAL_WIN32)
|
||||||
|
win32_cleanup();
|
||||||
|
|
||||||
initialized = 0;
|
initialized = 0;
|
||||||
|
init_flags = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURL *curl_easy_init(void)
|
CURL *curl_easy_init(void)
|
||||||
{
|
{
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
struct UrlData *data;
|
struct SessionHandle *data;
|
||||||
|
|
||||||
/* Make sure we inited the global SSL stuff */
|
/* Make sure we inited the global SSL stuff */
|
||||||
if (!initialized)
|
if (!initialized)
|
||||||
curl_global_init(CURL_GLOBAL_DEFAULT);
|
curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
|
|
||||||
/* We use curl_open() with undefined URL so far */
|
/* We use curl_open() with undefined URL so far */
|
||||||
res = Curl_open((CURL **)&data, NULL);
|
res = Curl_open(&data);
|
||||||
if(res != CURLE_OK)
|
if(res != CURLE_OK)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
/* SAC */
|
|
||||||
data->device = NULL;
|
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -128,7 +196,7 @@ CURLcode curl_easy_setopt(CURL *curl, CURLoption tag, ...)
|
|||||||
func_T param_func = (func_T)0;
|
func_T param_func = (func_T)0;
|
||||||
long param_long = 0;
|
long param_long = 0;
|
||||||
void *param_obj = NULL;
|
void *param_obj = NULL;
|
||||||
struct UrlData *data = curl;
|
struct SessionHandle *data = curl;
|
||||||
|
|
||||||
va_start(arg, tag);
|
va_start(arg, tag);
|
||||||
|
|
||||||
@@ -160,20 +228,98 @@ CURLcode curl_easy_setopt(CURL *curl, CURLoption tag, ...)
|
|||||||
|
|
||||||
CURLcode curl_easy_perform(CURL *curl)
|
CURLcode curl_easy_perform(CURL *curl)
|
||||||
{
|
{
|
||||||
return Curl_perform(curl);
|
struct SessionHandle *data = (struct SessionHandle *)curl;
|
||||||
|
|
||||||
|
return Curl_perform(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
void curl_easy_cleanup(CURL *curl)
|
void curl_easy_cleanup(CURL *curl)
|
||||||
{
|
{
|
||||||
Curl_close(curl);
|
struct SessionHandle *data = (struct SessionHandle *)curl;
|
||||||
|
Curl_close(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...)
|
CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...)
|
||||||
{
|
{
|
||||||
va_list arg;
|
va_list arg;
|
||||||
void *paramp;
|
void *paramp;
|
||||||
|
struct SessionHandle *data = (struct SessionHandle *)curl;
|
||||||
|
|
||||||
va_start(arg, info);
|
va_start(arg, info);
|
||||||
paramp = va_arg(arg, void *);
|
paramp = va_arg(arg, void *);
|
||||||
|
|
||||||
return Curl_getinfo(curl, info, paramp);
|
return Curl_getinfo(data, info, paramp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CURL *curl_easy_duphandle(CURL *incurl)
|
||||||
|
{
|
||||||
|
struct SessionHandle *data=(struct SessionHandle *)incurl;
|
||||||
|
|
||||||
|
struct SessionHandle *outcurl = (struct SessionHandle *)
|
||||||
|
malloc(sizeof(struct SessionHandle));
|
||||||
|
|
||||||
|
if(NULL == outcurl)
|
||||||
|
return NULL; /* failure */
|
||||||
|
|
||||||
|
/* start with clearing the entire new struct */
|
||||||
|
memset(outcurl, 0, sizeof(struct SessionHandle));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We setup a few buffers we need. We should probably make them
|
||||||
|
* get setup on-demand in the code, as that would probably decrease
|
||||||
|
* the likeliness of us forgetting to init a buffer here in the future.
|
||||||
|
*/
|
||||||
|
outcurl->state.headerbuff=(char*)malloc(HEADERSIZE);
|
||||||
|
if(!outcurl->state.headerbuff) {
|
||||||
|
free(outcurl); /* free the memory again */
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
outcurl->state.headersize=HEADERSIZE;
|
||||||
|
|
||||||
|
/* copy all userdefined values */
|
||||||
|
outcurl->set = data->set;
|
||||||
|
outcurl->state.numconnects = data->state.numconnects;
|
||||||
|
outcurl->state.connects = (struct connectdata **)
|
||||||
|
malloc(sizeof(struct connectdata *) * outcurl->state.numconnects);
|
||||||
|
|
||||||
|
if(!outcurl->state.connects) {
|
||||||
|
free(outcurl->state.headerbuff);
|
||||||
|
free(outcurl);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
memset(outcurl->state.connects, 0,
|
||||||
|
sizeof(struct connectdata *)*outcurl->state.numconnects);
|
||||||
|
|
||||||
|
outcurl->progress.flags = data->progress.flags;
|
||||||
|
outcurl->progress.callback = data->progress.callback;
|
||||||
|
|
||||||
|
if(data->cookies)
|
||||||
|
/* If cookies are enabled in the parent handle, we enable them
|
||||||
|
in the clone as well! */
|
||||||
|
outcurl->cookies = Curl_cookie_init(data->cookies->filename,
|
||||||
|
outcurl->cookies);
|
||||||
|
|
||||||
|
/* duplicate all values in 'change' */
|
||||||
|
if(data->change.url) {
|
||||||
|
outcurl->change.url = strdup(data->change.url);
|
||||||
|
outcurl->change.url_alloc = TRUE;
|
||||||
|
}
|
||||||
|
if(data->change.proxy) {
|
||||||
|
outcurl->change.proxy = strdup(data->change.proxy);
|
||||||
|
outcurl->change.proxy_alloc = TRUE;
|
||||||
|
}
|
||||||
|
if(data->change.referer) {
|
||||||
|
outcurl->change.referer = strdup(data->change.referer);
|
||||||
|
outcurl->change.referer_alloc = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return outcurl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
31
lib/escape.c
31
lib/escape.c
@@ -37,9 +37,9 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
char *curl_escape(char *string, int length)
|
char *curl_escape(const char *string, int length)
|
||||||
{
|
{
|
||||||
int alloc = (length?length:strlen(string))+1;
|
int alloc = (length?length:(int)strlen(string))+1;
|
||||||
char *ns = malloc(alloc);
|
char *ns = malloc(alloc);
|
||||||
unsigned char in;
|
unsigned char in;
|
||||||
int newlen = alloc;
|
int newlen = alloc;
|
||||||
@@ -54,19 +54,6 @@ char *curl_escape(char *string, int length)
|
|||||||
!(in >= 'A' && in <= 'Z') &&
|
!(in >= 'A' && in <= 'Z') &&
|
||||||
!(in >= '0' && in <= '9')) {
|
!(in >= '0' && in <= '9')) {
|
||||||
/* encode it */
|
/* encode it */
|
||||||
if(('%' == in) &&
|
|
||||||
(length>=2) &&
|
|
||||||
isxdigit((int)string[1]) &&
|
|
||||||
isxdigit((int)string[2]) ) {
|
|
||||||
/*
|
|
||||||
* This is an already encoded letter, leave it!
|
|
||||||
*/
|
|
||||||
memcpy(&ns[index], string, 3);
|
|
||||||
string+=2;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
/* encode this now */
|
|
||||||
|
|
||||||
newlen += 2; /* the size grows with two, since this'll become a %XX */
|
newlen += 2; /* the size grows with two, since this'll become a %XX */
|
||||||
if(newlen > alloc) {
|
if(newlen > alloc) {
|
||||||
alloc *= 2;
|
alloc *= 2;
|
||||||
@@ -75,7 +62,7 @@ char *curl_escape(char *string, int length)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
sprintf(&ns[index], "%%%02X", in);
|
sprintf(&ns[index], "%%%02X", in);
|
||||||
}
|
|
||||||
index+=3;
|
index+=3;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@@ -88,9 +75,9 @@ char *curl_escape(char *string, int length)
|
|||||||
return ns;
|
return ns;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *curl_unescape(char *string, int length)
|
char *curl_unescape(const char *string, int length)
|
||||||
{
|
{
|
||||||
int alloc = (length?length:strlen(string))+1;
|
int alloc = (length?length:(int)strlen(string))+1;
|
||||||
char *ns = malloc(alloc);
|
char *ns = malloc(alloc);
|
||||||
unsigned char in;
|
unsigned char in;
|
||||||
int index=0;
|
int index=0;
|
||||||
@@ -123,3 +110,11 @@ char *curl_unescape(char *string, int length)
|
|||||||
return ns;
|
return ns;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -26,7 +26,7 @@
|
|||||||
/* Escape and unescape URL encoding in strings. The functions return a new
|
/* Escape and unescape URL encoding in strings. The functions return a new
|
||||||
* allocated string or NULL if an error occurred. */
|
* allocated string or NULL if an error occurred. */
|
||||||
|
|
||||||
char *curl_escape(char *string, int length);
|
char *curl_escape(const char *string, int length);
|
||||||
char *curl_unescape(char *string, int length);
|
char *curl_unescape(const char *string, int length);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
20
lib/file.c
20
lib/file.c
@@ -140,10 +140,10 @@ CURLcode Curl_file(struct connectdata *conn)
|
|||||||
*/
|
*/
|
||||||
CURLcode res = CURLE_OK;
|
CURLcode res = CURLE_OK;
|
||||||
struct stat statbuf;
|
struct stat statbuf;
|
||||||
size_t expected_size=-1;
|
ssize_t expected_size=-1;
|
||||||
size_t nread;
|
ssize_t nread;
|
||||||
struct UrlData *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
char *buf = data->buffer;
|
char *buf = data->state.buffer;
|
||||||
int bytecount = 0;
|
int bytecount = 0;
|
||||||
struct timeval start = Curl_tvnow();
|
struct timeval start = Curl_tvnow();
|
||||||
struct timeval now = start;
|
struct timeval now = start;
|
||||||
@@ -152,6 +152,7 @@ CURLcode Curl_file(struct connectdata *conn)
|
|||||||
/* get the fd from the connection phase */
|
/* get the fd from the connection phase */
|
||||||
fd = conn->proto.file->fd;
|
fd = conn->proto.file->fd;
|
||||||
|
|
||||||
|
/*VMS?? -- This only works reliable for STREAMLF files */
|
||||||
if( -1 != fstat(fd, &statbuf)) {
|
if( -1 != fstat(fd, &statbuf)) {
|
||||||
/* we could stat it, then read out the size */
|
/* we could stat it, then read out the size */
|
||||||
expected_size = statbuf.st_size;
|
expected_size = statbuf.st_size;
|
||||||
@@ -167,11 +168,12 @@ CURLcode Curl_file(struct connectdata *conn)
|
|||||||
while (res == CURLE_OK) {
|
while (res == CURLE_OK) {
|
||||||
nread = read(fd, buf, BUFSIZE-1);
|
nread = read(fd, buf, BUFSIZE-1);
|
||||||
|
|
||||||
if (0 <= nread)
|
if ( nread > 0)
|
||||||
buf[nread] = 0;
|
buf[nread] = 0;
|
||||||
|
|
||||||
if (nread <= 0)
|
if (nread <= 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
bytecount += nread;
|
bytecount += nread;
|
||||||
/* NOTE: The following call to fwrite does CR/LF translation on
|
/* NOTE: The following call to fwrite does CR/LF translation on
|
||||||
Windows systems if the target is stdout. Use -O or -o parameters
|
Windows systems if the target is stdout. Use -O or -o parameters
|
||||||
@@ -194,3 +196,11 @@ CURLcode Curl_file(struct connectdata *conn)
|
|||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
862
lib/formdata.c
862
lib/formdata.c
File diff suppressed because it is too large
Load Diff
@@ -36,6 +36,17 @@ struct Form {
|
|||||||
been sent in a previous invoke */
|
been sent in a previous invoke */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* used by FormAdd for temporary storage */
|
||||||
|
typedef struct FormInfo {
|
||||||
|
char *name;
|
||||||
|
long namelength;
|
||||||
|
char *value;
|
||||||
|
long contentslength;
|
||||||
|
char *contenttype;
|
||||||
|
long flags;
|
||||||
|
struct FormInfo *more;
|
||||||
|
} FormInfo;
|
||||||
|
|
||||||
int Curl_FormInit(struct Form *form, struct FormData *formdata );
|
int Curl_FormInit(struct Form *form, struct FormData *formdata );
|
||||||
|
|
||||||
struct FormData *Curl_getFormData(struct HttpPost *post,
|
struct FormData *Curl_getFormData(struct HttpPost *post,
|
||||||
@@ -47,8 +58,15 @@ int Curl_FormReader(char *buffer,
|
|||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *mydata);
|
FILE *mydata);
|
||||||
|
|
||||||
|
/* possible (old) fread() emulation that copies at most one line */
|
||||||
|
int Curl_FormReadOneLine(char *buffer,
|
||||||
|
size_t size,
|
||||||
|
size_t nitems,
|
||||||
|
FILE *mydata);
|
||||||
|
|
||||||
char *Curl_FormBoundary(void);
|
char *Curl_FormBoundary(void);
|
||||||
|
|
||||||
void Curl_FormFree(struct FormData *);
|
void Curl_formclean(struct FormData *);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -28,11 +28,10 @@ CURLcode Curl_ftp_done(struct connectdata *conn);
|
|||||||
CURLcode Curl_ftp_connect(struct connectdata *conn);
|
CURLcode Curl_ftp_connect(struct connectdata *conn);
|
||||||
CURLcode Curl_ftp_disconnect(struct connectdata *conn);
|
CURLcode Curl_ftp_disconnect(struct connectdata *conn);
|
||||||
|
|
||||||
size_t Curl_ftpsendf(int fd, struct connectdata *, char *fmt, ...);
|
size_t Curl_ftpsendf(struct connectdata *, const char *fmt, ...);
|
||||||
|
|
||||||
/* The kerberos stuff needs this: */
|
/* The kerberos stuff needs this: */
|
||||||
int Curl_GetFTPResponse(int sockfd, char *buf,
|
int Curl_GetFTPResponse(char *buf, struct connectdata *conn,
|
||||||
struct connectdata *conn,
|
|
||||||
int *ftpcode);
|
int *ftpcode);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -1524,9 +1524,11 @@ yyerrhandle:
|
|||||||
the same signature as the function definition does. */
|
the same signature as the function definition does. */
|
||||||
#include "getdate.h"
|
#include "getdate.h"
|
||||||
|
|
||||||
|
#ifndef WIN32 /* the windows dudes don't need these, does anyone really? */
|
||||||
extern struct tm *gmtime ();
|
extern struct tm *gmtime ();
|
||||||
extern struct tm *localtime ();
|
extern struct tm *localtime ();
|
||||||
extern time_t mktime ();
|
extern time_t mktime ();
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Month and day table. */
|
/* Month and day table. */
|
||||||
static TABLE const MonthDayTable[] = {
|
static TABLE const MonthDayTable[] = {
|
||||||
@@ -2124,3 +2126,11 @@ main (ac, av)
|
|||||||
/* NOTREACHED */
|
/* NOTREACHED */
|
||||||
}
|
}
|
||||||
#endif /* defined (TEST) */
|
#endif /* defined (TEST) */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -477,9 +477,11 @@ o_merid : /* NULL */
|
|||||||
the same signature as the function definition does. */
|
the same signature as the function definition does. */
|
||||||
#include "getdate.h"
|
#include "getdate.h"
|
||||||
|
|
||||||
|
#ifndef WIN32 /* the windows dudes don't need these, does anyone really? */
|
||||||
extern struct tm *gmtime ();
|
extern struct tm *gmtime ();
|
||||||
extern struct tm *localtime ();
|
extern struct tm *localtime ();
|
||||||
extern time_t mktime ();
|
extern time_t mktime ();
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Month and day table. */
|
/* Month and day table. */
|
||||||
static TABLE const MonthDayTable[] = {
|
static TABLE const MonthDayTable[] = {
|
||||||
|
24
lib/getenv.c
24
lib/getenv.c
@@ -29,12 +29,16 @@
|
|||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef VMS
|
||||||
|
#include <unixlib.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static
|
static
|
||||||
char *GetEnv(char *variable)
|
char *GetEnv(const char *variable)
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
/* This shit requires windows.h (HUGE) to be included */
|
/* This shit requires windows.h (HUGE) to be included */
|
||||||
@@ -43,14 +47,30 @@ char *GetEnv(char *variable)
|
|||||||
env[0] = '\0';
|
env[0] = '\0';
|
||||||
if (temp != NULL)
|
if (temp != NULL)
|
||||||
ExpandEnvironmentStrings(temp, env, sizeof(env));
|
ExpandEnvironmentStrings(temp, env, sizeof(env));
|
||||||
|
#else
|
||||||
|
#ifdef VMS
|
||||||
|
char *env = getenv(variable);
|
||||||
|
if (env && strcmp("HOME",variable) == 0) {
|
||||||
|
env = decc$translate_vms(env);
|
||||||
|
}
|
||||||
|
/* printf ("Getenv: %s=%s\n",variable,env); */
|
||||||
#else
|
#else
|
||||||
/* no length control */
|
/* no length control */
|
||||||
char *env = getenv(variable);
|
char *env = getenv(variable);
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
return (env && env[0])?strdup(env):NULL;
|
return (env && env[0])?strdup(env):NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *curl_getenv(char *v)
|
char *curl_getenv(const char *v)
|
||||||
{
|
{
|
||||||
return GetEnv(v);
|
return GetEnv(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -31,13 +31,32 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
CURLcode Curl_getinfo(CURL *curl, CURLINFO info, ...)
|
/*
|
||||||
|
* This is supposed to be called in the beginning of a permform() session
|
||||||
|
* and should reset all session-info variables
|
||||||
|
*/
|
||||||
|
CURLcode Curl_initinfo(struct SessionHandle *data)
|
||||||
|
{
|
||||||
|
struct Progress *pro = &data->progress;
|
||||||
|
struct PureInfo *info =&data->info;
|
||||||
|
|
||||||
|
pro->t_nslookup = 0;
|
||||||
|
pro->t_connect = 0;
|
||||||
|
pro->t_pretransfer = 0;
|
||||||
|
|
||||||
|
info->httpcode = 0;
|
||||||
|
info->httpversion=0;
|
||||||
|
info->filetime=-1; /* -1 is an illegal time and thus means unknown */
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
CURLcode Curl_getinfo(struct SessionHandle *data, CURLINFO info, ...)
|
||||||
{
|
{
|
||||||
va_list arg;
|
va_list arg;
|
||||||
long *param_longp;
|
long *param_longp;
|
||||||
double *param_doublep;
|
double *param_doublep;
|
||||||
char **param_charp;
|
char **param_charp;
|
||||||
struct UrlData *data = (struct UrlData *)curl;
|
|
||||||
va_start(arg, info);
|
va_start(arg, info);
|
||||||
|
|
||||||
switch(info&CURLINFO_TYPEMASK) {
|
switch(info&CURLINFO_TYPEMASK) {
|
||||||
@@ -62,19 +81,19 @@ CURLcode Curl_getinfo(CURL *curl, CURLINFO info, ...)
|
|||||||
|
|
||||||
switch(info) {
|
switch(info) {
|
||||||
case CURLINFO_EFFECTIVE_URL:
|
case CURLINFO_EFFECTIVE_URL:
|
||||||
*param_charp = data->url?data->url:"";
|
*param_charp = data->change.url?data->change.url:(char *)"";
|
||||||
break;
|
break;
|
||||||
case CURLINFO_HTTP_CODE:
|
case CURLINFO_HTTP_CODE:
|
||||||
*param_longp = data->progress.httpcode;
|
*param_longp = data->info.httpcode;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_FILETIME:
|
case CURLINFO_FILETIME:
|
||||||
*param_longp = data->progress.filetime;
|
*param_longp = data->info.filetime;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_HEADER_SIZE:
|
case CURLINFO_HEADER_SIZE:
|
||||||
*param_longp = data->header_size;
|
*param_longp = data->info.header_size;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_REQUEST_SIZE:
|
case CURLINFO_REQUEST_SIZE:
|
||||||
*param_longp = data->request_size;
|
*param_longp = data->info.request_size;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_TOTAL_TIME:
|
case CURLINFO_TOTAL_TIME:
|
||||||
*param_doublep = data->progress.timespent;
|
*param_doublep = data->progress.timespent;
|
||||||
@@ -101,7 +120,7 @@ CURLcode Curl_getinfo(CURL *curl, CURLINFO info, ...)
|
|||||||
*param_doublep = data->progress.ulspeed;
|
*param_doublep = data->progress.ulspeed;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_SSL_VERIFYRESULT:
|
case CURLINFO_SSL_VERIFYRESULT:
|
||||||
*param_longp = data->ssl.certverifyresult;
|
*param_longp = data->set.ssl.certverifyresult;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_CONTENT_LENGTH_DOWNLOAD:
|
case CURLINFO_CONTENT_LENGTH_DOWNLOAD:
|
||||||
*param_doublep = data->progress.size_dl;
|
*param_doublep = data->progress.size_dl;
|
||||||
@@ -114,3 +133,11 @@ CURLcode Curl_getinfo(CURL *curl, CURLINFO info, ...)
|
|||||||
}
|
}
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
28
lib/getinfo.h
Normal file
28
lib/getinfo.h
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
#ifndef __GETINFO_H
|
||||||
|
#define __GETINFO_H
|
||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
CURLcode Curl_getinfo(struct SessionHandle *data, CURLINFO info, ...);
|
||||||
|
CURLcode Curl_initinfo(struct SessionHandle *data);
|
||||||
|
|
||||||
|
#endif
|
@@ -42,6 +42,30 @@
|
|||||||
#ifndef HAVE_GETPASS_R
|
#ifndef HAVE_GETPASS_R
|
||||||
|
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
|
#ifdef VMS
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include descrip
|
||||||
|
#include starlet
|
||||||
|
#include iodef
|
||||||
|
#include iosbdef
|
||||||
|
char *getpass_r(const char *prompt, char *buffer, size_t buflen)
|
||||||
|
{
|
||||||
|
long sts;
|
||||||
|
short chan;
|
||||||
|
struct _iosb iosb;
|
||||||
|
$DESCRIPTOR(ttdesc, "TT");
|
||||||
|
|
||||||
|
buffer[0]='\0';
|
||||||
|
if ((sts = sys$assign(&ttdesc, &chan,0,0)) & 1) {
|
||||||
|
if (((sts = sys$qiow(0, chan, IO$_READPROMPT | IO$M_NOECHO, &iosb, 0, 0, buffer, buflen, 0, 0, prompt, strlen(prompt))) & 1) && (iosb.iosb$w_status&1)) {
|
||||||
|
buffer[iosb.iosb$w_bcnt] = '\0';
|
||||||
|
}
|
||||||
|
sts = sys$dassgn(chan);
|
||||||
|
}
|
||||||
|
return buffer; /* we always return success */
|
||||||
|
}
|
||||||
|
#else /* VMS */
|
||||||
#ifdef HAVE_TERMIOS_H
|
#ifdef HAVE_TERMIOS_H
|
||||||
# if !defined(HAVE_TCGETATTR) && !defined(HAVE_TCSETATTR)
|
# if !defined(HAVE_TCGETATTR) && !defined(HAVE_TCSETATTR)
|
||||||
# undef HAVE_TERMIOS_H
|
# undef HAVE_TERMIOS_H
|
||||||
@@ -186,6 +210,7 @@ char *getpass_r(const char *prompt, char *buffer, size_t buflen)
|
|||||||
|
|
||||||
return buffer; /* we always return success */
|
return buffer; /* we always return success */
|
||||||
}
|
}
|
||||||
|
#endif /* VMS */
|
||||||
#else /* WIN32 */
|
#else /* WIN32 */
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <conio.h>
|
#include <conio.h>
|
||||||
@@ -219,3 +244,11 @@ char *getpass(const char *prompt)
|
|||||||
return getpass_r(prompt, buf, sizeof(buf));
|
return getpass_r(prompt, buf, sizeof(buf));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -29,7 +29,7 @@
|
|||||||
/*
|
/*
|
||||||
* Returning NULL will abort the continued operation!
|
* Returning NULL will abort the continued operation!
|
||||||
*/
|
*/
|
||||||
char* getpass_r(char *prompt, char* buffer, size_t buflen );
|
char* getpass_r(const char *prompt, char* buffer, size_t buflen );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
210
lib/hostip.c
210
lib/hostip.c
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* In order to be useful for every potential user, curl and libcurl are
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
@@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
#define _REENTRANT
|
#define _REENTRANT
|
||||||
|
|
||||||
|
|
||||||
#if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__)
|
#if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__)
|
||||||
#include <winsock.h>
|
#include <winsock.h>
|
||||||
#else
|
#else
|
||||||
@@ -46,10 +47,15 @@
|
|||||||
#ifdef HAVE_ARPA_INET_H
|
#ifdef HAVE_ARPA_INET_H
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef VMS
|
||||||
|
#include <inet.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
|
#include "hostip.h"
|
||||||
|
|
||||||
#if defined(HAVE_INET_NTOA_R) && !defined(HAVE_INET_NTOA_R_DECL)
|
#if defined(HAVE_INET_NTOA_R) && !defined(HAVE_INET_NTOA_R_DECL)
|
||||||
#include "inet_ntoa_r.h"
|
#include "inet_ntoa_r.h"
|
||||||
@@ -60,8 +66,168 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is a wrapper function for freeing name information in a protocol
|
||||||
|
* independent way. This takes care of using the appropriate underlaying
|
||||||
|
* proper function.
|
||||||
|
*/
|
||||||
|
void Curl_freeaddrinfo(void *freethis)
|
||||||
|
{
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
freeaddrinfo(freethis);
|
||||||
|
#else
|
||||||
|
free(freethis);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/* --- resolve name or IP-number --- */
|
/* --- resolve name or IP-number --- */
|
||||||
|
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
/* These two are strictly for memory tracing and are using the same
|
||||||
|
* style as the family otherwise present in memdebug.c. I put these ones
|
||||||
|
* here since they require a bunch of struct types I didn't wanna include
|
||||||
|
* in memdebug.c
|
||||||
|
*/
|
||||||
|
int curl_getaddrinfo(char *hostname, char *service,
|
||||||
|
struct addrinfo *hints,
|
||||||
|
struct addrinfo **result,
|
||||||
|
int line, const char *source)
|
||||||
|
{
|
||||||
|
int res=(getaddrinfo)(hostname, service, hints, result);
|
||||||
|
if(0 == res) {
|
||||||
|
/* success */
|
||||||
|
if(logfile)
|
||||||
|
fprintf(logfile, "ADDR %s:%d getaddrinfo() = %p\n",
|
||||||
|
source, line, *result);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(logfile)
|
||||||
|
fprintf(logfile, "ADDR %s:%d getaddrinfo() failed\n",
|
||||||
|
source, line);
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
void curl_freeaddrinfo(struct addrinfo *freethis,
|
||||||
|
int line, const char *source)
|
||||||
|
{
|
||||||
|
(freeaddrinfo)(freethis);
|
||||||
|
if(logfile)
|
||||||
|
fprintf(logfile, "ADDR %s:%d freeaddrinfo(%p)\n",
|
||||||
|
source, line, freethis);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return name information about the given hostname and port number. If
|
||||||
|
* successful, the 'addrinfo' is returned and the forth argument will point to
|
||||||
|
* memory we need to free after use. That meory *MUST* be freed with
|
||||||
|
* Curl_freeaddrinfo(), nothing else.
|
||||||
|
*/
|
||||||
|
Curl_addrinfo *Curl_getaddrinfo(struct SessionHandle *data,
|
||||||
|
char *hostname,
|
||||||
|
int port,
|
||||||
|
char **bufp)
|
||||||
|
{
|
||||||
|
struct addrinfo hints, *res;
|
||||||
|
int error;
|
||||||
|
char sbuf[NI_MAXSERV];
|
||||||
|
|
||||||
|
memset(&hints, 0, sizeof(hints));
|
||||||
|
hints.ai_family = PF_UNSPEC;
|
||||||
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
|
hints.ai_flags = AI_CANONNAME;
|
||||||
|
snprintf(sbuf, sizeof(sbuf), "%d", port);
|
||||||
|
error = getaddrinfo(hostname, sbuf, &hints, &res);
|
||||||
|
if (error) {
|
||||||
|
infof(data, "getaddrinfo(3) failed for %s\n", hostname);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
*bufp=(char *)res; /* make it point to the result struct */
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
#else /* following code is IPv4-only */
|
||||||
|
|
||||||
|
#ifndef HAVE_GETHOSTBYNAME_R
|
||||||
|
/**
|
||||||
|
* Performs a "deep" copy of a hostent into a buffer (returns a pointer to the
|
||||||
|
* copy). Make absolutely sure the destination buffer is big enough!
|
||||||
|
*
|
||||||
|
* Keith McGuigan
|
||||||
|
* 10/3/2001 */
|
||||||
|
static struct hostent* pack_hostent(char* buf, struct hostent* orig)
|
||||||
|
{
|
||||||
|
char* bufptr;
|
||||||
|
struct hostent* copy;
|
||||||
|
|
||||||
|
int i;
|
||||||
|
char* str;
|
||||||
|
int len;
|
||||||
|
|
||||||
|
bufptr = buf;
|
||||||
|
copy = (struct hostent*)bufptr;
|
||||||
|
|
||||||
|
bufptr += sizeof(struct hostent);
|
||||||
|
copy->h_name = bufptr;
|
||||||
|
len = strlen(orig->h_name) + 1;
|
||||||
|
strncpy(bufptr, orig->h_name, len);
|
||||||
|
bufptr += len;
|
||||||
|
|
||||||
|
/* we align on even 64bit boundaries for safety */
|
||||||
|
#define MEMALIGN(x) (((unsigned long)(x)&0xfffffff8)+8)
|
||||||
|
|
||||||
|
/* This must be aligned properly to work on many CPU architectures! */
|
||||||
|
copy->h_aliases = (char**)MEMALIGN(bufptr);
|
||||||
|
|
||||||
|
/* Figure out how many aliases there are */
|
||||||
|
for (i = 0; orig->h_aliases[i] != NULL; ++i);
|
||||||
|
|
||||||
|
/* Reserve room for the array */
|
||||||
|
bufptr += (i + 1) * sizeof(char*);
|
||||||
|
|
||||||
|
/* Clone all known aliases */
|
||||||
|
for(i = 0; (str = orig->h_aliases[i]); i++) {
|
||||||
|
len = strlen(str) + 1;
|
||||||
|
strncpy(bufptr, str, len);
|
||||||
|
copy->h_aliases[i] = bufptr;
|
||||||
|
bufptr += len;
|
||||||
|
}
|
||||||
|
/* Terminate the alias list with a NULL */
|
||||||
|
copy->h_aliases[i] = NULL;
|
||||||
|
|
||||||
|
copy->h_addrtype = orig->h_addrtype;
|
||||||
|
copy->h_length = orig->h_length;
|
||||||
|
|
||||||
|
/* align it for (at least) 32bit accesses */
|
||||||
|
bufptr = (char *)MEMALIGN(bufptr);
|
||||||
|
|
||||||
|
copy->h_addr_list = (char**)bufptr;
|
||||||
|
|
||||||
|
/* Figure out how many addresses there are */
|
||||||
|
for (i = 0; orig->h_addr_list[i] != NULL; ++i);
|
||||||
|
|
||||||
|
/* Reserve room for the array */
|
||||||
|
bufptr += (i + 1) * sizeof(char*);
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
len = orig->h_length;
|
||||||
|
str = orig->h_addr_list[i];
|
||||||
|
while (str != NULL) {
|
||||||
|
memcpy(bufptr, str, len);
|
||||||
|
copy->h_addr_list[i] = bufptr;
|
||||||
|
bufptr += len;
|
||||||
|
str = orig->h_addr_list[++i];
|
||||||
|
}
|
||||||
|
copy->h_addr_list[i] = NULL;
|
||||||
|
|
||||||
|
return copy;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static char *MakeIP(unsigned long num,char *addr, int addr_len)
|
static char *MakeIP(unsigned long num,char *addr, int addr_len)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_INET_NTOA) || defined(HAVE_INET_NTOA_R)
|
#if defined(HAVE_INET_NTOA) || defined(HAVE_INET_NTOA_R)
|
||||||
@@ -83,29 +249,6 @@ static char *MakeIP(unsigned long num,char *addr, int addr_len)
|
|||||||
return (addr);
|
return (addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ENABLE_IPV6
|
|
||||||
struct addrinfo *Curl_getaddrinfo(struct UrlData *data,
|
|
||||||
char *hostname,
|
|
||||||
int port)
|
|
||||||
{
|
|
||||||
struct addrinfo hints, *res;
|
|
||||||
int error;
|
|
||||||
char sbuf[NI_MAXSERV];
|
|
||||||
|
|
||||||
memset(&hints, 0, sizeof(hints));
|
|
||||||
hints.ai_family = PF_UNSPEC;
|
|
||||||
hints.ai_socktype = SOCK_STREAM;
|
|
||||||
hints.ai_flags = AI_CANONNAME;
|
|
||||||
snprintf(sbuf, sizeof(sbuf), "%d", port);
|
|
||||||
error = getaddrinfo(hostname, sbuf, &hints, &res);
|
|
||||||
if (error) {
|
|
||||||
infof(data, "getaddrinfo(3) failed for %s\n", hostname);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* The original code to this function was once stolen from the Dancer source
|
/* The original code to this function was once stolen from the Dancer source
|
||||||
code, written by Bjorn Reese, it has since been patched and modified
|
code, written by Bjorn Reese, it has since been patched and modified
|
||||||
considerably. */
|
considerably. */
|
||||||
@@ -114,8 +257,9 @@ struct addrinfo *Curl_getaddrinfo(struct UrlData *data,
|
|||||||
#define INADDR_NONE (unsigned long) ~0
|
#define INADDR_NONE (unsigned long) ~0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct hostent *Curl_gethost(struct UrlData *data,
|
Curl_addrinfo *Curl_getaddrinfo(struct SessionHandle *data,
|
||||||
char *hostname,
|
char *hostname,
|
||||||
|
int port,
|
||||||
char **bufp)
|
char **bufp)
|
||||||
{
|
{
|
||||||
struct hostent *h = NULL;
|
struct hostent *h = NULL;
|
||||||
@@ -132,6 +276,7 @@ struct hostent *Curl_gethost(struct UrlData *data,
|
|||||||
return NULL; /* major failure */
|
return NULL; /* major failure */
|
||||||
*bufp = buf;
|
*bufp = buf;
|
||||||
|
|
||||||
|
port=0; /* unused in IPv4 code */
|
||||||
ret = 0; /* to prevent the compiler warning */
|
ret = 0; /* to prevent the compiler warning */
|
||||||
|
|
||||||
if ( (in=inet_addr(hostname)) != INADDR_NONE ) {
|
if ( (in=inet_addr(hostname)) != INADDR_NONE ) {
|
||||||
@@ -206,7 +351,22 @@ struct hostent *Curl_gethost(struct UrlData *data,
|
|||||||
free(buf);
|
free(buf);
|
||||||
*bufp=NULL;
|
*bufp=NULL;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
/* we make a copy of the hostent right now, right here, as the
|
||||||
|
static one we got a pointer to might get removed when we don't
|
||||||
|
want/expect that */
|
||||||
|
h = pack_hostent(buf, h);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
return (h);
|
return (h);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* end of IPv4-specific code */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
20
lib/hostip.h
20
lib/hostip.h
@@ -24,12 +24,24 @@
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
struct addrinfo;
|
struct addrinfo;
|
||||||
struct addrinfo *Curl_getaddrinfo(struct UrlData *data,
|
struct hostent;
|
||||||
char *hostname,
|
struct SessionHandle;
|
||||||
int port);
|
|
||||||
|
|
||||||
struct hostent *Curl_gethost(struct UrlData *data,
|
/* Get name info */
|
||||||
|
Curl_addrinfo *Curl_getaddrinfo(struct SessionHandle *data,
|
||||||
char *hostname,
|
char *hostname,
|
||||||
|
int port,
|
||||||
char **bufp);
|
char **bufp);
|
||||||
|
/* free name info */
|
||||||
|
void Curl_freeaddrinfo(void *freethis);
|
||||||
|
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
void curl_freeaddrinfo(struct addrinfo *freethis,
|
||||||
|
int line, const char *source);
|
||||||
|
int curl_getaddrinfo(char *hostname, char *service,
|
||||||
|
struct addrinfo *hints,
|
||||||
|
struct addrinfo **result,
|
||||||
|
int line, const char *source);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
296
lib/http.c
296
lib/http.c
@@ -104,7 +104,7 @@
|
|||||||
* be sent in one go.
|
* be sent in one go.
|
||||||
*/
|
*/
|
||||||
static CURLcode
|
static CURLcode
|
||||||
add_buffer(send_buffer *in, void *inptr, size_t size);
|
add_buffer(send_buffer *in, const void *inptr, size_t size);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* add_buffer_init() returns a fine buffer struct
|
* add_buffer_init() returns a fine buffer struct
|
||||||
@@ -125,22 +125,27 @@ send_buffer *add_buffer_init(void)
|
|||||||
* add_buffer_send() sends a buffer and frees all associated memory.
|
* add_buffer_send() sends a buffer and frees all associated memory.
|
||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
size_t add_buffer_send(int sockfd, struct connectdata *conn, send_buffer *in)
|
CURLcode add_buffer_send(int sockfd, struct connectdata *conn, send_buffer *in,
|
||||||
|
long *bytes_written)
|
||||||
{
|
{
|
||||||
size_t amount;
|
size_t amount;
|
||||||
if(conn->data->bits.verbose) {
|
CURLcode result;
|
||||||
fputs("> ", conn->data->err);
|
|
||||||
|
if(conn->data->set.verbose) {
|
||||||
|
fputs("> ", conn->data->set.err);
|
||||||
/* this data _may_ contain binary stuff */
|
/* this data _may_ contain binary stuff */
|
||||||
fwrite(in->buffer, in->size_used, 1, conn->data->err);
|
fwrite(in->buffer, in->size_used, 1, conn->data->set.err);
|
||||||
}
|
}
|
||||||
|
|
||||||
Curl_write(conn, sockfd, in->buffer, in->size_used, &amount);
|
result = Curl_write(conn, sockfd, in->buffer, in->size_used, &amount);
|
||||||
|
|
||||||
if(in->buffer)
|
if(in->buffer)
|
||||||
free(in->buffer);
|
free(in->buffer);
|
||||||
free(in);
|
free(in);
|
||||||
|
|
||||||
return amount;
|
*bytes_written = amount;
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -148,7 +153,7 @@ size_t add_buffer_send(int sockfd, struct connectdata *conn, send_buffer *in)
|
|||||||
* add_bufferf() builds a buffer from the formatted input
|
* add_bufferf() builds a buffer from the formatted input
|
||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
CURLcode add_bufferf(send_buffer *in, char *fmt, ...)
|
CURLcode add_bufferf(send_buffer *in, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
CURLcode result = CURLE_OUT_OF_MEMORY;
|
CURLcode result = CURLE_OUT_OF_MEMORY;
|
||||||
char *s;
|
char *s;
|
||||||
@@ -168,12 +173,11 @@ CURLcode add_bufferf(send_buffer *in, char *fmt, ...)
|
|||||||
* add_buffer() appends a memory chunk to the existing one
|
* add_buffer() appends a memory chunk to the existing one
|
||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
CURLcode add_buffer(send_buffer *in, void *inptr, size_t size)
|
CURLcode add_buffer(send_buffer *in, const void *inptr, size_t size)
|
||||||
{
|
{
|
||||||
char *new_rb;
|
char *new_rb;
|
||||||
int new_size;
|
int new_size;
|
||||||
|
|
||||||
if(size > 0) {
|
|
||||||
if(!in->buffer ||
|
if(!in->buffer ||
|
||||||
((in->size_used + size) > (in->size_max - 1))) {
|
((in->size_used + size) > (in->size_max - 1))) {
|
||||||
new_size = (in->size_used+size)*2;
|
new_size = (in->size_used+size)*2;
|
||||||
@@ -193,7 +197,6 @@ CURLcode add_buffer(send_buffer *in, void *inptr, size_t size)
|
|||||||
memcpy(&in->buffer[in->size_used], inptr, size);
|
memcpy(&in->buffer[in->size_used], inptr, size);
|
||||||
|
|
||||||
in->size_used += size;
|
in->size_used += size;
|
||||||
}
|
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
@@ -206,31 +209,18 @@ CURLcode add_buffer(send_buffer *in, void *inptr, size_t size)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static
|
static
|
||||||
int GetLine(int sockfd, char *buf, struct connectdata *conn)
|
int GetLine(int sockfd, char *ptr, struct connectdata *conn)
|
||||||
{
|
{
|
||||||
ssize_t nread;
|
ssize_t nread;
|
||||||
int read_rc=1;
|
|
||||||
char *ptr;
|
|
||||||
struct UrlData *data=conn->data;
|
|
||||||
|
|
||||||
ptr=buf;
|
|
||||||
|
|
||||||
/* get us a full line, terminated with a newline */
|
/* get us a full line, terminated with a newline */
|
||||||
for(nread=0;
|
for(nread=0; (nread<BUFSIZE); nread++, ptr++) {
|
||||||
(nread<BUFSIZE) && read_rc;
|
|
||||||
nread++, ptr++) {
|
|
||||||
if((CURLE_OK != Curl_read(conn, sockfd, ptr, 1, &nread)) ||
|
if((CURLE_OK != Curl_read(conn, sockfd, ptr, 1, &nread)) ||
|
||||||
(nread <= 0) ||
|
(nread <= 0) || (*ptr == '\n'))
|
||||||
(*ptr == '\n'))
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
*ptr=0; /* zero terminate */
|
*ptr=0; /* zero terminate */
|
||||||
|
|
||||||
if(data->bits.verbose) {
|
|
||||||
fputs("< ", data->err);
|
|
||||||
fwrite(buf, 1, nread, data->err);
|
|
||||||
fputs("\n", data->err);
|
|
||||||
}
|
|
||||||
return nread>0?nread:0;
|
return nread>0?nread:0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -240,12 +230,12 @@ int GetLine(int sockfd, char *buf, struct connectdata *conn)
|
|||||||
* This function checks the linked list of custom HTTP headers for a particular
|
* This function checks the linked list of custom HTTP headers for a particular
|
||||||
* header (prefix).
|
* header (prefix).
|
||||||
*/
|
*/
|
||||||
bool static checkheaders(struct UrlData *data, char *thisheader)
|
static bool checkheaders(struct SessionHandle *data, const char *thisheader)
|
||||||
{
|
{
|
||||||
struct curl_slist *head;
|
struct curl_slist *head;
|
||||||
size_t thislen = strlen(thisheader);
|
size_t thislen = strlen(thisheader);
|
||||||
|
|
||||||
for(head = data->headers; head; head=head->next) {
|
for(head = data->set.headers; head; head=head->next) {
|
||||||
if(strnequal(head->data, thisheader, thislen)) {
|
if(strnequal(head->data, thisheader, thislen)) {
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@@ -265,11 +255,13 @@ CURLcode Curl_ConnectHTTPProxyTunnel(struct connectdata *conn,
|
|||||||
{
|
{
|
||||||
int httperror=0;
|
int httperror=0;
|
||||||
int subversion=0;
|
int subversion=0;
|
||||||
struct UrlData *data=conn->data;
|
struct SessionHandle *data=conn->data;
|
||||||
|
CURLcode result;
|
||||||
|
|
||||||
infof(data, "Establish HTTP proxy tunnel to %s:%d\n", hostname, remote_port);
|
infof(data, "Establish HTTP proxy tunnel to %s:%d\n", hostname, remote_port);
|
||||||
|
|
||||||
/* OK, now send the connect request to the proxy */
|
/* OK, now send the connect request to the proxy */
|
||||||
|
result =
|
||||||
Curl_sendf(tunnelsocket, conn,
|
Curl_sendf(tunnelsocket, conn,
|
||||||
"CONNECT %s:%d HTTP/1.0\015\012"
|
"CONNECT %s:%d HTTP/1.0\015\012"
|
||||||
"%s"
|
"%s"
|
||||||
@@ -277,14 +269,21 @@ CURLcode Curl_ConnectHTTPProxyTunnel(struct connectdata *conn,
|
|||||||
"\r\n",
|
"\r\n",
|
||||||
hostname, remote_port,
|
hostname, remote_port,
|
||||||
(conn->bits.proxy_user_passwd)?conn->allocptr.proxyuserpwd:"",
|
(conn->bits.proxy_user_passwd)?conn->allocptr.proxyuserpwd:"",
|
||||||
(data->useragent?conn->allocptr.uagent:"")
|
(data->set.useragent?conn->allocptr.uagent:"")
|
||||||
);
|
);
|
||||||
|
if(result) {
|
||||||
|
failf(data, "Failed sending CONNECT to proxy");
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
/* wait for the proxy to send us a HTTP/1.0 200 OK header */
|
/* wait for the proxy to send us a HTTP/1.0 200 OK header */
|
||||||
while(GetLine(tunnelsocket, data->buffer, conn)) {
|
while(GetLine(tunnelsocket, data->state.buffer, conn)) {
|
||||||
if('\r' == data->buffer[0])
|
if('\r' == data->state.buffer[0])
|
||||||
break; /* end of headers */
|
break; /* end of headers */
|
||||||
if(2 == sscanf(data->buffer, "HTTP/1.%d %d",
|
if(data->set.verbose)
|
||||||
|
fprintf(data->set.err, "< %s\n", data->state.buffer);
|
||||||
|
|
||||||
|
if(2 == sscanf(data->state.buffer, "HTTP/1.%d %d",
|
||||||
&subversion,
|
&subversion,
|
||||||
&httperror)) {
|
&httperror)) {
|
||||||
;
|
;
|
||||||
@@ -308,7 +307,7 @@ CURLcode Curl_ConnectHTTPProxyTunnel(struct connectdata *conn,
|
|||||||
*/
|
*/
|
||||||
CURLcode Curl_http_connect(struct connectdata *conn)
|
CURLcode Curl_http_connect(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct UrlData *data;
|
struct SessionHandle *data;
|
||||||
CURLcode result;
|
CURLcode result;
|
||||||
|
|
||||||
data=conn->data;
|
data=conn->data;
|
||||||
@@ -320,7 +319,7 @@ CURLcode Curl_http_connect(struct connectdata *conn)
|
|||||||
* has occured, can we start talking SSL
|
* has occured, can we start talking SSL
|
||||||
*/
|
*/
|
||||||
if (conn->protocol & PROT_HTTPS) {
|
if (conn->protocol & PROT_HTTPS) {
|
||||||
if (data->bits.httpproxy) {
|
if (data->change.proxy) {
|
||||||
/* HTTPS through a proxy can only be done with a tunnel */
|
/* HTTPS through a proxy can only be done with a tunnel */
|
||||||
result = Curl_ConnectHTTPProxyTunnel(conn, conn->firstsocket,
|
result = Curl_ConnectHTTPProxyTunnel(conn, conn->firstsocket,
|
||||||
conn->hostname, conn->remote_port);
|
conn->hostname, conn->remote_port);
|
||||||
@@ -334,53 +333,51 @@ CURLcode Curl_http_connect(struct connectdata *conn)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(conn->bits.user_passwd && !data->bits.this_is_a_follow) {
|
if(conn->bits.user_passwd && !data->state.this_is_a_follow) {
|
||||||
/* Authorization: is requested, this is not a followed location, get the
|
/* Authorization: is requested, this is not a followed location, get the
|
||||||
original host name */
|
original host name */
|
||||||
data->auth_host = strdup(conn->hostname);
|
data->state.auth_host = strdup(conn->hostname);
|
||||||
}
|
}
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* called from curl_close() when this struct is about to get wasted, free
|
|
||||||
protocol-specific resources */
|
|
||||||
CURLcode Curl_http_close(struct connectdata *conn)
|
|
||||||
{
|
|
||||||
if(conn->data->auth_host)
|
|
||||||
free(conn->data->auth_host);
|
|
||||||
return CURLE_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
CURLcode Curl_http_done(struct connectdata *conn)
|
CURLcode Curl_http_done(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct UrlData *data;
|
struct SessionHandle *data;
|
||||||
long *bytecount = &conn->bytecount;
|
long *bytecount = &conn->bytecount;
|
||||||
struct HTTP *http;
|
struct HTTP *http;
|
||||||
|
|
||||||
data=conn->data;
|
data=conn->data;
|
||||||
http=conn->proto.http;
|
http=conn->proto.http;
|
||||||
|
|
||||||
if(data->bits.http_formpost) {
|
if(HTTPREQ_POST_FORM == data->set.httpreq) {
|
||||||
*bytecount = http->readbytecount + http->writebytecount;
|
*bytecount = http->readbytecount + http->writebytecount;
|
||||||
|
|
||||||
Curl_FormFree(http->sendit); /* Now free that whole lot */
|
Curl_formclean(http->sendit); /* Now free that whole lot */
|
||||||
|
|
||||||
data->fread = http->storefread; /* restore */
|
data->set.fread = http->storefread; /* restore */
|
||||||
data->in = http->in; /* restore */
|
data->set.in = http->in; /* restore */
|
||||||
}
|
}
|
||||||
else if(data->bits.http_put) {
|
else if(HTTPREQ_PUT == data->set.httpreq) {
|
||||||
*bytecount = http->readbytecount + http->writebytecount;
|
*bytecount = http->readbytecount + http->writebytecount;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(0 == (http->readbytecount + conn->headerbytecount)) {
|
||||||
|
/* nothing was read from the HTTP server, this can't be right
|
||||||
|
so we return an error here */
|
||||||
|
failf(data, "Empty reply from server\n");
|
||||||
|
return CURLE_GOT_NOTHING;
|
||||||
|
}
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
CURLcode Curl_http(struct connectdata *conn)
|
CURLcode Curl_http(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct UrlData *data=conn->data;
|
struct SessionHandle *data=conn->data;
|
||||||
char *buf = data->buffer; /* this is a short cut to the buffer */
|
char *buf = data->state.buffer; /* this is a short cut to the buffer */
|
||||||
CURLcode result=CURLE_OK;
|
CURLcode result=CURLE_OK;
|
||||||
struct HTTP *http;
|
struct HTTP *http;
|
||||||
struct Cookie *co=NULL; /* no cookies from start */
|
struct Cookie *co=NULL; /* no cookies from start */
|
||||||
@@ -404,8 +401,8 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
conn->bits.close = FALSE;
|
conn->bits.close = FALSE;
|
||||||
|
|
||||||
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
|
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
|
||||||
data->bits.upload) {
|
data->set.upload) {
|
||||||
data->bits.http_put=1;
|
data->set.httpreq = HTTPREQ_PUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The User-Agent string has been built in url.c already, because it might
|
/* The User-Agent string has been built in url.c already, because it might
|
||||||
@@ -422,11 +419,12 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
|
|
||||||
/* To prevent the user+password to get sent to other than the original
|
/* To prevent the user+password to get sent to other than the original
|
||||||
host due to a location-follow, we do some weirdo checks here */
|
host due to a location-follow, we do some weirdo checks here */
|
||||||
if(!data->bits.this_is_a_follow ||
|
if(!data->state.this_is_a_follow ||
|
||||||
!data->auth_host ||
|
!data->state.auth_host ||
|
||||||
strequal(data->auth_host, conn->hostname)) {
|
strequal(data->state.auth_host, conn->hostname)) {
|
||||||
sprintf(data->buffer, "%s:%s", data->user, data->passwd);
|
sprintf(data->state.buffer, "%s:%s",
|
||||||
if(Curl_base64_encode(data->buffer, strlen(data->buffer),
|
data->state.user, data->state.passwd);
|
||||||
|
if(Curl_base64_encode(data->state.buffer, strlen(data->state.buffer),
|
||||||
&authorization) >= 0) {
|
&authorization) >= 0) {
|
||||||
if(conn->allocptr.userpwd)
|
if(conn->allocptr.userpwd)
|
||||||
free(conn->allocptr.userpwd);
|
free(conn->allocptr.userpwd);
|
||||||
@@ -436,31 +434,30 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if((data->bits.http_set_referer) && !checkheaders(data, "Referer:")) {
|
if((data->change.referer) && !checkheaders(data, "Referer:")) {
|
||||||
if(conn->allocptr.ref)
|
if(conn->allocptr.ref)
|
||||||
free(conn->allocptr.ref);
|
free(conn->allocptr.ref);
|
||||||
conn->allocptr.ref = aprintf("Referer: %s\015\012", data->referer);
|
conn->allocptr.ref = aprintf("Referer: %s\015\012", data->change.referer);
|
||||||
}
|
}
|
||||||
if(data->cookie && !checkheaders(data, "Cookie:")) {
|
if(data->set.cookie && !checkheaders(data, "Cookie:")) {
|
||||||
if(conn->allocptr.cookie)
|
if(conn->allocptr.cookie)
|
||||||
free(conn->allocptr.cookie);
|
free(conn->allocptr.cookie);
|
||||||
conn->allocptr.cookie = aprintf("Cookie: %s\015\012", data->cookie);
|
conn->allocptr.cookie = aprintf("Cookie: %s\015\012", data->set.cookie);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->cookies) {
|
if(data->cookies) {
|
||||||
co = Curl_cookie_getlist(data->cookies,
|
co = Curl_cookie_getlist(data->cookies,
|
||||||
host,
|
host, ppath,
|
||||||
ppath,
|
|
||||||
conn->protocol&PROT_HTTPS?TRUE:FALSE);
|
conn->protocol&PROT_HTTPS?TRUE:FALSE);
|
||||||
}
|
}
|
||||||
if ((data->bits.httpproxy) && !(conn->protocol&PROT_HTTPS)) {
|
if ((data->change.proxy) && !(conn->protocol&PROT_HTTPS)) {
|
||||||
/* The path sent to the proxy is in fact the entire URL */
|
/* The path sent to the proxy is in fact the entire URL */
|
||||||
ppath = data->url;
|
ppath = data->change.url;
|
||||||
}
|
}
|
||||||
if(data->bits.http_formpost) {
|
if(HTTPREQ_POST_FORM == data->set.httpreq) {
|
||||||
/* we must build the whole darned post sequence first, so that we have
|
/* we must build the whole darned post sequence first, so that we have
|
||||||
a size of the whole shebang before we start to send it */
|
a size of the whole shebang before we start to send it */
|
||||||
http->sendit = Curl_getFormData(data->httppost, &http->postsize);
|
http->sendit = Curl_getFormData(data->set.httppost, &http->postsize);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!checkheaders(data, "Host:")) {
|
if(!checkheaders(data, "Host:")) {
|
||||||
@@ -488,9 +485,9 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
if(!checkheaders(data, "Accept:"))
|
if(!checkheaders(data, "Accept:"))
|
||||||
http->p_accept = "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*\r\n";
|
http->p_accept = "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*\r\n";
|
||||||
|
|
||||||
if((data->bits.http_post ||
|
if(( (HTTPREQ_POST == data->set.httpreq) ||
|
||||||
data->bits.http_formpost ||
|
(HTTPREQ_POST_FORM == data->set.httpreq) ||
|
||||||
data->bits.http_put) &&
|
(HTTPREQ_PUT == data->set.httpreq) ) &&
|
||||||
conn->resume_from) {
|
conn->resume_from) {
|
||||||
/**********************************************************************
|
/**********************************************************************
|
||||||
* Resuming upload in HTTP means that we PUT or POST and that we have
|
* Resuming upload in HTTP means that we PUT or POST and that we have
|
||||||
@@ -523,7 +520,8 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
readthisamountnow = BUFSIZE;
|
readthisamountnow = BUFSIZE;
|
||||||
|
|
||||||
actuallyread =
|
actuallyread =
|
||||||
data->fread(data->buffer, 1, readthisamountnow, data->in);
|
data->set.fread(data->state.buffer, 1, readthisamountnow,
|
||||||
|
data->set.in);
|
||||||
|
|
||||||
passed += actuallyread;
|
passed += actuallyread;
|
||||||
if(actuallyread != readthisamountnow) {
|
if(actuallyread != readthisamountnow) {
|
||||||
@@ -534,10 +532,10 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
} while(passed != conn->resume_from); /* loop until done */
|
} while(passed != conn->resume_from); /* loop until done */
|
||||||
|
|
||||||
/* now, decrease the size of the read */
|
/* now, decrease the size of the read */
|
||||||
if(data->infilesize>0) {
|
if(data->set.infilesize>0) {
|
||||||
data->infilesize -= conn->resume_from;
|
data->set.infilesize -= conn->resume_from;
|
||||||
|
|
||||||
if(data->infilesize <= 0) {
|
if(data->set.infilesize <= 0) {
|
||||||
failf(data, "File already completely uploaded\n");
|
failf(data, "File already completely uploaded\n");
|
||||||
return CURLE_PARTIAL_FILE;
|
return CURLE_PARTIAL_FILE;
|
||||||
}
|
}
|
||||||
@@ -551,16 +549,16 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
* or uploading and we always let customized headers override our internal
|
* or uploading and we always let customized headers override our internal
|
||||||
* ones if any such are specified.
|
* ones if any such are specified.
|
||||||
*/
|
*/
|
||||||
if((data->httpreq == HTTPREQ_GET) &&
|
if((data->set.httpreq == HTTPREQ_GET) &&
|
||||||
!checkheaders(data, "Range:")) {
|
!checkheaders(data, "Range:")) {
|
||||||
conn->allocptr.rangeline = aprintf("Range: bytes=%s\r\n", conn->range);
|
conn->allocptr.rangeline = aprintf("Range: bytes=%s\r\n", conn->range);
|
||||||
}
|
}
|
||||||
else if((data->httpreq != HTTPREQ_GET) &&
|
else if((data->set.httpreq != HTTPREQ_GET) &&
|
||||||
!checkheaders(data, "Content-Range:")) {
|
!checkheaders(data, "Content-Range:")) {
|
||||||
|
|
||||||
if(conn->resume_from) {
|
if(conn->resume_from) {
|
||||||
/* This is because "resume" was selected */
|
/* This is because "resume" was selected */
|
||||||
long total_expected_size= conn->resume_from + data->infilesize;
|
long total_expected_size= conn->resume_from + data->set.infilesize;
|
||||||
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s%ld/%ld\r\n",
|
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s%ld/%ld\r\n",
|
||||||
conn->range, total_expected_size-1,
|
conn->range, total_expected_size-1,
|
||||||
total_expected_size);
|
total_expected_size);
|
||||||
@@ -569,14 +567,18 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
/* Range was selected and then we just pass the incoming range and
|
/* Range was selected and then we just pass the incoming range and
|
||||||
append total size */
|
append total size */
|
||||||
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s/%d\r\n",
|
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s/%d\r\n",
|
||||||
conn->range, data->infilesize);
|
conn->range, data->set.infilesize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
/* Use 1.1 unless the use specificly asked for 1.0 */
|
||||||
|
const char *httpstring=
|
||||||
|
data->set.httpversion==CURL_HTTP_VERSION_1_0?"1.0":"1.1";
|
||||||
|
|
||||||
send_buffer *req_buffer;
|
send_buffer *req_buffer;
|
||||||
struct curl_slist *headers=data->headers;
|
struct curl_slist *headers=data->set.headers;
|
||||||
|
|
||||||
/* initialize a dynamic send-buffer */
|
/* initialize a dynamic send-buffer */
|
||||||
req_buffer = add_buffer_init();
|
req_buffer = add_buffer_init();
|
||||||
@@ -584,7 +586,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
/* add the main request stuff */
|
/* add the main request stuff */
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"%s " /* GET/HEAD/POST/PUT */
|
"%s " /* GET/HEAD/POST/PUT */
|
||||||
"%s HTTP/1.1\r\n" /* path */
|
"%s HTTP/%s\r\n" /* path */
|
||||||
"%s" /* proxyuserpwd */
|
"%s" /* proxyuserpwd */
|
||||||
"%s" /* userpwd */
|
"%s" /* userpwd */
|
||||||
"%s" /* range */
|
"%s" /* range */
|
||||||
@@ -595,24 +597,25 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
"%s" /* accept */
|
"%s" /* accept */
|
||||||
"%s", /* referer */
|
"%s", /* referer */
|
||||||
|
|
||||||
data->customrequest?data->customrequest:
|
data->set.customrequest?data->set.customrequest:
|
||||||
(data->bits.no_body?"HEAD":
|
(data->set.no_body?"HEAD":
|
||||||
(data->bits.http_post || data->bits.http_formpost)?"POST":
|
((HTTPREQ_POST == data->set.httpreq) ||
|
||||||
(data->bits.http_put)?"PUT":"GET"),
|
(HTTPREQ_POST_FORM == data->set.httpreq))?"POST":
|
||||||
ppath,
|
(HTTPREQ_PUT == data->set.httpreq)?"PUT":"GET"),
|
||||||
|
ppath, httpstring,
|
||||||
(conn->bits.proxy_user_passwd &&
|
(conn->bits.proxy_user_passwd &&
|
||||||
conn->allocptr.proxyuserpwd)?conn->allocptr.proxyuserpwd:"",
|
conn->allocptr.proxyuserpwd)?conn->allocptr.proxyuserpwd:"",
|
||||||
(conn->bits.user_passwd && conn->allocptr.userpwd)?
|
(conn->bits.user_passwd && conn->allocptr.userpwd)?
|
||||||
conn->allocptr.userpwd:"",
|
conn->allocptr.userpwd:"",
|
||||||
(conn->bits.use_range && conn->allocptr.rangeline)?
|
(conn->bits.use_range && conn->allocptr.rangeline)?
|
||||||
conn->allocptr.rangeline:"",
|
conn->allocptr.rangeline:"",
|
||||||
(data->useragent && *data->useragent && conn->allocptr.uagent)?
|
(data->set.useragent && *data->set.useragent && conn->allocptr.uagent)?
|
||||||
conn->allocptr.uagent:"",
|
conn->allocptr.uagent:"",
|
||||||
(conn->allocptr.cookie?conn->allocptr.cookie:""), /* Cookie: <data> */
|
(conn->allocptr.cookie?conn->allocptr.cookie:""), /* Cookie: <data> */
|
||||||
(conn->allocptr.host?conn->allocptr.host:""), /* Host: host */
|
(conn->allocptr.host?conn->allocptr.host:""), /* Host: host */
|
||||||
http->p_pragma?http->p_pragma:"",
|
http->p_pragma?http->p_pragma:"",
|
||||||
http->p_accept?http->p_accept:"",
|
http->p_accept?http->p_accept:"",
|
||||||
(data->bits.http_set_referer && conn->allocptr.ref)?conn->allocptr.ref:"" /* Referer: <data> <CRLF> */
|
(data->change.referer && conn->allocptr.ref)?conn->allocptr.ref:"" /* Referer: <data> <CRLF> */
|
||||||
);
|
);
|
||||||
|
|
||||||
if(co) {
|
if(co) {
|
||||||
@@ -637,7 +640,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
co=NULL;
|
co=NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->timecondition) {
|
if(data->set.timecondition) {
|
||||||
struct tm *thistime;
|
struct tm *thistime;
|
||||||
|
|
||||||
/* Phil Karn (Fri, 13 Apr 2001) pointed out that the If-Modified-Since
|
/* Phil Karn (Fri, 13 Apr 2001) pointed out that the If-Modified-Since
|
||||||
@@ -652,9 +655,9 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
/* We assume that the presense of localtime_r() proves the presense
|
/* We assume that the presense of localtime_r() proves the presense
|
||||||
of gmtime_r() which is a bit ugly but might work */
|
of gmtime_r() which is a bit ugly but might work */
|
||||||
struct tm keeptime;
|
struct tm keeptime;
|
||||||
thistime = (struct tm *)gmtime_r(&data->timevalue, &keeptime);
|
thistime = (struct tm *)gmtime_r(&data->set.timevalue, &keeptime);
|
||||||
#else
|
#else
|
||||||
thistime = gmtime(&data->timevalue);
|
thistime = gmtime(&data->set.timevalue);
|
||||||
#endif
|
#endif
|
||||||
if(NULL == thistime) {
|
if(NULL == thistime) {
|
||||||
failf(data, "localtime() failed!");
|
failf(data, "localtime() failed!");
|
||||||
@@ -668,7 +671,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
/* TODO: Right, we *could* write a replacement here */
|
/* TODO: Right, we *could* write a replacement here */
|
||||||
strcpy(buf, "no strftime() support");
|
strcpy(buf, "no strftime() support");
|
||||||
#endif
|
#endif
|
||||||
switch(data->timecondition) {
|
switch(data->set.timecondition) {
|
||||||
case TIMECOND_IFMODSINCE:
|
case TIMECOND_IFMODSINCE:
|
||||||
default:
|
default:
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
@@ -703,55 +706,86 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
headers = headers->next;
|
headers = headers->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->bits.http_formpost) {
|
if(HTTPREQ_POST_FORM == data->set.httpreq) {
|
||||||
|
char contentType[256];
|
||||||
|
int linelength=0;
|
||||||
if(Curl_FormInit(&http->form, http->sendit)) {
|
if(Curl_FormInit(&http->form, http->sendit)) {
|
||||||
failf(data, "Internal HTTP POST error!\n");
|
failf(data, "Internal HTTP POST error!\n");
|
||||||
return CURLE_HTTP_POST_ERROR;
|
return CURLE_HTTP_POST_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
http->storefread = data->fread; /* backup */
|
http->storefread = data->set.fread; /* backup */
|
||||||
http->in = data->in; /* backup */
|
http->in = data->set.in; /* backup */
|
||||||
|
|
||||||
data->fread = (curl_read_callback)
|
data->set.fread = (curl_read_callback)
|
||||||
Curl_FormReader; /* set the read function to read from the
|
Curl_FormReader; /* set the read function to read from the
|
||||||
generated form data */
|
generated form data */
|
||||||
data->in = (FILE *)&http->form;
|
data->set.in = (FILE *)&http->form;
|
||||||
|
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"Content-Length: %d\r\n", http->postsize-2);
|
"Content-Length: %d\r\n", http->postsize-2);
|
||||||
|
|
||||||
|
if(!checkheaders(data, "Expect:")) {
|
||||||
|
/* if not disabled explicitly we add a Expect: 100-continue
|
||||||
|
to the headers which actually speeds up post operations (as
|
||||||
|
there is one packet coming back from the web server) */
|
||||||
|
add_bufferf(req_buffer,
|
||||||
|
"Expect: 100-continue\r\n");
|
||||||
|
data->set.expect100header = TRUE;
|
||||||
|
|
||||||
|
/* Get Content-Type: line from Curl_FormReadOneLine, which happens
|
||||||
|
to always be the first line. We can know this for sure since
|
||||||
|
we always build the formpost linked list the same way! */
|
||||||
|
linelength = Curl_FormReadOneLine (contentType,
|
||||||
|
sizeof(contentType),
|
||||||
|
1,
|
||||||
|
(FILE *)&http->form);
|
||||||
|
if(linelength == -1) {
|
||||||
|
failf(data, "Could not get Content-Type header line!\n");
|
||||||
|
return CURLE_HTTP_POST_ERROR;
|
||||||
|
}
|
||||||
|
add_buffer(req_buffer, contentType, linelength);
|
||||||
|
}
|
||||||
|
|
||||||
/* set upload size to the progress meter */
|
/* set upload size to the progress meter */
|
||||||
Curl_pgrsSetUploadSize(data, http->postsize);
|
Curl_pgrsSetUploadSize(data, http->postsize);
|
||||||
|
|
||||||
data->request_size =
|
/* fire away the whole request to the server */
|
||||||
add_buffer_send(conn->firstsocket, conn, req_buffer);
|
result = add_buffer_send(conn->firstsocket, conn, req_buffer,
|
||||||
|
&data->info.request_size);
|
||||||
|
if(result)
|
||||||
|
failf(data, "Failed sending POST request");
|
||||||
|
else
|
||||||
|
/* setup variables for the upcoming transfer */
|
||||||
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE,
|
||||||
&http->readbytecount,
|
&http->readbytecount,
|
||||||
conn->firstsocket,
|
conn->firstsocket,
|
||||||
&http->writebytecount);
|
&http->writebytecount);
|
||||||
if(result) {
|
if(result) {
|
||||||
Curl_FormFree(http->sendit); /* free that whole lot */
|
Curl_formclean(http->sendit); /* free that whole lot */
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(data->bits.http_put) {
|
else if(HTTPREQ_PUT == data->set.httpreq) {
|
||||||
/* Let's PUT the data to the server! */
|
/* Let's PUT the data to the server! */
|
||||||
|
|
||||||
if(data->infilesize>0) {
|
if(data->set.infilesize>0) {
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"Content-Length: %d\r\n\r\n", /* file size */
|
"Content-Length: %d\r\n\r\n", /* file size */
|
||||||
data->infilesize );
|
data->set.infilesize );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
add_bufferf(req_buffer, "\015\012");
|
add_bufferf(req_buffer, "\015\012");
|
||||||
|
|
||||||
/* set the upload size to the progress meter */
|
/* set the upload size to the progress meter */
|
||||||
Curl_pgrsSetUploadSize(data, data->infilesize);
|
Curl_pgrsSetUploadSize(data, data->set.infilesize);
|
||||||
|
|
||||||
/* this sends the buffer and frees all the buffer resources */
|
/* this sends the buffer and frees all the buffer resources */
|
||||||
data->request_size =
|
result = add_buffer_send(conn->firstsocket, conn, req_buffer,
|
||||||
add_buffer_send(conn->firstsocket, conn, req_buffer);
|
&data->info.request_size);
|
||||||
|
if(result)
|
||||||
|
failf(data, "Faied sending POST request");
|
||||||
|
else
|
||||||
/* prepare for transfer */
|
/* prepare for transfer */
|
||||||
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE,
|
||||||
&http->readbytecount,
|
&http->readbytecount,
|
||||||
@@ -762,42 +796,56 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(data->bits.http_post) {
|
if(HTTPREQ_POST == data->set.httpreq) {
|
||||||
/* this is the simple POST, using x-www-form-urlencoded style */
|
/* this is the simple POST, using x-www-form-urlencoded style */
|
||||||
|
|
||||||
|
if(!data->set.postfields) {
|
||||||
|
/*
|
||||||
|
* This is an attempt to do a POST without having anything to
|
||||||
|
* actually send. Let's make a NULL pointer equal "" here. Good/bad
|
||||||
|
* ?
|
||||||
|
*/
|
||||||
|
data->set.postfields = (char *)"";
|
||||||
|
data->set.postfieldsize = 0; /* it might been set to something illegal,
|
||||||
|
anything > 0 would be! */
|
||||||
|
}
|
||||||
|
|
||||||
if(!checkheaders(data, "Content-Length:"))
|
if(!checkheaders(data, "Content-Length:"))
|
||||||
/* we allow replacing this header, although it isn't very wise to
|
/* we allow replacing this header, although it isn't very wise to
|
||||||
actually set your own */
|
actually set your own */
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"Content-Length: %d\r\n",
|
"Content-Length: %d\r\n",
|
||||||
(data->postfieldsize?data->postfieldsize:
|
(data->set.postfieldsize?data->set.postfieldsize:
|
||||||
strlen(data->postfields)) );
|
strlen(data->set.postfields)) );
|
||||||
|
|
||||||
if(!checkheaders(data, "Content-Type:"))
|
if(!checkheaders(data, "Content-Type:"))
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"Content-Type: application/x-www-form-urlencoded\r\n");
|
"Content-Type: application/x-www-form-urlencoded\r\n");
|
||||||
|
|
||||||
/* and here comes the actual data */
|
/* and here comes the actual data */
|
||||||
if(data->postfieldsize) {
|
if(data->set.postfieldsize) {
|
||||||
add_buffer(req_buffer, "\r\n", 2);
|
add_buffer(req_buffer, "\r\n", 2);
|
||||||
add_buffer(req_buffer, data->postfields,
|
add_buffer(req_buffer, data->set.postfields,
|
||||||
data->postfieldsize);
|
data->set.postfieldsize);
|
||||||
add_buffer(req_buffer, "\r\n", 2);
|
add_buffer(req_buffer, "\r\n", 2);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"\r\n"
|
"\r\n"
|
||||||
"%s\r\n",
|
"%s\r\n",
|
||||||
data->postfields );
|
data->set.postfields );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
add_buffer(req_buffer, "\r\n", 2);
|
add_buffer(req_buffer, "\r\n", 2);
|
||||||
|
|
||||||
/* issue the request */
|
/* issue the request */
|
||||||
data->request_size =
|
result = add_buffer_send(conn->firstsocket, conn, req_buffer,
|
||||||
add_buffer_send(conn->firstsocket, conn, req_buffer);
|
&data->info.request_size);
|
||||||
|
|
||||||
|
if(result)
|
||||||
|
failf(data, "Failed sending HTTP request");
|
||||||
|
else
|
||||||
/* HTTP GET/HEAD download: */
|
/* HTTP GET/HEAD download: */
|
||||||
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE, bytecount,
|
||||||
-1, NULL); /* nothing to upload */
|
-1, NULL); /* nothing to upload */
|
||||||
@@ -810,3 +858,11 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -33,7 +33,6 @@ CURLcode Curl_ConnectHTTPProxyTunnel(struct connectdata *conn,
|
|||||||
CURLcode Curl_http(struct connectdata *conn);
|
CURLcode Curl_http(struct connectdata *conn);
|
||||||
CURLcode Curl_http_done(struct connectdata *conn);
|
CURLcode Curl_http_done(struct connectdata *conn);
|
||||||
CURLcode Curl_http_connect(struct connectdata *conn);
|
CURLcode Curl_http_connect(struct connectdata *conn);
|
||||||
CURLcode Curl_http_close(struct connectdata *conn);
|
|
||||||
|
|
||||||
/* The following functions are defined in http_chunks.c */
|
/* The following functions are defined in http_chunks.c */
|
||||||
void Curl_httpchunk_init(struct connectdata *conn);
|
void Curl_httpchunk_init(struct connectdata *conn);
|
||||||
|
@@ -44,7 +44,7 @@
|
|||||||
* Chunk format (simplified):
|
* Chunk format (simplified):
|
||||||
*
|
*
|
||||||
* <HEX SIZE>[ chunk extension ] CRLF
|
* <HEX SIZE>[ chunk extension ] CRLF
|
||||||
* <DATA>
|
* <DATA> CRLF
|
||||||
*
|
*
|
||||||
* Highlights from RFC2616 section 3.6 say:
|
* Highlights from RFC2616 section 3.6 say:
|
||||||
|
|
||||||
@@ -96,8 +96,8 @@ void Curl_httpchunk_init(struct connectdata *conn)
|
|||||||
*/
|
*/
|
||||||
CHUNKcode Curl_httpchunk_read(struct connectdata *conn,
|
CHUNKcode Curl_httpchunk_read(struct connectdata *conn,
|
||||||
char *datap,
|
char *datap,
|
||||||
ssize_t length,
|
size_t length,
|
||||||
ssize_t *wrote)
|
size_t *wrote)
|
||||||
{
|
{
|
||||||
CURLcode result;
|
CURLcode result;
|
||||||
struct Curl_chunker *ch = &conn->proto.http->chunk;
|
struct Curl_chunker *ch = &conn->proto.http->chunk;
|
||||||
@@ -220,3 +220,11 @@ CHUNKcode Curl_httpchunk_read(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
return CHUNKE_OK;
|
return CHUNKE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
17
lib/if2ip.c
17
lib/if2ip.c
@@ -66,6 +66,11 @@
|
|||||||
#include "inet_ntoa_r.h"
|
#include "inet_ntoa_r.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef VMS
|
||||||
|
#define IOCTL_3_ARGS
|
||||||
|
#include <inet.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
@@ -90,7 +95,11 @@ char *Curl_if2ip(char *interface, char *buf, int buf_size)
|
|||||||
memset(&req, 0, sizeof(req));
|
memset(&req, 0, sizeof(req));
|
||||||
strcpy(req.ifr_name, interface);
|
strcpy(req.ifr_name, interface);
|
||||||
req.ifr_addr.sa_family = AF_INET;
|
req.ifr_addr.sa_family = AF_INET;
|
||||||
|
#ifdef IOCTL_3_ARGS
|
||||||
|
if (SYS_ERROR == ioctl(dummy, SIOCGIFADDR, &req)) {
|
||||||
|
#else
|
||||||
if (SYS_ERROR == ioctl(dummy, SIOCGIFADDR, &req, sizeof(req))) {
|
if (SYS_ERROR == ioctl(dummy, SIOCGIFADDR, &req, sizeof(req))) {
|
||||||
|
#endif
|
||||||
sclose(dummy);
|
sclose(dummy);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@@ -115,3 +124,11 @@ char *Curl_if2ip(char *interface, char *buf, int buf_size)
|
|||||||
#else
|
#else
|
||||||
#define if2ip(x) NULL
|
#define if2ip(x) NULL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
244
lib/krb4.c
244
lib/krb4.c
@@ -1,8 +1,12 @@
|
|||||||
/* modified by Martin Hedenfalk <mhe@stacken.kth.se> for use in Curl
|
/* This source code was modified by Martin Hedenfalk <mhe@stacken.kth.se> for
|
||||||
* last modified 2000-09-18
|
* use in Curl. His latest changes were done 2000-09-18.
|
||||||
*/
|
*
|
||||||
|
* It has since been patched away like a madman by Daniel Stenberg
|
||||||
/*
|
* <daniel@haxx.se> to make it better applied to curl conditions, and to make
|
||||||
|
* it not use globals, pollute name space and more. This source code awaits a
|
||||||
|
* rewrite to work around the paragraph 2 in the BSD licenses as explained
|
||||||
|
* below.
|
||||||
|
*
|
||||||
* Copyright (c) 1995, 1996, 1997, 1998, 1999 Kungliga Tekniska H<>gskolan
|
* Copyright (c) 1995, 1996, 1997, 1998, 1999 Kungliga Tekniska H<>gskolan
|
||||||
* (Royal Institute of Technology, Stockholm, Sweden).
|
* (Royal Institute of Technology, Stockholm, Sweden).
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
@@ -32,8 +36,7 @@
|
|||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
* 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
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE. */
|
||||||
*/
|
|
||||||
|
|
||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
|
|
||||||
@@ -47,6 +50,10 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <krb.h>
|
#include <krb.h>
|
||||||
|
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
#include <unistd.h> /* for getpid() */
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "ftp.h"
|
#include "ftp.h"
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
|
|
||||||
@@ -55,23 +62,11 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef FTP_SERVER
|
#define LOCAL_ADDR (&conn->local_addr)
|
||||||
#define LOCAL_ADDR ctrl_addr
|
|
||||||
#define REMOTE_ADDR his_addr
|
|
||||||
#else
|
|
||||||
/*#define LOCAL_ADDR myctladdr***/
|
|
||||||
/*#define REMOTE_ADDR hisctladdr***/
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*extern struct sockaddr *LOCAL_ADDR, *REMOTE_ADDR;***/
|
|
||||||
|
|
||||||
#define LOCAL_ADDR (&local_addr)
|
|
||||||
#define REMOTE_ADDR (&conn->serv_addr)
|
#define REMOTE_ADDR (&conn->serv_addr)
|
||||||
#define myctladdr LOCAL_ADDR
|
#define myctladdr LOCAL_ADDR
|
||||||
#define hisctladdr REMOTE_ADDR
|
#define hisctladdr REMOTE_ADDR
|
||||||
|
|
||||||
static struct sockaddr_in local_addr;
|
|
||||||
|
|
||||||
struct krb4_data {
|
struct krb4_data {
|
||||||
des_cblock key;
|
des_cblock key;
|
||||||
des_key_schedule schedule;
|
des_key_schedule schedule;
|
||||||
@@ -105,6 +100,7 @@ size_t strlcpy (char *dst, const char *src, size_t dst_sz);
|
|||||||
static int
|
static int
|
||||||
krb4_check_prot(void *app_data, int level)
|
krb4_check_prot(void *app_data, int level)
|
||||||
{
|
{
|
||||||
|
app_data = NULL; /* prevent compiler warning */
|
||||||
if(level == prot_confidential)
|
if(level == prot_confidential)
|
||||||
return -1;
|
return -1;
|
||||||
return 0;
|
return 0;
|
||||||
@@ -137,6 +133,10 @@ krb4_decode(void *app_data, void *buf, int len, int level,
|
|||||||
static int
|
static int
|
||||||
krb4_overhead(void *app_data, int level, int len)
|
krb4_overhead(void *app_data, int level, int len)
|
||||||
{
|
{
|
||||||
|
/* no arguments are used, just init them to prevent compiler warnings */
|
||||||
|
app_data = NULL;
|
||||||
|
level = 0;
|
||||||
|
len = 0;
|
||||||
return 31;
|
return 31;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -158,98 +158,9 @@ krb4_encode(void *app_data, void *from, int length, int level, void **to,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef FTP_SERVER
|
|
||||||
|
|
||||||
static int
|
|
||||||
krb4_adat(void *app_data, void *buf, size_t len)
|
|
||||||
{
|
|
||||||
KTEXT_ST tkt;
|
|
||||||
AUTH_DAT auth_dat;
|
|
||||||
char *p;
|
|
||||||
int kerror;
|
|
||||||
u_int32_t cs;
|
|
||||||
char msg[35]; /* size of encrypted block */
|
|
||||||
int tmp_len;
|
|
||||||
struct krb4_data *d = app_data;
|
|
||||||
char inst[INST_SZ];
|
|
||||||
struct sockaddr_in *his_addr_sin = (struct sockaddr_in *)his_addr;
|
|
||||||
|
|
||||||
memcpy(tkt.dat, buf, len);
|
|
||||||
tkt.length = len;
|
|
||||||
|
|
||||||
k_getsockinst(0, inst, sizeof(inst));
|
|
||||||
kerror = krb_rd_req(&tkt, "ftp", inst,
|
|
||||||
his_addr_sin->sin_addr.s_addr, &auth_dat, "");
|
|
||||||
if(kerror == RD_AP_UNDEC){
|
|
||||||
k_getsockinst(0, inst, sizeof(inst));
|
|
||||||
kerror = krb_rd_req(&tkt, "rcmd", inst,
|
|
||||||
his_addr_sin->sin_addr.s_addr, &auth_dat, "");
|
|
||||||
}
|
|
||||||
|
|
||||||
if(kerror){
|
|
||||||
reply(535, "Error reading request: %s.", krb_get_err_text(kerror));
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
memcpy(d->key, auth_dat.session, sizeof(d->key));
|
|
||||||
des_set_key(&d->key, d->schedule);
|
|
||||||
|
|
||||||
strlcpy(d->name, auth_dat.pname, sizeof(d->name));
|
|
||||||
strlcpy(d->instance, auth_dat.pinst, sizeof(d->instance));
|
|
||||||
strlcpy(d->realm, auth_dat.prealm, sizeof(d->instance));
|
|
||||||
|
|
||||||
cs = auth_dat.checksum + 1;
|
|
||||||
{
|
|
||||||
unsigned char tmp[4];
|
|
||||||
KRB_PUT_INT(cs, tmp, 4, sizeof(tmp));
|
|
||||||
tmp_len = krb_mk_safe(tmp, msg, 4, &d->key,
|
|
||||||
(struct sockaddr_in *)LOCAL_ADDR,
|
|
||||||
(struct sockaddr_in *)REMOTE_ADDR);
|
|
||||||
}
|
|
||||||
if(tmp_len < 0){
|
|
||||||
reply(535, "Error creating reply: %s.", strerror(errno));
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
len = tmp_len;
|
|
||||||
if(base64_encode(msg, len, &p) < 0) {
|
|
||||||
reply(535, "Out of memory base64-encoding.");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
reply(235, "ADAT=%s", p);
|
|
||||||
sec_complete = 1;
|
|
||||||
free(p);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
krb4_userok(void *app_data, char *user)
|
|
||||||
{
|
|
||||||
struct krb4_data *d = app_data;
|
|
||||||
return krb_kuserok(d->name, d->instance, d->realm, user);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct sec_server_mech krb4_server_mech = {
|
|
||||||
"KERBEROS_V4",
|
|
||||||
sizeof(struct krb4_data),
|
|
||||||
NULL, /* init */
|
|
||||||
NULL, /* end */
|
|
||||||
krb4_check_prot,
|
|
||||||
krb4_overhead,
|
|
||||||
krb4_encode,
|
|
||||||
krb4_decode,
|
|
||||||
/* */
|
|
||||||
NULL,
|
|
||||||
krb4_adat,
|
|
||||||
NULL, /* pbsz */
|
|
||||||
NULL, /* ccc */
|
|
||||||
krb4_userok
|
|
||||||
};
|
|
||||||
|
|
||||||
#else /* FTP_SERVER */
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
mk_auth(struct krb4_data *d, KTEXT adat,
|
mk_auth(struct krb4_data *d, KTEXT adat,
|
||||||
char *service, char *host, int checksum)
|
const char *service, char *host, int checksum)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
CREDENTIALS cred;
|
CREDENTIALS cred;
|
||||||
@@ -283,12 +194,9 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
u_int32_t cs;
|
u_int32_t cs;
|
||||||
struct krb4_data *d = app_data;
|
struct krb4_data *d = app_data;
|
||||||
struct sockaddr_in *localaddr = (struct sockaddr_in *)LOCAL_ADDR;
|
struct sockaddr_in *localaddr = (struct sockaddr_in *)LOCAL_ADDR;
|
||||||
#if 0
|
char *host = conn->hostaddr->h_name;
|
||||||
struct sockaddr_in *remoteaddr = (struct sockaddr_in *)REMOTE_ADDR;
|
ssize_t nread;
|
||||||
#endif
|
int l = sizeof(conn->local_addr);
|
||||||
char *host = conn->hp->h_name;
|
|
||||||
size_t nread;
|
|
||||||
int l = sizeof(local_addr);
|
|
||||||
|
|
||||||
if(getsockname(conn->firstsocket,
|
if(getsockname(conn->firstsocket,
|
||||||
(struct sockaddr *)LOCAL_ADDR, &l) < 0)
|
(struct sockaddr *)LOCAL_ADDR, &l) < 0)
|
||||||
@@ -298,7 +206,7 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
ret = mk_auth(d, &adat, "ftp", host, checksum);
|
ret = mk_auth(d, &adat, "ftp", host, checksum);
|
||||||
if(ret == KDC_PR_UNKNOWN)
|
if(ret == KDC_PR_UNKNOWN)
|
||||||
ret = mk_auth(d, &adat, "rcmd", host, checksum);
|
ret = mk_auth(d, &adat, "rcmd", host, checksum);
|
||||||
if(ret){
|
if(ret) {
|
||||||
printf("%s\n", krb_get_err_text(ret));
|
printf("%s\n", krb_get_err_text(ret));
|
||||||
return AUTH_CONTINUE;
|
return AUTH_CONTINUE;
|
||||||
}
|
}
|
||||||
@@ -319,10 +227,8 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
localaddr->sin_addr = natAddr;
|
localaddr->sin_addr = natAddr;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This not the best place to do this, but it
|
* This not the best place to do this, but it is here we know that
|
||||||
* is here we know that (probably) NAT is in
|
* (probably) NAT is in use! */
|
||||||
* use!
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*passivemode = 1;***/
|
/*passivemode = 1;***/
|
||||||
/*printf("Setting: Passive mode on.\n");***/
|
/*printf("Setting: Passive mode on.\n");***/
|
||||||
@@ -338,21 +244,21 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
printf("Out of memory base64-encoding.\n");
|
printf("Out of memory base64-encoding.\n");
|
||||||
return AUTH_CONTINUE;
|
return AUTH_CONTINUE;
|
||||||
}
|
}
|
||||||
/*ret = command("ADAT %s", p)*/
|
|
||||||
Curl_ftpsendf(conn->firstsocket, conn, "ADAT %s", p);
|
if(Curl_ftpsendf(conn, "ADAT %s", p))
|
||||||
/* wait for feedback */
|
return -2;
|
||||||
nread = Curl_GetFTPResponse(conn->firstsocket,
|
|
||||||
conn->data->buffer, conn, NULL);
|
nread = Curl_GetFTPResponse(conn->data->state.buffer, conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
return -1;
|
||||||
free(p);
|
free(p);
|
||||||
|
|
||||||
if(/*ret != COMPLETE*/conn->data->buffer[0] != '2'){
|
if(/*ret != COMPLETE*/conn->data->state.buffer[0] != '2'){
|
||||||
printf("Server didn't accept auth data.\n");
|
printf("Server didn't accept auth data.\n");
|
||||||
return AUTH_ERROR;
|
return AUTH_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
p = strstr(/*reply_string*/conn->data->buffer, "ADAT=");
|
p = strstr(conn->data->state.buffer, "ADAT=");
|
||||||
if(!p){
|
if(!p){
|
||||||
printf("Remote host didn't send adat reply.\n");
|
printf("Remote host didn't send adat reply.\n");
|
||||||
return AUTH_ERROR;
|
return AUTH_ERROR;
|
||||||
@@ -380,7 +286,7 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
return AUTH_OK;
|
return AUTH_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct sec_client_mech krb4_client_mech = {
|
struct Curl_sec_client_mech Curl_krb4_client_mech = {
|
||||||
"KERBEROS_V4",
|
"KERBEROS_V4",
|
||||||
sizeof(struct krb4_data),
|
sizeof(struct krb4_data),
|
||||||
NULL, /* init */
|
NULL, /* init */
|
||||||
@@ -392,9 +298,7 @@ struct sec_client_mech krb4_client_mech = {
|
|||||||
krb4_decode
|
krb4_decode
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* FTP_SERVER */
|
void Curl_krb_kauth(struct connectdata *conn)
|
||||||
|
|
||||||
void krb_kauth(struct connectdata *conn)
|
|
||||||
{
|
{
|
||||||
des_cblock key;
|
des_cblock key;
|
||||||
des_key_schedule schedule;
|
des_key_schedule schedule;
|
||||||
@@ -403,63 +307,54 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
char *p;
|
char *p;
|
||||||
char passwd[100];
|
char passwd[100];
|
||||||
int tmp;
|
int tmp;
|
||||||
size_t nread;
|
ssize_t nread;
|
||||||
|
|
||||||
int save;
|
int save;
|
||||||
|
|
||||||
save = set_command_prot(conn, prot_private);
|
save = Curl_set_command_prot(conn, prot_private);
|
||||||
/*ret = command("SITE KAUTH %s", name);***/
|
|
||||||
Curl_ftpsendf(conn->firstsocket, conn,
|
if(Curl_ftpsendf(conn, "SITE KAUTH %s", conn->data->state.user))
|
||||||
"SITE KAUTH %s", conn->data->user);
|
return;
|
||||||
/* wait for feedback */
|
|
||||||
nread = Curl_GetFTPResponse(conn->firstsocket, conn->data->buffer,
|
nread = Curl_GetFTPResponse(conn->data->state.buffer,
|
||||||
conn, NULL);
|
conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/;
|
return /*CURLE_OPERATION_TIMEOUTED*/;
|
||||||
|
|
||||||
if(/*ret != CONTINUE*/conn->data->buffer[0] != '3'){
|
if(/*ret != CONTINUE*/conn->data->state.buffer[0] != '3'){
|
||||||
set_command_prot(conn, save);
|
Curl_set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
/*code = -1;***/
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
p = strstr(/*reply_string***/conn->data->buffer, "T=");
|
|
||||||
if(!p){
|
p = strstr(conn->data->state.buffer, "T=");
|
||||||
|
if(!p) {
|
||||||
printf("Bad reply from server.\n");
|
printf("Bad reply from server.\n");
|
||||||
set_command_prot(conn, save);
|
Curl_set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
p += 2;
|
p += 2;
|
||||||
tmp = Curl_base64_decode(p, &tkt.dat);
|
tmp = Curl_base64_decode(p, &tkt.dat);
|
||||||
if(tmp < 0){
|
if(tmp < 0) {
|
||||||
printf("Failed to decode base64 in reply.\n");
|
printf("Failed to decode base64 in reply.\n");
|
||||||
set_command_prot(conn, save);
|
Curl_set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
tkt.length = tmp;
|
tkt.length = tmp;
|
||||||
tktcopy.length = tkt.length;
|
tktcopy.length = tkt.length;
|
||||||
|
|
||||||
p = strstr(/*reply_string***/conn->data->buffer, "P=");
|
p = strstr(conn->data->state.buffer, "P=");
|
||||||
if(!p){
|
if(!p) {
|
||||||
printf("Bad reply from server.\n");
|
printf("Bad reply from server.\n");
|
||||||
set_command_prot(conn, save);
|
Curl_set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
name = p + 2;
|
name = p + 2;
|
||||||
for(; *p && *p != ' ' && *p != '\r' && *p != '\n'; p++);
|
for(; *p && *p != ' ' && *p != '\r' && *p != '\n'; p++);
|
||||||
*p = 0;
|
*p = 0;
|
||||||
|
|
||||||
#if 0
|
des_string_to_key (conn->data->state.passwd, &key);
|
||||||
snprintf(buf, sizeof(buf), "Password for %s:", name);
|
|
||||||
if (des_read_pw_string (passwd, sizeof(passwd)-1, buf, 0))
|
|
||||||
*passwd = '\0';
|
|
||||||
des_string_to_key (passwd, &key);
|
|
||||||
#else
|
|
||||||
des_string_to_key (conn->data->passwd, &key);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
des_key_sched(&key, schedule);
|
des_key_sched(&key, schedule);
|
||||||
|
|
||||||
des_pcbc_encrypt((des_cblock*)tkt.dat, (des_cblock*)tktcopy.dat,
|
des_pcbc_encrypt((des_cblock*)tkt.dat, (des_cblock*)tktcopy.dat,
|
||||||
@@ -468,7 +363,7 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
if (strcmp ((char*)tktcopy.dat + 8,
|
if (strcmp ((char*)tktcopy.dat + 8,
|
||||||
KRB_TICKET_GRANTING_TICKET) != 0) {
|
KRB_TICKET_GRANTING_TICKET) != 0) {
|
||||||
afs_string_to_key (passwd,
|
afs_string_to_key (passwd,
|
||||||
krb_realmofhost(/*hostname***/conn->hp->h_name),
|
krb_realmofhost(conn->hostaddr->h_name),
|
||||||
&key);
|
&key);
|
||||||
des_key_sched (&key, schedule);
|
des_key_sched (&key, schedule);
|
||||||
des_pcbc_encrypt((des_cblock*)tkt.dat, (des_cblock*)tktcopy.dat,
|
des_pcbc_encrypt((des_cblock*)tkt.dat, (des_cblock*)tktcopy.dat,
|
||||||
@@ -480,21 +375,28 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
memset(passwd, 0, sizeof(passwd));
|
memset(passwd, 0, sizeof(passwd));
|
||||||
if(Curl_base64_encode(tktcopy.dat, tktcopy.length, &p) < 0) {
|
if(Curl_base64_encode(tktcopy.dat, tktcopy.length, &p) < 0) {
|
||||||
failf(conn->data, "Out of memory base64-encoding.\n");
|
failf(conn->data, "Out of memory base64-encoding.\n");
|
||||||
set_command_prot(conn, save);
|
Curl_set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
memset (tktcopy.dat, 0, tktcopy.length);
|
memset (tktcopy.dat, 0, tktcopy.length);
|
||||||
/*ret = command("SITE KAUTH %s %s", name, p);***/
|
|
||||||
Curl_ftpsendf(conn->firstsocket, conn,
|
if(Curl_ftpsendf(conn, "SITE KAUTH %s %s", name, p))
|
||||||
"SITE KAUTH %s %s", name, p);
|
return;
|
||||||
/* wait for feedback */
|
|
||||||
nread = Curl_GetFTPResponse(conn->firstsocket, conn->data->buffer,
|
nread = Curl_GetFTPResponse(conn->data->state.buffer,
|
||||||
conn, NULL);
|
conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/;
|
return /*CURLE_OPERATION_TIMEOUTED*/;
|
||||||
free(p);
|
free(p);
|
||||||
set_command_prot(conn, save);
|
Curl_set_command_prot(conn, save);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* KRB4 */
|
#endif /* KRB4 */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -22,6 +22,6 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
void krb_kauth(struct connectdata *conn);
|
void Curl_krb_kauth(struct connectdata *conn);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
38
lib/ldap.c
38
lib/ldap.c
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* In order to be useful for every potential user, curl and libcurl are
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
@@ -47,6 +47,7 @@
|
|||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
|
#include "transfer.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
@@ -101,7 +102,7 @@ static void DynaClose(void)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void * DynaGetFunction(char *name)
|
static void * DynaGetFunction(const char *name)
|
||||||
{
|
{
|
||||||
void *func = NULL;
|
void *func = NULL;
|
||||||
|
|
||||||
@@ -116,16 +117,12 @@ static void * DynaGetFunction(char *name)
|
|||||||
|
|
||||||
static int WriteProc(void *param, char *text, int len)
|
static int WriteProc(void *param, char *text, int len)
|
||||||
{
|
{
|
||||||
struct UrlData *data = (struct UrlData *)param;
|
struct SessionHandle *data = (struct SessionHandle *)param;
|
||||||
|
len = 0; /* prevent compiler warning */
|
||||||
Curl_client_write(data, CLIENTWRITE_BODY, text, 0);
|
Curl_client_write(data, CLIENTWRITE_BODY, text, 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode Curl_ldap_done(struct connectdata *conn)
|
|
||||||
{
|
|
||||||
return CURLE_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
/***********************************************************************
|
/***********************************************************************
|
||||||
*/
|
*/
|
||||||
CURLcode Curl_ldap(struct connectdata *conn)
|
CURLcode Curl_ldap(struct connectdata *conn)
|
||||||
@@ -146,9 +143,9 @@ CURLcode Curl_ldap(struct connectdata *conn)
|
|||||||
void *entryIterator;
|
void *entryIterator;
|
||||||
|
|
||||||
int ldaptext;
|
int ldaptext;
|
||||||
struct UrlData *data=conn->data;
|
struct SessionHandle *data=conn->data;
|
||||||
|
|
||||||
infof(data, "LDAP: %s %s\n", data->url);
|
infof(data, "LDAP: %s %s\n", data->change.url);
|
||||||
|
|
||||||
DynaOpen();
|
DynaOpen();
|
||||||
if (libldap == NULL) {
|
if (libldap == NULL) {
|
||||||
@@ -156,7 +153,7 @@ CURLcode Curl_ldap(struct connectdata *conn)
|
|||||||
return CURLE_LIBRARY_NOT_FOUND;
|
return CURLE_LIBRARY_NOT_FOUND;
|
||||||
}
|
}
|
||||||
|
|
||||||
ldaptext = data->bits.ftp_ascii; /* This is a dirty hack */
|
ldaptext = data->set.ftp_ascii; /* This is a dirty hack */
|
||||||
|
|
||||||
/* The types are needed because ANSI C distinguishes between
|
/* The types are needed because ANSI C distinguishes between
|
||||||
* pointer-to-object (data) and pointer-to-function.
|
* pointer-to-object (data) and pointer-to-function.
|
||||||
@@ -177,12 +174,12 @@ CURLcode Curl_ldap(struct connectdata *conn)
|
|||||||
conn->hostname, conn->port);
|
conn->hostname, conn->port);
|
||||||
status = CURLE_COULDNT_CONNECT;
|
status = CURLE_COULDNT_CONNECT;
|
||||||
} else {
|
} else {
|
||||||
rc = ldap_simple_bind_s(server, data->user, data->passwd);
|
rc = ldap_simple_bind_s(server, data->state.user, data->state.passwd);
|
||||||
if (rc != 0) {
|
if (rc != 0) {
|
||||||
failf(data, "LDAP: %s", ldap_err2string(rc));
|
failf(data, "LDAP: %s", ldap_err2string(rc));
|
||||||
status = CURLE_LDAP_CANNOT_BIND;
|
status = CURLE_LDAP_CANNOT_BIND;
|
||||||
} else {
|
} else {
|
||||||
rc = ldap_url_search_s(server, data->url, 0, &result);
|
rc = ldap_url_search_s(server, data->change.url, 0, &result);
|
||||||
if (rc != 0) {
|
if (rc != 0) {
|
||||||
failf(data, "LDAP: %s", ldap_err2string(rc));
|
failf(data, "LDAP: %s", ldap_err2string(rc));
|
||||||
status = CURLE_LDAP_SEARCH_FAILED;
|
status = CURLE_LDAP_SEARCH_FAILED;
|
||||||
@@ -194,7 +191,7 @@ CURLcode Curl_ldap(struct connectdata *conn)
|
|||||||
if (ldaptext) {
|
if (ldaptext) {
|
||||||
rc = ldap_entry2text(server, NULL, entryIterator, NULL,
|
rc = ldap_entry2text(server, NULL, entryIterator, NULL,
|
||||||
NULL, NULL, WriteProc, data,
|
NULL, NULL, WriteProc, data,
|
||||||
"", 0, 0);
|
(char *)"", 0, 0);
|
||||||
if (rc != 0) {
|
if (rc != 0) {
|
||||||
failf(data, "LDAP: %s", ldap_err2string(rc));
|
failf(data, "LDAP: %s", ldap_err2string(rc));
|
||||||
status = CURLE_LDAP_SEARCH_FAILED;
|
status = CURLE_LDAP_SEARCH_FAILED;
|
||||||
@@ -202,7 +199,7 @@ CURLcode Curl_ldap(struct connectdata *conn)
|
|||||||
} else {
|
} else {
|
||||||
rc = ldap_entry2html(server, NULL, entryIterator, NULL,
|
rc = ldap_entry2html(server, NULL, entryIterator, NULL,
|
||||||
NULL, NULL, WriteProc, data,
|
NULL, NULL, WriteProc, data,
|
||||||
"", 0, 0, NULL, NULL);
|
(char *)"", 0, 0, NULL, NULL);
|
||||||
if (rc != 0) {
|
if (rc != 0) {
|
||||||
failf(data, "LDAP: %s", ldap_err2string(rc));
|
failf(data, "LDAP: %s", ldap_err2string(rc));
|
||||||
status = CURLE_LDAP_SEARCH_FAILED;
|
status = CURLE_LDAP_SEARCH_FAILED;
|
||||||
@@ -215,5 +212,16 @@ CURLcode Curl_ldap(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
DynaClose();
|
DynaClose();
|
||||||
|
|
||||||
|
/* no data to transfer */
|
||||||
|
Curl_Transfer(conn, -1, -1, FALSE, NULL, -1, NULL);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -22,14 +22,15 @@ EXPORTS
|
|||||||
curl_global_init @ 13 ;
|
curl_global_init @ 13 ;
|
||||||
curl_slist_append @ 14 ;
|
curl_slist_append @ 14 ;
|
||||||
curl_slist_free_all @ 15 ;
|
curl_slist_free_all @ 15 ;
|
||||||
curl_unescape @ 16 ;
|
curl_version @ 16 ;
|
||||||
curl_version @ 17 ;
|
curl_maprintf @ 17 ;
|
||||||
curl_maprintf @ 18 ;
|
curl_mfprintf @ 18 ;
|
||||||
curl_mfprintf @ 19 ;
|
curl_mprintf @ 19 ;
|
||||||
curl_mprintf @ 20 ;
|
curl_msprintf @ 20 ;
|
||||||
curl_msprintf @ 21 ;
|
curl_msnprintf @ 21 ;
|
||||||
curl_msnprintf @ 22 ;
|
curl_mvfprintf @ 22 ;
|
||||||
curl_mvfprintf @ 23 ;
|
curl_strequal @ 23 ;
|
||||||
curl_strequal @ 24 ;
|
curl_strnequal @ 24 ;
|
||||||
curl_strnequal @ 25 ;
|
curl_easy_duphandle @ 25 ;
|
||||||
|
curl_formadd @ 26 ;
|
||||||
|
|
||||||
|
@@ -58,21 +58,25 @@
|
|||||||
FILE *logfile;
|
FILE *logfile;
|
||||||
|
|
||||||
/* this sets the log file name */
|
/* this sets the log file name */
|
||||||
void curl_memdebug(char *logname)
|
void curl_memdebug(const char *logname)
|
||||||
{
|
{
|
||||||
|
if(logname)
|
||||||
logfile = fopen(logname, "w");
|
logfile = fopen(logname, "w");
|
||||||
|
else
|
||||||
|
logfile = stderr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void *curl_domalloc(size_t size, int line, char *source)
|
void *curl_domalloc(size_t size, int line, const char *source)
|
||||||
{
|
{
|
||||||
void *mem=(malloc)(size);
|
void *mem=(malloc)(size);
|
||||||
fprintf(logfile?logfile:stderr, "MEM %s:%d malloc(%d) = %p\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "MEM %s:%d malloc(%d) = %p\n",
|
||||||
source, line, size, mem);
|
source, line, size, mem);
|
||||||
return mem;
|
return mem;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *curl_dostrdup(const char *str, int line, char *source)
|
char *curl_dostrdup(const char *str, int line, const char *source)
|
||||||
{
|
{
|
||||||
char *mem;
|
char *mem;
|
||||||
size_t len;
|
size_t len;
|
||||||
@@ -85,20 +89,22 @@ char *curl_dostrdup(const char *str, int line, char *source)
|
|||||||
|
|
||||||
mem=(strdup)(str);
|
mem=(strdup)(str);
|
||||||
len=strlen(str)+1;
|
len=strlen(str)+1;
|
||||||
fprintf(logfile?logfile:stderr, "MEM %s:%d strdup(%p) (%d) = %p\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "MEM %s:%d strdup(%p) (%d) = %p\n",
|
||||||
source, line, str, len, mem);
|
source, line, str, len, mem);
|
||||||
return mem;
|
return mem;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *curl_dorealloc(void *ptr, size_t size, int line, char *source)
|
void *curl_dorealloc(void *ptr, size_t size, int line, const char *source)
|
||||||
{
|
{
|
||||||
void *mem=(realloc)(ptr, size);
|
void *mem=(realloc)(ptr, size);
|
||||||
fprintf(logfile?logfile:stderr, "MEM %s:%d realloc(%p, %d) = %p\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "MEM %s:%d realloc(%p, %d) = %p\n",
|
||||||
source, line, ptr, size, mem);
|
source, line, ptr, size, mem);
|
||||||
return mem;
|
return mem;
|
||||||
}
|
}
|
||||||
|
|
||||||
void curl_dofree(void *ptr, int line, char *source)
|
void curl_dofree(void *ptr, int line, const char *source)
|
||||||
{
|
{
|
||||||
if(NULL == ptr) {
|
if(NULL == ptr) {
|
||||||
fprintf(stderr, "ILLEGAL free() on NULL at %s:%d\n",
|
fprintf(stderr, "ILLEGAL free() on NULL at %s:%d\n",
|
||||||
@@ -108,23 +114,25 @@ void curl_dofree(void *ptr, int line, char *source)
|
|||||||
|
|
||||||
(free)(ptr);
|
(free)(ptr);
|
||||||
|
|
||||||
fprintf(logfile?logfile:stderr, "MEM %s:%d free(%p)\n",
|
if(logfile)
|
||||||
source, line, ptr);
|
fprintf(logfile, "MEM %s:%d free(%p)\n", source, line, ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
int curl_socket(int domain, int type, int protocol, int line, char *source)
|
int curl_socket(int domain, int type, int protocol, int line, char *source)
|
||||||
{
|
{
|
||||||
int sockfd=(socket)(domain, type, protocol);
|
int sockfd=(socket)(domain, type, protocol);
|
||||||
fprintf(logfile?logfile:stderr, "FD %s:%d socket() = %d\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "FD %s:%d socket() = %d\n",
|
||||||
source, line, sockfd);
|
source, line, sockfd);
|
||||||
return sockfd;
|
return sockfd;
|
||||||
}
|
}
|
||||||
|
|
||||||
int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
||||||
int line, char *source)
|
int line, const char *source)
|
||||||
{
|
{
|
||||||
int sockfd=(accept)(s, addr, addrlen);
|
int sockfd=(accept)(s, addr, addrlen);
|
||||||
fprintf(logfile?logfile:stderr, "FD %s:%d accept() = %d\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "FD %s:%d accept() = %d\n",
|
||||||
source, line, sockfd);
|
source, line, sockfd);
|
||||||
return sockfd;
|
return sockfd;
|
||||||
}
|
}
|
||||||
@@ -133,25 +141,37 @@ int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
|||||||
int curl_sclose(int sockfd, int line, char *source)
|
int curl_sclose(int sockfd, int line, char *source)
|
||||||
{
|
{
|
||||||
int res=sclose(sockfd);
|
int res=sclose(sockfd);
|
||||||
fprintf(logfile?logfile:stderr, "FD %s:%d sclose(%d)\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "FD %s:%d sclose(%d)\n",
|
||||||
source, line, sockfd);
|
source, line, sockfd);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
FILE *curl_fopen(char *file, char *mode, int line, char *source)
|
FILE *curl_fopen(const char *file, const char *mode,
|
||||||
|
int line, const char *source)
|
||||||
{
|
{
|
||||||
FILE *res=(fopen)(file, mode);
|
FILE *res=(fopen)(file, mode);
|
||||||
fprintf(logfile?logfile:stderr, "FILE %s:%d fopen(\"%s\") = %p\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "FILE %s:%d fopen(\"%s\") = %p\n",
|
||||||
source, line, file, res);
|
source, line, file, res);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
int curl_fclose(FILE *file, int line, char *source)
|
int curl_fclose(FILE *file, int line, const char *source)
|
||||||
{
|
{
|
||||||
int res=(fclose)(file);
|
int res=(fclose)(file);
|
||||||
fprintf(logfile?logfile:stderr, "FILE %s:%d fclose(%p)\n",
|
if(logfile)
|
||||||
|
fprintf(logfile, "FILE %s:%d fclose(%p)\n",
|
||||||
source, line, file);
|
source, line, file);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* MALLOCDEBUG */
|
#endif /* MALLOCDEBUG */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* local variables:
|
||||||
|
* eval: (load-file "../curl-mode.el")
|
||||||
|
* end:
|
||||||
|
* vim600: fdm=marker
|
||||||
|
* vim: et sw=2 ts=2 sts=2 tw=78
|
||||||
|
*/
|
||||||
|
@@ -2,23 +2,29 @@
|
|||||||
|
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#ifdef HAVE_MEMORY_H
|
||||||
|
#include <memory.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern FILE *logfile;
|
||||||
|
|
||||||
/* memory functions */
|
/* memory functions */
|
||||||
void *curl_domalloc(size_t size, int line, char *source);
|
void *curl_domalloc(size_t size, int line, const char *source);
|
||||||
void *curl_dorealloc(void *ptr, size_t size, int line, char *source);
|
void *curl_dorealloc(void *ptr, size_t size, int line, const char *source);
|
||||||
void curl_dofree(void *ptr, int line, char *source);
|
void curl_dofree(void *ptr, int line, const char *source);
|
||||||
char *curl_dostrdup(const char *str, int line, char *source);
|
char *curl_dostrdup(const char *str, int line, const char *source);
|
||||||
void curl_memdebug(char *logname);
|
void curl_memdebug(const char *logname);
|
||||||
|
|
||||||
/* file descriptor manipulators */
|
/* file descriptor manipulators */
|
||||||
int curl_socket(int domain, int type, int protocol, int, char *);
|
int curl_socket(int domain, int type, int protocol, int, const char *);
|
||||||
int curl_sclose(int sockfd, int, char *);
|
int curl_sclose(int sockfd, int, const char *source);
|
||||||
int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
||||||
int line, char *source);
|
int line, const char *source);
|
||||||
|
|
||||||
/* FILE functions */
|
/* FILE functions */
|
||||||
FILE *curl_fopen(char *file, char *mode, int line, char *source);
|
FILE *curl_fopen(const char *file, const char *mode, int line,
|
||||||
int curl_fclose(FILE *file, int line, char *source);
|
const char *source);
|
||||||
|
int curl_fclose(FILE *file, int line, const char *source);
|
||||||
|
|
||||||
/* Set this symbol on the command-line, recompile all lib-sources */
|
/* Set this symbol on the command-line, recompile all lib-sources */
|
||||||
#define strdup(ptr) curl_dostrdup(ptr, __LINE__, __FILE__)
|
#define strdup(ptr) curl_dostrdup(ptr, __LINE__, __FILE__)
|
||||||
@@ -31,6 +37,11 @@ int curl_fclose(FILE *file, int line, char *source);
|
|||||||
#define accept(sock,addr,len)\
|
#define accept(sock,addr,len)\
|
||||||
curl_accept(sock,addr,len,__LINE__,__FILE__)
|
curl_accept(sock,addr,len,__LINE__,__FILE__)
|
||||||
|
|
||||||
|
#define getaddrinfo(host,serv,hint,res) \
|
||||||
|
curl_getaddrinfo(host,serv,hint,res,__LINE__,__FILE__)
|
||||||
|
#define freeaddrinfo(data) \
|
||||||
|
curl_freeaddrinfo(data,__LINE__,__FILE__)
|
||||||
|
|
||||||
/* sclose is probably already defined, redefine it! */
|
/* sclose is probably already defined, redefine it! */
|
||||||
#undef sclose
|
#undef sclose
|
||||||
#define sclose(sockfd) curl_sclose(sockfd,__LINE__,__FILE__)
|
#define sclose(sockfd) curl_sclose(sockfd,__LINE__,__FILE__)
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user