summaryrefslogtreecommitdiff
path: root/src/network/network_gamelist.cpp
diff options
context:
space:
mode:
authorrubidium <rubidium@openttd.org>2007-02-01 21:04:40 +0000
committerrubidium <rubidium@openttd.org>2007-02-01 21:04:40 +0000
commit752ca4ebf7358a62d09ccb9d85cec53f5162bc8e (patch)
tree455c66fea8606601015929a491e75466741e09f6 /src/network/network_gamelist.cpp
parent4d0d6864ee38dd838d5b6717b3409b336eb7fbf9 (diff)
downloadopenttd-752ca4ebf7358a62d09ccb9d85cec53f5162bc8e.tar.xz
(svn r8520) -Fix/Feature: requery gameservers that did not respond to their first query.
Diffstat (limited to 'src/network/network_gamelist.cpp')
-rw-r--r--src/network/network_gamelist.cpp38
1 files changed, 38 insertions, 0 deletions
diff --git a/src/network/network_gamelist.cpp b/src/network/network_gamelist.cpp
index a202769e0..e5c1d9b9a 100644
--- a/src/network/network_gamelist.cpp
+++ b/src/network/network_gamelist.cpp
@@ -7,6 +7,10 @@
#include "network_data.h"
#include "../newgrf_config.h"
#include "../helpers.hpp"
+#include "network_udp.h"
+
+/** Should we stop/contiue requerying of offline servers? */
+static bool _stop_requerying = false;
// This file handles the GameList
// Also, it handles the request to a server for data about the server
@@ -40,6 +44,7 @@ NetworkGameList *NetworkGameListAddItem(uint32 ip, uint16 port)
DEBUG(net, 4, "[gamelist] added server to list");
UpdateNetworkGameWindow(false);
+ _stop_requerying = false;
return item;
}
@@ -72,4 +77,37 @@ void NetworkGameListRemoveItem(NetworkGameList *remove)
}
}
+enum {
+ MAX_GAME_LIST_REQUERY_COUNT = 5,
+ REQUERY_EVERY_X_GAMELOOPS = 30,
+};
+
+/** Requeries the (game) servers we have not gotten a reply from */
+void NetworkGameListRequery(void)
+{
+ static uint8 requery_cnt = 0;
+
+ if (_stop_requerying || ++requery_cnt < REQUERY_EVERY_X_GAMELOOPS) return;
+
+ requery_cnt = 0;
+ _stop_requerying = true;
+
+ struct in_addr ip;
+ NetworkGameList *item;
+
+ for (item = _network_game_list; item != NULL; item = item->next) {
+ if (item->online || item->retries >= MAX_GAME_LIST_REQUERY_COUNT) continue;
+
+ ip.s_addr = item->ip;
+
+ /* item gets mostly zeroed by NetworkUDPQueryServer */
+ uint8 retries = item->retries;
+ NetworkUDPQueryServer(inet_ntoa(ip), item->port);
+ item->retries = retries + 1;
+
+ _stop_requerying = false;
+ }
+
+}
+
#endif /* ENABLE_NETWORK */