Compare commits
339 Commits
curl-7_7
...
curl-7_8_1
Author | SHA1 | Date | |
---|---|---|---|
![]() |
a6a3673804 | ||
![]() |
944f9a73f4 | ||
![]() |
5ab1a10e9c | ||
![]() |
1813d2ddf7 | ||
![]() |
2827f5327a | ||
![]() |
47bb09e908 | ||
![]() |
7f21669ef2 | ||
![]() |
3a145180cc | ||
![]() |
f24d54a9c4 | ||
![]() |
9478d796a3 | ||
![]() |
00b00c6931 | ||
![]() |
e791f6ec58 | ||
![]() |
8987244758 | ||
![]() |
9b69f6faab | ||
![]() |
e7b966b9eb | ||
![]() |
e7801afed1 | ||
![]() |
929366b5ae | ||
![]() |
e1d8c5daa7 | ||
![]() |
2b44fdab2e | ||
![]() |
3e0a95bb78 | ||
![]() |
f0efa89484 | ||
![]() |
45037a39aa | ||
![]() |
31336d63ae | ||
![]() |
2c39a4381a | ||
![]() |
532624bafe | ||
![]() |
8469918306 | ||
![]() |
9646a8b346 | ||
![]() |
5e2a74fcc4 | ||
![]() |
813d7585c7 | ||
![]() |
ae55c1c144 | ||
![]() |
1a6143feba | ||
![]() |
b70a4227b3 | ||
![]() |
7d82bc81a2 | ||
![]() |
be449bdea1 | ||
![]() |
798aaf0c0a | ||
![]() |
6f2fca53ad | ||
![]() |
cd4aed6690 | ||
![]() |
fa601af722 | ||
![]() |
303b3cf41c | ||
![]() |
fc535aa086 | ||
![]() |
cd33795903 | ||
![]() |
c9d233d34a | ||
![]() |
bd192d5387 | ||
![]() |
4ac7a087c6 | ||
![]() |
2d5039184e | ||
![]() |
b1bbaebb17 | ||
![]() |
8f6997cbde | ||
![]() |
e18ecaf108 | ||
![]() |
fe67ba6d2b | ||
![]() |
e39e6c537e | ||
![]() |
4e4a899306 | ||
![]() |
9a78db6e59 | ||
![]() |
6475600afa | ||
![]() |
e450888b15 | ||
![]() |
23522a66d1 | ||
![]() |
116462a512 | ||
![]() |
217e033120 | ||
![]() |
259ac2dd77 | ||
![]() |
4ebf001d37 | ||
![]() |
5e326014cd | ||
![]() |
0b0bbffa35 | ||
![]() |
2b35432fcc | ||
![]() |
ef8a2bc4fc | ||
![]() |
96d235d9a3 | ||
![]() |
eaf51b62b9 | ||
![]() |
80994a123e | ||
![]() |
b1cd033c27 | ||
![]() |
268867311e | ||
![]() |
6840f80d21 | ||
![]() |
cac6876734 | ||
![]() |
753011c8db | ||
![]() |
2774dc390a | ||
![]() |
eb4534f735 | ||
![]() |
efb957039d | ||
![]() |
fe82ddda46 | ||
![]() |
94af496ac4 | ||
![]() |
6f17c2f140 | ||
![]() |
490c00fb30 | ||
![]() |
2d0dbd87c3 | ||
![]() |
13a5e16f35 | ||
![]() |
3d54ba1b9e | ||
![]() |
e051f904f2 | ||
![]() |
f8d94a3849 | ||
![]() |
ac691cae88 | ||
![]() |
43d0d75688 | ||
![]() |
77f34915ce | ||
![]() |
72b8993164 | ||
![]() |
6b9bd96c06 | ||
![]() |
6532f737eb | ||
![]() |
928ff54388 | ||
![]() |
95c94bf658 | ||
![]() |
7f295939d0 | ||
![]() |
aa27db6986 | ||
![]() |
4ce5fa3ea9 | ||
![]() |
ffa7c13117 | ||
![]() |
fbca7a83fc | ||
![]() |
870bacd689 | ||
![]() |
d9f39cc99b | ||
![]() |
f2e6d235f2 | ||
![]() |
baa220c1af | ||
![]() |
cabef4732d | ||
![]() |
cab90bf98a | ||
![]() |
ab449cce73 | ||
![]() |
b541537c66 | ||
![]() |
285e998fae | ||
![]() |
c503930b8d | ||
![]() |
5c6859e537 | ||
![]() |
4e376a2f1a | ||
![]() |
edd608aa76 | ||
![]() |
88d536eb3b | ||
![]() |
d567659bf4 | ||
![]() |
e0558ae541 | ||
![]() |
034f6378da | ||
![]() |
af129c499e | ||
![]() |
8b4809a898 | ||
![]() |
88d14e96ca | ||
![]() |
04d1491a6b | ||
![]() |
de16ddd5b4 | ||
![]() |
27751df6ec | ||
![]() |
cf02eb11f6 | ||
![]() |
22b8d387bc | ||
![]() |
bfd89c8078 | ||
![]() |
223c48e6b5 | ||
![]() |
7bb7550e23 | ||
![]() |
adf00f5b2e | ||
![]() |
0844c4fdb2 | ||
![]() |
38cabc4fdb | ||
![]() |
ec340e3e33 | ||
![]() |
f44f512f24 | ||
![]() |
ce0e2cc017 | ||
![]() |
b082832220 | ||
![]() |
1e5e0f9a26 | ||
![]() |
ac3ae8f775 | ||
![]() |
a51fd91db2 | ||
![]() |
d300cf4d84 | ||
![]() |
a9d0a85842 | ||
![]() |
81da4fc995 | ||
![]() |
b6ca1be1cd | ||
![]() |
20d67917c4 | ||
![]() |
915b10052c | ||
![]() |
d3516810a7 | ||
![]() |
68af9a222e | ||
![]() |
58c3bdc1a4 | ||
![]() |
72dec6cfec | ||
![]() |
8dc9f4330c | ||
![]() |
c77f77a1ce | ||
![]() |
2966ef6661 | ||
![]() |
93c53424c8 | ||
![]() |
4a2812c5e8 | ||
![]() |
4852a4930c | ||
![]() |
b555ca5baa | ||
![]() |
4a6eaf1b95 | ||
![]() |
a8bc40fe4e | ||
![]() |
1b9e26a287 | ||
![]() |
9f24645a5b | ||
![]() |
441a957d57 | ||
![]() |
adc0edc44b | ||
![]() |
4836154cef | ||
![]() |
0058e87ed5 | ||
![]() |
23903306a7 | ||
![]() |
49b9926d5a | ||
![]() |
6c50d2ee7d | ||
![]() |
9e8615ae1d | ||
![]() |
bb51c20c8b | ||
![]() |
a84af986fd | ||
![]() |
3ab3be1b6e | ||
![]() |
3ceb2bcbb9 | ||
![]() |
2457a31948 | ||
![]() |
9e1e318691 | ||
![]() |
e1132ecbe6 | ||
![]() |
ccb92f1a8a | ||
![]() |
8526fa97ce | ||
![]() |
f85c29aad8 | ||
![]() |
4677f733b2 | ||
![]() |
e82d2dc634 | ||
![]() |
b56f1e5185 | ||
![]() |
c7c942861a | ||
![]() |
a50fac0e63 | ||
![]() |
e0f56897d5 | ||
![]() |
c7dbde9f3f | ||
![]() |
8fd89d6b93 | ||
![]() |
632e951e14 | ||
![]() |
a3a2d200fa | ||
![]() |
4c2ca97d6d | ||
![]() |
11f2464a22 | ||
![]() |
291075b12f | ||
![]() |
282939c6fe | ||
![]() |
fef1fc0d32 | ||
![]() |
dc6da007ad | ||
![]() |
7be8993f94 | ||
![]() |
bad4c8967b | ||
![]() |
4dbac041f1 | ||
![]() |
dd344b65f2 | ||
![]() |
5c25c7bbfa | ||
![]() |
a6d9ccf66b | ||
![]() |
89ba66e071 | ||
![]() |
85631150ce | ||
![]() |
3654bd1b56 | ||
![]() |
237edbc9d8 | ||
![]() |
4127903183 | ||
![]() |
2ffc20dc7c | ||
![]() |
a2a446cb2f | ||
![]() |
9304055df5 | ||
![]() |
53e0c1b1a6 | ||
![]() |
4efa1e8e4c | ||
![]() |
ecba113125 | ||
![]() |
350c536f6c | ||
![]() |
a33eb9881c | ||
![]() |
bbe8aa073e | ||
![]() |
14521b418e | ||
![]() |
73982c65d2 | ||
![]() |
2eb94acb95 | ||
![]() |
6a80fb3482 | ||
![]() |
26d4c80049 | ||
![]() |
3974f30ed4 | ||
![]() |
44c246dbf2 | ||
![]() |
ef07903a51 | ||
![]() |
a7dc45997f | ||
![]() |
583c2e2f09 | ||
![]() |
90cce2ae3a | ||
![]() |
775dc07eb5 | ||
![]() |
a652db18bd | ||
![]() |
48f3feed59 | ||
![]() |
4ddb3fbbf4 | ||
![]() |
cc872ebc19 | ||
![]() |
ba46006896 | ||
![]() |
0b7e0638a9 | ||
![]() |
be49b01952 | ||
![]() |
8d0c1d5495 | ||
![]() |
2769a9ab0b | ||
![]() |
8ea5b5bbd0 | ||
![]() |
0ce49cb7ed | ||
![]() |
d802dfe86a | ||
![]() |
aabc0c08a1 | ||
![]() |
476addb9c1 | ||
![]() |
37d7a198d5 | ||
![]() |
16fe0c9be3 | ||
![]() |
f88ff705a4 | ||
![]() |
e83550f511 | ||
![]() |
fde31f0988 | ||
![]() |
d3090ac3f9 | ||
![]() |
2cf26d4fb7 | ||
![]() |
f470a131a6 | ||
![]() |
04b20b7ed2 | ||
![]() |
ff4f4abe4b | ||
![]() |
f4703aee2f | ||
![]() |
4c485994db | ||
![]() |
a921ee7b52 | ||
![]() |
f6d4a25f68 | ||
![]() |
2dfd2c642d | ||
![]() |
a2072a1fd0 | ||
![]() |
03fea9722c | ||
![]() |
a44a8cef99 | ||
![]() |
97ad165a63 | ||
![]() |
a508e73a8d | ||
![]() |
32f966b239 | ||
![]() |
60a43561e2 | ||
![]() |
a91b7d461d | ||
![]() |
8755c44d40 | ||
![]() |
5dd1cb0614 | ||
![]() |
b34bee45ca | ||
![]() |
e22fb3e7bc | ||
![]() |
6ea51f3cd7 | ||
![]() |
8e9f0a73d0 | ||
![]() |
80fbcdf2f2 | ||
![]() |
0fd9f64287 | ||
![]() |
b6175ec792 | ||
![]() |
1ee7f92ce4 | ||
![]() |
3fd65fb7d8 | ||
![]() |
ebcafe73b3 | ||
![]() |
8274bee963 | ||
![]() |
60aa975610 | ||
![]() |
28a9108257 | ||
![]() |
d1b0b08ba0 | ||
![]() |
cc7fc20251 | ||
![]() |
5ab751f5d0 | ||
![]() |
fb1ce5fd5b | ||
![]() |
fd8ea204c0 | ||
![]() |
b86674174a | ||
![]() |
69994f0114 | ||
![]() |
879c6c5711 | ||
![]() |
18f044f19d | ||
![]() |
d7b54eb835 | ||
![]() |
5eafb69bdb | ||
![]() |
a086e99bae | ||
![]() |
62056a644f | ||
![]() |
b2362bf51c | ||
![]() |
022099266e | ||
![]() |
870cea2aea | ||
![]() |
04c10e021c | ||
![]() |
d712a4e800 | ||
![]() |
d9f989c8c8 | ||
![]() |
90bb87b40e | ||
![]() |
025fa762f6 | ||
![]() |
ac510ab6a4 | ||
![]() |
65b286ca35 | ||
![]() |
cc5c53454a | ||
![]() |
f7874cad29 | ||
![]() |
84e71e1c50 | ||
![]() |
88bb054e1d | ||
![]() |
b054fbaebd | ||
![]() |
53e3c225ee | ||
![]() |
50a53d4eec | ||
![]() |
6bd1ed034a | ||
![]() |
fa491ed910 | ||
![]() |
66a1e3df69 | ||
![]() |
28497e7ee4 | ||
![]() |
87c7f403a9 | ||
![]() |
1a2c3acb3b | ||
![]() |
b54d752783 | ||
![]() |
b1328430c9 | ||
![]() |
34efa74a59 | ||
![]() |
794d08a728 | ||
![]() |
0abc999c4d | ||
![]() |
3e65062be2 | ||
![]() |
45ffb16c2a | ||
![]() |
0b8b0b7c86 | ||
![]() |
053bf49bd2 | ||
![]() |
8b08dfed38 | ||
![]() |
ba3a3553dc | ||
![]() |
6a26104724 | ||
![]() |
8b35b89f4d | ||
![]() |
31f9d4016d | ||
![]() |
bb601731ea | ||
![]() |
9a85172896 | ||
![]() |
a0eb52bee1 | ||
![]() |
6235a8d969 | ||
![]() |
0d6a87ed7a | ||
![]() |
b6241b3c89 | ||
![]() |
1e14f8d4c7 | ||
![]() |
bc5954fe2d | ||
![]() |
02f6894af5 | ||
![]() |
76576cd1e2 | ||
![]() |
997672ba9a | ||
![]() |
ec1f42a154 | ||
![]() |
aa1c3bb46d | ||
![]() |
95f0714ff8 | ||
![]() |
c050619b36 | ||
![]() |
58085dbbf6 |
1381
CHANGES.2000
Normal file
1381
CHANGES.2000
Normal file
File diff suppressed because it is too large
Load Diff
29
CVS-INFO
29
CVS-INFO
@@ -1,22 +1,37 @@
|
|||||||
This file is only present in the CVS - never in release archives.
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
This contains information about other files and things that the CVS repository
|
CVS-INFO
|
||||||
keeps in its inner sanctum.
|
|
||||||
|
This file is only present in the CVS - never in release archives. It contains
|
||||||
|
information about other files and things that the CVS repository keeps in its
|
||||||
|
inner sanctum.
|
||||||
|
|
||||||
|
Use autoconf 2.50 and no earlier. Also, try having automake 1.4 and libtool
|
||||||
|
1.4 at least.
|
||||||
|
|
||||||
|
You will need perl to generate the src/hugehelp.c file. The file
|
||||||
|
src/hugehelp.c.cvs is a one-shot file that you can rename to src/hugehelp.c if
|
||||||
|
you really can't generate the true file yourself!
|
||||||
|
|
||||||
CHANGES.0 contains ancient changes.
|
CHANGES.0 contains ancient changes.
|
||||||
|
|
||||||
memanalyze.pl is for analyzing the output generated by curl if -DMALLOCDEBUG
|
memanalyze.pl is for analyzing the output generated by curl if -DMALLOCDEBUG
|
||||||
is used when compiling
|
is used when compiling
|
||||||
|
|
||||||
|
buildconf builds the makefiles and configure stuff
|
||||||
|
|
||||||
Makefile.dist is included as the root Makefile in distribution archives
|
Makefile.dist is included as the root Makefile in distribution archives
|
||||||
|
|
||||||
perl/contrib/ is a subdirectory with various perl scripts
|
perl/contrib/ is a subdirectory with various perl scripts
|
||||||
|
|
||||||
|
java/ is a subdirectory with the Java interface to libcurl
|
||||||
|
|
||||||
To build after having extracted everything from CVS, do this:
|
To build after having extracted everything from CVS, do this:
|
||||||
|
|
||||||
automake
|
./buildconf
|
||||||
aclocal
|
|
||||||
autoheader
|
|
||||||
autoconf
|
|
||||||
./configure
|
./configure
|
||||||
make
|
make
|
||||||
|
22
Makefile.am
22
Makefile.am
@@ -6,7 +6,10 @@ AUTOMAKE_OPTIONS = foreign no-dependencies
|
|||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt \
|
||||||
config-win32.h reconf packages/README Makefile.dist
|
config-win32.h reconf packages/README Makefile.dist \
|
||||||
|
curl-config.in libtool
|
||||||
|
|
||||||
|
bin_SCRIPTS = curl-config
|
||||||
|
|
||||||
SUBDIRS = docs lib src include tests packages perl php
|
SUBDIRS = docs lib src include tests packages perl php
|
||||||
|
|
||||||
@@ -17,7 +20,7 @@ dist-hook:
|
|||||||
check: test
|
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
|
# Build source and binary rpms. For rpm-3.0 and above, the ~/.rpmmacros
|
||||||
@@ -45,3 +48,18 @@ rpm:
|
|||||||
rpm -ba --clean --rmsource $$RPM_TOPDIR/SPECS/$(RPMDIST).spec ; \
|
rpm -ba --clean --rmsource $$RPM_TOPDIR/SPECS/$(RPMDIST).spec ; \
|
||||||
mv $$RPM_TOPDIR/RPMS/i386/$(RPMDIST)-*.rpm . ; \
|
mv $$RPM_TOPDIR/RPMS/i386/$(RPMDIST)-*.rpm . ; \
|
||||||
mv $$RPM_TOPDIR/SRPMS/$(RPMDIST)-*.src.rpm .
|
mv $$RPM_TOPDIR/SRPMS/$(RPMDIST)-*.src.rpm .
|
||||||
|
|
||||||
|
#
|
||||||
|
# Build a Solaris pkkgadd format file
|
||||||
|
# run 'make pkgadd' once you've done './configure' and 'make' to make a Solaris pkgadd format
|
||||||
|
# file (which ends up back in this directory).
|
||||||
|
# The pkgadd file is in 'pkgtrans' format, so to install on Solaris, do
|
||||||
|
# pkgadd -d ./HAXXcurl-*
|
||||||
|
#
|
||||||
|
|
||||||
|
# gak - libtool requires an absoulte directory, hence the pwd below...
|
||||||
|
pkgadd:
|
||||||
|
umask 022 ; \
|
||||||
|
make install DESTDIR=`/bin/pwd`/packages/Solaris/root ; \
|
||||||
|
cat LEGAL MITX.txt MPL-1.1.txt > $(srcdir)/packages/Solaris/copyright ; \
|
||||||
|
cd $(srcdir)/packages/Solaris && $(MAKE) package
|
||||||
|
8
README
8
README
@@ -12,7 +12,7 @@ README
|
|||||||
document.
|
document.
|
||||||
|
|
||||||
libcurl is a library that Curl is using to do its job. It is readily
|
libcurl is a library that Curl is using to do its job. It is readily
|
||||||
available to be used by your software. Read the LIBCURL document to
|
available to be used by your software. Read the libcurl.5 man page to
|
||||||
find out how!
|
find out how!
|
||||||
|
|
||||||
You find answers to the most frequent questions we get in the FAQ document.
|
You find answers to the most frequent questions we get in the FAQ document.
|
||||||
@@ -34,11 +34,9 @@ README
|
|||||||
|
|
||||||
(just press enter when asked for password)
|
(just press enter when asked for password)
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl co .
|
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl co curl
|
||||||
|
|
||||||
(now, you'll get all the latest sources downloaded into your current
|
(you'll get a directory named curl created, filled with the source code)
|
||||||
directory. Note that this does NOT create a directory named curl or
|
|
||||||
anything)
|
|
||||||
|
|
||||||
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl logout
|
cvs -d :pserver:anonymous@cvs.curl.sourceforge.net:/cvsroot/curl logout
|
||||||
|
|
||||||
|
@@ -51,3 +51,6 @@
|
|||||||
|
|
||||||
/* Define this to your Entropy Gathering Daemon socket pathname */
|
/* Define this to your Entropy Gathering Daemon socket pathname */
|
||||||
#undef EGD_SOCKET
|
#undef EGD_SOCKET
|
||||||
|
|
||||||
|
/* Define if you have a working OpenSSL installation */
|
||||||
|
#undef OPENSSL_ENABLED
|
||||||
|
75
acinclude.m4
75
acinclude.m4
@@ -1,75 +0,0 @@
|
|||||||
#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
|
|
||||||
])
|
|
13
buildconf
Executable file
13
buildconf
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
die(){
|
||||||
|
echo "$@"
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
MAKEFILES=`find . -name Makefile.am | sed 's/\.am$//'`
|
||||||
|
|
||||||
|
automake $MAKEFILES || die "The command 'automake $MAKEFILES' failed"
|
||||||
|
aclocal || die "The command 'aclocal' failed"
|
||||||
|
autoheader || die "The command 'autoheader' failed"
|
||||||
|
autoconf || die "The command 'autoconf' failed"
|
512
config.guess
vendored
512
config.guess
vendored
@@ -1,8 +1,10 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Attempt to guess a canonical system name.
|
# Attempt to guess a canonical system name.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
# Free Software Foundation, Inc.
|
# Free Software Foundation, Inc.
|
||||||
#
|
|
||||||
|
timestamp='2001-04-20'
|
||||||
|
|
||||||
# This file is free software; you can redistribute it and/or modify it
|
# This file is free software; you can redistribute it and/or modify it
|
||||||
# under the terms of the GNU General Public License as published by
|
# under the terms of the GNU General Public License as published by
|
||||||
# the Free Software Foundation; either version 2 of the License, or
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
@@ -30,25 +32,85 @@
|
|||||||
# exits with 0. Otherwise, it exits with 1.
|
# exits with 0. Otherwise, it exits with 1.
|
||||||
#
|
#
|
||||||
# The plan is that this can be called by configure scripts if you
|
# The plan is that this can be called by configure scripts if you
|
||||||
# don't specify an explicit system type (host/target name).
|
# don't specify an explicit build system type.
|
||||||
#
|
|
||||||
# Only a few systems have been added to this list; please add others
|
|
||||||
# (but try to keep the structure clean).
|
|
||||||
#
|
|
||||||
|
|
||||||
# Use $HOST_CC if defined. $CC may point to a cross-compiler
|
me=`echo "$0" | sed -e 's,.*/,,'`
|
||||||
|
|
||||||
|
usage="\
|
||||||
|
Usage: $0 [OPTION]
|
||||||
|
|
||||||
|
Output the configuration name of the system \`$me' is run on.
|
||||||
|
|
||||||
|
Operation modes:
|
||||||
|
-h, --help print this help, then exit
|
||||||
|
-t, --time-stamp print date of last modification, then exit
|
||||||
|
-v, --version print version number, then exit
|
||||||
|
|
||||||
|
Report bugs and patches to <config-patches@gnu.org>."
|
||||||
|
|
||||||
|
version="\
|
||||||
|
GNU config.guess ($timestamp)
|
||||||
|
|
||||||
|
Originally written by Per Bothner.
|
||||||
|
Copyright (C) 1992, 93, 94, 95, 96, 97, 98, 99, 2000
|
||||||
|
Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This is free software; see the source for copying conditions. There is NO
|
||||||
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
|
||||||
|
help="
|
||||||
|
Try \`$me --help' for more information."
|
||||||
|
|
||||||
|
# Parse command line
|
||||||
|
while test $# -gt 0 ; do
|
||||||
|
case $1 in
|
||||||
|
--time-stamp | --time* | -t )
|
||||||
|
echo "$timestamp" ; exit 0 ;;
|
||||||
|
--version | -v )
|
||||||
|
echo "$version" ; exit 0 ;;
|
||||||
|
--help | --h* | -h )
|
||||||
|
echo "$usage"; exit 0 ;;
|
||||||
|
-- ) # Stop option processing
|
||||||
|
shift; break ;;
|
||||||
|
- ) # Use stdin as input.
|
||||||
|
break ;;
|
||||||
|
-* )
|
||||||
|
echo "$me: invalid option $1$help" >&2
|
||||||
|
exit 1 ;;
|
||||||
|
* )
|
||||||
|
break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if test $# != 0; then
|
||||||
|
echo "$me: too many arguments$help" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
dummy=dummy-$$
|
||||||
|
trap 'rm -f $dummy.c $dummy.o $dummy.rel $dummy; exit 1' 1 2 15
|
||||||
|
|
||||||
|
# CC_FOR_BUILD -- compiler used by this script.
|
||||||
|
# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
|
||||||
|
# use `HOST_CC' if defined, but it is deprecated.
|
||||||
|
|
||||||
|
case $CC_FOR_BUILD,$HOST_CC,$CC in
|
||||||
|
,,) echo "int dummy(){}" > $dummy.c
|
||||||
|
for c in cc gcc c89 ; do
|
||||||
|
($c $dummy.c -c -o $dummy.o) >/dev/null 2>&1
|
||||||
|
if test $? = 0 ; then
|
||||||
|
CC_FOR_BUILD="$c"; break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
rm -f $dummy.c $dummy.o $dummy.rel
|
||||||
if test x"$CC_FOR_BUILD" = x ; then
|
if test x"$CC_FOR_BUILD" = x ; then
|
||||||
if test x"$HOST_CC" != x; then
|
CC_FOR_BUILD=no_compiler_found
|
||||||
CC_FOR_BUILD="$HOST_CC"
|
|
||||||
else
|
|
||||||
if test x"$CC" != x; then
|
|
||||||
CC_FOR_BUILD="$CC"
|
|
||||||
else
|
|
||||||
CC_FOR_BUILD=cc
|
|
||||||
fi
|
fi
|
||||||
fi
|
;;
|
||||||
fi
|
,,*) CC_FOR_BUILD=$CC ;;
|
||||||
|
,*,*) CC_FOR_BUILD=$HOST_CC ;;
|
||||||
|
esac
|
||||||
|
|
||||||
# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
|
# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
|
||||||
# (ghazi@noc.rutgers.edu 8/24/94.)
|
# (ghazi@noc.rutgers.edu 8/24/94.)
|
||||||
@@ -61,9 +123,6 @@ UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
|
|||||||
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
|
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
|
||||||
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
|
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
|
||||||
|
|
||||||
dummy=dummy-$$
|
|
||||||
trap 'rm -f $dummy.c $dummy.o $dummy; exit 1' 1 2 15
|
|
||||||
|
|
||||||
# Note: order is significant - the case branches are not exclusive.
|
# Note: order is significant - the case branches are not exclusive.
|
||||||
|
|
||||||
case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
||||||
@@ -77,7 +136,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
|||||||
# object file format.
|
# object file format.
|
||||||
# Determine the machine/vendor (is the vendor relevant).
|
# Determine the machine/vendor (is the vendor relevant).
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
amiga) machine=m68k-cbm ;;
|
amiga) machine=m68k-unknown ;;
|
||||||
arm32) machine=arm-unknown ;;
|
arm32) machine=arm-unknown ;;
|
||||||
atari*) machine=m68k-atari ;;
|
atari*) machine=m68k-atari ;;
|
||||||
sun3*) machine=m68k-sun ;;
|
sun3*) machine=m68k-sun ;;
|
||||||
@@ -87,7 +146,10 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
|||||||
ibmrt|romp-ibm) machine=romp-ibm ;;
|
ibmrt|romp-ibm) machine=romp-ibm ;;
|
||||||
*) machine=${UNAME_MACHINE}-unknown ;;
|
*) machine=${UNAME_MACHINE}-unknown ;;
|
||||||
esac
|
esac
|
||||||
# The Operating System including object format.
|
# The Operating System including object format, if it has switched
|
||||||
|
# to ELF recently, or will in the future.
|
||||||
|
case "${UNAME_MACHINE}" in
|
||||||
|
i386|sparc|amiga|arm*|hp300|mvme68k|vax|atari|luna68k|mac68k|news68k|next68k|pc532|sun3*|x68k)
|
||||||
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
||||||
| grep __ELF__ >/dev/null
|
| grep __ELF__ >/dev/null
|
||||||
then
|
then
|
||||||
@@ -97,6 +159,11 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
|||||||
else
|
else
|
||||||
os=netbsdelf
|
os=netbsdelf
|
||||||
fi
|
fi
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
os=netbsd
|
||||||
|
;;
|
||||||
|
esac
|
||||||
# The OS release
|
# The OS release
|
||||||
release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
|
release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
|
||||||
# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
|
# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
|
||||||
@@ -173,7 +240,7 @@ EOF
|
|||||||
echo alpha-dec-winnt3.5
|
echo alpha-dec-winnt3.5
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
Amiga*:UNIX_System_V:4.0:*)
|
Amiga*:UNIX_System_V:4.0:*)
|
||||||
echo m68k-cbm-sysv4
|
echo m68k-unknown-sysv4
|
||||||
exit 0;;
|
exit 0;;
|
||||||
amiga:OpenBSD:*:*)
|
amiga:OpenBSD:*:*)
|
||||||
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
||||||
@@ -205,7 +272,7 @@ EOF
|
|||||||
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
|
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
|
||||||
echo arm-acorn-riscix${UNAME_RELEASE}
|
echo arm-acorn-riscix${UNAME_RELEASE}
|
||||||
exit 0;;
|
exit 0;;
|
||||||
SR2?01:HI-UX/MPP:*:*)
|
SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
|
||||||
echo hppa1.1-hitachi-hiuxmpp
|
echo hppa1.1-hitachi-hiuxmpp
|
||||||
exit 0;;
|
exit 0;;
|
||||||
Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
|
Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
|
||||||
@@ -341,10 +408,13 @@ EOF
|
|||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy \
|
$CC_FOR_BUILD $dummy.c -o $dummy \
|
||||||
&& ./$dummy `echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` \
|
&& ./$dummy `echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` \
|
||||||
&& rm $dummy.c $dummy && exit 0
|
&& rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo mips-mips-riscos${UNAME_RELEASE}
|
echo mips-mips-riscos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
Motorola:PowerMAX_OS:*:*)
|
||||||
|
echo powerpc-motorola-powermax
|
||||||
|
exit 0 ;;
|
||||||
Night_Hawk:Power_UNIX:*:*)
|
Night_Hawk:Power_UNIX:*:*)
|
||||||
echo powerpc-harris-powerunix
|
echo powerpc-harris-powerunix
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -392,9 +462,17 @@ EOF
|
|||||||
????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
|
????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
|
||||||
echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
|
echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
|
||||||
exit 0 ;; # Note that: echo "'`uname -s`'" gives 'AIX '
|
exit 0 ;; # Note that: echo "'`uname -s`'" gives 'AIX '
|
||||||
i?86:AIX:*:*)
|
i*86:AIX:*:*)
|
||||||
echo i386-ibm-aix
|
echo i386-ibm-aix
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
ia64:AIX:*:*)
|
||||||
|
if [ -x /usr/bin/oslevel ] ; then
|
||||||
|
IBM_REV=`/usr/bin/oslevel`
|
||||||
|
else
|
||||||
|
IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
|
||||||
|
fi
|
||||||
|
echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
|
||||||
|
exit 0 ;;
|
||||||
*:AIX:2:3)
|
*:AIX:2:3)
|
||||||
if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
|
if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
@@ -408,7 +486,7 @@ EOF
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo rs6000-ibm-aix3.2.5
|
echo rs6000-ibm-aix3.2.5
|
||||||
elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
|
elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
|
||||||
@@ -417,9 +495,9 @@ EOF
|
|||||||
echo rs6000-ibm-aix3.2
|
echo rs6000-ibm-aix3.2
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
*:AIX:*:4)
|
*:AIX:*:[45])
|
||||||
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | head -1 | awk '{ print $1 }'`
|
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | head -1 | awk '{ print $1 }'`
|
||||||
if /usr/sbin/lsattr -EHl ${IBM_CPU_ID} | grep POWER >/dev/null 2>&1; then
|
if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
|
||||||
IBM_ARCH=rs6000
|
IBM_ARCH=rs6000
|
||||||
else
|
else
|
||||||
IBM_ARCH=powerpc
|
IBM_ARCH=powerpc
|
||||||
@@ -427,7 +505,7 @@ EOF
|
|||||||
if [ -x /usr/bin/oslevel ] ; then
|
if [ -x /usr/bin/oslevel ] ; then
|
||||||
IBM_REV=`/usr/bin/oslevel`
|
IBM_REV=`/usr/bin/oslevel`
|
||||||
else
|
else
|
||||||
IBM_REV=4.${UNAME_RELEASE}
|
IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
|
||||||
fi
|
fi
|
||||||
echo ${IBM_ARCH}-ibm-aix${IBM_REV}
|
echo ${IBM_ARCH}-ibm-aix${IBM_REV}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -453,10 +531,28 @@ EOF
|
|||||||
echo m68k-hp-bsd4.4
|
echo m68k-hp-bsd4.4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
9000/[34678]??:HP-UX:*:*)
|
9000/[34678]??:HP-UX:*:*)
|
||||||
|
HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
9000/31? ) HP_ARCH=m68000 ;;
|
9000/31? ) HP_ARCH=m68000 ;;
|
||||||
9000/[34]?? ) HP_ARCH=m68k ;;
|
9000/[34]?? ) HP_ARCH=m68k ;;
|
||||||
9000/[678][0-9][0-9])
|
9000/[678][0-9][0-9])
|
||||||
|
case "${HPUX_REV}" in
|
||||||
|
11.[0-9][0-9])
|
||||||
|
if [ -x /usr/bin/getconf ]; then
|
||||||
|
sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
|
||||||
|
sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
|
||||||
|
case "${sc_cpu_version}" in
|
||||||
|
523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
|
||||||
|
528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
|
||||||
|
532) # CPU_PA_RISC2_0
|
||||||
|
case "${sc_kernel_bits}" in
|
||||||
|
32) HP_ARCH="hppa2.0n" ;;
|
||||||
|
64) HP_ARCH="hppa2.0w" ;;
|
||||||
|
esac ;;
|
||||||
|
esac
|
||||||
|
fi ;;
|
||||||
|
esac
|
||||||
|
if [ "${HP_ARCH}" = "" ]; then
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
|
|
||||||
#define _HPUX_SOURCE
|
#define _HPUX_SOURCE
|
||||||
@@ -491,11 +587,16 @@ EOF
|
|||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
(CCOPTS= $CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null ) && HP_ARCH=`./$dummy`
|
(CCOPTS= $CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null ) && HP_ARCH=`./$dummy`
|
||||||
|
if test -z "$HP_ARCH"; then HP_ARCH=hppa; fi
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
|
fi ;;
|
||||||
esac
|
esac
|
||||||
HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
|
|
||||||
echo ${HP_ARCH}-hp-hpux${HPUX_REV}
|
echo ${HP_ARCH}-hp-hpux${HPUX_REV}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
ia64:HP-UX:*:*)
|
||||||
|
HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
|
||||||
|
echo ia64-hp-hpux${HPUX_REV}
|
||||||
|
exit 0 ;;
|
||||||
3050*:HI-UX:*:*)
|
3050*:HI-UX:*:*)
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
sed 's/^ //' << EOF >$dummy.c
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@@ -522,7 +623,7 @@ EOF
|
|||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy && ./$dummy && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo unknown-hitachi-hiuxwe2
|
echo unknown-hitachi-hiuxwe2
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -541,7 +642,7 @@ EOF
|
|||||||
hp8??:OSF1:*:*)
|
hp8??:OSF1:*:*)
|
||||||
echo hppa1.0-hp-osf
|
echo hppa1.0-hp-osf
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:OSF1:*:*)
|
i*86:OSF1:*:*)
|
||||||
if [ -x /usr/sbin/sysversion ] ; then
|
if [ -x /usr/sbin/sysversion ] ; then
|
||||||
echo ${UNAME_MACHINE}-unknown-osf1mk
|
echo ${UNAME_MACHINE}-unknown-osf1mk
|
||||||
else
|
else
|
||||||
@@ -586,27 +687,28 @@ EOF
|
|||||||
CRAY*TS:*:*:*)
|
CRAY*TS:*:*:*)
|
||||||
echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY*T3E:*:*:*)
|
CRAY*T3D:*:*:*)
|
||||||
echo alpha-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
echo alpha-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
CRAY*T3E:*:*:*)
|
||||||
|
echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
|
exit 0 ;;
|
||||||
CRAY*SV1:*:*:*)
|
CRAY*SV1:*:*:*)
|
||||||
echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
CRAY-2:*:*:*)
|
CRAY-2:*:*:*)
|
||||||
echo cray2-cray-unicos
|
echo cray2-cray-unicos
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
F300:UNIX_System_V:*:*)
|
F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
|
||||||
|
FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
||||||
FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
|
FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
|
||||||
FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
|
FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
|
||||||
echo "f300-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
|
echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
|
||||||
exit 0 ;;
|
|
||||||
F301:UNIX_System_V:*:*)
|
|
||||||
echo f301-fujitsu-uxpv`echo $UNAME_RELEASE | sed 's/ .*//'`
|
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
hp300:OpenBSD:*:*)
|
hp300:OpenBSD:*:*)
|
||||||
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
echo m68k-unknown-openbsd${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:BSD/386:*:* | i?86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
|
i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
sparc*:BSD/OS:*:*)
|
sparc*:BSD/OS:*:*)
|
||||||
@@ -627,6 +729,9 @@ EOF
|
|||||||
i*:MINGW*:*)
|
i*:MINGW*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-mingw32
|
echo ${UNAME_MACHINE}-pc-mingw32
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
i*:PW*:*)
|
||||||
|
echo ${UNAME_MACHINE}-pc-pw32
|
||||||
|
exit 0 ;;
|
||||||
i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
|
i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
|
||||||
# How do we know it's Interix rather than the generic POSIX subsystem?
|
# How do we know it's Interix rather than the generic POSIX subsystem?
|
||||||
# It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
|
# It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
|
||||||
@@ -645,56 +750,39 @@ EOF
|
|||||||
*:GNU:*:*)
|
*:GNU:*:*)
|
||||||
echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
|
echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
*:Linux:*:*)
|
i*86:Minix:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-pc-minix
|
||||||
# The BFD linker knows what the default object file format is, so
|
exit 0 ;;
|
||||||
# first see if it will tell us. cd to the root directory to prevent
|
arm*:Linux:*:*)
|
||||||
# problems with other programs or directories called `ld' in the path.
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
ld_help_string=`cd /; ld --help 2>&1`
|
exit 0 ;;
|
||||||
ld_supported_emulations=`echo $ld_help_string \
|
ia64:Linux:*:*)
|
||||||
| sed -ne '/supported emulations:/!d
|
echo ${UNAME_MACHINE}-unknown-linux
|
||||||
s/[ ][ ]*/ /g
|
exit 0 ;;
|
||||||
s/.*supported emulations: *//
|
m68*:Linux:*:*)
|
||||||
s/ .*//
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
p'`
|
exit 0 ;;
|
||||||
case "$ld_supported_emulations" in
|
mips:Linux:*:*)
|
||||||
*ia64)
|
cat >$dummy.c <<EOF
|
||||||
echo "${UNAME_MACHINE}-unknown-linux"
|
#ifdef __cplusplus
|
||||||
exit 0
|
#include <stdio.h> /* for printf() prototype */
|
||||||
|
int main (int argc, char *argv[]) {
|
||||||
|
#else
|
||||||
|
int main (argc, argv) int argc; char *argv[]; {
|
||||||
|
#endif
|
||||||
|
#ifdef __MIPSEB__
|
||||||
|
printf ("%s-unknown-linux-gnu\n", argv[1]);
|
||||||
|
#endif
|
||||||
|
#ifdef __MIPSEL__
|
||||||
|
printf ("%sel-unknown-linux-gnu\n", argv[1]);
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm -f $dummy.c $dummy && exit 0
|
||||||
|
rm -f $dummy.c $dummy
|
||||||
;;
|
;;
|
||||||
i?86linux)
|
ppc:Linux:*:*)
|
||||||
echo "${UNAME_MACHINE}-pc-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
elf_i?86)
|
|
||||||
echo "${UNAME_MACHINE}-pc-linux"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
i?86coff)
|
|
||||||
echo "${UNAME_MACHINE}-pc-linux-gnucoff"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
sparclinux)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
armlinux)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
elf32arm*)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuoldld"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
armelf_linux*)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnu"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
m68klinux)
|
|
||||||
echo "${UNAME_MACHINE}-unknown-linux-gnuaout"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
elf32ppc | elf32ppclinux)
|
|
||||||
# Determine Lib Version
|
# Determine Lib Version
|
||||||
cat >$dummy.c <<EOF
|
cat >$dummy.c <<EOF
|
||||||
#include <features.h>
|
#include <features.h>
|
||||||
@@ -709,7 +797,7 @@ main(argc, argv)
|
|||||||
#if defined(__GLIBC__)
|
#if defined(__GLIBC__)
|
||||||
printf("%s %s\n", __libc_version, __libc_release);
|
printf("%s %s\n", __libc_version, __libc_release);
|
||||||
#else
|
#else
|
||||||
printf("unkown\n");
|
printf("unknown\n");
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -718,22 +806,16 @@ EOF
|
|||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null
|
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null
|
||||||
if test "$?" = 0 ; then
|
if test "$?" = 0 ; then
|
||||||
./$dummy | grep 1\.99 > /dev/null
|
./$dummy | grep 1\.99 > /dev/null
|
||||||
if test "$?" = 0 ; then
|
if test "$?" = 0 ; then LIBC="libc1" ; fi
|
||||||
LIBC="libc1"
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
echo powerpc-unknown-linux-gnu${LIBC}
|
echo powerpc-unknown-linux-gnu${LIBC}
|
||||||
exit 0
|
exit 0 ;;
|
||||||
;;
|
alpha:Linux:*:*)
|
||||||
esac
|
|
||||||
|
|
||||||
if test "${UNAME_MACHINE}" = "alpha" ; then
|
|
||||||
cat <<EOF >$dummy.s
|
cat <<EOF >$dummy.s
|
||||||
.data
|
.data
|
||||||
\$Lformat:
|
\$Lformat:
|
||||||
.byte 37,100,45,37,120,10,0 # "%d-%x\n"
|
.byte 37,100,45,37,120,10,0 # "%d-%x\n"
|
||||||
|
|
||||||
.text
|
.text
|
||||||
.globl main
|
.globl main
|
||||||
.align 4
|
.align 4
|
||||||
@@ -758,26 +840,13 @@ EOF
|
|||||||
$CC_FOR_BUILD $dummy.s -o $dummy 2>/dev/null
|
$CC_FOR_BUILD $dummy.s -o $dummy 2>/dev/null
|
||||||
if test "$?" = 0 ; then
|
if test "$?" = 0 ; then
|
||||||
case `./$dummy` in
|
case `./$dummy` in
|
||||||
0-0)
|
0-0) UNAME_MACHINE="alpha" ;;
|
||||||
UNAME_MACHINE="alpha"
|
1-0) UNAME_MACHINE="alphaev5" ;;
|
||||||
;;
|
1-1) UNAME_MACHINE="alphaev56" ;;
|
||||||
1-0)
|
1-101) UNAME_MACHINE="alphapca56" ;;
|
||||||
UNAME_MACHINE="alphaev5"
|
2-303) UNAME_MACHINE="alphaev6" ;;
|
||||||
;;
|
2-307) UNAME_MACHINE="alphaev67" ;;
|
||||||
1-1)
|
|
||||||
UNAME_MACHINE="alphaev56"
|
|
||||||
;;
|
|
||||||
1-101)
|
|
||||||
UNAME_MACHINE="alphapca56"
|
|
||||||
;;
|
|
||||||
2-303)
|
|
||||||
UNAME_MACHINE="alphaev6"
|
|
||||||
;;
|
|
||||||
2-307)
|
|
||||||
UNAME_MACHINE="alphaev67"
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
|
|
||||||
objdump --private-headers $dummy | \
|
objdump --private-headers $dummy | \
|
||||||
grep ld.so.1 > /dev/null
|
grep ld.so.1 > /dev/null
|
||||||
if test "$?" = 0 ; then
|
if test "$?" = 0 ; then
|
||||||
@@ -785,39 +854,62 @@ EOF
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
rm -f $dummy.s $dummy
|
rm -f $dummy.s $dummy
|
||||||
echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} ; exit 0
|
echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
|
||||||
elif test "${UNAME_MACHINE}" = "mips" ; then
|
exit 0 ;;
|
||||||
cat >$dummy.c <<EOF
|
parisc:Linux:*:* | hppa:Linux:*:*)
|
||||||
#ifdef __cplusplus
|
# Look for CPU level
|
||||||
#include <stdio.h> /* for printf() prototype */
|
case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
|
||||||
int main (int argc, char *argv[]) {
|
PA7*) echo hppa1.1-unknown-linux-gnu ;;
|
||||||
#else
|
PA8*) echo hppa2.0-unknown-linux-gnu ;;
|
||||||
int main (argc, argv) int argc; char *argv[]; {
|
*) echo hppa-unknown-linux-gnu ;;
|
||||||
#endif
|
esac
|
||||||
#ifdef __MIPSEB__
|
exit 0 ;;
|
||||||
printf ("%s-unknown-linux-gnu\n", argv[1]);
|
parisc64:Linux:*:* | hppa64:Linux:*:*)
|
||||||
#endif
|
echo hppa64-unknown-linux-gnu
|
||||||
#ifdef __MIPSEL__
|
exit 0 ;;
|
||||||
printf ("%sel-unknown-linux-gnu\n", argv[1]);
|
s390:Linux:*:* | s390x:Linux:*:*)
|
||||||
#endif
|
echo ${UNAME_MACHINE}-ibm-linux
|
||||||
return 0;
|
exit 0 ;;
|
||||||
}
|
sh*:Linux:*:*)
|
||||||
EOF
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm $dummy.c $dummy && exit 0
|
exit 0 ;;
|
||||||
rm -f $dummy.c $dummy
|
sparc:Linux:*:* | sparc64:Linux:*:*)
|
||||||
elif test "${UNAME_MACHINE}" = "s390"; then
|
echo ${UNAME_MACHINE}-unknown-linux-gnu
|
||||||
echo s390-ibm-linux && exit 0
|
exit 0 ;;
|
||||||
else
|
x86_64:Linux:*:*)
|
||||||
|
echo x86_64-unknown-linux-gnu
|
||||||
|
exit 0 ;;
|
||||||
|
i*86:Linux:*:*)
|
||||||
|
# The BFD linker knows what the default object file format is, so
|
||||||
|
# first see if it will tell us. cd to the root directory to prevent
|
||||||
|
# problems with other programs or directories called `ld' in the path.
|
||||||
|
ld_supported_emulations=`cd /; ld --help 2>&1 \
|
||||||
|
| sed -ne '/supported emulations:/!d
|
||||||
|
s/[ ][ ]*/ /g
|
||||||
|
s/.*supported emulations: *//
|
||||||
|
s/ .*//
|
||||||
|
p'`
|
||||||
|
case "$ld_supported_emulations" in
|
||||||
|
i*86linux)
|
||||||
|
echo "${UNAME_MACHINE}-pc-linux-gnuaout"
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
elf_i*86)
|
||||||
|
TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
|
||||||
|
;;
|
||||||
|
i*86coff)
|
||||||
|
echo "${UNAME_MACHINE}-pc-linux-gnucoff"
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
# Either a pre-BFD a.out linker (linux-gnuoldld)
|
# Either a pre-BFD a.out linker (linux-gnuoldld)
|
||||||
# or one that does not give us useful --help.
|
# or one that does not give us useful --help.
|
||||||
# GCC wants to distinguish between linux-gnuoldld and linux-gnuaout.
|
# GCC wants to distinguish between linux-gnuoldld and linux-gnuaout.
|
||||||
# If ld does not provide *any* "supported emulations:"
|
# If ld does not provide *any* "supported emulations:"
|
||||||
# that means it is gnuoldld.
|
# that means it is gnuoldld.
|
||||||
echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations:"
|
test -z "$ld_supported_emulations" && echo "${UNAME_MACHINE}-pc-linux-gnuoldld" && exit 0
|
||||||
test $? != 0 && echo "${UNAME_MACHINE}-pc-linux-gnuoldld" && exit 0
|
|
||||||
|
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
i?86)
|
i*86)
|
||||||
VENDOR=pc;
|
VENDOR=pc;
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
@@ -849,15 +941,16 @@ EOF
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy "${UNAME_MACHINE}" && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
fi ;;
|
test x"${TENTATIVE}" != x && echo "${TENTATIVE}" && exit 0
|
||||||
|
;;
|
||||||
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. earlier versions
|
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. earlier versions
|
||||||
# are messed up and put the nodename in both sysname and nodename.
|
# are messed up and put the nodename in both sysname and nodename.
|
||||||
i?86:DYNIX/ptx:4*:*)
|
i*86:DYNIX/ptx:4*:*)
|
||||||
echo i386-sequent-sysv4
|
echo i386-sequent-sysv4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:UNIX_SV:4.2MP:2.*)
|
i*86:UNIX_SV:4.2MP:2.*)
|
||||||
# Unixware is an offshoot of SVR4, but it has its own version
|
# Unixware is an offshoot of SVR4, but it has its own version
|
||||||
# number series starting with 2...
|
# number series starting with 2...
|
||||||
# I am not positive that other SVR4 systems won't match this,
|
# I am not positive that other SVR4 systems won't match this,
|
||||||
@@ -865,7 +958,7 @@ EOF
|
|||||||
# Use sysv4.2uw... so that sysv4* matches it.
|
# Use sysv4.2uw... so that sysv4* matches it.
|
||||||
echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
|
echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*:4.*:* | i?86:SYSTEM_V:4.*:*)
|
i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
|
||||||
UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
|
UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
|
||||||
if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
|
if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
|
||||||
echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
|
echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
|
||||||
@@ -873,7 +966,7 @@ EOF
|
|||||||
echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
|
echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*:5:7*)
|
i*86:*:5:7*)
|
||||||
# Fixed at (any) Pentium or better
|
# Fixed at (any) Pentium or better
|
||||||
UNAME_MACHINE=i586
|
UNAME_MACHINE=i586
|
||||||
if [ ${UNAME_SYSTEM} = "UnixWare" ] ; then
|
if [ ${UNAME_SYSTEM} = "UnixWare" ] ; then
|
||||||
@@ -882,7 +975,7 @@ EOF
|
|||||||
echo ${UNAME_MACHINE}-pc-sysv${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-pc-sysv${UNAME_RELEASE}
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*:3.2:*)
|
i*86:*:3.2:*)
|
||||||
if test -f /usr/options/cb.name; then
|
if test -f /usr/options/cb.name; then
|
||||||
UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
|
UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
|
||||||
echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
|
echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
|
||||||
@@ -900,7 +993,7 @@ EOF
|
|||||||
echo ${UNAME_MACHINE}-pc-sysv32
|
echo ${UNAME_MACHINE}-pc-sysv32
|
||||||
fi
|
fi
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:*DOS:*:*)
|
i*86:*DOS:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-msdosdjgpp
|
echo ${UNAME_MACHINE}-pc-msdosdjgpp
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
pc:*:*:*)
|
pc:*:*:*)
|
||||||
@@ -928,7 +1021,7 @@ EOF
|
|||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
M68*:*:R3V[567]*:*)
|
M68*:*:R3V[567]*:*)
|
||||||
test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;;
|
test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;;
|
||||||
3[34]??:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 4850:*:4.0:3.0)
|
3[34]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 4850:*:4.0:3.0)
|
||||||
OS_REL=''
|
OS_REL=''
|
||||||
test -r /etc/.relid \
|
test -r /etc/.relid \
|
||||||
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
|
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
|
||||||
@@ -939,21 +1032,24 @@ EOF
|
|||||||
3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
|
3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
|
||||||
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
|
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
|
||||||
&& echo i486-ncr-sysv4 && exit 0 ;;
|
&& echo i486-ncr-sysv4 && exit 0 ;;
|
||||||
m68*:LynxOS:2.*:*)
|
m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
|
||||||
echo m68k-unknown-lynxos${UNAME_RELEASE}
|
echo m68k-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
mc68030:UNIX_System_V:4.*:*)
|
mc68030:UNIX_System_V:4.*:*)
|
||||||
echo m68k-atari-sysv4
|
echo m68k-atari-sysv4
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
i?86:LynxOS:2.*:* | i?86:LynxOS:3.[01]*:*)
|
i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*)
|
||||||
echo i386-unknown-lynxos${UNAME_RELEASE}
|
echo i386-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
TSUNAMI:LynxOS:2.*:*)
|
TSUNAMI:LynxOS:2.*:*)
|
||||||
echo sparc-unknown-lynxos${UNAME_RELEASE}
|
echo sparc-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
rs6000:LynxOS:2.*:* | PowerPC:LynxOS:2.*:*)
|
rs6000:LynxOS:2.*:*)
|
||||||
echo rs6000-unknown-lynxos${UNAME_RELEASE}
|
echo rs6000-unknown-lynxos${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*)
|
||||||
|
echo powerpc-unknown-lynxos${UNAME_RELEASE}
|
||||||
|
exit 0 ;;
|
||||||
SM[BE]S:UNIX_SV:*:*)
|
SM[BE]S:UNIX_SV:*:*)
|
||||||
echo mips-dde-sysv${UNAME_RELEASE}
|
echo mips-dde-sysv${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
@@ -987,7 +1083,7 @@ EOF
|
|||||||
mc68*:A/UX:*:*)
|
mc68*:A/UX:*:*)
|
||||||
echo m68k-apple-aux${UNAME_RELEASE}
|
echo m68k-apple-aux${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
news*:NEWS-OS:*:6*)
|
news*:NEWS-OS:6*:*)
|
||||||
echo mips-sony-newsos6
|
echo mips-sony-newsos6
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
|
R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
|
||||||
@@ -1030,15 +1126,52 @@ EOF
|
|||||||
*:QNX:*:4*)
|
*:QNX:*:4*)
|
||||||
echo i386-pc-qnx
|
echo i386-pc-qnx
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
NSR-W:NONSTOP_KERNEL:*:*)
|
NSR-[KW]:NONSTOP_KERNEL:*:*)
|
||||||
echo nsr-tandem-nsk${UNAME_RELEASE}
|
echo nsr-tandem-nsk${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
*:NonStop-UX:*:*)
|
||||||
|
echo mips-compaq-nonstopux
|
||||||
|
exit 0 ;;
|
||||||
BS2000:POSIX*:*:*)
|
BS2000:POSIX*:*:*)
|
||||||
echo bs2000-siemens-sysv
|
echo bs2000-siemens-sysv
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
DS/*:UNIX_System_V:*:*)
|
DS/*:UNIX_System_V:*:*)
|
||||||
echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
|
||||||
exit 0 ;;
|
exit 0 ;;
|
||||||
|
*:Plan9:*:*)
|
||||||
|
# "uname -m" is not consistent, so use $cputype instead. 386
|
||||||
|
# is converted to i386 for consistency with other x86
|
||||||
|
# operating systems.
|
||||||
|
if test "$cputype" = "386"; then
|
||||||
|
UNAME_MACHINE=i386
|
||||||
|
else
|
||||||
|
UNAME_MACHINE="$cputype"
|
||||||
|
fi
|
||||||
|
echo ${UNAME_MACHINE}-unknown-plan9
|
||||||
|
exit 0 ;;
|
||||||
|
i*86:OS/2:*:*)
|
||||||
|
# If we were able to find `uname', then EMX Unix compatibility
|
||||||
|
# is probably installed.
|
||||||
|
echo ${UNAME_MACHINE}-pc-os2-emx
|
||||||
|
exit 0 ;;
|
||||||
|
*:TOPS-10:*:*)
|
||||||
|
echo pdp10-unknown-tops10
|
||||||
|
exit 0 ;;
|
||||||
|
*:TENEX:*:*)
|
||||||
|
echo pdp10-unknown-tenex
|
||||||
|
exit 0 ;;
|
||||||
|
KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
|
||||||
|
echo pdp10-dec-tops20
|
||||||
|
exit 0 ;;
|
||||||
|
XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
|
||||||
|
echo pdp10-xkl-tops20
|
||||||
|
exit 0 ;;
|
||||||
|
*:TOPS-20:*:*)
|
||||||
|
echo pdp10-unknown-tops20
|
||||||
|
exit 0 ;;
|
||||||
|
*:ITS:*:*)
|
||||||
|
echo pdp10-unknown-its
|
||||||
|
exit 0 ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
#echo '(No uname command or uname output not recognized.)' 1>&2
|
#echo '(No uname command or uname output not recognized.)' 1>&2
|
||||||
@@ -1131,7 +1264,20 @@ main ()
|
|||||||
|
|
||||||
#if defined (vax)
|
#if defined (vax)
|
||||||
# if !defined (ultrix)
|
# if !defined (ultrix)
|
||||||
|
# include <sys/param.h>
|
||||||
|
# if defined (BSD)
|
||||||
|
# if BSD == 43
|
||||||
|
printf ("vax-dec-bsd4.3\n"); exit (0);
|
||||||
|
# else
|
||||||
|
# if BSD == 199006
|
||||||
|
printf ("vax-dec-bsd4.3reno\n"); exit (0);
|
||||||
|
# else
|
||||||
printf ("vax-dec-bsd\n"); exit (0);
|
printf ("vax-dec-bsd\n"); exit (0);
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
printf ("vax-dec-bsd\n"); exit (0);
|
||||||
|
# endif
|
||||||
# else
|
# else
|
||||||
printf ("vax-dec-ultrix\n"); exit (0);
|
printf ("vax-dec-ultrix\n"); exit (0);
|
||||||
# endif
|
# endif
|
||||||
@@ -1145,7 +1291,7 @@ main ()
|
|||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy && rm $dummy.c $dummy && exit 0
|
$CC_FOR_BUILD $dummy.c -o $dummy 2>/dev/null && ./$dummy && rm -f $dummy.c $dummy && exit 0
|
||||||
rm -f $dummy.c $dummy
|
rm -f $dummy.c $dummy
|
||||||
|
|
||||||
# Apollos put the system type in the environment.
|
# Apollos put the system type in the environment.
|
||||||
@@ -1178,6 +1324,48 @@ then
|
|||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#echo '(Unable to guess system type)' 1>&2
|
cat >&2 <<EOF
|
||||||
|
$0: unable to guess system type
|
||||||
|
|
||||||
|
This script, last modified $timestamp, has failed to recognize
|
||||||
|
the operating system you are using. It is advised that you
|
||||||
|
download the most up to date version of the config scripts from
|
||||||
|
|
||||||
|
ftp://ftp.gnu.org/pub/gnu/config/
|
||||||
|
|
||||||
|
If the version you run ($0) is already up to date, please
|
||||||
|
send the following data and any information you think might be
|
||||||
|
pertinent to <config-patches@gnu.org> in order to provide the needed
|
||||||
|
information to handle your system.
|
||||||
|
|
||||||
|
config.guess timestamp = $timestamp
|
||||||
|
|
||||||
|
uname -m = `(uname -m) 2>/dev/null || echo unknown`
|
||||||
|
uname -r = `(uname -r) 2>/dev/null || echo unknown`
|
||||||
|
uname -s = `(uname -s) 2>/dev/null || echo unknown`
|
||||||
|
uname -v = `(uname -v) 2>/dev/null || echo unknown`
|
||||||
|
|
||||||
|
/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
|
||||||
|
/bin/uname -X = `(/bin/uname -X) 2>/dev/null`
|
||||||
|
|
||||||
|
hostinfo = `(hostinfo) 2>/dev/null`
|
||||||
|
/bin/universe = `(/bin/universe) 2>/dev/null`
|
||||||
|
/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null`
|
||||||
|
/bin/arch = `(/bin/arch) 2>/dev/null`
|
||||||
|
/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
|
||||||
|
/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
|
||||||
|
|
||||||
|
UNAME_MACHINE = ${UNAME_MACHINE}
|
||||||
|
UNAME_RELEASE = ${UNAME_RELEASE}
|
||||||
|
UNAME_SYSTEM = ${UNAME_SYSTEM}
|
||||||
|
UNAME_VERSION = ${UNAME_VERSION}
|
||||||
|
EOF
|
||||||
|
|
||||||
exit 1
|
exit 1
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "timestamp='"
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d"
|
||||||
|
# time-stamp-end: "'"
|
||||||
|
# End:
|
||||||
|
230
config.sub
vendored
230
config.sub
vendored
@@ -1,8 +1,10 @@
|
|||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Configuration validation subroutine script, version 1.1.
|
# Configuration validation subroutine script.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
# Free Software Foundation, Inc.
|
# Free Software Foundation, Inc.
|
||||||
#
|
|
||||||
|
timestamp='2001-04-20'
|
||||||
|
|
||||||
# This file is (in principle) common to ALL GNU software.
|
# This file is (in principle) common to ALL GNU software.
|
||||||
# The presence of a machine in this file suggests that SOME GNU software
|
# The presence of a machine in this file suggests that SOME GNU software
|
||||||
# can handle that machine. It does not imply ALL GNU software can.
|
# can handle that machine. It does not imply ALL GNU software can.
|
||||||
@@ -27,7 +29,6 @@
|
|||||||
# configuration script generated by Autoconf, you may include it under
|
# configuration script generated by Autoconf, you may include it under
|
||||||
# the same distribution terms that you use for the rest of that program.
|
# the same distribution terms that you use for the rest of that program.
|
||||||
|
|
||||||
# Written by Per Bothner <bothner@cygnus.com>.
|
|
||||||
# Please send patches to <config-patches@gnu.org>.
|
# Please send patches to <config-patches@gnu.org>.
|
||||||
#
|
#
|
||||||
# Configuration subroutine to validate and canonicalize a configuration type.
|
# Configuration subroutine to validate and canonicalize a configuration type.
|
||||||
@@ -50,30 +51,73 @@
|
|||||||
# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
|
# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
|
||||||
# It is wrong to echo any other type of specification.
|
# It is wrong to echo any other type of specification.
|
||||||
|
|
||||||
if [ x$1 = x ]
|
me=`echo "$0" | sed -e 's,.*/,,'`
|
||||||
then
|
|
||||||
echo Configuration name missing. 1>&2
|
|
||||||
echo "Usage: $0 CPU-MFR-OPSYS" 1>&2
|
|
||||||
echo "or $0 ALIAS" 1>&2
|
|
||||||
echo where ALIAS is a recognized configuration type. 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# First pass through any local machine types.
|
usage="\
|
||||||
|
Usage: $0 [OPTION] CPU-MFR-OPSYS
|
||||||
|
$0 [OPTION] ALIAS
|
||||||
|
|
||||||
|
Canonicalize a configuration name.
|
||||||
|
|
||||||
|
Operation modes:
|
||||||
|
-h, --help print this help, then exit
|
||||||
|
-t, --time-stamp print date of last modification, then exit
|
||||||
|
-v, --version print version number, then exit
|
||||||
|
|
||||||
|
Report bugs and patches to <config-patches@gnu.org>."
|
||||||
|
|
||||||
|
version="\
|
||||||
|
GNU config.sub ($timestamp)
|
||||||
|
|
||||||
|
Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
|
||||||
|
Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This is free software; see the source for copying conditions. There is NO
|
||||||
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
|
||||||
|
help="
|
||||||
|
Try \`$me --help' for more information."
|
||||||
|
|
||||||
|
# Parse command line
|
||||||
|
while test $# -gt 0 ; do
|
||||||
case $1 in
|
case $1 in
|
||||||
|
--time-stamp | --time* | -t )
|
||||||
|
echo "$timestamp" ; exit 0 ;;
|
||||||
|
--version | -v )
|
||||||
|
echo "$version" ; exit 0 ;;
|
||||||
|
--help | --h* | -h )
|
||||||
|
echo "$usage"; exit 0 ;;
|
||||||
|
-- ) # Stop option processing
|
||||||
|
shift; break ;;
|
||||||
|
- ) # Use stdin as input.
|
||||||
|
break ;;
|
||||||
|
-* )
|
||||||
|
echo "$me: invalid option $1$help"
|
||||||
|
exit 1 ;;
|
||||||
|
|
||||||
*local*)
|
*local*)
|
||||||
|
# First pass through any local machine types.
|
||||||
echo $1
|
echo $1
|
||||||
exit 0
|
exit 0;;
|
||||||
;;
|
|
||||||
* )
|
* )
|
||||||
;;
|
break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
case $# in
|
||||||
|
0) echo "$me: missing argument$help" >&2
|
||||||
|
exit 1;;
|
||||||
|
1) ;;
|
||||||
|
*) echo "$me: too many arguments$help" >&2
|
||||||
|
exit 1;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
|
# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
|
||||||
# Here we must recognize all the valid KERNEL-OS combinations.
|
# Here we must recognize all the valid KERNEL-OS combinations.
|
||||||
maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
|
maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
|
||||||
case $maybe_os in
|
case $maybe_os in
|
||||||
nto-qnx* | linux-gnu*)
|
nto-qnx* | linux-gnu* | storm-chaos* | os2-emx*)
|
||||||
os=-$maybe_os
|
os=-$maybe_os
|
||||||
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
|
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
|
||||||
;;
|
;;
|
||||||
@@ -99,7 +143,7 @@ case $os in
|
|||||||
-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
|
-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
|
||||||
-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
|
-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
|
||||||
-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
|
-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
|
||||||
-apple)
|
-apple | -axis)
|
||||||
os=
|
os=
|
||||||
basic_machine=$1
|
basic_machine=$1
|
||||||
;;
|
;;
|
||||||
@@ -171,30 +215,40 @@ esac
|
|||||||
case $basic_machine in
|
case $basic_machine in
|
||||||
# Recognize the basic CPU types without company name.
|
# Recognize the basic CPU types without company name.
|
||||||
# Some are omitted here because they have special meanings below.
|
# Some are omitted here because they have special meanings below.
|
||||||
tahoe | i860 | ia64 | m32r | m68k | m68000 | m88k | ns32k | arc | arm \
|
tahoe | i860 | ia64 | m32r | m68k | m68000 | m88k | ns32k | arc \
|
||||||
| arme[lb] | pyramid | mn10200 | mn10300 | tron | a29k \
|
| arm | arme[lb] | arm[bl]e | armv[2345] | armv[345][lb] | strongarm | xscale \
|
||||||
|
| pyramid | mn10200 | mn10300 | tron | a29k \
|
||||||
| 580 | i960 | h8300 \
|
| 580 | i960 | h8300 \
|
||||||
| x86 | ppcbe | mipsbe | mipsle | shbe | shle | armbe | armle \
|
| x86 | ppcbe | mipsbe | mipsle | shbe | shle \
|
||||||
| hppa | hppa1.0 | hppa1.1 | hppa2.0 | hppa2.0w | hppa2.0n \
|
| hppa | hppa1.0 | hppa1.1 | hppa2.0 | hppa2.0w | hppa2.0n \
|
||||||
| hppa64 \
|
| hppa64 \
|
||||||
| alpha | alphaev[4-8] | alphaev56 | alphapca5[67] \
|
| alpha | alphaev[4-8] | alphaev56 | alphapca5[67] \
|
||||||
| alphaev6[78] \
|
| alphaev6[78] \
|
||||||
| we32k | ns16k | clipper | i370 | sh | powerpc | powerpcle \
|
| we32k | ns16k | clipper | i370 | sh | sh[34] \
|
||||||
| 1750a | dsp16xx | pdp11 | mips16 | mips64 | mipsel | mips64el \
|
| powerpc | powerpcle \
|
||||||
|
| 1750a | dsp16xx | pdp10 | pdp11 \
|
||||||
|
| mips16 | mips64 | mipsel | mips64el \
|
||||||
| mips64orion | mips64orionel | mipstx39 | mipstx39el \
|
| mips64orion | mips64orionel | mipstx39 | mipstx39el \
|
||||||
| mips64vr4300 | mips64vr4300el | mips64vr4100 | mips64vr4100el \
|
| mips64vr4300 | mips64vr4300el | mips64vr4100 | mips64vr4100el \
|
||||||
| mips64vr5000 | miprs64vr5000el | mcore \
|
| mips64vr5000 | miprs64vr5000el | mcore | s390 | s390x \
|
||||||
| sparc | sparclet | sparclite | sparc64 | sparcv9 | v850 | c4x \
|
| sparc | sparclet | sparclite | sparc64 | sparcv9 | sparcv9b \
|
||||||
| thumb | d10v | fr30 | avr)
|
| v850 | c4x \
|
||||||
|
| thumb | d10v | d30v | fr30 | avr | openrisc | tic80 \
|
||||||
|
| pj | pjl | h8500)
|
||||||
basic_machine=$basic_machine-unknown
|
basic_machine=$basic_machine-unknown
|
||||||
;;
|
;;
|
||||||
m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | z8k | v70 | h8500 | w65 | pj | pjl)
|
m6811 | m68hc11 | m6812 | m68hc12)
|
||||||
|
# Motorola 68HC11/12.
|
||||||
|
basic_machine=$basic_machine-unknown
|
||||||
|
os=-none
|
||||||
|
;;
|
||||||
|
m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | z8k | v70 | w65)
|
||||||
;;
|
;;
|
||||||
|
|
||||||
# We use `pc' rather than `unknown'
|
# We use `pc' rather than `unknown'
|
||||||
# because (1) that's what they normally are, and
|
# because (1) that's what they normally are, and
|
||||||
# (2) the word "unknown" tends to confuse beginning users.
|
# (2) the word "unknown" tends to confuse beginning users.
|
||||||
i[34567]86)
|
i*86 | x86_64)
|
||||||
basic_machine=$basic_machine-pc
|
basic_machine=$basic_machine-pc
|
||||||
;;
|
;;
|
||||||
# Object if more than one company name word.
|
# Object if more than one company name word.
|
||||||
@@ -204,27 +258,30 @@ case $basic_machine in
|
|||||||
;;
|
;;
|
||||||
# Recognize the basic CPU types with company name.
|
# Recognize the basic CPU types with company name.
|
||||||
# FIXME: clean up the formatting here.
|
# FIXME: clean up the formatting here.
|
||||||
vax-* | tahoe-* | i[34567]86-* | i860-* | ia64-* | m32r-* | m68k-* | m68000-* \
|
vax-* | tahoe-* | i*86-* | i860-* | ia64-* | m32r-* | m68k-* | m68000-* \
|
||||||
| m88k-* | sparc-* | ns32k-* | fx80-* | arc-* | arm-* | c[123]* \
|
| m88k-* | sparc-* | ns32k-* | fx80-* | arc-* | c[123]* \
|
||||||
|
| arm-* | armbe-* | armle-* | armv*-* | strongarm-* | xscale-* \
|
||||||
| mips-* | pyramid-* | tron-* | a29k-* | romp-* | rs6000-* \
|
| mips-* | pyramid-* | tron-* | a29k-* | romp-* | rs6000-* \
|
||||||
| power-* | none-* | 580-* | cray2-* | h8300-* | h8500-* | i960-* \
|
| power-* | none-* | 580-* | cray2-* | h8300-* | h8500-* | i960-* \
|
||||||
| xmp-* | ymp-* \
|
| xmp-* | ymp-* \
|
||||||
| x86-* | ppcbe-* | mipsbe-* | mipsle-* | shbe-* | shle-* | armbe-* | armle-* \
|
| x86-* | ppcbe-* | mipsbe-* | mipsle-* | shbe-* | shle-* \
|
||||||
| hppa-* | hppa1.0-* | hppa1.1-* | hppa2.0-* | hppa2.0w-* \
|
| hppa-* | hppa1.0-* | hppa1.1-* | hppa2.0-* | hppa2.0w-* \
|
||||||
| hppa2.0n-* | hppa64-* \
|
| hppa2.0n-* | hppa64-* \
|
||||||
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphapca5[67]-* \
|
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphapca5[67]-* \
|
||||||
| alphaev6[78]-* \
|
| alphaev6[78]-* \
|
||||||
| we32k-* | cydra-* | ns16k-* | pn-* | np1-* | xps100-* \
|
| we32k-* | cydra-* | ns16k-* | pn-* | np1-* | xps100-* \
|
||||||
| clipper-* | orion-* \
|
| clipper-* | orion-* \
|
||||||
| sparclite-* | pdp11-* | sh-* | powerpc-* | powerpcle-* \
|
| sparclite-* | pdp10-* | pdp11-* | sh-* | powerpc-* | powerpcle-* \
|
||||||
| sparc64-* | sparcv9-* | sparc86x-* | mips16-* | mips64-* | mipsel-* \
|
| sparc64-* | sparcv9-* | sparcv9b-* | sparc86x-* \
|
||||||
|
| mips16-* | mips64-* | mipsel-* \
|
||||||
| mips64el-* | mips64orion-* | mips64orionel-* \
|
| mips64el-* | mips64orion-* | mips64orionel-* \
|
||||||
| mips64vr4100-* | mips64vr4100el-* | mips64vr4300-* | mips64vr4300el-* \
|
| mips64vr4100-* | mips64vr4100el-* | mips64vr4300-* | mips64vr4300el-* \
|
||||||
| mipstx39-* | mipstx39el-* | mcore-* \
|
| mipstx39-* | mipstx39el-* | mcore-* \
|
||||||
| f301-* | armv*-* | s390-* | sv1-* | t3e-* \
|
| f30[01]-* | f700-* | s390-* | s390x-* | sv1-* | t3e-* \
|
||||||
|
| [cjt]90-* \
|
||||||
| m88110-* | m680[01234]0-* | m683?2-* | m68360-* | z8k-* | d10v-* \
|
| m88110-* | m680[01234]0-* | m683?2-* | m68360-* | z8k-* | d10v-* \
|
||||||
| thumb-* | v850-* | d30v-* | tic30-* | c30-* | fr30-* \
|
| thumb-* | v850-* | d30v-* | tic30-* | tic80-* | c30-* | fr30-* \
|
||||||
| bs2000-*)
|
| bs2000-* | tic54x-* | c54x-* | x86_64-* | pj-* | pjl-*)
|
||||||
;;
|
;;
|
||||||
# Recognize the various machine names and aliases which stand
|
# Recognize the various machine names and aliases which stand
|
||||||
# for a CPU type and a company and sometimes even an OS.
|
# for a CPU type and a company and sometimes even an OS.
|
||||||
@@ -261,14 +318,14 @@ case $basic_machine in
|
|||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
amiga | amiga-*)
|
amiga | amiga-*)
|
||||||
basic_machine=m68k-cbm
|
basic_machine=m68k-unknown
|
||||||
;;
|
;;
|
||||||
amigaos | amigados)
|
amigaos | amigados)
|
||||||
basic_machine=m68k-cbm
|
basic_machine=m68k-unknown
|
||||||
os=-amigaos
|
os=-amigaos
|
||||||
;;
|
;;
|
||||||
amigaunix | amix)
|
amigaunix | amix)
|
||||||
basic_machine=m68k-cbm
|
basic_machine=m68k-unknown
|
||||||
os=-sysv4
|
os=-sysv4
|
||||||
;;
|
;;
|
||||||
apollo68)
|
apollo68)
|
||||||
@@ -315,13 +372,16 @@ case $basic_machine in
|
|||||||
basic_machine=cray2-cray
|
basic_machine=cray2-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
[ctj]90-cray)
|
[cjt]90)
|
||||||
basic_machine=c90-cray
|
basic_machine=${basic_machine}-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
crds | unos)
|
crds | unos)
|
||||||
basic_machine=m68k-crds
|
basic_machine=m68k-crds
|
||||||
;;
|
;;
|
||||||
|
cris | cris-* | etrax*)
|
||||||
|
basic_machine=cris-axis
|
||||||
|
;;
|
||||||
da30 | da30-*)
|
da30 | da30-*)
|
||||||
basic_machine=m68k-da30
|
basic_machine=m68k-da30
|
||||||
;;
|
;;
|
||||||
@@ -369,6 +429,10 @@ case $basic_machine in
|
|||||||
basic_machine=tron-gmicro
|
basic_machine=tron-gmicro
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
|
go32)
|
||||||
|
basic_machine=i386-pc
|
||||||
|
os=-go32
|
||||||
|
;;
|
||||||
h3050r* | hiux*)
|
h3050r* | hiux*)
|
||||||
basic_machine=hppa1.1-hitachi
|
basic_machine=hppa1.1-hitachi
|
||||||
os=-hiuxwe2
|
os=-hiuxwe2
|
||||||
@@ -444,19 +508,19 @@ case $basic_machine in
|
|||||||
basic_machine=i370-ibm
|
basic_machine=i370-ibm
|
||||||
;;
|
;;
|
||||||
# I'm not sure what "Sysv32" means. Should this be sysv3.2?
|
# I'm not sure what "Sysv32" means. Should this be sysv3.2?
|
||||||
i[34567]86v32)
|
i*86v32)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv32
|
os=-sysv32
|
||||||
;;
|
;;
|
||||||
i[34567]86v4*)
|
i*86v4*)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv4
|
os=-sysv4
|
||||||
;;
|
;;
|
||||||
i[34567]86v)
|
i*86v)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
i[34567]86sol2)
|
i*86sol2)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-solaris2
|
os=-solaris2
|
||||||
;;
|
;;
|
||||||
@@ -468,14 +532,6 @@ case $basic_machine in
|
|||||||
basic_machine=i386-unknown
|
basic_machine=i386-unknown
|
||||||
os=-vsta
|
os=-vsta
|
||||||
;;
|
;;
|
||||||
i386-go32 | go32)
|
|
||||||
basic_machine=i386-unknown
|
|
||||||
os=-go32
|
|
||||||
;;
|
|
||||||
i386-mingw32 | mingw32)
|
|
||||||
basic_machine=i386-unknown
|
|
||||||
os=-mingw32
|
|
||||||
;;
|
|
||||||
iris | iris4d)
|
iris | iris4d)
|
||||||
basic_machine=mips-sgi
|
basic_machine=mips-sgi
|
||||||
case $os in
|
case $os in
|
||||||
@@ -501,6 +557,10 @@ case $basic_machine in
|
|||||||
basic_machine=ns32k-utek
|
basic_machine=ns32k-utek
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
|
mingw32)
|
||||||
|
basic_machine=i386-pc
|
||||||
|
os=-mingw32
|
||||||
|
;;
|
||||||
miniframe)
|
miniframe)
|
||||||
basic_machine=m68000-convergent
|
basic_machine=m68000-convergent
|
||||||
;;
|
;;
|
||||||
@@ -531,7 +591,7 @@ case $basic_machine in
|
|||||||
os=-coff
|
os=-coff
|
||||||
;;
|
;;
|
||||||
msdos)
|
msdos)
|
||||||
basic_machine=i386-unknown
|
basic_machine=i386-pc
|
||||||
os=-msdos
|
os=-msdos
|
||||||
;;
|
;;
|
||||||
mvs)
|
mvs)
|
||||||
@@ -595,6 +655,10 @@ case $basic_machine in
|
|||||||
basic_machine=i960-intel
|
basic_machine=i960-intel
|
||||||
os=-mon960
|
os=-mon960
|
||||||
;;
|
;;
|
||||||
|
nonstopux)
|
||||||
|
basic_machine=mips-compaq
|
||||||
|
os=-nonstopux
|
||||||
|
;;
|
||||||
np1)
|
np1)
|
||||||
basic_machine=np1-gould
|
basic_machine=np1-gould
|
||||||
;;
|
;;
|
||||||
@@ -630,28 +694,28 @@ case $basic_machine in
|
|||||||
pc532 | pc532-*)
|
pc532 | pc532-*)
|
||||||
basic_machine=ns32k-pc532
|
basic_machine=ns32k-pc532
|
||||||
;;
|
;;
|
||||||
pentium | p5 | k5 | k6 | nexen)
|
pentium | p5 | k5 | k6 | nexgen)
|
||||||
basic_machine=i586-pc
|
basic_machine=i586-pc
|
||||||
;;
|
;;
|
||||||
pentiumpro | p6 | 6x86)
|
pentiumpro | p6 | 6x86 | athlon)
|
||||||
basic_machine=i686-pc
|
basic_machine=i686-pc
|
||||||
;;
|
;;
|
||||||
pentiumii | pentium2)
|
pentiumii | pentium2)
|
||||||
basic_machine=i786-pc
|
basic_machine=i686-pc
|
||||||
;;
|
;;
|
||||||
pentium-* | p5-* | k5-* | k6-* | nexen-*)
|
pentium-* | p5-* | k5-* | k6-* | nexgen-*)
|
||||||
basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
pentiumpro-* | p6-* | 6x86-*)
|
pentiumpro-* | p6-* | 6x86-* | athlon-*)
|
||||||
basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
pentiumii-* | pentium2-*)
|
pentiumii-* | pentium2-*)
|
||||||
basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
|
basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
pn)
|
pn)
|
||||||
basic_machine=pn-gould
|
basic_machine=pn-gould
|
||||||
;;
|
;;
|
||||||
power) basic_machine=rs6000-ibm
|
power) basic_machine=power-ibm
|
||||||
;;
|
;;
|
||||||
ppc) basic_machine=powerpc-unknown
|
ppc) basic_machine=powerpc-unknown
|
||||||
;;
|
;;
|
||||||
@@ -666,6 +730,10 @@ case $basic_machine in
|
|||||||
ps2)
|
ps2)
|
||||||
basic_machine=i386-ibm
|
basic_machine=i386-ibm
|
||||||
;;
|
;;
|
||||||
|
pw32)
|
||||||
|
basic_machine=i586-unknown
|
||||||
|
os=-pw32
|
||||||
|
;;
|
||||||
rom68k)
|
rom68k)
|
||||||
basic_machine=m68k-rom68k
|
basic_machine=m68k-rom68k
|
||||||
os=-coff
|
os=-coff
|
||||||
@@ -757,6 +825,10 @@ case $basic_machine in
|
|||||||
basic_machine=t3e-cray
|
basic_machine=t3e-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
|
tic54x | c54x*)
|
||||||
|
basic_machine=tic54x-unknown
|
||||||
|
os=-coff
|
||||||
|
;;
|
||||||
tx39)
|
tx39)
|
||||||
basic_machine=mipstx39-unknown
|
basic_machine=mipstx39-unknown
|
||||||
;;
|
;;
|
||||||
@@ -852,13 +924,20 @@ case $basic_machine in
|
|||||||
vax)
|
vax)
|
||||||
basic_machine=vax-dec
|
basic_machine=vax-dec
|
||||||
;;
|
;;
|
||||||
|
pdp10)
|
||||||
|
# there are many clones, so DEC is not a safe bet
|
||||||
|
basic_machine=pdp10-unknown
|
||||||
|
;;
|
||||||
pdp11)
|
pdp11)
|
||||||
basic_machine=pdp11-dec
|
basic_machine=pdp11-dec
|
||||||
;;
|
;;
|
||||||
we32k)
|
we32k)
|
||||||
basic_machine=we32k-att
|
basic_machine=we32k-att
|
||||||
;;
|
;;
|
||||||
sparc | sparcv9)
|
sh3 | sh4)
|
||||||
|
basic_machine=sh-unknown
|
||||||
|
;;
|
||||||
|
sparc | sparcv9 | sparcv9b)
|
||||||
basic_machine=sparc-sun
|
basic_machine=sparc-sun
|
||||||
;;
|
;;
|
||||||
cydra)
|
cydra)
|
||||||
@@ -880,6 +959,9 @@ case $basic_machine in
|
|||||||
basic_machine=c4x-none
|
basic_machine=c4x-none
|
||||||
os=-coff
|
os=-coff
|
||||||
;;
|
;;
|
||||||
|
*-unknown)
|
||||||
|
# Make sure to match an already-canonicalized machine name.
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
|
echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
@@ -939,12 +1021,13 @@ case $os in
|
|||||||
| -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
|
| -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
|
||||||
| -mingw32* | -linux-gnu* | -uxpv* | -beos* | -mpeix* | -udk* \
|
| -mingw32* | -linux-gnu* | -uxpv* | -beos* | -mpeix* | -udk* \
|
||||||
| -interix* | -uwin* | -rhapsody* | -darwin* | -opened* \
|
| -interix* | -uwin* | -rhapsody* | -darwin* | -opened* \
|
||||||
| -openstep* | -oskit*)
|
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
|
||||||
|
| -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* | -os2*)
|
||||||
# Remember, each alternative MUST END IN *, to match a version number.
|
# Remember, each alternative MUST END IN *, to match a version number.
|
||||||
;;
|
;;
|
||||||
-qnx*)
|
-qnx*)
|
||||||
case $basic_machine in
|
case $basic_machine in
|
||||||
x86-* | i[34567]86-*)
|
x86-* | i*86-*)
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
os=-nto$os
|
os=-nto$os
|
||||||
@@ -1000,7 +1083,7 @@ case $os in
|
|||||||
-ns2 )
|
-ns2 )
|
||||||
os=-nextstep2
|
os=-nextstep2
|
||||||
;;
|
;;
|
||||||
-nsk)
|
-nsk*)
|
||||||
os=-nsk
|
os=-nsk
|
||||||
;;
|
;;
|
||||||
# Preserve the version number of sinix5.
|
# Preserve the version number of sinix5.
|
||||||
@@ -1037,7 +1120,7 @@ case $os in
|
|||||||
-xenix)
|
-xenix)
|
||||||
os=-xenix
|
os=-xenix
|
||||||
;;
|
;;
|
||||||
-*mint | -*MiNT)
|
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
|
||||||
os=-mint
|
os=-mint
|
||||||
;;
|
;;
|
||||||
-none)
|
-none)
|
||||||
@@ -1071,6 +1154,9 @@ case $basic_machine in
|
|||||||
arm*-semi)
|
arm*-semi)
|
||||||
os=-aout
|
os=-aout
|
||||||
;;
|
;;
|
||||||
|
pdp10-*)
|
||||||
|
os=-tops20
|
||||||
|
;;
|
||||||
pdp11-*)
|
pdp11-*)
|
||||||
os=-none
|
os=-none
|
||||||
;;
|
;;
|
||||||
@@ -1179,7 +1265,7 @@ case $basic_machine in
|
|||||||
*-masscomp)
|
*-masscomp)
|
||||||
os=-rtu
|
os=-rtu
|
||||||
;;
|
;;
|
||||||
f301-fujitsu)
|
f30[01]-fujitsu | f700-fujitsu)
|
||||||
os=-uxpv
|
os=-uxpv
|
||||||
;;
|
;;
|
||||||
*-rom68k)
|
*-rom68k)
|
||||||
@@ -1257,7 +1343,7 @@ case $basic_machine in
|
|||||||
-mpw* | -macos*)
|
-mpw* | -macos*)
|
||||||
vendor=apple
|
vendor=apple
|
||||||
;;
|
;;
|
||||||
-*mint | -*MiNT)
|
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
|
||||||
vendor=atari
|
vendor=atari
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
@@ -1266,3 +1352,11 @@ case $basic_machine in
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
echo $basic_machine$os
|
echo $basic_machine$os
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "timestamp='"
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d"
|
||||||
|
# time-stamp-end: "'"
|
||||||
|
# End:
|
||||||
|
150
configure.in
150
configure.in
@@ -1,27 +1,45 @@
|
|||||||
dnl $Id$
|
dnl $Id$
|
||||||
dnl Process this file with autoconf to produce a configure script.
|
dnl Process this file with autoconf to produce a configure script.
|
||||||
AC_INIT(lib/urldata.h)
|
AC_INIT
|
||||||
|
AC_CONFIG_SRCDIR([lib/urldata.h])
|
||||||
AM_CONFIG_HEADER(config.h src/config.h)
|
AM_CONFIG_HEADER(config.h src/config.h)
|
||||||
|
|
||||||
VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h`
|
VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h`
|
||||||
AM_INIT_AUTOMAKE(curl,$VERSION)
|
AM_INIT_AUTOMAKE(curl,$VERSION)
|
||||||
AM_PROG_LIBTOOL
|
|
||||||
|
dnl
|
||||||
|
dnl we extract the numerical version for curl-config only
|
||||||
|
VERSIONNUM=`sed -ne 's/^#define LIBCURL_VERSION_NUM 0x\(.*\)/\1/p' ${srcdir}/include/curl/curl.h`
|
||||||
|
AC_SUBST(VERSIONNUM)
|
||||||
|
|
||||||
|
dnl Solaris pkgadd support definitions
|
||||||
|
PKGADD_PKG="HAXXcurl"
|
||||||
|
PKGADD_NAME="cURL - a client that groks URLs"
|
||||||
|
PKGADD_VENDOR="curl.haxx.se"
|
||||||
|
AC_SUBST(PKGADD_PKG)
|
||||||
|
AC_SUBST(PKGADD_NAME)
|
||||||
|
AC_SUBST(PKGADD_VENDOR)
|
||||||
|
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl Detect the canonical host and target build environment
|
dnl Detect the canonical host and target build environment
|
||||||
dnl
|
dnl
|
||||||
AC_CANONICAL_HOST
|
|
||||||
AC_CANONICAL_TARGET
|
|
||||||
|
|
||||||
dnl Checks for programs.
|
AC_CANONICAL_HOST
|
||||||
AC_PROG_CC
|
dnl Get system canonical name
|
||||||
|
AC_DEFINE_UNQUOTED(OS, "${host}")
|
||||||
|
|
||||||
dnl Check for AIX weirdos
|
dnl Check for AIX weirdos
|
||||||
AC_AIX
|
AC_AIX
|
||||||
|
|
||||||
|
dnl Checks for programs.
|
||||||
|
AC_PROG_CC
|
||||||
|
|
||||||
dnl check for how to do large files
|
dnl check for how to do large files
|
||||||
AC_SYS_LARGEFILE
|
AC_SYS_LARGEFILE
|
||||||
|
|
||||||
|
AM_PROG_LIBTOOL
|
||||||
|
|
||||||
dnl The install stuff has already been taken care of by the automake stuff
|
dnl The install stuff has already been taken care of by the automake stuff
|
||||||
dnl AC_PROG_INSTALL
|
dnl AC_PROG_INSTALL
|
||||||
AC_PROG_MAKE_SET
|
AC_PROG_MAKE_SET
|
||||||
@@ -46,8 +64,32 @@ AC_ARG_ENABLE(debug,
|
|||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
dnl ************************************************************
|
||||||
|
dnl check for "localhost", if it doesn't exist, we can't do the
|
||||||
|
dnl gethostbyname_r tests!
|
||||||
dnl
|
dnl
|
||||||
|
|
||||||
|
AC_DEFUN(CURL_CHECK_WORKING_RESOLVER,[
|
||||||
|
AC_MSG_CHECKING([if "localhost" resolves])
|
||||||
|
AC_TRY_RUN([
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main () {
|
||||||
|
struct hostent *h;
|
||||||
|
h = gethostbyname("localhost");
|
||||||
|
exit (h == NULL ? 1 : 0); }],[
|
||||||
|
AC_MSG_RESULT(yes)],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_ERROR([can't figure out gethostbyname_r() since localhost doesn't resolve])
|
||||||
|
|
||||||
|
]
|
||||||
|
)
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl ************************************************************
|
||||||
dnl check for working getaddrinfo()
|
dnl check for working getaddrinfo()
|
||||||
dnl
|
dnl
|
||||||
AC_DEFUN(CURL_CHECK_WORKING_GETADDRINFO,[
|
AC_DEFUN(CURL_CHECK_WORKING_GETADDRINFO,[
|
||||||
@@ -82,6 +124,9 @@ void main(void) {
|
|||||||
if test "$ac_cv_working_getaddrinfo" = "yes"; then
|
if test "$ac_cv_working_getaddrinfo" = "yes"; then
|
||||||
AC_DEFINE(HAVE_GETADDRINFO, 1, [Define if getaddrinfo exists and works])
|
AC_DEFINE(HAVE_GETADDRINFO, 1, [Define if getaddrinfo exists and works])
|
||||||
AC_DEFINE(ENABLE_IPV6, 1, [Define if you want to enable IPv6 support])
|
AC_DEFINE(ENABLE_IPV6, 1, [Define if you want to enable IPv6 support])
|
||||||
|
|
||||||
|
IPV6_ENABLED=1
|
||||||
|
AC_SUBST(IPV6_ENABLED)
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
@@ -397,7 +442,7 @@ dnl ucb lib?
|
|||||||
AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
AC_CHECK_FUNC(gethostname, , AC_CHECK_LIB(ucb, gethostname))
|
||||||
|
|
||||||
dnl dl lib?
|
dnl dl lib?
|
||||||
AC_CHECK_FUNC(dlopen, , AC_CHECK_LIB(dl, dlopen))
|
AC_CHECK_FUNC(dlclose, , AC_CHECK_LIB(dl, dlopen))
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the random seed preferences
|
dnl Check for the random seed preferences
|
||||||
@@ -506,6 +551,10 @@ then
|
|||||||
dnl add define KRB4
|
dnl add define KRB4
|
||||||
AC_DEFINE(KRB4)
|
AC_DEFINE(KRB4)
|
||||||
|
|
||||||
|
dnl substitute it too!
|
||||||
|
KRB4_ENABLED=1
|
||||||
|
AC_SUBST(KRB4_ENABLED)
|
||||||
|
|
||||||
dnl the krb4 stuff needs a strlcpy()
|
dnl the krb4 stuff needs a strlcpy()
|
||||||
AC_CHECK_FUNCS(strlcpy)
|
AC_CHECK_FUNCS(strlcpy)
|
||||||
|
|
||||||
@@ -515,6 +564,7 @@ else
|
|||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the presence of SSL libraries and headers
|
dnl Check for the presence of SSL libraries and headers
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -532,26 +582,43 @@ then
|
|||||||
AC_MSG_WARN(SSL/https support disabled)
|
AC_MSG_WARN(SSL/https support disabled)
|
||||||
else
|
else
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-ssl.
|
dnl Check for and handle argument to --with-ssl.
|
||||||
|
|
||||||
AC_MSG_CHECKING(where to look for SSL)
|
dnl save the pre-ssl check flags for a while
|
||||||
if test X"$OPT_SSL" = Xoff
|
CLEANLDFLAGS="$LDFLAGS"
|
||||||
then
|
CLEANCPPFLAGS="$CPPFLAGS"
|
||||||
AC_MSG_RESULT([defaults (or given in environment)])
|
|
||||||
else
|
|
||||||
test X"$OPT_SSL" = Xyes && OPT_SSL=/usr/local/ssl
|
|
||||||
dnl LIBS="$LIBS -L$OPT_SSL/lib"
|
|
||||||
LDFLAGS="$LDFLAGS -L$OPT_SSL/lib"
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$OPT_SSL/include/openssl -I$OPT_SSL/include"
|
|
||||||
AC_MSG_RESULT([$OPT_SSL])
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl check for crypto libs (part of SSLeay)
|
case "$OPT_SSL" in
|
||||||
AC_CHECK_LIB(crypto, CRYPTO_lock)
|
yes)
|
||||||
|
EXTRA_SSL=/usr/local/ssl ;;
|
||||||
|
*)
|
||||||
|
dnl check the given spot right away!
|
||||||
|
EXTRA_SSL=$OPT_SSL
|
||||||
|
LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib"
|
||||||
|
CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
if test $ac_cv_lib_crypto_CRYPTO_lock = yes; then
|
AC_CHECK_LIB(crypto, CRYPTO_lock,[
|
||||||
|
HAVECRYPTO="yes"
|
||||||
|
],[
|
||||||
|
OLDLDFLAGS="$LDFLAGS"
|
||||||
|
OLDCPPFLAGS="$CPPFLAGS"
|
||||||
|
LDFLAGS="$CLEANLDFLAGS -L$EXTRA_SSL/lib"
|
||||||
|
CPPFLAGS="$CLEANCPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
|
||||||
|
AC_CHECK_LIB(crypto, CRYPTO_add_lock,[
|
||||||
|
HAVECRYPTO="yes" ], [
|
||||||
|
LDFLAGS="$OLDLDFLAGS"
|
||||||
|
CPPFLAGS="$OLDCPPFLAGS"
|
||||||
|
])
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
if test "$HAVECRYPTO" = "yes"; then
|
||||||
dnl This is only reasonable to do if crypto actually is there: check for
|
dnl This is only reasonable to do if crypto actually is there: check for
|
||||||
dnl SSL libs NOTE: it is important to do this AFTER the crypto lib
|
dnl SSL libs NOTE: it is important to do this AFTER the crypto lib
|
||||||
|
|
||||||
|
AC_CHECK_LIB(crypto, CRYPTO_add_lock)
|
||||||
AC_CHECK_LIB(ssl, SSL_connect)
|
AC_CHECK_LIB(ssl, SSL_connect)
|
||||||
|
|
||||||
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
||||||
@@ -570,16 +637,26 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
dnl Check for SSLeay headers
|
dnl Check for SSLeay headers
|
||||||
AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h openssl/pem.h openssl/ssl.h openssl/err.h)
|
AC_CHECK_HEADERS(openssl/x509.h openssl/rsa.h openssl/crypto.h \
|
||||||
|
openssl/pem.h openssl/ssl.h openssl/err.h,
|
||||||
|
OPENSSL_ENABLED=1)
|
||||||
|
|
||||||
if test $ac_cv_header_openssl_x509_h = no; then
|
if test $ac_cv_header_openssl_x509_h = no; then
|
||||||
AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h)
|
AC_CHECK_HEADERS(x509.h rsa.h crypto.h pem.h ssl.h err.h,
|
||||||
|
OPENSSL_ENABLED=1)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
AC_SUBST(OPENSSL_ENABLED)
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if test X"$OPT_SSL" != Xoff &&
|
||||||
|
test "$OPENSSL_ENABLED" != "1"; then
|
||||||
|
AC_MSG_ERROR([OpenSSL libs and/or directories were not found where specified!])
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl these can only exist if openssl exists
|
dnl these can only exist if openssl exists
|
||||||
|
|
||||||
AC_CHECK_FUNCS( RAND_status \
|
AC_CHECK_FUNCS( RAND_status \
|
||||||
@@ -635,6 +712,9 @@ then
|
|||||||
Set to explicitly specify we don't want to use thread-safe functions)
|
Set to explicitly specify we don't want to use thread-safe functions)
|
||||||
else
|
else
|
||||||
|
|
||||||
|
dnl check that 'localhost' resolves first
|
||||||
|
CURL_CHECK_WORKING_RESOLVER
|
||||||
|
|
||||||
dnl dig around for gethostbyname_r()
|
dnl dig around for gethostbyname_r()
|
||||||
CURL_CHECK_GETHOSTBYNAME_R()
|
CURL_CHECK_GETHOSTBYNAME_R()
|
||||||
|
|
||||||
@@ -723,11 +803,6 @@ if test "$socklen_t" != "yes"; then
|
|||||||
AC_CHECK_TYPE(socklen_t, int)
|
AC_CHECK_TYPE(socklen_t, int)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl Get system canonical name
|
|
||||||
AC_CANONICAL_HOST
|
|
||||||
AC_DEFINE_UNQUOTED(OS, "${host}")
|
|
||||||
|
|
||||||
dnl Checks for library functions.
|
dnl Checks for library functions.
|
||||||
dnl AC_PROG_GCC_TRADITIONAL
|
dnl AC_PROG_GCC_TRADITIONAL
|
||||||
AC_TYPE_SIGNAL
|
AC_TYPE_SIGNAL
|
||||||
@@ -736,6 +811,7 @@ AC_CHECK_FUNCS( socket \
|
|||||||
select \
|
select \
|
||||||
strdup \
|
strdup \
|
||||||
strstr \
|
strstr \
|
||||||
|
strtok_r \
|
||||||
strftime \
|
strftime \
|
||||||
uname \
|
uname \
|
||||||
strcasecmp \
|
strcasecmp \
|
||||||
@@ -757,7 +833,8 @@ AC_CHECK_FUNCS( socket \
|
|||||||
getpass_r \
|
getpass_r \
|
||||||
strlcat \
|
strlcat \
|
||||||
getpwuid \
|
getpwuid \
|
||||||
geteuid
|
geteuid \
|
||||||
|
dlopen
|
||||||
)
|
)
|
||||||
|
|
||||||
dnl removed 'getpass' check on October 26, 2000
|
dnl removed 'getpass' check on October 26, 2000
|
||||||
@@ -783,7 +860,7 @@ dnl AC_PATH_PROG( RANLIB, ranlib, /usr/bin/ranlib,
|
|||||||
dnl $PATH:/usr/bin/:/usr/local/bin )
|
dnl $PATH:/usr/bin/:/usr/local/bin )
|
||||||
dnl AC_SUBST(RANLIB)
|
dnl AC_SUBST(RANLIB)
|
||||||
|
|
||||||
AC_OUTPUT( Makefile \
|
AC_CONFIG_FILES([Makefile \
|
||||||
docs/Makefile \
|
docs/Makefile \
|
||||||
docs/examples/Makefile \
|
docs/examples/Makefile \
|
||||||
include/Makefile \
|
include/Makefile \
|
||||||
@@ -798,9 +875,12 @@ AC_OUTPUT( Makefile \
|
|||||||
packages/Linux/RPM/Makefile \
|
packages/Linux/RPM/Makefile \
|
||||||
packages/Linux/RPM/curl.spec \
|
packages/Linux/RPM/curl.spec \
|
||||||
packages/Linux/RPM/curl-ssl.spec \
|
packages/Linux/RPM/curl-ssl.spec \
|
||||||
|
packages/Solaris/Makefile \
|
||||||
perl/Makefile \
|
perl/Makefile \
|
||||||
perl/Curl_easy/Makefile \
|
perl/Curl_easy/Makefile \
|
||||||
php/Makefile \
|
php/Makefile \
|
||||||
php/examples/Makefile
|
php/examples/Makefile \
|
||||||
)
|
curl-config
|
||||||
|
])
|
||||||
|
AC_OUTPUT
|
||||||
|
|
||||||
|
91
curl-config.in
Normal file
91
curl-config.in
Normal file
@@ -0,0 +1,91 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
#
|
||||||
|
# The idea to this kind of setup info script was stolen from numerous
|
||||||
|
# other packages, such as neon, libxml and gnome.
|
||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
prefix=@prefix@
|
||||||
|
exec_prefix=@exec_prefix@
|
||||||
|
includedir=@includedir@
|
||||||
|
|
||||||
|
usage()
|
||||||
|
{
|
||||||
|
cat <<EOF
|
||||||
|
Usage: curl-config [OPTION]
|
||||||
|
|
||||||
|
Available values for OPTION include:
|
||||||
|
|
||||||
|
--cflags pre-processor and compiler flags
|
||||||
|
--feature newline separated list of enabled features
|
||||||
|
--help display this help and exit
|
||||||
|
--libs library linking information
|
||||||
|
--prefix curl install prefix
|
||||||
|
--version output version information
|
||||||
|
--vernum output the version information as a number (hexadecimal)
|
||||||
|
EOF
|
||||||
|
|
||||||
|
exit $1
|
||||||
|
}
|
||||||
|
|
||||||
|
if test $# -eq 0; then
|
||||||
|
usage 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
while test $# -gt 0; do
|
||||||
|
case "$1" in
|
||||||
|
# this deals with options in the style
|
||||||
|
# --option=value and extracts the value part
|
||||||
|
# [not currently used]
|
||||||
|
-*=*) value=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
|
||||||
|
*) value= ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
--prefix)
|
||||||
|
echo $prefix
|
||||||
|
;;
|
||||||
|
|
||||||
|
--feature)
|
||||||
|
if test "@OPENSSL_ENABLED@" = "1"; then
|
||||||
|
echo "SSL"
|
||||||
|
fi
|
||||||
|
if test "@KRB4_ENABLED@" = "1"; then
|
||||||
|
echo "KRB4"
|
||||||
|
fi
|
||||||
|
if test "@IPV6_ENABLED@" = "1"; then
|
||||||
|
echo "IPv6"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
--version)
|
||||||
|
echo libcurl @VERSION@
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--vernum)
|
||||||
|
echo @VERSIONNUM@
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--help)
|
||||||
|
usage 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--cflags)
|
||||||
|
echo @CPPFLAGS@
|
||||||
|
;;
|
||||||
|
|
||||||
|
--libs)
|
||||||
|
echo @LDFLAGS@ @LIBS@
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
usage
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 0
|
@@ -16,7 +16,7 @@ The License Issue
|
|||||||
the same license curl and libcurl is already using unless stated otherwise.
|
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 enforce 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 GPL virus to attack users of libcurl) but they must
|
GPL (as we don't want the GPL virus to attack users of libcurl) but they must
|
||||||
use "GPL compatible" licenses.
|
use "GPL compatible" licenses.
|
||||||
|
114
docs/FAQ
114
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: March 22, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
Updated: May 29, 2001 (http://curl.haxx.se/docs/faq.shtml)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -12,6 +12,8 @@ FAQ
|
|||||||
1.2 What is libcurl?
|
1.2 What is libcurl?
|
||||||
1.3 What is cURL not?
|
1.3 What is cURL not?
|
||||||
1.4 When will you make curl do XXXX ?
|
1.4 When will you make curl do XXXX ?
|
||||||
|
1.5 Who makes cURL?
|
||||||
|
1.6 What do you get for making cURL?
|
||||||
|
|
||||||
2. Install Related Problems
|
2. Install Related Problems
|
||||||
2.1 configure doesn't find OpenSSL even when it is installed
|
2.1 configure doesn't find OpenSSL even when it is installed
|
||||||
@@ -30,8 +32,9 @@ 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.9 How do I use curl in PHP, Perl, Tcl, Ruby or Java?
|
||||||
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
3.10 What about SOAP, WebDAV, XML-RPC or similar protocols over HTTP?
|
||||||
|
3.11 How do I POST with a different Content-Type?
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
@@ -55,7 +58,7 @@ FAQ
|
|||||||
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.5 Does CURLOPT_FILE and CURLOPT_INFILE work on win32 ?
|
||||||
5.6 What about Keep-Alive or persistant connections?
|
5.6 What about Keep-Alive or persistent connections?
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
6.1 I have a GPL program, can I use the libcurl library?
|
6.1 I have a GPL program, can I use the libcurl library?
|
||||||
@@ -76,7 +79,7 @@ FAQ
|
|||||||
with URL spelled in uppercase to make it obvious it deals with URLs. The
|
with URL spelled in uppercase to make it obvious it deals with URLs. The
|
||||||
fact it can also be pronounced 'see URL' also helped.
|
fact it can also be pronounced 'see URL' also helped.
|
||||||
|
|
||||||
Curl supports a range of common internet protocols, currently including
|
Curl supports a range of common Internet protocols, currently including
|
||||||
HTTP, HTTPS, FTP, GOPHER, LDAP, DICT, TELNET and FILE.
|
HTTP, HTTPS, FTP, GOPHER, LDAP, DICT, TELNET and FILE.
|
||||||
|
|
||||||
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
We spell it cURL or just curl. We pronounce it with an initial k sound:
|
||||||
@@ -84,10 +87,11 @@ FAQ
|
|||||||
|
|
||||||
1.2 What is libcurl?
|
1.2 What is libcurl?
|
||||||
|
|
||||||
libcurl is a reliable, higly portable multiprotocol file transfer library.
|
libcurl is a reliable and portable library which provides you with an easy
|
||||||
|
interface to a range of common Internet protocols.
|
||||||
|
|
||||||
Any application is free to use libcurl, even commercial or closed-source
|
You can use libcurl for free in your application even if it is commercial
|
||||||
ones.
|
or closed-source.
|
||||||
|
|
||||||
1.3 What is cURL not?
|
1.3 What is cURL not?
|
||||||
|
|
||||||
@@ -100,8 +104,8 @@ FAQ
|
|||||||
something: fine, go ahead and write a script that wraps around curl to make
|
something: fine, go ahead and write a script that wraps around curl to make
|
||||||
it reality (like curlmirror.pl does).
|
it reality (like curlmirror.pl does).
|
||||||
|
|
||||||
Curl is not an ftp site mirroring program. Sure, get and send ftp with curl
|
Curl is not an FTP site mirroring program. Sure, get and send FTP with curl
|
||||||
but if you want systematic and sequential behaviour you should write a
|
but if you want systematic and sequential behavior you should write a
|
||||||
script (or write a new program that interfaces libcurl) and do it.
|
script (or write a new program that interfaces libcurl) and do it.
|
||||||
|
|
||||||
Curl is not a PHP tool, even though it works perfectly well when used from
|
Curl is not a PHP tool, even though it works perfectly well when used from
|
||||||
@@ -141,6 +145,31 @@ FAQ
|
|||||||
* If you write the code, chances are bigger that it will get into curl
|
* If you write the code, chances are bigger that it will get into curl
|
||||||
faster.
|
faster.
|
||||||
|
|
||||||
|
1.5 Who makes cURL?
|
||||||
|
|
||||||
|
cURL and libcurl are not made by any single individual. Sure, Daniel
|
||||||
|
Stenberg writes the major parts, but various people's submissions are
|
||||||
|
important and crucial. Anyone can post their changes and improvements and
|
||||||
|
have them inserted in the main sources (of course on the condition that
|
||||||
|
developers agree on that the fixes are good).
|
||||||
|
|
||||||
|
The list of contributors in the bottom of the man page is only a small part
|
||||||
|
of all the people that every day provide us with bug reports, suggestions,
|
||||||
|
ideas and source code.
|
||||||
|
|
||||||
|
curl is developed by a community, with Daniel at the wheel.
|
||||||
|
|
||||||
|
1.6 What do you get for making cURL?
|
||||||
|
|
||||||
|
Project cURL is entirely free and open, without any commercial interests or
|
||||||
|
money involved. No person gets paid in any way for developing curl. We all
|
||||||
|
do this voluntarily on our spare time.
|
||||||
|
|
||||||
|
We get some help from companies. Contactor Data hosts the curl web site and
|
||||||
|
the main mailing list, Haxx owns the curl web site's domain and
|
||||||
|
sourceforge.net hosts several project tools we take advantage from like the
|
||||||
|
bug tracker, mailing lists and more.
|
||||||
|
|
||||||
2. Install Related Problems
|
2. Install Related Problems
|
||||||
|
|
||||||
2.1. configure doesn't find OpenSSL even when it is installed
|
2.1. configure doesn't find OpenSSL even when it is installed
|
||||||
@@ -176,7 +205,7 @@ FAQ
|
|||||||
a few functions are left out from the libssl.
|
a few functions are left out from the libssl.
|
||||||
|
|
||||||
If the function names missing include RSA or RSAREF you can be certain
|
If the function names missing include RSA or RSAREF you can be certain
|
||||||
that this is because libssl requires the RSA and RSASEF libs to build.
|
that this is because libssl requires the RSA and RSAREF libs to build.
|
||||||
|
|
||||||
See the INSTALL file section that explains how to add those libs to
|
See the INSTALL file section that explains how to add those libs to
|
||||||
configure. Make sure that you remove the config.cache file before you
|
configure. Make sure that you remove the config.cache file before you
|
||||||
@@ -195,12 +224,12 @@ FAQ
|
|||||||
|
|
||||||
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 site to find
|
on a windows machine to do https://. Check out the curl web site to find
|
||||||
accurate and up-to-date pointers to recent OpenSSL DDLs and other binary
|
accurate and up-to-date pointers to recent OpenSSL DLLs and other binary
|
||||||
packages.
|
packages.
|
||||||
|
|
||||||
2.4. Does cURL support Socks (RFC 1928) ?
|
2.4. Does cURL support Socks (RFC 1928) ?
|
||||||
|
|
||||||
No. Nobody has wanted it that badly yet. We appriciate patches that bring
|
No. Nobody has wanted it that badly yet. We appreciate patches that bring
|
||||||
this functionality.
|
this functionality.
|
||||||
|
|
||||||
|
|
||||||
@@ -235,10 +264,11 @@ FAQ
|
|||||||
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'.
|
||||||
|
|
||||||
This is described in some detail in the README.curl file, and if you don't
|
This is described in some detail in the MANUAL and TheArtOfHttpScripting
|
||||||
understand it the first time, read it again before you post questions about
|
documents, and if you don't understand it the first time, read it again
|
||||||
this to the mailing list. Also, try reading through the mailing list
|
before you post questions about this to the mailing list. Also, try reading
|
||||||
archives for old postings and questions regarding this.
|
through the mailing list archives for old postings and questions regarding
|
||||||
|
this.
|
||||||
|
|
||||||
3.4. How do I tell curl to run custom FTP commands?
|
3.4. How do I tell curl to run custom FTP commands?
|
||||||
|
|
||||||
@@ -246,7 +276,7 @@ FAQ
|
|||||||
file transfer. Study the -Q/--quote option.
|
file transfer. Study the -Q/--quote option.
|
||||||
|
|
||||||
Since curl is used for file transfers, you don't use curl to just perform
|
Since curl is used for file transfers, you don't use curl to just perform
|
||||||
ftp commands without transfering anything. Therefore you must always specify
|
FTP commands without transferring anything. Therefore you must always specify
|
||||||
a URL to transfer to/from even when doing custom FTP commands.
|
a URL to transfer to/from even when doing custom FTP commands.
|
||||||
|
|
||||||
3.5. How can I disable the Pragma: nocache header?
|
3.5. How can I disable the Pragma: nocache header?
|
||||||
@@ -258,7 +288,7 @@ FAQ
|
|||||||
3.6. Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
3.6. Does curl support javascript, ASP, XML, XHTML or HTML version Y?
|
||||||
|
|
||||||
To curl, all contents are alike. It doesn't matter how the page was
|
To curl, all contents are alike. It doesn't matter how the page was
|
||||||
generated. It may be ASP, PHP, perl, shell-script, SSI or plain
|
generated. It may be ASP, PHP, Perl, shell-script, SSI or plain
|
||||||
HTML-files. There's no difference to curl and it doesn't even know what kind
|
HTML-files. There's no difference to curl and it doesn't even know what kind
|
||||||
of language that generated the page.
|
of language that generated the page.
|
||||||
|
|
||||||
@@ -268,7 +298,7 @@ FAQ
|
|||||||
|
|
||||||
3.7. Can I use curl to delete/rename a file through FTP?
|
3.7. Can I use curl to delete/rename a file through FTP?
|
||||||
|
|
||||||
Yes. You specify custom ftp commands with -Q/--quote.
|
Yes. You specify custom FTP commands with -Q/--quote.
|
||||||
|
|
||||||
One example would be to delete a file after you have downloaded it:
|
One example would be to delete a file after you have downloaded it:
|
||||||
|
|
||||||
@@ -282,7 +312,20 @@ FAQ
|
|||||||
|
|
||||||
curl -L http://redirector.com
|
curl -L http://redirector.com
|
||||||
|
|
||||||
3.9 How do I use curl in PHP?
|
3.9 How do I use curl in PHP, Perl, Tcl, Ruby or Java?
|
||||||
|
|
||||||
|
There exist many language-interfaces for curl that integrates it better with
|
||||||
|
various languages. If you are fluid in a script language, you may very well
|
||||||
|
opt to use such an interface instead of using the command line tool.
|
||||||
|
|
||||||
|
At the time of writing, there are bindings for the five language mentioned
|
||||||
|
above, but chances are there are even more by the time you read this. Or you
|
||||||
|
may be able you write your own wrapper for a not-yet supported language!
|
||||||
|
|
||||||
|
Find out more about which languages that support curl directly, and how to
|
||||||
|
install and use them, in the libcurl section of the curl web site:
|
||||||
|
|
||||||
|
http://curl.haxx.se/libcurl/
|
||||||
|
|
||||||
PHP4 has the ability to use libcurl as an internal module if built with that
|
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
|
option enabled. You then get a set of extra functions that can be used
|
||||||
@@ -305,6 +348,13 @@ FAQ
|
|||||||
Using libcurl or PHP's curl modules is just as fine and you'd just use the
|
Using libcurl or PHP's curl modules is just as fine and you'd just use the
|
||||||
proper library options to do the same.
|
proper library options to do the same.
|
||||||
|
|
||||||
|
3.11 How do I POST with a different Content-Type?
|
||||||
|
|
||||||
|
You can always replace the internally generated headers with -H/--header.
|
||||||
|
To make a simple HTTP POST with text/xml as content-type, do something like:
|
||||||
|
|
||||||
|
curl -d "datatopost" -H "Content-Type: text/xml" [URL]
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
|
|
||||||
4.1. Problems connecting to SSL servers.
|
4.1. Problems connecting to SSL servers.
|
||||||
@@ -326,7 +376,7 @@ FAQ
|
|||||||
|
|
||||||
In general unix shells, the & letter is treated special and when used, it
|
In general unix shells, the & letter is treated special and when used, it
|
||||||
runs the specified command in the background. To safely send the & as a part
|
runs the specified command in the background. To safely send the & as a part
|
||||||
of a URL, you should qoute the entire URL by using single (') or double (")
|
of a URL, you should quote the entire URL by using single (') or double (")
|
||||||
quotes around it.
|
quotes around it.
|
||||||
|
|
||||||
An example that would invoke a remote CGI that uses &-letters could be:
|
An example that would invoke a remote CGI that uses &-letters could be:
|
||||||
@@ -407,7 +457,7 @@ FAQ
|
|||||||
|
|
||||||
The first part is to avoid having clear-text passwords in the command line
|
The first part is to avoid having clear-text passwords in the command line
|
||||||
so that they don't appear in 'ps' outputs and similar. That is easily
|
so that they don't appear in 'ps' outputs and similar. That is easily
|
||||||
avoided by using the "-K" option tho tell curl to read parameters from a
|
avoided by using the "-K" option to tell curl to read parameters from a
|
||||||
file or stdin to which you can pass the secret info.
|
file or stdin to which you can pass the secret info.
|
||||||
|
|
||||||
To keep the passwords in your account secret from the rest of the world is
|
To keep the passwords in your account secret from the rest of the world is
|
||||||
@@ -417,11 +467,11 @@ FAQ
|
|||||||
|
|
||||||
Also note that regular HTTP and FTP passwords are sent in clear across the
|
Also note that regular HTTP and FTP passwords are sent in clear across the
|
||||||
network. All it takes for anyone to fetch them is to listen on the network.
|
network. All it takes for anyone to fetch them is to listen on the network.
|
||||||
Evesdropping is very easy.
|
Eavesdropping is very easy.
|
||||||
|
|
||||||
4.8 I found a bug!
|
4.8 I found a bug!
|
||||||
|
|
||||||
It is not a bug if the behaviour is documented. Read the docs first.
|
It is not a bug if the behavior is documented. Read the docs first.
|
||||||
|
|
||||||
If it is a problem with a binary you've downloaded or a package for your
|
If it is a problem with a binary you've downloaded or a package for your
|
||||||
particular platform, try contacting the person who built the package/archive
|
particular platform, try contacting the person who built the package/archive
|
||||||
@@ -450,14 +500,16 @@ FAQ
|
|||||||
programs. libcurl will use thread-safe functions instead of non-safe ones if
|
programs. libcurl will use thread-safe functions instead of non-safe ones if
|
||||||
your system has such.
|
your system has such.
|
||||||
|
|
||||||
We would appriciate some kind of report or README file from those who have
|
We would appreciate some kind of report or README file from those who have
|
||||||
used libcurl in a threaded environment.
|
used libcurl in a threaded environment.
|
||||||
|
|
||||||
5.2 How can I receive all data into a large memory chunk?
|
5.2 How can I receive all data into a large memory chunk?
|
||||||
|
|
||||||
|
[ See also the examples/getinmemory.c source ]
|
||||||
|
|
||||||
You are in full control of the callback function that gets called every time
|
You are in full control of the callback function that gets called every time
|
||||||
there is data received from the remote server. You can make that callback do
|
there is data received from the remote server. You can make that callback do
|
||||||
whatever you want. You do not have to write the receivied data to a file.
|
whatever you want. You do not have to write the received data to a file.
|
||||||
|
|
||||||
One solution to this problem could be to have a pointer to a struct that you
|
One solution to this problem could be to have a pointer to a struct that you
|
||||||
pass to the callback function. You set the pointer using the
|
pass to the callback function. You set the pointer using the
|
||||||
@@ -493,13 +545,13 @@ FAQ
|
|||||||
curl_easy_setopt() and then transfer it with curl_easy_perform(). The handle
|
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
|
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
|
7.7, but also you're encouraged to reuse it if you can, as that will enable
|
||||||
libcurl to use persistant connections.
|
libcurl to use persistent connections.
|
||||||
|
|
||||||
For libcurl prior to 7.7, there was no multiple file support. The only
|
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
|
available way to do multiple requests was to init/perform/cleanup for each
|
||||||
transfer.
|
transfer.
|
||||||
|
|
||||||
5.4 Does libcurl do Winsock initing on win32 systems?
|
5.4 Does libcurl do Winsock initialization on win32 systems?
|
||||||
|
|
||||||
No.
|
No.
|
||||||
|
|
||||||
@@ -519,15 +571,15 @@ FAQ
|
|||||||
|
|
||||||
(Provided by Joel DeYoung and Bob Schader)
|
(Provided by Joel DeYoung and Bob Schader)
|
||||||
|
|
||||||
5.6 What about Keep-Alive or persistant connections?
|
5.6 What about Keep-Alive or persistent connections?
|
||||||
|
|
||||||
Starting with version 7.7, curl and libcurl will have excellent support for
|
Starting with version 7.7, curl and libcurl will have excellent support for
|
||||||
persistant connections when transferring several files from the same server.
|
persistent connections when transferring several files from the same server.
|
||||||
Curl will attempt to reuse connections for all URLs specified on the same
|
Curl will attempt to reuse connections for all URLs specified on the same
|
||||||
command line/config file, and libcurl will reuse connections for all
|
command line/config file, and libcurl will reuse connections for all
|
||||||
transfers that are made using the same libcurl handle.
|
transfers that are made using the same libcurl handle.
|
||||||
|
|
||||||
Previous versions had no persistant connection support.
|
Previous versions had no persistent connection support.
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
|
|
||||||
|
20
docs/INSTALL
20
docs/INSTALL
@@ -183,9 +183,9 @@ Win32
|
|||||||
For VC++ 6, there's an included Makefile.vc6 that should be possible
|
For VC++ 6, there's an included Makefile.vc6 that should be possible
|
||||||
to use out-of-the-box.
|
to use out-of-the-box.
|
||||||
|
|
||||||
Microsoft note: add /Zm200 to the compiler options, as the hugehelp.c
|
Microsoft note: add /Zm200 to the compiler options to increase the
|
||||||
won't compile otherwise due to "too long puts string" or something
|
compiler's memory allocation limit, as the hugehelp.c won't compile
|
||||||
like that!
|
due to "too long puts string".
|
||||||
|
|
||||||
|
|
||||||
With SSL:
|
With SSL:
|
||||||
@@ -206,8 +206,14 @@ Win32
|
|||||||
|
|
||||||
Microsoft command line style
|
Microsoft command line style
|
||||||
----------------------------
|
----------------------------
|
||||||
|
Please read the OpenSSL documentation on how to compile and install
|
||||||
|
the OpenSSL library. This generates the libeay32.dll and ssleay32.dll
|
||||||
|
files.
|
||||||
|
|
||||||
Run the 'vcvars32.bat' file to get the proper environment variables
|
Run the 'vcvars32.bat' file to get the proper environment variables
|
||||||
set, then run 'nmake vc-ssl' in the root dir.
|
set. Edit the makefile.vc6 in the lib directory and define
|
||||||
|
OPENSSL_PATH. Set the location of the OpenSSL library and run 'nmake
|
||||||
|
vc-ssl' in the root directory.
|
||||||
|
|
||||||
The vcvars32.bat file is part of the Microsoft development
|
The vcvars32.bat file is part of the Microsoft development
|
||||||
environment.
|
environment.
|
||||||
@@ -237,7 +243,7 @@ IBM OS/2
|
|||||||
If you want to build with OpenSSL or OpenLDAP support, you'll need to
|
If you want to build with OpenSSL or OpenLDAP support, you'll need to
|
||||||
download those libraries, too. Dirk Ohme has done some work to port SSL
|
download those libraries, too. Dirk Ohme has done some work to port SSL
|
||||||
libraries under OS/2, but it looks like he doesn't care about emx. You'll
|
libraries under OS/2, but it looks like he doesn't care about emx. You'll
|
||||||
find his patches on: http://come.to/Dirk.Ohme
|
find his patches on: http://come.to/Dirk_Ohme
|
||||||
|
|
||||||
If during the linking you get an error about _errno being an undefined
|
If during the linking you get an error about _errno being an undefined
|
||||||
symbol referenced from the text segment, you need to add -D__ST_MT_ERRNO__
|
symbol referenced from the text segment, you need to add -D__ST_MT_ERRNO__
|
||||||
@@ -251,10 +257,10 @@ IBM OS/2
|
|||||||
|
|
||||||
PORTS
|
PORTS
|
||||||
=====
|
=====
|
||||||
Just to show off, this is a probably incomplete list of known hardware and
|
This is a probably incomplete list of known hardware and
|
||||||
operating systems that curl has been compiled for:
|
operating systems that curl has been compiled for:
|
||||||
|
|
||||||
- Ultrix
|
- Ultrix 4.3a
|
||||||
- SINIX-Z v5
|
- SINIX-Z v5
|
||||||
- Alpha DEC OSF 4
|
- Alpha DEC OSF 4
|
||||||
- Alpha Digital UNIX v3.2
|
- Alpha Digital UNIX v3.2
|
||||||
|
144
docs/INTERNALS
144
docs/INTERNALS
@@ -1,4 +1,4 @@
|
|||||||
Updated for curl 7.7 on March 13, 2001
|
Updated for curl 7.8 on May 29, 2001
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -69,45 +69,96 @@ Library
|
|||||||
rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are
|
rather small and easy-to-follow. All the ones prefixed with 'curl_easy' are
|
||||||
put in the lib/easy.c file.
|
put in the lib/easy.c file.
|
||||||
|
|
||||||
|
Starting with libcurl 7.8, curl_global_init_() and curl_global_cleanup() were
|
||||||
|
introduced. They should be called by the application to initialize and clean
|
||||||
|
up global stuff in the library. As of today, they just do the global SSL
|
||||||
|
initing if SSL is enabled. libcurl itself has no "global" scope.
|
||||||
|
|
||||||
All printf()-style functions use the supplied clones in lib/mprintf.c. This
|
All printf()-style functions use the supplied clones in lib/mprintf.c. This
|
||||||
makes sure we stay absolutely platform independent.
|
makes sure we stay absolutely platform independent.
|
||||||
|
|
||||||
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 reveal internals. This is the 'UrlData' struct
|
||||||
|
which works as a global "anchor" struct. All connections performed will get
|
||||||
|
connect-specific data allocated that should be used for things related to
|
||||||
|
particular connections/requests.
|
||||||
|
|
||||||
curl_easy_setopt() takes a three arguments, where the option stuff must be
|
curl_easy_setopt() takes three arguments, where the option stuff must be
|
||||||
passed in pairs, the parameter-ID and the parameter-value. The list of
|
passed in pairs: the parameter-ID and the parameter-value. The list of
|
||||||
options is documented in the man page.
|
options is documented in the man page. This function mainly sets things in
|
||||||
|
the 'UrlData' struct.
|
||||||
|
|
||||||
curl_easy_perform() does a whole lot of things:
|
curl_easy_perform() does a whole lot of things:
|
||||||
|
|
||||||
It starts off in the lib/easy.c file by calling curl_transfer(), but the main
|
It starts off in the lib/easy.c file by calling Curl_perform() and the main
|
||||||
work is lib/url.c. The function first analyzes the URL, it separates the
|
work then continues in lib/url.c. The flow continues with a call to
|
||||||
different components and connects to the remote host. This may involve using
|
Curl_connect() to connect to the remote site.
|
||||||
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 protocol-specific function is called. The
|
o Curl_connect()
|
||||||
functions are named after the protocols they handle. Curl_ftp(), Curl_http(),
|
|
||||||
Curl_dict(), etc. They all reside in their respective files (ftp.c, http.c
|
... analyzes the URL, it separates the different components and connects to
|
||||||
and dict.c).
|
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 Curl_connect is done, we are connected to the remote site. Then it is
|
||||||
|
time to tell the server to get a document/file. Curl_do() arranges this.
|
||||||
|
|
||||||
|
This function makes sure there's an allocated and initiated 'connectdata'
|
||||||
|
struct that is used for this particular connection only (although there may
|
||||||
|
be several requests performed on the same connect). A bunch of things are
|
||||||
|
inited/inherited from the UrlData struct.
|
||||||
|
|
||||||
|
o Curl_do()
|
||||||
|
|
||||||
|
Curl_do() makes sure the proper protocol-specific function is called. The
|
||||||
|
functions are named after the protocols they handle. Curl_ftp(),
|
||||||
|
Curl_http(), Curl_dict(), etc. They all reside in their respective files
|
||||||
|
(ftp.c, http.c and dict.c). HTTPS is handled by Curl_http() and FTPS by
|
||||||
|
Curl_ftp().
|
||||||
|
|
||||||
The protocol-specific functions of course deal with protocol-specific
|
The protocol-specific functions of course deal with protocol-specific
|
||||||
negotiations and setup. They have access to the Curl_sendf() (from
|
negotiations and setup. They have access to the Curl_sendf() (from
|
||||||
lib/sendf.c) function to send printf-style formatted data to the remote host
|
lib/sendf.c) function to send printf-style formatted data to the remote
|
||||||
and when they're ready to make the actual file transfer they call the
|
host and when they're ready to make the actual file transfer they call the
|
||||||
Curl_Transfer() function (in lib/transfer.c) to setup the transfer and
|
Curl_Transfer() function (in lib/transfer.c) to setup the transfer and
|
||||||
returns. Curl_perform() then calls Transfer() in lib/transfer.c that performs
|
returns.
|
||||||
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.
|
o Transfer()
|
||||||
|
|
||||||
|
Curl_perform() then calls Transfer() in lib/transfer.c that performs
|
||||||
|
the entire file transfer.
|
||||||
|
|
||||||
During transfer, the progress functions in lib/progress.c are called at a
|
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
|
||||||
that the transfer is as fast as required.
|
verify that the transfer is as fast as required.
|
||||||
|
|
||||||
|
o Curl_done()
|
||||||
|
|
||||||
|
Called after a transfer is done. This function takes care of everything
|
||||||
|
that has to be done after a transfer. This function attempts to leave
|
||||||
|
matters in a state so that Curl_do() should be possible to call again on
|
||||||
|
the same connection (in a persistent connection case). It might also soon
|
||||||
|
be closed with Curl_disconnect().
|
||||||
|
|
||||||
|
o Curl_disconnect()
|
||||||
|
|
||||||
|
When doing normal connections and transfers, no one ever tries to close any
|
||||||
|
connection so this is not normally called when curl_easy_perform() is
|
||||||
|
used. This function is only used when we are certain that no more transfers
|
||||||
|
is going to be made on the connection. It can be also closed by force, or
|
||||||
|
it can be called to make sure that libcurl doesn't keep too many
|
||||||
|
connections alive at the same time (there's a default amount of 5 but that
|
||||||
|
can be changed with the CURLOPT_MAXCONNECTS option).
|
||||||
|
|
||||||
|
This function cleans up all resources that are associated with a single
|
||||||
|
connection.
|
||||||
|
|
||||||
|
Curl_perform() is the function that does the main "connect - do - transfer -
|
||||||
|
done" loop. It loops if there's a Location: to follow.
|
||||||
|
|
||||||
When completed, the curl_easy_cleanup() should be called to free up used
|
When completed, the curl_easy_cleanup() should be called to free up used
|
||||||
resources.
|
resources. It runs Curl_disconnect() on all open connectons.
|
||||||
|
|
||||||
A quick roundup on internal function sequences (many of these call
|
A quick roundup on internal function sequences (many of these call
|
||||||
protocol-specific function-pointers):
|
protocol-specific function-pointers):
|
||||||
@@ -201,42 +252,41 @@ Library
|
|||||||
exists in lib/getpass.c. libcurl offers a custom callback that can be used
|
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.
|
instead of this, but it doesn't change much to us.
|
||||||
|
|
||||||
Persistant Connections
|
Persistent Connections
|
||||||
======================
|
======================
|
||||||
|
|
||||||
With curl 7.7, we added persistant connection support to libcurl which has
|
The persistent connection support in libcurl requires some considerations on
|
||||||
introduced a somewhat different treatmeant of things inside of libcurl.
|
how to do things inside of the library.
|
||||||
|
|
||||||
o The 'UrlData' struct returned in the curl_easy_init() call must never
|
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
|
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.
|
as all the options etc that the library-user may choose.
|
||||||
o The 'UrlData' struct holds the cache array of pointers to 'connectdata'
|
o The 'UrlData' struct holds the "connection cache" (an array of pointers to
|
||||||
structs. There's one connectdata struct for each connection that libcurl
|
'connectdata' structs). There's one connectdata struct allocated for each
|
||||||
knows about.
|
connection that libcurl knows about.
|
||||||
o This also enables the 'curl handle' to be reused on subsequent transfers,
|
o This also enables the 'curl handle' to be reused on subsequent transfers,
|
||||||
something that was illegal in pre-7.7 versions.
|
something that was illegal before libcurl 7.7.
|
||||||
o When we are about to perform a transfer with curl_easy_perform(), we first
|
o When we are about to perform a transfer with curl_easy_perform(), we first
|
||||||
check for an already existing connection in the cache that we can use,
|
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
|
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
|
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
|
select which one to close dependent on the close policy that may have been
|
||||||
previously set.
|
previously set.
|
||||||
o When the tranfer operation is complete, we try to leave the connection open.
|
o When the transfer operation is complete, we try to leave the connection
|
||||||
Particular options may tell us not to, and protocols may signal closure on
|
open. Particular options may tell us not to, and protocols may signal
|
||||||
connections and then we don't keep it open of course.
|
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.
|
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
|
You do realize that the curl handle must be re-used in order for the
|
||||||
persistant connections to work.
|
persistent connections to work.
|
||||||
|
|
||||||
Library Symbols
|
Library Symbols
|
||||||
===============
|
===============
|
||||||
|
|
||||||
All symbols used internally in libcurl must use a 'Curl_' prefix if they're
|
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
|
used in more than a single file. Single-file symbols must be made static.
|
||||||
static. Public (exported) symbols must use a 'curl_' prefix. (There are
|
Public ("exported") symbols must use a 'curl_' prefix. (There are exceptions,
|
||||||
exceptions, but they are destined to be changed to follow this pattern in the
|
but they are to be changed to follow this pattern in future versions.)
|
||||||
future.)
|
|
||||||
|
|
||||||
Return Codes and Informationals
|
Return Codes and Informationals
|
||||||
===============================
|
===============================
|
||||||
@@ -257,6 +307,7 @@ 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 URL-"globbing" support. Globbing in the sense that the {} and []
|
used for the URL-"globbing" support. Globbing in the sense that the {} and []
|
||||||
@@ -272,25 +323,26 @@ 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
|
Recent versions may loop and do all this several times if many URLs were
|
||||||
specified on the command line or config file.
|
specified on the command line or config file.
|
||||||
|
|
||||||
Memory Debugging
|
Memory Debugging
|
||||||
================
|
================
|
||||||
|
|
||||||
The file named lib/memdebug.c contains debug-versions of a few
|
The file lib/memdebug.c contains debug-versions of a few functions. Functions
|
||||||
functions. Functions such as malloc, free, fopen, fclose, etc that somehow
|
such as malloc, free, fopen, fclose, etc that somehow deal with resources
|
||||||
deal with resources that might give us problems if we "leak" them. The
|
that might give us problems if we "leak" them. The functions in the memdebug
|
||||||
functions in the memdebug system do nothing fancy, they do their normal
|
system do nothing fancy, they do their normal function and then log
|
||||||
function and then log information about what they just did. The logged data
|
information about what they just did. The logged data can then be analyzed
|
||||||
can then be analyzed after a complete session,
|
after a complete session,
|
||||||
|
|
||||||
memanalyze.pl is a perl script present only present in CVS (not part of the
|
memanalyze.pl is the perl script present only present in CVS (not part of the
|
||||||
release archives) that analyzes a log file generated by the memdebug
|
release archives) that analyzes a log file generated by the memdebug
|
||||||
system. It detects if resources are allocated but never freed and other kinds
|
system. It detects if resources are allocated but never freed and other kinds
|
||||||
of errors related to resource management.
|
of errors related to resource management.
|
||||||
|
|
||||||
Use -DMALLOCDEBUG when compiling to enable memory debugging.
|
Use -DMALLOCDEBUG when compiling to enable memory debugging, this is also
|
||||||
|
switched on by running configure with --enable-debug.
|
||||||
|
|
||||||
Test Suite
|
Test Suite
|
||||||
==========
|
==========
|
||||||
|
27
docs/LIBCURL
27
docs/LIBCURL
@@ -6,8 +6,8 @@
|
|||||||
|
|
||||||
How To Use Libcurl In Your C/C++ Program
|
How To Use Libcurl In Your C/C++ Program
|
||||||
|
|
||||||
[ libcurl can be used directly from within your PHP or Perl programs as well,
|
[ libcurl can be used directly from within your Java, PHP, Perl, Ruby or Tcl
|
||||||
look elsewhere for documentation on this ]
|
programs as well, look elsewhere for documentation on this ]
|
||||||
|
|
||||||
The interface is meant to be very simple for applictions/programmers, hence
|
The interface is meant to be very simple for applictions/programmers, hence
|
||||||
the name "easy". We have therefore minimized the number of entries.
|
the name "easy". We have therefore minimized the number of entries.
|
||||||
@@ -49,6 +49,29 @@ The Easy Interface
|
|||||||
|
|
||||||
For details on these, read the separate man pages.
|
For details on these, read the separate man pages.
|
||||||
|
|
||||||
|
Linking with libcurl
|
||||||
|
|
||||||
|
Staring with 7.7.2 (on unix-like machines), there's a tool named curl-config
|
||||||
|
that gets installed with the rest of the curl stuff when 'make install' is
|
||||||
|
performed.
|
||||||
|
|
||||||
|
curl-config is added to make it easier for applications to link with
|
||||||
|
libcurl and developers to learn about libcurl and how to use it.
|
||||||
|
|
||||||
|
Run 'curl-config --libs' to get the (additional) linker options you need to
|
||||||
|
link with the particular version of libcurl you've installed.
|
||||||
|
|
||||||
|
For details, see the curl-config.1 man page.
|
||||||
|
|
||||||
|
libcurl symbol names
|
||||||
|
|
||||||
|
All public functions in the libcurl interface are prefixed with 'curl_' (with
|
||||||
|
a lowercase c). You can find other functions in the library source code, but
|
||||||
|
other prefixes indicate the functions are private and may change without
|
||||||
|
further notice in the next release.
|
||||||
|
|
||||||
|
Only use documented functions and functionality!
|
||||||
|
|
||||||
Portability
|
Portability
|
||||||
|
|
||||||
libcurl works *exactly* the same, on any of the platforms it compiles and
|
libcurl works *exactly* the same, on any of the platforms it compiles and
|
||||||
|
62
docs/MANUAL
62
docs/MANUAL
@@ -15,10 +15,6 @@ SIMPLE USAGE
|
|||||||
|
|
||||||
curl ftp://ftp.funet.fi/README
|
curl ftp://ftp.funet.fi/README
|
||||||
|
|
||||||
Get a gopher document from funet's gopher server:
|
|
||||||
|
|
||||||
curl gopher://gopher.funet.fi
|
|
||||||
|
|
||||||
Get a web page from a server using port 8000:
|
Get a web page from a server using port 8000:
|
||||||
|
|
||||||
curl http://www.weirdserver.com:8000/
|
curl http://www.weirdserver.com:8000/
|
||||||
@@ -27,6 +23,10 @@ SIMPLE USAGE
|
|||||||
|
|
||||||
curl ftp://cool.haxx.se/
|
curl ftp://cool.haxx.se/
|
||||||
|
|
||||||
|
Get a gopher document from funet's gopher server:
|
||||||
|
|
||||||
|
curl gopher://gopher.funet.fi
|
||||||
|
|
||||||
Get the definition of curl from a dictionary:
|
Get the definition of curl from a dictionary:
|
||||||
|
|
||||||
curl dict://dict.org/m:curl
|
curl dict://dict.org/m:curl
|
||||||
@@ -186,7 +186,7 @@ DETAILED INFORMATION
|
|||||||
-D/--dump-header option when getting files from both FTP and HTTP, and it
|
-D/--dump-header option when getting files from both FTP and HTTP, and it
|
||||||
will then store the headers in the specified file.
|
will then store the headers in the specified file.
|
||||||
|
|
||||||
Store the HTTP headers in a separate file:
|
Store the HTTP headers in a separate file (headers.txt in the example):
|
||||||
|
|
||||||
curl --dump-header headers.txt curl.haxx.se
|
curl --dump-header headers.txt curl.haxx.se
|
||||||
|
|
||||||
@@ -245,32 +245,32 @@ POST (HTTP)
|
|||||||
|
|
||||||
-F accepts parameters like -F "name=contents". If you want the contents to
|
-F accepts parameters like -F "name=contents". If you want the contents to
|
||||||
be read from a file, use <@filename> as contents. When specifying a file,
|
be read from a file, use <@filename> as contents. When specifying a file,
|
||||||
you can also specify which content type the file is, by appending
|
you can also specify the file content type by appending ';type=<mime type>'
|
||||||
';type=<mime type>' to the file name. You can also post contents of several
|
to the file name. You can also post the contents of several files in one field.
|
||||||
files in one field. So that the field name 'coolfiles' can be sent three
|
For example, the field name 'coolfiles' is used to send three files, with
|
||||||
files with different content types in a manner similar to:
|
different content types using the following syntax:
|
||||||
|
|
||||||
curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \
|
curl -F "coolfiles=@fil1.gif;type=image/gif,fil2.txt,fil3.html" \
|
||||||
http://www.post.com/postit.cgi
|
http://www.post.com/postit.cgi
|
||||||
|
|
||||||
If content-type is not specified, curl will try to guess from the extension
|
If the content-type is not specified, curl will try to guess from the file
|
||||||
(it only knows a few), or use the previously specified type (from an earlier
|
extension (it only knows a few), or use the previously specified type
|
||||||
file if several files are specified in a list) or finally using the default
|
(from an earlier file if several files are specified in a list) or else it
|
||||||
type 'text/plain'.
|
will using the default type 'text/plain'.
|
||||||
|
|
||||||
Emulate a fill-in form with -F. Let's say you fill in three fields in a
|
Emulate a fill-in form with -F. Let's say you fill in three fields in a
|
||||||
form. One field is a file name which to post, one field is your name and one
|
form. One field is a file name which to post, one field is your name and one
|
||||||
field is a file description. We want to post the file we have written named
|
field is a file description. We want to post the file we have written named
|
||||||
"cooltext.txt". To let curl do the posting of this data instead of your
|
"cooltext.txt". To let curl do the posting of this data instead of your
|
||||||
favourite browser, you have to check out the HTML of the form page to get to
|
favourite browser, you have to read the HTML source of the form page and find
|
||||||
know the names of the input fields. In our example, the input field names are
|
the names of the input fields. In our example, the input field names are
|
||||||
'file', 'yourname' and 'filedescription'.
|
'file', 'yourname' and 'filedescription'.
|
||||||
|
|
||||||
curl -F "file=@cooltext.txt" -F "yourname=Daniel" \
|
curl -F "file=@cooltext.txt" -F "yourname=Daniel" \
|
||||||
-F "filedescription=Cool text file with cool text inside" \
|
-F "filedescription=Cool text file with cool text inside" \
|
||||||
http://www.post.com/postit.cgi
|
http://www.post.com/postit.cgi
|
||||||
|
|
||||||
So, to send two files in one post you can do it in two ways:
|
To send two files in one post you can do it in two ways:
|
||||||
|
|
||||||
1. Send multiple files in a single "field" with a single field name:
|
1. Send multiple files in a single "field" with a single field name:
|
||||||
|
|
||||||
@@ -280,11 +280,11 @@ POST (HTTP)
|
|||||||
|
|
||||||
curl -F "docpicture=@dog.gif" -F "catpicture=@cat.gif"
|
curl -F "docpicture=@dog.gif" -F "catpicture=@cat.gif"
|
||||||
|
|
||||||
REFERER
|
REFERRER
|
||||||
|
|
||||||
A HTTP request has the option to include information about which address
|
A HTTP request has the option to include information about which address
|
||||||
that referred to actual page, and curl allows the user to specify that
|
that referred to actual page. Curl allows you to specify the
|
||||||
referrer to get specified on the command line. It is especially useful to
|
referrer to be used on the command line. It is especially useful to
|
||||||
fool or trick stupid servers or CGI scripts that rely on that information
|
fool or trick stupid servers or CGI scripts that rely on that information
|
||||||
being available or contain certain data.
|
being available or contain certain data.
|
||||||
|
|
||||||
@@ -353,13 +353,17 @@ COOKIES
|
|||||||
Note that by specifying -b you enable the "cookie awareness" and with -L
|
Note that by specifying -b you enable the "cookie awareness" and with -L
|
||||||
you can make curl follow a location: (which often is used in combination
|
you can make curl follow a location: (which often is used in combination
|
||||||
with cookies). So that if a site sends cookies and a location, you can
|
with cookies). So that if a site sends cookies and a location, you can
|
||||||
use a non-existing file to trig the cookie awareness like:
|
use a non-existing file to trigger the cookie awareness like:
|
||||||
|
|
||||||
curl -L -b empty-file www.example.com
|
curl -L -b empty.txt www.example.com
|
||||||
|
|
||||||
The file to read cookies from must be formatted using plain HTTP headers OR
|
The file to read cookies from must be formatted using plain HTTP headers OR
|
||||||
as netscape's cookie file. Curl will determine what kind it is based on the
|
as netscape's cookie file. Curl will determine what kind it is based on the
|
||||||
file contents.
|
file contents. In the above command, curl will parse the header and store
|
||||||
|
the cookies received from www.example.com. curl will send to the server the
|
||||||
|
stored cookies which match the request as it follows the location. The
|
||||||
|
file "empty.txt" may be a non-existant file.
|
||||||
|
|
||||||
|
|
||||||
PROGRESS METER
|
PROGRESS METER
|
||||||
|
|
||||||
@@ -392,12 +396,12 @@ PROGRESS METER
|
|||||||
|
|
||||||
SPEED LIMIT
|
SPEED LIMIT
|
||||||
|
|
||||||
Curl offers the user to set conditions regarding transfer speed that must
|
Curl allows the user to set the transfer speed conditions that must be met
|
||||||
be met to let the transfer keep going. By using the switch -y and -Y you
|
to let the transfer keep going. By using the switch -y and -Y you
|
||||||
can make curl abort transfers if the transfer speed doesn't exceed your
|
can make curl abort transfers if the transfer speed is below the specified
|
||||||
given lowest limit for a specified time.
|
lowest limit for a specified time.
|
||||||
|
|
||||||
To let curl abandon downloading this page if its slower than 3000 bytes per
|
To have curl abort the download if the speed is slower than 3000 bytes per
|
||||||
second for 1 minute, run:
|
second for 1 minute, run:
|
||||||
|
|
||||||
curl -y 3000 -Y 60 www.far-away-site.com
|
curl -y 3000 -Y 60 www.far-away-site.com
|
||||||
@@ -587,7 +591,7 @@ HTTPS
|
|||||||
Run the 'openssl' application to convert the certificate. If you cd to the
|
Run the 'openssl' application to convert the certificate. If you cd to the
|
||||||
openssl installation, you can do it like:
|
openssl installation, you can do it like:
|
||||||
|
|
||||||
# ./apps/openssl pkcs12 -certfile [file you saved] -out [PEMfile]
|
# ./apps/openssl pkcs12 -in [file you saved] -clcerts -out [PEMfile]
|
||||||
|
|
||||||
|
|
||||||
RESUMING FILE TRANSFERS
|
RESUMING FILE TRANSFERS
|
||||||
@@ -610,7 +614,7 @@ RESUMING FILE TRANSFERS
|
|||||||
(*1) = This requires that the ftp server supports the non-standard command
|
(*1) = This requires that the ftp server supports the non-standard command
|
||||||
SIZE. If it doesn't, curl will say so.
|
SIZE. If it doesn't, curl will say so.
|
||||||
|
|
||||||
(*2) = This requires that the wb server supports at least HTTP/1.1. If it
|
(*2) = This requires that the web server supports at least HTTP/1.1. If it
|
||||||
doesn't, curl will say so.
|
doesn't, curl will say so.
|
||||||
|
|
||||||
TIME CONDITIONS
|
TIME CONDITIONS
|
||||||
|
@@ -6,6 +6,7 @@ AUTOMAKE_OPTIONS = foreign no-dependencies
|
|||||||
|
|
||||||
man_MANS = \
|
man_MANS = \
|
||||||
curl.1 \
|
curl.1 \
|
||||||
|
curl-config.1 \
|
||||||
curl_easy_cleanup.3 \
|
curl_easy_cleanup.3 \
|
||||||
curl_easy_getinfo.3 \
|
curl_easy_getinfo.3 \
|
||||||
curl_easy_init.3 \
|
curl_easy_init.3 \
|
||||||
@@ -19,10 +20,16 @@ man_MANS = \
|
|||||||
curl_slist_free_all.3 \
|
curl_slist_free_all.3 \
|
||||||
curl_version.3 \
|
curl_version.3 \
|
||||||
curl_escape.3 \
|
curl_escape.3 \
|
||||||
curl_unescape.3
|
curl_unescape.3 \
|
||||||
|
curl_strequal.3 \
|
||||||
|
curl_strnequal.3 \
|
||||||
|
curl_mprintf.3 \
|
||||||
|
curl_global_init.3 \
|
||||||
|
curl_global_cleanup.3 \
|
||||||
|
libcurl.3
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS) \
|
EXTRA_DIST = $(man_MANS) \
|
||||||
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS \
|
||||||
LIBCURL README.win32 RESOURCES TODO TheArtOfHttpScripting
|
LIBCURL README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS
|
||||||
|
|
||||||
SUBDIRS = examples
|
SUBDIRS = examples
|
||||||
|
@@ -22,3 +22,8 @@ README.win32
|
|||||||
in order to extract a separate text file:
|
in order to extract a separate text file:
|
||||||
|
|
||||||
curl -M >manual.txt
|
curl -M >manual.txt
|
||||||
|
|
||||||
|
Download all the libcurl man pages in HTML format using the link on the
|
||||||
|
bottom of this page:
|
||||||
|
|
||||||
|
http://curl.haxx.se/libcurl/c/
|
||||||
|
71
docs/THANKS
Normal file
71
docs/THANKS
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
This project has been alive for several years. Countless people have provided
|
||||||
|
feedback that have improved curl. Here follows a (incomplete) list of people
|
||||||
|
that have contributed with non-trivial parts:
|
||||||
|
|
||||||
|
- Daniel Stenberg <daniel@haxx.se>
|
||||||
|
- Rafael Sagula <sagula@inf.ufrgs.br>
|
||||||
|
- Sampo Kellomaki <sampo@iki.fi>
|
||||||
|
- Linas Vepstas <linas@linas.org>
|
||||||
|
- Bjorn Reese <breese@mail1.stofanet.dk>
|
||||||
|
- Johan Anderson <johan@homemail.com>
|
||||||
|
- Kjell Ericson <Kjell.Ericson@haxx.se>
|
||||||
|
- Troy Engel <tengel@sonic.net>
|
||||||
|
- Ryan Nelson <ryan@inch.com>
|
||||||
|
- Bj<42>rn Stenberg <bjorn@haxx.se>
|
||||||
|
- Angus Mackay <amackay@gus.ml.org>
|
||||||
|
- Eric Young <eay@cryptsoft.com>
|
||||||
|
- Simon Dick <simond@totally.irrelevant.org>
|
||||||
|
- Oren Tirosh <oren@monty.hishome.net>
|
||||||
|
- Steven G. Johnson <stevenj@alum.mit.edu>
|
||||||
|
- Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu>
|
||||||
|
- Andr<64>s Garc<72>a <ornalux@redestb.es>
|
||||||
|
- Douglas E. Wegscheid <wegscd@whirlpool.com>
|
||||||
|
- Mark Butler <butlerm@xmission.com>
|
||||||
|
- Eric Thelin <eric@generation-i.com>
|
||||||
|
- Marc Boucher <marc@mbsi.ca>
|
||||||
|
- Greg Onufer <Greg.Onufer@Eng.Sun.COM>
|
||||||
|
- Doug Kaufman <dkaufman@rahul.net>
|
||||||
|
- David Eriksson <david@2good.com>
|
||||||
|
- Ralph Beckmann <rabe@uni-paderborn.de>
|
||||||
|
- T. Yamada <tai@imasy.or.jp>
|
||||||
|
- Lars J. Aas <larsa@sim.no>
|
||||||
|
- J<>rn Hartroth <Joern.Hartroth@computer.org>
|
||||||
|
- Matthew Clarke <clamat@van.maves.ca>
|
||||||
|
- Linus Nielsen Feltzing <linus@haxx.se>
|
||||||
|
- Felix von Leitner <felix@convergence.de>
|
||||||
|
- Dan Zitter <dzitter@zitter.net>
|
||||||
|
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
||||||
|
- Chris Maltby <chris@aurema.com>
|
||||||
|
- Ron Zapp <rzapper@yahoo.com>
|
||||||
|
- Paul Marquis <pmarquis@iname.com>
|
||||||
|
- Ellis Pritchard <ellis@citria.com>
|
||||||
|
- Damien Adant <dams@usa.net>
|
||||||
|
- Chris <cbayliss@csc.come>
|
||||||
|
- Marco G. Salvagno <mgs@whiz.cjb.net>
|
||||||
|
- Paul Marquis <pmarquis@iname.com>
|
||||||
|
- David LeBlanc <dleblanc@qnx.com>
|
||||||
|
- Rich Gray at Plus Technologies
|
||||||
|
- Luong Dinh Dung <u8luong@lhsystems.hu>
|
||||||
|
- Torsten Foertsch <torsten.foertsch@gmx.net>
|
||||||
|
- Kristian K<>hntopp <kris@koehntopp.de>
|
||||||
|
- Fred Noz <FNoz@siac.com>
|
||||||
|
- Caolan McNamara <caolan@csn.ul.ie>
|
||||||
|
- Albert Chin-A-Young <china@thewrittenword.com>
|
||||||
|
- Stephen Kick <skick@epicrealm.com>
|
||||||
|
- Martin Hedenfalk <mhe@stacken.kth.se>
|
||||||
|
- Richard Prescott
|
||||||
|
- Jason S. Priebe <priebe@wral-tv.com>
|
||||||
|
- T. Bharath <TBharath@responsenetworks.com>
|
||||||
|
- Alexander Kourakos <awk@users.sourceforge.net>
|
||||||
|
- James Griffiths <griffiths_james@yahoo.com>
|
||||||
|
- Loic Dachary <loic@senga.org>
|
||||||
|
- Robert Weaver <robert.weaver@sabre.com>
|
||||||
|
- Ingo Ralf Blum <ingoralfblum@ingoralfblum.com>
|
||||||
|
- Jun-ichiro itojun Hagino <itojun@iijlab.net>
|
||||||
|
- Frederic Lepied <flepied@mandrakesoft.com>
|
||||||
|
- Georg Horn <horn@koblenz-net.de>
|
||||||
|
- Cris Bailiff <c.bailiff@awayweb.com>
|
||||||
|
- Sterling Hughes <sterling@designmultimedia.com>
|
||||||
|
- S. Moonesamy
|
||||||
|
- Ingo Wilken <iw@WWW.Ecce-Terram.DE>
|
||||||
|
- Pawel A. Gajda <mis@k2.net.pl>
|
71
docs/TODO
71
docs/TODO
@@ -7,33 +7,51 @@
|
|||||||
TODO
|
TODO
|
||||||
|
|
||||||
Things to do in project cURL. Please tell me what you think, contribute and
|
Things to do in project cURL. Please tell me what you think, contribute and
|
||||||
send me patches that improve things!
|
send me patches that improve things! Also check the http://curl.haxx.se/dev
|
||||||
|
web section for various development notes.
|
||||||
To do for the next release:
|
|
||||||
|
|
||||||
* Make SSL session ids get used if multiple HTTPS documents from the same
|
|
||||||
host is requested.
|
|
||||||
|
|
||||||
* Document the undocumented libcurl functions: the printf clones (like
|
|
||||||
curl_msprintf, curl_mfprintf, curl_msnprintf, curl_maprintf and
|
|
||||||
curl_mvfprintf) and the string compare functions (curl_strequal
|
|
||||||
and curl_strnequal).
|
|
||||||
|
|
||||||
To do in a future release (random order):
|
To do in a future release (random order):
|
||||||
|
|
||||||
* Rewrite parts of the test suite. Make a (XML?) format to store all
|
* It would be nice to be able to use "-d" (or something similar) to attach
|
||||||
test-data in a single for a single test case. The current system makes far
|
parameters of EITHER the GET or POST type... It would either require
|
||||||
too many separate files. We also need to have the test suite support
|
another curl argument to specify "GET" (obviously the default should remain
|
||||||
different behaviors, like when libcurl is compiled for IPv6 support and
|
POST), or it would require a new curl argument (perhaps -G/--get-data).
|
||||||
thus performs a different set of FTP commands.
|
|
||||||
|
I know we're running out of letters, but it somehow feels a little
|
||||||
|
"cleaner" to just tag on each of your HTTP "parameters" (data-items) one by
|
||||||
|
one and let curl put them together, rather than having to put them together
|
||||||
|
myself and include them in the URL.
|
||||||
|
|
||||||
|
* Add an interface that enables a user to select prefered SSL ciphers to use.
|
||||||
|
|
||||||
|
* Make curl deal with cookies better. libcurl should be able to maintain a
|
||||||
|
"cookie jar". Updating it with cookies that is received, and using it to
|
||||||
|
pass cookies to the servers that have matching cookies in the jar.
|
||||||
|
http://curl.haxx.se/dev/cookie-jar.txt
|
||||||
|
|
||||||
|
* Consider an interface to libcurl that allows applications to easier get to
|
||||||
|
know what cookies that are sent back in the response headers.
|
||||||
|
|
||||||
|
* Make SSL session ids get used if multiple HTTPS documents from the same
|
||||||
|
host is requested. http://curl.haxx.se/dev/SSL_session_id.txt
|
||||||
|
|
||||||
|
* HTTP PUT for files passed on stdin. Requires libcurl to send the file
|
||||||
|
with chunked content encoding. http://curl.haxx.se/dev/HTTP-PUT-stdin.txt
|
||||||
|
|
||||||
|
* Introduce another callback interface for upload/download that makes one
|
||||||
|
less copy of data and thus a faster operation.
|
||||||
|
http://curl.haxx.se/dev/no_copy_callbacks.txt
|
||||||
|
|
||||||
|
* Suggested on the mailing list: CURLOPT_FTP_MKDIR...!
|
||||||
|
|
||||||
* Add configure options that disables certain protocols in libcurl to
|
* Add configure options that disables certain protocols in libcurl to
|
||||||
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
decrease footprint. '--disable-[protocol]' where protocol is http, ftp,
|
||||||
telnet, ldap, dict or file.
|
telnet, ldap, dict or file.
|
||||||
|
|
||||||
* Extend the test suite to include telnet and https. The telnet could just do
|
* Extend the test suite to include telnet. The telnet could just do ftp or
|
||||||
ftp or http operations (for which we have test servers) and the https would
|
http operations (for which we have test servers).
|
||||||
probably work against/with some of the openssl tools.
|
|
||||||
|
* Make TELNET work on windows!
|
||||||
|
|
||||||
* 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. libcurl already is capable of fetching the remote
|
stamp as the remote file. libcurl already is capable of fetching the remote
|
||||||
@@ -45,16 +63,12 @@ To do in a future release (random order):
|
|||||||
(http://gnutls.hellug.gr/)
|
(http://gnutls.hellug.gr/)
|
||||||
|
|
||||||
* 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. http://curl.haxx.se/dev/async-resolver.txt
|
||||||
|
|
||||||
* 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".
|
||||||
|
|
||||||
* Add support for other languages than C. C++ (rumours have been heard about
|
* Add libcurl support/interfaces for more languages. C++ wrapper perhaps?
|
||||||
something being worked on in this area) and perl (we have seen the first
|
|
||||||
versions of this!) comes to mind. Python anyone?
|
|
||||||
|
|
||||||
* "Content-Encoding: compress/gzip/zlib" HTTP 1.1 clearly defines how to get
|
* "Content-Encoding: compress/gzip/zlib" HTTP 1.1 clearly defines how to get
|
||||||
and decode compressed documents. There is the zlib that is pretty good at
|
and decode compressed documents. There is the zlib that is pretty good at
|
||||||
@@ -86,10 +100,7 @@ To do in a future release (random order):
|
|||||||
* 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. (This is partly done.) RFC 2428 "FTP
|
* Full IPv6 Awareness and support. (This is partly done.) RFC 2428 "FTP
|
||||||
Extensions for IPv6 and NATs" is interesting. PORT should be replaced with
|
Extensions for IPv6 and NATs" is interesting. PORT should be replaced with
|
||||||
EPRT for IPv6 (done), and EPSV instead of PASV. HTTP proxies are left to
|
EPRT for IPv6 (done), and EPSV instead of PASV.
|
||||||
add support for.
|
|
||||||
|
|
||||||
* SSL for more protocols, like SSL-FTP...
|
|
||||||
(http://search.ietf.org/internet-drafts/draft-murray-auth-ftp-ssl-05.txt)
|
|
||||||
|
59
docs/curl-config.1
Normal file
59
docs/curl-config.1
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man curl-config.1
|
||||||
|
.\" Written by Daniel Stenberg
|
||||||
|
.\"
|
||||||
|
.TH curl-config 1 "28 May 2001" "Curl 7.8" "curl-config manual"
|
||||||
|
.SH NAME
|
||||||
|
curl-config \- Get information about a libcurl installation
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B curl-config [options]
|
||||||
|
.SH DESCRIPTION
|
||||||
|
.B curl-config
|
||||||
|
displays information about a previous curl and libcurl installation.
|
||||||
|
.SH OPTIONS
|
||||||
|
.IP "--cflags"
|
||||||
|
What set of CFLAGS that was used when libcurl was built. This is mostly a
|
||||||
|
debug option that serves no particular use to most people.
|
||||||
|
.IP "--feature"
|
||||||
|
Lists what particular main features the installed libcurl was built with. At
|
||||||
|
the time of writing, this list may include SSL, KRB4 or IPv6. Do not assume
|
||||||
|
any particular order. The keywords will be separated by newlines. There may be
|
||||||
|
none, one or several keywords in the list.
|
||||||
|
.IP "--help"
|
||||||
|
Displays the available options.
|
||||||
|
.IP "--libs"
|
||||||
|
Shows the complete set of libs and other linker options you will need in order
|
||||||
|
to link your application with libcurl.
|
||||||
|
.IP "--prefix"
|
||||||
|
This is the prefix used when libcurl was installed. Libcurl is then installed
|
||||||
|
in $prefix/lib and its header files are installed in $prefix/include and so
|
||||||
|
on. The prefix is set with "configure --prefix".
|
||||||
|
.IP "--version"
|
||||||
|
Outputs version information about the installed libcurl.
|
||||||
|
.IP "--vernum"
|
||||||
|
Outputs version information about the installed libcurl, in numerical mode.
|
||||||
|
This outputs the version number, in hexadecimal, with 8 bits for each part;
|
||||||
|
major, minor, patch. So that libcurl 7.7.4 would appear as 070704 and libcurl
|
||||||
|
12.13.14 would appear as 0c0d0e...
|
||||||
|
.SH "EXAMPLES"
|
||||||
|
What is the path to the curl header files?
|
||||||
|
|
||||||
|
echo `curl-config --prefix`/include
|
||||||
|
|
||||||
|
What is the path to libcurl?
|
||||||
|
|
||||||
|
echo `curl-config --prefix`/lib
|
||||||
|
|
||||||
|
What other linker options do I need when I link with libcurl?
|
||||||
|
|
||||||
|
curl-config --libs
|
||||||
|
|
||||||
|
How do I know if libcurl was built with SSL support?
|
||||||
|
|
||||||
|
curl-config --feature | grep SSL
|
||||||
|
|
||||||
|
What's the installed libcurl version?
|
||||||
|
|
||||||
|
curl-config --version
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl (1)
|
159
docs/curl.1
159
docs/curl.1
@@ -2,7 +2,7 @@
|
|||||||
.\" nroff -man curl.1
|
.\" nroff -man curl.1
|
||||||
.\" Written by Daniel Stenberg
|
.\" Written by Daniel Stenberg
|
||||||
.\"
|
.\"
|
||||||
.TH curl 1 "15 March 2001" "Curl 7.7" "Curl Manual"
|
.TH curl 1 "3 Aug 2001" "Curl 7.8" "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.
|
||||||
@@ -39,14 +39,14 @@ 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
|
You can specify any amount of URLs on the command line. They will be fetched
|
||||||
line. They will be fetched in a sequential manner in the specified order.
|
in a sequential manner in the specified order.
|
||||||
|
|
||||||
Starting with curl 7.7, curl will attempt to re-use connections for multiple
|
Curl will attempt to re-use connections for multiple file transfers, so that
|
||||||
file transfers, so that getting many files from the same server will not do
|
getting many files from the same server will not do multiple connects /
|
||||||
multiple connects/handshakes. This improves speed. Of course this is only done
|
handshakes. This improves speed. Of course this is only done on files
|
||||||
on files specified on a single command line and cannot be used between
|
specified on a single command line and cannot be used between separate curl
|
||||||
separate curl invokes.
|
invokes.
|
||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
.IP "-a/--append"
|
.IP "-a/--append"
|
||||||
(FTP)
|
(FTP)
|
||||||
@@ -62,7 +62,7 @@ fail if its not set to "Mozilla/4.0". To encode blanks in the string,
|
|||||||
surround the string with single quote marks. This can also be set with the
|
surround the string with single quote marks. This can also be set with the
|
||||||
-H/--header flag of course.
|
-H/--header flag of course.
|
||||||
|
|
||||||
If this option is used more than once, the last one will be the one to be
|
If this option is set more than once, the last one will be the one that's
|
||||||
used.
|
used.
|
||||||
.IP "-b/--cookie <name=data>"
|
.IP "-b/--cookie <name=data>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
@@ -72,18 +72,18 @@ The data should be in the format "NAME1=VALUE1; NAME2=VALUE2".
|
|||||||
|
|
||||||
If no '=' letter is used in the line, it is treated as a filename to use to
|
If no '=' letter is used in the line, it is treated as a filename to use to
|
||||||
read previously stored cookie lines from, which should be used in this session
|
read previously stored cookie lines from, which should be used in this session
|
||||||
if they match. Using this method also activates the "cookie parser" which
|
if they match. Using this method also activates the "cookie parser" which will
|
||||||
will make curl record incoming cookies too, which may be handy if you're using
|
make curl record incoming cookies too, which may be handy if you're using this
|
||||||
this in combination with the -L/--location option. The file format of the file
|
in combination with the -L/--location option. The file format of the file to
|
||||||
to read cookies from should be plain HTTP headers or the netscape cookie file
|
read cookies from should be plain HTTP headers or the Netscape/Mozilla cookie
|
||||||
format.
|
file format.
|
||||||
|
|
||||||
.B NOTE
|
.B NOTE
|
||||||
that the file specified with -b/--cookie is only used as input. No cookies
|
that the file specified with -b/--cookie is only used as input. No cookies
|
||||||
will be stored in the file. To store cookies, save the HTTP headers to a file
|
will be stored in the file. To store cookies, save the HTTP headers to a file
|
||||||
using -D/--dump-header!
|
using -D/--dump-header!
|
||||||
|
|
||||||
If this option is used more than once, the last one will be the one to be
|
If this option is set more than once, the last one will be the one that's
|
||||||
used.
|
used.
|
||||||
.IP "-B/--use-ascii"
|
.IP "-B/--use-ascii"
|
||||||
Use ASCII transfer when getting an FTP file or LDAP info. For FTP, this can
|
Use ASCII transfer when getting an FTP file or LDAP info. For FTP, this can
|
||||||
@@ -94,11 +94,12 @@ If this option is used twice, the second one will disable ASCII usage.
|
|||||||
.IP "--connect-timeout <seconds>"
|
.IP "--connect-timeout <seconds>"
|
||||||
Maximum time in seconds that you allow the connection to the server to take.
|
Maximum time in seconds that you allow the connection to the server to take.
|
||||||
This only limits the connection phase, once curl has connected this option is
|
This only limits the connection phase, once curl has connected this option is
|
||||||
of no more use. This option doesn't work in win32 systems. See also the
|
of no more use. This option didn't work in win32 systems until 7.7.2. See
|
||||||
|
also the
|
||||||
.I "--max-time"
|
.I "--max-time"
|
||||||
option.
|
option.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-c/--continue"
|
.IP "-c/--continue"
|
||||||
.B Deprecated. Use '-C -' instead.
|
.B Deprecated. Use '-C -' instead.
|
||||||
Continue/Resume a previous file transfer. This instructs curl to
|
Continue/Resume a previous file transfer. This instructs curl to
|
||||||
@@ -117,7 +118,7 @@ If used with uploads, the ftp server command SIZE will not be used by
|
|||||||
curl. Upload resume is for FTP only.
|
curl. Upload resume is for FTP only.
|
||||||
HTTP resume is only possible with HTTP/1.1 or later servers.
|
HTTP resume is only possible with HTTP/1.1 or later servers.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-d/--data <data>"
|
.IP "-d/--data <data>"
|
||||||
(HTTP) Sends the specified data in a POST request to the HTTP server, in a way
|
(HTTP) Sends the specified data in a POST request to the HTTP server, in a way
|
||||||
that can emulate as if a user has filled in a HTML form and pressed the submit
|
that can emulate as if a user has filled in a HTML form and pressed the submit
|
||||||
@@ -128,23 +129,24 @@ content-type application/x-www-form-urlencoded. Compare to -F. If more than
|
|||||||
one -d/--data option is used on the same command line, the data pieces
|
one -d/--data option is used on the same command line, the data pieces
|
||||||
specified will be merged together with a separating &-letter. Thus, using '-d
|
specified will be merged together with a separating &-letter. Thus, using '-d
|
||||||
name=daniel -d skill=lousy' would generate a post chunk that looks like
|
name=daniel -d skill=lousy' would generate a post chunk that looks like
|
||||||
'name=daniel&skill=lousy'.
|
\&'name=daniel&skill=lousy'.
|
||||||
|
|
||||||
If you start the data with the letter @, the rest should be a file name to
|
If you start the data with the letter @, the rest should be a file name to
|
||||||
read the data from, or - if you want curl to read the data from stdin. The
|
read the data from, or - if you want curl to read the data from stdin. The
|
||||||
contents of the file must already be url-encoded. Multiple files can also be
|
contents of the file must already be url-encoded. Multiple files can also be
|
||||||
specified.
|
specified. Posting data from a file named 'foobar' would thus be done with
|
||||||
|
"--data @foobar".
|
||||||
|
|
||||||
To post data purely binary, you should instead use the --data-binary option.
|
To post data purely binary, you should instead use the --data-binary option.
|
||||||
|
|
||||||
-d/--data is the same as --data-ascii.
|
-d/--data is the same as --data-ascii.
|
||||||
|
|
||||||
If this option is used serveral times, the ones following the first will
|
If this option is used several times, the ones following the first will
|
||||||
append data.
|
append data.
|
||||||
.IP "--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 ones following the first will
|
If this option is used several times, the ones following the first will
|
||||||
append data.
|
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
|
||||||
@@ -152,9 +154,9 @@ using this option the entire context of the posted data is kept as-is. If you
|
|||||||
want to post a binary file without the strip-newlines feature of the
|
want to post a binary file without the strip-newlines feature of the
|
||||||
--data-ascii option, this is for you.
|
--data-ascii option, this is for you.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
|
|
||||||
If this option is used serveral times, the ones following the first will
|
If this option is used several times, the ones following the first will
|
||||||
append data.
|
append data.
|
||||||
.IP "-D/--dump-header <file>"
|
.IP "-D/--dump-header <file>"
|
||||||
(HTTP/FTP)
|
(HTTP/FTP)
|
||||||
@@ -165,7 +167,7 @@ This option is handy to use when you want to store the cookies that a HTTP
|
|||||||
site sends to you. The cookies could then be read in a second curl invoke by
|
site sends to you. The cookies could then be read in a second curl invoke by
|
||||||
using the -b/--cookie option!
|
using the -b/--cookie option!
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-e/--referer <URL>"
|
.IP "-e/--referer <URL>"
|
||||||
(HTTP) Sends the "Referer Page" information to the HTTP server. This can also
|
(HTTP) Sends the "Referer Page" information to the HTTP server. This can also
|
||||||
be set with the -H/--header flag of course. When used with
|
be set with the -H/--header flag of course. When used with
|
||||||
@@ -174,7 +176,7 @@ you can append ";auto" to the referer URL to make curl automatically set the
|
|||||||
previous URL when it follows a Location: header. The ";auto" string can be
|
previous URL when it follows a Location: header. The ";auto" string can be
|
||||||
used alone, even if you don't set an initial referer.
|
used alone, even if you don't set an initial referer.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--egd-file <file>"
|
.IP "--egd-file <file>"
|
||||||
(HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The
|
(HTTPS) Specify the path name to the Entropy Gathering Daemon socket. The
|
||||||
socket is used to seed the random engine for SSL connections. See also the
|
socket is used to seed the random engine for SSL connections. See also the
|
||||||
@@ -188,12 +190,12 @@ If the optional password isn't specified, it will be queried for on
|
|||||||
the terminal. Note that this certificate is the private key and the private
|
the terminal. Note that this certificate is the private key and the private
|
||||||
certificate concatenated!
|
certificate concatenated!
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--cacert <CA certificate>"
|
.IP "--cacert <CA certificate>"
|
||||||
(HTTPS) Tells curl to use the specified certificate file to verify the
|
(HTTPS) Tells curl to use the specified certificate file to verify the
|
||||||
peer. The certificate must be in PEM format.
|
peer. The certificate must be in PEM format.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-f/--fail"
|
.IP "-f/--fail"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Fail silently (no output at all) on server errors. This is mostly done
|
Fail silently (no output at all) on server errors. This is mostly done
|
||||||
@@ -215,7 +217,7 @@ get attached in the post as a file upload, while the < makes a text field and
|
|||||||
just get the contents for that text field from a file.
|
just get the contents for that text field from a file.
|
||||||
|
|
||||||
Example, to send your password file to the server, where
|
Example, to send your password file to the server, where
|
||||||
'password' is the name of the form-field to which /etc/passwd will be the
|
\&'password' is the name of the form-field to which /etc/passwd will be the
|
||||||
input:
|
input:
|
||||||
|
|
||||||
.B curl
|
.B curl
|
||||||
@@ -256,7 +258,7 @@ name, IP address or host name. An example could look like:
|
|||||||
|
|
||||||
.B "curl --interface eth0:1 http://www.netscape.com/"
|
.B "curl --interface eth0:1 http://www.netscape.com/"
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-I/--head"
|
.IP "-I/--head"
|
||||||
(HTTP/FTP)
|
(HTTP/FTP)
|
||||||
Fetch the HTTP-header only! HTTP-servers feature the command HEAD
|
Fetch the HTTP-header only! HTTP-servers feature the command HEAD
|
||||||
@@ -269,7 +271,7 @@ If this option is used twice, the second will again disable header only.
|
|||||||
should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use
|
should be one of 'clear', 'safe', 'confidential' or 'private'. Should you use
|
||||||
a level that is not one of these, 'private' will instead be used.
|
a level that is not one of these, 'private' will instead be used.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-K/--config <config file>"
|
.IP "-K/--config <config file>"
|
||||||
Specify which config file to read curl arguments from. The config file is a
|
Specify which config file to read curl arguments from. The config file is a
|
||||||
text file in which command line arguments can be written which then will be
|
text file in which command line arguments can be written which then will be
|
||||||
@@ -307,7 +309,7 @@ See also the
|
|||||||
.I "--connect-timeout"
|
.I "--connect-timeout"
|
||||||
option.
|
option.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-M/--manual"
|
.IP "-M/--manual"
|
||||||
Manual. Display the huge help text.
|
Manual. Display the huge help text.
|
||||||
.IP "-n/--netrc"
|
.IP "-n/--netrc"
|
||||||
@@ -325,7 +327,7 @@ directory.
|
|||||||
A quick and very simple example of how to setup a
|
A quick and very simple example of how to setup a
|
||||||
.I .netrc
|
.I .netrc
|
||||||
to allow curl to ftp to the machine host.domain.com with user name
|
to allow curl to ftp to the machine host.domain.com with user name
|
||||||
'myself' and password 'secret' should look similar to:
|
\&'myself' and password 'secret' should look similar to:
|
||||||
|
|
||||||
.B "machine host.domain.com login myself password secret"
|
.B "machine host.domain.com login myself password secret"
|
||||||
|
|
||||||
@@ -385,7 +387,7 @@ i.e "my.host.domain" to specify machine
|
|||||||
(any single-letter string) to make it pick the machine's default
|
(any single-letter string) to make it pick the machine's default
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-q"
|
.IP "-q"
|
||||||
If used as the first parameter on the command line, the
|
If used as the first parameter on the command line, the
|
||||||
.I $HOME/.curlrc
|
.I $HOME/.curlrc
|
||||||
@@ -444,7 +446,7 @@ document.
|
|||||||
FTP range downloads only support the simple syntax 'start-stop' (optionally
|
FTP range downloads only support the simple syntax 'start-stop' (optionally
|
||||||
with one of the numbers omitted). It depends on the non-RFC command SIZE.
|
with one of the numbers omitted). It depends on the non-RFC command SIZE.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-s/--silent"
|
.IP "-s/--silent"
|
||||||
Silent mode. Don't show progress meter or error messages. Makes
|
Silent mode. Don't show progress meter or error messages. Makes
|
||||||
Curl mute.
|
Curl mute.
|
||||||
@@ -471,18 +473,18 @@ think that your last directory name is the remote file name to
|
|||||||
use. That will most likely cause the upload operation to fail. If
|
use. That will most likely cause the upload operation to fail. If
|
||||||
this is used on a http(s) server, the PUT command will be used.
|
this is used on a http(s) server, the PUT command will be used.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-u/--user <user:password>"
|
.IP "-u/--user <user:password>"
|
||||||
Specify user and password to use when fetching. See README.curl for detailed
|
Specify user and password to use when fetching. See README.curl for detailed
|
||||||
examples of how to use this. If no password is specified, curl will
|
examples of how to use this. If no password is specified, curl will
|
||||||
ask for it interactively.
|
ask for it interactively.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-U/--proxy-user <user:password>"
|
.IP "-U/--proxy-user <user:password>"
|
||||||
Specify user and password to use for Proxy authentication. If no
|
Specify user and password to use for Proxy authentication. If no
|
||||||
password is specified, curl will ask for it interactively.
|
password is specified, curl will ask for it interactively.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--url <URL>"
|
.IP "--url <URL>"
|
||||||
Specify a URL to fetch. This option is mostly handy when you wanna specify
|
Specify a URL to fetch. This option is mostly handy when you wanna specify
|
||||||
URL(s) in a config file.
|
URL(s) in a config file.
|
||||||
@@ -565,12 +567,12 @@ The average download speed that curl measured for the complete download.
|
|||||||
The average upload speed that curl measured for the complete upload.
|
The average upload speed that curl measured for the complete upload.
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-x/--proxy <proxyhost[:port]>"
|
.IP "-x/--proxy <proxyhost[:port]>"
|
||||||
Use specified proxy. If the port number is not specified, it is assumed at
|
Use specified proxy. If the port number is not specified, it is assumed at
|
||||||
port 1080.
|
port 1080.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-X/--request <command>"
|
.IP "-X/--request <command>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Specifies a custom request to use when communicating with the HTTP server.
|
Specifies a custom request to use when communicating with the HTTP server.
|
||||||
@@ -581,19 +583,19 @@ HTTP 1.1 specification for details and explanations.
|
|||||||
Specifies a custom FTP command to use instead of LIST when doing file lists
|
Specifies a custom FTP command to use instead of LIST when doing file lists
|
||||||
with ftp.
|
with ftp.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-y/--speed-time <time>"
|
.IP "-y/--speed-time <time>"
|
||||||
If a download is slower than speed-limit bytes per second during a speed-time
|
If a download is slower than speed-limit bytes per second during a speed-time
|
||||||
period, the download gets aborted. If speed-time is used, the default
|
period, the download gets aborted. If speed-time is used, the default
|
||||||
speed-limit will be 1 unless set with -y.
|
speed-limit will be 1 unless set with -y.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-Y/--speed-limit <speed>"
|
.IP "-Y/--speed-limit <speed>"
|
||||||
If a download is slower than this given speed, in bytes per second, for
|
If a download is slower than this given speed, in bytes per second, for
|
||||||
speed-time seconds it gets aborted. speed-time is set with -Y and is 30 if
|
speed-time seconds it gets aborted. speed-time is set with -Y and is 30 if
|
||||||
not set.
|
not set.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-z/--time-cond <date expression>"
|
.IP "-z/--time-cond <date expression>"
|
||||||
(HTTP)
|
(HTTP)
|
||||||
Request to get a file that has been modified later than the given time and
|
Request to get a file that has been modified later than the given time and
|
||||||
@@ -609,7 +611,7 @@ Start the date expression with a dash (-) to make it request for a document
|
|||||||
that is older than the given date/time, default is a document that is newer
|
that is older than the given date/time, default is a document that is newer
|
||||||
than the specified date/time.
|
than the specified date/time.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "-3/--sslv3"
|
.IP "-3/--sslv3"
|
||||||
(HTTPS)
|
(HTTPS)
|
||||||
Forces curl to use SSL version 3 when negotiating with a remote SSL server.
|
Forces curl to use SSL version 3 when negotiating with a remote SSL server.
|
||||||
@@ -630,7 +632,7 @@ Redirect all writes to stderr to the specified file instead. If the file name
|
|||||||
is a plain '-', it is instead written to stdout. This option has no point when
|
is a plain '-', it is instead written to stdout. This option has no point when
|
||||||
you're using a shell with decent redirecting capabilities.
|
you're using a shell with decent redirecting capabilities.
|
||||||
|
|
||||||
If this option is used serveral times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.SH FILES
|
.SH FILES
|
||||||
.I ~/.curlrc
|
.I ~/.curlrc
|
||||||
.RS
|
.RS
|
||||||
@@ -755,73 +757,18 @@ Interface error. A specified outgoing interface could not be used.
|
|||||||
Bad password entered. An error was signalled when the password was entered.
|
Bad password entered. An error was signalled when the password was entered.
|
||||||
.IP 47
|
.IP 47
|
||||||
Too many redirects. When following redirects, curl hit the maximum amount.
|
Too many redirects. When following redirects, curl hit the maximum amount.
|
||||||
|
.IP 48
|
||||||
|
Unknown TELNET option specified.
|
||||||
|
.IP 49
|
||||||
|
Malformed telnet option.
|
||||||
.IP XX
|
.IP XX
|
||||||
There will appear more error codes here in future releases. The existing ones
|
There will appear more error codes here in future releases. The existing ones
|
||||||
are meant to never change.
|
are meant to never change.
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
If you do find bugs, mail them to curl-bug@haxx.se.
|
If you do find bugs, mail them to curl-bug@haxx.se.
|
||||||
.SH AUTHORS / CONTRIBUTORS
|
.SH AUTHORS / CONTRIBUTORS
|
||||||
- Daniel Stenberg <Daniel.Stenberg@haxx.se>
|
Daniel Stenberg is the main author, but the whole list of contributors is
|
||||||
- Rafael Sagula <sagula@inf.ufrgs.br>
|
found in the separate THANKS file.
|
||||||
- Sampo Kellomaki <sampo@iki.fi>
|
|
||||||
- Linas Vepstas <linas@linas.org>
|
|
||||||
- Bjorn Reese <breese@mail1.stofanet.dk>
|
|
||||||
- Johan Anderson <johan@homemail.com>
|
|
||||||
- Kjell Ericson <Kjell.Ericson@haxx.se>
|
|
||||||
- Troy Engel <tengel@sonic.net>
|
|
||||||
- Ryan Nelson <ryan@inch.com>
|
|
||||||
- Bj<42>rn Stenberg <Bjorn.Stenberg@haxx.se>
|
|
||||||
- Angus Mackay <amackay@gus.ml.org>
|
|
||||||
- Eric Young <eay@cryptsoft.com>
|
|
||||||
- Simon Dick <simond@totally.irrelevant.org>
|
|
||||||
- Oren Tirosh <oren@monty.hishome.net>
|
|
||||||
- Steven G. Johnson <stevenj@alum.mit.edu>
|
|
||||||
- Gilbert Ramirez Jr. <gram@verdict.uthscsa.edu>
|
|
||||||
- Andr<64>s Garc<72>a <ornalux@redestb.es>
|
|
||||||
- Douglas E. Wegscheid <wegscd@whirlpool.com>
|
|
||||||
- Mark Butler <butlerm@xmission.com>
|
|
||||||
- Eric Thelin <eric@generation-i.com>
|
|
||||||
- Marc Boucher <marc@mbsi.ca>
|
|
||||||
- Greg Onufer <Greg.Onufer@Eng.Sun.COM>
|
|
||||||
- Doug Kaufman <dkaufman@rahul.net>
|
|
||||||
- David Eriksson <david@2good.com>
|
|
||||||
- Ralph Beckmann <rabe@uni-paderborn.de>
|
|
||||||
- T. Yamada <tai@imasy.or.jp>
|
|
||||||
- Lars J. Aas <larsa@sim.no>
|
|
||||||
- J<>rn Hartroth <Joern.Hartroth@computer.org>
|
|
||||||
- Matthew Clarke <clamat@van.maves.ca>
|
|
||||||
- Linus Nielsen Feltzing <linus@haxx.se>
|
|
||||||
- Felix von Leitner <felix@convergence.de>
|
|
||||||
- Dan Zitter <dzitter@zitter.net>
|
|
||||||
- Jongki Suwandi <Jongki.Suwandi@eng.sun.com>
|
|
||||||
- Chris Maltby <chris@aurema.com>
|
|
||||||
- Ron Zapp <rzapper@yahoo.com>
|
|
||||||
- Paul Marquis <pmarquis@iname.com>
|
|
||||||
- Ellis Pritchard <ellis@citria.com>
|
|
||||||
- Damien Adant <dams@usa.net>
|
|
||||||
- Chris <cbayliss@csc.come>
|
|
||||||
- Marco G. Salvagno <mgs@whiz.cjb.net>
|
|
||||||
- Paul Marquis <pmarquis@iname.com>
|
|
||||||
- David LeBlanc <dleblanc@qnx.com>
|
|
||||||
- Rich Gray at Plus Technologies
|
|
||||||
- Luong Dinh Dung <u8luong@lhsystems.hu>
|
|
||||||
- Torsten Foertsch <torsten.foertsch@gmx.net>
|
|
||||||
- Kristian K<>hntopp <kris@koehntopp.de>
|
|
||||||
- Fred Noz <FNoz@siac.com>
|
|
||||||
- Caolan McNamara <caolan@csn.ul.ie>
|
|
||||||
- Albert Chin-A-Young <china@thewrittenword.com>
|
|
||||||
- Stephen Kick <skick@epicrealm.com>
|
|
||||||
- Martin Hedenfalk <mhe@stacken.kth.se>
|
|
||||||
- Richard Prescott
|
|
||||||
- Jason S. Priebe <priebe@wral-tv.com>
|
|
||||||
- T. Bharath <TBharath@responsenetworks.com>
|
|
||||||
- Alexander Kourakos <awk@users.sourceforge.net>
|
|
||||||
- James Griffiths <griffiths_james@yahoo.com>
|
|
||||||
- Loic Dachary <loic@senga.org>
|
|
||||||
- Robert Weaver <robert.weaver@sabre.com>
|
|
||||||
- Ingo Ralf Blum <ingoralfblum@ingoralfblum.com>
|
|
||||||
- Jun-ichiro itojun Hagino <itojun@iijlab.net>
|
|
||||||
|
|
||||||
.SH WWW
|
.SH WWW
|
||||||
http://curl.haxx.se
|
http://curl.haxx.se
|
||||||
.SH FTP
|
.SH FTP
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_cleanup 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_easy_cleanup 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
@@ -8,7 +8,7 @@ curl_easy_cleanup - End a libcurl session
|
|||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.B #include <curl/curl.h>
|
||||||
.sp
|
.sp
|
||||||
.BI "curl_easy_cleanup(CURL *" handle ");"
|
.BI "void curl_easy_cleanup(CURL *" handle ");"
|
||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
This function must be the last function to call for a curl session. It is the
|
This function must be the last function to call for a curl session. It is the
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.6.1" "libcurl Manual"
|
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.6.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_easy_init 3 "5 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_perform 3 "5 Mar 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_easy_perform 3 "5 Mar 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -1,14 +1,14 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_easy_setopt 3 "13 March 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_easy_setopt 3 "1 June 2001" "libcurl 7.8" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_setopt - Set curl easy-session options
|
curl_easy_setopt - Set curl easy-session options
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B #include <curl/curl.h>
|
.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
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_easy_setopt() is called to tell libcurl how to behave in a number of
|
curl_easy_setopt() is called to tell libcurl how to behave in a number of
|
||||||
@@ -42,54 +42,43 @@ call.
|
|||||||
These options are in a bit of random order, but you'll figure it out!
|
These options are in a bit of random order, but you'll figure it out!
|
||||||
.TP 0.8i
|
.TP 0.8i
|
||||||
.B CURLOPT_FILE
|
.B CURLOPT_FILE
|
||||||
Data pointer to pass instead of FILE * to the file write function. Note that
|
Data pointer to pass to 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. If you don't use a callback, you
|
||||||
|
must pass a 'FILE *' as libcurl passes it to fwrite() when writing data.
|
||||||
|
|
||||||
NOTE: If you're using libcurl as a win32 .DLL, you MUST use a
|
NOTE: If you're using libcurl as a win32 DLL, you MUST use the
|
||||||
.I CURLOPT_WRITEFUNCTION
|
\fICURLOPT_WRITEFUNCTION\fP if you set this option.
|
||||||
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 match the following prototype:
|
||||||
.BI "size_t function( void *ptr, size_t size, size_t nmemb, FILE *stream);"
|
.BI "size_t function( void *ptr, size_t size, size_t nmemb, void *stream);"
|
||||||
This function gets called by libcurl as soon as there is received data that
|
This function gets called by libcurl as soon as there is received data that
|
||||||
needs to be written down. The size of the data pointed to by
|
needs to be written down. The size of the data pointed to by \fIptr\fP is
|
||||||
.I ptr
|
\fIsize\fP multiplied with \fInmemb\fP. Return the number of bytes actually
|
||||||
is
|
written or return -1 to signal error to the library (it will cause it to abort
|
||||||
.I size
|
the transfer with CURLE_WRITE_ERROR).
|
||||||
multiplied with
|
|
||||||
.I nmemb.
|
Set the \fIstream\fP argument with the \fBCURLOPT_FILE\fP option.
|
||||||
Return the number of bytes actually written or return -1 to signal error to the library (it will cause it to abort the transfer).
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_INFILE
|
.B CURLOPT_INFILE
|
||||||
Data pointer to pass instead of FILE * to the file read function. Note that if
|
Data pointer to pass to the file read function. Note that if you specify the
|
||||||
you specify the
|
\fICURLOPT_READFUNCTION\fP, this is the pointer you'll get as input. If you
|
||||||
.I CURLOPT_READFUNCTION
|
don't specify a read callback, this must be a valid FILE *.
|
||||||
, this is the pointer you'll get as input.
|
|
||||||
|
|
||||||
NOTE: If you're using libcurl as a win32 .DLL, you MUST use a
|
NOTE: If you're using libcurl as a win32 DLL, you MUST use a
|
||||||
.I CURLOPT_READFUNCTION
|
\fICURLOPT_READFUNCTION\fP if you set this option.
|
||||||
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 match the following prototype:
|
||||||
.BI "size_t function( void *ptr, size_t size, size_t nmemb, FILE *stream);"
|
.BI "size_t function( void *ptr, size_t size, size_t nmemb, void *stream);"
|
||||||
This function gets called by libcurl as soon as it needs to read data in order
|
This function gets called by libcurl as soon as it needs to read data in order
|
||||||
to send it to the peer. The data area pointed at by the pointer
|
to send it to the peer. The data area pointed at by the pointer \fIptr\fP may
|
||||||
.I ptr
|
be filled with at most \fIsize\fP multiplied with \fInmemb\fP number of
|
||||||
may be filled with at most
|
bytes. Your function must return the actual number of bytes that you stored in
|
||||||
.I size
|
that memory area. Returning -1 will signal an error to the library and cause
|
||||||
multiplied with
|
it to abort the current transfer immediately (with a CURLE_READ_ERROR return
|
||||||
.I nmemb
|
code).
|
||||||
number of bytes. Your function must return the actual number of bytes that you
|
|
||||||
stored in that memory area. Returning -1 will signal an error to the library
|
|
||||||
and cause it to abort the current transfer immediately.
|
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_INFILESIZE
|
.B CURLOPT_INFILESIZE
|
||||||
When uploading a file to a remote site, this option should be used to tell
|
When uploading a file to a remote site, this option should be used to tell
|
||||||
@@ -120,7 +109,8 @@ this means, you probably don't want this tunnel option. (Added in libcurl 7.3)
|
|||||||
.TP
|
.TP
|
||||||
.B CURLOPT_VERBOSE
|
.B CURLOPT_VERBOSE
|
||||||
Set the parameter to non-zero to get the library to display a lot of verbose
|
Set the parameter to non-zero to get the library to display a lot of verbose
|
||||||
information about its operations.
|
information about its operations. Very useful for libcurl and/or protocl
|
||||||
|
debugging and understanding.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HEADER
|
.B CURLOPT_HEADER
|
||||||
A non-zero parameter tells the library to include the header in the
|
A non-zero parameter tells the library to include the header in the
|
||||||
@@ -188,9 +178,6 @@ similar.
|
|||||||
A non-zero parameter tells the library to use HTTP PUT a file. The file to put
|
A non-zero parameter tells the library to use HTTP PUT a file. The file to put
|
||||||
must be set with CURLOPT_INFILE and CURLOPT_INFILESIZE.
|
must be set with CURLOPT_INFILE and CURLOPT_INFILESIZE.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_MUTE
|
|
||||||
A non-zero parameter tells the library to be completely quiet.
|
|
||||||
.TP
|
|
||||||
.B CURLOPT_USERPWD
|
.B CURLOPT_USERPWD
|
||||||
Pass a char * as parameter, which should be [username]:[password] to use for
|
Pass a char * as parameter, which should be [username]:[password] to use for
|
||||||
the connection. If the password is left out, you will be prompted for it.
|
the connection. If the password is left out, you will be prompted for it.
|
||||||
@@ -274,7 +261,11 @@ curl_slist' structs properly filled in. Use
|
|||||||
.I curl_slist_append(3)
|
.I curl_slist_append(3)
|
||||||
to create the list and
|
to create the list and
|
||||||
.I curl_slist_free_all(3)
|
.I curl_slist_free_all(3)
|
||||||
to clean up an entire list.
|
to clean up an entire list. If you add a header that is otherwise generated
|
||||||
|
and used by libcurl internally, your added one will be used instead. If you
|
||||||
|
add a header with no contents as in 'Accept:', the internally used header will
|
||||||
|
just get disabled. Thus, using this option you can add new headers, replace
|
||||||
|
internal headers and remove internal headers.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_HTTPPOST
|
.B CURLOPT_HTTPPOST
|
||||||
Tells libcurl you want a multipart/formdata HTTP POST to be made and you
|
Tells libcurl you want a multipart/formdata HTTP POST to be made and you
|
||||||
@@ -283,7 +274,8 @@ of HTTP post structs as parameter. The linked list should be a fully valid
|
|||||||
list of 'struct HttpPost' structs properly filled in. The best and most
|
list of 'struct HttpPost' structs properly filled in. The best and most
|
||||||
elegant way to do this, is to use
|
elegant way to do this, is to use
|
||||||
.I curl_formparse(3)
|
.I curl_formparse(3)
|
||||||
as documented.
|
as documented. The data in this list must remained intact until you close this
|
||||||
|
curl handle again with curl_easy_cleanup().
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_SSLCERT
|
.B CURLOPT_SSLCERT
|
||||||
Pass a pointer to a zero terminated string as parameter. The string should be
|
Pass a pointer to a zero terminated string as parameter. The string should be
|
||||||
@@ -313,12 +305,39 @@ struct curl_slist structs properly filled in as described for
|
|||||||
.I "CURLOPT_QUOTE"
|
.I "CURLOPT_QUOTE"
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_WRITEHEADER
|
.B CURLOPT_WRITEHEADER
|
||||||
Pass a FILE * to be used to write the header part of the received data to.
|
Pass a pointer to be used to write the header part of the received data to. If
|
||||||
|
you don't use a callback to take care of the writing, this must be a FILE
|
||||||
|
*. The headers are guaranteed to be written one-by-one and only complete lines
|
||||||
|
are written. Parsing headers should be easy enough using this. See also the
|
||||||
|
\fICURLOPT_HEADERFUNCTION\fP option.
|
||||||
|
.TP
|
||||||
|
.B CURLOPT_HEADERFUNCTION
|
||||||
|
Function pointer that should match the following prototype:
|
||||||
|
.BI "size_t function( void *ptr, size_t size, size_t nmemb, void *stream);"
|
||||||
|
This function gets called by libcurl as soon as there is received header data
|
||||||
|
that needs to be written down. The function will be called once for each
|
||||||
|
header with a complete header line in each invoke. The size of the data
|
||||||
|
pointed to by
|
||||||
|
.I ptr
|
||||||
|
is
|
||||||
|
.I size
|
||||||
|
multiplied with
|
||||||
|
.I nmemb.
|
||||||
|
The pointer named
|
||||||
|
.I stream
|
||||||
|
will be the one you passed to libcurl with the
|
||||||
|
.I CURLOPT_WRITEHEADER
|
||||||
|
option.
|
||||||
|
Return the number of bytes actually written or return -1 to signal error to
|
||||||
|
the library (it will cause it to abort the transfer with a
|
||||||
|
.I CURLE_WRITE_ERROR
|
||||||
|
return code). (Added in libcurl 7.7.2)
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_COOKIEFILE
|
.B CURLOPT_COOKIEFILE
|
||||||
Pass a pointer to a zero terminated string as parameter. It should contain the
|
Pass a pointer to a zero terminated string as parameter. It should contain the
|
||||||
name of your file holding cookie data. The cookie data may be in netscape
|
name of your file holding cookie data. The cookie data may be in Netscape /
|
||||||
cookie data format or just regular HTTP-style headers dumped to a file.
|
Mozilla cookie data format or just regular HTTP-style headers dumped to a
|
||||||
|
file.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_SSLVERSION
|
.B CURLOPT_SSLVERSION
|
||||||
Pass a long as parameter. Set what version of SSL to attempt to use, 2 or
|
Pass a long as parameter. Set what version of SSL to attempt to use, 2 or
|
||||||
@@ -353,7 +372,7 @@ name. (Added in libcurl 7.3)
|
|||||||
.B CURLOPT_KRB4LEVEL
|
.B CURLOPT_KRB4LEVEL
|
||||||
Pass a char * as parameter. Set the krb4 security level, this also enables
|
Pass a char * as parameter. Set the krb4 security level, this also enables
|
||||||
krb4 awareness. This is a string, 'clear', 'safe', 'confidential' or
|
krb4 awareness. This is a string, 'clear', 'safe', 'confidential' or
|
||||||
'private'. If the string is set but doesn't match one of these, 'private'
|
\&'private'. If the string is set but doesn't match one of these, 'private'
|
||||||
will be used. Set the string to NULL to disable kerberos4. The kerberos
|
will be used. Set the string to NULL to disable kerberos4. The kerberos
|
||||||
support only works for FTP. (Added in libcurl 7.3)
|
support only works for FTP. (Added in libcurl 7.3)
|
||||||
.TP
|
.TP
|
||||||
@@ -467,7 +486,7 @@ 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,
|
from to seed the random engine for SSL. The more random the specified file is,
|
||||||
the more secure will the SSL connection become.
|
the more secure will the SSL connection become.
|
||||||
.TP
|
.TP
|
||||||
.B CURLOPT_FORBID_REUSE
|
.B CURLOPT_EGDSOCKET
|
||||||
Pass a char * to the zero terminated path name to the Entropy Gathering Daemon
|
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.
|
socket. It will be used to seed the random engine for SSL.
|
||||||
.TP
|
.TP
|
||||||
@@ -476,7 +495,7 @@ Pass a long. It should contain the maximum time in seconds that you allow the
|
|||||||
connection to the server to take. This only limits the connection phase, once
|
connection to the server to take. This only limits the connection phase, once
|
||||||
it has connected, this option is of no more use. Set to zero to disable
|
it has connected, this option is of no more use. Set to zero to disable
|
||||||
connection timeout (it will then only timeout on the system's internal
|
connection timeout (it will then only timeout on the system's internal
|
||||||
timeouts). This option doesn't work in win32 systems. See also the
|
timeouts). See also the
|
||||||
.I CURLOPT_TIMEOUT
|
.I CURLOPT_TIMEOUT
|
||||||
option.
|
option.
|
||||||
.PP
|
.PP
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_escape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_escape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
@@ -13,7 +13,10 @@ curl_escape - URL encodes the given string
|
|||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
This function will convert the given input string to an URL encoded string and
|
This function will convert the given input string to an URL encoded string and
|
||||||
return that as a new allocated string. All input characters that are not a-z,
|
return that as a new allocated string. All input characters that are not a-z,
|
||||||
A-Z or 0-9 will be converted to their "URL escaped" version.
|
A-Z or 0-9 will be converted to their "URL escaped" version. If a sequence of
|
||||||
|
%NN (where NN is a two-digit hexadecimal number) is found in the string to
|
||||||
|
encode, that 3-letter combination will be copied to the output unmodifed,
|
||||||
|
assuming that it is an already encoded piece of data.
|
||||||
|
|
||||||
If the 'length' argument is set to 0, curl_escape() will use strlen() on the
|
If the 'length' argument is set to 0, curl_escape() will use strlen() on the
|
||||||
input 'url' string to find out the size.
|
input 'url' string to find out the size.
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_formfree 3 "5 March 2001" "libcurl 7.5" "libcurl Manual"
|
.TH curl_formfree 3 "6 April 2001" "libcurl 7.7.1" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
curl_formfree - free a previously build multipart/formdata HTTP POST chain
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -19,5 +19,7 @@ None
|
|||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_formparse "(3) "
|
.BR curl_formparse "(3) "
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
Surely there are some, you tell me!
|
libcurl 7.7.1 and earlier versions does not allow a NULL pointer to be used as
|
||||||
|
argument.
|
||||||
|
|
||||||
|
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_formparse 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
.TH curl_formparse 3 "21 May 2001" "libcurl 7.7.4" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl_formparse - add a section to a multipart/formdata HTTP POST
|
curl_formparse - add a section to a multipart/formdata HTTP POST
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -13,15 +13,25 @@ curl_formparse - add a section to a multipart/formdata HTTP POST
|
|||||||
.ad
|
.ad
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
curl_formparse() is used to append sections when building a multipart/formdata
|
curl_formparse() is used to append sections when building a multipart/formdata
|
||||||
HTTP POST. Append one section at a time until you've added all the sections
|
HTTP POST (sometimes refered to as rfc1867-style posts). Append one section at
|
||||||
you want included and then you pass the
|
a time until you've added all the sections you want included and then you pass
|
||||||
.I firstitem
|
the \fIfirstitem\fP pointer as parameter to \fBCURLOPT_HTTPPOST\fP.
|
||||||
pointer as parameter to CURLOPT_HTTPPOST.
|
\fIlastitem\fP is set after each call and on repeated invokes it should be
|
||||||
.I lastitem
|
left as set to allow repeated invokes to find the end of the list in a faster
|
||||||
is set after each call and on repeated invokes it should be left as set to
|
way. \fIstring\fP must be a zero terminated string abiding to the syntax
|
||||||
allow repeated invokes to find the end of the list in a faster way.
|
described in a section below
|
||||||
.I string
|
|
||||||
must be a zero terminated string following the following syntax.
|
The pointers \fI*firstitem\fP and \fI*lastitem\fP should both be pointing to
|
||||||
|
NULL in the first call to this function. All list-data will be allocated by
|
||||||
|
the function itself. You must call \fIcurl_formfree\fP after the form post has
|
||||||
|
been done to free the resources again.
|
||||||
|
|
||||||
|
This function will copy all input data and keep its own version of it
|
||||||
|
allocated until you call \fIcurl_formfree\fP. When you've passed the pointer
|
||||||
|
to \fIcurl_easy_setopt\fP, you must not free the list until after you've
|
||||||
|
called \fIcurl_easy_cleanup\fP for the curl handle.
|
||||||
|
|
||||||
|
See example below.
|
||||||
.SH "FORM PARSE STRINGS"
|
.SH "FORM PARSE STRINGS"
|
||||||
The
|
The
|
||||||
.I string
|
.I string
|
||||||
@@ -55,8 +65,21 @@ content-type for all of them in the same way as with a single file.
|
|||||||
.PP
|
.PP
|
||||||
.SH RETURN VALUE
|
.SH RETURN VALUE
|
||||||
Returns non-zero if an error occurs.
|
Returns non-zero if an error occurs.
|
||||||
|
.SH EXAMPLE
|
||||||
|
|
||||||
|
HttpPost* post = NULL;
|
||||||
|
HttpPost* last = NULL;
|
||||||
|
|
||||||
|
/* Add an image section */
|
||||||
|
curl_formparse("picture=@my-face.jpg", &post, &last);
|
||||||
|
/* Add a normal text section */
|
||||||
|
curl_formparse("name=FooBar", &post, &last);
|
||||||
|
/* Set the form info */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPPOST, post);
|
||||||
|
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_easy_setopt "(3) "
|
.BR curl_easy_setopt "(3), "
|
||||||
|
.BR curl_formfree "(3)
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
Surely there are some, you tell me!
|
Surely there are some, you tell me!
|
||||||
|
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
.TH curl_getdate 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_getenv 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
.TH curl_getenv 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
27
docs/curl_global_cleanup.3
Normal file
27
docs/curl_global_cleanup.3
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_global_cleanup 3 "28 May 2001" "libcurl 7.8" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_global_cleanup - Global libcurl cleanup
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "void curl_global_cleanup(void);"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
curl_global_cleanup must be called once (no matter how many threads or libcurl
|
||||||
|
sessions that'll be used) by every application that uses libcurl, after all
|
||||||
|
uses of libcurl is complete.
|
||||||
|
|
||||||
|
This is the opposite of \fIcurl_global_init\fP.
|
||||||
|
|
||||||
|
Not calling this function may result in memory leaks.
|
||||||
|
|
||||||
|
This function was added in libcurl 7.8.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_global_init "(3), "
|
||||||
|
.SH BUGS
|
||||||
|
None?
|
||||||
|
|
47
docs/curl_global_init.3
Normal file
47
docs/curl_global_init.3
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_global_init 3 "31 May 2001" "libcurl 7.8" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_global_init - Global libcurl initialisation
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "CURLcode curl_global_init(long " flags ");"
|
||||||
|
.ad
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This function should be called once (no matter how many threads or libcurl
|
||||||
|
sessions that'll be used) by every application that uses libcurl.
|
||||||
|
|
||||||
|
If this function hasn't been invoked when \fIcurl_easy_init\fP is called, it
|
||||||
|
will be done automatically by libcurl.
|
||||||
|
|
||||||
|
The flags option is a bit pattern that tells libcurl exact what features to
|
||||||
|
init, as described below. Set the desired bits by ORing the values together.
|
||||||
|
|
||||||
|
You must however \fBalways\fP use the \fIcurl_global_cleanup\fP function, as
|
||||||
|
that cannot be called automatically for you by libcurl.
|
||||||
|
|
||||||
|
This function was added in libcurl 7.8.
|
||||||
|
.SH FLAGS
|
||||||
|
.TP 5
|
||||||
|
.B CURL_GLOBAL_ALL
|
||||||
|
Initialize everything possible. This sets all known bits.
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_SSL
|
||||||
|
Initialize SSL
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_WIN32
|
||||||
|
Initialize the Win32 socket libraries.
|
||||||
|
.TP
|
||||||
|
.B CURL_GLOBAL_NOTHING
|
||||||
|
Initialise nothing extra. This sets no bit.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
If this function returns non-zero, something went wrong and you cannot use the
|
||||||
|
other curl functions.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR curl_global_cleanup "(3), "
|
||||||
|
.SH BUGS
|
||||||
|
None.
|
||||||
|
|
88
docs/curl_mprintf.3
Normal file
88
docs/curl_mprintf.3
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_printf 3 "20 April 2001" "libcurl 7.7.2" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_maprintf, curl_mfprintf, curl_mprintf, curl_msnprintf, curl_msprintf
|
||||||
|
curl_mvaprintf, curl_mvfprintf, curl_mvprintf, curl_mvsnprintf,
|
||||||
|
curl_mvsprintf - formatted output conversion
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/mprintf.h>
|
||||||
|
.sp
|
||||||
|
.BI "int curl_mprintf(const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mfprintf(FILE *" fd ", const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_msprintf(char *" buffer ", const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_msnprintf(char *" buffer ", size_t " maxlength ", const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvprintf(const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvfprintf(FILE *" fd ", const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvsprintf(char *" buffer ", const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "int curl_mvsnprintf(char *" buffer ", size_t " maxlength ", const char *" format ", va_list " args ");"
|
||||||
|
.br
|
||||||
|
.BI "char *curl_maprintf(const char *" format ", ...);"
|
||||||
|
.br
|
||||||
|
.BI "char *curl_mvaprintf(const char *" format ", va_list " args ");"
|
||||||
|
.SH DESCRIPTION
|
||||||
|
These are all functions that produces output according to a format string and
|
||||||
|
given arguments. These are mostly clones of the well-known C-style functions
|
||||||
|
and there will be no detailed explanation of all available formatting rules
|
||||||
|
and usage here.
|
||||||
|
|
||||||
|
See this table for notable exceptions.
|
||||||
|
.RS
|
||||||
|
.TP
|
||||||
|
.B curl_mprintf()
|
||||||
|
Normal printf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mfprintf()
|
||||||
|
Normal fprinf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_msprintf()
|
||||||
|
Normal sprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_msnprintf()
|
||||||
|
snprintf() clone. Many systems don't have this. It is just like \fBsprintf\fP
|
||||||
|
but with an extra argument after the buffer that specifies the length of the
|
||||||
|
target buffer.
|
||||||
|
.TP
|
||||||
|
.B curl_mvprintf()
|
||||||
|
Normal vprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mvfprintf()
|
||||||
|
Normal vfprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mvsprintf()
|
||||||
|
Normal vsprintf() clone.
|
||||||
|
.TP
|
||||||
|
.B curl_mvsnprintf()
|
||||||
|
vsnprintf() clone. Many systems don't have this. It is just like
|
||||||
|
\fBvsprintf\fP but with an extra argument after the buffer that specifies the
|
||||||
|
length of the target buffer.
|
||||||
|
.TP
|
||||||
|
.B curl_maprintf()
|
||||||
|
Like printf() but returns the output string as a malloc()ed string. The
|
||||||
|
returned string must be free()ed by the receiver.
|
||||||
|
.TP
|
||||||
|
.B curl_mvaprintf()
|
||||||
|
Like curl_maprintf() but takes a va_list pointer argument instead of a
|
||||||
|
variable amount of arguments.
|
||||||
|
.RE
|
||||||
|
|
||||||
|
To easily use all these cloned functions instead of the normal ones, #define
|
||||||
|
_MPRINTF_REPLACE before you include the <curl/mprintf.h> file. Then all the
|
||||||
|
normal names like printf, fprintf, sprintf etc will use the curl-functions
|
||||||
|
instead.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
The \fBcurl_maprintf\fP and \fBcurl_mvaprintf\fP functions return a pointer to
|
||||||
|
a newly allocated string, or NULL it it failed.
|
||||||
|
|
||||||
|
All other functions return the number of character they actually outputed.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR printf "(3), " sprintf "(3), " fprintf "(3), " vprintf "(3) "
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_slist_append 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
.TH curl_slist_append 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_slist_free_all 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
.TH curl_slist_free_all 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
30
docs/curl_strequal.3
Normal file
30
docs/curl_strequal.3
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH curl_strequal 3 "20 April 2001" "libcurl 7.7.2" "libcurl Manual"
|
||||||
|
.SH NAME
|
||||||
|
curl_strequal, curl_strnequal - case insensitive string comparisons
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B #include <curl/curl.h>
|
||||||
|
.sp
|
||||||
|
.BI "int curl_strequal(char *" str1 ", char *" str2 ");"
|
||||||
|
.sp
|
||||||
|
.BI "int curl_strenqual(char *" str1 ", char *" str2 ", size_t " len ");"
|
||||||
|
.SH DESCRIPTION
|
||||||
|
The
|
||||||
|
.B curl_strequal()
|
||||||
|
function compares the two strings \fIstr1\fP and \fIstr2\fP, ignoring the case
|
||||||
|
of the characters. It returns a non-zero (TRUE) integer if the strings are
|
||||||
|
identical.
|
||||||
|
.sp
|
||||||
|
The \fBcurl_strnequal()\fP function is similar, except it only compares the
|
||||||
|
first \fIlen\fP characters of \fIstr1\fP.
|
||||||
|
.sp
|
||||||
|
These functions are provided by libcurl to enable applications to compare
|
||||||
|
strings in a truly portable manner. There are no standard portable case
|
||||||
|
insensitive string comparison functions. These two works on all platforms.
|
||||||
|
.SH RETURN VALUE
|
||||||
|
Non-zero if the strings are identical. Zero if they're not.
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR strcmp "(3), " strcasecmp "(3)"
|
1
docs/curl_strnequal.3
Normal file
1
docs/curl_strnequal.3
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so curl_strequal.3
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
.TH curl_unescape 3 "22 March 2001" "libcurl 7.7" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
.\" You can view this file with:
|
.\" You can view this file with:
|
||||||
.\" nroff -man [file]
|
.\" nroff -man [file]
|
||||||
.\" Written by daniel@haxx.se
|
.\" $Id$
|
||||||
.\"
|
.\"
|
||||||
.TH curl_version 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
.TH curl_version 3 "5 March 2001" "libcurl 7.0" "libcurl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
|
@@ -4,10 +4,9 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
EXTRA_DIST =
|
EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit.c \
|
||||||
README curlgtk.c sepheaders.c simple.c postit.c \
|
win32sockets.c persistant.c ftpget.c Makefile.example \
|
||||||
win32sockets.c persistant.c \
|
multithread.c getinmemory.c
|
||||||
getpageinvar.php simpleget.php simplepost.php
|
|
||||||
|
|
||||||
all:
|
all:
|
||||||
@echo "done"
|
@echo "done"
|
||||||
|
42
docs/examples/Makefile.example
Normal file
42
docs/examples/Makefile.example
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
#############################################################################
|
||||||
|
# _ _ ____ _
|
||||||
|
# Project ___| | | | _ \| |
|
||||||
|
# / __| | | | |_) | |
|
||||||
|
# | (__| |_| | _ <| |___
|
||||||
|
# \___|\___/|_| \_\_____|
|
||||||
|
#
|
||||||
|
# $Id$
|
||||||
|
#
|
||||||
|
|
||||||
|
# What to call the final executable
|
||||||
|
TARGET = example
|
||||||
|
|
||||||
|
# Which object files that the executable consists of
|
||||||
|
OBJS= ftpget.o
|
||||||
|
|
||||||
|
# What compiler to use
|
||||||
|
CC = gcc
|
||||||
|
|
||||||
|
# Compiler flags, -g for debug, -c to make an object file
|
||||||
|
CFLAGS = -c -g
|
||||||
|
|
||||||
|
# This should point to a directory that holds libcurl, if it isn't
|
||||||
|
# in the system's standard lib dir
|
||||||
|
# We also set a -L to include the directory where we have the openssl
|
||||||
|
# libraries
|
||||||
|
LDFLAGS = -L/home/dast/lib -L/usr/local/ssl/lib
|
||||||
|
|
||||||
|
# We need -lcurl for the curl stuff
|
||||||
|
# We need -lsocket and -lnsl when on Solaris
|
||||||
|
# We need -lssl and -lcrypto when using libcurl with SSL support
|
||||||
|
# We need -ldl for dlopen() if that is in libdl
|
||||||
|
# We need -lpthread for the pthread example
|
||||||
|
LIBS = -lcurl -lsocket -lnsl -lssl -lcrypto -dl
|
||||||
|
|
||||||
|
# Link the target with all objects and libraries
|
||||||
|
$(TARGET) : $(OBJS)
|
||||||
|
$(CC) $(LDFLAGS) $(LIBS) -o $(TARGET) $(OBJS)
|
||||||
|
|
||||||
|
# Compile the source files into object files
|
||||||
|
ftpget.o : ftpget.c
|
||||||
|
$(CC) $(CFLAGS) $<
|
@@ -7,4 +7,12 @@ advantage of libcurl.
|
|||||||
If you end up with other small but still useful example sources, please mail
|
If you end up with other small but still useful example sources, please mail
|
||||||
them for submission in future packages and on the web site.
|
them for submission in future packages and on the web site.
|
||||||
|
|
||||||
|
The Makefile.example is an example makefile that could be used to build these
|
||||||
|
examples. Just edit the file according to your system and requirements first.
|
||||||
|
|
||||||
Try the php/examples/ directory for PHP programming snippets!
|
Try the php/examples/ directory for PHP programming snippets!
|
||||||
|
|
||||||
|
*PLEASE* do not use the curl.haxx.se site as a test target for your libcurl
|
||||||
|
applications/experiments. Even if the examples in this directory use that
|
||||||
|
site as an example URL at some places, it doesn't mean that the URLs work or
|
||||||
|
that we expect you to actually torture our web site with your tests! Thanks.
|
||||||
|
44
docs/examples/ftpget.c
Normal file
44
docs/examples/ftpget.c
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
win32socket.c file as well */
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
FILE *ftpfile;
|
||||||
|
|
||||||
|
/* local file name to store the file as */
|
||||||
|
ftpfile = fopen("curl.tar.gz", "wb"); /* b is binary for win */
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* Get curl 7.7 from sunet.se's FTP site: */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL,
|
||||||
|
"ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.7.tar.gz");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FILE, ftpfile);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose(ftpfile); /* close the local file */
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
80
docs/examples/getinmemory.c
Normal file
80
docs/examples/getinmemory.c
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* Example source code to show how the callback function can be used to
|
||||||
|
* download data into a chunk of memory instead of storing it in a file.
|
||||||
|
*
|
||||||
|
* This exact source code has not been verified to work.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* to make this work under windows, use the win32-functions from the
|
||||||
|
win32socket.c file as well */
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <curl/types.h>
|
||||||
|
#include <curl/easy.h>
|
||||||
|
|
||||||
|
struct MemoryStruct {
|
||||||
|
char *memory;
|
||||||
|
size_t size;
|
||||||
|
};
|
||||||
|
|
||||||
|
size_t
|
||||||
|
WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
|
{
|
||||||
|
register int realsize = size * nmemb;
|
||||||
|
struct MemoryStruct *mem = (struct MemoryStruct *)data;
|
||||||
|
|
||||||
|
mem->memory = (char *)realloc(mem->memory, mem->size + realsize + 1);
|
||||||
|
if (mem->memory) {
|
||||||
|
memcpy(&(mem->memory[mem->size]), ptr, realsize);
|
||||||
|
mem->size += realsize;
|
||||||
|
mem->memory[mem->size] = 0;
|
||||||
|
}
|
||||||
|
return realsize;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
CURL *curl_handle;
|
||||||
|
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
|
||||||
|
chunk.memory=NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
|
||||||
|
/* init the curl session */
|
||||||
|
curl_handle = curl_easy_init();
|
||||||
|
|
||||||
|
/* specify URL to get */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_URL, "http://cool.haxx.se/");
|
||||||
|
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_FILE, (void *)&chunk);
|
||||||
|
|
||||||
|
/* get it! */
|
||||||
|
curl_easy_perform(curl_handle);
|
||||||
|
|
||||||
|
/* cleanup curl stuff */
|
||||||
|
curl_easy_cleanup(curl_handle);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Now, our chunk.memory points to a memory block that is chunk.size
|
||||||
|
* bytes big and contains the remote file.
|
||||||
|
*
|
||||||
|
* Do something nice with it!
|
||||||
|
*/
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
70
docs/examples/multithread.c
Normal file
70
docs/examples/multithread.c
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* A multi-threaded example that uses pthreads extensively to fetch
|
||||||
|
* X remote files at once */
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
/* silly list of test-URLs */
|
||||||
|
char *urls[]= {
|
||||||
|
"http://curl.haxx.se/",
|
||||||
|
"ftp://cool.haxx.se/",
|
||||||
|
"http://www.contactor.se/",
|
||||||
|
"www.haxx.se"
|
||||||
|
};
|
||||||
|
|
||||||
|
void *pull_one_url(void *url)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
|
curl_easy_perform(curl);
|
||||||
|
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
int pthread_create(pthread_t *new_thread_ID,
|
||||||
|
const pthread_attr_t *attr,
|
||||||
|
void * (*start_func)(void *), void *arg);
|
||||||
|
*/
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
pthread_t tid[4];
|
||||||
|
int i;
|
||||||
|
int error;
|
||||||
|
for(i=0; i< 4; i++) {
|
||||||
|
error = pthread_create(&tid[i],
|
||||||
|
NULL, /* default attributes please */
|
||||||
|
pull_one_url,
|
||||||
|
urls[i]);
|
||||||
|
if(0 != error)
|
||||||
|
fprintf(stderr, "Couldn't run thread number %d, errno %d\n", i, error);
|
||||||
|
else
|
||||||
|
fprintf(stderr, "Thread %d, gets %s\n", i, urls[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* now wait for all threads to terminate */
|
||||||
|
for(i=0; i< 4; i++) {
|
||||||
|
error = pthread_join(tid[i], NULL);
|
||||||
|
fprintf(stderr, "Thread %d terminated\n", i);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -19,9 +19,9 @@
|
|||||||
#include <curl/types.h>
|
#include <curl/types.h>
|
||||||
#include <curl/easy.h>
|
#include <curl/easy.h>
|
||||||
|
|
||||||
size_t write_data(void *ptr, size_t size, size_t nmemb, FILE *stream)
|
size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
written = fwrite(ptr,size,nmemb,outfile);
|
written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
||||||
return written;
|
return written;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,14 +1,23 @@
|
|||||||
|
|
||||||
|
/*
|
||||||
|
* Note: This is only required if you use curl 7.8 or lower, later
|
||||||
|
* versions provide an option to curl_global_init() that does the
|
||||||
|
* win32 initialization for you.
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* These are example functions doing socket init that Windows
|
* These are example functions doing socket init that Windows
|
||||||
* require. If you don't use windows, you can safely ignore this crap.
|
* require. If you don't use windows, you can safely ignore this crap.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void win32_cleanup(void)
|
#include <windows.h>
|
||||||
|
|
||||||
|
void win32_cleanup(void)
|
||||||
{
|
{
|
||||||
WSACleanup();
|
WSACleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
static CURLcode win32_init(void)
|
int win32_init(void)
|
||||||
{
|
{
|
||||||
WORD wVersionRequested;
|
WORD wVersionRequested;
|
||||||
WSADATA wsaData;
|
WSADATA wsaData;
|
||||||
|
130
docs/libcurl.3
Normal file
130
docs/libcurl.3
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
.\" You can view this file with:
|
||||||
|
.\" nroff -man [file]
|
||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.TH libcurl 5 "28 May 2001" "libcurl 7.8" "libcurl overview"
|
||||||
|
.SH NAME
|
||||||
|
libcurl \- client-side URL transfers
|
||||||
|
.SH DESCRIPTION
|
||||||
|
This is an overview on how to use libcurl in your c/c++ programs. There are
|
||||||
|
specific man pages for each function mentioned in here.
|
||||||
|
|
||||||
|
libcurl can also be used directly from within your Java, PHP, Perl, Ruby or
|
||||||
|
Tcl programs as well, look elsewhere for documentation on this!
|
||||||
|
|
||||||
|
All applications that use libcurl should call \fIcurl_global_init()\fP exactly
|
||||||
|
once before any libcurl function can be used. After all usage of libcurl is
|
||||||
|
complete, it \fBmust\fP call \fIcurl_global_cleanup()\fP. In between those two
|
||||||
|
calls, you can use libcurl as described below.
|
||||||
|
|
||||||
|
When using libcurl you init your session and get a handle, which you use as
|
||||||
|
input to the following interface functions you use. Use \fIcurl_easy_init()\fP
|
||||||
|
to get the handle.
|
||||||
|
|
||||||
|
You continue by setting all the options you want in the upcoming transfer,
|
||||||
|
most important among them is the URL itself (you can't transfer anything
|
||||||
|
without a specified URL as you may have figured out yourself). You might want
|
||||||
|
to set some callbacks as well that will be called from the library when data
|
||||||
|
is available etc. \fIcurl_easy_setopt()\fP is there for this.
|
||||||
|
|
||||||
|
When all is setup, you tell libcurl to perform the transfer using
|
||||||
|
\fIcurl_easy_perform()\fP. It will then do the entire operation and won't
|
||||||
|
return until it is done (successfully or not).
|
||||||
|
|
||||||
|
After the transfer has been made, you can set new options and make another
|
||||||
|
transfer, or if you're done, cleanup the session by calling
|
||||||
|
\fIcurl_easy_cleanup()\fP. If you want persistant connections, you don't
|
||||||
|
cleanup immediately, but instead run ahead and perform other transfers using
|
||||||
|
the same handle. See the chapter below for Persistant Connections.
|
||||||
|
|
||||||
|
There is also a series of other helpful functions to use. They are:
|
||||||
|
|
||||||
|
.RS
|
||||||
|
.TP 10
|
||||||
|
.B curl_version()
|
||||||
|
displays the libcurl version
|
||||||
|
.TP
|
||||||
|
.B curl_getdate()
|
||||||
|
converts a date string to time_t
|
||||||
|
.TP
|
||||||
|
.B curl_getenv()
|
||||||
|
portable environment variable reader
|
||||||
|
.TP
|
||||||
|
.B curl_easy_getinfo()
|
||||||
|
get information about a performed transfer
|
||||||
|
.TP
|
||||||
|
.B curl_formparse()
|
||||||
|
helps building a HTTP form POST
|
||||||
|
.TP
|
||||||
|
.B curl_formfree()
|
||||||
|
free a list built with curl_formparse()
|
||||||
|
.TP
|
||||||
|
.B curl_slist_append()
|
||||||
|
builds a linked list
|
||||||
|
.TP
|
||||||
|
.B curl_slist_free_all()
|
||||||
|
frees a whole curl_slist
|
||||||
|
.TP
|
||||||
|
.B curl_mprintf()
|
||||||
|
portable printf() functions
|
||||||
|
.TP
|
||||||
|
.B curl_strequal()
|
||||||
|
portable case insensitive string comparisons
|
||||||
|
.RE
|
||||||
|
|
||||||
|
.SH "LINKING WITH LIBCURL"
|
||||||
|
Starting with 7.7.2 (on unix-like machines), there's a tool named curl-config
|
||||||
|
that gets installed with the rest of the curl stuff when 'make install' is
|
||||||
|
performed.
|
||||||
|
|
||||||
|
curl-config is added to make it easier for applications to link with libcurl
|
||||||
|
and developers to learn about libcurl and how to use it.
|
||||||
|
|
||||||
|
Run 'curl-config --libs' to get the (additional) linker options you need to
|
||||||
|
link with the particular version of libcurl you've installed.
|
||||||
|
|
||||||
|
For details, see the curl-config.1 man page.
|
||||||
|
.SH "LIBCURL SYMBOL NAMES"
|
||||||
|
All public functions in the libcurl interface are prefixed with 'curl_' (with
|
||||||
|
a lowercase c). You can find other functions in the library source code, but
|
||||||
|
other prefixes indicate the functions are private and may change without
|
||||||
|
further notice in the next release.
|
||||||
|
|
||||||
|
Only use documented functions and functionality!
|
||||||
|
.SH "PORTABILITY"
|
||||||
|
libcurl works
|
||||||
|
.B exactly
|
||||||
|
the same, on any of the platforms it compiles and builds on.
|
||||||
|
|
||||||
|
There's only one caution, and that is the win32 platform that may(*) require
|
||||||
|
you to init the winsock stuff before you use the libcurl functions. Details on
|
||||||
|
this are noted on the curl_easy_init() man page.
|
||||||
|
|
||||||
|
(*) = it appears as if users of the cygwin environment get this done
|
||||||
|
automatically.
|
||||||
|
.SH "THREADS"
|
||||||
|
Never ever call curl-functions simultaneously using the same handle from
|
||||||
|
several threads. libcurl is thread-safe and can be used in any number of
|
||||||
|
threads, but you must use separate curl handles if you want to use libcurl in
|
||||||
|
more than one thread simultaneously.
|
||||||
|
.SH "PERSISTANT CONNECTIONS"
|
||||||
|
With libcurl 7.7, persistant connections were added. Persistant connections
|
||||||
|
means that libcurl can re-use the same connection for several transfers, if
|
||||||
|
the conditions are right.
|
||||||
|
|
||||||
|
libcurl will *always* attempt to use persistant connections. Whenever you use
|
||||||
|
curl_easy_perform(), libcurl will attempt to use an existing connection to do
|
||||||
|
the transfer, and if none exists it'll open a new one that will be subject
|
||||||
|
for re-use on a possible following call to curl_easy_perform().
|
||||||
|
|
||||||
|
To allow libcurl to take full advantage of persistant connections, you should
|
||||||
|
do as many of your file transfers as possible using the same curl
|
||||||
|
handle. When you call curl_easy_cleanup(), all the possibly open connections
|
||||||
|
held by libcurl will be closed and forgotten.
|
||||||
|
|
||||||
|
Note that the options set with curl_easy_setopt() will be used in on every
|
||||||
|
repeat curl_easy_perform() call
|
||||||
|
.SH "COMPATIBILITY WITH OLDER LIBCURLS"
|
||||||
|
Repeated curl_easy_perform() calls on the same handle were not supported in
|
||||||
|
pre-7.7 versions, and caused confusion and undefined behaviour.
|
||||||
|
|
@@ -76,12 +76,12 @@ typedef int (*curl_progress_callback)(void *clientp,
|
|||||||
typedef size_t (*curl_write_callback)(char *buffer,
|
typedef size_t (*curl_write_callback)(char *buffer,
|
||||||
size_t size,
|
size_t size,
|
||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *outstream);
|
void *outstream);
|
||||||
|
|
||||||
typedef size_t (*curl_read_callback)(char *buffer,
|
typedef size_t (*curl_read_callback)(char *buffer,
|
||||||
size_t size,
|
size_t size,
|
||||||
size_t nitems,
|
size_t nitems,
|
||||||
FILE *instream);
|
void *instream);
|
||||||
|
|
||||||
typedef int (*curl_passwd_callback)(void *clientp,
|
typedef int (*curl_passwd_callback)(void *clientp,
|
||||||
char *prompt,
|
char *prompt,
|
||||||
@@ -146,10 +146,17 @@ typedef enum {
|
|||||||
CURLE_TOO_MANY_REDIRECTS , /* 47 - catch endless re-direct loops */
|
CURLE_TOO_MANY_REDIRECTS , /* 47 - catch endless re-direct loops */
|
||||||
CURLE_UNKNOWN_TELNET_OPTION, /* 48 - User specified an unknown option */
|
CURLE_UNKNOWN_TELNET_OPTION, /* 48 - User specified an unknown option */
|
||||||
CURLE_TELNET_OPTION_SYNTAX , /* 49 - Malformed telnet option */
|
CURLE_TELNET_OPTION_SYNTAX , /* 49 - Malformed telnet option */
|
||||||
|
CURLE_OBSOLETE, /* 50 - removed after 7.7.3 */
|
||||||
|
CURLE_SSL_PEER_CERTIFICATE, /* 51 - peer's certificate wasn't ok */
|
||||||
|
|
||||||
CURL_LAST /* never use! */
|
CURL_LAST /* never use! */
|
||||||
} CURLcode;
|
} CURLcode;
|
||||||
|
|
||||||
|
/* this was the error code 50 in 7.7.3 and a few earlier versions, this
|
||||||
|
is no longer used by libcurl but is instead #defined here only to not
|
||||||
|
make programs break */
|
||||||
|
#define CURLE_ALREADY_COMPLETE 99999
|
||||||
|
|
||||||
/* This is just to make older programs not break: */
|
/* This is just to make older programs not break: */
|
||||||
#define CURLE_FTP_PARTIAL_FILE CURLE_PARTIAL_FILE
|
#define CURLE_FTP_PARTIAL_FILE CURLE_PARTIAL_FILE
|
||||||
|
|
||||||
@@ -172,7 +179,7 @@ typedef enum {
|
|||||||
typedef enum {
|
typedef enum {
|
||||||
CINIT(NOTHING, LONG, 0), /********* the first one is unused ************/
|
CINIT(NOTHING, LONG, 0), /********* the first one is unused ************/
|
||||||
|
|
||||||
/* This is the FILE * the regular output should be written to. */
|
/* This is the FILE * or void * the regular output should be written to. */
|
||||||
CINIT(FILE, OBJECTPOINT, 1),
|
CINIT(FILE, OBJECTPOINT, 1),
|
||||||
|
|
||||||
/* The full URL to get/put */
|
/* The full URL to get/put */
|
||||||
@@ -275,7 +282,8 @@ typedef enum {
|
|||||||
/* send linked-list of QUOTE commands */
|
/* send linked-list of QUOTE commands */
|
||||||
CINIT(QUOTE, OBJECTPOINT, 28),
|
CINIT(QUOTE, OBJECTPOINT, 28),
|
||||||
|
|
||||||
/* send FILE * to store headers to */
|
/* send FILE * or void * to store headers to, if you use a callback it
|
||||||
|
is simply passed to the callback unmodified */
|
||||||
CINIT(WRITEHEADER, OBJECTPOINT, 29),
|
CINIT(WRITEHEADER, OBJECTPOINT, 29),
|
||||||
|
|
||||||
#ifdef MULTIDOC
|
#ifdef MULTIDOC
|
||||||
@@ -343,7 +351,8 @@ typedef enum {
|
|||||||
|
|
||||||
CINIT(TRANSFERTEXT, LONG, 53), /* transfer data in text/ASCII format */
|
CINIT(TRANSFERTEXT, LONG, 53), /* transfer data in text/ASCII format */
|
||||||
CINIT(PUT, LONG, 54), /* PUT the input file */
|
CINIT(PUT, LONG, 54), /* PUT the input file */
|
||||||
CINIT(MUTE, LONG, 55), /* force NOPROGRESS */
|
|
||||||
|
CINIT(MUTE, LONG, 55), /* OBSOLETE OPTION, removed in 7.8 */
|
||||||
|
|
||||||
/* Function that will be called instead of the internal progress display
|
/* Function that will be called instead of the internal progress display
|
||||||
* function. This function should be defined as the curl_progress_callback
|
* function. This function should be defined as the curl_progress_callback
|
||||||
@@ -430,6 +439,15 @@ typedef enum {
|
|||||||
phase. [Only works on unix-style/SIGALRM operating systems] */
|
phase. [Only works on unix-style/SIGALRM operating systems] */
|
||||||
CINIT(CONNECTTIMEOUT, LONG, 78),
|
CINIT(CONNECTTIMEOUT, LONG, 78),
|
||||||
|
|
||||||
|
/* Function that will be called to store headers (instead of fwrite). The
|
||||||
|
* parameters will use fwrite() syntax, make sure to follow them. */
|
||||||
|
CINIT(HEADERFUNCTION, FUNCTIONPOINT, 79),
|
||||||
|
|
||||||
|
/* Set this to force the HTTP request to get back to GET. Only really usable
|
||||||
|
if POST, PUT or a custom request have been used first.
|
||||||
|
*/
|
||||||
|
CINIT(HTTPGET, LONG, 80),
|
||||||
|
|
||||||
CURLOPT_LASTENTRY /* the last unusued */
|
CURLOPT_LASTENTRY /* the last unusued */
|
||||||
} CURLoption;
|
} CURLoption;
|
||||||
|
|
||||||
@@ -480,9 +498,19 @@ char *curl_version(void);
|
|||||||
char *curl_escape(char *string, int length);
|
char *curl_escape(char *string, int length);
|
||||||
char *curl_unescape(char *string, int length);
|
char *curl_unescape(char *string, int length);
|
||||||
|
|
||||||
|
/* curl_global_init() should be invoked exactly once for each application that
|
||||||
|
uses libcurl */
|
||||||
|
CURLcode curl_global_init(long flags);
|
||||||
|
|
||||||
|
/* curl_global_cleanup() should be invoked exactly once for each application
|
||||||
|
that uses libcurl */
|
||||||
|
void curl_global_cleanup(void);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* This is the version number */
|
/* This is the version number */
|
||||||
#define LIBCURL_VERSION "7.7"
|
#define LIBCURL_VERSION "7.8.1-pre3"
|
||||||
#define LIBCURL_VERSION_NUM 0x070700
|
#define LIBCURL_VERSION_NUM 0x070801
|
||||||
|
|
||||||
/* 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 {
|
||||||
@@ -551,6 +579,11 @@ typedef enum {
|
|||||||
CURLCLOSEPOLICY_LAST /* last, never use this */
|
CURLCLOSEPOLICY_LAST /* last, never use this */
|
||||||
} curl_closepolicy;
|
} curl_closepolicy;
|
||||||
|
|
||||||
|
#define CURL_GLOBAL_SSL (1<<0)
|
||||||
|
#define CURL_GLOBAL_WIN32 (1<<1)
|
||||||
|
#define CURL_GLOBAL_ALL (CURL_GLOBAL_SSL|CURL_GLOBAL_WIN32)
|
||||||
|
#define CURL_GLOBAL_NOTHING 0
|
||||||
|
#define CURL_GLOBAL_DEFAULT CURL_GLOBAL_ALL
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
134
java/CurlGlue.java
Normal file
134
java/CurlGlue.java
Normal file
@@ -0,0 +1,134 @@
|
|||||||
|
/**
|
||||||
|
* The curl class is a JNI wrapper for libcurl. Please bear with me, I'm no
|
||||||
|
* true java dude (yet). Improve what you think is bad and send me the
|
||||||
|
* updates!
|
||||||
|
* daniel@haxx.se
|
||||||
|
*
|
||||||
|
* This is meant as a raw, crude and low-level interface to libcurl. If you
|
||||||
|
* want fancy stuff, build upon this.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class CurlGlue
|
||||||
|
{
|
||||||
|
// start of imported generated list, make a new list with
|
||||||
|
// define2java.pl on demand
|
||||||
|
public static final int CURLOPT_NOTHING = 0;
|
||||||
|
public static final int CURLOPT_FILE = 10001;
|
||||||
|
public static final int CURLOPT_URL = 10002;
|
||||||
|
public static final int CURLOPT_PORT = 3;
|
||||||
|
public static final int CURLOPT_PROXY = 10004;
|
||||||
|
public static final int CURLOPT_USERPWD = 10005;
|
||||||
|
public static final int CURLOPT_PROXYUSERPWD = 10006;
|
||||||
|
public static final int CURLOPT_RANGE = 10007;
|
||||||
|
public static final int CURLOPT_INFILE = 10009;
|
||||||
|
public static final int CURLOPT_ERRORBUFFER = 10010;
|
||||||
|
public static final int CURLOPT_WRITEFUNCTION = 20011;
|
||||||
|
public static final int CURLOPT_READFUNCTION = 20012;
|
||||||
|
public static final int CURLOPT_TIMEOUT = 13;
|
||||||
|
public static final int CURLOPT_INFILESIZE = 14;
|
||||||
|
public static final int CURLOPT_POSTFIELDS = 10015;
|
||||||
|
public static final int CURLOPT_REFERER = 10016;
|
||||||
|
public static final int CURLOPT_FTPPORT = 10017;
|
||||||
|
public static final int CURLOPT_USERAGENT = 10018;
|
||||||
|
public static final int CURLOPT_LOW_SPEED_LIMIT = 19;
|
||||||
|
public static final int CURLOPT_LOW_SPEED_TIME = 20;
|
||||||
|
public static final int CURLOPT_RESUME_FROM = 21;
|
||||||
|
public static final int CURLOPT_COOKIE = 10022;
|
||||||
|
public static final int CURLOPT_HTTPHEADER = 10023;
|
||||||
|
public static final int CURLOPT_HTTPPOST = 10024;
|
||||||
|
public static final int CURLOPT_SSLCERT = 10025;
|
||||||
|
public static final int CURLOPT_SSLCERTPASSWD = 10026;
|
||||||
|
public static final int CURLOPT_CRLF = 27;
|
||||||
|
public static final int CURLOPT_QUOTE = 10028;
|
||||||
|
public static final int CURLOPT_WRITEHEADER = 10029;
|
||||||
|
public static final int CURLOPT_COOKIEFILE = 10031;
|
||||||
|
public static final int CURLOPT_SSLVERSION = 32;
|
||||||
|
public static final int CURLOPT_TIMECONDITION = 33;
|
||||||
|
public static final int CURLOPT_TIMEVALUE = 34;
|
||||||
|
public static final int CURLOPT_HTTPREQUEST = 10035;
|
||||||
|
public static final int CURLOPT_CUSTOMREQUEST = 10036;
|
||||||
|
public static final int CURLOPT_STDERR = 10037;
|
||||||
|
public static final int CURLOPT_POSTQUOTE = 10039;
|
||||||
|
public static final int CURLOPT_WRITEINFO = 10040;
|
||||||
|
public static final int CURLOPT_VERBOSE = 41;
|
||||||
|
public static final int CURLOPT_HEADER = 42;
|
||||||
|
public static final int CURLOPT_NOPROGRESS = 43;
|
||||||
|
public static final int CURLOPT_NOBODY = 44;
|
||||||
|
public static final int CURLOPT_FAILONERROR = 45;
|
||||||
|
public static final int CURLOPT_UPLOAD = 46;
|
||||||
|
public static final int CURLOPT_POST = 47;
|
||||||
|
public static final int CURLOPT_FTPLISTONLY = 48;
|
||||||
|
public static final int CURLOPT_FTPAPPEND = 50;
|
||||||
|
public static final int CURLOPT_NETRC = 51;
|
||||||
|
public static final int CURLOPT_FOLLOWLOCATION = 52;
|
||||||
|
public static final int CURLOPT_FTPASCII = 53;
|
||||||
|
public static final int CURLOPT_TRANSFERTEXT = 53;
|
||||||
|
public static final int CURLOPT_PUT = 54;
|
||||||
|
public static final int CURLOPT_MUTE = 55;
|
||||||
|
public static final int CURLOPT_PROGRESSFUNCTION = 20056;
|
||||||
|
public static final int CURLOPT_PROGRESSDATA = 10057;
|
||||||
|
public static final int CURLOPT_AUTOREFERER = 58;
|
||||||
|
public static final int CURLOPT_PROXYPORT = 59;
|
||||||
|
public static final int CURLOPT_POSTFIELDSIZE = 60;
|
||||||
|
public static final int CURLOPT_HTTPPROXYTUNNEL = 61;
|
||||||
|
public static final int CURLOPT_INTERFACE = 10062;
|
||||||
|
public static final int CURLOPT_KRB4LEVEL = 10063;
|
||||||
|
public static final int CURLOPT_SSL_VERIFYPEER = 64;
|
||||||
|
public static final int CURLOPT_CAINFO = 10065;
|
||||||
|
public static final int CURLOPT_PASSWDFUNCTION = 20066;
|
||||||
|
public static final int CURLOPT_PASSWDDATA = 10067;
|
||||||
|
public static final int CURLOPT_MAXREDIRS = 68;
|
||||||
|
public static final int CURLOPT_FILETIME = 10069;
|
||||||
|
public static final int CURLOPT_TELNETOPTIONS = 10070;
|
||||||
|
public static final int CURLOPT_MAXCONNECTS = 71;
|
||||||
|
public static final int CURLOPT_CLOSEPOLICY = 72;
|
||||||
|
public static final int CURLOPT_CLOSEFUNCTION = 20073;
|
||||||
|
public static final int CURLOPT_FRESH_CONNECT = 74;
|
||||||
|
public static final int CURLOPT_FORBID_REUSE = 75;
|
||||||
|
public static final int CURLOPT_RANDOM_FILE = 10076;
|
||||||
|
public static final int CURLOPT_EGDSOCKET = 10077;
|
||||||
|
public static final int CURLOPT_CONNECTTIMEOUT = 78;
|
||||||
|
public static final int CURLOPT_HEADERFUNCTION = 20079;
|
||||||
|
// end of generated list
|
||||||
|
|
||||||
|
public CurlGlue() {
|
||||||
|
javacurl_handle = jni_init();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void finalize() {
|
||||||
|
jni_cleanup(javacurl_handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
private int javacurl_handle;
|
||||||
|
|
||||||
|
/* constructor and destructor for the libcurl handle */
|
||||||
|
private native int jni_init();
|
||||||
|
private native void jni_cleanup(int javacurl_handle);
|
||||||
|
private native synchronized int jni_perform(int javacurl_handle);
|
||||||
|
|
||||||
|
// Instead of varargs, we have different functions for each
|
||||||
|
// kind of type setopt() can take
|
||||||
|
private native int jni_setopt(int libcurl, int option, String value);
|
||||||
|
private native int jni_setopt(int libcurl, int option, int value);
|
||||||
|
private native int jni_setopt(int libcurl, int option, CurlWrite value);
|
||||||
|
|
||||||
|
public native int getinfo();
|
||||||
|
|
||||||
|
public int perform() {
|
||||||
|
return jni_perform(javacurl_handle);
|
||||||
|
}
|
||||||
|
public int setopt(int option, int value) {
|
||||||
|
return jni_setopt(javacurl_handle, option, value);
|
||||||
|
}
|
||||||
|
public int setopt(int option, String value) {
|
||||||
|
return jni_setopt(javacurl_handle, option, value);
|
||||||
|
}
|
||||||
|
public int setopt(int option, CurlWrite value) {
|
||||||
|
return jni_setopt(javacurl_handle, option, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
static {
|
||||||
|
System.loadLibrary("javacurl");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
9
java/CurlWrite.java
Normal file
9
java/CurlWrite.java
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
public interface CurlWrite
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* handleString gets called by libcurl on each chunk of data
|
||||||
|
* we receive from the remote server
|
||||||
|
*/
|
||||||
|
public int handleString(byte s[]);
|
||||||
|
}
|
||||||
|
|
35
java/Makefile
Normal file
35
java/Makefile
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
|
||||||
|
TARGET = libjavacurl.so
|
||||||
|
|
||||||
|
OBJS = javacurl.o
|
||||||
|
|
||||||
|
CC = gcc
|
||||||
|
CFLAGS = -c
|
||||||
|
CPPFLAGS = -I/usr/j2se/include -I/usr/local/include -I/usr/j2se/include/solaris
|
||||||
|
|
||||||
|
# Linux might use -shared -Wl,-soname,libnative.so instead of -G
|
||||||
|
LDFLAGS = -G -lcurl -ldl -L/usr/local/ssl/lib -lssl -lcrypto
|
||||||
|
|
||||||
|
all: CurlGlue.h CurlGlue.class javacurl.o $(TARGET) test.class
|
||||||
|
|
||||||
|
test:
|
||||||
|
java test
|
||||||
|
|
||||||
|
javacurl.o: javacurl.c CurlGlue.h
|
||||||
|
$(CC) $(CPPFLAGS) $(CFLAGS) $<
|
||||||
|
|
||||||
|
CurlGlue.h: CurlGlue.java CurlGlue.class
|
||||||
|
javah CurlGlue
|
||||||
|
touch CurlGlue.h
|
||||||
|
|
||||||
|
test.class: CurlGlue.class javacurl.o
|
||||||
|
javac test.java
|
||||||
|
|
||||||
|
CurlGlue.class: CurlGlue.java
|
||||||
|
javac $<
|
||||||
|
|
||||||
|
$(TARGET): $(OBJS)
|
||||||
|
$(CC) -o $(TARGET) $(LDFLAGS) $(OBJS)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f javacurl.o CurlGlue.h CurlGlue.class
|
15
java/README
Normal file
15
java/README
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
_ _ ____ _
|
||||||
|
___| | | | _ \| |
|
||||||
|
/ __| | | | |_) | |
|
||||||
|
| (__| |_| | _ <| |___
|
||||||
|
\___|\___/|_| \_\_____|
|
||||||
|
|
||||||
|
Java Interface
|
||||||
|
|
||||||
|
This is not a complete implementation of a libcurl interface. I've made the
|
||||||
|
core work and it needs additional code to be added to get the rest of the
|
||||||
|
stuff supported.
|
||||||
|
|
||||||
|
The interface is not set yet, bring your suggestions!
|
||||||
|
|
||||||
|
Feel free to grab the source files in here and help out!
|
22
java/define2java.pl
Executable file
22
java/define2java.pl
Executable file
@@ -0,0 +1,22 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
open(GCC, "gcc -E ../include/curl/curl.h|");
|
||||||
|
|
||||||
|
while(<GCC>) {
|
||||||
|
if($_ =~ /(CURLOPT_(.*)) += (.*)/) {
|
||||||
|
$var= $1;
|
||||||
|
$expr = $3;
|
||||||
|
$f=$3;
|
||||||
|
if($expr =~ / *(\d+) *\+ *(\d+)/) {
|
||||||
|
$expr = $1+$2;
|
||||||
|
}
|
||||||
|
|
||||||
|
# nah, keep the CURL prefix to make them look like other
|
||||||
|
# languages' defines
|
||||||
|
# $var =~ s/^CURL//g;
|
||||||
|
|
||||||
|
print " public static final int $var = $expr;\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
close(GCC);
|
196
java/javacurl.c
Normal file
196
java/javacurl.c
Normal file
@@ -0,0 +1,196 @@
|
|||||||
|
|
||||||
|
#include <curl/curl.h> /* libcurl header */
|
||||||
|
#include "CurlGlue.h" /* the JNI-generated glue header file */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is a private struct allocated for every 'CurlGlue' object.
|
||||||
|
*/
|
||||||
|
struct javacurl {
|
||||||
|
void *libcurl;
|
||||||
|
void *whatever;
|
||||||
|
struct writecallback {
|
||||||
|
jmethodID mid;
|
||||||
|
JNIEnv *java;
|
||||||
|
jclass cls; /* global reference */
|
||||||
|
jobject object;
|
||||||
|
} write;
|
||||||
|
};
|
||||||
|
|
||||||
|
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1init(JNIEnv *java,
|
||||||
|
jobject myself)
|
||||||
|
{
|
||||||
|
void *libhandle;
|
||||||
|
struct javacurl *jcurl=NULL;
|
||||||
|
|
||||||
|
libhandle = curl_easy_init();
|
||||||
|
|
||||||
|
if(libhandle) {
|
||||||
|
jcurl=(struct javacurl *)malloc(sizeof(struct javacurl));
|
||||||
|
if(jcurl) {
|
||||||
|
memset(jcurl, 0, sizeof(struct javacurl));
|
||||||
|
jcurl->libcurl = libhandle;
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
curl_easy_cleanup(libhandle);
|
||||||
|
return (jint)0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return (jint) jcurl; /* nasty typecast */
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL Java_CurlGlue_jni_1cleanup(JNIEnv *java,
|
||||||
|
jobject myself,
|
||||||
|
jint jcurl)
|
||||||
|
{
|
||||||
|
|
||||||
|
struct javacurl *curl = (struct javacurl*)jcurl;
|
||||||
|
|
||||||
|
if(curl->write.cls) {
|
||||||
|
/* a global reference we must delete */
|
||||||
|
(*java)->DeleteGlobalRef(java, curl->write.cls);
|
||||||
|
(*java)->DeleteGlobalRef(java, curl->write.object);
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_easy_cleanup(curl->libcurl); /* cleanup libcurl stuff */
|
||||||
|
|
||||||
|
free((void *)curl); /* free the struct too */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* setopt() int + string
|
||||||
|
*/
|
||||||
|
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1setopt__IILjava_lang_String_2
|
||||||
|
(JNIEnv *java, jobject myself, jint jcurl, jint option, jstring value)
|
||||||
|
{
|
||||||
|
/* get the actual string C-style */
|
||||||
|
const char *str = (*java)->GetStringUTFChars(java, value, 0);
|
||||||
|
|
||||||
|
void *handle = (void *)((struct javacurl*)jcurl)->libcurl;
|
||||||
|
|
||||||
|
puts("setopt int + string");
|
||||||
|
|
||||||
|
return (jint)curl_easy_setopt(handle, (CURLoption)option, str);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* setopt() int + int
|
||||||
|
*/
|
||||||
|
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1setopt__III
|
||||||
|
(JNIEnv *java, jobject myself, jint jcurl, jint option, jint value)
|
||||||
|
{
|
||||||
|
void *handle = (void *)((struct javacurl*)jcurl)->libcurl;
|
||||||
|
CURLoption opt = (CURLoption)option;
|
||||||
|
|
||||||
|
puts("setopt int + int");
|
||||||
|
|
||||||
|
switch(opt) {
|
||||||
|
case CURLOPT_FILE:
|
||||||
|
/* silently ignored, we don't need user-specified callback data when
|
||||||
|
we have an object, and besides the CURLOPT_FILE is not exported
|
||||||
|
to the java interface */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (jint)curl_easy_setopt(handle, (CURLoption)option, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int javacurl_write_callback(void *ptr,
|
||||||
|
size_t size,
|
||||||
|
size_t nmemb,
|
||||||
|
FILE *stream)
|
||||||
|
{
|
||||||
|
struct javacurl *curl = (struct javacurl *)stream;
|
||||||
|
size_t realsize = size * nmemb;
|
||||||
|
JNIEnv *java = curl->write.java;
|
||||||
|
jbyteArray jb=NULL;
|
||||||
|
int ret=0;
|
||||||
|
|
||||||
|
fprintf(stderr, "%d bytes data received in callback:\n"
|
||||||
|
"ptr=%p, java=%p cls=%p\n",
|
||||||
|
realsize, curl, java, curl->write.cls);
|
||||||
|
|
||||||
|
jb=(*java)->NewByteArray(java, realsize);
|
||||||
|
(*java)->SetByteArrayRegion(java, jb, 0,
|
||||||
|
realsize, (jbyte *)ptr);
|
||||||
|
|
||||||
|
fprintf(stderr, "created byte-array\n");
|
||||||
|
|
||||||
|
ret = (*java)->CallIntMethod(java,
|
||||||
|
curl->write.object,
|
||||||
|
curl->write.mid,
|
||||||
|
jb);
|
||||||
|
|
||||||
|
fprintf(stderr, "java-method returned %d\n", ret);
|
||||||
|
|
||||||
|
return realsize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* setopt() int + object
|
||||||
|
*/
|
||||||
|
|
||||||
|
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1setopt__IILCurlWrite_2
|
||||||
|
(JNIEnv *java, jobject myself, jint jcurl, jint option, jobject object)
|
||||||
|
{
|
||||||
|
jclass cls_local = (*java)->GetObjectClass(java, object);
|
||||||
|
jmethodID mid;
|
||||||
|
struct javacurl *curl = (struct javacurl *)jcurl;
|
||||||
|
jclass cls;
|
||||||
|
jobject obj_global;
|
||||||
|
|
||||||
|
switch(option) {
|
||||||
|
case CURLOPT_WRITEFUNCTION:
|
||||||
|
/* this makes a reference that'll be alive until we kill it! */
|
||||||
|
cls = (*java)->NewGlobalRef(java, cls_local);
|
||||||
|
|
||||||
|
printf("setopt int + object, option = %d cls= %p\n",
|
||||||
|
option, cls);
|
||||||
|
|
||||||
|
if(!cls) {
|
||||||
|
puts("couldn't make local reference global");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* this is the write callback */
|
||||||
|
mid = (*java)->GetMethodID(java, cls, "handleString", "([B)I");
|
||||||
|
if(!mid) {
|
||||||
|
puts("no callback method found");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
obj_global = (*java)->NewGlobalRef(java, object);
|
||||||
|
|
||||||
|
curl->write.mid = mid;
|
||||||
|
curl->write.cls = cls;
|
||||||
|
curl->write.object = obj_global;
|
||||||
|
/*curl->write.java = java; stored on perform */
|
||||||
|
|
||||||
|
fprintf(stderr, "setopt write callback and write file pointer %p, java = %p\n",
|
||||||
|
curl, java);
|
||||||
|
|
||||||
|
curl_easy_setopt(curl->libcurl, CURLOPT_WRITEFUNCTION,
|
||||||
|
javacurl_write_callback);
|
||||||
|
curl_easy_setopt(curl->libcurl, CURLOPT_FILE,
|
||||||
|
curl);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jint JNICALL Java_CurlGlue_getinfo
|
||||||
|
(JNIEnv *java, jobject value)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jint JNICALL Java_CurlGlue_jni_1perform
|
||||||
|
(JNIEnv *java, jobject myself, jint jcurl)
|
||||||
|
{
|
||||||
|
struct javacurl *curl=(struct javacurl*)jcurl;
|
||||||
|
curl->write.java = java;
|
||||||
|
return (jint)curl_easy_perform(curl->libcurl);
|
||||||
|
}
|
27
java/test.java
Normal file
27
java/test.java
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
import CurlGlue;
|
||||||
|
import CurlWrite;
|
||||||
|
|
||||||
|
class test implements CurlWrite {
|
||||||
|
public int handleString(byte s[])
|
||||||
|
{
|
||||||
|
/* output everything */
|
||||||
|
System.out.println("IIIIIIIIIII -------------- OOOOOOOOOOOOOOOOOOO");
|
||||||
|
try {
|
||||||
|
System.out.write(s);
|
||||||
|
}
|
||||||
|
catch (java.io.IOException moo) {
|
||||||
|
// nothing
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args)
|
||||||
|
{
|
||||||
|
CurlGlue cg = new CurlGlue();
|
||||||
|
test cw = new test();
|
||||||
|
cg.setopt(CurlGlue.CURLOPT_URL, "http://www.contactor.se/");
|
||||||
|
cg.setopt(CurlGlue.CURLOPT_WRITEFUNCTION, cw);
|
||||||
|
cg.perform();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
6
lib/.cvsignore
Normal file
6
lib/.cvsignore
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
*.la
|
||||||
|
*.lo
|
||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
.deps
|
||||||
|
.libs
|
@@ -16,7 +16,7 @@ lib_LTLIBRARIES = libcurl.la
|
|||||||
INCLUDES = -I$(top_srcdir)/include
|
INCLUDES = -I$(top_srcdir)/include
|
||||||
|
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = -version-info 2:0:0
|
libcurl_la_LDFLAGS = -version-info 2:1: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.
|
||||||
@@ -59,7 +59,7 @@ escape.c mprintf.c telnet.c \
|
|||||||
escape.h getpass.c netrc.c telnet.h \
|
escape.h getpass.c netrc.c telnet.h \
|
||||||
getinfo.c transfer.c strequal.c strequal.h easy.c \
|
getinfo.c transfer.c strequal.c strequal.h easy.c \
|
||||||
security.h security.c krb4.c krb4.h memdebug.c memdebug.h inet_ntoa_r.h \
|
security.h security.c krb4.c krb4.h memdebug.c memdebug.h inet_ntoa_r.h \
|
||||||
http_chunks.c http_chunks.h
|
http_chunks.c http_chunks.h strtok.c strtok.h
|
||||||
|
|
||||||
noinst_HEADERS = setup.h transfer.h
|
noinst_HEADERS = setup.h transfer.h
|
||||||
|
|
||||||
|
@@ -14,7 +14,7 @@ RM = del
|
|||||||
LIB = tlib
|
LIB = tlib
|
||||||
TOPDIR = ..
|
TOPDIR = ..
|
||||||
CURNTDIR = .
|
CURNTDIR = .
|
||||||
CXXFLAGS = -5 -O2 -w-aus -w-ccc -w-csu -w-par -w-pia -w-rch -w-inl -w-ngu -w-pro
|
CXXFLAGS = -5 -O2 -w-aus -w-ccc -w-csu -w-par -w-pia -w-rch -w-inl -w-ngu -w-pro -tWM
|
||||||
DEFINES = -DLIBCURL_BIGENDIAN=0 -DNDEBUG -DWIN32 -DCONSOLE -DMBCS
|
DEFINES = -DLIBCURL_BIGENDIAN=0 -DNDEBUG -DWIN32 -DCONSOLE -DMBCS
|
||||||
INCDIRS = -I$(CURNTDIR);$(TOPDIR)/include/
|
INCDIRS = -I$(CURNTDIR);$(TOPDIR)/include/
|
||||||
|
|
||||||
@@ -34,6 +34,7 @@ SOURCES = \
|
|||||||
formdata.c \
|
formdata.c \
|
||||||
ftp.c \
|
ftp.c \
|
||||||
http.c \
|
http.c \
|
||||||
|
http_chunks.c \
|
||||||
ldap.c \
|
ldap.c \
|
||||||
dict.c \
|
dict.c \
|
||||||
telnet.c \
|
telnet.c \
|
||||||
@@ -54,7 +55,8 @@ SOURCES = \
|
|||||||
getinfo.c \
|
getinfo.c \
|
||||||
version.c \
|
version.c \
|
||||||
easy.c \
|
easy.c \
|
||||||
strequal.c
|
strequal.c \
|
||||||
|
strtok.c
|
||||||
|
|
||||||
OBJECTS = $(SOURCES:.c=.obj)
|
OBJECTS = $(SOURCES:.c=.obj)
|
||||||
|
|
||||||
@@ -64,11 +66,11 @@ OBJECTS = $(SOURCES:.c=.obj)
|
|||||||
all: $(LIBCURLLIB)
|
all: $(LIBCURLLIB)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
$(RM) $(LIBCURLLIB)
|
-$(RM) $(LIBCURLLIB)
|
||||||
$(RM) *.obj
|
-$(RM) *.obj
|
||||||
|
|
||||||
$(LIBCURLLIB): $(LINKLIB) $(OBJECTS) Makefile.b32.resp
|
$(LIBCURLLIB): $(LINKLIB) $(OBJECTS) Makefile.b32.resp
|
||||||
$(RM) $(LIBCURLLIB)
|
-$(RM) $(LIBCURLLIB)
|
||||||
$(LIB) $(LIBCURLLIB) @Makefile.b32.resp
|
$(LIB) $(LIBCURLLIB) @Makefile.b32.resp
|
||||||
|
|
||||||
|
|
||||||
|
@@ -5,6 +5,7 @@
|
|||||||
+formdata.obj &
|
+formdata.obj &
|
||||||
+ftp.obj &
|
+ftp.obj &
|
||||||
+http.obj &
|
+http.obj &
|
||||||
|
+http_chunks.obj &
|
||||||
+ldap.obj &
|
+ldap.obj &
|
||||||
+dict.obj &
|
+dict.obj &
|
||||||
+telnet.obj &
|
+telnet.obj &
|
||||||
|
@@ -33,13 +33,15 @@ libcurl_a_SOURCES = arpa_telnet.h file.c getpass.h netrc.h timeval.c base64.c \
|
|||||||
urldata.h transfer.c getdate.h ldap.c ssluse.c version.c transfer.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 strequal.c strequal.h easy.c security.h \
|
telnet.h getinfo.c strequal.c strequal.h easy.c security.h \
|
||||||
security.c krb4.h krb4.c memdebug.h memdebug.c inet_ntoa_r.h http_chunks.h http_chunks.c
|
security.c krb4.h krb4.c memdebug.h memdebug.c inet_ntoa_r.h http_chunks.h http_chunks.c \
|
||||||
|
strtok.c
|
||||||
|
|
||||||
libcurl_a_OBJECTS = file.o timeval.o base64.o hostip.o progress.o \
|
libcurl_a_OBJECTS = file.o timeval.o base64.o hostip.o progress.o \
|
||||||
formdata.o cookie.o http.o sendf.o ftp.o url.o dict.o if2ip.o \
|
formdata.o cookie.o http.o sendf.o ftp.o url.o dict.o if2ip.o \
|
||||||
speedcheck.o getdate.o transfer.o ldap.o ssluse.o version.o \
|
speedcheck.o getdate.o transfer.o ldap.o ssluse.o version.o \
|
||||||
getenv.o escape.o mprintf.o telnet.o getpass.o netrc.o getinfo.o \
|
getenv.o escape.o mprintf.o telnet.o getpass.o netrc.o getinfo.o \
|
||||||
strequal.o easy.o security.o krb4.o memdebug.o http_chunks.o
|
strequal.o easy.o security.o krb4.o memdebug.o http_chunks.o \
|
||||||
|
strtok.o
|
||||||
|
|
||||||
LIBRARIES = $(libcurl_a_LIBRARIES)
|
LIBRARIES = $(libcurl_a_LIBRARIES)
|
||||||
SOURCES = $(libcurl_a_SOURCES)
|
SOURCES = $(libcurl_a_SOURCES)
|
||||||
|
@@ -5,10 +5,11 @@
|
|||||||
##
|
##
|
||||||
## Comments to: Troy Engel <tengel@sonic.net>
|
## Comments to: Troy Engel <tengel@sonic.net>
|
||||||
## Updated by: Craig Davison <cd@securityfocus.com>
|
## Updated by: Craig Davison <cd@securityfocus.com>
|
||||||
|
## Updated by: SM <sm@technologist.com>
|
||||||
|
|
||||||
PROGRAM_NAME = libcurl.lib
|
PROGRAM_NAME = libcurl.lib
|
||||||
PROGRAM_NAME_DEBUG = libcurld.lib
|
PROGRAM_NAME_DEBUG = libcurld.lib
|
||||||
OPENSSL_PATH = ../../openssl-0.9.6
|
#OPENSSL_PATH = ../../openssl-0.9.6a
|
||||||
|
|
||||||
########################################################
|
########################################################
|
||||||
## Nothing more to do below this line!
|
## Nothing more to do below this line!
|
||||||
@@ -22,7 +23,7 @@ CCD = cl.exe /MDd /Gm /ZI /Od /D "_DEBUG" /GZ
|
|||||||
LINKD = link.exe -lib /out:$(PROGRAM_NAME_DEBUG)
|
LINKD = link.exe -lib /out:$(PROGRAM_NAME_DEBUG)
|
||||||
|
|
||||||
## SSL Release
|
## SSL Release
|
||||||
CCRS = cl.exe /MD /O2 /D "NDEBUG" /D "USE_SSLEAY" /I "$(OPENSSL_PATH)/include" /I "$(OPENSSL_PATH)/include/openssl"
|
CCRS = cl.exe /MD /O2 /D "NDEBUG" /D "USE_SSLEAY" /I "$(OPENSSL_PATH)/inc32" /I "$(OPENSSL_PATH)/inc32/openssl"
|
||||||
LINKRS = link.exe -lib /out:$(PROGRAM_NAME) /LIBPATH:$(OPENSSL_PATH)/out32dll
|
LINKRS = link.exe -lib /out:$(PROGRAM_NAME) /LIBPATH:$(OPENSSL_PATH)/out32dll
|
||||||
|
|
||||||
CFLAGS = /I "../include" /nologo /W3 /GX /D "WIN32" /D "VC6" /D "_MBCS" /D "_LIB" /YX /FD /c /D "MSDOS"
|
CFLAGS = /I "../include" /nologo /W3 /GX /D "WIN32" /D "VC6" /D "_MBCS" /D "_LIB" /YX /FD /c /D "MSDOS"
|
||||||
@@ -38,6 +39,7 @@ RELEASE_OBJS= \
|
|||||||
formdatar.obj \
|
formdatar.obj \
|
||||||
ftpr.obj \
|
ftpr.obj \
|
||||||
httpr.obj \
|
httpr.obj \
|
||||||
|
http_chunksr.obj \
|
||||||
ldapr.obj \
|
ldapr.obj \
|
||||||
dictr.obj \
|
dictr.obj \
|
||||||
telnetr.obj \
|
telnetr.obj \
|
||||||
@@ -58,7 +60,8 @@ RELEASE_OBJS= \
|
|||||||
getinfor.obj \
|
getinfor.obj \
|
||||||
versionr.obj \
|
versionr.obj \
|
||||||
easyr.obj \
|
easyr.obj \
|
||||||
strequalr.obj
|
strequalr.obj \
|
||||||
|
strtokr.obj
|
||||||
|
|
||||||
DEBUG_OBJS= \
|
DEBUG_OBJS= \
|
||||||
base64d.obj \
|
base64d.obj \
|
||||||
@@ -68,6 +71,7 @@ DEBUG_OBJS= \
|
|||||||
formdatad.obj \
|
formdatad.obj \
|
||||||
ftpd.obj \
|
ftpd.obj \
|
||||||
httpd.obj \
|
httpd.obj \
|
||||||
|
http_chunksd.obj \
|
||||||
ldapd.obj \
|
ldapd.obj \
|
||||||
dictd.obj \
|
dictd.obj \
|
||||||
telnetd.obj \
|
telnetd.obj \
|
||||||
@@ -88,7 +92,8 @@ DEBUG_OBJS= \
|
|||||||
getinfod.obj \
|
getinfod.obj \
|
||||||
versiond.obj \
|
versiond.obj \
|
||||||
easyd.obj \
|
easyd.obj \
|
||||||
strequald.obj
|
strequald.obj \
|
||||||
|
strtokd.obj
|
||||||
|
|
||||||
RELEASE_SSL_OBJS= \
|
RELEASE_SSL_OBJS= \
|
||||||
base64rs.obj \
|
base64rs.obj \
|
||||||
@@ -98,6 +103,7 @@ RELEASE_SSL_OBJS= \
|
|||||||
formdatars.obj \
|
formdatars.obj \
|
||||||
ftprs.obj \
|
ftprs.obj \
|
||||||
httprs.obj \
|
httprs.obj \
|
||||||
|
http_chunksrs.obj \
|
||||||
ldaprs.obj \
|
ldaprs.obj \
|
||||||
dictrs.obj \
|
dictrs.obj \
|
||||||
telnetrs.obj \
|
telnetrs.obj \
|
||||||
@@ -118,7 +124,8 @@ RELEASE_SSL_OBJS= \
|
|||||||
getinfors.obj \
|
getinfors.obj \
|
||||||
versionrs.obj \
|
versionrs.obj \
|
||||||
easyrs.obj \
|
easyrs.obj \
|
||||||
strequalrs.obj
|
strequalrs.obj \
|
||||||
|
strtokd.obj
|
||||||
|
|
||||||
LINK_OBJS= \
|
LINK_OBJS= \
|
||||||
base64.obj \
|
base64.obj \
|
||||||
@@ -128,6 +135,7 @@ LINK_OBJS= \
|
|||||||
formdata.obj \
|
formdata.obj \
|
||||||
ftp.obj \
|
ftp.obj \
|
||||||
http.obj \
|
http.obj \
|
||||||
|
http_chunks.obj \
|
||||||
ldap.obj \
|
ldap.obj \
|
||||||
dict.obj \
|
dict.obj \
|
||||||
telnet.obj \
|
telnet.obj \
|
||||||
@@ -148,7 +156,8 @@ LINK_OBJS= \
|
|||||||
getinfo.obj \
|
getinfo.obj \
|
||||||
version.obj \
|
version.obj \
|
||||||
easy.obj \
|
easy.obj \
|
||||||
strequal.obj
|
strequal.obj \
|
||||||
|
strtok.obj
|
||||||
|
|
||||||
all : release
|
all : release
|
||||||
|
|
||||||
@@ -176,6 +185,8 @@ ftpr.obj: ftp.c
|
|||||||
$(CCR) $(CFLAGS) ftp.c
|
$(CCR) $(CFLAGS) ftp.c
|
||||||
httpr.obj: http.c
|
httpr.obj: http.c
|
||||||
$(CCR) $(CFLAGS) http.c
|
$(CCR) $(CFLAGS) http.c
|
||||||
|
http_chunksr.obj: http_chunks.c
|
||||||
|
$(CCR) $(CFLAGS) http_chunks.c
|
||||||
ldapr.obj: ldap.c
|
ldapr.obj: ldap.c
|
||||||
$(CCR) $(CFLAGS) ldap.c
|
$(CCR) $(CFLAGS) ldap.c
|
||||||
dictr.obj: dict.c
|
dictr.obj: dict.c
|
||||||
@@ -218,6 +229,8 @@ easyr.obj: easy.c
|
|||||||
$(CCR) $(CFLAGS) easy.c
|
$(CCR) $(CFLAGS) easy.c
|
||||||
strequalr.obj: strequal.c
|
strequalr.obj: strequal.c
|
||||||
$(CCR) $(CFLAGS) strequal.c
|
$(CCR) $(CFLAGS) strequal.c
|
||||||
|
strtokr.obj:strtok.c
|
||||||
|
$(CCR) $(CFLAGS) strtok.c
|
||||||
|
|
||||||
## Debug
|
## Debug
|
||||||
base64d.obj: base64.c
|
base64d.obj: base64.c
|
||||||
@@ -234,6 +247,8 @@ ftpd.obj: ftp.c
|
|||||||
$(CCD) $(CFLAGS) ftp.c
|
$(CCD) $(CFLAGS) ftp.c
|
||||||
httpd.obj: http.c
|
httpd.obj: http.c
|
||||||
$(CCD) $(CFLAGS) http.c
|
$(CCD) $(CFLAGS) http.c
|
||||||
|
http_chunksd.obj: http_chunks.c
|
||||||
|
$(CCD) $(CFLAGS) http_chunks.c
|
||||||
ldapd.obj: ldap.c
|
ldapd.obj: ldap.c
|
||||||
$(CCD) $(CFLAGS) ldap.c
|
$(CCD) $(CFLAGS) ldap.c
|
||||||
dictd.obj: dict.c
|
dictd.obj: dict.c
|
||||||
@@ -276,7 +291,8 @@ easyd.obj: easy.c
|
|||||||
$(CCD) $(CFLAGS) easy.c
|
$(CCD) $(CFLAGS) easy.c
|
||||||
strequald.obj: strequal.c
|
strequald.obj: strequal.c
|
||||||
$(CCD) $(CFLAGS) strequal.c
|
$(CCD) $(CFLAGS) strequal.c
|
||||||
|
strtokd.obj:strtok.c
|
||||||
|
$(CCR) $(CFLAGS) strtok.c
|
||||||
|
|
||||||
## Release SSL
|
## Release SSL
|
||||||
base64rs.obj: base64.c
|
base64rs.obj: base64.c
|
||||||
@@ -292,7 +308,9 @@ formdatars.obj: formdata.c
|
|||||||
ftprs.obj: ftp.c
|
ftprs.obj: ftp.c
|
||||||
$(CCRS) $(CFLAGS) ftp.c
|
$(CCRS) $(CFLAGS) ftp.c
|
||||||
httprs.obj: http.c
|
httprs.obj: http.c
|
||||||
$(CCRS) $(CFLAGS) http.c
|
$(CCR) $(CFLAGS) http.c
|
||||||
|
http_chunksrs.obj: http_chunks.c
|
||||||
|
$(CCRS) $(CFLAGS) http_chunks.c
|
||||||
ldaprs.obj: ldap.c
|
ldaprs.obj: ldap.c
|
||||||
$(CCRS) $(CFLAGS) ldap.c
|
$(CCRS) $(CFLAGS) ldap.c
|
||||||
dictrs.obj: dict.c
|
dictrs.obj: dict.c
|
||||||
@@ -335,6 +353,8 @@ easyrs.obj: easy.c
|
|||||||
$(CCRS) $(CFLAGS) easy.c
|
$(CCRS) $(CFLAGS) easy.c
|
||||||
strequalrs.obj: strequal.c
|
strequalrs.obj: strequal.c
|
||||||
$(CCRS) $(CFLAGS) strequal.c
|
$(CCRS) $(CFLAGS) strequal.c
|
||||||
|
strtokrs.obj:strtok.c
|
||||||
|
$(CCR) $(CFLAGS) strtok.c
|
||||||
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
|
@@ -1,321 +1,101 @@
|
|||||||
/*
|
#ifndef __ARPA_TELNET_H
|
||||||
* Copyright (c) 1983, 1993
|
#define __ARPA_TELNET_H
|
||||||
* The Regents of the University of California. All rights reserved.
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
* 3. All advertising materials mentioning features or use of this software
|
|
||||||
* must display the following acknowledgement:
|
|
||||||
* This product includes software developed by the University of
|
|
||||||
* California, Berkeley and its contributors.
|
|
||||||
* 4. Neither the name of the University nor the names of its contributors
|
|
||||||
* may be used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*
|
*
|
||||||
* @(#)telnet.h 8.2 (Berkeley) 12/15/93
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
*/
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
#ifndef _ARPA_TELNET_H
|
* licenses. You may pick one of these licenses.
|
||||||
#define _ARPA_TELNET_H
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Definitions for the TELNET protocol.
|
* Telnet option defines. Add more here if in need.
|
||||||
*/
|
*/
|
||||||
#define IAC 255 /* interpret as command: */
|
#define TELOPT_BINARY 0 /* binary 8bit data */
|
||||||
#define DONT 254 /* you are not to use option */
|
#define TELOPT_SGA 3 /* Supress Go Ahead */
|
||||||
#define DO 253 /* please, you use option */
|
#define TELOPT_EXOPL 255 /* EXtended OPtions List */
|
||||||
#define WONT 252 /* I won't use option */
|
#define TELOPT_TTYPE 24 /* Terminal TYPE */
|
||||||
#define WILL 251 /* I will use option */
|
#define TELOPT_XDISPLOC 35 /* X DISPlay LOCation */
|
||||||
#define SB 250 /* interpret as subnegotiation */
|
|
||||||
#define GA 249 /* you may reverse the line */
|
|
||||||
#define EL 248 /* erase the current line */
|
|
||||||
#define EC 247 /* erase the current character */
|
|
||||||
#define AYT 246 /* are you there */
|
|
||||||
#define AO 245 /* abort output--but let prog finish */
|
|
||||||
#define IP 244 /* interrupt process--permanently */
|
|
||||||
#define BREAK 243 /* break */
|
|
||||||
#define DM 242 /* data mark--for connect. cleaning */
|
|
||||||
#define NOP 241 /* nop */
|
|
||||||
#define SE 240 /* end sub negotiation */
|
|
||||||
#define EOR 239 /* end of record (transparent mode) */
|
|
||||||
#define ABORT 238 /* Abort process */
|
|
||||||
#define SUSP 237 /* Suspend process */
|
|
||||||
#define xEOF 236 /* End of file: EOF is already used... */
|
|
||||||
|
|
||||||
#define SYNCH 242 /* for telfunc calls */
|
#define TELOPT_NEW_ENVIRON 39 /* NEW ENVIRONment variables */
|
||||||
|
|
||||||
#ifdef TELCMDS
|
|
||||||
static
|
|
||||||
char *telcmds[] = {
|
|
||||||
"EOF", "SUSP", "ABORT", "EOR",
|
|
||||||
"SE", "NOP", "DMARK", "BRK", "IP", "AO", "AYT", "EC",
|
|
||||||
"EL", "GA", "SB", "WILL", "WONT", "DO", "DONT", "IAC", 0,
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *telcmds[];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define TELCMD_FIRST xEOF
|
|
||||||
#define TELCMD_LAST IAC
|
|
||||||
#define TELCMD_OK(x) ((unsigned int)(x) <= TELCMD_LAST && \
|
|
||||||
(unsigned int)(x) >= TELCMD_FIRST)
|
|
||||||
#define TELCMD(x) telcmds[(x)-TELCMD_FIRST]
|
|
||||||
|
|
||||||
/* telnet options */
|
|
||||||
#define TELOPT_BINARY 0 /* 8-bit data path */
|
|
||||||
#define TELOPT_ECHO 1 /* echo */
|
|
||||||
#define TELOPT_RCP 2 /* prepare to reconnect */
|
|
||||||
#define TELOPT_SGA 3 /* suppress go ahead */
|
|
||||||
#define TELOPT_NAMS 4 /* approximate message size */
|
|
||||||
#define TELOPT_STATUS 5 /* give status */
|
|
||||||
#define TELOPT_TM 6 /* timing mark */
|
|
||||||
#define TELOPT_RCTE 7 /* remote controlled transmission and echo */
|
|
||||||
#define TELOPT_NAOL 8 /* negotiate about output line width */
|
|
||||||
#define TELOPT_NAOP 9 /* negotiate about output page size */
|
|
||||||
#define TELOPT_NAOCRD 10 /* negotiate about CR disposition */
|
|
||||||
#define TELOPT_NAOHTS 11 /* negotiate about horizontal tabstops */
|
|
||||||
#define TELOPT_NAOHTD 12 /* negotiate about horizontal tab disposition */
|
|
||||||
#define TELOPT_NAOFFD 13 /* negotiate about formfeed disposition */
|
|
||||||
#define TELOPT_NAOVTS 14 /* negotiate about vertical tab stops */
|
|
||||||
#define TELOPT_NAOVTD 15 /* negotiate about vertical tab disposition */
|
|
||||||
#define TELOPT_NAOLFD 16 /* negotiate about output LF disposition */
|
|
||||||
#define TELOPT_XASCII 17 /* extended ascic character set */
|
|
||||||
#define TELOPT_LOGOUT 18 /* force logout */
|
|
||||||
#define TELOPT_BM 19 /* byte macro */
|
|
||||||
#define TELOPT_DET 20 /* data entry terminal */
|
|
||||||
#define TELOPT_SUPDUP 21 /* supdup protocol */
|
|
||||||
#define TELOPT_SUPDUPOUTPUT 22 /* supdup output */
|
|
||||||
#define TELOPT_SNDLOC 23 /* send location */
|
|
||||||
#define TELOPT_TTYPE 24 /* terminal type */
|
|
||||||
#define TELOPT_EOR 25 /* end or record */
|
|
||||||
#define TELOPT_TUID 26 /* TACACS user identification */
|
|
||||||
#define TELOPT_OUTMRK 27 /* output marking */
|
|
||||||
#define TELOPT_TTYLOC 28 /* terminal location number */
|
|
||||||
#define TELOPT_3270REGIME 29 /* 3270 regime */
|
|
||||||
#define TELOPT_X3PAD 30 /* X.3 PAD */
|
|
||||||
#define TELOPT_NAWS 31 /* window size */
|
|
||||||
#define TELOPT_TSPEED 32 /* terminal speed */
|
|
||||||
#define TELOPT_LFLOW 33 /* remote flow control */
|
|
||||||
#define TELOPT_LINEMODE 34 /* Linemode option */
|
|
||||||
#define TELOPT_XDISPLOC 35 /* X Display Location */
|
|
||||||
#define TELOPT_OLD_ENVIRON 36 /* Old - Environment variables */
|
|
||||||
#define TELOPT_AUTHENTICATION 37/* Authenticate */
|
|
||||||
#define TELOPT_ENCRYPT 38 /* Encryption option */
|
|
||||||
#define TELOPT_NEW_ENVIRON 39 /* New - Environment variables */
|
|
||||||
#define TELOPT_EXOPL 255 /* extended-options-list */
|
|
||||||
|
|
||||||
|
|
||||||
#define NTELOPTS (1+TELOPT_NEW_ENVIRON)
|
|
||||||
#ifdef TELOPTS
|
|
||||||
static
|
|
||||||
char *telopts[NTELOPTS+1] = {
|
|
||||||
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD", "NAME",
|
|
||||||
"STATUS", "TIMING MARK", "RCTE", "NAOL", "NAOP",
|
|
||||||
"NAOCRD", "NAOHTS", "NAOHTD", "NAOFFD", "NAOVTS",
|
|
||||||
"NAOVTD", "NAOLFD", "EXTEND ASCII", "LOGOUT", "BYTE MACRO",
|
|
||||||
"DATA ENTRY TERMINAL", "SUPDUP", "SUPDUP OUTPUT",
|
|
||||||
"SEND LOCATION", "TERMINAL TYPE", "END OF RECORD",
|
|
||||||
"TACACS UID", "OUTPUT MARKING", "TTYLOC",
|
|
||||||
"3270 REGIME", "X.3 PAD", "NAWS", "TSPEED", "LFLOW",
|
|
||||||
"LINEMODE", "XDISPLOC", "OLD-ENVIRON", "AUTHENTICATION",
|
|
||||||
"ENCRYPT", "NEW-ENVIRON",
|
|
||||||
0,
|
|
||||||
};
|
|
||||||
#define TELOPT_FIRST TELOPT_BINARY
|
|
||||||
#define TELOPT_LAST TELOPT_NEW_ENVIRON
|
|
||||||
#define TELOPT_OK(x) ((unsigned int)(x) <= TELOPT_LAST)
|
|
||||||
#define TELOPT(x) telopts[(x)-TELOPT_FIRST]
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* sub-option qualifiers */
|
|
||||||
#define TELQUAL_IS 0 /* option is... */
|
|
||||||
#define TELQUAL_SEND 1 /* send option */
|
|
||||||
#define TELQUAL_INFO 2 /* ENVIRON: informational version of IS */
|
|
||||||
#define TELQUAL_REPLY 2 /* AUTHENTICATION: client version of IS */
|
|
||||||
#define TELQUAL_NAME 3 /* AUTHENTICATION: client version of IS */
|
|
||||||
|
|
||||||
#define LFLOW_OFF 0 /* Disable remote flow control */
|
|
||||||
#define LFLOW_ON 1 /* Enable remote flow control */
|
|
||||||
#define LFLOW_RESTART_ANY 2 /* Restart output on any char */
|
|
||||||
#define LFLOW_RESTART_XON 3 /* Restart output only on XON */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* LINEMODE suboptions
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define LM_MODE 1
|
|
||||||
#define LM_FORWARDMASK 2
|
|
||||||
#define LM_SLC 3
|
|
||||||
|
|
||||||
#define MODE_EDIT 0x01
|
|
||||||
#define MODE_TRAPSIG 0x02
|
|
||||||
#define MODE_ACK 0x04
|
|
||||||
#define MODE_SOFT_TAB 0x08
|
|
||||||
#define MODE_LIT_ECHO 0x10
|
|
||||||
|
|
||||||
#define MODE_MASK 0x1f
|
|
||||||
|
|
||||||
/* Not part of protocol, but needed to simplify things... */
|
|
||||||
#define MODE_FLOW 0x0100
|
|
||||||
#define MODE_ECHO 0x0200
|
|
||||||
#define MODE_INBIN 0x0400
|
|
||||||
#define MODE_OUTBIN 0x0800
|
|
||||||
#define MODE_FORCE 0x1000
|
|
||||||
|
|
||||||
#define SLC_SYNCH 1
|
|
||||||
#define SLC_BRK 2
|
|
||||||
#define SLC_IP 3
|
|
||||||
#define SLC_AO 4
|
|
||||||
#define SLC_AYT 5
|
|
||||||
#define SLC_EOR 6
|
|
||||||
#define SLC_ABORT 7
|
|
||||||
#define SLC_EOF 8
|
|
||||||
#define SLC_SUSP 9
|
|
||||||
#define SLC_EC 10
|
|
||||||
#define SLC_EL 11
|
|
||||||
#define SLC_EW 12
|
|
||||||
#define SLC_RP 13
|
|
||||||
#define SLC_LNEXT 14
|
|
||||||
#define SLC_XON 15
|
|
||||||
#define SLC_XOFF 16
|
|
||||||
#define SLC_FORW1 17
|
|
||||||
#define SLC_FORW2 18
|
|
||||||
|
|
||||||
#define NSLC 18
|
|
||||||
|
|
||||||
/*
|
|
||||||
* For backwards compatability, we define SLC_NAMES to be the
|
|
||||||
* list of names if SLC_NAMES is not defined.
|
|
||||||
*/
|
|
||||||
#define SLC_NAMELIST "0", "SYNCH", "BRK", "IP", "AO", "AYT", "EOR", \
|
|
||||||
"ABORT", "EOF", "SUSP", "EC", "EL", "EW", "RP", \
|
|
||||||
"LNEXT", "XON", "XOFF", "FORW1", "FORW2", 0,
|
|
||||||
#ifdef SLC_NAMES
|
|
||||||
char *slc_names[] = {
|
|
||||||
SLC_NAMELIST
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *slc_names[];
|
|
||||||
#define SLC_NAMES SLC_NAMELIST
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SLC_NAME_OK(x) ((unsigned int)(x) <= NSLC)
|
|
||||||
#define SLC_NAME(x) slc_names[x]
|
|
||||||
|
|
||||||
#define SLC_NOSUPPORT 0
|
|
||||||
#define SLC_CANTCHANGE 1
|
|
||||||
#define SLC_VARIABLE 2
|
|
||||||
#define SLC_DEFAULT 3
|
|
||||||
#define SLC_LEVELBITS 0x03
|
|
||||||
|
|
||||||
#define SLC_FUNC 0
|
|
||||||
#define SLC_FLAGS 1
|
|
||||||
#define SLC_VALUE 2
|
|
||||||
|
|
||||||
#define SLC_ACK 0x80
|
|
||||||
#define SLC_FLUSHIN 0x40
|
|
||||||
#define SLC_FLUSHOUT 0x20
|
|
||||||
|
|
||||||
#define OLD_ENV_VAR 1
|
|
||||||
#define OLD_ENV_VALUE 0
|
|
||||||
#define NEW_ENV_VAR 0
|
#define NEW_ENV_VAR 0
|
||||||
#define NEW_ENV_VALUE 1
|
#define NEW_ENV_VALUE 1
|
||||||
#define ENV_ESC 2
|
|
||||||
#define ENV_USERVAR 3
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* AUTHENTICATION suboptions
|
* The telnet options represented as strings
|
||||||
*/
|
*/
|
||||||
|
static char *telnetoptions[]=
|
||||||
/*
|
{
|
||||||
* Who is authenticating who ...
|
"BINARY", "ECHO", "RCP", "SUPPRESS GO AHEAD",
|
||||||
*/
|
"NAME", "STATUS" "TIMING MARK", "RCTE",
|
||||||
#define AUTH_WHO_CLIENT 0 /* Client authenticating server */
|
"NAOL", "NAOP", "NAOCRD", "NAOHTS",
|
||||||
#define AUTH_WHO_SERVER 1 /* Server authenticating client */
|
"NAOHTD", "NAOFFD", "NAOVTS", "NAOVTD",
|
||||||
#define AUTH_WHO_MASK 1
|
"NAOLFD", "EXTEND ASCII", "LOGOUT", "BYTE MACRO",
|
||||||
|
"DE TERMINAL", "SUPDUP", "SUPDUP OUTPUT", "SEND LOCATION",
|
||||||
/*
|
"TERM TYPE", "END OF RECORD", "TACACS UID", "OUTPUT MARKING",
|
||||||
* amount of authentication done
|
"TTYLOC", "3270 REGIME", "X3 PAD", "NAWS",
|
||||||
*/
|
"TERM SPEED", "LFLOW", "LINEMODE", "XDISPLOC",
|
||||||
#define AUTH_HOW_ONE_WAY 0
|
"OLD-ENVIRON", "AUTHENTICATION", "ENCRYPT", "NEW-ENVIRON"
|
||||||
#define AUTH_HOW_MUTUAL 2
|
|
||||||
#define AUTH_HOW_MASK 2
|
|
||||||
|
|
||||||
#define AUTHTYPE_NULL 0
|
|
||||||
#define AUTHTYPE_KERBEROS_V4 1
|
|
||||||
#define AUTHTYPE_KERBEROS_V5 2
|
|
||||||
#define AUTHTYPE_SPX 3
|
|
||||||
#define AUTHTYPE_MINK 4
|
|
||||||
#define AUTHTYPE_CNT 5
|
|
||||||
|
|
||||||
#define AUTHTYPE_TEST 99
|
|
||||||
|
|
||||||
#ifdef AUTH_NAMES
|
|
||||||
char *authtype_names[] = {
|
|
||||||
"NULL", "KERBEROS_V4", "KERBEROS_V5", "SPX", "MINK", 0,
|
|
||||||
};
|
};
|
||||||
#else
|
|
||||||
extern char *authtype_names[];
|
#define TELOPT_MAXIMUM TELOPT_NEW_ENVIRON
|
||||||
|
|
||||||
|
#define TELOPT_OK(x) ((x) <= TELOPT_MAXIMUM)
|
||||||
|
#define TELOPT(x) telnetoptions[x]
|
||||||
|
|
||||||
|
#define NTELOPTS 40
|
||||||
|
|
||||||
|
/*
|
||||||
|
* First some defines
|
||||||
|
*/
|
||||||
|
#define xEOF 236 /* End Of File */
|
||||||
|
#define SE 240 /* Sub negotiation End */
|
||||||
|
#define NOP 241 /* No OPeration */
|
||||||
|
#define DM 242 /* Data Mark */
|
||||||
|
#define GA 249 /* Go Ahead, reverse the line */
|
||||||
|
#define SB 250 /* SuBnegotiation */
|
||||||
|
#define WILL 251 /* Our side WILL use this option */
|
||||||
|
#define WONT 252 /* Our side WON'T use this option */
|
||||||
|
#define DO 253 /* DO use this option! */
|
||||||
|
#define DONT 254 /* DON'T use this option! */
|
||||||
|
#define IAC 255 /* Interpret As Command */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Then those numbers represented as strings:
|
||||||
|
*/
|
||||||
|
static char *telnetcmds[]=
|
||||||
|
{
|
||||||
|
"EOF", "SUSP", "ABORT", "EOR", "SE",
|
||||||
|
"NOP", "DMARK", "BRK", "IP", "AO",
|
||||||
|
"AYT", "EC", "EL", "GA", "SB",
|
||||||
|
"WILL", "WONT", "DO", "DONT", "IAC"
|
||||||
|
};
|
||||||
|
|
||||||
|
#define TELCMD_MINIMUM xEOF /* the first one */
|
||||||
|
#define TELCMD_MAXIMUM IAC /* surprise, 255 is the last one! ;-) */
|
||||||
|
|
||||||
|
#define TELQUAL_IS 0
|
||||||
|
#define TELQUAL_SEND 1
|
||||||
|
#define TELQUAL_INFO 2
|
||||||
|
#define TELQUAL_NAME 3
|
||||||
|
|
||||||
|
#define TELCMD_OK(x) ( ((unsigned int)(x) >= TELCMD_MINIMUM) && \
|
||||||
|
((unsigned int)(x) <= TELCMD_MAXIMUM) )
|
||||||
|
#define TELCMD(x) telnetcmds[(x)-TELCMD_MINIMUM]
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define AUTHTYPE_NAME_OK(x) ((unsigned int)(x) < AUTHTYPE_CNT)
|
|
||||||
#define AUTHTYPE_NAME(x) authtype_names[x]
|
|
||||||
|
|
||||||
/*
|
|
||||||
* ENCRYPTion suboptions
|
|
||||||
*/
|
|
||||||
#define ENCRYPT_IS 0 /* I pick encryption type ... */
|
|
||||||
#define ENCRYPT_SUPPORT 1 /* I support encryption types ... */
|
|
||||||
#define ENCRYPT_REPLY 2 /* Initial setup response */
|
|
||||||
#define ENCRYPT_START 3 /* Am starting to send encrypted */
|
|
||||||
#define ENCRYPT_END 4 /* Am ending encrypted */
|
|
||||||
#define ENCRYPT_REQSTART 5 /* Request you start encrypting */
|
|
||||||
#define ENCRYPT_REQEND 6 /* Request you send encrypting */
|
|
||||||
#define ENCRYPT_ENC_KEYID 7
|
|
||||||
#define ENCRYPT_DEC_KEYID 8
|
|
||||||
#define ENCRYPT_CNT 9
|
|
||||||
|
|
||||||
#define ENCTYPE_ANY 0
|
|
||||||
#define ENCTYPE_DES_CFB64 1
|
|
||||||
#define ENCTYPE_DES_OFB64 2
|
|
||||||
#define ENCTYPE_CNT 3
|
|
||||||
|
|
||||||
#ifdef ENCRYPT_NAMES
|
|
||||||
char *encrypt_names[] = {
|
|
||||||
"IS", "SUPPORT", "REPLY", "START", "END",
|
|
||||||
"REQUEST-START", "REQUEST-END", "ENC-KEYID", "DEC-KEYID",
|
|
||||||
0,
|
|
||||||
};
|
|
||||||
char *enctype_names[] = {
|
|
||||||
"ANY", "DES_CFB64", "DES_OFB64", 0,
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
extern char *encrypt_names[];
|
|
||||||
extern char *enctype_names[];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#define ENCRYPT_NAME_OK(x) ((unsigned int)(x) < ENCRYPT_CNT)
|
|
||||||
#define ENCRYPT_NAME(x) encrypt_names[x]
|
|
||||||
|
|
||||||
#define ENCTYPE_NAME_OK(x) ((unsigned int)(x) < ENCTYPE_CNT)
|
|
||||||
#define ENCTYPE_NAME(x) enctype_names[x]
|
|
||||||
#endif /* _ARPA_TELNET_H */
|
|
||||||
|
345
lib/base64.c
345
lib/base64.c
@@ -1,34 +1,35 @@
|
|||||||
/*
|
/*****************************************************************************
|
||||||
* Copyright (c) 1995 - 1999 Kungliga Tekniska H<>gskolan
|
* _ _ ____ _
|
||||||
* (Royal Institute of Technology, Stockholm, Sweden).
|
* Project ___| | | | _ \| |
|
||||||
* All rights reserved.
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Copyright (C) 2001, Andrew Francis and Daniel Stenberg
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
*
|
*
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
* notice, this list of conditions and the following disclaimer.
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
*
|
*
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
* documentation and/or other materials provided with the distribution.
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
*
|
*
|
||||||
* 3. Neither the name of the Institute nor the names of its contributors
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
* may be used to endorse or promote products derived from this software
|
* KIND, either express or implied.
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
* $Id$
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
*****************************************************************************/
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
|
/* Base64 encoding/decoding
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
*
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
* Test harnesses down the bottom - compile with -DTEST_ENCODE for
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
* a program that will read in raw data from stdin and write out
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
* a base64-encoded version to stdout, and the length returned by the
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
* encoding function to stderr. Compile with -DTEST_DECODE for a program that
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* will go the other way.
|
||||||
* SUCH DAMAGE.
|
*
|
||||||
|
* This code will break if int is smaller than 32 bits
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
@@ -38,115 +39,221 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "base64.h"
|
#include "base64.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static char base64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
static void decodeQuantum(unsigned char *dest, char *src)
|
||||||
|
|
||||||
static int pos(char c)
|
|
||||||
{
|
{
|
||||||
char *p;
|
unsigned int x = 0;
|
||||||
for(p = base64; *p; p++)
|
|
||||||
if(*p == c)
|
|
||||||
return p - base64;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 1
|
|
||||||
int Curl_base64_encode(const void *data, int size, char **str)
|
|
||||||
{
|
|
||||||
char *s, *p;
|
|
||||||
int i;
|
int i;
|
||||||
int c;
|
for(i = 0; i < 4; i++) {
|
||||||
const unsigned char *q;
|
if(src[i] >= 'A' && src[i] <= 'Z')
|
||||||
|
x = (x << 6) + (unsigned int)(src[i] - 'A' + 0);
|
||||||
|
else if(src[i] >= 'a' && src[i] <= 'z')
|
||||||
|
x = (x << 6) + (unsigned int)(src[i] - 'a' + 26);
|
||||||
|
else if(src[i] >= '0' && src[i] <= '9')
|
||||||
|
x = (x << 6) + (unsigned int)(src[i] - '0' + 52);
|
||||||
|
else if(src[i] == '+')
|
||||||
|
x = (x << 6) + 62;
|
||||||
|
else if(src[i] == '/')
|
||||||
|
x = (x << 6) + 63;
|
||||||
|
}
|
||||||
|
|
||||||
p = s = (char*)malloc(size*4/3+4);
|
dest[2] = (unsigned char)(x & 255); x >>= 8;
|
||||||
if (p == NULL)
|
dest[1] = (unsigned char)(x & 255); x >>= 8;
|
||||||
|
dest[0] = (unsigned char)(x & 255); x >>= 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* base64Decode
|
||||||
|
* Given a base64 string at src, decode it into the memory pointed
|
||||||
|
* to by dest. If rawLength points to a valid address (ie not NULL),
|
||||||
|
* store the length of the decoded data to it.
|
||||||
|
*/
|
||||||
|
static void base64Decode(unsigned char *dest, char *src, int *rawLength)
|
||||||
|
{
|
||||||
|
int length = 0;
|
||||||
|
int equalsTerm = 0;
|
||||||
|
int i;
|
||||||
|
unsigned char lastQuantum[3];
|
||||||
|
|
||||||
|
while((src[length] != '=') && src[length])
|
||||||
|
length++;
|
||||||
|
while(src[length+equalsTerm] == '=')
|
||||||
|
equalsTerm++;
|
||||||
|
|
||||||
|
if(rawLength)
|
||||||
|
*rawLength = (length * 3 / 4) - equalsTerm;
|
||||||
|
|
||||||
|
for(i = 0; i < length/4 - 1; i++) {
|
||||||
|
decodeQuantum(dest, src);
|
||||||
|
dest += 3; src += 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
decodeQuantum(lastQuantum, src);
|
||||||
|
for(i = 0; i < 3 - equalsTerm; i++) dest[i] = lastQuantum[i];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ---- Base64 Encoding --- */
|
||||||
|
static char table64[]=
|
||||||
|
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Curl_base64_encode()
|
||||||
|
*
|
||||||
|
* Returns the length of the newly created base64 string. The third argument
|
||||||
|
* is a pointer to an allocated area holding the base64 data. If something
|
||||||
|
* went wrong, -1 is returned.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
int Curl_base64_encode(const void *inp, int insize, char **outptr)
|
||||||
|
{
|
||||||
|
unsigned char ibuf[3];
|
||||||
|
unsigned char obuf[4];
|
||||||
|
int i;
|
||||||
|
int inputparts;
|
||||||
|
char *output;
|
||||||
|
char *base64data;
|
||||||
|
|
||||||
|
char *indata = (char *)inp;
|
||||||
|
|
||||||
|
if(0 == insize)
|
||||||
|
insize = strlen(indata);
|
||||||
|
|
||||||
|
base64data = output = (char*)malloc(insize*4/3+4);
|
||||||
|
if(NULL == output)
|
||||||
return -1;
|
return -1;
|
||||||
q = (const unsigned char*)data;
|
|
||||||
i=0;
|
while(insize > 0) {
|
||||||
for(i = 0; i < size;){
|
for (i = inputparts = 0; i < 3; i++) {
|
||||||
c=q[i++];
|
if(*indata) {
|
||||||
c*=256;
|
inputparts++;
|
||||||
if(i < size)
|
ibuf[i] = *indata;
|
||||||
c+=q[i];
|
indata++;
|
||||||
i++;
|
insize--;
|
||||||
c*=256;
|
|
||||||
if(i < size)
|
|
||||||
c+=q[i];
|
|
||||||
i++;
|
|
||||||
p[0]=base64[(c&0x00fc0000) >> 18];
|
|
||||||
p[1]=base64[(c&0x0003f000) >> 12];
|
|
||||||
p[2]=base64[(c&0x00000fc0) >> 6];
|
|
||||||
p[3]=base64[(c&0x0000003f) >> 0];
|
|
||||||
if(i > size)
|
|
||||||
p[3]='=';
|
|
||||||
if(i > size+1)
|
|
||||||
p[2]='=';
|
|
||||||
p+=4;
|
|
||||||
}
|
}
|
||||||
*p=0;
|
else
|
||||||
*str = s;
|
ibuf[i] = 0;
|
||||||
return strlen(s);
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
obuf [0] = (ibuf [0] & 0xFC) >> 2;
|
||||||
|
obuf [1] = ((ibuf [0] & 0x03) << 4) | ((ibuf [1] & 0xF0) >> 4);
|
||||||
|
obuf [2] = ((ibuf [1] & 0x0F) << 2) | ((ibuf [2] & 0xC0) >> 6);
|
||||||
|
obuf [3] = ibuf [2] & 0x3F;
|
||||||
|
|
||||||
|
switch(inputparts) {
|
||||||
|
case 1: /* only one byte read */
|
||||||
|
sprintf(output, "%c%c==",
|
||||||
|
table64[obuf[0]],
|
||||||
|
table64[obuf[1]]);
|
||||||
|
break;
|
||||||
|
case 2: /* two bytes read */
|
||||||
|
sprintf(output, "%c%c%c=",
|
||||||
|
table64[obuf[0]],
|
||||||
|
table64[obuf[1]],
|
||||||
|
table64[obuf[2]]);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
sprintf(output, "%c%c%c%c",
|
||||||
|
table64[obuf[0]],
|
||||||
|
table64[obuf[1]],
|
||||||
|
table64[obuf[2]],
|
||||||
|
table64[obuf[3]] );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
output += 4;
|
||||||
|
}
|
||||||
|
*output=0;
|
||||||
|
*outptr = base64data; /* make it return the actual data memory */
|
||||||
|
|
||||||
|
return strlen(base64data); /* return the length of the new data */
|
||||||
|
}
|
||||||
|
/* ---- End of Base64 Encoding ---- */
|
||||||
|
|
||||||
int Curl_base64_decode(const char *str, void *data)
|
int Curl_base64_decode(const char *str, void *data)
|
||||||
{
|
{
|
||||||
const char *p;
|
int ret;
|
||||||
unsigned char *q;
|
|
||||||
int c;
|
|
||||||
int x;
|
|
||||||
int done = 0;
|
|
||||||
q=(unsigned char*)data;
|
|
||||||
for(p=str; *p && !done; p+=4){
|
|
||||||
x = pos(p[0]);
|
|
||||||
if(x >= 0)
|
|
||||||
c = x;
|
|
||||||
else{
|
|
||||||
done = 3;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
x = pos(p[1]);
|
base64Decode((unsigned char *)data, (char *)str, &ret);
|
||||||
if(x >= 0)
|
return ret;
|
||||||
c += x;
|
}
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
if(p[2] == '=')
|
/************* TEST HARNESS STUFF ****************/
|
||||||
done++;
|
|
||||||
else{
|
|
||||||
x = pos(p[2]);
|
|
||||||
if(x >= 0)
|
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
c*=64;
|
|
||||||
|
|
||||||
if(p[3] == '=')
|
|
||||||
done++;
|
|
||||||
else{
|
|
||||||
if(done)
|
|
||||||
return -1;
|
|
||||||
x = pos(p[3]);
|
|
||||||
if(x >= 0)
|
|
||||||
c += x;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
if(done < 3)
|
|
||||||
*q++=(c&0x00ff0000)>>16;
|
|
||||||
|
|
||||||
if(done < 2)
|
#ifdef TEST_ENCODE
|
||||||
*q++=(c&0x0000ff00)>>8;
|
/* encoding test harness. Read in standard input and write out the length
|
||||||
if(done < 1)
|
* returned by Curl_base64_encode, followed by the base64'd data itself
|
||||||
*q++=(c&0x000000ff)>>0;
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#define TEST_NEED_SUCK
|
||||||
|
void *suck(int *);
|
||||||
|
|
||||||
|
int main(int argc, char **argv, char **envp) {
|
||||||
|
char *base64;
|
||||||
|
int base64Len;
|
||||||
|
unsigned char *data;
|
||||||
|
int dataLen;
|
||||||
|
|
||||||
|
data = (unsigned char *)suck(&dataLen);
|
||||||
|
base64Len = Curl_base64_encode(data, dataLen, &base64);
|
||||||
|
|
||||||
|
fprintf(stderr, "%d\n", base64Len);
|
||||||
|
fprintf(stdout, "%s", base64);
|
||||||
|
|
||||||
|
free(base64); free(data);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
return q - (unsigned char*)data;
|
#endif
|
||||||
|
|
||||||
|
#ifdef TEST_DECODE
|
||||||
|
/* decoding test harness. Read in a base64 string from stdin and write out the
|
||||||
|
* length returned by Curl_base64_decode, followed by the decoded data itself
|
||||||
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#define TEST_NEED_SUCK
|
||||||
|
void *suck(int *);
|
||||||
|
|
||||||
|
int main(int argc, char **argv, char **envp) {
|
||||||
|
char *base64;
|
||||||
|
int base64Len;
|
||||||
|
unsigned char *data;
|
||||||
|
int dataLen;
|
||||||
|
|
||||||
|
base64 = (char *)suck(&base64Len);
|
||||||
|
data = (unsigned char *)malloc(base64Len * 3/4 + 8);
|
||||||
|
dataLen = Curl_base64_decode(base64, data);
|
||||||
|
|
||||||
|
fprintf(stderr, "%d\n", dataLen);
|
||||||
|
fwrite(data,1,dataLen,stdout);
|
||||||
|
|
||||||
|
|
||||||
|
free(base64); free(data);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef TEST_NEED_SUCK
|
||||||
|
/* this function 'sucks' in as much as possible from stdin */
|
||||||
|
void *suck(int *lenptr) {
|
||||||
|
int cursize = 8192;
|
||||||
|
unsigned char *buf = NULL;
|
||||||
|
int lastread;
|
||||||
|
int len = 0;
|
||||||
|
|
||||||
|
do {
|
||||||
|
cursize *= 2;
|
||||||
|
buf = (unsigned char *)realloc(buf, cursize);
|
||||||
|
memset(buf + len, 0, cursize - len);
|
||||||
|
lastread = fread(buf + len, 1, cursize - len, stdin);
|
||||||
|
len += lastread;
|
||||||
|
} while(!feof(stdin));
|
||||||
|
|
||||||
|
lenptr[0] = len;
|
||||||
|
return (void *)buf;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
57
lib/base64.h
57
lib/base64.h
@@ -1,40 +1,27 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 1995, 1996, 1997 Kungliga Tekniska H<>gskolan
|
|
||||||
* (Royal Institute of Technology, Stockholm, Sweden).
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
*
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* 3. Neither the name of the Institute nor the names of its contributors
|
|
||||||
* may be used to endorse or promote products derived from this software
|
|
||||||
* without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
|
|
||||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
* SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __BASE64_H
|
#ifndef __BASE64_H
|
||||||
#define __BASE64_H
|
#define __BASE64_H
|
||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2000, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* In order to be useful for every potential user, curl and libcurl are
|
||||||
|
* dual-licensed under the MPL and the MIT/X-derivate licenses.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the MPL or the MIT/X-derivate
|
||||||
|
* licenses. You may pick one of these licenses.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
* $Id$
|
||||||
|
*****************************************************************************/
|
||||||
int Curl_base64_encode(const void *data, int size, char **str);
|
int Curl_base64_encode(const void *data, int size, char **str);
|
||||||
int Curl_base64_decode(const char *str, void *data);
|
int Curl_base64_decode(const char *str, void *data);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
29
lib/cookie.c
29
lib/cookie.c
@@ -86,6 +86,7 @@ Example set of cookies:
|
|||||||
#include "cookie.h"
|
#include "cookie.h"
|
||||||
#include "getdate.h"
|
#include "getdate.h"
|
||||||
#include "strequal.h"
|
#include "strequal.h"
|
||||||
|
#include "strtok.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
@@ -199,6 +200,7 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
/* This line is NOT a HTTP header style line, we do offer support for
|
/* This line is NOT a HTTP header style line, we do offer support for
|
||||||
reading the odd netscape cookies-file format here */
|
reading the odd netscape cookies-file format here */
|
||||||
char *firstptr;
|
char *firstptr;
|
||||||
|
char *tok_buf;
|
||||||
int fields;
|
int fields;
|
||||||
|
|
||||||
if(lineptr[0]=='#') {
|
if(lineptr[0]=='#') {
|
||||||
@@ -214,7 +216,7 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
if(ptr)
|
if(ptr)
|
||||||
*ptr=0; /* clear it */
|
*ptr=0; /* clear it */
|
||||||
|
|
||||||
firstptr=strtok(lineptr, "\t"); /* first tokenize it on the TAB */
|
firstptr=strtok_r(lineptr, "\t", &tok_buf); /* first tokenize it on the TAB */
|
||||||
|
|
||||||
/* Here's a quick check to eliminate normal HTTP-headers from this */
|
/* Here's a quick check to eliminate normal HTTP-headers from this */
|
||||||
if(!firstptr || strchr(firstptr, ':')) {
|
if(!firstptr || strchr(firstptr, ':')) {
|
||||||
@@ -224,17 +226,38 @@ Curl_cookie_add(struct CookieInfo *c,
|
|||||||
|
|
||||||
/* Now loop through the fields and init the struct we already have
|
/* Now loop through the fields and init the struct we already have
|
||||||
allocated */
|
allocated */
|
||||||
for(ptr=firstptr, fields=0; ptr; ptr=strtok(NULL, "\t"), fields++) {
|
for(ptr=firstptr, fields=0; ptr; ptr=strtok_r(NULL, "\t", &tok_buf), fields++) {
|
||||||
switch(fields) {
|
switch(fields) {
|
||||||
case 0:
|
case 0:
|
||||||
co->domain = strdup(ptr);
|
co->domain = strdup(ptr);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
/* what _is_ this field for? */
|
/* This field got its explanation on the 23rd of May 2001 by
|
||||||
|
Andr<64>s Garc<72>a:
|
||||||
|
|
||||||
|
flag: A TRUE/FALSE value indicating if all machines within a given
|
||||||
|
domain can access the variable. This value is set automatically by
|
||||||
|
the browser, depending on the value you set for the domain.
|
||||||
|
|
||||||
|
As far as I can see, it is set to true when the cookie says
|
||||||
|
.domain.com and to false when the domain is complete www.domain.com
|
||||||
|
|
||||||
|
We don't currently take advantage of this knowledge.
|
||||||
|
*/
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
|
/* It turns out, that sometimes the file format allows the path
|
||||||
|
field to remain not filled in, we try to detect this and work
|
||||||
|
around it! Andr<64>s Garc<72>a made us aware of this... */
|
||||||
|
if (strcmp("TRUE", ptr) && strcmp("FALSE", ptr)) {
|
||||||
|
/* only if the path doesn't look like a boolean option! */
|
||||||
co->path = strdup(ptr);
|
co->path = strdup(ptr);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
/* this doesn't look like a path, make one up! */
|
||||||
|
co->path = strdup("/");
|
||||||
|
fields++; /* add a field and fall down to secure */
|
||||||
|
/* FALLTHROUGH */
|
||||||
case 3:
|
case 3:
|
||||||
co->secure = strequal(ptr, "TRUE");
|
co->secure = strequal(ptr, "TRUE");
|
||||||
break;
|
break;
|
||||||
|
@@ -43,7 +43,7 @@ RSC=rc.exe
|
|||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
# ADD BASE CPP /nologo /MT /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
||||||
# ADD CPP /nologo /MT /W3 /GX /O2 /I "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 CPP /nologo /MT /W3 /GX /O2 /I "..\include" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /c
|
||||||
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||||
@@ -53,7 +53,7 @@ BSC32=bscmake.exe
|
|||||||
# ADD BSC32 /nologo
|
# ADD BSC32 /nologo
|
||||||
LINK32=link.exe
|
LINK32=link.exe
|
||||||
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /machine:I386
|
||||||
# ADD LINK32 kernel32.lib 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"
|
# ADD LINK32 kernel32.lib wsock32.lib /nologo /dll /machine:I386 /out:"Release/curl.dll"
|
||||||
|
|
||||||
!ELSEIF "$(CFG)" == "curllib - Win32 Debug"
|
!ELSEIF "$(CFG)" == "curllib - Win32 Debug"
|
||||||
|
|
||||||
@@ -69,7 +69,7 @@ LINK32=link.exe
|
|||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
# ADD BASE CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
||||||
# ADD CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I "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 CPP /nologo /MTd /W3 /Gm /GX /ZI /Od /I "..\include" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "CURLLIB_EXPORTS" /YX /FD /GZ /c
|
||||||
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||||
@@ -79,7 +79,8 @@ BSC32=bscmake.exe
|
|||||||
# ADD BSC32 /nologo
|
# ADD BSC32 /nologo
|
||||||
LINK32=link.exe
|
LINK32=link.exe
|
||||||
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /dll /debug /machine:I386 /pdbtype:sept
|
||||||
# ADD LINK32 kernel32.lib 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
|
# ADD LINK32 kernel32.lib wsock32.lib /nologo /dll /debug /machine:I386 /out:"Debug/curl.dll" /pdbtype:sept
|
||||||
|
# SUBTRACT LINK32 /nodefaultlib
|
||||||
|
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
@@ -112,14 +113,6 @@ SOURCE=.\easy.c
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin 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
|
SOURCE=.\escape.c
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -160,6 +153,10 @@ SOURCE=.\http.c
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\http_chunks.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\if2ip.c
|
SOURCE=.\if2ip.c
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -212,6 +209,10 @@ SOURCE=.\strequal.c
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\strtok.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\telnet.c
|
SOURCE=.\telnet.c
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -288,6 +289,10 @@ SOURCE=.\http.h
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\http_chunks.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\if2ip.h
|
SOURCE=.\if2ip.h
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -340,6 +345,10 @@ SOURCE=.\strequal.h
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\strtok.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\telnet.h
|
SOURCE=.\telnet.h
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
97
lib/easy.c
97
lib/easy.c
@@ -73,16 +73,111 @@
|
|||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "transfer.h"
|
#include "transfer.h"
|
||||||
#include <curl/types.h>
|
#include "ssluse.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* Silly win32 socket initialization functions */
|
||||||
|
|
||||||
|
#if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__)
|
||||||
|
static void win32_cleanup(void)
|
||||||
|
{
|
||||||
|
WSACleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
static CURLcode win32_init(void)
|
||||||
|
{
|
||||||
|
WORD wVersionRequested;
|
||||||
|
WSADATA wsaData;
|
||||||
|
int err;
|
||||||
|
wVersionRequested = MAKEWORD(1, 1);
|
||||||
|
|
||||||
|
err = WSAStartup(wVersionRequested, &wsaData);
|
||||||
|
|
||||||
|
if (err != 0)
|
||||||
|
/* Tell the user that we couldn't find a useable */
|
||||||
|
/* winsock.dll. */
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
|
||||||
|
/* Confirm that the Windows Sockets DLL supports 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 CURLE_FAILED_INIT;
|
||||||
|
}
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
/* The Windows Sockets DLL is acceptable. Proceed. */
|
||||||
|
#else
|
||||||
|
static CURLcode win32_init(void) { return CURLE_OK; }
|
||||||
|
#define win32_cleanup()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* true globals -- for curl_global_init() and curl_global_cleanup() */
|
||||||
|
static unsigned int initialized = 0;
|
||||||
|
static long init_flags = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Globally initializes cURL given a bitwise set of
|
||||||
|
* the different features to initialize.
|
||||||
|
*/
|
||||||
|
CURLcode curl_global_init(long flags)
|
||||||
|
{
|
||||||
|
if (initialized)
|
||||||
|
return CURLE_OK;
|
||||||
|
|
||||||
|
if (flags & CURL_GLOBAL_SSL)
|
||||||
|
Curl_SSL_init();
|
||||||
|
|
||||||
|
if (flags & CURL_GLOBAL_WIN32)
|
||||||
|
if (win32_init() != CURLE_OK)
|
||||||
|
return CURLE_FAILED_INIT;
|
||||||
|
|
||||||
|
initialized = 1;
|
||||||
|
init_flags = flags;
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Globally cleanup cURL, uses the value of "init_flags" to determine
|
||||||
|
* what needs to be cleaned up and what doesn't
|
||||||
|
*/
|
||||||
|
void curl_global_cleanup(void)
|
||||||
|
{
|
||||||
|
if (!initialized)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (init_flags & CURL_GLOBAL_SSL)
|
||||||
|
Curl_SSL_cleanup();
|
||||||
|
|
||||||
|
if (init_flags & CURL_GLOBAL_WIN32)
|
||||||
|
win32_cleanup();
|
||||||
|
|
||||||
|
initialized = 0;
|
||||||
|
init_flags = 0;
|
||||||
|
}
|
||||||
|
|
||||||
CURL *curl_easy_init(void)
|
CURL *curl_easy_init(void)
|
||||||
{
|
{
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
struct UrlData *data;
|
struct UrlData *data;
|
||||||
|
|
||||||
|
/* Make sure we inited the global SSL stuff */
|
||||||
|
if (!initialized)
|
||||||
|
curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
|
|
||||||
/* We use curl_open() with undefined URL so far */
|
/* We use curl_open() with undefined URL so far */
|
||||||
res = Curl_open((CURL **)&data, NULL);
|
res = Curl_open((CURL **)&data, NULL);
|
||||||
if(res != CURLE_OK)
|
if(res != CURLE_OK)
|
||||||
|
@@ -25,6 +25,7 @@
|
|||||||
* allocated string or NULL if an error occurred. */
|
* allocated string or NULL if an error occurred. */
|
||||||
|
|
||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
|
#include <ctype.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@@ -44,6 +45,7 @@ char *curl_escape(char *string, int length)
|
|||||||
int newlen = alloc;
|
int newlen = alloc;
|
||||||
int index=0;
|
int index=0;
|
||||||
|
|
||||||
|
length = alloc-1;
|
||||||
while(length--) {
|
while(length--) {
|
||||||
in = *string;
|
in = *string;
|
||||||
if(' ' == in)
|
if(' ' == in)
|
||||||
@@ -60,6 +62,7 @@ char *curl_escape(char *string, int length)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
sprintf(&ns[index], "%%%02X", in);
|
sprintf(&ns[index], "%%%02X", in);
|
||||||
|
|
||||||
index+=3;
|
index+=3;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@@ -183,11 +183,11 @@ CURLcode Curl_file(struct connectdata *conn)
|
|||||||
return res;
|
return res;
|
||||||
|
|
||||||
now = Curl_tvnow();
|
now = Curl_tvnow();
|
||||||
if(Curl_pgrsUpdate(data))
|
if(Curl_pgrsUpdate(conn))
|
||||||
res = CURLE_ABORTED_BY_CALLBACK;
|
res = CURLE_ABORTED_BY_CALLBACK;
|
||||||
}
|
}
|
||||||
now = Curl_tvnow();
|
now = Curl_tvnow();
|
||||||
if(Curl_pgrsUpdate(data))
|
if(Curl_pgrsUpdate(conn))
|
||||||
res = CURLE_ABORTED_BY_CALLBACK;
|
res = CURLE_ABORTED_BY_CALLBACK;
|
||||||
|
|
||||||
close(fd);
|
close(fd);
|
||||||
|
@@ -371,6 +371,7 @@ char *Curl_FormBoundary(void)
|
|||||||
void Curl_FormFree(struct FormData *form)
|
void Curl_FormFree(struct FormData *form)
|
||||||
{
|
{
|
||||||
struct FormData *next;
|
struct FormData *next;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
next=form->next; /* the following form line */
|
next=form->next; /* the following form line */
|
||||||
free(form->line); /* free the line */
|
free(form->line); /* free the line */
|
||||||
@@ -383,6 +384,11 @@ void Curl_FormFree(struct FormData *form)
|
|||||||
void curl_formfree(struct HttpPost *form)
|
void curl_formfree(struct HttpPost *form)
|
||||||
{
|
{
|
||||||
struct HttpPost *next;
|
struct HttpPost *next;
|
||||||
|
|
||||||
|
if(!form)
|
||||||
|
/* no form to free, just get out of this */
|
||||||
|
return;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
next=form->next; /* the following form line */
|
next=form->next; /* the following form line */
|
||||||
|
|
||||||
@@ -628,11 +634,16 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
form=Curl_getFormData(httppost, &size);
|
form=Curl_getFormData(httppost, &size);
|
||||||
|
|
||||||
FormInit(&formread, form);
|
Curl_FormInit(&formread, form);
|
||||||
|
|
||||||
while(nread = FormReader(buffer, 1, sizeof(buffer), (FILE *)&formread)) {
|
do {
|
||||||
|
nread = Curl_FormReader(buffer, 1, sizeof(buffer),
|
||||||
|
(FILE *)&formread);
|
||||||
|
|
||||||
|
if(-1 == nread)
|
||||||
|
break;
|
||||||
fwrite(buffer, nread, 1, stderr);
|
fwrite(buffer, nread, 1, stderr);
|
||||||
}
|
} while(1);
|
||||||
|
|
||||||
fprintf(stderr, "size: %d\n", size);
|
fprintf(stderr, "size: %d\n", size);
|
||||||
|
|
||||||
|
307
lib/ftp.c
307
lib/ftp.c
@@ -78,6 +78,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "strequal.h"
|
#include "strequal.h"
|
||||||
|
#include "ssluse.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
@@ -146,6 +147,165 @@ static CURLcode AllowServerConnect(struct UrlData *data,
|
|||||||
#define lastline(line) (isdigit((int)line[0]) && isdigit((int)line[1]) && \
|
#define lastline(line) (isdigit((int)line[0]) && isdigit((int)line[1]) && \
|
||||||
isdigit((int)line[2]) && (' ' == line[3]))
|
isdigit((int)line[2]) && (' ' == line[3]))
|
||||||
|
|
||||||
|
|
||||||
|
int Curl_GetFTPResponse(int sockfd,
|
||||||
|
char *buf,
|
||||||
|
struct connectdata *conn,
|
||||||
|
int *ftpcode)
|
||||||
|
{
|
||||||
|
/* Brand new implementation.
|
||||||
|
* We cannot read just one byte per read() and then go back to select()
|
||||||
|
* as it seems that the OpenSSL read() stuff doesn't grok that properly.
|
||||||
|
*
|
||||||
|
* Alas, read as much as possible, split up into lines, use the ending
|
||||||
|
* line in a response or continue reading.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int nread; /* total size read */
|
||||||
|
int perline; /* count bytes per line */
|
||||||
|
bool keepon=TRUE;
|
||||||
|
ssize_t gotbytes;
|
||||||
|
char *ptr;
|
||||||
|
int timeout = 3600; /* default timeout in seconds */
|
||||||
|
struct timeval interval;
|
||||||
|
fd_set rkeepfd;
|
||||||
|
fd_set readfd;
|
||||||
|
struct UrlData *data = conn->data;
|
||||||
|
char *line_start;
|
||||||
|
int code=0; /* default "error code" to return */
|
||||||
|
|
||||||
|
#define SELECT_OK 0
|
||||||
|
#define SELECT_ERROR 1
|
||||||
|
#define SELECT_TIMEOUT 2
|
||||||
|
int error = SELECT_OK;
|
||||||
|
|
||||||
|
if(ftpcode)
|
||||||
|
*ftpcode=0; /* 0 for errors */
|
||||||
|
|
||||||
|
if(data->timeout) {
|
||||||
|
/* if timeout is requested, find out how much remaining time we have */
|
||||||
|
timeout = data->timeout - /* timeout time */
|
||||||
|
(Curl_tvlong(Curl_tvnow()) - Curl_tvlong(conn->now)); /* spent time */
|
||||||
|
if(timeout <=0 ) {
|
||||||
|
failf(data, "Transfer aborted due to timeout");
|
||||||
|
return -SELECT_TIMEOUT; /* already too little time */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
FD_ZERO (&readfd); /* clear it */
|
||||||
|
FD_SET (sockfd, &readfd); /* read socket */
|
||||||
|
|
||||||
|
/* get this in a backup variable to be able to restore it on each lap in the
|
||||||
|
select() loop */
|
||||||
|
rkeepfd = readfd;
|
||||||
|
|
||||||
|
ptr=buf;
|
||||||
|
line_start = buf;
|
||||||
|
|
||||||
|
nread=0;
|
||||||
|
perline=0;
|
||||||
|
keepon=TRUE;
|
||||||
|
|
||||||
|
while((nread<BUFSIZE) && (keepon && !error)) {
|
||||||
|
readfd = rkeepfd; /* set every lap */
|
||||||
|
interval.tv_sec = timeout;
|
||||||
|
interval.tv_usec = 0;
|
||||||
|
|
||||||
|
switch (select (sockfd+1, &readfd, NULL, NULL, &interval)) {
|
||||||
|
case -1: /* select() error, stop reading */
|
||||||
|
error = SELECT_ERROR;
|
||||||
|
failf(data, "Transfer aborted due to select() error");
|
||||||
|
break;
|
||||||
|
case 0: /* timeout */
|
||||||
|
error = SELECT_TIMEOUT;
|
||||||
|
failf(data, "Transfer aborted due to timeout");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/*
|
||||||
|
* This code previously didn't use the kerberos sec_read() code
|
||||||
|
* to read, but when we use Curl_read() it may do so. Do confirm
|
||||||
|
* that this is still ok and then remove this comment!
|
||||||
|
*/
|
||||||
|
if(CURLE_OK != Curl_read(conn, sockfd, ptr, BUFSIZE-nread, &gotbytes))
|
||||||
|
keepon = FALSE;
|
||||||
|
else if(gotbytes <= 0) {
|
||||||
|
keepon = FALSE;
|
||||||
|
error = SELECT_ERROR;
|
||||||
|
failf(data, "Connection aborted");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* we got a whole chunk of data, which can be anything from one
|
||||||
|
* byte to a set of lines and possible just a piece of the last
|
||||||
|
* line */
|
||||||
|
int i;
|
||||||
|
|
||||||
|
nread += gotbytes;
|
||||||
|
for(i=0; i< gotbytes; ptr++, i++) {
|
||||||
|
perline++;
|
||||||
|
if(*ptr=='\n') {
|
||||||
|
/* a newline is CRLF in ftp-talk, so the CR is ignored as
|
||||||
|
the line isn't really terminated until the LF comes */
|
||||||
|
|
||||||
|
/* output debug output if that is requested */
|
||||||
|
if(data->bits.verbose) {
|
||||||
|
fputs("< ", data->err);
|
||||||
|
fwrite(line_start, 1, perline, data->err);
|
||||||
|
/* no need to output LF here, it is part of the data */
|
||||||
|
}
|
||||||
|
|
||||||
|
if(perline>3 && lastline(line_start)) {
|
||||||
|
/* This is the end of the last line, copy the last
|
||||||
|
* line to the start of the buffer and zero terminate,
|
||||||
|
* for old times sake (and krb4)! */
|
||||||
|
char *moo;
|
||||||
|
int i;
|
||||||
|
for(moo=line_start, i=0; moo<ptr; moo++, i++)
|
||||||
|
buf[i] = *moo;
|
||||||
|
moo[i]=0; /* zero terminate */
|
||||||
|
keepon=FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
perline=0; /* line starts over here */
|
||||||
|
line_start = ptr+1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
} /* switch */
|
||||||
|
} /* while there's buffer left and loop is requested */
|
||||||
|
|
||||||
|
if(!error)
|
||||||
|
code = atoi(buf);
|
||||||
|
|
||||||
|
#if KRB4
|
||||||
|
/* handle the security-oriented responses 6xx ***/
|
||||||
|
/* FIXME: some errorchecking perhaps... ***/
|
||||||
|
switch(code) {
|
||||||
|
case 631:
|
||||||
|
sec_read_msg(conn, buf, prot_safe);
|
||||||
|
break;
|
||||||
|
case 632:
|
||||||
|
sec_read_msg(conn, buf, prot_private);
|
||||||
|
break;
|
||||||
|
case 633:
|
||||||
|
sec_read_msg(conn, buf, prot_confidential);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* normal ftp stuff we pass through! */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if(error)
|
||||||
|
return -error;
|
||||||
|
|
||||||
|
if(ftpcode)
|
||||||
|
*ftpcode=code; /* return the initial number like this */
|
||||||
|
|
||||||
|
return nread; /* total amount of bytes read */
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
/*
|
/*
|
||||||
* We allow the ftpcode pointer to be NULL if no reply integer is wanted
|
* We allow the ftpcode pointer to be NULL if no reply integer is wanted
|
||||||
*/
|
*/
|
||||||
@@ -156,6 +316,7 @@ int Curl_GetFTPResponse(int sockfd, char *buf,
|
|||||||
{
|
{
|
||||||
int nread;
|
int nread;
|
||||||
ssize_t keepon=TRUE;
|
ssize_t keepon=TRUE;
|
||||||
|
size_t got;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
int timeout = 3600; /* in seconds */
|
int timeout = 3600; /* in seconds */
|
||||||
struct timeval interval;
|
struct timeval interval;
|
||||||
@@ -259,6 +420,7 @@ int Curl_GetFTPResponse(int sockfd, char *buf,
|
|||||||
|
|
||||||
return nread;
|
return nread;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* -- who are we? -- */
|
/* -- who are we? -- */
|
||||||
char *Curl_getmyhost(char *buf, int buf_size)
|
char *Curl_getmyhost(char *buf, int buf_size)
|
||||||
@@ -316,6 +478,15 @@ CURLcode Curl_ftp_connect(struct connectdata *conn)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(conn->protocol & PROT_FTPS) {
|
||||||
|
/* FTPS is simply ftp with SSL for the control channel */
|
||||||
|
/* now, perform the SSL initialization for this socket */
|
||||||
|
result = Curl_SSLConnect(conn);
|
||||||
|
if(result)
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* The first thing we do is wait for the "220*" line: */
|
/* The first thing we do is wait for the "220*" line: */
|
||||||
nread = Curl_GetFTPResponse(conn->firstsocket, buf, conn, &ftpcode);
|
nread = Curl_GetFTPResponse(conn->firstsocket, buf, conn, &ftpcode);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
@@ -337,8 +508,6 @@ CURLcode Curl_ftp_connect(struct connectdata *conn)
|
|||||||
set a valid level */
|
set a valid level */
|
||||||
sec_request_prot(conn, data->krb4_level);
|
sec_request_prot(conn, data->krb4_level);
|
||||||
|
|
||||||
data->cmdchannel = fdopen(conn->firstsocket, "w");
|
|
||||||
|
|
||||||
if(sec_login(conn) != 0)
|
if(sec_login(conn) != 0)
|
||||||
infof(data, "Logging in with password in cleartext!\n");
|
infof(data, "Logging in with password in cleartext!\n");
|
||||||
else
|
else
|
||||||
@@ -487,11 +656,14 @@ CURLcode Curl_ftp_done(struct connectdata *conn)
|
|||||||
failf(data, "Received only partial file");
|
failf(data, "Received only partial file");
|
||||||
return CURLE_PARTIAL_FILE;
|
return CURLE_PARTIAL_FILE;
|
||||||
}
|
}
|
||||||
else if(!data->bits.no_body && (0 == *ftp->bytecountp)) {
|
else if(!conn->bits.resume_done &&
|
||||||
|
!data->bits.no_body &&
|
||||||
|
(0 == *ftp->bytecountp)) {
|
||||||
failf(data, "No data was received!");
|
failf(data, "No data was received!");
|
||||||
return CURLE_FTP_COULDNT_RETR_FILE;
|
return CURLE_FTP_COULDNT_RETR_FILE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef KRB4
|
#ifdef KRB4
|
||||||
sec_fflush_fd(conn, conn->secondarysocket);
|
sec_fflush_fd(conn, conn->secondarysocket);
|
||||||
#endif
|
#endif
|
||||||
@@ -499,7 +671,7 @@ CURLcode Curl_ftp_done(struct connectdata *conn)
|
|||||||
sclose(conn->secondarysocket);
|
sclose(conn->secondarysocket);
|
||||||
conn->secondarysocket = -1;
|
conn->secondarysocket = -1;
|
||||||
|
|
||||||
if(!data->bits.no_body) {
|
if(!data->bits.no_body && !conn->bits.resume_done) {
|
||||||
/* now let's see what the server says about the transfer we
|
/* now let's see what the server says about the transfer we
|
||||||
just performed: */
|
just performed: */
|
||||||
nread = Curl_GetFTPResponse(conn->firstsocket, buf, conn, &ftpcode);
|
nread = Curl_GetFTPResponse(conn->firstsocket, buf, conn, &ftpcode);
|
||||||
@@ -508,11 +680,13 @@ CURLcode Curl_ftp_done(struct connectdata *conn)
|
|||||||
|
|
||||||
/* 226 Transfer complete, 250 Requested file action okay, completed. */
|
/* 226 Transfer complete, 250 Requested file action okay, completed. */
|
||||||
if((ftpcode != 226) && (ftpcode != 250)) {
|
if((ftpcode != 226) && (ftpcode != 250)) {
|
||||||
failf(data, "%s", buf+4);
|
failf(data, "server did not report OK, got %d", ftpcode);
|
||||||
return CURLE_FTP_WRITE_ERROR;
|
return CURLE_FTP_WRITE_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
conn->bits.resume_done = FALSE; /* clean this for next connection */
|
||||||
|
|
||||||
/* Send any post-transfer QUOTE strings? */
|
/* Send any post-transfer QUOTE strings? */
|
||||||
if(data->postquote) {
|
if(data->postquote) {
|
||||||
qitem = data->postquote;
|
qitem = data->postquote;
|
||||||
@@ -680,10 +854,8 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
return CURLE_OPERATION_TIMEOUTED;
|
return CURLE_OPERATION_TIMEOUTED;
|
||||||
|
|
||||||
if(ftpcode != 213) {
|
if(ftpcode == 213) {
|
||||||
failf(data, "Couldn't get file size: %s", buf+4);
|
|
||||||
return CURLE_FTP_COULDNT_GET_SIZE;
|
|
||||||
}
|
|
||||||
/* get the size from the ascii string: */
|
/* get the size from the ascii string: */
|
||||||
filesize = atoi(buf+4);
|
filesize = atoi(buf+4);
|
||||||
|
|
||||||
@@ -709,6 +881,7 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
@@ -727,8 +900,8 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
#else
|
#else
|
||||||
const int niflags = NI_NUMERICHOST | NI_NUMERICSERV;
|
const int niflags = NI_NUMERICHOST | NI_NUMERICSERV;
|
||||||
#endif
|
#endif
|
||||||
char *ap;
|
unsigned char *ap;
|
||||||
char *pp;
|
unsigned char *pp;
|
||||||
int alen, plen;
|
int alen, plen;
|
||||||
char portmsgbuf[4096], tmp[4096];
|
char portmsgbuf[4096], tmp[4096];
|
||||||
|
|
||||||
@@ -795,17 +968,17 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
|
|
||||||
switch (sa->sa_family) {
|
switch (sa->sa_family) {
|
||||||
case AF_INET:
|
case AF_INET:
|
||||||
ap = (char *)&((struct sockaddr_in *)&ss)->sin_addr;
|
ap = (unsigned char *)&((struct sockaddr_in *)&ss)->sin_addr;
|
||||||
alen = sizeof(((struct sockaddr_in *)&ss)->sin_addr);
|
alen = sizeof(((struct sockaddr_in *)&ss)->sin_addr);
|
||||||
pp = (char *)&((struct sockaddr_in *)&ss)->sin_port;
|
pp = (unsigned char *)&((struct sockaddr_in *)&ss)->sin_port;
|
||||||
plen = sizeof(((struct sockaddr_in *)&ss)->sin_port);
|
plen = sizeof(((struct sockaddr_in *)&ss)->sin_port);
|
||||||
lprtaf = 4;
|
lprtaf = 4;
|
||||||
eprtaf = 1;
|
eprtaf = 1;
|
||||||
break;
|
break;
|
||||||
case AF_INET6:
|
case AF_INET6:
|
||||||
ap = (char *)&((struct sockaddr_in6 *)&ss)->sin6_addr;
|
ap = (unsigned char *)&((struct sockaddr_in6 *)&ss)->sin6_addr;
|
||||||
alen = sizeof(((struct sockaddr_in6 *)&ss)->sin6_addr);
|
alen = sizeof(((struct sockaddr_in6 *)&ss)->sin6_addr);
|
||||||
pp = (char *)&((struct sockaddr_in6 *)&ss)->sin6_port;
|
pp = (unsigned char *)&((struct sockaddr_in6 *)&ss)->sin6_port;
|
||||||
plen = sizeof(((struct sockaddr_in6 *)&ss)->sin6_port);
|
plen = sizeof(((struct sockaddr_in6 *)&ss)->sin6_port);
|
||||||
lprtaf = 6;
|
lprtaf = 6;
|
||||||
eprtaf = 2;
|
eprtaf = 2;
|
||||||
@@ -830,7 +1003,8 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
ftpsendf(conn->firstsocket, conn, "%s |%d|%s|%s|", *modep, eprtaf,
|
ftpsendf(conn->firstsocket, conn, "%s |%d|%s|%s|", *modep, eprtaf,
|
||||||
portmsgbuf, tmp);
|
portmsgbuf, tmp);
|
||||||
} else if (strcmp(*modep, "LPRT") == 0 || strcmp(*modep, "PORT") == 0) {
|
} else if (strcmp(*modep, "LPRT") == 0 ||
|
||||||
|
strcmp(*modep, "PORT") == 0) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (strcmp(*modep, "LPRT") == 0 && lprtaf < 0)
|
if (strcmp(*modep, "LPRT") == 0 && lprtaf < 0)
|
||||||
@@ -842,7 +1016,7 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
if (strcmp(*modep, "LPRT") == 0) {
|
if (strcmp(*modep, "LPRT") == 0) {
|
||||||
snprintf(tmp, sizeof(tmp), "%d,%d", lprtaf, alen);
|
snprintf(tmp, sizeof(tmp), "%d,%d", lprtaf, alen);
|
||||||
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf)) {
|
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf)) {
|
||||||
goto again;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (i = 0; i < alen; i++) {
|
for (i = 0; i < alen; i++) {
|
||||||
@@ -851,18 +1025,18 @@ CURLcode _ftp(struct connectdata *conn)
|
|||||||
else
|
else
|
||||||
snprintf(tmp, sizeof(tmp), "%u", ap[i]);
|
snprintf(tmp, sizeof(tmp), "%u", ap[i]);
|
||||||
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf)) {
|
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf)) {
|
||||||
goto again;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (strcmp(*modep, "LPRT") == 0) {
|
if (strcmp(*modep, "LPRT") == 0) {
|
||||||
snprintf(tmp, sizeof(tmp), ",%d", plen);
|
snprintf(tmp, sizeof(tmp), ",%d", plen);
|
||||||
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf))
|
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf))
|
||||||
goto again;
|
continue;
|
||||||
}
|
}
|
||||||
for (i = 0; i < plen; i++) {
|
for (i = 0; i < plen; i++) {
|
||||||
snprintf(tmp, sizeof(tmp), ",%u", pp[i]);
|
snprintf(tmp, sizeof(tmp), ",%u", pp[i]);
|
||||||
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf)) {
|
if (strlcat(portmsgbuf, tmp, sizeof(portmsgbuf)) >= sizeof(portmsgbuf)) {
|
||||||
goto again;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ftpsendf(conn->firstsocket, conn, "%s %s", *modep, portmsgbuf);
|
ftpsendf(conn->firstsocket, conn, "%s %s", *modep, portmsgbuf);
|
||||||
@@ -998,6 +1172,7 @@ again:;
|
|||||||
}
|
}
|
||||||
else { /* we use the PASV command */
|
else { /* we use the PASV command */
|
||||||
#if 0
|
#if 0
|
||||||
|
/* no support for IPv6 passive mode yet */
|
||||||
char *mode[] = { "EPSV", "LPSV", "PASV", NULL };
|
char *mode[] = { "EPSV", "LPSV", "PASV", NULL };
|
||||||
int results[] = { 229, 228, 227, 0 };
|
int results[] = { 229, 228, 227, 0 };
|
||||||
#else
|
#else
|
||||||
@@ -1265,7 +1440,7 @@ again:;
|
|||||||
CURLE_FTP_COULDNT_SET_BINARY;
|
CURLE_FTP_COULDNT_SET_BINARY;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->resume_from) {
|
if(conn->resume_from) {
|
||||||
/* we're about to continue the uploading of a file */
|
/* we're about to continue the uploading of a file */
|
||||||
/* 1. get already existing file's size. We use the SIZE
|
/* 1. get already existing file's size. We use the SIZE
|
||||||
command for this which may not exist in the server!
|
command for this which may not exist in the server!
|
||||||
@@ -1279,7 +1454,7 @@ again:;
|
|||||||
/* 4. lower the infilesize counter */
|
/* 4. lower the infilesize counter */
|
||||||
/* => transfer as usual */
|
/* => transfer as usual */
|
||||||
|
|
||||||
if(data->resume_from < 0 ) {
|
if(conn->resume_from < 0 ) {
|
||||||
/* we could've got a specified offset from the command line,
|
/* we could've got a specified offset from the command line,
|
||||||
but now we know we didn't */
|
but now we know we didn't */
|
||||||
|
|
||||||
@@ -1295,10 +1470,10 @@ again:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* get the size from the ascii string: */
|
/* get the size from the ascii string: */
|
||||||
data->resume_from = atoi(buf+4);
|
conn->resume_from = atoi(buf+4);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->resume_from) {
|
if(conn->resume_from) {
|
||||||
/* do we still game? */
|
/* do we still game? */
|
||||||
int passed=0;
|
int passed=0;
|
||||||
/* enable append instead */
|
/* enable append instead */
|
||||||
@@ -1308,7 +1483,7 @@ again:;
|
|||||||
input. If we knew it was a proper file we could've just
|
input. If we knew it was a proper file we could've just
|
||||||
fseek()ed but we only have a stream here */
|
fseek()ed but we only have a stream here */
|
||||||
do {
|
do {
|
||||||
int readthisamountnow = (data->resume_from - passed);
|
int readthisamountnow = (conn->resume_from - passed);
|
||||||
int actuallyread;
|
int actuallyread;
|
||||||
|
|
||||||
if(readthisamountnow > BUFSIZE)
|
if(readthisamountnow > BUFSIZE)
|
||||||
@@ -1324,15 +1499,24 @@ again:;
|
|||||||
return CURLE_FTP_COULDNT_USE_REST;
|
return CURLE_FTP_COULDNT_USE_REST;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while(passed != data->resume_from);
|
while(passed != conn->resume_from);
|
||||||
|
|
||||||
/* now, decrease the size of the read */
|
/* now, decrease the size of the read */
|
||||||
if(data->infilesize>0) {
|
if(data->infilesize>0) {
|
||||||
data->infilesize -= data->resume_from;
|
data->infilesize -= conn->resume_from;
|
||||||
|
|
||||||
if(data->infilesize <= 0) {
|
if(data->infilesize <= 0) {
|
||||||
failf(data, "File already completely uploaded\n");
|
infof(data, "File already completely uploaded\n");
|
||||||
return CURLE_FTP_COULDNT_STOR_FILE;
|
|
||||||
|
/* no data to transfer */
|
||||||
|
result=Curl_Transfer(conn, -1, -1, FALSE, NULL, -1, NULL);
|
||||||
|
|
||||||
|
/* Set resume done so that we won't get any error in
|
||||||
|
* Curl_ftp_done() because we didn't transfer the amount of bytes
|
||||||
|
* that the local file file obviously is */
|
||||||
|
conn->bits.resume_done = TRUE;
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* we've passed, proceed as normal */
|
/* we've passed, proceed as normal */
|
||||||
@@ -1380,13 +1564,13 @@ again:;
|
|||||||
bool dirlist=FALSE;
|
bool dirlist=FALSE;
|
||||||
long downloadsize=-1;
|
long downloadsize=-1;
|
||||||
|
|
||||||
if(data->bits.set_range && data->range) {
|
if(conn->bits.use_range && conn->range) {
|
||||||
long from, to;
|
long from, to;
|
||||||
int totalsize=-1;
|
int totalsize=-1;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
char *ptr2;
|
char *ptr2;
|
||||||
|
|
||||||
from=strtol(data->range, &ptr, 0);
|
from=strtol(conn->range, &ptr, 0);
|
||||||
while(ptr && *ptr && (isspace((int)*ptr) || (*ptr=='-')))
|
while(ptr && *ptr && (isspace((int)*ptr) || (*ptr=='-')))
|
||||||
ptr++;
|
ptr++;
|
||||||
to=strtol(ptr, &ptr2, 0);
|
to=strtol(ptr, &ptr2, 0);
|
||||||
@@ -1396,22 +1580,23 @@ again:;
|
|||||||
}
|
}
|
||||||
if((-1 == to) && (from>=0)) {
|
if((-1 == to) && (from>=0)) {
|
||||||
/* X - */
|
/* X - */
|
||||||
data->resume_from = from;
|
conn->resume_from = from;
|
||||||
infof(data, "FTP RANGE %d to end of file\n", from);
|
infof(data, "FTP RANGE %d to end of file\n", from);
|
||||||
}
|
}
|
||||||
else if(from < 0) {
|
else if(from < 0) {
|
||||||
/* -Y */
|
/* -Y */
|
||||||
totalsize = -from;
|
totalsize = -from;
|
||||||
conn->maxdownload = -from;
|
conn->maxdownload = -from;
|
||||||
data->resume_from = from;
|
conn->resume_from = from;
|
||||||
infof(data, "FTP RANGE the last %d bytes\n", totalsize);
|
infof(data, "FTP RANGE the last %d bytes\n", totalsize);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* X-Y */
|
/* X-Y */
|
||||||
totalsize = to-from;
|
totalsize = to-from;
|
||||||
conn->maxdownload = totalsize+1; /* include the last mentioned byte */
|
conn->maxdownload = totalsize+1; /* include the last mentioned byte */
|
||||||
data->resume_from = from;
|
conn->resume_from = from;
|
||||||
infof(data, "FTP RANGE from %d getting %d bytes\n", from, conn->maxdownload);
|
infof(data, "FTP RANGE from %d getting %d bytes\n", from,
|
||||||
|
conn->maxdownload);
|
||||||
}
|
}
|
||||||
infof(data, "range-download from %d to %d, totally %d bytes\n",
|
infof(data, "range-download from %d to %d, totally %d bytes\n",
|
||||||
from, to, totalsize);
|
from, to, totalsize);
|
||||||
@@ -1459,7 +1644,7 @@ again:;
|
|||||||
CURLE_FTP_COULDNT_SET_BINARY;
|
CURLE_FTP_COULDNT_SET_BINARY;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->resume_from) {
|
if(conn->resume_from) {
|
||||||
|
|
||||||
/* Daniel: (August 4, 1999)
|
/* Daniel: (August 4, 1999)
|
||||||
*
|
*
|
||||||
@@ -1484,34 +1669,47 @@ again:;
|
|||||||
int foundsize=atoi(buf+4);
|
int foundsize=atoi(buf+4);
|
||||||
/* We got a file size report, so we check that there actually is a
|
/* We got a file size report, so we check that there actually is a
|
||||||
part of the file left to get, or else we go home. */
|
part of the file left to get, or else we go home. */
|
||||||
if(data->resume_from< 0) {
|
if(conn->resume_from< 0) {
|
||||||
/* We're supposed to download the last abs(from) bytes */
|
/* We're supposed to download the last abs(from) bytes */
|
||||||
if(foundsize < -data->resume_from) {
|
if(foundsize < -conn->resume_from) {
|
||||||
failf(data, "Offset (%d) was beyond file size (%d)",
|
failf(data, "Offset (%d) was beyond file size (%d)",
|
||||||
data->resume_from, foundsize);
|
conn->resume_from, foundsize);
|
||||||
return CURLE_FTP_BAD_DOWNLOAD_RESUME;
|
return CURLE_FTP_BAD_DOWNLOAD_RESUME;
|
||||||
}
|
}
|
||||||
/* convert to size to download */
|
/* convert to size to download */
|
||||||
downloadsize = -data->resume_from;
|
downloadsize = -conn->resume_from;
|
||||||
/* download from where? */
|
/* download from where? */
|
||||||
data->resume_from = foundsize - downloadsize;
|
conn->resume_from = foundsize - downloadsize;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(foundsize <= data->resume_from) {
|
if(foundsize < conn->resume_from) {
|
||||||
failf(data, "Offset (%d) was beyond file size (%d)",
|
failf(data, "Offset (%d) was beyond file size (%d)",
|
||||||
data->resume_from, foundsize);
|
conn->resume_from, foundsize);
|
||||||
return CURLE_FTP_BAD_DOWNLOAD_RESUME;
|
return CURLE_FTP_BAD_DOWNLOAD_RESUME;
|
||||||
}
|
}
|
||||||
/* Now store the number of bytes we are expected to download */
|
/* Now store the number of bytes we are expected to download */
|
||||||
downloadsize = foundsize-data->resume_from;
|
downloadsize = foundsize-conn->resume_from;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (downloadsize == 0) {
|
||||||
|
/* no data to transfer */
|
||||||
|
result=Curl_Transfer(conn, -1, -1, FALSE, NULL, -1, NULL);
|
||||||
|
infof(data, "File already completely downloaded\n");
|
||||||
|
|
||||||
|
/* Set resume done so that we won't get any error in Curl_ftp_done()
|
||||||
|
* because we didn't transfer the amount of bytes that the remote
|
||||||
|
* file obviously is */
|
||||||
|
conn->bits.resume_done = TRUE;
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/* Set resume file transfer offset */
|
/* Set resume file transfer offset */
|
||||||
infof(data, "Instructs server to resume from offset %d\n",
|
infof(data, "Instructs server to resume from offset %d\n",
|
||||||
data->resume_from);
|
conn->resume_from);
|
||||||
|
|
||||||
ftpsendf(conn->firstsocket, conn, "REST %d", data->resume_from);
|
ftpsendf(conn->firstsocket, conn, "REST %d", conn->resume_from);
|
||||||
|
|
||||||
nread = Curl_GetFTPResponse(conn->firstsocket, buf, conn, &ftpcode);
|
nread = Curl_GetFTPResponse(conn->firstsocket, buf, conn, &ftpcode);
|
||||||
if(nread < 0)
|
if(nread < 0)
|
||||||
@@ -1702,16 +1900,9 @@ size_t Curl_ftpsendf(int fd, struct connectdata *conn, char *fmt, ...)
|
|||||||
|
|
||||||
strcat(s, "\r\n"); /* append a trailing CRLF */
|
strcat(s, "\r\n"); /* append a trailing CRLF */
|
||||||
|
|
||||||
#ifdef KRB4
|
bytes_written=0;
|
||||||
if(conn->sec_complete && conn->data->cmdchannel) {
|
Curl_write(conn, fd, s, strlen(s), &bytes_written);
|
||||||
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);
|
return(bytes_written);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1720,12 +1911,14 @@ CURLcode Curl_ftp_disconnect(struct connectdata *conn)
|
|||||||
{
|
{
|
||||||
struct FTP *ftp= conn->proto.ftp;
|
struct FTP *ftp= conn->proto.ftp;
|
||||||
|
|
||||||
|
/* The FTP session may or may not have been allocated/setup at this point! */
|
||||||
|
if(ftp) {
|
||||||
if(ftp->user)
|
if(ftp->user)
|
||||||
free(ftp->user);
|
free(ftp->user);
|
||||||
if(ftp->passwd)
|
if(ftp->passwd)
|
||||||
free(ftp->passwd);
|
free(ftp->passwd);
|
||||||
if(ftp->entrypath)
|
if(ftp->entrypath)
|
||||||
free(ftp->entrypath);
|
free(ftp->entrypath);
|
||||||
|
}
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
196
lib/getdate.c
196
lib/getdate.c
@@ -32,18 +32,14 @@
|
|||||||
** This code is in the public domain and has no copyright.
|
** This code is in the public domain and has no copyright.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
# ifdef HAVE_ALLOCA_H
|
# ifdef HAVE_ALLOCA_H
|
||||||
# include <alloca.h>
|
# include <alloca.h>
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# ifdef NEED_REENTRANT
|
|
||||||
# define _REENTRANT /* Necessary to use in Solaris, since the silly guys at
|
|
||||||
Sun made the localtime_r() prototype dependent on it
|
|
||||||
(or _POSIX_C_SOURCE or _POSIX_PTHREAD_SEMANTICS) */
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# ifdef HAVE_TIME_H
|
# ifdef HAVE_TIME_H
|
||||||
# include <time.h>
|
# include <time.h>
|
||||||
# endif
|
# endif
|
||||||
@@ -132,44 +128,44 @@
|
|||||||
then those parser generators need to be fixed instead of adding those
|
then those parser generators need to be fixed instead of adding those
|
||||||
names to this list. */
|
names to this list. */
|
||||||
|
|
||||||
#define yymaxdepth gd_maxdepth
|
#define yymaxdepth Curl_gd_maxdepth
|
||||||
#define yyparse gd_parse
|
#define yyparse Curl_gd_parse
|
||||||
#define yylex gd_lex
|
#define yylex Curl_gd_lex
|
||||||
#define yyerror gd_error
|
#define yyerror Curl_gd_error
|
||||||
#define yylval gd_lval
|
#define yylval Curl_gd_lval
|
||||||
#define yychar gd_char
|
#define yychar Curl_gd_char
|
||||||
#define yydebug gd_debug
|
#define yydebug Curl_gd_debug
|
||||||
#define yypact gd_pact
|
#define yypact Curl_gd_pact
|
||||||
#define yyr1 gd_r1
|
#define yyr1 Curl_gd_r1
|
||||||
#define yyr2 gd_r2
|
#define yyr2 Curl_gd_r2
|
||||||
#define yydef gd_def
|
#define yydef Curl_gd_def
|
||||||
#define yychk gd_chk
|
#define yychk Curl_gd_chk
|
||||||
#define yypgo gd_pgo
|
#define yypgo Curl_gd_pgo
|
||||||
#define yyact gd_act
|
#define yyact Curl_gd_act
|
||||||
#define yyexca gd_exca
|
#define yyexca Curl_gd_exca
|
||||||
#define yyerrflag gd_errflag
|
#define yyerrflag Curl_gd_errflag
|
||||||
#define yynerrs gd_nerrs
|
#define yynerrs Curl_gd_nerrs
|
||||||
#define yyps gd_ps
|
#define yyps Curl_gd_ps
|
||||||
#define yypv gd_pv
|
#define yypv Curl_gd_pv
|
||||||
#define yys gd_s
|
#define yys Curl_gd_s
|
||||||
#define yy_yys gd_yys
|
#define yy_yys Curl_gd_yys
|
||||||
#define yystate gd_state
|
#define yystate Curl_gd_state
|
||||||
#define yytmp gd_tmp
|
#define yytmp Curl_gd_tmp
|
||||||
#define yyv gd_v
|
#define yyv Curl_gd_v
|
||||||
#define yy_yyv gd_yyv
|
#define yy_yyv Curl_gd_yyv
|
||||||
#define yyval gd_val
|
#define yyval Curl_gd_val
|
||||||
#define yylloc gd_lloc
|
#define yylloc Curl_gd_lloc
|
||||||
#define yyreds gd_reds /* With YYDEBUG defined */
|
#define yyreds Curl_gd_reds /* With YYDEBUG defined */
|
||||||
#define yytoks gd_toks /* With YYDEBUG defined */
|
#define yytoks Curl_gd_toks /* With YYDEBUG defined */
|
||||||
#define yylhs gd_yylhs
|
#define yylhs Curl_gd_yylhs
|
||||||
#define yylen gd_yylen
|
#define yylen Curl_gd_yylen
|
||||||
#define yydefred gd_yydefred
|
#define yydefred Curl_gd_yydefred
|
||||||
#define yydgoto gd_yydgoto
|
#define yydgoto Curl_gd_yydgoto
|
||||||
#define yysindex gd_yysindex
|
#define yysindex Curl_gd_yysindex
|
||||||
#define yyrindex gd_yyrindex
|
#define yyrindex Curl_gd_yyrindex
|
||||||
#define yygindex gd_yygindex
|
#define yygindex Curl_gd_yygindex
|
||||||
#define yytable gd_yytable
|
#define yytable Curl_gd_yytable
|
||||||
#define yycheck gd_yycheck
|
#define yycheck Curl_gd_yycheck
|
||||||
|
|
||||||
static int yylex ();
|
static int yylex ();
|
||||||
static int yyerror ();
|
static int yyerror ();
|
||||||
@@ -227,7 +223,7 @@ static int yyRelSeconds;
|
|||||||
static int yyRelYear;
|
static int yyRelYear;
|
||||||
|
|
||||||
|
|
||||||
#line 210 "getdate.y"
|
#line 206 "getdate.y"
|
||||||
typedef union {
|
typedef union {
|
||||||
int Number;
|
int Number;
|
||||||
enum _MERIDIAN Meridian;
|
enum _MERIDIAN Meridian;
|
||||||
@@ -310,11 +306,11 @@ static const short yyrhs[] = { -1,
|
|||||||
|
|
||||||
#if YYDEBUG != 0
|
#if YYDEBUG != 0
|
||||||
static const short yyrline[] = { 0,
|
static const short yyrline[] = { 0,
|
||||||
226, 227, 230, 233, 236, 239, 242, 245, 248, 254,
|
222, 223, 226, 229, 232, 235, 238, 241, 244, 250,
|
||||||
260, 269, 275, 287, 290, 293, 299, 303, 307, 313,
|
256, 265, 271, 283, 286, 289, 295, 299, 303, 309,
|
||||||
317, 335, 341, 347, 351, 356, 360, 367, 375, 378,
|
313, 331, 337, 343, 347, 352, 356, 363, 371, 374,
|
||||||
381, 384, 387, 390, 393, 396, 399, 402, 405, 408,
|
377, 380, 383, 386, 389, 392, 395, 398, 401, 404,
|
||||||
411, 414, 417, 420, 423, 426, 429, 434, 467, 471
|
407, 410, 413, 416, 419, 422, 425, 430, 463, 467
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -395,7 +391,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/lib/bison.simple"
|
#line 3 "/usr/local/share/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,
|
||||||
@@ -609,7 +605,7 @@ __yy_memcpy (char *to, char *from, unsigned int count)
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#line 217 "/usr/lib/bison.simple"
|
#line 217 "/usr/local/share/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 *.
|
||||||
@@ -938,37 +934,37 @@ yyreduce:
|
|||||||
switch (yyn) {
|
switch (yyn) {
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
#line 230 "getdate.y"
|
#line 226 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHaveTime++;
|
yyHaveTime++;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 4:
|
case 4:
|
||||||
#line 233 "getdate.y"
|
#line 229 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHaveZone++;
|
yyHaveZone++;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 5:
|
case 5:
|
||||||
#line 236 "getdate.y"
|
#line 232 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHaveDate++;
|
yyHaveDate++;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 6:
|
case 6:
|
||||||
#line 239 "getdate.y"
|
#line 235 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHaveDay++;
|
yyHaveDay++;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 7:
|
case 7:
|
||||||
#line 242 "getdate.y"
|
#line 238 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHaveRel++;
|
yyHaveRel++;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 9:
|
case 9:
|
||||||
#line 248 "getdate.y"
|
#line 244 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHour = yyvsp[-1].Number;
|
yyHour = yyvsp[-1].Number;
|
||||||
yyMinutes = 0;
|
yyMinutes = 0;
|
||||||
@@ -977,7 +973,7 @@ case 9:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 10:
|
case 10:
|
||||||
#line 254 "getdate.y"
|
#line 250 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHour = yyvsp[-3].Number;
|
yyHour = yyvsp[-3].Number;
|
||||||
yyMinutes = yyvsp[-1].Number;
|
yyMinutes = yyvsp[-1].Number;
|
||||||
@@ -986,7 +982,7 @@ case 10:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 11:
|
case 11:
|
||||||
#line 260 "getdate.y"
|
#line 256 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHour = yyvsp[-3].Number;
|
yyHour = yyvsp[-3].Number;
|
||||||
yyMinutes = yyvsp[-1].Number;
|
yyMinutes = yyvsp[-1].Number;
|
||||||
@@ -998,7 +994,7 @@ case 11:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 12:
|
case 12:
|
||||||
#line 269 "getdate.y"
|
#line 265 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHour = yyvsp[-5].Number;
|
yyHour = yyvsp[-5].Number;
|
||||||
yyMinutes = yyvsp[-3].Number;
|
yyMinutes = yyvsp[-3].Number;
|
||||||
@@ -1007,7 +1003,7 @@ case 12:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 13:
|
case 13:
|
||||||
#line 275 "getdate.y"
|
#line 271 "getdate.y"
|
||||||
{
|
{
|
||||||
yyHour = yyvsp[-5].Number;
|
yyHour = yyvsp[-5].Number;
|
||||||
yyMinutes = yyvsp[-3].Number;
|
yyMinutes = yyvsp[-3].Number;
|
||||||
@@ -1020,53 +1016,53 @@ case 13:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 14:
|
case 14:
|
||||||
#line 287 "getdate.y"
|
#line 283 "getdate.y"
|
||||||
{
|
{
|
||||||
yyTimezone = yyvsp[0].Number;
|
yyTimezone = yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 15:
|
case 15:
|
||||||
#line 290 "getdate.y"
|
#line 286 "getdate.y"
|
||||||
{
|
{
|
||||||
yyTimezone = yyvsp[0].Number - 60;
|
yyTimezone = yyvsp[0].Number - 60;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 16:
|
case 16:
|
||||||
#line 294 "getdate.y"
|
#line 290 "getdate.y"
|
||||||
{
|
{
|
||||||
yyTimezone = yyvsp[-1].Number - 60;
|
yyTimezone = yyvsp[-1].Number - 60;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 17:
|
case 17:
|
||||||
#line 299 "getdate.y"
|
#line 295 "getdate.y"
|
||||||
{
|
{
|
||||||
yyDayOrdinal = 1;
|
yyDayOrdinal = 1;
|
||||||
yyDayNumber = yyvsp[0].Number;
|
yyDayNumber = yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 18:
|
case 18:
|
||||||
#line 303 "getdate.y"
|
#line 299 "getdate.y"
|
||||||
{
|
{
|
||||||
yyDayOrdinal = 1;
|
yyDayOrdinal = 1;
|
||||||
yyDayNumber = yyvsp[-1].Number;
|
yyDayNumber = yyvsp[-1].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 19:
|
case 19:
|
||||||
#line 307 "getdate.y"
|
#line 303 "getdate.y"
|
||||||
{
|
{
|
||||||
yyDayOrdinal = yyvsp[-1].Number;
|
yyDayOrdinal = yyvsp[-1].Number;
|
||||||
yyDayNumber = yyvsp[0].Number;
|
yyDayNumber = yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 20:
|
case 20:
|
||||||
#line 313 "getdate.y"
|
#line 309 "getdate.y"
|
||||||
{
|
{
|
||||||
yyMonth = yyvsp[-2].Number;
|
yyMonth = yyvsp[-2].Number;
|
||||||
yyDay = yyvsp[0].Number;
|
yyDay = yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 21:
|
case 21:
|
||||||
#line 317 "getdate.y"
|
#line 313 "getdate.y"
|
||||||
{
|
{
|
||||||
/* Interpret as YYYY/MM/DD if $1 >= 1000, otherwise as MM/DD/YY.
|
/* Interpret as YYYY/MM/DD if $1 >= 1000, otherwise as MM/DD/YY.
|
||||||
The goal in recognizing YYYY/MM/DD is solely to support legacy
|
The goal in recognizing YYYY/MM/DD is solely to support legacy
|
||||||
@@ -1087,7 +1083,7 @@ case 21:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 22:
|
case 22:
|
||||||
#line 335 "getdate.y"
|
#line 331 "getdate.y"
|
||||||
{
|
{
|
||||||
/* ISO 8601 format. yyyy-mm-dd. */
|
/* ISO 8601 format. yyyy-mm-dd. */
|
||||||
yyYear = yyvsp[-2].Number;
|
yyYear = yyvsp[-2].Number;
|
||||||
@@ -1096,7 +1092,7 @@ case 22:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 23:
|
case 23:
|
||||||
#line 341 "getdate.y"
|
#line 337 "getdate.y"
|
||||||
{
|
{
|
||||||
/* e.g. 17-JUN-1992. */
|
/* e.g. 17-JUN-1992. */
|
||||||
yyDay = yyvsp[-2].Number;
|
yyDay = yyvsp[-2].Number;
|
||||||
@@ -1105,14 +1101,14 @@ case 23:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 24:
|
case 24:
|
||||||
#line 347 "getdate.y"
|
#line 343 "getdate.y"
|
||||||
{
|
{
|
||||||
yyMonth = yyvsp[-1].Number;
|
yyMonth = yyvsp[-1].Number;
|
||||||
yyDay = yyvsp[0].Number;
|
yyDay = yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 25:
|
case 25:
|
||||||
#line 351 "getdate.y"
|
#line 347 "getdate.y"
|
||||||
{
|
{
|
||||||
yyMonth = yyvsp[-3].Number;
|
yyMonth = yyvsp[-3].Number;
|
||||||
yyDay = yyvsp[-2].Number;
|
yyDay = yyvsp[-2].Number;
|
||||||
@@ -1120,14 +1116,14 @@ case 25:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 26:
|
case 26:
|
||||||
#line 356 "getdate.y"
|
#line 352 "getdate.y"
|
||||||
{
|
{
|
||||||
yyMonth = yyvsp[0].Number;
|
yyMonth = yyvsp[0].Number;
|
||||||
yyDay = yyvsp[-1].Number;
|
yyDay = yyvsp[-1].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 27:
|
case 27:
|
||||||
#line 360 "getdate.y"
|
#line 356 "getdate.y"
|
||||||
{
|
{
|
||||||
yyMonth = yyvsp[-1].Number;
|
yyMonth = yyvsp[-1].Number;
|
||||||
yyDay = yyvsp[-2].Number;
|
yyDay = yyvsp[-2].Number;
|
||||||
@@ -1135,7 +1131,7 @@ case 27:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 28:
|
case 28:
|
||||||
#line 367 "getdate.y"
|
#line 363 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelSeconds = -yyRelSeconds;
|
yyRelSeconds = -yyRelSeconds;
|
||||||
yyRelMinutes = -yyRelMinutes;
|
yyRelMinutes = -yyRelMinutes;
|
||||||
@@ -1146,115 +1142,115 @@ case 28:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 30:
|
case 30:
|
||||||
#line 378 "getdate.y"
|
#line 374 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelYear += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelYear += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 31:
|
case 31:
|
||||||
#line 381 "getdate.y"
|
#line 377 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelYear += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelYear += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 32:
|
case 32:
|
||||||
#line 384 "getdate.y"
|
#line 380 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelYear += yyvsp[0].Number;
|
yyRelYear += yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 33:
|
case 33:
|
||||||
#line 387 "getdate.y"
|
#line 383 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelMonth += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelMonth += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 34:
|
case 34:
|
||||||
#line 390 "getdate.y"
|
#line 386 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelMonth += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelMonth += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 35:
|
case 35:
|
||||||
#line 393 "getdate.y"
|
#line 389 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelMonth += yyvsp[0].Number;
|
yyRelMonth += yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 36:
|
case 36:
|
||||||
#line 396 "getdate.y"
|
#line 392 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelDay += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelDay += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 37:
|
case 37:
|
||||||
#line 399 "getdate.y"
|
#line 395 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelDay += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelDay += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 38:
|
case 38:
|
||||||
#line 402 "getdate.y"
|
#line 398 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelDay += yyvsp[0].Number;
|
yyRelDay += yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 39:
|
case 39:
|
||||||
#line 405 "getdate.y"
|
#line 401 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelHour += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelHour += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 40:
|
case 40:
|
||||||
#line 408 "getdate.y"
|
#line 404 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelHour += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelHour += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 41:
|
case 41:
|
||||||
#line 411 "getdate.y"
|
#line 407 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelHour += yyvsp[0].Number;
|
yyRelHour += yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 42:
|
case 42:
|
||||||
#line 414 "getdate.y"
|
#line 410 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelMinutes += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelMinutes += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 43:
|
case 43:
|
||||||
#line 417 "getdate.y"
|
#line 413 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelMinutes += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelMinutes += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 44:
|
case 44:
|
||||||
#line 420 "getdate.y"
|
#line 416 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelMinutes += yyvsp[0].Number;
|
yyRelMinutes += yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 45:
|
case 45:
|
||||||
#line 423 "getdate.y"
|
#line 419 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelSeconds += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelSeconds += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 46:
|
case 46:
|
||||||
#line 426 "getdate.y"
|
#line 422 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelSeconds += yyvsp[-1].Number * yyvsp[0].Number;
|
yyRelSeconds += yyvsp[-1].Number * yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 47:
|
case 47:
|
||||||
#line 429 "getdate.y"
|
#line 425 "getdate.y"
|
||||||
{
|
{
|
||||||
yyRelSeconds += yyvsp[0].Number;
|
yyRelSeconds += yyvsp[0].Number;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 48:
|
case 48:
|
||||||
#line 435 "getdate.y"
|
#line 431 "getdate.y"
|
||||||
{
|
{
|
||||||
if (yyHaveTime && yyHaveDate && !yyHaveRel)
|
if (yyHaveTime && yyHaveDate && !yyHaveRel)
|
||||||
yyYear = yyvsp[0].Number;
|
yyYear = yyvsp[0].Number;
|
||||||
@@ -1287,20 +1283,20 @@ case 48:
|
|||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 49:
|
case 49:
|
||||||
#line 468 "getdate.y"
|
#line 464 "getdate.y"
|
||||||
{
|
{
|
||||||
yyval.Meridian = MER24;
|
yyval.Meridian = MER24;
|
||||||
;
|
;
|
||||||
break;}
|
break;}
|
||||||
case 50:
|
case 50:
|
||||||
#line 472 "getdate.y"
|
#line 468 "getdate.y"
|
||||||
{
|
{
|
||||||
yyval.Meridian = yyvsp[0].Meridian;
|
yyval.Meridian = yyvsp[0].Meridian;
|
||||||
;
|
;
|
||||||
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/lib/bison.simple"
|
#line 543 "/usr/local/share/bison.simple"
|
||||||
|
|
||||||
yyvsp -= yylen;
|
yyvsp -= yylen;
|
||||||
yyssp -= yylen;
|
yyssp -= yylen;
|
||||||
@@ -1520,7 +1516,7 @@ yyerrhandle:
|
|||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#line 477 "getdate.y"
|
#line 473 "getdate.y"
|
||||||
|
|
||||||
|
|
||||||
/* Include this file down here because bison inserts code above which
|
/* Include this file down here because bison inserts code above which
|
||||||
|
@@ -8,18 +8,14 @@
|
|||||||
** This code is in the public domain and has no copyright.
|
** This code is in the public domain and has no copyright.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
# ifdef HAVE_ALLOCA_H
|
# ifdef HAVE_ALLOCA_H
|
||||||
# include <alloca.h>
|
# include <alloca.h>
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# ifdef NEED_REENTRANT
|
|
||||||
# define _REENTRANT /* Necessary to use in Solaris, since the silly guys at
|
|
||||||
Sun made the localtime_r() prototype dependent on it
|
|
||||||
(or _POSIX_C_SOURCE or _POSIX_PTHREAD_SEMANTICS) */
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# ifdef HAVE_TIME_H
|
# ifdef HAVE_TIME_H
|
||||||
# include <time.h>
|
# include <time.h>
|
||||||
# endif
|
# endif
|
||||||
@@ -108,44 +104,44 @@
|
|||||||
then those parser generators need to be fixed instead of adding those
|
then those parser generators need to be fixed instead of adding those
|
||||||
names to this list. */
|
names to this list. */
|
||||||
|
|
||||||
#define yymaxdepth gd_maxdepth
|
#define yymaxdepth Curl_gd_maxdepth
|
||||||
#define yyparse gd_parse
|
#define yyparse Curl_gd_parse
|
||||||
#define yylex gd_lex
|
#define yylex Curl_gd_lex
|
||||||
#define yyerror gd_error
|
#define yyerror Curl_gd_error
|
||||||
#define yylval gd_lval
|
#define yylval Curl_gd_lval
|
||||||
#define yychar gd_char
|
#define yychar Curl_gd_char
|
||||||
#define yydebug gd_debug
|
#define yydebug Curl_gd_debug
|
||||||
#define yypact gd_pact
|
#define yypact Curl_gd_pact
|
||||||
#define yyr1 gd_r1
|
#define yyr1 Curl_gd_r1
|
||||||
#define yyr2 gd_r2
|
#define yyr2 Curl_gd_r2
|
||||||
#define yydef gd_def
|
#define yydef Curl_gd_def
|
||||||
#define yychk gd_chk
|
#define yychk Curl_gd_chk
|
||||||
#define yypgo gd_pgo
|
#define yypgo Curl_gd_pgo
|
||||||
#define yyact gd_act
|
#define yyact Curl_gd_act
|
||||||
#define yyexca gd_exca
|
#define yyexca Curl_gd_exca
|
||||||
#define yyerrflag gd_errflag
|
#define yyerrflag Curl_gd_errflag
|
||||||
#define yynerrs gd_nerrs
|
#define yynerrs Curl_gd_nerrs
|
||||||
#define yyps gd_ps
|
#define yyps Curl_gd_ps
|
||||||
#define yypv gd_pv
|
#define yypv Curl_gd_pv
|
||||||
#define yys gd_s
|
#define yys Curl_gd_s
|
||||||
#define yy_yys gd_yys
|
#define yy_yys Curl_gd_yys
|
||||||
#define yystate gd_state
|
#define yystate Curl_gd_state
|
||||||
#define yytmp gd_tmp
|
#define yytmp Curl_gd_tmp
|
||||||
#define yyv gd_v
|
#define yyv Curl_gd_v
|
||||||
#define yy_yyv gd_yyv
|
#define yy_yyv Curl_gd_yyv
|
||||||
#define yyval gd_val
|
#define yyval Curl_gd_val
|
||||||
#define yylloc gd_lloc
|
#define yylloc Curl_gd_lloc
|
||||||
#define yyreds gd_reds /* With YYDEBUG defined */
|
#define yyreds Curl_gd_reds /* With YYDEBUG defined */
|
||||||
#define yytoks gd_toks /* With YYDEBUG defined */
|
#define yytoks Curl_gd_toks /* With YYDEBUG defined */
|
||||||
#define yylhs gd_yylhs
|
#define yylhs Curl_gd_yylhs
|
||||||
#define yylen gd_yylen
|
#define yylen Curl_gd_yylen
|
||||||
#define yydefred gd_yydefred
|
#define yydefred Curl_gd_yydefred
|
||||||
#define yydgoto gd_yydgoto
|
#define yydgoto Curl_gd_yydgoto
|
||||||
#define yysindex gd_yysindex
|
#define yysindex Curl_gd_yysindex
|
||||||
#define yyrindex gd_yyrindex
|
#define yyrindex Curl_gd_yyrindex
|
||||||
#define yygindex gd_yygindex
|
#define yygindex Curl_gd_yygindex
|
||||||
#define yytable gd_yytable
|
#define yytable Curl_gd_yytable
|
||||||
#define yycheck gd_yycheck
|
#define yycheck Curl_gd_yycheck
|
||||||
|
|
||||||
static int yylex ();
|
static int yylex ();
|
||||||
static int yyerror ();
|
static int yyerror ();
|
||||||
|
@@ -123,7 +123,6 @@ struct hostent *Curl_gethost(struct UrlData *data,
|
|||||||
int ret; /* this variable is unused on several platforms but used on some */
|
int ret; /* this variable is unused on several platforms but used on some */
|
||||||
|
|
||||||
#define CURL_NAMELOOKUP_SIZE 9000
|
#define CURL_NAMELOOKUP_SIZE 9000
|
||||||
|
|
||||||
/* Allocate enough memory to hold the full name information structs and
|
/* Allocate enough memory to hold the full name information structs and
|
||||||
* everything. OSF1 is known to require at least 8872 bytes. The buffer
|
* everything. OSF1 is known to require at least 8872 bytes. The buffer
|
||||||
* required for storing all possible aliases and IP numbers is according to
|
* required for storing all possible aliases and IP numbers is according to
|
||||||
@@ -133,6 +132,8 @@ struct hostent *Curl_gethost(struct UrlData *data,
|
|||||||
return NULL; /* major failure */
|
return NULL; /* major failure */
|
||||||
*bufp = buf;
|
*bufp = buf;
|
||||||
|
|
||||||
|
ret = 0; /* to prevent the compiler warning */
|
||||||
|
|
||||||
if ( (in=inet_addr(hostname)) != INADDR_NONE ) {
|
if ( (in=inet_addr(hostname)) != INADDR_NONE ) {
|
||||||
struct in_addr *addrentry;
|
struct in_addr *addrentry;
|
||||||
|
|
||||||
|
81
lib/http.c
81
lib/http.c
@@ -34,13 +34,6 @@
|
|||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
|
|
||||||
#ifdef NEED_REENTRANT
|
|
||||||
#define _REENTRANT /* Necessary to use in Solaris, since the silly guys at Sun
|
|
||||||
made the localtime_r() prototype dependent on it (or
|
|
||||||
_POSIX_C_SOURCE or _POSIX_PTHREAD_SEMANTICS). */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__)
|
#if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__)
|
||||||
#include <winsock.h>
|
#include <winsock.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
@@ -336,8 +329,9 @@ CURLcode Curl_http_connect(struct connectdata *conn)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* now, perform the SSL initialization for this socket */
|
/* now, perform the SSL initialization for this socket */
|
||||||
if(Curl_SSLConnect(conn))
|
result = Curl_SSLConnect(conn);
|
||||||
return CURLE_SSL_CONNECT_ERROR;
|
if(result)
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(conn->bits.user_passwd && !data->bits.this_is_a_follow) {
|
if(conn->bits.user_passwd && !data->bits.this_is_a_follow) {
|
||||||
@@ -367,7 +361,7 @@ CURLcode Curl_http_done(struct connectdata *conn)
|
|||||||
data=conn->data;
|
data=conn->data;
|
||||||
http=conn->proto.http;
|
http=conn->proto.http;
|
||||||
|
|
||||||
if(data->bits.http_formpost) {
|
if(HTTPREQ_POST_FORM == data->httpreq) {
|
||||||
*bytecount = http->readbytecount + http->writebytecount;
|
*bytecount = http->readbytecount + http->writebytecount;
|
||||||
|
|
||||||
Curl_FormFree(http->sendit); /* Now free that whole lot */
|
Curl_FormFree(http->sendit); /* Now free that whole lot */
|
||||||
@@ -375,7 +369,7 @@ CURLcode Curl_http_done(struct connectdata *conn)
|
|||||||
data->fread = http->storefread; /* restore */
|
data->fread = http->storefread; /* restore */
|
||||||
data->in = http->in; /* restore */
|
data->in = http->in; /* restore */
|
||||||
}
|
}
|
||||||
else if(data->bits.http_put) {
|
else if(HTTPREQ_PUT == data->httpreq) {
|
||||||
*bytecount = http->readbytecount + http->writebytecount;
|
*bytecount = http->readbytecount + http->writebytecount;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -411,7 +405,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
|
|
||||||
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
|
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
|
||||||
data->bits.upload) {
|
data->bits.upload) {
|
||||||
data->bits.http_put=1;
|
data->httpreq = HTTPREQ_PUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The User-Agent string has been built in url.c already, because it might
|
/* The User-Agent string has been built in url.c already, because it might
|
||||||
@@ -463,7 +457,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
/* The path sent to the proxy is in fact the entire URL */
|
/* The path sent to the proxy is in fact the entire URL */
|
||||||
ppath = data->url;
|
ppath = data->url;
|
||||||
}
|
}
|
||||||
if(data->bits.http_formpost) {
|
if(HTTPREQ_POST_FORM == data->httpreq) {
|
||||||
/* we must build the whole darned post sequence first, so that we have
|
/* we must build the whole darned post sequence first, so that we have
|
||||||
a size of the whole shebang before we start to send it */
|
a size of the whole shebang before we start to send it */
|
||||||
http->sendit = Curl_getFormData(data->httppost, &http->postsize);
|
http->sendit = Curl_getFormData(data->httppost, &http->postsize);
|
||||||
@@ -494,10 +488,10 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
if(!checkheaders(data, "Accept:"))
|
if(!checkheaders(data, "Accept:"))
|
||||||
http->p_accept = "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*\r\n";
|
http->p_accept = "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*\r\n";
|
||||||
|
|
||||||
if((data->bits.http_post ||
|
if(( (HTTPREQ_POST == data->httpreq) ||
|
||||||
data->bits.http_formpost ||
|
(HTTPREQ_POST_FORM == data->httpreq) ||
|
||||||
data->bits.http_put) &&
|
(HTTPREQ_PUT == data->httpreq) ) &&
|
||||||
data->resume_from) {
|
conn->resume_from) {
|
||||||
/**********************************************************************
|
/**********************************************************************
|
||||||
* Resuming upload in HTTP means that we PUT or POST and that we have
|
* Resuming upload in HTTP means that we PUT or POST and that we have
|
||||||
* got a resume_from value set. The resume value has already created
|
* got a resume_from value set. The resume value has already created
|
||||||
@@ -506,15 +500,15 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
* file size before we continue this venture in the dark lands of HTTP.
|
* file size before we continue this venture in the dark lands of HTTP.
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
if(data->resume_from < 0 ) {
|
if(conn->resume_from < 0 ) {
|
||||||
/*
|
/*
|
||||||
* This is meant to get the size of the present remote-file by itself.
|
* This is meant to get the size of the present remote-file by itself.
|
||||||
* We don't support this now. Bail out!
|
* We don't support this now. Bail out!
|
||||||
*/
|
*/
|
||||||
data->resume_from = 0;
|
conn->resume_from = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->resume_from) {
|
if(conn->resume_from) {
|
||||||
/* do we still game? */
|
/* do we still game? */
|
||||||
int passed=0;
|
int passed=0;
|
||||||
|
|
||||||
@@ -522,7 +516,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
input. If we knew it was a proper file we could've just
|
input. If we knew it was a proper file we could've just
|
||||||
fseek()ed but we only have a stream here */
|
fseek()ed but we only have a stream here */
|
||||||
do {
|
do {
|
||||||
int readthisamountnow = (data->resume_from - passed);
|
int readthisamountnow = (conn->resume_from - passed);
|
||||||
int actuallyread;
|
int actuallyread;
|
||||||
|
|
||||||
if(readthisamountnow > BUFSIZE)
|
if(readthisamountnow > BUFSIZE)
|
||||||
@@ -537,11 +531,11 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
passed);
|
passed);
|
||||||
return CURLE_READ_ERROR;
|
return CURLE_READ_ERROR;
|
||||||
}
|
}
|
||||||
} while(passed != data->resume_from); /* loop until done */
|
} while(passed != conn->resume_from); /* loop until done */
|
||||||
|
|
||||||
/* now, decrease the size of the read */
|
/* now, decrease the size of the read */
|
||||||
if(data->infilesize>0) {
|
if(data->infilesize>0) {
|
||||||
data->infilesize -= data->resume_from;
|
data->infilesize -= conn->resume_from;
|
||||||
|
|
||||||
if(data->infilesize <= 0) {
|
if(data->infilesize <= 0) {
|
||||||
failf(data, "File already completely uploaded\n");
|
failf(data, "File already completely uploaded\n");
|
||||||
@@ -551,7 +545,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
/* we've passed, proceed as normal */
|
/* we've passed, proceed as normal */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(data->bits.set_range) {
|
if(conn->bits.use_range) {
|
||||||
/*
|
/*
|
||||||
* A range is selected. We use different headers whether we're downloading
|
* A range is selected. We use different headers whether we're downloading
|
||||||
* or uploading and we always let customized headers override our internal
|
* or uploading and we always let customized headers override our internal
|
||||||
@@ -559,23 +553,23 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
*/
|
*/
|
||||||
if((data->httpreq == HTTPREQ_GET) &&
|
if((data->httpreq == HTTPREQ_GET) &&
|
||||||
!checkheaders(data, "Range:")) {
|
!checkheaders(data, "Range:")) {
|
||||||
conn->allocptr.rangeline = aprintf("Range: bytes=%s\r\n", data->range);
|
conn->allocptr.rangeline = aprintf("Range: bytes=%s\r\n", conn->range);
|
||||||
}
|
}
|
||||||
else if((data->httpreq != HTTPREQ_GET) &&
|
else if((data->httpreq != HTTPREQ_GET) &&
|
||||||
!checkheaders(data, "Content-Range:")) {
|
!checkheaders(data, "Content-Range:")) {
|
||||||
|
|
||||||
if(data->resume_from) {
|
if(conn->resume_from) {
|
||||||
/* This is because "resume" was selected */
|
/* This is because "resume" was selected */
|
||||||
long total_expected_size= data->resume_from + data->infilesize;
|
long total_expected_size= conn->resume_from + data->infilesize;
|
||||||
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s%ld/%ld\r\n",
|
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s%ld/%ld\r\n",
|
||||||
data->range, total_expected_size-1,
|
conn->range, total_expected_size-1,
|
||||||
total_expected_size);
|
total_expected_size);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* Range was selected and then we just pass the incoming range and
|
/* Range was selected and then we just pass the incoming range and
|
||||||
append total size */
|
append total size */
|
||||||
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s/%d\r\n",
|
conn->allocptr.rangeline = aprintf("Content-Range: bytes %s/%d\r\n",
|
||||||
data->range, data->infilesize);
|
conn->range, data->infilesize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -603,14 +597,15 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
|
|
||||||
data->customrequest?data->customrequest:
|
data->customrequest?data->customrequest:
|
||||||
(data->bits.no_body?"HEAD":
|
(data->bits.no_body?"HEAD":
|
||||||
(data->bits.http_post || data->bits.http_formpost)?"POST":
|
((HTTPREQ_POST == data->httpreq) ||
|
||||||
(data->bits.http_put)?"PUT":"GET"),
|
(HTTPREQ_POST_FORM == data->httpreq))?"POST":
|
||||||
|
(HTTPREQ_PUT == data->httpreq)?"PUT":"GET"),
|
||||||
ppath,
|
ppath,
|
||||||
(conn->bits.proxy_user_passwd &&
|
(conn->bits.proxy_user_passwd &&
|
||||||
conn->allocptr.proxyuserpwd)?conn->allocptr.proxyuserpwd:"",
|
conn->allocptr.proxyuserpwd)?conn->allocptr.proxyuserpwd:"",
|
||||||
(conn->bits.user_passwd && conn->allocptr.userpwd)?
|
(conn->bits.user_passwd && conn->allocptr.userpwd)?
|
||||||
conn->allocptr.userpwd:"",
|
conn->allocptr.userpwd:"",
|
||||||
(data->bits.set_range && conn->allocptr.rangeline)?
|
(conn->bits.use_range && conn->allocptr.rangeline)?
|
||||||
conn->allocptr.rangeline:"",
|
conn->allocptr.rangeline:"",
|
||||||
(data->useragent && *data->useragent && conn->allocptr.uagent)?
|
(data->useragent && *data->useragent && conn->allocptr.uagent)?
|
||||||
conn->allocptr.uagent:"",
|
conn->allocptr.uagent:"",
|
||||||
@@ -646,12 +641,21 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
if(data->timecondition) {
|
if(data->timecondition) {
|
||||||
struct tm *thistime;
|
struct tm *thistime;
|
||||||
|
|
||||||
|
/* Phil Karn (Fri, 13 Apr 2001) pointed out that the If-Modified-Since
|
||||||
|
* header family should have their times set in GMT as RFC2616 defines:
|
||||||
|
* "All HTTP date/time stamps MUST be represented in Greenwich Mean Time
|
||||||
|
* (GMT), without exception. For the purposes of HTTP, GMT is exactly
|
||||||
|
* equal to UTC (Coordinated Universal Time)." (see page 20 of RFC2616).
|
||||||
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_LOCALTIME_R
|
#ifdef HAVE_LOCALTIME_R
|
||||||
/* thread-safe version */
|
/* thread-safe version */
|
||||||
|
/* We assume that the presense of localtime_r() proves the presense
|
||||||
|
of gmtime_r() which is a bit ugly but might work */
|
||||||
struct tm keeptime;
|
struct tm keeptime;
|
||||||
thistime = (struct tm *)localtime_r(&data->timevalue, &keeptime);
|
thistime = (struct tm *)gmtime_r(&data->timevalue, &keeptime);
|
||||||
#else
|
#else
|
||||||
thistime = localtime(&data->timevalue);
|
thistime = gmtime(&data->timevalue);
|
||||||
#endif
|
#endif
|
||||||
if(NULL == thistime) {
|
if(NULL == thistime) {
|
||||||
failf(data, "localtime() failed!");
|
failf(data, "localtime() failed!");
|
||||||
@@ -700,7 +704,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
headers = headers->next;
|
headers = headers->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->bits.http_formpost) {
|
if(HTTPREQ_POST_FORM == data->httpreq) {
|
||||||
if(Curl_FormInit(&http->form, http->sendit)) {
|
if(Curl_FormInit(&http->form, http->sendit)) {
|
||||||
failf(data, "Internal HTTP POST error!\n");
|
failf(data, "Internal HTTP POST error!\n");
|
||||||
return CURLE_HTTP_POST_ERROR;
|
return CURLE_HTTP_POST_ERROR;
|
||||||
@@ -709,8 +713,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
http->storefread = data->fread; /* backup */
|
http->storefread = data->fread; /* backup */
|
||||||
http->in = data->in; /* backup */
|
http->in = data->in; /* backup */
|
||||||
|
|
||||||
data->fread =
|
data->fread = (curl_read_callback)
|
||||||
(size_t (*)(char *, size_t, size_t, FILE *))
|
|
||||||
Curl_FormReader; /* set the read function to read from the
|
Curl_FormReader; /* set the read function to read from the
|
||||||
generated form data */
|
generated form data */
|
||||||
data->in = (FILE *)&http->form;
|
data->in = (FILE *)&http->form;
|
||||||
@@ -732,7 +735,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(data->bits.http_put) {
|
else if(HTTPREQ_PUT == data->httpreq) {
|
||||||
/* Let's PUT the data to the server! */
|
/* Let's PUT the data to the server! */
|
||||||
|
|
||||||
if(data->infilesize>0) {
|
if(data->infilesize>0) {
|
||||||
@@ -760,7 +763,7 @@ CURLcode Curl_http(struct connectdata *conn)
|
|||||||
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(data->bits.http_post) {
|
if(HTTPREQ_POST == data->httpreq) {
|
||||||
/* this is the simple POST, using x-www-form-urlencoded style */
|
/* this is the simple POST, using x-www-form-urlencoded style */
|
||||||
|
|
||||||
if(!checkheaders(data, "Content-Length:"))
|
if(!checkheaders(data, "Content-Length:"))
|
||||||
|
@@ -34,10 +34,6 @@
|
|||||||
|
|
||||||
#if ! defined(WIN32) && ! defined(__BEOS__) && !defined(__CYGWIN32__)
|
#if ! defined(WIN32) && ! defined(__BEOS__) && !defined(__CYGWIN32__)
|
||||||
|
|
||||||
#ifdef NEED_REENTRANT
|
|
||||||
#define _REENTRANT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
#ifdef HAVE_SYS_SOCKET_H
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#endif
|
#endif
|
||||||
|
@@ -81,8 +81,8 @@ struct krb4_data {
|
|||||||
};
|
};
|
||||||
|
|
||||||
#ifndef HAVE_STRLCPY
|
#ifndef HAVE_STRLCPY
|
||||||
|
/* if it ever goes non-static, make it Curl_ prefixed! */
|
||||||
size_t
|
static size_t
|
||||||
strlcpy (char *dst, const char *src, size_t dst_sz)
|
strlcpy (char *dst, const char *src, size_t dst_sz)
|
||||||
{
|
{
|
||||||
size_t n;
|
size_t n;
|
||||||
|
@@ -13,20 +13,22 @@ EXPORTS
|
|||||||
curl_easy_perform @ 4 ;
|
curl_easy_perform @ 4 ;
|
||||||
curl_easy_setopt @ 5 ;
|
curl_easy_setopt @ 5 ;
|
||||||
curl_escape @ 6 ;
|
curl_escape @ 6 ;
|
||||||
curl_formparse @ 7 ;
|
curl_unescape @ 7;
|
||||||
curl_formfree @ 8 ;
|
curl_formparse @ 8 ;
|
||||||
curl_getdate @ 9 ;
|
curl_formfree @ 9 ;
|
||||||
curl_getenv @ 10 ;
|
curl_getdate @ 10 ;
|
||||||
curl_slist_append @ 11 ;
|
curl_getenv @ 11 ;
|
||||||
curl_slist_free_all @ 12 ;
|
curl_global_cleanup @ 12 ;
|
||||||
curl_unescape @ 13 ;
|
curl_global_init @ 13 ;
|
||||||
curl_version @ 14 ;
|
curl_slist_append @ 14 ;
|
||||||
curl_maprintf @ 15 ;
|
curl_slist_free_all @ 15 ;
|
||||||
curl_mfprintf @ 16 ;
|
curl_version @ 16 ;
|
||||||
curl_mprintf @ 17 ;
|
curl_maprintf @ 17 ;
|
||||||
curl_msprintf @ 18 ;
|
curl_mfprintf @ 18 ;
|
||||||
curl_msnprintf @ 19 ;
|
curl_mprintf @ 19 ;
|
||||||
curl_mvfprintf @ 20 ;
|
curl_msprintf @ 20 ;
|
||||||
curl_strequal @ 21 ;
|
curl_msnprintf @ 21 ;
|
||||||
curl_strnequal @ 22 ;
|
curl_mvfprintf @ 22 ;
|
||||||
|
curl_strequal @ 23 ;
|
||||||
|
curl_strnequal @ 24 ;
|
||||||
|
|
||||||
|
@@ -41,6 +41,7 @@
|
|||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
#include "strequal.h"
|
#include "strequal.h"
|
||||||
|
#include "strtok.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#ifdef MALLOCDEBUG
|
#ifdef MALLOCDEBUG
|
||||||
@@ -111,8 +112,9 @@ int Curl_parsenetrc(char *host,
|
|||||||
file = fopen(netrcbuffer, "r");
|
file = fopen(netrcbuffer, "r");
|
||||||
if(file) {
|
if(file) {
|
||||||
char *tok;
|
char *tok;
|
||||||
|
char *tok_buf;
|
||||||
while(fgets(netrcbuffer, sizeof(netrcbuffer), file)) {
|
while(fgets(netrcbuffer, sizeof(netrcbuffer), file)) {
|
||||||
tok=strtok(netrcbuffer, " \t\n");
|
tok=strtok_r(netrcbuffer, " \t\n", &tok_buf);
|
||||||
while(tok) {
|
while(tok) {
|
||||||
switch(state) {
|
switch(state) {
|
||||||
case NOTHING:
|
case NOTHING:
|
||||||
@@ -163,7 +165,7 @@ int Curl_parsenetrc(char *host,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
} /* switch (state) */
|
} /* switch (state) */
|
||||||
tok = strtok(NULL, " \t\n");
|
tok = strtok_r(NULL, " \t\n", &tok_buf);
|
||||||
} /* while (tok) */
|
} /* while (tok) */
|
||||||
} /* while fgets() */
|
} /* while fgets() */
|
||||||
|
|
||||||
|
@@ -91,11 +91,14 @@ static char *max5data(double bytes, char *max5)
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void Curl_pgrsDone(struct UrlData *data)
|
void Curl_pgrsDone(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
|
struct UrlData *data = conn->data;
|
||||||
if(!(data->progress.flags & PGRS_HIDE)) {
|
if(!(data->progress.flags & PGRS_HIDE)) {
|
||||||
data->progress.lastshow=0;
|
data->progress.lastshow=0;
|
||||||
Curl_pgrsUpdate(data); /* the final (forced) update */
|
Curl_pgrsUpdate(conn); /* the final (forced) update */
|
||||||
|
if(!data->progress.callback)
|
||||||
|
/* only output if we don't use progress callback */
|
||||||
fprintf(data->err, "\n");
|
fprintf(data->err, "\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -134,6 +137,7 @@ void Curl_pgrsTime(struct UrlData *data, timerid timer)
|
|||||||
|
|
||||||
void Curl_pgrsStartNow(struct UrlData *data)
|
void Curl_pgrsStartNow(struct UrlData *data)
|
||||||
{
|
{
|
||||||
|
data->progress.speeder_c = 0; /* reset the progress meter display */
|
||||||
data->progress.start = Curl_tvnow();
|
data->progress.start = Curl_tvnow();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -171,7 +175,7 @@ void Curl_pgrsSetUploadSize(struct UrlData *data, double size)
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int Curl_pgrsUpdate(struct UrlData *data)
|
int Curl_pgrsUpdate(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct timeval now;
|
struct timeval now;
|
||||||
int result;
|
int result;
|
||||||
@@ -184,6 +188,8 @@ int Curl_pgrsUpdate(struct UrlData *data)
|
|||||||
double total_transfer;
|
double total_transfer;
|
||||||
double total_expected_transfer;
|
double total_expected_transfer;
|
||||||
|
|
||||||
|
struct UrlData *data = conn->data;
|
||||||
|
|
||||||
int nowindex = data->progress.speeder_c% CURR_TIME;
|
int nowindex = data->progress.speeder_c% CURR_TIME;
|
||||||
int checkindex;
|
int checkindex;
|
||||||
int count;
|
int count;
|
||||||
@@ -197,15 +203,16 @@ int Curl_pgrsUpdate(struct UrlData *data)
|
|||||||
|
|
||||||
double total_estimate;
|
double total_estimate;
|
||||||
|
|
||||||
|
|
||||||
if(data->progress.flags & PGRS_HIDE)
|
if(data->progress.flags & PGRS_HIDE)
|
||||||
; /* We do enter this function even if we don't wanna see anything, since
|
; /* We do enter this function even if we don't wanna see anything, since
|
||||||
this is were lots of the calculations are being made that will be used
|
this is were lots of the calculations are being made that will be used
|
||||||
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)
|
if(conn->resume_from)
|
||||||
fprintf(data->err, "** Resuming transfer from byte position %d\n",
|
fprintf(data->err, "** Resuming transfer from byte position %d\n",
|
||||||
data->resume_from);
|
conn->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");
|
||||||
|
@@ -36,13 +36,13 @@ typedef enum {
|
|||||||
TIMER_LAST /* must be last */
|
TIMER_LAST /* must be last */
|
||||||
} timerid;
|
} timerid;
|
||||||
|
|
||||||
void Curl_pgrsDone(struct UrlData *data);
|
void Curl_pgrsDone(struct connectdata *);
|
||||||
void Curl_pgrsStartNow(struct UrlData *data);
|
void Curl_pgrsStartNow(struct UrlData *data);
|
||||||
void Curl_pgrsSetDownloadSize(struct UrlData *data, double size);
|
void Curl_pgrsSetDownloadSize(struct UrlData *data, double size);
|
||||||
void Curl_pgrsSetUploadSize(struct UrlData *data, double size);
|
void Curl_pgrsSetUploadSize(struct UrlData *data, double size);
|
||||||
void Curl_pgrsSetDownloadCounter(struct UrlData *data, double size);
|
void Curl_pgrsSetDownloadCounter(struct UrlData *data, double size);
|
||||||
void Curl_pgrsSetUploadCounter(struct UrlData *data, double size);
|
void Curl_pgrsSetUploadCounter(struct UrlData *data, double size);
|
||||||
int Curl_pgrsUpdate(struct UrlData *data);
|
int Curl_pgrsUpdate(struct connectdata *);
|
||||||
void Curl_pgrsTime(struct UrlData *data, timerid timer);
|
void Curl_pgrsTime(struct UrlData *data, timerid timer);
|
||||||
|
|
||||||
|
|
||||||
|
17
lib/sendf.c
17
lib/sendf.c
@@ -142,11 +142,6 @@ void Curl_failf(struct UrlData *data, char *fmt, ...)
|
|||||||
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 if(!data->bits.mute) {
|
|
||||||
/* no errorbuffer receives this, write to data->err instead */
|
|
||||||
vfprintf(data->err, fmt, ap);
|
|
||||||
fprintf(data->err, "\n");
|
|
||||||
}
|
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -235,8 +230,16 @@ CURLcode Curl_client_write(struct UrlData *data,
|
|||||||
return CURLE_WRITE_ERROR;
|
return CURLE_WRITE_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if((type & CLIENTWRITE_HEADER) && data->writeheader) {
|
if((type & CLIENTWRITE_HEADER) &&
|
||||||
wrote = data->fwrite(ptr, 1, len, data->writeheader);
|
(data->fwrite_header || data->writeheader) ) {
|
||||||
|
/*
|
||||||
|
* Write headers to the same callback or to the especially setup
|
||||||
|
* header callback function (added after version 7.7.1).
|
||||||
|
*/
|
||||||
|
curl_write_callback writeit=
|
||||||
|
data->fwrite_header?data->fwrite_header:data->fwrite;
|
||||||
|
|
||||||
|
wrote = writeit(ptr, 1, len, data->writeheader);
|
||||||
if(wrote != len) {
|
if(wrote != len) {
|
||||||
failf (data, "Failed writing header");
|
failf (data, "Failed writing header");
|
||||||
return CURLE_WRITE_ERROR;
|
return CURLE_WRITE_ERROR;
|
||||||
|
@@ -44,6 +44,14 @@
|
|||||||
typedef char bool;
|
typedef char bool;
|
||||||
#endif /* (rabe) */
|
#endif /* (rabe) */
|
||||||
|
|
||||||
|
#ifdef NEED_REENTRANT
|
||||||
|
/* Solaris machines needs _REENTRANT set for a few function prototypes and
|
||||||
|
things to appear in the #include files. We need to #define it before all
|
||||||
|
#include files */
|
||||||
|
#define _REENTRANT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#ifndef OS
|
#ifndef OS
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
81
lib/ssluse.c
81
lib/ssluse.c
@@ -37,6 +37,11 @@
|
|||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
#include <openssl/rand.h>
|
#include <openssl/rand.h>
|
||||||
|
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#ifdef MALLOCDEBUG
|
||||||
|
#include "memdebug.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
static char global_passwd[64];
|
static char global_passwd[64];
|
||||||
|
|
||||||
static int passwd_callback(char *buf, int num, int verify
|
static int passwd_callback(char *buf, int num, int verify
|
||||||
@@ -225,15 +230,59 @@ int cert_verify_callback(int ok, X509_STORE_CTX *ctx)
|
|||||||
err_cert=X509_STORE_CTX_get_current_cert(ctx);
|
err_cert=X509_STORE_CTX_get_current_cert(ctx);
|
||||||
X509_NAME_oneline(X509_get_subject_name(err_cert),buf,256);
|
X509_NAME_oneline(X509_get_subject_name(err_cert),buf,256);
|
||||||
|
|
||||||
return 1;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_SSLEAY
|
||||||
|
/* "global" init done? */
|
||||||
|
static int init_ssl=0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Global init */
|
||||||
|
void Curl_SSL_init(void)
|
||||||
|
{
|
||||||
|
#ifdef USE_SSLEAY
|
||||||
|
|
||||||
|
/* make sure this is only done once */
|
||||||
|
if(0 != init_ssl)
|
||||||
|
return;
|
||||||
|
|
||||||
|
init_ssl++; /* never again */
|
||||||
|
|
||||||
|
/* Lets get nice error messages */
|
||||||
|
SSL_load_error_strings();
|
||||||
|
|
||||||
|
/* Setup all the global SSL stuff */
|
||||||
|
SSLeay_add_ssl_algorithms();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Global cleanup */
|
||||||
|
void Curl_SSL_cleanup(void)
|
||||||
|
{
|
||||||
|
#ifdef USE_SSLEAY
|
||||||
|
if(init_ssl) {
|
||||||
|
/* only cleanup if we did a previous init */
|
||||||
|
|
||||||
|
/* Free the SSL error strings */
|
||||||
|
ERR_free_strings();
|
||||||
|
|
||||||
|
/* EVP_cleanup() removes all ciphers and digests from the
|
||||||
|
table. */
|
||||||
|
EVP_cleanup();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ====================================================== */
|
/* ====================================================== */
|
||||||
int
|
CURLcode
|
||||||
Curl_SSLConnect(struct connectdata *conn)
|
Curl_SSLConnect(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
|
CURLcode retcode = CURLE_OK;
|
||||||
|
|
||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
struct UrlData *data = conn->data;
|
struct UrlData *data = conn->data;
|
||||||
int err;
|
int err;
|
||||||
@@ -243,15 +292,9 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
/* mark this is being ssl enabled from here on out. */
|
/* mark this is being ssl enabled from here on out. */
|
||||||
conn->ssl.use = TRUE;
|
conn->ssl.use = TRUE;
|
||||||
|
|
||||||
/* Lets get nice error messages */
|
|
||||||
SSL_load_error_strings();
|
|
||||||
|
|
||||||
/* Make funny stuff to get random input */
|
/* Make funny stuff to get random input */
|
||||||
random_the_seed(conn);
|
random_the_seed(conn);
|
||||||
|
|
||||||
/* Setup all the global SSL stuff */
|
|
||||||
SSLeay_add_ssl_algorithms();
|
|
||||||
|
|
||||||
switch(data->ssl.version) {
|
switch(data->ssl.version) {
|
||||||
default:
|
default:
|
||||||
req_method = SSLv23_client_method();
|
req_method = SSLv23_client_method();
|
||||||
@@ -268,13 +311,13 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
|
|
||||||
if(!conn->ssl.ctx) {
|
if(!conn->ssl.ctx) {
|
||||||
failf(data, "SSL: couldn't create a context!");
|
failf(data, "SSL: couldn't create a context!");
|
||||||
return 1;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data->cert) {
|
if(data->cert) {
|
||||||
if (!cert_stuff(conn, data->cert, data->cert)) {
|
if (!cert_stuff(conn, data->cert, data->cert)) {
|
||||||
failf(data, "couldn't use certificate!\n");
|
/* failf() is already done in cert_stuff() */
|
||||||
return 2;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -287,7 +330,7 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
data->ssl.CAfile,
|
data->ssl.CAfile,
|
||||||
data->ssl.CApath)) {
|
data->ssl.CApath)) {
|
||||||
failf(data,"error setting cerficate verify locations\n");
|
failf(data,"error setting cerficate verify locations\n");
|
||||||
return 2;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -307,7 +350,7 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
if (-1 == err) {
|
if (-1 == err) {
|
||||||
err = ERR_get_error();
|
err = ERR_get_error();
|
||||||
failf(data, "SSL: %s", ERR_error_string(err, NULL));
|
failf(data, "SSL: %s", ERR_error_string(err, NULL));
|
||||||
return 10;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Informational message */
|
/* Informational message */
|
||||||
@@ -323,7 +366,7 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
conn->ssl.server_cert = SSL_get_peer_certificate (conn->ssl.handle);
|
conn->ssl.server_cert = SSL_get_peer_certificate (conn->ssl.handle);
|
||||||
if(!conn->ssl.server_cert) {
|
if(!conn->ssl.server_cert) {
|
||||||
failf(data, "SSL: couldn't get peer certificate!");
|
failf(data, "SSL: couldn't get peer certificate!");
|
||||||
return 3;
|
return CURLE_SSL_PEER_CERTIFICATE;
|
||||||
}
|
}
|
||||||
infof (data, "Server certificate:\n");
|
infof (data, "Server certificate:\n");
|
||||||
|
|
||||||
@@ -331,7 +374,7 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
NULL, 0);
|
NULL, 0);
|
||||||
if(!str) {
|
if(!str) {
|
||||||
failf(data, "SSL: couldn't get X509-subject!");
|
failf(data, "SSL: couldn't get X509-subject!");
|
||||||
return 4;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
}
|
||||||
infof(data, "\t subject: %s\n", str);
|
infof(data, "\t subject: %s\n", str);
|
||||||
CRYPTO_free(str);
|
CRYPTO_free(str);
|
||||||
@@ -340,7 +383,7 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
NULL, 0);
|
NULL, 0);
|
||||||
if(!str) {
|
if(!str) {
|
||||||
failf(data, "SSL: couldn't get X509-issuer name!");
|
failf(data, "SSL: couldn't get X509-issuer name!");
|
||||||
return 5;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
}
|
||||||
infof(data, "\t issuer: %s\n", str);
|
infof(data, "\t issuer: %s\n", str);
|
||||||
CRYPTO_free(str);
|
CRYPTO_free(str);
|
||||||
@@ -350,7 +393,9 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
|
|
||||||
if(data->ssl.verifypeer) {
|
if(data->ssl.verifypeer) {
|
||||||
data->ssl.certverifyresult=SSL_get_verify_result(conn->ssl.handle);
|
data->ssl.certverifyresult=SSL_get_verify_result(conn->ssl.handle);
|
||||||
infof(data, "Verify result: %d\n", data->ssl.certverifyresult);
|
failf(data, "SSL certificate verify result: %d\n",
|
||||||
|
data->ssl.certverifyresult);
|
||||||
|
retcode = CURLE_SSL_PEER_CERTIFICATE;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
data->ssl.certverifyresult=0;
|
data->ssl.certverifyresult=0;
|
||||||
@@ -360,5 +405,5 @@ Curl_SSLConnect(struct connectdata *conn)
|
|||||||
/* this is for "-ansi -Wall -pedantic" to stop complaining! (rabe) */
|
/* this is for "-ansi -Wall -pedantic" to stop complaining! (rabe) */
|
||||||
(void) conn;
|
(void) conn;
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
@@ -23,5 +23,9 @@
|
|||||||
* $Id$
|
* $Id$
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
int Curl_SSLConnect(struct connectdata *conn);
|
CURLcode Curl_SSLConnect(struct connectdata *conn);
|
||||||
|
/* Global SSL init */
|
||||||
|
void Curl_SSL_init(void);
|
||||||
|
/* Global SSL cleanup */
|
||||||
|
void Curl_SSL_cleanup(void);
|
||||||
#endif
|
#endif
|
||||||
|
@@ -80,7 +80,7 @@ int curl_strnequal(const char *first, const char *second, size_t max)
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
size_t strlcat(char *dst, const char *src, size_t siz)
|
size_t Curl_strlcat(char *dst, const char *src, size_t siz)
|
||||||
{
|
{
|
||||||
char *d = dst;
|
char *d = dst;
|
||||||
const char *s = src;
|
const char *s = src;
|
||||||
|
@@ -32,4 +32,9 @@ int curl_strnequal(const char *first, const char *second, size_t max);
|
|||||||
#define strequal(a,b) curl_strequal(a,b)
|
#define strequal(a,b) curl_strequal(a,b)
|
||||||
#define strnequal(a,b,c) curl_strnequal(a,b,c)
|
#define strnequal(a,b,c) curl_strnequal(a,b,c)
|
||||||
|
|
||||||
|
#ifndef HAVE_STRLCAT
|
||||||
|
#define strlcat(x,y,z) Curl_strlcat(x,y,z)
|
||||||
|
size_t Curl_strlcat(char *dst, const char *src, size_t siz);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
128
lib/strtok.c
Normal file
128
lib/strtok.c
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* 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"
|
||||||
|
|
||||||
|
#ifndef HAVE_STRTOK_R
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 1998 Softweyr LLC. All rights reserved.
|
||||||
|
*
|
||||||
|
* strtok_r, from Berkeley strtok
|
||||||
|
* Oct 13, 1998 by Wes Peters <wes@softweyr.com>
|
||||||
|
*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notices, this list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notices, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
*
|
||||||
|
* This product includes software developed by Softweyr LLC, the
|
||||||
|
* University of California, Berkeley, and its contributors.
|
||||||
|
*
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY SOFTWEYR LLC, THE REGENTS AND CONTRIBUTORS
|
||||||
|
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
||||||
|
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SOFTWEYR LLC, THE
|
||||||
|
* REGENTS, OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
|
||||||
|
* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
char *
|
||||||
|
Curl_strtok_r(char *s, const char *delim, char **last)
|
||||||
|
{
|
||||||
|
char *spanp;
|
||||||
|
int c, sc;
|
||||||
|
char *tok;
|
||||||
|
|
||||||
|
if (s == NULL && (s = *last) == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Skip (span) leading delimiters (s += strspn(s, delim), sort of).
|
||||||
|
*/
|
||||||
|
cont:
|
||||||
|
c = *s++;
|
||||||
|
for (spanp = (char *)delim; (sc = *spanp++) != 0; ) {
|
||||||
|
if (c == sc) {
|
||||||
|
goto cont;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (c == 0) { /* no non-delimiter characters */
|
||||||
|
*last = NULL;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
tok = s - 1;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Scan token (scan for delimiters: s += strcspn(s, delim), sort of).
|
||||||
|
* Note that delim must have one NUL; we stop if we see that, too.
|
||||||
|
*/
|
||||||
|
for (;;) {
|
||||||
|
c = *s++;
|
||||||
|
spanp = (char *)delim;
|
||||||
|
do {
|
||||||
|
if ((sc = *spanp++) == c) {
|
||||||
|
if (c == 0) {
|
||||||
|
s = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
char *w = s - 1;
|
||||||
|
*w = '\0';
|
||||||
|
}
|
||||||
|
*last = s;
|
||||||
|
return tok;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (sc != 0);
|
||||||
|
}
|
||||||
|
/* NOTREACHED */
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
38
lib/strtok.h
Normal file
38
lib/strtok.h
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* 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 _CURL_STRTOK_R_H
|
||||||
|
#define _CURL_STRTOK_R_H
|
||||||
|
|
||||||
|
#include "setup.h"
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
#ifndef HAVE_STRTOK_R
|
||||||
|
char *Curl_strtok_r(char *s, const char *delim, char **last);
|
||||||
|
#define strtok_r Curl_strtok_r
|
||||||
|
#else
|
||||||
|
#include <string.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
359
lib/transfer.c
359
lib/transfer.c
@@ -103,8 +103,74 @@
|
|||||||
#define min(a, b) ((a) < (b) ? (a) : (b))
|
#define min(a, b) ((a) < (b) ? (a) : (b))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Parts of this function was written by the friendly Mark Butler
|
/*
|
||||||
<butlerm@xmission.com>. */
|
* compareheader()
|
||||||
|
*
|
||||||
|
* Returns TRUE if 'headerline' contains the 'header' with given 'content'.
|
||||||
|
* Pass headers WITH the colon.
|
||||||
|
*/
|
||||||
|
static bool
|
||||||
|
compareheader(char *headerline, /* line to check */
|
||||||
|
char *header, /* header keyword _with_ colon */
|
||||||
|
char *content) /* content string to find */
|
||||||
|
{
|
||||||
|
/* RFC2616, section 4.2 says: "Each header field consists of a name followed
|
||||||
|
* by a colon (":") and the field value. Field names are case-insensitive.
|
||||||
|
* The field value MAY be preceded by any amount of LWS, though a single SP
|
||||||
|
* is preferred." */
|
||||||
|
|
||||||
|
size_t hlen = strlen(header);
|
||||||
|
size_t clen;
|
||||||
|
size_t len;
|
||||||
|
char *start;
|
||||||
|
char *end;
|
||||||
|
|
||||||
|
if(!strnequal(headerline, header, hlen))
|
||||||
|
return FALSE; /* doesn't start with header */
|
||||||
|
|
||||||
|
/* pass the header */
|
||||||
|
start = &headerline[hlen];
|
||||||
|
|
||||||
|
/* pass all white spaces */
|
||||||
|
while(*start && isspace((int)*start))
|
||||||
|
start++;
|
||||||
|
|
||||||
|
/* find the end of the header line */
|
||||||
|
end = strchr(start, '\r'); /* lines end with CRLF */
|
||||||
|
if(!end) {
|
||||||
|
/* in case there's a non-standard compliant line here */
|
||||||
|
end = strchr(start, '\n');
|
||||||
|
|
||||||
|
if(!end)
|
||||||
|
/* hm, there's no line ending here, return false and bail out! */
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = end-start; /* length of the content part of the input line */
|
||||||
|
clen = strlen(content); /* length of the word to find */
|
||||||
|
|
||||||
|
/* find the content string in the rest of the line */
|
||||||
|
for(;len>=clen;len--, start++) {
|
||||||
|
if(strnequal(start, content, clen))
|
||||||
|
return TRUE; /* match! */
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE; /* no match */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Transfer()
|
||||||
|
*
|
||||||
|
* This function is what performs the actual transfer. It is capable of
|
||||||
|
* doing both ways simultaneously.
|
||||||
|
* The transfer must already have been setup by a call to Curl_Transfer().
|
||||||
|
*
|
||||||
|
* Note that headers are created in a preallocated buffer of a default size.
|
||||||
|
* That buffer can be enlarged on demand, but it is never shrinken again.
|
||||||
|
*
|
||||||
|
* Parts of this function was once written by the friendly Mark Butler
|
||||||
|
* <butlerm@xmission.com>.
|
||||||
|
*/
|
||||||
|
|
||||||
CURLcode static
|
CURLcode static
|
||||||
Transfer(struct connectdata *c_conn)
|
Transfer(struct connectdata *c_conn)
|
||||||
@@ -128,7 +194,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
int offset = 0; /* possible resume offset read from the
|
int offset = 0; /* possible resume offset read from the
|
||||||
Content-Range: header */
|
Content-Range: header */
|
||||||
int httpcode = 0; /* error code from the 'HTTP/1.? XXX' line */
|
int httpcode = 0; /* error code from the 'HTTP/1.? XXX' line */
|
||||||
int httpversion = -1; /* the last digit in the HTTP/1.1 string */
|
int httpversion = -1; /* the HTTP version*10 */
|
||||||
|
|
||||||
/* for the low speed checks: */
|
/* for the low speed checks: */
|
||||||
CURLcode urg;
|
CURLcode urg;
|
||||||
@@ -236,6 +302,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
we bail out from this! */
|
we bail out from this! */
|
||||||
else if (0 >= (signed int) nread) {
|
else if (0 >= (signed int) nread) {
|
||||||
keepon &= ~KEEP_READ;
|
keepon &= ~KEEP_READ;
|
||||||
|
FD_ZERO(&rkeepfd);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -262,6 +329,10 @@ Transfer(struct connectdata *c_conn)
|
|||||||
/* copy what is remaining into headerbuff */
|
/* copy what is remaining into headerbuff */
|
||||||
int str_length = (int)strlen(str);
|
int str_length = (int)strlen(str);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We enlarge the header buffer if it seems to be too
|
||||||
|
* smallish
|
||||||
|
*/
|
||||||
if (hbuflen + (int)str_length >= data->headersize) {
|
if (hbuflen + (int)str_length >= data->headersize) {
|
||||||
char *newbuff;
|
char *newbuff;
|
||||||
long newsize=MAX((hbuflen+str_length)*3/2,
|
long newsize=MAX((hbuflen+str_length)*3/2,
|
||||||
@@ -284,6 +355,12 @@ Transfer(struct connectdata *c_conn)
|
|||||||
|
|
||||||
str = end_ptr + 1; /* move just past new line */
|
str = end_ptr + 1; /* move just past new line */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We're about to copy a chunk of data to the end of the
|
||||||
|
* already received header. We make sure that the full string
|
||||||
|
* fit in the allocated header buffer, or else we enlarge
|
||||||
|
* it.
|
||||||
|
*/
|
||||||
if (hbuflen + (str - str_start) >= data->headersize) {
|
if (hbuflen + (str - str_start) >= data->headersize) {
|
||||||
char *newbuff;
|
char *newbuff;
|
||||||
long newsize=MAX((hbuflen+(str-str_start))*3/2,
|
long newsize=MAX((hbuflen+(str-str_start))*3/2,
|
||||||
@@ -307,23 +384,17 @@ Transfer(struct connectdata *c_conn)
|
|||||||
|
|
||||||
p = data->headerbuff;
|
p = data->headerbuff;
|
||||||
|
|
||||||
/* we now have a full line that p points to */
|
/****
|
||||||
if (('\n' == *p) || ('\r' == *p)) {
|
* We now have a FULL header line that p points to
|
||||||
/* Zero-length line means end of header! */
|
*****/
|
||||||
#if 0
|
|
||||||
if (-1 != conn->size) /* if known */
|
|
||||||
conn->size += bytecount; /* we append the already read
|
|
||||||
size */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
if (('\n' == *p) || ('\r' == *p)) {
|
||||||
|
/* Zero-length header line means end of headers! */
|
||||||
|
|
||||||
if ('\r' == *p)
|
if ('\r' == *p)
|
||||||
p++; /* pass the \r byte */
|
p++; /* pass the \r byte */
|
||||||
if ('\n' == *p)
|
if ('\n' == *p)
|
||||||
p++; /* pass the \n byte */
|
p++; /* pass the \n byte */
|
||||||
#if 0 /* headers are not included in the size */
|
|
||||||
Curl_pgrsSetDownloadSize(data, conn->size);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if(100 == httpcode) {
|
if(100 == httpcode) {
|
||||||
/*
|
/*
|
||||||
@@ -354,14 +425,29 @@ Transfer(struct connectdata *c_conn)
|
|||||||
|
|
||||||
if(!header) {
|
if(!header) {
|
||||||
/*
|
/*
|
||||||
* end-of-headers.
|
* really end-of-headers.
|
||||||
*
|
*
|
||||||
* If we requested a "no body" and this isn't a "close"
|
* If we requested a "no body", this is a good time to get
|
||||||
* connection, this is a good time to get out and return
|
* out and return home.
|
||||||
* home.
|
|
||||||
*/
|
*/
|
||||||
if(!conn->bits.close && data->bits.no_body)
|
if(data->bits.no_body)
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
|
|
||||||
|
if(!conn->bits.close) {
|
||||||
|
/* If this is not the last request before a close, we must
|
||||||
|
set the maximum download size to the size of the
|
||||||
|
expected document or else, we won't know when to stop
|
||||||
|
reading! */
|
||||||
|
if(-1 != conn->size)
|
||||||
|
conn->maxdownload = conn->size;
|
||||||
|
|
||||||
|
/* If max download size is *zero* (nothing) we already
|
||||||
|
have nothing and can safely return ok now! */
|
||||||
|
if(0 == conn->maxdownload)
|
||||||
|
return CURLE_OK;
|
||||||
|
|
||||||
|
/* What to do if the size is *not* known? */
|
||||||
|
}
|
||||||
break; /* exit header line loop */
|
break; /* exit header line loop */
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -372,11 +458,31 @@ Transfer(struct connectdata *c_conn)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Checks for special headers coming up.
|
||||||
|
*/
|
||||||
|
|
||||||
if (!headerline++) {
|
if (!headerline++) {
|
||||||
/* This is the first header, it MUST be the error code line
|
/* This is the first header, it MUST be the error code line
|
||||||
or else we consiser this to be the body right away! */
|
or else we consiser this to be the body right away! */
|
||||||
if (2 == sscanf (p, " HTTP/1.%d %3d", &httpversion,
|
int httpversion_major;
|
||||||
&httpcode)) {
|
int nc=sscanf (p, " HTTP/%d.%d %3d",
|
||||||
|
&httpversion_major ,&httpversion, &httpcode);
|
||||||
|
if (nc==3) {
|
||||||
|
httpversion+=10*httpversion_major;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* this is the real world, not a Nirvana
|
||||||
|
NCSA 1.5.x returns this crap when asked for HTTP/1.1
|
||||||
|
*/
|
||||||
|
nc=sscanf (p, " HTTP %3d", &httpcode);
|
||||||
|
httpversion = 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nc) {
|
||||||
|
data->progress.httpcode = httpcode;
|
||||||
|
data->progress.httpversion = httpversion;
|
||||||
|
|
||||||
/* 404 -> URL not found! */
|
/* 404 -> URL not found! */
|
||||||
if (
|
if (
|
||||||
( ((data->bits.http_follow_location) &&
|
( ((data->bits.http_follow_location) &&
|
||||||
@@ -391,13 +497,21 @@ Transfer(struct connectdata *c_conn)
|
|||||||
failf (data, "The requested file was not found");
|
failf (data, "The requested file was not found");
|
||||||
return CURLE_HTTP_NOT_FOUND;
|
return CURLE_HTTP_NOT_FOUND;
|
||||||
}
|
}
|
||||||
data->progress.httpcode = httpcode;
|
|
||||||
data->progress.httpversion = httpversion;
|
if(httpversion == 10)
|
||||||
if(httpversion == 0)
|
|
||||||
/* Default action for HTTP/1.0 must be to close, unless
|
/* Default action for HTTP/1.0 must be to close, unless
|
||||||
we get one of those fancy headers that tell us the
|
we get one of those fancy headers that tell us the
|
||||||
server keeps it open for us! */
|
server keeps it open for us! */
|
||||||
conn->bits.close = TRUE;
|
conn->bits.close = TRUE;
|
||||||
|
|
||||||
|
if (httpcode == 304)
|
||||||
|
/* (quote from RFC2616, section 10.3.5):
|
||||||
|
* The 304 response MUST NOT contain a
|
||||||
|
* message-body, and thus is always
|
||||||
|
* terminated by the first empty line
|
||||||
|
* after the header fields.
|
||||||
|
*/
|
||||||
|
conn->size=0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
header = FALSE; /* this is not a header line */
|
header = FALSE; /* this is not a header line */
|
||||||
@@ -405,15 +519,14 @@ Transfer(struct connectdata *c_conn)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* check for Content-Length: header lines to get size */
|
/* check for Content-Length: header lines to get size */
|
||||||
if (strnequal("Content-Length", p, 14) &&
|
if (strnequal("Content-Length:", p, 15) &&
|
||||||
sscanf (p+14, ": %ld", &contentlength)) {
|
sscanf (p+15, " %ld", &contentlength)) {
|
||||||
conn->size = contentlength;
|
conn->size = contentlength;
|
||||||
Curl_pgrsSetDownloadSize(data, contentlength);
|
Curl_pgrsSetDownloadSize(data, contentlength);
|
||||||
}
|
}
|
||||||
else if((httpversion == 0) &&
|
else if((httpversion == 10) &&
|
||||||
conn->bits.httpproxy &&
|
conn->bits.httpproxy &&
|
||||||
strnequal("Proxy-Connection: keep-alive", p,
|
compareheader(p, "Proxy-Connection:", "keep-alive")) {
|
||||||
strlen("Proxy-Connection: keep-alive"))) {
|
|
||||||
/*
|
/*
|
||||||
* When a HTTP/1.0 reply comes when using a proxy, the
|
* When a HTTP/1.0 reply comes when using a proxy, the
|
||||||
* 'Proxy-Connection: keep-alive' line tells us the
|
* 'Proxy-Connection: keep-alive' line tells us the
|
||||||
@@ -423,8 +536,18 @@ Transfer(struct connectdata *c_conn)
|
|||||||
conn->bits.close = FALSE; /* don't close when done */
|
conn->bits.close = FALSE; /* don't close when done */
|
||||||
infof(data, "HTTP/1.0 proxy connection set to keep alive!\n");
|
infof(data, "HTTP/1.0 proxy connection set to keep alive!\n");
|
||||||
}
|
}
|
||||||
else if (strnequal("Connection: close", p,
|
else if((httpversion == 10) &&
|
||||||
strlen("Connection: close"))) {
|
compareheader(p, "Connection:", "keep-alive")) {
|
||||||
|
/*
|
||||||
|
* A HTTP/1.0 reply with the 'Connection: keep-alive' line
|
||||||
|
* tells us the connection will be kept alive for our
|
||||||
|
* pleasure. Default action for 1.0 is to close.
|
||||||
|
*
|
||||||
|
* [RFC2068, section 19.7.1] */
|
||||||
|
conn->bits.close = FALSE; /* don't close when done */
|
||||||
|
infof(data, "HTTP/1.0 connection set to keep alive!\n");
|
||||||
|
}
|
||||||
|
else if (compareheader(p, "Connection:", "close")) {
|
||||||
/*
|
/*
|
||||||
* [RFC 2616, section 8.1.2.1]
|
* [RFC 2616, section 8.1.2.1]
|
||||||
* "Connection: close" is HTTP/1.1 language and means that
|
* "Connection: close" is HTTP/1.1 language and means that
|
||||||
@@ -433,8 +556,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
*/
|
*/
|
||||||
conn->bits.close = TRUE; /* close when done */
|
conn->bits.close = TRUE; /* close when done */
|
||||||
}
|
}
|
||||||
else if (strnequal("Transfer-Encoding: chunked", p,
|
else if (compareheader(p, "Transfer-Encoding:", "chunked")) {
|
||||||
strlen("Transfer-Encoding: chunked"))) {
|
|
||||||
/*
|
/*
|
||||||
* [RFC 2616, section 3.6.1] A 'chunked' transfer encoding
|
* [RFC 2616, section 3.6.1] A 'chunked' transfer encoding
|
||||||
* means that the server will send a series of "chunks". Each
|
* means that the server will send a series of "chunks". Each
|
||||||
@@ -448,13 +570,13 @@ Transfer(struct connectdata *c_conn)
|
|||||||
/* init our chunky engine */
|
/* init our chunky engine */
|
||||||
Curl_httpchunk_init(conn);
|
Curl_httpchunk_init(conn);
|
||||||
}
|
}
|
||||||
else if (strnequal("Content-Range", p, 13)) {
|
else if (strnequal("Content-Range:", p, 14)) {
|
||||||
if (sscanf (p+13, ": bytes %d-", &offset) ||
|
if (sscanf (p+14, " bytes %d-", &offset) ||
|
||||||
sscanf (p+13, ": bytes: %d-", &offset)) {
|
sscanf (p+14, " bytes: %d-", &offset)) {
|
||||||
/* This second format was added August 1st 2000 by Igor
|
/* This second format was added August 1st 2000 by Igor
|
||||||
Khristophorov since Sun's webserver JavaWebServer/1.1.1
|
Khristophorov since Sun's webserver JavaWebServer/1.1.1
|
||||||
obviously sends the header this way! :-( */
|
obviously sends the header this way! :-( */
|
||||||
if (data->resume_from == offset) {
|
if (conn->resume_from == offset) {
|
||||||
/* we asked for a resume and we got it */
|
/* we asked for a resume and we got it */
|
||||||
content_range = TRUE;
|
content_range = TRUE;
|
||||||
}
|
}
|
||||||
@@ -474,14 +596,20 @@ Transfer(struct connectdata *c_conn)
|
|||||||
}
|
}
|
||||||
else if ((httpcode >= 300 && httpcode < 400) &&
|
else if ((httpcode >= 300 && httpcode < 400) &&
|
||||||
(data->bits.http_follow_location) &&
|
(data->bits.http_follow_location) &&
|
||||||
strnequal("Location: ", p, 10)) {
|
strnequal("Location:", p, 9)) {
|
||||||
/* this is the URL that the server advices us to get instead */
|
/* this is the URL that the server advices us to get instead */
|
||||||
char *ptr;
|
char *ptr;
|
||||||
char *start=p;
|
char *start=p;
|
||||||
char backup;
|
char backup;
|
||||||
|
|
||||||
start += 10; /* pass "Location: " */
|
start += 9; /* pass "Location:" */
|
||||||
|
|
||||||
|
/* Skip spaces and tabs. We do this to support multiple
|
||||||
|
white spaces after the "Location:" keyword. */
|
||||||
|
while(*start && isspace((int)*start ))
|
||||||
|
start++;
|
||||||
ptr = start; /* start scanning here */
|
ptr = start; /* start scanning here */
|
||||||
|
|
||||||
/* scan through the string to find the end */
|
/* scan through the string to find the end */
|
||||||
while(*ptr && !isspace((int)*ptr))
|
while(*ptr && !isspace((int)*ptr))
|
||||||
ptr++;
|
ptr++;
|
||||||
@@ -491,6 +619,10 @@ Transfer(struct connectdata *c_conn)
|
|||||||
*ptr = backup; /* restore ending letter */
|
*ptr = backup; /* restore ending letter */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* End of header-checks. Write them to the client.
|
||||||
|
*/
|
||||||
|
|
||||||
writetype = CLIENTWRITE_HEADER;
|
writetype = CLIENTWRITE_HEADER;
|
||||||
if (data->bits.http_include_header)
|
if (data->bits.http_include_header)
|
||||||
writetype |= CLIENTWRITE_BODY;
|
writetype |= CLIENTWRITE_BODY;
|
||||||
@@ -536,7 +668,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
infof (data, "Follow to new URL: %s\n", conn->newurl);
|
infof (data, "Follow to new URL: %s\n", conn->newurl);
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
else if (data->resume_from &&
|
else if (conn->resume_from &&
|
||||||
!content_range &&
|
!content_range &&
|
||||||
(data->httpreq==HTTPREQ_GET)) {
|
(data->httpreq==HTTPREQ_GET)) {
|
||||||
/* we wanted to resume a download, although the server
|
/* we wanted to resume a download, although the server
|
||||||
@@ -546,7 +678,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
"byte ranges. Cannot resume.");
|
"byte ranges. Cannot resume.");
|
||||||
return CURLE_HTTP_RANGE_ERROR;
|
return CURLE_HTTP_RANGE_ERROR;
|
||||||
}
|
}
|
||||||
else if(data->timecondition && !data->range) {
|
else if(data->timecondition && !conn->range) {
|
||||||
/* A time condition has been set AND no ranges have been
|
/* A time condition has been set AND no ranges have been
|
||||||
requested. This seems to be what chapter 13.3.4 of
|
requested. This seems to be what chapter 13.3.4 of
|
||||||
RFC 2616 defines to be the correct action for a
|
RFC 2616 defines to be the correct action for a
|
||||||
@@ -572,16 +704,6 @@ Transfer(struct connectdata *c_conn)
|
|||||||
} /* two valid time strings */
|
} /* two valid time strings */
|
||||||
} /* we have a time condition */
|
} /* we have a time condition */
|
||||||
|
|
||||||
if(!conn->bits.close) {
|
|
||||||
/* If this is not the last request before a close, we must
|
|
||||||
set the maximum download size to the size of the expected
|
|
||||||
document or else, we won't know when to stop reading! */
|
|
||||||
if(-1 != conn->size)
|
|
||||||
conn->maxdownload = conn->size;
|
|
||||||
|
|
||||||
/* What to do if the size is *not* known? */
|
|
||||||
}
|
|
||||||
|
|
||||||
} /* this is HTTP */
|
} /* this is HTTP */
|
||||||
} /* this is the first time we write a body part */
|
} /* this is the first time we write a body part */
|
||||||
bodywrites++;
|
bodywrites++;
|
||||||
@@ -603,6 +725,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
else if(CHUNKE_STOP == res) {
|
else if(CHUNKE_STOP == res) {
|
||||||
/* we're done reading chunks! */
|
/* we're done reading chunks! */
|
||||||
keepon &= ~KEEP_READ; /* read no more */
|
keepon &= ~KEEP_READ; /* read no more */
|
||||||
|
FD_ZERO(&rkeepfd);
|
||||||
|
|
||||||
/* There are now possibly N number of bytes at the end of the
|
/* There are now possibly N number of bytes at the end of the
|
||||||
str buffer that weren't written to the client, but we don't
|
str buffer that weren't written to the client, but we don't
|
||||||
@@ -611,19 +734,21 @@ Transfer(struct connectdata *c_conn)
|
|||||||
/* If it returned OK, we just keep going */
|
/* If it returned OK, we just keep going */
|
||||||
}
|
}
|
||||||
|
|
||||||
if(conn->maxdownload &&
|
if((-1 != conn->maxdownload) &&
|
||||||
(bytecount + nread >= conn->maxdownload)) {
|
(bytecount + nread >= conn->maxdownload)) {
|
||||||
nread = conn->maxdownload - bytecount;
|
nread = conn->maxdownload - bytecount;
|
||||||
if((signed int)nread < 0 ) /* this should be unusual */
|
if((signed int)nread < 0 ) /* this should be unusual */
|
||||||
nread = 0;
|
nread = 0;
|
||||||
|
|
||||||
keepon &= ~KEEP_READ; /* we're done reading */
|
keepon &= ~KEEP_READ; /* we're done reading */
|
||||||
|
FD_ZERO(&rkeepfd);
|
||||||
}
|
}
|
||||||
|
|
||||||
bytecount += nread;
|
bytecount += nread;
|
||||||
|
|
||||||
Curl_pgrsSetDownloadCounter(data, (double)bytecount);
|
Curl_pgrsSetDownloadCounter(data, (double)bytecount);
|
||||||
|
|
||||||
if(! conn->bits.chunk) {
|
if(!conn->bits.chunk && nread) {
|
||||||
/* If this is chunky transfer, it was already written */
|
/* If this is chunky transfer, it was already written */
|
||||||
urg = Curl_client_write(data, CLIENTWRITE_BODY, str, nread);
|
urg = Curl_client_write(data, CLIENTWRITE_BODY, str, nread);
|
||||||
if(urg)
|
if(urg)
|
||||||
@@ -650,6 +775,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
if ((signed int)nread<=0) {
|
if ((signed int)nread<=0) {
|
||||||
/* done */
|
/* done */
|
||||||
keepon &= ~KEEP_WRITE; /* we're done writing */
|
keepon &= ~KEEP_WRITE; /* we're done writing */
|
||||||
|
FD_ZERO(&wkeepfd);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
writebytecount += nread;
|
writebytecount += nread;
|
||||||
@@ -685,7 +811,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
}
|
}
|
||||||
|
|
||||||
now = Curl_tvnow();
|
now = Curl_tvnow();
|
||||||
if(Curl_pgrsUpdate(data))
|
if(Curl_pgrsUpdate(conn))
|
||||||
urg = CURLE_ABORTED_BY_CALLBACK;
|
urg = CURLE_ABORTED_BY_CALLBACK;
|
||||||
else
|
else
|
||||||
urg = Curl_speedcheck (data, now);
|
urg = Curl_speedcheck (data, now);
|
||||||
@@ -708,6 +834,12 @@ Transfer(struct connectdata *c_conn)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The tranfer has been performed. Just make some general checks before
|
||||||
|
* returning.
|
||||||
|
*/
|
||||||
|
|
||||||
if(!(data->bits.no_body) && contentlength &&
|
if(!(data->bits.no_body) && contentlength &&
|
||||||
(bytecount != contentlength)) {
|
(bytecount != contentlength)) {
|
||||||
failf(data, "transfer closed with %d bytes remaining to read",
|
failf(data, "transfer closed with %d bytes remaining to read",
|
||||||
@@ -719,7 +851,7 @@ Transfer(struct connectdata *c_conn)
|
|||||||
conn->proto.http->chunk.datasize);
|
conn->proto.http->chunk.datasize);
|
||||||
return CURLE_PARTIAL_FILE;
|
return CURLE_PARTIAL_FILE;
|
||||||
}
|
}
|
||||||
if(Curl_pgrsUpdate(data))
|
if(Curl_pgrsUpdate(conn))
|
||||||
return CURLE_ABORTED_BY_CALLBACK;
|
return CURLE_ABORTED_BY_CALLBACK;
|
||||||
|
|
||||||
if(conn->bytecountp)
|
if(conn->bytecountp)
|
||||||
@@ -736,6 +868,14 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
struct UrlData *data = (struct UrlData *)curl;
|
struct UrlData *data = (struct UrlData *)curl;
|
||||||
struct connectdata *conn=NULL;
|
struct connectdata *conn=NULL;
|
||||||
bool port=TRUE; /* allow data->use_port to set port to use */
|
bool port=TRUE; /* allow data->use_port to set port to use */
|
||||||
|
char *newurl = NULL; /* possibly a new URL to follow to! */
|
||||||
|
|
||||||
|
if(!data->url)
|
||||||
|
/* we can't do anything wihout URL */
|
||||||
|
return CURLE_URL_MALFORMAT;
|
||||||
|
|
||||||
|
data->followlocation=0; /* reset the location-follow counter */
|
||||||
|
data->bits.this_is_a_follow = FALSE; /* reset this */
|
||||||
|
|
||||||
Curl_pgrsStartNow(data);
|
Curl_pgrsStartNow(data);
|
||||||
|
|
||||||
@@ -745,12 +885,31 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
if(res == CURLE_OK) {
|
if(res == CURLE_OK) {
|
||||||
res = Curl_do(conn);
|
res = Curl_do(conn);
|
||||||
if(res == CURLE_OK) {
|
if(res == CURLE_OK) {
|
||||||
|
if(conn->protocol&PROT_FTPS)
|
||||||
|
/* FTPS, disable ssl while transfering data */
|
||||||
|
conn->ssl.use = FALSE;
|
||||||
res = Transfer(conn); /* now fetch that URL please */
|
res = Transfer(conn); /* now fetch that URL please */
|
||||||
if(res == CURLE_OK)
|
if(conn->protocol&PROT_FTPS)
|
||||||
|
/* FTPS, enable ssl again after havving transferred data */
|
||||||
|
conn->ssl.use = TRUE;
|
||||||
|
|
||||||
|
if(res == CURLE_OK) {
|
||||||
|
/*
|
||||||
|
* We must duplicate the new URL here as the connection data
|
||||||
|
* may be free()ed in the Curl_done() function.
|
||||||
|
*/
|
||||||
|
newurl = conn->newurl?strdup(conn->newurl):NULL;
|
||||||
|
|
||||||
res = Curl_done(conn);
|
res = Curl_done(conn);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if((res == CURLE_OK) && conn->newurl) {
|
/*
|
||||||
|
* Important: 'conn' cannot be used here, since it may have been closed
|
||||||
|
* in 'Curl_done' or other functions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if((res == CURLE_OK) && newurl) {
|
||||||
/* Location: redirect
|
/* Location: redirect
|
||||||
|
|
||||||
This is assumed to happen for HTTP(S) only!
|
This is assumed to happen for HTTP(S) only!
|
||||||
@@ -763,9 +922,6 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
|
|
||||||
if (data->maxredirs && (data->followlocation >= data->maxredirs)) {
|
if (data->maxredirs && (data->followlocation >= data->maxredirs)) {
|
||||||
failf(data,"Maximum (%d) redirects followed", data->maxredirs);
|
failf(data,"Maximum (%d) redirects followed", data->maxredirs);
|
||||||
#ifdef USE_OLD_DISCONNECT
|
|
||||||
curl_disconnect(c_connect);
|
|
||||||
#endif
|
|
||||||
res=CURLE_TOO_MANY_REDIRECTS;
|
res=CURLE_TOO_MANY_REDIRECTS;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -790,7 +946,7 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
data->bits.http_set_referer = TRUE; /* might have been false */
|
data->bits.http_set_referer = TRUE; /* might have been false */
|
||||||
}
|
}
|
||||||
|
|
||||||
if(2 != sscanf(conn->newurl, "%15[^:]://%c", prot, &letter)) {
|
if(2 != sscanf(newurl, "%15[^:]://%c", prot, &letter)) {
|
||||||
/***
|
/***
|
||||||
*DANG* this is an RFC 2068 violation. The URL is supposed
|
*DANG* this is an RFC 2068 violation. The URL is supposed
|
||||||
to be absolute and this doesn't seem to be that!
|
to be absolute and this doesn't seem to be that!
|
||||||
@@ -803,19 +959,21 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
char *pathsep;
|
char *pathsep;
|
||||||
char *newest;
|
char *newest;
|
||||||
|
|
||||||
|
/* we must make our own copy of the URL to play with, as it may
|
||||||
|
point to read-only data */
|
||||||
|
char *url_clone=strdup(data->url);
|
||||||
|
|
||||||
|
if(!url_clone)
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
/* protsep points to the start of the host name */
|
/* protsep points to the start of the host name */
|
||||||
protsep=strstr(data->url, "//");
|
protsep=strstr(url_clone, "//");
|
||||||
if(!protsep)
|
if(!protsep)
|
||||||
protsep=data->url;
|
protsep=url_clone;
|
||||||
else {
|
else
|
||||||
port=FALSE; /* we got a full URL and thus we should not obey the
|
|
||||||
port number that might have been set by the user
|
|
||||||
in data->use_port */
|
|
||||||
|
|
||||||
protsep+=2; /* pass the slashes */
|
protsep+=2; /* pass the slashes */
|
||||||
}
|
|
||||||
|
|
||||||
if('/' != conn->newurl[0]) {
|
if('/' != newurl[0]) {
|
||||||
/* First we need to find out if there's a ?-letter in the URL,
|
/* First we need to find out if there's a ?-letter in the URL,
|
||||||
and cut it and the right-side of that off */
|
and cut it and the right-side of that off */
|
||||||
pathsep = strrchr(protsep, '?');
|
pathsep = strrchr(protsep, '?');
|
||||||
@@ -836,16 +994,17 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
*pathsep=0;
|
*pathsep=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
newest=(char *)malloc( strlen(data->url) +
|
newest=(char *)malloc( strlen(url_clone) +
|
||||||
1 + /* possible slash */
|
1 + /* possible slash */
|
||||||
strlen(conn->newurl) + 1/* zero byte */);
|
strlen(newurl) + 1/* zero byte */);
|
||||||
|
|
||||||
if(!newest)
|
if(!newest)
|
||||||
return CURLE_OUT_OF_MEMORY;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
sprintf(newest, "%s%s%s", data->url, ('/' == conn->newurl[0])?"":"/",
|
sprintf(newest, "%s%s%s", url_clone, ('/' == newurl[0])?"":"/",
|
||||||
conn->newurl);
|
newurl);
|
||||||
free(conn->newurl);
|
free(newurl);
|
||||||
conn->newurl = newest;
|
free(url_clone);
|
||||||
|
newurl = newest;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* This is an absolute URL, don't use the custom port number */
|
/* This is an absolute URL, don't use the custom port number */
|
||||||
@@ -856,8 +1015,9 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
free(data->url);
|
free(data->url);
|
||||||
|
|
||||||
/* TBD: set the URL with curl_setopt() */
|
/* TBD: set the URL with curl_setopt() */
|
||||||
data->url = conn->newurl;
|
data->url = newurl;
|
||||||
conn->newurl = NULL; /* don't show! */
|
newurl = NULL; /* don't free! */
|
||||||
|
|
||||||
data->bits.urlstringalloc = TRUE; /* the URL is allocated */
|
data->bits.urlstringalloc = TRUE; /* the URL is allocated */
|
||||||
|
|
||||||
infof(data, "Follows Location: to new URL: '%s'\n", data->url);
|
infof(data, "Follows Location: to new URL: '%s'\n", data->url);
|
||||||
@@ -871,7 +1031,6 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
switch(data->progress.httpcode) {
|
switch(data->progress.httpcode) {
|
||||||
case 300: /* Multiple Choices */
|
case 300: /* Multiple Choices */
|
||||||
case 301: /* Moved Permanently */
|
case 301: /* Moved Permanently */
|
||||||
case 302: /* Found */
|
|
||||||
case 306: /* Not used */
|
case 306: /* Not used */
|
||||||
case 307: /* Temporary Redirect */
|
case 307: /* Temporary Redirect */
|
||||||
default: /* for all unknown ones */
|
default: /* for all unknown ones */
|
||||||
@@ -879,13 +1038,29 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
* seem to be OK to POST to.
|
* seem to be OK to POST to.
|
||||||
*/
|
*/
|
||||||
break;
|
break;
|
||||||
|
case 302: /* Found */
|
||||||
|
/* (From 10.3.3)
|
||||||
|
|
||||||
|
Note: RFC 1945 and RFC 2068 specify that the client is not allowed
|
||||||
|
to change the method on the redirected request. However, most
|
||||||
|
existing user agent implementations treat 302 as if it were a 303
|
||||||
|
response, performing a GET on the Location field-value regardless
|
||||||
|
of the original request method. The status codes 303 and 307 have
|
||||||
|
been added for servers that wish to make unambiguously clear which
|
||||||
|
kind of reaction is expected of the client.
|
||||||
|
|
||||||
|
(From 10.3.4)
|
||||||
|
|
||||||
|
Note: Many pre-HTTP/1.1 user agents do not understand the 303
|
||||||
|
status. When interoperability with such clients is a concern, the
|
||||||
|
302 status code may be used instead, since most user agents react
|
||||||
|
to a 302 response as described here for 303.
|
||||||
|
*/
|
||||||
case 303: /* See Other */
|
case 303: /* See Other */
|
||||||
/* Disable both types of POSTs, since doing a second POST when
|
/* Disable both types of POSTs, since doing a second POST when
|
||||||
* following isn't what anyone would want! */
|
* following isn't what anyone would want! */
|
||||||
data->bits.http_post = FALSE;
|
data->httpreq = HTTPREQ_GET; /* enforce GET request */
|
||||||
data->bits.http_formpost = FALSE;
|
infof(data, "Disables POST, goes with GET\n");
|
||||||
data->httpreq = HTTPREQ_GET; /* enfore GET request */
|
|
||||||
infof(data, "Disables POST\n");
|
|
||||||
break;
|
break;
|
||||||
case 304: /* Not Modified */
|
case 304: /* Not Modified */
|
||||||
/* 304 means we did a conditional request and it was "Not modified".
|
/* 304 means we did a conditional request and it was "Not modified".
|
||||||
@@ -902,29 +1077,23 @@ CURLcode Curl_perform(CURL *curl)
|
|||||||
*/
|
*/
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#ifdef USE_OLD_DISCONNECT
|
|
||||||
curl_disconnect(c_connect);
|
|
||||||
#endif
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_OLD_DISCONNECT
|
|
||||||
curl_disconnect(c_connect);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
break; /* it only reaches here when this shouldn't loop */
|
break; /* it only reaches here when this shouldn't loop */
|
||||||
|
|
||||||
} while(1); /* loop if Location: */
|
} while(1); /* loop if Location: */
|
||||||
|
|
||||||
if(conn->newurl) {
|
if(newurl)
|
||||||
free(conn->newurl);
|
free(newurl);
|
||||||
conn->newurl = NULL;
|
|
||||||
}
|
/* make sure the alarm is switched off! */
|
||||||
|
if(data->timeout || data->connecttimeout)
|
||||||
|
myalarm(0);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
CURLcode
|
CURLcode
|
||||||
Curl_Transfer(struct connectdata *c_conn, /* connection data */
|
Curl_Transfer(struct connectdata *c_conn, /* connection data */
|
||||||
int sockfd, /* socket to read from or -1 */
|
int sockfd, /* socket to read from or -1 */
|
||||||
|
@@ -35,11 +35,4 @@ Curl_Transfer (struct connectdata *data,
|
|||||||
the same we read from. -1 disables */
|
the same we read from. -1 disables */
|
||||||
long *writebytecountp /* return number of bytes written */
|
long *writebytecountp /* return number of bytes written */
|
||||||
);
|
);
|
||||||
|
|
||||||
#ifdef _OLDCURL
|
|
||||||
/* "hackish" define to make sources compile without too much human editing.
|
|
||||||
Don't use "Tranfer()" anymore! */
|
|
||||||
#define Transfer(a,b,c,d,e,f,g) Curl_Transfer(a,b,c,d,e,f,g)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
237
lib/url.c
237
lib/url.c
@@ -91,6 +91,7 @@
|
|||||||
#include "cookie.h"
|
#include "cookie.h"
|
||||||
#include "strequal.h"
|
#include "strequal.h"
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
|
#include "strtok.h"
|
||||||
|
|
||||||
/* And now for the protocols */
|
/* And now for the protocols */
|
||||||
#include "ftp.h"
|
#include "ftp.h"
|
||||||
@@ -153,13 +154,6 @@ CURLcode Curl_close(CURL *curl)
|
|||||||
data->bits.httpproxy=FALSE;
|
data->bits.httpproxy=FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(data->bits.rangestringalloc) {
|
|
||||||
free(data->range);
|
|
||||||
data->range=NULL;
|
|
||||||
data->bits.rangestringalloc=0; /* free now */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* check for allocated [URL] memory to free: */
|
/* check for allocated [URL] memory to free: */
|
||||||
if(data->freethis)
|
if(data->freethis)
|
||||||
free(data->freethis);
|
free(data->freethis);
|
||||||
@@ -223,10 +217,10 @@ CURLcode Curl_open(CURL **curl, char *url)
|
|||||||
data->err = stderr; /* default stderr to stderr */
|
data->err = stderr; /* default stderr to stderr */
|
||||||
|
|
||||||
/* use fwrite as default function to store output */
|
/* use fwrite as default function to store output */
|
||||||
data->fwrite = (size_t (*)(char *, size_t, size_t, FILE *))fwrite;
|
data->fwrite = (curl_write_callback)fwrite;
|
||||||
|
|
||||||
/* use fread as default function to read input */
|
/* use fread as default function to read input */
|
||||||
data->fread = (size_t (*)(char *, size_t, size_t, FILE *))fread;
|
data->fread = (curl_read_callback)fread;
|
||||||
|
|
||||||
/* set the default passwd function */
|
/* set the default passwd function */
|
||||||
data->fpasswd = my_getpass;
|
data->fpasswd = my_getpass;
|
||||||
@@ -237,6 +231,10 @@ CURLcode Curl_open(CURL **curl, char *url)
|
|||||||
|
|
||||||
data->httpreq = HTTPREQ_GET; /* Default HTTP request */
|
data->httpreq = HTTPREQ_GET; /* Default HTTP request */
|
||||||
|
|
||||||
|
/* make libcurl quiet by default: */
|
||||||
|
data->bits.hide_progress = TRUE; /* CURLOPT_NOPROGRESS changes these */
|
||||||
|
data->progress.flags |= PGRS_HIDE;
|
||||||
|
|
||||||
/* create an array with connection data struct pointers */
|
/* create an array with connection data struct pointers */
|
||||||
data->numconnects = 5; /* hard-coded right now */
|
data->numconnects = 5; /* hard-coded right now */
|
||||||
data->connects = (struct connectdata **)
|
data->connects = (struct connectdata **)
|
||||||
@@ -369,6 +367,8 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
data->bits.hide_progress = va_arg(param, long)?TRUE:FALSE;
|
data->bits.hide_progress = va_arg(param, long)?TRUE:FALSE;
|
||||||
if(data->bits.hide_progress)
|
if(data->bits.hide_progress)
|
||||||
data->progress.flags |= PGRS_HIDE;
|
data->progress.flags |= PGRS_HIDE;
|
||||||
|
else
|
||||||
|
data->progress.flags &= ~PGRS_HIDE;
|
||||||
break;
|
break;
|
||||||
case CURLOPT_NOBODY:
|
case CURLOPT_NOBODY:
|
||||||
/*
|
/*
|
||||||
@@ -432,18 +432,21 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
break;
|
break;
|
||||||
case CURLOPT_PUT:
|
case CURLOPT_PUT:
|
||||||
/*
|
/*
|
||||||
* Use the HTTP PUT request to transfer data.
|
* Use the HTTP PUT request to transfer data if this is TRUE. If this is
|
||||||
|
* FALSE, don't set the httpreq. We can't know what to revert it to!
|
||||||
*/
|
*/
|
||||||
data->bits.http_put = va_arg(param, long)?TRUE:FALSE;
|
if(va_arg(param, long))
|
||||||
if(data->bits.http_put)
|
|
||||||
data->httpreq = HTTPREQ_PUT;
|
data->httpreq = HTTPREQ_PUT;
|
||||||
break;
|
break;
|
||||||
|
#if 0
|
||||||
|
/* obsolete stuff, kept here a while for informational purposes */
|
||||||
case CURLOPT_MUTE:
|
case CURLOPT_MUTE:
|
||||||
/*
|
/*
|
||||||
* Stay absolutely quiet.
|
* Stay absolutely quiet.
|
||||||
*/
|
*/
|
||||||
data->bits.mute = va_arg(param, long)?TRUE:FALSE;
|
data->bits.mute = va_arg(param, long)?TRUE:FALSE;
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
case CURLOPT_TIMECONDITION:
|
case CURLOPT_TIMECONDITION:
|
||||||
/*
|
/*
|
||||||
* Set HTTP time condition. This must be one of the defines in the
|
* Set HTTP time condition. This must be one of the defines in the
|
||||||
@@ -477,9 +480,9 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
break;
|
break;
|
||||||
case CURLOPT_WRITEHEADER:
|
case CURLOPT_WRITEHEADER:
|
||||||
/*
|
/*
|
||||||
* Callback function for header data
|
* Custom pointer to pass the header write callback function
|
||||||
*/
|
*/
|
||||||
data->writeheader = (FILE *)va_arg(param, FILE *);
|
data->writeheader = (void *)va_arg(param, void *);
|
||||||
break;
|
break;
|
||||||
case CURLOPT_COOKIE:
|
case CURLOPT_COOKIE:
|
||||||
/*
|
/*
|
||||||
@@ -526,10 +529,18 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
* Set to make us do HTTP POST
|
* Set to make us do HTTP POST
|
||||||
*/
|
*/
|
||||||
data->httppost = va_arg(param, struct HttpPost *);
|
data->httppost = va_arg(param, struct HttpPost *);
|
||||||
data->bits.http_formpost = data->httppost?1:0;
|
if(data->httppost)
|
||||||
if(data->bits.http_formpost)
|
|
||||||
data->httpreq = HTTPREQ_POST_FORM;
|
data->httpreq = HTTPREQ_POST_FORM;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CURLOPT_HTTPGET:
|
||||||
|
/*
|
||||||
|
* Set to force us do HTTP GET
|
||||||
|
*/
|
||||||
|
if(va_arg(param, long))
|
||||||
|
data->httpreq = HTTPREQ_GET;
|
||||||
|
break;
|
||||||
|
|
||||||
case CURLOPT_INFILE:
|
case CURLOPT_INFILE:
|
||||||
/*
|
/*
|
||||||
* FILE pointer to read the file to be uploaded from. Or possibly
|
* FILE pointer to read the file to be uploaded from. Or possibly
|
||||||
@@ -572,8 +583,8 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
break;
|
break;
|
||||||
case CURLOPT_POST:
|
case CURLOPT_POST:
|
||||||
/* Does this option serve a purpose anymore? */
|
/* Does this option serve a purpose anymore? */
|
||||||
data->bits.http_post = va_arg(param, long)?TRUE:FALSE;
|
|
||||||
if(data->bits.http_post)
|
if(va_arg(param, long))
|
||||||
data->httpreq = HTTPREQ_POST;
|
data->httpreq = HTTPREQ_POST;
|
||||||
break;
|
break;
|
||||||
case CURLOPT_POSTFIELDS:
|
case CURLOPT_POSTFIELDS:
|
||||||
@@ -581,8 +592,7 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
* A string with POST data. Makes curl HTTP POST.
|
* A string with POST data. Makes curl HTTP POST.
|
||||||
*/
|
*/
|
||||||
data->postfields = va_arg(param, char *);
|
data->postfields = va_arg(param, char *);
|
||||||
data->bits.http_post = data->postfields?TRUE:FALSE;
|
if(data->postfields)
|
||||||
if(data->bits.http_post)
|
|
||||||
data->httpreq = HTTPREQ_POST;
|
data->httpreq = HTTPREQ_POST;
|
||||||
break;
|
break;
|
||||||
case CURLOPT_POSTFIELDSIZE:
|
case CURLOPT_POSTFIELDSIZE:
|
||||||
@@ -703,14 +713,14 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
/*
|
/*
|
||||||
* What range of the file you want to transfer
|
* What range of the file you want to transfer
|
||||||
*/
|
*/
|
||||||
data->range = va_arg(param, char *);
|
data->set_range = va_arg(param, char *);
|
||||||
data->bits.set_range = data->range?1:0;
|
data->bits.set_range = data->set_range?1:0;
|
||||||
break;
|
break;
|
||||||
case CURLOPT_RESUME_FROM:
|
case CURLOPT_RESUME_FROM:
|
||||||
/*
|
/*
|
||||||
* Resume transfer at the give file position
|
* Resume transfer at the give file position
|
||||||
*/
|
*/
|
||||||
data->resume_from = va_arg(param, long);
|
data->set_resume_from = va_arg(param, long);
|
||||||
break;
|
break;
|
||||||
case CURLOPT_STDERR:
|
case CURLOPT_STDERR:
|
||||||
/*
|
/*
|
||||||
@@ -719,6 +729,12 @@ CURLcode Curl_setopt(CURL *curl, CURLoption option, ...)
|
|||||||
*/
|
*/
|
||||||
data->err = va_arg(param, FILE *);
|
data->err = va_arg(param, FILE *);
|
||||||
break;
|
break;
|
||||||
|
case CURLOPT_HEADERFUNCTION:
|
||||||
|
/*
|
||||||
|
* Set header write callback
|
||||||
|
*/
|
||||||
|
data->fwrite_header = va_arg(param, curl_write_callback);
|
||||||
|
break;
|
||||||
case CURLOPT_WRITEFUNCTION:
|
case CURLOPT_WRITEFUNCTION:
|
||||||
/*
|
/*
|
||||||
* Set data write callback
|
* Set data write callback
|
||||||
@@ -795,6 +811,16 @@ CURLcode Curl_disconnect(struct connectdata *conn)
|
|||||||
if(!conn)
|
if(!conn)
|
||||||
return CURLE_OK; /* this is closed and fine already */
|
return CURLE_OK; /* this is closed and fine already */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The range string is usually freed in curl_done(), but we might
|
||||||
|
* get here *instead* if we fail prematurely. Thus we need to be able
|
||||||
|
* to free this resource here as well.
|
||||||
|
*/
|
||||||
|
if(conn->bits.rangestringalloc) {
|
||||||
|
free(conn->range);
|
||||||
|
conn->bits.rangestringalloc = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
if(-1 != conn->connectindex) {
|
if(-1 != conn->connectindex) {
|
||||||
/* unlink ourselves! */
|
/* unlink ourselves! */
|
||||||
infof(conn->data, "Closing live connection (#%d)\n", conn->connectindex);
|
infof(conn->data, "Closing live connection (#%d)\n", conn->connectindex);
|
||||||
@@ -816,11 +842,25 @@ CURLcode Curl_disconnect(struct connectdata *conn)
|
|||||||
free(conn->hostent_buf);
|
free(conn->hostent_buf);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if(conn->newurl)
|
||||||
|
free(conn->newurl);
|
||||||
|
|
||||||
if(conn->path) /* the URL path part */
|
if(conn->path) /* the URL path part */
|
||||||
free(conn->path);
|
free(conn->path);
|
||||||
|
|
||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
if (conn->ssl.use) {
|
if (conn->ssl.use) {
|
||||||
|
/*
|
||||||
|
ERR_remove_state() frees the error queue associated with
|
||||||
|
thread pid. If pid == 0, the current thread will have its
|
||||||
|
error queue removed.
|
||||||
|
|
||||||
|
Since error queue data structures are allocated
|
||||||
|
automatically for new threads, they must be freed when
|
||||||
|
threads are terminated in oder to avoid memory leaks.
|
||||||
|
*/
|
||||||
|
ERR_remove_state(0);
|
||||||
|
|
||||||
if(conn->ssl.handle) {
|
if(conn->ssl.handle) {
|
||||||
(void)SSL_shutdown(conn->ssl.handle);
|
(void)SSL_shutdown(conn->ssl.handle);
|
||||||
SSL_set_connect_state(conn->ssl.handle);
|
SSL_set_connect_state(conn->ssl.handle);
|
||||||
@@ -918,7 +958,7 @@ ConnectionExists(struct UrlData *data,
|
|||||||
|
|
||||||
if(strequal(needle->protostr, check->protostr) &&
|
if(strequal(needle->protostr, check->protostr) &&
|
||||||
strequal(needle->name, check->name) &&
|
strequal(needle->name, check->name) &&
|
||||||
(needle->port == check->port) ) {
|
(needle->remote_port == check->remote_port) ) {
|
||||||
bool dead;
|
bool dead;
|
||||||
if(strequal(needle->protostr, "FTP")) {
|
if(strequal(needle->protostr, "FTP")) {
|
||||||
/* This is FTP, verify that we're using the same name and
|
/* This is FTP, verify that we're using the same name and
|
||||||
@@ -936,9 +976,11 @@ ConnectionExists(struct UrlData *data,
|
|||||||
data->connects[i]=NULL; /* nothing here */
|
data->connects[i]=NULL; /* nothing here */
|
||||||
continue; /* try another one now */
|
continue; /* try another one now */
|
||||||
}
|
}
|
||||||
}
|
|
||||||
*usethis = check;
|
*usethis = check;
|
||||||
return TRUE; /* yes, we found one to use! */
|
return TRUE; /* yes, we found one to use! */
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else { /* The requested needle connection is using a proxy,
|
else { /* The requested needle connection is using a proxy,
|
||||||
is the checked one using the same? */
|
is the checked one using the same? */
|
||||||
@@ -1049,6 +1091,11 @@ ConnectionStore(struct UrlData *data,
|
|||||||
static CURLcode ConnectPlease(struct UrlData *data,
|
static CURLcode ConnectPlease(struct UrlData *data,
|
||||||
struct connectdata *conn)
|
struct connectdata *conn)
|
||||||
{
|
{
|
||||||
|
#if defined(WIN32)
|
||||||
|
unsigned long nonblock = 0;
|
||||||
|
fd_set connectfd;
|
||||||
|
struct timeval conntimeout;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef ENABLE_IPV6
|
#ifndef ENABLE_IPV6
|
||||||
conn->firstsocket = socket(AF_INET, SOCK_STREAM, 0);
|
conn->firstsocket = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
@@ -1211,10 +1258,33 @@ static CURLcode ConnectPlease(struct UrlData *data,
|
|||||||
return CURLE_COULDNT_CONNECT;
|
return CURLE_COULDNT_CONNECT;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
/* non-zero nonblock value sets socket as nonblocking under Win32 */
|
||||||
|
#if defined(WIN32)
|
||||||
|
FD_ZERO (&connectfd);
|
||||||
|
FD_SET(conn->firstsocket, &connectfd);
|
||||||
|
if (conn->data->connecttimeout > 0) {
|
||||||
|
nonblock = 1;
|
||||||
|
}
|
||||||
|
ioctlsocket(conn->firstsocket, FIONBIO, &nonblock);
|
||||||
|
#endif
|
||||||
if (connect(conn->firstsocket,
|
if (connect(conn->firstsocket,
|
||||||
(struct sockaddr *) &(conn->serv_addr),
|
(struct sockaddr *) &(conn->serv_addr),
|
||||||
sizeof(conn->serv_addr)
|
sizeof(conn->serv_addr)
|
||||||
) < 0) {
|
) < 0) {
|
||||||
|
#if defined(WIN32)
|
||||||
|
conntimeout.tv_sec = conn->data->connecttimeout;
|
||||||
|
conntimeout.tv_usec = 0;
|
||||||
|
if(-1 != select (conn->firstsocket + 1, NULL, &connectfd, NULL, &conntimeout)) {
|
||||||
|
if (FD_ISSET(conn->firstsocket, &connectfd)) {
|
||||||
|
/* shut off non-blocking again */
|
||||||
|
nonblock = 0;
|
||||||
|
ioctlsocket(conn->firstsocket, FIONBIO, &nonblock);
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
errno = EINTR;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
switch(errno) {
|
switch(errno) {
|
||||||
#ifdef ECONNREFUSED
|
#ifdef ECONNREFUSED
|
||||||
/* this should be made nicer */
|
/* this should be made nicer */
|
||||||
@@ -1309,6 +1379,9 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
conn->secondarysocket = -1; /* no file descriptor */
|
conn->secondarysocket = -1; /* no file descriptor */
|
||||||
conn->connectindex = -1; /* no index */
|
conn->connectindex = -1; /* no index */
|
||||||
conn->bits.httpproxy = data->bits.httpproxy; /* proxy-or-not status */
|
conn->bits.httpproxy = data->bits.httpproxy; /* proxy-or-not status */
|
||||||
|
conn->bits.use_range = data->bits.set_range; /* range status */
|
||||||
|
conn->range = data->set_range; /* clone the range setting */
|
||||||
|
conn->resume_from = data->set_resume_from; /* inherite resume_from */
|
||||||
|
|
||||||
/* Default protocol-independent behavior doesn't support persistant
|
/* Default protocol-independent behavior doesn't support persistant
|
||||||
connections, so we set this to force-close. Protocols that support
|
connections, so we set this to force-close. Protocols that support
|
||||||
@@ -1319,6 +1392,9 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
conn->bits.user_passwd = data->userpwd?1:0;
|
conn->bits.user_passwd = data->userpwd?1:0;
|
||||||
conn->bits.proxy_user_passwd = data->proxyuserpwd?1:0;
|
conn->bits.proxy_user_passwd = data->proxyuserpwd?1:0;
|
||||||
|
|
||||||
|
/* maxdownload must be -1 on init, as 0 is a valid value! */
|
||||||
|
conn->maxdownload = -1; /* might have been used previously! */
|
||||||
|
|
||||||
/* Store creation time to help future close decision making */
|
/* Store creation time to help future close decision making */
|
||||||
conn->created = Curl_tvnow();
|
conn->created = Curl_tvnow();
|
||||||
|
|
||||||
@@ -1397,6 +1473,8 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
else if(strnequal(conn->gname, "HTTPS", 5))
|
else if(strnequal(conn->gname, "HTTPS", 5))
|
||||||
strcpy(conn->protostr, "https");
|
strcpy(conn->protostr, "https");
|
||||||
|
else if(strnequal(conn->gname, "FTPS", 4))
|
||||||
|
strcpy(conn->protostr, "ftps");
|
||||||
#endif /* USE_SSLEAY */
|
#endif /* USE_SSLEAY */
|
||||||
else if(strnequal(conn->gname, "TELNET", 6))
|
else if(strnequal(conn->gname, "TELNET", 6))
|
||||||
strcpy(conn->protostr, "telnet");
|
strcpy(conn->protostr, "telnet");
|
||||||
@@ -1499,6 +1577,7 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
* checked if the lowercase versions don't exist.
|
* checked if the lowercase versions don't exist.
|
||||||
*/
|
*/
|
||||||
char *no_proxy=NULL;
|
char *no_proxy=NULL;
|
||||||
|
char *no_proxy_tok_buf;
|
||||||
char *proxy=NULL;
|
char *proxy=NULL;
|
||||||
char proxy_env[128];
|
char proxy_env[128];
|
||||||
|
|
||||||
@@ -1510,7 +1589,7 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
/* NO_PROXY wasn't specified or it wasn't just an asterisk */
|
/* NO_PROXY wasn't specified or it wasn't just an asterisk */
|
||||||
char *nope;
|
char *nope;
|
||||||
|
|
||||||
nope=no_proxy?strtok(no_proxy, ", "):NULL;
|
nope=no_proxy?strtok_r(no_proxy, ", ", &no_proxy_tok_buf):NULL;
|
||||||
while(nope) {
|
while(nope) {
|
||||||
if(strlen(nope) <= strlen(conn->name)) {
|
if(strlen(nope) <= strlen(conn->name)) {
|
||||||
char *checkn=
|
char *checkn=
|
||||||
@@ -1520,7 +1599,7 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
nope=strtok(NULL, ", ");
|
nope=strtok_r(NULL, ", ", &no_proxy_tok_buf);
|
||||||
}
|
}
|
||||||
if(!nope) {
|
if(!nope) {
|
||||||
/* It was not listed as without proxy */
|
/* It was not listed as without proxy */
|
||||||
@@ -1538,7 +1617,19 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
/* read the protocol proxy: */
|
/* read the protocol proxy: */
|
||||||
prox=curl_getenv(proxy_env);
|
prox=curl_getenv(proxy_env);
|
||||||
|
|
||||||
if(!prox) {
|
/*
|
||||||
|
* We don't try the uppercase version of HTTP_PROXY because of
|
||||||
|
* security reasons:
|
||||||
|
*
|
||||||
|
* When curl is used in a webserver application
|
||||||
|
* environment (cgi or php), this environment variable can
|
||||||
|
* be controlled by the web server user by setting the
|
||||||
|
* http header 'Proxy:' to some value.
|
||||||
|
*
|
||||||
|
* This can cause 'internal' http/ftp requests to be
|
||||||
|
* arbitrarily redirected by any external attacker.
|
||||||
|
*/
|
||||||
|
if(!prox && !strequal("http_proxy", proxy_env)) {
|
||||||
/* There was no lowercase variable, try the uppercase version: */
|
/* There was no lowercase variable, try the uppercase version: */
|
||||||
for(envp = proxy_env; *envp; envp++)
|
for(envp = proxy_env; *envp; envp++)
|
||||||
*envp = toupper(*envp);
|
*envp = toupper(*envp);
|
||||||
@@ -1597,13 +1688,13 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
* server, we just fail since we can't rewind the file writing from within
|
* server, we just fail since we can't rewind the file writing from within
|
||||||
* this function.
|
* this function.
|
||||||
***********************************************************/
|
***********************************************************/
|
||||||
if(data->resume_from) {
|
if(conn->resume_from) {
|
||||||
if(!data->bits.set_range) {
|
if(!conn->bits.use_range) {
|
||||||
/* if it already was in use, we just skip this */
|
/* if it already was in use, we just skip this */
|
||||||
snprintf(resumerange, sizeof(resumerange), "%d-", data->resume_from);
|
snprintf(resumerange, sizeof(resumerange), "%d-", conn->resume_from);
|
||||||
data->range=strdup(resumerange); /* tell ourselves to fetch this range */
|
conn->range=strdup(resumerange); /* tell ourselves to fetch this range */
|
||||||
data->bits.rangestringalloc = TRUE; /* mark as allocated */
|
conn->bits.rangestringalloc = TRUE; /* mark as allocated */
|
||||||
data->bits.set_range = 1; /* switch on range usage */
|
conn->bits.use_range = 1; /* switch on range usage */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1666,8 +1757,19 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
conn->curl_done = Curl_http_done;
|
conn->curl_done = Curl_http_done;
|
||||||
conn->curl_close = Curl_http_close;
|
conn->curl_close = Curl_http_close;
|
||||||
}
|
}
|
||||||
else if(strequal(conn->protostr, "FTP")) {
|
else if(strequal(conn->protostr, "FTP") ||
|
||||||
|
strequal(conn->protostr, "FTPS")) {
|
||||||
char *type;
|
char *type;
|
||||||
|
|
||||||
|
if(strequal(conn->protostr, "FTPS")) {
|
||||||
|
#ifdef USE_SSLEAY
|
||||||
|
conn->protocol |= PROT_FTPS;
|
||||||
|
#else
|
||||||
|
failf(data, "libcurl was built with SSL disabled, ftps: not supported!");
|
||||||
|
return CURLE_UNSUPPORTED_PROTOCOL;
|
||||||
|
#endif /* !USE_SSLEAY */
|
||||||
|
}
|
||||||
|
|
||||||
conn->port = (data->use_port && allow_port)?data->use_port:PORT_FTP;
|
conn->port = (data->use_port && allow_port)?data->use_port:PORT_FTP;
|
||||||
conn->remote_port = PORT_FTP;
|
conn->remote_port = PORT_FTP;
|
||||||
conn->protocol |= PROT_FTP;
|
conn->protocol |= PROT_FTP;
|
||||||
@@ -1676,6 +1778,12 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
!data->bits.tunnel_thru_httpproxy) {
|
!data->bits.tunnel_thru_httpproxy) {
|
||||||
/* Unless we have asked to tunnel ftp operations through the proxy, we
|
/* Unless we have asked to tunnel ftp operations through the proxy, we
|
||||||
switch and use HTTP operations only */
|
switch and use HTTP operations only */
|
||||||
|
if(conn->protocol & PROT_FTPS) {
|
||||||
|
/* FTPS is a hacked protocol and does not work through your
|
||||||
|
ordinary http proxy! */
|
||||||
|
failf(data, "ftps does not work through http proxy!");
|
||||||
|
return CURLE_UNSUPPORTED_PROTOCOL;
|
||||||
|
}
|
||||||
conn->curl_do = Curl_http;
|
conn->curl_do = Curl_http;
|
||||||
conn->curl_done = Curl_http_done;
|
conn->curl_done = Curl_http_done;
|
||||||
conn->curl_close = Curl_http_close;
|
conn->curl_close = Curl_http_close;
|
||||||
@@ -1940,24 +2048,52 @@ static CURLcode Connect(struct UrlData *data,
|
|||||||
*/
|
*/
|
||||||
struct connectdata *old_conn = conn;
|
struct connectdata *old_conn = conn;
|
||||||
char *path = old_conn->path; /* setup the current path pointer properly */
|
char *path = old_conn->path; /* setup the current path pointer properly */
|
||||||
|
char *ppath = old_conn->ppath; /* this is the modified path pointer */
|
||||||
if(old_conn->proxyhost)
|
if(old_conn->proxyhost)
|
||||||
free(old_conn->proxyhost);
|
free(old_conn->proxyhost);
|
||||||
conn = conn_temp; /* use this connection from now on */
|
conn = conn_temp; /* use this connection from now on */
|
||||||
free(conn->path); /* free the previous path pointer */
|
|
||||||
|
|
||||||
/* we need these pointers if we speak over a proxy */
|
/* we need these pointers if we speak over a proxy */
|
||||||
conn->name = old_conn->name;
|
conn->name = conn->gname;
|
||||||
conn->hostname = old_conn->hostname;
|
conn->hostname = old_conn->gname;
|
||||||
|
|
||||||
conn->path = path; /* use this one */
|
free(conn->path); /* free the previously allocated path pointer */
|
||||||
conn->ppath = path; /* set this too */
|
|
||||||
|
/* 'path' points to the allocated data, 'ppath' may have been advanced
|
||||||
|
to point somewhere within the 'path' area. */
|
||||||
|
conn->path = path;
|
||||||
|
conn->ppath = ppath;
|
||||||
|
|
||||||
/* re-use init */
|
/* re-use init */
|
||||||
conn->maxdownload = 0; /* might have been used previously! */
|
|
||||||
conn->bits.reuse = TRUE; /* yes, we're re-using here */
|
conn->bits.reuse = TRUE; /* yes, we're re-using here */
|
||||||
|
conn->bits.chunk = FALSE; /* always assume not chunked unless told
|
||||||
|
otherwise */
|
||||||
|
conn->maxdownload = -1; /* might have been used previously! */
|
||||||
|
|
||||||
free(old_conn); /* we don't need this anymore */
|
free(old_conn); /* we don't need this anymore */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we're doing a resumed transfer, we need to setup our stuff
|
||||||
|
* properly.
|
||||||
|
*/
|
||||||
|
conn->resume_from = data->set_resume_from;
|
||||||
|
if (conn->resume_from) {
|
||||||
|
snprintf(resumerange, sizeof(resumerange), "%d-", conn->resume_from);
|
||||||
|
if (conn->bits.rangestringalloc == TRUE)
|
||||||
|
free(conn->range);
|
||||||
|
|
||||||
|
/* tell ourselves to fetch this range */
|
||||||
|
conn->range = strdup(resumerange);
|
||||||
|
conn->bits.use_range = TRUE; /* enable range download */
|
||||||
|
conn->bits.rangestringalloc = TRUE; /* mark range string allocated */
|
||||||
|
}
|
||||||
|
else if (data->set_range) {
|
||||||
|
/* There is a range, but is not a resume, useful for random ftp access */
|
||||||
|
conn->range = strdup(data->set_range);
|
||||||
|
conn->bits.rangestringalloc = TRUE; /* mark range string allocated */
|
||||||
|
conn->bits.use_range = TRUE; /* enable range download */
|
||||||
|
}
|
||||||
|
|
||||||
*in_connect = conn; /* return this instead! */
|
*in_connect = conn; /* return this instead! */
|
||||||
|
|
||||||
infof(data, "Re-using existing connection! (#%d)\n", conn->connectindex);
|
infof(data, "Re-using existing connection! (#%d)\n", conn->connectindex);
|
||||||
@@ -2126,8 +2262,10 @@ CURLcode Curl_connect(struct UrlData *data,
|
|||||||
/* We're not allowed to return failure with memory left allocated
|
/* We're not allowed to return failure with memory left allocated
|
||||||
in the connectdata struct, free those here */
|
in the connectdata struct, free those here */
|
||||||
conn = (struct connectdata *)*in_connect;
|
conn = (struct connectdata *)*in_connect;
|
||||||
if(conn)
|
if(conn) {
|
||||||
Curl_disconnect(conn); /* close the connection */
|
Curl_disconnect(conn); /* close the connection */
|
||||||
|
*in_connect = NULL; /* return a NULL */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
@@ -2138,13 +2276,26 @@ CURLcode Curl_done(struct connectdata *conn)
|
|||||||
struct UrlData *data=conn->data;
|
struct UrlData *data=conn->data;
|
||||||
CURLcode result;
|
CURLcode result;
|
||||||
|
|
||||||
|
/* cleanups done even if the connection is re-used */
|
||||||
|
|
||||||
|
if(conn->bits.rangestringalloc) {
|
||||||
|
free(conn->range);
|
||||||
|
conn->bits.rangestringalloc = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Cleanup possible redirect junk */
|
||||||
|
if(conn->newurl) {
|
||||||
|
free(conn->newurl);
|
||||||
|
conn->newurl = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* this calls the protocol-specific function pointer previously set */
|
/* this calls the protocol-specific function pointer previously set */
|
||||||
if(conn->curl_done)
|
if(conn->curl_done)
|
||||||
result = conn->curl_done(conn);
|
result = conn->curl_done(conn);
|
||||||
else
|
else
|
||||||
result = CURLE_OK;
|
result = CURLE_OK;
|
||||||
|
|
||||||
Curl_pgrsDone(data); /* done with the operation */
|
Curl_pgrsDone(conn); /* done with the operation */
|
||||||
|
|
||||||
/* if data->bits.reuse_forbid is TRUE, it means the libcurl client has
|
/* if data->bits.reuse_forbid is TRUE, it means the libcurl client has
|
||||||
forced us to close this no matter what we think.
|
forced us to close this no matter what we think.
|
||||||
|
@@ -148,7 +148,7 @@ struct HTTP {
|
|||||||
|
|
||||||
/* For FORM posting */
|
/* For FORM posting */
|
||||||
struct Form form;
|
struct Form form;
|
||||||
size_t (*storefread)(char *, size_t , size_t , FILE *);
|
curl_read_callback storefread;
|
||||||
FILE *in;
|
FILE *in;
|
||||||
|
|
||||||
struct Curl_chunker chunk;
|
struct Curl_chunker chunk;
|
||||||
@@ -185,6 +185,12 @@ struct ConnectBits {
|
|||||||
bool httpproxy; /* if set, this transfer is done through a http proxy */
|
bool httpproxy; /* if set, this transfer is done through a http proxy */
|
||||||
bool user_passwd; /* do we use user+password for this connection? */
|
bool user_passwd; /* do we use user+password for this connection? */
|
||||||
bool proxy_user_passwd; /* user+password for the proxy? */
|
bool proxy_user_passwd; /* user+password for the proxy? */
|
||||||
|
|
||||||
|
bool use_range;
|
||||||
|
bool rangestringalloc; /* the range string is malloc()'ed */
|
||||||
|
|
||||||
|
bool resume_done; /* nothing was transfered, resumed transfer already
|
||||||
|
complete */
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -207,6 +213,7 @@ struct connectdata {
|
|||||||
#define PROT_DICT (1<<6)
|
#define PROT_DICT (1<<6)
|
||||||
#define PROT_LDAP (1<<7)
|
#define PROT_LDAP (1<<7)
|
||||||
#define PROT_FILE (1<<8)
|
#define PROT_FILE (1<<8)
|
||||||
|
#define PROT_FTPS (1<<9)
|
||||||
|
|
||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
struct addrinfo *hp; /* host info pointer list */
|
struct addrinfo *hp; /* host info pointer list */
|
||||||
@@ -227,6 +234,10 @@ struct connectdata {
|
|||||||
char *ppath;
|
char *ppath;
|
||||||
long bytecount;
|
long bytecount;
|
||||||
|
|
||||||
|
char *range; /* range, if used. See README for detailed specification on
|
||||||
|
this syntax. */
|
||||||
|
int resume_from; /* continue [ftp] transfer from here */
|
||||||
|
|
||||||
char *proxyhost; /* name of the http proxy host */
|
char *proxyhost; /* name of the http proxy host */
|
||||||
|
|
||||||
struct timeval now; /* "current" time */
|
struct timeval now; /* "current" time */
|
||||||
@@ -293,7 +304,6 @@ struct connectdata {
|
|||||||
document headers */
|
document headers */
|
||||||
|
|
||||||
#ifdef KRB4
|
#ifdef KRB4
|
||||||
|
|
||||||
enum protection_level command_prot;
|
enum protection_level command_prot;
|
||||||
enum protection_level data_prot;
|
enum protection_level data_prot;
|
||||||
enum protection_level request_data_prot;
|
enum protection_level request_data_prot;
|
||||||
@@ -372,12 +382,6 @@ typedef enum {
|
|||||||
/* This struct is for boolean settings that define how to behave during
|
/* This struct is for boolean settings that define how to behave during
|
||||||
this session. */
|
this session. */
|
||||||
struct Configbits {
|
struct Configbits {
|
||||||
/* these four request types mirror the httpreq field */
|
|
||||||
bool http_formpost;
|
|
||||||
bool http_post;
|
|
||||||
bool http_put;
|
|
||||||
bool http_get;
|
|
||||||
|
|
||||||
bool get_filetime;
|
bool get_filetime;
|
||||||
bool tunnel_thru_httpproxy;
|
bool tunnel_thru_httpproxy;
|
||||||
bool ftp_append;
|
bool ftp_append;
|
||||||
@@ -391,7 +395,6 @@ struct Configbits {
|
|||||||
bool http_set_referer;
|
bool http_set_referer;
|
||||||
bool http_auto_referer; /* set "correct" referer when following location: */
|
bool http_auto_referer; /* set "correct" referer when following location: */
|
||||||
bool httpproxy;
|
bool httpproxy;
|
||||||
bool mute;
|
|
||||||
bool no_body;
|
bool no_body;
|
||||||
bool set_port;
|
bool set_port;
|
||||||
bool set_range;
|
bool set_range;
|
||||||
@@ -401,7 +404,6 @@ struct Configbits {
|
|||||||
bool this_is_a_follow; /* this is a followed Location: request */
|
bool this_is_a_follow; /* this is a followed Location: request */
|
||||||
bool krb4; /* kerberos4 connection requested */
|
bool krb4; /* kerberos4 connection requested */
|
||||||
bool proxystringalloc; /* the http proxy string is malloc()'ed */
|
bool proxystringalloc; /* the http proxy string is malloc()'ed */
|
||||||
bool rangestringalloc; /* the range string is malloc()'ed */
|
|
||||||
bool urlstringalloc; /* the URL string is malloc()'ed */
|
bool urlstringalloc; /* the URL string is malloc()'ed */
|
||||||
bool reuse_forbid; /* if this is forbidden to be reused, close
|
bool reuse_forbid; /* if this is forbidden to be reused, close
|
||||||
after use */
|
after use */
|
||||||
@@ -450,9 +452,10 @@ struct UrlData {
|
|||||||
long header_size; /* size of read header(s) in bytes */
|
long header_size; /* size of read header(s) in bytes */
|
||||||
long request_size; /* the amount of bytes sent in the request(s) */
|
long request_size; /* the amount of bytes sent in the request(s) */
|
||||||
|
|
||||||
FILE *out; /* the fetched file goes here */
|
void *out; /* the fetched file goes here */
|
||||||
FILE *in; /* the uploaded file is read from here */
|
void *in; /* the uploaded file is read from here */
|
||||||
FILE *writeheader; /* write the header to this is non-NULL */
|
void *writeheader; /* write the header to this is non-NULL */
|
||||||
|
|
||||||
char *url; /* what to get */
|
char *url; /* what to get */
|
||||||
char *freethis; /* if non-NULL, an allocated string for the URL */
|
char *freethis; /* if non-NULL, an allocated string for the URL */
|
||||||
long use_port; /* which port to use (when not using default) */
|
long use_port; /* which port to use (when not using default) */
|
||||||
@@ -460,7 +463,7 @@ struct UrlData {
|
|||||||
struct ssl_config_data ssl; /* this is for ssl-stuff */
|
struct ssl_config_data ssl; /* this is for ssl-stuff */
|
||||||
|
|
||||||
char *userpwd; /* <user:password>, if used */
|
char *userpwd; /* <user:password>, if used */
|
||||||
char *range; /* range, if used. See README for detailed specification on
|
char *set_range; /* range, if used. See README for detailed specification on
|
||||||
this syntax. */
|
this syntax. */
|
||||||
|
|
||||||
/* stuff related to HTTP */
|
/* stuff related to HTTP */
|
||||||
@@ -485,6 +488,9 @@ struct UrlData {
|
|||||||
/* function that stores the output:*/
|
/* function that stores the output:*/
|
||||||
curl_write_callback fwrite;
|
curl_write_callback fwrite;
|
||||||
|
|
||||||
|
/* optional function that stores the header output:*/
|
||||||
|
curl_write_callback fwrite_header;
|
||||||
|
|
||||||
/* function that reads the input:*/
|
/* function that reads the input:*/
|
||||||
curl_read_callback fread;
|
curl_read_callback fread;
|
||||||
|
|
||||||
@@ -507,7 +513,7 @@ struct UrlData {
|
|||||||
long low_speed_limit; /* bytes/second */
|
long low_speed_limit; /* bytes/second */
|
||||||
long low_speed_time; /* number of seconds */
|
long low_speed_time; /* number of seconds */
|
||||||
|
|
||||||
int resume_from; /* continue [ftp] transfer from here */
|
int set_resume_from; /* continue [ftp] transfer from here */
|
||||||
|
|
||||||
char *cookie; /* HTTP cookie string to send */
|
char *cookie; /* HTTP cookie string to send */
|
||||||
|
|
||||||
@@ -553,10 +559,6 @@ struct UrlData {
|
|||||||
char proxypasswd[MAX_CURL_PASSWORD_LENGTH];
|
char proxypasswd[MAX_CURL_PASSWORD_LENGTH];
|
||||||
|
|
||||||
char *krb4_level; /* what security level */
|
char *krb4_level; /* what security level */
|
||||||
#ifdef KRB4
|
|
||||||
FILE *cmdchannel;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct timeval keeps_speed; /* this should be request-specific */
|
struct timeval keeps_speed; /* this should be request-specific */
|
||||||
|
|
||||||
/* 'connects' will be an allocated array with pointers. If the pointer is
|
/* 'connects' will be an allocated array with pointers. If the pointer is
|
||||||
|
@@ -38,6 +38,24 @@ char *curl_version(void)
|
|||||||
|
|
||||||
#ifdef USE_SSLEAY
|
#ifdef USE_SSLEAY
|
||||||
|
|
||||||
|
#if (SSLEAY_VERSION_NUMBER >= 0x906000)
|
||||||
|
{
|
||||||
|
char sub[2];
|
||||||
|
sub[1]='\0';
|
||||||
|
if(SSLEAY_VERSION_NUMBER&0xff0) {
|
||||||
|
sub[0]=((SSLEAY_VERSION_NUMBER>>4)&0xff) + 'a' -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
sub[0]='\0';
|
||||||
|
|
||||||
|
sprintf(ptr, " (OpenSSL %lx.%lx.%lx%s)",
|
||||||
|
(SSLEAY_VERSION_NUMBER>>28)&0xf,
|
||||||
|
(SSLEAY_VERSION_NUMBER>>20)&0xff,
|
||||||
|
(SSLEAY_VERSION_NUMBER>>12)&0xff,
|
||||||
|
sub);
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
#if (SSLEAY_VERSION_NUMBER >= 0x900000)
|
#if (SSLEAY_VERSION_NUMBER >= 0x900000)
|
||||||
sprintf(ptr, " (SSL %lx.%lx.%lx)",
|
sprintf(ptr, " (SSL %lx.%lx.%lx)",
|
||||||
(SSLEAY_VERSION_NUMBER>>28)&0xff,
|
(SSLEAY_VERSION_NUMBER>>28)&0xff,
|
||||||
@@ -46,17 +64,19 @@ char *curl_version(void)
|
|||||||
#else
|
#else
|
||||||
{
|
{
|
||||||
char sub[2];
|
char sub[2];
|
||||||
|
sub[1]='\0';
|
||||||
if(SSLEAY_VERSION_NUMBER&0x0f) {
|
if(SSLEAY_VERSION_NUMBER&0x0f) {
|
||||||
sub[0]=(SSLEAY_VERSION_NUMBER&0x0f) + 'a' -1;
|
sub[0]=(SSLEAY_VERSION_NUMBER&0x0f) + 'a' -1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
sub[0]=0;
|
sub[0]='\0';
|
||||||
|
|
||||||
sprintf(ptr, " (SSL %x.%x.%x%s)",
|
sprintf(ptr, " (SSL %x.%x.%x%s)",
|
||||||
(SSLEAY_VERSION_NUMBER>>12)&0xff,
|
(SSLEAY_VERSION_NUMBER>>12)&0xff,
|
||||||
(SSLEAY_VERSION_NUMBER>>8)&0xf,
|
(SSLEAY_VERSION_NUMBER>>8)&0xf,
|
||||||
(SSLEAY_VERSION_NUMBER>>4)&0xf, sub);
|
(SSLEAY_VERSION_NUMBER>>4)&0xf, sub);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
ptr=strchr(ptr, '\0');
|
ptr=strchr(ptr, '\0');
|
||||||
#endif
|
#endif
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user