forked from AuroraMiddleware/gtk
868ee07f49
Use the new ::resource-base-path property on #GApplication to attempt to load the menu layout of the application. We look first at gtk/menus-appmenu.ui or gtk/menus-traditional.ui depending on the setting of gtk_application_prefers_app_menu(). Failing that, we fall back to the common case of gtk/menus.ui (which should always be given). This provides a convenient way for application authors to provide a different set of menus, depending on the desktop environment they find themselves in. As is the intention with other resources, if the resource base path is unset, nothing will be loaded. Additionally, if the expected files are not found, it is not an error -- just nothing happens. https://bugzilla.gnome.org/show_bug.cgi?id=722092
164 lines
6.9 KiB
C
164 lines
6.9 KiB
C
/*
|
|
* Copyright © 2010 Codethink Limited
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the licence, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Author: Ryan Lortie <desrt@desrt.ca>
|
|
*/
|
|
|
|
#ifndef __GTK_APPLICATION_H__
|
|
#define __GTK_APPLICATION_H__
|
|
|
|
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
|
|
#error "Only <gtk/gtk.h> can be included directly."
|
|
#endif
|
|
|
|
#include <gtk/gtkwidget.h>
|
|
#include <gio/gio.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define GTK_TYPE_APPLICATION (gtk_application_get_type ())
|
|
#define GTK_APPLICATION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_APPLICATION, GtkApplication))
|
|
#define GTK_APPLICATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_APPLICATION, GtkApplicationClass))
|
|
#define GTK_IS_APPLICATION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_APPLICATION))
|
|
#define GTK_IS_APPLICATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_APPLICATION))
|
|
#define GTK_APPLICATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_APPLICATION, GtkApplicationClass))
|
|
|
|
typedef struct _GtkApplication GtkApplication;
|
|
typedef struct _GtkApplicationClass GtkApplicationClass;
|
|
typedef struct _GtkApplicationPrivate GtkApplicationPrivate;
|
|
|
|
struct _GtkApplication
|
|
{
|
|
GApplication parent;
|
|
|
|
/*< private >*/
|
|
GtkApplicationPrivate *priv;
|
|
};
|
|
|
|
/**
|
|
* GtkApplicationClass:
|
|
* @parent_class: The parent class.
|
|
* @window_added: Signal emitted when a #GtkWindow is added to
|
|
* application through gtk_application_add_window().
|
|
* @window_removed: Signal emitted when a #GtkWindow is removed from
|
|
* application, either as a side-effect of being destroyed or
|
|
* explicitly through gtk_application_remove_window().
|
|
*/
|
|
struct _GtkApplicationClass
|
|
{
|
|
GApplicationClass parent_class;
|
|
|
|
/*< public >*/
|
|
|
|
void (*window_added) (GtkApplication *application,
|
|
GtkWindow *window);
|
|
void (*window_removed) (GtkApplication *application,
|
|
GtkWindow *window);
|
|
|
|
/*< private >*/
|
|
gpointer padding[12];
|
|
};
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
GType gtk_application_get_type (void) G_GNUC_CONST;
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
GtkApplication * gtk_application_new (const gchar *application_id,
|
|
GApplicationFlags flags);
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
void gtk_application_add_window (GtkApplication *application,
|
|
GtkWindow *window);
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
void gtk_application_remove_window (GtkApplication *application,
|
|
GtkWindow *window);
|
|
GDK_AVAILABLE_IN_ALL
|
|
GList * gtk_application_get_windows (GtkApplication *application);
|
|
|
|
GDK_AVAILABLE_IN_3_4
|
|
GMenuModel * gtk_application_get_app_menu (GtkApplication *application);
|
|
GDK_AVAILABLE_IN_3_4
|
|
void gtk_application_set_app_menu (GtkApplication *application,
|
|
GMenuModel *app_menu);
|
|
|
|
GDK_AVAILABLE_IN_3_4
|
|
GMenuModel * gtk_application_get_menubar (GtkApplication *application);
|
|
GDK_AVAILABLE_IN_3_4
|
|
void gtk_application_set_menubar (GtkApplication *application,
|
|
GMenuModel *menubar);
|
|
|
|
GDK_DEPRECATED_IN_3_14_FOR(gtk_application_set_accels_for_action)
|
|
void gtk_application_add_accelerator (GtkApplication *application,
|
|
const gchar *accelerator,
|
|
const gchar *action_name,
|
|
GVariant *parameter);
|
|
|
|
GDK_DEPRECATED_IN_3_14_FOR(gtk_application_set_accels_for_action)
|
|
void gtk_application_remove_accelerator (GtkApplication *application,
|
|
const gchar *action_name,
|
|
GVariant *parameter);
|
|
|
|
typedef enum
|
|
{
|
|
GTK_APPLICATION_INHIBIT_LOGOUT = (1 << 0),
|
|
GTK_APPLICATION_INHIBIT_SWITCH = (1 << 1),
|
|
GTK_APPLICATION_INHIBIT_SUSPEND = (1 << 2),
|
|
GTK_APPLICATION_INHIBIT_IDLE = (1 << 3)
|
|
} GtkApplicationInhibitFlags;
|
|
|
|
GDK_AVAILABLE_IN_3_4
|
|
guint gtk_application_inhibit (GtkApplication *application,
|
|
GtkWindow *window,
|
|
GtkApplicationInhibitFlags flags,
|
|
const gchar *reason);
|
|
GDK_AVAILABLE_IN_3_4
|
|
void gtk_application_uninhibit (GtkApplication *application,
|
|
guint cookie);
|
|
GDK_AVAILABLE_IN_3_4
|
|
gboolean gtk_application_is_inhibited (GtkApplication *application,
|
|
GtkApplicationInhibitFlags flags);
|
|
|
|
GDK_AVAILABLE_IN_3_6
|
|
GtkWindow * gtk_application_get_window_by_id (GtkApplication *application,
|
|
guint id);
|
|
|
|
GDK_AVAILABLE_IN_3_6
|
|
GtkWindow * gtk_application_get_active_window (GtkApplication *application);
|
|
|
|
GDK_AVAILABLE_IN_3_12
|
|
gchar ** gtk_application_list_action_descriptions (GtkApplication *application);
|
|
|
|
GDK_AVAILABLE_IN_3_12
|
|
gchar ** gtk_application_get_accels_for_action (GtkApplication *application,
|
|
const gchar *detailed_action_name);
|
|
|
|
GDK_AVAILABLE_IN_3_12
|
|
void gtk_application_set_accels_for_action (GtkApplication *application,
|
|
const gchar *detailed_action_name,
|
|
const gchar * const *accels);
|
|
|
|
GDK_AVAILABLE_IN_3_14
|
|
gboolean gtk_application_prefers_app_menu (GtkApplication *application);
|
|
|
|
GDK_AVAILABLE_IN_3_14
|
|
GMenu * gtk_application_get_menu_by_id (GtkApplication *application,
|
|
const gchar *id);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* __GTK_APPLICATION_H__ */
|