/* This file is part of Raul. Copyright 2007-2012 David Robillard Raul is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. Raul is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Raul. If not, see . */ #ifndef RAUL_ATOMIC_PTR_HPP #define RAUL_ATOMIC_PTR_HPP #include #ifdef RAUL_CPP0x #include namespace Raul { /** Atomic pointer. * \ingroup raul */ template class AtomicPtr { public: inline AtomicPtr() : _val(NULL) {} inline AtomicPtr(const AtomicPtr& copy) : _val(copy.get()) {} inline T* get() const { return static_cast(_val.load()); } inline void operator=(T* val) { _val = val; } /** Set value to newval iff current value is oldval */ inline bool compare_and_exchange(void* oldval, void* newval) { return _val.compare_exchange_strong(oldval, newval); } private: std::atomic _val; }; } // namespace Raul #else // !RAUL_CPP0x #include namespace Raul { /** Atomic pointer. * \ingroup raul */ template class AtomicPtr { public: inline AtomicPtr() { g_atomic_pointer_set(static_cast(&_val), NULL); } inline AtomicPtr(const AtomicPtr& copy) { g_atomic_pointer_set(static_cast(&_val), static_cast(copy.get())); } inline T* get() const { return static_cast(g_atomic_pointer_get(static_cast(&_val))); } inline void operator=(T* val) { g_atomic_pointer_set(&_val, static_cast(val)); } /** Set value to newval iff current value is oldval */ inline bool compare_and_exchange(gpointer oldval, gpointer newval) { return g_atomic_pointer_compare_and_exchange(&_val, oldval, newval); } private: mutable volatile gpointer _val; }; } // namespace Raul #endif // RAUL_CPP0x #endif // RAUL_ATOMIC_PTR_HPP