6838f74fe0
Robert Marlow reported.
2377 lines
97 KiB
Plaintext
2377 lines
97 KiB
Plaintext
_ _ ____ _
|
||
___| | | | _ \| |
|
||
/ __| | | | |_) | |
|
||
| (__| |_| | _ <| |___
|
||
\___|\___/|_| \_\_____|
|
||
|
||
Changelog
|
||
|
||
Daniel (22 April 2004)
|
||
- David Byron found and fixed a small bug with the --fail and authentication
|
||
stuff added a few weeks ago. Turns out that if you specify --proxy-ntlm and
|
||
communicate with a proxy that requires basic authentication, the proxy
|
||
properly returns a 407, but the failure detection code doesn't realize it
|
||
should give up, so curl returns with exit code 0. Test case 162 added to
|
||
verify the functionality.
|
||
|
||
- allow newlines in the contents when doing -F "var=[contents]"
|
||
Robert Marlow reported.
|
||
|
||
- If a transfer is found out to be only partial, libcurl will now treat that
|
||
as a problem serious enough to skip the final QUIT command before closing
|
||
the control connection. To avoid the risk that it will "hang" waiting for
|
||
the QUIT response. Added test case 161 to verify this.
|
||
|
||
Daniel (21 April 2004)
|
||
- Modified the heuristics for dealing with the test 160 scenario. When a
|
||
connection is re-used and nothing at all is received from it (because the
|
||
server closes the connection), we will now retry the request on a fresh new
|
||
connection. The previous ECONNRESET stuff from January 30 was removed again
|
||
as it didn't detect the situation good enough.
|
||
|
||
Daniel (20 April 2004)
|
||
- Added test case 160 to verify that curl works correctly when it gets a
|
||
connection reset when trying to re-use a connection. It should then simply
|
||
create a new connection and resend the request.
|
||
|
||
Daniel (19 April 2004)
|
||
- No more 512 byte limit for host name (inclusing name + password) in libcurl.
|
||
An added bonus is that we use less memory for the typical (shorter URL)
|
||
case.
|
||
|
||
- Cleaned up the sources to better use the terms 'hostname' and 'path'
|
||
internally when referring to that data. The buffers used for keep that info
|
||
is called 'namebuffer' and 'pathbuffer'. Much easier to read and understand
|
||
than the previous mess.
|
||
|
||
Daniel (15 April 2004)
|
||
- Modified runtests.pl again to remove all log files in the log/ dir between
|
||
each test, and then made -p display all non-zero byte files in the log dir.
|
||
It should make that data more usable and contain less rubbish.
|
||
|
||
- ftpserver.pl now produces log files more similar to how the sws ones look
|
||
and they now also contains a bit more details to help debugging ftp
|
||
problems.
|
||
|
||
- Removed the fixed maximum amount of dir levels the FTP code supported.
|
||
Previously we had a fixed array for 100 levels, now we save space in each
|
||
handle by allocating only for a few level by default and then enlarging that
|
||
in case of need (with no maximum depth). Adjusted test case 142 to verify
|
||
that 150 dir levels work fine. An added bonus is that we use less memory
|
||
for the typical (not very deep) case.
|
||
|
||
Daniel (14 April 2004)
|
||
- Asking for CURL_IPRESOLVE_V6 when ipv6 addresses can't be resolved will
|
||
now cause the resolve function to return NULL immediately. This flaw was
|
||
pointed out by Gisle Vanem.
|
||
|
||
- Gisle Vanem made curl -4/-6 actually set the desired option to libcurl.
|
||
|
||
- runtests.pl now has a new option (-p) that will display "interesting" log
|
||
files to stdout in case of a test failure. This is primarily intended to be
|
||
used in the 'full-test' make target that is used by the autobuild tests, as
|
||
we then get a much better chance to understand (remote) test failures based
|
||
on autobuild logs alone.
|
||
|
||
Daniel (13 April 2004)
|
||
- Gisle Vanem made the multi interface work again on Windows even when built
|
||
without ares. Before this, select() would return -1 during the name resolve
|
||
phase since curl_multi_fdset() didn't return any fd_set at all which wasn't
|
||
appreciated!
|
||
|
||
- curl_easy_duphandle() now duplicates the tcp_nodelay info as well.
|
||
|
||
Daniel (11 April 2004)
|
||
- Applied David Byron's patch for the MSVC libcurl makefile for builds with
|
||
zlib.
|
||
|
||
Daniel (9 April 2004)
|
||
- Dirk Manske improved the timer resolution for CURLINFO_*_TIME, it can now
|
||
be down to usec if the system sypports it.
|
||
|
||
Daniel (7 April 2004)
|
||
- A request that sends "Expect: 100-continue" and gets nothing but a single
|
||
100 response back will now return a CURLE_GOT_NOTHING. Test 158 verifies.
|
||
|
||
- The strtoofft() macro is now named curlx_strtoofft() to use the curlx_*
|
||
approach fully.
|
||
|
||
Daniel (6 April 2004)
|
||
- Gisle Vanem's fixed bug #927979 reported by Nathan O'Sullivan. The problem
|
||
made libcurl on Windows leak a small amount of memory in each name resolve
|
||
when not used as a DLL.
|
||
|
||
- New authentication code added, particularly noticable when doing POST or PUT
|
||
with Digest or NTLM. libcurl will now use HEAD to negotiate the
|
||
authentication and when done perform the requested POST. Previously libcurl
|
||
sent POST immediately and expected the server to reply a final status code
|
||
with an error and then libcurl would not send the request-body but instead
|
||
send then next request in the sequence.
|
||
|
||
The reason for this change is due to IIS6 barfing on libcurl when we attempt
|
||
to POST with NTLM authentication. The reason for the problems is found in
|
||
RFC2616 section 8.2.3 regarding how servers should deal with the 100
|
||
continue request-header:
|
||
|
||
If it responds with a final status code, it MAY close the transport
|
||
connection or it MAY continue to read and discard the rest of the
|
||
request.
|
||
|
||
Previous versions of IIS clearly did close the connection in this case,
|
||
while this newer version decided it should "read and discard". That would've
|
||
forced us to send the whole POST (or PUT) data only to have it discarded and
|
||
then be forced to send it again. To avoid that huge penality, we switch to
|
||
using HEAD until we are authenticated and then send the POST.
|
||
|
||
The only actual drawback I can think of (except for the odd sites that might
|
||
treat HEAD differently than they would treat POST/PUT when given the same
|
||
URL) is that if you do POST with CURLAUTH_ANY set and the site requires NO
|
||
authentication, libcurl will still use a HEAD in a first round and then do a
|
||
POST.
|
||
|
||
If you do a HEAD or a GET on a site using CURLAUTH_ANY, libcurl will send
|
||
an un-authenticated request at once, which then is the only request if the
|
||
site requires no auth.
|
||
|
||
Alan Pinstein helped me work out the protocol details by figuring out why
|
||
libcurl failed and what IIS6 expects.
|
||
|
||
- The --limit-rate logic was corrected and now it works a lot better for
|
||
higher speeds, such as '10m' or similar. Reported in bug report #930249.
|
||
|
||
- Introducing curlx_tvnow() and curlx_tvdiff() using the new curlx_* fashion.
|
||
#include "timeval.h" from the lib dir to get the protos etc. Note that
|
||
these are NOT part of the libcurl API. The curl app simply uses the same
|
||
source files as the library does and therefore the file needs to be compiled
|
||
and linked with curl too, not just when creating libcurl.
|
||
|
||
- lib/strerror.c no longer uses sys_nerr on non-windows platforms since it
|
||
isn't portable enough
|
||
|
||
Daniel (2 April 2004)
|
||
- In the curl_strnqual.3 man page, we now prepend the man3 dir to the file
|
||
name to work better. As pointed out by Robin Kay.
|
||
|
||
- Andr<64>s Garc<72>a updated the mingw makefiles.
|
||
|
||
- Dirk Manske fixed a problem I recently added in the progress meter code that
|
||
broke subsecond resolution for CURLINFO_TOTAL_TIME. He also pointed out a
|
||
mistake in the code that produces the final update of the progress meter
|
||
that would often prevent it from actually being updated that final time.
|
||
|
||
Daniel (1 April 2004)
|
||
- Dirk Manske fixed a memory leak that happened when we use ares for name
|
||
resolves and decides to time-out before ares does it. This fix uses the
|
||
brand new ares_cancel() function which is not present in c-ares 1.1.0.
|
||
|
||
When told to enable ares, the configure script now checks for presence of
|
||
the ares_cancel function to alert users if they attempt to use a too old
|
||
c-ares library.
|
||
|
||
Daniel (31 March 2004)
|
||
- Roy Shan fixed a flaw that prevented ares name resolve timeouts to occur!
|
||
|
||
- Dirk Manske found out that libcurl timed out waiting for resolves far too
|
||
easy when libcurl was built to use (c-)ares for name resolving.
|
||
|
||
- Further Digest fixing and a successful test case 153 now makes me believe
|
||
Mitz Wark's problems are fixed.
|
||
|
||
- Andres Garcia figured out that test case 63, while working, only proved a
|
||
flaw in libcurl's 'http_proxy' parser when a user name and password is
|
||
provided. The user name was not extracted properly (and 'http' was always
|
||
used as user name).
|
||
|
||
- Andr<64>s Garc<72>a fixed compiler warnings in our ioctlsocket() usage.
|
||
|
||
Daniel (30 March 2004)
|
||
- Joe Halpin faced problems with the getnameinfo() argument ai_flags and the
|
||
particular bit named 'NI_WITHSCOPEID' on Solaris 9 for Intel. I've now
|
||
written a configure test that checks for a working NI_WITHSCOPEID
|
||
implemenation. No code uses the result from this test yet, it is still
|
||
experimental. James Carlson wrote in comp.unix.solaris: "It's a bug
|
||
(5006623) -- it's not supported and shouldn't be in the header file."
|
||
|
||
- I provided Mitz Wark with a first patch in order to fix libcurl's problems
|
||
to re-negotiate Digest authentication (when 'stale=true' is included in the
|
||
response header).
|
||
|
||
- Roy Shan discovered that the multi interface didn't properly timeout name
|
||
lookups which could make handles get stuck in that state and thus never get
|
||
completed. I've produced a first test patch that attempts to correct this.
|
||
|
||
- David Byron's patch was appplied to make CURLOPT_FAILONERROR work nicely
|
||
even with authentcations such as NTLM or Digest enabled. Test cases 150, 151
|
||
and 152 were added to verify the functionality.
|
||
|
||
Daniel (29 March 2004)
|
||
- Gisle Vanem updated files for the djgpp/MS-DOS build.
|
||
|
||
- Andr<64>s Garc<72>a helped me work out a fix for the runtests.pl script to make
|
||
the file:// tests run fine when tested with the mingw-built version of curl.
|
||
|
||
- Fixed an include issue with netinet/tcp.h on AIX, based on input by Tor.
|
||
This also required a minor fix of the configure script.
|
||
|
||
- The postit2.c source example used the wrong struct name for the post data.
|
||
|
||
Daniel (26 March 2004)
|
||
- Gisle Vanem improved ipv6 support on windows by making the curl build to use
|
||
the correct getaddrinfo() function.
|
||
|
||
Daniel (25 March 2004)
|
||
- It turned out that AIX, despite having a "thread-safe libc", doesn't offer
|
||
all traditional functions thread-safe. This URL is informative on this
|
||
subject:
|
||
|
||
http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \
|
||
genprogc/thread_quick_ref.htm
|
||
|
||
As a result of this, we now check for three *_r() functions on recent AIX
|
||
versions as well that the URL mentions aren't thread-safe in AIX 5.1.
|
||
|
||
- renamed curl_strerror.[ch] to strerror.[ch]
|
||
|
||
- Joe Halpin added CURLOPT_TCP_NODELAY and --tcp-nodelay to make it possible
|
||
for users to disable the Nagle algorthim-usage.
|
||
|
||
- Tor Arntsen provided some interesting strerror_r() knowledge. glibc has its
|
||
own API which differs from the POSIX one. Daniel adjusted the configure
|
||
script to detect the version in use, and the code now uses the new defines
|
||
accordingly.
|
||
|
||
- Fixed some build flaws with the new lib/curl_strerror.c source file.
|
||
|
||
Daniel (24 March 2004)
|
||
- Gisle Vanem's fix to replace the bad use of strerror(). This introduces
|
||
Curl_strerror() that attempts to be thread-safe _and_ works on Windows too!
|
||
|
||
- Tor Arntsen spell-fixed lots of libcurl man pages.
|
||
|
||
- Tor Arntsen made testcurl.pl work with older perl 5 versions, and Daniel
|
||
made it not use chdir .. to go back, as that isn't very good when you've
|
||
setup a testdir containing symlinks.
|
||
|
||
- Added a check for strerror_r() in the configure script.
|
||
|
||
Daniel (23 March 2004)
|
||
- Added Greg Hewgill's testcurl.pl script to CVS. We have not moved over to
|
||
use this script for the real distributed testing just yet, but it is only
|
||
a matter of time.
|
||
|
||
- Gisle Vanem provided code that makes curl report a better error message
|
||
if --interface fails on windows.
|
||
|
||
- The regular progress meter is now fixed to never wrap due to long lines. All
|
||
fields are now static sized. If the time in the time fields get a time value
|
||
that would represent a time that is 100 hours or more (if not, it remains
|
||
using a HH:MM:SS display), it switches first to a "NNNd NNh" display (for
|
||
days and hours) and if that isn't enough it switches to a "NNNd" display if
|
||
it is more than 999 days.
|
||
|
||
Several of the calculations were also moved to fixed-point math instead of
|
||
using doubles.
|
||
|
||
Daniel (22 March 2004)
|
||
- Glen Nakamura noticed CURLINFO_CONTENT_LENGTH_DOWNLOAD didn't work as it
|
||
used to do if CURLOPT_NOBODY is set TRUE.
|
||
|
||
- Kevin Roth patched the cygwin package makefile and README to adjust to
|
||
new cygwin packaging guidelines.
|
||
|
||
- Enabled "NT responses" in the NTLM authentication. Doing this simply means
|
||
that we provide an extra chunk of data in each "type-3 message". The only
|
||
reason for doing this is that it seems that using only the "Lanmanager hash"
|
||
(as we've been doing until now) doesn't support passwords longer than 14
|
||
characters and it turns out there are users out there who want to use
|
||
libcurl and NTLM with such passwords! ;-) Seven NTLM-related test cases were
|
||
updated accordingly. Mentioned as issue 29 in TODO-RELEASE, bug report
|
||
#915609
|
||
|
||
- Moved the generated libcurl version info to a new header file, named
|
||
curl/curlver.h. Now interested parties can include ONLY version info, should
|
||
anyone want that (and it seems at least some windows resource files would).
|
||
Mentioned as issue 27 in TODO-RELEASE.
|
||
|
||
Daniel (21 March 2004)
|
||
- Fixed the root Makefile to use tabs for the netware target. G<>nter Knauf
|
||
pointed this out.
|
||
|
||
- Marty Kuhrt's VMS cleanup
|
||
|
||
- Thomas Schwinge made buildconf recognize ACLOCAL_FLAGS to invoke aclocal
|
||
with particular pre-determined options.
|
||
|
||
Version 7.11.1 (19 March 2004)
|
||
|
||
Daniel (18 March 2004)
|
||
- Tor Arntsen brought some info about SGI IRIX:
|
||
|
||
IRIX supports 3 different executable/object formats, -32, -n32 and -64.
|
||
-n32 is default 32-bit format, -32 is the "old" 32-bit format, and -64 is
|
||
the 64-bit format. Libraries for the different formats are in lib, lib32
|
||
and lib64 respectively.
|
||
|
||
We've now adjusted the configure script to adapt to this when scanning for
|
||
3rd party libs, such as OpenSSL.
|
||
|
||
Daniel (17 March 2004)
|
||
- Watz pointed out a few missing files in the MSVC project description file.
|
||
|
||
- G<>nter Knauf brought patches, code and makefiles to build curl on Novell
|
||
NetWare.
|
||
|
||
Daniel (15 March 2004)
|
||
- Lots of libcurl man pages were updated to contain references to other man
|
||
pages the recognized way so that they appear as nice hyperlinks in the HTML
|
||
versions.
|
||
|
||
- buildconf now checks the m4 version too, since autoconf requires a GNU m4
|
||
version to build proper configure scripts.
|
||
|
||
Daniel (12 March 2004)
|
||
- Added CURLOPT_POSTFIELDSIZE_LARGE, the large file version of
|
||
CURLOPT_POSTFIELDSIZE to allow POSTs larger than 2GB.
|
||
|
||
- David Byron fixed an uninitialized variable case/crash.
|
||
|
||
Daniel (10 March 2004)
|
||
- Jeff Lawson fixed the SSL connection to deal with received signals during the
|
||
connect.
|
||
|
||
- Changed the OS string for win32 to become "i386-pc-win32".
|
||
|
||
Daniel (9 March 2004)
|
||
- Changed the internals to use curl_socket_t for socket variable type. This
|
||
should enable us to build with less warnings on Windows, where SOCKET is
|
||
used which is an unsigned int, while most other platforms use a mere int.
|
||
|
||
- Modified lib/config-win32.h to build fine on MSVC again.
|
||
|
||
Version 7.11.1-pre1 (8 March 2004)
|
||
|
||
Daniel (8 March 2004)
|
||
- Minor fix to make curl CURL_VERSION_LARGEFILE is only set if curl_off_t is
|
||
larger than 4 bytes.
|
||
|
||
Daniel (4 March 2004)
|
||
- Improved PUT/POST with NTLM/Digest authentication, the so called issue 12.
|
||
|
||
- Modified the test HTTP server a lot to work with the upcoming changes for
|
||
PUT/POST with NTLM/Digest authentication (like test case 88). Added Andr<64>s
|
||
Garc<72>a's win32-changes. Improved the logging.
|
||
|
||
- Fixed the file:-related progress/getinfo stuff a bit more.
|
||
|
||
Daniel (4 March 2004)
|
||
- I corrected a problem with the multi interface when following a Location:
|
||
header or when doing multiple-request authentications. A subsequent request
|
||
could erroneously re-use a previous connection that was sent with
|
||
Connection: close. Christopher R. Palmer reported.
|
||
|
||
- Andr<64>s Garc<72>a patched curl to prevent warnings while compiling with mingw,
|
||
mainly because it is now possible to have both WIN32 and HAVE_CONFIG_H
|
||
defined.
|
||
|
||
- When transferring files from a file: URL, the progress meter and other
|
||
transfer metrics were not updated properly.
|
||
|
||
- David Byron provided a "version resource" file to the curl executable for
|
||
the windows builds.
|
||
|
||
Daniel (3 March 2004)
|
||
- David Byron's work on making libcurl only require winsock 1.1 on Windows
|
||
machines.
|
||
|
||
- More variable cleanups based on compiler warnings generated by Tor Arntsen's
|
||
autobuilds with MIPSPro.
|
||
|
||
- Joe Halpin helped us fix some pedantic compiler warnings on FreeBSD.
|
||
|
||
- Applied Tom Bates' patch to build on nsr-tandem-nsk.
|
||
|
||
- Dan Fandrich corrected some flaws in the configure GSS detection.
|
||
|
||
Daniel (2 March 2004)
|
||
- Fixed the libcurl code to use FORMAT_OFF_T for printf() formatting
|
||
curl_off_t types internally.
|
||
|
||
Daniel (1 March 2004)
|
||
- Added CURL_VERSION_LARGEFILE as a feature-bit in the curl_version_info()
|
||
response, that signals if this libcurl supports >2GB files. curl -V now
|
||
outputs 'Largefile' in the Features: field if this is the case. Most systems
|
||
are likely to support this.
|
||
|
||
- We offer a CURL_FORMAT_OFF_T define in the public header, which can be used
|
||
to printf() curl_off_t variables. We also modified the libcurl sources to
|
||
use this define instead of the previous %Od approach (although I've left the
|
||
O-flag functional in the code). This should also prevent compilers to warn
|
||
on the home-grown option.
|
||
|
||
- Fixed the resume-check code to test for a working resume at the end of the
|
||
headers and not at the first body-byte.
|
||
|
||
- CURLOPT_DNS_USE_GLOBAL_CACHE is now considered obsolete. Stop using it. If
|
||
you need a global DNS cache for whatever reason, use the share interface and
|
||
you'll get a global cache that works the way it should work. You can even
|
||
have any number of global caches, all at your command. This is now also
|
||
mentioned in the docs.
|
||
|
||
- Made the *printf code support the z-flag to enable size_t printf() in a
|
||
manner similar to how glibc allows it. To make printfing of this work on
|
||
platforms with 64bit size_t and 32bit ints. If there even are any! ;-)
|
||
|
||
- Christopher R. Palmer discovered that if you CURLOPT_FRESH_CONNECT and
|
||
CURLAUTH_NTLM (or CURLAUTH_ANY and libcurl then picked NTLM), libcurl would
|
||
loop without succeeding to authenticate due to the new connection that was
|
||
made for all round-trips in the authentication. Now, the FRESH_CONNECT is
|
||
remade to only matter for the first connection made with curl_easy_perform()
|
||
and all the rest that might follow due to FOLLOWLOCATION or HTTP
|
||
authentication are now ignoring that option.
|
||
|
||
- Adjusted the QUIT code slightly since it could core-dump.
|
||
|
||
- Corrected the test suite's FTP server to provide a correct size to the
|
||
'verifiedserver' request.
|
||
|
||
Daniel (27 February 2004)
|
||
- Joe Halpin made the FTP code send QUIT on the control connection before
|
||
disconnecting the TCP connection. This is what good-behaving ftp clients
|
||
should do.
|
||
|
||
Daniel (26 February 2004)
|
||
- David Byron updated several files to make curl build fine on MSVC 6. He
|
||
also added the 'buildconf.bat' that works like the 'buildconf + configure'
|
||
combo does on unixes.
|
||
|
||
- Gisle Vanem made the memdebug stuff support calloc() as well.
|
||
|
||
- Tor Arntsen pointed out that testcurl.sh needed to remove the generated
|
||
files in order to have them re-generated in each build.
|
||
|
||
- Andy Serpa found out that the share interface did not enjoy life when not
|
||
having the lock and unlock callbacks set, even though documented to be
|
||
OK. It still is OK, and now the code won't segfault anymore!
|
||
|
||
Daniel (25 February 2004)
|
||
- Based on a patch by Greg Hewgill I modified how long long is used in the
|
||
mprintf code, as we can use a 64bit type with MSVC that is a long long
|
||
equivalent. This corrects some weird large file behaviors on windows.
|
||
|
||
- Tor Arntsen helped me work out --enable-debug to work better with different
|
||
versions of the gcc and icc compilers.
|
||
|
||
- Added CURLOPT_SHARE to the curl_easy_setopt.3 man page.
|
||
|
||
Daniel (22 February 2004)
|
||
- Applied the final pieces of Gisle Vanem's patch that brings a working name
|
||
resolve timeout to the windows versions of curl!
|
||
|
||
Daniel (21 February 2004)
|
||
- David Byron's fix to allow the speed-limit logic work even if you set
|
||
limit-rate. It does work on the expense of the rate limiter.
|
||
|
||
Daniel (20 February 2004)
|
||
- configure --enable-debug with gcc now also tries to detect the icc compiler
|
||
(which somehow gets treated as if it is a gcc) to stop using all the gcc
|
||
options with it, and we also provide -isystem options for each extra -I
|
||
option the configure script has figured out (for OpenSSL, kerberos, zlib,
|
||
Heimdal etc). This of course to prevent warnings on headers we don't have
|
||
control of.
|
||
|
||
Daniel (19 February 2004)
|
||
- Doug Porter made libcurl use the HOME environment variable before the
|
||
getpwuid results when looking for .netrc files.
|
||
|
||
- If 'configure --enable-debug' is used with gcc, it now checks which gcc
|
||
version it is and uses as picky compiler options as possible for the
|
||
particular version.
|
||
|
||
- Code that can be used in both the lib and in the curl app is now made to use
|
||
the curlx_ prefix. The first function to be available like this is the
|
||
curlx_strtoll() function. This is made to allow the app to use existing code,
|
||
but without polluting the libcurl API. Further explanations posted here:
|
||
|
||
http://curl.haxx.se/mail/lib-2004-02/0215.html
|
||
|
||
Daniel (18 February 2004)
|
||
- Fixed buildconf to not use "which" as AIX and Tru64 have what have been
|
||
referred to as "horribly broken 'which' programs".
|
||
|
||
- Made sure dns cache timeout set to -1 really means caching forever.
|
||
|
||
Daniel (17 February 2004)
|
||
- Made it possibly to build c-ares with the libcurl memdebug system to better
|
||
track memory.
|
||
|
||
Daniel (16 February 2004)
|
||
- When using ares, we now initialize the ares 'channel' in curl_easy_init()
|
||
and re-use that same handle during the entire curl handle's life-time. It
|
||
improves performance.
|
||
|
||
- Fixed a problem when displaying verbose for ipv6-enabled libcurls and
|
||
re-used connections. Problem reported and fix verified by Grigory Entin.
|
||
|
||
- Jeff Lawson fixed the version-check in the SOCKS5 code.
|
||
|
||
Daniel (15 February 2004)
|
||
- Fixed a case where a host cache entry was not flagged in-use properly when a
|
||
cached entry was used.
|
||
|
||
- Andr<64>s Garc<72>a's patch that checks for winmm in the configure script was
|
||
applied.
|
||
|
||
Daniel (13 February 2004)
|
||
- Ben Greear's SO_BINDTODEVICE patch for the binding of the local end to a
|
||
specific network interface.
|
||
|
||
- Greg Hewgill found out that the variable holding 'contentlength' wasn't big
|
||
enough to hold a large file!
|
||
|
||
- Tor Arntsen fixed a 64bit-related problem in date-related code in the ftp
|
||
department, and there was another potential problem in the name resolve code
|
||
too.
|
||
|
||
Daniel (11 February 2004)
|
||
- Removed a few variables that were only set but never used, as some compilers
|
||
warn about that and we do not like compiler warnings!
|
||
|
||
- Removed the need for symlinks in the tests/data directory if curl is built
|
||
outside of the source directory and the 'make test' is used. This was done
|
||
by providing a "source dir path" to the scripts/servers.
|
||
|
||
- Now, if the configure script can't find an nroff tool or an option to nroff
|
||
to use to convert man pages with, it will completely switch off the built-in
|
||
manual.
|
||
|
||
- 'configure --disable-manual' completely disables the built-in manual from
|
||
the curl command tool.
|
||
|
||
- Andr<64>s Garc<72>a fixed the configure script and a minor source edit, and now
|
||
he has managed to get msys/mingw to run configure and then build!
|
||
|
||
Daniel (9 February 2004)
|
||
- The default HTTP Accept: header was modified to the much simpler
|
||
"Accept: */*".
|
||
|
||
- P R Schaffner updated the curl-ssl spec file for RPMs.
|
||
|
||
- Dominick Meglio brought lots of documentation for the share interface's man
|
||
pages that were previously missing.
|
||
|
||
- Tor Arntsen provided a patch that makes libcurl work-around a bug in the
|
||
AIX5 implementation of getaddrinfo(). This makes the FTP PORT stuff work on
|
||
ipv6-enabled AIX builds.
|
||
|
||
- Ken Rastatter provided portability fixes for the curlgtk.c example, and now
|
||
it runs on windows with GTK as well!
|
||
|
||
Daniel (6 February 2004)
|
||
- Andr<64>s Garc<72>a made the configure script find gethostbyname() fine when run
|
||
with mingw on windows.
|
||
|
||
- Modified the ldap code to use proper function pointers all over (instead of
|
||
mixed data and function pointers) to work-around the picky MIPSPro compiler
|
||
warnings.
|
||
|
||
- A custom Host: header is only considered if the request is not made by
|
||
following a location. After discussions with Tim Baker.
|
||
|
||
Daniel (5 February 2004)
|
||
- The libz part of the configure script now only set the two libz-related
|
||
define HAVE_ZLIB_H and HAVE_LIBZ if both the lib and the header is found.
|
||
If one is missing, none of the defines is set.
|
||
|
||
- Andr<64>s Garc<72>a fixed the Mingw makefiles.
|
||
|
||
- Len Krause reported that curl 7.9.X could do uploading from stdin without
|
||
doing chunked encoding, which current curl cannot do even if you disable
|
||
the transfer-encoding chunked header. Now it can again, and test case 98
|
||
verifies this functionality.
|
||
|
||
- Tor Arntsen fixed a weird getaddrinfo() usage in the FTP code, preventing
|
||
the ipv6-code for PORT work on AIX 5.2. We now also provide (better) error
|
||
messages when bailing out in the that function.
|
||
|
||
- Tor Arntsen now provides AIX and IRIX (using gcc, xlc and the MIPSPro
|
||
compilers) automated build logs (http://curl.haxx.se/auto/) and we've fixed
|
||
numerous minor quirks to make less warnings appear.
|
||
|
||
Daniel (4 February 2004)
|
||
- Based on a patch by Gilad, we now use the custom timeouts when waiting for a
|
||
server to connect when using FTP PORT. Previously we always waited 10
|
||
seconds, no more no less. We now also changed the default (if no timeout is
|
||
set) to wait 60 seconds for the connect before we fail.
|
||
|
||
Daniel (3 February 2004)
|
||
- Modified to link with c-ares instead of ares.
|
||
|
||
Daniel (2 February 2004)
|
||
- Added a configure test to check for which option the (g)nroff tool wants
|
||
to extract plain text from the man pages. Tor Arntsen told us the AIX
|
||
version of GNU gnroff doesn't support -man!
|
||
|
||
- Added an undef of accept in memdebug.h to make curl build with --enable-debug
|
||
on AIX 5.2 which seems to have accept defined. Reported by Tor Arntsen.
|
||
|
||
- curl_version() now includes c-ares version info, and curl_version_info() now
|
||
returns a struct with version SECOND that also includes that info.
|
||
|
||
- We are now officially using c-ares for asynch name resolves. c-ares is the
|
||
new library, based on the existing ares but with an extended and slightly
|
||
modified API.
|
||
|
||
- Dirk improved the ares timeout code, and now we also include the ares error
|
||
string when we fail to resolve a name.
|
||
|
||
- Another tweak to make test case 91 run fine. Now we have another bit on a
|
||
connection that is set true if the connection is marked for 'retry'. That
|
||
makes the connection get closed and re-opened and the HTTP-done code must
|
||
not complain on the fact that no data was received.
|
||
|
||
- Based on Dirk Manske's patch, I modified the name resolving with ares to
|
||
feature a timeout for really slow lookups. It now defaults to 300 seconds,
|
||
but is now adjusted to the CONNECTTIMEOUT/TIMOUE timeouts if one of them
|
||
is set.
|
||
|
||
- Fixed the inclusion of ca-bundle.h to really use the one in the build dir
|
||
before the one in the source dir. Domenico Andreoli found out and reported.
|
||
|
||
- Added test case 97, a simple POST with a custom Content-Type header
|
||
replacing the original application/x-www-form-urlencoded one.
|
||
|
||
Daniel (30 January 2004)
|
||
- Added code that attempts to fix the test 91 failure. As has been figured out
|
||
by Patrick Smith, the error happens because we re-use a connection that the
|
||
server is just about to close and we even manage to send away the request
|
||
without seeing an error. On the first read attempt we get a ECONNRESET.
|
||
Starting now, we attempt to detect this and if so, we retry the request on a
|
||
fresh connection.
|
||
|
||
- I added test case 510 which is a custom program that does a POST using a
|
||
read callback, with chunked transfer-encoding.
|
||
|
||
- Adjusted one of the MPE/iX changes as it made test case 504 fail all over.
|
||
|
||
- Added --socks as a recognized option. It works just like --proxy but sets a
|
||
SOCKS5 proxy to use. SOCKS5 support has been available in libcurl for a
|
||
while, just not provided by the curl tool. This does not currently work for
|
||
IPv6-enabled libcurls.
|
||
|
||
Daniel (29 January 2004)
|
||
- Stadler Stephan pointed out that src/hugehelp.c included config.h without
|
||
checking the define if its present...
|
||
|
||
- Ken Hirsch provided patches to make curl build fine on the MPE/iX operating
|
||
system.
|
||
|
||
- Dan Fandrich compiled curl with lots of aggressively pedantic compiler
|
||
options and thus found a few minor errors and did some general cleanups to
|
||
avoid them.
|
||
|
||
- Dirk Manske fixed a flaw in ares that prevented it to use non-blocking
|
||
sockets properly.
|
||
|
||
Daniel (28 January 2004)
|
||
- Richard Bramante fixed chunked transfer-encoded "uploads" to send a final
|
||
CRLF combo properly.
|
||
|
||
Daniel (27 January 2004)
|
||
- Made the response-headers during a CONNECT request to a proxy get passed on
|
||
as regular headers, so they appear with -i/-I options and similar.
|
||
|
||
- Based on a patch by Gisle Vanem, I've made the progress meter display
|
||
properly switch to a GB-display when more than 9999MB have been transfered.
|
||
|
||
Daniel (23 January 2004)
|
||
- Gisle Vanem pointed out a curlrc parser problem/crash when an option with a
|
||
required didn't have one and was on the last line of a file.
|
||
|
||
- More Windows fixes for large files. We now build and link with
|
||
../lib/strtoofft.c in the app code since Curl_strtoll() is not a provided
|
||
libcurl function... Perhaps we should consider a 'common' dir or similar
|
||
where we put source code used in both the lib and the client. Or perhaps
|
||
we'll just make this function available in the library...
|
||
|
||
- Vincent Bronner found out the socks5 code crashed when no username was
|
||
set.
|
||
|
||
- Vincent Bronner spotted a problem with proxy username/password when re-using
|
||
a persistent connection.
|
||
|
||
- Fixed the progress meter display for files larger than 2^31 bytes. Gisle
|
||
Vanem reported.
|
||
|
||
Daniel (22 January 2004)
|
||
- Gisle Vanem made strtoll() get used when curl is built with the mingw
|
||
compiler.
|
||
|
||
- Gisle Vanem fixed the compressed help text code to display properly.
|
||
|
||
- Removed the '#define HttpPost' from the public header file, as curl_httppost
|
||
is the proper name and it has been for quite some time now. Fixes another
|
||
name space pollution.
|
||
|
||
- Added 'curl_off_t' typedef in the public header file, to be used to provide
|
||
large file sizes to the *_LARGE options. Adjusted the code all over to use
|
||
this variable type instead of 'off_t'. This is an attempt to make the large
|
||
file support work on more platforms. The configure script now checks the
|
||
size of the curl_off_t instead of the plain off_t.
|
||
|
||
Version 7.11.0 (22 January 2004)
|
||
|
||
Daniel (21 January 2004)
|
||
- Removed the defines in the public header file with TIMECOND_ prefixes. They
|
||
have been obsolete since April 22nd 2002, and if this causes anyone any
|
||
problems now it is very easy to just add CURL_ to the names. This corrects
|
||
this name space pollution.
|
||
|
||
Daniel (19 January 2004)
|
||
- David Byron cleaned up how --trace with no option was treated, and also
|
||
arguments in a config file without a required parameter!
|
||
|
||
Daniel (16 January 2004)
|
||
- Gisle Vanem fixed a few issues where compilers warned about variables
|
||
possibly being used unassigned.
|
||
|
||
- Minor Interix build problem fixed.
|
||
|
||
Daniel (15 January 2004)
|
||
- Peter Sylvester pointed out some necessary escaping needed in the
|
||
acinclude.m4 file when automake 1.8 or later is used.
|
||
|
||
Daniel (14 January 2004)
|
||
- Vincent Bronner fixed the Curl_resolv() return code. This extends the fix
|
||
Steve Green provided on december 3...
|
||
|
||
Daniel (13 January 2004)
|
||
- Luke Call made the win32 version of the password prompting function support
|
||
backspace.
|
||
|
||
- Dan Fandrich fixed the hugehelp source file to contain both a compressed and
|
||
an uncompressed version in the distribution, so that more people easier can
|
||
build curl with the compressed version.
|
||
|
||
- Diego Casorran brought another AmigaOS build patch for native Amiga builds.
|
||
|
||
- Matt Veenstra updated the Mac OS X framework files.
|
||
|
||
- Brian R Duffy brought a section to the INSTALL file on how to build a
|
||
SSL-enabled curl using the free Borland C++ compiler. He also updated the
|
||
Borland lib/Makefile.b32.
|
||
|
||
- I fixed the test case 509 which I broke yesterday. Now the libtest are
|
||
compiled with an include path that points to the library's source dir, so
|
||
that the libtests can include files from the source tree. This was made to
|
||
make it possible to use the USE_SSLEAY define in the library test files.
|
||
|
||
Daniel (12 January 2004)
|
||
- Peter Sylvester brought code that now allows a callback to modified the URL
|
||
even when the multi interface is used, and then libcurl will simulate a
|
||
"follow location" to that new URL. Test 509 was added to test this feature.
|
||
|
||
- Extended the time we retry servers in the test script, and I also made it
|
||
retry the https and ftps servers before they are considered bad. I believe
|
||
the previous approach could turn problematic on really slow hosts.
|
||
|
||
Version 7.11.0-pre1 (12 January 2004)
|
||
|
||
Daniel (11 January 2004)
|
||
- Dominick Meglio pointed out FTPS should use default port 990 according to
|
||
IANA.
|
||
|
||
Daniel (8 January 2004)
|
||
- Fixed the SPNEGO configure check to not use -R or other non-portable options
|
||
in the LDFLAGS. Reported by Pierre in bug report #872930.
|
||
|
||
Daniel (5 January 2004)
|
||
- Dan Fandrich provided a fix on our zlib usage.
|
||
|
||
- David J Meyer's patch that introduce large file support to libcurl was
|
||
applied. New curl_easy_setopt options that accept 'off_t' arguments are:
|
||
|
||
INFILESIZE_LARGE
|
||
RESUME_FROM_LARGE
|
||
MAXFILESIZE_LARGE
|
||
|
||
Daniel (4 January 2004)
|
||
- Based on Dominick Meglio's comments, I made our private version of
|
||
gettimeofday() declared static. This would otherwise collide with the same
|
||
function in other libs (like ares for example).
|
||
|
||
- Added Dominick Meglio's description on how to build libcurl with ares
|
||
on win32.
|
||
|
||
Daniel (19 December)
|
||
- CURLOPT_IPRESOLVE was not possible to set.
|
||
|
||
- Gisle Vanem updated the djgpp build files.
|
||
|
||
Daniel (18 December)
|
||
- John McGowan reported a redirect-problem that happened if a site used a URL
|
||
like "url.com?var=content" (without a proper slash) and from that address
|
||
redirected the user-agent to an absolute directory.
|
||
|
||
- David Byron made libcurl build fine with both the .NET and VC6 versions of
|
||
MSVC
|
||
|
||
Daniel (16 December)
|
||
- Updated test 506 since it started to fail after the cache prune change
|
||
yesterday. I also changed it slightly to feature a counter in each debug
|
||
output for easier tracing.
|
||
|
||
Daniel (15 December)
|
||
- Old DNS cache entries are now only pruned after curl is done with a request,
|
||
and not in the actual name resolve call.
|
||
|
||
- corrected the --enable-ares patch
|
||
|
||
- Giuseppe Attardi found and fixed a problem within libcurl that re-used
|
||
already freed memory.
|
||
|
||
Daniel (10 December)
|
||
- Gisle Vanem reported that the dict support was broken. I broke it during my
|
||
ftps-changes overhaul. I've now added a 'curlassert' function that can be
|
||
used to verify expressions, to prevent future errors of the same
|
||
kind. They're only present in debug-builds.
|
||
|
||
- Diego Casorran made curl and libcurl possible to build natively (no more
|
||
need for the ixemul library) on AmigaOS.
|
||
|
||
- Dominick Meglio made configure --enable-ares support a given path to the
|
||
installed ares lib, instead of always using it in the curl source tree.
|
||
This also fixed the curl-config --libs output.
|
||
|
||
- Eric S. Raymond patched a very minor man page format error in
|
||
libcurl-errors.3
|
||
|
||
Daniel (8 December)
|
||
- Fixed the flaw that made -lz appear twice on the link command line.
|
||
|
||
- After correspondence with Gisle Vanem, I changed the 'connection aborted'
|
||
error text when the FTP response reader failed to more specificly identify
|
||
what the problem is.
|
||
|
||
- Based on a patch from Dominick Meglio, curl-config --feature now outputs
|
||
'AsynchDNS' as a feature if libcurl was built with ares. The feature name
|
||
is the same that 'curl -V' outputs, for simplicity.
|
||
|
||
Daniel (3 December)
|
||
- Marty Kuhrt made the build up-to-date on VMS, and moved most of the VMS-
|
||
specific stuff in the client code to a separate header file.
|
||
|
||
- Steve Green fixed a return code bug in Curl_resolv(), that made the socks5
|
||
code fail.
|
||
|
||
- swalkaus at yahoo.com patched libcurl to ignore Content-Length: headers
|
||
when Transfer-Encoding: chunked is used, as mandated by RFC2616.
|
||
|
||
Daniel (2 December)
|
||
- --ftp-pasv was added, which serves the only purpose of overriding a
|
||
previously set --ftpport option. Starting now, --ftp-port is a recognized
|
||
alias for --ftpport for consistency.
|
||
|
||
- Giuseppe Attardi pointed out that we should use MSG_NOSIGNAL when we use
|
||
send() and recv(). I added checks for the define in the configure script and
|
||
adjusted the code accordingly. If the symbol is present, we won't attempt
|
||
to ignore the SIGPIPE signal.
|
||
|
||
Daniel (1 December)
|
||
- Mathias Axelsson set up a bsdftpd-ssl server for me and I could make curl
|
||
run fine against its FTPS implementation. Now these FTPS-related things
|
||
work:
|
||
o explicit and implicit FTPS
|
||
o active (PORT) and passive (PASV)
|
||
o upload and download
|
||
o verified against bsdftpd-ssl and RaidenFTPD
|
||
|
||
Daniel (27 November)
|
||
- James Clancy made the Borland Makefiles up to date.
|
||
|
||
- Markus Moeller improved the SPNEGO detection in the configure script.
|
||
|
||
Daniel (25 November)
|
||
- Dave May filed bug report #848371, identifying that if you'd do POST over a
|
||
proxy to a https server, libcurl didn't POST at all, it just made a GET! It
|
||
turned out to be because libcurl wrongly didn't consider the authentication
|
||
"negotiation phase" to be complete yet.
|
||
|
||
I added test case 95 to verify my fix for this.
|
||
|
||
Daniel (24 November)
|
||
- Thanks to Mathias Axelsson, I've been able to work on FTPS for libcurl and it
|
||
seems to work somewhat fine now.
|
||
|
||
The FTPS stuff is based on RFC2228 and the murray-auth-ftp-ssl draft
|
||
(version 12). There seems to exist quite a few servers that have implemented
|
||
the server side of this.
|
||
|
||
We can now use ftps:// URLs to explicitly switch on SSL/TSL for the control
|
||
connection and the data connection (dealing with two SSL connections forced
|
||
me to change a lot of stuff in libcurl).
|
||
|
||
Alternatively, and what seems to be the recommended way, we can set the new
|
||
option CURLOPT_FTP_SSL to one of these values:
|
||
|
||
CURLFTPSSL_NOPE, - do not attempt to use SSL
|
||
CURLFTPSSL_TRY - try using SSL, proceed anyway otherwise
|
||
CURLFTPSSL_CONTROL - SSL for the control connection or fail
|
||
CURLFTPSSL_ALL - SSL for all communication or fail
|
||
|
||
Any failure to set the desired level will make libcurl fail with the error
|
||
code CURLE_FTP_SSL_FAILED. This new option makes a "normal" ftp:// transfer
|
||
attempt to be made securely.
|
||
|
||
I've been able to login and get files (passively) from Mathias' server using
|
||
both ftps:// and CURLOPT_FTP_SSL. (I've made 'curl' understand the --ftp-ssl
|
||
option that sets CURLFTPSSL_TRY.)
|
||
|
||
- Gaz Iqbal fixed a range string memory leak.
|
||
|
||
- Gisle Vanem fixed the Windows builds.
|
||
|
||
- Added the new FTPSSL defines in curl/curl.h
|
||
|
||
Daniel (20 November)
|
||
- Josh Kapell filed bug report #845247 as he found an endless loop when
|
||
getting a 407 back from a proxy when no user+password was given. Added test
|
||
case 94 to verify the fix.
|
||
|
||
Daniel (19 November)
|
||
- Kevin Roth fixed a progress-bar problem on Windows.
|
||
|
||
- While working with Nicolas Croiset's bug report #843739, I noticed two minor
|
||
problems related to ftp partial downloads: if a partial transfer is
|
||
detected, we must close the connection as we cannot know in what state it is
|
||
anymore. This looks like a ProFTPD bug:
|
||
http://curl.haxx.se/mail/lib-2003-11/0079.html
|
||
|
||
Daniel (17 November)
|
||
- Maciej W. Rozycki made the configure script use a cache variable for the
|
||
writable argv test. This way, the default can be overridden better (for
|
||
cross-compiles etc)
|
||
|
||
Daniel (15 November)
|
||
- Mathias Axelsson found out libcurl sometimes freed the server certificate
|
||
twice, leading to crashes!
|
||
|
||
Daniel (14 November)
|
||
- Siddhartha Prakash Jain found a case with a bad resolve that we didn't
|
||
properly bail out from, when using ares.
|
||
|
||
Daniel (13 November)
|
||
- Default Content-Type for parts in multipart formposts has changed to
|
||
"application/octet-stream". This seems more appropriate, and I believe
|
||
mozilla and the likes do this. In the same area: .html files now get
|
||
text/html as Content-Type. (Pointed out in bug report #839806)
|
||
|
||
- Gisle Vanem corrected the --progress-bar output by doing a flush of the
|
||
output, which apparently makes it look better on at least windows, but
|
||
possibly other platforms too.
|
||
|
||
- Peter Sylvester identified a problem in the connect code, which made the
|
||
multi interface on a ipv6-enabled solaris box do bad. Test case 504 to be
|
||
specific. I've spent some time to clean-up the Curl_connecthost() function
|
||
now to use less duplicated code for the two different sections: ipv6 and
|
||
ipv4.
|
||
|
||
Daniel (11 November)
|
||
- Added CURLOPT_NETRC_FILE. Use this to tell libcurl which file to use instead
|
||
of trying to find a .netrc in the current user's home directory. The
|
||
existing .netrc file finder is somewhat naive and is far from perfect on
|
||
several platforms that aren't unix-style. If this option isn't set when
|
||
CURLOPT_NETRC is set, the previous approach will still be used.
|
||
|
||
The current .netrc check code now also support longer than 256 bytes path
|
||
names.
|
||
|
||
Daniel (10 November)
|
||
- Kang-Jin Lee pointed out that the generated ca-bundle.h file shouldn't be
|
||
written in the source dir if a different build dir is used.
|
||
|
||
- After S<>bastien Willemijns' bug report, we now check the separators properly
|
||
in the 229-reply servers respond on a EPSV command and bail out better if
|
||
the reply string is not RFC2428-compliant.
|
||
|
||
Daniel (7 November)
|
||
- Based on Gisle Vanem's patch, I made curl try harder to get the home
|
||
directory of the current user, in order to find the default .curlrc file.
|
||
We're also considering moving out the HOME-dir code from libcurl, and
|
||
instead have the app pass in the path to the .netrc file (which is the only
|
||
logic left in libcurl that uses the HOME dir). Then curl can use the home
|
||
dir for that purpose too.
|
||
|
||
- Ralph Mitchell's updated testcurl.sh to the script to take an existing
|
||
directory name and build/run/test curl in there instead of trying to update
|
||
from CVS. Using this approach, the script can now be used to test daily
|
||
tarballs etc.
|
||
|
||
- Gisle Vanem added a "resource file" to the Windows DLL builds, to contain
|
||
information such as version number, library name, copyright info etc.
|
||
|
||
Daniel (6 November)
|
||
- curl checks if the existing libcurl supports things like --ntlm, --negotiate
|
||
and --krb4 and returns error if not.
|
||
|
||
- I added three new global defines in the curl/curl.h header:
|
||
LIBCURL_VERSION_MAJOR, LIBCURL_VERSION_MINOR and LIBCURL_VERSION_PATCH. They
|
||
are the three numbers in the library's version number, separated for easier
|
||
usage. 'maketgz' was updated accordingly to generate these numbers properly
|
||
when building release-archives.
|
||
|
||
- Uninitialized variable fix, reported by both Marty Kuhrt and Benjamin
|
||
Gerard.
|
||
|
||
- Matt Veenstra provided build files to build libcurl as a "framework" under
|
||
Mac OS X. See the lib/libcurl.framework.make for details.
|
||
|
||
- Removed the defines of TRUE and FALSE from the curl/curl.h header file.
|
||
They're not in our name space so we should not fiddle with them.
|
||
|
||
Daniel (5 November)
|
||
- Replaced the man page to HTML converter program with a new one: roffit.
|
||
Makes nicer web pages.
|
||
|
||
Daniel (4 November)
|
||
- Troels Walsted Hansen fixed the MSVC makefiles to let them build curl fine
|
||
on Windows.
|
||
|
||
- Kevin Roth corrected the cygwin package generator and spell-fixed the
|
||
comment in the ca-bundle.h file.
|
||
|
||
Version 7.10.8 (1 November 2003)
|
||
|
||
Daniel (31 October)
|
||
- Assume that MDTM on an FTP server returns the timestamp using the UTC time
|
||
zone. This changes the time CURLINFO_FILETIME returns for a given file over
|
||
FTP, and will change existing uses of CURLOPT_TIMECONDITION. It will make
|
||
the functionality more similar to how the HTTP one is already working.
|
||
|
||
- Command line options that take numerical parameters (such as -y, -Y, -C etc)
|
||
now report error and exit if the parameter isn't truly a number greater than
|
||
or equal to zero. This helps users to notice bad usage earlier. Before, when
|
||
a user forgot or missed to add a numerical parameter to an option, the
|
||
command line parser would simply "eat" the following option and it would
|
||
cause great confusion.
|
||
|
||
Daniel (30 October)
|
||
- David Hull made libcurl deal with NOBODY and HEADER for file:// the same way
|
||
it already does for FTP: it provides HTTP-looking headers that provide info
|
||
only about the file, without doing the actual transfer. The curl tool then
|
||
lets --head do this.
|
||
|
||
Daniel (29 October)
|
||
- runtests.pl now checks for and use valgrind if present. It will redirect the
|
||
valgrind results in log/valgrind[num] but it currently doesn't scan that
|
||
file for any errors or anything, that is still only made manually.
|
||
|
||
- David Hull made the file: URL parser also accept the somewhat sloppy file
|
||
syntax: file:/path. I added test case 203 to verify this.
|
||
|
||
Daniel (28 October)
|
||
- Dan C tracked down yet another weird behavior in the glibc gethostbyname_r()
|
||
function for some specific versions (reported on 2.2.5 and 2.1.1), and
|
||
provided a fix. On Linux machines with these glibc versions, non-ipv6
|
||
builds of libcurl would often fail to resolve perfectly resolvable host
|
||
names.
|
||
|
||
Daniel (26 October)
|
||
- James Bursa found out that curl_msnprintf() could write the trailing
|
||
zero-byte outside its given buffer size. This could happen if you generated
|
||
a very long error message as then libcurl would overwrite the ERRORBUFFER
|
||
with one byte. Using a non-existing very long local file:// name is one case
|
||
that could make this occur.
|
||
|
||
Daniel (24 October)
|
||
- David Hull filed bug report #829827. It identified a problem with -C - if
|
||
the full file already was downloaded and thus the server responded with a
|
||
416. libcurl would then wrongly use the Content-Length: header and expect
|
||
that size to get transfer, causing a "hang" until the server closed the
|
||
connection and then an error 18 ("still N bytes data left of the transfer").
|
||
|
||
Now we don't return any error at all, but I think libcurl should perhaps
|
||
return some kind of info since the requested range was out of the size of
|
||
the document.
|
||
|
||
- Based on David Hull's fix in bug report #804599, we now check for solaris and
|
||
gcc in configure and set the -mimpure-text link flag for linking the lib
|
||
better.
|
||
|
||
- I've introduced a -t option to the runtests.pl script. With that option set,
|
||
the script runs special "memory torture" tests. For each test command line
|
||
in that section, the script first runs the command line and counts the total
|
||
amount of allocations made. It then runs the exact same command line again,
|
||
forcing allocation number N to fail. It will try every N from 1 to the total
|
||
number of amounts made. For every invoke, it checks that no memory was
|
||
leaked as that would indicate a bad cleanup somewhere in the code.
|
||
|
||
This is just beginning to work, and I've already made some corrections in
|
||
libcurl code. When this code works somewhat fine, I'll make sure 'make test'
|
||
in the root dir will run these tests as well.
|
||
|
||
Daniel (23 October)
|
||
- Georg Horn fixed how the CA verification is made. Verifications can now be
|
||
made while at the same time the result of it can be ignored. This also
|
||
affects the curl tool as -k can now be used together with --cacert or
|
||
--capath.
|
||
|
||
Daniel (22 October)
|
||
- Gisle Vanem found out --disable-eprt didn't work and patched it.
|
||
|
||
- Test case 91 was modified and could now repeat the problem Kevin Roth has
|
||
reported, and the bug was fixed.
|
||
|
||
- Dylan Ellicott added vc-libcurl-ssl-dll as a target to the root makefile
|
||
to build a static libcurl that links with a shared OpenSSL using MSVC.
|
||
|
||
Daniel (21 October)
|
||
- Andr<64>s Garc<72>a updated the mingw32 makefiles.
|
||
|
||
Version 7.10.8-pre5 (21 October 2003)
|
||
|
||
Daniel (19 October)
|
||
- Georg Horn made libcurl output more info on SSL failures when receiving
|
||
data.
|
||
|
||
Version 7.10.8-pre4 (18 October 2003)
|
||
|
||
Daniel (17 October)
|
||
- Dominick Meglio implemented CURLOPT_MAXFILESIZE and --max-filesize.
|
||
|
||
- Made libcurl show verbose info about what auth type and user name that is
|
||
being sent in its HTTP request-headers.
|
||
|
||
Daniel (16 October)
|
||
- Removed support for CURLOPT_PASSWDFUNCTION and CURLOPT_PASSWDDATA. libcurl
|
||
no longer prompt for passwords under any circumstances. Password prompting
|
||
was instead moved to curl, which now prompts for password if -u or -U lack
|
||
it. This solves the problem Kevin Roth reported when curl prompted for
|
||
password twice when doing NTLM authentication.
|
||
|
||
- I rewrote the SSL subjectAltName check to avoid having to rely on OpenLDAP-
|
||
licensed derivate code.
|
||
|
||
Daniel (15 October)
|
||
- Avoid doing getsockopt() on Windows to verify connects. It seems that this
|
||
hogs Windows machines when libcurl is being used multi-threaded (with > ~50
|
||
threads). Andrew Fuller helped us verify and test this.
|
||
|
||
Daniel (14 October)
|
||
- Kimmo Kinnunen fixed a crash with duphandle() when CURLDEBUG is set.
|
||
|
||
- Gisle Vanem made libcurl build and work with IPv6 on Windows.
|
||
|
||
Daniel (13 October)
|
||
- Giuseppe Attardi reported yet another segfault with ares and the multi
|
||
interface. Me fixed.
|
||
|
||
- Domenico Andreoli removed the extra LDFLAGS assignment in lib/Makefile.am
|
||
that was reported about in the debian bug report #212086.
|
||
|
||
Domenico also fixed two makefiles where we used 'gnroff' instead of the more
|
||
portable $(NROFF).
|
||
|
||
Daniel (12 October)
|
||
- Dirk Manske made the share locking around DNS lookups slightly different to
|
||
allow the share system's DNS lookups to run somewhat more
|
||
independent/faster.
|
||
|
||
Daniel (9 October)
|
||
- Lachlan O'Dea fixed a resume problem: "If I set CURLOPT_RESUME_FROM, perform
|
||
an HTTP download, then reset CURLOPT_RESUME_FROM to 0, the next download
|
||
still has a Range header with a garbage value." bug report #820502
|
||
|
||
- Dominick Meglio made the inet_pton.c file build fine using MSVC.
|
||
|
||
- The 'sws' test suite web server now #include setup.h from the lib directory.
|
||
This makes it more portable easier.
|
||
|
||
Version 7.10.8-pre3 (8 October 2003)
|
||
|
||
Daniel (8 October)
|
||
- Frank Ticheler provided a patch that fixes how libcurl connects to multiple
|
||
addresses, if one of them fails (ipv4-code).
|
||
|
||
Daniel (7 October)
|
||
- Neil Dunbar provided a patch that now makes libcurl check SSL
|
||
subjectAltNames when matching certs. This is apparently detailed in RFC2818
|
||
as the right thing to do. I had to add configure checks for inet_pton() and
|
||
our own (strictly speaking, code from BIND written by Paul Vixie) provided
|
||
code for the function for platforms that miss it.
|
||
|
||
- HTTP POST using the read callback didn't work, as Florian Schoppmann
|
||
reported.
|
||
|
||
Daniel (5 October)
|
||
- Shared provided a few fixes to make libcurl build on BeOS
|
||
out-of-the-box. New code for BeOS-style non-blocking sockets, provided by
|
||
Shard and Jeremy Friesner. Modified the autoconf check for non-blocking
|
||
sockets to check for this kind too.
|
||
|
||
Daniel (4 October)
|
||
- Vincent Bronner pointed out that if you set CURLOPT_COOKIE for a transfer
|
||
and then set it to NULL in a subsequent one, the previous cookie was still
|
||
sent off!
|
||
|
||
- Jon Turner fixed a problem libcurl had when it failed on an FTP transfer due
|
||
to a bad path, it would cause the next transfer to use a bad path as well.
|
||
|
||
- Siddhartha Prakash Jain provided a patch with a fix for libcurl with ares,
|
||
when working on IP-only names as we then could return "wait" status when the
|
||
name in fact already was resolved. I edited the patch slightly to not expose
|
||
asynch details to non-ares aware source code.
|
||
|
||
Daniel (3 October)
|
||
- Neil Spring posted the debian bug report #213180, and pointed out that using
|
||
the name 'access' in a function prototype is not very wise as some compilers
|
||
complain.
|
||
|
||
- Peter Sylvester provided his and Jean-Paul Merlin's curlx.c example source
|
||
code that shows how they use ssl and callbacks.
|
||
|
||
Daniel (2 October)
|
||
- James MacMillan's patch makes curl build on QNX 6.2.x.
|
||
|
||
Daniel (26 September)
|
||
- My daughter was born!
|
||
|
||
Daniel (23 September)
|
||
- Added support for -4/--ipv4 and -6/--ipv6 to force names to resolve to that
|
||
particular IP version. They only work for IPv6-enabled libcurls.
|
||
|
||
- curl -V now outputs 'SPNEGO' as a feature in case libcurl was built to
|
||
support that.
|
||
|
||
Version 7.10.8-pre2 (22 September 2003)
|
||
|
||
Daniel (22 September)
|
||
- Giuseppe Attardi found a segfault in libcurl when using the multi interface
|
||
with ares and doing repeated operations against a non-resolving host name.
|
||
|
||
Daniel (19 September)
|
||
- Added the CURLOPT_IPRESOLVE option, that allows an application to select
|
||
what kind of IP addresses he wants to use when resolving host names. This
|
||
is only interesting when using host names that resolve addresses using more
|
||
than one version of IP.
|
||
|
||
- Applied Markus Moeller's patch that introduces SPNEGO support if libcurl
|
||
is built with the FBopenssl libraries. curl_version_info() now returns
|
||
info on SPNEGO availability. The patch also made the GSSAPI stuff work fine
|
||
with the MIT GSS-library (the Heimdal one still works too).
|
||
|
||
Daniel (16 September)
|
||
- Doing PUT with --digest failed, as reported in bug report #805853.
|
||
|
||
- Using --anyauth that picked NTLM, and then a redirect closed the connection
|
||
and took curl to a second NTLM page made curl fail. Bug report #806328
|
||
identified the problem, test case 90 was added to verify the fix.
|
||
|
||
Daniel (14 September)
|
||
- codemastr brought a patch for ares to make the Windows portions of it work
|
||
properly on NT4. I uploaded a new diff and updated the docs on where to get
|
||
it etc.
|
||
|
||
- Jeff Pohlmeyer tracked down a very hard-to-find bug where we removed a
|
||
cached DNS entry even though it may be in use, which caused "random" memory
|
||
to get overwritten and thus "random" crashes.
|
||
|
||
Daniel (12 September)
|
||
- Based on a bug report by David Kimdon, I made the runtests.pl script clear
|
||
all possible proxy environment variables before the tests are run.
|
||
|
||
- By default, easy handles within a multi handle now share DNS cache.
|
||
|
||
- Tim Bartley brought a patch that makes the GSSNEGOTIATE option work for
|
||
Microsoft's "Negotiate" authentication as well.
|
||
|
||
Daniel (11 September)
|
||
- A zero-length proxy string confused FTP transfers.
|
||
|
||
- Bjorn Reese found a case with an uninitialized pointer, only present when
|
||
built for ares.
|
||
|
||
Version 7.10.8-pre1 (8 September 2003)
|
||
|
||
Daniel (7 September)
|
||
- Jurij Smakov found out that the non-OpenSSL MD5 code was not working on
|
||
Alpha (or ia64). Only the OpenSSL-version did. I made a fix I think corrects
|
||
the problem.
|
||
|
||
Daniel (5 September)
|
||
- Kevin Fisk reported that configure --enable-thread didn't work. I fixed.
|
||
|
||
- De-macrofied the lib/hash.c source code somewhat.
|
||
|
||
Daniel (4 September)
|
||
- CURLINFO_HTTPAUTH_AVAIL and CURLINFO_PROXYAUTH_AVAIL added, Based on Joerg
|
||
Mueller-Tolk's patch,
|
||
|
||
Early (4 September)
|
||
- Added CURLOPT_FTP_RESPONSE_TIMEOUT - allows user to set strict timeout
|
||
requirements on the FTP server's ability to respond to individual commands
|
||
without placing global requirements on transfer or connect time. Files
|
||
affected:
|
||
- include/curl/curl.h
|
||
Added option CURLOPT_FTP_RESPONSE_TIMEOUT
|
||
- lib/ftp.c
|
||
Added branch inside Curl_GetFTPResponse to check for
|
||
data->set.ftp_response_timeout
|
||
- lib/url.c
|
||
Modified Curl_setopt to recognize CURLOPT_FTP_RESPONSE_TIMEOUT
|
||
- lib/urldata.h
|
||
Added ftp_response_timeout to struct UserDefined
|
||
|
||
Daniel (3 September)
|
||
- Peter Pentchev found and fixed two problems in the test suite's web server
|
||
code, that made it segfault at times.
|
||
|
||
- J<>rg Mueller-Tolk improved the proxy user+password handling, especially
|
||
when providing a blank password.
|
||
|
||
Daniel (2 September)
|
||
- Fix for making CONNECT to proxies do the correct magic to allow NTLM, Digest
|
||
and similar to work.
|
||
|
||
Daniel (1 September)
|
||
- Henrik Storner made libcurl work fine with OpenLDAP 2.1.22 (current).
|
||
|
||
- Jeff Pohlmeyer added a proper error message for non-resolving hosts when
|
||
using ares for lookups.
|
||
|
||
Daniel (25 August)
|
||
- John McGowan reported that curl -k still failed if the HTTPS server's CN
|
||
field wasn't obtainable. This was due to the CURLOPT_SSL_VERIFYHOST being
|
||
set to 1, and libcurl failed if the CN was missing. Starting now, having it
|
||
set to 1 will simply output a warning if no CN could be obtained (as having
|
||
a mismatch is OK).
|
||
|
||
Daniel (21 August)
|
||
- Vincent Sanders provided a fix for name resolving when linked with uClibc.
|
||
|
||
Daniel (20 August)
|
||
- Gerd v. Egidy provided a patch that makes libcurl store the FTP response
|
||
code from ftp servers. Using curl_easy_getinfo() with CURLINFO_HTTP_CODE
|
||
returns that data. The option is therefore now also known as
|
||
CURLINFO_RESPONSE_CODE.
|
||
|
||
- Antoine Calando found a segfault when doing multi-part/formpost using
|
||
the multi interface.
|
||
|
||
- Antoine Calando pointed out that curl_multi_info_read() didn't set the
|
||
msgs_in_queue to 0 properly when returning NULL.
|
||
|
||
Daniel (19 August)
|
||
- I made curl support multiple -T options, as well as -T "{file1,file2}"
|
||
style globbing. One -T for each URL is supported.
|
||
|
||
- Jeff Pohlmeyer found a segfault when using ares-enabled libcurl and the
|
||
multi interface when trying a non-existing host name.
|
||
|
||
- Made the libcurl printf code support long longs if available.
|
||
|
||
- Loren Kirkby pointed out that we did not clean up all SSL-allocated memory
|
||
in curl_global_cleanup().
|
||
|
||
Daniel (17 August)
|
||
- Setting CURLOPT_WRITEFUNCTION or CURLOPT_READFUNCTION to NULL will now make
|
||
them get the internal defaults restored. Previously this could cause a
|
||
segfault. We should aim at having all pointer-related options get restored
|
||
to default/safe values when set to NULL.
|
||
|
||
Version 7.10.7 (15 August 2003)
|
||
|
||
Daniel (14 August)
|
||
- I modified the memdebug system to return failure on memory allocation
|
||
functions after a set amount of successful ones. This enables us to test
|
||
out-of-memory situations in a controlled manner and we can make sure that
|
||
curl/libcurl behaves good in those.
|
||
|
||
This made me find and fix several spots where we did not cleanup properly
|
||
when bailing out due to errors (low memory).
|
||
|
||
- Corrected test case 74. Made using -o with bad #[num] codes complain and
|
||
bail out. Made #[num] support numbers larger than 9 as well. Added test
|
||
case 86 for a proper range globbing test as well.
|
||
|
||
Version 7.10.7-pre4 (12 August 2003)
|
||
|
||
Daniel (12 August)
|
||
- curl_version_info() now returns a flag if libcurl was built with asynch DNS
|
||
support, and this is now also displayed with 'curl -V'.
|
||
|
||
- Added a few new man pages to the docs/libcurl dir: curl_share_init,
|
||
curl_share_setopt, curl_share_cleanup, libcurl-easy and libcurl-share.
|
||
|
||
Daniel (11 August)
|
||
- Mike Cherepov made the local binding code work for Windows, which makes
|
||
the option CURLOPT_INTERFACE work on Windows as well.
|
||
|
||
- Vincent Sanders updated the fopen.c example code a lot.
|
||
|
||
- --proxy-ntlm is now supported by the curl tool. It forces the proxy
|
||
authentication to be made using NTLM. It does not yet work for HTTPS over
|
||
proxies (or other proxy-tunneling options). Test case 81 and 82 do some
|
||
simple initial ntlm testing.
|
||
|
||
- Found and fixed a minor memory leak on re-used connections with
|
||
proxy-authentication.
|
||
|
||
- I removed -@ and -Z as valid short options. They were very rarely used (@
|
||
wasn't even documented).
|
||
|
||
- Serge Semashko introduced CURLOPT_PROXYAUTH, and make it work when set to
|
||
CURLAUTH_NTLM and/or CURLAUTH_BASIC. The PROXAUTH is similar to HTTPAUTH,
|
||
but is for the proxy connection only, and HTTPAUTH is for the remote host.
|
||
|
||
- Fixed loading of cookies with blank contents from a cookie jar. Also made the
|
||
cookie functions inform on added and skipped cookies (for cookie debugging).
|
||
|
||
Version 7.10.7-pre3 (8 August 2003)
|
||
|
||
Daniel (8 August)
|
||
- Applied David Byron's fix for file:// URLs with drive letters included.
|
||
|
||
- I added the --ftp-create-dirs to the client code, which activates Early's
|
||
CURLOPT_FTP_CREATE_MISSING_DIRS option, and wrote test case 147 to verify
|
||
it. Added the option to the curl.1 man page too. Added the option to the
|
||
curl_easy_setopt.3 man page too.
|
||
|
||
Daniel (7 August)
|
||
- Test case 60 failed on ia64 and AMD Opteron. Fixed now.
|
||
|
||
- Fixed a printf problem that resulted in urlglobbing bugs (bug #203827 in the
|
||
debian bug tracker). Added test case 74 to verify the fix and to discover if
|
||
this breaks in the future.
|
||
|
||
- "make distcheck" works again.
|
||
|
||
Version 7.10.7-pre2 (6 August 2003)
|
||
|
||
Daniel (5 August)
|
||
- Duncan Wilcox helped me verify that the latest incarnation of my ares patch
|
||
builds fine on Mac OS X (see the new lib/README.ares) file for all details.
|
||
|
||
- Salvatore Sorrentino filed bug report #783116 and Early Ehlinger posted a
|
||
bug report to the libcurl list, both identifying a problem with FTP
|
||
persistent connections and how the dir hierarchy was not properly reset
|
||
between files.
|
||
|
||
- David Byron's thoughts on a fixed Makefile in tests/ were applied.
|
||
|
||
- Jan Sundin reported a case where curl ignored a cookie that browsers don't,
|
||
which turned up to be due to the number of dots in the 'domain'. I've now
|
||
made curl follow the the original netscape cookie spec less strict on that
|
||
part.
|
||
|
||
Daniel (4 August)
|
||
- Dirk Manske added cookie support for the experimental, hidden and still
|
||
undocumented share feature!
|
||
|
||
- Mark Fletcher provided an excellent bug report that identified a problem
|
||
with FOLLOWLOCATION and chunked transfer-encoding, as libcurl would not
|
||
properly ignore the body contents of 3XX response that included the
|
||
Location: header.
|
||
|
||
Early (6 August)
|
||
- Added option CURLOPT_FTP_CREATE_MISSING_DIRS
|
||
This option will force the target file's path to be created if it
|
||
does not already exist on the remote system.
|
||
|
||
Files affected:
|
||
- include/curl/curl.h
|
||
Added option CURLOPT_FTP_CREATE_MISSING_DIRS
|
||
- lib/ftp.c
|
||
Added function ftp_mkd, which issues a MKD command
|
||
Added function ftp_force_cwd, which attempts a CWD,
|
||
and does a MKD and retries the CWD if the original CWD
|
||
fails
|
||
Modified ftp_perform() to call its change directory function
|
||
through a pointer. The pointer points to ftp_cwd by default,
|
||
and is modified to point to ftp_force_cwd IFF
|
||
data->set.ftp_create_missing_dirs is not 0.
|
||
- lib/url.c
|
||
Modified Curl_setopt to recognize CURLOPT_FTP_CREATE_MISSING_DIRS
|
||
- lib/urldata.h
|
||
Added ftp_create_missing_dirs to struct UserDefined
|
||
|
||
- Minor Bugfix for CURLOPT_TIMECONDITION with FTP - if the file was not
|
||
present to do the time comparison, it would fail.
|
||
Files affected:
|
||
- lib/ftp.c
|
||
In ftp_perform(), the call to ftp_getfiletime() used to be followed
|
||
by
|
||
if (result)
|
||
return result;
|
||
And then by the code that actually did the time comparison.
|
||
The code that did the comparison handled the case where the filetime
|
||
was not available (as indicated by info.filetime < 0 or set.timevalue
|
||
< 0), so I replaced the if (result) return result with a switch(result)
|
||
that allows CURLE_FTP_COULDNT_RETR_FILE to fall through to the
|
||
normal time comparison.
|
||
|
||
Daniel (3 August)
|
||
- When proxy authentication is used in a CONNECT request (as used for all SSL
|
||
connects and otherwise enforced tunnel-thru-proxy requests), the same
|
||
authentication header is also wrongly sent to the remote host.
|
||
|
||
This is a rather significant info leak. I've fixed it now and mailed a patch
|
||
and warning to the mailing lists.
|
||
|
||
Daniel (1 August)
|
||
- David Byron provided a patch to make 7.10.6 build correctly with the
|
||
compressed hugehelp.c source file.
|
||
|
||
Version 7.10.7-pre1 (31 July 2003)
|
||
|
||
Daniel (30 July)
|
||
- J<>rg M<>ller-Tolk updated the VC makefile.
|
||
|
||
- Daniel Noguerol made the ftp code output "Accept-Ranges: bytes" in similar
|
||
style like other faked HTTP headers when NOBODY and HEADER are used. I
|
||
updated two corresponding test cases too.
|
||
|
||
- Marty Kuhrt pointed out a compilation problem on VMS due to my having
|
||
changed a type from long to time_t, and I'm now changing it back to work
|
||
more portably...
|
||
|
||
He also indicated that distributing the src/hugehelp.c in a compressed state
|
||
like I accidentally did may not be the smartest move... I've now fixed the
|
||
distribute procedure to automatically generate an uncompressed version when I
|
||
make release archives.
|
||
|
||
Daniel (29 July)
|
||
- Gisle Vanem brought changes to the mkhelp script for the generation of the
|
||
compressed help text on some platforms.
|
||
|
||
Version 7.10.6 (28 July 2003)
|
||
|
||
Daniel (28 July)
|
||
- Fran<61>ois Pons brought a patch that once again made curl deal with ftp and
|
||
"double slash" as indicating the root directory. In the RFC1738-fix of April
|
||
30, that ability was removed (since it is not the "right" way). So, starting
|
||
now we can list the root dir of an ftp server both these ways:
|
||
|
||
curl ftp://server.com/%2f as well as
|
||
curl ftp://server.com//
|
||
|
||
Daniel (24 July)
|
||
- Henry Bland pointed out that we included sys/resource.h without good reason
|
||
in several source files. Without it included, QNX builds better...
|
||
|
||
- Andr<64>s Garc<72>a updated the mingw makefiles.
|
||
|
||
Daniel (23 July)
|
||
- Tracy Boehrer experienced DNS cache problems and did some nice debugging
|
||
and tracking which made it easy for me to correct the problem and Tracy
|
||
could verify that it did cure the problem! When re-using a connection we
|
||
now make sure we don't re-use the 'connect_addr' struct.
|
||
|
||
- Daniel Kouril corrected the GSS-Negotiate code.
|
||
|
||
- Juan F. Codagnone provided fixes to allow curl to build fine on Windows
|
||
again.
|
||
|
||
Daniel (22 July)
|
||
- Edited the curl/curl.h include file to build on Windows properly.
|
||
|
||
Daniel (21 July)
|
||
- Moved the proxy credentials from the SessionHandle struct to the connectdata
|
||
struct, to make multiple proxy connections with differerent user names work.
|
||
|
||
- Adjusted the NTLM code to support proxy functionality.
|
||
|
||
- Made the krb4 stuff compile with the user+password fields moved.
|
||
|
||
Version 7.10.6-pre4 (21 July 2003)
|
||
|
||
Daniel (20 July)
|
||
- David Gardner pointed out in bug report 770755 that using the FTP command
|
||
CWD with a blank argument is a bad idea and I made libcurl skip empty path
|
||
segments starting now.
|
||
|
||
Daniel (18 July)
|
||
- Cris pointed out that my fix on July 16th didn't work fully. His pointing
|
||
out this (and his patch) also made me realize that we have a very similar
|
||
bug in the FTP connection re-use code. We must store a separate user and
|
||
password field for each connection we keep (at least for FTP and HTTP+NTLM
|
||
connections, so I made us do this unconditionally).
|
||
|
||
- Since NTLM authenticates connections instead of single requests, I had to
|
||
re-arrange how we store the NTLM data and I had to improve the test suite to
|
||
finally work properly with persistency to make the NTLM tests run fine
|
||
again. This also forced me to have to update lots of HTTP test cases.
|
||
|
||
Daniel (16 July)
|
||
- Cris Bailiff's bug report 768275 pointed out that using Basic auth with
|
||
wrong user+password caused an endless loop. Fixed now. He also found out that
|
||
we didn't properly authenticate connections with NTLM. Fixed too.
|
||
|
||
- Dan Winship provided fixes for the NTLM code.
|
||
|
||
Daniel (5 July)
|
||
- Doug Kaufman provided additional fixes for the DOS port.
|
||
|
||
Daniel (4 July)
|
||
- Rick Richardson pointed out that using setvbuf() to achieve non-buffering
|
||
on output is no-good for SCO Xenix and other unixes. We switched over to
|
||
using plain fflush() instead.
|
||
|
||
- Dan Grayson pointed out that we set the CURL_CA_BUNDLE variable wrongly in
|
||
the configure script, and I had to change some build stuff to make the new
|
||
way work.
|
||
|
||
- Peter Sylvester's patch was applied that introduces the following:
|
||
|
||
CURLOPT_SSL_CTX_FUNCTION to set a callback that gets called with the
|
||
OpenSSL's ssl_ctx pointer passed in and allow a callback to act on it. If
|
||
anything but CURLE_OK is returned, that will also be returned by libcurl
|
||
all the way back. If this function changes the CURLOPT_URL, libcurl will
|
||
detect this and instead go use the new URL.
|
||
|
||
CURLOPT_SSL_CTX_DATA is a pointer you set to get passed to the callback set
|
||
with CURLOPT_SSL_CTX_FUNCTION.
|
||
|
||
Daniel (1 July)
|
||
- David Byron provided a patch that allows a client to quit the test suite's
|
||
HTTP server.
|
||
|
||
- Gisle Vanem found and patched a lib handle leak in the ldap code.
|
||
|
||
Daniel (25 June)
|
||
- More NTLM-improvements. Less code. Smaller packets back and forth.
|
||
|
||
Daniel (23 June)
|
||
- Eric Glass provided us with a better doc on NTLM details, and I added more
|
||
comments and clarified the current code more. Using the new knowledge, we
|
||
should be able to make the NTLM stuff work even better.
|
||
Eric's original URL: http://davenport.sourceforge.net/ntlm.html
|
||
Version stored and provided at curl site: http://curl.haxx.se/rfc/ntlm.html
|
||
|
||
- Fixed the minor compile problems pre3 had if built without GSSAPI and/or
|
||
SSL.
|
||
|
||
Version 7.10.6-pre3 (19 June 2003)
|
||
|
||
Daniel (19 June)
|
||
- Made curl use curl_free() on memory returned by curl_getenv(), as this
|
||
should theoreticly make it possibly to build and run curl and libcurl with
|
||
different memory allocation schemes with no problems.
|
||
|
||
Daniel (18 June)
|
||
- Improved the mkhelp.pl a bit further to make a nicer hugehelp text and to
|
||
include a better comment in the top for the gzip compressed version.
|
||
|
||
Daniel (17 June)
|
||
- CURLOPT_HTTPAUTH is now a bitmask, in which you set which authentication
|
||
type(s) you want to use. If more than one is set, libcurl will use one of
|
||
the selected one and the one it considers is more secure. Test case 67 and
|
||
68 (for NTLM) were fixed and we've reduced a round-trip for specific --ntlm
|
||
fetches, and test case 69 and 70 were added for testing authentication
|
||
"picking". --anyauth is the new command line tool option, and I also added
|
||
--basic for completeness (that's the default type).
|
||
|
||
- Fixed the runtests.pl script to use the info provided by the new curl -V
|
||
output.
|
||
|
||
- --enable-debug now sets the CURLDEBUG define instead of MALLOCDEBUG, as it
|
||
is meant to be a generic debug conditional.
|
||
|
||
- curl_version_info() can now return CURL_VERSION_DEBUG as a feature bit, to
|
||
indicate that the library was built with CURLDEBUG set.
|
||
|
||
- Ralph Mitchell found out that some web applications very badly uses white
|
||
spaces in Location: redirects, and apparently IE is a browser (the only
|
||
one?) that supports this abomination. Based on Ralph's patch, I added code
|
||
that now attempts to replace white spaces with the proper "%20" or "+".
|
||
Test case 40 and 42 were added to verify my changes.
|
||
|
||
- curl -V now also outputs a list of features the available library offers (if
|
||
any).
|
||
|
||
- The curl_version() string now includes "GSS" if libcurl is built with GSSAPI
|
||
support.
|
||
|
||
- David Orrell reported that libcurl still crashed when sending HUGE requests
|
||
over HTTPS... I fixed.
|
||
|
||
Version 7.10.6-pre2 (16 June 2003)
|
||
|
||
Daniel (16 June)
|
||
- curl_version_info() now returns bitmasked information weather NTLM and
|
||
GSSNEGOTIATE are supported, since it is doomed to vary on different
|
||
installations.
|
||
|
||
- I remade the HTTP Digest code to use the MD5-code provided by OpenSSL if
|
||
that is present, and only use our own MD5-code if it isn't.
|
||
|
||
Daniel (13 June)
|
||
- More NTLM help, fixes and patches from Cris Bailiff.
|
||
|
||
- Marty Kuhrt brought include fixes for making VMS builds warning-free.
|
||
|
||
Daniel (12 June)
|
||
- NTLM authentication works somewhat against the test servers provided by
|
||
Mathias Axelsson and Cris Bailiff. Use by setting CURLOPT_HTTPAUTH to
|
||
CURLAUTH_NTLM to libcurl, or --ntlm for the curl tool. Test case 67 and 68
|
||
were added for this. NTLM-support requires OpenSSL.
|
||
|
||
- Dan Fandrich provided a patch, that granted that gzip and libz are available
|
||
at build-time, compresses the hugehelp text in the curl command line and
|
||
uncompresses it at request. Saves some ~60K in the final output executable.
|
||
|
||
Daniel (11 June)
|
||
- Long day of fighting the NTLM demons.
|
||
|
||
Daniel (10 June)
|
||
- Modified how to set auth type to libcurl. Now use CURLOPT_HTTPAUTH instead,
|
||
and pick method. Supported ones currently are:
|
||
CURLAUTH_BASIC - default selection
|
||
CURLAUTH_DIGEST - formerly CURLOPT_HTTPDIGEST
|
||
CURLAUTH_GSSNEGOTIATE
|
||
|
||
- Daniel Kouril added HTTP GSS-Negotiate authentication support, as defined in
|
||
the IETF draft draft-brezak-spnego-http-04.txt. In use already by various
|
||
Microsoft web applications. --negotiate is the new family member. To take
|
||
advantage of this, you need one of these packages:
|
||
|
||
o Heimdal Kerberos5 http://www.pdc.kth.se/heimdal/heimdal.html
|
||
o GSSAPI from Globus http://www.globus.org/
|
||
o GSSAPI libraries from MIT Kerberos5 http://web.mit.edu/kerberos/www/
|
||
|
||
- A missing ending bracket (']') while doing URL globbing could lead to a
|
||
segfault. While fixing this, I also introduced better error reporting in the
|
||
globbing code. (All this is application code outside libcurl.)
|
||
|
||
Daniel (6 June)
|
||
- David Orrell found out that sending a huge GET request over HTTPS could
|
||
make libcurl fail and return an error code.
|
||
|
||
Daniel (2 June)
|
||
- Richard Bramante found out that "Content-Length: 0" was not properly used by
|
||
libcurl if the response-headers indicated that the connection would be
|
||
closed.
|
||
|
||
- David Byron's patch was applied, that makes the --progress-bar take the
|
||
local size into account when doing resumed downloads.
|
||
|
||
- Feedback from Serge Semashko made me change the error message returned when
|
||
CURLE_HTTP_RETURNED_ERROR is returned.
|
||
|
||
- Anonymous in bug report #745122 pointed out that we should really be using
|
||
SSL_CTX_set_options(... SSL_OP_ALL) to work around flaws in existing SSL
|
||
implementations.
|
||
|
||
Daniel (27 May)
|
||
- Andreas Ley and Rich Gray helped me point out that no version of HP-UX has
|
||
the sys/select.h header file so including it unconditionally in curl/multi.h
|
||
is not a good thing. Now we check for HPUX and avoid using that header on
|
||
such systems.
|
||
|
||
- Rudy Koento experienced problems with curl's recent habit of POSTing data in
|
||
two separate send() calls, first the headers and then the data. I've now
|
||
made a fix that for static and known content that is less than 100K in size,
|
||
everything is now sent in one single system call again. This is also better
|
||
for network performance reasons.
|
||
|
||
- I modified the main makefile to not build the test suite and a few other
|
||
unnecessary things by default. Now, the test suite is built when 'make test'
|
||
is run. This reduces build time for those who don't care for the test
|
||
suite, and it also reduces confusion for people using platforms where the
|
||
test suite build fails!
|
||
|
||
Daniel (26 May)
|
||
- Chris Lewis pointed out a flaw in the #ifdefs in curl/multi.h for Windows,
|
||
which is now corrected.
|
||
|
||
- Jis Joy found another flaw in the SOCK5 code, as libcurl treated the socks5
|
||
proxy a little too much like as if it was a http proxy.
|
||
|
||
Daniel (23 May)
|
||
- Ricardo Cadime found a socket leak when listing directories without
|
||
contents. Test cases 144 and 145 were added to verify the fix.
|
||
|
||
- Rudy Koento found yet another problem when a HTTP server returns only a
|
||
single-line of contents without any headers at all. libcurl then failed to
|
||
count the data, thus returning error 52 "no contents". Test case 66 was
|
||
added to verify that we now do right.
|
||
|
||
Version 7.10.6-pre1 (23 May 2003)
|
||
|
||
Daniel (23 May)
|
||
- Jis in bug report #741841, fixed a bug in the SOCKS5 proxy-using code.
|
||
|
||
Daniel (22 May)
|
||
- David Remahl set up a test-server for me providing Digest authentication,
|
||
and I wrote the first working code that support it. The test suite was
|
||
modified slightly as well to work better for it and --digest was added to
|
||
the command line options (and CURLOPT_HTTPDIGEST to the library)... RFC2617
|
||
has all the gory details.
|
||
|
||
Daniel (21 May)
|
||
- David Balazic pointed out that curl_unescape() didn't check that %-codes
|
||
were correctly followed by two hexadecimal digits when it unescape strings.
|
||
Now, we do the check and only %XX codes are unescaped if the X letters are
|
||
hexadecimals.
|
||
|
||
- Gisle Vanem made curl build with djgpp on DOS.
|
||
|
||
- Gisle Vanem improved the mkhelp.pl script to make a nicer manual that is
|
||
shown with curl -M.
|
||
|
||
Daniel (20 May)
|
||
- Gisle Vanem provided a fix that makes libcurl more conservative, not
|
||
expecting h_aliases of the hostent struct to always be non-NULL.
|
||
|
||
Daniel (19 May)
|
||
- As requested by Martin Michlmayr in Debian bug report #193630, libcurl now
|
||
supports user name and password in the proxy environment variables. Added
|
||
test case 63 to verify this.
|
||
|
||
Version 7.10.5 (19 May 2003)
|
||
|
||
Daniel (15 May)
|
||
- Changed the order for the in_addr_t testing, as 'unsigned long' seems to be
|
||
a very common type inet_addr() returns.
|
||
|
||
Daniel (14 May)
|
||
- George Comninos provided a fix that calls the progress meter when waiting
|
||
for FTP command responses take >1 second. It'll make applications more
|
||
"responsive" even when dealing with very slow ftp servers.
|
||
|
||
Daniel (12 May)
|
||
- George Comninos pointed out that libcurl uploads had two quirks:
|
||
o when using FTP PORT command, it used blocking sockets!
|
||
o it could loop a long time without doing progress meter updates
|
||
Both items are fixed now.
|
||
|
||
Daniel (9 May)
|
||
- Dan Fandrich changed CURLOPT_ENCODING to select all supported encodings if
|
||
set to "". This frees the application from having to know which encodings
|
||
the library supports.
|
||
|
||
- Dan Fandrich pointed out we had three unnecessary files in CVS that is
|
||
generated with libtoolize, so they're now removed and libtoolize is invoked
|
||
accordingly in the buildconf script.
|
||
|
||
- Avery Fay found out that the CURLOPT_INTERFACE way of first checking if the
|
||
given name is a network interface gave a real performance penalty on Linux,
|
||
so now we more appropriately first check if it is an IP number and if so
|
||
we don't check for a network interface with that name.
|
||
|
||
- CURLOPT_FTP_USE_EPRT added. Set this to FALSE to disable libcurl's attempts
|
||
to use EPRT and LPRT before the traditional PORT command. The command line
|
||
tool sets this option with '--disable-eprt'.
|
||
|
||
Version 7.10.5-pre2 (6 May 2003)
|
||
|
||
Daniel (6 May)
|
||
- Kevin Delafield reported another case where we didn't correctly check for
|
||
EAGAIN but only EWOULDBLOCK, which caused badness on HPUX.
|
||
|
||
Daniel (4 May)
|
||
- Ben Greear noticed that the check for 'writable argv' exited the configure
|
||
script when run for cross-compiling, which wasn't nice. Now it'll default to
|
||
no and output a warning about the fact that it was not checked for.
|
||
|
||
Daniel (2 May)
|
||
- Added test case 62 and fixed some more on the cookie sending with a custom
|
||
Host: header set.
|
||
|
||
Daniel (1 May)
|
||
- Andy Cedilnik fixed a few compiler warnings.
|
||
|
||
- Made the "SSL read error: 5" error message more verbose, by adding code that
|
||
queries the OpenSSL library to fill in the error buffer.
|
||
|
||
Daniel (30 Apr)
|
||
- Added sys/select.h include in the curl/multi.h file, after having been
|
||
reminded about this by Rich Gray.
|
||
|
||
- I made each test set its own server requirements, thus abandoning the
|
||
previous system where the test number implied what server(s) to use for a
|
||
specific test.
|
||
|
||
- David Balazic made curl more RFC1738-compliant for FTP URLs, by fixing so
|
||
that libcurl now uses one CWD command for each path part. A bunch of test
|
||
cases were fixed to work accordingly.
|
||
|
||
- Cookie fixes:
|
||
|
||
A. Save domains in jars like Mozilla does. It means all domains set in
|
||
Set-Cookie: headers are dot-prefixed.
|
||
B. Save and use the 'tailmatch' field in the Mozilla/Netscape cookie jars
|
||
(the second column).
|
||
C. Reject cookies using illegal domains in the Set-Cookie: line. Concerns
|
||
both domains with too few dots or domains that are outside the currently
|
||
operating server host's domain.
|
||
D. Set the path part by default to the one used in the request, if none was
|
||
set in the Set-Cookie line.
|
||
|
||
To make item C really good, I also made libcurl notice custom Host: headers
|
||
and extract the host name set in there and use that as the host name for the
|
||
site we're getting the cookies from. This allows user to specify a site's
|
||
IP-address, but still be able to receive and send its cookies properly if
|
||
you provide a valid Host: name for the site.
|
||
|
||
Daniel (29 Apr)
|
||
- Peter Kovacs provided a patch that makes the CURLINFO_CONNECT_TIME work fine
|
||
when using the multi interface (too).
|
||
|
||
Version 7.10.5-pre1 (23 Apr 2003)
|
||
|
||
Daniel (23 Apr)
|
||
- Upgraded to libtool 1.5.
|
||
|
||
Daniel (22 Apr)
|
||
- Peter Sylvester pointed out that curl_easy_setopt() will always (wrongly)
|
||
return CURLE_OK no matter what happens.
|
||
|
||
- Dan Fandrich fixed some gzip decompression bugs and flaws.
|
||
|
||
Daniel (16 Apr)
|
||
- Fixed minor typo in man page, reported in the Debian bug tracker.
|
||
|
||
Daniel (15 Apr)
|
||
- Fixed some FTP tests in the test suite that failed on my Solaris host, due
|
||
to the config.h not being included before the system headers. When done that
|
||
way, it did get a mixed sense of if big files are supported or not and then
|
||
stat() and fstat() (as used in test case 505) got confused and failed to
|
||
return a proper file size.
|
||
|
||
- Formposting a file using a .html suffix is now properly set to Content-Type: text/html.
|
||
|
||
Daniel (14 Apr)
|
||
- Fixed the SSL error handling to return proper SSL error messages again, they
|
||
broke in 7.10.4. I also attempt to track down CA cert problems and then
|
||
return the CURLE_SSL_CACERT error code.
|
||
|
||
- The curl tool now intercepts the CURLE_SSL_CACERT error code and displays
|
||
a fairly big and explanatory error message. Kevin Roth helped me out with
|
||
the wording.
|
||
|
||
Daniel (11 Apr)
|
||
- Nic Hines provided a second patch for gzip decompression, and fixed a bug
|
||
when deflate or gzip contents were downloaded using chunked encoding.
|
||
|
||
- Dan Fandrich made libcurl support automatic decompression of gzip contents
|
||
(as an addition to the previous deflate support).
|
||
|
||
- I made the CWD command during FTP session consider all 2xy codes to be OK
|
||
responses.
|
||
|
||
Daniel (10 Apr)
|
||
- Vlad Krupin fixed a URL parsing issue. URLs that were not using a slash
|
||
after the host name, but still had "?" and parameters appended, as in
|
||
"http://hostname.com?foobar=moo", were not properly parsed by libcurl.
|
||
|
||
Daniel (9 Apr)
|
||
- Made CURLOPT_TIMECONDITION work for FTP transfers, using the same syntax as
|
||
for HTTP. This then made -z work for ftp transfers too. Added test case 139
|
||
and 140 for verifying this.
|
||
|
||
- Getting the file date of an ftp file used the wrong time zone when
|
||
displayed. It is supposedly always GMT. Added test case 141 for this.
|
||
|
||
- Made the test suite's FTP server support MDTM.
|
||
|
||
- The default DEBUGFUNCTION, as enabled with CURLOPT_VERBOSE now outputs
|
||
CURLINFO_HEADER_IN data as well. The most notable effect from this is that
|
||
using curl -v, you get to see the incoming "headers" as well. This is
|
||
perhaps most useful when doing ftp.
|
||
|
||
Daniel (8 Apr)
|
||
- James Bursa fixed a flaw in the Content-Type extraction code, which missed
|
||
the first letter if no space followed the colon.
|
||
|
||
- Magnus Nilsson pointed out that share.c was missing in the MSVC project
|
||
file.
|
||
|
||
Daniel (6 Apr)
|
||
- Ryan Weaver provided a patch that makes the CA cert bundle not get installed
|
||
anymore when 'configure --without-ssl' has been used.
|
||
|
||
Daniel (4 Apr)
|
||
- Martijn Broenland found another cases where a server application didn't
|
||
like the boundary string used by curl when doing a multi-part/formpost. We
|
||
modified the boundary string to look like the one IE uses, as this is
|
||
probably gonna make curl work with more applications.
|
||
|
||
Daniel (3 Apr)
|
||
- Kevin Roth reported that a bunch of tests fails on cygwin. One set fails
|
||
when using perl 5.8 (and they run fine with perl 5.6), and another set
|
||
failed because of an artifact in the test suite's FTP server that I
|
||
corrected. It turned out the FTP server code was still having a file opened
|
||
while the main test script removed it and invoked the HTTP server that
|
||
attempted to create the same file name of the file the FTP server kept open.
|
||
This operation works fine on unix, but not on cygwin.
|
||
|
||
Version 7.10.4 (2 Apr 2003)
|
||
|
||
Daniel (1 Apr)
|
||
- Added test case 505 to exercise FTP upload with rename done with libcurl,
|
||
and for that I had to extend the test suite's FTP server to deal with the
|
||
RNFR and RNTO commands.
|
||
|
||
Daniel (31 Mar)
|
||
- Even more SSL config check modifications after Richard's testing.
|
||
|
||
Version 7.10.4-pre6 (31 Mar 2003)
|
||
|
||
Daniel (31 Mar)
|
||
- More fixes for the SSL session ID cache checks when SSL configs are changed
|
||
between connections. Based on tests and talks with Richard Bramante.
|
||
|
||
- Guillaume Cottenceau provided a patch that added CURLOPT_UNRESTRICTED_AUTH.
|
||
When enabled, it will prevent libcurl from limiting to which host it sends
|
||
user+password to when following locations. By default, libcurl only sends
|
||
name and password to the original host used in the first URL, but with this
|
||
option set it will send the auth info to all hosts it follows location
|
||
headers to. The new tool command line option for this is named
|
||
"--location-trusted".
|
||
|
||
- Frankie Fong reported a problem with libcurl if you re-used an easy handle
|
||
with a proxy, and you first made a https:// connection to a host and then
|
||
switched to a http:// one to the same host. libcurl would then wrongly re-use
|
||
the same connection for it and fail to get the second URL properly
|
||
|
||
Daniel (29 Mar)
|
||
- Dan Shearer's fix that makes curl complain if invoked with nothing but "curl
|
||
-O" was applied.
|
||
|
||
Daniel (26 Mar)
|
||
- Bryan Kemp was friendly enough to lend me an account on his Redhat 9 box and
|
||
I could fix the configure problems on redhat 8.1 and 9 in no time thanks to
|
||
this. Thanks a bunch Bryan!
|
||
|
||
Daniel (25 Mar)
|
||
- Renamed configure.in to configure.ac
|
||
|
||
Version 7.10.4-pre5 (25 Mar 2003)
|
||
|
||
Daniel (25 Mar)
|
||
- Richard Bramante provided a fix for a handle re-use problem seen when you
|
||
change options on an SSL-enabled connection between requests. Previously,
|
||
changing peer verification or host verification and similar things was not
|
||
taken into account when a connection were checked for re-use and thus
|
||
enabling stricter check between requests on a re-used connection made no
|
||
difference and the connection would thus be used erroneously.
|
||
|
||
Daniel (24 Mar)
|
||
- G<>tz Babin-Ebell pointed out that the ca-bundle.crt file contained a
|
||
certificate from Trustcenter that was a demo certificate only that was never
|
||
intended to be part of a CA bundle.
|
||
|
||
Daniel (21 Mar)
|
||
- Life is a mystery. Within a time period of 17 hours, Tim Pope and Michael
|
||
Churchill filed one bug report each, both identifying problems with a second
|
||
transfer when doing persistent transfers re-using a connection. Tim's one is
|
||
#706624, labeled "Multiple uploads per handle fail" and Michael's #707003
|
||
"Does not send Authorization: header when reusing connection". I could track
|
||
both down to the same piece of logic and it turned out libcurl was not using
|
||
new settings properly when re-using an existing connection. This concerned
|
||
both uploading and downloading and involved exactly those pieces these two
|
||
reports identified. This code has been this faulty since the day I
|
||
introduced persistent connection support in libcurl, more than 2 years ago.
|
||
|
||
Daniel (20 Mar 2003)
|
||
- Five year anniversary. Today five years ago, the first ever curl release saw
|
||
the light of day.
|
||
|
||
Daniel (17 Mar)
|
||
- Andy Cedilnik corrected flaws in some libcurl example-usage sources.
|
||
|
||
Daniel (16 Mar)
|
||
- Juan F. Codagnone reported that the fix from March 2nd was incomplete.
|
||
|
||
- Added code to the configure.in to check for select() argument types. I've
|
||
not made any code use the results just yet though.
|
||
|
||
Daniel (15 Mar)
|
||
- Gisle Vanem provided two patches to build better on Windows.
|
||
|
||
- Adjusted the test suite code to better make sure that the server(s) required
|
||
for a specific test is properly started before the test case is attempted.
|
||
Many tests now run a lot faster than before.
|
||
|
||
Daniel (14 Mar)
|
||
- Another configure.in adjustment made the configure detect functions properly
|
||
on HPUX now.
|
||
|
||
Daniel (13 Mar)
|
||
- Philippe Raoult fixed pre4-compile quirks for FreeBSD.
|
||
|
||
Version 7.10.4-pre4 (13 Mar 2003)
|
||
|
||
Daniel (13 Mar)
|
||
- Added a backup-check for functions that aren't found by AC_CHECK_FUNCS()
|
||
as I believe some checks on HPUX need this. At least some of the info given
|
||
to us by Rick Jones seemed to indicate this.
|
||
|
||
Daniel (12 Mar)
|
||
- Thomas Tonino found out that if you used the curl tool to do PUT operations
|
||
as in 'curl www.foo.com/dir/ -T file' and the file name included for example
|
||
space or other characters that don't belong in URLs, curl did not properly
|
||
URL encode them before using them in the URL.
|
||
|
||
- Added an option to configure called --enable-libgcc that simply adds -lgcc
|
||
to the LIBS variable, as this seems to be a common problem.
|
||
|
||
- I modified the configure.in file, so that the headers are now checked in an
|
||
order of "viality". We must also make sure to use the "default headers"
|
||
parameter to AC_CHECK_HEADERS() so that headers are checked with the proper
|
||
prerequisites included (i.e all the major and generally important header
|
||
files are included there by default). This might be what we need for various
|
||
Sun, HP, AIX and Tru64 systems to behave good again on the header check
|
||
front.
|
||
|
||
- Rick Jones pointed out a few compiler warnings on HP-UX that I addressed.
|
||
|
||
- I made the configure --help output nicer by using AC_HELP_STRING() a lot
|
||
more.
|
||
|
||
Daniel (11 Mar)
|
||
- Christophe Demory fixed the socket sending code to work better on HP-UX
|
||
when sending data to a socket that would block. It then returns EAGAIN, not
|
||
EWOULDBLOCK.
|
||
|
||
- Richard Gorton improved the seeding function for systems without a good
|
||
and reliable random source.
|
||
|
||
- Richard Gorton fixed a few warnings that popped up when you built curl
|
||
using the Sun compiler on a 64bit SPARC platform.
|
||
|
||
- Martin C. Martin fixed a case where a connect failure using the multi
|
||
interface didn't produce a human readable error string.
|
||
|
||
Daniel (10 Mar)
|
||
- Reverted ltmain.sh back to libtool 1.4.2 status again, as the 1.4.3 version
|
||
broke the build on numerous platforms. It seems that libtool 1.4.3 puts some
|
||
requirements on what versions of the other tools (autoconf + automake) that
|
||
I am not familiar with and thus I couldn't fulfill at this point.
|
||
|
||
Yes, this is more than mildly frustrating.
|
||
|
||
Daniel (7 Mar)
|
||
- Run libtoolize version 1.4.3.
|
||
|
||
Version 7.10.4-pre3 (4 Mar 2003)
|
||
|
||
Daniel (3 Mar)
|
||
- Added share.obj to the VC6 and Borland libcurl makefiles.
|
||
|
||
- Troels Walsted Hansen found and investigated a problem with libcurl on AIX,
|
||
presumably only on 4.3 or later. gethostbyname_r() is not returning data
|
||
that is possible to "keep" and cache the way libcurl does. But instead these
|
||
versions of AIX uses a gethostbyname() that works thread-safely we can
|
||
instead use the ordinary gethostbyname() and our pack_hostent() approach to
|
||
achieve what we want. The configure script now attempts to detect AIX 4.3 or
|
||
later to adjust for this.
|
||
|
||
Daniel (2 Mar)
|
||
- Juan F. Codagnone found a problem introduced in 7.10.3 when you first did a
|
||
POST and then back to a GET using the same easy handle.
|
||
|
||
Daniel (28 Feb)
|
||
- Removed the strequal and strnequal defines from curl/curl.h header. They
|
||
were never meant for the public header anyway. Philippe Raoult brought it
|
||
up.
|
||
|
||
- James Bursa fixed the RISC OS build.
|
||
|
||
Daniel (27 Feb)
|
||
- Avery Fay pointed out the very misleading curl_multi_info_read man page, and
|
||
I updated it to become more accurate.
|
||
|
||
- Salvatore Sorrentino found a problem with FTP downloading that turned out to
|
||
be his FTP server returning size zero (0 bytes) when SIZE was used on a file
|
||
while being in BINARY mode. We now make a second check for the actual size
|
||
by scanning the RETR reply anyway, even if the SIZE command returned 0.
|
||
|
||
Daniel (26 Feb)
|
||
- Kyle Sallee reported a case where he would do a transfer that didn't update
|
||
the progress meter properly. It turned out to be a case where libcurl would
|
||
loop a little too eagerly in the transfer loop, which isn't really good for
|
||
the APIs, especially not the multi API.
|
||
|
||
Version 7.10.4-pre2 (24 Feb 2003)
|
||
|
||
Daniel (24 Feb)
|
||
- Kjetil Jacobsen found out that setting CURLOPT_MAXCONNECTS to a value higher
|
||
than 5 could cause a segfault.
|
||
|
||
- I believe I fixed the 'Expect: 100-continue' behavior that has been broken
|
||
for a while (I think since my change dated Dec 10 2002). When this header is
|
||
used, libcurl should wait for a HTTP 100 (or timeout) before sending the
|
||
post/put data.
|
||
|
||
Daniel (14 Feb)
|
||
- Matthew Clarke provided some info what to modify to make curl build
|
||
flawlessly on AIX 3.2.5.
|
||
|
||
- Martin C. Martin found and fixed a problem in the multi interface when
|
||
running on Windows and trying to connect to a port without a listener.
|
||
|
||
Daniel (13 Feb)
|
||
- Christopher R. Palmer fixed Curl_base64_encode() to deal with zeroes in the
|
||
data to encode.
|
||
|
||
Daniel (4 Feb)
|
||
- Jean-Philippe added the first code that enables the 'share' system. This
|
||
should now enable sharing of DNS data between two curl easy handles.
|
||
|
||
- Incorporated Nico Baggus' fixes to again compile flawlessly on VMS.
|
||
|
||
- James Bursa corrected a bad comment in the public include file curl/multi.h
|
||
|
||
- Peter Forret reported one of those error:00000000 cases in libcurl again
|
||
when connecting to a HTTPS site, and this time I did discover some oddities
|
||
in how curl reports SSL errors back. It could miss showing the actual error.
|
||
|
||
Version 7.10.4-pre1 (3 Feb 2003)
|
||
|
||
Daniel (3 Feb)
|
||
- Removed things in the docs saying capath doesn't work on Windows, as Julian
|
||
Noble told us it works fine.
|
||
|
||
Daniel (31 Jan)
|
||
- Kevin Roth fixed the zlib build stuff in the Mingw32 makefile.
|
||
|
||
Daniel (30 Jan)
|
||
- Kevin Roth found out that curl on Windows always checked for the CA cert
|
||
bundle using the environment variable and the path scan, even though
|
||
-k/--insecure was used.
|
||
|
||
- Hamish Mackenzie pointed out that curl only did strict host name verifying
|
||
if capath or cainfo was used. Now it'll always do it unless -k / --insecure
|
||
is used!
|
||
|
||
- Pavel Cenek pointed out that the Content-Type extraction was done wrongly
|
||
as the full string was not fetched. Added test case 57 to verify that curl
|
||
does it right now.
|
||
|
||
Daniel (29 Jan)
|
||
- Jamie Wilkinson provided a patch that now makes curl attempt to clear out
|
||
"sensitive" command line arguments so that they don't appear in ps outputs
|
||
(only on platforms that allow writing to argv[]).
|
||
|
||
- John McGowan found out that the DEBUGFUNCTION could be called with bad
|
||
arguments and thus cause the --trace outputs to go wrong.
|
||
|
||
- Removed all the emacs local variables from all files. Mats Lidell provided
|
||
the new sample.emacs file (for a sample of what to include in your .emacs)
|
||
and the curl-style.el that sets a better c-style for editing curl sources.
|
||
|
||
- Dave Halbakken found a problem with FTP downloads that could accidently
|
||
return CURLE_PARTIAL_FILE when curl_easy_perform() was called with NOBODY
|
||
set TRUE.
|
||
|
||
Daniel (27 Jan)
|
||
- The fopen.c example was flawed as Nick Humfrey noticed, and I fixed it to
|
||
work again.
|
||
|
||
Daniel (24 Jan)
|
||
- Bertrand Demiddelaer found and fixed a memory leak (the content-type string)
|
||
when following locations.
|
||
|
||
Daniel (22 Jan 2003)
|
||
- Ian Wilkes and Legoff Vincent both independently provided fixes for making
|
||
curl/multi.h work properly when compiled with a C++ compiler.
|
||
|
||
Daniel (20 Jan 2003)
|
||
- Fixed 'buildconf' to check version number of the required tools before
|
||
they're actually used.
|
||
|
||
- Wrote 'testcurl.sh', a script targeted for automatic and distributed curl
|
||
tests on various platforms.
|
||
|
||
- David Thiel pointed out that the .netrc file was not being dealt with
|
||
properly anymore. I broke this in the password prompting "fix".
|
||
|
||
- Markus F.X.J. Oberhumer patched libcurl to allocate the scratch buffer only
|
||
on demand and thus we save 32KB in each curl handle that don't use that
|
||
buffer. This need appeared when some people started using thousands of
|
||
simultaneous curl handles... :-)
|
||
|
||
Daniel (16 Jan 2003)
|
||
- Markus Oberhumer fixed curl-config --cflags when the includedir was not
|
||
/usr/include.
|
||
|
||
- Markus Oberhumer fixed CURLINFO_PRIVATE to properly return NULL if it was
|
||
set to NULL!
|
||
|
||
Version 7.10.3 (14 Jan 2003)
|
||
|
||
Daniel (10 Jan 2003)
|
||
- Steve Oliphant pointed out that test case 105 did not work anymore and this
|
||
was due to a missing fix for the password prompting.
|
||
|
||
Version 7.10.3-pre6 (10 Jan 2003)
|
||
|
||
Daniel (9 Jan 2003)
|
||
- Bryan Kemp pointed out that curl -u could not provide a blank password
|
||
without prompting the user. It can now. -u username: makes the password
|
||
empty, while -u username makes curl prompt the user for a password.
|
||
|
||
- Kjetil Jacobsen found a remaining connect problem in the multi interface on
|
||
ipv4 systems (Linux only?), that I fixed and Kjetil verified that it fixed
|
||
his problems.
|
||
|
||
- memanalyze.pl now reads a file name from the command line, and no longer
|
||
takes the data on stdin as before.
|
||
|
||
Version 7.10.3-pre5 (9 Jan 2003)
|
||
|
||
Daniel (9 Jan 2003)
|
||
- Fixed tests/memanalyze.pl to work with file names that contain colons (as on
|
||
Windows).
|
||
|
||
- Kjetil Jacobsen quickly pointed out that lib/share.h was missing...
|
||
|
||
Version 7.10.3-pre4 (9 Jan 2003)
|
||
|
||
Daniel (9 Jan 2003)
|
||
- Updated lib/share.c quite a bit to match the design document at
|
||
http://curl.haxx.se/dev/sharing.txt a lot more.
|
||
|
||
I'll try to update the document soonish. share.c is still not actually used
|
||
by libcurl, but the API is slowly getting there and we can start
|
||
implementing code that takes advantage of this system.
|
||
|
||
Daniel (8 Jan 2003)
|
||
- Updated share stuff in curl/curl.h, including data types, structs and
|
||
function prototypes. The corresponding files in lib/ were also modified
|
||
of course to remain compilable. Based on input from Jean-Philippe and also
|
||
to make it more in line with the design document.
|
||
|
||
- Jean-Philippe Barrette-LaPierre patched a very trivial memory leak in
|
||
curl_escape() that would happen when realloc() returns NULL...
|
||
|
||
- Matthew Blain provided feedback to make the --create-dirs stuff build
|
||
properly on Windows.
|
||
|
||
- Fixed the #include in tests/libtest/first.c as Legoff Vincent pointed out.
|
||
|
||
Daniel (7 Jan 2003)
|
||
- Philippe Raoult provided a patch that now makes libcurl properly support
|
||
wildcard checks for certificate names.
|
||
|
||
- Simon Liu added CURLOPT_HTTP200ALIASES, to let an application set other
|
||
strings recognized as "HTTP 200" to allow http-like protocols to get
|
||
downloaded fine by curl.
|
||
|
||
- Now using autoconf 2.57 and automake 1.7.2
|
||
|
||
- Doing "curl -I ftp://domain/non-existing-file" still outputed a date!
|
||
Wayne Haigh reported.
|
||
|
||
- The error message is now written properly with a newline in the --trace
|
||
file.
|
||
|
||
Daniel (6 Jan 2003)
|
||
- Sterling Hughes fixed a possible bug: previously, if you called
|
||
curl_easy_perform and then set the global dns cache, the global cache
|
||
wouldn't be used. Pointed out by Jean-Philippe Barrette-LaPierre.
|
||
|
||
- Matthew Blain's fixed the VC6 libcurl makefile to include better debug data
|
||
on debug builds.
|