mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-08-03 15:27:13 -04:00
Merge branch 'document_object_cache' into 'master'
Add documentation for update function of Generic Object Cache See merge request OpenMW/openmw!4164
This commit is contained in:
commit
f7238cd043
@ -53,28 +53,49 @@ namespace Resource
|
|||||||
class GenericObjectCache : public osg::Referenced
|
class GenericObjectCache : public osg::Referenced
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// Update last usage timestamp using referenceTime for each cache time if they are not nullptr and referenced
|
/*
|
||||||
// from somewhere else. Remove items with last usage > expiryTime. Note: last usage might be updated from other
|
* @brief Updates usage timestamps and removes expired items
|
||||||
// places so nullptr or not references elsewhere items are not always removed.
|
*
|
||||||
|
* Updates the lastUsage timestamp of cached non-nullptr items that have external references.
|
||||||
|
* Initializes lastUsage timestamp for new items.
|
||||||
|
* Removes items that haven't been referenced for longer than expiryDelay.
|
||||||
|
*
|
||||||
|
* \note
|
||||||
|
* Last usage might be updated from other places so nullptr items
|
||||||
|
* that are not referenced elsewhere are not always removed.
|
||||||
|
*
|
||||||
|
* @param referenceTime the timestamp indicating when the item was most recently used
|
||||||
|
* @param expiryDelay the delay after which the cache entry for an item expires
|
||||||
|
*/
|
||||||
void update(double referenceTime, double expiryDelay)
|
void update(double referenceTime, double expiryDelay)
|
||||||
{
|
{
|
||||||
std::vector<osg::ref_ptr<osg::Object>> objectsToRemove;
|
std::vector<osg::ref_ptr<osg::Object>> objectsToRemove;
|
||||||
{
|
{
|
||||||
const double expiryTime = referenceTime - expiryDelay;
|
const double expiryTime = referenceTime - expiryDelay;
|
||||||
std::lock_guard<std::mutex> lock(mMutex);
|
std::lock_guard<std::mutex> lock(mMutex);
|
||||||
|
|
||||||
std::erase_if(mItems, [&](auto& v) {
|
std::erase_if(mItems, [&](auto& v) {
|
||||||
Item& item = v.second;
|
Item& item = v.second;
|
||||||
|
|
||||||
|
// update last usage timestamp if item is being referenced externally
|
||||||
|
// or initialize if not set
|
||||||
if ((item.mValue != nullptr && item.mValue->referenceCount() > 1) || item.mLastUsage == 0)
|
if ((item.mValue != nullptr && item.mValue->referenceCount() > 1) || item.mLastUsage == 0)
|
||||||
item.mLastUsage = referenceTime;
|
item.mLastUsage = referenceTime;
|
||||||
|
|
||||||
|
// skip items that have been accessed since expiryTime
|
||||||
if (item.mLastUsage > expiryTime)
|
if (item.mLastUsage > expiryTime)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
++mExpired;
|
++mExpired;
|
||||||
|
|
||||||
|
// just mark for removal here so objects can be removed in bulk outside the lock
|
||||||
if (item.mValue != nullptr)
|
if (item.mValue != nullptr)
|
||||||
objectsToRemove.push_back(std::move(item.mValue));
|
objectsToRemove.push_back(std::move(item.mValue));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// note, actual unref happens outside of the lock
|
// remove expired items from cache
|
||||||
objectsToRemove.clear();
|
objectsToRemove.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user