[gedit/wip/3.14-osx: 8/18] [osx] Use GtkApplication features for OS X



commit da98dc8ec67a656ebde63d65141cc2b9dfb2c827
Author: Jesse van den Kieboom <jessevdk gmail com>
Date:   Thu Aug 21 20:19:33 2014 +0200

    [osx] Use GtkApplication features for OS X

 gedit/gedit-app-osx.c        |  194 ++----------------------------------------
 gedit/gedit-dirs.c           |    4 +-
 gedit/gedit-window-private.h |    8 --
 3 files changed, 8 insertions(+), 198 deletions(-)
---
diff --git a/gedit/gedit-app-osx.c b/gedit/gedit-app-osx.c
index 9e3c64b..4420216 100644
--- a/gedit/gedit-app-osx.c
+++ b/gedit/gedit-app-osx.c
@@ -24,7 +24,6 @@
 #include <gedit/gedit-dirs.h>
 #include <gedit/gedit-debug.h>
 #include <gdk/gdkquartz.h>
-#include <gtkosxapplication.h>
 #include <string.h>
 #include <glib/gi18n.h>
 
@@ -134,17 +133,6 @@ gedit_app_osx_set_window_title_impl (GeditApp    *app,
 }
 
 static void
-gedit_app_osx_quit_impl (GeditApp *app)
-{
-       GtkOSXApplication *osxapp;
-
-       osxapp = g_object_new (GTK_TYPE_OSX_APPLICATION, NULL);
-       gtk_osxapplication_cleanup (osxapp);
-
-       GEDIT_APP_CLASS (gedit_app_osx_parent_class)->quit (app);
-}
-
-static void
 load_accels (void)
 {
        gchar *filename;
@@ -203,86 +191,13 @@ load_keybindings (void)
 }
 
 static void
-gedit_app_osx_constructed (GObject *object)
+gedit_app_osx_startup (GApplication *application)
 {
-       /* First load the osx specific accel overrides */
+       G_APPLICATION_CLASS (gedit_app_osx_parent_class)->startup (application);
+
+       /* Load the osx specific accel overrides */
        load_accels ();
        load_keybindings ();
-
-       if (G_OBJECT_CLASS (gedit_app_osx_parent_class)->constructed)
-       {
-               /* Then chain up to load the user specific accels */
-               G_OBJECT_CLASS (gedit_app_osx_parent_class)->constructed (object);
-       }
-}
-
-static GtkMenuItem *
-ui_manager_menu_item (GtkUIManager *uimanager,
-                      const gchar  *path)
-{
-       return GTK_MENU_ITEM (gtk_ui_manager_get_widget (uimanager, path));
-}
-
-static void
-setup_mac_menu (GeditWindow *window)
-{
-       GtkAction *action;
-       GtkOSXApplication *osxapp;
-       GtkUIManager *manager;
-       GtkWidget *menu;
-
-       manager = gedit_window_get_ui_manager (window);
-
-       /* Hide the menu bar */
-       menu = gtk_ui_manager_get_widget (manager, "/MenuBar");
-       gtk_widget_hide (menu);
-
-       osxapp = g_object_new (GTK_TYPE_OSX_APPLICATION, NULL);
-
-       action = gtk_ui_manager_get_action (manager, "/ui/MenuBar/HelpMenu/HelpAboutMenu");
-       gtk_action_set_label (action, _("About gedit"));
-
-       gtk_widget_hide (GTK_WIDGET (ui_manager_menu_item (manager,
-                                    "/ui/MenuBar/FileMenu/FileQuitMenu")));
-
-       gtk_osxapplication_set_menu_bar (osxapp,
-                                        GTK_MENU_SHELL (menu));
-
-       gtk_osxapplication_set_help_menu (osxapp,
-                                         ui_manager_menu_item (manager,
-                                                               "/ui/MenuBar/HelpMenu"));
-
-       gtk_osxapplication_set_window_menu (osxapp, NULL);
-
-       gtk_osxapplication_insert_app_menu_item (osxapp,
-                                                GTK_WIDGET (ui_manager_menu_item (manager,
-                                                                                  
"/ui/MenuBar/HelpMenu/HelpAboutMenu")),
-                                                0);
-
-       gtk_osxapplication_insert_app_menu_item (osxapp,
-                                                g_object_ref (gtk_separator_menu_item_new ()),
-                                                1);
-
-       gtk_osxapplication_insert_app_menu_item (osxapp,
-                                                GTK_WIDGET (ui_manager_menu_item (manager,
-                                                                                  
"/ui/MenuBar/EditMenu/EditPreferencesMenu")),
-                                                2);
-
-       /* We remove the accel group of the uimanager from the window */
-       gtk_window_remove_accel_group (GTK_WINDOW (window),
-                                      gtk_ui_manager_get_accel_group (manager));
-}
-
-static GeditWindow *
-gedit_app_osx_create_window_impl (GeditApp *app)
-{
-       GeditWindow *window;
-
-       window = GEDIT_APP_CLASS (gedit_app_osx_parent_class)->create_window (app);
-
-       setup_mac_menu (window);
-
-       return window;
 }
 
 static gboolean
@@ -306,126 +221,29 @@ gedit_app_osx_process_window_event_impl (GeditApp    *app,
 }
 
 static void
