This class holds information about reflected types. Each instance represents one type that is known to the reflection system.
More...
|
| xiiRTTI (xiiStringView sName, const xiiRTTI *pParentType, xiiUInt32 uiTypeSize, xiiUInt32 uiTypeVersion, xiiUInt8 uiVariantType, xiiBitflags< xiiTypeFlags > flags, xiiRTTIAllocator *pAllocator, xiiArrayPtr< const xiiAbstractProperty * > properties, xiiArrayPtr< const xiiAbstractFunctionProperty * > functions, xiiArrayPtr< const xiiPropertyAttribute * > attributes, xiiArrayPtr< xiiAbstractMessageHandler * > messageHandlers, xiiArrayPtr< xiiMessageSenderInfo > messageSenders, const xiiRTTI *(*fnVerifyParent)()) |
| The constructor requires all the information about the type that this object represents.
|
|
void | VerifyCorrectness () const |
| Can be called in debug builds to check that all reflected objects are correctly set up.
|
|
XII_ALWAYS_INLINE xiiStringView | GetTypeName () const |
| Returns the name of this type.
|
|
XII_ALWAYS_INLINE xiiUInt64 | GetTypeNameHash () const |
| Returns the hash of the name of this type.
|
|
XII_ALWAYS_INLINE const xiiRTTI * | GetParentType () const |
| Returns the type that is the base class of this type. May be nullptr if this type has no base class.
|
|
XII_ALWAYS_INLINE xiiVariantType::Enum | GetVariantType () const |
| Returns the corresponding variant type for this type or Invalid if there is none.
|
|
XII_ALWAYS_INLINE bool | IsDerivedFrom (const xiiRTTI *pBaseType) const |
| Returns true if this type is derived from the given type (or of the same type).
|
|
template<typename BASE> |
XII_ALWAYS_INLINE bool | IsDerivedFrom () const |
| Returns true if this type is derived from or identical to the given type.
|
|
XII_ALWAYS_INLINE xiiRTTIAllocator * | GetAllocator () const |
| Returns the object through which instances of this type can be allocated.
|
|
XII_ALWAYS_INLINE xiiArrayPtr< const xiiAbstractProperty *const > | GetProperties () const |
| Returns the array of properties that this type has. Does NOT include properties from base classes.
|
|
XII_ALWAYS_INLINE xiiArrayPtr< const xiiAbstractFunctionProperty *const > | GetFunctions () const |
|
XII_ALWAYS_INLINE xiiArrayPtr< const xiiPropertyAttribute *const > | GetAttributes () const |
|
template<typename Type> |
const Type * | GetAttributeByType () const |
| Returns the first attribute that derives from the given type, or nullptr if nothing is found.
|
|
void | GetAllProperties (xiiDynamicArray< const xiiAbstractProperty * > &out_properties) const |
| Returns the list of properties that this type has, including derived properties from all base classes.
|
|
XII_ALWAYS_INLINE xiiUInt32 | GetTypeSize () const |
| Returns the size (in bytes) of an instance of this type.
|
|
XII_ALWAYS_INLINE xiiUInt32 | GetTypeVersion () const |
| Returns the version number of this type.
|
|
XII_ALWAYS_INLINE const xiiBitflags< xiiTypeFlags > & | GetTypeFlags () const |
| Returns the type flags.
|
|
const xiiAbstractProperty * | FindPropertyByName (xiiStringView sName, bool bSearchBaseTypes=true) const |
| Will iterate over all properties of this type and (optionally) the base types to search for a property with the given name.
|
|
XII_ALWAYS_INLINE xiiStringView | GetPluginName () const |
| Returns the name of the plugin which this type is declared in.
|
|
XII_ALWAYS_INLINE const xiiArrayPtr< xiiAbstractMessageHandler * > & | GetMessageHandlers () const |
| Returns the array of message handlers that this type has.
|
|
bool | DispatchMessage (void *pInstance, xiiMessage &ref_msg) const |
| Dispatches the given message to the proper message handler, if there is one available. Returns true if so, false if no message handler for this type exists.
|
|
bool | DispatchMessage (const void *pInstance, xiiMessage &ref_msg) const |
| Dispatches the given message to the proper message handler, if there is one available. Returns true if so, false if no message handler for this type exists.
|
|
template<typename MessageType> |
XII_ALWAYS_INLINE bool | CanHandleMessage () const |
| Returns whether this type can handle the given message type.
|
|
bool | CanHandleMessage (xiiMessageId id) const |
| Returns whether this type can handle the message type with the given id.
|
|
XII_ALWAYS_INLINE const xiiArrayPtr< xiiMessageSenderInfo > & | GetMessageSender () const |
|
This class holds information about reflected types. Each instance represents one type that is known to the reflection system.
Instances of this class are typically created through the macros from the StaticRTTI.h header. Each instance represents one type. This class holds information about derivation hierarchies and exposed properties. You can thus find out whether a type is derived from some base class and what properties of which types are available. Properties can then be read and modified on instances of this type.