changeset 43170:a2f11ee215ea

(list-registers): New command. (describe-register-1): New subroutine, taken out of view-register.
author Richard M. Stallman <rms@gnu.org>
date Thu, 07 Feb 2002 17:40:44 +0000
parents 717543e790e1
children b9b20fd684a4
files lisp/register.el
diffstat 1 files changed, 57 insertions(+), 34 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/register.el	Thu Feb 07 17:39:27 2002 +0000
+++ b/lisp/register.el	Thu Feb 07 17:40:44 2002 +0000
@@ -168,54 +168,77 @@
     (if (null val)
 	(message "Register %s is empty" (single-key-description register))
       (with-output-to-temp-buffer "*Output*"
-	(princ "Register ")
-	(princ (single-key-description register))
-	(princ " contains ")
-	(cond
-	 ((numberp val)
-	  (princ val))
+	(describe-register-1 register t)))))
 
-	 ((markerp val)
-	  (let ((buf (marker-buffer val)))
-	    (if (null buf)
-		(princ "a marker in no buffer")
-	      (princ "a buffer position:\nbuffer ")
-	      (princ (buffer-name buf))
-	      (princ ", position ")
-	      (princ (marker-position val)))))
+(defun list-registers ()
+  "Display a list of nonempty registers saying briefly what they contain."
+  (interactive)
+  (let ((list (copy-sequence register-alist)))
+    (setq list (sort list (lambda (a b) (< (car a) (car b)))))
+    (with-output-to-temp-buffer "*Output*"
+      (dolist (elt list)
+	(when (get-register (car elt))
+	  (describe-register-1 (car elt))
+	  (terpri))))))
+
+(defun describe-register-1 (register &optional verbose)
+  (princ "Register ")
+  (princ (single-key-description register))
+  (princ " contains ")
+  (cond
+   ((numberp val)
+    (princ val))
 
-	 ((and (consp val) (window-configuration-p (car val)))
-	  (princ "a window configuration."))
+   ((markerp val)
+    (let ((buf (marker-buffer val)))
+      (if (null buf)
+	  (princ "a marker in no buffer")
+	(princ "a buffer position:\n    buffer ")
+	(princ (buffer-name buf))
+	(princ ", position ")
+	(princ (marker-position val)))))
 
-	 ((and (consp val) (frame-configuration-p (car val)))
-	  (princ "a frame configuration."))
+   ((and (consp val) (window-configuration-p (car val)))
+    (princ "a window configuration."))
+
+   ((and (consp val) (frame-configuration-p (car val)))
+    (princ "a frame configuration."))
 
-	 ((and (consp val) (eq (car val) 'file))
-	  (princ "the file ")
-	  (prin1 (cdr val))
-	  (princ "."))
+   ((and (consp val) (eq (car val) 'file))
+    (princ "the file ")
+    (prin1 (cdr val))
+    (princ "."))
 
-	 ((and (consp val) (eq (car val) 'file-query))
-	  (princ "a file-query reference:\nfile ")
-	  (prin1 (car (cdr val)))
-	  (princ ",\nposition ")
-	  (princ (car (cdr (cdr val))))
-	  (princ "."))
+   ((and (consp val) (eq (car val) 'file-query))
+    (princ "a file-query reference:\n    file ")
+    (prin1 (car (cdr val)))
+    (princ ",\n    position ")
+    (princ (car (cdr (cdr val))))
+    (princ "."))
 
-	 ((consp val)
+   ((consp val)
+    (if verbose
+	(progn
 	  (princ "the rectangle:\n")
 	  (while val
+	    (princ "    ")
 	    (princ (car val))
 	    (terpri)
 	    (setq val (cdr val))))
+      (princ "a rectangle starting with ")
+      (princ (car val))))
 
-	 ((stringp val)
+   ((stringp val)
+    (if verbose
+	(progn
 	  (princ "the text:\n")
 	  (princ val))
-
-	 (t
-	  (princ "Garbage:\n")
-	  (prin1 val)))))))
+      (princ "text starting with\n    ")
+      (string-match "[^ \t\n].\\{,20\\}" val)
+      (princ (match-string 0 val))))
+   (t
+    (princ "Garbage:\n")
+    (if verbose (prin1 val)))))
 
 (defun insert-register (register &optional arg)
   "Insert contents of register REGISTER.  (REGISTER is a character.)