34 template <
typename AronTypeT,
typename DerivedT>
62 const auto& n =
dynamic_cast<const DerivedT&
>(other);
69 return *(this->
aron) == *(other.aron);
73 type::dto::GenericTypePtr
103 return dynamic_cast<DerivedT&
>(n);
106 static const DerivedT&
109 return dynamic_cast<const DerivedT&
>(n);
112 static std::shared_ptr<DerivedT>
115 return std::dynamic_pointer_cast<DerivedT>(n);
118 static std::shared_ptr<DerivedT>
126 auto casted = std::dynamic_pointer_cast<DerivedT>(n);
132 typename AronTypeT::PointerType
aron;
virtual VariantPtr navigateAbsolute(const Path &path) const =0
naviate absolute
Variant(const type::Descriptor &descriptor, const Path &path=Path())
const type::Descriptor descriptor
static DerivedT & DynamicCast(Variant &n)
static const DerivedT & DynamicCast(const Variant &n)
SpecializedVariantBase(const AronTypeT &o, const type::Descriptor &descriptor, const Path &path)
AronTypeT::PointerType aron
type::Maybe getMaybe() const override
get the maybe type
static std::shared_ptr< DerivedT > DynamicCastAndCheck(const VariantPtr &n)
bool operator==(const Variant &other) const override
VariantPtr navigateRelative(const Path &path) const override
navigate relative
bool operator==(const DerivedT &other) const
void setMaybe(const type::Maybe m) override
set the maybetype of this type
SpecializedVariantBase(const type::Descriptor &descriptor, const Path &path)
static std::shared_ptr< DerivedT > DynamicCast(const VariantPtr &n)
virtual ~SpecializedVariantBase()=default
type::dto::GenericTypePtr toAronDTO() const override
convert this variant to a dto object.
#define ARMARX_CHECK_NOT_NULL(ptr)
This macro evaluates whether ptr is not null and if it turns out to be false it will throw an Express...
std::shared_ptr< Variant > VariantPtr