diff options
author | Loek Le Blansch <loek@pipeframe.xyz> | 2024-12-10 19:19:10 +0100 |
---|---|---|
committer | Loek Le Blansch <loek@pipeframe.xyz> | 2024-12-10 19:19:10 +0100 |
commit | 963c6c0d3e77c20ec2a2ca2b045bfae3e070702f (patch) | |
tree | cd3adce16793a466365ebf4ead9c1398fcbd7879 /src/crepe/manager/ResourceManager.hpp | |
parent | bf32bee7d66a701c43676e28b87e19138c0c8666 (diff) | |
parent | 7cbc577e94ed048f2a8146fab6972ae6ff290be7 (diff) |
merge master
Diffstat (limited to 'src/crepe/manager/ResourceManager.hpp')
-rw-r--r-- | src/crepe/manager/ResourceManager.hpp | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/crepe/manager/ResourceManager.hpp b/src/crepe/manager/ResourceManager.hpp new file mode 100644 index 0000000..5167d71 --- /dev/null +++ b/src/crepe/manager/ResourceManager.hpp @@ -0,0 +1,27 @@ +#pragma once + +#include <format> + +#include "ResourceManager.h" + +namespace crepe { + +template <typename T> +T & ResourceManager::get(const Asset & asset) { + using namespace std; + static_assert(is_base_of<Resource, T>::value, + "cache must recieve a derivative class of Resource"); + + CacheEntry & entry = this->get_entry(asset); + if (entry.resource == nullptr) entry.resource = make_unique<T>(asset); + + T * concrete_resource = dynamic_cast<T *>(entry.resource.get()); + if (concrete_resource == nullptr) + throw runtime_error(format("ResourceManager: mismatch between requested type and " + "actual type of resource ({})", + asset.get_path())); + + return *concrete_resource; +} + +} // namespace crepe |