From Fedora Project Wiki
 
(13 intermediate revisions by the same user not shown)
Line 2: Line 2:
= Updated for =
= Updated for =
This page has been updated for '''Fedora 23'''.
This page has been updated for '''Fedora 23'''.
=Context=


While reviewing translation on Zanata, the reviewer may find some repetitive faults the translator has made. This kind of situation may result from various reasons such as:
{{admon/note|This page explains how to pull translated files from Zanata in order to review and correct them with more or less automated tools and then pushing them back to Zanata. It describes how to set up the tool to do that in an efficient way.}}
* Lack of attention by the translator to some aspects that are not always very visible while editing (e.g. double spaces)
* Ignorance by the translator of a grammar or punctuation rule that leads to repetition of the error (e.g. in French double punctuation – :,;,!,? – should be preceded by a fine non breakable space contrarily to the English language)
* Pure translation error for a repetitive word
* Any other unknown rule


In such a situation, Zanata's search and replace functionality is not of great help. To be able to search and replace repetitive faults, the reviewer has to pull  the translated files from Zanata, use some OS tools to do so and, eventually, push back the modified files to Zanata.
==Context==
Translation on Zanata is rather good and efficient. Nevertheless, when comes the time of reviewing the translation, getting the translated files locally in order to use some specialized and automated tools may be of greet help in the whole process. This page explain how to setup and use the zanata-client command line tool to do so.


The present page explains the different stages to accomplish this efficiently.
= Setting up the Tool Necessary to Pull from and Push to Zanata =
 
{{admon/note| This page assumes the reviewer is using Fedora as OS – see the "Updated for" section above.}}
 
= Setting up the Pull an Push Tool =
== Installing the Zanata Command Line Client ==
== Installing the Zanata Command Line Client ==
The necessary command line tool to pull and push from Zanata is the Zanata command line client (CLI) available in the ''zanata-client'' package. Please install it with:
The necessary command line tool to pull and push from Zanata is the Zanata command line client (CLI) available in the ''zanata-client'' package. Please install it with:
Line 26: Line 18:
To allow the user to be authenticated by the Zanata server,  the zanata-cli presents the user's credentials  it finds in the {{Path|~/.config/zanata.ini}} file to the server. Thus, the first thing to do is to create this {{Path|~/.config/zanata.ini}} file and add the user's credential in it. Fortunately, the Zanata server provides a very convenient way of doing so.  
To allow the user to be authenticated by the Zanata server,  the zanata-cli presents the user's credentials  it finds in the {{Path|~/.config/zanata.ini}} file to the server. Thus, the first thing to do is to create this {{Path|~/.config/zanata.ini}} file and add the user's credential in it. Fortunately, the Zanata server provides a very convenient way of doing so.  


To create you configuration file:
To create your configuration file:


# Use your favorite text editor to create the {{Path|~/.config/zanata.ini}} file.
# Use your favorite text editor to create the {{Path|~/.config/zanata.ini}} file.
Line 38: Line 30:




{{admon/note|These steps must be repeated for each project-version before using any zanata-cli commands for the project-version.}}
{{admon/note|These steps must be repeated for each project-version before using any zanata-cli commands for the project version.}}


Project configuration stores information specific to a project-version in the {{Path|~/{{Replace|project dir path}}/zanata.xml}} file – where {{Replace|project dir path}} should be replaced by the name of the project version's local directory . It helps the user to shorten the ''zanata-cli'' commands by providing default values for options to these commands.
Project configuration stores information specific to a project version in the {{Path|~/{{Replace|project dir path}}/zanata.xml}} file – where {{Replace|project dir path}} should be replaced by the name of the project version's local directory . It helps the user to shorten the ''zanata-cli'' commands by providing default values for options to these commands.


====Downloading the Configuration File  ====
====Downloading the Configuration File  ====
Line 69: Line 61:
where {{Replace|YOURLOCALE}} has to be replaced with your language code (e.g. fr).
where {{Replace|YOURLOCALE}} has to be replaced with your language code (e.g. fr).


== Proceeding to Massive Search and Replace in the Translated Files ==
= Getting the Files from Zanata =
 
To get the files for your language from Zanata use the following command from your project version folder:


{{admon/note|All the commands given from here on assume your current directory is {{Replace|LOCALE_CODE}}/ under the project version directory, where {{Replace|LOCALE_CODE}} has to be replaced with your language code (e.g. fr)}}
zanata-cli pull --pull-type both


