summaryrefslogtreecommitdiff
path: root/tests/testxinerama.c
diff options
context:
space:
mode:
authorErwann Chenede - <erwann.chenede@sun.com>2002-05-01 17:22:54 +0000
committerErwann Chenede <erwannc@src.gnome.org>2002-05-01 17:22:54 +0000
commit2325caf979da21cb7be31f9382722e3d35d0e499 (patch)
treed42d47d4e91e3a6ebd37cdb1e30c3ad570bdb527 /tests/testxinerama.c
parentec72bb76d47157ebf6331fce20e11b6e487e27c5 (diff)
downloadgtk+-2325caf979da21cb7be31f9382722e3d35d0e499.tar.gz
remove virtualization and made it cross platform. fix #79961 fixed
2002-05-01 Erwann Chenede - <erwann.chenede@sun.com> * gdk/gdkscreen.[hc] (gdk_screen_x11_get_monitor_at_window): remove virtualization and made it cross platform. fix #79961 * gdk/x11/gdkdisplay-x11.c (check_solaris_xinerama): fixed initialization bugs. * gdk/x11/gdkscreen-x11.[hc] (gdk_screen_get_monitor_geometry): * tests/testxinerama.c: * gtk/gtkwindow.c (gtk_window_compute_configure_request): * gtk/gtkmenu.c (gtk_menu_position): take a GdkRectangle argument instead of returning a GdkRectangle * and propagated the changes. fix #79974
Diffstat (limited to 'tests/testxinerama.c')
-rw-r--r--tests/testxinerama.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/tests/testxinerama.c b/tests/testxinerama.c
index 69bc6fc7bd..2f6e05ea23 100644
--- a/tests/testxinerama.c
+++ b/tests/testxinerama.c
@@ -1,6 +1,5 @@
#include <stdlib.h>
#include <gtk/gtk.h>
-#include "x11/gdkx.h"
static gint num_monitors;
@@ -11,18 +10,19 @@ request (GtkWidget *widget,
{
gchar *str;
gint i = gdk_screen_get_monitor_at_window (gtk_widget_get_screen (widget),
- GDK_WINDOW_XWINDOW (widget->window));
+ widget->window);
if (i < 0)
str = g_strdup ("<big><span foreground='white' background='black'>Not on a monitor </span></big>");
else
{
- GdkRectangle *monitor = gdk_screen_get_monitor_geometry (gtk_widget_get_screen (widget), i);
+ GdkRectangle monitor;
+ gdk_screen_get_monitor_geometry (gtk_widget_get_screen (widget), i, &monitor);
str = g_strdup_printf ("<big><span foreground='white' background='black'>"
"Monitor %d of %d</span></big>\n"
"<i>Width - Height </i>: (%d,%d)\n"
"<i>Top left coordinate </i>: (%d,%d)",i+1, num_monitors,
- monitor->width, monitor->height, monitor->x, monitor->y);
+ monitor.width, monitor.height, monitor.x, monitor.y);
}
gtk_label_set_markup (GTK_LABEL (user_data), str);
@@ -42,25 +42,26 @@ main (int argc, char *argv[])
num_monitors = gdk_screen_get_n_monitors (screen);
if (num_monitors == 1)
- g_warning ("The current display has only one monitor.");
+ g_warning ("The current display does not support xinerama.");
for (i=0; i<num_monitors; i++)
{
- GdkRectangle *monitor = gdk_screen_get_monitor_geometry (screen, i);
+ GdkRectangle monitor;
gchar *str;
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ gdk_screen_get_monitor_geometry (screen, i, &monitor);
gtk_window_set_default_size (GTK_WINDOW (window), 200, 200);
- gtk_window_move (GTK_WINDOW (window), (monitor->width - 200) / 2 + monitor->x,
- (monitor->height - 200) / 2 + monitor->y);
+ gtk_window_move (GTK_WINDOW (window), (monitor.width - 200) / 2 + monitor.x,
+ (monitor.height - 200) / 2 + monitor.y);
label = gtk_label_new (NULL);
str = g_strdup_printf ("<big><span foreground='white' background='black'>"
"Monitor %d of %d</span></big>\n"
"<i>Width - Height </i>: (%d,%d)\n"
"<i>Top left coordinate </i>: (%d,%d)",i+1, num_monitors,
- monitor->width, monitor->height, monitor->x, monitor->y);
+ monitor.width, monitor.height, monitor.x, monitor.y);
gtk_label_set_markup (GTK_LABEL (label), str);
g_free (str);
button = gtk_button_new_with_label ("Close");