/usr/share/pyshared/translate/convert/xliff2po.py is in translate-toolkit 1.10.0-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 | #!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Copyright 2002-2009 Zuza Software Foundation
#
# This file is part of the Translate Toolkit.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <http://www.gnu.org/licenses/>.
"""Convert XLIFF localization files to Gettext PO localization files.
See: http://docs.translatehouse.org/projects/translate-toolkit/en/latest/commands/xliff2po.html
for examples and usage instructions.
"""
from translate.storage import po
from translate.storage import xliff
from translate.misc import wStringIO
class xliff2po:
def converttransunit(self, transunit):
"""makes a pounit from the given transunit"""
thepo = po.pounit()
# Header
if transunit.getrestype() == "x-gettext-domain-header":
thepo.source = ""
else:
thepo.source = transunit.source
thepo.target = transunit.target
# Location comments
locations = transunit.getlocations()
if locations:
thepo.addlocations(locations)
# NOTE: Supporting both <context> and <note> tags in xliff files
# for comments
# Translator comments
trancomments = transunit.getnotes("translator")
if trancomments:
thepo.addnote(trancomments, origin="translator")
# Automatic and Developer comments
autocomments = transunit.getnotes("developer")
if autocomments:
thepo.addnote(autocomments, origin="developer")
# See 5.6.1 of the spec. We should not check fuzzyness, but approved
# attribute
if transunit.isfuzzy():
thepo.markfuzzy(True)
return thepo
def convertstore(self, inputfile):
"""Converts a .xliff file to .po format"""
# XXX: The inputfile is converted to string because Pootle supplies
# XXX: a PootleFile object as input which cannot be sent to PoXliffFile
# XXX: The better way would be to have a consistent conversion API.
if not isinstance(inputfile, (file, wStringIO.StringIO)):
inputfile = str(inputfile)
XliffFile = xliff.xlifffile.parsestring(inputfile)
thetargetfile = po.pofile()
targetheader = thetargetfile.header()
# TODO: support multiple files
for transunit in XliffFile.units:
if transunit.isheader():
thetargetfile.updateheader(add=True, **XliffFile.parseheader())
if transunit.getnotes('translator'):
targetheader.addnote(transunit.getnotes('translator'),
origin='translator',
position='replace')
if transunit.getnotes('developer'):
targetheader.addnote(transunit.getnotes('developer'),
origin='developer',
position='replace')
targetheader.markfuzzy(transunit.isfuzzy())
continue
thepo = self.converttransunit(transunit)
thetargetfile.addunit(thepo)
return thetargetfile
def convertxliff(inputfile, outputfile, templates):
"""reads in stdin using fromfileclass, converts using convertorclass,
writes to stdout"""
convertor = xliff2po()
outputstore = convertor.convertstore(inputfile)
if outputstore.isempty():
return 0
outputfile.write(str(outputstore))
return 1
def main(argv=None):
from translate.convert import convert
formats = {"xlf": ("po", convertxliff)}
parser = convert.ConvertOptionParser(formats, usepots=True,
description=__doc__)
parser.add_duplicates_option()
parser.run(argv)
|