GTAV-Classes/base/pgDictionary.hpp

87 lines
2.0 KiB
C++
Raw Normal View History

#pragma once
namespace rage
{
class pgDictionaryBase
{
public:
virtual ~pgDictionaryBase() = default;
}; //Size: 0x0008
template<typename T>
class pgDictionary : public pgDictionaryBase
{
private:
struct Node {
T key;
Node* next;
Node(const T& k, Node* n = nullptr)
: key(k), next(n) {}
};
Node* head;
public:
pgDictionary() : head(nullptr) {}
~pgDictionary() {
clearDict();
}
void addDict(const T& key) {
Node* newNode = new Node(key, head);
head = newNode;
}
bool containsDict(const T& key) const {
Node* current = head;
while (current != nullptr) {
if (current->key == key) {
return true;
}
current = current->next;
}
return false;
}
void removeDict(const T& key) {
if (head == nullptr) {
return;
}
if (head->key == key) {
Node* temp = head;
head = head->next;
delete temp;
return;
}
Node* current = head;
while (current->next != nullptr) {
if (current->next->key == key) {
Node* temp = current->next;
current->next = current->next->next;
delete temp;
return;
}
current = current->next;
}
}
size_t sizeDict() const {
size_t count = 0;
Node* current = head;
while (current != nullptr) {
count++;
current = current->next;
}
return count;
}
void clearDict() {
while (head != nullptr) {
Node* temp = head;
head = head->next;
delete temp;
}
}
};
}