[gtk+/action-helper: 2/16] GtkApplication: add 'active-window' property
- From: Ryan Lortie <ryanl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/action-helper: 2/16] GtkApplication: add 'active-window' property
- Date: Sat, 18 Aug 2012 03:48:33 +0000 (UTC)
commit 1d864f962deff746363b1f884217b86b310edaa4
Author: Ryan Lortie <desrt desrt ca>
Date: Fri Aug 17 18:05:27 2012 -0400
GtkApplication: add 'active-window' property
gtk/gtkapplication.c | 35 ++++++++++++++++++++++++++++++++++-
gtk/gtkapplication.h | 3 +++
2 files changed, 37 insertions(+), 1 deletions(-)
---
diff --git a/gtk/gtkapplication.c b/gtk/gtkapplication.c
index efc1a8b..e141bc3 100644
--- a/gtk/gtkapplication.c
+++ b/gtk/gtkapplication.c
@@ -132,7 +132,8 @@ enum {
PROP_ZERO,
PROP_REGISTER_SESSION,
PROP_APP_MENU,
- PROP_MENUBAR
+ PROP_MENUBAR,
+ PROP_ACTIVE_WINDOW
};
G_DEFINE_TYPE (GtkApplication, gtk_application, G_TYPE_APPLICATION)
@@ -405,6 +406,8 @@ gtk_application_focus_in_event_cb (GtkWindow *window,
priv->windows = g_list_concat (link, priv->windows);
}
+ g_object_notify (G_OBJECT (application), "active-window");
+
#ifdef GDK_WINDOWING_QUARTZ
gtk_application_focus_changed (application, window);
#endif
@@ -755,6 +758,13 @@ gtk_application_class_init (GtkApplicationClass *class)
P_("The GMenuModel for the menubar"),
G_TYPE_MENU_MODEL,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
+
+ g_object_class_install_property (object_class, PROP_ACTIVE_WINDOW,
+ g_param_spec_object ("active-window",
+ P_("Active window"),
+ P_("The window which most recently had focus"),
+ GTK_TYPE_WINDOW,
+ G_PARAM_READABLE | G_PARAM_STATIC_STRINGS));
}
/**
@@ -916,6 +926,29 @@ gtk_application_get_window_by_id (GtkApplication *application,
}
/**
+ * gtk_application_get_active_window:
+ * @application: a #GtkApplication
+ *
+ * Gets the "active" window for the application.
+ *
+ * The active window is the one that was most recently focused (within
+ * the application). This window may not have the focus at the moment
+ * if another application has it -- this is just the most
+ * recently-focused window within this application.
+ *
+ * Returns: (transfer none): the active window
+ *
+ * Since: 3.6
+ **/
+GtkWindow *
+gtk_application_get_active_window (GtkApplication *application)
+{
+ g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
+
+ return application->priv->windows ? application->priv->windows->data : NULL;
+}
+
+/**
* gtk_application_add_accelerator:
* @application: a #GtkApplication
* @accelerator: accelerator string
diff --git a/gtk/gtkapplication.h b/gtk/gtkapplication.h
index 21cd389..d354562 100644
--- a/gtk/gtkapplication.h
+++ b/gtk/gtkapplication.h
@@ -119,6 +119,9 @@ 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);
+
G_END_DECLS
#endif /* __GTK_APPLICATION_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]