Change shell_global_get_modifier_keys to shell_global_get_pointer.

We can't use gdk_display_get_pointer/gdk_window_get_pointer from gjs
when XKB is active. We already had a wrapper that did the
get-modifier-state part of that, but some places also need the
get-pointer-location part of it. So update our wrapper to return both,
and update js code to use it.

https://bugzilla.gnome.org/show_bug.cgi?id=613428
This commit is contained in:
Dan Winship 2010-04-08 14:41:54 -04:00
parent 1d2f0e0e15
commit d42263c1bc
4 changed files with 23 additions and 18 deletions

View File

@ -173,7 +173,7 @@ AltTabPopup.prototype = {
// https://bugzilla.gnome.org/show_bug.cgi?id=596695 for // https://bugzilla.gnome.org/show_bug.cgi?id=596695 for
// details.) So we check now. (Have to do this after updating // details.) So we check now. (Have to do this after updating
// selection.) // selection.)
let mods = global.get_modifier_keys(); let [x, y, mods] = global.get_pointer();
if (!(mods & Gdk.ModifierType.MOD1_MASK)) { if (!(mods & Gdk.ModifierType.MOD1_MASK)) {
this._finish(); this._finish();
return false; return false;

View File

@ -423,7 +423,7 @@ WindowOverlay.prototype = {
}, },
show: function() { show: function() {
let [child, x, y, mask] = Gdk.Screen.get_default().get_root_window().get_pointer(); let [x, y, mask] = global.get_pointer();
let actor = global.stage.get_actor_at_pos(Clutter.PickMode.REACTIVE, let actor = global.stage.get_actor_at_pos(Clutter.PickMode.REACTIVE,
x, y); x, y);
if (actor == this._windowClone.actor) { if (actor == this._windowClone.actor) {
@ -533,7 +533,7 @@ WindowOverlay.prototype = {
_idleToggleCloseButton: function() { _idleToggleCloseButton: function() {
this._idleToggleCloseId = 0; this._idleToggleCloseId = 0;
let [child, x, y, mask] = Gdk.Screen.get_default().get_root_window().get_pointer(); let [x, y, mask] = global.get_pointer();
let actor = global.stage.get_actor_at_pos(Clutter.PickMode.REACTIVE, let actor = global.stage.get_actor_at_pos(Clutter.PickMode.REACTIVE,
x, y); x, y);
if (actor != this._windowClone.actor && actor != this.closeButton) { if (actor != this._windowClone.actor && actor != this.closeButton) {
@ -1185,8 +1185,7 @@ Workspace.prototype = {
if (this._windowIsZooming) if (this._windowIsZooming)
return true; return true;
let [child, x, y, mask] = let [x, y, mask] = global.get_pointer();
Gdk.Screen.get_default().get_root_window().get_pointer();
let wsWidth = this.actor.width * this.scale; let wsWidth = this.actor.width * this.scale;
let wsHeight = this.actor.height * this.scale; let wsHeight = this.actor.height * this.scale;
@ -1258,8 +1257,7 @@ Workspace.prototype = {
} }
// setup new handler // setup new handler
let [child, x, y, mask] = let [x, y, mask] = global.get_pointer();
Gdk.Screen.get_default().get_root_window().get_pointer();
this._cursorX = x; this._cursorX = x;
this._cursorY = y; this._cursorY = y;

View File

@ -1170,23 +1170,27 @@ shell_global_get_focus_monitor (ShellGlobal *global)
} }
/** /**
* shell_global_get_modifier_keys: * shell_global_get_pointer:
* @global: the #ShellGlobal * @global: the #ShellGlobal
* @x: (out): the X coordinate of the pointer, in global coordinates
* @y: (out): the Y coordinate of the pointer, in global coordinates
* @mods: (out): the current set of modifier keys that are pressed down
* *
* Gets the current set of modifier keys that are pressed down; * Gets the pointer coordinates and current modifier key state.
* this is a wrapper around gdk_display_get_pointer() that strips * This is a wrapper around gdk_display_get_pointer() that strips
* out any un-declared modifier flags, to make gjs happy; see * out any un-declared modifier flags, to make gjs happy; see
* https://bugzilla.gnome.org/show_bug.cgi?id=597292. * https://bugzilla.gnome.org/show_bug.cgi?id=597292.
*
* Return value: the current modifiers
*/ */
GdkModifierType void
shell_global_get_modifier_keys (ShellGlobal *global) shell_global_get_pointer (ShellGlobal *global,
int *x,
int *y,
ClutterModifierType *mods)
{ {
GdkModifierType mods; GdkModifierType raw_mods;
gdk_display_get_pointer (gdk_display_get_default (), NULL, NULL, NULL, &mods); gdk_display_get_pointer (gdk_display_get_default (), NULL, x, y, &raw_mods);
return mods & GDK_MODIFIER_MASK; *mods = raw_mods & GDK_MODIFIER_MASK;
} }
/** /**

View File

@ -82,7 +82,10 @@ GSList *shell_global_get_monitors (ShellGlobal *global);
GdkRectangle *shell_global_get_primary_monitor (ShellGlobal *global); GdkRectangle *shell_global_get_primary_monitor (ShellGlobal *global);
GdkRectangle *shell_global_get_focus_monitor (ShellGlobal *global); GdkRectangle *shell_global_get_focus_monitor (ShellGlobal *global);
GdkModifierType shell_global_get_modifier_keys (ShellGlobal *global); void shell_global_get_pointer (ShellGlobal *global,
int *x,
int *y,
ClutterModifierType *mods);
ClutterModifierType shell_get_event_state (ClutterEvent *event); ClutterModifierType shell_get_event_state (ClutterEvent *event);