* utf7.el (toplevel): Check the ucs features dynamically.
authorteranisi <teranisi>
Sun, 24 Nov 2002 13:12:38 +0000 (13:12 +0000)
committerteranisi <teranisi>
Sun, 24 Nov 2002 13:12:38 +0000 (13:12 +0000)
(Advice from Yoichi NAKAYAMA  <yoichi@eken.phys.nagoya-u.ac.jp>)

elmo/ChangeLog
elmo/utf7.el

index ac74ed7..2d2076e 100644 (file)
@@ -1,3 +1,8 @@
+2002-11-24  Yuuichi Teranishi  <teranisi@gohome.org>
+
+       * utf7.el (toplevel): Check the ucs features dynamically.
+       (Advice from Yoichi NAKAYAMA  <yoichi@eken.phys.nagoya-u.ac.jp>)
+
 2002-11-21  Yuuichi Teranishi  <teranisi@gohome.org>
 
        * elmo-nntp.el (elmo-nntp-search-primitive): Revert the last change.
index 81e66ee..31702d7 100644 (file)
   "Return required length of padding for IMAP modified base64 fragment."
   (mod (- len) modulus))
 
-(static-cond
+(cond
+ ((or (find-coding-system 'utf-7)
+      (module-installed-p 'un-define))
+  (defun utf7-fragment-decode (start end &optional imap)
+    "Decode base64 encoded fragment from START to END of UTF-7 text in buffer.
+Use IMAP modification if IMAP is non-nil."
+    (require 'un-define)
+    (save-restriction
+      (narrow-to-region start end)
+      (goto-char (point-min))
+      (insert "+")
+      (when imap
+       (goto-char start)
+       (while (search-forward "," nil 'move-to-end) (replace-match "/")))
+      (decode-coding-region (point-min) (point-max) 'utf-7)))
+
+  (defun utf7-fragment-encode (start end &optional imap)
+    "Encode text from START to END in buffer as UTF-7 escape fragment.
+Use IMAP modification if IMAP is non-nil."
+    (require 'un-define)
+    (let ((buffer (current-buffer))
+         encoded-string)
+      (setq encoded-string
+           (with-temp-buffer
+             (insert-buffer-substring buffer start end)
+             (encode-coding-region (point-min) 
+                                   (point-max) 'utf-7)
+             (goto-char (point-min))
+             (when imap
+               (skip-chars-forward "+")
+               (delete-region (point-min) (point))
+               (insert "&")
+               (while (search-forward "/" nil t)
+                 (replace-match ",")))
+             (skip-chars-forward "^= \t\n" (point-max))
+             (delete-region (point) (point-max))
+             (buffer-string)))
+      (delete-region start end)
+      (insert encoded-string))))
  ((and (featurep 'xemacs) 
-       (module-installed-p 'xemacs-ucs))
+       (or (find-coding-system 'utf-8)
+          (module-installed-p 'xemacs-ucs)))
   (defun utf7-fragment-decode (start end &optional imap)
     "Decode base64 encoded fragment from START to END of UTF-7 text in buffer.
 Use IMAP modification if IMAP is non-nil."  
@@ -105,7 +144,7 @@ Use IMAP modification if IMAP is non-nil."
                            utf7-utf7-to-utf8-program
                            t (current-buffer)))
       (decode-coding-region (point-min) (point-max) 'utf-8)))
-
+  
   (defun utf7-fragment-encode (start end &optional imap)
     "Decode base64 encoded fragment from START to END of UTF-7 text in buffer.
 Use IMAP modification if IMAP is non-nil."  
@@ -136,54 +175,17 @@ Use IMAP modification if IMAP is non-nil."
              (buffer-string)))
       (delete-region start end)
       (insert encoded-string))))
- ((module-installed-p 'un-define) ;; Emacs
-  (defun utf7-fragment-decode (start end &optional imap)
-    "Decode base64 encoded fragment from START to END of UTF-7 text in buffer.
-Use IMAP modification if IMAP is non-nil."
-    (require 'un-define)
-    (save-restriction
-      (narrow-to-region start end)
-      (goto-char (point-min))
-      (insert "+")
-      (when imap
-       (goto-char start)
-       (while (search-forward "," nil 'move-to-end) (replace-match "/")))
-      (decode-coding-region (point-min) (point-max) 'utf-7)
-      ))
-
-  (defun utf7-fragment-encode (start end &optional imap)
-    "Encode text from START to END in buffer as UTF-7 escape fragment.
-Use IMAP modification if IMAP is non-nil."
-    (require 'un-define)
-    (let ((buffer (current-buffer))
-         encoded-string)
-      (setq encoded-string
-           (with-temp-buffer
-             (insert-buffer-substring buffer start end)
-             (encode-coding-region (point-min) 
-                                   (point-max) 'utf-7)
-             (goto-char (point-min))
-             (when imap
-               (skip-chars-forward "+")
-               (delete-region (point-min) (point))
-               (insert "&")
-               (while (search-forward "/" nil t)
-                 (replace-match ",")))
-             (skip-chars-forward "^= \t\n" (point-max))
-             (delete-region (point) (point-max))
-             (buffer-string)))
-      (delete-region start end)
-      (insert encoded-string))))
  (t
-  ;; Define as null function.
   (defun utf7-fragment-decode (start end &optional imap)
     "Encode text from START to END in buffer as UTF-7 escape fragment.
 Use IMAP modification if IMAP is non-nil."
+    ;; Define as a null function.
     )
 
   (defun utf7-fragment-encode (start end &optional imap)
     "Encode text from START to END in buffer as UTF-7 escape fragment.
 Use IMAP modification if IMAP is non-nil."
+    ;; Define as a null function.
     )))
 
 (defun utf7-encode-region (start end &optional imap)