2000-01-19 23:07:23 +00:00
|
|
|
\section{Writing non-English applications}\label{nonenglishoverview}
|
|
|
|
|
|
|
|
This article describes how to write applications that communicate with
|
|
|
|
user in language other than English. Unfortunately many languages use
|
|
|
|
different charsets under Unix and Windows (and other platforms, to make
|
|
|
|
situation even more complicated). These charsets usually differ in so
|
|
|
|
many characters it is impossible to use same texts under all platforms.
|
|
|
|
wxWindows provide mechanism that helps you avoid distributing many
|
|
|
|
identical, only differently encoded, packages with your application
|
|
|
|
(e.g. help files and menu items in iso8859-13 and windows-1257). Thanks
|
2000-07-15 19:51:35 +00:00
|
|
|
to this mechanism you can, for example, distribute only iso8859-13 data
|
2000-01-19 23:07:23 +00:00
|
|
|
and it will be handled transparently under all systems.
|
|
|
|
|
2000-01-21 22:58:18 +00:00
|
|
|
Please read \helpref{Internationalization}{internationalization} which
|
2000-07-15 19:51:35 +00:00
|
|
|
describes the locales concept.
|
2000-01-19 23:07:23 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
In the following text, wherever {\it iso8859-2} and {\it windows-1250} are
|
2000-01-19 23:07:23 +00:00
|
|
|
used, any encodings are meant and any encodings may be substituted there.
|
|
|
|
|
|
|
|
\wxheading{Locales}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
The best way to ensure correctly displayed texts in a GUI across platforms
|
2000-01-21 22:58:18 +00:00
|
|
|
is to use locales. Write your in-code messages in English or without
|
2000-07-15 19:51:35 +00:00
|
|
|
diacritics and put real messages into the message catalog (see
|
2000-01-21 22:58:18 +00:00
|
|
|
\helpref{Internationalization}{internationalization}).
|
2000-01-19 23:07:23 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
A standard .po file begins with a header like this:
|
2000-01-21 22:58:18 +00:00
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
# SOME DESCRIPTIVE TITLE.
|
|
|
|
# Copyright (C) YEAR Free Software Foundation, Inc.
|
|
|
|
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
|
|
|
|
#
|
|
|
|
#, fuzzy
|
|
|
|
msgid ""
|
|
|
|
msgstr ""
|
|
|
|
"Project-Id-Version: PACKAGE VERSION\n"
|
|
|
|
"POT-Creation-Date: 1999-02-19 16:03+0100\n"
|
|
|
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
|
|
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
|
|
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
|
|
|
"MIME-Version: 1.0\n"
|
|
|
|
"Content-Type: text/plain; charset=CHARSET\n"
|
|
|
|
"Content-Transfer-Encoding: ENCODING\n"
|
|
|
|
\end{verbatim}
|
|
|
|
|
|
|
|
Notice these two lines:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
#, fuzzy
|
|
|
|
"Content-Type: text/plain; charset=CHARSET\n"
|
|
|
|
\end{verbatim}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
The first tells the {\it msgfmt} compiler not to include "" (the empty string)
|
|
|
|
in compiled .mo catalog. The second one specifies the charset used to write
|
2000-01-21 22:58:18 +00:00
|
|
|
translated messages.
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
You have to do two things: fill in proper charset information and delete
|
2000-01-21 22:58:18 +00:00
|
|
|
the {\tt fuzzy} line. Your .po file may look like this after doing so:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
# SOME DESCRIPTIVE TITLE.
|
|
|
|
# Copyright (C) YEAR Free Software Foundation, Inc.
|
|
|
|
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
|
|
|
|
#
|
|
|
|
msgid ""
|
|
|
|
msgstr ""
|
|
|
|
"Project-Id-Version: PACKAGE VERSION\n"
|
|
|
|
"POT-Creation-Date: 1999-02-19 16:03+0100\n"
|
|
|
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
|
|
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
|
|
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
|
|
|
"MIME-Version: 1.0\n"
|
|
|
|
"Content-Type: text/plain; charset=iso8859-2\n"
|
|
|
|
"Content-Transfer-Encoding: ENCODING\n"
|
|
|
|
\end{verbatim}
|
|
|
|
|
|
|
|
wxWindows is able to use this catalog under any supported platform
|
2000-07-15 19:51:35 +00:00
|
|
|
(although iso8859-2 is a Unix encoding and is not understood by Windows).
|
2000-01-21 22:58:18 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
How is this done? When you tell the wxLocale class to load a message catalog that
|
|
|
|
contains the header (msgid ""; normal .mo catalogs do {\bf not} contain it,
|
2000-01-21 22:58:18 +00:00
|
|
|
you must remove the line with {\it fuzzy}!), it checks the charset. If the
|
|
|
|
charset is "alien" on the platform the program is currently running (e.g.
|
2000-07-15 19:51:35 +00:00
|
|
|
any of ISO encodings under Windows or CP12XX under Unix) it uses
|
2000-01-21 22:58:18 +00:00
|
|
|
\helpref{wxEncodingConverter::GetPlatformEquivalents}{wxencodingconvertergetplatformequivalents}
|
2000-07-15 19:51:35 +00:00
|
|
|
to obtain an encoding that is more common on this platform and converts
|
2000-01-21 22:58:18 +00:00
|
|
|
the message catalog to this encoding. Note that it does {\bf not} check
|
|
|
|
for presence of this encoding! It only assumes that it is always better to
|
|
|
|
have strings in platform native encoding than in an encoding that is rarely
|
|
|
|
(if ever) used.
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
The behaviour described above is disabled by default.
|
2000-01-21 22:58:18 +00:00
|
|
|
You must set {\it bConvertEncoding} to TRUE in
|
|
|
|
\helpref{wxLocale constructor}{wxlocaledefctor} in order to enable
|
2000-07-15 19:51:35 +00:00
|
|
|
runtime encoding conversion.
|
2000-01-19 23:07:23 +00:00
|
|
|
|
|
|
|
\wxheading{Font mapping}
|
|
|
|
|
2000-03-18 09:20:21 +00:00
|
|
|
You can use \helpref{wxEncodingConverter}{wxencodingconverter} and
|
2000-01-21 22:58:18 +00:00
|
|
|
\helpref{wxFontMapper}{wxfontmapper} to display text:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
if (!wxTheFontMapper->IsEncodingAvailable(enc, facename))
|
|
|
|
{
|
|
|
|
wxFontEncoding alternative;
|
|
|
|
if (wxTheFontMapper->GetAltForEncoding(enc, &alternative,
|
|
|
|
facename, FALSE))
|
|
|
|
{
|
|
|
|
wxEncodingConverted encconv;
|
|
|
|
if (!encconv.Init(enc, alternative))
|
|
|
|
...failure...
|
|
|
|
else
|
|
|
|
text = encconv.Convert(text);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
...failure...
|
|
|
|
}
|
|
|
|
...display text...
|
|
|
|
\end{verbatim}
|
|
|
|
|
|
|
|
\wxheading{Converting data}
|
|
|
|
|
|
|
|
You may want to store all program data (created documents etc.) in
|
2000-07-15 19:51:35 +00:00
|
|
|
the same encoding, let's say windows1250. Obviously, the best way would
|
2000-01-21 22:58:18 +00:00
|
|
|
be to use \helpref{wxEncodingConverter}{wxencodingconverter}.
|
|
|
|
|
2000-01-19 23:07:23 +00:00
|
|
|
\wxheading{Help files}
|
|
|
|
|
|
|
|
If you're using \helpref{wxHtmlHelpController}{wxhtmlhelpcontroller} there is
|
2000-07-15 19:51:35 +00:00
|
|
|
no problem at all. You must only make sure that all the HTML files contain
|
|
|
|
the META tag, e.g.
|
2000-01-19 23:07:23 +00:00
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
<meta http-equiv="Content-Type" content="iso8859-2">
|
|
|
|
\end{verbatim}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
and that the hhp project file contains one additional line in the {\tt OPTIONS}
|
2000-01-19 23:07:23 +00:00
|
|
|
section:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
Charset=iso8859-2
|
|
|
|
\end{verbatim}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
This additional entry tells the HTML help controller what encoding is used
|
2000-01-19 23:07:23 +00:00
|
|
|
in contents and index tables.
|
2000-02-06 19:11:10 +00:00
|
|
|
|