diff --git a/ChangeLog b/ChangeLog index ed6bd7a04..2ee6d0665 100644 --- a/ChangeLog +++ b/ChangeLog @@ -84,6 +84,7 @@ * almost completely changed the storage interface (for custom storage) * added support for hashing pieces in multiple threads + * optimize enumeration of network interfaces on windows * improve reliability of binding listen sockets * support SNI in https web seeds and trackers * fix unhandled exception in DHT when receiving a DHT packet over IPv6 diff --git a/configure.ac b/configure.ac index 6d65f6416..efa1943fc 100644 --- a/configure.ac +++ b/configure.ac @@ -482,6 +482,8 @@ AS_CASE(["$ARG_ENABLE_PYTHON_BINDING"], AS_IF([test -z "$BOOST_PYTHON_LIB"], [AC_MSG_ERROR([Boost.Python library not found. Try using --with-boost-python=lib.])]) + + BOOST_PYTHON_LIB="-l$BOOST_PYTHON_LIB" ], ["no"], [ AC_MSG_RESULT([no]) diff --git a/include/libtorrent/session.hpp b/include/libtorrent/session.hpp index f2f107780..3fee69802 100644 --- a/include/libtorrent/session.hpp +++ b/include/libtorrent/session.hpp @@ -239,6 +239,8 @@ namespace libtorrent pack.set_int(settings_pack::max_retry_port_bind, listen_port_range.second - listen_port_range.first); pack.set_str(settings_pack::peer_fingerprint, print.to_string()); char if_string[100]; + + if (listen_interface == NULL) listen_interface = "0.0.0.0"; snprintf(if_string, sizeof(if_string), "%s:%d", listen_interface, listen_port_range.first); pack.set_str(settings_pack::listen_interfaces, if_string); diff --git a/include/libtorrent/sha1_hash.hpp b/include/libtorrent/sha1_hash.hpp index 57e7d4140..c86e9f446 100644 --- a/include/libtorrent/sha1_hash.hpp +++ b/include/libtorrent/sha1_hash.hpp @@ -42,8 +42,8 @@ POSSIBILITY OF SUCH DAMAGE. #include "libtorrent/assert.hpp" #include "libtorrent/aux_/byteswap.hpp" -#if TORRENT_USE_IOSTREAM #include "libtorrent/hex.hpp" // to_hex, from_hex +#if TORRENT_USE_IOSTREAM #include #include #endif diff --git a/src/enum_net.cpp b/src/enum_net.cpp index 862684915..6a50e5bb1 100644 --- a/src/enum_net.cpp +++ b/src/enum_net.cpp @@ -434,14 +434,14 @@ namespace libtorrent int s = socket(AF_INET, SOCK_DGRAM, 0); if (s < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return ret; } ifaddrs *ifaddr; if (getifaddrs(&ifaddr) == -1) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(s); return ret; } @@ -481,7 +481,7 @@ namespace libtorrent int s = socket(AF_INET, SOCK_DGRAM, 0); if (s < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return ret; } ifconf ifc; @@ -491,7 +491,7 @@ namespace libtorrent ifc.ifc_buf = (char*)buf; if (ioctl(s, SIOCGIFCONF, &ifc) < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(s); return ret; } @@ -529,7 +529,7 @@ namespace libtorrent strncpy(req.ifr_name, item.ifr_name, IF_NAMESIZE - 1); if (ioctl(s, siocgifmtu, &req) < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(s); return ret; } @@ -552,7 +552,7 @@ namespace libtorrent else #endif { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(s); return ret; } @@ -581,61 +581,61 @@ namespace libtorrent GetAdaptersAddresses_t GetAdaptersAddresses = (GetAdaptersAddresses_t)GetProcAddress( iphlp, "GetAdaptersAddresses"); - if (GetAdaptersAddresses) + if (GetAdaptersAddresses == NULL) { - PIP_ADAPTER_ADDRESSES adapter_addresses = 0; - ULONG out_buf_size = 0; - if (GetAdaptersAddresses(AF_UNSPEC, GAA_FLAG_SKIP_MULTICAST | GAA_FLAG_SKIP_DNS_SERVER - | GAA_FLAG_SKIP_ANYCAST, NULL, adapter_addresses, &out_buf_size) != ERROR_BUFFER_OVERFLOW) - { - FreeLibrary(iphlp); - ec = boost::asio::error::operation_not_supported; - return std::vector(); - } - - adapter_addresses = (IP_ADAPTER_ADDRESSES*)malloc(out_buf_size); - if (!adapter_addresses) - { - FreeLibrary(iphlp); - ec = boost::asio::error::no_memory; - return std::vector(); - } - - if (GetAdaptersAddresses(AF_UNSPEC, GAA_FLAG_SKIP_MULTICAST | GAA_FLAG_SKIP_DNS_SERVER - | GAA_FLAG_SKIP_ANYCAST, NULL, adapter_addresses, &out_buf_size) == NO_ERROR) - { - for (PIP_ADAPTER_ADDRESSES adapter = adapter_addresses; - adapter != 0; adapter = adapter->Next) - { - ip_interface r; - strncpy(r.name, adapter->AdapterName, sizeof(r.name)); - r.name[sizeof(r.name)-1] = 0; - r.mtu = adapter->Mtu; - IP_ADAPTER_UNICAST_ADDRESS* unicast = adapter->FirstUnicastAddress; - while (unicast) - { - r.interface_address = sockaddr_to_address(unicast->Address.lpSockaddr); - - ret.push_back(r); - - unicast = unicast->Next; - } - } - } - - // Free memory - free(adapter_addresses); FreeLibrary(iphlp); - return ret; + ec = error_code(boost::system::errc::not_supported, generic_category()); + return std::vector(); } + + ULONG buf_size = 10000; + std::vector buffer(buf_size); + PIP_ADAPTER_ADDRESSES adapter_addresses + = reinterpret_cast(&buffer[0]); + + DWORD r = GetAdaptersAddresses(AF_UNSPEC, GAA_FLAG_SKIP_MULTICAST | GAA_FLAG_SKIP_DNS_SERVER + | GAA_FLAG_SKIP_ANYCAST, NULL, adapter_addresses, &buf_size); + if (r == ERROR_BUFFER_OVERFLOW) + { + buffer.resize(buf_size); + r = GetAdaptersAddresses(AF_UNSPEC, GAA_FLAG_SKIP_MULTICAST | GAA_FLAG_SKIP_DNS_SERVER + | GAA_FLAG_SKIP_ANYCAST, NULL, adapter_addresses, &buf_size); + } + if (r != NO_ERROR) + { + FreeLibrary(iphlp); + ec = error_code(WSAGetLastError(), system_category()); + return std::vector(); + } + + for (PIP_ADAPTER_ADDRESSES adapter = adapter_addresses; + adapter != 0; adapter = adapter->Next) + { + ip_interface r; + strncpy(r.name, adapter->AdapterName, sizeof(r.name)); + r.name[sizeof(r.name)-1] = 0; + r.mtu = adapter->Mtu; + IP_ADAPTER_UNICAST_ADDRESS* unicast = adapter->FirstUnicastAddress; + while (unicast) + { + r.interface_address = sockaddr_to_address(unicast->Address.lpSockaddr); + + ret.push_back(r); + + unicast = unicast->Next; + } + } + + // Free memory FreeLibrary(iphlp); + return ret; } #endif SOCKET s = socket(AF_INET, SOCK_DGRAM, 0); if (s == SOCKET_ERROR) { - ec = error_code(WSAGetLastError(), boost::asio::error::system_category); + ec = error_code(WSAGetLastError(), system_category()); return ret; } @@ -645,7 +645,7 @@ namespace libtorrent if (WSAIoctl(s, SIO_GET_INTERFACE_LIST, 0, 0, buffer, sizeof(buffer), &size, 0, 0) != 0) { - ec = error_code(WSAGetLastError(), boost::asio::error::system_category); + ec = error_code(WSAGetLastError(), system_category()); closesocket(s); return ret; } @@ -755,14 +755,14 @@ namespace libtorrent int s = socket(PF_ROUTE, SOCK_RAW, AF_UNSPEC); if (s == -1) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return std::vector(); } int n = write(s, &m, len); if (n == -1) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(s); return std::vector(); } @@ -777,7 +777,7 @@ namespace libtorrent n = read(s, &m, len); if (n == -1) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(s); return std::vector(); } @@ -788,7 +788,7 @@ namespace libtorrent std::cout << " rtm_type: " << ptr->rtm_type << std::endl; if (ptr->rtm_errno) { - ec = error_code(ptr->rtm_errno, boost::asio::error::system_category); + ec = error_code(ptr->rtm_errno, system_category()); return std::vector(); } if (m.m_rtm.rtm_flags & RTF_UP == 0 @@ -844,7 +844,7 @@ namespace libtorrent if (sysctl(mib, 6, 0, &needed, 0, 0) < 0) #endif { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return std::vector(); } @@ -866,7 +866,7 @@ namespace libtorrent if (sysctl(mib, 6, buf.get(), &needed, 0, 0) < 0) #endif { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return std::vector(); } @@ -875,7 +875,7 @@ namespace libtorrent int s = socket(AF_INET, SOCK_DGRAM, 0); if (s < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return std::vector(); } rt_msghdr* rtm; @@ -1067,7 +1067,7 @@ namespace libtorrent int sock = socket(PF_ROUTE, SOCK_DGRAM, NETLINK_ROUTE); if (sock < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return std::vector(); } @@ -1085,7 +1085,7 @@ namespace libtorrent if (send(sock, nl_msg, nl_msg->nlmsg_len, 0) < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(sock); return std::vector(); } @@ -1093,7 +1093,7 @@ namespace libtorrent int len = read_nl_sock(sock, msg, BUFSIZE, seq, getpid()); if (len < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); close(sock); return std::vector(); } @@ -1101,7 +1101,7 @@ namespace libtorrent int s = socket(AF_INET, SOCK_DGRAM, 0); if (s < 0) { - ec = error_code(errno, boost::asio::error::system_category); + ec = error_code(errno, system_category()); return std::vector(); } for (; NLMSG_OK(nl_msg, len); nl_msg = NLMSG_NEXT(nl_msg, len)) diff --git a/src/session.cpp b/src/session.cpp index e2983f1ef..db9c9f113 100644 --- a/src/session.cpp +++ b/src/session.cpp @@ -351,7 +351,7 @@ namespace libtorrent ::_set_se_translator(straight_to_debugger); #endif - bool internal_executor = ios == NULL; + bool const internal_executor = ios == NULL; if (internal_executor) { diff --git a/src/session_impl.cpp b/src/session_impl.cpp index cecc22d2c..8f5b872a8 100644 --- a/src/session_impl.cpp +++ b/src/session_impl.cpp @@ -463,7 +463,10 @@ namespace aux { // post it to the io_service? void session_impl::start_session(settings_pack const& pack) { - m_alerts.set_alert_mask(pack.get_int(settings_pack::alert_mask)); + if (pack.has_val(settings_pack::alert_mask)) + { + m_alerts.set_alert_mask(pack.get_int(settings_pack::alert_mask)); + } #ifndef TORRENT_DISABLE_LOGGING session_log("start session");