summaryrefslogtreecommitdiff
path: root/lisp/frame.el
diff options
context:
space:
mode:
authorAndrea Corallo <akrl@sdf.org>2020-06-27 21:42:16 +0100
committerAndrea Corallo <akrl@sdf.org>2020-06-27 21:42:16 +0100
commit0eedb5af0b9f505dda9418323c74e992a40e5585 (patch)
tree9ef1315ecb577c36b062e8b3cb7a7c1bed6fd426 /lisp/frame.el
parent24f68d6bfc83b5514d928853ffd86b97c53e1623 (diff)
parent118c07e02e939c9f52688091509d4bff2a897032 (diff)
downloademacs-0eedb5af0b9f505dda9418323c74e992a40e5585.tar.gz
emacs-0eedb5af0b9f505dda9418323c74e992a40e5585.tar.bz2
emacs-0eedb5af0b9f505dda9418323c74e992a40e5585.zip
Merge remote-tracking branch 'savannah/master' into HEAD
Diffstat (limited to 'lisp/frame.el')
-rw-r--r--lisp/frame.el17
1 files changed, 17 insertions, 0 deletions
diff --git a/lisp/frame.el b/lisp/frame.el
index 6c2f774709e..77080b76e4f 100644
--- a/lisp/frame.el
+++ b/lisp/frame.el
@@ -1070,6 +1070,22 @@ that variable should be nil."
(setq arg (1+ arg)))
(select-frame-set-input-focus frame)))
+(defun other-frame-prefix ()
+ "Display the buffer of the next command in a new frame.
+The next buffer is the buffer displayed by the next command invoked
+immediately after this command (ignoring reading from the minibuffer).
+Creates a new frame before displaying the buffer.
+When `switch-to-buffer-obey-display-actions' is non-nil,
+`switch-to-buffer' commands are also supported."
+ (interactive)
+ (display-buffer-override-next-command
+ (lambda (buffer alist)
+ (cons (display-buffer-pop-up-frame
+ buffer (append '((inhibit-same-window . t))
+ alist))
+ 'frame)))
+ (message "Display next command buffer in a new frame..."))
+
(defun iconify-or-deiconify-frame ()
"Iconify the selected frame, or deiconify if it's currently an icon."
(interactive)
@@ -2697,6 +2713,7 @@ See also `toggle-frame-maximized'."
(define-key ctl-x-5-map "1" 'delete-other-frames)
(define-key ctl-x-5-map "0" 'delete-frame)
(define-key ctl-x-5-map "o" 'other-frame)
+(define-key ctl-x-5-map "5" 'other-frame-prefix)
(define-key global-map [f11] 'toggle-frame-fullscreen)
(define-key global-map [(meta f10)] 'toggle-frame-maximized)
(define-key esc-map [f10] 'toggle-frame-maximized)