annotate lisp/w3/mule-sysdp.el @ 16:0293115a14e9 r19-15b91

Import from CVS: tag r19-15b91
author cvs
date Mon, 13 Aug 2007 08:49:20 +0200
parents 9ee227acff29
children 441bb1e64a06
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
1 ;;; mule-sysdp.el --- consolidate MULE-version dependencies in one file.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
2
16
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
3 ;; Copyright (c) 1996, 1997 William Perry
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
4
16
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
5 ;; Author: William Perry <wmperry@cs.indiana.edu>
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
6 ;; Keywords: lisp, tools
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
7
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
8 ;; The purpose of this file is to eliminate the cruftiness that
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
9 ;; would otherwise be required of packages that want to run on multiple
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
10 ;; versions of Emacs with and without Mule support.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
11
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
12 (require 'cl)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
13
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
14 (defconst mule-sysdep-version (if (featurep 'mule)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
15 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
16 ((string-match "XEmacs" emacs-version)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
17 'xemacs)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
18 ((and
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
19 (boundp 'mule-version)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
20 (string-match "[0-9]+\\.[0-9]+"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
21 mule-version))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
22 (string-to-number (substring
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
23 mule-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
24 (match-beginning 0)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
25 (match-end 0))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
26 (t 2.3))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
27 0)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
28 "What version of mule we are running under.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
29
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
30 (defconst mule-retrieval-coding-system
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
31 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
32 (2.3 *euc-japan*)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
33 (2.4 'coding-system-euc-japan)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
34 (xemacs 'euc-japan)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
35 (otherwise nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
36 "Default retrieval coding system for packages that use this package.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
37
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
38 (defconst mule-no-coding-system
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
39 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
40 (2.4 'no-conversion)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
41 (2.3 *noconv*)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
42 (xemacs 'no-conversion)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
43 (otherwise nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
44 "Coding system that means no coding system should be used.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
45
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
46 (defun mule-detect-coding-version (st nd)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
47 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
48 (2.3 (code-detect-region (point-min) (point-max)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
49 (2.4 (detect-coding-region (point-min) (point-max)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
50 (xemacs (detect-coding-region (point-min) (point-max)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
51 (otherwise nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
52
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
53 (defun mule-code-convert-region (st nd code)
16
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
54 (if (and (listp code) (car code))
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
55 (setq code (car code)))
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
56 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
57 (2.3
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
58 (setq mc-flag t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
59 (code-convert-region (point-min) (point-max) code *internal*)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
60 (set-file-coding-system code))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
61 (2.4
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
62 (setq enable-multibyte-characters t)
16
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
63 (if (memq code '(autodetect coding-system-automatic))
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
64 nil
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
65 (decode-coding-region st nd code)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
66 (set-buffer-file-coding-system code)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
67 (xemacs
16
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
68 (if (and (listp code) (not (car code)))
0293115a14e9 Import from CVS: tag r19-15b91
cvs
parents: 14
diff changeset
69 (setq code 'autodetect))
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
70 (decode-coding-region (point-min) (point-max) code)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
71 (set-file-coding-system code))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
72 (otherwise
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
73 nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
74
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
75 (defun mule-inhibit-code-conversion (proc)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
76 (if (process-buffer proc)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
77 (save-excursion
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
78 (set-buffer (process-buffer proc))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
79 (set 'mc-flag nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
80 (set 'enable-multibyte-characters nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
81 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
82 ((2.4 2.3)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
83 (set-process-coding-system proc mule-no-coding-system
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
84 mule-no-coding-system))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
85 (xemacs
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
86 (set-process-input-coding-system proc mule-no-coding-system)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
87 (set-process-input-coding-system proc mule-no-coding-system))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
88
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
89 (defun mule-write-region-no-coding-system (st nd file)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
90 (let ((enable-multibyte-characters t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
91 (coding-system-for-write 'no-conversion)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
92 (file-coding-system mule-no-coding-system)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
93 (buffer-file-coding-system mule-no-coding-system)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
94 (mc-flag t))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
95 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
96 (2.3 (write-region st nd file nil nil nil *noconv*))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
97 (otherwise
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
98 (write-region st nd file)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
99
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
100 (defun mule-encode-string (str)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
101 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
102 (2.3
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
103 (code-convert-string str *internal* mule-retrieval-coding-system))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
104 ((2.4 xemacs)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
105 (encode-coding-string str mule-retrieval-coding-system))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
106 (otherwise
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
107 str)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
108
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
109 (defun mule-decode-string (str)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
110 (and str
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
111 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
112 ((2.4 xemacs)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
113 (decode-coding-string str mule-retrieval-coding-system))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
114 (2.3
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
115 (code-convert-string str *internal* mule-retrieval-coding-system))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
116 (otherwise
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
117 str))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
118
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
119 (defun mule-truncate-string (str len &optional pad)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
120 "Truncate string STR so that string-width of STR is not greater than LEN.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
121 If width of the truncated string is less than LEN, and if a character PAD is
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
122 defined, add padding end of it."
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
123 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
124 (2.4
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
125 (let ((cl (string-to-vector str)) (n 0) (sw 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
126 (if (<= (string-width str) len) str
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
127 (while (<= (setq sw (+ (char-width (aref cl n)) sw)) len)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
128 (setq n (1+ n)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
129 (string-match (make-string n ?.) str)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
130 (setq str (substring str 0 (match-end 0))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
131 (if pad (concat str (make-string (- len (string-width str)) pad)) str)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
132 (2.3
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
133 (let ((cl (string-to-char-list str)) (n 0) (sw 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
134 (if (<= (string-width str) len) str
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
135 (while (<= (setq sw (+ (char-width (nth n cl)) sw)) len)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
136 (setq n (1+ n)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
137 (string-match (make-string n ?.) str)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
138 (setq str (substring str 0 (match-end 0))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
139 (if pad (concat str (make-string (- len (string-width str)) pad)) str)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
140 (otherwise
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
141 (concat (if (> (length str) len) (substring str 0 len) str)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
142 (if (or (null pad) (> (length str) len))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
143 ""
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
144 (make-string (- len (length str)) pad))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
145
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
146 (defun mule-make-iso-character (char)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
147 (if (<= char 127)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
148 char
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
149 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
150 (2.3 (make-character lc-ltn1 char))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
151 (2.4 (make-char charset-latin-iso8859-1 char))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
152 (xemacs char)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
153 (otherwise char))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
154
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
155 (case mule-sysdep-version
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
156 ((2.3 2.4 xemacs) nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
157 (otherwise (fset 'string-width 'length)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
158
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
159 (and
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
160 (boundp 'MULE)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
161 (not (featurep 'mule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
162 (provide 'mule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
163
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
164 (provide 'mule-sysdp)