mirror of
git://git.savannah.nongnu.org/eliot.git
synced 2025-01-13 20:03:23 +01:00
Simplified the looging macros, and added logs in various key places.
This commit is contained in:
parent
674cd3e838
commit
0c76b9d781
30 changed files with 159 additions and 73 deletions
|
@ -23,7 +23,6 @@
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <iostream>
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <boost/format.hpp>
|
#include <boost/format.hpp>
|
||||||
#include <boost/foreach.hpp>
|
#include <boost/foreach.hpp>
|
||||||
|
@ -65,7 +64,7 @@
|
||||||
#define fmt(a) boost::format(a)
|
#define fmt(a) boost::format(a)
|
||||||
|
|
||||||
|
|
||||||
INIT_LOGGER(CompDic::logger, "Compdic");
|
INIT_LOGGER(dic, CompDic);
|
||||||
|
|
||||||
CompDic::CompDic()
|
CompDic::CompDic()
|
||||||
: m_currentRec(0), m_maxRec(0), m_loadTime(0), m_buildTime(0)
|
: m_currentRec(0), m_maxRec(0), m_loadTime(0), m_buildTime(0)
|
||||||
|
@ -186,7 +185,7 @@ void CompDic::writeNode(uint32_t *ioEdges, unsigned int num, ostream &outFile)
|
||||||
ioEdges[i] = htonl(ioEdges[i]);
|
ioEdges[i] = htonl(ioEdges[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_TRACE(logger, fmt("writing %1% edges") % num);
|
LOG_TRACE(fmt("writing %1% edges") % num);
|
||||||
outFile.write((char*)ioEdges, num * sizeof(DicEdge));
|
outFile.write((char*)ioEdges, num * sizeof(DicEdge));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ using namespace std;
|
||||||
|
|
||||||
class CompDic
|
class CompDic
|
||||||
{
|
{
|
||||||
DEFINE_LOGGER(logger);
|
DEFINE_LOGGER();
|
||||||
typedef boost::unordered_map<vector<DicEdge>, unsigned int> HashMap;
|
typedef boost::unordered_map<vector<DicEdge>, unsigned int> HashMap;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include <iostream>
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#include <cstdarg>
|
#include <cstdarg>
|
||||||
|
|
|
@ -26,25 +26,29 @@
|
||||||
#ifdef USE_LOGGING
|
#ifdef USE_LOGGING
|
||||||
# include <log4cxx/logger.h>
|
# include <log4cxx/logger.h>
|
||||||
|
|
||||||
# define DEFINE_LOGGER(logger) static log4cxx::LoggerPtr logger;
|
# define DEFINE_LOGGER() static log4cxx::LoggerPtr logger
|
||||||
# define INIT_LOGGER(logger, name) log4cxx::LoggerPtr logger(log4cxx::Logger::getLogger(name))
|
# define INIT_LOGGER(prefix, className) log4cxx::LoggerPtr className::logger(log4cxx::Logger::getLogger(#prefix "." #className))
|
||||||
|
|
||||||
# define LOG_TRACE(a, b) LOG4CXX_TRACE(a, b)
|
# define LOG_TRACE(a) LOG4CXX_TRACE(logger, a)
|
||||||
# define LOG_DEBUG(a, b) LOG4CXX_DEBUG(a, b)
|
# define LOG_DEBUG(a) LOG4CXX_DEBUG(logger, a)
|
||||||
# define LOG_INFO(a, b) LOG4CXX_INFO(a, b)
|
# define LOG_INFO(a) LOG4CXX_INFO(logger, a)
|
||||||
# define LOG_WARN(a, b) LOG4CXX_WARN(a, b)
|
# define LOG_WARN(a) LOG4CXX_WARN(logger, a)
|
||||||
# define LOG_ERROR(a, b) LOG4CXX_ERROR(a, b)
|
# define LOG_ERROR(a) LOG4CXX_ERROR(logger, a)
|
||||||
# define LOG_FATAL(a, b) LOG4CXX_FATAL(a, b)
|
# define LOG_FATAL(a) LOG4CXX_FATAL(logger, a)
|
||||||
|
# define LOG_ROOT_ERROR(a) LOG4CXX_ERROR(log4cxx::Logger::getRootLogger(), a)
|
||||||
|
# define LOG_ROOT_FATAL(a) LOG4CXX_FATAL(log4cxx::Logger::getRootLogger(), a)
|
||||||
#else
|
#else
|
||||||
# define DEFINE_LOGGER(logger)
|
# define DEFINE_LOGGER()
|
||||||
# define INIT_LOGGER(logger, name)
|
# define INIT_LOGGER(prefix, name)
|
||||||
|
|
||||||
# define LOG_TRACE(a, b)
|
# define LOG_TRACE(a)
|
||||||
# define LOG_DEBUG(a, b)
|
# define LOG_DEBUG(a)
|
||||||
# define LOG_INFO(a, b)
|
# define LOG_INFO(a)
|
||||||
# define LOG_WARN(a, b)
|
# define LOG_WARN(a)
|
||||||
# define LOG_ERROR(a, b)
|
# define LOG_ERROR(a)
|
||||||
# define LOG_FATAL(a, b)
|
# define LOG_FATAL(a)
|
||||||
|
# define LOG_ROOT_ERROR(a)
|
||||||
|
# define LOG_ROOT_FATAL(a)
|
||||||
#endif // USE_LOGGING
|
#endif // USE_LOGGING
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -19,9 +19,10 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#include "dic.h"
|
#include <cwctype> // For towupper
|
||||||
|
|
||||||
#include "board_search.h"
|
#include "board_search.h"
|
||||||
|
#include "dic.h"
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "tile.h"
|
#include "tile.h"
|
||||||
#include "rack.h"
|
#include "rack.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "matrix.h"
|
#include "matrix.h"
|
||||||
|
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
|
class Tile;
|
||||||
class Rack;
|
class Rack;
|
||||||
class Results;
|
class Results;
|
||||||
class Round;
|
class Round;
|
||||||
|
|
|
@ -45,9 +45,13 @@
|
||||||
#include "mark_played_cmd.h"
|
#include "mark_played_cmd.h"
|
||||||
#include "ai_player.h"
|
#include "ai_player.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
|
#include "encoding.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
|
|
||||||
|
INIT_LOGGER(game, Duplicate);
|
||||||
|
|
||||||
|
|
||||||
Duplicate::Duplicate(const Dictionary &iDic)
|
Duplicate::Duplicate(const Dictionary &iDic)
|
||||||
: Game(iDic)
|
: Game(iDic)
|
||||||
{
|
{
|
||||||
|
@ -177,6 +181,7 @@ void Duplicate::tryEndTurn()
|
||||||
|
|
||||||
void Duplicate::recordPlayerMove(const Move &iMove, Player &ioPlayer, bool isForHuman)
|
void Duplicate::recordPlayerMove(const Move &iMove, Player &ioPlayer, bool isForHuman)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Player " << ioPlayer.getId() << " plays: " << convertToMb(iMove.toString()));
|
||||||
Command *pCmd = new PlayerMoveCmd(ioPlayer, iMove);
|
Command *pCmd = new PlayerMoveCmd(ioPlayer, iMove);
|
||||||
pCmd->setAutoExecution(!isForHuman);
|
pCmd->setAutoExecution(!isForHuman);
|
||||||
accessNavigation().addAndExecute(pCmd);
|
accessNavigation().addAndExecute(pCmd);
|
||||||
|
@ -278,6 +283,7 @@ void Duplicate::endTurn()
|
||||||
|
|
||||||
void Duplicate::endGame()
|
void Duplicate::endGame()
|
||||||
{
|
{
|
||||||
|
LOG_INFO("End of the game");
|
||||||
m_finished = true;
|
m_finished = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
#include "game.h"
|
#include "game.h"
|
||||||
#include "command.h"
|
#include "command.h"
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
class Player;
|
class Player;
|
||||||
|
|
||||||
|
@ -53,6 +54,7 @@ using std::wstring;
|
||||||
*/
|
*/
|
||||||
class Duplicate: public Game
|
class Duplicate: public Game
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
friend class GameFactory;
|
friend class GameFactory;
|
||||||
friend class MarkPlayedCmd;
|
friend class MarkPlayedCmd;
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -40,9 +40,12 @@
|
||||||
#include "ai_player.h"
|
#include "ai_player.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
#include "turn.h"
|
#include "turn.h"
|
||||||
|
#include "encoding.h"
|
||||||
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
|
INIT_LOGGER(game, FreeGame);
|
||||||
|
|
||||||
|
|
||||||
FreeGame::FreeGame(const Dictionary &iDic)
|
FreeGame::FreeGame(const Dictionary &iDic)
|
||||||
: Game(iDic)
|
: Game(iDic)
|
||||||
|
@ -113,6 +116,7 @@ void FreeGame::playAI(unsigned int p)
|
||||||
void FreeGame::recordPlayerMove(const Move &iMove, Player &ioPlayer,
|
void FreeGame::recordPlayerMove(const Move &iMove, Player &ioPlayer,
|
||||||
bool isForHuman)
|
bool isForHuman)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Player " << ioPlayer.getId() << " plays: " << convertToMb(iMove.toString()));
|
||||||
Command *pCmd = new PlayerMoveCmd(ioPlayer, iMove);
|
Command *pCmd = new PlayerMoveCmd(ioPlayer, iMove);
|
||||||
pCmd->setAutoExecution(!isForHuman);
|
pCmd->setAutoExecution(!isForHuman);
|
||||||
accessNavigation().addAndExecute(pCmd);
|
accessNavigation().addAndExecute(pCmd);
|
||||||
|
@ -189,6 +193,8 @@ int FreeGame::endTurn()
|
||||||
// Adjust the scores of the players with the points of the remaining tiles
|
// Adjust the scores of the players with the points of the remaining tiles
|
||||||
void FreeGame::endGame()
|
void FreeGame::endGame()
|
||||||
{
|
{
|
||||||
|
LOG_INFO("End of the game");
|
||||||
|
|
||||||
vector<Tile> tiles;
|
vector<Tile> tiles;
|
||||||
|
|
||||||
// TODO: According to the rules of the game in the ODS, a game can end in 3
|
// TODO: According to the rules of the game in the ODS, a game can end in 3
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#define FREEGAME_H_
|
#define FREEGAME_H_
|
||||||
|
|
||||||
#include "game.h"
|
#include "game.h"
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
class Player;
|
class Player;
|
||||||
|
|
||||||
|
@ -42,6 +43,7 @@ using std::vector;
|
||||||
*/
|
*/
|
||||||
class FreeGame: public Game
|
class FreeGame: public Game
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
friend class GameFactory;
|
friend class GameFactory;
|
||||||
public:
|
public:
|
||||||
virtual GameMode getMode() const { return kFREEGAME; }
|
virtual GameMode getMode() const { return kFREEGAME; }
|
||||||
|
|
|
@ -46,6 +46,8 @@
|
||||||
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
|
INIT_LOGGER(game, Game);
|
||||||
|
|
||||||
const unsigned int Game::RACK_SIZE = 7;
|
const unsigned int Game::RACK_SIZE = 7;
|
||||||
const int Game::BONUS_POINTS = 50;
|
const int Game::BONUS_POINTS = 50;
|
||||||
|
|
||||||
|
@ -77,6 +79,7 @@ const Player& Game::getPlayer(unsigned int iNum) const
|
||||||
|
|
||||||
void Game::shuffleRack()
|
void Game::shuffleRack()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Shuffling rack for player " << currPlayer());
|
||||||
PlayedRack pld = getCurrentPlayer().getCurrentRack();
|
PlayedRack pld = getCurrentPlayer().getCurrentRack();
|
||||||
pld.shuffle();
|
pld.shuffle();
|
||||||
m_players[currPlayer()]->setCurrentRack(pld);
|
m_players[currPlayer()]->setCurrentRack(pld);
|
||||||
|
@ -340,11 +343,10 @@ PlayedRack Game::helperSetRackRandom(const PlayedRack &iPld,
|
||||||
|
|
||||||
// Get the best word
|
// Get the best word
|
||||||
const Round & bestRound = res.get(0);
|
const Round & bestRound = res.get(0);
|
||||||
#ifdef DEBUG
|
LOG_DEBUG("helperSetRackRandom(): initial rack: "
|
||||||
cout << "helperSetRackRandom(): initial rack: "
|
<< convertToMb(pld.toString()) << " (best word: "
|
||||||
<< convertToMb(pld.toString()) << " (best word: "
|
<< convertToMb(bestRound.getWord()) << ")");
|
||||||
<< convertToMb(bestRound.getWord()) << ")" << endl;
|
|
||||||
#endif
|
|
||||||
// Identify the joker
|
// Identify the joker
|
||||||
for (unsigned int i = 0; i < bestRound.getWordLen(); ++i)
|
for (unsigned int i = 0; i < bestRound.getWordLen(); ++i)
|
||||||
{
|
{
|
||||||
|
@ -352,10 +354,9 @@ PlayedRack Game::helperSetRackRandom(const PlayedRack &iPld,
|
||||||
{
|
{
|
||||||
const Tile &jokerTile = bestRound.getTile(i);
|
const Tile &jokerTile = bestRound.getTile(i);
|
||||||
Tile replacingTile(towupper(jokerTile.toChar()));
|
Tile replacingTile(towupper(jokerTile.toChar()));
|
||||||
#ifdef DEBUG
|
LOG_DEBUG("helperSetRackRandom(): replacing Joker with "
|
||||||
cout << "helperSetRackRandom(): replacing Joker with "
|
<< convertToMb(replacingTile.toChar()));
|
||||||
<< convertToMb(replacingTile.toChar()) << endl;
|
|
||||||
#endif
|
|
||||||
// If the bag does not contain this letter anymore,
|
// If the bag does not contain this letter anymore,
|
||||||
// simply keep the joker in the rack.
|
// simply keep the joker in the rack.
|
||||||
if (bag.in(replacingTile))
|
if (bag.in(replacingTile))
|
||||||
|
@ -457,6 +458,10 @@ void Game::addPlayer(Player *iPlayer)
|
||||||
// The ID of the player is its position in the m_players vector
|
// The ID of the player is its position in the m_players vector
|
||||||
iPlayer->setId(getNPlayers());
|
iPlayer->setId(getNPlayers());
|
||||||
m_players.push_back(iPlayer);
|
m_players.push_back(iPlayer);
|
||||||
|
|
||||||
|
LOG_INFO("Adding player '" << convertToMb(iPlayer->getName())
|
||||||
|
<< "' (" << (iPlayer->isHuman() ? "human" : "AI") << ")"
|
||||||
|
<< " with ID " << iPlayer->getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <iostream>
|
#include "logging.h"
|
||||||
#include "bag.h"
|
#include "bag.h"
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "history.h"
|
#include "history.h"
|
||||||
|
@ -48,6 +48,7 @@ using namespace std;
|
||||||
*/
|
*/
|
||||||
class Game
|
class Game
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
public:
|
public:
|
||||||
/// Game specs.
|
/// Game specs.
|
||||||
static const unsigned int RACK_SIZE;
|
static const unsigned int RACK_SIZE;
|
||||||
|
|
|
@ -45,6 +45,8 @@
|
||||||
#include "xml_reader.h"
|
#include "xml_reader.h"
|
||||||
|
|
||||||
|
|
||||||
|
INIT_LOGGER(game, GameFactory);
|
||||||
|
|
||||||
GameFactory *GameFactory::m_factory = NULL;
|
GameFactory *GameFactory::m_factory = NULL;
|
||||||
|
|
||||||
|
|
||||||
|
@ -76,6 +78,7 @@ void GameFactory::Destroy()
|
||||||
|
|
||||||
Training *GameFactory::createTraining(const Dictionary &iDic)
|
Training *GameFactory::createTraining(const Dictionary &iDic)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Creating a training game");
|
||||||
Training *game = new Training(iDic);
|
Training *game = new Training(iDic);
|
||||||
return game;
|
return game;
|
||||||
}
|
}
|
||||||
|
@ -83,6 +86,7 @@ Training *GameFactory::createTraining(const Dictionary &iDic)
|
||||||
|
|
||||||
FreeGame *GameFactory::createFreeGame(const Dictionary &iDic)
|
FreeGame *GameFactory::createFreeGame(const Dictionary &iDic)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Creating a free game");
|
||||||
FreeGame *game = new FreeGame(iDic);
|
FreeGame *game = new FreeGame(iDic);
|
||||||
return game;
|
return game;
|
||||||
}
|
}
|
||||||
|
@ -90,6 +94,7 @@ FreeGame *GameFactory::createFreeGame(const Dictionary &iDic)
|
||||||
|
|
||||||
Duplicate *GameFactory::createDuplicate(const Dictionary &iDic)
|
Duplicate *GameFactory::createDuplicate(const Dictionary &iDic)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Creating a duplicate game");
|
||||||
Duplicate *game = new Duplicate(iDic);
|
Duplicate *game = new Duplicate(iDic);
|
||||||
return game;
|
return game;
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
using std::string;
|
using std::string;
|
||||||
using std::wstring;
|
using std::wstring;
|
||||||
|
@ -44,6 +45,7 @@ class Duplicate;
|
||||||
*/
|
*/
|
||||||
class GameFactory
|
class GameFactory
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
public:
|
public:
|
||||||
static GameFactory *Instance();
|
static GameFactory *Instance();
|
||||||
static void Destroy();
|
static void Destroy();
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <cstdlib> // For atoi
|
#include <cstdlib> // For atoi
|
||||||
|
#include <cwctype> // For iswlower
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
|
|
||||||
#include "dic.h"
|
#include "dic.h"
|
||||||
|
|
|
@ -28,6 +28,8 @@
|
||||||
#include "encoding.h"
|
#include "encoding.h"
|
||||||
|
|
||||||
|
|
||||||
|
INIT_LOGGER(game, Navigation);
|
||||||
|
|
||||||
Navigation::Navigation()
|
Navigation::Navigation()
|
||||||
: m_currTurn(0)
|
: m_currTurn(0)
|
||||||
{
|
{
|
||||||
|
@ -46,6 +48,7 @@ Navigation::~Navigation()
|
||||||
|
|
||||||
void Navigation::newTurn()
|
void Navigation::newTurn()
|
||||||
{
|
{
|
||||||
|
LOG_INFO("New turn");
|
||||||
lastTurn();
|
lastTurn();
|
||||||
m_turnCommands.push_back(new TurnCmd);
|
m_turnCommands.push_back(new TurnCmd);
|
||||||
++m_currTurn;
|
++m_currTurn;
|
||||||
|
@ -98,6 +101,7 @@ void Navigation::prevTurn()
|
||||||
{
|
{
|
||||||
if (m_currTurn > 1)
|
if (m_currTurn > 1)
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Navigating to the previous turn");
|
||||||
--m_currTurn;
|
--m_currTurn;
|
||||||
m_turnCommands[m_currTurn]->undo();
|
m_turnCommands[m_currTurn]->undo();
|
||||||
// Special case: when the last turn is empty, automatically
|
// Special case: when the last turn is empty, automatically
|
||||||
|
@ -115,6 +119,7 @@ void Navigation::nextTurn()
|
||||||
{
|
{
|
||||||
if (m_currTurn < m_turnCommands.size())
|
if (m_currTurn < m_turnCommands.size())
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Navigating to the next turn");
|
||||||
m_turnCommands[m_currTurn]->execute();
|
m_turnCommands[m_currTurn]->execute();
|
||||||
++m_currTurn;
|
++m_currTurn;
|
||||||
// Special case: when the last turn is empty, automatically
|
// Special case: when the last turn is empty, automatically
|
||||||
|
@ -130,6 +135,7 @@ void Navigation::nextTurn()
|
||||||
|
|
||||||
void Navigation::firstTurn()
|
void Navigation::firstTurn()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Navigating to the first turn");
|
||||||
while (m_currTurn > 1)
|
while (m_currTurn > 1)
|
||||||
{
|
{
|
||||||
prevTurn();
|
prevTurn();
|
||||||
|
@ -139,6 +145,7 @@ void Navigation::firstTurn()
|
||||||
|
|
||||||
void Navigation::lastTurn()
|
void Navigation::lastTurn()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Navigating to the last turn");
|
||||||
while (m_currTurn < m_turnCommands.size())
|
while (m_currTurn < m_turnCommands.size())
|
||||||
{
|
{
|
||||||
nextTurn();
|
nextTurn();
|
||||||
|
@ -148,6 +155,8 @@ void Navigation::lastTurn()
|
||||||
|
|
||||||
void Navigation::clearFuture()
|
void Navigation::clearFuture()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Erasing all the future turns");
|
||||||
|
|
||||||
// Replay the auto-execution turns
|
// Replay the auto-execution turns
|
||||||
// (i.e. turns where only the AI was involved)
|
// (i.e. turns where only the AI was involved)
|
||||||
while (!isLastTurn() && m_turnCommands[m_currTurn]->isAutoExecution())
|
while (!isLastTurn() && m_turnCommands[m_currTurn]->isAutoExecution())
|
||||||
|
@ -180,12 +189,12 @@ const vector<TurnCmd *> & Navigation::getCommands() const
|
||||||
|
|
||||||
void Navigation::print() const
|
void Navigation::print() const
|
||||||
{
|
{
|
||||||
cout << "=== Commands history ===" << endl;
|
LOG_DEBUG("=== Commands history ===");
|
||||||
cout << "Current position right after turn " << m_currTurn - 1 << endl;
|
LOG_DEBUG("Current position right after turn " << m_currTurn - 1);
|
||||||
int index = 0;
|
int index = 0;
|
||||||
BOOST_FOREACH(const Command *c, m_turnCommands)
|
BOOST_FOREACH(const Command *c, m_turnCommands)
|
||||||
{
|
{
|
||||||
cout << index << " " << convertToMb(c->toString()) << endl;
|
LOG_DEBUG(index << " " << convertToMb(c->toString()));
|
||||||
++index;
|
++index;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#define NAVIGATION_H_
|
#define NAVIGATION_H_
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
class TurnCmd;
|
class TurnCmd;
|
||||||
class Command;
|
class Command;
|
||||||
|
@ -31,6 +32,7 @@ using namespace std;
|
||||||
|
|
||||||
class Navigation
|
class Navigation
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
public:
|
public:
|
||||||
Navigation();
|
Navigation();
|
||||||
~Navigation();
|
~Navigation();
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <cwctype> // For towupper
|
||||||
|
|
||||||
#if ENABLE_NLS
|
#if ENABLE_NLS
|
||||||
# include <libintl.h>
|
# include <libintl.h>
|
||||||
|
@ -45,6 +46,9 @@
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
|
|
||||||
|
INIT_LOGGER(game, Training);
|
||||||
|
|
||||||
|
|
||||||
Training::Training(const Dictionary &iDic)
|
Training::Training(const Dictionary &iDic)
|
||||||
: Game(iDic), m_results(1000)
|
: Game(iDic), m_results(1000)
|
||||||
{
|
{
|
||||||
|
@ -105,6 +109,7 @@ int Training::play(const wstring &iCoord, const wstring &iWord)
|
||||||
|
|
||||||
void Training::recordPlayerMove(const Move &iMove, Player &ioPlayer)
|
void Training::recordPlayerMove(const Move &iMove, Player &ioPlayer)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Player " << ioPlayer.getId() << " plays: " << convertToMb(iMove.toString()));
|
||||||
// Update the rack and the score of the current player
|
// Update the rack and the score of the current player
|
||||||
// PlayerMoveCmd::execute() must be called before Game::helperPlayMove()
|
// PlayerMoveCmd::execute() must be called before Game::helperPlayMove()
|
||||||
// (called in this class in endTurn()).
|
// (called in this class in endTurn()).
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
#include "game.h"
|
#include "game.h"
|
||||||
#include "round.h"
|
#include "round.h"
|
||||||
#include "results.h"
|
#include "results.h"
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
class Player;
|
class Player;
|
||||||
|
|
||||||
|
@ -44,6 +45,7 @@ using std::wstring;
|
||||||
*/
|
*/
|
||||||
class Training: public Game
|
class Training: public Game
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
friend class GameFactory;
|
friend class GameFactory;
|
||||||
public:
|
public:
|
||||||
virtual GameMode getMode() const { return kTRAINING; }
|
virtual GameMode getMode() const { return kTRAINING; }
|
||||||
|
|
|
@ -83,10 +83,10 @@ bool TurnCmd::isAutoExecution() const
|
||||||
wstring TurnCmd::toString() const
|
wstring TurnCmd::toString() const
|
||||||
{
|
{
|
||||||
wostringstream oss;
|
wostringstream oss;
|
||||||
oss << L"TurnCmd:" << endl;
|
oss << L"TurnCmd:";
|
||||||
BOOST_FOREACH(Command *cmd, m_commands)
|
BOOST_FOREACH(Command *cmd, m_commands)
|
||||||
{
|
{
|
||||||
oss << L" " << cmd->toString() << endl;
|
oss << endl << L" " << cmd->toString();
|
||||||
}
|
}
|
||||||
return oss.str();
|
return oss.str();
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,12 +40,17 @@
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
INIT_LOGGER(game, XmlReader);
|
||||||
|
|
||||||
|
|
||||||
Game * XmlReader::read(const string &iFileName, const Dictionary &iDic)
|
Game * XmlReader::read(const string &iFileName, const Dictionary &iDic)
|
||||||
{
|
{
|
||||||
// Try to load the old format first
|
// Try to load the old format first
|
||||||
|
LOG_INFO("Parsing savegame '" << iFileName << "'");
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Trying old format");
|
||||||
FILE *fin = fopen(iFileName.c_str(), "r");
|
FILE *fin = fopen(iFileName.c_str(), "r");
|
||||||
if (fin != NULL)
|
if (fin != NULL)
|
||||||
{
|
{
|
||||||
|
@ -53,14 +58,20 @@ Game * XmlReader::read(const string &iFileName, const Dictionary &iDic)
|
||||||
fclose(fin);
|
fclose(fin);
|
||||||
|
|
||||||
if (game != NULL)
|
if (game != NULL)
|
||||||
|
{
|
||||||
|
LOG_INFO("Savegame parsed successfully");
|
||||||
return game;
|
return game;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (const GameException &e)
|
catch (const GameException &e)
|
||||||
{
|
{
|
||||||
// Ignore the exception
|
// Ignore the exception
|
||||||
|
LOG_DEBUG("This doesn't look like the old format");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LOG_DEBUG("Trying XML format");
|
||||||
|
|
||||||
ifstream is(iFileName.c_str());
|
ifstream is(iFileName.c_str());
|
||||||
if (!is.is_open())
|
if (!is.is_open())
|
||||||
throw LoadGameException("Cannot open file '" + iFileName + "'");
|
throw LoadGameException("Cannot open file '" + iFileName + "'");
|
||||||
|
@ -79,6 +90,8 @@ Game * XmlReader::read(const string &iFileName, const Dictionary &iDic)
|
||||||
Game *game = handler.getGame();
|
Game *game = handler.getGame();
|
||||||
if (game == NULL)
|
if (game == NULL)
|
||||||
throw LoadGameException(handler.errorMessage);
|
throw LoadGameException(handler.errorMessage);
|
||||||
|
|
||||||
|
LOG_INFO("Savegame parsed successfully");
|
||||||
return game;
|
return game;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -155,12 +168,8 @@ void XmlReader::startElement(const string& namespaceURI,
|
||||||
{
|
{
|
||||||
(void) namespaceURI;
|
(void) namespaceURI;
|
||||||
(void) qName;
|
(void) qName;
|
||||||
#if 0
|
LOG_DEBUG("Start Element: " << (localName.empty() ? qName : namespaceURI + ":" + localName));
|
||||||
if (!localName.empty())
|
|
||||||
std::cout << "Start Element: " << namespaceURI << ":" << localName << std::endl;
|
|
||||||
else
|
|
||||||
std::cout << "Start Element: " << qName << std::endl;
|
|
||||||
#endif
|
|
||||||
m_data.clear();
|
m_data.clear();
|
||||||
const string &tag = localName;
|
const string &tag = localName;
|
||||||
if (tag == "Player")
|
if (tag == "Player")
|
||||||
|
@ -196,9 +205,8 @@ void XmlReader::endElement(const string& namespaceURI,
|
||||||
const string&)
|
const string&)
|
||||||
{
|
{
|
||||||
(void) namespaceURI;
|
(void) namespaceURI;
|
||||||
#if 0
|
LOG_DEBUG("endElement: " << namespaceURI << ":" << localName << "(" << m_data << ")");
|
||||||
std::cout << "endElement: " << namespaceURI << ":" << localName << "(" << m_data << ")" << std::endl;
|
|
||||||
#endif
|
|
||||||
const string &tag = localName;
|
const string &tag = localName;
|
||||||
if (tag == "Mode")
|
if (tag == "Mode")
|
||||||
{
|
{
|
||||||
|
@ -276,16 +284,12 @@ void XmlReader::endElement(const string& namespaceURI,
|
||||||
throw LoadGameException("Rack invalid for the current dictionary: " + m_data);
|
throw LoadGameException("Rack invalid for the current dictionary: " + m_data);
|
||||||
}
|
}
|
||||||
pldrack.setManual(rackStr);
|
pldrack.setManual(rackStr);
|
||||||
#if 0
|
LOG_DEBUG("loaded rack: " << convertToMb(pldrack.toString()));
|
||||||
cerr << "loaded rack: " << convertToMb(pldrack.toString()) << endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
Player &p = getPlayer(m_players, m_attributes["playerid"]);
|
Player &p = getPlayer(m_players, m_attributes["playerid"]);
|
||||||
PlayerRackCmd *cmd = new PlayerRackCmd(p, pldrack);
|
PlayerRackCmd *cmd = new PlayerRackCmd(p, pldrack);
|
||||||
m_game->accessNavigation().addAndExecute(cmd);
|
m_game->accessNavigation().addAndExecute(cmd);
|
||||||
#if 0
|
LOG_DEBUG("rack: " << convertToMb(pldrack.toString()));
|
||||||
cerr << "rack: " << convertToMb(pldrack.toString()) << endl;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (tag == "PlayerMove")
|
else if (tag == "PlayerMove")
|
||||||
|
@ -310,15 +314,14 @@ void XmlReader::endElement(const string& namespaceURI,
|
||||||
void XmlReader::characters(const string& ch)
|
void XmlReader::characters(const string& ch)
|
||||||
{
|
{
|
||||||
m_data += ch;
|
m_data += ch;
|
||||||
#if 0
|
LOG_DEBUG("Characters: " << ch);
|
||||||
std::cout << "Characters: " << ch << std::endl;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void XmlReader::warning(const Arabica::SAX::SAXParseException<string>& exception)
|
void XmlReader::warning(const Arabica::SAX::SAXParseException<string>& exception)
|
||||||
{
|
{
|
||||||
errorMessage = string("warning: ") + exception.what();
|
errorMessage = string("warning: ") + exception.what();
|
||||||
|
LOG_WARN(errorMessage);
|
||||||
//throw LoadGameException(string("warning: ") + exception.what());
|
//throw LoadGameException(string("warning: ") + exception.what());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -326,6 +329,7 @@ void XmlReader::warning(const Arabica::SAX::SAXParseException<string>& exception
|
||||||
void XmlReader::error(const Arabica::SAX::SAXParseException<string>& exception)
|
void XmlReader::error(const Arabica::SAX::SAXParseException<string>& exception)
|
||||||
{
|
{
|
||||||
errorMessage = string("error: ") + exception.what();
|
errorMessage = string("error: ") + exception.what();
|
||||||
|
LOG_ERROR(errorMessage);
|
||||||
//throw LoadGameException(string("error: ") + exception.what());
|
//throw LoadGameException(string("error: ") + exception.what());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -333,6 +337,7 @@ void XmlReader::error(const Arabica::SAX::SAXParseException<string>& exception)
|
||||||
void XmlReader::fatalError(const Arabica::SAX::SAXParseException<string>& exception)
|
void XmlReader::fatalError(const Arabica::SAX::SAXParseException<string>& exception)
|
||||||
{
|
{
|
||||||
errorMessage = string("fatal error: ") + exception.what();
|
errorMessage = string("fatal error: ") + exception.what();
|
||||||
|
LOG_FATAL(errorMessage);
|
||||||
//throw LoadGameException(string("fatal error: ") + exception.what());
|
//throw LoadGameException(string("fatal error: ") + exception.what());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include <SAX/Locator.hpp>
|
#include <SAX/Locator.hpp>
|
||||||
#include <SAX/Attributes.hpp>
|
#include <SAX/Attributes.hpp>
|
||||||
#include <SAX/SAXException.hpp>
|
#include <SAX/SAXException.hpp>
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
class Game;
|
class Game;
|
||||||
|
@ -36,6 +37,7 @@ using std::map;
|
||||||
|
|
||||||
class XmlReader : public Arabica::SAX::DefaultHandler<string>
|
class XmlReader : public Arabica::SAX::DefaultHandler<string>
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
public:
|
public:
|
||||||
virtual ~XmlReader() {}
|
virtual ~XmlReader() {}
|
||||||
|
|
||||||
|
|
|
@ -39,6 +39,7 @@
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
INIT_LOGGER(game, XmlWriter);
|
||||||
|
|
||||||
static void addIndent(string &s)
|
static void addIndent(string &s)
|
||||||
{
|
{
|
||||||
|
@ -81,6 +82,7 @@ static void writeMove(ostream &out, const Move &iMove,
|
||||||
|
|
||||||
void XmlWriter::write(const Game &iGame, const string &iFileName)
|
void XmlWriter::write(const Game &iGame, const string &iFileName)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Saving game into '" << iFileName << "'");
|
||||||
ofstream out(iFileName.c_str());
|
ofstream out(iFileName.c_str());
|
||||||
if (!out.is_open())
|
if (!out.is_open())
|
||||||
throw SaveGameException("Cannot open file for writing: '" + iFileName + "'");
|
throw SaveGameException("Cannot open file for writing: '" + iFileName + "'");
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#define XML_WRITER_H_
|
#define XML_WRITER_H_
|
||||||
|
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
#include "logging.h"
|
||||||
|
|
||||||
class Game;
|
class Game;
|
||||||
|
|
||||||
|
@ -29,6 +30,7 @@ using std::string;
|
||||||
|
|
||||||
class XmlWriter
|
class XmlWriter
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
public:
|
public:
|
||||||
static void write(const Game &iGame, const string &iFileName);
|
static void write(const Game &iGame, const string &iFileName);
|
||||||
};
|
};
|
||||||
|
|
|
@ -18,8 +18,6 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
#include <QtGui/QLabel>
|
#include <QtGui/QLabel>
|
||||||
#include <QtGui/QSpinBox>
|
#include <QtGui/QSpinBox>
|
||||||
#include <QtGui/QHeaderView>
|
#include <QtGui/QHeaderView>
|
||||||
|
|
12
qt/main.cpp
12
qt/main.cpp
|
@ -22,10 +22,10 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <exception>
|
#include <exception>
|
||||||
#include <iostream>
|
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QLocale>
|
#include <QLocale>
|
||||||
#include <QTranslator>
|
#include <QTranslator>
|
||||||
|
#include "logging.h"
|
||||||
#include "base_exception.h"
|
#include "base_exception.h"
|
||||||
#include "stacktrace.h"
|
#include "stacktrace.h"
|
||||||
#include "main_window.h"
|
#include "main_window.h"
|
||||||
|
@ -63,8 +63,7 @@ public:
|
||||||
}
|
}
|
||||||
catch (const BaseException &e)
|
catch (const BaseException &e)
|
||||||
{
|
{
|
||||||
cerr << "Exception caught: " << e.what() << endl;
|
LOG_ROOT_ERROR("Exception caught: " << e.what() << "\n" << e.getStackTrace());
|
||||||
cerr << e.getStackTrace() << endl;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -86,7 +85,7 @@ int main(int argc, char **argv)
|
||||||
/* Check if $LANG is set. */
|
/* Check if $LANG is set. */
|
||||||
if (NULL == getenv("LANG"))
|
if (NULL == getenv("LANG"))
|
||||||
{
|
{
|
||||||
// Retrieve the preferred language as chosen in System Preferences.app
|
// Retrieve the preferred language as chosen in System Preferences.app
|
||||||
// (note that CFLocaleCopyCurrent() is not used because it returns the
|
// (note that CFLocaleCopyCurrent() is not used because it returns the
|
||||||
// preferred locale not language)
|
// preferred locale not language)
|
||||||
CFArrayRef all_locales = CFLocaleCopyAvailableLocaleIdentifiers();
|
CFArrayRef all_locales = CFLocaleCopyAvailableLocaleIdentifiers();
|
||||||
|
@ -166,9 +165,8 @@ int main(int argc, char **argv)
|
||||||
#ifdef HAVE_EXECINFO_H
|
#ifdef HAVE_EXECINFO_H
|
||||||
static void bt_sighandler(int signum)
|
static void bt_sighandler(int signum)
|
||||||
{
|
{
|
||||||
cerr << "Segmentation fault!" << endl;
|
LOG_ROOT_FATAL("Segmentation fault!");
|
||||||
cerr << "Backtrace:" << endl;
|
LOG_ROOT_FATAL("Backtrace:\n" << StackTrace::GetStack());
|
||||||
cerr << StackTrace::GetStack() << endl;
|
|
||||||
|
|
||||||
// Restore the default handler to generate a nice core dump
|
// Restore the default handler to generate a nice core dump
|
||||||
signal(signum, SIG_DFL);
|
signal(signum, SIG_DFL);
|
||||||
|
|
|
@ -60,6 +60,8 @@
|
||||||
#include "coord.h"
|
#include "coord.h"
|
||||||
|
|
||||||
|
|
||||||
|
INIT_LOGGER(qt, MainWindow);
|
||||||
|
|
||||||
const char *MainWindow::m_windowName = "MainWindow";
|
const char *MainWindow::m_windowName = "MainWindow";
|
||||||
|
|
||||||
MainWindow::MainWindow(QWidget *iParent)
|
MainWindow::MainWindow(QWidget *iParent)
|
||||||
|
@ -67,6 +69,7 @@ MainWindow::MainWindow(QWidget *iParent)
|
||||||
m_prefsDialog(NULL), m_bagWindow(NULL), m_boardWindow(NULL),
|
m_prefsDialog(NULL), m_bagWindow(NULL), m_boardWindow(NULL),
|
||||||
m_historyWindow(NULL), m_dicToolsWindow(NULL), m_dicNameLabel(NULL)
|
m_historyWindow(NULL), m_dicToolsWindow(NULL), m_dicNameLabel(NULL)
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Creating main window");
|
||||||
m_ui.setupUi(this);
|
m_ui.setupUi(this);
|
||||||
createMenu();
|
createMenu();
|
||||||
readSettings();
|
readSettings();
|
||||||
|
@ -79,10 +82,9 @@ MainWindow::MainWindow(QWidget *iParent)
|
||||||
// but we would lose the desktop integration...
|
// but we would lose the desktop integration...
|
||||||
unsigned int val = time(NULL);
|
unsigned int val = time(NULL);
|
||||||
srand(val);
|
srand(val);
|
||||||
#ifdef DEBUG
|
|
||||||
// Make it easier to reproduce bugs
|
// Make it easier to reproduce bugs
|
||||||
cout << "Rand seed: " << val << endl;
|
LOG_DEBUG("Rand seed: " << val);
|
||||||
#endif
|
|
||||||
|
|
||||||
QObject::connect(this, SIGNAL(gameChanged(const PublicGame*)),
|
QObject::connect(this, SIGNAL(gameChanged(const PublicGame*)),
|
||||||
this, SLOT(updateForGame(const PublicGame*)));
|
this, SLOT(updateForGame(const PublicGame*)));
|
||||||
|
@ -162,6 +164,7 @@ MainWindow::MainWindow(QWidget *iParent)
|
||||||
QString dicPath = qs.value(PrefsDialog::kINTF_DIC_PATH, "").toString();
|
QString dicPath = qs.value(PrefsDialog::kINTF_DIC_PATH, "").toString();
|
||||||
if (dicPath != "")
|
if (dicPath != "")
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Using dictionary " << qtl(dicPath));
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
m_dic = new Dictionary(qtl(dicPath));
|
m_dic = new Dictionary(qtl(dicPath));
|
||||||
|
@ -193,6 +196,8 @@ void MainWindow::destroyCurrentGame()
|
||||||
if (m_game == NULL)
|
if (m_game == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
LOG_DEBUG("Destroying current game");
|
||||||
|
|
||||||
// Some controls, like the board, can live when there is no game.
|
// Some controls, like the board, can live when there is no game.
|
||||||
// We only have to give them a NULL handler instead of the current one.
|
// We only have to give them a NULL handler instead of the current one.
|
||||||
emit gameChangedNonConst(NULL);
|
emit gameChangedNonConst(NULL);
|
||||||
|
@ -202,6 +207,8 @@ void MainWindow::destroyCurrentGame()
|
||||||
|
|
||||||
delete m_game;
|
delete m_game;
|
||||||
m_game = NULL;
|
m_game = NULL;
|
||||||
|
|
||||||
|
LOG_DEBUG("Game destroyed");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -217,8 +224,7 @@ void MainWindow::refresh()
|
||||||
m_actionHistoryLastTurn->setEnabled(!isLastTurn);
|
m_actionHistoryLastTurn->setEnabled(!isLastTurn);
|
||||||
m_actionHistoryReplayTurn->setEnabled(!isLastTurn);
|
m_actionHistoryReplayTurn->setEnabled(!isLastTurn);
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
cout << endl << endl;
|
//m_game->printTurns();
|
||||||
m_game->printTurns();
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -226,6 +232,7 @@ void MainWindow::refresh()
|
||||||
|
|
||||||
void MainWindow::prefsUpdated()
|
void MainWindow::prefsUpdated()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Preferences updated");
|
||||||
// Disconnect the training rack updates from the "Plus 1" tab of the
|
// Disconnect the training rack updates from the "Plus 1" tab of the
|
||||||
// dictionary tools
|
// dictionary tools
|
||||||
m_playersWidget->disconnect(SIGNAL(trainingRackUpdated(const QString&)));
|
m_playersWidget->disconnect(SIGNAL(trainingRackUpdated(const QString&)));
|
||||||
|
@ -295,6 +302,7 @@ void MainWindow::updateStatusBar(const Dictionary *iDic)
|
||||||
|
|
||||||
void MainWindow::displayErrorMsg(QString iMsg, QString iContext)
|
void MainWindow::displayErrorMsg(QString iMsg, QString iContext)
|
||||||
{
|
{
|
||||||
|
LOG_ERROR("Displayed error: " << qtl(iMsg));
|
||||||
if (iContext == "")
|
if (iContext == "")
|
||||||
iContext = _q("Eliot - Error");
|
iContext = _q("Eliot - Error");
|
||||||
|
|
||||||
|
@ -304,6 +312,7 @@ void MainWindow::displayErrorMsg(QString iMsg, QString iContext)
|
||||||
|
|
||||||
void MainWindow::displayInfoMsg(QString iMsg)
|
void MainWindow::displayInfoMsg(QString iMsg)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Displayed message: " << qtl(iMsg));
|
||||||
statusBar()->showMessage(iMsg);
|
statusBar()->showMessage(iMsg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,6 +373,8 @@ void MainWindow::changeDictionary(QString iFileName)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LOG_INFO("Loading new dictionary file: " << qtl(iFileName));
|
||||||
|
|
||||||
destroyCurrentGame();
|
destroyCurrentGame();
|
||||||
|
|
||||||
try
|
try
|
||||||
|
@ -437,7 +448,7 @@ void MainWindow::createMenu()
|
||||||
false, QIcon(":/images/printer.png"));
|
false, QIcon(":/images/printer.png"));
|
||||||
menuFile->addSeparator();
|
menuFile->addSeparator();
|
||||||
addMenuAction(menuFile, _q("&Quit"), _q("Ctrl+Q"),
|
addMenuAction(menuFile, _q("&Quit"), _q("Ctrl+Q"),
|
||||||
_q("Quit Eliot"), SLOT(close()),
|
_q("Quit Eliot"), SLOT(onGameQuit()),
|
||||||
false, QIcon(":/images/quit_16px.png"));
|
false, QIcon(":/images/quit_16px.png"));
|
||||||
|
|
||||||
QMenu *menuHistory = new QMenu(m_ui.menubar);
|
QMenu *menuHistory = new QMenu(m_ui.menubar);
|
||||||
|
@ -505,6 +516,8 @@ void MainWindow::createMenu()
|
||||||
|
|
||||||
void MainWindow::onGameNew()
|
void MainWindow::onGameNew()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Starting a new game (unconfirmed)");
|
||||||
|
|
||||||
if (m_dic == NULL)
|
if (m_dic == NULL)
|
||||||
{
|
{
|
||||||
displayErrorMsg(_q("You have to select a dictionary (.dawg file) "
|
displayErrorMsg(_q("You have to select a dictionary (.dawg file) "
|
||||||
|
@ -538,11 +551,11 @@ void MainWindow::onGameNew()
|
||||||
|
|
||||||
m_ui.groupBoxPlayers->show();
|
m_ui.groupBoxPlayers->show();
|
||||||
|
|
||||||
|
displayInfoMsg(_q("Game started"));
|
||||||
m_game->start();
|
m_game->start();
|
||||||
emit gameChangedNonConst(m_game);
|
emit gameChangedNonConst(m_game);
|
||||||
emit gameChanged(m_game);
|
emit gameChanged(m_game);
|
||||||
emit gameUpdated();
|
emit gameUpdated();
|
||||||
displayInfoMsg(_q("Game started"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -600,6 +613,7 @@ void MainWindow::onGameSaveAs()
|
||||||
|
|
||||||
void MainWindow::onGamePrint()
|
void MainWindow::onGamePrint()
|
||||||
{
|
{
|
||||||
|
LOG_DEBUG("Printing game (unconfirmed)");
|
||||||
if (m_game == NULL)
|
if (m_game == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -607,6 +621,8 @@ void MainWindow::onGamePrint()
|
||||||
QPrintDialog printDialog(&printer, this);
|
QPrintDialog printDialog(&printer, this);
|
||||||
if (printDialog.exec() == QDialog::Accepted)
|
if (printDialog.exec() == QDialog::Accepted)
|
||||||
{
|
{
|
||||||
|
LOG_INFO("Printing game");
|
||||||
|
|
||||||
QPainter painter(&printer);
|
QPainter painter(&printer);
|
||||||
const History &history = m_game->getHistory();
|
const History &history = m_game->getHistory();
|
||||||
|
|
||||||
|
@ -740,10 +756,19 @@ void MainWindow::onGamePrint()
|
||||||
// Total score
|
// Total score
|
||||||
nextHeight += LINE_HEIGHT;
|
nextHeight += LINE_HEIGHT;
|
||||||
painter.drawText(curWidth, nextHeight, QString("%1").arg(score));
|
painter.drawText(curWidth, nextHeight, QString("%1").arg(score));
|
||||||
|
|
||||||
|
LOG_INFO("Game printed");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MainWindow::onGameQuit()
|
||||||
|
{
|
||||||
|
LOG_INFO("Exiting");
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void MainWindow::onSettingsPreferences()
|
void MainWindow::onSettingsPreferences()
|
||||||
{
|
{
|
||||||
if (m_prefsDialog == NULL)
|
if (m_prefsDialog == NULL)
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include <QMainWindow>
|
#include <QMainWindow>
|
||||||
|
|
||||||
#include <ui/main_window.ui.h>
|
#include <ui/main_window.ui.h>
|
||||||
|
#include "logging.h"
|
||||||
#include "coord_model.h"
|
#include "coord_model.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,6 +42,7 @@ class QAction;
|
||||||
|
|
||||||
class MainWindow: public QMainWindow
|
class MainWindow: public QMainWindow
|
||||||
{
|
{
|
||||||
|
DEFINE_LOGGER();
|
||||||
Q_OBJECT;
|
Q_OBJECT;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -67,6 +69,7 @@ private slots:
|
||||||
void onGameLoad();
|
void onGameLoad();
|
||||||
void onGameSaveAs();
|
void onGameSaveAs();
|
||||||
void onGamePrint();
|
void onGamePrint();
|
||||||
|
void onGameQuit();
|
||||||
void onSettingsChooseDic();
|
void onSettingsChooseDic();
|
||||||
void onSettingsCreateDic();
|
void onSettingsCreateDic();
|
||||||
void onSettingsPreferences();
|
void onSettingsPreferences();
|
||||||
|
|
|
@ -19,8 +19,6 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
// XXX: tmp
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
#include "tile_layout.h"
|
#include "tile_layout.h"
|
||||||
#include "tile_widget.h"
|
#include "tile_widget.h"
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <cstring> // For strlen
|
#include <cstring> // For strlen
|
||||||
|
#include <cwctype> // For iswalnum
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
#include "ncurses.h"
|
#include "ncurses.h"
|
||||||
|
|
Loading…
Reference in a new issue