#include <bn_list.h>
template<typename Type>
bn::ilist class

Base class of bn::list.

Template parameters
Type Element type.

Can be used as a reference type for all bn::list containers containing a specific type.

Derived classes

template<typename Type, int MaxSize>
class list
std::list like container with a fixed size buffer.

Public types

class const_iterator
Const iterator.
class iterator
Non const iterator.
using value_type = Type
Value type alias.
using size_type = int
Size type alias.
using difference_type = int
Difference type alias.
using reference = Type&
Reference alias.
using const_reference = const Type&
Const reference alias.
using pointer = Type*
Pointer alias.
using const_pointer = const Type*
Const pointer alias.
using reverse_iterator = bn::reverse_iterator<iterator>
Reverse iterator alias.
using const_reverse_iterator = bn::reverse_iterator<const_iterator>
Const reverse iterator alias.

Public functions

auto operator=(const ilist& other) -> ilist&
Copy assignment operator.
auto operator=(ilist&& other) -> ilist& noexcept
Move assignment operator.
auto size() const -> size_type
Returns the current size.
auto max_size() const -> size_type
Returns the maximum possible size.
auto available() const -> size_type
Returns the remaining capacity.
auto empty() const -> bool
Indicates if it doesn't contain any element.
auto full() const -> bool
Indicates if it can't contain any more elements.
auto begin() const -> const_iterator
Returns a const iterator to the beginning of the ilist.
auto begin() -> iterator
Returns an iterator to the beginning of the ilist.
auto end() const -> const_iterator
Returns a const iterator to the end of the ilist.
auto end() -> iterator
Returns an iterator to the end of the ilist.
auto cbegin() const -> const_iterator
Returns a const iterator to the beginning of the ilist.
auto cend() const -> const_iterator
Returns a const iterator to the end of the ilist.
auto rbegin() const -> const_reverse_iterator
Returns a const reverse iterator to the end of the ilist.
auto rbegin() -> reverse_iterator
Returns a reverse iterator to the end of the ilist.
auto rend() const -> const_reverse_iterator
Returns a const reverse iterator to the beginning of the ilist.
auto rend() -> reverse_iterator
Returns a reverse iterator to the beginning of the ilist.
auto crbegin() const -> const_reverse_iterator
Returns a const reverse iterator to the end of the ilist.
auto crend() const -> const_reverse_iterator
Returns a const reverse iterator to the beginning of the ilist.
auto front() const -> const_reference
Returns a const reference to the first element.
auto front() -> reference
Returns a reference to the first element.
auto back() const -> const_reference
Returns a const reference to the last element.
auto back() -> reference
Returns a reference to the last element.
void push_front(const_reference value)
Inserts a copy of a value at the beginning of the ilist.
void push_front(value_type&& value)
Inserts a moved value at the beginning of the ilist.
template<typename... Args>
auto emplace_front(Args && ... args) -> reference
Constructs and inserts a value at the beginning of the ilist.
void push_back(const_reference value)
Inserts a copy of a value at the end of the ilist.
void push_back(value_type&& value)
Inserts a moved value at the end of the ilist.
template<typename... Args>
auto emplace_back(Args && ... args) -> reference
Constructs and inserts a value at the end of the ilist.
void pop_front()
Removes the first element of the ilist.
void pop_back()
Removes the last element of the ilist.
auto insert(const_iterator position, const_reference value) -> iterator
Inserts a copy of a value at the specified position.
auto insert(const_iterator position, value_type&& value) -> iterator
Inserts a moved value at the specified position.
template<typename... Args>
auto emplace(const_iterator position, Args && ... args) -> iterator
Constructs and inserts a value at the specified position.
auto erase(const_iterator position) -> iterator
Erases an element.
auto erase(const_iterator first, const_iterator last) -> iterator
Erases a range of elements.
auto remove(const_reference value) -> size_type
Erases all elements that are equal to the specified value.
template<class Pred>
auto remove_if(const Pred& pred) -> size_type
Erases all elements that satisfy the specified predicate.
void assign(size_type count, const_reference value)
Assigns values to the ilist, removing the previous ones.
template<typename Iterator>
void assign(const Iterator& first, const Iterator& last)
Assigns values to the ilist, removing the previous ones.
void clear()
Removes all elements.
void swap(ilist& other)
Exchanges the contents of this ilist with those of the other one.

Friends

void swap(ilist& a, ilist& b)
Exchanges the contents of a ilist with those of another one.
auto operator==(const ilist& a, const ilist& b) -> bool
Equal operator.
auto operator<(const ilist& a, const ilist& b) -> bool
Less than operator.
auto operator>(const ilist& a, const ilist& b) -> bool
Greater than operator.
auto operator<=(const ilist& a, const ilist& b) -> bool
Less than or equal operator.
auto operator>=(const ilist& a, const ilist& b) -> bool
Greater than or equal operator.

Function documentation

template<typename Type>
ilist& bn::ilist<Type>::operator=(const ilist& other)

Copy assignment operator.

Parameters
other ilist to copy.
Returns Reference to this.

