Hello Jeff, hello all,<br><br><b># First think to understand</b><br><br>I praise the Mapserver community and the team behind the engine.<br>I'm a big fan of Mapserver and Sphinx and I've always love the really great documentation but I know people who deal only with there native language to do the job. So translation is a core part of a project to extend popularity accross countries (althought Mapserver popularity is already established)<br>
<br>My motivation is to deal with the french translation with i18n and not with RST.<br>I want to make think better, the way we do it is good but can be improve.<br>Why? Some thoughts to explain below<br><br><br><b># Advantages</b><br>
<br><b><i>1. Fulfillment</i></b><br><br>Really important for me because a community is based on humans who search small and big achievements and it's more easy with i18n to measure the job.<br><br>Imagine one rst file of 1000 lines (around 100 lines of empty lines or special rst declarations)<br>
<br>You generate is equivalent in pot file.<br>The number of string to translate is 430 <br><br>Offline:<br>Step by step you see what you've done and can by example, see that you've done 86 lines so, 20% of the job is done for the file.<br>
Your objective to go until 30%. When you reach it, you're happy. You've done 10% more of the file translation.<br><br>Online:<br>See this online app based on pottle for the Qgis community. You can see the <a href="http://translate.qgis.org/fr/qgis-user-guide/" target="_blank">http://translate.qgis.org/fr/qgis-user-guide/</a> example.<br>
In this case, you can make a survey of users who contribute, you can review with others, you now if a file translation is completed. You can distribute task between the community of users and not only of advanced users / developpers.<br>
<br>You can have a dedicated community of translators who care about content and not about the way to use sphinx and others technical things.<br><br><b><i>2. Separate presentation from contents</i></b><br><br>When you generate pot files, the string length is quite short. You don't have to care too much about rst indent : you will not break anything.<br>
If the presentation change, you content don't. I'm thinking about the annual change for FOSS4G image. You have to backport it manually with a merge in every langage version.<br><br><i><b>3. History and maintainability</b></i><br>
<br><i>## The typical workflow now</i><br><br>You cut and paste a rst file and you make the translation. Ok it's nice!! Why does I need to care about i18n? This guy is crazy!!<br><br>Because now imagine, you've done the translation 3 years ago (your community said "do it" and it was done).<br>
<br>The content was in english (the letter are use to represent a block of content in master version and number for content of translated example)<br><br>In the past<br><br>English French<br>
<br>AAAAAAAAA 1111111<br>BBBBBBBBB 222222<br>CCCCCCCCC 333333<br>DDDDDDDDD 444444<br>EEEEEEEEE 555555<br>
GGGGGGGG 777777<br>HHHHHHHHH 888888<br><br>Nowadays<br><br>BBBBBBBBB ??????<br>CCCCCCCCC ??????<br>DDDDDDDDD ??????<br>
FFFFFFFFFF ??????<br>GGGGGGGG ??????<br>HHHHHHHHH ??????<br><br>The way you do if you kept during three years the file you use to translate the original<br>
<br>Compare both english version<br><br>AAAAAAAAA dissapear<br>BBBBBBBBB seems to stay the same (BBBBBBBBB is a block so are you sure there no typo fixed?)<br>CCCCCCCCC is the same<br>DDDDDDDDD is the same<br>EEEEEEEEE dissapear<br>
FFFFFFFFFF appear<br>GGGGGGGG is the same<br>HHHHHHHHH is the same<br><br>Now find in the french file the corresponding<br><br>I now AAAAAAAAA dissapear in english so let's go delete it in the french version<br><br>Find the equivalent in french of AAAAAAAAA (where it begins and finish) and delete it<br>
Find BBBBBBBBB block in english and see what was the french string corresponding and replace now<br>Do the same for CCCCCCCCC, DDDDDDDDD<br>EEEEEEEEE dissapear so where is french equivalent (more difficult to find where it begins and finish) to delete<br>
FFFFFFFFFF appear so translate<br>Find GGGGGGGGG block in english and see what was the french string corresponding and replace now.<br>Do the same for HHHHHHHHH.<br><br>You get at the end the result. You just do a semantic three way merge manually (and I haven't imagine a case where there was reordering of content or small string fix)<br>
<br>BBBBBBBBB 222222<br>CCCCCCCCC 333333<br>DDDDDDDDD 444444<br>FFFFFFFFFF 666666<br>GGGGGGGG 777777<br>
HHHHHHHHH 888888<br><br><i>## I18N workflow</i><br><br>First translation<br><br>English French<br><br>AAAAAAAAA 111111<br>BBBBBBBBB 222222<br>
CCCCCCCCC 333333<br>DDDDDDDDD 444444<br>EEEEEEEEE 555555<br>GGGGGGGG 777777<br>HHHHHHHHH 888888<br>
<br>In the future, (if community change nothing)<br><br>BBBBBBBBB ??????<br>CCCCCCCCC ??????<br>DDDDDDDDD ??????<br>FFFFFFFFFF ??????<br>
GGGGGGGG ??????<br>HHHHHHHHH ??????<br><br>The way how msgmerge or manual poedit merge do<br><br>Open the translated file at a time (po file), open the newly pot file and say merge.<br>
<br>What happen,<br>the block AAAAAAAAA match nothing compare to before so comment in the po file<br>BBBBBBBBB block match, keep it.<br>CCCCCCCCC block match, keep it.<br>DDDDDDDDD block match, keep it.<br>The block EEEEEEEEE match nothing compare to before so comment in the po file<br>
FFFFFFFFFF match nothing but wasn't there ,so add it<br>GGGGGGGG block match, keep it.<br>HHHHHHHHH block match, keep it.<br><br>The UI like poedit or pootle tell you, you only have to translate FFFFFFFFF, the three way merge is mostly done automatically.<br>
That the only job. Quite nice compare to before<br><br>You foreign (not english) language is more easily updated like that and small change are easy to see.<br><br><b># Drawbacks</b><br><br>1. Less flexibility because, the workflow to be in the core doc repository is to ask to integrate change in the english version (master version) and after, you backport everything in every langage.<br>
<br>2. Some content are outside of the i18n parsing with sphinx.<br>When you generate i18n strings, see also directive or caption (for legend of image) are not parsed. So you must refactor a bit the syntax for image caption to put the legend outside. The same for see also.<br>
<br>3. Need to add more explicit links in original doc<br>Example for the glossary :ref:`gis` must be replace with :ref:`gis <gis>`__ because not helpful for translators not aware of sphinx syntax (the problem is already the same nowadays)<br>
<br>Sorry for the long "monologue"<br><br>Any reactions welcome<br><br>Regards<br><br>ThomasG<br>