Interface de traduction (traduction)

De Wiki1000
(Différences entre les versions)
(Aide à la traduction)
(Que traduire)
 
(16 révisions intermédiaires par 2 utilisateurs sont masquées)
Ligne 1 : Ligne 1 :
 
==Où traduire==
 
==Où traduire==
Il existe trois façons de traduire des message dans La Ligne 1000.
+
Il existe trois façons de traduire des message dans La Ligne 1000 :
  - Traduire les dictionnaires objets
+
  - Traduire le dictionnaire application
+
  - Traduire depuis les écrans
+
  
- Traduire les dictionnaires objets
+
1. Traduire les dictionnaires objets
C'est la méthode recommandée.
+
:'''C'est la méthode recommandée.'''
  
- Traduire le dictionnaire application
+
2. Traduire le dictionnaire application.
Cette méthode '''n'est pas recommandée''' car le dictionnaire d'application est un dictionnaire de travail '''qui est écrasé''' dès qu'on le reconstruit.
+
:Cette méthode n'est pas recommandée car le dictionnaire d'application est un dictionnaire de travail qui est écrasé dès qu'on le reconstruit.
  
- Traduire depuis les écrans
+
3. Traduire depuis les écrans
Cette méthode '''n'est pas recommandée''' car les traductions sont intégrées au dictionnaire application.
+
:Cette méthode n'est pas recommandée car les traductions sont intégrées au dictionnaire application et peuvent donc être perdues.
  
 
==Comment traduire==
 
==Comment traduire==
Ligne 18 : Ligne 15 :
 
L'écran de traduction  
 
L'écran de traduction  
  
[[Image:Saisie_messages.jpg]]
+
[[Image:Traduction2.jpg]]
  
 
===Ergonomie===
 
===Ergonomie===
 
Cet écran a été conçu pour pouvoir travailler uniquement au clavier et faciliter ainsi la traduction.
 
Cet écran a été conçu pour pouvoir travailler uniquement au clavier et faciliter ainsi la traduction.
une fois positionné sur la zone de traduction :
+
 
 +
Une fois le focus positionné sur la zone de traduction les raccourcis clavier suivant s'appliquent :  
 
   
 
   
'''Flèche bas''' :  passe au message suivant
+
{|class="wikitable"
 +
|-
 +
!Raccourci
 +
!Action
 +
|-
 +
|Flèche bas
 +
|Passe au message suivant
 +
|-
 +
|Flèche haut
 +
|Passe au message précédent
 +
|-
 +
|CTRL + T
 +
|Déclare le message comme traduit
 +
|-
 +
|CTRL + F
 +
|Inverse le statut "à confirmer"
 +
|-
 +
|CTRL + P
 +
|Permuter la sélection et normaliser
 +
|-
 +
|CTRL + N
 +
|Normaliser le message<br>
 +
Retire les majuscules sauf si tout le mot est en majuscule (acronyme)<br>
 +
Met le premier caractère en majuscule et le premier caractère après un point
 +
|-
 +
|CTRL + O
 +
|Remplacer tous les termes trouvés dans le lexique
 +
|-
 +
|CTRL + L
 +
|Supprimer le mot suivant le curseur dans la phrase.
 +
|}
  
'''Flèche haut''' : passe au message précédent
+
===Les lexiques===
 +
Les lexiques ont été introduits dans un souci de '''rationalisation''' et '''d'homogénéité''' de la traduction.
  
'''CTRL + T''' : déclare le message comme traduit
+
On peut créer un lexique par thème lexical, par exemple trésorerie.
  
'''CTRL + F''' : inverse le statut "à confirmer"
+
====Ajouter un mot dans le lexique====
 +
On ajoute une expression dans le lexique sur le clic droit.
  
===Aide à la traduction===
+
{{tip|sélectionner l'expression si elle comporte plus d'un mot}}
  
 +
[[Image:Lexique1.jpg]]
  
[[Image:Aide_a_la_traduction_2.jpg‎]]
+
On peut choisir le lexique (parmi les lexiques sélectionnés) dans lequel insérer l'expression.
 +
