mirror of
https://github.com/dashr9230/SA-MP.git
synced 2025-01-04 00:23:22 +08:00
118 lines
4.8 KiB
C++
118 lines
4.8 KiB
C++
// TODO: Implement RakServerInterface.h
|
|
|
|
#ifndef __RAK_SERVER_INTERFACE_H
|
|
#define __RAK_SERVER_INTERFACE_H
|
|
|
|
#include "Export.h"
|
|
|
|
/// This is a user-interface class to act as a game server. All it does is implement some functionality on top of RakPeer.
|
|
/// See the individual functions for what the class can do.
|
|
/// \brief Defines the functions used by a game server
|
|
class RAK_DLL_EXPORT RakServerInterface
|
|
{
|
|
|
|
public:
|
|
virtual void vftable_0()=0;
|
|
virtual void vftable_4()=0;
|
|
virtual void vftable_8()=0;
|
|
virtual void vftable_C()=0;
|
|
virtual void vftable_10()=0;
|
|
virtual void vftable_14()=0;
|
|
virtual void vftable_18()=0;
|
|
virtual void vftable_1C()=0;
|
|
virtual void vftable_20()=0;
|
|
virtual void vftable_24()=0;
|
|
virtual void vftable_28()=0;
|
|
virtual void vftable_2C()=0;
|
|
virtual void vftable_30()=0;
|
|
|
|
/// Set how many players are allowed on the server.
|
|
/// If more players are currently connected then are allowed then no more players will be allowed to join until the number of players is less than the number of allowed players.
|
|
/// \pre The server must be active for this to have meaning
|
|
/// \param[in] AllowedPlayers The number of players to allow
|
|
virtual void SetAllowedPlayers( unsigned short AllowedPlayers )=0;
|
|
|
|
/// Return how many players are allowed to connect. This value was set either from Start or from SetAllowedPlayers.
|
|
/// \pre The server must be active for this to have meaning
|
|
/// \return The number of allowed players
|
|
virtual unsigned short GetAllowedPlayers( void ) const=0;
|
|
|
|
virtual void vftable_3C()=0;
|
|
virtual void vftable_40()=0;
|
|
virtual void vftable_44()=0;
|
|
virtual void vftable_48()=0;
|
|
virtual void vftable_4C()=0;
|
|
virtual void vftable_50()=0;
|
|
virtual void vftable_54()=0;
|
|
virtual void vftable_58()=0;
|
|
virtual void vftable_5C()=0;
|
|
virtual void vftable_60()=0;
|
|
virtual void vftable_64()=0;
|
|
virtual void vftable_68()=0;
|
|
virtual void vftable_6C()=0;
|
|
virtual void vftable_70()=0;
|
|
|
|
/// \ingroup RAKNET_RPC
|
|
/// Register a C or static member function as available for calling as a remote procedure call
|
|
/// \param[in] uniqueID: A null-terminated unique string to identify this procedure. Recommended you use the macro CLASS_MEMBER_ID for class member functions
|
|
/// \param[in] functionPointer The name of the function to be used as a function pointer. This can be called whether active or not, and registered functions stay registered unless unregistered
|
|
virtual void RegisterAsRemoteProcedureCall( unsigned char* uniqueID, void ( *functionPointer ) ( RPCParameters *rpcParms ) )=0;
|
|
|
|
/// \ingroup RAKNET_RPC
|
|
/// Register a C++ member function as available for calling as a remote procedure call.
|
|
/// \param[in] uniqueID: A null terminated string to identify this procedure.Recommended you use the macro REGISTER_CLASS_MEMBER_RPC
|
|
/// \param[in] functionPointer: The name of the function to be used as a function pointer. This can be called whether active or not, and registered functions stay registered unless unregistered with UnregisterAsRemoteProcedureCall
|
|
/// \sa ObjectMemberRPC.cpp
|
|
virtual void RegisterClassMemberRPC( unsigned char* uniqueID, void *functionPointer )=0;
|
|
|
|
///\ingroup RAKNET_RPC
|
|
/// Unregisters a C function as available for calling as a remote procedure call that was formerly registeredwith RegisterAsRemoteProcedureCallOnly call offline
|
|
/// \param[in] uniqueID A string of only letters to identify this procedure. Recommended you use the macro CLASS_MEMBER_ID for class member functions. Must match the parameterpassed to RegisterAsRemoteProcedureCall
|
|
virtual void UnregisterAsRemoteProcedureCall( unsigned char* uniqueID )=0;
|
|
|
|
virtual void vftable_80()=0;
|
|
virtual void vftable_84()=0;
|
|
virtual void vftable_88()=0;
|
|
virtual void vftable_8C()=0;
|
|
virtual void vftable_90()=0;
|
|
virtual void vftable_94()=0;
|
|
virtual void vftable_98()=0;
|
|
virtual void vftable_9C()=0;
|
|
virtual void vftable_A0()=0;
|
|
virtual void vftable_A4()=0;
|
|
virtual void vftable_A8()=0;
|
|
virtual void vftable_AC()=0;
|
|
virtual void vftable_B0()=0;
|
|
virtual void vftable_B4()=0;
|
|
virtual void vftable_B8()=0;
|
|
virtual void vftable_BC()=0;
|
|
virtual void vftable_C0()=0;
|
|
virtual void vftable_C4()=0;
|
|
virtual void vftable_C8()=0;
|
|
virtual void vftable_CC()=0;
|
|
virtual void vftable_D0()=0;
|
|
virtual void vftable_D4()=0;
|
|
virtual void vftable_D8()=0;
|
|
virtual void vftable_DC()=0;
|
|
virtual void vftable_E0()=0;
|
|
virtual void vftable_E4()=0;
|
|
virtual void vftable_E8()=0;
|
|
virtual void vftable_EC()=0;
|
|
virtual void vftable_F0()=0;
|
|
virtual void vftable_F4()=0;
|
|
virtual void vftable_F8()=0;
|
|
virtual void vftable_FC()=0;
|
|
virtual void vftable_100()=0;
|
|
virtual void vftable_104()=0;
|
|
virtual void vftable_108()=0;
|
|
virtual void vftable_10C()=0;
|
|
virtual void vftable_110()=0;
|
|
virtual void vftable_114()=0;
|
|
virtual void vftable_118()=0;
|
|
virtual void vftable_11C()=0;
|
|
virtual void vftable_120()=0;
|
|
virtual void vftable_124()=0;
|
|
};
|
|
|
|
#endif
|