diff options
Diffstat (limited to 'adw/src/breakpoint.cpp')
| -rw-r--r-- | adw/src/breakpoint.cpp | 160 |
1 files changed, 160 insertions, 0 deletions
diff --git a/adw/src/breakpoint.cpp b/adw/src/breakpoint.cpp new file mode 100644 index 0000000..eb857ad --- /dev/null +++ b/adw/src/breakpoint.cpp @@ -0,0 +1,160 @@ +#include "turns/adw/breakpoint.hpp" + +#include "turns/adw/helpers/properties.hpp" + +#include <glibmm/class.h> +#include <glibmm/object.h> +#include <glibmm/objectbase.h> +#include <glibmm/private/object_p.h> +#include <glibmm/propertyproxy.h> +#include <glibmm/refptr.h> +#include <glibmm/ustring.h> +#include <glibmm/wrap.h> + +#include <glib-object.h> + +#include <optional> +#include <utility> + +namespace turns::adw +{ + + static_assert(static_cast<int>(BreakpointCondition::LengthType::min_width) == ADW_BREAKPOINT_CONDITION_MIN_WIDTH); + static_assert(static_cast<int>(BreakpointCondition::LengthType::max_width) == ADW_BREAKPOINT_CONDITION_MAX_WIDTH); + static_assert(static_cast<int>(BreakpointCondition::LengthType::min_height) == ADW_BREAKPOINT_CONDITION_MIN_HEIGHT); + static_assert(static_cast<int>(BreakpointCondition::LengthType::max_height) == ADW_BREAKPOINT_CONDITION_MAX_HEIGHT); + + static_assert(static_cast<int>(BreakpointCondition::RatioType::min_aspect_ratio) == ADW_BREAKPOINT_CONDITION_MIN_ASPECT_RATIO); + static_assert(static_cast<int>(BreakpointCondition::RatioType::max_aspect_ratio) == ADW_BREAKPOINT_CONDITION_MAX_ASPECT_RATIO); + + BreakpointCondition::BreakpointCondition(BreakpointCondition const & other) + : BreakpointCondition{adw_breakpoint_condition_copy(other.m_object)} + { + } + + BreakpointCondition::BreakpointCondition(BreakpointCondition && other) + : BreakpointCondition{std::exchange(other.m_object, nullptr)} + { + } + + BreakpointCondition::BreakpointCondition(LengthType type, double value, int unit) + : BreakpointCondition{adw_breakpoint_condition_new_length(static_cast<AdwBreakpointConditionLengthType>(static_cast<int>(type)), + value, + static_cast<AdwLengthUnit>(unit))} + { + } + + BreakpointCondition::BreakpointCondition(RatioType type, int width, int height) + : BreakpointCondition{ + adw_breakpoint_condition_new_ratio(static_cast<AdwBreakpointConditionRatioType>(static_cast<int>(type)), width, height)} + { + } + + BreakpointCondition::BreakpointCondition(AdwBreakpointCondition * object) + : m_object{object} + { + } + + BreakpointCondition::~BreakpointCondition() noexcept + { + if (m_object) + { + adw_breakpoint_condition_free(m_object); + m_object = nullptr; + } + } + + auto BreakpointCondition::operator&&(BreakpointCondition & rhs) & -> BreakpointCondition + { + return BreakpointCondition{adw_breakpoint_condition_new_and(m_object, rhs.m_object)}; + } + + auto BreakpointCondition::operator||(BreakpointCondition & rhs) & -> BreakpointCondition + { + return BreakpointCondition{adw_breakpoint_condition_new_or(m_object, rhs.m_object)}; + } + + BreakpointCondition::operator Glib::ustring() const + { + return adw_breakpoint_condition_to_string(const_cast<AdwBreakpointCondition *>(m_object)); + } + + auto BreakpointCondition::parse(Glib::ustring str) -> std::optional<BreakpointCondition> + { + if (auto object = adw_breakpoint_condition_parse(str.c_str())) + { + return BreakpointCondition{object}; + } + return std::nullopt; + } + +} // namespace turns::adw + +namespace turns::adw +{ + namespace + { + auto constinit _class = Breakpoint::Class{}; + } // namespace + + auto Breakpoint::Class::init() -> Glib::Class const & + { + if (!gtype_) + { + class_init_func_ = &class_init_function; + gtype_ = adw_breakpoint_get_type(); + } + return *this; + } + + auto Breakpoint::Class::class_init_function(void * gclass, void * data) -> void + { + auto const klass = static_cast<BaseClassType *>(gclass); + CppClassParent::class_init_function(klass, data); + } + + auto Breakpoint::Class::wrap_new(GObject * object) -> Glib::ObjectBase * + { + return new Breakpoint{ADW_BREAKPOINT(object)}; + } + + Breakpoint::Breakpoint(BreakpointCondition & condition) + : Glib::ObjectBase{nullptr} + , Glib::Object{Glib::ConstructParams{_class.init(), "condition", condition.m_object, nullptr}} + { + } + + Breakpoint::Breakpoint(Glib::ConstructParams const & params) + : Glib::Object{params} + { + } + + Breakpoint::Breakpoint(BaseObjectType * gobj) + : Glib::Object{G_OBJECT(gobj)} + { + } + + auto Breakpoint::get_type() -> GType + { + return _class.init().get_type(); + } + + auto Breakpoint::get_base_type() -> GType + { + return adw_breakpoint_get_type(); + } + + auto Breakpoint::property_condition() -> Glib::PropertyProxy<BreakpointCondition *> + { + return helpers::make_property_proxy<BreakpointCondition *>(*this, "condition"); + } + +} // namespace turns::adw + +namespace Glib +{ + auto wrap(AdwBreakpoint * object, bool copy) -> Glib::RefPtr<turns::adw::Breakpoint> + { + return Glib::make_refptr_for_instance(dynamic_cast<turns::adw::Breakpoint *>(Glib::wrap_auto(G_OBJECT(object), copy))); + } +} // namespace Glib |
