changes necessary to actually return a translation based on revision

hash of R.java passed by client, or none if it already has it.  Rough,
but works.
This commit is contained in:
Eric House 2014-05-02 22:00:25 -07:00
parent 56a057f06c
commit ad65b93ef2
2 changed files with 68 additions and 64 deletions

View file

@ -2,7 +2,8 @@
# Script meant to be installed on eehouse.org. # Script meant to be installed on eehouse.org.
import logging, shelve, hashlib, sys, json, subprocess, glob, os import logging, shelve, hashlib, sys, json, subprocess, glob, os
import mk_for_download import mk_for_download, mygit
import xwconfig
from stat import ST_CTIME from stat import ST_CTIME
try: try:
@ -12,6 +13,7 @@ except ImportError:
apacheAvailable = False apacheAvailable = False
# constants that are also used in UpdateCheckReceiver.java # constants that are also used in UpdateCheckReceiver.java
VERBOSE = False
k_NAME = 'name' k_NAME = 'name'
k_AVERS = 'avers' k_AVERS = 'avers'
k_GVERS = 'gvers' k_GVERS = 'gvers'
@ -24,6 +26,8 @@ k_CALLBACK = 'callback'
k_LOCALE = 'locale' k_LOCALE = 'locale'
k_XLATPROTO = 'proto' k_XLATPROTO = 'proto'
k_XLATEVERS = 'xlatevers' k_XLATEVERS = 'xlatevers'
k_STRINGSHASH = 'strings'
k_OLD = 'old' k_OLD = 'old'
k_NEW = 'new' k_NEW = 'new'
k_PAIRS = 'pairs' k_PAIRS = 'pairs'
@ -133,7 +137,7 @@ def getOrderedApks( path ):
files = ((os.stat(apk).st_mtime, apk) for apk in glob.glob(pattern)) files = ((os.stat(apk).st_mtime, apk) for apk in glob.glob(pattern))
for mtime, file in sorted(files, reverse=True): for mtime, file in sorted(files, reverse=True):
logging.debug( file + ": " + str(mtime) ) # logging.debug( file + ": " + str(mtime) )
apks.append( file ) apks.append( file )
return apks return apks
@ -178,11 +182,11 @@ def dictVersion( req, name, lang, md5sum ):
if 'close' in s_shelf: s_shelf.close() if 'close' in s_shelf: s_shelf.close()
return json.dumps( result ) return json.dumps( result )
def getApp( params ): def getApp( params, name ):
result = None result = None
if k_NAME in params: if k_NAME in params:
name = params[k_NAME] name = params[k_NAME]
if name:
# If we're a dev device, always push the latest # If we're a dev device, always push the latest
if k_DEVOK in params and params[k_DEVOK]: if k_DEVOK in params and params[k_DEVOK]:
apks = getOrderedApks( k_filebase + k_apkDir ) apks = getOrderedApks( k_filebase + k_apkDir )
@ -246,17 +250,54 @@ def getDicts( params ):
if 0 == len(result): result = None if 0 == len(result): result = None
return result return result
def getXlate( params ): def variantFor( name ):
result = [] if name == 'xw4': result = 'XWords4'
logging.debug( "getXlate:" + json.dumps(params) ) logging.debug( 'variantFor(%s)=>%s' % (name, result))
for entry in params: return result
locale = entry[k_LOCALE]
curVers = entry[k_XLATEVERS]
data = mk_for_download.getXlationFor( k_filebase + 'xw4', locale ) def getXlate( params, name, stringsHash ):
result = []
path = xwconfig.k_REPOPATH
logging.debug('creating repo with path ' + path)
repo = mygit.GitRepo( path )
logging.debug( "getXlate: %s, hash=%s" % (json.dumps(params), stringsHash) )
# logging.debug( 'status: ' + repo.status() )
# reduce org.eehouse.anroid.xxx to xxx, then turn it into a
# variant and get the contents of the R.java file
splits = name.split('.')
name = splits[len(splits)-1]
variant = variantFor( name );
rPath = '%s/archive/R.java' % variant
rDotJava = repo.cat( rPath, stringsHash )
# Figure out the newest hash possible for translated strings.xml
# files. If our R.java's the newest, that's HEAD. Otherwise it's
# the revision BEFORE the revision that changed R.java
head = repo.getHeadRev()
logging.debug('head = %s' % head)
rjavarevs = repo.getRevsBetween(head, stringsHash, rPath)
assert( 1 >= len(rjavarevs) )
assert( stringsHash == rjavarevs[len(rjavarevs)-1] )
if 1 == len(rjavarevs):
firstPossible = head
else:
firstPossible = rjavarevs[len(rjavarevs)-2] + '^'
# get actual number for rev^
firstPossible = repo.getRevsBetween( firstPossible, firstPossible )[0]
logging.debug('firstPossible: %s' % firstPossible)
for entry in params:
curVers = entry[k_XLATEVERS]
if not curVers == firstPossible:
locale = entry[k_LOCALE]
data = mk_for_download.getXlationFor( repo, rDotJava, locale, \
firstPossible )
if data: result.append( { k_LOCALE: locale, if data: result.append( { k_LOCALE: locale,
k_OLD: curVers, k_OLD: curVers,
k_NEW: curVers + "_new", k_NEW: firstPossible,
k_PAIRS: data, k_PAIRS: data,
} ) } )
@ -270,16 +311,17 @@ def getUpdates( req, params ):
logging.debug( "getUpdates: got params: %s" % params ) logging.debug( "getUpdates: got params: %s" % params )
asJson = json.loads( params ) asJson = json.loads( params )
if k_APP in asJson: if k_APP in asJson:
appResult = getApp( asJson[k_APP] ) name = None
if k_NAME in asJson: name = asJson[k_NAME]
appResult = getApp( asJson[k_APP], name )
if appResult: if appResult:
result[k_APP] = appResult result[k_APP] = appResult
if k_DICTS in asJson: if k_DICTS in asJson:
dictsResult = getDicts( asJson[k_DICTS] ) dictsResult = getDicts( asJson[k_DICTS] )
if dictsResult: if dictsResult:
result[k_DICTS] = dictsResult result[k_DICTS] = dictsResult
if k_XLATEINFO in asJson: if k_XLATEINFO in asJson and k_NAME in asJson and k_STRINGSHASH in asJson:
logging.debug( "found xlate info; calling getXlate" ) xlateResult = getXlate( asJson[k_XLATEINFO], asJson[k_NAME], asJson[k_STRINGSHASH] )
xlateResult = getXlate( asJson[k_XLATEINFO] )
if xlateResult: if xlateResult:
logging.debug( xlateResult ) logging.debug( xlateResult )
result[k_XLATEINFO] = xlateResult; result[k_XLATEINFO] = xlateResult;

