X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fsocket_wrapper.hxx;h=093a8094e32d42950dfc44bc273f2b36016894a0;hp=da972a2d01c57d01553522594728ea32697de12b;hb=238ad35f4e3b6516d4ba7611b540a0edeea71427;hpb=fb3345ada7ea94225b78994fd50e3de693a2a3d5 diff --git a/src/socket_wrapper.hxx b/src/socket_wrapper.hxx index da972a2..093a809 100644 --- a/src/socket_wrapper.hxx +++ b/src/socket_wrapper.hxx @@ -32,6 +32,12 @@ namespace libt2n { +/** @brief a basic implementation of ConnectionWrapper + + This is a basic version of a ConnectionWrapper which does not do any fancy + error handling or anything, it justs executes the regular calls. Use this + wrapper if you only want to use the singleton-feature of T2nSingletonWrapper. +*/ class BasicSocketWrapper : public ConnectionWrapper { protected: @@ -46,6 +52,9 @@ class BasicSocketWrapper : public ConnectionWrapper std::auto_ptr c; + // TODO: Mark object as non-copyable as it contains an auto_ptr. + // This will make sure nobody every tries to put this in a STL container + public: BasicSocketWrapper(int _port, const std::string& _server="127.0.0.1", long long _connect_timeout_usec=socket_client_connection::connect_timeout_usec_default, @@ -65,8 +74,15 @@ class BasicSocketWrapper : public ConnectionWrapper bool connection_established(void) { return (c.get() != NULL); } + + void set_logging(std::ostream *_logstream, log_level_values _log_level); }; +/** @brief a wrapper implementing reconnect-then-throw + + This ConnectionWrapper tries to reconnect to the server if something with the connection + goes wrong. If even reconnecting max_retries times does not help, an exception is thrown. +*/ class ReconnectSocketWrapper : public BasicSocketWrapper { public: @@ -85,6 +101,7 @@ class ReconnectSocketWrapper : public BasicSocketWrapper bool handle(command_client* stubBase, boost::function< void() > f); }; +/// a placeholder-client_connection which is closed all the time class dummy_client_connection : public client_connection { private: @@ -100,6 +117,12 @@ class dummy_client_connection : public client_connection { return false; } }; +/** @brief a wrapper implementing reconnect-then-ignore + + This ConnectionWrapper tries to reconnect to the server if something with the connection + goes wrong. If even reconnecting max_retries times does not help, the complete t2n-call is + ignored. The return value of the call will be created with the default constructor. +*/ class ReconnectIgnoreFailureSocketWrapper : public ReconnectSocketWrapper { private: