| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- // boost lockfree
- //
- // Copyright (C) 2011 Tim Blechmann
- //
- // Distributed under the Boost Software License, Version 1.0. (See
- // accompanying file LICENSE_1_0.txt or copy at
- // http://www.boost.org/LICENSE_1_0.txt)
- #ifndef BOOST_LOCKFREE_POLICIES_HPP_INCLUDED
- #define BOOST_LOCKFREE_POLICIES_HPP_INCLUDED
- #include <boost/config.hpp>
- #ifdef BOOST_HAS_PRAGMA_ONCE
- # pragma once
- #endif
- #include <boost/parameter/template_keyword.hpp>
- #include <type_traits>
- namespace boost { namespace lockfree {
- #ifndef BOOST_DOXYGEN_INVOKED
- namespace tag {
- struct allocator;
- struct fixed_sized;
- struct capacity;
- struct allow_multiple_reads;
- } // namespace tag
- template < bool IsFixedSized >
- struct fixed_sized : boost::parameter::template_keyword< tag::fixed_sized, std::integral_constant< bool, IsFixedSized > >
- {};
- template < size_t Size >
- struct capacity : boost::parameter::template_keyword< tag::capacity, std::integral_constant< size_t, Size > >
- {};
- template < class Alloc >
- struct allocator : boost::parameter::template_keyword< tag::allocator, Alloc >
- {};
- template < bool AllowMultipleReads >
- struct allow_multiple_reads :
- boost::parameter::template_keyword< tag::allow_multiple_reads, std::integral_constant< bool, AllowMultipleReads > >
- {};
- #else
- /** Configures a data structure as \b fixed-sized.
- *
- * The internal nodes are stored inside an array and they are addressed by array indexing. This limits the possible
- * size of the queue to the number of elements that can be addressed by the index type (usually 2**16-2), but on
- * platforms that lack double-width compare-and-exchange instructions, this is the best way to achieve lock-freedom.
- * This implies that a data structure is bounded.
- * */
- template < bool IsFixedSized >
- struct fixed_sized;
- /** Sets the \b capacity of a data structure at compile-time.
- *
- * This implies that a data structure is bounded and fixed-sized.
- * */
- template < size_t Size >
- struct capacity;
- /** Defines the \b allocator type of a data structure.
- * */
- template < class Alloc >
- struct allocator;
- /** Configures the spsc_value to consume the value multiple times
- *
- * Caveats:
- * * one cannot move the value out
- * */
- template < bool AllowMultipleReads >
- struct allow_multiple_reads;
- #endif
- }} // namespace boost::lockfree
- #endif /* BOOST_LOCKFREE_POLICIES_HPP_INCLUDED */
|