X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fcommand_client.hxx;h=49f28199d4bb489e656f393242f51b227babdc43;hp=6ec6a1d5efc8d6975476cc5320af41f003137b55;hb=56f3994d74dbc36d10bfa83b50b016bf269ac563;hpb=b2ba092858a40fc42afba6b529d5b97bcba363e2 diff --git a/src/command_client.hxx b/src/command_client.hxx index 6ec6a1d..49f2819 100644 --- a/src/command_client.hxx +++ b/src/command_client.hxx @@ -19,6 +19,9 @@ #ifndef __LIBT2N_COMMAND_CLIENT #define __LIBT2N_COMMAND_CLIENT +#include +#include + #include "client.hxx" #include "container.hxx" @@ -28,8 +31,12 @@ namespace libt2n /// a client sending out commands to a server class command_client { + public: + static const long long command_timeout_usec_default=90000000; + static const long long hello_timeout_usec_default=30000000; + private: - client_connection &c; + client_connection *c; long long hello_timeout_usec; long long command_timeout_usec; @@ -38,10 +45,31 @@ class command_client std::string read_packet(const long long &usec_timeout); bool check_hello(const std::string& hellostr); + // TODO: Deny access to copy constructor or use boost::shared_ptr + std::auto_ptr constructorException; + public: - command_client(client_connection& _c, long long _command_timeout_usec=90000000, long long _hello_timeout_usec=30000000); + command_client(client_connection* _c, + long long _command_timeout_usec=command_timeout_usec_default, + long long _hello_timeout_usec=hello_timeout_usec_default); + virtual ~command_client() {} + + void replace_connection(client_connection* _c); void send_command(command* cmd, result_container &res); + + void set_command_timeout_usec(long long _command_timeout_usec=command_timeout_usec_default) + { command_timeout_usec=_command_timeout_usec; } + void set_hello_timeout_usec(long long _hello_timeout_usec=hello_timeout_usec_default) + { hello_timeout_usec=_hello_timeout_usec; } + long long get_command_timeout_usec(void) + { return command_timeout_usec; } + long long get_hello_timeout_usec(void) + { return hello_timeout_usec; } + bool is_connection_closed(void) + { return c->is_closed(); } + t2n_exception* get_constuctor_exception(void) + { return constructorException.get(); } }; }