1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
|
// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
// SPDX-License-Identifier: BSD-3-Clause
#include "vtkFilteringInformationKeyManager.h"
#include "vtkCellMetadata.h"
#include "vtkInformationKey.h"
#include <vector>
VTK_ABI_NAMESPACE_BEGIN
std::vector<std::function<void()>>* vtkFilteringInformationKeyManager::Finalizers = nullptr;
// Subclass vector so we can directly call constructor. This works
// around problems on Borland C++.
struct vtkFilteringInformationKeyManagerKeysType : public std::vector<vtkInformationKey*>
{
typedef std::vector<vtkInformationKey*> Superclass;
typedef Superclass::iterator iterator;
};
//------------------------------------------------------------------------------
// Must NOT be initialized. Default initialization to zero is
// necessary.
static unsigned int vtkFilteringInformationKeyManagerCount;
static vtkFilteringInformationKeyManagerKeysType* vtkFilteringInformationKeyManagerKeys;
//------------------------------------------------------------------------------
vtkFilteringInformationKeyManager::vtkFilteringInformationKeyManager()
{
if (++vtkFilteringInformationKeyManagerCount == 1)
{
vtkFilteringInformationKeyManager::ClassInitialize();
}
}
//------------------------------------------------------------------------------
vtkFilteringInformationKeyManager::~vtkFilteringInformationKeyManager()
{
if (--vtkFilteringInformationKeyManagerCount == 0)
{
vtkFilteringInformationKeyManager::ClassFinalize();
}
}
//------------------------------------------------------------------------------
void vtkFilteringInformationKeyManager::Register(vtkInformationKey* key)
{
// Register this instance for deletion by the singleton.
vtkFilteringInformationKeyManagerKeys->push_back(key);
}
//------------------------------------------------------------------------------
void vtkFilteringInformationKeyManager::AddFinalizer(std::function<void()> finalizer)
{
if (!vtkFilteringInformationKeyManager::Finalizers)
{
vtkFilteringInformationKeyManager::Finalizers = new std::vector<std::function<void()>>();
}
vtkFilteringInformationKeyManager::Finalizers->push_back(finalizer);
}
//------------------------------------------------------------------------------
void vtkFilteringInformationKeyManager::ClassInitialize()
{
// Allocate the singleton storing pointers to information keys.
// This must be a malloc/free pair instead of new/delete to work
// around problems on MachO (Mac OS X) runtime systems that do lazy
// symbol loading. Calling operator new here causes static
// initialization to occur in other translation units immediately,
// which then may try to access the vector before it is set here.
void* keys = malloc(sizeof(vtkFilteringInformationKeyManagerKeysType));
vtkFilteringInformationKeyManagerKeys = new (keys) vtkFilteringInformationKeyManagerKeysType;
// The cell-metadata class cannot register its finalizer upon construction
// of the registrar since CommonDataModel cannot depend on CommonExecutionModel.
// So, we always register a finalizer for cell-grid responders.
vtkFilteringInformationKeyManager::AddFinalizer([]() { vtkCellMetadata::ClearResponders(); });
}
//------------------------------------------------------------------------------
void vtkFilteringInformationKeyManager::ClassFinalize()
{
// Allow persistent objects to be cleaned up before debugging leaks.
if (vtkFilteringInformationKeyManager::Finalizers)
{
for (const auto& finalizer : *vtkFilteringInformationKeyManager::Finalizers)
{
finalizer();
}
delete vtkFilteringInformationKeyManager::Finalizers;
vtkFilteringInformationKeyManager::Finalizers = nullptr;
}
if (vtkFilteringInformationKeyManagerKeys)
{
// Delete information keys.
for (vtkFilteringInformationKeyManagerKeysType::iterator i =
vtkFilteringInformationKeyManagerKeys->begin();
i != vtkFilteringInformationKeyManagerKeys->end(); ++i)
{
vtkInformationKey* key = *i;
delete key;
}
// Delete the singleton storing pointers to information keys. See
// ClassInitialize above for why this is a free instead of a
// delete.
vtkFilteringInformationKeyManagerKeys->~vtkFilteringInformationKeyManagerKeysType();
free(vtkFilteringInformationKeyManagerKeys);
vtkFilteringInformationKeyManagerKeys = nullptr;
}
}
VTK_ABI_NAMESPACE_END
|