diff options
author | Roland Reichwein <mail@reichwein.it> | 2020-05-09 18:12:28 +0200 |
---|---|---|
committer | Roland Reichwein <mail@reichwein.it> | 2020-05-09 18:12:28 +0200 |
commit | 05213d6f1d8e946e717dee948bd14b6ef3876827 (patch) | |
tree | c55f16f937e34d9de933dd6ce8cda0f62c2e8bff /plugins/fcgi/socket.cpp | |
parent | 91f78915fed4b1a3706c4d08a9b0c2c458cb0a2e (diff) |
Improve socket read handling
Diffstat (limited to 'plugins/fcgi/socket.cpp')
-rw-r--r-- | plugins/fcgi/socket.cpp | 23 |
1 files changed, 21 insertions, 2 deletions
diff --git a/plugins/fcgi/socket.cpp b/plugins/fcgi/socket.cpp index 228964c..5402cfb 100644 --- a/plugins/fcgi/socket.cpp +++ b/plugins/fcgi/socket.cpp @@ -106,7 +106,17 @@ size_t TCPSocket::write(const std::vector<char>& data) size_t TCPSocket::read(std::vector<char>& data) { try { - return m_socket.read_some(boost::asio::buffer(data)); + size_t result{0}; + + while (m_socket.available()) { + std::vector<char> inbuf_part(1024); + size_t got { m_socket.read_some(boost::asio::buffer(inbuf_part))}; + data.insert(data.end(), inbuf_part.begin(), inbuf_part.begin() + got); + result += got; + } + + return result; + } catch (const boost::system::system_error& ex) { if (ex.code() == boost::asio::error::eof) { throw fcgi_eof_error("EOF on read"); @@ -165,7 +175,16 @@ size_t FileSocket::write(const std::vector<char>& data) size_t FileSocket::read(std::vector<char>& data) { try { - return m_socket.read_some(boost::asio::buffer(data)); + size_t result{0}; + + while (m_socket.available()) { + std::vector<char> inbuf_part(1024); + size_t got { m_socket.read_some(boost::asio::buffer(inbuf_part))}; + data.insert(data.end(), inbuf_part.begin(), inbuf_part.begin() + got); + result += got; + } + + return result; } catch (const boost::system::system_error& ex) { if (ex.code() == boost::asio::error::eof) { throw fcgi_eof_error("EOF on read"); |