Revert "Core/RefCounted: Remove persistent boolean"
This reverts commit db2ef3e90c3871290d114a9e6437b412e96c65aa [formerly a3f6ff88a25e63374eb6ce5b18269da2ba743b06] [formerly cfa12604fbb0da76fc27288b210ee1254a8b3a38 [formerly dee6ce858398e2de38ef1af00c1c630fd0126e09]] [formerly 1a23f0fddcd80ac33030061b7a00a3cfd43cb7fe [formerly d3cb17069c71449ae3f1cba6de55ea70f509e7a4] [formerly b2f8f82e9f3427310204f2e8a61d7bdfd96202d2 [formerly 5d117720d08d6d6243b3428d4b3f8aea1abef845]]]. Former-commit-id: fcbfc6cb2fac86f6f10ff5def148cc5635082c83 [formerly 6bcf746c9b6f35aff6786da950001da11cedfc48] [formerly 9d219f350ddebbfa60eaa9c382d8d811d963ac15 [formerly 75f534e850802526877b811e8f6ca510bb7f2c16]] Former-commit-id: b5ca8fa1bde036ccb4f7be17a98ef8275ab5cf2a [formerly ee166858dad5c8cd00249894266b13e8ce1a153e] Former-commit-id: 2a601076664aebc1107654dd80f3b53f7acbc044
This commit is contained in:
@@ -23,10 +23,13 @@ namespace Nz
|
||||
*/
|
||||
|
||||
/*!
|
||||
* \brief Constructs a RefCounted object
|
||||
* \brief Constructs a RefCounted object with a persistance aspect
|
||||
*
|
||||
* \param persistent if false, object is destroyed when no more referenced
|
||||
*/
|
||||
|
||||
RefCounted::RefCounted() :
|
||||
RefCounted::RefCounted(bool persistent) :
|
||||
m_persistent(persistent),
|
||||
m_referenceCount(0)
|
||||
{
|
||||
}
|
||||
@@ -64,6 +67,16 @@ namespace Nz
|
||||
return m_referenceCount;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Checks whether the object is persistent
|
||||
* \return true if object is not destroyed when no more referenced
|
||||
*/
|
||||
|
||||
bool RefCounted::IsPersistent() const
|
||||
{
|
||||
return m_persistent;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Removes a reference to the object
|
||||
* \return true if object is deleted because no more referenced
|
||||
@@ -81,7 +94,7 @@ namespace Nz
|
||||
}
|
||||
#endif
|
||||
|
||||
if (--m_referenceCount == 0)
|
||||
if (--m_referenceCount == 0 && !m_persistent)
|
||||
{
|
||||
delete this; // Suicide
|
||||
|
||||
@@ -90,4 +103,26 @@ namespace Nz
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Sets the persistence of the object
|
||||
* \return true if object is deleted because no more referenced
|
||||
*
|
||||
* \param persistent Sets the persistence of the object
|
||||
* \param checkReferenceCount Checks if the object should be destroyed if true
|
||||
*/
|
||||
|
||||
bool RefCounted::SetPersistent(bool persistent, bool checkReferenceCount)
|
||||
{
|
||||
m_persistent = persistent;
|
||||
|
||||
if (checkReferenceCount && !persistent && m_referenceCount == 0)
|
||||
{
|
||||
delete this;
|
||||
|
||||
return true;
|
||||
}
|
||||
else
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user