Renamed ServerLobbyRoomProtocol to just ServerLobby, ClientLobbyRoomProtocol

to ClientLobby, and LobbyRoomProtocol to Lobbyprotocol.
This commit is contained in:
hiker 2016-11-23 09:39:33 +11:00
parent 09eae7e25f
commit 026e1623ec
16 changed files with 151 additions and 150 deletions

View File

@ -28,7 +28,7 @@
#include "karts/abstract_kart.hpp" #include "karts/abstract_kart.hpp"
#include "modes/world.hpp" #include "modes/world.hpp"
#include "network/network_config.hpp" #include "network/network_config.hpp"
#include "network/protocols/server_lobby_room_protocol.hpp" #include "network/protocols/server_lobby.hpp"
#include "network/race_event_manager.hpp" #include "network/race_event_manager.hpp"
#include "tracks/track.hpp" #include "tracks/track.hpp"

View File

@ -22,8 +22,8 @@
#include "network/network_config.hpp" #include "network/network_config.hpp"
#include "network/network_player_profile.hpp" #include "network/network_player_profile.hpp"
#include "network/stk_host.hpp" #include "network/stk_host.hpp"
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "network/protocols/server_lobby_room_protocol.hpp" #include "network/protocols/server_lobby.hpp"
#include "network/protocols/stop_server.hpp" #include "network/protocols/stop_server.hpp"
#include "network/stk_peer.hpp" #include "network/stk_peer.hpp"
#include "utils/log.hpp" #include "utils/log.hpp"
@ -78,23 +78,23 @@ void* NetworkConsole::mainLoop(void* data)
} }
else if (str == "start" && NetworkConfig::get()->isServer()) else if (str == "start" && NetworkConfig::get()->isServer())
{ {
ServerLobbyRoomProtocol* protocol = ServerLobby* protocol =
dynamic_cast<ServerLobbyRoomProtocol*>(LobbyRoomProtocol::get()); dynamic_cast<ServerLobby*>(LobbyRoomProtocol::get());
protocol->signalRaceStartToClients(); protocol->signalRaceStartToClients();
} }
else if (str == "selection" && NetworkConfig::get()->isServer()) else if (str == "selection" && NetworkConfig::get()->isServer())
{ {
ServerLobbyRoomProtocol* protocol = ServerLobby* protocol =
dynamic_cast<ServerLobbyRoomProtocol*>(LobbyRoomProtocol::get()); dynamic_cast<ServerLobby*>(LobbyRoomProtocol::get());
protocol->startSelection(); protocol->startSelection();
} }
else if (str == "select" && NetworkConfig::get()->isClient()) else if (str == "select" && NetworkConfig::get()->isClient())
{ {
std::string str2; std::string str2;
getline(std::cin, str2); getline(std::cin, str2);
ServerLobbyRoomProtocol* protocol = ServerLobby* protocol =
dynamic_cast<ServerLobbyRoomProtocol*>(LobbyRoomProtocol::get()); dynamic_cast<ServerLobby*>(LobbyRoomProtocol::get());
ClientLobbyRoomProtocol* clrp = dynamic_cast<ClientLobbyRoomProtocol*>(protocol); ClientLobby* clrp = dynamic_cast<ClientLobby*>(protocol);
std::vector<NetworkPlayerProfile*> players = std::vector<NetworkPlayerProfile*> players =
STKHost::get()->getMyPlayerProfiles(); STKHost::get()->getMyPlayerProfiles();
// For now send a vote for each local player // For now send a vote for each local player
@ -110,8 +110,8 @@ void* NetworkConsole::mainLoop(void* data)
std::string str2; std::string str2;
getline(std::cin, str2); getline(std::cin, str2);
LobbyRoomProtocol* protocol = LobbyRoomProtocol::get(); LobbyRoomProtocol* protocol = LobbyRoomProtocol::get();
ClientLobbyRoomProtocol* clrp = ClientLobby* clrp =
dynamic_cast<ClientLobbyRoomProtocol*>(protocol); dynamic_cast<ClientLobby*>(protocol);
std::vector<NetworkPlayerProfile*> players = std::vector<NetworkPlayerProfile*> players =
STKHost::get()->getMyPlayerProfiles(); STKHost::get()->getMyPlayerProfiles();
if (str2 == "track") if (str2 == "track")

View File

@ -16,7 +16,7 @@
// along with this program; if not, write to the Free Software // along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "config/player_manager.hpp" #include "config/player_manager.hpp"
#include "modes/world_with_rank.hpp" #include "modes/world_with_rank.hpp"
@ -35,31 +35,31 @@
#include "utils/log.hpp" #include "utils/log.hpp"
// ============================================================================ // ============================================================================
ClientLobbyRoomProtocol::ClientLobbyRoomProtocol() ClientLobby::ClientLobby()
: LobbyRoomProtocol(NULL) : LobbyRoomProtocol(NULL)
{ {
m_server_address.clear(); m_server_address.clear();
m_server = NULL; m_server = NULL;
setHandleDisconnections(true); setHandleDisconnections(true);
} // ClientLobbyRoomProtocol } // ClientLobby
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
ClientLobbyRoomProtocol::~ClientLobbyRoomProtocol() ClientLobby::~ClientLobby()
{ {
} // ClientLobbyRoomProtocol } // ClientLobby
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
/** Sets the address of the server. /** Sets the address of the server.
*/ */
void ClientLobbyRoomProtocol::setAddress(const TransportAddress &address) void ClientLobby::setAddress(const TransportAddress &address)
{ {
m_server_address.copy(address); m_server_address.copy(address);
} // setAddress } // setAddress
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void ClientLobbyRoomProtocol::setup() void ClientLobby::setup()
{ {
m_game_setup = STKHost::get()->setupNewGame(); // create a new game setup m_game_setup = STKHost::get()->setupNewGame(); // create a new game setup
m_state = NONE; m_state = NONE;
@ -70,7 +70,7 @@ void ClientLobbyRoomProtocol::setup()
* \param player_id The global player id of the voting player. * \param player_id The global player id of the voting player.
* \param kart_name Name of the selected kart. * \param kart_name Name of the selected kart.
*/ */
void ClientLobbyRoomProtocol::requestKartSelection(uint8_t player_id, void ClientLobby::requestKartSelection(uint8_t player_id,
const std::string &kart_name) const std::string &kart_name)
{ {
NetworkString *request = getNetworkString(3+kart_name.size()); NetworkString *request = getNetworkString(3+kart_name.size());
@ -87,7 +87,7 @@ void ClientLobbyRoomProtocol::requestKartSelection(uint8_t player_id,
* \param player_id The global player id of the voting player. * \param player_id The global player id of the voting player.
* \param major Major mode voted for. * \param major Major mode voted for.
*/ */
void ClientLobbyRoomProtocol::voteMajor(uint8_t player_id, uint32_t major) void ClientLobby::voteMajor(uint8_t player_id, uint32_t major)
{ {
NetworkString *request = getNetworkString(6); NetworkString *request = getNetworkString(6);
request->addUInt8(LE_VOTE_MAJOR).addUInt8(player_id) request->addUInt8(LE_VOTE_MAJOR).addUInt8(player_id)
@ -103,7 +103,7 @@ void ClientLobbyRoomProtocol::voteMajor(uint8_t player_id, uint32_t major)
* \param player_id The global player id of the voting player. * \param player_id The global player id of the voting player.
* \param count NUmber of tracks to play. * \param count NUmber of tracks to play.
*/ */
void ClientLobbyRoomProtocol::voteRaceCount(uint8_t player_id, uint8_t count) void ClientLobby::voteRaceCount(uint8_t player_id, uint8_t count)
{ {
NetworkString *request = getNetworkString(3); NetworkString *request = getNetworkString(3);
request->addUInt8(LE_VOTE_RACE_COUNT).addUInt8(player_id).addUInt8(count); request->addUInt8(LE_VOTE_RACE_COUNT).addUInt8(player_id).addUInt8(count);
@ -118,7 +118,7 @@ void ClientLobbyRoomProtocol::voteRaceCount(uint8_t player_id, uint8_t count)
* \param player_id The global player id of the voting player. * \param player_id The global player id of the voting player.
* \param minor Voted minor mode. * \param minor Voted minor mode.
*/ */
void ClientLobbyRoomProtocol::voteMinor(uint8_t player_id, uint32_t minor) void ClientLobby::voteMinor(uint8_t player_id, uint32_t minor)
{ {
NetworkString *request = getNetworkString(6); NetworkString *request = getNetworkString(6);
request->addUInt8(LE_VOTE_MINOR).addUInt8(player_id).addUInt32(minor); request->addUInt8(LE_VOTE_MINOR).addUInt8(player_id).addUInt32(minor);
@ -134,7 +134,7 @@ void ClientLobbyRoomProtocol::voteMinor(uint8_t player_id, uint32_t minor)
* \param track Name of the track. * \param track Name of the track.
* \param At which place in the list of tracks this track should be played. * \param At which place in the list of tracks this track should be played.
*/ */
void ClientLobbyRoomProtocol::voteTrack(uint8_t player_id, void ClientLobby::voteTrack(uint8_t player_id,
const std::string &track, const std::string &track,
uint8_t track_nb) uint8_t track_nb)
{ {
@ -154,7 +154,7 @@ void ClientLobbyRoomProtocol::voteTrack(uint8_t player_id,
* \param track_nb Index for the track to be voted on in the list of all * \param track_nb Index for the track to be voted on in the list of all
* tracks. * tracks.
*/ */
void ClientLobbyRoomProtocol::voteReversed(uint8_t player_id, bool reversed, void ClientLobby::voteReversed(uint8_t player_id, bool reversed,
uint8_t track_nb) uint8_t track_nb)
{ {
NetworkString *request = getNetworkString(9); NetworkString *request = getNetworkString(9);
@ -171,7 +171,7 @@ void ClientLobbyRoomProtocol::voteReversed(uint8_t player_id, bool reversed,
* \param laps Number of laps for the specified track. * \param laps Number of laps for the specified track.
* \param track_nb Index of the track in the list of all tracks. * \param track_nb Index of the track in the list of all tracks.
*/ */
void ClientLobbyRoomProtocol::voteLaps(uint8_t player_id, uint8_t laps, void ClientLobby::voteLaps(uint8_t player_id, uint8_t laps,
uint8_t track_nb) uint8_t track_nb)
{ {
NetworkString *request = getNetworkString(10); NetworkString *request = getNetworkString(10);
@ -184,7 +184,7 @@ void ClientLobbyRoomProtocol::voteLaps(uint8_t player_id, uint8_t laps,
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
/** Called when a client selects to exit a server. /** Called when a client selects to exit a server.
*/ */
void ClientLobbyRoomProtocol::leave() void ClientLobby::leave()
{ {
m_server->disconnect(); m_server->disconnect();
STKHost::get()->removePeer(m_server); STKHost::get()->removePeer(m_server);
@ -197,7 +197,7 @@ void ClientLobbyRoomProtocol::leave()
* screen. It notifies the server that this client has exited the screen and * screen. It notifies the server that this client has exited the screen and
* is back at the lobby. * is back at the lobby.
*/ */
void ClientLobbyRoomProtocol::doneWithResults() void ClientLobby::doneWithResults()
{ {
NetworkString *done = getNetworkString(1); NetworkString *done = getNetworkString(1);
done->addUInt8(LE_RACE_FINISHED_ACK); done->addUInt8(LE_RACE_FINISHED_ACK);
@ -207,14 +207,14 @@ void ClientLobbyRoomProtocol::doneWithResults()
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
bool ClientLobbyRoomProtocol::notifyEvent(Event* event) bool ClientLobby::notifyEvent(Event* event)
{ {
assert(m_game_setup); // assert that the setup exists assert(m_game_setup); // assert that the setup exists
NetworkString &data = event->data(); NetworkString &data = event->data();
assert(data.size()); // assert that data isn't empty assert(data.size()); // assert that data isn't empty
uint8_t message_type = data.getUInt8(); uint8_t message_type = data.getUInt8();
Log::info("ClientLobbyRoomProtocol", "Synchronous message of type %d", Log::info("ClientLobby", "Synchronous message of type %d",
message_type); message_type);
switch(message_type) switch(message_type)
{ {
@ -231,7 +231,7 @@ bool ClientLobbyRoomProtocol::notifyEvent(Event* event)
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
bool ClientLobbyRoomProtocol::notifyEventAsynchronous(Event* event) bool ClientLobby::notifyEventAsynchronous(Event* event)
{ {
assert(m_game_setup); // assert that the setup exists assert(m_game_setup); // assert that the setup exists
if (event->getType() == EVENT_TYPE_MESSAGE) if (event->getType() == EVENT_TYPE_MESSAGE)
@ -240,7 +240,7 @@ bool ClientLobbyRoomProtocol::notifyEventAsynchronous(Event* event)
assert(data.size()); // assert that data isn't empty assert(data.size()); // assert that data isn't empty
uint8_t message_type = data.getUInt8(); uint8_t message_type = data.getUInt8();
Log::info("ClientLobbyRoomProtocol", "Asynchronous message of type %d", Log::info("ClientLobby", "Asynchronous message of type %d",
message_type); message_type);
switch(message_type) switch(message_type)
{ {
@ -277,7 +277,7 @@ bool ClientLobbyRoomProtocol::notifyEventAsynchronous(Event* event)
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void ClientLobbyRoomProtocol::update(float dt) void ClientLobby::update(float dt)
{ {
switch (m_state) switch (m_state)
{ {
@ -346,7 +346,7 @@ void ClientLobbyRoomProtocol::update(float dt)
* Data | player_id | hostid | player name | * Data | player_id | hostid | player name |
* ------------------------------------- * -------------------------------------
*/ */
void ClientLobbyRoomProtocol::newPlayer(Event* event) void ClientLobby::newPlayer(Event* event)
{ {
if (!checkDataSize(event, 2)) return; if (!checkDataSize(event, 2)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -358,13 +358,13 @@ void ClientLobbyRoomProtocol::newPlayer(Event* event)
// FIXME need adjusting when splitscreen is used/ // FIXME need adjusting when splitscreen is used/
if(STKHost::get()->getGameSetup()->isLocalMaster(player_id)) if(STKHost::get()->getGameSetup()->isLocalMaster(player_id))
{ {
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"The server notified me that I'm a new player in the " "The server notified me that I'm a new player in the "
"room (not normal)."); "room (not normal).");
} }
else if (m_game_setup->getProfile(player_id) == NULL) else if (m_game_setup->getProfile(player_id) == NULL)
{ {
Log::verbose("ClientLobbyRoomProtocol", "New player connected."); Log::verbose("ClientLobby", "New player connected.");
NetworkPlayerProfile* profile = NetworkPlayerProfile* profile =
new NetworkPlayerProfile(name, player_id, host_id); new NetworkPlayerProfile(name, player_id, host_id);
m_game_setup->addPlayer(profile); m_game_setup->addPlayer(profile);
@ -372,7 +372,7 @@ void ClientLobbyRoomProtocol::newPlayer(Event* event)
} }
else else
{ {
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"One of the player notified in the list is myself."); "One of the player notified in the list is myself.");
} }
} // newPlayer } // newPlayer
@ -389,7 +389,7 @@ void ClientLobbyRoomProtocol::newPlayer(Event* event)
* Data | player id *| * Data | player id *|
* -------------- * --------------
*/ */
void ClientLobbyRoomProtocol::disconnectedPlayer(Event* event) void ClientLobby::disconnectedPlayer(Event* event)
{ {
if (!checkDataSize(event, 1)) return; if (!checkDataSize(event, 1)) return;
@ -400,13 +400,13 @@ void ClientLobbyRoomProtocol::disconnectedPlayer(Event* event)
m_game_setup->getProfile(data.getUInt8()); m_game_setup->getProfile(data.getUInt8());
if (m_game_setup->removePlayer(profile)) if (m_game_setup->removePlayer(profile))
{ {
Log::info("ClientLobbyRoomProtocol", Log::info("ClientLobby",
"Player %d removed successfully.", "Player %d removed successfully.",
profile->getGlobalPlayerId()); profile->getGlobalPlayerId());
} }
else else
{ {
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"The disconnected peer wasn't known."); "The disconnected peer wasn't known.");
} }
} // while } // while
@ -426,7 +426,7 @@ void ClientLobbyRoomProtocol::disconnectedPlayer(Event* event)
* Data | player_id| hostid | authorised |playernames* | * Data | player_id| hostid | authorised |playernames* |
* --------------------------------------------------------- * ---------------------------------------------------------
*/ */
void ClientLobbyRoomProtocol::connectionAccepted(Event* event) void ClientLobby::connectionAccepted(Event* event)
{ {
// At least 3 bytes should remain now // At least 3 bytes should remain now
if(!checkDataSize(event, 3)) return; if(!checkDataSize(event, 3)) return;
@ -436,7 +436,7 @@ void ClientLobbyRoomProtocol::connectionAccepted(Event* event)
// Accepted // Accepted
// ======== // ========
Log::info("ClientLobbyRoomProtocol", Log::info("ClientLobby",
"The server accepted the connection."); "The server accepted the connection.");
// self profile // self profile
@ -498,7 +498,7 @@ void ClientLobbyRoomProtocol::connectionAccepted(Event* event)
* Data | refusal code | * Data | refusal code |
* ---------------- * ----------------
*/ */
void ClientLobbyRoomProtocol::connectionRefused(Event* event) void ClientLobby::connectionRefused(Event* event)
{ {
if (!checkDataSize(event, 1)) return; if (!checkDataSize(event, 1)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -506,17 +506,17 @@ void ClientLobbyRoomProtocol::connectionRefused(Event* event)
switch (data.getUInt8()) // the second byte switch (data.getUInt8()) // the second byte
{ {
case 0: case 0:
Log::info("ClientLobbyRoomProtocol", Log::info("ClientLobby",
"Connection refused : too many players."); "Connection refused : too many players.");
break; break;
case 1: case 1:
Log::info("ClientLobbyRoomProtocol", "Connection refused : banned."); Log::info("ClientLobby", "Connection refused : banned.");
break; break;
case 2: case 2:
Log::info("ClientLobbyRoomProtocol", "Client busy."); Log::info("ClientLobby", "Client busy.");
break; break;
default: default:
Log::info("ClientLobbyRoomProtocol", "Connection refused."); Log::info("ClientLobby", "Connection refused.");
break; break;
} }
} // connectionRefused } // connectionRefused
@ -533,7 +533,7 @@ void ClientLobbyRoomProtocol::connectionRefused(Event* event)
* Data | refusal code | * Data | refusal code |
* ---------------- * ----------------
*/ */
void ClientLobbyRoomProtocol::kartSelectionRefused(Event* event) void ClientLobby::kartSelectionRefused(Event* event)
{ {
if(!checkDataSize(event, 1)) return; if(!checkDataSize(event, 1)) return;
@ -542,15 +542,15 @@ void ClientLobbyRoomProtocol::kartSelectionRefused(Event* event)
switch (data.getUInt8()) // the error code switch (data.getUInt8()) // the error code
{ {
case 0: case 0:
Log::info("ClientLobbyRoomProtocol", Log::info("ClientLobby",
"Kart selection refused : already taken."); "Kart selection refused : already taken.");
break; break;
case 1: case 1:
Log::info("ClientLobbyRoomProtocol", Log::info("ClientLobby",
"Kart selection refused : not available."); "Kart selection refused : not available.");
break; break;
default: default:
Log::info("ClientLobbyRoomProtocol", "Kart selection refused."); Log::info("ClientLobby", "Kart selection refused.");
break; break;
} }
} // kartSelectionRefused } // kartSelectionRefused
@ -567,7 +567,7 @@ void ClientLobbyRoomProtocol::kartSelectionRefused(Event* event)
* Data | player id | N (kart name size) | kart name | * Data | player id | N (kart name size) | kart name |
* -------------------------------------------------- * --------------------------------------------------
*/ */
void ClientLobbyRoomProtocol::kartSelectionUpdate(Event* event) void ClientLobby::kartSelectionUpdate(Event* event)
{ {
if(!checkDataSize(event, 3)) return; if(!checkDataSize(event, 3)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -576,7 +576,7 @@ void ClientLobbyRoomProtocol::kartSelectionUpdate(Event* event)
data.decodeString(&kart_name); data.decodeString(&kart_name);
if (!m_game_setup->isKartAvailable(kart_name)) if (!m_game_setup->isKartAvailable(kart_name))
{ {
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"The updated kart is taken already."); "The updated kart is taken already.");
} }
m_game_setup->setPlayerKart(player_id, kart_name); m_game_setup->setPlayerKart(player_id, kart_name);
@ -591,11 +591,11 @@ race needs to be started.
* \param event : Event providing the information (no additional information * \param event : Event providing the information (no additional information
* in this case). * in this case).
*/ */
void ClientLobbyRoomProtocol::startGame(Event* event) void ClientLobby::startGame(Event* event)
{ {
m_state = PLAYING; m_state = PLAYING;
World::getWorld()->setReadyToRace(); World::getWorld()->setReadyToRace();
Log::info("ClientLobbyRoomProtocol", "Starting new game"); Log::info("ClientLobby", "Starting new game");
} // startGame } // startGame
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
@ -604,10 +604,10 @@ void ClientLobbyRoomProtocol::startGame(Event* event)
* \param event : Event providing the information (no additional information * \param event : Event providing the information (no additional information
* in this case). * in this case).
*/ */
void ClientLobbyRoomProtocol::startSelection(Event* event) void ClientLobby::startSelection(Event* event)
{ {
m_state = KART_SELECTION; m_state = KART_SELECTION;
Log::info("ClientLobbyRoomProtocol", "Kart selection starts now"); Log::info("ClientLobby", "Kart selection starts now");
} // startSelection } // startSelection
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
@ -622,12 +622,12 @@ void ClientLobbyRoomProtocol::startSelection(Event* event)
* Data | Kart 1 ID | kart id 2 | ... | * Data | Kart 1 ID | kart id 2 | ... |
* ------------------------------- * -------------------------------
*/ */
void ClientLobbyRoomProtocol::raceFinished(Event* event) void ClientLobby::raceFinished(Event* event)
{ {
if(!checkDataSize(event, 1)) return; if(!checkDataSize(event, 1)) return;
NetworkString &data = event->data(); NetworkString &data = event->data();
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"Server notified that the race is finished."); "Server notified that the race is finished.");
// stop race protocols // stop race protocols
@ -636,7 +636,7 @@ void ClientLobbyRoomProtocol::raceFinished(Event* event)
if (protocol) if (protocol)
ProtocolManager::getInstance()->requestTerminate(protocol); ProtocolManager::getInstance()->requestTerminate(protocol);
else else
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"No controller events protocol registered."); "No controller events protocol registered.");
protocol = ProtocolManager::getInstance() protocol = ProtocolManager::getInstance()
@ -644,7 +644,7 @@ void ClientLobbyRoomProtocol::raceFinished(Event* event)
if (protocol) if (protocol)
ProtocolManager::getInstance()->requestTerminate(protocol); ProtocolManager::getInstance()->requestTerminate(protocol);
else else
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"No kart update protocol registered."); "No kart update protocol registered.");
protocol = ProtocolManager::getInstance() protocol = ProtocolManager::getInstance()
@ -652,7 +652,7 @@ void ClientLobbyRoomProtocol::raceFinished(Event* event)
if (protocol) if (protocol)
ProtocolManager::getInstance()->requestTerminate(protocol); ProtocolManager::getInstance()->requestTerminate(protocol);
else else
Log::error("ClientLobbyRoomProtocol", Log::error("ClientLobby",
"No game events protocol registered."); "No game events protocol registered.");
// finish the race // finish the race
@ -664,7 +664,7 @@ void ClientLobbyRoomProtocol::raceFinished(Event* event)
{ {
uint8_t kart_id = data.getUInt8(); uint8_t kart_id = data.getUInt8();
ranked_world->setKartPosition(kart_id,position); ranked_world->setKartPosition(kart_id,position);
Log::info("ClientLobbyRoomProtocol", "Kart %d has finished #%d", Log::info("ClientLobby", "Kart %d has finished #%d",
kart_id, position); kart_id, position);
position++; position++;
} }
@ -677,7 +677,7 @@ void ClientLobbyRoomProtocol::raceFinished(Event* event)
/** Called when the server informs the clients to exit the race result screen. /** Called when the server informs the clients to exit the race result screen.
* It exits the race, and goes back to the lobby. * It exits the race, and goes back to the lobby.
*/ */
void ClientLobbyRoomProtocol::exitResultScreen(Event *event) void ClientLobby::exitResultScreen(Event *event)
{ {
RaceResultGUI::getInstance()->backToLobby(); RaceResultGUI::getInstance()->backToLobby();
} // exitResultScreen } // exitResultScreen
@ -693,7 +693,7 @@ void ClientLobbyRoomProtocol::exitResultScreen(Event *event)
* Data |player id | major mode vote | * Data |player id | major mode vote |
* ------------------------------ * ------------------------------
*/ */
void ClientLobbyRoomProtocol::playerMajorVote(Event* event) void ClientLobby::playerMajorVote(Event* event)
{ {
const NetworkString &data = event->data(); const NetworkString &data = event->data();
if (!checkDataSize(event, 2)) if (!checkDataSize(event, 2))
@ -714,7 +714,7 @@ void ClientLobbyRoomProtocol::playerMajorVote(Event* event)
* Data | player id | races count | * Data | player id | races count |
* --------------------------- * ---------------------------
*/ */
void ClientLobbyRoomProtocol::playerRaceCountVote(Event* event) void ClientLobby::playerRaceCountVote(Event* event)
{ {
if (!checkDataSize(event, 2)) return; if (!checkDataSize(event, 2)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -734,7 +734,7 @@ void ClientLobbyRoomProtocol::playerRaceCountVote(Event* event)
* Data | player id | minor mode vote | * Data | player id | minor mode vote |
* ------------------------------- * -------------------------------
*/ */
void ClientLobbyRoomProtocol::playerMinorVote(Event* event) void ClientLobby::playerMinorVote(Event* event)
{ {
if (!checkDataSize(event, 2)) return; if (!checkDataSize(event, 2)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -755,7 +755,7 @@ void ClientLobbyRoomProtocol::playerMinorVote(Event* event)
* Data | player id | track number (gp) | N | track name | * Data | player id | track number (gp) | N | track name |
* -------------------------------------------------- * --------------------------------------------------
*/ */
void ClientLobbyRoomProtocol::playerTrackVote(Event* event) void ClientLobby::playerTrackVote(Event* event)
{ {
if (!checkDataSize(event, 3)) return; if (!checkDataSize(event, 3)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -779,7 +779,7 @@ void ClientLobbyRoomProtocol::playerTrackVote(Event* event)
* Data | player id |reversed | track number (gp) | * Data | player id |reversed | track number (gp) |
* ------------------------------------------- * -------------------------------------------
*/ */
void ClientLobbyRoomProtocol::playerReversedVote(Event* event) void ClientLobby::playerReversedVote(Event* event)
{ {
if (!checkDataSize(event, 3)) return; if (!checkDataSize(event, 3)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -802,7 +802,7 @@ void ClientLobbyRoomProtocol::playerReversedVote(Event* event)
* Data | player id | laps | track number (gp) | * Data | player id | laps | track number (gp) |
* ---------------------------------------- * ----------------------------------------
*/ */
void ClientLobbyRoomProtocol::playerLapsVote(Event* event) void ClientLobby::playerLapsVote(Event* event)
{ {
if (!checkDataSize(event, 3)) return; if (!checkDataSize(event, 3)) return;
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -817,7 +817,7 @@ void ClientLobbyRoomProtocol::playerLapsVote(Event* event)
* that the players on this host are ready to start the race. It is called by * that the players on this host are ready to start the race. It is called by
* the RaceManager after the world is loaded. * the RaceManager after the world is loaded.
*/ */
void ClientLobbyRoomProtocol::finishedLoadingWorld() void ClientLobby::finishedLoadingWorld()
{ {
assert(STKHost::get()->getPeerCount() == 1); assert(STKHost::get()->getPeerCount() == 1);
std::vector<NetworkPlayerProfile*> players = std::vector<NetworkPlayerProfile*> players =
@ -828,7 +828,7 @@ void ClientLobbyRoomProtocol::finishedLoadingWorld()
for (unsigned int i = 0; i < players.size(); i++) for (unsigned int i = 0; i < players.size(); i++)
{ {
ns->addUInt8(players[i]->getGlobalPlayerId()); ns->addUInt8(players[i]->getGlobalPlayerId());
Log::info("ClientLobbyRoomProtocol", Log::info("ClientLobby",
"Player %d ready, notifying server.", "Player %d ready, notifying server.",
players[i]->getGlobalPlayerId()); players[i]->getGlobalPlayerId());
} // for i < players.size() } // for i < players.size()

View File

@ -1,13 +1,13 @@
#ifndef CLIENT_LOBBY_ROOM_PROTOCOL_HPP #ifndef CLIENT_LOBBY_HPP
#define CLIENT_LOBBY_ROOM_PROTOCOL_HPP #define CLIENT_LOBBY_HPP
#include "network/protocols/lobby_room_protocol.hpp" #include "network/protocols/lobby_protocol.hpp"
#include "network/transport_address.hpp" #include "network/transport_address.hpp"
#include "utils/cpp2011.hpp" #include "utils/cpp2011.hpp"
class STKPeer; class STKPeer;
class ClientLobbyRoomProtocol : public LobbyRoomProtocol class ClientLobby : public LobbyRoomProtocol
{ {
private: private:
void newPlayer(Event* event); void newPlayer(Event* event);
@ -50,8 +50,8 @@ private:
STATE m_state; STATE m_state;
public: public:
ClientLobbyRoomProtocol(); ClientLobby();
virtual ~ClientLobbyRoomProtocol(); virtual ~ClientLobby();
virtual void requestKartSelection(uint8_t player_id, virtual void requestKartSelection(uint8_t player_id,
const std::string &kart_name) OVERRIDE; const std::string &kart_name) OVERRIDE;

View File

@ -26,7 +26,7 @@
#include "network/protocols/hide_public_address.hpp" #include "network/protocols/hide_public_address.hpp"
#include "network/protocols/request_connection.hpp" #include "network/protocols/request_connection.hpp"
#include "network/protocols/ping_protocol.hpp" #include "network/protocols/ping_protocol.hpp"
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "network/protocol_manager.hpp" #include "network/protocol_manager.hpp"
#include "network/servers_manager.hpp" #include "network/servers_manager.hpp"
#include "network/stk_host.hpp" #include "network/stk_host.hpp"
@ -238,8 +238,8 @@ void ConnectToServer::asynchronousUpdate()
// lobby room protocol if we're connected only // lobby room protocol if we're connected only
if(STKHost::get()->getPeers()[0]->isConnected()) if(STKHost::get()->getPeers()[0]->isConnected())
{ {
ClientLobbyRoomProtocol *p = ClientLobby *p =
LobbyRoomProtocol::create<ClientLobbyRoomProtocol>(); LobbyRoomProtocol::create<ClientLobby>();
p->setAddress(m_server_address); p->setAddress(m_server_address);
p->requestStart(); p->requestStart();
} }

View File

@ -17,7 +17,7 @@
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include "network/protocols/lobby_room_protocol.hpp" #include "network/protocols/lobby_protocol.hpp"
#include "input/input_manager.hpp" #include "input/input_manager.hpp"
#include "input/device_manager.hpp" #include "input/device_manager.hpp"

View File

@ -52,6 +52,7 @@ public:
LE_RACE_FINISHED, // race has finished, display result LE_RACE_FINISHED, // race has finished, display result
LE_RACE_FINISHED_ACK, // client went back to lobby LE_RACE_FINISHED_ACK, // client went back to lobby
LE_EXIT_RESULT, // Force clients to exit race result screen LE_EXIT_RESULT, // Force clients to exit race result screen
LE_VOTE, // Any vote (race mode, track, ...)
LE_VOTE_MAJOR, // vote of major race mode LE_VOTE_MAJOR, // vote of major race mode
LE_VOTE_MINOR, // vote for minor race mode LE_VOTE_MINOR, // vote for minor race mode
LE_VOTE_RACE_COUNT, // vote for number of tracks LE_VOTE_RACE_COUNT, // vote for number of tracks

View File

@ -16,7 +16,7 @@
// along with this program; if not, write to the Free Software // along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include "network/protocols/server_lobby_room_protocol.hpp" #include "network/protocols/server_lobby.hpp"
#include "config/player_manager.hpp" #include "config/player_manager.hpp"
#include "config/user_config.hpp" #include "config/user_config.hpp"
@ -75,21 +75,21 @@
* It starts with detecting the public ip address and port of this * It starts with detecting the public ip address and port of this
* host (GetPublicAddress). * host (GetPublicAddress).
*/ */
ServerLobbyRoomProtocol::ServerLobbyRoomProtocol() : LobbyRoomProtocol(NULL) ServerLobby::ServerLobby() : LobbyRoomProtocol(NULL)
{ {
setHandleDisconnections(true); setHandleDisconnections(true);
} // ServerLobbyRoomProtocol } // ServerLobby
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
/** Destructor. /** Destructor.
*/ */
ServerLobbyRoomProtocol::~ServerLobbyRoomProtocol() ServerLobby::~ServerLobby()
{ {
} // ~ServerLobbyRoomProtocol } // ~ServerLobby
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void ServerLobbyRoomProtocol::setup() void ServerLobby::setup()
{ {
m_game_setup = STKHost::get()->setupNewGame(); m_game_setup = STKHost::get()->setupNewGame();
m_game_setup->setNumLocalPlayers(0); // no local players on a server m_game_setup->setNumLocalPlayers(0); // no local players on a server
@ -101,7 +101,7 @@ void ServerLobbyRoomProtocol::setup()
: INIT_WAN; : INIT_WAN;
m_selection_enabled = false; m_selection_enabled = false;
m_current_protocol = NULL; m_current_protocol = NULL;
Log::info("ServerLobbyRoomProtocol", "Starting the protocol."); Log::info("ServerLobby", "Starting the protocol.");
// Initialise the data structures to detect if all clients and // Initialise the data structures to detect if all clients and
// the server are ready: // the server are ready:
@ -120,7 +120,7 @@ void ServerLobbyRoomProtocol::setup()
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
bool ServerLobbyRoomProtocol::notifyEventAsynchronous(Event* event) bool ServerLobby::notifyEventAsynchronous(Event* event)
{ {
assert(m_game_setup); // assert that the setup exists assert(m_game_setup); // assert that the setup exists
if (event->getType() == EVENT_TYPE_MESSAGE) if (event->getType() == EVENT_TYPE_MESSAGE)
@ -129,7 +129,7 @@ bool ServerLobbyRoomProtocol::notifyEventAsynchronous(Event* event)
assert(data.size()); // message not empty assert(data.size()); // message not empty
uint8_t message_type; uint8_t message_type;
message_type = data.getUInt8(); message_type = data.getUInt8();
Log::info("ServerLobbyRoomProtocol", "Message received with type %d.", Log::info("ServerLobby", "Message received with type %d.",
message_type); message_type);
switch(message_type) switch(message_type)
{ {
@ -159,7 +159,7 @@ bool ServerLobbyRoomProtocol::notifyEventAsynchronous(Event* event)
* is known, register the server and its address with the stk server so that * is known, register the server and its address with the stk server so that
* client can find it. * client can find it.
*/ */
void ServerLobbyRoomProtocol::update(float dt) void ServerLobby::update(float dt)
{ {
switch (m_state) switch (m_state)
{ {
@ -173,7 +173,7 @@ void ServerLobbyRoomProtocol::update(float dt)
break; break;
case GETTING_PUBLIC_ADDRESS: case GETTING_PUBLIC_ADDRESS:
{ {
Log::debug("ServerLobbyRoomProtocol", "Public address known."); Log::debug("ServerLobby", "Public address known.");
// Free GetPublicAddress protocol // Free GetPublicAddress protocol
delete m_current_protocol; delete m_current_protocol;
@ -181,7 +181,7 @@ void ServerLobbyRoomProtocol::update(float dt)
// this thread, but there is no need for the protocol manager // this thread, but there is no need for the protocol manager
// to react to any requests before the server is registered. // to react to any requests before the server is registered.
registerServer(); registerServer();
Log::info("ServerLobbyRoomProtocol", "Server registered."); Log::info("ServerLobby", "Server registered.");
m_state = ACCEPTING_CLIENTS; m_state = ACCEPTING_CLIENTS;
} }
break; break;
@ -262,7 +262,7 @@ void ServerLobbyRoomProtocol::update(float dt)
/** Callback when the GetPublicAddress terminates. It will unpause this /** Callback when the GetPublicAddress terminates. It will unpause this
* protocol, which triggers the next state of the finite state machine. * protocol, which triggers the next state of the finite state machine.
*/ */
void ServerLobbyRoomProtocol::callback(Protocol *protocol) void ServerLobby::callback(Protocol *protocol)
{ {
requestUnpause(); requestUnpause();
} // callback } // callback
@ -274,7 +274,7 @@ void ServerLobbyRoomProtocol::callback(Protocol *protocol)
* ProtocolManager thread). The information about this client is added * ProtocolManager thread). The information about this client is added
* to the table 'server'. * to the table 'server'.
*/ */
void ServerLobbyRoomProtocol::registerServer() void ServerLobby::registerServer()
{ {
Online::XMLRequest *request = new Online::XMLRequest(); Online::XMLRequest *request = new Online::XMLRequest();
const TransportAddress& addr = NetworkConfig::get()->getMyAddress(); const TransportAddress& addr = NetworkConfig::get()->getMyAddress();
@ -312,7 +312,7 @@ void ServerLobbyRoomProtocol::registerServer()
* are therefore ready to start the race. It signals to all clients * are therefore ready to start the race. It signals to all clients
* to start the race and then switches state to DELAY_SERVER. * to start the race and then switches state to DELAY_SERVER.
*/ */
void ServerLobbyRoomProtocol::signalRaceStartToClients() void ServerLobby::signalRaceStartToClients()
{ {
const std::vector<STKPeer*> &peers = STKHost::get()->getPeers(); const std::vector<STKPeer*> &peers = STKHost::get()->getPeers();
NetworkString *ns = getNetworkString(1); NetworkString *ns = getNetworkString(1);
@ -326,7 +326,7 @@ void ServerLobbyRoomProtocol::signalRaceStartToClients()
/** Instructs all clients to start the kart selection. If event is not NULL, /** Instructs all clients to start the kart selection. If event is not NULL,
* the command comes from a client (which needs to be authorised). * the command comes from a client (which needs to be authorised).
*/ */
void ServerLobbyRoomProtocol::startSelection(const Event *event) void ServerLobby::startSelection(const Event *event)
{ {
if(event && !event->getPeer()->isAuthorised()) if(event && !event->getPeer()->isAuthorised())
{ {
@ -352,7 +352,7 @@ void ServerLobbyRoomProtocol::startSelection(const Event *event)
/** Query the STK server for connection requests. For each connection request /** Query the STK server for connection requests. For each connection request
* start a ConnectToPeer protocol. * start a ConnectToPeer protocol.
*/ */
void ServerLobbyRoomProtocol::checkIncomingConnectionRequests() void ServerLobby::checkIncomingConnectionRequests()
{ {
// First poll every 5 seconds. Return if no polling needs to be done. // First poll every 5 seconds. Return if no polling needs to be done.
const float POLL_INTERVAL = 5.0f; const float POLL_INTERVAL = 5.0f;
@ -378,7 +378,7 @@ void ServerLobbyRoomProtocol::checkIncomingConnectionRequests()
if (!result->get("success", &success) || success != "yes") if (!result->get("success", &success) || success != "yes")
{ {
Log::error("ServerLobbyRoomProtocol", "Cannot retrieve the list."); Log::error("ServerLobby", "Cannot retrieve the list.");
return; return;
} }
@ -388,7 +388,7 @@ void ServerLobbyRoomProtocol::checkIncomingConnectionRequests()
for (unsigned int i = 0; i < users_xml->getNumNodes(); i++) for (unsigned int i = 0; i < users_xml->getNumNodes(); i++)
{ {
users_xml->getNode(i)->get("id", &id); users_xml->getNode(i)->get("id", &id);
Log::debug("ServerLobbyRoomProtocol", Log::debug("ServerLobby",
"User with id %d wants to connect.", id); "User with id %d wants to connect.", id);
Protocol *p = new ConnectToPeer(id); Protocol *p = new ConnectToPeer(id);
p->requestStart(); p->requestStart();
@ -401,7 +401,7 @@ void ServerLobbyRoomProtocol::checkIncomingConnectionRequests()
* to state RESULT_DISPLAY, during which the race result gui is shown and all * to state RESULT_DISPLAY, during which the race result gui is shown and all
* clients can click on 'continue'. * clients can click on 'continue'.
*/ */
void ServerLobbyRoomProtocol::checkRaceFinished() void ServerLobby::checkRaceFinished()
{ {
assert(RaceEventManager::getInstance()->isRunning()); assert(RaceEventManager::getInstance()->isRunning());
assert(World::getWorld()); assert(World::getWorld());
@ -439,12 +439,12 @@ void ServerLobbyRoomProtocol::checkIncomingConnectionRequests()
for (unsigned int i = 0; i < karts_results.size(); i++) for (unsigned int i = 0; i < karts_results.size(); i++)
{ {
total->addUInt8(karts_results[i]); // kart pos = i+1 total->addUInt8(karts_results[i]); // kart pos = i+1
Log::info("ServerLobbyRoomProtocol", "Kart %d finished #%d", Log::info("ServerLobby", "Kart %d finished #%d",
karts_results[i], i + 1); karts_results[i], i + 1);
} }
sendMessageToPeersChangingToken(total, /*reliable*/ true); sendMessageToPeersChangingToken(total, /*reliable*/ true);
delete total; delete total;
Log::info("ServerLobbyRoomProtocol", "End of game message sent"); Log::info("ServerLobby", "End of game message sent");
} // checkRaceFinished } // checkRaceFinished
@ -452,7 +452,7 @@ void ServerLobbyRoomProtocol::checkIncomingConnectionRequests()
/** Called when a client disconnects. /** Called when a client disconnects.
* \param event The disconnect event. * \param event The disconnect event.
*/ */
void ServerLobbyRoomProtocol::clientDisconnected(Event* event) void ServerLobby::clientDisconnected(Event* event)
{ {
std::vector<NetworkPlayerProfile*> players_on_host = std::vector<NetworkPlayerProfile*> players_on_host =
event->getPeer()->getAllPlayerProfiles(); event->getPeer()->getAllPlayerProfiles();
@ -463,7 +463,7 @@ void ServerLobbyRoomProtocol::clientDisconnected(Event* event)
for(unsigned int i=0; i<players_on_host.size(); i++) for(unsigned int i=0; i<players_on_host.size(); i++)
{ {
msg->addUInt8(players_on_host[i]->getGlobalPlayerId()); msg->addUInt8(players_on_host[i]->getGlobalPlayerId());
Log::info("ServerLobbyRoomProtocol", "Player disconnected : id %d", Log::info("ServerLobby", "Player disconnected : id %d",
players_on_host[i]->getGlobalPlayerId()); players_on_host[i]->getGlobalPlayerId());
m_game_setup->removePlayer(players_on_host[i]); m_game_setup->removePlayer(players_on_host[i]);
} }
@ -487,7 +487,7 @@ void ServerLobbyRoomProtocol::clientDisconnected(Event* event)
* Data | 4 |n| player name | * Data | 4 |n| player name |
* --------------------- * ---------------------
*/ */
void ServerLobbyRoomProtocol::connectionRequested(Event* event) void ServerLobby::connectionRequested(Event* event)
{ {
STKPeer* peer = event->getPeer(); STKPeer* peer = event->getPeer();
const NetworkString &data = event->data(); const NetworkString &data = event->data();
@ -504,7 +504,7 @@ void ServerLobbyRoomProtocol::connectionRequested(Event* event)
// send only to the peer that made the request // send only to the peer that made the request
peer->sendPacket(message); peer->sendPacket(message);
delete message; delete message;
Log::verbose("ServerLobbyRoomProtocol", "Player refused"); Log::verbose("ServerLobby", "Player refused");
return; return;
} }
@ -574,7 +574,7 @@ void ServerLobbyRoomProtocol::connectionRequested(Event* event)
m_game_setup->addPlayer(profile); m_game_setup->addPlayer(profile);
NetworkingLobby::getInstance()->addPlayer(profile); NetworkingLobby::getInstance()->addPlayer(profile);
Log::verbose("ServerLobbyRoomProtocol", "New player."); Log::verbose("ServerLobby", "New player.");
} // connectionRequested } // connectionRequested
@ -590,7 +590,7 @@ void ServerLobbyRoomProtocol::connectionRequested(Event* event)
* Data |player id | N (kart name size) | kart name | * Data |player id | N (kart name size) | kart name |
* ---------------------------------------------- * ----------------------------------------------
*/ */
void ServerLobbyRoomProtocol::kartSelectionRequested(Event* event) void ServerLobby::kartSelectionRequested(Event* event)
{ {
if(m_state!=SELECTING) if(m_state!=SELECTING)
{ {
@ -662,7 +662,7 @@ void ServerLobbyRoomProtocol::kartSelectionRequested(Event* event)
* Data | player-id | major mode vote | * Data | player-id | major mode vote |
* ------------------------------- * -------------------------------
*/ */
void ServerLobbyRoomProtocol::playerMajorVote(Event* event) void ServerLobby::playerMajorVote(Event* event)
{ {
if (!checkDataSize(event, 5)) return; if (!checkDataSize(event, 5)) return;
@ -688,7 +688,7 @@ void ServerLobbyRoomProtocol::playerMajorVote(Event* event)
* Data | player-id | races count | * Data | player-id | races count |
* --------------------------- * ---------------------------
*/ */
void ServerLobbyRoomProtocol::playerRaceCountVote(Event* event) void ServerLobby::playerRaceCountVote(Event* event)
{ {
if (!checkDataSize(event, 1)) return; if (!checkDataSize(event, 1)) return;
NetworkString &data = event->data(); NetworkString &data = event->data();
@ -715,7 +715,7 @@ void ServerLobbyRoomProtocol::playerRaceCountVote(Event* event)
* Data | player-id | minor mode vote | * Data | player-id | minor mode vote |
* ------------------------------- * -------------------------------
*/ */
void ServerLobbyRoomProtocol::playerMinorVote(Event* event) void ServerLobby::playerMinorVote(Event* event)
{ {
if (!checkDataSize(event, 1)) return; if (!checkDataSize(event, 1)) return;
NetworkString &data = event->data(); NetworkString &data = event->data();
@ -742,7 +742,7 @@ void ServerLobbyRoomProtocol::playerMinorVote(Event* event)
* Data | player id | track number (gp) | N | track name | * Data | player id | track number (gp) | N | track name |
* -------------------------------------------------- * --------------------------------------------------
*/ */
void ServerLobbyRoomProtocol::playerTrackVote(Event* event) void ServerLobby::playerTrackVote(Event* event)
{ {
if (!checkDataSize(event, 3)) return; if (!checkDataSize(event, 3)) return;
NetworkString &data = event->data(); NetworkString &data = event->data();
@ -786,7 +786,7 @@ void ServerLobbyRoomProtocol::playerTrackVote(Event* event)
* Data | player id | reversed | track number (gp) | * Data | player id | reversed | track number (gp) |
* -------------------------------------------- * --------------------------------------------
*/ */
void ServerLobbyRoomProtocol::playerReversedVote(Event* event) void ServerLobby::playerReversedVote(Event* event)
{ {
if (!checkDataSize(event, 3)) return; if (!checkDataSize(event, 3)) return;
@ -815,7 +815,7 @@ void ServerLobbyRoomProtocol::playerReversedVote(Event* event)
* Data | player id | laps | track number (gp) | * Data | player id | laps | track number (gp) |
* ---------------------------------------- * ----------------------------------------
*/ */
void ServerLobbyRoomProtocol::playerLapsVote(Event* event) void ServerLobby::playerLapsVote(Event* event)
{ {
if (!checkDataSize(event, 2)) return; if (!checkDataSize(event, 2)) return;
NetworkString &data = event->data(); NetworkString &data = event->data();
@ -835,7 +835,7 @@ void ServerLobbyRoomProtocol::playerLapsVote(Event* event)
/** Called from the RaceManager of the server when the world is loaded. Marks /** Called from the RaceManager of the server when the world is loaded. Marks
* the server to be ready to start the race. * the server to be ready to start the race.
*/ */
void ServerLobbyRoomProtocol::finishedLoadingWorld() void ServerLobby::finishedLoadingWorld()
{ {
m_server_has_loaded_world = true; m_server_has_loaded_world = true;
} // finishedLoadingWorld; } // finishedLoadingWorld;
@ -844,7 +844,7 @@ void ServerLobbyRoomProtocol::finishedLoadingWorld()
/** Called when a client notifies the server that it has loaded the world. /** Called when a client notifies the server that it has loaded the world.
* When all clients and the server are ready, the race can be started. * When all clients and the server are ready, the race can be started.
*/ */
void ServerLobbyRoomProtocol::finishedLoadingWorldClient(Event *event) void ServerLobby::finishedLoadingWorldClient(Event *event)
{ {
if (!checkDataSize(event, 1)) return; if (!checkDataSize(event, 1)) return;
@ -887,7 +887,7 @@ void ServerLobbyRoomProtocol::finishedLoadingWorldClient(Event *event)
/** Called when a client clicks on 'ok' on the race result screen. /** Called when a client clicks on 'ok' on the race result screen.
* If all players have clicked on 'ok', go back to the lobby. * If all players have clicked on 'ok', go back to the lobby.
*/ */
void ServerLobbyRoomProtocol::playerFinishedResult(Event *event) void ServerLobby::playerFinishedResult(Event *event)
{ {
m_player_ready_counter++; m_player_ready_counter++;
if(m_player_ready_counter == STKHost::get()->getPeerCount()) if(m_player_ready_counter == STKHost::get()->getPeerCount())

View File

@ -1,11 +1,11 @@
#ifndef SERVER_LOBBY_ROOM_PROTOCOL_HPP #ifndef SERVER_LOBBY_ROOM_PROTOCOL_HPP
#define SERVER_LOBBY_ROOM_PROTOCOL_HPP #define SERVER_LOBBY_ROOM_PROTOCOL_HPP
#include "network/protocols/lobby_room_protocol.hpp" #include "network/protocols/lobby_protocol.hpp"
#include "utils/cpp2011.hpp" #include "utils/cpp2011.hpp"
#include "utils/synchronised.hpp" #include "utils/synchronised.hpp"
class ServerLobbyRoomProtocol : public LobbyRoomProtocol class ServerLobby : public LobbyRoomProtocol
, public CallbackObject , public CallbackObject
{ {
private: private:
@ -70,8 +70,8 @@ private:
void registerServer(); void registerServer();
void finishedLoadingWorldClient(Event *event); void finishedLoadingWorldClient(Event *event);
public: public:
ServerLobbyRoomProtocol(); ServerLobby();
virtual ~ServerLobbyRoomProtocol(); virtual ~ServerLobby();
virtual bool notifyEventAsynchronous(Event* event) OVERRIDE; virtual bool notifyEventAsynchronous(Event* event) OVERRIDE;
virtual void setup() OVERRIDE; virtual void setup() OVERRIDE;
@ -86,6 +86,6 @@ public:
virtual void callback(Protocol *protocol) OVERRIDE; virtual void callback(Protocol *protocol) OVERRIDE;
}; // class ServerLobbyRoomProtocol }; // class ServerLobby
#endif // SERVER_LOBBY_ROOM_PROTOCOL_HPP #endif // SERVER_LOBBY_ROOM_PROTOCOL_HPP

View File

@ -126,7 +126,7 @@ bool SynchronizationProtocol::notifyEventAsynchronous(Event* event)
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
/** Waits for the countdown to be started. On the server the start of the /** Waits for the countdown to be started. On the server the start of the
* countdown is triggered by ServerLobbyRoomProtocol::finishedLoadingWorld(), * countdown is triggered by ServerLobby::finishedLoadingWorld(),
* which is called once all clients have confirmed that they are ready to * which is called once all clients have confirmed that they are ready to
* start. The server will send a ping request to each client once a second, * start. The server will send a ping request to each client once a second,
* and include the information if the countdown has started (and its current * and include the information if the countdown has started (and its current
@ -188,7 +188,7 @@ void SynchronizationProtocol::asynchronousUpdate()
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
/** Starts the countdown on this machine. On the server side this function /** Starts the countdown on this machine. On the server side this function
* is called from ServerLobbyRoomProtocol::finishedLoadingWorld() (when all * is called from ServerLobby::finishedLoadingWorld() (when all
* players have confirmed that they are ready to play). On the client side * players have confirmed that they are ready to play). On the client side
* this function is called from this protocol when a message from the server * this function is called from this protocol when a message from the server
* is received indicating that the countdown has to be started. * is received indicating that the countdown has to be started.

View File

@ -26,7 +26,7 @@
#include "network/network_string.hpp" #include "network/network_string.hpp"
#include "network/protocols/connect_to_peer.hpp" #include "network/protocols/connect_to_peer.hpp"
#include "network/protocols/connect_to_server.hpp" #include "network/protocols/connect_to_server.hpp"
#include "network/protocols/server_lobby_room_protocol.hpp" #include "network/protocols/server_lobby.hpp"
#include "network/protocol_manager.hpp" #include "network/protocol_manager.hpp"
#include "network/servers_manager.hpp" #include "network/servers_manager.hpp"
#include "network/stk_peer.hpp" #include "network/stk_peer.hpp"
@ -101,7 +101,7 @@ void STKHost::create()
* *
* Server: * Server:
* *
* 1. ServerLobbyRoomProtocol: * 1. ServerLobby:
* Spawns the following sub-protocols: * Spawns the following sub-protocols:
* 1. GetPublicAddress: Use STUN to discover the public ip address * 1. GetPublicAddress: Use STUN to discover the public ip address
* and port number of this host. * and port number of this host.
@ -141,7 +141,7 @@ void STKHost::create()
* *
* Server: * Server:
* *
* The ServerLobbyRoomProtocol (SLR) will then detect the above client * The ServerLobby (SLR) will then detect the above client
* requests, and start a ConnectToPeer protocol for each incoming client. * requests, and start a ConnectToPeer protocol for each incoming client.
* The ConnectToPeer protocol uses: * The ConnectToPeer protocol uses:
* 1. GetPeerAddress to get the ip address and port of the client. * 1. GetPeerAddress to get the ip address and port of the client.
@ -264,7 +264,7 @@ STKHost::STKHost(uint32_t server_id, uint32_t host_id)
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
/** The constructor for a server. /** The constructor for a server.
* The server control flow starts with the ServerLobbyRoomProtocol. * The server control flow starts with the ServerLobby.
*/ */
STKHost::STKHost(const irr::core::stringw &server_name) STKHost::STKHost(const irr::core::stringw &server_name)
{ {
@ -289,7 +289,7 @@ STKHost::STKHost(const irr::core::stringw &server_name)
} }
startListening(); startListening();
Protocol *p = LobbyRoomProtocol::create<ServerLobbyRoomProtocol>(); Protocol *p = LobbyRoomProtocol::create<ServerLobby>();
ProtocolManager::getInstance()->requestStart(p); ProtocolManager::getInstance()->requestStart(p);
} // STKHost(server_name) } // STKHost(server_name)

View File

@ -28,7 +28,7 @@
#include "karts/kart_properties_manager.hpp" #include "karts/kart_properties_manager.hpp"
#include "network/network_player_profile.hpp" #include "network/network_player_profile.hpp"
#include "network/protocol_manager.hpp" #include "network/protocol_manager.hpp"
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "network/stk_host.hpp" #include "network/stk_host.hpp"
#include "states_screens/server_selection.hpp" #include "states_screens/server_selection.hpp"
#include "states_screens/state_manager.hpp" #include "states_screens/state_manager.hpp"
@ -135,7 +135,7 @@ void NetworkKartSelectionScreen::playerConfirm(const int playerID)
{ {
LobbyRoomProtocol* protocol = LobbyRoomProtocol::get(); LobbyRoomProtocol* protocol = LobbyRoomProtocol::get();
ClientLobbyRoomProtocol *clrp = dynamic_cast<ClientLobbyRoomProtocol*>(protocol); ClientLobby *clrp = dynamic_cast<ClientLobby*>(protocol);
assert(clrp); assert(clrp);
// FIXME SPLITSCREEN: we need to supply the global player id of the // FIXME SPLITSCREEN: we need to supply the global player id of the
// player selecting the kart here. For now ... just vote the same kart // player selecting the kart here. For now ... just vote the same kart
@ -180,8 +180,8 @@ void NetworkKartSelectionScreen::playerSelected(uint8_t player_id,
{ {
Protocol* protocol = ProtocolManager::getInstance() Protocol* protocol = ProtocolManager::getInstance()
->getProtocol(PROTOCOL_LOBBY_ROOM); ->getProtocol(PROTOCOL_LOBBY_ROOM);
ClientLobbyRoomProtocol* clrp = ClientLobby* clrp =
dynamic_cast<ClientLobbyRoomProtocol*>(protocol); dynamic_cast<ClientLobby*>(protocol);
assert(clrp); assert(clrp);
// FIXME: for now we submit a vote from the authorised user // FIXME: for now we submit a vote from the authorised user
// for the various modes based on the settings in the race manager. // for the various modes based on the settings in the race manager.
@ -213,8 +213,8 @@ bool NetworkKartSelectionScreen::onEscapePressed()
ServerSelection::getInstance()->refresh(); ServerSelection::getInstance()->refresh();
Protocol *lobby = LobbyRoomProtocol::get(); Protocol *lobby = LobbyRoomProtocol::get();
// notify the server that we left // notify the server that we left
ClientLobbyRoomProtocol* clrp = ClientLobby* clrp =
dynamic_cast<ClientLobbyRoomProtocol*>(lobby); dynamic_cast<ClientLobby*>(lobby);
if (clrp) if (clrp)
clrp->leave(); clrp->leave();
return true; // remove the screen return true; // remove the screen

View File

@ -34,8 +34,8 @@
#include "input/input_manager.hpp" #include "input/input_manager.hpp"
#include "io/file_manager.hpp" #include "io/file_manager.hpp"
#include "network/network_player_profile.hpp" #include "network/network_player_profile.hpp"
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "network/protocols/server_lobby_room_protocol.hpp" #include "network/protocols/server_lobby.hpp"
#include "network/servers_manager.hpp" #include "network/servers_manager.hpp"
#include "network/stk_host.hpp" #include "network/stk_host.hpp"
#include "states_screens/state_manager.hpp" #include "states_screens/state_manager.hpp"
@ -163,8 +163,8 @@ void NetworkingLobby::eventCallback(Widget* widget, const std::string& name,
if(NetworkConfig::get()->isServer()) if(NetworkConfig::get()->isServer())
{ {
Protocol *p = LobbyRoomProtocol::get(); Protocol *p = LobbyRoomProtocol::get();
ServerLobbyRoomProtocol* slrp = ServerLobby* slrp =
dynamic_cast<ServerLobbyRoomProtocol*>(p); dynamic_cast<ServerLobby*>(p);
slrp->startSelection(); slrp->startSelection();
} }
else // client else // client
@ -198,8 +198,8 @@ void NetworkingLobby::tearDown()
bool NetworkingLobby::onEscapePressed() bool NetworkingLobby::onEscapePressed()
{ {
// notify the server that we left // notify the server that we left
ClientLobbyRoomProtocol* protocol = ClientLobby* protocol =
dynamic_cast<ClientLobbyRoomProtocol*>(LobbyRoomProtocol::get()); dynamic_cast<ClientLobby*>(LobbyRoomProtocol::get());
if (protocol) if (protocol)
protocol->leave(); protocol->leave();
STKHost::get()->shutdown(); STKHost::get()->shutdown();

View File

@ -45,7 +45,7 @@
#include "modes/soccer_world.hpp" #include "modes/soccer_world.hpp"
#include "modes/world_with_rank.hpp" #include "modes/world_with_rank.hpp"
#include "network/protocol_manager.hpp" #include "network/protocol_manager.hpp"
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "race/highscores.hpp" #include "race/highscores.hpp"
#include "scriptengine/property_animator.hpp" #include "scriptengine/property_animator.hpp"
#include "states_screens/feature_unlocked.hpp" #include "states_screens/feature_unlocked.hpp"
@ -342,8 +342,8 @@ void RaceResultGUI::eventCallback(GUIEngine::Widget* widget,
{ {
// Signal to the server that this client is back in the lobby now. // Signal to the server that this client is back in the lobby now.
Protocol* protocol = LobbyRoomProtocol::get(); Protocol* protocol = LobbyRoomProtocol::get();
ClientLobbyRoomProtocol* clrp = ClientLobby* clrp =
dynamic_cast<ClientLobbyRoomProtocol*>(protocol); dynamic_cast<ClientLobby*>(protocol);
if(clrp) if(clrp)
clrp->doneWithResults(); clrp->doneWithResults();
backToLobby(); backToLobby();

View File

@ -26,7 +26,7 @@
#include "guiengine/widgets/icon_button_widget.hpp" #include "guiengine/widgets/icon_button_widget.hpp"
#include "io/file_manager.hpp" #include "io/file_manager.hpp"
#include "network/network_player_profile.hpp" #include "network/network_player_profile.hpp"
#include "network/protocols/client_lobby_room_protocol.hpp" #include "network/protocols/client_lobby.hpp"
#include "network/stk_host.hpp" #include "network/stk_host.hpp"
#include "states_screens/state_manager.hpp" #include "states_screens/state_manager.hpp"
#include "states_screens/track_info_screen.hpp" #include "states_screens/track_info_screen.hpp"
@ -90,8 +90,8 @@ void TracksScreen::eventCallback(Widget* widget, const std::string& name,
if(STKHost::existHost()) if(STKHost::existHost())
{ {
Protocol* protocol = LobbyRoomProtocol::get(); Protocol* protocol = LobbyRoomProtocol::get();
ClientLobbyRoomProtocol* clrp = ClientLobby* clrp =
dynamic_cast<ClientLobbyRoomProtocol*>(protocol); dynamic_cast<ClientLobby*>(protocol);
assert(clrp); // server never shows the track screen. assert(clrp); // server never shows the track screen.
// FIXME SPLITSCREEN: we need to supply the global player id of the // FIXME SPLITSCREEN: we need to supply the global player id of the
// player selecting the track here. For now ... just vote the same // player selecting the track here. For now ... just vote the same