]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/intl.h
rewrite using type safe wxHashMap instead of wxObject-based wxHashTable
[wxWidgets.git] / interface / wx / intl.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: intl.h
e54c96f1 3// Purpose: interface of wxLocale
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxLocale
7c913512 11
23324ae1
FM
12 wxLocale class encapsulates all language-dependent settings and is a
13 generalization of the C locale concept.
7c913512 14
23324ae1
FM
15 In wxWidgets this class manages message catalogs which contain the translations
16 of the strings used to the current language.
7c913512 17
23324ae1 18 @b wxPerl note: In wxPerl you can't use the '_' function name, so
7c913512
FM
19 the @c Wx::Locale module can export the @c gettext and
20 @c gettext_noop under any given name.
21
23324ae1
FM
22 @code
23 # this imports gettext ( equivalent to Wx::GetTranslation
24 # and gettext_noop ( a noop )
25 # into your module
26 use Wx::Locale qw(:default);
7c913512 27
23324ae1 28 # ....
7c913512 29
23324ae1 30 # use the functions
cdbcf4c2 31 print gettext( "Panic!" );
7c913512 32
cdbcf4c2 33 button = Wx::Button-new( window, -1, gettext( "Label" ) );
23324ae1 34 @endcode
7c913512 35
23324ae1
FM
36 If you need to translate a lot of strings, then adding gettext( ) around
37 each one is a long task ( that is why _( ) was introduced ), so just choose
38 a shorter name for gettext:
7c913512 39
23324ae1
FM
40 @code
41 #
42 use Wx::Locale 'gettext' = 't',
43 'gettext_noop' = 'gettext_noop';
7c913512 44
23324ae1 45 # ...
7c913512 46
23324ae1 47 # use the functions
cdbcf4c2 48 print t( "Panic!!" );
7c913512 49
23324ae1
FM
50 # ...
51 @endcode
7c913512 52
23324ae1
FM
53 @library{wxbase}
54 @category{FIXME}
7c913512 55
e54c96f1 56 @see @ref overview_internationalization, @ref overview_sampleinternat "Internat
4cc4bfaf 57 sample", wxXLocale
23324ae1 58*/
7c913512 59class wxLocale
23324ae1
FM
60{
61public:
62 //@{
63 /**
64 See Init() for parameters description.
23324ae1
FM
65 The call of this function has several global side effects which you should
66 understand: first of all, the application locale is changed - note that this
67 will affect many of standard C library functions such as printf() or strftime().
68 Second, this wxLocale object becomes the new current global locale for the
69 application and so all subsequent calls to wxGetTranslation() will try to
70 translate the messages using the message catalogs for this locale.
71 */
72 wxLocale();
7c913512
FM
73 wxLocale(int language,
74 int flags =
75 wxLOCALE_LOAD_DEFAULT | wxLOCALE_CONV_ENCODING);
76 wxLocale(const wxString& name,
77 const wxString& short = wxEmptyString,
78 const wxString& locale = wxEmptyString,
4cc4bfaf
FM
79 bool bLoadDefault = true,
80 bool bConvertEncoding = false);
23324ae1
FM
81 //@}
82
83 /**
84 The destructor, like the constructor, also has global side effects: the
85 previously
7c913512 86 set locale is restored and so the changes described in
23324ae1
FM
87 Init() documentation are rolled back.
88 */
adaaa686 89 virtual ~wxLocale();
23324ae1
FM
90
91 //@{
92 /**
93 Add a catalog for use with the current locale: it is searched for in standard
94 places (current directory first, then the system one), but you may also prepend
7c913512 95 additional directories to the search path with
23324ae1 96 AddCatalogLookupPathPrefix().
23324ae1
FM
97 All loaded catalogs will be used for message lookup by
98 GetString() for the current locale.
23324ae1
FM
99 Returns @true if catalog was successfully loaded, @false otherwise (which might
100 mean that the catalog is not found or that it isn't in the correct format).
23324ae1 101 The second form of this method takes two additional arguments,
4cc4bfaf
FM
102 @a msgIdLanguage and @e msgIdCharset.
103 @a msgIdLanguage specifies the language of "msgid" strings in source code
23324ae1 104 (i.e. arguments to GetString(),
e54c96f1
FM
105 wxGetTranslation() and the
106 _() macro). It is used if AddCatalog cannot find any
23324ae1 107 catalog for current language: if the language is same as source code language,
7c913512 108 then strings from source code are used instead.
4cc4bfaf 109 @a msgIdCharset lets you specify the charset used for msgids in sources
23324ae1
FM
110 in case they use 8-bit characters (e.g. German or French strings). This
111 argument has no effect in Unicode build, because literals in sources are
112 Unicode strings; you have to use compiler-specific method of setting the right
113 charset when compiling with Unicode.
23324ae1
FM
114 By default (i.e. when you use the first form), msgid strings are assumed
115 to be in English and written only using 7-bit ASCII characters.
23324ae1 116 If you have to deal with non-English strings or 8-bit characters in the source
7c913512 117 code, see the instructions in
23324ae1
FM
118 @ref overview_nonenglishoverview "Writing non-English applications".
119 */
120 bool AddCatalog(const wxString& domain);
7c913512
FM
121 bool AddCatalog(const wxString& domain,
122 wxLanguage msgIdLanguage,
123 const wxString& msgIdCharset);
23324ae1
FM
124 //@}
125
126 /**
127 Add a prefix to the catalog lookup path: the message catalog files will be
128 looked up under prefix/lang/LC_MESSAGES, prefix/lang and prefix
129 (in this order).
23324ae1
FM
130 This only applies to subsequent invocations of AddCatalog().
131 */
adaaa686 132 static void AddCatalogLookupPathPrefix(const wxString& prefix);
23324ae1
FM
133
134 /**
135 Adds custom, user-defined language to the database of known languages. This
7c913512
FM
136 database is used in conjunction with the first form of
137 Init().
23324ae1 138 wxLanguageInfo is defined as follows:
23324ae1 139 @e Language should be greater than wxLANGUAGE_USER_DEFINED.
23324ae1
FM
140 Wx::LanguageInfo-new( language, canonicalName, WinLang, WinSubLang, Description
141 )
142 */
143 static void AddLanguage(const wxLanguageInfo& info);
144
145 /**
146 This function may be used to find the language description structure for the
147 given locale, specified either as a two letter ISO language code (for example,
148 "pt"), a language code followed by the country code ("pt_BR") or a full, human
149 readable, language description ("Portuguese-Brazil").
23324ae1
FM
150 Returns the information for the given language or @NULL if this language
151 is unknown. Note that even if the returned pointer is valid, the caller should
152 @e not delete it.
3c4f71cc 153
4cc4bfaf 154 @see GetLanguageInfo()
23324ae1 155 */
4cc4bfaf 156 static wxLanguageInfo* FindLanguageInfo(const wxString& locale);
23324ae1
FM
157
158 /**
159 Returns the canonical form of current locale name. Canonical form is the
160 one that is used on UNIX systems: it is a two- or five-letter string in xx or
161 xx_YY format, where xx is ISO 639 code of language and YY is ISO 3166 code of
162 the country. Examples are "en", "en_GB", "en_US" or "fr_FR".
23324ae1 163 This form is internally used when looking up message catalogs.
23324ae1
FM
164 Compare GetSysName().
165 */
328f5751 166 wxString GetCanonicalName() const;
23324ae1
FM
167
168 /**
4cc4bfaf 169 Returns the header value for header @e header. The search for @a header is case
23324ae1
FM
170 sensitive. If an @e domain
171 is passed, this domain is searched. Else all domains will be searched until a
172 header has been found.
173 The return value is the value of the header if found. Else this will be empty.
174 */
175 wxString GetHeaderValue(const wxString& header,
328f5751 176 const wxString& domain = wxEmptyString) const;
23324ae1
FM
177
178 /**
e54c96f1 179 Returns wxLanguage() constant of current language.
23324ae1
FM
180 Note that you can call this function only if you used the form of
181 Init() that takes wxLanguage argument.
182 */
328f5751 183 int GetLanguage() const;
23324ae1
FM
184
185 /**
186 Returns a pointer to wxLanguageInfo structure containing information about the
187 given language or @NULL if this language is unknown. Note that even if the
188 returned pointer is valid, the caller should @e not delete it.
23324ae1
FM
189 See AddLanguage() for the wxLanguageInfo
190 description.
23324ae1
FM
191 As with Init(), @c wxLANGUAGE_DEFAULT has the
192 special meaning if passed as an argument to this function and in this case the
193 result of GetSystemLanguage() is used.
194 */
328f5751 195 static wxLanguageInfo* GetLanguageInfo(int lang) const;
23324ae1
FM
196
197 /**
198 Returns English name of the given language or empty string if this
199 language is unknown.
23324ae1
FM
200 See GetLanguageInfo() for a remark about
201 special meaning of @c wxLANGUAGE_DEFAULT.
202 */
328f5751 203 static wxString GetLanguageName(int lang) const;
23324ae1
FM
204
205 /**
7c913512 206 Returns the locale name as passed to the constructor or
23324ae1
FM
207 Init(). This is full, human-readable name,
208 e.g. "English" or "French".
209 */
328f5751 210 const wxString GetLocale() const;
23324ae1
FM
211
212 /**
213 Returns the current short name for the locale (as given to the constructor or
214 the Init() function).
215 */
328f5751 216 const wxString GetName() const;
23324ae1
FM
217
218 //@{
219 /**
220 Retrieves the translation for a string in all loaded domains unless the szDomain
221 parameter is specified (and then only this catalog/domain is searched).
23324ae1
FM
222 Returns original string if translation is not available
223 (in this case an error message is generated the first time
224 a string is not found; use wxLogNull to suppress it).
23324ae1
FM
225 The second form is used when retrieving translation of string that has
226 different singular and plural form in English or different plural forms in some
227 other language. It takes two extra arguments: @e origString
228 parameter must contain the singular form of the string to be converted.
229 It is also used as the key for the search in the catalog.
4cc4bfaf
FM
230 The @a origString2 parameter is the plural form (in English).
231 The parameter @a n is used to determine the plural form. If no
232 message catalog is found @a origString is returned if 'n == 1',
23324ae1
FM
233 otherwise @e origString2.
234 See GNU gettext manual for additional information on plural forms handling.
e54c96f1
FM
235 This method is called by the wxGetTranslation()
236 function and _() macro.
3c4f71cc 237
23324ae1 238 @remarks Domains are searched in the last to first order, i.e. catalogs
4cc4bfaf 239 added later override those added before.
23324ae1
FM
240 */
241 const wxString GetString(const wxString& origString,
328f5751
FM
242 const wxString& domain = wxEmptyString) const;
243 const const wxString& GetString(const wxString& origString,
244 const wxString& origString2,
245 size_t n,
246 const wxString& domain = NULL) const;
23324ae1
FM
247 //@}
248
249 /**
250 Returns current platform-specific locale name as passed to setlocale().
23324ae1
FM
251 Compare GetCanonicalName().
252 */
328f5751 253 wxString GetSysName() const;
23324ae1
FM
254
255 /**
256 Tries to detect the user's default font encoding.
e54c96f1 257 Returns wxFontEncoding() value or
23324ae1
FM
258 @b wxFONTENCODING_SYSTEM if it couldn't be determined.
259 */
328f5751 260 static wxFontEncoding GetSystemEncoding() const;
23324ae1
FM
261
262 /**
263 Tries to detect the name of the user's default font encoding. This string isn't
264 particularly useful for the application as its form is platform-dependent and
7c913512 265 so you should probably use
23324ae1 266 GetSystemEncoding() instead.
23324ae1
FM
267 Returns a user-readable string value or an empty string if it couldn't be
268 determined.
269 */
328f5751 270 static wxString GetSystemEncodingName() const;
23324ae1
FM
271
272 /**
273 Tries to detect the user's default language setting.
e54c96f1 274 Returns wxLanguage() value or
23324ae1
FM
275 @b wxLANGUAGE_UNKNOWN if the language-guessing algorithm failed.
276 */
328f5751 277 static int GetSystemLanguage() const;
23324ae1
FM
278
279 //@{
280 /**
281 The second form is deprecated, use the first one unless you know what you are
7c913512 282 doing.
3c4f71cc 283
7c913512 284 @param language
4cc4bfaf
FM
285 wxLanguage identifier of the locale.
286 wxLANGUAGE_DEFAULT has special meaning -- wxLocale will use system's
287 default
288 language (see GetSystemLanguage).
7c913512 289 @param flags
4cc4bfaf 290 Combination of the following:
3c4f71cc
VS
291
292
293
294
295
296
297
4cc4bfaf 298 wxLOCALE_LOAD_DEFAULT
3c4f71cc
VS
299
300
301
302
4cc4bfaf
FM
303 Load the message catalog
304 for the given locale containing the translations of standard wxWidgets
305 messages
306 automatically.
3c4f71cc
VS
307
308
309
310
311
4cc4bfaf 312 wxLOCALE_CONV_ENCODING
3c4f71cc
VS
313
314
315
316
4cc4bfaf
FM
317 Automatically convert message
318 catalogs to platform's default encoding. Note that it will do only basic
319 conversion between well-known pair like iso8859-1 and windows-1252 or
320 iso8859-2 and windows-1250. See Writing non-English applications for
321 detailed
322 description of this behaviour. Note that this flag is meaningless in
323 Unicode build.
324 @param name
325 The name of the locale. Only used in diagnostic messages.
326 @param short
327 The standard 2 letter locale abbreviation; it is used as the
328 directory prefix when looking for the message catalog files.
329 @param locale
330 The parameter for the call to setlocale(). Note that it is
331 platform-specific.
332 @param bLoadDefault
333 May be set to @false to prevent loading of the message catalog
334 for the given locale containing the translations of standard wxWidgets
335 messages.
336 This parameter would be rarely used in normal circumstances.
7c913512 337 @param bConvertEncoding
4cc4bfaf
FM
338 May be set to @true to do automatic conversion of message
339 catalogs to platform's native encoding. Note that it will do only basic
340 conversion between well-known pair like iso8859-1 and windows-1252 or
341 iso8859-2 and windows-1250.
342 See Writing non-English applications for detailed
343 description of this behaviour.
23324ae1
FM
344 */
345 bool Init(int language = wxLANGUAGE_DEFAULT,
346 int flags =
7c913512
FM
347 wxLOCALE_LOAD_DEFAULT | wxLOCALE_CONV_ENCODING);
348 bool Init(const wxString& name,
349 const wxString& short = wxEmptyString,
350 const wxString& locale = wxEmptyString,
4cc4bfaf
FM
351 bool bLoadDefault = true,
352 bool bConvertEncoding = false);
23324ae1
FM
353 //@}
354
355 /**
356 Check whether the operating system and/or C run time environment supports
357 this locale. For example in Windows 2000 and Windows XP, support for many
358 locales is not installed by default. Returns @true if the locale is
359 supported.
4cc4bfaf 360 The argument @a lang is the wxLanguage identifier. To obtain this for a
7c913512 361 given a two letter ISO language code, use
23324ae1
FM
362 FindLanguageInfo() to obtain its
363 wxLanguageInfo structure. See AddLanguage() for
364 the wxLanguageInfo description.
3c4f71cc 365
1e24c2af 366 @since 2.7.1.
23324ae1
FM
367 */
368 static bool IsAvailable(int lang);
369
370 /**
371 Check if the given catalog is loaded, and returns @true if it is.
23324ae1
FM
372 According to GNU gettext tradition, each catalog
373 normally corresponds to 'domain' which is more or less the application name.
23324ae1
FM
374 See also: AddCatalog()
375 */
328f5751 376 bool IsLoaded(const char* domain) const;
23324ae1
FM
377
378 /**
379 Returns @true if the locale could be set successfully.
380 */
328f5751 381 bool IsOk() const;
23324ae1
FM
382
383 /**
384 See @ref overview_languagecodes "list of recognized language constants".
385 These constants may be used to specify the language
7c913512 386 in Init() and are returned by
23324ae1
FM
387 GetSystemLanguage():
388 */
389};
390
391
e54c96f1 392
23324ae1
FM
393/**
394 @class wxXLocale
7c913512
FM
395
396
23324ae1
FM
397 wxXLocale::wxXLocale
398 wxXLocale::GetCLocale
399 wxXLocale::IsOk
7c913512
FM
400
401
23324ae1 402 Introduction
7c913512
FM
403
404 This class represents a locale object used by so-called xlocale API. Unlike
23324ae1
FM
405 wxLocale it doesn't provide any non-trivial operations but
406 simply provides a portable wrapper for POSIX @c locale_t type. It exists
407 solely to be provided as an argument to various @c wxFoo_l() functions
408 which are the extensions of the standard locale-dependent functions (hence the
409 name xlocale). These functions do exactly the same thing as the corresponding
410 standard @c foo() except that instead of using the global program locale
411 they use the provided wxXLocale object. For example, if the user runs the
412 program in French locale, the standard @c printf() function will output
413 floating point numbers using decimal comma instead of decimal period. If the
414 program needs to format a floating-point number in a standard format it can
415 use @c wxPrintf_l(wxXLocale::GetCLocale(), "%g", number) to do it.
416 Conversely, if a program wanted to output the number in French locale, even if
417 the current locale is different, it could use wxXLocale(wxLANGUAGE_FRENCH).
7c913512
FM
418
419
23324ae1 420 Availability
7c913512 421
23324ae1
FM
422 This class is fully implemented only under the platforms where xlocale POSIX
423 API or equivalent is available. Currently the xlocale API is available under
424 most of the recent Unix systems (including Linux, various BSD and Mac OS X) and
425 Microsoft Visual C++ standard library provides a similar API starting from
426 version 8 (Visual Studio 2005).
7c913512 427
23324ae1
FM
428 If neither POSIX API nor Microsoft proprietary equivalent are available, this
429 class is still available but works in degraded mode: the only supported locale
430 is the C one and attempts to create wxXLocale object for any other locale will
431 fail. You can use the preprocessor macro @c wxHAS_XLOCALE_SUPPORT to
432 test if full xlocale API is available or only skeleton C locale support is
433 present.
7c913512
FM
434
435 Notice that wxXLocale is new in wxWidgets 2.9.0 and is not compiled in if
23324ae1 436 @c wxUSE_XLOCALE was set to 0 during the library compilation.
7c913512
FM
437
438
23324ae1 439 Locale-dependent functions
7c913512 440
23324ae1 441 Currently the following @c _l-functions are available:
7c913512 442
23324ae1
FM
443 Character classification functions: @c wxIsxxx_l(), e.g.
444 @c wxIsalpha_l(), @c wxIslower_l() and all the others.
445 Character transformation functions: @c wxTolower_l() and
446 @c wxToupper_l()
7c913512 447
23324ae1
FM
448 We hope to provide many more functions (covering numbers, time and formatted
449 IO) in the near future.
7c913512 450
23324ae1
FM
451 @library{wxbase}
452 @category{FIXME}
7c913512 453
e54c96f1 454 @see wxLocale
23324ae1 455*/
7c913512 456class wxXLocale
23324ae1
FM
457{
458public:
459 //@{
460 /**
461 Creates the locale object corresponding to the specified locale string. The
462 locale string is system-dependent, use constructor taking wxLanguage for better
463 portability.
464 */
465 wxLocale();
7c913512 466 wxLocale(wxLanguage lang);
4cc4bfaf 467 wxLocale(const char* loc);
23324ae1
FM
468 //@}
469
470 /**
471 This class is fully implemented only under the platforms where xlocale POSIX
472 API or equivalent is available. Currently the xlocale API is available under
473 most of the recent Unix systems (including Linux, various BSD and Mac OS X) and
474 Microsoft Visual C++ standard library provides a similar API starting from
475 version 8 (Visual Studio 2005).
23324ae1
FM
476 If neither POSIX API nor Microsoft proprietary equivalent are available, this
477 class is still available but works in degraded mode: the only supported locale
478 is the C one and attempts to create wxXLocale object for any other locale will
479 fail. You can use the preprocessor macro @c wxHAS_XLOCALE_SUPPORT to
480 test if full xlocale API is available or only skeleton C locale support is
481 present.
7c913512 482 Notice that wxXLocale is new in wxWidgets 2.9.0 and is not compiled in if
23324ae1
FM
483 @c wxUSE_XLOCALE was set to 0 during the library compilation.
484 */
485
486
487 /**
488 Returns the global object representing the "C" locale. For an even shorter
489 access to this object a global @c wxCLocale variable (implemented as a
490 macro) is provided and can be used instead of calling this method.
491 */
492 static wxXLocale GetCLocale();
493
494 /**
7c913512 495 This class represents a locale object used by so-called xlocale API. Unlike
23324ae1
FM
496 wxLocale it doesn't provide any non-trivial operations but
497 simply provides a portable wrapper for POSIX @c locale_t type. It exists
498 solely to be provided as an argument to various @c wxFoo_l() functions
499 which are the extensions of the standard locale-dependent functions (hence the
500 name xlocale). These functions do exactly the same thing as the corresponding
501 standard @c foo() except that instead of using the global program locale
502 they use the provided wxXLocale object. For example, if the user runs the
503 program in French locale, the standard @c printf() function will output
504 floating point numbers using decimal comma instead of decimal period. If the
505 program needs to format a floating-point number in a standard format it can
506 use @c wxPrintf_l(wxXLocale::GetCLocale(), "%g", number) to do it.
507 Conversely, if a program wanted to output the number in French locale, even if
508 the current locale is different, it could use wxXLocale(wxLANGUAGE_FRENCH).
509 */
510
511
512 /**
513 Returns @true if this object is initialized, i.e. represents a valid locale
7c913512 514 or
23324ae1
FM
515 @false otherwise.
516 */
328f5751 517 bool IsOk() const;
23324ae1
FM
518
519 /**
520 Currently the following @c _l-functions are available:
23324ae1
FM
521 Character classification functions: @c wxIsxxx_l(), e.g.
522 @c wxIsalpha_l(), @c wxIslower_l() and all the others.
523 Character transformation functions: @c wxTolower_l() and
524 @c wxToupper_l()
23324ae1
FM
525 We hope to provide many more functions (covering numbers, time and formatted
526 IO) in the near future.
3c4f71cc 527
4cc4bfaf 528 @see wxLocale
23324ae1
FM
529 */
530};
531
532
e54c96f1 533
23324ae1
FM
534// ============================================================================
535// Global functions/macros
536// ============================================================================
537
3950d49c
BP
538/** @ingroup group_funcmacro_string */
539//@{
540
23324ae1 541/**
3950d49c
BP
542 This macro is identical to _() but for the plural variant of
543 wxGetTranslation().
544
d29a9a8a 545 @return A const wxString.
3950d49c
BP
546
547 @header{wx/intl.h}
23324ae1 548*/
3950d49c 549#define wxPLURAL(string, plural, n)
23324ae1
FM
550
551/**
3950d49c
BP
552 This macro doesn't do anything in the program code -- it simply expands to
553 the value of its argument.
554
23324ae1
FM
555 However it does have a purpose which is to mark the literal strings for the
556 extraction into the message catalog created by @c xgettext program. Usually
3950d49c
BP
557 this is achieved using _() but that macro not only marks the string for
558 extraction but also expands into a wxGetTranslation() call which means that
559 it cannot be used in some situations, notably for static array
23324ae1 560 initialization.
3950d49c 561
23324ae1
FM
562 Here is an example which should make it more clear: suppose that you have a
563 static array of strings containing the weekday names and which have to be
3950d49c
BP
564 translated (note that it is a bad example, really, as wxDateTime already
565 can be used to get the localized week day names already). If you write:
4cc4bfaf 566
23324ae1
FM
567 @code
568 static const char * const weekdays[] = { _("Mon"), ..., _("Sun") };
569 ...
570 // use weekdays[n] as usual
571 @endcode
7c913512 572
3950d49c
BP
573 The code wouldn't compile because the function calls are forbidden in the
574 array initializer. So instead you should do this:
4cc4bfaf 575
23324ae1
FM
576 @code
577 static const char * const weekdays[] = { wxTRANSLATE("Mon"), ...,
578 wxTRANSLATE("Sun") };
579 ...
580 // use wxGetTranslation(weekdays[n])
581 @endcode
7c913512 582
23324ae1 583 Note that although the code @b would compile if you simply omit
3950d49c
BP
584 wxTRANSLATE() in the above, it wouldn't work as expected because there
585 would be no translations for the weekday names in the program message
586 catalog and wxGetTranslation() wouldn't find them.
587
d29a9a8a 588 @return A const wxChar*.
3950d49c
BP
589
590 @header{wx/intl.h}
23324ae1 591*/
3950d49c 592#define wxTRANSLATE(string)
23324ae1
FM
593
594/**
3950d49c
BP
595 This function returns the translation of @a string in the current
596 @c locale(). If the string is not found in any of the loaded message
597 catalogs (see @ref overview_i18n), the original string is returned. In
598 debug build, an error message is logged -- this should help to find the
599 strings which were not yet translated. If @a domain is specified then only
600 that domain/catalog is searched for a matching string. As this function is
601 used very often, an alternative (and also common in Unix world) syntax is
602 provided: the _() macro is defined to do the same thing as
603 wxGetTranslation().
604
605 This function calls wxLocale::GetString().
606
607 @note This function is not suitable for literal strings in Unicode builds
608 since the literal strings must be enclosed into _T() or wxT() macro
609 which makes them unrecognised by @c xgettext, and so they are not
610 extracted to the message catalog. Instead, use the _() and wxPLURAL()
611 macro for all literal strings.
612
613 @see wxGetTranslation(const wxString&, const wxString&, size_t, const wxString&)
614
615 @header{wx/intl.h}
23324ae1 616*/
3950d49c
BP
617const wxString wxGetTranslation(const wxString& string,
618 const wxString& domain = wxEmptyString);
23324ae1 619
23324ae1 620/**
3950d49c
BP
621 This is an overloaded version of
622 wxGetTranslation(const wxString&, const wxString&), please see its
623 documentation for general information.
624
625 This version is used when retrieving translation of string that has
626 different singular and plural forms in English or different plural forms in
627 some other language. Like wxGetTranslation(const wxString&,const wxString&),
628 the @a string parameter must contain the singular form of the string to be
629 converted and is used as the key for the search in the catalog. The
630 @a plural parameter is the plural form (in English). The parameter @a n is
631 used to determine the plural form. If no message catalog is found,
632 @a string is returned if "n == 1", otherwise @a plural is returned.
633
634 See GNU gettext Manual for additional information on plural forms handling:
635 <http://www.gnu.org/software/gettext/manual/gettext.html#Plural-forms>
636 For a shorter alternative see the wxPLURAL() macro.
637
638 This function calls wxLocale::GetString().
639
640 @header{wx/intl.h}
23324ae1 641*/
3950d49c
BP
642const wxString wxGetTranslation(const wxString& string,
643 const wxString& plural, size_t n,
644 const wxString& domain = wxEmptyString);
645
646/**
647 This macro expands into a call to wxGetTranslation(), so it marks the
648 message for the extraction by @c xgettext just as wxTRANSLATE() does, but
649 also returns the translation of the string for the current locale during
650 execution.
651
652 Don't confuse this with _T()!
653
654 @header{wx/intl.h}
655*/
656const wxString _(const wxString& string);
657
23324ae1
FM
658//@}
659