X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fsocket_wrapper.hxx;h=da972a2d01c57d01553522594728ea32697de12b;hp=51c0693d1c28bcbf5c4e406e15ba985e964fdaba;hb=fb3345ada7ea94225b78994fd50e3de693a2a3d5;hpb=4c3662a0b083759056b93c21e747e5551a8ddfcc diff --git a/src/socket_wrapper.hxx b/src/socket_wrapper.hxx index 51c0693..da972a2 100644 --- a/src/socket_wrapper.hxx +++ b/src/socket_wrapper.hxx @@ -62,6 +62,9 @@ class BasicSocketWrapper : public ConnectionWrapper { } client_connection* get_connection(void); + + bool connection_established(void) + { return (c.get() != NULL); } }; class ReconnectSocketWrapper : public BasicSocketWrapper @@ -79,12 +82,29 @@ class ReconnectSocketWrapper : public BasicSocketWrapper : BasicSocketWrapper(_path,_connect_timeout_usec,_max_retries) { } - void handle(command_client* stubBase, boost::function< void() > f); + bool handle(command_client* stubBase, boost::function< void() > f); }; +class dummy_client_connection : public client_connection +{ + private: + void real_write(const std::string& data) + { } + + public: + dummy_client_connection() + : client_connection() + { close(); } + + bool fill_buffer(long long usec_timeout=-1, long long *usec_timeout_remaining=NULL) + { return false; } +}; class ReconnectIgnoreFailureSocketWrapper : public ReconnectSocketWrapper { + private: + dummy_client_connection dc; + public: ReconnectIgnoreFailureSocketWrapper(int _port, const std::string& _server="127.0.0.1", long long _connect_timeout_usec=socket_client_connection::connect_timeout_usec_default, @@ -99,11 +119,9 @@ class ReconnectIgnoreFailureSocketWrapper : public ReconnectSocketWrapper { } client_connection* get_connection(void); - void handle(command_client* stubBase, boost::function< void() > f); + bool handle(command_client* stubBase, boost::function< void() > f); }; - - } #endif