The class template list is an intrusive container that mimics most of the interface of std::list as described in the C++ standard. More...
#include <list.hpp>
Public Types | |
typedef ValueTraits | value_traits |
typedef value_traits::pointer | pointer |
typedef value_traits::const_pointer | const_pointer |
typedef pointer_traits < pointer >::element_type | value_type |
typedef pointer_traits < pointer >::reference | reference |
typedef pointer_traits < const_pointer >::reference | const_reference |
typedef pointer_traits < pointer >::difference_type | difference_type |
typedef SizeType | size_type |
typedef list_iterator < value_traits, false > | iterator |
typedef list_iterator < value_traits, true > | const_iterator |
typedef boost::intrusive::detail::reverse_iterator < iterator > | reverse_iterator |
typedef boost::intrusive::detail::reverse_iterator < const_iterator > | const_reverse_iterator |
typedef value_traits::node_traits | node_traits |
typedef node_traits::node | node |
typedef node_traits::node_ptr | node_ptr |
typedef node_traits::const_node_ptr | const_node_ptr |
typedef circular_list_algorithms < node_traits > | node_algorithms |
typedef HeaderHolder | header_holder_type |
Public Member Functions | |
list_impl (const value_traits &v_traits=value_traits()) | |
Effects: constructs an empty list. More... | |
template<class Iterator > | |
list_impl (Iterator b, Iterator e, const value_traits &v_traits=value_traits()) | |
Requires: Dereferencing iterator must yield an lvalue of type value_type. More... | |
list_impl (BOOST_RV_REF(list_impl) x) | |
Effects: to-do More... | |
list_impl & | operator= (BOOST_RV_REF(list_impl) x) |
Effects: to-do More... | |
~list_impl () | |
Effects: If it's not a safe-mode or an auto-unlink value_type the destructor does nothing (ie. More... | |
void | push_back (reference value) |
Requires: value must be an lvalue. More... | |
void | push_front (reference value) |
Requires: value must be an lvalue. More... | |
void | pop_back () |
Effects: Erases the last element of the list. More... | |
template<class Disposer > | |
void | pop_back_and_dispose (Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
void | pop_front () |
Effects: Erases the first element of the list. More... | |
template<class Disposer > | |
void | pop_front_and_dispose (Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
reference | front () |
Effects: Returns a reference to the first element of the list. More... | |
const_reference | front () const |
Effects: Returns a const_reference to the first element of the list. More... | |
reference | back () |
Effects: Returns a reference to the last element of the list. More... | |
const_reference | back () const |
Effects: Returns a const_reference to the last element of the list. More... | |
iterator | begin () |
Effects: Returns an iterator to the first element contained in the list. More... | |
const_iterator | begin () const |
Effects: Returns a const_iterator to the first element contained in the list. More... | |
const_iterator | cbegin () const |
Effects: Returns a const_iterator to the first element contained in the list. More... | |
iterator | end () |
Effects: Returns an iterator to the end of the list. More... | |
const_iterator | end () const |
Effects: Returns a const_iterator to the end of the list. More... | |
const_iterator | cend () const |
Effects: Returns a constant iterator to the end of the list. More... | |
reverse_iterator | rbegin () |
Effects: Returns a reverse_iterator pointing to the beginning of the reversed list. More... | |
const_reverse_iterator | rbegin () const |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed list. More... | |
const_reverse_iterator | crbegin () const |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed list. More... | |
reverse_iterator | rend () |
Effects: Returns a reverse_iterator pointing to the end of the reversed list. More... | |
const_reverse_iterator | rend () const |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed list. More... | |
const_reverse_iterator | crend () const |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed list. More... | |
size_type | size () const |
Effects: Returns the number of the elements contained in the list. More... | |
bool | empty () const |
Effects: Returns true if the list contains no elements. More... | |
void | swap (list_impl &other) |
Effects: Swaps the elements of x and *this. More... | |
void | shift_backwards (size_type n=1) |
Effects: Moves backwards all the elements, so that the first element becomes the second, the second becomes the third... More... | |
void | shift_forward (size_type n=1) |
Effects: Moves forward all the elements, so that the second element becomes the first, the third becomes the second... More... | |
iterator | erase (const_iterator i) |
Effects: Erases the element pointed by i of the list. More... | |
iterator | erase (const_iterator b, const_iterator e) |
Requires: b and e must be valid iterators to elements in *this. More... | |
iterator | erase (const_iterator b, const_iterator e, size_type n) |
Requires: b and e must be valid iterators to elements in *this. More... | |
template<class Disposer > | |
iterator | erase_and_dispose (const_iterator i, Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
template<class Disposer > | |
iterator | erase_and_dispose (iterator i, Disposer disposer) |
template<class Disposer > | |
iterator | erase_and_dispose (const_iterator b, const_iterator e, Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
void | clear () |
Effects: Erases all the elements of the container. More... | |
template<class Disposer > | |
void | clear_and_dispose (Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
template<class Cloner , class Disposer > | |
void | clone_from (const list_impl &src, Cloner cloner, Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
iterator | insert (const_iterator p, reference value) |
Requires: value must be an lvalue and p must be a valid iterator of *this. More... | |
template<class Iterator > | |
void | insert (const_iterator p, Iterator b, Iterator e) |
Requires: Dereferencing iterator must yield an lvalue of type value_type and p must be a valid iterator of *this. More... | |
template<class Iterator > | |
void | assign (Iterator b, Iterator e) |
Requires: Dereferencing iterator must yield an lvalue of type value_type. More... | |
template<class Iterator , class Disposer > | |
void | dispose_and_assign (Disposer disposer, Iterator b, Iterator e) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
void | splice (const_iterator p, list_impl &x) |
Requires: p must be a valid iterator of *this. More... | |
void | splice (const_iterator p, list_impl &x, const_iterator new_ele) |
Requires: p must be a valid iterator of *this. More... | |
void | splice (const_iterator p, list_impl &x, const_iterator f, const_iterator e) |
Requires: p must be a valid iterator of *this. More... | |
void | splice (const_iterator p, list_impl &x, const_iterator f, const_iterator e, size_type n) |
Requires: p must be a valid iterator of *this. More... | |
void | sort () |
Effects: This function sorts the list *this according to std::less<value_type>. More... | |
template<class Predicate > | |
void | sort (Predicate p) |
Requires: p must be a comparison function that induces a strict weak ordering More... | |
void | merge (list_impl &x) |
Effects: This function removes all of x's elements and inserts them in order into *this according to std::less<value_type>. More... | |
template<class Predicate > | |
void | merge (list_impl &x, Predicate p) |
Requires: p must be a comparison function that induces a strict weak ordering and both *this and x must be sorted according to that ordering The lists x and *this must be distinct. More... | |
void | reverse () |
Effects: Reverses the order of elements in the list. More... | |
void | remove (const_reference value) |
Effects: Removes all the elements that compare equal to value. More... | |
template<class Disposer > | |
void | remove_and_dispose (const_reference value, Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
template<class Pred > | |
void | remove_if (Pred pred) |
Effects: Removes all the elements for which a specified predicate is satisfied. More... | |
template<class Pred , class Disposer > | |
void | remove_and_dispose_if (Pred pred, Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
void | unique () |
Effects: Removes adjacent duplicate elements or adjacent elements that are equal from the list. More... | |
template<class BinaryPredicate > | |
void | unique (BinaryPredicate pred) |
Effects: Removes adjacent duplicate elements or adjacent elements that satisfy some binary predicate from the list. More... | |
template<class Disposer > | |
void | unique_and_dispose (Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
template<class BinaryPredicate , class Disposer > | |
void | unique_and_dispose (BinaryPredicate pred, Disposer disposer) |
Requires: Disposer::operator()(pointer) shouldn't throw. More... | |
iterator | iterator_to (reference value) |
Requires: value must be a reference to a value inserted in a list. More... | |
const_iterator | iterator_to (const_reference value) const |
Requires: value must be a const reference to a value inserted in a list. More... | |
void | check () const |
Effects: Asserts the integrity of the container. More... | |
Static Public Member Functions | |
static list_impl & | container_from_end_iterator (iterator end_iterator) |
Precondition: end_iterator must be a valid end iterator of list. More... | |
static const list_impl & | container_from_end_iterator (const_iterator end_iterator) |
Precondition: end_iterator must be a valid end const_iterator of list. More... | |
static iterator | s_iterator_to (reference value) |
Requires: value must be a reference to a value inserted in a list. More... | |
static const_iterator | s_iterator_to (const_reference value) |
Requires: value must be a const reference to a value inserted in a list. More... | |
Static Public Attributes | |
static const bool | constant_time_size = ConstantTimeSize |
static const bool | stateful_value_traits = detail::is_stateful_value_traits<value_traits>::value |
static const bool | has_container_from_iterator |
The class template list is an intrusive container that mimics most of the interface of std::list as described in the C++ standard.
The template parameter T
is the type to be managed by the container. The user can specify additional options and if no options are provided default options are used.
The container supports the following options: base_hook<>/member_hook<>/value_traits<>
, constant_time_size<>
and size_type<>
.
typedef list_iterator<value_traits, true> boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::const_iterator |
typedef node_traits::const_node_ptr boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::const_node_ptr |
typedef value_traits::const_pointer boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::const_pointer |
typedef pointer_traits<const_pointer>::reference boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::const_reference |
typedef boost::intrusive::detail::reverse_iterator<const_iterator> boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::const_reverse_iterator |
typedef pointer_traits<pointer>::difference_type boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::difference_type |
typedef HeaderHolder boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::header_holder_type |
typedef list_iterator<value_traits, false> boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::iterator |
typedef node_traits::node boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::node |
typedef circular_list_algorithms<node_traits> boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::node_algorithms |
typedef node_traits::node_ptr boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::node_ptr |
typedef value_traits::node_traits boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::node_traits |
typedef value_traits::pointer boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::pointer |
typedef pointer_traits<pointer>::reference boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::reference |
typedef boost::intrusive::detail::reverse_iterator<iterator> boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::reverse_iterator |
typedef SizeType boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::size_type |
typedef ValueTraits boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::value_traits |
typedef pointer_traits<pointer>::element_type boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::value_type |
|
inlineexplicit |
Effects: constructs an empty list.
Complexity: Constant
Throws: If value_traits::node_traits::node constructor throws (this does not happen with predefined Boost.Intrusive hooks).
References boost::intrusive::circular_list_algorithms< NodeTraits >::init_header().
|
inline |
Requires: Dereferencing iterator must yield an lvalue of type value_type.
Effects: Constructs a list equal to the range [first,last).
Complexity: Linear in std::distance(b, e). No copy constructors are called.
Throws: If value_traits::node_traits::node constructor throws (this does not happen with predefined Boost.Intrusive hooks).
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cend(), boost::intrusive::circular_list_algorithms< NodeTraits >::init_header(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::insert().
|
inline |
|
inline |
Effects: If it's not a safe-mode or an auto-unlink value_type the destructor does nothing (ie.
no code is generated). Otherwise it detaches all elements from this. In this case the objects in the list are not deleted (i.e. no destructors are called), but the hooks according to the ValueTraits template parameter are set to their default value.
Complexity: Linear to the number of elements in the list, if it's a safe-mode or auto-unlink value . Otherwise constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear(), and boost::intrusive::circular_list_algorithms< NodeTraits >::init().
|
inline |
Requires: Dereferencing iterator must yield an lvalue of type value_type.
Effects: Clears the list and inserts the range pointed by b and e. No destructors or copy constructors are called.
Throws: Nothing.
Complexity: Linear to the number of elements inserted plus linear to the elements contained in the list if it's a safe-mode or auto-unlink value. Linear to the number of elements inserted in the list otherwise.
Note: Invalidates the iterators (but not the references) to the erased elements.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cend(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::insert().
|
inline |
Effects: Returns a reference to the last element of the list.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_reference to the last element of the list.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns an iterator to the first element contained in the list.
Throws: Nothing.
Complexity: Constant.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear_and_dispose(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clone_from(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::crend(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::merge(), boost::intrusive::operator<(), boost::intrusive::operator==(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::rend(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice().
|
inline |
Effects: Returns a const_iterator to the first element contained in the list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cbegin().
|
inline |
Effects: Returns a const_iterator to the first element contained in the list.
Throws: Nothing.
Complexity: Constant.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::merge(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::sort(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::unique_and_dispose().
|
inline |
Effects: Returns a constant iterator to the end of the list.
Throws: Nothing.
Complexity: Constant.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::assign(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::dispose_and_assign(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::end(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::list_impl(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::merge(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::unique_and_dispose().
|
inline |
Effects: Asserts the integrity of the container.
Complexity: Linear time.
Note: The method has no effect when asserts are turned off (e.g., with NDEBUG). Experimental function, interface might change in future versions.
References boost::multiprecision::backends::p.
|
inline |
Effects: Erases all the elements of the container.
No destructors are called.
Throws: Nothing.
Complexity: Linear to the number of elements of the list. if it's a safe-mode or auto-unlink value_type. Constant time otherwise.
Note: Invalidates the iterators (but not the references) to the erased elements.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear_and_dispose(), and boost::intrusive::circular_list_algorithms< NodeTraits >::init_header().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::assign(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::~list_impl().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Erases all the elements of the container. No destructors are called. Disposer::operator()(pointer) is called for the removed elements.
Throws: Nothing.
Complexity: Linear to the number of elements of the list.
Note: Invalidates the iterators to the erased elements.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::end(), boost::intrusive::circular_list_algorithms< NodeTraits >::init(), boost::intrusive::circular_list_algorithms< NodeTraits >::init_header(), and boost::it.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clone_from(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::dispose_and_assign().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Cloner should yield to nodes equivalent to the original nodes.
Effects: Erases all the elements from *this calling Disposer::operator()(pointer), clones all the elements from src calling Cloner::operator()(const_reference ) and inserts them on *this.
If cloner throws, all cloned elements are unlinked and disposed calling Disposer::operator()(pointer).
Complexity: Linear to erased plus inserted elements.
Throws: If cloner throws. Basic guarantee.
References boost::asio::b, boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear_and_dispose(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::end(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::push_back().
|
inlinestatic |
Precondition: end_iterator must be a valid end iterator of list.
Effects: Returns a const reference to the list associated to the end iterator
Throws: Nothing.
Complexity: Constant.
|
inlinestatic |
Precondition: end_iterator must be a valid end const_iterator of list.
Effects: Returns a const reference to the list associated to the end iterator
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::end().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::rbegin().
|
inline |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::rend().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Requires: Dereferencing iterator must yield an lvalue of type value_type.
Effects: Clears the list and inserts the range pointed by b and e. No destructors or copy constructors are called. Disposer::operator()(pointer) is called for the removed elements.
Throws: Nothing.
Complexity: Linear to the number of elements inserted plus linear to the elements contained in the list.
Note: Invalidates the iterators (but not the references) to the erased elements.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cend(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear_and_dispose(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::insert().
|
inline |
Effects: Returns true if the list contains no elements.
Throws: Nothing.
Complexity: Constant.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::unique().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::merge(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::sort(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice().
|
inline |
Effects: Returns an iterator to the end of the list.
Throws: Nothing.
Complexity: Constant.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clear_and_dispose(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clone_from(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::crbegin(), boost::intrusive::operator<(), boost::intrusive::operator==(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::rbegin(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice().
|
inline |
Effects: Returns a const_iterator to the end of the list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cend().
|
inline |
Effects: Erases the element pointed by i of the list.
No destructors are called.
Returns: the first element remaining beyond the removed element, or end() if no such element exists.
Throws: Nothing.
Complexity: Constant.
Note: Invalidates the iterators (but not the references) to the erased element.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase_and_dispose().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::remove_if().
|
inline |
Requires: b and e must be valid iterators to elements in *this.
Effects: Erases the element range pointed by b and e No destructors are called.
Returns: the first element remaining beyond the removed elements, or end() if no such element exists.
Throws: Nothing.
Complexity: Linear to the number of erased elements if it's a safe-mode or auto-unlink value, or constant-time size is enabled. Constant-time otherwise.
Note: Invalidates the iterators (but not the references) to the erased elements.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase_and_dispose(), and boost::intrusive::circular_list_algorithms< NodeTraits >::unlink().
|
inline |
Requires: b and e must be valid iterators to elements in *this.
n must be std::distance(b, e).
Effects: Erases the element range pointed by b and e No destructors are called.
Returns: the first element remaining beyond the removed elements, or end() if no such element exists.
Throws: Nothing.
Complexity: Linear to the number of erased elements if it's a safe-mode or auto-unlink value is enabled. Constant-time otherwise.
Note: Invalidates the iterators (but not the references) to the erased elements.
References boost::intrusive::circular_list_algorithms< NodeTraits >::distance(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase_and_dispose(), and boost::intrusive::circular_list_algorithms< NodeTraits >::unlink().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Erases the element pointed by i of the list. No destructors are called. Disposer::operator()(pointer) is called for the removed element.
Returns: the first element remaining beyond the removed element, or end() if no such element exists.
Throws: Nothing.
Complexity: Constant.
Note: Invalidates the iterators to the erased element.
References boost::multiprecision::backends::i, boost::intrusive::circular_list_algorithms< NodeTraits >::init(), and boost::intrusive::circular_list_algorithms< NodeTraits >::unlink().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase_and_dispose(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::remove_and_dispose_if(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::unique_and_dispose().
|
inline |
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Erases the element range pointed by b and e No destructors are called. Disposer::operator()(pointer) is called for the removed elements.
Returns: the first element remaining beyond the removed elements, or end() if no such element exists.
Throws: Nothing.
Complexity: Linear to the number of elements erased.
Note: Invalidates the iterators to the erased elements.
References boost::intrusive::circular_list_algorithms< NodeTraits >::init(), and boost::intrusive::circular_list_algorithms< NodeTraits >::unlink().
|
inline |
Effects: Returns a reference to the first element of the list.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_reference to the first element of the list.
Throws: Nothing.
Complexity: Constant.
|
inline |
Requires: value must be an lvalue and p must be a valid iterator of *this.
Effects: Inserts the value before the position pointed by p.
Returns: An iterator to the inserted element.
Throws: Nothing.
Complexity: Constant time. No copy constructors are called.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::inited(), and boost::intrusive::circular_list_algorithms< NodeTraits >::link_before().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::assign(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::dispose_and_assign(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::insert(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::list_impl().
|
inline |
Requires: Dereferencing iterator must yield an lvalue of type value_type and p must be a valid iterator of *this.
Effects: Inserts the range pointed by b and e before the position p. No copy constructors are called.
Throws: Nothing.
Complexity: Linear to the number of elements inserted.
Note: Does not affect the validity of iterators and references.
References boost::asio::b, and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::insert().
|
inline |
Requires: value must be a reference to a value inserted in a list.
Effects: This function returns a const_iterator pointing to the element
Throws: Nothing.
Complexity: Constant time.
Note: Iterators and references are not invalidated.
References boost::intrusive::circular_list_algorithms< NodeTraits >::inited().
|
inline |
Requires: value must be a const reference to a value inserted in a list.
Effects: This function returns an iterator pointing to the element.
Throws: Nothing.
Complexity: Constant time.
Note: Iterators and references are not invalidated.
References boost::intrusive::pointer_traits< Ptr >::const_cast_from(), and boost::intrusive::circular_list_algorithms< NodeTraits >::inited().
|
inline |
Effects: This function removes all of x's elements and inserts them in order into *this according to std::less<value_type>.
The merge is stable; that is, if an element from *this is equivalent to one from x, then the element from *this will precede the one from x.
Throws: If std::less<value_type> throws. Basic guarantee.
Complexity: This function is linear time: it performs at most size() + x.size() - 1 comparisons.
Note: Iterators and references are not invalidated
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::sort().
|
inline |
Requires: p must be a comparison function that induces a strict weak ordering and both *this and x must be sorted according to that ordering The lists x and *this must be distinct.
Effects: This function removes all of x's elements and inserts them in order into *this. The merge is stable; that is, if an element from *this is equivalent to one from x, then the element from *this will precede the one from x.
Throws: If the predicate throws. Basic guarantee.
Complexity: This function is linear time: it performs at most size() + x.size() - 1 comparisons.
Note: Iterators and references are not invalidated.
References boost::asio::b, boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cbegin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cend(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::empty(), boost::n, boost::multiprecision::backends::p, and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice().
|
inline |
Effects: to-do
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::swap().
|
inline |
Effects: Erases the last element of the list.
No destructors are called.
Throws: Nothing.
Complexity: Constant.
Note: Invalidates the iterators (but not the references) to the erased element.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::pop_back_and_dispose().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Erases the last element of the list. No destructors are called. Disposer::operator()(pointer) is called for the removed element.
Throws: Nothing.
Complexity: Constant.
Note: Invalidates the iterators to the erased element.
References boost::intrusive::circular_list_algorithms< NodeTraits >::init(), and boost::intrusive::circular_list_algorithms< NodeTraits >::unlink().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::pop_back().
|
inline |
Effects: Erases the first element of the list.
No destructors are called.
Throws: Nothing.
Complexity: Constant.
Note: Invalidates the iterators (but not the references) to the erased element.
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Erases the first element of the list. No destructors are called. Disposer::operator()(pointer) is called for the removed element.
Throws: Nothing.
Complexity: Constant.
Note: Invalidates the iterators to the erased element.
References boost::intrusive::circular_list_algorithms< NodeTraits >::init(), and boost::intrusive::circular_list_algorithms< NodeTraits >::unlink().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::pop_front().
|
inline |
Requires: value must be an lvalue.
Effects: Inserts the value in the back of the list. No copy constructors are called.
Throws: Nothing.
Complexity: Constant.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::inited(), and boost::intrusive::circular_list_algorithms< NodeTraits >::link_before().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::clone_from().
|
inline |
Requires: value must be an lvalue.
Effects: Inserts the value in the front of the list. No copy constructors are called.
Throws: Nothing.
Complexity: Constant.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::inited(), and boost::intrusive::circular_list_algorithms< NodeTraits >::link_before().
|
inline |
Effects: Returns a reverse_iterator pointing to the beginning of the reversed list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::end().
|
inline |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::crbegin().
|
inline |
Effects: Removes all the elements that compare equal to value.
No destructors are called.
Throws: If std::equal_to<value_type> throws. Basic guarantee.
Complexity: Linear time. It performs exactly size() comparisons for equality.
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::remove_if(), and boost::program_options::value().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Removes all the elements that compare equal to value. Disposer::operator()(pointer) is called for every removed element.
Throws: If std::equal_to<value_type> throws. Basic guarantee.
Complexity: Linear time. It performs exactly size() comparisons for equality.
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Removes all the elements for which a specified predicate is satisfied. Disposer::operator()(pointer) is called for every removed element.
Throws: If pred throws. Basic guarantee.
Complexity: Linear time. It performs exactly size() comparisons for equality.
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
References boost::intrusive::circular_list_algorithms< NodeTraits >::stable_partition_info::beg_2st_partition, boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase_and_dispose(), boost::intrusive::circular_list_algorithms< NodeTraits >::stable_partition(), and boost::multiprecision::backends::this.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::remove_and_dispose().
|
inline |
Effects: Removes all the elements for which a specified predicate is satisfied.
No destructors are called.
Throws: If pred throws. Basic guarantee.
Complexity: Linear time. It performs exactly size() calls to the predicate.
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
References boost::intrusive::circular_list_algorithms< NodeTraits >::stable_partition_info::beg_2st_partition, boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase(), boost::intrusive::circular_list_algorithms< NodeTraits >::stable_partition_info::num_1st_partition, boost::intrusive::circular_list_algorithms< NodeTraits >::stable_partition(), and boost::multiprecision::backends::this.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::remove().
|
inline |
Effects: Returns a reverse_iterator pointing to the end of the reversed list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin().
|
inline |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed list.
Throws: Nothing.
Complexity: Constant.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::crend().
|
inline |
Effects: Reverses the order of elements in the list.
Throws: Nothing.
Complexity: This function is linear time.
Note: Iterators and references are not invalidated
References boost::intrusive::circular_list_algorithms< NodeTraits >::reverse().
|
inlinestatic |
Requires: value must be a reference to a value inserted in a list.
Effects: This function returns a const_iterator pointing to the element
Throws: Nothing.
Complexity: Constant time.
Note: Iterators and references are not invalidated. This static function is available only if the value traits is stateless.
References boost::BOOST_STATIC_ASSERT(), and boost::intrusive::circular_list_algorithms< NodeTraits >::inited().
|
inlinestatic |
Requires: value must be a const reference to a value inserted in a list.
Effects: This function returns an iterator pointing to the element.
Throws: Nothing.
Complexity: Constant time.
Note: Iterators and references are not invalidated. This static function is available only if the value traits is stateless.
References boost::BOOST_STATIC_ASSERT(), boost::intrusive::pointer_traits< Ptr >::const_cast_from(), and boost::intrusive::circular_list_algorithms< NodeTraits >::inited().
|
inline |
Effects: Moves backwards all the elements, so that the first element becomes the second, the second becomes the third...
the last element becomes the first one.
Throws: Nothing.
Complexity: Linear to the number of shifts.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::move_forward(), and boost::n.
|
inline |
Effects: Moves forward all the elements, so that the second element becomes the first, the third becomes the second...
the first element becomes the last one.
Throws: Nothing.
Complexity: Linear to the number of shifts.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::move_backwards(), and boost::n.
|
inline |
Effects: Returns the number of the elements contained in the list.
Throws: Nothing.
Complexity: Linear to the number of elements contained in the list. if constant-time size option is disabled. Constant time otherwise.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::count().
Referenced by boost::intrusive::operator==().
|
inline |
Effects: This function sorts the list *this according to std::less<value_type>.
The sort is stable, that is, the relative order of equivalent elements is preserved.
Throws: If value_traits::node_traits::node constructor throws (this does not happen with predefined Boost.Intrusive hooks) or std::less<value_type> throws. Basic guarantee.
Notes: Iterators and references are not invalidated.
Complexity: The number of comparisons is approximately N log N, where N is the list's size.
|
inline |
Requires: p must be a comparison function that induces a strict weak ordering
Effects: This function sorts the list *this according to p. The sort is stable, that is, the relative order of equivalent elements is preserved.
Throws: If value_traits::node_traits::node constructor throws (this does not happen with predefined Boost.Intrusive hooks) or the predicate throws. Basic guarantee.
Notes: This won't throw if list_base_hook<> or list_member_hook are used. Iterators and references are not invalidated.
Complexity: The number of comparisons is approximately N log N, where N is the list's size.
References boost::multiprecision::backends::carry, boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cbegin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::empty(), std::fill(), boost::multiprecision::backends::i, boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::merge(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::swap().
|
inline |
Requires: p must be a valid iterator of *this.
Effects: Transfers all the elements of list x to this list, before the the element pointed by p. No destructors or copy constructors are called.
Throws: Nothing.
Complexity: Constant.
Note: Iterators of values obtained from list x now point to elements of this list. Iterators of this list and all the references are not invalidated.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::begin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::empty(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::end(), and boost::intrusive::circular_list_algorithms< NodeTraits >::transfer().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::merge(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::sort(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice().
|
inline |
Requires: p must be a valid iterator of *this.
new_ele must point to an element contained in list x.
Effects: Transfers the value pointed by new_ele, from list x to this list, before the element pointed by p. No destructors or copy constructors are called. If p == new_ele or p == ++new_ele, this function is a null operation.
Throws: Nothing.
Complexity: Constant.
Note: Iterators of values obtained from list x now point to elements of this list. Iterators of this list and all the references are not invalidated.
References boost::intrusive::circular_list_algorithms< NodeTraits >::transfer().
|
inline |
Requires: p must be a valid iterator of *this.
f and e must point to elements contained in list x.
Effects: Transfers the range pointed by f and e from list x to this list, before the element pointed by p. No destructors or copy constructors are called.
Throws: Nothing.
Complexity: Linear to the number of elements transferred if constant-time size option is enabled. Constant-time otherwise.
Note: Iterators of values obtained from list x now point to elements of this list. Iterators of this list and all the references are not invalidated.
References boost::intrusive::circular_list_algorithms< NodeTraits >::distance(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::splice().
|
inline |
Requires: p must be a valid iterator of *this.
f and e must point to elements contained in list x. n == std::distance(f, e)
Effects: Transfers the range pointed by f and e from list x to this list, before the element pointed by p. No destructors or copy constructors are called.
Throws: Nothing.
Complexity: Constant.
Note: Iterators of values obtained from list x now point to elements of this list. Iterators of this list and all the references are not invalidated.
References boost::intrusive::circular_list_algorithms< NodeTraits >::distance(), and boost::intrusive::circular_list_algorithms< NodeTraits >::transfer().
|
inline |
Effects: Swaps the elements of x and *this.
Throws: Nothing.
Complexity: Constant.
Note: Does not affect the validity of iterators and references.
References boost::intrusive::circular_list_algorithms< NodeTraits >::swap_nodes().
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::list_impl(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::operator=(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::sort(), and boost::intrusive::swap().
|
inline |
Effects: Removes adjacent duplicate elements or adjacent elements that are equal from the list.
No destructors are called.
Throws: If std::equal_to<value_type throws. Basic guarantee.
Complexity: Linear time (size()-1 comparisons calls to pred()).
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::unique_and_dispose().
|
inline |
Effects: Removes adjacent duplicate elements or adjacent elements that satisfy some binary predicate from the list.
No destructors are called.
Throws: If pred throws. Basic guarantee.
Complexity: Linear time (size()-1 comparisons equality comparisons).
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
References boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::unique_and_dispose().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Removes adjacent duplicate elements or adjacent elements that are equal from the list. Disposer::operator()(pointer) is called for every removed element.
Throws: If std::equal_to<value_type throws. Basic guarantee.
Complexity: Linear time (size()-1) comparisons equality comparisons.
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
Referenced by boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::unique().
|
inline |
Requires: Disposer::operator()(pointer) shouldn't throw.
Effects: Removes adjacent duplicate elements or adjacent elements that satisfy some binary predicate from the list. Disposer::operator()(pointer) is called for every removed element.
Throws: If pred throws. Basic guarantee.
Complexity: Linear time (size()-1) comparisons equality comparisons.
Note: The relative order of elements that are not removed is unchanged, and iterators to elements that are not removed remain valid.
References boost::xpressive::after(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cbegin(), boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::cend(), and boost::intrusive::list_impl< ValueTraits, SizeType, ConstantTimeSize, HeaderHolder >::erase_and_dispose().
|
static |
|
static |
|
static |