Function: register-read-with-preview
register-read-with-preview is a byte-compiled function defined in
register.el.gz.
Signature
(register-read-with-preview PROMPT)
Documentation
Read and return a register name, possibly showing existing registers.
Prompt with the string PROMPT. If register-alist and
register-preview-delay are both non-nil, display a window
listing existing registers after register-preview-delay seconds.
If help-char (or a member of help-event-list) is pressed,
display such a window regardless.
Probably introduced at or before Emacs version 24.4.
Source Code
;; Defined in /usr/src/emacs/lisp/register.el.gz
(defun register-read-with-preview (prompt)
"Read and return a register name, possibly showing existing registers.
Prompt with the string PROMPT. If `register-alist' and
`register-preview-delay' are both non-nil, display a window
listing existing registers after `register-preview-delay' seconds.
If `help-char' (or a member of `help-event-list') is pressed,
display such a window regardless."
(let* ((buffer "*Register Preview*")
(timer (when (numberp register-preview-delay)
(run-with-timer register-preview-delay nil
(lambda ()
(unless (get-buffer-window buffer)
(register-preview buffer))))))
(help-chars (cl-loop for c in (cons help-char help-event-list)
when (not (get-register c))
collect c)))
(unwind-protect
(progn
(while (memq (read-key (propertize prompt 'face 'minibuffer-prompt))
help-chars)
(unless (get-buffer-window buffer)
(register-preview buffer 'show-empty)))
(when (or (eq ?\C-g last-input-event)
(eq 'escape last-input-event)
(eq ?\C-\[ last-input-event))
(keyboard-quit))
(if (characterp last-input-event) last-input-event
(error "Non-character input-event")))
(and (timerp timer) (cancel-timer timer))
(let ((w (get-buffer-window buffer)))
(and (window-live-p w) (delete-window w)))
(and (get-buffer buffer) (kill-buffer buffer)))))