From: Kenichi Handa Date: Tue, 16 Jan 2001 10:37:43 +0000 (+0000) Subject: (transform-make-coding-system-args): New function. X-Git-Tag: emacs-pretest-21.0.96~278 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=50c29104d647ceb872c4e2eb91a318118885aa7e;p=emacs.git (transform-make-coding-system-args): New function. (make-coding-system): Accept XEmacs style arguments. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 2c1f60625fd..a2394a12e1f 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -3,7 +3,8 @@ * international/mule.el (decode-char): Fix conditions. (encode-char): Handle eight-bit-control too. (transform-make-coding-system-args): New function. - (make-coding-system): Accept XEmacs style arguments. + (make-coding-system): Accept XEmacs style arguments for CCL base + coding system. 2001-01-15 Gerd Moellmann diff --git a/lisp/international/mule.el b/lisp/international/mule.el index f9e048f2dc9..8896ef24eb4 100644 --- a/lisp/international/mule.el +++ b/lisp/international/mule.el @@ -620,6 +620,33 @@ formats (e.g. iso-latin-1-unix, koi8-r-dos)." (setq i (1+ i))) subsidiaries)) +(defun transform-make-coding-system-args (name type &optional doc-string props) + "For internal use only. +Transform XEmacs style args for `make-coding-system' to Emacs style. +Value is a list of transformed arguments." + (let ((mnemonic (string-to-char (or (plist-get props 'mnemonic) "?"))) + (eol-type (plist-get props 'eol-type)) + properties tmp) + (cond + ((eq eol-type 'lf) (setq eol-type 'unix)) + ((eq eol-type 'crlf) (setq eol-type 'dos)) + ((eq eol-type 'cr) (setq eol-type 'mac))) + (if (setq tmp (plist-get props 'post-read-conversion)) + (setq properties (plist-put properties 'post-read-conversion tmp))) + (if (setq tmp (plist-get props 'pre-write-conversion)) + (setq properties (plist-put properties 'pre-write-conversion tmp))) + (cond + ((eq type 'ccl) + `(,name 4 + ,mnemonic + ,doc-string + (,(plist-get props 'decode) . ,(plist-get props 'encode)) + ,properties + ,eol-type)) + (t + (error "Unsupported XEmacs style arguments for make-coding-style: %S" + `(,name ,type ,doc-string ,props)))))) + (defun make-coding-system (coding-system type mnemonic doc-string &optional flags @@ -714,6 +741,22 @@ treated as a compiled CCL code. 2. If PROPERTIES is just a list of character sets, the list is set as a value of `safe-charsets' in PLIST." + + ;; For compatiblity with XEmacs, we check the type of TYPE. If it + ;; is a symbol, perhaps, this fucntion is called with arguments of + ;; XEmacs style. Here, try to transform that kind of arguments to + ;; Emacs style. + (if (symbolp type) + (let ((args (transform-make-coding-system-args coding-system type + mnemonic doc-string))) + (setq coding-system (car args) + type (nth 1 nargs) + mnemonic (nth 2 args) + doc-string (nth 3 args) + flags (nth 4 args) + properties (nth 5 args) + eol-type (nth 6 args)))) + ;; Set a value of `coding-system' property. (let ((coding-spec (make-vector 5 nil)) (no-initial-designation t)