khanat-opennel-code/code/nel/include/nel/net/callback_client.h

115 lines
4 KiB
C++

// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifndef NL_CALLBACK_CLIENT_H
#define NL_CALLBACK_CLIENT_H
#include "nel/misc/types_nl.h"
#include "callback_net_base.h"
#include "buf_client.h"
namespace NLNET {
class CInetAddress;
/**
* Client class for layer 3
* \author Vianney Lecroart, Olivier Cado
* \author Nevrax France
* \date 2001
*/
class CCallbackClient : public CCallbackNetBase, public CBufClient
{
public:
/// Constructor
CCallbackClient( TRecordingState rec=Off, const std::string& recfilename="", bool recordall=true, bool initPipeForDataAvailable=true );
~CCallbackClient();
/// Sends a message to the remote host (the second parameter isn't used)
void send (const CMessage &buffer, TSockId hostid = InvalidSockId, bool log = true);
/// Force to send all data pending in the send queue. hostid must be InvalidSockId here. See comment in CCallbackNetBase.
bool flush (TSockId hostid = InvalidSockId, uint *nbBytesRemaining=NULL);
/** Updates the network (call this method evenly).
* More info about timeout and mintime in the code of CCallbackNetBase::baseUpdate().
*/
void update2 (sint32 timeout=-1, sint32 mintime=0);
/// Updates the network (call this method evenly) (legacy)
void update (sint32 timeout=0);
/// Connects to the specified host
void connect( const CInetAddress& addr );
/** Returns true if the connection is still connected (changed when a disconnection
* event has reached the front of the receive queue, just before calling the disconnection callback
* if there is one)
*/
virtual bool connected () const { return CBufClient::connected (); }
virtual const CInetAddress& hostAddress( TSockId /* hostid */ ) { return remoteAddress(); }
/** Disconnect a connection
* Unlike in CCallbackClient, you can call disconnect() on a socket that is already disconnected
* (it will do nothing)
*/
void disconnect (TSockId hostid = InvalidSockId);
/// Sets callback for disconnections (or NULL to disable callback)
void setDisconnectionCallback (TNetCallback cb, void *arg) { CCallbackNetBase::setDisconnectionCallback (cb, arg); }
/// Returns the sockid
virtual TSockId getSockId (TSockId hostid = InvalidSockId);
uint64 getReceiveQueueSize () { return CBufClient::getReceiveQueueSize(); }
uint64 getSendQueueSize () { return CBufClient::getSendQueueSize(); }
void displayReceiveQueueStat (NLMISC::CLog *log = NLMISC::InfoLog) { CBufClient::displayReceiveQueueStat(log); }
void displaySendQueueStat (NLMISC::CLog *log = NLMISC::InfoLog, TSockId /* destid */ = InvalidSockId) { CBufClient::displaySendQueueStat(log); }
void displayThreadStat (NLMISC::CLog *log = NLMISC::InfoLog) { CBufClient::displayThreadStat(log); }
private:
/// These function is public in the base class and put it private here because user cannot use it in layer 2
void send (const NLMISC::CMemStream &/* buffer */) { nlstop; }
/// Returns true if there are messages to read
bool dataAvailable ();
virtual bool getDataAvailableFlagV() const { return dataAvailableFlag(); }
void receive (CMessage &buffer, TSockId *hostid = NULL);
// ---------------------------------------
#ifdef USE_MESSAGE_RECORDER
virtual bool replaySystemCallbacks();
#endif
bool LockDeletion;
};
} // NLNET
#endif // NL_CALLBACK_CLIENT_H
/* End of callback_client.h */