diff options
Diffstat (limited to 'adw/src')
| -rw-r--r-- | adw/src/breakpoint.cpp | 160 | ||||
| -rw-r--r-- | adw/src/dialog.cpp | 21 | ||||
| -rw-r--r-- | adw/src/wrap_init.cpp | 3 |
3 files changed, 183 insertions, 1 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 diff --git a/adw/src/dialog.cpp b/adw/src/dialog.cpp index c6d5e2b..8047d65 100644 --- a/adw/src/dialog.cpp +++ b/adw/src/dialog.cpp @@ -1,10 +1,13 @@ #include "turns/adw/dialog.hpp" +#include "turns/adw/breakpoint.hpp" + #include <glibmm/class.h> #include <glibmm/object.h> #include <glibmm/objectbase.h> #include <glibmm/refptr.h> #include <glibmm/ustring.h> +#include <glibmm/utility.h> #include <glibmm/wrap.h> #include <gtkmm/init.h> @@ -71,9 +74,25 @@ namespace turns::adw { } + auto Dialog::add_breakpoint(adw::Breakpoint && breakpoint) -> void + { + breakpoint.reference(); + adw_dialog_add_breakpoint(Glib::unwrap(this), Glib::unwrap(&breakpoint)); + } + + auto Dialog::close() -> void + { + adw_dialog_close(Glib::unwrap(this)); + } + auto Dialog::present(Gtk::Widget * parent) -> void { - adw_dialog_present(gobj(), Glib::unwrap(parent)); + adw_dialog_present(Glib::unwrap(this), Glib::unwrap(parent)); + } + + auto Dialog::set_title(Glib::ustring const & str) -> void + { + adw_dialog_set_title(Glib::unwrap(this), Glib::c_str_or_nullptr(str)); } } // namespace turns::adw diff --git a/adw/src/wrap_init.cpp b/adw/src/wrap_init.cpp index 16f87c3..df553da 100644 --- a/adw/src/wrap_init.cpp +++ b/adw/src/wrap_init.cpp @@ -3,6 +3,7 @@ #include "turns/adw/actionrow.hpp" #include "turns/adw/application.hpp" #include "turns/adw/applicationwindow.hpp" +#include "turns/adw/breakpoint.hpp" #include "turns/adw/dialog.hpp" #include "turns/adw/preferencesdialog.hpp" #include "turns/adw/preferencespage.hpp" @@ -28,6 +29,7 @@ namespace turns::adw WRAP_CLASS(ActionRow, action_row); WRAP_CLASS(Application, application); WRAP_CLASS(ApplicationWindow, application_window); + WRAP_CLASS(Breakpoint, breakpoint); WRAP_CLASS(Dialog, dialog); WRAP_CLASS(Toast, toast); WRAP_CLASS(PreferencesDialog, preferences_dialog); @@ -39,6 +41,7 @@ namespace turns::adw ENSURE_TYPE(ActionRow); ENSURE_TYPE(Application); ENSURE_TYPE(ApplicationWindow); + ENSURE_TYPE(Breakpoint); ENSURE_TYPE(Dialog); ENSURE_TYPE(Toast); ENSURE_TYPE(PreferencesDialog); |
