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
|
// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
// SPDX-License-Identifier: BSD-3-Clause
#include "vtkCellGrid.h"
#include "vtkCellGridResponders.h"
#include "vtkCellMetadata.h"
#include "vtkDGTet.h"
#include "vtkDGTri.h"
#include "vtkDataSetAttributes.h"
#include "vtkDoubleArray.h"
#include "vtkIOCellGrid.h"
#include "vtkIdTypeArray.h"
#include "vtkIntArray.h"
#include "vtkNew.h"
#include "vtkSmartPointer.h"
#include "vtkTable.h"
#include "vtkTestUtilities.h"
#include "vtkVector.h"
using namespace vtk::literals;
namespace
{
bool InheritanceHierarchyExists()
{
vtkNew<vtkCellGrid> grid;
bool ok = true;
// Iterate over every registered cell type and ensure it overrides the
// InheritanceHierarchy() method on its leaf node.
for (const auto& cellTypeName : vtkCellMetadata::CellTypes())
{
auto cellType = vtkCellMetadata::NewInstance(cellTypeName.Data(), grid);
if (!cellType)
{
std::cerr << "ERROR! Could not create cell of type " << cellTypeName.Data() << "\n";
ok = false;
continue;
}
auto classNames = cellType->InheritanceHierarchy();
std::cout << " " << cellTypeName.Data() << " hierarchy:\n ";
bool didFindSelf = false;
bool once = true;
for (const auto& className : classNames)
{
if (className == "vtkObject"_token)
{
break;
}
std::cout << (once ? " " : " → ") << className.Data();
once = false;
if (className == vtkStringToken(cellType->GetClassName()))
{
didFindSelf = true;
}
}
std::cout << "\n";
if (!didFindSelf)
{
std::cerr << " ERROR! Could not find " << cellType->GetClassName() << "\n";
ok = false;
}
}
return ok;
}
} // anonymous namespace
int TestCellGridInheritance(int argc, char* argv[])
{
(void)argc;
(void)argv;
vtkIOCellGrid::RegisterCellsAndResponders();
if (!InheritanceHierarchyExists())
{
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
|