Compare commits
498 Commits
curl-7_20_
...
curl-7_21_
Author | SHA1 | Date | |
---|---|---|---|
![]() |
d371458348 | ||
![]() |
ecd624b8e7 | ||
![]() |
81f151c912 | ||
![]() |
b804906414 | ||
![]() |
2869b6ea2b | ||
![]() |
2d3c7b7e01 | ||
![]() |
edf9566c3b | ||
![]() |
331531f70e | ||
![]() |
51b8d30dc4 | ||
![]() |
450c994a49 | ||
![]() |
6a43ffa0d5 | ||
![]() |
6a90aa3f3d | ||
![]() |
1998de9993 | ||
![]() |
61f4cdb73a | ||
![]() |
cda02fb78b | ||
![]() |
a5f96b49d1 | ||
![]() |
18e7b52e8e | ||
![]() |
6d272e53a2 | ||
![]() |
9bce615f46 | ||
![]() |
81e107010e | ||
![]() |
70e8814e44 | ||
![]() |
fc137ee272 | ||
![]() |
79cd7ef9ab | ||
![]() |
4b69f641a6 | ||
![]() |
2ae6c47d5d | ||
![]() |
15622e69a9 | ||
![]() |
8500586251 | ||
![]() |
3aef3ed8f6 | ||
![]() |
488f9545a2 | ||
![]() |
588402585b | ||
![]() |
750c9179ca | ||
![]() |
5f0ae7a062 | ||
![]() |
8fa519dce4 | ||
![]() |
5fb4279ec7 | ||
![]() |
67c83eb9eb | ||
![]() |
9e1083488f | ||
![]() |
dfaaa99ded | ||
![]() |
87badbef84 | ||
![]() |
e3811ed7c3 | ||
![]() |
dacc44ddc2 | ||
![]() |
fc9f369829 | ||
![]() |
bfbc4c7e00 | ||
![]() |
05b72a6af2 | ||
![]() |
1e2056fecb | ||
![]() |
5df13c3173 | ||
![]() |
ed4eecc05e | ||
![]() |
7e1a45e224 | ||
![]() |
e329586489 | ||
![]() |
397e61128f | ||
![]() |
578e833d3b | ||
![]() |
4d58f97f60 | ||
![]() |
33c3bb057b | ||
![]() |
6bf2014745 | ||
![]() |
a10f5b34ff | ||
![]() |
b1df37c60e | ||
![]() |
31d59fb2cc | ||
![]() |
562d40e671 | ||
![]() |
612832e4c0 | ||
![]() |
3c69a08e3b | ||
![]() |
5ea9e78bd7 | ||
![]() |
69d7c48072 | ||
![]() |
7d4f8c2809 | ||
![]() |
d23c59ecfc | ||
![]() |
1d95a48fe9 | ||
![]() |
512a82d395 | ||
![]() |
fbb38de415 | ||
![]() |
0006cdddee | ||
![]() |
b684ccd8b1 | ||
![]() |
3f64d05d34 | ||
![]() |
e4128f90ba | ||
![]() |
e991a3536d | ||
![]() |
8665d4e593 | ||
![]() |
0e36bb71f2 | ||
![]() |
19f45eaa79 | ||
![]() |
70a025f3df | ||
![]() |
95e230c591 | ||
![]() |
5fcc4332d6 | ||
![]() |
7d84113e1d | ||
![]() |
f3df524b62 | ||
![]() |
c47148f142 | ||
![]() |
8a00c94b0f | ||
![]() |
9de4b26643 | ||
![]() |
3208757c1a | ||
![]() |
fae19aed8d | ||
![]() |
c59dba338e | ||
![]() |
a76f852ca4 | ||
![]() |
3880dd3741 | ||
![]() |
d8041a7ea5 | ||
![]() |
abde4c9d84 | ||
![]() |
6d88d58dd5 | ||
![]() |
fbefd816e4 | ||
![]() |
296b246b9c | ||
![]() |
5393f08df8 | ||
![]() |
b5da54e6c9 | ||
![]() |
22085f7d6e | ||
![]() |
2c1b4e74e4 | ||
![]() |
aca67e2775 | ||
![]() |
8e2f16e66f | ||
![]() |
a7f6747019 | ||
![]() |
c3c4626fab | ||
![]() |
9808480860 | ||
![]() |
6ce76e6996 | ||
![]() |
64f12a3b9f | ||
![]() |
18a758d907 | ||
![]() |
7aea2d522d | ||
![]() |
f3e3f5f1b2 | ||
![]() |
62ef465262 | ||
![]() |
c6fa1952a1 | ||
![]() |
d47bd396ce | ||
![]() |
6882ae8dee | ||
![]() |
a00297158e | ||
![]() |
413cbdce3c | ||
![]() |
864d5add0d | ||
![]() |
3238ef5b69 | ||
![]() |
ca10e28f06 | ||
![]() |
5e92015711 | ||
![]() |
ce00c2ef5d | ||
![]() |
0db9140747 | ||
![]() |
55c266de6d | ||
![]() |
3af696f7c4 | ||
![]() |
09cee1633b | ||
![]() |
8d121b6f8f | ||
![]() |
892d6930e7 | ||
![]() |
200e9b5dd1 | ||
![]() |
b0873cb657 | ||
![]() |
19d2bf4ee4 | ||
![]() |
ae467115bb | ||
![]() |
f43ecac175 | ||
![]() |
d2a7fd2fe6 | ||
![]() |
29439acfeb | ||
![]() |
a049528e94 | ||
![]() |
2fbbddbe85 | ||
![]() |
ecb3fe63d7 | ||
![]() |
6ed72fd7fa | ||
![]() |
40e1623649 | ||
![]() |
53151db167 | ||
![]() |
cb64c987a0 | ||
![]() |
67d1616018 | ||
![]() |
65629f2915 | ||
![]() |
795107453d | ||
![]() |
201637d468 | ||
![]() |
6b6a3bcb61 | ||
![]() |
0cbdcd07a8 | ||
![]() |
d106189a47 | ||
![]() |
ddb810ab70 | ||
![]() |
77ba147e76 | ||
![]() |
bed311eda2 | ||
![]() |
9a0b6e42af | ||
![]() |
cfdc4aca45 | ||
![]() |
ab6681c2c8 | ||
![]() |
eeb2cb05a1 | ||
![]() |
daa96f9928 | ||
![]() |
f37affab8c | ||
![]() |
dc4adc484f | ||
![]() |
d0dea8f869 | ||
![]() |
ab81f6c7c4 | ||
![]() |
ebbe694e78 | ||
![]() |
70baf46d8d | ||
![]() |
280d2cff2e | ||
![]() |
ac20f52ed3 | ||
![]() |
59842d4d5f | ||
![]() |
2b6208a6de | ||
![]() |
2f0532a072 | ||
![]() |
6b490ed33c | ||
![]() |
4d703ee100 | ||
![]() |
13b8fc46a3 | ||
![]() |
9f4a174698 | ||
![]() |
8f6189600f | ||
![]() |
41572648db | ||
![]() |
b980c9a027 | ||
![]() |
9124bfba45 | ||
![]() |
232ad6549a | ||
![]() |
03da3ba1c0 | ||
![]() |
4d53dc5d80 | ||
![]() |
5907777153 | ||
![]() |
72da720b4a | ||
![]() |
a6e088e855 | ||
![]() |
4342a2087a | ||
![]() |
8249b0522d | ||
![]() |
a43201e578 | ||
![]() |
3c2ee9c341 | ||
![]() |
8d31d70114 | ||
![]() |
9754b20adb | ||
![]() |
17c1e3bcba | ||
![]() |
6cf90c6a7b | ||
![]() |
67d76dd520 | ||
![]() |
8348dd96dd | ||
![]() |
2596eb6d19 | ||
![]() |
625932d398 | ||
![]() |
37201e3c36 | ||
![]() |
06869597c3 | ||
![]() |
517f3a1b8f | ||
![]() |
495d3e07d4 | ||
![]() |
44e5e37f38 | ||
![]() |
1d594772fd | ||
![]() |
ff26895b5c | ||
![]() |
d7134036b2 | ||
![]() |
7115245f88 | ||
![]() |
dc2157a087 | ||
![]() |
5d5dd08e77 | ||
![]() |
cfbdbf9783 | ||
![]() |
b24e872502 | ||
![]() |
50a1d5ee1c | ||
![]() |
6ccbd1bee4 | ||
![]() |
1267719735 | ||
![]() |
c49e9683b8 | ||
![]() |
6ea043a504 | ||
![]() |
af4eae77ac | ||
![]() |
7d342c723c | ||
![]() |
5c2b6b2d3e | ||
![]() |
11958ed331 | ||
![]() |
15201da4ca | ||
![]() |
59bad26bb2 | ||
![]() |
f91d578674 | ||
![]() |
9df8257301 | ||
![]() |
992ceae386 | ||
![]() |
364fd2f1ad | ||
![]() |
1cbe66fbc8 | ||
![]() |
f8cf037ecf | ||
![]() |
6028fdb305 | ||
![]() |
45456135d5 | ||
![]() |
52beeb2c9f | ||
![]() |
544f15af98 | ||
![]() |
000ac0c975 | ||
![]() |
fc308282ac | ||
![]() |
e9f3513264 | ||
![]() |
a1a5ba3d0a | ||
![]() |
687df5c8c3 | ||
![]() |
40253e32fe | ||
![]() |
f97a7eb400 | ||
![]() |
3cf658fc24 | ||
![]() |
5247266df6 | ||
![]() |
dfa6ee890d | ||
![]() |
bd5df39a29 | ||
![]() |
6f3dc2a726 | ||
![]() |
b01fb30f9c | ||
![]() |
f38e52071e | ||
![]() |
811fcccfc9 | ||
![]() |
b552ca223e | ||
![]() |
a93522f68d | ||
![]() |
425060fed1 | ||
![]() |
fbee86a9e2 | ||
![]() |
2f0c118577 | ||
![]() |
53e47ca947 | ||
![]() |
314117cbf1 | ||
![]() |
d296dd4ee8 | ||
![]() |
04eff9beb9 | ||
![]() |
b5c3feda17 | ||
![]() |
01c309e186 | ||
![]() |
d873c820bd | ||
![]() |
41cf1f4090 | ||
![]() |
6ad0acb608 | ||
![]() |
cfbb351e22 | ||
![]() |
11f53b9a18 | ||
![]() |
eb33f5d1f8 | ||
![]() |
cef30e0924 | ||
![]() |
a13128596c | ||
![]() |
6d2ccfed48 | ||
![]() |
7738b15977 | ||
![]() |
0fa4b41c2b | ||
![]() |
7d166b0ef6 | ||
![]() |
affff47b3d | ||
![]() |
d6981cb508 | ||
![]() |
40ecd6c9b8 | ||
![]() |
181b08babb | ||
![]() |
7abf3b97fe | ||
![]() |
4a1384a8b4 | ||
![]() |
d76874a665 | ||
![]() |
c8d42b2f1c | ||
![]() |
84332b60b9 | ||
![]() |
bc0699f226 | ||
![]() |
157e6d4e7e | ||
![]() |
d4e6404135 | ||
![]() |
3992309285 | ||
![]() |
241b704e1f | ||
![]() |
1dbb9a0ba4 | ||
![]() |
e7743aa7b4 | ||
![]() |
915032ea02 | ||
![]() |
e01cc7737c | ||
![]() |
bd36927f18 | ||
![]() |
0417d34533 | ||
![]() |
a57611e308 | ||
![]() |
12533bb184 | ||
![]() |
9be951a415 | ||
![]() |
7239538d9a | ||
![]() |
18a9ee6bdf | ||
![]() |
f3b77e5611 | ||
![]() |
89924a897d | ||
![]() |
bcefe839c7 | ||
![]() |
458dd4550b | ||
![]() |
f7ae7b3623 | ||
![]() |
31dd8ab1d6 | ||
![]() |
8da56e12c6 | ||
![]() |
0a04078916 | ||
![]() |
1182c8bdcd | ||
![]() |
55d2460fc3 | ||
![]() |
a89d7997b7 | ||
![]() |
d8383220ec | ||
![]() |
8e7ec794f5 | ||
![]() |
bd5d478dd4 | ||
![]() |
1b15b31c86 | ||
![]() |
e6d85923c1 | ||
![]() |
614bae813e | ||
![]() |
bd6a695545 | ||
![]() |
d63bdba097 | ||
![]() |
43edcc4a2e | ||
![]() |
01c2b397aa | ||
![]() |
51a757c11b | ||
![]() |
7a99672042 | ||
![]() |
7eecfb536a | ||
![]() |
a09814138a | ||
![]() |
42432d67cc | ||
![]() |
e91d167ff8 | ||
![]() |
88af6fbf98 | ||
![]() |
6b6fe2a4d5 | ||
![]() |
54aca3c5ec | ||
![]() |
0a9cf4365a | ||
![]() |
343c4c7072 | ||
![]() |
6a0d3233ff | ||
![]() |
d3714b016d | ||
![]() |
da6e992e1d | ||
![]() |
bb60fe0c1a | ||
![]() |
feecf63a96 | ||
![]() |
cbdd1cbcde | ||
![]() |
b3d7161642 | ||
![]() |
3b47d231ac | ||
![]() |
7977bc3dfa | ||
![]() |
00fdafb0a1 | ||
![]() |
f737e94164 | ||
![]() |
a0dd9df9ab | ||
![]() |
4724b9d966 | ||
![]() |
8098d9417c | ||
![]() |
605207a3a6 | ||
![]() |
43d20d81a5 | ||
![]() |
bc0f3dd15e | ||
![]() |
475c19c42b | ||
![]() |
c072bd4609 | ||
![]() |
684830cb2a | ||
![]() |
51248a9bdd | ||
![]() |
3b24076c3b | ||
![]() |
077125e4a2 | ||
![]() |
df06182d86 | ||
![]() |
d939e0f410 | ||
![]() |
69d07feb14 | ||
![]() |
1c4538610b | ||
![]() |
2c72732ebf | ||
![]() |
e1c2c9be1a | ||
![]() |
89da532445 | ||
![]() |
b38189c7b4 | ||
![]() |
1bb04927f3 | ||
![]() |
3fd01be648 | ||
![]() |
5ae6db321f | ||
![]() |
0546d448ce | ||
![]() |
b4fa27ae4b | ||
![]() |
12043e3c9c | ||
![]() |
a324fa7b97 | ||
![]() |
a9483b1f4a | ||
![]() |
40f8aaedb7 | ||
![]() |
374f48675b | ||
![]() |
20ae9d4f71 | ||
![]() |
35955179c6 | ||
![]() |
b1c1b9bb76 | ||
![]() |
123f80ae54 | ||
![]() |
c54ab4dca7 | ||
![]() |
233ec511db | ||
![]() |
4b96e5c70f | ||
![]() |
75743b009b | ||
![]() |
01459828ef | ||
![]() |
99179da4cc | ||
![]() |
645bdd837a | ||
![]() |
c03cbb38ad | ||
![]() |
63661d8e83 | ||
![]() |
4a0493f789 | ||
![]() |
eadeb5bd9a | ||
![]() |
9190e2876e | ||
![]() |
b4f0e1291f | ||
![]() |
dd8568739c | ||
![]() |
97b497a75f | ||
![]() |
d3c813e726 | ||
![]() |
9e480973eb | ||
![]() |
2e056353b0 | ||
![]() |
606b933a4f | ||
![]() |
d17709da31 | ||
![]() |
0bb6deda72 | ||
![]() |
0a29e2445c | ||
![]() |
700335103e | ||
![]() |
368fd5d27b | ||
![]() |
81239edb89 | ||
![]() |
22f3b01478 | ||
![]() |
5f53c9d94a | ||
![]() |
04cfef24a1 | ||
![]() |
1d26151d5f | ||
![]() |
aabd27d9aa | ||
![]() |
dcc061543a | ||
![]() |
2ffe834bff | ||
![]() |
027ceb37a1 | ||
![]() |
510836f80b | ||
![]() |
e4af5d6efc | ||
![]() |
43b816538f | ||
![]() |
77cfeadfa6 | ||
![]() |
ea521cf617 | ||
![]() |
a82c5a39c4 | ||
![]() |
7764795c06 | ||
![]() |
d6706294e0 | ||
![]() |
83305cbf9f | ||
![]() |
76255cfdc9 | ||
![]() |
ad6bc4d82e | ||
![]() |
147609ca6e | ||
![]() |
7871fbad4d | ||
![]() |
46b9719bbb | ||
![]() |
a1a98d5908 | ||
![]() |
a799162bc7 | ||
![]() |
d62ce21249 | ||
![]() |
0825cd80a6 | ||
![]() |
04cb15ae9d | ||
![]() |
bc8fc9803f | ||
![]() |
016ce4b1da | ||
![]() |
3e759f4fb6 | ||
![]() |
2e8b21833a | ||
![]() |
54b0e87796 | ||
![]() |
a784ed6065 | ||
![]() |
d2621445f1 | ||
![]() |
adaf87530d | ||
![]() |
8914857092 | ||
![]() |
aca0fff4e1 | ||
![]() |
d64bd82bdc | ||
![]() |
cb6647ce1c | ||
![]() |
51427e1947 | ||
![]() |
1de6b97a76 | ||
![]() |
f09340de8b | ||
![]() |
82b55efdba | ||
![]() |
16f575ee6c | ||
![]() |
38d2afcefb | ||
![]() |
7f616eb513 | ||
![]() |
fe818c8076 | ||
![]() |
a7b9452a6b | ||
![]() |
2c1b0624ac | ||
![]() |
107146676e | ||
![]() |
79dc74e84d | ||
![]() |
6be508dcc2 | ||
![]() |
82e9b78a38 | ||
![]() |
07f45946b5 | ||
![]() |
7fb7f24131 | ||
![]() |
5b40c11c2f | ||
![]() |
9d6a394c44 | ||
![]() |
d7b82baf97 | ||
![]() |
36e245658b | ||
![]() |
d487ade72c | ||
![]() |
71be565cf4 | ||
![]() |
81512cc02b | ||
![]() |
32236dad5e | ||
![]() |
b30ce34d84 | ||
![]() |
2164b6b463 | ||
![]() |
7af5e3c39e | ||
![]() |
42930155ab | ||
![]() |
e5b3246d0a | ||
![]() |
47dda4a1d4 | ||
![]() |
a5b7e3205d | ||
![]() |
dfce37da23 | ||
![]() |
14bfcb96f5 | ||
![]() |
87fbcb4494 | ||
![]() |
4bfe07640c | ||
![]() |
5d93525f30 | ||
![]() |
b7848e4a72 | ||
![]() |
99ec359b4d | ||
![]() |
dfad8a6dad | ||
![]() |
d841ab82b8 | ||
![]() |
d6be52d80e | ||
![]() |
c0111460b0 | ||
![]() |
93981bb9b5 | ||
![]() |
8f136288c5 | ||
![]() |
9799dbebd6 | ||
![]() |
b025ac16a6 | ||
![]() |
5d43c75c66 | ||
![]() |
15fa5dcfe6 | ||
![]() |
516dfd1705 | ||
![]() |
743bd81e64 | ||
![]() |
520cee3fb7 | ||
![]() |
fa7341143a | ||
![]() |
313a5b05c2 | ||
![]() |
01fc53e027 | ||
![]() |
0a4ccce054 | ||
![]() |
c2888604d7 | ||
![]() |
6632d957e7 | ||
![]() |
c5e539c312 | ||
![]() |
0338994c6a | ||
![]() |
2056ca9fea | ||
![]() |
cca192e58f | ||
![]() |
f3d4b17a9c | ||
![]() |
5bd38b70dd | ||
![]() |
44f1bef668 | ||
![]() |
f38510f4b5 | ||
![]() |
689b6929c3 | ||
![]() |
68aae7f579 | ||
![]() |
a76fa17681 | ||
![]() |
72411118ec | ||
![]() |
5a16df5e04 | ||
![]() |
5a814f6f2c |
5
.gitignore
vendored
5
.gitignore
vendored
@@ -5,6 +5,7 @@
|
|||||||
*.dll
|
*.dll
|
||||||
*.exe
|
*.exe
|
||||||
*.obj
|
*.obj
|
||||||
|
*.asc
|
||||||
.*.swp
|
.*.swp
|
||||||
Debug
|
Debug
|
||||||
Release
|
Release
|
||||||
@@ -26,6 +27,9 @@ curl-config
|
|||||||
libcurl.pc
|
libcurl.pc
|
||||||
missing
|
missing
|
||||||
curl-*.tar.gz
|
curl-*.tar.gz
|
||||||
|
curl-*.tar.bz2
|
||||||
|
curl-*.tar.lzma
|
||||||
|
curl-*.zip
|
||||||
INSTALL
|
INSTALL
|
||||||
install-sh
|
install-sh
|
||||||
*.o
|
*.o
|
||||||
@@ -36,3 +40,4 @@ tags
|
|||||||
TAGS
|
TAGS
|
||||||
*~
|
*~
|
||||||
aclocal.m4.bak
|
aclocal.m4.bak
|
||||||
|
CHANGES.dist
|
||||||
|
49
Android.mk
49
Android.mk
@@ -2,7 +2,7 @@
|
|||||||
#
|
#
|
||||||
# Place the curl source (including this makefile) into external/curl/ in the
|
# Place the curl source (including this makefile) into external/curl/ in the
|
||||||
# Android source tree. Then build them with 'make curl' or just 'make libcurl'
|
# Android source tree. Then build them with 'make curl' or just 'make libcurl'
|
||||||
# from the Android root. Tested with Android 1.5
|
# from the Android root. Tested with Android 1.5 and 2.1
|
||||||
#
|
#
|
||||||
# Note: you must first create a curl_config.h file by running configure in the
|
# Note: you must first create a curl_config.h file by running configure in the
|
||||||
# Android environment. The only way I've found to do this is tricky. Perform a
|
# Android environment. The only way I've found to do this is tricky. Perform a
|
||||||
@@ -12,26 +12,37 @@
|
|||||||
# shown. Now, from the external/curl/ directory, run curl's normal configure
|
# shown. Now, from the external/curl/ directory, run curl's normal configure
|
||||||
# command with flags that match what Android itself uses. This will mean
|
# command with flags that match what Android itself uses. This will mean
|
||||||
# putting the compiler directory into the PATH, putting the -I, -isystem and
|
# putting the compiler directory into the PATH, putting the -I, -isystem and
|
||||||
# -D options into CPPFLAGS, putting the -m, -f, -O and -nostdlib options into
|
# -D options into CPPFLAGS, putting the -W, -m, -f, -O and -nostdlib options
|
||||||
# CFLAGS, and putting the -Wl, -L and -l options into LIBS, along with the path
|
# into CFLAGS, and putting the -Wl, -L and -l options into LIBS, along with the
|
||||||
# to the files libgcc.a, crtbegin_dynamic.o, and ccrtend_android.o. Remember
|
# path to the files libgcc.a, crtbegin_dynamic.o, and ccrtend_android.o.
|
||||||
# that the paths must be absolute since you will not be running configure from
|
# Remember that the paths must be absolute since you will not be running
|
||||||
# the same directory as the Android make. The normal cross-compiler options
|
# configure from the same directory as the Android make. The normal
|
||||||
# must also be set.
|
# cross-compiler options must also be set. Note that the -c, -o, -MD and
|
||||||
|
# similar flags must not be set.
|
||||||
|
#
|
||||||
|
# To see all the LIBS options, you'll need to do the "showcommands" trick on an
|
||||||
|
# executable that's already buildable and watch what flags Android uses to link
|
||||||
|
# it (dhcpcd is a good choice to watch). You'll also want to add -L options to
|
||||||
|
# LIBS that point to the out/.../obj/lib/ and out/.../obj/system/lib/
|
||||||
|
# directories so that additional libraries can be found and used by curl.
|
||||||
#
|
#
|
||||||
# The end result will be a configure command that looks something like this
|
# The end result will be a configure command that looks something like this
|
||||||
# (the environment variable A is set to the Android root path):
|
# (the environment variable A is set to the Android root path which makes the
|
||||||
|
# command shorter):
|
||||||
#
|
#
|
||||||
# A=`realpath ../..` && \
|
# A=`realpath ../..` && \
|
||||||
# PATH="$A/prebuilt/linux-x86/toolchain/arm-eabi-X/bin:$PATH" \
|
# PATH="$A/prebuilt/linux-x86/toolchain/arm-eabi-X/bin:$PATH" \
|
||||||
# ./configure --host=arm-linux CC=arm-eabi-gcc \
|
# ./configure --host=arm-linux CC=arm-eabi-gcc \
|
||||||
# CPPFLAGS="-I $A/system/core/include ..." \
|
# CPPFLAGS="-I $A/system/core/include ..." \
|
||||||
# CFLAGS="-fno-exceptions -Wno-multichar ..." \
|
# CFLAGS="-nostdlib -fno-exceptions -Wno-multichar ..." \
|
||||||
# LIB="$A/prebuilt/linux-x86/toolchain/arm-eabi-X/lib/gcc/arm-eabi/X\
|
# LIBS="$A/prebuilt/linux-x86/toolchain/arm-eabi-X/lib/gcc/arm-eabi/X\
|
||||||
# /interwork/libgcc.a ..." \
|
# /interwork/libgcc.a ..."
|
||||||
|
#
|
||||||
|
# Finally, copy the file COPYING to NOTICE so that the curl license gets put
|
||||||
|
# into the right place (but see the note about this below).
|
||||||
#
|
#
|
||||||
# Dan Fandrich
|
# Dan Fandrich
|
||||||
# September 2009
|
# August 2010
|
||||||
|
|
||||||
LOCAL_PATH:= $(call my-dir)
|
LOCAL_PATH:= $(call my-dir)
|
||||||
|
|
||||||
@@ -63,6 +74,14 @@ LOCAL_COPY_HEADERS := $(addprefix include/curl/,$(CURL_HEADERS))
|
|||||||
|
|
||||||
LOCAL_MODULE:= libcurl
|
LOCAL_MODULE:= libcurl
|
||||||
|
|
||||||
|
# Copy the licence to a place where Android will find it.
|
||||||
|
# Actually, this doesn't quite work because the build system searches
|
||||||
|
# for NOTICE files before it gets to this point, so it will only be seen
|
||||||
|
# on subsequent builds.
|
||||||
|
ALL_PREBUILT += $(LOCAL_PATH)/NOTICE
|
||||||
|
$(LOCAL_PATH)/NOTICE: $(LOCAL_PATH)/COPYING | $(ACP)
|
||||||
|
$(copy-file-to-target)
|
||||||
|
|
||||||
include $(BUILD_STATIC_LIBRARY)
|
include $(BUILD_STATIC_LIBRARY)
|
||||||
|
|
||||||
|
|
||||||
@@ -71,7 +90,7 @@ include $(BUILD_STATIC_LIBRARY)
|
|||||||
|
|
||||||
include $(CLEAR_VARS)
|
include $(CLEAR_VARS)
|
||||||
include $(LOCAL_PATH)/src/Makefile.inc
|
include $(LOCAL_PATH)/src/Makefile.inc
|
||||||
LOCAL_SRC_FILES := $(addprefix src/,$(CURL_SOURCES))
|
LOCAL_SRC_FILES := $(addprefix src/,$(CURL_CFILES))
|
||||||
|
|
||||||
LOCAL_MODULE := curl
|
LOCAL_MODULE := curl
|
||||||
LOCAL_STATIC_LIBRARIES := libcurl
|
LOCAL_STATIC_LIBRARIES := libcurl
|
||||||
@@ -79,8 +98,8 @@ LOCAL_SYSTEM_SHARED_LIBRARIES := libc
|
|||||||
|
|
||||||
LOCAL_C_INCLUDES += $(LOCAL_PATH)/include $(LOCAL_PATH)/lib
|
LOCAL_C_INCLUDES += $(LOCAL_PATH)/include $(LOCAL_PATH)/lib
|
||||||
|
|
||||||
# This will also need to include $(CURLX_ONES) in order to correctly build
|
# This may also need to include $(CURLX_ONES) in order to correctly link
|
||||||
# a dynamic library
|
# if libcurl is changed to be built as a dynamic library
|
||||||
LOCAL_CFLAGS += $(common_CFLAGS)
|
LOCAL_CFLAGS += $(common_CFLAGS)
|
||||||
|
|
||||||
include $(BUILD_EXECUTABLE)
|
include $(BUILD_EXECUTABLE)
|
||||||
|
@@ -120,16 +120,11 @@ if(WIN32)
|
|||||||
if( NOT HAVE_WLDAP32)
|
if( NOT HAVE_WLDAP32)
|
||||||
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
||||||
message(STATUS "wldap32 not found CURL_DISABLE_LDAP set ON")
|
message(STATUS "wldap32 not found CURL_DISABLE_LDAP set ON")
|
||||||
option(CURL_LDAP_WIN "Use W$ LDAP implementation" OFF)
|
option(CURL_LDAP_WIN "Use Windows LDAP implementation" OFF)
|
||||||
else()
|
else()
|
||||||
option(CURL_LDAP_WIN "Use W$ LDAP implementation" ON)
|
option(CURL_LDAP_WIN "Use Windows LDAP implementation" ON)
|
||||||
endif()
|
endif()
|
||||||
mark_as_advanced(CURL_LDAP_WIN)
|
mark_as_advanced(CURL_LDAP_WIN)
|
||||||
set(CURL_LDAP_HYBRID OFF)
|
|
||||||
else()
|
|
||||||
option(CURL_LDAP_HYBRID "W$ LDAP with non-W$ compiler" OFF)
|
|
||||||
mark_as_advanced(CURL_LDAP_HYBRID)
|
|
||||||
set(CURL_LDAP_WIN OFF)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(HTTP_ONLY)
|
if(HTTP_ONLY)
|
||||||
@@ -836,7 +831,7 @@ function(TRANSFORM_MAKEFILE_INC INPUT_FILE OUTPUT_FILE)
|
|||||||
string(REPLACE "$(top_builddir)" "\${CURL_BINARY_DIR}" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
string(REPLACE "$(top_builddir)" "\${CURL_BINARY_DIR}" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
||||||
|
|
||||||
string(REGEX REPLACE "\\\\\n" "<22>!<21>" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
string(REGEX REPLACE "\\\\\n" "<22>!<21>" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
||||||
string(REGEX REPLACE "([a-zA-Z_][a-zA-Z0-9_]*)[\t ]*=[\t ]*([^\n]*\n)" "SET(\\1 \\2)\n" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
string(REGEX REPLACE "([a-zA-Z_][a-zA-Z0-9_]*)[\t ]*=[\t ]*([^\n]*)" "SET(\\1 \\2)" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
||||||
string(REPLACE "<22>!<21>" "\n" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
string(REPLACE "<22>!<21>" "\n" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT})
|
||||||
|
|
||||||
string(REGEX REPLACE "\\$\\(([a-zA-Z_][a-zA-Z0-9_]*)\\)" "\${\\1}" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT}) # Replace $() with ${}
|
string(REGEX REPLACE "\\$\\(([a-zA-Z_][a-zA-Z0-9_]*)\\)" "\${\\1}" MAKEFILE_INC_TEXT ${MAKEFILE_INC_TEXT}) # Replace $() with ${}
|
||||||
|
118
MacOSX-Framework
118
MacOSX-Framework
@@ -1,26 +1,76 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# This script performs all of the steps needed to build a
|
# This script performs all of the steps needed to build a
|
||||||
# universal binary libcurl.framework for Mac OS X 10.4 or greater.
|
# universal binary libcurl.framework for Mac OS X 10.4 or greater.
|
||||||
|
#
|
||||||
|
# Hendrik Visage:
|
||||||
|
# Generalizations added since Snowleopard (10.6) do not include
|
||||||
|
# the 10.4u SDK.
|
||||||
|
#
|
||||||
|
# Also note:
|
||||||
|
# 10.5 is the *ONLY* SDK that support PPC64 :( -- 10.6 do not have ppc64 support
|
||||||
|
#If you need to have PPC64 support then change below to 1
|
||||||
|
PPC64_NEEDED=0
|
||||||
|
|
||||||
|
# For me the default is to develop for the platform I am on, and if you
|
||||||
|
#desire compatibility with older versions then change USE_OLD to 1 :)
|
||||||
|
USE_OLD=0
|
||||||
|
|
||||||
VERSION=`/usr/bin/sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' include/curl/curlver.h`
|
VERSION=`/usr/bin/sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' include/curl/curlver.h`
|
||||||
|
FRAMEWORK_VERSION=Versions/Release-$VERSION
|
||||||
|
|
||||||
SDK32='/Developer/SDKs/MacOSX10.4u.sdk'
|
#I also wanted to "copy over" the system, and thus the reason I added the
|
||||||
|
# version to Versions/Release-7.20.1 etc.
|
||||||
|
# now a simple rsync -vaP libcurl.framework /Library/Frameworks will install it
|
||||||
|
# and setup the right paths to this version, leaving the system version
|
||||||
|
# "intact", so you can "fix" it later with the links to Versions/A/...
|
||||||
|
|
||||||
MINVER32='-mmacosx-version-min=10.4'
|
|
||||||
|
|
||||||
ARCHES32='-arch ppc -arch i386'
|
OLD_SDK=`ls /Developer/SDKs|head -1`
|
||||||
|
NEW_SDK=`ls -r /Developer/SDKs|head -1`
|
||||||
|
|
||||||
SDK64='/Developer/SDKs/MacOSX10.5.sdk'
|
if test "0"$USE_OLD -gt 0
|
||||||
|
then
|
||||||
|
SDK32=$OLD_SDK
|
||||||
|
else
|
||||||
|
SDK32=$NEW_SDK
|
||||||
|
fi
|
||||||
|
|
||||||
MINVER64='-mmacosx-version-min=10.5'
|
MACVER=`echo $SDK32|sed -e s/[a-zA-Z]//g -e s/.\$//`
|
||||||
|
|
||||||
ARCHES64='-arch ppc64 -arch x86_64'
|
SDK32_DIR='/Developer/SDKs/'$SDK32
|
||||||
|
MINVER32='-mmacosx-version-min='$MACVER
|
||||||
|
ARCHES32='-arch i386 -arch ppc'
|
||||||
|
|
||||||
if test -d $SDK32; then
|
|
||||||
|
if test $PPC64_NEEDED -gt 0
|
||||||
|
then
|
||||||
|
SDK64=10.5
|
||||||
|
ARCHES64='-arch x86_64 -arch ppc64'
|
||||||
|
SDK64=`ls /Developer/SDKs|grep 10.5|head -1`
|
||||||
|
else
|
||||||
|
ARCHES64='-arch x86_64'
|
||||||
|
#We "know" that 10.4 and earlier do not support 64bit
|
||||||
|
OLD_SDK64=`ls /Developer/SDKs|egrep -v "10.[0-4]"|head -1`
|
||||||
|
NEW_SDK64=`ls -r /Developer/SDKs|egrep -v "10.[0-4]"|head -1`
|
||||||
|
if test $USE_OLD -gt 0
|
||||||
|
then
|
||||||
|
SDK64=$OLD_SDK64
|
||||||
|
else
|
||||||
|
SDK64=$NEW_SDK64
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
SDK64_DIR='/Developer/SDKs/'$SDK64
|
||||||
|
MACVER64=`echo $SDK64|sed -e s/[a-zA-Z]//g -e s/.\$//`
|
||||||
|
|
||||||
|
MINVER64='-mmacosx-version-min='$MACVER64
|
||||||
|
|
||||||
|
if test ! -z $SDK32; then
|
||||||
echo "----Configuring libcurl for 32 bit universal framework..."
|
echo "----Configuring libcurl for 32 bit universal framework..."
|
||||||
|
make clean
|
||||||
./configure --disable-dependency-tracking --disable-static --with-gssapi \
|
./configure --disable-dependency-tracking --disable-static --with-gssapi \
|
||||||
CFLAGS="-Os -isysroot $SDK32 $ARCHES32 $MINVER32" \
|
CFLAGS="-Os -isysroot $SDK32_DIR $ARCHES32 $MINVER32" \
|
||||||
LDFLAGS="-Wl,-syslibroot,$SDK32 $ARCHES32 $MINVER32 -Wl,-headerpad_max_install_names" \
|
LDFLAGS="-Wl,-syslibroot,$SDK32_DIR $ARCHES32 $MINVER32 -Wl,-headerpad_max_install_names" \
|
||||||
CC=$CC
|
CC=$CC
|
||||||
|
|
||||||
echo "----Building 32 bit libcurl..."
|
echo "----Building 32 bit libcurl..."
|
||||||
@@ -28,40 +78,43 @@ if test -d $SDK32; then
|
|||||||
|
|
||||||
echo "----Creating 32 bit framework..."
|
echo "----Creating 32 bit framework..."
|
||||||
rm -r libcurl.framework
|
rm -r libcurl.framework
|
||||||
mkdir -p libcurl.framework/Versions/A/Resources
|
mkdir -p libcurl.framework/${FRAMEWORK_VERSION}/Resources
|
||||||
cp lib/.libs/libcurl.dylib libcurl.framework/Versions/A/libcurl
|
cp lib/.libs/libcurl.dylib libcurl.framework/${FRAMEWORK_VERSION}/libcurl
|
||||||
install_name_tool -id @executable_path/../Frameworks/libcurl.framework/Versions/A/libcurl libcurl.framework/Versions/A/libcurl
|
install_name_tool -id @executable_path/../Frameworks/libcurl.framework/${FRAMEWORK_VERSION}/libcurl libcurl.framework/${FRAMEWORK_VERSION}/libcurl
|
||||||
/usr/bin/sed -e "s/7\.12\.3/$VERSION/" lib/libcurl.plist >libcurl.framework/Versions/A/Resources/Info.plist
|
/usr/bin/sed -e "s/7\.12\.3/$VERSION/" lib/libcurl.plist >libcurl.framework/${FRAMEWORK_VERSION}/Resources/Info.plist
|
||||||
mkdir -p libcurl.framework/Versions/A/Headers/curl
|
mkdir -p libcurl.framework/${FRAMEWORK_VERSION}/Headers/curl
|
||||||
cp include/curl/*.h libcurl.framework/Versions/A/Headers/curl
|
cp include/curl/*.h libcurl.framework/${FRAMEWORK_VERSION}/Headers/curl
|
||||||
pushd libcurl.framework
|
pushd libcurl.framework
|
||||||
ln -fs Versions/A/libcurl libcurl
|
ln -fs ${FRAMEWORK_VERSION}/libcurl libcurl
|
||||||
ln -fs Versions/A/Resources Resources
|
ln -fs ${FRAMEWORK_VERSION}/Resources Resources
|
||||||
ln -fs Versions/A/Headers Headers
|
ln -fs ${FRAMEWORK_VERSION}/Headers Headers
|
||||||
cd Versions
|
cd Versions
|
||||||
ln -fs A Current
|
ln -fs ${FRAMEWORK_VERSION} Current
|
||||||
|
|
||||||
if test -d $SDK64; then
|
echo TEsting for SDK64
|
||||||
|
if test -d $SDK64_DIR; then
|
||||||
|
echo entering...
|
||||||
popd
|
popd
|
||||||
make clean
|
make clean
|
||||||
echo "----Configuring libcurl for 64 bit universal framework..."
|
echo "----Configuring libcurl for 64 bit universal framework..."
|
||||||
./configure --disable-dependency-tracking --disable-static --with-gssapi \
|
./configure --disable-dependency-tracking --disable-static --with-gssapi \
|
||||||
CFLAGS="-Os -isysroot $SDK64 $ARCHES64 $MINVER64" \
|
CFLAGS="-Os -isysroot $SDK64_DIR $ARCHES64 $MINVER64" \
|
||||||
LDFLAGS="-Wl,-syslibroot,$SDK64 $ARCHES64 $MINVER64 -Wl,-headerpad_max_install_names" \
|
LDFLAGS="-Wl,-syslibroot,$SDK64_DIR $ARCHES64 $MINVER64 -Wl,-headerpad_max_install_names" \
|
||||||
CC=$CC
|
CC=$CC
|
||||||
|
|
||||||
echo "----Building 64 bit libcurl..."
|
echo "----Building 64 bit libcurl..."
|
||||||
make
|
make
|
||||||
|
|
||||||
echo "----Appending 64 bit framework to 32 bit framework..."
|
echo "----Appending 64 bit framework to 32 bit framework..."
|
||||||
cp lib/.libs/libcurl.dylib libcurl.framework/Versions/A/libcurl64
|
cp lib/.libs/libcurl.dylib libcurl.framework/${FRAMEWORK_VERSION}/libcurl64
|
||||||
install_name_tool -id @executable_path/../Frameworks/libcurl.framework/Versions/A/libcurl libcurl.framework/Versions/A/libcurl64
|
install_name_tool -id @executable_path/../Frameworks/libcurl.framework/${FRAMEWORK_VERSION}/libcurl libcurl.framework/${FRAMEWORK_VERSION}/libcurl64
|
||||||
cp libcurl.framework/Versions/A/libcurl libcurl.framework/Versions/A/libcurl32
|
cp libcurl.framework/${FRAMEWORK_VERSION}/libcurl libcurl.framework/${FRAMEWORK_VERSION}/libcurl32
|
||||||
lipo libcurl.framework/Versions/A/libcurl32 libcurl.framework/Versions/A/libcurl64 -create -output libcurl.framework/Versions/A/libcurl
|
pwd
|
||||||
rm libcurl.framework/Versions/A/libcurl32 libcurl.framework/Versions/A/libcurl64
|
lipo libcurl.framework/${FRAMEWORK_VERSION}/libcurl32 libcurl.framework/${FRAMEWORK_VERSION}/libcurl64 -create -output libcurl.framework/${FRAMEWORK_VERSION}/libcurl
|
||||||
cp libcurl.framework/Versions/A/Headers/curl/curlbuild.h libcurl.framework/Versions/A/Headers/curl/curlbuild32.h
|
rm libcurl.framework/${FRAMEWORK_VERSION}/libcurl32 libcurl.framework/${FRAMEWORK_VERSION}/libcurl64
|
||||||
cp include/curl/curlbuild.h libcurl.framework/Versions/A/Headers/curl/curlbuild64.h
|
cp libcurl.framework/${FRAMEWORK_VERSION}/Headers/curl/curlbuild.h libcurl.framework/${FRAMEWORK_VERSION}/Headers/curl/curlbuild32.h
|
||||||
cat >libcurl.framework/Versions/A/Headers/curl/curlbuild.h <<EOF
|
cp include/curl/curlbuild.h libcurl.framework/${FRAMEWORK_VERSION}/Headers/curl/curlbuild64.h
|
||||||
|
cat >libcurl.framework/${FRAMEWORK_VERSION}/Headers/curl/curlbuild.h <<EOF
|
||||||
#ifdef __LP64__
|
#ifdef __LP64__
|
||||||
#include "curl/curlbuild64.h"
|
#include "curl/curlbuild64.h"
|
||||||
#else
|
#else
|
||||||
@@ -70,9 +123,10 @@ if test -d $SDK32; then
|
|||||||
EOF
|
EOF
|
||||||
fi
|
fi
|
||||||
|
|
||||||
lipo -info libcurl.framework/Versions/A/libcurl
|
pwd
|
||||||
|
lipo -info libcurl.framework/${FRAMEWORK_VERSION}/libcurl
|
||||||
echo "libcurl.framework is built and can now be included in other projects."
|
echo "libcurl.framework is built and can now be included in other projects."
|
||||||
echo "Copy libcurl.framework to your bundle's Contents/Frameworks folder, ~/Library/Frameworks or /Library/Frameworks."
|
echo "Copy libcurl.framework to your bundle's Contents/Frameworks folder, ~/Library/Frameworks or /Library/Frameworks."
|
||||||
else
|
else
|
||||||
echo "Building libcurl.framework requires Mac OS X 10.4 or later with the MacOSX10.4u SDK installed."
|
echo "Building libcurl.framework requires Mac OS X 10.4 or later with the MacOSX10.4/5/6 SDK installed."
|
||||||
fi
|
fi
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# This software is licensed as described in the file COPYING, which
|
# This software is licensed as described in the file COPYING, which
|
||||||
# you should have received as part of this distribution. The terms
|
# you should have received as part of this distribution. The terms
|
||||||
@@ -54,17 +54,23 @@ borland-clean:
|
|||||||
cd ..\src
|
cd ..\src
|
||||||
make -f Makefile.b32 clean
|
make -f Makefile.b32 clean
|
||||||
|
|
||||||
watcom:
|
watcom: .SYMBOLIC
|
||||||
cd lib
|
cd lib
|
||||||
wmake -f Makefile.Watcom
|
wmake -u -f Makefile.Watcom
|
||||||
cd ..\src
|
cd ..\src
|
||||||
wmake -f Makefile.Watcom
|
wmake -u -f Makefile.Watcom
|
||||||
|
|
||||||
watcom-clean:
|
watcom-clean: .SYMBOLIC
|
||||||
cd lib
|
cd lib
|
||||||
wmake -f Makefile.Watcom clean
|
wmake -u -f Makefile.Watcom clean
|
||||||
cd ..\src
|
cd ..\src
|
||||||
wmake -f Makefile.Watcom clean
|
wmake -u -f Makefile.Watcom clean
|
||||||
|
|
||||||
|
watcom-vclean: .SYMBOLIC
|
||||||
|
cd lib
|
||||||
|
wmake -u -f Makefile.Watcom vclean
|
||||||
|
cd ..\src
|
||||||
|
wmake -u -f Makefile.Watcom vclean
|
||||||
|
|
||||||
mingw32:
|
mingw32:
|
||||||
$(MAKE) -C lib -f Makefile.m32
|
$(MAKE) -C lib -f Makefile.m32
|
||||||
@@ -90,13 +96,13 @@ mingw32-clean:
|
|||||||
$(MAKE) -C lib -f Makefile.m32 clean
|
$(MAKE) -C lib -f Makefile.m32 clean
|
||||||
$(MAKE) -C src -f Makefile.m32 clean
|
$(MAKE) -C src -f Makefile.m32 clean
|
||||||
|
|
||||||
vc-clean:
|
vc-clean: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake -f Makefile.$(VC) clean
|
nmake -f Makefile.$(VC) clean
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake -f Makefile.$(VC) clean
|
nmake -f Makefile.$(VC) clean
|
||||||
|
|
||||||
vc-all:
|
vc-all: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake -f Makefile.$(VC) cfg=release
|
nmake -f Makefile.$(VC) cfg=release
|
||||||
nmake -f Makefile.$(VC) cfg=release-ssl
|
nmake -f Makefile.$(VC) cfg=release-ssl
|
||||||
@@ -121,85 +127,85 @@ vc-all:
|
|||||||
nmake -f Makefile.$(VC) cfg=debug-dll-zlib-dll
|
nmake -f Makefile.$(VC) cfg=debug-dll-zlib-dll
|
||||||
nmake -f Makefile.$(VC) cfg=debug-dll-ssl-dll-zlib-dll
|
nmake -f Makefile.$(VC) cfg=debug-dll-ssl-dll-zlib-dll
|
||||||
|
|
||||||
vc:
|
vc: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release
|
nmake /f Makefile.$(VC) cfg=release
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC)
|
nmake /f Makefile.$(VC)
|
||||||
|
|
||||||
vc-x64:
|
vc-x64: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release
|
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release
|
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release
|
||||||
|
|
||||||
vc-zlib:
|
vc-zlib: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-zlib
|
nmake /f Makefile.$(VC) cfg=release-zlib
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-zlib
|
nmake /f Makefile.$(VC) cfg=release-zlib
|
||||||
|
|
||||||
vc-ssl:
|
vc-ssl: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl
|
nmake /f Makefile.$(VC) cfg=release-ssl
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl
|
nmake /f Makefile.$(VC) cfg=release-ssl
|
||||||
|
|
||||||
vc-ssl-zlib:
|
vc-ssl-zlib: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl-zlib
|
nmake /f Makefile.$(VC) cfg=release-ssl-zlib
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl-zlib
|
nmake /f Makefile.$(VC) cfg=release-ssl-zlib
|
||||||
|
|
||||||
vc-x64-ssl-zlib:
|
vc-x64-ssl-zlib: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release-ssl-zlib
|
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release-ssl-zlib
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release-ssl-zlib
|
nmake /f Makefile.$(VC) MACHINE=x64 cfg=release-ssl-zlib
|
||||||
|
|
||||||
vc-ssl-dll:
|
vc-ssl-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl-dll
|
nmake /f Makefile.$(VC) cfg=release-ssl-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl-dll
|
nmake /f Makefile.$(VC) cfg=release-ssl-dll
|
||||||
|
|
||||||
vc-dll-ssl-dll:
|
vc-dll-ssl-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll
|
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll
|
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll
|
||||||
|
|
||||||
vc-dll:
|
vc-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll
|
nmake /f Makefile.$(VC) cfg=release-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll
|
nmake /f Makefile.$(VC) cfg=release-dll
|
||||||
|
|
||||||
vc-dll-zlib-dll:
|
vc-dll-zlib-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-dll-zlib-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-dll-zlib-dll
|
||||||
|
|
||||||
vc-dll-ssl-dll-zlib-dll:
|
vc-dll-ssl-dll-zlib-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-dll-ssl-dll-zlib-dll
|
||||||
|
|
||||||
vc-ssl-dll-zlib-dll:
|
vc-ssl-dll-zlib-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-ssl-dll-zlib-dll
|
||||||
|
|
||||||
vc-zlib-dll:
|
vc-zlib-dll: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-zlib-dll
|
||||||
cd ..\src
|
cd ..\src
|
||||||
nmake /f Makefile.$(VC) cfg=release-zlib-dll
|
nmake /f Makefile.$(VC) cfg=release-zlib-dll
|
||||||
|
|
||||||
vc-sspi:
|
vc-sspi: $(VC)
|
||||||
cd lib
|
cd lib
|
||||||
nmake /f Makefile.$(VC) cfg=release WINDOWS_SSPI=1
|
nmake /f Makefile.$(VC) cfg=release WINDOWS_SSPI=1
|
||||||
cd ..\src
|
cd ..\src
|
||||||
@@ -261,27 +267,40 @@ linux: all
|
|||||||
|
|
||||||
linux-ssl: ssl
|
linux-ssl: ssl
|
||||||
|
|
||||||
|
# We don't need to do anything for vc6.
|
||||||
|
vc6:
|
||||||
|
|
||||||
vc8: lib/Makefile.vc8 src/Makefile.vc8
|
vc8: lib/Makefile.vc8 src/Makefile.vc8
|
||||||
|
|
||||||
lib/Makefile.vc8: lib/Makefile.vc6
|
lib/Makefile.vc8: lib/Makefile.vc6
|
||||||
@echo "generate $@"
|
@echo "generate $@"
|
||||||
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/wsock32.lib/wsock32.lib bufferoverflowu.lib/g" -e "s/VC6/VC8/g" lib/Makefile.vc6 > lib/Makefile.vc8
|
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib bufferoverflowu.lib/g" -e "s/VC6/VC8/g" lib/Makefile.vc6 > lib/Makefile.vc8
|
||||||
|
|
||||||
src/Makefile.vc8: src/Makefile.vc6
|
src/Makefile.vc8: src/Makefile.vc6
|
||||||
@echo "generate $@"
|
@echo "generate $@"
|
||||||
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/wsock32.lib/wsock32.lib bufferoverflowu.lib/g" -e "s/VC6/VC8/g" src/Makefile.vc6 > src/Makefile.vc8
|
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib bufferoverflowu.lib/g" -e "s/VC6/VC8/g" src/Makefile.vc6 > src/Makefile.vc8
|
||||||
|
|
||||||
# VC9 makefiles are for use with VS2008
|
# VC9 makefiles are for use with VS2008
|
||||||
vc9: lib/Makefile.vc9 src/Makefile.vc9
|
vc9: lib/Makefile.vc9 src/Makefile.vc9
|
||||||
|
|
||||||
lib/Makefile.vc9: lib/Makefile.vc6
|
lib/Makefile.vc9: lib/Makefile.vc6
|
||||||
@echo "generate $@"
|
@echo "generate $@"
|
||||||
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/wsock32.lib/ws2_32.lib/g" -e "s/vc6/vc9/g" -e "s/VC6/VC9/g" lib/Makefile.vc6 > lib/Makefile.vc9
|
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc9/g" -e "s/VC6/VC9/g" lib/Makefile.vc6 > lib/Makefile.vc9
|
||||||
|
|
||||||
src/Makefile.vc9: src/Makefile.vc6
|
src/Makefile.vc9: src/Makefile.vc6
|
||||||
@echo "generate $@"
|
@echo "generate $@"
|
||||||
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/wsock32.lib/ws2_32.lib/g" -e "s/vc6/vc9/g" -e "s/VC6/VC9/g" src/Makefile.vc6 > src/Makefile.vc9
|
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc9/g" -e "s/VC6/VC9/g" src/Makefile.vc6 > src/Makefile.vc9
|
||||||
|
|
||||||
|
# VC10 makefiles are for use with VS2010
|
||||||
|
vc10: lib/Makefile.vc10 src/Makefile.vc10
|
||||||
|
|
||||||
|
lib/Makefile.vc10: lib/Makefile.vc6
|
||||||
|
@echo "generate $@"
|
||||||
|
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc10/g" -e "s/VC6/VC10/g" lib/Makefile.vc6 > lib/Makefile.vc10
|
||||||
|
|
||||||
|
src/Makefile.vc10: src/Makefile.vc6
|
||||||
|
@echo "generate $@"
|
||||||
|
@sed -e "s#/GX /DWIN32 /YX#/EHsc /DWIN32#" -e "s#/GZ#/RTC1#" -e "s/ws2_32.lib/ws2_32.lib/g" -e "s/vc6/vc10/g" -e "s/VC6/VC10/g" src/Makefile.vc6 > src/Makefile.vc10
|
||||||
|
|
||||||
ca-bundle: lib/mk-ca-bundle.pl
|
ca-bundle: lib/mk-ca-bundle.pl
|
||||||
@echo "generate a fresh ca-bundle.crt"
|
@echo "generate a fresh ca-bundle.crt"
|
||||||
|
@@ -1,51 +1,61 @@
|
|||||||
Curl and libcurl 7.20.1
|
Curl and libcurl 7.21.2
|
||||||
|
|
||||||
Public curl releases: 115
|
Public curl releases: 118
|
||||||
Command line options: 136
|
Command line options: 138
|
||||||
curl_easy_setopt() options: 174
|
curl_easy_setopt() options: 180
|
||||||
Public functions in libcurl: 58
|
Public functions in libcurl: 58
|
||||||
Known libcurl bindings: 39
|
Known libcurl bindings: 39
|
||||||
Contributors: 776
|
Contributors: 817
|
||||||
|
|
||||||
This release includes the following changes:
|
This release includes the following changes:
|
||||||
|
|
||||||
o The 'ares' subtree has been removed from the source repository
|
o curl -T: ignore file size of special files
|
||||||
o smoother rate limiting
|
o Added GOPHER protocol support
|
||||||
o allow user+password in the URL for all protocols
|
o Added mk-ca-bundle.vbs script
|
||||||
o POP3: Get message listing if no mailbox in URL
|
o c-ares build now requires c-ares >= 1.6.0
|
||||||
|
|
||||||
This release includes the following bugfixes:
|
This release includes the following bugfixes:
|
||||||
|
|
||||||
o VMS builder bad behavior when used in a batch job
|
o --remote-header-name security vulnerability fixed:
|
||||||
o multiple recepients with SMTP
|
http://curl.haxx.se/docs/adv_20101013.html
|
||||||
o fixed the CURL_FORMAT_* defines when building with cmake
|
|
||||||
o missing quote in libcurl.m4
|
o multi: support the timeouts correctly, fixes known bug #62
|
||||||
o SMTP: now waits for 250 after the DATA transfer
|
o multi: use timeouts properly for MAX_RECV/SEND_SPEED
|
||||||
o SMTP: use angle brackets in RCPT TO
|
o negotiation: Wrong proxy authorization
|
||||||
o curl --trace-time not using local time
|
o multi: avoid sending multiple complete messages
|
||||||
o off-by-one in the chunked encoding trailer parser
|
o cmdline: make -F type= accept ;charset=
|
||||||
o superfluous blocking for OpenSSL-based SSL connects and multi interface
|
o RESUME_FROM: clarify what ftp uploads do
|
||||||
o TFTP upload
|
o http: handle trailer headers in all chunked responses
|
||||||
o FTP timeouts after file transferred completely
|
o Curl_is_connected: use correct errno
|
||||||
o skip poll() on Interix
|
o Added SSPI build to Watcom makefile
|
||||||
o CURLOPT_CERTINFO memory leak
|
o progress: callback for POSTs less than MAX_INITIAL_POST_SIZE
|
||||||
o sub-second timeouts improvements
|
o linking problem on Fedora 13
|
||||||
o configure fixes for GSSAPI
|
o Link curl and the test apps with -lrt explicitly when necessary
|
||||||
o threaded resolver double free when closing curl handle
|
o chunky parser: only rewind stream internally if needed
|
||||||
o configure fixes for building with the clang compiler
|
o remote-header-name: don't output filename when NULL
|
||||||
o easy interix rate limiting logic
|
o Curl_timeleft: avoid returning "no timeout" by mistake
|
||||||
o curl_multi_remove_handle() caused use after free
|
o timeout: use the correct start value as offset
|
||||||
o TFTP improved error codes
|
o FTP: fix wrong timeout trigger
|
||||||
o TFTP fixed TSIZE handling for uploads
|
o buildconf got better output on failures
|
||||||
o SSL possible double free when reusing curl handle
|
o rtsp: avoid SIGSEGV on malformed header
|
||||||
o alarm()-based DNS timeout bug
|
o LDAP: Support for tunnelling queries through HTTP proxy
|
||||||
o re-used FTP connection multi interface crash
|
o configure's --enable-werror had a bashism
|
||||||
o chunked-encoding with Content-Length: header problem
|
o test565: Don't hardcode IP:PORT
|
||||||
o multi interface HTTP POST over a proxy using PROXYTUNNEL
|
o configure: check for gcrypt if using GnuTLS
|
||||||
o RTSP GET_PARAMETER
|
o configure: don't enable RTMP if the lib detect fails
|
||||||
o timeout after last data chunk was handled
|
o curl_easy_duphandle: clone the c-ares handle correctly
|
||||||
o SFTP download hang
|
o MacOSX-Framework: updates for Snowleopard
|
||||||
o FTP quote commands prefixed with '*' now can fail without aborting
|
o support URL containing colon without trailing port number
|
||||||
|
o parsedate: allow time specified without seconds
|
||||||
|
o curl_easy_escape: don't escape "unreserved" characters
|
||||||
|
o SFTP: avoid downloading negative sizes
|
||||||
|
o Lots of GSS/KRB FTP fixes
|
||||||
|
o TFTP: Work around tftpd-hpa upload bug
|
||||||
|
o libcurl.m4: several fixes
|
||||||
|
o HTTP: remove special case for 416
|
||||||
|
o examples: use example.com in example URLs
|
||||||
|
o globbing: fix crash on unballanced open brace
|
||||||
|
o cmake: build fixed
|
||||||
|
|
||||||
This release includes the following known bugs:
|
This release includes the following known bugs:
|
||||||
|
|
||||||
@@ -54,11 +64,10 @@ This release includes the following known bugs:
|
|||||||
This release would not have looked like this without help, code, reports and
|
This release would not have looked like this without help, code, reports and
|
||||||
advice from friends like these:
|
advice from friends like these:
|
||||||
|
|
||||||
Steven M. Schweda, Yang Tse, Jack Zhang, Tom Donovan, Martin Hager,
|
Kamil Dudka, Ben Greear, Cameron Kaiser, Dan Fandrich, Dirk Manske,
|
||||||
Daniel Fandrich, Patrick Monnerat, Pat Ray, Wesley Miaw, Ben Greear,
|
Guenter Knauf, Julien Chaffraix, Quanah Gibson-Mount, Tor Arntsen,
|
||||||
Ryan Chan, Markus Duft, Andrei Benea, Jacob Moshenko, Daniel Johnson,
|
Peter Pentchev, James Bursa, Fabian Keil, Michal Gorny, Mauro Iorio,
|
||||||
Constantine Sapuntzakis, Douglas Steinwand, Thomas Lopatic, Hauke Duden,
|
Hendrik Visage, Ning Dong, David McCreedy, Patrick Monnerat,
|
||||||
Akos Pasztory, Kenny To, Christopher Conroy, Massimo Callegari,
|
Tim Newsome, Dan Locks, Vlad Ureche, Dimitre Dimitrov
|
||||||
Bob Richmond, Matt Wixson
|
|
||||||
|
|
||||||
Thanks! (and sorry if I forgot to mention someone)
|
Thanks! (and sorry if I forgot to mention someone)
|
||||||
|
17
TODO-RELEASE
17
TODO-RELEASE
@@ -1,4 +1,17 @@
|
|||||||
To be addressed in 7.20.1 (planned release: April 2010)
|
To be addressed in 7.21.2
|
||||||
=========================
|
=========================
|
||||||
|
|
||||||
261 -
|
268 - 3076430 SFTP resume with 4GB file does not work
|
||||||
|
|
||||||
|
271 -
|
||||||
|
|
||||||
|
To be addressed in 7.21.3
|
||||||
|
=========================
|
||||||
|
|
||||||
|
262 - Manual setting of TLS Server Name Indication - use Host:
|
||||||
|
|
||||||
|
263 - Support binding DNS to local interface/IP
|
||||||
|
|
||||||
|
265 - 1. FTP cmd channel and data channel validation
|
||||||
|
|
||||||
|
267 - 2. Cert chain for data channel
|
||||||
|
@@ -2145,6 +2145,7 @@ AC_DEFUN([CURL_CHECK_LIBS_CLOCK_GETTIME_MONOTONIC], [
|
|||||||
else
|
else
|
||||||
LIBS="$curl_cv_gclk_LIBS $curl_cv_save_LIBS"
|
LIBS="$curl_cv_gclk_LIBS $curl_cv_save_LIBS"
|
||||||
fi
|
fi
|
||||||
|
CURL_LIBS="$CURL_LIBS $curl_cv_gclk_LIBS"
|
||||||
AC_MSG_RESULT([$curl_cv_gclk_LIBS])
|
AC_MSG_RESULT([$curl_cv_gclk_LIBS])
|
||||||
ac_cv_func_clock_gettime="yes"
|
ac_cv_func_clock_gettime="yes"
|
||||||
;;
|
;;
|
||||||
|
19
buildconf
19
buildconf
@@ -6,7 +6,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# This software is licensed as described in the file COPYING, which
|
# This software is licensed as described in the file COPYING, which
|
||||||
# you should have received as part of this distribution. The terms
|
# you should have received as part of this distribution. The terms
|
||||||
@@ -33,6 +33,17 @@ die(){
|
|||||||
findtool(){
|
findtool(){
|
||||||
file="$1"
|
file="$1"
|
||||||
|
|
||||||
|
if { echo $file | grep "/" >/dev/null 2>&1; } then
|
||||||
|
# we only check for the explicit file name if the file is given
|
||||||
|
# including a slash. Use ./ for current dir. Previously this would
|
||||||
|
# otherwise always cause findtool to search the local dir first, which
|
||||||
|
# is wrong.
|
||||||
|
if test -f "$file"; then
|
||||||
|
echo "$file"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
old_IFS=$IFS; IFS=':'
|
old_IFS=$IFS; IFS=':'
|
||||||
for path in $PATH
|
for path in $PATH
|
||||||
do
|
do
|
||||||
@@ -237,13 +248,17 @@ fi
|
|||||||
#--------------------------------------------------------------------------
|
#--------------------------------------------------------------------------
|
||||||
# m4 check
|
# m4 check
|
||||||
#
|
#
|
||||||
m4=`${M4:-m4} --version 2>/dev/null|head -n 1`;
|
m4=`(${M4:-m4} --version || ${M4:-gm4} --version) 2>/dev/null | head -n 1`;
|
||||||
m4_version=`echo $m4 | sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//'`
|
m4_version=`echo $m4 | sed -e 's/^.* \([0-9]\)/\1/' -e 's/[a-z]* *$//'`
|
||||||
|
|
||||||
if { echo $m4 | grep "GNU" >/dev/null 2>&1; } then
|
if { echo $m4 | grep "GNU" >/dev/null 2>&1; } then
|
||||||
echo "buildconf: GNU m4 version $m4_version (ok)"
|
echo "buildconf: GNU m4 version $m4_version (ok)"
|
||||||
|
else
|
||||||
|
if test -z "$m4"; then
|
||||||
|
echo "buildconf: m4 version not recognized. You need a GNU m4 installed!"
|
||||||
else
|
else
|
||||||
echo "buildconf: m4 version $m4 found. You need a GNU m4 installed!"
|
echo "buildconf: m4 version $m4 found. You need a GNU m4 installed!"
|
||||||
|
fi
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
352
configure.ac
352
configure.ac
@@ -24,7 +24,7 @@ dnl Process this file with autoconf to produce a configure script.
|
|||||||
AC_PREREQ(2.57)
|
AC_PREREQ(2.57)
|
||||||
|
|
||||||
dnl We don't know the version number "statically" so we use a dash here
|
dnl We don't know the version number "statically" so we use a dash here
|
||||||
AC_INIT([curl], [-], [a suitable curl mailing list => http://curl.haxx.se/mail/])
|
AC_INIT([curl], [-], [a suitable curl mailing list: http://curl.haxx.se/mail/])
|
||||||
|
|
||||||
CURL_OVERRIDE_AUTOCONF
|
CURL_OVERRIDE_AUTOCONF
|
||||||
|
|
||||||
@@ -40,6 +40,7 @@ AM_MAINTAINER_MODE
|
|||||||
CURL_CHECK_OPTION_DEBUG
|
CURL_CHECK_OPTION_DEBUG
|
||||||
CURL_CHECK_OPTION_OPTIMIZE
|
CURL_CHECK_OPTION_OPTIMIZE
|
||||||
CURL_CHECK_OPTION_WARNINGS
|
CURL_CHECK_OPTION_WARNINGS
|
||||||
|
CURL_CHECK_OPTION_WERROR
|
||||||
CURL_CHECK_OPTION_CURLDEBUG
|
CURL_CHECK_OPTION_CURLDEBUG
|
||||||
CURL_CHECK_OPTION_ARES
|
CURL_CHECK_OPTION_ARES
|
||||||
|
|
||||||
@@ -51,26 +52,40 @@ CURL_CHECK_PATH_SEPARATOR_REQUIRED
|
|||||||
CONFIGURE_OPTIONS="\"$ac_configure_args\""
|
CONFIGURE_OPTIONS="\"$ac_configure_args\""
|
||||||
AC_SUBST(CONFIGURE_OPTIONS)
|
AC_SUBST(CONFIGURE_OPTIONS)
|
||||||
|
|
||||||
|
CURL_CFLAG_EXTRAS=""
|
||||||
|
if test X"$want_werror" = Xyes; then
|
||||||
|
CURL_CFLAG_EXTRAS="-Werror"
|
||||||
|
fi
|
||||||
|
AC_SUBST(CURL_CFLAG_EXTRAS)
|
||||||
|
|
||||||
dnl SED is mandatory for configure process and libtool.
|
dnl SED is mandatory for configure process and libtool.
|
||||||
dnl Set it now, allowing it to be changed later.
|
dnl Set it now, allowing it to be changed later.
|
||||||
|
if test -z "$SED"; then
|
||||||
|
dnl allow it to be overridden
|
||||||
AC_PATH_PROG([SED], [sed], [not_found],
|
AC_PATH_PROG([SED], [sed], [not_found],
|
||||||
[$PATH:/usr/bin:/usr/local/bin])
|
[$PATH:/usr/bin:/usr/local/bin])
|
||||||
if test -z "$SED" || test "$SED" = "not_found"; then
|
if test -z "$SED" || test "$SED" = "not_found"; then
|
||||||
AC_MSG_ERROR([sed not found in PATH. Cannot continue without sed.])
|
AC_MSG_ERROR([sed not found in PATH. Cannot continue without sed.])
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
AC_SUBST([SED])
|
AC_SUBST([SED])
|
||||||
|
|
||||||
dnl GREP is mandatory for configure process and libtool.
|
dnl GREP is mandatory for configure process and libtool.
|
||||||
dnl Set it now, allowing it to be changed later.
|
dnl Set it now, allowing it to be changed later.
|
||||||
|
if test -z "$GREP"; then
|
||||||
|
dnl allow it to be overridden
|
||||||
AC_PATH_PROG([GREP], [grep], [not_found],
|
AC_PATH_PROG([GREP], [grep], [not_found],
|
||||||
[$PATH:/usr/bin:/usr/local/bin])
|
[$PATH:/usr/bin:/usr/local/bin])
|
||||||
if test -z "$GREP" || test "$GREP" = "not_found"; then
|
if test -z "$GREP" || test "$GREP" = "not_found"; then
|
||||||
AC_MSG_ERROR([grep not found in PATH. Cannot continue without grep.])
|
AC_MSG_ERROR([grep not found in PATH. Cannot continue without grep.])
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
AC_SUBST([GREP])
|
AC_SUBST([GREP])
|
||||||
|
|
||||||
dnl EGREP is mandatory for configure process and libtool.
|
dnl EGREP is mandatory for configure process and libtool.
|
||||||
dnl Set it now, allowing it to be changed later.
|
dnl Set it now, allowing it to be changed later.
|
||||||
|
if test -z "$EGREP"; then
|
||||||
|
dnl allow it to be overridden
|
||||||
if echo a | ($GREP -E '(a|b)') >/dev/null 2>&1; then
|
if echo a | ($GREP -E '(a|b)') >/dev/null 2>&1; then
|
||||||
AC_MSG_CHECKING([for egrep])
|
AC_MSG_CHECKING([for egrep])
|
||||||
EGREP="$GREP -E"
|
EGREP="$GREP -E"
|
||||||
@@ -79,6 +94,7 @@ else
|
|||||||
AC_PATH_PROG([EGREP], [egrep], [not_found],
|
AC_PATH_PROG([EGREP], [egrep], [not_found],
|
||||||
[$PATH:/usr/bin:/usr/local/bin])
|
[$PATH:/usr/bin:/usr/local/bin])
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
if test -z "$EGREP" || test "$EGREP" = "not_found"; then
|
if test -z "$EGREP" || test "$EGREP" = "not_found"; then
|
||||||
AC_MSG_ERROR([egrep not found in PATH. Cannot continue without egrep.])
|
AC_MSG_ERROR([egrep not found in PATH. Cannot continue without egrep.])
|
||||||
fi
|
fi
|
||||||
@@ -86,11 +102,14 @@ AC_SUBST([EGREP])
|
|||||||
|
|
||||||
dnl AR is mandatory for configure process and libtool.
|
dnl AR is mandatory for configure process and libtool.
|
||||||
dnl This is target dependent, so check it as a tool.
|
dnl This is target dependent, so check it as a tool.
|
||||||
|
if test -z "$AR"; then
|
||||||
|
dnl allow it to be overridden
|
||||||
AC_PATH_TOOL([AR], [ar], [not_found],
|
AC_PATH_TOOL([AR], [ar], [not_found],
|
||||||
[$PATH:/usr/bin:/usr/local/bin])
|
[$PATH:/usr/bin:/usr/local/bin])
|
||||||
if test -z "$AR" || test "$AR" = "not_found"; then
|
if test -z "$AR" || test "$AR" = "not_found"; then
|
||||||
AC_MSG_ERROR([ar not found in PATH. Cannot continue without ar.])
|
AC_MSG_ERROR([ar not found in PATH. Cannot continue without ar.])
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
AC_SUBST([AR])
|
AC_SUBST([AR])
|
||||||
|
|
||||||
AC_SUBST(libext)
|
AC_SUBST(libext)
|
||||||
@@ -121,13 +140,13 @@ AC_SUBST(PKGADD_VENDOR)
|
|||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl initialize all the info variables
|
dnl initialize all the info variables
|
||||||
curl_ssl_msg="no (--with-ssl / --with-gnutls / --with-nss)"
|
curl_ssl_msg="no (--with-{ssl,gnutls,nss,polarssl} )"
|
||||||
curl_ssh_msg="no (--with-libssh2)"
|
curl_ssh_msg="no (--with-libssh2)"
|
||||||
curl_zlib_msg="no (--with-zlib)"
|
curl_zlib_msg="no (--with-zlib)"
|
||||||
curl_krb4_msg="no (--with-krb4*)"
|
curl_krb4_msg="no (--with-krb4*)"
|
||||||
curl_gss_msg="no (--with-gssapi)"
|
curl_gss_msg="no (--with-gssapi)"
|
||||||
curl_spnego_msg="no (--with-spnego)"
|
curl_spnego_msg="no (--with-spnego)"
|
||||||
curl_ares_msg="no (--enable-ares)"
|
curl_res_msg="default (--enable-ares / --enable-threaded-resolver)"
|
||||||
curl_ipv6_msg="no (--enable-ipv6)"
|
curl_ipv6_msg="no (--enable-ipv6)"
|
||||||
curl_idn_msg="no (--with-libidn)"
|
curl_idn_msg="no (--with-libidn)"
|
||||||
curl_manual_msg="no (--enable-manual)"
|
curl_manual_msg="no (--enable-manual)"
|
||||||
@@ -136,6 +155,7 @@ curl_verbose_msg="enabled (--disable-verbose)"
|
|||||||
curl_ldap_msg="no (--enable-ldap / --with-ldap-lib / --with-lber-lib)"
|
curl_ldap_msg="no (--enable-ldap / --with-ldap-lib / --with-lber-lib)"
|
||||||
curl_ldaps_msg="no (--enable-ldaps)"
|
curl_ldaps_msg="no (--enable-ldaps)"
|
||||||
curl_rtsp_msg="no (--enable-rtsp)"
|
curl_rtsp_msg="no (--enable-rtsp)"
|
||||||
|
curl_rtmp_msg="no (--with-librtmp)"
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl Save anything in $LIBS for later
|
dnl Save anything in $LIBS for later
|
||||||
@@ -208,6 +228,9 @@ case $host in
|
|||||||
esac
|
esac
|
||||||
AC_MSG_RESULT($mimpure)
|
AC_MSG_RESULT($mimpure)
|
||||||
AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes)
|
AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes)
|
||||||
|
|
||||||
|
dnl 'STATICLIB' is, in spite of its name, not generic but only for static-only
|
||||||
|
dnl builds on Windows
|
||||||
AM_CONDITIONAL(STATICLIB, false)
|
AM_CONDITIONAL(STATICLIB, false)
|
||||||
|
|
||||||
AC_MSG_CHECKING([if we need BUILDING_LIBCURL])
|
AC_MSG_CHECKING([if we need BUILDING_LIBCURL])
|
||||||
@@ -369,29 +392,11 @@ AC_HELP_STRING([--disable-ldap],[Disable LDAP support]),
|
|||||||
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
||||||
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
||||||
;;
|
;;
|
||||||
*)
|
|
||||||
case $host in
|
|
||||||
*-*-cygwin*)
|
|
||||||
# Force no ldap. config/build process is broken for cygwin
|
|
||||||
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
|
||||||
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
esac
|
|
||||||
;;
|
;;
|
||||||
esac ],[
|
esac ],[
|
||||||
case $host in
|
AC_MSG_RESULT(yes) ]
|
||||||
*-*-cygwin*)
|
|
||||||
# Force no ldap. config/build process is broken for cygwin
|
|
||||||
AC_DEFINE(CURL_DISABLE_LDAP, 1, [to disable LDAP])
|
|
||||||
AC_SUBST(CURL_DISABLE_LDAP, [1])
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
esac ]
|
|
||||||
)
|
)
|
||||||
AC_MSG_CHECKING([whether to support ldaps])
|
AC_MSG_CHECKING([whether to support ldaps])
|
||||||
AC_ARG_ENABLE(ldaps,
|
AC_ARG_ENABLE(ldaps,
|
||||||
@@ -403,20 +408,26 @@ AC_HELP_STRING([--disable-ldaps],[Disable LDAPS support]),
|
|||||||
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
||||||
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
||||||
;;
|
;;
|
||||||
*) if test x$CURL_DISABLE_LDAP = x1 ; then
|
*) if test "x$CURL_DISABLE_LDAP" = "x1" ; then
|
||||||
AC_MSG_RESULT(LDAP support needs to be enabled in order to enable LDAPS support!)
|
AC_MSG_RESULT(LDAP needs to be enabled to support LDAPS)
|
||||||
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
||||||
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
||||||
else
|
else
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_LDAP_SSL, 1, [Use LDAPS implementation])
|
AC_DEFINE(HAVE_LDAP_SSL, 1, [Use LDAPS implementation])
|
||||||
curl_ldaps_msg="enabled"
|
AC_SUBST(HAVE_LDAP_SSL, [1])
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
esac ],
|
esac ],[
|
||||||
|
if test "x$CURL_DISABLE_LDAP" = "x1" ; then
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
AC_DEFINE(CURL_DISABLE_LDAPS, 1, [to disable LDAPS])
|
||||||
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
AC_SUBST(CURL_DISABLE_LDAPS, [1])
|
||||||
|
else
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_LDAP_SSL, 1, [Use LDAPS implementation])
|
||||||
|
AC_SUBST(HAVE_LDAP_SSL, [1])
|
||||||
|
fi ]
|
||||||
)
|
)
|
||||||
|
|
||||||
AC_MSG_CHECKING([whether to support rtsp])
|
AC_MSG_CHECKING([whether to support rtsp])
|
||||||
@@ -557,6 +568,22 @@ AC_HELP_STRING([--disable-smtp],[Disable SMTP support]),
|
|||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([whether to support gopher])
|
||||||
|
AC_ARG_ENABLE(gopher,
|
||||||
|
AC_HELP_STRING([--enable-gopher],[Enable Gopher support])
|
||||||
|
AC_HELP_STRING([--disable-gopher],[Disable Gopher support]),
|
||||||
|
[ case "$enableval" in
|
||||||
|
no)
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_DEFINE(CURL_DISABLE_GOPHER, 1, [to disable Gopher])
|
||||||
|
AC_SUBST(CURL_DISABLE_GOPHER, [1])
|
||||||
|
;;
|
||||||
|
*) AC_MSG_RESULT(yes)
|
||||||
|
;;
|
||||||
|
esac ],
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for built-in manual
|
dnl Check for built-in manual
|
||||||
@@ -751,6 +778,8 @@ ac_cv_func_strcasecmp="no"
|
|||||||
|
|
||||||
CURL_CHECK_LIBS_CONNECT
|
CURL_CHECK_LIBS_CONNECT
|
||||||
|
|
||||||
|
CURL_NETWORK_LIBS=$LIBS
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl In case that function clock_gettime with monotonic timer is available,
|
dnl In case that function clock_gettime with monotonic timer is available,
|
||||||
dnl check for additional required libraries.
|
dnl check for additional required libraries.
|
||||||
@@ -801,13 +830,11 @@ if test x$CURL_DISABLE_LDAP != x1 ; then
|
|||||||
CURL_CHECK_HEADER_LDAP_SSL
|
CURL_CHECK_HEADER_LDAP_SSL
|
||||||
|
|
||||||
if test -z "$LDAPLIBNAME" ; then
|
if test -z "$LDAPLIBNAME" ; then
|
||||||
case $host in
|
if test "$ac_cv_native_windows" = "yes"; then
|
||||||
*-*-cygwin* | *-*-mingw* | *-*-pw32*)
|
dnl Windows uses a single and unique LDAP library name
|
||||||
dnl Windows uses a single and unique OpenLDAP DLL name
|
|
||||||
LDAPLIBNAME="wldap32"
|
LDAPLIBNAME="wldap32"
|
||||||
LBERLIBNAME="no"
|
LBERLIBNAME="no"
|
||||||
;;
|
fi
|
||||||
esac
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "$LDAPLIBNAME" ; then
|
if test "$LDAPLIBNAME" ; then
|
||||||
@@ -849,20 +876,23 @@ if test x$CURL_DISABLE_LDAP != x1 ; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if test x$CURL_DISABLE_LDAP != x1 ; then
|
if test x$CURL_DISABLE_LDAP != x1 ; then
|
||||||
AC_CHECK_FUNCS([ldap_url_parse])
|
AC_CHECK_FUNCS([ldap_url_parse ldap_init_fd])
|
||||||
|
|
||||||
if test "$LDAPLIBNAME" = "wldap32"; then
|
if test "$LDAPLIBNAME" = "wldap32"; then
|
||||||
curl_ldap_msg="enabled (winldap)"
|
curl_ldap_msg="enabled (winldap)"
|
||||||
AC_DEFINE(CURL_LDAP_WIN, 1, [Use W$ LDAP implementation])
|
AC_DEFINE(CURL_LDAP_WIN, 1, [Use Windows LDAP implementation])
|
||||||
case $host in
|
|
||||||
*-*-cygwin* | *-*-pw32*)
|
|
||||||
AC_DEFINE(CURL_LDAP_HYBRID, 1, [W$ LDAP with non-W$ compiler])
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
else
|
else
|
||||||
curl_ldap_msg="enabled (OpenLDAP)"
|
curl_ldap_msg="enabled (OpenLDAP)"
|
||||||
|
if test "x$ac_cv_func_ldap_init_fd" = "xyes"; then
|
||||||
|
AC_DEFINE(USE_OPENLDAP, 1, [Use OpenLDAP-specific code])
|
||||||
|
AC_SUBST(USE_OPENLDAP, [1])
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test x$CURL_DISABLE_LDAPS != x1 ; then
|
||||||
|
curl_ldaps_msg="enabled"
|
||||||
|
fi
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Checks for IPv6
|
dnl Checks for IPv6
|
||||||
@@ -1137,10 +1167,17 @@ if test x"$want_gss" = xyes; then
|
|||||||
],
|
],
|
||||||
[
|
[
|
||||||
dnl not found, check Heimdal or MIT
|
dnl not found, check Heimdal or MIT
|
||||||
|
AC_CHECK_HEADERS([gssapi/gssapi.h], [], [not_mit=1])
|
||||||
AC_CHECK_HEADERS(
|
AC_CHECK_HEADERS(
|
||||||
[gssapi/gssapi.h gssapi/gssapi_generic.h gssapi/gssapi_krb5.h],
|
[gssapi/gssapi_generic.h gssapi/gssapi_krb5.h],
|
||||||
[],
|
[],
|
||||||
[not_mit=1])
|
[not_mit=1],
|
||||||
|
[
|
||||||
|
AC_INCLUDES_DEFAULT
|
||||||
|
#ifdef HAVE_GSSAPI_GSSAPI_H
|
||||||
|
#include <gssapi/gssapi.h>
|
||||||
|
#endif
|
||||||
|
])
|
||||||
if test "x$not_mit" = "x1"; then
|
if test "x$not_mit" = "x1"; then
|
||||||
dnl MIT not found, check for Heimdal
|
dnl MIT not found, check for Heimdal
|
||||||
AC_CHECK_HEADER(gssapi.h,
|
AC_CHECK_HEADER(gssapi.h,
|
||||||
@@ -1699,6 +1736,104 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
|
|
||||||
fi dnl OPENSSL != 1
|
fi dnl OPENSSL != 1
|
||||||
|
|
||||||
|
dnl ---
|
||||||
|
dnl If GnuTLS is enabled, we MUST verify that it uses libgcrypt since
|
||||||
|
dnl curl code relies on that but recent GnuTLS versions can in fact build
|
||||||
|
dnl with different crypto libraries which curl right now cannot handle
|
||||||
|
dnl ---
|
||||||
|
|
||||||
|
if test "$GNUTLS_ENABLED" = "1"; then
|
||||||
|
AC_CHECK_LIB(gcrypt,
|
||||||
|
gcry_control, ,
|
||||||
|
[
|
||||||
|
AC_MSG_ERROR([need GnuTLS built with gcrypt to function with GnuTLS])
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
|
||||||
|
dnl ----------------------------------------------------
|
||||||
|
dnl check for PolarSSL
|
||||||
|
dnl ----------------------------------------------------
|
||||||
|
|
||||||
|
dnl Default to compiler & linker defaults for PolarSSL files & libraries.
|
||||||
|
OPT_POLARSSL=no
|
||||||
|
|
||||||
|
_cppflags=$CPPFLAGS
|
||||||
|
_ldflags=$LDFLAGS
|
||||||
|
AC_ARG_WITH(polarssl,dnl
|
||||||
|
AC_HELP_STRING([--with-polarssl=PATH],[where to look for PolarSSL, PATH points to the installation root (default: /usr/local/)])
|
||||||
|
AC_HELP_STRING([--without-polarssl], [disable PolarSSL detection]),
|
||||||
|
OPT_POLARSSL=$withval)
|
||||||
|
|
||||||
|
if test "$OPENSSL_ENABLED" != "1"; then
|
||||||
|
|
||||||
|
if test X"$OPT_POLARSSL" != Xno; then
|
||||||
|
|
||||||
|
if test "$OPT_POLARSSL" = "yes"; then
|
||||||
|
OPT_POLARSSL=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z "$OPT_POLARSSL" ; then
|
||||||
|
dnl check for lib first without setting any new path
|
||||||
|
|
||||||
|
AC_CHECK_LIB(polarssl, havege_init,
|
||||||
|
dnl libpolarssl found, set the variable
|
||||||
|
[
|
||||||
|
AC_DEFINE(USE_POLARSSL, 1, [if PolarSSL is enabled])
|
||||||
|
AC_SUBST(USE_POLARSSL, [1])
|
||||||
|
POLARSSL_ENABLED=1
|
||||||
|
USE_POLARSSL="yes"
|
||||||
|
curl_ssl_msg="enabled (PolarSSL)"
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "x$USE_POLARSSL" != "xyes"; then
|
||||||
|
dnl add the path and test again
|
||||||
|
addld=-L$OPT_POLARSSL/lib$libsuff
|
||||||
|
addcflags=-I$OPT_POLARSSL/include
|
||||||
|
polarssllib=$OPT_POLARSSL/lib$libsuff
|
||||||
|
|
||||||
|
LDFLAGS="$LDFLAGS $addld"
|
||||||
|
if test "$addcflags" != "-I/usr/include"; then
|
||||||
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_CHECK_LIB(polarssl, ssl_init,
|
||||||
|
[
|
||||||
|
AC_DEFINE(USE_POLARSSL, 1, [if PolarSSL is enabled])
|
||||||
|
AC_SUBST(USE_POLARSSL, [1])
|
||||||
|
POLARSSL_ENABLED=1
|
||||||
|
USE_POLARSSL="yes"
|
||||||
|
curl_ssl_msg="enabled (PolarSSL)"
|
||||||
|
],
|
||||||
|
[
|
||||||
|
CPPFLAGS=$_cppflags
|
||||||
|
LDFLAGS=$_ldflags
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "x$USE_POLARSSL" = "xyes"; then
|
||||||
|
AC_MSG_NOTICE([detected PolarSSL])
|
||||||
|
|
||||||
|
CURL_LIBS="$CURL_LIBS -lpolarssl"
|
||||||
|
LIBS="$LIBS -lpolarssl"
|
||||||
|
|
||||||
|
if test -n "$polarssllib"; then
|
||||||
|
dnl when shared libs were found in a path that the run-time
|
||||||
|
dnl linker doesn't search through, we need to add it to
|
||||||
|
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
||||||
|
dnl due to this
|
||||||
|
|
||||||
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib"
|
||||||
|
export LD_LIBRARY_PATH
|
||||||
|
AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi dnl PolarSSL not disabled
|
||||||
|
|
||||||
|
fi dnl OPENSSL != 1
|
||||||
|
|
||||||
dnl ----------------------------------------------------
|
dnl ----------------------------------------------------
|
||||||
dnl NSS. Only check if GnuTLS and OpenSSL are not enabled
|
dnl NSS. Only check if GnuTLS and OpenSSL are not enabled
|
||||||
dnl ----------------------------------------------------
|
dnl ----------------------------------------------------
|
||||||
@@ -1795,9 +1930,9 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then
|
|||||||
|
|
||||||
fi dnl OPENSSL != 1 -a GNUTLS_ENABLED != 1
|
fi dnl OPENSSL != 1 -a GNUTLS_ENABLED != 1
|
||||||
|
|
||||||
if test "x$OPENSSL_ENABLED$GNUTLS_ENABLED$NSS_ENABLED" = "x"; then
|
if test "x$OPENSSL_ENABLED$GNUTLS_ENABLED$NSS_ENABLED$POLARSSL_ENABLED" = "x"; then
|
||||||
AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.])
|
AC_MSG_WARN([SSL disabled, you will not be able to use HTTPS, FTPS, NTLM and more.])
|
||||||
AC_MSG_WARN([Use --with-ssl, --with-gnutls or --with-nss to address this.])
|
AC_MSG_WARN([Use --with-ssl, --with-gnutls, --with-polarssl or --with-nss to address this.])
|
||||||
else
|
else
|
||||||
# SSL is enabled, genericly
|
# SSL is enabled, genericly
|
||||||
AC_SUBST(SSL_ENABLED)
|
AC_SUBST(SSL_ENABLED)
|
||||||
@@ -1882,7 +2017,10 @@ if test X"$OPT_LIBSSH2" != Xno; then
|
|||||||
dnl to prevent further configure tests to fail due to this
|
dnl to prevent further configure tests to fail due to this
|
||||||
|
|
||||||
dnl libssh2_version is a post 1.0 addition
|
dnl libssh2_version is a post 1.0 addition
|
||||||
AC_CHECK_FUNCS( libssh2_version )
|
dnl libssh2_init and libssh2_exit were added in 1.2.5
|
||||||
|
dnl libssh2_scp_send64 was added in 1.2.6
|
||||||
|
AC_CHECK_FUNCS( libssh2_version libssh2_init libssh2_exit \
|
||||||
|
libssh2_scp_send64 )
|
||||||
|
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
@@ -1896,6 +2034,80 @@ if test X"$OPT_LIBSSH2" != Xno; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
dnl **********************************************************************
|
||||||
|
dnl Check for the presence of LIBRTMP libraries and headers
|
||||||
|
dnl **********************************************************************
|
||||||
|
|
||||||
|
dnl Default to compiler & linker defaults for LIBRTMP files & libraries.
|
||||||
|
OPT_LIBRTMP=off
|
||||||
|
AC_ARG_WITH(librtmp,dnl
|
||||||
|
AC_HELP_STRING([--with-librtmp=PATH],[Where to look for librtmp, PATH points to the LIBRTMP installation (default: /usr/local/lib); when possible, set the PKG_CONFIG_PATH environment variable instead of using this option])
|
||||||
|
AC_HELP_STRING([--without-librtmp], [disable LIBRTMP]),
|
||||||
|
OPT_LIBRTMP=$withval)
|
||||||
|
|
||||||
|
if test X"$OPT_LIBRTMP" != Xno; then
|
||||||
|
dnl backup the pre-librtmp variables
|
||||||
|
CLEANLDFLAGS="$LDFLAGS"
|
||||||
|
CLEANCPPFLAGS="$CPPFLAGS"
|
||||||
|
CLEANLIBS="$LIBS"
|
||||||
|
|
||||||
|
case "$OPT_LIBRTMP" in
|
||||||
|
yes)
|
||||||
|
dnl --with-librtmp (without path) used
|
||||||
|
CURL_CHECK_PKGCONFIG(librtmp)
|
||||||
|
|
||||||
|
if test "$PKGCONFIG" != "no" ; then
|
||||||
|
LIB_RTMP=`$PKGCONFIG --libs-only-l librtmp`
|
||||||
|
LD_RTMP=`$PKGCONFIG --libs-only-L librtmp`
|
||||||
|
CPP_RTMP=`$PKGCONFIG --cflags-only-I librtmp`
|
||||||
|
version=`$PKGCONFIG --modversion librtmp`
|
||||||
|
DIR_RTMP=`echo $LD_RTMP | $SED -e 's/-L//'`
|
||||||
|
fi
|
||||||
|
|
||||||
|
;;
|
||||||
|
off)
|
||||||
|
dnl no --with-librtmp option given, just check default places
|
||||||
|
LIB_RTMP="-lrtmp"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
dnl use the given --with-librtmp spot
|
||||||
|
PREFIX_RTMP=$OPT_LIBRTMP
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
dnl if given with a prefix, we set -L and -I based on that
|
||||||
|
if test -n "$PREFIX_RTMP"; then
|
||||||
|
LD_RTMP=-L${PREFIX_RTMP}/lib$libsuff
|
||||||
|
CPP_RTMP=-I${PREFIX_RTMP}/include
|
||||||
|
DIR_RTMP=${PREFIX_RTMP}/lib$libsuff
|
||||||
|
fi
|
||||||
|
|
||||||
|
LDFLAGS="$LDFLAGS $LD_RTMP"
|
||||||
|
CPPFLAGS="$CPPFLAGS $CPP_RTMP"
|
||||||
|
LIBS="$LIBS $LIB_RTMP"
|
||||||
|
|
||||||
|
AC_CHECK_LIB(rtmp, RTMP_Init,
|
||||||
|
[
|
||||||
|
AC_CHECK_HEADERS(librtmp/rtmp.h,
|
||||||
|
curl_rtmp_msg="enabled (librtmp)"
|
||||||
|
LIBRTMP_ENABLED=1
|
||||||
|
AC_DEFINE(USE_LIBRTMP, 1, [if librtmp is in use])
|
||||||
|
AC_SUBST(USE_LIBRTMP, [1])
|
||||||
|
)
|
||||||
|
],
|
||||||
|
dnl not found, revert back to clean variables
|
||||||
|
LDFLAGS=$CLEANLDFLAGS
|
||||||
|
CPPFLAGS=$CLEANCPPFLAGS
|
||||||
|
LIBS=$CLEANLIBS
|
||||||
|
)
|
||||||
|
|
||||||
|
if test X"$OPT_LIBRTMP" != Xoff &&
|
||||||
|
test "$LIBRTMP_ENABLED" != "1"; then
|
||||||
|
AC_MSG_ERROR([librtmp libs and/or directories were not found where specified!])
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the presence of IDN libraries and headers
|
dnl Check for the presence of IDN libraries and headers
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -2282,6 +2494,35 @@ AM_CONDITIONAL(USE_MANUAL, test x"$USE_MANUAL" = x1)
|
|||||||
CURL_CHECK_LIB_ARES
|
CURL_CHECK_LIB_ARES
|
||||||
AM_CONDITIONAL(USE_EMBEDDED_ARES, test x$embedded_ares = xyes)
|
AM_CONDITIONAL(USE_EMBEDDED_ARES, test x$embedded_ares = xyes)
|
||||||
|
|
||||||
|
if test "x$enable_shared" = "xyes"; then
|
||||||
|
build_libhostname=yes
|
||||||
|
else
|
||||||
|
build_libhostname=no
|
||||||
|
fi
|
||||||
|
AM_CONDITIONAL(BUILD_LIBHOSTNAME, test x$build_libhostname = xyes)
|
||||||
|
|
||||||
|
CURL_CHECK_OPTION_THREADED_RESOLVER
|
||||||
|
|
||||||
|
if test "x$want_thres" = xyes && test "x$want_ares" = xyes; then
|
||||||
|
AC_MSG_ERROR(
|
||||||
|
[Options --enable-threaded-resolver and --enable-ares are mutually exclusive])
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$want_thres" = "yes"; then
|
||||||
|
AC_CHECK_HEADER(pthread.h,
|
||||||
|
[ AC_DEFINE(HAVE_PTHREAD_H, 1, [if you have <pthread.h>])
|
||||||
|
save_CFLAGS="$CFLAGS"
|
||||||
|
CFLAGS="$CFLAGS -pthread"
|
||||||
|
AC_CHECK_LIB(pthread, pthread_create,
|
||||||
|
[ AC_MSG_NOTICE([using POSIX threaded DNS lookup])
|
||||||
|
AC_DEFINE(USE_THREADS_POSIX, 1, [if you want POSIX threaded DNS lookup])
|
||||||
|
USE_THREADS_POSIX=1
|
||||||
|
curl_res_msg="threaded"
|
||||||
|
],
|
||||||
|
[ CFLAGS="$save_CFLAGS"])
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
|
||||||
dnl ************************************************************
|
dnl ************************************************************
|
||||||
dnl disable verbose text strings
|
dnl disable verbose text strings
|
||||||
dnl
|
dnl
|
||||||
@@ -2452,10 +2693,15 @@ LIBCURL_LIBS=$LIBS
|
|||||||
AC_SUBST(LIBCURL_LIBS)
|
AC_SUBST(LIBCURL_LIBS)
|
||||||
AC_SUBST(CURL_LIBS)
|
AC_SUBST(CURL_LIBS)
|
||||||
AC_SUBST(TEST_SERVER_LIBS)
|
AC_SUBST(TEST_SERVER_LIBS)
|
||||||
|
AC_SUBST(CURL_NETWORK_LIBS)
|
||||||
LIBS=$ALL_LIBS dnl LIBS is a magic variable that's used for every link
|
LIBS=$ALL_LIBS dnl LIBS is a magic variable that's used for every link
|
||||||
|
|
||||||
AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes)
|
AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes)
|
||||||
|
|
||||||
|
dnl yes or no
|
||||||
|
ENABLE_SHARED="$enable_shared"
|
||||||
|
AC_SUBST(ENABLE_SHARED)
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl For keeping supported features and protocols also in pkg-config file
|
dnl For keeping supported features and protocols also in pkg-config file
|
||||||
dnl since it is more cross-compile frient than curl-config
|
dnl since it is more cross-compile frient than curl-config
|
||||||
@@ -2475,7 +2721,7 @@ fi
|
|||||||
if test "x$HAVE_LIBZ" = "x1"; then
|
if test "x$HAVE_LIBZ" = "x1"; then
|
||||||
SUPPORT_FEATURES="$SUPPORT_FEATURES libz"
|
SUPPORT_FEATURES="$SUPPORT_FEATURES libz"
|
||||||
fi
|
fi
|
||||||
if test "x$USE_ARES" = "x1"; then
|
if test "x$USE_ARES" = "x1" -o "x$USE_THREADS_POSIX" = "x1"; then
|
||||||
SUPPORT_FEATURES="$SUPPORT_FEATURES AsynchDNS"
|
SUPPORT_FEATURES="$SUPPORT_FEATURES AsynchDNS"
|
||||||
fi
|
fi
|
||||||
if test "x$IDN_ENABLED" = "x1"; then
|
if test "x$IDN_ENABLED" = "x1"; then
|
||||||
@@ -2484,7 +2730,8 @@ fi
|
|||||||
if test "x$USE_WINDOWS_SSPI" = "x1"; then
|
if test "x$USE_WINDOWS_SSPI" = "x1"; then
|
||||||
SUPPORT_FEATURES="$SUPPORT_FEATURES SSPI"
|
SUPPORT_FEATURES="$SUPPORT_FEATURES SSPI"
|
||||||
fi
|
fi
|
||||||
if test "x$USE_SSLEAY" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" -o "x$GNUTLS_ENABLED" = "x1"; then
|
if test "x$USE_SSLEAY" = "x1" -o "x$USE_WINDOWS_SSPI" = "x1" \
|
||||||
|
-o "x$GNUTLS_ENABLED" = "x1" -o "x$NSS_ENABLED" = "x1"; then
|
||||||
SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM"
|
SUPPORT_FEATURES="$SUPPORT_FEATURES NTLM"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -2511,16 +2758,22 @@ if test "x$CURL_DISABLE_TELNET" != "x1"; then
|
|||||||
fi
|
fi
|
||||||
if test "x$CURL_DISABLE_LDAP" != "x1"; then
|
if test "x$CURL_DISABLE_LDAP" != "x1"; then
|
||||||
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS LDAP"
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS LDAP"
|
||||||
fi
|
|
||||||
if test "x$CURL_DISABLE_LDAPS" != "x1"; then
|
if test "x$CURL_DISABLE_LDAPS" != "x1"; then
|
||||||
|
if (test "x$USE_OPENLDAP" = "x1" && test "x$SSL_ENABLED" = "x1") ||
|
||||||
|
(test "x$USE_OPENLDAP" != "x1" && test "x$HAVE_LDAP_SSL" = "x1"); then
|
||||||
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS LDAPS"
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS LDAPS"
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
if test "x$CURL_DISABLE_DICT" != "x1"; then
|
if test "x$CURL_DISABLE_DICT" != "x1"; then
|
||||||
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS DICT"
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS DICT"
|
||||||
fi
|
fi
|
||||||
if test "x$CURL_DISABLE_TFTP" != "x1"; then
|
if test "x$CURL_DISABLE_TFTP" != "x1"; then
|
||||||
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS TFTP"
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS TFTP"
|
||||||
fi
|
fi
|
||||||
|
if test "x$CURL_DISABLE_GOPHER" != "x1"; then
|
||||||
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS GOPHER"
|
||||||
|
fi
|
||||||
if test "x$CURL_DISABLE_POP3" != "x1"; then
|
if test "x$CURL_DISABLE_POP3" != "x1"; then
|
||||||
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS POP3"
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS POP3"
|
||||||
if test "x$SSL_ENABLED" = "x1"; then
|
if test "x$SSL_ENABLED" = "x1"; then
|
||||||
@@ -2546,6 +2799,9 @@ fi
|
|||||||
if test "x$CURL_DISABLE_RTSP" != "x1"; then
|
if test "x$CURL_DISABLE_RTSP" != "x1"; then
|
||||||
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS RTSP"
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS RTSP"
|
||||||
fi
|
fi
|
||||||
|
if test "x$USE_LIBRTMP" = "x1"; then
|
||||||
|
SUPPORT_PROTOCOLS="$SUPPORT_PROTOCOLS RTMP"
|
||||||
|
fi
|
||||||
|
|
||||||
dnl replace spaces with newlines
|
dnl replace spaces with newlines
|
||||||
dnl sort the lines
|
dnl sort the lines
|
||||||
@@ -2565,6 +2821,7 @@ squeeze LIBS
|
|||||||
squeeze CURL_LIBS
|
squeeze CURL_LIBS
|
||||||
squeeze LIBCURL_LIBS
|
squeeze LIBCURL_LIBS
|
||||||
squeeze TEST_SERVER_LIBS
|
squeeze TEST_SERVER_LIBS
|
||||||
|
squeeze CURL_NETWORK_LIBS
|
||||||
|
|
||||||
squeeze SUPPORT_FEATURES
|
squeeze SUPPORT_FEATURES
|
||||||
squeeze SUPPORT_PROTOCOLS
|
squeeze SUPPORT_PROTOCOLS
|
||||||
@@ -2617,7 +2874,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl:
|
|||||||
krb4 support: ${curl_krb4_msg}
|
krb4 support: ${curl_krb4_msg}
|
||||||
GSSAPI support: ${curl_gss_msg}
|
GSSAPI support: ${curl_gss_msg}
|
||||||
SPNEGO support: ${curl_spnego_msg}
|
SPNEGO support: ${curl_spnego_msg}
|
||||||
c-ares support: ${curl_ares_msg}
|
resolver: ${curl_res_msg}
|
||||||
ipv6 support: ${curl_ipv6_msg}
|
ipv6 support: ${curl_ipv6_msg}
|
||||||
IDN support: ${curl_idn_msg}
|
IDN support: ${curl_idn_msg}
|
||||||
Build libcurl: Shared=${enable_shared}, Static=${enable_static}
|
Build libcurl: Shared=${enable_shared}, Static=${enable_static}
|
||||||
@@ -2629,6 +2886,7 @@ AC_MSG_NOTICE([Configured to build curl/libcurl:
|
|||||||
LDAP support: ${curl_ldap_msg}
|
LDAP support: ${curl_ldap_msg}
|
||||||
LDAPS support: ${curl_ldaps_msg}
|
LDAPS support: ${curl_ldaps_msg}
|
||||||
RTSP support: ${curl_rtsp_msg}
|
RTSP support: ${curl_rtsp_msg}
|
||||||
|
RTMP support: ${curl_rtmp_msg}
|
||||||
Protocols: ${SUPPORT_PROTOCOLS}
|
Protocols: ${SUPPORT_PROTOCOLS}
|
||||||
])
|
])
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 2001 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 2001 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# This software is licensed as described in the file COPYING, which
|
# This software is licensed as described in the file COPYING, which
|
||||||
# you should have received as part of this distribution. The terms
|
# you should have received as part of this distribution. The terms
|
||||||
@@ -32,6 +32,7 @@ Usage: curl-config [OPTION]
|
|||||||
|
|
||||||
Available values for OPTION include:
|
Available values for OPTION include:
|
||||||
|
|
||||||
|
--built-shared says 'yes' if libcurl was built shared
|
||||||
--ca ca bundle install path
|
--ca ca bundle install path
|
||||||
--cc compiler
|
--cc compiler
|
||||||
--cflags pre-processor and compiler flags
|
--cflags pre-processor and compiler flags
|
||||||
@@ -64,6 +65,10 @@ while test $# -gt 0; do
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
|
--built-shared)
|
||||||
|
echo @ENABLE_SHARED@
|
||||||
|
;;
|
||||||
|
|
||||||
--ca)
|
--ca)
|
||||||
echo "@CURL_CA_BUNDLE@"
|
echo "@CURL_CA_BUNDLE@"
|
||||||
;;
|
;;
|
||||||
@@ -87,6 +92,7 @@ while test $# -gt 0; do
|
|||||||
echo "$protocol"
|
echo "$protocol"
|
||||||
done
|
done
|
||||||
;;
|
;;
|
||||||
|
|
||||||
--version)
|
--version)
|
||||||
echo libcurl @VERSION@
|
echo libcurl @VERSION@
|
||||||
exit 0
|
exit 0
|
||||||
|
2
docs/.gitignore
vendored
Normal file
2
docs/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
*.html
|
||||||
|
*.pdf
|
@@ -29,9 +29,11 @@
|
|||||||
2.11 Test Cases
|
2.11 Test Cases
|
||||||
|
|
||||||
3. Pushing Out Your Changes
|
3. Pushing Out Your Changes
|
||||||
|
3.1 Write Access to git Repository
|
||||||
3.2 How To Make a Patch with git
|
3.2 How To Make a Patch with git
|
||||||
3.3 How To Make a Patch without git
|
3.3 How To Make a Patch without git
|
||||||
3.4 How to get your changes into the main sources
|
3.4 How to get your changes into the main sources
|
||||||
|
3.5 Write good commit messages
|
||||||
|
|
||||||
==============================================================================
|
==============================================================================
|
||||||
|
|
||||||
@@ -114,7 +116,7 @@
|
|||||||
|
|
||||||
2.4 Line Lengths
|
2.4 Line Lengths
|
||||||
|
|
||||||
We try to keep source lines shorter than 80 columns.
|
We write source lines shorter than 80 columns.
|
||||||
|
|
||||||
2.5 General Style
|
2.5 General Style
|
||||||
|
|
||||||
@@ -197,7 +199,8 @@
|
|||||||
git commit [file]
|
git commit [file]
|
||||||
|
|
||||||
As usual, group your commits so that you commit all changes that at once that
|
As usual, group your commits so that you commit all changes that at once that
|
||||||
constitutes a logical change.
|
constitutes a logical change. See also section "3.5 Write good commit
|
||||||
|
messages".
|
||||||
|
|
||||||
Once you have done all your commits and you're happy with what you see, you
|
Once you have done all your commits and you're happy with what you see, you
|
||||||
can make patches out of your changes that are suitable for mailing:
|
can make patches out of your changes that are suitable for mailing:
|
||||||
@@ -255,3 +258,22 @@
|
|||||||
5. If you've followed the above mentioned paragraphs and your patch still
|
5. If you've followed the above mentioned paragraphs and your patch still
|
||||||
hasn't been incorporated after some weeks, consider resubmitting it to the
|
hasn't been incorporated after some weeks, consider resubmitting it to the
|
||||||
list.
|
list.
|
||||||
|
|
||||||
|
3.5 Write good commit messages
|
||||||
|
|
||||||
|
A short guide to how to do fine commit messages in the curl project.
|
||||||
|
|
||||||
|
---- start ----
|
||||||
|
[area]: [short line describing the main effect]
|
||||||
|
|
||||||
|
[separate the above single line from the rest with an empty line]
|
||||||
|
|
||||||
|
[full description, no wider than 72 columns that describe as much as
|
||||||
|
possible as to why this change is made, and possibly what things
|
||||||
|
it fixes and everything else that is related]
|
||||||
|
---- stop ----
|
||||||
|
|
||||||
|
Don't forget to use commit --author="" if you commit someone else's work,
|
||||||
|
and make sure that you have your own user and email setup correctly in git
|
||||||
|
before you commit
|
||||||
|
|
||||||
|
155
docs/FAQ
155
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: Nov 7, 2009 (http://curl.haxx.se/docs/faq.html)
|
Updated: October 6, 2010 (http://curl.haxx.se/docs/faq.html)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -20,6 +20,8 @@ FAQ
|
|||||||
1.10 How many are using curl?
|
1.10 How many are using curl?
|
||||||
1.11 Why don't you update ca-bundle.crt
|
1.11 Why don't you update ca-bundle.crt
|
||||||
1.12 I have a problem who can I chat with?
|
1.12 I have a problem who can I chat with?
|
||||||
|
1.13 curl's ECCN number?
|
||||||
|
1.14 How do I submit my patch?
|
||||||
|
|
||||||
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
|
||||||
@@ -48,6 +50,7 @@ FAQ
|
|||||||
3.16 What certificates do I need when I use SSL?
|
3.16 What certificates do I need when I use SSL?
|
||||||
3.17 How do I list the root dir of an FTP server?
|
3.17 How do I list the root dir of an FTP server?
|
||||||
3.18 Can I use curl to send a POST/PUT and not wait for a response?
|
3.18 Can I use curl to send a POST/PUT and not wait for a response?
|
||||||
|
3.19 How do I get HTTP from a host using a specific IP address?
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
@@ -74,6 +77,7 @@ FAQ
|
|||||||
4.16 My HTTP POST or PUT requests are slow!
|
4.16 My HTTP POST or PUT requests are slow!
|
||||||
4.17 Non-functional connect timeouts on Windows
|
4.17 Non-functional connect timeouts on Windows
|
||||||
4.18 file:// URLs containing drive letters (Windows, NetWare)
|
4.18 file:// URLs containing drive letters (Windows, NetWare)
|
||||||
|
4.19 Why doesn't cURL return an error when the network cable is unplugged?
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
5.1 Is libcurl thread-safe?
|
5.1 Is libcurl thread-safe?
|
||||||
@@ -83,7 +87,7 @@ FAQ
|
|||||||
5.5 Does CURLOPT_WRITEDATA and CURLOPT_READDATA work on win32 ?
|
5.5 Does CURLOPT_WRITEDATA and CURLOPT_READDATA work on win32 ?
|
||||||
5.6 What about Keep-Alive or persistent connections?
|
5.6 What about Keep-Alive or persistent connections?
|
||||||
5.7 Link errors when building libcurl on Windows!
|
5.7 Link errors when building libcurl on Windows!
|
||||||
5.8 libcurl.so.3: open failed: No such file or directory
|
5.8 libcurl.so.X: open failed: No such file or directory
|
||||||
5.9 How does libcurl resolve host names?
|
5.9 How does libcurl resolve host names?
|
||||||
5.10 How do I prevent libcurl from writing the response to stdout?
|
5.10 How do I prevent libcurl from writing the response to stdout?
|
||||||
5.11 How do I make libcurl not receive the whole HTTP response?
|
5.11 How do I make libcurl not receive the whole HTTP response?
|
||||||
@@ -122,8 +126,10 @@ FAQ
|
|||||||
|
|
||||||
libcurl
|
libcurl
|
||||||
|
|
||||||
A free and easy-to-use client-side URL transfer library, supporting FTP,
|
A free and easy-to-use client-side URL transfer library, supporting DICT,
|
||||||
FTPS, HTTP, HTTPS, SCP, SFTP, TFTP, TELNET, DICT, FILE, LDAP and LDAPS.
|
FILE, FTP, FTPS, GOPHER, HTTP, HTTPS, IMAP, IMAPS, LDAP, LDAPS, POP3,
|
||||||
|
POP3S, RTMP, RTSP, SCP, SFTP, SMTP, SMTPS, TELNET and TFTP.
|
||||||
|
|
||||||
libcurl supports HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading,
|
libcurl supports HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading,
|
||||||
kerberos, HTTP form based upload, proxies, cookies, user+password
|
kerberos, HTTP form based upload, proxies, cookies, user+password
|
||||||
authentication, file transfer resume, http proxy tunneling and more!
|
authentication, file transfer resume, http proxy tunneling and more!
|
||||||
@@ -141,9 +147,8 @@ FAQ
|
|||||||
|
|
||||||
A command line tool for getting or sending files using URL syntax.
|
A command line tool for getting or sending files using URL syntax.
|
||||||
|
|
||||||
Since curl uses libcurl, it supports a range of common Internet protocols,
|
Since curl uses libcurl, curl supports the same wide range of common
|
||||||
currently including HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, LDAP, LDAPS,
|
Internet protocols that libcurl does.
|
||||||
DICT, TELNET and FILE.
|
|
||||||
|
|
||||||
We pronounce curl and cURL with an initial k sound: [kurl].
|
We pronounce curl and cURL with an initial k sound: [kurl].
|
||||||
|
|
||||||
@@ -307,9 +312,9 @@ FAQ
|
|||||||
as used by numerous applications that include libcurl binaries in their
|
as used by numerous applications that include libcurl binaries in their
|
||||||
distribution packages (like Adobe Acrobat Reader and Google Earth).
|
distribution packages (like Adobe Acrobat Reader and Google Earth).
|
||||||
|
|
||||||
More than 90 known named companies use curl in commercial environments and
|
More than a hundred known named companies use curl in commercial
|
||||||
products. More than 100 known named open source projects depend on
|
environments and products and more than a hundred known named open source
|
||||||
(lib)curl.
|
projects depend on (lib)curl.
|
||||||
|
|
||||||
In a poll on the curl web site mid-2005, more than 50% of the 300+ answers
|
In a poll on the curl web site mid-2005, more than 50% of the 300+ answers
|
||||||
estimated a user base of one million users or more.
|
estimated a user base of one million users or more.
|
||||||
@@ -319,6 +324,12 @@ FAQ
|
|||||||
based web servers. A guess is that a fair amount of these Linux
|
based web servers. A guess is that a fair amount of these Linux
|
||||||
installations have curl installed.
|
installations have curl installed.
|
||||||
|
|
||||||
|
The Debian project maintains statistics on packages installed by people
|
||||||
|
who have voluntarily run their package counting application. In mid-2010,
|
||||||
|
libcurl3 was installed on over 55000 such systems (62% of reporting systems)
|
||||||
|
and was one of the 320 most popular installed packages (out of about 107000
|
||||||
|
possible packages).
|
||||||
|
|
||||||
All this taken together, there is no doubt that there are millions of
|
All this taken together, there is no doubt that there are millions of
|
||||||
(lib)curl users.
|
(lib)curl users.
|
||||||
|
|
||||||
@@ -327,6 +338,7 @@ FAQ
|
|||||||
http://curl.haxx.se/libcurl/using/apps.html
|
http://curl.haxx.se/libcurl/using/apps.html
|
||||||
http://counter.li.org/estimates.php
|
http://counter.li.org/estimates.php
|
||||||
http://news.netcraft.com/archives/2005/03/14/fedora_makes_rapid_progress.html
|
http://news.netcraft.com/archives/2005/03/14/fedora_makes_rapid_progress.html
|
||||||
|
http://qa.debian.org/popcon.php?package=curl
|
||||||
|
|
||||||
1.11 Why don't you update ca-bundle.crt
|
1.11 Why don't you update ca-bundle.crt
|
||||||
|
|
||||||
@@ -357,6 +369,41 @@ FAQ
|
|||||||
IRC network irc.freenode.net. If you're polite and nice, chances are big
|
IRC network irc.freenode.net. If you're polite and nice, chances are big
|
||||||
that you can get -- or provide -- help instantly.
|
that you can get -- or provide -- help instantly.
|
||||||
|
|
||||||
|
1.13 curl's ECCN number?
|
||||||
|
|
||||||
|
The US government restricts exports of software that contains or uses
|
||||||
|
cryptography. When doing so, the Export Control Classification Number (ECCN)
|
||||||
|
is used to identify the level of export control etc.
|
||||||
|
|
||||||
|
ASF gives a good explanation at http://www.apache.org/dev/crypto.html
|
||||||
|
|
||||||
|
We believe curl's number might be ECCN 5D002, another possibility is
|
||||||
|
5D992. It seems necessary to write them, asking to confirm.
|
||||||
|
|
||||||
|
Comprehensible explanations of the meaning of such numbers and how to
|
||||||
|
obtain them (resp.) are here
|
||||||
|
|
||||||
|
http://www.bis.doc.gov/licensing/exportingbasics.htm
|
||||||
|
http://www.bis.doc.gov/licensing/do_i_needaneccn.html
|
||||||
|
|
||||||
|
An incomprehensible description of the two numbers above is here
|
||||||
|
http://www.access.gpo.gov/bis/ear/pdf/ccl5-pt2.pdf
|
||||||
|
|
||||||
|
1.14 How do I submit my patch?
|
||||||
|
|
||||||
|
When you have made a patch or a change of whatever sort, and want to submit
|
||||||
|
that to the project, there are a few different ways we prefer:
|
||||||
|
|
||||||
|
o send a patch to the curl-library mailing list. We're many subscribers
|
||||||
|
there and there are lots of people who can review patches, comment on them
|
||||||
|
and "receive" them properly.
|
||||||
|
|
||||||
|
o if your patch changes or fixes a bug, you can also opt to submit a bug
|
||||||
|
report in the bug tracker and attach your patch there. There are less
|
||||||
|
people involved there.
|
||||||
|
|
||||||
|
Lots of more details are found in the CONTRIBUTE and INTERNALS docs.
|
||||||
|
|
||||||
|
|
||||||
2. Install Related Problems
|
2. Install Related Problems
|
||||||
|
|
||||||
@@ -399,10 +446,10 @@ FAQ
|
|||||||
|
|
||||||
2.2 Does curl work/build with other SSL libraries?
|
2.2 Does curl work/build with other SSL libraries?
|
||||||
|
|
||||||
Curl has been written to use OpenSSL, GnuTLS, yassl or NSS, although there
|
Curl has been written to use OpenSSL, GnuTLS, yassl, NSS or PolarSSL,
|
||||||
should not be many problems using a different library. If anyone does "port"
|
although there should not be many problems using a different library. If
|
||||||
curl to use a different SSL library, we are of course very interested in
|
anyone does "port" curl to use a different SSL library, we are of course
|
||||||
getting the patch!
|
very interested in getting the patch!
|
||||||
|
|
||||||
2.3 Where can I find a copy of LIBEAY32.DLL?
|
2.3 Where can I find a copy of LIBEAY32.DLL?
|
||||||
|
|
||||||
@@ -614,6 +661,9 @@ FAQ
|
|||||||
provide this in order to prove that you actually are who you claim to be.
|
provide this in order to prove that you actually are who you claim to be.
|
||||||
If the server doesn't require this, you don't need a client certificate.
|
If the server doesn't require this, you don't need a client certificate.
|
||||||
|
|
||||||
|
A client certificate is always used together with a private key, and the
|
||||||
|
private key has a pass phrase that protects it.
|
||||||
|
|
||||||
- Server certificate. The server you communicate with has a server
|
- Server certificate. The server you communicate with has a server
|
||||||
certificate. You can and should verify this certificate to make sure that
|
certificate. You can and should verify this certificate to make sure that
|
||||||
you are truly talking to the real server and not a server impersonating
|
you are truly talking to the real server and not a server impersonating
|
||||||
@@ -621,8 +671,9 @@ FAQ
|
|||||||
|
|
||||||
- Certificate Authority certificate ("CA cert"). You often have several CA
|
- Certificate Authority certificate ("CA cert"). You often have several CA
|
||||||
certs in a CA cert bundle that can be used to verify a server certificate
|
certs in a CA cert bundle that can be used to verify a server certificate
|
||||||
that was signed by one of the authorities in the bundle. curl comes with a
|
that was signed by one of the authorities in the bundle. curl does not
|
||||||
default CA cert bundle. You can override the default.
|
come with a CA cert bundle but most curl installs provide one. You can
|
||||||
|
also override the default.
|
||||||
|
|
||||||
The server certificate verification process is made by using a Certificate
|
The server certificate verification process is made by using a Certificate
|
||||||
Authority certificate ("CA cert") that was used to sign the server
|
Authority certificate ("CA cert") that was used to sign the server
|
||||||
@@ -653,6 +704,17 @@ FAQ
|
|||||||
|
|
||||||
But you could easily write your own program using libcurl to do such stunts.
|
But you could easily write your own program using libcurl to do such stunts.
|
||||||
|
|
||||||
|
3.19 How do I get HTTP from a host using a specific IP address?
|
||||||
|
|
||||||
|
For example, you may be trying out a web site installation that isn't yet in
|
||||||
|
the DNS. Or you have a site using multiple IP addresses for a given host
|
||||||
|
name and you want to address a specific one out of the set.
|
||||||
|
|
||||||
|
Set a custom Host: header that identifies the server name you want to reach
|
||||||
|
but use the target IP address in the URL:
|
||||||
|
|
||||||
|
curl --header "Host: www.example.com" http://127.0.0.1/
|
||||||
|
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
|
|
||||||
@@ -801,10 +863,8 @@ FAQ
|
|||||||
|
|
||||||
4.9 Curl can't authenticate to the server that requires NTLM?
|
4.9 Curl can't authenticate to the server that requires NTLM?
|
||||||
|
|
||||||
This is supported in curl 7.10.6 or later. No earlier curl version knows
|
NTLM support requires OpenSSL, GnuTLS, NSS or Microsoft Windows libraries at
|
||||||
of this magic. Later versions require the OpenSSL, GnuTLS or Microsoft
|
build-time to provide this functionality.
|
||||||
Windows libraries to provide this functionality. Using the NSS library
|
|
||||||
will not provide NTLM authentication functionality in curl.
|
|
||||||
|
|
||||||
NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You
|
NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You
|
||||||
should not use such ones.
|
should not use such ones.
|
||||||
@@ -944,6 +1004,31 @@ FAQ
|
|||||||
|
|
||||||
In either case, cURL should now be looking for the correct file.
|
In either case, cURL should now be looking for the correct file.
|
||||||
|
|
||||||
|
4.19 Why doesn't cURL return an error when the network cable is unplugged?
|
||||||
|
|
||||||
|
Unplugging the cable is not an error situation. The TCP/IP protocol stack
|
||||||
|
was designed to be fault tolerant, so even though there may be a physical
|
||||||
|
break somewhere the connection shouldn't be affected, just possibly
|
||||||
|
delayed. Eventually, the physical break will be fixed or the data will be
|
||||||
|
re-routed around the physical problem.
|
||||||
|
|
||||||
|
In such cases, the TCP/IP stack is responsible for detecting when the
|
||||||
|
network connection is irrevocably lost. Since with some protocols it is
|
||||||
|
perfectly legal for the client wait indefinitely for data, the stack may
|
||||||
|
never report a problem, and even when it does, it can take up to 20 minutes
|
||||||
|
for it to detect an issue. The curl option --keepalive-time enables
|
||||||
|
keep-alive support in the TCP/IP stack which makes it periodically probe the
|
||||||
|
connection to make sure it is still available to send data. That should
|
||||||
|
reliably detect any TCP/IP network failure.
|
||||||
|
|
||||||
|
But even that won't detect the network going down before the TCP/IP
|
||||||
|
connection is established (e.g. during a DNS lookup) or using protocols that
|
||||||
|
don't use TCP. To handle those situations, curl offers a number of timeouts
|
||||||
|
on its own. --speed-limit/--speed-time will abort if the data transfer rate
|
||||||
|
falls too low, and --connect-timeout and --max-time can be used to put an
|
||||||
|
overall timeout on the connection phase or the entire transfer.
|
||||||
|
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
|
|
||||||
5.1 Is libcurl thread-safe?
|
5.1 Is libcurl thread-safe?
|
||||||
@@ -1044,11 +1129,14 @@ FAQ
|
|||||||
|
|
||||||
When building an application that uses the static libcurl library, you must
|
When building an application that uses the static libcurl library, you must
|
||||||
add -DCURL_STATICLIB to your CFLAGS. Otherwise the linker will look for
|
add -DCURL_STATICLIB to your CFLAGS. Otherwise the linker will look for
|
||||||
dynamic import symbols. If you get linker error like "unknown symbol
|
dynamic import symbols. If you're using Visual Studio, you need to instead
|
||||||
__imp__curl_easy_init ..." you have linked against the wrong (static)
|
add CURL_STATICLIB in the "Preprocessor Definitions" section.
|
||||||
library. If you want to use the libcurl.dll and import lib, you don't need
|
|
||||||
any extra CFLAGS, but use one of the import libraries below. These are the
|
If you get linker error like "unknown symbol __imp__curl_easy_init ..." you
|
||||||
libraries produced by the various lib/Makefile.* files:
|
have linked against the wrong (static) library. If you want to use the
|
||||||
|
libcurl.dll and import lib, you don't need any extra CFLAGS, but use one of
|
||||||
|
the import libraries below. These are the libraries produced by the various
|
||||||
|
lib/Makefile.* files:
|
||||||
|
|
||||||
Target: static lib. import lib for libcurl*.dll.
|
Target: static lib. import lib for libcurl*.dll.
|
||||||
-----------------------------------------------------------
|
-----------------------------------------------------------
|
||||||
@@ -1058,13 +1146,14 @@ FAQ
|
|||||||
Borland: libcurl.lib libcurl_imp.lib
|
Borland: libcurl.lib libcurl_imp.lib
|
||||||
|
|
||||||
|
|
||||||
5.8 libcurl.so.3: open failed: No such file or directory
|
5.8 libcurl.so.X: open failed: No such file or directory
|
||||||
|
|
||||||
This is an error message you might get when you try to run a program linked
|
This is an error message you might get when you try to run a program linked
|
||||||
with a shared version of libcurl and your run-time linker (ld.so) couldn't
|
with a shared version of libcurl and your run-time linker (ld.so) couldn't
|
||||||
find the shared library named libcurl.so.3.
|
find the shared library named libcurl.so.X. (Where X is the number of the
|
||||||
|
current libcurl ABI, typically 3 or 4).
|
||||||
|
|
||||||
You need to make sure that ld.so finds libcurl.so.3. You can do that
|
You need to make sure that ld.so finds libcurl.so.X. You can do that
|
||||||
multiple ways, and it differs somewhat between different operating systems,
|
multiple ways, and it differs somewhat between different operating systems,
|
||||||
but they are usually:
|
but they are usually:
|
||||||
|
|
||||||
@@ -1100,10 +1189,10 @@ FAQ
|
|||||||
Using this offers asynchronous name resolves but it currently has no IPv6
|
Using this offers asynchronous name resolves but it currently has no IPv6
|
||||||
support.
|
support.
|
||||||
|
|
||||||
- The Windows threaded resolver. It use:
|
- The threaded resolver (default option on Windows). It uses:
|
||||||
|
|
||||||
A - gethostbyname() on plain ipv4 windows hosts
|
A - gethostbyname() on plain ipv4 hosts
|
||||||
B - getaddrinfo() on ipv6-enabled windows hosts
|
B - getaddrinfo() on ipv6-enabled hosts
|
||||||
|
|
||||||
Also note that libcurl never resolves or reverse-lookups addresses given as
|
Also note that libcurl never resolves or reverse-lookups addresses given as
|
||||||
pure numbers, such as 127.0.0.1 or ::1.
|
pure numbers, such as 127.0.0.1 or ::1.
|
||||||
@@ -1182,7 +1271,9 @@ FAQ
|
|||||||
to do "LIST -a" or similar to see them.
|
to do "LIST -a" or similar to see them.
|
||||||
|
|
||||||
The application thus needs to parse the LIST output. One such existing
|
The application thus needs to parse the LIST output. One such existing
|
||||||
list parser is available at http://cr.yp.to/ftpparse.html
|
list parser is available at http://cr.yp.to/ftpparse.html Versions of
|
||||||
|
libcurl since 7.21.0 also provide the ability to specify a wildcard to
|
||||||
|
download multiple files from one FTP directory.
|
||||||
|
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
|
@@ -43,7 +43,7 @@ HTTP
|
|||||||
- POST
|
- POST
|
||||||
- Pipelining
|
- Pipelining
|
||||||
- multipart formpost (RFC1867-style)
|
- multipart formpost (RFC1867-style)
|
||||||
- authentication: Basic, Digest, NTLM(*1), GSS-Negotiate/Negotiate(*3) and
|
- authentication: Basic, Digest, NTLM(*9), GSS-Negotiate/Negotiate(*3) and
|
||||||
SPNEGO (*4) to server and proxy
|
SPNEGO (*4) to server and proxy
|
||||||
- resume (both GET and PUT)
|
- resume (both GET and PUT)
|
||||||
- follow redirects
|
- follow redirects
|
||||||
@@ -125,7 +125,7 @@ FILE
|
|||||||
FOOTNOTES
|
FOOTNOTES
|
||||||
=========
|
=========
|
||||||
|
|
||||||
*1 = requires OpenSSL, GnuTLS, NSS or yassl
|
*1 = requires OpenSSL, GnuTLS, NSS, yassl or PolarSSL
|
||||||
*2 = requires OpenLDAP
|
*2 = requires OpenLDAP
|
||||||
*3 = requires a GSSAPI-compliant library, such as Heimdal or similar.
|
*3 = requires a GSSAPI-compliant library, such as Heimdal or similar.
|
||||||
*4 = requires FBopenssl
|
*4 = requires FBopenssl
|
||||||
@@ -133,3 +133,4 @@ FOOTNOTES
|
|||||||
*6 = requires c-ares
|
*6 = requires c-ares
|
||||||
*7 = requires OpenSSL or NSS, as GnuTLS only supports SSLv3 and TLSv1
|
*7 = requires OpenSSL or NSS, as GnuTLS only supports SSLv3 and TLSv1
|
||||||
*8 = requires libssh2
|
*8 = requires libssh2
|
||||||
|
*9 = requires OpenSSL, GnuTLS, NSS or yassl
|
||||||
|
58
docs/HISTORY
58
docs/HISTORY
@@ -157,6 +157,20 @@ September 2005:
|
|||||||
|
|
||||||
More than 100,000 unique visitors of the curl web site. 25 mirrors.
|
More than 100,000 unique visitors of the curl web site. 25 mirrors.
|
||||||
|
|
||||||
|
December 2005:
|
||||||
|
|
||||||
|
security vulnerability: libcurl URL Buffer Overflow
|
||||||
|
|
||||||
|
January 2006:
|
||||||
|
|
||||||
|
We dropped support for Gopher. We found bugs in the implementation that
|
||||||
|
turned out having been introduced years ago, so with the conclusion that
|
||||||
|
nobody had found out in all this time we removed it instead of fixing it.
|
||||||
|
|
||||||
|
March 2006:
|
||||||
|
|
||||||
|
security vulnerability: libcurl TFTP Packet Buffer Overflow
|
||||||
|
|
||||||
April 2006:
|
April 2006:
|
||||||
|
|
||||||
Added the multi_socket() API
|
Added the multi_socket() API
|
||||||
@@ -174,6 +188,10 @@ February 2007:
|
|||||||
|
|
||||||
Added support for the Mozilla NSS library to do the SSL/TLS stuff
|
Added support for the Mozilla NSS library to do the SSL/TLS stuff
|
||||||
|
|
||||||
|
July 2007:
|
||||||
|
|
||||||
|
security vulnerability: libcurl GnuTLS insufficient cert verification
|
||||||
|
|
||||||
November 2008:
|
November 2008:
|
||||||
|
|
||||||
Command line options: 128
|
Command line options: 128
|
||||||
@@ -184,3 +202,43 @@ November 2008:
|
|||||||
|
|
||||||
145,000 unique visitors. >100 GB downloaded.
|
145,000 unique visitors. >100 GB downloaded.
|
||||||
|
|
||||||
|
March 2009:
|
||||||
|
|
||||||
|
security vulnerability: libcurl Arbitrary File Access
|
||||||
|
|
||||||
|
August 2009:
|
||||||
|
|
||||||
|
security vulnerability: libcurl embedded zero in cert name
|
||||||
|
|
||||||
|
December 2009:
|
||||||
|
|
||||||
|
Added support for IMAP, POP3 and SMTP
|
||||||
|
|
||||||
|
January 2010:
|
||||||
|
|
||||||
|
Added support for RTSP
|
||||||
|
|
||||||
|
February 2010:
|
||||||
|
|
||||||
|
security vulnerability: libcurl data callback excessive length
|
||||||
|
|
||||||
|
March 2010:
|
||||||
|
|
||||||
|
The project switched over to use git instead of CVS for source code control
|
||||||
|
|
||||||
|
May 2010:
|
||||||
|
|
||||||
|
Added support for RTMP
|
||||||
|
|
||||||
|
Added support for PolarSSL to do the SSL/TLS stuff
|
||||||
|
|
||||||
|
August 2010:
|
||||||
|
|
||||||
|
Public curl releases: 117
|
||||||
|
Command line options: 138
|
||||||
|
curl_easy_setopt() options: 180
|
||||||
|
Public functions in libcurl: 58
|
||||||
|
Known libcurl bindings: 39
|
||||||
|
Contributors: 808
|
||||||
|
|
||||||
|
Gopher support added (re-added actually)
|
||||||
|
29
docs/INSTALL
29
docs/INSTALL
@@ -139,6 +139,9 @@ UNIX
|
|||||||
To build with NSS support instead of OpenSSL for SSL/TLS, note that
|
To build with NSS support instead of OpenSSL for SSL/TLS, note that
|
||||||
you need to use both --without-ssl and --with-nss.
|
you need to use both --without-ssl and --with-nss.
|
||||||
|
|
||||||
|
To build with PolarSSL support instead of OpenSSL for SSL/TLS, note that
|
||||||
|
you need to use both --without-ssl and --with-polarssl.
|
||||||
|
|
||||||
To get GSSAPI support, build with --with-gssapi and have the MIT or
|
To get GSSAPI support, build with --with-gssapi and have the MIT or
|
||||||
Heimdal Kerberos 5 packages installed.
|
Heimdal Kerberos 5 packages installed.
|
||||||
|
|
||||||
@@ -779,6 +782,11 @@ VxWorks
|
|||||||
To clean the build results type 'make -f ./Makefile.vxworks clean'.
|
To clean the build results type 'make -f ./Makefile.vxworks clean'.
|
||||||
|
|
||||||
|
|
||||||
|
Android
|
||||||
|
=======
|
||||||
|
See the build notes in the Android.mk file.
|
||||||
|
|
||||||
|
|
||||||
CROSS COMPILE
|
CROSS COMPILE
|
||||||
=============
|
=============
|
||||||
(This section was graciously brought to us by Jim Duey, with additions by
|
(This section was graciously brought to us by Jim Duey, with additions by
|
||||||
@@ -908,7 +916,7 @@ PORTS
|
|||||||
- Alpha OpenVMS V7.1-1H2
|
- Alpha OpenVMS V7.1-1H2
|
||||||
- Alpha Tru64 v5.0 5.1
|
- Alpha Tru64 v5.0 5.1
|
||||||
- AVR32 Linux
|
- AVR32 Linux
|
||||||
- ARM Android 1.5
|
- ARM Android 1.5, 2.1
|
||||||
- ARM INTEGRITY
|
- ARM INTEGRITY
|
||||||
- ARM iPhone OS
|
- ARM iPhone OS
|
||||||
- Cell Linux
|
- Cell Linux
|
||||||
@@ -972,10 +980,17 @@ PORTS
|
|||||||
Useful URLs
|
Useful URLs
|
||||||
===========
|
===========
|
||||||
|
|
||||||
OpenSSL http://www.openssl.org
|
c-ares http://daniel.haxx.se/projects/c-ares/license.html
|
||||||
MingW http://www.mingw.org
|
GNU GSS http://www.gnu.org/software/gss/
|
||||||
OpenLDAP http://www.openldap.org
|
GnuTLS http://www.gnu.org/software/gnutls/
|
||||||
Zlib http://www.gzip.org/zlib/
|
Heimdal http://www.pdc.kth.se/heimdal/
|
||||||
|
libidn http://www.gnu.org/software/libidn/
|
||||||
libssh2 http://www.libssh2.org
|
libssh2 http://www.libssh2.org
|
||||||
|
MingW http://www.mingw.org
|
||||||
|
MIT Kerberos http://web.mit.edu/kerberos/www/dist/
|
||||||
|
NSS http://www.mozilla.org/projects/security/pki/nss/
|
||||||
|
OpenLDAP http://www.openldap.org
|
||||||
|
OpenSSL http://www.openssl.org
|
||||||
|
PolarSSL http://polarssl.org
|
||||||
|
yassl http://www.yassl.com/
|
||||||
|
Zlib http://www.gzip.org/zlib/
|
||||||
|
@@ -37,7 +37,7 @@ Portability
|
|||||||
GnuTLS 1.2
|
GnuTLS 1.2
|
||||||
zlib 1.1.4
|
zlib 1.1.4
|
||||||
libssh2 0.16
|
libssh2 0.16
|
||||||
c-ares 1.5.0
|
c-ares 1.6.0
|
||||||
libidn 0.4.1
|
libidn 0.4.1
|
||||||
*yassl 1.4.0 (http://curl.haxx.se/mail/lib-2008-02/0093.html)
|
*yassl 1.4.0 (http://curl.haxx.se/mail/lib-2008-02/0093.html)
|
||||||
openldap 2.0
|
openldap 2.0
|
||||||
@@ -356,7 +356,7 @@ multi interface/non-blocking
|
|||||||
|
|
||||||
The FTP and the SFTP/SCP protocols are thus perfect examples of how we adapt
|
The FTP and the SFTP/SCP protocols are thus perfect examples of how we adapt
|
||||||
and adjust the code to allow non-blocking operations even on multi-stage
|
and adjust the code to allow non-blocking operations even on multi-stage
|
||||||
protocols. The DICT, TELNET and TFTP are crappy examples and they are subject
|
protocols. The DICT, LDAP and TELNET are crappy examples and they are subject
|
||||||
for rewrite in the future to better fit the libcurl protocol family.
|
for rewrite in the future to better fit the libcurl protocol family.
|
||||||
|
|
||||||
SSL libraries
|
SSL libraries
|
||||||
|
@@ -3,6 +3,11 @@ join in and help us correct one or more of these! Also be sure to check the
|
|||||||
changelog of the current development status, as one or more of these problems
|
changelog of the current development status, as one or more of these problems
|
||||||
may have been fixed since this was written!
|
may have been fixed since this was written!
|
||||||
|
|
||||||
|
76. The SOCKET type in Win64 is 64 bits large (and thus so is curl_socket_t on
|
||||||
|
that platform), and long is only 32 bits. It makes it impossible for
|
||||||
|
curl_easy_getinfo() to return a socket properly with the CURLINFO_LASTSOCKET
|
||||||
|
option as for all other operating systems.
|
||||||
|
|
||||||
75. NTLM authentication involving unicode user name or password.
|
75. NTLM authentication involving unicode user name or password.
|
||||||
http://curl.haxx.se/mail/lib-2009-10/0024.html
|
http://curl.haxx.se/mail/lib-2009-10/0024.html
|
||||||
http://curl.haxx.se/bug/view.cgi?id=2944325
|
http://curl.haxx.se/bug/view.cgi?id=2944325
|
||||||
@@ -49,11 +54,6 @@ may have been fixed since this was written!
|
|||||||
handle with curl_easy_cleanup() and create a new. Some more details:
|
handle with curl_easy_cleanup() and create a new. Some more details:
|
||||||
http://curl.haxx.se/mail/lib-2009-04/0300.html
|
http://curl.haxx.se/mail/lib-2009-04/0300.html
|
||||||
|
|
||||||
62. CURLOPT_TIMEOUT does not work properly with the regular multi and
|
|
||||||
multi_socket interfaces. The work-around for apps is to simply remove the
|
|
||||||
easy handle once the time is up. See also:
|
|
||||||
http://curl.haxx.se/bug/view.cgi?id=2501457
|
|
||||||
|
|
||||||
61. If an upload using Expect: 100-continue receives an HTTP 417 response,
|
61. If an upload using Expect: 100-continue receives an HTTP 417 response,
|
||||||
it ought to be automatically resent without the Expect:. A workaround is
|
it ought to be automatically resent without the Expect:. A workaround is
|
||||||
for the client application to redo the transfer after disabling Expect:.
|
for the client application to redo the transfer after disabling Expect:.
|
||||||
@@ -63,10 +63,6 @@ may have been fixed since this was written!
|
|||||||
is waiting for the the 100-continue response.
|
is waiting for the the 100-continue response.
|
||||||
http://curl.haxx.se/mail/lib-2008-08/0462.html
|
http://curl.haxx.se/mail/lib-2008-08/0462.html
|
||||||
|
|
||||||
59. If the CURLOPT_PORT option is used on an FTP URL like
|
|
||||||
"ftp://example.com/file;type=A" using a proxy, the ";type=A" is stripped off.
|
|
||||||
See the comment in parse_remote_port()
|
|
||||||
|
|
||||||
58. It seems sensible to be able to use CURLOPT_NOBODY and
|
58. It seems sensible to be able to use CURLOPT_NOBODY and
|
||||||
CURLOPT_FAILONERROR with FTP to detect if a file exists or not, but it is
|
CURLOPT_FAILONERROR with FTP to detect if a file exists or not, but it is
|
||||||
not working: http://curl.haxx.se/mail/lib-2008-07/0295.html
|
not working: http://curl.haxx.se/mail/lib-2008-07/0295.html
|
||||||
@@ -91,7 +87,7 @@ may have been fixed since this was written!
|
|||||||
|
|
||||||
52. Gautam Kachroo's issue that identifies a problem with the multi interface
|
52. Gautam Kachroo's issue that identifies a problem with the multi interface
|
||||||
where a connection can be re-used without actually being properly
|
where a connection can be re-used without actually being properly
|
||||||
SSL-negoatiated:
|
SSL-negotiated:
|
||||||
http://curl.haxx.se/mail/lib-2008-01/0277.html
|
http://curl.haxx.se/mail/lib-2008-01/0277.html
|
||||||
|
|
||||||
49. If using --retry and the transfer timeouts (possibly due to using -m or
|
49. If using --retry and the transfer timeouts (possibly due to using -m or
|
||||||
@@ -141,12 +137,13 @@ may have been fixed since this was written!
|
|||||||
30. You need to use -g to the command line tool in order to use RFC2732-style
|
30. You need to use -g to the command line tool in order to use RFC2732-style
|
||||||
IPv6 numerical addresses in URLs.
|
IPv6 numerical addresses in URLs.
|
||||||
|
|
||||||
29. IPv6 URLs with zone ID is not supported.
|
29. IPv6 URLs with zone ID is not nicely supported.
|
||||||
http://www.ietf.org/internet-drafts/draft-fenner-literal-zone-02.txt (expired)
|
http://www.ietf.org/internet-drafts/draft-fenner-literal-zone-02.txt (expired)
|
||||||
specifies the use of a plus sign instead of a percent when specifying zone
|
specifies the use of a plus sign instead of a percent when specifying zone
|
||||||
IDs in URLs to get around the problem of percent signs being
|
IDs in URLs to get around the problem of percent signs being
|
||||||
special. According to the reporter, Firefox deals with the URL _with_ a
|
special. According to the reporter, Firefox deals with the URL _with_ a
|
||||||
percent letter (which seems like a blatant URL spec violation).
|
percent letter (which seems like a blatant URL spec violation).
|
||||||
|
libcurl supports zone IDs where the percent sign is URL-escaped (i.e. %25).
|
||||||
|
|
||||||
See http://curl.haxx.se/bug/view.cgi?id=1371118
|
See http://curl.haxx.se/bug/view.cgi?id=1371118
|
||||||
|
|
||||||
@@ -189,7 +186,7 @@ may have been fixed since this was written!
|
|||||||
would not meaningfully support NUL characters within RFC 959 <string>,
|
would not meaningfully support NUL characters within RFC 959 <string>,
|
||||||
anyway (e.g., UNIX pathnames may not contain NUL).
|
anyway (e.g., UNIX pathnames may not contain NUL).
|
||||||
|
|
||||||
14. Test case 165 might fail on system which has libidn present, but with an
|
14. Test case 165 might fail on a system which has libidn present, but with an
|
||||||
old iconv version (2.1.3 is a known bad version), since it doesn't recognize
|
old iconv version (2.1.3 is a known bad version), since it doesn't recognize
|
||||||
the charset when named ISO8859-1. Changing the name to ISO-8859-1 makes the
|
the charset when named ISO8859-1. Changing the name to ISO-8859-1 makes the
|
||||||
test pass, but instead makes it fail on Solaris hosts that use its native
|
test pass, but instead makes it fail on Solaris hosts that use its native
|
||||||
|
@@ -32,12 +32,16 @@ This document lists documents and standards used by curl.
|
|||||||
|
|
||||||
RFC 2068 - HTTP 1.1 (obsoleted by RFC 2616)
|
RFC 2068 - HTTP 1.1 (obsoleted by RFC 2616)
|
||||||
|
|
||||||
|
RFC 2104 - Keyed-Hashing for Message Authentication
|
||||||
|
|
||||||
RFC 2109 - HTTP State Management Mechanism (cookie stuff)
|
RFC 2109 - HTTP State Management Mechanism (cookie stuff)
|
||||||
- Also, read Netscape's specification at
|
- Also, read Netscape's specification at
|
||||||
http://curl.haxx.se/rfc/cookie_spec.html
|
http://curl.haxx.se/rfc/cookie_spec.html
|
||||||
|
|
||||||
RFC 2183 - The Content-Disposition Header Field
|
RFC 2183 - The Content-Disposition Header Field
|
||||||
|
|
||||||
|
RFC 2195 - CRAM-MD5 authentication
|
||||||
|
|
||||||
RFC 2229 - A Dictionary Server Protocol
|
RFC 2229 - A Dictionary Server Protocol
|
||||||
|
|
||||||
RFC 2255 - Newer LDAP URL syntax document.
|
RFC 2255 - Newer LDAP URL syntax document.
|
||||||
@@ -73,3 +77,7 @@ This document lists documents and standards used by curl.
|
|||||||
RFC 2965 - HTTP State Management Mechanism. Cookies. Obsoletes RFC2109
|
RFC 2965 - HTTP State Management Mechanism. Cookies. Obsoletes RFC2109
|
||||||
|
|
||||||
RFC 3207 - SMTP over TLS
|
RFC 3207 - SMTP over TLS
|
||||||
|
|
||||||
|
RFC 4616 - PLAIN authentication
|
||||||
|
|
||||||
|
RFC 4954 - SMTP Authentication
|
||||||
|
41
docs/THANKS
41
docs/THANKS
@@ -6,14 +6,17 @@
|
|||||||
|
|
||||||
Aaron Oneal
|
Aaron Oneal
|
||||||
Adam D. Moss
|
Adam D. Moss
|
||||||
|
Adam Light
|
||||||
Adam Piggott
|
Adam Piggott
|
||||||
Adrian Schuur
|
Adrian Schuur
|
||||||
|
Akos Pasztory
|
||||||
Alan Pinstein
|
Alan Pinstein
|
||||||
Albert Chin-A-Young
|
Albert Chin-A-Young
|
||||||
Albert Choy
|
Albert Choy
|
||||||
Ale Vesely
|
Ale Vesely
|
||||||
Aleksandar Milivojevic
|
Aleksandar Milivojevic
|
||||||
Alessandro Vesely
|
Alessandro Vesely
|
||||||
|
Alex Bligh
|
||||||
Alex Fishman
|
Alex Fishman
|
||||||
Alex Neblett
|
Alex Neblett
|
||||||
Alex Suykov
|
Alex Suykov
|
||||||
@@ -41,6 +44,7 @@ Andreas Olsson
|
|||||||
Andreas Rieke
|
Andreas Rieke
|
||||||
Andreas Schuldei
|
Andreas Schuldei
|
||||||
Andreas Wurf
|
Andreas Wurf
|
||||||
|
Andrei Benea
|
||||||
Andres Garcia
|
Andres Garcia
|
||||||
Andrew Benham
|
Andrew Benham
|
||||||
Andrew Biggs
|
Andrew Biggs
|
||||||
@@ -69,6 +73,7 @@ Axel Tillequin
|
|||||||
Balint Szilakszi
|
Balint Szilakszi
|
||||||
Bart Whiteley
|
Bart Whiteley
|
||||||
Bas Mevissen
|
Bas Mevissen
|
||||||
|
Ben Darnell
|
||||||
Ben Greear
|
Ben Greear
|
||||||
Ben Madsen
|
Ben Madsen
|
||||||
Ben Van Hof
|
Ben Van Hof
|
||||||
@@ -81,6 +86,7 @@ Bill Hoffman
|
|||||||
Bjorn Augustsson
|
Bjorn Augustsson
|
||||||
Bjorn Reese
|
Bjorn Reese
|
||||||
Bj<EFBFBD>rn Stenberg
|
Bj<EFBFBD>rn Stenberg
|
||||||
|
Bob Richmond
|
||||||
Bob Schader
|
Bob Schader
|
||||||
Bogdan Nicula
|
Bogdan Nicula
|
||||||
Brad Burdick
|
Brad Burdick
|
||||||
@@ -118,6 +124,7 @@ Christian Schmitz
|
|||||||
Christian Vogt
|
Christian Vogt
|
||||||
Christophe Demory
|
Christophe Demory
|
||||||
Christophe Legry
|
Christophe Legry
|
||||||
|
Christopher Conroy
|
||||||
Christopher Palow
|
Christopher Palow
|
||||||
Christopher R. Palmer
|
Christopher R. Palmer
|
||||||
Ciprian Badescu
|
Ciprian Badescu
|
||||||
@@ -200,7 +207,9 @@ Dominick Meglio
|
|||||||
Doug Kaufman
|
Doug Kaufman
|
||||||
Doug Porter
|
Doug Porter
|
||||||
Douglas E. Wegscheid
|
Douglas E. Wegscheid
|
||||||
|
Douglas Kilpatrick
|
||||||
Douglas R. Horner
|
Douglas R. Horner
|
||||||
|
Douglas Steinwand
|
||||||
Dov Murik
|
Dov Murik
|
||||||
Duane Cathey
|
Duane Cathey
|
||||||
Duncan Mac-Vicar Prett
|
Duncan Mac-Vicar Prett
|
||||||
@@ -222,6 +231,7 @@ Eric Cooper
|
|||||||
Eric Landes
|
Eric Landes
|
||||||
Eric Lavigne
|
Eric Lavigne
|
||||||
Eric Melville
|
Eric Melville
|
||||||
|
Eric Mertens
|
||||||
Eric Rautman
|
Eric Rautman
|
||||||
Eric Thelin
|
Eric Thelin
|
||||||
Eric Vergnaud
|
Eric Vergnaud
|
||||||
@@ -243,6 +253,7 @@ Forrest Cahoon
|
|||||||
Frank Hempel
|
Frank Hempel
|
||||||
Frank Keeney
|
Frank Keeney
|
||||||
Frank McGeough
|
Frank McGeough
|
||||||
|
Frank Meier
|
||||||
Frank Ticheler
|
Frank Ticheler
|
||||||
Fred Machado
|
Fred Machado
|
||||||
Fred New
|
Fred New
|
||||||
@@ -291,9 +302,12 @@ Hans Steegers
|
|||||||
Hans-Jurgen May
|
Hans-Jurgen May
|
||||||
Hardeep Singh
|
Hardeep Singh
|
||||||
Harshal Pradhan
|
Harshal Pradhan
|
||||||
|
Hauke Duden
|
||||||
Heikki Korpela
|
Heikki Korpela
|
||||||
Henrik Storner
|
Henrik Storner
|
||||||
Hidemoto Nakada
|
Hidemoto Nakada
|
||||||
|
Hoi-Ho Chan
|
||||||
|
Howard Chu
|
||||||
Hzhijun
|
Hzhijun
|
||||||
Ian Ford
|
Ian Ford
|
||||||
Ian Gulliver
|
Ian Gulliver
|
||||||
@@ -310,8 +324,10 @@ Immanuel Gregoire
|
|||||||
Ingmar Runge
|
Ingmar Runge
|
||||||
Ingo Ralf Blum
|
Ingo Ralf Blum
|
||||||
Ingo Wilken
|
Ingo Wilken
|
||||||
|
Jack Zhang
|
||||||
Jacky Lam
|
Jacky Lam
|
||||||
Jacob Meuser
|
Jacob Meuser
|
||||||
|
Jacob Moshenko
|
||||||
Jad Chamcham
|
Jad Chamcham
|
||||||
James Bursa
|
James Bursa
|
||||||
James Cheng
|
James Cheng
|
||||||
@@ -325,8 +341,10 @@ Jamie Lokier
|
|||||||
Jamie Newton
|
Jamie Newton
|
||||||
Jamie Wilkinson
|
Jamie Wilkinson
|
||||||
Jan Kunder
|
Jan Kunder
|
||||||
|
Jan Van Boghout
|
||||||
Jared Lundell
|
Jared Lundell
|
||||||
Jari Sundell
|
Jari Sundell
|
||||||
|
Jason McDonald
|
||||||
Jason S. Priebe
|
Jason S. Priebe
|
||||||
Jay Austin
|
Jay Austin
|
||||||
Jayesh A Shah
|
Jayesh A Shah
|
||||||
@@ -345,6 +363,7 @@ Jeff Weber
|
|||||||
Jeffrey Pohlmeyer
|
Jeffrey Pohlmeyer
|
||||||
Jeremy Friesner
|
Jeremy Friesner
|
||||||
Jerome Muffat-Meridol
|
Jerome Muffat-Meridol
|
||||||
|
Jerome Vouillon
|
||||||
Jes Badwal
|
Jes Badwal
|
||||||
Jesper Jensen
|
Jesper Jensen
|
||||||
Jesse Noller
|
Jesse Noller
|
||||||
@@ -369,9 +388,11 @@ John Lightsey
|
|||||||
John McGowan
|
John McGowan
|
||||||
John P. McCaskey
|
John P. McCaskey
|
||||||
John Wilkinson
|
John Wilkinson
|
||||||
|
John-Mark Bell
|
||||||
Johnny Luong
|
Johnny Luong
|
||||||
Jon Grubbs
|
Jon Grubbs
|
||||||
Jon Nelson
|
Jon Nelson
|
||||||
|
Jon Sargeant
|
||||||
Jon Travis
|
Jon Travis
|
||||||
Jon Turner
|
Jon Turner
|
||||||
Jonas Forsman
|
Jonas Forsman
|
||||||
@@ -396,6 +417,7 @@ J
|
|||||||
J<EFBFBD>rn Hartroth
|
J<EFBFBD>rn Hartroth
|
||||||
Kai Sommerfeld
|
Kai Sommerfeld
|
||||||
Kai-Uwe Rommel
|
Kai-Uwe Rommel
|
||||||
|
Kalle Vahlman
|
||||||
Kamil Dudka
|
Kamil Dudka
|
||||||
Kang-Jin Lee
|
Kang-Jin Lee
|
||||||
Karl Moerder
|
Karl Moerder
|
||||||
@@ -408,6 +430,7 @@ Keith McGuigan
|
|||||||
Keith Mok
|
Keith Mok
|
||||||
Ken Hirsch
|
Ken Hirsch
|
||||||
Ken Rastatter
|
Ken Rastatter
|
||||||
|
Kenny To
|
||||||
Kent Boortz
|
Kent Boortz
|
||||||
Keshav Krity
|
Keshav Krity
|
||||||
Kevin Baughman
|
Kevin Baughman
|
||||||
@@ -471,24 +494,28 @@ Mark Eichin
|
|||||||
Mark Incley
|
Mark Incley
|
||||||
Mark Karpeles
|
Mark Karpeles
|
||||||
Mark Lentczner
|
Mark Lentczner
|
||||||
|
Markus Duft
|
||||||
Markus Koetter
|
Markus Koetter
|
||||||
Markus Moeller
|
Markus Moeller
|
||||||
Markus Oberhumer
|
Markus Oberhumer
|
||||||
Martijn Koster
|
Martijn Koster
|
||||||
Martin C. Martin
|
Martin C. Martin
|
||||||
Martin Drasar
|
Martin Drasar
|
||||||
|
Martin Hager
|
||||||
Martin Hedenfalk
|
Martin Hedenfalk
|
||||||
Martin Skinner
|
Martin Skinner
|
||||||
Martin Storsjo
|
Martin Storsjo
|
||||||
Marty Kuhrt
|
Marty Kuhrt
|
||||||
Maruko
|
Maruko
|
||||||
Massimiliano Ziccardi
|
Massimiliano Ziccardi
|
||||||
|
Massimo Callegari
|
||||||
Mateusz Loskot
|
Mateusz Loskot
|
||||||
Mathias Axelsson
|
Mathias Axelsson
|
||||||
Mats Lidell
|
Mats Lidell
|
||||||
Matt Kraai
|
Matt Kraai
|
||||||
Matt Veenstra
|
Matt Veenstra
|
||||||
Matt Witherspoon
|
Matt Witherspoon
|
||||||
|
Matt Wixson
|
||||||
Matthew Blain
|
Matthew Blain
|
||||||
Matthew Clarke
|
Matthew Clarke
|
||||||
Maurice Barnum
|
Maurice Barnum
|
||||||
@@ -512,11 +539,13 @@ Michal Bonino
|
|||||||
Michal Marek
|
Michal Marek
|
||||||
Michele Bini
|
Michele Bini
|
||||||
Mihai Ionescu
|
Mihai Ionescu
|
||||||
|
Mikael Johansson
|
||||||
Mikael Sennerholm
|
Mikael Sennerholm
|
||||||
Mike Bytnar
|
Mike Bytnar
|
||||||
Mike Crowe
|
Mike Crowe
|
||||||
Mike Dobbs
|
Mike Dobbs
|
||||||
Mike Hommey
|
Mike Hommey
|
||||||
|
Mike Power
|
||||||
Mike Protts
|
Mike Protts
|
||||||
Mike Revi
|
Mike Revi
|
||||||
Miklos Nemeth
|
Miklos Nemeth
|
||||||
@@ -554,18 +583,21 @@ Olaf St
|
|||||||
Oren Tirosh
|
Oren Tirosh
|
||||||
P R Schaffner
|
P R Schaffner
|
||||||
Pascal Terjan
|
Pascal Terjan
|
||||||
|
Pat Ray
|
||||||
Patrick Bihan-Faou
|
Patrick Bihan-Faou
|
||||||
Patrick Monnerat
|
Patrick Monnerat
|
||||||
Patrick Scott
|
Patrick Scott
|
||||||
Patrick Smith
|
Patrick Smith
|
||||||
Patrik Thunstrom
|
Patrik Thunstrom
|
||||||
Paul Harrington
|
Paul Harrington
|
||||||
|
Paul Howarth
|
||||||
Paul Marquis
|
Paul Marquis
|
||||||
Paul Moore
|
Paul Moore
|
||||||
Paul Nolan
|
Paul Nolan
|
||||||
Paul Querna
|
Paul Querna
|
||||||
Pavel Cenek
|
Pavel Cenek
|
||||||
Pavel Orehov
|
Pavel Orehov
|
||||||
|
Pavel Raiskup
|
||||||
Pawel A. Gajda
|
Pawel A. Gajda
|
||||||
Pawel Kierski
|
Pawel Kierski
|
||||||
Pedro Neves
|
Pedro Neves
|
||||||
@@ -595,12 +627,14 @@ Philippe Raoult
|
|||||||
Philippe Vaucher
|
Philippe Vaucher
|
||||||
Pierre
|
Pierre
|
||||||
Pierre Brico
|
Pierre Brico
|
||||||
|
Pierre Joye
|
||||||
Pooyan McSporran
|
Pooyan McSporran
|
||||||
Pramod Sharma
|
Pramod Sharma
|
||||||
Puneet Pawaia
|
Puneet Pawaia
|
||||||
Quagmire
|
Quagmire
|
||||||
Rafa Muyo
|
Rafa Muyo
|
||||||
Rafael Sagula
|
Rafael Sagula
|
||||||
|
Rainer Canavan
|
||||||
Rainer Koenig
|
Rainer Koenig
|
||||||
Ralf S. Engelschall
|
Ralf S. Engelschall
|
||||||
Ralph Beckmann
|
Ralph Beckmann
|
||||||
@@ -638,6 +672,7 @@ Robert Foreman
|
|||||||
Robert Iakobashvili
|
Robert Iakobashvili
|
||||||
Robert Olson
|
Robert Olson
|
||||||
Robert Weaver
|
Robert Weaver
|
||||||
|
Robin Cornelius
|
||||||
Robin Johnson
|
Robin Johnson
|
||||||
Robin Kay
|
Robin Kay
|
||||||
Robson Braga Araujo
|
Robson Braga Araujo
|
||||||
@@ -651,6 +686,8 @@ Ron Zapp
|
|||||||
Rosimildo da Silva
|
Rosimildo da Silva
|
||||||
Roy Shan
|
Roy Shan
|
||||||
Rune Kleveland
|
Rune Kleveland
|
||||||
|
Ruslan Gazizov
|
||||||
|
Ryan Chan
|
||||||
Ryan Nelson
|
Ryan Nelson
|
||||||
S. Moonesamy
|
S. Moonesamy
|
||||||
Salvador D<>vila
|
Salvador D<>vila
|
||||||
@@ -676,6 +713,7 @@ Shard
|
|||||||
Shawn Poulson
|
Shawn Poulson
|
||||||
Shmulik Regev
|
Shmulik Regev
|
||||||
Siddhartha Prakash Jain
|
Siddhartha Prakash Jain
|
||||||
|
Sidney San Martin
|
||||||
Siegfried Gyuricsko
|
Siegfried Gyuricsko
|
||||||
Simon Dick
|
Simon Dick
|
||||||
Simon Josefsson
|
Simon Josefsson
|
||||||
@@ -703,6 +741,7 @@ Steve Oliphant
|
|||||||
Steve Roskowski
|
Steve Roskowski
|
||||||
Steven Bazyl
|
Steven Bazyl
|
||||||
Steven G. Johnson
|
Steven G. Johnson
|
||||||
|
Steven M. Schweda
|
||||||
Stoned Elipot
|
Stoned Elipot
|
||||||
Sven Anders
|
Sven Anders
|
||||||
Sven Neuhaus
|
Sven Neuhaus
|
||||||
@@ -714,6 +753,7 @@ Tanguy Fautre
|
|||||||
Temprimus
|
Temprimus
|
||||||
Thomas J. Moore
|
Thomas J. Moore
|
||||||
Thomas Klausner
|
Thomas Klausner
|
||||||
|
Thomas Lopatic
|
||||||
Thomas Schwinge
|
Thomas Schwinge
|
||||||
Thomas Tonino
|
Thomas Tonino
|
||||||
Tim Ansell
|
Tim Ansell
|
||||||
@@ -727,6 +767,7 @@ Toby Peterson
|
|||||||
Todd Kulesza
|
Todd Kulesza
|
||||||
Todd Vierling
|
Todd Vierling
|
||||||
Tom Benoist
|
Tom Benoist
|
||||||
|
Tom Donovan
|
||||||
Tom Lee
|
Tom Lee
|
||||||
Tom Mattison
|
Tom Mattison
|
||||||
Tom Moers
|
Tom Moers
|
||||||
|
116
docs/TODO
116
docs/TODO
@@ -27,7 +27,7 @@
|
|||||||
3.1 More and better
|
3.1 More and better
|
||||||
|
|
||||||
4. FTP
|
4. FTP
|
||||||
4.1 PRET
|
4.1 HOST
|
||||||
4.2 Alter passive/active on failure and retry
|
4.2 Alter passive/active on failure and retry
|
||||||
4.3 Earlier bad letter detection
|
4.3 Earlier bad letter detection
|
||||||
4.4 REST for large files
|
4.4 REST for large files
|
||||||
@@ -55,33 +55,27 @@
|
|||||||
7.7 Support other SSL libraries
|
7.7 Support other SSL libraries
|
||||||
7.8 Support SRP on the TLS layer
|
7.8 Support SRP on the TLS layer
|
||||||
7.9 improve configure --with-ssl
|
7.9 improve configure --with-ssl
|
||||||
7.10 Make NTLM work with other crypto functions
|
|
||||||
|
|
||||||
8. GnuTLS
|
8. GnuTLS
|
||||||
8.1 SSL engine stuff
|
8.1 SSL engine stuff
|
||||||
8.2 SRP
|
8.2 SRP
|
||||||
8.3 non-blocking
|
8.3 check connection
|
||||||
8.4 check connection
|
8.4 non-gcrypt
|
||||||
|
|
||||||
9. Other protocols
|
9. Other protocols
|
||||||
9.1 ditch ldap-specific select
|
|
||||||
|
|
||||||
10. New protocols
|
10. New protocols
|
||||||
10.1 RTSP
|
10.1 RSYNC
|
||||||
10.2 RSYNC
|
|
||||||
10.3 RTMP
|
|
||||||
|
|
||||||
11. Client
|
11. Client
|
||||||
11.1 Content-Disposition
|
11.1 sync
|
||||||
11.2 sync
|
11.2 glob posts
|
||||||
11.3 glob posts
|
11.3 prevent file overwriting
|
||||||
11.4 prevent file overwriting
|
11.4 simultaneous parallel transfers
|
||||||
11.5 ftp wildcard download
|
11.5 provide formpost headers
|
||||||
11.6 simultaneous parallel transfers
|
11.6 url-specific options
|
||||||
11.7 provide formpost headers
|
11.7 metalink support
|
||||||
11.8 url-specific options
|
11.8 warning when setting an option
|
||||||
11.9 metalink support
|
|
||||||
11.10 warning when setting an option
|
|
||||||
|
|
||||||
12. Build
|
12. Build
|
||||||
12.1 roffit
|
12.1 roffit
|
||||||
@@ -148,7 +142,6 @@
|
|||||||
EWOULDBLOCK or similar. Blocking cases include:
|
EWOULDBLOCK or similar. Blocking cases include:
|
||||||
|
|
||||||
- Name resolves on non-windows unless c-ares is used
|
- Name resolves on non-windows unless c-ares is used
|
||||||
- GnuTLS SSL connections
|
|
||||||
- NSS SSL connections
|
- NSS SSL connections
|
||||||
- Active FTP connections
|
- Active FTP connections
|
||||||
- HTTP proxy CONNECT operations
|
- HTTP proxy CONNECT operations
|
||||||
@@ -190,7 +183,6 @@
|
|||||||
serial requests and currently libcurl only supports that for HEAD and GET
|
serial requests and currently libcurl only supports that for HEAD and GET
|
||||||
requests but it should also be possible for PUT.
|
requests but it should also be possible for PUT.
|
||||||
|
|
||||||
|
|
||||||
3. Documentation
|
3. Documentation
|
||||||
|
|
||||||
3.1 More and better
|
3.1 More and better
|
||||||
@@ -199,12 +191,12 @@
|
|||||||
|
|
||||||
4. FTP
|
4. FTP
|
||||||
|
|
||||||
4.1 PRET
|
4.1 HOST
|
||||||
|
|
||||||
PRET is a command that primarily "drftpd" supports, which could be useful
|
HOST is a suggested command in the works for a client to tell which host name
|
||||||
when using libcurl against such a server. It is a non-standard and a rather
|
to use, to offer FTP servers named-based virtual hosting:
|
||||||
oddly designed command, but...
|
|
||||||
http://curl.haxx.se/bug/feature.cgi?id=1729967
|
http://tools.ietf.org/html/draft-hethmon-mcmurray-ftp-hosts-11
|
||||||
|
|
||||||
4.2 Alter passive/active on failure and retry
|
4.2 Alter passive/active on failure and retry
|
||||||
|
|
||||||
@@ -343,14 +335,6 @@ to provide the data to send.
|
|||||||
make the configure --with-ssl option first check for OpenSSL, then GnuTLS,
|
make the configure --with-ssl option first check for OpenSSL, then GnuTLS,
|
||||||
then NSS...
|
then NSS...
|
||||||
|
|
||||||
7.10 Make NTLM work with other crypto functions
|
|
||||||
|
|
||||||
Get NTLM working using the functions provided by NSS etc. Not strictly
|
|
||||||
SSL/TLS related, but hey... Another option is to get available DES and MD4
|
|
||||||
source code from the cryptopp library. They are fine license-wise, but are
|
|
||||||
C++. NTLM currenly only works when libcurl is built with OpenSSL or GnuTLS
|
|
||||||
support.
|
|
||||||
|
|
||||||
8. GnuTLS
|
8. GnuTLS
|
||||||
|
|
||||||
8.1 SSL engine stuff
|
8.1 SSL engine stuff
|
||||||
@@ -362,54 +346,34 @@ to provide the data to send.
|
|||||||
Work out a common method with Peter Sylvester's OpenSSL-patch for SRP on the
|
Work out a common method with Peter Sylvester's OpenSSL-patch for SRP on the
|
||||||
TLS to provide name and password. GnuTLS already supports it...
|
TLS to provide name and password. GnuTLS already supports it...
|
||||||
|
|
||||||
8.3 non-blocking
|
8.3 check connection
|
||||||
|
|
||||||
Fix the connection phase to be non-blocking when multi interface is used
|
|
||||||
|
|
||||||
8.4 check connection
|
|
||||||
|
|
||||||
Add a way to check if the connection seems to be alive, to correspond to the
|
Add a way to check if the connection seems to be alive, to correspond to the
|
||||||
SSL_peak() way we use with OpenSSL.
|
SSL_peak() way we use with OpenSSL.
|
||||||
|
|
||||||
|
8.4 non-gcrypt
|
||||||
|
|
||||||
|
libcurl assumes that there are gcrypt functions available when
|
||||||
|
GnuTLS is.
|
||||||
|
|
||||||
|
GnuTLS can be built to use libnettle instead as crypto library,
|
||||||
|
which breaks the previously mentioned assumption
|
||||||
|
|
||||||
|
The correct fix would be to detect which crypto layer that is in use and
|
||||||
|
adapt our code to use that instead of blindly assuming gcrypt.
|
||||||
|
|
||||||
9. Other protocols
|
9. Other protocols
|
||||||
|
|
||||||
9.1 ditch ldap-specific select
|
|
||||||
|
|
||||||
* Look over the implementation. The looping will have to "go away" from the
|
|
||||||
lib/ldap.c source file and get moved to the main network code so that the
|
|
||||||
multi interface and friends will work for LDAP as well.
|
|
||||||
|
|
||||||
9.2 stop TFTP blocking
|
|
||||||
|
|
||||||
Stop TFTP from being blocking and doing its own read loop in tftp_do.
|
|
||||||
|
|
||||||
10. New protocols
|
10. New protocols
|
||||||
|
|
||||||
10.1 RTSP
|
10.1 RSYNC
|
||||||
|
|
||||||
RFC2326 (protocol - very HTTP-like, also contains URL description)
|
|
||||||
|
|
||||||
10.2 RSYNC
|
|
||||||
|
|
||||||
There's no RFC for protocol nor URI/URL format. An implementation should
|
There's no RFC for protocol nor URI/URL format. An implementation should
|
||||||
most probably use an existing rsync library, such as librsync.
|
most probably use an existing rsync library, such as librsync.
|
||||||
|
|
||||||
10.3 RTMP
|
|
||||||
|
|
||||||
There exists a patch that claims to introduce this protocol:
|
|
||||||
http://osdir.com/ml/gnu.gnash.devel2/2006-11/msg00278.html, further details
|
|
||||||
in the feature-request: http://curl.haxx.se/bug/feature.cgi?id=1843469
|
|
||||||
|
|
||||||
11. Client
|
11. Client
|
||||||
|
|
||||||
11.1 Content-Disposition
|
11.1 sync
|
||||||
|
|
||||||
Add option that is similar to -O but that takes the output file name from the
|
|
||||||
Content-Disposition: header, and/or uses the local file name used in
|
|
||||||
redirections for the cases the server bounces the request further to a
|
|
||||||
different file (name): http://curl.haxx.se/bug/feature.cgi?id=1364676
|
|
||||||
|
|
||||||
11.2 sync
|
|
||||||
|
|
||||||
"curl --sync http://example.com/feed[1-100].rss" or
|
"curl --sync http://example.com/feed[1-100].rss" or
|
||||||
"curl --sync http://example.net/{index,calendar,history}.html"
|
"curl --sync http://example.net/{index,calendar,history}.html"
|
||||||
@@ -418,12 +382,12 @@ to provide the data to send.
|
|||||||
remote file is newer than the local file. A Last-Modified HTTP date header
|
remote file is newer than the local file. A Last-Modified HTTP date header
|
||||||
should also be used to set the mod date on the downloaded file.
|
should also be used to set the mod date on the downloaded file.
|
||||||
|
|
||||||
11.3 glob posts
|
11.2 glob posts
|
||||||
|
|
||||||
Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'.
|
Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'.
|
||||||
This is easily scripted though.
|
This is easily scripted though.
|
||||||
|
|
||||||
11.4 prevent file overwriting
|
11.3 prevent file overwriting
|
||||||
|
|
||||||
Add an option that prevents cURL from overwriting existing local files. When
|
Add an option that prevents cURL from overwriting existing local files. When
|
||||||
used, and there already is an existing file with the target file name
|
used, and there already is an existing file with the target file name
|
||||||
@@ -431,18 +395,14 @@ to provide the data to send.
|
|||||||
existing). So that index.html becomes first index.html.1 and then
|
existing). So that index.html becomes first index.html.1 and then
|
||||||
index.html.2 etc.
|
index.html.2 etc.
|
||||||
|
|
||||||
11.5 ftp wildcard download
|
11.4 simultaneous parallel transfers
|
||||||
|
|
||||||
"curl ftp://site.com/*.txt"
|
|
||||||
|
|
||||||
11.6 simultaneous parallel transfers
|
|
||||||
|
|
||||||
The client could be told to use maximum N simultaneous parallel transfers and
|
The client could be told to use maximum N simultaneous parallel transfers and
|
||||||
then just make sure that happens. It should of course not make more than one
|
then just make sure that happens. It should of course not make more than one
|
||||||
connection to the same remote host. This would require the client to use the
|
connection to the same remote host. This would require the client to use the
|
||||||
multi interface. http://curl.haxx.se/bug/feature.cgi?id=1558595
|
multi interface. http://curl.haxx.se/bug/feature.cgi?id=1558595
|
||||||
|
|
||||||
11.7 provide formpost headers
|
11.5 provide formpost headers
|
||||||
|
|
||||||
Extending the capabilities of the multipart formposting. How about leaving
|
Extending the capabilities of the multipart formposting. How about leaving
|
||||||
the ';type=foo' syntax as it is and adding an extra tag (headers) which
|
the ';type=foo' syntax as it is and adding an extra tag (headers) which
|
||||||
@@ -456,7 +416,7 @@ to provide the data to send.
|
|||||||
which should overwrite the program reasonable defaults (plain/text,
|
which should overwrite the program reasonable defaults (plain/text,
|
||||||
8bit...)
|
8bit...)
|
||||||
|
|
||||||
11.8 url-specific options
|
11.6 url-specific options
|
||||||
|
|
||||||
Provide a way to make options bound to a specific URL among several on the
|
Provide a way to make options bound to a specific URL among several on the
|
||||||
command line. Possibly by letting ':' separate options between URLs,
|
command line. Possibly by letting ':' separate options between URLs,
|
||||||
@@ -470,12 +430,12 @@ to provide the data to send.
|
|||||||
|
|
||||||
The example would do a POST-GET-POST combination on a single command line.
|
The example would do a POST-GET-POST combination on a single command line.
|
||||||
|
|
||||||
11.9 metalink support
|
11.7 metalink support
|
||||||
|
|
||||||
Add metalink support to curl (http://www.metalinker.org/). This is most useful
|
Add metalink support to curl (http://www.metalinker.org/). This is most useful
|
||||||
with simultaneous parallel transfers (11.6) but not necessary.
|
with simultaneous parallel transfers (11.6) but not necessary.
|
||||||
|
|
||||||
11.10 warning when setting an option
|
11.8 warning when setting an option
|
||||||
|
|
||||||
Display a warning when libcurl returns an error when setting an option.
|
Display a warning when libcurl returns an error when setting an option.
|
||||||
This can be useful to tell when support for a particular feature hasn't been
|
This can be useful to tell when support for a particular feature hasn't been
|
||||||
|
@@ -38,10 +38,10 @@ Date: May 28, 2008
|
|||||||
request a particular action, and then the server replies a few text lines
|
request a particular action, and then the server replies a few text lines
|
||||||
before the actual requested content is sent to the client.
|
before the actual requested content is sent to the client.
|
||||||
|
|
||||||
Using curl's option -v will display what kind of commands curl sends to the
|
Using curl's option --verbose (-v as a short option) will display what kind of
|
||||||
server, as well as a few other informational texts. -v is the single most
|
commands curl sends to the server, as well as a few other informational texts.
|
||||||
useful option when it comes to debug or even understand the curl<->server
|
--verbose is the single most useful option when it comes to debug or even
|
||||||
interaction.
|
understand the curl<->server interaction.
|
||||||
|
|
||||||
2. URL
|
2. URL
|
||||||
|
|
||||||
@@ -62,9 +62,9 @@ Date: May 28, 2008
|
|||||||
that that URL holds.
|
that that URL holds.
|
||||||
|
|
||||||
All HTTP replies contain a set of headers that are normally hidden, use
|
All HTTP replies contain a set of headers that are normally hidden, use
|
||||||
curl's -i option to display them as well as the rest of the document. You can
|
curl's --include (-i) option to display them as well as the rest of the
|
||||||
also ask the remote server for ONLY the headers by using the -I option (which
|
document. You can also ask the remote server for ONLY the headers by using the
|
||||||
will make curl issue a HEAD request).
|
--head (-I) option (which will make curl issue a HEAD request).
|
||||||
|
|
||||||
4. Forms
|
4. Forms
|
||||||
|
|
||||||
@@ -103,7 +103,7 @@ Date: May 28, 2008
|
|||||||
To make curl do the GET form post for you, just enter the expected created
|
To make curl do the GET form post for you, just enter the expected created
|
||||||
URL:
|
URL:
|
||||||
|
|
||||||
curl "www.hotmail.com/when/junk.cgi?birthyear=1905&press=OK"
|
curl "http://www.hotmail.com/when/junk.cgi?birthyear=1905&press=OK"
|
||||||
|
|
||||||
4.2 POST
|
4.2 POST
|
||||||
|
|
||||||
@@ -127,7 +127,7 @@ Date: May 28, 2008
|
|||||||
And to use curl to post this form with the same data filled in as before, we
|
And to use curl to post this form with the same data filled in as before, we
|
||||||
could do it like:
|
could do it like:
|
||||||
|
|
||||||
curl -d "birthyear=1905&press=%20OK%20" www.hotmail.com/when/junk.cgi
|
curl --data "birthyear=1905&press=%20OK%20" http://www.hotmail.com/when/junk.cgi
|
||||||
|
|
||||||
This kind of POST will use the Content-Type
|
This kind of POST will use the Content-Type
|
||||||
application/x-www-form-urlencoded and is the most widely used POST kind.
|
application/x-www-form-urlencoded and is the most widely used POST kind.
|
||||||
@@ -139,7 +139,7 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
Recent curl versions can in fact url-encode POST data for you, like this:
|
Recent curl versions can in fact url-encode POST data for you, like this:
|
||||||
|
|
||||||
curl --data-urlencode "name=I am Daniel" www.example.com
|
curl --data-urlencode "name=I am Daniel" http://www.example.com
|
||||||
|
|
||||||
4.3 File Upload POST
|
4.3 File Upload POST
|
||||||
|
|
||||||
@@ -160,7 +160,7 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
To post to a form like this with curl, you enter a command line like:
|
To post to a form like this with curl, you enter a command line like:
|
||||||
|
|
||||||
curl -F upload=@localfilename -F press=OK [URL]
|
curl --form upload=@localfilename --form press=OK [URL]
|
||||||
|
|
||||||
4.4 Hidden Fields
|
4.4 Hidden Fields
|
||||||
|
|
||||||
@@ -181,7 +181,7 @@ Date: May 28, 2008
|
|||||||
To post this with curl, you won't have to think about if the fields are
|
To post this with curl, you won't have to think about if the fields are
|
||||||
hidden or not. To curl they're all the same:
|
hidden or not. To curl they're all the same:
|
||||||
|
|
||||||
curl -d "birthyear=1905&press=OK&person=daniel" [URL]
|
curl --data "birthyear=1905&press=OK&person=daniel" [URL]
|
||||||
|
|
||||||
4.5 Figure Out What A POST Looks Like
|
4.5 Figure Out What A POST Looks Like
|
||||||
|
|
||||||
@@ -204,7 +204,7 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
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 --upload-file uploadfile http://www.uploadhttp.com/receive.cgi
|
||||||
|
|
||||||
6. HTTP Authentication
|
6. HTTP Authentication
|
||||||
|
|
||||||
@@ -217,7 +217,7 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
To tell curl to use a user and password for authentication:
|
To tell curl to use a user and password for authentication:
|
||||||
|
|
||||||
curl -u name:password www.secrets.com
|
curl --user name:password http://www.secrets.com
|
||||||
|
|
||||||
The site might require a different authentication method (check the headers
|
The site might require a different authentication method (check the headers
|
||||||
returned by the server), and then --ntlm, --digest, --negotiate or even
|
returned by the server), and then --ntlm, --digest, --negotiate or even
|
||||||
@@ -228,7 +228,7 @@ Date: May 28, 2008
|
|||||||
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 --proxy-user proxyuser:proxypassword curl.haxx.se
|
||||||
|
|
||||||
If your proxy requires the authentication to be done using the NTLM method,
|
If your proxy requires the authentication to be done using the NTLM method,
|
||||||
use --proxy-ntlm, if it requires Digest use --proxy-digest.
|
use --proxy-ntlm, if it requires Digest use --proxy-digest.
|
||||||
@@ -257,7 +257,7 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
Use curl to set the referer field with:
|
Use curl to set the referer field with:
|
||||||
|
|
||||||
curl -e http://curl.haxx.se daniel.haxx.se
|
curl --referer http://curl.haxx.se http://daniel.haxx.se
|
||||||
|
|
||||||
8. User Agent
|
8. User Agent
|
||||||
|
|
||||||
@@ -275,11 +275,11 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
To make curl look like Internet Explorer on a Windows 2000 box:
|
To make curl look like Internet Explorer on a Windows 2000 box:
|
||||||
|
|
||||||
curl -A "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)" [URL]
|
curl --user-agent "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)" [URL]
|
||||||
|
|
||||||
Or why not look like you're using Netscape 4.73 on a Linux (PIII) box:
|
Or why not look like you're using Netscape 4.73 on a Linux (PIII) box:
|
||||||
|
|
||||||
curl -A "Mozilla/4.73 [en] (X11; U; Linux 2.2.15 i686)" [URL]
|
curl --user-agent "Mozilla/4.73 [en] (X11; U; Linux 2.2.15 i686)" [URL]
|
||||||
|
|
||||||
9. Redirects
|
9. Redirects
|
||||||
|
|
||||||
@@ -294,11 +294,12 @@ Date: May 28, 2008
|
|||||||
|
|
||||||
To tell curl to follow a Location:
|
To tell curl to follow a Location:
|
||||||
|
|
||||||
curl -L www.sitethatredirects.com
|
curl --location http://www.sitethatredirects.com
|
||||||
|
|
||||||
If you use curl to POST to a site that immediately redirects you to another
|
If you use curl to POST to a site that immediately redirects you to another
|
||||||
page, you can safely use -L and -d/-F together. Curl will only use POST in
|
page, you can safely use --location (-L) and --data/--form together. Curl will
|
||||||
the first request, and then revert to GET in the following operations.
|
only use POST in the first request, and then revert to GET in the following
|
||||||
|
operations.
|
||||||
|
|
||||||
10. Cookies
|
10. Cookies
|
||||||
|
|
||||||
@@ -320,16 +321,16 @@ Date: May 28, 2008
|
|||||||
The simplest way to send a few cookies to the server when getting a page with
|
The simplest way to send a few cookies to the server when getting a page with
|
||||||
curl is to add them on the command line like:
|
curl is to add them on the command line like:
|
||||||
|
|
||||||
curl -b "name=Daniel" www.cookiesite.com
|
curl --cookie "name=Daniel" http://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 --dump-header (-D) option like:
|
||||||
|
|
||||||
curl -D headers_and_cookies www.cookiesite.com
|
curl --dump-header headers_and_cookies http://www.cookiesite.com
|
||||||
|
|
||||||
(Take note that the -c option described below is a better way to store
|
(Take note that the --cookie-jar option described below is a better way to
|
||||||
cookies.)
|
store cookies.)
|
||||||
|
|
||||||
Curl has a full blown cookie parsing engine built-in that comes to use if you
|
Curl has a full blown cookie parsing engine built-in that comes to use if you
|
||||||
want to reconnect to a server and use cookies that were stored from a
|
want to reconnect to a server and use cookies that were stored from a
|
||||||
@@ -337,24 +338,24 @@ Date: May 28, 2008
|
|||||||
believing you had a previous connection). To use previously stored cookies,
|
believing you had a previous connection). To use previously stored cookies,
|
||||||
you run curl like:
|
you run curl like:
|
||||||
|
|
||||||
curl -b stored_cookies_in_file www.cookiesite.com
|
curl --cookie stored_cookies_in_file http://www.cookiesite.com
|
||||||
|
|
||||||
Curl's "cookie engine" gets enabled when you use the -b option. If you only
|
Curl's "cookie engine" gets enabled when you use the --cookie option. If you
|
||||||
want curl to understand received cookies, use -b with a file that doesn't
|
only want curl to understand received cookies, use --cookie with a file that
|
||||||
exist. Example, if you want to let curl understand cookies from a page and
|
doesn't exist. Example, if you want to let curl understand cookies from a page
|
||||||
follow a location (and thus possibly send back cookies it received), you can
|
and follow a location (and thus possibly send back cookies it received), you
|
||||||
invoke it like:
|
can invoke it like:
|
||||||
|
|
||||||
curl -b nada -L www.cookiesite.com
|
curl --cookie nada --location http://www.cookiesite.com
|
||||||
|
|
||||||
Curl has the ability to read and write cookie files that use the same file
|
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
|
format that Netscape and Mozilla do. It is a convenient way to share cookies
|
||||||
between browsers and automatic scripts. The -b switch automatically detects
|
between browsers and automatic scripts. The --cookie (-b) switch automatically
|
||||||
if a given file is such a cookie file and parses it, and by using the
|
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
|
--cookie-jar (-c) option you'll make curl write a new cookie file at the end of
|
||||||
an operation:
|
an operation:
|
||||||
|
|
||||||
curl -b cookies.txt -c newcookies.txt www.cookiesite.com
|
curl --cookie cookies.txt --cookie-jar newcookies.txt http://www.cookiesite.com
|
||||||
|
|
||||||
11. HTTPS
|
11. HTTPS
|
||||||
|
|
||||||
@@ -381,13 +382,13 @@ Date: May 28, 2008
|
|||||||
can be specified on the command line or if not, entered interactively when
|
can be specified on the command line or if not, entered interactively when
|
||||||
curl queries for it. Use a certificate with curl on a HTTPS server like:
|
curl queries for it. Use a certificate with curl on a HTTPS server like:
|
||||||
|
|
||||||
curl -E mycert.pem https://that.secure.server.com
|
curl --cert mycert.pem https://that.secure.server.com
|
||||||
|
|
||||||
curl also tries to verify that the server is who it claims to be, by
|
curl also tries to verify that the server is who it claims to be, by
|
||||||
verifying the server's certificate against a locally stored CA cert
|
verifying the server's certificate against a locally stored CA cert
|
||||||
bundle. Failing the verification will cause curl to deny the connection. You
|
bundle. Failing the verification will cause curl to deny the connection. You
|
||||||
must then use -k in case you want to tell curl to ignore that the server
|
must then use --insecure (-k) in case you want to tell curl to ignore that
|
||||||
can't be verified.
|
the server can't be verified.
|
||||||
|
|
||||||
More about server certificate verification and ca cert bundles can be read
|
More about server certificate verification and ca cert bundles can be read
|
||||||
in the SSLCERTS document, available online here:
|
in the SSLCERTS document, available online here:
|
||||||
@@ -402,17 +403,17 @@ Date: May 28, 2008
|
|||||||
For example, you can change the POST request to a PROPFIND and send the data
|
For example, you can change the POST request to a PROPFIND and send the data
|
||||||
as "Content-Type: text/xml" (instead of the default Content-Type) like this:
|
as "Content-Type: text/xml" (instead of the default Content-Type) like this:
|
||||||
|
|
||||||
curl -d "<xml>" -H "Content-Type: text/xml" -X PROPFIND url.com
|
curl --data "<xml>" --header "Content-Type: text/xml" --request PROPFIND url.com
|
||||||
|
|
||||||
You can delete a default header by providing one without content. Like you
|
You can delete a default header by providing one without content. Like you
|
||||||
can ruin the request by chopping off the Host: header:
|
can ruin the request by chopping off the Host: header:
|
||||||
|
|
||||||
curl -H "Host:" http://mysite.com
|
curl --header "Host:" http://mysite.com
|
||||||
|
|
||||||
You can add headers the same way. Your server may want a "Destination:"
|
You can add headers the same way. Your server may want a "Destination:"
|
||||||
header, and you can add it:
|
header, and you can add it:
|
||||||
|
|
||||||
curl -H "Destination: http://moo.com/nowhere" http://url.com
|
curl --header "Destination: http://moo.com/nowhere" http://url.com
|
||||||
|
|
||||||
13. Web Login
|
13. Web Login
|
||||||
|
|
||||||
@@ -456,8 +457,8 @@ Date: May 28, 2008
|
|||||||
* Use the --trace-ascii option to store fully detailed logs of the requests
|
* Use the --trace-ascii option to store fully detailed logs of the requests
|
||||||
for easier analyzing and better understanding
|
for easier analyzing and better understanding
|
||||||
|
|
||||||
* Make sure you check for and use cookies when needed (both reading with -b
|
* Make sure you check for and use cookies when needed (both reading with
|
||||||
and writing with -c)
|
--cookie and writing with --cookie-jar)
|
||||||
|
|
||||||
* Set user-agent to one like a recent popular browser does
|
* Set user-agent to one like a recent popular browser does
|
||||||
|
|
||||||
|
71
docs/curl.1
71
docs/curl.1
@@ -29,8 +29,9 @@ curl \- transfer a URL
|
|||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
.B curl
|
.B curl
|
||||||
is a tool to transfer data from or to a server, using one of the supported
|
is a tool to transfer data from or to a server, using one of the supported
|
||||||
protocols (HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, DICT, TELNET, LDAP or
|
protocols (DICT, FILE, FTP, FTPS, GOPHER, HTTP, HTTPS, IMAP, IMAPS, LDAP,
|
||||||
FILE). The command is designed to work without user interaction.
|
LDAPS, POP3, POP3S, RTMP, RTSP, SCP, SFTP, SMTP, SMTPS, TELNET and TFTP). The
|
||||||
|
command is designed to work without user interaction.
|
||||||
|
|
||||||
curl offers a busload of useful tricks like proxy support, user
|
curl offers a busload of useful tricks like proxy support, user
|
||||||
authentication, FTP upload, HTTP post, SSL connections, cookies, file transfer
|
authentication, FTP upload, HTTP post, SSL connections, cookies, file transfer
|
||||||
@@ -55,16 +56,16 @@ or you can get sequences of alphanumeric series by using [] as in:
|
|||||||
ftp://ftp.numericals.com/file[001-100].txt (with leading zeros)
|
ftp://ftp.numericals.com/file[001-100].txt (with leading zeros)
|
||||||
ftp://ftp.letters.com/file[a-z].txt
|
ftp://ftp.letters.com/file[a-z].txt
|
||||||
|
|
||||||
No nesting of the sequences is supported at the moment, but you can use
|
Nested sequences are not supported, but you can use several ones next to each
|
||||||
several ones next to each other:
|
other:
|
||||||
|
|
||||||
http://any.org/archive[1996-1999]/vol[1-4]/part{a,b,c}.html
|
http://any.org/archive[1996-1999]/vol[1-4]/part{a,b,c}.html
|
||||||
|
|
||||||
You can specify any amount of URLs on the command line. They will be fetched
|
You can specify any amount of URLs on the command line. They will be fetched
|
||||||
in a sequential manner in the specified order.
|
in a sequential manner in the specified order.
|
||||||
|
|
||||||
Since curl 7.15.1 you can also specify a step counter for the ranges, so that
|
You can specify a step counter for the ranges to get every Nth number or
|
||||||
you can get every Nth number or letter:
|
letter:
|
||||||
|
|
||||||
http://www.numericals.com/file[1-100:10].txt
|
http://www.numericals.com/file[1-100:10].txt
|
||||||
http://www.letters.com/file[a-z:2].txt
|
http://www.letters.com/file[a-z:2].txt
|
||||||
@@ -87,8 +88,8 @@ invokes.
|
|||||||
curl normally displays a progress meter during operations, indicating the amount
|
curl normally displays a progress meter during operations, indicating the amount
|
||||||
of transferred data, transfer speeds and estimated time left, etc.
|
of transferred data, transfer speeds and estimated time left, etc.
|
||||||
|
|
||||||
However, since curl displays this data to the terminal by default, if you invoke
|
curl displays this data to the terminal by default, so if you invoke curl to
|
||||||
curl to do an operation and it is about to write data to the terminal, it
|
do an operation and it is about to write data to the terminal, it
|
||||||
\fIdisables\fP the progress meter as otherwise it would mess up the output
|
\fIdisables\fP the progress meter as otherwise it would mess up the output
|
||||||
mixing progress meter and response data.
|
mixing progress meter and response data.
|
||||||
|
|
||||||
@@ -300,8 +301,8 @@ away. EPRT and LPRT are extensions to the original FTP protocol, and may not wor
|
|||||||
on all servers, but they enable more functionality in a better way than the
|
on all servers, but they enable more functionality in a better way than the
|
||||||
traditional PORT command.
|
traditional PORT command.
|
||||||
|
|
||||||
Since curl 7.19.0, \fB--eprt\fP can be used to explicitly enable EPRT again
|
\fB--eprt\fP can be used to explicitly enable EPRT again and \fB--no-eprt\fP
|
||||||
and \fB--no-eprt\fP is an alias for \fB--disable-eprt\fP.
|
is an alias for \fB--disable-eprt\fP.
|
||||||
|
|
||||||
Disabling EPRT only changes the active behavior. If you want to switch to
|
Disabling EPRT only changes the active behavior. If you want to switch to
|
||||||
passive mode you need to not use \fI-P/--ftp-port\fP or force it with
|
passive mode you need to not use \fI-P/--ftp-port\fP or force it with
|
||||||
@@ -311,8 +312,8 @@ passive mode you need to not use \fI-P/--ftp-port\fP or force it with
|
|||||||
transfers. Curl will normally always first attempt to use EPSV before PASV,
|
transfers. Curl will normally always first attempt to use EPSV before PASV,
|
||||||
but with this option, it will not try using EPSV.
|
but with this option, it will not try using EPSV.
|
||||||
|
|
||||||
Since curl 7.19.0, \fB--epsv\fP can be used to explicitly enable EPRT again
|
\fB--epsv\fP can be used to explicitly enable EPRT again and \fB--no-epsv\fP
|
||||||
and \fB--no-epsv\fP is an alias for \fB--disable-epsv\fP.
|
is an alias for \fB--disable-epsv\fP.
|
||||||
|
|
||||||
Disabling EPSV only changes the passive behavior. If you want to switch to
|
Disabling EPSV only changes the passive behavior. If you want to switch to
|
||||||
active mode you need to use \fI-P/--ftp-port\fP.
|
active mode you need to use \fI-P/--ftp-port\fP.
|
||||||
@@ -927,6 +928,52 @@ in web browsers, so curl does the conversion by default to maintain
|
|||||||
consistency. However, a server may require a POST to remain a POST after such
|
consistency. However, a server may require a POST to remain a POST after such
|
||||||
a redirection. This option is meaningful only when using \fI-L/--location\fP
|
a redirection. This option is meaningful only when using \fI-L/--location\fP
|
||||||
(Added in 7.19.1)
|
(Added in 7.19.1)
|
||||||
|
.IP "--proto <protocols>"
|
||||||
|
Tells curl to use the listed protocols for its initial retrieval. Protocols
|
||||||
|
are evaluated left to right, are comma separated, and are each a protocol
|
||||||
|
name or 'all', optionally prefixed by zero or more modifiers. Available
|
||||||
|
modifiers are:
|
||||||
|
.RS
|
||||||
|
.TP 3
|
||||||
|
.B +
|
||||||
|
Permit this protocol in addition to protocols already permitted (this is
|
||||||
|
the default if no modifier is used).
|
||||||
|
.TP
|
||||||
|
.B -
|
||||||
|
Deny this protocol, removing it from the list of protocols already permitted.
|
||||||
|
.TP
|
||||||
|
.B =
|
||||||
|
Permit only this protocol (ignoring the list already permitted), though
|
||||||
|
subject to later modification by subsequent entries in the comma separated
|
||||||
|
list.
|
||||||
|
.RE
|
||||||
|
.IP
|
||||||
|
For example:
|
||||||
|
.RS
|
||||||
|
.TP 15
|
||||||
|
.B --proto -ftps
|
||||||
|
uses the default protocols, but disables ftps
|
||||||
|
.TP
|
||||||
|
.B --proto -all,https,+http
|
||||||
|
only enables http and https
|
||||||
|
.TP
|
||||||
|
.B --proto =http,https
|
||||||
|
also only enables http and https
|
||||||
|
.RE
|
||||||
|
.IP
|
||||||
|
Unknown protocols produce a warning. This allows scripts to safely rely on
|
||||||
|
being able to disable potentially dangerous protocols, without relying upon
|
||||||
|
support for that protocol being built into curl to avoid an error.
|
||||||
|
|
||||||
|
This option can be used multiple times, in which case the effect is the same
|
||||||
|
as concatenating the protocols into one instance of the option.
|
||||||
|
|
||||||
|
(Added in 7.20.2)
|
||||||
|
.IP "--proto-redir <protocols>"
|
||||||
|
Tells curl to use the listed protocols after a redirect. See --proto for
|
||||||
|
how protocols are represented.
|
||||||
|
|
||||||
|
(Added in 7.20.2)
|
||||||
.IP "--proxy-anyauth"
|
.IP "--proxy-anyauth"
|
||||||
Tells curl to pick a suitable authentication method when communicating with
|
Tells curl to pick a suitable authentication method when communicating with
|
||||||
the given proxy. This might cause an extra request/response round-trip. (Added
|
the given proxy. This might cause an extra request/response round-trip. (Added
|
||||||
|
32
docs/examples/.gitignore
vendored
Normal file
32
docs/examples/.gitignore
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
10-at-a-time
|
||||||
|
anyauthput
|
||||||
|
certinfo
|
||||||
|
chkspeed
|
||||||
|
cookie_interface
|
||||||
|
debug
|
||||||
|
fileupload
|
||||||
|
fopen
|
||||||
|
ftp-wildcard
|
||||||
|
ftpget
|
||||||
|
ftpgetinfo
|
||||||
|
ftpgetresp
|
||||||
|
ftpupload
|
||||||
|
getinfo
|
||||||
|
getinmemory
|
||||||
|
http-post
|
||||||
|
httpcustomheader
|
||||||
|
httpput
|
||||||
|
https
|
||||||
|
multi-app
|
||||||
|
multi-debugcallback
|
||||||
|
multi-double
|
||||||
|
multi-post
|
||||||
|
multi-single
|
||||||
|
persistant
|
||||||
|
post-callback
|
||||||
|
postit2
|
||||||
|
sendrecv
|
||||||
|
sepheaders
|
||||||
|
simple
|
||||||
|
simplepost
|
||||||
|
simplessl
|
@@ -119,7 +119,7 @@ int main(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
while (U) {
|
while (U) {
|
||||||
while (CURLM_CALL_MULTI_PERFORM == curl_multi_perform(cm, &U));
|
curl_multi_perform(cm, &U);
|
||||||
|
|
||||||
if (U) {
|
if (U) {
|
||||||
FD_ZERO(&R);
|
FD_ZERO(&R);
|
||||||
|
@@ -1,16 +1,12 @@
|
|||||||
# These are all libcurl example programs to be test compiled
|
# These are all libcurl example programs to be test compiled
|
||||||
check_PROGRAMS = 10-at-a-time anyauthput cookie_interface \
|
check_PROGRAMS = 10-at-a-time anyauthput cookie_interface debug fileupload \
|
||||||
debug fileupload fopen ftpget ftpgetresp ftpupload \
|
fopen ftpget ftpgetresp ftpupload getinfo getinmemory http-post httpput \
|
||||||
getinfo getinmemory http-post httpput \
|
https multi-app multi-debugcallback multi-double multi-post multi-single \
|
||||||
https multi-app multi-debugcallback multi-double \
|
persistant post-callback postit2 sepheaders simple simplepost simplessl \
|
||||||
multi-post multi-single persistant post-callback \
|
sendrecv httpcustomheader certinfo chkspeed ftpgetinfo ftp-wildcard
|
||||||
postit2 sepheaders simple simplepost simplessl \
|
|
||||||
sendrecv httpcustomheader certinfo chkspeed ftpgetinfo
|
|
||||||
|
|
||||||
# These examples require external dependencies that may not be commonly
|
# These examples require external dependencies that may not be commonly
|
||||||
# available on POSIX systems, so don't bother attempting to compile them here.
|
# available on POSIX systems, so don't bother attempting to compile them here.
|
||||||
COMPLICATED_EXAMPLES = \
|
COMPLICATED_EXAMPLES = curlgtk.c curlx.c htmltitle.cc cacertinmem.c \
|
||||||
curlgtk.c curlx.c htmltitle.cc cacertinmem.c ftpuploadresume.c \
|
ftpuploadresume.c ghiper.c hiperfifo.c htmltidy.c multithread.c \
|
||||||
ghiper.c hiperfifo.c htmltidy.c multithread.c \
|
|
||||||
opensslthreadlock.c sampleconv.c synctime.c threaded-ssl.c evhiperfifo.c
|
opensslthreadlock.c sampleconv.c synctime.c threaded-ssl.c evhiperfifo.c
|
||||||
|
|
||||||
|
@@ -111,7 +111,7 @@ int main(void)
|
|||||||
rv=curl_easy_setopt(ch,CURLOPT_WRITEHEADER, stderr);
|
rv=curl_easy_setopt(ch,CURLOPT_WRITEHEADER, stderr);
|
||||||
rv=curl_easy_setopt(ch,CURLOPT_SSLCERTTYPE,"PEM");
|
rv=curl_easy_setopt(ch,CURLOPT_SSLCERTTYPE,"PEM");
|
||||||
rv=curl_easy_setopt(ch,CURLOPT_SSL_VERIFYPEER,1L);
|
rv=curl_easy_setopt(ch,CURLOPT_SSL_VERIFYPEER,1L);
|
||||||
rv=curl_easy_setopt(ch, CURLOPT_URL, "https://www.cacert.org/");
|
rv=curl_easy_setopt(ch, CURLOPT_URL, "https://www.example.com/");
|
||||||
|
|
||||||
/* first try: retrieve page without cacerts' certificate -> will fail
|
/* first try: retrieve page without cacerts' certificate -> will fail
|
||||||
*/
|
*/
|
||||||
|
@@ -20,7 +20,7 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "https://www.networking4all.com/");
|
curl_easy_setopt(curl, CURLOPT_URL, "https://www.example.com/");
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, wrfu);
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, wrfu);
|
||||||
|
|
||||||
|
@@ -40,6 +40,8 @@ static size_t WriteCallback(void *ptr, size_t size, size_t nmemb, void *data)
|
|||||||
{
|
{
|
||||||
/* we are not interested in the downloaded bytes itself,
|
/* we are not interested in the downloaded bytes itself,
|
||||||
so we only return the size we would have saved ... */
|
so we only return the size we would have saved ... */
|
||||||
|
(void)ptr; /* unused */
|
||||||
|
(void)data; /* unused */
|
||||||
return (size_t)(size * nmemb);
|
return (size_t)(size * nmemb);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -48,7 +50,7 @@ int main(int argc, char *argv[])
|
|||||||
CURL *curl_handle;
|
CURL *curl_handle;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
int prtsep = 0, prttime = 0;
|
int prtsep = 0, prttime = 0;
|
||||||
char *url = URL_1M;
|
const char *url = URL_1M;
|
||||||
char *appname = argv[0];
|
char *appname = argv[0];
|
||||||
|
|
||||||
if (argc > 1) {
|
if (argc > 1) {
|
||||||
@@ -135,17 +137,17 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
/* check for bytes downloaded */
|
/* check for bytes downloaded */
|
||||||
res = curl_easy_getinfo(curl_handle, CURLINFO_SIZE_DOWNLOAD, &val);
|
res = curl_easy_getinfo(curl_handle, CURLINFO_SIZE_DOWNLOAD, &val);
|
||||||
if((CURLE_OK == res) && val)
|
if((CURLE_OK == res) && (val>0))
|
||||||
printf("Data downloaded: %0.0f bytes.\n", val);
|
printf("Data downloaded: %0.0f bytes.\n", val);
|
||||||
|
|
||||||
/* check for total download time */
|
/* check for total download time */
|
||||||
res = curl_easy_getinfo(curl_handle, CURLINFO_TOTAL_TIME, &val);
|
res = curl_easy_getinfo(curl_handle, CURLINFO_TOTAL_TIME, &val);
|
||||||
if((CURLE_OK == res) && val)
|
if((CURLE_OK == res) && (val>0))
|
||||||
printf("Total download time: %0.3f sec.\n", val);
|
printf("Total download time: %0.3f sec.\n", val);
|
||||||
|
|
||||||
/* check for average download speed */
|
/* check for average download speed */
|
||||||
res = curl_easy_getinfo(curl_handle, CURLINFO_SPEED_DOWNLOAD, &val);
|
res = curl_easy_getinfo(curl_handle, CURLINFO_SPEED_DOWNLOAD, &val);
|
||||||
if((CURLE_OK == res) && val)
|
if((CURLE_OK == res) && (val>0))
|
||||||
printf("Average download speed: %0.3f kbyte/sec.\n", val / 1024);
|
printf("Average download speed: %0.3f kbyte/sec.\n", val / 1024);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@@ -53,7 +53,7 @@ main(void)
|
|||||||
if (curl) {
|
if (curl) {
|
||||||
char nline[256];
|
char nline[256];
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://www.google.com/"); /* google.com sets "PREF" cookie */
|
curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.com/");
|
||||||
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
||||||
curl_easy_setopt(curl, CURLOPT_COOKIEFILE, ""); /* just to start the cookie engine */
|
curl_easy_setopt(curl, CURLOPT_COOKIEFILE, ""); /* just to start the cookie engine */
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
@@ -118,7 +118,7 @@ int main(void)
|
|||||||
/* the DEBUGFUNCTION has no effect until we enable VERBOSE */
|
/* the DEBUGFUNCTION has no effect until we enable VERBOSE */
|
||||||
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/");
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
|
@@ -68,7 +68,6 @@ typedef struct _GlobalInfo
|
|||||||
struct ev_io fifo_event;
|
struct ev_io fifo_event;
|
||||||
struct ev_timer timer_event;
|
struct ev_timer timer_event;
|
||||||
CURLM *multi;
|
CURLM *multi;
|
||||||
int prev_running;
|
|
||||||
int still_running;
|
int still_running;
|
||||||
FILE* input;
|
FILE* input;
|
||||||
} GlobalInfo;
|
} GlobalInfo;
|
||||||
@@ -122,7 +121,6 @@ static void mcode_or_die(const char *where, CURLMcode code)
|
|||||||
switch ( code )
|
switch ( code )
|
||||||
{
|
{
|
||||||
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
||||||
case CURLM_OK: s="CURLM_OK"; break;
|
|
||||||
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
||||||
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
||||||
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
||||||
@@ -144,39 +142,20 @@ static void mcode_or_die(const char *where, CURLMcode code)
|
|||||||
|
|
||||||
|
|
||||||
/* Check for completed transfers, and remove their easy handles */
|
/* Check for completed transfers, and remove their easy handles */
|
||||||
static void check_run_count(GlobalInfo *g)
|
static void check_multi_info(GlobalInfo *g)
|
||||||
{
|
{
|
||||||
DPRINT("%s prev %i still %i\n", __PRETTY_FUNCTION__,
|
char *eff_url;
|
||||||
g->prev_running, g->still_running);
|
|
||||||
if ( g->prev_running > g->still_running )
|
|
||||||
{
|
|
||||||
char *eff_url=NULL;
|
|
||||||
CURLMsg *msg;
|
CURLMsg *msg;
|
||||||
int msgs_left;
|
int msgs_left;
|
||||||
ConnInfo *conn=NULL;
|
ConnInfo *conn;
|
||||||
CURL *easy;
|
CURL *easy;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
|
|
||||||
fprintf(MSG_OUT, "REMAINING: %d\n", g->still_running);
|
fprintf(MSG_OUT, "REMAINING: %d\n", g->still_running);
|
||||||
/*
|
while ((msg = curl_multi_info_read(g->multi, &msgs_left))) {
|
||||||
I am still uncertain whether it is safe to remove an easy
|
if (msg->msg == CURLMSG_DONE) {
|
||||||
handle from inside the curl_multi_info_read loop, so here I
|
|
||||||
will search for completed transfers in the inner "while"
|
|
||||||
loop, and then remove them in the outer "do-while" loop...
|
|
||||||
*/
|
|
||||||
do
|
|
||||||
{
|
|
||||||
easy=NULL;
|
|
||||||
while ( (msg = curl_multi_info_read(g->multi, &msgs_left)) )
|
|
||||||
{
|
|
||||||
if ( msg->msg == CURLMSG_DONE )
|
|
||||||
{
|
|
||||||
easy = msg->easy_handle;
|
easy = msg->easy_handle;
|
||||||
res = msg->data.result;
|
res = msg->data.result;
|
||||||
}
|
|
||||||
|
|
||||||
if ( easy )
|
|
||||||
{
|
|
||||||
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
||||||
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
||||||
fprintf(MSG_OUT, "DONE: %s => (%d) %s\n", eff_url, res, conn->error);
|
fprintf(MSG_OUT, "DONE: %s => (%d) %s\n", eff_url, res, conn->error);
|
||||||
@@ -186,12 +165,10 @@ static void check_run_count(GlobalInfo *g)
|
|||||||
free(conn);
|
free(conn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} while ( easy );
|
|
||||||
}
|
|
||||||
g->prev_running = g->still_running;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Called by libevent when we get action on a multi socket */
|
/* Called by libevent when we get action on a multi socket */
|
||||||
static void event_cb(EV_P_ struct ev_io *w, int revents)
|
static void event_cb(EV_P_ struct ev_io *w, int revents)
|
||||||
{
|
{
|
||||||
@@ -201,12 +178,9 @@ static void event_cb(EV_P_ struct ev_io *w, int revents)
|
|||||||
|
|
||||||
int action = (revents&EV_READ?CURL_POLL_IN:0)|
|
int action = (revents&EV_READ?CURL_POLL_IN:0)|
|
||||||
(revents&EV_WRITE?CURL_POLL_OUT:0);
|
(revents&EV_WRITE?CURL_POLL_OUT:0);
|
||||||
do
|
|
||||||
{
|
|
||||||
rc = curl_multi_socket_action(g->multi, w->fd, action, &g->still_running);
|
rc = curl_multi_socket_action(g->multi, w->fd, action, &g->still_running);
|
||||||
} while ( rc == CURLM_CALL_MULTI_PERFORM );
|
mcode_or_die("event_cb: curl_multi_socket_action", rc);
|
||||||
mcode_or_die("event_cb: curl_multi_socket", rc);
|
check_multi_info(g);
|
||||||
check_run_count(g);
|
|
||||||
if ( g->still_running <= 0 )
|
if ( g->still_running <= 0 )
|
||||||
{
|
{
|
||||||
fprintf(MSG_OUT, "last transfer done, kill timeout\n");
|
fprintf(MSG_OUT, "last transfer done, kill timeout\n");
|
||||||
@@ -222,12 +196,9 @@ static void timer_cb(EV_P_ struct ev_timer *w, int revents)
|
|||||||
GlobalInfo *g = (GlobalInfo *)w->data;
|
GlobalInfo *g = (GlobalInfo *)w->data;
|
||||||
CURLMcode rc;
|
CURLMcode rc;
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
rc = curl_multi_socket_action(g->multi, CURL_SOCKET_TIMEOUT, 0, &g->still_running);
|
rc = curl_multi_socket_action(g->multi, CURL_SOCKET_TIMEOUT, 0, &g->still_running);
|
||||||
} while ( rc == CURLM_CALL_MULTI_PERFORM );
|
mcode_or_die("timer_cb: curl_multi_socket_action", rc);
|
||||||
mcode_or_die("timer_cb: curl_multi_socket", rc);
|
check_multi_info(g);
|
||||||
check_run_count(g);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Clean up the SockInfo structure */
|
/* Clean up the SockInfo structure */
|
||||||
@@ -367,8 +338,8 @@ static void new_conn(char *url, GlobalInfo *g )
|
|||||||
rc = curl_multi_add_handle(g->multi, conn->easy);
|
rc = curl_multi_add_handle(g->multi, conn->easy);
|
||||||
mcode_or_die("new_conn: curl_multi_add_handle", rc);
|
mcode_or_die("new_conn: curl_multi_add_handle", rc);
|
||||||
|
|
||||||
mcode_or_die("new_conn: curl_multi_socket_all", rc);
|
/* note that the add_handle() will set a time-out to trigger very soon so
|
||||||
check_run_count(g);
|
that the necessary socket_action() call will be called by this app */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This gets called whenever data is received from the fifo */
|
/* This gets called whenever data is received from the fifo */
|
||||||
@@ -448,10 +419,9 @@ int main(int argc, char **argv)
|
|||||||
curl_multi_setopt(g.multi, CURLMOPT_SOCKETDATA, &g);
|
curl_multi_setopt(g.multi, CURLMOPT_SOCKETDATA, &g);
|
||||||
curl_multi_setopt(g.multi, CURLMOPT_TIMERFUNCTION, multi_timer_cb);
|
curl_multi_setopt(g.multi, CURLMOPT_TIMERFUNCTION, multi_timer_cb);
|
||||||
curl_multi_setopt(g.multi, CURLMOPT_TIMERDATA, &g);
|
curl_multi_setopt(g.multi, CURLMOPT_TIMERDATA, &g);
|
||||||
do
|
|
||||||
{
|
/* we don't call any curl_multi_socket*() function yet as we have no handles
|
||||||
rc = curl_multi_socket_all(g.multi, &g.still_running);
|
added! */
|
||||||
} while ( CURLM_CALL_MULTI_PERFORM == rc );
|
|
||||||
|
|
||||||
ev_loop(g.loop, 0);
|
ev_loop(g.loop, 0);
|
||||||
curl_multi_cleanup(g.multi);
|
curl_multi_cleanup(g.multi);
|
||||||
|
@@ -131,7 +131,6 @@ fill_buffer(URL_FILE *file,int want,int waittime)
|
|||||||
fd_set fdread;
|
fd_set fdread;
|
||||||
fd_set fdwrite;
|
fd_set fdwrite;
|
||||||
fd_set fdexcep;
|
fd_set fdexcep;
|
||||||
int maxfd;
|
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
@@ -144,6 +143,9 @@ fill_buffer(URL_FILE *file,int want,int waittime)
|
|||||||
/* attempt to fill buffer */
|
/* attempt to fill buffer */
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
int maxfd = -1;
|
||||||
|
long curl_timeo = -1;
|
||||||
|
|
||||||
FD_ZERO(&fdread);
|
FD_ZERO(&fdread);
|
||||||
FD_ZERO(&fdwrite);
|
FD_ZERO(&fdwrite);
|
||||||
FD_ZERO(&fdexcep);
|
FD_ZERO(&fdexcep);
|
||||||
@@ -152,12 +154,23 @@ fill_buffer(URL_FILE *file,int want,int waittime)
|
|||||||
timeout.tv_sec = 60; /* 1 minute */
|
timeout.tv_sec = 60; /* 1 minute */
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
curl_multi_timeout(multi_handle, &curl_timeo);
|
||||||
|
if(curl_timeo >= 0) {
|
||||||
|
timeout.tv_sec = curl_timeo / 1000;
|
||||||
|
if(timeout.tv_sec > 1)
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
else
|
||||||
|
timeout.tv_usec = (curl_timeo % 1000) * 1000;
|
||||||
|
}
|
||||||
|
|
||||||
/* get file descriptors from the transfers */
|
/* get file descriptors from the transfers */
|
||||||
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
/* In a real-world program you OF COURSE check the return code of the
|
/* In a real-world program you OF COURSE check the return code of the
|
||||||
function calls, *and* you make sure that maxfd is bigger than -1
|
function calls. On success, the value of maxfd is guaranteed to be
|
||||||
so that the call to select() below makes sense! */
|
greater or equal than -1. We call select(maxfd + 1, ...), specially
|
||||||
|
in case of (maxfd == -1), we call select(0, ...), which is basically
|
||||||
|
equal to sleep. */
|
||||||
|
|
||||||
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
@@ -171,12 +184,7 @@ fill_buffer(URL_FILE *file,int want,int waittime)
|
|||||||
|
|
||||||
default:
|
default:
|
||||||
/* timeout or readable/writable sockets */
|
/* timeout or readable/writable sockets */
|
||||||
/* note we *could* be more efficient and not wait for
|
curl_multi_perform(multi_handle, &file->still_running);
|
||||||
* CURLM_CALL_MULTI_PERFORM to clear here and check it on re-entry
|
|
||||||
* but that gets messy */
|
|
||||||
while(curl_multi_perform(multi_handle, &file->still_running) ==
|
|
||||||
CURLM_CALL_MULTI_PERFORM);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} while(file->still_running && (file->buffer_pos < want));
|
} while(file->still_running && (file->buffer_pos < want));
|
||||||
@@ -247,8 +255,7 @@ url_fopen(const char *url,const char *operation)
|
|||||||
curl_multi_add_handle(multi_handle, file->handle.curl);
|
curl_multi_add_handle(multi_handle, file->handle.curl);
|
||||||
|
|
||||||
/* lets start the fetch */
|
/* lets start the fetch */
|
||||||
while(curl_multi_perform(multi_handle, &file->still_running) ==
|
curl_multi_perform(multi_handle, &file->still_running);
|
||||||
CURLM_CALL_MULTI_PERFORM );
|
|
||||||
|
|
||||||
if((file->buffer_pos == 0) && (!file->still_running))
|
if((file->buffer_pos == 0) && (!file->still_running))
|
||||||
{
|
{
|
||||||
|
135
docs/examples/ftp-wildcard.c
Normal file
135
docs/examples/ftp-wildcard.c
Normal file
@@ -0,0 +1,135 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
struct callback_data {
|
||||||
|
FILE *output;
|
||||||
|
};
|
||||||
|
|
||||||
|
static long file_is_comming(struct curl_fileinfo *finfo,
|
||||||
|
struct callback_data *data,
|
||||||
|
int remains);
|
||||||
|
|
||||||
|
static long file_is_downloaded(struct callback_data *data);
|
||||||
|
|
||||||
|
static size_t write_it(char *buff, size_t size, size_t nmemb,
|
||||||
|
struct callback_data *data);
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int rc = CURLE_OK;
|
||||||
|
|
||||||
|
/* curl easy handle */
|
||||||
|
CURL *handle;
|
||||||
|
|
||||||
|
/* help data */
|
||||||
|
struct callback_data data = { 0 };
|
||||||
|
|
||||||
|
/* global initialization */
|
||||||
|
rc = curl_global_init(CURL_GLOBAL_ALL);
|
||||||
|
if(rc)
|
||||||
|
return rc;
|
||||||
|
|
||||||
|
/* initialization of easy handle */
|
||||||
|
handle = curl_easy_init();
|
||||||
|
if(!handle) {
|
||||||
|
curl_global_cleanup();
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* turn on wildcard matching */
|
||||||
|
curl_easy_setopt(handle, CURLOPT_WILDCARDMATCH, 1L);
|
||||||
|
|
||||||
|
/* callback is called before download of concrete file started */
|
||||||
|
curl_easy_setopt(handle, CURLOPT_CHUNK_BGN_FUNCTION, file_is_comming);
|
||||||
|
|
||||||
|
/* callback is called after data from the file have been transferred */
|
||||||
|
curl_easy_setopt(handle, CURLOPT_CHUNK_END_FUNCTION, file_is_downloaded);
|
||||||
|
|
||||||
|
/* this callback will write contents into files */
|
||||||
|
curl_easy_setopt(handle, CURLOPT_WRITEFUNCTION, write_it);
|
||||||
|
|
||||||
|
/* put transfer data into callbacks */
|
||||||
|
curl_easy_setopt(handle, CURLOPT_CHUNK_DATA, &data);
|
||||||
|
curl_easy_setopt(handle, CURLOPT_WRITEDATA, &data);
|
||||||
|
|
||||||
|
/* curl_easy_setopt(handle, CURLOPT_VERBOSE, 1L); */
|
||||||
|
|
||||||
|
/* set an URL containing wildcard pattern (only in the last part) */
|
||||||
|
if(argc == 2)
|
||||||
|
curl_easy_setopt(handle, CURLOPT_URL, argv[1]);
|
||||||
|
else
|
||||||
|
curl_easy_setopt(handle, CURLOPT_URL, "ftp://example.com/test/*");
|
||||||
|
|
||||||
|
/* and start transfer! */
|
||||||
|
rc = curl_easy_perform(handle);
|
||||||
|
|
||||||
|
curl_easy_cleanup(handle);
|
||||||
|
curl_global_cleanup();
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
static long file_is_comming(struct curl_fileinfo *finfo,
|
||||||
|
struct callback_data *data,
|
||||||
|
int remains)
|
||||||
|
{
|
||||||
|
printf("%3d %40s %10luB ", remains, finfo->filename,
|
||||||
|
(unsigned long)finfo->size);
|
||||||
|
|
||||||
|
switch(finfo->filetype) {
|
||||||
|
case CURLFILETYPE_DIRECTORY:
|
||||||
|
printf(" DIR\n");
|
||||||
|
break;
|
||||||
|
case CURLFILETYPE_FILE:
|
||||||
|
printf("FILE ");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("OTHER\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(finfo->filetype == CURLFILETYPE_FILE) {
|
||||||
|
/* do not transfer files >= 50B */
|
||||||
|
if(finfo->size > 50) {
|
||||||
|
printf("SKIPPED\n");
|
||||||
|
return CURL_CHUNK_BGN_FUNC_SKIP;
|
||||||
|
}
|
||||||
|
|
||||||
|
data->output = fopen(finfo->filename, "w");
|
||||||
|
if(!data->output) {
|
||||||
|
return CURL_CHUNK_BGN_FUNC_FAIL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return CURL_CHUNK_BGN_FUNC_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static long file_is_downloaded(struct callback_data *data)
|
||||||
|
{
|
||||||
|
if(data->output) {
|
||||||
|
printf("DOWNLOADED\n");
|
||||||
|
fclose(data->output);
|
||||||
|
data->output = 0x0;
|
||||||
|
}
|
||||||
|
return CURL_CHUNK_END_FUNC_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static size_t write_it(char *buff, size_t size, size_t nmemb,
|
||||||
|
struct callback_data *data)
|
||||||
|
{
|
||||||
|
size_t written = 0;
|
||||||
|
if(data->output)
|
||||||
|
written = fwrite(buff, size, nmemb, data->output);
|
||||||
|
else
|
||||||
|
/* listing output */
|
||||||
|
written = fwrite(buff, size, nmemb, stdout);
|
||||||
|
return written;
|
||||||
|
}
|
@@ -52,12 +52,10 @@ int main(void)
|
|||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/*
|
/*
|
||||||
* Get curl 7.9.2 from sunet.se's FTP site. curl 7.9.2 is most likely not
|
* You better replace the URL with one that works!
|
||||||
* present there by the time you read this, so you'd better replace the
|
|
||||||
* URL with one that works!
|
|
||||||
*/
|
*/
|
||||||
curl_easy_setopt(curl, CURLOPT_URL,
|
curl_easy_setopt(curl, CURLOPT_URL,
|
||||||
"ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz");
|
"ftp://ftp.example.com/pub/www/utilities/curl/curl-7.9.2.tar.gz");
|
||||||
/* Define our callback to get called when there's data to be written */
|
/* Define our callback to get called when there's data to be written */
|
||||||
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, my_fwrite);
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, my_fwrite);
|
||||||
/* Set a pointer to our struct to pass to the callback */
|
/* Set a pointer to our struct to pass to the callback */
|
||||||
|
@@ -28,8 +28,7 @@ static size_t throw_away(void *ptr, size_t size, size_t nmemb, void *data)
|
|||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
/* Check for binutils 2.19.1 from ftp.gnu.org's FTP site. */
|
char ftpurl[] = "ftp://ftp.example.com/gnu/binutils/binutils-2.19.1.tar.bz2";
|
||||||
char ftpurl[] = "ftp://ftp.gnu.org/gnu/binutils/binutils-2.19.1.tar.bz2";
|
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
const time_t filetime;
|
const time_t filetime;
|
||||||
|
@@ -43,7 +43,7 @@ int main(int argc, char **argv)
|
|||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* Get a file listing from sunet */
|
/* Get a file listing from sunet */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "ftp://ftp.sunet.se/");
|
curl_easy_setopt(curl, CURLOPT_URL, "ftp://ftp.example.com/");
|
||||||
curl_easy_setopt(curl, CURLOPT_WRITEDATA, ftpfile);
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, ftpfile);
|
||||||
/* If you intend to use this on windows with a libcurl DLL, you must use
|
/* If you intend to use this on windows with a libcurl DLL, you must use
|
||||||
CURLOPT_WRITEFUNCTION as well */
|
CURLOPT_WRITEFUNCTION as well */
|
||||||
|
@@ -30,7 +30,7 @@
|
|||||||
|
|
||||||
#define LOCAL_FILE "/tmp/uploadthis.txt"
|
#define LOCAL_FILE "/tmp/uploadthis.txt"
|
||||||
#define UPLOAD_FILE_AS "while-uploading.txt"
|
#define UPLOAD_FILE_AS "while-uploading.txt"
|
||||||
#define REMOTE_URL "ftp://localhost/" UPLOAD_FILE_AS
|
#define REMOTE_URL "ftp://example.com/" UPLOAD_FILE_AS
|
||||||
#define RENAME_FILE_TO "renamed-and-fine.txt"
|
#define RENAME_FILE_TO "renamed-and-fine.txt"
|
||||||
|
|
||||||
/* NOTE: if you want this example to work on Windows with libcurl as a
|
/* NOTE: if you want this example to work on Windows with libcurl as a
|
||||||
|
@@ -32,7 +32,8 @@ int __cdecl _snscanf(const char * input, size_t length, const char * format, ...
|
|||||||
|
|
||||||
|
|
||||||
/* parse headers for Content-Length */
|
/* parse headers for Content-Length */
|
||||||
size_t getcontentlengthfunc(void *ptr, size_t size, size_t nmemb, void *stream) {
|
size_t getcontentlengthfunc(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
|
{
|
||||||
int r;
|
int r;
|
||||||
long len = 0;
|
long len = 0;
|
||||||
|
|
||||||
@@ -46,7 +47,8 @@ size_t getcontentlengthfunc(void *ptr, size_t size, size_t nmemb, void *stream)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* discard downloaded data */
|
/* discard downloaded data */
|
||||||
size_t discardfunc(void *ptr, size_t size, size_t nmemb, void *stream) {
|
size_t discardfunc(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
|
{
|
||||||
return size * nmemb;
|
return size * nmemb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -143,13 +145,14 @@ int upload(CURL *curlhandle, const char * remotepath, const char * localpath,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int c, char **argv) {
|
int main(int c, char **argv)
|
||||||
|
{
|
||||||
CURL *curlhandle = NULL;
|
CURL *curlhandle = NULL;
|
||||||
|
|
||||||
curl_global_init(CURL_GLOBAL_ALL);
|
curl_global_init(CURL_GLOBAL_ALL);
|
||||||
curlhandle = curl_easy_init();
|
curlhandle = curl_easy_init();
|
||||||
|
|
||||||
upload(curlhandle, "ftp://user:pass@host/path/file", "C:\\file", 0, 3);
|
upload(curlhandle, "ftp://user:pass@example.com/path/file", "C:\\file", 0, 3);
|
||||||
|
|
||||||
curl_easy_cleanup(curlhandle);
|
curl_easy_cleanup(curlhandle);
|
||||||
curl_global_cleanup();
|
curl_global_cleanup();
|
||||||
|
@@ -19,7 +19,7 @@ int main(void)
|
|||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_setopt.html#CURLOPTURL */
|
/* http://curl.haxx.se/libcurl/c/curl_easy_setopt.html#CURLOPTURL */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.com/");
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_perform.html */
|
/* http://curl.haxx.se/libcurl/c/curl_easy_perform.html */
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
@@ -8,8 +8,6 @@
|
|||||||
*
|
*
|
||||||
* Example source code to show how the callback function can be used to
|
* Example source code to show how the callback function can be used to
|
||||||
* download data into a chunk of memory instead of storing it in a file.
|
* download data into a chunk of memory instead of storing it in a file.
|
||||||
*
|
|
||||||
* This exact source code has not been verified to work.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@@ -17,25 +15,12 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <curl/types.h>
|
|
||||||
#include <curl/easy.h>
|
|
||||||
|
|
||||||
struct MemoryStruct {
|
struct MemoryStruct {
|
||||||
char *memory;
|
char *memory;
|
||||||
size_t size;
|
size_t size;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void *myrealloc(void *ptr, size_t size);
|
|
||||||
|
|
||||||
static void *myrealloc(void *ptr, size_t size)
|
|
||||||
{
|
|
||||||
/* There might be a realloc() out there that doesn't like reallocing
|
|
||||||
NULL pointers, so we take care of it here */
|
|
||||||
if(ptr)
|
|
||||||
return realloc(ptr, size);
|
|
||||||
else
|
|
||||||
return malloc(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
static size_t
|
static size_t
|
||||||
WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
|
WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
@@ -43,22 +28,28 @@ WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
|
|||||||
size_t realsize = size * nmemb;
|
size_t realsize = size * nmemb;
|
||||||
struct MemoryStruct *mem = (struct MemoryStruct *)data;
|
struct MemoryStruct *mem = (struct MemoryStruct *)data;
|
||||||
|
|
||||||
mem->memory = myrealloc(mem->memory, mem->size + realsize + 1);
|
mem->memory = realloc(mem->memory, mem->size + realsize + 1);
|
||||||
if (mem->memory) {
|
if (mem->memory == NULL) {
|
||||||
|
/* out of memory! */
|
||||||
|
printf("not enough memory (realloc returned NULL)\n");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
|
||||||
memcpy(&(mem->memory[mem->size]), ptr, realsize);
|
memcpy(&(mem->memory[mem->size]), ptr, realsize);
|
||||||
mem->size += realsize;
|
mem->size += realsize;
|
||||||
mem->memory[mem->size] = 0;
|
mem->memory[mem->size] = 0;
|
||||||
}
|
|
||||||
return realsize;
|
return realsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
CURL *curl_handle;
|
CURL *curl_handle;
|
||||||
|
|
||||||
struct MemoryStruct chunk;
|
struct MemoryStruct chunk;
|
||||||
|
|
||||||
chunk.memory=NULL; /* we expect realloc(NULL, size) to work */
|
chunk.memory = malloc(1); /* will be grown as needed by the realloc above */
|
||||||
chunk.size = 0; /* no data at this point */
|
chunk.size = 0; /* no data at this point */
|
||||||
|
|
||||||
curl_global_init(CURL_GLOBAL_ALL);
|
curl_global_init(CURL_GLOBAL_ALL);
|
||||||
@@ -67,7 +58,7 @@ int main(int argc, char **argv)
|
|||||||
curl_handle = curl_easy_init();
|
curl_handle = curl_easy_init();
|
||||||
|
|
||||||
/* specify URL to get */
|
/* specify URL to get */
|
||||||
curl_easy_setopt(curl_handle, CURLOPT_URL, "http://cool.haxx.se/");
|
curl_easy_setopt(curl_handle, CURLOPT_URL, "http://www.example.com/");
|
||||||
|
|
||||||
/* send all data to this function */
|
/* send all data to this function */
|
||||||
curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
@@ -96,6 +87,8 @@ int main(int argc, char **argv)
|
|||||||
* you're done with it, you should free() it as a nice application.
|
* you're done with it, you should free() it as a nice application.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
printf("%lu bytes retrieved\n", chunk.size);
|
||||||
|
|
||||||
if(chunk.memory)
|
if(chunk.memory)
|
||||||
free(chunk.memory);
|
free(chunk.memory);
|
||||||
|
|
||||||
|
@@ -58,10 +58,7 @@ callback.
|
|||||||
typedef struct _GlobalInfo {
|
typedef struct _GlobalInfo {
|
||||||
CURLM *multi;
|
CURLM *multi;
|
||||||
guint timer_event;
|
guint timer_event;
|
||||||
int prev_running;
|
|
||||||
int still_running;
|
int still_running;
|
||||||
int requested; /* count: curl_easy_init() */
|
|
||||||
int completed; /* count: curl_easy_cleanup() */
|
|
||||||
} GlobalInfo;
|
} GlobalInfo;
|
||||||
|
|
||||||
|
|
||||||
@@ -95,7 +92,6 @@ static void mcode_or_die(const char *where, CURLMcode code) {
|
|||||||
const char *s;
|
const char *s;
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
||||||
case CURLM_OK: s="CURLM_OK"; break;
|
|
||||||
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
||||||
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
||||||
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
||||||
@@ -113,62 +109,43 @@ static void mcode_or_die(const char *where, CURLMcode code) {
|
|||||||
|
|
||||||
|
|
||||||
/* Check for completed transfers, and remove their easy handles */
|
/* Check for completed transfers, and remove their easy handles */
|
||||||
static void check_run_count(GlobalInfo *g)
|
static void check_multi_info(GlobalInfo *g)
|
||||||
{
|
{
|
||||||
if (g->prev_running > g->still_running) {
|
char *eff_url;
|
||||||
char *eff_url=NULL;
|
|
||||||
CURLMsg *msg;
|
CURLMsg *msg;
|
||||||
int msgs_left;
|
int msgs_left;
|
||||||
ConnInfo *conn=NULL;
|
ConnInfo *conn;
|
||||||
CURL *easy;
|
CURL *easy;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
|
|
||||||
MSG_OUT("REMAINING: %d\n", g->still_running);
|
MSG_OUT("REMAINING: %d\n", g->still_running);
|
||||||
/*
|
|
||||||
I am still uncertain whether it is safe to remove an easy handle
|
|
||||||
from inside the curl_multi_info_read loop, so here I will search
|
|
||||||
for completed transfers in the inner "while" loop, and then remove
|
|
||||||
them in the outer "do-while" loop...
|
|
||||||
*/
|
|
||||||
do {
|
|
||||||
easy=NULL;
|
|
||||||
while ((msg = curl_multi_info_read(g->multi, &msgs_left))) {
|
while ((msg = curl_multi_info_read(g->multi, &msgs_left))) {
|
||||||
if (msg->msg == CURLMSG_DONE) {
|
if (msg->msg == CURLMSG_DONE) {
|
||||||
easy = msg->easy_handle;
|
easy = msg->easy_handle;
|
||||||
res = msg->data.result;
|
res = msg->data.result;
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (easy) {
|
|
||||||
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
||||||
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
||||||
MSG_OUT("DONE: %s => (%d) %s\n", eff_url, res, conn->error);
|
MSG_OUT("DONE: %s => (%d) %s\n", eff_url, res, conn->error);
|
||||||
curl_multi_remove_handle(g->multi, easy);
|
curl_multi_remove_handle(g->multi, easy);
|
||||||
g_free(conn->url);
|
free(conn->url);
|
||||||
curl_easy_cleanup(easy);
|
curl_easy_cleanup(easy);
|
||||||
g_free(conn);
|
free(conn);
|
||||||
g->completed++;
|
|
||||||
}
|
}
|
||||||
} while ( easy );
|
|
||||||
MSG_OUT("Requested: %d Completed:%d\n", g->requested, g->completed);
|
|
||||||
}
|
}
|
||||||
g->prev_running = g->still_running;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Called by glib when our timeout expires */
|
/* Called by glib when our timeout expires */
|
||||||
static gboolean timer_cb(gpointer data)
|
static gboolean timer_cb(gpointer data)
|
||||||
{
|
{
|
||||||
GlobalInfo *g = (GlobalInfo *)data;
|
GlobalInfo *g = (GlobalInfo *)data;
|
||||||
CURLMcode rc;
|
CURLMcode rc;
|
||||||
|
|
||||||
do {
|
rc = curl_multi_socket_action(g->multi,
|
||||||
rc = curl_multi_socket(g->multi, CURL_SOCKET_TIMEOUT, &g->still_running);
|
CURL_SOCKET_TIMEOUT, 0, &g->still_running);
|
||||||
} while (rc == CURLM_CALL_MULTI_PERFORM);
|
mcode_or_die("timer_cb: curl_multi_socket_action", rc);
|
||||||
mcode_or_die("timer_cb: curl_multi_socket", rc);
|
check_multi_info(g);
|
||||||
check_run_count(g);
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -198,11 +175,15 @@ static gboolean event_cb(GIOChannel *ch, GIOCondition condition, gpointer data)
|
|||||||
GlobalInfo *g = (GlobalInfo*) data;
|
GlobalInfo *g = (GlobalInfo*) data;
|
||||||
CURLMcode rc;
|
CURLMcode rc;
|
||||||
int fd=g_io_channel_unix_get_fd(ch);
|
int fd=g_io_channel_unix_get_fd(ch);
|
||||||
do {
|
|
||||||
rc = curl_multi_socket(g->multi, fd, &g->still_running);
|
int action =
|
||||||
} while (rc == CURLM_CALL_MULTI_PERFORM);
|
(condition & G_IO_IN ? CURL_CSELECT_IN : 0) |
|
||||||
mcode_or_die("event_cb: curl_multi_socket", rc);
|
(condition & G_IO_OUT ? CURL_CSELECT_OUT : 0);
|
||||||
check_run_count(g);
|
|
||||||
|
rc = curl_multi_socket_action(g->multi, fd, action, &g->still_running);
|
||||||
|
mcode_or_die("event_cb: curl_multi_socket_action", rc);
|
||||||
|
|
||||||
|
check_multi_info(g);
|
||||||
if(g->still_running) {
|
if(g->still_running) {
|
||||||
return TRUE;
|
return TRUE;
|
||||||
} else {
|
} else {
|
||||||
@@ -338,12 +319,9 @@ static void new_conn(char *url, GlobalInfo *g )
|
|||||||
MSG_OUT("Adding easy %p to multi %p (%s)\n", conn->easy, g->multi, url);
|
MSG_OUT("Adding easy %p to multi %p (%s)\n", conn->easy, g->multi, url);
|
||||||
rc =curl_multi_add_handle(g->multi, conn->easy);
|
rc =curl_multi_add_handle(g->multi, conn->easy);
|
||||||
mcode_or_die("new_conn: curl_multi_add_handle", rc);
|
mcode_or_die("new_conn: curl_multi_add_handle", rc);
|
||||||
g->requested++;
|
|
||||||
do {
|
/* note that the add_handle() will set a time-out to trigger very soon so
|
||||||
rc = curl_multi_socket_all(g->multi, &g->still_running);
|
that the necessary socket_action() call will be called by this app */
|
||||||
} while (CURLM_CALL_MULTI_PERFORM == rc);
|
|
||||||
mcode_or_die("new_conn: curl_multi_socket_all", rc);
|
|
||||||
check_run_count(g);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -451,9 +429,10 @@ int main(int argc, char **argv)
|
|||||||
curl_multi_setopt(g->multi, CURLMOPT_SOCKETDATA, g);
|
curl_multi_setopt(g->multi, CURLMOPT_SOCKETDATA, g);
|
||||||
curl_multi_setopt(g->multi, CURLMOPT_TIMERFUNCTION, update_timeout_cb);
|
curl_multi_setopt(g->multi, CURLMOPT_TIMERFUNCTION, update_timeout_cb);
|
||||||
curl_multi_setopt(g->multi, CURLMOPT_TIMERDATA, g);
|
curl_multi_setopt(g->multi, CURLMOPT_TIMERDATA, g);
|
||||||
do {
|
|
||||||
rc = curl_multi_socket_all(g->multi, &g->still_running);
|
/* we don't call any curl_multi_socket*() function yet as we have no handles
|
||||||
} while (CURLM_CALL_MULTI_PERFORM == rc);
|
added! */
|
||||||
|
|
||||||
g_main_loop_run(gmain);
|
g_main_loop_run(gmain);
|
||||||
curl_multi_cleanup(g->multi);
|
curl_multi_cleanup(g->multi);
|
||||||
return 0;
|
return 0;
|
||||||
|
@@ -62,7 +62,6 @@ typedef struct _GlobalInfo {
|
|||||||
struct event fifo_event;
|
struct event fifo_event;
|
||||||
struct event timer_event;
|
struct event timer_event;
|
||||||
CURLM *multi;
|
CURLM *multi;
|
||||||
int prev_running;
|
|
||||||
int still_running;
|
int still_running;
|
||||||
FILE* input;
|
FILE* input;
|
||||||
} GlobalInfo;
|
} GlobalInfo;
|
||||||
@@ -110,7 +109,6 @@ static void mcode_or_die(const char *where, CURLMcode code)
|
|||||||
const char *s;
|
const char *s;
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
||||||
case CURLM_OK: s="CURLM_OK"; break;
|
|
||||||
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
||||||
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
||||||
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
||||||
@@ -132,33 +130,20 @@ static void mcode_or_die(const char *where, CURLMcode code)
|
|||||||
|
|
||||||
|
|
||||||
/* Check for completed transfers, and remove their easy handles */
|
/* Check for completed transfers, and remove their easy handles */
|
||||||
static void check_run_count(GlobalInfo *g)
|
static void check_multi_info(GlobalInfo *g)
|
||||||
{
|
{
|
||||||
if (g->prev_running > g->still_running) {
|
char *eff_url;
|
||||||
char *eff_url=NULL;
|
|
||||||
CURLMsg *msg;
|
CURLMsg *msg;
|
||||||
int msgs_left;
|
int msgs_left;
|
||||||
ConnInfo *conn=NULL;
|
ConnInfo *conn;
|
||||||
CURL *easy;
|
CURL *easy;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
|
|
||||||
fprintf(MSG_OUT, "REMAINING: %d\n", g->still_running);
|
fprintf(MSG_OUT, "REMAINING: %d\n", g->still_running);
|
||||||
/*
|
|
||||||
I am still uncertain whether it is safe to remove an easy handle
|
|
||||||
from inside the curl_multi_info_read loop, so here I will search
|
|
||||||
for completed transfers in the inner "while" loop, and then remove
|
|
||||||
them in the outer "do-while" loop...
|
|
||||||
*/
|
|
||||||
do {
|
|
||||||
easy=NULL;
|
|
||||||
while ((msg = curl_multi_info_read(g->multi, &msgs_left))) {
|
while ((msg = curl_multi_info_read(g->multi, &msgs_left))) {
|
||||||
if (msg->msg == CURLMSG_DONE) {
|
if (msg->msg == CURLMSG_DONE) {
|
||||||
easy = msg->easy_handle;
|
easy = msg->easy_handle;
|
||||||
res = msg->data.result;
|
res = msg->data.result;
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (easy) {
|
|
||||||
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
||||||
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
||||||
fprintf(MSG_OUT, "DONE: %s => (%d) %s\n", eff_url, res, conn->error);
|
fprintf(MSG_OUT, "DONE: %s => (%d) %s\n", eff_url, res, conn->error);
|
||||||
@@ -167,9 +152,7 @@ static void check_run_count(GlobalInfo *g)
|
|||||||
curl_easy_cleanup(easy);
|
curl_easy_cleanup(easy);
|
||||||
free(conn);
|
free(conn);
|
||||||
}
|
}
|
||||||
} while ( easy );
|
|
||||||
}
|
}
|
||||||
g->prev_running = g->still_running;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -184,13 +167,10 @@ static void event_cb(int fd, short kind, void *userp)
|
|||||||
(kind & EV_READ ? CURL_CSELECT_IN : 0) |
|
(kind & EV_READ ? CURL_CSELECT_IN : 0) |
|
||||||
(kind & EV_WRITE ? CURL_CSELECT_OUT : 0);
|
(kind & EV_WRITE ? CURL_CSELECT_OUT : 0);
|
||||||
|
|
||||||
do {
|
|
||||||
rc = curl_multi_socket_action(g->multi, fd, action, &g->still_running);
|
rc = curl_multi_socket_action(g->multi, fd, action, &g->still_running);
|
||||||
} while (rc == CURLM_CALL_MULTI_PERFORM);
|
|
||||||
|
|
||||||
mcode_or_die("event_cb: curl_multi_socket_action", rc);
|
mcode_or_die("event_cb: curl_multi_socket_action", rc);
|
||||||
|
|
||||||
check_run_count(g);
|
check_multi_info(g);
|
||||||
if ( g->still_running <= 0 ) {
|
if ( g->still_running <= 0 ) {
|
||||||
fprintf(MSG_OUT, "last transfer done, kill timeout\n");
|
fprintf(MSG_OUT, "last transfer done, kill timeout\n");
|
||||||
if (evtimer_pending(&g->timer_event, NULL)) {
|
if (evtimer_pending(&g->timer_event, NULL)) {
|
||||||
@@ -209,12 +189,10 @@ static void timer_cb(int fd, short kind, void *userp)
|
|||||||
(void)fd;
|
(void)fd;
|
||||||
(void)kind;
|
(void)kind;
|
||||||
|
|
||||||
do {
|
|
||||||
rc = curl_multi_socket_action(g->multi,
|
rc = curl_multi_socket_action(g->multi,
|
||||||
CURL_SOCKET_TIMEOUT, 0, &g->still_running);
|
CURL_SOCKET_TIMEOUT, 0, &g->still_running);
|
||||||
} while (rc == CURLM_CALL_MULTI_PERFORM);
|
|
||||||
mcode_or_die("timer_cb: curl_multi_socket_action", rc);
|
mcode_or_die("timer_cb: curl_multi_socket_action", rc);
|
||||||
check_run_count(g);
|
check_multi_info(g);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -17,7 +17,7 @@ int main(void)
|
|||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "https://sourceforge.net/");
|
curl_easy_setopt(curl, CURLOPT_URL, "https://example.com/");
|
||||||
|
|
||||||
#ifdef SKIP_PEER_VERIFICATION
|
#ifdef SKIP_PEER_VERIFICATION
|
||||||
/*
|
/*
|
||||||
|
@@ -43,9 +43,9 @@ int main(int argc, char **argv)
|
|||||||
handles[i] = curl_easy_init();
|
handles[i] = curl_easy_init();
|
||||||
|
|
||||||
/* set the options (I left out a few, you'll get the point anyway) */
|
/* set the options (I left out a few, you'll get the point anyway) */
|
||||||
curl_easy_setopt(handles[HTTP_HANDLE], CURLOPT_URL, "http://website.com");
|
curl_easy_setopt(handles[HTTP_HANDLE], CURLOPT_URL, "http://example.com");
|
||||||
|
|
||||||
curl_easy_setopt(handles[FTP_HANDLE], CURLOPT_URL, "ftp://ftpsite.com");
|
curl_easy_setopt(handles[FTP_HANDLE], CURLOPT_URL, "ftp://example.com");
|
||||||
curl_easy_setopt(handles[FTP_HANDLE], CURLOPT_UPLOAD, 1L);
|
curl_easy_setopt(handles[FTP_HANDLE], CURLOPT_UPLOAD, 1L);
|
||||||
|
|
||||||
/* init a multi stack */
|
/* init a multi stack */
|
||||||
@@ -56,8 +56,7 @@ int main(int argc, char **argv)
|
|||||||
curl_multi_add_handle(multi_handle, handles[i]);
|
curl_multi_add_handle(multi_handle, handles[i]);
|
||||||
|
|
||||||
/* we start some action by calling perform right away */
|
/* we start some action by calling perform right away */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
|
|
||||||
while(still_running) {
|
while(still_running) {
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
@@ -66,7 +65,9 @@ int main(int argc, char **argv)
|
|||||||
fd_set fdread;
|
fd_set fdread;
|
||||||
fd_set fdwrite;
|
fd_set fdwrite;
|
||||||
fd_set fdexcep;
|
fd_set fdexcep;
|
||||||
int maxfd;
|
int maxfd = -1;
|
||||||
|
|
||||||
|
long curl_timeo = -1;
|
||||||
|
|
||||||
FD_ZERO(&fdread);
|
FD_ZERO(&fdread);
|
||||||
FD_ZERO(&fdwrite);
|
FD_ZERO(&fdwrite);
|
||||||
@@ -76,12 +77,23 @@ int main(int argc, char **argv)
|
|||||||
timeout.tv_sec = 1;
|
timeout.tv_sec = 1;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
curl_multi_timeout(multi_handle, &curl_timeo);
|
||||||
|
if(curl_timeo >= 0) {
|
||||||
|
timeout.tv_sec = curl_timeo / 1000;
|
||||||
|
if(timeout.tv_sec > 1)
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
else
|
||||||
|
timeout.tv_usec = (curl_timeo % 1000) * 1000;
|
||||||
|
}
|
||||||
|
|
||||||
/* get file descriptors from the transfers */
|
/* get file descriptors from the transfers */
|
||||||
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
/* In a real-world program you OF COURSE check the return code of the
|
/* In a real-world program you OF COURSE check the return code of the
|
||||||
function calls, *and* you make sure that maxfd is bigger than -1 so
|
function calls. On success, the value of maxfd is guaranteed to be
|
||||||
that the call to select() below makes sense! */
|
greater or equal than -1. We call select(maxfd + 1, ...), specially in
|
||||||
|
case of (maxfd == -1), we call select(0, ...), which is basically equal
|
||||||
|
to sleep. */
|
||||||
|
|
||||||
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
@@ -95,8 +107,7 @@ int main(int argc, char **argv)
|
|||||||
default:
|
default:
|
||||||
/* one or more of curl's file descriptors say there's data to read
|
/* one or more of curl's file descriptors say there's data to read
|
||||||
or write */
|
or write */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -118,7 +118,7 @@ int main(int argc, char **argv)
|
|||||||
http_handle = curl_easy_init();
|
http_handle = curl_easy_init();
|
||||||
|
|
||||||
/* set the options (I left out a few, you'll get the point anyway) */
|
/* set the options (I left out a few, you'll get the point anyway) */
|
||||||
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.haxx.se/");
|
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.example.com/");
|
||||||
|
|
||||||
curl_easy_setopt(http_handle, CURLOPT_DEBUGFUNCTION, my_trace);
|
curl_easy_setopt(http_handle, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
curl_easy_setopt(http_handle, CURLOPT_VERBOSE, 1L);
|
curl_easy_setopt(http_handle, CURLOPT_VERBOSE, 1L);
|
||||||
@@ -130,8 +130,7 @@ int main(int argc, char **argv)
|
|||||||
curl_multi_add_handle(multi_handle, http_handle);
|
curl_multi_add_handle(multi_handle, http_handle);
|
||||||
|
|
||||||
/* we start some action by calling perform right away */
|
/* we start some action by calling perform right away */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
|
|
||||||
while(still_running) {
|
while(still_running) {
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
@@ -140,7 +139,9 @@ int main(int argc, char **argv)
|
|||||||
fd_set fdread;
|
fd_set fdread;
|
||||||
fd_set fdwrite;
|
fd_set fdwrite;
|
||||||
fd_set fdexcep;
|
fd_set fdexcep;
|
||||||
int maxfd;
|
int maxfd = -1;
|
||||||
|
|
||||||
|
long curl_timeo = -1;
|
||||||
|
|
||||||
FD_ZERO(&fdread);
|
FD_ZERO(&fdread);
|
||||||
FD_ZERO(&fdwrite);
|
FD_ZERO(&fdwrite);
|
||||||
@@ -150,12 +151,23 @@ int main(int argc, char **argv)
|
|||||||
timeout.tv_sec = 1;
|
timeout.tv_sec = 1;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
curl_multi_timeout(multi_handle, &curl_timeo);
|
||||||
|
if(curl_timeo >= 0) {
|
||||||
|
timeout.tv_sec = curl_timeo / 1000;
|
||||||
|
if(timeout.tv_sec > 1)
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
else
|
||||||
|
timeout.tv_usec = (curl_timeo % 1000) * 1000;
|
||||||
|
}
|
||||||
|
|
||||||
/* get file descriptors from the transfers */
|
/* get file descriptors from the transfers */
|
||||||
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
/* In a real-world program you OF COURSE check the return code of the
|
/* In a real-world program you OF COURSE check the return code of the
|
||||||
function calls, *and* you make sure that maxfd is bigger than -1
|
function calls. On success, the value of maxfd is guaranteed to be
|
||||||
so that the call to select() below makes sense! */
|
greater or equal than -1. We call select(maxfd + 1, ...), specially in
|
||||||
|
case of (maxfd == -1), we call select(0, ...), which is basically equal
|
||||||
|
to sleep. */
|
||||||
|
|
||||||
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
@@ -168,8 +180,7 @@ int main(int argc, char **argv)
|
|||||||
case 0:
|
case 0:
|
||||||
default:
|
default:
|
||||||
/* timeout or readable/writable sockets */
|
/* timeout or readable/writable sockets */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -34,7 +34,7 @@ int main(int argc, char **argv)
|
|||||||
http_handle2 = curl_easy_init();
|
http_handle2 = curl_easy_init();
|
||||||
|
|
||||||
/* set options */
|
/* set options */
|
||||||
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.haxx.se/");
|
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.example.com/");
|
||||||
|
|
||||||
/* set options */
|
/* set options */
|
||||||
curl_easy_setopt(http_handle2, CURLOPT_URL, "http://localhost/");
|
curl_easy_setopt(http_handle2, CURLOPT_URL, "http://localhost/");
|
||||||
@@ -47,8 +47,7 @@ int main(int argc, char **argv)
|
|||||||
curl_multi_add_handle(multi_handle, http_handle2);
|
curl_multi_add_handle(multi_handle, http_handle2);
|
||||||
|
|
||||||
/* we start some action by calling perform right away */
|
/* we start some action by calling perform right away */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
|
|
||||||
while(still_running) {
|
while(still_running) {
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
@@ -57,7 +56,9 @@ int main(int argc, char **argv)
|
|||||||
fd_set fdread;
|
fd_set fdread;
|
||||||
fd_set fdwrite;
|
fd_set fdwrite;
|
||||||
fd_set fdexcep;
|
fd_set fdexcep;
|
||||||
int maxfd;
|
int maxfd = -1;
|
||||||
|
|
||||||
|
long curl_timeo = -1;
|
||||||
|
|
||||||
FD_ZERO(&fdread);
|
FD_ZERO(&fdread);
|
||||||
FD_ZERO(&fdwrite);
|
FD_ZERO(&fdwrite);
|
||||||
@@ -67,12 +68,23 @@ int main(int argc, char **argv)
|
|||||||
timeout.tv_sec = 1;
|
timeout.tv_sec = 1;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
curl_multi_timeout(multi_handle, &curl_timeo);
|
||||||
|
if(curl_timeo >= 0) {
|
||||||
|
timeout.tv_sec = curl_timeo / 1000;
|
||||||
|
if(timeout.tv_sec > 1)
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
else
|
||||||
|
timeout.tv_usec = (curl_timeo % 1000) * 1000;
|
||||||
|
}
|
||||||
|
|
||||||
/* get file descriptors from the transfers */
|
/* get file descriptors from the transfers */
|
||||||
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
/* In a real-world program you OF COURSE check the return code of the
|
/* In a real-world program you OF COURSE check the return code of the
|
||||||
function calls, *and* you make sure that maxfd is bigger than -1 so
|
function calls. On success, the value of maxfd is guaranteed to be
|
||||||
that the call to select() below makes sense! */
|
greater or equal than -1. We call select(maxfd + 1, ...), specially in
|
||||||
|
case of (maxfd == -1), we call select(0, ...), which is basically equal
|
||||||
|
to sleep. */
|
||||||
|
|
||||||
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
@@ -83,8 +95,7 @@ int main(int argc, char **argv)
|
|||||||
case 0:
|
case 0:
|
||||||
default:
|
default:
|
||||||
/* timeout or readable/writable sockets */
|
/* timeout or readable/writable sockets */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -58,8 +58,7 @@ int main(int argc, char *argv[])
|
|||||||
if(curl && multi_handle) {
|
if(curl && multi_handle) {
|
||||||
|
|
||||||
/* what URL that receives this POST */
|
/* what URL that receives this POST */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL,
|
curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.com/upload.cgi");
|
||||||
"http://www.fillinyoururl.com/upload.cgi");
|
|
||||||
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
|
||||||
@@ -67,8 +66,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
curl_multi_add_handle(multi_handle, curl);
|
curl_multi_add_handle(multi_handle, curl);
|
||||||
|
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
|
|
||||||
while(still_running) {
|
while(still_running) {
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
@@ -77,7 +75,9 @@ int main(int argc, char *argv[])
|
|||||||
fd_set fdread;
|
fd_set fdread;
|
||||||
fd_set fdwrite;
|
fd_set fdwrite;
|
||||||
fd_set fdexcep;
|
fd_set fdexcep;
|
||||||
int maxfd;
|
int maxfd = -1;
|
||||||
|
|
||||||
|
long curl_timeo = -1;
|
||||||
|
|
||||||
FD_ZERO(&fdread);
|
FD_ZERO(&fdread);
|
||||||
FD_ZERO(&fdwrite);
|
FD_ZERO(&fdwrite);
|
||||||
@@ -87,12 +87,23 @@ int main(int argc, char *argv[])
|
|||||||
timeout.tv_sec = 1;
|
timeout.tv_sec = 1;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
curl_multi_timeout(multi_handle, &curl_timeo);
|
||||||
|
if(curl_timeo >= 0) {
|
||||||
|
timeout.tv_sec = curl_timeo / 1000;
|
||||||
|
if(timeout.tv_sec > 1)
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
else
|
||||||
|
timeout.tv_usec = (curl_timeo % 1000) * 1000;
|
||||||
|
}
|
||||||
|
|
||||||
/* get file descriptors from the transfers */
|
/* get file descriptors from the transfers */
|
||||||
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
/* In a real-world program you OF COURSE check the return code of the
|
/* In a real-world program you OF COURSE check the return code of the
|
||||||
function calls, *and* you make sure that maxfd is bigger than -1
|
function calls. On success, the value of maxfd is guaranteed to be
|
||||||
so that the call to select() below makes sense! */
|
greater or equal than -1. We call select(maxfd + 1, ...), specially in
|
||||||
|
case of (maxfd == -1), we call select(0, ...), which is basically equal
|
||||||
|
to sleep. */
|
||||||
|
|
||||||
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
@@ -105,8 +116,7 @@ int main(int argc, char *argv[])
|
|||||||
default:
|
default:
|
||||||
/* timeout or readable/writable sockets */
|
/* timeout or readable/writable sockets */
|
||||||
printf("perform!\n");
|
printf("perform!\n");
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
printf("running: %d!\n", still_running);
|
printf("running: %d!\n", still_running);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@@ -32,7 +32,7 @@ int main(int argc, char **argv)
|
|||||||
http_handle = curl_easy_init();
|
http_handle = curl_easy_init();
|
||||||
|
|
||||||
/* set the options (I left out a few, you'll get the point anyway) */
|
/* set the options (I left out a few, you'll get the point anyway) */
|
||||||
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.haxx.se/");
|
curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.example.com/");
|
||||||
|
|
||||||
/* init a multi stack */
|
/* init a multi stack */
|
||||||
multi_handle = curl_multi_init();
|
multi_handle = curl_multi_init();
|
||||||
@@ -41,8 +41,7 @@ int main(int argc, char **argv)
|
|||||||
curl_multi_add_handle(multi_handle, http_handle);
|
curl_multi_add_handle(multi_handle, http_handle);
|
||||||
|
|
||||||
/* we start some action by calling perform right away */
|
/* we start some action by calling perform right away */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
|
|
||||||
while(still_running) {
|
while(still_running) {
|
||||||
struct timeval timeout;
|
struct timeval timeout;
|
||||||
@@ -51,7 +50,9 @@ int main(int argc, char **argv)
|
|||||||
fd_set fdread;
|
fd_set fdread;
|
||||||
fd_set fdwrite;
|
fd_set fdwrite;
|
||||||
fd_set fdexcep;
|
fd_set fdexcep;
|
||||||
int maxfd;
|
int maxfd = -1;
|
||||||
|
|
||||||
|
long curl_timeo = -1;
|
||||||
|
|
||||||
FD_ZERO(&fdread);
|
FD_ZERO(&fdread);
|
||||||
FD_ZERO(&fdwrite);
|
FD_ZERO(&fdwrite);
|
||||||
@@ -61,12 +62,23 @@ int main(int argc, char **argv)
|
|||||||
timeout.tv_sec = 1;
|
timeout.tv_sec = 1;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
curl_multi_timeout(multi_handle, &curl_timeo);
|
||||||
|
if(curl_timeo >= 0) {
|
||||||
|
timeout.tv_sec = curl_timeo / 1000;
|
||||||
|
if(timeout.tv_sec > 1)
|
||||||
|
timeout.tv_sec = 1;
|
||||||
|
else
|
||||||
|
timeout.tv_usec = (curl_timeo % 1000) * 1000;
|
||||||
|
}
|
||||||
|
|
||||||
/* get file descriptors from the transfers */
|
/* get file descriptors from the transfers */
|
||||||
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
|
||||||
|
|
||||||
/* In a real-world program you OF COURSE check the return code of the
|
/* In a real-world program you OF COURSE check the return code of the
|
||||||
function calls, *and* you make sure that maxfd is bigger than -1 so
|
function calls. On success, the value of maxfd is guaranteed to be
|
||||||
that the call to select() below makes sense! */
|
greater or equal than -1. We call select(maxfd + 1, ...), specially in
|
||||||
|
case of (maxfd == -1), we call select(0, ...), which is basically equal
|
||||||
|
to sleep. */
|
||||||
|
|
||||||
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
|
||||||
|
|
||||||
@@ -79,8 +91,7 @@ int main(int argc, char **argv)
|
|||||||
case 0:
|
case 0:
|
||||||
default:
|
default:
|
||||||
/* timeout or readable/writable sockets */
|
/* timeout or readable/writable sockets */
|
||||||
while(CURLM_CALL_MULTI_PERFORM ==
|
curl_multi_perform(multi_handle, &still_running);
|
||||||
curl_multi_perform(multi_handle, &still_running));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -24,12 +24,12 @@ int main(int argc, char **argv)
|
|||||||
curl_easy_setopt(curl, CURLOPT_HEADER, 1L);
|
curl_easy_setopt(curl, CURLOPT_HEADER, 1L);
|
||||||
|
|
||||||
/* get the first document */
|
/* get the first document */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/");
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
/* get another document from the same server using the same
|
/* get another document from the same server using the same
|
||||||
connection */
|
connection */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/docs/");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/docs/");
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
|
@@ -51,8 +51,8 @@ int main(void)
|
|||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* First set the URL that is about to receive our POST. */
|
/* First set the URL that is about to receive our POST. */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL,
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/index.cgi");
|
||||||
"http://receivingsite.com.pooh/index.cgi");
|
|
||||||
/* Now specify we want to POST data */
|
/* Now specify we want to POST data */
|
||||||
curl_easy_setopt(curl, CURLOPT_POST, 1L);
|
curl_easy_setopt(curl, CURLOPT_POST, 1L);
|
||||||
|
|
||||||
|
@@ -67,7 +67,7 @@ int main(int argc, char *argv[])
|
|||||||
headerlist = curl_slist_append(headerlist, buf);
|
headerlist = curl_slist_append(headerlist, buf);
|
||||||
if(curl) {
|
if(curl) {
|
||||||
/* what URL that receives this POST */
|
/* what URL that receives this POST */
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/examplepost.cgi");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/examplepost.cgi");
|
||||||
if ( (argc == 2) && (!strcmp(argv[1], "noexpectheader")) )
|
if ( (argc == 2) && (!strcmp(argv[1], "noexpectheader")) )
|
||||||
/* only disable 100-continue header if explicitly requested */
|
/* only disable 100-continue header if explicitly requested */
|
||||||
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
|
||||||
|
@@ -75,7 +75,7 @@ int main(void)
|
|||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
||||||
|
|
||||||
/* use platform-specific functions for codeset conversions */
|
/* use platform-specific functions for codeset conversions */
|
||||||
curl_easy_setopt(curl, CURLOPT_CONV_FROM_NETWORK_FUNCTION,
|
curl_easy_setopt(curl, CURLOPT_CONV_FROM_NETWORK_FUNCTION,
|
||||||
|
@@ -48,13 +48,13 @@ int main(void)
|
|||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
/* Minimalistic http request */
|
/* Minimalistic http request */
|
||||||
const char *request = "GET / HTTP/1.0\r\nHost: curl.haxx.se\r\n\r\n";
|
const char *request = "GET / HTTP/1.0\r\nHost: example.com\r\n\r\n";
|
||||||
int sockfd; /* socket */
|
int sockfd; /* socket */
|
||||||
size_t iolen;
|
size_t iolen;
|
||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
||||||
/* Do not do the transfer - only connect to host */
|
/* Do not do the transfer - only connect to host */
|
||||||
curl_easy_setopt(curl, CURLOPT_CONNECT_ONLY, 1L);
|
curl_easy_setopt(curl, CURLOPT_CONNECT_ONLY, 1L);
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
@@ -35,7 +35,7 @@ int main(int argc, char **argv)
|
|||||||
curl_handle = curl_easy_init();
|
curl_handle = curl_easy_init();
|
||||||
|
|
||||||
/* set URL to get */
|
/* set URL to get */
|
||||||
curl_easy_setopt(curl_handle, CURLOPT_URL, "http://curl.haxx.se");
|
curl_easy_setopt(curl_handle, CURLOPT_URL, "http://example.com");
|
||||||
|
|
||||||
/* no progress meter please */
|
/* no progress meter please */
|
||||||
curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1L);
|
curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1L);
|
||||||
|
@@ -17,7 +17,7 @@ int main(void)
|
|||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
|
@@ -20,7 +20,7 @@ int main(void)
|
|||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://posthere.com");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
||||||
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postthis);
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postthis);
|
||||||
|
|
||||||
/* if we don't provide POSTFIELDSIZE, libcurl will strlen() by
|
/* if we don't provide POSTFIELDSIZE, libcurl will strlen() by
|
||||||
|
@@ -91,10 +91,10 @@ void init_locks(void)
|
|||||||
|
|
||||||
/* List of URLs to fetch.*/
|
/* List of URLs to fetch.*/
|
||||||
const char * const urls[]= {
|
const char * const urls[]= {
|
||||||
"https://www.sf.net/",
|
"https://www.example.com/",
|
||||||
"https://www.openssl.org/",
|
"https://www2.example.com/",
|
||||||
"https://www.sf.net/",
|
"https://www3.example.com/",
|
||||||
"https://www.openssl.org/",
|
"https://www4.example.com/",
|
||||||
};
|
};
|
||||||
|
|
||||||
static void *pull_one_url(void *url)
|
static void *pull_one_url(void *url)
|
||||||
|
2
docs/libcurl/.gitignore
vendored
Normal file
2
docs/libcurl/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
*.html
|
||||||
|
*.pdf
|
@@ -173,6 +173,17 @@ string holding the IP address of the most recent connection done with this
|
|||||||
\fBcurl\fP handle. This string may be IPv6 if that's enabled. Note that you
|
\fBcurl\fP handle. This string may be IPv6 if that's enabled. Note that you
|
||||||
get a pointer to a memory area that will be re-used at next request so you
|
get a pointer to a memory area that will be re-used at next request so you
|
||||||
need to copy the string if you want to keep the information. (Added in 7.19.0)
|
need to copy the string if you want to keep the information. (Added in 7.19.0)
|
||||||
|
.IP CURLINFO_PRIMARY_PORT
|
||||||
|
Pass a pointer to a long to receive the destination port of the most recent
|
||||||
|
connection done with this \fBcurl\fP handle. (Added in 7.21.0)
|
||||||
|
.IP CURLINFO_LOCAL_IP
|
||||||
|
Pass a pointer to a char pointer to receive the pointer to a zero-terminated
|
||||||
|
string holding the local (source) IP address of the most recent connection done
|
||||||
|
with this \fBcurl\fP handle. This string may be IPv6 if that's enabled. The
|
||||||
|
same restrictions apply as to \fICURLINFO_PRIMARY_IP\fP. (Added in 7.21.0)
|
||||||
|
.IP CURLINFO_LOCAL_PORT
|
||||||
|
Pass a pointer to a long to receive the local (source) port of the most recent
|
||||||
|
connection done with this \fBcurl\fP handle. (Added in 7.21.0)
|
||||||
.IP CURLINFO_COOKIELIST
|
.IP CURLINFO_COOKIELIST
|
||||||
Pass a pointer to a 'struct curl_slist *' to receive a linked-list of all
|
Pass a pointer to a 'struct curl_slist *' to receive a linked-list of all
|
||||||
cookies cURL knows (expired ones, too). Don't forget to
|
cookies cURL knows (expired ones, too). Don't forget to
|
||||||
@@ -187,6 +198,9 @@ working with the socket, you must call curl_easy_cleanup() as usual and let
|
|||||||
libcurl close the socket and cleanup other resources associated with the
|
libcurl close the socket and cleanup other resources associated with the
|
||||||
handle. This is typically used in combination with \fICURLOPT_CONNECT_ONLY\fP.
|
handle. This is typically used in combination with \fICURLOPT_CONNECT_ONLY\fP.
|
||||||
(Added in 7.15.2)
|
(Added in 7.15.2)
|
||||||
|
|
||||||
|
NOTE: this API is not really working on win64, since the SOCKET type on win64
|
||||||
|
is 64 bit large while its 'long' is only 32 bits.
|
||||||
.IP CURLINFO_FTP_ENTRY_PATH
|
.IP CURLINFO_FTP_ENTRY_PATH
|
||||||
Pass a pointer to a char pointer to receive a pointer to a string holding the
|
Pass a pointer to a char pointer to receive a pointer to a string holding the
|
||||||
path of the entry path. That is the initial path libcurl ended up in when
|
path of the entry path. That is the initial path libcurl ended up in when
|
||||||
|
@@ -84,11 +84,61 @@ If this option is set and libcurl has been built with the standard name
|
|||||||
resolver, timeouts will not occur while the name resolve takes place.
|
resolver, timeouts will not occur while the name resolve takes place.
|
||||||
Consider building libcurl with c-ares support to enable asynchronous DNS
|
Consider building libcurl with c-ares support to enable asynchronous DNS
|
||||||
lookups, which enables nice timeouts for name resolves without signals.
|
lookups, which enables nice timeouts for name resolves without signals.
|
||||||
|
.IP CURLOPT_WILDCARDMATCH
|
||||||
|
Set this option to 1 if you want to transfer multiple files according to a
|
||||||
|
file name pattern. The pattern can be specified as part of the
|
||||||
|
\fICURLOPT_URL\fP option, using an fnmatch-like pattern (Shell Pattern
|
||||||
|
Matching) in the last part of URL (file name).
|
||||||
|
|
||||||
|
By default, libcurl uses its internal wildcard matching implementation. You
|
||||||
|
can provide your own matching function by the \fICURLOPT_FNMATCH_FUNCTION\fP
|
||||||
|
option.
|
||||||
|
|
||||||
|
This feature is only supported by the FTP download for now.
|
||||||
|
|
||||||
|
A brief introduction of its syntax follows:
|
||||||
|
.RS
|
||||||
|
.IP "\fB*\fP - ASTERISK"
|
||||||
|
\&ftp://example.com/some/path/\fB*.txt\fP (for all txt's from the root
|
||||||
|
directory)
|
||||||
|
.RE
|
||||||
|
.RS
|
||||||
|
.IP "\fB?\fP - QUESTION MARK"
|
||||||
|
Question mark matches any (exactly one) character.
|
||||||
|
|
||||||
|
\&ftp://example.com/some/path/\fBphoto?.jpeg\fP
|
||||||
|
.RE
|
||||||
|
.RS
|
||||||
|
.IP "\fB[\fP - BRACKET EXPRESSION"
|
||||||
|
The left bracket opens a bracket expression. The question mark and asterisk have
|
||||||
|
no special meaning in a bracket expression. Each bracket expression ends by the
|
||||||
|
right bracket and matches exactly one character. Some examples follow:
|
||||||
|
|
||||||
|
\fB[a-zA-Z0\-9]\fP or \fB[f\-gF\-G]\fP \- character interval
|
||||||
|
|
||||||
|
\fB[abc]\fP - character enumeration
|
||||||
|
|
||||||
|
\fB[^abc]\fP or \fB[!abc]\fP - negation
|
||||||
|
|
||||||
|
\fB[[:\fP\fIname\fP\fB:]]\fP class expression. Supported classes are
|
||||||
|
\fBalnum\fP,\fBlower\fP, \fBspace\fP, \fBalpha\fP, \fBdigit\fP, \fBprint\fP,
|
||||||
|
\fBupper\fP, \fBblank\fP, \fBgraph\fP, \fBxdigit\fP.
|
||||||
|
|
||||||
|
\fB[][-!^]\fP - special case \- matches only '\-', ']', '[', '!' or '^'. These
|
||||||
|
characters have no special purpose.
|
||||||
|
|
||||||
|
\fB[\\[\\]\\\\]\fP - escape syntax. Matches '[', ']' or '\\'.
|
||||||
|
|
||||||
|
Using the rules above, a file name pattern can be constructed:
|
||||||
|
|
||||||
|
\&ftp://example.com/some/path/\fB[a-z[:upper:]\\\\].jpeg\fP
|
||||||
|
.RE
|
||||||
.PP
|
.PP
|
||||||
|
(This was added in 7.21.0)
|
||||||
.SH CALLBACK OPTIONS
|
.SH CALLBACK OPTIONS
|
||||||
.IP CURLOPT_WRITEFUNCTION
|
.IP CURLOPT_WRITEFUNCTION
|
||||||
Function pointer that should match the following prototype: \fBsize_t
|
Function pointer that should match the following prototype: \fBsize_t
|
||||||
function( void *ptr, size_t size, size_t nmemb, void *stream);\fP This
|
function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP This
|
||||||
function gets called by libcurl as soon as there is data received that needs
|
function gets called by libcurl as soon as there is data received that needs
|
||||||
to be saved. The size of the data pointed to by \fIptr\fP is \fIsize\fP
|
to be saved. The size of the data pointed to by \fIptr\fP is \fIsize\fP
|
||||||
multiplied with \fInmemb\fP, it will not be zero terminated. Return the number
|
multiplied with \fInmemb\fP, it will not be zero terminated. Return the number
|
||||||
@@ -107,7 +157,7 @@ Set this option to NULL to get the internal default function. The internal
|
|||||||
default function will write the data to the FILE * given with
|
default function will write the data to the FILE * given with
|
||||||
\fICURLOPT_WRITEDATA\fP.
|
\fICURLOPT_WRITEDATA\fP.
|
||||||
|
|
||||||
Set the \fIstream\fP argument with the \fICURLOPT_WRITEDATA\fP option.
|
Set the \fIuserdata\fP argument with the \fICURLOPT_WRITEDATA\fP option.
|
||||||
|
|
||||||
The callback function will be passed as much data as possible in all invokes,
|
The callback function will be passed as much data as possible in all invokes,
|
||||||
but you cannot possibly make any assumptions. It may be one byte, it may be
|
but you cannot possibly make any assumptions. It may be one byte, it may be
|
||||||
@@ -130,7 +180,7 @@ This option is also known with the older name \fICURLOPT_FILE\fP, the name
|
|||||||
\fICURLOPT_WRITEDATA\fP was introduced in 7.9.7.
|
\fICURLOPT_WRITEDATA\fP was introduced in 7.9.7.
|
||||||
.IP CURLOPT_READFUNCTION
|
.IP CURLOPT_READFUNCTION
|
||||||
Function pointer that should match the following prototype: \fBsize_t
|
Function pointer that should match the following prototype: \fBsize_t
|
||||||
function( void *ptr, size_t size, size_t nmemb, void *stream);\fP This
|
function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP This
|
||||||
function gets called by libcurl as soon as it needs to read data in order to
|
function gets called by libcurl as soon as it needs to read data in order to
|
||||||
send it to the peer. The data area pointed at by the pointer \fIptr\fP may be
|
send it to the peer. The data area pointed at by the pointer \fIptr\fP may 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
|
||||||
@@ -151,9 +201,9 @@ From 7.18.0, the function can return CURL_READFUNC_PAUSE which then will cause
|
|||||||
reading from this connection to become paused. See \fIcurl_easy_pause(3)\fP
|
reading from this connection to become paused. See \fIcurl_easy_pause(3)\fP
|
||||||
for further details.
|
for further details.
|
||||||
|
|
||||||
If you set the callback pointer to NULL, or don't set it at all, the default
|
If you set this callback pointer to NULL, or don't set it at all, the default
|
||||||
internal read function will be used. It is simply doing an fread() on the FILE
|
internal read function will be used. It is doing an fread() on the FILE *
|
||||||
* stream set with \fICURLOPT_READDATA\fP.
|
userdata set with \fICURLOPT_READDATA\fP.
|
||||||
.IP CURLOPT_READDATA
|
.IP CURLOPT_READDATA
|
||||||
Data pointer to pass to the file read function. If you use the
|
Data pointer to pass to the file read function. If you use the
|
||||||
\fICURLOPT_READFUNCTION\fP option, this is the pointer you'll get as input. If
|
\fICURLOPT_READFUNCTION\fP option, this is the pointer you'll get as input. If
|
||||||
@@ -246,11 +296,11 @@ argument in the opensocket callback set with \fICURLOPT_OPENSOCKETFUNCTION\fP.
|
|||||||
Function pointer that should match the \fIcurl_progress_callback\fP prototype
|
Function pointer that should match the \fIcurl_progress_callback\fP prototype
|
||||||
found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of
|
found in \fI<curl/curl.h>\fP. This function gets called by libcurl instead of
|
||||||
its internal equivalent with a frequent interval during operation (roughly
|
its internal equivalent with a frequent interval during operation (roughly
|
||||||
once per second) no matter if data is being transfered or not. Unknown/unused
|
once per second or sooner) no matter if data is being transfered or not.
|
||||||
argument values passed to the callback will be set to zero (like if you only
|
Unknown/unused argument values passed to the callback will be set to zero
|
||||||
download data, the upload size will remain 0). Returning a non-zero value from
|
(like if you only download data, the upload size will remain 0). Returning a
|
||||||
this callback will cause libcurl to abort the transfer and return
|
non-zero value from this callback will cause libcurl to abort the transfer and
|
||||||
\fICURLE_ABORTED_BY_CALLBACK\fP.
|
return \fICURLE_ABORTED_BY_CALLBACK\fP.
|
||||||
|
|
||||||
If you transfer data with the multi interface, this function will not be
|
If you transfer data with the multi interface, this function will not be
|
||||||
called during periods of idleness unless you call the appropriate libcurl
|
called during periods of idleness unless you call the appropriate libcurl
|
||||||
@@ -263,13 +313,13 @@ Pass a pointer that will be untouched by libcurl and passed as the first
|
|||||||
argument in the progress callback set with \fICURLOPT_PROGRESSFUNCTION\fP.
|
argument in the progress callback set with \fICURLOPT_PROGRESSFUNCTION\fP.
|
||||||
.IP CURLOPT_HEADERFUNCTION
|
.IP CURLOPT_HEADERFUNCTION
|
||||||
Function pointer that should match the following prototype: \fIsize_t
|
Function pointer that should match the following prototype: \fIsize_t
|
||||||
function( void *ptr, size_t size, size_t nmemb, void *stream);\fP. This
|
function( void *ptr, size_t size, size_t nmemb, void *userdata);\fP. This
|
||||||
function gets called by libcurl as soon as it has received header data. The
|
function gets called by libcurl as soon as it has received header data. The
|
||||||
header callback will be called once for each header and only complete header
|
header callback will be called once for each header and only complete header
|
||||||
lines are passed on to the callback. Parsing headers should be easy enough
|
lines are passed on to the callback. Parsing headers should be easy enough
|
||||||
using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP
|
using this. The size of the data pointed to by \fIptr\fP is \fIsize\fP
|
||||||
multiplied with \fInmemb\fP. Do not assume that the header line is zero
|
multiplied with \fInmemb\fP. Do not assume that the header line is zero
|
||||||
terminated! The pointer named \fIstream\fP is the one you set with the
|
terminated! The pointer named \fIuserdata\fP is the one you set with the
|
||||||
\fICURLOPT_WRITEHEADER\fP option. The callback function must return the number
|
\fICURLOPT_WRITEHEADER\fP option. The callback function must return the number
|
||||||
of bytes actually taken care of. If that amount differs from the amount passed
|
of bytes actually taken care of. If that amount differs from the amount passed
|
||||||
to your function, it'll signal an error to the library. This will abort the
|
to your function, it'll signal an error to the library. This will abort the
|
||||||
@@ -402,7 +452,7 @@ You will need to override these definitions if they are different on your
|
|||||||
system.
|
system.
|
||||||
.IP CURLOPT_INTERLEAVEFUNCTION
|
.IP CURLOPT_INTERLEAVEFUNCTION
|
||||||
Function pointer that should match the following prototype: \fIsize_t
|
Function pointer that should match the following prototype: \fIsize_t
|
||||||
function( void *ptr, size_t size, size_t nmemb, void *stream)\fP. This
|
function( void *ptr, size_t size, size_t nmemb, void *userdata)\fP. This
|
||||||
function gets called by libcurl as soon as it has received interleaved RTP
|
function gets called by libcurl as soon as it has received interleaved RTP
|
||||||
data. This function gets called for each $ block and therefore contains
|
data. This function gets called for each $ block and therefore contains
|
||||||
exactly one upper-layer protocol unit (e.g. one RTP packet). Curl writes the
|
exactly one upper-layer protocol unit (e.g. one RTP packet). Curl writes the
|
||||||
@@ -422,8 +472,52 @@ request, (e.g. \fICURL_RTSPREQ_PAUSE\fP) then the response handler will
|
|||||||
process any pending RTP data before marking the request as finished. (Added
|
process any pending RTP data before marking the request as finished. (Added
|
||||||
in 7.20.0)
|
in 7.20.0)
|
||||||
.IP CURLOPT_INTERLEAVEDATA
|
.IP CURLOPT_INTERLEAVEDATA
|
||||||
This is the stream that will be passed to \fICURLOPT_INTERLEAVEFUNCTION\fP when
|
This is the userdata pointer that will be passed to
|
||||||
interleaved RTP data is received. (Added in 7.20.0)
|
\fICURLOPT_INTERLEAVEFUNCTION\fP when interleaved RTP data is received. (Added
|
||||||
|
in 7.20.0)
|
||||||
|
.IP CURLOPT_CHUNK_BGN_FUNCTION
|
||||||
|
Function pointer that should match the following prototype: \fBlong function
|
||||||
|
(const void *transfer_info, void *ptr, int remains)\fP. This function gets
|
||||||
|
called by libcurl before a part of the stream is going to be transferred (if
|
||||||
|
the transfer supports chunks).
|
||||||
|
|
||||||
|
This callback makes sense only when using the \fICURLOPT_WILDCARDMATCH\fP
|
||||||
|
option for now.
|
||||||
|
|
||||||
|
The target of transfer_info parameter is a "feature depended" structure. For
|
||||||
|
the FTP wildcard download, the target is curl_fileinfo structure (see
|
||||||
|
\fIcurl/curl.h\fP). The parameter ptr is a pointer given by
|
||||||
|
\fICURLOPT_CHUNK_DATA\fP. The parameter remains contains number of chunks
|
||||||
|
remaining per the transfer. If the feature is not available, the parameter has
|
||||||
|
zero value.
|
||||||
|
|
||||||
|
Return \fICURL_CHUNK_BGN_FUNC_OK\fP if everything is fine,
|
||||||
|
\fICURL_CHUNK_BGN_FUNC_SKIP\fP if you want to skip the concrete chunk or
|
||||||
|
\fICURL_CHUNK_BGN_FUNC_FAIL\fP to tell libcurl to stop if some error occurred.
|
||||||
|
(This was added in 7.21.0)
|
||||||
|
.IP CURLOPT_CHUNK_END_FUNCTION
|
||||||
|
Function pointer that should match the following prototype: \fBlong
|
||||||
|
function(void *ptr)\fP. This function gets called by libcurl as soon as a part
|
||||||
|
of the stream has been transferred (or skipped).
|
||||||
|
|
||||||
|
Return \fICURL_CHUNK_END_FUNC_OK\fP if everything is fine or
|
||||||
|
\fBCURL_CHUNK_END_FUNC_FAIL\fP to tell the lib to stop if some error occurred.
|
||||||
|
(This was added in 7.21.0)
|
||||||
|
.IP CURLOPT_CHUNK_DATA
|
||||||
|
Pass a pointer that will be untouched by libcurl and passed as the ptr
|
||||||
|
argument to the \fICURL_CHUNK_BGN_FUNTION\fP and \fICURL_CHUNK_END_FUNTION\fP.
|
||||||
|
(This was added in 7.21.0)
|
||||||
|
.IP CURLOPT_FNMATCH_FUNCTION
|
||||||
|
Function pointer that should match \fBint function(void *ptr, const char
|
||||||
|
*pattern, const char *string)\fP prototype (see \fIcurl/curl.h\fP). It is used
|
||||||
|
internally for the wildcard matching feature.
|
||||||
|
|
||||||
|
Return \fICURL_FNMATCHFUNC_MATCH\fP if pattern matches the string,
|
||||||
|
\fICURL_FNMATCHFUNC_NOMATCH\fP if not or \fICURL_FNMATCHFUNC_FAIL\fP if an
|
||||||
|
error occurred. (This was added in 7.21.0)
|
||||||
|
.IP CURLOPT_FNMATCH_DATA
|
||||||
|
Pass a pointer that will be untouched by libcurl and passed as the ptr argument
|
||||||
|
to the \fICURL_FNMATCH_FUNCTION\fP. (This was added in 7.21.0)
|
||||||
.SH ERROR OPTIONS
|
.SH ERROR OPTIONS
|
||||||
.IP CURLOPT_ERRORBUFFER
|
.IP 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
|
||||||
@@ -1165,9 +1259,15 @@ A parameter set to 1 tells the library to just list the names of files in a
|
|||||||
directory, instead of doing a full directory listing that would include file
|
directory, instead of doing a full directory listing that would include file
|
||||||
sizes, dates etc. This works for FTP and SFTP URLs.
|
sizes, dates etc. This works for FTP and SFTP URLs.
|
||||||
|
|
||||||
This causes an FTP NLST command to be sent on an FTP server. Beware
|
This causes an FTP NLST command to be sent on an FTP server. Beware that some
|
||||||
that some FTP servers list only files in their response to NLST; they
|
FTP servers list only files in their response to NLST; they might not include
|
||||||
might not include subdirectories and symbolic links.
|
subdirectories and symbolic links.
|
||||||
|
|
||||||
|
Setting this option to 1 also implies a directory listing even if the URL
|
||||||
|
doesn't end with a slash, which otherwise is necessary.
|
||||||
|
|
||||||
|
Do NOT use this option if you also use \fICURLOPT_WILDCARDMATCH\fP as it will
|
||||||
|
effectively break that feature then.
|
||||||
|
|
||||||
(This option was known as CURLOPT_FTPLISTONLY up to 7.16.4)
|
(This option was known as CURLOPT_FTPLISTONLY up to 7.16.4)
|
||||||
.IP CURLOPT_APPEND
|
.IP CURLOPT_APPEND
|
||||||
@@ -1445,6 +1545,10 @@ want the transfer to start from. Set this option to 0 to make the transfer
|
|||||||
start from the beginning (effectively disabling resume). For FTP, set this
|
start from the beginning (effectively disabling resume). For FTP, set this
|
||||||
option to -1 to make the transfer start from the end of the target file
|
option to -1 to make the transfer start from the end of the target file
|
||||||
(useful to continue an interrupted upload).
|
(useful to continue an interrupted upload).
|
||||||
|
|
||||||
|
When doing uploads with FTP, the resume position is where in the local/source
|
||||||
|
file libcurl should try to resume the upload from and it will then append the
|
||||||
|
source file to the remote target file.
|
||||||
.IP CURLOPT_RESUME_FROM_LARGE
|
.IP CURLOPT_RESUME_FROM_LARGE
|
||||||
Pass a curl_off_t as parameter. It contains the offset in number of bytes that
|
Pass a curl_off_t as parameter. It contains the offset in number of bytes that
|
||||||
you want the transfer to start from. (Added in 7.11.0)
|
you want the transfer to start from. (Added in 7.11.0)
|
||||||
|
@@ -112,14 +112,15 @@ timeout value to use when waiting for socket activities.
|
|||||||
them for activity. This can be done through your application code, or by way
|
them for activity. This can be done through your application code, or by way
|
||||||
of an external library such as libevent or glib.
|
of an external library such as libevent or glib.
|
||||||
|
|
||||||
6. Wait for activity on any of libcurl's sockets, use the timeout value your
|
6. Call curl_multi_socket_action() to kickstart everything. To get one or more
|
||||||
|
callbacks called.
|
||||||
|
|
||||||
|
7. Wait for activity on any of libcurl's sockets, use the timeout value your
|
||||||
callback has been told
|
callback has been told
|
||||||
|
|
||||||
7, When activity is detected, call curl_multi_socket_action() for the
|
8, When activity is detected, call curl_multi_socket_action() for the
|
||||||
socket(s) that got action. If no activity is detected and the timeout expires,
|
socket(s) that got action. If no activity is detected and the timeout expires,
|
||||||
call \fIcurl_multi_socket_action(3)\fP with \fICURL_SOCKET_TIMEOUT\fP
|
call \fIcurl_multi_socket_action(3)\fP with \fICURL_SOCKET_TIMEOUT\fP
|
||||||
|
|
||||||
8. Go back to step 6.
|
|
||||||
.SH AVAILABILITY
|
.SH AVAILABILITY
|
||||||
This function was added in libcurl 7.15.4, and is deemed stable since 7.16.0.
|
This function was added in libcurl 7.15.4, and is deemed stable since 7.16.0.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
@@ -218,6 +218,16 @@ return code is only returned from \fIcurl_easy_recv(3)\fP and
|
|||||||
Failed to load CRL file (Added in 7.19.0)
|
Failed to load CRL file (Added in 7.19.0)
|
||||||
.IP "CURLE_SSL_ISSUER_ERROR (83)"
|
.IP "CURLE_SSL_ISSUER_ERROR (83)"
|
||||||
Issuer check failed (Added in 7.19.0)
|
Issuer check failed (Added in 7.19.0)
|
||||||
|
.IP "CURLE_FTP_PRET_FAILED (84)"
|
||||||
|
PRET command failed
|
||||||
|
.IP "CURLE_RTSP_CSEQ_ERROR (85)"
|
||||||
|
Mismatch of RTSP CSeq numbers.
|
||||||
|
.IP "CURLE_RTSP_SESSION_ERROR (86)"
|
||||||
|
Mismatch of RTSP Session Identifiers.
|
||||||
|
.IP "CURLE_FTP_BAD_FILE_LIST (87)"
|
||||||
|
Unable to parse FTP file list (during FTP wildcard downloading).
|
||||||
|
.IP "CURLE_CHUNK_FAILED (88)"
|
||||||
|
Chunk callback reported error.
|
||||||
.IP "CURLE_OBSOLETE*"
|
.IP "CURLE_OBSOLETE*"
|
||||||
These error codes will never be returned. They were used in an old libcurl
|
These error codes will never be returned. They were used in an old libcurl
|
||||||
version and are currently unused.
|
version and are currently unused.
|
||||||
|
@@ -275,6 +275,10 @@ NSS
|
|||||||
|
|
||||||
is claimed to be thread-safe already without anything required.
|
is claimed to be thread-safe already without anything required.
|
||||||
|
|
||||||
|
PolarSSL
|
||||||
|
|
||||||
|
Required actions unknown.
|
||||||
|
|
||||||
yassl
|
yassl
|
||||||
|
|
||||||
Required actions unknown.
|
Required actions unknown.
|
||||||
@@ -1233,6 +1237,15 @@ are used to generate structured data. Characters like embedded carriage
|
|||||||
returns or ampersands could allow the user to create additional headers or
|
returns or ampersands could allow the user to create additional headers or
|
||||||
fields that could cause malicious transactions.
|
fields that could cause malicious transactions.
|
||||||
|
|
||||||
|
.IP "Server-supplied Names"
|
||||||
|
A server can supply data which the application may, in some cases, use as
|
||||||
|
a file name. The curl command-line tool does this with --remote-header-name,
|
||||||
|
using the Content-disposition: header to generate a file name. An application
|
||||||
|
could also use CURLINFO_EFFECTIVE_URL to generate a file name from a
|
||||||
|
server-supplied redirect URL. Special care must be taken to sanitize such
|
||||||
|
names to avoid the possibility of a malicious server supplying one like
|
||||||
|
"/etc/passwd", "\autoexec.bat" or even ".bashrc".
|
||||||
|
|
||||||
.IP "Server Certificates"
|
.IP "Server Certificates"
|
||||||
A secure application should never use the CURLOPT_SSL_VERIFYPEER option to
|
A secure application should never use the CURLOPT_SSL_VERIFYPEER option to
|
||||||
disable certificate validation. There are numerous attacks that are enabled
|
disable certificate validation. There are numerous attacks that are enabled
|
||||||
|
@@ -61,7 +61,7 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG],
|
|||||||
AH_TEMPLATE([LIBCURL_PROTOCOL_SMTP],[Defined if libcurl supports SMTP])
|
AH_TEMPLATE([LIBCURL_PROTOCOL_SMTP],[Defined if libcurl supports SMTP])
|
||||||
|
|
||||||
AC_ARG_WITH(libcurl,
|
AC_ARG_WITH(libcurl,
|
||||||
AC_HELP_STRING([--with-libcurl=DIR],[look for the curl library in DIR]),
|
AC_HELP_STRING([--with-libcurl=PREFIX],[look for the curl library in PREFIX/lib and headers in PREFIX/include]),
|
||||||
[_libcurl_with=$withval],[_libcurl_with=ifelse([$1],,[yes],[$1])])
|
[_libcurl_with=$withval],[_libcurl_with=ifelse([$1],,[yes],[$1])])
|
||||||
|
|
||||||
if test "$_libcurl_with" != "no" ; then
|
if test "$_libcurl_with" != "no" ; then
|
||||||
@@ -75,10 +75,10 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG],
|
|||||||
if test -d "$_libcurl_with" ; then
|
if test -d "$_libcurl_with" ; then
|
||||||
LIBCURL_CPPFLAGS="-I$withval/include"
|
LIBCURL_CPPFLAGS="-I$withval/include"
|
||||||
_libcurl_ldflags="-L$withval/lib"
|
_libcurl_ldflags="-L$withval/lib"
|
||||||
AC_PATH_PROG([_libcurl_config],[curl-config],["$withval/bin"],
|
AC_PATH_PROG([_libcurl_config],[curl-config],[],
|
||||||
["$withval/bin"])
|
["$withval/bin"])
|
||||||
else
|
else
|
||||||
AC_PATH_PROG([_libcurl_config],[curl-config])
|
AC_PATH_PROG([_libcurl_config],[curl-config],[],[$PATH])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test x$_libcurl_config != "x" ; then
|
if test x$_libcurl_config != "x" ; then
|
||||||
|
@@ -151,11 +151,14 @@ CURLINFO_HTTPAUTH_AVAIL 7.10.8
|
|||||||
CURLINFO_HTTP_CODE 7.4.1 7.10.8
|
CURLINFO_HTTP_CODE 7.4.1 7.10.8
|
||||||
CURLINFO_HTTP_CONNECTCODE 7.10.7
|
CURLINFO_HTTP_CONNECTCODE 7.10.7
|
||||||
CURLINFO_LASTSOCKET 7.15.2
|
CURLINFO_LASTSOCKET 7.15.2
|
||||||
|
CURLINFO_LOCAL_IP 7.21.0
|
||||||
|
CURLINFO_LOCAL_PORT 7.21.0
|
||||||
CURLINFO_NAMELOOKUP_TIME 7.4.1
|
CURLINFO_NAMELOOKUP_TIME 7.4.1
|
||||||
CURLINFO_NUM_CONNECTS 7.12.3
|
CURLINFO_NUM_CONNECTS 7.12.3
|
||||||
CURLINFO_OS_ERRNO 7.12.2
|
CURLINFO_OS_ERRNO 7.12.2
|
||||||
CURLINFO_PRETRANSFER_TIME 7.4.1
|
CURLINFO_PRETRANSFER_TIME 7.4.1
|
||||||
CURLINFO_PRIMARY_IP 7.19.0
|
CURLINFO_PRIMARY_IP 7.19.0
|
||||||
|
CURLINFO_PRIMARY_PORT 7.21.0
|
||||||
CURLINFO_PRIVATE 7.10.3
|
CURLINFO_PRIVATE 7.10.3
|
||||||
CURLINFO_PRIVATE 7.10.3
|
CURLINFO_PRIVATE 7.10.3
|
||||||
CURLINFO_PROXYAUTH_AVAIL 7.10.8
|
CURLINFO_PROXYAUTH_AVAIL 7.10.8
|
||||||
@@ -188,6 +191,9 @@ CURLOPT_BUFFERSIZE 7.10
|
|||||||
CURLOPT_CAINFO 7.4.2
|
CURLOPT_CAINFO 7.4.2
|
||||||
CURLOPT_CAPATH 7.9.8
|
CURLOPT_CAPATH 7.9.8
|
||||||
CURLOPT_CERTINFO 7.19.1
|
CURLOPT_CERTINFO 7.19.1
|
||||||
|
CURLOPT_CHUNK_BGN_FUNCTION 7.21.0
|
||||||
|
CURLOPT_CHUNK_DATA 7.21.0
|
||||||
|
CURLOPT_CHUNK_END_FUNCTION 7.21.0
|
||||||
CURLOPT_CLOSEFUNCTION 7.7 7.11.1 7.15.4
|
CURLOPT_CLOSEFUNCTION 7.7 7.11.1 7.15.4
|
||||||
CURLOPT_CLOSEPOLICY 7.7 7.16.1
|
CURLOPT_CLOSEPOLICY 7.7 7.16.1
|
||||||
CURLOPT_CONNECTTIMEOUT 7.7
|
CURLOPT_CONNECTTIMEOUT 7.7
|
||||||
@@ -217,6 +223,8 @@ CURLOPT_FAILONERROR 7.1
|
|||||||
CURLOPT_FILE 7.1 7.9.7
|
CURLOPT_FILE 7.1 7.9.7
|
||||||
CURLOPT_FILETIME 7.5
|
CURLOPT_FILETIME 7.5
|
||||||
CURLOPT_FLAGS 7.1 - 7.9.2
|
CURLOPT_FLAGS 7.1 - 7.9.2
|
||||||
|
CURLOPT_FNMATCH_DATA 7.21.0
|
||||||
|
CURLOPT_FNMATCH_FUNCTION 7.21.0
|
||||||
CURLOPT_FOLLOWLOCATION 7.1
|
CURLOPT_FOLLOWLOCATION 7.1
|
||||||
CURLOPT_FORBID_REUSE 7.7
|
CURLOPT_FORBID_REUSE 7.7
|
||||||
CURLOPT_FRESH_CONNECT 7.7
|
CURLOPT_FRESH_CONNECT 7.7
|
||||||
@@ -236,14 +244,6 @@ CURLOPT_FTP_SSL_CCC 7.16.1
|
|||||||
CURLOPT_FTP_USE_EPRT 7.10.5
|
CURLOPT_FTP_USE_EPRT 7.10.5
|
||||||
CURLOPT_FTP_USE_EPSV 7.9.2
|
CURLOPT_FTP_USE_EPSV 7.9.2
|
||||||
CURLOPT_FTP_USE_PRET 7.20.0
|
CURLOPT_FTP_USE_PRET 7.20.0
|
||||||
CURLOPT_RTSP_REQUEST 7.20.0
|
|
||||||
CURLOPT_RTSP_SESSION_ID 7.20.0
|
|
||||||
CURLOPT_RTSP_STREAM_URI 7.20.0
|
|
||||||
CURLOPT_RTSP_TRANSPORT 7.20.0
|
|
||||||
CURLOPT_RTSP_CLIENT_CSEQ 7.20.0
|
|
||||||
CURLOPT_RTSP_SERVER_CSEQ 7.20.0
|
|
||||||
CURLOPT_INTERLEAVEDATA 7.20.0
|
|
||||||
CURLOPT_INTERLEAVEFUNCTION 7.20.0
|
|
||||||
CURLOPT_HEADER 7.1
|
CURLOPT_HEADER 7.1
|
||||||
CURLOPT_HEADERDATA 7.10
|
CURLOPT_HEADERDATA 7.10
|
||||||
CURLOPT_HEADERFUNCTION 7.7.2
|
CURLOPT_HEADERFUNCTION 7.7.2
|
||||||
@@ -262,6 +262,8 @@ CURLOPT_INFILE 7.1 7.9.7
|
|||||||
CURLOPT_INFILESIZE 7.1
|
CURLOPT_INFILESIZE 7.1
|
||||||
CURLOPT_INFILESIZE_LARGE 7.11.0
|
CURLOPT_INFILESIZE_LARGE 7.11.0
|
||||||
CURLOPT_INTERFACE 7.3
|
CURLOPT_INTERFACE 7.3
|
||||||
|
CURLOPT_INTERLEAVEDATA 7.20.0
|
||||||
|
CURLOPT_INTERLEAVEFUNCTION 7.20.0
|
||||||
CURLOPT_IOCTLDATA 7.12.3
|
CURLOPT_IOCTLDATA 7.12.3
|
||||||
CURLOPT_IOCTLFUNCTION 7.12.3
|
CURLOPT_IOCTLFUNCTION 7.12.3
|
||||||
CURLOPT_IPRESOLVE 7.10.8
|
CURLOPT_IPRESOLVE 7.10.8
|
||||||
@@ -328,6 +330,12 @@ CURLOPT_REDIR_PROTOCOLS 7.19.4
|
|||||||
CURLOPT_REFERER 7.1
|
CURLOPT_REFERER 7.1
|
||||||
CURLOPT_RESUME_FROM 7.1
|
CURLOPT_RESUME_FROM 7.1
|
||||||
CURLOPT_RESUME_FROM_LARGE 7.11.0
|
CURLOPT_RESUME_FROM_LARGE 7.11.0
|
||||||
|
CURLOPT_RTSP_CLIENT_CSEQ 7.20.0
|
||||||
|
CURLOPT_RTSP_REQUEST 7.20.0
|
||||||
|
CURLOPT_RTSP_SERVER_CSEQ 7.20.0
|
||||||
|
CURLOPT_RTSP_SESSION_ID 7.20.0
|
||||||
|
CURLOPT_RTSP_STREAM_URI 7.20.0
|
||||||
|
CURLOPT_RTSP_TRANSPORT 7.20.0
|
||||||
CURLOPT_SEEKDATA 7.18.1
|
CURLOPT_SEEKDATA 7.18.1
|
||||||
CURLOPT_SEEKFUNCTION 7.18.1
|
CURLOPT_SEEKFUNCTION 7.18.1
|
||||||
CURLOPT_SHARE 7.10
|
CURLOPT_SHARE 7.10
|
||||||
@@ -380,6 +388,7 @@ CURLOPT_USERNAME 7.19.1
|
|||||||
CURLOPT_USERPWD 7.1
|
CURLOPT_USERPWD 7.1
|
||||||
CURLOPT_USE_SSL 7.17.0
|
CURLOPT_USE_SSL 7.17.0
|
||||||
CURLOPT_VERBOSE 7.1
|
CURLOPT_VERBOSE 7.1
|
||||||
|
CURLOPT_WILDCARDMATCH 7.21.0
|
||||||
CURLOPT_WRITEDATA 7.9.7
|
CURLOPT_WRITEDATA 7.9.7
|
||||||
CURLOPT_WRITEFUNCTION 7.1
|
CURLOPT_WRITEFUNCTION 7.1
|
||||||
CURLOPT_WRITEHEADER 7.1
|
CURLOPT_WRITEHEADER 7.1
|
||||||
@@ -396,6 +405,12 @@ CURLPROTO_LDAP 7.19.4
|
|||||||
CURLPROTO_LDAPS 7.19.4
|
CURLPROTO_LDAPS 7.19.4
|
||||||
CURLPROTO_POP3 7.20.0
|
CURLPROTO_POP3 7.20.0
|
||||||
CURLPROTO_POP3S 7.20.0
|
CURLPROTO_POP3S 7.20.0
|
||||||
|
CURLPROTO_RTMP 7.21.0
|
||||||
|
CURLPROTO_RTMPE 7.21.0
|
||||||
|
CURLPROTO_RTMPS 7.21.0
|
||||||
|
CURLPROTO_RTMPT 7.21.0
|
||||||
|
CURLPROTO_RTMPTE 7.21.0
|
||||||
|
CURLPROTO_RTMPTS 7.21.0
|
||||||
CURLPROTO_RTSP 7.20.0
|
CURLPROTO_RTSP 7.20.0
|
||||||
CURLPROTO_SCP 7.19.4
|
CURLPROTO_SCP 7.19.4
|
||||||
CURLPROTO_SFTP 7.19.4
|
CURLPROTO_SFTP 7.19.4
|
||||||
@@ -427,6 +442,14 @@ CURLVERSION_FIRST 7.10
|
|||||||
CURLVERSION_NOW 7.10
|
CURLVERSION_NOW 7.10
|
||||||
CURLVERSION_SECOND 7.11.1
|
CURLVERSION_SECOND 7.11.1
|
||||||
CURLVERSION_THIRD 7.12.0
|
CURLVERSION_THIRD 7.12.0
|
||||||
|
CURL_CHUNK_BGN_FUNC_FAIL 7.21.0
|
||||||
|
CURL_CHUNK_BGN_FUNC_OK 7.21.0
|
||||||
|
CURL_CHUNK_BGN_FUNC_SKIP 7.21.0
|
||||||
|
CURL_CHUNK_END_FUNC_FAIL 7.21.0
|
||||||
|
CURL_CHUNK_END_FUNC_OK 7.21.0
|
||||||
|
CURL_FNMATCHFUNC_FAIL 7.21.0
|
||||||
|
CURL_FNMATCHFUNC_MATCH 7.21.0
|
||||||
|
CURL_FNMATCHFUNC_NOMATCH 7.21.0
|
||||||
CURL_HTTP_VERSION_1_0 7.9.1
|
CURL_HTTP_VERSION_1_0 7.9.1
|
||||||
CURL_HTTP_VERSION_1_1 7.9.1
|
CURL_HTTP_VERSION_1_1 7.9.1
|
||||||
CURL_HTTP_VERSION_NONE 7.9.1
|
CURL_HTTP_VERSION_NONE 7.9.1
|
||||||
|
2
include/curl/.gitignore
vendored
2
include/curl/.gitignore
vendored
@@ -1,3 +1,3 @@
|
|||||||
curlbuild.h
|
curlbuild.h
|
||||||
stamp-h3
|
stamp-h3
|
||||||
|
curlver.h.dist
|
||||||
|
@@ -198,6 +198,97 @@ typedef size_t (*curl_write_callback)(char *buffer,
|
|||||||
size_t nitems,
|
size_t nitems,
|
||||||
void *outstream);
|
void *outstream);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* enumeration of file types */
|
||||||
|
typedef enum {
|
||||||
|
CURLFILETYPE_FILE = 0,
|
||||||
|
CURLFILETYPE_DIRECTORY,
|
||||||
|
CURLFILETYPE_SYMLINK,
|
||||||
|
CURLFILETYPE_DEVICE_BLOCK,
|
||||||
|
CURLFILETYPE_DEVICE_CHAR,
|
||||||
|
CURLFILETYPE_NAMEDPIPE,
|
||||||
|
CURLFILETYPE_SOCKET,
|
||||||
|
CURLFILETYPE_DOOR, /* is possible only on Sun Solaris now */
|
||||||
|
|
||||||
|
CURLFILETYPE_UNKNOWN /* should never occur */
|
||||||
|
} curlfiletype;
|
||||||
|
|
||||||
|
#define CURLFINFOFLAG_KNOWN_FILENAME (1<<0)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_FILETYPE (1<<1)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_TIME (1<<2)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_PERM (1<<3)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_UID (1<<4)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_GID (1<<5)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_SIZE (1<<6)
|
||||||
|
#define CURLFINFOFLAG_KNOWN_HLINKCOUNT (1<<7)
|
||||||
|
|
||||||
|
/* Content of this structure depends on information which is known and is
|
||||||
|
achievable (e.g. by FTP LIST parsing). Please see the url_easy_setopt(3) man
|
||||||
|
page for callbacks returning this structure -- some fields are mandatory,
|
||||||
|
some others are optional. The FLAG field has special meaning. */
|
||||||
|
struct curl_fileinfo {
|
||||||
|
char *filename;
|
||||||
|
curlfiletype filetype;
|
||||||
|
time_t time;
|
||||||
|
unsigned int perm;
|
||||||
|
int uid;
|
||||||
|
int gid;
|
||||||
|
curl_off_t size;
|
||||||
|
long int hardlinks;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
/* If some of these fields is not NULL, it is a pointer to b_data. */
|
||||||
|
char *time;
|
||||||
|
char *perm;
|
||||||
|
char *user;
|
||||||
|
char *group;
|
||||||
|
char *target; /* pointer to the target filename of a symlink */
|
||||||
|
} strings;
|
||||||
|
|
||||||
|
unsigned int flags;
|
||||||
|
|
||||||
|
/* used internally */
|
||||||
|
char * b_data;
|
||||||
|
size_t b_size;
|
||||||
|
size_t b_used;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* return codes for CURLOPT_CHUNK_BGN_FUNCTION */
|
||||||
|
#define CURL_CHUNK_BGN_FUNC_OK 0
|
||||||
|
#define CURL_CHUNK_BGN_FUNC_FAIL 1 /* tell the lib to end the task */
|
||||||
|
#define CURL_CHUNK_BGN_FUNC_SKIP 2 /* skip this chunk over */
|
||||||
|
|
||||||
|
/* if splitting of data transfer is enabled, this callback is called before
|
||||||
|
download of an individual chunk started. Note that parameter "remains" works
|
||||||
|
only for FTP wildcard downloading (for now), otherwise is not used */
|
||||||
|
typedef long (*curl_chunk_bgn_callback)(const void *transfer_info,
|
||||||
|
void *ptr,
|
||||||
|
int remains);
|
||||||
|
|
||||||
|
/* return codes for CURLOPT_CHUNK_END_FUNCTION */
|
||||||
|
#define CURL_CHUNK_END_FUNC_OK 0
|
||||||
|
#define CURL_CHUNK_END_FUNC_FAIL 1 /* tell the lib to end the task */
|
||||||
|
|
||||||
|
/* If splitting of data transfer is enabled this callback is called after
|
||||||
|
download of an individual chunk finished.
|
||||||
|
Note! After this callback was set then it have to be called FOR ALL chunks.
|
||||||
|
Even if downloading of this chunk was skipped in CHUNK_BGN_FUNC.
|
||||||
|
This is the reason why we don't need "transfer_info" parameter in this
|
||||||
|
callback and we are not interested in "remains" parameter too. */
|
||||||
|
typedef long (*curl_chunk_end_callback)(void *ptr);
|
||||||
|
|
||||||
|
/* return codes for FNMATCHFUNCTION */
|
||||||
|
#define CURL_FNMATCHFUNC_MATCH 0 /* string corresponds to the pattern */
|
||||||
|
#define CURL_FNMATCHFUNC_NOMATCH 1 /* pattern doesn't match the string */
|
||||||
|
#define CURL_FNMATCHFUNC_FAIL 2 /* an error occurred */
|
||||||
|
|
||||||
|
/* callback type for wildcard downloading pattern matching. If the
|
||||||
|
string matches the pattern, return CURL_FNMATCHFUNC_MATCH value, etc. */
|
||||||
|
typedef int (*curl_fnmatch_callback)(void *ptr,
|
||||||
|
const char *pattern,
|
||||||
|
const char *string);
|
||||||
|
|
||||||
/* These are the return codes for the seek callbacks */
|
/* These are the return codes for the seek callbacks */
|
||||||
#define CURL_SEEKFUNC_OK 0
|
#define CURL_SEEKFUNC_OK 0
|
||||||
#define CURL_SEEKFUNC_FAIL 1 /* fail the entire transfer */
|
#define CURL_SEEKFUNC_FAIL 1 /* fail the entire transfer */
|
||||||
@@ -409,6 +500,8 @@ typedef enum {
|
|||||||
CURLE_FTP_PRET_FAILED, /* 84 - a PRET command failed */
|
CURLE_FTP_PRET_FAILED, /* 84 - a PRET command failed */
|
||||||
CURLE_RTSP_CSEQ_ERROR, /* 85 - mismatch of RTSP CSeq numbers */
|
CURLE_RTSP_CSEQ_ERROR, /* 85 - mismatch of RTSP CSeq numbers */
|
||||||
CURLE_RTSP_SESSION_ERROR, /* 86 - mismatch of RTSP Session Identifiers */
|
CURLE_RTSP_SESSION_ERROR, /* 86 - mismatch of RTSP Session Identifiers */
|
||||||
|
CURLE_FTP_BAD_FILE_LIST, /* 87 - unable to parse FTP file list */
|
||||||
|
CURLE_CHUNK_FAILED, /* 88 - chunk callback reported error */
|
||||||
|
|
||||||
CURL_LAST /* never use! */
|
CURL_LAST /* never use! */
|
||||||
} CURLcode;
|
} CURLcode;
|
||||||
@@ -623,6 +716,13 @@ typedef enum {
|
|||||||
#define CURLPROTO_SMTP (1<<16)
|
#define CURLPROTO_SMTP (1<<16)
|
||||||
#define CURLPROTO_SMTPS (1<<17)
|
#define CURLPROTO_SMTPS (1<<17)
|
||||||
#define CURLPROTO_RTSP (1<<18)
|
#define CURLPROTO_RTSP (1<<18)
|
||||||
|
#define CURLPROTO_RTMP (1<<19)
|
||||||
|
#define CURLPROTO_RTMPT (1<<20)
|
||||||
|
#define CURLPROTO_RTMPE (1<<21)
|
||||||
|
#define CURLPROTO_RTMPTE (1<<22)
|
||||||
|
#define CURLPROTO_RTMPS (1<<23)
|
||||||
|
#define CURLPROTO_RTMPTS (1<<24)
|
||||||
|
#define CURLPROTO_GOPHER (1<<25)
|
||||||
#define CURLPROTO_ALL (~0) /* enable everything */
|
#define CURLPROTO_ALL (~0) /* enable everything */
|
||||||
|
|
||||||
/* long may be 32 or 64 bits, but we should never depend on anything else
|
/* long may be 32 or 64 bits, but we should never depend on anything else
|
||||||
@@ -1316,6 +1416,26 @@ typedef enum {
|
|||||||
/* Let the application define a custom write method for RTP data */
|
/* Let the application define a custom write method for RTP data */
|
||||||
CINIT(INTERLEAVEFUNCTION, FUNCTIONPOINT, 196),
|
CINIT(INTERLEAVEFUNCTION, FUNCTIONPOINT, 196),
|
||||||
|
|
||||||
|
/* Turn on wildcard matching */
|
||||||
|
CINIT(WILDCARDMATCH, LONG, 197),
|
||||||
|
|
||||||
|
/* Directory matching callback called before downloading of an
|
||||||
|
individual file (chunk) started */
|
||||||
|
CINIT(CHUNK_BGN_FUNCTION, FUNCTIONPOINT, 198),
|
||||||
|
|
||||||
|
/* Directory matching callback called after the file (chunk)
|
||||||
|
was downloaded, or skipped */
|
||||||
|
CINIT(CHUNK_END_FUNCTION, FUNCTIONPOINT, 199),
|
||||||
|
|
||||||
|
/* Change match (fnmatch-like) callback for wildcard matching */
|
||||||
|
CINIT(FNMATCH_FUNCTION, FUNCTIONPOINT, 200),
|
||||||
|
|
||||||
|
/* Let the application define custom chunk data pointer */
|
||||||
|
CINIT(CHUNK_DATA, OBJECTPOINT, 201),
|
||||||
|
|
||||||
|
/* FNMATCH_FUNCTION user pointer */
|
||||||
|
CINIT(FNMATCH_DATA, OBJECTPOINT, 202),
|
||||||
|
|
||||||
CURLOPT_LASTENTRY /* the last unused */
|
CURLOPT_LASTENTRY /* the last unused */
|
||||||
} CURLoption;
|
} CURLoption;
|
||||||
|
|
||||||
@@ -1764,9 +1884,12 @@ typedef enum {
|
|||||||
CURLINFO_RTSP_CLIENT_CSEQ = CURLINFO_LONG + 37,
|
CURLINFO_RTSP_CLIENT_CSEQ = CURLINFO_LONG + 37,
|
||||||
CURLINFO_RTSP_SERVER_CSEQ = CURLINFO_LONG + 38,
|
CURLINFO_RTSP_SERVER_CSEQ = CURLINFO_LONG + 38,
|
||||||
CURLINFO_RTSP_CSEQ_RECV = CURLINFO_LONG + 39,
|
CURLINFO_RTSP_CSEQ_RECV = CURLINFO_LONG + 39,
|
||||||
|
CURLINFO_PRIMARY_PORT = CURLINFO_LONG + 40,
|
||||||
|
CURLINFO_LOCAL_IP = CURLINFO_STRING + 41,
|
||||||
|
CURLINFO_LOCAL_PORT = CURLINFO_LONG + 42,
|
||||||
/* Fill in new entries below here! */
|
/* Fill in new entries below here! */
|
||||||
|
|
||||||
CURLINFO_LASTONE = 39
|
CURLINFO_LASTONE = 42
|
||||||
} CURLINFO;
|
} CURLINFO;
|
||||||
|
|
||||||
/* CURLINFO_RESPONSE_CODE is the new name for the option previously known as
|
/* CURLINFO_RESPONSE_CODE is the new name for the option previously known as
|
||||||
|
@@ -30,13 +30,13 @@
|
|||||||
|
|
||||||
/* This is the version number of the libcurl package from which this header
|
/* This is the version number of the libcurl package from which this header
|
||||||
file origins: */
|
file origins: */
|
||||||
#define LIBCURL_VERSION "7.20.1-DEV"
|
#define LIBCURL_VERSION "7.21.2-DEV"
|
||||||
|
|
||||||
/* The numeric version number is also available "in parts" by using these
|
/* The numeric version number is also available "in parts" by using these
|
||||||
defines: */
|
defines: */
|
||||||
#define LIBCURL_VERSION_MAJOR 7
|
#define LIBCURL_VERSION_MAJOR 7
|
||||||
#define LIBCURL_VERSION_MINOR 20
|
#define LIBCURL_VERSION_MINOR 21
|
||||||
#define LIBCURL_VERSION_PATCH 1
|
#define LIBCURL_VERSION_PATCH 2
|
||||||
|
|
||||||
/* This is the numeric version of the libcurl version number, meant for easier
|
/* This is the numeric version of the libcurl version number, meant for easier
|
||||||
parsing and comparions by programs. The LIBCURL_VERSION_NUM define will
|
parsing and comparions by programs. The LIBCURL_VERSION_NUM define will
|
||||||
@@ -53,7 +53,7 @@
|
|||||||
and it is always a greater number in a more recent release. It makes
|
and it is always a greater number in a more recent release. It makes
|
||||||
comparisons with greater than and less than work.
|
comparisons with greater than and less than work.
|
||||||
*/
|
*/
|
||||||
#define LIBCURL_VERSION_NUM 0x071401
|
#define LIBCURL_VERSION_NUM 0x071502
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is the date and time when the full source package was created. The
|
* This is the date and time when the full source package was created. The
|
||||||
|
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -25,11 +25,16 @@
|
|||||||
/* wraps curl_easy_setopt() with typechecking */
|
/* wraps curl_easy_setopt() with typechecking */
|
||||||
|
|
||||||
/* To add a new kind of warning, add an
|
/* To add a new kind of warning, add an
|
||||||
* if(_curl_is_sometype_option(_curl_opt) && ! _curl_is_sometype(value))
|
* if(_curl_is_sometype_option(_curl_opt))
|
||||||
|
* if(!_curl_is_sometype(value))
|
||||||
* _curl_easy_setopt_err_sometype();
|
* _curl_easy_setopt_err_sometype();
|
||||||
* block and define _curl_is_sometype_option, _curl_is_sometype and
|
* block and define _curl_is_sometype_option, _curl_is_sometype and
|
||||||
* _curl_easy_setopt_err_sometype below
|
* _curl_easy_setopt_err_sometype below
|
||||||
*
|
*
|
||||||
|
* NOTE: We use two nested 'if' statements here instead of the && operator, in
|
||||||
|
* order to work around gcc bug #32061. It affects only gcc 4.3.x/4.4.x
|
||||||
|
* when compiling with -Wlogical-op.
|
||||||
|
*
|
||||||
* To add an option that uses the same type as an existing option, you'll just
|
* To add an option that uses the same type as an existing option, you'll just
|
||||||
* need to extend the appropriate _curl_*_option macro
|
* need to extend the appropriate _curl_*_option macro
|
||||||
*/
|
*/
|
||||||
@@ -37,50 +42,65 @@
|
|||||||
__extension__ ({ \
|
__extension__ ({ \
|
||||||
__typeof__ (option) _curl_opt = option; \
|
__typeof__ (option) _curl_opt = option; \
|
||||||
if (__builtin_constant_p(_curl_opt)) { \
|
if (__builtin_constant_p(_curl_opt)) { \
|
||||||
if (_curl_is_long_option(_curl_opt) && !_curl_is_long(value)) \
|
if (_curl_is_long_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_long(value)) \
|
||||||
_curl_easy_setopt_err_long(); \
|
_curl_easy_setopt_err_long(); \
|
||||||
if (_curl_is_off_t_option(_curl_opt) && !_curl_is_off_t(value)) \
|
if (_curl_is_off_t_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_off_t(value)) \
|
||||||
_curl_easy_setopt_err_curl_off_t(); \
|
_curl_easy_setopt_err_curl_off_t(); \
|
||||||
if (_curl_is_string_option(_curl_opt) && !_curl_is_string(value)) \
|
if (_curl_is_string_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_string(value)) \
|
||||||
_curl_easy_setopt_err_string(); \
|
_curl_easy_setopt_err_string(); \
|
||||||
if (_curl_is_write_cb_option(_curl_opt) && !_curl_is_write_cb(value)) \
|
if (_curl_is_write_cb_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_write_cb(value)) \
|
||||||
_curl_easy_setopt_err_write_callback(); \
|
_curl_easy_setopt_err_write_callback(); \
|
||||||
if ((_curl_opt) == CURLOPT_READFUNCTION && !_curl_is_read_cb(value)) \
|
if ((_curl_opt) == CURLOPT_READFUNCTION) \
|
||||||
|
if (!_curl_is_read_cb(value)) \
|
||||||
_curl_easy_setopt_err_read_cb(); \
|
_curl_easy_setopt_err_read_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_IOCTLFUNCTION && !_curl_is_ioctl_cb(value)) \
|
if ((_curl_opt) == CURLOPT_IOCTLFUNCTION) \
|
||||||
|
if (!_curl_is_ioctl_cb(value)) \
|
||||||
_curl_easy_setopt_err_ioctl_cb(); \
|
_curl_easy_setopt_err_ioctl_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_SOCKOPTFUNCTION && !_curl_is_sockopt_cb(value))\
|
if ((_curl_opt) == CURLOPT_SOCKOPTFUNCTION) \
|
||||||
|
if (!_curl_is_sockopt_cb(value)) \
|
||||||
_curl_easy_setopt_err_sockopt_cb(); \
|
_curl_easy_setopt_err_sockopt_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_OPENSOCKETFUNCTION && \
|
if ((_curl_opt) == CURLOPT_OPENSOCKETFUNCTION) \
|
||||||
!_curl_is_opensocket_cb(value)) \
|
if (!_curl_is_opensocket_cb(value)) \
|
||||||
_curl_easy_setopt_err_opensocket_cb(); \
|
_curl_easy_setopt_err_opensocket_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_PROGRESSFUNCTION && \
|
if ((_curl_opt) == CURLOPT_PROGRESSFUNCTION) \
|
||||||
!_curl_is_progress_cb(value)) \
|
if (!_curl_is_progress_cb(value)) \
|
||||||
_curl_easy_setopt_err_progress_cb(); \
|
_curl_easy_setopt_err_progress_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_DEBUGFUNCTION && !_curl_is_debug_cb(value)) \
|
if ((_curl_opt) == CURLOPT_DEBUGFUNCTION) \
|
||||||
|
if (!_curl_is_debug_cb(value)) \
|
||||||
_curl_easy_setopt_err_debug_cb(); \
|
_curl_easy_setopt_err_debug_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_SSL_CTX_FUNCTION && \
|
if ((_curl_opt) == CURLOPT_SSL_CTX_FUNCTION) \
|
||||||
!_curl_is_ssl_ctx_cb(value)) \
|
if (!_curl_is_ssl_ctx_cb(value)) \
|
||||||
_curl_easy_setopt_err_ssl_ctx_cb(); \
|
_curl_easy_setopt_err_ssl_ctx_cb(); \
|
||||||
if (_curl_is_conv_cb_option(_curl_opt) && !_curl_is_conv_cb(value)) \
|
if (_curl_is_conv_cb_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_conv_cb(value)) \
|
||||||
_curl_easy_setopt_err_conv_cb(); \
|
_curl_easy_setopt_err_conv_cb(); \
|
||||||
if ((_curl_opt) == CURLOPT_SEEKFUNCTION && !_curl_is_seek_cb(value)) \
|
if ((_curl_opt) == CURLOPT_SEEKFUNCTION) \
|
||||||
|
if (!_curl_is_seek_cb(value)) \
|
||||||
_curl_easy_setopt_err_seek_cb(); \
|
_curl_easy_setopt_err_seek_cb(); \
|
||||||
if (_curl_is_cb_data_option(_curl_opt) && !_curl_is_cb_data(value)) \
|
if (_curl_is_cb_data_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_cb_data(value)) \
|
||||||
_curl_easy_setopt_err_cb_data(); \
|
_curl_easy_setopt_err_cb_data(); \
|
||||||
if ((_curl_opt) == CURLOPT_ERRORBUFFER && !_curl_is_error_buffer(value)) \
|
if ((_curl_opt) == CURLOPT_ERRORBUFFER) \
|
||||||
|
if (!_curl_is_error_buffer(value)) \
|
||||||
_curl_easy_setopt_err_error_buffer(); \
|
_curl_easy_setopt_err_error_buffer(); \
|
||||||
if ((_curl_opt) == CURLOPT_STDERR && !_curl_is_FILE(value)) \
|
if ((_curl_opt) == CURLOPT_STDERR) \
|
||||||
|
if (!_curl_is_FILE(value)) \
|
||||||
_curl_easy_setopt_err_FILE(); \
|
_curl_easy_setopt_err_FILE(); \
|
||||||
if (_curl_is_postfields_option(_curl_opt) && !_curl_is_postfields(value)) \
|
if (_curl_is_postfields_option(_curl_opt)) \
|
||||||
|
if (!_curl_is_postfields(value)) \
|
||||||
_curl_easy_setopt_err_postfields(); \
|
_curl_easy_setopt_err_postfields(); \
|
||||||
if ((_curl_opt) == CURLOPT_HTTPPOST && \
|
if ((_curl_opt) == CURLOPT_HTTPPOST) \
|
||||||
!_curl_is_arr((value), struct curl_httppost)) \
|
if (!_curl_is_arr((value), struct curl_httppost)) \
|
||||||
_curl_easy_setopt_err_curl_httpost(); \
|
_curl_easy_setopt_err_curl_httpost(); \
|
||||||
if (_curl_is_slist_option(_curl_opt) && \
|
if (_curl_is_slist_option(_curl_opt)) \
|
||||||
!_curl_is_arr((value), struct curl_slist)) \
|
if (!_curl_is_arr((value), struct curl_slist)) \
|
||||||
_curl_easy_setopt_err_curl_slist(); \
|
_curl_easy_setopt_err_curl_slist(); \
|
||||||
if ((_curl_opt) == CURLOPT_SHARE && !_curl_is_ptr((value), CURLSH)) \
|
if ((_curl_opt) == CURLOPT_SHARE) \
|
||||||
|
if (!_curl_is_ptr((value), CURLSH)) \
|
||||||
_curl_easy_setopt_err_CURLSH(); \
|
_curl_easy_setopt_err_CURLSH(); \
|
||||||
} \
|
} \
|
||||||
curl_easy_setopt(handle, _curl_opt, value); \
|
curl_easy_setopt(handle, _curl_opt, value); \
|
||||||
@@ -92,14 +112,17 @@ __extension__ ({ \
|
|||||||
__extension__ ({ \
|
__extension__ ({ \
|
||||||
__typeof__ (info) _curl_info = info; \
|
__typeof__ (info) _curl_info = info; \
|
||||||
if (__builtin_constant_p(_curl_info)) { \
|
if (__builtin_constant_p(_curl_info)) { \
|
||||||
if (_curl_is_string_info(_curl_info) && !_curl_is_arr((arg), char *)) \
|
if (_curl_is_string_info(_curl_info)) \
|
||||||
|
if (!_curl_is_arr((arg), char *)) \
|
||||||
_curl_easy_getinfo_err_string(); \
|
_curl_easy_getinfo_err_string(); \
|
||||||
if (_curl_is_long_info(_curl_info) && !_curl_is_arr((arg), long)) \
|
if (_curl_is_long_info(_curl_info)) \
|
||||||
|
if (!_curl_is_arr((arg), long)) \
|
||||||
_curl_easy_getinfo_err_long(); \
|
_curl_easy_getinfo_err_long(); \
|
||||||
if (_curl_is_double_info(_curl_info) && !_curl_is_arr((arg), double)) \
|
if (_curl_is_double_info(_curl_info)) \
|
||||||
|
if (!_curl_is_arr((arg), double)) \
|
||||||
_curl_easy_getinfo_err_double(); \
|
_curl_easy_getinfo_err_double(); \
|
||||||
if (_curl_is_slist_info(_curl_info) && \
|
if (_curl_is_slist_info(_curl_info)) \
|
||||||
!_curl_is_arr((arg), struct curl_slist *)) \
|
if (!_curl_is_arr((arg), struct curl_slist *)) \
|
||||||
_curl_easy_getinfo_err_curl_slist(); \
|
_curl_easy_getinfo_err_curl_slist(); \
|
||||||
} \
|
} \
|
||||||
curl_easy_getinfo(handle, _curl_info, arg); \
|
curl_easy_getinfo(handle, _curl_info, arg); \
|
||||||
@@ -230,6 +253,12 @@ _CURL_WARNING(_curl_easy_getinfo_err_curl_slist,
|
|||||||
(option) == CURLOPT_SSH_PRIVATE_KEYFILE || \
|
(option) == CURLOPT_SSH_PRIVATE_KEYFILE || \
|
||||||
(option) == CURLOPT_CRLFILE || \
|
(option) == CURLOPT_CRLFILE || \
|
||||||
(option) == CURLOPT_ISSUERCERT || \
|
(option) == CURLOPT_ISSUERCERT || \
|
||||||
|
(option) == CURLOPT_SOCKS5_GSSAPI_SERVICE || \
|
||||||
|
(option) == CURLOPT_SSH_KNOWNHOSTS || \
|
||||||
|
(option) == CURLOPT_MAIL_FROM || \
|
||||||
|
(option) == CURLOPT_RTSP_SESSION_ID || \
|
||||||
|
(option) == CURLOPT_RTSP_STREAM_URI || \
|
||||||
|
(option) == CURLOPT_RTSP_TRANSPORT || \
|
||||||
0)
|
0)
|
||||||
|
|
||||||
/* evaluates to true if option takes a curl_write_callback argument */
|
/* evaluates to true if option takes a curl_write_callback argument */
|
||||||
@@ -256,6 +285,10 @@ _CURL_WARNING(_curl_easy_getinfo_err_curl_slist,
|
|||||||
(option) == CURLOPT_SSL_CTX_DATA || \
|
(option) == CURLOPT_SSL_CTX_DATA || \
|
||||||
(option) == CURLOPT_SEEKDATA || \
|
(option) == CURLOPT_SEEKDATA || \
|
||||||
(option) == CURLOPT_PRIVATE || \
|
(option) == CURLOPT_PRIVATE || \
|
||||||
|
(option) == CURLOPT_SSH_KEYDATA || \
|
||||||
|
(option) == CURLOPT_INTERLEAVEDATA || \
|
||||||
|
(option) == CURLOPT_CHUNK_DATA || \
|
||||||
|
(option) == CURLOPT_FNMATCH_DATA || \
|
||||||
0)
|
0)
|
||||||
|
|
||||||
/* evaluates to true if option takes a POST data argument (void* or char*) */
|
/* evaluates to true if option takes a POST data argument (void* or char*) */
|
||||||
@@ -272,6 +305,7 @@ _CURL_WARNING(_curl_easy_getinfo_err_curl_slist,
|
|||||||
(option) == CURLOPT_POSTQUOTE || \
|
(option) == CURLOPT_POSTQUOTE || \
|
||||||
(option) == CURLOPT_PREQUOTE || \
|
(option) == CURLOPT_PREQUOTE || \
|
||||||
(option) == CURLOPT_TELNETOPTIONS || \
|
(option) == CURLOPT_TELNETOPTIONS || \
|
||||||
|
(option) == CURLOPT_MAIL_RCPT || \
|
||||||
0)
|
0)
|
||||||
|
|
||||||
/* groups of curl_easy_getinfo infos that take the same type of argument */
|
/* groups of curl_easy_getinfo infos that take the same type of argument */
|
||||||
|
5
lib/.gitignore
vendored
5
lib/.gitignore
vendored
@@ -4,3 +4,8 @@ stamp-h1
|
|||||||
*.orig
|
*.orig
|
||||||
*.rej
|
*.rej
|
||||||
TAGS
|
TAGS
|
||||||
|
Makefile.vc8.dist
|
||||||
|
Makefile.vc9.dist
|
||||||
|
libcurl.plist.dist
|
||||||
|
libcurl.vcproj
|
||||||
|
vc6libcurl.dsp
|
||||||
|
@@ -3,56 +3,131 @@
|
|||||||
# G. Vanem <gvanem@broadpark.no>
|
# G. Vanem <gvanem@broadpark.no>
|
||||||
#
|
#
|
||||||
|
|
||||||
TARGETS = libcurl_wc.dll libcurl_wc_imp.lib libcurl_wc.lib
|
!ifndef %watcom
|
||||||
|
!error WATCOM environment variable not set!
|
||||||
|
!else
|
||||||
|
SYS_INCL = -I$(%watcom)\h\nt -I$(%watcom)\h
|
||||||
|
SYS_LIBS = $(%watcom)\lib386\nt;$(%watcom)\lib386
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %libname
|
||||||
|
LIBNAME = $(%libname)
|
||||||
|
!else
|
||||||
|
LIBNAME = libcurl
|
||||||
|
!endif
|
||||||
|
TARGETS = $(LIBNAME).dll $(LIBNAME)_imp.lib $(LIBNAME).lib
|
||||||
|
|
||||||
CC = wcc386
|
CC = wcc386
|
||||||
|
LD = wlink
|
||||||
|
AR = wlib
|
||||||
|
RC = wrc
|
||||||
|
|
||||||
CFLAGS = -3s -mf -d3 -hc -zff -zgf -zq -zm -zc -s -fr=con -w2 -fpi -oilrtfm -bt=nt &
|
!ifdef __LOADDLL__
|
||||||
-bd -d+ -dWIN32 -dCURL_CA_BUNDLE=getenv("CURL_CA_BUNDLE") &
|
! loaddll wcc386 wccd386
|
||||||
-dBUILDING_LIBCURL -dHAVE_SPNEGO=1 -dENABLE_IPV6 &
|
! loaddll wpp386 wppd386
|
||||||
-dDEBUG=1 -dDEBUGBUILD -d_WIN32_WINNT=0x0501 -dWINBERAPI=__declspec(cdecl) &
|
! loaddll wlib wlibd
|
||||||
-dWINLDAPAPI=__declspec(cdecl) -I. -I..\include
|
! if $(__VERSION__) > 1270
|
||||||
|
! loaddll wlink wlinkd
|
||||||
|
! else
|
||||||
|
! loaddll wlink wlink
|
||||||
|
! endif
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!if $(__VERSION__) < 1250
|
||||||
|
RM = del /q /f 2>NUL
|
||||||
|
!else
|
||||||
|
RM = rm -f
|
||||||
|
!endif
|
||||||
|
MD = mkdir
|
||||||
|
RD = rmdir /q /s 2>NUL
|
||||||
|
CP = copy
|
||||||
|
|
||||||
|
CFLAGS = -3r -mf -hc -zff -zgf -zq -zm -zc -s -fr=con -w2 -fpi -oilrtfm &
|
||||||
|
-wcd=201 -bt=nt -d+ -dWIN32 -dCURL_WANTS_CA_BUNDLE_ENV &
|
||||||
|
-dBUILDING_LIBCURL -dHAVE_SPNEGO=1 -I. -I..\include $(SYS_INCL)
|
||||||
|
|
||||||
|
!ifdef %debug
|
||||||
|
DEBUG = -dDEBUG=1 -dDEBUGBUILD
|
||||||
|
CFLAGS += -d3 $(DEBUG)
|
||||||
|
!else
|
||||||
|
CFLAGS += -d0
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %use_ipv6
|
||||||
|
CFLAGS += -d_WIN32_WINNT=0x0501 -dENABLE_IPV6
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %use_sspi
|
||||||
|
CFLAGS += -dUSE_WINDOWS_SSPI
|
||||||
|
!endif
|
||||||
|
|
||||||
#
|
#
|
||||||
# Change to suite.
|
# Change to suite.
|
||||||
#
|
#
|
||||||
ZLIB_ROOT = ..\..\..\zlib-1.2.3
|
!ifdef %zlib_root
|
||||||
USE_ZLIB = 0
|
ZLIB_ROOT = $(%zlib_root)
|
||||||
USE_ARES = 0
|
!else
|
||||||
USE_WATT32 = 0
|
ZLIB_ROOT = ..\..\zlib-1.2.5
|
||||||
|
!endif
|
||||||
|
|
||||||
!ifeq USE_ZLIB 1
|
!ifdef %libssh2_root
|
||||||
|
LIBSSH2_ROOT = $(%libssh2_root)
|
||||||
|
!else
|
||||||
|
LIBSSH2_ROOT = ..\..\libssh2-1.2.7
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %librtmp_root
|
||||||
|
LIBRTMP_ROOT = $(%librtmp_root)
|
||||||
|
!else
|
||||||
|
LIBRTMP_ROOT = ..\..\librtmp-2.3
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %openssl_root
|
||||||
|
OPENSSL_ROOT = $(%openssl_root)
|
||||||
|
!else
|
||||||
|
OPENSSL_ROOT = ..\..\openssl-0.9.8o
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %ares_root
|
||||||
|
ARES_ROOT = $(%ares_root)
|
||||||
|
!else
|
||||||
|
ARES_ROOT = ..\ares
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %use_zlib
|
||||||
CFLAGS += -dHAVE_ZLIB_H -dHAVE_LIBZ -I$(ZLIB_ROOT)
|
CFLAGS += -dHAVE_ZLIB_H -dHAVE_LIBZ -I$(ZLIB_ROOT)
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
!ifeq USE_ARES 1
|
!ifdef %use_rtmp
|
||||||
CFLAGS += -dUSE_ARES -I..\ares
|
CFLAGS += -dUSE_LIBRTMP -I$(LIBRTMP_ROOT)
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
!ifeq USE_WATT32 1
|
!ifdef %use_ssh2
|
||||||
|
CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H -I$(LIBSSH2_ROOT)\include -I$(LIBSSH2_ROOT)\win32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %use_ssl
|
||||||
|
CFLAGS += -wcd=138 -dUSE_OPENSSL -dUSE_SSLEAY -I$(OPENSSL_ROOT)\inc32
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %use_ares
|
||||||
|
CFLAGS += -dUSE_ARES -I$(ARES_ROOT)
|
||||||
|
!endif
|
||||||
|
|
||||||
|
!ifdef %use_watt32
|
||||||
CFLAGS += -dUSE_WATT32 -I$(%watt_root)\inc
|
CFLAGS += -dUSE_WATT32 -I$(%watt_root)\inc
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
OBJ_BASE = WC_Win32.obj
|
OBJ_BASE = WC_Win32.obj
|
||||||
C_ARG = $(OBJ_BASE)\wcc386.arg
|
|
||||||
LINK_ARG = $(OBJ_BASE)\dyn\wlink.arg
|
LINK_ARG = $(OBJ_BASE)\dyn\wlink.arg
|
||||||
LIB_ARG = $(OBJ_BASE)\stat\wlib.arg
|
LIB_ARG = $(OBJ_BASE)\stat\wlib.arg
|
||||||
|
|
||||||
# Unfortunately, we can't include Makefile.inc here because wmake doesn't
|
# In order to process Makefile.inc wmake must be called with -u switch!
|
||||||
# use backslash as the line continuation character by default
|
!ifndef %MAKEFLAGS
|
||||||
CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c &
|
!error You MUST call wmake with the -u switch!
|
||||||
cookie.c http.c sendf.c ftp.c url.c dict.c if2ip.c speedcheck.c &
|
!else
|
||||||
ldap.c ssluse.c version.c getenv.c escape.c mprintf.c telnet.c &
|
!include Makefile.inc
|
||||||
netrc.c getinfo.c transfer.c strequal.c easy.c security.c krb4.c &
|
!endif
|
||||||
krb5.c memdebug.c http_chunks.c strtok.c connect.c llist.c hash.c &
|
|
||||||
multi.c content_encoding.c share.c http_digest.c md5.c curl_rand.c &
|
|
||||||
http_negotiate.c http_ntlm.c inet_pton.c strtoofft.c strerror.c &
|
|
||||||
hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c &
|
|
||||||
inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c &
|
|
||||||
strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c &
|
|
||||||
socks_gssapi.c socks_sspi.c curl_sspi.c slist.c nonblock.c &
|
|
||||||
curl_memrchr.c imap.c pop3.c smtp.c pingpong.c rtsp.c curl_threads.c &
|
|
||||||
warnless.c
|
|
||||||
|
|
||||||
OBJS = $(CSOURCES:.c=.obj)
|
OBJS = $(CSOURCES:.c=.obj)
|
||||||
OBJS = $OBJ_DIR\$(OBJS: = $OBJ_DIR\)
|
OBJS = $OBJ_DIR\$(OBJS: = $OBJ_DIR\)
|
||||||
@@ -66,500 +141,82 @@ OBJS_STAT = $+ $(OBJS) $-
|
|||||||
OBJ_DIR = $(OBJ_BASE)\dyn
|
OBJ_DIR = $(OBJ_BASE)\dyn
|
||||||
OBJS_DYN = $+ $(OBJS) $-
|
OBJS_DYN = $+ $(OBJS) $-
|
||||||
|
|
||||||
|
CURLBUILDH = ..\include\curl\curlbuild.h
|
||||||
RESOURCE = $(OBJ_BASE)\dyn\libcurl.res
|
RESOURCE = $(OBJ_BASE)\dyn\libcurl.res
|
||||||
|
|
||||||
all: $(OBJ_BASE) $(C_ARG) $(TARGETS) .SYMBOLIC
|
all: $(CURLBUILDH) $(OBJ_BASE) $(TARGETS) .SYMBOLIC
|
||||||
@echo Welcome to libcurl
|
@echo Welcome to libcurl
|
||||||
|
|
||||||
$(OBJ_BASE):
|
|
||||||
- mkdir $(OBJ_BASE)
|
|
||||||
- mkdir $(OBJ_BASE)\stat
|
|
||||||
- mkdir $(OBJ_BASE)\dyn
|
|
||||||
|
|
||||||
libcurl_wc.dll libcurl_wc_imp.lib: $(OBJS_DYN) $(RESOURCE) $(LINK_ARG)
|
|
||||||
wlink name libcurl_wc.dll @$(LINK_ARG)
|
|
||||||
|
|
||||||
libcurl_wc.lib: $(OBJS_STAT) $(LIB_ARG)
|
|
||||||
wlib -q -b- c $@ @$(LIB_ARG)
|
|
||||||
|
|
||||||
clean: .SYMBOLIC
|
clean: .SYMBOLIC
|
||||||
- rm -f $(OBJS_STAT) $(OBJS_DYN) $(RESOURCE) $(C_ARG) $(LINK_ARG) $(LIB_ARG)
|
-$(RM) $(OBJS_STAT)
|
||||||
|
-$(RM) $(OBJS_DYN)
|
||||||
|
-$(RM) $(RESOURCE) $(LINK_ARG) $(LIB_ARG)
|
||||||
|
|
||||||
vclean realclean: clean .SYMBOLIC
|
vclean distclean: clean .SYMBOLIC
|
||||||
- rm -f $(TARGETS) libcurl_wc.map
|
-$(RM) $(TARGETS) $(LIBNAME).map $(LIBNAME).sym
|
||||||
- rmdir $(OBJ_BASE)\stat
|
-$(RD) $(OBJ_BASE)\stat
|
||||||
- rmdir $(OBJ_BASE)\dyn
|
-$(RD) $(OBJ_BASE)\dyn
|
||||||
- rmdir $(OBJ_BASE)
|
-$(RD) $(OBJ_BASE)
|
||||||
|
|
||||||
|
$(OBJ_BASE):
|
||||||
|
-$(MD) $^@
|
||||||
|
-$(MD) $^@\stat
|
||||||
|
-$(MD) $^@\dyn
|
||||||
|
|
||||||
|
$(CURLBUILDH): .EXISTSONLY
|
||||||
|
$(CP) $^@.dist $^@
|
||||||
|
|
||||||
|
$(LIBNAME).dll: $(OBJS_DYN) $(RESOURCE) $(LINK_ARG)
|
||||||
|
$(LD) name $^@ @$]@
|
||||||
|
|
||||||
|
$(LIBNAME).lib: $(OBJS_STAT) $(LIB_ARG)
|
||||||
|
$(AR) -q -b -c $^@ @$]@
|
||||||
|
|
||||||
.ERASE
|
.ERASE
|
||||||
$(RESOURCE): libcurl.rc
|
$(RESOURCE): libcurl.rc
|
||||||
wrc -dDEBUGBUILD=1 -q -r -zm -I..\include -fo=$@ libcurl.rc
|
$(RC) $(DEBUG) -q -r -zm -I..\include $(SYS_INCL) $[@ -fo=$^@
|
||||||
|
|
||||||
.ERASE
|
.ERASE
|
||||||
.c{$(OBJ_BASE)\dyn}.obj:
|
.c{$(OBJ_BASE)\dyn}.obj:
|
||||||
$(CC) $[@ @$(C_ARG) -fo=$@
|
$(CC) $(CFLAGS) -bd -br $[@ -fo=$^@
|
||||||
|
|
||||||
.ERASE
|
.ERASE
|
||||||
.c{$(OBJ_BASE)\stat}.obj:
|
.c{$(OBJ_BASE)\stat}.obj:
|
||||||
$(CC) $[@ @$(C_ARG) -DCURL_STATICLIB -fo=$@
|
$(CC) $(CFLAGS) -DCURL_STATICLIB $[@ -fo=$^@
|
||||||
|
|
||||||
$(C_ARG): $(__MAKEFILES__)
|
|
||||||
%create $^@
|
|
||||||
%append $^@ $(CFLAGS)
|
|
||||||
|
|
||||||
$(LINK_ARG): $(__MAKEFILES__)
|
$(LINK_ARG): $(__MAKEFILES__)
|
||||||
%create $^@
|
%create $^@
|
||||||
@%append $^@ system nt dll
|
@%append $^@ system nt dll
|
||||||
@%append $^@ file { $(OBJS_DYN) }
|
@%append $^@ file { $(OBJS_DYN) }
|
||||||
@%append $^@ option quiet, map, caseexact, eliminate, implib=libcurl_wc_imp.lib,
|
!ifdef %debug
|
||||||
@%append $^@ res=$(RESOURCE) libpath $(%watcom)\lib386;$(%watcom)\lib386\nt
|
@%append $^@ debug all
|
||||||
@%append $^@ library clib3s.lib, wldap32.lib
|
@%append $^@ option symfile
|
||||||
!ifeq USE_WATT32 1
|
!endif
|
||||||
|
@%append $^@ option quiet, map, caseexact, eliminate, implib=$(LIBNAME)_imp.lib,
|
||||||
|
@%append $^@ res=$(RESOURCE) libpath $(SYS_LIBS)
|
||||||
|
@%append $^@ library wldap32.lib
|
||||||
|
!ifdef %use_watt32
|
||||||
@%append $^@ library $(%watt_root)\lib\wattcpw_imp.lib
|
@%append $^@ library $(%watt_root)\lib\wattcpw_imp.lib
|
||||||
!else
|
!else
|
||||||
@%append $^@ library ws2_32.lib
|
@%append $^@ library ws2_32.lib
|
||||||
!endif
|
!endif
|
||||||
!ifeq USE_ZLIB 1
|
!ifdef %use_zlib
|
||||||
@%append $^@ library $(ZLIB_ROOT)\zlib.lib
|
@%append $^@ library $(ZLIB_ROOT)\zlib.lib
|
||||||
!endif
|
!endif
|
||||||
!ifeq USE_ARES 1
|
!ifdef %use_rtmp
|
||||||
@%append $^@ library ..\ares\cares.lib
|
@%append $^@ library $(LIBRTMP_ROOT)\librtmp\librtmp.lib
|
||||||
|
!endif
|
||||||
|
!ifdef %use_ssh2
|
||||||
|
@%append $^@ library $(LIBSSH2_ROOT)\win32\libssh2.lib
|
||||||
|
!endif
|
||||||
|
!ifdef %use_ssl
|
||||||
|
@%append $^@ library $(OPENSSL_ROOT)\out32\libeay32.lib, $(OPENSSL_ROOT)\out32\ssleay32.lib
|
||||||
|
!endif
|
||||||
|
!ifdef %use_ares
|
||||||
|
@%append $^@ library $(ARES_ROOT)\cares.lib
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
$(LIB_ARG): $(__MAKEFILES__)
|
$(LIB_ARG): $(__MAKEFILES__)
|
||||||
%create $^@
|
%create $^@
|
||||||
for %f in ($(OBJS_STAT)) do @%append $^@ +- %f
|
@for %f in ($(OBJS_STAT)) do @%append $^@ +- %f
|
||||||
|
|
||||||
#
|
|
||||||
# Dependencies based on "gcc -MM .."
|
|
||||||
#
|
|
||||||
$(OBJ_DIR)\file.obj: file.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h strtoofft.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h &
|
|
||||||
progress.h sendf.h escape.h file.h speedcheck.h getinfo.h transfer.h &
|
|
||||||
url.h curl_memory.h parsedate.h ..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\timeval.obj: timeval.c timeval.h setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\base64.obj: base64.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\mprintf.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h urldata.h cookie.h ..\include\curl\curl.h &
|
|
||||||
formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h &
|
|
||||||
curl_addrinfo.h splay.h easyif.h curl_base64.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\hostip.obj: hostip.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h inet_ntop.h ..\include\curl\mprintf.h curl_memory.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\progress.obj: progress.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
progress.h ..\include\curl\mprintf.h
|
|
||||||
$(OBJ_DIR)\formdata.obj: formdata.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h easyif.h strequal.h curl_memory.h &
|
|
||||||
curl_rand.h ..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\cookie.obj: cookie.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\mprintf.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h urldata.h cookie.h ..\include\curl\curl.h &
|
|
||||||
formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h &
|
|
||||||
curl_addrinfo.h splay.h strequal.h strtok.h sendf.h curl_memory.h share.h &
|
|
||||||
strtoofft.h rawstr.h memdebug.h curl_memrchr.h
|
|
||||||
$(OBJ_DIR)\http.obj: http.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h &
|
|
||||||
transfer.h sendf.h easyif.h progress.h curl_base64.h strequal.h &
|
|
||||||
sslgen.h http_digest.h http_ntlm.h http_negotiate.h url.h share.h &
|
|
||||||
http.h curl_memory.h select.h parsedate.h strtoofft.h multiif.h rawstr.h &
|
|
||||||
..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\sendf.obj: sendf.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h sendf.h connect.h sslgen.h ssh.h &
|
|
||||||
multiif.h ..\include\curl\mprintf.h curl_memory.h strerror.h easyif.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\ftp.obj: ftp.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h sendf.h easyif.h if2ip.h progress.h &
|
|
||||||
transfer.h escape.h http.h socks.h ftp.h strtoofft.h strequal.h &
|
|
||||||
sslgen.h connect.h strerror.h inet_ntop.h inet_pton.h select.h &
|
|
||||||
parsedate.h sockaddr.h multiif.h url.h ..\include\curl\mprintf.h &
|
|
||||||
curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\url.obj: url.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h netrc.h &
|
|
||||||
sslgen.h transfer.h sendf.h progress.h strequal.h strerror.h escape.h &
|
|
||||||
strtok.h share.h content_encoding.h http_digest.h http_negotiate.h &
|
|
||||||
select.h multiif.h easyif.h speedcheck.h rawstr.h ftp.h dict.h telnet.h &
|
|
||||||
tftp.h http.h file.h curl_ldap.h ssh.h url.h connect.h inet_ntop.h &
|
|
||||||
http_ntlm.h socks.h ..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\dict.obj: dict.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h &
|
|
||||||
transfer.h sendf.h progress.h strequal.h dict.h rawstr.h &
|
|
||||||
..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\if2ip.obj: if2ip.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h inet_ntop.h strequal.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h if2ip.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\speedcheck.obj: speedcheck.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h &
|
|
||||||
formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h &
|
|
||||||
curl_addrinfo.h splay.h sendf.h multiif.h speedcheck.h
|
|
||||||
$(OBJ_DIR)\ldap.obj: ldap.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\ssluse.obj: ssluse.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
url.h inet_pton.h ssluse.h connect.h strequal.h select.h sslgen.h &
|
|
||||||
rawstr.h ..\include\curl\mprintf.h
|
|
||||||
$(OBJ_DIR)\version.obj: version.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h sslgen.h ..\include\curl\mprintf.h
|
|
||||||
$(OBJ_DIR)\getenv.obj: getenv.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\escape.obj: escape.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
curl_memory.h urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h &
|
|
||||||
hash.h llist.h curl_addrinfo.h splay.h easyif.h &
|
|
||||||
..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\mprintf.obj: mprintf.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\mprintf.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h curl_memory.h ..\include\curl\curl.h memdebug.h
|
|
||||||
$(OBJ_DIR)\telnet.obj: telnet.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h &
|
|
||||||
transfer.h sendf.h telnet.h connect.h ..\include\curl\mprintf.h &
|
|
||||||
arpa_telnet.h curl_memory.h select.h strequal.h rawstr.h memdebug.h
|
|
||||||
$(OBJ_DIR)\netrc.obj: netrc.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
netrc.h strequal.h strtok.h curl_memory.h rawstr.h ..\include\curl\mprintf.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\getinfo.obj: getinfo.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h getinfo.h curl_memory.h sslgen.h connect.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\transfer.obj: transfer.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h strtoofft.h strequal.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h rawstr.h urldata.h &
|
|
||||||
cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h &
|
|
||||||
curl_addrinfo.h splay.h netrc.h content_encoding.h transfer.h sendf.h &
|
|
||||||
speedcheck.h progress.h http.h url.h getinfo.h sslgen.h http_digest.h &
|
|
||||||
http_ntlm.h http_negotiate.h share.h curl_memory.h select.h multiif.h &
|
|
||||||
easyif.h ..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\strequal.obj: strequal.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h strequal.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h
|
|
||||||
$(OBJ_DIR)\easy.obj: easy.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h strequal.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h urldata.h cookie.h &
|
|
||||||
formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h &
|
|
||||||
curl_addrinfo.h splay.h transfer.h sslgen.h url.h getinfo.h share.h &
|
|
||||||
strdup.h curl_memory.h progress.h easyif.h select.h sendf.h http_ntlm.h &
|
|
||||||
curl_rand.h connect.h ..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\security.obj: security.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\krb4.obj: krb4.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\krb5.obj: krb5.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\memdebug.obj: memdebug.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\mprintf.h urldata.h cookie.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h curl_memory.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\http_chunks.obj: http_chunks.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
urldata.h cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
content_encoding.h http.h curl_memory.h easyif.h ..\include\curl\mprintf.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\strtok.obj: strtok.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h strtok.h
|
|
||||||
$(OBJ_DIR)\connect.obj: connect.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\mprintf.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h urldata.h cookie.h ..\include\curl\curl.h &
|
|
||||||
formdata.h timeval.h http_chunks.h hostip.h hash.h llist.h &
|
|
||||||
curl_addrinfo.h splay.h sendf.h if2ip.h strerror.h connect.h curl_memory.h &
|
|
||||||
select.h url.h multiif.h sockaddr.h inet_ntop.h sslgen.h memdebug.h
|
|
||||||
$(OBJ_DIR)\llist.obj: llist.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h llist.h curl_memory.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h memdebug.h
|
|
||||||
$(OBJ_DIR)\hash.obj: hash.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h hash.h llist.h &
|
|
||||||
..\include\curl\mprintf.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h curl_memory.h &
|
|
||||||
..\include\curl\curl.h memdebug.h
|
|
||||||
$(OBJ_DIR)\multi.obj: multi.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h transfer.h url.h connect.h progress.h &
|
|
||||||
easyif.h multiif.h sendf.h http.h ..\include\curl\mprintf.h curl_memory.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\content_encoding.obj: content_encoding.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\share.obj: share.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h share.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\http_digest.obj: http_digest.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
urldata.h cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
rawstr.h curl_base64.h curl_md5.h http_digest.h strtok.h url.h curl_memory.h &
|
|
||||||
easyif.h ..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\md5.obj: md5.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h curl_md5.h
|
|
||||||
$(OBJ_DIR)\http_negotiate.obj: http_negotiate.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\http_ntlm.obj: http_ntlm.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
urldata.h cookie.h ..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h easyif.h &
|
|
||||||
sendf.h rawstr.h curl_base64.h http_ntlm.h url.h curl_memory.h ssluse.h &
|
|
||||||
..\include\curl\mprintf.h memdebug.h
|
|
||||||
$(OBJ_DIR)\inet_pton.obj: inet_pton.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
inet_pton.h
|
|
||||||
$(OBJ_DIR)\strtoofft.obj: strtoofft.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
strtoofft.h
|
|
||||||
$(OBJ_DIR)\strerror.obj: strerror.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
strerror.h urldata.h cookie.h formdata.h timeval.h http_chunks.h &
|
|
||||||
hostip.h hash.h llist.h curl_addrinfo.h splay.h &
|
|
||||||
..\include\curl\mprintf.h
|
|
||||||
$(OBJ_DIR)\hostares.obj: hostares.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h multiif.h inet_pton.h connect.h select.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\hostasyn.obj: hostasyn.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h ..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\hostip4.obj: hostip4.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h inet_pton.h ..\include\curl\mprintf.h curl_memory.h &
|
|
||||||
memdebug.h
|
|
||||||
$(OBJ_DIR)\hostip6.obj: hostip6.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h inet_pton.h connect.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\hostsyn.obj: hostsyn.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h ..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\hostthre.obj: hostthre.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
share.h strerror.h url.h multiif.h inet_pton.h &
|
|
||||||
..\include\curl\mprintf.h inet_ntop.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\inet_ntop.obj: inet_ntop.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\mprintf.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h inet_ntop.h
|
|
||||||
$(OBJ_DIR)\parsedate.obj: parsedate.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h rawstr.h parsedate.h
|
|
||||||
$(OBJ_DIR)\select.obj: select.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h ..\include\curl\curl.h &
|
|
||||||
..\include\curl\curlver.h ..\include\curl\curlrules.h &
|
|
||||||
..\include\curl\easy.h ..\include\curl\multi.h ..\include\curl\curl.h &
|
|
||||||
urldata.h cookie.h formdata.h timeval.h http_chunks.h hostip.h hash.h &
|
|
||||||
llist.h curl_addrinfo.h splay.h connect.h select.h
|
|
||||||
$(OBJ_DIR)\gtls.obj: gtls.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\sslgen.obj: sslgen.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sslgen.h &
|
|
||||||
ssluse.h gtls.h nssg.h qssl.h sendf.h rawstr.h url.h curl_memory.h &
|
|
||||||
progress.h memdebug.h
|
|
||||||
$(OBJ_DIR)\tftp.obj: tftp.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h &
|
|
||||||
transfer.h sendf.h tftp.h progress.h connect.h strerror.h sockaddr.h &
|
|
||||||
url.h ..\include\curl\mprintf.h curl_memory.h select.h memdebug.h
|
|
||||||
$(OBJ_DIR)\splay.obj: splay.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h splay.h
|
|
||||||
$(OBJ_DIR)\strdup.obj: strdup.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h strdup.h
|
|
||||||
$(OBJ_DIR)\socks.obj: socks.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
strequal.h select.h connect.h socks.h memdebug.h
|
|
||||||
$(OBJ_DIR)\ssh.obj: ssh.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\nss.obj: nss.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h urldata.h cookie.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h formdata.h timeval.h &
|
|
||||||
http_chunks.h hostip.h hash.h llist.h curl_addrinfo.h splay.h sendf.h &
|
|
||||||
url.h connect.h strequal.h select.h sslgen.h ..\include\curl\mprintf.h
|
|
||||||
$(OBJ_DIR)\qssl.obj: qssl.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h
|
|
||||||
$(OBJ_DIR)\nonblock.obj: nonblock.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h nonblock.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h
|
|
||||||
$(OBJ_DIR)\rawstr.obj: rawstr.c setup.h config-win32.h ..\include\curl\curlbuild.h &
|
|
||||||
..\include\curl\curlrules.h setup_once.h rawstr.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h
|
|
||||||
$(OBJ_DIR)\curl_addrinfo.obj: curl_addrinfo.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h curl_addrinfo.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\curl_rand.obj: curl_rand.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h curl_rand.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\curl_memrchr.obj: curl_memrchr.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h curl_memrchr.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\imap.obj: imap.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h imap.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\pop3.obj: pop3.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h pop3.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\smtp.obj: smtp.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h smtp.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
$(OBJ_DIR)\pingpong.obj: pingpong.c setup.h config-win32.h &
|
|
||||||
..\include\curl\curlbuild.h ..\include\curl\curlrules.h setup_once.h &
|
|
||||||
..\include\curl\curl.h ..\include\curl\curlver.h &
|
|
||||||
..\include\curl\curlrules.h ..\include\curl\easy.h &
|
|
||||||
..\include\curl\multi.h ..\include\curl\curl.h pingpong.h &
|
|
||||||
..\include\curl\mprintf.h curl_memory.h memdebug.h
|
|
||||||
|
@@ -37,13 +37,17 @@ EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 Makefile.riscos $(DSP) \
|
|||||||
Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot \
|
Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot \
|
||||||
config-win32ce.h config-os400.h setup-os400.h config-symbian.h \
|
config-win32ce.h config-os400.h setup-os400.h config-symbian.h \
|
||||||
Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl \
|
Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl \
|
||||||
firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h Makefile.vxworks
|
mk-ca-bundle.vbs firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h \
|
||||||
|
Makefile.vxworks
|
||||||
|
|
||||||
CLEANFILES = $(DSP) $(VCPROJ)
|
CLEANFILES = $(DSP) $(VCPROJ)
|
||||||
|
|
||||||
lib_LTLIBRARIES = libcurl.la
|
lib_LTLIBRARIES = libcurl.la
|
||||||
LIBCURL_LIBS = @LIBCURL_LIBS@
|
LIBCURL_LIBS = @LIBCURL_LIBS@
|
||||||
|
|
||||||
|
# This might hold -Werror
|
||||||
|
CFLAGS += @CURL_CFLAG_EXTRAS@
|
||||||
|
|
||||||
# Specify our include paths here, and do it relative to $(top_srcdir) and
|
# Specify our include paths here, and do it relative to $(top_srcdir) and
|
||||||
# $(top_builddir), to ensure that these paths which belong to the library
|
# $(top_builddir), to ensure that these paths which belong to the library
|
||||||
# being currently built and tested are searched before the library which
|
# being currently built and tested are searched before the library which
|
||||||
|
@@ -1,28 +1,40 @@
|
|||||||
# ./lib/Makefile.inc
|
# ./lib/Makefile.inc
|
||||||
|
# Using the backslash as line continuation character might be problematic
|
||||||
|
# with some make flavours, as Watcom's wmake showed us already. If we
|
||||||
|
# ever want to change this in a portable manner then we should consider
|
||||||
|
# this idea (posted to the libcurl list by Adam Kellas):
|
||||||
|
# CSRC1 = file1.c file2.c file3.c
|
||||||
|
# CSRC2 = file4.c file5.c file6.c
|
||||||
|
# CSOURCES = $(CSRC1) $(CSRC2)
|
||||||
|
|
||||||
CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c \
|
CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c \
|
||||||
cookie.c http.c sendf.c ftp.c url.c dict.c if2ip.c speedcheck.c \
|
cookie.c http.c sendf.c ftp.c url.c dict.c if2ip.c speedcheck.c \
|
||||||
ldap.c ssluse.c version.c getenv.c escape.c mprintf.c telnet.c \
|
ldap.c ssluse.c version.c getenv.c escape.c mprintf.c telnet.c \
|
||||||
netrc.c getinfo.c transfer.c strequal.c easy.c security.c krb4.c \
|
netrc.c getinfo.c transfer.c strequal.c easy.c security.c krb4.c \
|
||||||
krb5.c memdebug.c http_chunks.c strtok.c connect.c llist.c hash.c \
|
curl_fnmatch.c fileinfo.c ftplistparser.c wildcard.c krb5.c \
|
||||||
multi.c content_encoding.c share.c http_digest.c md5.c curl_rand.c \
|
memdebug.c http_chunks.c strtok.c connect.c llist.c hash.c multi.c \
|
||||||
|
content_encoding.c share.c http_digest.c md4.c md5.c curl_rand.c \
|
||||||
http_negotiate.c http_ntlm.c inet_pton.c strtoofft.c strerror.c \
|
http_negotiate.c http_ntlm.c inet_pton.c strtoofft.c strerror.c \
|
||||||
hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c \
|
hostares.c hostasyn.c hostip4.c hostip6.c hostsyn.c hostthre.c \
|
||||||
inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c \
|
inet_ntop.c parsedate.c select.c gtls.c sslgen.c tftp.c splay.c \
|
||||||
strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c \
|
strdup.c socks.c ssh.c nss.c qssl.c rawstr.c curl_addrinfo.c \
|
||||||
socks_gssapi.c socks_sspi.c curl_sspi.c slist.c nonblock.c \
|
socks_gssapi.c socks_sspi.c curl_sspi.c slist.c nonblock.c \
|
||||||
curl_memrchr.c imap.c pop3.c smtp.c pingpong.c rtsp.c curl_threads.c \
|
curl_memrchr.c imap.c pop3.c smtp.c pingpong.c rtsp.c curl_threads.c \
|
||||||
warnless.c
|
warnless.c hmac.c polarssl.c curl_rtmp.c openldap.c curl_gethostname.c\
|
||||||
|
gopher.c
|
||||||
|
|
||||||
HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h \
|
HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h \
|
||||||
progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h \
|
progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h \
|
||||||
if2ip.h speedcheck.h urldata.h curl_ldap.h ssluse.h escape.h telnet.h \
|
if2ip.h speedcheck.h urldata.h curl_ldap.h ssluse.h escape.h telnet.h \
|
||||||
getinfo.h strequal.h krb4.h memdebug.h http_chunks.h curl_rand.h \
|
getinfo.h strequal.h krb4.h memdebug.h http_chunks.h curl_rand.h \
|
||||||
strtok.h connect.h llist.h hash.h content_encoding.h share.h \
|
curl_fnmatch.h wildcard.h fileinfo.h ftplistparser.h strtok.h \
|
||||||
|
connect.h llist.h hash.h content_encoding.h share.h curl_md4.h \
|
||||||
curl_md5.h http_digest.h http_negotiate.h http_ntlm.h inet_pton.h \
|
curl_md5.h http_digest.h http_negotiate.h http_ntlm.h inet_pton.h \
|
||||||
strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h setup.h \
|
strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h setup.h \
|
||||||
transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h \
|
transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h \
|
||||||
tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h nssg.h \
|
tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h nssg.h \
|
||||||
curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h nonblock.h \
|
curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h nonblock.h \
|
||||||
curl_memrchr.h imap.h pop3.h smtp.h pingpong.h rtsp.h curl_threads.h \
|
curl_memrchr.h imap.h pop3.h smtp.h pingpong.h rtsp.h curl_threads.h \
|
||||||
warnless.h
|
warnless.h curl_hmac.h polarssl.h curl_rtmp.h curl_gethostname.h \
|
||||||
|
gopher.h
|
||||||
|
|
||||||
|
@@ -1,13 +1,13 @@
|
|||||||
#########################################################################
|
#########################################################################
|
||||||
#
|
#
|
||||||
## Makefile for building libcurl.a with MingW32 (GCC-3.2 or later)
|
## Makefile for building libcurl.a with MingW32 (GCC-3.2 or later)
|
||||||
## and optionally OpenSSL (0.9.8), libssh2 (1.1), zlib (1.2.3)
|
## and optionally OpenSSL (0.9.8), libssh2 (1.2), zlib (1.2.5)
|
||||||
##
|
##
|
||||||
## Usage:
|
## Usage:
|
||||||
## mingw32-make -f Makefile.m32 [SSL=1] [SSH2=1] [ZLIB=1] [IDN=1] [SSPI=1] [IPV6=1] [LDAPS=1] [DYN=1]
|
## mingw32-make -f Makefile.m32 [SSL=1] [SSH2=1] [ZLIB=1] [IDN=1] [SSPI=1] [IPV6=1] [LDAPS=1] [RTMP=1] [DYN=1]
|
||||||
##
|
##
|
||||||
## Hint: you can also set environment vars to control the build, f.e.:
|
## Hint: you can also set environment vars to control the build, f.e.:
|
||||||
## set ZLIB_PATH=c:/zlib-1.2.3
|
## set ZLIB_PATH=c:/zlib-1.2.5
|
||||||
## set ZLIB=1
|
## set ZLIB=1
|
||||||
##
|
##
|
||||||
## Comments to: Troy Engel <tengel@sonic.net> or
|
## Comments to: Troy Engel <tengel@sonic.net> or
|
||||||
@@ -16,20 +16,24 @@
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
ifndef ZLIB_PATH
|
ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ../../zlib-1.2.4
|
ZLIB_PATH = ../../zlib-1.2.5
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
ifndef OPENSSL_PATH
|
ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../openssl-0.9.8n
|
OPENSSL_PATH = ../../openssl-0.9.8o
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your LibSSH2 package.
|
# Edit the path below to point to the base of your LibSSH2 package.
|
||||||
ifndef LIBSSH2_PATH
|
ifndef LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../libssh2-1.2.4
|
LIBSSH2_PATH = ../../libssh2-1.2.7
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your libidn package.
|
# Edit the path below to point to the base of your libidn package.
|
||||||
ifndef LIBIDN_PATH
|
ifndef LIBIDN_PATH
|
||||||
LIBIDN_PATH = ../../libidn-1.18
|
LIBIDN_PATH = ../../libidn-1.18
|
||||||
endif
|
endif
|
||||||
|
# Edit the path below to point to the base of your librtmp package.
|
||||||
|
ifndef LIBRTMP_PATH
|
||||||
|
LIBRTMP_PATH = ../../librtmp-2.3
|
||||||
|
endif
|
||||||
# Edit the path below to point to the base of your Novell LDAP NDK.
|
# Edit the path below to point to the base of your Novell LDAP NDK.
|
||||||
ifndef LDAP_SDK
|
ifndef LDAP_SDK
|
||||||
LDAP_SDK = c:/novell/ndk/cldapsdk/win32
|
LDAP_SDK = c:/novell/ndk/cldapsdk/win32
|
||||||
@@ -47,7 +51,7 @@ LDFLAGS = -s
|
|||||||
RANLIB = ranlib
|
RANLIB = ranlib
|
||||||
RC = windres
|
RC = windres
|
||||||
RCFLAGS = --include-dir=../include -DDEBUGBUILD=0 -O COFF -i
|
RCFLAGS = --include-dir=../include -DDEBUGBUILD=0 -O COFF -i
|
||||||
RM = del /q /f > NUL 2>&1
|
RM = del /q /f 2>NUL
|
||||||
STRIP = strip -g
|
STRIP = strip -g
|
||||||
|
|
||||||
########################################################
|
########################################################
|
||||||
@@ -61,6 +65,11 @@ ifdef ARES
|
|||||||
DLL_LIBS += -L$(LIBCARES_PATH) -lcares
|
DLL_LIBS += -L$(LIBCARES_PATH) -lcares
|
||||||
libcurl_dll_DEPENDENCIES = $(LIBCARES_PATH)/libcares.a
|
libcurl_dll_DEPENDENCIES = $(LIBCARES_PATH)/libcares.a
|
||||||
endif
|
endif
|
||||||
|
ifdef RTMP
|
||||||
|
INCLUDES += -I"$(LIBRTMP_PATH)"
|
||||||
|
CFLAGS += -DUSE_LIBRTMP
|
||||||
|
DLL_LIBS += -L"$(LIBRTMP_PATH)/librtmp" -lrtmp -lwinmm
|
||||||
|
endif
|
||||||
ifdef SSH2
|
ifdef SSH2
|
||||||
INCLUDES += -I"$(LIBSSH2_PATH)/include" -I"$(LIBSSH2_PATH)/win32"
|
INCLUDES += -I"$(LIBSSH2_PATH)/include" -I"$(LIBSSH2_PATH)/win32"
|
||||||
CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H
|
CFLAGS += -DUSE_LIBSSH2 -DHAVE_LIBSSH2_H
|
||||||
@@ -148,7 +157,7 @@ $(libcurl_dll_LIBRARY): $(libcurl_a_OBJECTS) $(RESOURCE) $(libcurl_dll_DEPENDENC
|
|||||||
clean:
|
clean:
|
||||||
-$(RM) $(libcurl_a_OBJECTS) $(RESOURCE)
|
-$(RM) $(libcurl_a_OBJECTS) $(RESOURCE)
|
||||||
|
|
||||||
distrib: clean
|
distclean vclean: clean
|
||||||
-$(RM) $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_a_LIBRARY)
|
-$(RM) $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_a_LIBRARY)
|
||||||
|
|
||||||
FORCE: ;
|
FORCE: ;
|
||||||
@@ -156,4 +165,3 @@ FORCE: ;
|
|||||||
$(LIBCARES_PATH)/libcares.a:
|
$(LIBCARES_PATH)/libcares.a:
|
||||||
$(MAKE) -C $(LIBCARES_PATH) -f Makefile.m32
|
$(MAKE) -C $(LIBCARES_PATH) -f Makefile.m32
|
||||||
|
|
||||||
|
|
||||||
|
@@ -14,17 +14,17 @@ endif
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
ifndef ZLIB_PATH
|
ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ../../zlib-1.2.4
|
ZLIB_PATH = ../../zlib-1.2.5
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
ifndef OPENSSL_PATH
|
ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../openssl-0.9.8n
|
OPENSSL_PATH = ../../openssl-0.9.8o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your LibSSH2 package.
|
# Edit the path below to point to the base of your LibSSH2 package.
|
||||||
ifndef LIBSSH2_PATH
|
ifndef LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../libssh2-1.2.4
|
LIBSSH2_PATH = ../../libssh2-1.2.7
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your libidn package.
|
# Edit the path below to point to the base of your libidn package.
|
||||||
@@ -32,6 +32,11 @@ ifndef LIBIDN_PATH
|
|||||||
LIBIDN_PATH = ../../libidn-1.18
|
LIBIDN_PATH = ../../libidn-1.18
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Edit the path below to point to the base of your librtmp package.
|
||||||
|
ifndef LIBRTMP_PATH
|
||||||
|
LIBRTMP_PATH = ../../librtmp-2.3
|
||||||
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your c-ares package.
|
# Edit the path below to point to the base of your c-ares package.
|
||||||
ifndef LIBCARES_PATH
|
ifndef LIBCARES_PATH
|
||||||
LIBCARES_PATH = ../ares
|
LIBCARES_PATH = ../ares
|
||||||
@@ -84,14 +89,13 @@ else
|
|||||||
CC = gcc
|
CC = gcc
|
||||||
endif
|
endif
|
||||||
PERL = perl
|
PERL = perl
|
||||||
# a native win32 awk can be downloaded from here:
|
# Here you can find a native Win32 binary of the original awk:
|
||||||
# http://www.gknw.net/development/prgtools/awk-20070501.zip
|
# http://www.gknw.net/development/prgtools/awk-20070501.zip
|
||||||
AWK = awk
|
AWK = awk
|
||||||
YACC = bison -y
|
|
||||||
CP = cp -afv
|
CP = cp -afv
|
||||||
MKDIR = mkdir
|
MKDIR = mkdir
|
||||||
# RM = rm -f
|
# RM = rm -f
|
||||||
# if you want to mark the target as MTSAFE you will need a tool for
|
# If you want to mark the target as MTSAFE you will need a tool for
|
||||||
# generating the xdc data for the linker; here's a minimal tool:
|
# generating the xdc data for the linker; here's a minimal tool:
|
||||||
# http://www.gknw.net/development/prgtools/mkxdc.zip
|
# http://www.gknw.net/development/prgtools/mkxdc.zip
|
||||||
MPKXDC = mkxdc
|
MPKXDC = mkxdc
|
||||||
@@ -117,13 +121,13 @@ CFLAGS += -relax_pointers
|
|||||||
#CFLAGS += -w on
|
#CFLAGS += -w on
|
||||||
ifeq ($(LIBARCH),LIBC)
|
ifeq ($(LIBARCH),LIBC)
|
||||||
ifeq ($(POSIXFL),1)
|
ifeq ($(POSIXFL),1)
|
||||||
PRELUDE = $(SDK_LIBC)/imports/posixpre.o
|
PRELUDE = $(NDK_LIBC)/imports/posixpre.o
|
||||||
else
|
else
|
||||||
PRELUDE = $(SDK_LIBC)/imports/libcpre.o
|
PRELUDE = $(NDK_LIBC)/imports/libcpre.o
|
||||||
endif
|
endif
|
||||||
CFLAGS += -align 4
|
CFLAGS += -align 4
|
||||||
else
|
else
|
||||||
# PRELUDE = $(SDK_CLIB)/imports/clibpre.o
|
# PRELUDE = $(NDK_CLIB)/imports/clibpre.o
|
||||||
# to avoid the __init_* / __deinit_* whoes dont use prelude from NDK
|
# to avoid the __init_* / __deinit_* whoes dont use prelude from NDK
|
||||||
PRELUDE = "$(MWCW_PATH)/libraries/runtime/prelude.obj"
|
PRELUDE = "$(MWCW_PATH)/libraries/runtime/prelude.obj"
|
||||||
# CFLAGS += -include "$(MWCW_PATH)/headers/nlm_clib_prefix.h"
|
# CFLAGS += -include "$(MWCW_PATH)/headers/nlm_clib_prefix.h"
|
||||||
@@ -140,12 +144,12 @@ CFLAGS += -fno-builtin -fpcc-struct-return -fno-strict-aliasing
|
|||||||
CFLAGS += -Wall # -pedantic
|
CFLAGS += -Wall # -pedantic
|
||||||
ifeq ($(LIBARCH),LIBC)
|
ifeq ($(LIBARCH),LIBC)
|
||||||
ifeq ($(POSIXFL),1)
|
ifeq ($(POSIXFL),1)
|
||||||
PRELUDE = $(SDK_LIBC)/imports/posixpre.gcc.o
|
PRELUDE = $(NDK_LIBC)/imports/posixpre.gcc.o
|
||||||
else
|
else
|
||||||
PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o
|
PRELUDE = $(NDK_LIBC)/imports/libcpre.gcc.o
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
PRELUDE = $(SDK_CLIB)/imports/clibpre.gcc.o
|
PRELUDE = $(NDK_CLIB)/imports/clibpre.gcc.o
|
||||||
# to avoid the __init_* / __deinit_* whoes dont use prelude from NDK
|
# to avoid the __init_* / __deinit_* whoes dont use prelude from NDK
|
||||||
# http://www.gknw.net/development/mk_nlm/gcc_pre.zip
|
# http://www.gknw.net/development/mk_nlm/gcc_pre.zip
|
||||||
# PRELUDE = $(NDK_ROOT)/pre/prelude.o
|
# PRELUDE = $(NDK_ROOT)/pre/prelude.o
|
||||||
@@ -154,9 +158,15 @@ endif
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
NDK_ROOT = $(NDKBASE)/ndk
|
NDK_ROOT = $(NDKBASE)/ndk
|
||||||
SDK_CLIB = $(NDK_ROOT)/nwsdk
|
ifndef NDK_CLIB
|
||||||
SDK_LIBC = $(NDK_ROOT)/libc
|
NDK_CLIB = $(NDK_ROOT)/nwsdk
|
||||||
SDK_LDAP = $(NDK_ROOT)/cldapsdk/netware
|
endif
|
||||||
|
ifndef NDK_LIBC
|
||||||
|
NDK_LIBC = $(NDK_ROOT)/libc
|
||||||
|
endif
|
||||||
|
ifndef NDK_LDAP
|
||||||
|
NDK_LDAP = $(NDK_ROOT)/cldapsdk/netware
|
||||||
|
endif
|
||||||
CURL_INC = ../include
|
CURL_INC = ../include
|
||||||
CURL_LIB = ../lib
|
CURL_LIB = ../lib
|
||||||
|
|
||||||
@@ -175,6 +185,10 @@ else
|
|||||||
IMPORTS += @$(LIBSSH2_PATH)/nw/libssh2.imp
|
IMPORTS += @$(LIBSSH2_PATH)/nw/libssh2.imp
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
ifdef WITH_RTMP
|
||||||
|
INCLUDES += -I$(LIBRTMP_PATH)
|
||||||
|
LDLIBS += $(LIBRTMP_PATH)/librtmp/librtmp.$(LIBEXT)
|
||||||
|
endif
|
||||||
ifdef WITH_SSL
|
ifdef WITH_SSL
|
||||||
INCLUDES += -I$(OPENSSL_PATH)/outinc_nw_$(LIBARCH_L)
|
INCLUDES += -I$(OPENSSL_PATH)/outinc_nw_$(LIBARCH_L)
|
||||||
LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/ssl.$(LIBEXT)
|
LDLIBS += $(OPENSSL_PATH)/out_nw_$(LIBARCH_L)/ssl.$(LIBEXT)
|
||||||
@@ -197,17 +211,17 @@ ifdef WITH_IDN
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(LIBARCH),LIBC)
|
ifeq ($(LIBARCH),LIBC)
|
||||||
INCLUDES += -I$(SDK_LIBC)/include
|
INCLUDES += -I$(NDK_LIBC)/include
|
||||||
# INCLUDES += -I$(SDK_LIBC)/include/nks
|
# INCLUDES += -I$(NDK_LIBC)/include/nks
|
||||||
# INCLUDES += -I$(SDK_LIBC)/include/winsock
|
# INCLUDES += -I$(NDK_LIBC)/include/winsock
|
||||||
CFLAGS += -D_POSIX_SOURCE
|
CFLAGS += -D_POSIX_SOURCE
|
||||||
else
|
else
|
||||||
INCLUDES += -I$(SDK_CLIB)/include/nlm
|
INCLUDES += -I$(NDK_CLIB)/include/nlm
|
||||||
# INCLUDES += -I$(SDK_CLIB)/include/nlm/obsolete
|
# INCLUDES += -I$(NDK_CLIB)/include/nlm/obsolete
|
||||||
# INCLUDES += -I$(SDK_CLIB)/include
|
# INCLUDES += -I$(NDK_CLIB)/include
|
||||||
endif
|
endif
|
||||||
ifndef DISABLE_LDAP
|
ifndef DISABLE_LDAP
|
||||||
INCLUDES += -I$(SDK_LDAP)/$(LIBARCH_L)/inc
|
INCLUDES += -I$(NDK_LDAP)/$(LIBARCH_L)/inc
|
||||||
endif
|
endif
|
||||||
CFLAGS += $(INCLUDES)
|
CFLAGS += $(INCLUDES)
|
||||||
|
|
||||||
@@ -269,7 +283,7 @@ clean:
|
|||||||
-$(RM) curl_config.h
|
-$(RM) curl_config.h
|
||||||
-$(RM) -r $(OBJDIR)
|
-$(RM) -r $(OBJDIR)
|
||||||
|
|
||||||
distclean: clean
|
distclean vclean: clean
|
||||||
-$(RM) $(TARGET).$(LIBEXT) $(TARGET).nlm
|
-$(RM) $(TARGET).$(LIBEXT) $(TARGET).nlm
|
||||||
-$(RM) certdata.txt ca-bundle.crt
|
-$(RM) certdata.txt ca-bundle.crt
|
||||||
|
|
||||||
@@ -323,15 +337,15 @@ endif
|
|||||||
ifeq ($(LIBARCH),CLIB)
|
ifeq ($(LIBARCH),CLIB)
|
||||||
@echo $(DL)start _Prelude$(DL) >> $@
|
@echo $(DL)start _Prelude$(DL) >> $@
|
||||||
@echo $(DL)exit _Stop$(DL) >> $@
|
@echo $(DL)exit _Stop$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_CLIB)/imports/clib.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_CLIB)/imports/clib.imp$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_CLIB)/imports/threads.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_CLIB)/imports/threads.imp$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_CLIB)/imports/nlmlib.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_CLIB)/imports/nlmlib.imp$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_CLIB)/imports/socklib.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_CLIB)/imports/socklib.imp$(DL) >> $@
|
||||||
@echo $(DL)module clib$(DL) >> $@
|
@echo $(DL)module clib$(DL) >> $@
|
||||||
ifndef DISABLE_LDAP
|
ifndef DISABLE_LDAP
|
||||||
@echo $(DL)import @$(SDK_LDAP)/clib/imports/ldapsdk.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_LDAP)/clib/imports/ldapsdk.imp$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_LDAP)/clib/imports/ldapssl.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_LDAP)/clib/imports/ldapssl.imp$(DL) >> $@
|
||||||
# @echo $(DL)import @$(SDK_LDAP)/clib/imports/ldapx.imp$(DL) >> $@
|
# @echo $(DL)import @$(NDK_LDAP)/clib/imports/ldapx.imp$(DL) >> $@
|
||||||
@echo $(DL)module ldapsdk ldapssl$(DL) >> $@
|
@echo $(DL)module ldapsdk ldapssl$(DL) >> $@
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
@@ -348,13 +362,13 @@ else
|
|||||||
@echo $(DL)exit _LibCPostlude$(DL) >> $@
|
@echo $(DL)exit _LibCPostlude$(DL) >> $@
|
||||||
@echo $(DL)check _LibCCheckUnload$(DL) >> $@
|
@echo $(DL)check _LibCCheckUnload$(DL) >> $@
|
||||||
endif
|
endif
|
||||||
@echo $(DL)import @$(SDK_LIBC)/imports/libc.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_LIBC)/imports/libc.imp$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_LIBC)/imports/netware.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_LIBC)/imports/netware.imp$(DL) >> $@
|
||||||
@echo $(DL)module libc$(DL) >> $@
|
@echo $(DL)module libc$(DL) >> $@
|
||||||
ifndef DISABLE_LDAP
|
ifndef DISABLE_LDAP
|
||||||
@echo $(DL)import @$(SDK_LDAP)/libc/imports/lldapsdk.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_LDAP)/libc/imports/lldapsdk.imp$(DL) >> $@
|
||||||
@echo $(DL)import @$(SDK_LDAP)/libc/imports/lldapssl.imp$(DL) >> $@
|
@echo $(DL)import @$(NDK_LDAP)/libc/imports/lldapssl.imp$(DL) >> $@
|
||||||
# @echo $(DL)import @$(SDK_LDAP)/libc/imports/lldapx.imp$(DL) >> $@
|
# @echo $(DL)import @$(NDK_LDAP)/libc/imports/lldapx.imp$(DL) >> $@
|
||||||
@echo $(DL)module lldapsdk lldapssl$(DL) >> $@
|
@echo $(DL)module lldapsdk lldapssl$(DL) >> $@
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@@ -425,13 +439,6 @@ else
|
|||||||
@echo $(DL)#define HAVE_SYS_PARAM_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_SYS_PARAM_H 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_SYS_SELECT_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_SYS_SELECT_H 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_TERMIOS_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_TERMIOS_H 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_FREEADDRINFO 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_GETADDRINFO 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define RECV_TYPE_ARG1 int$(DL) >> $@
|
@echo $(DL)#define RECV_TYPE_ARG1 int$(DL) >> $@
|
||||||
@echo $(DL)#define RECV_TYPE_ARG2 void *$(DL) >> $@
|
@echo $(DL)#define RECV_TYPE_ARG2 void *$(DL) >> $@
|
||||||
@echo $(DL)#define RECV_TYPE_ARG3 size_t$(DL) >> $@
|
@echo $(DL)#define RECV_TYPE_ARG3 size_t$(DL) >> $@
|
||||||
@@ -451,11 +458,19 @@ else
|
|||||||
@echo $(DL)#define SEND_TYPE_ARG3 size_t$(DL) >> $@
|
@echo $(DL)#define SEND_TYPE_ARG3 size_t$(DL) >> $@
|
||||||
@echo $(DL)#define SEND_TYPE_ARG4 int$(DL) >> $@
|
@echo $(DL)#define SEND_TYPE_ARG4 int$(DL) >> $@
|
||||||
@echo $(DL)#define SEND_TYPE_RETV ssize_t$(DL) >> $@
|
@echo $(DL)#define SEND_TYPE_RETV ssize_t$(DL) >> $@
|
||||||
@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@
|
|
||||||
@echo $(DL)#define SIZEOF_OFF_T 8$(DL) >> $@
|
@echo $(DL)#define SIZEOF_OFF_T 8$(DL) >> $@
|
||||||
@echo $(DL)#define _LARGEFILE 1$(DL) >> $@
|
@echo $(DL)#define _LARGEFILE 1$(DL) >> $@
|
||||||
ifdef ENABLE_IPV6
|
ifdef ENABLE_IPV6
|
||||||
@echo $(DL)#define ENABLE_IPV6 1$(DL) >> $@
|
@echo $(DL)#define ENABLE_IPV6 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_AF_INET6 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_PF_INET6 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_FREEADDRINFO 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_GETADDRINFO 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_STRUCT_IN6_ADDR 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define HAVE_STRUCT_SOCKADDR_IN6 1$(DL) >> $@
|
||||||
|
@echo $(DL)#define SIZEOF_STRUCT_IN6_ADDR 16$(DL) >> $@
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@echo $(DL)#define USE_MANUAL 1$(DL) >> $@
|
@echo $(DL)#define USE_MANUAL 1$(DL) >> $@
|
||||||
@@ -491,7 +506,6 @@ endif
|
|||||||
@echo $(DL)#define HAVE_STRFTIME 1$(DL) >> $@
|
@echo $(DL)#define HAVE_STRFTIME 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_STRING_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_STRING_H 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_STRSTR 1$(DL) >> $@
|
@echo $(DL)#define HAVE_STRSTR 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_STRUCT_ADDRINFO 1$(DL) >> $@
|
|
||||||
@echo $(DL)#define HAVE_STRUCT_TIMEVAL 1$(DL) >> $@
|
@echo $(DL)#define HAVE_STRUCT_TIMEVAL 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_SYS_IOCTL_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_SYS_IOCTL_H 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_SYS_STAT_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_SYS_STAT_H 1$(DL) >> $@
|
||||||
@@ -555,6 +569,9 @@ endif
|
|||||||
ifdef WITH_IDN
|
ifdef WITH_IDN
|
||||||
@echo $(DL)#define HAVE_LIBIDN 1$(DL) >> $@
|
@echo $(DL)#define HAVE_LIBIDN 1$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_TLD_H 1$(DL) >> $@
|
@echo $(DL)#define HAVE_TLD_H 1$(DL) >> $@
|
||||||
|
endif
|
||||||
|
ifdef WITH_RTMP
|
||||||
|
@echo $(DL)#define USE_LIBRTMP 1$(DL) >> $@
|
||||||
endif
|
endif
|
||||||
@echo $(DL)#ifdef __GNUC__$(DL) >> $@
|
@echo $(DL)#ifdef __GNUC__$(DL) >> $@
|
||||||
@echo $(DL)#define HAVE_VARIADIC_MACROS_GCC 1$(DL) >> $@
|
@echo $(DL)#define HAVE_VARIADIC_MACROS_GCC 1$(DL) >> $@
|
||||||
@@ -616,6 +633,9 @@ $(CURL_INC)/curl/curlbuild.h: Makefile.netware FORCE
|
|||||||
@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@
|
@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@
|
||||||
@echo $(DL)** All your changes will be lost!!$(DL) >> $@
|
@echo $(DL)** All your changes will be lost!!$(DL) >> $@
|
||||||
@echo $(DL)*/$(DL) >> $@
|
@echo $(DL)*/$(DL) >> $@
|
||||||
|
@echo $(DL)#ifndef NETWARE$(DL) >> $@
|
||||||
|
@echo $(DL)#error This $(notdir $@) is created for NetWare platform!$(DL) >> $@
|
||||||
|
@echo $(DL)#endif$(DL) >> $@
|
||||||
@echo $(DL)#ifndef __CURL_CURLBUILD_H$(DL) >> $@
|
@echo $(DL)#ifndef __CURL_CURLBUILD_H$(DL) >> $@
|
||||||
@echo $(DL)#define __CURL_CURLBUILD_H$(DL) >> $@
|
@echo $(DL)#define __CURL_CURLBUILD_H$(DL) >> $@
|
||||||
ifeq ($(LIBARCH),LIBC)
|
ifeq ($(LIBARCH),LIBC)
|
||||||
|
@@ -1,21 +1,21 @@
|
|||||||
# Makefile for project libcurl
|
# Makefile for project libcurl
|
||||||
# Generated on Sun,13 Jan 2002.16:57:00 by EasyGCC (0.1.3 [beta 2] (3 Jan 2002))
|
|
||||||
# Contact: easygcc@melotech.co.uk
|
|
||||||
|
|
||||||
# Project objects:
|
# Project objects:
|
||||||
objs = o.base64 o.connect o.cookie o.dict \
|
objs = o.base64 o.connect o.cookie o.dict \
|
||||||
o.dllinit o.easy o.escape o.file \
|
o.dllinit o.easy o.escape o.file \
|
||||||
o.formdata o.ftp o.getenv \
|
o.formdata o.ftp o.getenv o.gopher \
|
||||||
o.getinfo o.getpass o.hostip \
|
o.getinfo o.getpass o.hostip \
|
||||||
o.hostip4 o.hostsyn o.http \
|
o.hostip4 o.hostsyn o.http \
|
||||||
o.http_chunks o.inet_ntop o.inet_pton o.if2ip o.krb4 o.ldap \
|
o.http_chunks o.inet_ntop o.inet_pton o.if2ip o.krb4 o.ldap \
|
||||||
|
o.curl_fnmatch o.fileinfo o.ftplistparser o.wildcard \
|
||||||
o.memdebug o.mprintf o.netrc o.parsedate o.progress \
|
o.memdebug o.mprintf o.netrc o.parsedate o.progress \
|
||||||
o.security o.select o.sendf o.speedcheck o.ssluse \
|
o.security o.select o.sendf o.speedcheck o.ssluse \
|
||||||
o.strequal o.strtok o.telnet o.timeval \
|
o.strequal o.strtok o.telnet o.timeval \
|
||||||
o.transfer o.url o.version o.strtoofft o.sslgen o.gtls \
|
o.transfer o.url o.version o.strtoofft o.sslgen o.gtls \
|
||||||
o.rawstr o.curl_addrinfo o.slist o.nonblock o.curl_rand \
|
o.rawstr o.curl_addrinfo o.slist o.nonblock o.curl_rand \
|
||||||
o.curl_memrchr o.imap o.pop3 o.smtp o.pingpong o.rtsp \
|
o.curl_memrchr o.imap o.pop3 o.smtp o.pingpong o.rtsp \
|
||||||
o.curl_threads o.warnless
|
o.curl_threads o.warnless o.hmac o.md5 o.curl_rtmp \
|
||||||
|
o.openldap o.polarssl o.md4 o.curl_gethostname
|
||||||
|
|
||||||
|
|
||||||
# Compile options:
|
# Compile options:
|
||||||
@@ -39,12 +39,18 @@ o.cookie: c.cookie
|
|||||||
o.curl_addrinfo: c.curl_addrinfo
|
o.curl_addrinfo: c.curl_addrinfo
|
||||||
gcc $(compileropts) -c -o curl_addrinfo.o c.curl_addrinfo
|
gcc $(compileropts) -c -o curl_addrinfo.o c.curl_addrinfo
|
||||||
|
|
||||||
|
o.curl_gethostname: c.curl_gethostname
|
||||||
|
gcc $(compileropts) -c -o curl_gethostname.o c.curl_gethostname
|
||||||
|
|
||||||
o.curl_memrchr: c.curl_memrchr
|
o.curl_memrchr: c.curl_memrchr
|
||||||
gcc $(compileropts) -c -o curl_memrchr.o c.curl_memrchr
|
gcc $(compileropts) -c -o curl_memrchr.o c.curl_memrchr
|
||||||
|
|
||||||
o.curl_rand: c.curl_rand
|
o.curl_rand: c.curl_rand
|
||||||
gcc $(compileropts) -c -o curl_rand.o c.curl_rand
|
gcc $(compileropts) -c -o curl_rand.o c.curl_rand
|
||||||
|
|
||||||
|
o.curl_rtmp: c.curl_rtmp
|
||||||
|
gcc $(compileropts) -c -o curl_rtmp.o c.curl_rtmp
|
||||||
|
|
||||||
o.curl_threads: c.curl_threads
|
o.curl_threads: c.curl_threads
|
||||||
gcc $(compileropts) -c -o curl_threads.o c.curl_threads
|
gcc $(compileropts) -c -o curl_threads.o c.curl_threads
|
||||||
|
|
||||||
@@ -78,6 +84,12 @@ o.getinfo: c.getinfo
|
|||||||
o.getpass: c.getpass
|
o.getpass: c.getpass
|
||||||
gcc $(compileropts) -c -o getpass.o c.getpass
|
gcc $(compileropts) -c -o getpass.o c.getpass
|
||||||
|
|
||||||
|
o.gopher: c.gopher
|
||||||
|
gcc $(compileropts) -c -o gopher.o c.gopher
|
||||||
|
|
||||||
|
o.hmac: c.hmac
|
||||||
|
gcc $(compileropts) -c -o hmac.o c.hmac
|
||||||
|
|
||||||
o.hostip: c.hostip
|
o.hostip: c.hostip
|
||||||
gcc $(compileropts) -c -o hostip.o c.hostip
|
gcc $(compileropts) -c -o hostip.o c.hostip
|
||||||
|
|
||||||
@@ -111,6 +123,12 @@ o.krb4: c.krb4
|
|||||||
o.ldap: c.ldap
|
o.ldap: c.ldap
|
||||||
gcc $(compileropts) -IOpenLDAP: -c -o ldap.o c.ldap
|
gcc $(compileropts) -IOpenLDAP: -c -o ldap.o c.ldap
|
||||||
|
|
||||||
|
o.md4: c.md4
|
||||||
|
gcc $(compileropts) -c -o md4.o c.md4
|
||||||
|
|
||||||
|
o.md5: c.md5
|
||||||
|
gcc $(compileropts) -c -o md5.o c.md5
|
||||||
|
|
||||||
o.memdebug: c.memdebug
|
o.memdebug: c.memdebug
|
||||||
gcc $(compileropts) -c -o memdebug.o c.memdebug
|
gcc $(compileropts) -c -o memdebug.o c.memdebug
|
||||||
|
|
||||||
@@ -120,12 +138,18 @@ o.mprintf: c.mprintf
|
|||||||
o.netrc: c.netrc
|
o.netrc: c.netrc
|
||||||
gcc $(compileropts) -c -o netrc.o c.netrc
|
gcc $(compileropts) -c -o netrc.o c.netrc
|
||||||
|
|
||||||
|
o.openldap: c.openldap
|
||||||
|
gcc $(compileropts) -c -o openldap.o c.openldap
|
||||||
|
|
||||||
o.parsedate: c.parsedate
|
o.parsedate: c.parsedate
|
||||||
gcc $(compileropts) -c -o parsedate.o c.parsedate
|
gcc $(compileropts) -c -o parsedate.o c.parsedate
|
||||||
|
|
||||||
o.pingpong: c.pingpong
|
o.pingpong: c.pingpong
|
||||||
gcc $(compileropts) -c -o pingpong.o c.pingpong
|
gcc $(compileropts) -c -o pingpong.o c.pingpong
|
||||||
|
|
||||||
|
o.polarssl: c.polarssl
|
||||||
|
gcc $(compileropts) -c -o polarssl.o c.polarssl
|
||||||
|
|
||||||
o.pop3: c.pop3
|
o.pop3: c.pop3
|
||||||
gcc $(compileropts) -c -o pop3.o c.pop3
|
gcc $(compileropts) -c -o pop3.o c.pop3
|
||||||
|
|
||||||
@@ -194,3 +218,15 @@ o.version: c.version
|
|||||||
|
|
||||||
o.warnless: c.warnless
|
o.warnless: c.warnless
|
||||||
gcc $(compileropts) -c -o warnless.o c.warnless
|
gcc $(compileropts) -c -o warnless.o c.warnless
|
||||||
|
|
||||||
|
o.curl_fnmatch: c.curl_fnmatch
|
||||||
|
gcc $(compileropts) -c -o curl_fnmatch.o c.curl_fnmatch
|
||||||
|
|
||||||
|
o.fileinfo: c.fileinfo
|
||||||
|
gcc $(compileropts) -c -o fileinfo.o c.fileinfo
|
||||||
|
|
||||||
|
o.ftplistparser: c.ftplistparser
|
||||||
|
gcc $(compileropts) -c -o ftplistparser.o c.ftplistparser
|
||||||
|
|
||||||
|
o.wildcard: c.wildcard
|
||||||
|
gcc $(compileropts) -c -o wildcard.o c.wildcard
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 1999 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 1999 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# This software is licensed as described in the file COPYING, which
|
# This software is licensed as described in the file COPYING, which
|
||||||
# you should have received as part of this distribution. The terms
|
# you should have received as part of this distribution. The terms
|
||||||
@@ -18,7 +18,6 @@
|
|||||||
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
# KIND, either express or implied.
|
# KIND, either express or implied.
|
||||||
#
|
#
|
||||||
# $Id: Makefile.am,v 1.139 2008-11-03 08:50:58 bagder Exp $
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
#
|
#
|
||||||
# Makefile for building libcurl with MSVC6
|
# Makefile for building libcurl with MSVC6
|
||||||
@@ -55,11 +54,11 @@ IMPLIB_NAME = libcurl_imp
|
|||||||
IMPLIB_NAME_DEBUG = libcurld_imp
|
IMPLIB_NAME_DEBUG = libcurld_imp
|
||||||
|
|
||||||
!IFNDEF OPENSSL_PATH
|
!IFNDEF OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../openssl-0.9.8g
|
OPENSSL_PATH = ../../openssl-0.9.8o
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF ZLIB_PATH
|
!IFNDEF ZLIB_PATH
|
||||||
ZLIB_PATH = ../../zlib-1.2.3
|
ZLIB_PATH = ../../zlib-1.2.5
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF MACHINE
|
!IFNDEF MACHINE
|
||||||
@@ -101,7 +100,7 @@ LFLAGS = /nologo /machine:$(MACHINE)
|
|||||||
SSLLIBS = libeay32.lib ssleay32.lib
|
SSLLIBS = libeay32.lib ssleay32.lib
|
||||||
ZLIBLIBSDLL= zdll.lib
|
ZLIBLIBSDLL= zdll.lib
|
||||||
ZLIBLIBS = zlib.lib
|
ZLIBLIBS = zlib.lib
|
||||||
WINLIBS = wsock32.lib wldap32.lib
|
WINLIBS = ws2_32.lib wldap32.lib
|
||||||
CFLAGS = $(CFLAGS)
|
CFLAGS = $(CFLAGS)
|
||||||
|
|
||||||
CFGSET = FALSE
|
CFGSET = FALSE
|
||||||
@@ -110,6 +109,10 @@ CFGSET = FALSE
|
|||||||
CFLAGS = $(CFLAGS) /DUSE_WINDOWS_SSPI /I$(WINDOWS_SDK_PATH)\include
|
CFLAGS = $(CFLAGS) /DUSE_WINDOWS_SSPI /I$(WINDOWS_SDK_PATH)\include
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
|
!IFDEF USE_IPV6
|
||||||
|
CFLAGS = $(CFLAGS) /DUSE_IPV6
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
##############################################################
|
##############################################################
|
||||||
# Runtime library configuration
|
# Runtime library configuration
|
||||||
|
|
||||||
@@ -450,46 +453,56 @@ X_OBJS= \
|
|||||||
$(DIROBJ)\content_encoding.obj \
|
$(DIROBJ)\content_encoding.obj \
|
||||||
$(DIROBJ)\cookie.obj \
|
$(DIROBJ)\cookie.obj \
|
||||||
$(DIROBJ)\curl_addrinfo.obj \
|
$(DIROBJ)\curl_addrinfo.obj \
|
||||||
|
$(DIROBJ)\curl_fnmatch.obj \
|
||||||
|
$(DIROBJ)\curl_gethostname.obj \
|
||||||
$(DIROBJ)\curl_memrchr.obj \
|
$(DIROBJ)\curl_memrchr.obj \
|
||||||
$(DIROBJ)\curl_rand.obj \
|
$(DIROBJ)\curl_rand.obj \
|
||||||
|
$(DIROBJ)\curl_rtmp.obj \
|
||||||
$(DIROBJ)\curl_sspi.obj \
|
$(DIROBJ)\curl_sspi.obj \
|
||||||
$(DIROBJ)\curl_threads.obj \
|
$(DIROBJ)\curl_threads.obj \
|
||||||
$(DIROBJ)\dict.obj \
|
$(DIROBJ)\dict.obj \
|
||||||
$(DIROBJ)\easy.obj \
|
$(DIROBJ)\easy.obj \
|
||||||
$(DIROBJ)\escape.obj \
|
$(DIROBJ)\escape.obj \
|
||||||
|
$(DIROBJ)\fileinfo.obj \
|
||||||
$(DIROBJ)\file.obj \
|
$(DIROBJ)\file.obj \
|
||||||
$(DIROBJ)\formdata.obj \
|
$(DIROBJ)\formdata.obj \
|
||||||
|
$(DIROBJ)\ftplistparser.obj \
|
||||||
$(DIROBJ)\ftp.obj \
|
$(DIROBJ)\ftp.obj \
|
||||||
$(DIROBJ)\getenv.obj \
|
$(DIROBJ)\getenv.obj \
|
||||||
$(DIROBJ)\getinfo.obj \
|
$(DIROBJ)\getinfo.obj \
|
||||||
$(DIROBJ)\gtls.obj \
|
$(DIROBJ)\gtls.obj \
|
||||||
|
$(DIROBJ)\gopher.obj \
|
||||||
$(DIROBJ)\hash.obj \
|
$(DIROBJ)\hash.obj \
|
||||||
|
$(DIROBJ)\hmac.obj \
|
||||||
$(DIROBJ)\hostares.obj \
|
$(DIROBJ)\hostares.obj \
|
||||||
$(DIROBJ)\hostasyn.obj \
|
$(DIROBJ)\hostasyn.obj \
|
||||||
$(DIROBJ)\hostip.obj \
|
|
||||||
$(DIROBJ)\hostip4.obj \
|
$(DIROBJ)\hostip4.obj \
|
||||||
$(DIROBJ)\hostip6.obj \
|
$(DIROBJ)\hostip6.obj \
|
||||||
|
$(DIROBJ)\hostip.obj \
|
||||||
$(DIROBJ)\hostsyn.obj \
|
$(DIROBJ)\hostsyn.obj \
|
||||||
$(DIROBJ)\hostthre.obj \
|
$(DIROBJ)\hostthre.obj \
|
||||||
$(DIROBJ)\http.obj \
|
|
||||||
$(DIROBJ)\http_chunks.obj \
|
$(DIROBJ)\http_chunks.obj \
|
||||||
$(DIROBJ)\http_digest.obj \
|
$(DIROBJ)\http_digest.obj \
|
||||||
$(DIROBJ)\http_negotiate.obj \
|
$(DIROBJ)\http_negotiate.obj \
|
||||||
$(DIROBJ)\http_ntlm.obj \
|
$(DIROBJ)\http_ntlm.obj \
|
||||||
|
$(DIROBJ)\http.obj \
|
||||||
$(DIROBJ)\if2ip.obj \
|
$(DIROBJ)\if2ip.obj \
|
||||||
$(DIROBJ)\imap.obj \
|
$(DIROBJ)\imap.obj \
|
||||||
$(DIROBJ)\inet_ntop.obj \
|
$(DIROBJ)\inet_ntop.obj \
|
||||||
$(DIROBJ)\inet_pton.obj \
|
$(DIROBJ)\inet_pton.obj \
|
||||||
$(DIROBJ)\ldap.obj \
|
$(DIROBJ)\ldap.obj \
|
||||||
$(DIROBJ)\llist.obj \
|
$(DIROBJ)\llist.obj \
|
||||||
|
$(DIROBJ)\md4.obj \
|
||||||
$(DIROBJ)\md5.obj \
|
$(DIROBJ)\md5.obj \
|
||||||
$(DIROBJ)\memdebug.obj \
|
$(DIROBJ)\memdebug.obj \
|
||||||
$(DIROBJ)\mprintf.obj \
|
$(DIROBJ)\mprintf.obj \
|
||||||
$(DIROBJ)\multi.obj \
|
$(DIROBJ)\multi.obj \
|
||||||
$(DIROBJ)\netrc.obj \
|
$(DIROBJ)\netrc.obj \
|
||||||
$(DIROBJ)\nonblock.obj \
|
$(DIROBJ)\nonblock.obj \
|
||||||
|
$(DIROBJ)\openldap.obj \
|
||||||
$(DIROBJ)\parsedate.obj \
|
$(DIROBJ)\parsedate.obj \
|
||||||
$(DIROBJ)\pingpong.obj \
|
$(DIROBJ)\pingpong.obj \
|
||||||
|
$(DIROBJ)\polarssl.obj \
|
||||||
$(DIROBJ)\pop3.obj \
|
$(DIROBJ)\pop3.obj \
|
||||||
$(DIROBJ)\progress.obj \
|
$(DIROBJ)\progress.obj \
|
||||||
$(DIROBJ)\rawstr.obj \
|
$(DIROBJ)\rawstr.obj \
|
||||||
@@ -499,8 +512,8 @@ X_OBJS= \
|
|||||||
$(DIROBJ)\share.obj \
|
$(DIROBJ)\share.obj \
|
||||||
$(DIROBJ)\slist.obj \
|
$(DIROBJ)\slist.obj \
|
||||||
$(DIROBJ)\smtp.obj \
|
$(DIROBJ)\smtp.obj \
|
||||||
$(DIROBJ)\socks.obj \
|
|
||||||
$(DIROBJ)\socks_gssapi.obj \
|
$(DIROBJ)\socks_gssapi.obj \
|
||||||
|
$(DIROBJ)\socks.obj \
|
||||||
$(DIROBJ)\socks_sspi.obj \
|
$(DIROBJ)\socks_sspi.obj \
|
||||||
$(DIROBJ)\speedcheck.obj \
|
$(DIROBJ)\speedcheck.obj \
|
||||||
$(DIROBJ)\splay.obj \
|
$(DIROBJ)\splay.obj \
|
||||||
@@ -518,6 +531,7 @@ X_OBJS= \
|
|||||||
$(DIROBJ)\url.obj \
|
$(DIROBJ)\url.obj \
|
||||||
$(DIROBJ)\version.obj \
|
$(DIROBJ)\version.obj \
|
||||||
$(DIROBJ)\warnless.obj \
|
$(DIROBJ)\warnless.obj \
|
||||||
|
$(DIROBJ)\wildcard.obj \
|
||||||
$(RESOURCE)
|
$(RESOURCE)
|
||||||
|
|
||||||
all : $(TARGET)
|
all : $(TARGET)
|
||||||
|
@@ -11,7 +11,7 @@ c-ares:
|
|||||||
http://c-ares.haxx.se/
|
http://c-ares.haxx.se/
|
||||||
|
|
||||||
NOTE
|
NOTE
|
||||||
The latest libcurl version requires c-ares 1.4.0 or later.
|
The latest libcurl version requires c-ares 1.6.0 or later.
|
||||||
|
|
||||||
Once upon the time libcurl built fine with the "original" ares. That is no
|
Once upon the time libcurl built fine with the "original" ares. That is no
|
||||||
longer true. You need to use c-ares.
|
longer true. You need to use c-ares.
|
||||||
|
@@ -48,10 +48,7 @@
|
|||||||
/* to enable hidden symbols */
|
/* to enable hidden symbols */
|
||||||
/*#define CURL_HIDDEN_SYMBOLS 1*/
|
/*#define CURL_HIDDEN_SYMBOLS 1*/
|
||||||
|
|
||||||
/* W$ LDAP with non-W$ compiler */
|
/* Use Windows LDAP implementation */
|
||||||
/* #undef CURL_LDAP_HYBRID */
|
|
||||||
|
|
||||||
/* Use W$ LDAP implementation */
|
|
||||||
/* #undef CURL_LDAP_WIN */
|
/* #undef CURL_LDAP_WIN */
|
||||||
|
|
||||||
/* when not building a shared library */
|
/* when not building a shared library */
|
||||||
|
@@ -59,10 +59,7 @@
|
|||||||
/* to enable hidden symbols */
|
/* to enable hidden symbols */
|
||||||
/* #undef CURL_HIDDEN_SYMBOLS */
|
/* #undef CURL_HIDDEN_SYMBOLS */
|
||||||
|
|
||||||
/* W$ LDAP with non-W$ compiler */
|
/* Use Windows LDAP implementation */
|
||||||
/* #undef CURL_LDAP_HYBRID */
|
|
||||||
|
|
||||||
/* Use W$ LDAP implementation */
|
|
||||||
/* #undef CURL_LDAP_WIN */
|
/* #undef CURL_LDAP_WIN */
|
||||||
|
|
||||||
/* when not building a shared library */
|
/* when not building a shared library */
|
||||||
|
@@ -504,6 +504,10 @@
|
|||||||
# define USE_WIN32_LARGE_FILES
|
# define USE_WIN32_LARGE_FILES
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(__WATCOMC__) && !defined(USE_WIN32_LARGE_FILES)
|
||||||
|
# define USE_WIN32_LARGE_FILES
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(__POCC__)
|
#if defined(__POCC__)
|
||||||
# undef USE_WIN32_LARGE_FILES
|
# undef USE_WIN32_LARGE_FILES
|
||||||
#endif
|
#endif
|
||||||
@@ -535,20 +539,24 @@
|
|||||||
/* ---------------------------------------------------------------- */
|
/* ---------------------------------------------------------------- */
|
||||||
|
|
||||||
#if defined(CURL_HAS_NOVELL_LDAPSDK) || defined(CURL_HAS_MOZILLA_LDAPSDK)
|
#if defined(CURL_HAS_NOVELL_LDAPSDK) || defined(CURL_HAS_MOZILLA_LDAPSDK)
|
||||||
#undef CURL_LDAP_HYBRID
|
|
||||||
#undef CURL_LDAP_WIN
|
#undef CURL_LDAP_WIN
|
||||||
#define HAVE_LDAP_SSL_H 1
|
#define HAVE_LDAP_SSL_H 1
|
||||||
#define HAVE_LDAP_URL_PARSE 1
|
#define HAVE_LDAP_URL_PARSE 1
|
||||||
#elif defined(CURL_HAS_OPENLDAP_LDAPSDK)
|
#elif defined(CURL_HAS_OPENLDAP_LDAPSDK)
|
||||||
#undef CURL_LDAP_HYBRID
|
|
||||||
#undef CURL_LDAP_WIN
|
#undef CURL_LDAP_WIN
|
||||||
#define HAVE_LDAP_URL_PARSE 1
|
#define HAVE_LDAP_URL_PARSE 1
|
||||||
#else
|
#else
|
||||||
#undef CURL_LDAP_HYBRID
|
|
||||||
#undef HAVE_LDAP_URL_PARSE
|
#undef HAVE_LDAP_URL_PARSE
|
||||||
#define CURL_LDAP_WIN 1
|
#define CURL_LDAP_WIN 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(__WATCOMC__) && defined(CURL_LDAP_WIN)
|
||||||
|
#if __WATCOMC__ < 1280
|
||||||
|
#define WINBERAPI __declspec(cdecl)
|
||||||
|
#define WINLDAPAPI __declspec(cdecl)
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(__POCC__) && defined(CURL_LDAP_WIN)
|
#if defined(__POCC__) && defined(CURL_LDAP_WIN)
|
||||||
# define CURL_DISABLE_LDAP 1
|
# define CURL_DISABLE_LDAP 1
|
||||||
#endif
|
#endif
|
||||||
@@ -572,7 +580,7 @@
|
|||||||
/* Name of package */
|
/* Name of package */
|
||||||
#define PACKAGE "curl"
|
#define PACKAGE "curl"
|
||||||
|
|
||||||
#if defined(__POCC__)
|
#if defined(__POCC__) || (USE_IPV6)
|
||||||
# define ENABLE_IPV6 1
|
# define ENABLE_IPV6 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -379,7 +379,6 @@
|
|||||||
/* ---------------------------------------------------------------- */
|
/* ---------------------------------------------------------------- */
|
||||||
|
|
||||||
#define CURL_LDAP_WIN 1
|
#define CURL_LDAP_WIN 1
|
||||||
#undef CURL_LDAP_HYBRID
|
|
||||||
#undef HAVE_LDAP_URL_PARSE
|
#undef HAVE_LDAP_URL_PARSE
|
||||||
|
|
||||||
/* ---------------------------------------------------------------- */
|
/* ---------------------------------------------------------------- */
|
||||||
|
231
lib/connect.c
231
lib/connect.c
@@ -112,10 +112,11 @@ struct Curl_sockaddr_ex {
|
|||||||
|
|
||||||
static bool verifyconnect(curl_socket_t sockfd, int *error);
|
static bool verifyconnect(curl_socket_t sockfd, int *error);
|
||||||
|
|
||||||
static curl_socket_t
|
static CURLcode
|
||||||
singleipconnect(struct connectdata *conn,
|
singleipconnect(struct connectdata *conn,
|
||||||
const Curl_addrinfo *ai, /* start connecting to this */
|
const Curl_addrinfo *ai, /* start connecting to this */
|
||||||
long timeout_ms,
|
long timeout_ms,
|
||||||
|
curl_socket_t *sock,
|
||||||
bool *connected);
|
bool *connected);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -173,6 +174,9 @@ long Curl_timeleft(struct connectdata *conn,
|
|||||||
|
|
||||||
/* substract elapsed time */
|
/* substract elapsed time */
|
||||||
timeout_ms -= Curl_tvdiff(*nowp, data->progress.t_startsingle);
|
timeout_ms -= Curl_tvdiff(*nowp, data->progress.t_startsingle);
|
||||||
|
if(!timeout_ms)
|
||||||
|
/* avoid returning 0 as that means no timeout! */
|
||||||
|
return -1;
|
||||||
|
|
||||||
return timeout_ms;
|
return timeout_ms;
|
||||||
}
|
}
|
||||||
@@ -180,16 +184,13 @@ long Curl_timeleft(struct connectdata *conn,
|
|||||||
/*
|
/*
|
||||||
* waitconnect() waits for a TCP connect on the given socket for the specified
|
* waitconnect() waits for a TCP connect on the given socket for the specified
|
||||||
* number if milliseconds. It returns:
|
* number if milliseconds. It returns:
|
||||||
* 0 fine connect
|
|
||||||
* -1 select() error
|
|
||||||
* 1 select() timeout
|
|
||||||
* 2 select() returned with an error condition fd_set
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define WAITCONN_CONNECTED 0
|
#define WAITCONN_CONNECTED 0
|
||||||
#define WAITCONN_SELECT_ERROR -1
|
#define WAITCONN_SELECT_ERROR -1
|
||||||
#define WAITCONN_TIMEOUT 1
|
#define WAITCONN_TIMEOUT 1
|
||||||
#define WAITCONN_FDSET_ERROR 2
|
#define WAITCONN_FDSET_ERROR 2
|
||||||
|
#define WAITCONN_ABORTED 3
|
||||||
|
|
||||||
static
|
static
|
||||||
int waitconnect(struct connectdata *conn,
|
int waitconnect(struct connectdata *conn,
|
||||||
@@ -209,9 +210,8 @@ int waitconnect(struct connectdata *conn,
|
|||||||
/* now select() until we get connect or timeout */
|
/* now select() until we get connect or timeout */
|
||||||
rc = Curl_socket_ready(CURL_SOCKET_BAD, sockfd, (int)(timeout_msec>1000?
|
rc = Curl_socket_ready(CURL_SOCKET_BAD, sockfd, (int)(timeout_msec>1000?
|
||||||
1000:timeout_msec));
|
1000:timeout_msec));
|
||||||
|
|
||||||
if(Curl_pgrsUpdate(conn))
|
if(Curl_pgrsUpdate(conn))
|
||||||
return CURLE_ABORTED_BY_CALLBACK;
|
return WAITCONN_ABORTED;
|
||||||
|
|
||||||
if(-1 == rc)
|
if(-1 == rc)
|
||||||
/* error, no connect here, try next */
|
/* error, no connect here, try next */
|
||||||
@@ -492,37 +492,130 @@ static bool verifyconnect(curl_socket_t sockfd, int *error)
|
|||||||
|
|
||||||
/* Used within the multi interface. Try next IP address, return TRUE if no
|
/* Used within the multi interface. Try next IP address, return TRUE if no
|
||||||
more address exists or error */
|
more address exists or error */
|
||||||
static bool trynextip(struct connectdata *conn,
|
static CURLcode trynextip(struct connectdata *conn,
|
||||||
int sockindex,
|
int sockindex,
|
||||||
bool *connected)
|
bool *connected)
|
||||||
{
|
{
|
||||||
curl_socket_t sockfd;
|
curl_socket_t sockfd;
|
||||||
Curl_addrinfo *ai;
|
Curl_addrinfo *ai;
|
||||||
|
|
||||||
/* first close the failed socket */
|
/* First clean up after the failed socket.
|
||||||
sclose(conn->sock[sockindex]);
|
Don't close it yet to ensure that the next IP's socket gets a different
|
||||||
|
file descriptor, which can prevent bugs when the curl_multi_socket_action
|
||||||
|
interface is used with certain select() replacements such as kqueue. */
|
||||||
|
curl_socket_t fd_to_close = conn->sock[sockindex];
|
||||||
conn->sock[sockindex] = CURL_SOCKET_BAD;
|
conn->sock[sockindex] = CURL_SOCKET_BAD;
|
||||||
*connected = FALSE;
|
*connected = FALSE;
|
||||||
|
|
||||||
if(sockindex != FIRSTSOCKET)
|
if(sockindex != FIRSTSOCKET) {
|
||||||
return TRUE; /* no next */
|
sclose(fd_to_close);
|
||||||
|
return CURLE_COULDNT_CONNECT; /* no next */
|
||||||
|
}
|
||||||
|
|
||||||
/* try the next address */
|
/* try the next address */
|
||||||
ai = conn->ip_addr->ai_next;
|
ai = conn->ip_addr->ai_next;
|
||||||
|
|
||||||
while(ai) {
|
while(ai) {
|
||||||
sockfd = singleipconnect(conn, ai, 0L, connected);
|
CURLcode res = singleipconnect(conn, ai, 0L, &sockfd, connected);
|
||||||
|
if(res)
|
||||||
|
return res;
|
||||||
if(sockfd != CURL_SOCKET_BAD) {
|
if(sockfd != CURL_SOCKET_BAD) {
|
||||||
/* store the new socket descriptor */
|
/* store the new socket descriptor */
|
||||||
conn->sock[sockindex] = sockfd;
|
conn->sock[sockindex] = sockfd;
|
||||||
conn->ip_addr = ai;
|
conn->ip_addr = ai;
|
||||||
return FALSE;
|
sclose(fd_to_close);
|
||||||
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
ai = ai->ai_next;
|
ai = ai->ai_next;
|
||||||
}
|
}
|
||||||
|
sclose(fd_to_close);
|
||||||
|
return CURLE_COULDNT_CONNECT;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* retrieves ip address and port from a sockaddr structure */
|
||||||
|
static bool getaddressinfo(struct sockaddr* sa, char* addr,
|
||||||
|
long* port)
|
||||||
|
{
|
||||||
|
unsigned short us_port;
|
||||||
|
struct sockaddr_in* si = NULL;
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
struct sockaddr_in6* si6 = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
switch (sa->sa_family) {
|
||||||
|
case AF_INET:
|
||||||
|
si = (struct sockaddr_in*) sa;
|
||||||
|
if(Curl_inet_ntop(sa->sa_family, &si->sin_addr,
|
||||||
|
addr, MAX_IPADR_LEN) == NULL)
|
||||||
|
return FALSE;
|
||||||
|
us_port = ntohs(si->sin_port);
|
||||||
|
*port = us_port;
|
||||||
|
break;
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
case AF_INET6:
|
||||||
|
si6 = (struct sockaddr_in6*)sa;
|
||||||
|
if(Curl_inet_ntop(sa->sa_family, &si6->sin6_addr,
|
||||||
|
addr, MAX_IPADR_LEN) == NULL)
|
||||||
|
return FALSE;
|
||||||
|
us_port = ntohs(si6->sin6_port);
|
||||||
|
*port = us_port;
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
addr[0] = '\0';
|
||||||
|
*port = 0;
|
||||||
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* retrieves the start/end point information of a socket of an established
|
||||||
|
connection */
|
||||||
|
void Curl_updateconninfo(struct connectdata *conn, curl_socket_t sockfd)
|
||||||
|
{
|
||||||
|
int error;
|
||||||
|
curl_socklen_t len;
|
||||||
|
struct Curl_sockaddr_storage ssrem;
|
||||||
|
struct Curl_sockaddr_storage ssloc;
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
struct PureInfo *info = &conn->data->info;
|
||||||
|
|
||||||
|
if(conn->bits.reuse)
|
||||||
|
/* reusing same connection */
|
||||||
|
return;
|
||||||
|
|
||||||
|
len = sizeof(struct Curl_sockaddr_storage);
|
||||||
|
if(getpeername(sockfd, (struct sockaddr*) &ssrem, &len)) {
|
||||||
|
error = SOCKERRNO;
|
||||||
|
failf(data, "getpeername() failed with errno %d: %s",
|
||||||
|
error, Curl_strerror(conn, error));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = sizeof(struct Curl_sockaddr_storage);
|
||||||
|
if(getsockname(sockfd, (struct sockaddr*) &ssloc, &len)) {
|
||||||
|
error = SOCKERRNO;
|
||||||
|
failf(data, "getsockname() failed with errno %d: %s",
|
||||||
|
error, Curl_strerror(conn, error));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!getaddressinfo((struct sockaddr*)&ssrem,
|
||||||
|
info->ip, &info->port)) {
|
||||||
|
error = ERRNO;
|
||||||
|
failf(data, "ssrem inet_ntop() failed with errno %d: %s",
|
||||||
|
error, Curl_strerror(conn, error));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!getaddressinfo((struct sockaddr*)&ssloc,
|
||||||
|
info->localip, &info->localport)) {
|
||||||
|
error = ERRNO;
|
||||||
|
failf(data, "ssloc inet_ntop() failed with errno %d: %s",
|
||||||
|
error, Curl_strerror(conn, error));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Curl_is_connected() is used from the multi interface to check if the
|
* Curl_is_connected() is used from the multi interface to check if the
|
||||||
* firstsocket has connected.
|
* firstsocket has connected.
|
||||||
@@ -537,6 +630,7 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
CURLcode code = CURLE_OK;
|
CURLcode code = CURLE_OK;
|
||||||
curl_socket_t sockfd = conn->sock[sockindex];
|
curl_socket_t sockfd = conn->sock[sockindex];
|
||||||
long allow = DEFAULT_CONNECT_TIMEOUT;
|
long allow = DEFAULT_CONNECT_TIMEOUT;
|
||||||
|
int error = 0;
|
||||||
|
|
||||||
DEBUGASSERT(sockindex >= FIRSTSOCKET && sockindex <= SECONDARYSOCKET);
|
DEBUGASSERT(sockindex >= FIRSTSOCKET && sockindex <= SECONDARYSOCKET);
|
||||||
|
|
||||||
@@ -544,13 +638,6 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
|
|
||||||
if(conn->bits.tcpconnect) {
|
if(conn->bits.tcpconnect) {
|
||||||
/* we are connected already! */
|
/* we are connected already! */
|
||||||
long allow_total = 0;
|
|
||||||
|
|
||||||
/* subtract the most strict timeout of the ones */
|
|
||||||
if(data->set.timeout)
|
|
||||||
allow_total = data->set.timeout;
|
|
||||||
|
|
||||||
Curl_expire(data, allow_total);
|
|
||||||
*connected = TRUE;
|
*connected = TRUE;
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
@@ -564,52 +651,52 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
return CURLE_OPERATION_TIMEDOUT;
|
return CURLE_OPERATION_TIMEDOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
Curl_expire(data, allow);
|
|
||||||
|
|
||||||
/* check for connect without timeout as we want to return immediately */
|
/* check for connect without timeout as we want to return immediately */
|
||||||
rc = waitconnect(conn, sockfd, 0);
|
rc = waitconnect(conn, sockfd, 0);
|
||||||
|
if(WAITCONN_TIMEOUT == rc)
|
||||||
|
/* not an error, but also no connection yet */
|
||||||
|
return code;
|
||||||
|
|
||||||
if(WAITCONN_CONNECTED == rc) {
|
if(WAITCONN_CONNECTED == rc) {
|
||||||
int error;
|
|
||||||
if(verifyconnect(sockfd, &error)) {
|
if(verifyconnect(sockfd, &error)) {
|
||||||
/* we are connected, awesome! */
|
/* we are connected, awesome! */
|
||||||
conn->bits.tcpconnect = TRUE;
|
conn->bits.tcpconnect = TRUE;
|
||||||
*connected = TRUE;
|
*connected = TRUE;
|
||||||
|
Curl_pgrsTime(data, TIMER_CONNECT); /* connect done */
|
||||||
|
Curl_verboseconnect(conn);
|
||||||
|
Curl_updateconninfo(conn, sockfd);
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
/* nope, not connected for real */
|
/* nope, not connected for real */
|
||||||
data->state.os_errno = error;
|
|
||||||
infof(data, "Connection failed\n");
|
|
||||||
if(trynextip(conn, sockindex, connected)) {
|
|
||||||
failf(data, "Failed connect to %s:%ld; %s",
|
|
||||||
conn->host.name, conn->port, Curl_strerror(conn, error));
|
|
||||||
code = CURLE_COULDNT_CONNECT;
|
|
||||||
}
|
}
|
||||||
}
|
else {
|
||||||
else if(WAITCONN_TIMEOUT != rc) {
|
|
||||||
int error = 0;
|
|
||||||
|
|
||||||
/* nope, not connected */
|
/* nope, not connected */
|
||||||
if(WAITCONN_FDSET_ERROR == rc) {
|
if(WAITCONN_FDSET_ERROR == rc) {
|
||||||
(void)verifyconnect(sockfd, &error);
|
(void)verifyconnect(sockfd, &error);
|
||||||
data->state.os_errno = error;
|
|
||||||
infof(data, "%s\n",Curl_strerror(conn, error));
|
infof(data, "%s\n",Curl_strerror(conn, error));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
infof(data, "Connection failed\n");
|
infof(data, "Connection failed\n");
|
||||||
|
}
|
||||||
|
|
||||||
if(trynextip(conn, sockindex, connected)) {
|
/*
|
||||||
|
* The connection failed here, we should attempt to connect to the "next
|
||||||
|
* address" for the given host. But first remember the latest error.
|
||||||
|
*/
|
||||||
|
if(error) {
|
||||||
|
data->state.os_errno = error;
|
||||||
|
SET_SOCKERRNO(error);
|
||||||
|
}
|
||||||
|
|
||||||
|
code = trynextip(conn, sockindex, connected);
|
||||||
|
|
||||||
|
if(code) {
|
||||||
error = SOCKERRNO;
|
error = SOCKERRNO;
|
||||||
data->state.os_errno = error;
|
data->state.os_errno = error;
|
||||||
failf(data, "Failed connect to %s:%ld; %s",
|
failf(data, "Failed connect to %s:%ld; %s",
|
||||||
conn->host.name, conn->port, Curl_strerror(conn, error));
|
conn->host.name, conn->port, Curl_strerror(conn, error));
|
||||||
code = CURLE_COULDNT_CONNECT;
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
/*
|
|
||||||
* If the connection failed here, we should attempt to connect to the "next
|
|
||||||
* address" for the given host.
|
|
||||||
*/
|
|
||||||
|
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
@@ -691,12 +778,20 @@ void Curl_sndbufset(curl_socket_t sockfd)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* singleipconnect() connects to the given IP only, and it may return without
|
/*
|
||||||
having connected if used from the multi interface. */
|
* singleipconnect()
|
||||||
static curl_socket_t
|
*
|
||||||
|
* Note that even on connect fail it returns CURLE_OK, but with 'sock' set to
|
||||||
|
* CURL_SOCKET_BAD. Other errors will however return proper errors.
|
||||||
|
*
|
||||||
|
* singleipconnect() connects to the given IP only, and it may return without
|
||||||
|
* having connected if used from the multi interface.
|
||||||
|
*/
|
||||||
|
static CURLcode
|
||||||
singleipconnect(struct connectdata *conn,
|
singleipconnect(struct connectdata *conn,
|
||||||
const Curl_addrinfo *ai,
|
const Curl_addrinfo *ai,
|
||||||
long timeout_ms,
|
long timeout_ms,
|
||||||
|
curl_socket_t *sockp,
|
||||||
bool *connected)
|
bool *connected)
|
||||||
{
|
{
|
||||||
struct Curl_sockaddr_ex addr;
|
struct Curl_sockaddr_ex addr;
|
||||||
@@ -706,13 +801,15 @@ singleipconnect(struct connectdata *conn,
|
|||||||
bool isconnected;
|
bool isconnected;
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
curl_socket_t sockfd;
|
curl_socket_t sockfd;
|
||||||
CURLcode res;
|
CURLcode res = CURLE_OK;
|
||||||
const void *iptoprint;
|
const void *iptoprint;
|
||||||
struct sockaddr_in * const sa4 = (void *)&addr.sa_addr;
|
struct sockaddr_in * const sa4 = (void *)&addr.sa_addr;
|
||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
struct sockaddr_in6 * const sa6 = (void *)&addr.sa_addr;
|
struct sockaddr_in6 * const sa6 = (void *)&addr.sa_addr;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
*sockp = CURL_SOCKET_BAD;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The Curl_sockaddr_ex structure is basically libcurl's external API
|
* The Curl_sockaddr_ex structure is basically libcurl's external API
|
||||||
* curl_sockaddr structure with enough space available to directly hold
|
* curl_sockaddr structure with enough space available to directly hold
|
||||||
@@ -751,7 +848,7 @@ singleipconnect(struct connectdata *conn,
|
|||||||
|
|
||||||
if(sockfd == CURL_SOCKET_BAD)
|
if(sockfd == CURL_SOCKET_BAD)
|
||||||
/* no socket, no connection */
|
/* no socket, no connection */
|
||||||
return CURL_SOCKET_BAD;
|
return CURLE_OK;
|
||||||
|
|
||||||
#if defined(ENABLE_IPV6) && defined(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID)
|
#if defined(ENABLE_IPV6) && defined(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID)
|
||||||
if (conn->scope && (addr.family == AF_INET6))
|
if (conn->scope && (addr.family == AF_INET6))
|
||||||
@@ -804,7 +901,7 @@ singleipconnect(struct connectdata *conn,
|
|||||||
CURLSOCKTYPE_IPCXN);
|
CURLSOCKTYPE_IPCXN);
|
||||||
if(error) {
|
if(error) {
|
||||||
sclose(sockfd); /* close the socket and bail out */
|
sclose(sockfd); /* close the socket and bail out */
|
||||||
return CURL_SOCKET_BAD;
|
return res;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -812,7 +909,7 @@ singleipconnect(struct connectdata *conn,
|
|||||||
res = bindlocal(conn, sockfd, addr.family);
|
res = bindlocal(conn, sockfd, addr.family);
|
||||||
if(res) {
|
if(res) {
|
||||||
sclose(sockfd); /* close socket and bail out */
|
sclose(sockfd); /* close socket and bail out */
|
||||||
return CURL_SOCKET_BAD;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* set socket non-blocking */
|
/* set socket non-blocking */
|
||||||
@@ -840,6 +937,10 @@ singleipconnect(struct connectdata *conn,
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
rc = waitconnect(conn, sockfd, timeout_ms);
|
rc = waitconnect(conn, sockfd, timeout_ms);
|
||||||
|
if(WAITCONN_ABORTED == rc) {
|
||||||
|
sclose(sockfd);
|
||||||
|
return CURLE_ABORTED_BY_CALLBACK;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* unknown error, fallthrough and try another address! */
|
/* unknown error, fallthrough and try another address! */
|
||||||
@@ -855,7 +956,8 @@ singleipconnect(struct connectdata *conn,
|
|||||||
if((WAITCONN_TIMEOUT == rc) &&
|
if((WAITCONN_TIMEOUT == rc) &&
|
||||||
(data->state.used_interface == Curl_if_multi)) {
|
(data->state.used_interface == Curl_if_multi)) {
|
||||||
/* Timeout when running the multi interface */
|
/* Timeout when running the multi interface */
|
||||||
return sockfd;
|
*sockp = sockfd;
|
||||||
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
isconnected = verifyconnect(sockfd, &error);
|
isconnected = verifyconnect(sockfd, &error);
|
||||||
@@ -864,7 +966,9 @@ singleipconnect(struct connectdata *conn,
|
|||||||
/* we are connected, awesome! */
|
/* we are connected, awesome! */
|
||||||
*connected = TRUE; /* this is a true connect */
|
*connected = TRUE; /* this is a true connect */
|
||||||
infof(data, "connected\n");
|
infof(data, "connected\n");
|
||||||
return sockfd;
|
Curl_updateconninfo(conn, sockfd);
|
||||||
|
*sockp = sockfd;
|
||||||
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
else if(WAITCONN_TIMEOUT == rc)
|
else if(WAITCONN_TIMEOUT == rc)
|
||||||
infof(data, "Timeout\n");
|
infof(data, "Timeout\n");
|
||||||
@@ -876,7 +980,7 @@ singleipconnect(struct connectdata *conn,
|
|||||||
/* connect failed or timed out */
|
/* connect failed or timed out */
|
||||||
sclose(sockfd);
|
sclose(sockfd);
|
||||||
|
|
||||||
return CURL_SOCKET_BAD;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -918,7 +1022,6 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
failf(data, "Connection time-out");
|
failf(data, "Connection time-out");
|
||||||
return CURLE_OPERATION_TIMEDOUT;
|
return CURLE_OPERATION_TIMEDOUT;
|
||||||
}
|
}
|
||||||
Curl_expire(data, timeout_ms);
|
|
||||||
|
|
||||||
/* Max time for each address */
|
/* Max time for each address */
|
||||||
num_addr = Curl_num_addresses(remotehost->addr);
|
num_addr = Curl_num_addresses(remotehost->addr);
|
||||||
@@ -941,7 +1044,11 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
curr_addr = curr_addr->ai_next, aliasindex++) {
|
curr_addr = curr_addr->ai_next, aliasindex++) {
|
||||||
|
|
||||||
/* start connecting to the IP curr_addr points to */
|
/* start connecting to the IP curr_addr points to */
|
||||||
sockfd = singleipconnect(conn, curr_addr, timeout_per_addr, connected);
|
CURLcode res =
|
||||||
|
singleipconnect(conn, curr_addr, timeout_per_addr, &sockfd, connected);
|
||||||
|
|
||||||
|
if(res)
|
||||||
|
return res;
|
||||||
|
|
||||||
if(sockfd != CURL_SOCKET_BAD)
|
if(sockfd != CURL_SOCKET_BAD)
|
||||||
break;
|
break;
|
||||||
@@ -979,12 +1086,12 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
* Used to extract socket and connectdata struct for the most recent
|
* Used to extract socket and connectdata struct for the most recent
|
||||||
* transfer on the given SessionHandle.
|
* transfer on the given SessionHandle.
|
||||||
*
|
*
|
||||||
* The socket 'long' will be -1 in case of failure!
|
* The returned socket will be CURL_SOCKET_BAD in case of failure!
|
||||||
*/
|
*/
|
||||||
CURLcode Curl_getconnectinfo(struct SessionHandle *data,
|
curl_socket_t Curl_getconnectinfo(struct SessionHandle *data,
|
||||||
long *param_longp,
|
|
||||||
struct connectdata **connp)
|
struct connectdata **connp)
|
||||||
{
|
{
|
||||||
|
curl_socket_t sockfd;
|
||||||
if((data->state.lastconnect != -1) &&
|
if((data->state.lastconnect != -1) &&
|
||||||
(data->state.connc->connects[data->state.lastconnect] != NULL)) {
|
(data->state.connc->connects[data->state.lastconnect] != NULL)) {
|
||||||
struct connectdata *c =
|
struct connectdata *c =
|
||||||
@@ -992,13 +1099,13 @@ CURLcode Curl_getconnectinfo(struct SessionHandle *data,
|
|||||||
if(connp)
|
if(connp)
|
||||||
/* only store this if the caller cares for it */
|
/* only store this if the caller cares for it */
|
||||||
*connp = c;
|
*connp = c;
|
||||||
*param_longp = c->sock[FIRSTSOCKET];
|
sockfd = c->sock[FIRSTSOCKET];
|
||||||
/* we have a socket connected, let's determine if the server shut down */
|
/* we have a socket connected, let's determine if the server shut down */
|
||||||
/* determine if ssl */
|
/* determine if ssl */
|
||||||
if(c->ssl[FIRSTSOCKET].use) {
|
if(c->ssl[FIRSTSOCKET].use) {
|
||||||
/* use the SSL context */
|
/* use the SSL context */
|
||||||
if(!Curl_ssl_check_cxn(c))
|
if(!Curl_ssl_check_cxn(c))
|
||||||
*param_longp = -1; /* FIN received */
|
return CURL_SOCKET_BAD; /* FIN received */
|
||||||
}
|
}
|
||||||
/* Minix 3.1 doesn't support any flags on recv; just assume socket is OK */
|
/* Minix 3.1 doesn't support any flags on recv; just assume socket is OK */
|
||||||
#ifdef MSG_PEEK
|
#ifdef MSG_PEEK
|
||||||
@@ -1007,13 +1114,13 @@ CURLcode Curl_getconnectinfo(struct SessionHandle *data,
|
|||||||
char buf;
|
char buf;
|
||||||
if(recv((RECV_TYPE_ARG1)c->sock[FIRSTSOCKET], (RECV_TYPE_ARG2)&buf,
|
if(recv((RECV_TYPE_ARG1)c->sock[FIRSTSOCKET], (RECV_TYPE_ARG2)&buf,
|
||||||
(RECV_TYPE_ARG3)1, (RECV_TYPE_ARG4)MSG_PEEK) == 0) {
|
(RECV_TYPE_ARG3)1, (RECV_TYPE_ARG4)MSG_PEEK) == 0) {
|
||||||
*param_longp = -1; /* FIN received */
|
return CURL_SOCKET_BAD; /* FIN received */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
*param_longp = -1;
|
return CURL_SOCKET_BAD;
|
||||||
|
|
||||||
return CURLE_OK;
|
return sockfd;
|
||||||
}
|
}
|
||||||
|
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -47,10 +47,9 @@ long Curl_timeleft(struct connectdata *conn,
|
|||||||
* Used to extract socket and connectdata struct for the most recent
|
* Used to extract socket and connectdata struct for the most recent
|
||||||
* transfer on the given SessionHandle.
|
* transfer on the given SessionHandle.
|
||||||
*
|
*
|
||||||
* The socket 'long' will be -1 in case of failure!
|
* The returned socket will be CURL_SOCKET_BAD in case of failure!
|
||||||
*/
|
*/
|
||||||
CURLcode Curl_getconnectinfo(struct SessionHandle *data,
|
curl_socket_t Curl_getconnectinfo(struct SessionHandle *data,
|
||||||
long *param_longp,
|
|
||||||
struct connectdata **connp);
|
struct connectdata **connp);
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
@@ -68,4 +67,6 @@ void Curl_sndbufset(curl_socket_t sockfd);
|
|||||||
#define Curl_sndbufset(y)
|
#define Curl_sndbufset(y)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void Curl_updateconninfo(struct connectdata *conn, curl_socket_t sockfd);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -103,7 +103,7 @@ inflate_stream(struct connectdata *conn,
|
|||||||
status = inflate(z, Z_SYNC_FLUSH);
|
status = inflate(z, Z_SYNC_FLUSH);
|
||||||
if(status == Z_OK || status == Z_STREAM_END) {
|
if(status == Z_OK || status == Z_STREAM_END) {
|
||||||
allow_restart = 0;
|
allow_restart = 0;
|
||||||
if(DSIZ - z->avail_out) {
|
if((DSIZ - z->avail_out) && (!k->ignorebody)) {
|
||||||
result = Curl_client_write(conn, CLIENTWRITE_BODY, decomp,
|
result = Curl_client_write(conn, CLIENTWRITE_BODY, decomp,
|
||||||
DSIZ - z->avail_out);
|
DSIZ - z->avail_out);
|
||||||
/* if !CURLE_OK, clean up, return */
|
/* if !CURLE_OK, clean up, return */
|
||||||
@@ -123,7 +123,9 @@ inflate_stream(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Done with these bytes, exit */
|
/* Done with these bytes, exit */
|
||||||
if(status == Z_OK && z->avail_in == 0) {
|
|
||||||
|
/* status is always Z_OK at this point! */
|
||||||
|
if(z->avail_in == 0) {
|
||||||
free(decomp);
|
free(decomp);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -247,7 +249,6 @@ static enum {
|
|||||||
|
|
||||||
/* Skip over the NUL */
|
/* Skip over the NUL */
|
||||||
--len;
|
--len;
|
||||||
++data;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(flags & HEAD_CRC) {
|
if(flags & HEAD_CRC) {
|
||||||
@@ -255,7 +256,6 @@ static enum {
|
|||||||
return GZIP_UNDERFLOW;
|
return GZIP_UNDERFLOW;
|
||||||
|
|
||||||
len -= 2;
|
len -= 2;
|
||||||
data += 2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
*headerlen = totallen - len;
|
*headerlen = totallen - len;
|
||||||
|
@@ -151,7 +151,10 @@ Curl_getaddrinfo_ex(const char *nodename,
|
|||||||
ca->ai_next = NULL;
|
ca->ai_next = NULL;
|
||||||
|
|
||||||
if((ai->ai_addrlen > 0) && (ai->ai_addr != NULL)) {
|
if((ai->ai_addrlen > 0) && (ai->ai_addr != NULL)) {
|
||||||
ca->ai_addrlen = ai->ai_addrlen;
|
/* typecast below avoid warning on at least win64:
|
||||||
|
conversion from 'size_t' to 'curl_socklen_t', possible loss of data
|
||||||
|
*/
|
||||||
|
ca->ai_addrlen = (curl_socklen_t)ai->ai_addrlen;
|
||||||
if((ca->ai_addr = malloc(ca->ai_addrlen)) == NULL) {
|
if((ca->ai_addr = malloc(ca->ai_addrlen)) == NULL) {
|
||||||
error = EAI_MEMORY;
|
error = EAI_MEMORY;
|
||||||
free(ca);
|
free(ca);
|
||||||
|
@@ -58,10 +58,7 @@
|
|||||||
/* to enable hidden symbols */
|
/* to enable hidden symbols */
|
||||||
#cmakedefine CURL_HIDDEN_SYMBOLS ${CURL_HIDDEN_SYMBOLS}
|
#cmakedefine CURL_HIDDEN_SYMBOLS ${CURL_HIDDEN_SYMBOLS}
|
||||||
|
|
||||||
/* W$ LDAP with non-W$ compiler */
|
/* Use Windows LDAP implementation */
|
||||||
#cmakedefine CURL_LDAP_HYBRID ${CURL_LDAP_HYBRID}
|
|
||||||
|
|
||||||
/* Use W$ LDAP implementation */
|
|
||||||
#cmakedefine CURL_LDAP_WIN ${CURL_LDAP_WIN}
|
#cmakedefine CURL_LDAP_WIN ${CURL_LDAP_WIN}
|
||||||
|
|
||||||
/* when not building a shared library */
|
/* when not building a shared library */
|
||||||
@@ -889,6 +886,9 @@
|
|||||||
/* if GnuTLS is enabled */
|
/* if GnuTLS is enabled */
|
||||||
#cmakedefine USE_GNUTLS ${USE_GNUTLS}
|
#cmakedefine USE_GNUTLS ${USE_GNUTLS}
|
||||||
|
|
||||||
|
/* if PolarSSL is enabled */
|
||||||
|
#cmakedefine USE_POLARSSL ${USE_POLARSSL}
|
||||||
|
|
||||||
/* if libSSH2 is in use */
|
/* if libSSH2 is in use */
|
||||||
#cmakedefine USE_LIBSSH2 ${USE_LIBSSH2}
|
#cmakedefine USE_LIBSSH2 ${USE_LIBSSH2}
|
||||||
|
|
||||||
|
424
lib/curl_fnmatch.c
Normal file
424
lib/curl_fnmatch.c
Normal file
@@ -0,0 +1,424 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
|
#include "curl_fnmatch.h"
|
||||||
|
|
||||||
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
|
#include "curl_memory.h"
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#include "memdebug.h"
|
||||||
|
|
||||||
|
#define CURLFNM_CHARSET_LEN (sizeof(char) * 256)
|
||||||
|
#define CURLFNM_CHSET_SIZE (CURLFNM_CHARSET_LEN + 15)
|
||||||
|
|
||||||
|
#define CURLFNM_NEGATE CURLFNM_CHARSET_LEN
|
||||||
|
|
||||||
|
#define CURLFNM_ALNUM (CURLFNM_CHARSET_LEN + 1)
|
||||||
|
#define CURLFNM_DIGIT (CURLFNM_CHARSET_LEN + 2)
|
||||||
|
#define CURLFNM_XDIGIT (CURLFNM_CHARSET_LEN + 3)
|
||||||
|
#define CURLFNM_ALPHA (CURLFNM_CHARSET_LEN + 4)
|
||||||
|
#define CURLFNM_PRINT (CURLFNM_CHARSET_LEN + 5)
|
||||||
|
#define CURLFNM_BLANK (CURLFNM_CHARSET_LEN + 6)
|
||||||
|
#define CURLFNM_LOWER (CURLFNM_CHARSET_LEN + 7)
|
||||||
|
#define CURLFNM_GRAPH (CURLFNM_CHARSET_LEN + 8)
|
||||||
|
#define CURLFNM_SPACE (CURLFNM_CHARSET_LEN + 9)
|
||||||
|
#define CURLFNM_UPPER (CURLFNM_CHARSET_LEN + 10)
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CURLFNM_LOOP_DEFAULT = 0,
|
||||||
|
CURLFNM_LOOP_BACKSLASH
|
||||||
|
} loop_state;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CURLFNM_SCHS_DEFAULT = 0,
|
||||||
|
CURLFNM_SCHS_MAYRANGE,
|
||||||
|
CURLFNM_SCHS_MAYRANGE2,
|
||||||
|
CURLFNM_SCHS_RIGHTBR,
|
||||||
|
CURLFNM_SCHS_RIGHTBRLEFTBR
|
||||||
|
} setcharset_state;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CURLFNM_PKW_INIT = 0,
|
||||||
|
CURLFNM_PKW_DDOT
|
||||||
|
} parsekey_state;
|
||||||
|
|
||||||
|
#define SETCHARSET_OK 1
|
||||||
|
#define SETCHARSET_FAIL 0
|
||||||
|
|
||||||
|
static int parsekeyword(unsigned char **pattern, unsigned char *charset)
|
||||||
|
{
|
||||||
|
parsekey_state state = CURLFNM_PKW_INIT;
|
||||||
|
#define KEYLEN 10
|
||||||
|
char keyword[KEYLEN] = { 0 };
|
||||||
|
int found = FALSE;
|
||||||
|
int i;
|
||||||
|
unsigned char *p = *pattern;
|
||||||
|
for(i = 0; !found; i++) {
|
||||||
|
char c = *p++;
|
||||||
|
if(i >= KEYLEN)
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
switch(state) {
|
||||||
|
case CURLFNM_PKW_INIT:
|
||||||
|
if(ISALPHA(c) && ISLOWER(c))
|
||||||
|
keyword[i] = c;
|
||||||
|
else if(c == ':')
|
||||||
|
state = CURLFNM_PKW_DDOT;
|
||||||
|
else
|
||||||
|
return 0;
|
||||||
|
break;
|
||||||
|
case CURLFNM_PKW_DDOT:
|
||||||
|
if(c == ']')
|
||||||
|
found = TRUE;
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#undef KEYLEN
|
||||||
|
|
||||||
|
*pattern = p; /* move caller's pattern pointer */
|
||||||
|
if(strcmp(keyword, "digit") == 0)
|
||||||
|
charset[CURLFNM_DIGIT] = 1;
|
||||||
|
else if(strcmp(keyword, "alnum") == 0)
|
||||||
|
charset[CURLFNM_ALNUM] = 1;
|
||||||
|
else if(strcmp(keyword, "alpha") == 0)
|
||||||
|
charset[CURLFNM_ALPHA] = 1;
|
||||||
|
else if(strcmp(keyword, "xdigit") == 0)
|
||||||
|
charset[CURLFNM_XDIGIT] = 1;
|
||||||
|
else if(strcmp(keyword, "print") == 0)
|
||||||
|
charset[CURLFNM_PRINT] = 1;
|
||||||
|
else if(strcmp(keyword, "graph") == 0)
|
||||||
|
charset[CURLFNM_GRAPH] = 1;
|
||||||
|
else if(strcmp(keyword, "space") == 0)
|
||||||
|
charset[CURLFNM_SPACE] = 1;
|
||||||
|
else if(strcmp(keyword, "blank") == 0)
|
||||||
|
charset[CURLFNM_BLANK] = 1;
|
||||||
|
else if(strcmp(keyword, "upper") == 0)
|
||||||
|
charset[CURLFNM_UPPER] = 1;
|
||||||
|
else if(strcmp(keyword, "lower") == 0)
|
||||||
|
charset[CURLFNM_LOWER] = 1;
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
return SETCHARSET_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* returns 1 (true) if pattern is OK, 0 if is bad ("p" is pattern pointer) */
|
||||||
|
static int setcharset(unsigned char **p, unsigned char *charset)
|
||||||
|
{
|
||||||
|
setcharset_state state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
unsigned char rangestart = 0;
|
||||||
|
unsigned char lastchar = 0;
|
||||||
|
bool something_found = FALSE;
|
||||||
|
unsigned char c;
|
||||||
|
for(;;) {
|
||||||
|
c = **p;
|
||||||
|
switch(state) {
|
||||||
|
case CURLFNM_SCHS_DEFAULT:
|
||||||
|
if(ISALNUM(c)) { /* ASCII value */
|
||||||
|
rangestart = c;
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
state = CURLFNM_SCHS_MAYRANGE;
|
||||||
|
something_found = TRUE;
|
||||||
|
}
|
||||||
|
else if(c == ']') {
|
||||||
|
if(something_found)
|
||||||
|
return SETCHARSET_OK;
|
||||||
|
else
|
||||||
|
something_found = TRUE;
|
||||||
|
state = CURLFNM_SCHS_RIGHTBR;
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else if(c == '[') {
|
||||||
|
char c2 = *((*p)+1);
|
||||||
|
if(c2 == ':') { /* there has to be a keyword */
|
||||||
|
(*p) += 2;
|
||||||
|
if(parsekeyword(p, charset)) {
|
||||||
|
state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
something_found = TRUE;
|
||||||
|
}
|
||||||
|
else if(c == '?' || c == '*') {
|
||||||
|
something_found = TRUE;
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else if(c == '^' || c == '!') {
|
||||||
|
if(!something_found) {
|
||||||
|
if(charset[CURLFNM_NEGATE]) {
|
||||||
|
charset[c] = 1;
|
||||||
|
something_found = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
charset[CURLFNM_NEGATE] = 1; /* negate charset */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else if(c == '\\') {
|
||||||
|
c = *(++(*p));
|
||||||
|
if(ISPRINT((c))) {
|
||||||
|
something_found = TRUE;
|
||||||
|
state = CURLFNM_SCHS_MAYRANGE;
|
||||||
|
charset[c] = 1;
|
||||||
|
rangestart = c;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
else if(c == '\0') {
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
something_found = TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case CURLFNM_SCHS_MAYRANGE:
|
||||||
|
if(c == '-') {
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
lastchar = '-';
|
||||||
|
state = CURLFNM_SCHS_MAYRANGE2;
|
||||||
|
}
|
||||||
|
else if(c == '[') {
|
||||||
|
state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
}
|
||||||
|
else if(ISALNUM(c)) {
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else if(c == '\\') {
|
||||||
|
c = *(++(*p));
|
||||||
|
if(ISPRINT(c)) {
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
else if(c == ']') {
|
||||||
|
return SETCHARSET_OK;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
break;
|
||||||
|
case CURLFNM_SCHS_MAYRANGE2:
|
||||||
|
if(c == '\\') {
|
||||||
|
c = *(++(*p));
|
||||||
|
if(!ISPRINT(c))
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
if(c == ']') {
|
||||||
|
return SETCHARSET_OK;
|
||||||
|
}
|
||||||
|
else if(c == '\\') {
|
||||||
|
c = *(++(*p));
|
||||||
|
if(ISPRINT(c)) {
|
||||||
|
charset[c] = 1;
|
||||||
|
state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
if(c >= rangestart) {
|
||||||
|
if((ISLOWER(c) && ISLOWER(rangestart)) ||
|
||||||
|
(ISDIGIT(c) && ISDIGIT(rangestart)) ||
|
||||||
|
(ISUPPER(c) && ISUPPER(rangestart))) {
|
||||||
|
charset[lastchar] = 0;
|
||||||
|
rangestart++;
|
||||||
|
while(rangestart++ <= c)
|
||||||
|
charset[rangestart-1] = 1;
|
||||||
|
(*p)++;
|
||||||
|
state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case CURLFNM_SCHS_RIGHTBR:
|
||||||
|
if(c == '[') {
|
||||||
|
state = CURLFNM_SCHS_RIGHTBRLEFTBR;
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
else if(c == ']') {
|
||||||
|
return SETCHARSET_OK;
|
||||||
|
}
|
||||||
|
else if(c == '\0') {
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
else if(ISPRINT(c)) {
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
/* used 'goto fail' instead of 'return SETCHARSET_FAIL' to avoid a
|
||||||
|
* nonsense warning 'statement not reached' at end of the fnc when
|
||||||
|
* compiling on Solaris */
|
||||||
|
goto fail;
|
||||||
|
break;
|
||||||
|
case CURLFNM_SCHS_RIGHTBRLEFTBR:
|
||||||
|
if(c == ']') {
|
||||||
|
return SETCHARSET_OK;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
state = CURLFNM_SCHS_DEFAULT;
|
||||||
|
charset[c] = 1;
|
||||||
|
(*p)++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fail:
|
||||||
|
return SETCHARSET_FAIL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int loop(const unsigned char *pattern, const unsigned char *string)
|
||||||
|
{
|
||||||
|
loop_state state = CURLFNM_LOOP_DEFAULT;
|
||||||
|
unsigned char *p = (unsigned char *)pattern;
|
||||||
|
unsigned char *s = (unsigned char *)string;
|
||||||
|
unsigned char charset[CURLFNM_CHSET_SIZE] = { 0 };
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
|
for (;;) {
|
||||||
|
switch(state) {
|
||||||
|
case CURLFNM_LOOP_DEFAULT:
|
||||||
|
if(*p == '*') {
|
||||||
|
while(*(p+1) == '*') /* eliminate multiple stars */
|
||||||
|
p++;
|
||||||
|
if(*s == '\0' && *(p+1) == '\0')
|
||||||
|
return CURL_FNMATCH_MATCH;
|
||||||
|
rc = loop(p + 1, s); /* *.txt matches .txt <=> .txt matches .txt */
|
||||||
|
if(rc == CURL_FNMATCH_MATCH)
|
||||||
|
return CURL_FNMATCH_MATCH;
|
||||||
|
if(*s) /* let the star eat up one character */
|
||||||
|
s++;
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_NOMATCH;
|
||||||
|
}
|
||||||
|
else if(*p == '?') {
|
||||||
|
if(ISPRINT(*s)) {
|
||||||
|
s++;
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
else if(*s == '\0')
|
||||||
|
return CURL_FNMATCH_NOMATCH;
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_FAIL; /* cannot deal with other character */
|
||||||
|
}
|
||||||
|
else if(*p == '\0') {
|
||||||
|
if(*s == '\0')
|
||||||
|
return CURL_FNMATCH_MATCH;
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_NOMATCH;
|
||||||
|
}
|
||||||
|
else if(*p == '\\') {
|
||||||
|
state = CURLFNM_LOOP_BACKSLASH;
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
else if(*p == '[') {
|
||||||
|
unsigned char *pp = p+1; /* cannot handle with pointer to register */
|
||||||
|
if(setcharset(&pp, charset)) {
|
||||||
|
int found = FALSE;
|
||||||
|
if(charset[(unsigned int)*s])
|
||||||
|
found = TRUE;
|
||||||
|
else if(charset[CURLFNM_ALNUM])
|
||||||
|
found = ISALNUM(*s);
|
||||||
|
else if(charset[CURLFNM_ALPHA])
|
||||||
|
found = ISALPHA(*s);
|
||||||
|
else if(charset[CURLFNM_DIGIT])
|
||||||
|
found = ISDIGIT(*s);
|
||||||
|
else if(charset[CURLFNM_XDIGIT])
|
||||||
|
found = ISXDIGIT(*s);
|
||||||
|
else if(charset[CURLFNM_PRINT])
|
||||||
|
found = ISPRINT(*s);
|
||||||
|
else if(charset[CURLFNM_SPACE])
|
||||||
|
found = ISSPACE(*s);
|
||||||
|
else if(charset[CURLFNM_UPPER])
|
||||||
|
found = ISUPPER(*s);
|
||||||
|
else if(charset[CURLFNM_LOWER])
|
||||||
|
found = ISLOWER(*s);
|
||||||
|
else if(charset[CURLFNM_BLANK])
|
||||||
|
found = ISBLANK(*s);
|
||||||
|
else if(charset[CURLFNM_GRAPH])
|
||||||
|
found = ISGRAPH(*s);
|
||||||
|
|
||||||
|
if(charset[CURLFNM_NEGATE])
|
||||||
|
found = !found;
|
||||||
|
|
||||||
|
if(found) {
|
||||||
|
p = pp+1;
|
||||||
|
s++;
|
||||||
|
memset(charset, 0, CURLFNM_CHSET_SIZE);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_NOMATCH;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_FAIL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(*p++ != *s++)
|
||||||
|
return CURL_FNMATCH_NOMATCH;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case CURLFNM_LOOP_BACKSLASH:
|
||||||
|
if(ISPRINT(*p)) {
|
||||||
|
if(*p++ == *s++)
|
||||||
|
state = CURLFNM_LOOP_DEFAULT;
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_NOMATCH;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return CURL_FNMATCH_FAIL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Curl_fnmatch(void *ptr, const char *pattern, const char *string)
|
||||||
|
{
|
||||||
|
(void)ptr; /* the argument is specified by the curl_fnmatch_callback
|
||||||
|
prototype, but not used by Curl_fnmatch() */
|
||||||
|
if(!pattern || !string) {
|
||||||
|
return CURL_FNMATCH_FAIL;
|
||||||
|
}
|
||||||
|
return loop((unsigned char *)pattern, (unsigned char *)string);
|
||||||
|
}
|
44
lib/curl_fnmatch.h
Normal file
44
lib/curl_fnmatch.h
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#ifndef HEADER_CURL_FNMATCH_H
|
||||||
|
#define HEADER_CURL_FNMATCH_H
|
||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2009, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#define CURL_FNMATCH_MATCH 0
|
||||||
|
#define CURL_FNMATCH_NOMATCH 1
|
||||||
|
#define CURL_FNMATCH_FAIL 2
|
||||||
|
|
||||||
|
/* default pattern matching function
|
||||||
|
* =================================
|
||||||
|
* Implemented with recursive backtracking, if you want to use Curl_fnmatch,
|
||||||
|
* please note that there is not implemented UTF/UNICODE support.
|
||||||
|
*
|
||||||
|
* Implemented features:
|
||||||
|
* '?' notation, does not match UTF characters
|
||||||
|
* '*' can also work with UTF string
|
||||||
|
* [a-zA-Z0-9] enumeration support
|
||||||
|
*
|
||||||
|
* keywords: alnum, digit, xdigit, alpha, print, blank, lower, graph, space
|
||||||
|
* and upper (use as "[[:alnum:]]")
|
||||||
|
*/
|
||||||
|
int Curl_fnmatch(void *ptr, const char *pattern, const char *string);
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_FNMATCH_H */
|
81
lib/curl_gethostname.c
Normal file
81
lib/curl_gethostname.c
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
# include <unistd.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "curl_gethostname.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Curl_gethostname() is a wrapper around gethostname() which allows
|
||||||
|
* overriding the host name that the function would normally return.
|
||||||
|
* This capability is used by the test suite to verify exact matching
|
||||||
|
* of NTLM authentication, which exercises libcurl's MD4 and DES code.
|
||||||
|
*
|
||||||
|
* For libcurl debug enabled builds host name overriding takes place
|
||||||
|
* when environment variable CURL_GETHOSTNAME is set, using the value
|
||||||
|
* held by the variable to override returned host name.
|
||||||
|
*
|
||||||
|
* For libcurl shared library release builds the test suite preloads
|
||||||
|
* another shared library named libhostname using the LD_PRELOAD
|
||||||
|
* mechanism which intercepts, and might override, the gethostname()
|
||||||
|
* function call. In this case a given platform must support the
|
||||||
|
* LD_PRELOAD mechanism and additionally have environment variable
|
||||||
|
* CURL_GETHOSTNAME set in order to override the returned host name.
|
||||||
|
*
|
||||||
|
* For libcurl static library release builds no overriding takes place.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int Curl_gethostname(char *name, GETHOSTNAME_TYPE_ARG2 namelen) {
|
||||||
|
|
||||||
|
#ifndef HAVE_GETHOSTNAME
|
||||||
|
|
||||||
|
/* Allow compilation and return failure when unavailable */
|
||||||
|
(void) name;
|
||||||
|
(void) namelen;
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#ifdef DEBUGBUILD
|
||||||
|
|
||||||
|
/* Override host name when environment variable CURL_GETHOSTNAME is set */
|
||||||
|
const char *force_hostname = getenv("CURL_GETHOSTNAME");
|
||||||
|
if(force_hostname) {
|
||||||
|
strncpy(name, force_hostname, namelen);
|
||||||
|
name[namelen-1] = '\0';
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* DEBUGBUILD */
|
||||||
|
|
||||||
|
/* The call to system's gethostname() might get intercepted by the
|
||||||
|
libhostname library when libcurl is built as a non-debug shared
|
||||||
|
library when running the test suite. */
|
||||||
|
return gethostname(name, namelen);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
27
lib/curl_gethostname.h
Normal file
27
lib/curl_gethostname.h
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
#ifndef HEADER_CURL_GETHOSTNAME_H
|
||||||
|
#define HEADER_CURL_GETHOSTNAME_H
|
||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
int Curl_gethostname(char *name, GETHOSTNAME_TYPE_ARG2 namelen);
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_GETHOSTNAME_H */
|
67
lib/curl_hmac.h
Normal file
67
lib/curl_hmac.h
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
#ifndef HEADER_CURL_HMAC_H
|
||||||
|
#define HEADER_CURL_HMAC_H
|
||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#ifndef CURL_DISABLE_CRYPTO_AUTH
|
||||||
|
|
||||||
|
typedef void (* HMAC_hinit_func)(void * context);
|
||||||
|
typedef void (* HMAC_hupdate_func)(void * context,
|
||||||
|
const unsigned char * data,
|
||||||
|
unsigned int len);
|
||||||
|
typedef void (* HMAC_hfinal_func)(unsigned char * result, void * context);
|
||||||
|
|
||||||
|
|
||||||
|
/* Per-hash function HMAC parameters. */
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
HMAC_hinit_func hmac_hinit; /* Initialize context procedure. */
|
||||||
|
HMAC_hupdate_func hmac_hupdate; /* Update context with data. */
|
||||||
|
HMAC_hfinal_func hmac_hfinal; /* Get final result procedure. */
|
||||||
|
unsigned int hmac_ctxtsize; /* Context structure size. */
|
||||||
|
unsigned int hmac_maxkeylen; /* Maximum key length (bytes). */
|
||||||
|
unsigned int hmac_resultlen; /* Result length (bytes). */
|
||||||
|
} HMAC_params;
|
||||||
|
|
||||||
|
|
||||||
|
/* HMAC computation context. */
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
const HMAC_params * hmac_hash; /* Hash function definition. */
|
||||||
|
void * hmac_hashctxt1; /* Hash function context 1. */
|
||||||
|
void * hmac_hashctxt2; /* Hash function context 2. */
|
||||||
|
} HMAC_context;
|
||||||
|
|
||||||
|
|
||||||
|
/* Prototypes. */
|
||||||
|
|
||||||
|
HMAC_context * Curl_HMAC_init(const HMAC_params * hashparams,
|
||||||
|
const unsigned char * key,
|
||||||
|
unsigned int keylen);
|
||||||
|
int Curl_HMAC_update(HMAC_context * context,
|
||||||
|
const unsigned char * data,
|
||||||
|
unsigned int len);
|
||||||
|
int Curl_HMAC_final(HMAC_context * context, unsigned char * result);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_HMAC_H */
|
@@ -8,7 +8,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -25,7 +25,8 @@
|
|||||||
#ifndef CURL_DISABLE_LDAP
|
#ifndef CURL_DISABLE_LDAP
|
||||||
extern const struct Curl_handler Curl_handler_ldap;
|
extern const struct Curl_handler Curl_handler_ldap;
|
||||||
|
|
||||||
#ifdef HAVE_LDAP_SSL
|
#if (defined(USE_OPENLDAP) && defined(USE_SSL)) || \
|
||||||
|
(!defined(USE_OPENLDAP) && defined(HAVE_LDAP_SSL))
|
||||||
extern const struct Curl_handler Curl_handler_ldaps;
|
extern const struct Curl_handler Curl_handler_ldaps;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
33
lib/curl_md4.h
Normal file
33
lib/curl_md4.h
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
#ifndef HEADER_CURL_MD4_H
|
||||||
|
#define HEADER_CURL_MD4_H
|
||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
|
/* NSS crypto library does not provide the MD4 hash algorithm, so that we have
|
||||||
|
* a local implementation of it */
|
||||||
|
#ifdef USE_NSS
|
||||||
|
void Curl_md4it(unsigned char *output, const unsigned char *input, size_t len);
|
||||||
|
#endif /* USE_NSS */
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_MD4_H */
|
@@ -22,7 +22,13 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
#ifndef CURL_DISABLE_CRYPTO_AUTH
|
||||||
|
#include "curl_hmac.h"
|
||||||
|
|
||||||
|
extern const HMAC_params Curl_HMAC_MD5[1];
|
||||||
|
|
||||||
void Curl_md5it(unsigned char *output,
|
void Curl_md5it(unsigned char *output,
|
||||||
const unsigned char *input);
|
const unsigned char *input);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* HEADER_CURL_MD5_H */
|
#endif /* HEADER_CURL_MD5_H */
|
||||||
|
284
lib/curl_rtmp.c
Normal file
284
lib/curl_rtmp.c
Normal file
@@ -0,0 +1,284 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010, Howard Chu, <hyc@highlandsun.com>
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
|
#ifdef USE_LIBRTMP
|
||||||
|
|
||||||
|
#include "urldata.h"
|
||||||
|
#include "nonblock.h" /* for curlx_nonblock */
|
||||||
|
#include "progress.h" /* for Curl_pgrsSetUploadSize */
|
||||||
|
#include "transfer.h"
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <librtmp/rtmp.h>
|
||||||
|
|
||||||
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
|
#include "curl_memory.h"
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#include "memdebug.h"
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
#define setsockopt(a,b,c,d,e) (setsockopt)(a,b,c,(const char *)d,(int)e)
|
||||||
|
#define SET_RCVTIMEO(tv,s) int tv = s*1000
|
||||||
|
#else
|
||||||
|
#define SET_RCVTIMEO(tv,s) struct timeval tv = {s,0}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define DEF_BUFTIME (2*60*60*1000) /* 2 hours */
|
||||||
|
|
||||||
|
static CURLcode rtmp_setup(struct connectdata *conn);
|
||||||
|
static CURLcode rtmp_do(struct connectdata *conn, bool *done);
|
||||||
|
static CURLcode rtmp_done(struct connectdata *conn, CURLcode, bool premature);
|
||||||
|
static CURLcode rtmp_connect(struct connectdata *conn, bool *done);
|
||||||
|
static CURLcode rtmp_disconnect(struct connectdata *conn);
|
||||||
|
|
||||||
|
static Curl_recv rtmp_recv;
|
||||||
|
static Curl_send rtmp_send;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* RTMP protocol handler.h, based on http://rtmpdump.mplayerhq.hu
|
||||||
|
*/
|
||||||
|
|
||||||
|
const struct Curl_handler Curl_handler_rtmp = {
|
||||||
|
"RTMP", /* scheme */
|
||||||
|
rtmp_setup, /* setup_connection */
|
||||||
|
rtmp_do, /* do_it */
|
||||||
|
rtmp_done, /* done */
|
||||||
|
ZERO_NULL, /* do_more */
|
||||||
|
rtmp_connect, /* connect_it */
|
||||||
|
ZERO_NULL, /* connecting */
|
||||||
|
ZERO_NULL, /* doing */
|
||||||
|
ZERO_NULL, /* proto_getsock */
|
||||||
|
ZERO_NULL, /* doing_getsock */
|
||||||
|
ZERO_NULL, /* perform_getsock */
|
||||||
|
rtmp_disconnect, /* disconnect */
|
||||||
|
PORT_RTMP, /* defport */
|
||||||
|
PROT_RTMP /* protocol */
|
||||||
|
};
|
||||||
|
|
||||||
|
const struct Curl_handler Curl_handler_rtmpt = {
|
||||||
|
"RTMPT", /* scheme */
|
||||||
|
rtmp_setup, /* setup_connection */
|
||||||
|
rtmp_do, /* do_it */
|
||||||
|
rtmp_done, /* done */
|
||||||
|
ZERO_NULL, /* do_more */
|
||||||
|
rtmp_connect, /* connect_it */
|
||||||
|
ZERO_NULL, /* connecting */
|
||||||
|
ZERO_NULL, /* doing */
|
||||||
|
ZERO_NULL, /* proto_getsock */
|
||||||
|
ZERO_NULL, /* doing_getsock */
|
||||||
|
ZERO_NULL, /* perform_getsock */
|
||||||
|
rtmp_disconnect, /* disconnect */
|
||||||
|
PORT_RTMPT, /* defport */
|
||||||
|
PROT_RTMPT /* protocol */
|
||||||
|
};
|
||||||
|
|
||||||
|
const struct Curl_handler Curl_handler_rtmpe = {
|
||||||
|
"RTMPE", /* scheme */
|
||||||
|
rtmp_setup, /* setup_connection */
|
||||||
|
rtmp_do, /* do_it */
|
||||||
|
rtmp_done, /* done */
|
||||||
|
ZERO_NULL, /* do_more */
|
||||||
|
rtmp_connect, /* connect_it */
|
||||||
|
ZERO_NULL, /* connecting */
|
||||||
|
ZERO_NULL, /* doing */
|
||||||
|
ZERO_NULL, /* proto_getsock */
|
||||||
|
ZERO_NULL, /* doing_getsock */
|
||||||
|
ZERO_NULL, /* perform_getsock */
|
||||||
|
rtmp_disconnect, /* disconnect */
|
||||||
|
PORT_RTMP, /* defport */
|
||||||
|
PROT_RTMPE /* protocol */
|
||||||
|
};
|
||||||
|
|
||||||
|
const struct Curl_handler Curl_handler_rtmpte = {
|
||||||
|
"RTMPTE", /* scheme */
|
||||||
|
rtmp_setup, /* setup_connection */
|
||||||
|
rtmp_do, /* do_it */
|
||||||
|
rtmp_done, /* done */
|
||||||
|
ZERO_NULL, /* do_more */
|
||||||
|
rtmp_connect, /* connect_it */
|
||||||
|
ZERO_NULL, /* connecting */
|
||||||
|
ZERO_NULL, /* doing */
|
||||||
|
ZERO_NULL, /* proto_getsock */
|
||||||
|
ZERO_NULL, /* doing_getsock */
|
||||||
|
ZERO_NULL, /* perform_getsock */
|
||||||
|
rtmp_disconnect, /* disconnect */
|
||||||
|
PORT_RTMPT, /* defport */
|
||||||
|
PROT_RTMPTE /* protocol */
|
||||||
|
};
|
||||||
|
|
||||||
|
const struct Curl_handler Curl_handler_rtmps = {
|
||||||
|
"RTMPS", /* scheme */
|
||||||
|
rtmp_setup, /* setup_connection */
|
||||||
|
rtmp_do, /* do_it */
|
||||||
|
rtmp_done, /* done */
|
||||||
|
ZERO_NULL, /* do_more */
|
||||||
|
rtmp_connect, /* connect_it */
|
||||||
|
ZERO_NULL, /* connecting */
|
||||||
|
ZERO_NULL, /* doing */
|
||||||
|
ZERO_NULL, /* proto_getsock */
|
||||||
|
ZERO_NULL, /* doing_getsock */
|
||||||
|
ZERO_NULL, /* perform_getsock */
|
||||||
|
rtmp_disconnect, /* disconnect */
|
||||||
|
PORT_RTMPS, /* defport */
|
||||||
|
PROT_RTMPS /* protocol */
|
||||||
|
};
|
||||||
|
const struct Curl_handler Curl_handler_rtmpts = {
|
||||||
|
"RTMPTS", /* scheme */
|
||||||
|
rtmp_setup, /* setup_connection */
|
||||||
|
rtmp_do, /* do_it */
|
||||||
|
rtmp_done, /* done */
|
||||||
|
ZERO_NULL, /* do_more */
|
||||||
|
rtmp_connect, /* connect_it */
|
||||||
|
ZERO_NULL, /* connecting */
|
||||||
|
ZERO_NULL, /* doing */
|
||||||
|
ZERO_NULL, /* proto_getsock */
|
||||||
|
ZERO_NULL, /* doing_getsock */
|
||||||
|
ZERO_NULL, /* perform_getsock */
|
||||||
|
rtmp_disconnect, /* disconnect */
|
||||||
|
PORT_RTMPS, /* defport */
|
||||||
|
PROT_RTMPTS /* protocol */
|
||||||
|
};
|
||||||
|
|
||||||
|
static CURLcode rtmp_setup(struct connectdata *conn)
|
||||||
|
{
|
||||||
|
RTMP *r = RTMP_Alloc();
|
||||||
|
|
||||||
|
if (!r)
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
|
RTMP_Init(r);
|
||||||
|
RTMP_SetBufferMS(r, DEF_BUFTIME);
|
||||||
|
if (!RTMP_SetupURL(r, conn->data->change.url)) {
|
||||||
|
RTMP_Free(r);
|
||||||
|
return CURLE_URL_MALFORMAT;
|
||||||
|
}
|
||||||
|
conn->proto.generic = r;
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode rtmp_connect(struct connectdata *conn, bool *done)
|
||||||
|
{
|
||||||
|
RTMP *r = conn->proto.generic;
|
||||||
|
SET_RCVTIMEO(tv,10);
|
||||||
|
|
||||||
|
r->m_sb.sb_socket = conn->sock[FIRSTSOCKET];
|
||||||
|
|
||||||
|
/* We have to know if it's a write before we send the
|
||||||
|
* connect request packet
|
||||||
|
*/
|
||||||
|
if (conn->data->set.upload)
|
||||||
|
r->Link.protocol |= RTMP_FEATURE_WRITE;
|
||||||
|
|
||||||
|
/* For plain streams, use the buffer toggle trick to keep data flowing */
|
||||||
|
if (!(r->Link.lFlags & RTMP_LF_LIVE) && !(r->Link.protocol & RTMP_FEATURE_HTTP))
|
||||||
|
r->Link.lFlags |= RTMP_LF_BUFX;
|
||||||
|
|
||||||
|
curlx_nonblock(r->m_sb.sb_socket, FALSE);
|
||||||
|
setsockopt(r->m_sb.sb_socket, SOL_SOCKET, SO_RCVTIMEO, (char *)&tv, sizeof(tv));
|
||||||
|
|
||||||
|
if (!RTMP_Connect1(r, NULL))
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
|
||||||
|
/* Clients must send a periodic BytesReceived report to the server */
|
||||||
|
r->m_bSendCounter = true;
|
||||||
|
|
||||||
|
*done = TRUE;
|
||||||
|
conn->recv[FIRSTSOCKET] = rtmp_recv;
|
||||||
|
conn->send[FIRSTSOCKET] = rtmp_send;
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode rtmp_do(struct connectdata *conn, bool *done)
|
||||||
|
{
|
||||||
|
RTMP *r = conn->proto.generic;
|
||||||
|
|
||||||
|
if (!RTMP_ConnectStream(r, 0))
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
|
||||||
|
if (conn->data->set.upload) {
|
||||||
|
Curl_pgrsSetUploadSize(conn->data, conn->data->set.infilesize);
|
||||||
|
Curl_setup_transfer(conn, -1, -1, FALSE, NULL, FIRSTSOCKET, NULL);
|
||||||
|
} else
|
||||||
|
Curl_setup_transfer(conn, FIRSTSOCKET, -1, FALSE, NULL, -1, NULL);
|
||||||
|
*done = TRUE;
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode rtmp_done(struct connectdata *conn, CURLcode status,
|
||||||
|
bool premature)
|
||||||
|
{
|
||||||
|
(void)conn; /* unused */
|
||||||
|
(void)status; /* unused */
|
||||||
|
(void)premature; /* unused */
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode rtmp_disconnect(struct connectdata *conn)
|
||||||
|
{
|
||||||
|
RTMP *r = conn->proto.generic;
|
||||||
|
if (r) {
|
||||||
|
conn->proto.generic = NULL;
|
||||||
|
RTMP_Close(r);
|
||||||
|
RTMP_Free(r);
|
||||||
|
}
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ssize_t rtmp_recv(struct connectdata *conn, int sockindex, char *buf,
|
||||||
|
size_t len, CURLcode *err)
|
||||||
|
{
|
||||||
|
RTMP *r = conn->proto.generic;
|
||||||
|
ssize_t nread;
|
||||||
|
|
||||||
|
(void)sockindex; /* unused */
|
||||||
|
|
||||||
|
nread = RTMP_Read(r, buf, len);
|
||||||
|
if (nread < 0) {
|
||||||
|
if (r->m_read.status == RTMP_READ_COMPLETE ||
|
||||||
|
r->m_read.status == RTMP_READ_EOF) {
|
||||||
|
conn->data->req.size = conn->data->req.bytecount;
|
||||||
|
nread = 0;
|
||||||
|
} else
|
||||||
|
*err = CURLE_RECV_ERROR;
|
||||||
|
}
|
||||||
|
return nread;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ssize_t rtmp_send(struct connectdata *conn, int sockindex,
|
||||||
|
const void *buf, size_t len, CURLcode *err)
|
||||||
|
{
|
||||||
|
RTMP *r = conn->proto.generic;
|
||||||
|
ssize_t num;
|
||||||
|
|
||||||
|
(void)sockindex; /* unused */
|
||||||
|
|
||||||
|
num = RTMP_Write(r, (char *)buf, len);
|
||||||
|
if (num < 0) {
|
||||||
|
*err = CURLE_SEND_ERROR;
|
||||||
|
}
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
#endif /* USE_LIBRTMP */
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user