# HG changeset patch # User Kenichi Handa # Date 1161862449 0 # Node ID 042336f13176918de4466b39676e5b2e03907241 # Parent a4f566c827f5cc9f324fce60d6c7b96410588879 (terminal-composition-function): New function. (terminal-composition-function-table): New variable. (auto-compose-chars): If running on a terminal, use terminal-composition-function-table. diff -r a4f566c827f5 -r 042336f13176 lisp/composite.el --- a/lisp/composite.el Thu Oct 26 11:32:57 2006 +0000 +++ b/lisp/composite.el Thu Oct 26 11:34:09 2006 +0000 @@ -427,6 +427,41 @@ (put 'save-buffer-state 'lisp-indent-function 1) +(defun terminal-composition-function (pos &optional string) + "General composition function used on terminal. +Non-spacing characters are composed with the preceding spacing +character. All non-spacing characters has this function in +`terminal-composition-function-table'." + (let ((from (1- pos)) + ch) + (if string + (length string) + (setq pos (1+ pos)) + (while (and (< pos (point-max)) + (= (aref char-width-table (char-after pos)) 0)) + (setq pos (1+ pos))) + (if (and (>= from (point-min)) + (= (aref (symbol-name (get-char-code-property (char-after from) + 'general-category)) + 0) + ?L)) + (compose-region from pos (buffer-substring from pos)) + (compose-region (1+ from) pos + (concat " " (buffer-substring (1+ from) pos)))) + pos))) + +(defvar terminal-composition-function-table + (let ((table (make-char-table nil))) + (map-char-table + #'(lambda (key val) + (if (= val 0) (set-char-table-range table key + 'terminal-composition-function))) + char-width-table) + table) + "Char table of functions for automatic character composition on terminal. +This is like `composition-function-table' but used when Emacs is running +on a terminal.") + (defvar auto-compose-current-font nil "The current font-object used for characters being composed automatically.") @@ -444,6 +479,9 @@ (let ((start pos) (limit (if string (length string) (point-max))) (auto-compose-current-font font-object) + (table (if (display-graphic-p) + composition-function-table + terminal-composition-function-table)) ch func newpos) (setq limit (or (text-property-any pos limit 'auto-composed t string) @@ -455,7 +493,7 @@ (setq ch (aref string pos)) (if (= ch ?\n) (throw 'tag (1+ pos))) - (setq func (aref composition-function-table ch)) + (setq func (aref table ch)) (if (and (functionp func) (setq newpos (funcall func pos string)) (> newpos pos)) @@ -465,7 +503,7 @@ (setq ch (char-after pos)) (if (= ch ?\n) (throw 'tag (1+ pos))) - (setq func (aref composition-function-table ch)) + (setq func (aref table ch)) (if (and (functionp func) (setq newpos (funcall func pos string)) (> newpos pos))