summaryrefslogtreecommitdiff
path: root/adw/src/breakpoint.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'adw/src/breakpoint.cpp')
-rw-r--r--adw/src/breakpoint.cpp160
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