1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
#include "Console.h"
#include "System/Log/ILog.h"
#include "Action.h"
#include <assert.h>
void CommandReceiver::RegisterAction(const std::string& name)
{
Console::Instance().AddCommandReceiver(name, this);
}
Console& Console::Instance()
{
static Console myInstance;
return myInstance;
}
void Console::AddCommandReceiver(const std::string& name, CommandReceiver* rec)
{
if (commandMap.find(name) != commandMap.end()) {
LOG_L(L_WARNING, "Overwriting command: %s", name.c_str());
}
commandMap[name] = rec;
}
bool Console::ExecuteAction(const Action& action)
{
if (action.command == "commands")
{
LOG("Registered commands:");
std::map<const std::string, CommandReceiver*>::const_iterator cri;
for (cri = commandMap.begin(); cri != commandMap.end(); ++cri)
{
LOG("%s", cri->first.c_str());
}
return true;
}
std::map<const std::string, CommandReceiver*>::iterator cri = commandMap.find(action.command);
if (cri == commandMap.end()) {
return false;
} else {
cri->second->PushAction(action);
return true;
}
}
Console::Console()
{
}
Console::~Console()
{
}
|