diff options
author | Kenichi Handa <handa@m17n.org> | 2006-01-16 12:08:35 +0000 |
---|---|---|
committer | Kenichi Handa <handa@m17n.org> | 2006-01-16 12:08:35 +0000 |
commit | 0814ca04aea186499b5cc6a1454b029b71f5a5a3 (patch) | |
tree | 24bdabad7cb202675138ba03c04e50a7c496adfd /lisp/international | |
parent | 8d39b9766e97b53f7ed29d677a46e2cb2f346acf (diff) | |
download | emacs-0814ca04aea186499b5cc6a1454b029b71f5a5a3.tar.gz |
(autoload-coding-system): Prepare for EOL variants.
Diffstat (limited to 'lisp/international')
-rw-r--r-- | lisp/international/mule.el | 47 |
1 files changed, 31 insertions, 16 deletions
diff --git a/lisp/international/mule.el b/lisp/international/mule.el index cd26cd2f73f..b0320ce98d9 100644 --- a/lisp/international/mule.el +++ b/lisp/international/mule.el @@ -1144,7 +1144,11 @@ Return the resulting coding system." FROM is a form to evaluate to define the coding-system." (put symbol 'coding-system-define-form form) (setq coding-system-alist (cons (list (symbol-name symbol)) - coding-system-alist))) + coding-system-alist)) + (dolist (elt '("-unix" "-dos" "-mac")) + (let ((name (concat (symbol-name symbol) elt))) + (put (intern name) 'coding-system-define-form form) + (setq coding-system-alist (cons (list name) coding-system-alist))))) (defun set-buffer-file-coding-system (coding-system &optional force nomodify) "Set the file coding-system of the current buffer to CODING-SYSTEM. @@ -1589,6 +1593,23 @@ and the contents of `file-coding-system-alist'." :type '(repeat (cons (regexp :tag "Regexp") (symbol :tag "Coding system")))) +(defun auto-coding-regexp-alist-lookup (from to) + "Lookup `auto-coding-regexp-alist' for the contents of the current buffer. +The value is a coding system is specified for the region FROM and TO, +or nil." + (save-excursion + (goto-char from) + (let ((alist auto-coding-regexp-alist) + coding-system) + (while (and alist (not coding-system)) + (let ((regexp (car (car alist)))) + (if enable-multibyte-characters + (setq regexp (string-to-multibyte regexp))) + (if (re-search-forward regexp to t) + (setq coding-system (cdr (car alist))) + (setq alist (cdr alist))))) + coding-system))) + ;; See the bottom of this file for built-in auto coding functions. (defcustom auto-coding-functions '(sgml-xml-auto-coding-function sgml-html-meta-auto-coding-function) @@ -1648,24 +1669,15 @@ indicating by what CODING is specified. Note that the validity of CODING is not checked; it's callers responsibility to check it. -If nothing is specified, the return value is nil. - -The variable `set-auto-coding-function' (which see) is set to this -function by default." +If nothing is specified, the return value is nil." (or (let ((coding-system (auto-coding-alist-lookup filename))) (if coding-system (cons coding-system 'auto-coding-alist))) ;; Try using `auto-coding-regexp-alist'. - (save-excursion - (let ((alist auto-coding-regexp-alist) - coding-system) - (while (and alist (not coding-system)) - (let ((regexp (car (car alist)))) - (when (re-search-forward regexp (+ (point) size) t) - (setq coding-system (cdr (car alist))))) - (setq alist (cdr alist))) - (if coding-system - (cons coding-system 'auto-coding-regexp-alist)))) + (let ((coding-system (auto-coding-regexp-alist-lookup (point) + (+ (point) size)))) + (if coding-system + (cons coding-system 'auto-coding-regexp-alist))) (let* ((case-fold-search t) (head-start (point)) (head-end (+ head-start (min size 1024))) @@ -1758,7 +1770,10 @@ function by default." (defun set-auto-coding (filename size) "Return coding system for a file FILENAME of which SIZE bytes follow point. See `find-auto-coding' for how the coding system is found. -Return nil if an invalid coding system is found." +Return nil if an invalid coding system is found. + +The variable `set-auto-coding-function' (which see) is set to this +function by default." (let ((found (find-auto-coding filename size))) (if (and found (coding-system-p (car found))) (car found)))) |