Si l'expression existe déjà dans le lexique, sa traduction est affichée pour modification.
  
L'aide à la traduction permet de proposer un traduction à partir de plusieurs sources de messages :  
+
[[Image:Lexique2.jpg]]
  
- Fichiers xml
+
====Exploiter le lexique lors de la traduction====
- Dictionnaires internes
+
Les expressions présentes dans les lexiques apparaissent en gras dans l'éditeur.
- Dictionnaires externes
+
- Traduction Google
+
  
 +
Par le clic droit dans la zone de traduction, on peut :
 +
*Copier l'expression
 +
*Remplacer toutes les occurrences de l'expression par sa traduction
 +
*Remplacer toutes les occurrences des expressions trouvées dans le message (Remplacer tous)
  
- Fichiers xml
+
[[Image:Lexique3.jpg]]
  
[[Image:Ressource_xml.jpg]]
+
====Exploiter le lexique pour améliorer la qualité de la traduction====
  
'''- Dictionnaires internes'''
+
*Marquer les messages concernés
 +
:Marque les messages qui contiennent au moins une expression des lexiques sélectionnés.
  
Utile pour récupérer des traductions déjà effectuées
+
*Marquer les messages non conformes
 +
:Marque les messages qui contiennent au moins une expression des lexiques sélectionnés et dont la traduction ne contient '''pas''' les expressions traduites du lexique.
  
'''- Dictionnaires externes'''
+
[[Image:Lexique4.jpg]]
  
Fichier *.dut.
+
===La recherche===
  
'''- Traduction Google'''
+
[[Image:search_replace.jpg]]
  
Peut être long.
+
[[Image:search_replace2.jpg]]
  
 +
===L'aide à la traduction===
  
L'aide à la traduction utilise une méthode pour augmenter ses chances de réussite.
+
[[Image:Aide_a_la_traduction_2.jpg‎]]
Ainsi, elle retire les caractères non alphabétiques de début et de fin de phrase avant de comparer les chaines.
+
Par exemple, je cherche à traduire la chaine brute ''" - Le contrat : "''.
+
J'applique la méthode et '''je l'applique aussi au messages sources ''' avant de comparer.
+
Le message recherché est donc "le contrat".
+
Si je trouve ce message dans les sources (qui pouvait être à l'origine ''"*le contrat ..."'' d'ailleurs), je prends la traduction ''"the contract"'' et '''je restitue les éléments retirés avant la recherche ''' pour retrouver ''"- The contract : "''
+
  
Cette méthode est utile pour augmenter le succès de traduction '''mais elle présente des inconvénients'''.
+
L'aide à la traduction permet de proposer un traduction à partir de plusieurs sources de messages :
  
Ainsi, en Anglais, il ne faut pas d'espace avant ":".
+
* Fichiers xml
Avec cette méthode, si dans ma source j'ai ''"Le code : "'' traduit par ''"The code: "'' (ce qui est correct), on obtiendra la chaine ''"The code : "'' (avec un espace en trop).
+
[[Image:Ressource_xml.jpg]]
De même, ''"je suis un tailleur"'' sera traduit par ''"i am a tailor"'' (il manque la majuscule)
+
* Dictionnaires internes
 +
:Utile pour récupérer des traductions déjà effectuées
 +
* Dictionnaires externes
 +
:Fichier *.dut.  
  
C'est pourquoi il existe une option pour désactiver cette méthode :
+
L'aide à la traduction retire les caractères non alphabétiques de début et de fin de phrase avant de comparer les chaines, puis si le message est trouvé la traduction réintroduit les caractères non alphabétique.
'''Recherche du message exact'''
+
  
==Que traduire==
+
Par exemple:
  
=== Les messages ordinaires ===
+
Je cherche à traduire la chaine brute ''" - Le contrat : "''.
  
 +
*Le message recherché est "le contrat".
 +
*Le message trouvé est  "the contract".
 +
*Le message traduit est " - The contract : ".
 +
 +
Ceci permet d'améliorer les chances de trouver une traduction existante mais peut présenter des inconvénients.
 +
 +
