mirror of
https://github.com/juce-framework/JUCE.git
synced 2026-01-10 23:44:24 +00:00
Avoided an MS compiler warning in DeletedAtShutdown
This commit is contained in:
parent
dc10e61366
commit
a616f336b2
2 changed files with 27 additions and 17 deletions
|
|
@ -28,58 +28,70 @@
|
|||
==============================================================================
|
||||
*/
|
||||
|
||||
static SpinLock deletedAtShutdownLock;
|
||||
static SpinLock deletedAtShutdownLock; // use a spin lock because it can be statically initialised
|
||||
|
||||
static Array<DeletedAtShutdown*>& getDeletedAtShutdownObjects()
|
||||
{
|
||||
static Array<DeletedAtShutdown*> objects;
|
||||
return objects;
|
||||
}
|
||||
|
||||
DeletedAtShutdown::DeletedAtShutdown()
|
||||
{
|
||||
const SpinLock::ScopedLockType sl (deletedAtShutdownLock);
|
||||
getObjects().add (this);
|
||||
getDeletedAtShutdownObjects().add (this);
|
||||
}
|
||||
|
||||
DeletedAtShutdown::~DeletedAtShutdown()
|
||||
{
|
||||
const SpinLock::ScopedLockType sl (deletedAtShutdownLock);
|
||||
getObjects().removeFirstMatchingValue (this);
|
||||
getDeletedAtShutdownObjects().removeFirstMatchingValue (this);
|
||||
}
|
||||
|
||||
void DeletedAtShutdown::deleteAll()
|
||||
{
|
||||
// make a local copy of the array, so it can't get into a loop if something
|
||||
// creates another DeletedAtShutdown object during its destructor.
|
||||
Array <DeletedAtShutdown*> localCopy;
|
||||
Array<DeletedAtShutdown*> localCopy;
|
||||
|
||||
{
|
||||
const SpinLock::ScopedLockType sl (deletedAtShutdownLock);
|
||||
localCopy = getObjects();
|
||||
localCopy = getDeletedAtShutdownObjects();
|
||||
}
|
||||
|
||||
for (int i = localCopy.size(); --i >= 0;)
|
||||
{
|
||||
#if JUCE_MSVC
|
||||
// Disable unreachable code warning, in case the compiler manages to figure out
|
||||
// that you have no classes of DeletedAtShutdown that could throw an exception here.
|
||||
#pragma warning (push)
|
||||
#pragma warning (disable: 4702)
|
||||
#endif
|
||||
|
||||
JUCE_TRY
|
||||
{
|
||||
DeletedAtShutdown* deletee = localCopy.getUnchecked(i);
|
||||
auto* deletee = localCopy.getUnchecked(i);
|
||||
|
||||
// double-check that it's not already been deleted during another object's destructor.
|
||||
{
|
||||
const SpinLock::ScopedLockType sl (deletedAtShutdownLock);
|
||||
if (! getObjects().contains (deletee))
|
||||
|
||||
if (! getDeletedAtShutdownObjects().contains (deletee))
|
||||
deletee = nullptr;
|
||||
}
|
||||
|
||||
delete deletee;
|
||||
}
|
||||
JUCE_CATCH_EXCEPTION
|
||||
|
||||
#if JUCE_MSVC
|
||||
#pragma warning (pop)
|
||||
#endif
|
||||
}
|
||||
|
||||
// if no objects got re-created during shutdown, this should have been emptied by their
|
||||
// destructors
|
||||
jassert (getObjects().size() == 0);
|
||||
jassert (getDeletedAtShutdownObjects().isEmpty());
|
||||
|
||||
getObjects().clear(); // just to make sure the array doesn't have any memory still allocated
|
||||
}
|
||||
|
||||
Array <DeletedAtShutdown*>& DeletedAtShutdown::getObjects()
|
||||
{
|
||||
static Array <DeletedAtShutdown*> objects;
|
||||
return objects;
|
||||
getDeletedAtShutdownObjects().clear(); // just to make sure the array doesn't have any memory still allocated
|
||||
}
|
||||
|
|
|
|||
|
|
@ -65,7 +65,5 @@ public:
|
|||
static void deleteAll();
|
||||
|
||||
private:
|
||||
static Array <DeletedAtShutdown*>& getObjects();
|
||||
|
||||
JUCE_DECLARE_NON_COPYABLE (DeletedAtShutdown)
|
||||
};
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue