diff options
| author | untodesu <kirill@untode.su> | 2025-12-11 15:14:26 +0500 |
|---|---|---|
| committer | untodesu <kirill@untode.su> | 2025-12-11 15:14:26 +0500 |
| commit | f40d09cb8f712e87691af4912f3630d92d692779 (patch) | |
| tree | 7ac3a4168ff722689372fd489c6f94d0a2546e8f /src/core/resource/resource.hh | |
| parent | 8bcbd2729388edc63c82d77d314b583af1447c49 (diff) | |
| download | voxelius-f40d09cb8f712e87691af4912f3630d92d692779.tar.bz2 voxelius-f40d09cb8f712e87691af4912f3630d92d692779.zip | |
Shuffle stuff around
- Use the new and improved hierarchy I figured out when making Prospero chat
- Re-add NSIS scripts, again from Prospero
- Update most build and utility scripts with their most recent versions
Diffstat (limited to 'src/core/resource/resource.hh')
| -rw-r--r-- | src/core/resource/resource.hh | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/src/core/resource/resource.hh b/src/core/resource/resource.hh new file mode 100644 index 0000000..105c7ff --- /dev/null +++ b/src/core/resource/resource.hh @@ -0,0 +1,53 @@ +#pragma once + +template<typename T> +using resource_ptr = std::shared_ptr<const T>; + +constexpr std::uint32_t RESOURCE_CACHE = 0x00000001U; ///< Cache the resource after loading +constexpr std::uint32_t RESOURCE_USER = 0xFFFFFF00U; ///< User-defined flags for custom behavior + +using ResourceLoadFunc = const void* (*)(const char* name, std::uint32_t flags); +using ResourceFreeFunc = void (*)(const void* resource); + +namespace resource::detail +{ +void register_loader(const std::type_info& type, ResourceLoadFunc load_func, ResourceFreeFunc free_func); +resource_ptr<void> load_resource(const std::type_info& type, std::string_view name, std::uint32_t flags); +resource_ptr<void> find_resource(const std::type_info& type, std::string_view name); +} // namespace resource::detail + +namespace resource +{ +template<typename T> +void register_loader(ResourceLoadFunc load_func, ResourceFreeFunc free_func); +template<typename T> +resource_ptr<T> load(std::string_view name, std::uint32_t flags = 0U); +template<typename T> +resource_ptr<T> find(std::string_view name); +} // namespace resource + +namespace resource +{ +void hard_cleanup(void); +void soft_cleanup(void); +} // namespace resource + +template<typename T> +void resource::register_loader(ResourceLoadFunc load_func, ResourceFreeFunc free_func) +{ + resource::detail::register_loader(typeid(T), load_func, free_func); +} + +template<typename T> +resource_ptr<T> resource::load(std::string_view name, std::uint32_t flags) +{ + auto result = resource::detail::load_resource(typeid(T), name, flags); + return std::reinterpret_pointer_cast<const T>(result); +} + +template<typename T> +resource_ptr<T> resource::find(std::string_view name) +{ + auto result = resource::detail::find_resource(typeid(T), name); + return std::reinterpret_pointer_cast<const T>(result); +} |
