use make to avoid reprocessing res_src strings.xml files

They never change, so use make's understanding of dependencies.
This commit is contained in:
Eric House 2020-01-13 12:10:40 -08:00
parent 3f78263f54
commit 7e570cff2c
7 changed files with 66 additions and 4775 deletions

View file

@ -302,11 +302,17 @@ task mkImages(type: Exec) {
commandLine './scripts/mkimages.sh' commandLine './scripts/mkimages.sh'
} }
task copyStrings(type: Exec) { task copyLocStrings(type: Exec) {
workingDir '../' workingDir '../'
commandLine './scripts/copy-strings.py' commandLine 'make', '-f', './scripts/copy-strings.mk'
} }
task cleanLocStrings(type: Exec) {
workingDir '../'
commandLine 'make', '-f', './scripts/copy-strings.mk', 'clean'
}
clean.dependsOn cleanLocStrings
task ndkSetupDebug(type: Exec) { task ndkSetupDebug(type: Exec) {
workingDir '../' workingDir '../'
// remove ', "--arm-only"' for Genymotion builds // remove ', "--arm-only"' for Genymotion builds
@ -323,7 +329,7 @@ task ndkSetupRelease(type: Exec) {
commandLine "./scripts/ndksetup.sh", "--with-clang", "--arm-only" commandLine "./scripts/ndksetup.sh", "--with-clang", "--arm-only"
} }
task myPreBuild(dependsOn: ['mkImages', 'copyStrings', 'mkXml']) { task myPreBuild(dependsOn: ['mkImages', 'copyLocStrings', 'mkXml']) {
} }
preBuild.dependsOn myPreBuild preBuild.dependsOn myPreBuild

File diff suppressed because it is too large Load diff

View file

@ -706,10 +706,6 @@ Introduïu el vostre nom aquí. S\'usarà en crear partides noves. (Podreu
<string name="not_again_turnchanged">E jugador amb el torn apareix apareix amb el marcador més gros.\n\nAguanteu el dit en un nom del marcador per a obtenir detalls sobre la jugada més recent del jugador.</string> <string name="not_again_turnchanged">E jugador amb el torn apareix apareix amb el marcador més gros.\n\nAguanteu el dit en un nom del marcador per a obtenir detalls sobre la jugada més recent del jugador.</string>
<string name="not_again_newfrom">Crea una partida llesta per a jugar usant la configuració d\'aquesta. Això és, usa aquesta partida com a plantilla.</string> <string name="not_again_newfrom">Crea una partida llesta per a jugar usant la configuració d\'aquesta. Això és, usa aquesta partida com a plantilla.</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 de dades. 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 de dades. Heu d\'actualitzar abans de continuar.</string>
<plurals name="invite_bt_desc_fmt">
<item quantity="one">Seleccioneu l\'aparell que voleu incloure en aquesta partida. Useu el botó «%2$s» si no veieu l\'aparell que espereu.</item>
<item quantity="other">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>
</plurals>
<plurals name="invite_sms_desc_fmt"> <plurals name="invite_sms_desc_fmt">
<item quantity="one">Comproveu el número de telèfon que voleu convidar a la partida nova, aleshores toqueu «%2$s».</item> <item quantity="one">Comproveu el número de telèfon que voleu convidar a la partida nova, aleshores toqueu «%2$s».</item>
<item quantity="other">Comproveu els %1$d números de telèfon que voleu convidar a la partida nova, aleshores toqueu «%2$s».</item> <item quantity="other">Comproveu els %1$d números de telèfon que voleu convidar a la partida nova, aleshores toqueu «%2$s».</item>

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,35 @@
# -*- mode: Makefile -*-
SRCS = $(wildcard ./res_src/values-*/strings.xml)
TARGETS = $(SRCS:./res_src/value%/strings.xml=app/src/main/res/value%/strings.xml)
.PHONY: all clean
RES_SRC = ./res_src
RES_DEST = ./app/src/main/res
all: $(TARGETS)
pwd
echo $(SRCS)
echo $(TARGETS)
# all: $(TARGETS)
$(RES_DEST)/value%/strings.xml: $(RES_SRC)/value%/strings.xml
./scripts/copy-strings.py -f $<
clean:
rm -f $(TARGETS)
# SRC = $(wildcard *.html)
# TAR = $(SRC:.html=.markdown)
# .PHONY: all clean
# all: $(TAR)
# %.markdown: %.html
# pandoc -o $< $@
# clean:
# rm -f $(TAR)

View file

@ -25,7 +25,7 @@ def exitWithError(msg):
sys.exit(1) sys.exit(1)
def usage(): def usage():
print "usage:", sys.argv[0], '[-k <list-o-dirs>]' print "usage:", sys.argv[0], '[-k <list-o-dirs>] [-f inFile]'
sys.exit(1) sys.exit(1)
def sameOrSameWithPrefix( str1, str2 ): def sameOrSameWithPrefix( str1, str2 ):
@ -227,11 +227,13 @@ def main():
# add these via params later # add these via params later
excepts = ['values-ca_PS', 'values-ba_CK'] excepts = ['values-ca_PS', 'values-ba_CK']
verboses = ['values-ja'] verboses = ['values-ja']
srcFiles = []
try: try:
pairs, rest = getopt.getopt(sys.argv[1:], "k:") pairs, rest = getopt.getopt(sys.argv[1:], "k:f:")
for option, value in pairs: for option, value in pairs:
if option == '-k': excepts += value.split(' ') if option == '-k': excepts += value.split(' ')
if option == '-f': srcFiles.append(value)
else: usage() else: usage()
except: except:
print "Unexpected error:", sys.exc_info()[0] print "Unexpected error:", sys.exc_info()[0]
@ -257,19 +259,23 @@ def main():
engNames[name] = item engNames[name] = item
# print engNames # print engNames
# iterate over src files # if -f option not used, iterate over src files to collect them all
for subdir, dirs, files in os.walk('res_src'): if not srcFiles:
for file in [file for file in files if file == "strings.xml"]: for subdir, dirs, files in os.walk('res_src'):
path = "%s/%s" % (subdir, file) for file in [file for file in files if file == "strings.xml"]:
for excpt in excepts: path = "%s/%s" % (subdir, file)
if excpt in path : if path:
path = None for excpt in excepts:
break if path and excpt in path:
if path: path = None
verbose = 0 == len(verboses) or 0 < len([verb for verb in verboses if verb in path]) if path:
print "*** looking at %s ***" % (path) srcFiles.append(path)
dest = path.replace( 'res_src', 'app/src/main/res', 1 )
checkAndCopy( parser, engNames, engFormats, path, dest, verbose ) # Finally, do the work
for path in srcFiles:
verbose = 0 == len(verboses) or 0 < len([verb for verb in verboses if verb in path])
dest = path.replace( 'res_src', 'app/src/main/res', 1 )
checkAndCopy( parser, engNames, engFormats, path, dest, verbose )
############################################################################## ##############################################################################
if __name__ == '__main__': if __name__ == '__main__':

View file

@ -85,7 +85,7 @@ def main():
usage() usage()
parser = etree.XMLParser(remove_blank_text=True) parser = etree.XMLParser(remove_blank_text=True)
doc = etree.parse("res/values/strings.xml", parser) doc = etree.parse("app/src/main/res/values/strings.xml", parser)
for elem in doc.getroot().iter(): for elem in doc.getroot().iter():
if 'string' == elem.tag or 'item' == elem.tag: if 'string' == elem.tag or 'item' == elem.tag:
text = elem.text text = elem.text