1 ////////////////////////////////////////////////////////////
\r
3 // SFML - Simple and Fast Multimedia Library
\r
4 // Copyright (C) 2007-2009 Laurent Gomila (laurent.gom@gmail.com)
\r
6 // This software is provided 'as-is', without any express or implied warranty.
\r
7 // In no event will the authors be held liable for any damages arising from the use of this software.
\r
9 // Permission is granted to anyone to use this software for any purpose,
\r
10 // including commercial applications, and to alter it and redistribute it freely,
\r
11 // subject to the following restrictions:
\r
13 // 1. The origin of this software must not be misrepresented;
\r
14 // you must not claim that you wrote the original software.
\r
15 // If you use this software in a product, an acknowledgment
\r
16 // in the product documentation would be appreciated but is not required.
\r
18 // 2. Altered source versions must be plainly marked as such,
\r
19 // and must not be misrepresented as being the original software.
\r
21 // 3. This notice may not be removed or altered from any source distribution.
\r
23 ////////////////////////////////////////////////////////////
\r
25 #ifndef SFML_SELECTORBASE_HPP
\r
26 #define SFML_SELECTORBASE_HPP
\r
28 ////////////////////////////////////////////////////////////
\r
30 ////////////////////////////////////////////////////////////
\r
31 #include <SFML/Config.hpp>
\r
32 #include <SFML/Network/SocketHelper.hpp>
\r
38 ////////////////////////////////////////////////////////////
\r
39 /// Private base class for selectors.
\r
40 /// As Selector is a template class, this base is needed so that
\r
41 /// every system call get compiled in SFML (not inlined)
\r
42 ////////////////////////////////////////////////////////////
\r
43 class SFML_API SelectorBase
\r
47 ////////////////////////////////////////////////////////////
\r
48 /// Default constructor
\r
50 ////////////////////////////////////////////////////////////
\r
53 ////////////////////////////////////////////////////////////
\r
54 /// Add a socket to watch
\r
56 /// \param Socket : Socket to add
\r
58 ////////////////////////////////////////////////////////////
\r
59 void Add(SocketHelper::SocketType Socket);
\r
61 ////////////////////////////////////////////////////////////
\r
64 /// \param Socket : Socket to remove
\r
66 ////////////////////////////////////////////////////////////
\r
67 void Remove(SocketHelper::SocketType Socket);
\r
69 ////////////////////////////////////////////////////////////
\r
70 /// Remove all sockets
\r
72 ////////////////////////////////////////////////////////////
\r
75 ////////////////////////////////////////////////////////////
\r
76 /// Wait and collect sockets which are ready for reading.
\r
77 /// This functions will return either when at least one socket
\r
78 /// is ready, or when the given time is out
\r
80 /// \param Timeout : Timeout, in seconds (0 by default : no timeout)
\r
82 /// \return Number of sockets ready to be read
\r
84 ////////////////////////////////////////////////////////////
\r
85 unsigned int Wait(float Timeout = 0.f);
\r
87 ////////////////////////////////////////////////////////////
\r
88 /// After a call to Wait(), get the Index-th socket which is
\r
89 /// ready for reading. The total number of sockets ready
\r
90 /// is the integer returned by the previous call to Wait()
\r
92 /// \param Index : Index of the socket to get
\r
94 /// \return The Index-th socket
\r
96 ////////////////////////////////////////////////////////////
\r
97 SocketHelper::SocketType GetSocketReady(unsigned int Index);
\r
101 ////////////////////////////////////////////////////////////
\r
103 ////////////////////////////////////////////////////////////
\r
104 fd_set mySet; ///< Set of socket to watch
\r
105 fd_set mySetReady; ///< Set of socket which are ready for reading
\r
106 int myMaxSocket; ///< Maximum socket index
\r
112 #endif // SFML_SELECTORBASE_HPP
\r