From 37b452c361d99ca809c699b6968df3723f0cadb9 Mon Sep 17 00:00:00 2001 From: Matthias Schiffer Date: Thu, 25 Sep 2008 21:15:48 +0200 Subject: Teile vom CommandParser als CommandManager abgespalten --- src/Client/CommandParser.h | 40 +++++++--------------------------------- 1 file changed, 7 insertions(+), 33 deletions(-) (limited to 'src/Client/CommandParser.h') 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 #include @@ -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 finished; + CommandManager commandManager; Net::Connection *connection; - unsigned int activeRequests; - bool disconnect; - bool split(const std::string &str, std::vector &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 &args); void listHostsCommand(const std::vector &args); void rebootCommand(const std::vector &args); @@ -77,31 +63,19 @@ class CommandParser { void statusCommand(const std::vector &args); void exitCommand(const std::vector&); - void coreStatusRequestFinished(const Common::Request &request); - void daemonCommandRequestFinished(const Common::Request<> &request); - void daemonListRequestFinished(const Common::Request &request, bool all); - void daemonStatusRequestFinished(const Common::Request &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 signalFinished() const {return commandManager.signalFinished();} bool parse(const std::string &cmd); void requestDisconnect() { exitCommand(std::vector()); } - - sigc::signal signalFinished() const {return finished;} }; } -- cgit v1.2.3