Data Types

Detailed Description

Groups

 GRADIENT_INTERPOLATION_TYPE
 
 SPLINEMAPPER_INTERPOLATION_TYPE
 
 SPLINEMAPPER_KNOT_FLAGS
 
 SPLINEMAPPER_RANGE_STATE
 
 SPLINEMAPPER_SPLINE_TYPE
 

Classes

struct  IntType< BYTES >
 
struct  IntType< 1 >
 
struct  IntType< 2 >
 
struct  IntType< 4 >
 
struct  IntType< 8 >
 
struct  UIntType< BYTES >
 
struct  UIntType< 1 >
 
struct  UIntType< 2 >
 
struct  UIntType< 4 >
 
struct  UIntType< 8 >
 
struct  StandardType< T, INTEGRAL >
 
struct  StandardType< T, true >
 
class  Block< T, STRIDED, MOVE >
 
class  GenericComponent
 
class  Result< RESULT_TYPE >
 
class  ResultOk< T >
 
class  EmptyClass
 
class  EmptyVirtualClass
 
class  SFINAEHelper< T, CHECK >
 
struct  is_constructible< maxon::Generic, const maxon::Generic & >
 
class  ThreadReferencedError
 
struct  TestForCopyFromMember< T >
 
class  ObjectConstructor< T, hasCopyFrom >
 
class  ObjectConstructor< T, false >
 
struct  HasInit< DETECTORINPUTTYPE >
 
struct  AlignedStorage< SIZE, ALIGN >
 
class  DefaultLValue< VALUETYPE >
 
class  DataDictionaryInterface
 
class  DataDictionaryIteratorInterface
 
class  DataDictionaryIterator
 
class  DataDictionaryObjectInterface
 
class  DataDictionaryReferenceObjectInterface
 
class  UnregisteredDataTypeErrorInterface
 
struct  IsSimdElementType< T, CHECK >
 
struct  IsSimdElementType< T, typename SFINAEHelper< void, typename T::VectorStrideType >::type >
 
struct  SimdInfo
 
class  SimdBlock< T >
 
struct  AInt
 
struct  AUInt
 
struct  AFloat
 
struct  CheckedGetDataType< T, POLICY, QUALIFIED >
 
class  DataTypeCache
 
class  DataTypeCacheInstance< T, POLICY, ELEMENTARY >
 
class  DataTypeCacheInstance< T, POLICY, true >
 
class  DataTypeCacheInstance< void, POLICY, true >
 
class  DataTypeCacheInstance< std::nullptr_t, POLICY, true >
 
class  DataTypeCacheInstance< InvalidType, POLICY, true >
 
struct  NamedTupleMembers
 
class  NamedTuple< T >
 
class  TupleValue
 
class  FunctionDataType
 
struct  DataMemBlock
 
class  Opt< T >
 
class  DataTypePtr
 
class  DataTypeImpl
 
class  DataTypeImpl::Primary
 
class  DataTypeImpl::Instantiated
 
class  DataType
 
class  DataType::Primary
 
class  Data
 
struct  IsZeroInitialized< Data >
 
class  ConstDataPtr
 
class  ConstDataPtr::Wrapper< T, CHECK >
 
class  DataPtr
 
class  MoveDataPtr
 
struct  ForwardingDataPtr
 
class  TrivialDataPtr
 
class  AbstractDataTypeFunctions
 
class  DataTypeReferenceFunctions< T, SUPER >
 
class  DefaultDataTypeFunctionsBase< T >
 
class  DefaultDataTypeFunctions< T, TYPE >
 
class  DefaultDataTypeFunctions< T, DATATYPEMODE::SMALLISPOD >
 
class  DefaultDataTypeFunctions< T, DATATYPEMODE::SMALL >
 
class  DefaultDataTypeFunctions< T, DATATYPEMODE::BIG >
 
struct  DefaultDataTypeFunctionsCapabilityFlags< T >
 
class  DataTypeFunctions< T >
 
class  InterfaceDataTypeFunctions< T >
 
class  InternedId
 
struct  IsTriviallyEquatable< InternedId >
 
struct  IsZeroInitialized< InternedId >
 
struct  Member
 
struct  TypeArguments
 
class  DataTypeLib
 
class  TupleDataType
 
class  DelegateDataType
 
class  EnumDataType
 
class  ContainerDataType< T >
 
class  RefCountedCString
 
class  ResultMemT< T >
 
class  LiteralId
 
class  Id
 
class  CompareTemplate< ALLOW_UNDEFINED, EQ, OPERATOR_RANK >
 
class  DefaultCompare
 
class  EqualityCompare
 
class  CStringCompare
 
class  RefCompare< COW, IS_INTERFACE >
 
class  RefCompare< true, false >
 
class  RefCompare< true, true >
 
class  BigIntegerInterface
 
class  BigInteger
 
struct  GradientKnot
 
class  GradientInterface
 
class  GradientRenderDataInterface
 
struct  SplineMapperKnot
 
class  SplineMapperInterface
 

Macros

#define MAXON_ATTRIBUTE_DLL_PUBLIC
 
#define MAXON_ATTRIBUTE_NO_INLINE
 
#define MAXON_ATTRIBUTE_FORCE_INLINE
 
#define MAXON_ATTRIBUTE_FORCE_RELEASE_INLINE
 
#define MAXON_ATTRIBUTE_USED
 
#define PRIVATE_MAXON_DEPRECATED_ENUMVALUE(name, value, reason)
 
#define MAXON_DEPRECATED_ENUMVALUE(name, value, reason)
 
#define MAXON_IMPLICIT
 
#define MAXON_ATTRIBUTE_SYSCHAR_IS_CHAR
 
#define MAXON_CONSTEXPR_EVAL(T, X)
 
#define PRIVATE_MAXON_AS_UTF8(x)
 
#define CONSTSTRING(x)
 
#define PRIVATE_MAXON_TRANSLATIONUNIT_FLAGS
 
#define PRIVATE_MAXON_TRANSLATIONUNIT_FLAGS_2
 
#define PRIVATE_MAXON_DETECT_MEMBER_HELPER1(x, i, a)
 
#define PRIVATE_MAXON_DETECT_MEMBER_HELPER2(x, i, a)
 
#define PRIVATE_MAXON_DETECT_MEMBER_HELPER3(x, i, a)
 
#define MAXON_DETECT_MEMBER_HELPER(NAME, ...)
 
#define MAXON_SCOPE
 
#define MAXON_WARN_MUTE_FUNCTION_LENGTH
 
#define MAXON_WARN_MUTE_NAMING
 
#define PRIVATE_MAXON_DATATYPE_A(type, id)
 
#define PRIVATE_MAXON_DATATYPE(type, id)
 
#define MAXON_DATATYPE(type, id)
 
#define PRIVATE_MAXON_DATATYPE_REGISTER(T, ret, flags)
 
#define PRIVATE_MAXON_DATATYPE_REGISTER_ENUM(enumtype, cppname, id, size, flags, names, ...)
 
#define MAXON_DATATYPE_REGISTER(type)
 
#define PRIVATE_MAXON_DATATYPE_LOCAL_STATIC
 
#define MAXON_DATATYPE_LOCAL(type, id)
 
#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_INIT(x, i, a)
 
#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_OFFSETS(x, i, a)
 
#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_B(Type, line, count, ...)
 
#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_A(type, line, count, ...)
 
#define MAXON_DATATYPE_REGISTER_STRUCT(type, ...)
 
#define SPLINEMAPPER_KNOT_GET_ID(flags)
 
#define SPLINEMAPPER_KNOT_SET_ID(flags, flag_id)
 

Typedefs

using Int16 = int16_t
 
using UInt16 = uint16_t
 
using Int32 = int32_t
 
using UInt32 = uint32_t
 
using Int64 = int64_t
 
using UInt64 = uint64_t
 
using Bool = bool
 
using Float32 = float
 
using Float64 = double
 
using Char = char
 
using UChar = unsigned char
 
using Int = Int64
 
using UInt = UInt64
 
using Float = Float64
 
using Utf32Char = char32_t
 
using Utf16Char = char16_t
 
using SysChar = char
 
using type = Char
 
using type = Int16
 
using type = Int32
 
using type = Int64
 
using type = UChar
 
using type = UInt16
 
using type = UInt32
 
using type = UInt64
 
using type = T
 
using DT = typename std::decay< T >::type
 
using type = typename std::conditional< KEEP, T, typename std::conditional< STD_IS_REPLACEMENT(signed, T), typename IntType< sizeof(T)>::type, typename UIntType< sizeof(T)>::type >::type >::type
 
using HashInt = UInt
 
using type = T
 
using InitMTable = void(*)()
 
using DestructorPointer = void(*)(const void *)
 
using BoolLValue = DefaultLValue< Bool >
 
using ResultMem = ResultMemT< Bool >
 

Enumerations

enum class  ENUM_DONT_INITIALIZE { VALUE }
 
enum class  IN_PLACE_TYPE { VALUE }
 
enum class  CONVERSION_FLAGS {
  NONE ,
  NARROWING ,
  WIDENING_LOSSY ,
  WIDENING_LOSSLESS ,
  REDUCING ,
  EXPANDING ,
  STRUCT_CAST ,
  ITERATION ,
  INCONVERTIBLE ,
  WIDENING_MASK ,
  NARROWING_REDUCING_MASK
}
 
enum class  GET_DATATYPE_POLICY {
  NONE ,
  GENERIC_FOR_UNKNOWN ,
  ERROR_FOR_UNKNOWN ,
  RESULT_FOR_UNKNOWN_MASK
}
 
enum class  DATATYPEMODE {
  SMALLISPOD ,
  SMALL ,
  BIG
}
 
enum class  INNERMOST_MEMBER : Int32
 
enum class  COMPARERESULT {
  LESS ,
  EQUAL ,
  GREATER ,
  INCOMPARABLE
}
 
enum class  EQUALITY {
  SHALLOW ,
  DEEP
}
 

Functions

 __attribute__ ((always_inline)) const expr Float operator""_f(long double f)
 
const StringStringInterface_GetAndCacheConstString (const wchar_t *str, Int len)
 
const StringStringInterface_GetAndCacheConstString (const Char *str, Int len, Int isUtf8)
 
constexpr Bool PrivateIsUtf8 (const char *str, Int len)
 
const Stringoperator""_s (const char *str, std::size_t cnt)
 
const Stringoperator""_s (const wchar_t *str, std::size_t cnt)
 
template<typename T >
String GlobalToString (const T &object, const FormatStatement *formatStatement, Bool checkDataType=true)
 
virtual ~EmptyVirtualClass ()
 
template<typename T , typename E >
E && MakeDependentExpr (E &&value)
 
template<typename T >
T * addressof (T &x)
 
template<typename T >
 __attribute__ ((always_inline)) auto AssignCopy(T &dst
 
enum maxon::ENUM_DONT_INITIALIZE MAXON_ENUM_LIST (ENUM_DONT_INITIALIZE)
 
enum maxon::IN_PLACE_TYPE MAXON_ENUM_LIST (IN_PLACE_TYPE)
 
 Helper (OverloadRank2, T &obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER1,,,,)) -> decltype(obj. GetMemorySize(MAXON_MAKE_COMMA_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER2,,,)))
 
 Helper (OverloadRank1, T &obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER1,,,,)) -> decltype(GetMemorySize(obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER3,,,,)))
 
 Helper (T &obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER1,,,,)) -> decltype(MAXON_CONCAT(GetMemorySize, Helper)(((maxon::OverloadRankMax) nullptr), obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER3,,,,)))
 
