X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/46f4442e9a5a4f3b98b7c1083586332f6a8a99a4..249c4c5ea9376c24572daf9c2effa7484a282f14:/icuSources/test/testdata/Makefile.in diff --git a/icuSources/test/testdata/Makefile.in b/icuSources/test/testdata/Makefile.in index ea7bdd0d..00322615 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-2008, International Business Machines +# Copyright (C) 1998-2015, International Business Machines # Corporation and others. All Rights Reserved. # #****************************************************************************** @@ -29,7 +31,9 @@ SUBDIRS = .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 java-output +check check-local check-recursive build-dir testdata.jar xcheck check-exhaustive + +xcheck: all-local .NOTPARALLEL: build-dir @@ -44,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: @@ -63,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 @@ -86,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) @@ -101,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 @@ -119,84 +131,81 @@ TESTDT=$(TESTDATA) 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 test1bmp.ucm test3.ucm test4.ucm test4x.ucm ibm9027.ucm +TEST_UCM_SOURCE= test1.ucm test1bmp.ucm test2.ucm test3.ucm test4.ucm test4x.ucm test5.ucm ibm9027.ucm TEST_UCM_FILES=$(TEST_UCM_SOURCE:%=$(TESTSRCDATADIR)/data/%) TEST_CNV_FILES=$(TEST_UCM_SOURCE:%.ucm=$(TESTBUILDDIR)/%.cnv) +TEST_NRM_FILES=$(TESTBUILDDIR)/testnorm.nrm + # import the shared .mk file include $(TESTSRCDATADIR)/tstfiles.mk -include $(TESTSRCDATADIR)/tstlocal.mk # TEST_RES_SOURCE comes from tstfiles.mk -TEST_RES = $(TEST_RES_SOURCE) $(TEST_RES_LOCAL) 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 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 +TEST_RES = $(TEST_RES_SOURCE) $(TEST_RES_LOCAL) 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 idna_rules.txt conversion.txt icuio.txt testtable32.txt metaZones.txt timezoneTypes.txt windowsZones.txt zoneinfo64.txt +TEST_RES_FILES=$(TEST_RES:%.txt=$(TESTBUILDDIR)/%.res) $(TESTBUILDDIR)/encoded.res $(TESTBUILDDIR)/old_l_testtypes.res $(TESTBUILDDIR)/old_e_testtypes.res -ALL_TEST_FILES = $(TEST_DAT_FILES) $(TEST_SPP_FILES) $(TEST_BRK_FILES) $(TEST_CNV_FILES) $(TEST_RES_FILES) $(TESTOUTDIR)/$(TESTDT)/nam.typ +ALL_TEST_FILES = $(TEST_DAT_FILES) $(TEST_SPP_FILES) $(TEST_BRK_FILES) $(TEST_CNV_FILES) $(TEST_NRM_FILES) $(TEST_RES_FILES) $(TESTOUTDIR)/$(TESTDT)/nam.typ $(TESTOUTDIR)/$(TESTDT)/zoneinfo64.res # list $(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 \ + @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) $(TEST_NRM_FILES:$(TESTBUILDDIR)/%.nrm=%.nrm); do \ echo $$file >> $@; \ done; -build-testdata: build-dir $(ALL_TEST_FILES) $(TESTBUILDDIR)/testdata.lst $(TESTBUILDDIR)/iscii.res +build-testdata: build-dir $(ALL_TEST_FILES) $(TESTBUILDDIR)/testdata.lst $(TESTBUILDDIR)/encoded.res # 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) - -# java output -java-output: $(JAVA_OUT_DIR)/DebugUtilitiesData.java +$(TESTBUILDDIR)/test.icu: $(GENTEST) + $(INVOKE) $(GENTEST) -d $(TESTBUILDDIR) -$(JAVA_OUT_DIR)/DebugUtilitiesData.java: $(TOOLDIR)/gentest/gentest$(EXEEXT) - $(MKINSTALLDIRS) $(JAVA_OUT_DIR) - $(INVOKE) $(TOOLDIR)/gentest/gentest -j -d $(JAVA_OUT_DIR) +$(TESTBUILDDIR)/testtable32.txt: $(GENTEST) + $(INVOKE) $(GENTEST) -r -d $(TESTBUILDDIR) - -$(TESTBUILDDIR)/testtable32.res: $(TESTBUILDDIR)/testtable32.txt $(BINDIR)/genrb$(EXEEXT) - $(INVOKE) $(BINDIR)/genrb $(GENRBOPTS) -s $(TESTBUILDDIR) $(ICU_DATA_OPT) -d $(TESTBUILDDIR) $(/dev/null || ( echo "WARNING: could not open ISCII - it may have been disabled." | tee $@ ) + ICU_DATA=$(BUILDDIR) $(INVOKE) $(TOOLBINDIR)/genrb $(GENRBOPTS) -s $(TESTSRCDATADIR) -eUTF-16BE -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 + +# 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 + + +DEBUGUTILITIESDATA_DIR=main/tests/core/src/com/ibm/icu/dev/test/util +DEBUGUTILITIESDATA_SRC=DebugUtilitiesData.java + +ICU4J_DATA=$(OUTDIR)/icu4j/src/$(DEBUGUTILITIESDATA_SRC) $(OUTDIR)/icu4j/testdata.jar + +$(OUTDIR)/icu4j/src/$(DEBUGUTILITIESDATA_SRC): $(GENTEST) + mkdir -p $(OUTDIR)/icu4j/src + $(INVOKE) $(GENTEST) -j -d $(OUTDIR)/icu4j/src + +ifdef ICU4J_ROOT + +icu4j-data-install: $(ICU4J_ROOT)/main/shared/data/testdata.jar $(ICU4J_ROOT)/$(DEBUGUTILITIESDATA_DIR)/$(DEBUGUTILITIESDATA_SRC) + @echo ICU4J test data installed in $(ICU4J_ROOT) + +$(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 + +$(ICU4J_ROOT)/$(DEBUGUTILITIESDATA_DIR)/$(DEBUGUTILITIESDATA_SRC): $(OUTDIR)/icu4j/src/$(DEBUGUTILITIESDATA_SRC) + mkdir -p $(ICU4J_ROOT)/$(DEBUGUTILITIESDATA_DIR) + cp $^ $@ + +else + +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)