template<typename Type>
ilist& bn::ilist<Type>::operator=(ilist&& other) noexcept

Move assignment operator.

Parameters
other ilist to move.
Returns Reference to this.

template<typename Type>
void bn::ilist<Type>::push_front(const_reference value)

Inserts a copy of a value at the beginning of the ilist.

Parameters
value Value to insert.

template<typename Type>
void bn::ilist<Type>::push_front(value_type&& value)

Inserts a moved value at the beginning of the ilist.

Parameters
value Value to insert.

template<typename Type> template<typename... Args>
reference bn::ilist<Type>::emplace_front(Args && ... args)

Constructs and inserts a value at the beginning of the ilist.

Parameters
args Parameters of the value to insert.
Returns Reference to the new value.

template<typename Type>
void bn::ilist<Type>::push_back(const_reference value)

Inserts a copy of a value at the end of the ilist.

Parameters
value Value to insert.

template<typename Type>
void bn::ilist<Type>::push_back(value_type&& value)

Inserts a moved value at the end of the ilist.

Parameters
value Value to insert.

template<typename Type> template<typename... Args>
reference bn::ilist<Type>::emplace_back(Args && ... args)

Constructs and inserts a value at the end of the ilist.

Parameters
args Parameters of the value to insert.
Returns Reference to the new value.

template<typename Type>
iterator bn::ilist<Type>::insert(const_iterator position, const_reference value)

Inserts a copy of a value at the specified position.

Parameters
position The given value is inserted before this position.
value Value to insert.
Returns Iterator pointing to the inserted value.

template<typename Type>
iterator bn::ilist<Type>::insert(const_iterator position, value_type&& value)

Inserts a moved value at the specified position.

Parameters
position The given value is inserted before this position.
value Value to insert.
Returns Iterator pointing to the inserted value.

template<typename Type> template<typename... Args>
iterator bn::ilist<Type>::emplace(const_iterator position, Args && ... args)

Constructs and inserts a value at the specified position.

Parameters
position The new value is inserted before this position.
args Parameters of the value to insert.
Returns Iterator pointing to the new value.

template<typename Type>
iterator bn::ilist<Type>::erase(const_iterator position)

Erases an element.

Parameters
position Iterator to the element to erase.
Returns Iterator following the erased element.

template<typename Type>
iterator bn::ilist<Type>::erase(const_iterator first, const_iterator last)

Erases a range of elements.

Parameters
first Iterator to the first element to erase.
last Iterator to the last element to erase.
Returns Iterator following the last erased element.

The range includes all the elements between first and last, including the element pointed by first, but not the one pointed by last.

template<typename Type>
size_type bn::ilist<Type>::remove(const_reference value)

Erases all elements that are equal to the specified value.

Parameters
value Element to erase.
Returns Number of erased elements.

template<typename Type> template<class Pred>
size_type bn::ilist<Type>::remove_if(const Pred& pred)

Erases all elements that satisfy the specified predicate.

Parameters
pred Unary predicate which returns true if the element should be erased.
Returns Number of erased elements.

template<typename Type>
void bn::ilist<Type>::assign(size_type count, const_reference value)

Assigns values to the ilist, removing the previous ones.

Parameters
count Number of elements to insert.
value Value to fill new elements with.

template<typename Type> template<typename Iterator>
void bn::ilist<Type>::assign(const Iterator& first, const Iterator& last)

Assigns values to the ilist, removing the previous ones.

Parameters
first Iterator to the first element to insert.
last Iterator following to the last element to insert.

template<typename Type>
void bn::ilist<Type>::swap(ilist& other)

Exchanges the contents of this ilist with those of the other one.

Parameters
other ilist to exchange the contents with.

template<typename Type>
void swap(ilist& a, ilist& b)

Exchanges the contents of a ilist with those of another one.

Parameters
a First ilist to exchange the contents with.
b Second ilist to exchange the contents with.

template<typename Type>
bool operator==(const ilist& a, const ilist& b)

Equal operator.

Parameters
a First ilist to compare.
b Second ilist to compare.
Returns true if the first ilist is equal to the second one, otherwise false.

template<typename Type>
bool operator<(const ilist& a, const ilist& b)

Less than operator.

Parameters
a First ilist to compare.
b Second ilist to compare.
Returns true if the first ilist is lexicographically less than the second one, otherwise false.

template<typename Type>
bool operator>(const ilist& a, const ilist& b)

Greater than operator.

Parameters
a First ilist to compare.
b Second ilist to compare.
Returns true if the first ilist is lexicographically greater than the second one, otherwise false.

template<typename Type>
bool operator<=(const ilist& a, const ilist& b)

Less than or equal operator.

Parameters
a First ilist to compare.
b Second ilist to compare.
Returns true if the first ilist is lexicographically less than or equal to the second one, otherwise false.

template<typename Type>
bool operator>=(const ilist& a, const ilist& b)

Greater than or equal operator.

Parameters
a First ilist to compare.
b Second ilist to compare.
Returns true if the first ilist is lexicographically greater than or equal to the second one, otherwise false.