Aller au contenu

« GNU gettext » : différence entre les versions

Un article de Wikipédia, l'encyclopédie libre.
Contenu supprimé Contenu ajouté
m logo GNU dans l'infobox
Ligne 94 : Ligne 94 :
===Liens externes===
===Liens externes===
* {{en}} [http://www.gnu.org/software/gettext/manual/gettext.html Documentation officielle]
* {{en}} [http://www.gnu.org/software/gettext/manual/gettext.html Documentation officielle]
* {{en}} [http://code.google.com/p/gettext-commons/ Gettext-Commons], librairie Java
* {{fr}} [http://traduc.org/L%27adaptation_des_logiciels/Gettext L'adaptation des logiciels avec Gettext]
* {{fr}} [http://traduc.org/L%27adaptation_des_logiciels/Gettext L'adaptation des logiciels avec Gettext]
* {{fr}} [http://www.waanser.com/php/184-get-text.html L’utilisation de gettext en php] sur Tutoriel pratique
* {{fr}} [http://www.waanser.com/php/184-get-text.html L’utilisation de gettext en php] sur Tutoriel pratique

Version du 24 mars 2011 à 15:56

gettext
[[Fichier: |frameless |upright=0.55 |alt=Description de l'image . ]]

Informations
Créateur Ulrich DrepperVoir et modifier les données sur Wikidata
Développé par Le projet GNU
Première version Voir et modifier les données sur Wikidata
Dernière version 0.18.1 ([1])
Dépôt git.savannah.gnu.org/cgit/gettext.gitVoir et modifier les données sur Wikidata
Écrit en CVoir et modifier les données sur Wikidata
Supporte les langages PythonVoir et modifier les données sur Wikidata
Système d'exploitation GNU/Linux, BSD, Microsoft Windows et macOSVoir et modifier les données sur Wikidata
Environnement Multiplate-forme
Formats lus GNU Gettext Machine Object (big endian) (d), GNU Gettext Machine Object (litte endian) (d) et Gettext catalog file (d)Voir et modifier les données sur Wikidata
Formats écrits GNU Gettext Machine Object (big endian) (d), GNU Gettext Machine Object (litte endian) (d) et Gettext catalog file (d)Voir et modifier les données sur Wikidata
Type Bibliothèque logicielle
Licence GNU GPL
Documentation gnu.org/software/gettext/manualVoir et modifier les données sur Wikidata
Site web (en) Site officiel

gettext est la bibliothèque GNU d'internationalisation (i18n). Elle est couramment utilisée pour écrire des programmes multilingues.

Processus

Programmeur

Le code source est d'abord modifié pour utiliser les appels à la fonction GNU gettext. Pour la plupart des langages, ceci se fait en insérant les chaînes destinées à l'utilisateur dans la fonction gettext. Pour gagner du temps de saisie et clarifier le code, l'alias de substitution _ est habituellement utilisé pour cette fonction de sorte que le code C :

printf(gettext("My name is %s.\n"), my_name);

devienne

printf(_("My name is %s.\n"), my_name);

gettext utilise alors la chaîne fournie comme clef de recherche de traductions et renvoie la chaîne d'origine si aucune traduction n'est disponible, à la différence de systèmes comme catgets ou de l'utilisation de Loadstring sous Microsoft Windows, où une identité de programmation est utilisée (souvent un entier).

Outre le C, la fonction GNU gettext est implémentée en : C++, Objective C, SH script, bash script, Python, Objective Caml, GNU CLISP, Emacs Lisp, librep, GNU Smalltalk, Ruby, Java, GNU awk, Pascal, wxWidgets (par wxLocale), YCP (langage de YaST2), Tcl, Perl, PHP, Pike, et R. Dans la plupart des cas, son utilisation s'y apparente à celle du C.

xgettext est appliquée aux sources pour produire un fichier .pot, ou modèle, qui contient une liste de toutes les chaînes traduisibles extraites du code. Pour l'exemple ci-dessus, une entrée du fichier .pot ressemblerait à ceci :

#: src/name.c:36
msgid "My name is %s.\n"
msgstr ""

Commentaires pour les traducteurs

Si le développeur désire donner au traducteur une indication pour une chaîne spécifique, il peut le faire dans le code source à l'aide d'une étiquette (TAG) destinée à xgettext, pour lui permettre de filtrer ces indications et de les mettre dans le fichier .pot. Ces indications seront montrées par KBabel et PoEdit.

 printf(_("My name is %s.\n"), my_name);
 // TRANSLATORS: Please let %s as it is, because it is exchanged by the program.
 // Thank you for contributing to this project.

Dans cet exemple, l'étiquette est // et doit être fournie à xgettext pour lui permettre d'extraire les commentaires pour les traducteurs lors de la construction du fichier .pot. D'autres caractères peuvent être utilisés comme étiquette du moment qu'ils sont utilisés de manière cohérente dans tout le code.

xgettext -c=//

Avec les commentaires, le fichier .pot ressemblerait à ceci :

#. TRANSLATORS: Please let %s as it is, because it is exchanged by the program.
#. Thank you for contributing to this project. 
#: src/name.c:36
msgid "My name is %s.\n"
msgstr ""

Traducteur

Le traducteur dérive un fichier .po du modèle en utilisant le programme msginit puis remplit les traductions. msginit initialise les traductions de sorte que pour créer une traduction en français, par exemple, il faut exécuter :

msginit --locale=fr --input=name.pot

Ceci engendre fr.po. Un exemple d'entrée serait :

#: src/name.c:36
msgid "My name is %s.\n"
msgstr "My name is %s.\n"

Le traducteur doit les corriger, à la main ou à l'aide d'un outil de traduction comme PoEdit. Ceci fait, l'entrée prendrait la forme suivante :

#: src/name.c:36
msgid "My name is %s.\n"
msgstr "Je m'appelle %s.\n"

Finalement, les fichiers .po sont compilés en fichiers binaires .mo avec msgfmt. Ils sont alors prêts à être distribués dans le paquet logiciel.

Utilisateur

L'utilisateur, sur des systèmes de type Unix, ajuste la variable d'environnement LC_MESSAGES et le programme affiche alors les chaînes dans la langue sélectionnée, si un fichier .mo est présent et si les locales de la langue en question sont installées.


Notes & références

  1. (en) GNU gettext 0.18.1 réalisé le 4 juin 2010.

Voir aussi

Liens externes


Modèle:GNU