Skip to content
  1. Apr 18, 2014
  2. Mar 19, 2014
  3. Jan 18, 2014
  4. Jan 17, 2014
  5. Jan 15, 2014
  6. Jan 11, 2014
    • Daniel Stenberg's avatar
      multi: remove MULTI_TIMEOUT_INACCURACY · 3b183df9
      Daniel Stenberg authored
      With the recently added timeout "reminder" functionality, there's no
      reason left for us to execute timeout code before the time is
      ripe. Simplifies the handling too.
      
      This will make the *TIMEOUT and *CONNECTTIMEOUT options more accurate
      again, which probably is most important when the *_MS versions are used.
      
      In multi_socket, make sure to update 'now' after having handled activity
      on a socket.
      3b183df9
  7. Jan 08, 2014
  8. Dec 28, 2013
  9. Dec 20, 2013
  10. Dec 04, 2013
  11. Nov 27, 2013
  12. Nov 17, 2013
  13. Nov 14, 2013
  14. Nov 10, 2013
  15. Nov 04, 2013
    • Björn Stenberg's avatar
      connect: Add connection delay to Happy Eyeballs. · 02fbc26d
      Björn Stenberg authored
      This patch adds a 200ms delay between the first and second address
      family socket connection attempts.
      
      It also iterates over IP addresses in the order returned by the
      system, meaning most dual-stack systems will try IPv6 first.
      
      Additionally, it refactors the connect code, removing most code that
      handled synchronous connects. Since all sockets are now non-blocking,
      the logic can be made simpler.
      02fbc26d
  16. Nov 03, 2013
  17. Oct 29, 2013
  18. Oct 27, 2013
    • Björn Stenberg's avatar
      Typo fix in trynextip(). · 8230af0b
      Björn Stenberg authored
      8230af0b
    • Björn Stenberg's avatar
      Add "Happy Eyeballs" for IPv4/IPv6. · 7d7df831
      Björn Stenberg authored
      This patch invokes two socket connect()s nearly simultaneously, and
      the socket that is first connected "wins" and is subsequently used for
      the connection. The other is terminated.
      
      There is a very slight IPv4 preference, in that if both sockets connect
      simultaneously IPv4 is checked first and thus will win.
      7d7df831
  19. Oct 26, 2013
    • Daniel Stenberg's avatar
      FTP: make the data connection work when going through proxy · d44b0142
      Daniel Stenberg authored
      This is a regression since the switch to always-multi internally
      c4312741.
      
      Test 1316 was modified since we now clearly call the Curl_client_write()
      function when doing the LIST transfer part and then the
      handler->protocol says FTP and ftpc.transfertype is 'A' which implies
      text converting even though that the response is initially a HTTP
      CONNECT response in this case.
      d44b0142
  20. Jul 23, 2013
  21. Jun 20, 2013
    • Daniel Stenberg's avatar
      multi_socket: react on socket close immediately · 88c5c63f
      Daniel Stenberg authored
      As a remedy to the problem when a socket gets closed and a new one is
      opened with the same file descriptor number and as a result
      multi.c:singlesocket() doesn't detect the difference, the new function
      Curl_multi_closed() gets told when a socket is closed so that it can be
      removed from the socket hash. When the old one has been removed, a new
      socket should be detected fine by the singlesocket() on next invoke.
      
      Bug: http://curl.haxx.se/bug/view.cgi?id=1248
      Reported-by: Erik Johansson
      88c5c63f
  22. May 01, 2013
  23. Apr 08, 2013
  24. Apr 06, 2013
    • Kim Vandry's avatar
      connect: treat an interface bindlocal() problem as a non-fatal error · 090b55c1
      Kim Vandry authored
      I am using curl_easy_setopt(CURLOPT_INTERFACE, "if!something") to force
      transfers to use a particular interface but the transfer fails with
      CURLE_INTERFACE_FAILED, "Failed binding local connection end" if the
      interface I specify has no IPv6 address. The cause is as follows:
      
      The remote hostname resolves successfully and has an IPv6 address and an
      IPv4 address.
      
      cURL attempts to connect to the IPv6 address first.
      
      bindlocal (in lib/connect.c) fails because Curl_if2ip cannot find an
      IPv6 address on the interface.
      
      This is a fatal error in singleipconnect()
      
      This change will make cURL try the next IP address in the list.
      
      Also included are two changes related to IPv6 address scope:
      
      - Filter the choice of address in Curl_if2ip to only consider addresses
      with the same scope ID as the connection address (mismatched scope for
      local and remote address does not result in a working connection).
      
      - bindlocal was ignoring the scope ID of addresses returned by
      Curl_if2ip . Now it uses them.
      
      Bug: http://curl.haxx.se/bug/view.cgi?id=1189
      090b55c1
  25. Apr 02, 2013
    • Daniel Stenberg's avatar
      SO_SNDBUF: don't set SNDBUF for win32 versions vista or later · 43e045fc
      Daniel Stenberg authored
      The Microsoft knowledge-base article
      http://support.microsoft.com/kb/823764 describes how to use SNDBUF to
      overcome a performance shortcoming in winsock, but it doesn't apply to
      Windows Vista and later versions. If the described SNDBUF magic is
      applied when running on those more recent Windows versions, it seems to
      instead have the reversed effect in many cases and thus make libcurl
      perform less good on those systems.
      
      This fix thus adds a run-time version-check that does the SNDBUF magic
      conditionally depending if it is deemed necessary or not.
      
      Bug: http://curl.haxx.se/bug/view.cgi?id=1188
      Reported by: Andrew Kurushin
      Tested by: Christian Hägele
      43e045fc
  26. Mar 31, 2013
  27. Feb 05, 2013
  28. Feb 01, 2013
    • Daniel Stenberg's avatar
      singleipconnect: simplify and clean up · 56b7c87c
      Daniel Stenberg authored
      Remove timeout argument that's never used.
      
      Make the actual connection get detected on a single spot to reduce code
      duplication.
      
      Store the IPv6 state already when the connection is attempted.
      56b7c87c
  29. Jan 17, 2013
    • Daniel Stenberg's avatar
      always-multi: always use non-blocking internals · c4312741
      Daniel Stenberg authored
      Remove internal separated behavior of the easy vs multi intercace.
      curl_easy_perform() is now using the multi interface itself.
      
      Several minor multi interface quirks and bugs have been fixed in the
      process.
      
      Much help with debugging this has been provided by: Yang Tse
      c4312741
  30. Jan 08, 2013
    • Yang Tse's avatar
      build: fix circular header inclusion with other packages · 5a053ffe
      Yang Tse authored
      This commit renames lib/setup.h to lib/curl_setup.h and
      renames lib/setup_once.h to lib/curl_setup_once.h.
      
      Removes the need and usage of a header inclusion guard foreign
      to libcurl. [1]
      
      Removes the need and presence of an alarming notice we carried
      in old setup_once.h [2]
      
      ----------------------------------------
      
      1 - lib/setup_once.h used __SETUP_ONCE_H macro as header inclusion guard
          up to commit ec691ca3 which changed this to HEADER_CURL_SETUP_ONCE_H,
          this single inclusion guard is enough to ensure that inclusion of
          lib/setup_once.h done from lib/setup.h is only done once.
      
          Additionally lib/setup.h has always used __SETUP_ONCE_H macro to
          protect inclusion of setup_once.h even after commit ec691ca3, this
          was to avoid a circular header inclusion triggered when building a
          c-ares enabled version with c-ares sources available which also has
          a setup_once.h header. Commit ec691ca3 exposes the real nature of
          __SETUP_ONCE_H usage in lib/setup.h, it is a header inclusion guard
          foreign to libcurl belonging to c-ares's setup_once.h
      
          The renaming this commit does, fixes the circular header inclusion,
          and as such removes the need and usage of a header inclusion guard
          foreign to libcurl. Macro __SETUP_ONCE_H no longer used in libcurl.
      
      2 - Due to the circular interdependency of old lib/setup_once.h and the
          c-ares setup_once.h header, old file lib/setup_once.h has carried
          back from 2006 up to now days an alarming and prominent notice about
          the need of keeping libcurl's and c-ares's setup_once.h in sync.
      
          Given that this commit fixes the circular interdependency, the need
          and presence of mentioned notice is removed.
      
          All mentioned interdependencies come back from now old days when
          the c-ares project lived inside a curl subdirectory. This commit
          removes last traces of such fact.
      5a053ffe