Mercurial > emacs
changeset 101168:f6eac5742ca0
(special-display-popup-frame): Rewrite doc-string and simplify code.
author | Martin Rudalics <rudalics@gmx.at> |
---|---|
date | Wed, 14 Jan 2009 10:12:01 +0000 |
parents | a4d9fa835dc5 |
children | 39077981fbed |
files | lisp/ChangeLog lisp/frame.el |
diffstat | 2 files changed, 24 insertions(+), 15 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/ChangeLog Wed Jan 14 09:56:11 2009 +0000 +++ b/lisp/ChangeLog Wed Jan 14 10:12:01 2009 +0000 @@ -1,5 +1,8 @@ 2009-01-14 Martin Rudalics <rudalics@gmx.at> + * frame.el (special-display-popup-frame): Rewrite doc-string and + simplify code. + * window.el (special-display-buffer-names) (special-display-regexps): Add customization support for function/other-args elements. Rewrite doc-strings.
--- a/lisp/frame.el Wed Jan 14 09:56:11 2009 +0000 +++ b/lisp/frame.el Wed Jan 14 10:12:01 2009 +0000 @@ -105,7 +105,7 @@ `pop-up-frame-function' for the creation of new frames. Since `pop-up-frame-function' is used by `display-buffer' for -making new frames, any value specified here, by default affects +making new frames, any value specified here by default affects the automatic generation of new frames via `display-buffer' and all functions based on it. The behavior of `make-frame' is not affected by this variable." @@ -126,7 +126,7 @@ (defcustom special-display-frame-alist '((height . 14) (width . 80) (unsplittable . t)) "Alist of parameters for special frames. -Special frames are used for buffers whose names are in +Special frames are used for buffers whose names are listed in `special-display-buffer-names' and for buffers whose names match one of the regular expressions in `special-display-regexps'. @@ -141,13 +141,21 @@ :group 'frames) (defun special-display-popup-frame (buffer &optional args) - "Display BUFFER in its own frame, reusing an existing window if any. -Return the window chosen. -Currently we do not insist on selecting the window within its frame. -If ARGS is an alist, use it as a list of frame parameter specs. -If ARGS is a list whose car is a symbol, -use (car ARGS) as a function to do the work. -Pass it BUFFER as first arg, and (cdr ARGS) gives the rest of the args." + "Display BUFFER and return the window chosen. +If BUFFER is already displayed in a visible or iconified frame, +raise that frame. Otherwise, display BUFFER in a new frame. + +Optional argument ARGS is a list specifying additional +information. + +If ARGS is an alist, use it as a list of frame parameters. If +these parameters contain \(same-window . t), display BUFFER in +the selected window. If they contain \(same-frame . t), display +BUFFER in a window of the selected frame. + +If ARGS is a list whose car is a symbol, use (car ARGS) as a +function to do the work. Pass it BUFFER as first argument, +and (cdr ARGS) as second." (if (and args (symbolp (car args))) (apply (car args) buffer (cdr args)) (let ((window (get-buffer-window buffer 0))) @@ -165,12 +173,10 @@ (error nil))) ;; Stay on the same frame if requested. (when (or (cdr (assq 'same-frame args)) (cdr (assq 'same-window args))) - (let* ((pop-up-frames nil) (pop-up-windows t) - special-display-regexps special-display-buffer-names - (window (display-buffer buffer))) - ;; Only do it if this is a new window: - ;; (set-window-dedicated-p window t) - window)) + (let* ((pop-up-windows t) + pop-up-frames + special-display-buffer-names special-display-regexps) + (display-buffer buffer))) ;; If no window yet, make one in a new frame. (let ((frame (with-current-buffer buffer