aboutsummaryrefslogtreecommitdiff
path: root/resource-manager/resource_manager.cpp
diff options
context:
space:
mode:
authorjaroWMR <jarorutjes07@gmail.com>2024-10-23 19:57:44 +0200
committerjaroWMR <jarorutjes07@gmail.com>2024-10-23 19:57:44 +0200
commitedbb6c892299e3b7f93638abcc9e55b2cfce2358 (patch)
treed9c306af19636f5c757397ec1c1a157a93c12f0c /resource-manager/resource_manager.cpp
parent1b96c6e3c57b9d1dc5fb02cbd24b625d7f7f5b05 (diff)
parenteaa05e7a981b0f581f5393882e4753d9294a3dba (diff)
merge with niels/rendering
Diffstat (limited to 'resource-manager/resource_manager.cpp')
-rw-r--r--resource-manager/resource_manager.cpp38
1 files changed, 38 insertions, 0 deletions
diff --git a/resource-manager/resource_manager.cpp b/resource-manager/resource_manager.cpp
new file mode 100644
index 0000000..aee0ce2
--- /dev/null
+++ b/resource-manager/resource_manager.cpp
@@ -0,0 +1,38 @@
+
+
+#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);
+ }
+}
+