diff lisp/descr-text.el @ 97005:8e17e43e57e9

* descr-text.el (describe-char): Don't overwrite local variable char when describing characters with display-table entries. Display font backend when describing composed characters. Simplify: use `let' instead of `let*', and `or x y' instead of `if x x y'.
author Juanma Barranquero <lekktu@gmail.com>
date Fri, 25 Jul 2008 12:01:59 +0000
parents 79e210b5bd7b
children 15d4d10ad710
line wrap: on
line diff
--- a/lisp/descr-text.el	Fri Jul 25 11:25:43 2008 +0000
+++ b/lisp/descr-text.el	Fri Jul 25 12:01:59 2008 +0000
@@ -335,7 +335,7 @@
       (let ((char-font-info (internal-char-font pos char)))
 	(if char-font-info
 	    (let ((type (font-get (car char-font-info) :type))
-		  (name (font-xlfd-name  (car char-font-info)))
+		  (name (font-xlfd-name (car char-font-info)))
 		  (code (cdr char-font-info)))
 	       (if (integerp code)
 		   (format "%s:%s (#x%02X)" type name code)
@@ -461,10 +461,10 @@
 	       (disp-vector
 		(setq disp-vector (copy-sequence disp-vector))
 		(dotimes (i (length disp-vector))
-		  (setq char (aref disp-vector i))
 		  (aset disp-vector i
-			(cons char (describe-char-display
-				    pos (glyph-char char)))))
+			(cons (aref disp-vector i)
+			      (describe-char-display
+			       pos (glyph-char (aref disp-vector i))))))
 		(format "by display table entry [%s] (see below)"
 			(mapconcat
 			 #'(lambda (x)
@@ -544,7 +544,7 @@
 	  (save-excursion
 	    (goto-char (point-min))
 	    (re-search-forward "character:[ \t\n]+")
-	    (let* ((end (+ (point) (length char-description))))
+	    (let ((end (+ (point) (length char-description))))
 	      (mapc #'(lambda (props)
 			(let ((o (make-overlay (point) end)))
 			  (while props
@@ -561,9 +561,7 @@
 		(dotimes (i (length disp-vector))
 		  (insert (glyph-char (car (aref disp-vector i))) ?:
 			  (propertize " " 'display '(space :align-to 5))
-			  (if (cdr (aref disp-vector i))
-			      (cdr (aref disp-vector i))
-			    "-- no font --")
+			  (or (cdr (aref disp-vector i)) "-- no font --")
 			  "\n")
 		  (let ((face (glyph-face (car (aref disp-vector i)))))
 		    (when face
@@ -600,16 +598,17 @@
 			"\"")))
 	  (if (and (vectorp (nth 2 composition))
 		   (vectorp (aref (nth 2 composition) 0)))
-	      (progn
+	      (let ((font (aref (aref (nth 2 composition) 0) 0)))
 		(insert " using this font:\n  "
-			(aref (query-font (aref (aref (nth 2 composition) 0) 0))
-			      0)
+			(symbol-name (font-get font :type))
+			?:
+			(aref (query-font font) 0)
 			"\nby these glyphs:\n")
 		(mapc (lambda (x) (insert (format "  %S\n" x)))
 		      (nth 2 composition)))
 	    (insert " by the rule:\n\t(")
 	    (let ((first t))
-	      (mapc (lambda (x) 
+	      (mapc (lambda (x)
 		      (if first (setq first nil)
 			(insert " "))
 		      (if (consp x) (insert (format "%S" x))
@@ -623,7 +622,7 @@
 		  (insert "these fonts (glyph codes):")
 		  (dolist (elt component-chars)
 		    (if (/= (car elt) ?\t)
-			(insert "\n " 
+			(insert "\n "
 				(describe-char-padded-string (car elt))
 				?:
 				(propertize " " 'display '(space :align-to 5))