aboutsummaryrefslogtreecommitdiff
path: root/mwe/resource-manager/resource_manager.cpp
diff options
context:
space:
mode:
authorWBoerenkamps <wrj.boerenkamps@student.avans.nl>2024-10-25 20:59:34 +0200
committerWBoerenkamps <wrj.boerenkamps@student.avans.nl>2024-10-25 20:59:34 +0200
commit15a4c4a1cf67e13be53ef423c51c56488f332ea9 (patch)
tree661084fc8171089ce32bf779f2b3a85d634b38e4 /mwe/resource-manager/resource_manager.cpp
parentf472e0ba3bf54fc5055cf9f08925bed3f98a1dbc (diff)
parentb3b762a34e7ccb4a0dcd041a693ac7180af16002 (diff)
merge conficts fixed
Diffstat (limited to 'mwe/resource-manager/resource_manager.cpp')
-rw-r--r--mwe/resource-manager/resource_manager.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/mwe/resource-manager/resource_manager.cpp b/mwe/resource-manager/resource_manager.cpp
new file mode 100644
index 0000000..189aa8b
--- /dev/null
+++ b/mwe/resource-manager/resource_manager.cpp
@@ -0,0 +1,35 @@
+
+
+#include "resource_manager.h"
+#include "constants.h"
+#include "resource.h"
+#include <unordered_map>
+
+ResourceManager * ResourceManager::m_single_resource_manager = nullptr;
+
+ResourceManager * ResourceManager::get_instance() {
+ if (m_single_resource_manager == nullptr) {
+ m_single_resource_manager = new ResourceManager();
+ }
+ return m_single_resource_manager;
+}
+
+ResourceManager::ResourceManager() {}
+
+ResourceManager::~ResourceManager() {
+
+ for (auto pair : m_resources) {
+ delete pair.second;
+ }
+
+ delete m_single_resource_manager;
+}
+
+void ResourceManager::Unload(const Constants::FILE_PATH & file_path) {
+ std::unordered_map<Constants::FILE_PATH, Resource *>::iterator itr
+ = m_resources.find(file_path);
+ if (itr != m_resources.end()) {
+ delete itr->second;
+ m_resources.erase(itr);
+ }
+}