diff options
author | Toni Uhlig <matzeton@googlemail.com> | 2018-07-02 01:06:39 +0200 |
---|---|---|
committer | Toni Uhlig <matzeton@googlemail.com> | 2018-07-02 03:08:59 +0200 |
commit | c2a2445897af17adb56a32dcf111312763a575d4 (patch) | |
tree | ad459cdd682aff3a011d11b6f2a3c518c60dec6a /libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/Packet.h |
initial commit
Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
Diffstat (limited to 'libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/Packet.h')
-rwxr-xr-x | libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/Packet.h | 177 |
1 files changed, 177 insertions, 0 deletions
diff --git a/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/Packet.h b/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/Packet.h new file mode 100755 index 0000000..75fc95d --- /dev/null +++ b/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/Packet.h @@ -0,0 +1,177 @@ +//////////////////////////////////////////////////////////// +// +// SFML - Simple and Fast Multimedia Library +// Copyright (C) 2007-2013 Laurent Gomila (laurent.gom@gmail.com) +// +// This software is provided 'as-is', without any express or implied warranty. +// In no event will the authors be held liable for any damages arising from the use of this software. +// +// Permission is granted to anyone to use this software for any purpose, +// including commercial applications, and to alter it and redistribute it freely, +// subject to the following restrictions: +// +// 1. The origin of this software must not be misrepresented; +// you must not claim that you wrote the original software. +// If you use this software in a product, an acknowledgment +// in the product documentation would be appreciated but is not required. +// +// 2. Altered source versions must be plainly marked as such, +// and must not be misrepresented as being the original software. +// +// 3. This notice may not be removed or altered from any source distribution. +// +//////////////////////////////////////////////////////////// + +#ifndef SFML_PACKET_H +#define SFML_PACKET_H + +//////////////////////////////////////////////////////////// +// Headers +//////////////////////////////////////////////////////////// +#include <SFML/Network/Export.h> +#include <SFML/Network/Types.h> +#include <stddef.h> + + +//////////////////////////////////////////////////////////// +/// \brief Create a new packet +/// +/// \return A new sfPacket object +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API sfPacket* sfPacket_create(void); + +//////////////////////////////////////////////////////////// +/// \brief Create a new packet by copying an existing one +/// +/// \param packet Packet to copy +/// +/// \return A new sfPacket object which is a copy of \a packet +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API sfPacket* sfPacket_copy(const sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Destroy a packet +/// +/// \param packet Packet to destroy +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API void sfPacket_destroy(sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Append data to the end of a packet +/// +/// \param packet Packet object +/// \param data Pointer to the sequence of bytes to append +/// \param sizeInBytes Number of bytes to append +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API void sfPacket_append(sfPacket* packet, const void* data, size_t sizeInBytes); + +//////////////////////////////////////////////////////////// +/// \brief Clear a packet +/// +/// After calling Clear, the packet is empty. +/// +/// \param packet Packet object +/// +/////////////////////////////////////////////////////////// +CSFML_NETWORK_API void sfPacket_clear(sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Get a pointer to the data contained in a packet +/// +/// Warning: the returned pointer may become invalid after +/// you append data to the packet, therefore it should never +/// be stored. +/// The return pointer is NULL if the packet is empty. +/// +/// \param packet Packet object +/// +/// \return Pointer to the data +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API const void* sfPacket_getData(const sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Get the size of the data contained in a packet +/// +/// This function returns the number of bytes pointed to by +/// what sfPacket_getData returns. +/// +/// \param packet Packet object +/// +/// \return Data size, in bytes +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API size_t sfPacket_getDataSize(const sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Tell if the reading position has reached the +/// end of a packet +/// +/// This function is useful to know if there is some data +/// left to be read, without actually reading it. +/// +/// \param packet Packet object +/// +/// \return sfTrue if all data was read, sfFalse otherwise +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API sfBool sfPacket_endOfPacket(const sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Test the validity of a packet, for reading +/// +/// This function allows to test the packet, to check if +/// a reading operation was successful. +/// +/// A packet will be in an invalid state if it has no more +/// data to read. +/// +/// \param packet Packet object +/// +/// \return sfTrue if last data extraction from packet was successful +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API sfBool sfPacket_canRead(const sfPacket* packet); + +//////////////////////////////////////////////////////////// +/// \brief Functions to extract data from a packet +/// +/// \param packet Packet object +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API sfBool sfPacket_readBool(sfPacket* packet); +CSFML_NETWORK_API sfInt8 sfPacket_readInt8(sfPacket* packet); +CSFML_NETWORK_API sfUint8 sfPacket_readUint8(sfPacket* packet); +CSFML_NETWORK_API sfInt16 sfPacket_readInt16(sfPacket* packet); +CSFML_NETWORK_API sfUint16 sfPacket_readUint16(sfPacket* packet); +CSFML_NETWORK_API sfInt32 sfPacket_readInt32(sfPacket* packet); +CSFML_NETWORK_API sfUint32 sfPacket_readUint32(sfPacket* packet); +CSFML_NETWORK_API float sfPacket_readFloat(sfPacket* packet); +CSFML_NETWORK_API double sfPacket_readDouble(sfPacket* packet); +CSFML_NETWORK_API void sfPacket_readString(sfPacket* packet, char* string); +CSFML_NETWORK_API void sfPacket_readWideString(sfPacket* packet, wchar_t* string); + +//////////////////////////////////////////////////////////// +/// \brief Functions to insert data into a packet +/// +/// \param packet Packet object +/// +//////////////////////////////////////////////////////////// +CSFML_NETWORK_API void sfPacket_writeBool(sfPacket* packet, sfBool); +CSFML_NETWORK_API void sfPacket_writeInt8(sfPacket* packet, sfInt8); +CSFML_NETWORK_API void sfPacket_writeUint8(sfPacket* packet, sfUint8); +CSFML_NETWORK_API void sfPacket_writeInt16(sfPacket* packet, sfInt16); +CSFML_NETWORK_API void sfPacket_writeUint16(sfPacket* packet, sfUint16); +CSFML_NETWORK_API void sfPacket_writeInt32(sfPacket* packet, sfInt32); +CSFML_NETWORK_API void sfPacket_writeUint32(sfPacket* packet, sfUint32); +CSFML_NETWORK_API void sfPacket_writeFloat(sfPacket* packet, float); +CSFML_NETWORK_API void sfPacket_writeDouble(sfPacket* packet, double); +CSFML_NETWORK_API void sfPacket_writeString(sfPacket* packet, const char* string); +CSFML_NETWORK_API void sfPacket_writeWideString(sfPacket* packet, const wchar_t* string); + + +#endif // SFML_PACKET_H |