2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file fl_stack.h
|
|
|
|
* @brief Fixed-length stack
|
|
|
|
*
|
|
|
|
* @date Jul 9, 2014
|
2017-01-03 03:05:22 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2017
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef FL_STACK_H_
|
|
|
|
#define FL_STACK_H_
|
|
|
|
|
2018-09-16 19:26:57 -07:00
|
|
|
#include "global.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
#include "error_handling.h"
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
class FLStack {
|
|
|
|
public:
|
|
|
|
FLStack();
|
|
|
|
void push(T value);
|
|
|
|
void reset();
|
|
|
|
T pop();
|
|
|
|
T get(int index);
|
2016-01-11 14:01:33 -08:00
|
|
|
bool remove(T value);
|
2015-07-10 06:01:56 -07:00
|
|
|
int size();
|
|
|
|
bool isEmpty();
|
|
|
|
private:
|
|
|
|
int currentSize;
|
|
|
|
T values[MAXSIZE];
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
FLStack<T, MAXSIZE>::FLStack() {
|
|
|
|
reset();
|
|
|
|
memset(values, 0, sizeof(values));
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
bool FLStack<T, MAXSIZE>::isEmpty() {
|
|
|
|
return currentSize == 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
void FLStack<T, MAXSIZE>::reset() {
|
|
|
|
currentSize = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
2016-01-11 14:01:33 -08:00
|
|
|
bool FLStack<T, MAXSIZE>::remove(T value) {
|
2015-07-10 06:01:56 -07:00
|
|
|
for (int i = 0; i < currentSize; i++) {
|
|
|
|
if (values[i] == value) {
|
|
|
|
values[0] = values[currentSize - 1];
|
|
|
|
currentSize--;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
void FLStack<T, MAXSIZE>::push(T value) {
|
|
|
|
if (currentSize >= MAXSIZE) {
|
2017-05-29 16:23:15 -07:00
|
|
|
firmwareError(ERROR_FL_STACK_OVERFLOW, "FLstack overflow");
|
2015-07-10 06:01:56 -07:00
|
|
|
return;
|
|
|
|
//warning()
|
|
|
|
}
|
|
|
|
values[currentSize++] = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
T FLStack<T, MAXSIZE>::pop() {
|
|
|
|
if (currentSize == 0) {
|
2017-04-19 19:03:14 -07:00
|
|
|
firmwareError(CUSTOM_FLSTACK, "FLStack is empty");
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
return values[--currentSize];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return element at the specified index
|
|
|
|
*/
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
T FLStack<T, MAXSIZE>::get(int index) {
|
2018-07-25 20:30:00 -07:00
|
|
|
efiAssert(CUSTOM_ERR_ASSERT, index >= 0 && index < MAXSIZE, "FLget", values[0]);
|
2015-07-10 06:01:56 -07:00
|
|
|
return values[index];
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T, int MAXSIZE>
|
|
|
|
int FLStack<T, MAXSIZE>::size() {
|
|
|
|
return currentSize;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class Type, int Dimention>
|
|
|
|
class ArrayList {
|
|
|
|
public:
|
|
|
|
ArrayList();
|
|
|
|
int size;
|
|
|
|
Type elements[Dimention];
|
|
|
|
void reset(void);
|
|
|
|
Type *add(void);
|
|
|
|
void removeAt(int index);
|
|
|
|
};
|
|
|
|
|
|
|
|
template<class Type, int Dimention>
|
|
|
|
ArrayList<Type, Dimention>::ArrayList(void) {
|
|
|
|
memset(&elements, 0, sizeof(elements));
|
|
|
|
reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class Type, int Dimention>
|
|
|
|
void ArrayList<Type, Dimention>::removeAt(int index) {
|
2018-07-25 20:03:04 -07:00
|
|
|
efiAssertVoid(CUSTOM_ERR_6572, index < size, "index greater then size");
|
2015-07-10 06:01:56 -07:00
|
|
|
memcpy(&elements[index], &elements[size - 1], sizeof(Type));
|
|
|
|
memset(&elements[size - 1], 0, sizeof(Type));
|
|
|
|
size--;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class Type, int Dimention>
|
|
|
|
void ArrayList<Type, Dimention>::reset(void) {
|
|
|
|
size = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class Type, int Dimention>
|
|
|
|
Type * ArrayList<Type, Dimention>::add(void) {
|
2018-07-25 20:30:00 -07:00
|
|
|
efiAssert(CUSTOM_ERR_ASSERT, size < Dimention, "add() too many elements", (Type *)NULL);
|
2015-07-10 06:01:56 -07:00
|
|
|
return &elements[size++];
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* FL_STACK_H_ */
|