VideoTools
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
gbufferedserverpeer.h
Go to the documentation of this file.
1 //
2 // Copyright (C) 2017 Graeme Walker
3 //
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
16 // ===
17 ///
18 /// \file gbufferedserverpeer.h
19 ///
20 
21 #ifndef G_BUFFERED_SERVER_PEER_H
22 #define G_BUFFERED_SERVER_PEER_H
23 
24 #include "gdef.h"
25 #include "gnet.h"
26 #include "gserver.h"
27 #include "gsocketprotocol.h"
28 #include "glinebuffer.h"
29 #include "gexception.h"
30 #include <string>
31 
32 namespace GNet
33 {
34  class BufferedServerPeer ;
35 }
36 
37 /// \class GNet::BufferedServerPeer
38 /// A ServerPeer that does line-buffering on input.
39 ///
41 {
42 public:
44  ///< Constructor with an auto-detected line ending.
45 
46  BufferedServerPeer( Server::PeerInfo , const std::string & eol ) ;
47  ///< Constructor with a fixed line ending.
48 
49  virtual ~BufferedServerPeer() ;
50  ///< Destructor.
51 
52  const std::string & eol() const ;
53  ///< Returns the line-buffer's line ending. This is typically used
54  ///< in the first onReceive() callback to check the auto-detection
55  ///< result.
56 
57  void expect( size_t n ) ;
58  ///< Temporarily suspends line buffering so that the next 'n' bytes
59  ///< are accumulated without regard to line terminators.
60 
61 protected:
62  virtual bool onReceive( const std::string & ) = 0 ;
63  ///< Called when a complete line is received from the peer. Returns
64  ///< false if no more lines should be delivered.
65 
66  virtual void onData( const char * , ServerPeer::size_type ) ;
67  ///< Override from GNet::SocketProtocolSink.
68 
69 private:
71  void operator=( const BufferedServerPeer & ) ;
72 
73 private:
74  LineBuffer m_line_buffer ;
75  size_t m_expect ;
76  std::string m_expect_data ;
77 } ;
78 
79 #endif
An abstract base class for the GNet::Server's connection to a remote client.
Definition: gserver.h:173
BufferedServerPeer(Server::PeerInfo)
Constructor with an auto-detected line ending.
virtual bool onReceive(const std::string &)=0
Called when a complete line is received from the peer.
virtual void onData(const char *, ServerPeer::size_type)
Override from GNet::SocketProtocolSink.
void expect(size_t n)
Temporarily suspends line buffering so that the next 'n' bytes are accumulated without regard to line...
virtual ~BufferedServerPeer()
Destructor.
A class which does line buffering.
Definition: glinebuffer.h:52
const std::string & eol() const
Returns the line-buffer's line ending.
A ServerPeer that does line-buffering on input.
A structure used in GNet::Server::newPeer().
Definition: gserver.h:86