X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fsocket_wrapper.hxx;h=82b8354f8bcbc589f833e2ed1c8d38f949b5551b;hp=ebb85f6a8ff6000e9ae99cc2e260fbca0f0dd16b;hb=19facd8558fe2e32ce843860b40631ebe03ff3cf;hpb=2a956e6587338524eec8f66efe3a733a2116eb9b diff --git a/src/socket_wrapper.hxx b/src/socket_wrapper.hxx index ebb85f6..82b8354 100644 --- a/src/socket_wrapper.hxx +++ b/src/socket_wrapper.hxx @@ -1,21 +1,24 @@ -/*************************************************************************** - * Copyright (C) 2008 by Gerd v. Egidy * - * gve@intra2net.com * - * * - * This library is free software; you can redistribute it and/or modify * - * it under the terms of the GNU Lesser General Public License version * - * 2.1 as published by the Free Software Foundation. * - * * - * This library is distributed in the hope that it will be useful, * - * but WITHOUT ANY WARRANTY; without even the implied warranty of * - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * - * GNU Lesser General Public License for more details. * - * * - * You should have received a copy of the GNU Lesser General Public * - * License along with this program; if not, write to the * - * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * - ***************************************************************************/ +/* +Copyright (C) 2006 by Intra2net AG - Gerd v. Egidy + +The software in this package is distributed under the GNU General +Public License version 2 (with a special exception described below). + +A copy of GNU General Public License (GPL) is included in this distribution, +in the file COPYING.GPL. + +As a special exception, if other files instantiate templates or use macros +or inline functions from this file, or you compile this file and link it +with other works to produce a work based on this file, this file +does not by itself cause the resulting work to be covered +by the GNU General Public License. + +However the source code for this file must still be made available +in accordance with section (3) of the GNU General Public License. + +This exception does not invalidate any other reasons why a work based +on this file might be covered by the GNU General Public License. +*/ #ifndef __LIBT2N_SOCKET_WRAPPER #define __LIBT2N_SOCKET_WRAPPER @@ -32,6 +35,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 +55,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, @@ -69,6 +81,11 @@ class BasicSocketWrapper : public ConnectionWrapper 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: @@ -87,6 +104,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: @@ -102,6 +120,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: