1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-06-23 00:28:08 +02:00

Use async_resolve to avoid crash on resolve error

This commit is contained in:
Ivan Savenko
2024-05-11 08:46:41 +00:00
parent a74d9791a1
commit 16f43254b5

View File

@ -32,8 +32,17 @@ std::unique_ptr<INetworkServer> NetworkHandler::createServerTCP(INetworkServerLi
void NetworkHandler::connectToRemote(INetworkClientListener & listener, const std::string & host, uint16_t port) void NetworkHandler::connectToRemote(INetworkClientListener & listener, const std::string & host, uint16_t port)
{ {
auto socket = std::make_shared<NetworkSocket>(*io); auto socket = std::make_shared<NetworkSocket>(*io);
boost::asio::ip::tcp::resolver resolver(*io); auto resolver = std::make_shared<boost::asio::ip::tcp::resolver>(*io);
auto endpoints = resolver.resolve(host, std::to_string(port));
resolver->async_resolve(host, std::to_string(port),
[&listener, resolver, socket](const boost::system::error_code& error, const boost::asio::ip::tcp::resolver::results_type & endpoints)
{
if (error)
{
listener.onConnectionFailed(error.message());
return;
}
boost::asio::async_connect(*socket, endpoints, [socket, &listener](const boost::system::error_code& error, const boost::asio::ip::tcp::endpoint& endpoint) boost::asio::async_connect(*socket, endpoints, [socket, &listener](const boost::system::error_code& error, const boost::asio::ip::tcp::endpoint& endpoint)
{ {
if (error) if (error)
@ -46,6 +55,7 @@ void NetworkHandler::connectToRemote(INetworkClientListener & listener, const st
listener.onConnectionEstablished(connection); listener.onConnectionEstablished(connection);
}); });
});
} }
void NetworkHandler::run() void NetworkHandler::run()