220 lines
7.5 KiB
C++
220 lines
7.5 KiB
C++
|
////////////////////////////////////////////////////////////
|
||
|
//
|
||
|
// SFML - Simple and Fast Multimedia Library
|
||
|
// Copyright (C) 2007-2018 Laurent Gomila (laurent@sfml-dev.org)
|
||
|
//
|
||
|
// 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_SOCKET_HPP
|
||
|
#define SFML_SOCKET_HPP
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
// Headers
|
||
|
////////////////////////////////////////////////////////////
|
||
|
#include <SFML/Network/Export.hpp>
|
||
|
#include <SFML/Network/SocketHandle.hpp>
|
||
|
#include <SFML/System/NonCopyable.hpp>
|
||
|
#include <vector>
|
||
|
|
||
|
|
||
|
namespace sf
|
||
|
{
|
||
|
class SocketSelector;
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Base class for all the socket types
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
class SFML_NETWORK_API Socket : NonCopyable
|
||
|
{
|
||
|
public:
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Status codes that may be returned by socket functions
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
enum Status
|
||
|
{
|
||
|
Done, ///< The socket has sent / received the data
|
||
|
NotReady, ///< The socket is not ready to send / receive data yet
|
||
|
Partial, ///< The socket sent a part of the data
|
||
|
Disconnected, ///< The TCP socket has been disconnected
|
||
|
Error ///< An unexpected error happened
|
||
|
};
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Some special values used by sockets
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
enum
|
||
|
{
|
||
|
AnyPort = 0 ///< Special value that tells the system to pick any available port
|
||
|
};
|
||
|
|
||
|
public:
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Destructor
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
virtual ~Socket();
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Set the blocking state of the socket
|
||
|
///
|
||
|
/// In blocking mode, calls will not return until they have
|
||
|
/// completed their task. For example, a call to Receive in
|
||
|
/// blocking mode won't return until some 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 blocking True to set the socket as blocking, false for non-blocking
|
||
|
///
|
||
|
/// \see isBlocking
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
void setBlocking(bool blocking);
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Tell whether the socket is in blocking or non-blocking mode
|
||
|
///
|
||
|
/// \return True if the socket is blocking, false otherwise
|
||
|
///
|
||
|
/// \see setBlocking
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
bool isBlocking() const;
|
||
|
|
||
|
protected:
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Types of protocols that the socket can use
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
enum Type
|
||
|
{
|
||
|
Tcp, ///< TCP protocol
|
||
|
Udp ///< UDP protocol
|
||
|
};
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Default constructor
|
||
|
///
|
||
|
/// This constructor can only be accessed by derived classes.
|
||
|
///
|
||
|
/// \param type Type of the socket (TCP or UDP)
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
Socket(Type type);
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Return the internal handle of the socket
|
||
|
///
|
||
|
/// The returned handle may be invalid if the socket
|
||
|
/// was not created yet (or already destroyed).
|
||
|
/// This function can only be accessed by derived classes.
|
||
|
///
|
||
|
/// \return The internal (OS-specific) handle of the socket
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
SocketHandle getHandle() const;
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Create the internal representation of the socket
|
||
|
///
|
||
|
/// This function can only be accessed by derived classes.
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
void create();
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Create the internal representation of the socket
|
||
|
/// from a socket handle
|
||
|
///
|
||
|
/// This function can only be accessed by derived classes.
|
||
|
///
|
||
|
/// \param handle OS-specific handle of the socket to wrap
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
void create(SocketHandle handle);
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \brief Close the socket gracefully
|
||
|
///
|
||
|
/// This function can only be accessed by derived classes.
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|
||
|
void close();
|
||
|
|
||
|
private:
|
||
|
|
||
|
friend class SocketSelector;
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
// Member data
|
||
|
////////////////////////////////////////////////////////////
|
||
|
Type m_type; ///< Type of the socket (TCP or UDP)
|
||
|
SocketHandle m_socket; ///< Socket descriptor
|
||
|
bool m_isBlocking; ///< Current blocking mode of the socket
|
||
|
};
|
||
|
|
||
|
} // namespace sf
|
||
|
|
||
|
|
||
|
#endif // SFML_SOCKET_HPP
|
||
|
|
||
|
|
||
|
////////////////////////////////////////////////////////////
|
||
|
/// \class sf::Socket
|
||
|
/// \ingroup network
|
||
|
///
|
||
|
/// This class mainly defines internal stuff to be used by
|
||
|
/// derived classes.
|
||
|
///
|
||
|
/// The only public features that it defines, and which
|
||
|
/// is therefore common to all the socket classes, is the
|
||
|
/// blocking state. All sockets can be set as blocking or
|
||
|
/// non-blocking.
|
||
|
///
|
||
|
/// In blocking mode, socket functions will hang until
|
||
|
/// the operation completes, which means that the entire
|
||
|
/// program (well, in fact the current thread if you use
|
||
|
/// multiple ones) will be stuck waiting for your socket
|
||
|
/// operation to complete.
|
||
|
///
|
||
|
/// In non-blocking mode, all the socket functions will
|
||
|
/// return immediately. If the socket is not ready to complete
|
||
|
/// the requested operation, the function simply returns
|
||
|
/// the proper status code (Socket::NotReady).
|
||
|
///
|
||
|
/// The default mode, which is blocking, is the one that is
|
||
|
/// generally used, in combination with threads or selectors.
|
||
|
/// The non-blocking mode is rather used in real-time
|
||
|
/// applications that run an endless loop that can poll
|
||
|
/// the socket often enough, and cannot afford blocking
|
||
|
/// this loop.
|
||
|
///
|
||
|
/// \see sf::TcpListener, sf::TcpSocket, sf::UdpSocket
|
||
|
///
|
||
|
////////////////////////////////////////////////////////////
|