78 m_data[i_l] = other.m_data[i_l];
105 other.m_size_max = 0;
115 if (
this != std::addressof(other)) {
125 m_data[i_l] = other.m_data[i_l];
139 if (
this != std::addressof(other)) {
140 m_data = std::move(other.m_data );
141 m_head = std::move(other.m_head );
142 m_count = std::move(other.m_count );
149 other.m_size_max = 0;
194 if (pos >=
m_count)
throw std::invalid_argument(
"Invalid subscript");
205 if (pos >=
m_count)
throw std::invalid_argument(
"Invalid subscript");
216 if (pos >=
m_count)
throw std::invalid_argument(
"Invalid subscript");
227 if (pos >=
m_count)
throw std::invalid_argument(
"Invalid subscript");
240 if (pos >=
m_size_max)
throw std::invalid_argument(
"Invalid subscript");
253 if (pos >=
m_size_max)
throw std::invalid_argument(
"Invalid subscript");
290 m_data[pos] = std::move(v);
295 m_data[pos] = std::move(v);
306 if (!
m_count)
throw std::invalid_argument(
"Empty storage");
347 if (!
m_count)
throw std::invalid_argument(
"Empty storage");
357 if (!
m_count)
throw std::invalid_argument(
"Empty storage");
366 if (!
m_count)
throw std::invalid_argument(
"Empty storage");
399 if (!
m_count)
throw std::invalid_argument(
"Empty storage");
Helper class to allow limited size FIFO queues implemented as vector of elements.
Definition vector_queue.hpp:19
vector_queue< value_type > & operator=(const vector_queue< value_type > &other)
Copies existing queue.
Definition vector_queue.hpp:113
T value_type
Element type.
Definition vector_queue.hpp:29
bool empty() const
Tests if the queue is empty.
Definition vector_queue.hpp:182
size_type tail() const
Returns absolute subscript or position number of the last element in the queue. The element must exis...
Definition vector_queue.hpp:397
reference operator[](size_type pos)
Returns a reference to the element at a specified location in the queue.
Definition vector_queue.hpp:203
vector_queue(const vector_queue< value_type > &other)
Copies existing queue.
Definition vector_queue.hpp:69
value_type * m_data
Underlying data container.
Definition vector_queue.hpp:412
const T & const_reference
Constant reference to element type.
Definition vector_queue.hpp:39
const_reference back() const
Returns a constant reference to the last element in the queue.
Definition vector_queue.hpp:381
vector_queue(vector_queue< value_type > &&other)
Moves existing queue.
Definition vector_queue.hpp:95
reference back()
Returns a reference to the last element in the queue.
Definition vector_queue.hpp:373
size_type push_back(value_type &&v)
Moves the element to the end of the queue, overriding the first one when queue is out of space.
Definition vector_queue.hpp:286
size_type head() const
Returns absolute subscript or position number of the head element in the queue. The element does not ...
Definition vector_queue.hpp:389
size_type m_count
Number of elements.
Definition vector_queue.hpp:414
virtual ~vector_queue()
Destroys the queue.
Definition vector_queue.hpp:85
reference front()
Returns a reference to the head element in the queue.
Definition vector_queue.hpp:355
size_type m_size_max
Maximum size.
Definition vector_queue.hpp:415
size_t size_type
Type to measure element count and indices in.
Definition vector_queue.hpp:24
vector_queue< value_type > & operator=(vector_queue< value_type > &&other)
Moves existing queue.
Definition vector_queue.hpp:137
reference at_abs(size_type pos)
Returns a reference to the element at the absolute location in the queue.
Definition vector_queue.hpp:238
T & reference
Reference to element type.
Definition vector_queue.hpp:34
void clear()
Erases the elements of the queue.
Definition vector_queue.hpp:174
const_reference front() const
Returns a constant reference to the head element in the queue.
Definition vector_queue.hpp:364
vector_queue(size_type size_max)
Construct queue of fixed size.
Definition vector_queue.hpp:57
size_type push_back(const value_type &v)
Copies an existing element to the end of the queue, overriding the first one when queue is out of spa...
Definition vector_queue.hpp:264
void pop_back()
Removes (dequeues) the last element of the queue.
Definition vector_queue.hpp:304
size_type m_head
Index of the first element.
Definition vector_queue.hpp:413
const_reference at(size_type pos) const
Returns a constant reference to the element at a specified location in the queue.
Definition vector_queue.hpp:214
T * pointer
Pointer to element.
Definition vector_queue.hpp:44
const_reference operator[](size_type pos) const
Returns a constant reference to the element at a specified location in the queue.
Definition vector_queue.hpp:225
size_type size() const
Returns the number of elements in the vector.
Definition vector_queue.hpp:158
void pop_front()
Removes (dequeues) the head element of the queue.
Definition vector_queue.hpp:345
size_type capacity() const
Returns the number of elements that the queue can contain before overwriting head ones.
Definition vector_queue.hpp:166
const T * const_pointer
Constant pointer to element.
Definition vector_queue.hpp:49
size_type push_front(const value_type &v)
Copies an existing element to the head of the queue, overriding the last one when queue is out of spa...
Definition vector_queue.hpp:317
reference at(size_type pos)
Returns a reference to the element at a specified location in the queue.
Definition vector_queue.hpp:192
size_type abs(size_type pos) const
Returns absolute subscript or position number of the given element in the queue.
Definition vector_queue.hpp:406
size_type push_front(value_type &&v)
Moves the element to the head of the queue, overriding the last one when queue is out of space and mo...
Definition vector_queue.hpp:333
const_reference at_abs(size_type pos) const
Returns a constant reference to the element at the absolute location in the queue: measured from the ...
Definition vector_queue.hpp:251