annotate man/lispref/internationalization.texi @ 5785:7343a186a475

Correct some partial character accounting, buffered_bytecount_to_charcount(). src/ChangeLog addition: 2014-01-23 Aidan Kehoe <kehoea@parhasard.net> * lstream.c (Lstream_read_1): Don't include the unread partial character in unget_character_count, since our consumers will never be aware of it. * text.c: * text.c (buffered_bytecount_to_charcount): A buffer consisting entirely of a partial character needs to be treated as a partial last character, not a partial first character, to avoid double-counting.
author Aidan Kehoe <kehoea@parhasard.net>
date Thu, 23 Jan 2014 13:49:40 +0000
parents a46c5c8d6564
children 9fae6227ede5
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1 @c -*-texinfo-*-
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
2 @c This is part of the XEmacs Lisp Reference Manual.
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
3 @c Copyright (C) 1990, 1991, 1992, 1993 Free Software Foundation, Inc.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
4 @c See the file lispref.texi for copying conditions.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
5 @setfilename ../../info/internationalization.info
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 428
diff changeset
6 @node Internationalization, MULE, PostgreSQL Support, top
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
7 @chapter Internationalization
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
8
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
9 @menu
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
10 * I18N Levels 1 and 2:: Support for different time, date, and currency formats.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
11 * I18N Level 3:: Support for localized messages.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
12 * I18N Level 4:: Support for Asian languages.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
13 @end menu
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
14
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
15
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
16 @node I18N Levels 1 and 2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
17 @section I18N Levels 1 and 2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
18
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
19 XEmacs is now compliant with I18N levels 1 and 2. Specifically, this means
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
20 that it is 8-bit clean and correctly handles time and date functions. XEmacs
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
21 will correctly display the entire ISO-Latin 1 character set.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
22
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
23 The compose key may now be used to create any character in the ISO-Latin 1
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
24 character set not directly available via the keyboard.. In order for the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
25 compose key to work it is necessary to load the file @file{x-compose.el}.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
26 At any time while composing a character, @code{C-h} will display all valid
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
27 completions and the character which would be produced.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
28
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
29
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
30 @node I18N Level 3
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
31 @section I18N Level 3
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
32
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33 @menu
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34 * Level 3 Basics::
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35 * Level 3 Primitives::
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
36 * Dynamic Messaging::
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
37 * Domain Specification::
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
38 @end menu
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
39
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
40 @node Level 3 Basics
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
41 @subsection Level 3 Basics
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
42
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
43 XEmacs now provides alpha-level functionality for I18N Level 3. This means
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
44 that everything necessary for full messaging is available, but not every
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
45 file has been converted.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
46
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
47 The two message files which have been created are @file{src/emacs.po} and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
48 @file{lisp/packages/mh-e.po}. Both files need to be converted using
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
49 @code{msgfmt}, and the resulting @file{.mo} files placed in some locale's
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
50 @code{LC_MESSAGES} directory. The test ``translations'' in these files are
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
51 the original messages prefixed by @code{TRNSLT_}.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
52
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
53 The domain for a variable is stored on the variable's property list under
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
54 the property name @var{variable-domain}. The function
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
55 @code{documentation-property} uses this information when translating a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
56 variable's documentation.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
57
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
58
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
59 @node Level 3 Primitives
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
60 @subsection Level 3 Primitives
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
61
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
62 @defun gettext string
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
63 This function looks up @var{string} in the default message domain and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
64 returns its translation. If @code{I18N3} was not enabled when XEmacs was
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
65 compiled, it just returns @var{string}.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
66 @end defun
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
67
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
68 @defun dgettext domain string
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
69 This function looks up @var{string} in the specified message domain and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
70 returns its translation. If @code{I18N3} was not enabled when XEmacs was
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
71 compiled, it just returns @var{string}.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
72 @end defun
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
73
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
74 @defun bind-text-domain domain pathname
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
75 This function associates a pathname with a message domain.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 Here's how the path to message file is constructed under SunOS 5.x:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79 @code{@{pathname@}/@{LANG@}/LC_MESSAGES/@{domain@}.mo}
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 @end example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
82 If @code{I18N3} was not enabled when XEmacs was compiled, this function does
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
83 nothing.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 @end defun
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85
5547
a46c5c8d6564 Avoid calling various macros "special operators" in the manuals.
Aidan Kehoe <kehoea@parhasard.net>
parents: 5361
diff changeset
86 @defmac domain string
a46c5c8d6564 Avoid calling various macros "special operators" in the manuals.
Aidan Kehoe <kehoea@parhasard.net>
parents: 5361
diff changeset
87 This macro specifies the text domain used for translating documentation
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 strings and interactive prompts of a function. For example, write:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
90 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
91 (defun foo (arg) "Doc string" (domain "emacs-foo") @dots{})
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 @end example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 to specify @code{emacs-foo} as the text domain of the function @code{foo}.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
95 The ``call'' to @code{domain} is actually a declaration rather than a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
96 function; when actually called, @code{domain} just returns @code{nil}.
5547
a46c5c8d6564 Avoid calling various macros "special operators" in the manuals.
Aidan Kehoe <kehoea@parhasard.net>
parents: 5361
diff changeset
97 @end defmac
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
98
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
99 @defun domain-of function
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
100 This function returns the text domain of @var{function}; it returns
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
101 @code{nil} if it is the default domain. If @code{I18N3} was not enabled
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102 when XEmacs was compiled, it always returns @code{nil}.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103 @end defun
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
104
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
105
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 @node Dynamic Messaging
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107 @subsection Dynamic Messaging
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
109 The @code{format} function has been extended to permit you to change the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
110 order of parameter insertion. For example, the conversion format
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111 @code{%1$s} inserts parameter one as a string, while @code{%2$s} inserts
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
112 parameter two. This is useful when creating translations which require you
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 to change the word order.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
114
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
115
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116 @node Domain Specification
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
117 @subsection Domain Specification
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
118
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
119 The default message domain of XEmacs is `emacs'. For add-on packages, it is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
120 best to use a different domain. For example, let us say we want to convert
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
121 the ``gorilla'' package to use the domain `emacs-gorilla'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 To translate the message ``What gorilla?'', use @code{dgettext} as follows:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
124 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
125 (dgettext "emacs-gorilla" "What gorilla?")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
126 @end example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
127
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
128 A function (or macro) which has a documentation string or an interactive
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
129 prompt needs to be associated with the domain in order for the documentation
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
130 or prompt to be translated. This is done with the @code{domain} special
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
131 form as follows:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
132
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
133 @page
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
134 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
135 (defun scratch (location)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
136 "Scratch the specified location."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
137 (domain "emacs-gorilla")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
138 (interactive "sScratch: ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
139 @dots{} )
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
140 @end example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
141
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
142 It is most efficient to specify the domain in the first line of the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
143 function body, before the @code{interactive} form.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
144
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
145 For variables and constants which have documentation strings, specify the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
146 domain after the documentation.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
147
5361
62b9ef1ed4ac Change "special form" to "special operator" in the manuals, too
Aidan Kehoe <kehoea@parhasard.net>
parents: 4894
diff changeset
148 @deffn {Special Operator} defvar symbol [value [doc-string [domain]]]
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
149 Example:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
150 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
151 (defvar weight 250 "Weight of gorilla, in pounds." "emacs-gorilla")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
152 @end example
5361
62b9ef1ed4ac Change "special form" to "special operator" in the manuals, too
Aidan Kehoe <kehoea@parhasard.net>
parents: 4894
diff changeset
153 @end deffn
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
154
5361
62b9ef1ed4ac Change "special form" to "special operator" in the manuals, too
Aidan Kehoe <kehoea@parhasard.net>
parents: 4894
diff changeset
155 @deffn {Special Operator} defconst symbol [value [doc-string [domain]]]
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
156 Example:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
157 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
158 (defconst limbs 4 "Number of limbs" "emacs-gorilla")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
159 @end example
5361
62b9ef1ed4ac Change "special form" to "special operator" in the manuals, too
Aidan Kehoe <kehoea@parhasard.net>
parents: 4894
diff changeset
160 @end deffn
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
162 @defun autoload function filename &optional docstring interactive type
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
163 This function defines @var{function} to autoload from @var{filename}
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
164 Example:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
165 @example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
166 (autoload 'explore "jungle" "Explore the jungle." nil nil "emacs-gorilla")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
167 @end example
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
168 @end defun
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
169
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
170 @node I18N Level 4
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
171 @section I18N Level 4
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
172
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
173 The Asian-language support in XEmacs is called ``MULE''. @xref{MULE}.