Skip to content
Snippets Groups Projects
CHANGES 63.6 KiB
Newer Older
  • Learn to ignore specific revisions
  • Daniel Stenberg's avatar
    Daniel Stenberg committed
                                      _   _ ____  _     
                                  ___| | | |  _ \| |    
                                 / __| | | | |_) | |    
                                | (__| |_| |  _ <| |___ 
                                 \___|\___/|_| \_\_____|
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
                                      Changelog
    
    
    Daniel (20 Jan 2003)
    - 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 Stenberg's avatar
    Daniel Stenberg committed
    Daniel (16 Jan 2003)
    
    - Markus Oberhumer fixed curl-config --cflags when the includedir was not
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      /usr/include.
    
    - Markus Oberhumer fixed CURLINFO_PRIVATE to properly return NULL if it was
      set to NULL!
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.10.3 (14 Jan 2003)
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    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 Stenberg's avatar
    Daniel Stenberg committed
    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 Stenberg's avatar
    Daniel Stenberg committed
    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 Stenberg's avatar
    Daniel Stenberg committed
    Daniel (7 Jan 2003)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - 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.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Now using autoconf 2.57 and automake 1.7.2
    
    - Doing "curl -I ftp://domain/non-existing-file" still outputed a date!
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      Wayne Haigh reported.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    - 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
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      wouldn't be used. Pointed out by Jean-Philippe Barrette-LaPierre.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    - Matthew Blain's fixed the VC6 libcurl makefile to include better debug data
      on debug builds.
    
    Daniel (27 Dec 2002)
    - Philippe Raoult reported a bug with HTTPS connections which I evidently
      added in my 19 dec fix. I corrected it.
    
    Daniel (20 Dec)
    - Idea from the Debian latest patch: use AM_MAINTAINER_MODE in the configure
      script to make the default makefile less confusing "to the casual
      installer".
    
    Version 7.10.3-pre3 (20 Dec)
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (19 Dec)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Matthew Blain patched the Curl_base64_decode() function.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    - Evan Jordan reported in bug report #653022 that the SSL_read() usage was
      wrong, and it certainly was. It could lead to curl using too much CPU due to
      a stupid loop.
    
    Daniel (18 Dec)
    - As suggested by Margus Freudenthal, CURLE_HTTP_NOT_FOUND was renamed to
      CURLE_HTTP_RETURNED_ERROR since it is returned on any >= 400 code when
      CURLOPT_FAILONERROR is set.
    
    Daniel (17 Dec)
    - Bug reported #651464, reported by Christopher Palmer, provided an example
      source code using the multi interface that hang when trying to connect to a
      proxy on a localhost port where no proxy was listening. This bug was not
      repeatable on libcurls that were IPv6-enabled.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (16 Dec)
    - Christopher Palmer also noticed what Vojtech Janota already was
      experiencing: The attempted name resolve fix for glibc 2.2.93 caused libcurl
      to crash when used on some older glibc versions. The problem is of course
      the silliness of the 2.2.93. I committed a fix that hopefully should make
      the binary run fine on either one of the versions, even though the solution
      is not as nice as I'd like it to be.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (13 Dec)
    - Bug report #651460 by Christopher R. Palmer showed that when using libcurl
      to for example go over a proxy on localhost, it would attempt to connect
      through the proxy TWICE.
    
      I added test case 503 with which I managed to repeat this problem and I
      fixed the code to not re-attempt any connects (which also made it a nicer
      fix for the #650941 bug mentioned below).
    
      The sws server was extended to deal with CONNECT in order to make test
      case 503 do good.
    
    - Evan Jordan posted bug report #650989 about a memory leak in the public key
      retrieving code. He provided a suggested fix and I merely applied it!
    
    - Bug report #650941, posted by Christopher R. Palmer identified a problem
      with the multi interface and getting file:// URLs. This was now fixed and
      test case 502 was added to verify this.
    
    Daniel (12 Dec)
    - Test case 500 and 501 are the first ever libcurl test cases that run.
    
    - Made "configure --enable-debug" cut off all -O* options to the compiler
    
    - Finally fixed the test suite's ftp server so that test case 402 doesn't
      cause the following test case to fail anymore!
    
    Daniel (11 Dec)
    - CURL_MAX_WRITE_SIZE is now decreased to 16KB since it makes the Windows
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      version perform uploads much faster!!! RBramante did lots of research on
      this topic.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    - Fixed the #include in curl/curl.h to include the other files outside the
      extern "C" scope.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (10 Dec)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Moved around and added more logic:
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
      First, POST data is never sent as part of the request headers in the http.c
      code. It is always sent the "normal" read callback then send() way. This now
      enables a plain HTTP POST to be sent chunked if we want to. This also
      reduces the risk of having very big POSTs causing problems.
    
      Further, sending off the initial HTTP request is not done using a loop
      anymore. If it wasn't all sent off in the first send(), the rest of the
      request is sent off in the normal transfer select() loop. This makes several
      things possible, but mainly it makes libcurl block less when used from the
      multi interface and it also reduces the risk of problems with issuing very
      large requests.
    
    Daniel (9 Dec)
    - Moved the read callback pointer and data within the structs to a more
      suitable place. This in preparation for a better HTTP-request sending code
      without (a silly) loop.
    
    - The Dodds fix seems not to work.
    
    - Vojtech Janota tests proved that the resolve fix from oct 21st is not good
      enough since obviously older glibcs might return EAGAIN without this meaning
      that the buffer was too small.
    
    - [the other day] Made libcurl loop on recv() and send() now until done, and
      then get back to select(). Previously it went back to select() more often
      which really was a slight overhead. This was due to the reported performance
      problems on HTTP PUT on Windows. I couldn't see any notable difference on
      Linux...
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.10.3-pre2 (4 Dec 2002)
    
    Daniel (4 Dec 2002)
    - Lots of work with Malcolm Dodds made me add a temporary code fix that now
      shortens the timeout waiting for the 226 or 250 line after a completed
      FTP transfer.
    
      If no data is received within 60 seconds, this is taken as a sign of a dead
      control connection and we bail out.
    
    Daniel (3 Dec 2002)
    - Ralph's bug report #644841 identified a problem in which curl returned a
      timeout error code when in fact the problem was not a timeout. The proper
      error should now be propagated better when they're detected in the FTP
      response reading function.
    
    - Updated the Borland Makefiles.
    
    Daniel (2 Dec 2002)
    - Nicolas Berloquin provided a patch that introduced --create-dirs to the
      command line tool. When used in combination with -o, it lets curl create
      [non-existing] directories used in -o, suitably used with #-combinations
      such as:
    
         curl "www.images.com/{flowers,cities,parks,mountains}/pic_[1-100].jpg \
           -o "dir_#1/pic#2.jpg" --create-dirs
    
    Version 7.10.3-pre1
    
    
    Daniel (28 Nov 2002)
    - I visited Lars Nordgren and had a go with his problem, which lead me to
      implement this fix. If libcurl detects the added custom header
      "Transfer-Encoding: chunked", it will now enable a chunked transfer.
    
      Also, chunked transfer didn't quite work before but seems to do so now.
    
    - Kjetil Jacobsen pointed out that ./configure --disable-ipv6 --without-zlib
      didn't work on any platform...
    
    Daniel (26 Nov 2002)
    - Fixed a bad addrinfo free in the hostip.c code, hardly exposed anywhere
    
    - Dan Becker found and fixed a minor memory leak on persistent connnections
      using CURLOPT_USERPWD.
    
    Daniel (22 Nov 2002)
    - Based on Ralph Mitchell's excellent analysis I found a bug in the test suite
      web server (sws) which now lets test case 306 run fine even in combination
      with the other test cases.
    
    - Juan Ignacio Hervás found a crash in the verbose connect message that is
      used on persistent connections. This bug was added in 7.10.2 due to the
      rearranged name resolve code.
    
    Daniel (20 Nov 2002)
    - Kjetil Jacobsen provided a patch that introduces:
    
       CURLOPT_PRIVATE stores a private pointer in the curl handle.
    
       CURLINFO_PRIVATE retrieves the private pointer from the curl handle.
    
    - Karol Pietrzak pointed out how curl-config --cflags didn't output a good
      include dir so I've removed that for now.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.10.2 (18 Nov 2002)
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (11 Nov 2002)
    - Dave Halbakken added curl_version_info to lib/libcurl.def to make libcurl
      properly build with MSVC on Windows.
    
    Daniel (8 Nov 2002)
    - Doing HTTP PUT without a specified file size now makes libcurl use
      Transfer-Encoding: chunked.
    
    Daniel (7 Nov 2002)
    - Bug report #634625 identified how curl returned timeout immediately when
      CURLOPT_CONNECTTIMEOUT was used and provided a fix.
    
    Version 7.10.2-pre4 (6 Nov 2002)
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (5 Nov 2002)
    - Lehel Bernadt found out and fixed. libcurl sent error message to the debug
      output when it stored the error message.
    
    - Avery Fay found some problems with the DNS cache (when the cache time was
      set to 0 we got a memory leak, but when the leak was fixed he got a crash
      when he used the CURLOPT_INTERFACE with that) that had me do some real
      restructuring so that we now have a reference counter in the dns cache
      entries to prevent an entry to get flushed while still actually in use.
    
      I also detected that we previously didn't update the time stamp when we
      extracted an entry from the cache so that must've been a reason for some
      very weird dns cache bugs.
    
    Version 7.10.2-pre3
    
    Daniel (31 Oct 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Downgraded automake to 1.6.3 in an attempt to fix cygwin problems. (It
      turned out this didn't help though.)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    - Disable the DNS cache (by setting the timeout to 0) made libcurl leak
      memory. Avery Fay brought the example code that proved this.
    
    Version 7.10.2-pre2
    
    Daniel (28 Oct 2002)
    - Upgraded to autoconf 2.54 and automake 1.7 on the release-build host.
    
    - Kevin Roth made the command line tool check for a CURL_CA_BUNDLE environment
      variable (if --cacert isn't used) and if not set, the Windows version will
      check for a file named "curl-ca-bundle.crt" in the current directory or the
      directory where curl is located. That file is then used as CA root cert
      bundle.
    
    - Avery Fay pointed out that curl's configure scrip didn't get right if you
      used autoconf newer than 2.52. This was due to some badly quoted code.
    
    Version 7.10.2-pre1
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (23 Oct 2002)
    - Emiliano Ida confirmed that we now build properly with the Borland C++
      compiler too. We needed yet another fix for the ISO cpp check in the curl.h
      header file.
    
    - Yet another fix was needed to get the HTTP download without headers to work.
      This time it was needed if the first "believed header" was read all in the
      first read. Test 306 has not run properly since the 11th october fix.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (21 Oct 2002)
    - Zvi Har'El pointed out a problem with curl's name resolving on Redhat 8
      machines (running IPv6 disabled). Mats Lidell let me use an account on his
      machine and I could verify that gethostbyname_r() has been changed to return
      EAGAIN instead of ERANGE when the given buffer size is too small. This is
      glibc 2.2.93.
    
    - Albert Chin helped me get the -no-undefined option corrected in
      lib/Makefile.am since Cygwin builds want it there while Solaris builds don't
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      want it present. Kevin Roth helped me try it out on cygwin.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Nikita Schmidt provided a bug fix for a FOLLOWLOCATION bug introduced when
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      the ../ support got in (7.10.1).
    
    Daniel (18 Oct 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Fabrizio Ammollo pointed out a remaining problem with FOLLOWLOCATION in
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      the multi interface.
    
    Daniel (17 Oct 2002)
    - Richard Cooper's experimenting proved that -j (CURLOPT_COOKIESESSION) didn't
      work quite as supposed. You needed to set it *before* you use
      CURLOPT_COOKIEFILE, and we dont' want that kind of dependencies.
    
    Daniel (15 Oct 2002)
    - Andrés García provided corrections for erratas in four libcurl man pages.
    
    Daniel (13 Oct 2002)
    - Starting now, we generate and include PDF versions of all the docs in the
      release archives.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (12 Oct 2002)
    - Trying to connect to a host on a bad port number caused the multi interface
      to never return failure and it appeared to keep on trying forever (it just
      didn't do anything).
    
    Daniel (11 Oct 2002)
    - Downloading HTTP without headers didn't work 100%, some of the initial data
      got written twice. Kevin Roth reported.
    
    - Kevin Roth found out the "config file" parser in the client code could
      segfault, like if DOS newlines were used.
    
    Version 7.10.1 (11 Oct 2002)
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (10 Oct 2002)
    - Jeff Lawson fixed a few problems with connection re-use that remained when
      you set CURLOPT_PROXY to "".
    
    Daniel (9 Oct 2002)
    - Craig Davison found a terrible flaw and Cris Bailiff helped out in the
      search. Getting HTTP data from servers when the headers are split up in
      multiple reads, could cause junk data to get inserted among the saved
      headers. This only concerns HTTP(S) headers.
    
    Daniel (8 Oct 2002)
    - Vincent Penquerc'h gave us the good suggestion that when the ERRRORBUFFER
      is set internally, the error text is sent to the debug function as well.
    
    - I fixed the telnet code to timeout properly as the option tells it to. On
      non-windows platforms.
    
    Daniel (7 Oct 2002)
    - John Crow pointed out that libcurl-the-guide wasn't included in the release
      tarball!
    
    - Kevin Roth pointed out that make install didn't do right if build outside
      the source tree (ca-bundle wise).
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - FOLLOWLOCATION bugfix for the multi interface
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (4 Oct 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Kevin Roth got problems with his cygwin build with -no-undefined was not
      present in lib/Makefile.am so I put it back in there again. The poor one who
      needs to remove it again must write a configure script to detect that need.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Ralph Mitchell pointed out that curl was a bit naive and didn't deal with ./
      or ../ stuff in the string passed back in a Location: header when following
      locations.
    
    - Albert Chin helped me to work out a better configure.in check for zlib, and
      both --without-zlib and -with-zlib seem to work rather well right now.
    
    - Zvi Har'El improvied the OpenSSL ENGINE check in the configure script to
      become more accurate.
    
    Daniel (1 Oct 2002)
    - Detlef Schmier pointed out the lack of a --without-libz option to configure,
      so I added one.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.10 (1 Oct 2002)
    
    Daniel (30 Sep 2002)
    - Modified the curl_version_info() proto and returned struct once again, and
      updated the man page accordingly.
    
    - Cris Bailiff found out that the pre-releases crashed on name lookups on
      names such as "a:" or "baz:" (on Linux versions not being ipv6-enabled) due
      to some weird return codes from gethostbyname_r(). I'll blame the complete
      lack of docs in that department. Cris provided a fix, which I modified only
      slightly.
    
    Daniel (27 Sep 2002)
    - After a suggestion from Christian Kurz to Debian curl package maintainer
      Domenico Andreoli, I made it possible to override the proxy environment
      variables better. Now, by setting -x "" you can explicitly tell libcurl to
      not use a proxy, no matter whan the environment variables say.
    
    Version 7.10-pre4
    
    
    Daniel (26 Sep 2002)
    - Extended curl_version_info() more and wrote a man page for it.
    
    
    Daniel (25 Sep 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - libcurl could leak memory when downloading multiple files using http ranges,
      reported and fixed by Jean-Luc Guevel.
    
    
    - Walter J. Mack provided code and docs for the new curl_free() function that
      shall be used to free memory that is allocated by libcurl and returned back
      to the application, as curl_escape() and curl_unescape() do.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Yarram Sunil pointed out a flaw in the multi interface where a failed
      connection didn't close down properly and thus a second transfer using the
      same handle failed.
    
    
    - Andrés García fixed a flaw that made (among other things) dict-fetches
      return a random value.
    
    Daniel (24 Sep 2002)
    - Wez Furlong brought his initial patch that introduced curl_version_info().
      We might need to tweak it somewhat before release.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (20 Sep 2002)
    - Craig Markwardt fixed another Tru64 IP resolve problem.
    
    Daniel (19 Sep 2002)
    - Dolbneff A.V and Spiridonoff A.V made the file:// code work with resumes
      in the same style other code does.
    
    - Ilguiz Latypov fixed a flaw in the client code when fetching multiple URLs
      and -C - was used. The first file's resume position was then accidentally
      reused on all the other files too.
    
    Daniel (18 Sep 2002)
    - The curl_easy_setopt.3 man page was greatly modified and the options have
      now been grouped in logical groups so that it should be somewhat easier to
      read it and find things you search for.
    
    Daniel (13 Sep 2002)
    - Kevin Roth pinpointed a scary flaw in libcurl, when the HTTP server doesn't
      send any headers back, only raw content. Right, that is a violation of the
      standard but still happens at times and we need to deal with it. Test case
      306 was added to verify that we do right now.
    
    Version 7.10-pre3
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (11 Sep 2002)
    - Lukasz Czekierda found out that curl didn't send a correct HTTP Host: header
      when you specified the URL with an IPv6 IP-address.
    
    Daniel (4 Sep 2002)
    - Sven Neuhaus made --silent being acknowledged even when multiple URLs
      were used. It used to output "[1/2]: http://host/a.html.de --> a.html.d" etc
      even when told to shut up.
    
    Daniel (3 Sep 2002)
    - Updated all source code headers to use MIT-license references only, and
      point to the COPYING file and the http://curl.haxx.se/docs/copyright.html
      URL. I've cut out all references to MPL that I could find.
    
    - Corected the makefiles to not always use -lz when linking
    
    
    Daniel (2 Sep 2002)
    - James Gallagher added Content-Encoding support to libcurl so now curl and
      libcurl-using apps can request compressed contents using the 'deflate'
      method. See the special file lib/README.encoding for details.
    
      curl --compressed is now used to request compressed contents.
    
    
      curl-config --feature will include 'libz' if this feature was around when
      the library was built.
    
    
    Daniel (30 Aug 2002)
    - Applied an anonymous SOCKS5-proxy patch. Not properly working in all
      situations though, as all getaddrinfo()-using libcurls will fail on this.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      This is because of the somewhat naive way the current code tries to extract
      the IP address of the proxy.
    
    
    - Fixed up the SSL cert fixes from the other day even more after more inputs
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      from Cris. Added three new SSL error codes to make the
      CURLE_SSL_CONNECT_ERROR slightly less overloaded.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (27 Aug 2002)
    - After lots of talk with Tom Zerucha, Nick Gimbrone and Cris Bailiff I
    
      decided to talk the bold path and I now made libcurl do CA certificate
      verification by default. Thus library users need to explicitly turn this off
      if you want to connect to sites without proper checking. We also install a
      CA cert bundle on 'make install' now.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
      The curl tool now requires the -k/--insecure option in order to allow
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      connections and operations on SSL sites that aren't properly verified with
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
      curl-config --ca displays the built-in path to the CA cert bundle.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (26 Aug 2002)
    - Andrew Francis cleaned up some code that now compiles fine without the need
      for ugly MSVC pragmas.
    
    - Keith MacDonald found a minor bug in src/main.c that made it close stdin
      instead of the actual file handle. It shouldn't have resulted in much
      trouble as most operating systems close all file handles on process exit
      anyway.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (22 Aug 2002)
    - Markus Oberhumer provided some documentation for his previously provided
      CURLOPT_NOSIGNAL fix.
    
    - Patched the lib/Makefile.am to hopefully no longer complain on undefined
      symbols that seemed to occur on builds with shared OpenSSL libraries on
      Solaris lately...
    
    Daniel (20 Aug 2002)
    - Fixed compiler warnings on MSCV++ compiles. We're looking for help here:
      remove the pragmas from lib/config-win32.h and adjust the sources where
      the warnings occur. Hiding them with pragmas like this is not the correct
      way of dealing with compiler warnings.
    
    Daniel (13 Aug 2002)
    - Ulrich Zadow made the global include files in curl/* include themselves
      using "curl.h" instead of <curl/curl.h> which thus allows people to more
      freely decide how to include curl and how to setup their include paths.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Sterling Hughes added the curl_share* interface, somewhat as discussed
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      previously.
    
    - Jörn Hartroth pointed out that poll() was used in the pre1 source code and
      it isn't very portable, so now I check for it in the configure script and
      work around it.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.9.9-pre1
    
    
    Daniel (12 Aug 2002)
    - Applied my initial take on making the multi stuff more asynchronous. Connects
      should now return back without "hanging" until it has connected for real.
      This should also be the case for FTP-PASV connects.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (9 Aug 2002)
    - Applied Markus F.X.J. Oberhumer's patch that introduces CURLOPT_NOSIGNAL,
      which effectively prevents libcurl from doing anything that may cause
      signals to get sent. This is basicly for multi-threaded applications that
      now can use timeouts properly, without risking any signals to burst in and
      ruin the party.
      
    
    Daniel (5 Aug 2002)
    - Lukasz Czekierda reported that RFC2732-style literal IPv6 addresses didn't
      work. When did that code vanish? Anyway, it's back again now and seems to
      work!
    
    - Jonatan Lander found out that POSTing an empty string didn't work with the
      command line tool.
    
    Daniel (3 Aug 2002)
    - Jörn Hartroth fixed the libcurl.def file to build the windows DLL with
      the multi interface enabled.
    
    Daniel (1 Aug 2002)
    - The ftp PORT command now uses a better default IP address, as it will
      extract and use the local IP address used by the control connection.
    
    - Modified the #include lines in curl/multi.h to work better on more
      platforms.
    
    Daniel (31 Jul 2002)
    - Attempted a fix for Ray DeGennaro's reported HP-UX host name resolve
      problems.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (30 Jul 2002)
    
    - Priya Ramakrishnan and Ryan Jones compiles curl/curl.h with a C++ compiler
      and don't get __STDC__ defined, which required us to extend the preprocessor
      check for the ## operator usage.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Correct the description for CURLOPT_PASSWDFUNCTION, if set to NULL the
      internal default function will be put back.
    
    - danfuzz at milk.com found out that libcurl badly assumed a space after
      'Set-Cookie:' so if it wasn't present, it caused the first letter of the
      cookie name to fall off!
    
    Daniel (29 Jul 2002)
    - The password prompt asking for user password used stdout and now uses
      stderr instead to better allow redirecting. It also leaked a fopen() file
      handle that is now fixed.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (28 Jul 2002)
    - HAVE_SETVBUF was left out from src/main.c which made -N not work. Found out
      by M T.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (26 Jun 2002)
    
    - Glen Nakamura solved a crash in the name resolving function for IP-only
      addresses on Alpha Linux (at least).
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - T. Bharath corrected the high resolution timer introduced in 7.9.8.
    
    Daniel (22 Jun 2002)
    - Andrés García pointed out man page errors in curl_formadd.3. I fixed.
    
    Daniel (19 Jun 2002)
    - Chris Combes pointed out a flaw in curl_escape(). I fixed. We no longer
      tries to generate nor parse '+' in URLs. Spaces become %20, and only %-codes
      are translated by curl_unescape().
    
    Daniel (15 Jun 2002)
    - Added --limit-rate to the curl tool. Allows the user to set a maxmimum
      upper limit to how much bandwidth to use for transfers.
    
    - CURLOPT_BUFFERSIZE was added to libcurl. This sets a prefered size for the
      receive buffer in libcurl. The main point of this would be that the write
      callback gets called more often and with smaller chunks.
    
    Daniel (14 Jun 2002)
    - Yarram Sunil found out that the SocketIsDead() function performed a lot
      faster on Windows when removing the 1 microsecond timeout.
    
    - Hanno L. Kranzhoff fixed the VC++ project files.
    
    - Tom Mattison found out that ftp transfers closed the connection a little
      too often.
    
    - Miklos Nemeth posted a VC++ makefile fix and some INSTALL comments on how
      to disable specific protocols when building for Windows.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.9.8
    
    Daniel (13 Jun 2002)
    - Time to let this baby go.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Chris Combes added three new options for curl_formadd(): CURLFORM_BUFFER,
      CURLFORM_BUFFERPTR, CURLFORM_BUFFERLENGTH.  They are used to create a
      multipart that appears as a regular file upload, but the data is provided
      with a pointer and length.
    
      
    - Nico Baggus made the VMS version use sigsetjmp() too.
    
    - Jörn Hartroth fixed the mingw32 build using the mm lib.
    
    - Applied patches by Kris Kennaway that correct format string problems in
      lib/ftp.c and lib/ldap.c.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.9.8-pre3
    
    Daniel (11 Jun 2002)
    - James Cone brought the idea of using sigsetjmp() in the signal handler to
      make the time-out of name lookups to work, even when the underlying name
      resolver library traps EINTR. The use of sigsetjmp() and siglongjmp() for
      this may be a bit drastic, and also not likely to exist on all platforms.  I
      added careful checking for this in the configure script, even checks for it
      being a macro (which seems to be the case in for example Linux).
    
      sigsetjmp() seems to be mentioned in the Single Unix specification.
    
    - Miklos Nemeth brought a patch that allows libcurl to get built with specific
      protocols disabled. This is done by running ./configure
      --disable-[protocol].
    
    - FTP range downloads could make CURLE_FTP_WRITE_ERROR get returned. We now
      make precautions to not return this for range downloads.
    
      Added test case 135 that makes an ftp range download. Had to tweak the
      runtests.pl script a bit too.
    
    - Bug report #566835 identified a strlen() on a NULL pointer. Added additional
      check to prevent this.
    
    Daniel (10 Jun 2002)
    - Found and corrected a connect failure problem that didn't create a human
      error text.
    
    - Added code to compile with OpenSSL 0.9.7. Based on patch from Jacob Meuser
      and comments from Götz Babin-Ebell.
    
    - Gautam Mani found a socket descriptor leak that happened when FTP transfers
      failed and you reinvoked curl_easy_perform().
    
    Daniel (5 Jun 2002)
    - Gustaf Hui corrected curl_multi_remove_handle() so that it won't crash no
      matter when you decide to remove the CURL handle.
    
    - HAVE_RAND_STATUS was added to lib/config-win32.h by Andreas Olsson, as it
      makes windows builds stop complaining about "weak seeding" when it in fact
      isn't.
    
    - Another 64bit architecture crash that was introduced in 7.9.7 was now
      removed, as bug report #564585 clarified. This happened due to our attempts
      to only allocate only as much memory as is actually needed for name
      resolving (using realloc) which called for a function that could 'move' a
      hostent struct in memory.
    
    Version 7.9.8-pre2
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (3 Jun 2002)
    - T. Bharath fixed the CURLINFO_REDIRECT_TIME to return a correct time and
      made the CURLINFO_REQUEST_SIZE return the correct total request size. He
      also made the win32 timers use higher resolution than before.
    
    Daniel (29 May 2002)
    - Renaud Chaillat made me aware of the fact that libcurl returned an error if
      you tried to get an empty FTP file. This seemed like a wrong thing to do, so
      now it no longer does that! I just hope that no one built anything fancy
      upon this unexpected behavior...
    
    Daniel (28 May 2002)
    - Cris Bailiff brought CURLOPT_CAPATH that works like CURLOPT_CAINFO but
      specifies a path to a directory with certificates rather than a single file
      with them all concatenated. --capath was added to the command line tool
      for the same function.
    
      Windows users need to pay attention that the directory should be setup with
      the c_rehash tool of the OpenSSL package, and that creates symlinks by
      default that need to be replaced with actual copies to work on Windows.
    
    - Gustaf Hui provided new code that changes how curl_multi_info_read()
      messages are stored, so that they don't have to be kept around for the multi
      handle's entire life time. He also made it return failure codes properly
      which it didn't do before.
    
    Daniel (27 May 2002)
    - Gustaf Hui pointed out that running curl_multi_perform() without doing
      curl_multi_fdset() first was not really a working combo. I added an internal
      check for this and have some extra select() code without timeout to make the
      library internals work identically nevertheless. We might need to somehow
      either document that once you've used the *_fdset() you should remain using
      them in select() or you should blank them somehow so that libcurl won't go
      crazy.
    
    Version 7.9.8-pre1
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (22 May 2002)
    - James Cone brought an excellent patch, including several tests and docs!
      CURLOPT_NETRC now takes an enum as argument instead of the previous boolean.
      --netrc-optional was introduced as an addition to --netrc to allow the
      command line client to take use of all that new netrc stuff.
    
    - Bug report #558888 showed a case where libcurl re-used the previous host
      name when a connection over a proxy was re-used but to a different target
      host.
    
    Daniel (21 May 2002)
    - Edin Kadribasic helped me sort out a problem to made libcurl crash when
      trying to HTTP POST an empty string.
    
    - Clarified that Juergen Wilke donated the original tests/server/sws.c code.
    
    - Jean-Philippe Barrette-LaPierre made curl_formadd() return a typedef named
      CURLFORMcode instead of the previous 'int', and the various return codes are
      now globally exported. It allows applications to better figure out what goes
      wrong when curl_formadd() returns errors.
    
    Daniel (20 May 2002)
    - Roland Zimmermann pointed out that SSL_CTX_use_certificate_chain_file()
      is prefered to SSL_CTX_use_certificate_file().
    
    Daniel (17 May 2002)
    - Bug report #556869 pointed out that src/writeout.c didn't compile on freebsd
      after my AIX fixes the other week.
    
    - Bug report #556930 pointed out a FreeBSD core dump introduced in 7.9.7 in
      the DNS struct realloc stuff. Actually, this crash could happen on all
      systems that made the pack_hostent() function get invoked.
    
    - I removed several compiler warnings in the test suite's HTTP server.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.9.7
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (10 May 2002)
    - Kevin Roth adjusted the --trace-ascii output slightly.
    
    - Paul Harrington found out that src/writeout.c needed an additional header
      file included for AIX builds
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Version 7.9.7-pre2
    
    Daniel (7 May 2002)
    - Updated the man page with --trace-ascii and -j/--junk-session-cookies.
    
    - Made --trace-ascii do pretty much the same as --trace but without the hex
      part in the output.
    
    - Added CURLOPT_COOKIESESSION that when enabled makes libcurl ignore session
      cookies read from a file. This option is enforced by the curl command line
      tool using the new -j/--junk-session-cookies option. After discussions with
      Kevin Roth. This makes it easier to use curl to fully emulate a browser's
      behavior, even when it comes to "session cookies". Session cookies are
      cookies that a normal browser discards when the browser is shut
      down. They're identified by not having any expire date/time.
    
    - When CURLOPT_DEBUGDATA was set, it ruined the CURLOPT_STDERR setting and
      this was discovered when --trace was made to crash.
    
    - Using -v and --trace at the same time confused matters. -v is now pretty
      much ignored when --trace or --trace-ascii is used.
    
    - Made --trace (and --trace-ascii) support - as file name to pass output to
      stdout instead. It makes it consistent with how other options work.
    
    Version 7.9.7-pre1
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (6 May 2002)
    - Added multi-post.c to the examples directory. I got the basic source for
      this from Gustaf Hui.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (3 May 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - CURL_MAX_WRITE_SIZE is now an exported #define in the curl/curl.h header and
      can be used to figure out the maximum buffer size your write callback can
      get.
    
    - CURLOPT_READDATA is now an alias for CURLOPT_INFILE and CURLOPT_WRITEDATE is
      an alias for CURLOPT_FILE. These two were added for conformity. Most other
      callback function's userdata are provided with options using a similar name-
      scheme.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Added "--trace [file]" to the command line tool. It makes a very detailed
      trace dump get stored, with a full protocol dump that includes all received
      and transmitted data. This could be a very effective tool for debugging what
      goes wrong. This dump includes every byte the way it is sent to/received
      from the server. The dump is the plain-text version, so SSL transfers will
      still be readable.
    
    - I found out that the DEBUGFUNCTION was not called properly everywhere as we
      wanted it to. I fixed it.
    
    - -D now stores all headers to the same file if multiple URLs are given on the
      command line! Kevin Roth made me aware of that it didn't already do this!
    
    - Gustaf Hui wrote an excellent formpost example that used the multi
      interface.  Unfortunately, it didn't work due to several bugs in how
      transfers were made when the multi interface was used.
    
    Daniel (2 May 2002)
    - Hanno Kranzhoff found out that when doing multiple transfers on the same
      easy handle, the progress meter would show a bad "currently downloaded
      value" when the transfer starts.
    
    Daniel (1 May 2002)
    - Applied another patch by Jacky Lam to make the name resolve info realloc()
      stuff work properly.
    
    Daniel (28 April 2002)
    - curl_multi_info_read() is now implemented!
    
    
    Daniel (27 April 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Updated BUGS, TODO, FAQ, INSTALL and added BINDINGS.
    
    
    - I think I fixed the DNS cache prune crach Jacky Lam found and reported.
    
    - I cleaned up the name prefix stuff in the hash and llist modules.
    
    - FTP responses should now be better on timing out properly. The timeout value
      is maximum timeout for the entire request operation, but before this, the
      timeout was used as a maximum allowed time between two reads...
    
    
    Daniel (26 April 2002)
    - Fixed the test suite http server to not use snprintf() anymore due to better
      portability.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (25 April 2002)
    - With Sterling Hughes' new DNS pruning, Jacky Lam asked if this wouldn't
      cause problems since the pruning is only checking the entry time, and it
      sure could cause problems. Therefor, I've now added and changed code so that
      this should not be a problem. Nowhere in the code will be store name
      resolved information around so that a sunsequent DNS cache prune should
      cause a problem. This of course called for some mild internal changes.
    
    Daniel (23 April 2002)
    - Improved the 'no_proxy' check, as using port numbers in the URL confused it
      previously. Reported by Erwan Legrand in bug report #547484.
    
    - The --interface option now works even on IPv6 enabled builds. Reported by
      'thor'.
    
    Daniel (22 April 2002)
    - The #defines names starting with TIMECOND now has CURL_ prefixes. (The old
      names are still #defined too.) Pointed out by Robert Olson.
    
    - Jacky Lam brought code that lets the name resolve function only use as much
      memory as it actually needs. This only works on certain operating systems,
      but is totally transparant to all users.
    
    Daniel (19 April 2002)
    - Bjorn Reese fixed pack_hostent to work properly with 64 bit pointers.
    
    Daniel (18 April 2002)
    - Sterling Hughes added code to prune old DNS cache entries, since Jacky Lam
      experienced very big caches.
    
    Daniel (17 April 2002)
    - Dirk Manske patched the 301 response to work against the RFC but more like
      common browsers do. If a POST get a 301 back, it'll switch to GET in the
      next request (if location-following is enabled).
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Dirk Manske posted a patch originally written by Ingo Wilken that introduced
      two new CURLINFO_* values: CURLINFO_REDIRECT_TIME and
      CURLINFO_REDIRECT_COUNT.
    
    
    Daniel (15 April 2002)
    - Jonatan Lander patched the verbose text 'Disables POST, goes with GET' to
      reflect reality better, like when the first request isn't POST and when
      the second isn't GET... :-)
    
    - Craig Davison pointed out that when curl_formadd()ing a file that doesn't
      exist, libcurl doesn't return error. Now, curl_easy_perform() will return
      CURLE_READ_ERROR if that is the case. Test 41 was added to verify this.
    
    Version 7.9.6
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (14 April 2002)
    - Dirk Manske brought a fix that makes libcurl strip off white spaces from the
      beginning of cookie contents.
    
    - Had to patch include/curl/curl.h since MSVC doesn't set the __STDC__ define.
      Moonesamy pointed out the problem, Bjorn Reese the solution.
    
    Version 7.9.6-pre5
    
    
    Daniel (12 April 2002)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    - Fixed the TIMER_CONNECT to be more accurate for FTP transfers. Previously
      FTP transfers got the "connect done" time set after the initial FTP commands
      and not directly after the TCP/IP connect as it should.
    
      I also made the time stamp get set even if the connect itself fails, which
      it didn't do previously.
    
    
    - Jean-Philippe Barrette-LaPierre provided his patch that introduces
      CURLOPT_DEBUGFUNCTION and CURLOPT_DEBUGDATA. They allow a program to a set a
      callback to receive debug/information data. That includes headers and data
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      that is received and sent. CURLOPT_VERBOSE still controls it.
    
      By default, there is an internal debugfunction that will make things look
      and work as before if not changed.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Daniel (10 April 2002)
    - Sebastien Willemijns found out that -x didn't use the default port number as
      is documented. It does now.
    
    - libcurl-errors.3 is a new man page attempting to document all libcurl error
      codes
    
    - Added two new error codes and changed the behaviour of two old ones
      slightly:
    
      CURLE_WRITE_ERROR
       This error was returned *both* for errors that occured when writing
       received data to a local file, as well as when we get problems writing data
       to a remote server. CURLE_SEND_ERROR has now been added for the latter
       error.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
       This error was similarly returned *both* for errors when reading a local
       file, as well as when getting problems when reading network data.
       CURLE_RECV_ERROR has now been added for the latter error.
    
     (Two test cases were adjusted accordingly.)
    
    Daniel (9 April 2002)
    - runtests.pl now sets the HOME variable before running curl, to prevent any