parent
e4b28fcdbe
commit
a59674ba9d
@ -1,39 +1,67 @@
|
||||
#ifndef TCP_SERVER_HPP
|
||||
#define TCP_SERVER_HPP
|
||||
|
||||
#include "Socket.hpp"
|
||||
#include "Logger.hpp"
|
||||
|
||||
#include "Connection.hpp"
|
||||
#include "Poll.hpp"
|
||||
|
||||
|
||||
|
||||
#include <string>
|
||||
|
||||
class TcpServer : public Socket
|
||||
, public Poll
|
||||
template <typename T>
|
||||
class TcpServer
|
||||
{
|
||||
public:
|
||||
|
||||
TcpServer ( const std::string host,
|
||||
const std::string port,
|
||||
const int maxClients = 5 );
|
||||
const int maxClients = 5,
|
||||
const int maxPendingQueueLen = 10 )
|
||||
: m_connection(host, port)
|
||||
, m_poll( &m_connection, maxClients)
|
||||
, m_maxPendingQueueLen(maxPendingQueueLen)
|
||||
{
|
||||
TRACE;
|
||||
}
|
||||
|
||||
virtual ~TcpServer()
|
||||
{
|
||||
TRACE;
|
||||
}
|
||||
|
||||
bool start()
|
||||
{
|
||||
TRACE;
|
||||
|
||||
if ( !m_connection.bindToHost() )
|
||||
return false;
|
||||
|
||||
virtual ~TcpServer();
|
||||
if ( m_connection.listen( m_maxPendingQueueLen ) == -1 ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
bool start();
|
||||
void stop();
|
||||
m_poll.startPolling();
|
||||
return true;
|
||||
}
|
||||
|
||||
// implements Poll::receive
|
||||
bool receive( const int fd );
|
||||
void stop()
|
||||
{
|
||||
TRACE;
|
||||
m_poll.stopPolling();
|
||||
m_connection.closeConnection();
|
||||
}
|
||||
|
||||
virtual void msgArrived(const int clientSocket,
|
||||
const unsigned char* msg,
|
||||
const int msgLen ) = 0;
|
||||
|
||||
private:
|
||||
|
||||
TcpServer(const TcpServer&);
|
||||
TcpServer& operator=(const TcpServer&);
|
||||
|
||||
std::string m_host;
|
||||
std::string m_port;
|
||||
Connection<T> m_connection;
|
||||
Poll<T> m_poll;
|
||||
const int m_maxPendingQueueLen;
|
||||
};
|
||||
|
||||
#endif // TCP_SERVER_HPP
|
||||
|
Loading…
Reference in new issue