/* * Portable Agile C++ Classes (PACC) * Copyright (C) 2001-2004 by Marc Parizeau and Marc Dubreuil * http://manitou.gel.ulaval.ca/~parizeau/PACC * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * 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 library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * Contact: * Laboratoire de Vision et Systemes Numeriques * Departement de genie electrique et de genie informatique * Universite Laval, Quebec, Canada, G1K 7P4 * http://vision.gel.ulaval.ca * */ /*! * \file PACC/Socket/Cafe.hpp * \brief Class definition for the cafe protocol. * \author Marc Parizeau and Marc Dubreuil, Laboratoire de vision et systèmes numériques, Université Laval * $Revision: 1.5 $ * $Date: 2005/10/05 13:38:27 $ */ #ifndef PACC_Socket_Cafe_hpp_ #define PACC_Socket_Cafe_hpp_ #include "Socket/TCP.hpp" namespace PACC { using namespace std; namespace Socket { /*!\brief %Cafe protocol. \author Marc Parizeau, Laboratoire de vision et systèmes numériques, Université Laval \ingroup Socket This class implements a custom protocol for socket communication. It encapsulates ASCII string messages over %TCP using a header containing a double word signature plus message length information. There are in fact two protocols. The first uses the \c 0xCAFE signature to encapsulate uncompressed messages. In that case, the next double word (4 bytes) contain the message length in network order. The second uses the \c 0xCCAFE signature to encapsulate compressed messages. In this case, the header contains two double words: the first being the compressed message length (in network order), and the second the uncompressed message length (again in network order). By default, this class does not allow message compression (compression level must be 0). In order to enable compression (levels 1 to 9), it needs to be compiled with variable PACC_ZLIB set, and the executable needs to be linked with the zlib library . Also note that messages will be sent uncompressed whenever compression would result in longer messages. Any error raises a Socket::Exception. */ class Cafe : public TCP { public: //! Construct unconnected socket. explicit Cafe(void) throw() {} //! Construct using existing socket descriptor \c inDescriptor. Cafe(int inDescriptor) throw() : TCP(inDescriptor) {} //! Construct socket connected to peer \c inPeer. Cafe(const Address& inPeer) : TCP(inPeer) {} void receiveMessage(string& outMessage); void sendMessage(const string& inMessage, unsigned int inCompressionLevel = 0); protected: void compress(const string& inMessage, string& outMessage, unsigned int inCompressionLevel); void uncompress(string& ioMessage, unsigned int inSize); void receive(char* inBuffer, unsigned int inCount); }; } // end of Socket namespace } // end of PACC namespace #endif // PACC_Socket_Cafe_hpp_