2015-05-23 22:55:12 -06:00
|
|
|
// Copyright 2008 Dolphin Emulator Project
|
2015-05-17 17:08:10 -06:00
|
|
|
// Licensed under GPLv2+
|
2013-04-17 21:09:55 -06:00
|
|
|
// Refer to the license.txt file included.
|
2008-12-07 21:46:09 -07:00
|
|
|
|
2014-02-10 11:54:46 -07:00
|
|
|
#pragma once
|
2008-12-07 21:46:09 -07:00
|
|
|
|
2016-06-25 09:39:54 -06:00
|
|
|
#include <array>
|
2014-02-19 20:11:52 -07:00
|
|
|
#include <cstddef>
|
2016-06-25 09:39:54 -06:00
|
|
|
#include <utility>
|
2014-02-19 20:11:52 -07:00
|
|
|
|
2008-12-07 21:46:09 -07:00
|
|
|
// STL-look-a-like interface, but name is mixed case to distinguish it clearly from the
|
|
|
|
// real STL classes.
|
2016-06-25 09:39:54 -06:00
|
|
|
//
|
2008-12-07 21:46:09 -07:00
|
|
|
// Not fully featured, no safety checking yet. Add features as needed.
|
|
|
|
|
|
|
|
template <class T, int N>
|
|
|
|
class FixedSizeQueue
|
|
|
|
{
|
|
|
|
public:
|
2016-06-24 02:43:46 -06:00
|
|
|
void clear()
|
|
|
|
{
|
|
|
|
head = 0;
|
|
|
|
tail = 0;
|
|
|
|
count = 0;
|
|
|
|
}
|
2008-12-07 21:46:09 -07:00
|
|
|
|
2016-06-24 02:43:46 -06:00
|
|
|
void push(T t)
|
|
|
|
{
|
2016-06-25 09:39:54 -06:00
|
|
|
storage[tail] = std::move(t);
|
2016-06-24 02:43:46 -06:00
|
|
|
tail++;
|
|
|
|
if (tail == N)
|
|
|
|
tail = 0;
|
|
|
|
count++;
|
|
|
|
}
|
2008-12-07 21:46:09 -07:00
|
|
|
|
2016-06-24 02:43:46 -06:00
|
|
|
void pop()
|
|
|
|
{
|
|
|
|
head++;
|
|
|
|
if (head == N)
|
|
|
|
head = 0;
|
|
|
|
count--;
|
|
|
|
}
|
2008-12-07 21:46:09 -07:00
|
|
|
|
2016-06-24 02:43:46 -06:00
|
|
|
T pop_front()
|
|
|
|
{
|
2016-06-25 09:39:54 -06:00
|
|
|
T& temp = storage[head];
|
2016-06-24 02:43:46 -06:00
|
|
|
pop();
|
2016-06-25 09:39:54 -06:00
|
|
|
return std::move(temp);
|
2016-06-24 02:43:46 -06:00
|
|
|
}
|
2008-12-07 21:46:09 -07:00
|
|
|
|
2016-06-24 02:43:46 -06:00
|
|
|
T& front() { return storage[head]; }
|
|
|
|
const T& front() const { return storage[head]; }
|
|
|
|
size_t size() const { return count; }
|
2018-04-12 06:18:04 -06:00
|
|
|
|
2016-06-25 09:39:54 -06:00
|
|
|
private:
|
|
|
|
std::array<T, N> storage;
|
|
|
|
int head = 0;
|
|
|
|
int tail = 0;
|
|
|
|
// Sacrifice 4 bytes for a simpler implementation. may optimize away in the future.
|
|
|
|
int count = 0;
|
2008-12-07 21:46:09 -07:00
|
|
|
};
|