[buoh/cleanups] BuohApplication: port to GtkApplication
- From: Jan Tojnar <jtojnar src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [buoh/cleanups] BuohApplication: port to GtkApplication
- Date: Tue, 22 Jan 2019 06:22:49 +0000 (UTC)
commit ef7926198590de529834ab2d4e1208bf16ba1e1f
Author: Jan Tojnar <jtojnar gmail com>
Date: Tue Jan 22 07:19:43 2019 +0100
BuohApplication: port to GtkApplication
src/buoh-application.c | 28 ++++++++++++++++++----------
src/buoh-application.h | 4 ++--
src/buoh-window.c | 2 --
src/main.c | 23 ++++++++---------------
4 files changed, 28 insertions(+), 29 deletions(-)
---
diff --git a/src/buoh-application.c b/src/buoh-application.c
index 4db5a43..abec65a 100644
--- a/src/buoh-application.c
+++ b/src/buoh-application.c
@@ -42,11 +42,10 @@
#include "buoh-comic-manager-date.h"
struct _BuohApplication {
- GObject parent;
+ GtkApplication parent;
- BuohWindow *window;
- GtkTreeModel *comic_list;
- gchar *datadir;
+ GtkTreeModel *comic_list;
+ gchar *datadir;
};
static void buoh_application_init (BuohApplication *buoh);
@@ -61,7 +60,7 @@ static void buoh_application_save_comic_list (GtkTreeModel
gpointer gdata);
static void buoh_application_create_user_dir (BuohApplication *buoh);
-G_DEFINE_TYPE (BuohApplication, buoh_application, G_TYPE_OBJECT)
+G_DEFINE_TYPE (BuohApplication, buoh_application, GTK_TYPE_APPLICATION)
void
buoh_debug (const gchar *format, ...)
@@ -432,7 +431,9 @@ buoh_application_get_instance (void)
static BuohApplication *buoh = NULL;
if (!buoh) {
- buoh = g_object_new (BUOH_TYPE_APPLICATION, NULL);
+ buoh = g_object_new (BUOH_TYPE_APPLICATION,
+ "application-id", "org.gnome.buoh",
+ NULL);
}
return buoh;
@@ -457,14 +458,21 @@ buoh_application_exit (BuohApplication *buoh)
}
void
-buoh_application_create_main_window (BuohApplication *buoh)
+buoh_application_activate (BuohApplication *buoh)
{
g_return_if_fail (BUOH_IS_APPLICATION (buoh));
- if (buoh->window) {
- gtk_window_present (GTK_WINDOW (buoh->window));
+ GList *list;
+ GtkWidget *window;
+
+ list = gtk_application_get_windows (GTK_APPLICATION (buoh));
+
+ if (list) {
+ gtk_window_present (GTK_WINDOW (list->data));
} else {
- buoh->window = BUOH_WINDOW (buoh_window_new ());
+ window = buoh_window_new ();
+ gtk_window_set_application (GTK_WINDOW (window), GTK_APPLICATION (buoh));
+ gtk_widget_show (window);
}
}
diff --git a/src/buoh-application.h b/src/buoh-application.h
index b39c0ab..b543372 100644
--- a/src/buoh-application.h
+++ b/src/buoh-application.h
@@ -34,14 +34,14 @@ enum {
};
#define BUOH_TYPE_APPLICATION (buoh_application_get_type())
-G_DECLARE_FINAL_TYPE (BuohApplication, buoh_application, BUOH, APPLICATION, GObject)
+G_DECLARE_FINAL_TYPE (BuohApplication, buoh_application, BUOH, APPLICATION, GtkApplication)
BuohApplication *buoh_application_get_instance (void);
BuohApplication *buoh_application_new (void);
void buoh_application_exit (BuohApplication *buoh);
-void buoh_application_create_main_window (BuohApplication *buoh);
+void buoh_application_activate (BuohApplication *buoh);
GtkTreeModel *buoh_application_get_comics_model (BuohApplication *buoh);
const gchar *buoh_application_get_datadir (BuohApplication *buoh);
diff --git a/src/buoh-window.c b/src/buoh-window.c
index ec0a5a1..d22d8eb 100644
--- a/src/buoh-window.c
+++ b/src/buoh-window.c
@@ -391,8 +391,6 @@ buoh_window_init (BuohWindow *buoh_window)
buoh_window_update_zoom_mode (buoh_window);
gtk_widget_grab_focus (GTK_WIDGET (buoh_window->view));
-
- gtk_widget_show (GTK_WIDGET (buoh_window));
}
static void
diff --git a/src/main.c b/src/main.c
index 7d1033e..d5cf30a 100644
--- a/src/main.c
+++ b/src/main.c
@@ -29,25 +29,18 @@
#include "buoh-application.h"
-gint
-main (gint argc, gchar **argv)
+int
+main (int argc, char *argv[])
{
BuohApplication *buoh;
-
- /* Initialize the i18n stuff */
- bindtextdomain (GETTEXT_PACKAGE, LOCALE_DIR);
- bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
- textdomain (GETTEXT_PACKAGE);
-
- gtk_init (&argc, &argv);
-
- g_set_application_name (_("Buoh"));
- gtk_window_set_default_icon_name ("buoh");
+ gint status;
buoh = buoh_application_new ();
- buoh_application_create_main_window (buoh);
+ g_signal_connect (buoh, "activate", G_CALLBACK (buoh_application_activate), NULL);
+
+ status = g_application_run (G_APPLICATION (buoh), argc, argv);
- gtk_main ();
+ g_object_unref (buoh);
- return 0;
+ return status;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]