mirror of
https://github.com/emacs-exwm/exwm.git
synced 2024-11-23 13:07:59 +01:00
Fix input & input focus issues
* exwm-manage.el (exwm-manage--manage-window): Only grab left/middle/right buttons. * exwm-input.el (exwm-input--on-ButtonPress): Only perform click-to-focus on unfocused X windows. * exwm-input.el (exwm-input--update-focus): Do not focus an X window on another workspace, but instead keep focusing on the current one and set exwm--urgency parameter on that frame. * exwm-input.el (exwm-input--fake-key): Send KeyRelease event (some applications reply on it).
This commit is contained in:
parent
81478de9e6
commit
9f30672b15
2 changed files with 37 additions and 27 deletions
|
@ -114,7 +114,14 @@ It's updated in several occasions, and only used by `exwm-input--set-focus'.")
|
|||
(when exwm-input--focus-window
|
||||
(with-current-buffer (window-buffer exwm-input--focus-window)
|
||||
(if (eq major-mode 'exwm-mode)
|
||||
(if (not (eq exwm--frame exwm-workspace--current))
|
||||
;; Do not focus X windows on other workspace
|
||||
(progn
|
||||
(set-frame-parameter exwm--frame 'exwm--urgency t)
|
||||
(setq exwm-workspace--switch-history-outdated t)
|
||||
(force-mode-line-update)
|
||||
;; The application may have changed its input focus
|
||||
(exwm-workspace-switch exwm-workspace-current-index t))
|
||||
(when exwm--floating-frame
|
||||
(redirect-frame-focus exwm--floating-frame nil)
|
||||
(select-frame-set-input-focus exwm--floating-frame t))
|
||||
|
@ -180,7 +187,9 @@ It's updated in several occasions, and only used by `exwm-input--set-focus'.")
|
|||
(exwm-floating--start-moveresize event))
|
||||
(t
|
||||
;; Click to focus
|
||||
(select-window (get-buffer-window (exwm--id->buffer event) t))
|
||||
(let ((window (get-buffer-window (exwm--id->buffer event) t)))
|
||||
(unless (eq window (selected-window))
|
||||
(select-window window)))
|
||||
;; The event should be replayed
|
||||
(setq mode xcb:Allow:ReplayPointer))))
|
||||
(xcb:+request exwm--connection
|
||||
|
@ -360,12 +369,13 @@ It's updated in several occasions, and only used by `exwm-input--set-focus'.")
|
|||
(keycode (xcb:keysyms:keysym->keycode exwm--connection (car keysym)))
|
||||
(id (exwm--buffer->id (window-buffer (selected-window)))))
|
||||
(when keycode
|
||||
(dolist (class '(xcb:KeyPress xcb:KeyRelease))
|
||||
(xcb:+request exwm--connection
|
||||
(make-instance 'xcb:SendEvent
|
||||
:propagate 0 :destination id
|
||||
:event-mask xcb:EventMask:NoEvent
|
||||
:event (xcb:marshal
|
||||
(make-instance 'xcb:KeyPress
|
||||
(make-instance class
|
||||
:detail keycode
|
||||
:time xcb:Time:CurrentTime
|
||||
:root exwm--root :event id
|
||||
|
@ -374,7 +384,7 @@ It's updated in several occasions, and only used by `exwm-input--set-focus'.")
|
|||
:event-x 0 :event-y 0
|
||||
:state (cadr keysym)
|
||||
:same-screen 1)
|
||||
exwm--connection))))
|
||||
exwm--connection)))))
|
||||
(xcb:flush exwm--connection)))
|
||||
|
||||
;;;###autoload
|
||||
|
|
|
@ -145,16 +145,16 @@ corresponding buffer.")
|
|||
(make-instance 'xcb:ConfigureWindow
|
||||
:window id :value-mask xcb:ConfigWindow:BorderWidth
|
||||
:border-width 0))
|
||||
(xcb:+request exwm--connection ;grab buttons for set focus/move/resize
|
||||
(dolist (button ;grab buttons to set focus / move / resize
|
||||
(list xcb:ButtonIndex:1 xcb:ButtonIndex:2 xcb:ButtonIndex:3))
|
||||
(xcb:+request-checked+request-check exwm--connection
|
||||
(make-instance 'xcb:GrabButton
|
||||
:owner-events 0 :grab-window id
|
||||
:event-mask xcb:EventMask:ButtonPress
|
||||
:pointer-mode xcb:GrabMode:Sync
|
||||
:keyboard-mode xcb:GrabMode:Async
|
||||
:confine-to xcb:Window:None
|
||||
:cursor xcb:Cursor:None
|
||||
:button xcb:ButtonIndex:Any
|
||||
:modifiers xcb:ModMask:Any))
|
||||
:confine-to xcb:Window:None :cursor xcb:Cursor:None
|
||||
:button button :modifiers xcb:ModMask:Any)))
|
||||
(xcb:+request exwm--connection ;update _NET_CLIENT_LIST
|
||||
(make-instance 'xcb:ewmh:set-_NET_CLIENT_LIST
|
||||
:window exwm--root
|
||||
|
|
Loading…
Reference in a new issue