-gedit_app_osx_ready_impl (GeditApp *app)
-{
-       GtkOSXApplication *osxapp;
-
-       osxapp = g_object_new (GTK_TYPE_OSX_APPLICATION, NULL);
-       gtk_osxapplication_ready (osxapp);
-
-       GEDIT_APP_CLASS (gedit_app_osx_parent_class)->ready (app);
-}
-
-static void
 gedit_app_osx_class_init (GeditAppOSXClass *klass)
 {
        GObjectClass *object_class = G_OBJECT_CLASS (klass);
        GeditAppClass *app_class = GEDIT_APP_CLASS (klass);
+       GApplicationClass *application_class = G_APPLICATION_CLASS (klass);
 
        object_class->finalize = gedit_app_osx_finalize;
-       object_class->constructed = gedit_app_osx_constructed;
+       application_class->startup = gedit_app_osx_startup;
 
        app_class->show_help = gedit_app_osx_show_help_impl;
        app_class->set_window_title = gedit_app_osx_set_window_title_impl;
-       app_class->quit = gedit_app_osx_quit_impl;
-       app_class->create_window = gedit_app_osx_create_window_impl;
        app_class->process_window_event = gedit_app_osx_process_window_event_impl;
-       app_class->ready = gedit_app_osx_ready_impl;
-}
-
-static void
-on_osx_will_terminate (GtkOSXApplication *osxapp,
-                       GeditAppOSX       *app)
-{
-       g_application_quit (G_APPLICATION (app));
-}
-
-static gboolean
-on_osx_block_termination (GtkOSXApplication *osxapp,
-                          GeditAppOSX       *app)
-{
-       GtkUIManager *manager;
-       GtkAction *action;
-       GeditWindow *window;
-
-       window = gtk_appliction_get_active_window (GTK_APPLICATION (app));
-
-       // Synthesize quit-all
-       manager = gedit_window_get_ui_manager (window);
-
-       action = gtk_ui_manager_get_action (manager,
-                                           "/ui/MenuBar/FileMenu/FileQuitMenu");
-
-       _gedit_cmd_file_quit (action, window);
-       return TRUE;
-}
-
-static gboolean
-on_osx_open_files (GtkOSXApplication  *osxapp,
-                   gchar const       **paths,
-                   GeditAppOSX        *app)
-{
-       GSList *locations = NULL;
-
-       while (paths && *paths)
-       {
-               locations = g_slist_prepend (locations,
-                                            g_file_new_for_path (*paths));
-               ++paths;
-       }
-
-       locations = g_slist_reverse (locations);
-
-       if (locations != NULL)
-       {
-               GSList *files;
-               GeditWindow *window;
-
-               window = gtk_application_get_active_window (GTK_APPLICATION (app));
-
-               files = gedit_commands_load_locations (window,
-                                                      locations,
-                                                      NULL,
-                                                      0,
-                                                      0);
-
-               g_slist_free_full (locations, g_object_unref);
-       }
-
-       return TRUE;
 }
 
 static void
 gedit_app_osx_init (GeditAppOSX *app)
 {
-       GtkOSXApplication *osxapp;
-
        /* This is required so that Cocoa is not going to parse the
           command line arguments by itself and generate OpenFile events.
           We already parse the command line ourselves, so this is needed
           to prevent opening files twice, etc. */
        [[NSUserDefaults standardUserDefaults] setObject:@"NO"
                                               forKey:@"NSTreatUnknownArgumentsAsOpen"];
-
-       /* This is a singleton */
-       osxapp = g_object_new (GTK_TYPE_OSX_APPLICATION, NULL);
-
-       g_signal_connect (osxapp,
-                         "NSApplicationWillTerminate",
-                         G_CALLBACK (on_osx_will_terminate),
-                         app);
-
-       g_signal_connect (osxapp,
-                         "NSApplicationBlockTermination",
-                         G_CALLBACK (on_osx_block_termination),
-                         app);
-
-       g_signal_connect (osxapp,
-                         "NSApplicationOpenFiles",
-                         G_CALLBACK (on_osx_open_files),
-                         app);
-
-       gtk_osxapplication_set_use_quartz_accelerators (osxapp, FALSE);
 }
 
 /* ex:set ts=8 noet: */
diff --git a/gedit/gedit-dirs.c b/gedit/gedit-dirs.c
index f766e8e..929d0e4 100644
--- a/gedit/gedit-dirs.c
+++ b/gedit/gedit-dirs.c
@@ -62,9 +62,9 @@ gedit_dirs_init ()
        g_free (win32_dir);
 #else /* !G_OS_WIN32 */
 #ifdef OS_OSX
-       if (quartz_application_get_bundle_id ())
+       if (gtkosx_application_get_bundle_id () != NULL)
        {
-               const gchar *bundle_resource_dir = quartz_application_get_resource_path ();
+               const gchar *bundle_resource_dir = gtkosx_application_get_resource_path ();
 
                gedit_data_dir = g_build_filename (bundle_resource_dir,
                                                   "share",
diff --git a/gedit/gedit-window-private.h b/gedit/gedit-window-private.h
index 6a4de4f..b567420 100644
--- a/gedit/gedit-window-private.h
+++ b/gedit/gedit-window-private.h
@@ -29,10 +29,6 @@
 #include "gedit-multi-notebook.h"
 #include "gedit-open-document-selector.h"
 
-#ifdef OS_OSX
-#include <gtkosxapplication.h>
-#endif
-
 G_BEGIN_DECLS
 
 /* WindowPrivate is in a separate .h so that we can access it from gedit-commands */
@@ -116,10 +112,6 @@ struct _GeditWindowPrivate
 
        GSList         *closed_docs_stack;
 
-#ifdef OS_OSX
-       GtkOSXApplicationMenuGroup *mac_menu_group;
-#endif
-
        guint           removing_tabs : 1;
        guint           dispose_has_run : 1;
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]