Compare commits
322 Commits
curl-7_5_2
...
curl-7_7-b
Author | SHA1 | Date | |
---|---|---|---|
![]() |
1841c8ee6a | ||
![]() |
70793595fe | ||
![]() |
28a8e1602d | ||
![]() |
cce05b9138 | ||
![]() |
72a7fd4dc7 | ||
![]() |
9a6a476cf5 | ||
![]() |
5d0efedd2d | ||
![]() |
a426818a78 | ||
![]() |
bfe413d8bd | ||
![]() |
dbbd20646f | ||
![]() |
b8fe4deb13 | ||
![]() |
332a016e3c | ||
![]() |
3738e4bdc0 | ||
![]() |
3201d2dafa | ||
![]() |
0a1e002ca4 | ||
![]() |
9195bb64d4 | ||
![]() |
11ee547a0e | ||
![]() |
147de35d41 | ||
![]() |
e16e9b91ae | ||
![]() |
f9cde0646f | ||
![]() |
195233ed5c | ||
![]() |
048e654514 | ||
![]() |
dfbd45142d | ||
![]() |
ff681f7bfd | ||
![]() |
60bbb64a81 | ||
![]() |
c622f2bb4e | ||
![]() |
cd59f13da6 | ||
![]() |
11d718bf52 | ||
![]() |
8e8846d876 | ||
![]() |
7d562bb685 | ||
![]() |
20ddd35669 | ||
![]() |
063f88cd14 | ||
![]() |
87b0b7cab9 | ||
![]() |
70d0d9d4da | ||
![]() |
4ae3bd71ea | ||
![]() |
a9390665b8 | ||
![]() |
fb7a6e3423 | ||
![]() |
cc99e3f7de | ||
![]() |
e6b40bb6ac | ||
![]() |
f2fd1b8856 | ||
![]() |
cb4efcf275 | ||
![]() |
56a27d608a | ||
![]() |
46c9075eab | ||
![]() |
d95fa648e9 | ||
![]() |
563ad213dc | ||
![]() |
0121d7d731 | ||
![]() |
8495fac1c5 | ||
![]() |
38c349f751 | ||
![]() |
542df800ab | ||
![]() |
3e88b1cac5 | ||
![]() |
d774b10afb | ||
![]() |
b449b94393 | ||
![]() |
a6cb9b08b2 | ||
![]() |
440a3101d0 | ||
![]() |
9778a5356b | ||
![]() |
de7dcdbc54 | ||
![]() |
070968abbc | ||
![]() |
e97fc2aab5 | ||
![]() |
a23ac24192 | ||
![]() |
9ee14644a7 | ||
![]() |
c576e114b9 | ||
![]() |
639a7982ba | ||
![]() |
5bbe189420 | ||
![]() |
93ff159e32 | ||
![]() |
8eb8a0a8e4 | ||
![]() |
a4af638867 | ||
![]() |
75a9a87ec2 | ||
![]() |
b5ba011110 | ||
![]() |
e9b763ff05 | ||
![]() |
ac0bad2433 | ||
![]() |
67d5c0a970 | ||
![]() |
580896d615 | ||
![]() |
11693c0faa | ||
![]() |
26cd8eda4a | ||
![]() |
8cd3f44040 | ||
![]() |
2b30bfc349 | ||
![]() |
8ec4dba599 | ||
![]() |
1efec6572e | ||
![]() |
781dd7a9bf | ||
![]() |
beb8761b22 | ||
![]() |
071c7de9fe | ||
![]() |
3e7ebcd051 | ||
![]() |
c67952fc5c | ||
![]() |
7d7c24f915 | ||
![]() |
0dc8c4d451 | ||
![]() |
9cf4434ae2 | ||
![]() |
8ccd8b6dbc | ||
![]() |
b4f70aa2c8 | ||
![]() |
f54a282ccc | ||
![]() |
2a11bdc216 | ||
![]() |
5cd4c3ed24 | ||
![]() |
147a673063 | ||
![]() |
9ce5827fc1 | ||
![]() |
97f1c93674 | ||
![]() |
e61ceaf1bd | ||
![]() |
1118612249 | ||
![]() |
a23db7b7c7 | ||
![]() |
f6b6dff46a | ||
![]() |
55b8ceac18 | ||
![]() |
bcf448ee32 | ||
![]() |
91e4da7ddb | ||
![]() |
2873c18132 | ||
![]() |
5dd0a8a63e | ||
![]() |
2103dc41f5 | ||
![]() |
2ef13230cb | ||
![]() |
9479ac6dda | ||
![]() |
4e878eae79 | ||
![]() |
1e8e90a220 | ||
![]() |
fe95c7dc34 | ||
![]() |
6dae34d5da | ||
![]() |
36c621c9df | ||
![]() |
1717963e3d | ||
![]() |
4646a1ffa9 | ||
![]() |
0cb4eba002 | ||
![]() |
5eba359b5d | ||
![]() |
07ce7539a8 | ||
![]() |
c21f848c1c | ||
![]() |
84e94fda8b | ||
![]() |
ebd6897b10 | ||
![]() |
5ab8a9d32f | ||
![]() |
cf8704ccdf | ||
![]() |
5543c2f11f | ||
![]() |
90ac37a683 | ||
![]() |
dd893fd8a4 | ||
![]() |
834f079918 | ||
![]() |
2665c763df | ||
![]() |
d1cfbd51b5 | ||
![]() |
a3ba6b7a6a | ||
![]() |
415d2e7cb7 | ||
![]() |
af4451ec26 | ||
![]() |
7c6562683a | ||
![]() |
b6fa2f882c | ||
![]() |
b6c5da337a | ||
![]() |
9bc24e4876 | ||
![]() |
4af55809e4 | ||
![]() |
9c63fcf210 | ||
![]() |
1f17fb5f89 | ||
![]() |
584dbffe60 | ||
![]() |
1c6f6f6972 | ||
![]() |
da06a6e7e3 | ||
![]() |
46e0937263 | ||
![]() |
a1d6ad2610 | ||
![]() |
5f3d63ed5b | ||
![]() |
63b5748eb6 | ||
![]() |
e2590430c5 | ||
![]() |
ada9bc2b24 | ||
![]() |
43da41e73e | ||
![]() |
720fa45b56 | ||
![]() |
7de874c438 | ||
![]() |
2078c1a01a | ||
![]() |
f7a8909372 | ||
![]() |
250df30e64 | ||
![]() |
b887cf7521 | ||
![]() |
630e932091 | ||
![]() |
cdabd67aa9 | ||
![]() |
42e4f9d776 | ||
![]() |
c111033595 | ||
![]() |
26d1aaccdf | ||
![]() |
ce95d2020f | ||
![]() |
948c3b3aa9 | ||
![]() |
a140e5311d | ||
![]() |
7686ac3f2c | ||
![]() |
54778134e4 | ||
![]() |
c59baa06f0 | ||
![]() |
c107303ade | ||
![]() |
21b05afc99 | ||
![]() |
eebcf7d4f5 | ||
![]() |
8d169dfadd | ||
![]() |
b12e334d83 | ||
![]() |
7e36c4437e | ||
![]() |
3c7a80a275 | ||
![]() |
61e2a8108b | ||
![]() |
abb14de7e0 | ||
![]() |
ccd57e58f6 | ||
![]() |
58d70db92e | ||
![]() |
09f6fc22ed | ||
![]() |
833ce37cb9 | ||
![]() |
07e7018564 | ||
![]() |
db70cd28b3 | ||
![]() |
f6e2bfd464 | ||
![]() |
1ae5dab8fb | ||
![]() |
c6355e6a43 | ||
![]() |
7d26eb61fe | ||
![]() |
8613ce377f | ||
![]() |
d6b94488a1 | ||
![]() |
5d7b32d09f | ||
![]() |
ed16d30ea8 | ||
![]() |
6f7c70fbbc | ||
![]() |
9ab5d30e3b | ||
![]() |
3b44a3df76 | ||
![]() |
572c29a4a3 | ||
![]() |
9464c5430d | ||
![]() |
a14aaaf23f | ||
![]() |
c41c5a0ef2 | ||
![]() |
c0c0283356 | ||
![]() |
1bcd3e601a | ||
![]() |
e721f85c83 | ||
![]() |
7015c61b86 | ||
![]() |
30ec0af109 | ||
![]() |
f585b66af7 | ||
![]() |
1b77c18430 | ||
![]() |
bd0bd35771 | ||
![]() |
368e3526ea | ||
![]() |
1bbe407a4d | ||
![]() |
513bc44421 | ||
![]() |
4cc76d1576 | ||
![]() |
6dc5c6ffc7 | ||
![]() |
c69c79dd04 | ||
![]() |
7fca24b14b | ||
![]() |
2fa0d3dd5f | ||
![]() |
3a8210c975 | ||
![]() |
d69302202d | ||
![]() |
227662d2ed | ||
![]() |
3cb3d43913 | ||
![]() |
c8a546c941 | ||
![]() |
62fec1d28d | ||
![]() |
ac98c73b04 | ||
![]() |
a145654394 | ||
![]() |
e8382ba290 | ||
![]() |
fcb347d124 | ||
![]() |
c331ef02f9 | ||
![]() |
3a3f632bf0 | ||
![]() |
68d7b6f871 | ||
![]() |
c43a9d9068 | ||
![]() |
64e80091db | ||
![]() |
4f255ffbeb | ||
![]() |
80d75b0eaf | ||
![]() |
808c4020e6 | ||
![]() |
149d6363b3 | ||
![]() |
30eab8ca51 | ||
![]() |
e49a82b06c | ||
![]() |
45fdb48189 | ||
![]() |
3fcc9677c4 | ||
![]() |
1552bd9c8c | ||
![]() |
939c0c5521 | ||
![]() |
f0b9aefd2e | ||
![]() |
11f3c51e8f | ||
![]() |
1a329b98a3 | ||
![]() |
29bcba9a90 | ||
![]() |
1716dbb68a | ||
![]() |
16ecfcf62c | ||
![]() |
8bafc3692d | ||
![]() |
8a75120568 | ||
![]() |
3d96ee7423 | ||
![]() |
b3dbdfa306 | ||
![]() |
25bad589ba | ||
![]() |
0b6cd75004 | ||
![]() |
7872cc131a | ||
![]() |
210aa4371c | ||
![]() |
6f438bc8fb | ||
![]() |
65840f1fd1 | ||
![]() |
5fc492e5c6 | ||
![]() |
abcd1e7d5a | ||
![]() |
6429c378a2 | ||
![]() |
d830f10417 | ||
![]() |
3d6fcbf97b | ||
![]() |
609be218c2 | ||
![]() |
41084e57ca | ||
![]() |
9afab85105 | ||
![]() |
7822233964 | ||
![]() |
022315089b | ||
![]() |
faa5c14aee | ||
![]() |
3dd886955b | ||
![]() |
c2dbf21459 | ||
![]() |
133eb220b9 | ||
![]() |
c5796d9e39 | ||
![]() |
d80f87554c | ||
![]() |
c1d37470f6 | ||
![]() |
9c695393b2 | ||
![]() |
444024ea14 | ||
![]() |
afcd933b4c | ||
![]() |
ae0a6835bd | ||
![]() |
f2f11be8ba | ||
![]() |
e09eda9c7c | ||
![]() |
c6877a414e | ||
![]() |
a3eb91ffb1 | ||
![]() |
12708473a6 | ||
![]() |
9012f8cdb3 | ||
![]() |
e26ee09586 | ||
![]() |
7d09e51162 | ||
![]() |
18ebde6960 | ||
![]() |
b0c0e8d815 | ||
![]() |
16502d7d15 | ||
![]() |
ce05deece8 | ||
![]() |
b77e2528e7 | ||
![]() |
27f8cf6dfc | ||
![]() |
f5aa7f64bd | ||
![]() |
44254c4945 | ||
![]() |
a9ea507c6a | ||
![]() |
b137d5ec23 | ||
![]() |
4792eee5d0 | ||
![]() |
a84625eca6 | ||
![]() |
19d3fd1185 | ||
![]() |
a9be9bc7f5 | ||
![]() |
e8b99d21e5 | ||
![]() |
f6c57990ee | ||
![]() |
370d7f7527 | ||
![]() |
7d38692c4f | ||
![]() |
a997d60304 | ||
![]() |
ff8fb8cdb0 | ||
![]() |
b915ca68f9 | ||
![]() |
703fc264f0 | ||
![]() |
19d92834ed | ||
![]() |
9ade752fa7 | ||
![]() |
e8a5f3026f | ||
![]() |
2cac4a9c72 | ||
![]() |
39e939a507 | ||
![]() |
803005892c | ||
![]() |
08cfdf909e | ||
![]() |
434ce48016 | ||
![]() |
10051e6916 | ||
![]() |
d54cdf294b | ||
![]() |
2e342d5d9b | ||
![]() |
fe84071e80 | ||
![]() |
044ca343ad | ||
![]() |
f59ea9adb3 | ||
![]() |
0cec4ba6bf | ||
![]() |
14ca732a8f | ||
![]() |
53c27c7722 | ||
![]() |
c2f5b71dc9 | ||
![]() |
6403257886 | ||
![]() |
4031104404 |
423
CHANGES
423
CHANGES
@@ -6,6 +6,429 @@
|
|||||||
|
|
||||||
History of Changes
|
History of Changes
|
||||||
|
|
||||||
|
|
||||||
|
Daniel (14 March 2001)
|
||||||
|
- Bj<42>rn Stenberg provided similar fixes as J<>rn did and some additional patches
|
||||||
|
for non-SSL compiles.
|
||||||
|
|
||||||
|
- I increased the interface number for libcurl as I've removed the low level
|
||||||
|
functions from the interface. I also took this opportunity to rename the
|
||||||
|
Curl_strequal function to curl_strequal and Curl_strnequal to
|
||||||
|
curl_strnequal, as they're public libcurl functions (even if they're still
|
||||||
|
undocumented).
|
||||||
|
|
||||||
|
This will make older programs not capable of using the new libcurl with
|
||||||
|
just a drop-in replacement.
|
||||||
|
|
||||||
|
- J<>rn Hartroth updated stuff for win32 compiles:
|
||||||
|
o config-win32.h was fixed for socklen_t
|
||||||
|
o lib/ssluse.c had a bad #endif placement
|
||||||
|
o lib/file.c was made to compile on win32 again
|
||||||
|
o lib/Makefile.m32 was updated with the new files
|
||||||
|
o lib/libcurl.def matches the current interface state
|
||||||
|
|
||||||
|
Daniel (13 March 2001)
|
||||||
|
- It only took an hour or so before J<>rn Hartroth found a problem in the
|
||||||
|
chunked transfer-encoding. Given his fine example-site, I could easily spot
|
||||||
|
the problem and when I re-read the spec (the part I have pasted in the top
|
||||||
|
of the http_chunks.h file), I realized I had made my state-machine slightly
|
||||||
|
wrong and didn't expect/handle the trailing CRLF that comes after the data
|
||||||
|
in each chunk (and those extra two bytes sure feel wasted).
|
||||||
|
|
||||||
|
Had to modify test case 34 to match this as well.
|
||||||
|
|
||||||
|
Version 7.7-beta2
|
||||||
|
|
||||||
|
Daniel (13 March 2001)
|
||||||
|
- Added the policy stuff to the curl_easy_setopt man page for the two supported
|
||||||
|
policies.
|
||||||
|
|
||||||
|
- Implemented some support for the CURLOPT_CLOSEPOLICY option. The policies
|
||||||
|
CURLCLOSEPOLICY_LEAST_RECENTLY_USED and CURLCLOSEPOLICY_OLDEST are now
|
||||||
|
supported, and the "least recently used" is used as default if no policy
|
||||||
|
is chosen.
|
||||||
|
|
||||||
|
Daniel (12 March 2001)
|
||||||
|
- Added CURLOPT_RANDOM_FILE and CURLOPT_EGDSOCKET to libcurl for seeding the
|
||||||
|
SSL random engine. The random seeding support was also brought to the curl
|
||||||
|
client with the new options --random-file <file> and --egd-file <file>. I
|
||||||
|
need some people to really test this to know they work as supposed. Remember
|
||||||
|
that libcurl now informs (if verbose is on) if the random seed is considered
|
||||||
|
weak (HTTPS connections).
|
||||||
|
|
||||||
|
- Made the chunked transfer-encoding engine detected bad formatted data length
|
||||||
|
and return error if so (we can't possibly extract sensible data if this is
|
||||||
|
the case). Added a test case that detects this. Number 36. Now there are 60
|
||||||
|
test cases.
|
||||||
|
|
||||||
|
- Added 5 new libcurl options to curl/curl.h that can be used to control the
|
||||||
|
persistant connection support in libcurl. They're also documented (fairly
|
||||||
|
thoroughly) in the curl_easy_setopt.3 man page. Three of them are now
|
||||||
|
implemented, although not really tested at this point... Anyway, the new
|
||||||
|
implemented options are named CURLOPT_MAXCONNECTS, CURLOPT_FRESH_CONNECT,
|
||||||
|
CURLOPT_FORBID_REUSE. The ones still left to write code for are:
|
||||||
|
CURLOPT_CLOSEPOLICY and its related option CURLOPT_CLOSEFUNCTION.
|
||||||
|
|
||||||
|
- Made curl (the actual command line tool) use the new libcurl 7.7 persistant
|
||||||
|
connection support by re-using the same curl handle for every specified file
|
||||||
|
transfer and after some more test case tweaking we have 100% test case OK.
|
||||||
|
I made some test cases return HTTP/1.0 now to make sure that works as well.
|
||||||
|
|
||||||
|
- Had to add 'Connection: close' to the headers of a bunch of test cases so
|
||||||
|
that curl behaves "old-style" since the test http server doesn't do multiple
|
||||||
|
connections... Now I get 100% test case OK.
|
||||||
|
|
||||||
|
- The curl.haxx.se site, the main curl mailing list and my personal email are
|
||||||
|
all dead today due to power blackout in the area where the main servers are
|
||||||
|
located. Horrible.
|
||||||
|
|
||||||
|
- I've made persistance work over a squid HTTP proxy. I find it disturbing
|
||||||
|
that it uses headers that aren't present in any HTTP standard though
|
||||||
|
(Proxy-Connection:) and that makes me feel that I'm now on the edge of what
|
||||||
|
the standard actually defines. I need to get this code excercised on a lot
|
||||||
|
of different HTTP proxies before I feel safe.
|
||||||
|
|
||||||
|
Now I'm facing the problem with my test suite servers (both FTP and HTTP)
|
||||||
|
not supporting persistant connections and libcurl is doing them now. I have
|
||||||
|
to fix the test servers to get all the test cases do OK.
|
||||||
|
|
||||||
|
Daniel (8 March 2001)
|
||||||
|
- Guenole Bescon reported that libcurl did output errors to stderr even if
|
||||||
|
MUTE and NOPROGRESS was set. It turned out to be a bug and happens if
|
||||||
|
there's an error and no ERRORBUFFER is set. This is now corrected.
|
||||||
|
|
||||||
|
Version 7.7-beta1
|
||||||
|
|
||||||
|
Daniel (8 March 2001)
|
||||||
|
- "Transfer-Encoding: chunked" is no longer any trouble for libcurl. I've
|
||||||
|
added two source files and I've run some test downloads that look fine.
|
||||||
|
|
||||||
|
- HTTP HEAD works too, even on 1.1 servers.
|
||||||
|
|
||||||
|
Daniel (5 March 2001)
|
||||||
|
- The current 57 test cases now pass OK. It would suggest that libcurl works
|
||||||
|
using the old-style with one connection per handle. The test suite doesn't
|
||||||
|
handle multiple connections yet so there are no test cases for this.
|
||||||
|
|
||||||
|
- I patched the telnet.c heavily to not use any global variables anymore. It
|
||||||
|
should make it a lot nicer library-wise.
|
||||||
|
|
||||||
|
- The file:// support was modified slightly to use the internal connect-first-
|
||||||
|
then-do approach.
|
||||||
|
|
||||||
|
Daniel (4 March 2001)
|
||||||
|
- More bugs erased.
|
||||||
|
|
||||||
|
Version 7.7-alpha2
|
||||||
|
|
||||||
|
Daniel (4 March 2001)
|
||||||
|
- Now, there's even a basic check that a re-used connection is still alive
|
||||||
|
before it is assumed so. A few first tests have proven that libcurl will
|
||||||
|
then re-connect instead of re-use the dead connection!
|
||||||
|
|
||||||
|
Daniel (2 March 2001)
|
||||||
|
- Now they work intermixed as well. Major coolness!
|
||||||
|
|
||||||
|
- More fiddling around, my 'tiny' client I have for testing purposes now has
|
||||||
|
proved to download both FTP and HTTP with persistant connections. They do
|
||||||
|
not work intermixed yet though.
|
||||||
|
|
||||||
|
Daniel (1 March 2001)
|
||||||
|
- Wilfredo Sanchez pointed out a minor spelling mistake in a man page and that
|
||||||
|
curl_slist_append() should take a const char * as second argument. It does
|
||||||
|
now.
|
||||||
|
|
||||||
|
Daniel (22 February 2001)
|
||||||
|
- The persistant connections start to look good for HTTP. On a subsequent
|
||||||
|
request, it seems that libcurl now can pick an already existing connection
|
||||||
|
if a suitable one exists, or it opens a new one.
|
||||||
|
|
||||||
|
- Douglas R. Horner mailed me corrections to the curl_formparse() man page
|
||||||
|
that I applied.
|
||||||
|
|
||||||
|
Daniel (20 February 2001)
|
||||||
|
- Added the docs/examples/win32sockets.c file for our windows friends.
|
||||||
|
|
||||||
|
- Linus Nielsen Feltzing provided brand new TELNET functionality and
|
||||||
|
improvements:
|
||||||
|
|
||||||
|
* Negotiation is now passive. Curl does not negotiate until the peer does.
|
||||||
|
* Possibility to set negotiation options on the command line, currently only
|
||||||
|
XDISPLOC, TTYPE and NEW_ENVIRON (called NEW_ENV).
|
||||||
|
* Now sends the USER environment variable if the -u switch is used.
|
||||||
|
* Use -t to set telnet options (Linus even updated the man page, awesome!)
|
||||||
|
|
||||||
|
- Haven't done this big changes to curl for a while. Moved around a lot of
|
||||||
|
struct fields and stuff to make multiple connections get connection specific
|
||||||
|
data in separate structs so that they can co-exist in a nice way. See the
|
||||||
|
mailing lists for discussions around how this is gonna be implemented. Docs
|
||||||
|
and more will follow.
|
||||||
|
|
||||||
|
Studied the HTTP RFC to find out better how persistant connections should
|
||||||
|
work. Seems cool enough.
|
||||||
|
|
||||||
|
Daniel (19 February 2001)
|
||||||
|
- Bob Schader brought me two files that help set up a MS VC++ libcurl project
|
||||||
|
easier. He also provided me with an up-to-date libcurl.def file.
|
||||||
|
|
||||||
|
- I moved a bunch of prototypes from the public <curl/curl.h> file to the
|
||||||
|
library private urldata.h. This is because of the upcoming changes. The
|
||||||
|
low level interface is no longer being planned to become reality.
|
||||||
|
|
||||||
|
Daniel (15 February 2001)
|
||||||
|
- CURLOPT_POST is not required anymore. Just setting the POST string with
|
||||||
|
CURLOPT_POSTFIELDS will switch on the HTTP POST. Most other things in
|
||||||
|
libcurl already works this way, i.e they require only the parameter to
|
||||||
|
switch on a feature so I think this works well with the rest. Setting a NULL
|
||||||
|
string switches off the POST again.
|
||||||
|
|
||||||
|
- Excellent suggestions from Rich Gray, Rick Jones, Johan Nilsson and Bjorn
|
||||||
|
Reese helped me define a way how to incorporate persistant connections into
|
||||||
|
libcurl in a very smooth way. If done right, no change may have to be made
|
||||||
|
to older programs and they will just start using persistant connections when
|
||||||
|
applicable!
|
||||||
|
|
||||||
|
Daniel (13 February 2001)
|
||||||
|
- Changed the word 'timeouted' to 'timed out' in two different error messages.
|
||||||
|
Suggested by Larry Fahnoe.
|
||||||
|
|
||||||
|
Version 7.6.1
|
||||||
|
|
||||||
|
Daniel (9 February 2001)
|
||||||
|
- Frank Reid and Cain Hopwood provided information and research around a HTTPS
|
||||||
|
PUT/upload problem we seem to have. No solution found yet.
|
||||||
|
|
||||||
|
Daniel (8 February 2001)
|
||||||
|
- An interesting discussion is how to specify an empty password without having
|
||||||
|
curl ask for it interactively? The current implmentation takes an empty
|
||||||
|
password as a request for a password prompt. However, I still want to
|
||||||
|
support a blank user field. Thus, today if you enter "-u :" (without user
|
||||||
|
and password) curl will prompt for the password. Tricky. How would you
|
||||||
|
specify you want the prompt otherwise?
|
||||||
|
|
||||||
|
- Made the netrc parse result possible to use for other protocols than FTP and
|
||||||
|
HTTP (such as the upcoming TELNET fixes).
|
||||||
|
|
||||||
|
- The previously mentioned "MSVC++ problems" turned out to be a non-issue.
|
||||||
|
|
||||||
|
- Added a HTTP file upload code example in the docs/examples/ section on
|
||||||
|
request.
|
||||||
|
|
||||||
|
- Adjusted the FTP response fix slightly.
|
||||||
|
|
||||||
|
Version 7.6.1-pre3
|
||||||
|
|
||||||
|
Daniel (7 February 2001)
|
||||||
|
- SM found a flaw in the response reading function for FTP that could make
|
||||||
|
libcurl not get out of the loop properly when it should, if libcurl got -1
|
||||||
|
returned when reading the socket.
|
||||||
|
|
||||||
|
- I found a similar mistake in http.c when using a proxy and reading the
|
||||||
|
results from the proxy connection.
|
||||||
|
|
||||||
|
Daniel (6 February 2001)
|
||||||
|
- A friendly person named "SM" (nntp at iname.com) pointed out that the VC
|
||||||
|
makefile in src/ needed the libpath set for the debug build to work.
|
||||||
|
|
||||||
|
- Daniel Gehriger stepped in to assist with the VC++ stuff Robert Weaver
|
||||||
|
brought up yesterday.
|
||||||
|
|
||||||
|
Daniel (5 February 2001)
|
||||||
|
- Jun-ichiro itojun Hagino brought a big patch that brings IPv6-awareness to
|
||||||
|
a bunch of different areas within libcurl.
|
||||||
|
|
||||||
|
- Robert Weaver told me about the problems the MS VC++ 6.0 compiler has with
|
||||||
|
the 'static' keyword on a number of libcurl functions. I might need to add a
|
||||||
|
patch that redefines static when libcurl is compiled with that compiler.
|
||||||
|
How do I know when VC++ compiles, anyone?
|
||||||
|
|
||||||
|
Daniel (4 February 2001)
|
||||||
|
- curl_getinfo() was extended with two new options:
|
||||||
|
CURLINFO_CONTENT_LENGTH_DOWNLOAD and CURLINFO_CONTENT_LENGTH_UPLOAD. They
|
||||||
|
return the full assumed content length of the transfer in the given
|
||||||
|
direction. The CURLINFO_CONTENT_LENGTH_DOWNLOAD will be the Content-Length:
|
||||||
|
size of a HTTP download. Added descriptions to the man page as well. This
|
||||||
|
was done after discussions with Bob Schader.
|
||||||
|
|
||||||
|
Daniel (3 February 2001)
|
||||||
|
- Ingo Ralf Blum provided another fix that makes curl build under the more
|
||||||
|
recent cygwin installations. It seems they've changed the preset defines to
|
||||||
|
not include WIN32 anymore.
|
||||||
|
|
||||||
|
Version 7.6.1-pre2
|
||||||
|
|
||||||
|
Daniel (31 January 2001)
|
||||||
|
- Curl_read() and curl_read() now return a ssize_t for the size, as it had to
|
||||||
|
be able to return -1. The telnet support crashed due to this and there was a
|
||||||
|
possibility to weird behaviour all over. Linus Nielsen Feltzing helped me
|
||||||
|
find this.
|
||||||
|
|
||||||
|
- Added a configure.in check for a working getaddrinfo() if IPv6 is requested.
|
||||||
|
I also made the configure script feature --enable-debug which sets a couple
|
||||||
|
of compiler options when used. It assumes gcc.
|
||||||
|
|
||||||
|
Daniel (30 January 2001)
|
||||||
|
- I finally took a stab at the long-term FIXME item I've had on myself, and
|
||||||
|
now libcurl will properly work when doing a HTTP range-request that follows
|
||||||
|
a Location:. Previously that would make libcurl fail saying that the server
|
||||||
|
doesn't seem to support range requests.
|
||||||
|
|
||||||
|
Daniel (29 January 2001)
|
||||||
|
- I added a test case for the HTTP PUT resume thing (test case 33).
|
||||||
|
|
||||||
|
Version 7.6.1-pre1
|
||||||
|
|
||||||
|
Daniel (29 January 2001)
|
||||||
|
- Yet another Content-Range change. Ok now? Bob Schader checks from his end
|
||||||
|
and it works for him.
|
||||||
|
|
||||||
|
Daniel (27 January 2001)
|
||||||
|
- So the HTTP PUT resume fix wasn't good. There should appearantly be a
|
||||||
|
Content-Range header when resuming a PUT.
|
||||||
|
|
||||||
|
- I noticed I broke the download-check that verifies that a resumed HTTP
|
||||||
|
download is actually resumed. It got broke because my new 'httpreq' field
|
||||||
|
in the main curl struct. I should get slapped. I added a test case for
|
||||||
|
this now, so I won't be able to ruin this again without noticing.
|
||||||
|
|
||||||
|
- Added a test case for content-length verifying when downloading HTTP.
|
||||||
|
|
||||||
|
- Made the progress meter title say if the transfer is being transfered. It
|
||||||
|
makes the output slightly better for resumes.
|
||||||
|
|
||||||
|
- When dealing with Location: and HTTP return codes, libcurl will not attempt
|
||||||
|
to follow the spirit of RFC2616 better. It means that when POSTing to a
|
||||||
|
URL that is being following to a second place, the standard will judge on
|
||||||
|
what to do. All HTTP codes except 303 and 305 will cause curl to make a
|
||||||
|
second POST operation. 303 will make a GET and 305 is not yet supported.
|
||||||
|
|
||||||
|
I also wrote two test cases for this POST/GET/Location stuff.
|
||||||
|
|
||||||
|
Version 7.6
|
||||||
|
|
||||||
|
Daniel (26 January 2001)
|
||||||
|
- Lots of mails back and forth with Bob Schader finally made me add a small
|
||||||
|
piece of code in the HTTP engine so that HTTP upload resume works. You can
|
||||||
|
now do an operation like 'curl -T file -C <offset> <URL>' and curl will PUT
|
||||||
|
the ending part of the file starting at given offet to the specified URL.
|
||||||
|
|
||||||
|
Version 7.6-pre4
|
||||||
|
|
||||||
|
Daniel (25 January 2001)
|
||||||
|
- I took hold of Rick Jones' question why we don't use recv() and send() for
|
||||||
|
reading/writing to the sockets and I've now modified the sread() and
|
||||||
|
swrite() macros to use them instead. If nothing else, they could be tested
|
||||||
|
in the next beta-round coming right up.
|
||||||
|
|
||||||
|
- Jeff Morrow found a problem with libcurl's usage of SSL_read() and supplied
|
||||||
|
his research results in how to fix this. It turns out we have to invoke the
|
||||||
|
function several times in some cases. The same goes for the SSL_write().
|
||||||
|
|
||||||
|
I made some rather drastic changes all over libcurl to make all writes and
|
||||||
|
reads get done on one single place so that this repeated-attempts thing
|
||||||
|
would only have to be implemented at one point.
|
||||||
|
|
||||||
|
- Rick Jones spotted that the 'total time' counter really didn't measure the
|
||||||
|
total time very accurate on subsecond levels.
|
||||||
|
|
||||||
|
- Johan Nilsson pointed out the need to more clearly specify that the timeout
|
||||||
|
value you set for a download is for the *entire* download. There's currently
|
||||||
|
no option available that sets a timeout for the connection phase only.
|
||||||
|
|
||||||
|
Daniel (24 January 2001)
|
||||||
|
- Ingo Ralf Blum submitted a series of patches required to get curl to compile
|
||||||
|
properly with cygwin.
|
||||||
|
|
||||||
|
- Robert Weaver posted a fix for the win32 section of the curl_getenv() code
|
||||||
|
that corrected a potential memory leak.
|
||||||
|
|
||||||
|
- Added comments in a few files in a sudden attempt to make the sources more
|
||||||
|
easy to read and understand!
|
||||||
|
|
||||||
|
Daniel (23 January 2001)
|
||||||
|
- Added simple IPv6 detection in the configure script and made the version
|
||||||
|
string add 'ipv6' to the enable section in that case. ENABLE_IPV6 will be
|
||||||
|
set if curl is compiled with IPv6 support enabled.
|
||||||
|
|
||||||
|
- Added a parser for IPv6-style specified IP-addresses in a URL. Thus, when
|
||||||
|
IPv6 gets enabled soon, we can use URLs like '[0::1]:80'...
|
||||||
|
|
||||||
|
- Made the URL globbing in the client possible to fail silently if there's an
|
||||||
|
error in the globbing. It makes it almost intuitive, so when you don't
|
||||||
|
follow the syntax rules, globbing is simply switched off and the raw string
|
||||||
|
is used instead.
|
||||||
|
|
||||||
|
I still think we'll get problems with IPv6-style IP-addresses when we *want*
|
||||||
|
globbing on parts of the URL as the initial part of the URL will for sure
|
||||||
|
seriously confuse the globber.
|
||||||
|
|
||||||
|
Daniel (22 January 2001)
|
||||||
|
- Bj<42>rn Stenberg supplied a progress meter patch that makes it look better even
|
||||||
|
during slow starts. Previously it made some silly assumptions...
|
||||||
|
|
||||||
|
- Added two FTP tests for -Q and -Q - stuff since it was being discussed on
|
||||||
|
the mailing list. Had to correct the ftpserver.pl too as it bugged slightly.
|
||||||
|
|
||||||
|
Daniel (19 January 2001)
|
||||||
|
- Made the Location: parsers deal with any-length URLs. Thus I removed the last
|
||||||
|
code that restricts the length of URLs that curl supports.
|
||||||
|
|
||||||
|
- Added a --globoff test case (#28) and it quickly identified a memory problem
|
||||||
|
in src/main.c that I took care of.
|
||||||
|
|
||||||
|
Version 7.6-pre3
|
||||||
|
|
||||||
|
Daniel (17 January 2001)
|
||||||
|
- Made the two former files lib/download.c and lib/highlevel.c become the new
|
||||||
|
lib/transfer.c which makes more sense. I also did the rename from Transfer()
|
||||||
|
to Curl_Transfer() in the other source files that use the transfer function
|
||||||
|
in the spirit of using Curl_ prefix for library-scoped global symbols.
|
||||||
|
|
||||||
|
Daniel (11 January 2001)
|
||||||
|
- Added -g/--globoff that switches OFF the URL globbing and thus enables {}[]
|
||||||
|
letters to be part of the URL. Do note that RFC2396 section 2.4.3 explicitly
|
||||||
|
mention these letters to be escaped. This was posted as a feature request by
|
||||||
|
Jorge Gutierrez and as a bug by Terry.
|
||||||
|
|
||||||
|
- Short options to curl that requires parameters can now be specified without
|
||||||
|
having the option and its parameter space separated. -ofile works as good as
|
||||||
|
-o file. -m20 is equal to -m 20. Do note that this goes for single-letter
|
||||||
|
options only, verbose --long-style options still must be separated with
|
||||||
|
space from their parameters.
|
||||||
|
|
||||||
|
Daniel (8 January 2001)
|
||||||
|
- Francis Dagenais reported that the SCO compiler still fails when compiling
|
||||||
|
curl due to that getpass_r() prototype. I've now put it around #ifndef
|
||||||
|
HAVE_GETPASS_R in an attempt to please the SCO systems.
|
||||||
|
|
||||||
|
- Made some minor corrections to get the client to cleanup properly and I made
|
||||||
|
the separator work again when getting multiple globbed URLs to stdout.
|
||||||
|
|
||||||
|
- Worked with Loic Dachary to get the make dist and make distcheck work
|
||||||
|
correctly. The 'maketgz' script is now using the automake generated 'make
|
||||||
|
dist' when creating release archives. Loic successfully made 'make rpms'
|
||||||
|
automatically build RPMs!
|
||||||
|
|
||||||
|
Loic Dachary (6 January 2001)
|
||||||
|
- Automated generation of rpm packages, no need to be root.
|
||||||
|
|
||||||
|
- make distcheck generates a proper distribution (EXTRA_DIST
|
||||||
|
in all Makefile.am modified to match FILES).
|
||||||
|
|
||||||
|
Daniel (5 January 2001)
|
||||||
|
- Huge client-side hack: now multiple URLs are supported. Any number of URLs
|
||||||
|
can be specified on the command line, and they'll all be downloaded. There
|
||||||
|
must be a corresponding -o or -O for each URL or the data will be written to
|
||||||
|
stdout. This needs more testing, time to release a 7.6-pre package.
|
||||||
|
|
||||||
|
- The krb4 support was broken in the release. Fixed now.
|
||||||
|
|
||||||
|
- Huge internal symbol rename operation. All non-static but still lib-internal
|
||||||
|
symbols should now be prefixed with 'Curl_' to prevent collisions with other
|
||||||
|
libs. All public symbols should be prefixed with 'curl_' and the rest should
|
||||||
|
be static and thus invisible to the outside world. I updated the INTERNALS
|
||||||
|
document to say this as well.
|
||||||
|
|
||||||
Version 7.5.2
|
Version 7.5.2
|
||||||
|
|
||||||
Daniel (4 January 2001)
|
Daniel (4 January 2001)
|
||||||
|
10
CVS-INFO
10
CVS-INFO
@@ -14,7 +14,9 @@ perl/ is a subdirectory with various perl scripts
|
|||||||
|
|
||||||
To build after having extracted everything from CVS, do this:
|
To build after having extracted everything from CVS, do this:
|
||||||
|
|
||||||
% automake
|
automake
|
||||||
% autoconf
|
aclocal
|
||||||
% ./configure
|
autoheader
|
||||||
% make
|
autoconf
|
||||||
|
./configure
|
||||||
|
make
|
||||||
|
86
FILES
86
FILES
@@ -1,86 +0,0 @@
|
|||||||
CHANGES
|
|
||||||
FILES
|
|
||||||
LEGAL
|
|
||||||
MPL-1.1.txt
|
|
||||||
MITX.txt
|
|
||||||
README
|
|
||||||
docs/BUGS
|
|
||||||
docs/CONTRIBUTE
|
|
||||||
docs/FAQ
|
|
||||||
docs/FEATURES
|
|
||||||
docs/INSTALL
|
|
||||||
docs/INTERNALS
|
|
||||||
docs/MANUAL
|
|
||||||
docs/README.win32
|
|
||||||
docs/LIBCURL
|
|
||||||
docs/RESOURCES
|
|
||||||
docs/TODO
|
|
||||||
docs/curl.1
|
|
||||||
docs/Makefile.in
|
|
||||||
docs/Makefile.am
|
|
||||||
docs/TheArtOfHttpScripting
|
|
||||||
docs/*.3
|
|
||||||
docs/examples/README
|
|
||||||
docs/examples/*.c
|
|
||||||
maketgz
|
|
||||||
Makefile.in
|
|
||||||
Makefile.am
|
|
||||||
acconfig.h
|
|
||||||
acinclude.m4
|
|
||||||
aclocal.m4
|
|
||||||
config.guess
|
|
||||||
config.h.in
|
|
||||||
config-win32.h
|
|
||||||
config.sub
|
|
||||||
configure
|
|
||||||
configure.in
|
|
||||||
install-sh
|
|
||||||
missing
|
|
||||||
mkinstalldirs
|
|
||||||
reconf
|
|
||||||
stamp-h.in
|
|
||||||
ltconfig
|
|
||||||
ltmain.sh
|
|
||||||
src/config-win32.h
|
|
||||||
src/hugehelp.c
|
|
||||||
src/main.c
|
|
||||||
src/setup.h
|
|
||||||
src/urlglob.c
|
|
||||||
src/urlglob.h
|
|
||||||
src/version.h
|
|
||||||
src/writeout.c
|
|
||||||
src/writeout.h
|
|
||||||
src/*.in
|
|
||||||
src/*.am
|
|
||||||
src/mkhelp.pl
|
|
||||||
src/Makefile.vc6
|
|
||||||
src/Makefile.b32
|
|
||||||
src/*m32
|
|
||||||
lib/getdate.y
|
|
||||||
lib/*.[ch]
|
|
||||||
lib/*in
|
|
||||||
lib/*am
|
|
||||||
lib/Makefile.vc6
|
|
||||||
lib/*m32
|
|
||||||
lib/Makefile.b32
|
|
||||||
lib/Makefile.b32.resp
|
|
||||||
lib/libcurl.def
|
|
||||||
include/README
|
|
||||||
include/Makefile.in
|
|
||||||
include/Makefile.am
|
|
||||||
include/curl/*.h
|
|
||||||
include/curl/Makefile.in
|
|
||||||
include/curl/Makefile.am
|
|
||||||
packages/Linux/RPM/curl-ssl.spec
|
|
||||||
packages/Linux/RPM/curl.spec
|
|
||||||
packages/Linux/RPM/make_curl_rpm
|
|
||||||
packages/Linux/RPM/README
|
|
||||||
packages/Win32/README
|
|
||||||
packages/README
|
|
||||||
tests/Makefile.am
|
|
||||||
tests/Makefile.in
|
|
||||||
tests/runtests.pl
|
|
||||||
tests/README
|
|
||||||
tests/httpserver.pl
|
|
||||||
tests/ftpserver.pl
|
|
||||||
tests/data/*.txt
|
|
39
Makefile.am
39
Makefile.am
@@ -4,9 +4,44 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
EXTRA_DIST = curl.spec curl-ssl.spec
|
EXTRA_DIST = \
|
||||||
|
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
||||||
|
config-win32.h reconf packages/README Makefile.dist
|
||||||
|
|
||||||
SUBDIRS = docs lib src include tests
|
SUBDIRS = docs lib src include tests packages
|
||||||
|
|
||||||
|
# create a root makefile in the distribution:
|
||||||
|
dist-hook:
|
||||||
|
cp $(srcdir)/Makefile.dist $(distdir)/Makefile
|
||||||
|
|
||||||
|
check: test
|
||||||
|
|
||||||
test:
|
test:
|
||||||
@(cd tests; make quiet-test)
|
@(cd tests; make quiet-test)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros
|
||||||
|
# must contain the following line:
|
||||||
|
# %_topdir /home/loic/local/rpm
|
||||||
|
# and that /home/loic/local/rpm contains the directory SOURCES, BUILD etc.
|
||||||
|
#
|
||||||
|
# cd /home/loic/local/rpm ; mkdir -p SOURCES BUILD RPMS/i386 SPECS SRPMS
|
||||||
|
#
|
||||||
|
# If additional configure flags are needed to build the package, add the
|
||||||
|
# following in ~/.rpmmacros
|
||||||
|
# %configure CFLAGS="%{optflags}" ./configure %{_target_platform} --prefix=%{_prefix} ${AM_CONFIGFLAGS}
|
||||||
|
# and run make rpm in the following way:
|
||||||
|
# AM_CONFIGFLAGS='--with-uri=/home/users/loic/local/RedHat-6.2' make rpm
|
||||||
|
#
|
||||||
|
|
||||||
|
rpms:
|
||||||
|
$(MAKE) RPMDIST=curl rpm
|
||||||
|
$(MAKE) RPMDIST=curl-ssl rpm
|
||||||
|
|
||||||
|
rpm:
|
||||||
|
RPM_TOPDIR=`rpm --showrc | $(PERL) -n -e 'print if(s/.*_topdir\s+(.*)/$$1/)'` ; \
|
||||||
|
cp $(srcdir)/packages/Linux/RPM/$(RPMDIST).spec $$RPM_TOPDIR/SPECS ; \
|
||||||
|
cp $(PACKAGE)-$(VERSION).tar.gz $$RPM_TOPDIR/SOURCES ; \
|
||||||
|
rpm -ba --clean --rmsource $$RPM_TOPDIR/SPECS/$(RPMDIST).spec ; \
|
||||||
|
mv $$RPM_TOPDIR/RPMS/i386/$(RPMDIST)-*.rpm . ; \
|
||||||
|
mv $$RPM_TOPDIR/SRPMS/$(RPMDIST)-*.src.rpm .
|
||||||
|
15
acconfig.h
15
acconfig.h
@@ -36,3 +36,18 @@
|
|||||||
|
|
||||||
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
||||||
#undef KRB4
|
#undef KRB4
|
||||||
|
|
||||||
|
/* Define if you want to enable IPv6 support */
|
||||||
|
#undef ENABLE_IPV6
|
||||||
|
|
||||||
|
/* Define this to 'int' if ssize_t is not an available typedefed type */
|
||||||
|
#undef ssize_t
|
||||||
|
|
||||||
|
/* Define this to 'int' if socklen_t is not an available typedefed type */
|
||||||
|
#undef socklen_t
|
||||||
|
|
||||||
|
/* Define this as a suitable file to read random data from */
|
||||||
|
#undef RANDOM_FILE
|
||||||
|
|
||||||
|
/* Define this to your Entropy Gathering Daemon socket pathname */
|
||||||
|
#undef EGD_SOCKET
|
||||||
|
616
aclocal.m4
vendored
616
aclocal.m4
vendored
@@ -1,616 +0,0 @@
|
|||||||
dnl aclocal.m4 generated automatically by aclocal 1.4
|
|
||||||
|
|
||||||
dnl Copyright (C) 1994, 1995-8, 1999 Free Software Foundation, Inc.
|
|
||||||
dnl This file is free software; the Free Software Foundation
|
|
||||||
dnl gives unlimited permission to copy and/or distribute it,
|
|
||||||
dnl with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
dnl This program is distributed in the hope that it will be useful,
|
|
||||||
dnl but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
dnl even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
dnl PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
#serial 12
|
|
||||||
|
|
||||||
dnl By default, many hosts won't let programs access large files;
|
|
||||||
dnl one must use special compiler options to get large-file access to work.
|
|
||||||
dnl For more details about this brain damage please see:
|
|
||||||
dnl http://www.sas.com/standards/large.file/x_open.20Mar96.html
|
|
||||||
|
|
||||||
dnl Written by Paul Eggert <eggert@twinsun.com>.
|
|
||||||
|
|
||||||
dnl Internal subroutine of AC_SYS_LARGEFILE.
|
|
||||||
dnl AC_SYS_LARGEFILE_TEST_INCLUDES
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE_TEST_INCLUDES,
|
|
||||||
[[#include <sys/types.h>
|
|
||||||
int a[(off_t) 9223372036854775807 == 9223372036854775807 ? 1 : -1];
|
|
||||||
]])
|
|
||||||
|
|
||||||
dnl Internal subroutine of AC_SYS_LARGEFILE.
|
|
||||||
dnl AC_SYS_LARGEFILE_MACRO_VALUE(C-MACRO, VALUE, CACHE-VAR, COMMENT, INCLUDES, FUNCTION-BODY)
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE_MACRO_VALUE,
|
|
||||||
[AC_CACHE_CHECK([for $1 value needed for large files], $3,
|
|
||||||
[$3=no
|
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES
|
|
||||||
$5
|
|
||||||
,
|
|
||||||
[$6],
|
|
||||||
,
|
|
||||||
[AC_TRY_COMPILE([#define $1 $2]
|
|
||||||
AC_SYS_LARGEFILE_TEST_INCLUDES
|
|
||||||
$5
|
|
||||||
,
|
|
||||||
[$6],
|
|
||||||
[$3=$2])])])
|
|
||||||
if test "[$]$3" != no; then
|
|
||||||
AC_DEFINE_UNQUOTED([$1], [$]$3, [$4])
|
|
||||||
fi])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_SYS_LARGEFILE,
|
|
||||||
[AC_ARG_ENABLE(largefile,
|
|
||||||
[ --disable-largefile omit support for large files])
|
|
||||||
if test "$enable_largefile" != no; then
|
|
||||||
|
|
||||||
AC_CACHE_CHECK([for special C compiler options needed for large files],
|
|
||||||
ac_cv_sys_largefile_CC,
|
|
||||||
[ac_cv_sys_largefile_CC=no
|
|
||||||
if test "$GCC" != yes; then
|
|
||||||
# IRIX 6.2 and later do not support large files by default,
|
|
||||||
# so use the C compiler's -n32 option if that helps.
|
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES, , ,
|
|
||||||
[ac_save_CC="$CC"
|
|
||||||
CC="$CC -n32"
|
|
||||||
AC_TRY_COMPILE(AC_SYS_LARGEFILE_TEST_INCLUDES, ,
|
|
||||||
ac_cv_sys_largefile_CC=' -n32')
|
|
||||||
CC="$ac_save_CC"])
|
|
||||||
fi])
|
|
||||||
if test "$ac_cv_sys_largefile_CC" != no; then
|
|
||||||
CC="$CC$ac_cv_sys_largefile_CC"
|
|
||||||
fi
|
|
||||||
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_FILE_OFFSET_BITS, 64,
|
|
||||||
ac_cv_sys_file_offset_bits,
|
|
||||||
[Number of bits in a file offset, on hosts where this is settable.])
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_LARGEFILE_SOURCE, 1,
|
|
||||||
ac_cv_sys_largefile_source,
|
|
||||||
[Define to make ftello visible on some hosts (e.g. HP-UX 10.20).],
|
|
||||||
[#include <stdio.h>], [return !ftello;])
|
|
||||||
AC_SYS_LARGEFILE_MACRO_VALUE(_LARGE_FILES, 1,
|
|
||||||
ac_cv_sys_large_files,
|
|
||||||
[Define for large files, on AIX-style hosts.])
|
|
||||||
dnl lftp does not need ftello, and _XOPEN_SOURCE=500 makes resolv.h fail.
|
|
||||||
dnl AC_SYS_LARGEFILE_MACRO_VALUE(_XOPEN_SOURCE, 500,
|
|
||||||
dnl ac_cv_sys_xopen_source,
|
|
||||||
dnl [Define to make ftello visible on some hosts (e.g. glibc 2.1.3).],
|
|
||||||
dnl [#include <stdio.h>], [return !ftello;])
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
# Like AC_CONFIG_HEADER, but automatically create stamp file.
|
|
||||||
|
|
||||||
AC_DEFUN(AM_CONFIG_HEADER,
|
|
||||||
[AC_PREREQ([2.12])
|
|
||||||
AC_CONFIG_HEADER([$1])
|
|
||||||
dnl When config.status generates a header, we must update the stamp-h file.
|
|
||||||
dnl This file resides in the same directory as the config header
|
|
||||||
dnl that is generated. We must strip everything past the first ":",
|
|
||||||
dnl and everything past the last "/".
|
|
||||||
AC_OUTPUT_COMMANDS(changequote(<<,>>)dnl
|
|
||||||
ifelse(patsubst(<<$1>>, <<[^ ]>>, <<>>), <<>>,
|
|
||||||
<<test -z "<<$>>CONFIG_HEADERS" || echo timestamp > patsubst(<<$1>>, <<^\([^:]*/\)?.*>>, <<\1>>)stamp-h<<>>dnl>>,
|
|
||||||
<<am_indx=1
|
|
||||||
for am_file in <<$1>>; do
|
|
||||||
case " <<$>>CONFIG_HEADERS " in
|
|
||||||
*" <<$>>am_file "*<<)>>
|
|
||||||
echo timestamp > `echo <<$>>am_file | sed -e 's%:.*%%' -e 's%[^/]*$%%'`stamp-h$am_indx
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
am_indx=`expr "<<$>>am_indx" + 1`
|
|
||||||
done<<>>dnl>>)
|
|
||||||
changequote([,]))])
|
|
||||||
|
|
||||||
# Do all the work for Automake. This macro actually does too much --
|
|
||||||
# some checks are only needed if your package does certain things.
|
|
||||||
# But this isn't really a big deal.
|
|
||||||
|
|
||||||
# serial 1
|
|
||||||
|
|
||||||
dnl Usage:
|
|
||||||
dnl AM_INIT_AUTOMAKE(package,version, [no-define])
|
|
||||||
|
|
||||||
AC_DEFUN(AM_INIT_AUTOMAKE,
|
|
||||||
[AC_REQUIRE([AC_PROG_INSTALL])
|
|
||||||
PACKAGE=[$1]
|
|
||||||
AC_SUBST(PACKAGE)
|
|
||||||
VERSION=[$2]
|
|
||||||
AC_SUBST(VERSION)
|
|
||||||
dnl test to see if srcdir already configured
|
|
||||||
if test "`cd $srcdir && pwd`" != "`pwd`" && test -f $srcdir/config.status; then
|
|
||||||
AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
|
|
||||||
fi
|
|
||||||
ifelse([$3],,
|
|
||||||
AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
|
|
||||||
AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package]))
|
|
||||||
AC_REQUIRE([AM_SANITY_CHECK])
|
|
||||||
AC_REQUIRE([AC_ARG_PROGRAM])
|
|
||||||
dnl FIXME This is truly gross.
|
|
||||||
missing_dir=`cd $ac_aux_dir && pwd`
|
|
||||||
AM_MISSING_PROG(ACLOCAL, aclocal, $missing_dir)
|
|
||||||
AM_MISSING_PROG(AUTOCONF, autoconf, $missing_dir)
|
|
||||||
AM_MISSING_PROG(AUTOMAKE, automake, $missing_dir)
|
|
||||||
AM_MISSING_PROG(AUTOHEADER, autoheader, $missing_dir)
|
|
||||||
AM_MISSING_PROG(MAKEINFO, makeinfo, $missing_dir)
|
|
||||||
AC_REQUIRE([AC_PROG_MAKE_SET])])
|
|
||||||
|
|
||||||
#
|
|
||||||
# Check to make sure that the build environment is sane.
|
|
||||||
#
|
|
||||||
|
|
||||||
AC_DEFUN(AM_SANITY_CHECK,
|
|
||||||
[AC_MSG_CHECKING([whether build environment is sane])
|
|
||||||
# Just in case
|
|
||||||
sleep 1
|
|
||||||
echo timestamp > conftestfile
|
|
||||||
# Do `set' in a subshell so we don't clobber the current shell's
|
|
||||||
# arguments. Must try -L first in case configure is actually a
|
|
||||||
# symlink; some systems play weird games with the mod time of symlinks
|
|
||||||
# (eg FreeBSD returns the mod time of the symlink's containing
|
|
||||||
# directory).
|
|
||||||
if (
|
|
||||||
set X `ls -Lt $srcdir/configure conftestfile 2> /dev/null`
|
|
||||||
if test "[$]*" = "X"; then
|
|
||||||
# -L didn't work.
|
|
||||||
set X `ls -t $srcdir/configure conftestfile`
|
|
||||||
fi
|
|
||||||
if test "[$]*" != "X $srcdir/configure conftestfile" \
|
|
||||||
&& test "[$]*" != "X conftestfile $srcdir/configure"; then
|
|
||||||
|
|
||||||
# If neither matched, then we have a broken ls. This can happen
|
|
||||||
# if, for instance, CONFIG_SHELL is bash and it inherits a
|
|
||||||
# broken ls alias from the environment. This has actually
|
|
||||||
# happened. Such a system could not be considered "sane".
|
|
||||||
AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
|
|
||||||
alias in your environment])
|
|
||||||
fi
|
|
||||||
|
|
||||||
test "[$]2" = conftestfile
|
|
||||||
)
|
|
||||||
then
|
|
||||||
# Ok.
|
|
||||||
:
|
|
||||||
else
|
|
||||||
AC_MSG_ERROR([newly created file is older than distributed files!
|
|
||||||
Check your system clock])
|
|
||||||
fi
|
|
||||||
rm -f conftest*
|
|
||||||
AC_MSG_RESULT(yes)])
|
|
||||||
|
|
||||||
dnl AM_MISSING_PROG(NAME, PROGRAM, DIRECTORY)
|
|
||||||
dnl The program must properly implement --version.
|
|
||||||
AC_DEFUN(AM_MISSING_PROG,
|
|
||||||
[AC_MSG_CHECKING(for working $2)
|
|
||||||
# Run test in a subshell; some versions of sh will print an error if
|
|
||||||
# an executable is not found, even if stderr is redirected.
|
|
||||||
# Redirect stdin to placate older versions of autoconf. Sigh.
|
|
||||||
if ($2 --version) < /dev/null > /dev/null 2>&1; then
|
|
||||||
$1=$2
|
|
||||||
AC_MSG_RESULT(found)
|
|
||||||
else
|
|
||||||
$1="$3/missing $2"
|
|
||||||
AC_MSG_RESULT(missing)
|
|
||||||
fi
|
|
||||||
AC_SUBST($1)])
|
|
||||||
|
|
||||||
|
|
||||||
# serial 40 AC_PROG_LIBTOOL
|
|
||||||
AC_DEFUN(AC_PROG_LIBTOOL,
|
|
||||||
[AC_REQUIRE([AC_LIBTOOL_SETUP])dnl
|
|
||||||
|
|
||||||
# Save cache, so that ltconfig can load it
|
|
||||||
AC_CACHE_SAVE
|
|
||||||
|
|
||||||
# Actually configure libtool. ac_aux_dir is where install-sh is found.
|
|
||||||
CC="$CC" CFLAGS="$CFLAGS" CPPFLAGS="$CPPFLAGS" \
|
|
||||||
LD="$LD" LDFLAGS="$LDFLAGS" LIBS="$LIBS" \
|
|
||||||
LN_S="$LN_S" NM="$NM" RANLIB="$RANLIB" \
|
|
||||||
DLLTOOL="$DLLTOOL" AS="$AS" OBJDUMP="$OBJDUMP" \
|
|
||||||
${CONFIG_SHELL-/bin/sh} $ac_aux_dir/ltconfig --no-reexec \
|
|
||||||
$libtool_flags --no-verify $ac_aux_dir/ltmain.sh $lt_target \
|
|
||||||
|| AC_MSG_ERROR([libtool configure failed])
|
|
||||||
|
|
||||||
# Reload cache, that may have been modified by ltconfig
|
|
||||||
AC_CACHE_LOAD
|
|
||||||
|
|
||||||
# This can be used to rebuild libtool when needed
|
|
||||||
LIBTOOL_DEPS="$ac_aux_dir/ltconfig $ac_aux_dir/ltmain.sh"
|
|
||||||
|
|
||||||
# Always use our own libtool.
|
|
||||||
LIBTOOL='$(SHELL) $(top_builddir)/libtool'
|
|
||||||
AC_SUBST(LIBTOOL)dnl
|
|
||||||
|
|
||||||
# Redirect the config.log output again, so that the ltconfig log is not
|
|
||||||
# clobbered by the next message.
|
|
||||||
exec 5>>./config.log
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_LIBTOOL_SETUP,
|
|
||||||
[AC_PREREQ(2.13)dnl
|
|
||||||
AC_REQUIRE([AC_ENABLE_SHARED])dnl
|
|
||||||
AC_REQUIRE([AC_ENABLE_STATIC])dnl
|
|
||||||
AC_REQUIRE([AC_ENABLE_FAST_INSTALL])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_BUILD])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_RANLIB])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_CC])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_LD])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_NM])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_LN_S])dnl
|
|
||||||
dnl
|
|
||||||
|
|
||||||
case "$target" in
|
|
||||||
NONE) lt_target="$host" ;;
|
|
||||||
*) lt_target="$target" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Check for any special flags to pass to ltconfig.
|
|
||||||
libtool_flags="--cache-file=$cache_file"
|
|
||||||
test "$enable_shared" = no && libtool_flags="$libtool_flags --disable-shared"
|
|
||||||
test "$enable_static" = no && libtool_flags="$libtool_flags --disable-static"
|
|
||||||
test "$enable_fast_install" = no && libtool_flags="$libtool_flags --disable-fast-install"
|
|
||||||
test "$ac_cv_prog_gcc" = yes && libtool_flags="$libtool_flags --with-gcc"
|
|
||||||
test "$ac_cv_prog_gnu_ld" = yes && libtool_flags="$libtool_flags --with-gnu-ld"
|
|
||||||
ifdef([AC_PROVIDE_AC_LIBTOOL_DLOPEN],
|
|
||||||
[libtool_flags="$libtool_flags --enable-dlopen"])
|
|
||||||
ifdef([AC_PROVIDE_AC_LIBTOOL_WIN32_DLL],
|
|
||||||
[libtool_flags="$libtool_flags --enable-win32-dll"])
|
|
||||||
AC_ARG_ENABLE(libtool-lock,
|
|
||||||
[ --disable-libtool-lock avoid locking (might break parallel builds)])
|
|
||||||
test "x$enable_libtool_lock" = xno && libtool_flags="$libtool_flags --disable-lock"
|
|
||||||
test x"$silent" = xyes && libtool_flags="$libtool_flags --silent"
|
|
||||||
|
|
||||||
# Some flags need to be propagated to the compiler or linker for good
|
|
||||||
# libtool support.
|
|
||||||
case "$lt_target" in
|
|
||||||
*-*-irix6*)
|
|
||||||
# Find out which ABI we are using.
|
|
||||||
echo '[#]line __oline__ "configure"' > conftest.$ac_ext
|
|
||||||
if AC_TRY_EVAL(ac_compile); then
|
|
||||||
case "`/usr/bin/file conftest.o`" in
|
|
||||||
*32-bit*)
|
|
||||||
LD="${LD-ld} -32"
|
|
||||||
;;
|
|
||||||
*N32*)
|
|
||||||
LD="${LD-ld} -n32"
|
|
||||||
;;
|
|
||||||
*64-bit*)
|
|
||||||
LD="${LD-ld} -64"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
rm -rf conftest*
|
|
||||||
;;
|
|
||||||
|
|
||||||
*-*-sco3.2v5*)
|
|
||||||
# On SCO OpenServer 5, we need -belf to get full-featured binaries.
|
|
||||||
SAVE_CFLAGS="$CFLAGS"
|
|
||||||
CFLAGS="$CFLAGS -belf"
|
|
||||||
AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf,
|
|
||||||
[AC_TRY_LINK([],[],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no])])
|
|
||||||
if test x"$lt_cv_cc_needs_belf" != x"yes"; then
|
|
||||||
# this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
|
|
||||||
CFLAGS="$SAVE_CFLAGS"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
ifdef([AC_PROVIDE_AC_LIBTOOL_WIN32_DLL],
|
|
||||||
[*-*-cygwin* | *-*-mingw*)
|
|
||||||
AC_CHECK_TOOL(DLLTOOL, dlltool, false)
|
|
||||||
AC_CHECK_TOOL(AS, as, false)
|
|
||||||
AC_CHECK_TOOL(OBJDUMP, objdump, false)
|
|
||||||
;;
|
|
||||||
])
|
|
||||||
esac
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_LIBTOOL_DLOPEN - enable checks for dlopen support
|
|
||||||
AC_DEFUN(AC_LIBTOOL_DLOPEN, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])])
|
|
||||||
|
|
||||||
# AC_LIBTOOL_WIN32_DLL - declare package support for building win32 dll's
|
|
||||||
AC_DEFUN(AC_LIBTOOL_WIN32_DLL, [AC_BEFORE([$0], [AC_LIBTOOL_SETUP])])
|
|
||||||
|
|
||||||
# AC_ENABLE_SHARED - implement the --enable-shared flag
|
|
||||||
# Usage: AC_ENABLE_SHARED[(DEFAULT)]
|
|
||||||
# Where DEFAULT is either `yes' or `no'. If omitted, it defaults to
|
|
||||||
# `yes'.
|
|
||||||
AC_DEFUN(AC_ENABLE_SHARED, [dnl
|
|
||||||
define([AC_ENABLE_SHARED_DEFAULT], ifelse($1, no, no, yes))dnl
|
|
||||||
AC_ARG_ENABLE(shared,
|
|
||||||
changequote(<<, >>)dnl
|
|
||||||
<< --enable-shared[=PKGS] build shared libraries [default=>>AC_ENABLE_SHARED_DEFAULT],
|
|
||||||
changequote([, ])dnl
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case "$enableval" in
|
|
||||||
yes) enable_shared=yes ;;
|
|
||||||
no) enable_shared=no ;;
|
|
||||||
*)
|
|
||||||
enable_shared=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_shared=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
enable_shared=AC_ENABLE_SHARED_DEFAULT)dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_DISABLE_SHARED - set the default shared flag to --disable-shared
|
|
||||||
AC_DEFUN(AC_DISABLE_SHARED, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_ENABLE_SHARED(no)])
|
|
||||||
|
|
||||||
# AC_ENABLE_STATIC - implement the --enable-static flag
|
|
||||||
# Usage: AC_ENABLE_STATIC[(DEFAULT)]
|
|
||||||
# Where DEFAULT is either `yes' or `no'. If omitted, it defaults to
|
|
||||||
# `yes'.
|
|
||||||
AC_DEFUN(AC_ENABLE_STATIC, [dnl
|
|
||||||
define([AC_ENABLE_STATIC_DEFAULT], ifelse($1, no, no, yes))dnl
|
|
||||||
AC_ARG_ENABLE(static,
|
|
||||||
changequote(<<, >>)dnl
|
|
||||||
<< --enable-static[=PKGS] build static libraries [default=>>AC_ENABLE_STATIC_DEFAULT],
|
|
||||||
changequote([, ])dnl
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case "$enableval" in
|
|
||||||
yes) enable_static=yes ;;
|
|
||||||
no) enable_static=no ;;
|
|
||||||
*)
|
|
||||||
enable_static=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_static=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
enable_static=AC_ENABLE_STATIC_DEFAULT)dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_DISABLE_STATIC - set the default static flag to --disable-static
|
|
||||||
AC_DEFUN(AC_DISABLE_STATIC, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_ENABLE_STATIC(no)])
|
|
||||||
|
|
||||||
|
|
||||||
# AC_ENABLE_FAST_INSTALL - implement the --enable-fast-install flag
|
|
||||||
# Usage: AC_ENABLE_FAST_INSTALL[(DEFAULT)]
|
|
||||||
# Where DEFAULT is either `yes' or `no'. If omitted, it defaults to
|
|
||||||
# `yes'.
|
|
||||||
AC_DEFUN(AC_ENABLE_FAST_INSTALL, [dnl
|
|
||||||
define([AC_ENABLE_FAST_INSTALL_DEFAULT], ifelse($1, no, no, yes))dnl
|
|
||||||
AC_ARG_ENABLE(fast-install,
|
|
||||||
changequote(<<, >>)dnl
|
|
||||||
<< --enable-fast-install[=PKGS] optimize for fast installation [default=>>AC_ENABLE_FAST_INSTALL_DEFAULT],
|
|
||||||
changequote([, ])dnl
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case "$enableval" in
|
|
||||||
yes) enable_fast_install=yes ;;
|
|
||||||
no) enable_fast_install=no ;;
|
|
||||||
*)
|
|
||||||
enable_fast_install=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_fast_install=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
enable_fast_install=AC_ENABLE_FAST_INSTALL_DEFAULT)dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_ENABLE_FAST_INSTALL - set the default to --disable-fast-install
|
|
||||||
AC_DEFUN(AC_DISABLE_FAST_INSTALL, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_ENABLE_FAST_INSTALL(no)])
|
|
||||||
|
|
||||||
# AC_PROG_LD - find the path to the GNU or non-GNU linker
|
|
||||||
AC_DEFUN(AC_PROG_LD,
|
|
||||||
[AC_ARG_WITH(gnu-ld,
|
|
||||||
[ --with-gnu-ld assume the C compiler uses GNU ld [default=no]],
|
|
||||||
test "$withval" = no || with_gnu_ld=yes, with_gnu_ld=no)
|
|
||||||
AC_REQUIRE([AC_PROG_CC])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
AC_REQUIRE([AC_CANONICAL_BUILD])dnl
|
|
||||||
ac_prog=ld
|
|
||||||
if test "$ac_cv_prog_gcc" = yes; then
|
|
||||||
# Check if gcc -print-prog-name=ld gives a path.
|
|
||||||
AC_MSG_CHECKING([for ld used by GCC])
|
|
||||||
ac_prog=`($CC -print-prog-name=ld) 2>&5`
|
|
||||||
case "$ac_prog" in
|
|
||||||
# Accept absolute paths.
|
|
||||||
changequote(,)dnl
|
|
||||||
[\\/]* | [A-Za-z]:[\\/]*)
|
|
||||||
re_direlt='/[^/][^/]*/\.\./'
|
|
||||||
changequote([,])dnl
|
|
||||||
# Canonicalize the path of ld
|
|
||||||
ac_prog=`echo $ac_prog| sed 's%\\\\%/%g'`
|
|
||||||
while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do
|
|
||||||
ac_prog=`echo $ac_prog| sed "s%$re_direlt%/%"`
|
|
||||||
done
|
|
||||||
test -z "$LD" && LD="$ac_prog"
|
|
||||||
;;
|
|
||||||
"")
|
|
||||||
# If it fails, then pretend we aren't using GCC.
|
|
||||||
ac_prog=ld
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
# If it is relative, then search for the first ld in PATH.
|
|
||||||
with_gnu_ld=unknown
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
elif test "$with_gnu_ld" = yes; then
|
|
||||||
AC_MSG_CHECKING([for GNU ld])
|
|
||||||
else
|
|
||||||
AC_MSG_CHECKING([for non-GNU ld])
|
|
||||||
fi
|
|
||||||
AC_CACHE_VAL(ac_cv_path_LD,
|
|
||||||
[if test -z "$LD"; then
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR-:}"
|
|
||||||
for ac_dir in $PATH; do
|
|
||||||
test -z "$ac_dir" && ac_dir=.
|
|
||||||
if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
|
|
||||||
ac_cv_path_LD="$ac_dir/$ac_prog"
|
|
||||||
# Check to see if the program is GNU ld. I'd rather use --version,
|
|
||||||
# but apparently some GNU ld's only accept -v.
|
|
||||||
# Break only if it was the GNU/non-GNU ld that we prefer.
|
|
||||||
if "$ac_cv_path_LD" -v 2>&1 < /dev/null | egrep '(GNU|with BFD)' > /dev/null; then
|
|
||||||
test "$with_gnu_ld" != no && break
|
|
||||||
else
|
|
||||||
test "$with_gnu_ld" != yes && break
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
else
|
|
||||||
ac_cv_path_LD="$LD" # Let the user override the test with a path.
|
|
||||||
fi])
|
|
||||||
LD="$ac_cv_path_LD"
|
|
||||||
if test -n "$LD"; then
|
|
||||||
AC_MSG_RESULT($LD)
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
fi
|
|
||||||
test -z "$LD" && AC_MSG_ERROR([no acceptable ld found in \$PATH])
|
|
||||||
AC_PROG_LD_GNU
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN(AC_PROG_LD_GNU,
|
|
||||||
[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], ac_cv_prog_gnu_ld,
|
|
||||||
[# I'd rather use --version here, but apparently some GNU ld's only accept -v.
|
|
||||||
if $LD -v 2>&1 </dev/null | egrep '(GNU|with BFD)' 1>&5; then
|
|
||||||
ac_cv_prog_gnu_ld=yes
|
|
||||||
else
|
|
||||||
ac_cv_prog_gnu_ld=no
|
|
||||||
fi])
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_PROG_NM - find the path to a BSD-compatible name lister
|
|
||||||
AC_DEFUN(AC_PROG_NM,
|
|
||||||
[AC_MSG_CHECKING([for BSD-compatible nm])
|
|
||||||
AC_CACHE_VAL(ac_cv_path_NM,
|
|
||||||
[if test -n "$NM"; then
|
|
||||||
# Let the user override the test.
|
|
||||||
ac_cv_path_NM="$NM"
|
|
||||||
else
|
|
||||||
IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR-:}"
|
|
||||||
for ac_dir in $PATH /usr/ccs/bin /usr/ucb /bin; do
|
|
||||||
test -z "$ac_dir" && ac_dir=.
|
|
||||||
if test -f $ac_dir/nm || test -f $ac_dir/nm$ac_exeext ; then
|
|
||||||
# Check to see if the nm accepts a BSD-compat flag.
|
|
||||||
# Adding the `sed 1q' prevents false positives on HP-UX, which says:
|
|
||||||
# nm: unknown option "B" ignored
|
|
||||||
if ($ac_dir/nm -B /dev/null 2>&1 | sed '1q'; exit 0) | egrep /dev/null >/dev/null; then
|
|
||||||
ac_cv_path_NM="$ac_dir/nm -B"
|
|
||||||
break
|
|
||||||
elif ($ac_dir/nm -p /dev/null 2>&1 | sed '1q'; exit 0) | egrep /dev/null >/dev/null; then
|
|
||||||
ac_cv_path_NM="$ac_dir/nm -p"
|
|
||||||
break
|
|
||||||
else
|
|
||||||
ac_cv_path_NM=${ac_cv_path_NM="$ac_dir/nm"} # keep the first match, but
|
|
||||||
continue # so that we can try to find one that supports BSD flags
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$ac_save_ifs"
|
|
||||||
test -z "$ac_cv_path_NM" && ac_cv_path_NM=nm
|
|
||||||
fi])
|
|
||||||
NM="$ac_cv_path_NM"
|
|
||||||
AC_MSG_RESULT([$NM])
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_CHECK_LIBM - check for math library
|
|
||||||
AC_DEFUN(AC_CHECK_LIBM,
|
|
||||||
[AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
LIBM=
|
|
||||||
case "$lt_target" in
|
|
||||||
*-*-beos* | *-*-cygwin*)
|
|
||||||
# These system don't have libm
|
|
||||||
;;
|
|
||||||
*-ncr-sysv4.3*)
|
|
||||||
AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw")
|
|
||||||
AC_CHECK_LIB(m, main, LIBM="$LIBM -lm")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
AC_CHECK_LIB(m, main, LIBM="-lm")
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_LIBLTDL_CONVENIENCE[(dir)] - sets LIBLTDL to the link flags for
|
|
||||||
# the libltdl convenience library and INCLTDL to the include flags for
|
|
||||||
# the libltdl header and adds --enable-ltdl-convenience to the
|
|
||||||
# configure arguments. Note that LIBLTDL and INCLTDL are not
|
|
||||||
# AC_SUBSTed, nor is AC_CONFIG_SUBDIRS called. If DIR is not
|
|
||||||
# provided, it is assumed to be `libltdl'. LIBLTDL will be prefixed
|
|
||||||
# with '${top_builddir}/' and INCLTDL will be prefixed with
|
|
||||||
# '${top_srcdir}/' (note the single quotes!). If your package is not
|
|
||||||
# flat and you're not using automake, define top_builddir and
|
|
||||||
# top_srcdir appropriately in the Makefiles.
|
|
||||||
AC_DEFUN(AC_LIBLTDL_CONVENIENCE, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
case "$enable_ltdl_convenience" in
|
|
||||||
no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;;
|
|
||||||
"") enable_ltdl_convenience=yes
|
|
||||||
ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;;
|
|
||||||
esac
|
|
||||||
LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdlc.la
|
|
||||||
INCLTDL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl'])
|
|
||||||
])
|
|
||||||
|
|
||||||
# AC_LIBLTDL_INSTALLABLE[(dir)] - sets LIBLTDL to the link flags for
|
|
||||||
# the libltdl installable library and INCLTDL to the include flags for
|
|
||||||
# the libltdl header and adds --enable-ltdl-install to the configure
|
|
||||||
# arguments. Note that LIBLTDL and INCLTDL are not AC_SUBSTed, nor is
|
|
||||||
# AC_CONFIG_SUBDIRS called. If DIR is not provided and an installed
|
|
||||||
# libltdl is not found, it is assumed to be `libltdl'. LIBLTDL will
|
|
||||||
# be prefixed with '${top_builddir}/' and INCLTDL will be prefixed
|
|
||||||
# with '${top_srcdir}/' (note the single quotes!). If your package is
|
|
||||||
# not flat and you're not using automake, define top_builddir and
|
|
||||||
# top_srcdir appropriately in the Makefiles.
|
|
||||||
# In the future, this macro may have to be called after AC_PROG_LIBTOOL.
|
|
||||||
AC_DEFUN(AC_LIBLTDL_INSTALLABLE, [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
|
|
||||||
AC_CHECK_LIB(ltdl, main,
|
|
||||||
[test x"$enable_ltdl_install" != xyes && enable_ltdl_install=no],
|
|
||||||
[if test x"$enable_ltdl_install" = xno; then
|
|
||||||
AC_MSG_WARN([libltdl not installed, but installation disabled])
|
|
||||||
else
|
|
||||||
enable_ltdl_install=yes
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
if test x"$enable_ltdl_install" = x"yes"; then
|
|
||||||
ac_configure_args="$ac_configure_args --enable-ltdl-install"
|
|
||||||
LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdl.la
|
|
||||||
INCLTDL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl'])
|
|
||||||
else
|
|
||||||
ac_configure_args="$ac_configure_args --enable-ltdl-install=no"
|
|
||||||
LIBLTDL="-lltdl"
|
|
||||||
INCLTDL=
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl old names
|
|
||||||
AC_DEFUN(AM_PROG_LIBTOOL, [indir([AC_PROG_LIBTOOL])])dnl
|
|
||||||
AC_DEFUN(AM_ENABLE_SHARED, [indir([AC_ENABLE_SHARED], $@)])dnl
|
|
||||||
AC_DEFUN(AM_ENABLE_STATIC, [indir([AC_ENABLE_STATIC], $@)])dnl
|
|
||||||
AC_DEFUN(AM_DISABLE_SHARED, [indir([AC_DISABLE_SHARED], $@)])dnl
|
|
||||||
AC_DEFUN(AM_DISABLE_STATIC, [indir([AC_DISABLE_STATIC], $@)])dnl
|
|
||||||
AC_DEFUN(AM_PROG_LD, [indir([AC_PROG_LD])])dnl
|
|
||||||
AC_DEFUN(AM_PROG_NM, [indir([AC_PROG_NM])])dnl
|
|
||||||
|
|
||||||
dnl This is just to silence aclocal about the macro not being used
|
|
||||||
ifelse([AC_DISABLE_FAST_INSTALL])dnl
|
|
||||||
|
|
@@ -23,6 +23,12 @@
|
|||||||
/* Define to `unsigned' if <sys/types.h> doesn't define. */
|
/* Define to `unsigned' if <sys/types.h> doesn't define. */
|
||||||
/* #undef size_t */
|
/* #undef size_t */
|
||||||
|
|
||||||
|
/* Define this to 'int' if ssize_t is not an available typedefed type */
|
||||||
|
#define ssize_t int
|
||||||
|
|
||||||
|
/* Define this to 'int' if socklen_t is not an available typedefed type */
|
||||||
|
#define socklen_t int
|
||||||
|
|
||||||
/* Define if you have the ANSI C header files. */
|
/* Define if you have the ANSI C header files. */
|
||||||
#define STDC_HEADERS 1
|
#define STDC_HEADERS 1
|
||||||
|
|
||||||
|
312
config.h.in
312
config.h.in
@@ -1,312 +0,0 @@
|
|||||||
/* config.h.in. Generated automatically from configure.in by autoheader. */
|
|
||||||
|
|
||||||
/* Define if on AIX 3.
|
|
||||||
System headers sometimes define this.
|
|
||||||
We just want to avoid a redefinition error message. */
|
|
||||||
#ifndef _ALL_SOURCE
|
|
||||||
#undef _ALL_SOURCE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Define to empty if the keyword does not work. */
|
|
||||||
#undef const
|
|
||||||
|
|
||||||
/* Define as the return type of signal handlers (int or void). */
|
|
||||||
#undef RETSIGTYPE
|
|
||||||
|
|
||||||
/* Define to `unsigned' if <sys/types.h> doesn't define. */
|
|
||||||
#undef size_t
|
|
||||||
|
|
||||||
/* Define if you have the ANSI C header files. */
|
|
||||||
#undef STDC_HEADERS
|
|
||||||
|
|
||||||
/* Define if you can safely include both <sys/time.h> and <time.h>. */
|
|
||||||
#undef TIME_WITH_SYS_TIME
|
|
||||||
|
|
||||||
/* Define cpu-machine-OS */
|
|
||||||
#undef OS
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R_5
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 7 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R_7
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 8 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R_8
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r() function with 3 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R_3
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r() function with 5 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R_5
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r() function with 6 arguments */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R_6
|
|
||||||
|
|
||||||
/* Define if you have the inet_ntoa_r function declared. */
|
|
||||||
#undef HAVE_INET_NTOA_R_DECL
|
|
||||||
|
|
||||||
/* Define if you need the _REENTRANT define for some functions */
|
|
||||||
#undef NEED_REENTRANT
|
|
||||||
|
|
||||||
/* Define if you have the Kerberos4 libraries (including -ldes) */
|
|
||||||
#undef KRB4
|
|
||||||
|
|
||||||
/* The number of bytes in a long double. */
|
|
||||||
#undef SIZEOF_LONG_DOUBLE
|
|
||||||
|
|
||||||
/* The number of bytes in a long long. */
|
|
||||||
#undef SIZEOF_LONG_LONG
|
|
||||||
|
|
||||||
/* Define if you have the RAND_screen function. */
|
|
||||||
#undef HAVE_RAND_SCREEN
|
|
||||||
|
|
||||||
/* Define if you have the RAND_status function. */
|
|
||||||
#undef HAVE_RAND_STATUS
|
|
||||||
|
|
||||||
/* Define if you have the closesocket function. */
|
|
||||||
#undef HAVE_CLOSESOCKET
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr function. */
|
|
||||||
#undef HAVE_GETHOSTBYADDR
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r function. */
|
|
||||||
#undef HAVE_GETHOSTBYADDR_R
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyname_r function. */
|
|
||||||
#undef HAVE_GETHOSTBYNAME_R
|
|
||||||
|
|
||||||
/* Define if you have the gethostname function. */
|
|
||||||
#undef HAVE_GETHOSTNAME
|
|
||||||
|
|
||||||
/* Define if you have the getpass_r function. */
|
|
||||||
#undef HAVE_GETPASS_R
|
|
||||||
|
|
||||||
/* Define if you have the getservbyname function. */
|
|
||||||
#undef HAVE_GETSERVBYNAME
|
|
||||||
|
|
||||||
/* Define if you have the gettimeofday function. */
|
|
||||||
#undef HAVE_GETTIMEOFDAY
|
|
||||||
|
|
||||||
/* Define if you have the inet_addr function. */
|
|
||||||
#undef HAVE_INET_ADDR
|
|
||||||
|
|
||||||
/* Define if you have the inet_ntoa function. */
|
|
||||||
#undef HAVE_INET_NTOA
|
|
||||||
|
|
||||||
/* Define if you have the inet_ntoa_r function. */
|
|
||||||
#undef HAVE_INET_NTOA_R
|
|
||||||
|
|
||||||
/* Define if you have the krb_get_our_ip_for_realm function. */
|
|
||||||
#undef HAVE_KRB_GET_OUR_IP_FOR_REALM
|
|
||||||
|
|
||||||
/* Define if you have the localtime_r function. */
|
|
||||||
#undef HAVE_LOCALTIME_R
|
|
||||||
|
|
||||||
/* Define if you have the perror function. */
|
|
||||||
#undef HAVE_PERROR
|
|
||||||
|
|
||||||
/* Define if you have the select function. */
|
|
||||||
#undef HAVE_SELECT
|
|
||||||
|
|
||||||
/* Define if you have the setvbuf function. */
|
|
||||||
#undef HAVE_SETVBUF
|
|
||||||
|
|
||||||
/* Define if you have the sigaction function. */
|
|
||||||
#undef HAVE_SIGACTION
|
|
||||||
|
|
||||||
/* Define if you have the signal function. */
|
|
||||||
#undef HAVE_SIGNAL
|
|
||||||
|
|
||||||
/* Define if you have the socket function. */
|
|
||||||
#undef HAVE_SOCKET
|
|
||||||
|
|
||||||
/* Define if you have the strcasecmp function. */
|
|
||||||
#undef HAVE_STRCASECMP
|
|
||||||
|
|
||||||
/* Define if you have the strcmpi function. */
|
|
||||||
#undef HAVE_STRCMPI
|
|
||||||
|
|
||||||
/* Define if you have the strdup function. */
|
|
||||||
#undef HAVE_STRDUP
|
|
||||||
|
|
||||||
/* Define if you have the strftime function. */
|
|
||||||
#undef HAVE_STRFTIME
|
|
||||||
|
|
||||||
/* Define if you have the stricmp function. */
|
|
||||||
#undef HAVE_STRICMP
|
|
||||||
|
|
||||||
/* Define if you have the strlcpy function. */
|
|
||||||
#undef HAVE_STRLCPY
|
|
||||||
|
|
||||||
/* Define if you have the strstr function. */
|
|
||||||
#undef HAVE_STRSTR
|
|
||||||
|
|
||||||
/* Define if you have the tcgetattr function. */
|
|
||||||
#undef HAVE_TCGETATTR
|
|
||||||
|
|
||||||
/* Define if you have the tcsetattr function. */
|
|
||||||
#undef HAVE_TCSETATTR
|
|
||||||
|
|
||||||
/* Define if you have the uname function. */
|
|
||||||
#undef HAVE_UNAME
|
|
||||||
|
|
||||||
/* Define if you have the <alloca.h> header file. */
|
|
||||||
#undef HAVE_ALLOCA_H
|
|
||||||
|
|
||||||
/* Define if you have the <arpa/inet.h> header file. */
|
|
||||||
#undef HAVE_ARPA_INET_H
|
|
||||||
|
|
||||||
/* Define if you have the <crypto.h> header file. */
|
|
||||||
#undef HAVE_CRYPTO_H
|
|
||||||
|
|
||||||
/* Define if you have the <des.h> header file. */
|
|
||||||
#undef HAVE_DES_H
|
|
||||||
|
|
||||||
/* Define if you have the <dlfcn.h> header file. */
|
|
||||||
#undef HAVE_DLFCN_H
|
|
||||||
|
|
||||||
/* Define if you have the <err.h> header file. */
|
|
||||||
#undef HAVE_ERR_H
|
|
||||||
|
|
||||||
/* Define if you have the <fcntl.h> header file. */
|
|
||||||
#undef HAVE_FCNTL_H
|
|
||||||
|
|
||||||
/* Define if you have the <getopt.h> header file. */
|
|
||||||
#undef HAVE_GETOPT_H
|
|
||||||
|
|
||||||
/* Define if you have the <io.h> header file. */
|
|
||||||
#undef HAVE_IO_H
|
|
||||||
|
|
||||||
/* Define if you have the <krb.h> header file. */
|
|
||||||
#undef HAVE_KRB_H
|
|
||||||
|
|
||||||
/* Define if you have the <malloc.h> header file. */
|
|
||||||
#undef HAVE_MALLOC_H
|
|
||||||
|
|
||||||
/* Define if you have the <net/if.h> header file. */
|
|
||||||
#undef HAVE_NET_IF_H
|
|
||||||
|
|
||||||
/* Define if you have the <netdb.h> header file. */
|
|
||||||
#undef HAVE_NETDB_H
|
|
||||||
|
|
||||||
/* Define if you have the <netinet/if_ether.h> header file. */
|
|
||||||
#undef HAVE_NETINET_IF_ETHER_H
|
|
||||||
|
|
||||||
/* Define if you have the <netinet/in.h> header file. */
|
|
||||||
#undef HAVE_NETINET_IN_H
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/crypto.h> header file. */
|
|
||||||
#undef HAVE_OPENSSL_CRYPTO_H
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/err.h> header file. */
|
|
||||||
#undef HAVE_OPENSSL_ERR_H
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/pem.h> header file. */
|
|
||||||
#undef HAVE_OPENSSL_PEM_H
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/rsa.h> header file. */
|
|
||||||
#undef HAVE_OPENSSL_RSA_H
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/ssl.h> header file. */
|
|
||||||
#undef HAVE_OPENSSL_SSL_H
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/x509.h> header file. */
|
|
||||||
#undef HAVE_OPENSSL_X509_H
|
|
||||||
|
|
||||||
/* Define if you have the <pem.h> header file. */
|
|
||||||
#undef HAVE_PEM_H
|
|
||||||
|
|
||||||
/* Define if you have the <rsa.h> header file. */
|
|
||||||
#undef HAVE_RSA_H
|
|
||||||
|
|
||||||
/* Define if you have the <sgtty.h> header file. */
|
|
||||||
#undef HAVE_SGTTY_H
|
|
||||||
|
|
||||||
/* Define if you have the <ssl.h> header file. */
|
|
||||||
#undef HAVE_SSL_H
|
|
||||||
|
|
||||||
/* Define if you have the <stdlib.h> header file. */
|
|
||||||
#undef HAVE_STDLIB_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/param.h> header file. */
|
|
||||||
#undef HAVE_SYS_PARAM_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/select.h> header file. */
|
|
||||||
#undef HAVE_SYS_SELECT_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/socket.h> header file. */
|
|
||||||
#undef HAVE_SYS_SOCKET_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/sockio.h> header file. */
|
|
||||||
#undef HAVE_SYS_SOCKIO_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/stat.h> header file. */
|
|
||||||
#undef HAVE_SYS_STAT_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/time.h> header file. */
|
|
||||||
#undef HAVE_SYS_TIME_H
|
|
||||||
|
|
||||||
/* Define if you have the <sys/types.h> header file. */
|
|
||||||
#undef HAVE_SYS_TYPES_H
|
|
||||||
|
|
||||||
/* Define if you have the <termio.h> header file. */
|
|
||||||
#undef HAVE_TERMIO_H
|
|
||||||
|
|
||||||
/* Define if you have the <termios.h> header file. */
|
|
||||||
#undef HAVE_TERMIOS_H
|
|
||||||
|
|
||||||
/* Define if you have the <time.h> header file. */
|
|
||||||
#undef HAVE_TIME_H
|
|
||||||
|
|
||||||
/* Define if you have the <unistd.h> header file. */
|
|
||||||
#undef HAVE_UNISTD_H
|
|
||||||
|
|
||||||
/* Define if you have the <winsock.h> header file. */
|
|
||||||
#undef HAVE_WINSOCK_H
|
|
||||||
|
|
||||||
/* Define if you have the <x509.h> header file. */
|
|
||||||
#undef HAVE_X509_H
|
|
||||||
|
|
||||||
/* Define if you have the crypto library (-lcrypto). */
|
|
||||||
#undef HAVE_LIBCRYPTO
|
|
||||||
|
|
||||||
/* Define if you have the dl library (-ldl). */
|
|
||||||
#undef HAVE_LIBDL
|
|
||||||
|
|
||||||
/* Define if you have the nsl library (-lnsl). */
|
|
||||||
#undef HAVE_LIBNSL
|
|
||||||
|
|
||||||
/* Define if you have the resolv library (-lresolv). */
|
|
||||||
#undef HAVE_LIBRESOLV
|
|
||||||
|
|
||||||
/* Define if you have the resolve library (-lresolve). */
|
|
||||||
#undef HAVE_LIBRESOLVE
|
|
||||||
|
|
||||||
/* Define if you have the socket library (-lsocket). */
|
|
||||||
#undef HAVE_LIBSOCKET
|
|
||||||
|
|
||||||
/* Define if you have the ssl library (-lssl). */
|
|
||||||
#undef HAVE_LIBSSL
|
|
||||||
|
|
||||||
/* Define if you have the ucb library (-lucb). */
|
|
||||||
#undef HAVE_LIBUCB
|
|
||||||
|
|
||||||
/* Name of package */
|
|
||||||
#undef PACKAGE
|
|
||||||
|
|
||||||
/* Version number of package */
|
|
||||||
#undef VERSION
|
|
||||||
|
|
||||||
/* Number of bits in a file offset, on hosts where this is settable. */
|
|
||||||
#undef _FILE_OFFSET_BITS
|
|
||||||
|
|
||||||
/* Define to make ftello visible on some hosts (e.g. HP-UX 10.20). */
|
|
||||||
#undef _LARGEFILE_SOURCE
|
|
||||||
|
|
||||||
/* Define for large files, on AIX-style hosts. */
|
|
||||||
#undef _LARGE_FILES
|
|
||||||
|
|
||||||
/* Set to explicitly specify we don't want to use thread-safe functions */
|
|
||||||
#undef DISABLED_THREADSAFE
|
|
||||||
|
|
184
configure.in
184
configure.in
@@ -26,6 +26,66 @@ dnl The install stuff has already been taken care of by the automake stuff
|
|||||||
dnl AC_PROG_INSTALL
|
dnl AC_PROG_INSTALL
|
||||||
AC_PROG_MAKE_SET
|
AC_PROG_MAKE_SET
|
||||||
|
|
||||||
|
dnl ************************************************************
|
||||||
|
dnl lame option to switch on debug options
|
||||||
|
dnl
|
||||||
|
AC_MSG_CHECKING([whether to enable debug options])
|
||||||
|
AC_ARG_ENABLE(debug,
|
||||||
|
[ --enable-debug Enable pedantic debug options
|
||||||
|
--disable-debug Disable debug options],
|
||||||
|
[ case "$enableval" in
|
||||||
|
no)
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
;;
|
||||||
|
*) AC_MSG_RESULT(yes)
|
||||||
|
|
||||||
|
CPPFLAGS="$CPPFLAGS -DMALLOCDEBUG"
|
||||||
|
CFLAGS="-Wall -pedantic -g"
|
||||||
|
;;
|
||||||
|
esac ],
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
dnl
|
||||||
|
dnl check for working getaddrinfo()
|
||||||
|
dnl
|
||||||
|
AC_DEFUN(CURL_CHECK_WORKING_GETADDRINFO,[
|
||||||
|
AC_CACHE_CHECK(for working getaddrinfo, ac_cv_working_getaddrinfo,[
|
||||||
|
AC_TRY_RUN( [
|
||||||
|
#include <netdb.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
|
||||||
|
void main(void) {
|
||||||
|
struct addrinfo hints, *ai;
|
||||||
|
int error;
|
||||||
|
|
||||||
|
memset(&hints, 0, sizeof(hints));
|
||||||
|
hints.ai_family = AF_UNSPEC;
|
||||||
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
|
error = getaddrinfo("127.0.0.1", "8080", &hints, &ai);
|
||||||
|
if (error) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],[
|
||||||
|
ac_cv_working_getaddrinfo="yes"
|
||||||
|
],[
|
||||||
|
ac_cv_working_getaddrinfo="no"
|
||||||
|
],[
|
||||||
|
ac_cv_working_getaddrinfo="yes"
|
||||||
|
])])
|
||||||
|
if test "$ac_cv_working_getaddrinfo" = "yes"; then
|
||||||
|
AC_DEFINE(HAVE_GETADDRINFO, 1, [Define if getaddrinfo exists and works])
|
||||||
|
AC_DEFINE(ENABLE_IPV6, 1, [Define if you want to enable IPv6 support])
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
AC_DEFUN(CURL_CHECK_LOCALTIME_R,
|
AC_DEFUN(CURL_CHECK_LOCALTIME_R,
|
||||||
[
|
[
|
||||||
dnl check for a few thread-safe functions
|
dnl check for a few thread-safe functions
|
||||||
@@ -237,6 +297,47 @@ exit (rc != 0 ? 1 : 0); }],[
|
|||||||
|
|
||||||
])
|
])
|
||||||
|
|
||||||
|
dnl **********************************************************************
|
||||||
|
dnl Checks for IPv6
|
||||||
|
dnl **********************************************************************
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([whether to enable ipv6])
|
||||||
|
AC_ARG_ENABLE(ipv6,
|
||||||
|
[ --enable-ipv6 Enable ipv6 (with ipv4) support
|
||||||
|
--disable-ipv6 Disable ipv6 support],
|
||||||
|
[ case "$enableval" in
|
||||||
|
no)
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
ipv6=no
|
||||||
|
;;
|
||||||
|
*) AC_MSG_RESULT(yes)
|
||||||
|
ipv6=yes
|
||||||
|
;;
|
||||||
|
esac ],
|
||||||
|
|
||||||
|
AC_TRY_RUN([ /* is AF_INET6 available? */
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
main()
|
||||||
|
{
|
||||||
|
if (socket(AF_INET6, SOCK_STREAM, 0) < 0)
|
||||||
|
exit(1);
|
||||||
|
else
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
],
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
ipv6=yes,
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
ipv6=no,
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
ipv6=no
|
||||||
|
))
|
||||||
|
|
||||||
|
if test "$ipv6" = "yes"; then
|
||||||
|
CURL_CHECK_WORKING_GETADDRINFO
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Checks for libraries.
|
dnl Checks for libraries.
|
||||||
@@ -290,6 +391,36 @@ AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
|||||||
dnl dl lib?
|
dnl dl lib?
|
||||||
AC_CHECK_FUNC(dlopen, , AC_CHECK_LIB(dl, dlopen))
|
AC_CHECK_FUNC(dlopen, , AC_CHECK_LIB(dl, dlopen))
|
||||||
|
|
||||||
|
dnl **********************************************************************
|
||||||
|
dnl Check for the random seed preferences
|
||||||
|
dnl **********************************************************************
|
||||||
|
|
||||||
|
AC_ARG_WITH(egd-socket,
|
||||||
|
[ --with-egd-socket=FILE Entropy Gathering Daemon socket pathname],
|
||||||
|
[ EGD_SOCKET="$withval" ]
|
||||||
|
)
|
||||||
|
if test -n "$EGD_SOCKET" ; then
|
||||||
|
AC_DEFINE_UNQUOTED(EGD_SOCKET, "$EGD_SOCKET")
|
||||||
|
fi
|
||||||
|
|
||||||
|
dnl Check for user-specified random device
|
||||||
|
AC_ARG_WITH(random,
|
||||||
|
[ --with-random=FILE read randomness from FILE (default=/dev/urandom)],
|
||||||
|
[ RANDOM_FILE="$withval" ],
|
||||||
|
[
|
||||||
|
dnl Check for random device
|
||||||
|
AC_CHECK_FILE("/dev/urandom",
|
||||||
|
[
|
||||||
|
RANDOM_FILE="/dev/urandom";
|
||||||
|
]
|
||||||
|
)
|
||||||
|
]
|
||||||
|
)
|
||||||
|
if test -n "$RANDOM_FILE" ; then
|
||||||
|
AC_SUBST(RANDOM_FILE)
|
||||||
|
AC_DEFINE_UNQUOTED(RANDOM_FILE, "$RANDOM_FILE")
|
||||||
|
fi
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the presence of Kerberos4 libraries and headers
|
dnl Check for the presence of Kerberos4 libraries and headers
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -327,6 +458,10 @@ AC_MSG_CHECKING([if Kerberos4 support is requested])
|
|||||||
|
|
||||||
if test "$want_krb4" = yes
|
if test "$want_krb4" = yes
|
||||||
then
|
then
|
||||||
|
if test "$ipv6" = "yes"; then
|
||||||
|
echo krb4 is not compatible with IPv6
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-krb4
|
dnl Check for & handle argument to --with-krb4
|
||||||
@@ -440,7 +575,8 @@ else
|
|||||||
dnl these can only exist if openssl exists
|
dnl these can only exist if openssl exists
|
||||||
|
|
||||||
AC_CHECK_FUNCS( RAND_status \
|
AC_CHECK_FUNCS( RAND_status \
|
||||||
RAND_screen )
|
RAND_screen \
|
||||||
|
RAND_egd )
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -554,6 +690,31 @@ AC_CHECK_SIZEOF(long double, 8)
|
|||||||
# check for 'long long'
|
# check for 'long long'
|
||||||
AC_CHECK_SIZEOF(long long, 4)
|
AC_CHECK_SIZEOF(long long, 4)
|
||||||
|
|
||||||
|
# check for ssize_t
|
||||||
|
AC_CHECK_TYPE(ssize_t, int)
|
||||||
|
|
||||||
|
dnl
|
||||||
|
dnl We can't just AC_CHECK_TYPE() for socklen_t since it doesn't appear
|
||||||
|
dnl in the standard headers. We egrep for it in the socket headers and
|
||||||
|
dnl if it is used there we assume we have the type defined, otherwise
|
||||||
|
dnl we search for it with AC_CHECK_TYPE() the "normal" way
|
||||||
|
dnl
|
||||||
|
|
||||||
|
if test "$ac_cv_header_sys_socket_h" = "yes"; then
|
||||||
|
AC_MSG_CHECKING(for socklen_t in sys/socket.h)
|
||||||
|
AC_EGREP_HEADER(socklen_t,
|
||||||
|
sys/socket.h,
|
||||||
|
socklen_t=yes
|
||||||
|
AC_MSG_RESULT(yes),
|
||||||
|
AC_MSG_RESULT(no))
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$socklen_t" != "yes"; then
|
||||||
|
# check for socklen_t the standard way if it wasn't found before
|
||||||
|
AC_CHECK_TYPE(socklen_t, int)
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl Get system canonical name
|
dnl Get system canonical name
|
||||||
AC_CANONICAL_HOST
|
AC_CANONICAL_HOST
|
||||||
AC_DEFINE_UNQUOTED(OS, "${host}")
|
AC_DEFINE_UNQUOTED(OS, "${host}")
|
||||||
@@ -584,12 +745,16 @@ AC_CHECK_FUNCS( socket \
|
|||||||
setvbuf \
|
setvbuf \
|
||||||
sigaction \
|
sigaction \
|
||||||
signal \
|
signal \
|
||||||
getpass_r
|
getpass_r \
|
||||||
|
strlcat
|
||||||
)
|
)
|
||||||
|
|
||||||
dnl removed 'getpass' check on October 26, 2000
|
dnl removed 'getpass' check on October 26, 2000
|
||||||
|
|
||||||
if test "$ac_cv_func_select" != "yes"; then
|
if test "$ac_cv_func_select" != "yes"; then
|
||||||
|
AC_MSG_ERROR(Can't work without an existing select() function)
|
||||||
|
fi
|
||||||
|
if test "$ac_cv_func_socket" != "yes"; then
|
||||||
AC_MSG_ERROR(Can't work without an existing socket() function)
|
AC_MSG_ERROR(Can't work without an existing socket() function)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -609,12 +774,17 @@ dnl AC_SUBST(RANLIB)
|
|||||||
|
|
||||||
AC_OUTPUT( Makefile \
|
AC_OUTPUT( Makefile \
|
||||||
docs/Makefile \
|
docs/Makefile \
|
||||||
|
docs/examples/Makefile \
|
||||||
include/Makefile \
|
include/Makefile \
|
||||||
include/curl/Makefile \
|
include/curl/Makefile \
|
||||||
src/Makefile \
|
src/Makefile \
|
||||||
lib/Makefile \
|
lib/Makefile \
|
||||||
tests/Makefile)
|
tests/Makefile \
|
||||||
dnl perl/checklinks.pl \
|
tests/data/Makefile \
|
||||||
dnl perl/getlinks.pl \
|
packages/Makefile \
|
||||||
dnl perl/formfind.pl \
|
packages/Win32/Makefile \
|
||||||
dnl perl/recursiveftpget.pl )
|
packages/Linux/Makefile \
|
||||||
|
packages/Linux/RPM/Makefile \
|
||||||
|
packages/Linux/RPM/curl.spec \
|
||||||
|
packages/Linux/RPM/curl-ssl.spec )
|
||||||
|
|
||||||
|
17
docs/BUGS
17
docs/BUGS
@@ -6,9 +6,9 @@
|
|||||||
|
|
||||||
BUGS
|
BUGS
|
||||||
|
|
||||||
Curl has grown substantially from that day, several years ago, when I
|
Curl and libcurl have grown substantially since the beginning. At the time
|
||||||
started fiddling with it. When I write this, there are 16500 lines of source
|
of writing (mid March 2001), there are 23000 lines of source code, and by
|
||||||
code, and by the time you read this it has probably grown even more.
|
the time you read this it has probably grown even more.
|
||||||
|
|
||||||
Of course there are lots of bugs left. And lots of misfeatures.
|
Of course there are lots of bugs left. And lots of misfeatures.
|
||||||
|
|
||||||
@@ -21,10 +21,11 @@ BUGS
|
|||||||
http://sourceforge.net/bugs/?group_id=976
|
http://sourceforge.net/bugs/?group_id=976
|
||||||
|
|
||||||
When reporting a bug, you should include information that will help us
|
When reporting a bug, you should include information that will help us
|
||||||
understand what's wrong, what's expected and how to repeat it. You therefore
|
understand what's wrong, what you expected to happen and how to repeat the
|
||||||
need to supply your operating system's name and version number (uname -a
|
bad behaviour. You therefore need to supply your operating system's name and
|
||||||
under a unix is fine), what version of curl you're using (curl -v is fine),
|
version number (uname -a under a unix is fine), what version of curl you're
|
||||||
what URL you were working with and anything else you think matters.
|
using (curl -V is fine), what URL you were working with and anything else
|
||||||
|
you think matters.
|
||||||
|
|
||||||
If curl crashed, causing a core dump (in unix), there is hardly any use to
|
If curl crashed, causing a core dump (in unix), there is hardly any use to
|
||||||
send that huge file to anyone of us. Unless we have an exact same system
|
send that huge file to anyone of us. Unless we have an exact same system
|
||||||
@@ -32,7 +33,7 @@ BUGS
|
|||||||
a stack trace and send that (much smaller) output to us instead!
|
a stack trace and send that (much smaller) output to us instead!
|
||||||
|
|
||||||
The address and how to subscribe to the mailing list is detailed in the
|
The address and how to subscribe to the mailing list is detailed in the
|
||||||
README.curl file.
|
MANUAL file.
|
||||||
|
|
||||||
HOW TO GET A STACK TRACE with a common unix debugger
|
HOW TO GET A STACK TRACE with a common unix debugger
|
||||||
====================================================
|
====================================================
|
||||||
|
@@ -13,12 +13,12 @@ To Think About When Contributing Source Code
|
|||||||
The License Issue
|
The License Issue
|
||||||
|
|
||||||
When contributing with code, you agree to put your changes and new code under
|
When contributing with code, you agree to put your changes and new code under
|
||||||
the same license curl and libcurl is already using.
|
the same license curl and libcurl is already using unless stated otherwise.
|
||||||
|
|
||||||
If you add a larger piece of code, you can opt to make that file or set of
|
If you add a larger piece of code, you can opt to make that file or set of
|
||||||
files to use a different license as long as they don't enfore any changes to
|
files to use a different license as long as they don't enfore any changes to
|
||||||
the rest of the package and they make sense. Such "separate parts" can not be
|
the rest of the package and they make sense. Such "separate parts" can not be
|
||||||
GPL (as we don't want the FPL virus to attack users of libcurl) but they must
|
GPL (as we don't want the GPL virus to attack users of libcurl) but they must
|
||||||
use "GPL compatible" licenses.
|
use "GPL compatible" licenses.
|
||||||
|
|
||||||
Naming
|
Naming
|
||||||
@@ -26,19 +26,19 @@ Naming
|
|||||||
Try using a non-confusing naming scheme for your new functions and variable
|
Try using a non-confusing naming scheme for your new functions and variable
|
||||||
names. It doesn't necessarily have to mean that you should use the same as in
|
names. It doesn't necessarily have to mean that you should use the same as in
|
||||||
other places of the code, just that the names should be logical,
|
other places of the code, just that the names should be logical,
|
||||||
understandable and be named according to what they're used for.
|
understandable and be named according to what they're used for. File-local
|
||||||
|
functions should be made static.
|
||||||
|
|
||||||
Indenting
|
Indenting
|
||||||
|
|
||||||
Please try using the same indenting levels and bracing method as all the
|
Please try using the same indenting levels and bracing method as all the
|
||||||
other code already does. It makes the source code a lot easier to follow if
|
other code already does. It makes the source code a lot easier to follow if
|
||||||
all of it is written using the same style. I don't ask you to like it, I just
|
all of it is written using the same style. We don't ask you to like it, we
|
||||||
ask you to follow the tradition! ;-)
|
just ask you to follow the tradition! ;-)
|
||||||
|
|
||||||
Commenting
|
Commenting
|
||||||
|
|
||||||
Comment your source code extensively. I don't see myself as a very good
|
Comment your source code extensively. Commented code is quality code and
|
||||||
source commenter, but I try to become one. Commented code is quality code and
|
|
||||||
enables future modifications much more. Uncommented code much more risk being
|
enables future modifications much more. Uncommented code much more risk being
|
||||||
completely replaced when someone wants to extend things, since other persons'
|
completely replaced when someone wants to extend things, since other persons'
|
||||||
source code can get quite hard to read.
|
source code can get quite hard to read.
|
||||||
@@ -71,9 +71,9 @@ Separate Patches Doing Different Things
|
|||||||
Patch Against Recent Sources
|
Patch Against Recent Sources
|
||||||
|
|
||||||
Please try to get the latest available sources to make your patches
|
Please try to get the latest available sources to make your patches
|
||||||
against. It makes my life so much easier. The very best is if you get the
|
against. It makes the life of the developers so much easier. The very best is
|
||||||
most up-to-date sources from the CVS repository, but the latest release
|
if you get the most up-to-date sources from the CVS repository, but the
|
||||||
archive is quite OK as well!
|
latest release archive is quite OK as well!
|
||||||
|
|
||||||
Document
|
Document
|
||||||
|
|
||||||
@@ -91,9 +91,9 @@ Write Access to CVS Repository
|
|||||||
|
|
||||||
Test Cases
|
Test Cases
|
||||||
|
|
||||||
Since the introduction of the test suite, we will get the possibility to
|
Since the introduction of the test suite, we can quickly verify that the main
|
||||||
quickly verify that the main features are working as supposed to. To maintain
|
features are working as they're supposed to. To maintain this situation and
|
||||||
this situation and improve it, all new features and functions that are added
|
improve it, all new features and functions that are added need to be tested
|
||||||
need tro be tested. Every feature that is added should get at least one valid
|
in the test suite. Every feature that is added should get at least one valid
|
||||||
test case that verifies that it works as documented. If every submitter also
|
test case that verifies that it works as documented. If every submitter also
|
||||||
post a few test cases, it won't end up as a heavy burden on a single person!
|
post a few test cases, it won't end up as a heavy burden on a single person!
|
||||||
|
216
docs/FAQ
216
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: January 4, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
Updated: March 13, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -30,10 +30,12 @@ FAQ
|
|||||||
3.6 Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
3.6 Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
||||||
3.7 Can I use curl to delete/rename a file through FTP?
|
3.7 Can I use curl to delete/rename a file through FTP?
|
||||||
3.8 How do I tell curl to follow HTTP redirects?
|
3.8 How do I tell curl to follow HTTP redirects?
|
||||||
|
3.9 How do I use curl in PHP?
|
||||||
|
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
4.2 Why do I get problems when I use & in the URL?
|
4.2 Why do I get problems when I use & or % in the URL?
|
||||||
4.3 How can I use {, }, [ or ] to specify multiple URLs?
|
4.3 How can I use {, }, [ or ] to specify multiple URLs?
|
||||||
4.4 Why do I get downloaded data even though the web page doesn't exist?
|
4.4 Why do I get downloaded data even though the web page doesn't exist?
|
||||||
4.5 Why do I get return code XXX from a HTTP server?
|
4.5 Why do I get return code XXX from a HTTP server?
|
||||||
@@ -48,10 +50,12 @@ 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?
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
5.1 Is libcurl thread safe?
|
5.1 Is libcurl thread-safe?
|
||||||
5.2 How can I receive all data into a large memory chunk?
|
5.2 How can I receive all data into a large memory chunk?
|
||||||
5.3 How do I fetch multiple files with libcurl?
|
5.3 How do I fetch multiple files with libcurl?
|
||||||
5.4 Does libcurl do Winsock initing on win32 systems?
|
5.4 Does libcurl do Winsock initing on win32 systems?
|
||||||
|
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
|
5.6 What about Keep-Alive or persistant connections?
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
6.1 I have a GPL program, can I use the libcurl library?
|
6.1 I have a GPL program, can I use the libcurl library?
|
||||||
@@ -73,19 +77,16 @@ FAQ
|
|||||||
fact it can also be pronounced 'see URL' also helped.
|
fact it can also be pronounced 'see URL' also helped.
|
||||||
|
|
||||||
Curl supports a range of common internet protocols, currently including
|
Curl supports a range of common internet protocols, currently including
|
||||||
HTTP, HTTPS, FTP, GOPHER, LDAP, DICT and FILE.
|
HTTP, HTTPS, FTP, GOPHER, LDAP, DICT, TELNET and FILE.
|
||||||
|
|
||||||
Please spell it cURL or just curl.
|
We spell it cURL or just curl.
|
||||||
|
|
||||||
1.2 What is libcurl?
|
1.2 What is libcurl?
|
||||||
|
|
||||||
libcurl is the engine inside curl that does all the work. curl is more or
|
libcurl is a reliable, higly portable multiprotocol file transfer library.
|
||||||
less the command line interface that converts the given options into libcurl
|
|
||||||
function invokes. libcurl is a reliable, higly portable multiprotocol file
|
|
||||||
transfer library.
|
|
||||||
|
|
||||||
Any application is free to use libcurl, even commercial or closed-source
|
Any application is free to use libcurl, even commercial or closed-source
|
||||||
ones. Just make sure changes to the lib itself are made public.
|
ones.
|
||||||
|
|
||||||
1.3 What is cURL not?
|
1.3 What is cURL not?
|
||||||
|
|
||||||
@@ -106,34 +107,35 @@ FAQ
|
|||||||
or with PHP.
|
or with PHP.
|
||||||
|
|
||||||
Curl is not a single-OS program. Curl exists, compiles, builds and runs
|
Curl is not a single-OS program. Curl exists, compiles, builds and runs
|
||||||
under a wide range of operating systems, including all modern Unixes,
|
under a wide range of operating systems, including all modern Unixes (and a
|
||||||
Windows, Amiga, BeOS, OS/2, OS X, QNX etc.
|
bunch of older ones too), Windows, Amiga, BeOS, OS/2, OS X, QNX etc.
|
||||||
|
|
||||||
1.4 When will you make curl do XXXX ?
|
1.4 When will you make curl do XXXX ?
|
||||||
|
|
||||||
I love suggestions of what to change in order to make curl and libcurl
|
We love suggestions of what to change in order to make curl and libcurl
|
||||||
better. I do however believe in a few rules when it comes to the future of
|
better. We do however believe in a few rules when it comes to the future of
|
||||||
curl:
|
curl:
|
||||||
|
|
||||||
* It is to remain a command line tool. If you want GUIs or fancy scripting
|
* Curl is to remain a command line tool. If you want GUIs or fancy scripting
|
||||||
capabilities, you're free to write another tool that uses libcurl and that
|
capabilities, you're free to write another tool that uses libcurl and that
|
||||||
offers this. There's no point in having one single tool that does every
|
offers this. There's no point in having a single tool that does every
|
||||||
imaginable thing. That's also one of the great advantages of having the
|
imaginable thing. That's also one of the great advantages of having the
|
||||||
core of curl as a library: libcurl.
|
core of curl as a library.
|
||||||
|
|
||||||
* I do not add things to curl that other small and available tools already
|
* We do not add things to curl that other small and available tools already
|
||||||
do very fine at the side. Curl's output is fine to pipe into another
|
do very fine at the side. Curl's output is fine to pipe into another
|
||||||
program or redirect to another file for the next program to interpret.
|
program or redirect to another file for the next program to interpret.
|
||||||
|
|
||||||
* I focus on protocol related issues and improvements. If you wanna do more
|
* We focus on protocol related issues and improvements. If you wanna do more
|
||||||
magic with the supported protocols than curl currently does, chances are
|
magic with the supported protocols than curl currently does, chances are
|
||||||
big I will agree. If you wanna add more protocols, I may very well
|
big I will agree. If you wanna add more protocols, I may very well
|
||||||
agree.
|
agree.
|
||||||
|
|
||||||
* If you want me to make all the work while you wait for me to implement it
|
* If you want someone else to make all the work while you wait for us to
|
||||||
for you, that is not a very friendly attitude. I spend a considerable time
|
implement it for you, that is not a very friendly attitude. We spend a
|
||||||
already on maintaining and developing curl. In order to get more out of
|
considerable time already on maintaining and developing curl. In order to
|
||||||
me, I trust you will offer some of your time and efforts in return.
|
get more out of us, you should consider trading in some of your time and
|
||||||
|
efforts in return.
|
||||||
|
|
||||||
* If you write the code, chances are bigger that it will get into curl
|
* If you write the code, chances are bigger that it will get into curl
|
||||||
faster.
|
faster.
|
||||||
@@ -181,26 +183,24 @@ FAQ
|
|||||||
|
|
||||||
2.2. Does curl work/build with other SSL libraries?
|
2.2. Does curl work/build with other SSL libraries?
|
||||||
|
|
||||||
Curl has been written to use OpenSSL, although I doubt there would be much
|
Curl has been written to use OpenSSL, although there should not be much
|
||||||
problems using a different library. I just don't know any other free one and
|
problems using a different library. If anyone does "port" curl to use a
|
||||||
that has limited my possibilities to develop against anything else.
|
different SSL library, we are of course very interested in getting the
|
||||||
|
patch!
|
||||||
If anyone does "port" curl to use a commercial SSL library, I am of course
|
|
||||||
very interested in getting the patch!
|
|
||||||
|
|
||||||
2.3. Where can I find a copy of LIBEAY32.DLL?
|
2.3. Where can I find a copy of LIBEAY32.DLL?
|
||||||
|
|
||||||
That is an OpenSSL binary built for Windows.
|
That is an OpenSSL binary built for Windows.
|
||||||
|
|
||||||
Curl uses OpenSSL to do the SSL stuff. The LIBEAY32.DLL is what curl needs
|
Curl uses OpenSSL to do the SSL stuff. The LIBEAY32.DLL is what curl needs
|
||||||
on a windows machine to do https://. Check out the curl web page to find
|
on a windows machine to do https://. Check out the curl web site to find
|
||||||
accurate and up-to-date pointers to recent OpenSSL DDLs and other binary
|
accurate and up-to-date pointers to recent OpenSSL DDLs and other binary
|
||||||
packages.
|
packages.
|
||||||
|
|
||||||
2.4. Does cURL support Socks (RFC 1928) ?
|
2.4. Does cURL support Socks (RFC 1928) ?
|
||||||
|
|
||||||
No. Nobody has wanted it that badly yet. I would appriciate patches that
|
No. Nobody has wanted it that badly yet. We appriciate patches that bring
|
||||||
brings this functionality.
|
this functionality.
|
||||||
|
|
||||||
|
|
||||||
3. Usage problems
|
3. Usage problems
|
||||||
@@ -222,7 +222,7 @@ FAQ
|
|||||||
|
|
||||||
3.2. How do I tell curl to resume a transfer?
|
3.2. How do I tell curl to resume a transfer?
|
||||||
|
|
||||||
Curl supports resume both ways on FTP, download ways on HTTP.
|
Curl supports resumed transfers both ways on both FTP and HTTP.
|
||||||
|
|
||||||
Try the -C option.
|
Try the -C option.
|
||||||
|
|
||||||
@@ -230,14 +230,14 @@ FAQ
|
|||||||
|
|
||||||
You can't simply use -F or -d at your choice. The web server that will
|
You can't simply use -F or -d at your choice. The web server that will
|
||||||
receive your post assumes one of the formats. If the form you're trying to
|
receive your post assumes one of the formats. If the form you're trying to
|
||||||
"fake" sets the type to 'multipart/form-data', than and only then you must
|
"fake" sets the type to 'multipart/form-data', then and only then you must
|
||||||
use the -F type. In all the most common cases, you should use -d which then
|
use the -F type. In all the most common cases, you should use -d which then
|
||||||
causes a posting with the type 'application/x-www-form-urlencoded'.
|
causes a posting with the type 'application/x-www-form-urlencoded'.
|
||||||
|
|
||||||
I have described this in some detail in the README.curl file, and if you
|
This is described in some detail in the README.curl file, and if you don't
|
||||||
don't understand it the first time, read it again before you post questions
|
understand it the first time, read it again before you post questions about
|
||||||
about this to the mailing list. I would also suggest that you read through
|
this to the mailing list. Also, try reading through the mailing list
|
||||||
the mailing list archives for old postings and questions regarding this.
|
archives for old postings and questions regarding this.
|
||||||
|
|
||||||
3.4. How do I tell curl to run custom FTP commands?
|
3.4. How do I tell curl to run custom FTP commands?
|
||||||
|
|
||||||
@@ -281,13 +281,36 @@ FAQ
|
|||||||
|
|
||||||
curl -L http://redirector.com
|
curl -L http://redirector.com
|
||||||
|
|
||||||
|
3.9 How do I use curl in PHP?
|
||||||
|
|
||||||
|
PHP4 has the ability to use libcurl as an internal module if built with that
|
||||||
|
option enabled. You then get a set of extra functions that can be used
|
||||||
|
within your PHP programs. You find all details about those functions in the
|
||||||
|
curl section in the PHP manual, see the online version at:
|
||||||
|
|
||||||
|
http://www.php.net/manual/ref.curl.php
|
||||||
|
|
||||||
|
PHP also offers the option to run a command line, and then you can of course
|
||||||
|
invoke the curl tool using a command line. This is the way to use curl if
|
||||||
|
you're using PHP3 or PHP4 built without curl module support.
|
||||||
|
|
||||||
|
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
|
|
||||||
|
Curl adheres to the HTTP spec, which basically means you can play with *any*
|
||||||
|
protocol that is built ontop of HTTP. Protocols such as SOAP, WEBDAV and
|
||||||
|
XML-RPC are all such ones. You can use -X to set custom requests and -H to
|
||||||
|
set custom headers (or replace internally generated ones).
|
||||||
|
|
||||||
|
Using libcurl or PHP's curl modules is just as fine and you'd just use the
|
||||||
|
proper library options to do the same.
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
|
|
||||||
4.1. Problems connecting to SSL servers.
|
4.1. Problems connecting to SSL servers.
|
||||||
|
|
||||||
It took a very long time before I could sort out why curl had problems
|
It took a very long time before we could sort out why curl had problems to
|
||||||
to connect to certain SSL servers when using SSLeay or OpenSSL v0.9+.
|
connect to certain SSL servers when using SSLeay or OpenSSL v0.9+. The
|
||||||
The error sometimes showed up similar to:
|
error sometimes showed up similar to:
|
||||||
|
|
||||||
16570:error:1407D071:SSL routines:SSL2_READ:bad mac decode:s2_pkt.c:233:
|
16570:error:1407D071:SSL routines:SSL2_READ:bad mac decode:s2_pkt.c:233:
|
||||||
|
|
||||||
@@ -295,12 +318,12 @@ FAQ
|
|||||||
requests properly. To correct this problem, tell curl to select SSLv2 from
|
requests properly. To correct this problem, tell curl to select SSLv2 from
|
||||||
the command line (-2/--sslv2).
|
the command line (-2/--sslv2).
|
||||||
|
|
||||||
I have also seen examples where the remote server didn't like the SSLv2
|
There has also been examples where the remote server didn't like the SSLv2
|
||||||
request and instead you had to force curl to use SSLv3 with -3/--sslv3.
|
request and instead you had to force curl to use SSLv3 with -3/--sslv3.
|
||||||
|
|
||||||
4.2. Why do I get problems when I use & in the URL?
|
4.2. Why do I get problems when I use & or % in the URL?
|
||||||
|
|
||||||
In general unix shells, the & letter is treated special and when used it
|
In general unix shells, the & letter is treated special and when used, it
|
||||||
runs the specified command in the background. To safely send the & as a part
|
runs the specified command in the background. To safely send the & as a part
|
||||||
of a URL, you should qoute the entire URL by using single (') or double (")
|
of a URL, you should qoute the entire URL by using single (') or double (")
|
||||||
quotes around it.
|
quotes around it.
|
||||||
@@ -309,6 +332,12 @@ FAQ
|
|||||||
|
|
||||||
curl 'http://www.altavista.com/cgi-bin/query?text=yes&q=curl'
|
curl 'http://www.altavista.com/cgi-bin/query?text=yes&q=curl'
|
||||||
|
|
||||||
|
In win32, the standard DOS shell treats the %-letter specially and you may
|
||||||
|
need to quote the string properly when % is used in it.
|
||||||
|
|
||||||
|
Also note that if you want the literal %-letter to be part of the data you
|
||||||
|
pass in a POST using -d/--data you must encode it as '%25'.
|
||||||
|
|
||||||
4.3. How can I use {, }, [ or ] to specify multiple URLs?
|
4.3. How can I use {, }, [ or ] to specify multiple URLs?
|
||||||
|
|
||||||
Because those letters have a special meaning to the shell, and to be used in
|
Because those letters have a special meaning to the shell, and to be used in
|
||||||
@@ -318,6 +347,12 @@ FAQ
|
|||||||
|
|
||||||
curl '{curl,www}.haxx.se'
|
curl '{curl,www}.haxx.se'
|
||||||
|
|
||||||
|
To be able to use those letters as actual parts of the URL (without using
|
||||||
|
them for the curl URL "globbing" system), use the -g/--globoff option (curl
|
||||||
|
7.6 and later):
|
||||||
|
|
||||||
|
curl -g 'www.site.com/weirdname[].html'
|
||||||
|
|
||||||
4.4. Why do I get downloaded data even though the web page doesn't exist?
|
4.4. Why do I get downloaded data even though the web page doesn't exist?
|
||||||
|
|
||||||
Curl asks remote servers for the page you specify. If the page doesn't exist
|
Curl asks remote servers for the page you specify. If the page doesn't exist
|
||||||
@@ -330,8 +365,8 @@ FAQ
|
|||||||
|
|
||||||
4.5 Why do I get return code XXX from a HTTP server?
|
4.5 Why do I get return code XXX from a HTTP server?
|
||||||
|
|
||||||
RFC2616 clearly explains the return codes. I'll make a short transcript
|
RFC2616 clearly explains the return codes. This is a short transcript. Go
|
||||||
here. Go read the RFC for exact details:
|
read the RFC for exact details:
|
||||||
|
|
||||||
4.5.1 "400 Bad Request"
|
4.5.1 "400 Bad Request"
|
||||||
|
|
||||||
@@ -367,7 +402,7 @@ FAQ
|
|||||||
|
|
||||||
4.7. How do I keep usernames and passwords secret in Curl command lines?
|
4.7. How do I keep usernames and passwords secret in Curl command lines?
|
||||||
|
|
||||||
I see this problem as two parts:
|
This problem has two sides:
|
||||||
|
|
||||||
The first part is to avoid having clear-text passwords in the command line
|
The first part is to avoid having clear-text passwords in the command line
|
||||||
so that they don't appear in 'ps' outputs and similar. That is easily
|
so that they don't appear in 'ps' outputs and similar. That is easily
|
||||||
@@ -392,8 +427,7 @@ FAQ
|
|||||||
you have.
|
you have.
|
||||||
|
|
||||||
If there is a bug, post a bug report in the Curl Bug Track System over at
|
If there is a bug, post a bug report in the Curl Bug Track System over at
|
||||||
http://sourceforge.net/bugs/?group_id=976 or mail a detailed bug description
|
http://sourceforge.net/bugs/?group_id=976
|
||||||
to curl-bug@haxx.se.
|
|
||||||
|
|
||||||
Always include as many details you can think of, including curl version,
|
Always include as many details you can think of, including curl version,
|
||||||
operating system name and version and complete instructions how to repeat
|
operating system name and version and complete instructions how to repeat
|
||||||
@@ -402,19 +436,21 @@ FAQ
|
|||||||
4.9. Curl can't authenticate to the server that requires NTLM?
|
4.9. Curl can't authenticate to the server that requires NTLM?
|
||||||
|
|
||||||
NTLM is a Microsoft proprietary protocol. Unfortunately, curl does not
|
NTLM is a Microsoft proprietary protocol. Unfortunately, curl does not
|
||||||
currently support that.
|
currently support that. Proprietary formats are evil. You should not use
|
||||||
|
such ones.
|
||||||
|
|
||||||
5. libcurl Issues
|
5. libcurl Issues
|
||||||
|
|
||||||
5.1. Is libcurl thread safe?
|
5.1. Is libcurl thread-safe?
|
||||||
|
|
||||||
We have attempted to write the entire code adjusted for multi-threaded
|
Yes.
|
||||||
programs. If your system has such, curl will attempt to use threadsafe
|
|
||||||
functions instead of non-safe ones.
|
|
||||||
|
|
||||||
I am very interested in once and for all getting some kind of report or
|
We have written the libcurl code specificly adjusted for multi-threaded
|
||||||
README file from those who have used libcurl in a threaded environment,
|
programs. libcurl will use thread-safe functions instead of non-safe ones if
|
||||||
since I haven't and I get this question more and more frequently!
|
your system has such.
|
||||||
|
|
||||||
|
We would appriciate some kind of report or README file from those who have
|
||||||
|
used libcurl in a threaded environment.
|
||||||
|
|
||||||
5.2 How can I receive all data into a large memory chunk?
|
5.2 How can I receive all data into a large memory chunk?
|
||||||
|
|
||||||
@@ -451,9 +487,16 @@ FAQ
|
|||||||
|
|
||||||
5.3 How do I fetch multiple files with libcurl?
|
5.3 How do I fetch multiple files with libcurl?
|
||||||
|
|
||||||
The easy interface of libcurl does not support multiple requests using the
|
Starting with version 7.7, curl and libcurl will have excellent support for
|
||||||
same connection. The only available way to do multiple requests is to
|
transferring multiple files. You should just repeatedly set new URLs with
|
||||||
init/perform/cleanup for each request.
|
curl_easy_setopt() and then transfer it with curl_easy_perform(). The handle
|
||||||
|
you get from curl_easy_init() is not only reusable starting with libcurl
|
||||||
|
7.7, but also you're encouraged to reuse it if you can, as that will enable
|
||||||
|
libcurl to use persistant connections.
|
||||||
|
|
||||||
|
For libcurl prior to 7.7, there was no multiple file support. The only
|
||||||
|
available way to do multiple requests was to init/perform/cleanup for each
|
||||||
|
transfer.
|
||||||
|
|
||||||
5.4 Does libcurl do Winsock initing on win32 systems?
|
5.4 Does libcurl do Winsock initing on win32 systems?
|
||||||
|
|
||||||
@@ -465,9 +508,27 @@ FAQ
|
|||||||
use several different libraries and parts, and there's no reason for every
|
use several different libraries and parts, and there's no reason for every
|
||||||
single library to do this.
|
single library to do this.
|
||||||
|
|
||||||
6. License Issues
|
5.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
|
|
||||||
NOTE: This section is now updated to concern curl 7.5.2 or later!
|
Yes, but you cannot open a FILE * and pass the pointer to a DLL and have
|
||||||
|
that DLL use the FILE *. If you set CURLOPT_FILE you must also use
|
||||||
|
CURLOPT_WRITEFUNCTION as well to set a function that writes the file, even
|
||||||
|
if that simply writes the data to the specified FILE*. Similarly, if you use
|
||||||
|
CURLOPT_INFILE you must also specify CURLOPT_READFUNCTION.
|
||||||
|
|
||||||
|
(Provided by Joel DeYoung and Bob Schader)
|
||||||
|
|
||||||
|
5.6 What about Keep-Alive or persistant connections?
|
||||||
|
|
||||||
|
Starting with version 7.7, curl and libcurl will have excellent support for
|
||||||
|
persistant connections when transferring several files from the same server.
|
||||||
|
Curl will attempt to reuse connections for all URLs specified on the same
|
||||||
|
command line/config file, and libcurl will reuse connections for all
|
||||||
|
transfers that are made using the same libcurl handle.
|
||||||
|
|
||||||
|
Previous versions had no persistant connection support.
|
||||||
|
|
||||||
|
6. License Issues
|
||||||
|
|
||||||
Curl and libcurl are released under a MIT/X derivate license *or* the MPL,
|
Curl and libcurl are released under a MIT/X derivate license *or* the MPL,
|
||||||
the Mozilla Public License. To get a really good answer to your license
|
the Mozilla Public License. To get a really good answer to your license
|
||||||
@@ -485,27 +546,25 @@ FAQ
|
|||||||
|
|
||||||
6.2. I have a closed-source program, can I use the libcurl library?
|
6.2. I have a closed-source program, can I use the libcurl library?
|
||||||
|
|
||||||
Yes.
|
Yes!
|
||||||
|
|
||||||
libcurl does not put any restrictions on the program that uses the
|
libcurl does not put any restrictions on the program that uses the library.
|
||||||
library.
|
|
||||||
|
|
||||||
6.3. I have a BSD licensed program, can I use the libcurl library?
|
6.3. I have a BSD licensed program, can I use the libcurl library?
|
||||||
|
|
||||||
Yes.
|
Yes!
|
||||||
|
|
||||||
libcurl does not put any restrictions on the program that uses the
|
libcurl does not put any restrictions on the program that uses the library.
|
||||||
library.
|
|
||||||
|
|
||||||
6.4. I have a program that uses LGPL libraries, can I use libcurl?
|
6.4. I have a program that uses LGPL libraries, can I use libcurl?
|
||||||
|
|
||||||
Yes.
|
Yes!
|
||||||
|
|
||||||
The LGPL license don't clash with other licenses.
|
The LGPL license doesn't clash with other licenses.
|
||||||
|
|
||||||
6.5. Can I modify curl/libcurl for my program and keep the changes secret?
|
6.5. Can I modify curl/libcurl for my program and keep the changes secret?
|
||||||
|
|
||||||
Yes.
|
Yes!
|
||||||
|
|
||||||
The MIT/X derivate license practically allows you to do almost anything with
|
The MIT/X derivate license practically allows you to do almost anything with
|
||||||
the sources, on the condition that the copyright texts in the sources are
|
the sources, on the condition that the copyright texts in the sources are
|
||||||
@@ -513,9 +572,12 @@ FAQ
|
|||||||
|
|
||||||
6.6. Can you please change the curl/libcurl license to XXXX?
|
6.6. Can you please change the curl/libcurl license to XXXX?
|
||||||
|
|
||||||
No. We carefully picked this license years ago and a large amount of people
|
No.
|
||||||
have contributed with source code knowing that this is the license we
|
|
||||||
use. This license puts the restrictions we want on curl/libcurl and it does
|
We have carefully picked this license after years of development and
|
||||||
not spread to other programs or libraries that use it. The recent dual
|
discussions and a large amount of people have contributed with source code
|
||||||
license modification should make it possible for everyone to use libcurl or
|
knowing that this is the license we use. This license puts the restrictions
|
||||||
curl in their projects, no matter what license they already have in use.
|
we want on curl/libcurl and it does not spread to other programs or
|
||||||
|
libraries that use it. The recent dual license modification should make it
|
||||||
|
possible for everyone to use libcurl or curl in their projects, no matter
|
||||||
|
what license they already have in use.
|
||||||
|
@@ -17,18 +17,21 @@ Misc
|
|||||||
- progress bar/time specs while downloading
|
- progress bar/time specs while downloading
|
||||||
- "standard" proxy environment variables support
|
- "standard" proxy environment variables support
|
||||||
- config file support
|
- config file support
|
||||||
- compiles on win32
|
- compiles on win32 (reported built on 29 operating systems)
|
||||||
- redirectable stderr
|
- redirectable stderr
|
||||||
- use selected network interface for outgoing traffic
|
- use selected network interface for outgoing traffic
|
||||||
|
- IPv6 support
|
||||||
|
- persistant connections
|
||||||
|
|
||||||
HTTP
|
HTTP
|
||||||
|
- HTTP/1.1 compliant
|
||||||
- GET
|
- GET
|
||||||
- PUT
|
- PUT
|
||||||
- HEAD
|
- HEAD
|
||||||
- POST
|
- POST
|
||||||
- multipart POST
|
- multipart POST
|
||||||
- authentication
|
- authentication
|
||||||
- resume
|
- resume (both GET and PUT)
|
||||||
- follow redirects
|
- follow redirects
|
||||||
- maximum amount of redirects to follow
|
- maximum amount of redirects to follow
|
||||||
- custom HTTP request
|
- custom HTTP request
|
||||||
@@ -71,6 +74,7 @@ FTP
|
|||||||
|
|
||||||
TELNET
|
TELNET
|
||||||
- connection negotiation
|
- connection negotiation
|
||||||
|
- custom telnet options
|
||||||
- stdin/stdout I/O
|
- stdin/stdout I/O
|
||||||
|
|
||||||
LDAP (*2)
|
LDAP (*2)
|
||||||
|
40
docs/INSTALL
40
docs/INSTALL
@@ -84,15 +84,31 @@ UNIX
|
|||||||
|
|
||||||
KNOWN PROBLEMS
|
KNOWN PROBLEMS
|
||||||
|
|
||||||
If you happen to have autoconf installed, but a version older than
|
If you happen to have autoconf installed, but a version older than 2.12
|
||||||
2.12 you will get into trouble. Then you can still build curl by
|
you will get into trouble. Then you can still build curl by issuing these
|
||||||
issuing these commands: (from Ralph Beckmann <rabe@uni-paderborn.de>)
|
commands (note that this requires curl to be built staticly): (from Ralph
|
||||||
|
Beckmann)
|
||||||
|
|
||||||
./configure [...]
|
./configure [...]
|
||||||
cd lib; make; cd ..
|
cd lib; make; cd ..
|
||||||
cd src; make; cd ..
|
cd src; make; cd ..
|
||||||
cp src/curl elsewhere/bin/
|
cp src/curl elsewhere/bin/
|
||||||
|
|
||||||
|
As suggested by David West, you can make a faked version of autoconf and
|
||||||
|
autoheader:
|
||||||
|
|
||||||
|
----start of autoconf----
|
||||||
|
#!/bin/bash
|
||||||
|
#fake autoconf for building curl
|
||||||
|
if [ "$1" = "--version" ] then
|
||||||
|
echo "Autoconf version 2.13"
|
||||||
|
fi
|
||||||
|
----end of autoconf----
|
||||||
|
|
||||||
|
Then make autoheader a symbolic link to the same script and make sure
|
||||||
|
they're executable and set to appear in the path *BEFORE* the actual (but
|
||||||
|
obsolete) autoconf and autoheader scripts.
|
||||||
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
|
|
||||||
Remember, to force configure to use the standard cc compiler if both
|
Remember, to force configure to use the standard cc compiler if both
|
||||||
@@ -124,6 +140,14 @@ UNIX
|
|||||||
|
|
||||||
./configure --with-krb4=/usr/athena
|
./configure --with-krb4=/usr/athena
|
||||||
|
|
||||||
|
If your system support shared libraries, but you want to built a static
|
||||||
|
version only, you can disable building the shared version by using:
|
||||||
|
|
||||||
|
./configure --disable-shared
|
||||||
|
|
||||||
|
If you're a curl developer and use gcc, you might want to enable more
|
||||||
|
debug options with the --enable-debug option.
|
||||||
|
|
||||||
Win32
|
Win32
|
||||||
=====
|
=====
|
||||||
|
|
||||||
@@ -154,6 +178,8 @@ Win32
|
|||||||
set, then run 'nmake -f Makefile.vc6' in the lib/ dir and then
|
set, then run 'nmake -f Makefile.vc6' in the lib/ dir and then
|
||||||
'nmake -f Makefile.vc6' in the src/ dir.
|
'nmake -f Makefile.vc6' in the src/ dir.
|
||||||
|
|
||||||
|
The vcvars32.bat file is part of the Microsoft development environment.
|
||||||
|
|
||||||
IDE-style
|
IDE-style
|
||||||
-------------------------
|
-------------------------
|
||||||
If you use VC++, Borland or similar compilers. Include all lib source
|
If you use VC++, Borland or similar compilers. Include all lib source
|
||||||
@@ -199,6 +225,8 @@ Win32
|
|||||||
set, then run 'nmake -f Makefile.vc6 release-ssl' in the lib/ dir and
|
set, then run 'nmake -f Makefile.vc6 release-ssl' in the lib/ dir and
|
||||||
then 'nmake -f Makefile.vc6' in the src/ dir.
|
then 'nmake -f Makefile.vc6' in the src/ dir.
|
||||||
|
|
||||||
|
The vcvars32.bat file is part of the Microsoft development environment.
|
||||||
|
|
||||||
Microsoft / Borland style
|
Microsoft / Borland style
|
||||||
-------------------------
|
-------------------------
|
||||||
If you have OpenSSL, and want curl to take advantage of it, edit your
|
If you have OpenSSL, and want curl to take advantage of it, edit your
|
||||||
@@ -256,18 +284,20 @@ PORTS
|
|||||||
- PowerPC Mac OS X
|
- PowerPC Mac OS X
|
||||||
- Sparc Linux
|
- Sparc Linux
|
||||||
- Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8
|
- Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8
|
||||||
- Sparc SunOS 4.1.*
|
- Sparc SunOS 4.1.X
|
||||||
- i386 BeOS
|
- i386 BeOS
|
||||||
- i386 FreeBSD
|
- i386 FreeBSD
|
||||||
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4
|
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4
|
||||||
- i386 NetBSD
|
- i386 NetBSD
|
||||||
- i386 OS/2
|
- i386 OS/2
|
||||||
- i386 OpenBSD
|
- i386 OpenBSD
|
||||||
|
- i386 SCO unix
|
||||||
- i386 Solaris 2.7
|
- i386 Solaris 2.7
|
||||||
- i386 Windows 95, 98, NT, 2000
|
- i386 Windows 95, 98, ME, NT, 2000
|
||||||
- ia64 Linux 2.3.99
|
- ia64 Linux 2.3.99
|
||||||
- m68k AmigaOS 3
|
- m68k AmigaOS 3
|
||||||
- m68k OpenBSD
|
- m68k OpenBSD
|
||||||
|
- StrongARM NetBSD 1.4.1
|
||||||
|
|
||||||
OpenSSL
|
OpenSSL
|
||||||
=======
|
=======
|
||||||
|
242
docs/INTERNALS
242
docs/INTERNALS
@@ -1,3 +1,4 @@
|
|||||||
|
Updated for curl 7.7 on March 13, 2001
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -6,15 +7,14 @@
|
|||||||
|
|
||||||
INTERNALS
|
INTERNALS
|
||||||
|
|
||||||
The project is kind of split in two. The library and the client. The client
|
The project is split in two. The library and the client. The client part uses
|
||||||
part uses the library, but the library is meant to be designed to allow other
|
the library, but the library is designed to allow other applications to use
|
||||||
applications to use it.
|
it.
|
||||||
|
|
||||||
Thus, the largest amount of code and complexity is in the library part.
|
The largest amount of code and complexity is in the library part.
|
||||||
|
|
||||||
CVS
|
CVS
|
||||||
===
|
===
|
||||||
|
|
||||||
All changes to the sources are committed to the CVS repository as soon as
|
All changes to the sources are committed to the CVS repository as soon as
|
||||||
they're somewhat verified to work. Changes shall be commited as independently
|
they're somewhat verified to work. Changes shall be commited as independently
|
||||||
as possible so that individual changes can be easier spotted and tracked
|
as possible so that individual changes can be easier spotted and tracked
|
||||||
@@ -27,47 +27,51 @@ Windows vs Unix
|
|||||||
===============
|
===============
|
||||||
|
|
||||||
There are a few differences in how to program curl the unix way compared to
|
There are a few differences in how to program curl the unix way compared to
|
||||||
the Windows way. The four most notable details are:
|
the Windows way. The four perhaps most notable details are:
|
||||||
|
|
||||||
|
1. Different function names for socket operations.
|
||||||
|
|
||||||
|
In curl, this is solved with defines and macros, so that the source looks
|
||||||
|
the same at all places except for the header file that defines them. The
|
||||||
|
macros in use are sclose(), sread() and swrite().
|
||||||
|
|
||||||
|
2. Windows requires a couple of init calls for the socket stuff.
|
||||||
|
|
||||||
|
Those must be made by the application that uses libcurl, in curl that means
|
||||||
|
src/main.c has some code #ifdef'ed to do just that.
|
||||||
|
|
||||||
1. Different function names for close(), read(), write()
|
|
||||||
2. Windows requires a couple of init calls for the socket stuff
|
|
||||||
3. The file descriptors for network communication and file operations are
|
3. The file descriptors for network communication and file operations are
|
||||||
not easily interchangable as in unix
|
not easily interchangable as in unix.
|
||||||
|
|
||||||
|
We avoid this by not trying any funny tricks on file descriptors.
|
||||||
|
|
||||||
4. When writing data to stdout, Windows makes end-of-lines the DOS way, thus
|
4. When writing data to stdout, Windows makes end-of-lines the DOS way, thus
|
||||||
destroying binary data, although you do want that conversion if it is
|
destroying binary data, although you do want that conversion if it is
|
||||||
text coming through... (sigh)
|
text coming through... (sigh)
|
||||||
|
|
||||||
In curl, (1) is made with defines and macros, so that the source looks the
|
We set stdout to binary under windows
|
||||||
same at all places except for the header file that defines them.
|
|
||||||
|
|
||||||
(2) must be made by the application that uses libcurl, in curl that means
|
Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All
|
||||||
src/main.c has some code #ifdef'ed to do just that.
|
|
||||||
|
|
||||||
(3) is simply avoided by not trying any funny tricks on file descriptors.
|
|
||||||
|
|
||||||
(4) we set stdout to binary under windows
|
|
||||||
|
|
||||||
Inside the source code, I do make an effort to avoid '#ifdef WIN32'. All
|
|
||||||
conditionals that deal with features *should* instead be in the format
|
conditionals that deal with features *should* instead be in the format
|
||||||
'#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts,
|
'#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts,
|
||||||
I maintain two config-win32.h files (one in / and one in src/) that are
|
we maintain two config-win32.h files (one in / and one in src/) that are
|
||||||
supposed to look exactly as a config.h file would have looked like on a
|
supposed to look exactly as a config.h file would have looked like on a
|
||||||
Windows machine!
|
Windows machine!
|
||||||
|
|
||||||
|
Generally speaking: always remember that this will be compiled on dozens of
|
||||||
|
operating systems. Don't walk on the edge.
|
||||||
|
|
||||||
Library
|
Library
|
||||||
=======
|
=======
|
||||||
|
|
||||||
As described elsewhere, libcurl is meant to get two different "layers" of
|
|
||||||
interfaces. At the present point only the high-level, the "easy", interface
|
|
||||||
has been fully implemented and documented. We assume the easy-interface in
|
|
||||||
this description, the low-level interface will be documented when fully
|
|
||||||
implemented.
|
|
||||||
|
|
||||||
There are plenty of entry points to the library, namely each publicly defined
|
There are plenty of entry points to the library, namely each publicly defined
|
||||||
function that libcurl offers to applications. All of those functions are
|
function that libcurl offers to applications. All of those functions are
|
||||||
rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are
|
rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are
|
||||||
put in the lib/easy.c file.
|
put in the lib/easy.c file.
|
||||||
|
|
||||||
|
All printf()-style functions use the supplied clones in lib/mprintf.c. This
|
||||||
|
makes sure we stay absolutely platform independent.
|
||||||
|
|
||||||
curl_easy_init() allocates an internal struct and makes some initializations.
|
curl_easy_init() allocates an internal struct and makes some initializations.
|
||||||
The returned handle does not revail internals.
|
The returned handle does not revail internals.
|
||||||
|
|
||||||
@@ -77,38 +81,58 @@ Library
|
|||||||
|
|
||||||
curl_easy_perform() does a whole lot of things:
|
curl_easy_perform() does a whole lot of things:
|
||||||
|
|
||||||
The function analyzes the URL, get the different components and connects to
|
It starts off in the lib/easy.c file by calling curl_transfer(), but the main
|
||||||
the remote host. This may involve using a proxy and/or using SSL. The
|
work is lib/url.c. The function first analyzes the URL, it separates the
|
||||||
GetHost() function in lib/hostip.c is used for looking up host names.
|
different components and connects to the remote host. This may involve using
|
||||||
|
a proxy and/or using SSL. The Curl_gethost() function in lib/hostip.c is used
|
||||||
|
for looking up host names.
|
||||||
|
|
||||||
When connected, the proper function is called. The functions are named after
|
When connected, the proper protocol-specific function is called. The
|
||||||
the protocols they handle. ftp(), http(), dict(), etc. They all reside in
|
functions are named after the protocols they handle. Curl_ftp(), Curl_http(),
|
||||||
their respective files (ftp.c, http.c and dict.c).
|
Curl_dict(), etc. They all reside in their respective files (ftp.c, http.c
|
||||||
|
and dict.c).
|
||||||
|
|
||||||
The protocol-specific functions deal with protocol-specific negotiations and
|
The protocol-specific functions of course deal with protocol-specific
|
||||||
setup. They have access to the sendf() (from lib/sendf.c) function to send
|
negotiations and setup. They have access to the Curl_sendf() (from
|
||||||
printf-style formatted data to the remote host and when they're ready to make
|
lib/sendf.c) function to send printf-style formatted data to the remote host
|
||||||
the actual file transfer they call the Transfer() function (in
|
and when they're ready to make the actual file transfer they call the
|
||||||
lib/download.c) to do the transfer. All printf()-style functions use the
|
Curl_Transfer() function (in lib/transfer.c) to setup the transfer and
|
||||||
supplied clones in lib/mprintf.c.
|
returns. Curl_perform() then calls Transfer() in lib/transfer.c that performs
|
||||||
|
the entire file transfer. Curl_perform() is what does the main "connect - do
|
||||||
|
- transfer - done" loop. It loops if there's a Location: to follow.
|
||||||
|
|
||||||
While transfering, the progress functions in lib/progress.c are called at a
|
During transfer, the progress functions in lib/progress.c are called at a
|
||||||
frequent interval (or at the user's choice, a specified callback might get
|
frequent interval (or at the user's choice, a specified callback might get
|
||||||
called). The speedcheck functions in lib/speedcheck.c are also used to verify
|
called). The speedcheck functions in lib/speedcheck.c are also used to verify
|
||||||
that the transfer is as fast as required.
|
that the transfer is as fast as required.
|
||||||
|
|
||||||
When completed curl_easy_cleanup() should be called to free up used
|
When completed, the curl_easy_cleanup() should be called to free up used
|
||||||
resources.
|
resources.
|
||||||
|
|
||||||
|
A quick roundup on internal function sequences (many of these call
|
||||||
|
protocol-specific function-pointers):
|
||||||
|
|
||||||
|
curl_connect - connects to a remote site and does initial connect fluff
|
||||||
|
This also checks for an existing connection to the requested site and uses
|
||||||
|
that one if it is possible.
|
||||||
|
|
||||||
|
curl_do - starts a transfer
|
||||||
|
curl_transfer() - transfers data
|
||||||
|
curl_done - ends a transfer
|
||||||
|
|
||||||
|
curl_disconnect - disconnects from a remote site. This is called when the
|
||||||
|
disconnect is really requested, which doesn't necessarily have to be
|
||||||
|
exactly after curl_done in case we want to keep the connection open for
|
||||||
|
a while.
|
||||||
|
|
||||||
HTTP(S)
|
HTTP(S)
|
||||||
|
|
||||||
HTTP offers a lot and is the protocol in curl that uses the most lines of
|
HTTP offers a lot and is the protocol in curl that uses the most lines of
|
||||||
code. There is a special file (lib/formdata.c) that offers all the multipart
|
code. There is a special file (lib/formdata.c) that offers all the multipart
|
||||||
post functions.
|
post functions.
|
||||||
|
|
||||||
base64-functions for user+password stuff is in (lib/base64.c) and all
|
base64-functions for user+password stuff (and more) is in (lib/base64.c) and
|
||||||
functions for parsing and sending cookies are found in
|
all functions for parsing and sending cookies are found in (lib/cookie.c).
|
||||||
(lib/cookie.c).
|
|
||||||
|
|
||||||
HTTPS uses in almost every means the same procedure as HTTP, with only two
|
HTTPS uses in almost every means the same procedure as HTTP, with only two
|
||||||
exceptions: the connect procedure is different and the function used to read
|
exceptions: the connect procedure is different and the function used to read
|
||||||
@@ -116,11 +140,27 @@ Library
|
|||||||
the source by the use of curl_read() for reading and curl_write() for writing
|
the source by the use of curl_read() for reading and curl_write() for writing
|
||||||
data to the remote server.
|
data to the remote server.
|
||||||
|
|
||||||
|
http_chunks.c contains functions that understands HTTP 1.1 chunked transfer
|
||||||
|
encoding.
|
||||||
|
|
||||||
|
An interesting detail with the HTTP(S) request, is the add_buffer() series of
|
||||||
|
functions we use. They append data to one single buffer, and when the
|
||||||
|
building is done the entire request is sent off in one single write. This is
|
||||||
|
done this way to overcome problems with flawed firewalls and lame servers.
|
||||||
|
|
||||||
FTP
|
FTP
|
||||||
|
|
||||||
The if2ip() function can be used for getting the IP number of a specified
|
The Curl_if2ip() function can be used for getting the IP number of a
|
||||||
network interface, and it resides in lib/if2ip.c. It is only used for the FTP
|
specified network interface, and it resides in lib/if2ip.c.
|
||||||
PORT command.
|
|
||||||
|
Curl_ftpsendf() is used for sending FTP commands to the remote server. It was
|
||||||
|
made a separate function to prevent us programmers from forgetting that they
|
||||||
|
must be CRLF terminated. They must also be sent in one single write() to make
|
||||||
|
firewalls and similar happy.
|
||||||
|
|
||||||
|
Kerberos
|
||||||
|
|
||||||
|
The kerberos support is mainly in lib/krb4.c and lib/security.c.
|
||||||
|
|
||||||
TELNET
|
TELNET
|
||||||
|
|
||||||
@@ -145,26 +185,85 @@ Library
|
|||||||
|
|
||||||
lib/getenv.c offers curl_getenv() which is for reading environment variables
|
lib/getenv.c offers curl_getenv() which is for reading environment variables
|
||||||
in a neat platform independent way. That's used in the client, but also in
|
in a neat platform independent way. That's used in the client, but also in
|
||||||
lib/url.c when checking the proxy environment variables.
|
lib/url.c when checking the proxy environment variables. Note that contrary
|
||||||
|
to the normal unix getenv(), this returns an allocated buffer that must be
|
||||||
|
free()ed after use.
|
||||||
|
|
||||||
lib/netrc.c holds the .netrc parser
|
lib/netrc.c holds the .netrc parser
|
||||||
|
|
||||||
lib/timeval.c features replacement functions for systems that don't have
|
lib/timeval.c features replacement functions for systems that don't have
|
||||||
gettimeofday().
|
gettimeofday() and a few support functions for timeval convertions.
|
||||||
|
|
||||||
A function named curl_version() that returns the full curl version string is
|
A function named curl_version() that returns the full curl version string is
|
||||||
found in lib/version.c.
|
found in lib/version.c.
|
||||||
|
|
||||||
|
If authentication is requested but no password is given, a getpass_r() clone
|
||||||
|
exists in lib/getpass.c. libcurl offers a custom callback that can be used
|
||||||
|
instead of this, but it doesn't change much to us.
|
||||||
|
|
||||||
|
Persistant Connections
|
||||||
|
======================
|
||||||
|
|
||||||
|
With curl 7.7, we added persistant connection support to libcurl which has
|
||||||
|
introduced a somewhat different treatmeant of things inside of libcurl.
|
||||||
|
|
||||||
|
o The 'UrlData' struct returned in the curl_easy_init() call must never
|
||||||
|
hold connection-oriented data. It is meant to hold the root data as well
|
||||||
|
as all the options etc that the library-user may choose.
|
||||||
|
o The 'UrlData' struct holds the cache array of pointers to 'connectdata'
|
||||||
|
structs. There's one connectdata struct for each connection that libcurl
|
||||||
|
knows about.
|
||||||
|
o This also enables the 'curl handle' to be reused on subsequent transfers,
|
||||||
|
something that was illegal in pre-7.7 versions.
|
||||||
|
o When we are about to perform a transfer with curl_easy_perform(), we first
|
||||||
|
check for an already existing connection in the cache that we can use,
|
||||||
|
otherwise we create a new one and add to the cache. If the cache is full
|
||||||
|
already when we add a new connection, we close one of the present ones. We
|
||||||
|
select which one to close dependent on the close policy that may have been
|
||||||
|
previously set.
|
||||||
|
o When the tranfer operation is complete, we try to leave the connection open.
|
||||||
|
Particular options may tell us not to, and protocols may signal closure on
|
||||||
|
connections and then we don't keep it open of course.
|
||||||
|
o When curl_easy_cleanup() is called, we close all still opened connections.
|
||||||
|
|
||||||
|
You do realize that the curl handle must be re-used in order for the
|
||||||
|
persistant connections to work.
|
||||||
|
|
||||||
|
Library Symbols
|
||||||
|
===============
|
||||||
|
|
||||||
|
All symbols used internally in libcurl must use a 'Curl_' prefix if they're
|
||||||
|
used in more than a single file. Single-file symbols must be made
|
||||||
|
static. Public (exported) symbols must use a 'curl_' prefix. (There are
|
||||||
|
exceptions, but they are destined to be changed to follow this pattern in the
|
||||||
|
future.)
|
||||||
|
|
||||||
|
Return Codes and Informationals
|
||||||
|
===============================
|
||||||
|
|
||||||
|
I've made things simple. Almost every function in libcurl returns a CURLcode,
|
||||||
|
that must be CURLE_OK if everything is OK or otherwise a suitable error code
|
||||||
|
as the curl/curl.h include file defines. The very spot that detects an error
|
||||||
|
must use the Curl_failf() function to set the human-readable error
|
||||||
|
description.
|
||||||
|
|
||||||
|
In aiding the user to understand what's happening and to debug curl usage, we
|
||||||
|
must supply a fair amount of informational messages by using the Curl_infof()
|
||||||
|
function. Those messages are only displayed when the user explicitly asks for
|
||||||
|
them. They are best used when revealing information that isn't otherwise
|
||||||
|
obvious.
|
||||||
|
|
||||||
Client
|
Client
|
||||||
======
|
======
|
||||||
|
|
||||||
main() resides in src/main.c together with most of the client code.
|
main() resides in src/main.c together with most of the client code.
|
||||||
src/hugehelp.c is automatically generated by the mkhelp.pl perl script to
|
src/hugehelp.c is automatically generated by the mkhelp.pl perl script to
|
||||||
display the complete "manual" and the src/urlglob.c file holds the functions
|
display the complete "manual" and the src/urlglob.c file holds the functions
|
||||||
used for the multiple-URL support.
|
used for the URL-"globbing" support. Globbing in the sense that the {} and []
|
||||||
|
expansion stuff is there.
|
||||||
|
|
||||||
The client mostly mess around to setup its config struct properly, then it
|
The client mostly messes around to setup its 'config' struct properly, then
|
||||||
calls the curl_easy_*() functions of the library and when it gets back
|
it calls the curl_easy_*() functions of the library and when it gets back
|
||||||
control after the curl_easy_perform() it cleans up the library, checks status
|
control after the curl_easy_perform() it cleans up the library, checks status
|
||||||
and exits.
|
and exits.
|
||||||
|
|
||||||
@@ -173,10 +272,30 @@ Client
|
|||||||
curl_easy_getinfo() function to extract useful information from the curl
|
curl_easy_getinfo() function to extract useful information from the curl
|
||||||
session.
|
session.
|
||||||
|
|
||||||
|
Recent versions may loop and do all that several times if many URLs were
|
||||||
|
specified on the command line or config file.
|
||||||
|
|
||||||
|
Memory Debugging
|
||||||
|
================
|
||||||
|
|
||||||
|
The file named lib/memdebug.c contains debug-versions of a few
|
||||||
|
functions. Functions such as malloc, free, fopen, fclose, etc that somehow
|
||||||
|
deal with resources that might give us problems if we "leak" them. The
|
||||||
|
functions in the memdebug system do nothing fancy, they do their normal
|
||||||
|
function and then log information about what they just did. The logged data
|
||||||
|
can then be analyzed after a complete session,
|
||||||
|
|
||||||
|
memanalyze.pl is a perl script present only present in CVS (not part of the
|
||||||
|
release archives) that analyzes a log file generated by the memdebug
|
||||||
|
system. It detects if resources are allocated but never freed and other kinds
|
||||||
|
of errors related to resource management.
|
||||||
|
|
||||||
|
Use -DMALLOCDEBUG when compiling to enable memory debugging.
|
||||||
|
|
||||||
Test Suite
|
Test Suite
|
||||||
==========
|
==========
|
||||||
|
|
||||||
During November 2000, a test suite has evolved. It is placed in its own
|
Since November 2000, a test suite has evolved. It is placed in its own
|
||||||
subdirectory directly off the root in the curl archive tree, and it contains
|
subdirectory directly off the root in the curl archive tree, and it contains
|
||||||
a bunch of scripts and a lot of test case data.
|
a bunch of scripts and a lot of test case data.
|
||||||
|
|
||||||
@@ -184,5 +303,20 @@ Test Suite
|
|||||||
httpserver.pl and ftpserver.pl before all the test cases are performed. The
|
httpserver.pl and ftpserver.pl before all the test cases are performed. The
|
||||||
test suite currently only runs on unix-like platforms.
|
test suite currently only runs on unix-like platforms.
|
||||||
|
|
||||||
You'll find a complete description of the test case data files in the README
|
You'll find a complete description of the test case data files in the
|
||||||
file in the test directory.
|
tests/README file.
|
||||||
|
|
||||||
|
The test suite automatically detects if curl was built with the memory
|
||||||
|
debugging enabled, and if it was it will detect memory leaks too.
|
||||||
|
|
||||||
|
Building Releases
|
||||||
|
=================
|
||||||
|
|
||||||
|
There's no magic to this. When you consider everything stable enough to be
|
||||||
|
released, run the 'maketgz' script (using 'make distcheck' will give you a
|
||||||
|
pretty good view on the status of the current sources). maketgz prompts for
|
||||||
|
version number of the client and the library before it creates a release
|
||||||
|
archive. maketgz uses 'make dist' for the actual archive building, why you
|
||||||
|
need to fill in the Makefile.am files properly for which files that should
|
||||||
|
be included in the release archives.
|
||||||
|
|
||||||
|
115
docs/LIBCURL
115
docs/LIBCURL
@@ -4,58 +4,91 @@
|
|||||||
| | | |_) | (__| |_| | | | |
|
| | | |_) | (__| |_| | | | |
|
||||||
|_|_|_.__/ \___|\__,_|_| |_|
|
|_|_|_.__/ \___|\__,_|_| |_|
|
||||||
|
|
||||||
|
How To Use Libcurl In Your C/C++ Program
|
||||||
|
|
||||||
How To Use Libcurl In Your Program
|
[ libcurl can be used directly from within your PHP or Perl programs as well,
|
||||||
|
look elsewhere for documentation on this ]
|
||||||
|
|
||||||
Interfaces
|
The interface is meant to be very simple for applictions/programmers, hence
|
||||||
|
the name "easy". We have therefore minimized the number of entries.
|
||||||
libcurl currently offers two different interfaces to the URL transfer
|
|
||||||
engine. They can be seen as one low-level and one high-level, in the sense
|
|
||||||
that the low-level one will allow you to deal with a lot more details but on
|
|
||||||
the other hand not offer as many fancy features (such as Location:
|
|
||||||
following). The high-level interface is supposed to be a built-in
|
|
||||||
implementation of the low-level interface. You will not be able to mix
|
|
||||||
function calls from the different layers.
|
|
||||||
|
|
||||||
As we currently ONLY support the high-level interface, the so called easy
|
|
||||||
interface, I will not attempt to describe any low-level functions at this
|
|
||||||
point.
|
|
||||||
|
|
||||||
Function descriptions
|
|
||||||
|
|
||||||
The interface is meant to be very simple for very simple
|
|
||||||
implementations. Thus, we have minimized the number of entries.
|
|
||||||
|
|
||||||
The Easy Interface
|
The Easy Interface
|
||||||
|
|
||||||
When using the easy interface, you init your easy-session and get a handle,
|
When using the easy interface, you init your session and get a handle, which
|
||||||
which you use as input to the following interface functions you use.
|
you use as input to the following interface functions you use. Use
|
||||||
|
curl_easy_init() to get the handle.
|
||||||
|
|
||||||
You continue by setting all the options you want in the upcoming transfer,
|
You continue by setting all the options you want in the upcoming transfer,
|
||||||
most important among them is the URL itself. You might want to set some
|
most important among them is the URL itself (you can't transfer anything
|
||||||
callbacks as well that will be called from the library when data is available
|
without a specified URL as you may have figured out yourself). You might want
|
||||||
etc.
|
to set some callbacks as well that will be called from the library when data
|
||||||
|
is available etc. curl_easy_setopt() is there for this.
|
||||||
|
|
||||||
When all is setup, you tell libcurl to perform the transfer. It will then do
|
When all is setup, you tell libcurl to perform the transfer using
|
||||||
the entire operation and won't return until it is done or failed.
|
curl_easy_perform(). It will then do the entire operation and won't return
|
||||||
|
until it is done or failed.
|
||||||
|
|
||||||
After the transfer has been made, you cleanup the easy-session's handle and
|
After the transfer has been made, you cleanup the session with
|
||||||
libcurl is entirely off the hook!
|
curl_easy_cleanup() and libcurl is entirely off the hook! If you want
|
||||||
|
persistant connections, you don't cleanup immediately, but instead run ahead
|
||||||
|
and perform other transfers. See the chapter below for Persistant
|
||||||
|
Connections.
|
||||||
|
|
||||||
curl_easy_init()
|
While the above mentioned four functions are the main functions to use in the
|
||||||
curl_easy_setopt()
|
easy interface, there is a series of other helpful functions to use. They
|
||||||
curl_easy_perform()
|
are:
|
||||||
curl_easy_cleanup()
|
|
||||||
|
|
||||||
While the above four functions are the main functions to use in the easy
|
curl_version() - displays the libcurl version
|
||||||
interface, there is a series of helpful functions to use. They are:
|
curl_getdate() - converts a date string to time_t
|
||||||
|
curl_getenv() - portable environment variable reader
|
||||||
|
curl_easy_getinfo() - get information about a performed transfer
|
||||||
|
curl_formparse() - helps building a HTTP form POST
|
||||||
|
curl_formfree() - free a list built with curl_formparse()
|
||||||
|
curl_slist_append() - builds a linked list
|
||||||
|
curl_slist_free_all() - frees a whole curl_slist
|
||||||
|
|
||||||
curl_version() - displays the libcurl version
|
For details on these, read the separate man pages.
|
||||||
curl_getdate() - converts a date string to time_t
|
|
||||||
curl_getenv() - portable environment variable reader
|
|
||||||
curl_formparse() - helps building a HTTP form POST
|
|
||||||
curl_slist_append() - builds a linked list
|
|
||||||
curl_slist_free_all() - frees a whole curl_slist
|
|
||||||
|
|
||||||
Read the separate man pages for these functions for details!
|
Portability
|
||||||
|
|
||||||
|
libcurl works *exactly* the same, on any of the platforms it compiles and
|
||||||
|
builds on.
|
||||||
|
|
||||||
|
There's only one caution, and that is the win32 platform that may(*) require
|
||||||
|
you to init the winsock stuff before you use the libcurl functions. Details
|
||||||
|
on this are noted on the curl_easy_init() man page.
|
||||||
|
|
||||||
|
(*) = it appears as if users of the cygwin environment get this done
|
||||||
|
automatically.
|
||||||
|
|
||||||
|
Threads
|
||||||
|
|
||||||
|
Never *ever* call curl-functions simultaneously using the same handle from
|
||||||
|
several threads. libcurl is thread-safe and can be used in any number of
|
||||||
|
threads, but you must use separate curl handles if you want to use libcurl in
|
||||||
|
more than one thread simultaneously.
|
||||||
|
|
||||||
|
Persistant Connections
|
||||||
|
|
||||||
|
With libcurl 7.7, persistant connections were added. Persistant connections
|
||||||
|
means that libcurl can re-use the same connection for several transfers, if
|
||||||
|
the conditions are right.
|
||||||
|
|
||||||
|
libcurl will *always* attempt to use persistant connections. Whenever you use
|
||||||
|
curl_easy_perform(), libcurl will attempt to use an existing connection to do
|
||||||
|
the transfer, and if none exists it'll open a new one that will be subject
|
||||||
|
for re-use on a possible following call to curl_easy_perform().
|
||||||
|
|
||||||
|
To allow libcurl to take full advantage of persistant connections, you should
|
||||||
|
do as many of your file transfers as possible using the same curl
|
||||||
|
handle. When you call curl_easy_cleanup(), all the possibly open connections
|
||||||
|
held by libcurl will be closed and forgotten.
|
||||||
|
|
||||||
|
Note that the options set with curl_easy_setopt() will be used in on every
|
||||||
|
repeat curl_easy_perform() call
|
||||||
|
|
||||||
|
Compatibility with older libcurls
|
||||||
|
|
||||||
|
Repeated curl_easy_perform() calls on the same handle were not supported in
|
||||||
|
pre-7.7 versions, and caused confusion and defined behaviour.
|
||||||
|
|
||||||
|
80
docs/MANUAL
80
docs/MANUAL
@@ -25,12 +25,16 @@ SIMPLE USAGE
|
|||||||
|
|
||||||
Get a list of the root directory of an FTP site:
|
Get a list of the root directory of an FTP site:
|
||||||
|
|
||||||
curl ftp://ftp.fts.frontec.se/
|
curl ftp://cool.haxx.se/
|
||||||
|
|
||||||
Get the definition of curl from a dictionary:
|
Get the definition of curl from a dictionary:
|
||||||
|
|
||||||
curl dict://dict.org/m:curl
|
curl dict://dict.org/m:curl
|
||||||
|
|
||||||
|
Fetch two documents at once:
|
||||||
|
|
||||||
|
curl ftp://cool.haxx.se/ http://www.weirdserver.com:8000/
|
||||||
|
|
||||||
DOWNLOAD TO A FILE
|
DOWNLOAD TO A FILE
|
||||||
|
|
||||||
Get a web page and store in a local file:
|
Get a web page and store in a local file:
|
||||||
@@ -43,6 +47,10 @@ DOWNLOAD TO A FILE
|
|||||||
|
|
||||||
curl -O http://www.netscape.com/index.html
|
curl -O http://www.netscape.com/index.html
|
||||||
|
|
||||||
|
Fetch two files and store them with their remote names:
|
||||||
|
|
||||||
|
curl -O www.haxx.se/index.html -O curl.haxx.se/download.html
|
||||||
|
|
||||||
USING PASSWORDS
|
USING PASSWORDS
|
||||||
|
|
||||||
FTP
|
FTP
|
||||||
@@ -455,9 +463,13 @@ EXTRA HEADERS
|
|||||||
|
|
||||||
curl -H "X-you-and-me: yes" www.love.com
|
curl -H "X-you-and-me: yes" www.love.com
|
||||||
|
|
||||||
This can also be useful in case you want curl to send a different text in
|
This can also be useful in case you want curl to send a different text in a
|
||||||
a header than it normally does. The -H header you specify then replaces the
|
header than it normally does. The -H header you specify then replaces the
|
||||||
header curl would normally send.
|
header curl would normally send. If you replace an internal header with an
|
||||||
|
empty one, you prevent that header from being sent. To prevent the Host:
|
||||||
|
header from being used:
|
||||||
|
|
||||||
|
curl -H "Host:" www.server.com
|
||||||
|
|
||||||
FTP and PATH NAMES
|
FTP and PATH NAMES
|
||||||
|
|
||||||
@@ -726,16 +738,60 @@ KERBEROS4 FTP TRANSFER
|
|||||||
There's no use for a password on the -u switch, but a blank one will make
|
There's no use for a password on the -u switch, but a blank one will make
|
||||||
curl ask for one and you already entered the real password to kauth.
|
curl ask for one and you already entered the real password to kauth.
|
||||||
|
|
||||||
MAILING LIST
|
TELNET
|
||||||
|
|
||||||
We have an open mailing list to discuss curl, its development and things
|
The curl telnet support is basic and very easy to use. Curl passes all data
|
||||||
relevant to this.
|
passed to it on stdin to the remote server. Connect to a remote telnet
|
||||||
|
server using a command line similar to:
|
||||||
|
|
||||||
To subscribe, mail curl-request@contactor.se with "subscribe <fill in your
|
curl telnet://remote.server.com
|
||||||
email address>" in the body.
|
|
||||||
|
|
||||||
To post to the list, mail curl@contactor.se.
|
And enter the data to pass to the server on stdin. The result will be sent
|
||||||
|
to stdout or to the file you specify with -o.
|
||||||
|
|
||||||
To unsubcribe, mail curl-request@contactor.se with "unsubscribe <your
|
You might want the -N/--no-buffer option to switch off the buffered output
|
||||||
subscribed email address>" in the body.
|
for slow connections or similar.
|
||||||
|
|
||||||
|
NOTE: the telnet protocol does not specify any way to login with a specified
|
||||||
|
user and password so curl can't do that automatically. To do that, you need
|
||||||
|
to track when the login prompt is received and send the username and
|
||||||
|
password accordingly.
|
||||||
|
|
||||||
|
PERSISTANT CONNECTIONS
|
||||||
|
|
||||||
|
Specifying multiple files on a single command line will make curl transfer
|
||||||
|
all of them, one after the other in the specified order.
|
||||||
|
|
||||||
|
libcurl will attempt to use persistant connections for the transfers so that
|
||||||
|
the second transfer to the same host can use the same connection that was
|
||||||
|
already initiated and was left open in the previous transfer. This greatly
|
||||||
|
decreases connection time for all but the first transfer and it makes a far
|
||||||
|
better use of the network.
|
||||||
|
|
||||||
|
Note that curl cannot use persistant connections for transfers that are used
|
||||||
|
in subsequence curl invokes. Try to stuff as many URLs as possible on the
|
||||||
|
same command line if they are using the same host, as that'll make the
|
||||||
|
transfers faster. If you use a http proxy for file transfers, practicly
|
||||||
|
all transfers will be persistant.
|
||||||
|
|
||||||
|
Persistant connections were introduced in curl 7.7.
|
||||||
|
|
||||||
|
MAILING LISTS
|
||||||
|
|
||||||
|
For your convenience, we have several open mailing lists to discuss curl,
|
||||||
|
its development and things relevant to this.
|
||||||
|
|
||||||
|
To subscribe to the main curl list, mail curl-request@contactor.se with
|
||||||
|
"subscribe <fill in your email address>" in the body.
|
||||||
|
|
||||||
|
To subscribe to the curl-library users/deverlopers list, follow the
|
||||||
|
instructions at http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
To subscribe to the curl-announce list, to only get information about new
|
||||||
|
releases, follow the instructions at http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
To subscribe to the curl-and-PHP list in which curl using with PHP is
|
||||||
|
discussed, follow the instructions at http://curl.haxx.se/mail/
|
||||||
|
|
||||||
|
Please direct curl questions, feature requests and trouble reports to one of
|
||||||
|
these mailing lists instead of mailing any individual.
|
||||||
|
@@ -12,11 +12,15 @@ man_MANS = \
|
|||||||
curl_easy_perform.3 \
|
curl_easy_perform.3 \
|
||||||
curl_easy_setopt.3 \
|
curl_easy_setopt.3 \
|
||||||
curl_formparse.3 \
|
curl_formparse.3 \
|
||||||
|
curl_formfree.3 \
|
||||||
curl_getdate.3 \
|
curl_getdate.3 \
|
||||||
curl_getenv.3 \
|
curl_getenv.3 \
|
||||||
curl_slist_append.3 \
|
curl_slist_append.3 \
|
||||||
curl_slist_free_all.3 \
|
curl_slist_free_all.3 \
|
||||||
curl_version.3
|
curl_version.3
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS)
|
EXTRA_DIST = $(man_MANS) \
|
||||||
|
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
||||||
|
LIBCURL README.win32 RESOURCES TODO TheArtOfHttpScripting
|
||||||
|
|
||||||
|
SUBDIRS = examples
|
||||||
|
@@ -102,6 +102,12 @@ Similar Tools
|
|||||||
|
|
||||||
Kermit - http://www.columbia.edu/kermit/ftpclient
|
Kermit - http://www.columbia.edu/kermit/ftpclient
|
||||||
|
|
||||||
|
Pavuk - http://www.idata.sk/~ondrej/pavuk/
|
||||||
|
|
||||||
|
httpr - http://zwolak.dhs.org/httpr/
|
||||||
|
|
||||||
|
puf - http://www.inf.tu-dresden.de/~ob6/sw/puf.html
|
||||||
|
|
||||||
Related Software
|
Related Software
|
||||||
----------------
|
----------------
|
||||||
ftpparse - http://cr.yp.to/ftpparse.html parses FTP LIST responses
|
ftpparse - http://cr.yp.to/ftpparse.html parses FTP LIST responses
|
||||||
|
89
docs/TODO
89
docs/TODO
@@ -6,51 +6,46 @@
|
|||||||
|
|
||||||
TODO
|
TODO
|
||||||
|
|
||||||
For the future
|
Things to do in project cURL. Please tell me what you think, contribute and
|
||||||
|
send me patches that improve things!
|
||||||
|
|
||||||
Ok, this is what I wanna do with Curl. Please tell me what you think, and
|
To do for the 7.7 release:
|
||||||
please don't hesitate to contribute and send me patches that improve this
|
|
||||||
product! (Yes, you may add things not mentioned here, these are just a
|
* Add a special connection-timeout that only goes for the connection phase.
|
||||||
few teasers...)
|
|
||||||
|
To do for the 7.8 release:
|
||||||
|
|
||||||
* Make SSL session ids get used if multiple HTTPS documents from the same
|
* Make SSL session ids get used if multiple HTTPS documents from the same
|
||||||
host is requested.
|
host is requested.
|
||||||
|
|
||||||
* Improve the command line option parser to accept '-m300' as well as the '-m
|
To do in a future release (random order):
|
||||||
300' convention. It should be able to work if '-m300' is considered to be
|
|
||||||
space separated to the next option.
|
|
||||||
|
|
||||||
* Make the curl tool support URLs that start with @ that would then mean that
|
* Document the undocumented libcurl functions: the printf clones (like
|
||||||
the following is a plain list with URLs to download. Thus @filename.txt
|
curl_msprintf, curl_mfprintf, curl_msnprintf, curl_maprintf and
|
||||||
reads a list of URLs from a local file. A fancy option would then be to
|
curl_mvfprintf), the string compare functions (curl_strequal
|
||||||
support @http://whatever.com that would first load a list and then get the
|
and curl_strnequal) and the URL escape/unescape functions.
|
||||||
URLs mentioned in the list. I figure -O or something would have to be
|
|
||||||
implied by such an action.
|
|
||||||
|
|
||||||
* Make curl with multiple URLs, even outside of {}-letters. I could also
|
* Add configure options that disables certain protocols in libcurl to
|
||||||
imagine an optional fork()ed system that downloads each URL in its own
|
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
||||||
thread. It should of course have a maximum amount of simultaneous fork()s.
|
telnet, ldap, dict or file.
|
||||||
|
|
||||||
* Improve the regular progress meter with --continue is used. It should be
|
* Extend the test suite to include telnet and https. The telnet could just do
|
||||||
noticable when there's a resume going on.
|
ftp or http operations (for which we have test servers) and the https would
|
||||||
|
probably work against/with some of the openssl tools.
|
||||||
|
|
||||||
* Add a command line option that allows the output file to get the same time
|
* Add a command line option that allows the output file to get the same time
|
||||||
stamp as the remote file. This requires some fiddling on FTP but comes
|
stamp as the remote file. libcurl already is capable of fetching the remote
|
||||||
almost free for HTTP.
|
file's date.
|
||||||
|
|
||||||
* Make the SSL layer option capable of using the Mozilla Security Services as
|
* Make the SSL layer option capable of using the Mozilla Security Services as
|
||||||
an alternative to OpenSSL:
|
an alternative to OpenSSL:
|
||||||
http://www.mozilla.org/projects/security/pki/nss/
|
http://www.mozilla.org/projects/security/pki/nss/
|
||||||
|
|
||||||
* Make sure the low-level interface works. highlevel.c should basically be
|
|
||||||
possible to write using that interface. Document the low-level interface
|
|
||||||
|
|
||||||
* Make the easy-interface support multiple file transfers. If they're done
|
|
||||||
to the same host, they should use persistant connections or similar.
|
|
||||||
|
|
||||||
* Add asynchronous name resolving, as this enables full timeout support for
|
* Add asynchronous name resolving, as this enables full timeout support for
|
||||||
fork() systems.
|
fork() systems.
|
||||||
|
|
||||||
|
* Non-blocking connect(), also to make timeouts work on windows.
|
||||||
|
|
||||||
* Move non-URL related functions that are used by both the lib and the curl
|
* Move non-URL related functions that are used by both the lib and the curl
|
||||||
application to a separate "portability lib".
|
application to a separate "portability lib".
|
||||||
|
|
||||||
@@ -58,50 +53,40 @@ For the future
|
|||||||
something being worked on in this area) and perl (we have seen the first
|
something being worked on in this area) and perl (we have seen the first
|
||||||
versions of this!) comes to mind. Python anyone?
|
versions of this!) comes to mind. Python anyone?
|
||||||
|
|
||||||
* "Content-Encoding: compress/gzip/zlib"
|
* "Content-Encoding: compress/gzip/zlib" HTTP 1.1 clearly defines how to get
|
||||||
|
and decode compressed documents. There is the zlib that is pretty good at
|
||||||
|
decompressing stuff. This work was started in October 1999 but halted again
|
||||||
|
since it proved more work than we thought. It is still a good idea to
|
||||||
|
implement though.
|
||||||
|
|
||||||
HTTP 1.1 clearly defines how to get and decode compressed documents. There
|
* Authentication: NTLM. Support for that MS crap called NTLM
|
||||||
is the zlib that is pretty good at decompressing stuff. This work was
|
|
||||||
started in October 1999 but halted again since it proved more work than we
|
|
||||||
thought. It is still a good idea to implement though.
|
|
||||||
|
|
||||||
* Authentication: NTLM. It would be cool to support that MS crap called NTLM
|
|
||||||
authentication. MS proxies and servers sometime require that. Since that
|
authentication. MS proxies and servers sometime require that. Since that
|
||||||
protocol is a proprietary one, it involves reverse engineering and network
|
protocol is a proprietary one, it involves reverse engineering and network
|
||||||
sniffing. This should however be a library-based functionality. There are a
|
sniffing. This should however be a library-based functionality. There are a
|
||||||
few different efforts "out there" to make open source HTTP clients support
|
few different efforts "out there" to make open source HTTP clients support
|
||||||
this and it should be possible to take advantage of other people's hard
|
this and it should be possible to take advantage of other people's hard
|
||||||
work. http://modntlm.sourceforge.net/ is one.
|
work. http://modntlm.sourceforge.net/ is one. There's a web page at
|
||||||
|
http://www.innovation.ch/java/ntlm.html that contains detailed reverse-
|
||||||
|
engineered info.
|
||||||
|
|
||||||
* RFC2617 compliance, "Digest Access Authentication"
|
* RFC2617 compliance, "Digest Access Authentication"
|
||||||
A valid test page seem to exist at:
|
A valid test page seem to exist at:
|
||||||
http://hopf.math.nwu.edu/testpage/digest/
|
http://hopf.math.nwu.edu/testpage/digest/
|
||||||
And some friendly person's server source code is available at
|
And some friendly person's server source code is available at
|
||||||
http://hopf.math.nwu.edu/digestauth/index.html
|
http://hopf.math.nwu.edu/digestauth/index.html
|
||||||
|
|
||||||
Then there's the Apache mod_digest source code too of course. It seems as
|
Then there's the Apache mod_digest source code too of course. It seems as
|
||||||
if Netscape doesn't support this, and not many servers do. Although this is
|
if Netscape doesn't support this, and not many servers do. Although this is
|
||||||
a lot better authentication method than the more common "Basic". Basic
|
a lot better authentication method than the more common "Basic". Basic
|
||||||
sends the password in cleartext over the network, this "Digest" method uses
|
sends the password in cleartext over the network, this "Digest" method uses
|
||||||
a challange-response protocol which increases security quite a lot.
|
a challange-response protocol which increases security quite a lot.
|
||||||
|
|
||||||
* Multiple Proxies?
|
|
||||||
Is there anyone that actually uses serial-proxies? I mean, send CONNECT to
|
|
||||||
the first proxy to connect to the second proxy to which you send CONNECT to
|
|
||||||
connect to the remote host (or even more iterations). Is there anyone
|
|
||||||
wanting curl to support it? (Not that it would be hard, just confusing...)
|
|
||||||
|
|
||||||
* Other proxies
|
* Other proxies
|
||||||
Ftp-kind proxy, Socks5, whatever kind of proxies are there?
|
Ftp-kind proxy, Socks5, whatever kind of proxies are there?
|
||||||
|
|
||||||
* IPv6 Awareness and support
|
* IPv6 Awareness and support. (This is partly done.) RFC 2428 "FTP
|
||||||
Where ever it would fit. configure search for v6-versions of a few
|
Extensions for IPv6 and NATs" is interesting. PORT should be replaced with
|
||||||
functions and then use them instead is of course the first thing to do...
|
EPRT for IPv6 (done), and EPSV instead of PASV. HTTP proxies are left to
|
||||||
RFC 2428 "FTP Extensions for IPv6 and NATs" will be interesting. PORT
|
add support for.
|
||||||
should be replaced with EPRT for IPv6, and EPSV instead of PASV.
|
|
||||||
|
|
||||||
* SSL for more protocols, like SSL-FTP...
|
* SSL for more protocols, like SSL-FTP...
|
||||||
(http://search.ietf.org/internet-drafts/draft-murray-auth-ftp-ssl-05.txt)
|
(http://search.ietf.org/internet-drafts/draft-murray-auth-ftp-ssl-05.txt)
|
||||||
|
|
||||||
* HTTP POST resume using Range:
|
|
||||||
|
|
||||||
|
67
docs/curl.1
67
docs/curl.1
@@ -2,18 +2,19 @@
|
|||||||
.\" nroff -man curl.1
|
.\" nroff -man curl.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl 1 "4 January 2001" "Curl 7.5.2" "Curl Manual"
|
.TH curl 1 "12 March 2001" "Curl 7.7" "Curl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl \- get a URL with FTP, TELNET, LDAP, GOPHER, DICT, FILE, HTTP or
|
curl \- get a URL with FTP, TELNET, LDAP, GOPHER, DICT, FILE, HTTP or
|
||||||
HTTPS syntax.
|
HTTPS syntax.
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B curl [options]
|
.B curl [options]
|
||||||
.I url
|
.I [URL...]
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
.B curl
|
.B curl
|
||||||
is a client to get documents/files from servers, using any of the
|
is a client to get documents/files from or send documents to a server, using
|
||||||
supported protocols. The command is designed to work without user
|
any of the supported protocols (HTTP, HTTPS, FTP, GOPHER, DICT, TELNET, LDAP
|
||||||
interaction or any kind of interactivity.
|
or FILE). The command is designed to work without user interaction or any kind
|
||||||
|
of interactivity.
|
||||||
|
|
||||||
curl offers a busload of useful tricks like proxy support, user
|
curl offers a busload of useful tricks like proxy support, user
|
||||||
authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file
|
authentication, ftp upload, HTTP post, SSL (https:) connections, cookies, file
|
||||||
@@ -37,6 +38,15 @@ It is possible to specify up to 9 sets or series for a URL, but no nesting is
|
|||||||
supported at the moment:
|
supported at the moment:
|
||||||
|
|
||||||
http://www.any.org/archive[1996-1999]/volume[1-4]part{a,b,c,index}.html
|
http://www.any.org/archive[1996-1999]/volume[1-4]part{a,b,c,index}.html
|
||||||
|
|
||||||
|
Starting with curl 7.6, you can specify any amount of URLs on the command
|
||||||
|
line. They will be fetched in a sequential manner in the specified order.
|
||||||
|
|
||||||
|
Starting with curl 7.7, curl will attempt to re-use connections for multiple
|
||||||
|
file transfers, so that getting many files from the same server will not do
|
||||||
|
multiple connects/handshakes. This improves speed. Of course this is only done
|
||||||
|
on files specified on a single command line and cannot be used between
|
||||||
|
separate curl invokes.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
.IP "-a/--append"
|
.IP "-a/--append"
|
||||||
(FTP)
|
(FTP)
|
||||||
@@ -120,11 +130,13 @@ To post data purely binary, you should instead use the --data-binary option.
|
|||||||
|
|
||||||
-d/--data is the same as --data-ascii.
|
-d/--data is the same as --data-ascii.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used serveral times, the ones following the first will
|
||||||
|
append data.
|
||||||
.IP "--data-ascii <data>"
|
.IP "--data-ascii <data>"
|
||||||
(HTTP) This is an alias for the -d/--data option.
|
(HTTP) This is an alias for the -d/--data option.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used serveral times, the ones following the first will
|
||||||
|
append data.
|
||||||
.IP "--data-binary <data>"
|
.IP "--data-binary <data>"
|
||||||
(HTTP) This posts data in a similar manner as --data-ascii does, although when
|
(HTTP) This posts data in a similar manner as --data-ascii does, although when
|
||||||
using this option the entire context of the posted data is kept as-is. If you
|
using this option the entire context of the posted data is kept as-is. If you
|
||||||
@@ -132,6 +144,9 @@ want to post a binary file without the strip-newlines feature of the
|
|||||||
--data-ascii option, this is for you.
|
--data-ascii option, this is for you.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used serveral times, the last one will be used.
|
||||||
|
|
||||||
|
If this option is used serveral times, the ones following the first will
|
||||||
|
append data.
|
||||||
.IP "-D/--dump-header <file>"
|
.IP "-D/--dump-header <file>"
|
||||||
(HTTP/FTP)
|
(HTTP/FTP)
|
||||||
Write the HTTP headers to this file. Write the FTP file info to this
|
Write the HTTP headers to this file. Write the FTP file info to this
|
||||||
@@ -196,6 +211,12 @@ To read the file's content from stdin insted of a file, use - where the file
|
|||||||
name should've been. This goes for both @ and < constructs.
|
name should've been. This goes for both @ and < constructs.
|
||||||
|
|
||||||
This option can be used multiple times.
|
This option can be used multiple times.
|
||||||
|
.IP "-g/--globoff"
|
||||||
|
This option switches off the "URL globbing parser". When you set this option,
|
||||||
|
you can specify URLs that contain the letters {}[] without having them being
|
||||||
|
interpreted by curl itself. Note that these letters are not normal legal URL
|
||||||
|
contents but they should be encoded according to the URI standard. (Option
|
||||||
|
added in curl 7.6)
|
||||||
.IP "-h/--help"
|
.IP "-h/--help"
|
||||||
Usage help.
|
Usage help.
|
||||||
.IP "-H/--header <header>"
|
.IP "-H/--header <header>"
|
||||||
@@ -311,11 +332,12 @@ or use several variables like:
|
|||||||
|
|
||||||
curl http://{site,host}.host[1-5].com -o "#1_#2"
|
curl http://{site,host}.host[1-5].com -o "#1_#2"
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
You may use this option as many times as you have number of URLs.
|
||||||
.IP "-O/--remote-name"
|
.IP "-O/--remote-name"
|
||||||
Write output to a local file named like the remote file we get. (Only
|
Write output to a local file named like the remote file we get. (Only
|
||||||
the file part of the remote file is used, the path is cut off.)
|
the file part of the remote file is used, the path is cut off.)
|
||||||
|
|
||||||
|
You may use this option as many times as you have number of URLs.
|
||||||
.IP "-p/--proxytunnel"
|
.IP "-p/--proxytunnel"
|
||||||
When an HTTP proxy is used, this option will cause non-HTTP protocols to
|
When an HTTP proxy is used, this option will cause non-HTTP protocols to
|
||||||
attempt to tunnel through the proxy instead of merely using it to do HTTP-like
|
attempt to tunnel through the proxy instead of merely using it to do HTTP-like
|
||||||
@@ -409,11 +431,14 @@ If this option is used twice, the second will again disable mute.
|
|||||||
When used with -s it makes curl show error message if it fails.
|
When used with -s it makes curl show error message if it fails.
|
||||||
|
|
||||||
If this option is used twice, the second will again disable show error.
|
If this option is used twice, the second will again disable show error.
|
||||||
.IP "-t/--upload"
|
.IP "-t/--telnet-option <OPT=val>"
|
||||||
.B Deprecated. Use '-T -' instead.
|
Pass options to the telnet protocol. Supported options are:
|
||||||
Transfer the stdin data to the specified file. Curl will read
|
|
||||||
everything from stdin until EOF and store with the supplied name. If
|
TTYPE=<term> Sets the terminal type.
|
||||||
this is used on a http(s) server, the PUT command will be used.
|
|
||||||
|
XDISPLOC=<X display> Sets the X display location.
|
||||||
|
|
||||||
|
NEW_ENV=<var,val> Sets an environment variable.
|
||||||
.IP "-T/--upload-file <file>"
|
.IP "-T/--upload-file <file>"
|
||||||
Like -t, but this transfers the specified local file. If there is no
|
Like -t, but this transfers the specified local file. If there is no
|
||||||
file part in the specified URL, Curl will append the local file
|
file part in the specified URL, Curl will append the local file
|
||||||
@@ -436,10 +461,14 @@ password is specified, curl will ask for it interactively.
|
|||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used serveral times, the last one will be used.
|
||||||
.IP "--url <URL>"
|
.IP "--url <URL>"
|
||||||
Set the URL to fetch. This option is mostly handy when you wanna specify URL
|
Specify a URL to fetch. This option is mostly handy when you wanna specify
|
||||||
in a config file.
|
URL(s) in a config file.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
This option may be used any number of times. To control where this URL is written, use the
|
||||||
|
.I -o
|
||||||
|
or the
|
||||||
|
.I -O
|
||||||
|
options.
|
||||||
.IP "-v/--verbose"
|
.IP "-v/--verbose"
|
||||||
Makes the fetching more verbose/talkative. Mostly usable for
|
Makes the fetching more verbose/talkative. Mostly usable for
|
||||||
debugging. Lines starting with '>' means data sent by curl, '<'
|
debugging. Lines starting with '>' means data sent by curl, '<'
|
||||||
@@ -738,7 +767,7 @@ If you do find bugs, mail them to curl-bug@haxx.se.
|
|||||||
- Lars J. Aas <larsa@sim.no>
|
- Lars J. Aas <larsa@sim.no>
|
||||||
- J<>rn Hartroth <Joern.Hartroth@computer.org>
|
- J<>rn Hartroth <Joern.Hartroth@computer.org>
|
||||||
- Matthew Clarke <clamat@van.maves.ca>
|
- Matthew Clarke <clamat@van.maves.ca>
|
||||||
- Linus Nielsen <Linus.Nielsen@haxx.se>
|
- Linus Nielsen Feltzing <linus@haxx.se>
|
||||||
- Felix von Leitner <felix@convergence.de>
|
- Felix von Leitner <felix@convergence.de>
|
||||||
- Dan Zitter <dzitter@zitter.net>
|
- Dan Zitter <dzitter@zitter.net>
|
||||||
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
||||||
@@ -765,6 +794,10 @@ If you do find bugs, mail them to curl-bug@haxx.se.
|
|||||||
- T. Bharath <TBharath@responsenetworks.com>
|
- T. Bharath <TBharath@responsenetworks.com>
|
||||||
- Alexander Kourakos <awk@users.sourceforge.net>
|
- Alexander Kourakos <awk@users.sourceforge.net>
|
||||||
- James Griffiths <griffiths_james@yahoo.com>
|
- James Griffiths <griffiths_james@yahoo.com>
|
||||||
|
- Loic Dachary <loic@senga.org>
|
||||||
|
- Robert Weaver <robert.weaver@sabre.com>
|
||||||
|
- Ingo Ralf Blum <ingoralfblum@ingoralfblum.com>
|
||||||
|
- Jun-ichiro itojun Hagino <itojun@iijlab.net>
|
||||||
|
|
||||||
.SH WWW
|
.SH WWW
|
||||||
http://curl.haxx.se
|
http://curl.haxx.se
|
||||||
|
@@ -2,13 +2,13 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_cleanup 3 "22 May 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_easy_cleanup 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_cleanup - End a libcurl "easy" session
|
curl_easy_cleanup - End a libcurl session
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "curl_easy_cleanup(CURL *" handle ");
|
.BI "curl_easy_cleanup(CURL *" handle ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
This function must be the last function to call for a curl session. It is the
|
This function must be the last function to call for a curl session. It is the
|
||||||
@@ -17,6 +17,10 @@ opposite of the
|
|||||||
function and must be called with the same
|
function and must be called with the same
|
||||||
.I handle
|
.I handle
|
||||||
as input as the curl_easy_init call returned.
|
as input as the curl_easy_init call returned.
|
||||||
|
|
||||||
|
This will effectively close all connections libcurl has been used and possibly
|
||||||
|
has kept open until now. Don't call this function if you intend to transfer
|
||||||
|
more files (libcurl 7.7 or later).
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
None
|
None
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
@@ -2,11 +2,11 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "22 November 2000" "Curl 7.5" "libcurl Manual"
|
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.6.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_getinfo - Extract information from a curl session (added in 7.4)
|
curl_easy_getinfo - Extract information from a curl session (added in 7.4)
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ... );"
|
.BI "CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ... );"
|
||||||
.ad
|
.ad
|
||||||
@@ -81,6 +81,14 @@ than one request if FOLLOWLOCATION is true.
|
|||||||
Pass a pointer to a long to receive the result of the certification
|
Pass a pointer to a long to receive the result of the certification
|
||||||
verification that was requested (using the CURLOPT_SSL_VERIFYPEER option to
|
verification that was requested (using the CURLOPT_SSL_VERIFYPEER option to
|
||||||
curl_easy_setopt). (Added in 7.4.2)
|
curl_easy_setopt). (Added in 7.4.2)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_CONTENT_LENGTH_DOWNLOAD
|
||||||
|
Pass a pointer to a double to receive the content-length of the download. This
|
||||||
|
is the value read from the Content-Length: field. (Added in 7.6.1)
|
||||||
|
.TP
|
||||||
|
.B CURLINFO_CONTENT_LENGTH_UPLOAD
|
||||||
|
Pass a pointer to a double to receive the specified size of the upload.
|
||||||
|
(Added in 7.6.1)
|
||||||
.PP
|
.PP
|
||||||
|
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
|
@@ -2,11 +2,11 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "26 September 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_init - Start a libcurl "easy" session
|
curl_easy_init - Start a libcurl session
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURL *curl_easy_init( );"
|
.BI "CURL *curl_easy_init( );"
|
||||||
.ad
|
.ad
|
||||||
@@ -19,6 +19,10 @@ when the operation is complete.
|
|||||||
|
|
||||||
On win32 systems, you need to init the winsock stuff manually, libcurl will
|
On win32 systems, you need to init the winsock stuff manually, libcurl will
|
||||||
not do that for you. WSAStartup() and WSACleanup() should be used accordingly.
|
not do that for you. WSAStartup() and WSACleanup() should be used accordingly.
|
||||||
|
|
||||||
|
Using libcurl 7.7 and later, you should perform all your sequential file
|
||||||
|
transfers using the same curl handle. This enables libcurl to use persistant
|
||||||
|
connections where possible.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
If this function returns NULL, something went wrong and you cannot use the
|
If this function returns NULL, something went wrong and you cannot use the
|
||||||
other curl functions.
|
other curl functions.
|
||||||
|
@@ -2,11 +2,11 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_perform 3 "26 May 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_easy_perform 3 "5 Mar 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_perform - Do the actual transfer in a "easy" session
|
curl_easy_perform - Perform a file transfer
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode curl_easy_perform(CURL *" handle ");
|
.BI "CURLcode curl_easy_perform(CURL *" handle ");
|
||||||
.ad
|
.ad
|
||||||
@@ -16,12 +16,29 @@ are made, and will perform the transfer as described in the options.
|
|||||||
It must be called with the same
|
It must be called with the same
|
||||||
.I handle
|
.I handle
|
||||||
as input as the curl_easy_init call returned.
|
as input as the curl_easy_init call returned.
|
||||||
|
|
||||||
|
libcurl version 7.7 or later (for older versions see below): You can do any
|
||||||
|
amount of calls to curl_easy_perform() while using the same handle. If you
|
||||||
|
intend to transfer more than one file, you are even encouraged to do
|
||||||
|
so. libcurl will then attempt to re-use the same connection for the following
|
||||||
|
transfers, thus making the operations faster, less CPU intense and using less
|
||||||
|
network resources. Just note that you will have to use
|
||||||
|
.I curl_easy_setopt
|
||||||
|
between the invokes to set options for the following curl_easy_perform.
|
||||||
|
|
||||||
|
You must never call this function simultaneously from two places using the
|
||||||
|
same handle. Let the function return first before invoking it another time. If
|
||||||
|
you want parallel transfers, you must use several curl handles.
|
||||||
|
|
||||||
|
Before libcurl version 7.7: You are only allowed to call this function once
|
||||||
|
using the same handle. If you want to do repeated calls, you must call
|
||||||
|
curl_easy_cleanup and curl_easy_init again first.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
0 means everything was ok, non-zero means an error occurred as
|
0 means everything was ok, non-zero means an error occurred as
|
||||||
.I <curl/curl.h>
|
.I <curl/curl.h>
|
||||||
defines. If the CURLOPT_ERRORBUFFER was set with
|
defines. If the CURLOPT_ERRORBUFFER was set with
|
||||||
.I curl_easy_setopt
|
.I curl_easy_setopt
|
||||||
there willo be a readable error message in the error buffer when non-zero is
|
there will be a readable error message in the error buffer when non-zero is
|
||||||
returned.
|
returned.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_init "(3), " curl_easy_setopt "(3), "
|
.BR curl_easy_init "(3), " curl_easy_setopt "(3), "
|
||||||
|
@@ -2,11 +2,11 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_setopt 3 "28 November 2000" "Curl 7.5" "libcurl Manual"
|
.TH curl_easy_setopt 3 "13 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_setopt - Set curl easy-session options
|
curl_easy_setopt - Set curl easy-session options
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode curl_easy_setopt(CURL *" handle ", CURLoption "option ", ...);
|
.BI "CURLcode curl_easy_setopt(CURL *" handle ", CURLoption "option ", ...);
|
||||||
.ad
|
.ad
|
||||||
@@ -20,7 +20,18 @@ followed by a parameter. That parameter can be a long, a function pointer or
|
|||||||
an object pointer, all depending on what the option in question expects. Read
|
an object pointer, all depending on what the option in question expects. Read
|
||||||
this manual carefully as bad input values may cause libcurl to behave badly!
|
this manual carefully as bad input values may cause libcurl to behave badly!
|
||||||
You can only set one option in each function call. A typical application uses
|
You can only set one option in each function call. A typical application uses
|
||||||
many calls in the setup phase.
|
many curl_easy_setopt() calls in the setup phase.
|
||||||
|
|
||||||
|
NOTE: strings passed to libcurl as 'char *' arguments, will not be copied by
|
||||||
|
the library. Instead you should keep them available until libcurl no longer
|
||||||
|
needs them. Failing to do so will cause very odd behaviour or even crashes.
|
||||||
|
|
||||||
|
More note: the options set with this function call are valid for the
|
||||||
|
forthcoming data transfers that are performed when you invoke
|
||||||
|
.I curl_easy_perform .
|
||||||
|
The options are not in any way reset between transfers, so if you want
|
||||||
|
subsequent transfers with different options, you must change them between the
|
||||||
|
transfers.
|
||||||
|
|
||||||
The
|
The
|
||||||
.I "handle"
|
.I "handle"
|
||||||
@@ -35,6 +46,12 @@ Data pointer to pass instead of FILE * to the file write function. Note that
|
|||||||
if you specify the
|
if you specify the
|
||||||
.I CURLOPT_WRITEFUNCTION
|
.I CURLOPT_WRITEFUNCTION
|
||||||
, this is the pointer you'll get as input.
|
, this is the pointer you'll get as input.
|
||||||
|
|
||||||
|
NOTE: If you're using libcurl as a win32 .DLL, you MUST use a
|
||||||
|
.I CURLOPT_WRITEFUNCTION
|
||||||
|
if you set the
|
||||||
|
.I CURLOPT_FILE
|
||||||
|
option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_WRITEFUNCTION
|
.B CURLOPT_WRITEFUNCTION
|
||||||
Function pointer that should use match the following prototype:
|
Function pointer that should use match the following prototype:
|
||||||
@@ -53,6 +70,12 @@ Data pointer to pass instead of FILE * to the file read function. Note that if
|
|||||||
you specify the
|
you specify the
|
||||||
.I CURLOPT_READFUNCTION
|
.I CURLOPT_READFUNCTION
|
||||||
, this is the pointer you'll get as input.
|
, this is the pointer you'll get as input.
|
||||||
|
|
||||||
|
NOTE: If you're using libcurl as a win32 .DLL, you MUST use a
|
||||||
|
.I CURLOPT_READFUNCTION
|
||||||
|
if you set the
|
||||||
|
.I CURLOPT_INFILE
|
||||||
|
option.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_READFUNCTION
|
.B CURLOPT_READFUNCTION
|
||||||
Function pointer that should use match the following prototype:
|
Function pointer that should use match the following prototype:
|
||||||
@@ -74,14 +97,16 @@ libcurl what the expected size of the infile is.
|
|||||||
.TP
|
.TP
|
||||||
.B CURLOPT_URL
|
.B CURLOPT_URL
|
||||||
The actual URL to deal with. The parameter should be a char * to a zero
|
The actual URL to deal with. The parameter should be a char * to a zero
|
||||||
terminated string. NOTE: this option is currently required!
|
terminated string. The string must remain present until curl no longer needs
|
||||||
|
it, as it doesn't copy the string. NOTE: this option is required to be set
|
||||||
|
before curl_easy_perform() is called.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PROXY
|
.B CURLOPT_PROXY
|
||||||
If you need libcurl to use a http proxy to access the outside world, set the
|
If you need libcurl to use a http proxy to access the outside world, set the
|
||||||
proxy string with this option. The parameter should be a char * to a zero
|
proxy string with this option. The parameter should be a char * to a zero
|
||||||
terminated string. To specify port number in this string, append":[port]" to
|
terminated string. To specify port number in this string, append :[port] to
|
||||||
the end of the host name. The proxy string may be prefixed with
|
the end of the host name. The proxy string may be prefixed with
|
||||||
"[protocol]://" since any such prefix will be ignored.
|
[protocol]:// since any such prefix will be ignored.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_PROXYPORT
|
.B CURLOPT_PROXYPORT
|
||||||
Set this long with this option to set the proxy port to use unless it is
|
Set this long with this option to set the proxy port to use unless it is
|
||||||
@@ -177,9 +202,11 @@ prompted for it.
|
|||||||
.TP
|
.TP
|
||||||
.B CURLOPT_RANGE
|
.B CURLOPT_RANGE
|
||||||
Pass a char * as parameter, which should contain the specified range you
|
Pass a char * as parameter, which should contain the specified range you
|
||||||
want. It should be in the format "X-Y", where X or Y may be left out. The HTTP
|
want. It should be in the format "X-Y", where X or Y may be left out. HTTP
|
||||||
transfers also support several intervals, separated with commas as in
|
transfers also support several intervals, separated with commas as in
|
||||||
.I "X-Y,N-M".
|
.I "X-Y,N-M"
|
||||||
|
. Using this kind of multiple intervals will cause the HTTP server to send the
|
||||||
|
response document in pieces.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_ERRORBUFFER
|
.B CURLOPT_ERRORBUFFER
|
||||||
Pass a char * to a buffer that the libcurl may store human readable error
|
Pass a char * to a buffer that the libcurl may store human readable error
|
||||||
@@ -190,7 +217,8 @@ library. The buffer must be at least CURL_ERROR_SIZE big.
|
|||||||
Pass a long as parameter containing the maximum time in seconds that you allow
|
Pass a long as parameter containing the maximum time in seconds that you allow
|
||||||
the libcurl transfer operation to take. Do note that normally, name lookups
|
the libcurl transfer operation to take. Do note that normally, name lookups
|
||||||
maky take a considerable time and that limiting the operation to less than a
|
maky take a considerable time and that limiting the operation to less than a
|
||||||
few minutes risk aborting perfectly normal operations.
|
few minutes risk aborting perfectly normal operations. This option will cause
|
||||||
|
curl to use the SIGALRM to enable timeouting system calls.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_POSTFIELDS
|
.B CURLOPT_POSTFIELDS
|
||||||
Pass a char * as parameter, which should be the full data to post in a HTTP
|
Pass a char * as parameter, which should be the full data to post in a HTTP
|
||||||
@@ -398,6 +426,50 @@ Pass a long. The set number will be the redirection limit. If that many
|
|||||||
redirections have been followed, the next redirect will cause an error. This
|
redirections have been followed, the next redirect will cause an error. This
|
||||||
option only makes sense if the CURLOPT_FOLLOWLOCATION is used at the same
|
option only makes sense if the CURLOPT_FOLLOWLOCATION is used at the same
|
||||||
time. (Added in 7.5)
|
time. (Added in 7.5)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_MAXCONNECTS
|
||||||
|
Pass a long. The set number will be the persistant connection cache size. The
|
||||||
|
set amount will be the maximum amount of simultaneous connections that libcurl
|
||||||
|
may cache between file transfers. Default is 5, and there isn't much point in
|
||||||
|
changing this value unless you are perfectly aware of how this work and
|
||||||
|
changes libcurl's behaviour. Note: if you have already performed transfers
|
||||||
|
with this curl handle, setting a smaller MAXCONNECTS than before may cause
|
||||||
|
open connections to unnecessarily get closed. (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_CLOSEPOLICY
|
||||||
|
Pass a long. This option sets what policy libcurl should use when the
|
||||||
|
connection cache is filled and one of the open connections has to be closed to
|
||||||
|
make room for a new connection. This must be one of the CURLCLOSEPOLICY_*
|
||||||
|
defines. Use CURLCLOSEPOLICY_LEAST_RECENTLY_USED to make libcurl close the
|
||||||
|
connection that was least recently used, that connection is also least likely
|
||||||
|
to be capable of re-use. Use CURLCLOSEPOLICY_OLDEST to make libcurl close the
|
||||||
|
oldest connection, the one that was created first among the ones in the
|
||||||
|
connection cache. The other close policies are not support yet. (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_FRESH_CONNECT
|
||||||
|
Pass a long. Set to non-zero to make the next transfer use a new connection by
|
||||||
|
force. If the connection cache is full before this connection, one of the
|
||||||
|
existinf connections will be closed as according to the set policy. This
|
||||||
|
option should be used with caution and only if you understand what it
|
||||||
|
does. Set to 0 to have libcurl attempt re-use of an existing connection.
|
||||||
|
(Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_FORBID_REUSE
|
||||||
|
Pass a long. Set to non-zero to make the next transfer explicitly close the
|
||||||
|
connection when done. Normally, libcurl keep all connections alive when done
|
||||||
|
with one transfer in case there comes a succeeding one that can re-use them.
|
||||||
|
This option should be used with caution and only if you understand what it
|
||||||
|
does. Set to 0 to have libcurl keep the connection open for possibly later
|
||||||
|
re-use. (Added in 7.7)
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_RANDOM_FILE
|
||||||
|
Pass a char * to a zero terminated file name. The file will be used to read
|
||||||
|
from to seed the random engine for SSL. The more random the specified file is,
|
||||||
|
the more secure will the SSL connection become.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_FORBID_REUSE
|
||||||
|
Pass a char * to the zero terminated path name to the Entropy Gathering Daemon
|
||||||
|
socket. It will be used to seed the random engine for SSL.
|
||||||
.PP
|
.PP
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
0 means the option was set properly, non-zero means an error as
|
0 means the option was set properly, non-zero means an error as
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_formfree 3 "17 November 2000" "Curl 7.5" "libcurl Manual"
|
.TH curl_formfree 3 "5 March 2001" "libcurl 7.5" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
|
@@ -2,13 +2,13 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_formparse 3 "6 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_formparse 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_formparse - add a section to a multipart/formdata HTTP POST
|
curl_formparse - add a section to a multipart/formdata HTTP POST
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "CURLcode *curl_formparse(char *" string, "struct HttpPost **" firstitem,
|
.BI "CURLcode curl_formparse(char *" string, "struct HttpPost **" firstitem,
|
||||||
.BI "struct HttpPost ** "lastitem ");"
|
.BI "struct HttpPost ** "lastitem ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
@@ -42,14 +42,14 @@ Add a form field named 'name' with the contents as read from the local files
|
|||||||
named 'filename1' and 'filename2'. This is identical to the upper, except that
|
named 'filename1' and 'filename2'. This is identical to the upper, except that
|
||||||
you get the contents of several files in one section.
|
you get the contents of several files in one section.
|
||||||
.TP
|
.TP
|
||||||
.B [name]=@[filename];[content-type]
|
.B [name]=@[filename];[type=<content-type>]
|
||||||
Whenever you specify a file to read from, you can optionally specify the
|
Whenever you specify a file to read from, you can optionally specify the
|
||||||
content-type as well. The content-type is passed to the server together with
|
content-type as well. The content-type is passed to the server together with
|
||||||
the contents of the file. curl_formparse() will guess content-type for a
|
the contents of the file. curl_formparse() will guess content-type for a
|
||||||
number of well-known extensions and otherwise it will set it to binary. You
|
number of well-known extensions and otherwise it will set it to binary. You
|
||||||
can override the internal decision by using this option.
|
can override the internal decision by using this option.
|
||||||
.TP
|
.TP
|
||||||
.B [name]=@[filename1,filename2,...];[content-type]
|
.B [name]=@[filename1,filename2,...];[type=<content-type>]
|
||||||
When you specify several files to read the contents from, you can set the
|
When you specify several files to read the contents from, you can set the
|
||||||
content-type for all of them in the same way as with a single file.
|
content-type for all of them in the same way as with a single file.
|
||||||
.PP
|
.PP
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getdate 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_getdate - Convert an date in a ASCII string to number of seconds since
|
curl_getdate - Convert an date in a ASCII string to number of seconds since
|
||||||
January 1, 1970
|
January 1, 1970
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getenv 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_getenv 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_getenv - return value for environment name
|
curl_getenv - return value for environment name
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
|
@@ -2,14 +2,14 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_slist_append 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_slist_append 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_slist_append - add a string to an slist
|
curl_slist_append - add a string to an slist
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "struct curl_slist *curl_slist_append(struct curl_slit *" list,
|
.BI "struct curl_slist *curl_slist_append(struct curl_slit *" list,
|
||||||
.BI "char * "string ");"
|
.BI "const char * "string ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_slist_append() appends a specified string to a linked list of
|
curl_slist_append() appends a specified string to a linked list of
|
||||||
|
@@ -2,13 +2,13 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_slist_free_all 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_slist_free_all 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_slist_free_all - free an entire curl_slist list
|
curl_slist_free_all - free an entire curl_slist list
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "void curl_slist_free_all(struct curl_slit *" list);
|
.BI "void curl_slist_free_all(struct curl_slist *" list);
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_slist_free_all() removes all traces of a previously built curl_slist
|
curl_slist_free_all() removes all traces of a previously built curl_slist
|
||||||
|
@@ -2,11 +2,11 @@
|
|||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" Written by daniel@haxx.se
|
||||||
.\"
|
.\"
|
||||||
.TH curl_version 3 "2 June 2000" "Curl 7.0" "libcurl Manual"
|
.TH curl_version 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_version - returns the libcurl version string
|
curl_version - returns the libcurl version string
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/easy.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "char *curl_version( );"
|
.BI "char *curl_version( );"
|
||||||
.ad
|
.ad
|
||||||
@@ -14,9 +14,9 @@ curl_version - returns the libcurl version string
|
|||||||
Returns a human readable string with the version number of libcurl and some of
|
Returns a human readable string with the version number of libcurl and some of
|
||||||
its important components (like OpenSSL version).
|
its important components (like OpenSSL version).
|
||||||
|
|
||||||
Do note that this returns the actual running lib's version, you might have
|
Note: this returns the actual running lib's version, you might have installed
|
||||||
installed a newer lib's include files in your system which may turn your
|
a newer lib's include files in your system which may turn your LIBCURL_VERSION
|
||||||
LIBCURL_VERSION #define value to differ from this result.
|
#define value to differ from this result.
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
A pointer to a zero terminated string.
|
A pointer to a zero terminated string.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
13
docs/examples/Makefile.am
Normal file
13
docs/examples/Makefile.am
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
|
||||||
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
|
EXTRA_DIST =
|
||||||
|
README curlgtk.c sepheaders.c simple.c postit.c \
|
||||||
|
win32sockets.c persistant.c \
|
||||||
|
getpageinvar.php simpleget.php simplepost.php
|
||||||
|
|
||||||
|
all:
|
||||||
|
@echo "done"
|
@@ -6,3 +6,6 @@ advantage of libcurl.
|
|||||||
|
|
||||||
If you end up with other small but still useful example sources, please mail
|
If you end up with other small but still useful example sources, please mail
|
||||||
them for submission in future packages and on the web site.
|
them for submission in future packages and on the web site.
|
||||||
|
|
||||||
|
There are examples for different languages and environments. Browse around to
|
||||||
|
find those that fit you.
|
||||||
|
@@ -1,4 +1,12 @@
|
|||||||
/* curlgtk.c */
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
/* Copyright (c) 2000 David Odin (aka DindinX) for MandrakeSoft */
|
/* Copyright (c) 2000 David Odin (aka DindinX) for MandrakeSoft */
|
||||||
/* an attempt to use the curl library in concert with a gtk-threaded application */
|
/* an attempt to use the curl library in concert with a gtk-threaded application */
|
||||||
|
|
||||||
|
10
docs/examples/getpageinvar.php
Normal file
10
docs/examples/getpageinvar.php
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
#
|
||||||
|
# The PHP curl module supports the received page to be returned in a variable
|
||||||
|
# if told.
|
||||||
|
#
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_URL,"http://www.myurl.com/");
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
|
||||||
|
$result=curl_exec ($ch);
|
||||||
|
curl_close ($ch);
|
53
docs/examples/persistant.c
Normal file
53
docs/examples/persistant.c
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
docs/examples/win32socket.c file as well */
|
||||||
|
|
||||||
|
/* This example REQUIRES libcurl 7.7 or later */
|
||||||
|
#if (LIBCURL_VERSION_NUM < 0x070700)
|
||||||
|
#error Too old libcurl version, upgrade or stay away.
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
/* this sends all memory debug messages to a specified logfile */
|
||||||
|
curl_memdebug("memdump");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADER, 1);
|
||||||
|
|
||||||
|
/* get the first document */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/");
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* get another document from the same server using the same
|
||||||
|
connection */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/docs/");
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
71
docs/examples/postit.c
Normal file
71
docs/examples/postit.c
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* Example code that uploads a file name 'foo' to a remote script that accepts
|
||||||
|
* "HTML form based" (as described in RFC1738) uploads using HTTP POST.
|
||||||
|
*
|
||||||
|
* The imaginary form we'll fill in looks like:
|
||||||
|
*
|
||||||
|
* <form method="post" enctype="multipart/form-data" action="examplepost.cgi">
|
||||||
|
* Enter file: <input type="file" name="sendfile" size="40">
|
||||||
|
* Enter file name: <input type="text" name="filename" size="30">
|
||||||
|
* <input type="submit" value="send" name="submit">
|
||||||
|
* </form>
|
||||||
|
*
|
||||||
|
* This exact source code has not been verified to work.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
win32socket.c file as well */
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
struct HttpPost *formpost=NULL;
|
||||||
|
struct HttpPost *lastptr=NULL;
|
||||||
|
|
||||||
|
/* Fill in the file upload field */
|
||||||
|
curl_formparse("sendfile=@foo",
|
||||||
|
&formpost,
|
||||||
|
&lastptr);
|
||||||
|
|
||||||
|
/* Fill in the filename field */
|
||||||
|
curl_formparse("filename=foo",
|
||||||
|
&formpost,
|
||||||
|
&lastptr);
|
||||||
|
|
||||||
|
|
||||||
|
/* Fill in the submit field too, even if this is rarely needed */
|
||||||
|
curl_formparse("submit=send",
|
||||||
|
&formpost,
|
||||||
|
&lastptr);
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* what URL that receives this POST */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "http://curl.haxx.se/examplepost.cgi");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
/* then cleanup the formpost chain */
|
||||||
|
curl_formfree(formpost);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -1,3 +1,16 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
win32socket.c file as well */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@@ -1,9 +1,22 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <curl/types.h>
|
#include <curl/types.h>
|
||||||
#include <curl/easy.h>
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
win32socket.c file as well */
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
|
13
docs/examples/simpleget.php
Normal file
13
docs/examples/simpleget.php
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
#
|
||||||
|
# A very simple example that gets a HTTP page.
|
||||||
|
#
|
||||||
|
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
curl_setopt ($ch, CURLOPT_URL, "http://www.zend.com/");
|
||||||
|
curl_setopt ($ch, CURLOPT_HEADER, 0);
|
||||||
|
|
||||||
|
curl_exec ($ch);
|
||||||
|
|
||||||
|
curl_close ($ch);
|
||||||
|
|
12
docs/examples/simplepost.php
Normal file
12
docs/examples/simplepost.php
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
#
|
||||||
|
# A very simple PHP example that sends a HTTP POST to a remote site
|
||||||
|
#
|
||||||
|
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_URL,"http://www.mysite.com/tester.phtml");
|
||||||
|
curl_setopt($ch, CURLOPT_POST, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_POSTFIELDS, "postvar1=value1&postvar2=value2&postvar3=value3");
|
||||||
|
|
||||||
|
curl_exec ($ch);
|
||||||
|
curl_close ($ch);
|
40
docs/examples/win32sockets.c
Normal file
40
docs/examples/win32sockets.c
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* These are example functions doing socket init that Windows
|
||||||
|
* require. If you don't use windows, you can safely ignore this crap.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void win32_cleanup(void)
|
||||||
|
{
|
||||||
|
WSACleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode win32_init(void)
|
||||||
|
{
|
||||||
|
WORD wVersionRequested;
|
||||||
|
WSADATA wsaData;
|
||||||
|
int err;
|
||||||
|
wVersionRequested = MAKEWORD(1, 1);
|
||||||
|
|
||||||
|
err = WSAStartup(wVersionRequested, &wsaData);
|
||||||
|
|
||||||
|
if (err != 0)
|
||||||
|
/* Tell the user that we couldn't find a useable */
|
||||||
|
/* winsock.dll. */
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
/* Confirm that the Windows Sockets DLL supports 1.1.*/
|
||||||
|
/* Note that if the DLL supports versions greater */
|
||||||
|
/* than 1.1 in addition to 1.1, it will still return */
|
||||||
|
/* 1.1 in wVersion since that is the version we */
|
||||||
|
/* requested. */
|
||||||
|
|
||||||
|
if ( LOBYTE( wsaData.wVersion ) != 1 ||
|
||||||
|
HIBYTE( wsaData.wVersion ) != 1 ) {
|
||||||
|
/* Tell the user that we couldn't find a useable */
|
||||||
|
|
||||||
|
/* winsock.dll. */
|
||||||
|
WSACleanup();
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0; /* 0 is ok */
|
||||||
|
}
|
@@ -97,68 +97,57 @@ typedef int (*curl_passwd_callback)(void *clientp,
|
|||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
CURLE_OK = 0,
|
CURLE_OK = 0,
|
||||||
CURLE_UNSUPPORTED_PROTOCOL,
|
CURLE_UNSUPPORTED_PROTOCOL, /* 1 */
|
||||||
CURLE_FAILED_INIT,
|
CURLE_FAILED_INIT, /* 2 */
|
||||||
CURLE_URL_MALFORMAT,
|
CURLE_URL_MALFORMAT, /* 3 */
|
||||||
CURLE_URL_MALFORMAT_USER,
|
CURLE_URL_MALFORMAT_USER, /* 4 */
|
||||||
CURLE_COULDNT_RESOLVE_PROXY,
|
CURLE_COULDNT_RESOLVE_PROXY, /* 5 */
|
||||||
CURLE_COULDNT_RESOLVE_HOST,
|
CURLE_COULDNT_RESOLVE_HOST, /* 6 */
|
||||||
CURLE_COULDNT_CONNECT,
|
CURLE_COULDNT_CONNECT, /* 7 */
|
||||||
CURLE_FTP_WEIRD_SERVER_REPLY,
|
CURLE_FTP_WEIRD_SERVER_REPLY, /* 8 */
|
||||||
CURLE_FTP_ACCESS_DENIED,
|
CURLE_FTP_ACCESS_DENIED, /* 9 */
|
||||||
CURLE_FTP_USER_PASSWORD_INCORRECT,
|
CURLE_FTP_USER_PASSWORD_INCORRECT, /* 10 */
|
||||||
CURLE_FTP_WEIRD_PASS_REPLY,
|
CURLE_FTP_WEIRD_PASS_REPLY, /* 11 */
|
||||||
CURLE_FTP_WEIRD_USER_REPLY,
|
CURLE_FTP_WEIRD_USER_REPLY, /* 12 */
|
||||||
CURLE_FTP_WEIRD_PASV_REPLY,
|
CURLE_FTP_WEIRD_PASV_REPLY, /* 13 */
|
||||||
CURLE_FTP_WEIRD_227_FORMAT,
|
CURLE_FTP_WEIRD_227_FORMAT, /* 14 */
|
||||||
CURLE_FTP_CANT_GET_HOST,
|
CURLE_FTP_CANT_GET_HOST, /* 15 */
|
||||||
CURLE_FTP_CANT_RECONNECT,
|
CURLE_FTP_CANT_RECONNECT, /* 16 */
|
||||||
CURLE_FTP_COULDNT_SET_BINARY,
|
CURLE_FTP_COULDNT_SET_BINARY, /* 17 */
|
||||||
CURLE_PARTIAL_FILE,
|
CURLE_PARTIAL_FILE, /* 18 */
|
||||||
CURLE_FTP_COULDNT_RETR_FILE,
|
CURLE_FTP_COULDNT_RETR_FILE, /* 19 */
|
||||||
CURLE_FTP_WRITE_ERROR,
|
CURLE_FTP_WRITE_ERROR, /* 20 */
|
||||||
CURLE_FTP_QUOTE_ERROR,
|
CURLE_FTP_QUOTE_ERROR, /* 21 */
|
||||||
CURLE_HTTP_NOT_FOUND,
|
CURLE_HTTP_NOT_FOUND, /* 22 */
|
||||||
CURLE_WRITE_ERROR,
|
CURLE_WRITE_ERROR, /* 23 */
|
||||||
|
CURLE_MALFORMAT_USER, /* 24 - user name is illegally specified */
|
||||||
|
CURLE_FTP_COULDNT_STOR_FILE, /* 25 - failed FTP upload */
|
||||||
|
CURLE_READ_ERROR, /* 26 - could open/read from file */
|
||||||
|
CURLE_OUT_OF_MEMORY, /* 27 */
|
||||||
|
CURLE_OPERATION_TIMEOUTED, /* 28 - the timeout time was reached */
|
||||||
|
CURLE_FTP_COULDNT_SET_ASCII, /* 29 - TYPE A failed */
|
||||||
|
CURLE_FTP_PORT_FAILED, /* 30 - FTP PORT operation failed */
|
||||||
|
CURLE_FTP_COULDNT_USE_REST, /* 31 - the REST command failed */
|
||||||
|
CURLE_FTP_COULDNT_GET_SIZE, /* 32 - the SIZE command failed */
|
||||||
|
CURLE_HTTP_RANGE_ERROR, /* 33 - RANGE "command" didn't work */
|
||||||
|
CURLE_HTTP_POST_ERROR, /* 34 */
|
||||||
|
CURLE_SSL_CONNECT_ERROR, /* 35 - wrong when connecting with SSL */
|
||||||
|
CURLE_FTP_BAD_DOWNLOAD_RESUME, /* 36 - couldn't resume download */
|
||||||
|
CURLE_FILE_COULDNT_READ_FILE, /* 37 */
|
||||||
|
CURLE_LDAP_CANNOT_BIND, /* 38 */
|
||||||
|
CURLE_LDAP_SEARCH_FAILED, /* 39 */
|
||||||
|
CURLE_LIBRARY_NOT_FOUND, /* 40 */
|
||||||
|
CURLE_FUNCTION_NOT_FOUND, /* 41 */
|
||||||
|
CURLE_ABORTED_BY_CALLBACK, /* 42 */
|
||||||
|
CURLE_BAD_FUNCTION_ARGUMENT, /* 43 */
|
||||||
|
CURLE_BAD_CALLING_ORDER, /* 44 */
|
||||||
|
CURLE_HTTP_PORT_FAILED, /* 45 - HTTP Interface operation failed */
|
||||||
|
CURLE_BAD_PASSWORD_ENTERED, /* 46 - my_getpass() returns fail */
|
||||||
|
CURLE_TOO_MANY_REDIRECTS , /* 47 - catch endless re-direct loops */
|
||||||
|
CURLE_UNKNOWN_TELNET_OPTION, /* 48 - User specified an unknown option */
|
||||||
|
CURLE_TELNET_OPTION_SYNTAX , /* 49 - Malformed telnet option */
|
||||||
|
|
||||||
CURLE_MALFORMAT_USER, /* the user name is illegally specified */
|
CURL_LAST /* never use! */
|
||||||
CURLE_FTP_COULDNT_STOR_FILE, /* failed FTP upload */
|
|
||||||
CURLE_READ_ERROR, /* could open/read from file */
|
|
||||||
|
|
||||||
CURLE_OUT_OF_MEMORY,
|
|
||||||
CURLE_OPERATION_TIMEOUTED, /* the timeout time was reached */
|
|
||||||
CURLE_FTP_COULDNT_SET_ASCII, /* TYPE A failed */
|
|
||||||
|
|
||||||
CURLE_FTP_PORT_FAILED, /* FTP PORT operation failed */
|
|
||||||
|
|
||||||
CURLE_FTP_COULDNT_USE_REST, /* the REST command failed */
|
|
||||||
CURLE_FTP_COULDNT_GET_SIZE, /* the SIZE command failed */
|
|
||||||
|
|
||||||
CURLE_HTTP_RANGE_ERROR, /* The RANGE "command" didn't seem to work */
|
|
||||||
|
|
||||||
CURLE_HTTP_POST_ERROR,
|
|
||||||
|
|
||||||
CURLE_SSL_CONNECT_ERROR, /* something was wrong when connecting with SSL */
|
|
||||||
|
|
||||||
CURLE_FTP_BAD_DOWNLOAD_RESUME, /* couldn't resume download */
|
|
||||||
|
|
||||||
CURLE_FILE_COULDNT_READ_FILE,
|
|
||||||
|
|
||||||
CURLE_LDAP_CANNOT_BIND,
|
|
||||||
CURLE_LDAP_SEARCH_FAILED,
|
|
||||||
CURLE_LIBRARY_NOT_FOUND,
|
|
||||||
CURLE_FUNCTION_NOT_FOUND,
|
|
||||||
|
|
||||||
CURLE_ABORTED_BY_CALLBACK,
|
|
||||||
CURLE_BAD_FUNCTION_ARGUMENT,
|
|
||||||
CURLE_BAD_CALLING_ORDER,
|
|
||||||
|
|
||||||
CURLE_HTTP_PORT_FAILED, /* HTTP Interface operation failed */
|
|
||||||
|
|
||||||
CURLE_BAD_PASSWORD_ENTERED, /* when the my_getpass() returns fail */
|
|
||||||
CURLE_TOO_MANY_REDIRECTS , /* catch endless re-direct loops */
|
|
||||||
|
|
||||||
CURL_LAST
|
|
||||||
} CURLcode;
|
} CURLcode;
|
||||||
|
|
||||||
/* This is just to make older programs not break: */
|
/* This is just to make older programs not break: */
|
||||||
@@ -166,10 +155,6 @@ typedef enum {
|
|||||||
|
|
||||||
#define CURL_ERROR_SIZE 256
|
#define CURL_ERROR_SIZE 256
|
||||||
|
|
||||||
/* maximum URL length we deal with in headers */
|
|
||||||
#define URL_MAX_LENGTH 4096
|
|
||||||
#define URL_MAX_LENGTH_TXT "4095"
|
|
||||||
|
|
||||||
/* name is uppercase CURLOPT_<name>,
|
/* name is uppercase CURLOPT_<name>,
|
||||||
type is one of the defined CURLOPTTYPE_<type>
|
type is one of the defined CURLOPTTYPE_<type>
|
||||||
number is unique identifier */
|
number is unique identifier */
|
||||||
@@ -410,6 +395,36 @@ typedef enum {
|
|||||||
document! Pass a NULL to shut it off. */
|
document! Pass a NULL to shut it off. */
|
||||||
CINIT(FILETIME, OBJECTPOINT, 69),
|
CINIT(FILETIME, OBJECTPOINT, 69),
|
||||||
|
|
||||||
|
/* This points to a linked list of telnet options */
|
||||||
|
CINIT(TELNETOPTIONS, OBJECTPOINT, 70),
|
||||||
|
|
||||||
|
/* Max amount of cached alive connections */
|
||||||
|
CINIT(MAXCONNECTS, LONG, 71),
|
||||||
|
|
||||||
|
/* What policy to use when closing connections when the cache is filled
|
||||||
|
up */
|
||||||
|
CINIT(CLOSEPOLICY, LONG, 72),
|
||||||
|
|
||||||
|
/* Callback to use when CURLCLOSEPOLICY_CALLBACK is set */
|
||||||
|
CINIT(CLOSEFUNCTION, FUNCTIONPOINT, 73),
|
||||||
|
|
||||||
|
/* Set to explicitly use a new connection for the upcoming transfer.
|
||||||
|
Do not use this unless you're absolutely sure of this, as it makes the
|
||||||
|
operation slower and is less friendly for the network. */
|
||||||
|
CINIT(FRESH_CONNECT, LONG, 74),
|
||||||
|
|
||||||
|
/* Set to explicitly forbid the upcoming transfer's connection to be re-used
|
||||||
|
when done. Do not use this unless you're absolutely sure of this, as it
|
||||||
|
makes the operation slower and is less friendly for the network. */
|
||||||
|
CINIT(FORBID_REUSE, LONG, 75),
|
||||||
|
|
||||||
|
/* Set to a file name that contains random data for libcurl to use to
|
||||||
|
seed the random engine when doing SSL connects. */
|
||||||
|
CINIT(RANDOM_FILE, OBJECTPOINT, 76),
|
||||||
|
|
||||||
|
/* Set to the Entropy Gathering Daemon socket pathname */
|
||||||
|
CINIT(EGDSOCKET, OBJECTPOINT, 77),
|
||||||
|
|
||||||
CURLOPT_LASTENTRY /* the last unusued */
|
CURLOPT_LASTENTRY /* the last unusued */
|
||||||
} CURLoption;
|
} CURLoption;
|
||||||
|
|
||||||
@@ -435,8 +450,10 @@ typedef enum {
|
|||||||
|
|
||||||
NOTE: they return TRUE if the strings match *case insensitively*.
|
NOTE: they return TRUE if the strings match *case insensitively*.
|
||||||
*/
|
*/
|
||||||
extern int (strequal)(const char *s1, const char *s2);
|
extern int (curl_strequal)(const char *s1, const char *s2);
|
||||||
extern int (strnequal)(const char *s1, const char *s2, size_t n);
|
extern int (curl_strnequal)(const char *s1, const char *s2, size_t n);
|
||||||
|
#define strequal(a,b) curl_strequal(a,b)
|
||||||
|
#define strnequal(a,b,c) curl_strnequal(a,b,c)
|
||||||
|
|
||||||
/* external form function */
|
/* external form function */
|
||||||
int curl_formparse(char *string,
|
int curl_formparse(char *string,
|
||||||
@@ -454,8 +471,8 @@ char *curl_getenv(char *variable);
|
|||||||
char *curl_version(void);
|
char *curl_version(void);
|
||||||
|
|
||||||
/* This is the version number */
|
/* This is the version number */
|
||||||
#define LIBCURL_VERSION "7.5.2"
|
#define LIBCURL_VERSION "7.7-beta3"
|
||||||
#define LIBCURL_VERSION_NUM 0x070502
|
#define LIBCURL_VERSION_NUM 0x070700
|
||||||
|
|
||||||
/* linked-list structure for the CURLOPT_QUOTE option (and other) */
|
/* linked-list structure for the CURLOPT_QUOTE option (and other) */
|
||||||
struct curl_slist {
|
struct curl_slist {
|
||||||
@@ -463,184 +480,8 @@ struct curl_slist {
|
|||||||
struct curl_slist *next;
|
struct curl_slist *next;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct curl_slist *curl_slist_append(struct curl_slist *list, char *data);
|
struct curl_slist *curl_slist_append(struct curl_slist *, const char *);
|
||||||
void curl_slist_free_all(struct curl_slist *list);
|
void curl_slist_free_all(struct curl_slist *);
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_init()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Inits libcurl globally. This must be used before any libcurl calls can
|
|
||||||
* be used. This may install global plug-ins or whatever. (This does not
|
|
||||||
* do winsock inits in Windows.)
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* curl_init();
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
CURLcode curl_init(void);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_init()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Frees libcurl globally. This must be used after all libcurl calls have
|
|
||||||
* been used. This may remove global plug-ins or whatever. (This does not
|
|
||||||
* do winsock cleanups in Windows.)
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* curl_free(curl);
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
void curl_free(void);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_open()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Opens a general curl session. It does not try to connect or do anything
|
|
||||||
* on the network because of this call. The specified URL is only required
|
|
||||||
* to enable curl to figure out what protocol to "activate".
|
|
||||||
*
|
|
||||||
* A session should be looked upon as a series of requests to a single host. A
|
|
||||||
* session interacts with one host only, using one single protocol.
|
|
||||||
*
|
|
||||||
* The URL is not required. If set to "" or NULL, it can still be set later
|
|
||||||
* using the curl_setopt() function. If the curl_connect() function is called
|
|
||||||
* without the URL being known, it will return error.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLcode result;
|
|
||||||
* CURL *curl;
|
|
||||||
* result = curl_open(&curl, "http://curl.haxx.nu/libcurl/");
|
|
||||||
* if(result != CURL_OK) {
|
|
||||||
* return result;
|
|
||||||
* }
|
|
||||||
* */
|
|
||||||
CURLcode curl_open(CURL **curl, char *url);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_setopt()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Sets a particular option to the specified value.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURL curl;
|
|
||||||
* curl_setopt(curl, CURL_HTTP_FOLLOW_LOCATION, TRUE);
|
|
||||||
*/
|
|
||||||
CURLcode curl_setopt(CURL *handle, CURLoption option, ...);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_close()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Closes a session previously opened with curl_open()
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURL *curl;
|
|
||||||
* CURLcode result;
|
|
||||||
*
|
|
||||||
* result = curl_close(curl);
|
|
||||||
*/
|
|
||||||
CURLcode curl_close(CURL *curl); /* the opposite of curl_open() */
|
|
||||||
|
|
||||||
CURLcode curl_read(CURLconnect *c_conn, char *buf, size_t buffersize,
|
|
||||||
size_t *n);
|
|
||||||
CURLcode curl_write(CURLconnect *c_conn, char *buf, size_t amount,
|
|
||||||
size_t *n);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_connect()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Connects to the peer server and performs the initial setup. This function
|
|
||||||
* writes a connect handle to its second argument that is a unique handle for
|
|
||||||
* this connect. This allows multiple connects from the same handle returned
|
|
||||||
* by curl_open().
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLCode result;
|
|
||||||
* CURL curl;
|
|
||||||
* CURLconnect connect;
|
|
||||||
* result = curl_connect(curl, &connect);
|
|
||||||
*/
|
|
||||||
|
|
||||||
CURLcode curl_connect(CURL *curl, CURLconnect **in_connect);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_do()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* (Note: May 3rd 2000: this function does not currently allow you to
|
|
||||||
* specify a document, it will use the one set previously)
|
|
||||||
*
|
|
||||||
* This function asks for the particular document, file or resource that
|
|
||||||
* resides on the server we have connected to. You may specify a full URL,
|
|
||||||
* just an absolute path or even a relative path. That means, if you're just
|
|
||||||
* getting one file from the remote site, you can use the same URL as input
|
|
||||||
* for both curl_open() as well as for this function.
|
|
||||||
*
|
|
||||||
* In the even there is a host name, port number, user name or password parts
|
|
||||||
* in the URL, you can use the 'flags' argument to ignore them completely, or
|
|
||||||
* at your choice, make the function fail if you're trying to get a URL from
|
|
||||||
* different host than you connected to with curl_connect().
|
|
||||||
*
|
|
||||||
* You can only get one document at a time using the same connection. When one
|
|
||||||
* document has been received you can although request again.
|
|
||||||
*
|
|
||||||
* When the transfer is done, curl_done() MUST be called.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLCode result;
|
|
||||||
* char *url;
|
|
||||||
* CURLconnect *connect;
|
|
||||||
* result = curl_do(connect, url, CURL_DO_NONE); */
|
|
||||||
CURLcode curl_do(CURLconnect *in_conn);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_done()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* When the transfer following a curl_do() call is done, this function should
|
|
||||||
* get called.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLCode result;
|
|
||||||
* char *url;
|
|
||||||
* CURLconnect *connect;
|
|
||||||
* result = curl_done(connect); */
|
|
||||||
CURLcode curl_done(CURLconnect *connect);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NAME curl_disconnect()
|
|
||||||
*
|
|
||||||
* DESCRIPTION
|
|
||||||
*
|
|
||||||
* Disconnects from the peer server and performs connection cleanup.
|
|
||||||
*
|
|
||||||
* EXAMPLE
|
|
||||||
*
|
|
||||||
* CURLcode result;
|
|
||||||
* CURLconnect *connect;
|
|
||||||
* result = curl_disconnect(connect); */
|
|
||||||
CURLcode curl_disconnect(CURLconnect *connect);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* NAME curl_getdate()
|
* NAME curl_getdate()
|
||||||
@@ -678,22 +519,28 @@ typedef enum {
|
|||||||
CURLINFO_SSL_VERIFYRESULT = CURLINFO_LONG + 13,
|
CURLINFO_SSL_VERIFYRESULT = CURLINFO_LONG + 13,
|
||||||
CURLINFO_FILETIME = CURLINFO_LONG + 14,
|
CURLINFO_FILETIME = CURLINFO_LONG + 14,
|
||||||
|
|
||||||
CURLINFO_LASTONE = 15
|
CURLINFO_CONTENT_LENGTH_DOWNLOAD = CURLINFO_DOUBLE + 15,
|
||||||
|
CURLINFO_CONTENT_LENGTH_UPLOAD = CURLINFO_DOUBLE + 16,
|
||||||
|
|
||||||
|
CURLINFO_LASTONE = 17
|
||||||
} CURLINFO;
|
} CURLINFO;
|
||||||
|
|
||||||
/*
|
/* unfortunately, the easy.h include file needs the options and info stuff
|
||||||
* NAME curl_getinfo()
|
before it can be included! */
|
||||||
*
|
#include <curl/easy.h> /* nothing in curl is fun without the easy stuff */
|
||||||
* DESCRIPTION
|
|
||||||
*
|
typedef enum {
|
||||||
* Request internal information from the curl session with this function.
|
CURLCLOSEPOLICY_NONE, /* first, never use this */
|
||||||
* The third argument MUST be a pointer to a long or a pointer to a char *.
|
|
||||||
* The data pointed to will be filled in accordingly and can be relied upon
|
CURLCLOSEPOLICY_OLDEST,
|
||||||
* only if the function returns CURLE_OK.
|
CURLCLOSEPOLICY_LEAST_RECENTLY_USED,
|
||||||
* This function is intended to get used *AFTER* a performed transfer, all
|
CURLCLOSEPOLICY_LEAST_TRAFFIC,
|
||||||
* results are undefined before the transfer is completed.
|
CURLCLOSEPOLICY_SLOWEST,
|
||||||
*/
|
CURLCLOSEPOLICY_CALLBACK,
|
||||||
CURLcode curl_getinfo(CURL *curl, CURLINFO info, ...);
|
|
||||||
|
CURLCLOSEPOLICY_LAST /* last, never use this */
|
||||||
|
} curl_closepolicy;
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@@ -55,26 +55,28 @@
|
|||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
int mprintf(const char *format, ...);
|
int curl_mprintf(const char *format, ...);
|
||||||
int mfprintf(FILE *fd, const char *format, ...);
|
int curl_mfprintf(FILE *fd, const char *format, ...);
|
||||||
int msprintf(char *buffer, const char *format, ...);
|
int curl_msprintf(char *buffer, const char *format, ...);
|
||||||
int msnprintf(char *buffer, size_t maxlength, const char *format, ...);
|
int curl_msnprintf(char *buffer, size_t maxlength, const char *format, ...);
|
||||||
int mvprintf(const char *format, va_list args);
|
int curl_mvprintf(const char *format, va_list args);
|
||||||
int mvfprintf(FILE *fd, const char *format, va_list args);
|
int curl_mvfprintf(FILE *fd, const char *format, va_list args);
|
||||||
int mvsprintf(char *buffer, const char *format, va_list args);
|
int curl_mvsprintf(char *buffer, const char *format, va_list args);
|
||||||
int mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list args);
|
int curl_mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list args);
|
||||||
char *maprintf(const char *format, ...);
|
char *curl_maprintf(const char *format, ...);
|
||||||
char *mvaprintf(const char *format, va_list args);
|
char *curl_mvaprintf(const char *format, va_list args);
|
||||||
|
|
||||||
#ifdef _MPRINTF_REPLACE
|
#ifdef _MPRINTF_REPLACE
|
||||||
# define printf mprintf
|
# define printf curl_mprintf
|
||||||
# define fprintf mfprintf
|
# define fprintf curl_mfprintf
|
||||||
# define sprintf msprintf
|
# define sprintf curl_msprintf
|
||||||
# define snprintf msnprintf
|
# define snprintf curl_msnprintf
|
||||||
# define vprintf mvprintf
|
# define vprintf curl_mvprintf
|
||||||
# define vfprintf mvfprintf
|
# define vfprintf curl_mvfprintf
|
||||||
# define vsprintf mvsprintf
|
# define vsprintf curl_mvsprintf
|
||||||
# define vsnprintf mvsnprintf
|
# define vsnprintf curl_mvsnprintf
|
||||||
|
# define aprintf curl_maprintf
|
||||||
|
# define vaprintf curl_mvaprintf
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* H_MPRINTF */
|
#endif /* H_MPRINTF */
|
||||||
|
@@ -4,6 +4,10 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign
|
AUTOMAKE_OPTIONS = foreign
|
||||||
|
|
||||||
|
EXTRA_DIST = getdate.y \
|
||||||
|
Makefile.b32 Makefile.b32.resp Makefile.m32 Makefile.vc6 \
|
||||||
|
libcurl.def dllinit.c curllib.dsp curllib.dsw
|
||||||
|
|
||||||
lib_LTLIBRARIES = libcurl.la
|
lib_LTLIBRARIES = libcurl.la
|
||||||
|
|
||||||
# Some flags needed when trying to cause warnings ;-)
|
# Some flags needed when trying to cause warnings ;-)
|
||||||
@@ -12,7 +16,7 @@ lib_LTLIBRARIES = libcurl.la
|
|||||||
INCLUDES = -I$(top_srcdir)/include
|
INCLUDES = -I$(top_srcdir)/include
|
||||||
|
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = -version-info 1:0:0
|
libcurl_la_LDFLAGS = -version-info 2:0:0
|
||||||
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
||||||
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
|
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
|
||||||
# 1.
|
# 1.
|
||||||
@@ -49,12 +53,15 @@ cookie.c formdata.h http.c sendf.c \
|
|||||||
cookie.h ftp.c http.h sendf.h url.c \
|
cookie.h ftp.c http.h sendf.h url.c \
|
||||||
dict.c ftp.h if2ip.c speedcheck.c url.h \
|
dict.c ftp.h if2ip.c speedcheck.c url.h \
|
||||||
dict.h getdate.c if2ip.h speedcheck.h urldata.h \
|
dict.h getdate.c if2ip.h speedcheck.h urldata.h \
|
||||||
download.c getdate.h ldap.c ssluse.c version.c \
|
getdate.h ldap.c ssluse.c version.c \
|
||||||
download.h getenv.c ldap.h ssluse.h \
|
getenv.c ldap.h ssluse.h \
|
||||||
escape.c getenv.h mprintf.c telnet.c \
|
escape.c mprintf.c telnet.c \
|
||||||
escape.h getpass.c netrc.c telnet.h \
|
escape.h getpass.c netrc.c telnet.h \
|
||||||
getinfo.c highlevel.c strequal.c strequal.h easy.c \
|
getinfo.c transfer.c strequal.c strequal.h easy.c \
|
||||||
security.h security.c krb4.c memdebug.c memdebug.h
|
security.h security.c krb4.c krb4.h memdebug.c memdebug.h inet_ntoa_r.h \
|
||||||
|
http_chunks.c http_chunks.h
|
||||||
|
|
||||||
|
noinst_HEADERS = setup.h transfer.h
|
||||||
|
|
||||||
# Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule.
|
# Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule.
|
||||||
$(srcdir)/getdate.c: getdate.y
|
$(srcdir)/getdate.c: getdate.y
|
||||||
|
@@ -29,7 +29,7 @@ LIBCURLLIB = libcurl.lib
|
|||||||
SOURCES = \
|
SOURCES = \
|
||||||
base64.c \
|
base64.c \
|
||||||
cookie.c \
|
cookie.c \
|
||||||
download.c \
|
transfer.c \
|
||||||
escape.c \
|
escape.c \
|
||||||
formdata.c \
|
formdata.c \
|
||||||
ftp.c \
|
ftp.c \
|
||||||
@@ -54,7 +54,6 @@ SOURCES = \
|
|||||||
getinfo.c \
|
getinfo.c \
|
||||||
version.c \
|
version.c \
|
||||||
easy.c \
|
easy.c \
|
||||||
highlevel.c \
|
|
||||||
strequal.c
|
strequal.c
|
||||||
|
|
||||||
OBJECTS = $(SOURCES:.c=.obj)
|
OBJECTS = $(SOURCES:.c=.obj)
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
+base64.obj &
|
+base64.obj &
|
||||||
+cookie.obj &
|
+cookie.obj &
|
||||||
+download.obj &
|
+transfer.obj &
|
||||||
+escape.obj &
|
+escape.obj &
|
||||||
+formdata.obj &
|
+formdata.obj &
|
||||||
+ftp.obj &
|
+ftp.obj &
|
||||||
@@ -25,5 +25,4 @@
|
|||||||
+getinfo.obj &
|
+getinfo.obj &
|
||||||
+version.obj &
|
+version.obj &
|
||||||
+easy.obj &
|
+easy.obj &
|
||||||
+highlevel.obj &
|
|
||||||
+strequal.obj
|
+strequal.obj
|
||||||
|
357
lib/Makefile.in
357
lib/Makefile.in
@@ -1,357 +0,0 @@
|
|||||||
# Makefile.in generated automatically by automake 1.4 from Makefile.am
|
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995-8, 1999 Free Software Foundation, Inc.
|
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
#
|
|
||||||
# $Id$
|
|
||||||
#
|
|
||||||
|
|
||||||
|
|
||||||
SHELL = @SHELL@
|
|
||||||
|
|
||||||
srcdir = @srcdir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
VPATH = @srcdir@
|
|
||||||
prefix = @prefix@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
|
|
||||||
bindir = @bindir@
|
|
||||||
sbindir = @sbindir@
|
|
||||||
libexecdir = @libexecdir@
|
|
||||||
datadir = @datadir@
|
|
||||||
sysconfdir = @sysconfdir@
|
|
||||||
sharedstatedir = @sharedstatedir@
|
|
||||||
localstatedir = @localstatedir@
|
|
||||||
libdir = @libdir@
|
|
||||||
infodir = @infodir@
|
|
||||||
mandir = @mandir@
|
|
||||||
includedir = @includedir@
|
|
||||||
oldincludedir = /usr/include
|
|
||||||
|
|
||||||
DESTDIR =
|
|
||||||
|
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
|
||||||
|
|
||||||
top_builddir = ..
|
|
||||||
|
|
||||||
ACLOCAL = @ACLOCAL@
|
|
||||||
AUTOCONF = @AUTOCONF@
|
|
||||||
AUTOMAKE = @AUTOMAKE@
|
|
||||||
AUTOHEADER = @AUTOHEADER@
|
|
||||||
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@ $(AM_INSTALL_PROGRAM_FLAGS)
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
|
||||||
transform = @program_transform_name@
|
|
||||||
|
|
||||||
NORMAL_INSTALL = :
|
|
||||||
PRE_INSTALL = :
|
|
||||||
POST_INSTALL = :
|
|
||||||
NORMAL_UNINSTALL = :
|
|
||||||
PRE_UNINSTALL = :
|
|
||||||
POST_UNINSTALL = :
|
|
||||||
host_alias = @host_alias@
|
|
||||||
host_triplet = @host@
|
|
||||||
AS = @AS@
|
|
||||||
CC = @CC@
|
|
||||||
DLLTOOL = @DLLTOOL@
|
|
||||||
LIBTOOL = @LIBTOOL@
|
|
||||||
LN_S = @LN_S@
|
|
||||||
MAKEINFO = @MAKEINFO@
|
|
||||||
NROFF = @NROFF@
|
|
||||||
OBJDUMP = @OBJDUMP@
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
PERL = @PERL@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
YACC = @YACC@
|
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign
|
|
||||||
|
|
||||||
lib_LTLIBRARIES = libcurl.la
|
|
||||||
|
|
||||||
# Some flags needed when trying to cause warnings ;-)
|
|
||||||
# CFLAGS = -DMALLOCDEBUG -g # -Wall #-pedantic
|
|
||||||
|
|
||||||
INCLUDES = -I$(top_srcdir)/include
|
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = -version-info 1:0:0
|
|
||||||
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
|
||||||
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
|
|
||||||
# 1.
|
|
||||||
#
|
|
||||||
# If either revision or age are omitted, they default to 0. Also note that age
|
|
||||||
# must be less than or equal to the current interface number.
|
|
||||||
#
|
|
||||||
# Here are a set of rules to help you update your library version information:
|
|
||||||
#
|
|
||||||
# 1.Start with version information of 0:0:0 for each libtool library.
|
|
||||||
#
|
|
||||||
# 2.Update the version information only immediately before a public release of
|
|
||||||
# your software. More frequent updates are unnecessary, and only guarantee
|
|
||||||
# that the current interface number gets larger faster.
|
|
||||||
#
|
|
||||||
# 3.If the library source code has changed at all since the last update, then
|
|
||||||
# increment revision (c:r:a becomes c:r+1:a).
|
|
||||||
#
|
|
||||||
# 4.If any interfaces have been added, removed, or changed since the last
|
|
||||||
# update, increment current, and set revision to 0.
|
|
||||||
#
|
|
||||||
# 5.If any interfaces have been added since the last public release, then
|
|
||||||
# increment age.
|
|
||||||
#
|
|
||||||
# 6.If any interfaces have been removed since the last public release, then
|
|
||||||
# set age to 0.
|
|
||||||
#
|
|
||||||
|
|
||||||
libcurl_la_SOURCES = arpa_telnet.h file.c getpass.h netrc.h timeval.c base64.c file.h hostip.c progress.c timeval.h base64.h formdata.c hostip.h progress.h cookie.c formdata.h http.c sendf.c cookie.h ftp.c http.h sendf.h url.c dict.c ftp.h if2ip.c speedcheck.c url.h dict.h getdate.c if2ip.h speedcheck.h urldata.h download.c getdate.h ldap.c ssluse.c version.c download.h getenv.c ldap.h ssluse.h escape.c getenv.h mprintf.c telnet.c escape.h getpass.c netrc.c telnet.h getinfo.c highlevel.c strequal.c strequal.h easy.c security.h security.c krb4.c memdebug.c memdebug.h
|
|
||||||
|
|
||||||
mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
|
|
||||||
CONFIG_HEADER = ../config.h ../src/config.h
|
|
||||||
CONFIG_CLEAN_FILES =
|
|
||||||
LTLIBRARIES = $(lib_LTLIBRARIES)
|
|
||||||
|
|
||||||
|
|
||||||
DEFS = @DEFS@ -I. -I$(srcdir) -I.. -I../src
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
libcurl_la_LIBADD =
|
|
||||||
libcurl_la_OBJECTS = file.lo timeval.lo base64.lo hostip.lo progress.lo \
|
|
||||||
formdata.lo cookie.lo http.lo sendf.lo ftp.lo url.lo dict.lo if2ip.lo \
|
|
||||||
speedcheck.lo getdate.lo download.lo ldap.lo ssluse.lo version.lo \
|
|
||||||
getenv.lo escape.lo mprintf.lo telnet.lo getpass.lo netrc.lo getinfo.lo \
|
|
||||||
highlevel.lo strequal.lo easy.lo security.lo krb4.lo memdebug.lo
|
|
||||||
CFLAGS = @CFLAGS@
|
|
||||||
COMPILE = $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
|
||||||
LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
|
||||||
CCLD = $(CC)
|
|
||||||
LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(LDFLAGS) -o $@
|
|
||||||
DIST_COMMON = Makefile.am Makefile.in
|
|
||||||
|
|
||||||
|
|
||||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
|
||||||
|
|
||||||
TAR = gtar
|
|
||||||
GZIP_ENV = --best
|
|
||||||
SOURCES = $(libcurl_la_SOURCES)
|
|
||||||
OBJECTS = $(libcurl_la_OBJECTS)
|
|
||||||
|
|
||||||
all: all-redirect
|
|
||||||
.SUFFIXES:
|
|
||||||
.SUFFIXES: .S .c .lo .o .s
|
|
||||||
$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4)
|
|
||||||
cd $(top_srcdir) && $(AUTOMAKE) --foreign --include-deps lib/Makefile
|
|
||||||
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
cd $(top_builddir) \
|
|
||||||
&& CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status
|
|
||||||
|
|
||||||
|
|
||||||
mostlyclean-libLTLIBRARIES:
|
|
||||||
|
|
||||||
clean-libLTLIBRARIES:
|
|
||||||
-test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
|
|
||||||
|
|
||||||
distclean-libLTLIBRARIES:
|
|
||||||
|
|
||||||
maintainer-clean-libLTLIBRARIES:
|
|
||||||
|
|
||||||
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
|
|
||||||
@$(NORMAL_INSTALL)
|
|
||||||
$(mkinstalldirs) $(DESTDIR)$(libdir)
|
|
||||||
@list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
|
||||||
if test -f $$p; then \
|
|
||||||
echo "$(LIBTOOL) --mode=install $(INSTALL) $$p $(DESTDIR)$(libdir)/$$p"; \
|
|
||||||
$(LIBTOOL) --mode=install $(INSTALL) $$p $(DESTDIR)$(libdir)/$$p; \
|
|
||||||
else :; fi; \
|
|
||||||
done
|
|
||||||
|
|
||||||
uninstall-libLTLIBRARIES:
|
|
||||||
@$(NORMAL_UNINSTALL)
|
|
||||||
list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
|
||||||
$(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.c.o:
|
|
||||||
$(COMPILE) -c $<
|
|
||||||
|
|
||||||
.s.o:
|
|
||||||
$(COMPILE) -c $<
|
|
||||||
|
|
||||||
.S.o:
|
|
||||||
$(COMPILE) -c $<
|
|
||||||
|
|
||||||
mostlyclean-compile:
|
|
||||||
-rm -f *.o core *.core
|
|
||||||
|
|
||||||
clean-compile:
|
|
||||||
|
|
||||||
distclean-compile:
|
|
||||||
-rm -f *.tab.c
|
|
||||||
|
|
||||||
maintainer-clean-compile:
|
|
||||||
|
|
||||||
.c.lo:
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
|
||||||
|
|
||||||
.s.lo:
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
|
||||||
|
|
||||||
.S.lo:
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
|
||||||
|
|
||||||
mostlyclean-libtool:
|
|
||||||
-rm -f *.lo
|
|
||||||
|
|
||||||
clean-libtool:
|
|
||||||
-rm -rf .libs _libs
|
|
||||||
|
|
||||||
distclean-libtool:
|
|
||||||
|
|
||||||
maintainer-clean-libtool:
|
|
||||||
|
|
||||||
libcurl.la: $(libcurl_la_OBJECTS) $(libcurl_la_DEPENDENCIES)
|
|
||||||
$(LINK) -rpath $(libdir) $(libcurl_la_LDFLAGS) $(libcurl_la_OBJECTS) $(libcurl_la_LIBADD) $(LIBS)
|
|
||||||
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP)
|
|
||||||
list='$(SOURCES) $(HEADERS)'; \
|
|
||||||
unique=`for i in $$list; do echo $$i; done | \
|
|
||||||
awk ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
here=`pwd` && cd $(srcdir) \
|
|
||||||
&& mkid -f$$here/ID $$unique $(LISP)
|
|
||||||
|
|
||||||
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS)'; \
|
|
||||||
unique=`for i in $$list; do echo $$i; done | \
|
|
||||||
awk ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
test -z "$(ETAGS_ARGS)$$unique$(LISP)$$tags" \
|
|
||||||
|| (cd $(srcdir) && etags $(ETAGS_ARGS) $$tags $$unique $(LISP) -o $$here/TAGS)
|
|
||||||
|
|
||||||
mostlyclean-tags:
|
|
||||||
|
|
||||||
clean-tags:
|
|
||||||
|
|
||||||
distclean-tags:
|
|
||||||
-rm -f TAGS ID
|
|
||||||
|
|
||||||
maintainer-clean-tags:
|
|
||||||
|
|
||||||
distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir)
|
|
||||||
|
|
||||||
subdir = lib
|
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
|
||||||
@for file in $(DISTFILES); do \
|
|
||||||
d=$(srcdir); \
|
|
||||||
if test -d $$d/$$file; then \
|
|
||||||
cp -pr $$/$$file $(distdir)/$$file; \
|
|
||||||
else \
|
|
||||||
test -f $(distdir)/$$file \
|
|
||||||
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
|
||||||
|| cp -p $$d/$$file $(distdir)/$$file || :; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
info-am:
|
|
||||||
info: info-am
|
|
||||||
dvi-am:
|
|
||||||
dvi: dvi-am
|
|
||||||
check-am: all-am
|
|
||||||
check: check-am
|
|
||||||
installcheck-am:
|
|
||||||
installcheck: installcheck-am
|
|
||||||
install-exec-am: install-libLTLIBRARIES
|
|
||||||
install-exec: install-exec-am
|
|
||||||
|
|
||||||
install-data-am:
|
|
||||||
install-data: install-data-am
|
|
||||||
|
|
||||||
install-am: all-am
|
|
||||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
|
||||||
install: install-am
|
|
||||||
uninstall-am: uninstall-libLTLIBRARIES
|
|
||||||
uninstall: uninstall-am
|
|
||||||
all-am: Makefile $(LTLIBRARIES)
|
|
||||||
all-redirect: all-am
|
|
||||||
install-strip:
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) AM_INSTALL_PROGRAM_FLAGS=-s install
|
|
||||||
installdirs:
|
|
||||||
$(mkinstalldirs) $(DESTDIR)$(libdir)
|
|
||||||
|
|
||||||
|
|
||||||
mostlyclean-generic:
|
|
||||||
|
|
||||||
clean-generic:
|
|
||||||
|
|
||||||
distclean-generic:
|
|
||||||
-rm -f Makefile $(CONFIG_CLEAN_FILES)
|
|
||||||
-rm -f config.cache config.log stamp-h stamp-h[0-9]*
|
|
||||||
|
|
||||||
maintainer-clean-generic:
|
|
||||||
mostlyclean-am: mostlyclean-libLTLIBRARIES mostlyclean-compile \
|
|
||||||
mostlyclean-libtool mostlyclean-tags \
|
|
||||||
mostlyclean-generic
|
|
||||||
|
|
||||||
mostlyclean: mostlyclean-am
|
|
||||||
|
|
||||||
clean-am: clean-libLTLIBRARIES clean-compile clean-libtool clean-tags \
|
|
||||||
clean-generic mostlyclean-am
|
|
||||||
|
|
||||||
clean: clean-am
|
|
||||||
|
|
||||||
distclean-am: distclean-libLTLIBRARIES distclean-compile \
|
|
||||||
distclean-libtool distclean-tags distclean-generic \
|
|
||||||
clean-am
|
|
||||||
-rm -f libtool
|
|
||||||
|
|
||||||
distclean: distclean-am
|
|
||||||
|
|
||||||
maintainer-clean-am: maintainer-clean-libLTLIBRARIES \
|
|
||||||
maintainer-clean-compile maintainer-clean-libtool \
|
|
||||||
maintainer-clean-tags maintainer-clean-generic \
|
|
||||||
distclean-am
|
|
||||||
@echo "This command is intended for maintainers to use;"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-am
|
|
||||||
|
|
||||||
.PHONY: mostlyclean-libLTLIBRARIES distclean-libLTLIBRARIES \
|
|
||||||
clean-libLTLIBRARIES maintainer-clean-libLTLIBRARIES \
|
|
||||||
uninstall-libLTLIBRARIES install-libLTLIBRARIES mostlyclean-compile \
|
|
||||||
distclean-compile clean-compile maintainer-clean-compile \
|
|
||||||
mostlyclean-libtool distclean-libtool clean-libtool \
|
|
||||||
maintainer-clean-libtool tags mostlyclean-tags distclean-tags \
|
|
||||||
clean-tags maintainer-clean-tags distdir info-am info dvi-am dvi check \
|
|
||||||
check-am installcheck-am installcheck install-exec-am install-exec \
|
|
||||||
install-data-am install-data install-am install uninstall-am uninstall \
|
|
||||||
all-redirect all-am all installdirs mostlyclean-generic \
|
|
||||||
distclean-generic clean-generic maintainer-clean-generic clean \
|
|
||||||
mostlyclean distclean maintainer-clean
|
|
||||||
|
|
||||||
|
|
||||||
# Say $(srcdir), so GNU make does not report an ambiguity with the .y.c rule.
|
|
||||||
$(srcdir)/getdate.c: getdate.y
|
|
||||||
cd $(srcdir) && \
|
|
||||||
$(YACC) $(YFLAGS) getdate.y; \
|
|
||||||
mv -f y.tab.c getdate.c
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
@@ -30,16 +30,16 @@ libcurl_a_SOURCES = arpa_telnet.h file.c getpass.h netrc.h timeval.c base64.c \
|
|||||||
file.h hostip.c progress.c timeval.h base64.h formdata.c hostip.h progress.h \
|
file.h hostip.c progress.c timeval.h base64.h formdata.c hostip.h progress.h \
|
||||||
cookie.c formdata.h http.c sendf.c cookie.h ftp.c http.h sendf.h url.c dict.c \
|
cookie.c formdata.h http.c sendf.c cookie.h ftp.c http.h sendf.h url.c dict.c \
|
||||||
ftp.h if2ip.c speedcheck.c url.h dict.h getdate.c if2ip.h speedcheck.h \
|
ftp.h if2ip.c speedcheck.c url.h dict.h getdate.c if2ip.h speedcheck.h \
|
||||||
urldata.h download.c getdate.h ldap.c ssluse.c version.c download.h getenv.c \
|
urldata.h transfer.c getdate.h ldap.c ssluse.c version.c transfer.h getenv.c \
|
||||||
ldap.h ssluse.h escape.c getenv.h mprintf.c telnet.c escape.h getpass.c netrc.c \
|
ldap.h ssluse.h escape.c getenv.h mprintf.c telnet.c escape.h getpass.c netrc.c \
|
||||||
telnet.h getinfo.c highlevel.c strequal.c strequal.h easy.c security.h \
|
telnet.h getinfo.c strequal.c strequal.h easy.c security.h \
|
||||||
security.c krb4.c
|
security.c krb4.h krb4.c memdebug.h memdebug.c inet_ntoa_r.h http_chunks.h http_chunks.c
|
||||||
|
|
||||||
libcurl_a_OBJECTS = file.o timeval.o base64.o hostip.o progress.o \
|
libcurl_a_OBJECTS = file.o timeval.o base64.o hostip.o progress.o \
|
||||||
formdata.o cookie.o http.o sendf.o ftp.o url.o dict.o if2ip.o \
|
formdata.o cookie.o http.o sendf.o ftp.o url.o dict.o if2ip.o \
|
||||||
speedcheck.o getdate.o download.o ldap.o ssluse.o version.o \
|
speedcheck.o getdate.o transfer.o ldap.o ssluse.o version.o \
|
||||||
getenv.o escape.o mprintf.o telnet.o getpass.o netrc.o getinfo.o \
|
getenv.o escape.o mprintf.o telnet.o getpass.o netrc.o getinfo.o \
|
||||||
highlevel.o strequal.o easy.o security.o krb4.o
|
strequal.o easy.o security.o krb4.o memdebug.o http_chunks.o
|
||||||
|
|
||||||
LIBRARIES = $(libcurl_a_LIBRARIES)
|
LIBRARIES = $(libcurl_a_LIBRARIES)
|
||||||
SOURCES = $(libcurl_a_SOURCES)
|
SOURCES = $(libcurl_a_SOURCES)
|
||||||
|
@@ -33,7 +33,7 @@ LINKSLIBS = libeay32.lib ssleay32.lib RSAglue.lib
|
|||||||
RELEASE_OBJS= \
|
RELEASE_OBJS= \
|
||||||
base64r.obj \
|
base64r.obj \
|
||||||
cookier.obj \
|
cookier.obj \
|
||||||
downloadr.obj \
|
transferr.obj \
|
||||||
escaper.obj \
|
escaper.obj \
|
||||||
formdatar.obj \
|
formdatar.obj \
|
||||||
ftpr.obj \
|
ftpr.obj \
|
||||||
@@ -58,13 +58,12 @@ RELEASE_OBJS= \
|
|||||||
getinfor.obj \
|
getinfor.obj \
|
||||||
versionr.obj \
|
versionr.obj \
|
||||||
easyr.obj \
|
easyr.obj \
|
||||||
highlevelr.obj \
|
|
||||||
strequalr.obj
|
strequalr.obj
|
||||||
|
|
||||||
DEBUG_OBJS= \
|
DEBUG_OBJS= \
|
||||||
base64d.obj \
|
base64d.obj \
|
||||||
cookied.obj \
|
cookied.obj \
|
||||||
downloadd.obj \
|
transferd.obj \
|
||||||
escaped.obj \
|
escaped.obj \
|
||||||
formdatad.obj \
|
formdatad.obj \
|
||||||
ftpd.obj \
|
ftpd.obj \
|
||||||
@@ -89,13 +88,12 @@ DEBUG_OBJS= \
|
|||||||
getinfod.obj \
|
getinfod.obj \
|
||||||
versiond.obj \
|
versiond.obj \
|
||||||
easyd.obj \
|
easyd.obj \
|
||||||
highleveld.obj \
|
|
||||||
strequald.obj
|
strequald.obj
|
||||||
|
|
||||||
RELEASE_SSL_OBJS= \
|
RELEASE_SSL_OBJS= \
|
||||||
base64rs.obj \
|
base64rs.obj \
|
||||||
cookiers.obj \
|
cookiers.obj \
|
||||||
downloadrs.obj \
|
transferrs.obj \
|
||||||
escapers.obj \
|
escapers.obj \
|
||||||
formdatars.obj \
|
formdatars.obj \
|
||||||
ftprs.obj \
|
ftprs.obj \
|
||||||
@@ -120,13 +118,12 @@ RELEASE_SSL_OBJS= \
|
|||||||
getinfors.obj \
|
getinfors.obj \
|
||||||
versionrs.obj \
|
versionrs.obj \
|
||||||
easyrs.obj \
|
easyrs.obj \
|
||||||
highlevelrs.obj \
|
|
||||||
strequalrs.obj
|
strequalrs.obj
|
||||||
|
|
||||||
LINK_OBJS= \
|
LINK_OBJS= \
|
||||||
base64.obj \
|
base64.obj \
|
||||||
cookie.obj \
|
cookie.obj \
|
||||||
download.obj \
|
transfer.obj \
|
||||||
escape.obj \
|
escape.obj \
|
||||||
formdata.obj \
|
formdata.obj \
|
||||||
ftp.obj \
|
ftp.obj \
|
||||||
@@ -151,7 +148,6 @@ LINK_OBJS= \
|
|||||||
getinfo.obj \
|
getinfo.obj \
|
||||||
version.obj \
|
version.obj \
|
||||||
easy.obj \
|
easy.obj \
|
||||||
highlevel.obj \
|
|
||||||
strequal.obj
|
strequal.obj
|
||||||
|
|
||||||
all : release
|
all : release
|
||||||
@@ -170,8 +166,8 @@ base64r.obj: base64.c
|
|||||||
$(CCR) $(CFLAGS) base64.c
|
$(CCR) $(CFLAGS) base64.c
|
||||||
cookier.obj: cookie.c
|
cookier.obj: cookie.c
|
||||||
$(CCR) $(CFLAGS) cookie.c
|
$(CCR) $(CFLAGS) cookie.c
|
||||||
downloadr.obj: download.c
|
transferr.obj: transfer.c
|
||||||
$(CCR) $(CFLAGS) download.c
|
$(CCR) $(CFLAGS) transfer.c
|
||||||
escaper.obj: escape.c
|
escaper.obj: escape.c
|
||||||
$(CCR) $(CFLAGS) escape.c
|
$(CCR) $(CFLAGS) escape.c
|
||||||
formdatar.obj: formdata.c
|
formdatar.obj: formdata.c
|
||||||
@@ -220,8 +216,6 @@ versionr.obj: version.c
|
|||||||
$(CCR) $(CFLAGS) version.c
|
$(CCR) $(CFLAGS) version.c
|
||||||
easyr.obj: easy.c
|
easyr.obj: easy.c
|
||||||
$(CCR) $(CFLAGS) easy.c
|
$(CCR) $(CFLAGS) easy.c
|
||||||
highlevelr.obj: highlevel.c
|
|
||||||
$(CCR) $(CFLAGS) highlevel.c
|
|
||||||
strequalr.obj: strequal.c
|
strequalr.obj: strequal.c
|
||||||
$(CCR) $(CFLAGS) strequal.c
|
$(CCR) $(CFLAGS) strequal.c
|
||||||
|
|
||||||
@@ -230,8 +224,8 @@ base64d.obj: base64.c
|
|||||||
$(CCD) $(CFLAGS) base64.c
|
$(CCD) $(CFLAGS) base64.c
|
||||||
cookied.obj: cookie.c
|
cookied.obj: cookie.c
|
||||||
$(CCD) $(CFLAGS) cookie.c
|
$(CCD) $(CFLAGS) cookie.c
|
||||||
downloadd.obj: download.c
|
transferd.obj: transfer.c
|
||||||
$(CCD) $(CFLAGS) download.c
|
$(CCD) $(CFLAGS) transfer.c
|
||||||
escaped.obj: escape.c
|
escaped.obj: escape.c
|
||||||
$(CCD) $(CFLAGS) escape.c
|
$(CCD) $(CFLAGS) escape.c
|
||||||
formdatad.obj: formdata.c
|
formdatad.obj: formdata.c
|
||||||
@@ -280,8 +274,6 @@ versiond.obj: version.c
|
|||||||
$(CCD) $(CFLAGS) version.c
|
$(CCD) $(CFLAGS) version.c
|
||||||
easyd.obj: easy.c
|
easyd.obj: easy.c
|
||||||
$(CCD) $(CFLAGS) easy.c
|
$(CCD) $(CFLAGS) easy.c
|
||||||
highleveld.obj: highlevel.c
|
|
||||||
$(CCD) $(CFLAGS) highlevel.c
|
|
||||||
strequald.obj: strequal.c
|
strequald.obj: strequal.c
|
||||||
$(CCD) $(CFLAGS) strequal.c
|
$(CCD) $(CFLAGS) strequal.c
|
||||||
|
|
||||||
@@ -291,8 +283,8 @@ base64rs.obj: base64.c
|
|||||||
$(CCRS) $(CFLAGS) base64.c
|
$(CCRS) $(CFLAGS) base64.c
|
||||||
cookiers.obj: cookie.c
|
cookiers.obj: cookie.c
|
||||||
$(CCRS) $(CFLAGS) cookie.c
|
$(CCRS) $(CFLAGS) cookie.c
|
||||||
downloadrs.obj: download.c
|
transferrs.obj: transfer.c
|
||||||
$(CCRS) $(CFLAGS) download.c
|
$(CCRS) $(CFLAGS) transfer.c
|
||||||
escapers.obj: escape.c
|
escapers.obj: escape.c
|
||||||
$(CCRS) $(CFLAGS) escape.c
|
$(CCRS) $(CFLAGS) escape.c
|
||||||
formdatars.obj: formdata.c
|
formdatars.obj: formdata.c
|
||||||
@@ -341,8 +333,6 @@ versionrs.obj: version.c
|
|||||||
$(CCRS) $(CFLAGS) version.c
|
$(CCRS) $(CFLAGS) version.c
|
||||||
easyrs.obj: easy.c
|
easyrs.obj: easy.c
|
||||||
$(CCRS) $(CFLAGS) easy.c
|
$(CCRS) $(CFLAGS) easy.c
|
||||||
highlevelrs.obj: highlevel.c
|
|
||||||
$(CCRS) $(CFLAGS) highlevel.c
|
|
||||||
strequalrs.obj: strequal.c
|
strequalrs.obj: strequal.c
|
||||||
$(CCRS) $(CFLAGS) strequal.c
|
$(CCRS) $(CFLAGS) strequal.c
|
||||||
|
|
||||||
|
@@ -63,6 +63,7 @@
|
|||||||
#define SYNCH 242 /* for telfunc calls */
|
#define SYNCH 242 /* for telfunc calls */
|
||||||
|
|
||||||
#ifdef TELCMDS
|
#ifdef TELCMDS
|
||||||
|
static
|
||||||
char *telcmds[] = {
|
char *telcmds[] = {
|
||||||
"EOF", "SUSP", "ABORT", "EOR",
|
"EOF", "SUSP", "ABORT", "EOR",
|
||||||
"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC",
|
"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC",
|
||||||
@@ -124,6 +125,7 @@ extern char *telcmds[];
|
|||||||
|
|
||||||
#define NTELOPTS (1+TELOPT_NEW_ENVIRON)
|
#define NTELOPTS (1+TELOPT_NEW_ENVIRON)
|
||||||
#ifdef TELOPTS
|
#ifdef TELOPTS
|
||||||
|
static
|
||||||
char *telopts[NTELOPTS+1] = {
|
char *telopts[NTELOPTS+1] = {
|
||||||
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD", "NAME",
|
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD", "NAME",
|
||||||
"STATUS", "TIMING MARK", "RCTE", "NAOL", "NAOP",
|
"STATUS", "TIMING MARK", "RCTE", "NAOL", "NAOP",
|
||||||
|
@@ -55,7 +55,7 @@ static int pos(char c)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if 1
|
#if 1
|
||||||
int base64_encode(const void *data, int size, char **str)
|
int Curl_base64_encode(const void *data, int size, char **str)
|
||||||
{
|
{
|
||||||
char *s, *p;
|
char *s, *p;
|
||||||
int i;
|
int i;
|
||||||
@@ -93,7 +93,7 @@ int base64_encode(const void *data, int size, char **str)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int base64_decode(const char *str, void *data)
|
int Curl_base64_decode(const char *str, void *data)
|
||||||
{
|
{
|
||||||
const char *p;
|
const char *p;
|
||||||
unsigned char *q;
|
unsigned char *q;
|
||||||
|
@@ -34,6 +34,7 @@
|
|||||||
#ifndef __BASE64_H
|
#ifndef __BASE64_H
|
||||||
#define __BASE64_H
|
#define __BASE64_H
|
||||||
|
|
||||||
int base64_encode(const void *data, int size, char **str);
|
int Curl_base64_encode(const void *data, int size, char **str);
|
||||||
|
int Curl_base64_decode(const char *str, void *data);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
21
lib/cookie.c
21
lib/cookie.c
@@ -100,9 +100,10 @@ Example set of cookies:
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
struct Cookie *cookie_add(struct CookieInfo *c,
|
struct Cookie *
|
||||||
bool httpheader, /* TRUE if HTTP header-style line */
|
Curl_cookie_add(struct CookieInfo *c,
|
||||||
char *lineptr) /* first non-space of the line */
|
bool httpheader, /* TRUE if HTTP header-style line */
|
||||||
|
char *lineptr) /* first non-space of the line */
|
||||||
{
|
{
|
||||||
struct Cookie *clist;
|
struct Cookie *clist;
|
||||||
char what[MAX_COOKIE_LINE];
|
char what[MAX_COOKIE_LINE];
|
||||||
@@ -347,7 +348,7 @@ struct Cookie *cookie_add(struct CookieInfo *c,
|
|||||||
* called before any cookies are set. File may be NULL.
|
* called before any cookies are set. File may be NULL.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
struct CookieInfo *cookie_init(char *file)
|
struct CookieInfo *Curl_cookie_init(char *file)
|
||||||
{
|
{
|
||||||
char line[MAX_COOKIE_LINE];
|
char line[MAX_COOKIE_LINE];
|
||||||
struct CookieInfo *c;
|
struct CookieInfo *c;
|
||||||
@@ -375,7 +376,7 @@ struct CookieInfo *cookie_init(char *file)
|
|||||||
while(*lineptr && isspace((int)*lineptr))
|
while(*lineptr && isspace((int)*lineptr))
|
||||||
lineptr++;
|
lineptr++;
|
||||||
|
|
||||||
cookie_add(c, TRUE, lineptr);
|
Curl_cookie_add(c, TRUE, lineptr);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* This might be a netscape cookie-file line, get it! */
|
/* This might be a netscape cookie-file line, get it! */
|
||||||
@@ -383,7 +384,7 @@ struct CookieInfo *cookie_init(char *file)
|
|||||||
while(*lineptr && isspace((int)*lineptr))
|
while(*lineptr && isspace((int)*lineptr))
|
||||||
lineptr++;
|
lineptr++;
|
||||||
|
|
||||||
cookie_add(c, FALSE, lineptr);
|
Curl_cookie_add(c, FALSE, lineptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(fromfile)
|
if(fromfile)
|
||||||
@@ -405,8 +406,8 @@ struct CookieInfo *cookie_init(char *file)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
struct Cookie *cookie_getlist(struct CookieInfo *c,
|
struct Cookie *Curl_cookie_getlist(struct CookieInfo *c,
|
||||||
char *host, char *path, bool secure)
|
char *host, char *path, bool secure)
|
||||||
{
|
{
|
||||||
struct Cookie *newco;
|
struct Cookie *newco;
|
||||||
struct Cookie *co;
|
struct Cookie *co;
|
||||||
@@ -473,7 +474,7 @@ struct Cookie *cookie_getlist(struct CookieInfo *c,
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
void cookie_freelist(struct Cookie *co)
|
void Curl_cookie_freelist(struct Cookie *co)
|
||||||
{
|
{
|
||||||
struct Cookie *next;
|
struct Cookie *next;
|
||||||
if(co) {
|
if(co) {
|
||||||
@@ -493,7 +494,7 @@ void cookie_freelist(struct Cookie *co)
|
|||||||
* Free a "cookie object" previous created with cookie_init().
|
* Free a "cookie object" previous created with cookie_init().
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
void cookie_cleanup(struct CookieInfo *c)
|
void Curl_cookie_cleanup(struct CookieInfo *c)
|
||||||
{
|
{
|
||||||
struct Cookie *co;
|
struct Cookie *co;
|
||||||
struct Cookie *next;
|
struct Cookie *next;
|
||||||
|
10
lib/cookie.h
10
lib/cookie.h
@@ -63,10 +63,10 @@ struct CookieInfo {
|
|||||||
#define MAX_NAME 256
|
#define MAX_NAME 256
|
||||||
#define MAX_NAME_TXT "255"
|
#define MAX_NAME_TXT "255"
|
||||||
|
|
||||||
struct Cookie *cookie_add(struct CookieInfo *, bool, char *);
|
struct Cookie *Curl_cookie_add(struct CookieInfo *, bool, char *);
|
||||||
struct CookieInfo *cookie_init(char *);
|
struct CookieInfo *Curl_cookie_init(char *);
|
||||||
struct Cookie *cookie_getlist(struct CookieInfo *, char *, char *, bool);
|
struct Cookie *Curl_cookie_getlist(struct CookieInfo *, char *, char *, bool);
|
||||||
void cookie_freelist(struct Cookie *);
|
void Curl_cookie_freelist(struct Cookie *);
|
||||||
void cookie_cleanup(struct CookieInfo *);
|
void Curl_cookie_cleanup(struct CookieInfo *);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
367
lib/curllib.dsp
Normal file
367
lib/curllib.dsp
Normal file
@@ -0,0 +1,367 @@
|
|||||||
|
# Microsoft Developer Studio Project File - Name="curllib" - Package Owner=<4>
|
||||||
|
# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
||||||
|
# ** DO NOT EDIT **
|
||||||
|
|
||||||
|
# TARGTYPE "Win32 (x86) Dynamic-Link Library" 0x0102
|
||||||
|
|
||||||
|
CFG=curllib - Win32 Debug
|
||||||
|
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||||
|
!MESSAGE use the Export Makefile command and run
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "curllib.mak".
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE You can specify a configuration when running NMAKE
|
||||||
|
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE NMAKE /f "curllib.mak" CFG="curllib - Win32 Debug"
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE Possible choices for configuration are:
|
||||||
|
!MESSAGE
|
||||||
|
!MESSAGE "curllib - Win32 Release" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE "curllib - Win32 Debug" (based on "Win32 (x86) Dynamic-Link Library")
|
||||||
|
!MESSAGE
|
||||||
|
|
||||||
|
# Begin Project
|
||||||
|
# PROP AllowPerConfigDependencies 0
|
||||||
|
# PROP Scc_ProjName ""
|
||||||
|
# PROP Scc_LocalPath ""
|
||||||
|
CPP=cl.exe
|
||||||
|
MTL=midl.exe
|
||||||
|
RSC=rc.exe
|
||||||
|
|
||||||
|
!IF "$(CFG)" == "curllib - Win32 Release"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 0
|
||||||
|
# PROP BASE Output_Dir "Release"
|
||||||
|
# PROP BASE Intermediate_Dir "Release"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 0
|
||||||
|
# PROP Output_Dir "Release"
|
||||||
|
# PROP Intermediate_Dir "Release"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
||||||
|
# ADD CPP /nologo /MT /W3 /GX /O2 /I "C:\jdk1.3.0_01\include" /I "C:\jdk1.3.0_01\include\win32" /I "..\include" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
||||||
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib wsock32.lib /nologo /dll /machine:I386 /out:"Release/curl.dll"
|
||||||
|
|
||||||
|
!ELSEIF "$(CFG)" == "curllib - Win32 Debug"
|
||||||
|
|
||||||
|
# PROP BASE Use_MFC 0
|
||||||
|
# PROP BASE Use_Debug_Libraries 1
|
||||||
|
# PROP BASE Output_Dir "Debug"
|
||||||
|
# PROP BASE Intermediate_Dir "Debug"
|
||||||
|
# PROP BASE Target_Dir ""
|
||||||
|
# PROP Use_MFC 0
|
||||||
|
# PROP Use_Debug_Libraries 1
|
||||||
|
# PROP Output_Dir "Debug"
|
||||||
|
# PROP Intermediate_Dir "Debug"
|
||||||
|
# PROP Ignore_Export_Lib 0
|
||||||
|
# PROP Target_Dir ""
|
||||||
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
||||||
|
# ADD CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I "C:\jdk1.3.0_01\include" /I "C:\jdk1.3.0_01\include\win32" /I "..\include" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
||||||
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
|
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||||
|
BSC32=bscmake.exe
|
||||||
|
# ADD BASE BSC32 /nologo
|
||||||
|
# ADD BSC32 /nologo
|
||||||
|
LINK32=link.exe
|
||||||
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
||||||
|
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib wsock32.lib /nologo /dll /debug /machine:I386 /out:"Debug/curl.dll" /pdbtype:sept
|
||||||
|
|
||||||
|
!ENDIF
|
||||||
|
|
||||||
|
# Begin Target
|
||||||
|
|
||||||
|
# Name "curllib - Win32 Release"
|
||||||
|
# Name "curllib - Win32 Debug"
|
||||||
|
# Begin Group "Source Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\base64.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\cookie.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\dict.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\dllinit.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\easy.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\easyswig.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\easyswig_wrap.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\escape.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\file.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\formdata.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\ftp.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getdate.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getenv.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getinfo.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getpass.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\hostip.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\http.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\if2ip.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\krb4.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\ldap.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\libcurl.def
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\memdebug.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\mprintf.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\netrc.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\progress.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\security.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\sendf.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\speedcheck.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\ssluse.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\strequal.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\telnet.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\timeval.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\transfer.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\url.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\version.c
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\arpa_telnet.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\base64.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\cookie.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\dict.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\escape.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\file.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\formdata.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\ftp.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getdate.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getenv.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\getpass.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\hostip.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\http.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\if2ip.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\inet_ntoa_r.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\krb4.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\ldap.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\memdebug.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\netrc.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\progress.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\security.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\sendf.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\setup.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\speedcheck.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\ssluse.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\strequal.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\telnet.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\timeval.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\transfer.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\url.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\urldata.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Resource Files"
|
||||||
|
|
||||||
|
# PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe"
|
||||||
|
# End Group
|
||||||
|
# End Target
|
||||||
|
# End Project
|
29
lib/curllib.dsw
Normal file
29
lib/curllib.dsw
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
Microsoft Developer Studio Workspace File, Format Version 6.00
|
||||||
|
# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE!
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Project: "curllib"=".\curllib.dsp" - Package Owner=<4>
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<4>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
Global:
|
||||||
|
|
||||||
|
Package=<5>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
Package=<3>
|
||||||
|
{{{
|
||||||
|
}}}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
68
lib/dict.c
68
lib/dict.c
@@ -71,7 +71,7 @@
|
|||||||
|
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "download.h"
|
#include "transfer.h"
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
|
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
@@ -80,12 +80,12 @@
|
|||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
CURLcode dict_done(struct connectdata *conn)
|
CURLcode Curl_dict_done(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode dict(struct connectdata *conn)
|
CURLcode Curl_dict(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
int nth;
|
int nth;
|
||||||
char *word;
|
char *word;
|
||||||
@@ -141,21 +141,21 @@ CURLcode dict(struct connectdata *conn)
|
|||||||
nth = atoi(nthdef);
|
nth = atoi(nthdef);
|
||||||
}
|
}
|
||||||
|
|
||||||
sendf(data->firstsocket, data,
|
Curl_sendf(conn->firstsocket, conn,
|
||||||
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
||||||
"MATCH "
|
"MATCH "
|
||||||
"%s " /* database */
|
"%s " /* database */
|
||||||
"%s " /* strategy */
|
"%s " /* strategy */
|
||||||
"%s\n" /* word */
|
"%s\n" /* word */
|
||||||
"QUIT\n",
|
"QUIT\n",
|
||||||
|
|
||||||
database,
|
database,
|
||||||
strategy,
|
strategy,
|
||||||
word
|
word
|
||||||
);
|
);
|
||||||
|
|
||||||
result = Transfer(conn, data->firstsocket, -1, FALSE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
||||||
-1, NULL); /* no upload */
|
-1, NULL); /* no upload */
|
||||||
|
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
@@ -191,19 +191,19 @@ CURLcode dict(struct connectdata *conn)
|
|||||||
nth = atoi(nthdef);
|
nth = atoi(nthdef);
|
||||||
}
|
}
|
||||||
|
|
||||||
sendf(data->firstsocket, data,
|
Curl_sendf(conn->firstsocket, conn,
|
||||||
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
||||||
"DEFINE "
|
"DEFINE "
|
||||||
"%s " /* database */
|
"%s " /* database */
|
||||||
"%s\n" /* word */
|
"%s\n" /* word */
|
||||||
"QUIT\n",
|
"QUIT\n",
|
||||||
|
|
||||||
database,
|
database,
|
||||||
word
|
word
|
||||||
);
|
);
|
||||||
|
|
||||||
result = Transfer(conn, data->firstsocket, -1, FALSE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
||||||
-1, NULL); /* no upload */
|
-1, NULL); /* no upload */
|
||||||
|
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
@@ -220,14 +220,14 @@ CURLcode dict(struct connectdata *conn)
|
|||||||
if (ppath[i] == ':')
|
if (ppath[i] == ':')
|
||||||
ppath[i] = ' ';
|
ppath[i] = ' ';
|
||||||
}
|
}
|
||||||
sendf(data->firstsocket, data,
|
Curl_sendf(conn->firstsocket, conn,
|
||||||
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
"CLIENT " LIBCURL_NAME " " LIBCURL_VERSION "\n"
|
||||||
"%s\n"
|
"%s\n"
|
||||||
"QUIT\n",
|
"QUIT\n",
|
||||||
ppath);
|
ppath);
|
||||||
|
|
||||||
result = Transfer(conn, data->firstsocket, -1, FALSE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, FALSE, bytecount,
|
||||||
-1, NULL);
|
-1, NULL);
|
||||||
|
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
@@ -23,7 +23,7 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
CURLcode dict(struct connectdata *conn);
|
CURLcode Curl_dict(struct connectdata *conn);
|
||||||
CURLcode dict_done(struct connectdata *conn);
|
CURLcode Curl_dict_done(struct connectdata *conn);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
100
lib/download.c
100
lib/download.c
@@ -1,100 +0,0 @@
|
|||||||
/*****************************************************************************
|
|
||||||
* _ _ ____ _
|
|
||||||
* Project ___| | | | _ \| |
|
|
||||||
* / __| | | | |_) | |
|
|
||||||
* | (__| |_| | _ <| |___
|
|
||||||
* \___|\___/|_| \_\_____|
|
|
||||||
*
|
|
||||||
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
||||||
*
|
|
||||||
* In order to be useful for every potential user, curl and libcurl are
|
|
||||||
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
|
||||||
*
|
|
||||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
||||||
* copies of the Software, and permit persons to whom the Software is
|
|
||||||
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
|
||||||
* licenses. You may pick one of these licenses.
|
|
||||||
*
|
|
||||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
||||||
* KIND, either express or implied.
|
|
||||||
*
|
|
||||||
* $Id$
|
|
||||||
*****************************************************************************/
|
|
||||||
|
|
||||||
#include "setup.h"
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#ifdef HAVE_SYS_TYPES_H
|
|
||||||
#include <sys/types.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
#include <unistd.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_SYS_SELECT_H
|
|
||||||
#include <sys/select.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "urldata.h"
|
|
||||||
#include <curl/curl.h>
|
|
||||||
|
|
||||||
#ifdef __BEOS__
|
|
||||||
#include <net/socket.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef WIN32
|
|
||||||
#if !defined( __GNUC__) || defined(__MINGW32__)
|
|
||||||
#include <winsock.h>
|
|
||||||
#endif
|
|
||||||
#include <time.h> /* for the time_t typedef! */
|
|
||||||
|
|
||||||
#if defined(__GNUC__) && defined(TIME_WITH_SYS_TIME)
|
|
||||||
#include <sys/time.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "progress.h"
|
|
||||||
#include "speedcheck.h"
|
|
||||||
#include "sendf.h"
|
|
||||||
|
|
||||||
#include <curl/types.h>
|
|
||||||
|
|
||||||
/* --- download and upload a stream from/to a socket --- */
|
|
||||||
|
|
||||||
/* Parts of this function was brought to us by the friendly Mark Butler
|
|
||||||
<butlerm@xmission.com>. */
|
|
||||||
|
|
||||||
CURLcode
|
|
||||||
Transfer(CURLconnect *c_conn,
|
|
||||||
/* READ stuff */
|
|
||||||
int sockfd, /* socket to read from or -1 */
|
|
||||||
int size, /* -1 if unknown at this point */
|
|
||||||
bool getheader, /* TRUE if header parsing is wanted */
|
|
||||||
long *bytecountp, /* return number of bytes read or NULL */
|
|
||||||
|
|
||||||
/* WRITE stuff */
|
|
||||||
int writesockfd, /* socket to write to, it may very well be
|
|
||||||
the same we read from. -1 disables */
|
|
||||||
long *writebytecountp /* return number of bytes written or NULL */
|
|
||||||
)
|
|
||||||
{
|
|
||||||
struct connectdata *conn = (struct connectdata *)c_conn;
|
|
||||||
if(!conn)
|
|
||||||
return CURLE_BAD_FUNCTION_ARGUMENT;
|
|
||||||
|
|
||||||
/* now copy all input parameters */
|
|
||||||
conn->sockfd = sockfd;
|
|
||||||
conn->size = size;
|
|
||||||
conn->getheader = getheader;
|
|
||||||
conn->bytecountp = bytecountp;
|
|
||||||
conn->writesockfd = writesockfd;
|
|
||||||
conn->writebytecountp = writebytecountp;
|
|
||||||
|
|
||||||
return CURLE_OK;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
21
lib/easy.c
21
lib/easy.c
@@ -72,7 +72,7 @@
|
|||||||
|
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "highlevel.h"
|
#include "transfer.h"
|
||||||
#include <curl/types.h>
|
#include <curl/types.h>
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
@@ -83,15 +83,11 @@ CURL *curl_easy_init(void)
|
|||||||
CURLcode res;
|
CURLcode res;
|
||||||
struct UrlData *data;
|
struct UrlData *data;
|
||||||
|
|
||||||
if(curl_init())
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
/* We use curl_open() with undefined URL so far */
|
/* We use curl_open() with undefined URL so far */
|
||||||
res = curl_open((CURL **)&data, NULL);
|
res = Curl_open((CURL **)&data, NULL);
|
||||||
if(res != CURLE_OK)
|
if(res != CURLE_OK)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
data->interf = CURLI_EASY; /* mark it as an easy one */
|
|
||||||
/* SAC */
|
/* SAC */
|
||||||
data->device = NULL;
|
data->device = NULL;
|
||||||
|
|
||||||
@@ -119,16 +115,16 @@ CURLcode curl_easy_setopt(CURL *curl, CURLoption tag, ...)
|
|||||||
if(tag < CURLOPTTYPE_OBJECTPOINT) {
|
if(tag < CURLOPTTYPE_OBJECTPOINT) {
|
||||||
/* This is a LONG type */
|
/* This is a LONG type */
|
||||||
param_long = va_arg(arg, long);
|
param_long = va_arg(arg, long);
|
||||||
curl_setopt(data, tag, param_long);
|
Curl_setopt(data, tag, param_long);
|
||||||
}
|
}
|
||||||
else if(tag < CURLOPTTYPE_FUNCTIONPOINT) {
|
else if(tag < CURLOPTTYPE_FUNCTIONPOINT) {
|
||||||
/* This is a object pointer type */
|
/* This is a object pointer type */
|
||||||
param_obj = va_arg(arg, void *);
|
param_obj = va_arg(arg, void *);
|
||||||
curl_setopt(data, tag, param_obj);
|
Curl_setopt(data, tag, param_obj);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
param_func = va_arg(arg, func_T );
|
param_func = va_arg(arg, func_T );
|
||||||
curl_setopt(data, tag, param_func);
|
Curl_setopt(data, tag, param_func);
|
||||||
}
|
}
|
||||||
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
@@ -137,13 +133,12 @@ CURLcode curl_easy_setopt(CURL *curl, CURLoption tag, ...)
|
|||||||
|
|
||||||
CURLcode curl_easy_perform(CURL *curl)
|
CURLcode curl_easy_perform(CURL *curl)
|
||||||
{
|
{
|
||||||
return curl_transfer(curl);
|
return Curl_perform(curl);
|
||||||
}
|
}
|
||||||
|
|
||||||
void curl_easy_cleanup(CURL *curl)
|
void curl_easy_cleanup(CURL *curl)
|
||||||
{
|
{
|
||||||
curl_close(curl);
|
Curl_close(curl);
|
||||||
curl_free();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...)
|
CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...)
|
||||||
@@ -153,5 +148,5 @@ CURLcode curl_easy_getinfo(CURL *curl, CURLINFO info, ...)
|
|||||||
va_start(arg, info);
|
va_start(arg, info);
|
||||||
paramp = va_arg(arg, void *);
|
paramp = va_arg(arg, void *);
|
||||||
|
|
||||||
return curl_getinfo(curl, info, paramp);
|
return Curl_getinfo(curl, info, paramp);
|
||||||
}
|
}
|
||||||
|
@@ -78,7 +78,7 @@ char *curl_unescape(char *string, int length)
|
|||||||
char *ns = malloc(alloc);
|
char *ns = malloc(alloc);
|
||||||
unsigned char in;
|
unsigned char in;
|
||||||
int index=0;
|
int index=0;
|
||||||
int hex;
|
unsigned int hex;
|
||||||
char querypart=FALSE; /* everything to the right of a '?' letter is
|
char querypart=FALSE; /* everything to the right of a '?' letter is
|
||||||
the "query part" where '+' should become ' '.
|
the "query part" where '+' should become ' '.
|
||||||
RFC 2316, section 3.10 */
|
RFC 2316, section 3.10 */
|
||||||
|
73
lib/file.c
73
lib/file.c
@@ -91,29 +91,24 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
CURLcode file(struct connectdata *conn)
|
/* Emulate a connect-then-transfer protocol. We connect to the file here */
|
||||||
|
CURLcode Curl_file_connect(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
/* This implementation ignores the host name in conformance with
|
char *actual_path = curl_unescape(conn->path, 0);
|
||||||
RFC 1738. Only local files (reachable via the standard file system)
|
struct FILE *file;
|
||||||
are supported. This means that files on remotely mounted directories
|
|
||||||
(via NFS, Samba, NT sharing) can be accessed through a file:// URL
|
|
||||||
*/
|
|
||||||
CURLcode res = CURLE_OK;
|
|
||||||
char *path = conn->path;
|
|
||||||
struct stat statbuf;
|
|
||||||
size_t expected_size=-1;
|
|
||||||
size_t nread;
|
|
||||||
struct UrlData *data = conn->data;
|
|
||||||
char *buf = data->buffer;
|
|
||||||
int bytecount = 0;
|
|
||||||
struct timeval start = tvnow();
|
|
||||||
struct timeval now = start;
|
|
||||||
int fd;
|
int fd;
|
||||||
char *actual_path = curl_unescape(path, 0);
|
|
||||||
|
|
||||||
#if defined(WIN32) || defined(__EMX__)
|
#if defined(WIN32) || defined(__EMX__)
|
||||||
int i;
|
int i;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
file = (struct FILE *)malloc(sizeof(struct FILE));
|
||||||
|
if(!file)
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
|
memset(file, 0, sizeof(struct FILE));
|
||||||
|
conn->proto.file = file;
|
||||||
|
|
||||||
|
#if defined(WIN32) || defined(__EMX__)
|
||||||
/* change path separators from '/' to '\\' for Windows and OS/2 */
|
/* change path separators from '/' to '\\' for Windows and OS/2 */
|
||||||
for (i=0; actual_path[i] != '\0'; ++i)
|
for (i=0; actual_path[i] != '\0'; ++i)
|
||||||
if (actual_path[i] == '/')
|
if (actual_path[i] == '/')
|
||||||
@@ -126,9 +121,37 @@ CURLcode file(struct connectdata *conn)
|
|||||||
free(actual_path);
|
free(actual_path);
|
||||||
|
|
||||||
if(fd == -1) {
|
if(fd == -1) {
|
||||||
failf(data, "Couldn't open file %s", path);
|
failf(conn->data, "Couldn't open file %s", conn->path);
|
||||||
return CURLE_FILE_COULDNT_READ_FILE;
|
return CURLE_FILE_COULDNT_READ_FILE;
|
||||||
}
|
}
|
||||||
|
file->fd = fd;
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* This is the do-phase, separated from the connect-phase above */
|
||||||
|
|
||||||
|
CURLcode Curl_file(struct connectdata *conn)
|
||||||
|
{
|
||||||
|
/* This implementation ignores the host name in conformance with
|
||||||
|
RFC 1738. Only local files (reachable via the standard file system)
|
||||||
|
are supported. This means that files on remotely mounted directories
|
||||||
|
(via NFS, Samba, NT sharing) can be accessed through a file:// URL
|
||||||
|
*/
|
||||||
|
CURLcode res = CURLE_OK;
|
||||||
|
struct stat statbuf;
|
||||||
|
size_t expected_size=-1;
|
||||||
|
size_t nread;
|
||||||
|
struct UrlData *data = conn->data;
|
||||||
|
char *buf = data->buffer;
|
||||||
|
int bytecount = 0;
|
||||||
|
struct timeval start = Curl_tvnow();
|
||||||
|
struct timeval now = start;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
/* get the fd from the connection phase */
|
||||||
|
fd = conn->proto.file->fd;
|
||||||
|
|
||||||
if( -1 != fstat(fd, &statbuf)) {
|
if( -1 != fstat(fd, &statbuf)) {
|
||||||
/* we could stat it, then read out the size */
|
/* we could stat it, then read out the size */
|
||||||
expected_size = statbuf.st_size;
|
expected_size = statbuf.st_size;
|
||||||
@@ -139,7 +162,7 @@ CURLcode file(struct connectdata *conn)
|
|||||||
it avoids problems with select() and recv() on file descriptors
|
it avoids problems with select() and recv() on file descriptors
|
||||||
in Winsock */
|
in Winsock */
|
||||||
if(expected_size != -1)
|
if(expected_size != -1)
|
||||||
pgrsSetDownloadSize(data, expected_size);
|
Curl_pgrsSetDownloadSize(data, expected_size);
|
||||||
|
|
||||||
while (res == CURLE_OK) {
|
while (res == CURLE_OK) {
|
||||||
nread = read(fd, buf, BUFSIZE-1);
|
nread = read(fd, buf, BUFSIZE-1);
|
||||||
@@ -155,16 +178,16 @@ CURLcode file(struct connectdata *conn)
|
|||||||
to prevent CR/LF translation (this then goes to a binary mode
|
to prevent CR/LF translation (this then goes to a binary mode
|
||||||
file descriptor). */
|
file descriptor). */
|
||||||
|
|
||||||
res = client_write(data, CLIENTWRITE_BODY, buf, nread);
|
res = Curl_client_write(data, CLIENTWRITE_BODY, buf, nread);
|
||||||
if(res)
|
if(res)
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
now = tvnow();
|
now = Curl_tvnow();
|
||||||
if(pgrsUpdate(data))
|
if(Curl_pgrsUpdate(data))
|
||||||
res = CURLE_ABORTED_BY_CALLBACK;
|
res = CURLE_ABORTED_BY_CALLBACK;
|
||||||
}
|
}
|
||||||
now = tvnow();
|
now = Curl_tvnow();
|
||||||
if(pgrsUpdate(data))
|
if(Curl_pgrsUpdate(data))
|
||||||
res = CURLE_ABORTED_BY_CALLBACK;
|
res = CURLE_ABORTED_BY_CALLBACK;
|
||||||
|
|
||||||
close(fd);
|
close(fd);
|
||||||
|
@@ -23,6 +23,6 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
CURLcode file(struct connectdata *conn);
|
CURLcode Curl_file(struct connectdata *conn);
|
||||||
|
CURLcode Curl_file_connect(struct connectdata *conn);
|
||||||
#endif
|
#endif
|
||||||
|
@@ -91,16 +91,10 @@ static void GetStr(char **string,
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
int curl_formparse(char *input,
|
|
||||||
struct HttpPost **httppost,
|
|
||||||
struct HttpPost **last_post)
|
|
||||||
{
|
|
||||||
return FormParse(input, httppost, last_post);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define FORM_FILE_SEPARATOR ','
|
#define FORM_FILE_SEPARATOR ','
|
||||||
#define FORM_TYPE_SEPARATOR ';'
|
#define FORM_TYPE_SEPARATOR ';'
|
||||||
|
|
||||||
|
static
|
||||||
int FormParse(char *input,
|
int FormParse(char *input,
|
||||||
struct HttpPost **httppost,
|
struct HttpPost **httppost,
|
||||||
struct HttpPost **last_post)
|
struct HttpPost **last_post)
|
||||||
@@ -298,6 +292,13 @@ int FormParse(char *input,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int curl_formparse(char *input,
|
||||||
|
struct HttpPost **httppost,
|
||||||
|
struct HttpPost **last_post)
|
||||||
|
{
|
||||||
|
return FormParse(input, httppost, last_post);
|
||||||
|
}
|
||||||
|
|
||||||
static int AddFormData(struct FormData **formp,
|
static int AddFormData(struct FormData **formp,
|
||||||
void *line,
|
void *line,
|
||||||
long length)
|
long length)
|
||||||
@@ -339,7 +340,7 @@ static int AddFormDataf(struct FormData **formp,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
char *MakeFormBoundary(void)
|
char *Curl_FormBoundary(void)
|
||||||
{
|
{
|
||||||
char *retstring;
|
char *retstring;
|
||||||
static int randomizer=0; /* this is just so that two boundaries within
|
static int randomizer=0; /* this is just so that two boundaries within
|
||||||
@@ -367,7 +368,7 @@ char *MakeFormBoundary(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Used from http.c */
|
/* Used from http.c */
|
||||||
void FormFree(struct FormData *form)
|
void Curl_FormFree(struct FormData *form)
|
||||||
{
|
{
|
||||||
struct FormData *next;
|
struct FormData *next;
|
||||||
do {
|
do {
|
||||||
@@ -400,8 +401,8 @@ void curl_formfree(struct HttpPost *form)
|
|||||||
} while((form=next)); /* continue */
|
} while((form=next)); /* continue */
|
||||||
}
|
}
|
||||||
|
|
||||||
struct FormData *getFormData(struct HttpPost *post,
|
struct FormData *Curl_getFormData(struct HttpPost *post,
|
||||||
int *sizep)
|
int *sizep)
|
||||||
{
|
{
|
||||||
struct FormData *form = NULL;
|
struct FormData *form = NULL;
|
||||||
struct FormData *firstform;
|
struct FormData *firstform;
|
||||||
@@ -415,7 +416,7 @@ struct FormData *getFormData(struct HttpPost *post,
|
|||||||
if(!post)
|
if(!post)
|
||||||
return NULL; /* no input => no output! */
|
return NULL; /* no input => no output! */
|
||||||
|
|
||||||
boundary = MakeFormBoundary();
|
boundary = Curl_FormBoundary();
|
||||||
|
|
||||||
/* Make the first line of the output */
|
/* Make the first line of the output */
|
||||||
AddFormDataf(&form,
|
AddFormDataf(&form,
|
||||||
@@ -439,7 +440,7 @@ struct FormData *getFormData(struct HttpPost *post,
|
|||||||
/* If used, this is a link to more file names, we must then do
|
/* If used, this is a link to more file names, we must then do
|
||||||
the magic to include several files with the same field name */
|
the magic to include several files with the same field name */
|
||||||
|
|
||||||
fileboundary = MakeFormBoundary();
|
fileboundary = Curl_FormBoundary();
|
||||||
|
|
||||||
size += AddFormDataf(&form,
|
size += AddFormDataf(&form,
|
||||||
"\r\nContent-Type: multipart/mixed,"
|
"\r\nContent-Type: multipart/mixed,"
|
||||||
@@ -535,24 +536,11 @@ struct FormData *getFormData(struct HttpPost *post,
|
|||||||
return firstform;
|
return firstform;
|
||||||
}
|
}
|
||||||
|
|
||||||
int FormInit(struct Form *form, struct FormData *formdata )
|
int Curl_FormInit(struct Form *form, struct FormData *formdata )
|
||||||
{
|
{
|
||||||
if(!formdata)
|
if(!formdata)
|
||||||
return 1; /* error */
|
return 1; /* error */
|
||||||
|
|
||||||
#if 0
|
|
||||||
struct FormData *lastnode=formdata;
|
|
||||||
|
|
||||||
/* find the last node in the list */
|
|
||||||
while(lastnode->next) {
|
|
||||||
lastnode = lastnode->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Now, make sure that we'll send a nice terminating sequence at the end
|
|
||||||
* of the post. We *DONT* add this string to the size of the data since this
|
|
||||||
* is actually AFTER the data. */
|
|
||||||
AddFormDataf(&lastnode, "\r\n\r\n");
|
|
||||||
#endif
|
|
||||||
form->data = formdata;
|
form->data = formdata;
|
||||||
form->sent = 0;
|
form->sent = 0;
|
||||||
|
|
||||||
@@ -560,10 +548,10 @@ int FormInit(struct Form *form, struct FormData *formdata )
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* fread() emulation */
|
/* fread() emulation */
|
||||||
int FormReader(char *buffer,
|
int Curl_FormReader(char *buffer,
|
||||||
size_t size,
|
size_t size,
|
||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *mydata)
|
FILE *mydata)
|
||||||
{
|
{
|
||||||
struct Form *form;
|
struct Form *form;
|
||||||
int wantedsize;
|
int wantedsize;
|
||||||
@@ -638,7 +626,7 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
form=getFormData(httppost, &size);
|
form=Curl_getFormData(httppost, &size);
|
||||||
|
|
||||||
FormInit(&formread, form);
|
FormInit(&formread, form);
|
||||||
|
|
||||||
|
@@ -36,23 +36,19 @@ struct Form {
|
|||||||
been sent in a previous invoke */
|
been sent in a previous invoke */
|
||||||
};
|
};
|
||||||
|
|
||||||
int FormParse(char *string,
|
int Curl_FormInit(struct Form *form, struct FormData *formdata );
|
||||||
struct HttpPost **httppost,
|
|
||||||
struct HttpPost **last_post);
|
|
||||||
|
|
||||||
int FormInit(struct Form *form, struct FormData *formdata );
|
struct FormData *Curl_getFormData(struct HttpPost *post,
|
||||||
|
int *size);
|
||||||
struct FormData *getFormData(struct HttpPost *post,
|
|
||||||
int *size);
|
|
||||||
|
|
||||||
/* fread() emulation */
|
/* fread() emulation */
|
||||||
int FormReader(char *buffer,
|
int Curl_FormReader(char *buffer,
|
||||||
size_t size,
|
size_t size,
|
||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *mydata);
|
FILE *mydata);
|
||||||
|
|
||||||
char *MakeFormBoundary(void);
|
char *Curl_FormBoundary(void);
|
||||||
|
|
||||||
void FormFree(struct FormData *);
|
void Curl_FormFree(struct FormData *);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
15
lib/ftp.h
15
lib/ftp.h
@@ -23,11 +23,16 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
CURLcode ftp(struct connectdata *conn);
|
CURLcode Curl_ftp(struct connectdata *conn);
|
||||||
CURLcode ftp_done(struct connectdata *conn);
|
CURLcode Curl_ftp_done(struct connectdata *conn);
|
||||||
CURLcode ftp_connect(struct connectdata *conn);
|
CURLcode Curl_ftp_connect(struct connectdata *conn);
|
||||||
|
CURLcode Curl_ftp_disconnect(struct connectdata *conn);
|
||||||
|
|
||||||
struct curl_slist *curl_slist_append(struct curl_slist *list, char *data);
|
size_t Curl_ftpsendf(int fd, struct connectdata *, char *fmt, ...);
|
||||||
void curl_slist_free_all(struct curl_slist *list);
|
|
||||||
|
/* The kerberos stuff needs this: */
|
||||||
|
int Curl_GetFTPResponse(int sockfd, char *buf,
|
||||||
|
struct connectdata *conn,
|
||||||
|
int *ftpcode);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -390,7 +390,7 @@ static const short yycheck[] = { 0,
|
|||||||
56
|
56
|
||||||
};
|
};
|
||||||
/* -*-C-*- Note some compilers choke on comments on `#line' lines. */
|
/* -*-C-*- Note some compilers choke on comments on `#line' lines. */
|
||||||
#line 3 "/usr/local/share/bison.simple"
|
#line 3 "/usr/lib/bison.simple"
|
||||||
/* This file comes from bison-1.28. */
|
/* This file comes from bison-1.28. */
|
||||||
|
|
||||||
/* Skeleton output parser for bison,
|
/* Skeleton output parser for bison,
|
||||||
@@ -604,7 +604,7 @@ __yy_memcpy (char *to, char *from, unsigned int count)
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#line 217 "/usr/local/share/bison.simple"
|
#line 217 "/usr/lib/bison.simple"
|
||||||
|
|
||||||
/* The user can define YYPARSE_PARAM as the name of an argument to be passed
|
/* The user can define YYPARSE_PARAM as the name of an argument to be passed
|
||||||
into yyparse. The argument should have type void *.
|
into yyparse. The argument should have type void *.
|
||||||
@@ -1295,7 +1295,7 @@ case 50:
|
|||||||
break;}
|
break;}
|
||||||
}
|
}
|
||||||
/* the action file gets copied in in place of this dollarsign */
|
/* the action file gets copied in in place of this dollarsign */
|
||||||
#line 543 "/usr/local/share/bison.simple"
|
#line 543 "/usr/lib/bison.simple"
|
||||||
|
|
||||||
yyvsp -= yylen;
|
yyvsp -= yylen;
|
||||||
yyssp -= yylen;
|
yyssp -= yylen;
|
||||||
|
@@ -33,6 +33,7 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static
|
||||||
char *GetEnv(char *variable)
|
char *GetEnv(char *variable)
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
@@ -40,12 +41,13 @@ char *GetEnv(char *variable)
|
|||||||
char env[MAX_PATH]; /* MAX_PATH is from windef.h */
|
char env[MAX_PATH]; /* MAX_PATH is from windef.h */
|
||||||
char *temp = getenv(variable);
|
char *temp = getenv(variable);
|
||||||
env[0] = '\0';
|
env[0] = '\0';
|
||||||
ExpandEnvironmentStrings(temp, env, sizeof(env));
|
if (temp != NULL)
|
||||||
|
ExpandEnvironmentStrings(temp, env, sizeof(env));
|
||||||
#else
|
#else
|
||||||
/* no length control */
|
/* no length control */
|
||||||
char *env = getenv(variable);
|
char *env = getenv(variable);
|
||||||
#endif
|
#endif
|
||||||
return env?strdup(env):NULL;
|
return (env && env[0])?strdup(env):NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *curl_getenv(char *v)
|
char *curl_getenv(char *v)
|
||||||
|
29
lib/getenv.h
29
lib/getenv.h
@@ -1,29 +0,0 @@
|
|||||||
#ifndef __GETENV_H
|
|
||||||
#define __GETENV_H
|
|
||||||
/*****************************************************************************
|
|
||||||
* _ _ ____ _
|
|
||||||
* Project ___| | | | _ \| |
|
|
||||||
* / __| | | | |_) | |
|
|
||||||
* | (__| |_| | _ <| |___
|
|
||||||
* \___|\___/|_| \_\_____|
|
|
||||||
*
|
|
||||||
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
||||||
*
|
|
||||||
* In order to be useful for every potential user, curl and libcurl are
|
|
||||||
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
|
||||||
*
|
|
||||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
||||||
* copies of the Software, and permit persons to whom the Software is
|
|
||||||
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
|
||||||
* licenses. You may pick one of these licenses.
|
|
||||||
*
|
|
||||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
||||||
* KIND, either express or implied.
|
|
||||||
*
|
|
||||||
* $Id$
|
|
||||||
*****************************************************************************/
|
|
||||||
|
|
||||||
/* Unix and Win32 getenv function call */
|
|
||||||
char *GetEnv(char *variable);
|
|
||||||
|
|
||||||
#endif
|
|
@@ -31,7 +31,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
CURLcode curl_getinfo(CURL *curl, CURLINFO info, ...)
|
CURLcode Curl_getinfo(CURL *curl, CURLINFO info, ...)
|
||||||
{
|
{
|
||||||
va_list arg;
|
va_list arg;
|
||||||
long *param_longp;
|
long *param_longp;
|
||||||
@@ -103,6 +103,12 @@ CURLcode curl_getinfo(CURL *curl, CURLINFO info, ...)
|
|||||||
case CURLINFO_SSL_VERIFYRESULT:
|
case CURLINFO_SSL_VERIFYRESULT:
|
||||||
*param_longp = data->ssl.certverifyresult;
|
*param_longp = data->ssl.certverifyresult;
|
||||||
break;
|
break;
|
||||||
|
case CURLINFO_CONTENT_LENGTH_DOWNLOAD:
|
||||||
|
*param_doublep = data->progress.size_dl;
|
||||||
|
break;
|
||||||
|
case CURLINFO_CONTENT_LENGTH_UPLOAD:
|
||||||
|
*param_doublep = data->progress.size_ul;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return CURLE_BAD_FUNCTION_ARGUMENT;
|
return CURLE_BAD_FUNCTION_ARGUMENT;
|
||||||
}
|
}
|
||||||
|
@@ -1,8 +1,35 @@
|
|||||||
#ifndef __GETPASS_H
|
#ifndef __GETPASS_H
|
||||||
#define __GETPASS_H
|
#define __GETPASS_H
|
||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
#ifndef HAVE_GETPASS_R
|
||||||
|
/* If there's a system-provided function named like this, we trust it is
|
||||||
|
also found in one of the standard headers. */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Returning NULL will abort the continued operation!
|
* Returning NULL will abort the continued operation!
|
||||||
*/
|
*/
|
||||||
char* getpass_r(char *prompt, char* buffer, size_t buflen );
|
char* getpass_r(char *prompt, char* buffer, size_t buflen );
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
38
lib/hostip.c
38
lib/hostip.c
@@ -62,7 +62,7 @@
|
|||||||
|
|
||||||
/* --- resolve name or IP-number --- */
|
/* --- resolve name or IP-number --- */
|
||||||
|
|
||||||
char *MakeIP(unsigned long num,char *addr, int addr_len)
|
static char *MakeIP(unsigned long num,char *addr, int addr_len)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_INET_NTOA) || defined(HAVE_INET_NTOA_R)
|
#if defined(HAVE_INET_NTOA) || defined(HAVE_INET_NTOA_R)
|
||||||
struct in_addr in;
|
struct in_addr in;
|
||||||
@@ -83,14 +83,40 @@ char *MakeIP(unsigned long num,char *addr, int addr_len)
|
|||||||
return (addr);
|
return (addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The original code to this function was stolen from the Dancer source code,
|
#ifdef ENABLE_IPV6
|
||||||
written by Bjorn Reese, it has since been patched and modified. */
|
struct addrinfo *Curl_getaddrinfo(struct UrlData *data,
|
||||||
|
char *hostname,
|
||||||
|
int port)
|
||||||
|
{
|
||||||
|
struct addrinfo hints, *res;
|
||||||
|
int error;
|
||||||
|
char sbuf[NI_MAXSERV];
|
||||||
|
|
||||||
|
memset(&hints, 0, sizeof(hints));
|
||||||
|
hints.ai_family = PF_UNSPEC;
|
||||||
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
|
hints.ai_flags = AI_CANONNAME;
|
||||||
|
snprintf(sbuf, sizeof(sbuf), "%d", port);
|
||||||
|
error = getaddrinfo(hostname, sbuf, &hints, &res);
|
||||||
|
if (error) {
|
||||||
|
infof(data, "getaddrinfo(3) failed for %s\n", hostname);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The original code to this function was once stolen from the Dancer source
|
||||||
|
code, written by Bjorn Reese, it has since been patched and modified
|
||||||
|
considerably. */
|
||||||
|
|
||||||
#ifndef INADDR_NONE
|
#ifndef INADDR_NONE
|
||||||
#define INADDR_NONE (unsigned long) ~0
|
#define INADDR_NONE (unsigned long) ~0
|
||||||
#endif
|
#endif
|
||||||
struct hostent *GetHost(struct UrlData *data,
|
|
||||||
char *hostname,
|
struct hostent *Curl_gethost(struct UrlData *data,
|
||||||
char **bufp)
|
char *hostname,
|
||||||
|
char **bufp)
|
||||||
{
|
{
|
||||||
struct hostent *h = NULL;
|
struct hostent *h = NULL;
|
||||||
unsigned long in;
|
unsigned long in;
|
||||||
|
@@ -23,6 +23,13 @@
|
|||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
struct hostent *GetHost(struct UrlData *data, char *hostname, char **bufp );
|
struct addrinfo;
|
||||||
|
struct addrinfo *Curl_getaddrinfo(struct UrlData *data,
|
||||||
|
char *hostname,
|
||||||
|
int port);
|
||||||
|
|
||||||
|
struct hostent *Curl_gethost(struct UrlData *data,
|
||||||
|
char *hostname,
|
||||||
|
char **bufp);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
406
lib/http.c
406
lib/http.c
@@ -87,14 +87,13 @@
|
|||||||
|
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "download.h"
|
#include "transfer.h"
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
#include "formdata.h"
|
#include "formdata.h"
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
#include "base64.h"
|
#include "base64.h"
|
||||||
#include "cookie.h"
|
#include "cookie.h"
|
||||||
#include "strequal.h"
|
#include "strequal.h"
|
||||||
#include "url.h"
|
|
||||||
#include "ssluse.h"
|
#include "ssluse.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
@@ -105,6 +104,145 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
/*
|
||||||
|
* The add_buffer series of functions are used to build one large memory chunk
|
||||||
|
* from repeated function invokes. Used so that the entire HTTP request can
|
||||||
|
* be sent in one go.
|
||||||
|
*/
|
||||||
|
static CURLcode
|
||||||
|
add_buffer(send_buffer *in, void *inptr, size_t size);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* add_buffer_init() returns a fine buffer struct
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
send_buffer *add_buffer_init(void)
|
||||||
|
{
|
||||||
|
send_buffer *blonk;
|
||||||
|
blonk=(send_buffer *)malloc(sizeof(send_buffer));
|
||||||
|
if(blonk) {
|
||||||
|
memset(blonk, 0, sizeof(send_buffer));
|
||||||
|
return blonk;
|
||||||
|
}
|
||||||
|
return NULL; /* failed, go home */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* add_buffer_send() sends a buffer and frees all associated memory.
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
size_t add_buffer_send(int sockfd, struct connectdata *conn, send_buffer *in)
|
||||||
|
{
|
||||||
|
size_t amount;
|
||||||
|
if(conn->data->bits.verbose) {
|
||||||
|
fputs("> ", conn->data->err);
|
||||||
|
/* this data _may_ contain binary stuff */
|
||||||
|
fwrite(in->buffer, in->size_used, 1, conn->data->err);
|
||||||
|
}
|
||||||
|
|
||||||
|
Curl_write(conn, sockfd, in->buffer, in->size_used, &amount);
|
||||||
|
|
||||||
|
if(in->buffer)
|
||||||
|
free(in->buffer);
|
||||||
|
free(in);
|
||||||
|
|
||||||
|
return amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* add_bufferf() builds a buffer from the formatted input
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
CURLcode add_bufferf(send_buffer *in, char *fmt, ...)
|
||||||
|
{
|
||||||
|
CURLcode result = CURLE_OUT_OF_MEMORY;
|
||||||
|
char *s;
|
||||||
|
va_list ap;
|
||||||
|
va_start(ap, fmt);
|
||||||
|
s = vaprintf(fmt, ap); /* this allocs a new string to append */
|
||||||
|
va_end(ap);
|
||||||
|
|
||||||
|
if(s) {
|
||||||
|
result = add_buffer(in, s, strlen(s));
|
||||||
|
free(s);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* add_buffer() appends a memory chunk to the existing one
|
||||||
|
*/
|
||||||
|
static
|
||||||
|
CURLcode add_buffer(send_buffer *in, void *inptr, size_t size)
|
||||||
|
{
|
||||||
|
char *new_rb;
|
||||||
|
int new_size;
|
||||||
|
|
||||||
|
if(size > 0) {
|
||||||
|
if(!in->buffer ||
|
||||||
|
((in->size_used + size) > (in->size_max - 1))) {
|
||||||
|
new_size = (in->size_used+size)*2;
|
||||||
|
if(in->buffer)
|
||||||
|
/* we have a buffer, enlarge the existing one */
|
||||||
|
new_rb = (char *)realloc(in->buffer, new_size);
|
||||||
|
else
|
||||||
|
/* create a new buffer */
|
||||||
|
new_rb = (char *)malloc(new_size);
|
||||||
|
|
||||||
|
if(!new_rb)
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
|
in->buffer = new_rb;
|
||||||
|
in->size_max = new_size;
|
||||||
|
}
|
||||||
|
memcpy(&in->buffer[in->size_used], inptr, size);
|
||||||
|
|
||||||
|
in->size_used += size;
|
||||||
|
}
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* end of the add_buffer functions */
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Read everything until a newline.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static
|
||||||
|
int GetLine(int sockfd, char *buf, struct connectdata *conn)
|
||||||
|
{
|
||||||
|
ssize_t nread;
|
||||||
|
int read_rc=1;
|
||||||
|
char *ptr;
|
||||||
|
struct UrlData *data=conn->data;
|
||||||
|
|
||||||
|
ptr=buf;
|
||||||
|
|
||||||
|
/* get us a full line, terminated with a newline */
|
||||||
|
for(nread=0;
|
||||||
|
(nread<BUFSIZE) && read_rc;
|
||||||
|
nread++, ptr++) {
|
||||||
|
if((CURLE_OK != Curl_read(conn, sockfd, ptr, 1, &nread)) ||
|
||||||
|
(nread <= 0) ||
|
||||||
|
(*ptr == '\n'))
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
*ptr=0; /* zero terminate */
|
||||||
|
|
||||||
|
if(data->bits.verbose) {
|
||||||
|
fputs("< ", data->err);
|
||||||
|
fwrite(buf, 1, nread, data->err);
|
||||||
|
fputs("\n", data->err);
|
||||||
|
}
|
||||||
|
return nread>0?nread:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This function checks the linked list of custom HTTP headers for a particular
|
* This function checks the linked list of custom HTTP headers for a particular
|
||||||
* header (prefix).
|
* header (prefix).
|
||||||
@@ -123,32 +261,34 @@ bool static checkheaders(struct UrlData *data, char *thisheader)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* GetHTTPProxyTunnel() requires that we're connected to a HTTP proxy. This
|
* ConnectHTTPProxyTunnel() requires that we're connected to a HTTP proxy. This
|
||||||
* function will issue the necessary commands to get a seamless tunnel through
|
* function will issue the necessary commands to get a seamless tunnel through
|
||||||
* this proxy. After that, the socket can be used just as a normal socket.
|
* this proxy. After that, the socket can be used just as a normal socket.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
CURLcode GetHTTPProxyTunnel(struct UrlData *data, int tunnelsocket,
|
CURLcode Curl_ConnectHTTPProxyTunnel(struct connectdata *conn,
|
||||||
char *hostname, int remote_port)
|
int tunnelsocket,
|
||||||
|
char *hostname, int remote_port)
|
||||||
{
|
{
|
||||||
int httperror=0;
|
int httperror=0;
|
||||||
int subversion=0;
|
int subversion=0;
|
||||||
|
struct UrlData *data=conn->data;
|
||||||
|
|
||||||
infof(data, "Establish HTTP proxy tunnel to %s:%d\n", hostname, remote_port);
|
infof(data, "Establish HTTP proxy tunnel to %s:%d\n", hostname, remote_port);
|
||||||
|
|
||||||
/* OK, now send the connect statment */
|
/* OK, now send the connect request to the proxy */
|
||||||
sendf(tunnelsocket, data,
|
Curl_sendf(tunnelsocket, conn,
|
||||||
"CONNECT %s:%d HTTP/1.0\015\012"
|
"CONNECT %s:%d HTTP/1.0\015\012"
|
||||||
"%s"
|
"%s"
|
||||||
"%s"
|
"%s"
|
||||||
"\r\n",
|
"\r\n",
|
||||||
hostname, remote_port,
|
hostname, remote_port,
|
||||||
(data->bits.proxy_user_passwd)?data->ptr_proxyuserpwd:"",
|
(data->bits.proxy_user_passwd)?conn->allocptr.proxyuserpwd:"",
|
||||||
(data->useragent?data->ptr_uagent:"")
|
(data->useragent?conn->allocptr.uagent:"")
|
||||||
);
|
);
|
||||||
|
|
||||||
/* wait for the proxy to send us a HTTP/1.0 200 OK header */
|
/* wait for the proxy to send us a HTTP/1.0 200 OK header */
|
||||||
while(GetLine(tunnelsocket, data->buffer, data)) {
|
while(GetLine(tunnelsocket, data->buffer, conn)) {
|
||||||
if('\r' == data->buffer[0])
|
if('\r' == data->buffer[0])
|
||||||
break; /* end of headers */
|
break; /* end of headers */
|
||||||
if(2 == sscanf(data->buffer, "HTTP/1.%d %d",
|
if(2 == sscanf(data->buffer, "HTTP/1.%d %d",
|
||||||
@@ -170,7 +310,10 @@ CURLcode GetHTTPProxyTunnel(struct UrlData *data, int tunnelsocket,
|
|||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode http_connect(struct connectdata *conn)
|
/*
|
||||||
|
* HTTP stuff to do at connect-time.
|
||||||
|
*/
|
||||||
|
CURLcode Curl_http_connect(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct UrlData *data;
|
struct UrlData *data;
|
||||||
CURLcode result;
|
CURLcode result;
|
||||||
@@ -186,22 +329,21 @@ CURLcode http_connect(struct connectdata *conn)
|
|||||||
if (conn->protocol & PROT_HTTPS) {
|
if (conn->protocol & PROT_HTTPS) {
|
||||||
if (data->bits.httpproxy) {
|
if (data->bits.httpproxy) {
|
||||||
/* HTTPS through a proxy can only be done with a tunnel */
|
/* HTTPS through a proxy can only be done with a tunnel */
|
||||||
result = GetHTTPProxyTunnel(data, data->firstsocket,
|
result = Curl_ConnectHTTPProxyTunnel(conn, conn->firstsocket,
|
||||||
data->hostname, data->remote_port);
|
conn->hostname, conn->remote_port);
|
||||||
if(CURLE_OK != result)
|
if(CURLE_OK != result)
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* now, perform the SSL initialization for this socket */
|
/* now, perform the SSL initialization for this socket */
|
||||||
if(UrgSSLConnect (data)) {
|
if(Curl_SSLConnect(conn))
|
||||||
return CURLE_SSL_CONNECT_ERROR;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->bits.user_passwd && !data->bits.this_is_a_follow) {
|
if(data->bits.user_passwd && !data->bits.this_is_a_follow) {
|
||||||
/* Authorization: is requested, this is not a followed location, get the
|
/* Authorization: is requested, this is not a followed location, get the
|
||||||
original host name */
|
original host name */
|
||||||
data->auth_host = strdup(data->hostname);
|
data->auth_host = strdup(conn->hostname);
|
||||||
}
|
}
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
@@ -209,26 +351,26 @@ CURLcode http_connect(struct connectdata *conn)
|
|||||||
|
|
||||||
/* called from curl_close() when this struct is about to get wasted, free
|
/* called from curl_close() when this struct is about to get wasted, free
|
||||||
protocol-specific resources */
|
protocol-specific resources */
|
||||||
CURLcode http_close(struct connectdata *conn)
|
CURLcode Curl_http_close(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
if(conn->data->auth_host)
|
if(conn->data->auth_host)
|
||||||
free(conn->data->auth_host);
|
free(conn->data->auth_host);
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode http_done(struct connectdata *conn)
|
CURLcode Curl_http_done(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct UrlData *data;
|
struct UrlData *data;
|
||||||
long *bytecount = &conn->bytecount;
|
long *bytecount = &conn->bytecount;
|
||||||
struct HTTP *http;
|
struct HTTP *http;
|
||||||
|
|
||||||
data=conn->data;
|
data=conn->data;
|
||||||
http=data->proto.http;
|
http=conn->proto.http;
|
||||||
|
|
||||||
if(data->bits.http_formpost) {
|
if(data->bits.http_formpost) {
|
||||||
*bytecount = http->readbytecount + http->writebytecount;
|
*bytecount = http->readbytecount + http->writebytecount;
|
||||||
|
|
||||||
FormFree(http->sendit); /* Now free that whole lot */
|
Curl_FormFree(http->sendit); /* Now free that whole lot */
|
||||||
|
|
||||||
data->fread = http->storefread; /* restore */
|
data->fread = http->storefread; /* restore */
|
||||||
data->in = http->in; /* restore */
|
data->in = http->in; /* restore */
|
||||||
@@ -237,14 +379,11 @@ CURLcode http_done(struct connectdata *conn)
|
|||||||
*bytecount = http->readbytecount + http->writebytecount;
|
*bytecount = http->readbytecount + http->writebytecount;
|
||||||
}
|
}
|
||||||
|
|
||||||
free(http);
|
|
||||||
data->proto.http=NULL; /* it is gone */
|
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
CURLcode http(struct connectdata *conn)
|
CURLcode Curl_http(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct UrlData *data=conn->data;
|
struct UrlData *data=conn->data;
|
||||||
char *buf = data->buffer; /* this is a short cut to the buffer */
|
char *buf = data->buffer; /* this is a short cut to the buffer */
|
||||||
@@ -255,11 +394,20 @@ CURLcode http(struct connectdata *conn)
|
|||||||
char *host = conn->name;
|
char *host = conn->name;
|
||||||
long *bytecount = &conn->bytecount;
|
long *bytecount = &conn->bytecount;
|
||||||
|
|
||||||
http = (struct HTTP *)malloc(sizeof(struct HTTP));
|
if(!conn->proto.http) {
|
||||||
if(!http)
|
/* Only allocate this struct if we don't already have it! */
|
||||||
return CURLE_OUT_OF_MEMORY;
|
|
||||||
memset(http, 0, sizeof(struct HTTP));
|
http = (struct HTTP *)malloc(sizeof(struct HTTP));
|
||||||
data->proto.http = http;
|
if(!http)
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
memset(http, 0, sizeof(struct HTTP));
|
||||||
|
conn->proto.http = http;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
http = conn->proto.http;
|
||||||
|
|
||||||
|
/* We default to persistant connections */
|
||||||
|
conn->bits.close = FALSE;
|
||||||
|
|
||||||
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
|
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
|
||||||
data->bits.upload) {
|
data->bits.upload) {
|
||||||
@@ -270,9 +418,9 @@ CURLcode http(struct connectdata *conn)
|
|||||||
have been used in the proxy connect, but if we have got a header with
|
have been used in the proxy connect, but if we have got a header with
|
||||||
the user-agent string specified, we erase the previously made string
|
the user-agent string specified, we erase the previously made string
|
||||||
here. */
|
here. */
|
||||||
if(checkheaders(data, "User-Agent:") && data->ptr_uagent) {
|
if(checkheaders(data, "User-Agent:") && conn->allocptr.uagent) {
|
||||||
free(data->ptr_uagent);
|
free(conn->allocptr.uagent);
|
||||||
data->ptr_uagent=NULL;
|
conn->allocptr.uagent=NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((data->bits.user_passwd) && !checkheaders(data, "Authorization:")) {
|
if((data->bits.user_passwd) && !checkheaders(data, "Authorization:")) {
|
||||||
@@ -282,31 +430,34 @@ CURLcode http(struct connectdata *conn)
|
|||||||
host due to a location-follow, we do some weirdo checks here */
|
host due to a location-follow, we do some weirdo checks here */
|
||||||
if(!data->bits.this_is_a_follow ||
|
if(!data->bits.this_is_a_follow ||
|
||||||
!data->auth_host ||
|
!data->auth_host ||
|
||||||
strequal(data->auth_host, data->hostname)) {
|
strequal(data->auth_host, conn->hostname)) {
|
||||||
sprintf(data->buffer, "%s:%s", data->user, data->passwd);
|
sprintf(data->buffer, "%s:%s", data->user, data->passwd);
|
||||||
if(base64_encode(data->buffer, strlen(data->buffer),
|
if(Curl_base64_encode(data->buffer, strlen(data->buffer),
|
||||||
&authorization) >= 0) {
|
&authorization) >= 0) {
|
||||||
data->ptr_userpwd = maprintf( "Authorization: Basic %s\015\012",
|
if(conn->allocptr.userpwd)
|
||||||
authorization);
|
free(conn->allocptr.userpwd);
|
||||||
|
conn->allocptr.userpwd = aprintf( "Authorization: Basic %s\015\012",
|
||||||
|
authorization);
|
||||||
free(authorization);
|
free(authorization);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if((data->bits.set_range) && !checkheaders(data, "Range:")) {
|
|
||||||
data->ptr_rangeline = maprintf("Range: bytes=%s\015\012", data->range);
|
|
||||||
}
|
|
||||||
if((data->bits.http_set_referer) && !checkheaders(data, "Referer:")) {
|
if((data->bits.http_set_referer) && !checkheaders(data, "Referer:")) {
|
||||||
data->ptr_ref = maprintf("Referer: %s\015\012", data->referer);
|
if(conn->allocptr.ref)
|
||||||
|
free(conn->allocptr.ref);
|
||||||
|
conn->allocptr.ref = aprintf("Referer: %s\015\012", data->referer);
|
||||||
}
|
}
|
||||||
if(data->cookie && !checkheaders(data, "Cookie:")) {
|
if(data->cookie && !checkheaders(data, "Cookie:")) {
|
||||||
data->ptr_cookie = maprintf("Cookie: %s\015\012", data->cookie);
|
if(conn->allocptr.cookie)
|
||||||
|
free(conn->allocptr.cookie);
|
||||||
|
conn->allocptr.cookie = aprintf("Cookie: %s\015\012", data->cookie);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->cookies) {
|
if(data->cookies) {
|
||||||
co = cookie_getlist(data->cookies,
|
co = Curl_cookie_getlist(data->cookies,
|
||||||
host,
|
host,
|
||||||
ppath,
|
ppath,
|
||||||
conn->protocol&PROT_HTTPS?TRUE:FALSE);
|
conn->protocol&PROT_HTTPS?TRUE:FALSE);
|
||||||
}
|
}
|
||||||
if ((data->bits.httpproxy) && !(conn->protocol&PROT_HTTPS)) {
|
if ((data->bits.httpproxy) && !(conn->protocol&PROT_HTTPS)) {
|
||||||
/* The path sent to the proxy is in fact the entire URL */
|
/* The path sent to the proxy is in fact the entire URL */
|
||||||
@@ -315,17 +466,26 @@ CURLcode http(struct connectdata *conn)
|
|||||||
if(data->bits.http_formpost) {
|
if(data->bits.http_formpost) {
|
||||||
/* we must build the whole darned post sequence first, so that we have
|
/* we must build the whole darned post sequence first, so that we have
|
||||||
a size of the whole shebang before we start to send it */
|
a size of the whole shebang before we start to send it */
|
||||||
http->sendit = getFormData(data->httppost, &http->postsize);
|
http->sendit = Curl_getFormData(data->httppost, &http->postsize);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!checkheaders(data, "Host:")) {
|
if(!checkheaders(data, "Host:")) {
|
||||||
if(((conn->protocol&PROT_HTTPS) && (data->remote_port == PORT_HTTPS)) ||
|
/* if ptr_host is already set, it is almost OK since we only re-use
|
||||||
(!(conn->protocol&PROT_HTTPS) && (data->remote_port == PORT_HTTP)) )
|
connections to the very same host and port, but when we use a HTTP
|
||||||
|
proxy we have a persistant connect and yet we must change the Host:
|
||||||
|
header! */
|
||||||
|
|
||||||
|
if(conn->allocptr.host)
|
||||||
|
free(conn->allocptr.host);
|
||||||
|
|
||||||
|
if(((conn->protocol&PROT_HTTPS) && (conn->remote_port == PORT_HTTPS)) ||
|
||||||
|
(!(conn->protocol&PROT_HTTPS) && (conn->remote_port == PORT_HTTP)) )
|
||||||
/* If (HTTPS on port 443) OR (non-HTTPS on port 80) then don't include
|
/* If (HTTPS on port 443) OR (non-HTTPS on port 80) then don't include
|
||||||
the port number in the host string */
|
the port number in the host string */
|
||||||
data->ptr_host = maprintf("Host: %s\r\n", host);
|
conn->allocptr.host = aprintf("Host: %s\r\n", host);
|
||||||
else
|
else
|
||||||
data->ptr_host = maprintf("Host: %s:%d\r\n", host, data->remote_port);
|
conn->allocptr.host = aprintf("Host: %s:%d\r\n", host,
|
||||||
|
conn->remote_port);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!checkheaders(data, "Pragma:"))
|
if(!checkheaders(data, "Pragma:"))
|
||||||
@@ -334,6 +494,92 @@ CURLcode http(struct connectdata *conn)
|
|||||||
if(!checkheaders(data, "Accept:"))
|
if(!checkheaders(data, "Accept:"))
|
||||||
http->p_accept = "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*\r\n";
|
http->p_accept = "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*\r\n";
|
||||||
|
|
||||||
|
if((data->bits.http_post ||
|
||||||
|
data->bits.http_formpost ||
|
||||||
|
data->bits.http_put) &&
|
||||||
|
data->resume_from) {
|
||||||
|
/**********************************************************************
|
||||||
|
* Resuming upload in HTTP means that we PUT or POST and that we have
|
||||||
|
* got a resume_from value set. The resume value has already created
|
||||||
|
* a Range: header that will be passed along. We need to "fast forward"
|
||||||
|
* the file the given number of bytes and decrease the assume upload
|
||||||
|
* file size before we continue this venture in the dark lands of HTTP.
|
||||||
|
*********************************************************************/
|
||||||
|
|
||||||
|
if(data->resume_from < 0 ) {
|
||||||
|
/*
|
||||||
|
* This is meant to get the size of the present remote-file by itself.
|
||||||
|
* We don't support this now. Bail out!
|
||||||
|
*/
|
||||||
|
data->resume_from = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(data->resume_from) {
|
||||||
|
/* do we still game? */
|
||||||
|
int passed=0;
|
||||||
|
|
||||||
|
/* Now, let's read off the proper amount of bytes from the
|
||||||
|
input. If we knew it was a proper file we could've just
|
||||||
|
fseek()ed but we only have a stream here */
|
||||||
|
do {
|
||||||
|
int readthisamountnow = (data->resume_from - passed);
|
||||||
|
int actuallyread;
|
||||||
|
|
||||||
|
if(readthisamountnow > BUFSIZE)
|
||||||
|
readthisamountnow = BUFSIZE;
|
||||||
|
|
||||||
|
actuallyread =
|
||||||
|
data->fread(data->buffer, 1, readthisamountnow, data->in);
|
||||||
|
|
||||||
|
passed += actuallyread;
|
||||||
|
if(actuallyread != readthisamountnow) {
|
||||||
|
failf(data, "Could only read %d bytes from the input\n",
|
||||||
|
passed);
|
||||||
|
return CURLE_READ_ERROR;
|
||||||
|
}
|
||||||
|
} while(passed != data->resume_from); /* loop until done */
|
||||||
|
|
||||||
|
/* now, decrease the size of the read */
|
||||||
|
if(data->infilesize>0) {
|
||||||
|
data->infilesize -= data->resume_from;
|
||||||
|
|
||||||
|
if(data->infilesize <= 0) {
|
||||||
|
failf(data, "File already completely uploaded\n");
|
||||||
|
return CURLE_PARTIAL_FILE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* we've passed, proceed as normal */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(data->bits.set_range) {
|
||||||
|
/*
|
||||||
|
* A range is selected. We use different headers whether we're downloading
|
||||||
|
* or uploading and we always let customized headers override our internal
|
||||||
|
* ones if any such are specified.
|
||||||
|
*/
|
||||||
|
if((data->httpreq == HTTPREQ_GET) &&
|
||||||
|
!checkheaders(data, "Range:")) {
|
||||||
|
conn->allocptr.rangeline = aprintf("Range: bytes=%s\r\n", data->range);
|
||||||
|
}
|
||||||
|
else if((data->httpreq != HTTPREQ_GET) &&
|
||||||
|
!checkheaders(data, "Content-Range:")) {
|
||||||
|
|
||||||
|
if(data->resume_from) {
|
||||||
|
/* This is because "resume" was selected */
|
||||||
|
long total_expected_size= data->resume_from + data->infilesize;
|
||||||
|
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s%ld/%ld\r\n",
|
||||||
|
data->range, total_expected_size-1,
|
||||||
|
total_expected_size);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* Range was selected and then we just pass the incoming range and
|
||||||
|
append total size */
|
||||||
|
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s/%d\r\n",
|
||||||
|
data->range, data->infilesize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
send_buffer *req_buffer;
|
send_buffer *req_buffer;
|
||||||
struct curl_slist *headers=data->headers;
|
struct curl_slist *headers=data->headers;
|
||||||
@@ -344,7 +590,7 @@ CURLcode http(struct connectdata *conn)
|
|||||||
/* add the main request stuff */
|
/* add the main request stuff */
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"%s " /* GET/HEAD/POST/PUT */
|
"%s " /* GET/HEAD/POST/PUT */
|
||||||
"%s HTTP/1.0\r\n" /* path */
|
"%s HTTP/1.1\r\n" /* path */
|
||||||
"%s" /* proxyuserpwd */
|
"%s" /* proxyuserpwd */
|
||||||
"%s" /* userpwd */
|
"%s" /* userpwd */
|
||||||
"%s" /* range */
|
"%s" /* range */
|
||||||
@@ -360,15 +606,15 @@ CURLcode http(struct connectdata *conn)
|
|||||||
(data->bits.http_post || data->bits.http_formpost)?"POST":
|
(data->bits.http_post || data->bits.http_formpost)?"POST":
|
||||||
(data->bits.http_put)?"PUT":"GET"),
|
(data->bits.http_put)?"PUT":"GET"),
|
||||||
ppath,
|
ppath,
|
||||||
(data->bits.proxy_user_passwd && data->ptr_proxyuserpwd)?data->ptr_proxyuserpwd:"",
|
(data->bits.proxy_user_passwd && conn->allocptr.proxyuserpwd)?conn->allocptr.proxyuserpwd:"",
|
||||||
(data->bits.user_passwd && data->ptr_userpwd)?data->ptr_userpwd:"",
|
(data->bits.user_passwd && conn->allocptr.userpwd)?conn->allocptr.userpwd:"",
|
||||||
(data->bits.set_range && data->ptr_rangeline)?data->ptr_rangeline:"",
|
(data->bits.set_range && conn->allocptr.rangeline)?conn->allocptr.rangeline:"",
|
||||||
(data->useragent && *data->useragent && data->ptr_uagent)?data->ptr_uagent:"",
|
(data->useragent && *data->useragent && conn->allocptr.uagent)?conn->allocptr.uagent:"",
|
||||||
(data->ptr_cookie?data->ptr_cookie:""), /* Cookie: <data> */
|
(conn->allocptr.cookie?conn->allocptr.cookie:""), /* Cookie: <data> */
|
||||||
(data->ptr_host?data->ptr_host:""), /* Host: host */
|
(conn->allocptr.host?conn->allocptr.host:""), /* Host: host */
|
||||||
http->p_pragma?http->p_pragma:"",
|
http->p_pragma?http->p_pragma:"",
|
||||||
http->p_accept?http->p_accept:"",
|
http->p_accept?http->p_accept:"",
|
||||||
(data->bits.http_set_referer && data->ptr_ref)?data->ptr_ref:"" /* Referer: <data> <CRLF> */
|
(data->bits.http_set_referer && conn->allocptr.ref)?conn->allocptr.ref:"" /* Referer: <data> <CRLF> */
|
||||||
);
|
);
|
||||||
|
|
||||||
if(co) {
|
if(co) {
|
||||||
@@ -389,7 +635,7 @@ CURLcode http(struct connectdata *conn)
|
|||||||
if(count) {
|
if(count) {
|
||||||
add_buffer(req_buffer, "\r\n", 2);
|
add_buffer(req_buffer, "\r\n", 2);
|
||||||
}
|
}
|
||||||
cookie_freelist(store); /* free the cookie list */
|
Curl_cookie_freelist(store); /* free the cookie list */
|
||||||
co=NULL;
|
co=NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -451,7 +697,7 @@ CURLcode http(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(data->bits.http_formpost) {
|
if(data->bits.http_formpost) {
|
||||||
if(FormInit(&http->form, http->sendit)) {
|
if(Curl_FormInit(&http->form, http->sendit)) {
|
||||||
failf(data, "Internal HTTP POST error!\n");
|
failf(data, "Internal HTTP POST error!\n");
|
||||||
return CURLE_HTTP_POST_ERROR;
|
return CURLE_HTTP_POST_ERROR;
|
||||||
}
|
}
|
||||||
@@ -461,24 +707,24 @@ CURLcode http(struct connectdata *conn)
|
|||||||
|
|
||||||
data->fread =
|
data->fread =
|
||||||
(size_t (*)(char *, size_t, size_t, FILE *))
|
(size_t (*)(char *, size_t, size_t, FILE *))
|
||||||
FormReader; /* set the read function to read from the
|
Curl_FormReader; /* set the read function to read from the
|
||||||
generated form data */
|
generated form data */
|
||||||
data->in = (FILE *)&http->form;
|
data->in = (FILE *)&http->form;
|
||||||
|
|
||||||
add_bufferf(req_buffer,
|
add_bufferf(req_buffer,
|
||||||
"Content-Length: %d\r\n", http->postsize-2);
|
"Content-Length: %d\r\n", http->postsize-2);
|
||||||
|
|
||||||
/* set upload size to the progress meter */
|
/* set upload size to the progress meter */
|
||||||
pgrsSetUploadSize(data, http->postsize);
|
Curl_pgrsSetUploadSize(data, http->postsize);
|
||||||
|
|
||||||
data->request_size =
|
data->request_size =
|
||||||
add_buffer_send(data->firstsocket, conn, req_buffer);
|
add_buffer_send(conn->firstsocket, conn, req_buffer);
|
||||||
result = Transfer(conn, data->firstsocket, -1, TRUE,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE,
|
||||||
&http->readbytecount,
|
&http->readbytecount,
|
||||||
data->firstsocket,
|
conn->firstsocket,
|
||||||
&http->writebytecount);
|
&http->writebytecount);
|
||||||
if(result) {
|
if(result) {
|
||||||
FormFree(http->sendit); /* free that whole lot */
|
Curl_FormFree(http->sendit); /* free that whole lot */
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -494,16 +740,16 @@ CURLcode http(struct connectdata *conn)
|
|||||||
add_bufferf(req_buffer, "\015\012");
|
add_bufferf(req_buffer, "\015\012");
|
||||||
|
|
||||||
/* set the upload size to the progress meter */
|
/* set the upload size to the progress meter */
|
||||||
pgrsSetUploadSize(data, data->infilesize);
|
Curl_pgrsSetUploadSize(data, data->infilesize);
|
||||||
|
|
||||||
/* this sends the buffer and frees all the buffer resources */
|
/* this sends the buffer and frees all the buffer resources */
|
||||||
data->request_size =
|
data->request_size =
|
||||||
add_buffer_send(data->firstsocket, conn, req_buffer);
|
add_buffer_send(conn->firstsocket, conn, req_buffer);
|
||||||
|
|
||||||
/* prepare for transfer */
|
/* prepare for transfer */
|
||||||
result = Transfer(conn, data->firstsocket, -1, TRUE,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE,
|
||||||
&http->readbytecount,
|
&http->readbytecount,
|
||||||
data->firstsocket,
|
conn->firstsocket,
|
||||||
&http->writebytecount);
|
&http->writebytecount);
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
@@ -544,10 +790,10 @@ CURLcode http(struct connectdata *conn)
|
|||||||
|
|
||||||
/* issue the request */
|
/* issue the request */
|
||||||
data->request_size =
|
data->request_size =
|
||||||
add_buffer_send(data->firstsocket, conn, req_buffer);
|
add_buffer_send(conn->firstsocket, conn, req_buffer);
|
||||||
|
|
||||||
/* HTTP GET/HEAD download: */
|
/* HTTP GET/HEAD download: */
|
||||||
result = Transfer(conn, data->firstsocket, -1, TRUE, bytecount,
|
result = Curl_Transfer(conn, conn->firstsocket, -1, TRUE, bytecount,
|
||||||
-1, NULL); /* nothing to upload */
|
-1, NULL); /* nothing to upload */
|
||||||
}
|
}
|
||||||
if(result)
|
if(result)
|
||||||
|
18
lib/http.h
18
lib/http.h
@@ -25,13 +25,19 @@
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/* ftp can use this as well */
|
/* ftp can use this as well */
|
||||||
CURLcode GetHTTPProxyTunnel(struct UrlData *data, int tunnelsocket,
|
CURLcode Curl_ConnectHTTPProxyTunnel(struct connectdata *conn,
|
||||||
char *hostname, int remote_port);
|
int tunnelsocket,
|
||||||
|
char *hostname, int remote_port);
|
||||||
|
|
||||||
/* protocol-specific functions set up to be called by the main engine */
|
/* protocol-specific functions set up to be called by the main engine */
|
||||||
CURLcode http(struct connectdata *conn);
|
CURLcode Curl_http(struct connectdata *conn);
|
||||||
CURLcode http_done(struct connectdata *conn);
|
CURLcode Curl_http_done(struct connectdata *conn);
|
||||||
CURLcode http_connect(struct connectdata *conn);
|
CURLcode Curl_http_connect(struct connectdata *conn);
|
||||||
CURLcode http_close(struct connectdata *conn);
|
CURLcode Curl_http_close(struct connectdata *conn);
|
||||||
|
|
||||||
|
/* The following functions are defined in http_chunks.c */
|
||||||
|
void Curl_httpchunk_init(struct connectdata *conn);
|
||||||
|
CHUNKcode Curl_httpchunk_read(struct connectdata *conn, char *datap,
|
||||||
|
ssize_t length, ssize_t *wrote);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
222
lib/http_chunks.c
Normal file
222
lib/http_chunks.c
Normal file
@@ -0,0 +1,222 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
|
/* -- WIN32 approved -- */
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
|
||||||
|
#include "urldata.h" /* it includes http_chunks.h */
|
||||||
|
#include "sendf.h" /* for the client write stuff */
|
||||||
|
|
||||||
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
#include "memdebug.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Chunk format (simplified):
|
||||||
|
*
|
||||||
|
* <HEX SIZE>[ chunk extension ] CRLF
|
||||||
|
* <DATA>
|
||||||
|
*
|
||||||
|
* Highlights from RFC2616 section 3.6 say:
|
||||||
|
|
||||||
|
The chunked encoding modifies the body of a message in order to
|
||||||
|
transfer it as a series of chunks, each with its own size indicator,
|
||||||
|
followed by an OPTIONAL trailer containing entity-header fields. This
|
||||||
|
allows dynamically produced content to be transferred along with the
|
||||||
|
information necessary for the recipient to verify that it has
|
||||||
|
received the full message.
|
||||||
|
|
||||||
|
Chunked-Body = *chunk
|
||||||
|
last-chunk
|
||||||
|
trailer
|
||||||
|
CRLF
|
||||||
|
|
||||||
|
chunk = chunk-size [ chunk-extension ] CRLF
|
||||||
|
chunk-data CRLF
|
||||||
|
chunk-size = 1*HEX
|
||||||
|
last-chunk = 1*("0") [ chunk-extension ] CRLF
|
||||||
|
|
||||||
|
chunk-extension= *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
|
||||||
|
chunk-ext-name = token
|
||||||
|
chunk-ext-val = token | quoted-string
|
||||||
|
chunk-data = chunk-size(OCTET)
|
||||||
|
trailer = *(entity-header CRLF)
|
||||||
|
|
||||||
|
The chunk-size field is a string of hex digits indicating the size of
|
||||||
|
the chunk. The chunked encoding is ended by any chunk whose size is
|
||||||
|
zero, followed by the trailer, which is terminated by an empty line.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
void Curl_httpchunk_init(struct connectdata *conn)
|
||||||
|
{
|
||||||
|
struct Curl_chunker *chunk = &conn->proto.http->chunk;
|
||||||
|
chunk->hexindex=0; /* start at 0 */
|
||||||
|
chunk->dataleft=0; /* no data left yet! */
|
||||||
|
chunk->state = CHUNK_HEX; /* we get hex first! */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* chunk_read() returns a OK for normal operations, or a positive return code
|
||||||
|
* for errors. STOP means this sequence of chunks is complete. The 'wrote'
|
||||||
|
* argument is set to tell the caller how many bytes we actually passed to the
|
||||||
|
* client (for byte-counting and whatever).
|
||||||
|
*
|
||||||
|
* The states and the state-machine is further explained in the header file.
|
||||||
|
*/
|
||||||
|
CHUNKcode Curl_httpchunk_read(struct connectdata *conn,
|
||||||
|
char *datap,
|
||||||
|
ssize_t length,
|
||||||
|
ssize_t *wrote)
|
||||||
|
{
|
||||||
|
CURLcode result;
|
||||||
|
struct Curl_chunker *ch = &conn->proto.http->chunk;
|
||||||
|
int piece;
|
||||||
|
*wrote = 0; /* nothing yet */
|
||||||
|
|
||||||
|
while(length) {
|
||||||
|
switch(ch->state) {
|
||||||
|
case CHUNK_HEX:
|
||||||
|
if(isxdigit((int)*datap)) {
|
||||||
|
if(ch->hexindex < MAXNUM_SIZE) {
|
||||||
|
ch->hexbuffer[ch->hexindex] = *datap;
|
||||||
|
datap++;
|
||||||
|
length--;
|
||||||
|
ch->hexindex++;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return CHUNKE_TOO_LONG_HEX; /* longer hex than we support */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(0 == ch->hexindex) {
|
||||||
|
/* This is illegal data, we received junk where we expected
|
||||||
|
a hexadecimal digit. */
|
||||||
|
return CHUNKE_ILLEGAL_HEX;
|
||||||
|
}
|
||||||
|
/* length and datap are unmodified */
|
||||||
|
ch->hexbuffer[ch->hexindex]=0;
|
||||||
|
ch->datasize=strtoul(ch->hexbuffer, NULL, 16);
|
||||||
|
ch->state = CHUNK_POSTHEX;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CHUNK_POSTHEX:
|
||||||
|
/* In this state, we're waiting for CRLF to arrive. We support
|
||||||
|
this to allow so called chunk-extensions to show up here
|
||||||
|
before the CRLF comes. */
|
||||||
|
if(*datap == '\r')
|
||||||
|
ch->state = CHUNK_CR;
|
||||||
|
length--;
|
||||||
|
datap++;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CHUNK_CR:
|
||||||
|
/* waiting for the LF */
|
||||||
|
if(*datap == '\n') {
|
||||||
|
/* we're now expecting data to come, unless size was zero! */
|
||||||
|
if(0 == ch->datasize) {
|
||||||
|
ch->state = CHUNK_STOP; /* stop reading! */
|
||||||
|
if(1 == length) {
|
||||||
|
/* This was the final byte, return right now */
|
||||||
|
return CHUNKE_STOP;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ch->state = CHUNK_DATA;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
/* previously we got a fake CR, go back to CR waiting! */
|
||||||
|
ch->state = CHUNK_CR;
|
||||||
|
datap++;
|
||||||
|
length--;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CHUNK_DATA:
|
||||||
|
/* we get pure and fine data
|
||||||
|
|
||||||
|
We expect another 'datasize' of data. We have 'length' right now,
|
||||||
|
it can be more or less than 'datasize'. Get the smallest piece.
|
||||||
|
*/
|
||||||
|
piece = (ch->datasize >= length)?length:ch->datasize;
|
||||||
|
|
||||||
|
/* Write the data portion available */
|
||||||
|
result = Curl_client_write(conn->data, CLIENTWRITE_BODY, datap, piece);
|
||||||
|
if(result)
|
||||||
|
return CHUNKE_WRITE_ERROR;
|
||||||
|
*wrote += piece;
|
||||||
|
|
||||||
|
ch->datasize -= piece; /* decrease amount left to expect */
|
||||||
|
datap += piece; /* move read pointer forward */
|
||||||
|
length -= piece; /* decrease space left in this round */
|
||||||
|
|
||||||
|
if(0 == ch->datasize)
|
||||||
|
/* end of data this round, we now expect a trailing CRLF */
|
||||||
|
ch->state = CHUNK_POSTCR;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CHUNK_POSTCR:
|
||||||
|
if(*datap == '\r') {
|
||||||
|
ch->state = CHUNK_POSTLF;
|
||||||
|
datap++;
|
||||||
|
length--;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return CHUNKE_BAD_CHUNK;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CHUNK_POSTLF:
|
||||||
|
if(*datap == '\n') {
|
||||||
|
/*
|
||||||
|
* The last one before we go back to hex state and start all
|
||||||
|
* over.
|
||||||
|
*/
|
||||||
|
Curl_httpchunk_init(conn);
|
||||||
|
datap++;
|
||||||
|
length--;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return CHUNKE_BAD_CHUNK;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CHUNK_STOP:
|
||||||
|
/* If we arrive here, there is data left in the end of the buffer
|
||||||
|
even if there's no more chunks to read */
|
||||||
|
ch->dataleft = length;
|
||||||
|
return CHUNKE_STOP; /* return stop */
|
||||||
|
default:
|
||||||
|
return CHUNKE_STATE_ERROR;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return CHUNKE_OK;
|
||||||
|
}
|
87
lib/http_chunks.h
Normal file
87
lib/http_chunks.h
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
#ifndef __HTTP_CHUNKS_H
|
||||||
|
#define __HTTP_CHUNKS_H
|
||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* The longest possible hexadecimal number we support in a chunked transfer.
|
||||||
|
* Weird enough, RFC2616 doesn't set a maximum size! Since we use strtoul()
|
||||||
|
* to convert it, we "only" support 2^32 bytes chunk data.
|
||||||
|
*/
|
||||||
|
#define MAXNUM_SIZE 16
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CHUNK_FIRST, /* never use */
|
||||||
|
|
||||||
|
/* In this we await and buffer all hexadecimal digits until we get one
|
||||||
|
that isn't a hexadecimal digit. When done, we go POSTHEX */
|
||||||
|
CHUNK_HEX,
|
||||||
|
|
||||||
|
/* We have received the hexadecimal digit and we eat all characters until
|
||||||
|
we get a CRLF pair. When we see a CR we go to the CR state. */
|
||||||
|
CHUNK_POSTHEX,
|
||||||
|
|
||||||
|
/* A single CR has been found and we should get a LF right away in this
|
||||||
|
state or we go back to POSTHEX. When LF is received, we go to DATA.
|
||||||
|
If the size given was zero, we set state to STOP and return. */
|
||||||
|
CHUNK_CR,
|
||||||
|
|
||||||
|
/* We eat the amount of data specified. When done, we move on to the
|
||||||
|
POST_CR state. */
|
||||||
|
CHUNK_DATA,
|
||||||
|
|
||||||
|
/* POSTCR should get a CR and nothing else, then move to POSTLF */
|
||||||
|
CHUNK_POSTCR,
|
||||||
|
|
||||||
|
/* POSTLF should get a LF and nothing else, then move back to HEX as
|
||||||
|
the CRLF combination marks the end of a chunk */
|
||||||
|
CHUNK_POSTLF,
|
||||||
|
|
||||||
|
/* This is mainly used to really mark that we're out of the game.
|
||||||
|
NOTE: that there's a 'dataleft' field in the struct that will tell how
|
||||||
|
many bytes that were not passed to the client in the end of the last
|
||||||
|
buffer! */
|
||||||
|
CHUNK_STOP,
|
||||||
|
|
||||||
|
CHUNK_LAST /* never use */
|
||||||
|
} ChunkyState;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CHUNKE_STOP = -1,
|
||||||
|
CHUNKE_OK = 0,
|
||||||
|
CHUNKE_TOO_LONG_HEX = 1,
|
||||||
|
CHUNKE_ILLEGAL_HEX,
|
||||||
|
CHUNKE_BAD_CHUNK,
|
||||||
|
CHUNKE_WRITE_ERROR,
|
||||||
|
CHUNKE_STATE_ERROR,
|
||||||
|
CHUNKE_LAST
|
||||||
|
} CHUNKcode;
|
||||||
|
|
||||||
|
struct Curl_chunker {
|
||||||
|
char hexbuffer[ MAXNUM_SIZE + 1];
|
||||||
|
int hexindex;
|
||||||
|
ChunkyState state;
|
||||||
|
size_t datasize;
|
||||||
|
size_t dataleft; /* untouched data amount at the end of the last buffer */
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
@@ -32,7 +32,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if ! defined(WIN32) && ! defined(__BEOS__)
|
#if ! defined(WIN32) && ! defined(__BEOS__) && !defined(__CYGWIN32__)
|
||||||
|
|
||||||
#ifdef NEED_REENTRANT
|
#ifdef NEED_REENTRANT
|
||||||
#define _REENTRANT
|
#define _REENTRANT
|
||||||
@@ -72,7 +72,7 @@
|
|||||||
|
|
||||||
#define SYS_ERROR -1
|
#define SYS_ERROR -1
|
||||||
|
|
||||||
char *if2ip(char *interface, char *buf, int buf_size)
|
char *Curl_if2ip(char *interface, char *buf, int buf_size)
|
||||||
{
|
{
|
||||||
int dummy;
|
int dummy;
|
||||||
char *ip=NULL;
|
char *ip=NULL;
|
||||||
|
@@ -24,10 +24,10 @@
|
|||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
|
|
||||||
#if ! defined(WIN32) && ! defined(__BEOS__)
|
#if ! defined(WIN32) && ! defined(__BEOS__) && !defined(__CYGWIN32__)
|
||||||
extern char *if2ip(char *interface, char *buf, int buf_size);
|
extern char *Curl_if2ip(char *interface, char *buf, int buf_size);
|
||||||
#else
|
#else
|
||||||
#define if2ip(a,b,c) NULL
|
#define Curl_if2ip(a,b,c) NULL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
43
lib/krb4.c
43
lib/krb4.c
@@ -47,6 +47,9 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <krb.h>
|
#include <krb.h>
|
||||||
|
|
||||||
|
#include "ftp.h"
|
||||||
|
#include "sendf.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
@@ -95,7 +98,8 @@ strlcpy (char *dst, const char *src, size_t dst_sz)
|
|||||||
else
|
else
|
||||||
return n + strlen (src);
|
return n + strlen (src);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
size_t strlcpy (char *dst, const char *src, size_t dst_sz);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@@ -279,12 +283,15 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
u_int32_t cs;
|
u_int32_t cs;
|
||||||
struct krb4_data *d = app_data;
|
struct krb4_data *d = app_data;
|
||||||
struct sockaddr_in *localaddr = (struct sockaddr_in *)LOCAL_ADDR;
|
struct sockaddr_in *localaddr = (struct sockaddr_in *)LOCAL_ADDR;
|
||||||
|
#if 0
|
||||||
struct sockaddr_in *remoteaddr = (struct sockaddr_in *)REMOTE_ADDR;
|
struct sockaddr_in *remoteaddr = (struct sockaddr_in *)REMOTE_ADDR;
|
||||||
|
#endif
|
||||||
char *host = conn->hp->h_name;
|
char *host = conn->hp->h_name;
|
||||||
size_t nread;
|
size_t nread;
|
||||||
int l = sizeof(local_addr);
|
int l = sizeof(local_addr);
|
||||||
|
|
||||||
if(getsockname(conn->data->firstsocket, LOCAL_ADDR, &l) < 0)
|
if(getsockname(conn->firstsocket,
|
||||||
|
(struct sockaddr *)LOCAL_ADDR, &l) < 0)
|
||||||
perror("getsockname()");
|
perror("getsockname()");
|
||||||
|
|
||||||
checksum = getpid();
|
checksum = getpid();
|
||||||
@@ -308,7 +315,7 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
else {
|
else {
|
||||||
if (natAddr.s_addr != localaddr->sin_addr.s_addr) {
|
if (natAddr.s_addr != localaddr->sin_addr.s_addr) {
|
||||||
printf("Using NAT IP address (%s) for kerberos 4\n",
|
printf("Using NAT IP address (%s) for kerberos 4\n",
|
||||||
inet_ntoa(natAddr));
|
(char *)inet_ntoa(natAddr));
|
||||||
localaddr->sin_addr = natAddr;
|
localaddr->sin_addr = natAddr;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -327,15 +334,15 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
/*printf("Local address is %s\n", inet_ntoa(localaddr->sin_addr));***/
|
/*printf("Local address is %s\n", inet_ntoa(localaddr->sin_addr));***/
|
||||||
/*printf("Remote address is %s\n", inet_ntoa(remoteaddr->sin_addr));***/
|
/*printf("Remote address is %s\n", inet_ntoa(remoteaddr->sin_addr));***/
|
||||||
|
|
||||||
if(base64_encode(adat.dat, adat.length, &p) < 0) {
|
if(Curl_base64_encode(adat.dat, adat.length, &p) < 0) {
|
||||||
printf("Out of memory base64-encoding.\n");
|
printf("Out of memory base64-encoding.\n");
|
||||||
return AUTH_CONTINUE;
|
return AUTH_CONTINUE;
|
||||||
}
|
}
|
||||||
/*ret = command("ADAT %s", p)*/
|
/*ret = command("ADAT %s", p)*/
|
||||||
ftpsendf(conn->data->firstsocket, conn, "ADAT %s", p);
|
Curl_ftpsendf(conn->firstsocket, conn, "ADAT %s", p);
|
||||||
/* wait for feedback */
|
/* wait for feedback */
|
||||||
nread = GetLastResponse(conn->data->firstsocket,
|
nread = Curl_GetFTPResponse(conn->firstsocket,
|
||||||
conn->data->buffer, conn);
|
conn->data->buffer, conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
||||||
free(p);
|
free(p);
|
||||||
@@ -351,7 +358,7 @@ krb4_auth(void *app_data, struct connectdata *conn)
|
|||||||
return AUTH_ERROR;
|
return AUTH_ERROR;
|
||||||
}
|
}
|
||||||
p += 5;
|
p += 5;
|
||||||
len = base64_decode(p, adat.dat);
|
len = Curl_base64_decode(p, adat.dat);
|
||||||
if(len < 0){
|
if(len < 0){
|
||||||
printf("Failed to decode base64 from server.\n");
|
printf("Failed to decode base64 from server.\n");
|
||||||
return AUTH_ERROR;
|
return AUTH_ERROR;
|
||||||
@@ -389,14 +396,11 @@ struct sec_client_mech krb4_client_mech = {
|
|||||||
|
|
||||||
void krb_kauth(struct connectdata *conn)
|
void krb_kauth(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
char buf[1024];
|
|
||||||
des_cblock key;
|
des_cblock key;
|
||||||
des_key_schedule schedule;
|
des_key_schedule schedule;
|
||||||
KTEXT_ST tkt, tktcopy;
|
KTEXT_ST tkt, tktcopy;
|
||||||
char *name;
|
char *name;
|
||||||
char *p;
|
char *p;
|
||||||
int overbose;
|
|
||||||
char passwd[100];
|
char passwd[100];
|
||||||
int tmp;
|
int tmp;
|
||||||
size_t nread;
|
size_t nread;
|
||||||
@@ -405,20 +409,19 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
|
|
||||||
save = set_command_prot(conn, prot_private);
|
save = set_command_prot(conn, prot_private);
|
||||||
/*ret = command("SITE KAUTH %s", name);***/
|
/*ret = command("SITE KAUTH %s", name);***/
|
||||||
ftpsendf(conn->data->firstsocket, conn,
|
Curl_ftpsendf(conn->firstsocket, conn,
|
||||||
"SITE KAUTH %s", conn->data->user);
|
"SITE KAUTH %s", conn->data->user);
|
||||||
/* wait for feedback */
|
/* wait for feedback */
|
||||||
nread = GetLastResponse(conn->data->firstsocket, conn->data->buffer, conn);
|
nread = Curl_GetFTPResponse(conn->firstsocket, conn->data->buffer,
|
||||||
|
conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/;
|
return /*CURLE_OPERATION_TIMEOUTED*/;
|
||||||
|
|
||||||
if(/*ret != CONTINUE*/conn->data->buffer[0] != '3'){
|
if(/*ret != CONTINUE*/conn->data->buffer[0] != '3'){
|
||||||
/*verbose = overbose;***/
|
|
||||||
set_command_prot(conn, save);
|
set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
/*code = -1;***/
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/*verbose = overbose;***/
|
|
||||||
p = strstr(/*reply_string***/conn->data->buffer, "T=");
|
p = strstr(/*reply_string***/conn->data->buffer, "T=");
|
||||||
if(!p){
|
if(!p){
|
||||||
printf("Bad reply from server.\n");
|
printf("Bad reply from server.\n");
|
||||||
@@ -427,7 +430,7 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
p += 2;
|
p += 2;
|
||||||
tmp = base64_decode(p, &tkt.dat);
|
tmp = Curl_base64_decode(p, &tkt.dat);
|
||||||
if(tmp < 0){
|
if(tmp < 0){
|
||||||
printf("Failed to decode base64 in reply.\n");
|
printf("Failed to decode base64 in reply.\n");
|
||||||
set_command_prot(conn, save);
|
set_command_prot(conn, save);
|
||||||
@@ -440,7 +443,6 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
p = strstr(/*reply_string***/conn->data->buffer, "P=");
|
p = strstr(/*reply_string***/conn->data->buffer, "P=");
|
||||||
if(!p){
|
if(!p){
|
||||||
printf("Bad reply from server.\n");
|
printf("Bad reply from server.\n");
|
||||||
/*verbose = overbose;***/
|
|
||||||
set_command_prot(conn, save);
|
set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
/*code = -1;***/
|
||||||
return;
|
return;
|
||||||
@@ -476,7 +478,7 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
memset(key, 0, sizeof(key));
|
memset(key, 0, sizeof(key));
|
||||||
memset(schedule, 0, sizeof(schedule));
|
memset(schedule, 0, sizeof(schedule));
|
||||||
memset(passwd, 0, sizeof(passwd));
|
memset(passwd, 0, sizeof(passwd));
|
||||||
if(base64_encode(tktcopy.dat, tktcopy.length, &p) < 0) {
|
if(Curl_base64_encode(tktcopy.dat, tktcopy.length, &p) < 0) {
|
||||||
failf(conn->data, "Out of memory base64-encoding.\n");
|
failf(conn->data, "Out of memory base64-encoding.\n");
|
||||||
set_command_prot(conn, save);
|
set_command_prot(conn, save);
|
||||||
/*code = -1;***/
|
/*code = -1;***/
|
||||||
@@ -484,10 +486,11 @@ void krb_kauth(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
memset (tktcopy.dat, 0, tktcopy.length);
|
memset (tktcopy.dat, 0, tktcopy.length);
|
||||||
/*ret = command("SITE KAUTH %s %s", name, p);***/
|
/*ret = command("SITE KAUTH %s %s", name, p);***/
|
||||||
ftpsendf(conn->data->firstsocket, conn,
|
Curl_ftpsendf(conn->firstsocket, conn,
|
||||||
"SITE KAUTH %s %s", name, p);
|
"SITE KAUTH %s %s", name, p);
|
||||||
/* wait for feedback */
|
/* wait for feedback */
|
||||||
nread = GetLastResponse(conn->data->firstsocket, conn->data->buffer, conn);
|
nread = Curl_GetFTPResponse(conn->firstsocket, conn->data->buffer,
|
||||||
|
conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/;
|
return /*CURLE_OPERATION_TIMEOUTED*/;
|
||||||
free(p);
|
free(p);
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#ifndef __HIGHLEVEL_H
|
#ifndef __KRB4_H
|
||||||
#define __HIGHLEVEL_H
|
#define __KRB4_H
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -22,5 +22,6 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
CURLcode curl_transfer(CURL *curl);
|
void krb_kauth(struct connectdata *conn);
|
||||||
|
|
||||||
#endif
|
#endif
|
10
lib/ldap.c
10
lib/ldap.c
@@ -117,18 +117,18 @@ static void * DynaGetFunction(char *name)
|
|||||||
static int WriteProc(void *param, char *text, int len)
|
static int WriteProc(void *param, char *text, int len)
|
||||||
{
|
{
|
||||||
struct UrlData *data = (struct UrlData *)param;
|
struct UrlData *data = (struct UrlData *)param;
|
||||||
client_write(data, CLIENTWRITE_BODY, text, 0);
|
Curl_client_write(data, CLIENTWRITE_BODY, text, 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode ldap_done(struct connectdata *conn)
|
CURLcode Curl_ldap_done(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/***********************************************************************
|
/***********************************************************************
|
||||||
*/
|
*/
|
||||||
CURLcode ldap(struct connectdata *conn)
|
CURLcode Curl_ldap(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
CURLcode status = CURLE_OK;
|
CURLcode status = CURLE_OK;
|
||||||
int rc;
|
int rc;
|
||||||
@@ -171,10 +171,10 @@ CURLcode ldap(struct connectdata *conn)
|
|||||||
DYNA_GET_FUNCTION(int (*)(void *, char *, void *, void *, char **, char **, int (*)(void *, char *, int), void *, char *, int, unsigned long), ldap_entry2text);
|
DYNA_GET_FUNCTION(int (*)(void *, char *, void *, void *, char **, char **, int (*)(void *, char *, int), void *, char *, int, unsigned long), ldap_entry2text);
|
||||||
DYNA_GET_FUNCTION(int (*)(void *, char *, void *, void *, char **, char **, int (*)(void *, char *, int), void *, char *, int, unsigned long, char *, char *), ldap_entry2html);
|
DYNA_GET_FUNCTION(int (*)(void *, char *, void *, void *, char **, char **, int (*)(void *, char *, int), void *, char *, int, unsigned long, char *, char *), ldap_entry2html);
|
||||||
|
|
||||||
server = ldap_open(data->hostname, data->port);
|
server = ldap_open(conn->hostname, conn->port);
|
||||||
if (server == NULL) {
|
if (server == NULL) {
|
||||||
failf(data, "LDAP: Cannot connect to %s:%d",
|
failf(data, "LDAP: Cannot connect to %s:%d",
|
||||||
data->hostname, data->port);
|
conn->hostname, conn->port);
|
||||||
status = CURLE_COULDNT_CONNECT;
|
status = CURLE_COULDNT_CONNECT;
|
||||||
} else {
|
} else {
|
||||||
rc = ldap_simple_bind_s(server, data->user, data->passwd);
|
rc = ldap_simple_bind_s(server, data->user, data->passwd);
|
||||||
|
@@ -23,7 +23,7 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
CURLcode ldap(struct connectdata *conn);
|
CURLcode Curl_ldap(struct connectdata *conn);
|
||||||
CURLcode ldap_done(struct connectdata *conn);
|
CURLcode Curl_ldap_done(struct connectdata *conn);
|
||||||
|
|
||||||
#endif /* __LDAP_H */
|
#endif /* __LDAP_H */
|
||||||
|
@@ -7,36 +7,25 @@ LIBRARY LIBCURL
|
|||||||
DESCRIPTION 'curl libcurl - http://curl.haxx.se'
|
DESCRIPTION 'curl libcurl - http://curl.haxx.se'
|
||||||
|
|
||||||
EXPORTS
|
EXPORTS
|
||||||
curl_close @ 1 ;
|
curl_easy_cleanup @ 1 ;
|
||||||
curl_connect @ 2 ;
|
curl_easy_getinfo @ 2 ;
|
||||||
curl_disconnect @ 3 ;
|
curl_easy_init @ 3 ;
|
||||||
curl_do @ 4 ;
|
curl_easy_perform @ 4 ;
|
||||||
curl_done @ 5 ;
|
curl_easy_setopt @ 5 ;
|
||||||
curl_easy_cleanup @ 6 ;
|
curl_escape @ 6 ;
|
||||||
curl_easy_getinfo @ 7 ;
|
curl_formparse @ 7 ;
|
||||||
curl_easy_init @ 8 ;
|
curl_formfree @ 8 ;
|
||||||
curl_easy_perform @ 9 ;
|
curl_getdate @ 9 ;
|
||||||
curl_easy_setopt @ 10 ;
|
curl_getenv @ 10 ;
|
||||||
curl_escape @ 11 ;
|
curl_slist_append @ 11 ;
|
||||||
curl_formparse @ 12 ;
|
curl_slist_free_all @ 12 ;
|
||||||
curl_free @ 13 ;
|
curl_unescape @ 13 ;
|
||||||
curl_getdate @ 14 ;
|
curl_version @ 14 ;
|
||||||
curl_getenv @ 15 ;
|
curl_maprintf @ 15 ;
|
||||||
curl_init @ 16 ;
|
curl_mfprintf @ 16 ;
|
||||||
curl_open @ 17 ;
|
curl_mprintf @ 17 ;
|
||||||
curl_read @ 18 ;
|
curl_msprintf @ 18 ;
|
||||||
curl_setopt @ 19 ;
|
curl_msnprintf @ 19 ;
|
||||||
curl_slist_append @ 20 ;
|
curl_mvfprintf @ 20 ;
|
||||||
curl_slist_free_all @ 21 ;
|
curl_strequal @ 21 ;
|
||||||
curl_transfer @ 22 ;
|
curl_strnequal @ 22 ;
|
||||||
curl_unescape @ 23 ;
|
|
||||||
curl_version @ 24 ;
|
|
||||||
curl_write @ 25 ;
|
|
||||||
maprintf @ 26 ;
|
|
||||||
mfprintf @ 27 ;
|
|
||||||
mprintf @ 28 ;
|
|
||||||
msprintf @ 29 ;
|
|
||||||
msnprintf @ 30 ;
|
|
||||||
mvfprintf @ 31 ;
|
|
||||||
strequal @ 32 ;
|
|
||||||
strnequal @ 33 ;
|
|
||||||
|
@@ -72,7 +72,7 @@ void *curl_domalloc(size_t size, int line, char *source)
|
|||||||
return mem;
|
return mem;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *curl_dostrdup(char *str, int line, char *source)
|
char *curl_dostrdup(const char *str, int line, char *source)
|
||||||
{
|
{
|
||||||
char *mem;
|
char *mem;
|
||||||
size_t len;
|
size_t len;
|
||||||
@@ -120,7 +120,7 @@ int curl_socket(int domain, int type, int protocol, int line, char *source)
|
|||||||
return sockfd;
|
return sockfd;
|
||||||
}
|
}
|
||||||
|
|
||||||
int curl_accept(int s, struct sockaddr *addr, int *addrlen,
|
int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
||||||
int line, char *source)
|
int line, char *source)
|
||||||
{
|
{
|
||||||
int sockfd=(accept)(s, addr, addrlen);
|
int sockfd=(accept)(s, addr, addrlen);
|
||||||
@@ -135,7 +135,7 @@ int curl_sclose(int sockfd, int line, char *source)
|
|||||||
int res=sclose(sockfd);
|
int res=sclose(sockfd);
|
||||||
fprintf(logfile?logfile:stderr, "FD %s:%d sclose(%d)\n",
|
fprintf(logfile?logfile:stderr, "FD %s:%d sclose(%d)\n",
|
||||||
source, line, sockfd);
|
source, line, sockfd);
|
||||||
return sockfd;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
FILE *curl_fopen(char *file, char *mode, int line, char *source)
|
FILE *curl_fopen(char *file, char *mode, int line, char *source)
|
||||||
|
@@ -7,13 +7,13 @@
|
|||||||
void *curl_domalloc(size_t size, int line, char *source);
|
void *curl_domalloc(size_t size, int line, char *source);
|
||||||
void *curl_dorealloc(void *ptr, size_t size, int line, char *source);
|
void *curl_dorealloc(void *ptr, size_t size, int line, char *source);
|
||||||
void curl_dofree(void *ptr, int line, char *source);
|
void curl_dofree(void *ptr, int line, char *source);
|
||||||
char *curl_dostrdup(char *str, int line, char *source);
|
char *curl_dostrdup(const char *str, int line, char *source);
|
||||||
void curl_memdebug(char *logname);
|
void curl_memdebug(char *logname);
|
||||||
|
|
||||||
/* file descriptor manipulators */
|
/* file descriptor manipulators */
|
||||||
int curl_socket(int domain, int type, int protocol, int, char *);
|
int curl_socket(int domain, int type, int protocol, int, char *);
|
||||||
int curl_sclose(int sockfd, int, char *);
|
int curl_sclose(int sockfd, int, char *);
|
||||||
int curl_accept(int s, struct sockaddr *addr, int *addrlen,
|
int curl_accept(int s, struct sockaddr *addr, socklen_t *addrlen,
|
||||||
int line, char *source);
|
int line, char *source);
|
||||||
|
|
||||||
/* FILE functions */
|
/* FILE functions */
|
||||||
|
@@ -207,7 +207,7 @@ struct asprintf {
|
|||||||
size_t alloc; /* length of alloc */
|
size_t alloc; /* length of alloc */
|
||||||
};
|
};
|
||||||
|
|
||||||
int msprintf(char *buffer, const char *format, ...);
|
int curl_msprintf(char *buffer, const char *format, ...);
|
||||||
|
|
||||||
static int dprintf_DollarString(char *input, char **end)
|
static int dprintf_DollarString(char *input, char **end)
|
||||||
{
|
{
|
||||||
@@ -955,11 +955,11 @@ static int dprintf_formatf(
|
|||||||
|
|
||||||
if(width >= 0) {
|
if(width >= 0) {
|
||||||
/* RECURSIVE USAGE */
|
/* RECURSIVE USAGE */
|
||||||
fptr += msprintf(fptr, "%d", width);
|
fptr += curl_msprintf(fptr, "%d", width);
|
||||||
}
|
}
|
||||||
if(prec >= 0) {
|
if(prec >= 0) {
|
||||||
/* RECURSIVE USAGE */
|
/* RECURSIVE USAGE */
|
||||||
fptr += msprintf(fptr, ".%d", prec);
|
fptr += curl_msprintf(fptr, ".%d", prec);
|
||||||
}
|
}
|
||||||
if (p->flags & FLAGS_LONG)
|
if (p->flags & FLAGS_LONG)
|
||||||
strcat(fptr, "l");
|
strcat(fptr, "l");
|
||||||
@@ -1025,7 +1025,7 @@ static int addbyter(int output, FILE *data)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int msnprintf(char *buffer, size_t maxlength, const char *format, ...)
|
int curl_msnprintf(char *buffer, size_t maxlength, const char *format, ...)
|
||||||
{
|
{
|
||||||
va_list ap_save; /* argument pointer */
|
va_list ap_save; /* argument pointer */
|
||||||
int retcode;
|
int retcode;
|
||||||
@@ -1045,7 +1045,7 @@ int msnprintf(char *buffer, size_t maxlength, const char *format, ...)
|
|||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list ap_save)
|
int curl_mvsnprintf(char *buffer, size_t maxlength, const char *format, va_list ap_save)
|
||||||
{
|
{
|
||||||
int retcode;
|
int retcode;
|
||||||
struct nsprintf info;
|
struct nsprintf info;
|
||||||
@@ -1092,7 +1092,7 @@ static int alloc_addbyter(int output, FILE *data)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
char *maprintf(const char *format, ...)
|
char *curl_maprintf(const char *format, ...)
|
||||||
{
|
{
|
||||||
va_list ap_save; /* argument pointer */
|
va_list ap_save; /* argument pointer */
|
||||||
int retcode;
|
int retcode;
|
||||||
@@ -1113,7 +1113,7 @@ char *maprintf(const char *format, ...)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *mvaprintf(const char *format, va_list ap_save)
|
char *curl_mvaprintf(const char *format, va_list ap_save)
|
||||||
{
|
{
|
||||||
int retcode;
|
int retcode;
|
||||||
struct asprintf info;
|
struct asprintf info;
|
||||||
@@ -1140,7 +1140,7 @@ static int storebuffer(int output, FILE *data)
|
|||||||
return output; /* act like fputc() ! */
|
return output; /* act like fputc() ! */
|
||||||
}
|
}
|
||||||
|
|
||||||
int msprintf(char *buffer, const char *format, ...)
|
int curl_msprintf(char *buffer, const char *format, ...)
|
||||||
{
|
{
|
||||||
va_list ap_save; /* argument pointer */
|
va_list ap_save; /* argument pointer */
|
||||||
int retcode;
|
int retcode;
|
||||||
@@ -1153,7 +1153,7 @@ int msprintf(char *buffer, const char *format, ...)
|
|||||||
|
|
||||||
extern int fputc(int, FILE *);
|
extern int fputc(int, FILE *);
|
||||||
|
|
||||||
int mprintf(const char *format, ...)
|
int curl_mprintf(const char *format, ...)
|
||||||
{
|
{
|
||||||
int retcode;
|
int retcode;
|
||||||
va_list ap_save; /* argument pointer */
|
va_list ap_save; /* argument pointer */
|
||||||
@@ -1163,7 +1163,7 @@ int mprintf(const char *format, ...)
|
|||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mfprintf(FILE *whereto, const char *format, ...)
|
int curl_mfprintf(FILE *whereto, const char *format, ...)
|
||||||
{
|
{
|
||||||
int retcode;
|
int retcode;
|
||||||
va_list ap_save; /* argument pointer */
|
va_list ap_save; /* argument pointer */
|
||||||
@@ -1173,7 +1173,7 @@ int mfprintf(FILE *whereto, const char *format, ...)
|
|||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mvsprintf(char *buffer, const char *format, va_list ap_save)
|
int curl_mvsprintf(char *buffer, const char *format, va_list ap_save)
|
||||||
{
|
{
|
||||||
int retcode;
|
int retcode;
|
||||||
retcode = dprintf_formatf(&buffer, storebuffer, format, ap_save);
|
retcode = dprintf_formatf(&buffer, storebuffer, format, ap_save);
|
||||||
@@ -1181,12 +1181,12 @@ int mvsprintf(char *buffer, const char *format, va_list ap_save)
|
|||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mvprintf(const char *format, va_list ap_save)
|
int curl_mvprintf(const char *format, va_list ap_save)
|
||||||
{
|
{
|
||||||
return dprintf_formatf(stdout, fputc, format, ap_save);
|
return dprintf_formatf(stdout, fputc, format, ap_save);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mvfprintf(FILE *whereto, const char *format, va_list ap_save)
|
int curl_mvfprintf(FILE *whereto, const char *format, va_list ap_save)
|
||||||
{
|
{
|
||||||
return dprintf_formatf(whereto, fputc, format, ap_save);
|
return dprintf_formatf(whereto, fputc, format, ap_save);
|
||||||
}
|
}
|
||||||
|
11
lib/netrc.c
11
lib/netrc.c
@@ -27,7 +27,8 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "getenv.h"
|
#include <curl/curl.h>
|
||||||
|
|
||||||
#include "strequal.h"
|
#include "strequal.h"
|
||||||
|
|
||||||
/* Debug this single source file with:
|
/* Debug this single source file with:
|
||||||
@@ -51,15 +52,15 @@ enum {
|
|||||||
#define LOGINSIZE 64
|
#define LOGINSIZE 64
|
||||||
#define PASSWORDSIZE 64
|
#define PASSWORDSIZE 64
|
||||||
|
|
||||||
int ParseNetrc(char *host,
|
int Curl_parsenetrc(char *host,
|
||||||
char *login,
|
char *login,
|
||||||
char *password)
|
char *password)
|
||||||
{
|
{
|
||||||
FILE *file;
|
FILE *file;
|
||||||
char netrcbuffer[256];
|
char netrcbuffer[256];
|
||||||
int retcode=1;
|
int retcode=1;
|
||||||
|
|
||||||
char *home = GetEnv("HOME"); /* portable environment reader */
|
char *home = curl_getenv("HOME"); /* portable environment reader */
|
||||||
int state=NOTHING;
|
int state=NOTHING;
|
||||||
|
|
||||||
char state_login=0;
|
char state_login=0;
|
||||||
|
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
int ParseNetrc(char *host,
|
int Curl_parsenetrc(char *host,
|
||||||
char *login,
|
char *login,
|
||||||
char *password);
|
char *password);
|
||||||
#endif
|
#endif
|
||||||
|
@@ -45,7 +45,7 @@
|
|||||||
|
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
|
|
||||||
void time2str(char *r, int t)
|
static void time2str(char *r, int t)
|
||||||
{
|
{
|
||||||
int h = (t/3600);
|
int h = (t/3600);
|
||||||
int m = (t-(h*3600))/60;
|
int m = (t-(h*3600))/60;
|
||||||
@@ -55,7 +55,7 @@ void time2str(char *r, int t)
|
|||||||
|
|
||||||
/* The point of this function would be to return a string of the input data,
|
/* The point of this function would be to return a string of the input data,
|
||||||
but never longer than 5 columns. Add suffix k, M, G when suitable... */
|
but never longer than 5 columns. Add suffix k, M, G when suitable... */
|
||||||
char *max5data(double bytes, char *max5)
|
static char *max5data(double bytes, char *max5)
|
||||||
{
|
{
|
||||||
#define ONE_KILOBYTE 1024
|
#define ONE_KILOBYTE 1024
|
||||||
#define ONE_MEGABYTE (1024*1024)
|
#define ONE_MEGABYTE (1024*1024)
|
||||||
@@ -91,16 +91,16 @@ char *max5data(double bytes, char *max5)
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void pgrsDone(struct UrlData *data)
|
void Curl_pgrsDone(struct UrlData *data)
|
||||||
{
|
{
|
||||||
if(!(data->progress.flags & PGRS_HIDE)) {
|
if(!(data->progress.flags & PGRS_HIDE)) {
|
||||||
data->progress.lastshow=0;
|
data->progress.lastshow=0;
|
||||||
pgrsUpdate(data); /* the final (forced) update */
|
Curl_pgrsUpdate(data); /* the final (forced) update */
|
||||||
fprintf(data->err, "\n");
|
fprintf(data->err, "\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void pgrsTime(struct UrlData *data, timerid timer)
|
void Curl_pgrsTime(struct UrlData *data, timerid timer)
|
||||||
{
|
{
|
||||||
switch(timer) {
|
switch(timer) {
|
||||||
default:
|
default:
|
||||||
@@ -111,19 +111,19 @@ void pgrsTime(struct UrlData *data, timerid timer)
|
|||||||
/* This is set at the start of a single fetch, there may be several
|
/* This is set at the start of a single fetch, there may be several
|
||||||
fetches within an operation, why we add all other times relative
|
fetches within an operation, why we add all other times relative
|
||||||
to this one */
|
to this one */
|
||||||
data->progress.t_startsingle = tvnow();
|
data->progress.t_startsingle = Curl_tvnow();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TIMER_NAMELOOKUP:
|
case TIMER_NAMELOOKUP:
|
||||||
data->progress.t_nslookup += tvdiff(tvnow(),
|
data->progress.t_nslookup += Curl_tvdiff(Curl_tvnow(),
|
||||||
data->progress.t_startsingle);
|
data->progress.t_startsingle);
|
||||||
break;
|
break;
|
||||||
case TIMER_CONNECT:
|
case TIMER_CONNECT:
|
||||||
data->progress.t_connect += tvdiff(tvnow(),
|
data->progress.t_connect += Curl_tvdiff(Curl_tvnow(),
|
||||||
data->progress.t_startsingle);
|
data->progress.t_startsingle);
|
||||||
break;
|
break;
|
||||||
case TIMER_PRETRANSFER:
|
case TIMER_PRETRANSFER:
|
||||||
data->progress.t_pretransfer += tvdiff(tvnow(),
|
data->progress.t_pretransfer += Curl_tvdiff(Curl_tvnow(),
|
||||||
data->progress.t_startsingle);
|
data->progress.t_startsingle);
|
||||||
break;
|
break;
|
||||||
case TIMER_POSTRANSFER:
|
case TIMER_POSTRANSFER:
|
||||||
@@ -132,22 +132,22 @@ void pgrsTime(struct UrlData *data, timerid timer)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void pgrsStartNow(struct UrlData *data)
|
void Curl_pgrsStartNow(struct UrlData *data)
|
||||||
{
|
{
|
||||||
data->progress.start = tvnow();
|
data->progress.start = Curl_tvnow();
|
||||||
}
|
}
|
||||||
|
|
||||||
void pgrsSetDownloadCounter(struct UrlData *data, double size)
|
void Curl_pgrsSetDownloadCounter(struct UrlData *data, double size)
|
||||||
{
|
{
|
||||||
data->progress.downloaded = size;
|
data->progress.downloaded = size;
|
||||||
}
|
}
|
||||||
|
|
||||||
void pgrsSetUploadCounter(struct UrlData *data, double size)
|
void Curl_pgrsSetUploadCounter(struct UrlData *data, double size)
|
||||||
{
|
{
|
||||||
data->progress.uploaded = size;
|
data->progress.uploaded = size;
|
||||||
}
|
}
|
||||||
|
|
||||||
void pgrsSetDownloadSize(struct UrlData *data, double size)
|
void Curl_pgrsSetDownloadSize(struct UrlData *data, double size)
|
||||||
{
|
{
|
||||||
if(size > 0) {
|
if(size > 0) {
|
||||||
data->progress.size_dl = size;
|
data->progress.size_dl = size;
|
||||||
@@ -155,7 +155,7 @@ void pgrsSetDownloadSize(struct UrlData *data, double size)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void pgrsSetUploadSize(struct UrlData *data, double size)
|
void Curl_pgrsSetUploadSize(struct UrlData *data, double size)
|
||||||
{
|
{
|
||||||
if(size > 0) {
|
if(size > 0) {
|
||||||
data->progress.size_ul = size;
|
data->progress.size_ul = size;
|
||||||
@@ -171,7 +171,7 @@ void pgrsSetUploadSize(struct UrlData *data, double size)
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int pgrsUpdate(struct UrlData *data)
|
int Curl_pgrsUpdate(struct UrlData *data)
|
||||||
{
|
{
|
||||||
struct timeval now;
|
struct timeval now;
|
||||||
int result;
|
int result;
|
||||||
@@ -203,6 +203,9 @@ int pgrsUpdate(struct UrlData *data)
|
|||||||
even when not displayed! */
|
even when not displayed! */
|
||||||
else if(!(data->progress.flags & PGRS_HEADERS_OUT)) {
|
else if(!(data->progress.flags & PGRS_HEADERS_OUT)) {
|
||||||
if (!data->progress.callback) {
|
if (!data->progress.callback) {
|
||||||
|
if(data->resume_from)
|
||||||
|
fprintf(data->err, "** Resuming transfer from byte position %d\n",
|
||||||
|
data->resume_from);
|
||||||
fprintf(data->err,
|
fprintf(data->err,
|
||||||
" %% Total %% Received %% Xferd Average Speed Time Curr.\n"
|
" %% Total %% Received %% Xferd Average Speed Time Curr.\n"
|
||||||
" Dload Upload Total Current Left Speed\n");
|
" Dload Upload Total Current Left Speed\n");
|
||||||
@@ -210,16 +213,16 @@ int pgrsUpdate(struct UrlData *data)
|
|||||||
data->progress.flags |= PGRS_HEADERS_OUT; /* headers are shown */
|
data->progress.flags |= PGRS_HEADERS_OUT; /* headers are shown */
|
||||||
}
|
}
|
||||||
|
|
||||||
now = tvnow(); /* what time is it */
|
now = Curl_tvnow(); /* what time is it */
|
||||||
|
|
||||||
if(data->progress.lastshow == tvlong(now))
|
/* The exact time spent so far */
|
||||||
|
data->progress.timespent = Curl_tvdiff (now, data->progress.start);
|
||||||
|
|
||||||
|
if(data->progress.lastshow == Curl_tvlong(now))
|
||||||
return 0; /* never update this more than once a second if the end isn't
|
return 0; /* never update this more than once a second if the end isn't
|
||||||
reached */
|
reached */
|
||||||
data->progress.lastshow = now.tv_sec;
|
data->progress.lastshow = now.tv_sec;
|
||||||
|
|
||||||
/* The exact time spent so far */
|
|
||||||
data->progress.timespent = tvdiff (now, data->progress.start);
|
|
||||||
|
|
||||||
/* The average download speed this far */
|
/* The average download speed this far */
|
||||||
data->progress.dlspeed = data->progress.downloaded/(data->progress.timespent!=0.0?data->progress.timespent:1.0);
|
data->progress.dlspeed = data->progress.downloaded/(data->progress.timespent!=0.0?data->progress.timespent:1.0);
|
||||||
|
|
||||||
@@ -257,17 +260,13 @@ int pgrsUpdate(struct UrlData *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Figure out the estimated time of arrival for the upload */
|
/* Figure out the estimated time of arrival for the upload */
|
||||||
if(data->progress.flags & PGRS_UL_SIZE_KNOWN) {
|
if((data->progress.flags & PGRS_UL_SIZE_KNOWN) && data->progress.ulspeed){
|
||||||
if(!data->progress.ulspeed)
|
|
||||||
data->progress.ulspeed=1;
|
|
||||||
ulestimate = data->progress.size_ul / data->progress.ulspeed;
|
ulestimate = data->progress.size_ul / data->progress.ulspeed;
|
||||||
ulpercen = (data->progress.uploaded / data->progress.size_ul)*100;
|
ulpercen = (data->progress.uploaded / data->progress.size_ul)*100;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ... and the download */
|
/* ... and the download */
|
||||||
if(data->progress.flags & PGRS_DL_SIZE_KNOWN) {
|
if((data->progress.flags & PGRS_DL_SIZE_KNOWN) && data->progress.dlspeed) {
|
||||||
if(!data->progress.dlspeed)
|
|
||||||
data->progress.dlspeed=1;
|
|
||||||
dlestimate = data->progress.size_dl / data->progress.dlspeed;
|
dlestimate = data->progress.size_dl / data->progress.dlspeed;
|
||||||
dlpercen = (data->progress.downloaded / data->progress.size_dl)*100;
|
dlpercen = (data->progress.downloaded / data->progress.size_dl)*100;
|
||||||
}
|
}
|
||||||
|
@@ -36,14 +36,14 @@ typedef enum {
|
|||||||
TIMER_LAST /* must be last */
|
TIMER_LAST /* must be last */
|
||||||
} timerid;
|
} timerid;
|
||||||
|
|
||||||
void pgrsDone(struct UrlData *data);
|
void Curl_pgrsDone(struct UrlData *data);
|
||||||
void pgrsStartNow(struct UrlData *data);
|
void Curl_pgrsStartNow(struct UrlData *data);
|
||||||
void pgrsSetDownloadSize(struct UrlData *data, double size);
|
void Curl_pgrsSetDownloadSize(struct UrlData *data, double size);
|
||||||
void pgrsSetUploadSize(struct UrlData *data, double size);
|
void Curl_pgrsSetUploadSize(struct UrlData *data, double size);
|
||||||
void pgrsSetDownloadCounter(struct UrlData *data, double size);
|
void Curl_pgrsSetDownloadCounter(struct UrlData *data, double size);
|
||||||
void pgrsSetUploadCounter(struct UrlData *data, double size);
|
void Curl_pgrsSetUploadCounter(struct UrlData *data, double size);
|
||||||
int pgrsUpdate(struct UrlData *data);
|
int Curl_pgrsUpdate(struct UrlData *data);
|
||||||
void pgrsTime(struct UrlData *data, timerid timer);
|
void Curl_pgrsTime(struct UrlData *data, timerid timer);
|
||||||
|
|
||||||
|
|
||||||
/* Don't show progress for sizes smaller than: */
|
/* Don't show progress for sizes smaller than: */
|
||||||
|
@@ -40,13 +40,22 @@
|
|||||||
|
|
||||||
#ifdef KRB4
|
#ifdef KRB4
|
||||||
|
|
||||||
|
#define _MPRINTF_REPLACE /* we want curl-functions instead of native ones */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
#include "security.h"
|
#include "security.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
|
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "base64.h"
|
#include "base64.h"
|
||||||
|
#include "sendf.h"
|
||||||
|
#include "ftp.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
@@ -64,6 +73,7 @@ static struct {
|
|||||||
{ prot_private, "private" }
|
{ prot_private, "private" }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if 0
|
||||||
static const char *
|
static const char *
|
||||||
level_to_name(enum protection_level level)
|
level_to_name(enum protection_level level)
|
||||||
{
|
{
|
||||||
@@ -73,6 +83,7 @@ level_to_name(enum protection_level level)
|
|||||||
return level_names[i].name;
|
return level_names[i].name;
|
||||||
return "unknown";
|
return "unknown";
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef FTP_SERVER /* not used in server */
|
#ifndef FTP_SERVER /* not used in server */
|
||||||
static enum protection_level
|
static enum protection_level
|
||||||
@@ -319,7 +330,7 @@ sec_vfprintf2(struct connectdata *conn, FILE *f, const char *fmt, va_list ap)
|
|||||||
if(conn->data_prot == prot_clear)
|
if(conn->data_prot == prot_clear)
|
||||||
return vfprintf(f, fmt, ap);
|
return vfprintf(f, fmt, ap);
|
||||||
else {
|
else {
|
||||||
buf = maprintf(fmt, ap);
|
buf = aprintf(fmt, ap);
|
||||||
ret = buffer_write(&conn->out_buffer, buf, strlen(buf));
|
ret = buffer_write(&conn->out_buffer, buf, strlen(buf));
|
||||||
free(buf);
|
free(buf);
|
||||||
return ret;
|
return ret;
|
||||||
@@ -360,7 +371,7 @@ sec_read_msg(struct connectdata *conn, char *s, int level)
|
|||||||
int code;
|
int code;
|
||||||
|
|
||||||
buf = malloc(strlen(s));
|
buf = malloc(strlen(s));
|
||||||
len = base64_decode(s + 4, buf); /* XXX */
|
len = Curl_base64_decode(s + 4, buf); /* XXX */
|
||||||
|
|
||||||
len = (*mech->decode)(conn->app_data, buf, len, level, conn);
|
len = (*mech->decode)(conn->app_data, buf, len, level, conn);
|
||||||
if(len < 0)
|
if(len < 0)
|
||||||
@@ -390,7 +401,7 @@ sec_vfprintf(struct connectdata *conn, FILE *f, const char *fmt, va_list ap)
|
|||||||
if(!conn->sec_complete)
|
if(!conn->sec_complete)
|
||||||
return vfprintf(f, fmt, ap);
|
return vfprintf(f, fmt, ap);
|
||||||
|
|
||||||
buf = maprintf(fmt, ap);
|
buf = aprintf(fmt, ap);
|
||||||
len = (*mech->encode)(conn->app_data, buf, strlen(buf),
|
len = (*mech->encode)(conn->app_data, buf, strlen(buf),
|
||||||
conn->command_prot, &enc,
|
conn->command_prot, &enc,
|
||||||
conn);
|
conn);
|
||||||
@@ -399,7 +410,7 @@ sec_vfprintf(struct connectdata *conn, FILE *f, const char *fmt, va_list ap)
|
|||||||
failf(conn->data, "Failed to encode command.\n");
|
failf(conn->data, "Failed to encode command.\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if(base64_encode(enc, len, &buf) < 0){
|
if(Curl_base64_encode(enc, len, &buf) < 0){
|
||||||
failf(conn->data, "Out of memory base64-encoding.\n");
|
failf(conn->data, "Out of memory base64-encoding.\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@@ -461,7 +472,6 @@ sec_status(void)
|
|||||||
static int
|
static int
|
||||||
sec_prot_internal(struct connectdata *conn, int level)
|
sec_prot_internal(struct connectdata *conn, int level)
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
char *p;
|
char *p;
|
||||||
unsigned int s = 1048576;
|
unsigned int s = 1048576;
|
||||||
size_t nread;
|
size_t nread;
|
||||||
@@ -472,11 +482,11 @@ sec_prot_internal(struct connectdata *conn, int level)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(level){
|
if(level){
|
||||||
ftpsendf(conn->data->firstsocket, conn,
|
Curl_ftpsendf(conn->firstsocket, conn,
|
||||||
"PBSZ %u", s);
|
"PBSZ %u", s);
|
||||||
/* wait for feedback */
|
/* wait for feedback */
|
||||||
nread = GetLastResponse(conn->data->firstsocket,
|
nread = Curl_GetFTPResponse(conn->firstsocket,
|
||||||
conn->data->buffer, conn);
|
conn->data->buffer, conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
||||||
if(/*ret != COMPLETE*/conn->data->buffer[0] != '2'){
|
if(/*ret != COMPLETE*/conn->data->buffer[0] != '2'){
|
||||||
@@ -491,11 +501,11 @@ sec_prot_internal(struct connectdata *conn, int level)
|
|||||||
conn->buffer_size = s;
|
conn->buffer_size = s;
|
||||||
}
|
}
|
||||||
|
|
||||||
ftpsendf(conn->data->firstsocket, conn,
|
Curl_ftpsendf(conn->firstsocket, conn,
|
||||||
"PROT %c", level["CSEP"]);
|
"PROT %c", level["CSEP"]);
|
||||||
/* wait for feedback */
|
/* wait for feedback */
|
||||||
nread = GetLastResponse(conn->data->firstsocket,
|
nread = Curl_GetFTPResponse(conn->firstsocket,
|
||||||
conn->data->buffer, conn);
|
conn->data->buffer, conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
||||||
if(/*ret != COMPLETE*/conn->data->buffer[0] != '2'){
|
if(/*ret != COMPLETE*/conn->data->buffer[0] != '2'){
|
||||||
@@ -600,11 +610,11 @@ sec_login(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
infof(data, "Trying %s...\n", (*m)->name);
|
infof(data, "Trying %s...\n", (*m)->name);
|
||||||
/*ret = command("AUTH %s", (*m)->name);***/
|
/*ret = command("AUTH %s", (*m)->name);***/
|
||||||
ftpsendf(conn->data->firstsocket, conn,
|
Curl_ftpsendf(conn->firstsocket, conn,
|
||||||
"AUTH %s", (*m)->name);
|
"AUTH %s", (*m)->name);
|
||||||
/* wait for feedback */
|
/* wait for feedback */
|
||||||
nread = GetLastResponse(conn->data->firstsocket,
|
nread = Curl_GetFTPResponse(conn->firstsocket,
|
||||||
conn->data->buffer, conn);
|
conn->data->buffer, conn, NULL);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
return /*CURLE_OPERATION_TIMEOUTED*/-1;
|
||||||
if(/*ret != CONTINUE*/conn->data->buffer[0] != '3'){
|
if(/*ret != CONTINUE*/conn->data->buffer[0] != '3'){
|
||||||
|
277
lib/sendf.c
277
lib/sendf.c
@@ -50,9 +50,79 @@
|
|||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* infof() is for info message along the way */
|
/* returns last node in linked list */
|
||||||
|
static struct curl_slist *slist_get_last(struct curl_slist *list)
|
||||||
|
{
|
||||||
|
struct curl_slist *item;
|
||||||
|
|
||||||
void infof(struct UrlData *data, char *fmt, ...)
|
/* if caller passed us a NULL, return now */
|
||||||
|
if (!list)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
/* loop through to find the last item */
|
||||||
|
item = list;
|
||||||
|
while (item->next) {
|
||||||
|
item = item->next;
|
||||||
|
}
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* append a struct to the linked list. It always retunrs the address of the
|
||||||
|
* first record, so that you can sure this function as an initialization
|
||||||
|
* function as well as an append function. If you find this bothersome,
|
||||||
|
* then simply create a separate _init function and call it appropriately from
|
||||||
|
* within the proram. */
|
||||||
|
struct curl_slist *curl_slist_append(struct curl_slist *list,
|
||||||
|
const char *data)
|
||||||
|
{
|
||||||
|
struct curl_slist *last;
|
||||||
|
struct curl_slist *new_item;
|
||||||
|
|
||||||
|
new_item = (struct curl_slist *) malloc(sizeof(struct curl_slist));
|
||||||
|
if (new_item) {
|
||||||
|
new_item->next = NULL;
|
||||||
|
new_item->data = strdup(data);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
fprintf(stderr, "Cannot allocate memory for QUOTE list.\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (list) {
|
||||||
|
last = slist_get_last(list);
|
||||||
|
last->next = new_item;
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* if this is the first item, then new_item *is* the list */
|
||||||
|
return new_item;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* be nice and clean up resources */
|
||||||
|
void curl_slist_free_all(struct curl_slist *list)
|
||||||
|
{
|
||||||
|
struct curl_slist *next;
|
||||||
|
struct curl_slist *item;
|
||||||
|
|
||||||
|
if (!list)
|
||||||
|
return;
|
||||||
|
|
||||||
|
item = list;
|
||||||
|
do {
|
||||||
|
next = item->next;
|
||||||
|
|
||||||
|
if (item->data) {
|
||||||
|
free(item->data);
|
||||||
|
}
|
||||||
|
free(item);
|
||||||
|
item = next;
|
||||||
|
} while (next);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Curl_infof() is for info message along the way */
|
||||||
|
|
||||||
|
void Curl_infof(struct UrlData *data, char *fmt, ...)
|
||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
if(data->bits.verbose) {
|
if(data->bits.verbose) {
|
||||||
@@ -63,106 +133,84 @@ void infof(struct UrlData *data, char *fmt, ...)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* failf() is for messages stating why we failed, the LAST one will be
|
/* Curl_failf() is for messages stating why we failed, the LAST one will be
|
||||||
returned for the user (if requested) */
|
returned for the user (if requested) */
|
||||||
|
|
||||||
void failf(struct UrlData *data, char *fmt, ...)
|
void Curl_failf(struct UrlData *data, char *fmt, ...)
|
||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
if(data->errorbuffer)
|
if(data->errorbuffer)
|
||||||
vsnprintf(data->errorbuffer, CURL_ERROR_SIZE, fmt, ap);
|
vsnprintf(data->errorbuffer, CURL_ERROR_SIZE, fmt, ap);
|
||||||
else /* no errorbuffer receives this, write to data->err instead */
|
else if(!data->bits.mute) {
|
||||||
|
/* no errorbuffer receives this, write to data->err instead */
|
||||||
vfprintf(data->err, fmt, ap);
|
vfprintf(data->err, fmt, ap);
|
||||||
|
fprintf(data->err, "\n");
|
||||||
|
}
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* sendf() sends the formated data to the server */
|
/* Curl_sendf() sends formated data to the server */
|
||||||
size_t sendf(int fd, struct UrlData *data, char *fmt, ...)
|
size_t Curl_sendf(int sockfd, struct connectdata *conn,
|
||||||
|
char *fmt, ...)
|
||||||
{
|
{
|
||||||
|
struct UrlData *data = conn->data;
|
||||||
size_t bytes_written;
|
size_t bytes_written;
|
||||||
char *s;
|
char *s;
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
s = mvaprintf(fmt, ap);
|
s = vaprintf(fmt, ap); /* returns an allocated string */
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
if(!s)
|
if(!s)
|
||||||
return 0; /* failure */
|
return 0; /* failure */
|
||||||
if(data->bits.verbose)
|
if(data->bits.verbose)
|
||||||
fprintf(data->err, "> %s", s);
|
fprintf(data->err, "> %s", s);
|
||||||
|
|
||||||
#ifndef USE_SSLEAY
|
/* Write the buffer to the socket */
|
||||||
bytes_written = swrite(fd, s, strlen(s));
|
Curl_write(conn, sockfd, s, strlen(s), &bytes_written);
|
||||||
#else /* USE_SSLEAY */
|
|
||||||
if (data->ssl.use) {
|
|
||||||
bytes_written = SSL_write(data->ssl.handle, s, strlen(s));
|
|
||||||
} else {
|
|
||||||
bytes_written = swrite(fd, s, strlen(s));
|
|
||||||
}
|
|
||||||
#endif /* USE_SSLEAY */
|
|
||||||
free(s); /* free the output string */
|
free(s); /* free the output string */
|
||||||
return(bytes_written);
|
|
||||||
|
return bytes_written;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ftpsendf() sends the formated string as a ftp command to a ftp server
|
* Curl_write() is an internal write function that sends plain (binary) data
|
||||||
*
|
* to the server. Works with plain sockets, SSL or kerberos.
|
||||||
* NOTE: we build the command in a fixed-length buffer, which sets length
|
|
||||||
* restrictions on the command!
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
size_t ftpsendf(int fd, struct connectdata *conn, char *fmt, ...)
|
CURLcode Curl_write(struct connectdata *conn, int sockfd,
|
||||||
|
void *mem, size_t len,
|
||||||
|
size_t *written)
|
||||||
{
|
{
|
||||||
size_t bytes_written;
|
size_t bytes_written;
|
||||||
char s[256];
|
|
||||||
|
|
||||||
va_list ap;
|
|
||||||
va_start(ap, fmt);
|
|
||||||
vsnprintf(s, 250, fmt, ap);
|
|
||||||
va_end(ap);
|
|
||||||
|
|
||||||
if(conn->data->bits.verbose)
|
|
||||||
fprintf(conn->data->err, "> %s\n", s);
|
|
||||||
|
|
||||||
strcat(s, "\r\n"); /* append a trailing CRLF */
|
|
||||||
|
|
||||||
#ifdef KRB4
|
|
||||||
if(conn->sec_complete && conn->data->cmdchannel) {
|
|
||||||
bytes_written = sec_fprintf(conn, conn->data->cmdchannel, s);
|
|
||||||
fflush(conn->data->cmdchannel);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
#endif /* KRB4 */
|
|
||||||
{
|
|
||||||
bytes_written = swrite(fd, s, strlen(s));
|
|
||||||
}
|
|
||||||
return(bytes_written);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ssend() sends plain (binary) data to the server */
|
|
||||||
size_t ssend(int fd, struct connectdata *conn, void *mem, size_t len)
|
|
||||||
{
|
|
||||||
size_t bytes_written;
|
|
||||||
struct UrlData *data=conn->data; /* conn knows data, not vice versa */
|
|
||||||
|
|
||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
if (data->ssl.use) {
|
if (conn->ssl.use) {
|
||||||
bytes_written = SSL_write(data->ssl.handle, mem, len);
|
int loop=100; /* just a precaution to never loop endlessly */
|
||||||
|
while(loop--) {
|
||||||
|
bytes_written = SSL_write(conn->ssl.handle, mem, len);
|
||||||
|
if((-1 != bytes_written) ||
|
||||||
|
(SSL_ERROR_WANT_WRITE != SSL_get_error(conn->ssl.handle,
|
||||||
|
bytes_written) ))
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
#endif
|
#endif
|
||||||
#ifdef KRB4
|
#ifdef KRB4
|
||||||
if(conn->sec_complete) {
|
if(conn->sec_complete) {
|
||||||
bytes_written = sec_write(conn, fd, mem, len);
|
bytes_written = sec_write(conn, sockfd, mem, len);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif /* KRB4 */
|
#endif /* KRB4 */
|
||||||
bytes_written = swrite(fd, mem, len);
|
bytes_written = swrite(sockfd, mem, len);
|
||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return bytes_written;
|
*written = bytes_written;
|
||||||
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* client_write() sends data to the write callback(s)
|
/* client_write() sends data to the write callback(s)
|
||||||
@@ -170,10 +218,10 @@ size_t ssend(int fd, struct connectdata *conn, void *mem, size_t len)
|
|||||||
The bit pattern defines to what "streams" to write to. Body and/or header.
|
The bit pattern defines to what "streams" to write to. Body and/or header.
|
||||||
The defines are in sendf.h of course.
|
The defines are in sendf.h of course.
|
||||||
*/
|
*/
|
||||||
CURLcode client_write(struct UrlData *data,
|
CURLcode Curl_client_write(struct UrlData *data,
|
||||||
int type,
|
int type,
|
||||||
char *ptr,
|
char *ptr,
|
||||||
size_t len)
|
size_t len)
|
||||||
{
|
{
|
||||||
size_t wrote;
|
size_t wrote;
|
||||||
|
|
||||||
@@ -200,90 +248,37 @@ CURLcode client_write(struct UrlData *data,
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* add_buffer_init() returns a fine buffer struct
|
* Internal read-from-socket function. This is meant to deal with plain
|
||||||
|
* sockets, SSL sockets and kerberos sockets.
|
||||||
*/
|
*/
|
||||||
send_buffer *add_buffer_init(void)
|
CURLcode Curl_read(struct connectdata *conn, int sockfd,
|
||||||
|
char *buf, size_t buffersize,
|
||||||
|
ssize_t *n)
|
||||||
{
|
{
|
||||||
send_buffer *blonk;
|
ssize_t nread;
|
||||||
blonk=(send_buffer *)malloc(sizeof(send_buffer));
|
|
||||||
if(blonk) {
|
|
||||||
memset(blonk, 0, sizeof(send_buffer));
|
|
||||||
return blonk;
|
|
||||||
}
|
|
||||||
return NULL; /* failed, go home */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
#ifdef USE_SSLEAY
|
||||||
* add_buffer_send() sends a buffer and frees all associated memory.
|
if (conn->ssl.use) {
|
||||||
*/
|
int loop=100; /* just a precaution to never loop endlessly */
|
||||||
size_t add_buffer_send(int sockfd, struct connectdata *conn, send_buffer *in)
|
while(loop--) {
|
||||||
{
|
nread = SSL_read(conn->ssl.handle, buf, buffersize);
|
||||||
size_t amount;
|
if((-1 != nread) ||
|
||||||
if(conn->data->bits.verbose) {
|
(SSL_ERROR_WANT_READ != SSL_get_error(conn->ssl.handle, nread) ))
|
||||||
fputs("> ", conn->data->err);
|
break;
|
||||||
/* this data _may_ contain binary stuff */
|
|
||||||
fwrite(in->buffer, in->size_used, 1, conn->data->err);
|
|
||||||
}
|
|
||||||
|
|
||||||
amount = ssend(sockfd, conn, in->buffer, in->size_used);
|
|
||||||
|
|
||||||
if(in->buffer)
|
|
||||||
free(in->buffer);
|
|
||||||
free(in);
|
|
||||||
|
|
||||||
return amount;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* add_bufferf() builds a buffer from the formatted input
|
|
||||||
*/
|
|
||||||
CURLcode add_bufferf(send_buffer *in, char *fmt, ...)
|
|
||||||
{
|
|
||||||
CURLcode result = CURLE_OUT_OF_MEMORY;
|
|
||||||
char *s;
|
|
||||||
va_list ap;
|
|
||||||
va_start(ap, fmt);
|
|
||||||
s = mvaprintf(fmt, ap); /* this allocs a new string to append */
|
|
||||||
va_end(ap);
|
|
||||||
|
|
||||||
if(s) {
|
|
||||||
result = add_buffer(in, s, strlen(s));
|
|
||||||
free(s);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* add_buffer() appends a memory chunk to the existing one
|
|
||||||
*/
|
|
||||||
CURLcode add_buffer(send_buffer *in, void *inptr, size_t size)
|
|
||||||
{
|
|
||||||
char *new_rb;
|
|
||||||
int new_size;
|
|
||||||
|
|
||||||
if(size > 0) {
|
|
||||||
if(!in->buffer ||
|
|
||||||
((in->size_used + size) > (in->size_max - 1))) {
|
|
||||||
new_size = (in->size_used+size)*2;
|
|
||||||
if(in->buffer)
|
|
||||||
/* we have a buffer, enlarge the existing one */
|
|
||||||
new_rb = (char *)realloc(in->buffer, new_size);
|
|
||||||
else
|
|
||||||
/* create a new buffer */
|
|
||||||
new_rb = (char *)malloc(new_size);
|
|
||||||
|
|
||||||
if(!new_rb)
|
|
||||||
return CURLE_OUT_OF_MEMORY;
|
|
||||||
|
|
||||||
in->buffer = new_rb;
|
|
||||||
in->size_max = new_size;
|
|
||||||
}
|
}
|
||||||
memcpy(&in->buffer[in->size_used], inptr, size);
|
|
||||||
|
|
||||||
in->size_used += size;
|
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
#endif
|
||||||
|
#ifdef KRB4
|
||||||
|
if(conn->sec_complete)
|
||||||
|
nread = sec_read(conn, sockfd, buf, buffersize);
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
nread = sread (sockfd, buf, buffersize);
|
||||||
|
#ifdef USE_SSLEAY
|
||||||
|
}
|
||||||
|
#endif /* USE_SSLEAY */
|
||||||
|
*n = nread;
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
27
lib/sendf.h
27
lib/sendf.h
@@ -23,11 +23,12 @@
|
|||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
size_t ftpsendf(int fd, struct connectdata *, char *fmt, ...);
|
size_t Curl_sendf(int fd, struct connectdata *, char *fmt, ...);
|
||||||
size_t sendf(int fd, struct UrlData *, char *fmt, ...);
|
void Curl_infof(struct UrlData *, char *fmt, ...);
|
||||||
size_t ssend(int fd, struct connectdata *, void *fmt, size_t len);
|
void Curl_failf(struct UrlData *, char *fmt, ...);
|
||||||
void infof(struct UrlData *, char *fmt, ...);
|
|
||||||
void failf(struct UrlData *, char *fmt, ...);
|
#define infof Curl_infof
|
||||||
|
#define failf Curl_failf
|
||||||
|
|
||||||
struct send_buffer {
|
struct send_buffer {
|
||||||
char *buffer;
|
char *buffer;
|
||||||
@@ -40,12 +41,16 @@ typedef struct send_buffer send_buffer;
|
|||||||
#define CLIENTWRITE_HEADER 2
|
#define CLIENTWRITE_HEADER 2
|
||||||
#define CLIENTWRITE_BOTH (CLIENTWRITE_BODY|CLIENTWRITE_HEADER)
|
#define CLIENTWRITE_BOTH (CLIENTWRITE_BODY|CLIENTWRITE_HEADER)
|
||||||
|
|
||||||
CURLcode client_write(struct UrlData *data, int type, char *ptr,
|
CURLcode Curl_client_write(struct UrlData *data, int type, char *ptr,
|
||||||
size_t len);
|
size_t len);
|
||||||
send_buffer *add_buffer_init(void);
|
|
||||||
CURLcode add_buffer(send_buffer *in, void *inptr, size_t size);
|
|
||||||
CURLcode add_bufferf(send_buffer *in, char *fmt, ...);
|
|
||||||
size_t add_buffer_send(int sockfd, struct connectdata *conn, send_buffer *in);
|
|
||||||
|
|
||||||
|
/* internal read-function, does plain socket, SSL and krb4 */
|
||||||
|
CURLcode Curl_read(struct connectdata *conn, int sockfd,
|
||||||
|
char *buf, size_t buffersize,
|
||||||
|
ssize_t *n);
|
||||||
|
/* internal write-function, does plain socket, SSL and krb4 */
|
||||||
|
CURLcode Curl_write(struct connectdata *conn, int sockfd,
|
||||||
|
void *mem, size_t len,
|
||||||
|
size_t *written);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -100,7 +100,6 @@ defined(HAVE_LIBSSL) && defined(HAVE_LIBCRYPTO)
|
|||||||
1. close a socket
|
1. close a socket
|
||||||
2. read from a socket
|
2. read from a socket
|
||||||
3. write to a socket
|
3. write to a socket
|
||||||
(Hopefully, only win32-crap do this weird name changing)
|
|
||||||
|
|
||||||
4. set the SIGALRM signal timeout
|
4. set the SIGALRM signal timeout
|
||||||
5. set dir/file naming defines
|
5. set dir/file naming defines
|
||||||
@@ -115,8 +114,8 @@ defined(HAVE_LIBSSL) && defined(HAVE_LIBCRYPTO)
|
|||||||
#else
|
#else
|
||||||
/* gcc-for-win is still good :) */
|
/* gcc-for-win is still good :) */
|
||||||
#define sclose(x) close(x)
|
#define sclose(x) close(x)
|
||||||
#define sread(x,y,z) read(x,y,z)
|
#define sread(x,y,z) recv(x,y,z,0)
|
||||||
#define swrite(x,y,z) write(x,y,z)
|
#define swrite(x,y,z) send(x,y,z,0)
|
||||||
#define myalarm(x) alarm(x)
|
#define myalarm(x) alarm(x)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -24,6 +24,7 @@
|
|||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
#if defined(__MINGW32__)
|
#if defined(__MINGW32__)
|
||||||
#include <winsock.h>
|
#include <winsock.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -33,24 +34,24 @@
|
|||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
#include "speedcheck.h"
|
#include "speedcheck.h"
|
||||||
|
|
||||||
void speedinit(struct UrlData *data)
|
void Curl_speedinit(struct UrlData *data)
|
||||||
{
|
{
|
||||||
memset(&data->keeps_speed, 0, sizeof(struct timeval));
|
memset(&data->keeps_speed, 0, sizeof(struct timeval));
|
||||||
}
|
}
|
||||||
|
|
||||||
CURLcode speedcheck(struct UrlData *data,
|
CURLcode Curl_speedcheck(struct UrlData *data,
|
||||||
struct timeval now)
|
struct timeval now)
|
||||||
{
|
{
|
||||||
if((data->progress.current_speed >= 0) &&
|
if((data->progress.current_speed >= 0) &&
|
||||||
data->low_speed_time &&
|
data->low_speed_time &&
|
||||||
(tvlong(data->keeps_speed) != 0) &&
|
(Curl_tvlong(data->keeps_speed) != 0) &&
|
||||||
(data->progress.current_speed < data->low_speed_limit)) {
|
(data->progress.current_speed < data->low_speed_limit)) {
|
||||||
|
|
||||||
/* We are now below the "low speed limit". If we are below it
|
/* We are now below the "low speed limit". If we are below it
|
||||||
for "low speed time" seconds we consider that enough reason
|
for "low speed time" seconds we consider that enough reason
|
||||||
to abort the download. */
|
to abort the download. */
|
||||||
|
|
||||||
if( tvdiff(now, data->keeps_speed) > data->low_speed_time) {
|
if( Curl_tvdiff(now, data->keeps_speed) > data->low_speed_time) {
|
||||||
/* we have been this slow for long enough, now die */
|
/* we have been this slow for long enough, now die */
|
||||||
failf(data,
|
failf(data,
|
||||||
"Operation too slow. "
|
"Operation too slow. "
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user