extra logging; minor server crash fix

This commit is contained in:
Max-Wilhelm Bruker 2011-07-11 23:49:54 +02:00
parent c8813bb2aa
commit b38f0e2100
2 changed files with 20 additions and 19 deletions

View file

@ -56,7 +56,7 @@ Server_Game::~Server_Game()
room->removeGame(this);
delete creatorInfo;
qDebug("Server_Game destructor");
qDebug() << "Server_Game destructor: gameId=" << gameId;
}
void Server_Game::pingClockTimeout()

View file

@ -207,25 +207,26 @@ void Server_ProtocolHandler::processCommandContainer(CommandContainer *cont)
gameListMutex.lock();
GameEventContainer *gQPublic = cont->getGameEventQueuePublic();
if (gQPublic) {
Server_Game *game = games.value(gQPublic->getGameId()).first;
Server_Player *player = games.value(gQPublic->getGameId()).second;
QPair<Server_Game *, Server_Player *> gamePlayerPair = games.value(gQPublic->getGameId());
if (gamePlayerPair.first) {
GameEventContainer *gQPrivate = cont->getGameEventQueuePrivate();
GameEventContainer *gQOmniscient = cont->getGameEventQueueOmniscient();
if (gQPrivate) {
int privatePlayerId = cont->getPrivatePlayerId();
Server_Player *privatePlayer;
if (privatePlayerId == -1)
privatePlayer = player;
privatePlayer = gamePlayerPair.second;
else
privatePlayer = game->getPlayer(privatePlayerId);
privatePlayer = gamePlayerPair.first->getPlayer(privatePlayerId);
if (gQOmniscient) {
game->sendGameEventContainer(gQPublic, privatePlayer, true);
game->sendGameEventContainerOmniscient(gQOmniscient, privatePlayer);
gamePlayerPair.first->sendGameEventContainer(gQPublic, privatePlayer, true);
gamePlayerPair.first->sendGameEventContainerOmniscient(gQOmniscient, privatePlayer);
} else
game->sendGameEventContainer(gQPublic, privatePlayer);
gamePlayerPair.first->sendGameEventContainer(gQPublic, privatePlayer);
privatePlayer->sendProtocolItem(gQPrivate);
} else
game->sendGameEventContainer(gQPublic);
gamePlayerPair.first->sendGameEventContainer(gQPublic);
}
}
gameListMutex.unlock();