From e2fba2caa9b691c6d93553a9ea5612fda784d597 Mon Sep 17 00:00:00 2001 From: Arvid Norberg Date: Wed, 8 Oct 2014 15:27:52 +0000 Subject: [PATCH] fix available() function on ssl_stream --- include/libtorrent/ssl_stream.hpp | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/include/libtorrent/ssl_stream.hpp b/include/libtorrent/ssl_stream.hpp index a6c9ddb6f..bb63788bd 100644 --- a/include/libtorrent/ssl_stream.hpp +++ b/include/libtorrent/ssl_stream.hpp @@ -196,13 +196,16 @@ public: return m_sock.write_some(buffers, ec); } + // the SSL stream may cache 17 kiB internally, and there's no way of + // asking how large its buffer is. 17 kiB isn't very much though, so it + // seems fine to potentially over-estimate the number of bytes available. #ifndef BOOST_NO_EXCEPTIONS std::size_t available() const - { return const_cast(m_sock).next_layer().available(); } + { return 17 * 1024 + const_cast(m_sock).next_layer().available(); } #endif std::size_t available(error_code& ec) const - { return const_cast(m_sock).next_layer().available(ec); } + { return 17 * 1024 + const_cast(m_sock).next_layer().available(ec); } #ifndef BOOST_NO_EXCEPTIONS void bind(endpoint_type const& endpoint)