summaryrefslogtreecommitdiff
path: root/gdk/gdkdisplay.c
diff options
context:
space:
mode:
authorOwen Taylor <otaylor@redhat.com>2002-04-25 22:29:14 +0000
committerOwen Taylor <otaylor@src.gnome.org>2002-04-25 22:29:14 +0000
commit425b9886c9e042bc4e8c789e6983127981aca6cf (patch)
tree9ee6face8770b4e4bea7d4b68cb4e31cb2aa86ab /gdk/gdkdisplay.c
parente39e92123b156b6a470d54fd4d9000d7eedcf478 (diff)
downloadgdk-pixbuf-425b9886c9e042bc4e8c789e6983127981aca6cf.tar.gz
Start of integration of Erwann Chenede's multihead work from the
Thu Apr 25 16:51:40 2002 Owen Taylor <otaylor@redhat.com> Start of integration of Erwann Chenede's multihead work from the gtk-multihead branch. * gdk/gdkdisplay.[ch] gdk/gdkscreen.[ch] gdk/x11/gdkdisplay-x11.[ch] gdk/x11/gdkscreen-x11.[ch] New classes representing a set of screens with attached input devices and a single contiguous area, respectively. * gdk/gdk.[ch] gdk/gdkinternals.h gdk/x11/gdkmain-x11.c: gdk/x11/gdkprivate-x11.h: Make the initialization interface simple _gdk_windowing_init() and do the rest in gdk_open_display() calls. * gdk/gdk.[ch]: Add gdk_parse_args() which can be used to do the display-independent part of initialization instead of gdk_init_[check]. * gdk/gdkcursor.h gdk/gdkfont.h gdk/gdkkeys.h gdk/gdkpixmap.h gdk/gdkproperty.h gdk/gdkselection.h gdk/gdkwindow.h: Add multihead variants (_for_display(), for_screen()) of functions getting information specific to a particular screen screen or display. * gdk/gdkscreen.[ch]: Add gdk_screen__* variants of functions like gdk_rgb_get_colormap() that used to get/list global objects. * gdk/x11/gdkx.h: Add functions for converting GdkScreen and GdkDisplay into the X equivalents. * gdk/x11/gdkwindow-x11.c: Removed gdk_window_xid_at_coords() not in the headers and unused. * configure.in gdk/x11/{gxid.c,gxid_lib.[ch],gdkinput-gxi.c}: Remove gxid support ... has not been tested for a long time... "xfree" support is more portable to non XFree86. * gdk/**.h: Add a GDK_MULTIHEAD_SAFE define that can be used to turn off functions that are inherently non-multihead safe. * gdk/**.c: add GDK_NOTE(multihead, ...) calls when functions are used in non-multihead-safe ways. * gdk/*.c gdk/x11/*.c: Changes to make the internals of GDK multihead safe.
Diffstat (limited to 'gdk/gdkdisplay.c')
-rw-r--r--gdk/gdkdisplay.c292
1 files changed, 292 insertions, 0 deletions
diff --git a/gdk/gdkdisplay.c b/gdk/gdkdisplay.c
new file mode 100644
index 000000000..6e62364ab
--- /dev/null
+++ b/gdk/gdkdisplay.c
@@ -0,0 +1,292 @@
+/* GDK - The GIMP Drawing Kit
+ * gdkdisplay.c
+ *
+ * Copyright 2001 Sun Microsystems Inc.
+ *
+ * Erwann Chenede <erwann.chenede@sun.com>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <glib.h>
+#include "gdkdisplay.h"
+#include "gdkinternals.h"
+
+static void gdk_display_class_init (GdkDisplayClass *class);
+static void gdk_display_init (GdkDisplay *display);
+static void gdk_display_finalize (GObject *object);
+
+static GdkDisplay *default_display = NULL;
+
+static GObjectClass *parent_class;
+
+GType
+gdk_display_get_type (void)
+{
+
+ static GType object_type = 0;
+
+ if (!object_type)
+ {
+ static const GTypeInfo object_info = {
+ sizeof (GdkDisplayClass),
+ (GBaseInitFunc) NULL,
+ (GBaseFinalizeFunc) NULL,
+ (GClassInitFunc) gdk_display_class_init,
+ NULL, /* class_finalize */
+ NULL, /* class_data */
+ sizeof (GdkDisplay),
+ 0, /* n_preallocs */
+ (GInstanceInitFunc) gdk_display_init
+ };
+ object_type = g_type_register_static (G_TYPE_OBJECT,
+ "GdkDisplay", &object_info, 0);
+ }
+
+ return object_type;
+}
+
+static void
+gdk_display_class_init (GdkDisplayClass *class)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (class);
+
+ parent_class = g_type_class_peek_parent (class);
+
+ object_class->finalize = gdk_display_finalize;
+}
+
+static void
+gdk_display_init (GdkDisplay *display)
+{
+ _gdk_displays = g_slist_prepend (_gdk_displays, display);
+
+ display->button_click_time[0] = display->button_click_time[1] = 0;
+ display->button_window[0] = display->button_window[1] = NULL;
+ display->button_number[0] = display->button_number[1] = -1;
+
+ display->double_click_time = 250;
+}
+
+static void
+gdk_display_finalize (GObject *object)
+{
+ GdkDisplay *display = GDK_DISPLAY_OBJECT (object);
+
+ _gdk_displays = g_slist_remove (_gdk_displays, display);
+
+ if (default_display == display)
+ default_display = NULL;
+
+ parent_class->finalize (object);
+}
+
+/**
+ * gdk_display_get_name:
+ * @display: a #GdkDisplay
+ *
+ * Gets the name of the display.
+ *
+ * Returns: a string representing the display name.
+ */
+G_CONST_RETURN gchar *
+gdk_display_get_name (GdkDisplay * display)
+{
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+ return GDK_DISPLAY_GET_CLASS (display)->get_display_name (display);
+}
+
+/**
+ * gdk_display_get_n_screens:
+ * @display: a #GdkDisplay
+ *
+ * Gets the number of screen managed by the @display.
+ *
+ * Returns: number of screens.
+ */
+
+gint
+gdk_display_get_n_screens (GdkDisplay * display)
+{
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), 0);
+ return GDK_DISPLAY_GET_CLASS (display)->get_n_screens (display);
+}
+
+/**
+ * gdk_display_get_screen:
+ * @display: a #GdkDisplay
+ * @screen_num: the screen number
+ *
+ * Returns a screen object for one of the screens of the display.
+ *
+ * Returns: the #GdkScreen object
+ */
+
+GdkScreen *
+gdk_display_get_screen (GdkDisplay * display, gint screen_num)
+{
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+ return GDK_DISPLAY_GET_CLASS (display)->get_screen (display, screen_num);
+}
+
+/**
+ * gdk_display_get_default_screen:
+ * @display: a #GdkDisplay
+ *
+ * Get the default #GdkScreen for @display.
+ *
+ * Returns: the default #GdkScreen object for @display
+ */
+
+GdkScreen *
+gdk_display_get_default_screen (GdkDisplay * display)
+{
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+ return GDK_DISPLAY_GET_CLASS (display)->get_default_screen (display);
+}
+
+/**
+ * gdk_display_close:
+ * @display: a #GdkDisplay
+ *
+ * Closes and cleanup the resources used by the @display
+ */
+void
+gdk_display_close (GdkDisplay *display)
+{
+ g_return_if_fail (GDK_IS_DISPLAY (display));
+ g_object_unref (G_OBJECT (display));
+}
+
+/**
+ * gdk_set_default_display:
+ * @display: a #GdkDisplay
+ *
+ * Sets @display as the default display.
+ **/
+void
+gdk_set_default_display (GdkDisplay *display)
+{
+ default_display = display;
+}
+
+/**
+ * gdk_get_default_display:
+ *
+ * Gets the default #GdkDisplay.
+ *
+ * Returns: a #GdkDisplay, or %NULL if there is no default
+ * display.
+ */
+GdkDisplay *
+gdk_get_default_display (void)
+{
+ return default_display;
+}
+
+/**
+ * gdk_get_default_screen:
+ *
+ * Gets the default screen for the default display. (See
+ * gdk_get_default_display ()).
+ *
+ * Returns: a #GdkScreen.
+ */
+GdkScreen *
+gdk_get_default_screen (void)
+{
+ return gdk_display_get_default_screen (gdk_get_default_display ());
+}
+
+/**
+ * gdk_list_displays:
+ *
+ * List all currently open displays.
+ *
+ * Return value: a newly allocated #GSList of #GdkDisplay objects.
+ * Free this list with g_slist_free() when you are done with it.
+ **/
+GSList *
+gdk_list_displays (void)
+{
+ return g_slist_copy (_gdk_displays);
+}
+
+/**
+ * gdk_display_get_event:
+ * @display: a #GdkDisplay
+ * @event: a #GdkEvent
+ *
+ * Gets the next #GdkEvent to be processed for @display, fetching events from the
+ * windowing system if necessary.
+ *
+ * Return value: the next #GdkEvent to be processed, or %NULL if no events
+ * are pending. The returned #GdkEvent should be freed with gdk_event_free().
+ **/
+GdkEvent*
+gdk_display_get_event (GdkDisplay *display)
+{
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+
+ _gdk_events_queue (display);
+ return _gdk_event_unqueue (display);
+}
+
+/**
+ * gdk_display_peek_event:
+ * @void:
+ *
+ * Gets a copy of the first #GdkEvent in the @display's event queue, without
+ * removing the event from the queue. (Note that this function will
+ * not get more events from the windowing system. It only checks the events
+ * that have already been moved to the GDK event queue.)
+ *
+ * Return value: a copy of the first #GdkEvent on the event queue, or %NULL if no
+ * events are in the queue. The returned #GdkEvent should be freed with
+ * gdk_event_free().
+ **/
+GdkEvent*
+gdk_display_peek_event (GdkDisplay *display)
+{
+ GList *tmp_list;
+
+ g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);
+
+ tmp_list = _gdk_event_queue_find_first (display);
+
+ if (tmp_list)
+ return gdk_event_copy (tmp_list->data);
+ else
+ return NULL;
+}
+
+/**
+ * gdk_display_put_event:
+ * @display: a #GdkDisplay
+ * @event: a #GdkEvent.
+ *
+ * Appends a copy of the given event onto the front of the event
+ * queue for @display.
+ **/
+void
+gdk_display_put_event (GdkDisplay *display,
+ GdkEvent *event)
+{
+ g_return_if_fail (GDK_IS_DISPLAY (display));
+ g_return_if_fail (event != NULL);
+
+ _gdk_event_queue_append (display, gdk_event_copy (event));
+}