summaryrefslogtreecommitdiff
path: root/l10ntools/scripts/tool/xtxex.py
blob: 96912754b7dffdbdc8f6e7895a84951401fe3b60 (plain)
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
#*************************************************************************
#
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# 
# Copyright 2000, 2010 Oracle and/or its affiliates.
#
# OpenOffice.org - a multi-platform office productivity suite
#
# This file is part of OpenOffice.org.
#
# OpenOffice.org is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License version 3
# only, as published by the Free Software Foundation.
#
# OpenOffice.org 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 Lesser General Public License version 3 for more details
# (a copy is included in the LICENSE file that accompanied this code).
#
# You should have received a copy of the GNU Lesser General Public License
# version 3 along with OpenOffice.org.  If not, see
# <http://www.openoffice.org/license.html>
# for a copy of the LGPLv3 License.
#
#*************************************************************************

from l10ntool import AbstractL10nTool
from sdf import SdfEntity
import sys
import shutil 

class Xtxex(AbstractL10nTool):
    _resource_type       = "xtx" 
       
    def __init__(self):
        AbstractL10nTool.__init__(self)
        
    def merge_file(self, inputfilename, outputfilename, parsed_file_ref, lang, is_forced_lang, sdfdata): 
        # Special handling for en-US files
        if lang == "en-US":             
            mod_outputfilename = outputfilename
            # mod here if needed
            self.copy_file(inputfilename, mod_outputfilename)
            return      
        # merge usual lang
        sdfline = self.prepare_sdf_line(inputfilename,lang)
        if sdfdata.has_key(sdfline.get_id()):
            line = sdfdata[sdfline.get_id()].text.replace("\\n", '\n')
            self.make_dirs(outputfilename)
            try:
                f = open(outputfilename, "w+")
                f.write(line)
            except IOError:
                print "ERROR: Can not write file " + outputfilename
                sys.exit(-1)
            else:
                f.close()
            return        
        # no sdf data found then copy en-US source file
        if is_forced_lang:
            self.copy_file(inputfilename, outputfilename)
               
    ##### Extract a single File
    def extract_file(self, inputfile):
        lines = []
        try:
            f = open(inputfile, "r")
            lines = f.readlines()
        except IOError:
            print "ERROR: Can not open file " + inputfile
            sys.exit(-1)
        else:
            f.close()
        # remove legal header
        lines = [line for line in lines if len(line) > 0 and not line[0] == '#']        
        # escape all returns
        lines = [line.replace('\n', "\\n") for line in lines]
        line = ''.join(lines)
        test = str(line)
        if len(test.strip()):
            sdf_entity = self.prepare_sdf_line(inputfile);
            sdf_entity.text = line
            return str(sdf_entity)
        else:
            return ""

    def prepare_sdf_line(self, inputfile="", lang=""):
        if lang == "":
            lang = self._source_language
        return SdfEntity(project=self._options.project_name, source_file=self.get_filename_string(inputfile),
                          resource_type=self._resource_type, gid="none", lid="none", langid=lang,text="")
         
run = Xtxex()