X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/46f4442e9a5a4f3b98b7c1083586332f6a8a99a4..340931cb2e044a2141d11567dd0f782524e32994:/icuSources/icudefs.mk.in diff --git a/icuSources/icudefs.mk.in b/icuSources/icudefs.mk.in index 4167822f..59d82052 100644 --- a/icuSources/icudefs.mk.in +++ b/icuSources/icudefs.mk.in @@ -2,12 +2,14 @@ # # Yves Arrouye. # -# Copyright (C) 2000-2008, International Business Machines Corporation and others. +# Copyright (C) 2016 and later: Unicode, Inc. and others. +# License & terms of use: http://www.unicode.org/copyright.html +# Copyright (C) 2000-2016, International Business Machines Corporation and others. # All Rights Reserved. # # Some of these variables are overridden in the config/mh-* files. -# +# # Please be sure to update config/Makefile.inc.in if you add something here. # @@ -15,6 +17,9 @@ SHELL = @SHELL@ +# Instruct Python to never write any byte code to the ICU source tree. +export PYTHONDONTWRITEBYTECODE = 1 + # Standard directories prefix = @prefix@ @@ -28,9 +33,14 @@ libdir = @libdir@ includedir = @includedir@ mandir = @mandir@ sysconfdir = @sysconfdir@ +# controls the include of $(top_builddir)/icucross.mk at bottom of file +cross_compiling = @cross_compiling@ +cross_buildroot = @cross_buildroot@ # Package information +PACKAGE_ICU_DESCRIPTION = "International Components for Unicode" +PACKAGE_ICU_URL = "http://icu-project.org" PACKAGE = @PACKAGE@ VERSION = @VERSION@ UNICODE_VERSION = @UNICODE_VERSION@ @@ -45,7 +55,8 @@ SO_TARGET_VERSION_MAJOR = @LIB_VERSION_MAJOR@ ICUDATA_DIR = @pkgicudatadir@/$(PACKAGE)$(ICULIBSUFFIX)/$(VERSION) ICUDATA_BASENAME_VERSION = $(ICUPREFIX)dt@LIB_VERSION_MAJOR@ -ICUDATA_ENTRY_POINT = $(ICUDATA_BASENAME_VERSION) +# the entry point is almost like the basename, but has the lib suffix. +ICUDATA_ENTRY_POINT = $(ICUPREFIX)dt@ICULIBSUFFIXCNAME@@LIB_VERSION_MAJOR@ ICUDATA_CHAR = @ICUDATA_CHAR@ ICUDATA_PLATFORM_NAME = $(ICUDATA_BASENAME_VERSION)$(ICUDATA_CHAR) PKGDATA_LIBSTATICNAME = -L $(STATIC_PREFIX)$(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX) @@ -61,12 +72,16 @@ ICUDATA_NAME = $(ICUDATA_PLATFORM_NAME) PKGDATA_LIBNAME = -L $(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX) ICUPKGDATA_DIR = $(libdir) else +ifeq ($(PKGDATA_MODE),static) +ICUDATA_NAME = $(ICUDATA_PLATFORM_NAME) +PKGDATA_LIBNAME = -L $(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX) +ICUPKGDATA_DIR = $(libdir) +else ICUDATA_NAME = $(ICUDATA_PLATFORM_NAME) ICUPKGDATA_DIR = $(ICUDATA_DIR) endif endif -# This is needed so that make -j2 doesn't complain when invoking pkgdata's make -PKGDATA_INVOKE_OPTS = MAKEFLAGS= +endif # These are defined here because mh-cygwin-msvc needs to override these values. ICUPKGDATA_INSTALL_DIR = $(DESTDIR)$(ICUPKGDATA_DIR) @@ -105,13 +120,16 @@ AR = @AR@ ARFLAGS = @ARFLAGS@ r RANLIB = @RANLIB@ COMPILE_LINK_ENVVAR = @COMPILE_LINK_ENVVAR@ +UCLN_NO_AUTO_CLEANUP = @UCLN_NO_AUTO_CLEANUP@ +SED = @SED@ # Various flags for the tools # DEFS is for common macro definitions. # configure prevents user defined DEFS, and configure's DEFS is not needed # So we ignore the DEFS that comes from configure -DEFS = +# U_ATTRIBUTE_DEPRECATED is defined to hide warnings about deprecated API warnings. +DEFS = -DU_ATTRIBUTE_DEPRECATED= # CFLAGS is for C only flags CFLAGS = @CFLAGS@ # CXXFLAGS is for C++ only flags @@ -145,20 +163,39 @@ ENABLE_SHARED = @ENABLE_SHARED@ # Echo w/o newline -#ECHO_N = @ECHO_N@ -#ECHO_C = @ECHO_C@ +#ECHO_N = @ICU_ECHO_N@ +#ECHO_C = @ICU_ECHO_C@ # Commands to compile COMPILE.c= $(CC) $(CPPFLAGS) $(DEFS) $(CFLAGS) -c COMPILE.cc= $(CXX) $(CPPFLAGS) $(DEFS) $(CXXFLAGS) -c # Commands to link -LINK.c= $(CC) $(CFLAGS) $(LDFLAGS) -LINK.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) +LINK.c= $(CC) $(CFLAGS) $(LDFLAGS) $(LINKFLAGS) +LINK.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) $(LINKFLAGS) # Commands to make a shared library -SHLIB.c= $(CC) $(CFLAGS) $(LDFLAGS) -shared -SHLIB.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) -shared +SHLIB.c= $(CC) $(CFLAGS) $(LDFLAGS) -shared $(LD_SOOPTIONS) +SHLIB.cc= $(CXX) $(CXXFLAGS) $(LDFLAGS) -shared $(LD_SOOPTIONS) + +# ICU_MSG +ICU_MSG=@echo " $(1) " + +# Do not show the large compiling arguments by default. +# To use: +# change +# $(CC) -o foo +# to +# $(call SILENT_COMPILE,$(CC) -o foo) +ifndef VERBOSE + SILENT_COMPILE=$(call ICU_MSG,$(notdir $(firstword $(1)))) "... " $< && $(1) || \ + ( echo "*** Failed compilation command follows: ----------------------------------------------------------" ; \ + echo "$(1)" ; \ + echo "--- ( rebuild with \"$(MAKE) VERBOSE=1 $(MAKECMDGOALS)\" to show all parameters ) --------" ; \ + false ) +else + SILENT_COMPILE=$(1) +endif # Environment variable to set a runtime search path LDLIBRARYPATH_ENVVAR = LD_LIBRARY_PATH @@ -203,41 +240,95 @@ LIBDIR=$(top_builddir)/lib # Location of the executables before "make install" is used BINDIR=$(top_builddir)/bin -# Current full path directory. -CURR_FULL_DIR=$(shell pwd) -# Current full path directory for use in source code in a -D compiler option. -CURR_SRCCODE_FULL_DIR=$(shell pwd) +# overridden by icucross.mk +TOOLBINDIR=$(BINDIR) +TOOLLIBDIR=$(LIBDIR) # Name flexibility for the library naming scheme. Any modifications should # be made in the mh- file for the specific platform. DATA_STUBNAME = data COMMON_STUBNAME = uc I18N_STUBNAME = i18n -LAYOUT_STUBNAME = le LAYOUTEX_STUBNAME = lx IO_STUBNAME = io TOOLUTIL_STUBNAME = tu CTESTFW_STUBNAME = test +# get these from pkg-config, if available +ICULEHB_CFLAGS=@ICULEHB_CFLAGS@ +ICULEHB_LIBS=@ICULEHB_LIBS@ +ifneq ($(ICULEHB_CFLAGS),) +USING_ICULEHB=yes +ICULEHB_TRUE= +ICULEHB_FALSE=# +ICULIBS_LE=$(ICULEHB_LIBS) +ICULE_CFLAGS=$(ICULEHB_CFLAGS) -DUSING_ICULEHB +else +USING_ICULEHB=no +ICULEHB_TRUE=# +ICULEHB_FALSE= +endif + +# Just the libs. +ICULIBS_DT = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +ICULIBS_UC = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(COMMON_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +ICULIBS_I18N = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(I18N_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +ICULIBS_LX = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(LAYOUTEX_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +ICULIBS_IO = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(IO_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +ICULIBS_CTESTFW = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(CTESTFW_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +ICULIBS_TOOLUTIL = -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(TOOLUTIL_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) # Link commands to link to ICU libs -LIBICUDT= -L$(LIBDIR) -L$(top_builddir)/stubdata -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(DATA_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) -LIBICUUC= -L$(LIBDIR) -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(COMMON_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) $(LIBICUDT) -LIBICUI18N= -L$(LIBDIR) -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(I18N_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) -LIBICULE= -L$(LIBDIR) -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(LAYOUT_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) -LIBICULX= -L$(LIBDIR) -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(LAYOUTEX_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) -LIBCTESTFW= -L$(top_builddir)/tools/ctestfw -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(CTESTFW_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) -LIBICUTOOLUTIL= -L$(LIBDIR) -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(TOOLUTIL_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) -LIBICUIO= -L$(LIBDIR) -l$(STATIC_PREFIX_WHEN_USED)$(ICUPREFIX)$(IO_STUBNAME)$(ICULIBSUFFIX)$(SO_TARGET_VERSION_SUFFIX) +LLIBDIR = -L$(LIBDIR) +LSTUBDIR = -L$(top_builddir)/stubdata +LCTESTFW = -L$(top_builddir)/tools/ctestfw + +LIBICUDT = $(LLIBDIR) $(LSTUBDIR) $(ICULIBS_DT) +LIBICUUC = $(LLIBDIR) $(ICULIBS_UC) $(LSTUBDIR) $(ICULIBS_DT) +LIBICUI18N = $(LLIBDIR) $(ICULIBS_I18N) +LIBICULE = $(ICULEHB_CFLAGS) $(LLIBDIR) $(ICULIBS_LE) +LIBICULX = $(LLIBDIR) $(ICULIBS_LX) +LIBCTESTFW = $(LCTESTFW) $(ICULIBS_CTESTFW) +LIBICUTOOLUTIL = $(LLIBDIR) $(ICULIBS_TOOLUTIL) +LIBICUIO = $(LLIBDIR) $(ICULIBS_IO) # Invoke, set library path for all ICU libraries. +# overridden by icucross.mk INVOKE = $(LDLIBRARYPATH_ENVVAR)=$(LIBRARY_PATH_PREFIX)$(LIBDIR):$(top_builddir)/stubdata:$(top_builddir)/tools/ctestfw:$$$(LDLIBRARYPATH_ENVVAR) $(LEAK_CHECKER) +# prefer stubdata +PKGDATA_INVOKE = $(LDLIBRARYPATH_ENVVAR)=$(top_builddir)/stubdata:$(top_builddir)/tools/ctestfw:$(LIBRARY_PATH_PREFIX)$(LIBDIR):$$$(LDLIBRARYPATH_ENVVAR) $(LEAK_CHECKER) +INSTALLED_INVOKE = $(LDLIBRARYPATH_ENVVAR)=$(libdir):$$$(LDLIBRARYPATH_ENVVAR) + +# Current full path directory for cross compilation +ifneq ($(strip $(cross_buildroot)),) +include $(cross_buildroot)/config/icucross.inc +endif # Platform-specific setup include @platform_make_fragment@ +# Current full path directory. +CURR_FULL_DIR?=$(shell pwd | sed 's/ /\\ /g') +# Current full path directory for use in source code in a -D compiler option. +CURR_SRCCODE_FULL_DIR?=$(shell pwd | sed 's/ /\\ /') + # When shared libraries are disabled and static libraries are enabled, # the C++ compiler must be used to link in the libraries for the tools. ifneq ($(ENABLE_SHARED),YES) LINK.c = $(LINK.cc) endif +# some imported things from the cross env +TOOLEXEEXT = $(EXEEXT) +ifneq ($(strip $(cross_buildroot)),) +include $(cross_buildroot)/config/icucross.mk +else +cross_buildroot = $(top_builddir) +endif + +# for tests +ifneq ($(TEST_STATUS_FILE),) +TEST_OUTPUT_OPTS="-E$(TEST_STATUS_FILE)" +endif + +# optional include at top +-include $(top_builddir)/icudefs.local