Handle non-native windows in the gdk test utils

We need to add the non-native offset to the root coords when
sending events.
This commit is contained in:
Alexander Larsson 2009-07-08 18:40:05 +02:00
parent a90d43bed6
commit 9ef87ea11e

View File

@ -86,6 +86,7 @@ gdk_test_simulate_key (GdkWindow *window,
{ {
GdkScreen *screen; GdkScreen *screen;
GdkKeymapKey *keys = NULL; GdkKeymapKey *keys = NULL;
GdkWindowObject *priv;
gboolean success; gboolean success;
gint n_keys = 0; gint n_keys = 0;
XKeyEvent xev = { XKeyEvent xev = {
@ -104,6 +105,12 @@ gdk_test_simulate_key (GdkWindow *window,
x /= 2; x /= 2;
y /= 2; y /= 2;
} }
priv = (GdkWindowObject *)window;
/* Convert to impl coordinates */
x = x + priv->abs_x;
y = y + priv->abs_y;
xev.type = key_pressrelease == GDK_KEY_PRESS ? KeyPress : KeyRelease; xev.type = key_pressrelease == GDK_KEY_PRESS ? KeyPress : KeyRelease;
xev.display = GDK_DRAWABLE_XDISPLAY (window); xev.display = GDK_DRAWABLE_XDISPLAY (window);
xev.window = GDK_WINDOW_XID (window); xev.window = GDK_WINDOW_XID (window);
@ -190,6 +197,7 @@ gdk_test_simulate_button (GdkWindow *window,
1, /* send_event */ 1, /* send_event */
}; };
gboolean success; gboolean success;
GdkWindowObject *priv;
g_return_val_if_fail (button_pressrelease == GDK_BUTTON_PRESS || button_pressrelease == GDK_BUTTON_RELEASE, FALSE); g_return_val_if_fail (button_pressrelease == GDK_BUTTON_PRESS || button_pressrelease == GDK_BUTTON_RELEASE, FALSE);
g_return_val_if_fail (window != NULL, FALSE); g_return_val_if_fail (window != NULL, FALSE);
@ -203,6 +211,12 @@ gdk_test_simulate_button (GdkWindow *window,
x /= 2; x /= 2;
y /= 2; y /= 2;
} }
priv = (GdkWindowObject *)window;
/* Convert to impl coordinates */
x = x + priv->abs_x;
y = y + priv->abs_y;
xev.type = button_pressrelease == GDK_BUTTON_PRESS ? ButtonPress : ButtonRelease; xev.type = button_pressrelease == GDK_BUTTON_PRESS ? ButtonPress : ButtonRelease;
xev.display = GDK_DRAWABLE_XDISPLAY (window); xev.display = GDK_DRAWABLE_XDISPLAY (window);
xev.window = GDK_WINDOW_XID (window); xev.window = GDK_WINDOW_XID (window);