template<typename X >
T & __attribute__ ((always_inline)) void UseVariable(X &&var)
 
template<typename T >
decltype(std::declval< T >().CopyFrom(std::declval< const T & >())) TestForCopyFromFunction (OverloadRank1)
 
template<typename T >
std::false_type TestForCopyFromFunction (OverloadRank0)
 
template<typename T , typename ARG >
 __attribute__ ((always_inline)) auto NewCopy(T &dst
 
template<typename T >
void Destruct (const T *object)
 
template<typename T >
DestructorPointer GetDestructorPointer ()
 
template<typename T >
void Reset (T &object)
 
template<typename T , typename... ARGS>
static auto Create (ARGS &&... args)
 
Result< void > MergeDataDictionaries (DataDictionary &base, const DataDictionary &other, Bool mergeSubContainers)
 
Result< void > MergeDataDictionariesPreferBase (DataDictionary &base, const DataDictionary &other, Bool mergeSubContainers)
 
Result< DataGetDataDescriptionValueI (const Id &databaseScope, const InternedId &attributeData, const ConstDataPtr &keyPtr)
 
template<typename ATTRIBUTETYPE , typename KEY >
static Result< typename IsFidClass< ATTRIBUTETYPE >::typeGetDataDescriptionValue (ATTRIBUTETYPE &&attribute, KEY &&key)
 
template<typename TT , typename ATTRIBUTETYPE >
static Result< TT > GetDataDescriptionValue2 (ATTRIBUTETYPE &&attribute, const ConstDataPtr &key)
 
template<typename ATTRIBUTETYPE , typename KEY >
static Result< typename IsFidClass< KEY >::typeGetDataDescriptionValueFromKey (ATTRIBUTETYPE &&attribute, KEY &&key)
 
template<typename TT , typename KEY >
TT GetDefaultFromFidIfAvailable (KEY &&key, OverloadRank0)
 
template<typename TT , typename KEY >
SFINAEHelper< TT, decltype(std::remove_reference< KEY >::type::DEFAULTVALUE)>::type GetDefaultFromFidIfAvailable (KEY &&key, OverloadRank2)
 
ConstDataPtr GetDefaultValueKey ()
 
template<typename SRCCLASS , typename PROPSRCTYPE , typename DSTCLASS , typename PROPDSTTYPE >
Result< void > TransferPropertyIfAvailable (const SRCCLASS &src, PROPSRCTYPE &&srcType, DSTCLASS &dst, PROPDSTTYPE &&dstType)
 
 MAXON_DECLARATION (Class< DataDictionaryObjectRef >, DataDictionaryObjectEmptyClass, "net.maxon.class.datadictionaryobjectempty")
 
 MAXON_DECLARATION (Class< DataDictionaryObjectRef >, DataDictionaryObjectClass, "net.maxon.class.datadictionaryobject")
 
 MAXON_DECLARATION (Class< DataDictionaryObjectRef >, DataDictionaryObjectLockedClass, "net.maxon.class.datadictionaryobjectlocked")
 
 MAXON_DECLARATION (Class< DataDictionaryObjectRef >, DataDictionaryObjectSyncedClass, "net.maxon.class.datadictionaryobjectsynced")
 
 MAXON_DECLARATION (Class< DataDictionaryReferenceObjectRef >, DataDictionaryObjectReferenceClass, "net.maxon.class.datadictionaryobjectreference")
 
Result< DataDictionaryObjectRef > CreateDataDictionaryReferenceObject (DataDictionary *reference)
 
Result< DataDictionaryObjectRef > CreateDataDictionaryReferenceObject (const DataDictionary *reference)
 
Result< DataDictionary > GetDataDictionaryFromDataDictionaryObjectRef (const DataDictionaryObjectRef &ref)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (GenericArithmetic **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (void **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (std::nullptr_t **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (InvalidType **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
SFINAEHelper< Result< const DataType & >, typename T::NonvirtualInterfaceMarker >::type PrivateGetDataType (T **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
SFINAEHelper< Result< const DataType & >, typename T::InterfaceMarker >::type PrivateGetDataType (T **, OverloadRank1)
 
template<GET_DATATYPE_POLICY POLICY>
Result< const DataType & > PrivateGetDataType (void *, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (DataType **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (DataType::Primary **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (TupleDataType **, OverloadRank0)
 
template<typename T >
void PrivateDataTypeMarker (T *)
 
 MAXON_REGISTRY (DataType, DataTypes, "net.maxon.registry.datatypes")
 
void * PrivateDataTypeMarker (Char *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Char, "char")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Char **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Char)
 
void * PrivateDataTypeMarker (UChar *)
 
 MAXON_DECLARATION (maxon::DataType, DT_UChar, "uchar")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (UChar **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (UChar)
 
void * PrivateDataTypeMarker (Int16 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Int16, "int16")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Int16 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Int16)
 
void * PrivateDataTypeMarker (UInt16 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_UInt16, "uint16")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (UInt16 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (UInt16)
 
void * PrivateDataTypeMarker (Int32 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Int32, "int32")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Int32 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Int32)
 
void * PrivateDataTypeMarker (UInt32 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_UInt32, "uint32")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (UInt32 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (UInt32)
 
void * PrivateDataTypeMarker (Int64 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Int64, "int64")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Int64 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Int64)
 
void * PrivateDataTypeMarker (UInt64 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_UInt64, "uint64")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (UInt64 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (UInt64)
 
void * PrivateDataTypeMarker (Utf16Char *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Utf16Char, "utf16char")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Utf16Char **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Utf16Char)
 
void * PrivateDataTypeMarker (Utf32Char *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Utf32Char, "utf32char")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Utf32Char **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Utf32Char)
 
void * PrivateDataTypeMarker (Float32 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Float32, "float32")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Float32 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Float32)
 
void * PrivateDataTypeMarker (Float64 *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Float64, "float64")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Float64 **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Float64)
 
void * PrivateDataTypeMarker (Bool *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Bool, "bool")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Bool **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Bool)
 
void * PrivateDataTypeMarker (Byte *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Byte, "byte")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Byte **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Byte)
 
void * PrivateDataTypeMarker (AInt *)
 
 MAXON_DECLARATION (maxon::DataType, DT_AInt, "int")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (AInt **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (AInt)
 
void * PrivateDataTypeMarker (AUInt *)
 
 MAXON_DECLARATION (maxon::DataType, DT_AUInt, "uint")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (AUInt **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (AUInt)
 
void * PrivateDataTypeMarker (AFloat *)
 
 MAXON_DECLARATION (maxon::DataType, DT_AFloat, "float")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (AFloat **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (AFloat)
 
void * PrivateDataTypeMarker (UniqueHash *)
 
 MAXON_DECLARATION (maxon::DataType, DT_UniqueHash, "net.maxon.datatype.hash")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (UniqueHash **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (UniqueHash)
 
void * PrivateDataTypeMarker (Id *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Id, "net.maxon.datatype.id")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Id **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Id)
 
void * PrivateDataTypeMarker (LiteralId *)
 
 MAXON_DECLARATION (maxon::DataType, DT_LiteralId, "net.maxon.datatype.literalid")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (LiteralId **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (LiteralId)
 
void * PrivateDataTypeMarker (InternedId *)
 
 MAXON_DECLARATION (maxon::DataType, DT_InternedId, "net.maxon.datatype.internedid")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (InternedId **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (InternedId)
 
void * PrivateDataTypeMarker (Data *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Data, "net.maxon.datatype.data")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Data **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Data)
 
void * PrivateDataTypeMarker (UnitType *)
 
 MAXON_DECLARATION (maxon::DataType, DT_UnitType, "net.maxon.datatype.unittype")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (UnitType **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (UnitType)
 
void * PrivateDataTypeMarker (SourceLocation *)
 
 MAXON_DECLARATION (maxon::DataType, DT_SourceLocation, "net.maxon.datatype.sourcelocation")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (SourceLocation **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (SourceLocation)
 
void * PrivateDataTypeMarker (DelegateBase *)
 
 MAXON_DECLARATION (maxon::DataType, DT_DelegateBase, "net.maxon.datatype.delegatebase")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (DelegateBase **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (DelegateBase)
 
template<Bool , typename T >
ResultOk< const DataType & > PrivateGetEnumDataType (T *, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (long **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (unsigned long **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (ParametricType **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (ComponentDescriptor **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (T ***, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Block< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (StridedBlock< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Opt< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Result< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY>
Result< DataTypePrivateGetDataType (AtomicBool **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Atomic8< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Atomic16< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Atomic32< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (Atomic64< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (AtomicPtr< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (AtomicFloatType< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T >
Result< DataTypePrivateGetDataType (BaseArray< T > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename... T>
Result< TupleDataTypePrivateGetDataType (Tuple< T... > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T , typename = typename T::StructTupleType>
Result< TupleDataTypePrivateGetDataType (T **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename R , typename... ARGS>
Result< DelegateDataTypePrivateGetDataType (Delegate< R(ARGS...)> **, OverloadRank2)
 
template<typename T , GET_DATATYPE_POLICY POLICY>
const auto & GetDataType ()
 
template<GET_DATATYPE_POLICY POLICY>
ResultOk< const DataType & > PrivateGetDataType (Generic **, OverloadRank0)
 
void * PrivateDataTypeMarker (ConstDataPtr *)
 
 MAXON_DECLARATION (maxon::DataType, DT_ConstDataPtr, "net.maxon.datatype.constdataptr")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (ConstDataPtr **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (ConstDataPtr)
 
void * PrivateDataTypeMarker (TrivialDataPtr *)
 
 MAXON_DECLARATION (maxon::DataType, DT_TrivialDataPtr, "net.maxon.datatype.trivialdataptr")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (TrivialDataPtr **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (TrivialDataPtr)
 
void * PrivateDataTypeMarker (DataPtr *)
 
 MAXON_DECLARATION (maxon::DataType, DT_DataPtr, "net.maxon.datatype.dataptr")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (DataPtr **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (DataPtr)
 
void * PrivateDataTypeMarker (MoveDataPtr *)
 
 MAXON_DECLARATION (maxon::DataType, DT_MoveDataPtr, "net.maxon.datatype.movedataptr")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (MoveDataPtr **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (MoveDataPtr)
 
void * PrivateDataTypeMarker (ForwardingDataPtr *)
 
 MAXON_DECLARATION (maxon::DataType, DT_ForwardingDataPtr, "net.maxon.datatype.forwardingdataptr")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (ForwardingDataPtr **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (ForwardingDataPtr)
 
void * PrivateDataTypeMarker (Member *)
 
 MAXON_DECLARATION (maxon::DataType, DT_Member, "net.maxon.datatype.member")
 
template<maxon::GET_DATATYPE_POLICY >
maxon::ResultOk< const maxon::DataType & > PrivateGetDataType (Member **, maxon::OverloadRank2)
 
 MAXON_ASSERT_LEGAL_LAYOUT (Member)
 
template<GET_DATATYPE_POLICY POLICY, typename... T>
Result< TupleDataTypePrivateGetDataType (NamedTuple< T... > **, OverloadRank0)
 
template<GET_DATATYPE_POLICY POLICY, typename T , T C>
Result< DataTypePrivateGetDataType (std::integral_constant< T, C > **, OverloadRank0)
 
enum maxon::CONVERSION_FLAGS MAXON_ENUM_FLAGS (CONVERSION_FLAGS)
 
enum maxon::GET_DATATYPE_POLICY MAXON_ENUM_FLAGS (GET_DATATYPE_POLICY)
 
 MAXON_DETECT_MEMBER_HELPER (DescribeIO, const DataSerializeInterface &)
 
template<typename T >
Result< void > DescribeIO (const T &s, const DataSerializeInterface &dsi)
 
enum maxon::DATATYPEMODE MAXON_ENUM_LIST (DATATYPEMODE)
 
Result< void * > DecltypeNewInstanceHelper (const void *)
 
template<typename T >
static Result< void * > PrivateNewInterfaceInstance (OverloadRank0)
 
template<typename T >
static decltype(DecltypeNewInstanceHelper(T::Alloc(maxon::SourceLocation()))) MAXON_WARN_UNUSED PrivateNewInterfaceInstance (OverloadRank1)
 
enum maxon::INNERMOST_MEMBER Int32 MAXON_ENUM_ORDERED_LIST (INNERMOST_MEMBER)
 
enum maxon::COMPARERESULT MAXON_ENUM_ORDERED_LIST (COMPARERESULT, "net.maxon.datatype.enum.compareresult", EARLY)
 
enum maxon::EQUALITY MAXON_ENUM_LIST (EQUALITY, "net.maxon.datatype.enum.equality", EARLY)
 
template<Bool ALLOW_UNDEFINED = false>
Bool LexicographicalGreaterThan ()
 
template<Bool ALLOW_UNDEFINED = false, typename T1 , typename... TN>
Bool LexicographicalGreaterThan (const T1 &a1, const T1 &b1, const TN &... ab)
 
template<Bool ALLOW_UNDEFINED = false>
Bool LexicographicalLessThan ()
 
template<Bool ALLOW_UNDEFINED = false, typename T1 , typename... TN>
Bool LexicographicalLessThan (const T1 &a1, const T1 &b1, const TN &... ab)
 
template<Bool ALLOW_UNDEFINED = false>
COMPARERESULT LexicographicalCompare ()
 
template<Bool ALLOW_UNDEFINED = false, typename T1 , typename... TN>
COMPARERESULT LexicographicalCompare (const T1 &a1, const T1 &b1, const TN &... ab)
 
 MAXON_DATATYPE (GradientKnot, "net.maxon.datatype.gradientknot")
 
COMPARERESULT Compare (const GradientKnot &a, const GradientKnot &b)
 
 MAXON_DATATYPE (SplineMapperKnot, "net.maxon.datatype.splinemapperknot")
 
 DataDictionaryIterator (const DataDictionaryInterface *dict, Bool end)
 
template<typename T , typename KEY >
std::conditional< std::is_void< T >::value, typename IsFidClass< KEY >::type, T >::type GetOrDefault (KEY &&key) const
 
 DataDictionaryIterator (const DataDictionaryObjectInterface *dict, Bool end)
 
template<typename T , typename KEY >
std::conditional< std::is_void< T >::value, typename IsFidClass< KEY >::type, T >::type GetOrDefault (KEY &&key) const
 
template<typename T >
void AssertType () const
 
template<typename T >
Bool Is () const
 
template<typename DEST , typename SRC >
Result< void > AddConversion (CONVERSION_FLAGS kind, Result< void >(*conversion)(DEST &, const SRC &))
 
template<typename T >
Bool IsCastableFrom () const
 
template<typename T >
Bool IsCastableTo () const
 
template<typename T >
static Result< DataCreate ()
 
Result< DataGetCopy () const
 
template<typename T >
void InitSet (T &&data)
 
template<>
void InitSet (Data &&data)
 
template<typename DEST , typename SRC >
Result< void > SetImpl (SRC &&data, OverloadRank0)
 
template<typename DEST >
Result< void > SetImpl (Data &&data, OverloadRank1)
 
template<typename DEST >
Result< void > SetImpl (const Data &data, OverloadRank1)
 
template<typename DEST >
Result< void > SetImpl (Data &data, OverloadRank1)
 
template<typename T >
T * GetPtr ()
 
template<>
DataGetPtr ()
 
template<typename T >
void Set (const T &value)
 
static String ToString (const T *object, const FormatStatement *formatStatement, Bool checkDataType)
 
MAXON_IMPLICIT DataTypePtr (const DataType &type)
 
template<>
Result< void > Get () const
 
template<>
Result< void > Set (const Data &value)
 
template<>
Result< void > Set (Data &value)
 
template<>
Result< void > Set (Data &&value)
 
template<>
Result< void > Get () const
 
template<>
Result< DataGet ()
 

Variables

enum Byte
 
static const Bool KEEP
 
static const Int InvalidArrayIndex
 
static const Int MAXON_FLEXIBLE_ARRAY_LENGTH
 
const void * g_zeroMemory
 
static constexpr Int ZERO_MEMORY_SIZE
 
static const void *const g_zeroPtr
 
static const ENUM_DONT_INITIALIZE DONT_INITIALIZE
 
static const IN_PLACE_TYPE IN_PLACE
 
const ARG & src
 
return OK
 
template<typename T , GET_DATATYPE_POLICY POLICY, Bool ELEMENTARY>
const DataTypeCache DataTypeCacheInstance< T, POLICY, ELEMENTARY >::_instance & CheckedGetDataType
 
struct maxon::TypeArguments MAXON_ENUM_ORDERED_LIST
 
static HelperStorage _helper
 

Macro Definition Documentation

◆ MAXON_ATTRIBUTE_DLL_PUBLIC

#define MAXON_ATTRIBUTE_DLL_PUBLIC

Use MAXON_ATTRIBUTE_DLL_PUBLIC in the declaration of a variable or function to export symbols (project settings make them private by default), e.g. MAXON_ATTRIBUTE_DLL_PUBLIC int variable; extern "C" MAXON_ATTRIBUTE_DLL_PUBLIC void function();

◆ MAXON_ATTRIBUTE_NO_INLINE

#define MAXON_ATTRIBUTE_NO_INLINE

Use MAXON_ATTRIBUTE_NO_INLINE to prevent the compiler from inlining a method, e.g. static MAXON_ATTRIBUTE_NO_INLINE void FreeContainer(Container& c);

◆ MAXON_ATTRIBUTE_FORCE_INLINE

#define MAXON_ATTRIBUTE_FORCE_INLINE

Use MAXON_ATTRIBUTE_FORCE_INLINE to force the compiler to explicitly inline a method, e.g. MAXON_ATTRIBUTE_FORCE_INLINE Float32 Clamp01(Float32 a)

◆ MAXON_ATTRIBUTE_FORCE_RELEASE_INLINE

#define MAXON_ATTRIBUTE_FORCE_RELEASE_INLINE
See also
MAXON_ATTRIBUTE_FORCE_INLINE. Will do nothing in debug builds, allowing to set breakpoints painlessly.

◆ MAXON_ATTRIBUTE_USED

#define MAXON_ATTRIBUTE_USED

use MAXON_ATTRIBUTE_USED to tell the linker it must not dead-strip a function or static variable (even if it determines that the rest of the program does not refer to the object)

◆ PRIVATE_MAXON_DEPRECATED_ENUMVALUE

#define PRIVATE_MAXON_DEPRECATED_ENUMVALUE (   name,
  value,
  reason 
)

◆ MAXON_DEPRECATED_ENUMVALUE

#define MAXON_DEPRECATED_ENUMVALUE (   name,
  value,
  reason 
)

Use MAXON_DEPRECATED_ENUMVALUE to mark an enum value being deprecated. This macro is processed by MSVC, Clang, GCC and Doxygen.

Note
Don't use a comma after the macro!

Example:

enum class COLORS
{
RED,
MAXON_DEPRECATED_ENUMVALUE(BROWN, 100, "Color for brown objects. Use red from now on")
MAXON_DEPRECATED_ENUMVALUE(YELLOW, 200, "Color for yellow objects. Use blue from now on")
};
for(i=0;i< length;i++)
Definition: unicodeobject.h:61
Py_ssize_t PyObject * from
Definition: unicodeobject.h:502
#define MAXON_DEPRECATED_ENUMVALUE(name, value, reason)
Definition: apibase.h:147
Col3< Float, 1 > Color
Definition: vector.h:84

◆ MAXON_IMPLICIT

#define MAXON_IMPLICIT

Use MAXON_IMPLICIT to mark a constructor which may be used for implicit conversions. Example:

class MyClass
{
public:
MAXON_IMPLICIT MyClass(Int x);
explicit MyClass(const Char* x);
};
void Func(const MyClass& x);
Func(42) // OK: the constructor is used for an implicit conversion of 42 to a temporary MyClass object
Func("Hello World"); // Error: the constructor is marked explicit
PyObject * x
Definition: bytesobject.h:38
maxon::Char Char
Definition: ge_sys_math.h:56
maxon::Int Int
Definition: ge_sys_math.h:64
#define MAXON_IMPLICIT
Definition: apibase.h:172

Note that you have to mark a potential conversion constructor (i.e., one that takes a single argument) with either MAXON_IMPLICIT or explicit, otherwise the source processor will complain.

◆ MAXON_ATTRIBUTE_SYSCHAR_IS_CHAR

#define MAXON_ATTRIBUTE_SYSCHAR_IS_CHAR

Internal.

◆ MAXON_CONSTEXPR_EVAL

#define MAXON_CONSTEXPR_EVAL (   T,
 
)

Forces a compile-time evaluation of the constexpr expression X of integral type T. Sometimes this is needed to give the compiler a clue that the expression can be evaluated at run-time, which then can enable further optimization.

Parameters
TType of the expression (has to be an integral type).
XThe expression.
Returns
Compile-time constant value of the expression.

◆ PRIVATE_MAXON_AS_UTF8

#define PRIVATE_MAXON_AS_UTF8 (   x)

◆ CONSTSTRING

#define CONSTSTRING (   x)

◆ PRIVATE_MAXON_TRANSLATIONUNIT_FLAGS

#define PRIVATE_MAXON_TRANSLATIONUNIT_FLAGS

◆ PRIVATE_MAXON_TRANSLATIONUNIT_FLAGS_2

#define PRIVATE_MAXON_TRANSLATIONUNIT_FLAGS_2

◆ PRIVATE_MAXON_DETECT_MEMBER_HELPER1

#define PRIVATE_MAXON_DETECT_MEMBER_HELPER1 (   x,
  i,
 
)

◆ PRIVATE_MAXON_DETECT_MEMBER_HELPER2

#define PRIVATE_MAXON_DETECT_MEMBER_HELPER2 (   x,
  i,
 
)

◆ PRIVATE_MAXON_DETECT_MEMBER_HELPER3

#define PRIVATE_MAXON_DETECT_MEMBER_HELPER3 (   x,
  i,
 
)

◆ MAXON_DETECT_MEMBER_HELPER

#define MAXON_DETECT_MEMBER_HELPER (   NAME,
  ... 
)

Example usage of this macro is MAXON_DETECT_MEMBER_HELPER(WriteTo, const char*); this allows automatic detection of the WriteTo as a member or static function: struct X { Bool WriteTo(const char* str) const { } }; or struct Y {}; static Bool WriteTo(const Y& y, const char* str) { }

You can add a fallback by using overload rank 0, or further specializations with ranks starting at 3, e.g.,

template <typename T> typename SFINAEHelper<Bool, ... some T-based check...>::type WriteToHelper(OverloadRank3, T& obj, const char* str);
PyObject * obj
Definition: complexobject.h:60
void * str
Definition: bytesobject.h:77
maxon::Bool Bool
Definition: ge_sys_math.h:55
PrivateOverloadRank3 * OverloadRank3
See OverloadRank0.
Definition: apibase.h:696
PyObject ** type
Definition: pycore_pyerrors.h:34

◆ MAXON_SCOPE

#define MAXON_SCOPE

Marks a block of code that is scoped for a certain reason.

MAXON_SCOPE // do whatever you want
{
ScopedLock lock(lock);
... more code ...
}
#define MAXON_SCOPE
Definition: apibase.h:2841

◆ MAXON_WARN_MUTE_FUNCTION_LENGTH

#define MAXON_WARN_MUTE_FUNCTION_LENGTH

Marks a function so that the source processor doesn't issue a warning if the function length exceeds the line count limit. This should really only be used where it doesn't make sense to split up the function into smaller pieces, such as the initialization of tables.

MAXON_WARN_MUTE_FUNCTION_LENGTH Result<void> InitTranslationTable()
{
... really long function ...
}
#define MAXON_WARN_MUTE_FUNCTION_LENGTH
Definition: apibase.h:2856

◆ MAXON_WARN_MUTE_NAMING

#define MAXON_WARN_MUTE_NAMING

Marks a declaration so that the source processor doesn't issue a warning if the declaration violates the naming conventions of the style guide.

MAXON_WARN_MUTE_NAMING TIFFErrorHandler _TIFFwarningHandler = nullptr;
#define MAXON_WARN_MUTE_NAMING
Definition: apibase.h:2866

◆ PRIVATE_MAXON_DATATYPE_A

#define PRIVATE_MAXON_DATATYPE_A (   type,
  id 
)

◆ PRIVATE_MAXON_DATATYPE

#define PRIVATE_MAXON_DATATYPE (   type,
  id 
)

◆ MAXON_DATATYPE

#define MAXON_DATATYPE (   type,
  id 
)

MAXON_DATATYPE declares a primary DataType for the given type. Use this in a header file to be able to use values of type for the DataType system. There has to be a matching DataType definition via MAXON_DATATYPE_REGISTER in a cpp file.

MAXON_DATATYPE(TimeValue, "net.maxon.datatype.timevalue");
#define MAXON_DATATYPE(type, id)
Definition: datatype.h:295

You don't have to declare data types for interfaces, this is done automatically. Also you don't have to declare data types for template instantiations if there is a ParametricType for the class template. For example there is a ParametricType for StrongRef<T>, so for any T for which a DataType is declared the DataType for StrongRef<T> needn't be declared because the ParametricType automatically derives it from the DataType for T.

Parameters
[in]typeType for which a DataType shall be implemented.
[in]idUnique identifier of the data type.

◆ PRIVATE_MAXON_DATATYPE_REGISTER

#define PRIVATE_MAXON_DATATYPE_REGISTER (   T,
  ret,
  flags 
)

◆ PRIVATE_MAXON_DATATYPE_REGISTER_ENUM

#define PRIVATE_MAXON_DATATYPE_REGISTER_ENUM (   enumtype,
  cppname,
  id,
  size,
  flags,
  names,
  ... 
)

◆ MAXON_DATATYPE_REGISTER

#define MAXON_DATATYPE_REGISTER (   type)

MAXON_DATATYPE_REGISTER defines the implementation of a maxon::DataType for the given type. This macro has to be used in a cpp file, and there has to be a corresponding MAXON_DATATYPE in a header file. For each type, there must be exactly one MAXON_DATATYPE_REGISTER for the whole application. The usage is as easy as

#define MAXON_DATATYPE_REGISTER(type)
Definition: datatype.h:336

However, this assumes that the appropriate functions for comparison, string conversion etc. are available in the current scope.

If the type is a struct type consisting of public member variables, you can use MAXON_DATATYPE_REGISTER_STRUCT to make the members of your type accessible to the DataType system.

Parameters
[in]typeType for which a DataType shall be implemented.

◆ PRIVATE_MAXON_DATATYPE_LOCAL_STATIC

#define PRIVATE_MAXON_DATATYPE_LOCAL_STATIC

◆ MAXON_DATATYPE_LOCAL

#define MAXON_DATATYPE_LOCAL (   type,
  id 
)

MAXON_DATATYPE_LOCAL can be used for DataType declarations which need not be publicly visible in a header file. It comprises the declaration (which would normally done by MAXON_DATATYPE in a header file) and its implementation (normally done by MAXON_DATATYPE_REGISTER). MAXON_DATATYPE_LOCAL has to be placed in a cpp file. The functions for comparison, string conversion etc. are taken from the current scope.

Parameters
[in]typeType for which a local DataType shall be declared and implemented.
[in]idThe unique identifier of the local data type.

◆ PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_INIT

#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_INIT (   x,
  i,
 
)

◆ PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_OFFSETS

#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_OFFSETS (   x,
  i,
 
)

◆ PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_B

#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_B (   Type,
  line,
  count,
  ... 
)

◆ PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_A

#define PRIVATE_MAXON_DATATYPE_REGISTER_STRUCT_A (   type,
  line,
  count,
  ... 
)

◆ MAXON_DATATYPE_REGISTER_STRUCT

#define MAXON_DATATYPE_REGISTER_STRUCT (   type,
  ... 
)

MAXON_DATATYPE_REGISTER_STRUCT defines the implementation of a DataType for the given type, and it also sets up an underlying tuple type which is composed of the members given by ... . You can use this instead of MAXON_DATATYPE_REGISTER for a struct type consisting of public member variables, then the members of your type are accessible to the DataType system. Also there's no need to implement the DescribeIO function because the one from the underlying type is used.

This macro has to be used in a cpp file, and there has to be a corresponding MAXON_DATATYPE in a header file.

// header file
struct Member
{
DataType type;
InternedId name;
};
MAXON_DATATYPE(Member, "net.maxon.datatype.member");
// cpp file
const char const char * name
Definition: abstract.h:195
#define MAXON_DATATYPE_REGISTER_STRUCT(type,...)
Definition: datatype.h:411
Parameters
[in]typeType for which a DataType shall be implemented.
[in]...List of the names of the member variables of type.

◆ SPLINEMAPPER_KNOT_GET_ID

#define SPLINEMAPPER_KNOT_GET_ID (   flags)

Gets the ID of a SplineMapperKnot. Usage:

Int32 id = SPLINEMAPPER_KNOT_GET_ID(point.flags);
maxon::Int32 Int32
Definition: ge_sys_math.h:60
#define SPLINEMAPPER_KNOT_GET_ID(flags)
Definition: splinemapper.h:21

◆ SPLINEMAPPER_KNOT_SET_ID

#define SPLINEMAPPER_KNOT_SET_ID (   flags,
  flag_id 
)

Sets the ID of a SplineMapperKnot. Usage:

SPLINEMAPPER_KNOT_SET_ID(point.flags, id);
#define SPLINEMAPPER_KNOT_SET_ID(flags, flag_id)
Definition: splinemapper.h:27

Typedef Documentation

◆ Int16

using Int16 = int16_t

16 bit signed integer datatype.

◆ UInt16

using UInt16 = uint16_t

16 bit unsigned integer datatype.

◆ Int32

using Int32 = int32_t

32 bit signed integer datatype.

◆ UInt32

using UInt32 = uint32_t

32 bit unsigned integer datatype.

◆ Int64

using Int64 = int64_t

64 bit signed integer datatype.

◆ UInt64

using UInt64 = uint64_t

64 bit unsigned integer datatype.

◆ Bool

using Bool = bool

boolean type, possible values are only false/true, 8 bit

◆ Float32

using Float32 = float

32 bit floating point value (float)

◆ Float64

using Float64 = double

64 bit floating point value (double)

◆ Char

using Char = char

signed 8 bit character

◆ UChar

using UChar = unsigned char

unsigned 8 bit character

◆ Int

using Int = Int64

signed 32/64 bit int, size depends on the platform

◆ UInt

using UInt = UInt64

unsigned 32/64 bit int, size depends on the platform

◆ Float

using Float = Float64

current floating point model. right now it's adjusted to Float64==64 bit but maybe it's redefined to Float32 anytime

◆ Utf32Char

using Utf32Char = char32_t

32 bit unicode (UTF-32) character. Utf32Char is the datatype for a single 32 bit unicode character.

◆ Utf16Char

using Utf16Char = char16_t

16 bit unicode character. Note that complex unicodes can be composed of two individual 16 bit characters.

◆ SysChar

using SysChar = char

System-specific character. This is the character that will be fed to all system functions. Under windows this is a 16-bit wide value, all other platforms define it as 8-bit (and encode strings as UTF-8).

◆ type [1/11]

using type = Char

◆ type [2/11]

using type = Int16

◆ type [3/11]

using type = Int32

◆ type [4/11]

using type = Int64

◆ type [5/11]

using type = UChar

◆ type [6/11]

using type = UInt16

◆ type [7/11]

using type = UInt32

◆ type [8/11]

using type = UInt64

◆ type [9/11]

using type = T

◆ DT

using DT = typename std::decay<T>::type

◆ type [10/11]

using type = typename std::conditional<KEEP, T, typename std::conditional<STD_IS_REPLACEMENT(signed, T), typename IntType<sizeof(T)>::type, typename UIntType<sizeof(T)>::type>::type>::type

◆ HashInt

using HashInt = UInt

HashInt is used as return type of GetHashCode functions. It has the same bit width as Int. With that bit width hash collisions for reasonable hash code functions are rare but possible.

◆ type [11/11]

using type = T

The result type will always be T.

◆ InitMTable

using InitMTable = void (*)()

initSystemTable/InitMTable is not allowed to call thread specific methods as the thread model is not up at the point of calling

◆ DestructorPointer

using DestructorPointer = void (*)(const void*)

◆ BoolLValue

Use this class when you need a default argument for parameters of type Bool&. As an example, consider a function which adds elements to some set:

Result<void> Add(Element* e, Bool& added = BoolLValue());
@ Add
Definition: Python-ast.h:24
DefaultLValue< Bool > BoolLValue
Definition: apibase.h:2829
Py_ssize_t * e
Definition: longobject.h:89
Definition: annotations.h:7

e could already exist before in the set, so added is set to indicate if e was really added. If you as a caller are not interested in this, the default argument helps to provide a valid temporary lvalue object.

◆ ResultMem

Use this class as result type of functions that can fail in out-of-memory situations. This allows to use the result in combination with iferr or Result<void> return values. ResultMem accepts Bool, ResultPtr, ResultRef, pointers and strong/unique references in its constructors.

ResultMem is just a type alias for ResultMemT<Bool>.

Enumeration Type Documentation

◆ ENUM_DONT_INITIALIZE

enum ENUM_DONT_INITIALIZE
strong

Marker type for constructors which don't initialize the class members at all. E.g., vectors usally initialize all components with (0, 0, 0). Vector v(DONT_INITIALIZE); will create an uninitialized vector.

Enumerator
VALUE 

◆ IN_PLACE_TYPE

enum IN_PLACE_TYPE
strong

Marker type to resolve ambiguity for perfect-forwarded in-place constructors.

Enumerator
VALUE 

◆ CONVERSION_FLAGS

enum CONVERSION_FLAGS
strong

This enum defines flags for a DataType conversion.

See also
AddConversion
Convert
Enumerator
NONE 

When no other flags are set, the conversion is a one-to-one correspondence (such as from Float to TimeValue and back).

NARROWING 

The conversion contains a narrowing conversion. The conversion may not always be possible (such as converting a negative Int to a UInt), then it returns an error.

WIDENING_LOSSY 

The conversion contains a widening conversion which is always possible, but it might result in loss of precision (a Float64 can't represent all bits of an Int64).

WIDENING_LOSSLESS 

The conversion contains a lossless widening conversion.

REDUCING 

The conversion contains a reducing conversion such as from a vector to a scalar (or a higher-dimensional vector to a lower-dimensional vector).

EXPANDING 

The conversion contains an expanding conversion such as from a scalar to a vector (or a lower-dimensional vector to a higher-dimensional vector).

STRUCT_CAST 

The conversion contains a cast between layout-compatible structs (such as from Vector to Color).

ITERATION 

The conversion contains an iteration over a collection (such as from a Vector-array to Vector).

INCONVERTIBLE 

No conversion possible.

WIDENING_MASK 

Mask to check for a widening conversion (combination of WIDENING_LOSSY and WIDENING_LOSSLESS).

NARROWING_REDUCING_MASK 

Mask to check for a narrowing or reducing conversion (combination of NARROWING and REDUCING).

◆ GET_DATATYPE_POLICY

enum GET_DATATYPE_POLICY
strong

GET_DATATYPE_POLICY controls the behavior of GetDataType for special cases.

Enumerator
NONE 
GENERIC_FOR_UNKNOWN 

Set this flag if the datatype of Generic shall be returned for a type which hasn't been registered (otherwise a compile-time error happens unless ERROR_FOR_UNKNOWN is set).

ERROR_FOR_UNKNOWN 

Set this flag if a runtime error shall be returned by CheckedGetDataType for a type which hasn't been registered (otherwise a compile-time error happens unless GENERIC_FOR_UNKNOWN is set).

RESULT_FOR_UNKNOWN_MASK 

◆ DATATYPEMODE

enum DATATYPEMODE
strong
Enumerator
SMALLISPOD 
SMALL 
BIG 

◆ INNERMOST_MEMBER

enum INNERMOST_MEMBER : Int32
strong

◆ COMPARERESULT

enum COMPARERESULT
strong

Data type for comparison results.

Enumerator
LESS 

result is less than

EQUAL 

result is equal

GREATER 

result is greater than

INCOMPARABLE 

values are incomparable (either a compare function doesn't exist, or we have a partial order)

◆ EQUALITY

enum EQUALITY
strong

EQUALITY is used for the second parameter of the IsEqual-function of collections. It controls whether the collection shall do the equality check on its values using == or IsEqual.

Enumerator
SHALLOW 

A shallow equality-test shall be done. For pointers or (non-copy-on-write) references the object identity (pointer value) is used.

DEEP 

A deep equality-test shall be done. For pointers or (non-copy-on-write) references the referenced objects are compared for equality.

Function Documentation

◆ __attribute__() [1/4]

__attribute__ ( (always_inline)  ) const

User-defined literal to allow floating-point constants with the Float datatype of the MAXON API. E.g. instead of writing 1.0 or 1.0f better write 1.0_f to use the Float type.

Aligns value according to alignment. alignment has to be a power of two, then the function returns the smallest value not less than value which is a multiple of alignment.

Parameters
[in]valueValue to align.
[in]alignmentRequired alignment, must be a power of two.
Returns
Aligned value (multiple of alignment closest to and not less than value).

Aligns value according to alignment. alignment has to be a power of two, then the function returns the smallest pointer value not pointing below value which is a multiple of alignment.

Parameters
[in]valuePointer value to align.
[in]alignmentRequired alignment, must be a power of two.
Returns
Aligned pointer value (multiple of alignment closest to and not less than value).

◆ StringInterface_GetAndCacheConstString() [1/2]

const String& maxon::StringInterface_GetAndCacheConstString ( const wchar_t *  str,
Int  len 
)

Internal. Forwards to StringInterface::GetAndCacheConstString, this allows to use CONSTSTRING and the literal operator _s in uninstantiated template code without having to include string.h

◆ StringInterface_GetAndCacheConstString() [2/2]

const String& maxon::StringInterface_GetAndCacheConstString ( const Char str,
Int  len,
Int  isUtf8 
)

Internal. Forwards to StringInterface::GetAndCacheConstString, this allows to use CONSTSTRING and the literal operator _s in uninstantiated template code without having to include string.h

◆ PrivateIsUtf8()

constexpr Bool maxon::PrivateIsUtf8 ( const char *  str,
Int  len 
)
constexpr

◆ operator""_s() [1/2]

const String& maxon::operator""_s ( const char *  str,
std::size_t  cnt 
)

Returns a String object of the characters passed in quotation marks. If the same characters are used in another place the String will still only be created once in memory. In the following example the second loop is far more efficient because the String is created only once whereas in the first loop the characters are converted to unicode and a new String object is created (and deleted) on each iteration.

for (...)
{
if (s.FindIndex(String("A is created each time.")) == 0) ...
}
for (...)
{
if (s.FindIndex("B is created only once."_s) == 42) ...
}
PyObject PyObject const char const char char ** s
Definition: bytesobject.h:60
Definition: c4d_string.h:39

As MSVC does not properly resolve "\u" sequences for char* you need to use the wchar_t version below for any characters >=0x80.

◆ operator""_s() [2/2]

const String& maxon::operator""_s ( const wchar_t *  str,
std::size_t  cnt 
)

Returns a String object of the characters passed in quotation marks. This version can be used for unicode characters, e.g. L"t\u00e8st"_s.

◆ GlobalToString()

String GlobalToString ( const T &  object,
const FormatStatement formatStatement,
Bool  checkDataType = true 
)

Forwards to ToString function overloads. A call to GlobalToString can be used within a class if the class itself declares a ToString member function (which is quite common): Then this function hides the ToString functions of enclosing namespaces, and to call them you either have to write maxon::ToString (but then you have to be sure that the function is in the maxon namespace), or just GlobalToString (which utilizes argument-dependent lookup and, thus, finds ToString functions in all related namespaces).

Parameters
[in]objectSome object to be converted to a string.
[in]formatStatementNullptr or additional formatting instruction. See also Formatting Integer values.
[in]checkDataTypeMust be set to true (the default value), only for internal use.
Returns
The converted result.

◆ ~EmptyVirtualClass()

virtual ~EmptyVirtualClass ( )
virtual

◆ MakeDependentExpr()

E&& maxon::MakeDependentExpr ( E &&  value)

Artificially makes the given expression value dependent on a template type parameter T. This can be used in function templates when an expression contains an incomplete type at its point of definition (so that compilers complain), but the type will be complete when the template is instantiated later.

Template Parameters
TA template type parameter on which the expression shall be made dependent.
Parameters
[in]valueThe expression value.
Returns
The forwarded expression value.

◆ addressof()

T* std::maxon_std::addressof ( T &  x)

◆ __attribute__() [2/4]

__attribute__ ( (always_inline)  ) const &

Copy assignment.

Returns a C++ reference to an object of type const T whose memory consists of immutable zero bytes. This size of T must not exceed 1024 bytes. This is not checked by the compiler to allow for incomplete types.

Returns a C++ reference to an object of type const T whose memory consists of immutable zero bytes The size of T must not exceed the size of a pointer. This is not checked by the compiler to allow for incomplete types.

◆ MAXON_ENUM_LIST() [1/4]

enum maxon::ENUM_DONT_INITIALIZE maxon::MAXON_ENUM_LIST ( ENUM_DONT_INITIALIZE  )

◆ MAXON_ENUM_LIST() [2/4]

enum maxon::IN_PLACE_TYPE maxon::MAXON_ENUM_LIST ( IN_PLACE_TYPE  )

◆ Helper() [1/3]

maxon::Helper ( OverloadRank2  ,
T &obj   MAXON_MAKE_LISTPRIVATE_MAXON_DETECT_MEMBER_HELPER1,,,, 
) -> decltype(obj. GetMemorySize (MAXON_MAKE_COMMA_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER2,,,)))

◆ Helper() [2/3]

maxon::Helper ( OverloadRank1  ,
T &obj   MAXON_MAKE_LISTPRIVATE_MAXON_DETECT_MEMBER_HELPER1,,,, 
) -> decltype( GetMemorySize (obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER3,,,,)))

◆ Helper() [3/3]

maxon::Helper ( T &obj   MAXON_MAKE_LISTPRIVATE_MAXON_DETECT_MEMBER_HELPER1,,,,) -> decltype(MAXON_CONCAT( GetMemorySize , Helper)( ((maxon::OverloadRankMax) nullptr) , obj MAXON_MAKE_LIST(PRIVATE_MAXON_DETECT_MEMBER_HELPER3,,,,)))

◆ __attribute__() [3/4]

T& maxon::__attribute__ ( (always_inline)  ) &&

UseVariable creates a little bit of code that makes sure that you won't get a warning for an unused variable. or the unused return value of an expression. You can also use this macro to make sure a speed test is not removed by the compiler, otherwise the example would be completely removed by the compiler's optimizer. Please note that UseVariable will create a little bit of extra code, therefore do not use it in speed critical code.

Float sum = 0.0;
for (Int64 i = 0; i < 10000000; i++)
{
sum += Sin((Float)i);
}
UseVariable(sum);
Py_ssize_t i
Definition: abstract.h:645
maxon::Int64 Int64
Definition: ge_sys_math.h:62
maxon::Float Float
Definition: ge_sys_math.h:66
MAXON_ATTRIBUTE_FORCE_INLINE Float32 Sin(Float32 val)
Calculates the sine of a value.
Definition: apibasemath.h:198

◆ TestForCopyFromFunction() [1/2]

decltype(std::declval<T>().CopyFrom(std::declval<const T&>())) maxon::TestForCopyFromFunction ( OverloadRank1  )

◆ TestForCopyFromFunction() [2/2]

std::false_type maxon::TestForCopyFromFunction ( OverloadRank0  )

◆ __attribute__() [4/4]

__attribute__ ( (always_inline)  ) &

Calls new (&dst) T(src) or dst.CopyFrom(src) if T has a CopyFrom function.

Converting copy assignment.

◆ Destruct()

void maxon::Destruct ( const T *  object)

Destructs the object.

Template Parameters
TType of object.
Parameters
[out]objectThe object to destruct.

◆ GetDestructorPointer()

DestructorPointer maxon::GetDestructorPointer ( )

Returns a function to destruct an object of type T.

Template Parameters
TType of object.

◆ Reset()

void maxon::Reset ( T &  object)

Resets the object to the state of a default-constructed T. This function destructs obj and then default-constructs a new T in place.

Template Parameters
TType of object.
Parameters
[out]objectThe object to reset.

◆ Create() [1/2]

static auto maxon::Create ( ARGS &&...  args)
static

Constructs a new object of type T with the given arguments.

  • If T has a member function named Init, a default-constructed object will be used, the Init function will be called on that object with the given arguments, and the object will be returned (or a possible error returned by the Init function). The return type is Result<T>.
  • Otherwise, a constructor of T is called with the given arguments. In this case the return type is ResultOk<T>.
    Template Parameters
    TType of object to construct.
    Parameters
    [in]argsOptional arguments for constructor or Init function.
    Returns
    The constructed object.

◆ MergeDataDictionaries()

Result<void> maxon::MergeDataDictionaries ( DataDictionary &  base,
const DataDictionary &  other,
Bool  mergeSubContainers 
)

MergeDataDictionaries combines the two given data dictionaries into the base dictionary. The same keys in 'other' will overwrite the base values.

Parameters
[in]baseDictionary to merge as the base.
[in]otherDictionary to merge into base. this values will overwrite values with the same key in 'base'.
[in]mergeSubContainersTrue if sub dictionaries inside the dictionary should be merged recursively as well. False if the dictionary is treated like atomic data.
Returns
OK on success.

◆ MergeDataDictionariesPreferBase()

Result<void> maxon::MergeDataDictionariesPreferBase ( DataDictionary &  base,
const DataDictionary &  other,
Bool  mergeSubContainers 
)

◆ GetDataDescriptionValueI()

Result<Data> maxon::GetDataDescriptionValueI ( const Id databaseScope,
const InternedId attributeData,
const ConstDataPtr keyPtr 
)

GetDataDescriptionValueI returns a data description value from the database.

Parameters
[in]databaseScopeDatabase id.
[in]attributeDataAttribute to query.
[in]keyPtrKey to query.
Returns
Data on success.

◆ GetDataDescriptionValue()

static Result<typename IsFidClass<ATTRIBUTETYPE>::type> maxon::GetDataDescriptionValue ( ATTRIBUTETYPE &&  attribute,
KEY &&  key 
)
static

Returns the defined description value of any attribute. Example usage:

Int32 min = GetDataDescriptionValue(MACHINEINFO::NUMBEROFPROCESSORS, DESCRIPTION::DATA::BASE::MINVALUE) iferr_return;
Int32 max = GetDataDescriptionValue(MACHINEINFO::NUMBEROFPROCESSORS, DESCRIPTION::DATA::BASE::MAXVALUE) iferr_return;
static Result< typename IsFidClass< ATTRIBUTETYPE >::type > GetDataDescriptionValue(ATTRIBUTETYPE &&attribute, KEY &&key)
Definition: datadictionary.h:372
const char Py_ssize_t const char Py_ssize_t Py_ssize_t max
Definition: modsupport.h:59
const char Py_ssize_t const char Py_ssize_t min
Definition: modsupport.h:58
#define iferr_return
Definition: resultbase.h:1519
Parameters
[in]attributeAttribute to find.
[in]keyValue to return, e.g. DESCRIPTION::DATA::BASE::MAXVALUE.
Returns
Requested value on success. The return type will be determined by the data type of ATTRIBUTETYPE.

◆ GetDataDescriptionValue2()

static Result<TT> maxon::GetDataDescriptionValue2 ( ATTRIBUTETYPE &&  attribute,
const ConstDataPtr key 
)
static

◆ GetDataDescriptionValueFromKey()

static Result<typename IsFidClass<KEY>::type> maxon::GetDataDescriptionValueFromKey ( ATTRIBUTETYPE &&  attribute,
KEY &&  key 
)
static

Returns the defined key value description of any attribute. Example usage:

BaseArray<Tuple<Id, Data>> dataTypeList = GetDataDescriptionValueFromKey(DESCRIPTION::DATA::BASE::DATATYPE, DESCRIPTION::DATA::BASE::ENUM) iferr_return;
static Result< typename IsFidClass< KEY >::type > GetDataDescriptionValueFromKey(ATTRIBUTETYPE &&attribute, KEY &&key)
Definition: datadictionary.h:403
Parameters
[in]attributeAttribute to find.
[in]keyValue to return, e.g. DESCRIPTION::DATA::BASE::ENUM.
Returns
Requested value on success. The return type will be determined by the data type of KEY.

◆ GetDefaultFromFidIfAvailable() [1/2]

TT maxon::GetDefaultFromFidIfAvailable ( KEY &&  key,
OverloadRank0   
)

◆ GetDefaultFromFidIfAvailable() [2/2]

SFINAEHelper<TT, decltype(std::remove_reference<KEY>::type::DEFAULTVALUE)>::type maxon::GetDefaultFromFidIfAvailable ( KEY &&  key,
OverloadRank2   
)

◆ GetDefaultValueKey()

ConstDataPtr maxon::GetDefaultValueKey ( )

Returns the Id of DESCRIPTION::DATA::BASE::DEFAULTVALUE.

◆ TransferPropertyIfAvailable()

Result<void> maxon::TransferPropertyIfAvailable ( const SRCCLASS &  src,
PROPSRCTYPE &&  srcType,
DSTCLASS &  dst,
PROPDSTTYPE &&  dstType 
)

TransferPropertyIfAvailable copies the value of src into dst if available.

Parameters
[in]srcSource object.
[in]srcTypeSource property type id.
[in]dstDestination object.
[in]dstTypeDestination property type id.
Returns
OK on success.

◆ MAXON_DECLARATION() [1/36]

maxon::MAXON_DECLARATION ( Class< DataDictionaryObjectRef >  ,
DataDictionaryObjectEmptyClass  ,
"net.maxon.class.datadictionaryobjectempty"   
)

Implementation of the DataDictionaryObjectInterface without any data stored. This class can be used as a base component for you own inherited classes which overrides SetData/GetData.

◆ MAXON_DECLARATION() [2/36]

maxon::MAXON_DECLARATION ( Class< DataDictionaryObjectRef >  ,
DataDictionaryObjectClass  ,
"net.maxon.class.datadictionaryobject"   
)

Implementation of the DataDictionaryObjectInterface without locking, so it's not threadsafe.

◆ MAXON_DECLARATION() [3/36]

maxon::MAXON_DECLARATION ( Class< DataDictionaryObjectRef >  ,
DataDictionaryObjectLockedClass  ,
"net.maxon.class.datadictionaryobjectlocked"   
)

Implementation of the DataDictionaryObjectInterface with a spinlock protected hashmap, so it's threadsafe.

◆ MAXON_DECLARATION() [4/36]

maxon::MAXON_DECLARATION ( Class< DataDictionaryObjectRef >  ,
DataDictionaryObjectSyncedClass  ,
"net.maxon.class.datadictionaryobjectsynced"   
)

Implementation of the DataDictionaryObjectInterface with a lockfree hashmap, so it's threadsafe.

◆ MAXON_DECLARATION() [5/36]

maxon::MAXON_DECLARATION ( Class< DataDictionaryReferenceObjectRef >  ,
DataDictionaryObjectReferenceClass  ,
"net.maxon.class.datadictionaryobjectreference"   
)

Implementation of the DataDictionaryObjectInterface with a reference to a DataDictionary. This allows to pass DataDictionary to all functions expecting a DataDictionaryObjectRef.

◆ CreateDataDictionaryReferenceObject() [1/2]

Result<DataDictionaryObjectRef> maxon::CreateDataDictionaryReferenceObject ( DataDictionary *  reference)

Creates a DataDictionaryObjectRef for a given DataDictionary pointer. All calls to SetData, GetData, EraseData will be routed to the DataDictionary. So this allows to pass a DataDictionary to all functions which expect a DataDictionaryObjectRef. Important: the DataDictionary object needs to be saved and be valid all the time. Otherwise it will crash.

Parameters
[in]referencePointer to a DataDictionary.
Returns
DataDictionaryObjectRef which wraps the DataDictionary.

◆ CreateDataDictionaryReferenceObject() [2/2]

Result<DataDictionaryObjectRef> maxon::CreateDataDictionaryReferenceObject ( const DataDictionary *  reference)

◆ GetDataDictionaryFromDataDictionaryObjectRef()

Result<DataDictionary> maxon::GetDataDictionaryFromDataDictionaryObjectRef ( const DataDictionaryObjectRef &  ref)

Returns a DataDictionary copy the given DataDictionaryObjectRef.

Parameters
[in]refReference to a DataDictionaryObjectRef.
Returns
DataDictionary with the copy of all data.

◆ PrivateGetDataType() [1/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( GenericArithmetic **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [2/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( void **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [3/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( std::nullptr_t **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [4/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( InvalidType **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [5/64]

SFINAEHelper<Result<const DataType&>, typename T::NonvirtualInterfaceMarker>::type maxon::PrivateGetDataType ( T **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [6/64]

SFINAEHelper<Result<const DataType&>, typename T::InterfaceMarker>::type maxon::PrivateGetDataType ( T **  ,
OverloadRank1   
)

◆ PrivateGetDataType() [7/64]

Result<const DataType&> maxon::PrivateGetDataType ( void *  ,
OverloadRank0   
)

◆ PrivateGetDataType() [8/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( DataType **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [9/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( DataType::Primary **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [10/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( TupleDataType **  ,
OverloadRank0   
)

◆ PrivateDataTypeMarker() [1/32]

void maxon::PrivateDataTypeMarker ( T *  )

◆ MAXON_REGISTRY()

maxon::MAXON_REGISTRY ( DataType  ,
DataTypes  ,
"net.maxon.registry.datatypes"   
)

This registry is used to register all primary data types (those which are declared by MAXON_DATATYPE, and interfaces). It does not include compound data types such as array, tuple or reference types. Use DataType::Get() to obtain a DataType for a data type identifier, whether it is primary or compound.

◆ PrivateDataTypeMarker() [2/32]

void* maxon::PrivateDataTypeMarker ( Char )

◆ MAXON_DECLARATION() [6/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Char  ,
"char"   
)

◆ PrivateGetDataType() [11/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Char **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [1/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Char  )

◆ PrivateDataTypeMarker() [3/32]

void* maxon::PrivateDataTypeMarker ( UChar )

◆ MAXON_DECLARATION() [7/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_UChar  ,
"uchar"   
)

◆ PrivateGetDataType() [12/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( UChar **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [2/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( UChar  )

◆ PrivateDataTypeMarker() [4/32]

void* maxon::PrivateDataTypeMarker ( Int16 )

◆ MAXON_DECLARATION() [8/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Int16  ,
"int16"   
)

◆ PrivateGetDataType() [13/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Int16 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [3/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Int16  )

◆ PrivateDataTypeMarker() [5/32]

void* maxon::PrivateDataTypeMarker ( UInt16 )

◆ MAXON_DECLARATION() [9/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_UInt16  ,
"uint16"   
)

◆ PrivateGetDataType() [14/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( UInt16 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [4/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( UInt16  )

◆ PrivateDataTypeMarker() [6/32]

void* maxon::PrivateDataTypeMarker ( Int32 )

◆ MAXON_DECLARATION() [10/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Int32  ,
"int32"   
)

◆ PrivateGetDataType() [15/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Int32 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [5/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Int32  )

◆ PrivateDataTypeMarker() [7/32]

void* maxon::PrivateDataTypeMarker ( UInt32 )

◆ MAXON_DECLARATION() [11/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_UInt32  ,
"uint32"   
)

◆ PrivateGetDataType() [16/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( UInt32 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [6/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( UInt32  )

◆ PrivateDataTypeMarker() [8/32]

void* maxon::PrivateDataTypeMarker ( Int64 )

◆ MAXON_DECLARATION() [12/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Int64  ,
"int64"   
)

◆ PrivateGetDataType() [17/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Int64 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [7/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Int64  )

◆ PrivateDataTypeMarker() [9/32]

void* maxon::PrivateDataTypeMarker ( UInt64 )

◆ MAXON_DECLARATION() [13/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_UInt64  ,
"uint64"   
)

◆ PrivateGetDataType() [18/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( UInt64 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [8/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( UInt64  )

◆ PrivateDataTypeMarker() [10/32]

void* maxon::PrivateDataTypeMarker ( Utf16Char )

◆ MAXON_DECLARATION() [14/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Utf16Char  ,
"utf16char"   
)

◆ PrivateGetDataType() [19/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Utf16Char **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [9/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Utf16Char  )

◆ PrivateDataTypeMarker() [11/32]

void* maxon::PrivateDataTypeMarker ( Utf32Char )

◆ MAXON_DECLARATION() [15/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Utf32Char  ,
"utf32char"   
)

◆ PrivateGetDataType() [20/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Utf32Char **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [10/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Utf32Char  )

◆ PrivateDataTypeMarker() [12/32]

void* maxon::PrivateDataTypeMarker ( Float32 )

◆ MAXON_DECLARATION() [16/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Float32  ,
"float32"   
)

◆ PrivateGetDataType() [21/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Float32 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [11/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Float32  )

◆ PrivateDataTypeMarker() [13/32]

void* maxon::PrivateDataTypeMarker ( Float64 )

◆ MAXON_DECLARATION() [17/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Float64  ,
"float64"   
)

◆ PrivateGetDataType() [22/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Float64 **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [12/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Float64  )

◆ PrivateDataTypeMarker() [14/32]

void* maxon::PrivateDataTypeMarker ( Bool )

◆ MAXON_DECLARATION() [18/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Bool  ,
"bool"   
)

◆ PrivateGetDataType() [23/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Bool **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [13/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Bool  )

◆ PrivateDataTypeMarker() [15/32]

void* maxon::PrivateDataTypeMarker ( Byte )

◆ MAXON_DECLARATION() [19/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Byte  ,
"byte"   
)

◆ PrivateGetDataType() [24/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Byte **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [14/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Byte  )

◆ PrivateDataTypeMarker() [16/32]

void* maxon::PrivateDataTypeMarker ( AInt )

◆ MAXON_DECLARATION() [20/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_AInt  ,
"int"   
)

◆ PrivateGetDataType() [25/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( AInt **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [15/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( AInt  )

◆ PrivateDataTypeMarker() [17/32]

void* maxon::PrivateDataTypeMarker ( AUInt )

◆ MAXON_DECLARATION() [21/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_AUInt  ,
"uint"   
)

◆ PrivateGetDataType() [26/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( AUInt **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [16/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( AUInt  )

◆ PrivateDataTypeMarker() [18/32]

void* maxon::PrivateDataTypeMarker ( AFloat )

◆ MAXON_DECLARATION() [22/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_AFloat  ,
"float"   
)

◆ PrivateGetDataType() [27/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( AFloat **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [17/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( AFloat  )

◆ PrivateDataTypeMarker() [19/32]

void* maxon::PrivateDataTypeMarker ( UniqueHash )

◆ MAXON_DECLARATION() [23/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_UniqueHash  ,
"net.maxon.datatype.hash"   
)

◆ PrivateGetDataType() [28/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( UniqueHash **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [18/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( UniqueHash  )

◆ PrivateDataTypeMarker() [20/32]

void* maxon::PrivateDataTypeMarker ( Id )

◆ MAXON_DECLARATION() [24/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Id  ,
"net.maxon.datatype.id"   
)

◆ PrivateGetDataType() [29/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Id **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [19/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Id  )

◆ PrivateDataTypeMarker() [21/32]

void* maxon::PrivateDataTypeMarker ( LiteralId )

◆ MAXON_DECLARATION() [25/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_LiteralId  ,
"net.maxon.datatype.literalid"   
)

◆ PrivateGetDataType() [30/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( LiteralId **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [20/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( LiteralId  )

◆ PrivateDataTypeMarker() [22/32]

void* maxon::PrivateDataTypeMarker ( InternedId )

◆ MAXON_DECLARATION() [26/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_InternedId  ,
"net.maxon.datatype.internedid"   
)

◆ PrivateGetDataType() [31/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( InternedId **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [21/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( InternedId  )

◆ PrivateDataTypeMarker() [23/32]

void* maxon::PrivateDataTypeMarker ( Data )

◆ MAXON_DECLARATION() [27/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Data  ,
"net.maxon.datatype.data"   
)

◆ PrivateGetDataType() [32/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Data **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [22/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Data  )

◆ PrivateDataTypeMarker() [24/32]

void* maxon::PrivateDataTypeMarker ( UnitType )

◆ MAXON_DECLARATION() [28/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_UnitType  ,
"net.maxon.datatype.unittype"   
)

◆ PrivateGetDataType() [33/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( UnitType **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [23/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( UnitType  )

◆ PrivateDataTypeMarker() [25/32]

void* maxon::PrivateDataTypeMarker ( SourceLocation )

◆ MAXON_DECLARATION() [29/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_SourceLocation  ,
"net.maxon.datatype.sourcelocation"   
)

◆ PrivateGetDataType() [34/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( SourceLocation **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [24/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( SourceLocation  )

◆ PrivateDataTypeMarker() [26/32]

void* maxon::PrivateDataTypeMarker ( DelegateBase )

◆ MAXON_DECLARATION() [30/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_DelegateBase  ,
"net.maxon.datatype.delegatebase"   
)

◆ PrivateGetDataType() [35/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( DelegateBase **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [25/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( DelegateBase  )

◆ PrivateGetEnumDataType()

ResultOk<const DataType&> maxon::PrivateGetEnumDataType ( T *  ,
OverloadRank0   
)

◆ PrivateGetDataType() [36/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( long **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [37/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( unsigned long **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [38/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( ParametricType **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [39/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( ComponentDescriptor **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [40/64]

Result<DataType> maxon::PrivateGetDataType ( T ***  ,
OverloadRank0   
)

◆ PrivateGetDataType() [41/64]

Result<DataType> maxon::PrivateGetDataType ( Block< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [42/64]

Result<DataType> maxon::PrivateGetDataType ( StridedBlock< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [43/64]

Result<DataType> maxon::PrivateGetDataType ( Opt< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [44/64]

Result<DataType> maxon::PrivateGetDataType ( Result< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [45/64]

Result<DataType> maxon::PrivateGetDataType ( AtomicBool **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [46/64]

Result<DataType> maxon::PrivateGetDataType ( Atomic8< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [47/64]

Result<DataType> maxon::PrivateGetDataType ( Atomic16< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [48/64]

Result<DataType> maxon::PrivateGetDataType ( Atomic32< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [49/64]

Result<DataType> maxon::PrivateGetDataType ( Atomic64< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [50/64]

Result<DataType> maxon::PrivateGetDataType ( AtomicPtr< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [51/64]

Result<DataType> maxon::PrivateGetDataType ( AtomicFloatType< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [52/64]

Result<DataType> maxon::PrivateGetDataType ( BaseArray< T > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [53/64]

Result<TupleDataType> maxon::PrivateGetDataType ( Tuple< T... > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [54/64]

Result<TupleDataType> maxon::PrivateGetDataType ( T **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [55/64]

Result<DelegateDataType> maxon::PrivateGetDataType ( Delegate< R(ARGS...)> **  ,
OverloadRank2   
)

◆ GetDataType()

const auto & GetDataType ( )

Returns the DataType representation of T. This covers not only primary datatypes which have been registered directly with MAXON_DATATYPE_REGISTER, but also compound types which are derived from other types (such as arrays, pointers, references, tuples).

Template Parameters
TType for which the DataType shall be obtained.
POLICYAn optional policy for the operation.
Returns
The DataType representation for T.

Returns the DataType for the given C++ type.

const DataType& type = GetDataType<T>();
const DataType& type = GetDataType<Tuple<Int, String>>();
Template Parameters
TType of which the DataType representation shall be obtained.
POLICYOptional parameter to modify the data type resolution.
Returns
DataType for T.

◆ PrivateGetDataType() [56/64]

ResultOk<const DataType&> maxon::PrivateGetDataType ( Generic **  ,
OverloadRank0   
)

◆ PrivateDataTypeMarker() [27/32]

void* maxon::PrivateDataTypeMarker ( ConstDataPtr )

◆ MAXON_DECLARATION() [31/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_ConstDataPtr  ,
"net.maxon.datatype.constdataptr"   
)

◆ PrivateGetDataType() [57/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( ConstDataPtr **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [26/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( ConstDataPtr  )

◆ PrivateDataTypeMarker() [28/32]

void* maxon::PrivateDataTypeMarker ( TrivialDataPtr )

◆ MAXON_DECLARATION() [32/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_TrivialDataPtr  ,
"net.maxon.datatype.trivialdataptr"   
)

◆ PrivateGetDataType() [58/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( TrivialDataPtr **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [27/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( TrivialDataPtr  )

◆ PrivateDataTypeMarker() [29/32]

void* maxon::PrivateDataTypeMarker ( DataPtr )

◆ MAXON_DECLARATION() [33/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_DataPtr  ,
"net.maxon.datatype.dataptr"   
)

◆ PrivateGetDataType() [59/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( DataPtr **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [28/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( DataPtr  )

◆ PrivateDataTypeMarker() [30/32]

void* maxon::PrivateDataTypeMarker ( MoveDataPtr )

◆ MAXON_DECLARATION() [34/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_MoveDataPtr  ,
"net.maxon.datatype.movedataptr"   
)

◆ PrivateGetDataType() [60/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( MoveDataPtr **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [29/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( MoveDataPtr  )

◆ PrivateDataTypeMarker() [31/32]

void* maxon::PrivateDataTypeMarker ( ForwardingDataPtr )

◆ MAXON_DECLARATION() [35/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_ForwardingDataPtr  ,
"net.maxon.datatype.forwardingdataptr"   
)

◆ PrivateGetDataType() [61/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( ForwardingDataPtr **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [30/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( ForwardingDataPtr  )

◆ PrivateDataTypeMarker() [32/32]

void* maxon::PrivateDataTypeMarker ( Member )

◆ MAXON_DECLARATION() [36/36]

maxon::MAXON_DECLARATION ( maxon::DataType  ,
DT_Member  ,
"net.maxon.datatype.member"   
)

◆ PrivateGetDataType() [62/64]

maxon::ResultOk<const maxon::DataType&> maxon::PrivateGetDataType ( Member **  ,
maxon::OverloadRank2   
)

◆ MAXON_ASSERT_LEGAL_LAYOUT() [31/31]

maxon::MAXON_ASSERT_LEGAL_LAYOUT ( Member  )

◆ PrivateGetDataType() [63/64]

Result<TupleDataType> maxon::PrivateGetDataType ( NamedTuple< T... > **  ,
OverloadRank0   
)

◆ PrivateGetDataType() [64/64]

Result<DataType> maxon::PrivateGetDataType ( std::integral_constant< T, C > **  ,
OverloadRank0   
)

◆ MAXON_ENUM_FLAGS() [1/2]

enum maxon::CONVERSION_FLAGS maxon::MAXON_ENUM_FLAGS ( CONVERSION_FLAGS  )

◆ MAXON_ENUM_FLAGS() [2/2]

enum maxon::GET_DATATYPE_POLICY maxon::MAXON_ENUM_FLAGS ( GET_DATATYPE_POLICY  )

◆ MAXON_DETECT_MEMBER_HELPER()

maxon::MAXON_DETECT_MEMBER_HELPER ( DescribeIO  ,
const DataSerializeInterface  
)

◆ DescribeIO()

Result<void> maxon::DescribeIO ( const T &  s,
const DataSerializeInterface dsi 
)

◆ MAXON_ENUM_LIST() [3/4]

enum maxon::DATATYPEMODE maxon::MAXON_ENUM_LIST ( DATATYPEMODE  )

◆ DecltypeNewInstanceHelper()

Result<void*> maxon::DecltypeNewInstanceHelper ( const void *  )

◆ PrivateNewInterfaceInstance() [1/2]

static Result<void*> maxon::PrivateNewInterfaceInstance ( OverloadRank0  )
static

◆ PrivateNewInterfaceInstance() [2/2]

static decltype(DecltypeNewInstanceHelper(T::Alloc(maxon::SourceLocation()))) MAXON_WARN_UNUSED maxon::PrivateNewInterfaceInstance ( OverloadRank1  )
static

◆ MAXON_ENUM_ORDERED_LIST() [1/2]

enum maxon::INNERMOST_MEMBER Int32 maxon::MAXON_ENUM_ORDERED_LIST ( INNERMOST_MEMBER  )

◆ MAXON_ENUM_ORDERED_LIST() [2/2]

enum maxon::COMPARERESULT maxon::MAXON_ENUM_ORDERED_LIST ( COMPARERESULT  ,
"net.maxon.datatype.enum.compareresult"  ,
EARLY   
)

◆ MAXON_ENUM_LIST() [4/4]

enum maxon::EQUALITY maxon::MAXON_ENUM_LIST ( EQUALITY  ,
"net.maxon.datatype.enum.equality"  ,
EARLY   
)

◆ LexicographicalGreaterThan() [1/2]

Bool maxon::LexicographicalGreaterThan ( )

◆ LexicographicalGreaterThan() [2/2]

Bool maxon::LexicographicalGreaterThan ( const T1 &  a1,
const T1 &  b1,
const TN &...  ab 
)

Lexicographically compares the tuple (a1, a2, ...) against (b1, b2, ...). (a1, a2) is greater than (b1, b2) if a1 > b1, or if a1 == b1 and a2 > b2 (and so forth for the remaining tuple elements). In other words, the first pair ai, bi which is not equal determines the relationship between the tuples.

Parameters
[in]a1First value of first tuple.
[in]b1First value of second tuple.
[in]abThe remaining values of the tuples (in the order a2, b2, a3, b3, ...).
Returns
True if (a1, a2, ...) is lexicographically greater than (b1, b2, ...).

◆ LexicographicalLessThan() [1/2]

Bool maxon::LexicographicalLessThan ( )

◆ LexicographicalLessThan() [2/2]

Bool maxon::LexicographicalLessThan ( const T1 &  a1,
const T1 &  b1,
const TN &...  ab 
)

Lexicographically compares the tuple (a1, a2, ...) against (b1, b2, ...). (a1, a2) is less than (b1, b2) if a1 < b1, or if a1 == b1 and a2 < b2 (and so forth for the remaining tuple elements). In other words, the first pair ai, bi which is not equal determines the relationship between the tuples.

Parameters
[in]a1First value of first tuple.
[in]b1First value of second tuple.
[in]abThe remaining values of the tuples (in the order a2, b2, a3, b3, ...).
Returns
True if (a1, a2, ...) is lexicographically less than (b1, b2, ...).

◆ LexicographicalCompare() [1/2]

COMPARERESULT maxon::LexicographicalCompare ( )

◆ LexicographicalCompare() [2/2]

COMPARERESULT maxon::LexicographicalCompare ( const T1 &  a1,
const T1 &  b1,
const TN &...  ab 
)

Lexicographically compares the tuple (a1, a2, ...) against (b1, b2, ...). For the lexicographic order, (a1, a2) is greater than (b1, b2) if a1 > b1, or if a1 == b1 and a2 > b2 (and so forth for the remaining tuple elements). If all values are equal, the tuples are equal, in the remaining cases (a1, a2) is less than (b1, b2). In other words, the first pair ai, bi which is not equal determines the relationship between the tuples.

Parameters
[in]a1First value of first tuple.
[in]b1First value of second tuple.
[in]abThe remaining values of the tuples (in the order a2, b2, a3, b3, ...).
Returns
Lexicographic comparison of the tuples (a1, a2, ...), (b1, b2, ...).

◆ MAXON_DATATYPE() [1/2]

maxon::MAXON_DATATYPE ( GradientKnot  ,
"net.maxon.datatype.gradientknot"   
)

◆ Compare()

COMPARERESULT maxon::Compare ( const GradientKnot a,
const GradientKnot b 
)

◆ MAXON_DATATYPE() [2/2]

maxon::MAXON_DATATYPE ( SplineMapperKnot  ,
"net.maxon.datatype.splinemapperknot"   
)

◆ DataDictionaryIterator() [1/2]

◆ GetOrDefault() [1/2]

std::conditional<std::is_void<T>::value, typename IsFidClass<KEY>::type, T>::type GetOrDefault ( KEY &&  key) const

◆ DataDictionaryIterator() [2/2]

◆ GetOrDefault() [2/2]

std::conditional<std::is_void<T>::value, typename IsFidClass<KEY>::type, T>::type GetOrDefault ( KEY &&  key) const

◆ AssertType()

void AssertType

In debug configuration, checks if this type is the same as #T and writes warnings to the console if not. This functions does nothing in release configuration.

Template Parameters
TType to compare.

◆ Is()

Bool Is

Returns true if this type is the same as #T. {t.Is<T>()} is a shorthand for {t == GetDataType<T>()}.

Template Parameters
TType to compare.
Returns
True if this type is #T, false otherwise.

◆ AddConversion()

Result<void> AddConversion ( CONVERSION_FLAGS  kind,
Result< void >(*)(DEST &, const SRC &)  conversion 
)

◆ IsCastableFrom()

Bool IsCastableFrom

Checks if a value of type T can be cast safely to a value of this type. This holds if either both types are the same, have the same underlying type, or this type is Generic, or both types are reference or pointer types and the type to which this type points is a base type of the type to which T points (see IsBaseOfOrSame).

Template Parameters
TAnother data type.
Returns
True if a value of this data type can be safely cast from a value of type T.

◆ IsCastableTo()

Bool IsCastableTo

Checks if a value of this type can safely be cast to a value of type T.

See also
IsBaseOfOrSame.
Template Parameters
TAnother data type.
Returns
True if a value of this data type can be safely cast from a value of type T.

◆ Create() [2/2]

Result< Data > Create
static

Creates a Data and initializes it with the given type.

Template Parameters
TType of data which shall be created.
Returns
Data initialized to the given type on success.

◆ GetCopy()

Result< Data > GetCopy ( ) const

Returns a copy of the data.

◆ InitSet() [1/2]

void InitSet ( T &&  data)
private

Private: Copy or move specific data into a Data from the constructur.

Parameters
[in]dataData to copy or move to this.

◆ InitSet() [2/2]

void InitSet ( Data &&  data)

◆ SetImpl() [1/4]

Result< void > SetImpl ( SRC &&  data,
OverloadRank0   
)
private

◆ SetImpl() [2/4]

Result< void > SetImpl ( Data &&  data,
OverloadRank1   
)
private

◆ SetImpl() [3/4]

Result< void > SetImpl ( const Data data,
OverloadRank1   
)
private

◆ SetImpl() [4/4]

Result< void > SetImpl ( Data data,
OverloadRank1   
)
private

◆ GetPtr() [1/2]

T * GetPtr

Returns the pointer of the native data if its type matches the given type T, otherwise nullptr.

Template Parameters
TThe desired type.
Returns
Pointer to the data in native format.

◆ GetPtr() [2/2]

Data* GetPtr ( )

◆ Set() [1/4]

void Set ( const T &  value)

◆ ToString()

String ToString ( const T *  object,
const FormatStatement formatStatement,
Bool  checkDataType 
)
static

◆ DataTypePtr()

DataTypePtr ( const DataType type)

◆ Get() [1/3]

Result<void> Get ( ) const

◆ Set() [2/4]

Result<void> Set ( const Data value)

◆ Set() [3/4]

Result<void> Set ( Data value)

◆ Set() [4/4]

Result<void> Set ( Data &&  value)

◆ Get() [2/3]

Result<void> Get ( ) const

◆ Get() [3/3]

Result<Data> Get ( )

Variable Documentation

◆ Byte

enum Byte
strong

A byte.

◆ KEEP

const Bool KEEP
static

◆ InvalidArrayIndex

const Int InvalidArrayIndex
static

Invalid array index (e.g. returned for an array index out of bounds).

◆ MAXON_FLEXIBLE_ARRAY_LENGTH

const Int MAXON_FLEXIBLE_ARRAY_LENGTH
static

Use this as the bound of an array which is the last member of a class and shall have a flexible array length. Usually you can just leave the array bound empty (like in {Int b[];}), this non-standard extension declares a flexible array member and is supported by MSVC, Clang, ICC and GCC. However there are cases such as a member type with non-trivial destructor where a flexible array member isn't supported, then you can use MAXON_FLEXIBLE_ARRAY_LENGTH. Example:

struct MyStruct
{
Int a;
};
...
MyStruct* s = MAXON_SAFE_PLACEMENT_NEW(NewMem(Char, SIZEOF(MyStruct) + SIZEOF(Int) * (cnt - MAXON_FLEXIBLE_ARRAY_LENGTH))) MyStruct();
#define NewMem(T, cnt)
Definition: defaultallocator.h:195
static const Int MAXON_FLEXIBLE_ARRAY_LENGTH
Definition: apibase.h:302
#define MAXON_SAFE_PLACEMENT_NEW(PTR)
Definition: compilerdetection.h:446
#define SIZEOF(...)
Calculates the size of a datatype or element.
Definition: apibasemath.h:214
Warning
This may only be used if the class has standard-layout. Also you have to implement default constructor, destructor and copy operations properly. Keep in mind that the actual class instance may have less elements than the compiler thinks.

◆ g_zeroMemory

const void* g_zeroMemory
extern

Points to a 32-byte-aligned block of ZERO_MEMORY_SIZE zero bytes. The memory will be write-protected if possible.

◆ ZERO_MEMORY_SIZE

constexpr Int ZERO_MEMORY_SIZE
staticconstexpr

The number of zero bytes available at g_zeroMemory.

◆ g_zeroPtr

const void* const g_zeroPtr
static

A global const void* value initialized to zero. Compilers will be able to do optimizations because they know the zero value.

◆ DONT_INITIALIZE

const ENUM_DONT_INITIALIZE DONT_INITIALIZE
static

◆ IN_PLACE

const IN_PLACE_TYPE IN_PLACE
static

◆ src

U && src

◆ OK

static const ERROR_OK OK

OK can be used for comparison with a Result value and as a return value of a function returning Result<void>. It indicates the success of an operation:

Result<void> Func()
{
if (...)
return OutOfMemoryError(MAXON_SOURCE_LOCATION);
return OK;
}
if (Func() == OK)
{
...
}
return OK
Definition: apibase.h:2690
#define MAXON_SOURCE_LOCATION
Definition: memoryallocationbase.h:67

It can also be used where an Error is expected, then it constructs a null Error reference which actually means that no error occurred.

◆ CheckedGetDataType

const DataTypeCache DataTypeCacheInstance<T, POLICY, ELEMENTARY>::_instance& CheckedGetDataType

◆ MAXON_ENUM_ORDERED_LIST

class maxon::SplineMapperInterface MAXON_ENUM_ORDERED_LIST

◆ _helper

NamedTuple< T... >::HelperStorage _helper
staticprivate