mirror of
https://github.com/ch11ng/exwm.git
synced 2024-11-27 21:18:00 +01:00
Automatically iconify floating X windows
* exwm-layout.el (exwm-layout-auto-iconify): New user option to specify whether to automatically iconify X windows. (exwm-layout--auto-iconify): Automatically iconify floating X windows when its main X window (if any) is iconified. (exwm-layout--show, exwm-layout--hide): Use it.
This commit is contained in:
parent
2efd7495d9
commit
404c94568d
1 changed files with 21 additions and 1 deletions
|
@ -32,6 +32,10 @@
|
||||||
:version "25.3"
|
:version "25.3"
|
||||||
:group 'exwm)
|
:group 'exwm)
|
||||||
|
|
||||||
|
(defcustom exwm-layout-auto-iconify t
|
||||||
|
"Non-nil to automatically iconify unused X windows when possible."
|
||||||
|
:type 'boolean)
|
||||||
|
|
||||||
(defcustom exwm-layout-show-all-buffers nil
|
(defcustom exwm-layout-show-all-buffers nil
|
||||||
"Non-nil to allow switching to buffers on other workspaces."
|
"Non-nil to allow switching to buffers on other workspaces."
|
||||||
:type 'boolean)
|
:type 'boolean)
|
||||||
|
@ -76,6 +80,20 @@
|
||||||
(when (derived-mode-p 'exwm-mode)
|
(when (derived-mode-p 'exwm-mode)
|
||||||
(memq xcb:Atom:_NET_WM_STATE_FULLSCREEN exwm--ewmh-state)))
|
(memq xcb:Atom:_NET_WM_STATE_FULLSCREEN exwm--ewmh-state)))
|
||||||
|
|
||||||
|
(defun exwm-layout--auto-iconify ()
|
||||||
|
(when (and exwm-layout-auto-iconify
|
||||||
|
(not exwm-transient-for))
|
||||||
|
(let ((xwin exwm--id)
|
||||||
|
(state exwm-state))
|
||||||
|
(dolist (pair exwm--id-buffer-alist)
|
||||||
|
(with-current-buffer (cdr pair)
|
||||||
|
(when (and exwm--floating-frame
|
||||||
|
(eq exwm-transient-for xwin)
|
||||||
|
(not (eq exwm-state state)))
|
||||||
|
(if (eq state xcb:icccm:WM_STATE:NormalState)
|
||||||
|
(exwm-layout--refresh-floating exwm--floating-frame)
|
||||||
|
(exwm-layout--hide exwm--id))))))))
|
||||||
|
|
||||||
(defun exwm-layout--show (id &optional window)
|
(defun exwm-layout--show (id &optional window)
|
||||||
"Show window ID exactly fit in the Emacs window WINDOW."
|
"Show window ID exactly fit in the Emacs window WINDOW."
|
||||||
(exwm--log "Show #x%x in %s" id window)
|
(exwm--log "Show #x%x in %s" id window)
|
||||||
|
@ -111,7 +129,8 @@
|
||||||
height height*)))
|
height height*)))
|
||||||
(exwm--set-geometry id x y width height)
|
(exwm--set-geometry id x y width height)
|
||||||
(xcb:+request exwm--connection (make-instance 'xcb:MapWindow :window id))
|
(xcb:+request exwm--connection (make-instance 'xcb:MapWindow :window id))
|
||||||
(exwm-layout--set-state id xcb:icccm:WM_STATE:NormalState)))
|
(exwm-layout--set-state id xcb:icccm:WM_STATE:NormalState)
|
||||||
|
(exwm-layout--auto-iconify)))
|
||||||
(xcb:flush exwm--connection))
|
(xcb:flush exwm--connection))
|
||||||
|
|
||||||
(defun exwm-layout--hide (id)
|
(defun exwm-layout--hide (id)
|
||||||
|
@ -141,6 +160,7 @@
|
||||||
:window id :value-mask xcb:CW:EventMask
|
:window id :value-mask xcb:CW:EventMask
|
||||||
:event-mask exwm--client-event-mask))
|
:event-mask exwm--client-event-mask))
|
||||||
(exwm-layout--set-state id xcb:icccm:WM_STATE:IconicState)
|
(exwm-layout--set-state id xcb:icccm:WM_STATE:IconicState)
|
||||||
|
(exwm-layout--auto-iconify)
|
||||||
(xcb:flush exwm--connection))))
|
(xcb:flush exwm--connection))))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
|
|
Loading…
Reference in a new issue