Par exemple, en Anglais, il ne faut pas d'espace avant ":".
 +
 +
Avec cette méthode, ''"Le code : "'' traduit par ''"The code: "'' serait remplacé par ''"The code : "'' qui comporte un espace de trop.
 +
 +
De même, ''"je suis un tailleur"'' sera traduit par ''"i am a tailor"'' où il manque la majuscule.
 +
 +
C'est pourquoi cette option est désactivable par l'option "Recherche du message exact"
 +
 +
==Que traduire==
 +
===Les messages ordinaires===
 
Les messages sont extraits bruts. C'est à dire qu'ils ne subissent aucune modification.
 
Les messages sont extraits bruts. C'est à dire qu'ils ne subissent aucune modification.
 
"code" et "Code" sont deux messages différents.
 
"code" et "Code" sont deux messages différents.
Les mécanismes pour extraire l'idée du message afin de stocker moins de messages s'avèrent trop complexes.
 
  
 
En revanche, l'aide à traduction peut traduire des messages ressemblants.
 
En revanche, l'aide à traduction peut traduire des messages ressemblants.
Ligne 90 : Ligne 139 :
 
Charge au traducteur de vérifier ensuite.
 
Charge au traducteur de vérifier ensuite.
  
=== Les messages à ne pas traduire ===
+
===Les messages à ne pas traduire===
 
+
 
La mécanique d'extraction concerne des éléments qui ne sont parfois pas formulés correctement.
 
La mécanique d'extraction concerne des éléments qui ne sont parfois pas formulés correctement.
 
Il est alors inutile de traduire ces messages.
 
Il est alors inutile de traduire ces messages.
Ligne 99 : Ligne 147 :
 
Certains libellé court ''"RoleTiersList"''
 
Certains libellé court ''"RoleTiersList"''
  
En revanche on peut les cocher comme traduits pour les statistiques.
+
{{tip|En revanche on doit les cocher comme traduits pour les statistiques.}}
 
+
 
+
=== Les messages à considérer avec attention ===
+
  
 +
===Les messages à considérer avec attention===
 +
====Paramètre de format %====
 
Certaines chaines contiennent des paramètres ''"Le montant %d concernant le tiers %s ..."''.
 
Certaines chaines contiennent des paramètres ''"Le montant %d concernant le tiers %s ..."''.
  
