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