2014-04-21 16:13:41 +02:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
2014-04-24 15:24:38 +02:00
|
|
|
import re, sys
|
2014-04-21 16:13:41 +02:00
|
|
|
from lxml import etree
|
2014-04-30 16:25:23 +02:00
|
|
|
import mygit, xwconfig
|
2014-04-21 16:13:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
# Take an English strings.xml file and another, "join" them on the
|
|
|
|
# name of each string, and then produce an array that's a mapping of
|
|
|
|
# English to the other. Get ride of extra whitespace etc in the
|
|
|
|
# English strings so they're identical to how an Android app displays
|
|
|
|
# them.
|
|
|
|
|
|
|
|
english = 'res/values/strings.xml'
|
|
|
|
other_f = 'res_src/values-%s/strings.xml'
|
|
|
|
|
2014-04-30 16:25:23 +02:00
|
|
|
def readIDs(rDotJava):
|
2014-04-24 15:24:38 +02:00
|
|
|
ids = {}
|
|
|
|
start = re.compile('\s*public static final class string {\s*')
|
|
|
|
end = re.compile('\s*}\s*')
|
|
|
|
entry = re.compile('\s*public static final int (\S+)=(0x.*);\s*')
|
|
|
|
inLine = False
|
2014-04-30 16:25:23 +02:00
|
|
|
for line in rDotJava.splitlines():
|
2014-04-24 15:24:38 +02:00
|
|
|
if inLine:
|
|
|
|
if end.match(line):
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
match = entry.match(line)
|
|
|
|
if match:
|
|
|
|
name = match.group(1)
|
|
|
|
value = int(match.group(2), 16)
|
|
|
|
ids[name] = value
|
|
|
|
elif start.match(line):
|
|
|
|
inLine = True
|
|
|
|
return ids
|
|
|
|
|
2014-04-30 16:25:23 +02:00
|
|
|
def asMap( repo, rev, path, ids ):
|
2014-05-05 01:26:35 +02:00
|
|
|
map = None
|
2014-04-30 16:25:23 +02:00
|
|
|
data = repo.cat( path, rev )
|
2014-05-05 01:26:35 +02:00
|
|
|
if data:
|
|
|
|
map = {}
|
|
|
|
doc = etree.fromstring( data )
|
|
|
|
for elem in doc.iter():
|
|
|
|
if 'string' == elem.tag:
|
|
|
|
text = elem.text
|
|
|
|
if text:
|
|
|
|
# print 'text before:', text
|
|
|
|
text = " ".join(re.split('\s+', text)) \
|
|
|
|
.replace("\\'", "'") \
|
|
|
|
.replace( '\\"', '"' )
|
|
|
|
# print 'text after:', text
|
|
|
|
name = elem.get('name')
|
|
|
|
# All should be there, but aren't yet, and I wanna
|
|
|
|
# test
|
|
|
|
if name in ids:
|
|
|
|
id = ids[name]
|
|
|
|
map[id] = text
|
2014-04-21 16:13:41 +02:00
|
|
|
return map
|
|
|
|
|
2014-04-30 16:25:23 +02:00
|
|
|
# Build from the most recent revisions of the english and locale
|
2014-05-01 17:15:42 +02:00
|
|
|
# strings.xml files that are compatible with (haven't changed since)
|
2014-04-30 16:25:23 +02:00
|
|
|
# stringsHash on the R.java file. For now, just get what matches,
|
|
|
|
# assuming that all are updated with the same commit -- which they
|
|
|
|
# aren't.
|
2014-05-01 17:15:42 +02:00
|
|
|
#
|
|
|
|
# The stringsHash is hard-coded for an app that's shipped (and based
|
|
|
|
# on its R.java file), but both the English and (especially) the
|
|
|
|
# non-English strings.xml files can change after. We want the newest
|
|
|
|
# of each that's still compatible with the ids compiled into the app.
|
|
|
|
# So we look for any change to R.java newer than stringsHash, and move
|
|
|
|
# backwards from one-before there to find the first (newest) version
|
|
|
|
# of the english and localized strings.xml
|
|
|
|
#
|
|
|
|
# So for R.java, we generate a list of revisions of it from HEAD back
|
|
|
|
# to the one we know. Taking the revision immediately after the one
|
|
|
|
# we know, we generate a list from it back to the one we know. The
|
|
|
|
# second revision in that list is the identifier of the newest
|
|
|
|
# strings.xml we an safely use.
|
|
|
|
#
|
2014-05-03 07:00:25 +02:00
|
|
|
def getXlationFor( repo, rDotJava, locale, firstHash ):
|
2014-04-30 16:25:23 +02:00
|
|
|
ids = readIDs(rDotJava)
|
2014-05-01 17:15:42 +02:00
|
|
|
|
2014-05-03 07:00:25 +02:00
|
|
|
eng = asMap( repo, firstHash, english, ids )
|
2014-05-05 01:26:35 +02:00
|
|
|
other = asMap( repo, firstHash, other_f % (locale), ids )
|
|
|
|
if not other:
|
|
|
|
locale = locale.split('_')
|
|
|
|
if 2 == len(locale):
|
|
|
|
other = asMap( repo, firstHash, other_f % (locale[0]), ids )
|
2014-04-21 16:13:41 +02:00
|
|
|
result = []
|
2014-05-05 01:26:35 +02:00
|
|
|
if other:
|
|
|
|
for key in eng.keys():
|
|
|
|
if key in other:
|
|
|
|
result.append( { 'id' : key, 'loc' : other[key] } )
|
2014-05-03 07:00:25 +02:00
|
|
|
return result
|
2014-04-21 16:13:41 +02:00
|
|
|
|
|
|
|
def main():
|
2014-04-30 16:25:23 +02:00
|
|
|
repo = mygit.GitRepo( xwconfig.k_REPOPATH )
|
2014-05-06 16:25:00 +02:00
|
|
|
head = repo.getHeadRev()
|
2014-05-01 17:15:42 +02:00
|
|
|
|
|
|
|
# testing with the most recent (as of now) R.java change
|
2014-05-06 16:25:00 +02:00
|
|
|
hash = repo.getRevsBetween( head, '33a83b0e2fcf062f4f640ccab0785b2d2b439542', \
|
|
|
|
'R.java' )[0]
|
|
|
|
print 'using hash:', hash
|
2014-05-01 17:15:42 +02:00
|
|
|
|
2014-04-30 16:25:23 +02:00
|
|
|
rDotJava = repo.cat( 'R.java', hash )
|
2014-05-06 16:25:00 +02:00
|
|
|
data = getXlationFor( repo, rDotJava, 'ca_PS', hash )
|
|
|
|
print 'data :' , data
|
|
|
|
data = getXlationFor( repo, rDotJava, 'ba_CK', hash )
|
|
|
|
print 'data :' , data
|
2014-04-21 16:13:41 +02:00
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|