Resource cache subsystem. Loads resources on demand and stores them for later access.
More...
|
| ResourceCache (Context *context) |
| Construct.
|
|
| ~ResourceCache () override |
| Destruct. Free all resources.
|
|
bool | AddResourceDir (const String &pathName, i32 priority=PRIORITY_LAST) |
| Add a resource load directory. Optional priority parameter which will control search order.
|
|
bool | AddPackageFile (PackageFile *package, i32 priority=PRIORITY_LAST) |
| Add a package file for loading resources from. Optional priority parameter which will control search order.
|
|
bool | AddPackageFile (const String &fileName, i32 priority=PRIORITY_LAST) |
| Add a package file for loading resources from by name. Optional priority parameter which will control search order.
|
|
bool | AddManualResource (Resource *resource) |
| Add a manually created resource. Must be uniquely named within its type.
|
|
void | RemoveResourceDir (const String &pathName) |
| Remove a resource load directory.
|
|
void | RemovePackageFile (PackageFile *package, bool releaseResources=true, bool forceRelease=false) |
| Remove a package file. Optionally release the resources loaded from it.
|
|
void | RemovePackageFile (const String &fileName, bool releaseResources=true, bool forceRelease=false) |
| Remove a package file by name. Optionally release the resources loaded from it.
|
|
void | ReleaseResource (StringHash type, const String &name, bool force=false) |
| Release a resource by name.
|
|
void | ReleaseResources (StringHash type, bool force=false) |
| Release all resources of a specific type.
|
|
void | ReleaseResources (StringHash type, const String &partialName, bool force=false) |
| Release resources of a specific type and partial name.
|
|
void | ReleaseResources (const String &partialName, bool force=false) |
| Release resources of all types by partial name.
|
|
void | ReleaseAllResources (bool force=false) |
| Release all resources. When called with the force flag false, releases all currently unused resources.
|
|
bool | ReloadResource (Resource *resource) |
| Reload a resource. Return true on success. The resource will not be removed from the cache in case of failure.
|
|
void | ReloadResourceWithDependencies (const String &fileName) |
| Reload a resource based on filename. Causes also reload of dependent resources if necessary.
|
|
void | SetMemoryBudget (StringHash type, unsigned long long budget) |
| Set memory budget for a specific resource type, default 0 is unlimited.
|
|
void | SetAutoReloadResources (bool enable) |
| Enable or disable automatic reloading of resources as files are modified. Default false.
|
|
void | SetReturnFailedResources (bool enable) |
| Enable or disable returning resources that failed to load. Default false. This may be useful in editing to not lose resource ref attributes.
|
|
void | SetSearchPackagesFirst (bool value) |
| Define whether when getting resources should check package files or directories first. True for packages, false for directories.
|
|
void | SetFinishBackgroundResourcesMs (int ms) |
| Set how many milliseconds maximum per frame to spend on finishing background loaded resources.
|
|
void | AddResourceRouter (ResourceRouter *router, bool addAsFirst=false) |
| Add a resource router object. By default there is none, so the routing process is skipped.
|
|
void | RemoveResourceRouter (ResourceRouter *router) |
| Remove a resource router object.
|
|
SharedPtr< File > | GetFile (const String &name, bool sendEventOnFailure=true) |
| Open and return a file from the resource load paths or from inside a package file. If not found, use a fallback search with absolute path. Return null if fails. Can be called from outside the main thread.
|
|
Resource * | GetResource (StringHash type, const String &name, bool sendEventOnFailure=true) |
| Return a resource by type and name. Load if not loaded yet. Return null if not found or if fails, unless SetReturnFailedResources(true) has been called. Can be called only from the main thread.
|
|
SharedPtr< Resource > | GetTempResource (StringHash type, const String &name, bool sendEventOnFailure=true) |
| Load a resource without storing it in the resource cache. Return null if not found or if fails. Can be called from outside the main thread if the resource itself is safe to load completely (it does not possess for example GPU data).
|
|
bool | BackgroundLoadResource (StringHash type, const String &name, bool sendEventOnFailure=true, Resource *caller=nullptr) |
| Background load a resource. An event will be sent when complete. Return true if successfully stored to the load queue, false if eg. already exists. Can be called from outside the main thread.
|
|
unsigned | GetNumBackgroundLoadResources () const |
| Return number of pending background-loaded resources.
|
|
void | GetResources (Vector< Resource * > &result, StringHash type) const |
| Return all loaded resources of a specific type.
|
|
Resource * | GetExistingResource (StringHash type, const String &name) |
| Return an already loaded resource of specific type & name, or null if not found. Will not load if does not exist.
|
|
const HashMap< StringHash, ResourceGroup > & | GetAllResources () const |
| Return all loaded resources.
|
|
const Vector< String > & | GetResourceDirs () const |
| Return added resource load directories.
|
|
const Vector< SharedPtr< PackageFile > > & | GetPackageFiles () const |
| Return added package files.
|
|
template<class T > |
T * | GetResource (const String &name, bool sendEventOnFailure=true) |
| Template version of returning a resource by name.
|
|
template<class T > |
T * | GetExistingResource (const String &name) |
| Template version of returning an existing resource by name.
|
|
template<class T > |
SharedPtr< T > | GetTempResource (const String &name, bool sendEventOnFailure=true) |
| Template version of loading a resource without storing it to the cache.
|
|
template<class T > |
void | ReleaseResource (const String &name, bool force=false) |
| Template version of releasing a resource by name.
|
|
template<class T > |
bool | BackgroundLoadResource (const String &name, bool sendEventOnFailure=true, Resource *caller=nullptr) |
| Template version of queueing a resource background load.
|
|
template<class T > |
void | GetResources (Vector< T * > &result) const |
| Template version of returning loaded resources of a specific type.
|
|
bool | Exists (const String &name) const |
| Return whether a file exists in the resource directories or package files. Does not check manually added in-memory resources.
|
|
unsigned long long | GetMemoryBudget (StringHash type) const |
| Return memory budget for a resource type.
|
|
unsigned long long | GetMemoryUse (StringHash type) const |
| Return total memory use for a resource type.
|
|
unsigned long long | GetTotalMemoryUse () const |
| Return total memory use for all resources.
|
|
String | GetResourceFileName (const String &name) const |
| Return full absolute file name of resource if possible, or empty if not found.
|
|
bool | GetAutoReloadResources () const |
| Return whether automatic resource reloading is enabled.
|
|
bool | GetReturnFailedResources () const |
| Return whether resources that failed to load are returned.
|
|
bool | GetSearchPackagesFirst () const |
| Return whether when getting resources should check package files or directories first.
|
|
int | GetFinishBackgroundResourcesMs () const |
| Return how many milliseconds maximum to spend on finishing background loaded resources.
|
|
ResourceRouter * | GetResourceRouter (unsigned index) const |
| Return a resource router by index.
|
|
String | GetPreferredResourceDir (const String &path) const |
| Return either the path itself or its parent, based on which of them has recognized resource subdirectories.
|
|
String | SanitateResourceName (const String &name) const |
| Remove unsupported constructs from the resource name to prevent ambiguity, and normalize absolute filename to resource path relative if possible.
|
|
String | SanitateResourceDirName (const String &name) const |
| Remove unnecessary constructs from a resource directory name and ensure it to be an absolute path.
|
|
void | StoreResourceDependency (Resource *resource, const String &dependency) |
| Store a dependency for a resource. If a dependency file changes, the resource will be reloaded.
|
|
void | ResetDependencies (Resource *resource) |
| Reset dependencies for a resource.
|
|
String | PrintMemoryUsage () const |
| Returns a formatted string containing the memory actively used.
|
|
| Object (Context *context) |
| Construct.
|
|
| ~Object () override |
| Destruct. Clean up self from event sender & receiver structures.
|
|
virtual StringHash | GetType () const =0 |
| Return type hash. More...
|
|
virtual const String & | GetTypeName () const =0 |
| Return type name. More...
|
|
virtual const TypeInfo * | GetTypeInfo () const =0 |
| Return type info.
|
|
virtual void | OnEvent (Object *sender, StringHash eventType, VariantMap &eventData) |
| Handle event.
|
|
bool | IsInstanceOf (StringHash type) const |
| Check current instance is type of specified type.
|
|
bool | IsInstanceOf (const TypeInfo *typeInfo) const |
| Check current instance is type of specified type.
|
|
template<typename T > |
bool | IsInstanceOf () const |
| Check current instance is type of specified class.
|
|
template<typename T > |
T * | Cast () |
| Cast the object to specified most derived class.
|
|
template<typename T > |
const T * | Cast () const |
| Cast the object to specified most derived class.
|
|
void | SubscribeToEvent (StringHash eventType, EventHandler *handler) |
| Subscribe to an event that can be sent by any sender.
|
|
void | SubscribeToEvent (Object *sender, StringHash eventType, EventHandler *handler) |
| Subscribe to a specific sender's event.
|
|
void | SubscribeToEvent (StringHash eventType, const std::function< void(StringHash, VariantMap &)> &function, void *userData=nullptr) |
| Subscribe to an event that can be sent by any sender.
|
|
void | SubscribeToEvent (Object *sender, StringHash eventType, const std::function< void(StringHash, VariantMap &)> &function, void *userData=nullptr) |
| Subscribe to a specific sender's event.
|
|
void | UnsubscribeFromEvent (StringHash eventType) |
| Unsubscribe from an event.
|
|
void | UnsubscribeFromEvent (Object *sender, StringHash eventType) |
| Unsubscribe from a specific sender's event.
|
|
void | UnsubscribeFromEvents (Object *sender) |
| Unsubscribe from a specific sender's events.
|
|
void | UnsubscribeFromAllEvents () |
| Unsubscribe from all events.
|
|
void | UnsubscribeFromAllEventsExcept (const Vector< StringHash > &exceptions, bool onlyUserData) |
| Unsubscribe from all events except those listed, and optionally only those with userdata (script registered events).
|
|
void | SendEvent (StringHash eventType) |
| Send event to all subscribers.
|
|
void | SendEvent (StringHash eventType, VariantMap &eventData) |
| Send event with parameters to all subscribers.
|
|
VariantMap & | GetEventDataMap () const |
| Return a preallocated map for event data. Used for optimization to avoid constant re-allocation of event data maps.
|
|
template<typename... Args> |
void | SendEvent (StringHash eventType, Args... args) |
| Send event with variadic parameter pairs to all subscribers. The parameter pairs is a list of paramID and paramValue separated by comma, one pair after another.
|
|
Context * | GetContext () const |
| Return execution context.
|
|
const Variant & | GetGlobalVar (StringHash key) const |
| Return global variable based on key.
|
|
const VariantMap & | GetGlobalVars () const |
| Return all global variables.
|
|
void | SetGlobalVar (StringHash key, const Variant &value) |
| Set global variable with the respective key and value.
|
|
Object * | GetSubsystem (StringHash type) const |
| Return subsystem by type.
|
|
Object * | GetEventSender () const |
| Return active event sender. Null outside event handling.
|
|
EventHandler * | GetEventHandler () const |
| Return active event handler. Null outside event handling.
|
|
bool | HasSubscribedToEvent (StringHash eventType) const |
| Return whether has subscribed to an event without specific sender.
|
|
bool | HasSubscribedToEvent (Object *sender, StringHash eventType) const |
| Return whether has subscribed to a specific sender's event.
|
|
bool | HasEventHandlers () const |
| Return whether has subscribed to any event.
|
|
template<class T > |
T * | GetSubsystem () const |
| Template version of returning a subsystem.
|
|
const String & | GetCategory () const |
| Return object category. Categories are (optionally) registered along with the object factory. Return an empty string if the object category is not registered.
|
|
void | SetBlockEvents (bool block) |
| Block object from sending and receiving events.
|
|
bool | GetBlockEvents () const |
| Return sending and receiving events blocking status.
|
|
| RefCounted () |
| Construct. Allocate the reference count structure and set an initial self weak reference.
|
|
virtual | ~RefCounted () |
| Destruct. Mark as expired and also delete the reference count structure if no outside weak references exist.
|
|
| RefCounted (const RefCounted &rhs)=delete |
| Prevent copy construction.
|
|
RefCounted & | operator= (const RefCounted &rhs)=delete |
| Prevent assignment.
|
|
void | AddRef () |
| Increment reference count. Can also be called outside of a SharedPtr for traditional reference counting.
|
|
void | ReleaseRef () |
| Decrement reference count and delete self if no more references. Can also be called outside of a SharedPtr for traditional reference counting.
|
|
int | Refs () const |
| Return reference count.
|
|
int | WeakRefs () const |
| Return weak reference count.
|
|
RefCount * | RefCountPtr () |
| Return pointer to the reference count structure.
|
|