]> git.eshelyaron.com Git - emacs.git/commitdiff
international/mule-cmds.el (canonicalize-coding-system-name): Convert "msXXX", "ibmXX...
authorKenichi Handa <handa@m17n.org>
Fri, 15 Jan 2010 12:35:31 +0000 (21:35 +0900)
committerKenichi Handa <handa@m17n.org>
Fri, 15 Jan 2010 12:35:31 +0000 (21:35 +0900)
lisp/ChangeLog
lisp/international/mule-cmds.el

index 2b14d89c3258b8c595297399892474b09787bbac..1f3e01fddb27b8b6056cb4fe5500ae64cb02260d 100644 (file)
@@ -1,3 +1,8 @@
+2010-01-15  Kenichi Handa  <handa@m17n.org>
+
+       * international/mule-cmds.el (canonicalize-coding-system-name):
+       Convert "msXXX", "ibmXXX", "windows-XXX" to "cpXXX".
+
 2010-01-14  Glenn Morris  <rgm@gnu.org>
 
        * frame.el (show-trailing-whitespace): Safe if boolean.  (Bug#5312)
index c21bfb23ba96dab768003123bcb9ab1fe11849b4..a594b837e0bd879c78370fe5571ee9d6834c7907 100644 (file)
@@ -226,19 +226,22 @@ how text is formatted automatically while decoding."
 ;; and delimiter characters.  Support function of
 ;; coding-system-from-name.
 (defun canonicalize-coding-system-name (name)
-  (if (string-match "^iso[-_ ]?[0-9]" name)
-      ;; "iso-8859-1" -> "8859-1", "iso-2022-jp" ->"2022-jp"
-      (setq name (substring name (1- (match-end 0)))))
-  (let ((idx (string-match "[-_ /]" name)))
-    ;; Delete "-", "_", " ", "/" but do distinguish "16-be" and "16be".
-    (while idx
-      (if (and (>= idx 2)
-              (eq (string-match "16-[lb]e$" name (- idx 2))
-                  (- idx 2)))
-         (setq idx (string-match "[-_ /]" name (match-end 0)))
-       (setq name (concat (substring name 0 idx) (substring name (1+ idx)))
-             idx (string-match "[-_ /]" name idx))))
-    name))
+  (if (string-match "^\\(ms\\|ibm\\|windows-\\)\\([0-9]+\\)$" name)
+      ;; "ms950", "ibm950", "windows-950" -> "cp950"
+      (concat "cp" (match-string 2 name))
+    (if (string-match "^iso[-_ ]?[0-9]" name)
+       ;; "iso-8859-1" -> "8859-1", "iso-2022-jp" ->"2022-jp"
+       (setq name (substring name (1- (match-end 0)))))
+    (let ((idx (string-match "[-_ /]" name)))
+      ;; Delete "-", "_", " ", "/" but do distinguish "16-be" and "16be".
+      (while idx
+       (if (and (>= idx 2)
+                (eq (string-match "16-[lb]e$" name (- idx 2))
+                    (- idx 2)))
+           (setq idx (string-match "[-_ /]" name (match-end 0)))
+         (setq name (concat (substring name 0 idx) (substring name (1+ idx)))
+               idx (string-match "[-_ /]" name idx))))
+      name)))
 
 (defun coding-system-from-name (name)
   "Return a coding system whose name matches with NAME (string or symbol)."