Merge branch 'master' of https://github.com/supertuxkart/stk-code
This commit is contained in:
commit
a2659f479c
@ -479,6 +479,10 @@ convert -scale 48x48 "$APP_ICON" "$DIRNAME/res/drawable-mdpi/icon.png"
|
|||||||
convert -scale 96x96 "$APP_ICON" "$DIRNAME/res/drawable-xhdpi/icon.png"
|
convert -scale 96x96 "$APP_ICON" "$DIRNAME/res/drawable-xhdpi/icon.png"
|
||||||
convert -scale 144x144 "$APP_ICON" "$DIRNAME/res/drawable-xxhdpi/icon.png"
|
convert -scale 144x144 "$APP_ICON" "$DIRNAME/res/drawable-xxhdpi/icon.png"
|
||||||
|
|
||||||
|
if [ -f "/usr/lib/jvm/java-8-openjdk-amd64/bin/java" ]; then
|
||||||
|
export JAVA_HOME="/usr/lib/jvm/java-8-openjdk-amd64"
|
||||||
|
export PATH=$JAVA_HOME/bin:$PATH
|
||||||
|
fi
|
||||||
|
|
||||||
if [ "$BUILD_TOOL" = "gradle" ]; then
|
if [ "$BUILD_TOOL" = "gradle" ]; then
|
||||||
export ANDROID_HOME="$SDK_PATH"
|
export ANDROID_HOME="$SDK_PATH"
|
||||||
|
@ -230,138 +230,3 @@ void Network::closeLog()
|
|||||||
m_log_file.unlock();
|
m_log_file.unlock();
|
||||||
}
|
}
|
||||||
} // closeLog
|
} // closeLog
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
/** Sets a list of default broadcast addresses which is used in case no valid
|
|
||||||
* broadcast address is found. This list includes default private network
|
|
||||||
* addresses.
|
|
||||||
*/
|
|
||||||
void Network::setDefaultBroadcastAddresses()
|
|
||||||
{
|
|
||||||
// Add some common LAN addresses
|
|
||||||
m_broadcast_address.emplace_back(std::string("192.168.255.255"));
|
|
||||||
m_broadcast_address.emplace_back(std::string("192.168.0.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("192.168.1.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("172.31.255.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("172.16.255.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("172.16.0.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("10.255.255.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("10.0.255.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("10.0.0.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("255.255.255.255"));
|
|
||||||
m_broadcast_address.emplace_back(std::string("127.0.0.255") );
|
|
||||||
m_broadcast_address.emplace_back(std::string("127.0.0.1") );
|
|
||||||
} // setDefaultBroadcastAddresses
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
/** This masks various possible broadcast addresses. For example, in a /16
|
|
||||||
* network it would first use *.*.255.255, then *.*.*.255. Also if the
|
|
||||||
* length of the mask is not a multiple of 8, the original value will
|
|
||||||
* be used, before multiple of 8 are create: /22 (*.3f.ff.ff), then
|
|
||||||
* /16 (*.*.ff.ff), /8 (*.*.*.ff). While this is usually an overkill,
|
|
||||||
* it can help in the case that the router does not forward a broadcast
|
|
||||||
* as expected (this problem often happens with 255.255.255.255, which is
|
|
||||||
* why this broadcast address creation code was added).
|
|
||||||
* \param a The transport address for which the broadcast addresses need
|
|
||||||
* to be created.
|
|
||||||
* \param len Number of bits to be or'ed.
|
|
||||||
*/
|
|
||||||
void Network::addAllBroadcastAddresses(const TransportAddress &a, int len)
|
|
||||||
{
|
|
||||||
// Try different broadcast addresses - by masking on
|
|
||||||
// byte boundaries
|
|
||||||
while (len > 0)
|
|
||||||
{
|
|
||||||
unsigned int mask = (1 << len) - 1;
|
|
||||||
TransportAddress bcast(a.getIP() | mask,
|
|
||||||
NetworkConfig::get()->getServerDiscoveryPort());
|
|
||||||
Log::info("Broadcast", "address %s length %d mask %x --> %s",
|
|
||||||
a.toString().c_str(),
|
|
||||||
len, mask,
|
|
||||||
bcast.toString().c_str());
|
|
||||||
m_broadcast_address.push_back(bcast);
|
|
||||||
if (len % 8 != 0)
|
|
||||||
len -= (len % 8);
|
|
||||||
else
|
|
||||||
len = len - 8;
|
|
||||||
} // while len > 0
|
|
||||||
} // addAllBroadcastAddresses
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
/** Returns a list of all possible broadcast addresses on this machine.
|
|
||||||
* It queries all adapters for active IPV4 interfaces, determines their
|
|
||||||
* netmask to create the broadcast addresses. It will also add 'smaller'
|
|
||||||
* broadcast addesses, e.g. in a /16 network, it will add *.*.255.255 and
|
|
||||||
* *.*.*.255, since it was sometimes observed that routers would not let
|
|
||||||
* all broadcast addresses through. Duplicated answers (from the same server
|
|
||||||
* to different addersses) will be filtered out in ServersManager.
|
|
||||||
*/
|
|
||||||
const std::vector<TransportAddress>& Network::getBroadcastAddresses()
|
|
||||||
{
|
|
||||||
if (m_broadcast_address.size() > 0) return m_broadcast_address;
|
|
||||||
|
|
||||||
#ifdef WIN32
|
|
||||||
IP_ADAPTER_ADDRESSES *addresses;
|
|
||||||
int count = 100, return_code;
|
|
||||||
|
|
||||||
int iteration = 0;
|
|
||||||
do
|
|
||||||
{
|
|
||||||
addresses = new IP_ADAPTER_ADDRESSES[count];
|
|
||||||
ULONG buf_len = sizeof(IP_ADAPTER_ADDRESSES)*count;
|
|
||||||
long flags = 0;
|
|
||||||
return_code = GetAdaptersAddresses(AF_INET, flags, NULL, addresses,
|
|
||||||
&buf_len);
|
|
||||||
iteration++;
|
|
||||||
} while (return_code == ERROR_BUFFER_OVERFLOW && iteration<10);
|
|
||||||
|
|
||||||
if (return_code == ERROR_BUFFER_OVERFLOW)
|
|
||||||
{
|
|
||||||
Log::warn("NetworkConfig", "Can not get broadcast addresses.");
|
|
||||||
setDefaultBroadcastAddresses();
|
|
||||||
return m_broadcast_address;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (IP_ADAPTER_ADDRESSES *p = addresses; p; p = p->Next)
|
|
||||||
{
|
|
||||||
// Check all operational IP4 adapters
|
|
||||||
if (p->OperStatus == IfOperStatusUp &&
|
|
||||||
p->FirstUnicastAddress->Address.lpSockaddr->sa_family == AF_INET)
|
|
||||||
{
|
|
||||||
const sockaddr_in *sa = (sockaddr_in*)p->FirstUnicastAddress->Address.lpSockaddr;
|
|
||||||
// Use sa->sin_addr.S_un.S_addr and htonl?
|
|
||||||
TransportAddress ta(sa->sin_addr.S_un.S_un_b.s_b1,
|
|
||||||
sa->sin_addr.S_un.S_un_b.s_b2,
|
|
||||||
sa->sin_addr.S_un.S_un_b.s_b3,
|
|
||||||
sa->sin_addr.S_un.S_un_b.s_b4);
|
|
||||||
int len = 32 - p->FirstUnicastAddress->OnLinkPrefixLength;
|
|
||||||
addAllBroadcastAddresses(ta, len);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
struct ifaddrs *addresses, *p;
|
|
||||||
|
|
||||||
getifaddrs(&addresses);
|
|
||||||
for (p = addresses; p; p = p->ifa_next)
|
|
||||||
{
|
|
||||||
if (p->ifa_addr->sa_family == AF_INET)
|
|
||||||
{
|
|
||||||
struct sockaddr_in *sa = (struct sockaddr_in *) p->ifa_addr;
|
|
||||||
TransportAddress ta(htonl(sa->sin_addr.s_addr), 0);
|
|
||||||
uint32_t u = ((sockaddr_in*)(p->ifa_netmask))->sin_addr.s_addr;
|
|
||||||
// Convert mask to #bits: SWAT algorithm
|
|
||||||
u = u - ((u >> 1) & 0x55555555);
|
|
||||||
u = (u & 0x33333333) + ((u >> 2) & 0x33333333);
|
|
||||||
u = (((u + (u >> 4)) & 0x0F0F0F0F) * 0x01010101) >> 24;
|
|
||||||
|
|
||||||
printf("Interface: %s\tAddress: %s\tmask: %x\n", p->ifa_name,
|
|
||||||
ta.toString().c_str(), u);
|
|
||||||
addAllBroadcastAddresses(ta, u);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
return m_broadcast_address;
|
|
||||||
} // getBroadcastAddresses
|
|
||||||
|
|
||||||
|
@ -51,12 +51,6 @@ private:
|
|||||||
/** Where to log packets. If NULL for FILE* logging is disabled. */
|
/** Where to log packets. If NULL for FILE* logging is disabled. */
|
||||||
static Synchronised<FILE*> m_log_file;
|
static Synchronised<FILE*> m_log_file;
|
||||||
|
|
||||||
/** List of broadcast addresses to use. */
|
|
||||||
std::vector<TransportAddress> m_broadcast_address;
|
|
||||||
|
|
||||||
void setDefaultBroadcastAddresses();
|
|
||||||
void addAllBroadcastAddresses(const TransportAddress &a, int len);
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Network(int peer_count, int channel_limit,
|
Network(int peer_count, int channel_limit,
|
||||||
uint32_t max_incoming_bandwidth,
|
uint32_t max_incoming_bandwidth,
|
||||||
@ -75,7 +69,6 @@ public:
|
|||||||
TransportAddress* sender, int max_tries = -1);
|
TransportAddress* sender, int max_tries = -1);
|
||||||
void broadcastPacket(NetworkString *data,
|
void broadcastPacket(NetworkString *data,
|
||||||
bool reliable = true);
|
bool reliable = true);
|
||||||
const std::vector<TransportAddress>& getBroadcastAddresses();
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
/** Returns a pointer to the ENet host object. */
|
/** Returns a pointer to the ENet host object. */
|
||||||
|
@ -82,7 +82,7 @@ void ConnectToServer::asynchronousUpdate()
|
|||||||
{
|
{
|
||||||
if (!m_server)
|
if (!m_server)
|
||||||
{
|
{
|
||||||
while (!ServersManager::get()->refresh())
|
while (!ServersManager::get()->refresh(false))
|
||||||
StkTime::sleep(1);
|
StkTime::sleep(1);
|
||||||
while (!ServersManager::get()->listUpdated())
|
while (!ServersManager::get()->listUpdated())
|
||||||
StkTime::sleep(1);
|
StkTime::sleep(1);
|
||||||
|
@ -33,6 +33,14 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#if defined(WIN32)
|
||||||
|
# undef _WIN32_WINNT
|
||||||
|
# define _WIN32_WINNT 0x600
|
||||||
|
# include <iphlpapi.h>
|
||||||
|
#else
|
||||||
|
# include <ifaddrs.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#define SERVER_REFRESH_INTERVAL 5.0f
|
#define SERVER_REFRESH_INTERVAL 5.0f
|
||||||
|
|
||||||
static ServersManager* g_manager_singleton(NULL);
|
static ServersManager* g_manager_singleton(NULL);
|
||||||
@ -136,7 +144,7 @@ Online::XMLRequest* ServersManager::getLANRefreshRequest() const
|
|||||||
addr.port = STKHost::PORT_ANY;
|
addr.port = STKHost::PORT_ANY;
|
||||||
Network *broadcast = new Network(1, 1, 0, 0, &addr);
|
Network *broadcast = new Network(1, 1, 0, 0, &addr);
|
||||||
const std::vector<TransportAddress> &all_bcast =
|
const std::vector<TransportAddress> &all_bcast =
|
||||||
broadcast->getBroadcastAddresses();
|
ServersManager::get()->getBroadcastAddresses();
|
||||||
for (auto &bcast_addr : all_bcast)
|
for (auto &bcast_addr : all_bcast)
|
||||||
{
|
{
|
||||||
Log::info("Server Discovery", "Broadcasting to %s",
|
Log::info("Server Discovery", "Broadcasting to %s",
|
||||||
@ -225,7 +233,7 @@ void ServersManager::setLanServers(const std::map<irr::core::stringw,
|
|||||||
/** Factory function to create either a LAN or a WAN update-of-server
|
/** Factory function to create either a LAN or a WAN update-of-server
|
||||||
* requests. The current list of servers is also cleared.
|
* requests. The current list of servers is also cleared.
|
||||||
*/
|
*/
|
||||||
bool ServersManager::refresh()
|
bool ServersManager::refresh(bool full_refresh)
|
||||||
{
|
{
|
||||||
if (StkTime::getRealTime() - m_last_load_time.load()
|
if (StkTime::getRealTime() - m_last_load_time.load()
|
||||||
< SERVER_REFRESH_INTERVAL)
|
< SERVER_REFRESH_INTERVAL)
|
||||||
@ -236,10 +244,21 @@ bool ServersManager::refresh()
|
|||||||
|
|
||||||
cleanUpServers();
|
cleanUpServers();
|
||||||
m_list_updated = false;
|
m_list_updated = false;
|
||||||
|
|
||||||
if (NetworkConfig::get()->isWAN())
|
if (NetworkConfig::get()->isWAN())
|
||||||
Online::RequestManager::get()->addRequest(getWANRefreshRequest());
|
{
|
||||||
|
Online::RequestManager::get()->addRequest(getWANRefreshRequest());
|
||||||
|
}
|
||||||
else
|
else
|
||||||
Online::RequestManager::get()->addRequest(getLANRefreshRequest());
|
{
|
||||||
|
if (full_refresh)
|
||||||
|
{
|
||||||
|
updateBroadcastAddresses();
|
||||||
|
}
|
||||||
|
|
||||||
|
Online::RequestManager::get()->addRequest(getLANRefreshRequest());
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
} // refresh
|
} // refresh
|
||||||
|
|
||||||
@ -275,3 +294,147 @@ void ServersManager::setWanServers(bool success, const XMLNode* input)
|
|||||||
m_last_load_time.store((float)StkTime::getRealTime());
|
m_last_load_time.store((float)StkTime::getRealTime());
|
||||||
m_list_updated = true;
|
m_list_updated = true;
|
||||||
} // refresh
|
} // refresh
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
/** Sets a list of default broadcast addresses which is used in case no valid
|
||||||
|
* broadcast address is found. This list includes default private network
|
||||||
|
* addresses.
|
||||||
|
*/
|
||||||
|
void ServersManager::setDefaultBroadcastAddresses()
|
||||||
|
{
|
||||||
|
// Add some common LAN addresses
|
||||||
|
m_broadcast_address.emplace_back(std::string("192.168.255.255"));
|
||||||
|
m_broadcast_address.emplace_back(std::string("192.168.0.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("192.168.1.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("172.31.255.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("172.16.255.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("172.16.0.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("10.255.255.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("10.0.255.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("10.0.0.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("255.255.255.255"));
|
||||||
|
m_broadcast_address.emplace_back(std::string("127.0.0.255") );
|
||||||
|
m_broadcast_address.emplace_back(std::string("127.0.0.1") );
|
||||||
|
} // setDefaultBroadcastAddresses
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
/** This masks various possible broadcast addresses. For example, in a /16
|
||||||
|
* network it would first use *.*.255.255, then *.*.*.255. Also if the
|
||||||
|
* length of the mask is not a multiple of 8, the original value will
|
||||||
|
* be used, before multiple of 8 are create: /22 (*.3f.ff.ff), then
|
||||||
|
* /16 (*.*.ff.ff), /8 (*.*.*.ff). While this is usually an overkill,
|
||||||
|
* it can help in the case that the router does not forward a broadcast
|
||||||
|
* as expected (this problem often happens with 255.255.255.255, which is
|
||||||
|
* why this broadcast address creation code was added).
|
||||||
|
* \param a The transport address for which the broadcast addresses need
|
||||||
|
* to be created.
|
||||||
|
* \param len Number of bits to be or'ed.
|
||||||
|
*/
|
||||||
|
void ServersManager::addAllBroadcastAddresses(const TransportAddress &a, int len)
|
||||||
|
{
|
||||||
|
// Try different broadcast addresses - by masking on
|
||||||
|
// byte boundaries
|
||||||
|
while (len > 0)
|
||||||
|
{
|
||||||
|
unsigned int mask = (1 << len) - 1;
|
||||||
|
TransportAddress bcast(a.getIP() | mask,
|
||||||
|
NetworkConfig::get()->getServerDiscoveryPort());
|
||||||
|
Log::info("Broadcast", "address %s length %d mask %x --> %s",
|
||||||
|
a.toString().c_str(),
|
||||||
|
len, mask,
|
||||||
|
bcast.toString().c_str());
|
||||||
|
m_broadcast_address.push_back(bcast);
|
||||||
|
if (len % 8 != 0)
|
||||||
|
len -= (len % 8);
|
||||||
|
else
|
||||||
|
len = len - 8;
|
||||||
|
} // while len > 0
|
||||||
|
} // addAllBroadcastAddresses
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
/** Updates a list of all possible broadcast addresses on this machine.
|
||||||
|
* It queries all adapters for active IPV4 interfaces, determines their
|
||||||
|
* netmask to create the broadcast addresses. It will also add 'smaller'
|
||||||
|
* broadcast addesses, e.g. in a /16 network, it will add *.*.255.255 and
|
||||||
|
* *.*.*.255, since it was sometimes observed that routers would not let
|
||||||
|
* all broadcast addresses through. Duplicated answers (from the same server
|
||||||
|
* to different addersses) will be filtered out in ServersManager.
|
||||||
|
*/
|
||||||
|
void ServersManager::updateBroadcastAddresses()
|
||||||
|
{
|
||||||
|
m_broadcast_address.clear();
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
IP_ADAPTER_ADDRESSES *addresses;
|
||||||
|
int count = 100, return_code;
|
||||||
|
|
||||||
|
int iteration = 0;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
addresses = new IP_ADAPTER_ADDRESSES[count];
|
||||||
|
ULONG buf_len = sizeof(IP_ADAPTER_ADDRESSES)*count;
|
||||||
|
long flags = 0;
|
||||||
|
return_code = GetAdaptersAddresses(AF_INET, flags, NULL, addresses,
|
||||||
|
&buf_len);
|
||||||
|
iteration++;
|
||||||
|
} while (return_code == ERROR_BUFFER_OVERFLOW && iteration<10);
|
||||||
|
|
||||||
|
if (return_code == ERROR_BUFFER_OVERFLOW)
|
||||||
|
{
|
||||||
|
Log::warn("NetworkConfig", "Can not get broadcast addresses.");
|
||||||
|
setDefaultBroadcastAddresses();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (IP_ADAPTER_ADDRESSES *p = addresses; p; p = p->Next)
|
||||||
|
{
|
||||||
|
// Check all operational IP4 adapters
|
||||||
|
if (p->OperStatus == IfOperStatusUp &&
|
||||||
|
p->FirstUnicastAddress->Address.lpSockaddr->sa_family == AF_INET)
|
||||||
|
{
|
||||||
|
const sockaddr_in *sa = (sockaddr_in*)p->FirstUnicastAddress->Address.lpSockaddr;
|
||||||
|
// Use sa->sin_addr.S_un.S_addr and htonl?
|
||||||
|
TransportAddress ta(sa->sin_addr.S_un.S_un_b.s_b1,
|
||||||
|
sa->sin_addr.S_un.S_un_b.s_b2,
|
||||||
|
sa->sin_addr.S_un.S_un_b.s_b3,
|
||||||
|
sa->sin_addr.S_un.S_un_b.s_b4);
|
||||||
|
int len = 32 - p->FirstUnicastAddress->OnLinkPrefixLength;
|
||||||
|
addAllBroadcastAddresses(ta, len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
struct ifaddrs *addresses, *p;
|
||||||
|
|
||||||
|
getifaddrs(&addresses);
|
||||||
|
for (p = addresses; p; p = p->ifa_next)
|
||||||
|
{
|
||||||
|
if (p->ifa_addr->sa_family == AF_INET)
|
||||||
|
{
|
||||||
|
struct sockaddr_in *sa = (struct sockaddr_in *) p->ifa_addr;
|
||||||
|
TransportAddress ta(htonl(sa->sin_addr.s_addr), 0);
|
||||||
|
uint32_t u = ((sockaddr_in*)(p->ifa_netmask))->sin_addr.s_addr;
|
||||||
|
// Convert mask to #bits: SWAT algorithm
|
||||||
|
u = u - ((u >> 1) & 0x55555555);
|
||||||
|
u = (u & 0x33333333) + ((u >> 2) & 0x33333333);
|
||||||
|
u = (((u + (u >> 4)) & 0x0F0F0F0F) * 0x01010101) >> 24;
|
||||||
|
|
||||||
|
printf("Interface: %s\tAddress: %s\tmask: %x\n", p->ifa_name,
|
||||||
|
ta.toString().c_str(), u);
|
||||||
|
addAllBroadcastAddresses(ta, u);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
} // updateBroadcastAddresses
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
/** Returns a list of all possible broadcast addresses on this machine.
|
||||||
|
*/
|
||||||
|
const std::vector<TransportAddress>& ServersManager::getBroadcastAddresses()
|
||||||
|
{
|
||||||
|
if (m_broadcast_address.empty())
|
||||||
|
{
|
||||||
|
updateBroadcastAddresses();
|
||||||
|
}
|
||||||
|
|
||||||
|
return m_broadcast_address;
|
||||||
|
} // getBroadcastAddresses
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
namespace Online { class XMLRequest; }
|
namespace Online { class XMLRequest; }
|
||||||
class Server;
|
class Server;
|
||||||
|
class TransportAddress;
|
||||||
class XMLNode;
|
class XMLNode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -41,6 +42,9 @@ private:
|
|||||||
/** List of servers */
|
/** List of servers */
|
||||||
std::vector<std::shared_ptr<Server> > m_servers;
|
std::vector<std::shared_ptr<Server> > m_servers;
|
||||||
|
|
||||||
|
/** List of broadcast addresses to use. */
|
||||||
|
std::vector<TransportAddress> m_broadcast_address;
|
||||||
|
|
||||||
std::atomic<float> m_last_load_time;
|
std::atomic<float> m_last_load_time;
|
||||||
|
|
||||||
std::atomic_bool m_list_updated;
|
std::atomic_bool m_list_updated;
|
||||||
@ -57,6 +61,10 @@ private:
|
|||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
void setLanServers(const std::map<irr::core::stringw,
|
void setLanServers(const std::map<irr::core::stringw,
|
||||||
std::shared_ptr<Server> >& servers);
|
std::shared_ptr<Server> >& servers);
|
||||||
|
|
||||||
|
void setDefaultBroadcastAddresses();
|
||||||
|
void addAllBroadcastAddresses(const TransportAddress &a, int len);
|
||||||
|
void updateBroadcastAddresses();
|
||||||
public:
|
public:
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
// Singleton
|
// Singleton
|
||||||
@ -66,11 +74,13 @@ public:
|
|||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
void cleanUpServers() { m_servers.clear(); }
|
void cleanUpServers() { m_servers.clear(); }
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
bool refresh();
|
bool refresh(bool full_refresh);
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
std::vector<std::shared_ptr<Server> >& getServers() { return m_servers; }
|
std::vector<std::shared_ptr<Server> >& getServers() { return m_servers; }
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
bool listUpdated() const { return m_list_updated; }
|
bool listUpdated() const { return m_list_updated; }
|
||||||
|
// ------------------------------------------------------------------------
|
||||||
|
const std::vector<TransportAddress>& getBroadcastAddresses();
|
||||||
|
|
||||||
}; // class ServersManager
|
}; // class ServersManager
|
||||||
#endif // HEADER_SERVERS_MANAGER_HPP
|
#endif // HEADER_SERVERS_MANAGER_HPP
|
||||||
|
@ -42,6 +42,7 @@ using namespace Online;
|
|||||||
ServerSelection::ServerSelection() : Screen("online/server_selection.stkgui")
|
ServerSelection::ServerSelection() : Screen("online/server_selection.stkgui")
|
||||||
{
|
{
|
||||||
m_refreshing_server = false;
|
m_refreshing_server = false;
|
||||||
|
m_refresh_timer = 0.0f;
|
||||||
} // ServerSelection
|
} // ServerSelection
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@ -65,15 +66,16 @@ void ServerSelection::tearDown()
|
|||||||
/** Requests the servers manager to update its list of servers, and disables
|
/** Requests the servers manager to update its list of servers, and disables
|
||||||
* the 'refresh' button (till the refresh was finished).
|
* the 'refresh' button (till the refresh was finished).
|
||||||
*/
|
*/
|
||||||
void ServerSelection::refresh()
|
void ServerSelection::refresh(bool full_refresh)
|
||||||
{
|
{
|
||||||
// If the request was created (i.e. no error, and not re-requested within
|
// If the request was created (i.e. no error, and not re-requested within
|
||||||
// 5 seconds), clear the list and display the waiting message:
|
// 5 seconds), clear the list and display the waiting message:
|
||||||
if (ServersManager::get()->refresh())
|
if (ServersManager::get()->refresh(full_refresh))
|
||||||
{
|
{
|
||||||
m_server_list_widget->clear();
|
m_server_list_widget->clear();
|
||||||
m_reload_widget->setActive(false);
|
m_reload_widget->setActive(false);
|
||||||
m_refreshing_server = true;
|
m_refreshing_server = true;
|
||||||
|
m_refresh_timer = 0.0f;
|
||||||
}
|
}
|
||||||
} // refresh
|
} // refresh
|
||||||
|
|
||||||
@ -120,7 +122,7 @@ void ServerSelection::init()
|
|||||||
Screen::init();
|
Screen::init();
|
||||||
m_sort_desc = true;
|
m_sort_desc = true;
|
||||||
/** Triggers the loading of the server list in the servers manager. */
|
/** Triggers the loading of the server list in the servers manager. */
|
||||||
refresh();
|
refresh(true);
|
||||||
} // init
|
} // init
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@ -215,7 +217,7 @@ void ServerSelection::eventCallback(GUIEngine::Widget* widget,
|
|||||||
}
|
}
|
||||||
else if (name == "reload")
|
else if (name == "reload")
|
||||||
{
|
{
|
||||||
refresh();
|
refresh(true);
|
||||||
}
|
}
|
||||||
else if (name == "private_server")
|
else if (name == "private_server")
|
||||||
{
|
{
|
||||||
@ -251,6 +253,17 @@ void ServerSelection::onUpdate(float dt)
|
|||||||
sid->requestJoin();
|
sid->requestJoin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ServersManager::get()->getServers().empty() && !m_refreshing_server &&
|
||||||
|
!NetworkConfig::get()->isWAN())
|
||||||
|
{
|
||||||
|
m_refresh_timer += dt;
|
||||||
|
|
||||||
|
if (m_refresh_timer > 10.0f)
|
||||||
|
{
|
||||||
|
refresh(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!m_refreshing_server) return;
|
if (!m_refreshing_server) return;
|
||||||
|
|
||||||
if (ServersManager::get()->listUpdated())
|
if (ServersManager::get()->listUpdated())
|
||||||
@ -269,8 +282,9 @@ void ServerSelection::onUpdate(float dt)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
SFXManager::get()->quickSound("anvil");
|
SFXManager::get()->quickSound("anvil");
|
||||||
new MessageDialog(_("No server is available."));
|
|
||||||
m_server_list_widget->clear();
|
m_server_list_widget->clear();
|
||||||
|
m_server_list_widget->addItem("loading",
|
||||||
|
_("No server is available."));
|
||||||
}
|
}
|
||||||
m_reload_widget->setActive(true);
|
m_reload_widget->setActive(true);
|
||||||
}
|
}
|
||||||
|
@ -60,12 +60,14 @@ private:
|
|||||||
|
|
||||||
bool m_refreshing_server;
|
bool m_refreshing_server;
|
||||||
|
|
||||||
|
float m_refresh_timer;
|
||||||
|
|
||||||
/** Load the servers into the main list.*/
|
/** Load the servers into the main list.*/
|
||||||
void loadList(unsigned sort_case);
|
void loadList(unsigned sort_case);
|
||||||
|
|
||||||
void copyFromServersManager();
|
void copyFromServersManager();
|
||||||
|
|
||||||
void refresh();
|
void refresh(bool full_refresh);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/** \brief implement callback from parent class GUIEngine::Screen */
|
/** \brief implement callback from parent class GUIEngine::Screen */
|
||||||
|
Loading…
Reference in New Issue
Block a user