diff options
author | Matthias Schiffer <matthias@gamezock.de> | 2008-09-25 21:15:48 +0200 |
---|---|---|
committer | Matthias Schiffer <matthias@gamezock.de> | 2008-09-25 21:15:48 +0200 |
commit | 37b452c361d99ca809c699b6968df3723f0cadb9 (patch) | |
tree | 4c22b433a0c8876aaf7677efd44fe976ad342af8 /src/Client/CommandParser.h | |
parent | af0f84058d322d68cbbff98ef272dd2bcd0f692c (diff) | |
download | mad-37b452c361d99ca809c699b6968df3723f0cadb9.tar mad-37b452c361d99ca809c699b6968df3723f0cadb9.zip |
Teile vom CommandParser als CommandManager abgespalten
Diffstat (limited to 'src/Client/CommandParser.h')
-rw-r--r-- | src/Client/CommandParser.h | 40 |
1 files changed, 7 insertions, 33 deletions
diff --git a/src/Client/CommandParser.h b/src/Client/CommandParser.h index 9b94ef0..86be22f 100644 --- a/src/Client/CommandParser.h +++ b/src/Client/CommandParser.h @@ -20,6 +20,7 @@ #ifndef MAD_CLIENT_COMMANDPARSER_H_ #define MAD_CLIENT_COMMANDPARSER_H_ +#include "CommandManager.h" #include <Common/Request.h> #include <string> @@ -27,18 +28,8 @@ namespace Mad { -namespace Common { -class Exception; -} - namespace Net { class Connection; - -namespace Packets { -class HostStatusPacket; -class HostListPacket; -} - } namespace Client { @@ -56,20 +47,15 @@ class CommandParser { static const Command commands[]; - sigc::signal<void> finished; + CommandManager commandManager; Net::Connection *connection; - unsigned int activeRequests; - bool disconnect; - bool split(const std::string &str, std::vector<std::string> &ret); const Command* findCommand(const std::string& command); void printUsage(const std::string& command); - void printHostStatus(const Net::Packets::HostStatusPacket &packet); - void helpCommand(const std::vector<std::string> &args); void listHostsCommand(const std::vector<std::string> &args); void rebootCommand(const std::vector<std::string> &args); @@ -77,31 +63,19 @@ class CommandParser { void statusCommand(const std::vector<std::string> &args); void exitCommand(const std::vector<std::string>&); - void coreStatusRequestFinished(const Common::Request<Net::Packets::HostStatusPacket> &request); - void daemonCommandRequestFinished(const Common::Request<> &request); - void daemonListRequestFinished(const Common::Request<Net::Packets::HostListPacket> &request, bool all); - void daemonStatusRequestFinished(const Common::Request<Net::Packets::HostStatusPacket> &request); - void disconnectRequestFinished(const Common::Request<> &request); - - void requestFinished() { - activeRequests--; - - finished(); - } - public: - CommandParser(Net::Connection *connection0) : connection(connection0), activeRequests(0), disconnect(false) {} + CommandParser(Net::Connection *connection0) : connection(connection0) {} + + bool requestsActive() {return commandManager.requestsActive();} + bool willDisconnect() {return commandManager.willDisconnect();} - bool requestsActive() {return (activeRequests > 0);} - bool willDisconnect() {return disconnect;} + sigc::signal<void> signalFinished() const {return commandManager.signalFinished();} bool parse(const std::string &cmd); void requestDisconnect() { exitCommand(std::vector<std::string>()); } - - sigc::signal<void> signalFinished() const {return finished;} }; } |