![]() |
ezEngine
Release 25.03
|
The base class for a property that represents a function. More...
#include <AbstractProperty.h>
Public Member Functions | |
ezAbstractFunctionProperty (const char *szPropertyName) | |
Passes the property name through to ezAbstractProperty. | |
virtual ezPropertyCategory::Enum | GetCategory () const override |
Returns the category of this property. Cast this property to the next higher type for more information. | |
virtual ezFunctionType::Enum | GetFunctionType () const =0 |
Returns the type of function, see ezFunctionPropertyType::Enum. | |
virtual const ezRTTI * | GetReturnType () const =0 |
Returns the type of the return value. | |
virtual ezBitflags< ezPropertyFlags > | GetReturnFlags () const =0 |
Returns property flags of the return value. | |
virtual ezUInt32 | GetArgumentCount () const =0 |
Returns the number of arguments. | |
virtual const ezRTTI * | GetArgumentType (ezUInt32 uiParamIndex) const =0 |
Returns the type of the given argument. | |
virtual ezBitflags< ezPropertyFlags > | GetArgumentFlags (ezUInt32 uiParamIndex) const =0 |
Returns the property flags of the given argument. | |
virtual void | Execute (void *pInstance, ezArrayPtr< ezVariant > arguments, ezVariant &out_returnValue) const =0 |
Calls the function. Provide the instance on which the function is supposed to be called. More... | |
virtual const ezRTTI * | GetSpecificType () const override |
Returns the type information of the constant property. Use this to cast this property to a specific version of ezTypedConstantProperty. | |
ezAbstractFunctionProperty * | AddFlags (ezBitflags< ezPropertyFlags > flags) |
Adds flags to the property. Returns itself to allow to be called during initialization. | |
ezAbstractFunctionProperty * | AddAttributes (ezPropertyAttribute *pAttrib1, ezPropertyAttribute *pAttrib2=nullptr, ezPropertyAttribute *pAttrib3=nullptr, ezPropertyAttribute *pAttrib4=nullptr, ezPropertyAttribute *pAttrib5=nullptr, ezPropertyAttribute *pAttrib6=nullptr) |
Adds attributes to the property. Returns itself to allow to be called during initialization. Allocate an attribute using standard 'new'. | |
![]() | |
ezAbstractProperty (const char *szPropertyName) | |
The constructor must get the name of the property. The string must be a compile-time constant. | |
const char * | GetPropertyName () const |
Returns the name of the property. | |
const ezBitflags< ezPropertyFlags > & | GetFlags () const |
Returns the flags of the property. | |
ezAbstractProperty * | AddFlags (ezBitflags< ezPropertyFlags > flags) |
Adds flags to the property. Returns itself to allow to be called during initialization. | |
ezAbstractProperty * | AddAttributes (ezPropertyAttribute *pAttrib1, ezPropertyAttribute *pAttrib2=nullptr, ezPropertyAttribute *pAttrib3=nullptr, ezPropertyAttribute *pAttrib4=nullptr, ezPropertyAttribute *pAttrib5=nullptr, ezPropertyAttribute *pAttrib6=nullptr) |
Adds attributes to the property. Returns itself to allow to be called during initialization. Allocate an attribute using standard 'new'. | |
ezArrayPtr< const ezPropertyAttribute *const > | GetAttributes () const |
Returns the array of property attributes. | |
template<typename Type > | |
const Type * | GetAttributeByType () const |
Returns the first attribute that derives from the given type, or nullptr if nothing is found. | |
Additional Inherited Members | |
![]() | |
ezBitflags< ezPropertyFlags > | m_Flags |
const char * | m_szPropertyName |
ezHybridArray< const ezPropertyAttribute *, 2, ezStaticsAllocatorWrapper > | m_Attributes |
The base class for a property that represents a function.
|
pure virtual |
Calls the function. Provide the instance on which the function is supposed to be called.
arguments must be the size of GetArgumentCount, the following rules apply for both arguments and return value: Any standard type must be provided by value, even if it is a pointer to one. Types must match exactly, no ConvertTo is called. enum and bitflags are supported if ezEnum / ezBitflags is used, value must be provided as ezInt64. Out values (&, *) are written back to the variant they were read from. Any class is provided by pointer, regardless of whether it is a pointer or not. The returnValue must only be valid if the return value is a ref or by value class. In that case returnValue must be a ptr to a valid class instance of the returned type. An invalid variant is equal to a nullptr, except for if the argument is of type ezVariant, in which case it is impossible to pass along a nullptr.
Implemented in ezPhantomFunctionProperty, ezConstructorFunctionProperty< CLASS, Args >, ezScriptCoroutineFunctionProperty, ezFunctionProperty< R(*)(Args...)>, ezFunctionProperty< R(CLASS::*)(Args...) const >, ezFunctionProperty< R(CLASS::*)(Args...)>, ezAngelScriptFunctionProperty, and ezVisualScriptFunctionProperty.