1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
#ifndef SOCKET_H
#define SOCKET_H
//#include <boost/asio.hpp> must be included before streflop!
#include <boost/asio/io_service.hpp>
#include <boost/asio/ip/udp.hpp>
#include <boost/asio/ip/tcp.hpp>
namespace netcode
{
extern boost::asio::io_service netservice;
/**
* Check if a network error occured and eventually log it.
* @returns true if a network error occured, false otherwise
*/
bool CheckErrorCode(boost::system::error_code& err);
/**
* Resolves a host name or IP plus port number into a boost UDP end-point,
* eventually resolving the host, if it is specified as name.
* @param host name or IP
*/
boost::asio::ip::udp::endpoint ResolveAddr(const std::string& host, int port, boost::system::error_code* error);
/**
* Evaluates if an address is a loopback one or not.
* In IP v4 it is "127.*.*.*", in IP v6 "::1".
*/
bool IsLoopbackAddress(const boost::asio::ip::address& addr);
/**
* Encapsulates the ip::address::from_string(str) function,
* for sync relevant reasons.
*/
boost::asio::ip::address WrapIP(const std::string& ip,
boost::system::error_code* err = NULL);
/**
* Encapsulates the ip::udp::resolver::resolve(query) function,
* for sync relevant reasons.
*/
boost::asio::ip::udp::resolver::iterator WrapResolve(
boost::asio::ip::udp::resolver& resolver,
boost::asio::ip::udp::resolver::query& query,
boost::system::error_code* err = NULL);
boost::asio::ip::address GetAnyAddress(const bool IPv6);
} // namespace netcode
#endif // SOCKET_H
|