Simplified the looging macros, and added logs in various key places.

This commit is contained in:
Olivier Teulière 2011-01-29 23:47:20 +00:00
parent 674cd3e838
commit 0c76b9d781
30 changed files with 159 additions and 73 deletions

View file

@ -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));
} }

View file

@ -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:

View file

@ -20,7 +20,6 @@
#include "config.h" #include "config.h"
#include <iostream>
#include <sstream> #include <sstream>
#include <cstdlib> #include <cstdlib>
#include <cstdarg> #include <cstdarg>

View file

@ -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

View file

@ -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"

View file

@ -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;

View file

@ -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;
} }

View file

@ -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:

View file

@ -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

View file

@ -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; }

View file

@ -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());
} }

View file

@ -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;

View file

@ -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;
} }

View file

@ -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();

View file

@ -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"

View file

@ -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;
} }
} }

View file

@ -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();

View file

@ -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()).

View file

@ -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; }

View file

@ -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();
} }

View file

@ -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());
} }

View file

@ -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() {}

View file

@ -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 + "'");

View file

@ -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);
}; };

View file

@ -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>

View file

@ -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);

View file

@ -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)

View file

@ -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();

View file

@ -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"

View file

@ -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"