From c61998283c8436dd4360e35ce10c309e7d3ee723 Mon Sep 17 00:00:00 2001 From: Felix Morgner Date: Thu, 25 Jul 2024 13:05:02 +0200 Subject: adw: add bare bones wrapper for AdwApplication --- app/src/application.cpp | 73 ------------------------------------------------- app/src/main.cpp | 38 +++++++++++++++++++++++-- 2 files changed, 36 insertions(+), 75 deletions(-) delete mode 100644 app/src/application.cpp (limited to 'app/src') diff --git a/app/src/application.cpp b/app/src/application.cpp deleted file mode 100644 index 083cf9b..0000000 --- a/app/src/application.cpp +++ /dev/null @@ -1,73 +0,0 @@ -#include "turns/app/application.hpp" - -#include "turns/core/init.hpp" -#include "turns/ui/init.hpp" -#include "turns/ui/windows/tracker.hpp" - -#include - -#include -#include -#include - -namespace turns::app -{ - - auto application::create() -> std::shared_ptr - { - Gtk::init_gtkmm_internals(); - adw_init(); - core::register_types(); - ui::register_types(); - return std::shared_ptr{new application{}}; - } - - auto application::run(int argc, char * argv[]) -> int - { - return g_application_run(G_APPLICATION(m_adw), argc, argv); - } - - application::application() - { - m_adw = adw_application_new("ch.arknet.Turns", G_APPLICATION_DEFAULT_FLAGS); - m_application = Glib::wrap(GTK_APPLICATION(m_adw)); - - m_application->signal_activate().connect(sigc::mem_fun(*this, &application::on_activate)); - m_application->signal_shutdown().connect(sigc::mem_fun(*this, &application::on_shutdown)); - m_application->signal_startup().connect(sigc::mem_fun(*this, &application::on_startup)); - } - - auto application::handle_action_quit() -> void - { - m_tracker->close(); - } - - auto application::on_activate() -> void - { - auto builder = Gtk::Builder::create_from_resource("/windows/tracker.ui"); - m_tracker = Gtk::Builder::get_widget_derived(builder, "tracker"); - - m_application->add_window(*m_tracker); - m_tracker->present(); - } - - auto application::on_shutdown() -> void - { - m_tracker->close(); - delete m_tracker; - } - - auto application::on_startup() -> void - { - auto style_manager = adw_style_manager_get_default(); - adw_style_manager_set_color_scheme(style_manager, ADW_COLOR_SCHEME_PREFER_LIGHT); - - m_application->add_action("quit", sigc::mem_fun(*this, &application::handle_action_quit)); - m_application->set_accel_for_action("app.quit", "q"); - m_application->set_accel_for_action("win.clear", "x"); - m_application->set_accel_for_action("win.next", "space"); - m_application->set_accel_for_action("win.previous", "BackSpace"); - m_application->set_accel_for_action("win.add_participant", "a"); - } - -} // namespace turns::app \ No newline at end of file diff --git a/app/src/main.cpp b/app/src/main.cpp index 9ec90d2..119022f 100644 --- a/app/src/main.cpp +++ b/app/src/main.cpp @@ -1,7 +1,13 @@ -#include "turns/app/application.hpp" +#include "turns/adw/application.hpp" +#include "turns/adw/wrap_init.hpp" +#include "turns/core/init.hpp" +#include "turns/ui/init.hpp" +#include "turns/ui/windows/tracker.hpp" #include +#include + auto main(int argc, char * argv[]) -> int { setlocale(LC_ALL, ""); @@ -9,6 +15,34 @@ auto main(int argc, char * argv[]) -> int bind_textdomain_codeset("turns", "UTF-8"); textdomain("turns"); - auto app = turns::app::application::create(); + auto app = turns::adw::Application::create("ch.arknet.Turns"); + auto builder = Gtk::Builder::create_from_resource("/windows/tracker.ui"); + auto window = Gtk::Builder::get_widget_derived(builder, "tracker"); + + app->signal_startup().connect([app] { + turns::core::register_types(); + turns::ui::register_types(); + + auto style_manager = adw_style_manager_get_default(); + adw_style_manager_set_color_scheme(style_manager, ADW_COLOR_SCHEME_PREFER_LIGHT); + + app->add_action("quit", sigc::mem_fun(*app, &turns::adw::Application::quit)); + app->set_accel_for_action("app.quit", "q"); + app->set_accel_for_action("win.clear", "x"); + app->set_accel_for_action("win.next", "space"); + app->set_accel_for_action("win.previous", "BackSpace"); + app->set_accel_for_action("win.add_participant", "a"); + }); + + app->signal_shutdown().connect([window] { + window->close(); + delete window; + }); + + app->signal_activate().connect([app, window] { + app->add_window(*window); + window->present(); + }); + return app->run(argc, argv); } \ No newline at end of file -- cgit v1.2.3