{{admon/warning| Be aware that all the commands below  are rather dangerous, thus ensure you are in the right directory and the command doesn't include any typographic fault.}}
After the downloading, you should find the .pot files and a {{Replace|YOURLOCALE}} folder into the project version folder where {{Replace|YOURLOCALE}} is your language code. Change to the {{Replace|YOURLOCALE}} folder to use the search and replace commands described below.


===General Form of the Commands and Explanations ===
=Modifying the Translated Files Locally =
The general form of the search and replace commands is as follows:


grep -l '{{Replace|STRING_TO_SEARCH_FOR}}' ./* | xargs sed -i 's/{{Replace|STRING_TO_SEARCH_FOR}}/{{Replace|SUBSTITUTE_STRING}}/g'
Once the .po files have been downloaded locally, the user can use any tool he likes to edit the .po files before pushing them back to Zanata.


* '{{Replace|STRING_TO_SEARCH_FOR}}' is the pattern for grep
==Available tools ==
* the -l argument to grep stands for --files-with-matches  and makes the grep command print only names of files  containing matches
At the moment the following tools are available:
* the ./* argument to grep limits the search to the files under the current directory
* the xargs command presents the grep output name of files as arguments to the sed command
* the sed command proceeds to the replacement
* the g option to the sed command tells that the replacement should applied globally on the lines


=== Searching Multiple Spaces and Replacing with a Unique Space ===
* [[L10N/Typo_Purification_of_po_Files|po_typo_purifier.py ]]: a tool to check translated messages against typographic rules declared in a configuration file.


grep -l ' \+' ./* | xargs sed -i 's/ \+/ /g'
= Saving your Work into Zanata =


=== Ensuring an Unbreakable Space is Inserted Before Double Punctuations (French language) ===
To push back your modified translated files into the Zanata server, use the following command:
In the French Language double punctuation i.e. ?,!,;,: require a narrow no-break space between them and the word that precedes. To ensure this rule is always applied, use the following command:


  grep -l [^'\s][?!;:]' ./* |xargs sed -i 's/\([a-zA-Z0-9 ]\)\([?!;:]\)/\1 \2/g'
  zanata-cli push --push-type trans --merge-type auto


Explanation:
* the first term of the substitute command in sed is formed of 2 groups ([a-zA-Z0-9]) which represents any alphanumerical character or space (invisible here) and ([?!;:]) which is 1 among the 4 double punctutations. Parenthesis must be escaped.
* the second term is group1, narrow no-break space (invisible here), and group 2


{{admon/note|If your keyboard doesn't permit you to enter the narrow no-break space, use the {{Key|ctrl}} '''+''' {{Key|Shift}} '''+''' {{Key|u}} key combination. This should make a <u>u</u> be displayed in your editor, then enter the unicode for the narrow no-break space which is: 202F and release all the keys}}


{{admon/note| Generally, very few fonts offer the narrow no-break space (202F) thus it may be replaced by the normal no-break space (00A0).}}
[[Category:Localization]]

Latest revision as of 10:55, 2 June 2016

Updated for

This page has been updated for Fedora 23.

This page explains how to pull translated files from Zanata in order to review and correct them with more or less automated tools and then pushing them back to Zanata. It describes how to set up the tool to do that in an efficient way.

Context

Translation on Zanata is rather good and efficient. Nevertheless, when comes the time of reviewing the translation, getting the translated files locally in order to use some specialized and automated tools may be of greet help in the whole process. This page explain how to setup and use the zanata-client command line tool to do so.

Setting up the Tool Necessary to Pull from and Push to Zanata

Installing the Zanata Command Line Client

The necessary command line tool to pull and push from Zanata is the Zanata command line client (CLI) available in the zanata-client package. Please install it with:

su -c 'dnf -y install zanata-client' 

Configuring the Zanata Client

User Configuration

To allow the user to be authenticated by the Zanata server, the zanata-cli presents the user's credentials it finds in the ~/.config/zanata.ini file to the server. Thus, the first thing to do is to create this ~/.config/zanata.ini file and add the user's credential in it. Fortunately, the Zanata server provides a very convenient way of doing so.

To create your configuration file:

  1. Use your favorite text editor to create the ~/.config/zanata.ini file.
  2. Login into the Zanata server and navigate to the user's Settings page – click on the user's avatar in the top-right corner and, in the drop down menu that opens, chose Settings.
  3. Click the <> Client link.
  4. Ensure an API key is displayed. If not, click on the Generate API Key button to create one.
  5. Copy the content of the Configuration[zanata.ini] text-box.
  6. Past the copied lines into the ~/.ini/zanata.ini file and save it.

Project Version Configuration

These steps must be repeated for each project-version before using any zanata-cli commands for the project version.

Project configuration stores information specific to a project version in the ~/<project dir path>/zanata.xml file – where <project dir path> should be replaced by the name of the project version's local directory . It helps the user to shorten the zanata-cli commands by providing default values for options to these commands.

Downloading the Configuration File

The ~/<project dir path>/zanata.xml can be customized after a base for it has been downloaded from the Zanata server. To download this configuration base, please, once connected to the server, do the followings:

  1. Navigate the project version page – the one that presents a list of languages for the project version.
  2. Click on the v … link just below the user's avatar in the top-right part of the page.
  3. Click on the Download Configuration File link and save the file into your ~/<project dir path> folder.

The downloaded file should look like the following:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<config xmlns="http://zanata.org/namespace/config/">
  <url>https://fedora.zanata.org/</url>
  <project>fedora-installation-guide</project>
  <project-version>f23</project-version>
  <project-type>podir</project-type>

</config>

Customizing the Configuration File

Locale

While using the Zanata CLI, if no further indication about the locale is provided with the command, the po and pot files of every Zanata recognized language will be downloaded. In order to systematically add a locale indication to the command, the zanata.xml file of the project version can be customized. To limit the download to your locale, please add the following lines into the <config> xml element in your zanata.xml file:

<locales>
  <locale><YOURLOCALE><locale>
<locales>

where <YOURLOCALE> has to be replaced with your language code (e.g. fr).

Getting the Files from Zanata

To get the files for your language from Zanata use the following command from your project version folder:

zanata-cli pull --pull-type both

After the downloading, you should find the .pot files and a <YOURLOCALE> folder into the project version folder where <YOURLOCALE> is your language code. Change to the <YOURLOCALE> folder to use the search and replace commands described below.

Modifying the Translated Files Locally

Once the .po files have been downloaded locally, the user can use any tool he likes to edit the .po files before pushing them back to Zanata.

Available tools

At the moment the following tools are available:

  • po_typo_purifier.py : a tool to check translated messages against typographic rules declared in a configuration file.

Saving your Work into Zanata

To push back your modified translated files into the Zanata server, use the following command:

zanata-cli push --push-type trans --merge-type auto