X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/73c04bcfe1096173b00431f0cdc742894b15eef0..340931cb2e044a2141d11567dd0f782524e32994:/icuSources/test/testdata/Makefile.in diff --git a/icuSources/test/testdata/Makefile.in b/icuSources/test/testdata/Makefile.in index bddd4640..04bc1c1a 100644 --- a/icuSources/test/testdata/Makefile.in +++ b/icuSources/test/testdata/Makefile.in @@ -1,6 +1,8 @@ +# Copyright (C) 2016 and later: Unicode, Inc. and others. +# License & terms of use: http://www.unicode.org/copyright.html #****************************************************************************** # -# Copyright (C) 1998-2006, International Business Machines +# Copyright (C) 1998-2015, International Business Machines # Corporation and others. All Rights Reserved. # #****************************************************************************** @@ -23,11 +25,15 @@ CLEANFILES = *~ SUBDIRS = +-include Makefile.local + ## List of phony targets .PHONY : all all-local all-recursive install install-local \ install-recursive clean clean-local clean-recursive distclean \ distclean-local distclean-recursive doc dist dist-local dist-recursive \ -check check-local check-recursive build-dir +check check-local check-recursive build-dir testdata.jar xcheck check-exhaustive + +xcheck: all-local .NOTPARALLEL: build-dir @@ -42,6 +48,8 @@ distclean : distclean-local dist: dist-local check: all check-local +check-exhaustive: check + all-local: build-dir build-testdata testdata packagetest install-local: @@ -61,21 +69,20 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status cd $(top_builddir) \ && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status -pkgdata.inc: $(srcdir)/pkgdata.inc.in Makefile $(top_builddir)/config.status +pkgdata.inc: pkgdataMakefile + $(MAKE) -f pkgdataMakefile + +pkgdataMakefile: cd $(top_builddir) \ && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status - ######################################################################### ############################## Test ## stuff ############################ -ifeq ($(PKGDATA_OPTS),) -PKGDATA_OPTS = -O $(top_builddir)/test/testdata/pkgdata.inc -endif - # relative lib links from pkgdata are the same as for tmp GENRBOPTS=-k -TOOLDIR=$(top_builddir)/tools +# use the cross root, in case we are cross compiling. Otherwise it is equal to top_builddir +TOOLDIR=$(cross_buildroot)/tools SRCDATADIR=$(top_srcdir)/data UNICODEDATADIR=$(SRCDATADIR)/unidata OUTDIR=$(top_builddir)/data/out @@ -84,6 +91,7 @@ BUILDDIR=$(OUTDIR)/build/$(ICUDATA_PLATFORM_NAME) TESTSRCDATADIR=$(top_srcdir)/test/testdata TESTOUTDIR=$(top_builddir)/test/testdata/out BUILD_DIRS = $(TESTOUTDIR) $(TESTBUILDDIR) $(TESTOUTDIR)/$(TESTDT) +GENTEST=$(TOOLDIR)/gentest/gentest$(TOOLEXEEXT) ifeq ($(PKGDATA_MODE),common) ICU_DATA_OPT = -i $(OUTDIR) @@ -99,7 +107,13 @@ ICU_DATA_OPT = -i $(BUILDDIR) endif endif -PKGDATA = $(BINDIR)/pkgdata $(PKGDATA_OPTS) -q -c -s $(CURDIR)/out/build/$(ICUDATA_PLATFORM_NAME) +CURDIR:=$(CURR_FULL_DIR) +# current directory should not be blank +ifeq ($(CURDIR),) +CURDIR=. +endif + +PKGDATA = $(TOOLBINDIR)/pkgdata -q -c -s $(CURDIR)/out/build/$(ICUDATA_PLATFORM_NAME) PKGDATA_INVOKE:=$(INVOKE) $(PKGDATA_INVOKE_OPTS) # Contains all 'intermediate' files (and temp files) except for 'unpackaged data' below @@ -113,96 +127,74 @@ TESTDATA=testdata # prefix for files that are testdata TESTDT=$(TESTDATA) -# File definitions -TEST_DAT_FILES=$(TESTBUILDDIR)/test.icu -TEST_SPP_FILES=$(TESTBUILDDIR)/nfscsi.spp $(TESTBUILDDIR)/nfscss.spp $(TESTBUILDDIR)/nfscis.spp $(TESTBUILDDIR)/nfsmxs.spp $(TESTBUILDDIR)/nfsmxp.spp - -TEST_UCM_SOURCE= test1.ucm test3.ucm test4.ucm test4x.ucm ibm9027.ucm -TEST_UCM_FILES=$(TEST_UCM_SOURCE:%=$(TESTSRCDATADIR)/data/%) -TEST_CNV_FILES=$(TEST_UCM_SOURCE:%.ucm=$(TESTBUILDDIR)/%.cnv) - -TEST_RES = casing.txt mc.txt root.txt sh.txt sh_YU.txt te.txt te_IN.txt te_IN_REVISED.txt testtypes.txt testaliases.txt testempty.txt structLocale.txt DataDrivenCollationTest.txt idna_rules.txt conversion.txt icuio.txt testtable32.txt -TEST_RES_FILES=$(TEST_RES:%.txt=$(TESTBUILDDIR)/%.res) $(TESTBUILDDIR)/iscii.res $(TESTBUILDDIR)/icu26_testtypes.res $(TESTBUILDDIR)/icu26e_testtypes.res +# Variable names for rules.mk +OUT_DIR=$(TESTBUILDDIR) +TMP_DIR=$(TESTOUTDIR)/$(TESTDT) -ALL_TEST_FILES = $(TEST_DAT_FILES) $(TEST_SPP_FILES) $(TEST_BRK_FILES) $(TEST_CNV_FILES) $(TEST_RES_FILES) $(TESTOUTDIR)/$(TESTDT)/nam.typ +## Include the Python-generated rules -# list +include $(top_builddir)/$(subdir)/rules.mk -$(TESTBUILDDIR)/testdata.lst: $(SRCLISTDEPS) - @echo "generating $@ (list of data files)" - @-$(RMV) $@ - @for file in $(TEST_RES_FILES:$(TESTBUILDDIR)/%.res=%.res) $(TEST_DAT_FILES:$(TESTBUILDDIR)/%.icu=%.icu) $(TEST_SPP_FILES:$(TESTBUILDDIR)/%.spp=%.spp) $(TEST_CNV_FILES:$(TESTBUILDDIR)/%.cnv=%.cnv); do \ - echo $$file >> $@; \ - done; +build-testdata: build-dir $(TESTDATA_ALL_OUTPUT_FILES) -build-testdata: build-dir $(ALL_TEST_FILES) $(TESTBUILDDIR)/testdata.lst $(TESTBUILDDIR)/iscii.res +testdata: build-testdata -# test.icu -$(TESTBUILDDIR)/test.icu: $(TOOLDIR)/gentest/gentest$(EXEEXT) - $(INVOKE) $(TOOLDIR)/gentest/gentest -d $(TESTBUILDDIR) -$(TESTBUILDDIR)/testtable32.txt: $(TOOLDIR)/gentest/gentest$(EXEEXT) - $(INVOKE) $(TOOLDIR)/gentest/gentest -r -d $(TESTBUILDDIR) +packagetest: build-dir testdata pkgdata.inc $(TMP_DIR)/testdata.lst + $(PKGDATA_INVOKE) $(PKGDATA) -T $(TESTBUILDDIR) -d $(TESTOUTDIR) -s $(TESTBUILDDIR) -p $(TESTDATA) -m common $(TMP_DIR)/testdata.lst -$(TESTBUILDDIR)/testtable32.res: $(TESTBUILDDIR)/testtable32.txt $(BINDIR)/genrb$(EXEEXT) - $(INVOKE) $(BINDIR)/genrb $(GENRBOPTS) -s $(TESTBUILDDIR) $(ICU_DATA_OPT) -d $(TESTBUILDDIR) $( make JAR=jar ICU4J_ROOT=~/svn.icu4j/trunk testdata.jar +# You can omit the ICU4J_ROOT for just building the .jar files without copying them. +# You can omit the JAR if it's just jar. +JAR=jar -# Targets for nfsmxs.spp -$(TESTBUILDDIR)/nfsmxs.spp: $(BINDIR)/gensprep$(EXEEXT) $(TESTSRCDATADIR)/nfs4_mixed_prep_s.txt - @echo Building nfsmxs.spp - $(INVOKE) $(BINDIR)/gensprep -s $(TESTSRCDATADIR) $(ICU_DATA_OPT) -d $(TESTBUILDDIR) -b nfsmxs -k -n $(UNICODEDATADIR) -u 3.2.0 nfs4_mixed_prep_s.txt +# Build testdata.jar: +# - swap the test data +# - extract all data items +# - package them into the .jar file +$(OUTDIR)/icu4j/testdata.jar: build-dir testdata $(TESTOUTDIR)/testdata.dat + mkdir -p $(OUTDIR)/icu4j/com/ibm/icu/dev/data/testdata + $(INVOKE) $(TOOLBINDIR)/icupkg $(TESTOUTDIR)/testdata.dat -r test.icu -x '*' -tb -d $(OUTDIR)/icu4j/com/ibm/icu/dev/data/testdata + $(JAR) cf $(OUTDIR)/icu4j/testdata.jar -C $(OUTDIR)/icu4j com/ibm/icu/dev/data/testdata -# Targets for nfsmxp.spp -$(TESTBUILDDIR)/nfsmxp.spp: $(BINDIR)/gensprep$(EXEEXT) $(TESTSRCDATADIR)/nfs4_mixed_prep_p.txt - @echo Building nfsmxp.spp - $(INVOKE) $(BINDIR)/gensprep -s $(TESTSRCDATADIR) $(ICU_DATA_OPT) -d $(TESTBUILDDIR) -b nfsmxp -k -n $(UNICODEDATADIR) -u 3.2.0 nfs4_mixed_prep_p.txt -$(TESTBUILDDIR)/%.cnv: $(TESTSRCDATADIR)/%.ucm $(BINDIR)/makeconv$(EXEEXT) - $(INVOKE) $(BINDIR)/makeconv -c -d $(TESTBUILDDIR) $(TESTSRCDATADIR)/$(/dev/null || ( echo "WARNING: could not open ISCII - it may have been disabled." | tee $@ ) - @echo Finished testing genrb -e option +$(OUTDIR)/icu4j/src/$(DEBUGUTILITIESDATA_SRC): $(GENTEST) + mkdir -p $(OUTDIR)/icu4j/src + $(INVOKE) $(GENTEST) -j -d $(OUTDIR)/icu4j/src -################################################################### TYP -# TYP FILES +ifdef ICU4J_ROOT -$(TESTOUTDIR)/$(TESTDT)/nam.typ: $(TESTBUILDDIR)/te_IN.res - cp $< $@ -$(TESTBUILDDIR)/icu26_testtypes.res: $(TESTSRCDATADIR)/icu26_testtypes.res - cp $< $@ -$(TESTBUILDDIR)/icu26e_testtypes.res: $(TESTSRCDATADIR)/icu26e_testtypes.res - cp $< $@ +icu4j-data-install: $(ICU4J_ROOT)/main/shared/data/testdata.jar $(ICU4J_ROOT)/$(DEBUGUTILITIESDATA_DIR)/$(DEBUGUTILITIESDATA_SRC) + @echo ICU4J test data installed in $(ICU4J_ROOT) -testdata: build-dir $(ALL_TEST_FILES) $(UNPACKAGEDTESTDATA) +$(ICU4J_ROOT)/main/shared/data/testdata.jar: $(OUTDIR)/icu4j/testdata.jar + mkdir -p $(ICU4J_ROOT)/main/shared/data + cp $(OUTDIR)/icu4j/testdata.jar $(ICU4J_ROOT)/main/shared/data -#$(ALL_TEST_FILES) $(TESTBUILDDIR)/testtable32.txt $(TESTBUILDDIR)/testdata.lst: build-dir +$(ICU4J_ROOT)/$(DEBUGUTILITIESDATA_DIR)/$(DEBUGUTILITIESDATA_SRC): $(OUTDIR)/icu4j/src/$(DEBUGUTILITIESDATA_SRC) + mkdir -p $(ICU4J_ROOT)/$(DEBUGUTILITIESDATA_DIR) + cp $^ $@ -packagetest: build-dir testdata pkgdata.inc $(TESTBUILDDIR)/testdata.lst - $(PKGDATA_INVOKE) $(PKGDATA) -T $(TESTBUILDDIR) -d $(TESTOUTDIR) -s $(TESTBUILDDIR) -p $(TESTDATA) -m common $(TESTBUILDDIR)/testdata.lst +else -build-dir: $(BUILD_DIRS) -$(BUILD_DIRS): - -$(MKINSTALLDIRS) $(BUILD_DIRS) +icu4j-data-install: $(ICU4J_DATA) + @echo ICU4J data was built into $(OUTDIR)/icu4j + @echo '** Error:' ICU4J_ROOT was not set, could not install + exit 1 +endif +icu4j-data: $(ICU4J_DATA)