4 #ifndef OPENVDB_TYPES_HAS_BEEN_INCLUDED
5 #define OPENVDB_TYPES_HAS_BEEN_INCLUDED
9 #include <OpenEXR/half.h>
21 #include <type_traits>
36 using Byte =
unsigned char;
91 template<
typename T>
using SharedPtr = std::shared_ptr<T>;
92 template<
typename T>
using WeakPtr = std::weak_ptr<T>;
132 template<
typename IntType_, Index Kind>
135 static_assert(std::is_integral<IntType_>::value,
"PointIndex requires an integer value type");
168 template <
typename T,
template <
typename...>
class Template>
171 template <
typename... Args,
template <
typename...>
class Template>
178 template<typename T, bool = IsSpecializationOf<T, math::Vec2>::value ||
183 static const bool IsVec =
true;
184 static const int Size = T::size;
191 static const bool IsVec =
false;
192 static const int Size = 1;
196 template<typename T, bool = IsSpecializationOf<T, math::Quat>::value>
199 static const bool IsQuat =
true;
200 static const int Size = T::size;
207 static const bool IsQuat =
false;
208 static const int Size = 1;
212 template<typename T, bool = IsSpecializationOf<T, math::Mat3>::value ||
216 static const bool IsMat =
true;
217 static const int Size = T::size;
224 static const bool IsMat =
false;
225 static const int Size = 1;
229 template<typename T, bool = VecTraits<T>::IsVec ||
237 static const bool IsScalar =
false;
238 static const int Size = T::size;
239 static const int Elements = IsMat ? Size*Size : Size;
246 static const bool IsVec =
false;
247 static const bool IsQuat =
false;
248 static const bool IsMat =
false;
249 static const bool IsScalar =
true;
250 static const int Size = 1;
251 static const int Elements = 1;
261 template<
typename FromType,
typename ToType>
262 struct CanConvertType {
enum { value = std::is_constructible<ToType, FromType>::value }; };
273 template<
typename T0,
typename T1>
275 template<
typename T0,
typename T1>
277 template<
typename T0,
typename T1>
298 using Type =
typename std::remove_const<ToType>::type;
302 template<
typename FromType,
typename ToType>
struct CopyConstness<const FromType, ToType> {
303 using Type =
const ToType;
313 template<
typename... Ts>
struct TypeList;
330 template<
typename ListT,
size_t Idx,
typename =
void>
struct TSGetElementImpl;
335 template<
typename... Ts,
size_t Idx>
336 struct TSGetElementImpl<TypeList<Ts...>, Idx,
337 typename
std::enable_if<(Idx < sizeof...(Ts) && sizeof...(Ts))>::type> {
338 using type =
typename std::tuple_element<Idx, std::tuple<Ts...>>::type;
345 template<
typename... Ts,
size_t Idx>
346 struct TSGetElementImpl<TypeList<Ts...>, Idx,
347 typename
std::enable_if<!(Idx < sizeof...(Ts) && sizeof...(Ts))>::type> {
348 using type = NullType;
364 template <
typename ListT,
typename T,
size_t=0>
365 struct TSHasTypeImpl;
372 template <
typename T,
size_t Idx>
373 struct TSHasTypeImpl<TypeList<>, T, Idx> {
374 static constexpr
bool Value =
false;
375 static constexpr int64_t
Index = -1;
385 template <
typename U,
typename T,
typename... Ts,
size_t Idx>
386 struct TSHasTypeImpl<TypeList<U, Ts...>, T, Idx> :
387 TSHasTypeImpl<TypeList<Ts...>, T, Idx+1> {};
394 template <
typename T,
typename... Ts,
size_t Idx>
395 struct TSHasTypeImpl<TypeList<T, Ts...>, T, Idx>
397 static constexpr
bool Value =
true;
398 static constexpr int64_t
Index =
static_cast<int64_t
>(Idx);
412 template <
typename ListT,
typename... Ts>
413 struct TSMakeUniqueImpl {
425 template <
typename... Ts,
typename U,
typename... Us>
426 struct TSMakeUniqueImpl<TypeList<Ts...>, U, Us...>
428 using type =
typename std::conditional<
429 TSHasTypeImpl<TypeList<Ts...>, U>::Value,
430 typename TSMakeUniqueImpl<TypeList<Ts...>, Us...>::type,
431 typename TSMakeUniqueImpl<TypeList<Ts..., U>, Us...>::type >::type;
439 template<
typename ListT,
typename... Ts>
struct TSAppendImpl;
445 template<
typename... Ts,
typename... OtherTs>
446 struct TSAppendImpl<TypeList<Ts...>, OtherTs...> {
447 using type = TypeList<Ts..., OtherTs...>;
454 template<
typename... Ts,
typename... OtherTs>
455 struct TSAppendImpl<TypeList<Ts...>, TypeList<OtherTs...>> {
456 using type = TypeList<Ts..., OtherTs...>;
464 template<
typename ListT,
typename T>
struct TSEraseImpl;
469 struct TSEraseImpl<TypeList<>, T> {
using type = TypeList<>; };
476 template<
typename... Ts,
typename T>
477 struct TSEraseImpl<TypeList<T, Ts...>, T> {
478 using type =
typename TSEraseImpl<TypeList<Ts...>, T>::type;
487 template<
typename T2,
typename... Ts,
typename T>
488 struct TSEraseImpl<TypeList<T2, Ts...>, T> {
489 using type =
typename TSAppendImpl<TypeList<T2>,
490 typename TSEraseImpl<TypeList<Ts...>, T>::type>::type;
499 template<
typename ListT,
typename... Ts>
struct TSRemoveImpl;
503 template<
typename ListT>
504 struct TSRemoveImpl<ListT> {
using type = ListT; };
511 template<
typename ListT,
typename T,
typename... Ts>
512 struct TSRemoveImpl<ListT, T, Ts...> {
513 using type =
typename TSRemoveImpl<typename TSEraseImpl<ListT, T>::type, Ts...>::type;
521 template<
typename ListT,
typename... Ts>
522 struct TSRemoveImpl<ListT, TypeList<Ts...>> {
523 using type =
typename TSRemoveImpl<ListT, Ts...>::type;
531 struct TSRemoveFirstImpl {
532 using type = TypeList<>;
539 template<
typename T,
typename... Ts>
540 struct TSRemoveFirstImpl<TypeList<T, Ts...>> {
541 using type = TypeList<Ts...>;
550 struct TSRemoveLastImpl {
using type = TypeList<>; };
559 struct TSRemoveLastImpl<TypeList<T>> : TSRemoveLastImpl<T> {};
567 template<
typename T,
typename... Ts>
568 struct TSRemoveLastImpl<TypeList<T, Ts...>>
571 typename TypeList<T>::template
572 Append<
typename TSRemoveLastImpl<TypeList<Ts...>>::type>;
588 template<
typename ListT,
size_t First,
size_t Last,
size_t Idx=0>
589 struct TSRemoveIndicesImpl;
595 template<
size_t First,
size_t Last,
size_t Idx>
596 struct TSRemoveIndicesImpl<TypeList<>, First, Last, Idx> {
597 using type = TypeList<>;
605 template<
typename T,
size_t First,
size_t Last,
size_t Idx>
606 struct TSRemoveIndicesImpl<TypeList<T>, First, Last, Idx>
609 static constexpr
bool Remove = Idx >= First && Idx <= Last;
611 using type =
typename std::conditional<Remove, TypeList<>, TypeList<T>>::type;
626 template<
typename T,
typename... Ts,
size_t First,
size_t Last,
size_t Idx>
627 struct TSRemoveIndicesImpl<TypeList<T, Ts...>, First, Last, Idx>
630 using ThisList =
typename TSRemoveIndicesImpl<TypeList<T>, First, Last, Idx>::type;
631 using NextList =
typename TSRemoveIndicesImpl<TypeList<Ts...>, First, Last, Idx+1>::type;
633 using type =
typename ThisList::template Append<NextList>;
637 template<
typename OpT>
inline void TSForEachImpl(OpT) {}
638 template<
typename OpT,
typename T,
typename... Ts>
639 inline void TSForEachImpl(OpT op) { op(T()); TSForEachImpl<OpT, Ts...>(op); }
651 template<
typename... Ts>
658 static constexpr
size_t Size =
sizeof...(Ts);
663 using Get =
typename internal::TSGetElementImpl<Self, N>::type;
680 static constexpr
bool Contains = internal::TSHasTypeImpl<Self, T>::Value;
709 using Unique =
typename internal::TSMakeUniqueImpl<TypeList<>, Ts...>::type;
724 template<
typename... TypesToAppend>
725 using Append =
typename internal::TSAppendImpl<
Self, TypesToAppend...>::type;
737 template<
typename... TypesToRemove>
738 using Remove =
typename internal::TSRemoveImpl<
Self, TypesToRemove...>::type;
753 using PopFront =
typename internal::TSRemoveFirstImpl<Self>::type;
768 using PopBack =
typename internal::TSRemoveLastImpl<Self>::type;
784 template <
size_t First,
size_t Last>
785 using RemoveByIndex =
typename internal::TSRemoveIndicesImpl<Self, First, Last>::type;
807 template<
typename OpT>
808 static void foreach(OpT op) { internal::TSForEachImpl<OpT, Ts...>(op); }
903 template<>
inline const char* typeNameAsString<std::string>() {
return "string"; }
908 template<>
inline const char* typeNameAsString<math::Quats>() {
return "quats"; }
909 template<>
inline const char* typeNameAsString<math::Quatd>() {
return "quatd"; }
930 template<
typename AValueType,
typename BValueType = AValueType>
940 , mResultValPtr(&mResultVal)
943 , mResultIsActive(false)
948 CombineArgs(
const AValueType& a,
const BValueType& b, AValueType& result,
949 bool aOn =
false,
bool bOn =
false)
952 , mResultValPtr(&result)
956 this->updateResultActive();
960 CombineArgs(
const AValueType& a,
const BValueType& b,
bool aOn =
false,
bool bOn =
false)
963 , mResultValPtr(&mResultVal)
967 this->updateResultActive();
971 const AValueType&
a()
const {
return *mAValPtr; }
973 const BValueType&
b()
const {
return *mBValPtr; }
975 const AValueType& result()
const {
return *mResultValPtr; }
977 AValueType&
result() {
return *mResultValPtr; }
1021 template<
typename ValueType,
typename CombineOp>
1057 #define OPENVDB_START_THREADSAFE_STATIC_REFERENCE __pragma(warning(disable:1710))
1058 #define OPENVDB_FINISH_THREADSAFE_STATIC_REFERENCE __pragma(warning(default:1710))
1059 #define OPENVDB_START_THREADSAFE_STATIC_WRITE __pragma(warning(disable:1711))
1060 #define OPENVDB_FINISH_THREADSAFE_STATIC_WRITE __pragma(warning(default:1711))
1061 #define OPENVDB_START_THREADSAFE_STATIC_ADDRESS __pragma(warning(disable:1712))
1062 #define OPENVDB_FINISH_THREADSAFE_STATIC_ADDRESS __pragma(warning(default:1712))
1066 #define OPENVDB_START_NON_THREADSAFE_STATIC_REFERENCE __pragma(warning(disable:1710))
1067 #define OPENVDB_FINISH_NON_THREADSAFE_STATIC_REFERENCE __pragma(warning(default:1710))
1068 #define OPENVDB_START_NON_THREADSAFE_STATIC_WRITE __pragma(warning(disable:1711))
1069 #define OPENVDB_FINISH_NON_THREADSAFE_STATIC_WRITE __pragma(warning(default:1711))
1070 #define OPENVDB_START_NON_THREADSAFE_STATIC_ADDRESS __pragma(warning(disable:1712))
1071 #define OPENVDB_FINISH_NON_THREADSAFE_STATIC_ADDRESS __pragma(warning(default:1712))
1074 #define OPENVDB_THREADSAFE_STATIC_REFERENCE(CODE) \
1075 __pragma(warning(disable:1710)); CODE; __pragma(warning(default:1710))
1076 #define OPENVDB_THREADSAFE_STATIC_WRITE(CODE) \
1077 __pragma(warning(disable:1711)); CODE; __pragma(warning(default:1711))
1078 #define OPENVDB_THREADSAFE_STATIC_ADDRESS(CODE) \
1079 __pragma(warning(disable:1712)); CODE; __pragma(warning(default:1712))
1081 #else // GCC does not support these compiler warnings
1083 #define OPENVDB_START_THREADSAFE_STATIC_REFERENCE
1084 #define OPENVDB_FINISH_THREADSAFE_STATIC_REFERENCE
1085 #define OPENVDB_START_THREADSAFE_STATIC_WRITE
1086 #define OPENVDB_FINISH_THREADSAFE_STATIC_WRITE
1087 #define OPENVDB_START_THREADSAFE_STATIC_ADDRESS
1088 #define OPENVDB_FINISH_THREADSAFE_STATIC_ADDRESS
1090 #define OPENVDB_START_NON_THREADSAFE_STATIC_REFERENCE
1091 #define OPENVDB_FINISH_NON_THREADSAFE_STATIC_REFERENCE
1092 #define OPENVDB_START_NON_THREADSAFE_STATIC_WRITE
1093 #define OPENVDB_FINISH_NON_THREADSAFE_STATIC_WRITE
1094 #define OPENVDB_START_NON_THREADSAFE_STATIC_ADDRESS
1095 #define OPENVDB_FINISH_NON_THREADSAFE_STATIC_ADDRESS
1097 #define OPENVDB_THREADSAFE_STATIC_REFERENCE(CODE) CODE
1098 #define OPENVDB_THREADSAFE_STATIC_WRITE(CODE) CODE
1099 #define OPENVDB_THREADSAFE_STATIC_ADDRESS(CODE) CODE
1101 #endif // defined(__ICC)
1103 #endif // OPENVDB_TYPES_HAS_BEEN_INCLUDED