X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/4388f060552cc537e71e957d32f35e9d75a61233..9f1b115531acc2f3640893f76e8bcf6680033062:/icuSources/Makefile.in diff --git a/icuSources/Makefile.in b/icuSources/Makefile.in index bcaec91a..f4bab77e 100644 --- a/icuSources/Makefile.in +++ b/icuSources/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-2012, International Business Machines +# Copyright (C) 1998-2016, International Business Machines # Corporation and others. All Rights Reserved. # #****************************************************************************** @@ -16,9 +18,8 @@ include $(top_builddir)/icudefs.mk docdir = $(datadir)/doc docsubdir = $(PACKAGE)$(ICULIBDASHSUFFIX)/html -docsubsrchdir = $(docsubdir)/search docfilesdir = doc/html -docfiles = $(docfilesdir)/*.png $(docfilesdir)/*.html $(docfilesdir)/*.css $(docfilesdir)/*.tag $(docfilesdir)/installdox +docfiles = $(docfilesdir)/*.png $(docfilesdir)/*.html $(docfilesdir)/*.css $(docfilesdir)/*.tag docsrchdir = $(docfilesdir)/search docsrchfiles = $(docsrchdir)/* @@ -30,11 +31,17 @@ subdir = . #AUTOCONF = @AUTOCONF@ ## Optional directory setup -@LAYOUT_TRUE@LAYOUT = layout layoutex +@LAYOUTEX_TRUE@LAYOUTEX = layoutex @ICUIO_TRUE@ICUIO = io @EXTRAS_TRUE@EXTRA = extra @TESTS_TRUE@TEST = test @SAMPLES_TRUE@SAMPLE = samples +@TOOLS_TRUE@TOOLS = tools + +## pkgconfig setup. Always have uc and i18n. Others are optional. +ALL_PKGCONFIG_SUFFIX=uc i18n +@LAYOUTEX_TRUE@ALL_PKGCONFIG_SUFFIX+= lx +@ICUIO_TRUE@ALL_PKGCONFIG_SUFFIX+= io DOXYGEN = @DOXYGEN@ DOCZIP = icu-docs.zip @@ -42,17 +49,16 @@ DOCZIP = icu-docs.zip ## Files to remove for 'make clean' CLEANFILES = *~ -ALL_PKGCONFIG_SUFFIX=uc i18n io le lx ALL_PKGCONFIG_FILES=$(ALL_PKGCONFIG_SUFFIX:%=$(top_builddir)/config/icu-%.pc) ## Files built (autoconfed) and installed INSTALLED_BUILT_FILES = $(top_builddir)/config/Makefile.inc $(top_builddir)/config/pkgdata.inc $(top_builddir)/config/icu-config @platform_make_fragment@ $(EXTRA_DATA:%=$(DESTDIR)$(pkglibdir)/%) $(ALL_PKGCONFIG_FILES) ## Files built (autoconfed) but not installed -LOCAL_BUILT_FILES = icudefs.mk config/icucross.mk +LOCAL_BUILT_FILES = icudefs.mk config/icucross.mk config/icucross.inc DOCDIRS = common i18n -SUBDIRS = stubdata common i18n $(LAYOUT) tools data $(ICUIO) $(EXTRA) $(SAMPLE) $(TEST) +SUBDIRS = stubdata common i18n $(LAYOUTEX) $(ICUIO) $(TOOLS) data $(EXTRA) $(SAMPLE) $(TEST) SECTION = 1 @@ -86,6 +92,9 @@ xcheck: all xcheck-recursive xperf: all xperf-recursive check-exhaustive: all check-exhaustive-recursive +pcheck: all tests + @$(MAKE) -C test pcheck + check-exhaustive-local: check-local xcheck-recursive: all xcheck-local @@ -104,12 +113,16 @@ doc doc-searchengine: else doc: doc/html/index.html -doc-searchengine: Doxyfile $(wildcard ./common/unicode/platform.h $(srcdir)/common/unicode/*.h $(srcdir)/i18n/unicode/*.h $(srcdir)/layout/unicode/*.h $(srcdir)/io/unicode/*.h) +doc-searchengine: Doxyfile $(wildcard ./common/unicode/platform.h $(srcdir)/common/unicode/*.h $(srcdir)/i18n/unicode/*.h $(srcdir)/io/unicode/*.h) sed < Doxyfile -e 's%[^#]*SEARCHENGINE.*%SEARCHENGINE=YES%' | $(DOXYGEN) - + @echo adding links from non-namespaced class files + find doc/html -name 'classicu_1_1*' -print | sed -e 's%^\(.*class\)icu_1_1\(.*\)$$%ln & \1\2%' | sh @echo Docs created - WARNING, probably contains non-GPL .js files -doc/html/index.html: Doxyfile $(wildcard ./common/unicode/platform.h $(srcdir)/common/unicode/*.h $(srcdir)/i18n/unicode/*.h $(srcdir)/layout/unicode/*.h $(srcdir)/io/unicode/*.h) +doc/html/index.html: Doxyfile $(wildcard ./common/unicode/platform.h $(srcdir)/common/unicode/*.h $(srcdir)/i18n/unicode/*.h $(srcdir)/io/unicode/*.h) $(DOXYGEN) + @echo adding links from non-namespaced class files + find doc/html -name 'classicu_1_1*' -print | sed -e 's%^\(.*class\)icu_1_1\(.*\)$$%ln & \1\2%' | sh Doxyfile: $(srcdir)/Doxyfile.in CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status @@ -120,13 +133,17 @@ $(DOCZIP): doc endif LOCAL_SUBDIRS = $(SUBDIRS) -CLEAN_FIRST_SUBDIRS = tools +CLEAN_FIRST_SUBDIRS = $(TOOLS) $(LIBDIR) $(BINDIR): -$(MKINSTALLDIRS) $@ ## Recursive targets all-recursive install-recursive clean-recursive distclean-recursive dist-recursive check-recursive check-exhaustive-recursive: $(LIBDIR) $(BINDIR) +ifneq ($(NEED_ESCAPING),) + @echo "building tools/escapesrc (Needed for this platform with NEED_ESCAPING)" + @(cd tools/escapesrc && $(MAKE) RECURSIVE=YES $$local_target) || exit +endif @dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ list='$(LOCAL_SUBDIRS)'; for subdir in $$list; do \ @@ -147,9 +164,16 @@ clean-recursive-with-twist: $(MAKE) clean-recursive LOCAL_SUBDIRS='$(CLEAN_FIRST_SUBDIRS) $(filter-out $(CLEAN_FIRST_SUBDIRS),$(LOCAL_SUBDIRS))' all-local: $(srcdir)/configure $(LOCAL_BUILT_FILES) $(INSTALLED_BUILT_FILES) - +ifndef VERBOSE + @echo "Note: rebuild with \"$(MAKE) VERBOSE=1 $(MAKECMDGOALS)\" to show all compiler parameters." +endif install-local: install-icu install-manx +# always installs. Used by layoutex. +install-pkgconfig: $(ALL_PKGCONFIG_FILES) + @$(MKINSTALLDIRS) $(DESTDIR)$(libdir)/pkgconfig + $(INSTALL_DATA) $(ALL_PKGCONFIG_FILES) $(DESTDIR)$(libdir)/pkgconfig/ + install-icu: $(INSTALLED_BUILT_FILES) @$(MKINSTALLDIRS) $(DESTDIR)$(pkgdatadir)/config @$(MKINSTALLDIRS) $(DESTDIR)$(pkglibdir) @@ -160,7 +184,7 @@ install-icu: $(INSTALLED_BUILT_FILES) $(INSTALL_SCRIPT) $(top_srcdir)/install-sh $(DESTDIR)$(pkgdatadir)/install-sh @$(MKINSTALLDIRS) $(DESTDIR)$(libdir)/pkgconfig $(INSTALL_DATA) $(ALL_PKGCONFIG_FILES) $(DESTDIR)$(libdir)/pkgconfig/ - $(INSTALL_DATA) $(top_srcdir)/../license.html $(DESTDIR)$(pkgdatadir)/license.html + $(INSTALL_DATA) $(top_srcdir)/../LICENSE $(DESTDIR)$(pkgdatadir)/LICENSE $(INSTALL_SCRIPT) $(top_builddir)/config/icu-config $(DESTDIR)$(bindir)/icu-config $(INSTALL_DATA) $(top_builddir)/config/Makefile.inc $(DESTDIR)$(pkglibdir)/Makefile.inc $(INSTALL_DATA) $(top_builddir)/config/pkgdata.inc $(DESTDIR)$(pkglibdir)/pkgdata.inc @@ -176,9 +200,9 @@ install-doc: else install-doc: doc $(RM) -r $(DESTDIR)$(docdir)/$(docsubdir) - $(MKINSTALLDIRS) $(DESTDIR)$(docdir)/$(docsubsrchdir) + $(MKINSTALLDIRS) $(DESTDIR)$(docdir)/$(docsubdir) $(INSTALL_DATA) $(docfiles) $(DESTDIR)$(docdir)/$(docsubdir) - $(INSTALL_DATA) $(docsrchfiles) $(DESTDIR)$(docdir)/$(docsubsrchdir) + endif $(DESTDIR)$(pkglibdir)/%: $(top_srcdir)/../data/% @@ -197,7 +221,7 @@ clean-local: distclean-local: clean-local $(RMV) $(top_builddir)/config/Makefile.inc $(top_builddir)/config/pkgdata.inc $(top_builddir)/config/icu-config $(top_builddir)/config/icu.pc $(ALL_PKGCONFIG_FILES) - $(RMV) config.cache config.log config.status $(top_builddir)/config/icucross.mk autom4te.cache uconfig.h.prepend + $(RMV) config.cache config.log config.status $(top_builddir)/config/icucross.mk $(top_builddir)/config/icucross.inc autom4te.cache uconfig.h.prepend $(RMV) Makefile config/Makefile icudefs.mk $(LIBDIR) $(BINDIR) -$(RMV) dist @@ -211,8 +235,8 @@ xcheck-local: $(top_builddir)/config/icu-config $(top_builddir)/config/Makefile. @test "passed" = "$(shell $(MAKE) --no-print-directory -f $(top_builddir)/config/Makefile.inc SELFCHECK=1 selfcheck)" || (echo "FAIL: Makefile.inc could not run properly." ; exit 1 ) @echo "PASS: config selfcheck OK" -#$(srcdir)/configure : $(srcdir)/configure.in $(top_srcdir)/aclocal.m4 -# cd $(srcdir) && $(AUTOCONF) +#$(srcdir)/configure : $(srcdir)/configure.ac $(top_srcdir)/aclocal.m4 +# cd $(srcdir) && aclocal && $(AUTOCONF) icudefs.mk: $(srcdir)/icudefs.mk.in $(top_builddir)/config.status cd $(top_builddir) \ @@ -226,9 +250,14 @@ config/icucross.mk: $(top_builddir)/icudefs.mk $(top_builddir)/Makefile @(echo 'TOOLBINDIR=$$(cross_buildroot)/bin' ;\ echo 'TOOLLIBDIR=$$(cross_buildroot)/lib' ;\ echo "INVOKE=$(LDLIBRARYPATH_ENVVAR)=$(LIBRARY_PATH_PREFIX)"'$$(TOOLLIBDIR):$$(cross_buildroot)/stubdata:$$(cross_buildroot)/tools/ctestfw:$$$$'"$(LDLIBRARYPATH_ENVVAR)" ;\ - echo "PKGDATA_INVOKE=$(LDLIBRARYPATH_ENVVAR)=$(LIBRARY_PATH_PREFIX)"'$$(cross_buildroot)/stubdata:$$(cross_buildroot)/tools/ctestfw:$$(TOOLLIBDIR):$$$$'"$(LDLIBRARYPATH_ENVVAR) "'$$'"(PKGDATA_INVOKE_OPTS)" ;\ + echo "PKGDATA_INVOKE=$(LDLIBRARYPATH_ENVVAR)=$(LIBRARY_PATH_PREFIX)"'$$(cross_buildroot)/stubdata:$$(cross_buildroot)/tools/ctestfw:$$(TOOLLIBDIR):$$$$'"$(LDLIBRARYPATH_ENVVAR) " ;\ echo ) >> $@ +config/icucross.inc: $(top_builddir)/icudefs.mk $(top_builddir)/Makefile @platform_make_fragment@ + @echo rebuilding $@ + @(grep '^CURR_FULL_DIR' $(top_builddir)/icudefs.mk ; \ + grep '^CURR_FULL_DIR' @platform_make_fragment@ || echo ""; \ + ) > $@ config/icu.pc: $(srcdir)/config/icu.pc.in cd $(top_builddir) \ @@ -258,19 +287,22 @@ config/icu-io.pc: config/icu.pc Makefile icudefs.mk @echo "Libs:" "${ICULIBS_IO}" >> $@ @echo $@ updated. -config/icu-le.pc: config/icu.pc Makefile icudefs.mk - @cat config/icu.pc > $@ - @echo "Description: $(PACKAGE_ICU_DESCRIPTION): Layout library" >> $@ - @echo "Name: $(PACKAGE)-le" >> $@ - @echo "Requires: icu-uc" >> $@ - @echo "Libs:" "${ICULIBS_LE}" >> $@ - @echo $@ updated. +ICULEHB_LIBS=@ICULEHB_LIBS@ +USING_HB= +ifneq ($(ICULEHB_LIBS),) +USING_HB=(Using HarfBuzz) +endif + config/icu-lx.pc: config/icu.pc Makefile icudefs.mk @cat config/icu.pc > $@ - @echo "Description: $(PACKAGE_ICU_DESCRIPTION): Paragraph Layout library" >> $@ + @echo "Description: $(PACKAGE_ICU_DESCRIPTION): Paragraph Layout library $(USING_HB)" >> $@ @echo "Name: $(PACKAGE)-lx" >> $@ +ifneq ($(ICULEHB_LIBS),) + @echo "Requires: icu-le-hb icu-uc" >> $@ +else @echo "Requires: icu-le" >> $@ +endif @echo "Libs:" "${ICULIBS_LX}" >> $@ @echo $@ updated. @@ -295,11 +327,11 @@ $(top_builddir)/config/icu-config: $(top_builddir)/Makefile $(top_srcdir)/config -$(RMV) $@ $(INSTALL_SCRIPT) $(top_srcdir)/config/icu-config-top $@ chmod u+w $@ + @echo "# Following from icu/icu4c/source/config/Makefile.inc" >> $@ + LC_ALL=C $(SED) -f $(top_srcdir)/config/make2sh.sed < $(top_builddir)/config/Makefile.inc | grep -v '#M#' | uniq >> $@ @echo "# Following from @platform_make_fragment@" >> $@ - LC_ALL=C sed -f $(top_srcdir)/config/make2sh.sed < $(top_builddir)/config/Makefile.inc | grep -v '#M#' | uniq >> $@ - LC_ALL=C sed -f $(top_srcdir)/config/make2sh.sed < @platform_make_fragment@ | grep -v '#M#' | uniq >> $@ + LC_ALL=C $(SED) -f $(top_srcdir)/config/make2sh.sed < @platform_make_fragment@ | grep -v '#M#' | uniq >> $@ cat $(top_srcdir)/config/icu-config-bottom >> $@ - echo "# Rebuilt on "`date` >> $@ chmod u-w $@ config.status: $(srcdir)/configure $(srcdir)/common/unicode/uvernum.h @@ -347,7 +379,7 @@ update-windows-makefiles: config.status # For building a source distribution. distcheck dist-local: - $(MAKE) -C . -f config/dist.mk srcdir="$(srcdir)" top_srcdir="$(top_srcdir)" $@ + $(MAKE) -C . -f $(top_srcdir)/config/dist.mk srcdir="$(srcdir)" top_srcdir="$(top_srcdir)" $@ ifeq ($(DESTDIR),) releaseDist: