1 ////////////////////////////////////////////////////////////
3 // SFML - Simple and Fast Multimedia Library
4 // Copyright (C) 2007-2013 Laurent Gomila (laurent.gom@gmail.com)
6 // This software is provided 'as-is', without any express or implied warranty.
7 // In no event will the authors be held liable for any damages arising from the use of this software.
9 // Permission is granted to anyone to use this software for any purpose,
10 // including commercial applications, and to alter it and redistribute it freely,
11 // subject to the following restrictions:
13 // 1. The origin of this software must not be misrepresented;
14 // you must not claim that you wrote the original software.
15 // If you use this software in a product, an acknowledgment
16 // in the product documentation would be appreciated but is not required.
18 // 2. Altered source versions must be plainly marked as such,
19 // and must not be misrepresented as being the original software.
21 // 3. This notice may not be removed or altered from any source distribution.
23 ////////////////////////////////////////////////////////////
25 #ifndef SFML_THREADLOCAL_HPP
26 #define SFML_THREADLOCAL_HPP
28 ////////////////////////////////////////////////////////////
30 ////////////////////////////////////////////////////////////
31 #include <SFML/System/Export.hpp>
32 #include <SFML/System/NonCopyable.hpp>
40 class ThreadLocalImpl;
43 ////////////////////////////////////////////////////////////
44 /// \brief Defines variables with thread-local storage
46 ////////////////////////////////////////////////////////////
47 class SFML_SYSTEM_API ThreadLocal : NonCopyable
51 ////////////////////////////////////////////////////////////
52 /// \brief Default constructor
54 /// \param value Optional value to initalize the variable
56 ////////////////////////////////////////////////////////////
57 ThreadLocal(void* value = NULL);
59 ////////////////////////////////////////////////////////////
62 ////////////////////////////////////////////////////////////
65 ////////////////////////////////////////////////////////////
66 /// \brief Set the thread-specific value of the variable
68 /// \param value Value of the variable for the current thread
70 ////////////////////////////////////////////////////////////
71 void setValue(void* value);
73 ////////////////////////////////////////////////////////////
74 /// \brief Retrieve the thread-specific value of the variable
76 /// \return Value of the variable for the current thread
78 ////////////////////////////////////////////////////////////
79 void* getValue() const;
83 ////////////////////////////////////////////////////////////
85 ////////////////////////////////////////////////////////////
86 priv::ThreadLocalImpl* m_impl; ///< Pointer to the OS specific implementation
92 #endif // SFML_THREADLOCAL_HPP
95 ////////////////////////////////////////////////////////////
96 /// \class sf::ThreadLocal
99 /// This class manipulates void* parameters and thus is not
100 /// appropriate for strongly-typed variables. You should rather
101 /// use the sf::ThreadLocalPtr template class.
103 ////////////////////////////////////////////////////////////