summaryrefslogtreecommitdiff
path: root/gdk
diff options
context:
space:
mode:
authorCarlos Garnacho <carlosg@gnome.org>2015-11-26 19:52:23 +0100
committerCarlos Garnacho <carlosg@gnome.org>2015-12-15 00:16:15 +0100
commit6f4edc091b28390eb570e10e5ff8a5e4eb04389e (patch)
treefef75851171357efd989dbc15f590d744b41e09d /gdk
parentd24f63e9ce97cf88fe0cf0f565ea2c2bf14da59f (diff)
downloadgtk+-6f4edc091b28390eb570e10e5ff8a5e4eb04389e.tar.gz
GdkDisplay: Add GdkSeat getters
https://bugzilla.gnome.org/show_bug.cgi?id=759309
Diffstat (limited to 'gdk')
-rw-r--r--gdk/gdkdisplay.c80
-rw-r--r--gdk/gdkdisplay.h7
-rw-r--r--gdk/gdkdisplayprivate.h9
3 files changed, 96 insertions, 0 deletions
diff --git a/gdk/gdkdisplay.c b/gdk/gdkdisplay.c
index 29e359fcf6..37ef5fb45c 100644
--- a/gdk/gdkdisplay.c
+++ b/gdk/gdkdisplay.c
@@ -125,6 +125,15 @@ gdk_display_real_event_data_free (GdkDisplay *display,
{
}
+static GdkSeat *
+gdk_display_real_get_default_seat (GdkDisplay *display)
+{
+ if (!display->seats)
+ return NULL;
+
+ return display->seats->data;
+}
+
static void
gdk_display_class_init (GdkDisplayClass *class)
{
@@ -140,6 +149,7 @@ gdk_display_class_init (GdkDisplayClass *class)
class->make_default = gdk_display_real_make_default;
class->event_data_copy = gdk_display_real_event_data_copy;
class->event_data_free = gdk_display_real_event_data_free;
+ class->get_default_seat = gdk_display_real_get_default_seat;
/**
* GdkDisplay::opened:
@@ -2318,3 +2328,73 @@ gdk_display_get_debug_updates (GdkDisplay *display)
else
return _gdk_debug_updates;
}
+
+void
+gdk_display_add_seat (GdkDisplay *display,
+ GdkSeat *seat)
+{
+ g_return_if_fail (GDK_IS_DISPLAY (display));
+ g_return_if_fail (GDK_IS_SEAT (seat));
+
+ display->seats = g_list_prepend (display->seats, g_object_ref (seat));
+}
+
+void
+gdk_display_remove_seat (GdkDisplay *display,
+ GdkSeat *seat)
+{
+ GList *link;
+
+ g_return_if_fail (GDK_IS_DISPLAY (display));
+ g_return_if_fail (GDK_IS_SEAT (seat));
+
+ link = g_list_find (display->seats, seat);
+
+ if (link)
+ {
+ display->seats = g_list_remove_link (display->seats, link);
+ g_object_unref (link->data);
+ g_list_free (link);
+ }
+}
+
+/**
+ * gdk_display_get_default_seat:
+ * @display: a #GdkDisplay
+ *
+ * Returns the default #GdkSeat for this display.
+ *
+ * Returns: (transfer none): the default seat.
+ *
+ * Since: 3.20
+ **/
+GdkSeat *
+gdk_display_get_default_seat (GdkDisplay *display)
+{
+ GdkDisplayClass *display_class;
+
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+
+ display_class = GDK_DISPLAY_GET_CLASS (display);
+
+ return display_class->get_default_seat (display);
+}
+
+/**
+ * gdk_display_list_seats:
+ * @display: a #GdkDisplay
+ *
+ * Returns the list of seats known to @display.
+ *
+ * Returns: (transfer container) (element-type GdkSeat): the
+ * list of seats known to the #GdkDisplay
+ *
+ * Since: 3.20
+ **/
+GList *
+gdk_display_list_seats (GdkDisplay *display)
+{
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+
+ return g_list_copy (display->seats);
+}
diff --git a/gdk/gdkdisplay.h b/gdk/gdkdisplay.h
index a76af35bed..9e30d877d8 100644
--- a/gdk/gdkdisplay.h
+++ b/gdk/gdkdisplay.h
@@ -30,6 +30,7 @@
#include <gdk/gdktypes.h>
#include <gdk/gdkevents.h>
#include <gdk/gdkdevicemanager.h>
+#include <gdk/gdkseat.h>
G_BEGIN_DECLS
@@ -171,6 +172,12 @@ GdkDeviceManager * gdk_display_get_device_manager (GdkDisplay *display);
GDK_AVAILABLE_IN_ALL
GdkAppLaunchContext *gdk_display_get_app_launch_context (GdkDisplay *display);
+GDK_AVAILABLE_IN_3_20
+GdkSeat * gdk_display_get_default_seat (GdkDisplay *display);
+
+GDK_AVAILABLE_IN_3_20
+GList * gdk_display_list_seats (GdkDisplay *display);
+
G_END_DECLS
#endif /* __GDK_DISPLAY_H__ */
diff --git a/gdk/gdkdisplayprivate.h b/gdk/gdkdisplayprivate.h
index 14d8ea6583..702d6cffe9 100644
--- a/gdk/gdkdisplayprivate.h
+++ b/gdk/gdkdisplayprivate.h
@@ -125,6 +125,8 @@ struct _GdkDisplay
guint debug_updates_set : 1;
GdkRenderingMode rendering_mode;
+
+ GList *seats;
};
struct _GdkDisplayClass
@@ -237,6 +239,8 @@ struct _GdkDisplayClass
gboolean (*make_gl_context_current) (GdkDisplay *display,
GdkGLContext *context);
+ GdkSeat * (*get_default_seat) (GdkDisplay *display);
+
/* Signals */
void (*opened) (GdkDisplay *display);
void (*closed) (GdkDisplay *display,
@@ -318,6 +322,11 @@ GdkWindow * _gdk_display_create_window (GdkDisplay *display
gboolean gdk_display_make_gl_context_current (GdkDisplay *display,
GdkGLContext *context);
+void gdk_display_add_seat (GdkDisplay *display,
+ GdkSeat *seat);
+void gdk_display_remove_seat (GdkDisplay *display,
+ GdkSeat *seat);
+
G_END_DECLS
#endif /* __GDK_DISPLAY_PRIVATE_H__ */