4#ifndef vtkDataArrayMeta_h
5#define vtkDataArrayMeta_h
9#include "vtkDebugRangeIterators.h"
28#if defined(VTK_DEBUG_RANGE_ITERATORS)
29#define VTK_ITER_ASSERT(x, msg) assert((x) && msg)
31#define VTK_ITER_ASSERT(x, msg)
34#if (defined(VTK_ALWAYS_OPTIMIZE_ARRAY_ITERATORS) || !defined(VTK_DEBUG_RANGE_ITERATORS)) && \
35 !defined(VTK_COMPILER_MSVC)
36#define VTK_ITER_INLINE VTK_ALWAYS_INLINE
37#define VTK_ITER_ASSUME VTK_ASSUME_NO_ASSERT
38#define VTK_ITER_OPTIMIZE_START VTK_ALWAYS_OPTIMIZE_START
39#define VTK_ITER_OPTIMIZE_END VTK_ALWAYS_OPTIMIZE_END
41#define VTK_ITER_INLINE inline
42#define VTK_ITER_ASSUME VTK_ASSUME
43#define VTK_ITER_OPTIMIZE_START
44#define VTK_ITER_OPTIMIZE_END
50VTK_ABI_NAMESPACE_BEGIN
51template <
typename ValueType>
57VTK_ABI_NAMESPACE_BEGIN
67VTK_ABI_NAMESPACE_BEGIN
79 std::is_base_of_v<vtkAbstractArray, T> && !std::is_same_v<vtkAbstractArray, T>;
97template <ComponentIdType Size>
98struct IsValidTupleSize : std::integral_constant<bool, (Size > 0 || Size == DynamicTupleSize)>
102template <ComponentIdType TupleSize>
107template <ComponentIdType Size>
112template <ComponentIdType TupleSize>
117template <ComponentIdType S1, ComponentIdType S2>
119 : std::integral_constant<bool, (IsStaticTupleSize<S1>::value && IsStaticTupleSize<S2>::value)>
123template <ComponentIdType S1, ComponentIdType S2,
typename T =
void>
125 typename std::enable_if<AreStaticTupleSizes<S1, S2>::value, T>::type;
129template <ComponentIdType S1, ComponentIdType S2>
131 : std::integral_constant<bool, (!IsStaticTupleSize<S1>::value || !IsStaticTupleSize<S2>::value)>
135template <ComponentIdType S1, ComponentIdType S2,
typename T =
void>
137 std::enable_if_t<IsEitherTupleSizeDynamic<S1, S2>::value, T>;
142template <ComponentIdType TupleSize>
148 using Superclass = std::integral_constant<ComponentIdType, TupleSize>;
152 using Superclass::Superclass;
168 :
value(array->GetNumberOfComponents())
178template <
typename ArrayType,
typename ForceValueTypeForVtkDataArray =
double>
181 using APIType =
typename ArrayType::ValueType;
183template <
typename ForceValueTypeForVtkDataArray>
186 using APIType = ForceValueTypeForVtkDataArray;
192VTK_ABI_NAMESPACE_BEGIN
196template <
typename ArrayType,
typename ForceValueTypeForVtkDataArray = double,
206VTK_ABI_NAMESPACE_BEGIN
208template <
typename ArrayType>
212 static constexpr bool value = std::is_base_of<vtkAOSDataArrayTemplate<APIType>, ArrayType>
::value;
218VTK_ABI_NAMESPACE_BEGIN
221template <
typename ArrayType>
222using IsAOSDataArray = std::integral_constant<bool, detail::IsAOSDataArrayImpl<ArrayType>::value>;
Array-Of-Structs implementation of vtkGenericDataArray.
Abstract superclass for all arrays.
std::enable_if_t< IsVtkDataArray< T >::value > EnableIfVtkDataArray
static constexpr ComponentIdType DynamicTupleSize
std::enable_if_t< IsValidTupleSize< TupleSize >::value > EnableIfValidTupleSize
std::enable_if_t< IsStaticTupleSize< TupleSize >::value > EnableIfStaticTupleSize
std::enable_if_t< IsEitherTupleSizeDynamic< S1, S2 >::value, T > EnableIfEitherTupleSizeIsDynamic
std::enable_if_t< IsVtkArray< T >::value > EnableIfVtkArray
typename std::enable_if< AreStaticTupleSizes< S1, S2 >::value, T >::type EnableIfStaticTupleSizes
Specialization of tuple ranges and iterators for vtkAOSDataArrayTemplate.
typename detail::GetAPITypeImpl< ArrayType, ForceValueTypeForVtkDataArray >::APIType GetAPIType
std::integral_constant< bool, detail::IsAOSDataArrayImpl< ArrayType >::value > IsAOSDataArray
VTK_ITER_INLINE GenericTupleSize() noexcept
VTK_ITER_INLINE value_type operator()() const noexcept
ComponentIdType value_type
VTK_ITER_INLINE GenericTupleSize(vtkAbstractArray *array)
VTK_ITER_INLINE GenericTupleSize() noexcept=default
ForceValueTypeForVtkDataArray APIType
typename ArrayType::ValueType APIType
static constexpr bool value
GetAPIType< ArrayType > APIType
static constexpr bool value