#ifndef EFL_IO_MODEL_EO_HH #define EFL_IO_MODEL_EO_HH #include extern "C" { #include "efl_class.eo.h" #include "efl_io_model.eo.h" #include "efl_loop.eo.h" #include "efl_loop_consumer.eo.h" #include "efl_loop_model.eo.h" #include "efl_model.eo.h" #include "efl_object.eo.h" } #include #include #include "efl_class.eo.hh" #include "efl_loop.eo.hh" #include "efl_loop_consumer.eo.hh" #include "efl_loop_model.eo.hh" #include "efl_model.eo.hh" #include "efl_object.eo.hh" #ifndef EFL_IO_MODEL_FWD_GUARD #define EFL_IO_MODEL_FWD_GUARD namespace efl { namespace io { struct Model; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::io::Model> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::io::Model&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::io::Model const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::io::Model 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_LOOP_FWD_GUARD #define EFL_LOOP_FWD_GUARD namespace efl { struct Loop; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop const&> : ::std::true_type {}; } } #endif #ifndef EFL_LOOP_CONSUMER_FWD_GUARD #define EFL_LOOP_CONSUMER_FWD_GUARD namespace efl { struct Loop_Consumer; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Consumer> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Consumer&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Consumer const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Consumer const&> : ::std::true_type {}; } } #endif #ifndef EFL_LOOP_MODEL_FWD_GUARD #define EFL_LOOP_MODEL_FWD_GUARD namespace efl { struct Loop_Model; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Model> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Model&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Model const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Loop_Model const&> : ::std::true_type {}; } } #endif #ifndef EFL_MODEL_FWD_GUARD #define EFL_MODEL_FWD_GUARD namespace efl { struct Model; } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Model> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Model&> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Model const> : ::std::true_type {}; } } namespace efl { namespace eo { template<> struct is_eolian_object< ::efl::Model 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 EFLIOFILTER_DEFINED #define EFLIOFILTER_DEFINED namespace efl { namespace eolian { template struct function_wrapper { function_wrapper(F cxx_func) : _cxx_func(cxx_func) {} void *data_to_c() { return static_cast(this); } EflIoFilter func_to_c() const { return &caller; } Eina_Free_Cb free_to_c() const { return &deleter; } private: F _cxx_func; static void deleter(void *data) { delete static_cast*>(data); } static int caller(void *cxx_call_data, ::Efl_Io_Model* model, Eina_File_Direct_Info * entry) { auto fw = static_cast*>(cxx_call_data); auto __return_value = fw->_cxx_func( ::efl::eolian::out_traits< ::efl::io::Model>::type(model), ::efl::eolian::out_traits::type(entry)); return ::efl::eolian::convert_to_c(__return_value); } }; } } #endif #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wignored-qualifiers" namespace eo_cxx { namespace efl { namespace io { struct Model { #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits< ::efl::eina::string_view>::type path_get() const; #endif #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits::type path_set( ::efl::eolian::in_traits< ::efl::eina::string_view>::type path) const; #endif #ifdef EFL_BETA_API_SUPPORT template ::efl::eolian::return_traits::type children_filter_set(F filter) const; #endif static Efl_Class const* _eo_class() { return EFL_IO_MODEL_CLASS; } Eo* _eo_ptr() const { return *(reinterpret_cast(const_cast(this))); } operator ::efl::io::Model() const; operator ::efl::io::Model&(); operator ::efl::io::Model 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 io { struct Model : private ::efl::eo::concrete , EO_CXX_INHERIT(::efl::Loop_Consumer) , EO_CXX_INHERIT(::efl::Loop_Model) , EO_CXX_INHERIT(::efl::Model) , EO_CXX_INHERIT(::efl::Object) { explicit Model( ::Eo* eo) : ::efl::eo::concrete(eo) {} Model(std::nullptr_t) : ::efl::eo::concrete(nullptr) {} explicit Model() = default; Model(Model const&) = default; Model(Model&&) = default; Model& operator=(Model const&) = default; Model& operator=(Model&&) = default; template Model(Derived&& derived , typename std::enable_if< ::efl::eo::is_eolian_object::value && std::is_base_of< Model, Derived>::value>::type* = 0) : ::efl::eo::concrete(derived._eo_ptr()) {} Model( ::efl::eo::instantiate_t) { ::efl::eolian::do_eo_add( ::efl::eo::concrete::_eo_raw, ::efl::eo::concrete{nullptr}, _eo_class()); } template explicit Model( ::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 Model( ::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 Model( ::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::eina::string_view>::type path_get() const; #endif #ifdef EFL_BETA_API_SUPPORT ::efl::eolian::return_traits::type path_set( ::efl::eolian::in_traits< ::efl::eina::string_view>::type path) const; #endif #ifdef EFL_BETA_API_SUPPORT template ::efl::eolian::return_traits::type children_filter_set(F filter) const; #endif static Efl_Class const* _eo_class() { return EFL_IO_MODEL_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 Model* operator->() const { return this; } Model* operator->() { return this; } operator Eo*() const { return _eo_ptr(); } #endif friend bool operator==(Model const& lhs, Model const& rhs) { return lhs._get_concrete() == rhs._get_concrete(); } friend bool operator!=(Model const& lhs, Model const& rhs) { return !(lhs == rhs); } }; static_assert(sizeof(Model) == sizeof(Eo*), ""); static_assert(std::is_standard_layout::value, ""); } } #pragma GCC diagnostic pop #endif