Skip to main content

A framework to allow im and export of xliff files for translations

Project description

slc.xliff Package Readme
========================

Overview
--------

XLIFF (XML Localization Interchange File Format) is an XML-based format created to standardize localization. slc.xliff is a framework to allow export of Plone content to XLIFF files for translation and also to import the translated XLIFF files.


Translating content using XLIFF
-------------------------------

------
Export
------

Most content objects in Plone can be exported to XLIFF. On any page in a portal you can select *Actions->XLIFF Export*. Here you have the following options:

* Recursive subtree export?
* Generate a single file?
* Download as zip?
* HTML compatibility mode (recommended)
* Export my current Shoppinglist

These options are mostly self explanatory. The Shoppinglist functionality lets you select a variety of objects via the *Actions->Add to shopping list* menu and then export them all at once from the *Xliff Export* form.

If your translator is able to read XLIFF natively (e.g. the translation program *Trados* is able to do that), send the native xliff version, otherwise make sure you have checked the HTML compatibility option. That generates an HTMLized XLIFF version which can be edited and translated using a common HTML editor.

The XLIFF file contains a reference to the id of the object translated as well as the path. This means it will still work correctly even if the path to the item has changed.

------
Import
------

When the translations have been returned they can be imported via the *Actions->Import Xliff* menu. Select *HTML compatibility mode* if the XLIFF file also used that option, or if an XML version was mistakenly edited in an HTML editor and converted by the translator.

A single .xliff file can be uploaded which contains multiple translations. Alternatively a .zip file can be uploaded which contains many .xliff files. If the filenames are prefixed with the language code then that code will be used to determine the language, even if the target-language attribute is not set correctly e.g. my-test-file_de.xliff will be treated as the German translation of my-test-file.

---------------------
XLIFF format overview
---------------------

Some sample XLIFF::

<file original="/osha/portal/Members/test-user/a-very-interesting-report" oid="6c4858d40cdcb7bce24aacead4er6a26" source-language="en" target-language="en">
<body>
<group>
<trans-unit id="title">
<source xml:lang='en'>
<!-- A interesting report -->
</source>
<target xml:lang='en'>
A interesting report
</target>
</trans-unit>

<trans-unit id="description">
<source xml:lang='en'>
<!-- A report on a wide variety of topics. -->
</source>
<target xml:lang='en'>
A report on a wide variety of topics.
</target>
</trans-unit>

Note that the oid refers to the unique ID of the item. The translator will edit the content inside the *target* entities.

Credits
=======

Copyright European Agency for Health and Safety at Work and Syslab.com
GmbH.

slc.xliff development was funded by the European Agency for Health and
Safety at Work.


License
=======

slc.xliff is licensed under the GNU Lesser Generic Public License,
version 2 or later and EUPL version 1.1 only. The complete license
texts can be found in docs/LICENSE.GPL and docs/LICENSE.EUPL.

slc.xliff Changelog
===================

1.3 (2012-09-17)
----------------

- Plone 4

1.2.2 (unreleased)
------------------

- Set a document's text_format (e.g. text/html) based on the source's
setting (thomasw)

1.2.1 (2009-12-13)
------------------

- Bugfix, wrong dummy interface definition (thomasw)


1.2 (2009-12-13)
----------------

- Added EUPL license (deroiste)
- When exporting by path, sort results by pyth (shortest first),
to make sure top-level objects come first. (thomasw)
- Enabled epoxrt of slc.seminarportal's Seminar (thomasw)


slc.xliff 1.1 (2009-06-19)
--------------------------

- code cleanup (gerken)

- fixed tests (gerken)

slc.xliff 1.0 (2008-03-31)
--------------------------

- packaged egg

slc.xliff 1.0b1
---------------

* Added export support for IObjectManager
* Added browser views, actions

slc.xliff 1.0a1
---------------

* port from eITXliffTool to slc.xliff plone3 compatible



Detailed Documentation
**********************

How it works
============

please see the doc/ directory

TODO
----

Currently untested are:

- html compatibility export and import


HTML Compatibility
------------------

Unfortunately some translators still only can translate using html editors. For this case we supply an htmlized form of the xliff file which adds an html header. It also hides the source tags and adds the source language into the target tag so that it can be translated by replacing it. There is a flag to use compatibility mode.

There is a log output which explicitly states which languages have been uploaded and where parsing problems have occured. Note that in html compatibility mode you are responsible yourself to check if the results are good.


Contributors
************

- Patrick Gerken (Syslab.com GmbH)
- Wolfgang Thomas (Syslab.com GmbH)
- Alexander Pilz (Syslab.com GmbH)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

slc.xliff-1.3.zip (69.4 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page