From: Dave Love <fx@gnu.org>
Date: Tue, 10 Sep 2002 17:39:35 +0000 (+0000)
Subject: (ucs-mule-to-mule-unicode): Define
X-Git-Tag: ttn-vms-21-2-B4~13254
X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=988b5a141bf7dc222728f9036ab1378a64ab5af6;p=emacs.git

(ucs-mule-to-mule-unicode): Define
unconditionally.
(utf-8-fragmentation-table): New.  Use it in top-level mapc.
(utf-8-fragment-on-decoding): Use it to keep
utf-8-translation-table-for-decode variable and translation table
in sync.
---

diff --git a/lisp/international/utf-8.el b/lisp/international/utf-8.el
index a85d980bc02..e2f4976b97b 100644
--- a/lisp/international/utf-8.el
+++ b/lisp/international/utf-8.el
@@ -66,10 +66,8 @@
 
 (defvar ucs-mule-to-mule-unicode (make-translation-table)
   "Translation table for encoding to `mule-utf-8'.")
-;; Could have been done by ucs-tables loaded before.
-(unless (get 'ucs-mule-to-mule-unicode 'translation-table)
-  (define-translation-table 'ucs-mule-to-mule-unicode
-    ucs-mule-to-mule-unicode))
+(define-translation-table 'ucs-mule-to-mule-unicode
+  ucs-mule-to-mule-unicode)
 
 (defvar utf-8-subst-table (make-hash-table :test 'eq))
 (defvar utf-8-subst-rev-table (make-hash-table :test 'eq))
@@ -87,9 +85,13 @@ decoded into mule-unicode-0100-24ff.")
 ;; space of mule-unicode.  For Latin scripts this isn't very
 ;; important.  Hebrew and Arabic might go here too when there's proper
 ;; support for them.
+(defvar utf-8-fragmentation-table (make-translation-table)
+  "Char table normally mapping non-Latin mule-unicode-... characters to iso8859.
+Used as the value of `utf-8-translation-table-for-decode' in
+`utf-8-fragment-on-decoding' mode.")
 (mapc
  (lambda (pair)
-   (aset utf-8-translation-table-for-decode (car pair) (cdr pair)))
+   (aset utf-8-fragmentation-table (car pair) (cdr pair)))
  '((?$,1&d(B . ?,F4(B) (?$,1&e(B . ?,F5(B) (?$,1&f(B . ?,F6(B) (?$,1&h(B . ?,F8(B) (?$,1&i(B . ?,F9(B)
    (?$,1&j(B . ?,F:(B) (?$,1&l(B . ?,F<(B) (?$,1&n(B . ?,F>(B) (?$,1&o(B . ?,F?(B) (?$,1&p(B . ?,F@(B)
    (?$,1&q(B . ?,FA(B) (?$,1&r(B . ?,FB(B) (?$,1&s(B . ?,FC(B) (?$,1&t(B . ?,FD(B) (?$,1&u(B . ?,FE(B)
@@ -138,10 +140,12 @@ for mechanisms to make this largely transparent.
 
 Setting this variable outside customize has no effect."
   :set (lambda (s v)
-	 (if v
-	     (define-translation-table 'utf-8-translation-table-for-decode
-	       utf-8-translation-table-for-decode)
-	   (define-translation-table 'utf-8-translation-table-for-decode))
+	 (setq utf-8-translation-table-for-decode
+	       (if v
+		   utf-8-fragmentation-table
+		 (make-char-table)))
+	 (define-translation-table 'utf-8-translation-table-for-decode
+	   utf-8-translation-table-for-decode)
 	 (set-default s v))
   :version "21.4"
   :type 'boolean