libsocket
inetserverstream.hpp
Go to the documentation of this file.
1 #ifndef LIBSOCKET_INETSERVERSTREAM_H_D84111E97D5548209F3816859EF080FE
2 #define LIBSOCKET_INETSERVERSTREAM_H_D84111E97D5548209F3816859EF080FE
3 
4 #include "inetbase.hpp"
5 #include "inetclientstream.hpp"
6 
7 #include <memory>
8 
14 /*
15  The committers of the libsocket project, all rights reserved
16  (c) 2012, dermesser <lbo@spheniscida.de>
17 
18  Redistribution and use in source and binary forms, with or without
19  modification, are permitted provided that the following conditions are met:
20 
21  1. Redistributions of source code must retain the above copyright notice,
22  this list of conditions and the following disclaimer.
23  2. Redistributions in binary form must reproduce the above copyright notice,
24  this list of conditions and the following disclaimer in the documentation
25  and/or other materials provided with the distribution.
26 
27  THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS “AS IS” AND ANY
28  EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
29  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
30  DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
31  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
32  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
33  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
34  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37 
38 */
39 
40 namespace libsocket {
41 using std::unique_ptr;
42 
57  public:
58  inet_stream_server(void);
59  inet_stream_server(const char* bindhost, const char* bindport,
60  int proto_osi3, int flags = 0);
61  inet_stream_server(const string& bindhost, const string& bindport,
62  int proto_osi3, int flags = 0);
63 
64  void setup(const char* bindhost, const char* bindport, int proto_osi3,
65  int flags = 0);
66  void setup(const string& bindhost, const string& bindport, int proto_osi3,
67  int flags = 0);
68 
69  inet_stream* accept(int numeric = 0, int accept_flags = 0);
70  unique_ptr<inet_stream> accept2(int numeric = 0, int accept_flags = 0);
71 
72  const string& getbindhost(void);
73  const string& getbindport(void);
74 };
78 } // namespace libsocket
79 
80 #endif
Contains libsocket elements.
Definition: dgramclient.hpp:41
unique_ptr< inet_stream > accept2(int numeric=0, int accept_flags=0)
Accept a connection and return a socket connected to the client.
Provides TCP/IP client sockets. This class is the most used socket class in libsocket++....
void setup(const char *bindhost, const char *bindport, int proto_osi3, int flags=0)
Set up a server socket.
Internet-socket base class This class provides some fields for all internet sockets,...
Definition: inetbase.hpp:52
inet_stream * accept(int numeric=0, int accept_flags=0)
Accept a connection and return a socket connected to the client.
inet_stream_server(void)
Void constructor; don't forget to setup() the socket before use!
TCP server socket (passive TCP socket)