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:
parent
1d2f0e0e15
commit
d42263c1bc
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user