mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-09 05:24:44 +01:00
Merge branch 'android_branch' into relay_noconn
Conflicts: xwords4/android/XWords4/archive/R.java xwords4/android/XWords4/jni/Android.mk xwords4/android/XWords4/jni/xwjni.c xwords4/android/XWords4/res/values/common_rsrc.xml
This commit is contained in:
commit
ec581d1dbd
4 changed files with 176 additions and 84 deletions
|
@ -324,7 +324,7 @@
|
||||||
<string name="vs_join">" vs. "</string>
|
<string name="vs_join">" vs. "</string>
|
||||||
|
|
||||||
<plurals name="strd_remains_header_fmt">
|
<plurals name="strd_remains_header_fmt">
|
||||||
<item quantity="one">%1$d fitxes romanents al sac.</item>
|
<item quantity="one">Queden %1$d fitxes al sac.</item>
|
||||||
<item quantity="other"/>
|
<item quantity="other"/>
|
||||||
</plurals>
|
</plurals>
|
||||||
<plurals name="strd_remains_expl_fmt">
|
<plurals name="strd_remains_expl_fmt">
|
||||||
|
@ -893,7 +893,7 @@
|
||||||
<string name="sms_bad_proto_fmt">La versió del Crosswords al telèfon amb número «%1$s» no és compatible amb aquest per a jugar via SMS. Heu d\'actualitzar abans de continuar.</string>
|
<string name="sms_bad_proto_fmt">La versió del Crosswords al telèfon amb número «%1$s» no és compatible amb aquest per a jugar via SMS. Heu d\'actualitzar abans de continuar.</string>
|
||||||
|
|
||||||
<plurals name="invite_bt_desc_fmt">
|
<plurals name="invite_bt_desc_fmt">
|
||||||
<item quantity="one">Selecioneu fins a %1$d aparells que voleu incloure en aquesta partida. Useu el botó «%2$s» si no veieu l\'aparell que espereu.</item>
|
<item quantity="one">Seleccioneu fins a %1$d aparells que voleu incloure en aquesta partida. Useu el botó «%2$s» si no veieu l\'aparell que espereu.</item>
|
||||||
<item quantity="other"/>
|
<item quantity="other"/>
|
||||||
</plurals>
|
</plurals>
|
||||||
<plurals name="invite_sms_desc_fmt">
|
<plurals name="invite_sms_desc_fmt">
|
||||||
|
@ -1043,4 +1043,6 @@
|
||||||
<string name="rematch_msg">Gestió de les invitacions per a tornar a jugar la partida. Us mostrarem aquest missatge mentre no l\'accepteu.\n\nNo heu de tenir aquesta partida oberta mentre espereu. Rebreu una notificació quan la partida estigui preparada per a jugar.</string>
|
<string name="rematch_msg">Gestió de les invitacions per a tornar a jugar la partida. Us mostrarem aquest missatge mentre no l\'accepteu.\n\nNo heu de tenir aquesta partida oberta mentre espereu. Rebreu una notificació quan la partida estigui preparada per a jugar.</string>
|
||||||
|
|
||||||
<string name="redir_host">Convida l\'amfitrió redirigit</string>
|
<string name="redir_host">Convida l\'amfitrió redirigit</string>
|
||||||
|
<string name="str_no_hint_found">No puc trobar cap jugada</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -1140,6 +1140,7 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
JSONObject theOne = null;
|
JSONObject theOne = null;
|
||||||
String langName = null;
|
String langName = null;
|
||||||
String json = NetUtils.runPost( post, new JSONObject() );
|
String json = NetUtils.runPost( post, new JSONObject() );
|
||||||
|
if ( null != json ) {
|
||||||
try {
|
try {
|
||||||
JSONObject obj = new JSONObject( json );
|
JSONObject obj = new JSONObject( json );
|
||||||
JSONArray langs = obj.optJSONArray( "langs" );
|
JSONArray langs = obj.optJSONArray( "langs" );
|
||||||
|
@ -1163,7 +1164,8 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
int nWords = dict.getInt( "nWords" );
|
int nWords = dict.getInt( "nWords" );
|
||||||
if ( null == theOne || nWords > theOneNWords ) {
|
if ( null == theOne
|
||||||
|
|| nWords > theOneNWords ) {
|
||||||
theOne = dict;
|
theOne = dict;
|
||||||
theOneNWords = nWords;
|
theOneNWords = nWords;
|
||||||
}
|
}
|
||||||
|
@ -1185,6 +1187,7 @@ public class DictsDelegate extends ListDelegateBase
|
||||||
DbgUtils.loge( ex );
|
DbgUtils.loge( ex );
|
||||||
theOne = null;
|
theOne = null;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ( null != theOne ) {
|
if ( null != theOne ) {
|
||||||
name = theOne.optString( "xwd" );
|
name = theOne.optString( "xwd" );
|
||||||
|
|
|
@ -244,6 +244,8 @@ public class NetUtils {
|
||||||
}
|
}
|
||||||
} catch( java.io.UnsupportedEncodingException uee ) {
|
} catch( java.io.UnsupportedEncodingException uee ) {
|
||||||
DbgUtils.loge( uee );
|
DbgUtils.loge( uee );
|
||||||
|
} catch( java.net.UnknownHostException uhe ) {
|
||||||
|
DbgUtils.loge( uhe );
|
||||||
} catch( java.io.IOException ioe ) {
|
} catch( java.io.IOException ioe ) {
|
||||||
DbgUtils.loge( ioe );
|
DbgUtils.loge( ioe );
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,13 +4,31 @@ import mk_xml, os, sys, getopt, re
|
||||||
|
|
||||||
from lxml import etree
|
from lxml import etree
|
||||||
|
|
||||||
|
g_verbose = False
|
||||||
|
|
||||||
|
def getDocNames( doc ):
|
||||||
|
stringNames = {}
|
||||||
|
pluralsNames = {}
|
||||||
|
|
||||||
|
for elem in doc.getroot():
|
||||||
|
if elem.tag == 'string': stringNames[elem.get('name')] = True
|
||||||
|
elif elem.tag == 'plurals': pluralsNames[elem.get('name')] = True
|
||||||
|
|
||||||
|
return { 'stringNames' : stringNames,
|
||||||
|
'pluralsNames' : pluralsNames,
|
||||||
|
}
|
||||||
|
|
||||||
|
def getEnglishNames():
|
||||||
|
doc = etree.parse("res/values/strings.xml")
|
||||||
|
return getDocNames( doc )
|
||||||
|
|
||||||
def longestCommon( name, pairs ):
|
def longestCommon( name, pairs ):
|
||||||
match = None
|
match = None
|
||||||
for ii in range(1, len(name)):
|
for ii in range(1, len(name)):
|
||||||
str = name[:ii]
|
str = name[:ii]
|
||||||
for key in pairs.keys():
|
for key in pairs.keys():
|
||||||
if str == key[:ii]:
|
if str == key[:ii]:
|
||||||
print str, "matches", key, "so far"
|
if g_verbose: print str, "matches", key, "so far"
|
||||||
match = key
|
match = key
|
||||||
break
|
break
|
||||||
return match
|
return match
|
||||||
|
@ -50,28 +68,40 @@ def checkAgainst( doc, pairs ):
|
||||||
# response = raw_input( "unknown name: %s; respond:" % (name) )
|
# response = raw_input( "unknown name: %s; respond:" % (name) )
|
||||||
# print "you wrote:", response
|
# print "you wrote:", response
|
||||||
|
|
||||||
def findWithName( doc, name ):
|
def findWithName( doc, name, tag ):
|
||||||
result = None
|
result = None
|
||||||
for string in doc.findall('string'):
|
for string in doc.findall(tag):
|
||||||
if string.get('name') == name:
|
if string.get('name') == name:
|
||||||
result = string
|
result = string
|
||||||
break
|
break
|
||||||
print 'findWithName=>', result, 'for', name
|
# if g_verbose: print 'findWithName=>', result, 'for', name
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
def makePluralsFrom( src ):
|
||||||
|
newNode = etree.fromstring('<plurals name="%s"></plurals>' % (src.get('name')))
|
||||||
|
for item in src.findall('item'):
|
||||||
|
obj = etree.fromstring('<item quantity="%s">XLATE ME: %s</item>'
|
||||||
|
% (item.get('quantity'), item.text))
|
||||||
|
newNode.append(obj)
|
||||||
|
return newNode
|
||||||
|
|
||||||
def insertAfter( locRoot, englishElem, lastMatch, prevComments ):
|
def insertAfter( locRoot, englishElem, lastMatch, prevComments ):
|
||||||
name = englishElem.get('name')
|
name = englishElem.get('name')
|
||||||
text = englishElem.text
|
text = englishElem.text
|
||||||
print "insertAfter(", locRoot, englishElem.get('name'), lastMatch.get('name'), prevComments, ")"
|
if g_verbose: print "insertAfter(", locRoot, englishElem.get('name'), lastMatch.get('name'), prevComments, ")"
|
||||||
index = locRoot.getchildren().index(lastMatch)
|
index = locRoot.getchildren().index(lastMatch)
|
||||||
print 'index:', index
|
if g_verbose: print 'index:', index
|
||||||
|
|
||||||
for comment in prevComments:
|
for comment in prevComments:
|
||||||
commentNode = etree.Comment(comment)
|
commentNode = etree.Comment(comment)
|
||||||
index += 1
|
index += 1
|
||||||
locRoot.insert( index, commentNode )
|
locRoot.insert( index, commentNode )
|
||||||
|
|
||||||
|
if 'string' == englishElem.tag:
|
||||||
newNode = etree.fromstring('<string name="%s">XLATE ME: %s</string>' % (name, text))
|
newNode = etree.fromstring('<string name="%s">XLATE ME: %s</string>' % (name, text))
|
||||||
|
elif 'plurals' == englishElem.tag:
|
||||||
|
newNode = makePluralsFrom(englishElem)
|
||||||
|
else: sys.exit(1)
|
||||||
index += 1
|
index += 1
|
||||||
locRoot.insert( index, newNode )
|
locRoot.insert( index, newNode )
|
||||||
|
|
||||||
|
@ -80,6 +110,14 @@ def longFormFor(fmt ):
|
||||||
elif fmt == '%d': return '%1$d'
|
elif fmt == '%d': return '%1$d'
|
||||||
else: assert False
|
else: assert False
|
||||||
|
|
||||||
|
def printStats( doc ):
|
||||||
|
engNames = getEnglishNames()
|
||||||
|
langNames = getDocNames( doc )
|
||||||
|
print "strings: English: %d; lang: %d" % (len(engNames['stringNames']),
|
||||||
|
len(langNames['stringNames']))
|
||||||
|
print "plurals: English: %d; lang: %d" % (len(engNames['pluralsNames']),
|
||||||
|
len(langNames['pluralsNames']))
|
||||||
|
|
||||||
def replacePcts( doc ):
|
def replacePcts( doc ):
|
||||||
pat = re.compile( '(%[sd])', re.DOTALL | re.MULTILINE )
|
pat = re.compile( '(%[sd])', re.DOTALL | re.MULTILINE )
|
||||||
for string in doc.findall('string'):
|
for string in doc.findall('string'):
|
||||||
|
@ -95,29 +133,29 @@ def replacePcts( doc ):
|
||||||
# elem before it that is in doc and insert it after. Start over each
|
# elem before it that is in doc and insert it after. Start over each
|
||||||
# time to avoid problems with iteration and order
|
# time to avoid problems with iteration and order
|
||||||
def doAddMissing( doc ):
|
def doAddMissing( doc ):
|
||||||
done = False
|
|
||||||
while not done:
|
|
||||||
locRoot = doc.getroot()
|
locRoot = doc.getroot()
|
||||||
lastMatch = None
|
lastMatch = None
|
||||||
prevComments = []
|
prevComments = []
|
||||||
for elem in etree.parse("res/values/strings.xml").getroot().iter():
|
resources = etree.parse("res/values/strings.xml").getroot()
|
||||||
if not isinstance( elem.tag, basestring ):
|
for elem in resources:
|
||||||
|
# if g_verbose: print "got elem:", elem
|
||||||
|
tag = elem.tag
|
||||||
|
if not isinstance( tag, basestring ):
|
||||||
prevComments.append( elem.text )
|
prevComments.append( elem.text )
|
||||||
print "added comment:", elem.text
|
# if g_verbose: print "added comment:", elem.text
|
||||||
elif 'string' == elem.tag:
|
elif 'string' == tag or 'plurals' == tag:
|
||||||
name = elem.get('name')
|
name = elem.get('name')
|
||||||
match = findWithName( locRoot, name )
|
match = findWithName( locRoot, name, tag )
|
||||||
print 'elem', name, 'has comments', prevComments
|
|
||||||
if None == match:
|
if None == match:
|
||||||
print 'NO match for', name
|
if g_verbose: print 'NO match for', name
|
||||||
insertAfter( locRoot, elem, lastMatch, prevComments )
|
insertAfter( locRoot, elem, lastMatch, prevComments )
|
||||||
done = True
|
|
||||||
# sys.exit(0)
|
|
||||||
else:
|
else:
|
||||||
print 'got match for', name
|
|
||||||
lastMatch = match
|
lastMatch = match
|
||||||
lastComments = prevComments
|
lastComments = prevComments
|
||||||
prevComments = []
|
prevComments = []
|
||||||
|
else:
|
||||||
|
print "unexpected tag:", elem.tag
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
def compare( engPairs, docPath ):
|
def compare( engPairs, docPath ):
|
||||||
locStrings = mk_xml.getStrings( docPath, True )
|
locStrings = mk_xml.getStrings( docPath, True )
|
||||||
|
@ -127,29 +165,67 @@ def compare( engPairs, docPath ):
|
||||||
otherOnly = [key for key in locStrings.keys() if not key in engPairs]
|
otherOnly = [key for key in locStrings.keys() if not key in engPairs]
|
||||||
print "%d strings missing from English: %s" % (len(otherOnly), ", ".join(otherOnly))
|
print "%d strings missing from English: %s" % (len(otherOnly), ", ".join(otherOnly))
|
||||||
|
|
||||||
|
def removeNotInEnglish( doc ):
|
||||||
|
locRoot = doc.getroot()
|
||||||
|
engNames = getEnglishNames()
|
||||||
|
for elem in locRoot:
|
||||||
|
if not isinstance( elem.tag, basestring ):
|
||||||
|
prevComment = elem
|
||||||
|
elif elem.tag == 'string':
|
||||||
|
name = elem.get('name')
|
||||||
|
if not name in engNames['stringNames']:
|
||||||
|
print "removing string", name
|
||||||
|
locRoot.remove(elem)
|
||||||
|
if prevComment: locRoot.remove(prevComment)
|
||||||
|
prevComment = None
|
||||||
|
elif elem.tag == 'plurals':
|
||||||
|
name = elem.get('name')
|
||||||
|
if not name in engNames['pluralsNames']:
|
||||||
|
print "removing plurals", name
|
||||||
|
locRoot.remove(elem)
|
||||||
|
if prevComment: locRoot.remove(prevComment)
|
||||||
|
prevComment = None
|
||||||
|
else:
|
||||||
|
print "unknown tag", elem.tag
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
def usage():
|
def usage():
|
||||||
print "usage:", sys.argv[0]
|
print "usage:", sys.argv[0]
|
||||||
print " -a # insert missing string elements for translation"
|
print " -a # insert missing string elements for translation"
|
||||||
print " -c # compare each file with the English, listing string not in both"
|
print " -c # compare each file with the English, listing string not in both"
|
||||||
|
print " -i # save any changes made (does not by default)"
|
||||||
print " -f # work on this strings.xml file (does all if none specified)"
|
print " -f # work on this strings.xml file (does all if none specified)"
|
||||||
|
print " -l # work on the strings.xml file for this language (e.g. ca, nl)"
|
||||||
|
print " -r # remove elements not present in English"
|
||||||
|
print " -s # print stats"
|
||||||
print " -% # replace %[sd] with the correct longer form"
|
print " -% # replace %[sd] with the correct longer form"
|
||||||
print " -s # save any changes made (does not by default)"
|
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
def langFileFor(code):
|
||||||
|
return "res_src/values-%s/strings.xml" % code
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
global g_verbose
|
||||||
stringsFiles = []
|
stringsFiles = []
|
||||||
addMissing = False
|
addMissing = False
|
||||||
doSave = False
|
doSave = False
|
||||||
doCompare = False
|
doCompare = False
|
||||||
doReplace = False
|
doReplace = False
|
||||||
|
doRemove = False
|
||||||
|
doStats = False
|
||||||
try:
|
try:
|
||||||
pairs, rest = getopt.getopt(sys.argv[1:], "acf:s%")
|
pairs, rest = getopt.getopt(sys.argv[1:], "acf:il:rsv%")
|
||||||
for option, value in pairs:
|
for option, value in pairs:
|
||||||
if option == '-a': addMissing = True
|
if option == '-a': addMissing = True
|
||||||
elif option == '-c': doCompare = True
|
elif option == '-c': doCompare = True
|
||||||
elif option == '-%': doReplace = True
|
elif option == '-i': doSave = True
|
||||||
elif option == '-f': stringsFiles.append(value)
|
elif option == '-f': stringsFiles.append(value)
|
||||||
elif option == '-s': doSave = True
|
elif option == '-l': stringsFiles.append(langFileFor(value))
|
||||||
|
elif option == '-v': g_verbose = True
|
||||||
|
elif option == '-r': doRemove = True
|
||||||
|
elif option == '-s': doStats = True
|
||||||
|
elif option == '-%': doReplace = True
|
||||||
else: usage()
|
else: usage()
|
||||||
except:
|
except:
|
||||||
usage()
|
usage()
|
||||||
|
@ -164,11 +240,20 @@ def main():
|
||||||
|
|
||||||
parser = etree.XMLParser(remove_blank_text=True, encoding="utf-8")
|
parser = etree.XMLParser(remove_blank_text=True, encoding="utf-8")
|
||||||
for path in stringsFiles:
|
for path in stringsFiles:
|
||||||
|
print "looking at", path
|
||||||
doc = etree.parse(path, parser)
|
doc = etree.parse(path, parser)
|
||||||
# checkAgainst( doc, pairs )
|
# checkAgainst( doc, pairs )
|
||||||
if doReplace: replacePcts( doc )
|
if doReplace:
|
||||||
if addMissing: doAddMissing( doc )
|
replacePcts( doc )
|
||||||
if doCompare: compare( pairs, path )
|
if addMissing:
|
||||||
|
doAddMissing( doc )
|
||||||
|
if doCompare:
|
||||||
|
compare( pairs, path )
|
||||||
|
if doRemove:
|
||||||
|
removeNotInEnglish( doc )
|
||||||
|
# print stats after any other changes have been made
|
||||||
|
if doStats:
|
||||||
|
printStats( doc )
|
||||||
if doSave:
|
if doSave:
|
||||||
out = open( path, "w" )
|
out = open( path, "w" )
|
||||||
out.write( etree.tostring( doc, pretty_print=True, encoding="utf-8", xml_declaration=True ) )
|
out.write( etree.tostring( doc, pretty_print=True, encoding="utf-8", xml_declaration=True ) )
|
Loading…
Reference in a new issue