module
AssetsAdds asset management to Cubos.
Settings
assets.app.osPath
- path to the application assets directory - will be mounted to `/assets/. If empty (default), no archive is mounted, and the user is responsible for mounting one.assets.app.readOnly
- whether the mounted archive, if any, should be read-only. Default istrue
.assets.builtin.osPath
- path to the builtin assets directory - will be mounted to/builtin/
. If empty (default), no archive is mounted, and the user is responsible for mounting one.
Resources
- Assets - the asset manager, used to access asset data.
Dependencies
Files
- file asset.hpp
- Classes cubos::
engine:: AnyAsset and cubos:: engine:: Asset. - file assets.hpp
- Resource cubos::
engine:: Assets. - file bridge.hpp
- Class cubos::
engine:: AssetBridge. - file file.hpp
- Class cubos::
engine:: FileBridge. - file json.hpp
- Class cubos::
engine:: JSONBridge. - file meta.hpp
- Class cubos::
engine:: AssetMeta. - file plugin.hpp
- Plugin entry point.
Classes
- class cubos::engine::AnyAsset
- Handle to an asset of any type. May either be weak or strong. Weak handles do not guarantee the asset is loaded, while strong handles do.
-
template<typename T>class cubos::engine::Asset
- Handle to an asset of a specific type.
- class cubos::engine::Assets
- Resource which manages all assets. Responsible for loading and unloading assets, storing them in memory, and providing access to them.
- class cubos::engine::AssetBridge
- Bridges are the objects responsible for loading and saving assets from/to disk. They form the bridge between the asset manager and the virtual file system.
- class cubos::engine::FileBridge
- Abstract bridge type defined to reduce boilerplate code in bridge implementations which open a single file to load and save assets.
-
template<typename T>class cubos::engine::JSONBridge
- Bridge for loading and saving assets which are serialized to and from a JSON file.
- class cubos::engine::AssetMeta
- Stores metadata about an asset - the data stored in .meta files. Each asset has a corresponding meta object, which contains load or import parameters.
Typedefs
- using AssetMetaRead = core::memory::ReadGuard<AssetMeta, std::shared_lock<std::shared_mutex>>
- Read-only guard for an asset's metadata.
- using AssetMetaWrite = core::memory::WriteGuard<AssetMeta, std::unique_lock<std::shared_mutex>>
- Read-write guard for an asset's metadata.
-
template<typename T>using AssetRead = core::memory::ReadGuard<T, std::shared_lock<std::shared_mutex>>
- Read-only guard for an asset's data.
-
template<typename T>using AssetWrite = core::memory::WriteGuard<T, std::unique_lock<std::shared_mutex>>
- Read-write guard for an asset's data.
Functions
-
auto assetsPlugin(Cubos& cubos) -> CUBOS_
ENGINE_ API void - Plugin entry function.
-
auto audioPlugin(Cubos& cubos) -> CUBOS_
ENGINE_ API void - Plugin entry function.
Typedef documentation
using AssetMetaRead = core::memory::ReadGuard<AssetMeta, std::shared_lock<std::shared_mutex>>
#include <engine/assets/assets.hpp>
Read-only guard for an asset's metadata.
using AssetMetaWrite = core::memory::WriteGuard<AssetMeta, std::unique_lock<std::shared_mutex>>
#include <engine/assets/assets.hpp>
Read-write guard for an asset's metadata.
#include <engine/assets/assets.hpp>
template<typename T>
using AssetRead = core::memory::ReadGuard<T, std::shared_lock<std::shared_mutex>>
Read-only guard for an asset's data.
Template parameters | |
---|---|
T | The type of the data to guard. |
#include <engine/assets/assets.hpp>
template<typename T>
using AssetWrite = core::memory::WriteGuard<T, std::unique_lock<std::shared_mutex>>
Read-write guard for an asset's data.
Template parameters | |
---|---|
T | The type of the data to guard. |
Function documentation
CUBOS_ ENGINE_ API void assetsPlugin(Cubos& cubos)
#include <engine/assets/plugin.hpp>
Plugin entry function.
Parameters | |
---|---|
cubos | Cubos main class. |
CUBOS_ ENGINE_ API void audioPlugin(Cubos& cubos)
#include <engine/audio/plugin.hpp>
Plugin entry function.
Parameters | |
---|---|
cubos | Cubos main class. |