31#ifndef ETL_QUEUE_INCLUDED
32#define ETL_QUEUE_INCLUDED
104 template <
size_t MEMORY_MODEL = etl::memory_model::MEMORY_MODEL_LARGE>
194 ETL_INCREMENT_DEBUG_COUNT;
207 ETL_DECREMENT_DEBUG_COUNT;
218 ETL_RESET_DEBUG_COUNT;
240 template <
typename T, const
size_t MEMORY_MODEL = etl::memory_model::MEMORY_MODEL_LARGE>
274 return p_buffer[
out];
283 return p_buffer[
out];
311#if defined(ETL_CHECK_PUSH_POP)
326#if defined(ETL_CHECK_PUSH_POP)
329 ::new (&p_buffer[
in])
T(etl::move(value));
334#if ETL_USING_CPP11 && ETL_NOT_USING_STLPORT && !defined(ETL_QUEUE_FORCE_CPP03_IMPLEMENTATION)
340 template <
typename ...
Args>
343#if defined(ETL_CHECK_PUSH_POP)
358#if defined(ETL_CHECK_PUSH_POP)
372 template <
typename T1>
375#if defined(ETL_CHECK_PUSH_POP)
390 template <
typename T1,
typename T2>
393#if defined(ETL_CHECK_PUSH_POP)
397 ::new (&value)
T(value1, value2);
409 template <
typename T1,
typename T2,
typename T3>
412#if defined(ETL_CHECK_PUSH_POP)
416 ::new (&value)
T(value1, value2, value3);
429 template <
typename T1,
typename T2,
typename T3,
typename T4>
432#if defined(ETL_CHECK_PUSH_POP)
436 ::new (&value)
T(value1, value2, value3, value4);
471#if defined(ETL_CHECK_PUSH_POP)
494 template <
typename TContainer>
545 index = (index == (
CAPACITY - 1)) ? 0 : index + 1;
562 index = (index == (
CAPACITY - 1)) ? 0 : index + 1;
586#if defined(ETL_POLYMORPHIC_QUEUE) || defined(ETL_POLYMORPHIC_CONTAINERS)
607 template <
typename T, const
size_t SIZE, const
size_t MEMORY_MODEL = etl::memory_model::MEMORY_MODEL_LARGE>
621 static ETL_CONSTANT size_type MAX_SIZE = size_type(SIZE);
647 base_t::move_clone(etl::move(
rhs));
680 base_t::move_clone(etl::move(
rhs));
690 container_type buffer[SIZE];
693 template <
typename T, const
size_t SIZE, const
size_t MEMORY_MODEL>
694 ETL_CONSTANT
typename queue<T, SIZE, MEMORY_MODEL>::size_type queue<T, SIZE, MEMORY_MODEL>::MAX_SIZE;
Definition alignment.h:245
#define ETL_ASSERT(b, e)
Definition error_handler.h:356
Definition exception.h:47
Definition integral_limits.h:516
~queue()
Destructor.
Definition queue.h:654
size_type in
Where to input new data.
Definition queue.h:221
reference emplace(const T1 &value1, const T2 &value2)
Definition queue.h:391
queue & operator=(const queue &rhs)
Assignment operator.
Definition queue.h:662
const_reference front() const
Definition queue.h:281
ETL_DECLARE_DEBUG_COUNT
For internal debugging purposes.
Definition queue.h:225
const T * const_pointer
A const pointer to the type used in the queue.
Definition queue.h:256
void push(const_reference value)
Definition queue.h:309
reference emplace(const T1 &value1, const T2 &value2, const T3 &value3)
Definition queue.h:410
const_reference back() const
Definition queue.h:299
reference front()
Definition queue.h:272
size_type current_size
The number of items in the queue.
Definition queue.h:223
queue()
Default constructor.
Definition queue.h:626
void pop_into(reference destination)
Definition queue.h:482
etl::size_type_lookup< MEMORY_MODEL >::type size_type
The type used for determining the size of queue.
Definition queue.h:110
iqueue & operator=(const iqueue &rhs)
Assignment operator.
Definition queue.h:504
reference emplace(const T1 &value1, const T2 &value2, const T3 &value3, const T4 &value4)
Definition queue.h:430
T value_type
The type stored in the queue.
Definition queue.h:249
void pop()
Definition queue.h:469
void index_clear()
Clears the indexes.
Definition queue.h:213
size_type out
Where to get the oldest data.
Definition queue.h:222
~queue_base()
Destructor.
Definition queue.h:179
bool full() const
Definition queue.h:149
reference back()
Definition queue.h:290
size_type available() const
Definition queue.h:158
void del_out()
Increments (and wraps) the 'out' index value to record a queue deletion.
Definition queue.h:200
void add_in()
Increments (and wraps) the 'in' index value to record a queue addition.
Definition queue.h:186
~iqueue()
Destructor.
Definition queue.h:593
const size_type CAPACITY
The maximum number of items in the queue.
Definition queue.h:224
reference emplace()
Definition queue.h:356
base_t::size_type size_type
The type used for determining the size of the queue.
Definition queue.h:257
iqueue(T *p_buffer_, size_type max_size_)
The constructor that is called from derived classes.
Definition queue.h:570
queue_base(size_type max_size_)
The constructor that is called from derived classes.
Definition queue.h:168
void clone(const iqueue &other)
Make this a clone of the supplied queue.
Definition queue.h:536
queue(const queue &rhs)
Copy constructor.
Definition queue.h:634
size_type size() const
Returns the current number of items in the queue.
Definition queue.h:115
const T & const_reference
A const reference to the type used in the queue.
Definition queue.h:251
void pop_into(TContainer &destination)
Definition queue.h:495
size_type capacity() const
Returns the maximum number of items that can be queued.
Definition queue.h:131
T & reference
A reference to the type used in the queue.
Definition queue.h:250
size_type max_size() const
Returns the maximum number of items that can be queued.
Definition queue.h:123
reference emplace(const T1 &value1)
Definition queue.h:373
bool empty() const
Definition queue.h:140
T * pointer
A pointer to the type used in the queue.
Definition queue.h:255
void clear()
Clears the queue to the empty state.
Definition queue.h:445
This is the base for all queues that contain a particular type.
Definition queue.h:242
add_rvalue_reference
Definition type_traits_generator.h:1366
bitset_ext
Definition absolute.h:38
ETL_NODISCARD ETL_CONSTEXPR14 T round_half_even_unscaled(T value) ETL_NOEXCEPT
Definition scaled_rounding.h:314
Definition alignment.h:247
Definition type_traits_generator.h:2190
Definition memory_model.h:50