aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2014-09-12 19:34:26 +0200
committerShauren <shauren.trinity@gmail.com>2014-09-12 19:34:26 +0200
commit6dff6b74256748f182ad65634a1ab16c5989d40e (patch)
treee44656203fbdc6df215cbee7c20a28e55e5c56d2
parentdcba0106d64bd598e70cc65be8e28f6ee279dcfd (diff)
Core/NetworkIO: Set non blocking mode on sockets properly
-rw-r--r--src/server/shared/Networking/AsyncAcceptor.h9
1 files changed, 4 insertions, 5 deletions
diff --git a/src/server/shared/Networking/AsyncAcceptor.h b/src/server/shared/Networking/AsyncAcceptor.h
index a8b688e6b26..c8f8e2dbd90 100644
--- a/src/server/shared/Networking/AsyncAcceptor.h
+++ b/src/server/shared/Networking/AsyncAcceptor.h
@@ -32,8 +32,6 @@ public:
_acceptor(ioService, tcp::endpoint(boost::asio::ip::address::from_string(bindIp), port)),
_socket(ioService)
{
- boost::system::error_code error;
- _acceptor.non_blocking(true, error);
}
template <class T>
@@ -47,12 +45,13 @@ public:
{
try
{
- // this-> is required here to fix an segmentation fault in gcc 4.7.2 - reason is lambdas in a templated class
- mgrHandler(std::move(this->_socket));
+ _socket.non_blocking(true);
+
+ mgrHandler(std::move(_socket));
}
catch (boost::system::system_error const& err)
{
- TC_LOG_INFO("network", "Failed to retrieve client's remote address %s", err.what());
+ TC_LOG_INFO("network", "Failed to initialize client's socket %s", err.what());
}
}