diff options
author | Richard M. Stallman <rms@gnu.org> | 1992-06-07 04:20:03 +0000 |
---|---|---|
committer | Richard M. Stallman <rms@gnu.org> | 1992-06-07 04:20:03 +0000 |
commit | 031317994b0d9f02e3e5dfd06a6385479e197dfe (patch) | |
tree | 3e18861affbd126f7d62cba1d7073f24dfac8263 /lisp/disp-table.el | |
parent | 464f88989ff0c5ce1ec228eaf178091bc1f591b8 (diff) | |
download | emacs-031317994b0d9f02e3e5dfd06a6385479e197dfe.tar.gz |
*** empty log message ***
Diffstat (limited to 'lisp/disp-table.el')
-rw-r--r-- | lisp/disp-table.el | 34 |
1 files changed, 15 insertions, 19 deletions
diff --git a/lisp/disp-table.el b/lisp/disp-table.el index d0f0ec03899..9b275cbca0f 100644 --- a/lisp/disp-table.el +++ b/lisp/disp-table.el @@ -19,9 +19,7 @@ ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. -;; Written by Howard Gayle. See case-table.el for details. - -(require 'case-table) +;; Written by Howard Gayle. (defun rope-to-vector (rope) (let* ((len (/ (length rope) 2)) @@ -34,13 +32,13 @@ (defun describe-display-table (DT) "Describe the display table DT in a help buffer." (with-output-to-temp-buffer "*Help*" - (princ "\nTruncation glyf: ") + (princ "\nTruncation glyph: ") (prin1 (aref dt 256)) - (princ "\nWrap glyf: ") + (princ "\nWrap glyph: ") (prin1 (aref dt 257)) - (princ "\nEscape glyf: ") + (princ "\nEscape glyph: ") (prin1 (aref dt 258)) - (princ "\nCtrl glyf: ") + (princ "\nCtrl glyph: ") (prin1 (aref dt 259)) (princ "\nSelective display rope: ") (prin1 (rope-to-vector (aref dt 260))) @@ -88,30 +86,28 @@ (or standard-display-table (setq standard-display-table (make-vector 261 nil))) (aset standard-display-table c - (make-rope (create-glyf (concat "\016" (char-to-string sc) "\017"))))) + (make-rope (create-glyph (concat "\016" (char-to-string sc) "\017"))))) (defun standard-display-graphic (c gc) "Display character C as character GC in graphics character set." (or standard-display-table (setq standard-display-table (make-vector 261 nil))) (aset standard-display-table c - (make-rope (create-glyf (concat "\e(0" (char-to-string gc) "\e(B"))))) + (make-rope (create-glyph (concat "\e(0" (char-to-string gc) "\e(B"))))) (defun standard-display-underline (c uc) "Display character C as character UC plus underlining." (or standard-display-table (setq standard-display-table (make-vector 261 nil))) (aset standard-display-table c - (make-rope (create-glyf (concat "\e[4m" (char-to-string uc) "\e[m"))))) - -(defun create-glyf (string) - (let ((i 256)) - (while (and (< i 65536) (aref glyf-table i) - (not (string= (aref glyf-table i) string))) - (setq i (1+ i))) - (if (= i 65536) - (error "No free glyf codes remain")) - (aset glyf-table i string))) + (make-rope (create-glyph (concat "\e[4m" (char-to-string uc) "\e[m"))))) + +;; Allocate a glyph code to display by sending STRING to the terminal. +(defun create-glyph (string) + (if (= (length glyph-table) 65536) + (error "No free glyph codes remain")) + (setq glyph-table (vconcat glyph-table (list string))) + (1- (length glyph-table))) (provide 'disp-table) |