X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=po%2Fxml2po.py;h=8108caeb5c1f667939c98ad8d2ee405eeea5d460;hb=029c97915f5048d0e03b6fefe92b7829b336a65d;hp=382f2d894d42fb058ede318d7e2a3a48f1e9c582;hpb=d2b1dcb3466ed5476094d9ff445d1df1b4ed14ff;p=vuplus_dvbapp diff --git a/po/xml2po.py b/po/xml2po.py index 382f2d8..8108cae 100755 --- a/po/xml2po.py +++ b/po/xml2po.py @@ -1,25 +1,43 @@ #!/usr/bin/python import sys import os +import string from xml.sax import make_parser -from xml.sax.handler import ContentHandler - -class parseXML(ContentHandler): +from xml.sax.handler import ContentHandler, property_lexical_handler +try: + from _xmlplus.sax.saxlib import LexicalHandler + no_comments = False +except ImportError: + class LexicalHandler: + pass + no_comments = True + +class parseXML(ContentHandler, LexicalHandler): def __init__(self, attrlist): self.isPointsElement, self.isReboundsElement = 0, 0 self.attrlist = attrlist + self.last_comment = None + + def comment(self, comment): + if comment.find("TRANSLATORS:") != -1: + self.last_comment = comment def startElement(self, name, attrs): - if (attrs.has_key('text')): - attrlist[attrs.get('text', "")] = "foo" + for x in ["text", "title", "value", "caption"]: + try: + attrlist.add((attrs[x], self.last_comment)) + self.last_comment = None + except KeyError: + pass parser = make_parser() -attrlist = {} +attrlist = set() contentHandler = parseXML(attrlist) parser.setContentHandler(contentHandler) - +if not no_comments: + parser.setProperty(property_lexical_handler, contentHandler) dir = os.listdir(sys.argv[1]) for x in dir: if (str(x[-4:]) == ".xml"): @@ -27,9 +45,17 @@ for x in dir: #parser.parse(sys.argv[1]) -for k, v in attrlist.items(): +attrlist = list(attrlist) +attrlist.sort(key=lambda a: a[0]) + +for (k,c) in attrlist: print print '#: ' + sys.argv[1] - print 'msgid "' + str(k) + '"' - print 'msgstr ""' + string.replace(k, "\\n", "\"\n\"") + if c: + for l in c.split('\n'): + print "#. ", l + if str(k) != "": + print 'msgid "' + str(k) + '"' + print 'msgstr ""'