Creates a new #GtkApplication instance.
Installs an accelerator that will cause the named action to be activated when the key combination specificed by accelerator is pressed.
Adds a window to application.
Connect to QueryEnd signal.
Connect to WindowAdded signal.
Connect to WindowRemoved signal.
Gets the accelerators that are currently associated with the given action.
Returns the list of actions (possibly empty) that accel maps to. Each item in the list is a detailed action name in the usual form.
Gets the “active” window for the application.
Returns the menu model that has been set with gtk.application.Application.setAppMenu.
Gets a menu from automatically loaded resources. See [Automatic resources][automatic-resources] for more information.
Returns the menu model that has been set with gtk.application.Application.setMenubar.
Returns the #GtkApplicationWindow with the given ID.
Gets a list of the #GtkWindows associated with application.
Inform the session manager that certain types of actions should be inhibited. This is not guaranteed to work on all platforms and for all types of actions.
Determines if any of the actions specified in flags are currently inhibited (possibly by another application).
Lists the detailed action names which have associated accelerators. See gtk.application.Application.setAccelsForAction.
Determines if the desktop environment in which the application is running would prefer an application menu be shown.
Removes an accelerator that has been previously added with gtk.application.Application.addAccelerator.
Remove a window from application.
Returns this, for use in with statements.
Sets zero or more keyboard accelerators that will trigger the given action. The first item in accels will be the primary accelerator, which may be displayed in the UI.
Sets or unsets the application menu for application.
Sets or unsets the menubar for windows of application.
Removes an inhibitor that has been established with gtk.application.Application.inhibit. Inhibitors are also cleared when the application exits.
Get registerSession property.
Set registerSession property.
Get screensaverActive property.
Get builder for gtk.application.Application
Returns this, for use in with statements.
Get builder for gio.application.Application
Set actionGroup property.
Get applicationId property.
Set applicationId property.
Get flags property.
Set flags property.
Get inactivityTimeout property.
Set inactivityTimeout property.
Get isBusy property.
Get isRegistered property.
Get isRemote property.
Get resourceBasePath property.
Set resourceBasePath property.
Get version_ property.
Set version_ property.
Returns the default #GApplication instance for this process.
Checks if application_id is a valid application identifier.
Activates the application.
Add an option to be handled by application.
Adds main option entries to be handled by application.
Adds a #GOptionGroup to the commandline handling of application.
Marks application as busy (see gio.application.Application.markBusy) while property on object is true.
Gets the unique identifier for application.
Gets the #GDBusConnection being used by the application, or null.
Gets the D-Bus object path being used by the application, or null.
Gets the flags for application.
Gets the current inactivity timeout for the application.
Gets the application's current busy state, as set through gio.application.Application.markBusy or gio.application.Application.bindBusyProperty.
Checks if application is registered.
Checks if application is remote.
Gets the resource base path of application.
Gets the version of application.
Increases the use count of application.
Increases the busy count of application.
Opens the given files.
Immediately quits the application.
Attempts registration of the application.
Decrease the use count of application.
Runs the application.
Sends a notification on behalf of application to the desktop shell. There is no guarantee that the notification is displayed immediately, or even at all.
This used to be how actions were associated with a #GApplication. Now there is #GActionMap for that.
Sets the unique identifier for application.
Sets or unsets the default application for the process, as returned by gio.application.Application.getDefault.
Sets the flags for application.
Sets the current inactivity timeout for the application.
Adds a description to the application option context.
Sets the parameter string to be used by the commandline handling of application.
Adds a summary to the application option context.
Sets (or unsets) the base resource path of application.
Sets the version number of application. This will be used to implement a --version command line argument
Destroys a binding between property and the busy state of application that was previously created with gio.application.Application.bindBusyProperty.
Decreases the busy count of application.
Withdraws a notification that was sent with gio.application.Application.sendNotification.
Connect to Activate signal.
Connect to CommandLine signal.
Connect to HandleLocalOptions signal.
Connect to NameLost signal.
Connect to Open signal.
Connect to Shutdown signal.
Connect to Startup signal.
#GtkApplication is a class that handles many important aspects of a GTK+ application in a convenient fashion, without enforcing a one-size-fits-all application model.
Currently, GtkApplication handles GTK+ initialization, application uniqueness, session management, provides some basic scriptability and desktop shell integration by exporting actions and menus and manages a list of toplevel windows whose life-cycle is automatically tied to the life-cycle of your application.
While GtkApplication works fine with plain #GtkWindows, it is recommended to use it together with #GtkApplicationWindow.
When GDK threads are enabled, GtkApplication will acquire the GDK lock when invoking actions that arrive from other processes. The GDK lock is not touched for local action invocations. In order to have actions invoked in a predictable context it is therefore recommended that the GDK lock be held while invoking actions locally with gio.action_group.ActionGroup.activateAction. The same applies to actions associated with #GtkApplicationWindow and to the “activate” and “open” #GApplication methods.
Automatic resources ## {#automatic-resources}
#GtkApplication will automatically load menus from the #GtkBuilder resource located at "gtk/menus.ui", relative to the application's resource base path (see gio.application.Application.setResourceBasePath). The menu with the ID "app-menu" is taken as the application's app menu and the menu with the ID "menubar" is taken as the application's menubar. Additional menus (most interesting submenus) can be named and accessed via gtk.application.Application.getMenuById which allows for dynamic population of a part of the menu structure.
If the resources "gtk/menus-appmenu.ui" or "gtk/menus-traditional.ui" are present then these files will be used in preference, depending on the value of gtk.application.Application.prefersAppMenu. If the resource "gtk/menus-common.ui" is present it will be loaded as well. This is useful for storing items that are referenced from both "gtk/menus-appmenu.ui" and "gtk/menus-traditional.ui".
It is also possible to provide the menus manually using gtk.application.Application.setAppMenu and gtk.application.Application.setMenubar.
#GtkApplication will also automatically setup an icon search path for the default icon theme by appending "icons" to the resource base path. This allows your application to easily store its icons as resources. See gtk.icon_theme.IconTheme.addResourcePath for more information.
If there is a resource located at "gtk/help-overlay.ui" which defines a #GtkShortcutsWindow with ID "help_overlay" then GtkApplication associates an instance of this shortcuts window with each #GtkApplicationWindow and sets up keyboard accelerators (Control-F1 and Control-?) to open it. To create a menu item that displays the shortcuts window, associate the item with the action win.show-help-overlay.
A simple application ## {#gtkapplication}
A simple example
GtkApplication optionally registers with a session manager of the users session (if you set the #GtkApplication:register-session property) and offers various functionality related to the session life-cycle.
An application can block various ways to end the session with the gtk.application.Application.inhibit function. Typical use cases for this kind of inhibiting are long-running, uninterruptible operations, such as burning a CD or performing a disk backup. The session manager may not honor the inhibitor, but it can be expected to inform the user about the negative consequences of ending the session while inhibitors are present.
## See Also ## {#seealso} HowDoI: Using GtkApplication, Getting Started with GTK+: Basics