View file

@ -72,55 +72,17 @@ def asMap( repo, rev, path, ids ):
# second revision in that list is the identifier of the newest # second revision in that list is the identifier of the newest
# strings.xml we an safely use. # strings.xml we an safely use.
# #
def getXlationFor( repo, rDotJava, rDotHash, locale ): def getXlationFor( repo, rDotJava, locale, firstHash ):
ids = readIDs(rDotJava) ids = readIDs(rDotJava)
assert rDotHash == '33a83b0e2fcf062f4f640ccab0785b2d2b439542' eng = asMap( repo, firstHash, english, ids )
############################################################
# This clusterf*ck needs to be rewritten!!!!
############################################################
# Find the hash that's sure to include the newest strings.xml files
# compatible with the R.java indicated by the app hash
head = repo.getHeadRev()
locFileName = other_f % (locale) locFileName = other_f % (locale)
newerRDotJavas = repo.getRevsBetween( head, rDotHash, 'R.java' ) other = asMap( repo, firstHash, locFileName, ids )
print 'newerRDotJavas:', newerRDotJavas
assert newerRDotJavas[len(newerRDotJavas)-1] == rDotHash
# If newerRDotJavas is of length 1, there have been no changes to
# R.java since the client shipped so we can safely use HEAD for
# locale files. Otherwise there's more work to do
if 1 == len(newerRDotJavas):
locFileRev = head
else:
newerRDot = newerRDotJavas[len(newerRDotJavas)-2]
print 'last rev before new R.java:', newerRDot
# now find the newest revision of our file prior to the change in
# R.java. Worst case we use the hash of R.java passed in
locFileRev = rDotHash
newestToRDot = repo.getRevsBetween( newerRDot, rDotHash, locFileName )
print 'newestToRDot:', newestToRDot
# If the list includes newerRDot, that's an entry we can't use.
if newestToRDot and newestToRDot[0] == newerRDot:
newestToRDot = newestToRDot[1:]
if 0 == len(newestToRDot): newestToRDot = None
if newestToRDot: locFileRev = newestToRDot[0]
print 'rev of locale string.xml:', locFileRev
eng = asMap( repo, locFileRev, english, ids )
other = asMap( repo, locFileRev, locFileName, ids )
result = [] result = []
for key in eng.keys(): for key in eng.keys():
if key in other: if key in other:
result.append( { 'id' : key, 'loc' : other[key] } ) result.append( { 'id' : key, 'loc' : other[key] } )
return result, locFileRev return result
def main(): def main():
repo = mygit.GitRepo( xwconfig.k_REPOPATH ) repo = mygit.GitRepo( xwconfig.k_REPOPATH )
@ -129,9 +91,9 @@ def main():
hash = '33a83b0e2fcf062f4f640ccab0785b2d2b439542' hash = '33a83b0e2fcf062f4f640ccab0785b2d2b439542'
rDotJava = repo.cat( 'R.java', hash ) rDotJava = repo.cat( 'R.java', hash )
data, newHash = getXlationFor( repo, rDotJava, hash, 'ca_PS' ) data, newHash = getXlationFor( repo, rDotJava, 'ca_PS', hash )
print 'data for:', newHash, ':' , data print 'data for:', newHash, ':' , data
data, newHash = getXlationFor( repo, rDotJava, hash, 'ba_CK' ) data, newHash = getXlationFor( repo, rDotJava, 'ba_CK', hash )
print 'data for:', newHash, ':' , data print 'data for:', newHash, ':' , data
############################################################################## ##############################################################################