#include <AzCore/Component/ComponentBus.h>
#include <AzCore/Component/NamedEntityId.h>
#include <AzCore/RTTI/ReflectContext.h>
#include <AzCore/Memory/Memory.h>
#include <AzCore/Memory/SystemAllocator.h>
#include <AzCore/Outcome/Outcome.h>
#include <AzCore/std/containers/unordered_set.h>
Classes | |
class | AZ::Component |
class | AZ::ComponentDescriptor |
struct | AZ::ComponentDescriptorBusTraits |
class | AZ::ComponentDescriptorHelper< ComponentClass > |
class | AZ::ComponentDescriptorDefault< ComponentClass > |
Namespaces | |
namespace | AZ |
Reopen namespace to define DataPatch class. | |
Macros | |
#define | AZ_COMPONENT_BASE(_ComponentClass, ...) |
#define | AZ_COMPONENT_BASE_DECL() |
#define | AZ_COMPONENT_BASE_IMPL_0(_ComponentClass, _Inline, _TemplateParamsParen) |
#define | AZ_COMPONENT_BASE_IMPL(_ComponentClass, ...) |
#define | AZ_COMPONENT_BASE_IMPL_INLINE(_ComponentClass, ...) |
#define | AZ_COMPONENT_INTRUSIVE_DESCRIPTOR_TYPE(_ComponentClass) |
#define | AZ_COMPONENT(_ComponentClass, ...) |
#define | AZ_COMPONENT_DECL(_ComponentClass) |
#define | AZ_COMPONENT_MACRO_CALL_II(macro, ...) macro(__VA_ARGS__) |
#define | AZ_COMPONENT_MACRO_CALL_I(macro, ...) AZ_COMPONENT_MACRO_CALL_II(macro, __VA_ARGS__) |
#define | AZ_COMPONENT_MACRO_CALL(macro, ...) AZ_COMPONENT_MACRO_CALL_I(macro, __VA_ARGS__) |
#define | AZ_COMPONENT_IMPL(_ComponentClassOrTemplate, _DisplayName, _Uuid, ...) |
#define | AZ_COMPONENT_IMPL_INLINE(_ComponentClassOrTemplate, _DisplayName, _Uuid, ...) |
Typedefs | |
typedef AZ::u32 | AZ::ComponentServiceType |
ID of a user-defined component service. The system uses it to build a dependency tree. | |
using | AZ::ImmutableEntityVector = AZStd::vector< AZ::Entity const * > |
using | AZ::ComponentTypeList = AZStd::vector< Uuid > |
List of Component class type IDs. | |
using | AZ::ComponentValidationResult = AZ::Outcome< void, AZStd::string > |
using | AZ::ComponentDescriptorBus = AZ::EBus< ComponentDescriptor, ComponentDescriptorBusTraits > |
Functions | |
DECLARE_EBUS_EXTERN_WITH_TRAITS (ComponentDescriptor, ComponentDescriptorBusTraits) | |
Header file for the Component base class. In Open 3D Engine's component entity system, each component defines a discrete feature that can be attached to an entity.
#define AZ_COMPONENT | ( | _ComponentClass, | |
... | |||
) |
Declares a component with the default settings. The component derives from AZ::Component, is not templated, uses AZ::SystemAllocator, and so on. AZ_COMPONENT(_ComponentClass, _ComponentId, OtherBaseClases... Component) is included automatically.
The component that this macro creates has a static function called CreateDescriptor and a type called DescriptorType. Although you can delete the descriptor, keep in mind that you cannot use component instances without a descriptor. This is because descriptors are released when the component application closes or a module is unloaded. Descriptors must have access to AZ::ComponentDescriptor::Reflect, AZ::ComponentDescriptor::GetProvidedServices, and other descriptor services.
You are not required to use the AZ_COMPONENT macro if you want to implement your own creation functions by calling AZ_CLASS_ALLOCATOR, AZ_RTTI, and so on.
#define AZ_COMPONENT_BASE | ( | _ComponentClass, | |
... | |||
) |
Includes the core component code required to make a component work. This macro is typically included in other macros, such as AZ_COMPONENT, to create a component.
#define AZ_COMPONENT_BASE_DECL | ( | ) |
Declares the functions needed to make the component work with the Component Descriptor system Does not provide any definitions, nor added AZ_CLASS_ALLOCATOR for the type
#define AZ_COMPONENT_BASE_IMPL | ( | _ComponentClass, | |
... | |||
) |
Implements the CreateDescriptor function If the Component Class is a template, the variadic arguments are AZ_TYPE_INFO_CLASS, AZ_TYPE_INFO_AUTO placeholder parameters that can be used to create an out of line definition
#define AZ_COMPONENT_BASE_IMPL_0 | ( | _ComponentClass, | |
_Inline, | |||
_TemplateParamsParen | |||
) |
#define AZ_COMPONENT_BASE_IMPL_INLINE | ( | _ComponentClass, | |
... | |||
) |
Implements the CreateDescriptor function with the inline
keyword in front of the function signature This is suitable for adding an implementation to an .inl or header file
#define AZ_COMPONENT_DECL | ( | _ComponentClass | ) |
Declares the required AzTypeInfo(GetO3deTypeName and GetO3deTypeId), RTTI (RTTI_TypeName and RTTI_Type), static placement allocator functions(operator new and operator delete) and Component Descriptor functions (CreateDescriptor). This macro does not provide any definitions for those functions and it's primary use is to avoid function definitions and include dependencies that are needed in a header to reduce compilation time
#define AZ_COMPONENT_IMPL | ( | _ComponentClassOrTemplate, | |
_DisplayName, | |||
_Uuid, | |||
... | |||
) |
Implements the the required definitions needed for AzTypeInfo, RTTI, Allocator opt-in and Component Descriptor creation This macro pairs with the AZ_COMPONENT_DECL macro. It is suitable for used in a cpp file within the same namespace where the component class was created
_ComponentClassOrTemplate | The C++ identifier associated with the component class NOTES: The first argument should be either the class name for a regular class or when specifying the arguments for a class template the simple-template-name with no angle brackets(i.e ComponentTemplate , not ComponentTemplate<T> ) inside of an inner set of parenthesis, followed by 0 or template placeholder arguments ex. class class EditorInspectorComponent -> AZ_COMPONENT_IMPL(EditorInspectorComponent, ...) ex. class template template<class, class, class> class EditorComponentAdapter -> `AZ_COMPONENT_IMPL_INLINE((EditorComponentAdapter, AZ_CLASS, AZ_CLASS, AZ_CLASS), ...); |
_DisplayName | cstring which is used by AzTypeInfo as the TypeName for lookups |
_Uuid | unique identifier associated with AzTypeInfo and pairs with the _DisplayName |
__VA_ARGS__ | optional parameters used for specifying the base class of the component This is only used for RTTI to allow conversions from base pointer to derived types using azrtti_typeof and azrtti_cast |
The following is examples illustrate how to use the macro for a regular component class
Macro call breakdown:
AZ_TYPE_INFO_WITH_NAME_IMPL
: The call to AZ_TYPE_INFO_WITH_NAME_IMPL
expects the template placeholder arguments to be passed as variadic arguments while the simple template name is passed as the first parameter. So the _ComponentClassOrTemplate
has the first argument queried from it if it was wrapped in parenthesis If _ComponentClassOrTemplate
isn't wrapped in parenthesis it is returned as is Any template arguments are supplied after the _Uuid
argument via using the AZ_INTERNAL_SKIP_FIRST
macro combined with the AZ_VA_OPT to optionally add a comma after the _Uuid
argument if there are any template parametersAZ_RTTI_NO_TYPE_INFO_IMPL
: The call to AZ_RTTI_NO_TYPE_INFO_IMPL
expects the template placeholder arguments to be wrapped in parenthesis along with the simple template name in the first argument. Therefore no special processing needs to be done for it here, as the AZ_RTTI_NO_TYPE_INFO_IMPL
will split out the template placeholder argumentsAZ_COMPONENT_BASE_IMPL
: The call to AZ_COMPONENT_BASE_IMPL
requires the template placeholder arguments to be supplied as variadic args, with the simple template name as the first parameter. It goes through the same transformation as the AZ_TYPE_INFO_WITH_NAME_IMPL
macro to split out the template name from the template placholder parameters via parenthesis unwrapping and using the AZ_INTERNAL_USE_FIRST_ELEMENT
and AZ_INTERNAL_SKIP_FIRST
macrosAZ_CLASS_ALLOCATOR_IMPL
: The call to AZ_CLASS_ALLOCATOR_IMPL
requires template placeholder argument to be wrapped in parenthesis with the simple template name as the entire first argument This is the same way wrapping that is needed for the AZ_RTTI_NO_TYPE_INFO_IMPL
macro when supplying a template classNext is an example of using the macro with a template class
The AZ_CLASS
is a placeholder macro that is used to substitute class
template parameters For non-type template parameters such as size_t
or int
the AZ_AUTO
placeholder can be used
#define AZ_COMPONENT_IMPL_INLINE | ( | _ComponentClassOrTemplate, | |
_DisplayName, | |||
_Uuid, | |||
... | |||
) |
Version of the AZ_COMPONENT_IMPL macro which can be used in a header or inline file which is included in multiple translation units
#define AZ_COMPONENT_INTRUSIVE_DESCRIPTOR_TYPE | ( | _ComponentClass | ) |
Declares a descriptor class. Unless you are implementing very advanced internal functionality, we recommend using AZ_COMPONENT instead of this macro. This macro enables you to implement a static function in the Component class instead of writing a descriptor. It defines a CreateDescriptorFunction that you can call to register a descriptor. (Only one descriptor can exist per environment.) This macro fails silently if you implement the functions with the wrong signatures.