mirror of
https://github.com/boostorg/circular_buffer.git
synced 2026-02-09 11:02:30 +00:00
Compare commits
14 Commits
20131209-d
...
boost-1.56
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7e233f7b41 | ||
|
|
689e79abd9 | ||
|
|
002f351a9f | ||
|
|
18306aee33 | ||
|
|
c4b62627e7 | ||
|
|
f5303c70d8 | ||
|
|
b896ace67c | ||
|
|
62233c53bb | ||
|
|
fc1d341a26 | ||
|
|
ece1277965 | ||
|
|
33cfe492d9 | ||
|
|
90711fb1fe | ||
|
|
6eb5fd4a3d | ||
|
|
6998f28fda |
@@ -532,6 +532,10 @@ Type: Patches
|
|||||||
|
|
||||||
[section:release Release Notes]
|
[section:release Release Notes]
|
||||||
|
|
||||||
|
[h4 Boost 1.56]
|
||||||
|
|
||||||
|
* C++11 allocator model support implemented by Glen Fernandes using Boost allocator_traits.
|
||||||
|
|
||||||
[h4 Boost 1.55]
|
[h4 Boost 1.55]
|
||||||
|
|
||||||
* Documentation refactored by Paul A. Bristow using Quickbook, Doxygen and Autoindexing.
|
* Documentation refactored by Paul A. Bristow using Quickbook, Doxygen and Autoindexing.
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
// Copyright (c) 2003-2008 Jan Gaspar
|
// Copyright (c) 2003-2008 Jan Gaspar
|
||||||
// Copyright (c) 2013 Paul A. Bristow // Doxygen comments changed.
|
// Copyright (c) 2013 Paul A. Bristow // Doxygen comments changed.
|
||||||
// Copyright (c) 2013 Antony Polukhin // Move semantics implementation.
|
// Copyright (c) 2013 Antony Polukhin // Move semantics implementation.
|
||||||
|
// Copyright (c) 2014 Glen Fernandes // C++11 allocator model support.
|
||||||
|
|
||||||
// Use, modification, and distribution is subject to the Boost Software
|
// Use, modification, and distribution is subject to the Boost Software
|
||||||
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
@@ -20,6 +20,7 @@
|
|||||||
#include <boost/call_traits.hpp>
|
#include <boost/call_traits.hpp>
|
||||||
#include <boost/concept_check.hpp>
|
#include <boost/concept_check.hpp>
|
||||||
#include <boost/limits.hpp>
|
#include <boost/limits.hpp>
|
||||||
|
#include <boost/container/allocator_traits.hpp>
|
||||||
#include <boost/iterator/reverse_iterator.hpp>
|
#include <boost/iterator/reverse_iterator.hpp>
|
||||||
#include <boost/iterator/iterator_traits.hpp>
|
#include <boost/iterator/iterator_traits.hpp>
|
||||||
#include <boost/type_traits/is_stateless.hpp>
|
#include <boost/type_traits/is_stateless.hpp>
|
||||||
@@ -30,10 +31,12 @@
|
|||||||
#include <boost/type_traits/is_copy_constructible.hpp>
|
#include <boost/type_traits/is_copy_constructible.hpp>
|
||||||
#include <boost/type_traits/conditional.hpp>
|
#include <boost/type_traits/conditional.hpp>
|
||||||
#include <boost/move/move.hpp>
|
#include <boost/move/move.hpp>
|
||||||
|
#include <boost/utility/addressof.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <deque>
|
#include <deque>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
#if BOOST_WORKAROUND(__MWERKS__, BOOST_TESTED_AT(0x3205))
|
#if BOOST_WORKAROUND(__MWERKS__, BOOST_TESTED_AT(0x3205))
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -92,31 +95,31 @@ public:
|
|||||||
typedef circular_buffer<T, Alloc> this_type;
|
typedef circular_buffer<T, Alloc> this_type;
|
||||||
|
|
||||||
//! The type of elements stored in the <code>circular_buffer</code>.
|
//! The type of elements stored in the <code>circular_buffer</code>.
|
||||||
typedef typename Alloc::value_type value_type;
|
typedef typename boost::container::allocator_traits<Alloc>::value_type value_type;
|
||||||
|
|
||||||
//! A pointer to an element.
|
//! A pointer to an element.
|
||||||
typedef typename Alloc::pointer pointer;
|
typedef typename boost::container::allocator_traits<Alloc>::pointer pointer;
|
||||||
|
|
||||||
//! A const pointer to the element.
|
//! A const pointer to the element.
|
||||||
typedef typename Alloc::const_pointer const_pointer;
|
typedef typename boost::container::allocator_traits<Alloc>::const_pointer const_pointer;
|
||||||
|
|
||||||
//! A reference to an element.
|
//! A reference to an element.
|
||||||
typedef typename Alloc::reference reference;
|
typedef typename boost::container::allocator_traits<Alloc>::reference reference;
|
||||||
|
|
||||||
//! A const reference to an element.
|
//! A const reference to an element.
|
||||||
typedef typename Alloc::const_reference const_reference;
|
typedef typename boost::container::allocator_traits<Alloc>::const_reference const_reference;
|
||||||
|
|
||||||
//! The distance type.
|
//! The distance type.
|
||||||
/*!
|
/*!
|
||||||
(A signed integral type used to represent the distance between two iterators.)
|
(A signed integral type used to represent the distance between two iterators.)
|
||||||
*/
|
*/
|
||||||
typedef typename Alloc::difference_type difference_type;
|
typedef typename boost::container::allocator_traits<Alloc>::difference_type difference_type;
|
||||||
|
|
||||||
//! The size type.
|
//! The size type.
|
||||||
/*!
|
/*!
|
||||||
(An unsigned integral type that can represent any non-negative value of the container's distance type.)
|
(An unsigned integral type that can represent any non-negative value of the container's distance type.)
|
||||||
*/
|
*/
|
||||||
typedef typename Alloc::size_type size_type;
|
typedef typename boost::container::allocator_traits<Alloc>::size_type size_type;
|
||||||
|
|
||||||
//! The type of an allocator used in the <code>circular_buffer</code>.
|
//! The type of an allocator used in the <code>circular_buffer</code>.
|
||||||
typedef Alloc allocator_type;
|
typedef Alloc allocator_type;
|
||||||
@@ -124,10 +127,10 @@ public:
|
|||||||
// Iterators
|
// Iterators
|
||||||
|
|
||||||
//! A const (random access) iterator used to iterate through the <code>circular_buffer</code>.
|
//! A const (random access) iterator used to iterate through the <code>circular_buffer</code>.
|
||||||
typedef cb_details::iterator< circular_buffer<T, Alloc>, cb_details::const_traits<Alloc> > const_iterator;
|
typedef cb_details::iterator< circular_buffer<T, Alloc>, cb_details::const_traits<boost::container::allocator_traits<Alloc> > > const_iterator;
|
||||||
|
|
||||||
//! A (random access) iterator used to iterate through the <code>circular_buffer</code>.
|
//! A (random access) iterator used to iterate through the <code>circular_buffer</code>.
|
||||||
typedef cb_details::iterator< circular_buffer<T, Alloc>, cb_details::nonconst_traits<Alloc> > iterator;
|
typedef cb_details::iterator< circular_buffer<T, Alloc>, cb_details::nonconst_traits<boost::container::allocator_traits<Alloc> > > iterator;
|
||||||
|
|
||||||
//! A const iterator used to iterate backwards through a <code>circular_buffer</code>.
|
//! A const iterator used to iterate backwards through a <code>circular_buffer</code>.
|
||||||
typedef boost::reverse_iterator<const_iterator> const_reverse_iterator;
|
typedef boost::reverse_iterator<const_iterator> const_reverse_iterator;
|
||||||
@@ -679,7 +682,7 @@ public:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (is_uninitialized(dest)) {
|
if (is_uninitialized(dest)) {
|
||||||
cb_details::do_construct<value_type>(dest, this_type::move_if_noexcept(*src), m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*dest), this_type::move_if_noexcept(*src));
|
||||||
++constructed;
|
++constructed;
|
||||||
} else {
|
} else {
|
||||||
value_type tmp = this_type::move_if_noexcept(*src);
|
value_type tmp = this_type::move_if_noexcept(*src);
|
||||||
@@ -800,7 +803,7 @@ public:
|
|||||||
\sa <code>size()</code>, <code>capacity()</code>, <code>reserve()</code>
|
\sa <code>size()</code>, <code>capacity()</code>, <code>reserve()</code>
|
||||||
*/
|
*/
|
||||||
size_type max_size() const BOOST_NOEXCEPT {
|
size_type max_size() const BOOST_NOEXCEPT {
|
||||||
return (std::min<size_type>)(m_alloc.max_size(), (std::numeric_limits<difference_type>::max)());
|
return (std::min<size_type>)(boost::container::allocator_traits<Alloc>::max_size(m_alloc), (std::numeric_limits<difference_type>::max)());
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Is the <code>circular_buffer</code> empty?
|
//! Is the <code>circular_buffer</code> empty?
|
||||||
@@ -1435,7 +1438,7 @@ private:
|
|||||||
increment(m_last);
|
increment(m_last);
|
||||||
m_first = m_last;
|
m_first = m_last;
|
||||||
} else {
|
} else {
|
||||||
cb_details::do_construct<value_type>(m_last, static_cast<ValT>(item), m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*m_last), static_cast<ValT>(item));
|
||||||
increment(m_last);
|
increment(m_last);
|
||||||
++m_size;
|
++m_size;
|
||||||
}
|
}
|
||||||
@@ -1452,7 +1455,7 @@ private:
|
|||||||
m_last = m_first;
|
m_last = m_first;
|
||||||
} else {
|
} else {
|
||||||
decrement(m_first);
|
decrement(m_first);
|
||||||
cb_details::do_construct<value_type>(m_first, static_cast<ValT>(item), m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*m_first), static_cast<ValT>(item));
|
||||||
++m_size;
|
++m_size;
|
||||||
}
|
}
|
||||||
} BOOST_CATCH(...) {
|
} BOOST_CATCH(...) {
|
||||||
@@ -2385,11 +2388,11 @@ private:
|
|||||||
if (n > max_size())
|
if (n > max_size())
|
||||||
throw_exception(std::length_error("circular_buffer"));
|
throw_exception(std::length_error("circular_buffer"));
|
||||||
#if BOOST_CB_ENABLE_DEBUG
|
#if BOOST_CB_ENABLE_DEBUG
|
||||||
pointer p = (n == 0) ? 0 : m_alloc.allocate(n, 0);
|
pointer p = (n == 0) ? 0 : m_alloc.allocate(n);
|
||||||
cb_details::do_fill_uninitialized_memory(p, sizeof(value_type) * n);
|
cb_details::do_fill_uninitialized_memory(p, sizeof(value_type) * n);
|
||||||
return p;
|
return p;
|
||||||
#else
|
#else
|
||||||
return (n == 0) ? 0 : m_alloc.allocate(n, 0);
|
return (n == 0) ? 0 : m_alloc.allocate(n);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2427,7 +2430,7 @@ private:
|
|||||||
*/
|
*/
|
||||||
void construct_or_replace(bool construct, pointer pos, param_value_type item) {
|
void construct_or_replace(bool construct, pointer pos, param_value_type item) {
|
||||||
if (construct)
|
if (construct)
|
||||||
cb_details::do_construct<value_type>(pos, item, m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*pos), item);
|
||||||
else
|
else
|
||||||
replace(pos, item);
|
replace(pos, item);
|
||||||
}
|
}
|
||||||
@@ -2439,14 +2442,14 @@ private:
|
|||||||
*/
|
*/
|
||||||
void construct_or_replace(bool construct, pointer pos, rvalue_type item) {
|
void construct_or_replace(bool construct, pointer pos, rvalue_type item) {
|
||||||
if (construct)
|
if (construct)
|
||||||
cb_details::do_construct<value_type>(pos, boost::move(item), m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*pos), boost::move(item));
|
||||||
else
|
else
|
||||||
replace(pos, boost::move(item));
|
replace(pos, boost::move(item));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Destroy an item.
|
//! Destroy an item.
|
||||||
void destroy_item(pointer p) {
|
void destroy_item(pointer p) {
|
||||||
m_alloc.destroy(p);
|
boost::container::allocator_traits<Alloc>::destroy(m_alloc, boost::addressof(*p));
|
||||||
#if BOOST_CB_ENABLE_DEBUG
|
#if BOOST_CB_ENABLE_DEBUG
|
||||||
invalidate_iterators(iterator(this, p));
|
invalidate_iterators(iterator(this, p));
|
||||||
cb_details::do_fill_uninitialized_memory(p, sizeof(value_type));
|
cb_details::do_fill_uninitialized_memory(p, sizeof(value_type));
|
||||||
@@ -2579,7 +2582,7 @@ private:
|
|||||||
if (buffer_capacity == 0)
|
if (buffer_capacity == 0)
|
||||||
return;
|
return;
|
||||||
while (first != last && !full()) {
|
while (first != last && !full()) {
|
||||||
cb_details::do_construct<value_type>(m_last, *first++, m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*m_last), *first++);
|
||||||
increment(m_last);
|
increment(m_last);
|
||||||
++m_size;
|
++m_size;
|
||||||
}
|
}
|
||||||
@@ -2844,7 +2847,7 @@ private:
|
|||||||
pointer p = m_last;
|
pointer p = m_last;
|
||||||
BOOST_TRY {
|
BOOST_TRY {
|
||||||
for (; ii < construct; ++ii, increment(p))
|
for (; ii < construct; ++ii, increment(p))
|
||||||
cb_details::do_construct<value_type>(p, *wrapper(), m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*p), *wrapper());
|
||||||
for (;ii < n; ++ii, increment(p))
|
for (;ii < n; ++ii, increment(p))
|
||||||
replace(p, *wrapper());
|
replace(p, *wrapper());
|
||||||
} BOOST_CATCH(...) {
|
} BOOST_CATCH(...) {
|
||||||
@@ -2938,7 +2941,7 @@ private:
|
|||||||
for (;ii > construct; --ii, increment(p))
|
for (;ii > construct; --ii, increment(p))
|
||||||
replace(p, *wrapper());
|
replace(p, *wrapper());
|
||||||
for (; ii > 0; --ii, increment(p))
|
for (; ii > 0; --ii, increment(p))
|
||||||
cb_details::do_construct<value_type>(p, *wrapper(), m_alloc);
|
boost::container::allocator_traits<Alloc>::construct(m_alloc, boost::addressof(*p), *wrapper());
|
||||||
} BOOST_CATCH(...) {
|
} BOOST_CATCH(...) {
|
||||||
size_type constructed = ii < construct ? construct - ii : 0;
|
size_type constructed = ii < construct ? construct - ii : 0;
|
||||||
m_last = add(m_last, constructed);
|
m_last = add(m_last, constructed);
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
// Helper classes and functions for the circular buffer.
|
// Helper classes and functions for the circular buffer.
|
||||||
|
|
||||||
// Copyright (c) 2003-2008 Jan Gaspar
|
// Copyright (c) 2003-2008 Jan Gaspar
|
||||||
|
// Copyright (c) 2014 Glen Fernandes // C++11 allocator model support.
|
||||||
|
|
||||||
// Use, modification, and distribution is subject to the Boost Software
|
// Use, modification, and distribution is subject to the Boost Software
|
||||||
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
@@ -15,8 +16,10 @@
|
|||||||
|
|
||||||
#include <boost/iterator.hpp>
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/throw_exception.hpp>
|
#include <boost/throw_exception.hpp>
|
||||||
|
#include <boost/container/allocator_traits.hpp>
|
||||||
#include <boost/move/move.hpp>
|
#include <boost/move/move.hpp>
|
||||||
#include <boost/type_traits/is_nothrow_move_constructible.hpp>
|
#include <boost/type_traits/is_nothrow_move_constructible.hpp>
|
||||||
|
#include <boost/utility/addressof.hpp>
|
||||||
#include <boost/detail/no_exceptions_support.hpp>
|
#include <boost/detail/no_exceptions_support.hpp>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
|
||||||
@@ -44,37 +47,6 @@ ForwardIterator uninitialized_copy(InputIterator first, InputIterator last, Forw
|
|||||||
template<class InputIterator, class ForwardIterator, class Alloc>
|
template<class InputIterator, class ForwardIterator, class Alloc>
|
||||||
ForwardIterator uninitialized_move_if_noexcept(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& a);
|
ForwardIterator uninitialized_move_if_noexcept(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& a);
|
||||||
|
|
||||||
|
|
||||||
//! Those `do_construct` methods are required because in C++03 default allocators
|
|
||||||
//! have `construct` method that accepts second parameter in as a const reference;
|
|
||||||
//! while move-only types emulated by Boost.Move require constructor that accepts
|
|
||||||
//! a non-const reference.
|
|
||||||
//!
|
|
||||||
//! So when we need to call `construct` and pointer to value_type is provided, we
|
|
||||||
//! assume that it is safe to call placement new instead of Alloc::construct.
|
|
||||||
//! Otherwise we are asume that user has made his own allocator or uses allocator
|
|
||||||
//! from other libraries. In that case it's users ability to provide Alloc::construct
|
|
||||||
//! with non-const reference parameter or just do not use move-only types.
|
|
||||||
template <class ValueType, class Alloc>
|
|
||||||
inline void do_construct(ValueType* p, BOOST_RV_REF(ValueType) item, Alloc&) {
|
|
||||||
::new (p) ValueType(boost::move(item));
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class ValueType, class Alloc>
|
|
||||||
inline void do_construct(ValueType* p, const ValueType& item, Alloc&) {
|
|
||||||
::new (p) ValueType(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class ValueType, class Alloc, class PointerT>
|
|
||||||
inline void do_construct(PointerT& p, BOOST_RV_REF(ValueType) item, Alloc& a) {
|
|
||||||
a.construct(p, boost::move(item));
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class ValueType, class Alloc, class PointerT>
|
|
||||||
inline void do_construct(PointerT& p, const ValueType& item, Alloc& a) {
|
|
||||||
a.construct(p, item);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\struct const_traits
|
\struct const_traits
|
||||||
\brief Defines the data types for a const iterator.
|
\brief Defines the data types for a const iterator.
|
||||||
@@ -141,7 +113,7 @@ private:
|
|||||||
*/
|
*/
|
||||||
template <class Value, class Alloc>
|
template <class Value, class Alloc>
|
||||||
struct assign_n {
|
struct assign_n {
|
||||||
typedef typename Alloc::size_type size_type;
|
typedef typename boost::container::allocator_traits<Alloc>::size_type size_type;
|
||||||
size_type m_n;
|
size_type m_n;
|
||||||
Value m_item;
|
Value m_item;
|
||||||
Alloc& m_alloc;
|
Alloc& m_alloc;
|
||||||
@@ -464,10 +436,10 @@ inline ForwardIterator uninitialized_copy(InputIterator first, InputIterator las
|
|||||||
ForwardIterator next = dest;
|
ForwardIterator next = dest;
|
||||||
BOOST_TRY {
|
BOOST_TRY {
|
||||||
for (; first != last; ++first, ++dest)
|
for (; first != last; ++first, ++dest)
|
||||||
do_construct<typename Alloc::value_type>(dest, *first, a);
|
boost::container::allocator_traits<Alloc>::construct(a, boost::addressof(*dest), *first);
|
||||||
} BOOST_CATCH(...) {
|
} BOOST_CATCH(...) {
|
||||||
for (; next != dest; ++next)
|
for (; next != dest; ++next)
|
||||||
a.destroy(next);
|
boost::container::allocator_traits<Alloc>::destroy(a, boost::addressof(*next));
|
||||||
BOOST_RETHROW
|
BOOST_RETHROW
|
||||||
}
|
}
|
||||||
BOOST_CATCH_END
|
BOOST_CATCH_END
|
||||||
@@ -478,7 +450,7 @@ template<class InputIterator, class ForwardIterator, class Alloc>
|
|||||||
ForwardIterator uninitialized_move_if_noexcept_impl(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& a,
|
ForwardIterator uninitialized_move_if_noexcept_impl(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& a,
|
||||||
true_type) {
|
true_type) {
|
||||||
for (; first != last; ++first, ++dest)
|
for (; first != last; ++first, ++dest)
|
||||||
do_construct<typename Alloc::value_type>(dest, boost::move(*first), a);
|
boost::container::allocator_traits<Alloc>::construct(a, boost::addressof(*dest), boost::move(*first));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -494,7 +466,7 @@ ForwardIterator uninitialized_move_if_noexcept_impl(InputIterator first, InputIt
|
|||||||
*/
|
*/
|
||||||
template<class InputIterator, class ForwardIterator, class Alloc>
|
template<class InputIterator, class ForwardIterator, class Alloc>
|
||||||
ForwardIterator uninitialized_move_if_noexcept(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& a) {
|
ForwardIterator uninitialized_move_if_noexcept(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& a) {
|
||||||
typedef typename boost::is_nothrow_move_constructible<typename Alloc::value_type>::type tag_t;
|
typedef typename boost::is_nothrow_move_constructible<typename boost::container::allocator_traits<Alloc>::value_type>::type tag_t;
|
||||||
return uninitialized_move_if_noexcept_impl(first, last, dest, a, tag_t());
|
return uninitialized_move_if_noexcept_impl(first, last, dest, a, tag_t());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -507,10 +479,10 @@ inline void uninitialized_fill_n_with_alloc(ForwardIterator first, Diff n, const
|
|||||||
ForwardIterator next = first;
|
ForwardIterator next = first;
|
||||||
BOOST_TRY {
|
BOOST_TRY {
|
||||||
for (; n > 0; ++first, --n)
|
for (; n > 0; ++first, --n)
|
||||||
do_construct<typename Alloc::value_type>(first, item, alloc);
|
boost::container::allocator_traits<Alloc>::construct(alloc, boost::addressof(*first), item);
|
||||||
} BOOST_CATCH(...) {
|
} BOOST_CATCH(...) {
|
||||||
for (; next != first; ++next)
|
for (; next != first; ++next)
|
||||||
alloc.destroy(next);
|
boost::container::allocator_traits<Alloc>::destroy(alloc, boost::addressof(*next));
|
||||||
BOOST_RETHROW
|
BOOST_RETHROW
|
||||||
}
|
}
|
||||||
BOOST_CATCH_END
|
BOOST_CATCH_END
|
||||||
|
|||||||
@@ -11,7 +11,7 @@
|
|||||||
#if !defined(BOOST_CIRCULAR_BUFFER_FWD_HPP)
|
#if !defined(BOOST_CIRCULAR_BUFFER_FWD_HPP)
|
||||||
#define BOOST_CIRCULAR_BUFFER_FWD_HPP
|
#define BOOST_CIRCULAR_BUFFER_FWD_HPP
|
||||||
|
|
||||||
#if defined(_MSC_VER)
|
#if defined(_MSC_VER) && _MSC_VER >= 1200
|
||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|||||||
117
test/common.ipp
117
test/common.ipp
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
// Copyright (c) 2003-2008 Jan Gaspar
|
// Copyright (c) 2003-2008 Jan Gaspar
|
||||||
// Copyright (c) 2013 Antony Polukhin
|
// Copyright (c) 2013 Antony Polukhin
|
||||||
|
// Copyright (c) 2014 Glen Fernandes // C++11 allocator model support.
|
||||||
|
|
||||||
// Use, modification, and distribution is subject to the Boost Software
|
// Use, modification, and distribution is subject to the Boost Software
|
||||||
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
@@ -163,50 +164,59 @@ public:
|
|||||||
typedef typename base_t::size_type size_type;
|
typedef typename base_t::size_type size_type;
|
||||||
typedef typename base_t::difference_type difference_type;
|
typedef typename base_t::difference_type difference_type;
|
||||||
|
|
||||||
struct const_pointer;
|
private:
|
||||||
struct pointer {
|
template<class U>
|
||||||
pointer(){}
|
struct const_pointer_;
|
||||||
pointer(void* p) : hidden_ptr_((T*)p) {}
|
|
||||||
difference_type operator-(const const_pointer& rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
|
||||||
difference_type operator-(pointer rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
|
||||||
pointer operator-(size_type rhs) const { return hidden_ptr_ - rhs; }
|
|
||||||
bool operator == (pointer rhs) const { return hidden_ptr_ == rhs.hidden_ptr_; }
|
|
||||||
bool operator != (pointer rhs) const { return hidden_ptr_ != rhs.hidden_ptr_; }
|
|
||||||
bool operator < (pointer rhs) const { return hidden_ptr_ < rhs.hidden_ptr_; }
|
|
||||||
bool operator >= (pointer rhs) const { return hidden_ptr_ >= rhs.hidden_ptr_; }
|
|
||||||
pointer& operator++() { ++hidden_ptr_; return *this; }
|
|
||||||
pointer& operator--() { --hidden_ptr_; return *this; }
|
|
||||||
pointer& operator+=(size_type s) { hidden_ptr_ += s; return *this; }
|
|
||||||
pointer operator+(size_type s) const { return hidden_ptr_ + s; }
|
|
||||||
pointer operator++(int) { pointer p = *this; ++hidden_ptr_; return p; }
|
|
||||||
pointer operator--(int) { pointer p = *this; --hidden_ptr_; return p; }
|
|
||||||
T& operator*() const { return *hidden_ptr_; }
|
|
||||||
|
|
||||||
T* hidden_ptr_;
|
template<class U>
|
||||||
|
struct pointer_ {
|
||||||
|
pointer_(){}
|
||||||
|
pointer_(void* p) : hidden_ptr_((U*)p) {}
|
||||||
|
difference_type operator-(const const_pointer_<U>& rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
||||||
|
difference_type operator-(pointer_ rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
||||||
|
pointer_ operator-(size_type rhs) const { return hidden_ptr_ - rhs; }
|
||||||
|
bool operator == (pointer_ rhs) const { return hidden_ptr_ == rhs.hidden_ptr_; }
|
||||||
|
bool operator != (pointer_ rhs) const { return hidden_ptr_ != rhs.hidden_ptr_; }
|
||||||
|
bool operator < (pointer_ rhs) const { return hidden_ptr_ < rhs.hidden_ptr_; }
|
||||||
|
bool operator >= (pointer_ rhs) const { return hidden_ptr_ >= rhs.hidden_ptr_; }
|
||||||
|
pointer_& operator++() { ++hidden_ptr_; return *this; }
|
||||||
|
pointer_& operator--() { --hidden_ptr_; return *this; }
|
||||||
|
pointer_& operator+=(size_type s) { hidden_ptr_ += s; return *this; }
|
||||||
|
pointer_ operator+(size_type s) const { return hidden_ptr_ + s; }
|
||||||
|
pointer_ operator++(int) { pointer_ p = *this; ++hidden_ptr_; return p; }
|
||||||
|
pointer_ operator--(int) { pointer_ p = *this; --hidden_ptr_; return p; }
|
||||||
|
U& operator*() const { return *hidden_ptr_; }
|
||||||
|
|
||||||
|
U* hidden_ptr_;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct const_pointer {
|
template<class U>
|
||||||
const_pointer(){}
|
struct const_pointer_ {
|
||||||
const_pointer(pointer p) : hidden_ptr_(p.hidden_ptr_) {}
|
const_pointer_(){}
|
||||||
const_pointer(const void* p) : hidden_ptr_((const T*)p) {}
|
const_pointer_(pointer_<U> p) : hidden_ptr_(p.hidden_ptr_) {}
|
||||||
difference_type operator-(pointer rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
const_pointer_(const void* p) : hidden_ptr_((const U*)p) {}
|
||||||
difference_type operator-(const_pointer rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
difference_type operator-(pointer_<U> rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
||||||
const_pointer operator-(size_type rhs) const { return hidden_ptr_ - rhs; }
|
difference_type operator-(const_pointer_ rhs) const { return hidden_ptr_ - rhs.hidden_ptr_; }
|
||||||
bool operator == (const_pointer rhs) const { return hidden_ptr_ == rhs.hidden_ptr_; }
|
const_pointer_ operator-(size_type rhs) const { return hidden_ptr_ - rhs; }
|
||||||
bool operator != (const_pointer rhs) const { return hidden_ptr_ != rhs.hidden_ptr_; }
|
bool operator == (const_pointer_ rhs) const { return hidden_ptr_ == rhs.hidden_ptr_; }
|
||||||
bool operator < (const_pointer rhs) const { return hidden_ptr_ < rhs.hidden_ptr_; }
|
bool operator != (const_pointer_ rhs) const { return hidden_ptr_ != rhs.hidden_ptr_; }
|
||||||
bool operator >= (const_pointer rhs) const { return hidden_ptr_ >= rhs.hidden_ptr_; }
|
bool operator < (const_pointer_ rhs) const { return hidden_ptr_ < rhs.hidden_ptr_; }
|
||||||
const_pointer& operator++() { ++hidden_ptr_; return *this; }
|
bool operator >= (const_pointer_ rhs) const { return hidden_ptr_ >= rhs.hidden_ptr_; }
|
||||||
const_pointer& operator--() { --hidden_ptr_; return *this; }
|
const_pointer_& operator++() { ++hidden_ptr_; return *this; }
|
||||||
const_pointer& operator+=(size_type s) { hidden_ptr_ += s; return hidden_ptr_; }
|
const_pointer_& operator--() { --hidden_ptr_; return *this; }
|
||||||
const_pointer operator+(size_type s) const { return hidden_ptr_ + s; }
|
const_pointer_& operator+=(size_type s) { hidden_ptr_ += s; return hidden_ptr_; }
|
||||||
const_pointer operator++(int) { const_pointer p = *this; ++hidden_ptr_; return p; }
|
const_pointer_ operator+(size_type s) const { return hidden_ptr_ + s; }
|
||||||
const_pointer operator--(int) { const_pointer p = *this; --hidden_ptr_; return p; }
|
const_pointer_ operator++(int) { const_pointer_ p = *this; ++hidden_ptr_; return p; }
|
||||||
const T& operator*() const { return *hidden_ptr_; }
|
const_pointer_ operator--(int) { const_pointer_ p = *this; --hidden_ptr_; return p; }
|
||||||
|
const U& operator*() const { return *hidden_ptr_; }
|
||||||
|
|
||||||
const T* hidden_ptr_;
|
const U* hidden_ptr_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
public:
|
||||||
|
typedef pointer_<T> pointer;
|
||||||
|
typedef const_pointer_<T> const_pointer;
|
||||||
|
|
||||||
template<class T2>
|
template<class T2>
|
||||||
struct rebind
|
struct rebind
|
||||||
{
|
{
|
||||||
@@ -248,6 +258,34 @@ void allocator_test() {
|
|||||||
generic_test(cb_a);
|
generic_test(cb_a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !defined(BOOST_NO_CXX11_ALLOCATOR)
|
||||||
|
template<class T>
|
||||||
|
class cxx11_allocator {
|
||||||
|
public:
|
||||||
|
typedef T value_type;
|
||||||
|
|
||||||
|
cxx11_allocator() {
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class U>
|
||||||
|
cxx11_allocator(const cxx11_allocator<U> &) {
|
||||||
|
}
|
||||||
|
|
||||||
|
T* allocate(std::size_t n) {
|
||||||
|
return static_cast<T*>(::operator new(n * sizeof(T)));
|
||||||
|
}
|
||||||
|
|
||||||
|
void deallocate(T * p, std::size_t n) {
|
||||||
|
::operator delete( p );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void cxx11_allocator_test() {
|
||||||
|
CB_CONTAINER<MyInteger, cxx11_allocator<MyInteger> > cb(10, 0);
|
||||||
|
generic_test(cb);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void begin_and_end_test() {
|
void begin_and_end_test() {
|
||||||
|
|
||||||
vector<int> v;
|
vector<int> v;
|
||||||
@@ -2440,5 +2478,8 @@ void add_common_tests(test_suite* tests) {
|
|||||||
tests->add(BOOST_TEST_CASE(&move_container_on_cpp11));
|
tests->add(BOOST_TEST_CASE(&move_container_on_cpp11));
|
||||||
tests->add(BOOST_TEST_CASE(&move_container_values_noexcept));
|
tests->add(BOOST_TEST_CASE(&move_container_values_noexcept));
|
||||||
tests->add(BOOST_TEST_CASE(&check_containers_exception_specifications));
|
tests->add(BOOST_TEST_CASE(&check_containers_exception_specifications));
|
||||||
|
#if !defined(BOOST_NO_CXX11_ALLOCATOR)
|
||||||
|
tests->add(BOOST_TEST_CASE(&cxx11_allocator_test));
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user