Il est important de conserver ces paramètres '''dans l'ordre dans lequel ils apparaissent'''.
+
{{tip|Il est important de conserver ces paramètres '''dans l'ordre dans lequel ils apparaissent}}
  
 
En effet une erreur de paramètre peut provoquer une erreur d'exécution du programme.
 
En effet une erreur de paramètre peut provoquer une erreur d'exécution du programme.
 
On peut aussi numéroter les paramètres ; par exemple :  
 
On peut aussi numéroter les paramètres ; par exemple :  
"nom : %s ; prénom %s" => "last name : %2s ; first name %1s"  
+
"nom : %s ; prénom %s" => "last name : %1:s ; first name %0:s"  
Ce cas ne devrait pas être rencontré fréquemment.
+
  
 +
attention : la numérotation des paramètres commence à zéro
 +
ShowMessage(Format('Reposition after 3 strings = %s %s %s %1:s %s',['Zero', 'One', 'Two', 'Three']))
 +
Reposition after 3 strings = Zero One Two One Two
  
 +
Il existe un outil dans la traduction pour vérifier que les paramètres de format sont conservés entre le message natif et le message traduit.
  
 +
====Paramètre de format @====
 
On trouvera également ce type de paramètre : ''"Le @code@ est erroné"''
 
On trouvera également ce type de paramètre : ''"Le @code@ est erroné"''
  
 +
 +
====Saut de ligne <cr>====
 +
Dans certains exports, les sauts de lignes sont remplacés par le mot réservé "<cr>", ce mot ne doit pas être traduit
 
Ces paramètres ne peuvent pas provoquer d'erreurs et leur ordre n'importe pas.
 
Ces paramètres ne peuvent pas provoquer d'erreurs et leur ordre n'importe pas.
  
Ligne 135 : Ligne 189 :
  
 
==Un processus itératif==
 
==Un processus itératif==
 
 
Afin d'effectuer en parallèle le travail de traduction et de validation, un batch lancé chaque soir est prévu.
 
Afin d'effectuer en parallèle le travail de traduction et de validation, un batch lancé chaque soir est prévu.
 
Le batch reconstruit le dictionnaire application afin que les équipes de qualité bénéficient des traductions effectuées dans la journée.
 
Le batch reconstruit le dictionnaire application afin que les équipes de qualité bénéficient des traductions effectuées dans la journée.
Ligne 145 : Ligne 198 :
  
 
Ainsi, la qualité peut constater rapidement les problèmes et les dictionnaires sont à jours.
 
Ainsi, la qualité peut constater rapidement les problèmes et les dictionnaires sont à jours.
 +
 +
{{Footer|Guide de la traduction (trans)}}
 +
[[Category:Traduction]]

Version actuelle en date du 6 janvier 2012 à 09:33

Sommaire

Où traduire

Il existe trois façons de traduire des message dans La Ligne 1000 :

1. Traduire les dictionnaires objets

C'est la méthode recommandée.

2. Traduire le dictionnaire application.

Cette méthode n'est pas recommandée car le dictionnaire d'application est un dictionnaire de travail qui est écrasé dès qu'on le reconstruit.

3. Traduire depuis les écrans

Cette méthode n'est pas recommandée car les traductions sont intégrées au dictionnaire application et peuvent donc être perdues.

Comment traduire

L'écran de traduction

Traduction2.jpg

Ergonomie

Cet écran a été conçu pour pouvoir travailler uniquement au clavier et faciliter ainsi la traduction.

Une fois le focus positionné sur la zone de traduction les raccourcis clavier suivant s'appliquent :

Raccourci Action
Flèche bas Passe au message suivant
Flèche haut Passe au message précédent
CTRL + T Déclare le message comme traduit
CTRL + F Inverse le statut "à confirmer"
CTRL + P Permuter la sélection et normaliser
CTRL + N Normaliser le message

Retire les majuscules sauf si tout le mot est en majuscule (acronyme)
Met le premier caractère en majuscule et le premier caractère après un point

CTRL + O Remplacer tous les termes trouvés dans le lexique
CTRL + L Supprimer le mot suivant le curseur dans la phrase.

Les lexiques

Les lexiques ont été introduits dans un souci de rationalisation et d'homogénéité de la traduction.

On peut créer un lexique par thème lexical, par exemple trésorerie.

Ajouter un mot dans le lexique

On ajoute une expression dans le lexique sur le clic droit.

Tip-20px.png Tip : sélectionner l'expression si elle comporte plus d'un mot

Lexique1.jpg

On peut choisir le lexique (parmi les lexiques sélectionnés) dans lequel insérer l'expression. Si l'expression existe déjà dans le lexique, sa traduction est affichée pour modification.

Lexique2.jpg

Exploiter le lexique lors de la traduction

Les expressions présentes dans les lexiques apparaissent en gras dans l'éditeur.

Par le clic droit dans la zone de traduction, on peut :

  • Copier l'expression
  • Remplacer toutes les occurrences de l'expression par sa traduction
  • Remplacer toutes les occurrences des expressions trouvées dans le message (Remplacer tous)

Lexique3.jpg

Exploiter le lexique pour améliorer la qualité de la traduction

  • Marquer les messages concernés
Marque les messages qui contiennent au moins une expression des lexiques sélectionnés.
  • Marquer les messages non conformes
Marque les messages qui contiennent au moins une expression des lexiques sélectionnés et dont la traduction ne contient pas les expressions traduites du lexique.

Lexique4.jpg

La recherche

Search replace.jpg

Search replace2.jpg

L'aide à la traduction

Aide a la traduction 2.jpg

L'aide à la traduction permet de proposer un traduction à partir de plusieurs sources de messages :

  • Fichiers xml

Ressource xml.jpg

  • Dictionnaires internes
Utile pour récupérer des traductions déjà effectuées
  • Dictionnaires externes
Fichier *.dut.

L'aide à la traduction retire les caractères non alphabétiques de début et de fin de phrase avant de comparer les chaines, puis si le message est trouvé la traduction réintroduit les caractères non alphabétique.

Par exemple:

Je cherche à traduire la chaine brute " - Le contrat : ".

  • Le message recherché est "le contrat".
  • Le message trouvé est "the contract".
  • Le message traduit est " - The contract : ".

Ceci permet d'améliorer les chances de trouver une traduction existante mais peut présenter des inconvénients.

Par exemple, en Anglais, il ne faut pas d'espace avant ":".

Avec cette méthode, "Le code : " traduit par "The code: " serait remplacé par "The code : " qui comporte un espace de trop.

De même, "je suis un tailleur" sera traduit par "i am a tailor" où il manque la majuscule.

C'est pourquoi cette option est désactivable par l'option "Recherche du message exact"

Que traduire

Les messages ordinaires

Les messages sont extraits bruts. C'est à dire qu'ils ne subissent aucune modification. "code" et "Code" sont deux messages différents.

En revanche, l'aide à traduction peut traduire des messages ressemblants. Si "code" est traduit, la traduction automatique traduira "Code", "-Code : ", "code..." etc... Charge au traducteur de vérifier ensuite.

Les messages à ne pas traduire

La mécanique d'extraction concerne des éléments qui ne sont parfois pas formulés correctement. Il est alors inutile de traduire ces messages.

Par exemple, un message de règle d'erreur "erreur_codeTiers".

Certains libellé court "RoleTiersList"

Tip-20px.png Tip : En revanche on doit les cocher comme traduits pour les statistiques.

Les messages à considérer avec attention

Paramètre de format %

Certaines chaines contiennent des paramètres "Le montant %d concernant le tiers %s ...".

Tip-20px.png Tip : Il est important de conserver ces paramètres dans l'ordre dans lequel ils apparaissent

En effet une erreur de paramètre peut provoquer une erreur d'exécution du programme. On peut aussi numéroter les paramètres ; par exemple : "nom : %s ; prénom %s" => "last name : %1:s ; first name %0:s"

attention : la numérotation des paramètres commence à zéro 
ShowMessage(Format('Reposition after 3 strings = %s %s %s %1:s %s',['Zero', 'One', 'Two', 'Three']))
Reposition after 3 strings = Zero One Two One Two

Il existe un outil dans la traduction pour vérifier que les paramètres de format sont conservés entre le message natif et le message traduit.

Paramètre de format @

On trouvera également ce type de paramètre : "Le @code@ est erroné"


Saut de ligne <cr>

Dans certains exports, les sauts de lignes sont remplacés par le mot réservé "<cr>", ce mot ne doit pas être traduit Ces paramètres ne peuvent pas provoquer d'erreurs et leur ordre n'importe pas.

Le travail de qualité

Les problèmes qu'on est susceptible de rencontrer lors de l'utilisation du produit :

  • Un message non traduit car non extrait
  • Un message non traduit car non restitué (mais extrait)


Les problèmes qu'on est susceptible de rencontrer lors de la traduction :

  • Un message extrait abusivement
  • Un message extrait mais non traduisible ("erreur_code")

Ces problèmes sont à signaler.

Un processus itératif

Afin d'effectuer en parallèle le travail de traduction et de validation, un batch lancé chaque soir est prévu. Le batch reconstruit le dictionnaire application afin que les équipes de qualité bénéficient des traductions effectuées dans la journée. Ensuite on procède à une sauvegarde de chaque dictionnaires objets, par soucis de sécurité et de traçabilité. Enfin, on effectue une mise à jour du dictionnaire application, ce qui consiste en

  • une actualisation des dictionnaires objets (pour diffuser les traductions dans les autres dictionnaires objets contenant les mêmes messages)
  • une extraction afin de récupérer les éventuels nouveaux messages ajoutés par l'équipe projet ou outil.
  • une reconstruction du dictionnaire application

Ainsi, la qualité peut constater rapidement les problèmes et les dictionnaires sont à jours.

Guide de la traduction (trans)Développement DSM

Outils personnels