From 95dc7e43a23300b3eacbb7e1e0a9d4f31a8bd5a0 Mon Sep 17 00:00:00 2001 From: Felix Morgner Date: Thu, 24 Apr 2025 20:12:26 +0200 Subject: adw: extract class definitions --- adw/include/adwaitamm/application.hpp | 35 ++++++++++++++--------------------- 1 file changed, 14 insertions(+), 21 deletions(-) (limited to 'adw/include/adwaitamm/application.hpp') diff --git a/adw/include/adwaitamm/application.hpp b/adw/include/adwaitamm/application.hpp index 5242d50..0cbc24f 100644 --- a/adw/include/adwaitamm/application.hpp +++ b/adw/include/adwaitamm/application.hpp @@ -4,6 +4,7 @@ #include "adwaitamm/helpers/gobj_mixin.hpp" #include +#include #include #include @@ -11,31 +12,21 @@ #include -using AdwApplication = struct _AdwApplication; -using AdwApplicationClass = struct _AdwApplicationClass; +#include + +#define _ADWAITA_INSIDE +#include +#undef _ADWAITA_INSIDE namespace Adwaita { struct Application : Gtk::Application, helpers::gobj_mixin { - struct Class : Glib::Class - { - using BaseClassParent = GtkApplicationClass; - using BaseClassType = AdwApplicationClass; - using BaseObjectType = AdwApplication; - using CppClassParent = struct Gtk::Application_Class; - using CppObjectType = Application; - - auto init() -> Glib::Class const &; - auto static class_init_function(void * gclass, void * data) -> void; - auto static wrap_new(GObject * object) -> Glib::ObjectBase *; - }; - - using BaseObjectType = Class::BaseObjectType; - using BaseClassType = Class::BaseClassType; - using CppObjectType = Class::CppObjectType; - using CppClassType = Class; + using BaseObjectType = AdwApplication; + using BaseClassType = AdwApplicationClass; + using CppObjectType = Application; + using CppClassType = struct Application_Class; using helpers::gobj_mixin::gobj; using helpers::gobj_mixin::gobj_copy; @@ -46,13 +37,15 @@ namespace Adwaita auto operator=(Application const & other) noexcept -> Application & = delete; auto operator=(Application && other) noexcept -> Application & = default; - auto static create(Glib::ustring const & id = {}, - Gio::Application::Flags flags = Gio::Application::Flags::NONE) -> Glib::RefPtr; + auto static create(Glib::ustring const & id = {}, Gio::Application::Flags flags = Gio::Application::Flags::NONE) + -> Glib::RefPtr; auto static get_type() -> GType; auto static get_base_type() -> GType; protected: + friend Application_Class; + explicit Application(Glib::ConstructParams const & params); explicit Application(BaseObjectType * gobj); explicit Application(Glib::ustring const & id = {}, Gio::Application::Flags flags = Gio::Application::Flags::NONE); -- cgit v1.2.3