#ifndef EFL_CANVAS_VG_CONTAINER_EO_HH #define EFL_CANVAS_VG_CONTAINER_EO_HH #include extern "C" { #include "efl_canvas_vg_container.eo.h" #include "efl_canvas_vg_node.eo.h" #include "efl_class.eo.h" #include "efl_duplicate.eo.h" #include "efl_gfx_color.eo.h" #include "efl_gfx_entity.eo.h" #include "efl_gfx_path.eo.h" #include "efl_gfx_stack.eo.h" #include "efl_object.eo.h" } #include #include #include "efl_canvas_vg_node.eo.hh" #include "efl_class.eo.hh" #include "efl_duplicate.eo.hh" #include "efl_gfx_color.eo.hh" #include "efl_gfx_entity.eo.hh" #include "efl_gfx_path.eo.hh" #include "efl_gfx_stack.eo.hh" #include "efl_object.eo.hh" #ifndef EFL_CANVAS_VG_CONTAINER_FWD_GUARD #define EFL_CANVAS_VG_CONTAINER_FWD_GUARD namespace efl { namespace canvas { namespace vg { struct Container; } } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Container> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Container&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Container const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Container const&> : ::std::true_type {}; } } #endif #ifndef EFL_CLASS_FWD_GUARD #define EFL_CLASS_FWD_GUARD namespace efl { struct Class; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Class> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Class&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Class const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Class const&> : ::std::true_type {}; } } #endif #ifndef EFL_DUPLICATE_FWD_GUARD #define EFL_DUPLICATE_FWD_GUARD namespace efl { struct Duplicate; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Duplicate> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Duplicate&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Duplicate const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Duplicate const&> : ::std::true_type {}; } } #endif #ifndef EFL_CANVAS_VG_NODE_FWD_GUARD #define EFL_CANVAS_VG_NODE_FWD_GUARD namespace efl { namespace canvas { namespace vg { struct Node; } } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node const&> : ::std::true_type {}; } } #endif #ifndef EFL_GFX_COLOR_FWD_GUARD #define EFL_GFX_COLOR_FWD_GUARD namespace efl { namespace gfx { struct Color; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Color> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Color&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Color const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Color const&> : ::std::true_type {}; } } #endif #ifndef EFL_GFX_ENTITY_FWD_GUARD #define EFL_GFX_ENTITY_FWD_GUARD namespace efl { namespace gfx { struct Entity; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Entity> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Entity&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Entity const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Entity const&> : ::std::true_type {}; } } #endif #ifndef EFL_OBJECT_FWD_GUARD #define EFL_OBJECT_FWD_GUARD namespace efl { struct Object; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Object> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Object&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Object const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Object const&> : ::std::true_type {}; } } #endif #ifndef EFL_CANVAS_VG_NODE_FWD_GUARD #define EFL_CANVAS_VG_NODE_FWD_GUARD namespace efl { namespace canvas { namespace vg { struct Node; } } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::canvas::vg::Node const&> : ::std::true_type {}; } } #endif #ifndef EFL_GFX_PATH_FWD_GUARD #define EFL_GFX_PATH_FWD_GUARD namespace efl { namespace gfx { struct Path; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Path> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Path&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Path const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Path const&> : ::std::true_type {}; } } #endif #ifndef EFL_GFX_STACK_FWD_GUARD #define EFL_GFX_STACK_FWD_GUARD namespace efl { namespace gfx { struct Stack; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Stack> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Stack&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Stack const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::gfx::Stack const&> : ::std::true_type {}; } } #endif #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wignored-qualifiers" namespace eo_cxx { namespace efl { namespace canvas { namespace vg { struct Container { #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::canvas::vg::Node>::type child_get( ::efl::eolian::in_traits< ::efl::eina::string_view>::type name) const; #endif #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::eina::iterator< ::efl::canvas::vg::Node>>::type children_get() const; #endif #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::eina::range_list< ::efl::canvas::vg::Node>>::type children_direct_get() const; #endif static Efl_Class const* _eo_class() { return EFL_CANVAS_VG_CONTAINER_CLASS; } Eo* _eo_ptr() const { return *(reinterpret_cast(const_cast(this))); } operator ::efl::canvas::vg::Container() const; operator ::efl::canvas::vg::Container&(); operator ::efl::canvas::vg::Container const&() const; /// @cond LOCAL ::efl::eolian::address_of_operator operator&() { return {this}; } ::efl::eolian::address_of_operator operator&() const { return {this}; } /// @endcond }; } } } } namespace efl { namespace canvas { namespace vg { struct Container : private ::efl::eo::concrete , EO_CXX_INHERIT(::efl::Duplicate) , EO_CXX_INHERIT(::efl::Object) , EO_CXX_INHERIT(::efl::canvas::vg::Node) , EO_CXX_INHERIT(::efl::gfx::Color) , EO_CXX_INHERIT(::efl::gfx::Entity) , EO_CXX_INHERIT(::efl::gfx::Path) , EO_CXX_INHERIT(::efl::gfx::Stack) { explicit Container( ::Eo* eo) : ::efl::eo::concrete(eo) {} Container(std::nullptr_t) : ::efl::eo::concrete(nullptr) {} explicit Container() = default; Container(Container const&) = default; Container(Container&&) = default; Container& operator=(Container const&) = default; Container& operator=(Container&&) = default; template Container(Derived&& derived , typename std::enable_if< ::efl::eo::is_eolian_object::value && std::is_base_of< Container, Derived>::value>::type* = 0) : ::efl::eo::concrete(derived._eo_ptr()) {} Container( ::efl::eo::instantiate_t) { ::efl::eolian::do_eo_add( ::efl::eo::concrete::_eo_raw, ::efl::eo::concrete{nullptr}, _eo_class()); } template explicit Container( ::efl::eo::instantiate_t, T&& parent, typename std::enable_if< ::efl::eo::is_eolian_object::value>::type* = 0) { ::efl::eolian::do_eo_add( ::efl::eo::concrete::_eo_raw, parent, _eo_class()); } template Container( ::efl::eo::instantiate_t, F&& f, typename ::std::enable_if< ::efl::eolian::is_constructor_lambda::value>::type* = 0) { ::efl::eolian::do_eo_add( ::efl::eo::concrete::_eo_raw, ::efl::eo::concrete{nullptr}, _eo_class(), *this, std::forward(f)); } template Container( ::efl::eo::instantiate_t, T&& parent, F&& f, typename ::std::enable_if< ::efl::eolian::is_constructor_lambda::value && ::efl::eo::is_eolian_object::value>::type* = 0) { ::efl::eolian::do_eo_add( ::efl::eo::concrete::_eo_raw, parent, _eo_class(), *this, std::forward(f)); } #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::canvas::vg::Node>::type child_get( ::efl::eolian::in_traits< ::efl::eina::string_view>::type name) const; #endif #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::eina::iterator< ::efl::canvas::vg::Node>>::type children_get() const; #endif #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::eina::range_list< ::efl::canvas::vg::Node>>::type children_direct_get() const; #endif static Efl_Class const* _eo_class() { return EFL_CANVAS_VG_CONTAINER_CLASS; } Eo* _eo_ptr() const { return *(reinterpret_cast(const_cast(this))); } /// @cond LOCAL ::efl::eolian::address_of_operator operator&() { return {this}; } ::efl::eolian::address_of_operator operator&() const { return {this}; } /// @endcond ::efl::eo::wref _get_wref() const { return ::efl::eo::wref(*this); } ::efl::eo::concrete const& _get_concrete() const { return *this; } ::efl::eo::concrete& _get_concrete() { return *this; } using ::efl::eo::concrete::_eo_ptr; using ::efl::eo::concrete::_release; using ::efl::eo::concrete::_reset; using ::efl::eo::concrete::_delete; using ::efl::eo::concrete::operator bool; #ifdef EFL_CXXPERIMENTAL const Container* operator->() const { return this; } Container* operator->() { return this; } operator Eo*() const { return _eo_ptr(); } #endif friend bool operator==(Container const& lhs, Container const& rhs) { return lhs._get_concrete() == rhs._get_concrete(); } friend bool operator!=(Container const& lhs, Container const& rhs) { return !(lhs == rhs); } }; static_assert(sizeof(Container) == sizeof(Eo*), ""); static_assert(std::is_standard_layout::value, ""); } } } #pragma GCC diagnostic pop #endif