Compare commits

..

448 Commits

Author SHA1 Message Date
Daniel Stenberg
4f0258ec09 7.12.2 2004-10-18 07:48:28 +00:00
Daniel Stenberg
db4d0d307a new mirror 2004-10-17 07:48:00 +00:00
Daniel Stenberg
2baf22e184 today's changes 2004-10-16 14:07:31 +00:00
Daniel Stenberg
21d5aead47 Alexander Krasnostavsky made the CURLOPT_FTP_CREATE_MISSING_DIRS option work
fine even for third party transfers.
2004-10-16 14:06:54 +00:00
Daniel Stenberg
f40c9b83df libcurl leaked memory for cookies with the "max-age" field set. 2004-10-16 13:54:40 +00:00
Gisle Vanem
b9e082b811 Changes for issue 50 2004-10-16 13:20:33 +00:00
Gisle Vanem
0bfa601a9f Open "debugit" in binary mode ("rb"). 2004-10-16 13:17:15 +00:00
Gisle Vanem
e356420123 Added Traian Nicolescu's patches for threaded resolver on
Windows. Plugged some potential handle and memory leaks.

Refs.
  http://curl.haxx.se/mail/lib-2004-10/0134.html
  http://curl.haxx.se/mail/lib-2004-10/0157.html
2004-10-16 12:59:05 +00:00
Daniel Stenberg
e8f85cba0f Eric Vergnaud pointed out that libcurl didn't treat ?-letters in the user name
and password fields properly in URLs, like
ftp://us?er:pass?word@site.com/. Added test 191 to verify the fix.
2004-10-14 13:44:54 +00:00
Daniel Stenberg
1aba99b1e7 use quotes to make gdb usage on this easier 2004-10-14 13:44:16 +00:00
Daniel Stenberg
12815d7cd6 let's fix this too 2004-10-14 13:34:42 +00:00
Gisle Vanem
9deb76ce3e Set errno = ENOMEM on faild countcheck(). 2004-10-13 19:11:46 +00:00
Daniel Stenberg
c98676068e .NET binding 2004-10-13 08:46:36 +00:00
Daniel Stenberg
b534f74bf4 correction 2004-10-12 18:20:36 +00:00
Daniel Stenberg
411e9b0c45 #include "strerror.h" to get the strerror proto 2004-10-12 12:49:38 +00:00
Daniel Stenberg
3fa1879f6a recent fixes 2004-10-12 12:47:38 +00:00
Daniel Stenberg
d30cf22c12 one item fixed, one added for 7.12.2 and two more for 7.12.3 2004-10-12 12:47:31 +00:00
Daniel Stenberg
557b6cfd3f add proper error message when send() fails 2004-10-12 07:24:19 +00:00
Daniel Stenberg
84bf03b365 removed trailing whitespace 2004-10-11 17:26:24 +00:00
Daniel Stenberg
34342bcd19 SO_NOSIGPIPE 2004-10-11 17:23:41 +00:00
Daniel Stenberg
5322a86313 another lame attempt to avoid the "warning: will never be executed" warning
by gcc 3.4
2004-10-10 14:36:22 +00:00
Gisle Vanem
1dc50e21c4 MSVC uses 'i64' suffix for 64-bit sizes. 2004-10-10 14:08:05 +00:00
Daniel Stenberg
1eddbb1b47 attempt to make the configure output appear in the build log when it runs
on my solaris 2.7 box too (currently unknown perl version)
2004-10-10 07:51:25 +00:00
Daniel Stenberg
bb8591cf54 set the SIZEOF_LONG define to get the new lib/strtoofft.h fine 2004-10-10 07:45:41 +00:00
Daniel Stenberg
a7913a62a9 If long is 8 bytes we can use strtol() to get 64 bit numbers and won't need
our strtoll() replacement function.
2004-10-10 03:39:59 +00:00
Daniel Stenberg
6d1b37b3da Prevent a longjmp warning by moving the rc assign within Curl_resolv().
Andy Cedilnik reported. Warning on HP-UX?
2004-10-10 03:32:01 +00:00
Daniel Stenberg
34750cc738 Use LL suffix for long long constants if the compiler supports it, to prevent
warnings.
2004-10-10 03:28:51 +00:00
Daniel Stenberg
af677c4e1d If long long is supported, check if [num]LL is supported for numerical
constants.
2004-10-10 03:22:45 +00:00
Daniel Stenberg
298076e00f --enable-ares on AIX has problem 2004-10-08 12:59:36 +00:00
Daniel Stenberg
0d2cdd9773 Use 'struct lifreq' and SIOCGLIFADDR 2004-10-08 09:57:33 +00:00
Daniel Stenberg
eb5d3b5a7c killed trailing whitespace 2004-10-08 09:39:37 +00:00
Daniel Stenberg
7663775971 if basename was found, check for a prototype and if none was found, provide
our own in the formdata.c file to prevent warnings on systems without it
2004-10-08 08:18:08 +00:00
Daniel Stenberg
fe46572f2b prevent warning with comparison between signed and unsigned 2004-10-08 08:16:02 +00:00
Daniel Stenberg
a6d4d3eeac use curlx_strnequal() from the private lib sources instead of strncasecmp()
for maximum portability
2004-10-07 22:57:24 +00:00
Daniel Stenberg
62f97f1817 use curl_strnequal(), not strncasecmp() 2004-10-07 22:56:24 +00:00
Daniel Stenberg
253ff7b2ad Gisle's new fix, the old file:// leak 2004-10-07 12:17:53 +00:00
Daniel Stenberg
c274e51654 use tld_strerror() only if previously detected, since otherwise we can't
work with libidn < 0.5.6
2004-10-07 07:41:44 +00:00
Daniel Stenberg
1239e48304 check for tld_strerror 2004-10-07 07:41:14 +00:00
Gisle Vanem
52313cbac9 Added tld_check_name(). 2004-10-06 19:00:37 +00:00
Gisle Vanem
071218a201 Fixed tld_check_name(). idna_to_unicode_lzlz() should never fail,
but return FALSE if 'uc_name == NULL' just in case.
2004-10-06 18:55:58 +00:00
Gisle Vanem
f0d6cc23ae USE_LIBIDN: Added Top-level-domain (TLD) check for host->name.
Only print a warning if check fails.
2004-10-06 18:40:10 +00:00
Daniel Stenberg
ceefe2e248 test resume and redirect 2004-10-06 14:58:07 +00:00
Daniel Stenberg
9a2aed7d7a Chih-Chung Chang reported that if you use CURLOPT_RESUME_FROM and enabled
CURLOPT_FOLLOWLOCATION, libcurl reported error if a redirect happened even if
the new URL would provide the resumed file. Test case 188 added to verify the
fix (together with existing test 99).
2004-10-06 13:37:12 +00:00
Gisle Vanem
a91a75355d *** empty log message *** 2004-10-06 13:24:08 +00:00
Daniel Stenberg
01acbfa1a5 updates of today 2004-10-06 09:04:20 +00:00
Daniel Stenberg
49b2896a3b avoid warnings on systems with this member set const 2004-10-06 07:52:20 +00:00
Daniel Stenberg
39af394a1c removed tabs and trailing whitespace from source 2004-10-06 07:50:18 +00:00
Daniel Stenberg
5c7dcc6c33 Dan Fandrich fix for hosts that need both -lnsl and -lsocket 2004-10-06 07:33:03 +00:00
Daniel Stenberg
6c5ea2af27 untabify 2004-10-06 06:58:42 +00:00
Gisle Vanem
93e084e097 djgpp has basename() 2004-10-05 13:48:50 +00:00
Daniel Stenberg
1a61bcecfc minor edit to re-use a variable and to hopefully avoid a (moot) warning
about code that won't be reached
2004-10-05 11:03:59 +00:00
Daniel Stenberg
3d9fb701e2 recent fixes 2004-10-05 10:52:51 +00:00
Daniel Stenberg
19a568a983 make the given path to --with-libidn override any other installation 2004-10-05 08:45:13 +00:00
Daniel Stenberg
70c3f6a8dd avoid warning for unused variable 2004-10-05 08:42:56 +00:00
Daniel Stenberg
bb999d8213 use idna_strerror() if it is available (only in libidn 0.5.6 or later) 2004-10-05 08:40:26 +00:00
Daniel Stenberg
121197bc87 Only include libgen.h if we have a basename as well.
Mainly meant to deal with the IRIX case which seems to requrie a "-lgen" lib
to find the basename function and thus without the gen lib, it finds the
header but not the function and our replacement function has a prototype
that doesn't match the IRIX one.

A different approach would be to make configure detect and use -lgen for the
systems that require it.
2004-10-05 06:55:09 +00:00
Daniel Stenberg
d5dd8e0fdc let our basename() be static 2004-10-05 06:49:09 +00:00
Daniel Stenberg
c368800877 name mix fix 2004-10-04 12:54:58 +00:00
Daniel Stenberg
6eb58549a9 closing in on release 2004-10-04 10:37:30 +00:00
Daniel Stenberg
95def48071 Made the dns entry remain locked while a connection to the host remains to
allow verbose output during this period. Bertrand Demiddelaer reported and
helped fixing.
2004-10-04 10:36:51 +00:00
Daniel Stenberg
2ee6c33412 set async.done to TRUE last in the addrinfo callback to prevent the risk that
the multi-threaded resolver does wrong
2004-10-03 21:32:24 +00:00
Daniel Stenberg
be7ce435c0 Replaced the use of isspace() with our own version instead since we have most
data as 'char *' and that makes us pass in negative values if there is 8bit
data in the string. Changing to unsigned causes too much warnings or too many
required typecasts to the normal string functions.
2004-10-03 21:02:01 +00:00
Daniel Stenberg
f4252f8672 when building with libidn support, check for idna_strerror() which is
included in very recent versions
2004-10-03 20:50:47 +00:00
Daniel Stenberg
f4f961c4ea added info about how users get info (like the CURLcode return code) from
individual transfers
2004-10-03 17:38:57 +00:00
Daniel Stenberg
e2fe03df8e removed trailing whitespace 2004-10-03 08:15:40 +00:00
Daniel Stenberg
19b284c214 Gisle Vanem provided code that displays an error message when the (libidn
based) IDN conversion fails. This is really due to a missing suitable
function in the libidn API that I hope we can remove once libidn gets a
function like this.
2004-10-02 13:01:44 +00:00
Daniel Stenberg
6b3e3095ea removed weird preprocessor juggling not needed 2004-10-02 12:58:27 +00:00
Daniel Stenberg
fd2aad1d9b someone should hit me 2004-10-01 11:27:14 +00:00
Daniel Stenberg
d239fc5d04 Aleksandar Milivojevic reported a problem in the Redhat bugzilla (see
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=134133) and not to anyone
involved in the curl project! This happens when you try to curl a file from a
proftpd site using SSL. It seems proftpd sends a somewhat unorthodox PASS
response code (232 instead of 230). I relaxed the response code check to deal
with this and similar cases.
2004-10-01 11:22:11 +00:00
Daniel Stenberg
ec4da97a35 fixed the basename() replacement, reported by Gisle 2004-10-01 11:20:38 +00:00
Daniel Stenberg
bb48ccedd7 mention when this option was added 2004-10-01 06:43:48 +00:00
Daniel Stenberg
afc0dfb141 reflect the last few changes 2004-10-01 06:43:37 +00:00
Daniel Stenberg
8e87223195 - Based on Fedor Karpelevitch's formpost path basename patch, file parts in
formposts no longer include the path part. If you _really_ want them, you
  must provide your preferred full file name with CURLFORM_FILENAME.

  Added detection for libgen.h and basename() to configure. My custom
  basename() replacement function for systems without it, might be a bit too
  naive...

  Updated 6 test cases to make them work with the stripped paths.
2004-10-01 06:36:11 +00:00
Daniel Stenberg
be1cece69b - Larry Campbell added CURLINFO_OS_ERRNO to curl_easy_getinfo() that allows an
app to retrieve the errno variable after a (connect) failure. It will make
  sense to provide this for more failures in a more generic way, but let's
  start like this.
2004-09-30 21:01:23 +00:00
Daniel Stenberg
45be6d6645 killed trailing whitespace 2004-09-30 20:50:34 +00:00
Daniel Stenberg
d4db35c125 Gnter Knauf and Casey O'Donnell worked out an extra #if condition for the
curl/multi.h header to work better in winsock-using apps.
2004-09-30 19:50:36 +00:00
Daniel Stenberg
94c6a5eeab Jean-Philippe Barrette-LaPierre made buildconf run better on Mac OS X by
properly using glibtoolize instead of plain libtoolize. (This is made if
glibtool was found and used instead of plain libtool.)
2004-09-30 19:46:32 +00:00
Daniel Stenberg
35292e794a --max-redirs is _not_ -Z 2004-09-30 14:38:29 +00:00
Daniel Stenberg
c2043a7f94 48 - Harshal Pradhan's isspace() fix for 8bit cookie content 2004-09-30 12:20:04 +00:00
Daniel Stenberg
e752588e8d issue 47 - Peter Sylvester's patch related to the new SRP on the TLS layer 2004-09-30 11:41:25 +00:00
Daniel Stenberg
8f30dbd4f0 fix the multi.h too 2004-09-30 11:38:46 +00:00
Daniel Stenberg
29eb80dbd1 added issue 45 "Chris' suspected race condition in the windows threaded
resolver"
2004-09-30 08:01:47 +00:00
Daniel Stenberg
6cf6f9a21e added five things I want fixed before the next release 2004-09-30 07:59:17 +00:00
Daniel Stenberg
6af6a2bbe8 Fixed an error message: we use CWD, we don't cd into dirs with FTP 2004-09-29 07:21:23 +00:00
Daniel Stenberg
2576ac1c76 Bertrand Demiddelaer fixed curl_easy_reset() so that it doesn't mistakingly
enable the progress meter.
2004-09-28 22:26:47 +00:00
Daniel Stenberg
bfeea8e6b7 - Henrik Stoerner fix: got a report that Tru64 Unix (the unix from Digital
when they made Alpha's) uses /etc/svc.conf for the purpose fixed below for
  other OSes. He made c-ares check for and understand it if present.

- Now c-ares will use local host name lookup _before_ DNS resolving by default
  if nothing else is told.
2004-09-28 22:19:39 +00:00
Daniel Stenberg
2f89f2311c recent stuff 2004-09-28 22:04:17 +00:00
Daniel Stenberg
75e5967afd made pkg-config not get used if a path is given with --with-ssl 2004-09-28 22:04:05 +00:00
Daniel Stenberg
1003628103 Only active the engine code if ssl is enabled. This is how the actual engine
member in the struct is used.
2004-09-28 07:11:32 +00:00
Daniel Stenberg
3451e888b9 - Henrik Stoerner: found out that C-ARES does not look at the /etc/host.conf
file to determine the sequence in which to search /etc/hosts and DNS.  So on
  systems where this order is defined by /etc/host.conf instead of a "lookup"
  entry in /etc/resolv.conf, C-ARES will always default to looking in DNS
  first, and /etc/hosts second.

  c-ares now looks at

  1) resolv.conf (for the "lookup" line);
  2) nsswitch.fon (for the "hosts:" line);
  3) host.conf (for the "order" line).

  First match wins.
2004-09-26 22:35:18 +00:00
Daniel Stenberg
12dc142a28 Dominick Meglio host file path discovery patch for windows 2004-09-26 18:20:58 +00:00
Daniel Stenberg
cb80670885 Ben Greear's minor fix to build (better) with cross-compiled(?) mingw 2004-09-26 06:53:53 +00:00
Daniel Stenberg
c189687188 allow setting CURLOPT_SSLENGINE to NULL even if no SSL engine is supported 2004-09-25 21:28:26 +00:00
Daniel Stenberg
595016d393 Dan Fandrich patched three tests 2004-09-22 18:23:14 +00:00
Daniel Stenberg
23550fe5de Dan Fandrich's fix to use 127.0.0.1 instead of localhost to not depend on
it resolving nicely
2004-09-22 18:21:45 +00:00
Daniel Stenberg
8420de971f Jean-Claude Chauve is a friend! 2004-09-22 12:54:41 +00:00
Daniel Stenberg
17f8f32b2e typo 2004-09-22 12:53:58 +00:00
Daniel Stenberg
7676f40218 jean-claude Chauve fixed an LDAP bug 2004-09-22 08:01:41 +00:00
Daniel Stenberg
2de62cb06f less long => int implicit conversion warnings 2004-09-20 13:21:48 +00:00
Gunter Knauf
be1df3ca0a removed getdate.c hack. 2004-09-19 23:30:34 +00:00
Daniel Stenberg
543ab6f331 added URL to the exception paragraph in the GPL FAQ 2004-09-19 22:37:26 +00:00
Daniel Stenberg
2b6f7ef2a9 the error message fix for failed connects 2004-09-19 14:30:16 +00:00
Daniel Stenberg
0d37f8564e kill trailing whitespace and clarify a few errors 2004-09-19 14:28:16 +00:00
Daniel Stenberg
6cd2536048 set an error message when connection fails 2004-09-19 14:27:56 +00:00
Daniel Stenberg
60fccf4e37 Location:-follow problem 2004-09-17 07:55:14 +00:00
Daniel Stenberg
8a8028394f one more option, one more friend 2004-09-16 22:10:15 +00:00
Daniel Stenberg
6a06667cc0 Added CURLOPT_FTPSSLAUTH 2004-09-16 21:45:16 +00:00
Daniel Stenberg
25bf23105d Location: problem with bad original URL, identified in bug report #1029478 2004-09-16 21:28:38 +00:00
Daniel Stenberg
2544c78083 Bertrand Demiddelaer's correction 2004-09-16 14:26:04 +00:00
Daniel Stenberg
40b9b6f6dc ftp-ssl mistake corrected 2004-09-16 08:45:11 +00:00
Daniel Stenberg
f5e1beddf1 no more getdate.c to care about 2004-09-15 08:07:20 +00:00
Daniel Stenberg
d4076c9a8a fixed to use the new file. Can we make this use Makefile.inc somehow? 2004-09-15 08:05:53 +00:00
Daniel Stenberg
106695d45e the new date parser affects -z 2004-09-15 07:31:48 +00:00
Daniel Stenberg
f71b3f48a1 Replaced the former date parser with a rewrite. No more yacc/bison needed. 2004-09-15 07:28:04 +00:00
Daniel Stenberg
aa8dd932c1 ignore more 2004-09-14 21:31:06 +00:00
Daniel Stenberg
adbe3eefb6 and moved back the month array to a static one since the ftp code won't need
it anymore
2004-09-13 20:49:27 +00:00
Daniel Stenberg
33f69c0546 removed this file again, we only provide a single public function and that
is already in the public header file
2004-09-13 20:48:24 +00:00
Daniel Stenberg
6c3a87a599 no longer includes getdate.h, there's no need for it 2004-09-13 20:47:31 +00:00
Daniel Stenberg
13cc010e38 getdate.h is not required to include, it adds nothing new 2004-09-13 20:47:15 +00:00
Daniel Stenberg
e99bf99829 revert the change for the new date parser, as the new one can deal with
the old format now
2004-09-13 20:43:12 +00:00
Daniel Stenberg
2e7dcc1e2a support for YYYYMMDD added, which allows us to keep using the lib/ftp.c code
I was previously #ifdef'ing to a different look when this parser is used
2004-09-13 20:40:27 +00:00
Daniel Stenberg
b85a036e4a added more examples/docs in the top comment 2004-09-13 07:57:12 +00:00
Daniel Stenberg
7885264b29 Since many users probably already use local time strings as input, I now
made it deal with named time zones as well as mail-style +0200 ones.

Seems to work fine. I'm comparing with GNU date command:

date -d [date] -u +%s
2004-09-13 07:45:19 +00:00
Daniel Stenberg
73dd450147 describes how you can extract the CA cert from a site using the openssl tool 2004-09-12 18:27:12 +00:00
Daniel Stenberg
96efa990f9 Added parsedate.[ch] 2004-09-11 20:06:33 +00:00
Daniel Stenberg
4e0aee9408 mention more friends 2004-09-11 20:06:14 +00:00
Daniel Stenberg
27d509cfe9 Minor adjustment needed for the new date parser to succeed. ifdef'ed out
for now.
2004-09-11 19:19:59 +00:00
Daniel Stenberg
ade8e47a8c more docs and fixed the delta compared to GMT that prevented test case 141 to
work with this
2004-09-11 19:16:34 +00:00
Daniel Stenberg
ca52c963c7 1. cookie expire-strings MUST use GMT timezones
2. adjusted date strings to upcoming date parser rewrite
2004-09-11 19:12:37 +00:00
Daniel Stenberg
17acdb5acf slightly better but still lacks 2004-09-11 13:07:42 +00:00
Daniel Stenberg
f6433211ae getdate replacement code. smaller, slicker, faster. 2004-09-11 09:24:02 +00:00
Daniel Stenberg
0ec4c66fba fixed -F to support setting type= even on parts that aren't file-uploads 2004-09-10 21:47:52 +00:00
Daniel Stenberg
1faa9d6fd5 minor indent change 2004-09-10 21:46:58 +00:00
Daniel Stenberg
23d64e720d up to date with recent changes 2004-09-10 21:13:55 +00:00
Daniel Stenberg
b8b56248bd - Bug report #1025986. When following a Location: with a custom Host: header
replacement, curl only replaced the Host: header on the initial request
  and didn't replace it on the following ones. This resulted in requests with
  two Host: headers.

  Now, curl checks if the location is on the same host as the initial request
  and then continues to replace the Host: header. And when it moves to another
  host, it doesn't replace the Host: header but it also doesn't make the
  second Host: header get used in the request.

  This change is verified by the two new test cases 184 and 185.
2004-09-10 20:58:51 +00:00
Daniel Stenberg
33929117f9 curl --sync 2004-09-09 06:58:01 +00:00
Daniel Stenberg
2b1673c9c8 Now the test servers and test cases can run on a custom port number. There's
no fixed port numbers in use anymore. Starting now, the default ports the
servers use are 8990 - 8993. There's no option to modify these yet, but
changing the $base option in the top of the runtests.pl script.
2004-09-08 08:08:38 +00:00
Gunter Knauf
702f549a6a fixed nasty warnings with gcc 3.3. 2004-09-03 18:51:36 +00:00
Daniel Stenberg
428741d7cf clarify CURLE_SSL_CERTPROBLEM somewhat 2004-09-02 21:05:56 +00:00
Daniel Stenberg
6fa624cf8c improved error message when client cert return failure 2004-09-02 21:03:41 +00:00
Daniel Stenberg
5f60188b8a use the correct struct name in the example 2004-09-02 20:42:44 +00:00
Daniel Stenberg
75a6fdeb58 added more info on the nobody 2004-09-01 12:05:59 +00:00
Daniel Stenberg
5f3fa92062 minor edit of HTTPGET 2004-09-01 09:25:19 +00:00
Daniel Stenberg
66077ae48b fix formatting flaw 2004-09-01 09:24:01 +00:00
Daniel Stenberg
92637303db fix the return code for curl_multi_add_handle() 2004-08-31 06:04:43 +00:00
Daniel Stenberg
811dfd710b mention when the function was added to the lib 2004-08-31 06:03:16 +00:00
Daniel Stenberg
b08dc2cadb proxy connection close and so 2004-08-30 15:02:37 +00:00
Daniel Stenberg
f7c5a097e3 proxy-connection close 2004-08-30 15:02:18 +00:00
Daniel Stenberg
5eb3102cd1 removed issue 36 from this list, we don't know how to do it and no one has
stepped forward to help us. Let's postpone that fix.
2004-08-30 14:22:47 +00:00
Daniel Stenberg
05825a8a9f Make "Proxy-Connection: close" close the current proxy connection, as
Roman Koifman found out.
2004-08-30 12:51:32 +00:00
Daniel Stenberg
24353c4372 getdate fix, adacurl release 2004-08-30 09:16:43 +00:00
Daniel Stenberg
e89ea07626 mention Gisle's recent fixes 2004-08-30 09:16:31 +00:00
Gisle Vanem
b99c95ba46 Removed ares_free_errmem.c from MSCV project files.
Fixed line-endings to CR-LF.
2004-08-29 15:40:17 +00:00
Daniel Stenberg
9432bfe90c updated with minor edits 2004-08-27 07:17:52 +00:00
Daniel Stenberg
37bf6da9c8 don't do SO_KEEPALIVE, we already have a finer grained method built-in 2004-08-27 07:04:31 +00:00
Daniel Stenberg
b3ebbd60a2 added some more details 2004-08-26 13:26:27 +00:00
Daniel Stenberg
e942394bdb getdate and new test cases from yday 2004-08-25 11:21:15 +00:00
Daniel Stenberg
4adfcd4fd7 not accurate anymore anyway 2004-08-25 11:18:33 +00:00
Daniel Stenberg
c10196afc0 Frankie V's description on how to get a CA cert for a random site using
IE
2004-08-25 08:09:48 +00:00
Daniel Stenberg
49746d1dce returned memory should not be freed 2004-08-24 20:36:38 +00:00
Daniel Stenberg
d46e235c2a added test 183 to verify that we properly send good Host: headers when
getting multiple URLs over a single proxy connection
2004-08-24 14:40:32 +00:00
Daniel Stenberg
ee44677d7e Attempt to quick-fix the getdate problem by post-replacing the getdate.c
file after the bison/yacc process to add the fix Harshal Pradhan suggested.
2004-08-24 11:48:02 +00:00
Daniel Stenberg
20057aee2e prevent files named ".nfs[something]" from being displayed when failing 2004-08-24 09:23:40 +00:00
Daniel Stenberg
7119679080 updated in CVS, generated with a much newer bison version 2004-08-23 15:28:53 +00:00
Daniel Stenberg
d869b51a57 Expect: 100-continue info added 2004-08-23 14:46:43 +00:00
Daniel Stenberg
dbacc81af7 added note about WRITEFUNCTION now being called with zero bytes if the file
to be transfered is empty
2004-08-23 14:41:54 +00:00
Daniel Stenberg
b233c13dca verify that transferring a zero byte FTP file results in a zero byte local
file
2004-08-23 14:41:19 +00:00
Daniel Stenberg
464be27479 Provide support for "transferring" zero bytes FTP files and comparing that
the output file actually is zero bytes after the transfer.
2004-08-23 14:40:43 +00:00
Daniel Stenberg
d736ac51c0 stripped trailing whitespace 2004-08-23 14:22:52 +00:00
Daniel Stenberg
e8b295ff7d lost of more into on how to tweak some headers 2004-08-23 14:22:44 +00:00
Daniel Stenberg
4a4490d5f1 debug.c is a fresh new example showing how to use the DEBUGFUNCTION to get
lots of fine info from a transfer
2004-08-23 14:22:26 +00:00
Daniel Stenberg
46313be2f5 added more header info for PUT and POST requests 2004-08-23 14:04:38 +00:00
Daniel Stenberg
723bfe42e7 Roman Koifman pointed out that libcurl send Expect: 100-continue on POSTs and
PUTs even when told to use HTTP 1.0, which is not correct.
2004-08-23 12:34:55 +00:00
Gisle Vanem
e35c7dcd72 More patches for Watt-32 on Win32; don't include "nameser.h". 2004-08-20 14:10:44 +00:00
Gisle Vanem
fa83a0573e No WSAGetLastError() on Watt-32/DOS 2004-08-20 14:07:11 +00:00
Gisle Vanem
7b97371ab1 No <sys/uio.h> on DOS/Win32 2004-08-20 13:48:24 +00:00
Gisle Vanem
b17e32baa7 Changes for Watt-32 on Windows. I've assumed Configure
sets the required HAVE_xx defines for non-DOS/Win targets.
2004-08-20 13:45:26 +00:00
Daniel Stenberg
cd52b9f0da Alexander Krasnostavsky made the write callback get called even when a zero
byte file is downloaded.
2004-08-20 12:09:09 +00:00
Daniel Stenberg
c3d74ffe48 socks proxy and timeouts bug 2004-08-20 10:52:35 +00:00
Daniel Stenberg
a231a96841 actually, we check for a numerical host using either ipv4 or ipv6, as neither
should result in a reverse dns lookup
2004-08-20 09:18:12 +00:00
Daniel Stenberg
93b61bf0d3 use inet_pton() correctly! 2004-08-20 09:11:52 +00:00
Gisle Vanem
06d39bd303 ZLIB_ROOT not needed 2004-08-19 15:24:49 +00:00
Gisle Vanem
52177b1f60 My first CVS commit just to see if this works.
BTW. Used eclipse IDE fo this, which really kicks ass.
2004-08-19 15:16:40 +00:00
Daniel Stenberg
566f7b5e58 simplified expression 2004-08-19 09:37:22 +00:00
Daniel Stenberg
c8c47768c7 Ling Thio pointed out that getaddrinfo() reverse-lookups ip-only names, and
this is an attempt to prevent it from doing that. affects ipv6-enabled only.
2004-08-19 06:44:19 +00:00
Daniel Stenberg
62ff567c47 the autobuilds failed all over on AIX, attempt to fix the strerror_r() problem
by setting _THREAD_SAFE (and -qthreaded) before strerror_r() is checked for.
2004-08-19 06:41:49 +00:00
Daniel Stenberg
ee400f9552 reuse handles in PHP/CURL works - Kirk Hedden told us 2004-08-19 06:31:29 +00:00
Daniel Stenberg
9ac7629e2c PHP FAQ 2004-08-18 11:18:36 +00:00
Daniel Stenberg
d72ca96a43 indented the code curl-style 2004-08-18 06:12:01 +00:00
Daniel Stenberg
d0dcb3b554 removed trailing whitespace 2004-08-17 19:46:34 +00:00
Daniel Stenberg
e139e49826 see also the reset function 2004-08-17 12:39:10 +00:00
Daniel Stenberg
3838745fdb mention the reset function 2004-08-17 12:37:35 +00:00
Daniel Stenberg
06a5c70f4d Kjetil Jacobsen reported an open file leak in file:// transfers of empty
files.
2004-08-17 12:00:39 +00:00
Daniel Stenberg
62af3fb7b9 added a check for the xlc compiler on AIX, and if that is detect we use
the -qthreaded compiler option
2004-08-17 10:47:57 +00:00
Daniel Stenberg
db302a1055 define _THREAD_SAFE on (recent) AIX systems to build thread-safe code 2004-08-17 09:00:30 +00:00
Daniel Stenberg
847c91e568 recent fixes 2004-08-17 06:56:53 +00:00
Daniel Stenberg
2646af106b allow a custom "Accept-Encoding:" header override the internally set one
that gets set with CURLOPT_ENCODING
2004-08-16 13:25:30 +00:00
Daniel Stenberg
7261b4556b strip trailing whitespace 2004-08-16 13:24:01 +00:00
Gunter Knauf
071e3cf007 syncronized with libcurl.def. 2004-08-16 11:09:30 +00:00
Gunter Knauf
164184b484 cosmetic fix. 2004-08-16 11:09:01 +00:00
Daniel Stenberg
8b6e87abee summary edit: mention that some options take a curl_off_t 2004-08-16 10:49:57 +00:00
Daniel Stenberg
45197b188e Roland Krikava's cookies over proxy fix. 2004-08-16 07:24:25 +00:00
Gunter Knauf
559553b169 fixed linkage dll targets. (submitted by Casey O'Donnell) 2004-08-14 22:03:40 +00:00
Daniel Stenberg
84ec4068de added two good ideas 2004-08-13 12:06:30 +00:00
Daniel Stenberg
aea87be19e mention Harshal Pradhan's windows fix 2004-08-13 12:01:20 +00:00
Daniel Stenberg
9f14744d16 Harshal Pradhan made minor syntax change to make this build with MSVC 7.1 2004-08-13 12:00:33 +00:00
Daniel Stenberg
1dc8c1dbc8 removed the ispell-added local word, compressed the final links into a
short section
2004-08-13 11:56:15 +00:00
Daniel Stenberg
e9812c53cb strip trailing whitespace 2004-08-13 11:53:33 +00:00
Daniel Stenberg
ed98565963 spell 2004-08-13 11:47:31 +00:00
Daniel Stenberg
1d3233612a Added "5.9 How does libcurl resolve host names?" since I wrote the text in
a mail anyway the other day.
2004-08-12 14:09:10 +00:00
Daniel Stenberg
8362a34cef updated with recent changes 2004-08-12 14:08:46 +00:00
Daniel Stenberg
edd16d978f hm 2004-08-12 11:39:00 +00:00
Daniel Stenberg
4356356305 3.16 What certificates do I need with I use SSL?
my first attempt at a basic description of the certs involvede
2004-08-12 11:02:01 +00:00
Daniel Stenberg
cb88135220 removed trailing whitespace, indented to curl-style levels 2004-08-12 07:01:20 +00:00
Daniel Stenberg
498a0fe795 Removed the _XOPEN_SOURCE defining again since it caused major havoc in IRIX
land with many warnings and even compiler errors due to missing structs etc
2004-08-12 06:30:17 +00:00
Daniel Stenberg
0ca1b6afcf --disable-[protocol] doesn't disable tests of the specific protocol 2004-08-11 11:18:24 +00:00
Daniel Stenberg
d3c9f3d6f8 clarify that CURLE_FTP_USER_PASSWORD_INCORRECT might in fact get returned
even if user and password are correct
2004-08-11 08:44:36 +00:00
Daniel Stenberg
df59ca1a45 include the server response in the error message when an FTP server gives
back a 530 after the password is provided, as it isn't necessary because of a
bad user name or password.
2004-08-11 08:39:48 +00:00
Daniel Stenberg
9d84442409 define the _XOPEN_SOURCE define in the config.h file instead, and also added a
decent quote about the define, taken from
http://www.opengroup.org/onlinepubs/007908799/xsh/compilation.html
2004-08-11 07:25:08 +00:00
Daniel Stenberg
5ab9d72e45 fixed the default result for xopen and mimpure to work better 2004-08-11 07:14:34 +00:00
Daniel Stenberg
6060e7ed96 experimental code to detect mips-sgi-irix systems that build without gcc
and if so, define _XOPEN_SOURCE to 500 in an attempt to build with less
warnings (on the 64bit versions)
2004-08-11 07:11:35 +00:00
Daniel Stenberg
7ca7f7a725 added several recent bindings 2004-08-11 06:42:20 +00:00
Daniel Stenberg
355b3d3057 updated the CURLOPT_POST description after input from Alan Pinstein 2004-08-10 13:22:08 +00:00
Daniel Stenberg
d5bdf5f89c Ok, setting CURLOPT_POST to 0 will now convert the request to a GET (this
remains undocumented as this is not the way we recommend)
2004-08-10 13:21:32 +00:00
Daniel Stenberg
17de7e0f1c minor reformat to suit the new FAQ parser 2004-08-10 12:41:44 +00:00
Daniel Stenberg
2cea484428 ignore curllib.dsp 2004-08-10 10:43:41 +00:00
Daniel Stenberg
fb3e19ae50 ignore more files 2004-08-10 10:43:10 +00:00
Daniel Stenberg
99db7fb222 7.12.2 work in progress 2004-08-10 10:40:56 +00:00
Daniel Stenberg
49d0272627 and we're back on a clean notes sheet again 2004-08-10 08:56:12 +00:00
Daniel Stenberg
da30242640 7.12.1 notes 2004-08-10 08:42:54 +00:00
Daniel Stenberg
811edcde18 added "5.8 libcurl.so.3: open failed: No such file or directory" and made
some general cleanups
2004-08-10 08:41:41 +00:00
Daniel Stenberg
4934e6471b In OpenSSL 0.9.7d and earlier, ASN1_STRING_to_UTF8 fails if the input is
already UTF-8 encoded. We check for this case and copy the raw string manually
to avoid the problem. This code can be made conditional in the future when
OpenSSL has been fixed. Work-around brought by Alexis S. L. Carvalho.
2004-08-10 08:06:43 +00:00
Daniel Stenberg
9dbd6659dc more typecasts to please picky compilers 2004-08-10 06:41:13 +00:00
Daniel Stenberg
5ddad4cdb3 version string, krb4 link fix, added number of web mirrors and libcurl bindings 2004-08-09 13:13:10 +00:00
Daniel Stenberg
338c2da24f GSS/Kerberos 5 for ftp 2004-08-09 12:39:28 +00:00
Daniel Stenberg
b5cafc0b83 added info about my current idea about option separation between URLs on
the command line
2004-08-09 12:36:17 +00:00
Daniel Stenberg
c50ced6cc2 adding notes for 7.12.2 now, 7.12.1 is removed due to release ANY DAY NOW 2004-08-09 12:18:30 +00:00
Daniel Stenberg
f4783bda27 --negotiate does not work without username/password, bug report #1004841 2004-08-09 12:15:23 +00:00
Daniel Stenberg
b55507c8a7 the krb4 stuff needs -lcom_err to link now, for some odd reason. This is
possibly only on some platforms, but it happens on my Solaris 2.7 box and I
don't know anyone else that regularly build curl with krb4 support.
2004-08-09 10:06:15 +00:00
Daniel Stenberg
827a805966 typecast the assigment of an unsigned variable to a signed one to prevent
picky warnings
2004-08-09 08:29:39 +00:00
Daniel Stenberg
e23ba31eb9 ->fread() should get a size_t variable passed in 2004-08-09 08:28:17 +00:00
Daniel Stenberg
02c6fde11e made telrcv() take a ssize_t argument instead of int to better match other
functions (and prevent warnings)
2004-08-09 08:25:39 +00:00
Daniel Stenberg
d003f6e125 mention the new cool CA extraction way just documented 2004-08-09 07:02:51 +00:00
Daniel Stenberg
1dfff2487f new web mirror 2004-08-06 17:44:59 +00:00
Daniel Stenberg
4ff9cd39c5 negotiate fix and new glib/GTK+ binding 2004-08-05 18:55:51 +00:00
Daniel Stenberg
9c4ffcc250 Enrico Scholz fixed the service name to be uppercase as reported in bug
report #1004105
2004-08-05 18:52:54 +00:00
Daniel Stenberg
6b5a04cf83 multi-connect fix and cookie domain fix 2004-08-04 13:12:00 +00:00
Daniel Stenberg
55e61c092e Fixed multiple IP connects with the multi interface. This fix is influenced
by Gisle Vanem's patch, only modified by me.
2004-08-04 12:38:01 +00:00
Daniel Stenberg
de6ab3de22 Dylan Salisbury's fix to prevent us from accepting cookies from TLD only 2004-08-04 12:26:27 +00:00
Daniel Stenberg
5e1eb58e5a borland is already mentioned 2004-07-31 20:47:04 +00:00
Daniel Stenberg
d892a4dc23 mention this is new 2004-07-31 19:47:00 +00:00
Daniel Stenberg
496ea65f39 link to reset as well 2004-07-31 19:46:25 +00:00
Daniel Stenberg
6577b15d08 curl_easy_reset() documented 2004-07-31 19:46:01 +00:00
Daniel Stenberg
f2e35fad27 digest fix 2004-07-31 19:23:57 +00:00
Daniel Stenberg
81c48aa43d Joel Chen reported that we assumed content within quotes a bit too much in
the digest code. This fixes it.
2004-07-31 07:36:01 +00:00
Daniel Stenberg
0cfa9b52ae prevent all the sig and alarm stuff when using ares 2004-07-29 08:06:33 +00:00
Daniel Stenberg
48b92c163f fix a mingw32 build warning 2004-07-29 07:48:47 +00:00
Daniel Stenberg
b7575b39c4 mingw32 builds make .a libs 2004-07-29 07:37:36 +00:00
Daniel Stenberg
ae2f002b44 added typecast in an attempt to fix a mingw32 warning 2004-07-29 07:34:17 +00:00
Daniel Stenberg
89c312691e additional typecasts to please MIPSPro on 64bit IRIX 2004-07-29 07:30:38 +00:00
Daniel Stenberg
1d23affbc5 oops, curl_easy_reset is a void 2004-07-29 07:29:56 +00:00
Daniel Stenberg
26ffaa263b variable type fix 2004-07-29 07:24:39 +00:00
Daniel Stenberg
ca5e6160b7 provide a curl_easy_reset() proto 2004-07-29 07:20:19 +00:00
Daniel Stenberg
6d60ff6ea1 removed C++ comment to please picky source checkers 2004-07-29 07:19:27 +00:00
Daniel Stenberg
43ae26f146 fixes! 2004-07-28 22:00:14 +00:00
Daniel Stenberg
3e01f70468 curl_easy_reset was added 2004-07-28 21:40:20 +00:00
Daniel Stenberg
b9f1dd7691 Bertrand Demiddelaer fixed the host name to get setup properly even when
a connection is re-used, when a proxy is in use.
2004-07-28 21:27:33 +00:00
Daniel Stenberg
a7bed4fc7c Fixes Brian Akins' reported problems with duplicate Host: headers on re-used
connections.
2004-07-28 21:13:29 +00:00
Daniel Stenberg
7ca49dc91d use Makefile.inc and make it get included in dist archives 2004-07-28 18:40:50 +00:00
Daniel Stenberg
645ee8a42a renamed CURL_HEADERS, since it is a magic automake name we must not use 2004-07-28 18:40:18 +00:00
Daniel Stenberg
115dd6f095 Bertrand Demiddelaer made the testing work with valgrind 2.1 2004-07-26 15:45:03 +00:00
Daniel Stenberg
0e03165467 Bertrand Demiddelaer fixed two missing newlines 2004-07-26 15:42:07 +00:00
Daniel Stenberg
6574f4106e -o #[num] fix 2004-07-26 15:30:23 +00:00
Daniel Stenberg
8e7fcd9ee1 using #[num] with -o now make it literally used if there's no globbing for
that particular index. Reported in bug report 997536.
2004-07-26 09:11:10 +00:00
Daniel Stenberg
ad63e1e698 removed trailing whitespace 2004-07-26 09:09:26 +00:00
Daniel Stenberg
d784526dae libs built with libtool are named .la in the build dir 2004-07-25 06:03:10 +00:00
Daniel Stenberg
79d480e1e7 --enable-debug builds static only, Gisle fixed a memory leak and more 2004-07-24 21:51:43 +00:00
Daniel Stenberg
b3b2ba31f7 Gisle Vanem:
Basically in loops like handle_errors(), 'query->next' was assigned a local
variable and then query was referenced after the memory was freed by
next_server(). I've changed that so next_server() and end_query() returns the
next query. So callers should use this ret-value.

The next problem was that 'server->tcp_buffer_pos' had a random value at entry
to 1st recv() (luckily causing Winsock to return ENOBUFS).

I've also added a ares_writev() for Windows to streamline the code
a bit more.
2004-07-24 21:47:49 +00:00
Daniel Stenberg
7f78bc3c6d autobuilds with ares and curl_easy_reset() 2004-07-24 21:43:33 +00:00
Daniel Stenberg
f508f30fb6 curl_easy_reset() added. Need testing and docs. I also think we should make
the initial setting up the struct should use this single function to avoid
having the initialisation code at two places.
2004-07-24 21:31:01 +00:00
Daniel Stenberg
d20a05161a AM_PROG_LIBTOOL is deprecated and AC_PROG_LIBTOOL should be used instead 2004-07-24 21:29:43 +00:00
Daniel Stenberg
6769ab2797 if --enable-ares is used, we must run 'buildconf' in the ares dir before
we run configure.
2004-07-24 21:24:03 +00:00
Daniel Stenberg
85867cbe94 --enable-debug now makes the lib built static only since otherwise we
get problems
2004-07-24 21:22:46 +00:00
Daniel Stenberg
5e8d3988a2 generate the new configure better 2004-07-24 06:29:38 +00:00
Daniel Stenberg
1cd0a08575 now generated by automake 2004-07-23 18:34:21 +00:00
Daniel Stenberg
efd71af2a1 buildconf and memanalyze are parts of the plain release 2004-07-22 22:23:34 +00:00
Daniel Stenberg
2ea80c29fa Added buildconf buildconf.bat to the dist 2004-07-22 22:22:49 +00:00
Daniel Stenberg
e3fc0d5e78 refer bug reports to the mailing lists, not the old email alias 2004-07-22 22:22:29 +00:00
Daniel Stenberg
33f42aacca recent activities 2004-07-22 22:20:07 +00:00
Daniel Stenberg
c85bf83e88 - Fixed a few variable return types for some system calls. Made configure
check for ssize_t to make it possible to use that when receiving the send()
  error code. This is necessary to prevent compiler warnings on some systems.

- Made configure create config.h, and all source files now include setup.h that
  might include the proper config.h (or a handicrafted alternative).

- Switched to 'ares_socket_t' type for sockets in ares, since Windows don't
  use 'int' for that.

- automake-ified and libool-ified c-ares. Now it builds libcares as a shared
  lib on most platforms if wanted. (This bloated the size of the release
  archive with another 200K!)

- Makefile.am now uses Makefile.inc for the c sources, h headers and man
  pages, to make it easier for other makefiles to use the exact same set of
  files.

- Adjusted 'maketgz' to use the new automake magic when building distribution
  archives.
2004-07-22 22:18:45 +00:00
Daniel Stenberg
060b6ce148 the multi interface is not so new anymore! 2004-07-17 08:24:22 +00:00
Daniel Stenberg
35618b4712 minor format fix 2004-07-17 08:22:50 +00:00
Daniel Stenberg
cd2e99e980 deal with negative Content-Length: headers by ignoring the info 2004-07-16 21:01:16 +00:00
Daniel Stenberg
0359ae8f40 test downloading from a server claiming negative content-length 2004-07-16 21:00:50 +00:00
Gunter Knauf
972d39234f removed Makefile.b32.resp from repository. 2004-07-16 10:14:51 +00:00
Gunter Knauf
798349fce6 removed Makefile.b32.resp from the list. 2004-07-16 09:23:29 +00:00
Gunter Knauf
9612fda886 changed to use a temporary response file with tlib to give W9x a chance to build; looks ugly but works fine. 2004-07-16 09:20:57 +00:00
Gunter Knauf
4b217efb84 added borland-ssl and borland-ssl-zlib targets. 2004-07-15 22:20:52 +00:00
Gunter Knauf
555cfb3059 fixed zlib suport. 2004-07-15 21:54:10 +00:00
Gunter Knauf
c0d1d6926c some more tweaks, fixed zlib suport. 2004-07-15 21:51:59 +00:00
Gunter Knauf
fca8fcec3e added just another switch. 2004-07-15 19:36:30 +00:00
Gunter Knauf
6844d5dcad removed old CXXFLAGS; added switch to suppress linker banner. 2004-07-15 18:17:15 +00:00
Gunter Knauf
d759e97166 removed unneeded libs from linking. 2004-07-15 17:21:07 +00:00
Daniel Stenberg
cbfc737d79 recent activities 2004-07-15 09:03:32 +00:00
Gunter Knauf
ab64bf6fb1 added Borland support. 2004-07-15 02:34:58 +00:00
Gunter Knauf
0b0d20021c made OpenSSL support conditional. 2004-07-15 02:09:40 +00:00
Gunter Knauf
932a6f6b77 made OpenSSL support conditional;
removed ugly dependence on Makefile.b32.resp.
2004-07-15 01:59:59 +00:00
Gunter Knauf
1318760ad2 Gisle's fix to support Borland builds again. 2004-07-15 01:08:08 +00:00
Daniel Stenberg
15a403a98d now known as libcurl-tutorial.3 2004-07-14 15:33:27 +00:00
Daniel Stenberg
a92b7c1b16 Jason Nye pointed out that callbacks don't need to use the "C namespace" 2004-07-14 15:32:09 +00:00
Daniel Stenberg
0c54013ee3 An Andres Garcia fix: add a typecast to make it work better 2004-07-14 14:20:53 +00:00
Daniel Stenberg
ca5d1e7a8d removed the config-netware.h from the release archives 2004-07-14 14:18:31 +00:00
Gunter Knauf
40a39e2270 some more fixes; added cw32mt.lib, winmm.lib to the link libs for curl.exe. 2004-07-14 12:12:08 +00:00
Gunter Knauf
982530b186 changed Borland target since Borland's make doesnt understand '&'. 2004-07-14 11:39:29 +00:00
Gunter Knauf
fadc08445a changed to use Makefile.inc. 2004-07-14 11:30:01 +00:00
Gunter Knauf
783381c163 updated for current cvs sources; looking for getting rid of this file.... 2004-07-13 20:02:31 +00:00
Gunter Knauf
5f26bee7c8 changed to use Makefile.inc. 2004-07-13 20:01:15 +00:00
Gunter Knauf
2be57d0833 minor corrections. 2004-07-12 11:29:36 +00:00
Gunter Knauf
6e6748f051 changed to use Makefile.inc since Gisle agreed. 2004-07-11 23:43:32 +00:00
Gunter Knauf
a8d544d9b3 minor cleanup. 2004-07-11 18:14:11 +00:00
Gunter Knauf
5f1490e1bd added some lines to fetch ares version. 2004-07-11 17:59:07 +00:00
Gunter Knauf
2c3e557b5c updated MSVC build instructions. 2004-07-11 13:49:52 +00:00
Gunter Knauf
08df4b8971 changed paths to external libs to recent versions. 2004-07-11 13:49:18 +00:00
Gunter Knauf
11f58ea896 added new vc-zlib target. 2004-07-11 12:31:29 +00:00
Gunter Knauf
15f3b4b6d1 removed zlib dependence from default target; added new zlib targets. 2004-07-11 12:28:07 +00:00
Gunter Knauf
35270e50c2 removed obsolete NetWare config files;
we generate now config.h dynamically from Makefile.
2004-07-11 09:31:53 +00:00
Gunter Knauf
8c975657e7 added ifdef for NetWare to ares.h. 2004-07-11 08:30:23 +00:00
Gunter Knauf
03cb3b9db1 ifdef keep_sigact since its only used when SIGALRM is defined. 2004-07-10 23:11:22 +00:00
Gunter Knauf
19ad942739 fixed ares linking. 2004-07-07 20:46:39 +00:00
Daniel Stenberg
3cf452b923 file:// upload fix on windows 2004-07-06 15:17:32 +00:00
Daniel Stenberg
2a6f9aa155 Andres Garcia pointed out that we searched for a slash badly since it is
converted and thus we must search for backslash on windows
2004-07-06 15:16:05 +00:00
Daniel Stenberg
570455b21d clarify the -Q option a bit better 2004-07-06 08:08:13 +00:00
Daniel Stenberg
dccdf9e66c mingw and netware makefiles added by Gunter Knauf 2004-07-06 08:06:03 +00:00
Gunter Knauf
dd4d5bb1e0 fixed Win32 prebuild section; fixed minor cosmetic bug. 2004-07-06 02:37:52 +00:00
Gunter Knauf
842e4aaa0d added vc-ssl-zlib target. 2004-07-06 01:52:32 +00:00
Gunter Knauf
ebb09cd9c4 minor cleanup. 2004-07-06 01:18:35 +00:00
Gunter Knauf
9a6df07d3d be a bit more verbose when things go wrong. 2004-07-05 23:35:49 +00:00
Gunter Knauf
c59c429a69 added additional check to avoid calling a non-existant external script. 2004-07-05 23:07:59 +00:00
Gunter Knauf
69f9d0c916 the simple way was too simple, so added --mktarball option. 2004-07-05 22:35:00 +00:00
Gunter Knauf
56edbe3804 minor cosmetic fix. 2004-07-05 21:44:09 +00:00
Gunter Knauf
94c4a18541 added simple way to create a tarball just before the build is deleted. 2004-07-05 21:41:28 +00:00
Gunter Knauf
bdcf8d626d changed to reflect recent NetWare makefile changes;
moved call to buildconf.bat down so that it takes place in the build dir.
2004-07-05 21:32:18 +00:00
Gunter Knauf
576b40b1b0 added MingW32 makefile. 2004-07-05 13:53:27 +00:00
Gunter Knauf
954575a19d changed to use Makefile.inc; made paths overwritable. 2004-07-05 13:25:30 +00:00
Gunter Knauf
47bbe36725 added comment. 2004-07-05 13:24:44 +00:00
Daniel Stenberg
1a8f7e830c Added README.netware to the release archive 2004-07-05 11:43:32 +00:00
Gunter Knauf
dfc85b7291 added line where to find compile instructions. 2004-07-05 02:34:17 +00:00
Gunter Knauf
1457b80617 minor NetWare upate. 2004-07-05 02:20:20 +00:00
Gunter Knauf
dba40b35f2 try to relax linux build host detection. 2004-07-05 01:58:33 +00:00
Gunter Knauf
e9d95f1a25 added a simple README.netware. 2004-07-05 01:00:47 +00:00
Gunter Knauf
67e40a2b16 added section for compiling NetWare target. 2004-07-05 00:55:48 +00:00
Daniel Stenberg
25f5f14d35 Gnter Knauf made c-ares build and run on Novell Netware. 2004-07-04 22:20:26 +00:00
Daniel Stenberg
dfda9cc007 explicit typecasts to prevent warnings 2004-07-04 21:54:49 +00:00
Daniel Stenberg
e39b29fc48 typecast the conversion to uInt when assigning z->avail_in to prevent
warnings from picky compilers
2004-07-04 21:53:46 +00:00
Daniel Stenberg
4c17ba4fc0 make sure the 3rd argument passed to bind() is a socklen_t 2004-07-04 21:48:54 +00:00
Daniel Stenberg
4511f7ac50 SSL_get_verify_result() returns a long, so we receive the result in a long
and not an int.
2004-07-04 21:42:32 +00:00
Daniel Stenberg
b9f76f11bb typecast long => int conversion 2004-07-04 21:38:36 +00:00
Daniel Stenberg
17841a20e3 explicit typecasts when converting from long to int to avoid warnings 2004-07-04 21:37:35 +00:00
Gunter Knauf
d90d40b5d1 added NetWare section for paths. 2004-07-04 21:36:32 +00:00
Daniel Stenberg
d2e6a0583a made 'connectindex' a long variable to prevent compiler warnings when
implicitly converting it to int
2004-07-04 21:36:14 +00:00
Gunter Knauf
b2c9277e66 update to build both test apps. 2004-07-04 21:35:26 +00:00
Daniel Stenberg
31c332af93 typecast the conversion from long to int to prevent picky compiler warnings 2004-07-04 21:35:12 +00:00
Gunter Knauf
90af60a6ef removed now obsolete ifdef. Shouldnt the other ifdefs be inside the else as they are in ./src/setup.h ? 2004-07-04 15:37:25 +00:00
Gunter Knauf
80c7566203 removed now obsolete ifdef. 2004-07-04 15:34:58 +00:00
Gunter Knauf
efb1fdbec8 removed abort() - sync'd with getdate.y 1.26 2004-07-04 15:27:08 +00:00
Daniel Stenberg
bada8cc259 include the Makefile.inc file to get all sources and headers 2004-07-04 08:45:25 +00:00
Gunter Knauf
c3a076176e minor fix for compiling on Linux. 2004-07-03 22:25:37 +00:00
Gunter Knauf
2cda3070d5 added few ifdefs to make it usable for NetWare. 2004-07-03 21:48:42 +00:00
Gunter Knauf
728bed8c98 added NetWare makefile. 2004-07-03 21:44:32 +00:00
Gunter Knauf
6e72ea7442 reverted, older gcc breaks compilation since it doesnt know the switch. 2004-07-03 20:18:02 +00:00
Gunter Knauf
a4aac27fd3 killed warning with gcc 3.3.1 and later when using -O2. 2004-07-03 19:58:01 +00:00
Gunter Knauf
5b8816dcb7 modified to use new Makefile.inc to build up object list;
added generation of config.h and a prebuild target to create all neded files.
2004-07-03 19:13:28 +00:00
Gunter Knauf
fc0df97278 modified to use new Makefile.inc to build up object list;
added generation of config.h and a prebuild target to create all neded files.
2004-07-03 18:06:39 +00:00
Gunter Knauf
592658e874 added Makefile.inc which can be included from other makefiles to reduce maintaining. 2004-07-03 17:49:40 +00:00
Daniel Stenberg
5a70e42428 I prefer CURLOPT_WRITEDATA before CURLOPT_FILE 2004-07-02 14:00:49 +00:00
Daniel Stenberg
e4caa98901 snprintf instead of sprintf,
better support for HUGE files with the -# progress bar
2004-07-02 12:48:53 +00:00
Daniel Stenberg
c211a7c685 added typecasts to please compilers 2004-07-02 12:29:15 +00:00
Daniel Stenberg
7876c078bc variable type cleanup to hush compilers,
killed trailing whitespace
2004-07-02 12:28:57 +00:00
Daniel Stenberg
aedadfc779 explicit typecasts to double to prevent warnings about implicit conversions
that might lose accuracy
2004-07-02 11:56:26 +00:00
Daniel Stenberg
2046a6b9e5 curl_share_cleanup fix 2004-07-02 11:27:06 +00:00
Daniel Stenberg
d1d53b2bbf make clean now removes getdate.c 2004-07-02 11:25:13 +00:00
Daniel Stenberg
950aa1c743 configure --disable-http works these days 2004-07-02 09:14:46 +00:00
Daniel Stenberg
a9572bf88a Andrs Garca found out the share cleanup code crashes when you cleanup
and there are not lock/unlock functions set!
2004-07-02 08:28:31 +00:00
Daniel Stenberg
5a93f50394 typecase the argument to curl_easy_strerror() to a CURLcode to please
picky compilers
2004-07-01 14:06:44 +00:00
Daniel Stenberg
60af1cbcc2 djgpp fixes by Gisle 2004-07-01 13:55:13 +00:00
Daniel Stenberg
8952ef933b Gisle's win32-fix. 'errno' is not used for errors when socket() fails on
Windows.
2004-07-01 13:54:24 +00:00
Daniel Stenberg
b350d5da59 Gisle added makefile for djgpp builds 2004-07-01 13:53:13 +00:00
Daniel Stenberg
6df3bf3644 --trace fix 2004-07-01 12:37:55 +00:00
Daniel Stenberg
35840a2c5c make functions use size_t instead of int next major update 2004-07-01 08:22:52 +00:00
Daniel Stenberg
090b89cc76 Variable type cleanups to please the picky MIPSPro compiler. 2004-07-01 08:10:21 +00:00
Daniel Stenberg
f05d47ddd6 variable type cleanup to fix picky compiler warnings 2004-07-01 07:43:20 +00:00
Daniel Stenberg
fcfd4bef2d typecast to prevent picky compiler warning 2004-07-01 07:30:19 +00:00
Daniel Stenberg
18dc8fbc26 typecast to int when the variable is int! 2004-07-01 07:28:36 +00:00
Daniel Stenberg
d9ceee1c75 Gisle's djgpp magic 2004-07-01 06:59:43 +00:00
Daniel Stenberg
097281f459 Gisle Vanem made this build fine with djgpp and the Watt-32 stack. 2004-07-01 06:58:47 +00:00
Daniel Stenberg
087748c48e don't close the trace stream until _after_ the easy handle has been cleaned
up, as that can send traces too
2004-07-01 06:19:19 +00:00
Daniel Stenberg
e35187741b spellfixed comments 2004-07-01 06:08:06 +00:00
Daniel Stenberg
574e911375 Another Gisle update 2004-06-30 12:34:33 +00:00
Daniel Stenberg
ce945bd2f0 5K array on the stack is a big hefty, it is now allocated with malloc
instead
2004-06-30 12:05:07 +00:00
Daniel Stenberg
8efa6f407d I think 1024 bytes is enough for even most ipv6 addresses :-) 2004-06-30 12:04:37 +00:00
Daniel Stenberg
85bd4621db Prevent a very long password to buffer overflow the global variable we
use when built with a very old OpenSSL version.
2004-06-30 11:53:34 +00:00
Daniel Stenberg
6c3759d78d removed trailing whitespace, free a missing malloc when returning error 2004-06-30 11:51:24 +00:00
Daniel Stenberg
4af08a19f8 passing in a very long interface name could make a buffer overflow 2004-06-30 11:48:19 +00:00
Daniel Stenberg
c14650caec not PIN code, pass phrase 2004-06-30 11:34:57 +00:00
Daniel Stenberg
c7a9e07909 simplified the check for when to free() the buf data 2004-06-30 11:32:16 +00:00
Daniel Stenberg
185baf036b NOBODY set TRUE after a POST makes a good HEAD now 2004-06-30 11:09:16 +00:00
Daniel Stenberg
3523613826 wxcurldav 2004-06-30 10:47:14 +00:00
Daniel Stenberg
782ade7223 fixed 2004-06-30 09:29:00 +00:00
Daniel Stenberg
ba40eccc90 make the SSL connect use the same default connect timeout define as the
generic connect uses
2004-06-30 09:22:48 +00:00
Daniel Stenberg
4191741fb6 Curl_addrinfo is another typedef we use frequently 2004-06-29 18:45:52 +00:00
Daniel Stenberg
7a52f44bd4 Gisle fixed a bad free from the resolve reorg, I changed type of the buf
variable to sort out some compiler warnings.
2004-06-29 18:44:59 +00:00
Daniel Stenberg
efa5485744 Gisle's djgpp updates 2004-06-29 18:43:56 +00:00
Daniel Stenberg
c81ac51e5c Gisle's update 2004-06-29 18:43:04 +00:00
Gunter Knauf
fd17cf2e3c fixed argument parsing; added --setup option. 2004-06-29 13:20:37 +00:00
Daniel Stenberg
d4b0999415 'M-x ispell-buffer' 2004-06-29 13:16:30 +00:00
Daniel Stenberg
03f8ec89db multi interface connect fix 2004-06-29 11:27:33 +00:00
Daniel Stenberg
f633ab688b commented out the check for gethostbyname_r() as we no longer use it 2004-06-29 11:22:39 +00:00
Daniel Stenberg
808621ab22 corrected the Curl_is_connected() proto 2004-06-29 11:21:05 +00:00
Daniel Stenberg
6ed5feda2b First attempt at making the multi interface work when connecting to a host
that resolves to multiple IP addresses.
2004-06-29 11:20:07 +00:00
Daniel Stenberg
964066c0de Added missing info for the command line tool, as noted by Mike Kienenberger 2004-06-29 07:58:52 +00:00
Daniel Stenberg
a913e93667 --limit-rate problems on Mac OS X was reported by Rob Stanzel 2004-06-28 07:08:09 +00:00
Daniel Stenberg
a7b99fc463 check for a fine poll() before it is used to sleep subsecond 2004-06-27 21:51:54 +00:00
Daniel Stenberg
6f252f4704 reset CURLOPT_CUSTOMREQUEST with NULL 2004-06-27 21:19:54 +00:00
Daniel Stenberg
b596c34bed snprintf and version 2004-06-24 15:20:29 +00:00
Daniel Stenberg
b0cd96478c oops 5 bytes makes 4 letters plus zero byte 2004-06-24 15:15:27 +00:00
Daniel Stenberg
387ec712e6 fix warning 2004-06-24 15:06:25 +00:00
Daniel Stenberg
f2a99d7d74 the _num_chars() function is not used, removing 2004-06-24 15:05:39 +00:00
Daniel Stenberg
8b6b15dccc to prevent compier warnings, we only declare len if we have code
that uses it
2004-06-24 14:52:51 +00:00
Daniel Stenberg
bbb72b7b6b Gisle: free used memory better 2004-06-24 14:40:16 +00:00
Daniel Stenberg
785bad388b Gisle cleaned up remaining host resolve re-org issues 2004-06-24 14:39:52 +00:00
Daniel Stenberg
cf10df6c68 include header for our printfs 2004-06-24 14:35:45 +00:00
Daniel Stenberg
5b55dcbfbb reverted bad win32 fix 2004-06-24 14:34:13 +00:00
Gunter Knauf
e7dbbd16a5 fixed the MSVC build. 2004-06-24 13:49:14 +00:00
Daniel Stenberg
62f0457961 length limit the sscanf() parsing to prevent buffer overflow 2004-06-24 12:07:36 +00:00
Daniel Stenberg
8879b57b73 ah, simplified my latest change more 2004-06-24 12:01:20 +00:00
Daniel Stenberg
e49a6feabb fix for systems without gethostbyname_r() 2004-06-24 11:58:43 +00:00
Daniel Stenberg
feb2dd2835 Replaced all uses of sprintf() with the safer snprintf(). It is just a
precaution to prevent mistakes to lead to buffer overflows.
2004-06-24 11:54:11 +00:00
Daniel Stenberg
5e34f3dc01 made the Curl_he2ai() take the port number as an int intead, to avoid lots
of typecasts all over
2004-06-24 10:43:50 +00:00
Daniel Stenberg
0031d76f2a use snprintf() to be on the safe side 2004-06-24 10:43:22 +00:00
Daniel Stenberg
00ee738fdd typecasts to prevent warnings 2004-06-24 09:14:59 +00:00
Daniel Stenberg
8d0a823124 only use sockaddr_in6 on ipv6-enabled hosts 2004-06-24 09:13:50 +00:00
Daniel Stenberg
9729df1756 socks proxy support even when libcurl is built ipv6-enabled 2004-06-24 08:59:54 +00:00
Daniel Stenberg
cdb419d65e typecast to prevent warning 2004-06-24 08:31:17 +00:00
Daniel Stenberg
d6f9a41539 use Curl_addrinfo, not 'struct addrinfo' 2004-06-24 08:30:39 +00:00
Daniel Stenberg
1daa258b8a fixed problems I missed to fix from my cleanup 2004-06-24 08:09:54 +00:00
Daniel Stenberg
560c257bd0 prevent warning 2004-06-24 08:08:28 +00:00
Daniel Stenberg
d7aae417b1 Yet another resolve code re-org 2004-06-24 07:56:07 +00:00
Daniel Stenberg
c39858aac0 Source cleanups. The major one being that we now _always_ use a Curl_addrinfo
linked list for name resolved data, even on hosts/systems with only IPv4
stacks as this simplifies a lot of code.
2004-06-24 07:43:48 +00:00
375 changed files with 10521 additions and 15042 deletions

405
CHANGES
View File

@@ -6,6 +6,405 @@
Changelog Changelog
Version 7.12.2 (18 October 2004)
Daniel (16 October 2004)
- Alexander Krasnostavsky made the CURLOPT_FTP_CREATE_MISSING_DIRS option work
fine even for third party transfers.
- runekl at opoint.com found out (and provided a fix) that libcurl leaked
memory for cookies with the "max-age" field set.
Gisle (16 October 2004)
- Issue 50 in TODO-RELEASE; Added Traian Nicolescu's patches for threaded
resolver on Windows. Plugged some potential handle and memory leaks.
Daniel (14 October 2004)
- Eric Vergnaud pointed out that libcurl didn't treat ?-letters in the user
name and password fields properly in URLs, like
ftp://us?er:pass?word@site.com/. Added test 191 to verify the fix.
Daniel (11 October 2004)
- libcurl now uses SO_NOSIGPIPE for systems that support it (Mac OS X 10.2 or
later is one) to inhibit the SIGPIPE signal when writing to a socket while
the peer dies. The same effect is provide by the MSG_NOSIGNAL parameter to
send() on other systems. Alan Pinstein verified the fix.
Daniel (10 October 2004)
- Systems with 64bit longs no longeruse strtoll() or our strtoll- replacement
to parse 64 bit numbers. strtol() works fine. Added a configure check to
detect if [constant]LL works and if so, use that in the strtoll replacement
code to work around compiler warnings reported by Andy Cedilnik.
Gisle (6 October 2004)
- For USE_LIBIDN builds: Added Top-Level-Domain (TLD) check of host-name
used in fix_hostname(). Checks if characters in 'host->name' (indirectly
via 'ace_hostname') are legal according to the TLD tables in libidn.
Daniel (6 October 2004)
- Chih-Chung Chang reported that if you use CURLOPT_RESUME_FROM and enabled
CURLOPT_FOLLOWLOCATION, libcurl reported error if a redirect happened even
if the new URL would provide the resumed file. Test case 188 added to verify
the fix (together with existing test 99).
- Dan Fandrich fixed a configure flaw for systems that need both nsl and socket
libs to use gethostbyname().
- Removed tabs and trailing whitespace from lots of source files.
Daniel (5 October 2004)
- Made configure --with-libidn=PATH try the given PATH before the default
paths to make it possible to override.
- If idna_strerror() is present in libidn, we can use that instead of our
internal replacement. This function was added by Simon in libidn 0.5.6 and
is detected by configure.
- It seems basename() on IRIX is in the libgen library and since we don't use
that, configure finds libgen.h but not basename and then we get a compiler
error because our basename() replacement doesn't match the proto in
libgen.h. Starting now, we don't include the file if basename wasn't found
as well.
Daniel (4 October 2004)
- Chris found a race condition resulting in CURLE_COULDNT_RESOLVE_HOST and
potential crash, in the windows threaded name resolver code.
Daniel (3 October 2004)
- Replaced the use of isspace() in cookie.c with our own version instead since
we have most data as 'char *' and that makes us pass in negative values if
there is 8bit data in the string. Changing to unsigned causes too much
warnings or too many required typecasts to the normal string functions.
Harshal Pradhan identified this problem.
Daniel (2 October 2004)
- Bertrand Demiddelaer found a case where libcurl could read already freed
data when CURLOPT_VERBOSE is used and a (very) persistent connection. It
happened when the dns cache entry for the connection was pruned while the
connection was still alive and then again re-used. We worked together on
this fix.
- Gisle Vanem provided code that displays an error message when the (libidn
based) IDN conversion fails. This is really due to a missing suitable
function in the libidn API that I hope we can remove once libidn gets a
function like this.
Daniel (1 October 2004)
- Aleksandar Milivojevic reported a problem in the Redhat bugzilla (see
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=134133) and not to
anyone involved in the curl project! This happens when you try to curl a
file from a proftpd site using SSL. It seems proftpd sends a somewhat
unorthodox response code (232 instead of 230). I relaxed the response code
check to deal with this and similar cases.
- Based on Fedor Karpelevitch's formpost path basename patch, file parts in
formposts no longer include the path part. If you _really_ want them, you
must provide your preferred full file name with CURLFORM_FILENAME.
Added detection for libgen.h and basename() to configure. My custom
basename() replacement function for systems without it, might be a bit too
naive...
Updated 6 test cases to make them work with the stripped paths.
Daniel (30 September 2004)
- Larry Campbell added CURLINFO_OS_ERRNO to curl_easy_getinfo() that allows an
app to retrieve the errno variable after a (connect) failure. It will make
sense to provide this for more failures in a more generic way, but let's
start like this.
- G<>nter Knauf and Casey O'Donnell worked out an extra #if condition for the
curl/multi.h header to work better in winsock-using apps.
- Jean-Philippe Barrette-LaPierre made buildconf run better on Mac OS X by
properly using glibtoolize instead of plain libtoolize. (This is made if
glibtool was found and used instead of plain libtool.)
Daniel (29 September 2004)
- Bertrand Demiddelaer fixed curl_easy_reset() so that it doesn't mistakingly
enable the progress meter.
Daniel (28 September 2004)
- "Mekonikum" found out that if you built curl without SSL support, although
your current SSL installation supports Engine, the compile fails.
Daniel (27 September 2004)
- When --with-ssl=PATH is used to the configure script, it no longer uses
pkg-config to figure out extra details. That is now only done if no PATH is
included or if SSL is checked for by default without the --with-ssl option.
Daniel (25 September 2004)
- Peter Sylvester pointed out that CURLOPT_SSLENGINE couldn't even be set to
NULL when no engine was supported. It can now.
Daniel (22 September 2004)
- Dan Fandrich fixed three test cases to no longer use "localhost" but instead
use "127.0.0.1" to avoid requiring that localhost resolves nicely.
- Jean-Claude Chauve fixed an LDAP crash when more than one record was
retrieved.
Daniel (19 September 2004)
- Andreas Rieke pointed out that when attempting to connect to a host without
a service on the specified port, curl_easy_perform() didn't properly provide
an error message in the CURLOPT_ERRORBUFFER buffer.
Daniel (16 September 2004)
- Daniel at touchtunes uses the FTP+SSL server "BSDFTPD-SSL from
http://bsdftpd-ssl.sc.ru/" which accordingly doesn't properly work with curl
when "AUTH SSL" is issued (although the server responds fine and everything)
but requires that curl issues "AUTH TLS" instead. See
http://curl.haxx.se/feedback/display.cgi?id=10951944937603&support=yes
Introducing CURLOPT_FTPSSLAUTH that allows the application to select which
of the AUTH strings to attempt first.
- Anonymous filed bug report #1029478 which identified a bug when you 1) used
a URL without properly seperating the host name and the parameters with a
slash. 2) the URL had parameters to the right of a ? that contains a slash
3) curl was told to follow Location:s 4) the request got a response that
contained a Location: to redirect to "/dir". curl then appended the new path
on the wrong position of the original URL.
Test case 187 was added to verify that this was fixed properly.
Daniel (11 September 2004)
- Added parsedate.c that contains a rewrite of the date parser currently
provided by getdate.y. The new one is MUCH smaller and will allow us to run
away from the yacc/bison jungle. It is also slightly lacking in features
compared to the old one, but it supports parsing of all date formats HTTP
involves (and a fair bunch of others).
Daniel (10 September 2004)
- As found out by Jonas Forsman, curl didn't allow -F to set Content-Type on
text-parts. Starting now, we can do -F "name=daniel;type=text/extra". Added
test case 186 to verify.
- Bug report #1025986. When following a Location: with a custom Host: header
replacement, curl only replaced the Host: header on the initial request
and didn't replace it on the following ones. This resulted in requests with
two Host: headers.
Now, curl checks if the location is on the same host as the initial request
and then continues to replace the Host: header. And when it moves to another
host, it doesn't replace the Host: header but it also doesn't make the
second Host: header get used in the request.
This change is verified by the two new test cases 184 and 185.
Daniel (8 September 2004)
- Modified the test suite to be able to use and run with customized port
numbers. This was always intended but never before possible. Now a simple
change in the runtests.pl script can make all tests use different ports.
The default ports in use from now on are 8990 to 8993.
Daniel (2 September 2004)
- Minor modification of an SSL-related error message.
Daniel (31 August 2004)
- David Tarendash found out that curl_multi_add_handle() returned
CURLM_CALL_MULTI_PERFORM instead of CURLM_OK.
Daniel (30 August 2004)
- Make "Proxy-Connection: close" close the current proxy connection, as Roman
Koifman found out.
Daniel (24 August 2004)
- Fixed a getdate problem by post-replacing the getdate.c file after the
bison/yacc process to add the fix Harshal Pradhan suggested. The problem
caused a crash on Windows when parsing some dates.
Daniel (23 August 2004)
- Roman Koifman pointed out that libcurl send Expect: 100-continue on POSTs
even when told to use HTTP 1.0, which is not correct. Test case 180 and
181 verify this.
- Added test case 182 to verify that zero byte transfers call the callback
properly.
Daniel (20 August 2004)
- Alexander Krasnostavsky made the write callback get called even when a zero
byte file is downloaded.
Daniel (18 August 2004)
- Ling Thio pointed out that when libcurl is built ipv6-enabled, it still did
reverse DNS lookups when fed with a numerical IP-address (like
http://127.0.0.1/), although it doesn't when built ipv6-disabled. libcurl
should never do reverse lookups.
Daniel (17 August 2004)
- Kjetil Jacobsen noticed that when transferring a file:// URL pointing to an
empty file, libcurl would return with the file still open.
- Alexander Krasnostavsky pointed out that the configure script needs to define
_THREAD_SAFE for AIX systems to make libcurl built really thread-safe.
Also added a check for the xlc compiler on AIX, and if that is detect we use
the -qthreaded compiler option
Daniel (16 August 2004)
- libcurl now allows a custom "Accept-Encoding:" header override the
internally set one that gets set with CURLOPT_ENCODING. Pointed out by Alex.
- Roland Krikava found and fixed a cookie problem when using a proxy (the
path matching was wrong). I added test case 179 to verify that we now do
right.
Daniel (15 August 2004)
- Casey O'Donnell fixed some MSVC makefile targets to link properly.
Daniel (11 August 2004)
- configure now defines _XOPEN_SOURCE to 500 on systems that need it to build
warning-free (the only known one so far is non-gcc builds on 64bit SGI
IRIX). (Reverted this change later as it caused compiler errors.)
- the FTP code now includes the server response in the error message when the
server gives back a 530 after the password is provided, as it isn't
necessary because of a bad user name or password.
Version 7.12.1 (10 August 2004)
Daniel (10 August 2004)
- In OpenSSL 0.9.7d and earlier, ASN1_STRING_to_UTF8 fails if the input is
already UTF-8 encoded. This made the certificate verification fail if the
remote server used a certificate with the name UTF-8 encoded.
Work-around brought by Alexis S. L. Carvalho.
Daniel (9 August 2004)
- I fixed the configure script for krb4 to use -lcom_err as well, as I started
to get link problems with it unless I did that on my Solaris 2.7 box. I
don't understand why I started to get problems with this now!
Daniel (5 August 2004)
- Enrico Scholz fixed the HTTP-Negotiate service name to be uppercase as
reported in bug report #1004105
Daniel (4 August 2004)
- Gisle Vanem provided a fix for the multi interface and connecting to a host
using multiple IP (bad) addresses.
- Dylan Salisbury made libcurl no longer accept cookies set to a TLD only (it
previously allowed that on the seven three-letter domains).
Daniel (31 July 2004)
- Joel Chen reported that the digest code assumed quotes around the contents a
bit too much.
Daniel (28 July 2004)
- Bertrand Demiddelaer fixed the host name to get setup properly even when a
connection is re-used, when a proxy is in use. Previously the wrong Host:
header could get sent when re-using a proxy connection to a different target
host.
- Fixed Brian Akins' reported problems with duplicate Host: headers on re-used
connections. If you attempted to replace the Host: header in the second
request, you got two such headers!
- src/Makefile.am now includes the Makefile.inc file to get info about files
Daniel (26 July 2004)
- Made "curl [URL] -o name#2" work as expected. If there's no globbing for the
#-number, it will simply be used as #2 in the file name.
- Bertrand Demiddelaer fixed testing with valgrind 2.1.x and added two missing
newlines in the cookie informationals.
Daniel (24 July 2004)
- I fixed the autobuilds with ares, since they now need to have buildconf run
in the ares dir before the configure script is run.
- Added Casey O'Donnell's curl_easy_reset() function. It has a proto in
curl/curl.h but we have no man page yet.
Daniel (20 July 2004)
- Added buildconf and buildconf.bat to the release archives, since they are
handy for rebuilding curl when using a daily snapshot (and not a pure CVS
checkout).
Daniel (16 July 2004)
- As suggested by Toby Peterson, libcurl now ignores Content-Length data if the
given size is a negative number. Test case 178 verifies this.
Daniel (14 July 2004)
- G<>nter Knauf has made the Netware builds do without the config-netware.h
files, so they are now removed from the dist packages.
- G<>nter Knauf made curl and libcurl build with Borland again.
- Andres Garcia fixed the common test 505 failures on windows.
Daniel (6 July 2004)
- Andr<64>s Garc<72>a found out why the windows tests failed on file:// "uploads".
Daniel (2 July 2004)
- Andr<64>s Garc<72>a reported a curl_share_cleanup() crash that occurs when no
lock/unlock callbacks have been set and the share is cleaned up.
Daniel (1 July 2004)
- When using curl --trace or --trace-ascii, no trace messages that were sent
by curl_easy_cleanup() were included in the trace file. This made the
message "Closing connection #0" never appear in trace dumps.
Daniel (30 June 2004)
- Niels van Tongeren found that setting CURLOPT_NOBODY to TRUE doesn't disable
a previously set POST request, making a very odd request get sent (unless
you disabled the POST) a HEAD request with a POST request-body. I've now
made CURLOPT_NOBODY enforce a proper HEAD. Added test case 514 for this.
Daniel (29 June 2004)
- G<>nter Knauf made the testcurl.pl script capable of using a custom setup
file to easier run multiple autobuilds on the same source tree.
- Gisle fixed the djgpp build and fixed a memory problem in some of the
reorged name resolved code.
- Fixed code to allow connects done using the multi interface to attempt the
next IP when connecting to a host that resolves to multiple IPs and a
connect attempt fails.
Daniel (27 June 2004)
- Based on Rob Stanzel's bug report #979480, I wrote a configure check that
checks if poll() can be used to wait on NULL as otherwise select() should be
used to do it. The select() usage was also fixed according to his report.
Mac OS X 10.3 says "poll() functionality for Mac OS X is implemented via an
emulation layer on top of select(), not in the kernel directly. It is
recommended that programs running under OS X 10.3 prefer select() over
poll(). Configure scripts should look for the _POLL_EMUL_H_ define (instead
of _POLL_H_ or _SYS_POLL_H_) and avoid implementations where poll is not
implemented in the kernel."
Yes, we can probably use select() on most platforms but today I prefered to
leave the code unaltered.
Daniel (24 June 2004)
- The standard curl_version() string now only includes version info about
involved libraries and not about particular features. Thus it will no longer
include info about ipv6 nor GSS. That info is of course still available in
the feature bitmask curl_version_info() offers.
- Replaced all occurances of sprintf() with snprintf(). This is mostly because
it is "A Good Thing" rather than actually fixing any known problem. This
will help preventing future possible mistakes to cause buffer overflows.
- Major reorganization in the host resolve code (again). This time, I've
modified the code to now always use a linked list of Curl_addrinfo structs
to return resolved info in, no matter what resolver method or support that
is available on the platform. It makes it a lot easier to write code that
uses or depends on resolved data.
Internally, this means amongst other things that we can stop doing the weird
"increase buffer size until it works" trick when resolving hosts on
ipv4-only with gethostbyname_r(), we support socks even on libcurls built
with ipv6 enabled (but only to socks servers that resolve to an ipv4
address) and we no longer deep-copy or relocate hostent structs (we create
Curl_addrinfo chains instead).
The new "hostent to Curl_addrinfo" converter function is named Curl_he2ai()
and is slightly naive and simple, yet I believe it is functional enough to
work for libcurl.
Daniel (22 June 2004) Daniel (22 June 2004)
- David Cohen pointed out that RFC2109 says clients should allow cookies to - David Cohen pointed out that RFC2109 says clients should allow cookies to
contain least 4096 bytes while libcurl only allowed 2047. I raised the limit contain least 4096 bytes while libcurl only allowed 2047. I raised the limit
@@ -36,7 +435,7 @@ Daniel (21 June 2004)
Test case 513 was added to verify that it works. I had to improve the test Test case 513 was added to verify that it works. I had to improve the test
HTTP server too to dump the request to a file even when the client HTTP server too to dump the request to a file even when the client
disconnects prematurely. disconnects prematurely.
Daniel (19 June 2004) Daniel (19 June 2004)
- Luca Alteas provided a test case with a failing curl operation: when we POST - Luca Alteas provided a test case with a failing curl operation: when we POST
to a site with --digest (or similar) set, and the server responded with a 302 to a site with --digest (or similar) set, and the server responded with a 302
@@ -121,7 +520,7 @@ Daniel (3 June 2004)
- Chris Gaukroger pointed out that 'make test' attempts to run the tests even - Chris Gaukroger pointed out that 'make test' attempts to run the tests even
if curl is built cross-compiled. I've now made it output a short message if curl is built cross-compiled. I've now made it output a short message
instead, saying it isn't possible to do. instead, saying it isn't possible to do.
- Alexander Krasnostavsky brought FTP 3rd party transfer support to libcurl. - Alexander Krasnostavsky brought FTP 3rd party transfer support to libcurl.
You can now use libcurl to transfer files between two remote hosts using You can now use libcurl to transfer files between two remote hosts using
FTP. There are a bunch of new options to control this with: FTP. There are a bunch of new options to control this with:
@@ -196,7 +595,7 @@ Daniel (20 May 2004)
wrong. The same was true for the download speed. Fixed now. wrong. The same was true for the download speed. Fixed now.
Daniel (19 May 2004) Daniel (19 May 2004)
- David Byron added test case 170 - this used to crash the previous version of - David Byron added test case 170 - this used to crash the previous version of
curl. curl.
Daniel (17 May 2004) Daniel (17 May 2004)

View File

@@ -15,12 +15,6 @@ Compile and build instructions follow below.
CHANGES.0 contains ancient changes. CHANGES.0 contains ancient changes.
CHANGES.$year contains changes for the particular year. CHANGES.$year contains changes for the particular year.
tests/memanalyze.pl
is for analyzing the output generated by curl if -DCURLDEBUG
is used when compiling (run configure with --enable-debug)
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/ is a subdirectory with various perl scripts perl/ is a subdirectory with various perl scripts

View File

@@ -23,8 +23,8 @@
AUTOMAKE_OPTIONS = foreign AUTOMAKE_OPTIONS = foreign
EXTRA_DIST = CHANGES COPYING maketgz reconf Makefile.dist \ EXTRA_DIST = CHANGES COPYING maketgz reconf Makefile.dist curl-config.in \
curl-config.in curl-style.el sample.emacs RELEASE-NOTES curl-style.el sample.emacs RELEASE-NOTES buildconf buildconf.bat
bin_SCRIPTS = curl-config bin_SCRIPTS = curl-config

View File

@@ -30,8 +30,28 @@ ssl:
make make
borland: borland:
cd lib & make -f Makefile.b32 cd lib
cd src & make -f Makefile.b32 make -f Makefile.b32
cd ..\src
make -f Makefile.b32
borland-ssl:
cd lib
make -f Makefile.b32 WITH_SSL=1
cd ..\src
make -f Makefile.b32 WITH_SSL=1
borland-ssl-zlib:
cd lib
make -f Makefile.b32 WITH_SSL=1 WITH_ZLIB=1
cd ..\src
make -f Makefile.b32 WITH_SSL=1 WITH_ZLIB=1
borland-clean:
cd lib
make -f Makefile.b32 clean
cd ..\src
make -f Makefile.b32 clean
mingw32: mingw32:
cd lib & make -f Makefile.m32 ZLIB=1 cd lib & make -f Makefile.m32 ZLIB=1
@@ -51,12 +71,24 @@ vc:
cd ..\src cd ..\src
nmake /f Makefile.vc6 nmake /f Makefile.vc6
vc-zlib:
cd lib
nmake /f Makefile.vc6 cfg=release-zlib
cd ..\src
nmake /f Makefile.vc6 cfg=release-zlib
vc-ssl: vc-ssl:
cd lib cd lib
nmake /f Makefile.vc6 cfg=release-ssl nmake /f Makefile.vc6 cfg=release-ssl
cd ..\src cd ..\src
nmake /f Makefile.vc6 cfg=release-ssl nmake /f Makefile.vc6 cfg=release-ssl
vc-ssl-zlib:
cd lib
nmake /f Makefile.vc6 cfg=release-ssl-zlib
cd ..\src
nmake /f Makefile.vc6 cfg=release-ssl-zlib
vc-ssl-dll: vc-ssl-dll:
cd lib cd lib
nmake /f Makefile.vc6 cfg=release-ssl-dll nmake /f Makefile.vc6 cfg=release-ssl-dll

10
README
View File

@@ -1,12 +1,12 @@
_ _ ____ _ _ _ ____ _
___| | | | _ \| | ___| | | | _ \| |
/ __| | | | |_) | | / __| | | | |_) | |
| (__| |_| | _ <| |___ | (__| |_| | _ <| |___
\___|\___/|_| \_\_____| \___|\___/|_| \_\_____|
README README
Curl is a command line tool for transfering data specified with URL Curl is a command line tool for transferring data specified with URL
syntax. Find out how to use Curl by reading the curl.1 man page or the syntax. Find out how to use Curl by reading the curl.1 man page or the
MANUAL document. Find out how to install Curl by reading the INSTALL MANUAL document. Find out how to install Curl by reading the INSTALL
document. document.

View File

@@ -1,51 +1,84 @@
Curl and libcurl 7.12.1 Curl and libcurl 7.12.2
Public curl release number: 82 Public curl release number: 83
Releases counted from the very beginning: 109 Releases counted from the very beginning: 110
Available command line options: 96 Available command line options: 96
Available curl_easy_setopt() options: 120 Available curl_easy_setopt() options: 121
Number of public functions in libcurl: 36 Number of public functions in libcurl: 36
Amount of public web site mirrors: 13
Number of known libcurl bindings: 27
This release includes the following changes: This release includes the following changes:
o read callbacks can stop the transfer by returning CURL_READFUNC_ABORT o the IDN code now verifies that only TLD-legitmate letters are used in the
o libcurl-tutorial.3 is the new man page formerly known as libcurl-the-guide name or a warning is displayed (when verbose is enabled)
o additional SSL trace data might be sent to the debug callback using two new o provides error texts for IDN errors
types: CURLINFO_SSL_DATA_IN and CURLINFO_SSL_DATA_OUT o file upload parts in formposts now get their directory names cut off
o multipart formposts can upload files larger than system memory o added CURLINFO_OS_ERRNO
o the curl tool continues with the next URL even if one transfer fails o added CURLOPT_FTPSSLAUTH to allow ftp connects to attempt "AUTH TLS" instead
o FTP 3rd party transfer support - seven new setopt() options before "AUTH SSL"
o curl_getdate() completely rewritten: may affect rare curl -z use cases
This release includes the following bugfixes: This release includes the following bugfixes:
o cookies can now hold 4999 bytes of content o CURLOPT_FTP_CREATE_MISSING_DIRS works for third party transfers
o HTTP POST/PUT with NTLM/Digest/Negotiate to a URL returning 3XX o memory leak for cookies received with max-age set
o HTTPS POST/PUT over a proxy requiring NTLM/Digest/Negotiate works now o potential memory leaks in the window name resolver
o less restrictive libidn requirements, 0.4.1 or later is fine o URLs with ?-letters in the user name or password fields
o fixed HTTP POST or PUT with Digest/Negotiate/NTLM selected but the server o libcurl error message is now provided when send() fails
didn't require any authentication o no more SIGPIPE on Mac OS X and other SO_NOSIGPIPE-supporting platforms
o win32 file:// transfer free memory bug o HTTP resume was refused if redirected
o configure --disable-http builds a libcurl without HTTP support o configure's gethostbyname check when both nsl and socket libs are required
o CURLOPT_FILETIME had wrong type, it expects a long argument o configure --with-libidn now checks the given path before defaults
o builds fine with Borland on Windows again o a race condition sometimes resulting in CURLE_COULDNT_RESOLVE_HOST in the
o the msvc curllib.dsp now builds the libcurl.lib file again windows threaded name resolver code
o builds fine on VMS again o isspace() invokes with negative values in the cookie code
o builds fine on NetWare again o a case of read-already-freed-data when CURLOPT_VERBOSE is used and a (very)
o HTTP Digest authentication with proxies uses correct user name + password persistent connection
o now builds fine with lcc-win32 o now includes descriptive error messages for IDN errors
o more forgivning PASS response code check for better working with proftpd
o curl/multi.h works better included in winsock-using apps
o curl_easy_reset() no longer enables the progress meter
o build fix for SSL disabled curl with SSL Engine support present
o configure --with-ssl=PATH now ignores pkg-config path info
o CURLOPT_SSLENGINE can be set to NULL even if no engine support is available
o LDAP crash when more than one record was received
o connect failures properly stores an error message in the errorbuffer
o Rare Location:-following problem with bad original URL
o -F can now add Content-Type on non-file sections
o double Host: header when following Location: with replaced Host:
o curl_multi_add_handle() return code
o "Proxy-Connection: close" is now understood and properly dealt with
o curl_getdate() crash
o downloading empty files now calls the write callback properly
o no reverse DNS lookups for ip-only addresses with ipv6-enabled libcurl
o file handler leak when getting an empty file:// URL
o libcurl works better multi-threaded on AIX (when built with xlc)
o cookies over proxy didn't match the path properly
o MSVC makefile fixes to build better
o FTP response 530 on 'PASS' now sends back a better error message
Other curl-related news since the previous public release: Other curl-related news since the previous public release:
o James Hu took over after Kevin Roth as maintainer of the curl package on o AdacURL version 7.12.1 http://www.almroth.com/adacurl/index.html
cygwin. Many saludos to Kevin for a work well done during many years. o pycurl version 7.12.1 http://pycurl.sourceforge.net/
o Gambas binding for libcurl: http://gambas.sf.net/ o tclcurl version 0.12.1
o pycurl 7.12.0 was released http://pycurl.sf.net/ http://personal1.iddeo.es/andresgarci/tclcurl/english/
o libcurl.NET was announce: http://www.seasideresearch.com/downloads.html
o Get your fresh Mozilla-extracted ca cert bundle here:
http://curl.haxx.se/docs/caextract.html
o New web mirror in Taiwan: http://curl.cs.pu.edu.tw/
This release would not have looked like this without help, code, reports and This release would not have looked like this without help, code, reports and
advice from friends like these: advice from friends like these:
Gisle Vanem, Vincent Bronner, Alexander Krasnostavsky, Chris Gaukroger, Casey O'Donnell, Roland Krikava, Alex, Alexander Krasnostavsky, Kjetil
G<EFBFBD>nter Knauf, Marty Kuhrt, Kjetil Jacobsen, Steven Bazyl, Seshubabu Pasam, Jacobsen, Ling Thio, Roman Koifman, Harshal Pradhan, Jonas Forsman, David
Luca Alteas, Jean-Louis Lemaire, David Byron, David Cohen Tarendash, Daniel at touchtunes, Bertrand Demiddelaer, Andreas Rieke,
Jean-Claude Chauve, Dan Fandrich, Peter Sylvester, "Mekonikum", Jean-Philippe
Barrette-LaPierre, G<>nter Knauf, Larry Campbell, Fedor Karpelevitch,
Aleksandar Milivojevic, Gisle Vanem, Chris "Bob Bob", Chih-Chung Chang, Andy
Cedilnik, Alan Pinstein, Eric Vergnaud, Traian Nicolescu, runekl at
opoint.com
Thanks! (and sorry if I forgot to mention someone) Thanks! (and sorry if I forgot to mention someone)

View File

@@ -1,17 +1,11 @@
Issues not sorted in any particular order. Issues not sorted in any particular order.
UNASSIGNED means that no person has publicly stated to work on the issue.
To get fixed in 7.12.1 (planned release: August 2004) To get fixed in 7.12.2 (planned release: mid October 2004)
====================== ======================
35 - Fix multi interface when connecting to host with multiple IP addresses: To get fixed in 7.12.3 (planned release: December 2004)
http://curl.haxx.se/mail/lib-2004-06/0163.html and
http://curl.haxx.se/mail/lib-2004-06/0167.html
UNASSIGNED
* Bugfixes reported until late July
To get fixed in 7.12.2 (planned release: December 2004)
====================== ======================
Bugfixes reported until late November 47 - Peter Sylvester's patch for SRP on the TLS layer
48 - MSVC Makefile improvements by Samuel D<>az Garc<72>a

View File

@@ -6,3 +6,17 @@ ahost
config.log config.log
config.status config.status
aclocal.m4 aclocal.m4
.deps
Makefile.in
config.guess
config.h
config.h.in
config.sub
libtool
ltmain.sh
stamp-h1
*.lo
.libs
depcomp
libcares.la
missing

View File

@@ -1,5 +1,107 @@
Changelog for the c-ares project Changelog for the c-ares project
* September 29
- Henrik Stoerner fix: got a report that Tru64 Unix (the unix from Digital
when they made Alpha's) uses /etc/svc.conf for the purpose fixed below for
other OSes. He made c-ares check for and understand it if present.
- Now c-ares will use local host name lookup _before_ DNS resolving by default
if nothing else is told.
* September 26
- Henrik Stoerner: found out that c-ares does not look at the /etc/host.conf
file to determine the sequence in which to search /etc/hosts and DNS. So on
systems where this order is defined by /etc/host.conf instead of a "lookup"
entry in /etc/resolv.conf, c-ares will always default to looking in DNS
first, and /etc/hosts second.
c-ares now looks at
1) resolv.conf (for the "lookup" line);
2) nsswitch.fon (for the "hosts:" line);
3) host.conf (for the "order" line).
First match wins.
- Dominick Meglio patched: C-ares on Windows assumed that the HOSTS file is
located in a static location. It assumed
C:\Windows\System32\Drivers\Etc. This is a poor assumption to make. In fact,
the location of the HOSTS file can be changed via a registry setting.
There is a key called DatabasePath which specifies the path to the HOSTS
file:
http://www.microsoft.com/technet/itsolutions/network/deploy/depovg/tcpip2k.mspx
The patch will make c-ares correctly consult the registry for the location
of this file.
* August 29
- Gisle Vanem fixed the MSVC build files.
* August 20
- Gisle Vanem made c-ares build and work with his Watt-32 TCP/IP stack.
* August 13
- Harshal Pradhan made a minor syntax change in ares_init.c to make it build
fine with MSVC 7.1
* July 24
- Made the lib get built static only if --enable-debug is used.
- Gisle Vanem fixed:
Basically in loops like handle_errors(), 'query->next' was assigned a local
variable and then query was referenced after the memory was freed by
next_server(). I've changed that so next_server() and end_query() returns
the next query. So callers should use this ret-value.
The next problem was that 'server->tcp_buffer_pos' had a random value at
entry to 1st recv() (luckily causing Winsock to return ENOBUFS).
I've also added a ares_writev() for Windows to streamline the code a bit
more.
* July 20
- Fixed a few variable return types for some system calls. Made configure
check for ssize_t to make it possible to use that when receiving the send()
error code. This is necessary to prevent compiler warnings on some systems.
- Made configure create config.h, and all source files now include setup.h that
might include the proper config.h (or a handicrafted alternative).
- Switched to 'ares_socket_t' type for sockets in ares, since Windows don't
use 'int' for that.
- automake-ified and libool-ified c-ares. Now it builds libcares as a shared
lib on most platforms if wanted. (This bloated the size of the release
archive with another 200K!)
- Makefile.am now uses Makefile.inc for the c sources, h headers and man
pages, to make it easier for other makefiles to use the exact same set of
files.
- Adjusted 'maketgz' to use the new automake magic when building distribution
archives.
- Anyone desires HTML and/or PDF versions of the man pages in the release
archives?
* July 3
- G<>nter Knauf made c-ares build and run on Novell Netware.
* July 1
- Gisle Vanem provided Makefile.dj to build with djgpp, added a few more djgpp
fixes and made ares not use 'errno' to provide further info on Windows.
* June 30
- Gisle Vanem made it build with djgpp and run fine with the Watt-32 stack.
* June 10 * June 10
- Gisle Vanem's init patch for Windows: - Gisle Vanem's init patch for Windows:

View File

@@ -10,6 +10,9 @@ maketgz
aclocal.m4 aclocal.m4
acinclude.m4 acinclude.m4
Makefile.in Makefile.in
Makefile.dj
Makefile.m32
Makefile.netware
install-sh install-sh
mkinstalldirs mkinstalldirs
configure configure

57
ares/Makefile.am Normal file
View File

@@ -0,0 +1,57 @@
AUTOMAKE_OPTIONS = foreign
lib_LTLIBRARIES = libcares.la
man_MANS = $(MANPAGES)
MSVCFILES = vc/adig/adig.dep vc/adig/adig.dsp vc/adig/adig.mak \
vc/adig/adig.plg vc/vc.dsw vc/ahost/ahost.dep vc/ahost/ahost.dsp \
vc/ahost/ahost.mak vc/ahost/ahost.plg vc/areslib/areslib.dep \
vc/areslib/areslib.dsp vc/areslib/areslib.mak vc/areslib/areslib.plg
# adig and ahost are just sample programs and thus not mentioned with the
# regular sources and headers
EXTRA_DIST = CHANGES README.cares Makefile.inc adig.c ahost.c $(man_MANS) \
$(MSVCFILES)
VER=-version-info 0:0:0
# This flag accepts an argument of the form current[:revision[:age]]. So,
# passing -version-info 3:12:1 sets current to 3, revision to 12, and age to
# 1.
#
# If either revision or age are omitted, they default to 0. Also note that age
# must be less than or equal to the current interface number.
#
# Here are a set of rules to help you update your library version information:
#
# 1.Start with version information of 0:0:0 for each libtool library.
#
# 2.Update the version information only immediately before a public release of
# your software. More frequent updates are unnecessary, and only guarantee
# that the current interface number gets larger faster.
#
# 3.If the library source code has changed at all since the last update, then
# increment revision (c:r+1:a)
#
# 4.If any interfaces have been added, removed, or changed since the last
# update, increment current, and set revision to 0. (c+1:r=0:a)
#
# 5.If any interfaces have been added since the last public release, then
# increment age. (c:r:a+1)
#
# 6.If any interfaces have been removed since the last public release, then
# set age to 0. (c:r:a=0)
#
libcares_la_LDFLAGS = $(VER)
# Makefile.inc provides the CSOURCES and HHEADERS defines
include Makefile.inc
libcares_la_SOURCES = $(CSOURCES) $(HHEADERS)
# where to install the c-ares headers
libcares_ladir = $(includedir)
# what headers to install on 'make install':
libcares_la_HEADERS = ares.h ares_version.h

50
ares/Makefile.dj Normal file
View File

@@ -0,0 +1,50 @@
#
# c-ares Makefile for djgpp/gcc/Watt-32.
# By Gisle Vanem <giva@bgnett.no> 2004.
#
.SUFFIXES: .exe
include Makefile.inc
WATT32_ROOT = $(subst \,/,$(WATT_ROOT))
CC = gcc
CFLAGS = -O2 -Wall -DWATT32 -Dselect=select_s -I$(WATT32_ROOT)/inc
LDFLAGS = -s
EX_LIBS = $(WATT32_ROOT)/lib/libwatt.a
OBJ_DIR = djgpp
OBJECTS = $(addprefix $(OBJ_DIR)/, $(CSOURCES:.c=.o))
all: $(OBJ_DIR) libcares.a ahost.exe adig.exe
@echo Welcome to c-ares.
$(OBJ_DIR):
- mkdir $(OBJ_DIR)
libcares.a: $(OBJECTS)
ar rs $@ $?
ahost.exe: ahost.c libcares.a
$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS)
adig.exe: adig.c libcares.a
$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $^ $(EX_LIBS)
clean:
rm -f $(OBJECTS) libcares.a
vclean realclean: clean
rm -f ahost.exe adig.exe depend.dj
- rmdir $(OBJ_DIR)
$(OBJ_DIR)/%.o: %.c
$(CC) $(CFLAGS) -o $@ -c $<
@echo
depend:
$(CC) -MM $(CFLAGS) $(CSOURCES) | \
sed -e 's/^\([a-zA-Z0-9_-]*\.o:\)/$$(OBJ_DIR)\/\1/' > depend.dj
-include depend.dj

View File

@@ -1,79 +0,0 @@
# $Id$
SHELL=/bin/sh
INSTALL=@INSTALL@
RANLIB=@RANLIB@
VPATH=@srcdir@
srcdir=@srcdir@
top_srcdir=@top_srcdir@
prefix=@prefix@
exec_prefix=@exec_prefix@
libdir=@libdir@
includedir=@includedir@
mandir=@mandir@
LIB=libcares.a
CC=@CC@
CPPFLAGS=@CPPFLAGS@
CFLAGS=@CFLAGS@ ${WARN_CFLAGS} ${ERROR_CFLAGS}
DEFS=@DEFS@
LDFLAGS=@LDFLAGS@
LIBS=@LIBS@
ALL_CFLAGS=${CPPFLAGS} ${CFLAGS} ${DEFS}
OBJS= ares__close_sockets.o ares__get_hostent.o ares__read_line.o \
ares_destroy.o ares_expand_name.o ares_fds.o \
ares_free_hostent.o ares_free_string.o ares_gethostbyaddr.o \
ares_gethostbyname.o ares_init.o ares_mkquery.o ares_parse_a_reply.o \
ares_parse_ptr_reply.o ares_process.o ares_query.o ares_search.o \
ares_send.o ares_strerror.o ares_timeout.o ares_version.o \
ares_expand_string.o ares_cancel.o
MANPAGES= ares_destroy.3 ares_expand_name.3 ares_expand_string.3 ares_fds.3 \
ares_free_hostent.3 ares_free_string.3 ares_gethostbyaddr.3 \
ares_gethostbyname.3 ares_init.3 ares_init_options.3 ares_mkquery.3 \
ares_parse_a_reply.3 ares_parse_ptr_reply.3 ares_process.3 \
ares_query.3 ares_search.3 ares_send.3 ares_strerror.3 ares_timeout.3 \
ares_version.3 ares_cancel.3
$(LIB): ${OBJS}
ar cru $@ ${OBJS}
${RANLIB} $@
all: $(LIB) demos
demos: adig ahost
tags:
etags *.[ch]
adig: adig.o $(LIB)
${CC} ${LDFLAGS} -o $@ adig.o $(LIB) ${LIBS}
ahost: ahost.o $(LIB)
${CC} ${LDFLAGS} -o $@ ahost.o $(LIB) ${LIBS}
${OBJS}: ares.h ares_dns.h ares_private.h
.c.o:
${CC} -c ${ALL_CFLAGS} $<
check:
install:
${top_srcdir}/mkinstalldirs ${DESTDIR}${libdir}
${top_srcdir}/mkinstalldirs ${DESTDIR}${includedir}
${top_srcdir}/mkinstalldirs ${DESTDIR}${mandir}/man3
${INSTALL} -m 644 $(LIB) ${DESTDIR}${libdir}
${RANLIB} ${DESTDIR}${libdir}/$(LIB)
chmod u-w ${DESTDIR}${libdir}/$(LIB)
${INSTALL} -m 444 ${srcdir}/ares.h ${DESTDIR}${includedir}
${INSTALL} -m 444 ${srcdir}/ares_version.h ${DESTDIR}${includedir}
(for man in $(MANPAGES); do \
${INSTALL} -m 444 ${srcdir}/$${man} ${DESTDIR}${mandir}/man3; \
done)
clean:
rm -f ${OBJS} $(LIB) adig.o adig ahost.o ahost
distclean: clean
rm -f config.cache config.log config.status Makefile

15
ares/Makefile.inc Normal file
View File

@@ -0,0 +1,15 @@
CSOURCES = ares_fds.c ares_process.c ares_free_hostent.c ares_query.c \
ares__close_sockets.c ares_free_string.c ares_search.c ares__get_hostent.c \
ares_gethostbyaddr.c ares_send.c ares__read_line.c ares_gethostbyname.c \
ares_strerror.c ares_cancel.c ares_init.c ares_timeout.c ares_destroy.c \
ares_mkquery.c ares_version.c ares_expand_name.c ares_parse_a_reply.c \
windows_port.c ares_expand_string.c ares_parse_ptr_reply.c
HHEADERS = ares.h ares_private.h setup.h ares_dns.h ares_version.h nameser.h
MANPAGES= ares_destroy.3 ares_expand_name.3 ares_expand_string.3 ares_fds.3 \
ares_free_hostent.3 ares_free_string.3 ares_gethostbyaddr.3 \
ares_gethostbyname.3 ares_init.3 ares_init_options.3 ares_mkquery.3 \
ares_parse_a_reply.3 ares_parse_ptr_reply.3 ares_process.3 \
ares_query.3 ares_search.3 ares_send.3 ares_strerror.3 ares_timeout.3 \
ares_version.3 ares_cancel.3

75
ares/Makefile.m32 Normal file
View File

@@ -0,0 +1,75 @@
#############################################################
# $Id$
#
## Makefile for building libcares.a with MingW32 (GCC-3.2)
## Use: make -f Makefile.m32 [demos]
##
## Quick hack by Guenter; comments to: /dev/nul
CC = gcc
AR = ar
RANLIB = ranlib
STRIP = strip -g
#RM = rm -f
########################################################
## Nothing more to do below this line!
LIB=libcares.a
CC=gcc
#CPPFLAGS=@CPPFLAGS@
WARN_FLAGS=-Wall
CFLAGS=-O2
CFLAGS+=${WARN_CFLAGS} ${ERROR_CFLAGS}
DEFS=-DMINGW32
LDFLAGS=-s
LIBS=-lwsock32
ALL_CFLAGS=${CPPFLAGS} ${CFLAGS} ${DEFS}
MANPAGES := $(patsubst %.c,%.o,$(wildcard ares_*.3))
OBJS := $(patsubst %.c,%.o,$(wildcard ares_*.c))
OBJS += windows_port.o
$(LIB): ${OBJS}
ar cru $@ ${OBJS}
${RANLIB} $@
all: $(LIB) demos
demos: adig.exe ahost.exe
tags:
etags *.[ch]
adig.exe: adig.o $(LIB)
${CC} ${LDFLAGS} -o $@ adig.o $(LIB) ${LIBS}
ahost.exe: ahost.o $(LIB)
${CC} ${LDFLAGS} -o $@ ahost.o $(LIB) ${LIBS}
${OBJS}: ares.h ares_dns.h ares_private.h
.c.o:
${CC} -c ${ALL_CFLAGS} $<
check:
install:
${top_srcdir}/mkinstalldirs ${DESTDIR}${libdir}
${top_srcdir}/mkinstalldirs ${DESTDIR}${includedir}
${top_srcdir}/mkinstalldirs ${DESTDIR}${mandir}/man3
${INSTALL} -m 644 $(LIB) ${DESTDIR}${libdir}
${RANLIB} ${DESTDIR}${libdir}/$(LIB)
chmod u-w ${DESTDIR}${libdir}/$(LIB)
${INSTALL} -m 444 ${srcdir}/ares.h ${DESTDIR}${includedir}
${INSTALL} -m 444 ${srcdir}/ares_version.h ${DESTDIR}${includedir}
(for man in $(MANPAGES); do \
${INSTALL} -m 444 ${srcdir}/$${man} ${DESTDIR}${mandir}/man3; \
done)
clean:
rm -f ${OBJS} $(LIB) adig.o adig.exe ahost.o ahost.exe
distclean: clean
rm -f config.cache config.log config.status Makefile

317
ares/Makefile.netware Normal file
View File

@@ -0,0 +1,317 @@
#################################################################
#
## Makefile for building libares.lib (NetWare version - gnu make)
## Use: make -f Makefile.netware
##
## Comments to: Guenter Knauf <eflash@gmx.net>
#
#################################################################
# Edit the path below to point to the base of your Novell NDK.
ifndef NDKBASE
NDKBASE = c:/novell
endif
ifndef INSTDIR
INSTDIR = ../curl-$(LIBCURL_VERSION_STR)-bin-nw
endif
# Edit the vars below to change NLM target settings.
TARGETS = adig.nlm ahost.nlm
LTARGET = libcares.lib
VERSION = $(LIBCARES_VERSION)
COPYR = Copyright (c) 1996 - 2004, Daniel Stenberg, <daniel@haxx.se>
DESCR = cURL $(subst .def,,$(notdir $@)) $(LIBCARES_VERSION_STR) - http://curl.haxx.se
MTSAFE = YES
STACK = 64000
SCREEN = none
#EXPORTS =
# Comment the line below if you dont want to load protected automatically.
#LDRING = 3
# Edit the var below to point to your lib architecture.
ifndef LIBARCH
LIBARCH = LIBC
endif
# must be equal to DEBUG or NDEBUG
DB = NDEBUG
# DB = DEBUG
# DB = CURLDEBUG
# Optimization: -O<n> or debugging: -g
ifeq ($(DB),NDEBUG)
OPT = -O2
OBJDIR = release
else
OPT = -g
OBJDIR = debug
endif
# Include the version info retrieved from curlver.h
-include $(OBJDIR)/version.inc
# The following line defines your compiler.
ifdef METROWERKS
CC = mwccnlm
else
CC = gcc
endif
YACC = bison -y
CP = cp -afv
# RM = rm -f
# if you want to mark the target as MTSAFE you will need a tool for
# generating the xdc data for the linker; here's a minimal tool:
# http://www.gknw.com/development/prgtools/mkxdc.zip
MPKXDC = mkxdc
# Global flags for all compilers
CFLAGS = $(OPT) -D$(DB) -DNETWARE -DHAVE_CONFIG_H -nostdinc
ifeq ($(CC),mwccnlm)
LD = mwldnlm
LDFLAGS = -nostdlib $(PRELUDE) $(OBJS) $(<:.def=.o) -o $@ -commandfile
AR = mwldnlm
ARFLAGS = -type library -w nocmdline $(OBJDIR)/*.o -o
CFLAGS += -msgstyle gcc -gccinc -inline off -opt nointrinsics -proc 586
CFLAGS += -relax_pointers
#CFLAGS += -w on
ifeq ($(LIBARCH),LIBC)
PRELUDE = $(SDK_LIBC)/imports/libcpre.o
CFLAGS += -align 4
else
PRELUDE = "$(METROWERKS)/Novell Support/libraries/runtime/prelude.obj"
# CFLAGS += -include "$(METROWERKS)/Novell Support/headers/nlm_prefix.h"
CFLAGS += -align 1
endif
else
LD = nlmconv
LDFLAGS = -T
AR = ar
ARFLAGS = -cq
CFLAGS += -fno-builtin -fpack-struct -fpcc-struct-return -fno-strict-aliasing
CFLAGS += -Wall -Wno-format # -pedantic
ifeq ($(LIBARCH),LIBC)
PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o
else
PRELUDE = $(SDK_CLIB)/imports/clibpre.gcc.o
CFLAGS += -include $(NDKBASE)/nlmconv/genlm.h
endif
endif
NDK_ROOT = $(NDKBASE)/ndk
SDK_CLIB = $(NDK_ROOT)/nwsdk
SDK_LIBC = $(NDK_ROOT)/libc
ifeq ($(LIBARCH),LIBC)
INCLUDES += -I$(SDK_LIBC)/include -I$(SDK_LIBC)/include/nks
INCLUDES += -I$(SDK_LIBC)/include/winsock
CFLAGS += -D_POSIX_SOURCE
# CFLAGS += -D__ANSIC__
else
INCLUDES += -I$(SDK_CLIB)/include/nlm -I$(SDK_CLIB)/include
# INCLUDES += -I$(SDK_CLIB)/include/nlm/obsolete
CFLAGS += -DNETDB_USE_INTERNET
endif
CFLAGS += -I. $(INCLUDES)
ifeq ($(MTSAFE),YES)
XDCOPT = -n
endif
ifeq ($(MTSAFE),NO)
XDCOPT = -u
endif
ifeq ($(findstring linux,$(OSTYPE)),linux)
DL = '
#-include $(NDKBASE)/nlmconv/ncpfs.inc
endif
OBJS := $(patsubst %.c,$(OBJDIR)/%.o,$(wildcard ares_*.c))
.PHONY: lib nlm prebuild dist install clean
lib: prebuild $(LTARGET)
nlm: prebuild $(TARGETS)
prebuild: $(OBJDIR) $(OBJDIR)/version.inc config.h arpa/nameser.h
dist: all
-$(RM) $(OBJS) $(OBJDIR)/*.map $(OBJDIR)/*.ncv
-$(RM) $(OBJDIR)/*.def $(OBJDIR)/*.xdc $(OBJDIR)/version.inc
install: $(INSTDIR) all
@$(CP) *.nlm $(INSTDIR)
@$(CP) ../CHANGES $(INSTDIR)
@$(CP) ../COPYING $(INSTDIR)
@$(CP) ../README $(INSTDIR)
@$(CP) ../RELEASE-NOTES $(INSTDIR)
clean:
-$(RM) $(LTARGET) $(TARGETS) config.h
-$(RM) -r $(OBJDIR)
-$(RM) -r arpa
%.lib: $(OBJS)
@echo Creating $@
@-$(RM) $@
@$(AR) $(ARFLAGS) $@ $^
%.nlm: $(OBJDIR)/%.def $(OBJDIR)/%.o $(OBJDIR)/%.xdc $(OBJS)
@echo Linking $@
@-$(RM) $@
@$(LD) $(LDFLAGS) $<
$(INSTDIR):
@mkdir $(INSTDIR)
$(OBJDIR):
@mkdir $(OBJDIR)
$(OBJDIR)/%.o: %.c
# @echo Compiling $<
$(CC) $(CFLAGS) -c $< -o $@
$(OBJDIR)/version.inc: ares_version.h $(OBJDIR)
@echo Creating $@
@awk -f ../packages/NetWare/get_ver.awk $< > $@
$(OBJDIR)/%.xdc: Makefile.netware
@echo Creating $@
@$(MPKXDC) $(XDCOPT) $@
$(OBJDIR)/%.def: Makefile.netware
@echo Creating $@
@echo $(DL)# DEF file for linking with $(LD)$(DL) > $@
@echo $(DL)# Do not edit this file - it is created by make!$(DL) >> $@
@echo $(DL)# All your changes will be lost!!$(DL) >> $@
@echo $(DL)#$(DL) >> $@
@echo $(DL)copyright "$(COPYR)"$(DL) >> $@
@echo $(DL)description "$(DESCR)"$(DL) >> $@
@echo $(DL)version $(VERSION)$(DL) >> $@
ifdef NLMTYPE
@echo $(DL)type $(NLMTYPE)$(DL) >> $@
endif
ifdef STACK
@echo $(DL)stack $(STACK)$(DL) >> $@
endif
ifdef SCREEN
@echo $(DL)screenname "$(SCREEN)"$(DL) >> $@
else
@echo $(DL)screenname "DEFAULT"$(DL) >> $@
endif
ifeq ($(DB),DEBUG)
@echo $(DL)debug$(DL) >> $@
endif
@echo $(DL)threadname "$^"$(DL) >> $@
ifdef XDCOPT
@echo $(DL)xdcdata $(@:.def=.xdc)$(DL) >> $@
endif
ifeq ($(LDRING),0)
@echo $(DL)flag_on 16$(DL) >> $@
endif
ifeq ($(LDRING),3)
@echo $(DL)flag_on 512$(DL) >> $@
endif
ifeq ($(LIBARCH),CLIB)
@echo $(DL)start _Prelude$(DL) >> $@
@echo $(DL)exit _Stop$(DL) >> $@
@echo $(DL)import @$(SDK_CLIB)/imports/clib.imp$(DL) >> $@
@echo $(DL)import @$(SDK_CLIB)/imports/threads.imp$(DL) >> $@
@echo $(DL)import @$(SDK_CLIB)/imports/nlmlib.imp$(DL) >> $@
@echo $(DL)import @$(SDK_CLIB)/imports/socklib.imp$(DL) >> $@
@echo $(DL)module clib$(DL) >> $@
else
@echo $(DL)flag_on 64$(DL) >> $@
@echo $(DL)pseudopreemption$(DL) >> $@
@echo $(DL)start _LibCPrelude$(DL) >> $@
@echo $(DL)exit _LibCPostlude$(DL) >> $@
@echo $(DL)check _LibCCheckUnload$(DL) >> $@
@echo $(DL)import @$(SDK_LIBC)/imports/libc.imp$(DL) >> $@
@echo $(DL)import @$(SDK_LIBC)/imports/netware.imp$(DL) >> $@
@echo $(DL)module libc$(DL) >> $@
endif
ifdef MODULES
@echo $(DL)module $(MODULES)$(DL) >> $@
endif
ifdef EXPORTS
@echo $(DL)export $(EXPORTS)$(DL) >> $@
endif
ifdef IMPORTS
@echo $(DL)import $(IMPORTS)$(DL) >> $@
endif
ifeq ($(LD),nlmconv)
@echo $(DL)input $(OBJS)$(DL) >> $@
@echo $(DL)input $(PRELUDE)$(DL) >> $@
@echo $(DL)output $(notdir $(@:.def=.nlm))$(DL) >> $@
endif
config.h: Makefile.netware
@echo Creating $@
@echo $(DL)/* $@ for NetWare target.$(DL) > $@
@echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@
@echo $(DL)** All your changes will be lost!!$(DL) >> $@
@echo $(DL)*/$(DL) >> $@
@echo $(DL)#define OS "i586-pc-NetWare"$(DL) >> $@
@echo $(DL)#define VERSION "$(LIBCURL_VERSION_STR)"$(DL) >> $@
@echo $(DL)#define PACKAGE_BUGREPORT "curl-bug@haxx.se"$(DL) >> $@
@echo $(DL)#define HAVE_ARPA_INET_H 1$(DL) >> $@
@echo $(DL)#define HAVE_ASSERT_H 1$(DL) >> $@
@echo $(DL)#define HAVE_DLFCN_H 1$(DL) >> $@
@echo $(DL)#define HAVE_DLOPEN 1$(DL) >> $@
@echo $(DL)#define HAVE_ERR_H 1$(DL) >> $@
@echo $(DL)#define HAVE_FCNTL_H 1$(DL) >> $@
@echo $(DL)#define HAVE_FIONBIO 1$(DL) >> $@
@echo $(DL)#define HAVE_GETHOSTBYADDR 1$(DL) >> $@
@echo $(DL)#define HAVE_GETTIMEOFDAY 1$(DL) >> $@
@echo $(DL)#define HAVE_INET_ADDR 1$(DL) >> $@
@echo $(DL)#define HAVE_INET_NTOA 1$(DL) >> $@
@echo $(DL)#define HAVE_INET_PTON 1$(DL) >> $@
@echo $(DL)#define HAVE_INTTYPES_H 1$(DL) >> $@
@echo $(DL)#define HAVE_LIMITS_H 1$(DL) >> $@
@echo $(DL)#define HAVE_LONGLONG 1$(DL) >> $@
@echo $(DL)#define HAVE_MALLOC_H 1$(DL) >> $@
@echo $(DL)#define HAVE_NETINET_IN_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SELECT 1$(DL) >> $@
@echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@
@echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@
@echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@
@echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@
@echo $(DL)#define HAVE_STRCASECMP 1$(DL) >> $@
@echo $(DL)#define HAVE_STRDUP 1$(DL) >> $@
@echo $(DL)#define HAVE_STRFTIME 1$(DL) >> $@
@echo $(DL)#define HAVE_STRING_H 1$(DL) >> $@
@echo $(DL)#define HAVE_STRLCAT 1$(DL) >> $@
@echo $(DL)#define HAVE_STRLCPY 1$(DL) >> $@
@echo $(DL)#define HAVE_STRSTR 1$(DL) >> $@
@echo $(DL)#define HAVE_SYS_PARAM_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SYS_SELECT_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SYS_STAT_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SYS_TIME_H 1$(DL) >> $@
@echo $(DL)#define HAVE_TERMIOS_H 1$(DL) >> $@
@echo $(DL)#define HAVE_TIME_H 1$(DL) >> $@
@echo $(DL)#define HAVE_UNAME 1$(DL) >> $@
@echo $(DL)#define HAVE_UNISTD_H 1$(DL) >> $@
@echo $(DL)#define RETSIGTYPE void$(DL) >> $@
@echo $(DL)#define SIZEOF_CURL_OFF_T 4$(DL) >> $@
@echo $(DL)#define STDC_HEADERS 1$(DL) >> $@
@echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@
ifdef NW_WINSOCK
@echo $(DL)#define HAVE_CLOSESOCKET 1$(DL) >> $@
else
@echo $(DL)#define HAVE_SYS_TYPES_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SYS_SOCKET_H 1$(DL) >> $@
@echo $(DL)#define HAVE_SYS_SOCKIO_H 1$(DL) >> $@
@echo $(DL)#define HAVE_NETDB_H 1$(DL) >> $@
endif
ifdef OLD_NOVELLSDK
@echo $(DL)#define socklen_t int$(DL) >> $@
endif
arpa/nameser.h: nameser.h
@echo Fix missing header $@
@-mkdir arpa
@$(CP) $< arpa

View File

@@ -1,3 +1,6 @@
Major changes since:
* see the CHANGES file
Major changes in release 1.1.1: Major changes in release 1.1.1:
* ares should now compile as C++ code (no longer uses reserved word * ares should now compile as C++ code (no longer uses reserved word
"class"). "class").

View File

@@ -13,6 +13,7 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #ifdef WIN32
@@ -36,7 +37,7 @@
#include "ares_dns.h" #include "ares_dns.h"
#ifndef INADDR_NONE #ifndef INADDR_NONE
#define INADDR_NONE 0xffffffff #define INADDR_NONE 0xffffffff
#endif #endif
/* Mac OS X portability check */ /* Mac OS X portability check */
@@ -53,58 +54,58 @@ struct nv {
}; };
static const struct nv flags[] = { static const struct nv flags[] = {
{ "usevc", ARES_FLAG_USEVC }, { "usevc", ARES_FLAG_USEVC },
{ "primary", ARES_FLAG_PRIMARY }, { "primary", ARES_FLAG_PRIMARY },
{ "igntc", ARES_FLAG_IGNTC }, { "igntc", ARES_FLAG_IGNTC },
{ "norecurse", ARES_FLAG_NORECURSE }, { "norecurse", ARES_FLAG_NORECURSE },
{ "stayopen", ARES_FLAG_STAYOPEN }, { "stayopen", ARES_FLAG_STAYOPEN },
{ "noaliases", ARES_FLAG_NOALIASES } { "noaliases", ARES_FLAG_NOALIASES }
}; };
static const int nflags = sizeof(flags) / sizeof(flags[0]); static const int nflags = sizeof(flags) / sizeof(flags[0]);
static const struct nv classes[] = { static const struct nv classes[] = {
{ "IN", C_IN }, { "IN", C_IN },
{ "CHAOS", C_CHAOS }, { "CHAOS", C_CHAOS },
{ "HS", C_HS }, { "HS", C_HS },
{ "ANY", C_ANY } { "ANY", C_ANY }
}; };
static const int nclasses = sizeof(classes) / sizeof(classes[0]); static const int nclasses = sizeof(classes) / sizeof(classes[0]);
static const struct nv types[] = { static const struct nv types[] = {
{ "A", T_A }, { "A", T_A },
{ "NS", T_NS }, { "NS", T_NS },
{ "MD", T_MD }, { "MD", T_MD },
{ "MF", T_MF }, { "MF", T_MF },
{ "CNAME", T_CNAME }, { "CNAME", T_CNAME },
{ "SOA", T_SOA }, { "SOA", T_SOA },
{ "MB", T_MB }, { "MB", T_MB },
{ "MG", T_MG }, { "MG", T_MG },
{ "MR", T_MR }, { "MR", T_MR },
{ "NULL", T_NULL }, { "NULL", T_NULL },
{ "WKS", T_WKS }, { "WKS", T_WKS },
{ "PTR", T_PTR }, { "PTR", T_PTR },
{ "HINFO", T_HINFO }, { "HINFO", T_HINFO },
{ "MINFO", T_MINFO }, { "MINFO", T_MINFO },
{ "MX", T_MX }, { "MX", T_MX },
{ "TXT", T_TXT }, { "TXT", T_TXT },
{ "RP", T_RP }, { "RP", T_RP },
{ "AFSDB", T_AFSDB }, { "AFSDB", T_AFSDB },
{ "X25", T_X25 }, { "X25", T_X25 },
{ "ISDN", T_ISDN }, { "ISDN", T_ISDN },
{ "RT", T_RT }, { "RT", T_RT },
{ "NSAP", T_NSAP }, { "NSAP", T_NSAP },
{ "NSAP_PTR", T_NSAP_PTR }, { "NSAP_PTR", T_NSAP_PTR },
{ "SIG", T_SIG }, { "SIG", T_SIG },
{ "KEY", T_KEY }, { "KEY", T_KEY },
{ "PX", T_PX }, { "PX", T_PX },
{ "GPOS", T_GPOS }, { "GPOS", T_GPOS },
{ "AAAA", T_AAAA }, { "AAAA", T_AAAA },
{ "LOC", T_LOC }, { "LOC", T_LOC },
{ "SRV", T_SRV }, { "SRV", T_SRV },
{ "AXFR", T_AXFR }, { "AXFR", T_AXFR },
{ "MAILB", T_MAILB }, { "MAILB", T_MAILB },
{ "MAILA", T_MAILA }, { "MAILA", T_MAILA },
{ "ANY", T_ANY } { "ANY", T_ANY }
}; };
static const int ntypes = sizeof(types) / sizeof(types[0]); static const int ntypes = sizeof(types) / sizeof(types[0]);
@@ -123,10 +124,10 @@ static const char *rcodes[] = {
static void callback(void *arg, int status, unsigned char *abuf, int alen); static void callback(void *arg, int status, unsigned char *abuf, int alen);
static const unsigned char *display_question(const unsigned char *aptr, static const unsigned char *display_question(const unsigned char *aptr,
const unsigned char *abuf, const unsigned char *abuf,
int alen); int alen);
static const unsigned char *display_rr(const unsigned char *aptr, static const unsigned char *display_rr(const unsigned char *aptr,
const unsigned char *abuf, int alen); const unsigned char *abuf, int alen);
static const char *type_name(int type); static const char *type_name(int type);
static const char *class_name(int dnsclass); static const char *class_name(int dnsclass);
static void usage(void); static void usage(void);
@@ -145,7 +146,7 @@ int main(int argc, char **argv)
WORD wVersionRequested = MAKEWORD(1,1); WORD wVersionRequested = MAKEWORD(1,1);
WSADATA wsaData; WSADATA wsaData;
WSAStartup(wVersionRequested, &wsaData); WSAStartup(wVersionRequested, &wsaData);
#endif #endif
options.flags = ARES_FLAG_NOCHECKRESP; options.flags = ARES_FLAG_NOCHECKRESP;
options.servers = NULL; options.servers = NULL;
@@ -153,80 +154,80 @@ int main(int argc, char **argv)
while ((c = getopt(argc, argv, "f:s:c:t:T:U:")) != -1) while ((c = getopt(argc, argv, "f:s:c:t:T:U:")) != -1)
{ {
switch (c) switch (c)
{ {
case 'f': case 'f':
/* Add a flag. */ /* Add a flag. */
for (i = 0; i < nflags; i++) for (i = 0; i < nflags; i++)
{ {
if (strcmp(flags[i].name, optarg) == 0) if (strcmp(flags[i].name, optarg) == 0)
break; break;
} }
if (i == nflags) if (i == nflags)
usage(); usage();
options.flags |= flags[i].value; options.flags |= flags[i].value;
break; break;
case 's': case 's':
/* Add a server, and specify servers in the option mask. */ /* Add a server, and specify servers in the option mask. */
hostent = gethostbyname(optarg); hostent = gethostbyname(optarg);
if (!hostent || hostent->h_addrtype != AF_INET) if (!hostent || hostent->h_addrtype != AF_INET)
{ {
fprintf(stderr, "adig: server %s not found.\n", optarg); fprintf(stderr, "adig: server %s not found.\n", optarg);
return 1; return 1;
} }
options.servers = realloc(options.servers, (options.nservers + 1) options.servers = realloc(options.servers, (options.nservers + 1)
* sizeof(struct in_addr)); * sizeof(struct in_addr));
if (!options.servers) if (!options.servers)
{ {
fprintf(stderr, "Out of memory!\n"); fprintf(stderr, "Out of memory!\n");
return 1; return 1;
} }
memcpy(&options.servers[options.nservers], hostent->h_addr, memcpy(&options.servers[options.nservers], hostent->h_addr,
sizeof(struct in_addr)); sizeof(struct in_addr));
options.nservers++; options.nservers++;
optmask |= ARES_OPT_SERVERS; optmask |= ARES_OPT_SERVERS;
break; break;
case 'c': case 'c':
/* Set the query class. */ /* Set the query class. */
for (i = 0; i < nclasses; i++) for (i = 0; i < nclasses; i++)
{ {
if (strcasecmp(classes[i].name, optarg) == 0) if (strcasecmp(classes[i].name, optarg) == 0)
break; break;
} }
if (i == nclasses) if (i == nclasses)
usage(); usage();
dnsclass = classes[i].value; dnsclass = classes[i].value;
break; break;
case 't': case 't':
/* Set the query type. */ /* Set the query type. */
for (i = 0; i < ntypes; i++) for (i = 0; i < ntypes; i++)
{ {
if (strcasecmp(types[i].name, optarg) == 0) if (strcasecmp(types[i].name, optarg) == 0)
break; break;
} }
if (i == ntypes) if (i == ntypes)
usage(); usage();
type = types[i].value; type = types[i].value;
break; break;
case 'T': case 'T':
/* Set the TCP port number. */ /* Set the TCP port number. */
if (!isdigit((unsigned char)*optarg)) if (!isdigit((unsigned char)*optarg))
usage(); usage();
options.tcp_port = strtol(optarg, NULL, 0); options.tcp_port = strtol(optarg, NULL, 0);
optmask |= ARES_OPT_TCP_PORT; optmask |= ARES_OPT_TCP_PORT;
break; break;
case 'U': case 'U':
/* Set the UDP port number. */ /* Set the UDP port number. */
if (!isdigit((unsigned char)*optarg)) if (!isdigit((unsigned char)*optarg))
usage(); usage();
options.udp_port = strtol(optarg, NULL, 0); options.udp_port = strtol(optarg, NULL, 0);
optmask |= ARES_OPT_UDP_PORT; optmask |= ARES_OPT_UDP_PORT;
break; break;
} }
} }
argc -= optind; argc -= optind;
argv += optind; argv += optind;
@@ -238,7 +239,7 @@ int main(int argc, char **argv)
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
{ {
fprintf(stderr, "ares_init_options: %s\n", fprintf(stderr, "ares_init_options: %s\n",
ares_strerror(status)); ares_strerror(status));
return 1; return 1;
} }
@@ -252,7 +253,7 @@ int main(int argc, char **argv)
else else
{ {
for (; *argv; argv++) for (; *argv; argv++)
ares_query(channel, *argv, dnsclass, type, callback, *argv); ares_query(channel, *argv, dnsclass, type, callback, *argv);
} }
/* Wait for all queries to complete. */ /* Wait for all queries to complete. */
@@ -262,14 +263,14 @@ int main(int argc, char **argv)
FD_ZERO(&write_fds); FD_ZERO(&write_fds);
nfds = ares_fds(channel, &read_fds, &write_fds); nfds = ares_fds(channel, &read_fds, &write_fds);
if (nfds == 0) if (nfds == 0)
break; break;
tvp = ares_timeout(channel, NULL, &tv); tvp = ares_timeout(channel, NULL, &tv);
count = select(nfds, &read_fds, &write_fds, NULL, tvp); count = select(nfds, &read_fds, &write_fds, NULL, tvp);
if (count < 0 && errno != EINVAL) if (count < 0 && errno != EINVAL)
{ {
perror("select"); perror("select");
return 1; return 1;
} }
ares_process(channel, &read_fds, &write_fds); ares_process(channel, &read_fds, &write_fds);
} }
@@ -295,7 +296,7 @@ static void callback(void *arg, int status, unsigned char *abuf, int alen)
{ {
printf("%s\n", ares_strerror(status)); printf("%s\n", ares_strerror(status));
if (!abuf) if (!abuf)
return; return;
} }
/* Won't happen, but check anyway, for safety. */ /* Won't happen, but check anyway, for safety. */
@@ -319,11 +320,11 @@ static void callback(void *arg, int status, unsigned char *abuf, int alen)
/* Display the answer header. */ /* Display the answer header. */
printf("id: %d\n", id); printf("id: %d\n", id);
printf("flags: %s%s%s%s%s\n", printf("flags: %s%s%s%s%s\n",
qr ? "qr " : "", qr ? "qr " : "",
aa ? "aa " : "", aa ? "aa " : "",
tc ? "tc " : "", tc ? "tc " : "",
rd ? "rd " : "", rd ? "rd " : "",
ra ? "ra " : ""); ra ? "ra " : "");
printf("opcode: %s\n", opcodes[opcode]); printf("opcode: %s\n", opcodes[opcode]);
printf("rcode: %s\n", rcodes[rcode]); printf("rcode: %s\n", rcodes[rcode]);
@@ -334,7 +335,7 @@ static void callback(void *arg, int status, unsigned char *abuf, int alen)
{ {
aptr = display_question(aptr, abuf, alen); aptr = display_question(aptr, abuf, alen);
if (aptr == NULL) if (aptr == NULL)
return; return;
} }
/* Display the answers. */ /* Display the answers. */
@@ -343,7 +344,7 @@ static void callback(void *arg, int status, unsigned char *abuf, int alen)
{ {
aptr = display_rr(aptr, abuf, alen); aptr = display_rr(aptr, abuf, alen);
if (aptr == NULL) if (aptr == NULL)
return; return;
} }
/* Display the NS records. */ /* Display the NS records. */
@@ -352,7 +353,7 @@ static void callback(void *arg, int status, unsigned char *abuf, int alen)
{ {
aptr = display_rr(aptr, abuf, alen); aptr = display_rr(aptr, abuf, alen);
if (aptr == NULL) if (aptr == NULL)
return; return;
} }
/* Display the additional records. */ /* Display the additional records. */
@@ -361,13 +362,13 @@ static void callback(void *arg, int status, unsigned char *abuf, int alen)
{ {
aptr = display_rr(aptr, abuf, alen); aptr = display_rr(aptr, abuf, alen);
if (aptr == NULL) if (aptr == NULL)
return; return;
} }
} }
static const unsigned char *display_question(const unsigned char *aptr, static const unsigned char *display_question(const unsigned char *aptr,
const unsigned char *abuf, const unsigned char *abuf,
int alen) int alen)
{ {
char *name; char *name;
int type, dnsclass, status; int type, dnsclass, status;
@@ -405,7 +406,7 @@ static const unsigned char *display_question(const unsigned char *aptr,
} }
static const unsigned char *display_rr(const unsigned char *aptr, static const unsigned char *display_rr(const unsigned char *aptr,
const unsigned char *abuf, int alen) const unsigned char *abuf, int alen)
{ {
const unsigned char *p; const unsigned char *p;
char *name; char *name;
@@ -462,7 +463,7 @@ static const unsigned char *display_rr(const unsigned char *aptr,
/* For these types, the RR data is just a domain name. */ /* For these types, the RR data is just a domain name. */
status = ares_expand_name(aptr, abuf, alen, &name, &len); status = ares_expand_name(aptr, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t%s.", name); printf("\t%s.", name);
free(name); free(name);
break; break;
@@ -472,12 +473,12 @@ static const unsigned char *display_rr(const unsigned char *aptr,
p = aptr; p = aptr;
len = *p; len = *p;
if (p + len + 1 > aptr + dlen) if (p + len + 1 > aptr + dlen)
return NULL; return NULL;
printf("\t%.*s", len, p + 1); printf("\t%.*s", len, p + 1);
p += len + 1; p += len + 1;
len = *p; len = *p;
if (p + len + 1 > aptr + dlen) if (p + len + 1 > aptr + dlen)
return NULL; return NULL;
printf("\t%.*s", len, p + 1); printf("\t%.*s", len, p + 1);
break; break;
@@ -486,13 +487,13 @@ static const unsigned char *display_rr(const unsigned char *aptr,
p = aptr; p = aptr;
status = ares_expand_name(p, abuf, alen, &name, &len); status = ares_expand_name(p, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t%s.", name); printf("\t%s.", name);
free(name); free(name);
p += len; p += len;
status = ares_expand_name(p, abuf, alen, &name, &len); status = ares_expand_name(p, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t%s.", name); printf("\t%s.", name);
free(name); free(name);
break; break;
@@ -502,11 +503,11 @@ static const unsigned char *display_rr(const unsigned char *aptr,
* then a domain name. * then a domain name.
*/ */
if (dlen < 2) if (dlen < 2)
return NULL; return NULL;
printf("\t%d", (aptr[0] << 8) | aptr[1]); printf("\t%d", (aptr[0] << 8) | aptr[1]);
status = ares_expand_name(aptr + 2, abuf, alen, &name, &len); status = ares_expand_name(aptr + 2, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t%s.", name); printf("\t%s.", name);
free(name); free(name);
break; break;
@@ -518,24 +519,24 @@ static const unsigned char *display_rr(const unsigned char *aptr,
p = aptr; p = aptr;
status = ares_expand_name(p, abuf, alen, &name, &len); status = ares_expand_name(p, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t%s.\n", name); printf("\t%s.\n", name);
free(name); free(name);
p += len; p += len;
status = ares_expand_name(p, abuf, alen, &name, &len); status = ares_expand_name(p, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t\t\t\t\t\t%s.\n", name); printf("\t\t\t\t\t\t%s.\n", name);
free(name); free(name);
p += len; p += len;
if (p + 20 > aptr + dlen) if (p + 20 > aptr + dlen)
return NULL; return NULL;
printf("\t\t\t\t\t\t( %d %d %d %d %d )", printf("\t\t\t\t\t\t( %d %d %d %d %d )",
(p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3], (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3],
(p[4] << 24) | (p[5] << 16) | (p[6] << 8) | p[7], (p[4] << 24) | (p[5] << 16) | (p[6] << 8) | p[7],
(p[8] << 24) | (p[9] << 16) | (p[10] << 8) | p[11], (p[8] << 24) | (p[9] << 16) | (p[10] << 8) | p[11],
(p[12] << 24) | (p[13] << 16) | (p[14] << 8) | p[15], (p[12] << 24) | (p[13] << 16) | (p[14] << 8) | p[15],
(p[16] << 24) | (p[17] << 16) | (p[18] << 8) | p[19]); (p[16] << 24) | (p[17] << 16) | (p[18] << 8) | p[19]);
break; break;
case T_TXT: case T_TXT:
@@ -543,19 +544,19 @@ static const unsigned char *display_rr(const unsigned char *aptr,
* strings. */ * strings. */
p = aptr; p = aptr;
while (p < aptr + dlen) while (p < aptr + dlen)
{ {
len = *p; len = *p;
if (p + len + 1 > aptr + dlen) if (p + len + 1 > aptr + dlen)
return NULL; return NULL;
printf("\t%.*s", len, p + 1); printf("\t%.*s", len, p + 1);
p += len + 1; p += len + 1;
} }
break; break;
case T_A: case T_A:
/* The RR data is a four-byte Internet address. */ /* The RR data is a four-byte Internet address. */
if (dlen != 4) if (dlen != 4)
return NULL; return NULL;
memcpy(&addr, aptr, sizeof(struct in_addr)); memcpy(&addr, aptr, sizeof(struct in_addr));
printf("\t%s", inet_ntoa(addr)); printf("\t%s", inet_ntoa(addr));
break; break;
@@ -568,18 +569,18 @@ static const unsigned char *display_rr(const unsigned char *aptr,
/* The RR data is three two-byte numbers representing the /* The RR data is three two-byte numbers representing the
* priority, weight, and port, followed by a domain name. * priority, weight, and port, followed by a domain name.
*/ */
printf("\t%d", DNS__16BIT(aptr)); printf("\t%d", DNS__16BIT(aptr));
printf(" %d", DNS__16BIT(aptr + 2)); printf(" %d", DNS__16BIT(aptr + 2));
printf(" %d", DNS__16BIT(aptr + 4)); printf(" %d", DNS__16BIT(aptr + 4));
status = ares_expand_name(aptr + 6, abuf, alen, &name, &len); status = ares_expand_name(aptr + 6, abuf, alen, &name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return NULL; return NULL;
printf("\t%s.", name); printf("\t%s.", name);
free(name); free(name);
break; break;
default: default:
printf("\t[Unknown RR; cannot parse]"); printf("\t[Unknown RR; cannot parse]");
} }
@@ -595,7 +596,7 @@ static const char *type_name(int type)
for (i = 0; i < ntypes; i++) for (i = 0; i < ntypes; i++)
{ {
if (types[i].value == type) if (types[i].value == type)
return types[i].name; return types[i].name;
} }
return "(unknown)"; return "(unknown)";
} }
@@ -607,7 +608,7 @@ static const char *class_name(int dnsclass)
for (i = 0; i < nclasses; i++) for (i = 0; i < nclasses; i++)
{ {
if (classes[i].value == dnsclass) if (classes[i].value == dnsclass)
return classes[i].name; return classes[i].name;
} }
return "(unknown)"; return "(unknown)";
} }
@@ -615,6 +616,6 @@ static const char *class_name(int dnsclass)
static void usage(void) static void usage(void)
{ {
fprintf(stderr, "usage: adig [-f flag] [-s server] [-c class] " fprintf(stderr, "usage: adig [-f flag] [-s server] [-c class] "
"[-t type] [-p port] name ...\n"); "[-t type] [-p port] name ...\n");
exit(1); exit(1);
} }

View File

@@ -13,6 +13,7 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #ifdef WIN32
@@ -32,7 +33,7 @@
#include "ares_dns.h" #include "ares_dns.h"
#ifndef INADDR_NONE #ifndef INADDR_NONE
#define INADDR_NONE 0xffffffff #define INADDR_NONE 0xffffffff
#endif #endif
static void callback(void *arg, int status, struct hostent *host); static void callback(void *arg, int status, struct hostent *host);
@@ -50,7 +51,7 @@ int main(int argc, char **argv)
WORD wVersionRequested = MAKEWORD(1,1); WORD wVersionRequested = MAKEWORD(1,1);
WSADATA wsaData; WSADATA wsaData;
WSAStartup(wVersionRequested, &wsaData); WSAStartup(wVersionRequested, &wsaData);
#endif #endif
if (argc <= 1) if (argc <= 1)
usage(); usage();
@@ -67,12 +68,12 @@ int main(int argc, char **argv)
{ {
addr.s_addr = inet_addr(*argv); addr.s_addr = inet_addr(*argv);
if (addr.s_addr == INADDR_NONE) if (addr.s_addr == INADDR_NONE)
ares_gethostbyname(channel, *argv, AF_INET, callback, *argv); ares_gethostbyname(channel, *argv, AF_INET, callback, *argv);
else else
{ {
ares_gethostbyaddr(channel, &addr, sizeof(addr), AF_INET, callback, ares_gethostbyaddr(channel, &addr, sizeof(addr), AF_INET, callback,
*argv); *argv);
} }
} }
/* Wait for all queries to complete. */ /* Wait for all queries to complete. */
@@ -82,7 +83,7 @@ int main(int argc, char **argv)
FD_ZERO(&write_fds); FD_ZERO(&write_fds);
nfds = ares_fds(channel, &read_fds, &write_fds); nfds = ares_fds(channel, &read_fds, &write_fds);
if (nfds == 0) if (nfds == 0)
break; break;
tvp = ares_timeout(channel, NULL, &tv); tvp = ares_timeout(channel, NULL, &tv);
select(nfds, &read_fds, &write_fds, NULL, tvp); select(nfds, &read_fds, &write_fds, NULL, tvp);
ares_process(channel, &read_fds, &write_fds); ares_process(channel, &read_fds, &write_fds);

View File

@@ -20,63 +20,66 @@
#include <sys/types.h> #include <sys/types.h>
#ifdef _AIX #if defined(_AIX) || defined(NETWARE)
/* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish
libc5-based Linux systems. Only include it on system that are known to libc5-based Linux systems. Only include it on system that are known to
require it! */ require it! */
#include <sys/select.h> #include <sys/select.h>
#endif #endif
#ifdef WIN32 #if defined(WATT32)
#include <winsock.h> #include <netinet/in.h>
#include <windows.h> #include <tcp.h>
#elif defined(WIN32)
#include <winsock.h>
#include <windows.h>
#else #else
#include <netinet/in.h> #include <netinet/in.h>
#endif #endif
#define ARES_SUCCESS 0 #define ARES_SUCCESS 0
/* Server error codes (ARES_ENODATA indicates no relevant answer) */ /* Server error codes (ARES_ENODATA indicates no relevant answer) */
#define ARES_ENODATA 1 #define ARES_ENODATA 1
#define ARES_EFORMERR 2 #define ARES_EFORMERR 2
#define ARES_ESERVFAIL 3 #define ARES_ESERVFAIL 3
#define ARES_ENOTFOUND 4 #define ARES_ENOTFOUND 4
#define ARES_ENOTIMP 5 #define ARES_ENOTIMP 5
#define ARES_EREFUSED 6 #define ARES_EREFUSED 6
/* Locally generated error codes */ /* Locally generated error codes */
#define ARES_EBADQUERY 7 #define ARES_EBADQUERY 7
#define ARES_EBADNAME 8 #define ARES_EBADNAME 8
#define ARES_EBADFAMILY 9 #define ARES_EBADFAMILY 9
#define ARES_EBADRESP 10 #define ARES_EBADRESP 10
#define ARES_ECONNREFUSED 11 #define ARES_ECONNREFUSED 11
#define ARES_ETIMEOUT 12 #define ARES_ETIMEOUT 12
#define ARES_EOF 13 #define ARES_EOF 13
#define ARES_EFILE 14 #define ARES_EFILE 14
#define ARES_ENOMEM 15 #define ARES_ENOMEM 15
#define ARES_EDESTRUCTION 16 #define ARES_EDESTRUCTION 16
#define ARES_EBADSTR 17 #define ARES_EBADSTR 17
/* Flag values */ /* Flag values */
#define ARES_FLAG_USEVC (1 << 0) #define ARES_FLAG_USEVC (1 << 0)
#define ARES_FLAG_PRIMARY (1 << 1) #define ARES_FLAG_PRIMARY (1 << 1)
#define ARES_FLAG_IGNTC (1 << 2) #define ARES_FLAG_IGNTC (1 << 2)
#define ARES_FLAG_NORECURSE (1 << 3) #define ARES_FLAG_NORECURSE (1 << 3)
#define ARES_FLAG_STAYOPEN (1 << 4) #define ARES_FLAG_STAYOPEN (1 << 4)
#define ARES_FLAG_NOSEARCH (1 << 5) #define ARES_FLAG_NOSEARCH (1 << 5)
#define ARES_FLAG_NOALIASES (1 << 6) #define ARES_FLAG_NOALIASES (1 << 6)
#define ARES_FLAG_NOCHECKRESP (1 << 7) #define ARES_FLAG_NOCHECKRESP (1 << 7)
/* Option mask values */ /* Option mask values */
#define ARES_OPT_FLAGS (1 << 0) #define ARES_OPT_FLAGS (1 << 0)
#define ARES_OPT_TIMEOUT (1 << 1) #define ARES_OPT_TIMEOUT (1 << 1)
#define ARES_OPT_TRIES (1 << 2) #define ARES_OPT_TRIES (1 << 2)
#define ARES_OPT_NDOTS (1 << 3) #define ARES_OPT_NDOTS (1 << 3)
#define ARES_OPT_UDP_PORT (1 << 4) #define ARES_OPT_UDP_PORT (1 << 4)
#define ARES_OPT_TCP_PORT (1 << 5) #define ARES_OPT_TCP_PORT (1 << 5)
#define ARES_OPT_SERVERS (1 << 6) #define ARES_OPT_SERVERS (1 << 6)
#define ARES_OPT_DOMAINS (1 << 7) #define ARES_OPT_DOMAINS (1 << 7)
#define ARES_OPT_LOOKUPS (1 << 8) #define ARES_OPT_LOOKUPS (1 << 8)
struct ares_options { struct ares_options {
int flags; int flags;
@@ -97,41 +100,41 @@ struct timeval;
struct ares_channeldata; struct ares_channeldata;
typedef struct ares_channeldata *ares_channel; typedef struct ares_channeldata *ares_channel;
typedef void (*ares_callback)(void *arg, int status, unsigned char *abuf, typedef void (*ares_callback)(void *arg, int status, unsigned char *abuf,
int alen); int alen);
typedef void (*ares_host_callback)(void *arg, int status, typedef void (*ares_host_callback)(void *arg, int status,
struct hostent *hostent); struct hostent *hostent);
int ares_init(ares_channel *channelptr); int ares_init(ares_channel *channelptr);
int ares_init_options(ares_channel *channelptr, struct ares_options *options, int ares_init_options(ares_channel *channelptr, struct ares_options *options,
int optmask); int optmask);
void ares_destroy(ares_channel channel); void ares_destroy(ares_channel channel);
void ares_cancel(ares_channel channel); void ares_cancel(ares_channel channel);
void ares_send(ares_channel channel, const unsigned char *qbuf, int qlen, void ares_send(ares_channel channel, const unsigned char *qbuf, int qlen,
ares_callback callback, void *arg); ares_callback callback, void *arg);
void ares_query(ares_channel channel, const char *name, int dnsclass, void ares_query(ares_channel channel, const char *name, int dnsclass,
int type, ares_callback callback, void *arg); int type, ares_callback callback, void *arg);
void ares_search(ares_channel channel, const char *name, int dnsclass, void ares_search(ares_channel channel, const char *name, int dnsclass,
int type, ares_callback callback, void *arg); int type, ares_callback callback, void *arg);
void ares_gethostbyname(ares_channel channel, const char *name, int family, void ares_gethostbyname(ares_channel channel, const char *name, int family,
ares_host_callback callback, void *arg); ares_host_callback callback, void *arg);
void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen, void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen,
int family, ares_host_callback callback, void *arg); int family, ares_host_callback callback, void *arg);
int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds); int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds);
struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv, struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv,
struct timeval *tv); struct timeval *tv);
void ares_process(ares_channel channel, fd_set *read_fds, fd_set *write_fds); void ares_process(ares_channel channel, fd_set *read_fds, fd_set *write_fds);
int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id, int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id,
int rd, unsigned char **buf, int *buflen); int rd, unsigned char **buf, int *buflen);
int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf, int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf,
int alen, char **s, long *enclen); int alen, char **s, long *enclen);
int ares_expand_string(const unsigned char *encoded, const unsigned char *abuf, int ares_expand_string(const unsigned char *encoded, const unsigned char *abuf,
int alen, unsigned char **s, long *enclen); int alen, unsigned char **s, long *enclen);
int ares_parse_a_reply(const unsigned char *abuf, int alen, int ares_parse_a_reply(const unsigned char *abuf, int alen,
struct hostent **host); struct hostent **host);
int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr, int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr,
int addrlen, int family, struct hostent **host); int addrlen, int family, struct hostent **host);
void ares_free_string(void *str); void ares_free_string(void *str);
void ares_free_hostent(struct hostent *host); void ares_free_hostent(struct hostent *host);
const char *ares_strerror(int code); const char *ares_strerror(int code);

View File

@@ -13,11 +13,13 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdlib.h> #include <stdlib.h>
#ifdef WIN32 #ifdef HAVE_UNISTD_H
#else
#include <unistd.h> #include <unistd.h>
#endif #endif
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"
@@ -42,14 +44,14 @@ void ares__close_sockets(struct server_state *server)
server->tcp_lenbuf_pos = 0; server->tcp_lenbuf_pos = 0;
/* Close the TCP and UDP sockets. */ /* Close the TCP and UDP sockets. */
if (server->tcp_socket != -1) if (server->tcp_socket != ARES_SOCKET_BAD)
{ {
closesocket(server->tcp_socket); closesocket(server->tcp_socket);
server->tcp_socket = -1; server->tcp_socket = ARES_SOCKET_BAD;
} }
if (server->udp_socket != -1) if (server->udp_socket != ARES_SOCKET_BAD)
{ {
closesocket(server->udp_socket); closesocket(server->udp_socket);
server->udp_socket = -1; server->udp_socket = ARES_SOCKET_BAD;
} }
} }

View File

@@ -13,11 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if !defined(WIN32) || defined(WATT32)
#else
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <arpa/inet.h> #include <arpa/inet.h>
@@ -43,96 +42,96 @@ int ares__get_hostent(FILE *fp, struct hostent **host)
{ {
/* Skip comment lines; terminate line at comment character. */ /* Skip comment lines; terminate line at comment character. */
if (*line == '#' || !*line) if (*line == '#' || !*line)
continue; continue;
p = strchr(line, '#'); p = strchr(line, '#');
if (p) if (p)
*p = 0; *p = 0;
/* Get the address part. */ /* Get the address part. */
p = line; p = line;
while (*p && !isspace((unsigned char)*p)) while (*p && !isspace((unsigned char)*p))
p++; p++;
if (!*p) if (!*p)
continue; continue;
*p = 0; *p = 0;
addr.s_addr = inet_addr(line); addr.s_addr = inet_addr(line);
if (addr.s_addr == INADDR_NONE) if (addr.s_addr == INADDR_NONE)
continue; continue;
/* Get the canonical hostname. */ /* Get the canonical hostname. */
p++; p++;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
if (!*p) if (!*p)
continue; continue;
q = p; q = p;
while (*q && !isspace((unsigned char)*q)) while (*q && !isspace((unsigned char)*q))
q++; q++;
end_at_hostname = (*q == 0); end_at_hostname = (*q == 0);
*q = 0; *q = 0;
canonical = p; canonical = p;
naliases = 0; naliases = 0;
if (!end_at_hostname) if (!end_at_hostname)
{ {
/* Count the aliases. */ /* Count the aliases. */
p = q + 1; p = q + 1;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
while (*p) while (*p)
{ {
while (*p && !isspace((unsigned char)*p)) while (*p && !isspace((unsigned char)*p))
p++; p++;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
naliases++; naliases++;
} }
} }
/* Allocate memory for the host structure. */ /* Allocate memory for the host structure. */
hostent = malloc(sizeof(struct hostent)); hostent = malloc(sizeof(struct hostent));
if (!hostent) if (!hostent)
break; break;
hostent->h_aliases = NULL; hostent->h_aliases = NULL;
hostent->h_addr_list = NULL; hostent->h_addr_list = NULL;
hostent->h_name = strdup(canonical); hostent->h_name = strdup(canonical);
if (!hostent->h_name) if (!hostent->h_name)
break; break;
hostent->h_addr_list = malloc(2 * sizeof(char *)); hostent->h_addr_list = malloc(2 * sizeof(char *));
if (!hostent->h_addr_list) if (!hostent->h_addr_list)
break; break;
hostent->h_addr_list[0] = malloc(sizeof(struct in_addr)); hostent->h_addr_list[0] = malloc(sizeof(struct in_addr));
if (!hostent->h_addr_list[0]) if (!hostent->h_addr_list[0])
break; break;
hostent->h_aliases = malloc((naliases + 1) * sizeof(char *)); hostent->h_aliases = malloc((naliases + 1) * sizeof(char *));
if (!hostent->h_aliases) if (!hostent->h_aliases)
break; break;
/* Copy in aliases. */ /* Copy in aliases. */
naliases = 0; naliases = 0;
if (!end_at_hostname) if (!end_at_hostname)
{ {
p = canonical + strlen(canonical) + 1; p = canonical + strlen(canonical) + 1;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
while (*p) while (*p)
{ {
q = p; q = p;
while (*q && !isspace((unsigned char)*q)) while (*q && !isspace((unsigned char)*q))
q++; q++;
hostent->h_aliases[naliases] = malloc(q - p + 1); hostent->h_aliases[naliases] = malloc(q - p + 1);
if (hostent->h_aliases[naliases] == NULL) if (hostent->h_aliases[naliases] == NULL)
break; break;
memcpy(hostent->h_aliases[naliases], p, q - p); memcpy(hostent->h_aliases[naliases], p, q - p);
hostent->h_aliases[naliases][q - p] = 0; hostent->h_aliases[naliases][q - p] = 0;
p = q; p = q;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
naliases++; naliases++;
} }
if (*p) if (*p)
break; break;
} }
hostent->h_aliases[naliases] = NULL; hostent->h_aliases[naliases] = NULL;
hostent->h_addrtype = AF_INET; hostent->h_addrtype = AF_INET;
@@ -150,22 +149,22 @@ int ares__get_hostent(FILE *fp, struct hostent **host)
{ {
/* Memory allocation failure; clean up. */ /* Memory allocation failure; clean up. */
if (hostent) if (hostent)
{ {
if(hostent->h_name) if(hostent->h_name)
free((char *) hostent->h_name); free((char *) hostent->h_name);
if (hostent->h_aliases) if (hostent->h_aliases)
{ {
for (alias = hostent->h_aliases; *alias; alias++) for (alias = hostent->h_aliases; *alias; alias++)
free(*alias); free(*alias);
} }
if(hostent->h_aliases) if(hostent->h_aliases)
free(hostent->h_aliases); free(hostent->h_aliases);
if (hostent->h_addr_list && hostent->h_addr_list[0]) if (hostent->h_addr_list && hostent->h_addr_list[0])
free(hostent->h_addr_list[0]); free(hostent->h_addr_list[0]);
if(hostent->h_addr_list) if(hostent->h_addr_list)
free(hostent->h_addr_list); free(hostent->h_addr_list);
free(hostent); free(hostent);
} }
return ARES_ENOMEM; return ARES_ENOMEM;
} }

View File

@@ -13,6 +13,7 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
@@ -37,26 +38,26 @@ int ares__read_line(FILE *fp, char **buf, int *bufsize)
{ {
*buf = malloc(128); *buf = malloc(128);
if (!*buf) if (!*buf)
return ARES_ENOMEM; return ARES_ENOMEM;
*bufsize = 128; *bufsize = 128;
} }
while (1) while (1)
{ {
if (!fgets(*buf + offset, *bufsize - (int)offset, fp)) if (!fgets(*buf + offset, *bufsize - (int)offset, fp))
return (offset != 0) ? 0 : (ferror(fp)) ? ARES_EFILE : ARES_EOF; return (offset != 0) ? 0 : (ferror(fp)) ? ARES_EFILE : ARES_EOF;
len = offset + strlen(*buf + offset); len = offset + strlen(*buf + offset);
if ((*buf)[len - 1] == '\n') if ((*buf)[len - 1] == '\n')
{ {
(*buf)[len - 1] = 0; (*buf)[len - 1] = 0;
return ARES_SUCCESS; return ARES_SUCCESS;
} }
offset = len; offset = len;
/* Allocate more space. */ /* Allocate more space. */
newbuf = realloc(*buf, *bufsize * 2); newbuf = realloc(*buf, *bufsize * 2);
if (!newbuf) if (!newbuf)
return ARES_ENOMEM; return ARES_ENOMEM;
*buf = newbuf; *buf = newbuf;
*bufsize *= 2; *bufsize *= 2;
} }

View File

@@ -1,18 +1,17 @@
/* Copyright 1998 by the Massachusetts Institute of Technology. /* Copyright (C) 2004 by Daniel Stenberg et al
* *
* Permission to use, copy, modify, and distribute this * Permission to use, copy, modify, and distribute this software and its
* software and its documentation for any purpose and without * documentation for any purpose and without fee is hereby granted, provided
* fee is hereby granted, provided that the above copyright * that the above copyright notice appear in all copies and that both that
* notice appear in all copies and that both that copyright * copyright notice and this permission notice appear in supporting
* notice and this permission notice appear in supporting * documentation, and that the name of M.I.T. not be used in advertising or
* documentation, and that the name of M.I.T. not be used in * publicity pertaining to distribution of the software without specific,
* advertising or publicity pertaining to distribution of the * written prior permission. M.I.T. makes no representations about the
* software without specific, written prior permission. * suitability of this software for any purpose. It is provided "as is"
* M.I.T. makes no representations about the suitability of
* this software for any purpose. It is provided "as is"
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdlib.h> #include <stdlib.h>
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"

View File

@@ -13,6 +13,7 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdlib.h> #include <stdlib.h>
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"

View File

@@ -18,64 +18,64 @@
#ifndef ARES__DNS_H #ifndef ARES__DNS_H
#define ARES__DNS_H #define ARES__DNS_H
#define DNS__16BIT(p) (((p)[0] << 8) | (p)[1]) #define DNS__16BIT(p) (((p)[0] << 8) | (p)[1])
#define DNS__32BIT(p) (((p)[0] << 24) | ((p)[1] << 16) | \ #define DNS__32BIT(p) (((p)[0] << 24) | ((p)[1] << 16) | \
((p)[2] << 8) | (p)[3]) ((p)[2] << 8) | (p)[3])
#define DNS__SET16BIT(p, v) (((p)[0] = ((v) >> 8) & 0xff), \ #define DNS__SET16BIT(p, v) (((p)[0] = ((v) >> 8) & 0xff), \
((p)[1] = (v) & 0xff)) ((p)[1] = (v) & 0xff))
#define DNS__SET32BIT(p, v) (((p)[0] = ((v) >> 24) & 0xff), \ #define DNS__SET32BIT(p, v) (((p)[0] = ((v) >> 24) & 0xff), \
((p)[1] = ((v) >> 16) & 0xff), \ ((p)[1] = ((v) >> 16) & 0xff), \
((p)[2] = ((v) >> 8) & 0xff), \ ((p)[2] = ((v) >> 8) & 0xff), \
((p)[3] = (v) & 0xff)) ((p)[3] = (v) & 0xff))
/* Macros for parsing a DNS header */ /* Macros for parsing a DNS header */
#define DNS_HEADER_QID(h) DNS__16BIT(h) #define DNS_HEADER_QID(h) DNS__16BIT(h)
#define DNS_HEADER_QR(h) (((h)[2] >> 7) & 0x1) #define DNS_HEADER_QR(h) (((h)[2] >> 7) & 0x1)
#define DNS_HEADER_OPCODE(h) (((h)[2] >> 3) & 0xf) #define DNS_HEADER_OPCODE(h) (((h)[2] >> 3) & 0xf)
#define DNS_HEADER_AA(h) (((h)[2] >> 2) & 0x1) #define DNS_HEADER_AA(h) (((h)[2] >> 2) & 0x1)
#define DNS_HEADER_TC(h) (((h)[2] >> 1) & 0x1) #define DNS_HEADER_TC(h) (((h)[2] >> 1) & 0x1)
#define DNS_HEADER_RD(h) ((h)[2] & 0x1) #define DNS_HEADER_RD(h) ((h)[2] & 0x1)
#define DNS_HEADER_RA(h) (((h)[3] >> 7) & 0x1) #define DNS_HEADER_RA(h) (((h)[3] >> 7) & 0x1)
#define DNS_HEADER_Z(h) (((h)[3] >> 4) & 0x7) #define DNS_HEADER_Z(h) (((h)[3] >> 4) & 0x7)
#define DNS_HEADER_RCODE(h) ((h)[3] & 0xf) #define DNS_HEADER_RCODE(h) ((h)[3] & 0xf)
#define DNS_HEADER_QDCOUNT(h) DNS__16BIT((h) + 4) #define DNS_HEADER_QDCOUNT(h) DNS__16BIT((h) + 4)
#define DNS_HEADER_ANCOUNT(h) DNS__16BIT((h) + 6) #define DNS_HEADER_ANCOUNT(h) DNS__16BIT((h) + 6)
#define DNS_HEADER_NSCOUNT(h) DNS__16BIT((h) + 8) #define DNS_HEADER_NSCOUNT(h) DNS__16BIT((h) + 8)
#define DNS_HEADER_ARCOUNT(h) DNS__16BIT((h) + 10) #define DNS_HEADER_ARCOUNT(h) DNS__16BIT((h) + 10)
/* Macros for constructing a DNS header */ /* Macros for constructing a DNS header */
#define DNS_HEADER_SET_QID(h, v) DNS__SET16BIT(h, v) #define DNS_HEADER_SET_QID(h, v) DNS__SET16BIT(h, v)
#define DNS_HEADER_SET_QR(h, v) ((h)[2] |= (((v) & 0x1) << 7)) #define DNS_HEADER_SET_QR(h, v) ((h)[2] |= (((v) & 0x1) << 7))
#define DNS_HEADER_SET_OPCODE(h, v) ((h)[2] |= (((v) & 0xf) << 3)) #define DNS_HEADER_SET_OPCODE(h, v) ((h)[2] |= (((v) & 0xf) << 3))
#define DNS_HEADER_SET_AA(h, v) ((h)[2] |= (((v) & 0x1) << 2)) #define DNS_HEADER_SET_AA(h, v) ((h)[2] |= (((v) & 0x1) << 2))
#define DNS_HEADER_SET_TC(h, v) ((h)[2] |= (((v) & 0x1) << 1)) #define DNS_HEADER_SET_TC(h, v) ((h)[2] |= (((v) & 0x1) << 1))
#define DNS_HEADER_SET_RD(h, v) ((h)[2] |= (((v) & 0x1))) #define DNS_HEADER_SET_RD(h, v) ((h)[2] |= (((v) & 0x1)))
#define DNS_HEADER_SET_RA(h, v) ((h)[3] |= (((v) & 0x1) << 7)) #define DNS_HEADER_SET_RA(h, v) ((h)[3] |= (((v) & 0x1) << 7))
#define DNS_HEADER_SET_Z(h, v) ((h)[3] |= (((v) & 0x7) << 4)) #define DNS_HEADER_SET_Z(h, v) ((h)[3] |= (((v) & 0x7) << 4))
#define DNS_HEADER_SET_RCODE(h, v) ((h)[3] |= (((v) & 0xf))) #define DNS_HEADER_SET_RCODE(h, v) ((h)[3] |= (((v) & 0xf)))
#define DNS_HEADER_SET_QDCOUNT(h, v) DNS__SET16BIT((h) + 4, v) #define DNS_HEADER_SET_QDCOUNT(h, v) DNS__SET16BIT((h) + 4, v)
#define DNS_HEADER_SET_ANCOUNT(h, v) DNS__SET16BIT((h) + 6, v) #define DNS_HEADER_SET_ANCOUNT(h, v) DNS__SET16BIT((h) + 6, v)
#define DNS_HEADER_SET_NSCOUNT(h, v) DNS__SET16BIT((h) + 8, v) #define DNS_HEADER_SET_NSCOUNT(h, v) DNS__SET16BIT((h) + 8, v)
#define DNS_HEADER_SET_ARCOUNT(h, v) DNS__SET16BIT((h) + 10, v) #define DNS_HEADER_SET_ARCOUNT(h, v) DNS__SET16BIT((h) + 10, v)
/* Macros for parsing the fixed part of a DNS question */ /* Macros for parsing the fixed part of a DNS question */
#define DNS_QUESTION_TYPE(q) DNS__16BIT(q) #define DNS_QUESTION_TYPE(q) DNS__16BIT(q)
#define DNS_QUESTION_CLASS(q) DNS__16BIT((q) + 2) #define DNS_QUESTION_CLASS(q) DNS__16BIT((q) + 2)
/* Macros for constructing the fixed part of a DNS question */ /* Macros for constructing the fixed part of a DNS question */
#define DNS_QUESTION_SET_TYPE(q, v) DNS__SET16BIT(q, v) #define DNS_QUESTION_SET_TYPE(q, v) DNS__SET16BIT(q, v)
#define DNS_QUESTION_SET_CLASS(q, v) DNS__SET16BIT((q) + 2, v) #define DNS_QUESTION_SET_CLASS(q, v) DNS__SET16BIT((q) + 2, v)
/* Macros for parsing the fixed part of a DNS resource record */ /* Macros for parsing the fixed part of a DNS resource record */
#define DNS_RR_TYPE(r) DNS__16BIT(r) #define DNS_RR_TYPE(r) DNS__16BIT(r)
#define DNS_RR_CLASS(r) DNS__16BIT((r) + 2) #define DNS_RR_CLASS(r) DNS__16BIT((r) + 2)
#define DNS_RR_TTL(r) DNS__32BIT((r) + 4) #define DNS_RR_TTL(r) DNS__32BIT((r) + 4)
#define DNS_RR_LEN(r) DNS__16BIT((r) + 8) #define DNS_RR_LEN(r) DNS__16BIT((r) + 8)
/* Macros for constructing the fixed part of a DNS resource record */ /* Macros for constructing the fixed part of a DNS resource record */
#define DNS_RR_SET_TYPE(r) DNS__SET16BIT(r, v) #define DNS_RR_SET_TYPE(r) DNS__SET16BIT(r, v)
#define DNS_RR_SET_CLASS(r) DNS__SET16BIT((r) + 2, v) #define DNS_RR_SET_CLASS(r) DNS__SET16BIT((r) + 2, v)
#define DNS_RR_SET_TTL(r) DNS__SET32BIT((r) + 4, v) #define DNS_RR_SET_TTL(r) DNS__SET32BIT((r) + 4, v)
#define DNS_RR_SET_LEN(r) DNS__SET16BIT((r) + 8, v) #define DNS_RR_SET_LEN(r) DNS__SET16BIT((r) + 8, v)
#endif /* ARES__DNS_H */ #endif /* ARES__DNS_H */

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <netinet/in.h> #include <netinet/in.h>
@@ -27,7 +28,7 @@
#include "ares_private.h" /* for the memdebug */ #include "ares_private.h" /* for the memdebug */
static int name_length(const unsigned char *encoded, const unsigned char *abuf, static int name_length(const unsigned char *encoded, const unsigned char *abuf,
int alen); int alen);
/* Expand an RFC1035-encoded domain name given by encoded. The /* Expand an RFC1035-encoded domain name given by encoded. The
* containing message is given by abuf and alen. The result given by * containing message is given by abuf and alen. The result given by
@@ -54,7 +55,7 @@ static int name_length(const unsigned char *encoded, const unsigned char *abuf,
*/ */
int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf, int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf,
int alen, char **s, long *enclen) int alen, char **s, long *enclen)
{ {
int len, indir = 0; int len, indir = 0;
char *q; char *q;
@@ -74,27 +75,27 @@ int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf,
while (*p) while (*p)
{ {
if ((*p & INDIR_MASK) == INDIR_MASK) if ((*p & INDIR_MASK) == INDIR_MASK)
{ {
if (!indir) if (!indir)
{ {
*enclen = p + 2 - encoded; *enclen = p + 2 - encoded;
indir = 1; indir = 1;
} }
p = abuf + ((*p & ~INDIR_MASK) << 8 | *(p + 1)); p = abuf + ((*p & ~INDIR_MASK) << 8 | *(p + 1));
} }
else else
{ {
len = *p; len = *p;
p++; p++;
while (len--) while (len--)
{ {
if (*p == '.' || *p == '\\') if (*p == '.' || *p == '\\')
*q++ = '\\'; *q++ = '\\';
*q++ = *p; *q++ = *p;
p++; p++;
} }
*q++ = '.'; *q++ = '.';
} }
} }
if (!indir) if (!indir)
*enclen = p + 1 - encoded; *enclen = p + 1 - encoded;
@@ -110,7 +111,7 @@ int ares_expand_name(const unsigned char *encoded, const unsigned char *abuf,
* -1 if the encoding is invalid. * -1 if the encoding is invalid.
*/ */
static int name_length(const unsigned char *encoded, const unsigned char *abuf, static int name_length(const unsigned char *encoded, const unsigned char *abuf,
int alen) int alen)
{ {
int n = 0, offset, indir = 0; int n = 0, offset, indir = 0;
@@ -121,34 +122,34 @@ static int name_length(const unsigned char *encoded, const unsigned char *abuf,
while (*encoded) while (*encoded)
{ {
if ((*encoded & INDIR_MASK) == INDIR_MASK) if ((*encoded & INDIR_MASK) == INDIR_MASK)
{ {
/* Check the offset and go there. */ /* Check the offset and go there. */
if (encoded + 1 >= abuf + alen) if (encoded + 1 >= abuf + alen)
return -1; return -1;
offset = (*encoded & ~INDIR_MASK) << 8 | *(encoded + 1); offset = (*encoded & ~INDIR_MASK) << 8 | *(encoded + 1);
if (offset >= alen) if (offset >= alen)
return -1; return -1;
encoded = abuf + offset; encoded = abuf + offset;
/* If we've seen more indirects than the message length, /* If we've seen more indirects than the message length,
* then there's a loop. * then there's a loop.
*/ */
if (++indir > alen) if (++indir > alen)
return -1; return -1;
} }
else else
{ {
offset = *encoded; offset = *encoded;
if (encoded + offset + 1 >= abuf + alen) if (encoded + offset + 1 >= abuf + alen)
return -1; return -1;
encoded++; encoded++;
while (offset--) while (offset--)
{ {
n += (*encoded == '.' || *encoded == '\\') ? 2 : 1; n += (*encoded == '.' || *encoded == '\\') ? 2 : 1;
encoded++; encoded++;
} }
n++; n++;
} }
} }
/* If there were any labels at all, then the number of dots is one /* If there were any labels at all, then the number of dots is one

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <netinet/in.h> #include <netinet/in.h>

View File

@@ -13,11 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #ifdef HAVE_SYS_TIME_H
#else
#include <sys/time.h> #include <sys/time.h>
#endif #endif
@@ -37,20 +36,20 @@ int ares_fds(ares_channel channel, fd_set *read_fds, fd_set *write_fds)
for (i = 0; i < channel->nservers; i++) for (i = 0; i < channel->nservers; i++)
{ {
server = &channel->servers[i]; server = &channel->servers[i];
if (server->udp_socket != -1) if (server->udp_socket != ARES_SOCKET_BAD)
{ {
FD_SET(server->udp_socket, read_fds); FD_SET(server->udp_socket, read_fds);
if (server->udp_socket >= nfds) if (server->udp_socket >= nfds)
nfds = server->udp_socket + 1; nfds = server->udp_socket + 1;
} }
if (server->tcp_socket != -1) if (server->tcp_socket != ARES_SOCKET_BAD)
{ {
FD_SET(server->tcp_socket, read_fds); FD_SET(server->tcp_socket, read_fds);
if (server->qhead) if (server->qhead)
FD_SET(server->tcp_socket, write_fds); FD_SET(server->tcp_socket, write_fds);
if (server->tcp_socket >= nfds) if (server->tcp_socket >= nfds)
nfds = server->tcp_socket + 1; nfds = server->tcp_socket + 1;
} }
} }
return nfds; return nfds;
} }

View File

@@ -13,11 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdlib.h> #include <stdlib.h>
#ifdef WIN32 #if !defined(WIN32) || defined(WATT32)
#else
#include <netdb.h> #include <netdb.h>
#endif #endif

View File

@@ -13,6 +13,7 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdlib.h> #include <stdlib.h>
#include "ares.h" #include "ares.h"

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <sys/socket.h> #include <sys/socket.h>
@@ -27,9 +28,14 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"
#ifdef WATT32
#undef WIN32
#endif
struct addr_query { struct addr_query {
/* Arguments passed to ares_gethostbyaddr() */ /* Arguments passed to ares_gethostbyaddr() */
ares_channel channel; ares_channel channel;
@@ -42,13 +48,13 @@ struct addr_query {
static void next_lookup(struct addr_query *aquery); static void next_lookup(struct addr_query *aquery);
static void addr_callback(void *arg, int status, unsigned char *abuf, static void addr_callback(void *arg, int status, unsigned char *abuf,
int alen); int alen);
static void end_aquery(struct addr_query *aquery, int status, static void end_aquery(struct addr_query *aquery, int status,
struct hostent *host); struct hostent *host);
static int file_lookup(struct in_addr *addr, struct hostent **host); static int file_lookup(struct in_addr *addr, struct hostent **host);
void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen, void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen,
int family, ares_host_callback callback, void *arg) int family, ares_host_callback callback, void *arg)
{ {
struct addr_query *aquery; struct addr_query *aquery;
@@ -84,27 +90,27 @@ static void next_lookup(struct addr_query *aquery)
for (p = aquery->remaining_lookups; *p; p++) for (p = aquery->remaining_lookups; *p; p++)
{ {
switch (*p) switch (*p)
{ {
case 'b': case 'b':
addr = ntohl(aquery->addr.s_addr); addr = ntohl(aquery->addr.s_addr);
a1 = (int)((addr >> 24) & 0xff); a1 = (int)((addr >> 24) & 0xff);
a2 = (int)((addr >> 16) & 0xff); a2 = (int)((addr >> 16) & 0xff);
a3 = (int)((addr >> 8) & 0xff); a3 = (int)((addr >> 8) & 0xff);
a4 = (int)(addr & 0xff); a4 = (int)(addr & 0xff);
sprintf(name, "%d.%d.%d.%d.in-addr.arpa", a4, a3, a2, a1); sprintf(name, "%d.%d.%d.%d.in-addr.arpa", a4, a3, a2, a1);
aquery->remaining_lookups = p + 1; aquery->remaining_lookups = p + 1;
ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback, ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback,
aquery); aquery);
return; return;
case 'f': case 'f':
status = file_lookup(&aquery->addr, &host); status = file_lookup(&aquery->addr, &host);
if (status != ARES_ENOTFOUND) if (status != ARES_ENOTFOUND)
{ {
end_aquery(aquery, status, host); end_aquery(aquery, status, host);
return; return;
} }
break; break;
} }
} }
end_aquery(aquery, ARES_ENOTFOUND, NULL); end_aquery(aquery, ARES_ENOTFOUND, NULL);
} }
@@ -117,7 +123,7 @@ static void addr_callback(void *arg, int status, unsigned char *abuf, int alen)
if (status == ARES_SUCCESS) if (status == ARES_SUCCESS)
{ {
status = ares_parse_ptr_reply(abuf, alen, &aquery->addr, status = ares_parse_ptr_reply(abuf, alen, &aquery->addr,
sizeof(struct in_addr), AF_INET, &host); sizeof(struct in_addr), AF_INET, &host);
end_aquery(aquery, status, host); end_aquery(aquery, status, host);
} }
else if (status == ARES_EDESTRUCTION) else if (status == ARES_EDESTRUCTION)
@@ -127,7 +133,7 @@ static void addr_callback(void *arg, int status, unsigned char *abuf, int alen)
} }
static void end_aquery(struct addr_query *aquery, int status, static void end_aquery(struct addr_query *aquery, int status,
struct hostent *host) struct hostent *host)
{ {
aquery->callback(aquery->arg, status, host); aquery->callback(aquery->arg, status, host);
if (host) if (host)
@@ -144,13 +150,30 @@ static int file_lookup(struct in_addr *addr, struct hostent **host)
char PATH_HOSTS[MAX_PATH]; char PATH_HOSTS[MAX_PATH];
if (IsNT) { if (IsNT) {
GetSystemDirectory(PATH_HOSTS, MAX_PATH); char tmp[MAX_PATH];
strcat(PATH_HOSTS, PATH_HOSTS_NT); HKEY hkeyHosts;
} else {
GetWindowsDirectory(PATH_HOSTS, MAX_PATH);
strcat(PATH_HOSTS, PATH_HOSTS_9X);
}
if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, WIN_NS_NT_KEY, 0, KEY_READ, &hkeyHosts)
== ERROR_SUCCESS)
{
DWORD dwLength = MAX_PATH;
RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, tmp,
&dwLength);
ExpandEnvironmentStrings(tmp, PATH_HOSTS, MAX_PATH);
RegCloseKey(hkeyHosts);
}
}
else
GetWindowsDirectory(PATH_HOSTS, MAX_PATH);
strcat(PATH_HOSTS, WIN_PATH_HOSTS);
#elif defined(WATT32)
extern const char *_w32_GetHostsFile (void);
const char *PATH_HOSTS = _w32_GetHostsFile();
if (!PATH_HOSTS)
return ARES_ENOTFOUND;
#endif #endif
fp = fopen(PATH_HOSTS, "r"); fp = fopen(PATH_HOSTS, "r");
@@ -160,7 +183,7 @@ static int file_lookup(struct in_addr *addr, struct hostent **host)
while ((status = ares__get_hostent(fp, host)) == ARES_SUCCESS) while ((status = ares__get_hostent(fp, host)) == ARES_SUCCESS)
{ {
if (memcmp((*host)->h_addr, addr, sizeof(struct in_addr)) == 0) if (memcmp((*host)->h_addr, addr, sizeof(struct in_addr)) == 0)
break; break;
ares_free_hostent(*host); ares_free_hostent(*host);
} }
fclose(fp); fclose(fp);

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <sys/socket.h> #include <sys/socket.h>
@@ -29,9 +30,14 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <ctype.h> #include <ctype.h>
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"
#ifdef WATT32
#undef WIN32
#endif
struct host_query { struct host_query {
/* Arguments passed to ares_gethostbyname() */ /* Arguments passed to ares_gethostbyname() */
ares_channel channel; ares_channel channel;
@@ -44,19 +50,19 @@ struct host_query {
static void next_lookup(struct host_query *hquery); static void next_lookup(struct host_query *hquery);
static void host_callback(void *arg, int status, unsigned char *abuf, static void host_callback(void *arg, int status, unsigned char *abuf,
int alen); int alen);
static void end_hquery(struct host_query *hquery, int status, static void end_hquery(struct host_query *hquery, int status,
struct hostent *host); struct hostent *host);
static int fake_hostent(const char *name, ares_host_callback callback, static int fake_hostent(const char *name, ares_host_callback callback,
void *arg); void *arg);
static int file_lookup(const char *name, struct hostent **host); static int file_lookup(const char *name, struct hostent **host);
static void sort_addresses(struct hostent *host, struct apattern *sortlist, static void sort_addresses(struct hostent *host, struct apattern *sortlist,
int nsort); int nsort);
static int get_address_index(struct in_addr *addr, struct apattern *sortlist, static int get_address_index(struct in_addr *addr, struct apattern *sortlist,
int nsort); int nsort);
void ares_gethostbyname(ares_channel channel, const char *name, int family, void ares_gethostbyname(ares_channel channel, const char *name, int family,
ares_host_callback callback, void *arg) ares_host_callback callback, void *arg)
{ {
struct host_query *hquery; struct host_query *hquery;
@@ -100,26 +106,26 @@ static void next_lookup(struct host_query *hquery)
struct hostent *host; struct hostent *host;
for (p = hquery->remaining_lookups; *p; p++) for (p = hquery->remaining_lookups; *p; p++)
{ {
switch (*p) switch (*p)
{ {
case 'b': case 'b':
/* DNS lookup */ /* DNS lookup */
hquery->remaining_lookups = p + 1; hquery->remaining_lookups = p + 1;
ares_search(hquery->channel, hquery->name, C_IN, T_A, host_callback, ares_search(hquery->channel, hquery->name, C_IN, T_A, host_callback,
hquery); hquery);
return; return;
case 'f': case 'f':
/* Host file lookup */ /* Host file lookup */
status = file_lookup(hquery->name, &host); status = file_lookup(hquery->name, &host);
if (status != ARES_ENOTFOUND) if (status != ARES_ENOTFOUND)
{ {
end_hquery(hquery, status, host); end_hquery(hquery, status, host);
return; return;
} }
break; break;
} }
} }
end_hquery(hquery, ARES_ENOTFOUND, NULL); end_hquery(hquery, ARES_ENOTFOUND, NULL);
} }
@@ -134,7 +140,7 @@ static void host_callback(void *arg, int status, unsigned char *abuf, int alen)
{ {
status = ares_parse_a_reply(abuf, alen, &host); status = ares_parse_a_reply(abuf, alen, &host);
if (host && channel->nsort) if (host && channel->nsort)
sort_addresses(host, channel->sortlist, channel->nsort); sort_addresses(host, channel->sortlist, channel->nsort);
end_hquery(hquery, status, host); end_hquery(hquery, status, host);
} }
else if (status == ARES_EDESTRUCTION) else if (status == ARES_EDESTRUCTION)
@@ -144,7 +150,7 @@ static void host_callback(void *arg, int status, unsigned char *abuf, int alen)
} }
static void end_hquery(struct host_query *hquery, int status, static void end_hquery(struct host_query *hquery, int status,
struct hostent *host) struct hostent *host)
{ {
hquery->callback(hquery->arg, status, host); hquery->callback(hquery->arg, status, host);
if (host) if (host)
@@ -157,7 +163,7 @@ static void end_hquery(struct host_query *hquery, int status,
* query immediately, and return true. Otherwise return false. * query immediately, and return true. Otherwise return false.
*/ */
static int fake_hostent(const char *name, ares_host_callback callback, static int fake_hostent(const char *name, ares_host_callback callback,
void *arg) void *arg)
{ {
struct in_addr addr; struct in_addr addr;
struct hostent hostent; struct hostent hostent;
@@ -169,7 +175,7 @@ static int fake_hostent(const char *name, ares_host_callback callback,
for (p = name; *p; p++) for (p = name; *p; p++)
{ {
if (!isdigit((unsigned char)*p) && *p != '.') if (!isdigit((unsigned char)*p) && *p != '.')
return 0; return 0;
} }
/* It also only looks like an IP address if it's non-zero-length and /* It also only looks like an IP address if it's non-zero-length and
@@ -214,16 +220,32 @@ static int file_lookup(const char *name, struct hostent **host)
int status; int status;
#ifdef WIN32 #ifdef WIN32
char PATH_HOSTS[MAX_PATH]; char PATH_HOSTS[MAX_PATH];
if (IsNT) { if (IsNT) {
GetSystemDirectory(PATH_HOSTS, MAX_PATH); char tmp[MAX_PATH];
strcat(PATH_HOSTS, PATH_HOSTS_NT); HKEY hkeyHosts;
} else {
GetWindowsDirectory(PATH_HOSTS, MAX_PATH);
strcat(PATH_HOSTS, PATH_HOSTS_9X);
}
if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, WIN_NS_NT_KEY, 0, KEY_READ, &hkeyHosts)
== ERROR_SUCCESS)
{
DWORD dwLength = MAX_PATH;
RegQueryValueEx(hkeyHosts, DATABASEPATH, NULL, NULL, tmp,
&dwLength);
ExpandEnvironmentStrings(tmp, PATH_HOSTS, MAX_PATH);
RegCloseKey(hkeyHosts);
}
}
else
GetWindowsDirectory(PATH_HOSTS, MAX_PATH);
strcat(PATH_HOSTS, WIN_PATH_HOSTS);
#elif defined(WATT32)
extern const char *_w32_GetHostsFile (void);
const char *PATH_HOSTS = _w32_GetHostsFile();
if (!PATH_HOSTS)
return ARES_ENOTFOUND;
#endif #endif
fp = fopen(PATH_HOSTS, "r"); fp = fopen(PATH_HOSTS, "r");
@@ -233,14 +255,14 @@ static int file_lookup(const char *name, struct hostent **host)
while ((status = ares__get_hostent(fp, host)) == ARES_SUCCESS) while ((status = ares__get_hostent(fp, host)) == ARES_SUCCESS)
{ {
if (strcasecmp((*host)->h_name, name) == 0) if (strcasecmp((*host)->h_name, name) == 0)
break; break;
for (alias = (*host)->h_aliases; *alias; alias++) for (alias = (*host)->h_aliases; *alias; alias++)
{ {
if (strcasecmp(*alias, name) == 0) if (strcasecmp(*alias, name) == 0)
break; break;
} }
if (*alias) if (*alias)
break; break;
ares_free_hostent(*host); ares_free_hostent(*host);
} }
fclose(fp); fclose(fp);
@@ -252,7 +274,7 @@ static int file_lookup(const char *name, struct hostent **host)
} }
static void sort_addresses(struct hostent *host, struct apattern *sortlist, static void sort_addresses(struct hostent *host, struct apattern *sortlist,
int nsort) int nsort)
{ {
struct in_addr a1, a2; struct in_addr a1, a2;
int i1, i2, ind1, ind2; int i1, i2, ind1, ind2;
@@ -267,13 +289,13 @@ static void sort_addresses(struct hostent *host, struct apattern *sortlist,
memcpy(&a1, host->h_addr_list[i1], sizeof(struct in_addr)); memcpy(&a1, host->h_addr_list[i1], sizeof(struct in_addr));
ind1 = get_address_index(&a1, sortlist, nsort); ind1 = get_address_index(&a1, sortlist, nsort);
for (i2 = i1 - 1; i2 >= 0; i2--) for (i2 = i1 - 1; i2 >= 0; i2--)
{ {
memcpy(&a2, host->h_addr_list[i2], sizeof(struct in_addr)); memcpy(&a2, host->h_addr_list[i2], sizeof(struct in_addr));
ind2 = get_address_index(&a2, sortlist, nsort); ind2 = get_address_index(&a2, sortlist, nsort);
if (ind2 <= ind1) if (ind2 <= ind1)
break; break;
memcpy(host->h_addr_list[i2 + 1], &a2, sizeof(struct in_addr)); memcpy(host->h_addr_list[i2 + 1], &a2, sizeof(struct in_addr));
} }
memcpy(host->h_addr_list[i2 + 1], &a1, sizeof(struct in_addr)); memcpy(host->h_addr_list[i2 + 1], &a1, sizeof(struct in_addr));
} }
} }
@@ -282,14 +304,14 @@ static void sort_addresses(struct hostent *host, struct apattern *sortlist,
* if none of them match. * if none of them match.
*/ */
static int get_address_index(struct in_addr *addr, struct apattern *sortlist, static int get_address_index(struct in_addr *addr, struct apattern *sortlist,
int nsort) int nsort)
{ {
int i; int i;
for (i = 0; i < nsort; i++) for (i = 0; i < nsort; i++)
{ {
if ((addr->s_addr & sortlist[i].mask.s_addr) == sortlist[i].addr.s_addr) if ((addr->s_addr & sortlist[i].mask.s_addr) == sortlist[i].addr.s_addr)
break; break;
} }
return i; return i;
} }

View File

@@ -13,21 +13,28 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#include <iphlpapi.h> #include <iphlpapi.h>
#include <malloc.h> #include <malloc.h>
#else #else
#include <sys/param.h> #include <sys/param.h>
#ifdef HAVE_SYS_TIME_H
#include <sys/time.h> #include <sys/time.h>
#endif
#include <netinet/in.h> #include <netinet/in.h>
#include <arpa/inet.h> #include <arpa/inet.h>
#include <netdb.h> #include <netdb.h>
#include <arpa/nameser.h> #include <arpa/nameser.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h> #include <unistd.h>
#endif #endif
#endif
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
@@ -38,17 +45,22 @@
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"
#ifdef WATT32
#undef WIN32 /* Redefined in MingW/MSVC headers */
#endif
static int init_by_options(ares_channel channel, struct ares_options *options, static int init_by_options(ares_channel channel, struct ares_options *options,
int optmask); int optmask);
static int init_by_environment(ares_channel channel); static int init_by_environment(ares_channel channel);
static int init_by_resolv_conf(ares_channel channel); static int init_by_resolv_conf(ares_channel channel);
static int init_by_defaults(ares_channel channel); static int init_by_defaults(ares_channel channel);
static int config_domain(ares_channel channel, char *str); static int config_domain(ares_channel channel, char *str);
static int config_lookup(ares_channel channel, const char *str); static int config_lookup(ares_channel channel, const char *str,
const char *bindch, const char *filech);
static int config_nameserver(struct server_state **servers, int *nservers, static int config_nameserver(struct server_state **servers, int *nservers,
char *str); char *str);
static int config_sortlist(struct apattern **sortlist, int *nsort, static int config_sortlist(struct apattern **sortlist, int *nsort,
const char *str); const char *str);
static int set_search(ares_channel channel, const char *str); static int set_search(ares_channel channel, const char *str);
static int set_options(ares_channel channel, const char *str); static int set_options(ares_channel channel, const char *str);
static char *try_config(char *s, const char *opt); static char *try_config(char *s, const char *opt);
@@ -62,7 +74,7 @@ int ares_init(ares_channel *channelptr)
} }
int ares_init_options(ares_channel *channelptr, struct ares_options *options, int ares_init_options(ares_channel *channelptr, struct ares_options *options,
int optmask) int optmask)
{ {
ares_channel channel; ares_channel channel;
int i, status; int i, status;
@@ -104,15 +116,15 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options,
{ {
/* Something failed; clean up memory we may have allocated. */ /* Something failed; clean up memory we may have allocated. */
if (channel->nservers != -1) if (channel->nservers != -1)
free(channel->servers); free(channel->servers);
if (channel->domains) if (channel->domains)
{ {
for (i = 0; i < channel->ndomains; i++) for (i = 0; i < channel->ndomains; i++)
free(channel->domains[i]); free(channel->domains[i]);
free(channel->domains); free(channel->domains);
} }
if (channel->sortlist) if (channel->sortlist)
free(channel->sortlist); free(channel->sortlist);
if(channel->lookups) if(channel->lookups)
free(channel->lookups); free(channel->lookups);
free(channel); free(channel);
@@ -127,8 +139,8 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options,
for (i = 0; i < channel->nservers; i++) for (i = 0; i < channel->nservers; i++)
{ {
server = &channel->servers[i]; server = &channel->servers[i];
server->udp_socket = -1; server->udp_socket = ARES_SOCKET_BAD;
server->tcp_socket = -1; server->tcp_socket = ARES_SOCKET_BAD;
server->tcp_lenbuf_pos = 0; server->tcp_lenbuf_pos = 0;
server->tcp_buffer = NULL; server->tcp_buffer = NULL;
server->qhead = NULL; server->qhead = NULL;
@@ -151,7 +163,7 @@ int ares_init_options(ares_channel *channelptr, struct ares_options *options,
} }
static int init_by_options(ares_channel channel, struct ares_options *options, static int init_by_options(ares_channel channel, struct ares_options *options,
int optmask) int optmask)
{ {
int i; int i;
@@ -173,11 +185,11 @@ static int init_by_options(ares_channel channel, struct ares_options *options,
if ((optmask & ARES_OPT_SERVERS) && channel->nservers == -1) if ((optmask & ARES_OPT_SERVERS) && channel->nservers == -1)
{ {
channel->servers = channel->servers =
malloc(options->nservers * sizeof(struct server_state)); malloc(options->nservers * sizeof(struct server_state));
if (!channel->servers && options->nservers != 0) if (!channel->servers && options->nservers != 0)
return ARES_ENOMEM; return ARES_ENOMEM;
for (i = 0; i < options->nservers; i++) for (i = 0; i < options->nservers; i++)
channel->servers[i].addr = options->servers[i]; channel->servers[i].addr = options->servers[i];
channel->nservers = options->nservers; channel->nservers = options->nservers;
} }
@@ -188,14 +200,14 @@ static int init_by_options(ares_channel channel, struct ares_options *options,
{ {
channel->domains = malloc(options->ndomains * sizeof(char *)); channel->domains = malloc(options->ndomains * sizeof(char *));
if (!channel->domains && options->ndomains != 0) if (!channel->domains && options->ndomains != 0)
return ARES_ENOMEM; return ARES_ENOMEM;
for (i = 0; i < options->ndomains; i++) for (i = 0; i < options->ndomains; i++)
{ {
channel->ndomains = i; channel->ndomains = i;
channel->domains[i] = strdup(options->domains[i]); channel->domains[i] = strdup(options->domains[i]);
if (!channel->domains[i]) if (!channel->domains[i])
return ARES_ENOMEM; return ARES_ENOMEM;
} }
channel->ndomains = options->ndomains; channel->ndomains = options->ndomains;
} }
@@ -204,7 +216,7 @@ static int init_by_options(ares_channel channel, struct ares_options *options,
{ {
channel->lookups = strdup(options->lookups); channel->lookups = strdup(options->lookups);
if (!channel->lookups) if (!channel->lookups)
return ARES_ENOMEM; return ARES_ENOMEM;
} }
return ARES_SUCCESS; return ARES_SUCCESS;
@@ -220,7 +232,7 @@ static int init_by_environment(ares_channel channel)
{ {
status = set_search(channel, localdomain); status = set_search(channel, localdomain);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return status; return status;
} }
res_options = getenv("RES_OPTIONS"); res_options = getenv("RES_OPTIONS");
@@ -228,7 +240,7 @@ static int init_by_environment(ares_channel channel)
{ {
status = set_options(channel, res_options); status = set_options(channel, res_options);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return status; return status;
} }
return ARES_SUCCESS; return ARES_SUCCESS;
@@ -293,7 +305,7 @@ static int get_iphlpapi_dns_info (char *ret_buf, size_t ret_size)
{ {
FIXED_INFO *fi = alloca (sizeof(*fi)); FIXED_INFO *fi = alloca (sizeof(*fi));
DWORD size = sizeof (*fi); DWORD size = sizeof (*fi);
DWORD WINAPI (*GetNetworkParams) (FIXED_INFO*, DWORD*); /* available only on Win-98/2000+ */ DWORD (WINAPI *GetNetworkParams) (FIXED_INFO*, DWORD*); /* available only on Win-98/2000+ */
HMODULE handle; HMODULE handle;
IP_ADDR_STRING *ipAddr; IP_ADDR_STRING *ipAddr;
int i, count = 0; int i, count = 0;
@@ -380,14 +392,14 @@ static int init_by_resolv_conf(ares_channel channel)
On Windows 9X, the DNS server can be found in: On Windows 9X, the DNS server can be found in:
HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\VxD\MSTCP\NameServer HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\VxD\MSTCP\NameServer
On Windows NT/2000/XP/2003: On Windows NT/2000/XP/2003:
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\NameServer HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\NameServer
or or
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\DhcpNameServer HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\DhcpNameServer
or or
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\{AdapterID}\ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\{AdapterID}\
NameServer NameServer
or or
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\{AdapterID}\ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\{AdapterID}\
DhcpNameServer DhcpNameServer
*/ */
@@ -506,6 +518,24 @@ DhcpNameServer
free(resolvers); free(resolvers);
} }
#elif defined(WATT32)
int i;
sock_init();
for (i = 0; def_nameservers[i]; i++)
;
if (i == 0)
return ARES_SUCCESS; /* use localhost DNS server */
nservers = i;
servers = calloc(sizeof(*servers), i);
if (!servers)
return ARES_ENOMEM;
for (i = 0; def_nameservers[i]; i++)
servers[i].addr.s_addr = htonl(def_nameservers[i]);
status = ARES_EOF;
#else #else
{ {
char *p; char *p;
@@ -520,7 +550,7 @@ DhcpNameServer
if ((p = try_config(line, "domain"))) if ((p = try_config(line, "domain")))
status = config_domain(channel, p); status = config_domain(channel, p);
else if ((p = try_config(line, "lookup")) && !channel->lookups) else if ((p = try_config(line, "lookup")) && !channel->lookups)
status = config_lookup(channel, p); status = config_lookup(channel, p, "bind", "file");
else if ((p = try_config(line, "search"))) else if ((p = try_config(line, "search")))
status = set_search(channel, p); status = set_search(channel, p);
else if ((p = try_config(line, "nameserver")) && channel->nservers == -1) else if ((p = try_config(line, "nameserver")) && channel->nservers == -1)
@@ -534,9 +564,49 @@ DhcpNameServer
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
break; break;
} }
fclose(fp);
if (!channel->lookups) {
/* Many systems (Solaris, Linux, BSD's) use nsswitch.conf */
fp = fopen("/etc/nsswitch.conf", "r");
if (fp) {
while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS)
{
if ((p = try_config(line, "hosts:")) && !channel->lookups)
status = config_lookup(channel, p, "dns", "files");
}
fclose(fp);
}
}
if (!channel->lookups) {
/* Linux / GNU libc 2.x and possibly others have host.conf */
fp = fopen("/etc/host.conf", "r");
if (fp) {
while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS)
{
if ((p = try_config(line, "order")) && !channel->lookups)
status = config_lookup(channel, p, "bind", "hosts");
}
fclose(fp);
}
}
if (!channel->lookups) {
/* Tru64 uses /etc/svc.conf */
fp = fopen("/etc/svc.conf", "r");
if (fp) {
while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS)
{
if ((p = try_config(line, "hosts=")) && !channel->lookups)
status = config_lookup(channel, p, "bind", "local");
}
fclose(fp);
}
}
if(line) if(line)
free(line); free(line);
fclose(fp);
} }
#endif #endif
@@ -593,7 +663,7 @@ static int init_by_defaults(ares_channel channel)
/* If nobody specified servers, try a local named. */ /* If nobody specified servers, try a local named. */
channel->servers = malloc(sizeof(struct server_state)); channel->servers = malloc(sizeof(struct server_state));
if (!channel->servers) if (!channel->servers)
return ARES_ENOMEM; return ARES_ENOMEM;
channel->servers[0].addr.s_addr = htonl(INADDR_LOOPBACK); channel->servers[0].addr.s_addr = htonl(INADDR_LOOPBACK);
channel->nservers = 1; channel->nservers = 1;
} }
@@ -604,22 +674,22 @@ static int init_by_defaults(ares_channel channel)
* or set it to empty if the hostname isn't helpful. * or set it to empty if the hostname isn't helpful.
*/ */
if (gethostname(hostname, sizeof(hostname)) == -1 if (gethostname(hostname, sizeof(hostname)) == -1
|| !strchr(hostname, '.')) || !strchr(hostname, '.'))
{ {
channel->domains = malloc(0); channel->domains = malloc(0);
channel->ndomains = 0; channel->ndomains = 0;
} }
else else
{ {
channel->domains = malloc(sizeof(char *)); channel->domains = malloc(sizeof(char *));
if (!channel->domains) if (!channel->domains)
return ARES_ENOMEM; return ARES_ENOMEM;
channel->ndomains = 0; channel->ndomains = 0;
channel->domains[0] = strdup(strchr(hostname, '.') + 1); channel->domains[0] = strdup(strchr(hostname, '.') + 1);
if (!channel->domains[0]) if (!channel->domains[0])
return ARES_ENOMEM; return ARES_ENOMEM;
channel->ndomains = 1; channel->ndomains = 1;
} }
} }
if (channel->nsort == -1) if (channel->nsort == -1)
@@ -630,9 +700,9 @@ static int init_by_defaults(ares_channel channel)
if (!channel->lookups) if (!channel->lookups)
{ {
channel->lookups = strdup("bf"); channel->lookups = strdup("fb");
if (!channel->lookups) if (!channel->lookups)
return ARES_ENOMEM; return ARES_ENOMEM;
} }
return ARES_SUCCESS; return ARES_SUCCESS;
@@ -650,7 +720,8 @@ static int config_domain(ares_channel channel, char *str)
return set_search(channel, str); return set_search(channel, str);
} }
static int config_lookup(ares_channel channel, const char *str) static int config_lookup(ares_channel channel, const char *str,
const char *bindch, const char *filech)
{ {
char lookups[3], *l; char lookups[3], *l;
const char *p; const char *p;
@@ -663,12 +734,14 @@ static int config_lookup(ares_channel channel, const char *str)
p = str; p = str;
while (*p) while (*p)
{ {
if ((*p == 'b' || *p == 'f') && l < lookups + 2) if ((*p == *bindch || *p == *filech) && l < lookups + 2) {
*l++ = *p; if (*p == *bindch) *l++ = 'b';
while (*p && !isspace((unsigned char)*p)) else *l++ = 'f';
p++; }
while (isspace((unsigned char)*p)) while (*p && !isspace((unsigned char)*p) && (*p != ','))
p++; p++;
while (*p && (isspace((unsigned char)*p) || (*p == ',')))
p++;
} }
*l = 0; *l = 0;
channel->lookups = strdup(lookups); channel->lookups = strdup(lookups);
@@ -676,7 +749,7 @@ static int config_lookup(ares_channel channel, const char *str)
} }
static int config_nameserver(struct server_state **servers, int *nservers, static int config_nameserver(struct server_state **servers, int *nservers,
char *str) char *str)
{ {
struct in_addr addr; struct in_addr addr;
struct server_state *newserv; struct server_state *newserv;
@@ -737,7 +810,7 @@ static int config_nameserver(struct server_state **servers, int *nservers,
} }
static int config_sortlist(struct apattern **sortlist, int *nsort, static int config_sortlist(struct apattern **sortlist, int *nsort,
const char *str) const char *str)
{ {
struct apattern pat, *newsort; struct apattern pat, *newsort;
const char *q; const char *q;
@@ -747,37 +820,37 @@ static int config_sortlist(struct apattern **sortlist, int *nsort,
{ {
q = str; q = str;
while (*q && *q != '/' && *q != ';' && !isspace((unsigned char)*q)) while (*q && *q != '/' && *q != ';' && !isspace((unsigned char)*q))
q++; q++;
if (ip_addr(str, (int)(q - str), &pat.addr) == 0) if (ip_addr(str, (int)(q - str), &pat.addr) == 0)
{ {
/* We have a pattern address; now determine the mask. */ /* We have a pattern address; now determine the mask. */
if (*q == '/') if (*q == '/')
{ {
str = q + 1; str = q + 1;
while (*q && *q != ';' && !isspace((unsigned char)*q)) while (*q && *q != ';' && !isspace((unsigned char)*q))
q++; q++;
if (ip_addr(str, (int)(q - str), &pat.mask) != 0) if (ip_addr(str, (int)(q - str), &pat.mask) != 0)
natural_mask(&pat); natural_mask(&pat);
} }
else else
natural_mask(&pat); natural_mask(&pat);
/* Add this pattern to our list. */ /* Add this pattern to our list. */
newsort = realloc(*sortlist, (*nsort + 1) * sizeof(struct apattern)); newsort = realloc(*sortlist, (*nsort + 1) * sizeof(struct apattern));
if (!newsort) if (!newsort)
return ARES_ENOMEM; return ARES_ENOMEM;
newsort[*nsort] = pat; newsort[*nsort] = pat;
*sortlist = newsort; *sortlist = newsort;
(*nsort)++; (*nsort)++;
} }
else else
{ {
while (*q && *q != ';' && !isspace((unsigned char)*q)) while (*q && *q != ';' && !isspace((unsigned char)*q))
q++; q++;
} }
str = q; str = q;
while (isspace((unsigned char)*str)) while (isspace((unsigned char)*str))
str++; str++;
} }
return ARES_SUCCESS; return ARES_SUCCESS;
@@ -802,9 +875,9 @@ static int set_search(ares_channel channel, const char *str)
while (*p) while (*p)
{ {
while (*p && !isspace((unsigned char)*p)) while (*p && !isspace((unsigned char)*p))
p++; p++;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
n++; n++;
} }
@@ -820,15 +893,15 @@ static int set_search(ares_channel channel, const char *str)
channel->ndomains = n; channel->ndomains = n;
q = p; q = p;
while (*q && !isspace((unsigned char)*q)) while (*q && !isspace((unsigned char)*q))
q++; q++;
channel->domains[n] = malloc(q - p + 1); channel->domains[n] = malloc(q - p + 1);
if (!channel->domains[n]) if (!channel->domains[n])
return ARES_ENOMEM; return ARES_ENOMEM;
memcpy(channel->domains[n], p, q - p); memcpy(channel->domains[n], p, q - p);
channel->domains[n][q - p] = 0; channel->domains[n][q - p] = 0;
p = q; p = q;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
n++; n++;
} }
channel->ndomains = n; channel->ndomains = n;
@@ -845,19 +918,19 @@ static int set_options(ares_channel channel, const char *str)
{ {
q = p; q = p;
while (*q && !isspace((unsigned char)*q)) while (*q && !isspace((unsigned char)*q))
q++; q++;
val = try_option(p, q, "ndots:"); val = try_option(p, q, "ndots:");
if (val && channel->ndots == -1) if (val && channel->ndots == -1)
channel->ndots = atoi(val); channel->ndots = atoi(val);
val = try_option(p, q, "retrans:"); val = try_option(p, q, "retrans:");
if (val && channel->timeout == -1) if (val && channel->timeout == -1)
channel->timeout = atoi(val); channel->timeout = atoi(val);
val = try_option(p, q, "retry:"); val = try_option(p, q, "retry:");
if (val && channel->tries == -1) if (val && channel->tries == -1)
channel->tries = atoi(val); channel->tries = atoi(val);
p = q; p = q;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
} }
return ARES_SUCCESS; return ARES_SUCCESS;

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <netinet/in.h> #include <netinet/in.h>
@@ -46,15 +47,15 @@
* *
* AA, TC, RA, and RCODE are only set in responses. Brief description * AA, TC, RA, and RCODE are only set in responses. Brief description
* of the remaining fields: * of the remaining fields:
* ID Identifier to match responses with queries * ID Identifier to match responses with queries
* QR Query (0) or response (1) * QR Query (0) or response (1)
* Opcode For our purposes, always QUERY * Opcode For our purposes, always QUERY
* RD Recursion desired * RD Recursion desired
* Z Reserved (zero) * Z Reserved (zero)
* QDCOUNT Number of queries * QDCOUNT Number of queries
* ANCOUNT Number of answers * ANCOUNT Number of answers
* NSCOUNT Number of name server records * NSCOUNT Number of name server records
* ARCOUNT Number of additional records * ARCOUNT Number of additional records
* *
* Question format, from RFC 1035: * Question format, from RFC 1035:
* 1 1 1 1 1 1 * 1 1 1 1 1 1
@@ -76,7 +77,7 @@
*/ */
int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id, int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id,
int rd, unsigned char **buf, int *buflen) int rd, unsigned char **buf, int *buflen)
{ {
int len; int len;
unsigned char *q; unsigned char *q;
@@ -88,7 +89,7 @@ int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id,
for (p = name; *p; p++) for (p = name; *p; p++)
{ {
if (*p == '\\' && *(p + 1) != 0) if (*p == '\\' && *(p + 1) != 0)
p++; p++;
len++; len++;
} }
/* If there are n periods in the name, there are n + 1 labels, and /* If there are n periods in the name, there are n + 1 labels, and
@@ -120,31 +121,31 @@ int ares_mkquery(const char *name, int dnsclass, int type, unsigned short id,
while (*name) while (*name)
{ {
if (*name == '.') if (*name == '.')
return ARES_EBADNAME; return ARES_EBADNAME;
/* Count the number of bytes in this label. */ /* Count the number of bytes in this label. */
len = 0; len = 0;
for (p = name; *p && *p != '.'; p++) for (p = name; *p && *p != '.'; p++)
{ {
if (*p == '\\' && *(p + 1) != 0) if (*p == '\\' && *(p + 1) != 0)
p++; p++;
len++; len++;
} }
if (len > MAXLABEL) if (len > MAXLABEL)
return ARES_EBADNAME; return ARES_EBADNAME;
/* Encode the length and copy the data. */ /* Encode the length and copy the data. */
*q++ = len; *q++ = len;
for (p = name; *p && *p != '.'; p++) for (p = name; *p && *p != '.'; p++)
{ {
if (*p == '\\' && *(p + 1) != 0) if (*p == '\\' && *(p + 1) != 0)
p++; p++;
*q++ = *p; *q++ = *p;
} }
/* Go to the next label and repeat, unless we hit the end. */ /* Go to the next label and repeat, unless we hit the end. */
if (!*p) if (!*p)
break; break;
name = p + 1; name = p + 1;
} }

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <sys/socket.h> #include <sys/socket.h>
@@ -32,7 +33,7 @@
#include "ares_private.h" #include "ares_private.h"
int ares_parse_a_reply(const unsigned char *abuf, int alen, int ares_parse_a_reply(const unsigned char *abuf, int alen,
struct hostent **host) struct hostent **host)
{ {
unsigned int qdcount, ancount; unsigned int qdcount, ancount;
int status, i, rr_type, rr_class, rr_len, naddrs; int status, i, rr_type, rr_class, rr_len, naddrs;
@@ -91,49 +92,49 @@ int ares_parse_a_reply(const unsigned char *abuf, int alen,
/* Decode the RR up to the data field. */ /* Decode the RR up to the data field. */
status = ares_expand_name(aptr, abuf, alen, &rr_name, &len); status = ares_expand_name(aptr, abuf, alen, &rr_name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
break; break;
aptr += len; aptr += len;
if (aptr + RRFIXEDSZ > abuf + alen) if (aptr + RRFIXEDSZ > abuf + alen)
{ {
status = ARES_EBADRESP; status = ARES_EBADRESP;
break; break;
} }
rr_type = DNS_RR_TYPE(aptr); rr_type = DNS_RR_TYPE(aptr);
rr_class = DNS_RR_CLASS(aptr); rr_class = DNS_RR_CLASS(aptr);
rr_len = DNS_RR_LEN(aptr); rr_len = DNS_RR_LEN(aptr);
aptr += RRFIXEDSZ; aptr += RRFIXEDSZ;
if (rr_class == C_IN && rr_type == T_A if (rr_class == C_IN && rr_type == T_A
&& rr_len == sizeof(struct in_addr) && rr_len == sizeof(struct in_addr)
&& strcasecmp(rr_name, hostname) == 0) && strcasecmp(rr_name, hostname) == 0)
{ {
memcpy(&addrs[naddrs], aptr, sizeof(struct in_addr)); memcpy(&addrs[naddrs], aptr, sizeof(struct in_addr));
naddrs++; naddrs++;
status = ARES_SUCCESS; status = ARES_SUCCESS;
} }
if (rr_class == C_IN && rr_type == T_CNAME) if (rr_class == C_IN && rr_type == T_CNAME)
{ {
/* Record the RR name as an alias. */ /* Record the RR name as an alias. */
aliases[naliases] = rr_name; aliases[naliases] = rr_name;
naliases++; naliases++;
/* Decode the RR data and replace the hostname with it. */ /* Decode the RR data and replace the hostname with it. */
status = ares_expand_name(aptr, abuf, alen, &rr_data, &len); status = ares_expand_name(aptr, abuf, alen, &rr_data, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
break; break;
free(hostname); free(hostname);
hostname = rr_data; hostname = rr_data;
} }
else else
free(rr_name); free(rr_name);
aptr += rr_len; aptr += rr_len;
if (aptr > abuf + alen) if (aptr > abuf + alen)
{ {
status = ARES_EBADRESP; status = ARES_EBADRESP;
break; break;
} }
} }
if (status == ARES_SUCCESS && naddrs == 0) if (status == ARES_SUCCESS && naddrs == 0)
@@ -144,23 +145,23 @@ int ares_parse_a_reply(const unsigned char *abuf, int alen,
aliases[naliases] = NULL; aliases[naliases] = NULL;
hostent = malloc(sizeof(struct hostent)); hostent = malloc(sizeof(struct hostent));
if (hostent) if (hostent)
{ {
hostent->h_addr_list = malloc((naddrs + 1) * sizeof(char *)); hostent->h_addr_list = malloc((naddrs + 1) * sizeof(char *));
if (hostent->h_addr_list) if (hostent->h_addr_list)
{ {
/* Fill in the hostent and return successfully. */ /* Fill in the hostent and return successfully. */
hostent->h_name = hostname; hostent->h_name = hostname;
hostent->h_aliases = aliases; hostent->h_aliases = aliases;
hostent->h_addrtype = AF_INET; hostent->h_addrtype = AF_INET;
hostent->h_length = sizeof(struct in_addr); hostent->h_length = sizeof(struct in_addr);
for (i = 0; i < naddrs; i++) for (i = 0; i < naddrs; i++)
hostent->h_addr_list[i] = (char *) &addrs[i]; hostent->h_addr_list[i] = (char *) &addrs[i];
hostent->h_addr_list[naddrs] = NULL; hostent->h_addr_list[naddrs] = NULL;
*host = hostent; *host = hostent;
return ARES_SUCCESS; return ARES_SUCCESS;
} }
free(hostent); free(hostent);
} }
status = ARES_ENOMEM; status = ARES_ENOMEM;
} }
for (i = 0; i < naliases; i++) for (i = 0; i < naliases; i++)

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <sys/socket.h> #include <sys/socket.h>
@@ -31,7 +32,7 @@
#include "ares_private.h" #include "ares_private.h"
int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr, int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr,
int addrlen, int family, struct hostent **host) int addrlen, int family, struct hostent **host)
{ {
unsigned int qdcount, ancount; unsigned int qdcount, ancount;
int status, i, rr_type, rr_class, rr_len; int status, i, rr_type, rr_class, rr_len;
@@ -72,47 +73,47 @@ int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr,
/* Decode the RR up to the data field. */ /* Decode the RR up to the data field. */
status = ares_expand_name(aptr, abuf, alen, &rr_name, &len); status = ares_expand_name(aptr, abuf, alen, &rr_name, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
break; break;
aptr += len; aptr += len;
if (aptr + RRFIXEDSZ > abuf + alen) if (aptr + RRFIXEDSZ > abuf + alen)
{ {
status = ARES_EBADRESP; status = ARES_EBADRESP;
break; break;
} }
rr_type = DNS_RR_TYPE(aptr); rr_type = DNS_RR_TYPE(aptr);
rr_class = DNS_RR_CLASS(aptr); rr_class = DNS_RR_CLASS(aptr);
rr_len = DNS_RR_LEN(aptr); rr_len = DNS_RR_LEN(aptr);
aptr += RRFIXEDSZ; aptr += RRFIXEDSZ;
if (rr_class == C_IN && rr_type == T_PTR if (rr_class == C_IN && rr_type == T_PTR
&& strcasecmp(rr_name, ptrname) == 0) && strcasecmp(rr_name, ptrname) == 0)
{ {
/* Decode the RR data and set hostname to it. */ /* Decode the RR data and set hostname to it. */
status = ares_expand_name(aptr, abuf, alen, &rr_data, &len); status = ares_expand_name(aptr, abuf, alen, &rr_data, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
break; break;
if (hostname) if (hostname)
free(hostname); free(hostname);
hostname = rr_data; hostname = rr_data;
} }
if (rr_class == C_IN && rr_type == T_CNAME) if (rr_class == C_IN && rr_type == T_CNAME)
{ {
/* Decode the RR data and replace ptrname with it. */ /* Decode the RR data and replace ptrname with it. */
status = ares_expand_name(aptr, abuf, alen, &rr_data, &len); status = ares_expand_name(aptr, abuf, alen, &rr_data, &len);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
break; break;
free(ptrname); free(ptrname);
ptrname = rr_data; ptrname = rr_data;
} }
free(rr_name); free(rr_name);
aptr += rr_len; aptr += rr_len;
if (aptr > abuf + alen) if (aptr > abuf + alen)
{ {
status = ARES_EBADRESP; status = ARES_EBADRESP;
break; break;
} }
} }
if (status == ARES_SUCCESS && !hostname) if (status == ARES_SUCCESS && !hostname)
@@ -122,33 +123,33 @@ int ares_parse_ptr_reply(const unsigned char *abuf, int alen, const void *addr,
/* We got our answer. Allocate memory to build the host entry. */ /* We got our answer. Allocate memory to build the host entry. */
hostent = malloc(sizeof(struct hostent)); hostent = malloc(sizeof(struct hostent));
if (hostent) if (hostent)
{ {
hostent->h_addr_list = malloc(2 * sizeof(char *)); hostent->h_addr_list = malloc(2 * sizeof(char *));
if (hostent->h_addr_list) if (hostent->h_addr_list)
{ {
hostent->h_addr_list[0] = malloc(addrlen); hostent->h_addr_list[0] = malloc(addrlen);
if (hostent->h_addr_list[0]) if (hostent->h_addr_list[0])
{ {
hostent->h_aliases = malloc(sizeof (char *)); hostent->h_aliases = malloc(sizeof (char *));
if (hostent->h_aliases) if (hostent->h_aliases)
{ {
/* Fill in the hostent and return successfully. */ /* Fill in the hostent and return successfully. */
hostent->h_name = hostname; hostent->h_name = hostname;
hostent->h_aliases[0] = NULL; hostent->h_aliases[0] = NULL;
hostent->h_addrtype = family; hostent->h_addrtype = family;
hostent->h_length = addrlen; hostent->h_length = addrlen;
memcpy(hostent->h_addr_list[0], addr, addrlen); memcpy(hostent->h_addr_list[0], addr, addrlen);
hostent->h_addr_list[1] = NULL; hostent->h_addr_list[1] = NULL;
*host = hostent; *host = hostent;
free(ptrname); free(ptrname);
return ARES_SUCCESS; return ARES_SUCCESS;
} }
free(hostent->h_addr_list[0]); free(hostent->h_addr_list[0]);
} }
free(hostent->h_addr_list); free(hostent->h_addr_list);
} }
free(hostent); free(hostent);
} }
status = ARES_ENOMEM; status = ARES_ENOMEM;
} }
if (hostname) if (hostname)

View File

@@ -18,38 +18,53 @@
#include <stdio.h> #include <stdio.h>
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if !defined(WIN32) || defined(WATT32)
#else
#include <netinet/in.h> #include <netinet/in.h>
/* We define closesocket() here so that we can use this function all over /* We define closesocket() here so that we can use this function all over
the source code for closing sockets. */ the source code for closing sockets. */
#define closesocket(x) close(x) #define closesocket(x) close(x)
#endif #endif
#define DEFAULT_TIMEOUT 5 #ifdef WATT32
#define DEFAULT_TRIES 4 #include <tcp.h>
#ifndef INADDR_NONE #include <sys/ioctl.h>
#define INADDR_NONE 0xffffffff #undef closesocket
#define closesocket(s) close_s(s)
#define writev(s,v,c) writev_s(s,v,c)
#endif #endif
#ifdef WIN32 #define DEFAULT_TIMEOUT 5
#define DEFAULT_TRIES 4
#ifndef INADDR_NONE
#define INADDR_NONE 0xffffffff
#endif
#if defined(WIN32) && !defined(WATT32)
#define IsNT ((int)GetVersion()>0) #define IsNT ((int)GetVersion()>0)
#define WIN_NS_9X "System\\CurrentControlSet\\Services\\VxD\\MSTCP" #define WIN_NS_9X "System\\CurrentControlSet\\Services\\VxD\\MSTCP"
#define WIN_NS_NT_KEY "System\\CurrentControlSet\\Services\\Tcpip\\Parameters" #define WIN_NS_NT_KEY "System\\CurrentControlSet\\Services\\Tcpip\\Parameters"
#define NAMESERVER "NameServer" #define NAMESERVER "NameServer"
#define DHCPNAMESERVER "DhcpNameServer" #define DHCPNAMESERVER "DhcpNameServer"
#define PATH_HOSTS_NT "\\drivers\\etc\\hosts" #define DATABASEPATH "DatabasePath"
#define PATH_HOSTS_9X "\\hosts" #define WIN_PATH_HOSTS "\\hosts"
#elif defined(WATT32)
#define PATH_RESOLV_CONF "/dev/ENV/etc/resolv.conf"
#elif defined(NETWARE)
#define PATH_RESOLV_CONF "sys:/etc/resolv.cfg"
#define PATH_HOSTS "sys:/etc/hosts"
#else #else
#define PATH_RESOLV_CONF "/etc/resolv.conf" #define PATH_RESOLV_CONF "/etc/resolv.conf"
#ifdef ETC_INET #ifdef ETC_INET
#define PATH_HOSTS "/etc/inet/hosts" #define PATH_HOSTS "/etc/inet/hosts"
#else #else
#define PATH_HOSTS "/etc/hosts" #define PATH_HOSTS "/etc/hosts"
#endif #endif
#endif #endif
@@ -65,8 +80,8 @@ struct send_request {
struct server_state { struct server_state {
struct in_addr addr; struct in_addr addr;
int udp_socket; ares_socket_t udp_socket;
int tcp_socket; ares_socket_t tcp_socket;
/* Mini-buffer for reading the length word */ /* Mini-buffer for reading the length word */
unsigned char tcp_lenbuf[2]; unsigned char tcp_lenbuf[2];

View File

@@ -13,44 +13,57 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <sys/socket.h> #include <sys/socket.h>
#ifdef HAVE_SYS_UIO_H
#include <sys/uio.h> #include <sys/uio.h>
#endif
#include <netinet/in.h> #include <netinet/in.h>
#include <netdb.h> #include <netdb.h>
#include <arpa/nameser.h> #include <arpa/nameser.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h> #include <unistd.h>
#endif #endif
#endif
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include <fcntl.h> #include <fcntl.h>
#include <time.h> #include <time.h>
#include <errno.h> #include <errno.h>
#include "ares.h" #include "ares.h"
#include "ares_dns.h" #include "ares_dns.h"
#include "ares_private.h" #include "ares_private.h"
#if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS)
#define GET_ERRNO() WSAGetLastError()
#else
#define GET_ERRNO() errno
#endif
static void write_tcp_data(ares_channel channel, fd_set *write_fds, static void write_tcp_data(ares_channel channel, fd_set *write_fds,
time_t now); time_t now);
static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now); static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now);
static void read_udp_packets(ares_channel channel, fd_set *read_fds, static void read_udp_packets(ares_channel channel, fd_set *read_fds,
time_t now); time_t now);
static void process_timeouts(ares_channel channel, time_t now); static void process_timeouts(ares_channel channel, time_t now);
static void process_answer(ares_channel channel, unsigned char *abuf, static void process_answer(ares_channel channel, unsigned char *abuf,
int alen, int whichserver, int tcp, int now); int alen, int whichserver, int tcp, int now);
static void handle_error(ares_channel channel, int whichserver, time_t now); static void handle_error(ares_channel channel, int whichserver, time_t now);
static void next_server(ares_channel channel, struct query *query, time_t now); static struct query *next_server(ares_channel channel, struct query *query, time_t now);
static int open_tcp_socket(ares_channel channel, struct server_state *server); static int open_tcp_socket(ares_channel channel, struct server_state *server);
static int open_udp_socket(ares_channel channel, struct server_state *server); static int open_udp_socket(ares_channel channel, struct server_state *server);
static int same_questions(const unsigned char *qbuf, int qlen, static int same_questions(const unsigned char *qbuf, int qlen,
const unsigned char *abuf, int alen); const unsigned char *abuf, int alen);
static void end_query(ares_channel channel, struct query *query, int status, static struct query *end_query(ares_channel channel, struct query *query, int status,
unsigned char *abuf, int alen); unsigned char *abuf, int alen);
/* Something interesting happened on the wire, or there was a timeout. /* Something interesting happened on the wire, or there was a timeout.
* See what's up and respond accordingly. * See what's up and respond accordingly.
@@ -74,95 +87,91 @@ static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now)
struct server_state *server; struct server_state *server;
struct send_request *sendreq; struct send_request *sendreq;
struct iovec *vec; struct iovec *vec;
int i, n, count; int i;
ssize_t scount;
int wcount;
size_t n;
for (i = 0; i < channel->nservers; i++) for (i = 0; i < channel->nservers; i++)
{ {
/* Make sure server has data to send and is selected in write_fds. */ /* Make sure server has data to send and is selected in write_fds. */
server = &channel->servers[i]; server = &channel->servers[i];
if (!server->qhead || server->tcp_socket == -1 if (!server->qhead || server->tcp_socket == ARES_SOCKET_BAD
|| !FD_ISSET(server->tcp_socket, write_fds)) || !FD_ISSET(server->tcp_socket, write_fds))
continue; continue;
/* Count the number of send queue items. */ /* Count the number of send queue items. */
n = 0; n = 0;
for (sendreq = server->qhead; sendreq; sendreq = sendreq->next) for (sendreq = server->qhead; sendreq; sendreq = sendreq->next)
n++; n++;
#ifdef WIN32
vec = NULL;
#else
/* Allocate iovecs so we can send all our data at once. */ /* Allocate iovecs so we can send all our data at once. */
vec = malloc(n * sizeof(struct iovec)); vec = malloc(n * sizeof(struct iovec));
#endif
if (vec) if (vec)
{ {
#ifdef WIN32 /* Fill in the iovecs and send. */
#else n = 0;
/* Fill in the iovecs and send. */ for (sendreq = server->qhead; sendreq; sendreq = sendreq->next)
n = 0; {
for (sendreq = server->qhead; sendreq; sendreq = sendreq->next) vec[n].iov_base = (char *) sendreq->data;
{ vec[n].iov_len = sendreq->len;
vec[n].iov_base = (char *) sendreq->data; n++;
vec[n].iov_len = sendreq->len; }
n++; wcount = writev(server->tcp_socket, vec, n);
} free(vec);
count = writev(server->tcp_socket, vec, n); if (wcount < 0)
free(vec); {
if (count < 0) handle_error(channel, i, now);
{ continue;
handle_error(channel, i, now); }
continue;
}
/* Advance the send queue by as many bytes as we sent. */ /* Advance the send queue by as many bytes as we sent. */
while (count) while (wcount)
{ {
sendreq = server->qhead; sendreq = server->qhead;
if ((size_t)count >= sendreq->len) if ((size_t)wcount >= sendreq->len)
{ {
count -= sendreq->len; wcount -= sendreq->len;
server->qhead = sendreq->next; server->qhead = sendreq->next;
if (server->qhead == NULL) if (server->qhead == NULL)
server->qtail = NULL; server->qtail = NULL;
free(sendreq); free(sendreq);
} }
else else
{ {
sendreq->data += count; sendreq->data += wcount;
sendreq->len -= count; sendreq->len -= wcount;
break; break;
} }
} }
#endif }
}
else else
{ {
/* Can't allocate iovecs; just send the first request. */ /* Can't allocate iovecs; just send the first request. */
sendreq = server->qhead; sendreq = server->qhead;
count = send(server->tcp_socket, sendreq->data, sendreq->len, 0); scount = send(server->tcp_socket, sendreq->data, sendreq->len, 0);
if (count < 0) if (scount < 0)
{ {
handle_error(channel, i, now); handle_error(channel, i, now);
continue; continue;
} }
/* Advance the send queue by as many bytes as we sent. */ /* Advance the send queue by as many bytes as we sent. */
if ((size_t)count == sendreq->len) if ((size_t)scount == sendreq->len)
{ {
server->qhead = sendreq->next; server->qhead = sendreq->next;
if (server->qhead == NULL) if (server->qhead == NULL)
server->qtail = NULL; server->qtail = NULL;
free(sendreq); free(sendreq);
} }
else else
{ {
sendreq->data += count; sendreq->data += scount;
sendreq->len -= count; sendreq->len -= scount;
} }
} }
} }
} }
@@ -179,68 +188,70 @@ static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now)
{ {
/* Make sure the server has a socket and is selected in read_fds. */ /* Make sure the server has a socket and is selected in read_fds. */
server = &channel->servers[i]; server = &channel->servers[i];
if (server->tcp_socket == -1 || !FD_ISSET(server->tcp_socket, read_fds)) if (server->tcp_socket == ARES_SOCKET_BAD ||
continue; !FD_ISSET(server->tcp_socket, read_fds))
continue;
if (server->tcp_lenbuf_pos != 2) if (server->tcp_lenbuf_pos != 2)
{ {
/* We haven't yet read a length word, so read that (or /* We haven't yet read a length word, so read that (or
* what's left to read of it). * what's left to read of it).
*/ */
count = recv(server->tcp_socket, count = recv(server->tcp_socket,
server->tcp_lenbuf + server->tcp_buffer_pos, server->tcp_lenbuf + server->tcp_buffer_pos,
2 - server->tcp_buffer_pos, 0); 2 - server->tcp_buffer_pos, 0);
if (count <= 0) if (count <= 0)
{ {
handle_error(channel, i, now); handle_error(channel, i, now);
continue; continue;
} }
server->tcp_lenbuf_pos += count; server->tcp_lenbuf_pos += count;
if (server->tcp_lenbuf_pos == 2) if (server->tcp_lenbuf_pos == 2)
{ {
/* We finished reading the length word. Decode the /* We finished reading the length word. Decode the
* length and allocate a buffer for the data. * length and allocate a buffer for the data.
*/ */
server->tcp_length = server->tcp_lenbuf[0] << 8 server->tcp_length = server->tcp_lenbuf[0] << 8
| server->tcp_lenbuf[1]; | server->tcp_lenbuf[1];
server->tcp_buffer = malloc(server->tcp_length); server->tcp_buffer = malloc(server->tcp_length);
if (!server->tcp_buffer) if (!server->tcp_buffer)
handle_error(channel, i, now); handle_error(channel, i, now);
server->tcp_buffer_pos = 0; server->tcp_buffer_pos = 0;
} }
} }
else else
{ {
/* Read data into the allocated buffer. */ /* Read data into the allocated buffer. */
count = recv(server->tcp_socket, count = recv(server->tcp_socket,
server->tcp_buffer + server->tcp_buffer_pos, server->tcp_buffer + server->tcp_buffer_pos,
server->tcp_length - server->tcp_buffer_pos, 0); server->tcp_length - server->tcp_buffer_pos, 0);
if (count <= 0) if (count <= 0)
{ {
handle_error(channel, i, now); handle_error(channel, i, now);
continue; continue;
} }
server->tcp_buffer_pos += count; server->tcp_buffer_pos += count;
if (server->tcp_buffer_pos == server->tcp_length) if (server->tcp_buffer_pos == server->tcp_length)
{ {
/* We finished reading this answer; process it and /* We finished reading this answer; process it and
* prepare to read another length word. * prepare to read another length word.
*/ */
process_answer(channel, server->tcp_buffer, server->tcp_length, process_answer(channel, server->tcp_buffer, server->tcp_length,
i, 1, now); i, 1, now);
free(server->tcp_buffer); if (server->tcp_buffer)
server->tcp_buffer = NULL; free(server->tcp_buffer);
server->tcp_lenbuf_pos = 0; server->tcp_buffer = NULL;
} server->tcp_lenbuf_pos = 0;
} }
}
} }
} }
/* If any UDP sockets select true for reading, process them. */ /* If any UDP sockets select true for reading, process them. */
static void read_udp_packets(ares_channel channel, fd_set *read_fds, static void read_udp_packets(ares_channel channel, fd_set *read_fds,
time_t now) time_t now)
{ {
struct server_state *server; struct server_state *server;
int i, count; int i, count;
@@ -251,12 +262,13 @@ static void read_udp_packets(ares_channel channel, fd_set *read_fds,
/* Make sure the server has a socket and is selected in read_fds. */ /* Make sure the server has a socket and is selected in read_fds. */
server = &channel->servers[i]; server = &channel->servers[i];
if (server->udp_socket == -1 || !FD_ISSET(server->udp_socket, read_fds)) if (server->udp_socket == ARES_SOCKET_BAD ||
continue; !FD_ISSET(server->udp_socket, read_fds))
continue;
count = recv(server->udp_socket, buf, sizeof(buf), 0); count = recv(server->udp_socket, buf, sizeof(buf), 0);
if (count <= 0) if (count <= 0)
handle_error(channel, i, now); handle_error(channel, i, now);
process_answer(channel, buf, count, i, 0, now); process_answer(channel, buf, count, i, 0, now);
} }
@@ -271,16 +283,16 @@ static void process_timeouts(ares_channel channel, time_t now)
{ {
next = query->next; next = query->next;
if (query->timeout != 0 && now >= query->timeout) if (query->timeout != 0 && now >= query->timeout)
{ {
query->error_status = ARES_ETIMEOUT; query->error_status = ARES_ETIMEOUT;
next_server(channel, query, now); next = next_server(channel, query, now);
} }
} }
} }
/* Handle an answer from a server. */ /* Handle an answer from a server. */
static void process_answer(ares_channel channel, unsigned char *abuf, static void process_answer(ares_channel channel, unsigned char *abuf,
int alen, int whichserver, int tcp, int now) int alen, int whichserver, int tcp, int now)
{ {
int id, tc, rcode; int id, tc, rcode;
struct query *query; struct query *query;
@@ -299,7 +311,7 @@ static void process_answer(ares_channel channel, unsigned char *abuf,
for (query = channel->queries; query; query = query->next) for (query = channel->queries; query; query = query->next)
{ {
if (query->qid == id) if (query->qid == id)
break; break;
} }
if (!query) if (!query)
return; return;
@@ -311,10 +323,10 @@ static void process_answer(ares_channel channel, unsigned char *abuf,
if ((tc || alen > PACKETSZ) && !tcp && !(channel->flags & ARES_FLAG_IGNTC)) if ((tc || alen > PACKETSZ) && !tcp && !(channel->flags & ARES_FLAG_IGNTC))
{ {
if (!query->using_tcp) if (!query->using_tcp)
{ {
query->using_tcp = 1; query->using_tcp = 1;
ares__send_query(channel, query, now); ares__send_query(channel, query, now);
} }
return; return;
} }
@@ -330,18 +342,18 @@ static void process_answer(ares_channel channel, unsigned char *abuf,
if (!(channel->flags & ARES_FLAG_NOCHECKRESP)) if (!(channel->flags & ARES_FLAG_NOCHECKRESP))
{ {
if (rcode == SERVFAIL || rcode == NOTIMP || rcode == REFUSED) if (rcode == SERVFAIL || rcode == NOTIMP || rcode == REFUSED)
{ {
query->skip_server[whichserver] = 1; query->skip_server[whichserver] = 1;
if (query->server == whichserver) if (query->server == whichserver)
next_server(channel, query, now); next_server(channel, query, now);
return; return;
} }
if (!same_questions(query->qbuf, query->qlen, abuf, alen)) if (!same_questions(query->qbuf, query->qlen, abuf, alen))
{ {
if (query->server == whichserver) if (query->server == whichserver)
next_server(channel, query, now); next_server(channel, query, now);
return; return;
} }
} }
end_query(channel, query, ARES_SUCCESS, abuf, alen); end_query(channel, query, ARES_SUCCESS, abuf, alen);
@@ -349,7 +361,7 @@ static void process_answer(ares_channel channel, unsigned char *abuf,
static void handle_error(ares_channel channel, int whichserver, time_t now) static void handle_error(ares_channel channel, int whichserver, time_t now)
{ {
struct query *query; struct query *query, *next;
/* Reset communications with this server. */ /* Reset communications with this server. */
ares__close_sockets(&channel->servers[whichserver]); ares__close_sockets(&channel->servers[whichserver]);
@@ -357,37 +369,39 @@ static void handle_error(ares_channel channel, int whichserver, time_t now)
/* Tell all queries talking to this server to move on and not try /* Tell all queries talking to this server to move on and not try
* this server again. * this server again.
*/ */
for (query = channel->queries; query; query = query->next)
for (query = channel->queries; query; query = next)
{ {
next = query->next;
if (query->server == whichserver) if (query->server == whichserver)
{ {
query->skip_server[whichserver] = 1; query->skip_server[whichserver] = 1;
next_server(channel, query, now); next = next_server(channel, query, now);
} }
} }
} }
static void next_server(ares_channel channel, struct query *query, time_t now) static struct query *next_server(ares_channel channel, struct query *query, time_t now)
{ {
/* Advance to the next server or try. */ /* Advance to the next server or try. */
query->server++; query->server++;
for (; query->try < channel->tries; query->try++) for (; query->try < channel->tries; query->try++)
{ {
for (; query->server < channel->nservers; query->server++) for (; query->server < channel->nservers; query->server++)
{ {
if (!query->skip_server[query->server]) if (!query->skip_server[query->server])
{ {
ares__send_query(channel, query, now); ares__send_query(channel, query, now);
return; return (query->next);
} }
} }
query->server = 0; query->server = 0;
/* Only one try if we're using TCP. */ /* Only one try if we're using TCP. */
if (query->using_tcp) if (query->using_tcp)
break; break;
} }
end_query(channel, query, query->error_status, NULL, 0); return end_query(channel, query, query->error_status, NULL, 0);
} }
void ares__send_query(ares_channel channel, struct query *query, time_t now) void ares__send_query(ares_channel channel, struct query *query, time_t now)
@@ -401,64 +415,68 @@ void ares__send_query(ares_channel channel, struct query *query, time_t now)
/* Make sure the TCP socket for this server is set up and queue /* Make sure the TCP socket for this server is set up and queue
* a send request. * a send request.
*/ */
if (server->tcp_socket == -1) if (server->tcp_socket == ARES_SOCKET_BAD)
{ {
if (open_tcp_socket(channel, server) == -1) if (open_tcp_socket(channel, server) == -1)
{ {
query->skip_server[query->server] = 1; query->skip_server[query->server] = 1;
next_server(channel, query, now); next_server(channel, query, now);
return; return;
} }
} }
sendreq = malloc(sizeof(struct send_request)); sendreq = calloc(sizeof(struct send_request), 1);
if (!sendreq) if (!sendreq)
end_query(channel, query, ARES_ENOMEM, NULL, 0); {
end_query(channel, query, ARES_ENOMEM, NULL, 0);
return;
}
sendreq->data = query->tcpbuf; sendreq->data = query->tcpbuf;
sendreq->len = query->tcplen; sendreq->len = query->tcplen;
sendreq->next = NULL; sendreq->next = NULL;
if (server->qtail) if (server->qtail)
server->qtail->next = sendreq; server->qtail->next = sendreq;
else else
server->qhead = sendreq; server->qhead = sendreq;
server->qtail = sendreq; server->qtail = sendreq;
query->timeout = 0; query->timeout = 0;
} }
else else
{ {
if (server->udp_socket == -1) if (server->udp_socket == ARES_SOCKET_BAD)
{ {
if (open_udp_socket(channel, server) == -1) if (open_udp_socket(channel, server) == -1)
{ {
query->skip_server[query->server] = 1; query->skip_server[query->server] = 1;
next_server(channel, query, now); next_server(channel, query, now);
return; return;
} }
} }
if (send(server->udp_socket, query->qbuf, query->qlen, 0) == -1) if (send(server->udp_socket, query->qbuf, query->qlen, 0) == -1)
{ {
query->skip_server[query->server] = 1; query->skip_server[query->server] = 1;
next_server(channel, query, now); next_server(channel, query, now);
return; return;
} }
query->timeout = now query->timeout = now
+ ((query->try == 0) ? channel->timeout + ((query->try == 0) ? channel->timeout
: channel->timeout << query->try / channel->nservers); : channel->timeout << query->try / channel->nservers);
} }
} }
static int open_tcp_socket(ares_channel channel, struct server_state *server) static int open_tcp_socket(ares_channel channel, struct server_state *server)
{ {
int s, flags; ares_socket_t s;
int flags;
struct sockaddr_in sockin; struct sockaddr_in sockin;
/* Acquire a socket. */ /* Acquire a socket. */
s = socket(AF_INET, SOCK_STREAM, 0); s = socket(AF_INET, SOCK_STREAM, 0);
if (s == -1) if (s == ARES_SOCKET_BAD)
return -1; return -1;
/* Set the socket non-blocking. */ /* Set the socket non-blocking. */
#ifdef WIN32 #if defined(WIN32) || defined(WATT32)
flags = 1; flags = 1;
ioctlsocket(s, FIONBIO, &flags); ioctlsocket(s, FIONBIO, &flags);
#else #else
@@ -466,41 +484,44 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server)
if (flags == -1) if (flags == -1)
{ {
close(s); closesocket(s);
return -1; return -1;
} }
flags |= O_NONBLOCK; flags |= O_NONBLOCK;
if (fcntl(s, F_SETFL, flags) == -1) if (fcntl(s, F_SETFL, flags) == -1)
{ {
close(s); closesocket(s);
return -1; return -1;
} }
#endif #endif
/* Connect to the server. */ /* Connect to the server. */
memset(&sockin, 0, sizeof(sockin)); memset(&sockin, 0, sizeof(sockin));
sockin.sin_family = AF_INET; sockin.sin_family = AF_INET;
sockin.sin_addr = server->addr; sockin.sin_addr = server->addr;
sockin.sin_port = channel->tcp_port; sockin.sin_port = channel->tcp_port;
if (connect(s, (struct sockaddr *) &sockin, sizeof(sockin)) == -1 if (connect(s, (struct sockaddr *) &sockin, sizeof(sockin)) == -1) {
&& errno != EINPROGRESS) int err = GET_ERRNO();
{
if (err != EINPROGRESS && err != EWOULDBLOCK) {
closesocket(s); closesocket(s);
return -1; return -1;
} }
}
server->tcp_buffer_pos = 0;
server->tcp_socket = s; server->tcp_socket = s;
return 0; return 0;
} }
static int open_udp_socket(ares_channel channel, struct server_state *server) static int open_udp_socket(ares_channel channel, struct server_state *server)
{ {
int s; ares_socket_t s;
struct sockaddr_in sockin; struct sockaddr_in sockin;
/* Acquire a socket. */ /* Acquire a socket. */
s = socket(AF_INET, SOCK_DGRAM, 0); s = socket(AF_INET, SOCK_DGRAM, 0);
if (s == -1) if (s == ARES_SOCKET_BAD)
return -1; return -1;
/* Connect to the server. */ /* Connect to the server. */
@@ -519,7 +540,7 @@ static int open_udp_socket(ares_channel channel, struct server_state *server)
} }
static int same_questions(const unsigned char *qbuf, int qlen, static int same_questions(const unsigned char *qbuf, int qlen,
const unsigned char *abuf, int alen) const unsigned char *abuf, int alen)
{ {
struct { struct {
const unsigned char *p; const unsigned char *p;
@@ -546,14 +567,14 @@ static int same_questions(const unsigned char *qbuf, int qlen,
{ {
/* Decode the question in the query. */ /* Decode the question in the query. */
if (ares_expand_name(q.p, qbuf, qlen, &q.name, &q.namelen) if (ares_expand_name(q.p, qbuf, qlen, &q.name, &q.namelen)
!= ARES_SUCCESS) != ARES_SUCCESS)
return 0; return 0;
q.p += q.namelen; q.p += q.namelen;
if (q.p + QFIXEDSZ > qbuf + qlen) if (q.p + QFIXEDSZ > qbuf + qlen)
{ {
free(q.name); free(q.name);
return 0; return 0;
} }
q.type = DNS_QUESTION_TYPE(q.p); q.type = DNS_QUESTION_TYPE(q.p);
q.dnsclass = DNS_QUESTION_CLASS(q.p); q.dnsclass = DNS_QUESTION_CLASS(q.p);
q.p += QFIXEDSZ; q.p += QFIXEDSZ;
@@ -561,55 +582,59 @@ static int same_questions(const unsigned char *qbuf, int qlen,
/* Search for this question in the answer. */ /* Search for this question in the answer. */
a.p = abuf + HFIXEDSZ; a.p = abuf + HFIXEDSZ;
for (j = 0; j < a.qdcount; j++) for (j = 0; j < a.qdcount; j++)
{ {
/* Decode the question in the answer. */ /* Decode the question in the answer. */
if (ares_expand_name(a.p, abuf, alen, &a.name, &a.namelen) if (ares_expand_name(a.p, abuf, alen, &a.name, &a.namelen)
!= ARES_SUCCESS) != ARES_SUCCESS)
{ {
free(q.name); free(q.name);
return 0; return 0;
} }
a.p += a.namelen; a.p += a.namelen;
if (a.p + QFIXEDSZ > abuf + alen) if (a.p + QFIXEDSZ > abuf + alen)
{ {
free(q.name); free(q.name);
free(a.name); free(a.name);
return 0; return 0;
} }
a.type = DNS_QUESTION_TYPE(a.p); a.type = DNS_QUESTION_TYPE(a.p);
a.dnsclass = DNS_QUESTION_CLASS(a.p); a.dnsclass = DNS_QUESTION_CLASS(a.p);
a.p += QFIXEDSZ; a.p += QFIXEDSZ;
/* Compare the decoded questions. */ /* Compare the decoded questions. */
if (strcasecmp(q.name, a.name) == 0 && q.type == a.type if (strcasecmp(q.name, a.name) == 0 && q.type == a.type
&& q.dnsclass == a.dnsclass) && q.dnsclass == a.dnsclass)
{ {
free(a.name); free(a.name);
break; break;
} }
free(a.name); free(a.name);
} }
free(q.name); free(q.name);
if (j == a.qdcount) if (j == a.qdcount)
return 0; return 0;
} }
return 1; return 1;
} }
static void end_query(ares_channel channel, struct query *query, int status, static struct query *end_query (ares_channel channel, struct query *query, int status,
unsigned char *abuf, int alen) unsigned char *abuf, int alen)
{ {
struct query **q; struct query **q, *next;
int i; int i;
query->callback(query->arg, status, abuf, alen); query->callback(query->arg, status, abuf, alen);
for (q = &channel->queries; *q; q = &(*q)->next) for (q = &channel->queries; *q; q = &(*q)->next)
{ {
if (*q == query) if (*q == query)
break; break;
} }
*q = query->next; *q = query->next;
if (*q)
next = (*q)->next;
else
next = NULL;
free(query->tcpbuf); free(query->tcpbuf);
free(query->skip_server); free(query->skip_server);
free(query); free(query);
@@ -620,6 +645,7 @@ static void end_query(ares_channel channel, struct query *query, int status,
if (!channel->queries && !(channel->flags & ARES_FLAG_STAYOPEN)) if (!channel->queries && !(channel->flags & ARES_FLAG_STAYOPEN))
{ {
for (i = 0; i < channel->nservers; i++) for (i = 0; i < channel->nservers; i++)
ares__close_sockets(&channel->servers[i]); ares__close_sockets(&channel->servers[i]);
} }
return (next);
} }

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <netinet/in.h> #include <netinet/in.h>
@@ -35,7 +36,7 @@ struct qquery {
static void qcallback(void *arg, int status, unsigned char *abuf, int alen); static void qcallback(void *arg, int status, unsigned char *abuf, int alen);
void ares_query(ares_channel channel, const char *name, int dnsclass, void ares_query(ares_channel channel, const char *name, int dnsclass,
int type, ares_callback callback, void *arg) int type, ares_callback callback, void *arg)
{ {
struct qquery *qquery; struct qquery *qquery;
unsigned char *qbuf; unsigned char *qbuf;
@@ -44,7 +45,7 @@ void ares_query(ares_channel channel, const char *name, int dnsclass,
/* Compose the query. */ /* Compose the query. */
rd = !(channel->flags & ARES_FLAG_NORECURSE); rd = !(channel->flags & ARES_FLAG_NORECURSE);
status = ares_mkquery(name, dnsclass, type, channel->next_id, rd, &qbuf, status = ares_mkquery(name, dnsclass, type, channel->next_id, rd, &qbuf,
&qlen); &qlen);
channel->next_id++; channel->next_id++;
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
{ {
@@ -84,26 +85,26 @@ static void qcallback(void *arg, int status, unsigned char *abuf, int alen)
/* Convert errors. */ /* Convert errors. */
switch (rcode) switch (rcode)
{ {
case NOERROR: case NOERROR:
status = (ancount > 0) ? ARES_SUCCESS : ARES_ENODATA; status = (ancount > 0) ? ARES_SUCCESS : ARES_ENODATA;
break; break;
case FORMERR: case FORMERR:
status = ARES_EFORMERR; status = ARES_EFORMERR;
break; break;
case SERVFAIL: case SERVFAIL:
status = ARES_ESERVFAIL; status = ARES_ESERVFAIL;
break; break;
case NXDOMAIN: case NXDOMAIN:
status = ARES_ENOTFOUND; status = ARES_ENOTFOUND;
break; break;
case NOTIMP: case NOTIMP:
status = ARES_ENOTIMP; status = ARES_ENOTIMP;
break; break;
case REFUSED: case REFUSED:
status = ARES_EREFUSED; status = ARES_EREFUSED;
break; break;
} }
qquery->callback(qquery->arg, status, abuf, alen); qquery->callback(qquery->arg, status, abuf, alen);
} }
free(qquery); free(qquery);

View File

@@ -13,12 +13,13 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <ctype.h> #include <ctype.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#endif #endif
@@ -28,26 +29,26 @@
struct search_query { struct search_query {
/* Arguments passed to ares_search */ /* Arguments passed to ares_search */
ares_channel channel; ares_channel channel;
char *name; /* copied into an allocated buffer */ char *name; /* copied into an allocated buffer */
int dnsclass; int dnsclass;
int type; int type;
ares_callback callback; ares_callback callback;
void *arg; void *arg;
int status_as_is; /* error status from trying as-is */ int status_as_is; /* error status from trying as-is */
int next_domain; /* next search domain to try */ int next_domain; /* next search domain to try */
int trying_as_is; /* current query is for name as-is */ int trying_as_is; /* current query is for name as-is */
}; };
static void search_callback(void *arg, int status, unsigned char *abuf, static void search_callback(void *arg, int status, unsigned char *abuf,
int alen); int alen);
static void end_squery(struct search_query *squery, int status, static void end_squery(struct search_query *squery, int status,
unsigned char *abuf, int alen); unsigned char *abuf, int alen);
static int cat_domain(const char *name, const char *domain, char **s); static int cat_domain(const char *name, const char *domain, char **s);
static int single_domain(ares_channel channel, const char *name, char **s); static int single_domain(ares_channel channel, const char *name, char **s);
void ares_search(ares_channel channel, const char *name, int dnsclass, void ares_search(ares_channel channel, const char *name, int dnsclass,
int type, ares_callback callback, void *arg) int type, ares_callback callback, void *arg)
{ {
struct search_query *squery; struct search_query *squery;
char *s; char *s;
@@ -98,7 +99,7 @@ void ares_search(ares_channel channel, const char *name, int dnsclass,
for (p = name; *p; p++) for (p = name; *p; p++)
{ {
if (*p == '.') if (*p == '.')
ndots++; ndots++;
} }
/* If ndots is at least the channel ndots threshold (usually 1), /* If ndots is at least the channel ndots threshold (usually 1),
@@ -119,22 +120,22 @@ void ares_search(ares_channel channel, const char *name, int dnsclass,
squery->trying_as_is = 0; squery->trying_as_is = 0;
status = cat_domain(name, channel->domains[0], &s); status = cat_domain(name, channel->domains[0], &s);
if (status == ARES_SUCCESS) if (status == ARES_SUCCESS)
{ {
ares_query(channel, s, dnsclass, type, search_callback, squery); ares_query(channel, s, dnsclass, type, search_callback, squery);
free(s); free(s);
} }
else else
{ {
/* failed, free the malloc()ed memory */ /* failed, free the malloc()ed memory */
free(squery->name); free(squery->name);
free(squery); free(squery);
callback(arg, status, NULL, 0); callback(arg, status, NULL, 0);
} }
} }
} }
static void search_callback(void *arg, int status, unsigned char *abuf, static void search_callback(void *arg, int status, unsigned char *abuf,
int alen) int alen)
{ {
struct search_query *squery = (struct search_query *) arg; struct search_query *squery = (struct search_query *) arg;
ares_channel channel = squery->channel; ares_channel channel = squery->channel;
@@ -148,37 +149,37 @@ static void search_callback(void *arg, int status, unsigned char *abuf,
{ {
/* Save the status if we were trying as-is. */ /* Save the status if we were trying as-is. */
if (squery->trying_as_is) if (squery->trying_as_is)
squery->status_as_is = status; squery->status_as_is = status;
if (squery->next_domain < channel->ndomains) if (squery->next_domain < channel->ndomains)
{ {
/* Try the next domain. */ /* Try the next domain. */
status = cat_domain(squery->name, status = cat_domain(squery->name,
channel->domains[squery->next_domain], &s); channel->domains[squery->next_domain], &s);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
end_squery(squery, status, NULL, 0); end_squery(squery, status, NULL, 0);
else else
{ {
squery->trying_as_is = 0; squery->trying_as_is = 0;
squery->next_domain++; squery->next_domain++;
ares_query(channel, s, squery->dnsclass, squery->type, ares_query(channel, s, squery->dnsclass, squery->type,
search_callback, squery); search_callback, squery);
free(s); free(s);
} }
} }
else if (squery->status_as_is == -1) else if (squery->status_as_is == -1)
{ {
/* Try the name as-is at the end. */ /* Try the name as-is at the end. */
squery->trying_as_is = 1; squery->trying_as_is = 1;
ares_query(channel, squery->name, squery->dnsclass, squery->type, ares_query(channel, squery->name, squery->dnsclass, squery->type,
search_callback, squery); search_callback, squery);
} }
else else
end_squery(squery, squery->status_as_is, NULL, 0); end_squery(squery, squery->status_as_is, NULL, 0);
} }
} }
static void end_squery(struct search_query *squery, int status, static void end_squery(struct search_query *squery, int status,
unsigned char *abuf, int alen) unsigned char *abuf, int alen)
{ {
squery->callback(squery->arg, status, abuf, alen); squery->callback(squery->arg, status, abuf, alen);
free(squery->name); free(squery->name);
@@ -228,41 +229,41 @@ static int single_domain(ares_channel channel, const char *name, char **s)
/* The name might be a host alias. */ /* The name might be a host alias. */
hostaliases = getenv("HOSTALIASES"); hostaliases = getenv("HOSTALIASES");
if (hostaliases) if (hostaliases)
{ {
fp = fopen(hostaliases, "r"); fp = fopen(hostaliases, "r");
if (fp) if (fp)
{ {
while ((status = ares__read_line(fp, &line, &linesize)) while ((status = ares__read_line(fp, &line, &linesize))
== ARES_SUCCESS) == ARES_SUCCESS)
{ {
if (strncasecmp(line, name, len) != 0 || if (strncasecmp(line, name, len) != 0 ||
!isspace((unsigned char)line[len])) !isspace((unsigned char)line[len]))
continue; continue;
p = line + len; p = line + len;
while (isspace((unsigned char)*p)) while (isspace((unsigned char)*p))
p++; p++;
if (*p) if (*p)
{ {
q = p + 1; q = p + 1;
while (*q && !isspace((unsigned char)*q)) while (*q && !isspace((unsigned char)*q))
q++; q++;
*s = malloc(q - p + 1); *s = malloc(q - p + 1);
if (*s) if (*s)
{ {
memcpy(*s, p, q - p); memcpy(*s, p, q - p);
(*s)[q - p] = 0; (*s)[q - p] = 0;
} }
free(line); free(line);
fclose(fp); fclose(fp);
return (*s) ? ARES_SUCCESS : ARES_ENOMEM; return (*s) ? ARES_SUCCESS : ARES_ENOMEM;
} }
} }
free(line); free(line);
fclose(fp); fclose(fp);
if (status != ARES_SUCCESS) if (status != ARES_SUCCESS)
return status; return status;
} }
} }
} }
if (channel->flags & ARES_FLAG_NOSEARCH || channel->ndomains == 0) if (channel->flags & ARES_FLAG_NOSEARCH || channel->ndomains == 0)

View File

@@ -13,9 +13,10 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #if defined(WIN32) && !defined(WATT32)
#include "nameser.h" #include "nameser.h"
#else #else
#include <netinet/in.h> #include <netinet/in.h>
@@ -30,7 +31,7 @@
#include "ares_private.h" #include "ares_private.h"
void ares_send(ares_channel channel, const unsigned char *qbuf, int qlen, void ares_send(ares_channel channel, const unsigned char *qbuf, int qlen,
ares_callback callback, void *arg) ares_callback callback, void *arg)
{ {
struct query *query; struct query *query;
int i; int i;

View File

@@ -13,6 +13,7 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <assert.h> #include <assert.h>
#include "ares.h" #include "ares.h"

View File

@@ -13,20 +13,20 @@
* without express or implied warranty. * without express or implied warranty.
*/ */
#include "setup.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef WIN32 #ifdef HAVE_SYS_TIME_H
#else
#include <sys/time.h> #include <sys/time.h>
#endif #endif
#include <time.h> #include <time.h>
#include "ares.h" #include "ares.h"
#include "ares_private.h" #include "ares_private.h"
struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv, struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv,
struct timeval *tvbuf) struct timeval *tvbuf)
{ {
struct query *query; struct query *query;
time_t now; time_t now;
@@ -42,12 +42,12 @@ struct timeval *ares_timeout(ares_channel channel, struct timeval *maxtv,
for (query = channel->queries; query; query = query->next) for (query = channel->queries; query; query = query->next)
{ {
if (query->timeout == 0) if (query->timeout == 0)
continue; continue;
offset = query->timeout - now; offset = query->timeout - now;
if (offset < 0) if (offset < 0)
offset = 0; offset = 0;
if (min_offset == -1 || offset < min_offset) if (min_offset == -1 || offset < min_offset)
min_offset = offset; min_offset = offset;
} }
/* If we found a minimum timeout and it's sooner than the one /* If we found a minimum timeout and it's sooner than the one

View File

@@ -1,5 +1,6 @@
/* $Id$ */ /* $Id$ */
#include "setup.h"
#include "ares_version.h" #include "ares_version.h"
const char *ares_version(int *version) const char *ares_version(int *version)

View File

@@ -1,4 +1,7 @@
#!/bin/sh #!/bin/sh
libtoolize --copy --automake --force
aclocal aclocal
autoheader
autoconf autoconf
automake --add-missing

1388
ares/config.guess vendored

File diff suppressed because it is too large Load Diff

1489
ares/config.sub vendored

File diff suppressed because it is too large Load Diff

View File

@@ -1,17 +1,22 @@
dnl Process this file with autoconf to produce a configure script. dnl Process this file with autoconf to produce a configure script.
AC_INIT(ares_init.c) AC_INIT(ares_init.c)
AM_CONFIG_HEADER(config.h)
AM_MAINTAINER_MODE
AM_INIT_AUTOMAKE(c-ares, CVS)
AC_PROG_CC AC_PROG_CC
AC_PROG_INSTALL AC_PROG_INSTALL
AC_PROG_RANLIB
AC_CANONICAL_HOST
case $host_os in case $host_os in
solaris*) solaris*)
AC_DEFINE(ETC_INET) AC_DEFINE(ETC_INET, 1, [if a /etc/inet dir is being used])
;; ;;
esac esac
# check for ssize_t
AC_CHECK_TYPE(ssize_t, ,
AC_DEFINE(ssize_t, int, [the signed version of size_t]))
AC_SEARCH_LIBS(gethostbyname, nsl) AC_SEARCH_LIBS(gethostbyname, nsl)
AC_SEARCH_LIBS(socket, socket) AC_SEARCH_LIBS(socket, socket)
@@ -30,6 +35,9 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]),
;; ;;
*) AC_MSG_RESULT(yes) *) AC_MSG_RESULT(yes)
dnl when doing the debug stuff, use static library only
AC_DISABLE_SHARED
dnl Checks for standard header files, to make memdebug.h inclusions bettter dnl Checks for standard header files, to make memdebug.h inclusions bettter
AC_HEADER_STDC AC_HEADER_STDC
@@ -45,12 +53,14 @@ AC_HELP_STRING([--disable-debug],[Disable debug options]),
AC_MSG_RESULT(no) AC_MSG_RESULT(no)
) )
AC_PROG_LIBTOOL
dnl check for a few basic system headers we need dnl check for a few basic system headers we need
dnl AC_CHECK_HEADERS( AC_CHECK_HEADERS(
dnl sys/types.h \ sys/types.h \
dnl sys/time.h \ sys/time.h \
dnl sys/select.h \ sys/select.h \
dnl sys/socket.h \ sys/socket.h \
dnl ) )
AC_OUTPUT(Makefile) AC_OUTPUT(Makefile)

View File

@@ -2,8 +2,6 @@
$version = $ARGV[0]; $version = $ARGV[0];
$name="c-ares";
if($version eq "") { if($version eq "") {
print "Enter version number!\n"; print "Enter version number!\n";
exit; exit;
@@ -15,86 +13,25 @@ if(!-f "ares.h") {
} }
if(!-f "configure") { if(!-f "configure") {
`autoconf`; print "running buildconf\n";
`./buildconf`;
} }
print "adding $version in the configure.ac file\n";
`sed -e 's/AM_INIT_AUTOMAKE(c-ares, CVS)/AM_INIT_AUTOMAKE(c-ares, $version)/' < configure.ac > configure.ac-rel`;
@files=`find . -name FILES`; # now make a new configure script with this
print "makes a new configure script\n";
`autoconf configure.ac-rel >configure`;
my @entries; # now run this new configure to get a fine makefile
print "running configure\n";
`./configure`;
sub dirpart { # now make the actual tarball
my ($file)=@_; print "running make dist\n";
my @p=split("/", $file); `make dist`;
$p[$#p]=""; # blank the last one
my $dir=join("/", @p);
$dir =~ s/^\.\///; # cut off ./ beginnings print "removing temporary configure.ac file\n";
`rm configure.ac-rel`;
$dir =~ s/\/$//; # off / trailers
if(!$dir) {
$dir = ".";
}
return $dir;
}
sub add {
my ($file)=@_;
my $dir=dirpart($file);
open(FILE, "<$file");
while(<FILE>) {
if($_ =~ /^ *\#/) {
next;
}
chomp;
push @entries, "$dir/$_";
}
close(FILE);
}
for(@files) {
chomp;
add($_);
}
sub mkalldir {
my ($dir) = @_;
my @parts = split("/", $dir);
#print "IN: $dir\n";
my $sub="";
for(@parts) {
#print "PART: $_\n";
$sub .= "$_";
if($_ eq "") {
next;
}
mkdir($sub, 0777);
#print "make $sub\n";
$sub .= "/";
}
}
for(@entries) {
my $dir = dirpart("$name-$version/$_");
# print "Create $dir\n";
mkalldir($dir);
# print "Copy $_ to $dir\n";
`cp -p $_ $dir`;
}
# make a tarball
`tar -cf $name-$version.tar $name-$version`;
# gzip the tarball
`gzip -9 $name-$version.tar`;
# remove the dir
`rm -rf $name-$version`;
print "NOTE: now cvs tag this release!\n"; print "NOTE: now cvs tag this release!\n";

View File

@@ -4,13 +4,18 @@
/* Windows-only header file provided by liren@vivisimo.com to make his Windows /* Windows-only header file provided by liren@vivisimo.com to make his Windows
port build */ port build */
#ifndef NETWARE
#include <windows.h> #include <windows.h>
#include <process.h> /* for the _getpid() proto */ #include <process.h> /* for the _getpid() proto */
#endif /* !NETWARE */
#include <sys/types.h> #include <sys/types.h>
#ifndef NETWARE
#define MAXHOSTNAMELEN 256 #define MAXHOSTNAMELEN 256
#define EINPROGRESS WSAEINPROGRESS #define EINPROGRESS WSAEINPROGRESS
#define EWOULDBLOCK WSAEWOULDBLOCK
/* Structure for scatter/gather I/O. */ /* Structure for scatter/gather I/O. */
struct iovec struct iovec
@@ -21,11 +26,16 @@ struct iovec
#define getpid() _getpid() #define getpid() _getpid()
int ares_writev (SOCKET s, const struct iovec *vector, size_t count);
#define writev(s,vect,count) ares_writev(s,vect,count)
struct timezone { int dummy; }; struct timezone { int dummy; };
int ares_gettimeofday(struct timeval *tv, struct timezone *tz); int ares_gettimeofday(struct timeval *tv, struct timezone *tz);
#define gettimeofday(tv,tz) ares_gettimeofday(tv,tz) #define gettimeofday(tv,tz) ares_gettimeofday(tv,tz)
#endif /* !NETWARE */
#define NS_CMPRSFLGS 0xc0 #define NS_CMPRSFLGS 0xc0
@@ -211,16 +221,4 @@ typedef enum __ns_rcode {
#define T_MAILA ns_t_maila #define T_MAILA ns_t_maila
#define T_ANY ns_t_any #define T_ANY ns_t_any
#ifndef __MINGW32__
/* protos for the functions we provide in windows_port.c */
int ares_strncasecmp(const char *s1, const char *s2, size_t n);
int ares_strcasecmp(const char *s1, const char *s2);
/* use this define magic to prevent us from adding symbol names to the library
that is a high-risk to collide with another libraries' attempts to do the
same */
#define strncasecmp(a,b,c) ares_strncasecmp(a,b,c)
#define strcasecmp(a,b) ares_strcasecmp(a,b)
#endif
#endif /* ARES_NAMESER_H */ #endif /* ARES_NAMESER_H */

72
ares/setup.h Normal file
View File

@@ -0,0 +1,72 @@
#ifndef ARES_SETUP_H
#define ARES_SETUP_H
/* Copyright (C) 2004 by Daniel Stenberg et al
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose and without fee is hereby granted, provided
* that the above copyright notice appear in all copies and that both that
* copyright notice and this permission notice appear in supporting
* documentation, and that the name of M.I.T. not be used in advertising or
* publicity pertaining to distribution of the software without specific,
* written prior permission. M.I.T. makes no representations about the
* suitability of this software for any purpose. It is provided "as is"
* without express or implied warranty.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#else
/* simple work-around for now, for systems without configure support */
#define ssize_t int
#endif
/* Recent autoconf versions define these symbols in config.h. We don't want
them (since they collide with the libcurl ones when we build
--enable-debug) so we undef them again here. */
#undef PACKAGE_STRING
#undef PACKAGE_TARNAME
#undef PACKAGE_VERSION
#undef PACKAGE_BUGREPORT
#undef PACKAGE_NAME
#undef VERSION
#undef PACKAGE
/* now typedef our socket type */
#if defined(WIN32) && !defined(WATT32)
#include <winsock.h>
typedef SOCKET ares_socket_t;
#define ARES_SOCKET_BAD INVALID_SOCKET
#else
typedef int ares_socket_t;
#define ARES_SOCKET_BAD -1
#endif
/* Assume a few thing unless they're set by configure
*/
#if !defined(HAVE_SYS_TIME_H) && !defined(_MSC_VER)
#define HAVE_SYS_TIME_H
#endif
#if !defined(HAVE_UNISTD_H) && !defined(_MSC_VER)
#define HAVE_UNISTD_H
#endif
#if !defined(HAVE_SYS_UIO_H) && !defined(WIN32) && !defined(MSDOS)
#define HAVE_SYS_UIO_H
#endif
#if (defined(WIN32) || defined(WATT32)) && \
!(defined(__MINGW32__) || defined(NETWARE))
/* protos for the functions we provide in windows_port.c */
int ares_strncasecmp(const char *s1, const char *s2, int n);
int ares_strcasecmp(const char *s1, const char *s2);
/* use this define magic to prevent us from adding symbol names to the library
that is a high-risk to collide with another libraries' attempts to do the
same */
#define strncasecmp(a,b,c) ares_strncasecmp(a,b,c)
#define strcasecmp(a,b) ares_strcasecmp(a,b)
#endif
#endif /* ARES_SETUP_H */

View File

@@ -7,19 +7,19 @@
CFG=areslib - Win32 Debug CFG=areslib - Win32 Debug
!MESSAGE This is not a valid makefile. To build this project using NMAKE, !MESSAGE This is not a valid makefile. To build this project using NMAKE,
!MESSAGE use the Export Makefile command and run !MESSAGE use the Export Makefile command and run
!MESSAGE !MESSAGE
!MESSAGE NMAKE /f "areslib.mak". !MESSAGE NMAKE /f "areslib.mak".
!MESSAGE !MESSAGE
!MESSAGE You can specify a configuration when running NMAKE !MESSAGE You can specify a configuration when running NMAKE
!MESSAGE by defining the macro CFG on the command line. For example: !MESSAGE by defining the macro CFG on the command line. For example:
!MESSAGE !MESSAGE
!MESSAGE NMAKE /f "areslib.mak" CFG="areslib - Win32 Debug" !MESSAGE NMAKE /f "areslib.mak" CFG="areslib - Win32 Debug"
!MESSAGE !MESSAGE
!MESSAGE Possible choices for configuration are: !MESSAGE Possible choices for configuration are:
!MESSAGE !MESSAGE
!MESSAGE "areslib - Win32 Release" (based on "Win32 (x86) Static Library") !MESSAGE "areslib - Win32 Release" (based on "Win32 (x86) Static Library")
!MESSAGE "areslib - Win32 Debug" (based on "Win32 (x86) Static Library") !MESSAGE "areslib - Win32 Debug" (based on "Win32 (x86) Static Library")
!MESSAGE !MESSAGE
# Begin Project # Begin Project
# PROP AllowPerConfigDependencies 0 # PROP AllowPerConfigDependencies 0
@@ -74,7 +74,7 @@ LIB32=link.exe -lib
# ADD BASE LIB32 /nologo # ADD BASE LIB32 /nologo
# ADD LIB32 /nologo # ADD LIB32 /nologo
!ENDIF !ENDIF
# Begin Target # Begin Target
@@ -109,10 +109,6 @@ SOURCE=..\..\ares_fds.c
# End Source File # End Source File
# Begin Source File # Begin Source File
SOURCE=..\..\ares_free_errmem.c
# End Source File
# Begin Source File
SOURCE=..\..\ares_free_hostent.c SOURCE=..\..\ares_free_hostent.c
# End Source File # End Source File
# Begin Source File # Begin Source File

View File

@@ -1,361 +1,351 @@
# Microsoft Developer Studio Generated NMAKE File, Based on areslib.dsp # Microsoft Developer Studio Generated NMAKE File, Based on areslib.dsp
!IF "$(CFG)" == "" !IF "$(CFG)" == ""
CFG=areslib - Win32 Debug CFG=areslib - Win32 Debug
!MESSAGE No configuration specified. Defaulting to areslib - Win32 Debug. !MESSAGE No configuration specified. Defaulting to areslib - Win32 Debug.
!ENDIF !ENDIF
!IF "$(CFG)" != "areslib - Win32 Release" && "$(CFG)" != "areslib - Win32 Debug" !IF "$(CFG)" != "areslib - Win32 Release" && "$(CFG)" != "areslib - Win32 Debug"
!MESSAGE Invalid configuration "$(CFG)" specified. !MESSAGE Invalid configuration "$(CFG)" specified.
!MESSAGE You can specify a configuration when running NMAKE !MESSAGE You can specify a configuration when running NMAKE
!MESSAGE by defining the macro CFG on the command line. For example: !MESSAGE by defining the macro CFG on the command line. For example:
!MESSAGE !MESSAGE
!MESSAGE NMAKE /f "areslib.mak" CFG="areslib - Win32 Debug" !MESSAGE NMAKE /f "areslib.mak" CFG="areslib - Win32 Debug"
!MESSAGE !MESSAGE
!MESSAGE Possible choices for configuration are: !MESSAGE Possible choices for configuration are:
!MESSAGE !MESSAGE
!MESSAGE "areslib - Win32 Release" (based on "Win32 (x86) Static Library") !MESSAGE "areslib - Win32 Release" (based on "Win32 (x86) Static Library")
!MESSAGE "areslib - Win32 Debug" (based on "Win32 (x86) Static Library") !MESSAGE "areslib - Win32 Debug" (based on "Win32 (x86) Static Library")
!MESSAGE !MESSAGE
!ERROR An invalid configuration is specified. !ERROR An invalid configuration is specified.
!ENDIF !ENDIF
!IF "$(OS)" == "Windows_NT" !IF "$(OS)" == "Windows_NT"
NULL= NULL=
!ELSE !ELSE
NULL=nul NULL=nul
!ENDIF !ENDIF
CPP=cl.exe CPP=cl.exe
RSC=rc.exe RSC=rc.exe
!IF "$(CFG)" == "areslib - Win32 Release" !IF "$(CFG)" == "areslib - Win32 Release"
OUTDIR=.\Release OUTDIR=.\Release
INTDIR=.\Release INTDIR=.\Release
# Begin Custom Macros # Begin Custom Macros
OutDir=.\Release OutDir=.\Release
# End Custom Macros # End Custom Macros
ALL : "$(OUTDIR)\areslib.lib" ALL : "$(OUTDIR)\areslib.lib"
CLEAN : CLEAN :
-@erase "$(INTDIR)\ares__close_sockets.obj" -@erase "$(INTDIR)\ares__close_sockets.obj"
-@erase "$(INTDIR)\ares__get_hostent.obj" -@erase "$(INTDIR)\ares__get_hostent.obj"
-@erase "$(INTDIR)\ares__read_line.obj" -@erase "$(INTDIR)\ares__read_line.obj"
-@erase "$(INTDIR)\ares_destroy.obj" -@erase "$(INTDIR)\ares_destroy.obj"
-@erase "$(INTDIR)\ares_expand_name.obj" -@erase "$(INTDIR)\ares_expand_name.obj"
-@erase "$(INTDIR)\ares_fds.obj" -@erase "$(INTDIR)\ares_fds.obj"
-@erase "$(INTDIR)\ares_free_errmem.obj" -@erase "$(INTDIR)\ares_free_hostent.obj"
-@erase "$(INTDIR)\ares_free_hostent.obj" -@erase "$(INTDIR)\ares_free_string.obj"
-@erase "$(INTDIR)\ares_free_string.obj" -@erase "$(INTDIR)\ares_gethostbyaddr.obj"
-@erase "$(INTDIR)\ares_gethostbyaddr.obj" -@erase "$(INTDIR)\ares_gethostbyname.obj"
-@erase "$(INTDIR)\ares_gethostbyname.obj" -@erase "$(INTDIR)\ares_init.obj"
-@erase "$(INTDIR)\ares_init.obj" -@erase "$(INTDIR)\ares_mkquery.obj"
-@erase "$(INTDIR)\ares_mkquery.obj" -@erase "$(INTDIR)\ares_parse_a_reply.obj"
-@erase "$(INTDIR)\ares_parse_a_reply.obj" -@erase "$(INTDIR)\ares_parse_ptr_reply.obj"
-@erase "$(INTDIR)\ares_parse_ptr_reply.obj" -@erase "$(INTDIR)\ares_process.obj"
-@erase "$(INTDIR)\ares_process.obj" -@erase "$(INTDIR)\ares_query.obj"
-@erase "$(INTDIR)\ares_query.obj" -@erase "$(INTDIR)\ares_search.obj"
-@erase "$(INTDIR)\ares_search.obj" -@erase "$(INTDIR)\ares_send.obj"
-@erase "$(INTDIR)\ares_send.obj" -@erase "$(INTDIR)\ares_strerror.obj"
-@erase "$(INTDIR)\ares_strerror.obj" -@erase "$(INTDIR)\ares_timeout.obj"
-@erase "$(INTDIR)\ares_timeout.obj" -@erase "$(INTDIR)\vc60.idb"
-@erase "$(INTDIR)\vc60.idb" -@erase "$(INTDIR)\windows_port.obj"
-@erase "$(INTDIR)\windows_port.obj" -@erase "$(OUTDIR)\areslib.lib"
-@erase "$(OUTDIR)\areslib.lib"
"$(OUTDIR)" :
"$(OUTDIR)" : if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"
if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"
CPP_PROJ=/nologo /MD /W3 /GX /O2 /I "..\.." /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /Fp"$(INTDIR)\areslib.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /c
CPP_PROJ=/nologo /MD /W3 /GX /O2 /I "..\.." /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /Fp"$(INTDIR)\areslib.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /c BSC32=bscmake.exe
BSC32=bscmake.exe BSC32_FLAGS=/nologo /o"$(OUTDIR)\areslib.bsc"
BSC32_FLAGS=/nologo /o"$(OUTDIR)\areslib.bsc" BSC32_SBRS= \
BSC32_SBRS= \
LIB32=link.exe -lib
LIB32=link.exe -lib LIB32_FLAGS=/nologo /out:"$(OUTDIR)\areslib.lib"
LIB32_FLAGS=/nologo /out:"$(OUTDIR)\areslib.lib" LIB32_OBJS= \
LIB32_OBJS= \ "$(INTDIR)\ares__close_sockets.obj" \
"$(INTDIR)\ares__close_sockets.obj" \ "$(INTDIR)\ares__get_hostent.obj" \
"$(INTDIR)\ares__get_hostent.obj" \ "$(INTDIR)\ares__read_line.obj" \
"$(INTDIR)\ares__read_line.obj" \ "$(INTDIR)\ares_destroy.obj" \
"$(INTDIR)\ares_destroy.obj" \ "$(INTDIR)\ares_expand_name.obj" \
"$(INTDIR)\ares_expand_name.obj" \ "$(INTDIR)\ares_fds.obj" \
"$(INTDIR)\ares_fds.obj" \ "$(INTDIR)\ares_free_hostent.obj" \
"$(INTDIR)\ares_free_errmem.obj" \ "$(INTDIR)\ares_free_string.obj" \
"$(INTDIR)\ares_free_hostent.obj" \ "$(INTDIR)\ares_gethostbyaddr.obj" \
"$(INTDIR)\ares_free_string.obj" \ "$(INTDIR)\ares_gethostbyname.obj" \
"$(INTDIR)\ares_gethostbyaddr.obj" \ "$(INTDIR)\ares_init.obj" \
"$(INTDIR)\ares_gethostbyname.obj" \ "$(INTDIR)\ares_mkquery.obj" \
"$(INTDIR)\ares_init.obj" \ "$(INTDIR)\ares_parse_a_reply.obj" \
"$(INTDIR)\ares_mkquery.obj" \ "$(INTDIR)\ares_parse_ptr_reply.obj" \
"$(INTDIR)\ares_parse_a_reply.obj" \ "$(INTDIR)\ares_process.obj" \
"$(INTDIR)\ares_parse_ptr_reply.obj" \ "$(INTDIR)\ares_query.obj" \
"$(INTDIR)\ares_process.obj" \ "$(INTDIR)\ares_search.obj" \
"$(INTDIR)\ares_query.obj" \ "$(INTDIR)\ares_send.obj" \
"$(INTDIR)\ares_search.obj" \ "$(INTDIR)\ares_strerror.obj" \
"$(INTDIR)\ares_send.obj" \ "$(INTDIR)\ares_timeout.obj" \
"$(INTDIR)\ares_strerror.obj" \ "$(INTDIR)\windows_port.obj"
"$(INTDIR)\ares_timeout.obj" \
"$(INTDIR)\windows_port.obj" "$(OUTDIR)\areslib.lib" : "$(OUTDIR)" $(DEF_FILE) $(LIB32_OBJS)
$(LIB32) @<<
"$(OUTDIR)\areslib.lib" : "$(OUTDIR)" $(DEF_FILE) $(LIB32_OBJS) $(LIB32_FLAGS) $(DEF_FLAGS) $(LIB32_OBJS)
$(LIB32) @<< <<
$(LIB32_FLAGS) $(DEF_FLAGS) $(LIB32_OBJS)
<< !ELSEIF "$(CFG)" == "areslib - Win32 Debug"
!ELSEIF "$(CFG)" == "areslib - Win32 Debug" OUTDIR=.\Debug
INTDIR=.\Debug
OUTDIR=.\Debug # Begin Custom Macros
INTDIR=.\Debug OutDir=.\Debug
# Begin Custom Macros # End Custom Macros
OutDir=.\Debug
# End Custom Macros ALL : "$(OUTDIR)\areslib.lib"
ALL : "$(OUTDIR)\areslib.lib"
CLEAN :
-@erase "$(INTDIR)\ares__close_sockets.obj"
CLEAN : -@erase "$(INTDIR)\ares__get_hostent.obj"
-@erase "$(INTDIR)\ares__close_sockets.obj" -@erase "$(INTDIR)\ares__read_line.obj"
-@erase "$(INTDIR)\ares__get_hostent.obj" -@erase "$(INTDIR)\ares_destroy.obj"
-@erase "$(INTDIR)\ares__read_line.obj" -@erase "$(INTDIR)\ares_expand_name.obj"
-@erase "$(INTDIR)\ares_destroy.obj" -@erase "$(INTDIR)\ares_fds.obj"
-@erase "$(INTDIR)\ares_expand_name.obj" -@erase "$(INTDIR)\ares_free_hostent.obj"
-@erase "$(INTDIR)\ares_fds.obj" -@erase "$(INTDIR)\ares_free_string.obj"
-@erase "$(INTDIR)\ares_free_errmem.obj" -@erase "$(INTDIR)\ares_gethostbyaddr.obj"
-@erase "$(INTDIR)\ares_free_hostent.obj" -@erase "$(INTDIR)\ares_gethostbyname.obj"
-@erase "$(INTDIR)\ares_free_string.obj" -@erase "$(INTDIR)\ares_init.obj"
-@erase "$(INTDIR)\ares_gethostbyaddr.obj" -@erase "$(INTDIR)\ares_mkquery.obj"
-@erase "$(INTDIR)\ares_gethostbyname.obj" -@erase "$(INTDIR)\ares_parse_a_reply.obj"
-@erase "$(INTDIR)\ares_init.obj" -@erase "$(INTDIR)\ares_parse_ptr_reply.obj"
-@erase "$(INTDIR)\ares_mkquery.obj" -@erase "$(INTDIR)\ares_process.obj"
-@erase "$(INTDIR)\ares_parse_a_reply.obj" -@erase "$(INTDIR)\ares_query.obj"
-@erase "$(INTDIR)\ares_parse_ptr_reply.obj" -@erase "$(INTDIR)\ares_search.obj"
-@erase "$(INTDIR)\ares_process.obj" -@erase "$(INTDIR)\ares_send.obj"
-@erase "$(INTDIR)\ares_query.obj" -@erase "$(INTDIR)\ares_strerror.obj"
-@erase "$(INTDIR)\ares_search.obj" -@erase "$(INTDIR)\ares_timeout.obj"
-@erase "$(INTDIR)\ares_send.obj" -@erase "$(INTDIR)\vc60.idb"
-@erase "$(INTDIR)\ares_strerror.obj" -@erase "$(INTDIR)\vc60.pdb"
-@erase "$(INTDIR)\ares_timeout.obj" -@erase "$(INTDIR)\windows_port.obj"
-@erase "$(INTDIR)\vc60.idb" -@erase "$(OUTDIR)\areslib.lib"
-@erase "$(INTDIR)\vc60.pdb"
-@erase "$(INTDIR)\windows_port.obj" "$(OUTDIR)" :
-@erase "$(OUTDIR)\areslib.lib" if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)"
"$(OUTDIR)" : CPP_PROJ=/nologo /MLd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /Fp"$(INTDIR)\areslib.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /GZ /c
if not exist "$(OUTDIR)/$(NULL)" mkdir "$(OUTDIR)" BSC32=bscmake.exe
BSC32_FLAGS=/nologo /o"$(OUTDIR)\areslib.bsc"
CPP_PROJ=/nologo /MLd /W3 /Gm /GX /ZI /Od /I "..\.." /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /Fp"$(INTDIR)\areslib.pch" /YX /Fo"$(INTDIR)\\" /Fd"$(INTDIR)\\" /FD /GZ /c BSC32_SBRS= \
BSC32=bscmake.exe
BSC32_FLAGS=/nologo /o"$(OUTDIR)\areslib.bsc" LIB32=link.exe -lib
BSC32_SBRS= \ LIB32_FLAGS=/nologo /out:"$(OUTDIR)\areslib.lib"
LIB32_OBJS= \
LIB32=link.exe -lib "$(INTDIR)\ares__close_sockets.obj" \
LIB32_FLAGS=/nologo /out:"$(OUTDIR)\areslib.lib" "$(INTDIR)\ares__get_hostent.obj" \
LIB32_OBJS= \ "$(INTDIR)\ares__read_line.obj" \
"$(INTDIR)\ares__close_sockets.obj" \ "$(INTDIR)\ares_destroy.obj" \
"$(INTDIR)\ares__get_hostent.obj" \ "$(INTDIR)\ares_expand_name.obj" \
"$(INTDIR)\ares__read_line.obj" \ "$(INTDIR)\ares_fds.obj" \
"$(INTDIR)\ares_destroy.obj" \ "$(INTDIR)\ares_free_hostent.obj" \
"$(INTDIR)\ares_expand_name.obj" \ "$(INTDIR)\ares_free_string.obj" \
"$(INTDIR)\ares_fds.obj" \ "$(INTDIR)\ares_gethostbyaddr.obj" \
"$(INTDIR)\ares_free_errmem.obj" \ "$(INTDIR)\ares_gethostbyname.obj" \
"$(INTDIR)\ares_free_hostent.obj" \ "$(INTDIR)\ares_init.obj" \
"$(INTDIR)\ares_free_string.obj" \ "$(INTDIR)\ares_mkquery.obj" \
"$(INTDIR)\ares_gethostbyaddr.obj" \ "$(INTDIR)\ares_parse_a_reply.obj" \
"$(INTDIR)\ares_gethostbyname.obj" \ "$(INTDIR)\ares_parse_ptr_reply.obj" \
"$(INTDIR)\ares_init.obj" \ "$(INTDIR)\ares_process.obj" \
"$(INTDIR)\ares_mkquery.obj" \ "$(INTDIR)\ares_query.obj" \
"$(INTDIR)\ares_parse_a_reply.obj" \ "$(INTDIR)\ares_search.obj" \
"$(INTDIR)\ares_parse_ptr_reply.obj" \ "$(INTDIR)\ares_send.obj" \
"$(INTDIR)\ares_process.obj" \ "$(INTDIR)\ares_strerror.obj" \
"$(INTDIR)\ares_query.obj" \ "$(INTDIR)\ares_timeout.obj" \
"$(INTDIR)\ares_search.obj" \ "$(INTDIR)\windows_port.obj"
"$(INTDIR)\ares_send.obj" \
"$(INTDIR)\ares_strerror.obj" \ "$(OUTDIR)\areslib.lib" : "$(OUTDIR)" $(DEF_FILE) $(LIB32_OBJS)
"$(INTDIR)\ares_timeout.obj" \ $(LIB32) @<<
"$(INTDIR)\windows_port.obj" $(LIB32_FLAGS) $(DEF_FLAGS) $(LIB32_OBJS)
<<
"$(OUTDIR)\areslib.lib" : "$(OUTDIR)" $(DEF_FILE) $(LIB32_OBJS)
$(LIB32) @<< !ENDIF
$(LIB32_FLAGS) $(DEF_FLAGS) $(LIB32_OBJS)
<< .c{$(INTDIR)}.obj::
$(CPP) @<<
!ENDIF $(CPP_PROJ) $<
<<
.c{$(INTDIR)}.obj::
$(CPP) @<< .cpp{$(INTDIR)}.obj::
$(CPP_PROJ) $< $(CPP) @<<
<< $(CPP_PROJ) $<
<<
.cpp{$(INTDIR)}.obj::
$(CPP) @<< .cxx{$(INTDIR)}.obj::
$(CPP_PROJ) $< $(CPP) @<<
<< $(CPP_PROJ) $<
<<
.cxx{$(INTDIR)}.obj::
$(CPP) @<< .c{$(INTDIR)}.sbr::
$(CPP_PROJ) $< $(CPP) @<<
<< $(CPP_PROJ) $<
<<
.c{$(INTDIR)}.sbr::
$(CPP) @<< .cpp{$(INTDIR)}.sbr::
$(CPP_PROJ) $< $(CPP) @<<
<< $(CPP_PROJ) $<
<<
.cpp{$(INTDIR)}.sbr::
$(CPP) @<< .cxx{$(INTDIR)}.sbr::
$(CPP_PROJ) $< $(CPP) @<<
<< $(CPP_PROJ) $<
<<
.cxx{$(INTDIR)}.sbr::
$(CPP) @<<
$(CPP_PROJ) $< !IF "$(NO_EXTERNAL_DEPS)" != "1"
<< !IF EXISTS("areslib.dep")
!INCLUDE "areslib.dep"
!ELSE
!IF "$(NO_EXTERNAL_DEPS)" != "1" !MESSAGE Warning: cannot find "areslib.dep"
!IF EXISTS("areslib.dep") !ENDIF
!INCLUDE "areslib.dep" !ENDIF
!ELSE
!MESSAGE Warning: cannot find "areslib.dep"
!ENDIF !IF "$(CFG)" == "areslib - Win32 Release" || "$(CFG)" == "areslib - Win32 Debug"
!ENDIF SOURCE=..\..\ares__close_sockets.c
"$(INTDIR)\ares__close_sockets.obj" : $(SOURCE) "$(INTDIR)"
!IF "$(CFG)" == "areslib - Win32 Release" || "$(CFG)" == "areslib - Win32 Debug" $(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares__close_sockets.c
"$(INTDIR)\ares__close_sockets.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares__get_hostent.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares__get_hostent.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares__get_hostent.c
"$(INTDIR)\ares__get_hostent.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares__read_line.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares__read_line.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares__read_line.c
"$(INTDIR)\ares__read_line.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_destroy.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_destroy.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_destroy.c
"$(INTDIR)\ares_destroy.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_expand_name.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_expand_name.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_expand_name.c
"$(INTDIR)\ares_expand_name.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_fds.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_fds.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_fds.c
"$(INTDIR)\ares_fds.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_free_hostent.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_free_hostent.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_free_errmem.c
"$(INTDIR)\ares_free_errmem.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_free_string.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_free_string.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_free_hostent.c
"$(INTDIR)\ares_free_hostent.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_gethostbyaddr.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_gethostbyaddr.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_free_string.c
"$(INTDIR)\ares_free_string.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_gethostbyname.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_gethostbyname.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_gethostbyaddr.c
"$(INTDIR)\ares_gethostbyaddr.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_init.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_init.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_gethostbyname.c
"$(INTDIR)\ares_gethostbyname.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_mkquery.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_mkquery.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_init.c
"$(INTDIR)\ares_init.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_parse_a_reply.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_parse_a_reply.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_mkquery.c
"$(INTDIR)\ares_mkquery.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_parse_ptr_reply.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_parse_ptr_reply.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_parse_a_reply.c
"$(INTDIR)\ares_parse_a_reply.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_process.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_process.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_parse_ptr_reply.c
"$(INTDIR)\ares_parse_ptr_reply.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_query.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_query.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_process.c
"$(INTDIR)\ares_process.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_search.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_search.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_query.c
"$(INTDIR)\ares_query.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_send.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_send.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_search.c
"$(INTDIR)\ares_search.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_strerror.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_strerror.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_send.c
"$(INTDIR)\ares_send.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\ares_timeout.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\ares_timeout.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_strerror.c
"$(INTDIR)\ares_strerror.obj" : $(SOURCE) "$(INTDIR)" SOURCE=..\..\windows_port.c
$(CPP) $(CPP_PROJ) $(SOURCE)
"$(INTDIR)\windows_port.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
SOURCE=..\..\ares_timeout.c
"$(INTDIR)\ares_timeout.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE) !ENDIF
SOURCE=..\..\windows_port.c
"$(INTDIR)\windows_port.obj" : $(SOURCE) "$(INTDIR)"
$(CPP) $(CPP_PROJ) $(SOURCE)
!ENDIF

View File

@@ -1,15 +1,28 @@
#include "setup.h"
/* only do the following on windows
*/
#if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS)
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <ctype.h> #include <ctype.h>
#include <string.h> #include <string.h>
#include <errno.h>
#include <malloc.h>
#ifdef WATT32
#include <sys/socket.h>
#else
#include "nameser.h" #include "nameser.h"
#endif
#include "ares.h"
#include "ares_private.h"
#ifndef __MINGW32__ #ifndef __MINGW32__
int int
ares_strncasecmp(const char *a, const char *b, size_t n) ares_strncasecmp(const char *a, const char *b, int n)
{ {
size_t i; int i;
for (i = 0; i < n; i++) { for (i = 0; i < n; i++) {
int c1 = isupper(a[i]) ? tolower(a[i]) : a[i]; int c1 = isupper(a[i]) ? tolower(a[i]) : a[i];
@@ -26,8 +39,8 @@ ares_strcasecmp(const char *a, const char *b)
} }
#endif #endif
int int
ares_gettimeofday(struct timeval *tv, struct timezone *tz) ares_gettimeofday(struct timeval *tv, struct timezone *tz)
{ {
FILETIME ft; FILETIME ft;
LARGE_INTEGER li; LARGE_INTEGER li;
@@ -40,24 +53,47 @@ ares_gettimeofday(struct timeval *tv, struct timezone *tz)
li.LowPart = ft.dwLowDateTime; li.LowPart = ft.dwLowDateTime;
li.HighPart = ft.dwHighDateTime; li.HighPart = ft.dwHighDateTime;
t = li.QuadPart; /* In 100-nanosecond intervals */ t = li.QuadPart; /* In 100-nanosecond intervals */
//t -= EPOCHFILETIME; /* Offset to the Epoch time */ #if 0
t -= EPOCHFILETIME; /* Offset to the Epoch time */
#endif
t /= 10; /* In microseconds */ t /= 10; /* In microseconds */
tv->tv_sec = (long)(t / 1000000); tv->tv_sec = (long)(t / 1000000);
tv->tv_usec = (long)(t % 1000000); tv->tv_usec = (long)(t % 1000000);
} }
#if 0
if (tz)
{
if (!tzflag)
{
_tzset();
tzflag++;
}
tz->tz_minuteswest = _timezone / 60;
tz->tz_dsttime = _daylight;
}
#endif
return 0; return 0;
} }
int
ares_writev (ares_socket_t s, const struct iovec *vector, size_t count)
{
char *buffer, *bp;
size_t i, bytes = 0;
/* Find the total number of bytes to write
*/
for (i = 0; i < count; i++)
bytes += vector[i].iov_len;
if (bytes == 0) /* not an error */
return (0);
/* Allocate a temporary buffer to hold the data
*/
buffer = bp = (char*) alloca (bytes);
if (!buffer)
{
errno = ENOMEM;
return (-1);
}
/* Copy the data into buffer.
*/
for (i = 0; i < count; ++i)
{
memcpy (bp, vector[i].iov_base, vector[i].iov_len);
bp += vector[i].iov_len;
}
return send (s, (const void*)buffer, bytes, 0);
}
#endif /* WIN32 builds only */

View File

@@ -101,6 +101,10 @@ libtool=`findtool glibtool 2>/dev/null`
if test ! -x "$libtool"; then if test ! -x "$libtool"; then
libtool=`findtool libtool` libtool=`findtool libtool`
fi fi
# set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found
LIBTOOLIZE="${libtool}ize"
lt_pversion=`$libtool --version 2>/dev/null|head -1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'` lt_pversion=`$libtool --version 2>/dev/null|head -1|sed -e 's/^[^0-9]*//g' -e 's/[- ].*//'`
if test -z "$lt_pversion"; then if test -z "$lt_pversion"; then
echo "buildconf: libtool not found." echo "buildconf: libtool not found."

View File

@@ -7,9 +7,6 @@ REM create ca-bundle.h
echo /* This file is generated automatically */ >lib\ca-bundle.h echo /* This file is generated automatically */ >lib\ca-bundle.h
echo #define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE") >>lib\ca-bundle.h echo #define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE") >>lib\ca-bundle.h
REM create getdate.c
copy lib\getdate.c.cvs lib\getdate.c
REM create hugehelp.c REM create hugehelp.c
copy src\hugehelp.c.cvs src\hugehelp.c copy src\hugehelp.c.cvs src\hugehelp.c

View File

@@ -4,7 +4,7 @@ dnl Process this file with autoconf to produce a configure script.
AC_PREREQ(2.57) AC_PREREQ(2.57)
dnl We don't know the version number "staticly" so we use a dash here dnl We don't know the version number "staticly" so we use a dash here
AC_INIT(curl, [-], [curl-bug@haxx.se]) AC_INIT(curl, [-], [a suitable curl mailing list => http://curl.haxx.se/mail/])
dnl configure script copyright dnl configure script copyright
AC_COPYRIGHT([Copyright (c) 1998 - 2004 Daniel Stenberg, <daniel@haxx.se> AC_COPYRIGHT([Copyright (c) 1998 - 2004 Daniel Stenberg, <daniel@haxx.se>
@@ -87,7 +87,7 @@ dnl check for cygwin stuff
AC_LIBTOOL_WIN32_DLL AC_LIBTOOL_WIN32_DLL
dnl libtool setup dnl libtool setup
AM_PROG_LIBTOOL AC_PROG_LIBTOOL
AC_MSG_CHECKING([if we need -no-undefined]) AC_MSG_CHECKING([if we need -no-undefined])
case $host in case $host in
@@ -102,6 +102,7 @@ AC_MSG_RESULT($need_no_undefined)
AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes) AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes)
AC_MSG_CHECKING([if we need -mimpure-text]) AC_MSG_CHECKING([if we need -mimpure-text])
mimpure=no
case $host in case $host in
*-*-solaris2*) *-*-solaris2*)
if test "$GCC" = "yes"; then if test "$GCC" = "yes"; then
@@ -109,7 +110,6 @@ case $host in
fi fi
;; ;;
*) *)
mimpure=no
;; ;;
esac esac
AC_MSG_RESULT($mimpure) AC_MSG_RESULT($mimpure)
@@ -287,7 +287,7 @@ then
AC_TRY_LINK( , AC_TRY_LINK( ,
[gethostbyname();], [gethostbyname();],
[ dnl found it! [ dnl found it!
HAVE_GETHOSTBYNAME="1", HAVE_GETHOSTBYNAME="1"
AC_MSG_RESULT([yes])], AC_MSG_RESULT([yes])],
[ dnl failed! [ dnl failed!
AC_MSG_RESULT([no]) AC_MSG_RESULT([no])
@@ -560,7 +560,7 @@ then
AC_CHECK_HEADERS(krb.h) AC_CHECK_HEADERS(krb.h)
dnl we found the required libraries, add to LIBS dnl we found the required libraries, add to LIBS
LIBS="-lkrb -ldes $LIBS" LIBS="-lkrb -lcom_err -ldes $LIBS"
dnl Check for function krb_get_our_ip_for_realm dnl Check for function krb_get_our_ip_for_realm
dnl this is needed for NAT networks dnl this is needed for NAT networks
@@ -707,45 +707,53 @@ else
CLEANCPPFLAGS="$CPPFLAGS" CLEANCPPFLAGS="$CPPFLAGS"
CLEANLIBS="$LIBS" CLEANLIBS="$LIBS"
dnl Detect the pkg-config tool, as it may have extra info about the openssl
dnl installation we can use. I *believe* this is what we are expected to do
dnl on really recent Redhat Linux hosts.
AC_PATH_PROG( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin)
if test "$PKGCONFIG" != "no" ; then
AC_MSG_CHECKING([OpenSSL options with pkg-config])
$PKGCONFIG --exists openssl
SSL_EXISTS=$?
if test "$SSL_EXISTS" -eq "0"; then
SSL_LIBS=`$PKGCONFIG --libs-only-l openssl 2>/dev/null`
SSL_LDFLAGS=`$PKGCONFIG --libs-only-L openssl 2>/dev/null`
SSL_CPPFLAGS=`$PKGCONFIG --cflags-only-I openssl 2>/dev/null`
dnl use the values pkg-config reported
LIBS="$LIBS $SSL_LIBS"
CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS"
LDFLAGS="$LDFLAGS $SSL_LDFLAGS"
AC_MSG_RESULT([found])
else
AC_MSG_RESULT([no])
fi
fi
case "$OPT_SSL" in case "$OPT_SSL" in
yes) yes)
dnl --with-ssl (without path) used
PKGTEST="yes"
EXTRA_SSL=/usr/local/ssl ;; EXTRA_SSL=/usr/local/ssl ;;
off) off)
dnl no --with-ssl option given, just check default places
PKGTEST="yes"
EXTRA_SSL= ;; EXTRA_SSL= ;;
*) *)
dnl check the given spot right away! dnl check the given --with-ssl spot
PKGTEST="no"
EXTRA_SSL=$OPT_SSL EXTRA_SSL=$OPT_SSL
LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib$libsuff" LDFLAGS="$LDFLAGS -L$EXTRA_SSL/lib$libsuff"
CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include" CPPFLAGS="$CPPFLAGS -I$EXTRA_SSL/include/openssl -I$EXTRA_SSL/include"
;; ;;
esac esac
if test "$PKGTEST" = "yes"; then
dnl Detect the pkg-config tool, as it may have extra info about the
dnl openssl installation we can use. I *believe* this is what we are
dnl expected to do on really recent Redhat Linux hosts.
AC_PATH_PROG( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin)
if test "$PKGCONFIG" != "no" ; then
AC_MSG_CHECKING([OpenSSL options with pkg-config])
$PKGCONFIG --exists openssl
SSL_EXISTS=$?
if test "$SSL_EXISTS" -eq "0"; then
SSL_LIBS=`$PKGCONFIG --libs-only-l openssl 2>/dev/null`
SSL_LDFLAGS=`$PKGCONFIG --libs-only-L openssl 2>/dev/null`
SSL_CPPFLAGS=`$PKGCONFIG --cflags-only-I openssl 2>/dev/null`
dnl use the values pkg-config reported
LIBS="$LIBS $SSL_LIBS"
CPPFLAGS="$CPPFLAGS $SSL_CPPFLAGS"
LDFLAGS="$LDFLAGS $SSL_LDFLAGS"
AC_MSG_RESULT([found])
else
AC_MSG_RESULT([no])
fi
fi
fi
AC_CHECK_LIB(crypto, CRYPTO_lock,[ AC_CHECK_LIB(crypto, CRYPTO_lock,[
HAVECRYPTO="yes" HAVECRYPTO="yes"
],[ ],[
@@ -945,26 +953,31 @@ case "$LIBIDN" in
AC_MSG_RESULT(no) AC_MSG_RESULT(no)
;; ;;
*) AC_MSG_RESULT(yes) *) AC_MSG_RESULT(yes)
AC_CHECK_LIB(idn, idna_to_ascii_lz, ,
[ idn=""
dnl if there was a given path, try it dnl if there is a given path, check that FIRST
nolibidn="true" if test "x$LIBIDN" != "xyes"; then
if test "x$LIBIDN" != "xyes"; then oldLDFLAGS=$LDFLAGS
nolibidn="" dnl reset to test again oldCPPFLAGS=$CPPFLAGS
oldLDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -L$LIBIDN/lib"
oldCPPFLAGS=$CPPFLAGS CPPFLAGS="$CPPFLAGS -I$LIBIDN/include"
LDFLAGS="$LDFLAGS -L$LIBIDN/lib" idn="yes"
CPPFLAGS="$CPPFLAGS -I$LIBIDN/include" AC_CHECK_LIB(idn, idna_to_ascii_4i, ,
AC_CHECK_LIB(idn, idna_to_ascii_4i, , idn=""
nolibidn="true" LDFLAGS=$oldLDFLAGS
LDFLAGS=$oldLDFLAGS CPPFLAGS=$oldCPPFLAGS)
CPPFLAGS=$oldCPPFLAGS) fi
fi
]) if test "x$idn" != "xyes"; then
if test "x$nolibidn" != "xtrue"; then dnl check with default paths
AC_CHECK_LIB(idn, idna_to_ascii_lz, ,
idn="")
fi
if test "x$idn" = "xyes"; then
curl_idn_msg="enabled" curl_idn_msg="enabled"
dnl different versions of libidn have different setups of these: dnl different versions of libidn have different setups of these:
AC_CHECK_FUNCS( idn_free ) AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror)
AC_CHECK_HEADERS( idn-free.h ) AC_CHECK_HEADERS( idn-free.h )
fi fi
@@ -1014,7 +1027,7 @@ else
CURL_CHECK_GETHOSTBYNAME_R() CURL_CHECK_GETHOSTBYNAME_R()
dnl dig around for gethostbyaddr_r() dnl dig around for gethostbyaddr_r()
CURL_CHECK_GETHOSTBYADDR_R() dnl CURL_CHECK_GETHOSTBYADDR_R()
fi fi
dnl poke around for inet_ntoa_r() dnl poke around for inet_ntoa_r()
@@ -1038,6 +1051,24 @@ dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \
dnl genprogc/thread_quick_ref.htm dnl genprogc/thread_quick_ref.htm
if test "x$RECENTAIX" = "xyes"; then if test "x$RECENTAIX" = "xyes"; then
AC_DEFINE(_THREAD_SAFE, 1, [define this if you need it to compile thread-safe code])
dnl check if this is the IMB xlc compiler
dnl Details thanks to => http://predef.sourceforge.net/
AC_MSG_CHECKING([if this is the xlc compiler])
AC_EGREP_CPP([^__xlC__], [__xlC__],
dnl action if the text is found, this it has not been replaced by the
dnl cpp
XLC="no"
AC_MSG_RESULT([no]),
dnl the text was not found, it was replaced by the cpp
XLC="yes"
AC_MSG_RESULT([yes])
CFLAGS="$CFLAGS -qthreaded"
)
dnl is there a localtime_r() dnl is there a localtime_r()
CURL_CHECK_LOCALTIME_R() CURL_CHECK_LOCALTIME_R()
@@ -1089,6 +1120,7 @@ AC_CHECK_HEADERS(
utime.h \ utime.h \
sys/utime.h \ sys/utime.h \
sys/poll.h \ sys/poll.h \
libgen.h \
setjmp.h, setjmp.h,
dnl to do if not found dnl to do if not found
[], [],
@@ -1124,9 +1156,22 @@ AC_CHECK_SIZEOF(curl_off_t, ,[
#include "$srcdir/include/curl/curl.h" #include "$srcdir/include/curl/curl.h"
]) ])
AC_CHECK_SIZEOF(size_t) AC_CHECK_SIZEOF(size_t)
AC_CHECK_SIZEOF(long)
AC_CHECK_TYPE(long long, AC_CHECK_TYPE(long long,
[AC_DEFINE(HAVE_LONGLONG, 1, [if your compiler supports 'long long'])]) [AC_DEFINE(HAVE_LONGLONG, 1, [if your compiler supports long long])]
longlong="yes"
)
if test "xyes" = "x$longlong"; then
AC_MSG_CHECKING([if numberLL works])
AC_COMPILE_IFELSE([long long val = 1000LL;],
[AC_DEFINE(HAVE_LL, 1, [if your compiler supports LL])]
AC_MSG_RESULT(yes),
AC_MSG_RESULT(no)
)
fi
# check for ssize_t # check for ssize_t
AC_CHECK_TYPE(ssize_t, , AC_CHECK_TYPE(ssize_t, ,
@@ -1171,6 +1216,7 @@ AC_CHECK_FUNCS( strtoll \
dlopen \ dlopen \
utime \ utime \
sigsetjmp \ sigsetjmp \
basename \
poll, poll,
dnl if found dnl if found
[], [],
@@ -1201,6 +1247,41 @@ if test "$ac_cv_func_sigsetjmp" != "yes"; then
) )
fi fi
AC_CHECK_DECL(basename, ,
AC_DEFINE(NEED_BASENAME_PROTO, 1, [If you lack a fine basename() prototype]),
#ifdef HAVE_STRING_H
#include <string.h>
#endif
#ifdef HAVE_LIBGEN_H
#include <libgen.h>
#endif
)
dnl poll() might be badly emulated, as in Mac OS X 10.3 (and other BSDs?) and
dnl to find out we make an extra check here!
if test "$ac_cv_func_poll" = "yes"; then
AC_MSG_CHECKING([if poll works with NULL inputs])
AC_RUN_IFELSE([
#ifdef HAVE_SYS_POLL_H
#include <sys/poll.h>
#endif
int main(void)
{
/* make this return 0 == timeout since there's nothing to read from */
return poll((void *)0, 0, 10 /*ms*/);
}
],
AC_MSG_RESULT(yes)
AC_DEFINE(HAVE_POLL_FINE, 1, [If you have a fine poll]),
AC_MSG_RESULT(no),
AC_MSG_RESULT(cross-compiling assumes yes)
AC_DEFINE(HAVE_POLL_FINE, 1, [If you have a fine poll])
) dnl end of AC_RUN_IFELSE
fi
AC_PATH_PROG( PERL, perl, , AC_PATH_PROG( PERL, perl, ,
$PATH:/usr/local/bin/perl:/usr/bin/:/usr/local/bin ) $PATH:/usr/local/bin/perl:/usr/bin/:/usr/local/bin )
AC_SUBST(PERL) AC_SUBST(PERL)
@@ -1239,22 +1320,6 @@ then
USE_MANUAL="no"; USE_MANUAL="no";
fi fi
AC_PROG_YACC
if test -z "$YACC"
then
AC_MSG_CHECKING([if OK to build without bison/yacc])
dnl no yacc is a big deal if we have no pre-fixed getdate.y
if test -r "$srcdir/lib/getdate.c"
then
dnl all is well, we don't have to generate it!
AC_MSG_RESULT(yes)
else
AC_MSG_RESULT(no)
AC_MSG_ERROR([no yacc or bison found, can't build libcurl!])
fi
fi
dnl ************************************************************************* dnl *************************************************************************
dnl If the manual variable still is set, then we go with providing a built-in dnl If the manual variable still is set, then we go with providing a built-in
dnl manual dnl manual

View File

@@ -20,6 +20,13 @@
) )
"Curl C Programming Style") "Curl C Programming Style")
(defun curl-code-cleanup ()
"no docs"
(interactive)
(untabify (point-min) (point-max))
(delete-trailing-whitespace)
)
;; Customizations for all of c-mode, c++-mode, and objc-mode ;; Customizations for all of c-mode, c++-mode, and objc-mode
(defun curl-c-mode-common-hook () (defun curl-c-mode-common-hook ()
"Curl C mode hook" "Curl C mode hook"
@@ -28,12 +35,12 @@
(setq tab-width 8 (setq tab-width 8
indent-tabs-mode nil ; Use spaces. Not tabs. indent-tabs-mode nil ; Use spaces. Not tabs.
comment-column 40 comment-column 40
c-font-lock-extra-types (append '("bool" "CURL" "CURLcode" "ssize_t" "size_t" "socklen_t" "fd_set" "time_t" "curl_off_t" "curl_socket_t" "in_addr_t" "CURLSHcode" "CURLMcode")) c-font-lock-extra-types (append '("bool" "CURL" "CURLcode" "ssize_t" "size_t" "socklen_t" "fd_set" "time_t" "curl_off_t" "curl_socket_t" "in_addr_t" "CURLSHcode" "CURLMcode" "Curl_addrinfo"))
) )
;; keybindings for C, C++, and Objective-C. We can put these in ;; keybindings for C, C++, and Objective-C. We can put these in
;; c-mode-base-map because of inheritance ... ;; c-mode-base-map because of inheritance ...
(define-key c-mode-base-map "\M-q" 'c-fill-paragraph) (define-key c-mode-base-map "\M-q" 'c-fill-paragraph)
(define-key c-mode-base-map "\M-m" 'delete-trailing-whitespace) (define-key c-mode-base-map "\M-m" 'curl-code-cleanup)
(setq c-recognize-knr-p nil) (setq c-recognize-knr-p nil)
;;; (add-hook 'write-file-hooks 'delete-trailing-whitespace t) ;;; (add-hook 'write-file-hooks 'delete-trailing-whitespace t)
(setq show-trailing-whitespace t) (setq show-trailing-whitespace t)

View File

@@ -1,7 +1,7 @@
_ _ ____ _ _ _ ____ _
___| | | | _ \| | ___| | | | _ \| |
/ __| | | | |_) | | / __| | | | |_) | |
| (__| |_| | _ <| |___ | (__| |_| | _ <| |___
\___|\___/|_| \_\_____| \___|\___/|_| \_\_____|
libcurl bindings libcurl bindings
@@ -17,22 +17,27 @@ archives, but must be downloaded and installed separately.
Ada95 Ada95
Writtten by Andreas Almroth. Writtten by Andreas Almroth
http://www.almroth.com/adacurl/index.html http://www.almroth.com/adacurl/index.html
Basic Basic
ScriptBasic bindings to libcurl. Writtten by Peter Verhas. ScriptBasic bindings to libcurl. Writtten by Peter Verhas
http://scriptbasic.com/ http://scriptbasic.com/
C++ C++
Written by Jean-Philippe Barrette-LaPierre. Written by Jean-Philippe Barrette-LaPierre
http://www.sourceforge.net/projects/curlpp http://www.sourceforge.net/projects/curlpp
Ch
Written by Stephen Nestinger and Jonathan Rogado
http://chcurl.sourceforge.net/
Cocoa Cocoa
Written by Dan Wood. Written by Dan Wood
http://curlhandle.sourceforge.net/ http://curlhandle.sourceforge.net/
D D
@@ -42,25 +47,33 @@ D
Dylan Dylan
Written by Chris Double. Written by Chris Double
http://dylanlibs.sourceforge.net/ http://dylanlibs.sourceforge.net/
Euphoria Euphoria
Written by Ray Smith. Written by Ray Smith
http://rays-web.com/eulibcurl.htm http://rays-web.com/eulibcurl.htm
Ferite Ferite
Written by Paul Querna
http://www.ferite.org/ http://www.ferite.org/
Gambas
http://gambas.sourceforge.net
glib/GTK+
Written by Richard Atterer
http://atterer.net/glibcurl/
Java Java
Written by Daniel Stenberg. Written by Daniel Stenberg
http://curl.haxx.se/libcurl/java/ http://curl.haxx.se/libcurl/java/
Lua Lua
Written by Steve Dekorte. Written by Steve Dekorte
http://curl.haxx.se/libcurl/lua/ http://curl.haxx.se/libcurl/lua/
Object-Pascal Object-Pascal
@@ -70,7 +83,7 @@ Object-Pascal
O'Caml O'Caml
Written by Lars Nilsson. Written by Lars Nilsson
http://sourceforge.net/projects/ocurl/ http://sourceforge.net/projects/ocurl/
Pascal Pascal
@@ -80,40 +93,49 @@ Pascal
Perl Perl
Maintained by Cris Bailiff. Maintained by Cris Bailiff
http://curl.haxx.se/libcurl/perl/ http://curl.haxx.se/libcurl/perl/
PHP PHP
Written by Sterling Hughes. Written by Sterling Hughes
http://curl.haxx.se/libcurl/php/ http://curl.haxx.se/libcurl/php/
PostgreSQL PostgreSQL
Written by Gian Paolo Ciceri. Written by Gian Paolo Ciceri
http://gborg.postgresql.org/project/pgcurl/projdisplay.php http://gborg.postgresql.org/project/pgcurl/projdisplay.php
Python Python
Written by Kjetil Jacobsen. Written by Kjetil Jacobsen
http://pycurl.sourceforge.net/ http://pycurl.sourceforge.net/
Rexx Rexx
Written Mark Hessling. Written Mark Hessling
http://rexxcurl.sourceforge.net/ http://rexxcurl.sourceforge.net/
Ruby Ruby
Written by Hirotaka Matsuyuki. Written by Hirotaka Matsuyuki
http://www.d1.dion.ne.jp/~matuyuki/ruby.html http://www.d1.dion.ne.jp/~matuyuki/ruby.html
Scheme Scheme
Bigloo binding written by Kirill Lisovsky. Bigloo binding written by Kirill Lisovsky
http://curl.haxx.se/libcurl/scheme/ http://curl.haxx.se/libcurl/scheme/
Tcl Tcl
Written by Andr<64>s Garc<72>a. Written by Andr<64>s Garc<72>a
http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html http://personal1.iddeo.es/andresgarci/tclcurl/english/docs.html
Q
http://q-lang.sourceforge.net/
wxWidgets
Written by Casey O'Donnell
http://homepage.mac.com/codonnell/wxcurldav/

View File

@@ -1,7 +1,7 @@
_ _ ____ _ _ _ ____ _
___| | | | _ \| | ___| | | | _ \| |
/ __| | | | |_) | | / __| | | | |_) | |
| (__| |_| | _ <| |___ | (__| |_| | _ <| |___
\___|\___/|_| \_\_____| \___|\___/|_| \_\_____|
To Think About When Contributing Source Code To Think About When Contributing Source Code
@@ -138,15 +138,15 @@ How To Make a Patch
If you have modified a single file, try something like: If you have modified a single file, try something like:
diff -u undmodified-file.c my-changed-one.c > my-fixes.diff diff -u unmodified-file.c my-changed-one.c > my-fixes.diff
If you have modified several files, possibly in different directories, you If you have modified several files, possibly in different directories, you
can use diff recursively: can use diff recursively:
diff -ur curl-original-dir curl-modfied-sources-dir > my-fixes.diff diff -ur curl-original-dir curl-modified-sources-dir > my-fixes.diff
The GNU diff and GNU patch tools exist for virtually all platforms, including The GNU diff and GNU patch tools exist for virtually all platforms, including
all kinds of unixes and Windows: all kinds of Unixes and Windows:
For unix-like operating systems: For unix-like operating systems:

246
docs/FAQ
View File

@@ -1,4 +1,4 @@
Updated: March 16, 2004 (http://curl.haxx.se/docs/faq.html) Updated: August 18, 2004 (http://curl.haxx.se/docs/faq.html)
_ _ ____ _ _ _ ____ _
___| | | | _ \| | ___| | | | _ \| |
/ __| | | | |_) | | / __| | | | |_) | |
@@ -10,20 +10,20 @@ FAQ
1. Philosophy 1. Philosophy
1.1 What is cURL? 1.1 What is cURL?
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.5 Who makes curl?
1.6 What do you get for making cURL? 1.6 What do you get for making curl?
1.7 What about CURL from curl.com? 1.7 What about CURL from curl.com?
1.8 I have a problem who do I mail? 1.8 I have a problem who do I mail?
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
2.1.1. native linker doesn't find OpenSSL 2.1.1 native linker doesn't find OpenSSL
2.1.2. only the libssl lib is missing 2.1.2 only the libssl lib is missing
2.2 Does curl work/build with other SSL libraries? 2.2 Does curl work/build with other SSL libraries?
2.3 Where can I find a copy of LIBEAY32.DLL? 2.3 Where can I find a copy of LIBEAY32.DLL?
2.4 Does cURL support Socks (RFC 1928) ? 2.4 Does curl support Socks (RFC 1928) ?
3. Usage Problems 3. Usage Problems
3.1 curl: (1) SSL is disabled, https: not supported 3.1 curl: (1) SSL is disabled, https: not supported
@@ -41,6 +41,7 @@ FAQ
3.13 Why does my single/double quotes fail? 3.13 Why does my single/double quotes fail?
3.14 Does curl support javascript or pac (automated proxy config)? 3.14 Does curl support javascript or pac (automated proxy config)?
3.15 Can I do recursive fetches with curl? 3.15 Can I do recursive fetches with curl?
3.16 What certificates do I need when I use SSL?
4. Running Problems 4. Running Problems
4.1 Problems connecting to SSL servers. 4.1 Problems connecting to SSL servers.
@@ -70,6 +71,8 @@ FAQ
5.5 Does CURLOPT_WRITEDATA and CURLOPT_READDATA work on win32 ? 5.5 Does CURLOPT_WRITEDATA and CURLOPT_READDATA work on win32 ?
5.6 What about Keep-Alive or persistent connections? 5.6 What about Keep-Alive or persistent connections?
5.7 Link errors when building libcurl on Windows! 5.7 Link errors when building libcurl on Windows!
5.8 libcurl.so.3: open failed: No such file or directory
5.9 How does libcurl resolve host names?
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?
@@ -79,24 +82,50 @@ FAQ
6.5 Can I modify curl/libcurl for my program and keep the changes secret? 6.5 Can I modify curl/libcurl for my program and keep the changes secret?
6.6 Can you please change the curl/libcurl license to XXXX? 6.6 Can you please change the curl/libcurl license to XXXX?
7. PHP/CURL Issues
7.1 What is PHP/CURL?
7.2 Who write PHP/CURL?
7.3 Can I perform multiple requests using the same handle?
============================================================================== ==============================================================================
1. Philosophy 1. Philosophy
1.1 What is cURL? 1.1 What is cURL?
cURL (or simply just 'curl') is a command line tool for getting or sending cURL is the name of the project. The name is a play on 'Client for URLs',
files using URL syntax. The name is a play on 'Client for URLs', originally originally with URL spelled in uppercase to make it obvious it deals with
with URL spelled in uppercase to make it obvious it deals with URLs. The URLs. The fact it can also be pronounced 'see URL' also helped, it works as
fact it can also be pronounced 'see URL' also helped, it works as an an abbrivation for "Client URL Request Library" or why not the recursive
abbrivation for "Client URL Request Library" or why not the recursive
version: "Curl URL Request Library". version: "Curl URL Request Library".
Curl supports a range of common Internet protocols, currently including The cURL project produces two products:
HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and FILE.
We spell it cURL or just curl. We pronounce it with an initial k sound: libcurl
[kurl].
A free and easy-to-use client-side URL transfer library, supporting FTP,
FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE and LDAP. libcurl supports
HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading, kerberos, HTTP
form based upload, proxies, cookies, user+password authentication, file
transfer resume, http proxy tunneling and more!
libcurl is highly portable, it builds and works identically on numerous
platforms, including Solaris, NetBSD, FreeBSD, OpenBSD, Darwin, HPUX,
IRIX, AIX, Tru64, Linux, UnixWare, HURD, Windows, Amiga, OS/2, BeOs, Mac
OS X, Ultrix, QNX, OpenVMS, RISC OS, Novell NetWare, DOS and more...
libcurl is free, thread-safe, IPv6 compatible, feature rich, well
supported and fast.
curl
A command line tool for getting or sending files using URL syntax.
Since curl uses libcurl, it supports a range of common Internet protocols,
currently including HTTP, HTTPS, FTP, FTPS, GOPHER, LDAP, DICT, TELNET and
FILE.
We pronounce curl and cURL with an initial k sound: [kurl].
NOTE: there are numerous sub-projects and related projects that also use the NOTE: there are numerous sub-projects and related projects that also use the
word curl in the project names in various combinations, but you should take word curl in the project names in various combinations, but you should take
@@ -112,7 +141,7 @@ FAQ
You can use libcurl for free in your application, be it open source, You can use libcurl for free in your application, be it open source,
commercial or closed-source. commercial or closed-source.
1.3 What is cURL not? 1.3 What is curl not?
Curl is *not* a wget clone. That is a common misconception. Never, during Curl is *not* a wget clone. That is a common misconception. Never, during
curl's development, have we intended curl to replace wget or compete on its curl's development, have we intended curl to replace wget or compete on its
@@ -127,7 +156,7 @@ FAQ
script (or write a new program that interfaces libcurl) and do it. script (or write a new program that interfaces libcurl) and do it.
Curl is not a PHP tool, even though it works perfectly well when used from Curl is not a PHP tool, even though it works perfectly well when used from
or with PHP. or with PHP (when using the PHP/CURL module).
Curl is not a single-OS program. Curl exists, compiles, builds and runs Curl is not a single-OS program. Curl exists, compiles, builds and runs
under a wide range of operating systems, including all modern Unixes (and a under a wide range of operating systems, including all modern Unixes (and a
@@ -161,9 +190,9 @@ 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? 1.5 Who makes curl?
cURL and libcurl are not made by any single individual. Sure, Daniel curl and libcurl are not made by any single individual. Sure, Daniel
Stenberg writes the major parts, but other persons' submissions are Stenberg writes the major parts, but other persons' submissions are
important and crucial. Anyone can contribute and post their changes and important and crucial. Anyone can contribute and post their changes and
improvements and have them inserted in the main sources (of course on the improvements and have them inserted in the main sources (of course on the
@@ -175,14 +204,16 @@ FAQ
curl is developed by a community, with Daniel at the wheel. curl is developed by a community, with Daniel at the wheel.
1.6 What do you get for making cURL? 1.6 What do you get for making curl?
Project cURL is entirely free and open. No person gets paid for developing Project cURL is entirely free and open. No person gets paid for developing
curl. We do this voluntarily on our spare time. (lib)curl. We do this voluntarily on our spare time.
We get some help from companies. Contactor Data hosts the curl web site, We get some help from companies. Contactor Data hosts the curl web site,
Haxx owns the curl web site's domain and sourceforge.net hosts project Haxx owns the curl web site's domain and sourceforge.net hosts project
services we take advantage from, like the bug tracker. services we take advantage from, like the bug tracker. Also, some companies
have sponsored certain parts of the development in the past and I hope some
will continue to do so in the future.
If you want to support our project with a donation or similar, one way of If you want to support our project with a donation or similar, one way of
doing that would be to buy "gift certificates" at useful online shopping doing that would be to buy "gift certificates" at useful online shopping
@@ -223,11 +254,11 @@ FAQ
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
This may be because of several reasons. This may be because of several reasons.
2.1.1. native linker doesn't find openssl 2.1.1 native linker doesn't find openssl
Affected platforms: Affected platforms:
Solaris (native cc compiler) Solaris (native cc compiler)
@@ -249,7 +280,7 @@ FAQ
Solution submitted by: Bob Allison <allisonb@users.sourceforge.net> Solution submitted by: Bob Allison <allisonb@users.sourceforge.net>
2.1.2. only the libssl lib is missing 2.1.2 only the libssl lib is missing
If all include files and the libcrypto lib is present, with only the If all include files and the libcrypto lib is present, with only the
libssl being missing according to configure, this is mostly likely because libssl being missing according to configure, this is mostly likely because
@@ -262,14 +293,14 @@ FAQ
configure. Make sure that you remove the config.cache file before you configure. Make sure that you remove the config.cache file before you
rerun configure with the new flags. rerun configure with the new flags.
2.2. Does curl work/build with other SSL libraries? 2.2 Does curl work/build with other SSL libraries?
Curl has been written to use OpenSSL, although there should not be much Curl has been written to use OpenSSL, although there should not be much
problems using a different library. If anyone does "port" curl to use a problems using a different library. If anyone does "port" curl to use a
different SSL library, we are of course very interested in getting the different SSL library, we are of course very interested in getting the
patch! patch!
2.3. Where can I find a copy of LIBEAY32.DLL? 2.3 Where can I find a copy of LIBEAY32.DLL?
That is an OpenSSL binary built for Windows. That is an OpenSSL binary built for Windows.
@@ -278,14 +309,14 @@ FAQ
accurate and up-to-date pointers to recent OpenSSL DLLs 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) ?
Yes, SOCKS5 is supported when curl is built with IPv6 support disabled. Yes, SOCKS5 is supported.
3. Usage problems 3. Usage problems
3.1. curl: (1) SSL is disabled, https: not supported 3.1 curl: (1) SSL is disabled, https: not supported
If you get this output when trying to get anything from a https:// server, If you get this output when trying to get anything from a https:// server,
it means that the configure script couldn't find all libs and include files it means that the configure script couldn't find all libs and include files
@@ -300,13 +331,13 @@ FAQ
Also, check out the other paragraph in this FAQ labeled "configure doesn't Also, check out the other paragraph in this FAQ labeled "configure doesn't
find OpenSSL even when it is installed". find OpenSSL even when it is installed".
3.2. How do I tell curl to resume a transfer? 3.2 How do I tell curl to resume a transfer?
Curl supports resumed transfers both ways on both FTP and HTTP. Curl supports resumed transfers both ways on both FTP and HTTP.
Try the -C option. Try the -C option.
3.3. Why doesn't my posting using -F work? 3.3 Why doesn't my posting using -F work?
You can't simply use -F or -d at your choice. The web server that will You can't simply use -F or -d at your choice. The web server that will
receive your post assumes one of the formats. If the form you're trying to receive your post assumes one of the formats. If the form you're trying to
@@ -320,7 +351,7 @@ FAQ
through the mailing list archives for old postings and questions regarding through the mailing list archives for old postings and questions regarding
this. 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?
You can tell curl to perform optional commands both before and/or after a You can tell curl to perform optional commands both before and/or after a
file transfer. Study the -Q/--quote option. file transfer. Study the -Q/--quote option.
@@ -329,13 +360,13 @@ FAQ
FTP commands without transferring 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?
You can change all internally generated headers by adding a replacement with You can change all internally generated headers by adding a replacement with
the -H/--header option. By adding a header with empty contents you safely the -H/--header option. By adding a header with empty contents you safely
disable that one. Use -H "Pragma:" to disable that specific header. disable that one. Use -H "Pragma:" to disable that specific header.
3.6. Does curl support ASP, XML, XHTML or HTML version Y? 3.6 Does curl support 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
@@ -344,7 +375,7 @@ FAQ
See also item 3.14 regarding javascript. See also item 3.14 regarding javascript.
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.
@@ -369,8 +400,7 @@ FAQ
Find out more about which languages that support curl directly, and how to 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: install and use them, in the libcurl section of the curl web site:
http://curl.haxx.se/libcurl/
http://curl.haxx.se/libcurl/
In February 2003, there are interfaces available for the following In February 2003, there are interfaces available for the following
languages: Basic, C, C++, Cocoa, Dylan, Euphoria, Java, Lua, Object-Pascal, languages: Basic, C, C++, Cocoa, Dylan, Euphoria, Java, Lua, Object-Pascal,
@@ -443,28 +473,57 @@ FAQ
Some work-arounds usually suggested to overcome this javascript dependency: Some work-arounds usually suggested to overcome this javascript dependency:
- Depending on the javascript complexity, write up a script that - Depending on the javascript complexity, write up a script that
translates it to another language and execute that. translates it to another language and execute that.
- Read the javascript code and rewrite the same logic in another language. - Read the javascript code and rewrite the same logic in another language.
- Implement a javascript interpreter, people have successfully used the - Implement a javascript interpreter, people have successfully used the
Mozilla javascript engine in the past. Mozilla javascript engine in the past.
- Ask your admins to stop this, for a static proxy setup or similar. - Ask your admins to stop this, for a static proxy setup or similar.
3.15 Can I do recursive fetches with curl? 3.15 Can I do recursive fetches with curl?
No. curl itself has no code that performs recursive operations, such as No. curl itself has no code that performs recursive operations, such as
those performed by wget. those performed by wget and similar tools.
There exist wrapper scripts with that functionality (for example the There exist wrapper scripts with that functionality (for example the
curlmirror perl script), and you can write programs based on libcurl to do curlmirror perl script), and you can write programs based on libcurl to do
it, but the command line tool curl itself cannot. it, but the command line tool curl itself cannot.
3.16 What certificates do I need when I use SSL?
There are three different kinds of "certificates" to keep track of when we
talk about using SSL-based protocols (HTTPS or FTPS) using curl or libcurl.
- Client certificate. The server you communicate may require that you can
provide this in order to prove that you actually are who you claim to be.
If the server doesn't require this, you don't need a client certificate.
- Server certificate. The server you communicate with has a server
certificate. You can and should verify this certficate to make sure that
you are truly talking to the real server and not a server impersonating
it. The server certificate verifaction process is made by using a
Certificate Authority certificate ("CA cert") that was used to sign the
server certificate. Server certificate verification is enabled by default
in curl and libcurl and is often the reason for problems as explained in
FAQ entry 4.12 and the SSLCERTS document
(http://curl.haxx.se/docs/sslcerts.html). Server certificates that are
"self-signed" or otherwise signed by a CA that you do not have a CA cert
for, cannot be verified. If the verification during a connect fails, you
are refused access. You then need to explicitly disable the verification
to connect to the server.
- Certificate Authority certificate ("CA cert"). You often have several CA
certs in a CA cert bundle that can be used to verify a server certificate
that was signed by one of the authorities in the bundle. curl comes with a
default CA cert bundle. You can override the default.
4. Running Problems 4. Running Problems
4.1. Problems connecting to SSL servers. 4.1 Problems connecting to SSL servers.
It took a very long time before we could sort out why curl had problems to It took a very long time before we could sort out why curl had problems to
connect to certain SSL servers when using SSLeay or OpenSSL v0.9+. The connect to certain SSL servers when using SSLeay or OpenSSL v0.9+. The
@@ -479,7 +538,7 @@ FAQ
There have also been examples where the remote server didn't like the SSLv2 There have also been examples where the remote server didn't like the SSLv2
request and instead you had to force curl to use SSLv3 with -3/--sslv3. request and instead you had to force curl to use SSLv3 with -3/--sslv3.
4.2. Why do I get problems when I use & or % in the URL? 4.2 Why do I get problems when I use & or % in the URL?
In general unix shells, the & letter is treated special and when used, it In general unix shells, the & letter is treated special and when used, it
runs the specified command in the background. To safely send the & as a part runs the specified command in the background. To safely send the & as a part
@@ -497,7 +556,7 @@ FAQ
pass in a POST using -d/--data you must encode it as '%25' (which then also pass in a POST using -d/--data you must encode it as '%25' (which then also
needs the %-letter doubled on Windows machines). needs the %-letter doubled on Windows machines).
4.3. How can I use {, }, [ or ] to specify multiple URLs? 4.3 How can I use {, }, [ or ] to specify multiple URLs?
Because those letters have a special meaning to the shell, and to be used in Because those letters have a special meaning to the shell, and to be used in
a URL specified to curl you must quote them. a URL specified to curl you must quote them.
@@ -511,7 +570,7 @@ FAQ
curl -g 'www.site.com/weirdname[].html' curl -g 'www.site.com/weirdname[].html'
4.4. Why do I get downloaded data even though the web page doesn't exist? 4.4 Why do I get downloaded data even though the web page doesn't exist?
Curl asks remote servers for the page you specify. If the page doesn't exist Curl asks remote servers for the page you specify. If the page doesn't exist
at the server, the HTTP protocol defines how the server should respond and at the server, the HTTP protocol defines how the server should respond and
@@ -562,14 +621,14 @@ FAQ
slash. Try the same operation again _with_ the trailing URL, or use the slash. Try the same operation again _with_ the trailing URL, or use the
-L/--location option to follow the redirection. -L/--location option to follow the redirection.
4.6. Can you tell me what error code 142 means? 4.6 Can you tell me what error code 142 means?
All error codes that are larger than the highest documented error code means All error codes that are larger than the highest documented error code means
that curl has exited due to a crash. This is a serious error, and we that curl has exited due to a crash. This is a serious error, and we
appreciate a detailed bug report from you that describes how we could go appreciate a detailed bug report from you that describes how we could go
ahead and repeat this! ahead and repeat this!
4.7. How do I keep user names and passwords secret in Curl command lines? 4.7 How do I keep user names and passwords secret in Curl command lines?
This problem has two sides: This problem has two sides:
@@ -603,7 +662,7 @@ FAQ
If there is a bug, read the BUGS document first. Then report it as described If there is a bug, read the BUGS document first. Then report it as described
in there. in there.
4.9. Curl can't authenticate to the server that requires NTLM? 4.9 Curl can't authenticate to the server that requires NTLM?
This is supported in curl 7.10.6 or later. No earlier curl version knows This is supported in curl 7.10.6 or later. No earlier curl version knows
of this magic. of this magic.
@@ -651,9 +710,10 @@ FAQ
Details are also in the SSLCERTS file in the release archives, found online Details are also in the SSLCERTS file in the release archives, found online
here: http://curl.haxx.se/docs/sslcerts.html here: http://curl.haxx.se/docs/sslcerts.html
5. libcurl Issues 5. libcurl Issues
5.1. Is libcurl thread-safe? 5.1 Is libcurl thread-safe?
Yes. Yes.
@@ -687,7 +747,7 @@ FAQ
size_t size_t
WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data) WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
{ {
register int realsize = size * nmemb; size_t realsize = size * nmemb;
struct MemoryStruct *mem = (struct MemoryStruct *)data; struct MemoryStruct *mem = (struct MemoryStruct *)data;
mem->memory = (char *)realloc(mem->memory, mem->size + realsize + 1); mem->memory = (char *)realloc(mem->memory, mem->size + realsize + 1);
@@ -743,6 +803,47 @@ FAQ
(Provided by Andrew Francis) (Provided by Andrew Francis)
5.8 libcurl.so.3: open failed: No such file or directory
This is an error message you might get when you try to run a program linked
with a shared version of libcurl and your run-time linker (ld.so) couldn't
find the shared library named libcurl.so.3.
You need to make sure that ld.so finds libcurl.so.3. You can do that
multiple ways, and it differs somewhat between different operating systems,
but they are usually:
* Add an option to the linker command line that specify the hard-coded path
the run-time linker should check for the lib (usually -R)
* Set an environment variable (LD_LIBRARY_PATH for example) where ld.so
should check for libs
* Adjust the system's config to check for libs in the directory where you've
put the dir (like Linux's /etc/ld.so.conf)
'man ld.so' and 'man ld' will tell you more details
5.9 How does libcurl resolve host names?
libcurl includes a number of different name resolve functions:
- The non-ipv6 resolver that can use one out of four host name resolve calls
(depending on what your system supports):
A - gethostbyname()
B - gethostbyname_r() with 3 arguments
C - gethostbyname_r() with 5 arguments
D - gethostbyname_r() with 6 arguments
- The ipv6-resolver that uses getaddrinfo()
- The c-ares based name resolver that uses the c-ares library for resolves.
- The Windows threaded resolver. It use:
A - gethostbyname() on plain ipv4 windows hosts
B - getaddrinfo() on ipv6-enabled windows hosts
6. License Issues 6. License Issues
@@ -751,32 +852,32 @@ FAQ
is just a brief summary for the cases we get the most questions. (Parts of is just a brief summary for the cases we get the most questions. (Parts of
this section was much enhanced by Bjorn Reese.) this section was much enhanced by Bjorn Reese.)
6.1. I have a GPL program, can I use the libcurl library? 6.1 I have a GPL program, can I use the libcurl library?
Yes! Yes!
Since libcurl may be distributed under the MIT/X derivate license, it can be Since libcurl may be distributed under the MIT/X derivate license, it can be
used together with GPL in any software. used together with GPL in any software.
6.2. I have a closed-source program, can I use the libcurl library? 6.2 I have a closed-source program, can I use the libcurl library?
Yes! Yes!
libcurl does not put any restrictions on the program that uses the library. libcurl does not put any restrictions on the program that uses the library.
6.3. I have a BSD licensed program, can I use the libcurl library? 6.3 I have a BSD licensed program, can I use the libcurl library?
Yes! Yes!
libcurl does not put any restrictions on the program that uses the library. libcurl does not put any restrictions on the program that uses the library.
6.4. I have a program that uses LGPL libraries, can I use libcurl? 6.4 I have a program that uses LGPL libraries, can I use libcurl?
Yes! Yes!
The LGPL license doesn't clash with other licenses. The LGPL license doesn't clash with other licenses.
6.5. Can I modify curl/libcurl for my program and keep the changes secret? 6.5 Can I modify curl/libcurl for my program and keep the changes secret?
Yes! Yes!
@@ -784,7 +885,7 @@ FAQ
the sources, on the condition that the copyright texts in the sources are the sources, on the condition that the copyright texts in the sources are
left intact. left intact.
6.6. Can you please change the curl/libcurl license to XXXX? 6.6 Can you please change the curl/libcurl license to XXXX?
No. No.
@@ -794,3 +895,26 @@ FAQ
we want on curl/libcurl and it does not spread to other programs or we want on curl/libcurl and it does not spread to other programs or
libraries that use it. It should be possible for everyone to use libcurl or libraries that use it. It should be possible for everyone to use libcurl or
curl in their projects, no matter what license they already have in use. curl in their projects, no matter what license they already have in use.
7. PHP/CURL Issues
7.1 What is PHP/CURL?
The module for PHP that makes it possible for PHP programs to access curl-
functions from within PHP. We often call it PHP/CURL to differentiate from
curl the command line tool and libcurl the library.
7.2 Who write PHP/CURL?
PHP/CURL is a module that comes with the regular PHP package. It depends and
uses libcurl, so you need to have libcurl installed properly first before
PHP/CURL can be used. PHP/CURL is written by Sterling Hughes.
7.3 Can I perform multiple requests using the same handle?
Yes - at least in PHP version 4.3.8 and later (this has been known to not
work in earlier versions, but the exact version when it started to work is
unknown to me).
After a transfer, you just set new options in the handle and make another
transfer. This will make libcurl to re-use the same connection if it can.

View File

@@ -6,26 +6,33 @@
FEATURES FEATURES
Misc curl tool
- full URL syntax - config file support
- multiple URLs in a single command line
- range "globbing" support: [0-13], {one,two,three}
- multiple file upload on a single command line
- custom maximum transfer rate
- redirectable stderr
libcurl supports
- full URL syntax with no length limit
- custom maximum download time - custom maximum download time
- custom least download speed acceptable - custom least download speed acceptable
- custom output result after completion - custom output result after completion
- multiple URLs
- guesses protocol from host name unless specified - guesses protocol from host name unless specified
- uses .netrc - uses .netrc
- progress bar/time specs while downloading - progress bar/time specs while downloading
- "standard" proxy environment variables support - "standard" proxy environment variables support
- config file support
- compiles on win32 (reported builds on 40+ operating systems) - compiles on win32 (reported builds on 40+ operating systems)
- redirectable stderr
- selectable network interface for outgoing traffic - selectable network interface for outgoing traffic
- IPv6 support - IPv6 support on unix and Windows
- persistant connections - persistant connections
- socks5 support - socks5 support
- supports user name + password in proxy environment variables - supports user name + password in proxy environment variables
- operations through proxy "tunnel" (using CONNECT) - operations through proxy "tunnel" (using CONNECT)
- supports transfers of large files (>2GB and >4GB) - supports large files (>2GB and >4GB) both upload/download
- replacable memory functions (malloc, free, realloc, etc)
- asynchronous name resolving (*6)
HTTP HTTP
- HTTP/1.1 compliant (optionally uses 1.0) - HTTP/1.1 compliant (optionally uses 1.0)
@@ -35,7 +42,7 @@ HTTP
- POST - POST
- multipart formpost (RFC1867-style) - multipart formpost (RFC1867-style)
- authentication: Basic, Digest, NTLM(*1), GSS-Negotiate/Negotiate(*3) and - authentication: Basic, Digest, NTLM(*1), GSS-Negotiate/Negotiate(*3) and
SPNEGO (*4) SPNEGO (*4) to server and proxy
- resume (both GET and PUT) - resume (both GET and PUT)
- follow redirects - follow redirects
- maximum amount of redirects to follow - maximum amount of redirects to follow
@@ -80,6 +87,8 @@ FTP
- via http-proxy - via http-proxy
- all operations can be tunneled through a http-proxy - all operations can be tunneled through a http-proxy
- customizable to retrieve file modification date - customizable to retrieve file modification date
- third party transfers
- no dir depth limit
FTPS (*1) FTPS (*1)
- explicit ftps:// support that use SSL on both connections - explicit ftps:// support that use SSL on both connections
@@ -103,6 +112,8 @@ GOPHER
FILE FILE
- URL support - URL support
- "uploads"
- resume
FOOTNOTES FOOTNOTES
========= =========
@@ -112,3 +123,4 @@ FOOTNOTES
*3 = requires a GSSAPI-compliant library, such as Heimdal or similar. *3 = requires a GSSAPI-compliant library, such as Heimdal or similar.
*4 = requires FBopenssl *4 = requires FBopenssl
*5 = requires a krb4 library, such as the MIT one or similar. *5 = requires a krb4 library, such as the MIT one or similar.
*6 = requires c-ares

View File

@@ -1,7 +1,7 @@
_ _ ____ _ _ _ ____ _
___| | | | _ \| | ___| | | | _ \| |
/ __| | | | |_) | | / __| | | | |_) | |
| (__| |_| | _ <| |___ | (__| |_| | _ <| |___
\___|\___/|_| \_\_____| \___|\___/|_| \_\_____|
How cURL Became Like This How cURL Became Like This
@@ -128,3 +128,14 @@ December 2003, full-fledged SSL for FTP is supported.
January 2004: curl 7.11.0 introduced large file support. January 2004: curl 7.11.0 introduced large file support.
June 2004: curl 7.12.0 introduced IDN support. 10 official web mirrors. June 2004: curl 7.12.0 introduced IDN support. 10 official web mirrors.
August 2004:
Curl and libcurl 7.12.1
Public curl release number: 82
Releases counted from the very beginning: 109
Available command line options: 96
Available curl_easy_setopt() options: 120
Number of public functions in libcurl: 36
Amount of public web site mirrors: 12
Number of known libcurl bindings: 26

View File

@@ -1,25 +0,0 @@
Steps To Perform When Building a Public Release
* "make distcheck"
* ./maketgz
then upload the 3 curl packages maketgz created
* update these files:
www/_download.html
www/_changes.html
www/_newslog.html
www/Makefile
* commit the web changes
* 'cvs commit'
* 'cvs tag'
* write the release announcement, including:
- changes / bugfixes
- other curl-related news
- contributors
* mail release-announcement to curl-announce and curl-users

View File

@@ -158,17 +158,9 @@ Win32
Make the sources in the src/ drawer be a "win32 console application" Make the sources in the src/ drawer be a "win32 console application"
project. Name it curl. project. Name it curl.
With VC++, add 'ws2_32.lib' to the link libs when you build curl!
Borland seems to do that itself magically. Of course you have to make
sure it links with the libcurl too!
For VC++ 6, there's an included Makefile.vc6 that should be possible For VC++ 6, there's an included Makefile.vc6 that should be possible
to use out-of-the-box. to use out-of-the-box.
Microsoft note: add /Zm200 to the compiler options to increase the
compiler's memory allocation limit, as the hugehelp.c won't compile
due to "too long puts string".
With SSL: With SSL:
@@ -189,28 +181,33 @@ Win32
Microsoft command line style Microsoft command line style
---------------------------- ----------------------------
Run the 'vcvars32.bat' file to get a proper environment. The
vcvars32.bat file is part of the Microsoft development environment and
you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin'
provided that you installed Visual C/C++ 6 in the default directory.
Then run 'nmake vc' in curl's root directory.
If you want to compile with zlib support, you will need to build
zlib (http://www.gzip.org/zlib/) as well. Please read the zlib
documentation on how to compile zlib. Define the ZLIB_PATH environment
variable to the location of zlib.h and zlib.lib, for example:
set ZLIB_PATH=c:\zlib-1.2.1
Then run 'nmake vc-zlib' in curl's root directory.
If you want to compile with SSL support you need the OpenSSL package.
Please read the OpenSSL documentation on how to compile and install Please read the OpenSSL documentation on how to compile and install
the OpenSSL libraries. The build process of OpenSSL generates the the OpenSSL libraries. The build process of OpenSSL generates the
libeay32.dll and ssleay32.dll files in the out32dll subdirectory in libeay32.dll and ssleay32.dll files in the out32dll subdirectory in
the OpenSSL home directory. OpenSSL static libraries (libeay32.lib, the OpenSSL home directory. OpenSSL static libraries (libeay32.lib,
ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory. ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory.
Run the 'vcvars32.bat' file to get a proper environment. The
vcvars32.bat file is part of the Microsoft development environment and
you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin'
provided that you installed Visual C/C++ 6 in the default directory.
Before running nmake define the OPENSSL_PATH environment variable with Before running nmake define the OPENSSL_PATH environment variable with
the root/base directory of OpenSSL, for example: the root/base directory of OpenSSL, for example:
set OPENSSL_PATH=c:\openssl-0.9.7a set OPENSSL_PATH=c:\openssl-0.9.7d
lib/Makefile.vc6 depends on zlib (http://www.gzip.org/zlib/) as well.
Please read the zlib documentation on how to compile zlib. Define the
ZLIB_PATH environment variable to the location of zlib.h and zlib.lib,
for example:
set ZLIB_PATH=c:\zlib-1.1.4
Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root
directory. 'nmake vc-ssl' will create a libcurl static and dynamic directory. 'nmake vc-ssl' will create a libcurl static and dynamic
@@ -219,10 +216,11 @@ Win32
version is a standalone executable not requiring any DLL at version is a standalone executable not requiring any DLL at
runtime. This make method requires that you have the static OpenSSL runtime. This make method requires that you have the static OpenSSL
libraries available in OpenSSL's out32 subdirectory. libraries available in OpenSSL's out32 subdirectory.
'nmake vc-ssl-dll' creates the libcurl dynamic library and 'nmake vc-ssl-dll' creates the libcurl dynamic library and
links curl.exe against libcurl and OpenSSL dynamically. links curl.exe against libcurl and OpenSSL dynamically.
This executable requires libcurl.dll and the OpenSSL DLLs This executable requires libcurl.dll and the OpenSSL DLLs
at runtime. at runtime.
Run 'nmake vc-ssl-zlib' to build with both ssl and zlib support.
Microsoft / Borland style Microsoft / Borland style
------------------------- -------------------------
@@ -361,12 +359,12 @@ VMS
the name can be fetched from external or internal message libraries the name can be fetched from external or internal message libraries
Errorcode - the errodes assigned by the application Errorcode - the errodes assigned by the application
Sev. - severity: Even = error, off = non error Sev. - severity: Even = error, off = non error
0 = Warning 0 = Warning
1 = Success 1 = Success
2 = Error 2 = Error
3 = Information 3 = Information
4 = Fatal 4 = Fatal
<5-7> reserved. <5-7> reserved.
This all presents itself with: This all presents itself with:
%<FACILITY>-<SeV>-<Errorname>, <Error message> %<FACILITY>-<SeV>-<Errorname>, <Error message>
@@ -379,7 +377,7 @@ VMS
This was all compiled with: This was all compiled with:
Compaq C V6.2-003 on OpenVMS Alpha V7.1-1H2 Compaq C V6.2-003 on OpenVMS Alpha V7.1-1H2
So far for porting notes as of: So far for porting notes as of:
13-jul-2001 13-jul-2001
@@ -472,6 +470,39 @@ AmigaOS
you can find a precompiled package at http://amiga.sourceforge.net/OpenSSL/ you can find a precompiled package at http://amiga.sourceforge.net/OpenSSL/
NetWare
=======
To compile curl.nlm / libcurl.nlm you need:
- either any gcc / nlmconv, or CodeWarrior 7 PDK 4 or later.
- gnu make and awk running on the platform you compile on;
native Win32 versions can be downloaded from:
http://www.gknw.com/development/prgtools/
- recent Novell LibC SDK availabable from:
http://developer.novell.com/ndk/libc.htm
- optional zlib sources (at the moment only dynamic linking with zlib.imp);
sources with NetWare Makefile can be optained from:
http://www.gknw.com/mirror/zlib/
Set a search path to your compiler, linker and tools; if you want to have
zlib support then set the environment var ZLIB_PATH pointing to your zlib
sources, on Linux make sure the var OSTYPE contains the string 'linux';
and finally type 'make netware' from the top source directory...
I found on some Linux systems (RH9) that OS detection didnt work although
a 'set | grep OSTYPE' shows the var present and set; I simply overwrote it
with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked...;
other options are currently not supported, although partly prepared.
The Ares lib builds arlready fine, and both test tools work fine at least
when build with CodeWarrior...; dont know yet why they fail when build with
gcc though; if you want to compile with Ares support then set an env var
WITH_ARES=1; I've not tested yet including libcares into curl.
Any help in testing appreciated!
Buils automatically created 4 times a day from current CVS are here:
http://www.gknw.com/mirror/curl/autobuilds/
the status of these buids can be viewed at the autobuild table:
http://curl.haxx.se/auto/
PORTS PORTS
===== =====
This is a probably incomplete list of known hardware and operating systems This is a probably incomplete list of known hardware and operating systems
@@ -527,25 +558,10 @@ PORTS
- s390 Linux - s390 Linux
- XScale/PXA250 Linux 2.4 - XScale/PXA250 Linux 2.4
OpenSSL Useful URLs
======= ===========
You'll find OpenSSL information at:
http://www.openssl.org
MingW32/Cygwin
==============
You'll find MingW32 and Cygwin information at:
http://www.mingw.org
OpenLDAP
========
You'll find OpenLDAP information at:
http://www.openldap.org
OpenSSL http://www.openssl.org
MingW http://www.mingw.org
OpenLDAP http://www.openldap.org
Zlib http://www.gzip.org/zlib/

View File

@@ -3,6 +3,21 @@ join in and help us correct one or more of these! Also be sure to check the
changelog of the current development status, as one or more of these problems changelog of the current development status, as one or more of these problems
may have been fixed since this was written! may have been fixed since this was written!
* curl version 7.12.2 fails on AIX if compiled with --enable-ares.
The workaround is to combine --enable-ares with --disable-shared
* When connecting to a SOCKS proxy, the (connect) timeout is not properly
acknowledged after the actual TCP connect (during the SOCKS "negotiate"
phase). Pointed out by Lucas. Fix: need to select() and timeout properly.
* Using configure --disable-[protocol] may cause 'make test' to fail for
tests using the disabled protocol(s).
* To get HTTP Negotiate authentication to work fine, you need to provide a
(fake) user name (this concerns both curl and the lib) because the code
wrongly only considers authentication if there's a user name provided.
Bug report #1004841. How? http://curl.haxx.se/mail/lib-2004-08/0182.html
* If you use a very large amount of file descriptors (more than FD_SETSIZE) * If you use a very large amount of file descriptors (more than FD_SETSIZE)
and then use libcurl, it might crash on its use of select() which then and then use libcurl, it might crash on its use of select() which then
stores data out of bounds. Bug report #948950. stores data out of bounds. Bug report #948950.
@@ -32,18 +47,11 @@ may have been fixed since this was written!
libcurl thinks of it as the *compressed* lenght. Some explanations are here: libcurl thinks of it as the *compressed* lenght. Some explanations are here:
http://curl.haxx.se/mail/lib-2003-06/0146.html http://curl.haxx.se/mail/lib-2003-06/0146.html
* Downloading 0 (zero) bytes files over FTP will not create a zero byte file
locally, which is because libcurl doesn't call the write callback with zero
bytes. Explained here: http://curl.haxx.se/mail/archive-2003-04/0143.html
* IPv6 support on AIX 4.3.3 doesn't work due to a missing sockaddr_storage * IPv6 support on AIX 4.3.3 doesn't work due to a missing sockaddr_storage
struct. It has been reported to work on AIX 5.1 though. struct. It has been reported to work on AIX 5.1 though.
* GOPHER transfers seem broken * GOPHER transfers seem broken
* configure --disable-http is not fully supported. All other protocols seem
to work to disable.
* If a HTTP server responds to a HEAD request and includes a body (thus * If a HTTP server responds to a HEAD request and includes a body (thus
violating the RFC2616), curl won't wait to read the response but just stop violating the RFC2616), curl won't wait to read the response but just stop
reading and return back. If a second request (let's assume a GET) is then reading and return back. If a second request (let's assume a GET) is then

View File

@@ -10,13 +10,14 @@ can lead to for end users.
I am not a lawyer and this is not legal advice! I am not a lawyer and this is not legal advice!
One common dilemma is that GPL[*]-licensed code is not allowed to be linked One common dilemma is that GPL[1]-licensed code is not allowed to be linked
with code licensed under the Original BSD license (with the announcement with code licensed under the Original BSD license (with the announcement
clause, unless there's a specified exception in the GPL-licensed module). You clause, unless there's a specified exception in the GPL-licensed module). You
may still build your own copies that use them all, but distributing them as may still build your own copies that use them all, but distributing them as
binaries would be to violate the GPL license. This particular problem was binaries would be to violate the GPL license - unless you accompany your
addressed when the Modified BSD license was created, which does not have the license with an exception[2]. This particular problem was addressed when the
annoncement clause that collides with GPL. Modified BSD license was created, which does not have the annoncement clause
that collides with GPL.
libcurl http://curl.haxx.se/docs/copyright.html libcurl http://curl.haxx.se/docs/copyright.html
@@ -80,4 +81,6 @@ OpenLDAP http://www.openldap.org/software/release/license.html
linked with libcurl in an app. linked with libcurl in an app.
[*] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html [1] = GPL - GNU General Public License: http://www.gnu.org/licenses/gpl.html
[2] = http://www.fsf.org/licenses/gpl-faq.html#GPLIncompatibleLibs details on
how to write such an exception to the GPL

View File

@@ -580,11 +580,11 @@ NETWORK INTERFACE
Get a web page from a server using a specified port for the interface: Get a web page from a server using a specified port for the interface:
curl --interface eth0:1 http://www.netscape.com/ curl --interface eth0:1 http://www.netscape.com/
or or
curl --interface 192.168.1.10 http://www.netscape.com/ curl --interface 192.168.1.10 http://www.netscape.com/
HTTPS HTTPS

View File

@@ -17,7 +17,7 @@ CLEANFILES = $(GENHTMLPAGES) $(PDFPAGES)
EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS \ EXTRA_DIST = MANUAL BUGS CONTRIBUTE FAQ FEATURES INTERNALS SSLCERTS \
README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS \ README.win32 RESOURCES TODO TheArtOfHttpScripting THANKS VERSIONS \
KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL \ KNOWN_BUGS BINDINGS $(man_MANS) $(HTMLPAGES) HISTORY INSTALL \
$(PDFPAGES) LICENSE-MIXING $(PDFPAGES) LICENSE-MIXING README.netware
MAN2HTML= roffit < $< >$@ MAN2HTML= roffit < $< >$@

27
docs/README.netware Normal file
View File

@@ -0,0 +1,27 @@
_ _ ____ _
___| | | | _ \| |
/ __| | | | |_) | |
| (__| |_| | _ <| |___
\___|\___/|_| \_\_____|
README.netware
Read the README file first.
Curl has been successfully compiled with gcc / nlmconv on different flavours
of Linux as well as with the official Metrowerks CodeWarrior compiler.
While not being the main development target, a continously growing share of
curl users are NetWare-based, specially also consuming the lib from PHP.
The unix-style man pages are tricky to read on windows, so therefore are all
those pages converted to HTML as well as pdf, and included in the release
archives.
The main curl.1 man page is also "built-in" in the command line tool. Use a
command line similar to this in order to extract a separate text file:
curl -M >manual.txt
Read the INSTALL file for instructions how to compile curl self.

View File

@@ -1,32 +1,30 @@
Peer SSL Certificate Verification Peer SSL Certificate Verification
================================= =================================
Since version 7.10, libcurl performs peer SSL certificate verification by libcurl performs peer SSL certificate verification by default. This is done by
default. This is done by installing a default CA cert bundle on 'make install' installing a default CA cert bundle on 'make install' (or similar), that CA
(or similar), that CA bundle package is used by default on operations against bundle package is used by default on operations against SSL servers.
SSL servers.
Alas, if you communicate with HTTPS servers using certificates that are signed If you communicate with HTTPS or FTPS servers using certificates that are
by CAs present in the bundle, you will not notice any changed behavior and you signed by CAs present in the bundle, you can be sure that the remote server
will seamlessly get a higher security level on your SSL connections since you really is the one it claims to be.
can be sure that the remote server really is the one it claims to be.
If the remote server uses a self-signed certificate, if you don't install If the remote server uses a self-signed certificate, if you don't install
curl's CA cert bundle, if the server uses a certificate signed by a CA that curl's CA cert bundle, if the server uses a certificate signed by a CA that
isn't included in the bundle or if the remoste host is an imposter isn't included in the bundle or if the remote host is an impostor
impersonating your favourite site, and you want to transfer files from this impersonating your favorite site, and you want to transfer files from this
server, do one of the following: server, do one of the following:
1. Tell libcurl to *not* verify the peer. With libcurl you disable with with 1. Tell libcurl to *not* verify the peer. With libcurl you disable with with
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, FALSE); curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, FALSE);
With the curl command tool, you disable this with -k/--insecure. With the curl command line tool, you disable this with -k/--insecure.
2. Get a CA certificate that can verify the remote server and use the proper 2. Get a CA certificate that can verify the remote server and use the proper
option to point out this CA cert for verification when connecting. For option to point out this CA cert for verification when connecting. For
libcurl hackers: curl_easy_setopt(curl, CURLOPT_CAPATH, capath); libcurl hackers: curl_easy_setopt(curl, CURLOPT_CAPATH, capath);
With the curl command tool: --cacert [file] With the curl command line tool: --cacert [file]
3. Add the CA cert for your server to the existing default CA cert bundle. 3. Add the CA cert for your server to the existing default CA cert bundle.
The default path of the CA bundle installed with the curl package is: The default path of the CA bundle installed with the curl package is:
@@ -34,15 +32,61 @@ server, do one of the following:
configure with the --with-ca-bundle option pointing out the path of your configure with the --with-ca-bundle option pointing out the path of your
choice. choice.
Neglecting to use one of the above menthods when dealing with a server using a To do this, you need to get the CA cert for your server in PEM format and
certficate that isn't signed by one of the certficates in the installed CA then append that to your CA cert bundle.
If you use Internet Explorer, this is one way to get extract the CA cert
for a particular server:
o View the certificate by double-clicking the padlock
o Find out where the CA certificate is kept (Certificate>
Authority Information Access>URL)
o Get a copy of the crt file using curl
o Convert it from crt to PEM using the openssl tool:
openssl x509 -inform DES -in yourdownloaded.crt \
-out outcert.pem -text
o Append the 'outcert.pem' to the CA cert bundle or use it stand-alone
as described below.
(Thanks to Frankie V for this description)
If you use the 'openssl' tool, this is one way to get extract the CA cert
for a particular server:
o openssl s_client -connect xxxxx.com:443 |tee logfile
o type "QUIT", followed by the "ENTER" key
o The certificate will have "BEGIN CERTIFICATE" and "END CERTIFICATE"
markers.
o If you want to see the data in the certificate, you can do: "openssl
x509 -inform PEM -in certfile -text -out certdata" where certfile is
the cert you extracted from logfile. Look in certdata.
o If you want to trust the certificate, you can append it to your
cert_bundle or use it stand-alone as described. Just remember that the
security is no better than the way you obtained the certificate.
(Thanks to Doug Kaufman for this description)
4. If you're using the curl command line tool, you can specify your own CA
cert path by setting the environment variable CURL_CA_BUNDLE to the path
of your choice.
If you're using the curl command line tool on Windows, curl will search
for a CA cert file named "curl-ca-bundle.crt" in these directories and in
this order:
1. application's directory
2. current working directory
3. Windows System directory (e.g. C:\windows\system32)
4. Windows Directory (e.g. C:\windows)
5. all directories along %PATH%
5. Get a better/different/newer CA cert bundle! One option is to extract the
one a recent Mozilla browser uses, by following the instruction found
here:
http://curl.haxx.se/docs/caextract.html
Neglecting to use one of the above methods when dealing with a server using a
certificate that isn't signed by one of the certificates in the installed CA
cert bundle, will cause SSL to report an error ("certificate verify failed") cert bundle, will cause SSL to report an error ("certificate verify failed")
during the handshake and SSL will then refuse further communication with that during the handshake and SSL will then refuse further communication with that
server. server.
This procedure has been deemed The Right Thing even though it adds this extra
trouble for some users, since it adds security to a majority of the SSL
connections that previously weren't really secure. It turned out many people
were using previous versions of curl/libcurl without realizing the need for
the CA cert options to get truly secure SSL connections.

View File

@@ -33,12 +33,8 @@ TODO
return informational stuff as errors, consider a new info returned by return informational stuff as errors, consider a new info returned by
curl_easy_getinfo() #845941 curl_easy_getinfo() #845941
* Option to set the SO_KEEPALIVE socket option to make libcurl notice and * Use 'struct lifreq' and SIOCGLIFADDR instead of 'struct ifreq' and
disconnect very long time idle connections. SIOCGIFADDR on newer Solaris versions as they claim the latter is obsolete.
* When posting multipart forms, we should _not_ create the whole data chunk
in memory before the upload starts but do it in a "streaming" manner to
allow uploads that are way larger than the amount of system memory.
LIBCURL - multi interface LIBCURL - multi interface
@@ -61,6 +57,18 @@ TODO
FTP FTP
* "PASV IP override" - When an FTPS host is behind a NAT firewall, passive
mode fails. The PASV response from the host ["227 PASV Entering passive
mode (_ip_address_, _port_)."] contains the private network IP address of
the host, which since it is encrypted, cannot be modified by the firewall
to the public IP address. What is needed is a cURL option to override the
IP address passed by the host "227 PASV" response. Requested by Ed
Hingsbergen
* Support GSS/Kerberos 5 for ftp file transfer. This will allow user
authentication and file encryption. Possible libraries and example clients
are available from MIT or Heimdal. Requsted by Markus Moeller.
* Optimize the way libcurl uses CWD on each new request over a persistent * Optimize the way libcurl uses CWD on each new request over a persistent
connection (on FTP) even if it doesn't have to. connection (on FTP) even if it doesn't have to.
@@ -89,9 +97,6 @@ TODO
HTTP HTTP
* GSS-Negotiate support for HTTP proxies. They only work on direct
connections to the server.
* Pipelining. Sending multiple requests before the previous one(s) are done. * Pipelining. Sending multiple requests before the previous one(s) are done.
This could possibly be implemented using the multi interface to queue This could possibly be implemented using the multi interface to queue
requests and the response data. requests and the response data.
@@ -114,21 +119,19 @@ TODO
* Evaluate/apply Gertjan van Wingerde's SSL patches: * Evaluate/apply Gertjan van Wingerde's SSL patches:
http://curl.haxx.se/mail/lib-2004-03/0087.html http://curl.haxx.se/mail/lib-2004-03/0087.html
* If you really want to improve the SSL situation, you should probably have a * "Look at SSL cafile - quick traces look to me like these are done on every
look at SSL cafile loading as well - quick traces look to me like these are request as well, when they should only be necessary once per ssl context
done on every request as well, when they should only be necessary once per (or once per handle)". The major improvement we can rather easily do is to
ssl context (or once per handle). Even better would be to support the SSL make sure we don't create and kill a new SSL "context" for every request,
CAdir option - instead of loading all of the root CA certs for every but instead make one for every connection and re-use that SSL context in
request, this option allows you to only read the CA chain that is actually the same style connections are re-used. It will make us use slightly more
required (into the cache)... memory but it will libcurl do less creations and deletions of SSL contexts.
* Add an interface to libcurl that enables "session IDs" to get * Add an interface to libcurl that enables "session IDs" to get
exported/imported. Cris Bailiff said: "OpenSSL has functions which can exported/imported. Cris Bailiff said: "OpenSSL has functions which can
serialise the current SSL state to a buffer of your choice, and serialise the current SSL state to a buffer of your choice, and
recover/reset the state from such a buffer at a later date - this is used recover/reset the state from such a buffer at a later date - this is used
by mod_ssl for apache to implement and SSL session ID cache". This whole by mod_ssl for apache to implement and SSL session ID cache".
idea might become moot if we enable the 'data sharing' as mentioned in the
LIBCURL label above.
* OpenSSL supports a callback for customised verification of the peer * OpenSSL supports a callback for customised verification of the peer
certificate, but this doesn't seem to be exposed in the libcurl APIs. Could certificate, but this doesn't seem to be exposed in the libcurl APIs. Could
@@ -137,8 +140,12 @@ TODO
* Make curl's SSL layer option capable of using other free SSL libraries. * Make curl's SSL layer option capable of using other free SSL libraries.
Such as the Mozilla Security Services Such as the Mozilla Security Services
(http://www.mozilla.org/projects/security/pki/nss/) and GNUTLS (http://www.mozilla.org/projects/security/pki/nss/) and GnuTLS
(http://gnutls.hellug.gr/) (http://www.gnu.org/software/gnutls/) This subject has been brought up
again recently since GPL-licensed applications that link with libcurl MAY
NOT distribute binaries that use OpenSSL without adding an exception clause
to the GPL license. See the LICENSE-MIXING document and this:
http://www.gnome.org/~markmc/openssl-and-the-gpl.html
LDAP LDAP
@@ -148,6 +155,17 @@ TODO
CLIENT CLIENT
* "curl --sync http://example.com/feed[1-100].rss" or
"curl --sync http://example.net/{index,calendar,history}.html"
Downloads a range or set of URLs using the remote name, but only if the
remote file is newer than the local file. A Last-Modified HTTP date header
should also be used to set the mod date on the downloaded file.
(idea from "Brianiac")
* Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'.
Requested by Dane Jensen and others. This is easily scripted though.
* Add an option that prevents cURL from overwiting existing local files. When * Add an option that prevents cURL from overwiting existing local files. When
used, and there already is an existing file with the target file name used, and there already is an existing file with the target file name
(either -O or -o), a number should be appended (and increased if already (either -O or -o), a number should be appended (and increased if already
@@ -182,14 +200,14 @@ TODO
http://curl.haxx.se/mail/archive-2003-11/0091.html (Kevin Roth suggested) http://curl.haxx.se/mail/archive-2003-11/0091.html (Kevin Roth suggested)
* Provide a way to make options bound to a specific URL among several on the * Provide a way to make options bound to a specific URL among several on the
command line. Possibly by adding a new option that separates options command line. Possibly by letting ':' separate options between URLs,
between URLs, similar to this: similar to this:
curl --data foo --url url.com --optionseparator curl --data foo --url url.com : \
--url url2.com --optionseparator \ --url url2.com : \
--url url3.com --data foo3 --url url3.com --data foo3
(--optionseparator used to show my point, it would need a better name) (More details: http://curl.haxx.se/mail/archive-2004-07/0133.html)
The example would do a POST-GET-POST combination on a single command line. The example would do a POST-GET-POST combination on a single command line.
@@ -222,6 +240,8 @@ TODO
* remove obsolete defines from curl/curl.h * remove obsolete defines from curl/curl.h
* make several functions use size_t instead of int in their APIs
* remove the following functions from the public API: * remove the following functions from the public API:
curl_getenv curl_getenv
curl_mprintf (and variations) curl_mprintf (and variations)

View File

@@ -370,11 +370,11 @@ Version: 0.6
In the HTTPS world, you use certificates to validate that you are the one In the HTTPS world, you use certificates to validate that you are the one
you you claim to be, as an addition to normal passwords. Curl supports you you claim to be, as an addition to normal passwords. Curl supports
client-side certificates. All certificates are locked with a PIN-code, why client-side certificates. All certificates are locked with a pass phrase,
you need to enter the unlock-code before the certificate can be used by which you need to enter before the certificate can be used by curl. The pass
curl. The PIN-code can be specified on the command line or if not, entered phrase can be specified on the command line or if not, entered interactively
interactively when curl queries for it. Use a certificate with curl on a when curl queries for it. Use a certificate with curl on a HTTPS server
HTTPS server like: like:
curl -E mycert.pem https://that.secure.server.com curl -E mycert.pem https://that.secure.server.com

View File

@@ -335,10 +335,10 @@ If this option is used twice, the second will again disable silent failure.
.IP "--ftp-ssl" .IP "--ftp-ssl"
(FTP) Make the FTP connection switch to use SSL/TLS. (Added in 7.11.0) (FTP) Make the FTP connection switch to use SSL/TLS. (Added in 7.11.0)
If this option is used twice, the second will again disable silent failure. If this option is used twice, the second will again disable this.
.IP "-F/--form <name=content>" .IP "-F/--form <name=content>"
(HTTP) This lets curl emulate a filled in form in which a user has pressed the (HTTP) This lets curl emulate a filled in form in which a user has pressed the
submit button. This causes curl to POST data using the content-type submit button. This causes curl to POST data using the Content-Type
multipart/form-data according to RFC1867. This enables uploading of binary multipart/form-data according to RFC1867. This enables uploading of binary
files etc. To force the 'content' part to be be a file, prefix the file name files etc. To force the 'content' part to be be a file, prefix the file name
with an @ sign. To just get the content part from a file, prefix the file name with an @ sign. To just get the content part from a file, prefix the file name
@@ -355,11 +355,15 @@ input:
To read the file's content from stdin insted of a file, use - where the file To read the file's content from stdin insted of a file, use - where the file
name should've been. This goes for both @ and < constructs. name should've been. This goes for both @ and < constructs.
You can also tell curl what Content-Type to use for the file upload part, by You can also tell curl what Content-Type to use by using 'type=', in a manner
using 'type=', in a manner similar to: similar to:
\fBcurl\fP -F "web=@index.html;type=text/html" url.com \fBcurl\fP -F "web=@index.html;type=text/html" url.com
or
\fBcurl\fP -F "name=daniel;type=text/foo" url.com
See further examples and details in the MANUAL. See further examples and details in the MANUAL.
This option can be used multiple times. This option can be used multiple times.
@@ -662,13 +666,12 @@ instead of PORT by using \fI--disable-eprt\fP. EPRT is really PORT++.
If used as the first parameter on the command line, the \fI$HOME/.curlrc\fP If used as the first parameter on the command line, the \fI$HOME/.curlrc\fP
file will not be read and used as a config file. file will not be read and used as a config file.
.IP "-Q/--quote <comand>" .IP "-Q/--quote <comand>"
(FTP) Send an arbitrary command to the remote FTP server, by using the QUOTE (FTP) Send an arbitrary command to the remote FTP server. Quote commands are
command of the server. Not all servers support this command, and the set of sent BEFORE the transfer is taking place. To make commands take place after a
QUOTE commands are server specific! Quote commands are sent BEFORE the successful transfer, prefix them with a dash '-'. You may specify any amount
transfer is taking place. To make commands take place after a successful of commands to be run before and after the transfer. If the server returns
transfer, prefix them with a dash '-'. You may specify any amount of commands failure for one of the commands, the entire operation will be aborted. You
to be run before and after the transfer. If the server returns failure for one must send syntactically correct FTP commands as RFC959 defines.
of the commands, the entire operation will be aborted.
This option can be used multiple times. This option can be used multiple times.
.IP "--random-file <file>" .IP "--random-file <file>"
@@ -973,22 +976,18 @@ not set.
If this option is used several times, the last one will be used. If this option is used several times, the last one will be used.
.IP "-z/--time-cond <date expression>" .IP "-z/--time-cond <date expression>"
(HTTP) (HTTP) Request 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
date, or one that has been modified before that time. The date expression can date, or one that has been modified before that time. The date expression can
be all sorts of date strings or if it doesn't match any internal ones, it be all sorts of date strings or if it doesn't match any internal ones, it
tries to get the time from a given file name instead! See the tries to get the time from a given file name instead! See the
.BR "GNU date(1)" \fIcurl_getdate(3)\fP man pages for date expression details.
or
.BR "curl_getdate(3)"
man pages for date expression details.
Start the date expression with a dash (-) to make it request for a document Start the date expression with a dash (-) to make it request for a document
that is older than the given date/time, default is a document that is newer that is older than the given date/time, default is a document that is newer
than the specified date/time. than the specified date/time.
If this option is used several times, the last one will be used. If this option is used several times, the last one will be used.
.IP "-Z/--max-redirs <num>" .IP "--max-redirs <num>"
Set maximum number of redirection-followings allowed. If \fI-L/--location\fP Set maximum number of redirection-followings allowed. If \fI-L/--location\fP
is used, this option can be used to prevent curl from following redirections is used, this option can be used to prevent curl from following redirections
\&"in absurdum". \&"in absurdum".

View File

@@ -9,7 +9,7 @@ EXTRA_DIST = README curlgtk.c sepheaders.c simple.c postit2.c \
ftpupload.c httpput.c simplessl.c ftpgetresp.c http-post.c \ ftpupload.c httpput.c simplessl.c ftpgetresp.c http-post.c \
post-callback.c multi-app.c multi-double.c multi-single.c \ post-callback.c multi-app.c multi-double.c multi-single.c \
multi-post.c fopen.c simplepost.c makefile.dj curlx.c https.c \ multi-post.c fopen.c simplepost.c makefile.dj curlx.c https.c \
multi-debugcallback.c fileupload.c getinfo.c ftp3rdparty.c multi-debugcallback.c fileupload.c getinfo.c ftp3rdparty.c debug.c
all: all:
@echo "done" @echo "done"

View File

@@ -1,4 +1,4 @@
/* /*
curlx.c Authors: Peter Sylvester, Jean-Paul Merlin curlx.c Authors: Peter Sylvester, Jean-Paul Merlin
This is a little program to demonstrate the usage of This is a little program to demonstrate the usage of
@@ -6,7 +6,7 @@
- an ssl initialisation callback setting a user key and trustbases - an ssl initialisation callback setting a user key and trustbases
coming from a pkcs12 file coming from a pkcs12 file
- using an ssl application callback to find a URI in the - using an ssl application callback to find a URI in the
certificate presented during ssl session establishment. certificate presented during ssl session establishment.
*/ */
@@ -20,13 +20,13 @@
* *
* 1. Redistributions of source code must retain the above copyright * 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions, the following disclaimer, * notice, this list of conditions, the following disclaimer,
* and the original OpenSSL and SSLeay Licences below. * and the original OpenSSL and SSLeay Licences below.
* *
* 2. Redistributions in binary form must reproduce the above copyright * 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions, the following disclaimer * notice, this list of conditions, the following disclaimer
* and the original OpenSSL and SSLeay Licences below in * and the original OpenSSL and SSLeay Licences below in
* the documentation and/or other materials provided with the * the documentation and/or other materials provided with the
* distribution. * distribution.
* *
* 3. All advertising materials mentioning features or use of this * 3. All advertising materials mentioning features or use of this
* software must display the following acknowledgments: * software must display the following acknowledgments:
@@ -100,7 +100,7 @@ static char *curlx_usage[]={
" -envpass arg - environement variable which content the tia private key password", " -envpass arg - environement variable which content the tia private key password",
" -out arg - output file (response)- default stdout", " -out arg - output file (response)- default stdout",
" -in arg - input file (request)- default stdin", " -in arg - input file (request)- default stdin",
" -connect arg - URL of the server for the connection ex: www.openevidenve.org", " -connect arg - URL of the server for the connection ex: www.openevidenve.org",
" -mimetype arg - MIME type for data in ex : application/timestamp-query or application/dvcs -default application/timestamp-query", " -mimetype arg - MIME type for data in ex : application/timestamp-query or application/dvcs -default application/timestamp-query",
" -acceptmime arg - MIME type acceptable for the response ex : application/timestamp-response or application/dvcs -default none", " -acceptmime arg - MIME type acceptable for the response ex : application/timestamp-response or application/dvcs -default none",
" -accesstype arg - an Object identifier in an AIA/SIA method, e.g. AD_DVCS or ad_timestamping", " -accesstype arg - an Object identifier in an AIA/SIA method, e.g. AD_DVCS or ad_timestamping",
@@ -109,7 +109,7 @@ NULL
/* /*
./curlx -p12 psy.p12 -envpass XX -in request -verbose -accesstype AD_DVCS ./curlx -p12 psy.p12 -envpass XX -in request -verbose -accesstype AD_DVCS
-mimetype application/dvcs -acceptmime application/dvcs -out response -mimetype application/dvcs -acceptmime application/dvcs -out response
*/ */
@@ -134,33 +134,33 @@ typedef struct sslctxparm_st {
static char *i2s_ASN1_IA5STRING( ASN1_IA5STRING *ia5) static char *i2s_ASN1_IA5STRING( ASN1_IA5STRING *ia5)
{ {
char *tmp; char *tmp;
if(!ia5 || !ia5->length) return NULL; if(!ia5 || !ia5->length) return NULL;
tmp = OPENSSL_malloc(ia5->length + 1); tmp = OPENSSL_malloc(ia5->length + 1);
memcpy(tmp, ia5->data, ia5->length); memcpy(tmp, ia5->data, ia5->length);
tmp[ia5->length] = 0; tmp[ia5->length] = 0;
return tmp; return tmp;
} }
/* A conveniance routine to get an access URI. */ /* A conveniance routine to get an access URI. */
static unsigned char *my_get_ext(X509 * cert, const int type, int extensiontype) { static unsigned char *my_get_ext(X509 * cert, const int type, int extensiontype) {
int i; int i;
STACK_OF(ACCESS_DESCRIPTION) * accessinfo ; STACK_OF(ACCESS_DESCRIPTION) * accessinfo ;
accessinfo = X509_get_ext_d2i(cert, extensiontype, NULL, NULL) ; accessinfo = X509_get_ext_d2i(cert, extensiontype, NULL, NULL) ;
if (!sk_ACCESS_DESCRIPTION_num(accessinfo)) return NULL; if (!sk_ACCESS_DESCRIPTION_num(accessinfo)) return NULL;
for (i = 0; i < sk_ACCESS_DESCRIPTION_num(accessinfo); i++) { for (i = 0; i < sk_ACCESS_DESCRIPTION_num(accessinfo); i++) {
ACCESS_DESCRIPTION * ad = sk_ACCESS_DESCRIPTION_value(accessinfo, i); ACCESS_DESCRIPTION * ad = sk_ACCESS_DESCRIPTION_value(accessinfo, i);
if (OBJ_obj2nid(ad->method) == type) { if (OBJ_obj2nid(ad->method) == type) {
if (ad->location->type == GEN_URI) { if (ad->location->type == GEN_URI) {
return i2s_ASN1_IA5STRING(ad->location->d.ia5); return i2s_ASN1_IA5STRING(ad->location->d.ia5);
} }
return NULL; return NULL;
} }
} }
return NULL; return NULL;
} }
/* This is an application verification call back, it does not /* This is an application verification call back, it does not
@@ -170,192 +170,192 @@ static unsigned char *my_get_ext(X509 * cert, const int type, int extensiontype)
*/ */
static int ssl_app_verify_callback(X509_STORE_CTX *ctx, void *arg) { static int ssl_app_verify_callback(X509_STORE_CTX *ctx, void *arg) {
sslctxparm * p = (sslctxparm *) arg; sslctxparm * p = (sslctxparm *) arg;
int ok; int ok;
if (p->verbose > 2) BIO_printf(p->errorbio,"entering ssl_app_verify_callback\n"); if (p->verbose > 2) BIO_printf(p->errorbio,"entering ssl_app_verify_callback\n");
if ((ok= X509_verify_cert(ctx)) && ctx->cert) { if ((ok= X509_verify_cert(ctx)) && ctx->cert) {
unsigned char * accessinfo ; unsigned char * accessinfo ;
if (p->verbose > 1) X509_print_ex(p->errorbio,ctx->cert,0,0); if (p->verbose > 1) X509_print_ex(p->errorbio,ctx->cert,0,0);
if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_sinfo_access)) { if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_sinfo_access)) {
if (p->verbose) BIO_printf(p->errorbio,"Setting URL from SIA to: %s\n",accessinfo); if (p->verbose) BIO_printf(p->errorbio,"Setting URL from SIA to: %s\n",accessinfo);
curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo); curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo);
} else if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_info_access)) { } else if (accessinfo = my_get_ext(ctx->cert,p->accesstype ,NID_info_access)) {
if (p->verbose) BIO_printf(p->errorbio,"Setting URL from AIA to: %s\n",accessinfo); if (p->verbose) BIO_printf(p->errorbio,"Setting URL from AIA to: %s\n",accessinfo);
curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo); curl_easy_setopt(p->curl, CURLOPT_URL,accessinfo);
} }
} }
if (p->verbose > 2) BIO_printf(p->errorbio,"leaving ssl_app_verify_callback with %d\n",ok); if (p->verbose > 2) BIO_printf(p->errorbio,"leaving ssl_app_verify_callback with %d\n",ok);
return(ok); return(ok);
} }
/* This is an example of an curl SSL initialisation call back. The callback sets: /* This is an example of an curl SSL initialisation call back. The callback sets:
- a private key and certificate - a private key and certificate
- a trusted ca certificate - a trusted ca certificate
- a preferred cipherlist - a preferred cipherlist
- an application verification callback (the function above) - an application verification callback (the function above)
*/ */
static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) { static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) {
sslctxparm * p = (sslctxparm *) parm;
SSL_CTX * ctx = (SSL_CTX *) sslctx ;
if (!SSL_CTX_use_certificate(ctx,p->usercert)) { sslctxparm * p = (sslctxparm *) parm;
BIO_printf(p->errorbio, "SSL_CTX_use_certificate problem\n"); goto err; SSL_CTX * ctx = (SSL_CTX *) sslctx ;
}
if (!SSL_CTX_use_PrivateKey(ctx,p->pkey)) {
BIO_printf(p->errorbio, "SSL_CTX_use_PrivateKey\n"); goto err;
}
if (!SSL_CTX_check_private_key(ctx)) {
BIO_printf(p->errorbio, "SSL_CTX_check_private_key\n"); goto err;
}
SSL_CTX_set_quiet_shutdown(ctx,1);
SSL_CTX_set_cipher_list(ctx,"RC4-MD5");
SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca,sk_X509_num(p->ca)-1)); if (!SSL_CTX_use_certificate(ctx,p->usercert)) {
BIO_printf(p->errorbio, "SSL_CTX_use_certificate problem\n"); goto err;
}
if (!SSL_CTX_use_PrivateKey(ctx,p->pkey)) {
BIO_printf(p->errorbio, "SSL_CTX_use_PrivateKey\n"); goto err;
}
SSL_CTX_set_verify_depth(ctx,2); if (!SSL_CTX_check_private_key(ctx)) {
BIO_printf(p->errorbio, "SSL_CTX_check_private_key\n"); goto err;
SSL_CTX_set_verify(ctx,SSL_VERIFY_PEER,NULL); }
SSL_CTX_set_cert_verify_callback(ctx, ssl_app_verify_callback, parm); SSL_CTX_set_quiet_shutdown(ctx,1);
SSL_CTX_set_cipher_list(ctx,"RC4-MD5");
SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca,sk_X509_num(p->ca)-1));
return CURLE_OK ;
err: SSL_CTX_set_verify_depth(ctx,2);
ERR_print_errors(p->errorbio);
return CURLE_SSL_CERTPROBLEM; SSL_CTX_set_verify(ctx,SSL_VERIFY_PEER,NULL);
SSL_CTX_set_cert_verify_callback(ctx, ssl_app_verify_callback, parm);
return CURLE_OK ;
err:
ERR_print_errors(p->errorbio);
return CURLE_SSL_CERTPROBLEM;
} }
int main(int argc, char **argv) { int main(int argc, char **argv) {
BIO* in=NULL; BIO* in=NULL;
BIO* out=NULL; BIO* out=NULL;
char * outfile = NULL;
char * infile = NULL ;
int tabLength=100; char * outfile = NULL;
char *binaryptr; char * infile = NULL ;
char* mimetype;
char* mimetypeaccept=NULL;
char* contenttype;
char** pp;
unsigned char* hostporturl = NULL;
binaryptr=(char*)malloc(tabLength);
BIO * p12bio ;
char **args = argv + 1;
unsigned char * serverurl;
sslctxparm p;
char *response;
p.verbose = 0;
CURLcode res; int tabLength=100;
struct curl_slist * headers=NULL; char *binaryptr;
char* mimetype;
char* mimetypeaccept=NULL;
char* contenttype;
char** pp;
unsigned char* hostporturl = NULL;
binaryptr=(char*)malloc(tabLength);
BIO * p12bio ;
char **args = argv + 1;
unsigned char * serverurl;
sslctxparm p;
char *response;
p.verbose = 0;
p.errorbio = BIO_new_fp (stderr, BIO_NOCLOSE); CURLcode res;
struct curl_slist * headers=NULL;
p.errorbio = BIO_new_fp (stderr, BIO_NOCLOSE);
curl_global_init(CURL_GLOBAL_DEFAULT);
curl_global_init(CURL_GLOBAL_DEFAULT);
/* we need some more for the P12 decoding */ /* we need some more for the P12 decoding */
OpenSSL_add_all_ciphers(); OpenSSL_add_all_ciphers();
OpenSSL_add_all_digests(); OpenSSL_add_all_digests();
ERR_load_crypto_strings(); ERR_load_crypto_strings();
int badarg=0; int badarg=0;
while (*args && *args[0] == '-') { while (*args && *args[0] == '-') {
if (!strcmp (*args, "-in")) { if (!strcmp (*args, "-in")) {
if (args[1]) { if (args[1]) {
infile=*(++args); infile=*(++args);
} else badarg=1; } else badarg=1;
} else if (!strcmp (*args, "-out")) { } else if (!strcmp (*args, "-out")) {
if (args[1]) { if (args[1]) {
outfile=*(++args); outfile=*(++args);
} else badarg=1; } else badarg=1;
} else if (!strcmp (*args, "-p12")) { } else if (!strcmp (*args, "-p12")) {
if (args[1]) { if (args[1]) {
p.p12file = *(++args); p.p12file = *(++args);
} else badarg=1; } else badarg=1;
} else if (strcmp(*args,"-envpass") == 0) { } else if (strcmp(*args,"-envpass") == 0) {
if (args[1]) { if (args[1]) {
p.pst = getenv(*(++args)); p.pst = getenv(*(++args));
} else badarg=1; } else badarg=1;
} else if (strcmp(*args,"-connect") == 0) { } else if (strcmp(*args,"-connect") == 0) {
if (args[1]) { if (args[1]) {
hostporturl = *(++args); hostporturl = *(++args);
} else badarg=1; } else badarg=1;
} else if (strcmp(*args,"-mimetype") == 0) { } else if (strcmp(*args,"-mimetype") == 0) {
if (args[1]) { if (args[1]) {
mimetype = *(++args); mimetype = *(++args);
} else badarg=1; } else badarg=1;
} else if (strcmp(*args,"-acceptmime") == 0) { } else if (strcmp(*args,"-acceptmime") == 0) {
if (args[1]) { if (args[1]) {
mimetypeaccept = *(++args); mimetypeaccept = *(++args);
} else badarg=1; } else badarg=1;
} else if (strcmp(*args,"-accesstype") == 0) { } else if (strcmp(*args,"-accesstype") == 0) {
if (args[1]) { if (args[1]) {
if ((p.accesstype = OBJ_obj2nid(OBJ_txt2obj(*++args,0))) == 0) badarg=1; if ((p.accesstype = OBJ_obj2nid(OBJ_txt2obj(*++args,0))) == 0) badarg=1;
} else badarg=1; } else badarg=1;
} else if (strcmp(*args,"-verbose") == 0) { } else if (strcmp(*args,"-verbose") == 0) {
p.verbose++; p.verbose++;
} else badarg=1; } else badarg=1;
args++; args++;
} }
if (mimetype==NULL || mimetypeaccept == NULL) badarg = 1; if (mimetype==NULL || mimetypeaccept == NULL) badarg = 1;
if (badarg) { if (badarg) {
for (pp=curlx_usage; (*pp != NULL); pp++) for (pp=curlx_usage; (*pp != NULL); pp++)
BIO_printf(p.errorbio,"%s\n",*pp); BIO_printf(p.errorbio,"%s\n",*pp);
BIO_printf(p.errorbio,"\n"); BIO_printf(p.errorbio,"\n");
goto err; goto err;
} }
/* set input */ /* set input */
if ((in=BIO_new(BIO_s_file())) == NULL) { if ((in=BIO_new(BIO_s_file())) == NULL) {
BIO_printf(p.errorbio, "Error setting input bio\n"); BIO_printf(p.errorbio, "Error setting input bio\n");
goto err; goto err;
} else if (infile == NULL) } else if (infile == NULL)
BIO_set_fp(in,stdin,BIO_NOCLOSE|BIO_FP_TEXT); BIO_set_fp(in,stdin,BIO_NOCLOSE|BIO_FP_TEXT);
else if (BIO_read_filename(in,infile) <= 0) { else if (BIO_read_filename(in,infile) <= 0) {
BIO_printf(p.errorbio, "Error opening input file %s\n", infile); BIO_printf(p.errorbio, "Error opening input file %s\n", infile);
BIO_free(in); BIO_free(in);
goto err; goto err;
} }
/* set output */ /* set output */
if ((out=BIO_new(BIO_s_file())) == NULL) { if ((out=BIO_new(BIO_s_file())) == NULL) {
BIO_printf(p.errorbio, "Error setting output bio.\n"); BIO_printf(p.errorbio, "Error setting output bio.\n");
goto err; goto err;
} else if (outfile == NULL) } else if (outfile == NULL)
BIO_set_fp(out,stdout,BIO_NOCLOSE|BIO_FP_TEXT); BIO_set_fp(out,stdout,BIO_NOCLOSE|BIO_FP_TEXT);
else if (BIO_write_filename(out,outfile) <= 0) { else if (BIO_write_filename(out,outfile) <= 0) {
BIO_printf(p.errorbio, "Error opening output file %s\n", outfile); BIO_printf(p.errorbio, "Error opening output file %s\n", outfile);
BIO_free(out); BIO_free(out);
goto err; goto err;
} }
p.errorbio = BIO_new_fp (stderr, BIO_NOCLOSE); p.errorbio = BIO_new_fp (stderr, BIO_NOCLOSE);
if (!(p.curl = curl_easy_init())) { if (!(p.curl = curl_easy_init())) {
BIO_printf(p.errorbio, "Cannot init curl lib\n"); BIO_printf(p.errorbio, "Cannot init curl lib\n");
goto err; goto err;
} }
@@ -365,112 +365,112 @@ int main(int argc, char **argv) {
if (!(p.p12 = d2i_PKCS12_bio (p12bio, NULL))) { if (!(p.p12 = d2i_PKCS12_bio (p12bio, NULL))) {
BIO_printf(p.errorbio, "Cannot decode P12 structure %s\n", p.p12file); goto err; BIO_printf(p.errorbio, "Cannot decode P12 structure %s\n", p.p12file); goto err;
} }
p.ca= NULL; p.ca= NULL;
if (!(PKCS12_parse (p.p12, p.pst, &(p.pkey), &(p.usercert), &(p.ca) ) )) { if (!(PKCS12_parse (p.p12, p.pst, &(p.pkey), &(p.usercert), &(p.ca) ) )) {
BIO_printf(p.errorbio,"Invalid P12 structure in %s\n", p.p12file); goto err; BIO_printf(p.errorbio,"Invalid P12 structure in %s\n", p.p12file); goto err;
} }
if (sk_X509_num(p.ca) <= 0) { if (sk_X509_num(p.ca) <= 0) {
BIO_printf(p.errorbio,"No trustworthy CA given.%s\n", p.p12file); goto err; BIO_printf(p.errorbio,"No trustworthy CA given.%s\n", p.p12file); goto err;
} }
if (p.verbose > 1) X509_print_ex(p.errorbio,p.usercert,0,0); if (p.verbose > 1) X509_print_ex(p.errorbio,p.usercert,0,0);
/* determine URL to go */ /* determine URL to go */
if (hostporturl) { if (hostporturl) {
serverurl=(char*) malloc(9+strlen(hostporturl)); serverurl=(char*) malloc(9+strlen(hostporturl));
sprintf(serverurl,"https://%s",hostporturl); sprintf(serverurl,"https://%s",hostporturl);
} else if (p.accesstype != 0) { /* see whether we can find an AIA or SIA for a given access type */ } else if (p.accesstype != 0) { /* see whether we can find an AIA or SIA for a given access type */
if (!(serverurl = my_get_ext(p.usercert,p.accesstype,NID_info_access))) { if (!(serverurl = my_get_ext(p.usercert,p.accesstype,NID_info_access))) {
BIO_printf(p.errorbio,"no service URL in user cert cherching in others certificats\n"); BIO_printf(p.errorbio,"no service URL in user cert cherching in others certificats\n");
int j=0; int j=0;
int find=0; int find=0;
for (j=0;j<sk_X509_num(p.ca);j++) { for (j=0;j<sk_X509_num(p.ca);j++) {
if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype,NID_info_access))) break; if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype,NID_info_access))) break;
if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype,NID_sinfo_access))) break; if ((serverurl = my_get_ext(sk_X509_value(p.ca,j),p.accesstype,NID_sinfo_access))) break;
} }
} }
} }
if (!serverurl) { if (!serverurl) {
BIO_printf(p.errorbio, "no service URL in certificats, check '-accesstype (AD_DVCS | ad_timestamping)' or use '-connect'\n"); goto err; BIO_printf(p.errorbio, "no service URL in certificats, check '-accesstype (AD_DVCS | ad_timestamping)' or use '-connect'\n"); goto err;
} }
if (p.verbose) BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl);
curl_easy_setopt(p.curl, CURLOPT_URL, serverurl);
/* Now specify the POST binary data */
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDS, binaryptr); if (p.verbose) BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl);
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDSIZE,tabLength); curl_easy_setopt(p.curl, CURLOPT_URL, serverurl);
/* pass our list of custom made headers */
contenttype=(char*) malloc(15+strlen(mimetype)); /* Now specify the POST binary data */
sprintf(contenttype,"Content-type: %s",mimetype);
headers = curl_slist_append(headers,contenttype);
curl_easy_setopt(p.curl, CURLOPT_HTTPHEADER, headers);
if (p.verbose) BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl); curl_easy_setopt(p.curl, CURLOPT_POSTFIELDS, binaryptr);
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDSIZE,tabLength);
{ /* pass our list of custom made headers */
FILE *outfp;
BIO_get_fp(out,&outfp);
curl_easy_setopt(p.curl, CURLOPT_FILE,outfp);
}
res = curl_easy_setopt(p.curl, CURLOPT_SSL_CTX_FUNCTION, sslctxfun) ; contenttype=(char*) malloc(15+strlen(mimetype));
sprintf(contenttype,"Content-type: %s",mimetype);
headers = curl_slist_append(headers,contenttype);
curl_easy_setopt(p.curl, CURLOPT_HTTPHEADER, headers);
if (res != CURLE_OK) if (p.verbose) BIO_printf(p.errorbio, "Service URL: <%s>\n", serverurl);
BIO_printf(p.errorbio,"%d %s=%d %d\n", __LINE__, "CURLOPT_SSL_CTX_FUNCTION",CURLOPT_SSL_CTX_FUNCTION,res);
curl_easy_setopt(p.curl, CURLOPT_SSL_CTX_DATA, &p);
{ {
int lu; int i=0; FILE *outfp;
while ((lu = BIO_read (in,&binaryptr[i],tabLength-i)) >0 ) { BIO_get_fp(out,&outfp);
i+=lu; curl_easy_setopt(p.curl, CURLOPT_FILE,outfp);
if (i== tabLength) { }
tabLength+=100;
binaryptr=(char*)realloc(binaryptr,tabLength); /* should be more careful */ res = curl_easy_setopt(p.curl, CURLOPT_SSL_CTX_FUNCTION, sslctxfun) ;
}
} if (res != CURLE_OK)
tabLength = i; BIO_printf(p.errorbio,"%d %s=%d %d\n", __LINE__, "CURLOPT_SSL_CTX_FUNCTION",CURLOPT_SSL_CTX_FUNCTION,res);
}
/* Now specify the POST binary data */ curl_easy_setopt(p.curl, CURLOPT_SSL_CTX_DATA, &p);
{
int lu; int i=0;
while ((lu = BIO_read (in,&binaryptr[i],tabLength-i)) >0 ) {
i+=lu;
if (i== tabLength) {
tabLength+=100;
binaryptr=(char*)realloc(binaryptr,tabLength); /* should be more careful */
}
}
tabLength = i;
}
/* Now specify the POST binary data */
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDS, binaryptr);
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDSIZE,tabLength);
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDS, binaryptr);
curl_easy_setopt(p.curl, CURLOPT_POSTFIELDSIZE,tabLength);
/* Perform the request, res will get the return code */ /* Perform the request, res will get the return code */
BIO_printf(p.errorbio,"%d %s %d\n", __LINE__, "curl_easy_perform", res = curl_easy_perform(p.curl)); BIO_printf(p.errorbio,"%d %s %d\n", __LINE__, "curl_easy_perform", res = curl_easy_perform(p.curl));
{ {
int result =curl_easy_getinfo(p.curl,CURLINFO_CONTENT_TYPE,&response); int result =curl_easy_getinfo(p.curl,CURLINFO_CONTENT_TYPE,&response);
if( mimetypeaccept && p.verbose) if( mimetypeaccept && p.verbose)
if(!strcmp(mimetypeaccept,response)) if(!strcmp(mimetypeaccept,response))
BIO_printf(p.errorbio,"the response has a correct mimetype : %s\n",response); BIO_printf(p.errorbio,"the response has a correct mimetype : %s\n",response);
else else
BIO_printf(p.errorbio,"the reponse doesn\'t has an acceptable mime type, it is %s instead of %s\n",response,mimetypeaccept); BIO_printf(p.errorbio,"the reponse doesn\'t has an acceptable mime type, it is %s instead of %s\n",response,mimetypeaccept);
} }
/*** code d'erreur si accept mime ***, egalement code return HTTP != 200 ***/ /*** code d'erreur si accept mime ***, egalement code return HTTP != 200 ***/
/* free the header list*/ /* free the header list*/
curl_slist_free_all(headers); curl_slist_free_all(headers);
/* always cleanup */ /* always cleanup */
curl_easy_cleanup(p.curl); curl_easy_cleanup(p.curl);
BIO_free(in); BIO_free(in);
BIO_free(out); BIO_free(out);
return (EXIT_SUCCESS); return (EXIT_SUCCESS);
err: BIO_printf(p.errorbio,"error"); err: BIO_printf(p.errorbio,"error");
exit(1); exit(1);
} }

128
docs/examples/debug.c Normal file
View File

@@ -0,0 +1,128 @@
/*****************************************************************************
* _ _ ____ _
* Project ___| | | | _ \| |
* / __| | | | |_) | |
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
* $Id$
*/
#include <stdio.h>
#include <curl/curl.h>
struct data {
char trace_ascii; /* 1 or 0 */
};
static
void dump(const char *text,
FILE *stream, unsigned char *ptr, size_t size,
char nohex)
{
size_t i;
size_t c;
unsigned int width=0x10;
if(nohex)
/* without the hex output, we can fit more on screen */
width = 0x40;
fprintf(stream, "%s, %zd bytes (0x%zx)\n", text, size, size);
for(i=0; i<size; i+= width) {
fprintf(stream, "%04zx: ", i);
if(!nohex) {
/* hex not disabled, show it */
for(c = 0; c < width; c++)
if(i+c < size)
fprintf(stream, "%02x ", ptr[i+c]);
else
fputs(" ", stream);
}
for(c = 0; (c < width) && (i+c < size); c++) {
/* check for 0D0A; if found, skip past and start a new line of output */
if (nohex && (i+c+1 < size) && ptr[i+c]==0x0D && ptr[i+c+1]==0x0A) {
i+=(c+2-width);
break;
}
fprintf(stream, "%c",
(ptr[i+c]>=0x20) && (ptr[i+c]<0x80)?ptr[i+c]:'.');
/* check again for 0D0A, to avoid an extra \n if it's at width */
if (nohex && (i+c+2 < size) && ptr[i+c+1]==0x0D && ptr[i+c+2]==0x0A) {
i+=(c+3-width);
break;
}
}
fputc('\n', stream); /* newline */
}
fflush(stream);
}
static
int my_trace(CURL *handle, curl_infotype type,
unsigned char *data, size_t size,
void *userp)
{
struct data *config = (struct data *)userp;
const char *text;
(void)handle; /* prevent compiler warning */
switch (type) {
case CURLINFO_TEXT:
fprintf(stderr, "== Info: %s", data);
default: /* in case a new one is introduced to shock us */
return 0;
case CURLINFO_HEADER_OUT:
text = "=> Send header";
break;
case CURLINFO_DATA_OUT:
text = "=> Send data";
break;
case CURLINFO_HEADER_IN:
text = "<= Recv header";
break;
case CURLINFO_DATA_IN:
text = "<= Recv data";
break;
case CURLINFO_SSL_DATA_IN:
text = "<= Recv SSL data";
break;
case CURLINFO_SSL_DATA_OUT:
text = "<= Send SSL data";
break;
}
dump(text, stderr, data, size, config->trace_ascii);
return 0;
}
int main(void)
{
CURL *curl;
CURLcode res;
struct data config;
config.trace_ascii = 1; /* enable ascii tracing */
curl = curl_easy_init();
if(curl) {
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &config);
/* the DEBUGFUNCTION has no effect until we enable VERBOSE */
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
res = curl_easy_perform(curl);
/* always cleanup */
curl_easy_cleanup(curl);
}
return 0;
}

View File

@@ -22,7 +22,7 @@ int main(void)
double speed_upload, total_time; double speed_upload, total_time;
FILE *fd; FILE *fd;
fd = fopen("debugit", "r"); /* open file to upload */ fd = fopen("debugit", "rb"); /* open file to upload */
if(!fd) { if(!fd) {
return 1; /* can't continue */ return 1; /* can't continue */

View File

@@ -55,16 +55,16 @@ enum fcurl_type_e { CFTYPE_NONE=0, CFTYPE_FILE=1, CFTYPE_CURL=2 };
struct fcurl_data struct fcurl_data
{ {
enum fcurl_type_e type; /* type of handle */ enum fcurl_type_e type; /* type of handle */
union { union {
CURL *curl; CURL *curl;
FILE *file; FILE *file;
} handle; /* handle */ } handle; /* handle */
char *buffer; /* buffer to store cached data*/ char *buffer; /* buffer to store cached data*/
int buffer_len; /* currently allocated buffers length */ int buffer_len; /* currently allocated buffers length */
int buffer_pos; /* end of data in buffer*/ int buffer_pos; /* end of data in buffer*/
int still_running; /* Is background url fetch still in progress */ int still_running; /* Is background url fetch still in progress */
}; };
typedef struct fcurl_data URL_FILE; typedef struct fcurl_data URL_FILE;
@@ -83,9 +83,9 @@ CURLM *multi_handle;
/* curl calls this routine to get more data */ /* curl calls this routine to get more data */
static size_t static size_t
write_callback(char *buffer, write_callback(char *buffer,
size_t size, size_t size,
size_t nitems, size_t nitems,
void *userp) void *userp)
{ {
char *newbuff; char *newbuff;
int rembuff; int rembuff;
@@ -97,21 +97,21 @@ write_callback(char *buffer,
if(size > rembuff) if(size > rembuff)
{ {
//not enuf space in buffer //not enuf space in buffer
newbuff=realloc(url->buffer,url->buffer_len + (size - rembuff)); newbuff=realloc(url->buffer,url->buffer_len + (size - rembuff));
if(newbuff==NULL) if(newbuff==NULL)
{ {
fprintf(stderr,"callback buffer grow failed\n"); fprintf(stderr,"callback buffer grow failed\n");
size=rembuff; size=rembuff;
} }
else else
{ {
/* realloc suceeded increase buffer size*/ /* realloc suceeded increase buffer size*/
url->buffer_len+=size - rembuff; url->buffer_len+=size - rembuff;
url->buffer=newbuff; url->buffer=newbuff;
/*printf("Callback buffer grown to %d bytes\n",url->buffer_len);*/ /*printf("Callback buffer grown to %d bytes\n",url->buffer_len);*/
} }
} }
memcpy(&url->buffer[url->buffer_pos], buffer, size); memcpy(&url->buffer[url->buffer_pos], buffer, size);
@@ -137,42 +137,42 @@ curl_fill_buffer(URL_FILE *file,int want,int waittime)
* doesnt exceed required size already * doesnt exceed required size already
*/ */
if((!file->still_running) || (file->buffer_pos > want)) if((!file->still_running) || (file->buffer_pos > want))
return 0; return 0;
/* attempt to fill buffer */ /* attempt to fill buffer */
do do
{ {
FD_ZERO(&fdread); FD_ZERO(&fdread);
FD_ZERO(&fdwrite); FD_ZERO(&fdwrite);
FD_ZERO(&fdexcep); FD_ZERO(&fdexcep);
/* set a suitable timeout to fail on */ /* set a suitable timeout to fail on */
timeout.tv_sec = 60; /* 1 minute */ timeout.tv_sec = 60; /* 1 minute */
timeout.tv_usec = 0; timeout.tv_usec = 0;
/* get file descriptors from the transfers */ /* get file descriptors from the transfers */
curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd);
rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);
switch(rc) { switch(rc) {
case -1: case -1:
/* select error */ /* select error */
break; break;
case 0: case 0:
break; break;
default: default:
/* timeout or readable/writable sockets */ /* timeout or readable/writable sockets */
/* note we *could* be more efficient and not wait for /* note we *could* be more efficient and not wait for
* CURLM_CALL_MULTI_PERFORM to clear here and check it on re-entry * CURLM_CALL_MULTI_PERFORM to clear here and check it on re-entry
* but that gets messy */ * but that gets messy */
while(curl_multi_perform(multi_handle, &file->still_running) == while(curl_multi_perform(multi_handle, &file->still_running) ==
CURLM_CALL_MULTI_PERFORM); CURLM_CALL_MULTI_PERFORM);
break; break;
} }
} while(file->still_running && (file->buffer_pos < want)); } while(file->still_running && (file->buffer_pos < want));
return 1; return 1;
} }
@@ -184,22 +184,22 @@ curl_use_buffer(URL_FILE *file,int want)
/* sort out buffer */ /* sort out buffer */
if((file->buffer_pos - want) <=0) if((file->buffer_pos - want) <=0)
{ {
/* ditch buffer - write will recreate */ /* ditch buffer - write will recreate */
if(file->buffer) if(file->buffer)
free(file->buffer); free(file->buffer);
file->buffer=NULL; file->buffer=NULL;
file->buffer_pos=0; file->buffer_pos=0;
file->buffer_len=0; file->buffer_len=0;
} }
else else
{ {
/* move rest down make it available for later */ /* move rest down make it available for later */
memmove(file->buffer, memmove(file->buffer,
&file->buffer[want], &file->buffer[want],
(file->buffer_pos - want)); (file->buffer_pos - want));
file->buffer_pos -= want; file->buffer_pos -= want;
} }
return 0; return 0;
} }
@@ -217,47 +217,47 @@ url_fopen(char *url,const char *operation)
file = (URL_FILE *)malloc(sizeof(URL_FILE)); file = (URL_FILE *)malloc(sizeof(URL_FILE));
if(!file) if(!file)
return NULL; return NULL;
memset(file, 0, sizeof(URL_FILE)); memset(file, 0, sizeof(URL_FILE));
if((file->handle.file=fopen(url,operation))) if((file->handle.file=fopen(url,operation)))
{ {
file->type = CFTYPE_FILE; /* marked as URL */ file->type = CFTYPE_FILE; /* marked as URL */
} }
else else
{ {
file->type = CFTYPE_CURL; /* marked as URL */ file->type = CFTYPE_CURL; /* marked as URL */
file->handle.curl = curl_easy_init(); file->handle.curl = curl_easy_init();
curl_easy_setopt(file->handle.curl, CURLOPT_URL, url); curl_easy_setopt(file->handle.curl, CURLOPT_URL, url);
curl_easy_setopt(file->handle.curl, CURLOPT_WRITEDATA, file); curl_easy_setopt(file->handle.curl, CURLOPT_WRITEDATA, file);
curl_easy_setopt(file->handle.curl, CURLOPT_VERBOSE, FALSE); curl_easy_setopt(file->handle.curl, CURLOPT_VERBOSE, FALSE);
curl_easy_setopt(file->handle.curl, CURLOPT_WRITEFUNCTION, write_callback); curl_easy_setopt(file->handle.curl, CURLOPT_WRITEFUNCTION, write_callback);
if(!multi_handle) if(!multi_handle)
multi_handle = curl_multi_init(); multi_handle = curl_multi_init();
curl_multi_add_handle(multi_handle, file->handle.curl); curl_multi_add_handle(multi_handle, file->handle.curl);
/* lets start the fetch */ /* lets start the fetch */
while(curl_multi_perform(multi_handle, &file->still_running) == while(curl_multi_perform(multi_handle, &file->still_running) ==
CURLM_CALL_MULTI_PERFORM ); CURLM_CALL_MULTI_PERFORM );
if((file->buffer_pos == 0) && (!file->still_running)) if((file->buffer_pos == 0) && (!file->still_running))
{ {
/* if still_running is 0 now, we should return NULL */ /* if still_running is 0 now, we should return NULL */
/* make sure the easy handle is not in the multi handle anymore */ /* make sure the easy handle is not in the multi handle anymore */
curl_multi_remove_handle(multi_handle, file->handle.curl); curl_multi_remove_handle(multi_handle, file->handle.curl);
/* cleanup */ /* cleanup */
curl_easy_cleanup(file->handle.curl); curl_easy_cleanup(file->handle.curl);
free(file); free(file);
file = NULL; file = NULL;
} }
} }
return file; return file;
} }
@@ -270,26 +270,26 @@ url_fclose(URL_FILE *file)
switch(file->type) switch(file->type)
{ {
case CFTYPE_FILE: case CFTYPE_FILE:
ret=fclose(file->handle.file); /* passthrough */ ret=fclose(file->handle.file); /* passthrough */
break; break;
case CFTYPE_CURL: case CFTYPE_CURL:
/* make sure the easy handle is not in the multi handle anymore */ /* make sure the easy handle is not in the multi handle anymore */
curl_multi_remove_handle(multi_handle, file->handle.curl); curl_multi_remove_handle(multi_handle, file->handle.curl);
/* cleanup */ /* cleanup */
curl_easy_cleanup(file->handle.curl); curl_easy_cleanup(file->handle.curl);
break; break;
default: /* unknown or supported type - oh dear */ default: /* unknown or supported type - oh dear */
ret=EOF; ret=EOF;
errno=EBADF; errno=EBADF;
break; break;
} }
if(file->buffer) if(file->buffer)
free(file->buffer);/* free any allocated buffer space */ free(file->buffer);/* free any allocated buffer space */
free(file); free(file);
@@ -304,17 +304,17 @@ url_feof(URL_FILE *file)
switch(file->type) switch(file->type)
{ {
case CFTYPE_FILE: case CFTYPE_FILE:
ret=feof(file->handle.file); ret=feof(file->handle.file);
break; break;
case CFTYPE_CURL: case CFTYPE_CURL:
if((file->buffer_pos == 0) && (!file->still_running)) if((file->buffer_pos == 0) && (!file->still_running))
ret = 1; ret = 1;
break; break;
default: /* unknown or supported type - oh dear */ default: /* unknown or supported type - oh dear */
ret=-1; ret=-1;
errno=EBADF; errno=EBADF;
break; break;
} }
return ret; return ret;
} }
@@ -327,38 +327,38 @@ url_fread(void *ptr, size_t size, size_t nmemb, URL_FILE *file)
switch(file->type) switch(file->type)
{ {
case CFTYPE_FILE: case CFTYPE_FILE:
want=fread(ptr,size,nmemb,file->handle.file); want=fread(ptr,size,nmemb,file->handle.file);
break; break;
case CFTYPE_CURL: case CFTYPE_CURL:
want = nmemb * size; want = nmemb * size;
curl_fill_buffer(file,want,1); curl_fill_buffer(file,want,1);
/* check if theres data in the buffer - if not curl_fill_buffer() /* check if theres data in the buffer - if not curl_fill_buffer()
* either errored or EOF */ * either errored or EOF */
if(!file->buffer_pos) if(!file->buffer_pos)
return 0; return 0;
/* ensure only available data is considered */ /* ensure only available data is considered */
if(file->buffer_pos < want) if(file->buffer_pos < want)
want = file->buffer_pos; want = file->buffer_pos;
/* xfer data to caller */ /* xfer data to caller */
memcpy(ptr, file->buffer, want); memcpy(ptr, file->buffer, want);
curl_use_buffer(file,want); curl_use_buffer(file,want);
want = want / size; /* number of items - nb correct op - checked want = want / size; /* number of items - nb correct op - checked
* with glibc code*/ * with glibc code*/
/*printf("(fread) return %d bytes %d left\n", want,file->buffer_pos);*/ /*printf("(fread) return %d bytes %d left\n", want,file->buffer_pos);*/
break; break;
default: /* unknown or supported type - oh dear */ default: /* unknown or supported type - oh dear */
want=0; want=0;
errno=EBADF; errno=EBADF;
break; break;
} }
return want; return want;
@@ -373,45 +373,45 @@ url_fgets(char *ptr, int size, URL_FILE *file)
switch(file->type) switch(file->type)
{ {
case CFTYPE_FILE: case CFTYPE_FILE:
ptr = fgets(ptr,size,file->handle.file); ptr = fgets(ptr,size,file->handle.file);
break; break;
case CFTYPE_CURL: case CFTYPE_CURL:
curl_fill_buffer(file,want,1); curl_fill_buffer(file,want,1);
/* check if theres data in the buffer - if not fill either errored or /* check if theres data in the buffer - if not fill either errored or
* EOF */ * EOF */
if(!file->buffer_pos) if(!file->buffer_pos)
return NULL; return NULL;
/* ensure only available data is considered */ /* ensure only available data is considered */
if(file->buffer_pos < want) if(file->buffer_pos < want)
want = file->buffer_pos; want = file->buffer_pos;
/*buffer contains data */ /*buffer contains data */
/* look for newline or eof */ /* look for newline or eof */
for(loop=0;loop < want;loop++) for(loop=0;loop < want;loop++)
{ {
if(file->buffer[loop] == '\n') if(file->buffer[loop] == '\n')
{ {
want=loop+1;/* include newline */ want=loop+1;/* include newline */
break; break;
} }
} }
/* xfer data to caller */ /* xfer data to caller */
memcpy(ptr, file->buffer, want); memcpy(ptr, file->buffer, want);
ptr[want]=0;/* allways null terminate */ ptr[want]=0;/* allways null terminate */
curl_use_buffer(file,want); curl_use_buffer(file,want);
/*printf("(fgets) return %d bytes %d left\n", want,file->buffer_pos);*/ /*printf("(fgets) return %d bytes %d left\n", want,file->buffer_pos);*/
break; break;
default: /* unknown or supported type - oh dear */ default: /* unknown or supported type - oh dear */
ptr=NULL; ptr=NULL;
errno=EBADF; errno=EBADF;
break; break;
} }
return ptr;/*success */ return ptr;/*success */
@@ -423,28 +423,28 @@ url_rewind(URL_FILE *file)
switch(file->type) switch(file->type)
{ {
case CFTYPE_FILE: case CFTYPE_FILE:
rewind(file->handle.file); /* passthrough */ rewind(file->handle.file); /* passthrough */
break; break;
case CFTYPE_CURL: case CFTYPE_CURL:
/* halt transaction */ /* halt transaction */
curl_multi_remove_handle(multi_handle, file->handle.curl); curl_multi_remove_handle(multi_handle, file->handle.curl);
/* restart */ /* restart */
curl_multi_add_handle(multi_handle, file->handle.curl); curl_multi_add_handle(multi_handle, file->handle.curl);
/* ditch buffer - write will recreate - resets stream pos*/ /* ditch buffer - write will recreate - resets stream pos*/
if(file->buffer) if(file->buffer)
free(file->buffer); free(file->buffer);
file->buffer=NULL; file->buffer=NULL;
file->buffer_pos=0; file->buffer_pos=0;
file->buffer_len=0; file->buffer_len=0;
break; break;
default: /* unknown or supported type - oh dear */ default: /* unknown or supported type - oh dear */
break; break;
} }
@@ -466,33 +466,33 @@ main(int argc, char *argv[])
if(argc < 2) if(argc < 2)
{ {
url="http://192.168.7.3/testfile";/* default to testurl */ url="http://192.168.7.3/testfile";/* default to testurl */
} }
else else
{ {
url=argv[1];/* use passed url */ url=argv[1];/* use passed url */
} }
/* copy from url line by line with fgets */ /* copy from url line by line with fgets */
outf=fopen("fgets.test","w+"); outf=fopen("fgets.test","w+");
if(!outf) if(!outf)
{ {
perror("couldnt open fgets output file\n"); perror("couldnt open fgets output file\n");
return 1; return 1;
} }
handle = url_fopen(url, "r"); handle = url_fopen(url, "r");
if(!handle) if(!handle)
{ {
printf("couldn't url_fopen()\n"); printf("couldn't url_fopen()\n");
fclose(outf); fclose(outf);
return 2; return 2;
} }
while(!url_feof(handle)) while(!url_feof(handle))
{ {
url_fgets(buffer,sizeof(buffer),handle); url_fgets(buffer,sizeof(buffer),handle);
fwrite(buffer,1,strlen(buffer),outf); fwrite(buffer,1,strlen(buffer),outf);
} }
url_fclose(handle); url_fclose(handle);
@@ -504,20 +504,20 @@ main(int argc, char *argv[])
outf=fopen("fread.test","w+"); outf=fopen("fread.test","w+");
if(!outf) if(!outf)
{ {
perror("couldnt open fread output file\n"); perror("couldnt open fread output file\n");
return 1; return 1;
} }
handle = url_fopen("testfile", "r"); handle = url_fopen("testfile", "r");
if(!handle) { if(!handle) {
printf("couldn't url_fopen()\n"); printf("couldn't url_fopen()\n");
fclose(outf); fclose(outf);
return 2; return 2;
} }
do { do {
nread = url_fread(buffer, 1,sizeof(buffer), handle); nread = url_fread(buffer, 1,sizeof(buffer), handle);
fwrite(buffer,1,nread,outf); fwrite(buffer,1,nread,outf);
} while(nread); } while(nread);
url_fclose(handle); url_fclose(handle);
@@ -529,26 +529,26 @@ main(int argc, char *argv[])
outf=fopen("rewind.test","w+"); outf=fopen("rewind.test","w+");
if(!outf) if(!outf)
{ {
perror("couldnt open fread output file\n"); perror("couldnt open fread output file\n");
return 1; return 1;
} }
handle = url_fopen("testfile", "r"); handle = url_fopen("testfile", "r");
if(!handle) { if(!handle) {
printf("couldn't url_fopen()\n"); printf("couldn't url_fopen()\n");
fclose(outf); fclose(outf);
return 2; return 2;
} }
nread = url_fread(buffer, 1,sizeof(buffer), handle); nread = url_fread(buffer, 1,sizeof(buffer), handle);
fwrite(buffer,1,nread,outf); fwrite(buffer,1,nread,outf);
url_rewind(handle); url_rewind(handle);
buffer[0]='\n'; buffer[0]='\n';
fwrite(buffer,1,1,outf); fwrite(buffer,1,1,outf);
nread = url_fread(buffer, 1,sizeof(buffer), handle); nread = url_fread(buffer, 1,sizeof(buffer), handle);
fwrite(buffer,1,nread,outf); fwrite(buffer,1,nread,outf);
url_fclose(handle); url_fclose(handle);

View File

@@ -1,8 +1,8 @@
/***************************************************************************** /*****************************************************************************
* _ _ ____ _ * _ _ ____ _
* Project ___| | | | _ \| | * Project ___| | | | _ \| |
* / __| | | | |_) | | * / __| | | | |_) | |
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* $Id$ * $Id$
@@ -49,10 +49,14 @@ int main(void)
}; };
curl_global_init(CURL_GLOBAL_DEFAULT); curl_global_init(CURL_GLOBAL_DEFAULT);
curl = curl_easy_init(); curl = curl_easy_init();
if(curl) { if(curl) {
/* Get curl 7.9.2 from sunet.se's FTP site: */ /*
* Get curl 7.9.2 from sunet.se's FTP site. curl 7.9.2 is most likely not
* present there by the time you read this, so you'd better replace the
* URL with one that works!
*/
curl_easy_setopt(curl, CURLOPT_URL, curl_easy_setopt(curl, CURLOPT_URL,
"ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz"); "ftp://ftp.sunet.se/pub/www/utilities/curl/curl-7.9.2.tar.gz");
/* Define our callback to get called when there's data to be written */ /* Define our callback to get called when there's data to be written */

View File

@@ -5,7 +5,7 @@
include ../../packages/DOS/common.dj include ../../packages/DOS/common.dj
CFLAGS += -I../../include CFLAGS += -I../../include -DFALSE=0 -DTRUE=1
LIBS = ../../lib/libcurl.a LIBS = ../../lib/libcurl.a
@@ -15,14 +15,16 @@ endif
LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a LIBS += $(WATT32_ROOT)/lib/libwatt.a $(ZLIB_ROOT)/libz.a
PROGRAMS = fopen.exe ftpget.exe ftpgetre.exe ftpuploa.exe getinmem.exe \ PROGRAMS = fopen.exe ftpget.exe ftpgetresp.exe ftpupload.exe \
http-pos.exe httpput.exe multi-ap.exe multi-do.exe \ getinmemory.exe http-post.exe httpput.exe multi-app.exe \
multi-po.exe multi-si.exe persista.exe post-cal.exe \ multi-double.exe multi-post.exe multi-single.exe \
postit2.exe sepheade.exe simple.exe simpless.exe persistant.exe post-callback.exe postit2.exe \
sepheaders.exe simple.exe simplessl.exe https.exe \
ftp3rdparty.exe getinfo.exe
all: $(PROGRAMS) all: $(PROGRAMS)
.c.exe: %.exe: %.c
$(CC) $(CFLAGS) -o $@ $^ $(LIBS) $(CC) $(CFLAGS) -o $@ $^ $(LIBS)
@echo @echo

View File

@@ -1,8 +1,8 @@
/***************************************************************************** /*****************************************************************************
* _ _ ____ _ * _ _ ____ _
* Project ___| | | | _ \| | * Project ___| | | | _ \| |
* / __| | | | |_) | | * / __| | | | |_) | |
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* $Id$ * $Id$
@@ -24,9 +24,9 @@
* Download a HTTP file and upload an FTP file simultaneously. * Download a HTTP file and upload an FTP file simultaneously.
*/ */
#define HANDLECOUNT 2 /* Number of simultaneous transfers */ #define HANDLECOUNT 2 /* Number of simultaneous transfers */
#define HTTP_HANDLE 0 /* Index for the HTTP transfer */ #define HTTP_HANDLE 0 /* Index for the HTTP transfer */
#define FTP_HANDLE 1 /* Index for the FTP transfer */ #define FTP_HANDLE 1 /* Index for the FTP transfer */
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
@@ -98,8 +98,6 @@ int main(int argc, char **argv)
} }
} }
curl_multi_cleanup(multi_handle);
/* See how the transfers went */ /* See how the transfers went */
while ((msg = curl_multi_info_read(multi_handle, &msgs_left))) { while ((msg = curl_multi_info_read(multi_handle, &msgs_left))) {
if (msg->msg == CURLMSG_DONE) { if (msg->msg == CURLMSG_DONE) {
@@ -111,15 +109,17 @@ int main(int argc, char **argv)
switch (idx) { switch (idx) {
case HTTP_HANDLE: case HTTP_HANDLE:
printf("HTTP transfer completed with status %d\n", msg->data.result); printf("HTTP transfer completed with status %d\n", msg->data.result);
break; break;
case FTP_HANDLE: case FTP_HANDLE:
printf("FTP transfer completed with status %d\n", msg->data.result); printf("FTP transfer completed with status %d\n", msg->data.result);
break; break;
} }
} }
} }
curl_multi_cleanup(multi_handle);
/* Free the CURL handles */ /* Free the CURL handles */
for (i=0; i<HANDLECOUNT; i++) for (i=0; i<HANDLECOUNT; i++)
curl_easy_cleanup(handles[i]); curl_easy_cleanup(handles[i]);

View File

@@ -1,8 +1,8 @@
/***************************************************************************** /*****************************************************************************
* _ _ ____ _ * _ _ ____ _
* Project ___| | | | _ \| | * Project ___| | | | _ \| |
* / __| | | | |_) | | * / __| | | | |_) | |
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* $Id$ * $Id$
@@ -57,9 +57,6 @@ int main(void)
/* Now specify we want to POST data */ /* Now specify we want to POST data */
curl_easy_setopt(curl, CURLOPT_POST, TRUE); curl_easy_setopt(curl, CURLOPT_POST, TRUE);
/* Set the expected POST size */
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft);
/* we want to use our own read function */ /* we want to use our own read function */
curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback); curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback);
@@ -69,6 +66,47 @@ int main(void)
/* get verbose debug output please */ /* get verbose debug output please */
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
/*
If you use POST to a HTTP 1.1 server, you can send data without knowing
the size before starting the POST if you use chunked encoding. You
enable this by adding a header like "Transfer-Encoding: chunked" with
CURLOPT_HTTPHEADER. With HTTP 1.0 or without chunked transfer, you must
specify the size in the request.
*/
#ifdef USE_CHUNKED
{
curl_slist *chunk = NULL;
chunk = curl_slist_append(chunk, "Transfer-Encoding: chunked");
res = curl_easy_setopt(curl, CURLOPT_HTTPHEADER);
/* use curl_slist_free_all() after the *perform() call to free this
list again */
}
#else
/* Set the expected POST size. If you want to POST large amounts of data,
consider CURLOPT_POSTFIELDSIZE_LARGE */
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft);
#endif
#ifdef DISABLE_EXPECT
/*
Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue"
header. You can disable this header with CURLOPT_HTTPHEADER as usual.
NOTE: if you want chunked transfer too, you need to combine these two
since you can only set one list of headers with CURLOPT_HTTPHEADER. */
/* A less good option would be to enforce HTTP 1.0, but that might also
have other implications. */
{
curl_slist *chunk = NULL;
chunk = curl_slist_append(chunk, "Expect:");
res = curl_easy_setopt(curl, CURLOPT_HTTPHEADER);
/* use curl_slist_free_all() after the *perform() call to free this
list again */
}
#endif
/* Perform the request, res will get the return code */ /* Perform the request, res will get the return code */
res = curl_easy_perform(curl); res = curl_easy_perform(curl);

View File

@@ -1,8 +1,8 @@
/***************************************************************************** /*****************************************************************************
* _ _ ____ _ * _ _ ____ _
* Project ___| | | | _ \| | * Project ___| | | | _ \| |
* / __| | | | |_) | | * / __| | | | |_) | |
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* $Id$ * $Id$
@@ -53,7 +53,7 @@ int main(int argc, char *argv[])
CURLFORM_COPYNAME, "filename", CURLFORM_COPYNAME, "filename",
CURLFORM_COPYCONTENTS, "postit2.c", CURLFORM_COPYCONTENTS, "postit2.c",
CURLFORM_END); CURLFORM_END);
/* Fill in the submit field too, even if this is rarely needed */ /* Fill in the submit field too, even if this is rarely needed */
curl_formadd(&formpost, curl_formadd(&formpost,

View File

@@ -1,8 +1,8 @@
/***************************************************************************** /*****************************************************************************
* _ _ ____ _ * _ _ ____ _
* Project ___| | | | _ \| | * Project ___| | | | _ \| |
* / __| | | | |_) | | * / __| | | | |_) | |
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* $Id$ * $Id$

View File

@@ -1,8 +1,8 @@
/***************************************************************************** /*****************************************************************************
* _ _ ____ _ * _ _ ____ _
* Project ___| | | | _ \| | * Project ___| | | | _ \| |
* / __| | | | |_) | | * / __| | | | |_) | |
* | (__| |_| | _ <| |___ * | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____| * \___|\___/|_| \_\_____|
* *
* $Id$ * $Id$
@@ -71,42 +71,48 @@ int main(int argc, char **argv)
while(1) /* do some ugly short cut... */ while(1) /* do some ugly short cut... */
{ {
if (pEngine) /* use crypto engine */ if (pEngine) /* use crypto engine */
{ {
if (curl_easy_setopt(curl, CURLOPT_SSLENGINE,pEngine) != CURLE_OK) if (curl_easy_setopt(curl, CURLOPT_SSLENGINE,pEngine) != CURLE_OK)
{ /* load the crypto engine */ { /* load the crypto engine */
fprintf(stderr,"can't set crypto engine\n"); fprintf(stderr,"can't set crypto engine\n");
break; break;
} }
if (curl_easy_setopt(curl, CURLOPT_SSLENGINE_DEFAULT,1) != CURLE_OK) if (curl_easy_setopt(curl, CURLOPT_SSLENGINE_DEFAULT,1) != CURLE_OK)
{ /* set the crypto engine as default */ { /* set the crypto engine as default */
/* only needed for the first time you load /* only needed for the first time you load
a engine in a curl object... */ a engine in a curl object... */
fprintf(stderr,"can't set crypto engine as default\n"); fprintf(stderr,"can't set crypto engine as default\n");
break; break;
} }
} }
/* cert is stored PEM coded in file... */ /* cert is stored PEM coded in file... */
/* since PEM is default, we needn't set it for PEM */ /* since PEM is default, we needn't set it for PEM */
curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM"); curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM");
/* set the cert for client authentication */
curl_easy_setopt(curl,CURLOPT_SSLCERT,pCertFile); /* set the cert for client authentication */
/* sorry, for engine we must set the passphrase curl_easy_setopt(curl,CURLOPT_SSLCERT,pCertFile);
(if the key has one...) */
if (pPassphrase) /* sorry, for engine we must set the passphrase
curl_easy_setopt(curl,CURLOPT_SSLKEYPASSWD,pPassphrase); (if the key has one...) */
/* if we use a key stored in a crypto engine, if (pPassphrase)
we must set the key type to "ENG" */ curl_easy_setopt(curl,CURLOPT_SSLKEYPASSWD,pPassphrase);
curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType);
/* set the private key (file or ID in engine) */ /* if we use a key stored in a crypto engine,
curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName); we must set the key type to "ENG" */
/* set the file with the certs vaildating the server */ curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,pKeyType);
curl_easy_setopt(curl,CURLOPT_CAINFO,pCACertFile);
/* disconnect if we can't validate server's cert */ /* set the private key (file or ID in engine) */
curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1); curl_easy_setopt(curl,CURLOPT_SSLKEY,pKeyName);
res = curl_easy_perform(curl); /* set the file with the certs vaildating the server */
break; /* we are done... */ curl_easy_setopt(curl,CURLOPT_CAINFO,pCACertFile);
/* disconnect if we can't validate server's cert */
curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1);
res = curl_easy_perform(curl);
break; /* we are done... */
} }
/* always cleanup */ /* always cleanup */
curl_easy_cleanup(curl); curl_easy_cleanup(curl);

File diff suppressed because it is too large Load Diff

View File

@@ -16,7 +16,7 @@ man_MANS = curl_easy_cleanup.3 curl_easy_getinfo.3 curl_easy_init.3 \
curl_share_init.3 curl_share_setopt.3 libcurl.3 libcurl-easy.3 \ curl_share_init.3 curl_share_setopt.3 libcurl.3 libcurl-easy.3 \
libcurl-multi.3 libcurl-share.3 libcurl-errors.3 curl_easy_strerror.3 \ libcurl-multi.3 libcurl-share.3 libcurl-errors.3 curl_easy_strerror.3 \
curl_multi_strerror.3 curl_share_strerror.3 curl_global_init_mem.3 \ curl_multi_strerror.3 curl_share_strerror.3 curl_global_init_mem.3 \
libcurl-tutorial.3 libcurl-tutorial.3 curl_easy_reset.3
HTMLPAGES = curl_easy_cleanup.html curl_easy_getinfo.html \ HTMLPAGES = curl_easy_cleanup.html curl_easy_getinfo.html \
curl_easy_init.html curl_easy_perform.html curl_easy_setopt.html \ curl_easy_init.html curl_easy_perform.html curl_easy_setopt.html \
@@ -32,7 +32,7 @@ HTMLPAGES = curl_easy_cleanup.html curl_easy_getinfo.html \
libcurl.html libcurl-multi.html libcurl-easy.html libcurl-share.html \ libcurl.html libcurl-multi.html libcurl-easy.html libcurl-share.html \
libcurl-errors.html curl_easy_strerror.html curl_multi_strerror.html \ libcurl-errors.html curl_easy_strerror.html curl_multi_strerror.html \
curl_share_strerror.html curl_global_init_mem.html \ curl_share_strerror.html curl_global_init_mem.html \
libcurl-tutorial.html libcurl-tutorial.html curl_easy_reset.html
PDFPAGES = curl_easy_cleanup.pdf curl_easy_getinfo.pdf \ PDFPAGES = curl_easy_cleanup.pdf curl_easy_getinfo.pdf \
curl_easy_init.pdf curl_easy_perform.pdf curl_easy_setopt.pdf \ curl_easy_init.pdf curl_easy_perform.pdf curl_easy_setopt.pdf \
@@ -47,7 +47,8 @@ PDFPAGES = curl_easy_cleanup.pdf curl_easy_getinfo.pdf \
curl_share_init.pdf curl_share_setopt.pdf libcurl.pdf \ curl_share_init.pdf curl_share_setopt.pdf libcurl.pdf \
libcurl-multi.pdf libcurl-easy.pdf libcurl-share.pdf \ libcurl-multi.pdf libcurl-easy.pdf libcurl-share.pdf \
libcurl-errors.pdf curl_easy_strerror.pdf curl_multi_strerror.pdf \ libcurl-errors.pdf curl_easy_strerror.pdf curl_multi_strerror.pdf \
curl_share_strerror.pdf curl_global_init_mem.pdf libcurl-tutorial.pdf curl_share_strerror.pdf curl_global_init_mem.pdf libcurl-tutorial.pdf \
curl_easy_reset.pdf
CLEANFILES = $(HTMLPAGES) $(PDFPAGES) CLEANFILES = $(HTMLPAGES) $(PDFPAGES)

View File

@@ -19,6 +19,9 @@ this documentation describes further down). The data pointed-to will be
filled in accordingly and can be relied upon only if the function returns filled in accordingly and can be relied upon only if the function returns
CURLE_OK. This function is intended to get used *AFTER* a performed transfer, CURLE_OK. This function is intended to get used *AFTER* a performed transfer,
all results from this function are undefined until the transfer is completed. all results from this function are undefined until the transfer is completed.
You should not free the memory returned by this function unless it is
explictly mentioned below.
.SH AVAILABLE INFORMATION .SH AVAILABLE INFORMATION
The following information can be extracted: The following information can be extracted:
.IP CURLINFO_EFFECTIVE_URL .IP CURLINFO_EFFECTIVE_URL
@@ -107,6 +110,9 @@ CURLOPT_HTTPAUTH option for \fIcurl_easy_setopt(3)\fP. (Added in 7.10.8)
.IP CURLINFO_PROXYAUTH_AVAIL .IP CURLINFO_PROXYAUTH_AVAIL
Pass a pointer to a long to receive a bitmask indicating the authentication Pass a pointer to a long to receive a bitmask indicating the authentication
method(s) available for your proxy authentication. (Added in 7.10.8) method(s) available for your proxy authentication. (Added in 7.10.8)
.IP CURLINFO_OS_ERRNO
Pass a pointer to a long to receive the errno variable from a connect failure.
(Added in 7.12.2)
.SH RETURN VALUE .SH RETURN VALUE
If the operation was successful, CURLE_OK is returned. Otherwise an If the operation was successful, CURLE_OK is returned. Otherwise an
appropriate error code will be returned. appropriate error code will be returned.

View File

@@ -1,5 +1,3 @@
.\" You can view this file with:
.\" nroff -man [file]
.\" $Id$ .\" $Id$
.\" .\"
.TH curl_easy_init 3 "4 March 2002" "libcurl 7.8.1" "libcurl Manual" .TH curl_easy_init 3 "4 March 2002" "libcurl 7.8.1" "libcurl Manual"
@@ -20,4 +18,4 @@ initializes curl and this call \fBMUST\fP have a corresponding call to
If this function returns NULL, something went wrong and you cannot use the If this function returns NULL, something went wrong and you cannot use the
other curl functions. other curl functions.
.SH "SEE ALSO" .SH "SEE ALSO"
.BR curl_easy_cleanup "(3), " curl_global_init "(3) .BR curl_easy_cleanup "(3), " curl_global_init "(3), " curl_easy_reset "(3)"

View File

@@ -0,0 +1,24 @@
.\" $Id$
.\"
.TH curl_easy_reset 3 "31 July 2004" "libcurl 7.12.1" "libcurl Manual"
.SH NAME
curl_easy_reset - reset all options of a libcurl session handle
.SH SYNOPSIS
.B #include <curl/curl.h>
.BI "void curl_easy_reset(CURL *"handle ");"
.SH DESCRIPTION
Re-initializes all options previously set on a specified CURL handle to the
default values. This puts back the handle to the same state as it was in when
it was just created with \fIcurl_easy_init(3)\fP.
It does not change the following information kept in the handle: live
connections, the Session ID cache, the DNS cache, the cookies and shares.
This function was added in libcurl 7.12.1.
.SH RETURN VALUE
Nothing
.SH "SEE ALSO"
.BR curl_easy_init "(3)," curl_easy_cleanup "(3)," curl_easy_setopt "(3)

View File

@@ -32,16 +32,17 @@ CURLcode curl_easy_setopt(CURL *handle, CURLoption option, parameter);
curl_easy_setopt() is used to tell libcurl how to behave. By using the curl_easy_setopt() is used to tell libcurl how to behave. By using the
appropriate options to \fIcurl_easy_setopt\fP, you can change libcurl's appropriate options to \fIcurl_easy_setopt\fP, you can change libcurl's
behavior. All options are set with the \fIoption\fP followed by a behavior. All options are set with the \fIoption\fP followed by a
\fIparameter\fP. That parameter can be a long, a function pointer or an object \fIparameter\fP. That parameter can be a \fBlong\fP, a \fBfunction pointer\fP,
pointer, all depending on what the specific option expects. Read this manual an \fBobject pointer\fP or a \fBcurl_off_t\fP, depending on what the specific
carefully as bad input values may cause libcurl to behave badly! You can only option expects. Read this manual carefully as bad input values may cause
set one option in each function call. A typical application uses many libcurl to behave badly! You can only set one option in each function call. A
curl_easy_setopt() calls in the setup phase. typical application uses many curl_easy_setopt() calls in the setup phase.
Options set with this function call are valid for all forthcoming transfers Options set with this function call are valid for all forthcoming transfers
performed using this \fIhandle\fP. The options are not in any way reset performed using this \fIhandle\fP. The options are not in any way reset
between transfers, so if you want subsequent transfers with different options, between transfers, so if you want subsequent transfers with different options,
you must change them between the transfers. you must change them between the transfers. You can optionally reset all
options back to internal default with \fIcurl_easy_reset(3)\fP.
\fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be \fBNOTE:\fP strings passed to libcurl as 'char *' arguments, will not be
copied by the library. Instead you should keep them available until libcurl no copied by the library. Instead you should keep them available until libcurl no
@@ -92,6 +93,9 @@ of bytes actually taken care of. If that amount differs from the amount passed
to your function, it'll signal an error to the library and it will abort the to your function, it'll signal an error to the library and it will abort the
transfer and return \fICURLE_WRITE_ERROR\fP. transfer and return \fICURLE_WRITE_ERROR\fP.
This function may be called with zero bytes data if the transfered file is
empty.
Set the \fIstream\fP argument with the \fICURLOPT_WRITEDATA\fP option. Set the \fIstream\fP argument with the \fICURLOPT_WRITEDATA\fP option.
\fBNOTE:\fP you will be passed as much data as possible in all invokes, but \fBNOTE:\fP you will be passed as much data as possible in all invokes, but
@@ -469,22 +473,45 @@ data should be set with \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZE\fP.
This option is deprecated and starting with version 7.12.1 you should instead This option is deprecated and starting with version 7.12.1 you should instead
use \fICURLOPT_UPLOAD\fP. use \fICURLOPT_UPLOAD\fP.
.IP CURLOPT_POST .IP CURLOPT_POST
A non-zero parameter tells the library to do a regular HTTP post. This is a A non-zero parameter tells the library to do a regular HTTP post. This will
normal application/x-www-form-urlencoded kind, which is the most commonly used also make the library use the a "Content-Type:
one by HTML forms. See the \fICURLOPT_POSTFIELDS\fP option for how to specify application/x-www-form-urlencoded" header. (This is by far the most commonly
the data to post and \fICURLOPT_POSTFIELDSIZE\fP in how to set the data used POST method).
size. Using the \fICURLOPT_POSTFIELDS\fP option implies this option.
Use the \fICURLOPT_POSTFIELDS\fP option to specify what data to post and
\fICURLOPT_POSTFIELDSIZE\fP to set the data size. Optionally, you can provide
data to POST using the \fICURLOPT_READFUNCTION\fP and \fICURLOPT_READDATA\fP
options.
You can override the default POST Content-Type: header by setting your own
with \fICURLOPT_HTTPHEADER\fP.
Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header.
You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual.
If you use POST to a HTTP 1.1 server, you can send data without knowing the
size before starting the POST if you use chunked encoding. You enable this by
adding a header like "Transfer-Encoding: chunked" with
\fICURLOPT_HTTPHEADER\fP. With HTTP 1.0 or without chunked transfer, you must
specify the size in the request.
NOTE: if you have issued a POST request and want to make a HEAD or GET
instead, you must explictly pick the new request type using
\fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar.
.IP CURLOPT_POSTFIELDS .IP CURLOPT_POSTFIELDS
Pass a char * as parameter, which should be the full data to post in an HTTP Pass a char * as parameter, which should be the full data to post in an HTTP
post operation. You need to make sure that the data is formatted the way you POST operation. You must make sure that the data is formatted the way you want
want the server to receive it. libcurl will not convert or encode it for the server to receive it. libcurl will not convert or encode it for you. Most
you. Most web servers will assume this data to be url-encoded. Take note. web servers will assume this data to be url-encoded. Take note.
This POST is a normal application/x-www-form-urlencoded kind (and libcurl will This POST is a normal application/x-www-form-urlencoded kind (and libcurl will
set that Content-Type by default when this option is used), which is the most set that Content-Type by default when this option is used), which is the most
commonly used one by HTML forms. See also the \fICURLOPT_POST\fP. Using commonly used one by HTML forms. See also the \fICURLOPT_POST\fP. Using
\fICURLOPT_POSTFIELDS\fP implies \fICURLOPT_POST\fP. \fICURLOPT_POSTFIELDS\fP implies \fICURLOPT_POST\fP.
Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header.
You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual.
\fBNote:\fP to make multipart/formdata posts (aka rfc1867-posts), check out \fBNote:\fP to make multipart/formdata posts (aka rfc1867-posts), check out
the \fICURLOPT_HTTPPOST\fP option. the \fICURLOPT_HTTPPOST\fP option.
.IP CURLOPT_POSTFIELDSIZE .IP CURLOPT_POSTFIELDSIZE
@@ -505,6 +532,9 @@ list of 'struct HttpPost' structs properly filled in. The best and most
elegant way to do this, is to use \fIcurl_formadd(3)\fP as documented. The elegant way to do this, is to use \fIcurl_formadd(3)\fP as documented. The
data in this list must remain intact until you close this curl handle again data in this list must remain intact until you close this curl handle again
with \fIcurl_easy_cleanup(3)\fP. with \fIcurl_easy_cleanup(3)\fP.
Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header.
You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual.
.IP CURLOPT_REFERER .IP CURLOPT_REFERER
Pass a pointer to a zero terminated string as parameter. It will be used to Pass a pointer to a zero terminated string as parameter. It will be used to
set the Referer: header in the http request sent to the remote server. This set the Referer: header in the http request sent to the remote server. This
@@ -597,7 +627,7 @@ cookies are cookies without expiry date and they are meant to be alive and
existing for this "session" only. existing for this "session" only.
.IP CURLOPT_HTTPGET .IP CURLOPT_HTTPGET
Pass a long. If the long is non-zero, this forces the HTTP request to get back Pass a long. If the long is non-zero, this forces the HTTP request to get back
to GET. Only really usable if POST, PUT or a custom request have been used to GET. usable if a POST, HEAD, PUT or a custom request have been used
previously using the same curl handle. previously using the same curl handle.
.IP CURLOPT_HTTP_VERSION .IP CURLOPT_HTTP_VERSION
Pass a long, set to one of the values described below. They force libcurl to Pass a long, set to one of the values described below. They force libcurl to
@@ -690,6 +720,18 @@ Require SSL for the control connection or fail with \fICURLE_FTP_SSL_FAILED\fP.
.IP CURLFTPSSL_ALL .IP CURLFTPSSL_ALL
Require SSL for all communication or fail with \fICURLE_FTP_SSL_FAILED\fP. Require SSL for all communication or fail with \fICURLE_FTP_SSL_FAILED\fP.
.RE .RE
.IP CURLOPT_FTPSSLAUTH
Pass a long using one of the values from below, to alter how libcurl issues
\&"AUTH TLS" or "AUTH SSL" when FTP over SSL is activated (see
\fICURLOPT_FTP_SSL\fP).
.RS
.IP CURLFTPAUTH_DEFAULT
Allow libcurl to decide
.IP CURLFTPAUTH_SSL
Try "AUTH SSL" first, and only if that fails try "AUTH TLS"
.IP CURLFTPAUTH_TLS
Try "AUTH TLS" first, and only if that fails try "AUTH SSL"
.RE
.SH PROTOCOL OPTIONS .SH PROTOCOL OPTIONS
.IP CURLOPT_TRANSFERTEXT .IP CURLOPT_TRANSFERTEXT
A non-zero parameter tells the library to use ASCII mode for ftp transfers, A non-zero parameter tells the library to use ASCII mode for ftp transfers,
@@ -712,8 +754,8 @@ Pass a long as parameter. It contains the offset in number of bytes that you
want the transfer to start from. Set this option to 0 to make the transfer want the transfer to start from. Set this option to 0 to make the transfer
start from the beginning (effectively disabling resume). start from the beginning (effectively disabling resume).
.IP CURLOPT_RESUME_FROM_LARGE .IP CURLOPT_RESUME_FROM_LARGE
Pass an curl_off_t as parameter. It contains the offset in number of bytes Pass a curl_off_t as parameter. It contains the offset in number of bytes that
that you want the transfer to start from. (Added in 7.11.0) you want the transfer to start from. (Added in 7.11.0)
.IP CURLOPT_CUSTOMREQUEST .IP CURLOPT_CUSTOMREQUEST
Pass a pointer to a zero terminated string as parameter. It will be user Pass a pointer to a zero terminated string as parameter. It will be user
instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST
@@ -721,6 +763,8 @@ when doing an ftp directory listing. This is useful for doing DELETE or other
more or less obscure HTTP requests. Don't do this at will, make sure your more or less obscure HTTP requests. Don't do this at will, make sure your
server supports the command first. server supports the command first.
Restore to the internal default by setting this to NULL.
\fBNOTE:\fP Many people have wrongly used this option to replace the entire \fBNOTE:\fP Many people have wrongly used this option to replace the entire
request with their own, including multiple headers and POST contents. While request with their own, including multiple headers and POST contents. While
that might work in many cases, it will cause libcurl to send invalid requests that might work in many cases, it will cause libcurl to send invalid requests
@@ -738,6 +782,10 @@ can be used after a transfer to extract the received time (if any).
A non-zero parameter tells the library to not include the body-part in the A non-zero parameter tells the library to not include the body-part in the
output. This is only relevant for protocols that have separate header and body output. This is only relevant for protocols that have separate header and body
parts. On HTTP(S) servers, this will make libcurl do a HEAD request. parts. On HTTP(S) servers, this will make libcurl do a HEAD request.
To change back to GET, you should use \fICURLOPT_HTTPGET\fP. To change back to
POST, you should use \fICURLOPT_POST\fP. Setting \fICURLOPT_NOBODY\fP to zero
has no effect.
.IP CURLOPT_INFILESIZE .IP 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
libcurl what the expected size of the infile is. This value should be passed libcurl what the expected size of the infile is. This value should be passed
@@ -748,9 +796,19 @@ libcurl what the expected size of the infile is. This value should be passed
as a curl_off_t. (Added in 7.11.0) as a curl_off_t. (Added in 7.11.0)
.IP CURLOPT_UPLOAD .IP CURLOPT_UPLOAD
A non-zero parameter tells the library to prepare for an upload. The A non-zero parameter tells the library to prepare for an upload. The
\fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZE_LARGE\fP are also interesting \fICURLOPT_READDATA\fP and \fICURLOPT_INFILESIZEE\fP or
for uploads. If the protocol is HTTP, uploading means using the PUT request \fICURLOPT_INFILESIZE_LARGE\fP are also interesting for uploads. If the
unless you tell libcurl otherwise. protocol is HTTP, uploading means using the PUT request unless you tell
libcurl otherwise.
Using PUT with HTTP 1.1 implies the use of a "Expect: 100-continue" header.
You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual.
If you use PUT to a HTTP 1.1 server, you can upload data without knowing the
size before starting the transfer if you use chunked encoding. You enable this
by adding a header like "Transfer-Encoding: chunked" with
\fICURLOPT_HTTPHEADER\fP. With HTTP 1.0 or without chunked transfer, you must
specify the size.
.IP CURLOPT_MAXFILESIZE .IP CURLOPT_MAXFILESIZE
Pass a long as parameter. This allows you to specify the maximum size (in Pass a long as parameter. This allows you to specify the maximum size (in
bytes) of a file to download. If the file requested is larger than this value, bytes) of a file to download. If the file requested is larger than this value,
@@ -981,4 +1039,4 @@ If you try to set an option that libcurl doesn't know about, perhaps because
the library is too old to support it or the option was removed in a recent the library is too old to support it or the option was removed in a recent
version, this function will return \fICURLE_FAILED_INIT\fP. version, this function will return \fICURLE_FAILED_INIT\fP.
.SH "SEE ALSO" .SH "SEE ALSO"
.BR curl_easy_init "(3), " curl_easy_cleanup "(3), " .BR curl_easy_init "(3), " curl_easy_cleanup "(3), " curl_easy_reset "(3), "

View File

@@ -12,6 +12,8 @@ curl_easy_strerror - return string describing error code
.SH DESCRIPTION .SH DESCRIPTION
The curl_easy_strerror() function returns a string describing the CURLcode The curl_easy_strerror() function returns a string describing the CURLcode
error code passed in the argument \fIerrornum\fP. error code passed in the argument \fIerrornum\fP.
This function was added in libcurl 7.12.0
.SH RETURN VALUE .SH RETURN VALUE
A pointer to a zero terminated string. A pointer to a zero terminated string.
.SH "SEE ALSO" .SH "SEE ALSO"

View File

@@ -26,6 +26,9 @@ 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 the function itself. You must call \fIcurl_formfree\fP after the form post has
been done to free the resources again. been done to free the resources again.
Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header.
You can disable this header with \fICURLOPT_HTTPHEADER\fP as usual.
First, there are some basics you need to understand about multipart/formdata First, there are some basics you need to understand about multipart/formdata
posts. Each part consists of at least a NAME and a CONTENTS part. If the part posts. Each part consists of at least a NAME and a CONTENTS part. If the part
is made for file upload, there are also a stored CONTENT-TYPE and a is made for file upload, there are also a stored CONTENT-TYPE and a
@@ -126,8 +129,8 @@ defines.
.SH EXAMPLE .SH EXAMPLE
.nf .nf
struct HttpPost* post = NULL; struct curl_httppost* post = NULL;
struct HttpPost* last = NULL; struct curl_httppost* last = NULL;
char namebuffer[] = "name buffer"; char namebuffer[] = "name buffer";
long namelength = strlen(namebuffer); long namelength = strlen(namebuffer);
char buffer[] = "test buffer"; char buffer[] = "test buffer";

View File

@@ -4,35 +4,36 @@
.\" .\"
.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
curl_getdate - Convert an date in a ASCII string to number of seconds since curl_getdate - Convert an date string to number of seconds since January 1,
January 1, 1970 1970
.SH SYNOPSIS .SH SYNOPSIS
.B #include <curl/curl.h> .B #include <curl/curl.h>
.sp .sp
.BI "time_t curl_getdate(char *" datestring ", time_t *"now" ); .BI "time_t curl_getdate(char *" datestring ", time_t *"now" );"
.ad .ad
.SH DESCRIPTION .SH DESCRIPTION
This function returns the number of seconds since January 1st 1970, for the This function returns the number of seconds since January 1st 1970 in the UTC
date and time that the time zone, for the date and time that the \fIdatestring\fP parameter
.I datestring specifies. The \fInow\fP parameter is not used, pass a NULL there.
parameter specifies. The
.I now \fBNOTE:\fP This function was rewritten for the 7.12.2 release and this
parameter is there and should hold the current time to allow the datestring to documentation covers the functionality of the new one. The new one is not
specify relative dates/times. Read further in the date string parser section feature-complete with the old one, but most of the formats supported by the
below. new one was supported by the old too.
.SH PARSING DATES AND TIMES .SH PARSING DATES AND TIMES
A "date" is a string, possibly empty, containing many items separated by A "date" is a string containing several items separated by whitespace. The
whitespace. The whitespace may be omitted when no ambiguity arises. The order of the items is immaterial. A date string may contain many flavors of
empty string means the beginning of today (i.e., midnight). Order of the items:
items is immaterial. A date string may contain many flavors of items:
.TP 0.8i .TP 0.8i
.B calendar date items .B calendar date items
This can be specified in a number of different ways. Including 1970-09-17, 70-9-17, 70-09-17, 9/17/72, 24 September 1972, 24 Sept 72, 24 Sep 72, Sep 24, 1972, 24-sep-72, 24sep72. Can be specified several ways. Month names can only be three-letter
The year can also be omitted, for example: 9/17 or "sep 17". abbrivations, numbers can be zero-prefixed and the year may use 2 or 4 digits.
Examples: 06 Nov 1994, 06-Nov-94 and Nov-94 6.
.TP .TP
.B time of the day items .B time of the day items
This string specifies the time on a given day. Syntax supported includes: This string specifies the time on a given day. You must specify it with 6
18:19:0, 18:19, 6:19pm, 18:19-0500 (for specifying the time zone as well). digits with two colons: HH:MM:SS. To not include the time in a date string,
will make the function assume 00:00:00. Example: 18:19:21.
.TP .TP
.B time zone items .B time zone items
Specifies international time zone. There are a few acronyms supported, but in Specifies international time zone. There are a few acronyms supported, but in
@@ -40,41 +41,52 @@ general you should instead use the specific relative time compared to
UTC. Supported formats include: -1200, MST, +0100. UTC. Supported formats include: -1200, MST, +0100.
.TP .TP
.B day of the week items .B day of the week items
Specifies a day of the week. If this is mentioned alone it means that day of Specifies a day of the week. Days of the week may be spelled out in full:
the week in the future. `Sunday', `Monday', etc or they may be abbreviated to their first three
letters. This is usually not info that adds anything.
Days of the week may be spelled out in full: `Sunday', `Monday', etc or they
may be abbreviated to their first three letters, optionally followed by a
period. The special abbreviations `Tues' for `Tuesday', `Wednes' for
`Wednesday' and `Thur' or `Thurs' for `Thursday' are also allowed.
A number may precede a day of the week item to move forward supplementary
weeks. It is best used in expression like `third monday'. In this context,
`last DAY' or `next DAY' is also acceptable; they move one week before or
after the day that DAY by itself would represent.
.TP
.B relative items
A relative item adjusts a date (or the current date if none) forward or
backward. Example syntax includes: "1 year", "1 year ago", "2 days", "4
weeks".
The string `tomorrow' is worth one day in the future (equivalent to `day'),
the string `yesterday' is worth one day in the past (equivalent to `day ago').
.TP .TP
.B pure numbers .B pure numbers
If the decimal number is of the form YYYYMMDD and no other calendar date item If a decimal number of the form YYYYMMDD appears, then YYYY is read as the
appears before it in the date string, then YYYY is read as the year, MM as the year, MM as the month number and DD as the day of the month, for the specified
month number and DD as the day of the month, for the specified calendar date. calendar date.
.PP .PP
.SH EXAMPLES
.nf
Sun, 06 Nov 1994 08:49:37 GMT
Sunday, 06-Nov-94 08:49:37 GMT
Sun Nov 6 08:49:37 1994
06 Nov 1994 08:49:37 GMT
06-Nov-94 08:49:37 GMT
Nov 6 08:49:37 1994
06 Nov 1994 08:49:37
06-Nov-94 08:49:37
1994 Nov 6 08:49:37
GMT 08:49:37 06-Nov-94 Sunday
94 6 Nov 08:49:37
1994 Nov 6
06-Nov-94
Sun Nov 6 94
1994.Nov.6
Sun/Nov/6/94/GMT
Sun, 06 Nov 1994 08:49:37 CET
06 Nov 1994 08:49:37 EST
Sun, 12 Sep 2004 15:05:58 -0700
Sat, 11 Sep 2004 21:32:11 +0200
20040912 15:05:58 -0700
20040911 +0200
.fi
.SH STANDARDS
This parser was written to handle date formats specified in RFC 822 (including
the update in RFC 1123) using time zone name or time zone delta and RFC 850
(obsoleted by RFC 1036) and ANSI C's asctime() format. These formats are the
only ones RFC2616 says HTTP applications may use.
.SH RETURN VALUE .SH RETURN VALUE
This function returns zero when it fails to parse the date string. Otherwise This function returns -1 when it fails to parse the date string. Otherwise it
it returns the number of seconds as described. returns the number of seconds as described.
.SH AUTHORS .SH REWRITE
Originally written by Steven M. Bellovin <smb@research.att.com> while at the The former version of this function was built with yacc and was not only very
University of North Carolina at Chapel Hill. Later tweaked by a couple of large, it was also never quite understood and it wasn't possible to build with
people on Usenet. Completely overhauled by Rich $alz <rsalz@bbn.com> and Jim non-GNU tools since only Bison could make it thread-safe!
Berets <jberets@bbn.com> in August, 1990.
It has been modified extensively since imported to curl. The rewrite was done for 7.12.2. The new one is much smaller and use simpler
.SH "SEE ALSO" code.
.BR GNU date(1)

View File

@@ -16,6 +16,13 @@ function does not require that there actually is any data available for
reading or that data can be written, it can be called just in case. It will reading or that data can be written, it can be called just in case. It will
write the number of handles that still transfer data in the second argument's write the number of handles that still transfer data in the second argument's
integer-pointer. integer-pointer.
When you call curl_multi_perform() and the amount of \fIrunning_handles\fP is
changed from the previous call (or is less than the amount of easy handles
you've added to the multi handle), you know that there is one or more
transfers less "running". You can then call \fIcurl_multi_info_read(3)\fP to
get information about each individual completed transfer, and that returned
info includes CURLcode and more.
.SH "RETURN VALUE" .SH "RETURN VALUE"
CURLMcode type, general libcurl multi interface error code. CURLMcode type, general libcurl multi interface error code.
@@ -34,4 +41,5 @@ file descriptors, then it'll wait for action on them using select() and as
soon as one or more of them are ready, \fIcurl_multi_perform(3)\fP gets soon as one or more of them are ready, \fIcurl_multi_perform(3)\fP gets
called. called.
.SH "SEE ALSO" .SH "SEE ALSO"
.BR curl_multi_cleanup "(3)," curl_multi_init "(3)," curl_multi_fdset "(3)" .BR curl_multi_cleanup "(3), " curl_multi_init "(3), "
.BR curl_multi_fdset "(3), " curl_multi_info_read "(3)"

View File

@@ -12,6 +12,8 @@ curl_multi_strerror - return string describing error code
.SH DESCRIPTION .SH DESCRIPTION
The curl_multi_strerror() function returns a string describing the CURLMcode The curl_multi_strerror() function returns a string describing the CURLMcode
error code passed in the argument \fIerrornum\fP. error code passed in the argument \fIerrornum\fP.
This function was added in libcurl 7.12.0
.SH RETURN VALUE .SH RETURN VALUE
A pointer to a zero terminated string. A pointer to a zero terminated string.
.SH "SEE ALSO" .SH "SEE ALSO"

View File

@@ -6,7 +6,7 @@ curl_share_cleanup - Clean up a shared object
.SH SYNOPSIS .SH SYNOPSIS
.B #include <curl/curl.h> .B #include <curl/curl.h>
.sp .sp
.BI "CURLSHcode curl_share_cleanup( );" .BI "CURLSHcode curl_share_cleanup(CURLSH *" share_handle ");"
.ad .ad
.SH DESCRIPTION .SH DESCRIPTION
This function deletes a shared object. The share handle cannot be used anymore This function deletes a shared object. The share handle cannot be used anymore

View File

@@ -12,6 +12,8 @@ curl_share_strerror - return string describing error code
.SH DESCRIPTION .SH DESCRIPTION
The curl_share_strerror() function returns a string describing the CURLSHcode The curl_share_strerror() function returns a string describing the CURLSHcode
error code passed in the argument \fIerrornum\fP. error code passed in the argument \fIerrornum\fP.
This function was added in libcurl 7.12.0
.SH RETURN VALUE .SH RETURN VALUE
A pointer to a zero terminated string. A pointer to a zero terminated string.
.SH "SEE ALSO" .SH "SEE ALSO"

Some files were not shown because too many files have changed in this diff Show More