Mercurial > emacs
view lisp/language/european.el @ 27018:c56e0e887ba4
(struct display_info): New.
(struct x_output): Add the display_info member.
(FRAME_X_DISPLAY_INFO): New macro.
author | Eli Zaretskii <eliz@gnu.org> |
---|---|
date | Tue, 28 Dec 1999 15:56:29 +0000 |
parents | 86441316f662 |
children | 2dbedede8507 |
line wrap: on
line source
;;; european.el --- European languages -*- coding: iso-2022-7bit; -*- ;; Copyright (C) 1995, 1997 Electrotechnical Laboratory, JAPAN. ;; Licensed to the Free Software Foundation. ;; Keywords: multilingual, European ;; This file is part of GNU Emacs. ;; GNU Emacs is free software; you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 2, or (at your option) ;; any later version. ;; GNU Emacs is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with GNU Emacs; see the file COPYING. If not, write to the ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, ;; Boston, MA 02111-1307, USA. ;;; Commentary: ;; For Europeans, character sets ISO8859-1,2,3,4,9,14,15 are supported. ;;; Code: ;; Latin-1 (ISO-8859-1) (make-coding-system 'iso-latin-1 2 ?1 "ISO 2022 based 8-bit encoding for Latin-1 (MIME:ISO-8859-1)" '(ascii latin-iso8859-1 nil nil nil nil nil nil nil nil nil nil nil nil nil nil t) '((safe-charsets ascii latin-iso8859-1) (mime-charset . iso-8859-1))) (define-coding-system-alias 'iso-8859-1 'iso-latin-1) (define-coding-system-alias 'latin-1 'iso-latin-1) (make-coding-system 'compound-text 2 ?1 "ISO 2022 based encoding used in inter client communication of X" '((ascii t) (latin-iso8859-1 t) nil nil nil ascii-eol ascii-cntl nil nil nil nil nil nil nil nil nil t) '((safe-charsets . t))) (define-coding-system-alias 'ctext 'compound-text) (defun setup-latin1-environment () "Set up multilingual environment (MULE) for European Latin-1 users." (interactive) (set-language-environment "Latin-1")) (set-language-info-alist "Latin-1" '((charset ascii latin-iso8859-1) (coding-system iso-latin-1) (coding-priority iso-latin-1) (nonascii-translation . latin-iso8859-1) (unibyte-syntax . "latin-1") (unibyte-display . iso-latin-1) (input-method . "latin-1-prefix") (sample-text . "Hello, Hej, Tere, Hei, Bonjour, Gr,A|_(B Gott, Ciao, ,A!(BHola!") (documentation . "\ This language environment is a generic one for the Latin-1 (ISO-8859-1) character set which supports the following European languages: Albanian, Basque, Breton, Catalan, Danish, Dutch, English, Faeroese, Finnish, French (with restrictions -- see Latin-9), Frisian, Galician, German, Greenlandic, Icelandic, Irish Gaelic (new orthography), Italian, Latin, Luxemburgish, Norwegian, Portuguese, Rhaeto-Romanic, Scottish Gaelic, Spanish, and Swedish. We also have a German specific language environment \"German\". Latin-1 also covers several written languages outside Europe, including Indonesian/Malay, Tagalog (Philippines), Swahili and Afrikaans.")) '("European")) ;; Latin-2 (ISO-8859-2) (make-coding-system 'iso-latin-2 2 ?2 "ISO 2022 based 8-bit encoding (MIME:ISO-8859-2)" '(ascii latin-iso8859-2 nil nil nil nil nil nil nil nil nil) '((safe-charsets ascii latin-iso8859-2) (mime-charset . iso-8859-2))) (define-coding-system-alias 'iso-8859-2 'iso-latin-2) (define-coding-system-alias 'latin-2 'iso-latin-2) (defun setup-latin2-environment () "Set up multilingual environment (MULE) for European Latin-2 users." (interactive) (set-language-environment "Latin-2")) (set-language-info-alist "Latin-2" '((charset ascii latin-iso8859-2) (coding-system iso-latin-2) (coding-priority iso-latin-2) (nonascii-translation . latin-iso8859-2) (unibyte-syntax . "latin-2") (unibyte-display . iso-latin-2) (input-method . "latin-2-prefix") (documentation . "\ This language environment is a generic one for the Latin-2 (ISO-8859-2) character set which supports the following languages: Albanian, Czech, English, German, Hungarian, Polish, Romanian, Serbo-Croatian or Croatian, Slovak, Slovene, Sorbian (upper and lower), and Swedish. We also have specific language environments for the following languages: For Czech, \"Czech\". For Romanian, \"Romanian\". For Slovak, \"Slovak\".")) '("European")) ;; Latin-3 (ISO-8859-3) (make-coding-system 'iso-latin-3 2 ?3 "ISO 2022 based 8-bit encoding (MIME:ISO-8859-3)" '(ascii latin-iso8859-3 nil nil nil nil nil nil nil nil nil) '((safe-charsets ascii latin-iso8859-3) (mime-charset . iso-8859-3))) (define-coding-system-alias 'iso-8859-3 'iso-latin-3) (define-coding-system-alias 'latin-3 'iso-latin-3) (defun setup-latin3-environment () "Set up multilingual environment (MULE) for European Latin-3 users." (interactive) (set-language-environment "Latin-3")) (set-language-info-alist "Latin-3" '((charset ascii latin-iso8859-3) (coding-system iso-latin-3) (coding-priority iso-latin-3) (nonascii-translation . latin-iso8859-3) (unibyte-syntax . "latin-3") (unibyte-display . iso-latin-3) (input-method . "latin-3-prefix") (documentation . "\ These languages are supported with the Latin-3 (ISO-8859-3) character set: Afrikaans, Catalan, Dutch, English, Esperanto, French, Galician, German, Italian, Maltese, Spanish, and Turkish.")) '("European")) ;; Latin-4 (ISO-8859-4) (make-coding-system 'iso-latin-4 2 ?4 "ISO 2022 based 8-bit encoding (MIME:ISO-8859-4)" '(ascii latin-iso8859-4 nil nil nil nil nil nil nil nil nil) '((safe-charsets ascii latin-iso8859-4) (mime-charset . iso-8895-4))) (define-coding-system-alias 'iso-8859-4 'iso-latin-4) (define-coding-system-alias 'latin-4 'iso-latin-4) (defun setup-latin4-environment () "Set up multilingual environment (MULE) for European Latin-4 users." (interactive) (set-language-environment "Latin-4")) (set-language-info-alist "Latin-4" '((charset ascii latin-iso8859-4) (coding-system iso-8859-4) (coding-priority iso-8859-4) (nonascii-translation . latin-iso8859-4) (unibyte-syntax . "latin-4") (unibyte-display . iso-8859-4) (input-method . "latin-4-prefix") (documentation . "\ These languages are supported with the Latin-4 (ISO-8859-4) character set: Danish, English, Estonian, Finnish, German, Greenlandic, Lappish, Latvian, Lithuanian, and Norwegian.")) '("European")) ;; Latin-5 (ISO-8859-9) (make-coding-system 'iso-latin-5 2 ?9 "ISO 2022 based 8-bit encoding (MIME:ISO-8859-9)" '(ascii latin-iso8859-9 nil nil nil nil nil nil nil nil nil) '((safe-charsets ascii latin-iso8859-9) (mime-charset . iso-8859-9))) (define-coding-system-alias 'iso-8859-9 'iso-latin-5) (define-coding-system-alias 'latin-5 'iso-latin-5) (defun setup-latin5-environment () "Set up multilingual environment (MULE) for European Latin-5 users." (interactive) (set-language-environment "Latin-5")) (set-language-info-alist "Latin-5" '((charset ascii latin-iso8859-9) (coding-system iso-latin-5) (coding-priority iso-latin-5) (nonascii-translation . latin-iso8859-9) (unibyte-syntax . "latin-5") (unibyte-display . iso-latin-5) (input-method . "latin-5-prefix") (documentation . "\ These languages are supported with the Latin-5 (ISO-8859-9) character set: Bulgarian, Byelorussian, (Slavic) Macedonian, Russian, Serbian and Ukranian.")) ; says ISO 8859-1 '("European")) ;; Latin-8 (ISO-8859-14) (make-coding-system 'iso-latin-8 2 ?W ; `W' for `Welsh', since `C' ; for `Celtic' is taken. "ISO 2022 based 8-bit encoding for Latin-8 (MIME:ISO-8859-14)" '(ascii latin-iso8859-14 nil nil nil nil nil nil nil nil nil nil nil nil nil nil t) '((safe-charsets ascii latin-iso8859-14) (mime-charset . iso-8859-14))) (define-coding-system-alias 'iso-8859-14 'iso-latin-8) (define-coding-system-alias 'latin-8 'iso-latin-8) (defun setup-latin8-environment () "Set up multilingual environment (MULE) for European Latin-8 users." (interactive) (set-language-environment "latin-8")) (set-language-info-alist "Latin-8" '((charset ascii latin-iso8859-14) (coding-system iso-latin-8) (coding-priority iso-latin-8) (nonascii-translation . latin-iso8859-14) (unibyte-syntax . "latin-8") (unibyte-display . iso-latin-8) (input-method . "latin-1-prefix") ; fixme ;;; Fixme: Welsh/Ga{e}lic greetings ;;; (sample-text ;;; . "") (documentation . "\ This language environment is a generic one for the Latin-8 (ISO-8859-14) character set which supports the Celtic languages which are not covered by other ISO-8859 character sets, specifically Welsh, Manx Gaelic and Irish Gaelic (old orthography).")) '("European")) ;; Latin-9 (ISO-8859-15) (make-coding-system 'iso-latin-9 2 ?0 ; `0' for `Latin-0' "ISO 2022 based 8-bit encoding for Latin-9 (MIME:ISO-8859-15)" '(ascii latin-iso8859-15 nil nil nil nil nil nil nil nil nil nil nil nil nil nil t) '((safe-charsets ascii latin-iso8859-15) (mime-charset . iso-8859-15))) (define-coding-system-alias 'iso-8859-15 'iso-latin-9) (define-coding-system-alias 'latin-9 'iso-latin-9) (define-coding-system-alias 'latin-0 'iso-latin-9) (defun setup-latin9-environment () "Set up multilingual environment (MULE) for European Latin-9 users." (interactive) (set-language-environment "latin-9")) (set-language-info-alist "Latin-9" '((charset ascii latin-iso8859-15) (coding-system iso-latin-9) (coding-priority iso-latin-9) (nonascii-translation . latin-iso8859-15) (unibyte-syntax . "latin-9") (unibyte-display . iso-latin-9) (input-method . "latin-1-prefix") ; fixme? (sample-text . "Ave Latinum IX, ,b&(48<=>(B ,b$$$(B") (documentation . "\ This language environment is a generic one for the Latin-9 (ISO-8859-15) character set which supports the same languages as Latin-1 with the addition of the Euro sign and some additional French and Finnish letters. Latin-9 is sometimes nicknamed `Latin-0'.")) '("European")) (defun setup-german-environment () "Set up multilingual environment (MULE) for German users." (interactive) (set-language-environment "German")) (set-language-info-alist "German" '((tutorial . "TUTORIAL.de") (charset ascii latin-iso8859-1) (coding-system iso-latin-1) (coding-priority iso-latin-1) (input-method . "german-postfix") (nonascii-translation . iso-latin-1) (unibyte-syntax . "latin-1") (unibyte-display . iso-latin-1) (sample-text . "\ German (Deutsch Nord) Guten Tag German (Deutsch S,A|(Bd) Gr,A|_(B Gott") (documentation . "\ This language environment is almost the same as Latin-1, but default input method is set to \"german-postfix\".")) '("European")) (defun setup-slovenian-environment () "Setup multilingual environment (MULE) for Slovenian." (interactive) (set-language-environment "Slovenian")) (set-language-info-alist "Slovenian" '((charset . (ascii latin-iso8859-2)) (coding-system . (iso-8859-2)) (coding-priority . (iso-8859-2)) (nonascii-translation . latin-iso8859-2) (input-method . "latin-2-postfix") (unibyte-syntax . "latin-2") (unibyte-display . iso-8859-2) (tutorial . "TUTORIAL.sl") (sample-text . ",B.(Belimo vam uspe,B9(Ben dan!") (documentation . t)) '("European")) ;; For Turkish, the character set ISO-8859-9 (Latin-5) is used. But, ;; before the introduction of ISO-8859-9 in 1988, ISO-8859-3 (Latin-3) ;; was used for Turkish. Those who use Latin-3 for Turkish should use ;; "Latin-3" language environment. (set-language-info-alist "Turkish" '((charset ascii latin-iso8859-9) (coding-system iso-latin-5) (coding-priority iso-latin-5) (nonascii-translation . latin-iso8859-9) (unibyte-syntax . "latin-5") (unibyte-display . iso-latin-5) (input-method . "turkish-postfix") (sample-text . "Turkish (T,M|(Brk,Mg(Be) Merhaba") (documentation . t))) ;;; european.el ends here