String literals should be typed in the source code in English, but
    they should be surrounded by a call to the gettext()
    function. These strings will be extracted for translation and the
    translations may be used at runtime instead of the original English
    strings.
  
The GNU gettext package allows you to mark strings in source code, extract those strings for translation, and use the translated strings in your application.
    However, Glib defines
    gettext()
    support macros which are shorter wrappers in an easy-to-use form.
    To use these macros, include <glibmm/i18n.h>,
    and then, for example, substitute:
display_message("Getting ready for i18n.");with:
display_message(_("Getting ready for i18n."));
    For reference, it is possible to generate a file which contains all
    strings which appear in your code, even if they are not marked for translation,
    together with file name and line
    number references. To generate such a file named
    my-strings, execute the following command,
    within the source code directory:
  
xgettext -a -o my-strings --omit-header *.cc *.h
    Finally, to let your program use the translation for the current locale,
    add this code to the beginning of your main.cc file, to initialize gettext.
  
bindtextdomain(GETTEXT_PACKAGE, PROGRAMNAME_LOCALEDIR);
bind_textdomain_codeset(GETTEXT_PACKAGE, "UTF-8");
textdomain(GETTEXT_PACKAGE);
      The intltool-update or
      xgettext script extracts the strings
      and puts them in a mypackage.pot file.
      The translators of your application create their translations by
      first copying this .pot file to a
      localename.po file. A locale identifies a
      language and an encoding for that language, including date and numerical
      formats. Later, when the text in your source code has changed, the
      msgmerge or intltool-update
      script is used to update the localename.po files from
      the regenerated .pot file.
    
      At install time, the .po files are converted to
      a binary format (with the extension .mo) and
      placed in a system-wide directory for locale files, for example
      /usr/share/locale/.
    
      When the application runs, the gettext
      library checks the system-wide directory to see if there is a
      .mo file for the user's locale environment
      (you can set the locale with, for instance, "export LANG=de_DE.UTF-8"
      from a bash console). Later, when the program reaches a
      gettext call, it looks for a translation of a
      particular string. If none is found, the original string is used.
    
      To convince yourself that you've done well, you may wish to add a
      translation for a new locale. In order to do that, go to the
      po subdirectory of your project and
      execute the following command:
    
intltool-update --pot
      That will create a file named programname.pot.
      Now copy that file to languagecode.po, such as
      de.po or hu.po. Also add
      that language code to LINGUAS. The
      .po file contains a header and a list of English strings,
      with space for the translated strings to be entered. Make sure you set the
      encoding of the .po file (specified in the header, but
      also as content) to UTF-8.
    
| ![[Note]](icons/note.png) | Note | 
|---|---|
| 
      It's possible that certain strings will be marked as
       | 
More information about what lies behind the internationalization and localization process is presented and demonstrated in: