summaryrefslogtreecommitdiff
path: root/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/TcpSocket.h
diff options
context:
space:
mode:
Diffstat (limited to 'libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/TcpSocket.h')
-rwxr-xr-xlibghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/TcpSocket.h210
1 files changed, 210 insertions, 0 deletions
diff --git a/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/TcpSocket.h b/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/TcpSocket.h
new file mode 100755
index 0000000..2911c00
--- /dev/null
+++ b/libghack/CSFML-2.1-windows-32bits/CSFML-2.1/include/SFML/Network/TcpSocket.h
@@ -0,0 +1,210 @@
+////////////////////////////////////////////////////////////
+//
+// 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_TCPSOCKET_H
+#define SFML_TCPSOCKET_H
+
+////////////////////////////////////////////////////////////
+// Headers
+////////////////////////////////////////////////////////////
+#include <SFML/Network/Export.h>
+#include <SFML/Network/IpAddress.h>
+#include <SFML/Network/SocketStatus.h>
+#include <SFML/Network/Types.h>
+#include <SFML/System/Time.h>
+#include <stddef.h>
+
+
+////////////////////////////////////////////////////////////
+/// \brief Create a new TCP socket
+///
+/// \return A new sfTcpSocket object
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfTcpSocket* sfTcpSocket_create(void);
+
+////////////////////////////////////////////////////////////
+/// \brief Destroy a TCP socket
+///
+/// \param socket TCP socket to destroy
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API void sfTcpSocket_destroy(sfTcpSocket* socket);
+
+////////////////////////////////////////////////////////////
+/// \brief Set the blocking state of a TCP listener
+///
+/// In blocking mode, calls will not return until they have
+/// completed their task. For example, a call to
+/// sfTcpSocket_receive in blocking mode won't return until
+/// new data was actually received.
+/// In non-blocking mode, calls will always return immediately,
+/// using the return code to signal whether there was data
+/// available or not.
+/// By default, all sockets are blocking.
+///
+/// \param socket TCP socket object
+/// \param blocking sfTrue to set the socket as blocking, sfFalse for non-blocking
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API void sfTcpSocket_setBlocking(sfTcpSocket* socket, sfBool blocking);
+
+////////////////////////////////////////////////////////////
+/// \brief Tell whether a TCP socket is in blocking or non-blocking mode
+///
+/// \param socket TCP socket object
+///
+/// \return sfTrue if the socket is blocking, sfFalse otherwise
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfBool sfTcpSocket_isBlocking(const sfTcpSocket* socket);
+
+////////////////////////////////////////////////////////////
+/// \brief Get the port to which a TCP socket is bound locally
+///
+/// If the socket is not connected, this function returns 0.
+///
+/// \param socket TCP socket object
+///
+/// \return Port to which the socket is bound
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API unsigned short sfTcpSocket_getLocalPort(const sfTcpSocket* socket);
+
+////////////////////////////////////////////////////////////
+/// \brief Get the address of the connected peer of a TCP socket
+///
+/// It the socket is not connected, this function returns
+/// sfIpAddress_None.
+///
+/// \param socket TCP socket object
+///
+/// \return Address of the remote peer
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfIpAddress sfTcpSocket_getRemoteAddress(const sfTcpSocket* socket);
+
+////////////////////////////////////////////////////////////
+/// \brief Get the port of the connected peer to which
+/// a TCP socket is connected
+///
+/// If the socket is not connected, this function returns 0.
+///
+/// \param socket TCP socket object
+///
+/// \return Remote port to which the socket is connected
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API unsigned short sfTcpSocket_getRemotePort(const sfTcpSocket* socket);
+
+////////////////////////////////////////////////////////////
+/// \brief Connect a TCP socket to a remote peer
+///
+/// In blocking mode, this function may take a while, especially
+/// if the remote peer is not reachable. The last parameter allows
+/// you to stop trying to connect after a given timeout.
+/// If the socket was previously connected, it is first disconnected.
+///
+/// \param socket TCP socket object
+/// \param remoteAddress Address of the remote peer
+/// \param remotePort Port of the remote peer
+/// \param timeout Maximum time to wait
+///
+/// \return Status code
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfSocketStatus sfTcpSocket_connect(sfTcpSocket* socket, sfIpAddress host, unsigned short port, sfTime timeout);
+
+////////////////////////////////////////////////////////////
+/// \brief Disconnect a TCP socket from its remote peer
+///
+/// This function gracefully closes the connection. If the
+/// socket is not connected, this function has no effect.
+///
+/// \param socket TCP socket object
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API void sfTcpSocket_disconnect(sfTcpSocket* socket);
+
+////////////////////////////////////////////////////////////
+/// \brief Send raw data to the remote peer of a TCP socket
+///
+/// This function will fail if the socket is not connected.
+///
+/// \param socket TCP socket object
+/// \param data Pointer to the sequence of bytes to send
+/// \param size Number of bytes to send
+///
+/// \return Status code
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfSocketStatus sfTcpSocket_send(sfTcpSocket* socket, const void* data, size_t size);
+
+////////////////////////////////////////////////////////////
+/// \brief Receive raw data from the remote peer of a TCP socket
+///
+/// In blocking mode, this function will wait until some
+/// bytes are actually received.
+/// This function will fail if the socket is not connected.
+///
+/// \param socket TCP socket object
+/// \param data Pointer to the array to fill with the received bytes
+/// \param size Maximum number of bytes that can be received
+/// \param received This variable is filled with the actual number of bytes received
+///
+/// \return Status code
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfSocketStatus sfTcpSocket_receive(sfTcpSocket* socket, void* data, size_t maxSize, size_t* sizeReceived);
+
+////////////////////////////////////////////////////////////
+/// \brief Send a formatted packet of data to the remote peer of a TCP socket
+///
+/// This function will fail if the socket is not connected.
+///
+/// \param socket TCP socket object
+/// \param packet Packet to send
+///
+/// \return Status code
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfSocketStatus sfTcpSocket_sendPacket(sfTcpSocket* socket, sfPacket* packet);
+
+////////////////////////////////////////////////////////////
+/// \brief Receive a formatted packet of data from the remote peer
+///
+/// In blocking mode, this function will wait until the whole packet
+/// has been received.
+/// This function will fail if the socket is not connected.
+///
+/// \param socket TCP socket object
+/// \param packet Packet to fill with the received data
+///
+/// \return Status code
+///
+////////////////////////////////////////////////////////////
+CSFML_NETWORK_API sfSocketStatus sfTcpSocket_receivePacket(sfTcpSocket* socket, sfPacket* packet);
+
+
+#endif // SFML_TCPSOCKET_H