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
|
/*=========================================================================
Program: Visualization Toolkit
Module: vtkInformationInternals.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkInformationInternals
* @brief internal structure for vtkInformation
*
* vtkInformationInternals is used in internal implementation of
* vtkInformation. This should only be accessed by friends
* and sub-classes of that class.
*/
#ifndef vtkInformationInternals_h
#define vtkInformationInternals_h
#include "vtkInformationKey.h"
#include "vtkObjectBase.h"
#include <cstdint>
#define VTK_INFORMATION_USE_HASH_MAP
#ifdef VTK_INFORMATION_USE_HASH_MAP
#include <unordered_map>
#else
#include <map>
#endif
//----------------------------------------------------------------------------
VTK_ABI_NAMESPACE_BEGIN
class vtkInformationInternals
{
public:
typedef vtkInformationKey* KeyType;
typedef vtkObjectBase* DataType;
#ifdef VTK_INFORMATION_USE_HASH_MAP
struct HashFun
{
size_t operator()(KeyType key) const
{
return reinterpret_cast<uintptr_t>(key) / sizeof(vtkInformationKey);
}
};
typedef std::unordered_map<KeyType, DataType, HashFun> MapType;
#else
typedef std::map<KeyType, DataType> MapType;
#endif
MapType Map;
#ifdef VTK_INFORMATION_USE_HASH_MAP
vtkInformationInternals()
: Map(33)
{
}
#endif
~vtkInformationInternals()
{
for (MapType::iterator i = this->Map.begin(); i != this->Map.end(); ++i)
{
if (vtkObjectBase* value = i->second)
{
value->UnRegister(nullptr);
}
}
}
#ifdef VTK_INFORMATION_USE_HASH_MAP
private:
vtkInformationInternals(vtkInformationInternals const&) = delete;
#endif
};
#undef VTK_INFORMATION_USE_HASH_MAP
VTK_ABI_NAMESPACE_END
#endif
// VTK-HeaderTest-Exclude: vtkInformationInternals.h
|