summaryrefslogtreecommitdiff
path: root/src/stable/tcpserversocket.h
blob: efb7287b282e94e0802cf9c777fa473d61f00493 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
 * Copyright (C) 2007-2011 Xagasoft, All rights reserved.
 *
 * This file is part of the libbu++ library and is released under the
 * terms of the license contained in the file LICENSE.
 */

#ifndef BU_TCP_SERVER_SOCKET_H
#define BU_TCP_SERVER_SOCKET_H

#include <stdint.h>
#include "bu/string.h"
#include "bu/exceptionbase.h"

#ifdef WIN32
 #include <Winsock2.h>
#else
 #include <sys/select.h>
#endif

namespace Bu
{
	subExceptionDecl( TcpServerSocketException );

	/**
	 * A single tcp/ip server socket.  When created the server socket will bind
	 * to the specified interface and port, and immediately begin listening for
	 * connections.  When connections come in they are pooled by the networking
	 * drivers in the kernel until they are accepted, this means that failure
	 * to keep space in the connection pool will result in connection refusals.
	 *
	 * Although the accept function returns an integral file descriptor, it is
	 * designed to be used with the Socket class.
	 *
	 *@ingroup Serving
	 */
	class TcpServerSocket
	{
	public:
		TcpServerSocket( int nPort, int nPoolSize=40 );
		TcpServerSocket( const String &sAddr, int nPort, int nPoolSize=40 );
		TcpServerSocket( int nSocket, bool bInit, int nPoolSize=40 );
		TcpServerSocket( const TcpServerSocket &rSrc );
		virtual ~TcpServerSocket();

		int accept( int nTimeoutSec=0, int nTimeoutUSec=0 );
		int getSocket();
		int getPort();

	private:
		void startServer( struct sockaddr_in &name, int nPoolSize );
		void initServer( struct sockaddr_in &name, int nPoolSize );

		fd_set fdActive;
#ifdef WIN32
		unsigned int nServer;
#else
		int nServer;
#endif
		int nPort;
	};
}

#endif